成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Python之CVXOPT模塊

LiuZh / 1532人閱讀

摘要:中支持凸規(guī)劃的模塊為其安裝方式為卸載原中的安裝的文件,鏈接為安裝的文件,鏈接為之所以選擇這種安裝方式,是因?yàn)榈暮椭苯拥牟患嫒菪浴?/p>

??Python中支持Convex Optimization(凸規(guī)劃)的模塊為CVXOPT,其安裝方式為:

卸載原Pyhon中的Numpy

安裝CVXOPT的whl文件,鏈接為:https://www.lfd.uci.edu/~gohl...

安裝Numpy+mkl的whl文件,鏈接為:https://www.lfd.uci.edu/~gohl...

之所以選擇這種安裝方式,是因?yàn)镻ython的whl和pip直接install的不兼容性。

??CVXOPT的官方說(shuō)明文檔網(wǎng)址為:http://cvxopt.org/index.html, 現(xiàn)最新版本為1.1.9,由Martin Andersen, Joachim Dahl 和Lieven Vandenberghe共同開發(fā)完成,能夠解決線性規(guī)劃和二次型規(guī)劃問題,其應(yīng)用場(chǎng)景如SVM中的Hard Margin SVM.

??CVXOPT使用舉例如下:

線性規(guī)劃問題

例1:

Python程序代碼:

import numpy as np
from cvxopt import matrix, solvers

A = matrix([[-1.0, -1.0, 0.0, 1.0], [1.0, -1.0, -1.0, -2.0]])
b = matrix([1.0, -2.0, 0.0, 4.0])
c = matrix([2.0, 1.0])

sol = solvers.lp(c,A,b)

print(sol["x"])
print(np.dot(sol["x"].T, c))
print(sol["primal objective"])

輸出結(jié)果:

     pcost       dcost       gap    pres   dres   k/t
 0:  2.6471e+00 -7.0588e-01  2e+01  8e-01  2e+00  1e+00
 1:  3.0726e+00  2.8437e+00  1e+00  1e-01  2e-01  3e-01
 2:  2.4891e+00  2.4808e+00  1e-01  1e-02  2e-02  5e-02
 3:  2.4999e+00  2.4998e+00  1e-03  1e-04  2e-04  5e-04
 4:  2.5000e+00  2.5000e+00  1e-05  1e-06  2e-06  5e-06
 5:  2.5000e+00  2.5000e+00  1e-07  1e-08  2e-08  5e-08
Optimal solution found.
{"primal objective": 2.4999999895543072, "s": <4x1 matrix, tc="d">, "dual infeasibility": 2.257878974569382e-08, "primal slack": 2.0388399547464153e-08, "dual objective": 2.4999999817312535, "residual as dual infeasibility certificate": None, "dual slack": 3.529915972607509e-09, "x": <2x1 matrix, tc="d">, "iterations": 5, "gap": 1.3974945737723005e-07, "residual as primal infeasibility certificate": None, "z": <4x1 matrix, tc="d">, "y": <0x1 matrix, tc="d">, "status": "optimal", "primal infeasibility": 1.1368786228004961e-08, "relative gap": 5.5899783359379607e-08}
[ 5.00e-01]
[ 1.50e+00]

[[ 2.49999999]]

例2

Python程序代碼

import numpy as np
from cvxopt import matrix, solvers

A = matrix([[1.0, 0.0, -1.0], [0.0, 1.0, -1.0]])
b = matrix([2.0, 2.0, -2.0])
c = matrix([1.0, 2.0])
d = matrix([-1.0, -2.0])

sol1 = solvers.lp(c,A,b)
min = np.dot(sol1["x"].T, c)
sol2 = solvers.lp(d,A,b)
max = -np.dot(sol2["x"].T, d)

print("min=%s,max=%s"%(min[0][0], max[0][0]))

