【优化调度】基于matlab粒子群算法求解燃机冷热电优化联供问题【含Matlab源码 330期】

✅博主简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,Matlab项目合作可私信。
🍎个人主页:海神之光
🏆代码获取方式:
海神之光Matlab王者学习之路—代码获取方式
⛳️座右铭:行百里者,半于九十。

更多Matlab仿真内容点击👇
Matlab图像处理(进阶版)
路径规划(Matlab)
神经网络预测与分类(Matlab)
优化求解(Matlab)
语音处理(Matlab)
信号处理(Matlab)
车间调度(Matlab)

⛄一、粒子群算法简介

1 粒子群算法的概念
粒子群优化算法(PSO:Particle swarm optimization) 是一种进化计算技术(evolutionary computation)。源于对鸟群捕食的行为研究。粒子群优化算法的基本思想:是通过群体中个体之间的协作和信息共享来寻找最优解.
PSO的优势:在于简单容易实现并且没有许多参数的调节。目前已被广泛应用于函数优化、神经网络训练、模糊系统控制以及其他遗传算法的应用领域。

2 粒子群算法分析
2.1基本思想
粒子群算法通过设计一种无质量的粒子来模拟鸟群中的鸟,粒子仅具有两个属性:速度和位置,速度代表移动的快慢,位置代表移动的方向。每个粒子在搜索空间中单独的搜寻最优解,并将其记为当前个体极值,并将个体极值与整个粒子群里的其他粒子共享,找到最优的那个个体极值作为整个粒子群的当前全局最优解,粒子群中的所有粒子根据自己找到的当前个体极值和整个粒子群共享的当前全局最优解来调整自己的速度和位置。下面的动图很形象地展示了PSO算法的过程:
在这里插入图片描述
2 更新规则
PSO初始化为一群随机粒子(随机解)。然后通过迭代找到最优解。在每一次的迭代中,粒子通过跟踪两个“极值”(pbest,gbest)来更新自己。在找到这两个最优值后,粒子通过下面的公式来更新自己的速度和位置。
在这里插入图片描述
公式(1)的第一部分称为【记忆项】,表示上次速度大小和方向的影响;公式(1)的第二部分称为【自身认知项】,是从当前点指向粒子自身最好点的一个矢量,表示粒子的动作来源于自己经验的部分;公式(1)的第三部分称为【群体认知项】,是一个从当前点指向种群最好点的矢量,反映了粒子间的协同合作和知识共享。粒子就是通过自己的经验和同伴中最好的经验来决定下一步的运动。以上面两个公式为基础,形成了PSO的标准形式。
在这里插入图片描述
公式(2)和 公式(3)被视为标准PSO算法。
3 PSO算法的流程和伪代码
在这里插入图片描述

⛄二、部分源代码

