123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 |
- #定义电池参数
- class BatParam:
- def __init__(self,celltype):
- #公用参数................................................................................................................................................
- #热失控参数
- self.TrwTempHigh=60
- self.TrwTempRate=3
- self.TrwTempDiff=15
- self.TrwCellVoltDiff=2.5
- self.TrwCellVoltFall=0.5
- self.TrwCellVoltLow=1.5
- self.TrwPackVoltFall=1.5
-
- #故障诊断参数
- self.temp_time=10
- self.volt_time=10
- self.SocJump=10
- self.SocClamp=0.1
- self.SocLow=3
- self.SocDiff=20
- self.SohLow=65
- self.SohDiff=15
- #mana-kendall趋势检验参数
- self.mk_p=0.001
- self.mk_z=-5
- self.mk_Tau=-0.7
- self.mk_slope=-0.1
- self.mk_s=-260
- self.mk_svar=1600
- self.OcvWeight_Temp=[-30,-20,-10,0,10,20,30,40,50]
- self.OcvWeight_StandingTime=[0,500,600,1200,1800,3600,7200,10800]
- self.OcvWeight =[[0,0, 0, 0, 0, 0.1,0.3, 1],
- [0,0, 0, 0, 0, 0.1,0.3, 1],
- [0,0, 0, 0, 0, 0.2,0.5, 1],
- [0,0, 0, 0, 0.2, 0.4,0.8, 1],
- [0,0, 0, 0.1, 0.3, 0.6,1, 1],
- [0,0, 0.1,0.2, 0.5, 0.8,1, 1],
- [0,0, 0.1,0.3, 0.6, 1, 1, 1],
- [0,0, 0.1,0.3, 0.7, 1, 1, 1],
- [0,0, 0.2,0.3, 0.8, 1, 1, 1]]
- if celltype==1: #永联+康普顿21700
- self.Capacity = 4*2
- self.PackFullChrgVolt=69.99
- self.CellFullChrgVolt=4.2
- self.CellFullChrgCrnt=-4
- self.CellVoltNums=120
- self.CellTempNums=40
- self.FullChrgSoc=90
- self.PackCrntDec=1
- self.BalCurrent=0.015
- self.LookTab_SOC = [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95, 100]
- self.LookTab_OCV = [2.8497, 3.0924, 3.2868, 3.4117, 3.4461, 3.5032, 3.5602, 3.6049, 3.6368, 3.6709, 3.7121, 3.7593, 3.8237, 3.8755, 3.9093, 3.9518, 4.0119, 4.0615, 4.077, 4.0969, 4.1821]
- self.CellOvLv1=4.2
- self.CellOvLv2=4.25
- self.CellUvLv1=2.8
- self.CellUvLv2=2.5
- self.CellVoltDiffLv1=0.3
- self.CellVoltDiffLv2=0.5
- self.PackVoltOvLv1=self.CellOvLv1*self.CellVoltNums
- self.PackVoltOvLv2=self.CellOvLv2*self.CellVoltNums
- self.PackVoltUvLv1=self.CellUvLv1*self.CellVoltNums
- self.PackVoltUvLv2=self.CellUvLv2*self.CellVoltNums
- self.CellTempUpLmt=119
- self.CellTempLwLmt=-39
- self.CellTempHighLv1=45
- self.CellTempHighLv2=50
- self.CellTempLowLv1=0
- self.CellTempLowLv2=-5
- self.CellTempDiffLv1=10
- self.CellTempDiffLv2=15
- self.CellTempRate=5
- self.PackChgOc=-40
- self.PackDisOc=200
- self.LeakCurrentLv1=-10
- self.LeakCurrentLv2=-15
- self.LeakCurrentLv3=-50
- self.TrwVoltRate=-1
- elif celltype==2: #中恒+华庭18650
- self.Capacity = 2*9
- self.CellVoltNums= 68
- self.CellTempNums= 40
- self.CellFullChrgVolt=4.2
- self.CellFullChrgCrnt=-self.Capacity/2
- self.FullChrgSoc=100
- self.PackCrntDec=1
- self.BalCurrent=0.015
- self.LookTab_SOC = [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95, 100]
- self.LookTab_OCV = [2.929, 3.2902, 3.3888, 3.425, 3.4846, 3.5382, 3.577, 3.6083, 3.638, 3.6786, 3.7127, 3.7596, 3.7853, 3.8371, 3.9081, 3.9127, 4.0097, 4.0314, 4.0463, 4.0969, 4.174]
- self.CellOvLv1=4.04
- self.CellOvLv2=4.05
- self.CellUvLv1=2.99
- self.CellUvLv2=2.950
- self.CellVoltDiffLv1=0.35
- self.CellVoltDiffLv2=0.4
- self.PackVoltOvLv1=self.CellOvLv1*self.CellVoltNums
- self.PackVoltOvLv2=self.CellOvLv2*self.CellVoltNums
- self.PackVoltUvLv1=self.CellUvLv1*self.CellVoltNums
- self.PackVoltUvLv2=self.CellUvLv2*self.CellVoltNums
- self.CellTempUpLmt=119
- self.CellTempLwLmt=-39
- self.CellTempHighLv1=45
- self.CellTempHighLv2=50
- self.CellTempLowLv1=0
- self.CellTempLowLv2=-5
- self.CellTempDiffLv1=10
- self.CellTempDiffLv2=15
- self.CellTempRate=5
- self.PackChgOc=-45
- self.PackDisOc=200
- self.LeakCurrentLv1=-10
- self.LeakCurrentLv2=-15
- self.LeakCurrentLv3=-50
- self.TrwVoltRate=-1
- elif celltype==99: #永联+力神
- self.Capacity = 40*2
- self.CellVoltNums=72
- self.CellTempNums=32
- self.CellFullChrgVolt=3.5
- self.CellFullChrgCrnt=-self.Capacity/2
- self.OcvInflexionBelow=3.285
- self.OcvInflexion2=3.303
- self.OcvInflexion3=3.343
- self.OcvInflexionAbove=3.36
- self.SocInflexion1=30
- self.SocInflexion2=60
- self.SocInflexion3=70
- self.FullChrgSoc=97
- self.PeakSoc=62.5
- self.PeakVoltLowLmt=3.37
- self.PeakVoltUpLmt=3.42
- self.PeakCellVolt=[3.384,3.385,3.386,3.387,3.388]
- self.PackCrntDec=1
- self.BalCurrent=0.015
- self.LookTab_SOC = [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 75, 80, 85, 90, 95, 96, 97, 98, 99, 100]
- self.LookTab_OCV = [2.6748, 3.2020, 3.2170, 3.2430, 3.2600, 3.2770, 3.2880, 3.2890, 3.2900, 3.2910, 3.2911, 3.2970, 3.3030, 3.3080, 3.3200, 3.3270, 3.3290, 3.3300, 3.3301, 3.3310, 3.3311, 3.3312, 3.3313, 3.3314, 3.3315, 3.3316, 3.3320, 3.3330, 3.3340, 3.3350, 3.3360, 3.3580, 3.3640]
- self.LookTab_OCVChg=[2.6460, 3.1570, 3.2220, 3.2450,3.2760, 3.2970, 3.3060, 3.3070, 3.3080, 3.3090, 3.3110, 3.3140, 3.3220, 3.3270, 3.3330, 3.3380, 3.3420, 3.3421, 3.3422, 3.3423, 3.3424, 3.3431, 3.3432, 3.3433, 3.3434, 3.3441, 3.3442, 3.3443, 3.3444, 3.3445, 3.3446, 3.3447, 3.3640]
- self.CellOvLv1=3.65
- self.CellOvLv2=3.7
- self.CellUvLv1=2.7
- self.CellUvLv2=2.6
- self.CellVoltDiffLv1=0.6
- self.CellVoltDiffLv2=1.1
- self.PackVoltOvLv1=self.CellOvLv1*self.CellVoltNums
- self.PackVoltOvLv2=self.CellOvLv2*self.CellVoltNums
- self.PackVoltUvLv1=self.CellUvLv1*self.CellVoltNums
- self.PackVoltUvLv2=self.CellUvLv2*self.CellVoltNums
- self.CellTempUpLmt=119
- self.CellTempLwLmt=-39
- self.CellTempHighLv1=45
- self.CellTempHighLv2=50
- self.CellTempLowLv1=0
- self.CellTempLowLv2=-5
- self.CellTempDiffLv1=15
- self.CellTempDiffLv2=20
- self.CellTempRate=5
- self.PackChgOc=-160
- self.PackDisOc=180
- self.LeakCurrentLv1=-20
- self.LeakCurrentLv2=-30
- self.LeakCurrentLv3=-100
- self.TrwVoltRate=-8
- self.mk_slope=-0.8
-
- else:
- print('未找到对应电池编号!!!')
- # sys.exit()
|