Difference between revisions of "OSC"
m (→To add OSC functionality to your program) |
(→To add OSC functionality to your program) |
||
(One intermediate revision by the same user not shown) | |||
Line 24: | Line 24: | ||
Then you can for example send messages using | Then you can for example send messages using | ||
+ | <pre> | ||
void oscSendMessageInt(char *address, u32 arg) | void oscSendMessageInt(char *address, u32 arg) | ||
− | |||
void oscSendMessageInt(char *address, u32 arg, u32 arg2) // to send two values at once | void oscSendMessageInt(char *address, u32 arg, u32 arg2) // to send two values at once | ||
+ | </pre> | ||
+ | |||
+ | 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: | ||
+ | <pre> | ||
+ | oscSendMessageInt(PSTR("/a2d/0"), a2dConvert10bit(0)); // These three lines are inside the main while() loop | ||
+ | oscSendMessageInt(PSTR("/a2d/1"), a2dConvert10bit(1)); | ||
+ | timerPause(10); | ||
+ | </pre> | ||
+ | |||
+ | == 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: | ||
+ | <pre> | ||
+ | /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 | ||
+ | </pre> | ||
+ | |||
+ | For more examples, please see the [http://opensoundcontrol.org/ OSC website], and/or this [http://opensoundcontrol.org/files/wright-welcome.pdf presentation] on the website. You can do lots of fancy things with OSC messages, like using [http://en.wikipedia.org/wiki/Regular_expression 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. |
Latest revision as of 07:12, 8 October 2008
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:
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.