如何将随机生成的数字拟合到自定义的“钟形曲线”分布?

时间:2019-04-25 00:14:39

标签: javascript random probability normal-distribution

我设计的值适合偏心的钟形曲线。试运行似乎能得到令人满意的结果,但是我有什么想念的?

我发现的东西

我发现了一个思想可以解决的问题,但是他们使用的是标准差。

  

JavaScript Math.random Normal distribution (Gaussian bell curve)?

以上问题:

  • 问:Math.random已经正常分发了吗?
  • A:

我有什么

const ranks = [
  ['X'   , 0.01, 0.01],
  ['SSS' , 0.03, 0.04],
  ['SS'  , 0.06, 0.10],
  ['S'   , 0.08, 0.18],
  ['A'   , 0.11, 0.29],
  ['B'   , 0.14, 0.43],
  ['C'   , 0.21, 0.64],
  ['D'   , 0.17, 0.81],
  ['E'   , 0.12, 0.93],
  ['F'   , 0.07, 1.00]
];

log('Total:', ranks.reduce((a, b) => a + b[1], 0).toFixed(2));
for (let i = 0; i < 10; i++) {
  generate();
}

/* Public */
function generate() {
  let percent = Math.random();
  log(percent.toFixed(4), getRank(percent));
}

/* Protected */
function getRank(percent) {
  return ranks.filter((rank, index) => {
    let min = index > 0 ? ranks[index - 1][2] : -1;
    return percent > min && percent <= rank[2];
  })[0][0];
}

/* Private */
function log() {
  let el = document.createElement('DIV');
  el.innerHTML = [].slice.call(arguments).join(' ');
  el.className = 'log-line';
  document.body.appendChild(el);
}
body {
  background: #666;
}

.log-line {
  font-family: monospace;
  background: #AAA;
  margin: 0.5em 0.25em;
  padding: 0.25em;
}

.log-line::before {
  content: '>>> ';
}

enter image description here

1 个答案:

答案 0 :(得分:0)

您可能缺少的是以下内容:

  • 将每个等级(“ X”,“ SS”等)分配给数字行上的一个点。
  • 对于每个等级,使用该点(使用自定义平均值和标准偏差)计算normal distribution的PDF(概率密度函数)。这是该排名的概率。
  • 在这里给出实现:将每个等级的概率除以所有概率之和。
  • 在此处提供实现:计算累积概率。

如果您使用加权随机选择的实现方式,那么最后两个步骤不是绝对必要的,

  • 允许概率加总为1以外的值,并且
  • “实时”计算累积概率。