列线图/诺莫图 含概率轴

r 复制代码
## =========================
## regplot 文字替换版
## =========================

pkgs <- c("readxl", "survival", "regplot")
for (p in pkgs) {
  if (!requireNamespace(p, quietly = TRUE)) install.packages(p)
  library(p, character.only = TRUE)
}

## 读入数据
file_path <- "C:/Users/P16v/Desktop/2025-12/MATLAB2026112.xlsx"
stopifnot(file.exists(file_path))
dat0 <- readxl::read_excel(file_path)

## 数据整理
train3 <- data.frame(
  RecurT        = as.numeric(dat0$RecurT),
  Recurrence    = as.integer(dat0$Recurrence),
  CombinedScore = as.numeric(dat0$CombinedScore),
  Size          = as.integer(dat0$Size)
)
train3 <- train3[complete.cases(train3), ]

## -------------------------------------------------------
## 把变量名改成你想显示的名字
## 注意:为了公式兼容,保留合法列名,绘图后再覆盖显示文字
## -------------------------------------------------------
train3_plot <- train3
names(train3_plot)[names(train3_plot) == "CombinedScore"] <- "Combined.Score"
names(train3_plot)[names(train3_plot) == "Size"]          <- "Lesion.Size"

cat("修改后列名:", names(train3_plot), "\n")

## 建模
fit_plot <- coxph(
  Surv(RecurT, Recurrence) ~ Combined.Score + Lesion.Size,
  data = train3_plot,
  x    = TRUE,
  ties = "efron"
)

print(summary(fit_plot))

## 绘图
graphics.off()
dev.new(width = 12, height = 8)

regplot::regplot(
  reg         = fit_plot,
  observation = train3_plot[1, ],
  interval    = "confidence",
  failtime    = c(6, 12, 24),
  title       = "",
  points      = TRUE,
  center      = FALSE,
  rank        = "sd",
  clickable   = FALSE,
  showP       = TRUE,
  odds        = FALSE
)

## -------------------------------------------------------
## 覆盖左侧标签文字
## 思路:用白色矩形盖住原标签,再写入新标签
## -------------------------------------------------------

## 获取当前绘图区坐标
usr <- par("usr")

## 左侧覆盖区域(根据图形效果可微调)
x_left  <- usr[1]
x_right <- usr[1] + 0.22 * (usr[2] - usr[1])

## 先盖住左侧原标签
rect(
  xleft   = x_left,
  ybottom = usr[3],
  xright  = x_right,
  ytop    = usr[4],
  col     = "white",
  border  = NA,
  xpd     = NA
)

## 重新写左侧标签
## 这些 y 位置是按当前 regplot 常见布局手工设置的
## 如有轻微上下偏差,可把数字微调
text(x = usr[1] + 0.02 * (usr[2] - usr[1]), y = usr[4] - 0.06 * (usr[4] - usr[3]),
     labels = "Points", adj = 0, cex = 1.2, font = 3, xpd = NA)

text(x = usr[1] + 0.02 * (usr[2] - usr[1]), y = usr[4] - 0.18 * (usr[4] - usr[3]),
     labels = "Combined Score", adj = 0, cex = 1.2, xpd = NA)

text(x = usr[1] + 0.02 * (usr[2] - usr[1]), y = usr[4] - 0.33 * (usr[4] - usr[3]),
     labels = "Lesion Size", adj = 0, cex = 1.2, xpd = NA)

text(x = usr[1] + 0.02 * (usr[2] - usr[1]), y = usr[4] - 0.47 * (usr[4] - usr[3]),
     labels = "Total points", adj = 0, cex = 1.2, font = 3, xpd = NA)

text(x = usr[1] + 0.14 * (usr[2] - usr[1]), y = usr[4] - 0.73 * (usr[4] - usr[3]),
     labels = "24-month Recurrence Risk", adj = 0, cex = 1.1, xpd = NA)

text(x = usr[1] + 0.14 * (usr[2] - usr[1]), y = usr[4] - 0.86 * (usr[4] - usr[3]),
     labels = "12-month Recurrence Risk", adj = 0, cex = 1.1, xpd = NA)

text(x = usr[1] + 0.14 * (usr[2] - usr[1]), y = usr[4] - 0.99 * (usr[4] - usr[3]),
     labels = "6-month Recurrence Risk", adj = 0, cex = 1.1, xpd = NA)

cat("\n========== 完成,请查看 Plots 窗口 ==========\n")

包含修改成分,输出Plots需要修改

一个典型的列线图通常包含以下几个关键部分:

(1)变量轴:每个预测变量(如年龄、性别、睡眠质量等)都有一个独立的轴,清晰地展示各自的影响。

(2)点数轴:用于将变量值转换为相应的点数,便于后续计算。

(3)总分轴:汇总所有变量的点数,提供一个整体评分,帮助快速评估风险。

(4)概率轴:根据总分预测事件发生的概率,使得临床决策更加科学、直观。

相关推荐
冬奇Lab8 小时前
Workflow 系列(06):安全——跨步骤注入传播与四层防御
人工智能·工作流引擎
冬奇Lab8 小时前
每日一个开源项目(第149篇):RAG-Anything - 把图片、表格、公式当成一等公民的多模态 RAG 框架
人工智能·开源
米小虾8 小时前
AI Agent 安全实战指南:当智能体开始"不听话",开发者该如何应对?
人工智能·安全·agent
IT_陈寒10 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
阿里云大数据AI技术12 小时前
构建高转化海外电商搜索:阿里云OpenSearch行业算法版的全链路智能优化策略实战
人工智能·搜索引擎
Awu122712 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
字节跳动视频云技术团队12 小时前
让 Agent 成为音视频工作台:AI MediaKit CLI + Skill 发布
人工智能·音视频开发
魏祖潇12 小时前
framework 整合实战——DDD/TDD/SDD 三件套在 framework 仓的真实落地
人工智能·后端
Token炼金师13 小时前
去噪扩散:从随机噪声到高保真图像的数学之路
人工智能·aigc