/* MicroMDAEPiano MicroMDAEPiano is a port of the MDA-EPiano sound engine (https://sourceforge.net/projects/mda-vst/) for the Teensy-3.5/3.6 with audio shield. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef __mdaEPiano__ #define __mdaEPiano__ #include #include #include #include "config.h" #define NPARAMS 12 //number of parameters #define NPROGS 8 //number of programs #define NOUTS 2 //number of outputs #define SUSTAIN 128 #define SILENCE 0.0001f //voice choking #define WAVELEN 422414 //wave data bytes extern config_t configuration; class mdaEPianoProgram { friend class mdaEPiano; private: float param[NPARAMS]; char name[24]; }; struct VOICE //voice state { int32_t delta; //sample playback int32_t frac; int32_t pos; int32_t end; int32_t loop; float env; //envelope float dec; float f0; //first-order LPF float f1; float ff; float outl; float outr; int32_t note; //remember what note triggered this }; struct KGRP //keygroup { int32_t root; //MIDI root note int32_t high; //highest note int32_t pos; int32_t end; int32_t loop; }; class mdaEPiano { public: mdaEPiano(); ~mdaEPiano(); virtual void process(int16_t *outputs_r, int16_t *outputs_l); void noteOn(int32_t note, int32_t velocity); virtual bool processMidiController(uint8_t data1, uint8_t data2); virtual void setProgram(int32_t program); virtual void setParameter(int32_t index, float value); virtual float getParameter(int32_t index); virtual void resume(); void reset_voices(void); int32_t guiUpdate; void guiGetDisplay(int32_t index, char *label); private: void update(); //my parameter update void fillpatch(int32_t p, char *name, float p0, float p1, float p2, float p3, float p4, float p5, float p6, float p7, float p8, float p9, float p10, float p11); mdaEPianoProgram* programs; float Fs, iFs; ///global internal variables KGRP kgrp[34]; VOICE voice[NVOICES]; int32_t activevoices; short *waves; float width; int32_t size, sustain; float lfo0, lfo1, dlfo, lmod, rmod; float treb, tfrq, tl, tr; float tune, fine, random, stretch, overdrive; float muff, muffvel, sizevel, velsens, volume, modwhl; float vol; uint8_t curProgram; }; #endif