自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Python進(jìn)行線性規(guī)劃示例

開發(fā) 后端
運(yùn)籌學(xué)是一種科學(xué)的決策方法,它通常是在需要分配稀缺資源的條件下,尋求系統(tǒng)的優(yōu)秀設(shè)計(jì)??茖W(xué)的決策方法需要使用一個(gè)或多個(gè)數(shù)學(xué)模型(優(yōu)化模型)來(lái)做出最優(yōu)決策。

 運(yùn)籌學(xué)

運(yùn)籌學(xué)是一種科學(xué)的決策方法,它通常是在需要分配稀缺資源的條件下,尋求系統(tǒng)的優(yōu)秀設(shè)計(jì)??茖W(xué)的決策方法需要使用一個(gè)或多個(gè)數(shù)學(xué)模型(優(yōu)化模型)來(lái)做出最優(yōu)決策。

[[326053]]

優(yōu)化模型試圖在滿足給定約束的決策變量的所有值的集合中,找到優(yōu)化(最大化或最小化)目標(biāo)函數(shù)的決策變量的值。 它的三個(gè)主要組成部分是:

  1. 目標(biāo)函數(shù):要優(yōu)化的函數(shù)(最大化或最小化)。
  2. 決策變量:影響系統(tǒng)性能的可控變量。
  3. 約束:決策變量的一組約束(即線性不等式或等式)。非負(fù)性約束限制了決策變量取正值。

優(yōu)化模型的解稱為最優(yōu)可行解。

建模步驟

對(duì)運(yùn)籌學(xué)問題進(jìn)行準(zhǔn)確建模是很重要的任務(wù),也是很困難的任務(wù)。錯(cuò)誤的模型會(huì)導(dǎo)致錯(cuò)誤的解決方案,從而不能解決原來(lái)的問題。團(tuán)隊(duì)成員應(yīng)按照以下步驟進(jìn)行建模:

  1. 問題定義:定義項(xiàng)目的范圍,并確定三個(gè)要素:決策變量、目標(biāo)和限制(即約束)。
  2. 模型構(gòu)建:將問題定義轉(zhuǎn)化為數(shù)學(xué)關(guān)系。
  3. 模型求解:使用標(biāo)準(zhǔn)優(yōu)化算法。在獲得解后,需要進(jìn)行靈敏度分析,以找出由于某些參數(shù)的變化而導(dǎo)致的解的行為。
  4. 模型有效性:檢查模型是否按預(yù)期工作。
  5. 實(shí)現(xiàn):將模型和結(jié)果轉(zhuǎn)換為解決方案。

線性規(guī)劃

線性規(guī)劃(Linear Programming,也稱為L(zhǎng)P)是一種運(yùn)籌學(xué)技術(shù),當(dāng)當(dāng)所有的目標(biāo)和約束都是線性的(在變量中)并且當(dāng)所有的決策變量都是連續(xù)的時(shí)使用。線性規(guī)劃是最簡(jiǎn)單的運(yùn)籌學(xué)方法。

Python的SciPy庫(kù)包含用于解決線性編程問題的linprog函數(shù)。在使用linprog時(shí),編寫代碼要考慮的兩個(gè)注意事項(xiàng):

  1. 這個(gè)問題必須表述為一個(gè)最小化問題。
  2. 不等式必須表示為≤。

最小化問題

讓我們考慮以下要解決的最小化問題:

 

使用Python進(jìn)行線性規(guī)劃示例

 

讓我們看一下Python代碼:

 

  1. # Import required libraries 
  2. import numpy as np 
  3. from scipy.optimize import linprog 
  4.  
  5. Set the inequality constraints matrix 
  6. # Note: the inequality constraints must be in the form of <= 
  7. A = np.array([[-1, -1, -1], [-1, 2, 0], [0, 0, -1], [-1, 0, 0], [0, -1, 0], [0, 0, -1]]) 
  8.  
  9. Set the inequality constraints vector 
  10. b = np.array([-1000, 0, -340, 0, 0, 0]) 
  11.  
  12. Set the coefficients of the linear objective function vector 
  13. c = np.array([10, 15, 25]) 
  14.  
  15. # Solve linear programming problem 
  16. res = linprog(c, A_ub=A, b_ub=b) 
  17.  
  18. # Print results 
  19. print('Optimal value:', round(res.fun, ndigits=2), 
  20.       '\nx values:', res.x, 
  21.       '\nNumber of iterations performed:', res.nit, 
  22.       '\nStatus:', res.message) 

