OSC

From CCRMA Wiki
Jump to: navigation, search

Open Sound Control (OSC) is a networking protocol for real-time musical control information. It was introduced in 1997 by the Center for New Music and Audio Technologies (CNMAT) in Berkeley. It is transport-independent--it can be used over UDP, TDP, WiFi, serial connections, and even within applications. We use it to transfer musical control information from the microcontroller to a computer, which is shown below as a laptop:

Overview.jpg

The FT232 chip interfaces the microcontroller with a standard Universal Serial Bus (USB) connector. We can use the USB link to open an OSC connection. The microcontroller acts as an OSC client by sending OSC messages. An application running on the computer, such as Pd, acts as an OSC server by receiving and interpreting the OSC messages.

To add OSC functionality to your program

It may be easier to hack one of the examples that uses OSC, but here are the main elements required:

Add $(AVRLIB)/uart.c $(AVRLIB)/ccrma/osc.c $(AVRLIB)/timerx8.c to the SRC line in the makefile so that the compiler knows which additional library source code is needed.

Add the proper includes at the top of the source file.

#include "uart.h"
#include "ccrma/osc.h"
#include "timerx8.h"

Somewhere early in your program initialize the UART, OSC, the timer, and set the rate at which we communicate over the serial link.

    uartInit();
    oscInit();
    timerInit();
    uartSetBaudRate(115200);

Then you can for example send messages using

void oscSendMessageInt(char *address, u32 arg)
void oscSendMessageInt(char *address, u32 arg, u32 arg2)     // to send two values at once

For example, to sample the first two ADC inputs and write them to the OSC addresses /a2d/0 and /a2d/1, we could use the following code:

     oscSendMessageInt(PSTR("/a2d/0"), a2dConvert10bit(0));     // These three lines are inside the main while() loop
     oscSendMessageInt(PSTR("/a2d/1"), a2dConvert10bit(1));
     timerPause(10);

Receiving OSC Messages in Pd

We use three objects in Pd to implement the OSC server.

  • The serialIO object allows Pd to communicate over the serial port.
  • The OpenSoundControl object parses the serial data, transforming it into lists.
  • OSCroute enables the user to strip off portions of the OSC addresses, while routing the data out the appropriate outlet.

See the help patches in Pd for more information.

OSC Addresses

We can use lots of other OSC addresses. In fact, sometimes it is enough information to only send the address, without any numbers. Here are some example addresses:

/bell1/cutoff-freq 
/glockies/midinote-off 
/glockies/midinote-on 
/ronbells/mute 
/ronbells/play/bell2a 
/ronbells/play/bell2b 
/ronbells/play/bell2c 
/ronbells/play/bell2d 
/ronbells/play/bell3a 
/ronbells/play/bell3b 
/harmtones/osc[1-8]/glissdir 
/harmtones/osc[1-8]/glissmag 
/harmtones/osc[1-8]/init 
/harmtones/osc[1-8]/mute 
/harmtones/osc[1-8]/play 
/harmtones/osc[1-8]/speaker 
/harmtones/osc[1-8]/volume-pedal 
/sampler/midinote-on 
/sampler/midinote-off 
/sampler/multisample 
/sampler/speaker 
/sampler/master-volume

For more examples, please see the OSC website, and/or this presentation on the website. You can do lots of fancy things with OSC messages, like using regular expressions such as *, ?, {a,b,c}, [a-h]. However, check first that your implementation supports all the fancy features you're trying to use.