C++和R穿刺针吸活检肿瘤算法模型模拟和进化动力学量化差异模型

🎯要点

🎯模拟肿瘤细胞增生进化轨迹 | 🎯肿瘤生长的随机空间细胞自动机模型 | 🎯模拟穿刺活检的收集空间局部的肿瘤块,模拟针吸活检采集长而薄的组织样本 | 🎯构建不同参数模拟合成肿瘤测试集 | 🎯算法模型计算先验分布、计算概率分布的瓦瑟斯坦距离和欧氏距离 | 🎯细胞进化系统动力学量化分裂差异模型。

📜病理学用例

📜Python和C++骨髓细胞进化解析数学模型

📜Python成像质谱流式细胞术病理生理学

📜Python流感传播感染康复图模型计算和算法

📜Python脑溶质扩散生理几何模型计算

📜Python流感常微分方程房室数学模型

📜Python药物副作用生物图分析算法和矩阵降维算法

🍪语言内容分比

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

🍇R瓦瑟斯坦距离

两个概率测度 μ \mu μ ν \nu ν 之间的 p th  p^{\text {th }} pth  瓦瑟斯坦距离,在有限 p th  p^{\text {th }} pth  矩下,可以定义为
W p ( μ , ν ) p = inf ⁡ E [ d ( X , Y ) p ] W_p(\mu, \nu)^p=\inf E \left[d(X, Y)^p\right] Wp(μ,ν)p=infE[d(X,Y)p]
其中 d d d 是一个度量, E [ Z ] E [Z] E[Z] 表示随机变量 Z Z Z 的期望值,下确界取随机变量 X X X Y Y Y 的所有联合分布,边际为分别为 μ \mu μ ν \nu ν。对于 p = 1 p=1 p=1,表明, R R R 上的两个累积分布函数 F 1 F_1 F1 F 2 F_2 F2 之间的一维(一维)瓦瑟斯坦-1 度量可以写为 L 1 L_1 L1距离:
W 1 ( F 1 , F 2 ) = ∫ R ∣ F 1 ( x ) − F 2 ( x ) ∣ d x W_1\left(F_1, F_2\right)=\int_{ R }\left|F_1(x)-F_2(x)\right| d x W1(F1,F2)=RF1(x)F2(x)dx
因此,对于具有数值可处理的累积分布函数的分布,瓦瑟斯坦-1 度量可以用数值积分来近似。值得注意的是,该距离在单调变换(例如,在尺度变换下)下不是不变的。

接下来,我们展示分布 F ( ⋅ ; θ ) F(\cdot ; \theta) F(;θ) 和嵌套兴趣分布 F ( ⋅ ; θ 0 ) F\left(\cdot ; \theta_0\right) F(;θ0) 之间瓦瑟斯坦-1 度量的数值计算示例,对于 θ 0 \theta_0 θ0 的某个固定值。我们省略了位置和比例参数,但可以轻松调整 R 代码以包含这些参数。我们还展示了该函数的图:
M ( θ ) = W 1 ( F ( ⋅ ; θ ) , F ( ⋅ ; θ 0 ) ) = ∫ R ∣ F ( x ; θ ) − F ( x ; θ 0 ) ∣ d x M(\theta)=W_1\left(F(\cdot ; \theta), F\left(\cdot ; \theta_0\right)\right)=\int_{ R }\left|F(x ; \theta)-F\left(x ; \theta_0\right)\right| d x M(θ)=W1(F(;θ),F(;θ0))=RF(x;θ)F(x;θ0)dx
可以解释为测量参数 θ \theta θ 效果的函数。

偏斜正态概率密度函数为:
f ( x ; λ ) = 2 ϕ ( x ) Φ ( λ x ) f(x ; \lambda)=2 \phi(x) \Phi(\lambda x) f(x;λ)=2ϕ(x)Φ(λx)
其中 ϕ \phi ϕ Φ \Phi Φ 分别是标准正态概率密度函数和累积分布函数, λ ∈ R \lambda \in R λR。在这里,我们计算 f ( x ; λ ) f(x ; \lambda) f(x;λ) ϕ ( x ) \phi(x) ϕ(x) 之间的瓦瑟斯坦-1 度量。

library(sn)
library(knitr)
MW1 <- Vectorize(function(par){tempf <- Vectorize(function(x)  abs(psn(x, alpha=par)  - pnorm(x)) )val <- integrate(tempf,-Inf,Inf)$valuereturn(val)
})lambda <- -5:5
W1 <- MW1(lambda)
print(kable(cbind(lambda,W1),digits=4))
## 
## 
##  lambda       W1
## -------  -------
##      -5   0.7824
##      -4   0.7741
##      -3   0.7569
##      -2   0.7136
##      -1   0.5642
##       0   0.0000
##       1   0.5642
##       2   0.7136
##       3   0.7569
##       4   0.7741
##       5   0.7824

