LabVIEWForum.de - Timingprobleme bei RS-232 Auslesung

LabVIEWForum.de

Normale Version: Timingprobleme bei RS-232 Auslesung
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Hallo,

ich hab folgendes Problem.
Ich verarbeite Daten auf einem board (Spartan 3E) und gebe mir die verarbeiten Werte aus einem AD-Wandler über die RS-232-Schnittstelle wieder raus.
Ich wandle auf dem Board U16 in ASCII um und sende die dAten über RS232.Es werden 5 WErte und ein Steuerzeichen(&) gesendet pro Übertragung.
Die Bitweiseübertragung wird 6x durchgeführt.Die Wartefunktionen sind darauf ausgelegt,die Daten mit 115200 Baut auszugeben.
Um zu testen,ob die kontinuierliche Übergabe der Daten funktioniert, habe ich die Daten,die über den Rs232 rausgeschmissen werden mir auf dem Computer über Tera Term anzeigen lassen.Das funktioniert sehr gut und in sehr guter GEschwindigkeit.Jetzt wollte ich mir ein VI basteln,mit dem man die Daten von der Rs232 Schnittstele auslesen kann und graphosch darstellen.Habe das Programm aus der Labviewhilfe genommen und ein bißchen modifiziert.Leider kommt eine Fehlermeldung.Es sieht so aus,als ob die Timmings nicht stimmen würden.Denn anstatt das die Strings so "01234&" aussehen,sehen die Strings teilweise so 01&34 aus.Wie stellt man die Timmings am besten auf dem Host_Vi?Meine zweitefrage wäre,wie kann mand as Steuerzeichen wieder rausnehmen?Hääte jetzt einfach durch 10 gerechnet und den REst abegschnitten.Dann kommt ja eine Zahl heraus,die man sich durch einen Graphen anzeigen lassen kann.

http://www.labviewforum.de/index.php?showtopic=18556
LV Version 2009
Hallo Frank,

mit etwas besserer Rechtschreibung hätte man deinen Beitrag auch sehr viel leichter lesen können...

Zitat:Habe das Programm aus der Labviewhilfe genommen und ein bißchen modifiziert.
Ja, und was wurde modifiziert? Vielleicht liegt's ja daran - also: VI anhängen.

Zitat:Es sieht so aus,als ob die Timmings nicht stimmen würden.
Welche Timings? Baudrate, Stop-Bit, DataBits, etc korrekt gesetzt?

Zitat:wie kann mand as Steuerzeichen wieder rausnehmen?
Wenn du es als EndOfTransmission-Zeichen gesetzt hättest, bekämst du es erst gar nicht geliefert. So: StringSubset oder ScanFromString benutzen...

Zitat:Hääte jetzt einfach durch 10 gerechnet und den REst abegschnitten
???
Hier ist das Vi mit den eingestellten GRößen.
Hallo Frank,

eine kurze Wartezeit wäre nicht schlecht, um den Port nicht im Microsekundentakt abzufragen...
Und üblicherweise sammelt man die Daten im String an, statt sie immer wieder zu überschreiben! (Das war im Example sicherlich mit drin gewesen...)

Wenn man ein EOT-Zeichen vorgibt, braucht man die Abfrage der BytesAtPort nicht, dann reicht ein genügend großes Timeout aus!
Okay,das mit der Wartefunktion klappt sehr gut.
Wie kann ich die Strings am besten in einen Buffer reinschreiben?Mit welcher Funktion?
Habe mir einen Anzeigefkt. gebastelt und eine Konvertierung von Strin to dez.
Leider gebe ich einen Sinus drauf,aber sehe leider keinen.
Bild ist angehängt.
Hallo Frank,

das Delay gehört in die Schleife, es sei denn, du verwendest ein CR als EOT (was anderes hast du ja beim SerialInit nicht vorgegeben!).

Hast du dir das Beispiel zum Lesen vom seriellen Port mal angeschaut? Da wird der String in einem Shiftregister gesammelt. Und das nicht ohne Grund: in deinem VI liest du so schnell wie möglich vom Port - und das bedeutet (Einzel-)Byte-weise! Da wirst du nie vernünftige Werte erhalten, solange du den String nicht korrekt einsammelst. Also: Example genau studieren!
Als Sonderzeichen oder Trennzeichen habe ich ein Linefeed genommen.(Bsp.: 01234 12897 00234)
Ich bekomme eine Fehlermeldung,die ich nicht deuten kann...Siehe Bild.
Hängt das damit zusammen,das ich die Strings überschreibe?
Die graphische Ausgabe ist gut,aber leider hat der Sinus in regelmäßigen Intervallen kurzfristige Zacken oder Einbrüche.
Hallo Frank,

Zitat:Ich bekomme eine Fehlermeldung,die ich nicht deuten kann
Wenn ich mir diesen Fehler in einem ErrorCluster anzeigen lasse, bekomme ich eine sehr eindeutige Fehlerbeschreibung: Du solltest die Wartezeit etwas geringer setzen, da der Buffer übergelaufen ist...
Außerdem sitzt die Wartefunktion immer noch an der falschen Stelle! (s. Beitrag #6)

Zitat:Die graphische Ausgabe ist gut,aber leider hat der Sinus in regelmäßigen Intervallen kurzfristige Zacken oder Einbrüche.
Das war dann wohl ein Lesefehler, den du nicht ausgewertet hast. Du solltest dir angewöhnen, den ErrorCluster nicht nur zu verdrahten, sondern auch zu verwenden!
Referenz-URLs