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;

代码如下:

 #include<iostream>
#include <opencv2/opencv.hpp>
#include <math.h>
using namespace cv; void Mask(const Mat& src, Mat& dst); int main(int argc,char**argv)
{
const Mat input_image = imread("9.jpg");
namedWindow("Sourse image");
imshow("Sourse image", input_image);
Mat output_image;
Mask(input_image,output_image);
namedWindow("Mask image");
imshow("Mask image",output_image);
waitKey();
return ;
} void Mask(const Mat& src, Mat& dst)
{
CV_Assert(src.depth() == CV_8U);//深度申明,只有unsigend char的可以传入
dst.create(src.size(),src.type());//创建一个和src大小类型一样的空模板
const int nChannels = src.channels();//取出通道数
for (int i = ; i < src.rows - ; i++)
{
const uchar *previous = src.ptr<uchar>(i - );
const uchar *currents = src.ptr<uchar>(i); //源操作图像
const uchar *nexts = src.ptr<uchar>(i + );
uchar *output = dst.ptr<uchar>(i);//目标操作图像
for (int j = nChannels; j < src.cols*nChannels - ; j++)
{
//------------掩膜计算的值进行限幅------------//
*output++ = saturate_cast<uchar>( * currents[j] - currents[j - nChannels]
- currents[j + nChannels] - previous[j] - nexts[j]);
}
}
}

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

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

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

测试代码如下:

 int main(int argc,char**argv)
{
const Mat input_image = imread("9.jpg");
namedWindow("Sourse image");
imshow("Sourse image", input_image);
Mat output_image;
//Mask(input_image,output_image);
Mat kernel = (Mat_<double>(, ) << , -, , -, , , -, , -, );
filter2D(input_image, output_image, input_image.depth(), kernel);
namedWindow("Mask image");
imshow("Mask image",output_image);
waitKey();
return ;
}

运行图片:

 3.1内核函数的扩展:

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

4.1效率测试:

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

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

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

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

掩膜操作手写+API(第二天)的更多相关文章

  1. web api写api接口时返回

    web api写api接口时默认返回的是把你的对象序列化后以XML形式返回,那么怎样才能让其返回为json呢,下面就介绍两种方法: 方法一:(改配置法) 找到Global.asax文件,在Applic ...

  2. Swagger解决你手写API接口文档的痛

    首先,老规矩,我们在接触新事物的时候, 要对之前学习和了解过的东西做一个总结. 01 痛     苦 不做.不行 之前,前后端分离的系统由前端和后端不同的编写,我们苦逼的后端工程师会把自己已经写完的A ...

  3. Java 常用API (第二部分)

    常用api第二部分 Date 类 import java.util.Date; 时间原点: 1970-01-01 00:00:00(英国格林威治) 中国属于东八区, 会把时间增加 8 个小时: 197 ...

  4. 写api接口神器--带你5分钟了解swagger

    随着互联网技术的发展,现在的网站架构基本都由原来的后端渲染,变成了:前端渲染.先后端分离的形态,而且前端技术和后端技术在各自的道路上越走越远. 前端和后端的唯一联系,变成了API接口:API文档变成了 ...

  5. 有了Swagger2,再也不用为写Api文档头疼了

    1.为什么要写Api文档 现在,前后端分离的开发模式已经非常流行,后端开发工程师只负责完成后端接口,前端页面的开发和渲染完全由前端工程师完成. 问题来了,前端工程师怎么知道后端接口的具体定义呢?答案是 ...

  6. KnockoutJS 3.X API 第二章 数据监控(1)视图模型与监控

    数据监控 KO的三个内置核心功能: 监控(Observable)和依赖性跟踪(dependency tracking) 声明绑定(Declarative bindings) 模板(Templating ...

  7. 01 语言基础+高级:1-5 常用API第二部分_day01.【Object类、常用API: Date类、System类、StringBuilder类】

    day01[Object类.常用API] 主要内容 Object类 Date类 DateFormat类 Calendar类 System类 StringBuilder类 包装类 java.lang.O ...

  8. KnockoutJS 3.X API 第二章 数据监控(2)监控属性数组

    监控属性数组 如果要对一个对象检测和响应变化,会使用监控属性.如果要对一个序列检测并监控变化,需要使用observableArray(监控属性数组).这在你显示或编辑多个值,需要用户界面的部分反复出现 ...

  9. 一步一步学swift之:自己写Api接口-PHP

    想要自己一个人完成app,那么后台接口也必须自己动动手.不用担心,其实很简单的,给自己信心!下面就以登录注册为例,做一个api接口 首先在mac上搭建PHP环境,下载 MAMP Pro for Mac ...

随机推荐

  1. caffe安装编译问题-ImportError: libopencv_core.so.3.4: cannot open shared object file: No such file or directory

    问题描述 >>> import caffe Traceback (most recent call last): File , in <module> File , in ...

  2. iOS7,iOS8和iOS9的区别

    iOS7,iOS8和iOS9的区别:iOS7.0 1.iOS 7是iOS面世以来在用户界面上做出改变最大的一个操作系统.iOS 7抛弃了以往的拟物化设计,而采用了扁平化设计. 苹果在重新思考 iOS ...

  3. 2243: [SDOI2011]染色(LCT)

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 10909  Solved: 4216[Submit][Statu ...

  4. ElasticSearch(十):springboot集成ElasticSearch集群完成数据的增,删,改

    前言 之前介绍了使用devTools进行索引库数据的crud,这里使用的是java程序,使用中间件activeMQ进行数据库和索引库数据的同步.主要是用来完成对数据库的修改来完成对索引库的同步. 正文 ...

  5. Word所有字体按比例缩小

    ctrl + [ 不然每次都要一部分一部分的修改啊

  6. Laravel 服务容器实例教程 —— 深入理解控制反转(IoC)和依赖注入(DI)

    容器,字面上理解就是装东西的东西.常见的变量.对象属性等都可以算是容器.一个容器能够装什么,全部取决于你对该容器的定义.当然,有这样一种容器,它存放的不是文本.数值,而是对象.对象的描述(类.接口)或 ...

  7. Tensorflow & Python3 做神经网络(视频教程)

    Tensorflow 简介 1.1 科普: 人工神经网络 VS 生物神经网络 1.2 什么是神经网络 (Neural Network) 1.3 神经网络 梯度下降 1.4 科普: 神经网络的黑盒不黑 ...

  8. C语言面试题2

    预处理 问题1:什么是预编译?何时需要预编译? 答:预编译又称预处理,是整个编译过程最先做的工作,即程序执行前的一些预处理工作.主要处理#开头的指令.如拷贝#include包含的文件代码.替换#def ...

  9. 常见MQ流行度比较

    MQ的流行度跟它的特性和应用场景密切相关,站在当下来看,kafka最火,rabbitmq用的也很多,ActiveMQ作为经典mq选择用它入门的也不少.

  10. chrome 小技巧:保持元素的hover状态

    审查元素,选中需要hover的标签 点击"Styles"菜单中的":hov",弹出 Force element state 选中相应的 :hover :acti ...