基于非支配排序遗传算法NSGAII的综合能源优化调度(Matlab代码实现)

👨‍💻做科研,涉及到一个深在的思想系统,需要科研者逻辑缜密,踏实认真,但是不能只是努力,很多时候借力比努力更重要,然后还要有仰望星空的创新点和启发点。当哲学课上老师问你什么是科学,什么是电的时候,不要觉得这些问题搞笑。哲学是科学之母,哲学就是追究终极问题,寻找那些不言自明只有小孩子会问的但是你却回答不出来的问题。建议读者按目录次序逐一浏览,免得骤然跌入幽暗的迷宫找不到来时的路,它不足为你揭示全部问题的答案,但若能让人胸中升起一朵朵疑云,也未尝不会酿成晚霞斑斓的别一番景致,万一它居然给你带来了一场精神世界的苦雨,那就借机洗刷一下原来存放在那儿的“躺平”上的尘埃吧。

     或许,雨过云收,神驰的天地更清朗.......🔎🔎🔎

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码实现


💥1 概述

基于非支配排序遗传算法(NSGA-II)的综合能源优化调度是一种常用的方法,用于解决能源系统中的多目标优化问题。该方法将非支配排序和遗传算法相结合,通过演化算法的方式搜索出一组最优解,这些解在多个目标函数的情况下不可被其他解所支配。

下面是基于NSGA-II的综合能源优化调度的一般步骤:

1. 定义问题:确定综合能源系统的建模方法以及目标函数,例如最小化能源成本、最大化可靠性等。

2. 确定变量和约束条件:确定问题的决策变量,例如电力的发电量、充电和放电规模等,并考虑到系统的物理约束条件和运行要求。

3. 初始化种群:随机生成初始解集作为种群,每个解包含一组决策变量的取值。

4. 评价适应度:根据目标函数评估每个解的适应度值,可以采用模拟算法、实验数据或者仿真模型进行评估。

5. 非支配排序:使用非支配排序算法将种群中的解按照Pareto优劣分类,得到多个非支配层级。

6. 计算拥挤度:为每个非支配层级的解计算拥挤度,用于保持种群的多样性。拥挤度反映了解在解空间中的密度,可以通过解的变量空间距离或目标函数值空间距离进行计算。

7. 选择操作:根据非支配排序和拥挤度计算,选择生成下一代种群的父代解,通常使用锦标赛选择或轮盘赌选择等方法。

8. 遗传操作:通过交叉和变异操作,生成子代解。交叉操作将两个父代解的某些特征进行交换、组合,变异操作则对某个解的特征进行随机改变。

9. 更新种群:将父代解和子代解结合,更新种群,并删除一些解以维持种群规模不变。

10. 重复步骤4-9,直到达到停止条件(例如最大迭代次数、目标函数收敛等)。

11. 输出结果:选择最优的解作为综合能源系统的优化调度结果,分析其特征和性能。

需要注意的是,NSGA-II是一种探索整个解空间的算法,通过非支配排序和拥挤度计算,可以得到一组非支配解和多样性的解集,而不仅仅是单个最优解。这使得决策者可以在最优解集中选择最适合实际需求的解。

📚2 运行结果

 

 

 

 

部分代码:

for t=1:24 % (2) 冷能平衡约束
    Pec(:,t)=-(Pmt(:,t)*0.8*1.2-Pc(:,t)); %电制冷机功率利用平衡求解
end

for t=1:24 % (1) 电能平衡约束
    Pg(:,t)=-(Pmt(:,t)+Ppv(:,t)-Pec(:,t)/4-Pgs(:,t)-Pel(:,t)) ; %=0%电制冷机功率利用平衡求解
end

%tosis取点后各个设备出力

Pmt1 = mm(aa,1:24);      % 燃气轮机出力 
Phrb1= 0.8*mm(aa,1:24); %余热锅炉
Pac1=0.8*1.2*mm(aa,1:24);%吸收式制冷机
Pgs1=mm(aa,25:48);  %地源热泵电功率
Pgs_hot1=4.4*mm(aa,25:48); %地源热泵热功率
Phs1=mm(aa,49:72);   %储热热备

Pgb1=Pgb(aa,1:24); %燃气锅炉
Pec1=Pec(aa,1:24); %电制冷机
Pg1=Pg(aa,1:24); %电网交互

🎉3 参考文献

部分理论来源于网络,如有侵权请联系删除。

[1]王安阳,单菲菲,钟崴等.基于非支配排序遗传算法-Ⅲ的工业园区综合能源系统多目标优化调度[J].热力发电,2021,50(06):46-53.DOI:10.19666/j.rlfd.202009257.

[2]李振,赵鹏翔,王楠等.基于储能灵活性的综合能源系统优化调度方法[J].电气传动,2023,53(05):33-40.DOI:10.19457/j.1001-2095.dqcd24103.

🌈4 Matlab代码实现

  • 17
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于支配排序遗传算法(Non-Dominated Sorting Genetic Algorithm,NSGA)是一种用于处理多目标优化问题的进化算法。它是在遗传算法的基础上进行改进,可以同时优化多个目标函数,并生成一系列支配解,这些解都不互相支配。 在基于支配排序遗传算法matlab例程中,首先需要定义多目标函数,即我们需要优化的多个目标的评价函数。然后,通过设定遗传算法的初始种群、交叉和变异操作的参数,进行种群的初始化。 接下来,在每一代中,使用支配排序算法对种群进行分层,将所有个体根据其支配关系划分为不同的层级。越接近第一层的个体越优秀,因为它们不被其他个体所支配。 然后,根据这些层级进行选择操作,以保留多样性和局部优化能力。选择操作可以使用快速支配排序算法,同时结合拥挤度算子,根据个体在解向量空间中的拥挤度进行选择。 接下来进行交叉和变异操作,通过交叉和变异产生新的个体,并替换掉原来的个体。通过不断进行交叉和变异操作,直到达到停止条件为止,例如达到最大迭代次数或找到满足要求的解。 最后,根据最终得到的支配解的集合,进行后处理操作,如生成帕累托前沿面、计算各个解的拥挤度等信息。 总之,基于支配排序遗传算法matlab例程通过将多目标函数转化为单目标优化问题,并结合支配排序和拥挤度算子等技术,能够有效求解多目标优化问题,得到一系列支配解,提供了多样性的解集。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值