每日一题【20200727】
非线性规划
matlab随机取样计算法解决非线性整数规划
matlab代码:
(1)编辑mengte.m文件
%目标函数f,约束条件g
function [f,g] = mengte(x)
f = x(1)^2 + x(2)^2 + 3*x(3)^2 + 4*x(4)^2 + 2*x(5)^2 - 8*x(1) - 2*x(2) - 3*x(3) - x(4) - 2*x(5);
g(1) = sum(x) - 400;
g(2) = x(1) + 2*x(2) + 2*x(3) + x(4) + 6*x(5) - 800;
g(3) = 2*x(1) + x(2) + 6*x(3) - 200;
g(4) = x(3) + x(4) + 5*x(5) - 200;
end
(2)matlab执行代码
%非线性整数规划----枚举法--随机取样计算法--有误差
%tic和toc用来记录matlab命令执行的时间。
%整数问题最好用Lingo-----可每次将 p0 改为最大值
tic
p0 = 0;
for i = 1 : 10^5
x = 99 * rand(5,1); %0 <= x <=99
x1 = floor(x); x2 = ceil(x); %取整
[f,g] = mengte(x1);
if sum(g <= 0) == 4
if f >= p0
x0 = x1;
p0 = f;
end
end
[f,g] = mengte(x2);
if sum(g <= 0) == 4
if f >= p0;
x0 = x2;
p0 = f;
end
end
end
x0,p0
toc
答案是:
x0 =
27
98
5
99
1
p0 =
49086
历时 0.770322 秒。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?