group.go 10 KB

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