|
@@ -8,6 +8,7 @@ import (
|
|
|
"hongze/hongze_chart_lib/models"
|
|
|
"hongze/hongze_chart_lib/models/data_manage"
|
|
|
"hongze/hongze_chart_lib/utils"
|
|
|
+ "strings"
|
|
|
"time"
|
|
|
)
|
|
|
|
|
@@ -30,9 +31,9 @@ func GetChartPredictEdbInfoDataListByRule1(edbInfoId int, dataValue float64, sta
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleTb(edbInfoId int, tbValue float64, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
@@ -161,9 +162,9 @@ func TbzDiv(a, b float64) (result float64) {
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleTc(edbInfoId int, tcValue float64, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
@@ -286,9 +287,9 @@ func TczDiv(a, b float64) (result float64) {
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleHb(edbInfoId int, hbValue float64, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
@@ -352,9 +353,9 @@ func HbzDiv(a, b float64) (result float64) {
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleHc(edbInfoId int, hcValue float64, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
@@ -412,9 +413,9 @@ func HczDiv(a, b float64) (result float64) {
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleNMoveMeanValue(edbInfoId int, nValue int, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
@@ -470,11 +471,11 @@ func GetChartPredictEdbInfoDataListByRuleNMoveMeanValue(edbInfoId int, nValue in
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
|
|
|
-
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleNLinearRegression(edbInfoId int, nValue int, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
|
|
|
|
|
@@ -587,17 +588,18 @@ func getLinearResult(s []Coordinate) (gradient, intercept float64) {
|
|
|
}
|
|
|
|
|
|
|
|
|
+
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleTrendsHC(edbInfoId, configId int, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
@@ -659,14 +661,15 @@ func GetChartPredictEdbInfoDataListByRuleTrendsHC(edbInfoId, configId int, start
|
|
|
}
|
|
|
|
|
|
|
|
|
+
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleFinalValueHc(edbInfoId int, finalValue float64, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
@@ -733,31 +736,39 @@ type SeasonConf struct {
|
|
|
}
|
|
|
|
|
|
|
|
|
+
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleSeason(edbInfoId int, yearsList []int, calendar string, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64, err error) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|
|
|
allDataList = append(allDataList, predictEdbInfoData...)
|
|
|
newPredictEdbInfoData = predictEdbInfoData
|
|
|
|
|
|
+
|
|
|
+ handleDataMap := make(map[string]float64)
|
|
|
+ err = HandleDataByLinearRegression(allDataList, handleDataMap)
|
|
|
+ if err != nil {
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
|
|
|
moveDayMap := make(map[int]int, 0)
|
|
|
{
|
|
@@ -806,13 +817,18 @@ func GetChartPredictEdbInfoDataListByRuleSeason(edbInfoId int, yearsList []int,
|
|
|
|
|
|
predictEdbInfoData = make([]*models.EdbDataList, 0)
|
|
|
for k, currentDate := range dayList {
|
|
|
+
|
|
|
+ if strings.Contains(currentDate.Format(utils.FormatDate), "02-29") {
|
|
|
+ continue
|
|
|
+ }
|
|
|
tmpHistoryVal := decimal.NewFromFloat(0)
|
|
|
tmpHistoryValNum := 0
|
|
|
|
|
|
tmpLenAllDataList := len(allDataList)
|
|
|
- tmpK := tmpLenAllDataList - 1
|
|
|
- lastDayStr := allDataList[tmpK].DataTime
|
|
|
- lastDayVal := allDataList[tmpK].Value
|
|
|
+ tmpK := tmpLenAllDataList - 1
|
|
|
+ lastDayData := allDataList[tmpK]
|
|
|
+ lastDayStr := lastDayData.DataTime
|
|
|
+ lastDayVal := lastDayData.Value
|
|
|
lastDay, tmpErr := time.ParseInLocation(utils.FormatDate, lastDayStr, time.Local)
|
|
|
if tmpErr != nil {
|
|
|
err = errors.New("获取上期日期转换失败:" + tmpErr.Error())
|
|
@@ -823,16 +839,16 @@ func GetChartPredictEdbInfoDataListByRuleSeason(edbInfoId int, yearsList []int,
|
|
|
var isFindHistoryCurrent, isFindHistoryLast bool
|
|
|
|
|
|
|
|
|
- tmpHistoryCurrentDate := currentDate.AddDate(year-currentDate.Year(), 0, moveDay)
|
|
|
+ tmpHistoryCurrentDate := currentDate.AddDate(year-currentDate.Year(), 0, -moveDay)
|
|
|
for i := 0; i <= 35; i++ {
|
|
|
tmpDate := tmpHistoryCurrentDate.AddDate(0, 0, i)
|
|
|
- if val, ok := existMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
+ if val, ok := handleDataMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
tmpHistoryCurrentVal = val
|
|
|
isFindHistoryCurrent = true
|
|
|
break
|
|
|
} else {
|
|
|
tmpDate := tmpHistoryCurrentDate.AddDate(0, 0, -i)
|
|
|
- if val, ok := existMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
+ if val, ok := handleDataMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
tmpHistoryCurrentVal = val
|
|
|
isFindHistoryCurrent = true
|
|
|
break
|
|
@@ -841,16 +857,16 @@ func GetChartPredictEdbInfoDataListByRuleSeason(edbInfoId int, yearsList []int,
|
|
|
}
|
|
|
|
|
|
|
|
|
- tmpHistoryLastDate := lastDay.AddDate(year-lastDay.Year(), 0, moveDay)
|
|
|
+ tmpHistoryLastDate := lastDay.AddDate(year-lastDay.Year(), 0, -moveDay)
|
|
|
for i := 0; i <= 35; i++ {
|
|
|
tmpDate := tmpHistoryLastDate.AddDate(0, 0, i)
|
|
|
- if val, ok := existMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
+ if val, ok := handleDataMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
tmpHistoryLastVal = val
|
|
|
isFindHistoryLast = true
|
|
|
break
|
|
|
} else {
|
|
|
tmpDate := tmpHistoryLastDate.AddDate(0, 0, -i)
|
|
|
- if val, ok := existMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
+ if val, ok := handleDataMap[tmpDate.Format(utils.FormatDate)]; ok {
|
|
|
tmpHistoryLastVal = val
|
|
|
isFindHistoryLast = true
|
|
|
break
|
|
@@ -876,16 +892,24 @@ func GetChartPredictEdbInfoDataListByRuleSeason(edbInfoId int, yearsList []int,
|
|
|
|
|
|
currentDateStr := currentDate.Format(utils.FormatDate)
|
|
|
tmpData := &models.EdbDataList{
|
|
|
- EdbDataId: edbInfoId + 10000000000 + index + k,
|
|
|
- EdbInfoId: edbInfoId,
|
|
|
- DataTime: currentDateStr,
|
|
|
- Value: val,
|
|
|
- DataTimestamp: (currentDate.UnixNano() / 1e6) + 1000,
|
|
|
+ EdbDataId: edbInfoId + 10000000000 + index + k,
|
|
|
+
|
|
|
+ DataTime: currentDateStr,
|
|
|
+ Value: val,
|
|
|
+
|
|
|
}
|
|
|
newPredictEdbInfoData = append(newPredictEdbInfoData, tmpData)
|
|
|
allDataList = append(allDataList, tmpData)
|
|
|
existMap[currentDateStr] = val
|
|
|
|
|
|
+
|
|
|
+ err = HandleDataByLinearRegression([]*models.EdbDataList{
|
|
|
+ lastDayData, tmpData,
|
|
|
+ }, handleDataMap)
|
|
|
+ if err != nil {
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
|
|
|
if val < minValue {
|
|
|
minValue = val
|
|
@@ -904,21 +928,22 @@ type MoveAverageConf struct {
|
|
|
}
|
|
|
|
|
|
|
|
|
+
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
func GetChartPredictEdbInfoDataListByRuleMoveAverageTb(edbInfoId int, nValue, year int, startDate, endDate time.Time, frequency string, realPredictEdbInfoData, predictEdbInfoData []*models.EdbDataList, existMap map[string]float64) (newPredictEdbInfoData []*models.EdbDataList, minValue, maxValue float64, err error) {
|
|
|
allDataList := make([]*models.EdbDataList, 0)
|
|
|
allDataList = append(allDataList, realPredictEdbInfoData...)
|