LabVIEWForum.de - Problem mit Dauermessung - immer wieder Absturz

LabVIEWForum.de

Normale Version: Problem mit Dauermessung - immer wieder Absturz
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Seiten: 1 2 3 4
Offtopic2
' schrieb:Latürnich!

' schrieb:Da fällt mir "Kentucky schreit ***" von RTL-Samstag Nacht ein.

"Darf ich Sie an die Bheke ***?" Rofl
Wie kann man einen solch genialen Buchstabendreher aus Asterix (Die Lorbeeren des Cäsar) mit RTL-Samstag Nacht vergleichen...
' schrieb:alles bis auf das VI mit dem Timeout-Anschluss (Read...siehe die Brille!) aus der Schleife raus!

Hmm...also ich hab das Ganze versucht so zu machen, wie du sagtest:

[attachment=13875]

Aber da werden dann nur einmal Messwerte aufgenommen und nicht kontinuierlich (seh ich auch per Scope am Ausgang des VIs). Sobald ich den Start Task wieder in die Schleife nehme, habe ich auch wieder kontinuierliche Messwerterfassung. Was mach ich falsch?
' schrieb:Aber da werden dann nur einmal Messwerte aufgenommen und nicht kontinuierlich (seh ich auch per Scope am Ausgang des VIs). Sobald ich den Start Task wieder in die Schleife nehme, habe ich auch wieder kontinuierliche Messwerterfassung.
Hast du den Abtasttakt noch auf "Finite Samples" stehen? Das sollte dann aber "infinite" sein - oder das ganze "Abtasttask"-VI weglassen.
Guten Morgen,

nachdem ich noch einiges probiert hatte, kam nun heraus, dass es am Rechner lag und ein anderer Rechner mit LV 8.5 dann keine Probleme hatte (obwohl es mit diesem PC unter LV 7.1 zu Abstürzen kam). Woran es genau lag, kann man letztlich nicht sagen, aber jetzt läuft es.

Jetzt habe ich allerdings noch eine Frage zu meiner Sicherheitsabschaltung (im VI rechts unten im Blockdiagramm). Bisher gab ich bei einer Fehlerbedingung testweise an einem Analogausgang 5 V aus. Nun sollen aber im Normalbetrieb 5 V anliegen und bei Fehler 0 V, was z.B. bei PC-Abstürzen/Neustarts auch dringend so erforderlich ist. Nun das Problem: Wenn das Programm läuft und ich beende es ordnungsgemäß (was aber auch durch einen LabVIEW-Fehler passieren könnte), liegen nach wie vor die 5 V am Ausgang an. Ich habe schon probiert, den Task-Start und -Ende in die Schleife zu nehmen, so dass der Kanal immer wieder neu initialisiert wird, das hat aber nichts gebracht. Gibt es irgendeine Funktion wie "Alle Kanäle zurücksetzen bei Programmabbruch"?

Viele Grüße
Hi,
das Ausgeben der Spannung sollte schon funktionieren...fällt mir jetzt auch nichts weiter dazu ein! Hast du mal versucht, ohne dein ganzes Brimborium aussenrum nur ein isoliertes VI mit der Spannungsausgabe zu testen?

Aber mal grundsätzlich:
Bei PC-Abstürzen bleiben die Karten-Ausgänge auf dem bisherigen Pegel...eben weil der Treiber aufgrund des PC-Absturzes keinen neuen Vorgabewert bekommt! Für eine Sicherheitsabschaltung ist diese Methode nicht geeignet! Du könntest aber z.B. ein Watchdog-Relais (das hier oder das hier) extern zwischenschalten, dass durch einen vom Programm vorgegebenen Rechteck-Takt immer wieder neu getriggert wird...solange das Programm läuft...wenn nicht, wird nach einer am Relais einstellbaren Zeit ausgeschaltet!

Gruß
Achim
' schrieb:Hi,
das Ausgeben der Spannung sollte schon funktionieren...fällt mir jetzt auch nichts weiter dazu ein! Hast du mal versucht, ohne dein ganzes Brimborium aussenrum nur ein isoliertes VI mit der Spannungsausgabe zu testen?

