- 8
- 0
- 约1.95万字
- 约 15页
- 2017-05-13 发布于四川
- 举报
图像高斯金字塔,用java编写
一:图像金字塔基本操作
对一张图像不断的模糊之后向下采样,得到不同分辨率的图像,同时每次得到的
新的图像宽与高是原来图像的1/2, 最常见就是基于高斯的模糊之后采样,得到的
一系列图像称为高斯金字塔。
高斯金字塔不同(DoG)又称为拉普拉斯金字塔,其计算公式如下:
L(i) = G(i) – expand(G(i+1))
第i层拉普拉斯金字塔是由第i层高斯金字塔减去第i+1层高斯金字塔expand之后得到。
本文得到的DoG(Difference of Gaussian)结果如下:
二:关键代码解析
金字塔reduce操作实现代码如下:
[java] view plaincopy
private BufferedImage pyramidReduce(BufferedImage src) {
int width = src.getWidth();
int height = src.getHeight();
BufferedImage dest = createSubCompatibleDestImage(src, null);
int[] inPixels = new int[width*height];
int ow = width/2;
int oh = height/2;
int[] outPixels = new int[ow*oh];
getRGB(src, 0, 0, width, height, inPixels );
int inRow=0, inCol = 0, index = 0, oudex =0, ta = 0;
float[][] keneralData = this.getHVGaussianKeneral();
for(int row=0; rowoh; row++) {
for(int col=0; colow; col++) {
inRow = 2* row;
inCol = 2* col;
if(inRow = height) {
inRow = 0;
}
if(inCol = width) {
inCol = 0;
}
float sumRed = 0, sumGreen = 0, sumBlue = 0;
for(int subRow = -2; subRow = 2; subRow++) {
int inRowOff = inRow + subRow;
if(inRowOff = height || inRowOff 0) {
inRowOff = 0;
}
for(int subCol = -2; subCol = 2; subCol++) {
int inColOff = inCol + subCol;
if(inColOff = width || inColOff 0) {
inColOff = 0;
}
index = inRowOff * width + inColOff;
ta = (inPixels[index] 24) 0xff;
int red = (inPixels[index] 16) 0xff;
int green = (inPixels[index] 8) 0xff;
int blue = inPixels[index] 0xff;
sumRed += keneralData[subRow + 2][su
您可能关注的文档
最近下载
- 房间隔缺损先天性心脏病防治专家共识(2025版)解读PPT课件.pptx VIP
- 濮阳濮阳县辅警招聘考试真题2023.doc VIP
- 《计算器后盖模具设计》-毕业论文(设计).doc VIP
- 基于单片机的室内环境监测系统设计与实现.docx
- 濮阳2023年辅警考试真题.pdf VIP
- 专题01 阅读理解“长难句克星”:主干提取三步法+观点态度词库(学生版) -2025年新高二英语暑假衔接讲练 (人教版).pdf VIP
- 苏J37-2009 消防站建筑设计图样.pdf VIP
- 日常生活能力量表(ADL)量表.docx VIP
- 背照式图像传感器及其制作方法、电子设备.pdf VIP
- 南通大学《信号与系统》2021-2022年第二学期期末试卷.pdf VIP
原创力文档

文档评论(0)