含电热联合系统的微电网运行优化附Matlab代码

news2025/7/19 2:40:12

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法  神经网络预测 雷达通信  无线传感器

信号处理 图像处理 路径规划 元胞自动机 无人机  电力系统

⛄ 内容介绍

在当前能源互联网迅速发展及电热联系日渐紧密的环境下,提出基于电热联合调度的区域并网型微电网运行优化模型.综合网内储能特性,分时电价,电热负荷与分布式电源的时序特征,以包含风机,光伏电池,热电联产系统,电锅炉,燃料电池和储能系统的并网型微电网为例,采用Cplex优化软件求得调度周期内各微电源最佳出力及总运行成本,并与两种常见电热调度方式进行比较.仿真算例表明:联合调度模型能实现电热统一协调调度并降低微电网运行成本.该模型可为电热之间能源互联及规划运营提供参考.

⛄ 部分代码

function f = initialize_variables(N, M, V, min_range, max_range, time, Zall, ComC0)

min = min_range;

max = max_range;

% K is the total number of array elements. For ease of computation decision

% variables and objective functions are concatenated to form a single

% array. For crossover and mutation only the decision variables are used

% while for selection, only the objective variable are utilized.

number_of_decision_variables.c =  V(1,1);

number_of_decision_variables.t =  V(2,1);

K = M + 2 * V(1,1) + 2 * V(2,1);

StepComC = 1; %变量的离散化

StepT1 = 0.025;

StepT2 = 0.025;

%% Initialize each chromosome

% For each chromosome perform the following (N is the population size)

for i = 1 : N

     for j= 1 : number_of_decision_variables.c

              f(i,j) = min.c(j,1) + (max.c(j,1) - min.c(j,1))*rand(1);

              f(i,j + number_of_decision_variables.c) = min.c(j,2) + (max.c(j,2) - min.c(j,2))*rand(1);

           %f(i,j)离散化

              ComCC(j)= f(i,j);

                ComCC1(j) = abs(ComCC(j)) / StepComC;

                %Tap1 = Tap ./ StepTap;

                ComCC2(j) = fix(ComCC1(j)); %商

                ComCC3(j) = abs(ComCC(j)) - ComCC2(j) * StepComC;%余

                ComCC2(j) =  ComCC2(j) *  StepComC;

                %Tap = Tap1 - fix(Tap1);

                if ComCC3(j) > (StepComC / 2)

                  ComCC3(j) = StepComC - ComCC3(j);

                  ComCC2(j) = ComCC2(j) + StepComC;

                end

               if f(i,j)>0

                f(i,j) = ComCC2(j);

               else

                f(i,j) = - ComCC2(j); 

               end

           %检验f(i,j)中无重复    

               pf(1,:) = f(i,1:number_of_decision_variables.c);

               for w = 1 : number_of_decision_variables.c

                   for ww =  (w + 1) : number_of_decision_variables.c

                       while f(i,w) == pf(1,ww)

                             f(i,w) = min.c(j,1) + (max.c(j,1) - min.c(j,1))*rand(1);

                             ComCC(j)= f(i,w);

                             ComCC1(j) = abs(ComCC(j)) / StepComC;

                            %Tap1 = Tap ./ StepTap;

                            ComCC2(j) = fix(ComCC1(j)); %商

                            ComCC3(j) = abs(ComCC(j)) - ComCC2(j) * StepComC;%余

                            ComCC2(j) =  ComCC2(j) *  StepComC;

                            %Tap = Tap1 - fix(Tap1);

                        if ComCC3(j) > (StepComC / 2)

                            ComCC3(j) = StepComC - ComCC3(j);

                            ComCC2(j) = ComCC2(j) + StepComC;

                        end

                         if f(i,w)>0

                          f(i,w) = ComCC2(j);

                         else

                          f(i,w) = - ComCC2(j); 

                         end

                       end

                    end

               end             

               %f(i,j + number_of_decision_variables)离散化

                 ComCC(j)= f(i,j + number_of_decision_variables.c);

                ComCC1(j) = abs(ComCC(j)) / StepComC;

                %Tap1 = Tap ./ StepTap;

                ComCC2(j) = fix(ComCC1(j)); %商

                ComCC3(j) = abs(ComCC(j)) - ComCC2(j) * StepComC;%余

                ComCC2(j) =  ComCC2(j) *  StepComC;

                %Tap = Tap1 - fix(Tap1);

                if ComCC3(j) > (StepComC / 2)

                  ComCC3(j) = StepComC - ComCC3(j);

                  ComCC2(j) = ComCC2(j) + StepComC;

                end

               if f(i,j + number_of_decision_variables.c)>0

                f(i,j + number_of_decision_variables.c) = ComCC2(j);

               else

                f(i,j + number_of_decision_variables.c) = - ComCC2(j); 

               end

     end 

     

    for j= 1 : number_of_decision_variables.t

              f(i,j + 2 * V(1,1)) = min.t(j,1) + (max.t(j,1) - min.t(j,1))*rand(1);

              f(i,j + 2 * V(1,1) + number_of_decision_variables.t) = min.t(j,2) + (max.t(j,2) - min.t(j,2))*rand(1);

           %f(i,j)离散化

              ComCC(j)= f(i,j + 2 * V(1,1));

                ComCC1(j) = abs(ComCC(j)) / StepT1;

                %Tap1 = Tap ./ StepTap;

                ComCC2(j) = fix(ComCC1(j)); %商

                ComCC3(j) = abs(ComCC(j)) - ComCC2(j) * StepT1;%余

                ComCC2(j) =  ComCC2(j) *  StepT1;

                %Tap = Tap1 - fix(Tap1);

                if ComCC3(j) > (StepT1 / 2)

                  ComCC3(j) = StepT1 - ComCC3(j);

                  ComCC2(j) = ComCC2(j) + StepT1;

                end

               if f(i,j)>0

                f(i,j + 2 * V(1,1)) = ComCC2(j);

               else

                f(i,j + 2 * V(1,1)) = - ComCC2(j); 

               end                 

               %f(i,j + 2 * V(1,1) + number_of_decision_variables)离散化

                 ComCC(j)= f(i,j + 2 * V(1,1) + number_of_decision_variables.t);

                ComCC1(j) = abs(ComCC(j)) / StepT2;

                %Tap1 = Tap ./ StepTap;

                ComCC2(j) = fix(ComCC1(j)); %商

                ComCC3(j) = abs(ComCC(j)) - ComCC2(j) * StepT2;%余

                ComCC2(j) =  ComCC2(j) *  StepT2;

                %Tap = Tap1 - fix(Tap1);

                if ComCC3(j) > (StepT2 / 2)

                  ComCC3(j) = StepT2 - ComCC3(j);

                  ComCC2(j) = ComCC2(j) + StepT2;

                end

               if f(i,j + 2 * V(1,1) + number_of_decision_variables.t)>0

                f(i,j + 2 * V(1,1) + number_of_decision_variables.t) = ComCC2(j);

               else

                f(i,j + 2 * V(1,1) + number_of_decision_variables.t) = - ComCC2(j); 

               end              

    end    

         f(i, 2 * V(1,1) + 2 * V(2,1) + 1 : K) = evaluate_objective(f(i,:),M ,V ,time, Zall, ComC0);

