目录

1.算法描述

2.仿真效果预览

3.MATLAB核心程序

4.完整MATLAB


1.算法描述

随着科技的发展,人民生活水平的不断提高,使得当今社会的发展对能源环保性和供电的可靠性的要求也不断提高。集中式供电系统由于污染大、可靠性差及操作难度大等缺陷越来越不能满足供电的要求。研究表明,集中式供电系统和分布式电源相结合可以降低配电网系统损耗,节省投资成本,增大系统的稳定性。但DG并网运行后会对系统的损耗、潮流分布、系统可靠性等方面造成影响,这些影响与分布式电源的位置和容量有关。所以,研究对分布式电源位置、容量优化配置问题具有重大意义。目前,对分布式电源选址定容的方法很多。本论文建立了系统有功损耗最小的单目标函数优化模型,并列写了相关的约束条件。介绍了不同的分布式电源的工作原理和并网接口类型,本论文中采用了双馈风力发电作为分布式电源。潮流计算的方法为前推回代法,使用遗传算法对分布式电源进行优化。针对遗传算法的不足,对遗传算法的选择操作进行了改进,从而提高了对问题解的查找能力,防止出现局部最优解的问题。

分布式电源(Distributed Generation,简称DG),通常是指发电功率在几千瓦至数百兆瓦(也有建议在30~50兆瓦以下)的小模块化、分散式、布置在用户附近的高效、可靠的发电单元。

分布式电源与配电网相结合,其优点可简单总结为如下几个方面:

1)分布式电源占地面积小,装机容量小,且经常安装于用户和负荷附近,降低线路损耗,节约投资成本。而集中式电源集中式发电,需远距离传输至用户,这样会增大线路的损耗,线路过长使安装成本增高。

2)分布式电源通过合理的能量的梯级利用,增大了能量的使用率,从而减小能量的损耗。

3)分布式电源可以弥补供电安全性的不足,提高供电的稳定性,一般在负荷侧安装DG,通过与配电网结合,可以在配电网事故停电下维持重要用户供电,保证用户用电可靠性。

4)对分布式能源进行合理优化,能够减小系统的损耗,减少能源浪费。

5)对分布式电源的合理优化降低能源的损耗,减少资金的投入和对环境的污染。

分布式电源作为一种绿色新能源,由于其具有能源利用率高且对环境污染小等优点,所以得到了广泛的应用研究。目前,分布式电源主要以备用电源的形式应用在工业、农业等领域。集中式供电系统中多个发电系统经过一个或几个变压器的汇集再并入配电网中,分布式供电系统中发电系统相互独立,每个发电系统都可以直接并入配电网。分布式电源和集中式电源最大的区别是安装在负荷点附近和规模较小,所以DG可以根据附近负荷需求量的大小,直接向负荷进或系统进行供电,一般情况下,不论为何种发电形式,只要是安装在用户附近的发电设备都可以定义为分布式电源。电力工业由单纯的集中式发电模式逐渐转型为以大型发电站为主、分布式电源为辅的新型发电模式,使供电方式更加灵活,从而提高了电能的质量、降低系统损耗。

近年来,各个国家都致力于发展分布式电源,并取得一定的成果。在风力发电方面,欧洲拥有大量的风力资源,风力发电的发展已由陆地向海洋转移,集中式开发、远距离传输是以后的主流方向。在光伏发电方面,西方国家的建筑主要为中低层住宅,适合光伏发电。在天然气发电方面,欧美各国具有很高的天然气产量,而且管网设施发展完善,具有很好的发展条件,所以适宜发展天然气发电。我们国家的风力资源大部分在近海和三北地区,适合集中式发电,小部分的风力资源在中东部地区,有利于分布式发电。太阳能资源分布在西北地区既华北荒漠地区,适合集中式开发,且我们国家城市的建筑较高,太阳能发电条件不完善,城市地区不适合太阳能发电。天燃气的供应不足,管道设施不够完善,使天然气发电的发展受到限制。我国拥有大量的水力资源,与欧洲国家相比条件要好,发展前景广阔。目前,我们国家的分布式电源类型以水力发电为主,其发电技术也是非常先进。总之,我们国家分布式发电技术的发展不算落后,但是由于资源条件、政府政策和产业基础的影响,还是存在一定差异。

目标函数:最小有功损耗

潮流计算使用前推回代法,分为不含分布式电源和含分布式电源的潮流计算程序,并且在结果中要对不含分布式电源和含分布式电源的节点电压、支路电流、支路损耗进行画图对比,假如选择加两个分布式电源则在最终的结果中要展现出网络的损耗以及选择出来的两个分布式电源的位置以及容量(及就是功率),并画出进化曲线图。

2.仿真效果预览

matlab2022a仿真结果如下:

3.MATLAB核心程序

