计算机视觉全系列实战教程:(十)图像的几何变换:平移 旋转 翻转 缩放 仿射等变换

本文主要是介绍计算机视觉全系列实战教程:(十)图像的几何变换:平移 旋转 翻转 缩放 仿射等变换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.概述

(1)Why(为什么要进行图像的几何变换)

  • 校正图像形变:纠正由于拍摄角度或硬件原因导致的图像几何变形
  • 图像增强:在深度学习的模型训练时,通过几何变换获得更多的训练集
  • 图像配准和拼接:先进行几何变换矫正,然后实现图像的配准或拼接

(2)What(什么是图像的几何变换)

本质:对图像像素的位置进行改变的操作

(3)Which(有哪些几何变换)

  • 位置变换:平移、旋转(填充旋转和截断旋转)、镜像等变换
  • 形状变换:缩放、错切、透视等变换

说明:实现几何变换的关键在于将非齐次坐标转为齐次坐标,本质是将22的变换矩阵(二阶矩阵)拓展成33的变换矩阵(三阶矩阵)

2.位置变换

(1)平移变换

A.图像大小不变
可直接使用

/* 图像平移(截断)*/
int ImgTranslateTrunc(const cv::Mat& imSrc, cv::Mat& imDst, int ix, int  iy)
{cv::Mat M(2, 3, CV_32FC1);M.at<float>(0, 0) = 1;M.at<float>(0, 1) = 0;M.at<float>(0, 2) = ix;M.at<float>(1, 0) = 0;M.at<float>(1, 1) = 1;M.at<float>(1, 2) = iy;cv::warpAffine(imSrc, imDst, M, imSrc.size());return 1;
}

B.图像大小改变
可直接拷贝使用


/* 图像平移(填充)*/
int ImgTranslateFilled(const cv::Mat& imSrc, cv::Mat& imDst, int ix, int iy)
{cv::Mat M(2, 3, CV_32FC1);M.at<float>(0, 0) = 1;M.at<float>(0, 1) = 0;M.at<float>(0, 2) = ix;M.at<float>(1, 0) = 0;M.at<float>(1, 1) = 1;M.at<float>(1, 2) = iy;cv::warpAffine(imSrc, imDst, M, imSrc.size() + cv::Size(ix, iy));return 1;
}

(2)图像旋转

一般认为图像的旋转指的是绕着图像的中心进行旋转;
关键:旋转中心+旋转角度
A.填充旋转


/* 图像旋转(填充)*/
int ImgRtFilled(const cv::Mat& imSrc, cv::Mat& imDst, double dAngle)
{// 图像的旋转中心int iWid = imSrc.cols, iHgt = imSrc.rows;cv::Point center = cv::Point(iWid / 2, iHgt / 2);// 获取M矩阵cv::Mat M = cv::getRotationMatrix2D(center, dAngle, 1.0);// 新的宽高 int iHgt_new = 0, iWid_new = 0;double alpha = dAngle * CV_PI / 180;iHgt_new = int(iWid * abs(sin(alpha)) + iHgt * abs(cos(alpha)));iWid_new = int(iHgt * abs(sin(alpha)) + iWid * abs(cos(alpha)));// 平移M.at<double>(0, 2) += (iWid_new - iWid) / 2;M.at<double>(1, 2) += (iHgt_new - iHgt) / 2;cv::warpAffine(imSrc, imDst, M, cv::Size(iWid_new, iHgt_new));return 1;
}

B.截断旋转

/* 图像旋转(截断)*/
int imgRtTrunc(const cv::Mat& imSrc, cv::Mat& imDst, double dAngle)
{cv::Point PCenter = cv::Point(imSrc.cols / 2, imSrc.rows / 2);cv::Mat M = getRotationMatrix2D(PCenter, dAngle, 1.0);cv::warpAffine(imSrc, imDst, M, imSrc.size());return 1;
}

(3)镜像变换

void cv::flip(cv::Mat &imSrc, cv::Mat &imDst, int Type  // 0表示x轴镜像,1表示y轴镜像,-1表示x和y轴的镜像);

3.图像缩放

(1)原理

将指定图像在x轴方向按照比例缩放fx倍,在y轴方向按照比例缩放fy倍
全比例缩放:如果在x轴方向和y轴方向的缩放比例相同,那么则称为全比例缩放

(2)How(如何进行图像的缩放)

void cv::resize(cv::Mat &imSrc,cv::Mat &imDst,cv::Size dsize, //目标图像的尺寸cv::double fx = 0, //x方向上的缩放比例cv::double fy = 0, //y方向上的缩放比例int interpolation = INTER_LINEAR, //插值方式);

参数interpolation的介绍:

  • INTER_NEAREST:最近邻插值
  • INTER_LINEAR:双线性插值
  • INTER_AREA:像素关系重采样,当图像缩小时,可避免出现波纹
  • INTER_ CUBIC:立方插值

这篇关于计算机视觉全系列实战教程:(十)图像的几何变换:平移 旋转 翻转 缩放 仿射等变换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1063970

相关文章

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

全网最全Tomcat完全卸载重装教程小结

《全网最全Tomcat完全卸载重装教程小结》windows系统卸载Tomcat重新通过ZIP方式安装Tomcat,优点是灵活可控,适合开发者自定义配置,手动配置环境变量后,可通过命令行快速启动和管理... 目录一、完全卸载Tomcat1. 停止Tomcat服务2. 通过控制面板卸载3. 手动删除残留文件4.

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

Python的pandas库基础知识超详细教程

《Python的pandas库基础知识超详细教程》Pandas是Python数据处理核心库,提供Series和DataFrame结构,支持CSV/Excel/SQL等数据源导入及清洗、合并、统计等功能... 目录一、配置环境二、序列和数据表2.1 初始化2.2  获取数值2.3 获取索引2.4 索引取内容2

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

Oracle Scheduler任务故障诊断方法实战指南

《OracleScheduler任务故障诊断方法实战指南》Oracle数据库作为企业级应用中最常用的关系型数据库管理系统之一,偶尔会遇到各种故障和问题,:本文主要介绍OracleSchedul... 目录前言一、故障场景:当定时任务突然“消失”二、基础环境诊断:搭建“全局视角”1. 数据库实例与PDB状态2

Git进行版本控制的实战指南

《Git进行版本控制的实战指南》Git是一种分布式版本控制系统,广泛应用于软件开发中,它可以记录和管理项目的历史修改,并支持多人协作开发,通过Git,开发者可以轻松地跟踪代码变更、合并分支、回退版本等... 目录一、Git核心概念解析二、环境搭建与配置1. 安装Git(Windows示例)2. 基础配置(必

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分