• Opencv矩阵操作


    分配矩阵空间:

    CvMat* cvCreateMat(int rows, int cols, int type);

    释放矩阵空间:

    cvReleaseMat(&M);

    数据类型宏定义:

    CV_<bit_depth>(S|U|F)C<number_of_channels>

    复制矩阵

    CvMat* M2;    M2=cvCloneMat(M1);

    初始化矩阵:

    double a[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12 };

    要么

    CvMat Ma=cvMat(3, 4, CV_64FC1, a); 

    或者

    CvMat Ma;

    cvInitMatHeader(&Ma, 3, 4, CV_64FC1, a);

    int main (int argc, char **argv)
    {
        CvMat *m = cvCreateMat(2,2, CV_32FC1);
        CvMat *n = cvCreateMatHeader(2,2, CV_32FC1);
        double t[2] = {1,2};
        cvInitMatHeader(n, 2,2, CV_32FC1,t);
        cvMatMul(m, n, m);
    
        return 0;
    }

    间接存取矩阵元素:

    cvmSet(M,i,j,2.0);

    t = cvmGet(M,i,j);

    直接存取,校正字节任意:

    CvMat* M = cvCreateMat(4,4,CV_32FC1);

    int step = M->step/sizeof(float);

    float *data = M->data.fl;

    (data+i*step)[j] = 3.0;

    矩阵间的运算:

    CvMat *Ma, *Mb, *Mc;
    cvAdd(Ma, Mb, Mc); // Ma+Mb -> Mc
    cvSub(Ma, Mb, Mc); // Ma-Mb -> Mc
    cvMatMul(Ma, Mb, Mc); // Ma*Mb -> Mc

    矩阵元素间的运算

    CvMat *Ma, *Mb, *Mc;
    cvMul(Ma, Mb, Mc); // Ma.*Mb -> Mc
    cvDiv(Ma, Mb, Mc); // Ma./Mb -> Mc
    cvAddS(Ma, cvScalar(-10.0), Mc); // Ma.-10 -> Mc

    单矩阵操作:

    CvMat *Ma, *Mb;
    cvTranspose(Ma, Mb); // transpose(Ma) -> Mb (不能对自身进行转置)
    CvScalar t = cvTrace(Ma); // trace(Ma) -> t.val[0]
    double d = cvDet(Ma); // det(Ma) -> d
    cvInvert(Ma, Mb); // inv(Ma) -> Mb

    向量乘积:

    double va[] = {1, 2, 3};
    double vb[] = {0, 0, 1};
    double vc[3];
    CvMat Va=cvMat(3, 1, CV_64FC1, va);
    CvMat Vb=cvMat(3, 1, CV_64FC1, vb);
    CvMat Vc=cvMat(3, 1, CV_64FC1, vc); 
    double res=cvDotProduct(&Va,&Vb); // 点乘:Va . Vb -> res
    cvCrossProduct(&Va, &Vb, &Vc); // 向量积: Va x Vb -> Vcend{verbatim}

    -----

    “未曾清贫难成人
    不经打击老天真
    自古英雄出炼狱
    从来富贵入凡尘”

  • 相关阅读:
    iOS之MRC和ARC
    给tableView的cell上加长按转发,复制、、等功能
    时间格式相关
    Xcode7,消失的pin菜单(Editor->pin)
    UIView常用的一些方法小记之setNeedsDisplay和setNeedsLayout
    监听iPhone的通话状态之---CoreTelephony.framework
    iOS中一些系统通知名字集合
    iOS中的程序的五种状态
    Objective-C基础之@synthesize, @dynamic
    Objective-C基础之category extension
  • 原文地址:https://www.cnblogs.com/sunniflyer/p/4473352.html
Copyright © 2020-2023  润新知