结果绘图

curve(MW1,-10,10, xlab = ~lambda, ylab="M", cex.axis=1.5, cex.lab=1.5, lwd=2, n = 250)

两部分正态概率密度函数定义为:
f ( x ; γ ) = ϕ ( x 1 + γ ) I ( x < 0 ) + ϕ ( x 1 − γ ) I ( x ≥ 0 ) f(x ; \gamma)=\phi\left(\frac{x}{1+\gamma}\right) I(x<0)+\phi\left(\frac{x}{1-\gamma}\right) I(x \geq 0) f(x;γ)=ϕ(1+γx)I(x<0)+ϕ(1γx)I(x0)
其中 ϕ \phi ϕ 是标准正态概率密度函数, γ ∈ ( − 1 , 1 ) \gamma \in(-1,1) γ(1,1)。在这里,我们计算 f ( x ; γ ) f(x ; \gamma) f(x;γ) ϕ ( x ) \phi(x) ϕ(x) 之间的瓦瑟斯坦-1度量。

library(twopiece)
library(knitr)MW1 <- Vectorize(function(par){tempf <- Vectorize(function(x)  abs(ptp3(x, 0, 1, par, FUN = pnorm, param = "eps")  - pnorm(x)) )val <- integrate(tempf,-Inf,Inf)$valuereturn(val)
})gamma <- seq(-0.9,0.9,by=0.1)
W1 <- MW1(gamma)
print(kable(cbind(gamma,W1),digits=4))
## 
## 
##  gamma       W1
## ------  -------
##   -0.9   1.4362
##   -0.8   1.2766
##   -0.7   1.1170
##   -0.6   0.9575
##   -0.5   0.7979
##   -0.4   0.6383
##   -0.3   0.4787
##   -0.2   0.3192
##   -0.1   0.1596
##    0.0   0.0000
##    0.1   0.1596
##    0.2   0.3192
##    0.3   0.4787
##    0.4   0.6383
##    0.5   0.7979
##    0.6   0.9575
##    0.7   1.1170
##    0.8   1.2766
##    0.9   1.4362

结果绘图

curve(MW1,-0.99,0.99, xlab = ~gamma, ylab="M", cex.axis=1.5, cex.lab=1.5, lwd=2, n = 250)

指数威布尔分布是一种三参数分布。它包含一个尺度参数、一个形状参数和一个幂(形状)参数 α \alpha α。 指数威布尔分布包含作为特殊情况 ( α = 1 ) (\alpha=1) (α=1) 的威布尔分布。 指数威布尔分布已用于对生存时间进行建模,因为它的风险函数可以捕获基本形状:常数、递增、递减、浴盆和单峰。

如果我们有兴趣比较两条生存曲线 S 1 S_1 S1 S 2 S_2 S2,一种可能的方法是计算生存曲线之间的面积,即它们之间的 L 1 L_1 L1 距离。此外,由于 S i ( ⋅ ) = 1 − F i ( ⋅ ) , i = 1 , 2 S_i(\cdot)=1-F_i(\cdot), i=1,2 Si()=1Fi(),i=1,2,因此
∫ R + ∣ S 1 ( x ) − S 2 ( x ) ∣ d x = ∫ R + ∣ F 1 ( x ) − F 2 ( x ) ∣ d x = W 1 ( F 1 , F 2 ) \int_{ R _{+}}\left|S_1(x)-S_2(x)\right| d x=\int_{ R _{+}}\left|F_1(x)-F_2(x)\right| d x=W_1\left(F_1, F_2\right) R+S1(x)S2(x)dx=R+F1(x)F2(x)dx=W1(F1,F2)
在这里,我们将测量在尺度和形状参数为 1 的情况下功率参数 α \alpha α 的影响,与具有单位尺度和形状参数的威布尔分布相比。

