news 2026/5/11 20:08:45

构建不确定集合

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
构建不确定集合

两阶段鲁棒优化指导,分布鲁棒,kkt函数附带经典代码

电力系统调度工程师老张最近遇到了头疼的问题——风电出力预测跟闹着玩似的,误差能到30%。传统的随机规划模型在极端天气面前像个纸糊的狮子,这时候两阶段鲁棒优化(Two-stage Robust Optimization)突然变得性感起来。

先看个简化版的电力调度场景:第一阶段决定火电机组启停(0/1决策),第二阶段根据实际风电出力调整发电功率。最刺激的部分在于,不确定性被框在一个椭球集合里——这其实就是分布鲁棒优化(DRO)的经典玩法,既不像随机规划需要精确分布,也比传统鲁棒优化更贴合实际。

from pyomo.environ import * import numpy as np class UncertaintySet: def __init__(self, nominal_wind, radius): self.nominal = nominal_wand self.radius = radius # 椭球半径控制保守程度 # 两阶段模型骨架 model = ConcreteModel() model.x = Var(within=Binary) # 第一阶段决策:机组启停 model.y = Var(within=NonNegativeReals) # 第二阶段:发电量 # 关键约束:应对最坏情况的鲁棒约束 def robust_constraint_rule(m): worst_wind = UncertaintySet(50, 15).nominal - UncertaintySet(50,15).radius return m.y >= 100*m.x - worst_wind model.robust_con = Constraint(rule=robust_constraint_rule)

这段代码藏着个精妙的设计:worst_wind的计算实际上完成了对偶转换。当我们在椭球集合里寻找最恶劣场景时,本质上是在求解一个带KKT条件的极值问题。不过这里用了取巧的方式——直接取区间端点,相当于把非线性问题线性化了。

说到KKT条件,它在鲁棒优化里就像瑞士军刀。比如处理含不确定性的约束:

# 原始约束:a*y ≤ b (a为不确定参数) # 对偶转换后 model.dual = Var(within=NonNegativeReals) dual_expr = (uncertain_a_upper * model.y - model.dual * (uncertain_a_upper - uncertain_a_lower) <= b)

这波操作把不确定约束转换为确定性的双变量问题,正是KKT条件的实战应用。不过要当心,这种转换在非凸问题里可能会翻车,这时候就需要上列生成算法(Column Generation)之类的黑魔法了。

最后来个灵魂拷问:分布鲁棒里的保守性怎么控制?看下面的调参现场:

# 调节鲁棒性参数 for gamma in [0.1, 0.5, 0.9]: uncertainty_set.radius = gamma * max_radius solve(model) print(f"参数{gamma}时成本为{model.obj()}")

这个gamma参数就像吃重庆火锅选的辣度,0.1是微辣(风险偏好型),0.9是变态辣(极端保守派)。实际项目中需要拿着历史数据反复测试,找到成本与鲁棒性的甜蜜点。

说到底,两阶段鲁棒优化就是个"先开枪后瞄准"的策略——先做不可逆决策,留足调整余地应对最坏情况。下次遇到光伏出力预测像心电图的项目,不妨试试这套组合拳,至少能让你的模型在极端场景下不会死得太难看。

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

Flutter---常用打印图标

Flutter打印中常用的小图标&#xff08;Emoji&#xff09;可以提高日志的可读性状态/操作图标print("✅ 操作成功"); print("✔️ 完成"); print("&#x1f3af; 目标达成"); print("&#x1f31f; 优秀");print("❌ 操作失败&qu…

作者头像 李华
网站建设 2026/5/4 9:59:05

Langchain-Chatchat问答置信度评估与展示

Langchain-Chatchat问答置信度评估与展示 在企业知识管理日益智能化的今天&#xff0c;一个核心挑战浮出水面&#xff1a;如何让AI生成的回答不仅快速准确&#xff0c;还能被用户真正信任&#xff1f;尤其是在法律、医疗、金融这类对信息准确性要求极高的领域&#xff0c;一句未…

作者头像 李华
网站建设 2026/5/3 9:38:41

基于回声状态神经网络(ESN)的回归预测模型优化与评价指标详解

回声状态神经网络(ESN)回归预测&#xff0c;代码非Matlab工具箱——可选择优化算法&#xff0c;如SSA,GEO,WOA,SMA进行优化改进等。模型评价指标包括:R2、MAE、MSE、RMSE和MAPE等&#xff0c;代码质量极高&#xff0c;方便学习和替换数据。手搓回声池&#xff1a;用Python搞ESN…

作者头像 李华
网站建设 2026/5/6 15:44:15

双Richards方程双渗模型

双 Richards 方程双渗模型。 在裂隙发育完全的边坡&#xff0c;可以使用等效法将裂隙平均到基质中&#xff0c;使用两个里查兹方程来方便描述裂隙的渗流情况和基质的渗流情况&#xff0c;并考虑裂隙与基质的水交换。 从数值模拟的结果可以看出&#xff1a;当降雨强度较低时&…

作者头像 李华
网站建设 2026/5/12 3:51:32

咱们今天聊点硬核的——用COMSOL搞基质裂缝双重介质里的油水两相流。别慌,我保证不甩公式砸死你,直接上手操作才是硬道理

comsol案例&#xff0c;两相流体&#xff0c;基于基质裂缝双重介质达西定律流动模式先看模型骨架&#xff1a;基质像海绵负责储油&#xff0c;裂缝当高速公路负责运油。这哥俩得分开建模但又得勾搭着传质。在COMSOL里直接调出达西定律和两相流物理场&#xff0c;注意这里得同时…

作者头像 李华