首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >显示包含复数的cvMatrix (CV_64FC2)

显示包含复数的cvMatrix (CV_64FC2)
EN

Stack Overflow用户
提问于 2010-01-12 11:41:04
回答 2查看 3.5K关注 0票数 4

我是OpenCV新手,我想将python程序的结果与我在OpenCV中的计算结果进行比较。我的矩阵包含复数,因为它是cvDFT的结果。Python可以很好地处理复数,并用科学记数法显示它。我的C++程序在尝试使用std::cout时无效。

我试图将我的numbers数组存储在std::complex[]中,而不是double[]中,但是它不能编译。

下面是我的代码,以及它的结果:

代码语言:javascript
运行
AI代码解释
复制
    CvMat *dft_A;

    dft_A = cvCreateMat(5, 5, CV_64FC2); // complex matrix
    double a[] = {
        0, 0, 0, 0, 0,
            1, 1, 1, 1, 1,
            2, 2, 2, 2, 2,
            3, 3, 3, 3, 3,
            4, 4, 4, 4, 4
           };
    dft_A->data.db = a;
    std::cout << "before : " << a[0] << std::endl;
    cvDFT( dft_A, dft_A, CV_DXT_FORWARD);  // DFT !
    std::cout << "after : " << a[0] << std::endl;


        >> before : 0

以下是python中的相同内容,输出如下:

代码语言:javascript
运行
AI代码解释
复制
>>> a = np.mgrid[:5, :5][0]
>>> a
array([[0, 0, 0, 0, 0],
       [1, 1, 1, 1, 1],
       [2, 2, 2, 2, 2],
       [3, 3, 3, 3, 3],
       [4, 4, 4, 4, 4]])
>>> np.fft.fft2(a)
array([[ 50.0 +0.j        ,   0.0 +0.j        ,   0.0 +0.j        ,
          0.0 +0.j        ,   0.0 +0.j        ],
       [-12.5+17.20477401j,   0.0 +0.j        ,   0.0 +0.j        ,
          0.0 +0.j        ,   0.0 +0.j        ],
       [-12.5 +4.0614962j ,   0.0 +0.j        ,   0.0 +0.j        ,
          0.0 +0.j        ,   0.0 +0.j        ],
       [-12.5 -4.0614962j ,   0.0 +0.j        ,   0.0 +0.j        ,
          0.0 +0.j        ,   0.0 +0.j        ],
       [-12.5-17.20477401j,   0.0 +0.j        ,   0.0 +0.j        ,
          0.0 +0.j        ,   0.0 +0.j        ]])
>>>

问题显然来自第二个cout,它对date类型(复数的CV_64FC2)的效率很低。

我的问题是:我如何转储结果,以便我可以检查我的python代码是否与我的cpp/opencv代码执行相同的操作?

谢谢!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-02-14 18:13:58

在OpenCV 2.0代码中有一个dft示例,我现在也在研究它。这里有一个拷贝粘贴给你,它可能会给你一个想法。正如您所看到的,它使用cvSplit将其扩展为实部和虚部。希望这能有所帮助:

代码语言:javascript
运行
AI代码解释
复制
im = cvLoadImage( filename, CV_LOAD_IMAGE_GRAYSCALE );
if( !im )
    return -1;

realInput = cvCreateImage( cvGetSize(im), IPL_DEPTH_64F, 1);
imaginaryInput = cvCreateImage( cvGetSize(im), IPL_DEPTH_64F, 1);
complexInput = cvCreateImage( cvGetSize(im), IPL_DEPTH_64F, 2);

cvScale(im, realInput, 1.0, 0.0);
cvZero(imaginaryInput);
cvMerge(realInput, imaginaryInput, NULL, NULL, complexInput);

dft_M = cvGetOptimalDFTSize( im->height - 1 );
dft_N = cvGetOptimalDFTSize( im->width - 1 );

dft_A = cvCreateMat( dft_M, dft_N, CV_64FC2 );
image_Re = cvCreateImage( cvSize(dft_N, dft_M), IPL_DEPTH_64F, 1);
image_Im = cvCreateImage( cvSize(dft_N, dft_M), IPL_DEPTH_64F, 1);

// copy A to dft_A and pad dft_A with zeros
cvGetSubRect( dft_A, &tmp, cvRect(0,0, im->width, im->height));
cvCopy( complexInput, &tmp, NULL );
if( dft_A->cols > im->width )
{
    cvGetSubRect( dft_A, &tmp, cvRect(im->width,0, dft_A->cols - im->width, im->height));
    cvZero( &tmp );
}

// no need to pad bottom part of dft_A with zeros because of
// use nonzero_rows parameter in cvDFT() call below

cvDFT( dft_A, dft_A, CV_DXT_FORWARD, complexInput->height );

cvNamedWindow("win", 0);
cvNamedWindow("magnitude", 0);
cvShowImage("win", im);

// Split Fourier in real and imaginary parts
cvSplit( dft_A, image_Re, image_Im, 0, 0 );

