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

news2024/9/9 7:51:31

🎯要点

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

📜病理学用例

📜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)$value
  return(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)$value
  return(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)$value
  return(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.coloradmin.cn/o/1963578.html

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

相关文章

【TS】TypeScript函数类型:提升函数的类型安全性和可读性

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 TypeScript函数类型&#xff1a;提升函数的类型安全性和可读性1. 引言2. 基本函…

vue3 基于elementui el-table封装 hooks (未使用ts版本)

elementui-table封装 hooks js-hooks import { ref, reactive, onMounted } from vue import { ElMessage, ElMessageBox, ElNotification } from element-plus /*** FileDescription: el-table 函数式组件hooks--实现一个表格的数据加载、分页、搜索、删除和导出等操作,* fu…

tesseract 图片识别引擎

什么是tesseract Tesseract是一款开源的光学字符识别&#xff08;OCR&#xff09;引擎&#xff0c;用于从图像中提取文本。它由Ray Smith在惠普实验室于1985年至1995年开发&#xff0c;并在2005年由惠普将其作为开源软件发布。之后&#xff0c;Tesseract的开发由Google主导&am…

如何理解低代码?怎么用好低代码

怎样理解低代码 理解一个概念最好的办法就是找相关概念进行类比&#xff0c;那么想要单独理解低代码这个概念是不太行的。我们还需要了解“零代码”以及“纯代码”开发的概念。那么什么是低代码&#xff1f;其与“零代码”和“纯代码”的关系又是如何&#xff1f; 零代码 也许…

IDEA资源文件中文乱码问题解决方法

目录 一、问题描述二、解决方法 一、问题描述 IDEA中打开资源文件出现乱码。 二、解决方法 进入“Settings” -> “Editor” -> “File Encodings”&#xff0c;按下图修改箭头所指的三个地方&#xff1a;

java类加载和双亲委派及加载恶意类代码应用

前面的CC1和CC6&#xff0c;都是在Runtime.exec执行命令。如果WAF过滤了Runtime就寄&#xff0c;而且用命令的方式写入shell进行下一步利用&#xff0c;在流量中一个数据包就能把你的行为全部看完&#xff0c;很容易被分析出来。 如果用恶意字节码加载的方式&#xff0c;我们的…

轮询系统的具体原理是什么

一般市面上的轮询系统&#xff0c;看似高深莫测&#xff0c;但都是大差不差的&#xff0c;没有太多的技术含量&#xff0c;都是通过你的订单情况&#xff0c;在数据库中找出一个可以收这个订单的支付方式&#xff0c;然后经过b站来实现与支付通道商交互。 这个过程看似复杂&am…

IP-GUARD文档云备份服务器迁移数据操作说明

一、功能简介 使用文档云备份过程可能出现需要迁移旧数据到新目录的情况(如一开始存储目录设置 不合理,之后变更存储目录),下面介绍迁移备份数据到新目录的方法,迁移后可正常查看、 下载、删除原备份文件。 二、同一计算机上迁移存储目录 当仅需要将存储目录迁移到同一计…

随机森林的可解释性分析(含python代码)

随机森林的可解释性分析 1.引言可解释性的重要性 2.随机森林的原理2.1 基本原理&#xff1a;2.2 随机森林的实现 3.随机森林的可解释性分析3.1 特征重要性3.2 特征重要性3.3 SHAP值3.4 部分依赖图&#xff08;PDP&#xff09;3.5 交互特征效应3.6 变量依赖图 4.结论5.参考文献 …

Android和iOS 测试五个最好的开源自动化工具

本文主要介绍Android和iOS 五个最好的开源自动化工具&#xff0c;这里整理了相关资料&#xff0c;希望能帮助测试软件的朋友&#xff0c;有需要的看下 自动化测试在产品测试上有着非常重要的作用。实现测试自动化有多种积极的方式&#xff0c;包括最大限度地减少测试执行时间&…

昇思25天学习打卡营第26天|munger85

ShuffleNet图像分类 和mobilenet一样&#xff0c;也是在资源有限的设备上进行神经网络来做ai图像分类的小模型&#xff0c;在保持精度的同时大大降低了模型的计算量。 是基本块 就是真正的网络&#xff0c;如果模型size是2&#xff0c;就是输出的时候多一些&#xff0c;精细一…

公司监控员工电脑都能监控到什么?公司电脑可以监控到哪些内容?

很多人反馈&#xff0c;公司监控电脑&#xff1a; 那到底为什么安装监控&#xff1f; 公司监控员工电脑又都能监控到什么&#xff1f; 下面小编跟你细细道来~ 第一部分&#xff1a;架空员工电脑监控的目的 在现代企业管理中&#xff0c;电脑监控已成为一种常见的做法。 企…

【LLM大模型】落地RAG系列:RAG入门及RAG面临的挑战和解决方案!!

2023 年以来&#xff0c;RAG 已成为基于大模型的人工智能系统中应用最为广泛的架构之一。因此对 RAG 应用的性能、检索效率、准确性的研究成为核心问题。 本文首先介绍什么是 RAG、为什需要 RAG、介绍 Naive RAG 工作流程及Naive RAG 存在的问题和挑战&#xff01; 为什么需要 …

10:WiFi模块服务器模式

WiFi模块服务器模式 1、单片机通过WiFi模块向移动设备进行通信 我们通过AT指令ATCWMODE x&#xff0c;可以配置WiFi模块的工作模式。   ATCWMODE1为移动设备模式&#xff0c;这时WiFi模块可以连接其他路由器WiFi&#xff0c;然后可以给连接这个WiFi的其他移动设备发送数据&a…

JAVA静态代理和动态代理

前言&#xff1a; 静态代理: 静态代理是在编译时就已经确定了代理类的具体实现。代理类需要实现与目标类相同的接口,并且持有目标对象的引用。在代理类中实现对目标方法的增强或修改。静态代理的优点是实现简单,可以很好地控制目标对象的行为。缺点是每个目标对象都需要创建一…

从光速常数的可变性看宇宙大爆炸的本质

基于先前关于光速本质的讨论&#xff0c;让我们从函数图像看看宇宙大爆炸到底是什么。 先前已经讨论过&#xff0c;在量子尺度上&#xff0c;长度的实际对应物是频率的差异&#xff0c;因为只有频率差异才能在这个尺度上区分相邻时空的两点&#xff0c;而两点之间“差异的大小”…

再不怕数据丢失了!全量增量的迁移工具发布!

随着用户量的增加,我们收到了各种各样的需求反馈。 为了更好地拓展Chat2DB Pro 产品, 我们很高兴地宣布推出了插件市场功能, 同时重磅推出数据迁移工具DBMotion插件。 &#x1f680; 关于 DBMotion 插件 DBMotion插件&#xff0c;是一款基于沃趣科技的 DBMotion 数据迁移工具…

软件兼容性测试内容和步骤简析,湖南软件测评公司分享

软件兼容性测试是确保软件产品在不同的硬件环境、操作系统、浏览器和设备上正常运行的重要环节。随着科技的迅猛发展&#xff0c;各类软件应用层出不穷&#xff0c;用户对软件的多样性需求日益增加&#xff0c;软件的兼容性显得尤为重要。 软件兼容性测试内容包含多个方面&…

RocketMQ中的参数约束和建议

消息发送重试次数&#xff1a; 默认值&#xff1a;3次。&#xff08;取值范围&#xff1a;无限制&#xff09; 消息发送重试和流控机制 | RocketMQ 消息消费重试次数&#xff1a; 默认值&#xff1a;16次。

便携式挂椅美国认证标准ASTM F1235测试,CPC认证

亚马逊作为一家致力于保障消费者权益的电商平台&#xff0c;亚马逊对便携式挂椅这一儿童用品的安全性有着严格的要求。为了确保儿童在使用过程中的安全&#xff0c;要求所有便携式挂椅必须经过特定法规或标准的检测&#xff0c;并符合相应的要求。 便携式挂椅是一种无腿座椅&am…