2021年第十届数学建模国际赛小美赛A题气道阻力的评估解题全过程文档及程序

2021年第十届数学建模国际赛小美赛

A题 气道阻力的评估

原题再现:

  气道阻力的定义是通过肺气道产生单位气流所需的经肺压力的变化。更简单地说,它是嘴和肺泡之间的压力差,除以气流。影响气道阻力的因素是多方面的,我们需要探讨这些因素是如何影响气道总阻力的。
  许多研究假设肺气道是一个光滑的相邻圆柱体系统,空气以层流方式流经该系统,其结果基于稳定流动的假设。这种假设与实际情况有许多不一致之处。例如,鼻气道阻力占总气道阻力的50%以上,但鼻腔不是圆柱形的。这种假设完全忽略了上气道的紊流。因此,预测气道的总通气量是不够的。
  我们需要建立一个模型来估计总气道阻力至少由这些因素:气流速度,肺容量,以及气道各部分的横截面积。这些是一些最重要的促成因素。对于某些患者,由于手术等原因,气道的某些部分会暂时/永久改变,包括某些部分的形状或横截面积。我们的模型将用于评估患者气道的通气性能,并帮助医生设计对气道总通气性能影响最小的治疗方案。

整体求解过程概述(摘要)

  气道阻力定义为产生单位气流通过肺气道所需的跨肺压力变化。气道阻力的大小间接反映了患者的气道通气性能。因此,有必要找出影响气道总阻力的因素。
  在问题的第一部分,根据流体力学方程,得到了口与肺泡压差、气道长度、气道各截面截面积等因素之间的关系,进而得到气道总阻力的表达式。由于气体可能具有一定的粘度,通过计算不考虑气体粘度的伯努利方程和分别考虑气体粘度的伯努利方程,可以得到压差与其它因素的关系。计算气道各节段的气流速度和口肺泡与肺的压差。在具体的计算中,采用蒙特卡罗模拟的方法,计算出气道各截面的一些物理量。最后根据气道阻力的定义计算气道阻力。在不考虑气体粘度和考虑气体粘度的情况下,利用MATLAB绘制了两种情况的比较图。通过比较,最终得到考虑气体粘度条件下的气道阻力。
  在问题的第二部分,根据呼吸系统的压力-容积曲线(拟合结果为s型曲线),压差与肺容积之间的关系可用指数函数来描述。然后,利用上一问题中的方法和MATLAB计算了气道内的平均气体流量。通过定义气道阻力,得到气道阻力与肺容量的关系曲线(其他变量在此控制不变)。
  并利用MATLAB控制其他变量,绘制气道阻力与气道各截面面积的关系曲线。通过观察关系曲线,可以得出对全气道通气性能影响不大的治疗方案。
  在此基础上,总结了气道阻力的影响因素和物理表现,并得到了相应的微分方程。

模型假设:

  (1) 由于气体的粘度非常小,因此未考虑气体粘度对气道阻力估计值的影响。
  (2) 当倾斜时,气体重力引起的倾斜角对压力的影响被忽略。
  (3) 由于人气道的每一段的横截面积可以变化,因此假设人气道的表面是平滑的曲面(不一定是圆柱形的),并且气道的每一段的横截面积满足正态分布。
  (4) 当气道的段数足够大时,假设每个段中的压差与每个段的长度成线性关系,即从气道的一个段到嘴的压差与它们之间的距离(深度)成线性关系。
  (5) 其他阻力对气道阻力估计的影响被忽略。
  (6) 假设气体密度不随气道深度变化,且气体密度p=1.293kg/m3为常数。

