package com.dev.bts.data;
|
|
import java.nio.ByteBuffer;
|
import java.nio.ByteOrder;
|
|
public class FBS9100_VCData
|
{
|
private final int BYTE_LEN = 1500;
|
private final int BATTGROUP_COUNT = FBS9100_ComBase.BattGroupCountMax;
|
private final int BASIC_LEN = 12 + 20*BATTGROUP_COUNT;
|
|
public FBS9100_SysState m_SysState = new FBS9100_SysState();
|
|
public int dataType[] = {0xAA, 0xAA, 0xAA, 0xAA};
|
public int CRC = 0;
|
public FBS9100_TestTime testTime = new FBS9100_TestTime();
|
public int battGroup = 1;
|
public int battSum = 24;
|
public int battGroupNum = 1;
|
|
public int battXuHangTime = 0;
|
public int stationPowerOffTLong = 0;
|
public int stationPowerOffCNT = 0;
|
|
public double onlinevol[] = new double[FBS9100_ComBase.BattGroupCountMax]; //ÔÚÏßµçѹ
|
public double groupvol[] = new double[FBS9100_ComBase.BattGroupCountMax]; //×é¶Ëµçѹ
|
public int battstate[] = new int[FBS9100_ComBase.BattGroupCountMax]; //³ä·Åµç״̬ 3 5 9
|
public double battcurr[] = new double[FBS9100_ComBase.BattGroupCountMax]; //µç³Ø×éµçÁ÷
|
public double battcap[] = new double[FBS9100_ComBase.BattGroupCountMax]; //µç³Ø×éÈÝÁ¿
|
public double batttemp[] = new double[FBS9100_ComBase.BattGroupCountMax]; //µç³Ø×éζÈ
|
public int monMAX_num[] = new int[FBS9100_ComBase.BattGroupCountMax]; //×î´óµ¥Ìå±àºÅ
|
public int monMIN_num[] = new int[FBS9100_ComBase.BattGroupCountMax]; //×îµÍ°´µ¥Ìå±àºÅ
|
public double monvolMAX[] = new double[FBS9100_ComBase.BattGroupCountMax]; //×î´óµ¥Ìåµçѹ
|
public double monvolMIN[] = new double[FBS9100_ComBase.BattGroupCountMax]; //×îµÍµ¥Ìåµçѹ
|
|
public double vol[] = new double[FBS9100_ComBase.MonomerCountMax]; //µ¥Ìåµçѹ
|
|
public FBS9100_VCData clone()
|
{
|
FBS9100_VCData obj = new FBS9100_VCData();
|
|
obj.m_SysState = (FBS9100_SysState) m_SysState.clone();
|
obj.dataType = dataType.clone();
|
obj.CRC = CRC;
|
obj.testTime = testTime;
|
obj.battGroup = battGroup;
|
obj.battSum = battSum;
|
|
obj.onlinevol = onlinevol.clone();
|
obj.groupvol = groupvol.clone();
|
obj.battstate = battstate.clone();
|
obj.battcurr = battcurr.clone();
|
|
obj.battcap = battcap.clone();
|
obj.batttemp = batttemp.clone();
|
obj.monMAX_num = monMAX_num.clone();
|
obj.monMIN_num = monMIN_num.clone();
|
obj.monvolMAX = monvolMAX.clone();
|
obj.monvolMIN = monvolMIN.clone();
|
obj.vol = vol.clone();
|
|
return obj;
|
}
|
|
public boolean putByteBuffer(final ByteBuffer bf, int dev_type, int soft_ver)
|
{
|
if(bf.limit() < BASIC_LEN)
|
return false;
|
|
int battcount = bf.getShort(10);
|
if(battcount > FBS9100_ComBase.MonomerCountMax) {
|
return false;
|
}
|
|
ByteBuffer tmpbuf = bf;
|
int crc0 = tmpbuf.getShort(4) & 0xFFFF;
|
tmpbuf.putShort(4, (short) 0);
|
int crc1 = FBS9100_Crc16.CalCRC16(tmpbuf, BASIC_LEN + 2*battcount);
|
if(crc0 != crc1) {
|
return false;
|
}
|
|
tmpbuf.position(0);
|
for(int n=0; n<4; n++)
|
dataType[n] = FBS9100_ComBase.changeByteToInt(tmpbuf.get());
|
|
CRC = FBS9100_ComBase.changeShortToInt(tmpbuf.getShort());
|
testTime.hour = FBS9100_ComBase.changeByteToInt(tmpbuf.get());
|
testTime.minute = FBS9100_ComBase.changeByteToInt(tmpbuf.get());
|
testTime.second = FBS9100_ComBase.changeByteToInt(tmpbuf.get());
|
battGroup = FBS9100_ComBase.changeByteToInt(tmpbuf.get());
|
battSum = FBS9100_ComBase.changeShortToInt(tmpbuf.getShort());
|
|
for(int n=0; n<BATTGROUP_COUNT; n++) {
|
double o_v = FBS9100_ComBase.changeShortToDouble(tmpbuf.getShort())/10;
|
if((FBS9100_DeviceInf.Dev_Type_Nomal == dev_type)) {
|
o_v /= 10;
|
}
|
onlinevol[n] = o_v;
|
}
|
for(int n=0; n<BATTGROUP_COUNT; n++) {
|
double g_v = FBS9100_ComBase.changeShortToDouble(tmpbuf.getShort())/10;
|
if((FBS9100_DeviceInf.Dev_Type_Nomal == dev_type)) {
|
g_v /= 10;
|
}
|
groupvol[n] = g_v;
|
}
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
battstate[n] = FBS9100_ComBase.changeShortToInt(tmpbuf.getShort());
|
for(int n=0; n<BATTGROUP_COUNT; n++) {
|
double b_curr = FBS9100_ComBase.changeShortToDouble(tmpbuf.getShort())/10;
|
// if(FBS9100_ComBase.BattState_Discharge == battstate[n]) {
|
// b_curr *= -1;
|
// }
|
battcurr[n] = b_curr;
|
}
|
for(int n=0; n<BATTGROUP_COUNT; n++) {
|
double b_cap = FBS9100_ComBase.changeShortToDouble(tmpbuf.getShort());
|
if(FBS9100_ComBase.BattState_Discharge == battstate[n]) {
|
b_cap *= -1;
|
}
|
battcap[n] = b_cap;
|
}
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
batttemp[n] = FBS9100_ComBase.changeShortToDouble((short)(tmpbuf.getShort()-(short)100))/10;
|
for(int n=0; n<BATTGROUP_COUNT; n++) {
|
monMAX_num[n] = FBS9100_ComBase.changeShortToInt(tmpbuf.getShort());
|
}
|
battXuHangTime = (monMAX_num[0]<<16) + monMAX_num[1];
|
stationPowerOffTLong = (monMAX_num[2]<<16) + monMAX_num[3];
|
|
for(int n=0; n<BATTGROUP_COUNT; n++) {
|
monMIN_num[n] = FBS9100_ComBase.changeShortToInt(tmpbuf.getShort());
|
}
|
stationPowerOffCNT = monMIN_num[0];
|
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
monvolMAX[n] = FBS9100_ComBase.changeShortToDouble(tmpbuf.getShort())/1000;
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
monvolMIN[n] = FBS9100_ComBase.changeShortToDouble(tmpbuf.getShort())/1000;
|
|
for(int n=0; n<battSum; n++) {
|
vol[n] = FBS9100_ComBase.changeShortToDouble(tmpbuf.getShort())/1000;
|
}
|
|
tmpbuf.compact();
|
tmpbuf.flip();
|
|
return true;
|
}
|
|
/**
|
* ¸ù¾Ýµ±Ç°Êý¾Ý¹¹ÔìÊý¾Ý
|
* @param datatype
|
* @return
|
*/
|
public ByteBuffer getByteBuffer(int datatype,FBS9100_ResCapData data)
|
{
|
ByteBuffer bytebuffer = ByteBuffer.allocate(BYTE_LEN);
|
bytebuffer.order(ByteOrder.LITTLE_ENDIAN);
|
|
// for(int n=0; n<4; n++)
|
// bytebuffer.put(FBS9100_ComBase.changeIntToByte(dataType[n]));
|
//
|
// CRC = 0;
|
// bytebuffer.putShort(FBS9100_ComBase.changeIntToShort(CRC));
|
// bytebuffer.put(FBS9100_ComBase.changeIntToByte(testTime.hour));
|
// bytebuffer.put(FBS9100_ComBase.changeIntToByte(testTime.minute));
|
// bytebuffer.put(FBS9100_ComBase.changeIntToByte(testTime.second));
|
// bytebuffer.put(FBS9100_ComBase.changeIntToByte(battGroup));
|
// //System.err.println(bytebuffer.position()+"#########################");
|
// bytebuffer.putShort(FBS9100_ComBase.changeIntToShort(battSum));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(onlinevol[n]*100));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(groupvol[n]*100));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeIntToShort(battstate[n]));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(battcurr[n]*10));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(battcap[n]));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(batttemp[n]*10+100));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeIntToShort(monMAX_num[n]));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeIntToShort(monMIN_num[n]));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(monvolMAX[n]*1000));
|
for(int n=0; n<BATTGROUP_COUNT; n++)
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(monvolMIN[n]*1000));
|
|
for(int n=0; n<battSum; n++) {
|
if(datatype == FBS9100_ComBase.DataType_MonVol) {
|
//Ä£ÄâµÄµ¥Ìåµçѹ
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(vol[n]*1000));
|
}else if(datatype == FBS9100_ComBase.DataType_MonRes) {
|
//Ä£ÄâµÄµ¥ÌåÄÚ×è
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort(data.m_res[n]*1000));
|
}else if(datatype == FBS9100_ComBase.DataType_MonTmp) {
|
//Ä£ÄâµÄµ¥ÌåζÈ
|
bytebuffer.putShort(FBS9100_ComBase.changeDoubleToShort((data.m_tmp[n]+10)*10));
|
}
|
|
}
|
|
CRC = FBS9100_Crc16.CalCRC16(bytebuffer, bytebuffer.position());
|
bytebuffer.putShort(4, FBS9100_ComBase.changeIntToShort(CRC));
|
|
bytebuffer.flip();
|
//System.err.println("buffer limit:"+bytebuffer.limit());
|
return bytebuffer;
|
}
|
|
|
/**
|
* Ä£ÄâËæ»ú²âÊÔµçÁ÷
|
* @param testGroupNum
|
* @param limitCurr
|
*/
|
public void setRandomTestCurr(int testGroupNum ,float limitCurr) {
|
if(battcurr[testGroupNum-1] > (limitCurr + 5)) {
|
battcurr[testGroupNum-1] = battcurr[testGroupNum-1] - 5 +(double)FBS9100_ComBase.CreateIntRanDom(0,10)/10;
|
}else if(battcurr[testGroupNum-1] >= (limitCurr + 0.5)) {
|
battcurr[testGroupNum-1] = battcurr[testGroupNum-1] - (double)FBS9100_ComBase.CreateIntRanDom(0,5)/10;
|
}else if(battcurr[testGroupNum-1] < (limitCurr-5)) {
|
battcurr[testGroupNum-1] = battcurr[testGroupNum-1] + 5 - (double)FBS9100_ComBase.CreateIntRanDom(0,10)/10;
|
}else if(battcurr[testGroupNum-1] <= (limitCurr-0.5)) {
|
battcurr[testGroupNum-1] = battcurr[testGroupNum-1] + (double)FBS9100_ComBase.CreateIntRanDom(0,5)/10;
|
}
|
}
|
|
@Override
|
public String toString() {
|
return "FBS9100_VCData [BYTE_LEN=" + BYTE_LEN/* + ", BATTGROUP_COUNT=" + BATTGROUP_COUNT + ", BASIC_LEN="
|
+ BASIC_LEN + ", m_SysState=" + m_SysState + ", dataType=" + Arrays.toString(dataType) + ", CRC=" + CRC
|
+ ", testTime=" + testTime + ", battGroup=" + battGroup + ", battSum=" + battSum + ", battGroupNum="
|
+ battGroupNum + ", onlinevol=" + Arrays.toString(onlinevol) + ", groupvol=" + Arrays.toString(groupvol)
|
+ ", battstate=" + Arrays.toString(battstate) + ", battcurr=" + Arrays.toString(battcurr) + ", battcap="
|
+ Arrays.toString(battcap) + ", batttemp=" + Arrays.toString(batttemp) + ", monMAX_num="
|
+ Arrays.toString(monMAX_num) + ", monMIN_num=" + Arrays.toString(monMIN_num) + ", monvolMAX="
|
+ Arrays.toString(monvolMAX) + ", monvolMIN=" + Arrays.toString(monvolMIN) + ", vol="
|
+ Arrays.toString(vol) + "]"*/;
|
}
|
|
|
|
|
}
|
/***************************************************************************************
|
****************************** end of file (FBS_VCData) ********************************
|
***************************************************************************************/
|