Aber mal grundsätzlich:
Bei PC-Abstürzen bleiben die Karten-Ausgänge auf dem bisherigen Pegel...eben weil der Treiber aufgrund des PC-Absturzes keinen neuen Vorgabewert bekommt! Für eine Sicherheitsabschaltung ist diese Methode nicht geeignet! Du könntest aber z.B. ein Watchdog-Relais (das hier oder das hier) extern zwischenschalten, dass durch einen vom Programm vorgegebenen Rechteck-Takt immer wieder neu getriggert wird...solange das Programm läuft...wenn nicht, wird nach einer am Relais einstellbaren Zeit ausgeschaltet!

Gruß
Achim
Das reine Ausgeben der Spannung klappt schon. Nur dass die Spannung bei Programmabbruch auch nicht mehr anliegt, das klappt noch nicht...
Diese Watchdog Relais sind allerdings schon sehr teuer...Aber eigentlich kann ich ja auch das Rechtsecksignal einfach gleichrichten und damit ein herkömmliches Relais ansteuern? Dazu müsste nur sichergestellt sein, dass die Messkarte bei Softwareabsturz (zB Bluescreen) auf keinen Fall weiterhin das Rechtecksignal weiter ausgibt.
' schrieb:Dazu müsste nur sichergestellt sein, dass die Messkarte bei Softwareabsturz (zB Bluescreen) auf keinen Fall weiterhin das Rechtecksignal weiter ausgibt.

Das ist ein Widerspruch in sich! Wenn Absturz...dann keine Aktualisierung!

Und offenbar hast du nicht verstanden, warum ein Rechteck-Signal verwendet werden soll: Die Watchdog-Relais erkennen steigende und/oder fallende Flanken...wenn keine kommt, d.h. wenn der Pegel immer gleich (high oder low) bleibt, läuft die eingestellte Zeit ab und ein Öffnerkontakt wird betätigt...= Unterbrechung!

Deswegen musst du auch in der SW den Takt programmatisch erzeugen...nur wenn die SW ordnungsgemäß läuft, ändern sich die Pegel!

Wenn du dein Programm manuell abbrichst, musst du dafür sorgen das das (Rück-) Setzen der Ausgabepegel durchgeführt wird, bevor du deine Schleife stoppst (Datenfluss-Prinzip von LabVIEW). Im Fehlerfall (SW hängt sich auf...) klappt das natürlich nicht...weil du nie weißt, wo das Programm hängt...und vor allem, weil es überhaupt hängt, d.h. es werden keinerlei weitere Aktionen durchgeführt!

Nochmal als dringender Hinweis:

Es ist nicht zulässig, über einen (normalen) PC eine Sicherheitsabschaltung zu realisieren! Wenn du das trotzdem so machen willst, möchte ich bei einem Unfall nicht in deiner Haut stecken!
' schrieb:Das ist ein Widerspruch in sich! Wenn Absturz...dann keine Aktualisierung!
Nun ja: letztlich sind 5V Gleichspannung und eine Rechteckspannung mit 5V Peak beides Signalformen, die LV ausgeben kann. So unlogisch ist es da nicht, nachzufragen, ob wirklich die eine Signalfom bei einem Programmabsturz am Ausgang unverändert ansteht und die andere nicht. Hängt von der Programmstruktur von LV ab.

' schrieb:Und offenbar hast du nicht verstanden, warum ein Rechteck-Signal verwendet werden soll: Die Watchdog-Relais erkennen steigende und/oder fallende Flanken...wenn keine kommt, d.h. wenn der Pegel immer gleich (high oder low) bleibt, läuft die eingestellte Zeit ab und ein Öffnerkontakt wird betätigt...= Unterbrechung!
Deswegen musst du auch in der SW den Takt programmatisch erzeugen...nur wenn die SW ordnungsgemäß läuft, ändern sich die Pegel!
Das Prinzip mit Gleichrichtung ist ja dasselbe: LabVIEW erzeugt (anscheinend) solange ein Rechtecksignal am Ausgang bis es nicht mehr korrekt läuft (dann aktualisiert es den Ausgang nicht mehr). Also habe ich dann entweder 0V oder 5V am Ausgang, aber keinesfalls mehr den Wert, der durch die Gleichrichtung entstünde. Sicher ist da ein Watchdog-Schalter eleganter, weil er nicht die Pegel kontrolliert, sondern den Takt.

