【亲测免费】 nnFormer 开源项目教程
2026-01-18 09:22:44作者:胡易黎Nicole
项目介绍
nnFormer 是一个基于 3D Transformer 的体积医学图像分割工具。该项目通过结合交错的卷积和自注意力操作,并引入局部和全局体积自注意力机制,来学习体积表示。此外,nnFormer 使用跳跃注意力替代传统的 U-Net 架构中的连接/求和操作。实验表明,nnFormer 在三个公共数据集上显著优于之前的基于 Transformer 的模型。
项目快速启动
环境设置
首先,克隆项目仓库并设置环境:
git clone https://github.com/282857341/nnFormer.git
cd nnFormer
conda env create -f environment.yml
source activate nnFormer
pip install -e .
数据准备
下载所需的数据集并进行预处理:
nnFormer_convert_decathlon_task -i /DATASET/nnFormer_raw/nnFormer_raw_data/Task01_ACDC
nnFormer_convert_decathlon_task -i /DATASET/nnFormer_raw/nnFormer_raw_data/Task02_Synapse
nnFormer_convert_decathlon_task -i /DATASET/nnFormer_raw/nnFormer_raw_data/Task03_tumor
nnFormer_plan_and_preprocess -t 1
nnFormer_plan_and_preprocess -t 2
nnFormer_plan_and_preprocess -t 3
训练模型
使用以下命令开始训练:
nnFormer/nnformer/run/run_training.py
模型评估
训练完成后,可以使用以下脚本进行模型评估:
nnFormer/nnformer/inference_acdc.py
nnFormer/nnformer/inference_synapse.py
nnFormer/nnformer/inference_tumor.py
应用案例和最佳实践
案例一:ACDC 数据集上的分割
在 ACDC 数据集上,nnFormer 能够有效地进行心脏分割,提供高质量的分割结果。通过调整训练参数和数据预处理步骤,可以进一步优化性能。
案例二:Synapse 多器官 CT 数据集
在 Synapse 数据集上,nnFormer 展示了其在多器官分割任务上的强大能力。通过使用跳跃注意力机制,模型能够更好地捕捉器官间的复杂关系。
最佳实践
- 数据预处理:确保数据集的正确组织和预处理,以避免常见的数据加载问题。
- 超参数调整:根据具体任务调整学习率、批大小和训练轮数等超参数。
- 模型评估:定期评估模型性能,使用如 DSC 和 HD95 等指标来衡量分割质量。
典型生态项目
nnUNet
nnUNet 是一个高度灵活和强大的医学图像分割框架,nnFormer 在设计上借鉴了 nnUNet 的许多优点,并在此基础上引入了 Transformer 架构,以进一步提升分割性能。
UNETR
UNETR 是另一个基于 Transformer 的医学图像分割模型,nnFormer 在某些方面与 UNETR 有相似之处,但通过引入新的注意力机制和优化策略,nnFormer 在多个数据集上取得了更好的结果。
通过结合这些生态项目,可以进一步扩展和优化 nnFormer 的功能和性能。
登录后查看全文
热门项目推荐
相关项目推荐
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0130
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
AgentCPM-ReportAgentCPM-Report是由THUNLP、中国人民大学RUCBM和ModelBest联合开发的开源大语言模型智能体。它基于MiniCPM4.1 80亿参数基座模型构建,接收用户指令作为输入,可自主生成长篇报告。Python00
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
496
3.64 K
Ascend Extension for PyTorch
Python
300
338
暂无简介
Dart
744
180
React Native鸿蒙化仓库
JavaScript
297
346
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
868
479
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
305
130
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
11
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
20
仓颉编程语言测试用例。
Cangjie
43
872