end

⛄ 运行结果

⛄ 参考文献

[1]李正茂, 张峰, 梁军,等. 含电热联合系统的微电网运行优化[J]. 中国电机工程学报, 2015, 35(14):3569-3576.

⛄ Matlab代码关注

❤️部分理论引用网络文献,若有侵权联系博主删除

❤️ 关注我领取海量matlab电子书和数学建模资料

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/38802.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot+Vue项目投稿和稿件处理系统

文末获取源码 开发语言:Java 使用框架:spring boot 前端技术:JavaScript、Vue.js 、css3 开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code 数据库:MySQL 5.7/8.0 数据库管理工具:phpstudy/Navicat JD…

MYSQL中的锁

全局锁 就是对整个数据库进行加锁,加锁之后整个数据库就处于只读状态,后续的DML写语句,DDL语句,以及对更新事务的提交操作都会被阻塞,典型地使用场景就是做整个数据库的逻辑备份,对所有的表进行锁定&#x…

非凡社群管理之如何高效的进行社群管理

一、初始成员的严格筛选 我们建立社群初期,就要严格筛选初始会员,争取让我们找到的第一批种子用户,就是有着共同的连接点。而不是找到一群人之后,再去培养大家的同好。这样不仅吃力不讨好,往往效果也不太高&#xf…

Kafka系列之:实现Kafka Connect集群访问认证

Kafka系列之:实现Kafka Connect集群访问认证 一、Kafka Connect访问控制二、Kafka Connect技术知识三、详细介绍Kafka connect访问认证实现过程四、启动Kafka Connect集群五、测试Kafka Connect集群访问认证一、Kafka Connect访问控制 实现的效果如下所示: 错误的用户名和密…

nginx降权及匹配php

1.nginx降权 1.1 capabilities的介绍与运用 1.2 用普通用户启动nginx 1.3 root用户权限赋予 1.4 查看普通用户的nginx权限 1.5 查看nginx的欢迎网页 2.nginx与php的相互匹配 2.1 安装php及php-fpm包 2.2 检查php-fpm服务运行状态 2.3 php-fpm上的配置 2.4 nginx上的配…

基于matlab的精馏塔作业模拟仿真

欢迎订阅《FPGA学习入门100例教程》、《MATLAB学习入门100例教程》 目录 一、理论基础 二、核心程序 三、测试结果 一、理论基础 原料物性表如下: 表3-1原料物理性质表 组分 质量流率 质量分数 摩尔流率 摩尔分数 分子量 常压沸点 丙烷 472.938 7.567…

