任务要求:
用c或java语言编写高斯随机数生成代码,并进行实验结果验证。用你自己的高斯随机数产生程序产生一个零均值,方差为0.001或者0.01(可调,由输入的命令行参数可调整均值和方差)的高斯随机数序列,共10000个,写到一个输出文本文件当中(学习把命令行屏幕输出的内容使用DOS/WINDOWS重定向符号写入文件,或者使用java的File类写入文件),作为噪声数据备用。
任务分析:
在这里采用java语言进行编写,并使用java的file类将数据写入文件。
1、我们需要从键盘得到均值和方差,并将这两个值作为高斯分布的参数。
2、在此我们要用到随机数,用Romdom类生成一个随机数作为高斯分布的变量
3、我们可以用Math.sqrt(b)*r.nextGaussian()+a语句作为高斯分布表达式,也可以用数学表达式输入。
4、产生的数据,直接用.writer()方法不能写入,是类型不匹配,也许是我没有掌握该知识点,所以我将产生的双精度型数据转换为浮点型并加上换行符。
程序代码:
package Tasktwo;
import java.io.FileWriter;//导入FileWriter,用于文件的写操作
import java.io.IOException;//导入IOException,输入输出异常
import java.util.Random;//导入Random,用于产生随机数
import java.util.Scanner;//导入Scanner,用于输入数据
public class test1 {
static void writer_test(String content)//写文件函数
{
try {
FileWriter fw=new FileWriter("E:\\project\\java\\text\\test2_1a\\test2_1a.txt",true);
fw.write(content);//将content写入文本
fw.flush();
fw.close();//关闭文件
}
catch(IOException e) {
e.printStackTrace();
}
}
public static void main(String []args)
{
Scanner reader=new Scanner(System.in);
System.out.print("请输入均值:");
float a=reader.nextFloat();//获得均值
System.out.print("请输入方差:");
float b=reader.nextFloat();//获得方差值
Random r = new Random();//新建一个随机数对象,作为高斯分布的变量
for(int i=0;i<=10;i++) {
double num = Math.sqrt(b)*r.nextGaussian()+a;//调用高斯随机函数公式,也可以采用高斯分布表达式
String num_str= String.valueOf(num); //将数值转换为字符型便于写入文件
String s=num_str+"\n";//将数据加上换行符,便于管理
writer_test(s);//调用写函数
System.out.println("产生的随机数为:"+num);//输出产生的随机数
}
}
}
运行结果:
在这产生10个高斯随机数进行测试