建模语言CellML初步

news2024/11/25 10:11:03

文章目录

    • 简介
    • 洛伦兹吸引子
    • 仿真

简介

CellML是主打计算生理学的一个编程语言,擅长处理微分方程问题,并且内置了单位系统,是细胞层次的建模工具。openCOR为其运行环境,提供了舒适的代码编辑窗口,以及一系列IDE工具,包括查看内存,图形输出等。其官网地址为openCOR,下载相应的版本,安装之后,其界面如下

在这里插入图片描述

洛伦兹吸引子

洛伦兹吸引子即蝴蝶效应,是各种主打科学计算的编程语言都喜欢用作示例的一个模型,其数学模型是三个一阶常微分方程组(ODEs)

{ x ˙ = σ ( y − x ) y ˙ = x ( ρ − x ) − y z ˙ = x y − β z \left\{\begin{aligned} \dot x&=\sigma(y-x)\\ \dot y&=x(\rho-x)-y\\ \dot z&=xy-\beta z \end{aligned}\right. x˙y˙z˙=σ(yx)=x(ρx)y=xyβz

这也是官方教程的一个示例,其参数设为

σ = 10 , ρ = 28 , β = 8 / 3 = 2.66667 \sigma=10, \rho=28, \beta=8/3=2.66667 σ=10,ρ=28,β=8/3=2.66667

初始条件为

x ( 0 ) = y ( 0 ) = z ( 0 ) = 1 x(0)=y(0)=z(0)=1 x(0)=y(0)=z(0)=1

下面将其写为CellML代码。点击【File】->【New】->【CellML File】,即可创建一个CellML文件,内容如下。

// CellML用//进行注释
def model Lorenz as
    def comp main as
        var t: dimensionless {init: 0};
        var x: dimensionless {init: 1};
        var y: dimensionless {init: 1};
        var z: dimensionless {init: 1};
        var sigma: dimensionless {init: 10};
        var beta: dimensionless {init: 2.66667};
        var rho: dimensionless {init: 28};
        ode(x,t)=sigma*(y-x);
        ode(y,t)=x*(rho-z)-y;
        ode(z,t)=x*y-beta*z;
    enddef;
enddef;

这几行代码的可读性非常强,首先定义一个模型lorenz,模型内部定义一个组件main,可以理解为入口函数。接下来 x , y , z , σ , β , ρ x,y,z,\sigma,\beta,\rho x,y,z,σ,β,ρ均为变量,最后是三个常微分方程,表示前文建立的模型。

当光标至于某行ode时,代码上方会出现其渲染的公式,非常便捷。

在这里插入图片描述

其选项卡标签File #2后面有个星星,说明当前文件未保存,可用【File】->【Save】或Ctrl+S将文件保存为cellml格式。

仿真

将代码输入框左侧的竖排选项卡,从【Editing】切换到【Simuliation】,其模拟结果如下。

在这里插入图片描述

其中,【Simulation】下拉框中存放的是仿真参数,为了能够清晰地展示 x , y , z x,y,z x,y,z之间的变化关系,将Ending Point设为50,Point interval设为0.01,二者分别表示终止时间和时间间隔。

点击左上角三角符号,即可完成仿真。点击下方【Parameters】下拉框,可实现二维图形的绘制。

目前尚未发现OpenCOR可以绘制三维图像,但可以将数据导出为csv文件。

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

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

相关文章

QEMU使用步骤

1、安装虚拟机环境:ubuntu-16.04.7-desktop-amd64.iso,下载地址:Index of /ubuntu-releases/16.04.7/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 2、安装gcc-linaro-7.3.1-2018.05-x86_64_arm-linux-gnueabihf.tar.xz到/opt目录&#xf…

漫漫数学之旅020

文章目录 经典格言数学习题古今评注名人小传 - 尼尔斯玻尔 经典格言 专家就是这样一个人,在一个很狭小的领域里犯下一切可能犯的错误。——尼尔斯玻尔(Niels Bohr) 尼尔斯玻尔,这位量子物理界的巨头,以一句幽默且充满…

【Python】高级数据类型

🚩 WRITE IN FRONT 🚩 🔎 介绍:"謓泽"正在路上朝着"攻城狮"方向"前进四" 🔎🏅 荣誉:2021|2022年度博客之星物联网与嵌入式开发TOP5|TOP4、2021|2222年获评…

几个经典金融理论

完整EA:Nerve Knife.ex4黄金交易策略_黄金趋势ea-CSDN博客 一、预期效用理论 预期效用理论是描述人们在做出决策时如何考虑风险和不确定性的一种理论。该理论最初由经济学家冯诺伊曼(John von Neumann)和奥斯卡摩根斯坦恩(Oskar…

图像配准之HomographyNet

文章名称:Deep Image Homography Estimation,论文地址:https://arxiv.org/pdf/1606.03798.pdf,代码地址:GitHub - mazenmel/Deep-homography-estimation-Pytorch: Deep homography network with Pytorch 1、背景介绍 …

maven创建webapp+Freemarker组件的实现

下载安装配置maven Maven官方版下载丨最新版下载丨绿色版下载丨APP下载-123云盘123云盘为您提供Maven最新版正式版官方版绿色版下载,Maven安卓版手机版apk免费下载安装到手机,支持电脑端一键快捷安装https://www.123pan.com/s/9QRqVv-TcUY.html链接为3.6.2-3.6.3的版本 下载解…

【C++】类和对象(四)

前言:在类和对象中,我们走过了十分漫长的道路,今天我们将进一步学习类和对象,类和对象这块荆棘地很长,各位一起加油呀。 💖 博主CSDN主页:卫卫卫的个人主页 💞 👉 专栏分类:高质量&a…

《小强升职记:时间管理故事书》阅读笔记

目录 前言 一、你的时间都去哪儿了 1.1 你真的很忙吗 1.2 如何记录和分析时间日志 1.3 如何找到自己的价值观 二、无压工作法 2.1 传说中的“四象限法则 2.2 衣柜整理法 三、行动时遇到问题怎么办? 3.1 臣服与拖延 3.2 如何做到要事第一? 3.…

【碎片知识点】安装Linux系统 VMware与kali

天命:VMware就是可以运行操作系统的载体,kali就是Linux的其中一个分支 天命:Linux有两个分支版本:centos与ubuntu,kali底层就是ubuntu(所有Linux用起来都差不多,没啥区别) 天命&…

linux系统zabbix自动发现主机

自动发现主机 新的主机浏览器配置创建发现规则创建发现主机后动作 新的主机 rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm# yum clean allyum install zabbix-agentvim /etc/zabbix/zabbix_agentd.conf Server10.12.153.1…

C语言:内存分配---栈区、堆区、全局区、常量区和代码区

一、C语言内存分区 C语言内存分区示意图如下: 1. 栈区 栈区介绍 栈区由编译器自动分配释放,由操作系统自动管理,无须手动管理。栈区上的内容只在函数范围内存在,当函数运行结束,这些内容也会自动被销毁。栈区按内存…

微服务中台架构的设计与实现

本文将探讨微服务中台架构的设计与实现,介绍如何通过微服务的方式进行系统拆分和组合,构建灵活、可扩展且易于维护的中台架构,以加速企业的数字化转型和提升竞争力。 ## 1. 引言 随着企业规模的不断扩大和业务的日益复杂化,传统…

山西电力市场日前价格预测【2024-02-12】

日前价格预测 预测说明: 如上图所示,预测明日(2024-02-12)山西电力市场全天平均日前电价为127.42元/MWh。其中,最高日前电价为369.24元/MWh,预计出现在18:45。最低日前电价为0.00元/MWh,预计出…

库函数strlen的实现

目录 一、原理二、思路三、实现 一、原理 库函数strlen的功能是求字符串长度,统计的是字符串中 \0 之前的字符的个数。 函数原型如下: size_t strlen ( const char * str );二、思路 参数str接收⼀个字符串的起始地址,然后开始统计字符串中…

WEB APIs(1)

变量声明const(修饰常量) const优先,如react,基本const, 对于引用数据类型,可用const声明,因为储存的是地址 何为APIs 可以使用js操作HTML和浏览器 分类:DOM(文档对象…

C# Winform .net6自绘的圆形进度条

using System; using System.Drawing; using System.Drawing.Drawing2D; using System.Windows.Forms;namespace Net6_GeneralUiWinFrm {public class CircularProgressBar : Control{private int progress 0;private int borderWidth 20; // 增加的边框宽度public int Progr…

全闭环直播推流桌面分享远控系统

直播推流涉及多协议,多端技术栈和知识点,,想要做好并不容易,经过几年时间的迭代,终于小有成就,聚集了媒体服务器,实时会议sfu,远控kvm等功能。可以做一个音视频应用的瑞士小军刀。主…

为什么说技术进步很慢? —— 技术的先进性与其当下价值的不匹配

一、背景 技术进步是否缓慢是一个相对的概念,需要在不同的领域和时间段内进行分析。以下是一些不同领域中可能造成技术进步看似缓慢的原因: 1. **基础研究瓶颈**:许多先进技术的发展依赖于基础科学的突破,而这些突破往往需要长时…

openGauss学习笔记-219 openGauss性能调优-确定性能调优范围-硬件瓶颈点分析-网络

文章目录 openGauss学习笔记-219 openGauss性能调优-确定性能调优范围-硬件瓶颈点分析-网络219.1 查看网络状况 openGauss学习笔记-219 openGauss性能调优-确定性能调优范围-硬件瓶颈点分析-网络 获取openGauss节点的CPU、内存、I/O和网络资源使用情况,确认这些资源…

论文阅读-面向机器学习的云工作负载预测模型的性能分析

论文名称:Performance Analysis of Machine Learning Centered Workload Prediction Models for Cloud 摘要 由于异构服务类型和动态工作负载的高变异性和维度,资源使用的精确估计是一个复杂而具有挑战性的问题。在过去几年中,资源使用和流…