Difference between revisions of "Project-jos-320c-2021"

From CCRMA Wiki
Jump to: navigation, search
(Test Pluck Help: update doc)
 
(38 intermediate revisions by the same user not shown)
Line 1: Line 1:
== JOS 320C Project Goals ==
+
= JOS 320C Project =
 +
 
 +
== Goals ==
  
 
* Make my first "meta plugin" that writes out files for other plugins to read
 
* Make my first "meta plugin" that writes out files for other plugins to read
Line 6: Line 8:
 
== Plan ==
 
== Plan ==
  
* Look at some 220C projects [https://ccrma.stanford.edu/courses/220c/] for general orientation on project reporting
+
* Look at some [https://ccrma.stanford.edu/courses/220c/ 220C projects] for general orientation on project reporting
* Read ahead in the course schedule [https://ccrma.stanford.edu/courses/320c/] to learn about GUI options
+
* Read ahead in the  [https://ccrma.stanford.edu/courses/320c/ course schedule] to learn about GUI options
 
* Decide on a file format: XML? Plain text? Encrypted?
 
* Decide on a file format: XML? Plain text? Encrypted?
  ** I am thinking plain text, including a hash string using some secret algorithm to detect modification if/when needed
+
** I am starting with plain text, and planning to include a hash string generated by a secret algorithm to detect modification if/when needed
 +
* I am now reading all GUI-related [https://juce.com/learn/tutorials JUCE tutorials] that are new since I last looked
 +
 
 +
== GUI Prototype ==
 +
 
 +
* JUCE GUI Editor used (very quick)
 +
* Band-setting sliders will be programmatically laid out dynamically
 +
** Later planning to draw the T60 curve directly, like many EQ interfaces these days
 +
* Configured for waveguide string loop filter
 +
** Can also be used to design late reverb
 +
=== Update 2021-05-06 ===
 +
* Changed name T60Designer to LoopFilterDesigner
 +
* Letting go of Reverb case for now (planning a separate plugin)
 +
* Created LoopFilterDesignerGUI from T60DesignerGUI and added a Tabbed Component
 +
* Moved T60DesignerGUI to Tab 1
 +
* Created a new IRDesignerGUI for Tab 2
 +
* Revised GUI prototype with Tab 1 and 2 selected, respectively:
 +
[[file:T60Designer.png|600px]]
 +
[[file:IRDesigner.png|600px]]
 +
=== Update 2021-05-08 ===
 +
* Started prototyping the GUI again, this time in PGM
 +
* PGM a little harder to work with at this point, but run-time editing is huge, and XML GUI description much better
 +
=== Update 2021-05-16 ===
 +
* [https://youtu.be/tsm1hp-X01w Remade GUI in PGM] and changed its layout a bit:
 +
[[file:LFD-GUI-2021-05-16.png|600px]]
 +
* The reason for making the plot more prominent at the top is to facilitate direct manipulation, as in the EqualizerExample
 +
* Now there is no need to show all the band design parameters (which requires programmatic layout)
 +
* Due to bug(s), I cannot create Classes in PGM (for editing groups of widgets all at once)
 +
* I am suspending efforts on GUI development and moving to implementations under the hood
 +
* I reported the bugs and may eventually work to debug PGM in order to resume GUI development
 +
===  Update 2021-05-29 ===
 +
* Discovered that it is super easy to edit the .xml of a PGM GUI - faster than using PGM itself!
 +
* Pulled in  the PGM EqualizerExample GUI as the starting point for my editable T60 GUI Plot:
 +
[[file:pgmxmlhack.jpg|600px]]
 +
* In Emacs, changed `parameter="string"' to `<!-- parameter="string"-->' in the .xml for now, so it will load without errors
 +
* Getting into the .xml showed me differences that led to working class-editing!
 +
** Apparently it is necessary to define some number of Nodes before Classes will work.
 +
** (I copied the Node definitions from EqualizerExample/Resources/magic.xml into my .xml)
 +
 
 +
== Project Source ==
 +
 
 +
See the <tt>jos</tt> directory of the [https://cm-gitlab.stanford.edu/jos/320C-2021  320C-2021 GitLab project] which can be cloned as follows:<br/>
 +
<tt>
 +
git clone git@cm-gitlab.stanford.edu:jos/320C-2021.git
 +
</tt>
 +
 
 +
== Loop Filter Designer Help ==
 +
 
 +
* Loop Filter Designer is an audio plugin that designs, tests, and exports digital filters to other compatible audio plugins.
 +
* The filter design is specified as the desired decay-time in each frequency band.
 +
* Decay time is specified by [https://ccrma.stanford.edu/~jos/mdft/Audio_Decay_Time_T60.html T60], which means "time in seconds to decay by 60 dB" (a term commonly used when studying [https://ccrma.stanford.edu/~jos/pasp/Artificial_Reverberation.html reverberation]).
 +
* Presently the only filter type is a String Loop Filter (loop filter used in a [https://ccrma.stanford.edu/~jos/swgt/ digital waveguide string model])
 +
* The same approach can be used to design Late Reverberator (feedback filter used to simulate [https://ccrma.stanford.edu/~jos/pasp/Air_Absorption.html air absorption] in an [https://ccrma.stanford.edu/~jos/pasp/Acoustic_Wave_Propagation_Simulation.html acoustic wave propagation model])
 +
 
 +
=== Test Pluck Help ===
 +
 
 +
The "Pluck Tester" panel in the lower-right corner provides a Pluck button for hearing the sound of a plucked waveguide string using the loop-filter designed by Loop Filter Designer.  When you like what you hear, you can Save it out as a Preset that any compatible waveguide-synthesis plugin can use.
 +
 
 +
== Audio Plugin Development Workflow Summary ==
 +
# Design the GUI using  [https://foleysfinest.com/developer/pluginguimagic/ Plugin GUI Magic] (or [https://www.youtube.com/watch?v=mJbXZgIW6xs JUCE GUI Editor])
 +
# Implement the plugin (which can go in parallel with professional GUI development)
 +
# Develop final image assets, color palettes, look-and-feel styles, etc. for a professional GUI appearance and incorporate them

Latest revision as of 00:08, 2 June 2021

JOS 320C Project

Goals

  • Make my first "meta plugin" that writes out files for other plugins to read
  • Learn how to make better GUIs for plugin Editors

Plan

  • Look at some 220C projects for general orientation on project reporting
  • Read ahead in the course schedule to learn about GUI options
  • Decide on a file format: XML? Plain text? Encrypted?
    • I am starting with plain text, and planning to include a hash string generated by a secret algorithm to detect modification if/when needed
  • I am now reading all GUI-related JUCE tutorials that are new since I last looked

GUI Prototype

  • JUCE GUI Editor used (very quick)
  • Band-setting sliders will be programmatically laid out dynamically
    • Later planning to draw the T60 curve directly, like many EQ interfaces these days
  • Configured for waveguide string loop filter
    • Can also be used to design late reverb

Update 2021-05-06

  • Changed name T60Designer to LoopFilterDesigner
  • Letting go of Reverb case for now (planning a separate plugin)
  • Created LoopFilterDesignerGUI from T60DesignerGUI and added a Tabbed Component
  • Moved T60DesignerGUI to Tab 1
  • Created a new IRDesignerGUI for Tab 2
  • Revised GUI prototype with Tab 1 and 2 selected, respectively:

T60Designer.png IRDesigner.png

Update 2021-05-08

  • Started prototyping the GUI again, this time in PGM
  • PGM a little harder to work with at this point, but run-time editing is huge, and XML GUI description much better

Update 2021-05-16

LFD-GUI-2021-05-16.png

  • The reason for making the plot more prominent at the top is to facilitate direct manipulation, as in the EqualizerExample
  • Now there is no need to show all the band design parameters (which requires programmatic layout)
  • Due to bug(s), I cannot create Classes in PGM (for editing groups of widgets all at once)
  • I am suspending efforts on GUI development and moving to implementations under the hood
  • I reported the bugs and may eventually work to debug PGM in order to resume GUI development

Update 2021-05-29

  • Discovered that it is super easy to edit the .xml of a PGM GUI - faster than using PGM itself!
  • Pulled in the PGM EqualizerExample GUI as the starting point for my editable T60 GUI Plot:

Pgmxmlhack.jpg

  • In Emacs, changed `parameter="string"' to `<!-- parameter="string"-->' in the .xml for now, so it will load without errors
  • Getting into the .xml showed me differences that led to working class-editing!
    • Apparently it is necessary to define some number of Nodes before Classes will work.
    • (I copied the Node definitions from EqualizerExample/Resources/magic.xml into my .xml)

Project Source

See the jos directory of the 320C-2021 GitLab project which can be cloned as follows:
git clone git@cm-gitlab.stanford.edu:jos/320C-2021.git

Loop Filter Designer Help

  • Loop Filter Designer is an audio plugin that designs, tests, and exports digital filters to other compatible audio plugins.
  • The filter design is specified as the desired decay-time in each frequency band.
  • Decay time is specified by T60, which means "time in seconds to decay by 60 dB" (a term commonly used when studying reverberation).
  • Presently the only filter type is a String Loop Filter (loop filter used in a digital waveguide string model)
  • The same approach can be used to design Late Reverberator (feedback filter used to simulate air absorption in an acoustic wave propagation model)

Test Pluck Help

The "Pluck Tester" panel in the lower-right corner provides a Pluck button for hearing the sound of a plucked waveguide string using the loop-filter designed by Loop Filter Designer. When you like what you hear, you can Save it out as a Preset that any compatible waveguide-synthesis plugin can use.

Audio Plugin Development Workflow Summary

  1. Design the GUI using Plugin GUI Magic (or JUCE GUI Editor)
  2. Implement the plugin (which can go in parallel with professional GUI development)
  3. Develop final image assets, color palettes, look-and-feel styles, etc. for a professional GUI appearance and incorporate them