问题重述:

  气道阻力可能受到许多不确定因素的影响,如气流速度、肺容量和每个气道段的横截面积。所以我们需要讨论这些因素是如何影响总气道阻力的。许多研究假设肺气道是一个光滑的连接柱体系统,空气以层流方式流过该系统,其结果基于稳定流动的假设。这种假设与实际情况有许多不一致之处。例如,鼻气道阻力占总气道阻力的50%以上,但鼻腔不是圆柱形的。这种假设完全忽略了上气道的紊流。因此,我们需要建立一个模型来描述影响气道阻力的因素。

  1气流速度与气道阻力的关系

  气道速度和气道阻力之间的关系是什么?如何利用曲线分析这些因素对气道阻力的影响?
  为了解决这类问题,我们需要找到一个合适的物理模型来描述这些物理量之间的关系。由于该问题是以气体(属于流体)为基础的,因此需要用流体力学方程来描述这些物理量之间的关系·首先,通过对伯努利方程进行变形,得到了相应的微分方程形式和气道各段气速、压差的递推公式。当然,也可以得到肺泡附近的气流速度与肺泡与口部的压差和初始气流速度之间的关系。然后,利用递推公式在MATLAB中进行蒙特卡罗仿真,并进行一定次数的迭代,使气道的每个截面都能近似光滑圆柱体,从而使数值接近真实值。最后,通过MATLAB绘图分析气道阻力与其他因素的关系。
  ·由于以前没有考虑空气粘度对气道内其他物理量的影响,本文对伯努利方程进行了修正,采用粘性流体伯努利方程求解。重复刚才的操作,在MATLAB上绘制图形,比较考虑粘性和不考虑粘性两种情况,最后选择考虑粘性的Bernoulli方程方案求解。

  2肺容量与气道阻力的关系
  肺容量和气道阻力之间的关系是什么?
  由于气道阻力是嘴和肺泡之间的压差与气道中气流的比率,因此问题可分为两部分:
  1) 探讨肺动脉压差与肺容量的关系。
  2) 通过以上两种关系间接探讨气道阻力与肺容量的关系。因此,通过寻找信息,我们找到了适合描述肺容积与压差关系的曲线:呼吸系统压力容积曲线。

  3横截面积与气道阻力的关系
  气道各部分的横截面积与气道阻力之间的关系是什么?
  根据第一个主题的方法,通过控制其他变量不变,探索气道阻力与气道各部分横截面积之间的关系。利用MATLAB软件分析了两者之间的关系。

  4如何评估患者的气道性能
  通气性能通常与气道阻力有关。因此,有必要探讨通气性能与气道阻力的相关性,并通过得出的结论对通气性能进行评价。

  5对全气道通气性能影响最小的方案
  对于某些患者,由于手术或其他原因,气道的某些部分可能会暂时/永久改变,包括某些部分的形状或横截面积。因此,可将该问题转化为以下问题:选择与术前横截面积差值最小的合适横截面积,使该面积下的气道阻力差值小于术前。
  通过分析第三个问题中气道阻力与横截面积的关系曲线,可以确定引起气道阻力微小变化的横截面积(横截面积应尽可能接近原始横截面积)。

模型的建立与求解整体论文缩略图

在这里插入图片描述
在这里插入图片描述

全部论文请见下方“ 只会建模 QQ名片” 点击QQ名片即可

部分程序代码:(代码和文档not free)

