123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- import pandas as pd
- import numpy as np
- import datetime
- import pika
- import json
- from USER.SPF.alibaba.Common import BatParam
- class BatCrtl():
- def __init__(self,host,port,df_statectrl_ram,df_rlyctrl_ram,df_diag,df_bms,sn_list): #参数初始化
- celltype=1
- self.host=host
- self.port=port
- self.sn_list=sn_list
- self.param=BatParam.BatParam(celltype)
-
- df_bms['time']=pd.to_datetime(df_bms['time'], format='%Y-%m-%d %H:%M:%S')
- self.df_bms=df_bms
- self.df_statectrl_ram=df_statectrl_ram.copy()
- self.df_rlyctrl_ram=df_rlyctrl_ram.copy()
- self.df_diag1=df_diag[(df_diag['fault_code']==110) | (df_diag['fault_code']==119) | (df_diag['fault_code']==12) | (df_diag['fault_code']==18)]
- self.df_diag2=df_diag[df_diag['fault_code']==100]
-
- # self.bmstime=df_bms['time']
- # self.packcrnt=df_bms['PackCrnt']*self.param.PackCrntDec
- # self.bms_soc=df_bms['PackSOC']
- # self.bms_soh=df_bms['PackSOH']
- # self.bmsstat=df_bms['BMSStat']
- self.cellvolt_name=['CellVolt'+str(x) for x in range(1,self.param.CellVoltNums+1)]
- self.celltemp_name=['CellTemp'+str(x) for x in range(1,self.param.CellTempNums+1)]
- #主调用函数........................................................................
- def bat_crtl(self):
- df_res1=self._bat_rlycrtl()
- df_res2=self._bat_statecrtl()
- return df_res1,df_res2
-
- #Ribbit队列发送数据..............................................................
- def _rabbit_send(self, dict_send):
- # 建立一个实例
- credentials = pika.PlainCredentials('admin', 'admin')
- connection = pika.BlockingConnection(pika.ConnectionParameters(self.host,self.port,credentials=credentials))
- # 声明一个管道,在管道里发消息
- channel = connection.channel()
- # 在管道里声明queue
- channel.queue_declare(queue='cmdQueue',durable=True)
- channel.basic_publish(exchange='cmdExchange',routing_key='CmdDirectRouting',body=json.dumps(dict_send)) # 消息内容
- connection.close()
- #电池继电器下行控制.........................................................................................................................
- def _bat_rlycrtl(self):
- time_now=datetime.datetime.now()
- if self.df_bms.empty:
- factory='康普盾'
- else:
- factory=self.df_bms.iloc[0]['factory']
- for sn in self.sn_list:
- if sn in list(self.df_diag1['sn']): #该sn发生4级或5级故障
- if sn in list(self.df_rlyctrl_ram['sn']): #ram是否包含该sn
- if self.df_rlyctrl_ram.loc[self.df_rlyctrl_ram[self.df_rlyctrl_ram['sn']==sn].index[0], 'batrlyctrl']==0:
- self.df_rlyctrl_ram.loc[self.df_rlyctrl_ram[self.df_rlyctrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_rlyctrl_ram.loc[self.df_rlyctrl_ram[self.df_rlyctrl_ram['sn']==sn].index[0], 'batrlyctrl']=1
- dict_send={"cmd_type":1,"factory":factory,"sn":sn,"batrlyctrl":1}
- self._rabbit_send(dict_send)
- return self.df_rlyctrl_ram
- else:
- pass
- else:
- self.df_rlyctrl_ram.loc[len(self.df_rlyctrl_ram)]=[time_now,sn,1]
- dict_send={"cmd_type":1,"factory":factory,"sn":sn,"batrlyctrl":1}
- self._rabbit_send(dict_send)
- return self.df_rlyctrl_ram
- else: #该sn没有4级和5级故障
- if sn in list(self.df_rlyctrl_ram['sn']): #ram是否包含该sn
- if self.df_rlyctrl_ram.loc[self.df_rlyctrl_ram[self.df_rlyctrl_ram['sn']==sn].index[0], 'batrlyctrl']==1:
- self.df_rlyctrl_ram.loc[self.df_rlyctrl_ram[self.df_rlyctrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_rlyctrl_ram.loc[self.df_rlyctrl_ram[self.df_rlyctrl_ram['sn']==sn].index[0], 'batrlyctrl']=0
- dict_send={"cmd_type":1,"factory":factory,"sn":sn,"batrlyctrl":0}
- self._rabbit_send(dict_send)
- return self.df_rlyctrl_ram
- else:
- pass
- else:
- self.df_rlyctrl_ram.loc[len(self.df_rlyctrl_ram)]=[time_now,sn,0]
- dict_send={"cmd_type":1,"factory":factory,"sn":sn,"batrlyctrl":0}
- self._rabbit_send(dict_send)
- return self.df_rlyctrl_ram
- return self.df_rlyctrl_ram
- #电池状态下行控制.........................................................................................................................
- def _bat_statecrtl(self):
- time_now=datetime.datetime.now()
- if self.df_bms.empty:
- factory='康普盾'
- else:
- factory=self.df_bms.iloc[0]['factory']
- #对完成充放电循环,且超过8天的,done_flg置0
- if not self.df_statectrl_ram.empty:
- for i in range(len(self.df_statectrl_ram)):
- if self.df_statectrl_ram.iloc[i]['done_flg']==1 and (time_now-self.df_statectrl_ram.iloc[i]['time']).total_seconds()>10*24*3600:
- self.df_statectrl_ram.iloc[i]['done_flg']=0
- else:
- pass
- else:
- pass
-
- #存在电池正在放电-------------------------------
- if 3 in list(self.df_statectrl_ram['batstatectrl']):
- sn=self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['batstatectrl']==3].index[0], 'sn']
- bms_index=self.df_bms[self.df_bms['sn']==sn].index[0]
- packsoc=self.df_bms.loc[bms_index,'PackSOC']
- cellvolt = self.df_bms.loc[bms_index,self.cellvolt_name]
- if packsoc<10 or min(cellvolt)<3: #结束放电
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'batstatectrl']=2
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":2,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else:
- pass
- #存在电池正在静置---------------------------------
- elif 2 in list(self.df_statectrl_ram['batstatectrl']):
- sn=self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['batstatectrl']==2].index[0], 'sn']
- bms_index=self.df_bms[self.df_bms['sn']==sn].index[0]
- packcrnt=self.df_bms.loc[bms_index,'PackCrnt']
- packsoc=self.df_bms.loc[bms_index,'PackSOC']
- cellvolt = self.df_bms.loc[bms_index,self.cellvolt_name]
- if packsoc>25 or min(cellvolt)>3.5:
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'batstatectrl']=3
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":3,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- elif abs(packcrnt)<0.1: #当前工况确实在静置
- time_st=self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']
- if (time_now-time_st).total_seconds()>3700: #静置时间满足要求
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'batstatectrl']=1
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":1,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else:
- pass
- else:
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'batstatectrl']=2
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":2,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- #存在电池正在充电------------------------------------
- elif 1 in list(self.df_statectrl_ram['batstatectrl']):
- sn=self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['batstatectrl']==1].index[0], 'sn']
- bms_index=self.df_bms[self.df_bms['sn']==sn].index[0]
- packsoc=self.df_bms.loc[bms_index,'PackSOC']
- cellvolt = self.df_bms.loc[bms_index,self.cellvolt_name]
- if packsoc>99 or max(cellvolt)>self.param.CellFullChrgVolt: #充电已完成
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'batstatectrl']=0
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'done_flg']=1
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":0,"dischrg_volt":270}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else:
- pass
- #当前电池均不在充放电循环过程中,则接下来判断是否存在100故障---------------------------------
- else:
- for sn in self.sn_list:
- if sn in list(self.df_diag2['sn']): #该sn发生100长时间未标定故障
- if sn in list(self.df_bms['sn']):
- bms_index=self.df_bms[self.df_bms['sn']==sn].index[0]
- packsoc=self.df_bms.loc[bms_index,'PackSOC']
- cellvolt = self.df_bms.loc[bms_index,self.cellvolt_name]
- if packsoc>20 or min(cellvolt)>3.5:
- if sn in list(self.df_statectrl_ram['sn']): #该sn的ram不为空
- if self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'done_flg']==0:
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'batstatectrl']=3
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":3,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else:
- pass
- else:
- self.df_statectrl_ram.loc[len(self.df_rlyctrl_ram)]=[time_now,sn,3,0]
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":3,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else:
- if sn in list(self.df_statectrl_ram['sn']): #该sn的ram不为空
- if self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'done_flg']==0:
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'time']=time_now
- self.df_statectrl_ram.loc[self.df_statectrl_ram[self.df_statectrl_ram['sn']==sn].index[0], 'batstatectrl']=2
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":2,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else:
- pass
- else:
- self.df_statectrl_ram.loc[len(self.df_rlyctrl_ram)]=[time_now,sn,2,0]
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":2,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else: #原始数据库为空,给寄存器赋0
- if sn in list(self.df_statectrl_ram['sn']):
- pass
- else:
- self.df_statectrl_ram.loc[len(self.df_rlyctrl_ram)]=[time_now,sn,0,0]
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":0,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
- else: #没有相关故障,给寄存器赋0
- if sn in list(self.df_statectrl_ram['sn']):
- pass
- else:
- self.df_statectrl_ram.loc[len(self.df_rlyctrl_ram)]=[time_now,sn,0,0]
- dict_send={"cmd_type":2,"factory":factory,"sn":sn,"batstatectrl":0,"dischrg_volt":272}
- self._rabbit_send(dict_send)
- return self.df_statectrl_ram
-
- return self.df_statectrl_ram
-
-
|