clear,clc;
load('tankData.mat');
load('quest3.mat');
% problem.objective = @(x)norm(getTotalCg(...
% x,...
% 0,...
% tankPosi,...
% tankSize,...
% aircraftMass,...
% oilDensity) - mean(aircraftIdealCg));
problem.objective = @(x)norm(getTotalCg(...
x,...
0,...
tankPosi,...
tankSize,...
aircraftMass,...
oilDensity) - aircraftIdealCg(1,:));
problem.x0 = tankInitQuantity;
problem.lb = zeros(6,1);
problem.ub = tankMaxQuantity';
problem.Aineq = zeros(1,6) - 1;
problem.bineq = -sum(aircraftFlow)/oilDensity;
problem.Aeq = [];
problem.Beq = [];
problem.nonlcon = [];
problem.solver = 'fmincon';
problem.options = optimoptions('fmincon','Display','none','Algorithm','sqp');
tankInitQuantity = fmincon(problem);
iActTank = logical([1 0 0 1 1 0]);
engineTank = logical([0 1 1 1 1 0]);
[tankFlow,tankQuantity] = deal(zeros(size(t,1),6));
actTank = false(size(t,1),6);
tankQuantity(1,:) = tankInitQuantity;
actTank(1,:) = iActTank;
tankQuantityBound = [1 -1 0 0 0 0;0 0 0 0 -1 1];
% actTankStateflow = quest2chart('actTank',iActTank,'tankQuantity',tankInitQuantity);
totalCg = zeros(size(t,1),3);
totalCg(1,:) = getTotalCg(tankQuantity(1,:),0,tankPosi,tankSize,aircraftMass,oilDensity)';
tankSwitchPoint = [2000 3300 4250 5200];
tic
for i = 1:numel(t)-1
problem.objective = @(x)norm(getTotalCgFromFlow(...
tankQuantity(i,:),...
iActTank,...
x,...
0,...
tankPosi,...
tankSize,...
aircraftMass,...
oilDensity)' - aircraftIdealCg(min(i+1,7200),:));
problem.x0 = zeros(sum(iActTank),1) + 1/6*aircraftFlow(i);
problem.lb = zeros(sum(iActTank),1) + 0.0001;
problem.ub = tankMaxFlow(iActTank);
problem.Aineq = tankQuantityBound(:,iActTank);
problem.bineq = [tankMaxQuantity(2) - tankQuantity(i,2);tankMaxQuantity(5) - tankQuantity(i,5)];
actEngineTank = iActTank & engineTank;
problem.Aeq = double(actEngineTank(iActTank));
problem.Beq = aircraftFlow(i);
problem.nonlcon = [];
problem.solver = 'fmincon';
problem.options = optimoptions('fmincon','Display','none','Algorithm','sqp');
tankFlow(i,iActTank) = fmincon(problem)';
iTankQuantity = tankQuantity(i,:) - tankFlow(i,:)/oilDensity;
iTankQuantity([2 5]) = iTankQuantity([2 5]) + tankFlow(i,[1 6])/oilDensity;
tankQuantity(i+1,:) = iTankQuantity;
if ismember(i,tankSwitchPoint) || any(iTankQuantity(iActTank) < 0.01)
iActTank = quest3changeTank(tankQuantity(i+1,:));
end
actTank(i+1,:) = iActTank;
disp(i);
end
toc
for i = 1:numel(t)
totalCg(i,:) = getTotalCg(tankQuantity(i,:),0,tankPosi,tankSize,aircraftMass,oilDensity)';
end
totalCgError = vecnorm(totalCg - aircraftIdealCg,2,2);
maxTotalCgError = max(totalCgError);
save quest3result.mat totalCg tankFlow tankQuantity actTank tankInitQuantity totalCgError maxTotalCgError
quest3plot
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
1、资源内容:基于Matlab求解2020华为杯F题(源码+数据+结果图).rar 2、适用人群:计算机,电子信息工程、数学等专业的学习者,作为自己程序部分功能的“参考资料”使用。 3、解压说明:本资源需要电脑端使用WinRAR、7zip等解压工具进行解压,没有解压工具的自行百度下载即可。 4、免责声明:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。不一定能够满足所有人的需求,需要有一定的基础能够看懂代码,能够自行调试代码并解决报错,能够自行添加功能修改代码。由于作者大厂工作较忙,不提供答疑服务,如不存在资源缺失问题概不负责,谢谢理解。
资源推荐
资源详情
资源评论
收起资源包目录
基于Matlab求解2020华为杯F题(源码+数据+结果图).rar (35个子文件)
基于Matlab求解2020华为杯F题(源码+数据+结果图)
quest4tankquantity.png 48KB
quest4changeTank.m 560B
quest3cg.png 63KB
plot_all.m 49B
quest1cg.png 50KB
quest4cg.png 49KB
flow2cg.m 1009B
quest2result.mat 417KB
quest4.mat 74KB
tankData.mat 4KB
getTotalCgFromFlow.m 453B
getTotalCg.m 816B
quest4tankflow.png 62KB
quest2.m 2KB
quest3tankquantity.png 50KB
quest4plot.m 798B
quest3plot.m 868B
quest1.mat 174KB
quest4.m 3KB
quest2changeTank.m 686B
quest2chart.sfx 34KB
quest2tankflow.png 59KB
quest2.mat 184KB
quest2cg.png 51KB
results.xlsx 1.27MB
quest1.m 536B
quest2plot.m 887B
quest3.m 3KB
quest3.mat 145KB
quest4result.mat 437KB
do_all_task.m 37B
quest2tankquantity.png 46KB
quest3result.mat 441KB
quest3changeTank.m 740B
quest3tankflow.png 56KB
共 35 条
- 1
资源评论
Matlab仿真实验室
- 粉丝: 2w+
- 资源: 2180
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功