pop=initpop(80,2,24,66,33);
objvalue=calobjvalue(pop);
PL=[63 57 44 43 43 40 56 66 78 75 89 105 125 121 116 104 101 103 104 121 116 121 106 89];
QL=[139 136 122 128 128 128 131 142 138 138 150 169 183 187 189 183 171 161 154 165 156 148 141 132];
popsize=80;
scope=24;
PMTmax=66;
PMTmin=33;
MaxIt=60;
c1=2;
c2=2;
w=0.6;
v=zeros(2,24,80);
pbest=pop;
objvaluepbest=calobjvalue(pbest);
gbest=pop(:,:,1);
objvaluegbest=objvalue(1);
for i=1:(popsize-1)
if objvalue(i+1)<objvalue(i)
gbest=pop(:,:,i+1); %比较每个粒子的适应度,将适应度最小的粒子位置取做gbest
objvaluegbest=objvalue(i+1);
end
end
iter=0;%迭代次数
while iter<MaxIt
iter=iter+1;
for i=1:popsize
if objvalue(i)<objvaluepbest(i)
objvaluepbest(i)=objvalue(i);
pbest(:,:,i)=pop(:,:,i);%当粒子的适应度小于其最佳适应度时,用其替代原来粒子的最佳适应度,并记下此解
end
end
for i=1:popsize
if objvalue(i)<objvaluegbest
objvaluegbest=objvalue(i);
gbest=pop(:,:,i);%当存在粒子的适应度小于种群的最佳适应度时,用其替代原来种群的最佳适应度,并记下此解
end
end
for i=1:popsize
gbestpop(:,:,i)=gbest;%将二维gbest拓展为三维gbestpop
end
R1=rand(2,24,80);
R2=rand(2,24,80);
v=vw+c1R1.(pbest-pop)+c2R2.(gbestpop-pop);
pop=pop+v;
for j=1:popsize
for i=1:scope
if pop(1,i,j)>PMTmax/2.91
pop(1,i,j)=PMTmax/2.91;
end
if pop(1,i,j)<PMTmin/2.91
pop(1,i,j)=PMTmin/2.91;
end
%为满足功率平衡,电网购电由燃气轮机出力求得
pop(2,i,j)=(QL(1,i)-pop(1,i,j)22.91)/2.3+PL(1,i)-2.91
pop(1,i,j);
end
end
objvalue=calobjvalue(pop)
end
gbest
%画图程序
x=[1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24];
y1=PL;
y2=2.91gbest(1,:);
y3=gbest(2,:);
y7=y2+y3-y1;
scatter(x,y1,‘k’)
hold on
scatter(x,y2,'r
’)
hold on
scatter(x,y3,‘b^’)
hold on
scatter(x,y7,‘kx’)
plot(x,y1);
hold on
plot(x,y2);
hold on
plot(x,y3);
hold on
plot(x,y7);
xlabel(‘时刻(h)’);
ylabel(‘输出功率(KW)’);
axis([0,24,0,180]);
legend(‘电负荷’,‘燃机出力’,‘系统与大电网交换功率’,‘电空调功率’);
title(‘夏季各设备电功率曲线图’);
y4=QL;
y5=22.91gbest(1,:);
y6=2.3y7;
figure(2);
scatter(x,y4,‘k’)
hold on
scatter(x,y5,'r
’)
hold on
scatter(x,y6,‘b^’)
plot(x,y4);
hold on
plot(x,y5);
hold on
plot(x,y6);
xlabel(‘时刻(h)’);
ylabel(‘制冷功率(KW)’);
title(‘夏季各设备冷功率曲线图’);
min)+PMTmin;
VMT(1,i)=PMT(1,i)/2.91;
QMTco(1,i)=2PMT(1,i);
Qairco(1,i)=QL(1,i)-QMTco(1,i);
if Qairco(1,i)<0;
Qairco(1,i)=0;
QMTco(1,i)=QL(1,i);
VMT(1,i)=QMTco(1,i)/(2
2.91);
end
PGrid(1,i)=PL(1,i)+Qairco(1,i)/2.3- VMT(1,i)2.91;
pop(1,i,j)=VMT(1,i);
pop(2,i,j)= PGrid(1,i);
end
end
for j=0.5
popsize+1:popsize %按照电网出力均分的粒子(假设从40kw到120kw均分)
for i=1:scope
PGrid(1,i)=(j-40-1)/39*(150-40)+40;
VMT(1,i)=(PL(1,i)-PGrid(1,i)+QL(1,i)/2.3)2300/4947;
if VMT(1,i)>PMTmax/2.91 %越上限按上限出力
VMT(1,i)=PMTmax/2.91;
end
if VMT(1,i)<PMTmin/2.91 %越下限按下限出力
VMT(1,i)=PMTmin/2.91;
end
QMTco(1,i)=2
PMT(1,i);
Qairco(1,i)=QL(1,i)-QMTco(1,i);%冷功率平衡
PGrid(1,i)=PL(1,i)+Qairco(1,i)/2.3- VMT(1,i)*2.91; %电功率平衡
pop(1,i,j)=VMT(1,i);
pop(2,i,j)= PGrid(1,i);
end
end

⛄三、运行结果

在这里插入图片描述
在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1] 包子阳,余继周,杨杉.智能优化算法及其MATLAB实例(第2版)[M].电子工业出版社,2016.
[2]张岩,吴水根.MATLAB优化算法源代码[M].清华大学出版社,2017.

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

🍅 仿真咨询
1 各类智能优化算法改进及应用

生产调度、经济调度、装配线调度、充电优化、车间调度、发车优化、水库调度、三维装箱、物流选址、货位优化、公交排班优化、充电桩布局优化、车间布局优化、集装箱船配载优化、水泵组合优化、解医疗资源分配优化、设施布局优化、可视域基站和无人机选址优化

2 机器学习和深度学习方面
卷积神经网络(CNN)、LSTM、支持向量机(SVM)、最小二乘支持向量机(LSSVM)、极限学习机(ELM)、核极限学习机(KELM)、BP、RBF、宽度学习、DBN、RF、RBF、DELM、XGBOOST、TCN实现风电预测、光伏预测、电池寿命预测、辐射源识别、交通流预测、负荷预测、股价预测、PM2.5浓度预测、电池健康状态预测、水体光学参数反演、NLOS信号识别、地铁停车精准预测、变压器故障诊断

3 图像处理方面
图像识别、图像分割、图像检测、图像隐藏、图像配准、图像拼接、图像融合、图像增强、图像压缩感知

4 路径规划方面
旅行商问题(TSP)、车辆路径问题(VRP、MVRP、CVRP、VRPTW等)、无人机三维路径规划、无人机协同、无人机编队、机器人路径规划、栅格地图路径规划、多式联运运输问题、车辆协同无人机路径规划、天线线性阵列分布优化、车间布局优化

5 无人机应用方面
无人机路径规划、无人机控制、无人机编队、无人机协同、无人机任务分配

6 无线传感器定位及布局方面
传感器部署优化、通信协议优化、路由优化、目标定位优化、Dv-Hop定位优化、Leach协议优化、WSN覆盖优化、组播优化、RSSI定位优化

7 信号处理方面
信号识别、信号加密、信号去噪、信号增强、雷达信号处理、信号水印嵌入提取、肌电信号、脑电信号、信号配时优化

8 电力系统方面
微电网优化、无功优化、配电网重构、储能配置

9 元胞自动机方面
交通流 人群疏散 病毒扩散 晶体生长

10 雷达方面
卡尔曼滤波跟踪、航迹关联、航迹融合

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

海神之光

有机会获得赠送范围1份代码

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值