123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- package main
- import (
- "cicv-data-closedloop/pjisuv_ticker"
- "fmt"
- "sync"
- "time"
- )
- var ()
- // 定时任务触发器固定的
- func Topic() string {
- return pjisuv_ticker.TickerTopic
- }
- // ******* 禁止存在下划线_
- // 触发器标记
- func Label() string {
- return "CBNAO"
- }
- func Rule(shareVars *sync.Map) {
- defer func() {
- if r := recover(); r != nil {
- fmt.Println("Recovered from panic:", r)
- }
- }()
- // 1 使用goroutine
- go func(shareVars *sync.Map) {
- // 2 定义触发器的间隔时间
- ticker := time.NewTicker(time.Duration(3) * time.Second)
- defer ticker.Stop()
- // 3 运行一个无限循环
- for {
- select {
- // 定时器触发时执行的代码
- case <-ticker.C:
- FinalCallback(shareVars)
- }
- }
- }(shareVars)
- }
- func findIndex(lst []float32, target float32) int {
- for i, v := range lst {
- if v == target {
- return i
- }
- }
- return -1
- }
- func isCrossAndOcclusion(id uint32, ObjectList [][]float32, ObjectSlice map[uint32][][]float32) bool {
- for i := 0; i < len(ObjectList[0]); i++ {
- xi := ObjectList[0][i]
- yi := ObjectList[1][i]
- diff_hi := ObjectList[7][i]
- Type := ObjectList[6][0]
- if xi >= 0 && yi <= -3 && diff_hi <= 120 && diff_hi >= 60 && Type == 4.0 {
- startFrame1 := ObjectList[5][i]
- for j := 0; j < len(ObjectList[0])-i-1; j++ {
- xj := ObjectList[0][j]
- yj := ObjectList[1][j]
- diff_hj := ObjectList[7][j]
- if xj >= 0 && xj <= 25 && yj >= 1 && diff_hj <= 120 && diff_hj >= 60 {
- startFrame2 := ObjectList[5][j]
- for this_id, objValue := range ObjectSlice {
- if this_id != id {
- this_startFrame_index1 := findIndex(objValue[3], startFrame1)
- this_startFrame_index2 := findIndex(objValue[3], startFrame2)
- this_type := objValue[6][0]
- //fmt.Println(objValue[0][this_startFrame_index2], xj)
- if this_startFrame_index1 != -1 && this_startFrame_index2 != -1 {
- if objValue[0][this_startFrame_index1] >= 2 && objValue[0][this_startFrame_index1] < xi-5 && objValue[1][this_startFrame_index1] < 0 && objValue[1][this_startFrame_index1] > yi && objValue[0][this_startFrame_index2] >= 1 && objValue[0][this_startFrame_index2] < xj-3 && objValue[1][this_startFrame_index2] < 0 && (this_type == 2.0 || this_type == 3.0) {
- return true
- }
- }
- } else {
- continue
- }
- }
- }
- }
- }
- }
- return false
- }
- func FinalCallback(shareVars *sync.Map) {
- OutsideWorkshopFlag, ok := shareVars.Load("OutsideWorkshopFlag")
- ObjDicOfTpperception, ok1 := shareVars.Load("objDicOfTpperception")
- ObjDic := ObjDicOfTpperception.(map[uint32][][]float32)
- AbsSpeed, ok2 := shareVars.Load("AbsSpeed")
- if ok && ok1 && ok2 && OutsideWorkshopFlag.(bool) == true && AbsSpeed.(float64) > 1 {
- for id, objValue := range ObjDic {
- if len(ObjDic[0]) <= 10 || !isCrossAndOcclusion(id, objValue, ObjDic) {
- continue
- }
- event_lable := "CBNAO"
- fmt.Println(event_lable)
- pjisuv_ticker.TickerChan <- pjisuv_ticker.TickInfo{FaultLabel: Label(), FaultHappenTime: pjisuv_ticker.GetNowTimeCustom()}
- }
- }
- }
|