// Compute the magnitude of the spectrum Mag = sqrt(Re^2 + Im^2)
cvPow( image_Re, image_Re, 2.0);
cvPow( image_Im, image_Im, 2.0);
cvAdd( image_Re, image_Im, image_Re, NULL);
cvPow( image_Re, image_Re, 0.5 );

// Compute log(1 + Mag)
cvAddS( image_Re, cvScalarAll(1.0), image_Re, NULL ); // 1 + Mag
cvLog( image_Re, image_Re ); // log(1 + Mag)
票数 4
EN

Stack Overflow用户

发布于 2010-01-22 16:19:46

你有没有尝试过OpenCV的python绑定?http://www.exothermia.net/monkeys_and_robots/2009/12/11/working-opencv-python-bindings/

通过绑定,您可以从python中调用OpenCV函数,并将结果作为numpy数组,然后将它们与纯python代码中的结果进行比较。通过一些修补,您可以包装自己的C代码,并使其在python中也可用。

但是如果你只想转储数据,你可以将真实的和虚构的部分保存为图像并在python中读取它们(我对OpenCV不是很熟悉,你必须检查它对浮动图像的支持-以及python的支持)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2048577

复制
相关文章
matlab插值函数的作用,matlab 插值函数[通俗易懂]
MATLAB中的插值函数为interp1,其调用格式为: yi= interp1(x,y,xi,’method’)
全栈程序员站长
2022/09/05
1.4K0
matlab fprintf函数_matlab绝对值函数
按指定的格式将变量的值输出到屏幕或指定文件,fid为文件句柄,若缺省,则输出到屏幕
全栈程序员站长
2022/11/02
1K0
matlab fprintf函数_matlab绝对值函数
matlab 稀疏矩阵 乘法,Matlab 矩阵运算[通俗易懂]
说明:这一段时间用Matlab做了LDPC码的性能仿真,过程中涉及了大量的矩阵运算,本文记录了Matlab中矩阵的相关知识,特别的说明了稀疏矩阵和有限域中的矩阵。Matlab的运算是在矩阵意义下进行的,这里所提到的是狭义上的矩阵,即通常意义上的矩阵。
全栈程序员站长
2022/09/12
3.1K0
matlab的fprintf语句_matlab绝对值函数
2、用法说明: fprintf(fid, format, variables); 按指定的格式将变量的值输出到屏幕或指定文件;
全栈程序员站长
2022/11/02
1K0
【MATLAB】数据类型 ( 矩阵 | 随机数函数 | 生成矩阵 )
作用 : 生成 标准正态分布的 伪随机数 ; 标准正态分布指的是均值 0 , 方差 1 ;
韩曙亮
2023/03/29
9240
【MATLAB】数据类型 ( 矩阵 | 随机数函数 | 生成矩阵 )
matlab输出矩阵格式_matlab中uint8函数用法
1、uint8与double double函数只是将读入图像的uint8数据转换为double类型,一般不使用;常用的是im2double函数,将 uint8图像转为double类型,范围为0-1,如果是255的图像,那么255转为1,0还是0,中间的做相应改变。 MATLAB中读入图像的数据类型是uint8,而在矩阵中使用的数据类型是double。因此 I2=im2double(I1) :把图像数组I1转换成double精度类型;如果不转换,在对uint8进行加减时会产生 溢出。默认情况下,matlab将图象中的数据存储为double型,即64位浮点数;matlab还支持无符号整型 (uint8和uint16);uint型的优势在于节省空间,涉及运算时要转换成double型。 im2double():将图象数组转换成double精度类型 im2uint8():将图象数组转换成unit8类型 im2uint16():将图象数组转换成unit16类型 2、uint8和im2uint8 在数据类型转换时候uint8和im2uint8的区别,uint8的操作仅仅是将一个double类型的小数点后面的部 分去掉;但是im2uint8是将输入中所有小于0的数设置为0,而将输入中所有大于1的数值设置为255,再将所 有其他值乘以255。 图像数据在计算前需要转换为double,以保证精度;很多矩阵数据也都是double的。要想显示其,必须先 转换为图像的标准数据格式。如果转换前的数据符合图像数据标准(比如如果是double则要位于0~1之间) ,那么可以直接使用im2uint8。如果转换前的数据分布不合规律,则使用uint8,将其自动切割至0~255( 超过255的按255)。最好使用mat2gray,将一个矩阵转化为灰度图像的数据格式(double) 3、double类型图像的显示 图像数据在进行计算前要转化为double类型的,这样可以保证图像数据运算的精度。很多矩阵的很多矩 阵数据也都是double的,要想显示其,必须先转换为图像的标准数据格式。如果直接运行imshow(I),我们会 发现显示的是一个白色的图像。这是因为imshow()显示图像时对double型是认为在0~1范围内,即大于1时都 是显示为白色,而imshow显示uint8型时是0~255范围。而经过运算的范围在0-255之间的double型数据就被 不正常得显示为白色图像了。具体方法有: imshow(I/256); ———-将图像矩阵转化到0-1之间 imshow(I,[]); ———-自动调整数据的范围以便于显示 (注意这里,必须是灰度图,否 则不行) imshow(uint8(I)); imshow(mat2gray(I)); 上面的mat2gray是将最终获得的矩阵转化为灰度图像。常用的为: A = im2uint8(mat2gray(result)) 这样就将result矩阵转化为uint8类型的图像。
全栈程序员站长
2022/09/30
2.8K0
MATLAB插值函数interp1
插值法又称“内插法”,是利用函数f (x)在某区间中已知的若干点的函数值,作出适当的特定函数,在区间的其他点上用这特定函数的值作为函数f (x)的近似值,这种方法称为插值法。如果这特定函数是多项式,就称它为插值多项式。
全栈程序员站长
2022/07/01
6550
MATLAB插值函数interp1
矩阵组合matlab,matlab中矩阵的所有组合[通俗易懂]
X = perms(1:N); % # Permuations of column indices
全栈程序员站长
2022/08/01
1.4K0
MATLAB 矩阵分块函数 mat2cell 及 cellfun 函数
该文介绍了MATLAB中矩阵分块函数和cellfun函数在项目中的应用。首先介绍了mat2cell函数的用法,该函数可以将矩阵划分成不同的块,并可以指定每个块的维度。然后介绍了cellfun函数的用法,该函数可以对每个块进行相同的操作,例如求和、求均值等。最后通过一个例子说明了如何使用mat2cell和cellfun函数,将一个10*5的矩阵划分成不同的块,并求出每个块的所有元素之和。
Alan Lee
2018/01/02
4.5K0
MATLAB 矩阵分块函数 mat2cell 及 cellfun 函数
【MATLAB】矩阵操作 ( 矩阵构造 | 矩阵运算 )
设置一个已经给定的矩阵的行列重复次数 , 根据给定的矩阵 , 进行指定的重复 , 生成新矩阵 ;
韩曙亮
2023/03/29
1.3K0
【MATLAB】矩阵操作 ( 矩阵构造 | 矩阵运算 )
MATLAB矩阵运算
MATLAB以矩阵作为数据操作的基本单位,这使得矩阵运算变得非常简捷、方便、高效。矩阵是由m×n个数av (i=1,2,…,m; j = 1,2,…,n)排成的m行n列数表,记成:
全栈程序员站长
2022/09/12
1.2K0
MATLAB矩阵运算
matlab矩阵拼接
3 4 3 4]
全栈程序员站长
2022/09/12
1.9K0
MATLAB矩阵生成
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/153010.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/12
8290
matlab 矩阵除法
Matlab提供了两种除法运算:左除(/)和右除(/)。 一般情况下,x=a/b是方程a*x =b的解,而x=b/a是方程x*a=b的解。 例:a=[1 2 3; 4 2 6; 7 4 9] b=[4; 1; 2]; x=a/b 则显示:x= -1.5000 2.0000 0.5000 如果a为非奇异矩阵,则a/b和b/a可通过a的逆矩阵与b阵得到: a/b = inv(a)*b b/a = b*inv(a)
全栈程序员站长
2022/09/07
1.6K0
Matlab矩阵大全
(1)将二维矩阵A转化成一维矩阵(列向量):Matlab 默认将其转化成列向量,需要行向量转置即可。
全栈程序员站长
2022/09/12
1.2K0
Matlab矩阵大全
如何在matlab矩阵中随机生成圆【含源代码】
言归正传,巴山在浏览知乎时邀请我回答上图所示的问题,所幸就点进去看了一眼,并给了解题思路。
巴山学长
2021/03/30
2.1K0
如何在matlab矩阵中随机生成圆【含源代码】
字符串矩阵 matlab(matlab 字符串矩阵)
这里字符串矩阵(或者有更标准的名称?)是指一个矩阵中的每个元素为长短不一的字符串,如:
全栈程序员站长
2022/08/01
3.7K0
MATLAB(2)–MATLAB矩阵的表示
利用直接输入法建立矩阵:将矩阵的元素用中括号括起来,按矩阵的顺序输入各元素,同一行的各元素之间用逗号或者空格分隔,不同的元素之间用分号分隔。
全栈程序员站长
2022/09/12
1.2K0
MATLAB(2)–MATLAB矩阵的表示
matlab矩阵求逆矩阵非方阵_matlab验证逆矩阵出问题
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/168305.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/20
7470
matlab矩阵求逆矩阵非方阵_matlab验证逆矩阵出问题
如何在矩阵的行上显示“其他”【2】
这个显示结果虽然达到了基础的目的,但并不是很理想。很明显,我们想的是让others在最后一行:
陈学谦
2021/11/15
1.7K0

相似问题

如何外推旋转矩阵值?

16

外推热矩阵中的封顶值

112

Matlab外推符号翻转

12

Matlab interp2外推

23

如何在Matlab中指定矩阵的子矩阵外?

20
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档