掩膜操作手写+API(第二天)

2024-05-28 20:18
文章标签 掩膜 第二天 api 操作手

本文主要是介绍掩膜操作手写+API(第二天),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.1首先是用到的理论知识:

上面是一个通用的公式,光知道上面写程序还是有点麻烦的,下面公式画的有点丑,可以表达我的观点。

 1.2用到的知识点:可以边看程序边看用到的知识点:

 CV_Assert(); //这是C++的一个限制函数,这个不用多说了。 

 dst.create();//创建一个图像,形式根据参数选定 

Mat.ptr<uchar>(i,j)//代表第i行,第j个点的值(j的大小包含通道数),这是一个地址
i = Mat.rols();
j = Mat.cols()*Mat.channels();
ucahr//代表这个容器存储的类型,和C++的Vector<int> test;一样的Mat.ptr<uchar>(i) //获取像素矩阵的指针,索引i表示第几行,从0开始计行数。这是一个指针
const uchar* current= myImage.ptr<uchar>(row);//获得当前行指针
p(row,col) =current[col]//获取当前像素点P(row, col)的像素值 这是一个值
saturate_cast<uchar>(data)//像素范围处理 
uchar//代表data的范围在-128-127 
usigned int //代表data的范围在0-255 上面的取值和系统有关,就是一个表达意思,不必深究!>Max=Max;<Min=Min;

代码如下:

 1 #include<iostream>2 #include <opencv2/opencv.hpp>3 #include <math.h>4 using namespace cv;5 6 void Mask(const Mat& src, Mat& dst);7 8 int main(int argc,char**argv)9 {
10     const Mat input_image = imread("9.jpg");
11     namedWindow("Sourse image");
12     imshow("Sourse image", input_image);
13     Mat output_image;
14     Mask(input_image,output_image);
15     namedWindow("Mask image");
16     imshow("Mask image",output_image);
17     waitKey(0);
18     return 0;
19 }
20 
21 void Mask(const Mat& src, Mat& dst) 
22 {
23     CV_Assert(src.depth() == CV_8U);//深度申明,只有unsigend char的可以传入
24     dst.create(src.size(),src.type());//创建一个和src大小类型一样的空模板
25     const int nChannels = src.channels();//取出通道数
26     for (int i = 1; i < src.rows - 1; i++) 
27     {
28         const uchar *previous = src.ptr<uchar>(i - 1);
29         const uchar *currents = src.ptr<uchar>(i);    //源操作图像
30         const uchar *nexts    = src.ptr<uchar>(i + 1);
31         uchar *output = dst.ptr<uchar>(i);//目标操作图像
32         for (int j = nChannels; j < src.cols*nChannels - 1; j++) 
33         {
34             //------------掩膜计算的值进行限幅------------//
35             *output++ = saturate_cast<uchar>(5 * currents[j] - currents[j - nChannels]
36                                                - currents[j + nChannels] - previous[j] - nexts[j]);
37         }
38     }
39 }

注:第一行第一列,最后一行最后一列都没经过处理,可以取值0,也可以取值原来值

2.1利用OPENCV自带的API函数进行掩膜操作:

1 Mat kernel = (Mat_<double>(3, 3) << 0, -1, 0, -1, 0, 5, -1, 0, -1, 0);//定义一个矩阵,不懂得可以看Mat的七种操作,记得加红色括号!!
2 filter2D(input_image, output_image, input_image.depth(), kernel);//掩膜操作函数

 测试代码如下:

 1 int main(int argc,char**argv)2 {3     const Mat input_image = imread("9.jpg");4     namedWindow("Sourse image");5     imshow("Sourse image", input_image);6     Mat output_image;7     //Mask(input_image,output_image);8     Mat kernel = (Mat_<double>(3, 3) << 0, -1, 0, -1, 0, 5, -1, 0, -1, 0);9     filter2D(input_image, output_image, input_image.depth(), kernel);
10     namedWindow("Mask image");
11     imshow("Mask image",output_image);
12     waitKey(0);
13     return 0;
14 }

 运行图片:

 3.1内核函数的扩展:

1 // 如果上述的核改变成
2    Kernel = (Mat_<double>(3,3)<<1,1,1,1,1,1,1,1,1);
3    Kernel/=1/9;//那么这就是平滑滤波函数,可以根据自己的情况对内核进行更改

 4.1效率测试:

opencv自带的时间计时函数,我们可以利用这个函数进行手写和API进行效率对比:

1 double Tick=static_cast<double(getTickCount());//static_cast<double>(j)这是C++自带的强制转换,相当于(double)(i),和saturate_cast<double>(i)不同(这是opencv语句)
2 filter2D(input_image, output_image, input_image.depth(), kernel);
3 Tick = (static_cast<double>(getTickCount()) - Tick) / getTickFrequency();//频率 X 计数值 = 时间
4 cout << Tick;

 下面是测试时间API=0.004毫秒,手写=0.007

opencv都是进行优化的库,这是小的测试,以后工程大了就能发现其中的奥妙

这篇关于掩膜操作手写+API(第二天)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

python通过curl实现访问deepseek的API

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... API申请和充值下面是deepeek的API网站https://platform.deepsee

Java对接Dify API接口的完整流程

《Java对接DifyAPI接口的完整流程》Dify是一款AI应用开发平台,提供多种自然语言处理能力,通过调用Dify开放API,开发者可以快速集成智能对话、文本生成等功能到自己的Java应用中,本... 目录Java对接Dify API接口完整指南一、Dify API简介二、准备工作三、基础对接实现1.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo