INFO: Dieses Forum nutzt Cookies...
Cookies sind für den Betrieb des Forums unverzichtbar. Mit der Nutzung des Forums erklärst Du dich damit einverstanden, dass wir Cookies verwenden.

Es wird in jedem Fall ein Cookie gesetzt um diesen Hinweis nicht mehr zu erhalten. Desweiteren setzen wir Google Adsense und Google Analytics ein.


Antwort schreiben 

Programm funktioniert nur im Debugmodus?



Wenn dein Problem oder deine Frage geklärt worden ist, markiere den Beitrag als "Lösung",
indem du auf den "Lösung" Button rechts unter dem entsprechenden Beitrag klickst. Vielen Dank!

31.05.2013, 15:21
Beitrag #1

meggi Offline
LVF-Neueinsteiger


Beiträge: 3
Registriert seit: May 2013

11.0.1
2013
DE_EN



Programm funktioniert nur im Debugmodus?
Hallo zusammen,

Mein Ziel ist die Datenerfassung über eine analoge Karte mit 8 Eingängen über ein RT-Crio.
Ich habe mir dazu das "getting started" beispiel kopiert, und wollte es dann anpassen. auf das erste problem stoße ich aber bereits, wenn ich in der RT-schleife mehr als 2 Eingänge der Karte abfrage -- die Schleife hört nach ein paar Durchläufen einfach auf. Ich habe selbstverständlich die Variable "Loopcom" erweitert, dass sie mit der doppelt so großen Datenmenge klarkommt und den Anzeigecase in der unteren Schleife habe ich auch geändert.
Ich habe auch versucht, Fehlermeldungen anzeigen zu lassen, aber anscheinend gibt es keine, das Anzeigeelement bleibt auf dem grünen Haken.
Jetzt das Seltsame:
Wenn ich den Debug/Highlightmodus aktiviere, und die Schleife ein paar Durchläufe gezwungen langsam machen lasse und dann auf schnell schalte, läuft das Programm einwandfrei!

Hat jmd. selbiges Problem schonmal gehabt, bzw. weiß eine Lösung dazu? Gibt es evtl. irgendwelche Dinge, die man beachten muss wenn man in RT-Schleifen auf Messkarten zugreift?

P.s. hab das ganze programm auch von einem anderen Rechner aus auf das Crio gespielt und ausgeführt -- gleiches Ergebnis.


Angehängte Datei(en)
0.0 .pdf  FindedenFehler.pdf (Größe: 213,91 KB / Downloads: 272)
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Anzeige
31.05.2013, 15:42 (Dieser Beitrag wurde zuletzt bearbeitet: 31.05.2013 15:44 von GerdW.)
Beitrag #2

GerdW Offline
______________
LVF-Team

Beiträge: 17.470
Registriert seit: May 2009

LV2021
1995
DE_EN

10×××
Deutschland
RE: Programm funktioniert nur im Debugmodus?
Hallo Meggi,

1. Du kannst Bilder auch direkt anhängen (als PNG) und musst sie nicht erst in einem PDF verpacken...
2. Du fragst über die ScanEngine 4 Werte in einer Schleife ab, die mit 1000Hz laufen soll. Das ist schon grenzwertig (meiner Erfahrung nach)...

Was passiert, wenn du die Messschleife als "normale" While-Loop anlegst und dort ein Wait mit 1ms hineinpackst?

Trägt zwar nicht zur Lösung bei, ist aber trotzdem fragwürdig:
- Warum wird in jeder Iteration der Messschleife erneut ein Array mit 4 Elementen überschrieben? Warum nicht einfach BuildArray nutzen?

Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
31.05.2013, 16:27
Beitrag #3

meggi Offline
LVF-Neueinsteiger


Beiträge: 3
Registriert seit: May 2013

11.0.1
2013
DE_EN



RE: Programm funktioniert nur im Debugmodus?
Hallo GerdW,

mein Ziel ist es, irgendwann die Daten in Echtzeit abzufragen, ich brauche eine Garantie, dass ich jede ms einen Satz Messwerte bekomme. mit einer normalen While-Schleife funktioniert das denke ich nicht oder?

Zum 2. Punkt:
Da habe ich mich auch schon gewundert, und habe es in einer anderen Variante auch durch "Builtarray"/"Array erstellen" ersetzt. Ursprünglich kommt das Programm ja aus der Beispielhilfe. Das funktioniert genauso, bzw. genauso nicht ;-)
Vermutlich ist das ersetzen schneller, da der Speicher schon reserviert ist und nicht neu zugewiesen werden muss..

Zu dem Punkt, dass 4 Messwerte grenzwertig sind für eine Frequenz von 1000Hz -- wenn ich ca. die ersten drei Schleifendurchläufe den Debugmodus anmache, funktioniert das programm danach auch einwandfrei OHNE Debugmodus.. Selbst Chuck Norris weiß bis jetzt nicht wieso..

P.s. Ich bin ein hilfloser Mac-User an einem Windows-PC, da finde ich es ja schon sehr bemerkenswert, dass ich es geschafft habe einen screenshot zu machen ;-) Das nächste Bild kommt dann auch als png oder jpg daher.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
02.06.2013, 17:53 (Dieser Beitrag wurde zuletzt bearbeitet: 02.06.2013 17:54 von GerdW.)
Beitrag #4

