CalculateDBThread.h 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. #ifndef _CALCULATEDBTHREAD_H_
  2. #define _CALCULATEDBTHREAD_H_
  3. #include "AudioData.h"
  4. #include "BaseCalculateThread.h"
  5. #include "CreateDBThread.h"
  6. #include "CreateLongFileThread.h"
  7. #include "SendStruct.h"
  8. #include "CalculateAudio.h"
  9. #include "CompareResult.h"
  10. /**
  11. 这个线程类进行静音、过载和反相等报警的计算,这个线程和对比项相关,需要对比项中的参数,由对比项线程创建
  12. 1、计算静音、过载和反相
  13. 2、保存报警结果得出的报警信息,外部获取是实时的报警状态,通过一个中介报警信息解决了报警时间粘连的问题
  14. 线程输出结果
  15. 1、静音报警信息
  16. 2、过载报警信息
  17. 3、反相报警信息
  18. 4、音量包信息
  19. 检测时间段:
  20. 1、如果某一项不在检测时间段内,那么这一项不会进行计算,检测结果全部为false
  21. 2、即使所有的检测项目都不在检测时间段内,这个线程也不能停,因为对比项需要从这里获取音量包信息
  22. */
  23. class CalculateDBThread : public BaseCalculateThread
  24. {
  25. public:
  26. CalculateDBThread(CalculateThreadInfo_t& threadInfo);
  27. ~CalculateDBThread() override;
  28. /* 获取线程通道信息 */
  29. const CompareItemRoadInfo_t& getRoadInfo() const { return m_roadInfo; }
  30. /* 获取结果,这个线程计算出静音、过载、反相和音量包信息 */
  31. OneRoadVolume_t getVolumeInfo();
  32. /* 获取最新音量值计算的结果 */
  33. bool getlastVolumeInfo(OneRoadVolume_t& volumeInfo);
  34. /* 获取最新的结果,实时结果 */
  35. // AlarmInfo_t getAlarm(EAlarmType alarmType);
  36. /* 设置是否在检测时段内 */
  37. void setSilenceInDetectPeriod(bool isInPeriod) { m_isSilenceInDetectPeriod = isInPeriod; }
  38. void setOverloadInDetectPeriod(bool isInPeriod) { m_isOverloadInDetectPeriod = isInPeriod; }
  39. void setPhaseInDetectPeriod(bool isInPeriod) { m_isPhaseInDetectPeriod = isInPeriod; }
  40. protected:
  41. /* 线程功能函数 */
  42. void task() override;
  43. /* 初始化数据 */
  44. bool initData() override;
  45. /* 清理数据 */
  46. void clearData() override;
  47. private:
  48. /* 计算静音过载反相 */
  49. void calcuDBData();
  50. /* 判断是否报警 */
  51. void processAlarm();
  52. /* 处理静音报警 */
  53. void processSilence();
  54. /* 处理过载报警 */
  55. void processOverload();
  56. /* 处理反相报警 */
  57. void processPhase();
  58. /* 结束所有的报警 */
  59. void endAllAlarm();
  60. private:
  61. /* 静音、过载、反相是否在检测时间段内 */
  62. std::atomic_bool m_isSilenceInDetectPeriod = true; /* 静音检测是否在检测时间段内 */
  63. std::atomic_bool m_isOverloadInDetectPeriod = true; /* 过载检测是否在检测时间段内 */
  64. std::atomic_bool m_isPhaseInDetectPeriod = true; /* 反相检测是否在检测时间段内 */
  65. /* 录音通道信息 */
  66. CompareItemRoadInfo_t m_roadInfo; /* 录音通道编号,带有对比项信息 */
  67. std::string m_roadName; /* 录音通道名称 */
  68. /* 计算结果 */
  69. std::mutex m_mutexVolumeInfo; /* 保护音量信息的互斥锁 */
  70. OneRoadVolume_t m_roadVolumeInfo; /* 一个录音通道的音量信息这个是计算结果 */
  71. /* 生成音量的线程 */
  72. CreateDBThread* m_threadCreateDB = nullptr; /* 生成音量的线程 */
  73. OneSecondData m_currSecondData; /* 最新一秒的数据 */
  74. StVolumeParam m_volumeParam; /* 音量计算的参数 */
  75. /* 录制报警文件的线程 */
  76. CreateLongFileThread* m_threadCreateAlarmFile = nullptr;
  77. int32_t m_numQueueSeconds = 0; /* 队列元素数目,单位:秒 */
  78. CaculateDBData m_caculateDBData; /* 计算音量的环形队列类 */
  79. bool m_bLastReversed = false; /* 上一次的反相状态 */
  80. bool m_bLastOverload = false; /* 上一次的过载状态 */
  81. /* 计算需要的相关参数 */
  82. int32_t m_avgCalculateDBSeconds = 0; /* 计算平均音量需要的秒数 */
  83. int m_silentStartPos = -1; /* 静音开始位置 */
  84. int m_silentEndPos = -1; /* 静音结束位置 */
  85. int m_overloadStartPos = -1; /* 过载开始位置 */
  86. int m_overloadEndPos = -1; /* 过载结束位置 */
  87. int m_phaseStartPos = -1; /* 反相开始位置 */
  88. int m_phaseEndPos = -1; /* 反相结束位置 */
  89. AlarmInfo_t m_alarmSilence; /* 静音报警信息 */
  90. AlarmInfo_t m_alarmOverload; /* 过载报警信息 */
  91. AlarmInfo_t m_alarmPhase; /* 反相报警信息 */
  92. /* 这里的报警信息作为返回给对比项线程的中介,防止刚结束报警,结果还未取出,又来了一个报警,
  93. * 报警时间粘连的问题 */
  94. // AlarmInfo_t m_alarmLastSilence; /* 上一次静音报警信息 */
  95. // AlarmInfo_t m_alarmLastOverload; /* 上一次过载报警信息 */
  96. // AlarmInfo_t m_alarmLastPhase; /* 上一次反相报警信息 */
  97. AlarmInfo_t m_alarmNull; /* 空报警信息 */
  98. };
  99. #endif // _CALCULATEDBTHREAD_H_