DescendingSteepHill.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. package main
  2. import (
  3. "cicv-data-closedloop/pjisuv_ticker"
  4. "fmt"
  5. "math"
  6. "sync"
  7. "time"
  8. )
  9. //记得在produce_window.go中将AngleSlice的注释解除!!!
  10. var (
  11. threshold float64 = -0.06 //道路坡度大于6%就可以被认为是陡坡
  12. )
  13. // 定时任务触发器固定的
  14. func Topic() string {
  15. return pjisuv_ticker.TickerTopic
  16. }
  17. // ******* 禁止存在下划线_
  18. // 触发器标记
  19. func Label() string {
  20. return "DescendingSteepHill"
  21. }
  22. func Rule(shareVars *sync.Map) {
  23. defer func() {
  24. if r := recover(); r != nil {
  25. fmt.Println("Recovered from panic:", r)
  26. }
  27. }()
  28. // 1 使用goroutine
  29. go func(shareVars *sync.Map) {
  30. // 2 定义触发器的间隔时间
  31. ticker := time.NewTicker(time.Duration(2) * time.Second)
  32. defer ticker.Stop()
  33. // 3 运行一个无限循环
  34. for {
  35. select {
  36. // 定时器触发时执行的代码
  37. case <-ticker.C:
  38. FinalCallback(shareVars)
  39. }
  40. }
  41. }(shareVars)
  42. }
  43. // QuaternionToEuler 将四元数转换为欧拉角
  44. func QuaternionToEuler(x, y, z, w float64) float64 {
  45. // 归一化四元数
  46. length := math.Sqrt(x*x + y*y + z*z + w*w)
  47. x /= length
  48. y /= length
  49. z /= length
  50. w /= length
  51. // 计算欧拉角
  52. pitch := math.Asin(2 * (w*y - z*x))
  53. return pitch
  54. }
  55. func countChanges(AngleSlice [][]float64) int {
  56. num := 0
  57. for i := 0; i < len(AngleSlice[1]); i++ {
  58. pitch := QuaternionToEuler(AngleSlice[0][i], AngleSlice[1][i], AngleSlice[2][i], AngleSlice[3][i])
  59. if pitch <= threshold {
  60. num++
  61. }
  62. }
  63. return num
  64. }
  65. func FinalCallback(shareVars *sync.Map) {
  66. OutsideWorkshopFlag, ok := shareVars.Load("OutsideWorkshopFlag")
  67. AngleSlice, ok1 := shareVars.Load("AngleSlice")
  68. if ok && ok1 && OutsideWorkshopFlag.(bool) == true {
  69. count := countChanges(AngleSlice.([][]float64))
  70. if count >= 5 {
  71. event_lable := "DescendingSteepHill"
  72. fmt.Println(event_lable)
  73. pjisuv_ticker.TickerChan <- pjisuv_ticker.TickInfo{FaultLabel: Label(), FaultHappenTime: pjisuv_ticker.GetNowTimeCustom()}
  74. AngleSlice = make([][]float64, 0)
  75. shareVars.Store("AngleSlice", AngleSlice)
  76. }
  77. }
  78. }