合金氢化物动力学与瞬时流量计算

news2025/2/9 2:12:02

        在经典的合金氢化物动力学描述中,有一种是用JMAK方程来描述和拟合合金的吸放氢过程,方程很简洁:\xi =1-e^{-kt},其中\xi是反应程度或者百分比,表示合金氢化物吸氢或者放氢的程度,k是该合金吸氢或放氢的一种特征常数,经常是通过实验测得动力学曲线后进行拟合得到,t是时间。该方程的曲线形状如下图所示。

 

        由于 \xi是反应程度,因此假设合金最终能放出m千克的氢气,则方程可变为M =m(1-e^{-kt}),该方程对时间t进行求导,可得q_{m}=\frac{dM}{dt}=mke^{-kt},该曲线即为瞬时质量流量曲线,其曲线形状如下图,k越大,初始瞬时流量越大,放氢时间越短。k实测可取值0.00005~0.05之间。

        合金放氢后,使得容器内压力P上升,根据q_{m}=\frac{dM}{dt}=mke^{-kt}m是放氢总质量,在这里,我假设m=200g, k=0.02,利用\Delta P=\frac{\Delta m}{V}R_{g}TV=10^{-3}m^{3}T=323KR_{g}=4157J/(kg\cdot K),设时间小量\Delta t=10^{-5}s,可知\Delta M=\Delta m\approx 4\times 10 ^{-8}kg,由此得\Delta P\approx 53.71Pa

        参照之前《恒容容器放气的瞬时流量的计算》文章,链接如下。恒容容器放气的瞬时流量的计算https://blog.csdn.net/qq_24800941/article/details/130911222?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22130911222%22%2C%22source%22%3A%22qq_24800941%22%7D

        根据第三种方法的数值计算结果,可以知道在非壅塞流状态下,大概0.063s时,容器内流失的质量或者压降才跟上述计算的结果\Delta P\approx 53.71Pa在数量级上接近。        很多时候,我们在测量合金放氢量的时候,不是在平衡压力下放氢,而是使盛装合金的容器在一定的温度下,使其腔内压力人为控制在大于该温度平衡氢压之上一定的数值,如1MPa等。然后放气过程阀门全开,测量瞬时流量随时间的变化,此时不可避免就会遇到壅塞流和亚声速流的情况。根据上一篇文章中小孔放气模型的分析,排气到大气压的整个排气过程时间在0.1s左右,又根据\Delta m=\int_{0}^{0.1}mke^{-kt}=0.4g\xi =1-e^{-0.1k}\approx 0.002,得到放出的氢气质量占总质量储氢量200g的0.2%,可见占比是非常小的。同时,根据上一篇文章数值计算结果,不计合金放氢过程,放出的氢有0.669g。也就是说,这样在容器较小、合金储氢量比较大时的放氢的过程中,对合金整体的脱氢瞬时流量随时间变化的曲线影响不是很大。很多时候,流量计的记录数据的间隔为1s,因此,记录的曲线也近似认为就是合金的瞬时流量随时间变化的曲线。

        当然,笔者也很好奇,将合金释放的氢气代入到瞬时流量计算的公式里面,到底会发生什么?算出来的跟JMAK方程求导后得到瞬时流量随时间关系的曲线是否有很大出入?既然产生了问题,那就试试把数据代入方程中,算一算。

        首先回顾一下,算的方程组有哪些,这里用的是《恒容容器放气的瞬时流量的计算》中第二种方法,原因在于,笔者认为温度到最后会上升,不是单纯的绝热过程计算。