輸出結(jié)果:

     pcost       dcost       gap    pres   dres   k/t
 0:  4.0000e+00 -0.0000e+00  4e+00  0e+00  0e+00  1e+00
 1:  2.7942e+00  1.9800e+00  8e-01  9e-17  7e-16  2e-01
 2:  2.0095e+00  1.9875e+00  2e-02  4e-16  2e-16  7e-03
 3:  2.0001e+00  1.9999e+00  2e-04  2e-16  6e-16  7e-05
 4:  2.0000e+00  2.0000e+00  2e-06  6e-17  5e-16  7e-07
 5:  2.0000e+00  2.0000e+00  2e-08  3e-16  7e-16  7e-09
Optimal solution found.
     pcost       dcost       gap    pres   dres   k/t
 0: -4.0000e+00 -8.0000e+00  4e+00  0e+00  1e-16  1e+00
 1: -5.2058e+00 -6.0200e+00  8e-01  1e-16  7e-16  2e-01
 2: -5.9905e+00 -6.0125e+00  2e-02  1e-16  0e+00  7e-03
 3: -5.9999e+00 -6.0001e+00  2e-04  1e-16  2e-16  7e-05
 4: -6.0000e+00 -6.0000e+00  2e-06  1e-16  2e-16  7e-07
Optimal solution found.
min=2.00000000952,max=5.99999904803

二次型規(guī)劃問題

其中P,q,G,h,A,b為輸入矩陣,該問題求解采用QP算法。

例1:

Python程序代碼:

from cvxopt import matrix, solvers

Q = 2*matrix([[2, .5], [.5, 1]])
p = matrix([1.0, 1.0])
G = matrix([[-1.0,0.0],[0.0,-1.0]])
h = matrix([0.0,0.0])
A = matrix([1.0, 1.0], (1,2))
b = matrix(1.0)

sol=solvers.qp(Q, p, G, h, A, b)
print(sol["x"])
print(sol["primal objective"])

輸出結(jié)果:

     pcost       dcost       gap    pres   dres
 0:  1.8889e+00  7.7778e-01  1e+00  2e-16  2e+00
 1:  1.8769e+00  1.8320e+00  4e-02  0e+00  6e-02
 2:  1.8750e+00  1.8739e+00  1e-03  1e-16  5e-04
 3:  1.8750e+00  1.8750e+00  1e-05  6e-17  5e-06
 4:  1.8750e+00  1.8750e+00  1e-07  2e-16  5e-08
Optimal solution found.
[ 2.50e-01]
[ 7.50e-01]

例2:

Python程序代碼:

from cvxopt import matrix, solvers

P = matrix([[1.0, 0.0], [0.0, 0.0]])
q = matrix([3.0, 4.0])
G = matrix([[-1.0, 0.0, -1.0, 2.0, 3.0], [0.0, -1.0, -3.0, 5.0, 4.0]])
h = matrix([0.0, 0.0, -15.0, 100.0, 80.0])

sol=solvers.qp(P, q, G, h)
print(sol["x"])
print(sol["primal objective"])

輸出結(jié)果

     pcost       dcost       gap    pres   dres
 0:  1.0780e+02 -7.6366e+02  9e+02  0e+00  4e+01
 1:  9.3245e+01  9.7637e+00  8e+01  6e-17  3e+00
 2:  6.7311e+01  3.2553e+01  3e+01  6e-17  1e+00
 3:  2.6071e+01  1.5068e+01  1e+01  2e-17  7e-01
 4:  3.7092e+01  2.3152e+01  1e+01  5e-18  4e-01
 5:  2.5352e+01  1.8652e+01  7e+00  7e-17  3e-16
 6:  2.0062e+01  1.9974e+01  9e-02  2e-16  3e-16
 7:  2.0001e+01  2.0000e+01  9e-04  8e-17  5e-16
 8:  2.0000e+01  2.0000e+01  9e-06  1e-16  2e-16
Optimal solution found.
[ 7.13e-07]
[ 5.00e+00]

20.00000617311241

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/41416.html

