group.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. package group
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "sort"
  6. "time"
  7. "tmr-watch/models"
  8. "tmr-watch/module"
  9. "tmr-watch/pkg/util"
  10. )
  11. // DistributeFeedFormulaService 饲料配方下发牧场端
  12. func DistributeFeedFormulaService(req *models.PastureBodyRequest) error {
  13. if len(req.Body) <= 0 {
  14. return nil
  15. }
  16. feedTemplateList := make([]*models.FeedTemplate, 0)
  17. for _, b := range req.Body {
  18. feedTemplateList = append(feedTemplateList, &models.FeedTemplate{
  19. PastureId: req.PastureId,
  20. TCode: b.EncodeNumber,
  21. TName: b.Name,
  22. TColor: b.Colour,
  23. CCid: int64(b.CattleCategoryId),
  24. CCName: b.CattleCategoryName,
  25. FTType: b.FormulaTypeName,
  26. FTTypeId: b.FormulaTypeId,
  27. Source: "集团下发",
  28. Remark: b.Remarks,
  29. Enable: 1,
  30. Version: b.Version,
  31. SaveTime: time.Now().Format("2006-01-02 15:04:05"),
  32. IsIssue: 0,
  33. IssueVersion: 0,
  34. IssueId: 0,
  35. IsModify: b.IsModify,
  36. })
  37. }
  38. return module.DistributeFeedFormula(feedTemplateList)
  39. }
  40. func FeedFormulaIsModifyService(req *models.PastureFeedFormulaIsModifyRequest) error {
  41. return module.FeedFormulaIsModify(req)
  42. }
  43. // AnalysisAccuracyService 首页准确率分析
  44. func AnalysisAccuracyService(req *models.AnalysisAccuracyRequest) (*models.AnalysisAccuracyResponse, error) {
  45. response := &models.AnalysisAccuracyResponse{
  46. MixedFodderAccurateRatio: make([]*models.PastureAnalysisAccuracyDataValue, 0),
  47. MixedFodderCorrectRatio: make([]*models.PastureAnalysisAccuracyDataValue, 0),
  48. SprinkleFodderAccurateRatio: make([]*models.PastureAnalysisAccuracyDataValue, 0),
  49. SprinkleFodderCorrectRatio: make([]*models.PastureAnalysisAccuracyDataValue, 0),
  50. }
  51. // 混料准确率
  52. mixedFodderDataList, err := module.MixedFodderData(req)
  53. if err != nil {
  54. return nil, err
  55. }
  56. // 撒料准确率
  57. sprinkleFodderDataList, err := module.SprinkleFodderData(req)
  58. if err != nil {
  59. return nil, err
  60. }
  61. // 混料正确率
  62. mixedFodderCorrectDataList, err := module.MixedFodderCorrectData(req)
  63. if err != nil {
  64. return nil, err
  65. }
  66. // 撒料正确率
  67. sprinkleFodderCorrectDataList, err := module.SprinkleFodderCorrectData(req)
  68. a, _ := json.Marshal(mixedFodderCorrectDataList)
  69. fmt.Println("====mixedFodderCorrectDataList===", string(a))
  70. b, _ := json.Marshal(sprinkleFodderCorrectDataList)
  71. fmt.Println("====mixedFodderCorrectDataList===", string(b))
  72. timeList := util.TimeBetween(req.StartDate, req.EndDate)
  73. for _, dayTime := range timeList {
  74. var mixedInfo, sprinkleInfo, mixedCorrectInfo, sprinkleCorrectInfo bool
  75. for _, mixed := range mixedFodderDataList {
  76. myDate := mixed.Date.Format(util.LayoutDateFormat)
  77. if myDate != dayTime {
  78. continue
  79. }
  80. // 混料准确率
  81. var mixedFodderAccurateRatio float64 = 0
  82. if mixed.Lweight > 0 && mixed.ActualWeightMinus > 0 {
  83. if mixed.Lweight > mixed.ActualWeightMinus {
  84. mixedFodderAccurateRatio = mixed.ActualWeightMinus / mixed.Lweight * 100
  85. } else {
  86. mixedFodderAccurateRatio = mixed.Lweight / mixed.ActualWeightMinus * 100
  87. }
  88. }
  89. mixedValue := &models.PastureAnalysisAccuracyDataValue{
  90. DayTime: dayTime,
  91. Ratio: mixedFodderAccurateRatio,
  92. }
  93. response.MixedFodderAccurateRatio = append(response.MixedFodderAccurateRatio, mixedValue)
  94. mixedInfo = true
  95. }
  96. if !mixedInfo {
  97. noInfo := &models.PastureAnalysisAccuracyDataValue{
  98. DayTime: dayTime,
  99. Ratio: 0,
  100. }
  101. response.MixedFodderAccurateRatio = append(response.MixedFodderAccurateRatio, noInfo)
  102. }
  103. for _, sprinkle := range sprinkleFodderDataList {
  104. myDate := sprinkle.Date.Format(util.LayoutDateFormat)
  105. if myDate != dayTime {
  106. continue
  107. }
  108. // 撒料准确率
  109. var sprinkleFodderAccurateRatio float64 = 0
  110. if sprinkle.Lweight > 0 && sprinkle.ActualWeightMinus > 0 {
  111. if sprinkle.Lweight > sprinkle.ActualWeightMinus {
  112. sprinkleFodderAccurateRatio = sprinkle.ActualWeightMinus / sprinkle.Lweight * 100
  113. } else {
  114. sprinkleFodderAccurateRatio = sprinkle.Lweight / sprinkle.ActualWeightMinus * 100
  115. }
  116. }
  117. sprinkleValue := &models.PastureAnalysisAccuracyDataValue{
  118. DayTime: dayTime,
  119. Ratio: sprinkleFodderAccurateRatio,
  120. }
  121. response.SprinkleFodderAccurateRatio = append(response.SprinkleFodderAccurateRatio, sprinkleValue)
  122. sprinkleInfo = true
  123. }
  124. if !sprinkleInfo {
  125. noInfo := &models.PastureAnalysisAccuracyDataValue{
  126. DayTime: dayTime,
  127. Ratio: 0,
  128. }
  129. response.SprinkleFodderAccurateRatio = append(response.SprinkleFodderAccurateRatio, noInfo)
  130. }
  131. for _, mixedFodder := range mixedFodderCorrectDataList {
  132. fmt.Println("====mixedFodder.Date========", mixedFodder.Date)
  133. if mixedFodder.Date != dayTime {
  134. continue
  135. }
  136. if mixedFodder.MixedCorrectNumber == 0 || mixedFodder.UseMixedFodderOptionNumber == 0 {
  137. response.MixedFodderCorrectRatio = append(response.MixedFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  138. DayTime: dayTime,
  139. Ratio: 0,
  140. })
  141. } else {
  142. response.MixedFodderCorrectRatio = append(response.MixedFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  143. DayTime: dayTime,
  144. Ratio: float64(mixedFodder.MixedCorrectNumber) / float64(mixedFodder.UseMixedFodderOptionNumber) * 100,
  145. })
  146. }
  147. mixedCorrectInfo = true
  148. }
  149. if !mixedCorrectInfo {
  150. response.MixedFodderCorrectRatio = append(response.MixedFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  151. DayTime: dayTime,
  152. Ratio: 0,
  153. })
  154. }
  155. for _, sprinkle := range sprinkleFodderCorrectDataList {
  156. myDateStr, _ := time.ParseInLocation(time.RFC3339, sprinkle.Date, time.Local)
  157. myDate := myDateStr.Format("2006-01-02")
  158. if myDate != dayTime {
  159. continue
  160. }
  161. if sprinkle.SprinkleCorrectNumber == 0 || sprinkle.UseSprinkleOptionNumber == 0 {
  162. response.SprinkleFodderCorrectRatio = append(response.SprinkleFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  163. DayTime: dayTime,
  164. Ratio: 0,
  165. })
  166. } else {
  167. response.SprinkleFodderCorrectRatio = append(response.SprinkleFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  168. DayTime: dayTime,
  169. Ratio: float64(sprinkle.SprinkleCorrectNumber) / float64(sprinkle.UseSprinkleOptionNumber) * 100,
  170. })
  171. }
  172. sprinkleCorrectInfo = true
  173. }
  174. if !sprinkleCorrectInfo {
  175. response.SprinkleFodderCorrectRatio = append(response.SprinkleFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  176. DayTime: dayTime,
  177. Ratio: 0,
  178. })
  179. }
  180. }
  181. return response, nil
  182. }
  183. // ProcessAnalysisService 过程分析
  184. func ProcessAnalysisService(req *models.AnalysisAccuracyRequest) (*models.ProcessAnalysisResponse, error) {
  185. response := &models.ProcessAnalysisResponse{
  186. AddFeedTime: &models.ProcessAnalysisDataValue{},
  187. SprinkleTime: &models.ProcessAnalysisDataValue{},
  188. StirTime: &models.ProcessAnalysisDataValue{},
  189. }
  190. processDataList, err := module.ProcessAnalysisData(req)
  191. if err != nil {
  192. return nil, err
  193. }
  194. addFeedList := make([]int, 0)
  195. sprinkleFeedList := make([]int, 0)
  196. stirDelayList := make([]int, 0)
  197. for _, v := range processDataList {
  198. addFeedList = append(addFeedList, util.TimeParseToMinutes(v.ExecProcessTime))
  199. sprinkleFeedList = append(sprinkleFeedList, util.TimeParseToMinutes(v.L2ProcessTime))
  200. stirDelayList = append(stirDelayList, v.ExecStirDelay)
  201. }
  202. if len(addFeedList) > 0 {
  203. sort.Ints(addFeedList)
  204. response.AddFeedTime.MaxValue = fmt.Sprintf("%.2f", float64(addFeedList[len(addFeedList)-1])/60)
  205. response.AddFeedTime.UpMiddleValue = fmt.Sprintf("%.2f", util.Median(addFeedList[len(addFeedList)/2+1:])/60)
  206. response.AddFeedTime.MiddleValue = fmt.Sprintf("%.2f", util.Median(addFeedList)/60)
  207. response.AddFeedTime.DownMiddleValue = fmt.Sprintf("%.2f", util.Median(addFeedList[0:len(addFeedList)/2])/60)
  208. response.AddFeedTime.MinValue = fmt.Sprintf("%.2f", float64(addFeedList[0])/60)
  209. }
  210. if len(sprinkleFeedList) > 0 {
  211. sort.Ints(sprinkleFeedList)
  212. response.SprinkleTime.MaxValue = fmt.Sprintf("%.2f", float64(sprinkleFeedList[len(sprinkleFeedList)-1])/60)
  213. response.SprinkleTime.UpMiddleValue = fmt.Sprintf("%.2f", util.Median(sprinkleFeedList[len(sprinkleFeedList)/2+1:])/60)
  214. response.SprinkleTime.MiddleValue = fmt.Sprintf("%.2f", util.Median(sprinkleFeedList)/60)
  215. response.SprinkleTime.DownMiddleValue = fmt.Sprintf("%.2f", util.Median(sprinkleFeedList[0:len(sprinkleFeedList)/2])/60)
  216. response.SprinkleTime.MinValue = fmt.Sprintf("%.2f", float64(sprinkleFeedList[0])/60)
  217. }
  218. if len(stirDelayList) > 0 {
  219. sort.Ints(stirDelayList)
  220. response.StirTime.MaxValue = fmt.Sprintf("%d", stirDelayList[len(stirDelayList)-1])
  221. response.StirTime.UpMiddleValue = fmt.Sprintf("%.2f", util.Median(stirDelayList[len(stirDelayList)/2+1:]))
  222. response.StirTime.MiddleValue = fmt.Sprintf("%.2f", util.Median(stirDelayList))
  223. response.StirTime.DownMiddleValue = fmt.Sprintf("%.2f", util.Median(stirDelayList[0:len(stirDelayList)/2]))
  224. response.StirTime.MinValue = fmt.Sprintf("%d", stirDelayList[0])
  225. }
  226. return response, nil
  227. }
  228. // SprinkleStatisticsService 撒料统计
  229. func SprinkleStatisticsService(req *models.SprinkleStatisticsRequest) ([]*models.SprinkleStatisticsDataList, error) {
  230. sprinkleDataList, err := module.SprinkleStatistics(req)
  231. if err != nil {
  232. return nil, err
  233. }
  234. return sprinkleDataList, nil
  235. }
  236. func AccountDistributionService(req *models.AccountDistributionRequest) error {
  237. return module.AccountDistribution(req)
  238. }
  239. func ForageCategoryDistributeService(req *models.CategoryRequest) error {
  240. feedClass := &models.FeedClass{
  241. PastureId: int64(req.PastureId),
  242. FCCode: req.Number,
  243. FCName: req.Name,
  244. Enable: req.IsShow,
  245. BigFeedClassId: req.ParentId,
  246. BigFeedClassName: req.ParentName,
  247. GroupId: int64(req.GroupId),
  248. }
  249. return module.ForageCategoryDistribute(feedClass)
  250. }
  251. func CattleCategoryDistributeService(req *models.CategoryRequest) error {
  252. cowClass := &models.CowClass{
  253. PastureId: int64(req.PastureId),
  254. ClassCode: req.Number,
  255. ClassName: req.Name,
  256. Enable: req.IsShow,
  257. ParentId: req.ParentId,
  258. ParentName: req.ParentName,
  259. GroupId: int64(req.GroupId),
  260. }
  261. return module.CattleCategoryDistribute(cowClass)
  262. }
  263. func CategoryDeleteService(keyWord string, req *models.CategoryDeleteRequest) error {
  264. switch keyWord {
  265. case "feed_delete":
  266. return module.ForageCategoryDelete(int64(req.PastureId), int64(req.GroupId))
  267. case "cow_delete":
  268. return module.CowCategoryDelete(int64(req.PastureId), int64(req.GroupId))
  269. }
  270. return nil
  271. }