function mean_p_airway=non_viscosity(dp,H,N)
v0=14.8e-6;
g=9.8;
ru=1.293;
p_airway=zeros(1,length(N));
for i=1:length(N)
v2=[v0^2,zeros(1,N(i))];
S=zeros(1,N(i));
for j=1:N(i)
S(j)=(0.0125^2*normrnd(1,rand(1)))*1e-2;
v2(j+1)=2/ru*(dp/N(i)-ru*g*H/N(i))+v2(j);
end
p_airway(i)=dp/mean(abs(sqrt(v2(2:end))).*S);
end
mean_p_airway=mean(p_airway);
end
function mean_p_airway=airway_resistance(dp,H,N0)
v0=14.8e-6;
g=9.8;
ru=1.293;
mu=0.01894;
p_airway=zeros(1,length(N0));
for N=N0
v2=[v0^2,zeros(1,N)];
S=zeros(1,N);
for i=1:N
S(i)=(0.0125^2*normrnd(1,rand(1)))*1e-2;
v2(i+1)=2/ru*(dp/N-ru*g*H/N-8*pi*mu*sqrt(v2(i))*H/(N*g*S(i)));
end
p_airway((N-N0(1))/(N0(2)-N0(1))+1)=dp/mean(abs(sqrt(v2(2:end))).*S);
end
mean_p_airway=mean(p_airway);
end
clear;clc;close all
p0=1.013e5;
v0=14.8e-6;
g=9.8;
ru=1.293;
mu=0.01894;
lN=input('Please enter the lower limit of monte Carlo simulation:');
uN=input('Please enter the maximum number of Monte Carlo simulations:');
N=lN:uN;
dp=100:300;
airway=zeros(1,length(dp));
mean_p_airway=zeros(1,length(dp));
for i=1:length(dp)
airway(i)=non_viscosity(dp(i),0.12,N);
mean_p_airway(i)=airway_resistance(dp(i),0.12,N);
end
figure(1)
plot(dp,airway,'r-p',dp,mean_p_airway,'b-*')
xlabel('differential pressure/Pa')
ylabel('airway resistance/Pa*m^{-3}*s')
legend('without the viscosity of the air','with the viscosity of the air')
figure(2)
plot(dp,airway,'r-p')
xlabel('differential pressure/Pa')
ylabel('airway resistance/Pa*m^{-3}*s')
figure(3)
plot(dp,mean_p_airway,'b-*')
xlabel('differential pressure/Pa')
ylabel('airway resistance/Pa*m^{-3}*s')
H=0.11:0.001:0.13;
airway=zeros(1,length(H));
mean_p_airway=zeros(1,length(H));
for i=1:length(H)
airway(i)=non_viscosity(200,H(i),N);
mean_p_airway(i)=airway_resistance(200,H(i),N);
end
figure(4)
plot(H,airway,'r-x',H,mean_p_airway,'-*')
xlabel('The length  of the airway/m')
ylabel('airway resistance/Pa*m^{-3}*s')
legend('without the viscosity of the air','with the viscosity of the air')
figure(5)
plot(H,airway,'r-x')
xlabel('The length of the airway/m')
ylabel('airway resistance/Pa*m^{-3}*s')
figure(6)
plot(H,mean_p_airway,'-*')
xlabel('The length of the airway/m')
ylabel('airway resistance/Pa*m^{-3}*s')
全部论文请见下方“ 只会建模 QQ名片” 点击QQ名片即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/227031.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python 数据分析

数据分析 数据分析是指用适当的方法对收集的数据进行分析,提取有用信息并且形成结论. 广义的数据分析包括狭义的数据分析和数据挖掘.狭义的数据分析是指根据目的,采用对比分析,分组分析,交叉分析,回归分析等分析方法,对数据进行分析和处理,得到特征统计量的过程.数据挖掘是指…

20231207给NanoPC-T4(RK3399)开发板刷Android12的挖掘机方案的LOG

20231207给NanoPC-T4(RK3399)开发板刷Android12的挖掘机方案的LOG 2023/12/7 23:50 SDK:rk356x_android12_220722.tgz 只修改DTS的DTC部分就【直接】可以跑NanoPC-T4 参考资料: http://www.friendlyelec.com.cn/agent.asp http://www.friendlyelec.com.c…

[FPGA 学习记录] 快速开发的法宝——IP核

快速开发的法宝——IP核 文章目录 1 IP 核是什么2 为什么要使用 IP 核3 IP 核的存在形式4 IP 核的缺点5 Quartus II 软件下 IP 核的调用6 Altera IP 核的分类 在本小节当中,我们来学习一下 IP 核的相关知识。 IP 核在 FPGA 开发当中应用十分广泛,它被称为…

Spark RDD惰性计算的自主优化

原创/朱季谦 RDD(弹性分布式数据集)中的数据就如final定义一般,只可读而无法修改,若要对RDD进行转换或操作,那就需要创建一个新的RDD来保存结果。故而就需要用到转换和行动的算子。 Spark运行是惰性的,在…

UE Http笔记

c参考链接 UE4 开发如何使用 Http 请求_wx61ae2f5191643的技术博客_51CTO博客 虚幻引擎:UEC如何对JSON文件进行读写?-CSDN博客 UE4 HTTP使用 官方免费插件 VaRest 在代码插件创建的VaRest - 虚幻引擎商城 UE5在蓝图中使用Varest插件Get,Post两种常见请求方式…

C# Solidworks二次开发:三种获取SW设计结构树的方法-第二讲

今天这篇文章是接上一篇文章的,主要讲述的是获取SW设计结构树节点的第二种方法。 这个方法获取节点的逻辑是先获取最顶层节点,然后再通过获取顶层节点的子节点一层一层的把所有节点都找出来,也就是需要递归。想要用这个方法就要了解下面几个…

