Ist ein Frequenzfilter-Programm realisierbar?



  • Nun ich hatte leztens den ATTiny2312 zur Hand, habe dort eine Schaltung fürn Taschenrechner nachgebaut und hier die Software überspielt.

    Wenn ich aber so in das Programm hinein schaue, sehe ich = nichts 🤡



  • @Volkard:

    c) den Filter als digitales Filter programmieren, die Koeffizienten der Differenzengleichung aus der Frequenzganggleichung gewinnen (Übergang von Frequenzgang auf z-Transformierte). Funktioniert super, ist sehr performant programmierbar (z.B. mit MAC-Befehl) und auch gut wartbar.



  • volkard schrieb:

    b) die filterhadware simulieren. vorteil: sehr perfomant. nachteil: kompliziert und praktisch nicht wartbar.

    Was ist an IIR Filtern praktisch nicht wartbar?
    Für einfache IIR Filter mit wenigen Taps gibt es AFAIK durchaus gute Formeln die sehr stabile Filter ausspucken.

    ----

    @Dorfler1000:
    Wieso willst du es denn nicht mit ganz normalen analogen Filtern machen?

    Digital wird vermutlich mit deinem Kenntnisstand nicht drin sein. Dazu müsstest du einen DSP mit zwei Wandlern (1x AD und 1x DA) zusammenknoten, und natürlich noch den DSP programmieren. Beides weitaus komplizierter als ein paar OpAmps, Kondensatoren und Widerstände zusammenzuschalten.

    Wenn du irgendwoher ein fertiges Board bekommst wäre es vielleicht denkbar. Aber nichtmal dann würde ich sowas digital machen, wenn es nur um einen einfachen Subsonic-Filter geht.

    Mach einen Linkwitz-Riley Filter 4. Ordnung (24 dB/Okt), und lass gut sein.



  • edit: ich ziehe mich zur Konsultation zurück.



  • Marc++us schrieb:

    @Volkard:

    c) den Filter als digitales Filter programmieren, die Koeffizienten der Differenzengleichung aus der Frequenzganggleichung gewinnen (Übergang von Frequenzgang auf z-Transformierte). Funktioniert super, ist sehr performant programmierbar (z.B. mit MAC-Befehl) und auch gut wartbar.

    Meinst du einen straight-forward implementierten FIR Filter?

    Bei kleinen Filter-Kernels ist das OK. Bei grösseren ist es deutlich performater die Kreuzkorrelation mittels FFT zu berechnen. Dadurch steigt zwar die Latenz, dafür sinkt die Komplexität von O(M * N) auf O(M * log N) (M=#samples, N=kernel-grösse).

    Bei Filtern mit einigen tausend Taps kann das schon nen deutlichen Unterschied machen. Und gerade im Bassbereich hat man oft lange Filter...



  • @Marc++us @hustbaer: ist mir völlig neu, daß man dazu einen guten zugang hat. nett, zu wissen.
    ich hatte mit meiner performance-aussage nur mini-filter im sinn. aber habe jetzt nichts mehr im sinn. nicht, bevor ich mich in die neue welt eingelesen habe. 😋



  • hustbaer schrieb:

    Marc++us schrieb:

    @Volkard:

    c) den Filter als digitales Filter programmieren, die Koeffizienten der Differenzengleichung aus der Frequenzganggleichung gewinnen (Übergang von Frequenzgang auf z-Transformierte). Funktioniert super, ist sehr performant programmierbar (z.B. mit MAC-Befehl) und auch gut wartbar.

    Meinst du einen straight-forward implementierten FIR Filter?

    Nein, er meint einen straight-forward implementierten IIR-Filter.



  • volkard schrieb:

    @Marc++us @hustbaer: ist mir völlig neu, daß man dazu einen guten zugang hat. nett, zu wissen.

    Das ist eigentlich total alt. Design im "analogen", dann Diskretisierung mit z.B. der bilinearen Transformation.



  • Hi,

    also ist das ganze doch nicht so einfach wie ich mir das vorstellte!!??

    Mit analogen Werten kann son Programm/Speicherbaustein nichts anfangen??

    Muss eine AD Umwandlung erfolgen?



  • Dorfler1000 schrieb:

    Hi,

    also ist das ganze doch nicht so einfach wie ich mir das vorstellte!!??

    Mit analogen Werten kann son Programm/Speicherbaustein nichts anfangen??

    Muss eine AD Umwandlung erfolgen?

    OMG.
    Wenn du nichtmal weisst was du nicht weisst, wie willst du dann eine Schaltung aufbauen???



  • Tim schrieb:

    hustbaer schrieb:

    Marc++us schrieb:

    @Volkard:

    c) den Filter als digitales Filter programmieren, die Koeffizienten der Differenzengleichung aus der Frequenzganggleichung gewinnen (Übergang von Frequenzgang auf z-Transformierte). Funktioniert super, ist sehr performant programmierbar (z.B. mit MAC-Befehl) und auch gut wartbar.

    Meinst du einen straight-forward implementierten FIR Filter?

    Nein, er meint einen straight-forward implementierten IIR-Filter.

    Hihi. OK. Immer diese Fachbegriffe 🙂

    EDIT: Hier fehlt mir wohl gerade die nötige Mathematik 🙂
    Aber... wenn ich es richtig verstehe muss man sich die Frequenzganggleichung schon "passend" aussuchen, um einen sinnvollen IIR Filter zu bekommen (d.h. einen der nicht zu gross wird). Korrekt?



  • hustbaer schrieb:

    OMG.
    Wenn du nichtmal weisst was du nicht weisst, wie willst du dann eine Schaltung aufbauen???

    Was soll das?
    Ich absoluter Neuling hier im Gebiet, Schaltungen aufbauen kein Ding, aber von solch IIR Filter oder weiß der Geier hab ich keine Ahnung...



  • hustbaer schrieb:

    Aber... wenn ich es richtig verstehe muss man sich die Frequenzganggleichung schon "passend" aussuchen, um einen sinnvollen IIR Filter zu bekommen (d.h. einen der nicht zu gross wird). Korrekt?

    Ich verstehe ehrlich gesagt nicht so ganz was du meinst 🙂



  • Dorfler1000 schrieb:

    hustbaer schrieb:

    OMG.
    Wenn du nichtmal weisst was du nicht weisst, wie willst du dann eine Schaltung aufbauen???

    Was soll das?
    Ich absoluter Neuling hier im Gebiet, Schaltungen aufbauen kein Ding, aber von solch IIR Filter oder weiß der Geier hab ich keine Ahnung...

    Was hustbär dir klarmachen wollte ist, dass dir auf den relevanten Gebieten (Mikrocontroller, Programmierung, "digital") einfach die Substanz fehlt. Das musst du ändern, denn ansonsten heisst die Antwort auf die Frage "Ist ein Frequenzfilter-Programm realisierbar?": "Ja, aber nicht von dir". Klingt hart, ist aber so. Nicht böse gemeint.



  • Dorfler1000 schrieb:

    Ich absoluter Neuling hier im Gebiet, Schaltungen aufbauen kein Ding, aber von solch IIR Filter oder weiß der Geier hab ich keine Ahnung...

    Du mußt für eine digitale Verarbeitung natürlich aus den analogen Werten digitale Werte machen, und mit denen muß man ein wenig anders umgehen. Vielleicht wäre es eine gute Idee, sich vorher ein paar Gedanken zu machen, bevor du einfach blind drauflosbastelst.



  • Tim schrieb:

    hustbaer schrieb:

    Aber... wenn ich es richtig verstehe muss man sich die Frequenzganggleichung schon "passend" aussuchen, um einen sinnvollen IIR Filter zu bekommen (d.h. einen der nicht zu gross wird). Korrekt?

    Ich verstehe ehrlich gesagt nicht so ganz was du meinst 🙂

    Naja, wenn ich mir einfach irgendeinen Frequenzgang aussuche, dann stehen die Chancen wohl sehr schlecht, dass ich mir daraus einen IIR Filter basteln kann, der mir halbwegs wenigen Taps auskommt (oder Stufen oder Operationen oder wie auch immer man das korrekt nennt). Natürlich kann ich mehr oder weniger gute Annäherungen mit mehr oder weniger Taps realisieren, aber ich gehe mal davon aus dass man sehr geringe Abweichungen möchte.

    Von daher hätte ich mir gedacht dass es wohl einfacher ist, wenn man sich gleich ein bekanntes IIR Filter Design aussucht für das es vorgegebene Formeln gibt, und dann nurmehr die gewünschte Grenzfrequenz einsetzt.

    ----

    Mit FIR Filtern weiss ich inetwa wie man es angeht, ist ja auch relativ einfach: Filtergrösse aussuchen, gewünschten Frequenzgang basteln (diskret), iDFT drüber, und fertig sind die Koeffizienten für den FIR Filter.

    Und da die z-Transformation ja ne enge Verwandte der Fourier-Transformation ist, hab' ich einfach mal angenommen dass das gemeint gewesen war.

    ----

    Aber wie gesagt: mir fehlt da etwas die Mathematik dahinter, und von daher kann leicht sein dass ich was grundlegend falsch verstanden habe. Vielleicht verstehe ich ja unter Frequenzganggleichung etwas gänzlich falsches.



  • hustbaer schrieb:

    Tim schrieb:

    hustbaer schrieb:

    Aber... wenn ich es richtig verstehe muss man sich die Frequenzganggleichung schon "passend" aussuchen, um einen sinnvollen IIR Filter zu bekommen (d.h. einen der nicht zu gross wird). Korrekt?

    Ich verstehe ehrlich gesagt nicht so ganz was du meinst 🙂

    Naja, wenn ich mir einfach irgendeinen Frequenzgang aussuche, dann stehen die Chancen wohl sehr schlecht, dass ich mir daraus einen IIR Filter basteln kann, der mir halbwegs wenigen Taps auskommt (oder Stufen oder Operationen oder wie auch immer man das korrekt nennt). Natürlich kann ich mehr oder weniger gute Annäherungen mit mehr oder weniger Taps realisieren, aber ich gehe mal davon aus dass man sehr geringe Abweichungen möchte.

    Von daher hätte ich mir gedacht dass es wohl einfacher ist, wenn man sich gleich ein bekanntes IIR Filter Design aussucht für das es vorgegebene Formeln gibt, und dann nurmehr die gewünschte Grenzfrequenz einsetzt.

    Typischerweise gibt man ein Toleranzband vor, in dem sich der analoge Filter befinden soll. Abhängig von Filtercharakteristik (Bessel, Butterworth, Cauer, Tschebyscheff 1/2, ...) ergibt sich dann die Ordnung des Filters und auch die Übertragungsfunktion. Diesen analogen Filter diskretisiert man dann (s.o. z.B. mit bilinearer Trafo).



  • Tim schrieb:

    Abhängig von Filtercharakteristik (Bessel, Butterworth, Cauer, Tschebyscheff 1/2, ...) ergibt sich dann die Ordnung des Filters und auch die Übertragungsfunktion. Diesen analogen Filter diskretisiert man dann (s.o. z.B. mit bilinearer Trafo).

    Das meinte ich mit "passend aussuchen".

    Würde ich nicht mit einem Bessel/Butterworth/... Frequenzgang anfangen, sondern eben mit *irgendwas*, würde ich wohl kaum einen "praktischen" IIR Filter rausbekommen.



  • wie ich sehe, wisst ihr was zu tuen ist...

    Von daher --> könnt ihr mir was basteln? 🤡

    Spaß beiseite, im Anfangspost erwähnte ich bereits, dass ich mich in die Sache reinarbeiten will (Grundlagen usw...)

    Wo mache ich mich am besten schlau? Gibts Tutorial`s etc.??
    Ich möchte jetzt nicht nächste Woche gleich nen fertschs Prog auf die Beine stellen, aber irgendwo muss man ja mal anfangen.

    Dass dieses Projekt für mich nicht zu schaffen ist (zur Zeit), das ist klar !!

    🕶



  • Naja das hängt jetzt stark davon ab was du genau machen willst.

    Das Projekt ansich ist ja nun IMO nicht wirklich ein sinnvolles Ziel - einen Tiefpassfilter kann man viel einfacher bekommen, dazu muss man wie gesagt keine Digitaltechnik einsetzen, und schon garnicht programmieren können.

    Also: was genau willst du lernen? Bzw. was willst du mit dem erlernten dann machen können, ausser Tiefpassfilter zu implementieren.

    p.S.: du schreibst "meine kleine PA Anlage". PA Anlagen werden ja normalerweise verwendet um bei Events (Feiern, Zeltfeste, ...) zu spielen, in Discos oder ähnliches. Was ich so mitbekommen habe ist es da schon sehr üblich, dass man keine CDs mehr auflegt, sondern alles mit dem Computer macht. Wäre es dann nicht interessanter ein DSP-Plugin für die Software zu schreiben, mit der du "auflegst"?


Anmelden zum Antworten