列线图/诺莫图 含概率轴

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)概率轴:根据总分预测事件发生的概率,使得临床决策更加科学、直观。

相关推荐
轮到我狗叫了2 小时前
GAN初次阅读
人工智能·神经网络·生成对抗网络
造夢先森2 小时前
【白话神经网络(三)】从Transformer到XXX
人工智能·神经网络·transformer
研究点啥好呢2 小时前
3月22日GitHub热门项目推荐|网页浏览,何须手动
人工智能·python·开源·github
zl_vslam2 小时前
SLAM中的非线性优-3D图优化之相对位姿Between Factor-四元数(十二)
人工智能·算法·计算机视觉
知行产研2 小时前
神宝能源:启动国内首个极寒工况5G+无人驾驶项目
人工智能·自动驾驶
love530love2 小时前
ComfyUI-3D-Pack:Windows 下手动编译 mesh_inpaint_processor C++ 加速模块
c++·人工智能·windows·python·3d·hunyuan3d·comfyui-3d-pack
uzong2 小时前
“腾讯QClaw全面开放”,不花 Token 钱、真正体验一把小龙虾的快乐,最低成本全面了解龙虾
人工智能·后端
剑穗挂着新流苏3122 小时前
111_神经网络的指路明灯:损失函数与反向传播深度解析
人工智能·深度学习·神经网络
ofoxcoding2 小时前
怎么用 API 搭一个 AI 客服机器人?从零到上线的完整方案
人工智能·ai·机器人