LabVIEWForum.de - Berechnung mit CLF-Knoten schneller?

LabVIEWForum.de

Normale Version: Berechnung mit CLF-Knoten schneller?
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Hallo,

in dem Buch "Einführung in LabVIEW" aus dem Hanser Verlag wird ein Beispiel zur Einbindung von C++ Code mit Hilfe eines CLF-Knoten beschrieben...und aufgezeigt, dass die Berechnung einer Reihe mit dem C++ Code schneller geht....aber leider keine Antwort darauf gegeben, warum es denn so ist.

Vielleicht könnt ihr mir erklären, warum es mit dem "Fremdcode" schneller geht...

... (VIs LV 6.1)

http://www.hs-weingarten.de/~georgi/Lehrbu...ReiheOhneCLF.vi

und mit CLF und der dazugehörigen dll-Datei zur Berechnung...

http://www.hs-weingarten.de/~georgi/Lehrbu...-ReiheMitCLF.vi

http://www.hs-weingarten.de/~georgi/Lehrbu...5/src/Reihe.dll

Quellcodeauszug:

#include stdafx.h

....

double WINAPI summieren(long n)
{ double s=0.0;
long=k;
for(k=1;k<=n;k++)
s+=1.0/(k*k);
return (s);
}



thx...
Hallo,

aus meiner Sicht mehrere Gründe:

1. Der C-Code berechnet das Produkt k*k bestimmt erst mal mit Integer-Operationen. Im reinen LV-Code wird vor der Quadrierung nach DBL gewandelt. Wenn man das ändert, holt man übrigens ein wenig Geschwindigkeit aus dem Bsp raus:
[attachment=10808]

2. Der Vergleich ist etwas unfair. Im Bsp mit DLL liegt die Berechnung ja schon im (puren) Maschinencode vor, und ich gehe mal davon aus, dass bei so einem einfachen Bsp ein C-Compiler bestimmt auch einen guten Code erzeugen kann. In reinen LV-Bsp "schleppst" du halt immer noch die ganze LV-Umgebung mit.

Fazit: Ein fairer Vergleich sollte zwischen 2 Exe-Dateien erfolgen, und das habe ich auch mal schnell gemacht: Und siehe da, beide exe sind praktisch gleich schnell...

Das Archiv enthält die Beiden Exe-Dateien, erstellt mit LV 8.21, es ist also ein Runtime-Engine V8.2 oder 8.21 zur Ausführung erforderlich.
[attachment=10809]

MfG, Jens
Tu mal einer das Eingabeelement aus der inneren Schleife raus und schau sich dann das ergebnis an: 0.000 Sekunden mit und ohne DLL. Bei einem modernen Prozessor muss man schon 1Mio Durchläufe machen um was zu sehen. Nicht, dass der Overhead wie DLL-Aufruf etc größer ist als die For-Schleife.
alles klar ...danke ...mit den exe-Dateien stelle ich auch (fast) keinen Unterschied mehr fest....das hätten sie ja auch irgendwie mal ins Buch reinschreiben können, da wird groß angekündigt, dass es mit der Einbindung des C++-Codes schneller geht ...aber dann kein weiterer Satz warum oder weshalb....nicht so tragitsch aber schön wäre es gewesen ^^...

mfg
' schrieb:alles klar ...danke ...mit den exe-Dateien stelle ich auch (fast) keinen Unterschied mehr fest....das hätten sie ja auch irgendwie mal ins Buch reinschreiben können, da wird groß angekündigt, dass es mit der Einbindung des C++-Codes schneller geht ...aber dann kein weiterer Satz warum oder weshalb....nicht so tragitsch aber schön wäre es gewesen ^^...

mfg

LabVIEW selber ist auch ein Compiler. Das was Du im Diagramm zeichnest wird direkt in Maschinencode umgesetzt und dann ausgeführt. In diesem Licht sind die meisten Claims dass LabVIEW prinzipiel langsamer ist als C absolut nicht wahr.
Aber in C kannst Du denn Compiler anweisen um hoch-optimalisierten Code zu erzeugen, LabVIEW optimalisiert auch aber hat durch die Datenfluss-Programmierung ganz andere Bedürfnisse in gewissen Gebieten. Ein C Compiler kann ganz einfach davon ausgehen dass der Code immer linear abläuft und dass wenn etwas parallel ausgeführt werden kann der C Programmierer schon damit Rechnung hält und wenn nicht dann ist es halt Pech gewesen und das Programm schmiert ab oder produziert falsche Ergebnisse.

LabVIEW hat durch die Datenflussprogrammierung inherent parallele Ausführung eingebaut und muss damit zu jedem Zeitpunk Rechnung tragen (und tut das auch extrem gut). Das hat aber auch zur Folge, dass nicht jede Optimalisierung die ein C Compiler durchführen kann für LabVIEW legitim ist. Und manchmal muss LabVIEW sogar extra Code einfügen um Kollisionen von ausführemdem Code zu verhindern. Das kann dazu führen dass der LabVIEW Code langsamer abläuft dann der durch einen hoch optimalisierten C Compiler erzeugten Code. Aber hier sprechen wir in den meisten Fällen über Prozente der Ausführungszeit nicht über Faktoren.

Wo es oftmals falsch geht in LabVIEW ist nicht im erzeugten Code selber, aber in der Verwendung eines suboptimalen Algorithmus im LabVIEW Diagramm oder einer suboptimalen Implementation eines Algorithmus. In C muss sich der Programmierer selber um jedes Byte kümmern dass im Speicher angelegt, verschoben und wieder freigegeben wird. In LabVIEW tut man überhaupt nichts dergleichen. LabVIEW alloziert und realloziert Speicher wann immer das nötig ist für uns. Und Speicherallozierung und Kopieren ist eine sehr langsame Operation im Verhältnis zu anderen Dingen. Wenn also jetzt jemand einen Algorithmus schreibt in dem er in einer Schlaufe mit BuildArray in jedem Durchlauf ein oder mehrere Elemente an das im Schieberegister gehaltene Array anfügt, wird in jedem Schleifendruchlauf dieses Array vergrössert, was fast immer mit einer Neuallokation mit anschliessendem Kopieren der Daten im Speicher und Deallozieren des alten Arrays verbunden ist. So ein Algorithmus ist EXTREM langsam, nicht weil LabVIEW schlechten Code erzeugt, sondern weil der Programmierer schlecht programmiert hat.
Das Problem ist hier eigentlich dass Programmieren in LabVIEW fast zu einfach ist. Man kann ohne überhaupt etwas von Programmierung zu verstehen immer noch ein Programm schreiben das mehr oder weniger das zu tun scheint (mit Nachdruck auf dem scheint) was man eigentlich wollte, auch wenn die Art und Weise wie das getan wird eigentlich katastrophal zu nennen ist.

Rolf Kalbermatter
Referenz-URLs