blob: 335e1d8597e371a8c684746d3fc1e3435960ea77 (
plain)
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
72
|
component xhc_hb04_util "xhc-hb04 convenience utility";
description """Provides logic for a start/pause button and an interface
to halui.program.is_paused,is_idle,is_running to generate outputs for
halui.program.pause,resume,run.
Includes 4 simple lowpass filters with coef and scale pins. The coef value should
be 0 <= coef <=1, smaller coef values slow response. Note: the xhc_hb04
component includes smoothing so these values can usually be left at 1.0
""";
pin in bit start_or_pause;
pin in bit is_paused;
pin in bit is_idle;
pin in bit is_running;
pin out bit pause;
pin out bit resume;
pin out bit run;
// integer low pass filters (see ilowpass.comp)
pin in s32 in0;
pin in s32 in1;
pin in s32 in2;
pin in s32 in3;
pin out s32 out0;
pin out s32 out1;
pin out s32 out2;
pin out s32 out3;
pin in float scale0 = 1.0;
pin in float scale1 = 1.0;
pin in float scale2 = 1.0;
pin in float scale3 = 1.0;
pin in float coef0 = 1.0;
pin in float coef1 = 1.0;
pin in float coef2 = 1.0;
pin in float coef3 = 1.0;
option data xhc_data;
variable double value0;
variable double value1;
variable double value2;
variable double value3;
function _;
license "GPL";
;;
#include <rtapi_math.h>
typedef struct { int old_start_or_pause; } xhc_data;
FUNCTION(_) {
// protect so that 0 <= coef <= 1
value0 += (in0 - value0) * (fabs(coef0) < 1 ? fabs(coef0) : 1);
value1 += (in1 - value1) * (fabs(coef1) < 1 ? fabs(coef1) : 1);
value2 += (in2 - value2) * (fabs(coef2) < 1 ? fabs(coef2) : 1);
value3 += (in3 - value3) * (fabs(coef3) < 1 ? fabs(coef3) : 1);
out0 = ceil(value0 - .5) * scale0;
out1 = ceil(value1 - .5) * scale1;
out2 = ceil(value2 - .5) * scale2;
out3 = ceil(value3 - .5) * scale3;
if (data.old_start_or_pause == start_or_pause) return;
data.old_start_or_pause = start_or_pause;
if (!start_or_pause) {
pause = run = resume = 0;
return;
}
if (is_paused) {pause = 0; run = 0; resume = 1; }
if (is_running) {pause = 1; run = 0; resume = 0; }
if (is_idle) {pause = 0; run = 1; resume = 0; }
}
|