数字图像处理实验报告文档格式.docx
- 文档编号:15018700
- 上传时间:2022-10-26
- 格式:DOCX
- 页数:5
- 大小:15.87KB
数字图像处理实验报告文档格式.docx
《数字图像处理实验报告文档格式.docx》由会员分享,可在线阅读,更多相关《数字图像处理实验报告文档格式.docx(5页珍藏版)》请在冰豆网上搜索。
五、具体实现
实现设计思路中定义的所有的数据类型,对每个操作给出实际算法。
对主程序和其他模块也都需要写出实际算法。
代码:
<
邻域平均法>
(3*3)
#include
>
"
/*------定义结构指针------*/
struct
bmphdr
*hdr;
//
argc=3;
argv[1]="
;
argv[2]="
//参数输入出错显示
/*
if
(argc
!
=
3)
{
printf("
please
input
the
name
of
and
out
bitmap
files\n"
);
exit
(1);
}*/
获取位图文件相关信息//
hdr
get_header(argv[1]);
get_header("
(!
hdr)
//以二进制可读方式打开输入位图文件
fp
fopen("
rb"
fp)
File
open
error!
\n"
}
//
文件指针指向数据区域
fseek(fp,
hdr->
offset,
SEEK_SET);
//计算位图像素的个数
nr_pixels
width
*
height;
nr_w
width;
nr_h
malloc(nr_pixels);
new_color
count
malloc((nr_w+2)*(+nr_h+2));
//读取位图数据到bitmap中
fread(bitmap,
nr_pixels,
1,
fp);
fclose(fp);
//因为图像边缘无法使用邻域平均,所以根据邻近颜色填补图像的周围一圈,存入count[]数组中
//中心图像存入count[]
for(i=nr_w+3;
i<
(nr_w+2)*(+nr_h+2)-nr_w-3;
i++)
j=i/(nr_w+2);
if(i%(nr_w+2)!
=0&
&
(i+1)%(nr_w+2)!
=0)
count[i]=bitmap[i-nr_w-1-2*j];
//填补第一排
for(i=1;
nr_w+1;
count[i]=bitmap[i-1];
//填补最后一排
count[(nr_w+2)*(nr_h+1)+i]=bitmap[nr_w*(nr_h-1)+i-1];
//填补左边一排
for(i=0;
nr_h+3;
count[i*(nr_w+2)]=count[i*(nr_w+2)+1];
//填补右边一排
count[(i+1)*(nr_w+2)-1]=count[(i+1)*(nr_w+2)-2];
//中值平均3*3
for(j=nr_w+3,i=0;
j<
j++)
if(j%(nr_w+2)!
(j+1)%(nr_w+2)!
t[0]=count[j];
t[1]=count[j-1];
t[2]=count[j+1];
t[3]=count[j-nr_w-2];
t[4]=count[j-1-nr_w-2];
t[5]=count[j+1-nr_w-2];
t[6]=count[j+nr_w+2];
t[7]=count[j-1+nr_w+2];
t[8]=count[j+1+nr_w+2];
for(m=0;
m<
9;
m++)
for(n=0;
n<
9-m;
n++)
if(t[n]>
t[n+1])
temp=t[n];
t[n]=t[n+1];
t[n+1]=temp;
new_color[i]=t[4];
i++;
//结果存入bitmap[]中
for
(i
0;
i
nr_pixels;
bitmap[i]=new_color[i];
打开一个以输出文件名命名的文件,设为可写的二进制形式
fpnew
wb+"
//由于位图文件的头部信息并没有因直方图均衡化而改变,因此输出图像的头部信息从原位图文件中拷贝即可:
fwrite(hdr->
signature,
2,
fpnew);
fwrite(&
size,
4,
reserved,
hdr_size,
width,
height,
nr_planes,
bits_per_pixel,
compress_type,
data_size,
resol_hori,
resol_vert,
nr_colors,
important_color,
(hdr->
offset
54)
info,
-
54),
//直方图均衡化的数据(bitmap)赋值
fwrite(bitmap,
//关闭
fclose(fpnew);
//释放内存(优化程序必需)
free(hdr);
free(bitmap);
free(new_color);
free(count);
return
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数字图像 处理 实验 报告