基于粒子群算法的分布式电源配电网重构优化matlab仿真

目录

1.课题概述

2.系统仿真结果

3.核心程序与模型

4.系统原理简介

4.1基本PSO算法原理

4.2配电网重构的目标函数

5.完整工程文件


1.课题概述

基于粒子群算法的分布式电源配电网重构优化。通过Matlab仿真,对比优化前后

1.节点的电压值
2.线路的损耗,这里计算网损
3.负荷均衡度
4.电压偏离
5.线路的传输功率
6.重构后和重构前开关变化状态

2.系统仿真结果

1.节点的电压值

  15.0000 + 0.0000i
  14.9761 + 0.0002i
  14.8564 + 0.0014i
  14.8396 + 0.0000i
  14.8257 - 0.0006i
  14.7965 - 0.0093i
  14.7898 - 0.0164i
  14.3003 - 0.3734i
  14.2857 - 0.3291i
  14.2937 - 0.3099i
  14.2968 - 0.3073i
  14.3781 - 0.4659i
  14.3691 - 0.4669i
  14.2306 - 0.2775i
  14.2385 - 0.2765i
  14.2389 - 0.2553i
  14.2331 - 0.2024i
  14.2325 - 0.1839i
  14.9747 - 0.0003i
  14.4088 - 0.4626i
  14.3907 - 0.4526i
  14.4048 - 0.4598i
  14.7643 - 0.0073i
  14.5812 - 0.0374i
  14.4344 - 0.0587i
  14.7945 - 0.0095i
  14.7931 - 0.0096i
  14.3626 - 0.0771i
  14.3669 - 0.0753i
  14.3191 - 0.0713i
  14.2603 - 0.1246i
  14.2465 - 0.1425i
  14.2405 - 0.1634i

2.线路的损耗,这里计算网损
PLoss0 =

  139.9155
PLoss1 =

   56.7952

损耗降低百分比:

ans =

   59.4075

3.负荷均衡度
ans =

    0.0196

4.电压偏离
ans =

   27.8995


5.线路的传输功率
Powers =

   22.5049
   22.5231
   22.5006
   22.5004
   22.5006
   22.5000
   22.9657
   22.5014
   22.5003
   22.5001
   22.5765
   22.5000
   22.5373
   22.5001
   22.5004
   22.5008
   22.5003
   22.5000
   22.6966
   22.5004
   22.5001
   22.5129
   22.5236
   22.5152
   22.5000
   22.5000
   22.6011
   22.5000
   22.5036
   22.5033
   22.5007
   22.5004
   22.5036
   22.5012
   22.5002
   22.5005
   22.5048

6.重构后和重构前开关变化状态
Switch0 =

     7     1     3     2    16


Switch1 =

     2     4     4     4    15


swicths =

     2     4     4     4    15
     3     5     5     5    16

3.核心程序与模型

版本:MATLAB2017B

.............................................................................figure;
plot(objs,'linewidth',2);
xlabel('迭代次数');
ylabel('适应度值');
grid on%1、节点的电压值
Node_volgates{indxmin2}
%2、线路的损耗,这里计算网损
%重构前
PLoss0 = Loss0(indxmin_,:) 
%重构后
PLoss1 = min(Loss1)
disp('损耗降低百分比:');
100*abs(PLoss0-PLoss1)/PLoss0%负荷均衡度,这里均衡采用了方差来计算,值越小,均衡度越高
fobj2(indxmin)%电压偏离
fobj1(indxmin)%3、线路的传输功率
case33;
Node_voltage = Node_volgates{indxmin2};
for iii = 1:length(Matrix1)Powers(iii,1) =  abs((abs(Node_voltage(Matrix1(iii,2))-Node_voltage(Matrix1(iii,3))))^2/(Matrix1(iii,4))+Rz); 
end
Powers
%4、重构后和重构前开关变化状态
%重构前
Switch0 = Best_pso_(indxmin_,:) 
%重构后
Switch1 = Best_pso(indxmin2,:) %5、如果出现故障,及一条线路断开之后开关变化状态
%这里进行断开支路测试
for i = 1:Swicthswicths(:,i) = [Matrix1(Switch1(i),2:3)]';
end
swicths
02_054m

4.系统原理简介

         分布式电源配电网重构(Distribution Network Reconfiguration,DNR)是一个重要的电力系统优化问题,旨在通过改变配电网中的开关状态,以最小化网络损耗、提高供电可靠性和优化分布式电源的接入效益。粒子群优化算法(Particle Swarm Optimization, PSO)作为一种启发式全局优化方法,被广泛应用于解决此类复杂优化问题。

4.1基本PSO算法原理

       在PSO中,每个粒子表示配电网重构的一种可能解(即一种开关状态组合),其位置矢量X_i代表第i个粒子所对应的解空间中的解。每个粒子具有速度矢量V_i,用于更新其位置:

  • w是惯性权重,用于平衡全局搜索和局部搜索。
  • c_1 和 c_2 是加速常数,控制个体最优解(P_i)和全局最优解(G_i)对当前粒子的影响。
  • r_1 和 r_2 是随机变量,在[0, 1]之间,用于引入随机性。
  • P_i 是粒子i的历史最优位置(对应最低目标函数值的开关状态组合)。
  • G 是整个种群中的全局最优位置(所有粒子经历过的最优开关状态组合)。