%%%%%%%给定初始化条件%%%%%%%%%%
%c1 学习因子1
%c2 学习因子2
%w惯性权重
%M最大迭代次数
%D搜索空间维数
%N初始化群体个体数目
clc;
clear;
close all;
warning off;
addpath(genpath(pwd));
rng('default')tic  % 输出程序运行时间
global Vi  X Y Z;  %定义全局变量Vi
Num=33;
N = 50;
% c1 = 1.5;
% c2 = 2.5;
% c1 = 2;
% c2 = 2;
% c1 = 2.05;
% c2 = 2.05;
% w=0.9;
c1 = 1;
c2 = 1.5;
w =0.65;
M =500;
% M =200;
D = 6;
% D = 4;
%3DG
ub = [33 33 33  3  3  3];
% ub = [33 33 33  2.048  2.048  2.048];
lb = [2  2  2   0  0  0];
% ub = [33 33 33  3  3  3  3  3  3];
% lb = [2  2  2   0  0  0  0  0  0];
%2DG
% ub = [33 33   2  2];
% lb = [2  2    0  0];
%%%%%%%%%%%%%%%%%%初始化种群的个体(可在这里限制位置和速度的范围)%%%%%
for i = 1:Nfor j = 1:Dub_j=ub(j);lb_j=lb(j);if j < 4
%           if j<3x(i,j) = round(rand(1,1).*(ub_j-lb_j))+lb_j;elsex(i,j)=rand(1,1).*(ub_j-lb_j)+lb_j;end
%         x(i,j) = randn;    %随机初始化位置v(i,j) = randn;    %随机初始化速度end
end%%%%%%%%%%%%先计算各个粒子的适应度值,并初始化pi和pg%%%%%%%%%
for i = 1:Np(i) = fitness(x(i,:));y(i,:) = x(i,:);
end
pg = x(N,:);    %pg为全局最优
for i = 1:(N-1)if fitness(x(i,:)) < fitness(pg)pg = x(i,:);end
end%%%%%%%%%%进入主要循环,按照公式依次迭代,直到满足精度要求%%%%%%%%%%%
for t = 1:Mtfor i = 1:N        %更新速度 位移v(i,:) = w*v(i,:)+c1*rand*(y(i,:)-x(i,:)-x(i,:))+c2*rand*(pg-x(i,:));x(i,:) = x(i,:) + v(i,:);for j = 1:Dub_j=ub(j);lb_j=lb(j);if j<4
%               if j < 3if x(i,j) > ub(j)x(i,j) = round(rand(1,1).*(ub_j-lb_j))+lb_j;elseif x(i,j) < lb(j)x(i,j) = round(rand(1,1).*(ub_j-lb_j))+lb_j;
%         else
%             x(i,j)=rand(1,1).*(ub_j-lb_j)+lb_j;endelseif x(i,j) > ub(j)x(i,j)=rand(1,1).*(ub_j-lb_j)+lb_j;elseif x(i,j) < lb(j)x(i,j)=rand(1,1).*(ub_j-lb_j)+lb_j;endendendx(i,[1,2,3]) = round(x(i,[1,2,3]));
%           x(i,[1,2]) = round(x(i,[1,2]));if fitness(x(i,:)) < p(i)p(i) = fitness(x(i,:));y(i,:) = x(i,:);endif p(i) < fitness(pg)pg = y(i,:);endendPbest(t) = fitness(pg);
end%%%%%%%%%%最后给出计算结果%%%%%%%%%%
disp('***************************************************')
disp('目标函数取最小值时的自变量:')
xm = pg
disp('目标函数最小值为:')
fv = fitness(pg)
disp('***************************************************')
% abs(Vi)
toc
figure;
plot(Pbest);
xlabel('迭代次数');
ylabel('有功损耗');
title ('进化曲线图');
[Ploss1,Udg,Idg,Sdg] = DGflow(X,Y,Z);
[Ploss0,Uv,IL,Sij,] = flow(Num); figure;
plot(Uv,'b-');
hold on;
plot(Udg,'r-');
xlabel('节点编号');
ylabel('节点电压幅值/标幺值');
legend('不加DG','添加DG');
title ('配电网接入DG后各节点电压对比图');
grid on  figure;
plot(IL,'b-');
hold on;
plot(Idg,'r-');
xlabel('支路编号');
ylabel('支路电流值/标幺值');
legend('不加DG','添加DG');
title ('配电网接入DG后各支路电流对比图');
grid on   figure;
plot(Sij,'b-');
hold on;
plot(Sdg,'r-');
xlabel('支路编号');
ylabel('支路损耗幅值/KW');
legend('不加DG','添加DG');
title ('配电网接入DG后各支路损耗对比图');
grid on
02_098m

4.完整MATLAB

V

