数字图像处理实验报告(3)
int new_len = 2*pow(2,nextpow2); int order = max(64,new_len/2); Mat filt = (Mat_
//a=0,选择无滤波
if(a==0) {
for(int i=0; i
filt = filt.t(); return filt; }
for(int i=0; i filt.at Mat w = (Mat_ w.at Mat filt2 = (Mat_ //shepp-logan if(a==1) { for(int i=1; i filt2.at for(int i=order/2+1; i //hamming if(a==2) { for(int i=1; i filt2.at for(int i=order/2+1; i filt2.at 11 } //hann if(a==3) { for(int i=1; i filt2.at for(int i=order/2+1; i filt2.at filt2 = filt2.t(); return filt2; } //子函数---傅立叶变换 void DFT(Mat& srcArr, Mat& dstArr) { Mat planes[] = {Mat_ //子函数---傅立叶反变换 void inverseDFT(Mat& dft_result, Mat& dst) { dft(dft_result, dst, DFT_INVERSE+DFT_SCALE|DFT_REAL_OUTPUT); normalize(dst, dst, 0, 1, NORM_MINMAX); } //子函数---滤波处理 void rho_filter(Mat& In,Mat& Out,int a,int d) { Mat Filt; Filt = Design_filter(In,a,d); Mat P = Mat::zeros(Filt.rows, In.cols, CV_32F); Mat target = P(Rect(0,0,In.cols,In.rows)); In.copyTo(target); Mat P_DFT; DFT(P, P_DFT); Mat planes[2]; split(P_DFT, planes); for(int i=0;i 12 for(int j=0;j planes[0].at Mat L; merge(planes, 2, P_DFT); inverseDFT(P_DFT,L); Mat target2=L(Rect(0,0,In.cols,In.rows)); target2.copyTo(Out); } //子函数---矩阵扩展 void repmat(Mat input, int x, int y, Mat& output) { int r = input.rows, c = input.cols; Mat Matrix_target = Mat::zeros(r*x, c*y, CV_32F); for ( int i = 0; i < x; i++) { for ( int j = 0; j < y; j++) { Rect roi = Rect(j*c, i*r, c, r); Mat Matrix_temp = Matrix_target(roi); input.copyTo(Matrix_temp); } } output = Matrix_target; } //主函数 int main() { Mat source_image = imread(\ int m = source_image.rows, n = source_image.cols; int xc = floor((m+1)/2), yc = floor((n+1)/2); Mat d = subpixels(source_image); int b = ceil(sqrt(m*m+n*n)/2+1); Mat xp = (Mat_ Size sz=xp.size(); Mat X,Y; ndgrid(xc,yc,m,n,X,Y); 13 X=flatten(X); Y=flatten(Y); d=flatten(d); int numDiv = 360; float * pTheta = new float[numDiv]; Mat RTtotal=Mat::zeros(xp.cols,numDiv,CV_32F); //生成正弦图 for (int i=0; i Mat Xp=cos(pTheta[i])*Y-sin(pTheta[i])*X; Mat ip=Xp+b+1; Mat frac=(Mat_ k.at frac.at Mat S=1-frac; Mat val1=Mat_ val1=d.mul(S); val2=d.mul(frac); Mat RT1, RT2; accumarray(k,val1,sz,RT1); accumarray(k+1,val2,sz,RT2); Mat RT=(RT1+RT2); Mat RTtotal_temp=RTtotal.col(i); RT.col(0).copyTo(RTtotal_temp); } imshow(\ normalize(RTtotal, RTtotal, 0, 1, CV_MINMAX);//归一化处理 imshow(\ Mat filter_img; rho_filter(RTtotal, filter_img, 0, 1);//第三个参数选择滤波器类型 normalize(filter_img, filter_img, 0, 1, CV_MINMAX); imshow(\ 14 Mat p = filter_img.clone(); Mat img = Mat::zeros(600, 600, CV_32FC1); int N = 600; int center = floor((N + 1)/2); int xleft = -center + 1; Mat x1 = (Mat_ x1.at Mat x,y; repmat(x1,N,1,x); int ytop = center - 1; for(int j=N-1; j>=0; j--) { y1.at repmat(y1,1,N,y);
相关推荐:
- [实用模板]第八章:法国“新浪潮”与“左岸派”
- [实用模板]2021年北京上半年临床医学检验技师生物
- [实用模板]SAP GUI 7.10客户端安装配置文档
- [实用模板]2001年临床执业医师资格考试综合笔试试
- [实用模板]36机场工作实用英语词汇总结
- [实用模板](一)社会保险稽核通知书
- [实用模板]安全教育主题班会材料
- [实用模板]濉溪县春季呼吸道传染病防控应急演练方
- [实用模板]长沙房地产市场周报(1.30-2.3)
- [实用模板]六年级数学上册典中点 - 图文
- [实用模板]C程序设计(红皮书)习题官方参考答案
- [实用模板]中国证监会第一届创业板发行审核委员会
- [实用模板]桥梁工程复习题
- [实用模板]2011学而思数学及答案
- [实用模板]初中病句修改专项练习
- [实用模板]监理学习知识1 - 图文
- [实用模板]小机灵杯四年级试题
- [实用模板]国贸专业毕业论文模板
- [实用模板]教育学概论考试练习题-判断题4
- [实用模板]2015届高考英语一轮复习精品资料(译林
- 00Nkmhe_市场营销学工商管理_电子商务_
- 事业单位考试法律常识
- 诚信教育实施方案
- 吉大小天鹅食品安全检测箱方案(高中低
- 房地产销售培训资料
- 高一地理必修1复习提纲
- 新概念英语第二册lesson_1_练习题
- 证券公司内部培训资料
- 小学英语时间介词专项练习
- 新世纪英语专业综合教程(第二版)第1册U
- 【新课标】浙教版最新2018年八年级数学
- 工程建设管理纲要
- 外研版 必修一Module 4 A Social Surve
- Adobe认证考试 AE复习资料
- 基于H.264AVC与AVS标准的帧内预测技术
- 《食品检验机构资质认定管理办法》(质
- ABB变频器培训课件
- (完整版)小学说明文阅读练习题及答案
- 深思洛克(SenseLock) 深思IV,深思4,深
- 弟子规全文带拼音




