基于多目标粒子群求解含风、光、柴油机、储能的微电网多目标优化问题(Matlab实现)

简介: 基于多目标粒子群求解含风、光、柴油机、储能的微电网多目标优化问题(Matlab实现)

摘要:

本文使用一种经济与环保相协调的微电网优化调度模型,针对光伏电池、风机、微型燃气轮机、柴油发电机以及蓄电池组成的微电网系统的优化问题进行研究,在满足系统约束条件下,建立了包含运行成本、可中断负荷补偿成本以及污染物处理费用的微电网多目标优化调度模型,并利用多目标粒子群算法(MOPSO)求解微电网优化调度问题,代码注释详细,结构简洁,适合快速入门多目标粒子群和多目标微电网调度的同学。


1.微电网模型

本文讨论的微电网模型中包括:风力发电机、光伏太阳能板、柴油发电机、储能电池、电力负荷。使用MOPSO算法求解该微电网的多目标最优化调度问题。


2.微电网多目标优化调度的目标函数

由于是多目标优化调度,因此本文设置目标函数有两个:运行成本最小和风光消纳率最高。


2.1运行成本最小:


式中:T为微电网的调度周期的时段数;N为微电源类型数目;COi,t为微电源i在t时刻的发电费用;IRt为微电网在t时刻的可中断费用;Pi,t为第i台微电源在t时刻的发电功率。

2.2风光消纳率最高:

使用各个时刻预测的可再生能源最大可调度功率值与实际使用了的可再生能源功率值进行相减,再将全日的总可再生能源未消纳的量相加,即可构成可再生能源消纳目标函数

 

式中:PWT,tPPV,t表示t时刻的风电和光伏能发出的最大功率,PWT,t'PPV,t'表示实际使用了的风电和光伏功率。


3.微电网多目标优化调度的约束条件

3.1最大最小功率约束:

3.2最大最小功率约束:

3.3储能电池运行约束:

储能电池的SOC需要在运行一天后回到初始的位置,并且在运行的过程中不能超过最大和最小的储能元件容量约束。

4.多目标粒子群算法(MOPSO)

粒子群算法的原理在这里就不再赘述了,感兴趣的可以看我之前的文章,这里主要说一下多目标粒子群的不同之处。由于优化问题中含有多个目标函数,因此需要在求解过程中引入Pareto分层排序原则对个体进行选择,主要的步骤为:


(1)数据初始化。输入微电网的系统组成和结构参数、模型参数、MOPSO算法参数等


(2)将将粒子个体作为系统变量输入仿真模型,对违背约束的变量进行修正,并计算系统的运行成本、环境成本以及惩罚项作为个体适应度值。


(3)将个体适应度作为优化模型的输入,得到子代种群确定个体极值pbest。将pbest作为粒子的初始个体极值,如果当前的粒子支配pbest,则将当前的粒子作为pbest个体极值;如果两者不能比较,则计算两者在群体中支配其他粒子的个数,支配较多则作为个体极值pbest。


(4)对种群进行分层排序,将最优的非支配解Pareto存入外部存档集合,清除非Pareto解,并判断外部存档集合是否超过规定容量,若是,则按照拥挤距离选取m个粒子。


(5)全局最优值gbest。采用外部存档集合保存的Pareto最优解,本文引用轮盘赌方法根据最优解的拥挤距离从外部集合中选取gbest。


(6)重复计算(3-5)直到达到最大的迭代次数。


5.程序运行结果

6.代码展示

%% 程序初始化
clear;
clc;
close all;
%% 定义全局变量
global P_load; %电负荷
global WT;%风电
global PV;%光伏
global WT_price;%
global PV_price;
global BT_price;
%% 获取数据
data=xlsread('mopso_data');
P_load=data(:,1);
PV=data(:,2);
WT=data(:,3);
PV_price=0.8;
BT_price=0.5;
WT_price=0.6;
%储能最大放电功率
StorageMaxDischargingPower=250;
%储能最大充电功率
StorageMaxChargingPower=-200;
%柴油发电机最大功率
DGMaxImportPower=600;
%柴油发电机最小功率
DGMinImportPower=200;
%% 调用mopso函数
mm=mopso; %调用mopso函数
nn=length(mm.swarm); %非支配解数目
%将非支配解中的经济成本和消纳比例分别赋值给yyy,xxx
for i=1:nn
   yyy(i)= mm.swarm(1,i).cost(1);
   xxx(i)= mm.swarm(1,i).cost(2);