常见的校验码

在计算机领域中,校验码是一种用于检测或纠正数据传输或存储中错误的技术。校验码通常通过在数据中添加一些冗余信息来实现。其主要目的是确保数据的完整性和准确性。 奇偶校验码(Parity Check) 奇校验: 确保数据中二进制位中的1的…

JWT安全及WebGoat靶场

JWT 安全 cookie(放在浏览器) cookie 是一个非常具体的东西,指的就是浏览器里面能永久存储的一种数据,仅仅是浏览器实现的一种数据存储功能。 cookie 由服务器生成,发送给浏览器,浏览器把 cookie 以 kv 形式保存到某个目录下的…

文件同步及实现简单监控

1. 软件简介 rsync rsync 是一款开源的、快速的、多功能的、可实现全量及增量的本地或远程 数据同步备份的优秀工具。在同步备份数据时,默认情况下,Rsync 通过其 独特的“quick check”算法,它仅同步大小或者最后修改时间发生变化的文 件或…

CentOS上配置和管理HTTP服务器的工具和实用程序

在CentOS系统上,有多个工具和实用程序可以帮助你配置和管理HTTP服务器。以下是一些常用的工具和实用程序: Apache HTTP服务器: Apache是CentOS上最常用的HTTP服务器之一。它是一个开源的Web服务器软件,具有高度的可配置性和可扩…

在jupyter notebook中修改其他文件的解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

dell服务器安装PERCCLI

因在linux 系统中无法查看系统磁盘的raid级别,也无法得知raid状态,需要安装额外的包来监控,因是dell服务器,就在dell网站中下载并安装 1、下载链接:驱动程序和下载 | Dell 中国https://www.dell.com/support/home/zh-…

ELK(四)—els基本操作

目录 elasticsearch基本概念RESTful API创建非结构化索引(增)创建空索引(删)删除索引(改)插入数据(改)数据更新(查)搜索数据(id)&…

查看端口号是否被占用

windows10查看端口号是否被占用及解除占用的常用命令 netstat -ano:查看所有端口号占用情况 netstat -ano |findstr “XXX”:查看端口号为XXX的占用情况,如下: 得到进程号为12160的进程正在占用本地的9090端口号(如果只…

Python+requests+unittest+excel实现接口自动化测试框架

在刚刚进入测试行业的时候,最开始也是做功能测试,我想很多伙伴和我一样,觉得自动化测试都很高端,很神秘。迫不及待的想去学习作自动化测试。 以前比较常用数据库python做自动化,后面发现excel个人觉得更加适合&#x…

flex布局的flex为1到底是什么

参考博客:flex:1什么意思_公孙元二的博客-CSDN博客 flex:1即为flex-grow:1,经常用作自适应布局,将父容器的display:flex,侧边栏大小固定后,将内容区flex:1,内…

算术运算(这么简单?进来坐坐?)

先热热身 算术运算,也称为四则运算,包括加法、减法、乘法和除法。此外,算术运算还包括乘方和开方。 在算术中,加减被视为一级运算,乘除被视为二级运算,乘方和开方被视为三级运算。在一道算式中,…

GDPU 数据结构 天码行空13

文章目录 一、【实验目的】二、【实验内容】三、实验源代码四、实验结果五、实验总结 一、【实验目的】 (1) 理解插入排序算法的实现过程; (2)理解不同排序算法的时间复杂度及适用环境; (3)了解算法性能…

华为数通---配置Smart Link负载分担案例

定义 Smart Link,又叫做备份链路。一个Smart Link由两个接口组成,其中一个接口作为另一个的备份。Smart Link常用于双上行组网,提供可靠高效的备份和快速的切换机制。 目的 下游设备连接到上游设备,当使用单上行方式时&#x…

算能 MilkV Duo开发板实战——opencv-mobile (迷你版opencv库)的移植和应用

前言 OpenCV是一种开源的计算机视觉和机器学习软件库,旨在提供一组通用的计算机视觉工具。它用于图像处理、目标识别、人脸识别、机器学习等领域,广泛应用于计算机视觉任务。 OpenCV-Mobile是OpenCV库的轻量版本,专为移动平台(A…