博客
关于我
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简单介绍
    查看>>
    Nginx虚拟主机配置
    查看>>
    Nginx访问控制_登陆权限的控制(http_auth_basic_module)
    查看>>
    nginx访问控制配置
    查看>>
    nginx负载均衡和反相代理的配置
    查看>>
    nginx负载均衡器处理session共享的几种方法(转)
    查看>>
    nginx负载均衡的5种策略
    查看>>
    nginx负载均衡的5种策略(转载)
    查看>>
    nginx负载均衡的五种算法
    查看>>
    Nginx负载均衡(upstream)
    查看>>
    nginx转发端口时与导致websocket不生效
    查看>>
    Nginx运维与实战(二)-Https配置
    查看>>
    Nginx部署_mysql代理_redis代理_phoenix代理_xxljob代理_websocket代理_Nacos代理_内网穿透代理_多系统转发---记录021_大数据工作笔记0181
    查看>>
    Nginx配置Https证书
    查看>>
    Nginx配置ssl实现https
    查看>>
    Nginx配置TCP代理指南
    查看>>
    Nginx配置——不记录指定文件类型日志
    查看>>
    nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>