LabVIEWForum.de - Frequenz ermitteln mit NI-9215

LabVIEWForum.de

Normale Version: Frequenz ermitteln mit NI-9215
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Seiten: 1 2 3 4 5
Da bin ich von der Theorie zu weit weg, um es 100%ig sagen zu können, aber vom Gefühl her bin ich mir ziemlich sicher, dass es nichts ausmacht, da ja Dein erfasstes Signal an sich und nicht die Länge Deines Signals transformiert wird. Vielleicht kann Dir das aber jemand bestätigen (Lucki ist z.B. ein Kandidat, der mit Mathematik sehr bewandert ist).

Gruß Markus

' schrieb:Hi, mir ist ein kleines Problem aufgefallen bei der Lösung mit FFT. Damit das ganze richtig funktioniert muss man ja beim Fenstern immer eine ganze Periode bzw. ein vielfaches einer Periode Fenstern. Das kann ich allerdings beim Sinus des Motors nie Wissen ob eine ganze Periode im Fenster ist oder nicht. Dass führt dann zu Aliasing und zu einer falschen Frequenz die ich dann durch die FFT ermittelt bekomme.
Liege ich da richtig?

MichaDu

Hallo,

das Fenster ist bei einer FFT ist ja erst dazu da, um diesen "Leck-Effekt", der durch Sprungstellen bei ungradzahligen Vielfachen einer Periode auftritt, zu verringern. Allerdings wird hierdurch auch die Frequenzauflösung etwas herabgesetzt. Ohne Fenster hättest du aber einen größeren Messfehler. Welches Fenster hierzu am besten geeignet ist, weiß ich allerdings auch nicht.

Alternativ könnte man auch zuerst die Frequenz bestimmen und danach die FFT durchführen. Sofern einigermaßen saubere Wechselsignale vorliegen, z.B. durch Messen der Zeiten zwischen den Nulldurchgängen.
Genau, das war auch mein erster gedanke wenn ich die Zeit messen kann zwischen 2 Nulldurchgängen kann ich mir ja die Frequenz errechnen. Bei einem TTL Signal kann man das ja mit hilfe des NI-9401 und dem Counter rel. einfach realisieren. Beim NI-9215 muss man das glaube ich von "Hand" machen. Das ist die grösste Hürde weil ich absolut keine Idee habe wie ich das machen soll.
Der Vorschlag von Y-P ist natürlich auch eine Super variante aber wie gesagt da habe ich bedenken ob das mit dem Fenstern 100% klappt.

Gruss Cheeze
Du hast ja die Abtastgeschwindigkeit und somit Dein "dt". Wenn Du nun Deine Werte als Array einliest, kannst Du ermitteln wie viele "dt's" es benötigt, bis Du einen bestimmten Wert über-/bzw. unterschritten hast. Somit kannst Du die Periodendauer und damit dann auch die Frequenz bestimmen..... Aber ob das genauer ist......?! Unsure

Gruß Markus

' schrieb:Genau, das war auch mein erster gedanke wenn ich die Zeit messen kann zwischen 2 Nulldurchgängen kann ich mir ja die Frequenz errechnen. Bei einem TTL Signal kann man das ja mit hilfe des NI-9401 und dem Counter rel. einfach realisieren. Beim NI-9215 muss man das glaube ich von "Hand" machen. Das ist die grösste Hürde weil ich absolut keine Idee habe wie ich das machen soll.
Der Vorschlag von Y-P ist natürlich auch eine Super variante aber wie gesagt da habe ich bedenken ob das mit dem Fenstern 100% klappt.

Gruss Cheeze
Also die Variable kann ich nicht direkt in ein Array umstellen. Im Dropdown-Menü werden zwar verschiedene Datentypen angezeigt, aber sie sind alle grau hinterlegt, sodass ich sie nicht auswählen kann. Ich habe es so gemacht, allerdings hat ein Versuch nichts gebracht. Ich habe überhaupt keine Frequenz angezeigt bekommen.

Lv86_img
So machst Du auch eine Fouriertransformation von einem einzelnen Wert. Das kann ja nicht gehen.
Du musst Deine Datn schon anders erfassen.

Gruß Markus
Der Inhalt der Variable ändert sich doch ständig in abhängigkeit der Amplitude?!
Das macht er, wenn Du die Werte einzeln ausliest. Aber Du solltest die Werte dann in eine Waveform wandeln.
In einem Array sammeln und bei Build Waveform anschließen, die Periodenlänge Deiner Abtastung an dt anschließen und einen Startwert anschließen. Schon hast Du eine Waveform und es funktioniert. (vgl. mein Bsp. mit dem Sinus)

Gruß Markus

' schrieb:Der Inhalt der Variable ändert sich doch ständig in abhängigkeit der Amplitude?!
Okayyyyy, jetzt reisst langsam der FadenSmile. Ist damit ein 2-Dimensionales Array gemeint??????
Ich habe keine Ahnung. Hmm
Hier vielleicht mal ein ganz anderer Lösungsansatz.

- Triggerunit mit Schwelle (mittels Komparator) und Flankenerkennung ( mittels Schieberegister ) implementieren
- bei entsprechender Flanke Loop-Counter (timed loop) auswerten und resetten

Hope it helps
Christian
Seiten: 1 2 3 4 5
Referenz-URLs