Ich habe einen fein abgestimmten Algorithmus in MATLAB, der auf Matrizen (natürlich) arbeitet. Ich habe Matlab-Codierer verwendet, um c-Code für diesen Algorithmus zu generieren, und es funktioniert wie erwartet.Mit Matlab Coder generierten Algorithmus für die Produktion
Hier ist ein Funktionsaufruf, die ich in Matlab
x = B/A
wobei
- B der Größe 1 * 500 verwendet (Zeilen * Spalten)
- A mit einer Größe von 10 * 500
- x, das Ergebnis ist von Größe 1 * 10
Wenn dies mit Matlab Coder in C-Quelle konvertiert wird. Ich habe festgestellt, dass die Funktionsdefinition Parameter akzeptiert, die den obigen Größen entsprechen.
void myfunction(const double B[500], const double A[5000], double x[10])
Für Prototypen und Testzwecke scheint dies in Ordnung. In der Produktion bevorzuge ich jedoch, diese Funktion auch für andere Größen zu verwenden. Zum Beispiel sollte 100 anstelle von 500 in den oben genannten Variablen auch funktionieren. Wie kann ich die Abhängigkeit von Matrixdimensionen in meinem Algorithmus entfernen?
Darüber hinaus gibt es einige Codezeilen, die hartcodierte Ganzzahlen verwenden. Zum Beispiel ist es Code wie
if (rankR <= 1.4903363393874656E-8)
// Some internal function calls
else
// Usage of standard sqrt
oder
500.0 * fabs(A[0]) * 2.2204460492503131E-16
Könnte jemand erklären, was sind diese hart codiert ganze Zahlen? Werden diese aus den Testdaten generiert, die ich in MATLAB verwendet habe?