library(knitr)pexpweibull<- function(t,lambda,kappa,alpha,log.p=FALSE){log.cdf <- alpha*pweibull(t,scale=lambda,shape=kappa,log.p=TRUE)ifelse(log.p, return(log.cdf), return(exp(log.cdf)))
} MW1 <- Vectorize(function(par){tempf <- Vectorize(function(x)  abs(pexpweibull(x, 1, 1, par)  - pweibull(x,1,1)) )val <- integrate(tempf,0,Inf)$valuereturn(val)
})alpha <- seq( 0.1,5,by=0.1)
W1 <- MW1(alpha)
print(kable(cbind(alpha,W1),digits=4))
## 
## 
##  alpha       W1
## ------  -------
##    0.1   0.8465
##    0.2   0.7118
##    0.3   0.5920
##    0.4   0.4842
##    0.5   0.3863
##    0.6   0.2967
##    0.7   0.2142
##    0.8   0.1378
##    0.9   0.0666
##    1.0   0.0000
##    1.1   0.0626
##    1.2   0.1215
##    1.3   0.1773
##    1.4   0.2301
##    1.5   0.2804
##    1.6   0.3283
##    1.7   0.3740
##    1.8   0.4178
##    1.9   0.4597
##    2.0   0.5000
##    2.1   0.5387
##    2.2   0.5761
##    2.3   0.6120
##    2.4   0.6468
##    2.5   0.6804
##    2.6   0.7129
##    2.7   0.7444
##    2.8   0.7749
##    2.9   0.8045
##    3.0   0.8333
##    3.1   0.8613
##    3.2   0.8886
##    3.3   0.9151
##    3.4   0.9409
##    3.5   0.9661
##    3.6   0.9907
##    3.7   1.0146
##    3.8   1.0381
##    3.9   1.0610
##    4.0   1.0833
##    4.1   1.1052
##    4.2   1.1266
##    4.3   1.1476
##    4.4   1.1682
##    4.5   1.1883
##    4.6   1.2080
##    4.7   1.2274
##    4.8   1.2464
##    4.9   1.2650
##    5.0   1.2833

结果绘图

curve(MW1,0.001,5, xlab = ~alpha, ylab="M", cex.axis=1.5, cex.lab=1.5, lwd=2, n = 1000)

👉参阅、更新:计算思维 | 亚图跨际

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

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

相关文章

LangChain--如何使用大模型

【&#x1f34a;易编橙终身成长社群&#x1f34a;】 大家好&#xff0c;我是小森( &#xfe61;ˆoˆ&#xfe61; ) &#xff01; 易编橙终身成长社群创始团队嘉宾&#xff0c;橙似锦计划领衔成员、阿里云专家博主、腾讯云内容共创官、CSDN人工智能领域优质创作者 。 LangCha…

Linux——简介

Linux的组成 Linux系统一般由四个主要部分组成&#xff1a;内核、shell、文件系统和应用程序。 内核&#xff1a;是操作系统的核心&#xff0c;负责管理系统的进程、内存、设备驱动程序、文件和网络系统等&#xff0c;决定着系统的性能和稳定性。shell&#xff1a;是系统的用…

2024:Qt--编译配置Protobuf(windows10) 配图详解

这里写自定义目录标题 一、准备1、Window10系统2、Qt Creator 5.0.2 Based on Qt 5.15.2 (MSVC 2019, 64 bit)3、protobuf-3.15.0&#xff08;本示例使用版本&#xff09;4、cmake-3.21.3-windows-x86_64&#xff08;本示例使用&#xff0c;下载的zip直接解压使用&#xff09; …

自编码器(autoencoder)

1.自编码器的由来 最初的自编码器是用来降维的&#xff0c;后来也逐渐用于去噪、生成任务。 2.自编码器的基本结构 自编码器&#xff08;autoencoder&#xff09;内部有一个隐藏层 h&#xff0c;可以产生编码&#xff08;code&#xff09;表示输入。该网络可以看作由两部分组…

ArcGIS Desktop使用入门(四)——ArcMap软件彻底卸载删除干净

系列文章目录 ArcGIS Desktop使用入门&#xff08;一&#xff09;软件初认识 ArcGIS Desktop使用入门&#xff08;二&#xff09;常用工具条——标准工具 ArcGIS Desktop使用入门&#xff08;二&#xff09;常用工具条——编辑器 ArcGIS Desktop使用入门&#xff08;二&#x…

支持向量机回归及其应用(附Python 案例代码)

使用支持向量机回归估计房价 让我们看看如何使用支持向量机&#xff08;SVM&#xff09;的概念构建一个回归器来估计房价。我们将使用sklearn中提供的数据集&#xff0c;其中每个数据点由13个属性定义。我们的目标是根据这些属性估计房价。 引言 支持向量回归&#xff08;SV…

vim的使用及退出码(return 0)

linux基础之vim快速入门 linux基础之vim快速入门_基本linux vim-CSDN博客https://blog.csdn.net/ypxcan/article/details/119878137?ops_request_misc&request_id&biz_id102&utm_termvim%E7%BC%96%E8%BE%91%E5%99%A8%E5%A4%8D%E5%88%B6%E7%B2%98%E8%B4%B4%E4%BA%…

Java(十)——接口

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 ⚡开源项目&#xff1a; rich-vue3 &#xff08;基于 Vue3 TS Pinia Element Plus Spring全家桶 MySQL&#xff09; &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1…

JAVA零基础学习3(Scanner类,字符串,StringBuilder,StringJoinder,ArrayList成员方法)

JAVA零基础学习&#xff13; Scanner类输入示例代码代码解释完整代码1. 读取字符串2. 读取整数3. 读取浮点数4. 读取布尔值5. 读取单个单词6. 读取长整型数7. 读取短整型数8. 读取字节数注意事项总结 API 字符串解释示例解释解决方法示例&#xff1a;使用 StringBuilder String…

