420B污染度等级查询代码

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
相关推荐
Jack206 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树7 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
唐青枫11 小时前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马12 小时前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户37215742613512 小时前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户37215742613512 小时前
Java 打印 Word 文档:从基础打印到高级设置
java
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
用户3521802454751 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程