輸出結(jié)果:

 

  1. # Optimal value: 15100.0  
  2. # x values: [6.59999996e+02 1.00009440e-07 3.40000000e+02]  
  3. # Number of iterations performed: 7  
  4. # Status: Optimization terminated successfully. 

最大化問題

由于Python的SciPy庫(kù)中的linprog函數(shù)是用來(lái)解決最小化問題的,因此有必要對(duì)原始目標(biāo)函數(shù)進(jìn)行轉(zhuǎn)換。通過將目標(biāo)函數(shù)的系數(shù)乘以-1(即通過改變其符號(hào)),可以將最小化問題轉(zhuǎn)化為一個(gè)最大化問題。

讓我們考慮下面需要解決的最大化問題:

 

使用Python進(jìn)行線性規(guī)劃示例

 

讓我們看一下Python的實(shí)現(xiàn):

 

  1. # Import required libraries 
  2. import numpy as np 
  3. from scipy.optimize import linprog 
  4.  
  5. Set the inequality constraints matrix 
  6. # Note: the inequality constraints must be in the form of <= 
  7. A = np.array([[1, 0], [2, 3], [1, 1], [-1, 0], [0, -1]]) 
  8.  
  9. Set the inequality constraints vector 
  10. b = np.array([16, 19, 8, 0, 0]) 
  11.  
  12. Set the coefficients of the linear objective function vector 
  13. # Note: when maximizing, change the signs of the c vector coefficient 
  14. c = np.array([-5, -7]) 
  15.  
  16. # Solve linear programming problem 
  17. res = linprog(c, A_ub=A, b_ub=b) 
  18.  
  19. # Print results 
  20. print('Optimal value:', round(res.fun*-1, ndigits=2), 
  21.       '\nx values:', res.x, 
  22.       '\nNumber of iterations performed:', res.nit, 
  23.       '\nStatus:', res.message) 

上述代碼的輸出結(jié)果為:

 

  1. # Optimal value: 46.0  
  2. # x values: [5. 3.]  
  3. # Number of iterations performed: 5  
  4. # Status: Optimization terminated successfully. 

最后

線性規(guī)劃為更好的決策提供了一種很好的優(yōu)化技術(shù)。Python的SciPy庫(kù)中的linprog函數(shù)允許只用幾行代碼就可以解決線性編程問題。雖然還有其他免費(fèi)的優(yōu)化軟件(如GAMS、AMPL、TORA、LINDO),但使用linprog函數(shù)可以節(jié)省大量時(shí)間。

責(zé)任編輯:華軒 來(lái)源: 今日頭條
相關(guān)推薦

2023-10-20 16:14:43

2022-12-19 15:16:46

機(jī)器學(xué)習(xí)模型

2020-08-25 18:10:22

Python代碼線性回歸

2023-08-15 16:20:42

Pandas數(shù)據(jù)分析

2024-06-11 00:00:01

用ReactGraphQLCRUD

2024-03-01 07:26:49

RustPolars機(jī)器學(xué)習(xí)

2024-07-03 11:31:53

2024-01-30 01:12:37

自然語(yǔ)言時(shí)間序列預(yù)測(cè)Pytorch

2021-02-22 13:44:41

開發(fā)Python金融

2023-04-12 08:00:00

人工智能ChatGPTPython

2022-06-09 09:14:31

機(jī)器學(xué)習(xí)PythonJava

2018-09-08 09:25:05

編程語(yǔ)言PythonVS Code

2020-10-15 12:00:01

Python 開發(fā)編程語(yǔ)言

2018-10-10 14:21:06

Python 工具程序員

2022-06-05 21:16:08

機(jī)器學(xué)習(xí)Python

2021-03-19 17:59:30

深度學(xué)習(xí)音頻程序

2022-04-02 21:46:27

深度學(xué)習(xí)編碼器圖像修復(fù)

2021-03-29 10:56:51

人工智能深度學(xué)習(xí)

2019-09-02 10:51:59

Python腳本語(yǔ)言程序員

2021-03-28 23:03:50

Python程序員編碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)