process.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /* Copyright Statement:
  2. *
  3. * This software/firmware and related documentation ("AutoChips Software") are
  4. * protected under relevant copyright laws. The information contained herein is
  5. * confidential and proprietary to AutoChips Inc. and/or its licensors. Without
  6. * the prior written permission of AutoChips inc. and/or its licensors, any
  7. * reproduction, modification, use or disclosure of AutoChips Software, and
  8. * information contained herein, in whole or in part, shall be strictly
  9. * prohibited.
  10. *
  11. * AutoChips Inc. (C) 2016. All rights reserved.
  12. *
  13. * BY OPENING THIS FILE, RECEIVER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
  14. * THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("AUTOCHIPS SOFTWARE")
  15. * RECEIVED FROM AUTOCHIPS AND/OR ITS REPRESENTATIVES ARE PROVIDED TO RECEIVER
  16. * ON AN "AS-IS" BASIS ONLY. AUTOCHIPS EXPRESSLY DISCLAIMS ANY AND ALL
  17. * WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED
  18. * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
  19. * NONINFRINGEMENT. NEITHER DOES AUTOCHIPS PROVIDE ANY WARRANTY WHATSOEVER WITH
  20. * RESPECT TO THE SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY,
  21. * INCORPORATED IN, OR SUPPLIED WITH THE AUTOCHIPS SOFTWARE, AND RECEIVER AGREES
  22. * TO LOOK ONLY TO SUCH THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO.
  23. * RECEIVER EXPRESSLY ACKNOWLEDGES THAT IT IS RECEIVER'S SOLE RESPONSIBILITY TO
  24. * OBTAIN FROM ANY THIRD PARTY ALL PROPER LICENSES CONTAINED IN AUTOCHIPS
  25. * SOFTWARE. AUTOCHIPS SHALL ALSO NOT BE RESPONSIBLE FOR ANY AUTOCHIPS SOFTWARE
  26. * RELEASES MADE TO RECEIVER'S SPECIFICATION OR TO CONFORM TO A PARTICULAR
  27. * STANDARD OR OPEN FORUM. RECEIVER'S SOLE AND EXCLUSIVE REMEDY AND AUTOCHIPS'S
  28. * ENTIRE AND CUMULATIVE LIABILITY WITH RESPECT TO THE AUTOCHIPS SOFTWARE
  29. * RELEASED HEREUNDER WILL BE, AT AUTOCHIPS'S OPTION, TO REVISE OR REPLACE THE
  30. * AUTOCHIPS SOFTWARE AT ISSUE, OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE
  31. * CHARGE PAID BY RECEIVER TO AUTOCHIPS FOR SUCH AUTOCHIPS SOFTWARE AT ISSUE.
  32. */
  33. #ifndef PROCESS_H
  34. #define PROCESS_H
  35. #ifdef __cplusplus
  36. extern "C" {
  37. #endif
  38. /*************<include>****************/
  39. #include "ac7840x.h"
  40. /*************<extern>*****************/
  41. extern uint8_t g_bvopen; // 0: close , 1: open
  42. extern uint8_t g_vo_delay;
  43. extern uint8_t g_voiceid;
  44. extern uint8_t g_autocalibration;
  45. extern uint16_t g_samplecount;
  46. extern uint8_t g_send_raw;
  47. extern uint8_t g_send_filtered;
  48. extern uint32_t g_send_sequence;
  49. #define BLINK_LED_MINT (100) /*闪烁LED灯最小时间间隔*/
  50. #define BLINK_LED_MAXT (2000) /*闪烁LED灯最大时间间隔*/
  51. #define BLINK_LED_DFTT (100) /*闪烁LED默认时间间隔*/
  52. #define VO_COUNT_DFTT (50) /*闪烁LED默认时间间隔*/
  53. #define CLOSEVALVE_DELAY (200) // 打开电磁阀,泄气2秒钟
  54. #define CLOSEVALVE_INTERVAL (100) /*触发关阀间隔*/
  55. #define CLOSEVALVE_MAXTIMES (3) /*最大关阀次数*/
  56. #define ALG_None (0)
  57. #define ALG_Start (1)
  58. #define ALG_Calibrate (2)
  59. #define ALG_Detecting (3)
  60. #define ALG_Triggering (4)
  61. #define ALG_Finished (5)
  62. #define CALIBRATE_COUNT (5*100) //5秒钟
  63. #define RUNDELAY_COUNT (5*60*100) //5分钟
  64. #define FILTER_CNT (32)
  65. typedef struct {
  66. float x;
  67. float y;
  68. float z;
  69. }axis_info_t;
  70. typedef struct _filter_avg{
  71. axis_info_t info[FILTER_CNT];
  72. uint8_t count;
  73. }filter_avg_t;
  74. #define DETECT_CNT (400) // 4s
  75. #define KEEP_CNT (80)
  76. #define DETECT_THRESHOLD (0.6) //m/s 2Km/h
  77. #define DETECT_THRESHOLD_DOWN (0.2) // 5Km/h
  78. #define MECHANICAL_NOISE_THRESHOLD (0.015) //g
  79. typedef struct _detect_info{
  80. axis_info_t info[DETECT_CNT];
  81. uint16_t count;
  82. }detect_info_t;
  83. #define ACC_DATASIZE (16)
  84. typedef struct
  85. {
  86. int16_t data[3][ACC_DATASIZE];
  87. uint16_t write_index;
  88. uint16_t read_index;
  89. }circle_buffer;
  90. //算法三个加速度轴同时检测, 只要有一个轴的速度变化超进阈值,就触发动作。
  91. typedef struct
  92. {
  93. uint8_t state;
  94. uint16_t valveclose_delay; //触发关阀持续时间
  95. uint8_t valveclose_times; //触发关阀次数
  96. uint8_t valveclose_interval; //触发关阀间隔
  97. uint16_t calibrate_count;
  98. //uint8_t vo_alarm; /* 是否触发语音输出*/
  99. //加速度零偏,主要是重力加速度在每个轴的分量
  100. axis_info_t axis_offset;
  101. }ALG_CONTEXT;
  102. void Process_Init(void);
  103. void Process_RunLedPrd(void);
  104. void Process_Alg(void);
  105. void timer_callback(void);
  106. void sv_open(void);
  107. void sv_close(void);
  108. #ifdef __cplusplus
  109. }
  110. #endif
  111. #endif /* PROCESS_H */