news 2026/4/3 6:43:54

最近在搞风光荷不确定性分析的时候,蒙特卡洛+K-means这套组合拳确实挺有意思。今天咱们就撸起袖子直接上代码,手把手实现从场景生成到削减的全流程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
最近在搞风光荷不确定性分析的时候,蒙特卡洛+K-means这套组合拳确实挺有意思。今天咱们就撸起袖子直接上代码,手把手实现从场景生成到削减的全流程

蒙特卡洛法场景生成+K-means聚类并削减 风电、光伏、负荷 Matlab 通过概率模型并根据weibull、beta、正态分布生成500次风电光伏、负荷场景,此基础上,基于Kmeans算法,分别对源荷场景进行聚类,从而实现大规模场景的削减,削减到5个场景,最后得出每个场景的概率与每个对应场景相乘求和得到不确定性出力

先说说蒙特卡洛这部分的门道。风电服从双参数威布尔分布,光伏的Beta分布参数得看天气,负荷这货用正态分布就能凑合。上Matlab代码:

% 场景参数设置 num_scenes = 500; % 总场景数 wind_shape = 2.5; % 威布尔形状参数 wind_scale = 12; % 威布尔尺度参数 % 风电场景生成 wind_scenes = wblrnd(wind_scale, wind_shape, [num_scenes,1]); % 光伏Beta分布参数(晴天场景) alpha_pv = 3; beta_pv = 2; pv_scenes = betarnd(alpha_pv, beta_pv, [num_scenes,1]) * 100; % 假设最大出力100MW % 负荷正态分布 load_mu = 500; load_sigma = 50; load_scenes = normrnd(load_mu, load_sigma, [num_scenes,1]);

这里有个坑要注意:光伏的Beta分布输出需要根据实际装机容量做归一化处理。比如最大出力是100MW,直接乘以这个系数就能得到实际功率值。

接下来是重头戏——K-means聚类削减。500个场景直接算到天荒地老,必须砍到5个典型场景:

% 合并源荷数据(按列拼接) data_matrix = [wind_scenes, pv_scenes, load_scenes]; % K-means聚类 num_clusters = 5; [cluster_idx, centroids] = kmeans(data_matrix, num_clusters, 'Replicates',10); % 统计各簇样本数 cluster_counts = histcounts(cluster_idx, num_clusters);

这里'Replicates'参数别省,多跑几次避免陷入局部最优。聚类后的centroids矩阵就是咱们要的典型场景,每行对应一个场景的三维坐标(风、光、荷)。

蒙特卡洛法场景生成+K-means聚类并削减 风电、光伏、负荷 Matlab 通过概率模型并根据weibull、beta、正态分布生成500次风电光伏、负荷场景,此基础上,基于Kmeans算法,分别对源荷场景进行聚类,从而实现大规模场景的削减,削减到5个场景,最后得出每个场景的概率与每个对应场景相乘求和得到不确定性出力

最后算期望值才是精髓所在。各场景概率乘以对应出力,这个积分用离散场景替代:

% 计算场景概率 probabilities = cluster_counts' / num_scenes; % 不确定性出力期望 wind_expected = sum(centroids(:,1) .* probabilities); pv_expected = sum(centroids(:,2) .* probabilities); load_expected = sum(centroids(:,3) .* probabilities); fprintf('风电期望出力:%.2f MW\n光伏期望出力:%.2f MW\n负荷期望值:%.2f MW\n',... wind_expected, pv_expected, load_expected);

实际跑数据的时候发现个有趣现象——当风速分布呈现明显长尾时,K-means会自动生成一个低概率的极端场景。这比传统的前N大概率筛选法更能捕捉黑天鹅事件。

不过这套方法也有软肋:聚类结果对初始质心敏感,建议配合肘部法则确定最佳聚类数。当风光荷呈现强相关性时,可能需要用谱聚类这类考虑数据结构的算法。但日常用用,这已经是个能跑能用的好方案了。

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

真的太省时间了!AI论文网站 千笔 VS 笔捷Ai,自考写论文神器!

随着人工智能技术的迅猛发展,AI辅助写作工具正逐步成为高校学生完成毕业论文的重要助手。无论是开题报告、文献综述还是整篇论文的撰写,越来越多的学生开始借助AI工具提升效率、降低写作难度。然而,面对市场上功能各异、水平参差不齐的AI写作…

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

程序员必看:大模型岗位技能图谱与求职指南(收藏版)_大模型工作岗位解析和大模型项目经理工作职责

本文全面介绍了大模型领域的各类岗位及其要求,包括技术类的算法工程师、研发工程师和管理类的AI项目经理、产品经理、销售及解决方案专家。详细分析了各岗位所需的技能和经验,提供了求职渠道,并分享了学习路线和资源,帮助零基础小…

作者头像 李华
网站建设 2026/3/28 6:36:52

【数学思维】

数学思维 主动忘掉“东西是什么”,只保留“它们之间哪些关系必须被保留”。

作者头像 李华
网站建设 2026/3/14 10:48:20

今日首发|Claude Opus 4.6重磅更新,一步API可直接接入

重磅消息!Anthropic今日正式推出旗舰级大模型——Claude Opus 4.6,全方位升级核心能力,新增多项实用功能。 更关键的是,无需复杂配置,通过一步API就能快速接入,新手开发者也能轻松上手,彻底降低…

作者头像 李华
网站建设 2026/4/1 19:19:19

Java,举例说明,函数式接口,函数式接口实现类,通过匿名内部类实现函数式接口,通过 Lambda 表达式实现函数式接口,演变的过程

Java,举例说明,函数式接口,函数式接口实现类,通过匿名内部类实现函数式接口,通过 Lambda 表达式实现函数式接口,演变的过程1. 什么是函数式接口 (Functional Interface)? 函数式接口是 只包含一…

作者头像 李华