首页 > 其他分享 >Matlab|基于两阶段鲁棒优化的微网电源储能容量优化配置

Matlab|基于两阶段鲁棒优化的微网电源储能容量优化配置

时间:2024-03-26 23:02:36浏览次数:20  
标签:24 储能 int sdpvar 鲁棒 Matlab 0.48 优化 1.35

目录

 主要内容   

1.1 目标函数

1.2 约束条件

1.3 不确定变量

  部分代码   

  结果一览   

下载链接


 主要内容   

程序主要复现的是《考虑寿命损耗的微网电池储能容量优化配置》,解决微网中电源/储能容量优化配置的问题,即风电、光伏、储能以及燃气轮机的容量规划问题,程序考虑了不确定性,采用两阶段鲁棒优化方法进行优化,采用的是KKTCCG算法,一阶段主要决策储能、风电、光伏的容量,二阶段主要规划风光燃储的实际出力变量,最后结果不仅给出了微网电源容量配置的结果,还给出了各个机组的出力。 

1.1 目标函数

1.2 约束条件

1.3 不确定变量

不确定变量考虑风光出力和负荷的不确定性,采用盒式不确定的方式。

tips:

1.该程序虽然收敛性良好,但是两阶段鲁棒优化流程还不完善,在一阶段未实现不同迭代次数下变量叠加,只是实现了变量的更新!有兴趣的可以看一下比较规范的两阶段鲁棒优化程序:《 6节点电网两阶段鲁棒优化调度matlab 【重磅】IEEE33配电网两阶段鲁棒优化调度CCG
2.模型对偶采用kkt方法,还是值得学习的,可结合《Solving two-stage robust optimization problems using a column-and-constraint generation》进行学习。

  部分代码   

%% 1.设参
%投资成本参数
rp = 0.08;%折现率
rbat = 10;rPV = 20;rWT = 15;rG = 15;%折现年数
cbat = 1107;cPV = 100;cWT = 300;cG = 2000;%单位容量投资成本
​
pm_max = 500;%联络线功率上限
eta = 0.95;%储能充放电效率
c_wt_om = 0.0296;c_pv_om = 0.0096;c_g_om = 0.059;c_bat_om = 0.009;%运维成本系数
c_fuel = 0.6;%燃料成本系数
%% 2.设决策变量
p_ch = sdpvar(24,4);%储能充电
p_dis = sdpvar(24,4);%储能放电
uu_bat = binvar(24,4);%充放电标识
​
uu_m = binvar(24,4);
p_buy = sdpvar(24,4);%配网购电
p_sell = sdpvar(24,4);%配网售电
​
p_wt = sdpvar(24,4);
p_pv = sdpvar(24,4);
p_load = sdpvar(24,4);
​
p_g = sdpvar(24,4);%微型燃气轮机
%% 3.设变量
ee_bat_int = sdpvar(1);%储能容量上限
p_pv_int = sdpvar(1);
p_wt_int = sdpvar(1);
p_g_int = sdpvar(1);
​
yita = sdpvar(1);
p_bat_int = ee_bat_int*0.21;%假设储能的功率上限和容量上限有比值关系
ee0 = 0.55*ee_bat_int;%储能初始电量
​
%风光出力和电价(以春季典型日为例)
p_l = xlsread('四个典型日数据.xlsx','0%','B3:E26')*900;%?
max_p_wt = xlsread('四个典型日数据.xlsx','0%','H3:K26')*p_wt_int; 
max_p_pv = xlsread('四个典型日数据.xlsx','0%','N3:Q26')*p_pv_int; 
%price=xlsread('四个典型日数据.xlsx','电价','A2:A25');
price = [0.48;0.48;0.48;0.48;0.48;0.48;0.48;0.9;1.35;1.35;1.35;0.9;0.9;0.9;0.9;0.9;0.9;0.9;1.35;1.35;1.35;1.35;1.35;0.48];
%% 4.设约束
C = [];
load = p_l';
wwt = 0.05;wpv = 0.1;wl = 0.15;%不确定度,缩放比例
C = [C, (1 - wwt)*max_p_wt <= p_wt,p_wt <= (1 + wwt)*max_p_wt];%不确定性风
C = [C, (1 - wpv)*max_p_pv <= p_pv,p_pv <= (1 + wpv)*max_p_pv];%不确定性光
C = [C, (1 - wl)*load' <= p_load,p_load <= (1 + wl)*load'];%不确定性负荷
%储能线性化

  结果一览   

下载链接

