TrafficCongestion.go 815 B

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. package main
  2. import (
  3. "cicv-data-closedloop/pjisuv_msgs"
  4. "cicv-data-closedloop/pjisuv_param"
  5. "fmt"
  6. "math"
  7. )
  8. func Topic() string {
  9. return "/tpperception"
  10. }
  11. // Label todo 禁止存在下划线_
  12. func Label() string {
  13. return "TrafficCongestion"
  14. }
  15. func Rule(data *pjisuv_msgs.PerceptionObjects, param *pjisuv_param.PjisuvParam) string {
  16. NumTargets := 0
  17. defer func() {
  18. if r := recover(); r != nil {
  19. fmt.Println("Recovered from panic:", r)
  20. }
  21. }()
  22. if param.VelocityXOfCicvLocation < 3.5 && len(data.Objs) > 3 {
  23. for _, obj := range data.Objs {
  24. if (obj.Type == 2 || obj.Type == 3) && math.Abs(float64(obj.Y)) <= 2.5 && math.Abs(float64(obj.X)) <= 20 && obj.Speed <= 4 {
  25. NumTargets++
  26. }
  27. }
  28. //fmt.Println(NumTargets)
  29. if NumTargets >= 3 {
  30. return "TrafficCongestion"
  31. }
  32. }
  33. return ""
  34. }