CvRNG基本随机数

原文地址:CvRNG基本随机数 作者:白屋顶黑乌鸦

#include "stdafx.h"
#include "cv.h"
#include "highgui.h"
#include <stdlib.h>
#include <stdio.h>
#pragma comment(lib,"cv200.lib")
#pragma comment(lib,"cxcore200.lib")
#pragma comment(lib,"highgui200.lib")
#pragma comment(lib,"cvaux200.lib")

//随机数简单示例
int _tmain(int argc, _TCHAR* argv[])
{
    CvRNG rng;
    rng= cvRNG(cvGetTickCount());
    for (int i= 0;i<10;i++)
    {
        printf("%d/n",cvRandInt(&rng)%6);//如果%6出来的将会是0~255的正整数
        printf("%.2f/n",cvRandReal(&rng));
    }
    printf("Tick Frequency= %f/n",cvGetTickFrequency());
    system("pause");
    return 0;
}

cvGetTickCount()
返回64位长整数的时间数据,在OpenCV是为CvRNG设置的专用种子

 

cvGetTickFrequency()

返回系统时钟频率

 

cvRNG()

跟一般的C语言srand()使用方法一样,要先给它一个种子,但srand()用到的是unsigned int的32位种子范围,而cvRNG()用的是64位长整数种子。初始化CvRNG资料结构,假如seed给0,它将会自动转成-1。
cvRNG(64位种子)

 

cvRandInt()

返回均匀分布32位的随机数均匀分布为统计学上的专有名词,表示长时间下所有数字出现的概率都是一样的,而cvRandint()在opencv里使用的公式

temp = (uint64)(unsigned)temp*1554115554 + (temp >> 32);

这个公式的名称叫Multiply-with-carry (MWC) generator,有兴趣的话可以在网络上找“随机数产生器”,Multiply-with-carry是将64位的种子去产生32位的随机数。
unsigned cvRandInt(CvRNG资料结构)

 

cvRandReal()

返回均匀分布,0~1之间的随机小数,cvRandReal()的公式则是用
cvRandInt(rng)*2.3283064365386962890625e-10
的方法,其实就是cvRandInt(rng)*2^(-32),也就是将cvRandInt()随机出来的结果(32位除以2的三十二次方,因此,出现的结果将会是0~1之间的小数,也就是随机0~1之间。
double cvRandReal(CvRNG资料结构)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值