能谱谱数据分解方法研究程序核数据处理课程设计.docVIP

能谱谱数据分解方法研究程序核数据处理课程设计.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
%本次课程设计采用的谱数据为iaea-1995文件夹下iaearfnw TSTSPEC %里面的数据。首先来看看CALIB.ASCo READ_ME.TXT屮说明了这个谱数据包含的部分 峰的峰位与对应能量如下: % Chan nel Energy (keV) % 301 122.06 % 1281 511.00 % 1661 661.66 % 2097 834.84 % 2951 1173.24 % 3207 1274.54 % 3353 1332.50 %运行程序,其屮参数选择为:选择傅里叶变换法平滑输入3,选择高斯滤波器输入 后 A=1,FWHM=4, 对称零面积法的参数是K=2, H=3,b=l寻出来 %的峰与READ_ME.TXT屮说明的部分峰的峰位与对应能暈数据相吻介。 2,然 clc; clear; [Filename,Pathname]=uigetfile(,*.*,,i^ 择谱数据); fid=fopen([Pathname Filename],r) %fid 为文件指针,i■表示读操作 [array,count]=fscanf(fid,,%d,,[l inf]); %指定格式转换后返冋给矩阵 array,同 时返冋成功的读出的数据数量count, 1表示读出一个元素到一个列向量,inf表示读到文件 结朿返冋一个与文件数据元素相同的列向量 fclose(fid); %%%%ifii 开始能谱平 zH-%%%%%%% pinghuaxuanze=i叩ut(*请选择平滑方法:\n输入1选择重心法平滑\n输入2选择多项式最小二 乘移动平滑法\n输入3选择傅里叶变换法\n输入4选择小波变换:W); 1 ?£? ?土 ?士 ?士 ?£? ?土 ?士 ■一|、 ■丿? I ? \ I / % J f Ia ?士 ?土 ?士 ?士 1 v y. 1 ? ? w 1A ? ~ if (pinghuaxuanze== 1) biaoji=l; for i=l:count array_z(i)=array(i); end w=i叩ut「i叩ut the width of the filter window:); %w 表示 w 点平滑公式 while mod(w,2)==0 %判断输入的数是否是奇数,不是则重新输入。 w=input(4nput odd number/); end m=floor(w/2); for j=l:m for i=l:count if(i==l) array_smooth(i)=0.5*(array_z(i)+array_z(i+1)); %能谱左边界做对称镜像处理 elseif(i 1 i(count-l)) array_smooth(i)=0.25*array_z(i-l)+0.5*array_z(i)+0.25*array_z(i+1); else array_smooth(i)=0.5*(array_z(count)+array_z(count-1)); %能谱右边界做对称镜 像处理 end end for i=l:count %将平滑好的数据放冋原数组,为下一次做好准备。 array_z( i )=array_smooth( i); end end for i=l:count al(i)=array_z(i); end 逐 ****** ****** ***********重心 法平 滑结束 ********** ********** ******* 轻 ******* ****** *** ******* 多项式最小二乘移动平滑法 **** *** ** ***** *** elseif(pi nghuaxua nze==2) biaoji=2; w=input(*i叩ut the width of the filter window:); %w 为窗口 宽度 fwk = zeros(w,l); %存储滤波器系数,产生一个1行,w列的零矩阵;当求平滑 之后谱的笫i点数据时,先在原始数据第i点的左、右各取m个数据点;也就是形成一个共 有w=2m+l个数据点的窗口; for i=l :w k=i-ceil(w/2); %调整,计算采用k=- m:m,窗口的中心点为ceil( w/2)点 fwk(i)=[ 1 +(15/(wA2-4))*((wA2-1)/12-kA2)]/w; %2 次或 3 次滤波器 %fwkz=2.5*(vvA2-7)*((wA2-1)/12-kA2)-9*((wA2-1 )*(3*wA2-7)/240-kA4); %4 次或5次滤波器 %fwk(i)=( 1 +105/(4*(wA2-4)*(wA2-16))*fwkz)/w; %fwk(i)=( 1+(15 *(3 * w

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档