Nucleo F401REでFM音源を実装するやつ 外部DACとオペアンプを利用 現在はMCP4922とNJM2737
Dependencies: AOTTrigon I2CEEPROM MCP4922 AQM0802A mbed
Fork of NuMidi401 by
NuFM401
Nucleo F401用の自作ソフトウェアMIDI音源
概要
だいたいそんなもんです。
特徴
- ブレッドボードの上で組める程度には簡単な回路構成
- 外部のDACにMCP4922を採用
- 念のためのボルテージフォロアとしてNJM2737Dを採用
- バンク用EEPROMに24FC1025を採用
- シリアル経由でMIDIデータを受信することで操作
補足
シリアル <=> MIDI のドライバにはHairless-MIDISerialをオススメします。 仮想MIDIケーブルはとりあえずMIDI Yokeで。
FMOscillator/FMAlgorithm.cpp
- Committer:
- kb10uy
- Date:
- 2015-01-29
- Revision:
- 21:e3014c1bdf9c
- Parent:
- 20:8278e607a687
- Child:
- 23:deb76bdf6f03
File content as of revision 21:e3014c1bdf9c:
#include "FMAlgorithm.h" FMAlgorithm::FMAlgorithm() { opcount = 0; cncount = 0; operators = NULL; connections = NULL; } FMAlgorithm::FMAlgorithm(int opc, int cnc) { opcount = opc; cncount = cnc; operators = new FMOperator*[opcount]; for(int i = 0; i < opcount; i++) operators[i] = NULL; connections = new FMAlgorithmConnection[cncount]; } FMAlgorithm::~FMAlgorithm() { if (operators != NULL) delete[] operators; if (connections != NULL) delete[] connections; } void FMAlgorithm::setOperator(int num, FMOperator *op) { if (num >= opcount) return; operators[num] = op; } void FMAlgorithm::setConnection(int num, int t, int s) { if (num >= cncount) return; connections[num].target = t; connections[num].source = s; connections[num].allocated = true; } void FMAlgorithm::noteOn(float freq, double time) { for(int i = 0; i < opcount; i++) { if (operators[i] != NULL) operators[i]->attackNote(freq, time); } } void FMAlgorithm::noteOff(double time) { for(int i = 0; i < opcount; i++) { if (operators[i] != NULL) operators[i]->releaseNote(time); } } float FMAlgorithm::calculate() { return calculate(0); } float FMAlgorithm::calculate(int opn) { float sum = 0; for(int i = 0; i < cncount; i++) { if (connections[i].allocated && connections[i].target == opn) { sum += calculate(connections[i].source); } } return operators[opn]->calculate(sum); }