- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)