博客
关于我
MATLAB生成一组和为定值的随机数——用于种群生成
阅读量:799 次
发布时间:2023-02-07

本文共 1109 字,大约阅读时间需要 3 分钟。

如何生成和为定值的随机数是优化算法种群生成环节中的重要步骤,例如用于生成总发电量为定值的日随机负荷或发电计划。以下是两种常见方法的实现代码及解释:

方法一:生成和为定值的随机数(最后一位常为负数)

% 示例参数SUM_powini = 1.401942259882683e+05; % 定值总和N = 24; % 随机数个数% 初始化数组存储随机数r = zeros(1, N);% 计算初始总和分配sumtemp = floor(SUM_powini / N);% 依次生成随机数for i = 1:(N-1)    r(i) = sumtemp * rand(); % 生成一个随机数    sumtemp = floor((SUM_powini - r(i)) / (N - i)); % 更新剩余和end% 计算最后一个数r(N) = SUM_powini - sum(r(1:N-1)); % 确保总和准确

方法二:生成和为定值的随机数(均为正数)

% 示例参数N = 24; % 随机数个数SUM_powini = 1.401942259882683e+05; % 定值总和% 初始化负荷数组PH = zeros(1, N);% 计算初始总和分配sumtemp = floor(SUM_powini / N);% 生成随机数并筛选非负数counter = 0; % 计数器避免无限循环while (PH(N) <= 0) && (counter < 100)    for j = 1:(N-1)        PH(j) = sumtemp * abs(rand()); % 生成一个非负随机数        sumtemp = floor((SUM_powini - PH(j)) / (N - j)); % 更新剩余和    end    PH(N) = SUM_powini - sum(PH(1:N-1)); % 计算最后一个数    counter = counter + 1; % 更新计数器end

方法解释

  • 方法一通过分配初始总和sumtemp,逐步生成每个随机数r(i),并根据剩余总和更新分配。最后一个数r(N)直接计算为总和减去前面所有数的和,确保总和准确性。这种方法适用于允许最后一个数为负数的情况。

  • 方法二使用while循环确保所有随机数均为非负数。通过abs(rand())生成非负数,结合计数器counter避免无限循环。这种方法适用于严格要求所有数均为正值的场景。

  • 两种方法均可应用于优化算法的种群生成环节,例如电力系统中的随机负荷或发电计划生成,确保总负荷或发电量为定值。

    转载地址:http://afyfk.baihongyu.com/

    你可能感兴趣的文章
    Nginx使用proxy_cache指令设置反向代理缓存静态资源
    查看>>
    Nginx入门教程-简介、安装、反向代理、负载均衡、动静分离使用实例
    查看>>
    nginx反向代理
    查看>>
    Nginx反向代理
    查看>>
    nginx反向代理、文件批量改名及统计ip访问量等精髓总结
    查看>>
    Nginx反向代理与正向代理配置
    查看>>
    Nginx反向代理及负载均衡实现过程部署
    查看>>
    Nginx反向代理和负载均衡部署指南
    查看>>
    Nginx反向代理是什么意思?如何配置Nginx反向代理?
    查看>>
    nginx反向代理解决跨域问题,使本地调试更方便
    查看>>
    nginx反向代理转发、正则、重写、负摘均衡配置案例
    查看>>
    Nginx反向代理配置
    查看>>
    Nginx启动SSL功能,并进行功能优化,你看这个就足够了
    查看>>
    nginx启动脚本
    查看>>
    Nginx在Windows上和Linux上(Docker启动)分别配置基本身份认证示例
    查看>>
    Nginx在Windows下载安装启动与配置前后端请求代理
    查看>>
    Nginx在开发中常用的基础命令
    查看>>
    Nginx多域名,多证书,多服务配置,实用版
    查看>>
    nginx如何实现图片防盗链
    查看>>
    Nginx学习总结(12)——Nginx各项配置总结
    查看>>