c++
cpp
// 420b等级-浓度表(粒径→各等级最大浓度值,个/100mL)
const QMap<int, QList<double>> MainWindow::size_rank_data = {
{4, {195, 390, 780, 1560, 3120, 6250, 12500, 25000, 50000, 100000, 200000, 400000, 800000, 1600000, 3200000}},
{6, {76, 152, 304, 609, 1220, 2430, 4860, 9730, 19500, 38900, 77900, 156000, 311000, 623000, 1250000}},
{14, {14, 27, 54, 109, 217, 432, 864, 1730, 3460, 6920, 13900, 27700, 55400, 111000, 222000}},
{21, {3, 5, 10, 20, 39, 76, 152, 306, 612, 1220, 2450, 4900, 9800, 19600, 39200}}
};// 等级查表函数
int MainWindow::get_rank_420b(double conc, int size)
{
// 1. 校验粒径是否有效
if (!size_rank_data.contains(size)) {
return -1;
}
// 2. 获取该粒径的等级阈值(个/100mL),转换为个/mL(除以100)
QList<double> rank_thresholds = size_rank_data[size];
for (int i = 0; i < rank_thresholds.size(); ++i) {
rank_thresholds[i] /= 100.0;
}
// 3. 找到第一个大于等于当前浓度的阈值索引(原等级索引:0=等级1,1=等级2...14=等级15)
int original_idx = -1;
for (int i = 0; i < rank_thresholds.size(); ++i) {
if (rank_thresholds[i] >= conc) {
original_idx = i;
break;
}
}
// 4. 处理边界情况:浓度大于所有阈值(原等级15)
if (original_idx == -1) {
original_idx = 14; // 原等级15对应索引14
}
// 5. 等级映射:前3级(原1/2/3级 → 索引0/1/2)返回0;原4-15级 → 1-12级
int new_rank_value = 0;
QString new_rank_label = "等级0";
// 前3级(原1/2/3级)
if (original_idx <= 2) {
new_rank_value = 0;
new_rank_label = "等级0";
}
// 原4-15级 → 转换为1-12级
else if (original_idx >= 3 && original_idx <= 14) {
new_rank_value = original_idx - 2; // 原4级(索引3)→1,原5级(索引4)→2...原15级(索引14)→12
new_rank_label = QString("等级%1").arg(new_rank_value);
}
// 6. 返回最终结果(标签+数值)
return new_rank_value;
}
py:
python
# 420b等级-浓度表(粒径→各等级最大浓度值,个/100mL)
size_rank_data = {
4: [195, 390, 780, 1560, 3120, 6250, 12500, 25000, 50000, 100000, 200000, 400000, 800000, 1600000, 3200000],
6: [76, 152, 304, 609, 1220, 2430, 4860, 9730, 19500, 38900, 77900, 156000, 311000, 623000, 1250000],
14: [14, 27, 54, 109, 217, 432, 864, 1730, 3460, 6920, 13900, 27700, 55400, 111000, 222000],
21: [3, 5, 10, 20, 39, 76, 152, 306, 612, 1220, 2450, 4900, 9800, 19600, 39200]
}
def get_rank_420b(conc: float, size: int) -> int:
"""
等级查表函数
:param conc: 浓度(个/mL)
:param size: 粒径(4/6/14/21)
:return: 转换后的等级值(0~12),无效粒径返回 -1
"""
# 1. 校验粒径是否有效
if size not in size_rank_data:
return -1
# 2. 获取该粒径的等级阈值(个/100mL),转换为个/mL(除以100)
rank_thresholds = [x / 100.0 for x in size_rank_data[size]]
# 3. 找到第一个大于等于当前浓度的阈值索引
original_idx = -1
for i in range(len(rank_thresholds)):
if rank_thresholds[i] >= conc:
original_idx = i
break
# 4. 处理边界:浓度大于所有阈值 → 等级15(索引14)
if original_idx == -1:
original_idx = 14
# 5. 等级映射规则
new_rank_value = 0
# 前3级(原1/2/3级 → 0)
if original_idx <= 2:
new_rank_value = 0
# 原4~15级 → 1~12级
elif 3 <= original_idx <= 14:
new_rank_value = original_idx - 2
return new_rank_value