• Audio
  • Faust compilation error

I'm opting for the use of faust2bela now, just b/c of what you said about the online IDE approach.

It's kind of sad, TBH, how hard it is to get anything w/Faust happening....such a promising project, and I've been battling for days to get the simplest thing happening.

Anyhow, I was able to finally get the karplus project in the examples folder to build and be pushed to the board, and even the port 5510 GUI was up! But, sadly: no sound, no MIDI (and I routed my host's keyboard Alsa MIDI port to Bela's MIDI port, per usual like I would in a Csound project), and not even the 'Gate' button would produce sound. I'm guessing maybe I didn't specify -osc in the params, but then I think that's a silly oversight to have a GIU and not be able to use it via -osc....more later; still trying.

hmm I am looking into this .. FAUST seems to be using the Bela default MIDI input (hw:1,0,0), which is typically an extenral USB keyboard plugged into it. If you wanted to use instead the virtual MIDI port to the host, you'd need to apply these changes:

diff --git a/libraries/Midi/Midi.cpp b/libraries/Midi/Midi.cpp
index 99f1ebcd..e1b611c3 100644
--- a/libraries/Midi/Midi.cpp
+++ b/libraries/Midi/Midi.cpp
@@ -111,7 +111,7 @@ inId(NULL), outId(NULL), outPipeName(NULL)
        setup();
 }
 void Midi::setup() {
-       sprintf(defaultPort, "%s", "hw:1,0,0"); // a bug in gcc<4.10 prevents initialization with defaultPort("hw:1,0,0") in the initialization list
+       sprintf(defaultPort, "%s", "hw:0,0,0"); // a bug in gcc<4.10 prevents initialization with defaultPort("hw:0,0,0") in the initialization list
        inputParser = 0;
        size_t inputBytesInitialSize = 1000;
        inputBytes.resize(inputBytesInitialSize);

We can look into making this automatic or selectable via parameters to faust2bela.

Note that currently you also need to pass -nvoices for MIDI note inputs to work. E.g.:

faust2bela -tobela -osc -midi -nvoices 1 ./examples/physicalModeling/karplus.dsp

works.

Thanks, giving this a shot now; will report later on how it went. Will also use hw:0,0 for now instead of hw:0,0,0 as you suggested since from the Bela, amidi -l reports that as the general symbolic port, and I doubt their equivalency.

they are actually equivalent. I tested it with the patch above and it works.

Drat, so for no luck getting sound, even after trying different ports for the MIDI input AND ALSO trying directly plugging into the Bela-mini with my keyboard.

Out of ideas here...with the OSC option, should I not expect sound unless I am also sending initialization mags to each parameter? Trying w/o OSC enabled now...but maybe that makes the GUI not work either :/....

A key insight: the "gate" button doesn't trigger any sound for me either, outside of any MIDI issues. I think I will need verbose logging of some sort to narrow down the issues...I suspect that although the patch appears to be running, something more fundamental (and perhaps simple) isn't in place.

<edited to add more intel here>:

Also: this is proof that hw:1,0,0 (direct plug-in to the Bela-mini's USB midi port) is working for me. And FYI, I reverted the Midi.cpp file to point to hw:1,0,0 and re-built the project.

root@bela:~/Bela# amidi -p hw:1,0,0 -d

90 30 4D
90 30 00
90 32 3E
90 32 00
90 35 23
90 35 00
90 37 3B
90 37 00
90 34 32
90 34 00
90 35 3D
90 35 00
90 32 26
90 34 32
90 32 00
90 34 00

So, whatever is going on, it's not the fault of the ability to propagate MIDI signals.

The gate signal from the GUI triggers a sound for me. Can you verify a regular Bela project (e.g. the fundamentals/sinetone example from the ide ) does indeed generate sound?

The "basic" project works -- I get the sine tone.

So, in theory, sound works. Might it be that I need the latest libHTTPD thingie?

    akjmicro ks. Might it be that I need the latest libHTTPD thingie

    May well be ... I just noticed that the GATE button works for me only after I have sent a stream of MIDI messages. Not just one note, but several ... perhaps only after I trigger Faust's voice stealing to actually steal a voice... and the button will stop working again a few seconds after the last MIDI note has been received ... pretty buggy, but this shouldn't be anything Bela-specific. Anyhow, this http GUI has been buggy for a while and my understanding from this conversation was that it wouldn't be maintained. But looking through the git log I see it has received some attention in the last few years. So, I went and rebuilt it. It didn't fix anything as far as I can tell (the issue linked above is still there and the gate still won't work before MIDI notes are received (or ever, if you click it before any notes are received)).

    On further inspection, this specific issue may not even be about the HTTPDGUI. I see that the time I can successfully press the gate button after a MIDI note was received is reduced if I increase the "damping" parameter ... This may not even be a bug but rather a "feature" of how ks_ui_MIDI , used by examples/physicalModeling/karplus.dsp is implemented in libraries//physmodels.lib, but I cannot tell by reading it as I don't really know much about FAUST ... I also see that I get a very similar issue (i.e.: no sound from on-GUI parameters if not for a brief period after MIDI notes) if I build example/physicalModeling/flute.dsp (which has no "ui_MIDI") with -nvoices X. On both karplus and flute the GATE button will work fine if you build without -nvoices X, so I'd guess that the expected behaviour is for the gate button to only really work properly when there are no MIDI voices allocated.

    By the way, I have not tried the OSC interface, but it may well be that - similarly - some functionalities may not work properly when -midi and nvoices are involved

    Now as to why you don't hear any sound when you receive MIDI notes, I'd suggest you try the following to ensure the program is actually reading from the port you are sending messages to:

    • do amidi -p hw:1,0,0 -d and verify you are getting notes. Stop it
    • do faust2bela -tobela -osc -gui -midi -nvoices 1 ./examples/physicalModeling/karplus.dsp and wait for the program to start
    • send MIDI notes to it. If it doesn't produce any sound, open a separate terminal window, ssh onto the board and do amidi -p hw:1,0,0 -d and verify it fails to start because it cannot access the MIDI device. This would suggest that the device is correctly opened by the FAUST/Bela program

    More info:

    Built the karplus patch with:

    aaron@aaron-XPS-13-9350:~/Downloads/faust/examples/physicalModeling$ faust2bela  -tobela -gui -osc -midi -nvoices 4 karplus.dsp 
    Send to bela
    /home/aaron/Downloads/faust/examples/physicalModeling/karplus
    Start communication with bela
    /home/aaron/Downloads/faust/examples/physicalModeling/karplus
    karplus
    Checking the board is up and running at root@192.168.7.2...done
    Stop running process...
    Run bela now
    uploadBuildRun START
    Copying new source files to BeagleBone...Using rsync...
       render.cpp
    Automatically detected PROJECT_TYPE: cpp 
    Running on __stretch__ with Xenomai __3__
    systemctl stop bela_startup || true
    PID=`grep bela-audio  /proc/xenomai/sched/stat | cut -d " " -f 5 | sed s/\s//g`; if [ -z $PID ]; then [ true = true ] || echo "No process to kill"; else [  true = true  ] || echo "Killing old Bela process $PID"; kill -2 $PID; sleep 0.2; kill -9 $PID 2> /dev/null; fi; screen -X -S Bela quit > /dev/null; exit 0;
    killall scsynth 2>/dev/null& killall sclang 2>/dev/null& true
    echo 'Building render.cpp...'
    Building render.cpp...
    /usr/bin/clang++  -I/root/Bela/projects/karplus -I./include/legacy  -I./include -I./build/pru/ -I./ -I/usr/xenomai/include/cobalt -I/usr/xenomai/include -march=armv7-a -mfpu=vfp3 -D_GNU_SOURCE -D_REENTRANT -fasynchronous-unwind-tables -D__COBALT__ -D__COBALT_WRAP__ -DXENOMAI_SKIN_posix -DXENOMAI_MAJOR=3 -O3 -g -march=armv7-a -mtune=cortex-a8 -mfloat-abi=hard -mfpu=neon -ftree-vectorize -ffast-math -DNDEBUG -DBELA_USE_RTDM -I/root/Bela/resources/stretch/include -save-temps=obj -DENABLE_PRU_UIO=1 -std=c++11 -DNDEBUG  -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"/root/Bela/projects/karplus/build/render.d" -o "/root/Bela/projects/karplus/build/render.o" "/root/Bela/projects/karplus/render.cpp" 
    echo ' ...done'
     ...done
    echo ' '
     
    ./resources/tools/detectlibraries.sh --path /root/Bela/projects/karplus/build
    Using library Midi
    Using library OscReceiver
    Using library UdpServer
    Using library OscSender
    Using library UdpClient
    make -f Makefile.linkbela --no-print-directory /root/Bela/projects/karplus/karplus
    echo 'Linking...'
    Linking...
    /usr/bin/clang++  -Llib/ -Wl,--as-needed       -pthread -o "/root/Bela/projects/karplus/karplus" build/core/default_main.o  libraries/Midi/build/Midi.o libraries/Midi/build/Midi_c.o libraries/OscReceiver/build/OscReceiver.o libraries/OscSender/build/OscSender.o libraries/UdpClient/build/UdpClient.o libraries/UdpServer/build/UdpServer.o build/core/FormatConvert.o build/core/OscillatorBank_routines.o build/core/math_runfast.o build/core/Gpio.o build/core/I2c_Codec.o build/core/BelaContextFifo.o build/core/Mmap.o build/core/RTAudio.o build/core/PruBinary.o build/core/RTAudioCommandLine.o build/core/Mcasp.o build/core/AuxTaskNonRT.o build/core/AuxTaskRT.o build/core/board_detect.o build/core/WSServer.o build/core/AuxiliaryTasks.o build/core/DataFifo.o build/core/I2c_MultiI2sCodec.o build/core/PRU.o build/core/GPIOcontrol.o build/core/I2c_MultiTLVCodec.o build/core/PruManager.o build/core/MiscUtilities.o build/core/I2c_MultiTdmCodec.o build/core/Spi_Codec.o build/core/JSONValue.o build/core/BelaContextSplitter.o build/core/DigitalChannelManager.o build/core/IirFilter.o build/core/JSON.o /root/Bela/projects/karplus/build/render.o -lHTTPDFaust -lasound     -L/usr/xenomai/lib -lcobalt -lmodechk -lpthread -lrt -lprussdrv -lasound -lseasocks
    echo ' ...done'
     ...done
    echo "Running" /root/Bela/projects/karplus/karplus 
    Running /root/Bela/projects/karplus/karplus
    sync& cd /root/Bela/projects/karplus && /root/Bela/projects/karplus/karplus 
    Started with 4 voices
    Faust httpd server version 0.73 is running on TCP port 5510
    ALSA lib rawmidi_hw.c:233:(snd_rawmidi_hw_open) open /dev/snd/midiC1D0 failed: No such device
    initconnect
    7 widgets, OSC Adresses:
    /Polyphonic/Voices/Panic 0.000000 to 1.000000
    /Polyphonic/Voices/karplus/params/freq 50.000000 to 1000.000000
    /Polyphonic/Voices/karplus/params/bend -2.000000 to 2.000000
    /Polyphonic/Voices/karplus/params/damping 0.000000 to 1.000000
    /Polyphonic/Voices/karplus/params/gain 0.000000 to 1.000000
    /Polyphonic/Voices/karplus/params/sustain 0.000000 to 1.000000
    /Polyphonic/Voices/karplus/gate 0.000000 to 1.000000
    connected

    Check via ssh that the MIDI connection is busy:

    root@bela:~# amidi -l
    Dir Device    Name
    IO  hw:0,0    f_midi
    I   hw:1,0,0  KeyRig 49 MIDI 1
    root@bela:~# amidi -p hw:1,0,0 -d
    ALSA lib rawmidi_hw.c:233:(snd_rawmidi_hw_open) open /dev/snd/midiC1D0 failed: Device or resource busy
    cannot open port "hw:1,0,0": Device or resource busy

    But still no sound when I play the keyboard attached. No such issues with a Csound patch. Also, no sound after playing the keyboard and hitting the Gate button in the GUI, either. I'm about to all but give up on faust.... :/

    I do wonder about:

    ALSA lib rawmidi_hw.c:233:(snd_rawmidi_hw_open) open /dev/snd/midiC1D0 failed: No such device

      akjmicro I'm about to all but give up on faust.... :/

      the "fun" thing here is that this is not FAUST's fault: FAUST is just a C++ project that uses Bela's Midi class, just like PureData and Csound and the C++ code below do. So it should work well just the same!

      akjmicro ALSA lib rawmidi_hw.c:233πŸ™snd_rawmidi_hw_open) open /dev/snd/midiC1D0 failed: No such device

      That means that there is another program using that port (this should be hw:1,0,0). Did you stop any amidi -d -p hw:1,0,0 running when you started the FAUST project? Only one program at a time can access that port.

      Can you try to run the program below ? If it runs successfully, stop it and run the faust program immediately after it. Does it still show the same ALSA lib error line ?

      If the error persists, to find out what process has the port open, run:

      find /proc/*/fd -lname "/dev/snd/*" -exec bash -c 'ps -`echo {} | sed "s:/proc/\([0-9]*\)/fd/.*:\1:"`' \;
      #include <Bela.h>
      #include <libraries/Midi/Midi.h>
      
      Midi gMidi;
      
      bool setup(BelaContext *context, void *userData)
      {
      	// Initialise the MIDI device
      	if(gMidi.readFrom("hw:1,0,0") < 0) {
      		fprintf(stderr, "Unable to read from MIDI port\n");
      		return false;
      	}
      	gMidi.enableParser(true);
      
      	return true;
      }
      
      void noteOn(int noteNumber, int velocity)
      {
      	printf("note on: %d %d\n", noteNumber, velocity);
      }
      
      void noteOff(int noteNumber)
      {
      	printf("note off: %d\n", noteNumber);
      }
      
      void render(BelaContext *context, void *userData)
      {
      	// At the beginning of each callback, look for available MIDI
      	// messages that have come in since the last block
      	while(gMidi.getParser()->numAvailableMessages() > 0) {
      		MidiChannelMessage message;
      		message = gMidi.getParser()->getNextChannelMessage();
      		message.prettyPrint();		// Print the message data
      
      		// A MIDI "note on" message type might actually hold a real
      		// note onset (e.g. key press), or it might hold a note off (key release).
      		// The latter is signified by a velocity of 0.
      		if(message.getType() == kmmNoteOn) {
      			int noteNumber = message.getDataByte(0);
      			int velocity = message.getDataByte(1);
      
      			// Velocity of 0 is really a note off
      			if(velocity == 0) {
      				noteOff(noteNumber);
      			}
      			else {
      				noteOn(noteNumber, velocity);
      			}
      		}
      		else if(message.getType() == kmmNoteOff) {
      			// We can also encounter the "note off" message type which is the same
      			// as "note on" with a velocity of 0.
      			int noteNumber = message.getDataByte(0);
      			noteOff(noteNumber);
      		}
      	}
      }
      
      void cleanup(BelaContext *context, void *userData)
      {
      }

      Ok, I'm happy to report I finally got MIDI triggering and sound!

      But, it wasn't via hw:1,0,0, which for some reason stubbornly resisted my attempts. For all I know, it might be a faulty bit of hardware in the USB port of the Bela. Like, a bad contact or something....however, when I forwarded MIDI bytes over the network Alsa midi connections, and read from hw:0,0, and then sanity-checked with:
      amidi -p hw:0,0 -d ...after having linked the bytes to forward from my M-Audio KeyRig 49, and also double checking the Bela MIDI-reading with your .cpp above, it all seemed to work.

      Now, the issue I'm having is the karplus code itself; mainly the default release time on a NoteOff is a bit much. But I can continue to hack further and explore from here.

      Thanks for all the help!

      -AKJ