标签:24,储能,int,sdpvar,鲁棒,Matlab,0.48,优化,1.35
From: https://blog.csdn.net/superone89/article/details/137060742

相关文章

  • 更新和添加参数校验优化(2024-3-26)
    由于更新文章分类和添加文章分类,参数校验时,一个需要IDnotnull一个只是让id自动增长,所以当再次添加新的文章时会出现id为空的错误:这时候就要用到validation提供的分组校验:把校验项进行分类,在完成不同功能的时候,校验指定组中的校验项packagecom.di.bigevent.pojo;importco......
  • 德勤大型企业业务流程优化及ERP整体规划方案(86页PPT)
    原文《德勤大型企业业务流程优化及ERP整体规划方案》PPT格式,共86页。纵向:建立统分并举的‘人、财、物、销’二级管控平台。横向:合理定位管控信息化与专业信息化平台。来源网络公开渠道,旨在交流学习,如有侵权联系速删,更多参考公众号:优享智库​原文《德勤大型企业业务流程优......
  • MySQL超大分页处理,以及优化思路说明。
    MySQL超大分页处理:MySQL中分页处理的方式:在MySQL中进行分页查询通常会使用LIMIT和OFFSET关键字来实现,下面是一种常见的方法:sqlCopyCodeSELECT*FROMyour_tableLIMIToffset,limit;offset表示起始行数,从0开始计数,即第一行为0。limit表示每页返回的行数。......
  • 【MATLAB源码-第15期】基于matlab的MSK的理论误码率与实际误码率BER对比仿真,采用差分
    操作环境:MATLAB2022a1、算法描述在数字调制中,最小频移键控(Minimum-ShiftKeying,缩写:MSK)是一种连续相位调制的频移键控方式,在1950年代末和1960年代产生。[1]与偏移四相相移键控(OQPSK)类似,MSK同样将正交路基带信号相对于同相路基带信号延时符号间隔的一半,从而消除了已调信号......
  • 【MATLAB源码-第16期】基于matlab的MSK定是同步仿真,采用gardner算法和锁相环。
    操作环境:MATLAB2022a1、算法描述**锁相环(PLL)**是一种控制系统,用于将一个参考信号的相位与一个输入信号的相位同步。它在许多领域中都有应用,如通信、无线电、音频、视频和计算机系统。锁相环通常由以下几个关键组件组成:1.**相位比较器(PhaseComparator):**这个组件比较输......
  • 深度学习中的“优化算法”
    AI大模型学习方向一:AI大模型学习的理论基础在深度学习中,优化算法的主要任务是调整模型的参数(例如神经网络中的权重),以最小化或最大化一个损失函数(目标函数)。这个过程是通过不断迭代来逼近最优解。优化算法对于模型的训练速度和最终性能至关重要。以下是一些深度学习中常见的优......
  • 【智能算法】野马优化算法(WHO)原理及实现
    目录1.背景2.算法原理2.1算法思想2.2算法过程3.结果展示4.参考文献1.背景2021年,Naruei等人受到野马自然社会行为启发,提出了野马优化算法(Wildhorseoptimization,WHO)。2.算法原理2.1算法思想WHO来源于野马的社会生活行为,主要包括小马驹的放牧行为、马的交配行......
  • 基于GA优化的CNN-GRU-Attention的时间序列回归预测matlab仿真
    1.算法运行效果图预览优化前:   优化后:   2.算法运行软件版本matlab2022a 3.算法理论概述      时间序列预测是许多领域中的核心问题,如金融市场分析、气候预测、交通流量预测等。近年来,深度学习在时间序列分析上取得了显著的成果,尤其是卷积神经网络......
  • 一些常见的简单优化
    1:输入优化readios::sync_with_stdio(0),cin.tie(0),cout.tie(0);namespaceio{ constllBUFSIZE=1<<20; charibuf[BUFSIZE],*is=ibuf,*it=ibuf; charobuf[BUFSIZE],*os=obuf,*ot=obuf+BUFSIZE; inlinechargetch(){ if(is==it)it=(is=ibuf)+fread(ibuf,1,BUF......
  • Mysql SQL优化
    ​​Mysql查询执行的过程链接一、索引的代价我们虽然可以根据我们的喜好在不同的列上建立索引,但是建立索引是有代价的,所以不要建太多的索引:【1】空间上的代价:每建立一个索引都要为它建立一棵B+树,每一棵B+树的每一个节点都是一个数据页,一个页默认会占用16KB的存储空间,一......