ProbabilityStatistics
class ProbabilityStatistics:
@staticmethod
def simulation_of_probability(v, ratio=10000):
assert v >= 0 and v <= 1
_v = int(v * ratio)
complement = ratio - _v
l = [0 for _ in range(_v)] + [1 for _ in range(complement)]
import random
# TODO numpy scipy
return random.choice(l) == 0
if __name__ == '__main__':
vs = (0.1, 0.5, 0.5123, 0.9)
for v in vs:
for times in (100, 1000, 10000, 100000):
ok = 0
for i in range(times):
b = ProbabilityStatistics.simulation_of_probability(v)
if b:
ok += 1
print('got-times,run-times,p,target', ok, times, ok / times, v)
got-times,run-times,p,target 14 100 0.14 0.1
got-times,run-times,p,target 83 1000 0.083 0.1
got-times,run-times,p,target 957 10000 0.0957 0.1
got-times,run-times,p,target 10171 100000 0.10171 0.1
got-times,run-times,p,target 42 100 0.42 0.5
got-times,run-times,p,target 524 1000 0.524 0.5
got-times,run-times,p,target 4940 10000 0.494 0.5
got-times,run-times,p,target 50071 100000 0.50071 0.5
got-times,run-times,p,target 55 100 0.55 0.5123
got-times,run-times,p,target 475 1000 0.475 0.5123
got-times,run-times,p,target 5205 10000 0.5205 0.5123
got-times,run-times,p,target 51188 100000 0.51188 0.5123
got-times,run-times,p,target 92 100 0.92 0.9
got-times,run-times,p,target 902 1000 0.902 0.9
got-times,run-times,p,target 9035 10000 0.9035 0.9
got-times,run-times,p,target 90093 100000 0.90093 0.9
class ProbabilityStatistics:
@staticmethod
def simulation_of_probability(v, ratio=10000):
assert v >= 0 and v <= 1
_v = int(v * ratio)
complement = ratio - _v
l = [0 for _ in range(_v)] + [1 for _ in range(complement)]
import random
# TODO numpy scipy
return random.choice(l) == 0
if __name__ == '__main__':
vs = (0.1, 0.5, 0.5123, 0.9)
for v in vs:
for times in (100, 1000, 10000, 100000):
ok = 0
for i in range(times):
b = ProbabilityStatistics.simulation_of_probability(v)
if b:
ok += 1
print('got-times,run-times,p,target', ok, times, ok / times, v)
ProbabilityStatistics的更多相关文章
- 【javascript】:Highcharts实战
		PS: Highcharts是一款前端图标设计框架,非常绚. 前端JS: var probabilityStatisticsData; var yearTool; var CoordinateX = ... 
随机推荐
- C# 生成6位短信验证码
			1 private string VerifyCode() 2 { 3 Random random = new Random(); 4 return random.Next(100000, 99999 ... 
- 算法(Java实现)—— 贪心算法
			贪心算法 应用场景-集合覆盖问题 假设在下面需要付费的广播台,以及广播台新型号可以覆盖的地区,如何选择最少的广播台,让所有地区都可以接收到信号 广播台 覆盖地区 k1 北京.上海.天津 k2 广州.北 ... 
- Sublime Text 2 强大的编辑功能
			多行编辑功能:1) 同时编辑多行 (Ctrl+Shift+L (Win) 或 Command+Shift+L (Mac))如要在选中的多行文本的最后面同时添加一个字符"a",先选 ... 
- java 多态 向上造型
			最近在读java 编程思想,在读多态一章时,遇到了一个问题,在此记录一下. 1 package main.demo; 2 3 class Super{ 4 public int filed =0; 5 ... 
- r5 5600H 怎么样 相当于什么水平
			Ryzen 5 5600H是基于Zen 3架构的6核12线程处理器.它具有3.30 GHz的默认频率和4.25GHz的加速频率,带有16MB的L3缓存和3 MB的L2缓存,显卡部分,AMD搭配的Veg ... 
- “==”和equals的区别
			区别: (1)比较基本数据类型时 只能采用"==",比较的是数值; (2)当比较引用数据类型时 "==" 比较的是引用对象的内存地址; 而equals分两种情况 ... 
- 如何将项目推到github上面
			1.先查看是否安装git. 2.如果没有安装git ,下载之后别忘了配置环境变量.(右击此电脑 --属性--高级系统设置--环境变量--系统变量中的path) 3.推代码 查看状态(可查可不查) gi ... 
- 万万没想到,面试中,连 ClassLoader类加载器 也能问出这么多问题…..
			1.类加载过程 类加载时机 「加载」 将类的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在内存上创建一个java.lang.Class对象用来封装类在方法区内的数据 ... 
- lcobucci/jwt的安装和使用
			安装 composer require lcobucci/jwt 3.3 封装 <?php namespace tools\jwt; use Lcobucci\JWT\Builder; use ... 
- tf.argmax(vector,axis)函数的使用
			1.返回值 vector为向量,返回行或列的最大值的索引号: vector为矩阵,返回值是向量,返回每行或每列的最大值的索引号. 2.参数 vector为向量或者矩阵 axis = 0 或1 0:返回 ... 
