HISE Logo Forum
    • Categories
    • Register
    • Login

    Simple ML neural network

    Scheduled Pinned Locked Moved General Questions
    134 Posts 18 Posters 11.1k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • resonantR
      resonant @Christoph Hart
      last edited by resonant

      @Christoph-Hart

      In the homepage: https://github.com/GuitarML/Automated-GuitarAmpModelling

      It says:

      Using this repository requires a python environment with the 'pytorch', 'scipy', 'tensorboard' and 'numpy' packages installed.

      Regarding the Neural node, parameterized FX example such as Distortion or Saturation is required which is currently only Sinus synth example is available on the snippet browser.

      1 Reply Last reply Reply Quote 0
      • Dan KorneffD
        Dan Korneff @Christoph Hart
        last edited by

        @Christoph-Hart it should be a pytorch model.
        This is the training script I'm testing with. It uses RTneural as a backend as well:
        https://github.com/GuitarML/Automated-GuitarAmpModelling

        Dan Korneff - Producer / Mixer / Audio Nerd

        Christoph HartC 3 Replies Last reply Reply Quote 0
        • Christoph HartC
          Christoph Hart @Dan Korneff
          last edited by

          @Dan-Korneff Ah I see, I think the Pytorch loader in HISE expects the output from this script:

          Link Preview Image
          RTNeural/python/model_utils.py at main · jatinchowdhury18/RTNeural

          Real-time neural network inferencing. Contribute to jatinchowdhury18/RTNeural development by creating an account on GitHub.

          favicon

          GitHub (github.com)

          which seems to have a different formatting.

          1 Reply Last reply Reply Quote 0
          • Christoph HartC
            Christoph Hart @Dan Korneff
            last edited by

            parameterized FX example such as Distortion or Saturation is required which is currently only Sinus synth example is available on the snippet browser.

            The parameters need to be additional inputs to the neural network. So if you have stereo processing and 3 parameters, the network needs 5 inputs and 2 outputs. The neural network will then analyze how many channels it needs depending on the processing context and use the remaining inputs as parameters.

            So far is the theory but yeah, it would be good to have a model that we can use to check if it actually works :) I'm a bit out of the loop when it comes to model creation, so let's hope we find a model that uses this structure and can be loaded into HISE.

            Dan KorneffD 1 Reply Last reply Reply Quote 1
            • Dan KorneffD
              Dan Korneff @Christoph Hart
              last edited by

              @Christoph-Hart said in Simple ML neural network:

              I'm a bit out of the loop when it comes to model creation, so let's hope we find a model that uses this structure and can be loaded into HISE.

              That'll be my homework for the day. Thanks for taking a look.

              Dan Korneff - Producer / Mixer / Audio Nerd

              1 Reply Last reply Reply Quote 1
              • C
                ccbl
                last edited by

                I realise we already hashed this discussion out, and people might be sick of it. But IMO the NAM trainer has a really intuitive GUI trainer which allows for different sized networks, at various sample rates. It also has a very defined output model format, which seems to be a sticking point with RTNeural.

                Given the existence of the core C++ library https://github.com/sdatkinson/NeuralAmpModelerCore

                Might it be easier to implement this instead, given many people want to use ML Networks for non-linnear processing for the most part?

                C 1 Reply Last reply Reply Quote 1
                • P
                  Phelan Kane
                  last edited by Phelan Kane

                  I'll just leave these here:

                  Link Preview Image
                  Introduction — Introduction to Audio Synthesizer Programming

                  favicon

                  (intro2ddsp.github.io)

                  Link Preview Image
                  GitHub - aisynth/diffmoog

                  Contribute to aisynth/diffmoog development by creating an account on GitHub.

                  favicon

                  GitHub (github.com)

                  https://archives.ismir.net/ismir2021/paper/000053.pdf

                  Link Preview Image
                  Efficient neural networks for real-time modeling of analog dynamic range compression

                  favicon

                  (csteinmetz1.github.io)

                  I'm convinced Parameter Inference and TCNs will be the future of audio plug-ins. CNN's will take over circuit modelling as the next fad. Training NN so we can map weights to params to make any sound source will take over. Just have a look at Synth Plant 2.

                  Having access to trained models from PyTorch in HISE would be awesome. A few VSTs devs are using ONNX Runtime in the cloud to store the weights and the VST calls back to perform the inferences.

                  P

                  1 Reply Last reply Reply Quote 0
                  • C
                    ccbl @ccbl
                    last edited by

                    @ccbl for instance, how I plan to use HISE is to create plugins where I use a NN to model various non-linear components such as transformers, tubes, fet preamps etc, and then use the regular DSP in between. I'm just a hobbiest who plans to release everything FOSS though, so I'll have to wait and see what you much more clever folks come up with.

                    Christoph HartC 1 Reply Last reply Reply Quote 1
                    • Christoph HartC
                      Christoph Hart @ccbl
                      last edited by

                      I realise we already hashed this discussion out, and people might be sick of it. But IMO the NAM trainer has a really intuitive GUI trainer which allows for different sized networks, at various sample rates.

                      The current state is that I will not add another neural network engine to HISE because of bloat but try to add compatibility of NAM files to RTNeural as suggested in this issue:

                      Link Preview Image
                      Add support for NAM files · Issue #143 · jatinchowdhury18/RTNeural

                      Hi Jatin, how hard would it be to add support for parsing the NAM file format? https://github.com/sdatkinson/NeuralAmpModelerCore Just from a quick peek at both sources the required layers are almost there (except for the wavenet layer w...

                      favicon

                      GitHub (github.com)

                      There seems to be some motivation by other developers to make this happen but it‘s not my best area of expertise and I have a few other priorities at the moment.

                      1 Reply Last reply Reply Quote 0
                      • Christoph HartC
                        Christoph Hart @Dan Korneff
                        last edited by

                        @Dan-Korneff said in Simple ML neural network:

                        @Christoph-Hart it should be a pytorch model.
                        This is the training script I'm testing with. It uses RTneural as a backend as well:
                        https://github.com/GuitarML/Automated-GuitarAmpModelling

                        Have you tried running it through this script?

                        Link Preview Image
                        Automated-GuitarAmpModelling/simple_modelToKeras.py at next · AidaDSP/Automated-GuitarAmpModelling

                        Contribute to AidaDSP/Automated-GuitarAmpModelling development by creating an account on GitHub.

                        favicon

                        GitHub (github.com)

                        Dan KorneffD 2 Replies Last reply Reply Quote 0
                        • Dan KorneffD
                          Dan Korneff @Christoph Hart
                          last edited by

                          @Christoph-Hart I just read the thread and found the link. Gonna give this a go first thing this morning.

                          Dan Korneff - Producer / Mixer / Audio Nerd

                          1 Reply Last reply Reply Quote 0
                          • Dan KorneffD
                            Dan Korneff @Christoph Hart
                            last edited by

                            @Christoph-Hart
                            https://github.com/AidaDSP/Automated-GuitarAmpModelling

                            There is already a script in Automated-GuitarAmpModelling named modelToKeras.
                            "a way to export models generated here in a format compatible with RTNeural"

                            I'll give both a try and report back.

                            I'm seeing that there is also a script to convert NAM dataset.

                            "NAM Dataset
                            Since I've received a bunch of request from the NAM community, I leave some infos here. Since the NAM models at the moment are not compatible with the inference engine used by rt-neural-generic (RTNeural), you can't use them with our plugin directly. But you can still use our training script and the NAM Dataset, so that you will be able to use the amplifiers that you are using on NAM with our plugin. In the end, training is 10mins on a Laptop with CUDA."

                            Dan Korneff - Producer / Mixer / Audio Nerd

                            C 1 Reply Last reply Reply Quote 0
                            • Dan KorneffD
                              Dan Korneff
                              last edited by

                              Learning curve is high on this one.
                              I've written a config script, prepared the audio files into a dataset, trained the model with dist_model_recnet.ph.
                              The model_utils.py script complained about how output_shape was being accessed, so I made a little tweak there.
                              In the end, it was able to convert the model to keras, but the layer dimensions are exporting as null.
                              Time for more beer and research

                              Dan Korneff - Producer / Mixer / Audio Nerd

                              Christoph HartC A 2 Replies Last reply Reply Quote 0
                              • Christoph HartC
                                Christoph Hart @Dan Korneff
                                last edited by

                                @Dan-Korneff yeah I tried to write the wavenet layer today for RTNeural, by porting it over from the NAM codebase, but I don't know either framework (or anything about writing inference engines lol), so it wasn't very fruitful.

                                Let me know if you get somewhere then we'll try to load it into the HISE neural engine.

                                Dan KorneffD 1 Reply Last reply Reply Quote 0
                                • A
                                  aaronventure @Dan Korneff
                                  last edited by

                                  @Dan-Korneff DId you have any luck running the colab for training? I upload input.wav and target.wav and get an error

                                  5b33d696-0c44-426c-b9fa-48bf77714e35-image.png

                                  Dan KorneffD 1 Reply Last reply Reply Quote 0
                                  • resonantR
                                    resonant
                                    last edited by resonant

                                    I don't know if it helps, but Karanyi Sounds (uses HISE) also does machine learning using HISE Neural Network with colab, they shared this photo today.

                                    As I see, if this Neural implementation is done very well, it will be really popular among developers. Lots of people would love to use this latest technology in their software.

                                    IMG_1696.jpg

                                    Dan KorneffD C 2 Replies Last reply Reply Quote 1
                                    • Dan KorneffD
                                      Dan Korneff @Christoph Hart
                                      last edited by

                                      @Christoph-Hart It seems like so many projects are abandoned, even if it's relatively new. Still researching

                                      Dan Korneff - Producer / Mixer / Audio Nerd

                                      1 Reply Last reply Reply Quote 0
                                      • Dan KorneffD
                                        Dan Korneff @aaronventure
                                        last edited by

                                        @aaronventure The tech is evolving so much that the scripts on google collab break just about every time there is an update. I got the google collab script to work for Proteus, but moved to local processing cause my GPU is better than the ones provided by google.

                                        Dan Korneff - Producer / Mixer / Audio Nerd

                                        1 Reply Last reply Reply Quote 0
                                        • Dan KorneffD
                                          Dan Korneff @resonant
                                          last edited by

                                          @resonant Invite them to the conversation

                                          Dan Korneff - Producer / Mixer / Audio Nerd

                                          LindonL 1 Reply Last reply Reply Quote 1
                                          • C
                                            ccbl @Dan Korneff
                                            last edited by

                                            @Dan-Korneff In this instance the dataset refers to the input output audio pairs that NAM uses for it's training, not the resulting model. Basically they're saying they added info in their training script that can detect the NAM audio pairs and train and Aida-X model based on those.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            17

                                            Online

                                            1.7k

                                            Users

                                            11.8k

                                            Topics

                                            102.4k

                                            Posts