我正在Windows中使用TDM gcc 64位编译器
我的标题
#include "lapacke.h"
#include "lapacke_config.h"
我有一个像这样的简单代码
lapack_complex_double x = {8.0, 6.0};
printf( "x = (%6.2f,%6.2f)\n", x.real, x.imag);
首先,它给我以下错误和警告
warning: excess elements in scalar initializer
lapack_complex_double x = {8.0, 6.0};
&
error: request for member 'real' in something, not a structure or union
printf( "x = (%6.2f,%6.2f)\n", x.real, x.imag);
我将代码更改如下
lapack_complex_double x = {8.0, 6.0};
printf( "x = (%6.2f,%6.2f)\n", lapack_complex_double_real(x),
lapack_complex_double_imag(x) );
使用相同的警告编译代码,但结果是
x = ( 8.00, 0.00)
警告似乎是一个重要错误。
答案 0 :(得分:0)
您说对了,警告是一个重要错误,它告诉您,这不是您使用lapacke库初始化复杂类型的方式。您需要使用:
x = lapack_make_complex_float(8.0, 6.0);
请参阅此问题中的示例。这样应该可以为您工作。