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

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
简介: m基于粒子群算法的分布式电源DG的优化配置

1.算法描述

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

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

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

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

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

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

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

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

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

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

   目标函数:最小有功损耗

1.png
2.png

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

3.png

2.仿真效果预览
matlab2022a仿真结果如下:

4.png
5.png
6.png
7.png

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:N
    for j = 1:D
        ub_j=ub(j);
        lb_j=lb(j);
        if j < 4
%           if j<3
            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;
        end
%         x(i,j) = randn;    %随机初始化位置
        v(i,j) = randn;    %随机初始化速度
    end
end
 
%%%%%%%%%%%%先计算各个粒子的适应度值,并初始化pi和pg%%%%%%%%%
for i = 1:N
    p(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:M
    t
    for 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:D
            ub_j=ub(j);
            lb_j=lb(j);
            if j<4
%               if j < 3
               if 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;
             end
            else
                if 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;
                end
            end
        end
        x(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,:);
        end
        if p(i) < fitness(pg)
            pg = y(i,:);
        end
   end
    Pbest(t) = fitness(pg);
end
相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
WK
|
1天前
|
算法
粒子群算法的优缺点分别是什么
粒子群优化(PSO)算法概念简单,易于编程实现,参数少,收敛速度快,全局搜索能力强,并行处理高效。然而,它也容易陷入局部最优,参数设置敏感,缺乏坚实的理论基础,且性能依赖初始种群分布,有时会出现早熟收敛。实际应用中需根据具体问题调整参数以最大化优势。
WK
10 2
|
6天前
|
机器学习/深度学习 算法
深度学习中的优化算法:从梯度下降到Adam
本文深入探讨了深度学习中的核心——优化算法,重点分析了梯度下降及其多种变体。通过比较梯度下降、动量方法、AdaGrad、RMSProp以及Adam等算法,揭示了它们如何更高效地找到损失函数的最小值。此外,文章还讨论了不同优化算法在实际模型训练中的表现和选择依据,为深度学习实践提供了宝贵的指导。
23 7
|
1天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于PSO粒子群优化的GroupCNN分组卷积网络时间序列预测算法matlab仿真
本项目展示了一种结合粒子群优化(PSO)与分组卷积神经网络(GroupCNN)的时间序列预测算法。该算法通过PSO寻找最优网络结构和超参数,提高预测准确性与效率。软件基于MATLAB 2022a,提供完整代码及详细中文注释,并附带操作步骤视频。分组卷积有效降低了计算成本,而PSO则智能调整网络参数。此方法特别适用于金融市场预测和天气预报等场景。
|
2天前
|
机器学习/深度学习 人工智能 自然语言处理
深度学习中的优化算法
本文将探讨深度学习中的几种常见优化算法,包括梯度下降、动量方法、AdaGrad、RMSProp和Adam。这些算法在训练神经网络时发挥着重要作用,通过调整学习率和更新策略,能够显著提高模型的训练效率和性能。了解这些优化算法有助于更好地应用深度学习技术解决实际问题。
|
10天前
|
算法 Python
群智能算法:灰狼优化算法(GWO)的详细解读
在优化问题中,寻找最优解是核心目标。灰狼优化算法(GWO)受到自然界灰狼狩猎行为和社会等级结构的启发,通过模拟Alpha(头狼)、Beta(助手狼)、Delta(支配狼)和Omega(普通狼)的角色,高效搜索最优解。本文详细解析GWO的原理与步骤,并提供Python代码实现,帮助读者理解并应用这一算法。
|
13天前
|
算法 BI Serverless
基于鱼群算法的散热片形状优化matlab仿真
本研究利用浴盆曲线模拟空隙外形,并通过鱼群算法(FSA)优化浴盆曲线参数,以获得最佳孔隙度值及对应的R值。FSA通过模拟鱼群的聚群、避障和觅食行为,实现高效全局搜索。具体步骤包括初始化鱼群、计算适应度值、更新位置及判断终止条件。最终确定散热片的最佳形状参数。仿真结果显示该方法能显著提高优化效率。相关代码使用MATLAB 2022a实现。
|
13天前
|
算法 数据可视化
基于SSA奇异谱分析算法的时间序列趋势线提取matlab仿真
奇异谱分析(SSA)是一种基于奇异值分解(SVD)和轨迹矩阵的非线性、非参数时间序列分析方法,适用于提取趋势、周期性和噪声成分。本项目使用MATLAB 2022a版本实现从强干扰序列中提取趋势线,并通过可视化展示了原时间序列与提取的趋势分量。代码实现了滑动窗口下的奇异值分解和分组重构,适用于非线性和非平稳时间序列分析。此方法在气候变化、金融市场和生物医学信号处理等领域有广泛应用。
|
1月前
|
算法
基于模糊控制算法的倒立摆控制系统matlab仿真
本项目构建了一个基于模糊控制算法的倒立摆控制系统,利用MATLAB 2022a实现了从不稳定到稳定状态的转变,并输出了相应的动画和收敛过程。模糊控制器通过对小车位置与摆的角度误差及其变化量进行模糊化处理,依据预设的模糊规则库进行模糊推理并最终去模糊化为精确的控制量,成功地使倒立摆维持在直立位置。该方法无需精确数学模型,适用于处理系统的非线性和不确定性。
基于模糊控制算法的倒立摆控制系统matlab仿真
|
14天前
|
资源调度 算法
基于迭代扩展卡尔曼滤波算法的倒立摆控制系统matlab仿真
本课题研究基于迭代扩展卡尔曼滤波算法的倒立摆控制系统,并对比UKF、EKF、迭代UKF和迭代EKF的控制效果。倒立摆作为典型的非线性系统,适用于评估不同滤波方法的性能。UKF采用无迹变换逼近非线性函数,避免了EKF中的截断误差;EKF则通过泰勒级数展开近似非线性函数;迭代EKF和迭代UKF通过多次迭代提高状态估计精度。系统使用MATLAB 2022a进行仿真和分析,结果显示UKF和迭代UKF在非线性强的系统中表现更佳,但计算复杂度较高;EKF和迭代EKF则更适合维数较高或计算受限的场景。
|
16天前
|
算法
基于SIR模型的疫情发展趋势预测算法matlab仿真
该程序基于SIR模型预测疫情发展趋势,通过MATLAB 2022a版实现病例增长拟合分析,比较疫情防控力度。使用SIR微分方程模型拟合疫情发展过程,优化参数并求解微分方程组以预测易感者(S)、感染者(I)和移除者(R)的数量变化。![]该模型将总人群分为S、I、R三部分,通过解析或数值求解微分方程组预测疫情趋势。