-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathADDAC_Random.h
executable file
·71 lines (55 loc) · 2.04 KB
/
ADDAC_Random.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/*
* ADDA5664
* Version 0.1 November, 2009
* Copyright 2009 AndrŽ Gonalves
* For details, see http://
*
* AD5668 programming based on
* DAC V11 by Robin Price 2009
+
* shiftIn Example 2.1 by Carlyn Maw
*/
#ifndef ADDAC_Random_h
#define ADDAC_Random_h
#if defined(ARDUINO) && ARDUINO >= 100
#include "Arduino.h"
#else
#include <WProgram.h>
#endif
extern volatile unsigned long timer0_millis;
class ADDAC_Random{
public:
ADDAC_Random();
// MODES
float CVstream;
float actualCVstream; // replace DACvolts[4];
float oldCVstream; // replace oldDACvolts[4];
unsigned long RandomTime; // replace DACtimes[4];
unsigned long oldRandomTime;
int RandomDelay; // replace RNDdelays[4];
bool GateDelay; // replace GateDelay[4];
bool GateOut, ClockOut, StepReset;
float BrownVal;
int BROWN,BROWNTIME;
float fMin,fMax,fSeed,vMin,vMax;
float threshold;
float smooth;
int TRIGGtime;
// RANDOM
void setBrownianRandom(bool brown);
void setBrownianTime(bool brown);
void setStepReset(bool _reset);
void update(float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax, float _smooth);
void update(bool _gate, float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax, float _smooth);
private:
void CalcRandom(float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax, float _smooth);
void CalcGatedRandom(float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax, float _smooth);
void CalcGatedRandomUpdate(float _smooth);
void CalcNormalRandom(float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax);
void CalcGaussianRandom(float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax);
void CalcBrownianRandom(float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax);
void CalcBrownianTimedRandom(float _randomMin, float _randomMax, int _randomFreqMin, int _randomFreqMax);
void brownian(float _randomMin, float _randomMax);
void brownianTime(float _randomMin, float _randomMax);
};
#endif