博客
关于我
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 反向代理配置去除前缀
    查看>>
    nginx 后端获取真实ip
    查看>>
    Nginx 多端口配置和访问异常问题的排查与优化
    查看>>
    Nginx 如何代理转发传递真实 ip 地址?
    查看>>
    Nginx 学习总结(16)—— 动静分离、压缩、缓存、黑白名单、性能等内容温习
    查看>>
    Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
    查看>>
    Nginx 学习(一):Nginx 下载和启动
    查看>>
    nginx 常用指令配置总结
    查看>>
    Nginx 常用配置清单
    查看>>
    nginx 常用配置记录
    查看>>
    nginx 开启ssl模块 [emerg] the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx
    查看>>
    Nginx 我们必须知道的那些事
    查看>>
    Nginx 源码完全注释(11)ngx_spinlock
    查看>>
    Nginx 的 proxy_pass 使用简介
    查看>>
    Nginx 的配置文件中的 keepalive 介绍
    查看>>
    Nginx 结合 consul 实现动态负载均衡
    查看>>
    Nginx 负载均衡与权重配置解析
    查看>>
    Nginx 负载均衡详解
    查看>>
    nginx 配置 单页面应用的解决方案
    查看>>
    nginx 配置https(一)—— 自签名证书
    查看>>