news 2026/5/14 9:51:33

最近在搞风光荷不确定性分析的时候,蒙特卡洛+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/5/9 9:36:18

它打电话前,会“预习”客户资料——AI销售机器人

一、问题:传统电销的核心痛点——“盲打”导致的转化率瓶颈 根据Gartner 2024年全球销售自动化市场报告,传统电销的平均转化率仅为2.1%,其中37%的失败案例源于销售对客户资料的掌握不足:要么遗漏客户历史订单的核心诉求&#xff…

作者头像 李华
网站建设 2026/5/9 21:49:45

变频器线速度计算程序示例:实时输入参数计算线速度输出

变频器频率与线速度程序示例,输入相应参数可以计算出实时的线速度。变频器在工业自动化领域就像个隐形管家,今天咱们来聊聊怎么用代码把它的输出频率换算成实际线速度。直接上硬菜,先看核心公式:线速度π直径频率/(减速比60)。这个…

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

2026年AI应用爆发元年已至,大模型投资逻辑全解析

AI大模型应用正迎来关键转折点,随着智谱、MiniMax上市,AI从基础建设转向应用落地。2026年或成AI应用爆发元年,中国企业因工程师红利、供应链融合和政策支持优势有望率先实现规模化落地。AI手机、眼镜、机器人和智能驾驶是重点方向&#xff0c…

作者头像 李华
网站建设 2026/5/7 8:36:07

计算机毕业设计之springboot基于Vue的小麦供销平台设计与实现

伴随着我国社会的发展,人民生活质量日益提高。于是对小麦供销进行规范而严格是十分有必要的,所以许许多多的信息管理系统应运而生。此时单靠人力应对这些事务就显得有些力不从心了。所以本论文将设计一套小麦供销平台,帮助用户进行出售信息、…

作者头像 李华
网站建设 2026/5/1 9:01:26

dvi_encoder编码模块的解析

相关文章:xilinx源语OSERDESE2 的应用HDMI接口rgb2dvi `timescale 1 ps / 1psmodule dvi_encoder (input clkin, // pixel clock inputinput rstin, // async. reset input (active high)input [7:0] din, // data inputs: expect reg…

作者头像 李华