L P
# solves *bounded* LPs of the form:
# max cx
# sub to: Ax <= b
from sympy import *
from itertools import combinations
# enumerates all the vertices of {x | Ax <= b}
def enumeratevertices(A, b):
m, n = A.rows, A.cols
for rowlist in combinations(range(m), n):
Ap = A.extract(rowlist, range(n))
bp = b.extract(rowlist, [0])
if Ap.det() != 0:
xp = Ap.LUsolve(bp)
d = A * xp - b
feasible = True
for i in range(m):
if d[i] > 0:
feasible = False
if feasible:
yield xp
# finds the optimum using vertex enumeration
def findoptimum(A, b, c):
m, n = A.rows, A.cols
bestvalue, bestvertex = None, None
for vertex in enumeratevertices(A, b):
if bestvalue is None or (vertex.T*c)[0] > bestvalue:
bestvalue = (vertex.T * c)[0]
bestvertex = vertex
return bestvertex
def solve(A, b, c):
x = findoptimum(A, b, c)
if not x:
print 'LP is infeasible'
else:
print 'Vertex', x.T, 'is optimal'
print 'Optimal value is', c.T*x
if __name__ == '__main__':
A = Matrix([[-10, -6, -9, -10],
[ 8, -6, -5, -5],
[ -7, -1, -9, 3],
[ -1, -4, 5, 10],
[ 1, 2, 0, 10],
[ 2, -9, 3, -8],
[ -8, -1, -8, 1],
[ 7, -10, 4, -4],
[-10, 2, 5, 8],
[ -7, 9, 4, -4],
[ -1, 0, 0, 0],
[ 0, -1, 0, 0],
[ 0, 0, -1, 0],
[ 0, 0, 0, -1]])
b = Matrix([9, 7, 3, 4, 8, 0, 3, 2, 4, 8, 0, 0, 0, 0])
c = Matrix([2, -2, -3, 8])
solve(A, b, c)
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.