4.2配电网重构的目标函数

       在基于粒子群算法的分布式电源配电网重构优化问题中,目标函数通常结合了多个评价指标以达到综合最优。这里主要考虑以下三个关键因素:

       节点电压偏离(Voltage Deviation) 节点电压偏离反映了配电网络重构后各节点实际电压与额定电压之间的差异。其数学表示通常采用均方误差的形式:

其中,Ui​ 是第 i 个节点的实际电压,Uref​ 是参考电压或额定电压,N 是总节点数。

       线路负荷均衡度(Load Balance Index) 线路负荷均衡度衡量的是整个配电网内各线路负载分布的均匀程度。一种可能的度量方法是计算所有线路负荷与其平均值的标准差:

其中,Pj​ 表示第 j 条线路的功率负荷,ˉPˉ 是所有线路负荷的平均值,M 是线路总数。

        线路损耗(Line Losses) 线路损耗包括电阻损耗和电抗损耗,在考虑分布式电源接入的情况下,需要根据重构后的网络拓扑结构和运行状态计算总的线路损耗:

这里,Rj​ 和Xj​ 分别为第 j 条线路的电阻和感抗,Ij​ 是通过该线路的电流。

将上述三个指标整合成一个复合目标函数,可以采用加权和的方式表达:

       粒子群算法则用于求解此复合目标函数的最小化问题,通过不断迭代更新每个粒子(即潜在的网络重构方案)的位置和速度,最终找到一组最优的开关状态组合。

5.完整工程文件

v

v

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

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

相关文章

阿里二面:什么情况会发生Full GC?如何避免频繁Full GC?

阿里二面:什么情况会发生Full GC?如何避免频繁Full GC? Minor GC、Major GC 和 Full GC区别? Minor GC、Major GC和Full GC是垃圾回收中的三个重要概念,它们描述了垃圾回收的不同阶段和范围: Minor GC&am…

【leetcode热题】 分数到小数

给定两个整数,分别表示分数的分子 numerator 和分母 denominator,以 字符串形式返回小数 。 如果小数部分为循环小数,则将循环的部分括在括号内。 如果存在多个答案,只需返回 任意一个 。 对于所有给定的输入,保证 …

【SQL Server】实验七 数据完整性

1 实验目的 掌握实体完整性、参照完整性和用户自定义完整性约束的创建方法。掌握完整性约束的运行检查机制。掌握参照完整性的级联删除和修改方法。掌握正确设计关系模式完整性约束的方法。 2 实验内容 2.1 掌握实体完整性约束的创建和使用方法 创建表时定义由一个属性组成…

【蓝桥杯选拔赛真题38】C++判断数字 第十四届蓝桥杯青少年创意编程大赛 算法思维 C++编程选拔赛真题解析

目录 C判断数字 一、题目要求 1、编程实现 2、输入输出 二、算法分析 三、程序编写 四、程序说明 五、运行结果 六、考点分析 七、推荐资料 C判断数字 第十四届蓝桥杯青少年创意编程大赛C选拔赛真题 一、题目要求 1、编程实现 给定一个正整数N(100≤N<100000)…

特殊内齿轮加工的另一种选择

内齿轮加工普遍采用插齿或拉削&#xff0c;但对于一些特殊齿廓的内齿轮来说&#xff0c;插齿可能会有一定的困难&#xff0c;或者成本较高。在这种情况下&#xff0c;线切割加工不失为一种不错的选择。那么什么样的零件需要选择这种加工方式呢&#xff1f;一起来看看&#xff1…

【Java】常用类和基础API

文章目录 一、String的特性二、String的内存结构2.1 拼接2.2 new 三、String的常用API-13.1 构造器 四、String的常用API-24.1 常用方法4.2 查找4.3 字符串截取4.4 和字符/字符数组相关4.5 开头与结尾4.6 替换 五、StringBuffer、StringBuilder5.1 StringBuilder、StringBuffer…

【RS422】基于未来科技FT4232HL芯片的多波特率串口通信收发实现

功能简介 串行通信接口常常用于在计算机和低速外部设备之间传输数据。串口通信存在多种标准&#xff0c;以RS422为例&#xff0c;它将数据分成多个位&#xff0c;采用异步通信方式进行传输。   本文基于Xilinx VCU128 FPGA开发板&#xff0c;对RS422串口通信进行学习。   根…

sqlite 常见命令 表结构

在 SQLite 中&#xff0c;将表结构保存为 SQL 具有一定的便捷性和重要性&#xff0c;原因如下 便捷性&#xff1a; 备份和恢复&#xff1a;将表结构保存为 SQL 可以方便地进行备份。如果需要还原或迁移数据库&#xff0c;只需执行保存的 SQL 脚本&#xff0c;就可以重新创建表…

