Hallo Freunde des Forums.
Ich beschäftige mich schon eine ganze Weile mit dem gleichzeitigen auslesen von 3 Virtuellen Com ports, die über usb mit dem rechner verbunden sind.
Diese VCP laufen mit Treibern von FTDI.
Ich habe nun nach langem Probieren herausgefunden, dass immer wenn ich mehr als 3 Com´s gleichzeitig auslese die Menge an "Current Bytes on Port" bei zwei von den 3 Com´s kontinuierlich steigt. Das ganze geht dann solange, bis der max Wert von 4096 überschritten wurde und dann beginnt das Programm sich permanent zu verrechnen.
Ich lasse nun nach ca. 12000 Schleifendurchläufen den Puffer bei allen Ports löschen, aber das ist leider nicht die wirklich elegante Lösung. Denn hierbei ist dann in meiner kontinuierlich laufenden Aufzeichnung der gelesenen Werte im Moment des Löschens ein Einbruch (kleine Wertänderung Richtung 0 ) zu sehen.
Kann mir jemand helfen dieses Problem in den Griff zu bekommen?
Vielen Dank schon im Voraus
mit besten Grüßen
Otti
' schrieb:Ich habe nun nach langem Probieren herausgefunden, dass immer wenn ich mehr als 3 Com´s gleichzeitig auslese die Menge an "Current Bytes on Port" bei zwei von den 3 Com´s kontinuierlich steigt.
Das kann genau in dem Fall auftreten, wenn die Verarbeitungeschwindigkeit der empfangenen Daten langsamer ist als das Ankommen der Daten. Also: Wie hoch ist denn die Baudrate der Schnittstellen? Wie sieht denn der Verarbeitungsalgorithmus aus?
Möglichkeiten gibt es bestimmt mehrere: Zwischenpuffern, Programm optimieren.
Also die Baudrate der Schnittstellen ist 38400
Verarbeitet wird das ganze in einer kontinuierlich laufenden Schleife.
Dabei werden die gewonnenen Daten der Schnittstellen an ein Cluster übergeben und in einer weiteren Schleife via lokaler Variable wieder aufgerufen.
Um das vielleicht besser zu veranschaulichen, habe ich das ganze mal als Datei angehangen...
ich hoffe das ist OK
Gruß otti
(VIs LV 8.0)
' schrieb:ich hoffe das ist OK
Das ist ok.
Was nicht OK ist, ist die Formatierung deines Codes. Ich sag nur Styleguide. Was du da geschrieben hast, lässt sich nur schlecht lesen.
Im Prinzip kann ich nichts negatives - außer dem Styleguide - finden. Du kannst ja mal nachrechnen: 38400 bei drei Schnittstellen und 11 Zeichen pro Durchlauf macht eine Millisekunde pro Durchlauf. (38400 => 4 Zeichen pro Millisekunde; 3 Schnittstellen => 4*3=12 pro Millisekunde; Pro Schnittstelle 11 Zeichen => 1 ms pro Durchlauf.) Vorausgesetzt der Datenfluss ist ohne Pause dann ist das alles an der Grenze des Machbaren mit einem PC. Schließlich passiert hier ja mehr als VISA auslesen.
In deinem Falle fällt mir so auf die Schnelle nichts ein, was du mal probieren könntest.
Danke dir für die schnelle Antwort! Freut mich wirklich sehr, dass sich jemand meinem Problem so schnell angenommen hat.
Wie du ja siehst lasse ich meine "lese-Schleife" für die Daten der Schnittstellen auf max Geschwindigkeit laufen. Allerdings reicht das eben auf Dauer nicht und nach einer weile läuft der "Puffer" (denke ich jedenfalls)über und es kommt zu solchen Aussetzern in der Aufzeichnung. (siehe Bild)
Wenn ich die Puffer -im Progam derzeit nach 12000 Schleifen durchläufen- lösche dann gibt es eben immer mal kleine Werteinbrüche(so wie oben beschrieben).
Die Frage ist nun, brauche ich da jetzt einen noch schnelleren Rechner (momentan 3200+AMD Athlon und 1GB RAM)?
Oder kann man da gar nichts wirklch machen...
otti
' schrieb:Die Frage ist nun, brauche ich da jetzt einen noch schnelleren Rechner (momentan 3200+AMD Athlon und 1GB RAM)?
Das möchte ich bezweifeln.
Zitat:Oder kann man da gar nichts wirklch machen
Bestimmt.
Du könntest folgendes probieren: Mach aus der Schleife, die die VISA's ausliest (das ist also die obere), alles raus, was auf das Frontpanel zugreift. Das ist der Cluster, der die Daten anzeigt, und die Variable des Stopp-Buttons. Ersetze die Stopp-Variable durch einen Melder und den Cluster durch eine Queue. In der Hauptschleife setzt du den Melder zum Stoppen und ließt die Queue aus.
Möglicherweise ist die Queue und der Melder schneller als der Cluster und die Variable. Ob dem so ist, weis ich nicht. Das kann dir nur ein richtiger LV-Experte sagen. Schaden tut es aber nichts. Möglicherweise lernst du nämlich was über Queues und Melder.
Und bevor ich es vergesse - denk an den Styleguide.
Vielen Dank für die Tipps, ich werde das morgen mal ausprobieren und melde mich dann einfach noch mal.
Eine Frage noch zum Schluss: Wie meinst du das mit dem styleguide?
Was muss ich da beachten?
Einen schönen Freitagabend, ciao, otti
' schrieb:Wie meinst du das mit dem styleguide?
So was wie
das hier, oder
das hier.
Zurückführende Wires, Wires unnötig lang, 95% leere Fläche erschweren die Lesbarkeit erheblich.
Hallo "IchSelbst",
habe die Sache gelöst!!! Bin total happy...
Ich habe es erst mit der Queue-Sache probiert, aber dass hatte leider überhaupt keinen Effekt auf die Problematik.
Nun habe ich einfach jedes "read" in eine eigene Schleife gesteckt und schreibe die Daten nach wie vor in lokale Variablen, die ich dann in der "Haupt-Schleife" auslese. Ja, und was soll ich sagen -siehe da- es geht... *wahnsinn*
Danke nochmal für deine Unterstützung!!!
Grüße aus Leipzig und ein schönes Wochenende
otti
' schrieb:Hallo "IchSelbst",
habe die Sache gelöst!!! Bin total happy...
Ich habe es erst mit der Queue-Sache probiert, aber dass hatte leider überhaupt keinen Effekt auf die Problematik.
Nun habe ich einfach jedes "read" in eine eigene Schleife gesteckt und schreibe die Daten nach wie vor in lokale Variablen, die ich dann in der "Haupt-Schleife" auslese. Ja, und was soll ich sagen -siehe da- es geht... *wahnsinn*
Danke nochmal für deine Unterstützung!!!
Grüße aus Leipzig und ein schönes Wochenende
otti
Das geht natürlich schon und wohl noch eine ganze Weile auch mit mehr Schnittstellen. Aber!!!!!
Lokale Variablen sind nicht synchornisiert, das will heissen die Read Loop pro Schnittstelle kann ganz einfach 200 mal durchlaufen werden bevor Deine Hauptschlaufe einmal im Stande ist diese lokale Variable zu lesen. Falls das kein Problem für Dich ist dann ist das OK, aber Du solltest das schon wissen.
Dein Instrument könnte ja ein ziemlicher dummer Schreier sein der einfach seine Daten wild hinausschreit ohne jeweils erst ein Kommando zu erwarten und für solche Instrumente ist die von Dir gemachte Entkopplung meist die Beste Sache.
Lokale Variablen können Schlaufen entkoppeln, was prinzipiel gut ist aber man muss darauf achten dass die Schreiboperation völlig asynchron zur Leseoperation läuft das heisst, Du kannst in der Hauptschlaufe entweder 100 mal denselben Wert lesen weil die Leseschlaufe eben viel langsamer ist oder im anderen Extremfall liest Du nur jeden x hundersten Wert der von der Leseschlaufe produziert wird. Falls Du Deine Schlaufen doch irgendwie synchronisieren willst wird es komplizierter.
Rolf Kalbermatter