LabVIEWForum.de - Kontinuierliche Daten erfassen und jeden Wert sofot verarbeiten

LabVIEWForum.de

Normale Version: Kontinuierliche Daten erfassen und jeden Wert sofot verarbeiten
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Seiten: 1 2 3
Hallo zusammen

Erst mal Danke an euch beide für die rasche Antwort

Wir haben das Vi nun mit Kommentaren versehen, die Flip Flops als Reetrent SubVis umgewandelt und auch die Cluster-Typdef angewand. Die Übersichtlichkeit ist nun um einiges besser geworden.

Den Tip mit der State Maschine haben wir noch nicht umgesetzt, da wir uns noch nicht schlüssig sind in wo diese Umstrukturierng in unserem Programm anwendbarist.

Die Warten Funktion haben wir aus Unwissenheit einfach aus einem Beispiel übernommen und seitdem verwendet. Uns war die Auswirkung nicht ganz klar, jedoch haben wir auf Grund der Aussage von JensG aus unserem Projekt entfernt.

Zitat:Wobei, Moment, die 250 Hz können aktuell gar nicht erreicht werden, da in 2 SubVIs ein Wait von 20 ms drin ist, hoppla, damit wird das Ganze auf 50 Hz gebremst...

Im aktuellen sind weder Warten noch Warten bis zum nächsten Vielfachen enthalten.

Dies macht keinen Sinn, da nach unserm Verständnis diese Funktionen dazu dienen Schleifen mit anderen Teilen des Programms zu synchonisieren (immer Warten bis einen Zeit abgelaufen ist bevor der nächste Teil abgearbeitet wird). Liegen wir mit der Vermutung richtig??

Die Interpretation ist soweit richtig, ich habe nun ein Timing Diagramm der Messung angehängt (dieses ist händisch gezeichnet da der Prüfling außer Betrieb ist). Hoffe man kann es nun besser verstehen.

Grob gesagt wir haben 2 Bedingungen mit der unser Messvorgang startet: Einmal wenn die Spannung unter einen einstellbaren Wert fällt (Analogtrigger) oder wenn die Pneumatik ein digitales Signal liefert (Digitaltrigger).
Nach eintrete einer dieser Bedingung vergeht eine eingestellte Zeit (bei Analogtrigger nur die Zeit in der der Taster prellt; bei Digital eine Zeit in der der Metallstift einen Weg zurücklegt bis er den Taster betätigt + die Zeit in der der Taster prellt) danach beginnt die Messung. Hier werden nun "alle" Werte erfasst und ausgewertet. Dies geschiet über das MinMax Array welches pro Sample einen MinMax Wert liefert dieser wird mit einen eingestellten Wert verglichen und entweder in Excel geschrieben oder nicht. Bei nicht betätigten Taster läuft einfach eine längerzeit ab (die aber auch mit der bereits erwähnten Bedingung startet) und verfährt nach dem selben Verfahren. Ein zusätzlicher Zähler zählt die Betätigungen.

Ich hoffe es wird nun verständlicher was unser Programm machen soll. Das hochgeladen Haupt Vi soll später über 8 Taster mit jeweils 2 solchen Messungen verfügen.

Das überarbeitet Haupt Vi hab ich mal hochgeladen inklusive der SubVis die dazu benötigt werden. Falls jemand bei durcheschauen noch etwas festsellt was wir umstrukturiern könnten bitte bescheid geben.

LabView 2009

MfG JackBlack
Hallo Jack,

ihr habt nur Erfahrung mit text-basierter Programmierung, oder?
Mal ein Vorschlag, wie man "Min_No.vi" auch programmieren könnte:
[attachment=31506]

Das gilt für die ganzen anderen Min/Max-VIs gleichermaßen... (Verzicht auf lokale Variablen, Nutzung vorhandener LV-Funktionen, keine die Übersichtlichkeit behindernden Strukturen)

Ein RS-FF kann man auch so abbilden:
[attachment=31507]
Da LabVIEW eine Programmiersprache und kein Leiterplatten-Planungsprogramm ist, muss man sich nicht sklavisch an Schaltpläne halten - man kann stattdessen die Funktionalität umsetzen...

Zell-Bezeichnungen für Excel geht auch ohne Schleifen:
[attachment=31508]

- Wieso schreibt ihr erst in das Terminal eines Indicators und gleich daneben nochmal in eine lokale Variable desselben Indicators? (Zeilenindex, Zähler in Stufe1.vi)
- Ein paar subVIs fehlen immer noch...
Schließe mich Gerd voll und ganz an.

Zusätzlich könnt ihr noch die Express-Verstrichene-Zeit durch einen kleinen Codeblock ersetzen:
[attachment=31509]

Dann Spart ihr euch den ganzen Express-zusatz Code, den ihr nicht braucht.

Siehe: [attachment=31510]

Gruß Richard
Soweit ich es verstanden habe soll der maximale Kontaktwiderstand eines Tasters in einem bestimmten Zeitfenster ermittelt werden. Dazu würde ich die Datenerfassung aller zu messenden Größen ggf. mit einem Pretrigger mit dem Tastersignal (analog) starten. Die Anzahl der Samples sollte den kompletten Tastendruck umfassen. Wenn die Samples erfasst sind, würde ich sie auswerten.

In dem Programm soll, so weit ich es aus dem Thread verstanden habe, dagegen die Messung erst nach Eintreten einer bestimmten Bedingung gestartet werden. Das halte ich für zu kompliziert und unter Windows nicht für richtig zuverlässig.

Ich hoffe, ich liege mit meinem Kommentar nicht völlig daneben.
Hallo zusammen

Erst mal Danke für die schnellen und zahlreichen Antworten