m基于粒子群算法的分布式电源DG的优化配置相关推荐

  1. 【微电网优化】基于粒子群算法求解混合储能系统容量优化问题含Matlab源码

    1 简介 为了提高供电的稳定性.可靠性,实现日夜发电,在太阳能.风能资源比较丰富的区域,建立风能.太阳能互补发电系统.但是由于系统投入成本过高,风.光又存在间歇性和不稳定性等问题,需要配置储能系统来平 ...

  2. 基于多目标粒子群算法在分布式电源选址和定容中的应用matlab程序

    基于多目标粒子群算法在分布式电源选址和定容中的应用matlab程序 摘 要: 为更好地解决分布式电源选址定容问题,提出一种改进的多目标粒子群算法.考虑投资成本.网损以及电压稳定性三因素建立了一个三目标 ...

  3. 粒子群算法,分布式电源选址定容。 以IEEE33节点系统为算例,对分布式电源最佳接入位置及接入容量进行选取

    粒子群算法,分布式电源选址定容. 以IEEE33节点系统为算例,对分布式电源最佳接入位置及接入容量进行选取,以电压越限惩罚和网损为目标,利用粒子群算法进行优化设计,得到最佳接入位置和接入容量,完成选址 ...

  4. matlab代码:基于粒子群算法的智能微电网经济运行优化 智能微电网PSO优化算法

    matlab代码:基于粒子群算法的智能微电网经济运行优化 智能微电网PSO优化算法 基于时段电价差异,制定合理的储能系统充放电运行方式,优化各时段微电网与主网之间的交换功率,从而使得风光储微网系统综合 ...

  5. 【优化选址】基于模拟退火结合粒子群算法求解分布式电源定容选址问题matlab源码

    1 算法介绍 1.1 模拟退火算法 1.2 粒子群算法 粒子群算法同遗传算法相似,也是根据生物界中的种群行为而发明的一种算法.也是解决优化问题常用的一种算法.其原理简单,实现起来也不复杂,并且经过自己 ...

  6. 混合储能系统容量优化MATLAB程序基于粒子群算法

    混合储能系统容量优化MATLAB程序基于粒子群算法 (1)该程序为基于粒子群算法的混合储能系统容量优化程序,中文核心期刊论文源程序,配有该论文,再给一篇类似的参考论文. (2)该程序中混合储能系统为蓄 ...

  7. 基于粒子群算法的配电网重构研究matlab程序

    基于粒子群算法的配电网重构研究matlab程序 参考文献:基于改进灰狼算法的含分布式电源配电网重构研究 (本文未考虑分布式电源) 摘要:使用基本环矩阵编码的智能优化算法在处理配电网重构问题中,通常使用 ...

  8. 基于粒子群算法的微电网优化调度应用研究(四、基于粒子群算法的调度模型)

    基于粒子群算法的调度模型 4.1 目标函数 离网型的微电网包含各种分布式发电,如风力发电机组.光伏电池等,光伏和风力发电受自然资源的影响,输出功率不受控制,很难人工调度,其一次设备成本高,而微电网完全 ...

  9. 【配电网重构】基于粒子群算法实现配电网重构含Matlab源码

    1 简介 随着大规模,跨区域的配电网不断发展,对配电网运行的经济性和可靠性要求越来越高,在配电网发生大范围停电事故后,需要对配电网的拓扑结构进行重新组合,从而达到恢复供电的目的,这个重新组合配电网拓扑 ...

最新文章

  1. 盘点:2020 年机器学习 10 大进展
  2. 这安全测试的面试题目也太简单了吧,分分钟入职成功
  3. URAL 1427. SMS(DP+单调队列)
  4. 20155307 实验四 Android程序设计
  5. 【MFC】MFC开发之前言
  6. CoreOS安装到硬盘
  7. python网站用什么数据库_PyMySQL数据库的使用
  8. [vue] vue2.0不再支持v-html中使用过滤器了怎么办?
  9. lambda表达式或者匿名函数中为什么要求外部变量为final
  10. 原版英文书籍《Linux命令行》阅读记录1 | 什么是shell?
  11. Spring Cloud Config 规范 1
  12. java里ssm框架分页代码_SSM框架实现分页查询例子
  13. python linux 命令_Python Linux 命令行 sudo
  14. Javascript四种调用模式中的this指向
  15. qt可以实现创建临时无线热点吗?_数据线断了,身边又没有路由,如何无线高速传输文件?...
  16. 阶段3 1.Mybatis_01.Mybatis课程介绍及环境搭建_04.mybatis概述
  17. python怎样保存在桌面_python3应用windows api对后台程序窗口及桌面截图并保存的方法...
  18. uniapp将h5链接打包成安卓
  19. 常用的前端框架有哪些?
  20. USB闪存盘变成FDD(软盘驱动器)了?

热门文章

  1. LlamaIndex 联合创始人下场揭秘:如何使用私有数据提升 LLM 的能力?
  2. 阿里云大数据计算服务 - MaxCompute (原名 ODPS)
  3. AP1236 线性LDO稳压IC 工作原理图分享
  4. 人工智能数据集:直升机(2)
  5. 【文献调研】慢病患者就医行为预测:就医选择行为有哪些?预测什么?如何预测?慢病患者?
  6. 【分享】除了压缩文件,WinRAR还有这些好用的功能
  7. 讲解人工智能中的知识图谱、图灵测试以及深度学习、机器学习
  8. I Hate It(线段树点更新)
  9. 2022-2028中国半导体检测设备市场现状研究分析与发展前景预测报告
  10. iis设置mine_IIS Mime类型(转)