-
Notifications
You must be signed in to change notification settings - Fork 56
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
User friendly web interfaces for plugins. #122
Comments
@dspverden any comment is appreciated. |
I highly appreciate that. Although, I don't have the time to dive into the details of those frameworks atm. If you want to do something, just do it. The communication with the Aurora board is a simple REST API, data is transferred by JSON. It is easy to understand from the JavaScript I think. |
Re memory constraints: I am not a huge fan of cloud stuff, but maybe exposing just an API on the ESP (and maybe the basic UI?) and storing the static HTML/JS of the advanced UI somewhere else might be an option (at least for prototyping). E.g. I have a Linux NAS that's always-on, others have their RPi, etc. And if its just static code, it could even be stored on the users local filesystem. For the general public, you could also put it on a GitHub-hosted github.io (and maybe offer to install it as a PWA so it works offline; do PWAs work offline?). IIRC you (Raphael) are already using a filesystem lib, I suppose that's already compressing the content? Is the mentioned userdata also handled by it? If the FIR floats are stored as ASCII there could also be potential savings by storing them in a binary format. |
Memory limitation is the biggest problem here indeed. There are already some approaches getting popular JS frameworks running on a ESP32. Of course it will impossible to load your JS app with a lot of external packages and expect it to fit into the ESP memory. But a PoC is described here: https://www.pschatzmann.ch/home/2020/04/08/progressive-javascript-frameworks-with-microcontrollers-vue-js-on-esp32/ I will try to to port the 8channel plugin as an PoC and see how it goes. I will keep you updated. @archi: This is a possible solution but creates even more complexity and dependencies. Not everybody has an NAS at home and also not everybody wants to expose its Aurora to the internet. Especially based on the experience with the majority of the users, who are using the Aurora it will be too confusing for them. I would prefer a standalone solution with all data providing by the local ESP. |
Cloud solutions are not good, indeed. Many users run their Aurora offline via an ad-hoc connection. They don't have access to a cloud then. Regarding file system: All user settings (filter coeffs, eq settings etc.) are stored in a binary format on the internal NOR flash. The develop branch has already a commit that introduces a new feature: All html, js and css stuff can now be stored compress (.gz file) on the internal NOR flash. |
Exposing wouldn't be necessary, and a bad idea overall; I totally agree with you there :) But there are at least these two options I can quickly come up with:
Of course putting everything on the Aurora is better, and if you're looking for someone to bash "cloud-native" and ask questions later: I'm your man ;) It was just an idea in case the better/proper solution should turn out to be absolutely, definitely and under any and all circumstances not realistically feasible. //edit: Ah, dspverden was a bit quicker than I was. With gzip added, this might already help a lot. You might also want to look at other algorithms supported by browsers these days. Usually the ESP should not need to decompress the HTML/JS, only deliver it with the apropriate headers. |
The ESP only delivers. There is a new python script available that compresses all the GUI stuff needed for a DSP plugin. I just used gzip because it is usually available on *nix machines and than I found a python lib for it. |
I have finally found some time to redo the frontend. Here is a sneak preview of a very early alpha stage. I am happy about comments. The huge benefit will be the visualization of settings using line charts AND a feature to be able to import REW PEQ files. Btw... How much space do we have left on the ESP32? Also while refaactoring the frontend I have noticed that the backend API is not built according to best practices. But this is a whole another task and not for now... |
I like the style of the current GUI. Dark, minimalistic and not too many buttons to click. |
Progress is going well... Here is another sneak preview -- but animated this time! E.g. in my oponion a bypass sbould be activated with only one click, so I put it on the main page. I have so many ideas for backend refactoring but first things first! Two big steps still to do for the frontend:
And here I am kinda stuck. I would like to calculate and display the charts adequate based on the chosen filter and frequency. Every Filter (Bessel, Butterworth, Linkwitz-Riley) has its own curve. How do I calculate them for visualization. Does anybody has the formulas? @dspverden: Maybe you can help here? If somebody is interested in the technical facts: The frontend is build as a singlepage application (SPA) with the help of SvelteKit, Bulma and Chart.JS. This means, I can automate a lot of code generation and do not have the need to copy & paste, for instance, all the sound processing blocks, input selects etc. The temple engine handles this for me. I will push the code soon to my github account. Also due tree shaking and post processing the final web files are only a few hundred kbs in size. Still do not know, how much space we actually have left on the ESP32. |
I can explain to you, how to calculate frequency responses. To get the amplitude for a frequency
where To get the response of multiple filters, simply multiply their transfer functions. eg:
Update: Sometime the formulas you find on wikipedia don't contain the cutoff frequency. |
Hi, Looks cool, what you did so far! Regarding filter transfer functions: The formulas for each filter are given in the help file of SigmaStudio. There you can see how the parameters are used by the formulas. Regarding memory: You have almost nothing. You have 1.5MB for user data. That includes everything: Stored preset and plugin files and GUI files. The file size for storing presets is a bit difficult to estimate. It depends on the plugin itself (which and how many filter blocks are used). I think the 4FIRs is a good guess how big it can be. You have one file per preset. My plugins define four presets. But if customers make their own forks, there could be more or less presets. |
Thank both of you for the explanation of the transfer functions. I think, I have understood it so far (maybe there is still some potential left). SigmaStudio wiki has truly some transfer functions explained: https://wiki.analog.com/resources/tools-software/sigmastudio/toolbox/filters/general2ndorder What are the coefficients for underneath the transfer functions? Is there a more efficient way to solve the transfer function using the coefficients? Also the SigmaStudio wiki does not contain any transfer function details for Linkwitz-Riley filters. Any idea, where to get them? They are somehow explained here but a little bit tricky to understand: https://www.linkwitzlab.com/filters.htm I have googled for some already existing transfer function implementations and came across "Bode Plots", which is basically the plotting of magnitude (amplitude) and phase. There are not much implementation for JS:
I have a few question:
The implementation is here in the currently commented section: https://github.com/exislow/freeDSP-Aurora-Svelte-Frontend/blob/master/src/routes/ModalChartGeneric.svelte#L105 Somehow I am stuck again, maybe due to the fact, that I have just seen mathematical equation today and haven't sorted everything out so far... I appreciate any comments on this! Alternatively... What do you think? Is any implementation of the Bode Plots (1. - 3.) correct and could be altered successfully for our purposes? What do you think looks the most promising? |
https://github.com/exislow/freeDSP-Aurora-Svelte-Frontend/blob/master/src/routes/ModalChartGeneric.svelte#L106 |
Have a look at the file AudioFilterFactory.cpp in the ESP32 code. |
Thank you for the hint. I had totally forgotten the complex number. So I did basically a small re-implementation (https://github.com/exislow/freeDSP-Aurora-Svelte-Frontend/blob/1756f4c9346f487d820b5cf377c6b535d96f9d52/src/routes/ModalChartGeneric.svelte#L106-L108) based on https://github.com/asparagii/bodeplot-viz/blob/master/src/script.js#L82 The Bessel 3rd order filter looks now like this (axis are adjusted): Can anybody tell me, if this output is correct for a 3rd order Bessel filter? If it is correct I would like to re-facotr and optimize my code based on this. Right now I am still a little bit confused and not just, if this output is correct. If this output is correct my next question would be:
If I follow this suggestion:
and As you see, the filter starts do cut-off around 22Hz and not at 200Hz. What did I do wrong? Or must be the formula like this
Thank you very much. I should have found that by myself... |
That's the correct way doing it. I don't fully understand the plotting code. But to me it looks like you forgot 2*pi after your refactoring. |
Damn you are genius! Now it looks somehow as expected: Just be sure: Do you think, based on the output, that the implementation of the 3rd order Bessel filter is correct? If yes, I will re-factor and optimize my code, so I can implement it for each block respectively. Right now the line chart code + calculation is just a prototype.
// Math.JS is basically able to convert every formula given as string to a computable equation. This is what is done in the next two lines.
const transfer_function = mathjs.parse('15 / ((s/1256.63)^3 + (6 * (s/1256.63)^2) + (15 * (s/1256.63)) + 15)')
const compiled_tf = transfer_function.compile()
// Here I basically tell MathJS, that s is my variable and should be replaced with `mathjs.complex(0, f * 2 * Math.PI)`
// This is basically the aquivalent of `H(s)`.
const magnitudeEquation = compiled_tf.eval({s: mathjs.complex(0, f * 2 * Math.PI)})
// Since MathJS has computed `H(s)` I ask MathJS to convert the result to polar coordinates and return me the real number.
const magnitudePolar = magnitudeEquation.toPolar()
const magnitude = magnitudePolar.r Is it more understandable now? Update:
Here is the source: https://github.com/freeDSP/freeDSP-aurora/blob/6ebdf607493865ae2f485185a327978fcdd1b969/SOURCES/WEBAPP/ESP32/aurora/AudioFilterFactory.cpp The filters are implemented as BiQuads, which means it uses |
The shape looks right, but the slope is too steep. Any 3rd order lowpass should be -18dB/octave. And your plot is showing -27dB per octave.
Sorry, I meant the code around was not clear to me. That part was already good.
The z-space is defined on the unit circle. Where f=0 is z=1 and f = nyquist is z = -1. |
Under this assumption the output of my formula should actually be (if cut-off frequency is 200 Hz):
but this is not the case. My plot show at
What is wrong...? I have fixed the x-axis scaling for better readability: Furthermore thank you for the z-space function and the Wikipedia link. I am getting more and more in detail with this topic. Feels great! |
The newest one looks right. 👍 |
I do not get... Why is this correct? I thought a 3rd order lowpass has 18dB/octave. My cut-off frequency was is set to 200 Hz. Thus the result should be:
Where is my calculation wrong? Or can you explain me how you calculated this values?
|
Those filters doesn't reach their maximum steepness at the cutoff frequency. So you need to look at a point where the gradient doesn't change anymore.
I took those numbers out of your last diagram. |
I know that. I was more like: Can you explain me, why those numbers are correct, despite it is in my diagram. But anyway, I take like it is for now and try to implement the remaining features. Those algorithms can be changed easily later, if any mistake is still there. Thank you very much (honestly!) for your support so far. I appreciate it a lot. |
Have a look into the art of VA filter design. |
Just to give you a small update: I'm still on it. Almost finished to re-implement the current functions in a more modern way. Soon all the advantages to ease up your life will be implemented, so I can release the first version of the new 8channel plugin. |
Hi ! existlow do you continue to develop the new interface ? |
Despite the fact that I was busy with something else in the meantime I am still developing this UI. You can see the progress in my personal repo (link posted somewhere up here). There is "only" the PEQ visualization part left to be done. I hope, I can release the UI for beta testing soon. |
Just a quick update here: I am currently working on a first usable beta of this plugin. But there are some issues to compile all the Svelte code into a single JS file. After this problem is solved I will offer the plugin for download for everybody who likes to test it. The current code can be found here: https://github.com/exislow/freeDSP-Aurora-Svelte-Frontend/tree/biquad P.S.: I know, it's been a while, but this had some private reasons... |
Finally, I am able to present the first running beta of my work: This is the new web interface for the 8channel v2.2.2 plugin. You can get the beta here: 8channels_new_v2.2.2.zip What are the advantages of this new web interface?
Known Issues:
If you like to submit bugs, ideas etc. please create an issue here: https://github.com/exislow/freeDSP-Aurora-Svelte-Frontend/issues I will not support any issues in this thread. Thank you for your understanding. |
The current web interfaces of the plugins are very basic and hard to handle. If you like to change, e.g. EQ settings you only have a simple input based interface. Why not make it interactive using some more javascript?
I would like to help and re-create the plugin webinterfaces in a more user friendly manner. There are already approaches to get output of several JS based frameworks on ESP32, for instance, https://github.com/ayushsharma82/ESP-DASH.
Is this something considerable? If yes, I would like to submit some PoCs.
The text was updated successfully, but these errors were encountered: