-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOpener.h
167 lines (141 loc) · 5.06 KB
/
Opener.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
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
/**
* @file Opener/Opener.h
* @subpage opener_class
* @brief ハイブリッドロケットの開放機構の制御を行うライブラリ
* @details ハイブリッドロケットの開放機構の制御を行うライブラリ
**/
#ifndef OPENER_H
#define OPENER_H
#include <Arduino.h>
//#include "pico/stdlib.h"
int arraycmp(const void *p1, const void *p2);
bool is_odd_number(int n);
float get_median(int n, float a[]);
/*!
* @brief ハイブリッドロケットの開放機構の制御を行うクラス
*/
class OPENER
{
private:
/**
* @brief 開放判定の判定結果が格納される
**/
typedef struct
{
//! 開放機構を開くべきか
bool isOpend = false;
//! 手動で開放禁止されているか
bool prohibitOpen = true;
//! 離床判定からの時間により燃焼終了したと判断したか
bool meco_time = false;
//! 加速度がかかっていないことにより燃焼終了したと判断したか
bool meco_acc = false;
//! 離床判定からの時間により頂点到達したと判断したか
bool apogee_time = false;
//! 下降を検知し頂点到達したと判断したか
bool apogee_descending = false;
} OPEN_JUDGE;
void goFLIGHT();
void goOPENED();
uint32_t get_time_ms();
// timer
uint32_t before_10Hz_time = 0;
uint32_t before_100Hz_time = 0;
uint32_t count_100Hz = 0;
void opener_10Hz();
// get median
float ALT_buf_mss[10];
float ACC_buf_mss[10];
// oversampling
int ALT_count = 0;
// altitude->velocity
float before_altitude_m = 0;
// sensor_judgement
int lift_off_altitude_count = 0;
int lift_off_acc_count = 0;
int apogee_altitude_count = 0;
int meco_acc_count = 0;
// threshold
float lift_off_threshold_altitude_m = 0;
float lift_off_threshold_ac_mss = 0;
int ALT_oversampling_count = 0;
int ALT_threshold_count = 0;
protected:
//! 頂点判定に使われる,0.1秒間の高度変化の閾値
float open_threshold_altitude_m = 0.5;
//! 燃焼終了に使われる,加速度の閾値
float open_threshold_ac_mss = 7;
//! opener_10Hz()が適切なタイミングで呼ばれているかの判定に使われる,10Hzの周期
uint32_t period_10Hz_ms = 150; // 10Hz+50ms
//! opener_100Hz()が適切なタイミングで呼ばれているかの判定に使われる,100Hzの周期
uint32_t period_100Hz_ms = 20; // 100Hz+10ms
//! 閾値以上の加速度が何回連続したときに離床判定・燃焼終了判定を行うかという回数
int ACC_threshold_count = 5;
//! 離床判定にかかる時間
int flight_judgement_duration_ms = ACC_threshold_count * 100;
//! 離床判定後,燃焼中と判断し開放判定を行わない時間[ms]
uint32_t meco_threshold_time_ms = 5000;
//! 開放機構の動作にかかる時間を引いた,離床から開放までの時間のシム値[ms]の初期値
uint32_t open_threshold_time_ms = 11000;
float fm_lift_off_threshold_altitude_m = 1.0;
float fm_lift_off_threshold_ac_mss = 25.0;
int fm_ALT_oversampling_count = 1;
int fm_ALT_threshold_count = ACC_threshold_count;
float shinsasyo_lift_off_threshold_altitude_m = 0.5;
float shinsasyo_lift_off_threshold_ac_mss = 9.0;
int shinsasyo_ALT_oversampling_count = 5.0;
int shinsasyo_ALT_threshold_count = 2;
//! 開放機構を開く
virtual void open() = 0;
//! 開放機構を閉じる
virtual void close() = 0;
public:
enum SETTING
{
//! 閾値をフライト用に設定
FM,
//! 閾値を審査書用に設定
SHINSASYO
};
//! FMと審査書で閾値を切り替える
void switch_parameter(SETTING setting);
enum MODE
{
//! 離床判定禁止
CHECK,
//! 離床判定許可
READY,
//! 離床判定後
FLIGHT,
//! 開放判定後
OPENED
} mode = CHECK;
enum LIFT_OFF_JUDGE
{
//! 離床判定前
NONE,
//! 加速度により離床判定
ACCSEN,
//! 高度上昇により離床判定
ALTSEN
} lift_off_judge = NONE;
//! 初期化(myOpenerクラスでオーバーライドするときは必ず OPENER::init() を呼び出すこと)
//! myOpenerでハードウェアの初期化をしたあと,OPENERで状態を初期化して閉鎖するため
void init();
void goCHECK();
void goREADY();
void clear_prohibitOpen();
void prohibitOpen();
void manualOpen();
void manualClose();
OPEN_JUDGE open_judge;
bool opener_100Hz(float acceleration_mss, float altitude_m);
void set_open_threshold_time_ms(uint32_t _open_threshold_time_ms);
uint32_t get_open_threshold_time_ms();
uint32_t get_meco_time_ms();
//! 離床したと推定される時刻(離床判定が行われた時刻ではない)
uint32_t lift_off_time_ms;
//! 実際に開放した時刻
uint32_t open_time_ms;
};
#endif