Zitat:ihr habt nur Erfahrung mit text-basierter Programmierung, oder?

Das ist richtig wir haben bisher nur Erfahrung mit VBA


Wir haben im neuen Haupt Vi wie vorgeschlagen die Änderungen an der Vergleichslogik, den Flip Flops und Zellenbezeichnung vorgenommen. Diesen Vis haben wir die Eigenschaft "Reentrant" zugewiesen.


Zitat:- Ein paar subVIs fehlen immer noch...
Ich vermute das sich die Aussage auf die "Open Sheet" und "Open Book" Vis bezogen sind. Diese haben wir nun auch mit hochgeladen.

Zitat:- Wieso schreibt ihr erst in das Terminal eines Indicators und gleich daneben nochmal in eine lokale Variable desselben Indicators? (Zeilenindex, Zähler in Stufe1.vi)
Wir haben das Stufe1 Vi nach unserm Verständniss geändert (Verbindung Indicator gelöscht).
Oder bezog sich die Anmerkung auf die Funktion der beiden Zähler?
Da der Zählerstand unabhängig vom Zeilenindex sein sollte, soll der Zählerstand dauerhaft hochgezählt werden wenn die Taste betätigt wird. Der Zeilenindex sollte sich nur erhöhen wenn ein Wert außerhalb des Grenzwertes ist, somit wird er für das Protokoll benötigt und der Zeilenindex muss sich erhöhen. Deshalb haben wir zwei indentische Zähler (Zellenindex, Zähler).

Die Ansteuerung des Zeilenindexes ist noch nicht korrekt.

Zitat:Zusätzlich könnt ihr noch die Express-Verstrichene-Zeit durch einen kleinen Codeblock ersetzen:
Müssen wir noch umbauen und testen, Danke für den Tipp.


Zitat:In dem Programm soll, so weit ich es aus dem Thread verstanden habe, dagegen die Messung erst nach Eintreten einer bestimmten Bedingung gestartet werden. Das halte ich für zu kompliziert und unter Windows nicht für richtig zuverlässig.

Die Messung kann bei uns von zwei Bedingugen ausgelöst werden:
- Digital Trigger ( Steuersiganl für die Ventile)
- Analog Trigger ( Nach unterschreiten einer gewissen Spannung)

zwischen diesen beiden Trigger Möglichkeiten kann gewählt werden. Dies sind für uns die einzigst ersichtlichen Möglichenkeiten
um den Trigger zu starten.

Was meinst du eigentlich mit dem Pretrigger, ist die eine Software oder Hardware Lösung?

Wir haben wieder alles zusammengestellt und hochgeladen.

LabView 2009

MfG JackBlack
Hallo Jack,

Zitat:Wir haben das Stufe1 Vi nach unserm Verständniss geändert (Verbindung Indicator gelöscht).
Genau falsch rum... Den Indicator verbunden lassen und die (unnötige) lokale Variable löschen.
Wozu wollt(et) ihr überhaupt zweimal einen Wert dem gleichen Indicator zuweisen (per lokaler Variable und per Terminal)? Einmal zuweisen reicht - und da ist das Terminal immer die bessere Wahl!
Hallo zusammen


Zitat:Genau falsch rum... Den Indicator verbunden lassen und die (unnötige) lokale Variable löschen.
Wozu wollt(et) ihr überhaupt zweimal einen Wert dem gleichen Indicator zuweisen (per lokaler Variable und per Terminal)? Einmal zuweisen reicht - und da ist das Terminal immer die bessere Wahl!

Ok dan haben wirs es falsche verstanden. Haben es nun nochmal umgeändert und die lokale variable entfernt.

Zitat:Soweit ich es verstanden habe soll der maximale Kontaktwiderstand eines Tasters in einem bestimmten Zeitfenster ermittelt werden. Dazu würde ich die Datenerfassung aller zu messenden Größen ggf. mit einem Pretrigger mit dem Tastersignal (analog) starten. Die Anzahl der Samples sollte den kompletten Tastendruck umfassen. Wenn die Samples erfasst sind, würde ich sie auswerten

Da wir in unerem Programm nicht die Werte verarbeiten müssen die vor dem Eintreten des Trigger aufgezeichnet werden, hab wir uns gedacht auf einen Pretrigger verzichten können. Die Anahme bezieht sich auf die Infromation im Labview zum Thema Referenz Trigger.

Ist unsere Anahme richtig?


LabView 2009

MfG JackBlack
Hallo zusammen

Wir haben nun unser Programm das für einen Taster mit 2 Stufen funktioniert, für die andern 7 Taster dupliziert.

Beim Testlauf mit dem Signalsimulation ist uns aufgefallen das die Werte nicht mehr richtig eingetragen werden. Wir benutzten zu dem 8 verschiedene Tabellen in Excel, in die wir im schlimmsten Falle gleichzeitig schreiben müssen.

Zusätzlich ist uns aufgefallen das die CPU Auslastung der PCs durch Excel und Labview bei ca. 70% liegt.
Liegen wir richtig mit der Annahme das, das schreiben so Ressourcen belastend ist .Das es zu diesen Fehlern kommt??

Um das Problem zu lösen haben wir uns vorgestellt die Werte anstatt direkt in Excel erst in ein Array zu sichern und nach Beendigung der Messung erst in Excel zu übertragen.

Sind wir mit unserer Theorie auf der richtigen Spur?? Wenn ja wie kann man dies realisieren.

Oder falls noch jemand einen andere Möglichkeit sieht wie wir dieses Problem bewältigen können.

Unser Projekt haben wir wieder mit hochgeladen, wir sind über jeder konstruktive Kritik dankbar!!

LabView 2009

MfG JackBlack
Seiten: 1 2 3
Referenz-URLs