【2024高教社杯全国大学生数学建模竞赛】B题完整解析(含论文、代码分享)

目录

  • 1问题重述
    • 1.1问题背景
    • 1.2研究意义
    • 1.3具体问题
  • 2 总体分析
  • 3 模型假设
  • 4 符号说明
  • 5 模型的建立与求解
  • 5.1问题一模型的建立与求解
    • 5.1.1问题的具体分析
      • 5.1.2模型的准备
      • **5.1.3模型的建立与求解**
  • 代码
    • 第一问
  • 完整论文&代码

1问题重述

1.1问题背景

1.2研究意义

1.3具体问题

2 总体分析

3 模型假设

4 符号说明

5 模型的建立与求解

5.1问题一模型的建立与求解

5.1.1问题的具体分析

问题一要求制定一个抽样检测计划,以决定是否接受一批零配件,基于供应商所声称的次品率。关键在于如何确定适当的样本量和决策标准,以最小化检测成本,同时确保决策的高可靠性。

在具体分析中,企业面临的主要挑战是在95%的置信水平下拒收次品率超过标称值的零配件,在90%的置信水平下接受次品率不超过标称值的零配件。这涉及到统计假设检验,特别是需要控制第一类错误(错误地拒绝良品)和第二类错误(错误地接受次品)的概率。
次品率的抽样检测通常采用二项分布进行建模,每个零配件要么合格,要么不合格,完全符合二项分布的特性。基于供应商提供的次品率标称值,可以设定零假设(次品率小于等于标称值)和备择假设(次品率大于标称值),并采用z检验或t检验等统计方法来决定是否拒收整批零配件。

在模型构建方面,首先需要定义这些假设,然后是确定样本量,这一步骤至关重要,以确保检验的功效,即最小化第一类和第二类错误的概率。这可以通过设定错误的容忍界限(例如α=5%,β=10%)和进行功效分析来实现。接着,需要设定决策规则,即根据样本次品率与临界值的比较结果来接受或拒绝零假设。

求解模型时,会计算在给定置信水平下的临界值,如果样本次品率大于此临界值,则拒绝零假设,否则接受。可以通过模拟抽样过程,计算样本次品率,并根据这些数据与临界值比较来确定是否接受或拒绝。这种方法可以为企业提供一个科学且经济有效的抽样检测方案,帮助企业在保证产品质量的同时控制相关成本。

5.1.2模型的准备

【2024高教社杯全国大学生数学建模竞赛】B题完整解析(含论文、代码分享)_第1张图片

【2024高教社杯全国大学生数学建模竞赛】B题完整解析(含论文、代码分享)_第2张图片
【2024高教社杯全国大学生数学建模竞赛】B题完整解析(含论文、代码分享)_第3张图片

5.1.3模型的建立与求解

【2024高教社杯全国大学生数学建模竞赛】B题完整解析(含论文、代码分享)_第4张图片

代码

第一问

from scipy.stats import binom
import matplotlib.pyplot as plt
from matplotlib import rcParams

rcParams['font.sans-serif'] = ['SimHei']
rcParams['axes.unicode_minus'] = False

def calculate_sample_size_and_visualize(p0, beta_accept, beta_reject):
    # 估计样本量的合理初始范围
    n_start = 30  # 假设样本量从30开始
    n_max = 500  # 最大样本量限制为500

    sample_sizes = []
    reject_probabilities = []
    accept_probabilities = []
    sample_size_found = None

    for n in range(n_start, n_max, 10):  # 每次增加10个样本
        # 计算在p0条件下的拒收和接收概率
        p_reject = binom.cdf(int(n * p0), n, p0)
        p_accept = 1 - binom.cdf(int(n * p0), n, p0)

        # 存储每个样本量的结果,用于可视化
        sample_sizes.append(n)
        reject_probabilities.append(p_reject)
        accept_probabilities.append(p_accept)

        # 判断是否满足条件
        if p_reject <= beta_reject and p_accept >= beta_accept and sample_size_found is None:
            sample_size_found = n  # 记录找到的最小样本量

    # 如果没有找到符合条件的样本量,返回最大样本量
    if sample_size_found is None:
        sample_size_found = n_max

    # 返回结果及用于可视化的数据
    return sample_size_found, sample_sizes, reject_probabilities, accept_probabilities


# 参数设置
p0 = 0.10  # 标称次品率
beta_accept = 0.90  # 90%接收概率
beta_reject = 0.05  # 5%拒收概率

# 计算最小样本量并获取可视化数据
sample_size, sample_sizes, reject_probs, accept_probs = calculate_sample_size_and_visualize(p0, beta_accept,
                                                                                            beta_reject)



# 可视化输出
plt.figure(figsize=(10, 6))

# 拒收概率曲线
plt.plot(sample_sizes, reject_probs, label="拒收概率", color='red', marker='o')
# 接收概率曲线
plt.plot(sample_sizes, accept_probs, label="接收概率", color='blue', marker='x')

# 标注最小抽样量
plt.axvline(x=sample_size, color='green', linestyle='--', label=f"最小抽样量 = {sample_size}")

# 图表标题和标签
plt.title('样本量与拒收/接收概率的关系')
plt.xlabel('样本量')
plt.ylabel('概率')
plt.legend()

# 显示网格
plt.grid(True)

# 显示图表
plt.show()

完整论文&代码


22页,18822字,完整论文与代码请看下方!

你可能感兴趣的:(数模国赛,数学建模,数学建模国赛,B题)