' schrieb:Nochmal als dringender Hinweis:[/b][/u]
Es ist nicht zulässig, über einen (normalen) PC eine Sicherheitsabschaltung zu realisieren! Wenn du das trotzdem so machen willst, möchte ich bei einem Unfall nicht in deiner Haut stecken!
Das ist doch solange zulässig wie der PC funktioniert. Und wenn ich - so wie geplant - einen PC- oder Softwarefehler hardwaretechnisch abfange (durch Ausschaltung der gesamten Anlage) sehe ich da kaum Risiko.
' schrieb:Aber da werden dann nur einmal Messwerte aufgenommen und nicht kontinuierlich (seh ich auch per Scope am Ausgang des VIs). Sobald ich den Start Task wieder in die Schleife nehme, habe ich auch wieder kontinuierliche Messwerterfassung. Was mach ich falsch?
Habe mir Dein VI jetzt mal kurz angesehen, und dabei folgendes gesehen:
Kontinuierliche Messwerterfassung:
Das funktioniert nur mit der Betriebsweise "kontinuierlich" Einen Task mit N samples in einer Schleife immer wieder neu starten, ergibt keine kontinuierliche Betriebsart. Es ist so, daß Stop und Start dann nicht lückenlos aufeinander folgen, da.h. es gehen immer Samples verloren.
Es ist unbedingt zu empfehlen, an DAQmxRead einen Wert für die Anzahl der Samples anzuschließen (und - der Vollständigkeit halber - in die Erfassungsschleife kein Wait). Macht man das nicht, so wird immer ohne zu warten alles was zufällig im Buffer ist gelesen. Die Schleife läft mit maximaler Geschwindigkeit, und die Anzahl der gelesenen Werte ist jedesmal zufällig - davon abhängig was es in der Schleife sonst noch zu tun gibt.
Es sei auch noch erwähnt: In der Betriebweise "kontinierlich" ist der Eingang "Anzahl der Samples" im Timing-VI umfunktioniert, siehe Hilfe. Damit legt man die Größe des Buffers fest.

Braucht man das "Start"-VI"? Meistens nicht, wenn es fehlt, wird beim ersten Lesevorgang gestartet. Wichtig ist es aber z.B, wenn man AI-und AO-Tasks miteinander synchronisieren muß. Es kann auch sein, wie hier bei Dir, daß bei geschickter Platzierung des Start-VI etwas weniger Lücke zwischen Stop und nächstem Start ist. Aber dann zu glauben, die Datenerfassung wäre kontinuierlich, ist trotzdem eine Illusion.
' schrieb:Das ist doch solange zulässig wie der PC funktioniert. Und wenn ich - so wie geplant - einen PC- oder Softwarefehler hardwaretechnisch abfange (durch Ausschaltung der gesamten Anlage) sehe ich da kaum Risiko.
Software auf einem PC ist per se nicht sicher. Ebenso normale Standard-Hardware, wenn sie nicht ausdrücklich für einen Sicherheitsaspekt geeignet ist. Auch ein eigenes Rechtecksignal mit Gleichrichtung etc. gilt per se als nicht sicher und ist somit ungeeignet zum Abschalten z.B. des Notauskreises.

Es kommt natürlich darauf an, was an deinem Relais hängt. Hängt das Relais nicht in einem Notauskreis und erfüllt keine Sicherheitsfunktion im weitesten Sinne - werde ich das nicht so eng sehen.
Seiten: 1 2 3 4
Referenz-URLs