@@ -67,7 +67,7 @@ class DataSta():
HvSaftyCode=[]
SysSaftyCode=[]
CellSaftyCode=[3,5,6,7,8,9,10,11,13,14,15,16,17,19,20,21,15,16,17,19,23,24,25,26,29,30,31,51,119]
- CtrlSatyCode=[4,12,18,20,21,22]
+ CtrlSatyCode=[4,12,18,20,21,22,57]
StateSaftyCode=[27,28,52]
DsnSaftyCodeCount=len(df_fltinfo[df_fltinfo['code'].isin(DsnSaftyCode)])
@@ -0,0 +1,74 @@
+import sys
+import numpy as np
+import pandas as pd
+import string
+import os
+from pandas import Series
+from matplotlib import pyplot as plt
+from pandas.core.frame import DataFrame
+from pandas.core.indexes.base import Index
+from LIB.BACKEND import DBManager
+import datetime
+import time
+import re
+
+class CtrlSafty:
+ def __init__(self):
+ pass
+ def main(sn,param,bms_info,df_Diag_Ram_in):
+ df_Diag_Ram_Update_inside=DataFrame(columns=['start_time', 'end_time', 'product_id', 'code', 'level', 'info','advice'])
+ df_Diag_Ram_Update_inside=df_Diag_Ram_Update_inside.append(df_Diag_Ram_in)
+ global QuitErrCount
+ VolStarkCount=[0 for i in range(param.CellVoltNums)]
+ VolCount=0
+ QuitErrCount=[0 for i in range(param.FaultCount)]
+ #--------------该电池的所有当前故障-------------
+ df_Diag_Ram_Update_inside=CtrlSafty.TempCtrlDiag(sn,bms_info,param,df_Diag_Ram_Update_inside)
+ return df_Diag_Ram_Update_inside
+ def TempCtrlDiag(sn,bms_info,param,df_Diag_Ram):
+ ErrorFlg=0
+ CellTempMax=0
+ OtherTempMax=0
+ CellTempNum=['单体温度'+str(i) for i in range(1,param.CellTempNums+1)]
+ if 'MXMLX' in sn:
+ OtherTempNum=['其他温度1','其他温度3','其他温度4','其他温度5']
+ else:
+ OtherTempNum=['其他温度'+str(i) for i in range(1,param.OtherTempNums+1)]
+ CellTempMax=bms_info[bms_info[CellTempNum]>(param.CellMaxUSBTemp-5)]
+ CellTempMax=CellTempMax[CellTempMax<(param.CellMaxUSBTemp+5)]
+ OtherTempMax=bms_info[bms_info[OtherTempNum]>(param.OtherOTlmt-10)]
+ OtherTempMax=OtherTempMax[OtherTempMax[OtherTempNum]<(param.OtherOTlmt+5)]
+ if len(CellTempMax) and len(OtherTempMax):
+ QuitErrCount[57]=0
+ if not 57 in df_Diag_Ram['code'].values.tolist():#如果故障发生当前故障中没有该故障,则压入该故障
+ df_Diag_Ram.loc[len(df_Diag_Ram)]=[bms_info.loc[len(bms_info)-1,'时间戳'],'0000-00-00 00:00:00',sn,57,4,'电芯温度高','立即联系用户确认电池状态']
+ ErrorFlg=1
+ else:#如果故障发生当前故障中有该故障,则不进行操作
+ if 57 in df_Diag_Ram['code'].values.tolist():
+ QuitErrCount[57]=QuitErrCount[57]+1
+ if QuitErrCount[57]>3:
+ QuitErrCount[57]=4
+ end_time=datetime.datetime.now()
+ end_time=end_time.strftime('%Y-%m-%d %H:%M:%S')
+ df_Diag_Ram.loc[df_Diag_Ram[df_Diag_Ram['code']==57].index,['end_time']]=end_time
+ print(df_Diag_Ram)
+ return df_Diag_Ram
@@ -1,5 +1,8 @@
import CBMSBatDiag
from SC_SamplingSafty import SamplingSafty
+from DataStatistics import DataSta
+from DiagDataMerge import DiagDataMerge
+from SC_CtrlSafty import CtrlSafty
import datetime
import pandas as pd
from LIB.BACKEND import DBManager, Log
@@ -12,8 +15,6 @@ from pandas.core.frame import DataFrame
import datacompy
from LIB.MIDDLE.SaftyCenter.Common import QX_BatteryParam
from LIB.MIDDLE.SaftyCenter.Common import DBDownload as DBDw
-from DataStatistics import DataSta
-from DiagDataMerge import DiagDataMerge
#...................................电池包电芯安全诊断函数......................................................................................................................
def diag_cal():
@@ -27,6 +28,8 @@ def diag_cal():
start_time=start_time.strftime('%Y-%m-%d %H:%M:%S')
end_time=end_time.strftime('%Y-%m-%d %H:%M:%S')
host='rm-bp10j10qy42bzy0q77o.mysql.rds.aliyuncs.com'
port=3306
db='safety_platform'
@@ -101,7 +104,8 @@ def diag_cal():
#获取当前故障电池的历史故障信息↑↑↑↑↑↑↑↑↑↑↑.......................................................................................................................................
if not df_bms.empty:
df_Diag_Batdiag_update_xq=SamplingSafty.main(sn,param,df_bms,CellFltInfo)#学琦计算故障
- batDiag=CBMSBatDiag.BatDiag(sn,celltype,df_bms, df_soh, df_uniform, df_Diag_Batdiag_update_xq)#鹏飞计算
+ df_Diag_Batdiag_update_xq2=CtrlSafty.main(sn,param,df_bms,df_Diag_Batdiag_update_xq)
+ batDiag=CBMSBatDiag.BatDiag(sn,celltype,df_bms, df_soh, df_uniform, df_Diag_Batdiag_update_xq2)#鹏飞计算
df_Diag_Batdiag_update=batDiag.diag()
# df_Diag_Batdiag_update=BatDiag.diag()
else:
@@ -255,7 +259,7 @@ if __name__ == "__main__":
SNnums_U7255=SNdata_U7255['SN号'].tolist()
SNnums=SNnums_L7255 + SNnums_C7255 + SNnums_6040 + SNnums_4840 + SNnums_U7255+ SNnums_6060
# SNnums=['MGMCLN750N215I005','PK504B10100004341','PK504B00100004172','MGMLXN750N2189014']
- #SNnums = ['MGMLXN750N218G006'] #SNnums_6040
+ SNnums = ['MGMLXN750N218N004'] #SNnums_6040
mylog=log.Mylog('log_diag.txt','error')
mylog.logcfg()