group.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  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. mixDateStr, _ := time.ParseInLocation(time.RFC3339, mixedFodder.Date, time.Local)
  133. mixDate := mixDateStr.Format("2006-01-02")
  134. if mixDate != dayTime {
  135. continue
  136. }
  137. if mixedFodder.MixedCorrectNumber == 0 || mixedFodder.UseMixedFodderOptionNumber == 0 {
  138. response.MixedFodderCorrectRatio = append(response.MixedFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  139. DayTime: dayTime,
  140. Ratio: 0,
  141. })
  142. } else {
  143. response.MixedFodderCorrectRatio = append(response.MixedFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  144. DayTime: dayTime,
  145. Ratio: float64(mixedFodder.MixedCorrectNumber) / float64(mixedFodder.UseMixedFodderOptionNumber) * 100,
  146. })
  147. }
  148. mixedCorrectInfo = true
  149. }
  150. if !mixedCorrectInfo {
  151. response.MixedFodderCorrectRatio = append(response.MixedFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  152. DayTime: dayTime,
  153. Ratio: 0,
  154. })
  155. }
  156. for _, sprinkle := range sprinkleFodderCorrectDataList {
  157. myDateStr, _ := time.ParseInLocation(time.RFC3339, sprinkle.Date, time.Local)
  158. myDate := myDateStr.Format("2006-01-02")
  159. if myDate != dayTime {
  160. continue
  161. }
  162. if sprinkle.SprinkleCorrectNumber == 0 || sprinkle.UseSprinkleOptionNumber == 0 {
  163. response.SprinkleFodderCorrectRatio = append(response.SprinkleFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  164. DayTime: dayTime,
  165. Ratio: 0,
  166. })
  167. } else {
  168. response.SprinkleFodderCorrectRatio = append(response.SprinkleFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  169. DayTime: dayTime,
  170. Ratio: float64(sprinkle.SprinkleCorrectNumber) / float64(sprinkle.UseSprinkleOptionNumber) * 100,
  171. })
  172. }
  173. sprinkleCorrectInfo = true
  174. }
  175. if !sprinkleCorrectInfo {
  176. response.SprinkleFodderCorrectRatio = append(response.SprinkleFodderCorrectRatio, &models.PastureAnalysisAccuracyDataValue{
  177. DayTime: dayTime,
  178. Ratio: 0,
  179. })
  180. }
  181. }
  182. return response, nil
  183. }
  184. // ProcessAnalysisService 过程分析
  185. func ProcessAnalysisService(req *models.AnalysisAccuracyRequest) (*models.ProcessAnalysisResponse, error) {
  186. response := &models.ProcessAnalysisResponse{
  187. AddFeedTime: &models.ProcessAnalysisDataValue{},
  188. SprinkleTime: &models.ProcessAnalysisDataValue{},
  189. StirTime: &models.ProcessAnalysisDataValue{},
  190. }
  191. processDataList, err := module.ProcessAnalysisData(req)
  192. if err != nil {
  193. return nil, err
  194. }
  195. addFeedList := make([]int, 0)
  196. sprinkleFeedList := make([]int, 0)
  197. stirDelayList := make([]int, 0)
  198. for _, v := range processDataList {
  199. addFeedList = append(addFeedList, util.TimeParseToMinutes(v.ExecProcessTime))
  200. sprinkleFeedList = append(sprinkleFeedList, util.TimeParseToMinutes(v.L2ProcessTime))
  201. stirDelayList = append(stirDelayList, v.ExecStirDelay)
  202. }
  203. if len(addFeedList) > 0 {
  204. sort.Ints(addFeedList)
  205. response.AddFeedTime.MaxValue = fmt.Sprintf("%.2f", float64(addFeedList[len(addFeedList)-1])/60)
  206. response.AddFeedTime.UpMiddleValue = fmt.Sprintf("%.2f", util.Median(addFeedList[len(addFeedList)/2+1:])/60)
  207. response.AddFeedTime.MiddleValue = fmt.Sprintf("%.2f", util.Median(addFeedList)/60)
  208. response.AddFeedTime.DownMiddleValue = fmt.Sprintf("%.2f", util.Median(addFeedList[0:len(addFeedList)/2])/60)
  209. response.AddFeedTime.MinValue = fmt.Sprintf("%.2f", float64(addFeedList[0])/60)
  210. }
  211. if len(sprinkleFeedList) > 0 {
  212. sort.Ints(sprinkleFeedList)
  213. response.SprinkleTime.MaxValue = fmt.Sprintf("%.2f", float64(sprinkleFeedList[len(sprinkleFeedList)-1])/60)
  214. response.SprinkleTime.UpMiddleValue = fmt.Sprintf("%.2f", util.Median(sprinkleFeedList[len(sprinkleFeedList)/2+1:])/60)
  215. response.SprinkleTime.MiddleValue = fmt.Sprintf("%.2f", util.Median(sprinkleFeedList)/60)
  216. response.SprinkleTime.DownMiddleValue = fmt.Sprintf("%.2f", util.Median(sprinkleFeedList[0:len(sprinkleFeedList)/2])/60)
  217. response.SprinkleTime.MinValue = fmt.Sprintf("%.2f", float64(sprinkleFeedList[0])/60)
  218. }
  219. if len(stirDelayList) > 0 {
  220. sort.Ints(stirDelayList)
  221. response.StirTime.MaxValue = fmt.Sprintf("%d", stirDelayList[len(stirDelayList)-1])
  222. response.StirTime.UpMiddleValue = fmt.Sprintf("%.2f", util.Median(stirDelayList[len(stirDelayList)/2+1:]))
  223. response.StirTime.MiddleValue = fmt.Sprintf("%.2f", util.Median(stirDelayList))
  224. response.StirTime.DownMiddleValue = fmt.Sprintf("%.2f", util.Median(stirDelayList[0:len(stirDelayList)/2]))
  225. response.StirTime.MinValue = fmt.Sprintf("%d", stirDelayList[0])
  226. }
  227. return response, nil
  228. }
  229. // SprinkleStatisticsService 撒料统计
  230. func SprinkleStatisticsService(req *models.SprinkleStatisticsRequest) ([]*models.SprinkleStatisticsDataList, error) {
  231. sprinkleDataList, err := module.SprinkleStatistics(req)
  232. if err != nil {
  233. return nil, err
  234. }
  235. return sprinkleDataList, nil
  236. }
  237. func AccountDistributionService(req *models.AccountDistributionRequest) error {
  238. return module.AccountDistribution(req)
  239. }
  240. func ForageCategoryDistributeService(req *models.CategoryRequest) error {
  241. feedClass := &models.FeedClass{
  242. PastureId: int64(req.PastureId),
  243. FCCode: req.Number,
  244. FCName: req.Name,
  245. Enable: req.IsShow,
  246. BigFeedClassId: req.ParentId,
  247. BigFeedClassName: req.ParentName,
  248. GroupId: int64(req.GroupId),
  249. }
  250. return module.ForageCategoryDistribute(feedClass)
  251. }
  252. func CattleCategoryDistributeService(req *models.CategoryRequest) error {
  253. cowClass := &models.CowClass{
  254. PastureId: int64(req.PastureId),
  255. ClassCode: req.Number,
  256. ClassName: req.Name,
  257. Enable: req.IsShow,
  258. ParentId: req.ParentId,
  259. ParentName: req.ParentName,
  260. GroupId: int64(req.GroupId),
  261. }
  262. return module.CattleCategoryDistribute(cowClass)
  263. }
  264. func CategoryDeleteService(keyWord string, req *models.CategoryDeleteRequest) error {
  265. switch keyWord {
  266. case "feed_delete":
  267. return module.ForageCategoryDelete(int64(req.PastureId), int64(req.GroupId))
  268. case "cow_delete":
  269. return module.CowCategoryDelete(int64(req.PastureId), int64(req.GroupId))
  270. }
  271. return nil
  272. }