游戏开发中伪随机正态分布JavaScript
在游戏开发中经常遇到随机奖励的情况,一般会采取先生成数组,再一个一个取的方式发随机奖励。
下面是js测试正态分布代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<canvas id="myCanvas" width="800" height="400" style="border:1px solid #c3c3c3;">
Your browser does not support the canvas element.
</canvas>
<canvas id="myCanvas2" width="800" height="400" style="border:1px solid #c3c3c3;">
Your browser does not support the canvas element.
</canvas>
<textarea id="text" cols="200" rows="5000"></textarea>
<script type="text/javascript"> var timesArr = [];
var timesArrObj = {};
window.onload = function () {
// for (var meter = 0; meter < 800; meter++) {
// var times = getNumberInNormalDistribution(20, 7);
// addPoint(times, meter);
// timesArr.push(Math.floor(times));
// }
// drawGreenTab(timesArr,1);
// drawLine(0, 380, 800, 380);
drawResult(1);
drawResult(2);
drawResult(0);
drawGreenTab(timesArrObj[1], 1);
drawGreenTab(timesArrObj[2], 2);
drawGreenTab(timesArrObj[0], 0); }
//制作绿色柱状图表
function drawGreenTab(timesArr, color) {
var timesTypes = {};
for (var i in timesArr) {
var times = timesArr[i];
if (timesTypes[times] == null) {
timesTypes[times] = 0;
} else {
timesTypes[times] = timesTypes[times] + 1;
}
}
for (var i in timesTypes) {
drawRect(i, timesTypes[i], 4, color);
}
}
//画圆点
function addPoint(y, x, color) {
y = 400 - y;
var c = document.getElementById("myCanvas");
var cxt = c.getContext("2d");
if (color == null) {
cxt.fillStyle = "#FF0000";
} else {
cxt.fillStyle = color;
}
cxt.beginPath();
cxt.arc(x, y, 2, 0, Math.PI * 2, true);
cxt.closePath();
cxt.fill();
}
var meter = 0;
//划线
function drawLine(beginx, beginy, endx, endy) {
var c = document.getElementById("myCanvas");
var cxt = c.getContext("2d");
cxt.moveTo(beginx, beginy);
cxt.lineTo(endx, endy);
cxt.stroke();
}
//模拟正态分布取值
function getNumberInNormalDistribution(mean, std_dev) {
return mean + (uniform2NormalDistribution() * std_dev);
}
//模拟正态分布偏差
function uniform2NormalDistribution() {
var sum = 0.0;
for (var i = 0; i < 12; i++) {
sum = sum + Math.random();
}
return sum - 6;
}
//画一个长方形
function drawRect(x, y, width, index) {
var color = "#FF0000";
if (index == 1) {
color = "#00FF00";
} else if (index == 2) {
color = "#0000FF";
}
var c = document.getElementById("myCanvas2");
var cxt = c.getContext("2d");
cxt.fillStyle = color;
cxt.fillRect(x * width + index * 200, 400 - y, width - 2, y);
}
//画出生成的图像
function drawResult(index) {
var color = "#FF0000";
if (index % 3 == 1) {
color = "#00FF00";
} else if (index % 3 == 2) {
color = "#0000FF";
}
var result = generateList();
var resultStr = "";
// for (var i in result) {
// resultStr = resultStr + result[i] + "\n";
// }
//document.getElementById("text").value = resultStr;
var resulttimes = {};
for (var i in result) {
if (resulttimes[result[i]] == null) {
resulttimes[result[i]] = 1;
} else {
resulttimes[result[i]] = resulttimes[result[i]] + 1;
}
}
for (var i in resulttimes) {
resultStr = resultStr + resulttimes[i] + "\n";
}
document.getElementById("text").value = resultStr;
var timeslist = [];
var times = 1;
for (var i in result) {
if (result[i] == index) {
addPoint(times, i / 5, color);
if (timesArrObj[index] == null) {
timesArrObj[index] = [];
}
timesArrObj[index].push(times);
times = 0;
} else {
times++;
}
}
}
//权重数组
var wt = [105, 216, 316, 488, 1000, 2000, 3680, 5890];//,14770,71535
//生成结果数组函数,结果为权重数组的索引,从0开始
function generateList() {
//生成的结果数组长度
var n = 50000;
var wtp = [];
var sum = 0;
for (var i in wt) {
sum = sum + wt[i];
}
for (var i in wt) {
wtp.push(wt[i] / sum);
}
var result = [];
var p = [];
for (var i in wtp) {
var inp = getNumberInNormalDistribution(1 / wtp[i], 1 / wtp[i] / 3);
p.push(inp);
}
for (var i = 0; i < n; i++) {
var minp = 99999999;
var minj = -1;
for (var j in p) {
if (p[j] < minp) {
minp = p[j];
minj = j;
}
}
result.push(minj);
for (var j in p) {
p[j] = p[j] - minp;
}
p[minj] = getNumberInNormalDistribution(1 / wtp[minj], 1 / wtp[minj] / 3);
}
return result; }
</script>
</body>
</html>
游戏开发中伪随机正态分布JavaScript的更多相关文章
- 在基于TypeScript的LayaAir HTML5游戏开发中使用AMD
在基于TypeScript的LayaAir HTML5游戏开发中使用AMD AMD AMD是"Asynchronous Module Definition"的缩写,意思就是&quo ...
- 借助AMD来解决HTML5游戏开发中的痛点
借助AMD来解决HTML5游戏开发中的痛点 游戏开发的痛点 现在,基于国内流行引擎(LayaAir和Egret)和TypeScript的HTML5游戏开发有诸多痛点: 未采用TypeScript编译器 ...
- [Unity游戏开发]向量在游戏开发中的应用(三)
本文已同步发表在CSDN:http://blog.csdn.net/wenxin2011/article/details/51088236 在上一篇博客中讲了利用向量点乘在游戏开发中应用的几种情景.本 ...
- [Unity游戏开发]向量在游戏开发中的应用(二)
本文已同步发表在CSDN:http://blog.csdn.net/wenxin2011/article/details/50972976 在上一篇博客中讲了利用向量方向的性质来解决问题.这篇博客将继 ...
- [Unity游戏开发]向量在游戏开发中的应用(一)
本文已同步发表在CSDN:http://blog.csdn.net/wenxin2011/article/details/50810102 向量在游戏开发中是非常实用的,我们在学校学完向量的知识后,只 ...
- Cocos2d-x游戏开发中的消息机制:CCNotificationCenter的使用
在HTML5游戏开发中,js可以使用Event对象的addEventListener(添加事件监听).dispatchEvent(触发事件)实现监听机制,如果在coocos2d-x中,去实现这种机制该 ...
- 二、Cocos2dx概念介绍(游戏开发中不同的坐标系,cocos2dx锚点)
注:ccp是cocos2dx中的一个宏定义,#define ccp(__X__,__Y__)CCPointMake((float)__X__, (float)__Y__),在此文章中表示坐标信息 1. ...
- [C++基金会]位计算 游戏开发中的应用
定义的位操作:通俗点说,,位计算是计算机操作二进制整数. 无论整数可以用二的方式来表示进度,不同类型的其长度的整数位的是不一样的.INT8要么char靠8个月2 位表示,INT16或者short是由1 ...
- 游戏开发中IIS常见支持MIME类型文件解析
游戏开发中IIS常见支持MIME类型文件解析 .apkapplication/vnd.android .ipaapplication/vnd.iphone .csbapplication/octet- ...
随机推荐
- 字符编码,python解释器------总结
目录 1. 编码: 1.字符编码 2. 编码的历史 3. 编码和解码 2. python解释器 解释代码的流程 1. 读取文本到解释器 2. 识别代码(检查语法问题) 3. 往终端打印 1. 编码: ...
- javascript权威指南第13章 事件示例代码
html 部分 <!DOCTYPE html> <html> <head> <title>Event Bubling Example</title ...
- win32通用控件
1.标准控件 可以在win32窗口程序中添加资源脚本来给程序添加标准控件: 具体操作为:新建资源脚本 ->在.rc文件中添加控件 ->给控件绑定事件: 常用的标准控件: ...
- (RE) luogu P3690 【模板】Link Cut Tree
二次联通门 : luogu P3690 [模板]Link Cut Tree 莫名RE第8个点....如果有dalao帮忙查错的话万分感激 #include <cstdio> #includ ...
- P1966 火柴排队——逆序对(归并,树状数组)
P1966 火柴排队 很好的逆序对板子题: 求的是(x1-x2)*(x1-x2)的最小值: x1*x1+x2*x2-2*x1*x2 让x1*x2最大即可: 可以证明将b,c数组排序后,一一对应的状态是 ...
- 前端武器库系列之html后台管理页面布局
设计网页,让网页好看:网上找模板 搜 HTML模板 BootStrap 一.页面布局之主站页面 主站布局一般不占满页面,分为菜单栏.主页面.底部 上中下三部分.伪代码如下: <div class ...
- vue 传参props里面为什么要带type,还有default?
这个是子组件啦 ,写type的意思是swiperDate传过来的数据类型是数组,default就是表示不传默认返回的[ ],空数组. 这种就是表示传的数据类型是number,不传默认是0.
- PyTricks-函数参数的解包操作
def myfunc(x, y, z): print(x, y, z) tuple_vec = (1, 0, 1) dict_vec = {'x': 1, 'y': 0, 'z': 1} >&g ...
- 《Glibc内存管理》笔记DAY1
目录 x86_64栈和mmap固定映射地址 内存的延迟分配 内核数据结构 mm_struct Heap 操作相关函数 Mmap 映射区域操作相关函数 内容来源 x86_64栈和mmap固定映射地址 ...
- 微信小程序设置滚动条
前言 又很久没有写东西了,上周开始将一个APP和一个网站的内容整合到微信小程序中,到这会儿终于搞得快结束了,才发现为啥我的小程序滚动视图没有滚动条,这是闹哪样,没有滚动条的滚动是没有灵魂的. 客官可移 ...