LabVIEWForum.de - Doppelpuls Signal über CSV in Digitaldaten Tabelle und als Output schalten

LabVIEWForum.de

Normale Version: Doppelpuls Signal über CSV in Digitaldaten Tabelle und als Output schalten
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Seiten: 1 2 3 4 5 6
Hallo Gerd,

wir sind jetzt soweit, dass wir den CRIO als Projekt mit FPGA eingerichtet haben. Jedoch kommen wir nicht weiter, wie wir die Digitaldaten mit den richtigen Zeiten auf den Ausgang geschaltet bekommen. Die erste Spalte bei den Digitaldaten sind ja "us" Mikrosekunden, zweite Spalte der Binärzustand 0 oder 1. Unser Modul C-9375 hat eine maximale Tastrate von 7us. Die Schnelligkeit sollte also reichen.

Wir freuen uns auf eine Antwort
Mfg
Lukas & Nico
Habe die angehängte Datei nochmal die VI´s hinzugefügt
Hallo Lucky.,

danke für das Anhängen des kompletten Projekts, das ermöglicht es uns, eure genaue cRIO-Konfiguration zu begutachten.

Es ist gut, dass ihr das 9375 als Modul2 im FPGA eingebunden habt.
Es ist gut, dass ihr die DO-Daten direkt auf die IONodes im FPGA ausgebt.
Es ist aber leider komplett falsch, einfach euer bisheriges RT-VI in den FPGA verschieben zu wollen: dieser unterstützt einen Großteil des programmierten Codes überhaupt nicht! (Arrays variabler Größe, die ganzen File-Funktionen, String-Operationen, digitale Waveforms, etc.)
Es ist auch falsch, dass ihr MOD1/AO0-7 für die Ausgabe programmiert, wenn ihr eigentlich Mod2 zu nutzen vorgebt…

Nochmal:
Geht bitte ALLE Einsteigerkurse zu den Themen RT und FPGA durch! Das ist wirklich wichtig, wenn ihr hier Fortschritte produzieren wollt!
Schaut euch die Beispielprojekte an, die mit LabVIEW+RT+FPGA bereitgestellt werden! Dort wird gezeigt, wie man zwischen PC & cRIO & FPGA kommuniziert!

Euer FPGA-VI sollte in etwa (!) so aussehen:
[attachment=61586]
Alles andere wird im RT-VI vorbereitet!
(Im Snippet wird nur ein Sample pro Channel ausgegeben. Ihr solltet stattdessen einen FIFO implementieren, der eure Waveform aufnimmt und an den FPGA weiterleitet. Dazu dann noch ein Flag, mit dem die Ausgabe des FIFO-Inhalts im FPGA selbst getriggert wird. Nur so eine Idee, wie ich das evtl. umsetzen würde…)

Ich hatte ja schon einmal geschrieben, dass ihr eine steile Lernkurve zu nehmen habt! Big Grin

P.S.: Leider kann ich eure Anfrage nach einem Zoom-Meeting momentan nicht erfüllen. Tagsüber muss ich arbeiten (Geld verdienen), abends habe ich Freizeit und nur wenig Lust auf weitere Videokonferenzen… Wink
Hallo,

Vorweg, vielen Dank für die Hilfe!

Wir haben uns nun tatsächlich mal durch die Tutorials gekämpft und haben auch ein fast funktionierendes Programm entwickelt. (Habe es angehängt)

Getestet haben wir das Programm mit langsamen Pulsen, einem Steckbrett und LED's, dies funktionierte wunderbar, also dachten wir uns, wir beschleunigen die Sache und messen das Signal mal mit einem Oszilloskop...
Dann fiel der Fehler leider auf, dass zwischen den Pulsen unsere Spannung von 5V nur auf 2V fällt anstatt auf 0V, nachdem der Durchlauf abgeschlossen ist, bleibt der Wert auch auf 2V, anstatt auf 0V.. Keine Ahnung warum! Bahn

Vielleicht weiß hier ja einer warum das so ist...

Danke im Voraus

Lukas und Nico Blush
Hallo ihr zwei,

Zitat: ein fast funktionierendes Programm entwickelt. (Habe es angehängt)
Ihr habt da was vergessen…

Zitat:Dann fiel der Fehler leider auf, dass zwischen den Pulsen unsere Spannung von 5V nur auf 2V fällt anstatt auf 0V, nachdem der Durchlauf abgeschlossen ist, bleibt der Wert auch auf 2V, anstatt auf 0V.. Keine Ahnung warum!
Wenn ihr euer Programm anhängt, dann bitte auch den Schaltplan, den ihr zu Dokumentationszwecken sicherlich schon erstellt habt!
Ups, sorry. Das Programm sollte nun verfügbar sein.

Einen Schaltplan hab ich für den Testaufbau nun nicht gemacht, später sollen durch die AO's MOSFETs angesteuert werden und über den DO im FPGA ein Doppelpuls-Signal mit 5V Amplitude erzeugt werden.

Danke
(02.02.2021 14:56 )Lucky. schrieb: [ -> ]Getestet haben wir das Programm mit langsamen Pulsen, einem Steckbrett und LED's, dies funktionierte wunderbar, also dachten wir uns, wir beschleunigen die Sache und messen das Signal mal mit einem Oszilloskop...
Dann fiel der Fehler leider auf, dass zwischen den Pulsen unsere Spannung von 5V nur auf 2V fällt anstatt auf 0V, nachdem der Durchlauf abgeschlossen ist, bleibt der Wert auch auf 2V, anstatt auf 0V.. Keine Ahnung warum! Bahn