GerdW Offline
______________
LVF-Team

Beiträge: 17.470
Registriert seit: May 2009

LV2021
1995
DE_EN

10×××
Deutschland
RE: Programm funktioniert nur im Debugmodus?
Hallo meggi,

Zitat:mein Ziel ist es, irgendwann die Daten in Echtzeit abzufragen, ich brauche eine Garantie, dass ich jede ms einen Satz Messwerte bekomme.

Was bedeutet bei dir "Echtzeit"? Die Garantie bekommst du, wenn du den FPGA selbst nutzt...

Zitat:mit einer normalen While-Schleife funktioniert das denke ich nicht oder?
Die Frage ist eher, ob alle anderen Komponenten mitspielen:
- ist dein AI-Modul überhaupt schnell genug?
- ist die ScanEngine schnell genug?
- ist das cRIO schnell genug und nicht mit anderem "Zeugs" ausgelastet?
Wie schon gesagt: Sampleraten von 4kHz sind mit der ScanEngine grenzwertig...

Zum 2. Punkt:
Das Ersetzen in einem Array ist dem BuildArray üblicherweise vorzuziehen (aus Performance- und Resourcengründen). Aber in deinem gezeigten Bild ist es einfach "RubeGoldberg": in jeder Iteration wird das von InitArray bereitgestellte Array mit neuen Messwerten beschrieben, ohne dass das Array danach weiterverwendet wird - z.B. mit einem Schieberegister. Deshalb meine Anmerkung: nimm dort doch einfach BuildArray...

Zitat:wenn ich ca. die ersten drei Schleifendurchläufe den Debugmodus anmache, funktioniert das programm danach auch einwandfrei OHNE Debugmodus.
Dann programmiere das doch ganz einfach: die ersten 3 Iterationen mit einem Schleifentakt von 1000ms, danach dann mit einem Takt von 1ms laufen lassen. Die TWL bietet doch entsprechende In-/Out-Knoten an...

Zitat:P.s. Ich bin ein hilfloser Mac-User an einem Windows-PC, da finde ich es ja schon sehr bemerkenswert, dass ich es geschafft habe einen screenshot zu machen ;-)
Auch an einem MAC könntest du dir die LabVIEW-Hilfe zum Thema "Snippets" durchlesen und danach anwenden. Kein Grund, über evtl. nicht vorhandene OS-Tools (oder eine ungewohnte Arbeitsumgebung) zu sinnieren...

Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
02.06.2013, 18:36
Beitrag #5

meggi Offline
LVF-Neueinsteiger


Beiträge: 3
Registriert seit: May 2013

11.0.1
2013
DE_EN



RE: Programm funktioniert nur im Debugmodus?
Das CRio unterstützt meines Wissens nach auch Echtzeit-Schleifen... Die FPGA-Programmierung ist aufwändiger und in manchen Punkten schwieriger umzusetzen, deswegen wollte ich das erst einmal umgehen.

Zu dem Built-Array: Wie gesagt in meinem normalen Programm ist das auch mit einem Builtarray gemacht, der Screenshot ist aus einem eben leicht modifizierten Beispielprogramm, das ich genommen habe um mein Problem möglichst einfach zu schildern.

Das mit dem Verlangsamen probiere ich morgen gleich mal aus.
Allerdings kann das ja nicht die einzige Lösung sein..
Wenn ich übrigens das CRio das erste Mal connecte und dann das VI das erste Mal draufspiele, läuft das Programm einwandfrei.
Meine Vermutung ist, dass das Problem irgendwie mit den Variableneinstellungen von Loopcom zusammenhängt.. gibt es dazu evtl. irgendwo eine Hilfe? In der Labview-Hilfe habe ich nicht sonderlich viel gefunden(was natürlich auch an mir liegen kann).

P.s. Mein P.s. war nicht besonders ernst gemeint...
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
02.06.2013, 19:23
Beitrag #6

Ascend Offline
LVF-Grünschnabel
*


Beiträge: 18
Registriert seit: May 2013

09 SP1, 12 SP1, 13 SP1, 14 SP1
2012
EN


Deutschland
RE: Programm funktioniert nur im Debugmodus?
4 kHz mit der Scan-Engine? Blink Mich würde mal interessieren, ob deine Schleife dann tatsächlich alle 1 ms läuft...
Meiner Erfahrung nach schaffe ich mit der Scan Engine nichtmal 50 Hz stabil sobald da noch ne PID o.ä. drin ist.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Anzeige
02.06.2013, 21:28
Beitrag #7

Holy Offline
LVF-Stammgast
***


Beiträge: 339
Registriert seit: Sep 2008

2014
2007
EN

09XXX
Deutschland
RE: Programm funktioniert nur im Debugmodus?
NI selbst nennt ungefähr 1kHz als Grenze. Je nach Anwendungsfall kann auch mehr gehen. Ich selbst habe seit Jahren stabil im Einsatz 500 Hz. Die TWL kann dir sagen ob sie den Zyklus gehalten hat. Also ausprogrammieren und dann schauen ob es hinkommt.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Antwort schreiben 


Gehe zu: