36 static const float bias = 1.3f;
40 static const Datum kInterpData[] = {
41 Datum(0, 21.0f * 1000.0f * bias),
42 Datum(11, 19.4 * 1000.0f * bias),
43 Datum(22, 15.1f * 1000.0f * bias),
44 Datum(35, 12.5f * 1000.0f * bias),
45 Datum(44, 10.f * 1000.0f * bias),
46 Datum(50, 8.1f * 1000.0f * bias),
47 Datum(53, 5.3f * 1000.0f * bias),
48 Datum(61, 4.0f * 1000.0f * bias),
49 Datum(66, 5.0f * 1000.0f * bias),
50 Datum(69, 4.6f * 1000.0f * bias),
51 Datum(70, 4.4f * 1000.0f * bias),
52 Datum(71, 4.3f * 1000.0f * bias),
53 Datum(74, 3.9f * 1000.0f * bias),
54 Datum(80, 1.9f * 1000.0f * bias),
55 Datum(81, 1.8f * 1000.0f * bias),
56 Datum(82, 1.7f * 1000.0f * bias),
57 Datum(83, 1.5f * 1000.0f * bias),
58 Datum(84, 1.3f * 1000.0f * bias),
59 Datum(86, 1.0f * 1000.0f * bias),
60 Datum(87, 0.9f * 1000.0f * bias),
63 static const int n =
sizeof(kInterpData) /
sizeof(kInterpData[0]);
64 float approx_val =
Interp(key_idx, kInterpData, n);
76 float time_elapsed_ms) {
78 static const float kDefaultDecayTime = .2f * 1000.f;
79 static const float kBias = 1.10;
80 float decay_time = kDefaultDecayTime;
81 if (key_on || sustain_pedal_on || !dampened_key) {
87 float intensity_factor =
mapf(time_elapsed_ms,
88 0.0, decay_time * kBias,
95 intensity_factor = constrain(intensity_factor, 0.0f, 1.0f);
96 return intensity_factor;
float mapf(float x, float in_min, float in_max, float out_min, float out_max)
float CalcDecayFactor(bool sustain_pedal_on, bool key_on, int key_idx, float velocity, bool dampened_key, float time_elapsed_ms)