2017-07-02 2 views
0

Ich habe versucht, ein Mat-Objekt in OpenCV mit einem 2D-Float-Array zu initialisieren. Ich setze den Datentyp des Mat als CV_64FC1 und drucke dann den Mat aus. Das Ausdruckergebnis unterscheidet sich vom Initialisierungs-2D-Array.CV_32FC1 zu CV_64FC1 ändern Ergebnis falsche Datenkonvertierung

void testConversion() 
{ float data[10][2] = 
{ 
    {2.5, 2.4}, 
    {0.5, 0.7}, 
    {2.2, 2.9}, 
    {1.9, 2.2}, 
    {3.1, 3.0}, 
    {2.3, 2.7}, 
    {2,  1.6}, 
    {1,  1.1}, 
    {1.5, 1.6}, 
    {1.1, 0.9} 
}; 


    Mat 
    mData(10,2,CV_64FC1,&data); 
    cout<<"mData\n"<< mData <<endl; 

    return; 
} 

Das Ergebnis ausdrucken Anzeige als:

[6.400002481415868, 0.0002929687607320375; 
25.60000992119312, 3.600000857934356; 
32.00000766217708, 14.40000343546271; 
0.2250000536441803, 0.01406250333820935; 
0.225000053527765, 0.002734374717329047; 
2.541574442831658e-173, 1.956130224762901e-304; 
2.779084519612415e-308, 7.165336730703368e-317; 
1.#QNAN, -9.255963134931783e+061; 
-9.255963134931783e+061, -9.255963134931783e+061; 
-9.255963134931783e+061, -9.255963134931783e+061] 

Es funktioniert nur, wenn ich

Mat 
mData(10,2,CV_64FC1,&data); 

zu

Mat 
mData(10,2,CV_32FC1,&data); 

jemand ändern könnte erklärt, warum? Danke im Voraus.

Antwort

1

Der Grund für Ihr Problem ist eine Diskrepanz zwischen dem Typ Ihres Arrays (Float) und dem OpenCV-Typparameter CV_64FC1.

Der Parameter CV_64FC1 legt fest, dass das Datenarray als ein Array von Doubles (64 Bits pro Wert) behandelt werden soll.

Ihr Array hat jedoch einen Float-Typ mit 32 Bit pro Wert. Daher ist die Verwendung von CV_32FC1 in diesem Fall die richtige Verwendung.