积分规则 网站地图 帮助中心    
嵌入式软件 单 片 机 DSP 存储器 传感控制 光电显示
嵌入式硬件 CPLD/FPGA SOPC AD/DA 接口电路 模拟设计
I C设计 通信产品 汽车电子 电源产品 消费电子 数控系统
工业控制 军工/航天 安防产品 医疗电子 计算机外设 测试测量
供应 I C
求购 公司库

  IC 求购 销售 公司 论文 DATASHEET 参考设计 论坛
当前位置: 电子技术 >> DSP >> DSP代码示例
  相关分类: 应用论文 | TI DSP | 新产品 | 算法 | 下载 | DSP代码示例 | ADI DSP | freescale DSP |
lRandom Number Generators(随机数生成)
 
作者:未知   来源:互联网    点击数:704   更新时间:2007-2-7
您可以添加到网摘 让更多人关注此文章:

    

lRandom Number Generators(随机数生成)

Random Number Generators
 
gran.c - gaussian random number generator
 
ran.c - uniform random number generator
 
ran1f.c - 1/f noise generator
 
ranh.c - low-frequency hold generator
 
ranl.c - linearly interpolated generator

----------------------------------------------------------------------------------------------------------------

/* ranl.c - linearly interpolated random generator of period D */

 

double ran();                             /* uniform generator */

void cdelay2();                           /* circular delay */

 

double ranl(D, u, q, iseed)               /* usage: y = ranl(D, u, &q, &iseed); */

int D, *q;                                /* \(q\) is cycled modulo-\(D\) */

double *u;                                /* \(u\) = 2-dimensional array */

long *iseed;                              /* \(q\), iseed are passed by address */

{

       double y;

       int i;

 

       i = (D - *q) % D;                      /* interpolation index */

 

       y = u[0] + (u[1] - u[0]) * i / D;      /* linear interpolation */

 

       cdelay2(D-1, q);                       /* decrement \(q\) and wrap mod-\(D\) */

 

       if (*q == 0) {                         /* every \(D\) calls, */

              u[0] = u[1];                    /* set new \(u[0]\) and */

              u[1] = ran(iseed) - 0.5;        /* get new \(u[1]\) (zero mean) */

              }

 

       return y;

}

----------------------------------------------------------------------------------------------------------------

/* ranh.c - hold random number generator of period D */

 

double ran();                             /* uniform generator */

void cdelay2();                           /* circular delay */

 

double ranh(D, u, q, iseed)               /* usage: y = ranh(D, u, &q, &iseed); */

int D, *q;                                /* \(q\) is cycled modulo-\(D\) */

double *u;                                /* \(u\) = 1-dimensional array */

long *iseed;                              /* \(q\), iseed are passed by address */

{

       double y;

 

       y = u[0];                              /* hold sample for \(D\) calls */

 

       cdelay2(D-1, q);                       /* decrement \(q\) and wrap mod-\(D\) */

 

       if (*q == 0)                           /* every \(D\) calls, */

              u[0] = ran(iseed) - 0.5;        /* get new \(u[0]\) (zero mean) */

 

       return y;

}

----------------------------------------------------------------------------------------------------------------

/* ran1f.c - 1/f random number generator */

 

double ranh();                              /* random hold periodic generator */

 

double ran1f(B, u, q, iseed)                /* usage: y = ran1f(B, u, q, &iseed); */

int B, *q;                                  /* \(q, u\) are \(B\)-dimensional */

double *u;

long *iseed;                                /* passed by address */

{

    double y;

    int b;

 

    for(y=0, b=0; b<B; b++)

          y += ranh(1<<b, u+b, q+b, iseed);         /* period = (1<<b) = 2\(\sp{b}\) */

 

    return y / B;

}

----------------------------------------------------------------------------------------------------------------

/* ran.c - uniform random number generator in [0, 1) */

 

#define  a    16807                              /* that is, \(a = 7\sp{5}\) */

#define  m    2147483647                         /* that is, \(m = 2\sp{31}-1\) */

#define  q    127773                             /* note, \(q = m/a\) = quotient */

#define  r    2836                               /* note, \(r = m\%a\) = remainder */

 

double ran(iseed)                                /* usage: u = ran(&iseed); */

long *iseed;                                     /* iseed passed by address */

{

    *iseed = a * (*iseed % q) - r * (*iseed / q);          /* update seed */

 

    if (*iseed < 0)                              /* wrap to positive values */

           *iseed += m;

 

    return (double) *iseed / (double) m;

}

----------------------------------------------------------------------------------------------------------------

/* gran.c - gaussian random number generator */

 

double ran();                            /* uniform generator */

 

double gran(m, s, iseed)                 /* usage: x = gran(m, s, &iseed); */

double m, s;                             /* \(m\) = mean, \(s\sp{2}\) = variance */

long *iseed;                             /* iseed passed by address */

{

       double v = 0;

       int i;

 

       for (i = 0; i < 12; i++)          /* sum 12 uniform random numbers */

              v += ran(iseed);

 

       return s * (v - 6) + m;           /* adjust mean and variance */

}



相关文章
· 科技奥运与计算机技术的应用[361]
· Electromedical[2638]
· 患者监控[2695]
· 基于TMS320LF2407A DSP的心电监护系统研究[3133]
· 用S3C2410实现三导联远程心电监护系统[3063]
热门评论排行
·VHDL设计中电路简化问题的
·江苏嵌入式Linux教育培训
·锐极LINUX驱动培训班定于
·基于实时操作系统μC/OS-
·ARM嵌入式系统基础教程(N

文章评论
    没有任何评论
*只显示最新10条评论。评论内容只代表网友观点,与本站立场无关。更多评论
发表评论
  * 请先[登陆]再进行评论,谢谢。
评分: 1分 2分 3分 4分 5分
内容: *
发帖须知:
一.所发文章必须遵守《互联网电子公告服务管理规定》;
二.严禁发布供求代理信息,公司介绍,产品信息等广告宣传信息;
三.严禁恶意重复发帖;
四.严禁对个人,实体,民族,国家等进行漫骂,污蔑,诽谤。
 
热点新闻 [更多]
 
赛普拉斯为用于机器视觉与运动分析应用
赛普拉斯针对机器视觉与全息数据存储应
金融危机来袭 台湾LED产
半导体市场环境恶化 安森美
Vishay 的新型&nb
Intersil推出采用小尺寸QFN
富士通微电子携手西安电子科技大学成立
纤巧和高压的 LDO&nb
华为计划收购北电业务 华为
华为计划收购北电业务 华为
 
热门下载 [更多]
 
[ PCB设计] Protel99教程下载
[ ] 手把手学单片机20个例
[ ] 单片机做的智能台灯
[ ] 单片机入门书
[ ] linux系统移植开发文档
[ ] IC卡的读写程序
[ ] 8051单片机C语言彻底应用
[ 常用软件] 555定时器电路设计软件V1.2
[ 常用软件] 51定时器计算软件
[ ] ARM处理器应用开发4步骤
 
论坛新帖 [更多]
 
四折批发各种数码相机,摄相机等...
最低价销售各种品牌手机...
震撼出售各种品牌笔记本电脑等!...
IC design 的流程...
电子工程师,别拿一分钱不当回事...
新款安全多用途非接触式芯片(T...
关于ARM启动的一篇文章!...
Linux网络设备驱动编程...
linux文件系统基础知识...
求奇想达QXD-DM642开发...

 
赞助商 [更多]
 

ICP许可证号:[粤 05056597]
联系电话:010-82517432 82517615 传真: 010-82517615

版权所有 Copyright © 2006 嵌入式技术网