end
m1=max(yyy);
m2=max(xxx);


相关文章
|
1天前
|
传感器 数据采集 数据处理
MATLAB热传导方程模型最小二乘法模型、线性规划对集成电路板炉温优化
MATLAB热传导方程模型最小二乘法模型、线性规划对集成电路板炉温优化
|
3天前
|
机器学习/深度学习 算法 数据挖掘
基于PSO优化的CNN-GRU-Attention的时间序列回归预测matlab仿真
摘要: 本文介绍了运用粒子群优化(PSO)调整深度学习模型超参数以提升时间序列预测性能的方法。在比较了优化前后的效果(Ttttttttttt12 vs Ttttttttttt34)后,阐述了使用matlab2022a软件的算法。文章详细讨论了CNN、GRU网络和注意力机制在时间序列预测中的作用,以及PSO如何优化这些模型的超参数。核心程序展示了PSO的迭代过程,通过限制和调整粒子的位置(x1)和速度(v1),寻找最佳解决方案(gbest1)。最终,结果保存在R2.mat文件中。
基于PSO优化的CNN-GRU-Attention的时间序列回归预测matlab仿真
|
9天前
|
机器学习/深度学习 算法 数据挖掘
基于PSO优化的CNN-LSTM-Attention的时间序列回归预测matlab仿真
该文档介绍了使用MATLAB2022A中PSO优化算法提升时间序列预测模型性能的过程。PSO优化前后对比显示了优化效果。算法基于CNN、LSTM和Attention机制构建CNN-LSTM-Attention模型,利用PSO调整模型超参数。代码示例展示了PSO的迭代优化过程及训练、预测和误差分析环节。最终,模型的预测结果以图形形式展示,并保存了相关数据。
|
9天前
|
机器学习/深度学习 算法
MATLAB随机森林优化贝叶斯预测分析汽车燃油经济性
MATLAB随机森林优化贝叶斯预测分析汽车燃油经济性
19 0
|
15天前
|
机器学习/深度学习 算法 网络架构
matlab使用贝叶斯优化的深度学习:卷积神经网络CNN
matlab使用贝叶斯优化的深度学习:卷积神经网络CNN
14 0
|
15天前
|
数据可视化 API 决策智能
matlab使用Copula仿真优化市场风险
matlab使用Copula仿真优化市场风险
21 0
|
15天前
matlab使用Copula仿真优化市场风险数据VaR分析
matlab使用Copula仿真优化市场风险数据VaR分析
11 0
|
16天前
|
机器学习/深度学习 算法 网络架构
matlab使用贝叶斯优化的深度学习
matlab使用贝叶斯优化的深度学习
19 0
|
22天前
|
机器学习/深度学习 算法
基于GA优化的CNN-LSTM-Attention的时间序列回归预测matlab仿真
时间序列预测是许多领域中的核心问题,如金融市场分析、气候预测、交通流量预测等。近年来,深度学习在时间序列分析上取得了显著的成果,尤其是卷积神经网络(CNN)、长短时记忆网络(LSTM)和注意力机制(Attention)的结合使用
|
2月前
|
机器学习/深度学习 算法 数据可视化
基于GA优化的CNN-GRU-Attention的时间序列回归预测matlab仿真
该内容描述了一个使用CNN-LSTM-Attention模型优化时间序列预测的过程。在优化前后,算法的预测效果有明显提升,软件版本为matlab2022a。理论部分介绍了CNN用于特征提取,LSTM处理序列依赖,Attention关注重要信息,以及遗传算法(GA)优化超参数。提供的核心代码展示了GA的优化迭代和模型训练,以及预测结果的可视化比较。

热门文章

最新文章