import cvxpy as cp
import numpy as np
M = 10000
t = np.array([210, 300, 100, 130, 260])
s = np.array([150, 210, 60, 80, 180])
x = cp.Variable(5, integer=True)
obj = cp.Maximize(cp.sum(cp.multiply(x, s)))
con = [x[0] + x[1] + x[2] == 1, x[2] + x[3] == 1,
cp.sum(cp.multiply(x, t)) <= 600, x[4] <= x[0] * M, x <= 1, x >= 0]
prob = cp.Problem(obj, con)
prob.solve(solver='GLPK_MI')
print("最优值为:", prob.value)
print("最优解为:", x.value)
import cvxpy as cp
import numpy as np
w = np.array([8, 13, 6, 9, 5, 7])
s = np.array([3, 5, 2, 4, 2, 3])
x = cp.Variable(6, integer=True)
obj = cp.Maximize(cp.sum(cp.multiply(x, s)))
con = [cp.sum(cp.multiply(x, w)) <= 24, x >= 0, x <= 1]
prob = cp.Problem(obj, con)
prob.solve(solver='GLPK_MI')
print("最优值为:", prob.value)
print("最优解为:", x.value)
c1 = np.array([0.2, 0.2, 0.2])
c2 = np.array([58, 54, 50])
a = np.array([[-1, 0, 0], [-1, -1, 0]])
b = np.array([-40, -100])
x = cp.Variable(3, integer=True)
obj = cp.Minimize(c1 @ x ** 2 + c2 @ x - 560)
con = [x >= 0, x <= 100, x[0] >= 40, x[0] + x[1] >= 100, x[0] + x[1] + x[2] == 180, a @ x <= b]
prob = cp.Problem(obj, con)
prob.solve(solver='CPLEX')
print("最优值为:", prob.value)
print("最优解为:", x.value)
x = cp.Variable(3, integer=False)
obj = lambda x: (x[0] + 4 * x[1] + 5 * x[2]) * x[0] + (4 * x[0] + 2 * x[1] + 6 * x[2]) * x[1] + (5 * x[0] + 6 * x[1] + 3 * x[2]) * x[2]
con = [x[0] ** 2 + x[1] ** 2 + x[2] ** 2 == 1]
cons = {'type': 'eq', 'fun': lambda x: x[0] ** 2 + x[1] ** 2 + x[2] ** 2 - 1}
# prob = cp.Problem(obj, con)
# bd = [(-1, 1) for i in range(0, 3)]
LB = [-1] * 3;
UB = [1] * 3
bound = tuple(zip(LB, UB))
res = minimize(obj, np.ones(3), constraints=cons, bounds=bound)
print(res.fun, '\n', res.success, '\n', res.x) # 输出最优值、求解状态、最优解
知道你对编程感兴趣,便准备了这套python学习资料,
对于0基础小白入门:
如果你是零基础小白,想快速入门Python是可以考虑培训的。
一方面是学习时间相对较短,学习内容更全面更集中。
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。(学习教程文末领取哈)
温馨提示:篇幅有限,已打包文件夹,获取方式在:文末
观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
检查学习结果。
这份完整版的Python全套学习资料已为大家备好,朋友们如果需要可以微信扫描下方二维码添加,输入"领取资料" 可免费领取全套资料【有什么需要协作的还可以随时联系我】朋友圈也会不定时的更新最前言python知识。
这世界上赚钱成本最低的就是:用知识投资大脑
人生什么时候学习都不晚,晚的是你一直想学却一直没有行动,而导致大量内耗
最后祝你学习愉快
了解python的前景:https://blog.csdn.net/weixin_49891576/article/details/127187029
python有什么用:https://blog.csdn.net/weixin_49891576/article/details/127125308