如何在“Microsoft Visual Studio”中使用OpenCV编译应用程序

返回目录&#xff1a;OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 前一篇&#xff1a;OpenCV4.9.0在windows系统下的安装 后一篇&#xff1a; 警告&#xff1a; 本教程可以包含过时的信息。 我在这里描述的所有内容都将适用于 OpenCV 的C\C接口。我首先假…

力扣热题100_矩阵_240_搜索二维矩阵 II

文章目录 题目链接解题思路解题代码 题目链接 240. 搜索二维矩阵 II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性&#xff1a; 每行的元素从左到右升序排列。 每列的元素从上到下升序排列。 示例 1&#xff1a; 输入&#xf…

专升本 C语言笔记-07 逗号运算符

1.逗号表达式的用法 就是用逗号隔开的多个表达式。逗号表达式&#xff0c;从左向右依次执行。 2.逗号表达式的特性 2.1.当没有括号时&#xff0c;第一个表达式为整个表达式的值。 代码 int x 3,y 5,a 0; a x,y; printf("a %d",a); 说明:因为逗号优先级最低,会…

PyTorch学习笔记之激活函数篇(一)

文章目录 1、Sigmoid函数1.1 公式1.2 对应图像1.2 生成图像代码1.4 优点与不足1.5 torch.sigmoid()函数 1、Sigmoid函数 1.1 公式 Sigmoid函数的公式&#xff1a; f ( x ) 1 1 e − x f(x) \frac{1}{1e^{-x}} f(x)1e−x1​ Sigmoid函数的导函数&#xff1a; f ′ ( x ) e …

灯塔:CSS笔记(4)

伪类选择器&#xff1a; 1.作用与优势&#xff1a; 1.作用&#xff1a;根据元素在HTML中的结构关系查找元素 2.优势&#xff1a;减少对于HTML中类的依赖&#xff0c;有利于保持代码的整洁 3.场景&#xff1a;常用于查找某父级选择器中的子元素 2.选择器 选择器说明E:first-c…

软考80-上午题-【面向对象技术3-设计模式】-结构型设计模式03

一、外观模式 1-1、意图 为子系统中的一组接口提供一个一致的界面。 Facade 模式定义了一个高层接口&#xff0c;这个接口使得这一子系统更加容易使用。 1-2、结构 Facade 知道哪些子系统类负责处理请求&#xff1a;将客户的请求代理给适当的子系统对象。Subsvstem classes …

SpingBoot集成Rabbitmq及Docker部署

文章目录 介绍RabbitMQ的特点Rabbitmq术语消息发布接收流程 Docker部署管理界面说明Overview: 这个页面显示了RabbitMQ服务器的一般信息&#xff0c;例如集群节点的名字、状态、运行时间等。Connections: 在这里&#xff0c;可以查看、管理和关闭当前所有的TCP连接。Channels: …

【ollama】(7):使用Nvidia Jetson Nano设备,成功运行ollama,运行qwen:0.5b-chat,速度还可以,可以做创新项目了

1&#xff0c;视频地址 https://www.bilibili.com/video/BV1Pj421o7W5/ 【ollama】&#xff08;7&#xff09;&#xff1a;使用Nvidia Jetson Nano设备&#xff0c;成功运行ollama&#xff0c;运行qwen:0.5b-chat&#xff0c;速度还可以&#xff0c;可以做创新项目了 2&#x…

源码编译部署LAMP

编译部署LAMP 配置apache [rootzyq ~]#: wget https://downloads.apache.org/apr/apr-1.7.4.tar.gz --2023-12-11 14:35:57-- https://downloads.apache.org/apr/apr-1.7.4.tar.gz Resolving downloads.apache.org (downloads.apache.org)... 88.99.95.219, 135.181.214.104…

MySQL实现事务隔离的秘诀之锁

在MySQL中&#xff0c;有多种锁类型&#xff0c;我们先了解三种概念的锁&#xff0c;以便对接下来的内容有更好理解。 表级锁&#xff08;Table Lock&#xff09;&#xff1a;对整个表加锁&#xff0c;其他事务无法修改或读取该表的数据&#xff0c;但可以对其他表进行操作。页…

【研发管理】产品经理-基础认知

导读&#xff1a;产品经理&#xff08;Product Manager&#xff09;是一个负责产品的全周期管理的职位&#xff0c;他们不仅参与产品的设计、开发、推广和销售&#xff0c;还涉及到产品的市场调研、用户需求分析、竞争分析、产品规划、产品测试以及后续的产品迭代等多个环节。产…

C语言-strtok(切片的使用)

strtok&#xff08;切片的使用&#xff09; 使用规则 使用的基本情况 strcpy 第二次调用的时候传的是空指针 所以打印出来的是 每一次调用函数都会把当前函数的地址记住 所以二次调用的时候 传的是null 连起始位置都不传了 只是传null 但是需要知道的是 当知道三段 你调用第…