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
相关推荐
计算机安禾6 小时前
【算法分析与设计】第19篇:二分图匹配与指派问题
大数据·人工智能·算法
学习中.........6 小时前
从傅里叶级数到傅里叶变换:详细的数学推导
算法
小白学大数据6 小时前
Playwright 爬虫:Python 爬取 JS 渲染的 JSP 网站
开发语言·javascript·爬虫·python·数据分析
折哥的程序人生 · 物流技术专研6 小时前
《Java 100 天进阶之路》第35篇:Java异常处理最佳实践
java·开发语言·后端·面试·求职招聘
Dfreedom.6 小时前
深度学习量化技术全景解析:从校准算法到量化算子的完整指南
人工智能·深度学习·算法·量化·模型加速
AI玫瑰助手6 小时前
Python函数:位置参数与关键字参数的使用
开发语言·python·信息可视化
如竟没有火炬6 小时前
乘法表中第K小的数——二分
开发语言·数据结构·python·算法·leetcode·职场和发展·动态规划
凯瑟琳.奥古斯特6 小时前
选择题专练数据库原理精选30题
开发语言·数据库·职场和发展·数据库开发
2401_876964137 小时前
27考研李艳芳网课|王谱2027数学讲义
人工智能·经验分享·深度学习·考研·算法·计算机视觉·概率论