还在被机组组合问题困扰?快来试试这个用处极大的考虑安全约束机组组合模型!

前言

所谓安全约束机组组合,即在满足电力系统安全性约束的条件下,以系统购电成本最低等为优化目标,制定多时段的机组开停机计划。

机组组合(Unit commitment,
Uc)优化问题旨在电力系统运行时,安全给定以及调整发电机组的启/停与实时出力,使发电机组的总运行成本最小。研究UC问题的混合整数规划方法,主要涉及机组组合模型紧且简洁的重构

紧性能减少求解器搜索空间,简洁性提高求解器搜索速度,研究的机组模型能显著减少计算负担。此外,研究机组组合完全分布式优化方法,通过对偶完全解耦机组系统约束,在完全保护机组隐私信息前提下,获得高质量的机组调度方案。

模型紧凑/简洁性描述

安全约束机组组合(Security Constrained Unit
Commitment,简称SCUC)是一种基于电力系统安全性约束条件下的发电机组优化组合问题。在电力系统运行中,为了保证电力供应的安全性,需要对发电机组的开启和关闭状态进行优化调度。SCUC问题就是在满足电力系统安全约束的前提下,寻找一组最优的发电机组组合,使得系统的运行成本最低或经济效益最大。

SCUC与考虑约束的经济调度(SCED)的区别

SCUC与考虑约束的经济调度(Screening-based Constrained Economic
Dispatch,简称SCED)都是电力系统优化调度问题,但它们之间存在一些区别:

1.优化目标:SCUC问题的优化目标是在满足安全约束条件下,寻找组发电机组组合,使得系统的运行成本最低或经济效益最大;而SCED问题则是在满足电力系统可靠性和经济性约束条件下,寻找一组最优的发电机组组合。

2.约束条件:SCUC问题主要考虑电力系统的安全性约束,包括功角约束、电压约束等;而SCED问题除了考虑安全性约束外,还需要考虑经济性约束,如燃料成本、排放约束等。

3.应用背景:SCUC问题主要应用于电力系统的安全稳定运行,如防止电力系统故障、确保电力供应可靠性等;而SCED问题则更多应用于电力市场的优化调度,如发电机组的调峰、备用容量管理等。

程序简介

程序综合分析了机组发电量约束及安全校正计算的特点,提出了一种有效的处理方法,通过修正机组出力可调整量约束,将发电量约束隐含于各越限时段的建模和计算过程中,考虑系统运行的故障情况,在安全校正计算完成后自然得到满足。程序算例丰富、注释清晰、干货满满,可扩展性和创新性很高!下面对文章和程序做简要介绍!

建模步骤

SCUC是根据研究周期内的各个时段系统负荷预测优化机组发电计划,包括机组起停方式和机组发电出力。优化的目标是系统的总成本(包括发电成本、开机成本、停机成本)最小。约束主要分为3类:

(1)系统约束。包括负荷平衡、系统备用;

(2)机组约束。包括机组出力上下限、最小持续开停时间、爬坡率、旋转备用、最大开停次数;(3)安全约束。包括支路输电极限、断面极限、
节点电压等。SCUC在实际应用中还可以根据需要添加约束条件,如开停机过程的出力约束、分区备用约束、排放约束、资源约束等。

数学模型

电能平衡在UC中有三种不同的表示方式:

在单母线近似中,网格被忽略:只要总产量等于总需求,就认为需求得到满足,无论其地理位置如何。

在DC(直流)近似中,仅对基尔霍夫电流定律建模;这对应于忽略无功功率流,电压角差被认为很小,并且角电压曲线被假定为恒定;

在完整的AC(交流)模型中,使用了完整的基尔霍夫定律:这导致模型中存在高度非线性和非凸约束。当使用全交流模型时,UC实际上包含了最优潮流问题,这已经是一个非凸非线性问题。

本程序考虑AC和DC模型,在AC模型中采用二阶锥模型对机组发电成本做了线性化处理,因此可利用Yalmip+Cplex高效求解。模型中考虑了机组组合故障状态约束,对考虑机组组合故障、电网韧性的小伙伴很有帮助!

程序结果

适用平台:Matlab+Yalmip+Cplex/Gurobi

(1)DC模型:依次为IEEE14节点、30节点、118节点

![](https://img-
blog.csdnimg.cn/img_convert/08251e68f9460a9e329379bd84da5be9.png)

(2)AC模型:依次为IEEE14节点、30节点、118节点

![](https://img-
blog.csdnimg.cn/img_convert/537073ff66beb4b8477f6edfc4a4a461.png)

部分程序:

%​% 读入
% casename = input('Please enter case name : ', 's');
% casename = 'case14mod_SCUC';
% casename = 'case30mod';
 casename = 'case118mod';
