出版社を探す

Juliaによる数理最適化

著:小林 和博

紙版

内容紹介

【読書対象】
数理最適化を用いていろいろな分野の問題を解きたい方で,パッケージを用いた迅速なモデル構築の方法を学びたい方を読者として想定している。

【書籍の特徴】
科学技術計算で用いられるプログラミング言語であるJuliaでは,数理最適化のための便利なパッケージが利用可能である。本書では,これらのパッケージを用いて,様々なクラスの最適化問題を解く方法を解説する。取り上げたのは,現実に遭遇する問題を解く際に有用な,適用範囲が広く,よく用いられる最適化問題である。

本書では,錐構造を持つ最適化問題として,線形最適化問題(LP)の他に,2次錐最適化問題(SOCP)と半正定値最適化問題(SDP)も扱っている。最近のアルゴリズム研究とその実装技術の進展により,LPと比較して計算量の大きいSOCPとSDPも,手軽に用いることのできる数理最適化問題とみなせるようになってきた。SOCPとSDPはLPよりもモデル化能力が高く,様々な分野の問題の解決に有効であるが,それらをコンピュータを用いて解く方法を扱った書籍は少ない。本書では,Juliaでこれらの問題を解く方法を解説している。また,離散最適化と連続最適化の両方を扱うことで,読者が遭遇する幅広い問題を解く技術が身につけられるように留意した。

本書で取り扱っている数理最適化問題のクラスは,下記の通りである。
- 連続最適化問題
⇒線形最適化問題,2次最適化問題,2次錐最適化問題,半正定値最適化問題
- 離散最適化問題
⇒最短路問題,最大流問題,整数線形最適化問題,整数2次錐最適化問題

そして,これらを用いて解く問題として取り上げたのは,下記の通りである。
- 輸送最適化問題,巡回セールスマン問題,施設配置問題,信号推定問題,多項式最適化問題,最大カット問題の緩和解法,データ分類問題

【著者からのメッセージ】
数理最適化モデルの数式表現を理解すること自体は,四則演算がわかれば可能である。和の記号や行列に慣れれば中学生・高校生にも特に難しいところはないと思う。一方で,コンピュータを用いて数理最適化モデルを表現して解くためには,入口のところでいくらか手引きが必要かもしれない。本書は,そのような手引きとなることを目指した。いったん入口から入ってしまえば,より複雑なモデルに取り組むことはそれほど難しくないと思う。読者の方々が,本書を数理最適化の豊かな世界への入り口にされることを望んでいる。

目次

1.Juliaの利用環境の構築
1.1 Juliaのインストール
1.2 Juliaでのパッケージ管理
1.3 モデラーとソルバー
2.Juliaの基礎知識
2.1 ベクトル
2.2 行列
 2.2.1 密行列の表現
 2.2.2 疎行列の表現
2.3 線形演算
 2.3.1 ベクトルとスカラーの演算
 2.3.2 ベクトル同士の演算
 2.3.3 行列とベクトルの積
 2.3.4 行列同士の積
2.4 反復処理
3.数理最適化の概要
3.1 変数と定数
3.2 目的関数
3.3 制約条件
3.4 数理最適化問題の分類
 3.4.1 凸最適化問題と非凸最適化問題
 3.4.2 線形最適化問題
 3.4.3 2次最適化問題
 3.4.4 整数最適化問題
 3.4.5 半正定値最適化問題
4.線形最適化問題
4.1 問題例:栄養素の問題
4.2 変数と定数
4.3 目的関数
4.4 制約条件
4.5 定式化
4.6 解法
 4.6.1 単体法
 4.6.2 内点法
 4.6.3 プログラムを用いた求解
 4.6.4 実行可能な問題例の生成
4.7 双対問題
4.8 潜在価格
4.9 輸送最適化問題
5.グラフ最適化問題
5.1 グラフの表現
5.2 最短路問題
 5.2.1 整数最適化問題として解く方法
 5.2.2 ダイクストラ法を用いて解く方法
5.3 最大流問題
6.整数最適化問題
6.1 集合分割問題
6.2 巡回セールスマン問題
 6.2.1 不完全な定式化
 6.2.2 完全な定式化
6.3 施設配置問題
7.2次最適化問題
7.1 ソルバーを用いて解く方法
7.2 信号推定問題
8.2次錐最適化問題
8.12 次錐と2次錐最適化問題
8.2 多項式最適化問題
8.3 信号推定問題のよい定式化
9.半正定値最適化問題
9.1 最大カット問題の緩和解
9.2 データ分類問題
 9.2.1 線形分類
 9.2.2 2次関数による分類
引用・参考文献
索引

ISBN:9784339029345
出版社:コロナ社
判型:A5
ページ数:208ページ
定価:3200円(本体)
発行年月日:2023年05月
発売日:2023年04月12日
国際分類コード【Thema(シーマ)】 1:PBT