已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
随机模拟与实验上机实验报告 通信0809 潇洒哥 学号 一. 随机模拟的典型步骤: 1、根据问题构建模拟系统 2、仿真系统中各种分布的随机变量3、运行模拟系统,进行统计测量 4、分析数据,输出结果二主要工具基本工具:C、C+等编程模拟、matlab网络模拟:OPNET Modeler、NS2:大型网络仿真 CASSAP:数字信号处理;SPW:电子系统三编译代码/ MyRand.cpp: implementation of the CMyRand class./#include stdafx.h#include random.h#include MyRand.h#include math.h#ifdef _DEBUG#undef THIS_FILEstatic char THIS_FILE=_FILE_;#define new DEBUG_NEW#endif/ Construction/Destruction/CMyRand:CMyRand()CMyRand:CMyRand()void CMyRand:MyRandInit(void)N = 0x7FFFFFFF; /231-1K = 16807; /75seed = 2;/*函数功能,采用线性同余法,根据输入的种子数产生一个伪随机数,如果种子不变, 则将可以重复调用产生一个伪随机序列实现思路:利用CMyRand类中定义的全局变量:S, K, N, Y。其中K和N为算法参数,S用于保存种子数,Y为产生的随机数,第一次调用检查将seed赋值与S获得Y的初值,之后调用选择rand()函数赋值与Y。*/unsigned int CMyRand:MyRand(unsigned int seed)if(S != seed)S = seed;Y = (seed * K) % N;elseY = (Y * K) % N;if(Y = 0)Y = rand();return Y;/*函数功能,产生一个在minmax范围内精度为4位小数的平均分布的随机数实现思路:min和max代表该均匀随机变量的取值范围,精确到小数点后4位。该参数在randomDlg.cpp中OnAverage ()和OnAverageStat()函数中已经设置,因此只需将该数小数点右移四位强制取整即可获得整数范围内的随机数,采用对(max-min)求余再加上min并将获得的结果缩小10000倍即可。*/double CMyRand:AverageRandom(double min,double max)int minInteger = (int)(min*10000);int maxInteger = (int)(max*10000);int randInteger = MyRand(seed);int diffInteger = maxInteger - minInteger;int resultInteger = randInteger % diffInteger + minInteger;return resultInteger/10000.0;/*函数功能,在min 到max 范围内产生正态分布的随机数miu,最大概率密度处的随机变量,即产生的随机数中,概率最大的那个sigma实现思路:设由AverageRandom函数获得01间隔均匀分布随机数U(0,1),i=1,2,n,且相互独立,由中心极限定理可知,当n较大时*/double CMyRand:NormalRandom(double miu, double sigma, double min, double max)double dResult;dResult = 0;for(int i=0;i12;i+)dResult += AverageRandom(min,max);dResult = (dResult-6)/(max-min);dResult = dResult*sigma + miu;return dResult;/*函数功能,产生指数分布的随机数实现思路: 1)用AverageRandom产生均匀分布随机数ui; 2)计算指数分布随机数:xi=-ln ui /*/double CMyRand:ExpRandom(double lambda, double min, double max)double dResult = 0.0;while(dResult = F)p = lambda*p/(i+1);F += p;i +;dResult = i;return dResult;/*函数功能,计算任意分布的随机过程的均值实现过程:用for语句调用任意函数加和循环再求平均*/double CMyRand:Ex(void)int m;double Ex=0.0;/添加均值计算代码for (m=0; m1000; m+)Ex += NormalRandom(0,1.2, 0,1);return Ex/1000;/*函数功能,计算随机过程的自相关序列实现过程:由平稳随机过程数字特征求解的相关原理可得RX(m)=I2e-2|m|; */double* CMyRand:Rx(double lambda, int points)int m,I=5;double *Rx = (double*)malloc(2*points+1)*sizeof(double);/添加自相关序列产生代码/产生的自相关序列存入Rx中,Rx可当作数组使用/不要在本函数中释放该数组!for (m=-points; m=points; m+)Rx(m+points) = I * I * exp(-2 * lambda * abs(m);return Rx;4 执行截图均匀分布均匀统计正态分布正态统计指数分布指数统计泊松分布泊松统计均值(此时取NormalRandom(0,1.2, 0,1))自相关(此时取int m,I=5;)5 实验心得1. 该课程设计所设计的各种模块和原理与随机过程的理论知识紧密结合。所以这样与课本知识关联紧的课程实际比较容易完成,同时不仅加强了对书本基础知识的理解,而且实践环节得到了很好的锻炼,能够激发实践者对随机的兴趣甚至能够自己动手完成一些课题项目。2. 学习使用该
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 幼儿园教师教学活动设计与教案集
- 压力管理技巧助力你在面试中脱颖而出
- (完整版)苏教六年级下册期末数学测试模拟试题经典套题
- 学习与发展顾问培训课程开发指南
- 商业保理法律顾问内勤岗位文件归档制度
- 投资尽职调查关键关注点与流程
- 工程技术部主管技术创新与研发项目规划
- 浙江国企招聘2025浙江省新华书店集团中招聘40人笔试历年参考题库附带答案详解
- 基建工程变更工程师项目管理经验
- 2025福建省水务发展集团有限公司招聘10人笔试历年参考题库附带答案详解
- 3.2 与世界深度互动 课件 2024-2025学年统编版道德与法治九年级下册
- 平均数与方差(5)课件北师大版数学八年级上册
- 自动控制原理课件 1.1 自动控制基本概念
- 无人机装调检修课件
- 2025西安外国语大学附属学校鄠邑区实验小学教师招聘笔试考试参考试题及答案解析
- 《新能源汽车控制技术》课件 模块四任务3 高压互锁回路测试
- 网络安全和信息化领导小组职责
- 学校食堂食品安全管理领导小组及职责
- 大学生情商训练
- 二年级看图写话植树教案(2025-2026学年)
- 2025年江苏省昆山市辅警招聘考试试题题库附参考答案详解(巩固)
评论
0/150
提交评论