k_safe = 0.85;    %安全系数,用于留一定的裕度,针对潮流安全约束​
% 时段数t 用于机组组合优化
n_T = 24;
% 发电机曲线 二次函数 分段线性化
n_L = 20;​
% 初始化文件
initial;PD = bus(:, BUS_PD)/baseMVA;​QD = bus(:, BUS_QD)/baseMVA;
% PD = PD*ones(1, n_T);​% QD = QD*ones(1, n_T);
% 24小时的负荷数据
Q_factor = QD/sum(QD);​P_factor = PD/sum(PD);
%P_sum = sum(PD)-sum(PD)/2*sin(pi/12*[0:n_T-1]+pi/3);
P_sum = mpc.PD'/baseMVA;​QD = Q_factor*sum(QD)*P_sum/sum(PD);
PD = P_factor*P_sum;spnningReserve = 1.02*P_sum;​
%导纳矩阵计算
% [Ybus, Yf, Yt] = makeYbus(baseMVA, bus, M_branch);   % build admitance matrix
[Bbus, Bf, Pbusinj, Pfinj] = makeBdc(baseMVA, bus, branch);       %直流潮流​
% 创建决策变量​% 发电机出力 非发电机节点取0
gen_P = sdpvar(n_bus, n_T);​gen_P_upper = sdpvar(n_bus, n_T);   %发电机有功出力上界
% gen_Q = sdpvar(n_bus, n_T);
% 各节点电压幅值 相角
% Vm = sdpvar(n_bus, n_T);      %幅值
Vm = ones(n_bus, n_T);        %幅值 直流潮流
Va = sdpvar(n_bus, n_T);      %相角​
% 各支路潮流
PF_D = sdpvar(n_branch, n_T);     %P Flow Direct 正向有功潮流 1->2
% QF_D = sdpvar(n_M_branch, n_T);     %Q Flow Direct 正向无功潮流 1->2
% PF_R = sdpvar(n_branch, n_T);     %P Flow Reverse 反向有功潮流 2->1
% QF_R = sdpvar(n_M_branch, n_T);     %Q Flow Reverse 反向无功潮流 2->1​
% 机组状态
u_state = binvar(n_bus, n_T);     %按母线数,非发电机节点取0
C = [];     %约束​% C = sdpvar(C)>=0;
%发电机费用曲线 二次函数分段线性化
P_nl = sdpvar(n_gen, n_L, n_T);​for i = 1: n_gen
 ​gen_P(gen(i,GEN_BUS),t) == sum(P_nl(i,:,t))+gen(i,GEN_PMIN)*u_state(gen(i,GEN_BUS),t)/baseMVA,
​0 <= P_nl(i,l,t) <= (gen(i, GEN_PMAX)-gen(i, GEN_PMIN))/n_L/baseMVA,
​% 机组开机费用 Cjk
cost_up = sdpvar(n_gen, n_T);​C = [C, cost_up >= 0];
​cost_up(:,k) >= start_cost(:,t).*(u_state(gen(:,GEN_BUS),k) - sum(u_state(gen(:,GEN_BUS),[k-t: k-1]),2))

部分内容源自网络,侵权联系删除!

欢迎感兴趣的小伙伴关注并私信获取完整版代码,小编会不定期更新高质量的学习资料、文章和程序代码,为您的科研加油助力!

学习网络安全技术的方法无非三种:

第一种是报网络安全专业,现在叫网络空间安全专业,主要专业课程:程序设计、计算机组成原理原理、数据结构、操作系统原理、数据库系统、 计算机网络、人工智能、自然语言处理、社会计算、网络安全法律法规、网络安全、内容安全、数字取证、机器学习,多媒体技术,信息检索、舆情分析等。

第二种是自学,就是在网上找资源、找教程,或者是想办法认识一-些大佬,抱紧大腿,不过这种方法很耗时间,而且学习没有规划,可能很长一段时间感觉自己没有进步,容易劝退。

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里👉网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

第三种就是去找培训。

image.png

接下来,我会教你零基础入门快速入门上手网络安全。

网络安全入门到底是先学编程还是先学计算机基础?这是一个争议比较大的问题,有的人会建议先学编程,而有的人会建议先学计算机基础,其实这都是要学的。而且这些对学习网络安全来说非常重要。但是对于完全零基础的人来说又或者急于转行的人来说,学习编程或者计算机基础对他们来说都有一定的难度,并且花费时间太长。

第一阶段:基础准备 4周~6周

这个阶段是所有准备进入安全行业必学的部分,俗话说:基础不劳,地动山摇
image.png

第二阶段:web渗透

学习基础 时间:1周 ~ 2周:

① 了解基本概念:(SQL注入、XSS、上传、CSRF、一句话木马、等)为之后的WEB渗透测试打下基础。
② 查看一些论坛的一些Web渗透,学一学案例的思路,每一个站点都不一样,所以思路是主要的。
③ 学会提问的艺术,如果遇到不懂得要善于提问。
image.png

配置渗透环境 时间:3周 ~ 4周:

① 了解渗透测试常用的工具,例如(AWVS、SQLMAP、NMAP、BURP、中国菜刀等)。
② 下载这些工具无后门版本并且安装到计算机上。
③ 了解这些工具的使用场景,懂得基本的使用,推荐在Google上查找。

渗透实战操作 时间:约6周:

① 在网上搜索渗透实战案例,深入了解SQL注入、文件上传、解析漏洞等在实战中的使用。
② 自己搭建漏洞环境测试,推荐DWVA,SQLi-labs,Upload-labs,bWAPP。
③ 懂得渗透测试的阶段,每一个阶段需要做那些动作:例如PTES渗透测试执行标准。
④ 深入研究手工SQL注入,寻找绕过waf的方法,制作自己的脚本。
⑤ 研究文件上传的原理,如何进行截断、双重后缀欺骗(IIS、PHP)、解析漏洞利用(IIS、Nignix、Apache)等,参照:上传攻击框架。
⑥ 了解XSS形成原理和种类,在DWVA中进行实践,使用一个含有XSS漏洞的cms,安装安全狗等进行测试。
⑦ 了解一句话木马,并尝试编写过狗一句话。
⑧ 研究在Windows和Linux下的提升权限,Google关键词:提权
image.png
以上就是入门阶段

第三阶段:进阶

已经入门并且找到工作之后又该怎么进阶?详情看下图
image.png

给新手小白的入门建议:
新手入门学习最好还是从视频入手进行学习,视频的浅显易懂相比起晦涩的文字而言更容易吸收,这里我给大家准备了一套网络安全从入门到精通的视频学习资料包免费领取哦!

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里👉网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值