news 2026/6/15 13:52:27

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

作者头像

张小明

前端开发工程师

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/6/13 12:00:04

Shell脚本的实用书籍大纲

文章目录 我们正在编写一套Shell脚本的实用书籍,目标是让读者能够通过实践掌握Shell脚本在企业环境中的应用。这套书分为三册,每册约600页,侧重基础、实操和企业级应用。下面是大纲的详细优化和细化,特别注重小而精的案例,每个知识点都配有实际可操作的例子,并且这些例子…

作者头像 李华
网站建设 2026/6/12 23:21:10

Android 系统层学习目录

知识目录 Android 系统层到底是什么?AOSP / Framework / AMSWMSPMS 一次讲清为什么有的 Android 架构图是 4 层,有的却是 5 层?Android Native 层是如何运行 ART 与 Native Libraries 的?Binder 是如何贯穿 ART / Native / Kernel…

作者头像 李华
网站建设 2026/6/12 17:13:52

热电联产系统智能经济调度:深度强化学习之路

深度强化学习电气工程复现文章,适合小白学习 关键词:热电联产经济调度 深度强化学习 近端策略优化 编程语言:python平台 主题:热电联产系统智能经济调度:一种深度强化学习方法 内容简介: 本文提出了一种用于…

作者头像 李华
网站建设 2026/6/15 12:32:25

基于ssm的农业管理系统8y15w544(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序文件列表 开题报告内容 课题名称: 基于SSM框架的农业管理系统的设计与实现 一、 选题依据(研究背景与意义) 1. 研究背景 随着我国乡村振兴战略的全面推进和数字乡村建设的深入开展,传统农业正面临向现代化、精细化、智…

作者头像 李华
网站建设 2026/6/14 2:43:40

基于ssm社区老人健康服务跟踪系统l54o0ud2(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序文件列表 开题报告内容 基于SSM的社区老人健康服务跟踪系统开题报告 一、选题背景与意义 选题背景 随着全球人口老龄化的加速推进,我国老年人口比例持续上升,社区老年人的健康问题日益成为社会关注的焦点。传统的社区健康服务模式存在诸多弊…

作者头像 李华
网站建设 2026/6/13 10:59:16

开关磁阻电机控制仿真:Matlab 2016b的探索之旅

开关磁阻电机控制仿真(matlab 2016b版本仿真模型 自用) 模型包涵: 开关磁阻电机传统控制:电流斩波控制、电压PWM控制、角度位置控制。 智能控制:12/8三相开关磁阻电机有限元分析本体建模、转矩分配函数控制、模糊PID控制、模糊角度控制、神经…

作者头像 李华