zoukankan      html  css  js  c++  java
  • 《学习opencv》笔记——矩阵和图像操作——cvAbs,cvAbsDiff and cvAbsDiffS

    矩阵和图像的操作


    (1)cvAbs,cvAbsdiff,cvAbsDiffS

    它们的结构为:

    void cvAbs(  //取src中元素的绝对值,写到dst中
      const CvArr* src,
      const dst
    );
    
    void cvAbsDiff( //src1减去src2的差的绝对值存入dst
      const CvArr* src1,
      const CvArr* src2,
      const dst
    );
    
    void cvAbsDiffs( //src中每一个元素减去value存入dst中
      const CvArr* src,
      CvScalar value,
      const dst
    _;


    使用实例代码:


    #include <cv.h>
    #include <highgui.h>
    #include <cxcore.h>
    #include <iostream>
    using namespace std;
    int main( int argc, char** argv ){
    	CvMat *mat;
    	mat=cvCreateMat(4,4,CV_32FC1);
    
    	float value = 0.0;
    	int i = 0, j = 0;
    	cout<<"初始化原始数组"<<endl;
    	for ( i = 0; i < 4; i ++ ){
    		for( j = 0; j < 4; j ++ ){
    
    			value -= 1.0;
    			CV_MAT_ELEM( *mat, float, i, j) = value;		
    		}
    	}
    	for ( i = 0; i < 4; i ++ ){
    		for( j = 0; j < 4; j ++ ){
    
    			cout<<"	"<<CV_MAT_ELEM( *mat, float, i, j);		
    		}
    		cout<<endl;
    	}
    	CvMat *matDes;
    
    	matDes=cvCreateMat(4,4,CV_32FC1); 
    
    	cout<<"目标矩阵"<<endl;
    	for ( i = 0; i < 4; i ++ ){
    		for( j = 0; j < 4; j ++ ){
    			cvmSet( matDes, i, j,0);
    			cout<<"	"<<CV_MAT_ELEM( *matDes, float, i, j);		
    		}
    
    		cout<<endl;
    	}
    
    	cvAbs( mat, matDes );
    	cout<<"数组的绝对值"<<endl;
    	for ( i = 0; i < 4; i ++ ){
    		for( j = 0; j < 4; j ++ ){
    
    			cout<<"	"<<CV_MAT_ELEM( *matDes, float, i, j);		
    		}
    
    		cout<<endl;
    	}
    
    	CvMat *matDiff1 = cvCreateMat(4,4,CV_32FC1);
    
    	cvAbsDiff( mat,matDes , matDiff1);
    	cout<<"两个差的绝对值"<<endl;
    	for ( i = 0; i < 4; i ++ ){
    		for( j = 0; j < 4; j ++ ){
    
    			cout<<"	"<<CV_MAT_ELEM( *matDiff1, float, i, j);		
    		}
    
    		cout<<endl;
    	}
    
    	CvScalar cs;
    	cs.val[0] = 2.0;
    	cs.val[1] = 1.0;
    
    	cvAbsDiffS( mat, matDiff1,cs);
    	cout<<"矩阵减去标准值的绝对值"<<endl;
    	for ( i = 0; i < 4; i ++ ){
    		for( j = 0; j < 4; j ++ ){
    
    			cout<<"	"<<CV_MAT_ELEM( *matDiff1, float, i, j);		
    		}
    
    		cout<<endl;
    	}
    	cvReleaseMat( &mat );
    	cvReleaseMat( &matDes );
    	getchar();
    	return 0;
    }


    输出结果:




       to be continued

  • 相关阅读:
    字符编码
    visual studio 2015 安装记录和问题修复
    TCP状态转换图的理解
    静态库与动态库的编译链接
    运行库glibc
    堆栈的简单认识
    Makefile学习总结
    关于STM32单片机的IAP实现
    ubuntu12.0.4安装启动后无法进入图形操作界面
    观察者模式
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/3770931.html
Copyright © 2011-2022 走看看