口碑爆棚的高分法国电影,一起在光影中领略法式魅力吧!

文章目录 引言《与玛格丽特的午后》(网友评分:9.1)《午夜巴黎》(网友评分:8.3)《玫瑰人生》(网友评分:8.4)《双姝奇缘》(网友评分:8.7)《巴黎淘气帮》(网友评分:8.6)《触不可及》(网友评分:9.3)《爱在日落黄昏时》(网友评分:8.9)《悲惨世界》(网友评分:…

VScode使用Github Copilot插件时出现read ECONNREST问题的解决方法

文章目录 read ECONNREST查看是否仍是 Copilot 会员查看控制台输出网络连接问题浏览器设置问题笔者的话 read ECONNREST 最近使用 Copilot 时一直出现 read ECONNREST 问题&#xff0c;这个表示连接被对方重置了&#xff0c;就是说在读取数据时连接被关闭。 我首先怀疑是不是…

[023-2].第2节:SpringBoot中接收参数相关注解

我的后端学习大纲 SpringBoot学习大纲 1.1.基本介绍&#xff1a; SpringBoot接收客户端提交的数据、参数会使用的一些注解&#xff1a; 1.PathVarible2. RequestHeader3.RequestParam4.CookieValue5.RequestBody6.RequestAttribute 1.2.接收参数相关注解与应用实例&#xff1a;…

无人机制造工艺流程详解

一、需求分析 无人机制造的第一步是需求分析。这一阶段主要明确无人机的使用场景、功能要求、性能指标以及成本预算等。通过与客户或项目团队的深入沟通&#xff0c;确保对无人机的需求有全面而准确的理解。同时&#xff0c;也需要进行市场调研&#xff0c;了解同类型产品的特…

科普文:docker基础概念、软件安装和常用命令

docker基本概念 一 容器的概念 1. 什么是容器&#xff1a;容器是在隔离的环境里面运行的一个进程&#xff0c;这个隔离的环境有自己的系统目录文件&#xff0c;有自己的ip地址&#xff0c;主机名等。也可以说&#xff1a;容器是一种轻量级虚拟化的技术。 2. 容器相对于kvm虚…

如何使用 SQLite ?

SQLite 是一个轻量级、嵌入式的关系型数据库管理系统&#xff08;RDBMS&#xff09;。它是一种 C 库&#xff0c;实现了自给自足、无服务器、零配置、事务性 SQL 数据库引擎。SQLite 的源代码是开放的&#xff0c;完全在公共领域。它被广泛用于各种应用程序&#xff0c;包括浏览…

【C语言】函数的递归

目录 一、什么是递归 二、递归的思想 三、递归的限制条件 四、递归中的栈溢出 五、递归举例 &#xff08;1&#xff09;例1&#xff1a;n的阶乘 &#xff08;2&#xff09;例子2&#xff1a;顺序打印一个数的每一位 六、递归和迭代 七、拓展题目 &#xff08;1&#…

Chainlit一个快速构建成式AI应用的Python框架,无缝集成与多平台部署

概述 Chainlit 是一个开源 Python 包&#xff0c;用于构建和部署生成式 AI 应用的开源框架。它提供了一种简单的方法来创建交互式的用户界面&#xff0c;这些界面可以与 LLM&#xff08;大型语言模型&#xff09;驱动的应用程序进行通信。Chainlit 旨在帮助开发者快速构建基于…

如何知道一个字段在selenium中是否可编辑?

这篇文章将检查我们如何使用Java检查selenium webdriver中的字段是否可编辑。 我们如何知道我们是否可以编辑字段&#xff1f;“readonly”属性控制字段的可编辑性。如果元素上存在“readonly”属性&#xff0c;则无法编辑或操作该元素或字段。 因此&#xff0c;如果我们找到一…

强大的开源网络攻击面分析工具:Hetty

Hetty&#xff1a;深入网络的每一个角落&#xff0c;Hetty让安全漏洞无处遁形。- 精选真开源&#xff0c;释放新价值。 概览 Hetty作为一个专为网络攻击面分析而设计的开源HTTP/1.1客户端&#xff0c;其设计初衷是为了帮助安全研究人员和渗透测试人员深入挖掘潜在的网络漏洞。…

[网鼎杯 2020 朱雀组]Nmap(详细解读版)

这道题考察nmap的一些用法,以及escapeshellarg和escapeshellcmd两个函数的绕过&#xff0c;可以看这里PHP escapeshellarg()escapeshellcmd() 之殇 (seebug.org) 两种解题方法&#xff1a; 第一种通过nmap的-iL参数读取扫描一个文件到指定文件中第二种是利用nmap的参数写入we…