流量公式组:\left\{\begin{matrix} u=Ma\cdot \sqrt{kR_gT_b} \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \\ \frac{T_{0}}{T_{b}}=1+\frac{k-1}{2}Ma^{2},T_0=323K \\\frac{P}{P_b}=(1+\frac{k-1}{2}Ma^{2})^{\frac{k}{k-1}}\; \; \; \; \; \; \; \; \; \\ P=\rho R_gT_b\; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \\ \frac{dm}{dt}=\rho \cdot u\cdot A\, \, \, \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \; \end{matrix}\right.,合金公式组:\left\{\begin{matrix} \xi =1-e^{-kt}\; \; \; \; \; \; \; \; \; \; \\ q_{m}=\frac{dM}{dt}=mke^{-kt}\end{matrix}\right.

        由于要用数值求解法,因此在这里我先假设一个时间小量\Delta t=10^{-4}s,并给出以下边界条件:初始压力P_{0}=10^{6}Pa,初始温度T_{0}=323K,初始Ma=1,这是因为临界压力比为P_{2}/P_{1}=\frac{101325}{10^{6}}=0.10325<0.5283,比热比取k=1.4R_g=4157J/(kg\cdot K)P_{b}=P_{atm}=101325Pa,截面A=\frac{\pi d^{2}}{4}=\frac{3.14*(6.35\times 10^{-3})^{2}}{4}=3.165\times 10^{-5}m^{2},合金方面,动力学中的k=0.02s^{-1},储氢总量m=1.4g

         另外,合金一开始就放氢,使容器内压力P上升,因此我每一步都让合金产生的压升直接加在当前压力那一列,即P^{t=t+\Delta t}=P_{next}^{t=t}+\Delta P(metal)^{t=t},P^{t=0s}=10^{6}Pa,首先计算当前时间的瞬时流量q_{m},利用\Delta m=q_{m}\cdot \Delta t,得到\Delta m,利用\Delta P=\frac{R_{g}T_{b}}{V}\Delta m得到\Delta P,所以有P_{next}=P_{now}-\Delta P+\Delta P(metal)\Delta P(metal)=\frac{R_{g}T_{b}}{V}mke^{-kt}\Delta t。数值计算结果如下图,仅列出部分值。注意,q_{v}(JMAK)=mk\cdot e^{-kt}\cdot1000\cdot60/\rho\rho是“rho”那一列数据。

        从结果来看,数值计算的q_{v}(simulation)在基本快要降至P_{atm}=101325Pa时,瞬时流量值才与q_{v}(JMAK)基本一致,笔者觉得挺神奇的,从P^{t=t+\Delta t}=P_{next}^{t=t}+\Delta P(metal)^{t=t}的式子,可以看出压力当P_{next}^{t=t}接近101325Pa时,压力贡献项就基本只有合金的放氢过程了,相当于似乎在说,前面放气阶段,合金放氢过程可以忽略不计,完全是容器内非合金部分气体的快速放气过程,而且经过壅塞流和亚声速流状态。然后,接下来的阶段就是合金放氢过程为主导,瞬时流量基本就是JMAK方程解出的数值解

        另外,很多时候,燃料电池不同功率下都会有一个氢气流速要求(如:1L/min等),合金储氢怎么去匹配这个氢气流速,这完全取决于合金的动力学性能。不过,对于不同的场景,不同的需求,合金会存储在不同的尺寸的罐子里面,加上材料本身的性质、热管理手段的不同、结构的不同,导致合金动力学性能曲线也会有所不一样。这时候,就要适当利用仿真软件进行模拟现实情况了,而且实测试验也会少不了,对数据进行合理的修正。当然,动力学方程不仅仅只有JMAK方程,还有很多数学模型来拟合,当中的学问深之又深,有种物理模型的尽头就是搞数学一样,跨学科的感觉就此而来。

结束语:感谢阅读至此,希望这篇文章对你有所启发和帮助,欢迎大佬私信交流。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

57、基于51单片机智能硬币分拣分类机电子存钱罐报警系统设计(程序+原理图+PCB源文件+Proteus仿真+参考论文+参考PPT+元器件清单等)

摘 要 近年来&#xff0c;随着我国经济的发展和社会的进步&#xff0c;邮政事业得到了空前发展。邮政通信网的技术含量不断增加&#xff0c;技术装备水平也在不断的提高&#xff0c;邮件处理已基本实现机械化&#xff0c;并且朝着自动化的方向迈进。本文着眼于我国当前邮政事…

Unity编辑器扩展-第一集-在菜单栏加入自己的按钮

一、概述 unity自己本身就是一个大的程序&#xff0c;我们看见的所有功能&#xff0c;都是用程序写出来的&#xff0c;但是根据各行各业不同的需求&#xff0c;有些时候我们制作时&#xff0c;想要自己编辑一些原有的功能。 二、本节目标效果展示 1.在菜单栏加入属于自己的一…

【前端基础篇】CSS选择器 和 CSS属性

前言&#xff1a;CSS 简介 CSS 概述 CSS ( Cascading Style Sheet ) 层叠样式表&#xff0c;用来修饰 HTML&#xff0c;使得效果更加多样化CSS 在 HTML4.0 中引入&#xff0c;一般在开发过程中&#xff0c;会使用单独的 CSS 文件进行开发&#xff0c;然后将这个独立 CSS 文件引…

Unity编辑器扩展-第二集-按钮排序/分组/放入右键菜单

第一集链接&#xff1a;Unity编辑器扩展-第一集-在菜单栏加入自己的按钮_菌菌巧乐兹的博客-CSDN博客 一、本节目标效果展示 1.按钮排序 变成 2.按钮分组 仔细看&#xff0c;有个灰色的杠杠 3.放入右键菜单 4.皮一下 二、按钮排序具体流程 第一集讲&#xff0c;如果想放入…

Java自定义泛型类、泛型接口、泛型方法以及 泛型擦除的细节

体会&#xff1a;使用泛型的主要优点是能够在编译时而不是在运行时检测错误。 /*** 自定义泛型类*/ public class Order<T> {String orderName;int orderId;//类的内部结构就可以使用类的泛型T orderT;public Order(){//编译不通过 // T[] arr new T[10];//编译…

Unity基础3——Resources资源动态加载

一、特殊文件夹 &#xff08;一&#xff09;工程路径获取 // 注意 该方式 获取到的路径 一般情况下 只在 编辑模式下使用 // 我们不会在实际发布游戏后 还使用该路径 // 游戏发布过后 该路径就不存在了 print(Application.dataPath);&#xff08;二&#xff09;Resources 资…

如何自动生成正交法测试用例?

目录 引言 正交法实验 自动生成正交用例 引言 正交法测试用例是一种高效且可靠的方法&#xff0c;能够最大限度地减少测试工作量&#xff0c;同时保证覆盖所有可能的组合情况。通过了解如何优化这些测试用例的生成过程&#xff0c;可以提高产品的质量&#xff0c;降低故障率…

机器人视觉梳理(上)

原创 | 文BFT机器人 01 机器人视觉的概念 在智能制造过程中&#xff0c;通过传统的编程来执行某一特定动作的机器人&#xff08;机械手、机械手臂、机械臂等&#xff0c;未作特殊说明时&#xff0c;不作严格区分&#xff0c;统一称为机器人&#xff09;&#xff0c;将难以满足制…

【CV大模型SAM(Segment-Anything)】如何保存分割后的对象mask?并提取mask对应的图片区域?

上一篇文章【CV大模型SAM&#xff08;Segment-Anything&#xff09;】真是太强大了&#xff0c;分割一切的SAM大模型使用方法:可通过不同的提示得到想要的分割目标中详细介绍了大模型SAM&#xff08;Segment-Anything&#xff09;的不同使用方法&#xff0c;后面有很多小伙伴给…

【JVM 监控工具】使用JConsole监控进程、线程、内存、cpu、类情况

文章目录 前言一、如何启动JConsole二、如何设置JAVA程序运行时可以被JConsolse连接分析三、JConsole如何连接远程机器的JAVA程序&#xff08;举例说明&#xff09;四、性能分析概述内存线程类VM摘要MBean 五、使用Jconsole监控某方法的性能总结 前言 Jconsole是JDK自带的监控…

网络工程师必备,华为/思科/华三交换机命令对比

本期对华为/思科/华三交换机配置命令对比,来看下他们的区别在哪里&#xff0c;这里对命令做了个汇总&#xff0c;平时对命令不熟的朋友这次可以看下。 另外我们来看下华为与H3C的命令情况&#xff0c;方便大家进行对比。 一、华为交换机基础配置命令 1、创建vlan&#xff1a; …

Unity基础1——3D数学

一、Mathf &#xff08;一&#xff09;Mathf 和 Math ​ Math 是 C# 中封装好的用于数学计算的工具类 —— 位于 System 命名空间中 ​ Mathf 是 Unity 中封装好的用于数学计算的工具结构体 —— 位于 UnityEngine 命名空间中 ​ 他们都是提供来用于进行数学相关计算的 ​…

机器学习 day18(用Tensorflow搭建一个神经网络)

之前搭建神经网络的方法 先初始化输入数据X&#xff0c;创建layer 1并计算激活值a1&#xff0c;创建layer 2并计算激活值a2&#xff0c;这是前向传播代码的显式形式。 另一种简单些的创建神经网络的方法 创建layer 1和layer 2与前一种方法相同&#xff0c;但我们不需要手动…

JUC并发编程学习笔记

1&#xff1a;回顾多线程 进程和线程是什么 进程是操作系统分配资源的最小单元&#xff0c;而线程是cpu调度的最小单元。 java默认有几个线程 2个,main线程和GC线程&#xff08;GC垃圾回收机制&#xff09; java可以开启线程么 不能 并发和并行 并发,多线程操作同一个资源,cp…

纯电驱动车辆动力总成的优化与比较研究

摘要&#xff1a; 不同动力总成拓扑结构的对比分析 前言 纯电驱动的电动汽车因为集成有大容量电池组&#xff0c;可以存储取自公共电网的电能&#xff0c;用来驱动车辆的行驶。相比于传统的混合动力汽车&#xff0c;具有更加优越的节能减排效果和潜力。因此&#xff0c;近年来…

cpp文件编译过程 makefile cmake

这里写目录标题 argc argv参数头文件编译过程静态链接&#xff0c;动态链接&#xff0c;静态库&#xff0c;动态库 -shared制作使用动态库libxxx。so冲突 静态库预处理编译汇编链接目录选项-Idir 大写Iinclude<> 与 " "-I -I- 与 -I- -I ld/objdump/objcopy 选…

内网渗透—隧道搭建Ngrok与Frp内网穿透

这里写目录标题 1. 前言1.1. 隧道技术介绍1.2. 代理技术介绍1.2.1. 正向代理1.2.2. 反向代理1.2.3. 透明代理1.2.4. 正向代理与透明代理区别 2. 内网穿透2.1. Ngrok2.1.1. 访问Ngrok2.1.2. 代理设置2.1.2.1. 开通代理2.1.2.2. 配置隧道2.1.2.3. 下载客户端 2.1.3. 配置客户端2.…

P20[6-8]编码器接口测速(软)

与外部中断编码器逻辑不同,此处编码器使用的是定时器方法 1.Encoder编码器部分: #include "stm32f10x.h" // Device header void Encoder_Init(void) { RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE); RCC_APB2PeriphClockCm…

吐血整理,自动化测试场景处理(多场景覆盖)+解决方案

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、添加时间等待 …

53.最大子数组和

贪心算法 时间复杂度&#xff1a;代码中只有一个循环&#xff0c;循环次数为数组的长度&#xff0c;因此时间复杂度为 O(n)&#xff0c;其中 n 是数组的长度。空间复杂度&#xff1a;代码中只使用了常数级别的额外空间&#xff0c;因此空间复杂度为 O(1)。 这段代码使用贪心算…