开源代码分享(19)-配电网孤岛优化划分方法

2024-04-09 17:52

本文主要是介绍开源代码分享(19)-配电网孤岛优化划分方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考文献:

DING Tao, LIN Yanling, LI Gengfeng, et al. A new model for resilient distribution systems by microgrids formation[J]. IEEE Transactions on Power Systems, 2017, 32(5): 4145-4147. 

1.基本原理

        通过分布式电源(DGs)形成多个微网,为在配电系统中恢复关键负载提供了一种坚韧可靠的解决方案。然而,随着微网数量的增加,需要更多的虚拟二进制和连续变量,从而增加了这种模型的复杂性。为解决这一问题,本文提出了一种新模型来重新制定具有韧性的配电网络中的微网形成问题。与传统模型相比,二进制和连续变量的数量大大减少,因此计算性能得到了显著提高。在IEEE测试系统上的数值结果验证了所提出模型的有效性。本文将提出一种新的数学模型,以减少配电网孤岛划分模型的决策变量数量,并改善计算性能。

        弹性配电系统的微网形成通过分段开关来形成不同的网络单元,每个微网中只有一个DG,以确保系统具有自给自足性。其目标是在满足运行约束和拓扑约束的情况下,最大化自然灾害后所吸纳的负荷的加权总和。

1.1 运行约束:

        对于微网,我们使用线性化DistFlow模型来制定微网的运行约束,其中给出了约束(1)-(6)。具体来说,(1)表示功率平衡;(2)是DistFlow方程。具体而言,如果支路关闭,则该支路的电压差受功率流限制,支路电流应受到限制;否则,电压差是任意的,支路电流必须为零;(3)给出了每个母线的电压限制;(4)和(5)是关于DG输出限制的;(6)表示负荷需求限制。

1.2 拓扑约束

        拓扑约束考虑了节点聚类约束、微网连通性约束和支路-节点约束来实现配电网络的划分成多个微网。然而,与输电系统不同,配电系统具有拓扑呈辐射状的特性。因此,如果可以实现辐射性,那么[4]中所有与拓扑相关的约束都将得到满足。在这种情况下,[4]中提到的约束是多余的,可以简化为本文中的“辐射性约束”。
        此外,[5]中提出了一种实现辐射性的充分必要条件,即当且仅当以下两个条件得到满足时,图形具有辐射性:(i)每个子图都是一个连通图;(ii)支路数等于节点数减去给定的子图数。
        为了满足第一个条件,根据图论,可以通过数学规划和单一商品流方法[6]来表述子图的连通性约束。关于网络连通性的条件是基于单一商品流的以下特点:设计一个具有相同拓扑结构的虚构网络,其中每个子图只有一个电源,称为“源”,而其他所有母线(除“源”母线外)具有单位负荷需求,充当“汇”。由于虚构网络与原始电力网络具有相同的拓扑结构,它们具有相同的连通性。因此,在虚构网络中每个母线的能量平衡的满足意味着“源”母线与所有其他母线之间至少存在一条路径,因此子图必须是连通的。
        值得注意的是,可以在每个微网中的任何母线上选择源。在本文中,我们选择每个微网中的DG母线作为“源”母线。因此,我们有

        值得注意的是,由于每个微网只包含一个DG,所以微网的数量与DG的数量相同。因此,|{DG}|是一个预先确定的参数。另外,令wj表示与母线j处负荷相关联的优先权重。最后,所提出的模型可以被表述为:

2.运行结果

3.matlab代码

        完整matlab代码可从下面的链接中免费获取:

开源代码分享(19)-配电网孤岛优化划分方法matlab代码资源-CSDN文库

这篇关于开源代码分享(19)-配电网孤岛优化划分方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/888836

相关文章

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Window Server2016加入AD域的方法步骤

《WindowServer2016加入AD域的方法步骤》:本文主要介绍WindowServer2016加入AD域的方法步骤,包括配置DNS、检测ping通、更改计算机域、输入账号密码、重启服务... 目录一、 准备条件二、配置ServerB加入ServerA的AD域(test.ly)三、查看加入AD域后的变

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

Window Server2016 AD域的创建的方法步骤

《WindowServer2016AD域的创建的方法步骤》本文主要介绍了WindowServer2016AD域的创建的方法步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、准备条件二、在ServerA服务器中常见AD域管理器:三、创建AD域,域地址为“test.ly”

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,