相關(guān)文章

  • Python 機(jī)器學(xué)習(xí) SVM 預(yù)測(cè)買賣(標(biāo)的物:比特幣)

    摘要:入門簡(jiǎn)單策略機(jī)器學(xué)習(xí)庫(kù)的使用什么是支持向量機(jī)。就是試圖把棍放在最佳位置,好讓在棍的兩邊有盡可能大的間隙?,F(xiàn)在即使魔鬼放了更多的球,棍仍然是一個(gè)好的分界線。魔鬼看到大俠已經(jīng)學(xué)會(huì)了一個(gè),于是魔鬼給了大俠一個(gè)新的挑戰(zhàn)。 Python入門簡(jiǎn)單策略 sklearn 機(jī)器學(xué)習(xí)庫(kù)的使用 什么是 SVM ? 支持向量機(jī)/support vector machine (SVM)。 當(dāng)然首先看一下wik...

    andong777 評(píng)論0 收藏0
  • Python標(biāo)準(zhǔn)庫(kù)系列模塊介紹

    摘要:的模塊其實(shí)就是封裝了一個(gè)或者多個(gè)功能的代碼集合,以便于重用,模塊可以是一個(gè)文件也可以是一個(gè)目錄,目錄的形式稱作包。已經(jīng)導(dǎo)入的模塊會(huì)保存在字典中。 Python的模塊其實(shí)就是封裝了一個(gè)或者多個(gè)功能的代碼集合,以便于重用,模塊可以是一個(gè)文件也可以是一個(gè)目錄,目錄的形式稱作包。 模塊分類 內(nèi)置模塊 內(nèi)置模塊可以理解成當(dāng)你安裝好python環(huán)境之后,直接可以使用import導(dǎo)入的就是內(nèi)置模塊,...

    v1 評(píng)論0 收藏0
  • 首次公開,整理12年積累的博客收藏夾,零距離展示《收藏夾吃灰》系列博客

    摘要:時(shí)間永遠(yuǎn)都過得那么快,一晃從年注冊(cè),到現(xiàn)在已經(jīng)過去了年那些被我藏在收藏夾吃灰的文章,已經(jīng)太多了,是時(shí)候把他們整理一下了。那是因?yàn)槭詹貖A太亂,橡皮擦給設(shè)置私密了,不收拾不好看呀。 ...

    Harriet666 評(píng)論0 收藏0
  • Python 3 學(xué)習(xí)筆記——變量作用域、模塊和包

    摘要:局部變量只能在其被聲明的函數(shù)內(nèi)部訪問,而全局變量可以在整個(gè)程序范圍內(nèi)訪問。調(diào)用函數(shù)時(shí),所有在函數(shù)內(nèi)聲明的變量名稱都將被加入到作用域中。 1. 變量作用域 Python 中,程序的變量并不是在哪個(gè)位置都可以訪問的,訪問權(quán)限決定于這個(gè)變量是在哪里賦值的。變量的作用域決定了在哪一部分程序可以訪問哪個(gè)特定的變量名稱。Python 的作用域一共有4種,分別是: L (Local) 局部作用...

    lijinke666 評(píng)論0 收藏0
  • Python基礎(chǔ)(一)基本數(shù)據(jù)類型

    摘要:但是在轉(zhuǎn)化中,浮點(diǎn)數(shù)轉(zhuǎn)化為二進(jìn)制后,不會(huì)精確等于十進(jìn)制的。一般情況下,只要簡(jiǎn)單地將最終顯示的結(jié)果用四舍五入到所期望的十進(jìn)制位數(shù),就會(huì)得到期望的最終結(jié)果。四舍五入內(nèi)建函數(shù)。在中的第二個(gè)數(shù),表示要保留的小數(shù)位數(shù),返回值是一個(gè)四舍五入之后的數(shù)值。 數(shù)字 基本類型 首先,進(jìn)入Python交互模式中: //整數(shù) >>> 3 3 //長(zhǎng)整數(shù) >>> 3333333333333333333333...

    yagami 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<