Euere DO sind doch Sourcing - und ihr habt da eine Diode drin. Ersetzt die Schaltung mal durch einen simplem (nicht zu großen und nicht zu kleinen) Widerstand.
Hallo LuckyPoint,

Zitat:Einen Schaltplan hab ich für den Testaufbau nun nicht gemacht,
Obwohl ihr mit eurer Schaltung Probleme habt, könnt ihr keinen Schaltplan vorweisen, anhand dessen man die Probleme analysieren könnte?
Da habt ihr aber noch einiges zu lernen für euren Schul-/Lehr-/Uni-Abschluss…

Zitat:Das Programm sollte nun verfügbar sein.
Habt ihr auch mal irgendwelche Vorschläge von uns zum Thema "gute Programmierung" übernommen?
Warum sieht man immer noch Terminals im Blockdiagramm ohne Label?
so wie hier: [attachment=61611] (fehlende Labels sind von mir markiert…)

Warum nutzt ihr immer noch lokale Variablen anstatt Draht und Schieberegister (z.B. für Wertetabelle)?
Warum braucht ihr für jeden AO eine Case-Struktur mit 2 Cases und 2 IO-Nodes? Warum nicht einfach sowas hier:
[attachment=61610]
Warum haben boolscher Control und Indicator im Bild das exakt gleiche Label? Habt ihr sowas in den Programmiergrundlagen gelernt???

Ich hatte euch doch schon gezeigt, wie man die Wertetabelle wesentlich eleganter für eure AOs auswertet: was daran hat euch nicht gefallen? War der Code zu einfach?

Wenn ihr schon nach Hilfe fragt, dann solltet ihr solche gesammelten Hinweise dann nicht einfach ignorieren…

Zum FPGA-VI:
Normalerweise lässt man den FPGA ständig laufen und beendet das VI nicht einfach nach einem Durchlauf! Das solltet ihr in den Grundlagenkursen eigentlich gelernt haben!
Wozu dann überhaupt die While-Loop? Sowas nennt sich "Rube-Goldberg-Code"…
Da das FPGA-VI innerhalb von Mikrosekunden beendet wird, ist die Schleife im RT-VI um das Schreiben der Puls-Parameter ebenso Blödsinn! Und noch viel schlimmer: ihr habt da eine Race-Condition programmiert! Was ist wohl schneller: der FPGA beim Abarbeiten seiner Case-Struktur oder der RT beim Senden der ganzen Parameter zum FPGA?
Noch viel blöder: da der FPGA ja nur einmal vor der großen RT-While-Loop gestartet wird, könnt ihr hinterher soviele Parameter zum FPGA schicken, wie ihr wollt: der FPGA arbeitet da schon lange nicht mehr…

Nochmal: Schaut euch BITTE die Einsteigerkurse zum Thema RT & FPGA an. Das ist wirklich wichtig!

Edit: Ich habe mal beide VIs etwas überarbeitet, das war mir echt zu schrecklich…
Hallo zusammen,

erstmal vielen Dank für die ganzen Hilfreichen Beiträge von euch. Wir sind nun entscheident vorran gekommen.
Hierzu werde ich euch mal ein aktuellen Stand da lassen :-)

Eine weitere Frage hätte ich da noch. Und zwar kann unser Chip (Datenblatt im Anhang) eine Temperatur, welche er im Mosfet misst, in ein PWM Signal wandeln und an unseren Controller ausgeben. Die Spezifikationen befinden sich im Datenblatt dazu. Ich habe mich nun etwa 8 Std damit beschäftig, nur leider komme ich zu keiner Lösung wie ich diese Signal auswerten und als Temperatur mir anzeigen lassen kann. Vielleicht wär einer so lieb und könnte mir ein Beispiel oder ein fertiges VI geben.

Ich freue mich auf eine Antwort :-)

Mfg
Lukas
Hallo Lucky.,

Zitat:Wir sind nun entscheident vorran gekommen. Hierzu werde ich euch mal ein aktuellen Stand da lassen :-)
Sobald ihr euer "Pulsprogramm" startet, bleibt euer VI in einer Endlosschleife hängen.
So richtig läuft das wohl noch nicht!

Ansonsten:
In der Hauptschleife ist kein Timing zu erkennen.
Die ganzen Konstanten (0-8) am IndexArray sind unnötig!
Die ganzen "Ohm"-Schalter in ein Array, die zugehörigen Anzeigen auch - und die Hauptschleife wird gleich viel aufgeräumter…

Zitat:Ich habe mich nun etwa 8 Std damit beschäftig, nur leider komme ich zu keiner Lösung wie ich diese Signal auswerten und als Temperatur mir anzeigen lassen kann. Vielleicht wär einer so lieb und könnte mir ein Beispiel oder ein fertiges VI geben.
Ich freue mich auf eine Antwort :-)
Und was ist dir in diesen 8 Stunden so eingefallen?
Was hast du ausprobiert? Woran bist du gescheitert?

Mach doch einfach, was im Datenblatt steht: "filtered by a simple RC filter as an analog signal"!
Seiten: 1 2 3 4 5 6
Referenz-URLs