图像缩放--OpenCV cvResize函数
void cvResize( const CvArr* src, CvArr* dst, int interpolation=CV_INTER_LINEAR ); src 输入图像. dst 输出图像. interpolation 插值方法:
- CV_INTER_NN - 最近邻插值,
- CV_INTER_LINEAR - 双线性插值 (缺省使用)
- CV_INTER_AREA - 使用象素关系重采样。当图像缩小时候,该方法可以避免波纹出现。当图像放大时,类似于 CV_INTER_NN 方法..
- CV_INTER_CUBIC - 立方插值.
函数 cvResize 将图像 src 改变尺寸得到与 dst 同样大小。若设定 ROI,函数将按常规支持 ROI.
最近邻插值:效果(放大4倍)有马赛克现象
双线性插值:效果(放大4倍)比最近邻插值效果好
最近邻插值和双线性插值的基本原理
图像的缩放很好理解,就是图像的放大和缩小。传统的绘画工具中,有一种叫做“放大尺”的绘画工具,画家常用它来放大图画。当然,在计算机上,我们不再需要用放大尺去放大或缩小图像了,把这个工作交给程序来完成就可以了。下面就来讲讲计算机怎么来放大缩小图象;在本文中,我们所说的图像都是指点阵图,也就是用一个像素矩阵来描述图像的方法,对于另一种图像:用函数来描述图像的矢量图,不在本文讨论之列。
越是简单的模型越适合用来举例子,我们就举个简单的图像:3X3 的256级灰度图,也就是高为3个象素,宽也是3个象素的图像,每个象素的取值可以是 0-255,代表该像素的亮度,255代表最亮,也就是白色,0代表最暗,即黑色。假如图像的象素矩阵如下图所示(这个原始图把它叫做源图,Source):
234 38 22
67 44 12
89 65 63
这个矩阵中,元素坐标(x,y)是这样确定的,x从左到右,从0开始,y从上到下,也是从零开始,这是图象处理中最常用的坐标系,就是这样一个坐标:
---------------------->X
|
|
|
|
|
∨Y
如果想把这副图放大为 4X4大小的图像,那么该怎么做呢?那么第一步肯定想到的是先把4X4的矩阵先画出来再说,好了矩阵画出来了,如下所示,当然,矩阵的每个像素都是未知数,等待着我们去填充(这个将要被填充的图的叫做目标图,Destination):
? ? ? ?
? ? ? ?
? ? ? ?
? ? ? ?
然后要往这个空的矩阵里面填值了,要填的值从哪里来来呢?是从源图中来,好,先填写目标图最左上角的象素,坐标为(0,0),那么该坐标对应源图中的坐标可以由如下公式得出:
srcX=dstX* (srcWidth/dstWidth) , srcY = dstY * (srcHeight/dstHeight)
好了,套用公式,就可以找到对应的原图的坐标了(0*(3/4),0*(3/4))=>(0*0.75,0*0.75)=>(0,0)
,找到了源图的对应坐标,就可以把源图中坐标为(0,0)处的234象素值填进去目标图的(0,0)这个位置了。
接下来,如法炮制,寻找目标图中坐标为(1,0)的象素对应源图中的坐标,套用公式:
(1*0.75,0*0.75)=>(0.75,0)
结果发现,得到的坐标里面竟然有小数,这可怎么办?计算机里的图像可是数字图像,象素就是最小单位了,象素的坐标都是整数,从来没有小数坐标。这时候采用的一种策略就是采用四舍五入的方法(也可以采用直接舍掉小数位的方法),把非整数坐标转换成整数,好,那么按照四舍五入的方法就得到坐标(1,0),完整的运算过程就是这样的:
(1*0.75,0*0.75)=>(0.75,0)=>(1,0)
那么就可以再填一个象素到目标矩阵中了,同样是把源图中坐标为(1,0)处的像素值38填入目标图中的坐标。
依次填完每个象素,一幅放大后的图像就诞生了,像素矩阵如下所示:
234 38 22 22
67 44 12 12
89 65 63 63
89 65 63 63
这种放大图像的方法叫做最临近插值算法,这是一种最基本、最简单的图像缩放算法,效果也是最不好的,放大后的图像有很严重的马赛克,缩小后的图像有很严重的失真;效果不好的根源就是其简单的最临近插值方法引入了严重的图像失真,比如,当由目标图的坐标反推得到的源图的的坐标是一个浮点数的时候,采用了四舍五入的方法,直接采用了和这个浮点数最接近的象素的值,这种方法是很不科学的,当推得坐标值为 0.75的时候,不应该就简单的取为1,既然是0.75,比1要小0.25 ,比0要大0.75 ,那么目标象素值其实应该根据这个源图中虚拟的点四周的四个真实的点来按照一定的规律计算出来的,这样才能达到更好的缩放效果。双线型内插值算法就是一种比较好的图像缩放算法,它充分的利用了源图中虚拟点四周的四个真实存在的像素值来共同决定目标图中的一个像素值,因此缩放效果比简单的最邻近插值要好很多。
双线性内插值算法描述如下:
对于一个目的像素,设置坐标通过反向变换得到的浮点坐标为(i+u,j+v) (其中i、j均为浮点坐标的整数部分,u、v为浮点坐标的小数部分,是取值[0,1)区间的浮点数),则这个像素得值 f(i+u,j+v) 可由原图像中坐标为 (i,j)、(i+1,j)、(i,j+1)、(i+1,j+1)所对应的周围四个像素的值决定,即:
f(i+u,j+v) = (1-u)(1-v)f(i,j) + (1-u)vf(i,j+1) + u(1-v)f(i+1,j) + uvf(i+1,j+1) 公式1
其中f(i,j)表示源图像(i,j)处的的像素值,以此类推。
比如,象刚才的例子,现在假如目标图的象素坐标为(1,1),那么反推得到的对应于源图的坐标是(0.75 , 0.75), 这其实只是一个概念上的虚拟象素,实际在源图中并不存在这样一个象素,那么目标图的象素(1,1)的取值不能够由这个虚拟象素来决定,而只能由源图的这四个象素共同决定:(0,0)(0,1)(1,0)(1,1),而由于(0.75,0.75)离(1,1)要更近一些,那么(1,1)所起的决定作用更大一些,这从公式1中的系数uv=0.75×0.75就可以体现出来,而(0.75,0.75)离(0,0)最远,所以(0,0)所起的决定作用就要小一些,公式中系数为(1-u)(1-v)=0.25×0.25也体现出了这一特点。
原理参考link:http://blog.csdn.net/andrew659/article/details/4818988
OpenCV代码:scale是放缩比例
点击(此处)折叠或打开
- #include "stdafx.h"
- #include <cv.h>
- #include <cxcore.h>
- #include <highgui.h>
- #include <cmath>
- using namespace std;
- using namespace cv;
- int main(int argc ,char ** argv)
- {
- IplImage *scr=0;
- IplImage *dst=0;
- double scale=4;
- CvSize dst_cvsize;
- if (argc==2&&(scr=cvLoadImage(argv[1],-1))!=0)
- {
- dst_cvsize.width=(int)(scr->width*scale);
- dst_cvsize.height=(int)(scr->height*scale);
- dst=cvCreateImage(dst_cvsize,scr->depth,scr->nChannels);
- cvResize(scr,dst,CV_INTER_NN);//
- // CV_INTER_NN - 最近邻插值,
- // CV_INTER_LINEAR - 双线性插值 (缺省使用)
- // CV_INTER_AREA - 使用象素关系重采样。当图像缩小时候,该方法可以避免波纹出现。
- /*当图像放大时,类似于 CV_INTER_NN 方法..*/
- // CV_INTER_CUBIC - 立方插值.
- cvNamedWindow("scr",CV_WINDOW_AUTOSIZE);
- cvNamedWindow("dst",CV_WINDOW_AUTOSIZE);
- cvShowImage("scr",scr);
- cvShowImage("dst",dst);
- cvWaitKey();
- cvReleaseImage(&scr);
- cvReleaseImage(&dst);
- cvDestroyWindow("scr");
- cvDestroyWindow("dst");
- }
- return 0;
- }
图像缩放--OpenCV cvResize函数相关推荐
- c语言实现图像resize函数,调整图像的尺寸 - cvResize() 函数实现
前言 有时会碰到一张图片太大了,想将它缩小.本文将讲解一个很好用的函数解决这个问题. 图像尺寸调整函数 cvResize() // 图像尺寸调整函数 void Resize ( const CvArr ...
- OpenCV resize 图像缩放
::返回OpenCV算子速查表 图像缩放 resize 1. 函数定义 2. 例程 1. 函数定义 OpenCV官方文档 resize resize(InputArray src,OutputArra ...
- 【OpenCV】图像缩放
1.内置函数resize: void resize(InputArray src, OutputArray dst, Size dsize, double fx=0, double fy=0, int ...
- 图像缩放算法_opencv缩放算法
1.opencv插值介绍 opencv提供resize函数用来做图像缩放,该函数有6个参数: (1)输入图像,Mat型 (2)输出图像,Mat型 (3)输出图像大小,可用cv::Size(out_im ...
- python图像处理第七课--图像缩放、翻转、旋转、平移--小白的成长历程
#目的为记录在自己运行时存在的问题及解决方法,本文基于CSDN社区的Eastmount大佬的课程,通过学习,其中也增加了自己的考量和问题的解决. 图像缩放 图像缩放由 resize() 函数实现,如下 ...
- Matlab图像的几何变换之图像缩放
Matlab图像缩放 Matlab实现函数代码如下: clc I=rgb2gray(imread('Campus-scenery2sk.JPG')); figure,imshow(I); title( ...
- OpenCV图像缩放函数resize()的使用
OPenCV版本:4.4 IDE:VS2017 功能描述 简述:缩放一个图像 函数把源图像缩放大或缩放小到指定的大小,注意初始的dst的类型或大小不用考虑,而是从src,dsize,fx, 和fy获取 ...
- OpenCV图像缩放插值之BiCubic双三次插值
图像缩放算法简介 在图像的仿射变换中,很多地方需要用到插值运算,常见的插值运算包括最邻近插值,双线性插值,双三次插值(立体插值),兰索思插值等方法,OpenCV提供了很多方法,其中,双线性插值由于折中 ...
- python函数图像平移_[Python图像处理]六.图像缩放,图像旋转,图像翻转与图像平移...
图像缩放 图像缩放主要是调用resize()函数实现,result = cv2.resize(src, dsize[, result[.fx, fy[,interpolation]]]) 其中src ...
最新文章
- 5G NGC — NWDAF 网络智能分析功能
- 报Access数据库不存在或者打不开的错误
- 前端学习(2788):完成图片商品数据页面渲染
- 请写出3个Android布局,一起撸一波干货集中营练练手Android(三)布局+实现篇
- CISCO PVST+配置和结果验证 per vlan spanning tree(51cto 实验10)
- Jenkins ssh 发布jar 时区不对
- C语言头歌educoder实训作业答案分享 结构体
- java web学习心得
- PCWorld盘点2011科技界15大败笔 索尼居首(图)
- Java Date总结
- win10录屏软件用什么好?分享:一款win10支持的录屏软件,超好用
- 建筑工程PPP项目财务风险控制探析
- 5.12 按照多个条件进行组合排序 [原创Excel教程]
- 史上最全公开课纪录片下载地址汇总
- Markdown语法笔记
- 目标检测任务超大图像的切图实现
- vue设置页面title
- 深信服上网行为管理开启snmp_SANGFOR上网行为管理系统用户手册.pdf
- MBA-day20 不定方程问题-练习题
- 聚类(2)——层次聚类 Hierarchical Clustering
热门文章
- Spark源码走读1——RDD
- mysql教程多表查询_解析Mysql多表查询的实现
- scala模板写入es_Spark——scala 实用小方法
- centos7全盘备份到本地_CentOS7 系统盘迁移案例【大硬盘迁移到小硬盘,新思路】...
- 看ct片子的软件_X光、CT、核磁、B超的辐射到底对孩子有多大影响?
- tlc5620输出三角波流程图_TLC5620(电压输出型)_pdf
- Linux安装Nessus
- 微软高性能计算服务器pdf,微软高性能计算HPCserver2008技术概览.pdf
- python的内存泄露_Python 程序的内存泄露,教你一招来解决?
- error超频 whea win10_解决WHEA_UNCORRECTABLE_ERROR蓝屏