!17 根据GBT27930解析中止原因

* Merge branch 'feat_0x1d' into develop
* 删除main方法; 添加单元测试
* Merge branch 'feat_0x1d' into develop
* 根据GBT27930解析中止原因
This commit is contained in:
2025-08-07 13:16:16 +00:00
committed by 三丙
parent 3f4bb375a0
commit 35ea634f9d
2 changed files with 201 additions and 29 deletions

View File

@@ -86,10 +86,50 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
* BMS中止充电原因枚举 * BMS中止充电原因枚举
*/ */
public enum AbortReasonEnum { public enum AbortReasonEnum {
SOC_TARGET("需求SOC目标值"), SOC_TARGET("需求SOC目标值") {
TOTAL_VOLTAGE("达到总电压设定值"), @Override
CELL_VOLTAGE("达到单体电压设定值"), public String getStateDescription(int state) {
CHARGER_INITIATED("充电机主动中止"); switch (state) {
case 0: return "未达到所需SOC目标值";
case 1: return "达到所需SOC目标值";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
TOTAL_VOLTAGE("达到总电压设定值") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "未达到总电压设定值";
case 1: return "达到总电压设定值";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
CELL_VOLTAGE("达到单体电压设定值") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "未达到单体电压设定值";
case 1: return "达到单体电压设定值";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
CHARGER_INITIATED("充电机主动中止") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "充电机主动中止正常";
case 1: return "充电机中止(收到CST帧)";
case 2: return "不可信状态";
default: return "未知状态";
}
}
};
private final String description; private final String description;
@@ -100,6 +140,8 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
public String getDescription() { public String getDescription() {
return description; return description;
} }
public abstract String getStateDescription(int state);
} }
/** /**
@@ -119,26 +161,103 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
int bitPosition = reason.ordinal() * 2; int bitPosition = reason.ordinal() * 2;
int mask = 0b11 << bitPosition; // 创建该组的位掩码 int mask = 0b11 << bitPosition; // 创建该组的位掩码
int groupValue = (value & mask) >>> bitPosition; // 提取组值 int groupValue = (value & mask) >>> bitPosition; // 提取组值
reasons.add(reason.getStateDescription(groupValue));
if (groupValue != 0) {
reasons.add(reason.getDescription());
}
} }
return Joiner.on(",").join(reasons); return Joiner.on(", ").join(reasons);
} }
/** /**
* BMS中止充电故障原因枚举 * BMS中止充电故障原因枚举
*/ */
public enum FaultReasonsEnum { public enum FaultReasonsEnum {
INSULATION_FAULT("绝缘故障"), INSULATION_FAULT("绝缘故障"){
CONNECTOR_OVERHEAT("输出连接器过温故障"), @Override
BMS_COMPONENT_OVERHEAT("BMS元件过温故障"), public String getStateDescription(int state) {
CHARGING_CONNECTOR_FAULT("充电连接器故障"), switch (state) {
BATTERY_OVERHEAT("电池组温度过高故障"), case 0: return "绝缘正常";
HIGH_VOLTAGE_RELAY_FAULT("高压继电器故障"), case 1: return "绝缘故障";
VOLTAGE_DETECTION_FAULT("检测点2电压检测故障"), case 2: return "不可信状态";
OTHER_FAULT("其他故障"); default: return "未知状态";
}
}
},
CONNECTOR_OVERHEAT("输出连接器过温故障"){
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "输出连接器正常";
case 1: return "输出连接器过温故障";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
BMS_COMPONENT_OVERHEAT("BMS元件过温故障") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "BMS元件正常";
case 1: return "BMS元件过温故障";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
CHARGING_CONNECTOR_FAULT("充电连接器故障") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "充电连接器正常";
case 1: return "充电连接器故障";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
BATTERY_OVERHEAT("电池组温度过高故障") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "电池组温度正常";
case 1: return "电池组温度过高故障";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
HIGH_VOLTAGE_RELAY_FAULT("高压继电器故障") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "高压继电器正常";
case 1: return "高压继电器故障";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
VOLTAGE_DETECTION_FAULT("检测点2电压检测故障") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "检测点2电压检测正常";
case 1: return "检测点2电压检测故障";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
OTHER_FAULT("其他故障") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "其他正常";
case 1: return "其他故障";
case 2: return "不可信状态";
default: return "未知状态";
}
}
};
private final String description; private final String description;
@@ -149,6 +268,9 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
public String getDescription() { public String getDescription() {
return description; return description;
} }
public abstract String getStateDescription(int state);
} }
/** /**
@@ -171,12 +293,9 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
int bitPosition = fault.ordinal() * 2; int bitPosition = fault.ordinal() * 2;
int mask = 0b11 << bitPosition; // 创建该组的位掩码 int mask = 0b11 << bitPosition; // 创建该组的位掩码
int groupValue = (value & mask) >>> bitPosition; // 提取组值 int groupValue = (value & mask) >>> bitPosition; // 提取组值
faults.add(fault.getStateDescription(groupValue));
if (groupValue != 0) {
faults.add(fault.getDescription());
}
} }
return Joiner.on(",").join(faults); return Joiner.on(", ").join(faults);
} }
/** /**
@@ -184,8 +303,28 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
*/ */
@Getter @Getter
public enum ErrorReasonsEnum { public enum ErrorReasonsEnum {
CURRENT_OVERFLOW("电流过大"), CURRENT_OVERFLOW("电流过大") {
VOLTAGE_ABNORMAL("电压异常"); @Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "电流正常";
case 1: return "电流超过需求值";
case 2: return "不可信状态";
default: return "未知状态";
}
}
},
VOLTAGE_ABNORMAL("电压异常") {
@Override
public String getStateDescription(int state) {
switch (state) {
case 0: return "电压正常";
case 1: return "电压异常";
case 2: return "不可信状态";
default: return "未知状态";
}
}
};
private final String description; private final String description;
@@ -193,6 +332,8 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
this.description = description; this.description = description;
} }
public abstract String getStateDescription(int state);
} }
/** /**
@@ -208,11 +349,9 @@ public class YunKuaiChongV150BmsAbortULCmd extends YunKuaiChongUplinkCmdExe {
int bitPosition = error.ordinal() * 2; int bitPosition = error.ordinal() * 2;
int mask = 0b11 << bitPosition; int mask = 0b11 << bitPosition;
int groupValue = (value & mask) >>> bitPosition; int groupValue = (value & mask) >>> bitPosition;
errors.add(error.getStateDescription(groupValue));
if (groupValue != 0) {
errors.add(error.getDescription());
}
} }
return Joiner.on(",").join(errors); return Joiner.on(", ").join(errors);
} }
} }

View File

@@ -0,0 +1,33 @@
package sanbing.jcpp.protocol.yunkuaichong.v150;
import org.junit.Test;
import org.springframework.boot.test.context.SpringBootTest;
import sanbing.jcpp.protocol.yunkuaichong.v150.cmd.YunKuaiChongV150BmsAbortULCmd;
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.NONE)
public class BmsAbortULCmdTest {
@Test
public void test() {
YunKuaiChongV150BmsAbortULCmd bmsAbortULCmd = new YunKuaiChongV150BmsAbortULCmd();
/*
解析中止原因
0x05 -> 00000101
*/
System.out.println("BMS中止充电原因: " + bmsAbortULCmd.parseAbortReasons((byte) 0x05));
/*
解析故障原因
0x0005 -> 00000000 00000101
*/
System.out.println("BMS中止充电故障原因: " + bmsAbortULCmd.parseFaultReasons(new byte[]{(byte)0x00, (byte)0x05}));
/*
解析错误原因
0x01 -> 00000001
*/
System.out.println("BMS中止充电错误原因: " + bmsAbortULCmd.parseErrorReasons((byte) 0x01));
}
}