欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Python如何實現(xiàn)線性規(guī)劃

本文小編為大家詳細介紹“Python如何實現(xiàn)線性規(guī)劃”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“Python如何實現(xiàn)線性規(guī)劃”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

成都網(wǎng)站建設哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、小程序制作、集團企業(yè)網(wǎng)站制作等服務項目。核心團隊均擁有互聯(lián)網(wǎng)行業(yè)多年經(jīng)驗,服務眾多知名企業(yè)客戶;涵蓋的客戶類型包括:宣傳片制作等眾多領域,積累了大量豐富的經(jīng)驗,同時也獲得了客戶的一致認可!

 運籌學

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

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

  1. 目標函數(shù):要優(yōu)化的函數(shù)(最大化或最小化)。

  2. 決策變量:影響系統(tǒng)性能的可控變量。

  3. 約束:決策變量的一組約束(即線性不等式或等式)。非負性約束限制了決策變量取正值。

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

建模步驟

對運籌學問題進行準確建模是很重要的任務,也是很困難的任務。錯誤的模型會導致錯誤的解決方案,從而不能解決原來的問題。團隊成員應按照以下步驟進行建模:

  1. 問題定義:定義項目的范圍,并確定三個要素:決策變量、目標和限制(即約束)。

  2. 模型構建:將問題定義轉(zhuǎn)化為數(shù)學關系。

  3. 模型求解:使用標準優(yōu)化算法。在獲得解后,需要進行靈敏度分析,以找出由于某些參數(shù)的變化而導致的解的行為。

  4. 模型有效性:檢查模型是否按預期工作。

  5. 實現(xiàn):將模型和結果轉(zhuǎn)換為解決方案。

線性規(guī)劃

線性規(guī)劃(Linear  Programming,也稱為LP)是一種運籌學技術,當當所有的目標和約束都是線性的(在變量中)并且當所有的決策變量都是連續(xù)的時使用。線性規(guī)劃是最簡單的運籌學方法。

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

  1. 這個問題必須表述為一個最小化問題。

  2. 不等式必須表示為≤。

最小化問題

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

Python如何實現(xiàn)線性規(guī)劃

讓我們看一下Python代碼:

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

輸出結果:

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

最大化問題

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

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

Python如何實現(xiàn)線性規(guī)劃

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

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

上述代碼的輸出結果為:

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

讀到這里,這篇“Python如何實現(xiàn)線性規(guī)劃”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內(nèi)容的文章,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

標題名稱:Python如何實現(xiàn)線性規(guī)劃
URL標題:http://chinadenli.net/article32/gjeesc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供虛擬主機、網(wǎng)站收錄網(wǎng)站導航、網(wǎng)站設計公司自適應網(wǎng)站、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設