運籌學——matlab實現單純形法
引言
這個程式碼較為簡單易懂,並且每一步幾乎都有詳細的註釋,適合初學者,請放心閱讀。
該matlab程式碼解決的是標準線性規劃下的極大值問題,當然,如果你要解決的是極小值問題,稍加修改就ok了。
完整程式碼
function [x_opt,fx_opt,iter] = simplex(A,b,c)
% 單純形法求解標準形線性規劃問題: max cx s.t. Ax=b x>=0
% x_opt,fx_opt,iter(最優解、最優函式值、迭代次數)
format rat %元素使用分數表示
[m,n] = size(A); %m約束條件個數, n決策變數數
v=nchoosek(1:n,m);
for i=1:size(v,1)
if A(:,v(i,:))==eye(m)
ind_B=v(i,:);
end
end %這幾步主要是為了在係數矩陣中隨機選取幾列,每一次都判斷是否為單位矩陣(基矩陣),並得到基矩陣的列索引
ind_N = setdiff(1:n, ind_B); %非基變數的索引,原理是返回在1:n中出現而不在ind_B即基變數索引中出現的元素,並從小到大排序
ST = [];
iter=0; %記錄迭代次數
% 迴圈求解
while true
x0 = zeros(n,1);
x0(ind_B) = b; %初始基可行解,令基變數的位置為方程組右邊係數,非基變數取值為0
cB = c(ind_B); %計算cB,即目標函式在基變數處對應的係數
Sigma = zeros(1,n); %Sigma為檢驗數向量
Sigma(ind_N) = c(ind_N) - cB*A(:,ind_N); %計算檢驗數(非基變數),因為基變數對應的初始檢驗數一定為0
[~, k] = max(Sigma); %選出最大檢驗數, 確定進基變數索引k;~表示忽略第一個引數(即最大值),k是索引
Theta = b ./ A(:,k); %計算θ(點除,即矩陣中對應元素相除,得到一個新的矩陣)
Theta(Theta<=0) = 10000;
[~, q] = min(Theta); %選出最小θ
el = ind_B(q); %確定出基變數在係數矩陣中的列索引el, 主元為A(q,k)
vals = [cB',ind_B',b,A,Theta];
vals = [vals; NaN, NaN, NaN, Sigma, NaN];
ST = [ST; vals];
disp(ST);
if ~any(Sigma > 0) %所有檢驗數都小於0,此基可行解為最優解, any表示存在某個檢驗數>0
x_opt = x0;
fx_opt = c * x_opt; %算出最優解
return
end
if all(A(:,k) <= 0) %表示檢驗數這一列每個數都<=0,有無界解
x_opt = [];
break
end
% 換基
ind_B(ind_B == el) = k; %新的基變數索引
ind_N = setdiff(1:n, ind_B); %非基變數索引
% 更新A和b
A(:,ind_N) = A(:,ind_B) \ A(:,ind_N); %基矩陣的逆乘以非基矩陣
b = A(:,ind_B) \ b; %基矩陣的逆乘以b
A(:,ind_B) = eye(m,m); %基矩陣更新為單位矩陣
iter=iter+1;
end
end
如果覺得還不錯的話,請給博主點個贊再走,謝謝~
相關文章
- 對偶理論和對偶單純形法——Python實現Python
- 對偶單純形法演算法精要演算法
- 線性規劃單純形法精解
- 運籌優化(一)--運籌學概述優化
- sobel運算元,matlab實現Matlab
- 線性規劃之單純形演算法矩陣描述與python實現演算法矩陣Python
- 純CSS實現表單驗證CSS
- 量子圖形加密演算法的MATLAB程式碼實現加密演算法Matlab
- 演算法中的變形金剛——單純形演算法學習筆記演算法筆記
- 【運籌學】P62 2.8
- 運籌學之“折衷係數”
- 【運籌學】P98 3.7(2)
- 運用clip-path的純CSS形狀變換CSS
- WPF實現樹形下拉選單框(TreeComboBox)
- 單一div的正多邊形變換(純CSS)CSS
- 利用transform實現一個純CSS彈出選單ORMCSS
- Python影像處理丨三種實現影像形態學轉化運算模式Python模式
- 運籌優化(五)--線性規劃之內點法優化
- matlab實現人臉識別(數學基礎原理)Matlab
- 巧妙運用clip-path,實現CSS形狀變換CSS
- MATLAB神經網路工具箱(程式碼簡單實現)Matlab神經網路
- 運籌學-整數規劃IP演算法演算法
- 運籌學練習Python精解——指派問題Python
- Vue遞迴元件實現樹形結構選單Vue遞迴元件
- 純js實現 vue 元件 與 vue 單檔案元件對比JSVue元件
- matlab繪製正多邊形Matlab
- 正則實現數學運算
- 水晶藍蓮花(Matlab實現)Matlab
- 機器學習之線性迴歸(純python實現)機器學習Python
- 運籌學練習Python精解——整數規劃Python
- 運籌學練習Python精解——圖與網路Python
- React Native 純 javascript toast實現React NativeJavaScriptAST
- 純 CSS 實現斜紋效果CSS
- 純JS實現走馬燈JS
- 純 Git 實現前端 CI/CDGit前端
- 純CSS實現液晶字型效果CSS
- matlab中出現mex無法編譯的問題Matlab編譯
- 簡單理解async、await語法實現原理AI