| Size: 6476 Comment:  | Size: 6613 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 32: | Line 32: | 
| ==== Firmware page by page ==== | ==== Firmware ==== | 
| Line 35: | Line 35: | 
| This is the current Main File: [[MicrodecAsm|Microdec1]] | * [[MicrodecAsm|Main File]] | 
| Line 37: | Line 37: | 
| This is a listing of the pre-programmed functions: [[StockFunctions|Stock Functions]] | * [[StockFunctions|Stock Functions]] | 
| Line 39: | Line 39: | 
| And here is a compiled hex file with the stock functions: [[attachment:microdec1.hex|microdec1.hex]] | * Compiled Hex File with the Stock Functions: [[attachment:microdec1.hex|microdec1.hex]] | 
| Line 41: | Line 41: | 
| User written programs (which can be added to the Function Bank) can be found here: [[UserPrograms|User Programs]]. | * [[UserPrograms|User Written Programs]]. | 
| Line 43: | Line 43: | 
| This is a list of useful functions (written in assembly), that can be used to save you time when programming. They are usually optimized for speed, and have 16b and 32b math operations, along with procedures for talking to the codec or other tasks required by the microcontroller: [[UsefulFunctions|Useful Functions]] | * [[UsefulFunctions|Useful Functions]] (in assembly) - These can be used to save you time when programming. They are usually optimized for speed, and have 16b and 32b math operations, along with procedures for talking to the codec or other tasks required by the microcontroller. | 
| Line 45: | Line 45: | 
| Here is an example of a delay, with extensive comments, designed to demonstrate programming the MICrODEC in assembly: [[DelayTutorialAsm|Delay Tutorial]] | * [[DelayTutorialAsm|Programming example]] - A delay program, with extensive comments, designed to demonstrate programming the MICrODEC in assembly. | 
| Line 49: | Line 49: | 
| Adding another knob: [[AddingAKnob|Adding A Knob]] | * Adding another knob: [[AddingAKnob|Adding A Knob]] | 
| Line 51: | Line 51: | 
| Talking [[MicrodecMidi|MIDI]] | * Talking [[MicrodecMidi|MIDI]] | 
| Line 53: | Line 53: | 
| Talking to the [[MicrodecCereal|serial port]] | * Talking to the [[MicrodecCereal|serial port]] | 
| Line 65: | Line 65: | 
| * [[attachment:microdec_front_text.png|front graphics png]] * [[attachment:microdec_back_text.png|rear graphics png]] | * [[attachment:microdec_text_front.png|front graphics png]] * [[attachment:microdec_text_back.png|rear graphics png]] | 
| Line 74: | Line 74: | 
| ==== Other Reprogrammable Audio Platforms ==== There are a lot of people who have made audio processing platforms. Have a look and see if any of them are more suited to what you're interested in doing. Each has its ups and downs, the major tradeoffs being cost, complexity, and audio quality. * [[OtherPlatfroms|Other Platforms]] | 
About MICrODEC
MICrODEC is a work in progress (and probably always will be). It is an open-source platform for Digital Signal Processing (DSP) that is approachable for those familiar with programming Atmel microcontrollers. For those unfamiliar, we hope its a fun excuse to learn.
The hardware itself is of moderately high quality (44.1ksps, 16bit, stereo, -96dB noise, 3Hz - 18kHz frequency response), and has built in features for use with audio effects (wet/dry mix, feedback, mic./instrument/line level inputs). Because of the high data rate, the MICrODEC does not allow for as much processing time as low-end ADC to PWM style microcontroller audio interfaces, but, with 6 seconds of sample time, plenty of useful functions can be executed in the ~400 free clock cycles per sample. And, at a lower cost in comparison to high-end DSP units, it provides a good platform for sound installations where more than a few units may be required.
Features yet implemented
- All initialization routines for the codec, microcontroller, and memory - The codec is capable of multiple sample rates, and these can be easily changed to trade-off between audio quality and processing time. The codec also has an on-board headphone driver and microphone input which can be enabled, although the off-board hardware is much better. Both input and output filters can be modified, along with gain and internal signal path.
- FTDI cable header - This will allow for connection to computers, and future bootloading capability. All of the necessary components are attached to mimic the Arduino bootloader.
- Clip and level LEDs - The level LED comes on at approximately -35dB, and becomes brighter with more signal. The clip LED turns on, and stays on for 1 second, every time the signal goes above approximately -3dB. 0dB is when distortion begins.
- Variable gain input stage - The front end presents an input impedance of 520k to AC signals, and has a variable gain of 0db to +34dB.
- Socketed op-amps - Just in case you want to fiddle around with the sound. We suggest the TLC074 for good frequency response and output drive, but unless your listening on headphones at the output, you probably won't notice too much difference with the less expensive TLV274.
- Optional jumpers - There are jumpers for installing a hard bypass switch between the input and output. There is also a jumper for installing a foot-switch in parallel with the rotary encoder push-button.
Features not yet implemented
The current MICrODEC implementation is fun to use, but there are a number of things that would make it even better.
- Internal USB - There is currently an FTDI cable header onboard, but it would be far more convenient if the case did not need to be removed to take advantage of it.
- Bootloader - Once there is USB, there can be bootloader! This would allow for downloading and trading of MICrODEC programs by those who aren't interested in the details of AVR programming.
- MIDI - An optional MIDI board would allow the MICrODEC to be controlled by external pedals, synths, and computer software. Sample MIDI code has been written and tested, so merely a break-out board is required. Currently, there is only one USART for both MIDI and USB, so a solution to allow for both is needed.
- Arduino compatibility - Although this would seriously reduce the full power of the processor, it would also allow for a wider user base.
- C code - The current assembler needs to be ported to C for those who are into such things.
Firmware
The Firmware for the MICrODEC is divided into 2 parts. The first is a Main File, which deals with initializing the microcontroller and codec, and handles the interrupt routine. The second is the Function Bank, which holds all of the commands which are executed when an interrupt is called (once per audio sample). This may or may not be the best implementation. It has the advantage of being more portable, as different programs can be dropped into the Function Bank, without having to worry about conflicts in the Main File. On the other hand, no processing can occur during idle time outside of the interrupt loop.
- Compiled Hex File with the Stock Functions: microdec1.hex 
- Useful Functions (in assembly) - These can be used to save you time when programming. They are usually optimized for speed, and have 16b and 32b math operations, along with procedures for talking to the codec or other tasks required by the microcontroller. 
- Programming example - A delay program, with extensive comments, designed to demonstrate programming the MICrODEC in assembly. 
Modifications, Additions, Enhancements
- Adding another knob: Adding A Knob 
- Talking MIDI 
- Talking to the serial port 
Documentation
Files: Beta Release
Files: Datasheets
- 4M SRAM (SRAM chips may vary, but all have the same interface) 
Other Reprogrammable Audio Platforms
There are a lot of people who have made audio processing platforms. Have a look and see if any of them are more suited to what you're interested in doing. Each has its ups and downs, the major tradeoffs being cost, complexity, and audio quality.
