-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun.sh
executable file
·168 lines (141 loc) · 5.95 KB
/
run.sh
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
#!/bin/bash
# Try to find the device automatically. Override with `DEVICE=`.
declare DEFAULT_DEVICE="--auto"
# Default to use flash mode for acquisition
declare DEFAULT_DETECTION_MODE="reflective"
# Default to use flash mode for acquisition
declare DEFAULT_MODE="flash"
# By default, turn on:
# - the green LED (1 << 14)
# - an infra-red LED (1 << 2)
# Override with `LED_MASK=`.
declare DEFAULT_LED_MASK=0xF000
# Default to enabling all channels. Override with `SRC_MASK=`.
declare DEFAULT_SRC_MASK=0x7f
# Default to 512 sample oversample. Override with `OVERSAMPLE=`.
declare DEFAULT_OVERSAMPLE=512
# Default to 50Hz. Override with `FREQUENCY=`.
declare DEFAULT_FREQUENCY=50
usage()
{
echo "$0 command"
}
# Collect 32-bit samples to be processed for calibrating the device.
run_cal()
{
declare device="${DEVICE:-$DEFAULT_DEVICE}"
declare detection="--${DETECTION_MODE:-$DEFAULT_DETECTION_MODE}"
declare mode="--${MODE:-$DEFAULT_MODE}"
declare led_mask="${LED_MASK:-$DEFAULT_LED_MASK}"
declare src_mask="${SRC_MASK:-$DEFAULT_SRC_MASK}"
declare frequency="${FREQUENCY:-$DEFAULT_FREQUENCY}"
declare oversample="${OVERSAMPLE:-$DEFAULT_OVERSAMPLE}"
# Shine the lights
host/build/bl led "$device" "$led_mask"
# srccfg <source> <gain> <offset> <sw oversample> [hw oversample] [hw shift]
host/build/bl srccfg "$device" 0 1 0 "$oversample" 0 0 # Photodiode 1
host/build/bl srccfg "$device" 1 1 0 "$oversample" 0 0 # Photodiode 2
host/build/bl srccfg "$device" 2 1 0 "$oversample" 0 0 # Photodiode 3
host/build/bl srccfg "$device" 3 1 0 "$oversample" 0 0 # Photodiode 4
host/build/bl srccfg "$device" 4 1 0 "$oversample" 0 0 # 3.3V
host/build/bl srccfg "$device" 5 1 0 "$oversample" 0 0 # 5.0V
host/build/bl srccfg "$device" 6 1 0 "$oversample" 0 0 # Temperature
# There are 19 channels including 16 LEDs plus 3.3V, 5.0V and Temperature
# chancfg <channel> <source> [offset] [shift] [sample32]
host/build/bl chancfg "$device" 0 2 0 0 1 # Photodiode 3
host/build/bl chancfg "$device" 1 2 0 0 1 # Photodiode 3
host/build/bl chancfg "$device" 2 2 0 0 1 # Photodiode 3
host/build/bl chancfg "$device" 3 2 0 0 1 # Photodiode 3
host/build/bl chancfg "$device" 4 3 0 0 1 # Photodiode 4
host/build/bl chancfg "$device" 5 3 0 0 1 # Photodiode 4
host/build/bl chancfg "$device" 6 3 0 0 1 # Photodiode 4
host/build/bl chancfg "$device" 7 3 0 0 1 # Photodiode 4
host/build/bl chancfg "$device" 8 1 0 0 1 # Photodiode 2
host/build/bl chancfg "$device" 9 1 0 0 1 # Photodiode 2
host/build/bl chancfg "$device" 10 1 0 0 1 # Photodiode 2
host/build/bl chancfg "$device" 11 1 0 0 1 # Photodiode 2
host/build/bl chancfg "$device" 12 0 0 0 1 # Photodiode 1
host/build/bl chancfg "$device" 13 0 0 0 1 # Photodiode 1
host/build/bl chancfg "$device" 14 0 0 0 1 # Photodiode 1
host/build/bl chancfg "$device" 15 0 0 0 1 # Photodiode 1
host/build/bl chancfg "$device" 16 4 0 0 1 # 3.3V
host/build/bl chancfg "$device" 17 5 0 0 1 # 5.0V
host/build/bl chancfg "$device" 18 6 0 0 1 # Temperature
# Start the calibration acquisition.
host/build/bl start "$device" "$mode" "$detection" "$frequency" "$src_mask" "$led_mask"
}
# Run an acquisition.
run_acq()
{
declare device="${DEVICE:-$DEFAULT_DEVICE}"
declare led_mask="${LED_MASK:-$DEFAULT_LED_MASK}"
declare src_mask="${SRC_MASK:-$DEFAULT_SRC_MASK}"
declare frequency="${FREQUENCY:-$DEFAULT_FREQUENCY}"
declare oversample="${OVERSAMPLE:-$DEFAULT_OVERSAMPLE}"
# Shine the lights
host/build/bl led "$device" "$led_mask"
# srccfg <source> <gain> <offset> <sw oversample> [hw oversample] [hw shift]
host/build/bl srccfg "$device" 0 16 0 "$oversample" 0 0 # Photodiode 1
host/build/bl srccfg "$device" 1 1 0 "$oversample" 0 0 # Photodiode 2
host/build/bl srccfg "$device" 2 1 0 "$oversample" 0 0 # Photodiode 3
host/build/bl srccfg "$device" 3 1 0 "$oversample" 0 0 # Photodiode 4
host/build/bl srccfg "$device" 4 1 0 "$oversample" 0 0 # 3.3V
host/build/bl srccfg "$device" 5 1 0 "$oversample" 0 0 # 5.0V
host/build/bl srccfg "$device" 6 1 0 "$oversample" 0 0 # Temperature
# TODO: this chancfg table has to change to be similar to the one
# in run_cal, but I've no idea where do those shift values come
# from, so leave it for now.
# chancfg <channel> <source> [offset] [shift] [sample32]
host/build/bl chancfg "$device" 0 0 1264480 0 # Photodiode 1
host/build/bl chancfg "$device" 1 1 54879 0 # Photodiode 2
host/build/bl chancfg "$device" 2 2 567447 0 # Photodiode 3
host/build/bl chancfg "$device" 3 3 0 0 # Photodiode 4
host/build/bl chancfg "$device" 4 4 1038856 0 # 3.3V
host/build/bl chancfg "$device" 5 5 1031704 0 # 5.0V
host/build/bl chancfg "$device" 6 6 860701 0 # Temperature
# Start the calibration acquisition.
host/build/bl start "$device" "$frequency" "$src_mask" "$led_mask"
}
# Turn off the lights and stop any acquisition.
run_off()
{
declare device="${DEVICE:-$DEFAULT_DEVICE}"
host/build/bl led "$device" 0x0000
host/build/bl abort "$device"
}
# Sequential exexute calibration and acquisition
run_cal_acq()
{
TMP_CFG=tmp_cfg
declare device="${DEVICE:-$DEFAULT_DEVICE}"
declare led_mask="${LED_MASK:-$DEFAULT_LED_MASK}"
declare src_mask="${SRC_MASK:-$DEFAULT_SRC_MASK}"
declare frequency="${FREQUENCY:-$DEFAULT_FREQUENCY}"
declare oversample="${OVERSAMPLE:-$DEFAULT_OVERSAMPLE}"
# Run calibration to get the config
run_cal | host/build/calibrate | grep chancfg > "$TMP_CFG" &
#echo "Wait 10s for default configuration"
sleep 10
# Save pid of acquisition to later use
BID=$(pgrep -f "bl start")
#echo "Run acquisition for 30 seconds to get calibration data."
sleep 30
# Terminate acquisition
kill -s SIGINT "$BID"
sleep 1
# Run saved configurate command from calibration
while read -r LINE
do
eval "$LINE"
done < "$TMP_CFG"
rm "$TMP_CFG"
# Start the calibration acquisition.
host/build/bl start "$device" "$frequency" "$src_mask" "$led_mask"
}
if [ $# -lt 1 ]; then
usage
exit 1
fi
cmd="$1"
shift 1
"run_$cmd" "$@"