news 2026/2/23 23:39:23

微网鲁邦调度:①复现了《微电网两阶段鲁棒优化经济调度方法_刘一欣》。 ②考虑微电网内可再生分布...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
微网鲁邦调度:①复现了《微电网两阶段鲁棒优化经济调度方法_刘一欣》。 ②考虑微电网内可再生分布...

微网鲁邦调度:①复现了《微电网两阶段鲁棒优化经济调度方法_刘一欣》。 ②考虑微电网内可再生分布式电源和负荷的不确定性及储能、需求响应负荷和可控分布式电源等的协调控制。

最近在折腾微电网鲁棒调度的复现工作,刚好把刘一欣老师那篇经典论文的模型啃下来了。这个两阶段玩法特别有意思——就像先给自己规划好退路再去冒险的生存策略。先来点干货,咱们直接看代码怎么把不确定性装进数学模型里。

建模部分用Pyomo写起来特别带劲,先定义个盒式不确定集把风光出力捆住:

model = ConcreteModel() model.PV_uncertainty = Param(initialize=0.2) # 光伏波动率20% model.WT_uncertainty = Param(initialize=0.3) # 风机波动率30% def uncertainty_bounds(model, t): return (-model.PV_uncertainty, model.PV_uncertainty) model.PV_delta = Var(time_horizon, bounds=uncertainty_bounds) def WT_uncertainty_bounds(model, t): return (-model.WT_uncertainty, model.WT_uncertainty) model.WT_delta = Var(time_horizon, bounds=WT_uncertainty_bounds)

这里PVdelta和WTdelta这两个变量就像给风光出力套了个紧箍咒,既允许波动又不让它们撒欢乱跑。注意边界值不是固定数而是相对值,这样处理实际数据时不用每次都改参数。

第一阶段模型看着像普通的经济调度,但暗藏杀机——所有决策变量都得留着给第二阶段当靶子:

model.Pg = Var(gen_set, time_horizon) # 燃机出力 model.Pb_ch = Var(battery_set, time_horizon) # 储能充电 model.Pb_dis = Var(battery_set, time_horizon) # 储能放电 def stage1_cost_rule(model): return sum(gen_cost[i] * model.Pg[i,t] for i in gen_set for t in time_horizon) model.stage1_cost = Objective(rule=stage1_cost_rule)

这时候如果直接求解,得到的调度方案遇到实际波动绝对崩盘。所以得祭出列与约束生成(C&CG)这个神器,主问题和子问题来回拉扯的代码特别有戏剧性:

# 主问题求解 def master_problem(): mp = ConcreteModel() # 保留第一阶段变量... # 添加可行性割平面 for cut in cuts: mp.add_component(f'cut_{cut}', cut) solve_with_gurobi(mp) return mp # 最恶劣场景子问题 def sub_problem(master_solution): sp = ConcreteModel() # 固定第一阶段变量值... # 构建双层优化结构 solve_with_benders(sp) if sp.obj() > 0: add_cut_to_master() # 生成新的割约束 return sp

这个循环就像在玩博弈游戏,主问题每次给出调度方案,子问题就拼命找出能让系统崩溃的极端场景,然后主问题再根据这些威胁改进方案,直到子问题找不到破绽为止。

微网鲁邦调度:①复现了《微电网两阶段鲁棒优化经济调度方法_刘一欣》。 ②考虑微电网内可再生分布式电源和负荷的不确定性及储能、需求响应负荷和可控分布式电源等的协调控制。

需求响应负荷的处理有点小技巧,得把可平移负荷建模成带时间窗的任务:

shift_load = { 'task1': { 'power': 150, # 需要转移的负荷量 'start_window': [8, 18], # 允许开始时段 'duration': 3 # 持续3小时 } } # 二进制变量表示任务启动时刻 model.task1_start = Var(range(8,19), within=Binary) def task_duration_rule(model): return sum(model.task1_start[t] for t in range(8,19)) == 1 model.task_duration_con = Constraint(rule=task_duration_rule)

这么一来,优化过程会自动选择对系统最友好的负荷转移时段,比如在光伏大发的时候多干活。实际跑数据时发现,需求响应和储能的配合简直天作之合——一个负责搬移负荷,一个负责填谷平峰。

最后验证鲁棒性时搞了个压力测试:故意在光伏预测曲线上叠加拿破仑炮击式的冲击扰动。结果调度方案稳如老狗,储能像太极高手一样把波动消化在充放电动作里。这种看着数学模型在极端场景下依然坚挺的感觉,堪比看自家娃考试超常发挥的老父亲心情。

完整项目里还埋了不少彩蛋,比如用Platypus库做多目标优化时,发现鲁棒性和经济性的帕累托前沿居然呈现非线性跳变——这说明在某些关键参数阈值附近,稍微增加点成本就能大幅提升系统韧性。这或许就是鲁棒优化的魅力所在:在不确定性的迷雾中,寻找那个进可攻退可守的甜蜜点。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/18 1:26:19

STM32F10x_TIM.C 初学者全解 + 典型应用案例

目录 一、先搞懂:STM32F1 的定时器分类(tim.c 的支持范围) 二、stm32f10x_tim.c 文件核心组成拆解 2.1 头文件与模块定义 2.2 寄存器位掩码宏定义(最开头的一大片 #define) 2.3 静态辅助函数(文件中 4…

作者头像 李华
网站建设 2026/2/20 1:57:21

LITEON光宝 LTST-C193KSKT-5A 603 发光二极管/LED

特性 符合ROHS标准,绿色产品。 超薄(0.35H毫米)芯片LED。 *包装在直径7英寸的卷轴上,使用8毫米胶带。 符合EIA标准封装。 *与IC兼容。 *兼容自动贴装设备。 *兼容红外和蒸汽相回流焊工艺。

作者头像 李华
网站建设 2026/2/24 3:14:31

40个漏洞挖掘实战清单,覆盖90%渗透场景!

Web漏洞的本质是信任体系的失控与验证机制的失效。其核心源于开发者对用户输入、权限边界及系统交互的过度信任,具体表现为三类问题: 输入不可控:未对用户输入进行严格过滤(如SQL注入、XSS),导致恶意数据被…

作者头像 李华
网站建设 2026/2/22 18:49:38

计算机毕业设计springboot会员刷卡积分管理系统 基于SpringBoot的商户会员积分刷卡平台 SpringBoot驱动的会员刷卡消费与积分运营系统

计算机毕业设计springboot会员刷卡积分管理系统x03s3 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。 移动支付的普及让“刷卡”不再局限于实体银行卡,会员手中的那…

作者头像 李华
网站建设 2026/2/22 4:59:31

台达 B10S615 触摸屏与台达 M 变频器通讯控制探索

台达触摸屏和台达M变频器通讯控制 型号b10s615 在自动化控制领域,台达的产品以其稳定性和易用性受到广泛关注。今天咱就来唠唠台达 B10S615 触摸屏与台达 M 变频器之间的通讯控制,看看这俩货是怎么携手工作的。 前期准备 首先,咱得了解这俩…

作者头像 李华
网站建设 2026/2/24 5:55:53

学长亲荐2026专科生AI论文工具TOP8:开题报告神器测评

学长亲荐2026专科生AI论文工具TOP8:开题报告神器测评 2026年专科生AI论文工具测评:为何值得一看? 随着人工智能技术的不断进步,越来越多的专科生开始借助AI工具提升论文写作效率。然而,面对市场上五花八门的AI论文辅…

作者头像 李华