news 2026/5/1 4:58:09

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

2026必备!降AI率软件 千笔·降AI率助手 VS 云笔AI,研究生专属高效选择!

在AI技术迅速发展的今天,越来越多的研究生开始借助AI工具辅助论文写作,以提升效率和内容质量。然而,随着各大查重系统对AI生成内容的识别能力不断提升,AI率超标问题逐渐成为学术写作中的“隐形杀手”。无论是知网、维普还是Turnit…

作者头像 李华
网站建设 2026/5/1 4:56:20

Andersen Consulting与Alfa Group达成合作协议

Andersen Consulting携手合作公司Alfa Group深化网络安全服务能力,后者是一家领先的科技企业,拥有近三十年行业经验,致力于帮助各类组织保护和优化其运营。 Alfa Group成立于1996年,总部位于罗马,致力于提供网络安全、…

作者头像 李华
网站建设 2026/5/1 4:56:02

毕业论文通关秘籍!专业 AI 写作软件,新手也能快速上手

毕业论文写作可借助专业 AI 工具实现全流程提效,新手遵循 “选题 - 大纲 - 初稿 - 文献 - 降重 - 排版” 六步走,搭配 PaperRed、毕业之家等工具,能快速上手并产出规范成果。以下是可直接落地的通关秘籍与实操指南。一、核心工具精选&#xf…

作者头像 李华
网站建设 2026/4/23 17:40:45

【GitHub项目推荐--BitNet:微软官方1位大语言模型推理框架】⭐⭐⭐⭐⭐

简介 BitNet是微软官方推出的1位大语言模型推理框架,专门为BitNet b1.58等1位量化模型设计的高性能推理解决方案。该项目基于llama.cpp框架构建,提供了一套高度优化的内核,支持在CPU和GPU上实现快速、无损的1.58位模型推理。BitNet代表了大型…

作者头像 李华
网站建设 2026/4/20 19:02:42

java+vue基于springboot的新能源汽车4s店车辆管理系统

目录系统概述技术架构核心功能创新点应用价值开发技术路线结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!系统概述 该系统基于SpringBoot后端框架与Vue.js前端框架开发,旨在为新能源汽车4S店提供一体化的车辆管理解决方案…

作者头像 李华