SpringBoot SpringBoot 原理篇 1 自动配置 1.9 bean 的加载方式【七】

SpringBoot 【黑马程序员SpringBoot2全套视频教程,springboot零基础到项目实战(spring boot2完整版)】 SpringBoot 原理篇 文章目录SpringBootSpringBoot 原理篇1 自动配置1.9 bean 的加载方式【七】1.9.1 ImportBeanDefinitionRegistrar1 …

mysql 到底是 join性能好,还是in一下更快呢

先总结: 数据量小的时候,用join更划算数据量大的时候,join的成本更高,但相对来说join的速度会更快数据量过大的时候,in的数据量过多,会有无法执行SQL的问题,待解决 事情是这样的,去…

浅谈Spring Cloud Gateway源码

本文不谈Spring Cloud Gateway相关的使用,仅梳理在微服务项目中,在使用Spring Cloud Gateway做为服务网关后,接收到请求后的大体执行流程。 文章目录大致流程图具体流程一、DispatcherHandler二、getHandler1、getHandlerInternal2、lookupRo…

【GlobalMapper精品教程】027:路径剖面和和视线工具的使用

文章目录 一、路径剖面简介二、创建剖面图1. 加载DEM2. 创建剖面图3. 计算填挖方3. 保存剖面图一、路径剖面简介 路径剖面视线工具允许您使用加载的高程数据集沿用户指定的路径获取垂直剖面。 要定义生成3D路径剖面所遵循的路径,只需单击鼠标左键选择路径的点,然后石键单击…

[acwing周赛复盘] 第 60 场周赛20220716

[acwing周赛复盘] 第 60 场周赛20220716 一、本周周赛总结二、 4722. 数列元素1. 题目描述2. 思路分析3. 代码实现三、4723. 队列1. 题目描述2. 思路分析3. 代码实现四、4724. 靓号1. 题目描述2. 思路分析3. 代码实现六、参考链接一、本周周赛总结 第一次打acwing,…

POJ1007:DNA排序

一、Description One measure of unsortedness in a sequence is the number of pairs of entries that are out of order with respect to each other. For instance, in the letter sequence DAABEC’‘, this measure is 5, since D is greater than four letters to its ri…

傻白入门芯片设计,典型的2D/2D+/2.5D/3D封装技术(六)

集成电路终于成为了一级学科,对集成电路领域的投入也日益加大,集成电路属于电子集成技术的一种,那么,现在的电子集成技术发展到了什么程度呢? 先进的电子集成技术可以在不到芝麻粒大小的1平方毫米内集成1亿只以上的晶体…

Tableau 合集3:格式设置之可视化图显示百分比和提示工具对齐问题

一、前言 本文通过可视化图中显示不了百分比和提示工具无法对齐两个小问题出发,介绍了关于Tableau设置格式和工具提示的一些使用方法。 环境:Windows11 64位、Tableau desktop 2021.2 二、问题1:可视化图中显示不了百分比 问题描述&#…

springboot整合其它项目(连接池和监控)

目录 一、整合Druid 1. Druid是什么? 2.如何在Spring Boot中集成Druid连接池和监控? 二、整合Redis 1.集成redis之非注解式开发 2.集成redis之注解缓存开发 一、整合Druid 1. Druid是什么? Druid是Java语言中最好的数据库连接池。…

paddleocr识别模型训练记录

准备数据集 自己新建目录 下载识别预训练模型 下载之后是一个压缩包,解压后(注意:rec是自己新建的目录) 修改配置文件 修改内容: 1.训练后模型存储目录; 2.是否训练可视化; 3.训练数据集图…

tensorflow2 minist手写数字识别数据训练

✨ 博客主页:小小马车夫的主页 ✨ 所属专栏:Tensorflow 文章目录前言一、tenosrflow minist手写数字识别代码二、输出三、参考资料总结前言 刚开始学习tensorflow, 首先接触的是minist手写数字识别,用的梯度下降算法,…

linux下mysql的三种安装方法

目录1. 离线安装(.tar.gz安装包)2. 离线安装(rpm安装包)3. 在线安装(yum安装)前言安装环境 : Redhat Enterprise Linux 81. 离线安装(.tar.gz安装包) 参考这篇博客 2. 离线安装&am…

HTB-Toolbox

HTB-Toolbox信息收集提权信息收集 使用nmap简单扫描一下网站端口。 21 ftp22 ssh443 https? 去https看看。 网站基本是静态的。因为是https,所以有ssl协议,去看看吧。 more information里面能找到协议。 找到admin.megalogistic.com子域。…

Spring(完整版)

文章目录一、Spring(一)、Spring简介1、Spring概述2、Spring家族3、Spring Framework1、Spring Framework五大功能模块2、Spring Framework特性(二)、控制反转IOC1、IOC容器1、IOC思想2、IOC容器在Spring中的两种实现方式①BeanFactory②ApplicationContext③ApplicationContex…