Medical Image Nnalysis发表对抗多实例学习框架,基于病理切片进行生存分析
小罗碎碎念
在医学AI领域,全切片图像(WSI)的生存分析对疾病预后评估至关重要。
现有基于WSI的生存分析方法存在局限性,经典生存分析规则使模型只能给出事件发生时间的点估计,缺乏预测稳健性和可解释性;且全监督学习方式依赖大量标记数据,而当前WSI数据集规模小,影响模型泛化能力。
针对这些问题,今天和大家分享的这篇论文,提出了对抗多实例学习(AdvMIL)框架。
该框架基于对抗时间到事件建模,融合了WSI表示学习所需的多实例学习。生成器采用通用MIL编码器和MLP层,可提取全局特征并生成时间到事件估计;判别器使用区域级实例投影(RLIP)融合网络,能有效处理大规模矩阵和标量值的融合。通过cGAN损失和监督损失优化网络,并提出k折半监督训练策略,充分利用无标记数据。
实验结果显示,AdvMIL在多个方面表现出色。它能以较低计算成本提升主流WSI生存分析方法的性能,帮助模型更有效地利用无标记数据进行半监督学习。
同时,AdvMIL还增强了模型对补丁遮挡和图像噪声的鲁棒性。这一框架为医学AI中基于WSI的生存分析研究提供了新方向,有望推动该领域进一步发展。
交流群
欢迎大家加入【医学AI】交流群,本群设立的初衷是提供交流平台,方便大家后续课题合作。
目前小罗全平台关注量61,000+
,交流群总成员1400+
,大部分来自国内外顶尖院校/医院,期待您的加入!!
由于近期入群推销人员较多,已开启入群验证,扫码添加我的联系方式,备注姓名-单位-科室/专业
,即可邀您入群。
知识星球
对推文中的内容感兴趣,想深入探讨?在处理项目时遇到了问题,无人商量?加入小罗的知识星球,寻找科研道路上的伙伴吧!
一、文献概述
“AdvMIL: Adversarial multiple instance learning for the survival analysis on whole-slide images”提出了一种新的对抗多实例学习框架AdvMIL,用于基于全切片图像(WSI)的生存分析,能有效提升模型性能、利用无标记数据,并增强模型鲁棒性。
作者类型 | 姓名 | 单位 |
---|---|---|
第一作者 | Pei Liu | 电子科技大学计算机科学与工程学院 |
通讯作者 | Luping Ji | 电子科技大学计算机科学与工程学院 |
1-1:研究背景
WSI生存分析对疾病预后评估意义重大,但现有方法受经典生存分析规则和全监督学习限制,只能给出事件发生时间点估计,且在小数据环境下训练。
生成对抗网络(GAN)可解决这些问题,本研究将GAN与多实例学习(MIL)结合,提出AdvMIL框架。
1-2:方法
框架设计
通过生成器中的MIL编码器和判别器中的区域级实例投影(RLIP)融合网络,将对抗时间到事件建模推广到MIL。
生成器利用MIL编码器提取全局特征,结合噪声生成时间到事件估计;判别器通过RLIP融合网络区分真实和虚假样本对。
网络训练
使用cGAN损失和监督损失优化网络。监督损失考虑了删失和未删失患者,使模型能通过隐式采样估计时间到事件分布。
k折半监督学习
提出k折半监督训练策略,将无标记数据分成k折,在不同训练轮次中依次使用不同折与标记数据训练,减少无标记数据主导训练的问题。
1-3:实验
设置
使用NLST、BRCA和LGG三个公开数据集,选择ABMIL、DeepAttnMISL、PatchGCN和ESAT作为基线模型。
详细设置了数据处理、模型参数、训练超参数和评估指标。
结果
AdvMIL能提升主流MIL网络性能,ESAT + AdvMIL在三个数据集上综合性能最佳。
AdvMIL计算开销小,在半监督学习中对训练时使用的无标记数据预测效果好,k折策略在标记数据较少时效果更好。
RLIP策略有效,均匀分布噪声性能更优。AdvMIL - 基于模型对补丁遮挡和图像噪声更鲁棒。案例分析表明AdvMIL能提供分布估计,更接近真实值。
1-4:讨论与结论
AdvMIL为计算病理学中的生存分析带来新方法,但存在无法定量评估分布估计覆盖度、实验采样次数有限和数据集类型有限等局限。
总体而言,AdvMIL能提升模型性能,辅助时间到事件分布估计和半监督学习,增强模型鲁棒性。
二、重点关注
2-1:嵌入级多实例学习(MIL)范式
这张图展示了用于全切片图像(WSI)表示学习的嵌入级多实例学习(MIL)范式 。
关联构建(Correlation building)
以簇(Cluster)、图(Graph)、序列(Sequence )三种结构来构建WSI图像块(WSI patches)之间的相关性。
比如簇结构将图像块分组关联;图结构用节点和边表示图像块关系;序列结构按顺序排列图像块建立关联 。
嵌入学习(Embedding learning)
利用全卷积网络(FCN)、图卷积网络(GCN)或Transformer等网络,基于前面构建的相关性,对图像块进行嵌入学习,得到图像块级(Patch - level)的特征表示 。
聚合(Aggregating)
通过池化(pooling)操作,将图像块级特征聚合成全切片图像级(WSI - level)的特征表示 。
这种范式旨在借助不同结构构建图像块相关性,再经特定网络学习和聚合操作,实现从图像块特征到全切片图像整体特征的有效学习,为后续基于WSI的分析任务(如疾病诊断、预后分析等)提供有力的特征表示基础 。
2-2:模型对比
这张图从模型输出和输入两方面,对比了现有全切片图像(WSI)生存分析模型与AdvMIL :
(a)模型输出
- 现有模型:局限于事件发生时间的点估计(用 y ^ \hat{y} y^ 表示) 。如针对结局为死亡(death ,红框)和删失(censored ,蓝框)的WSI图像,只能给出单一估计值 。
- AdvMIL:能提供事件发生时间分布的估计(用 { y ^ } \{\hat{y}\} {y^} 表示 ),相比点估计更稳健、可解释 。
(b)模型输入
展示了常用WSI生存分析数据集的规模,包括NLST、BRCA、LGG等 。
蓝色柱代表患者数量(# Patients) ,橙色柱代表切片数量(# Slides) 。可见这些数据集规模通常较小,患者数约500 ,切片数约1000 。
这反映出该领域数据规模小的现状,也凸显了AdvMIL在小数据环境下提升模型性能的研究意义。
2-3:AdvMIL的总体框架
包构建(Bag Construction)
将千兆像素级的全切片图像(Gigapixel WSI)通过从大到小的切片方式(big - to - small patching),转化为单个图像块(Patches)以及带有区域划分的图像块(Patches with region partition) 。
条件生成器(Conditional generator)
以通用的多实例学习编码器(MIL encoder)作为骨干 。
将图像块输入MIL编码器,结合从特定分布的高维向量获取的噪声(Noise) ,再经多层感知机(MLP)处理,输出事件时间的估计值 t ^ \hat{t} t^ 。
判别器(Discriminator)
采用区域级实例投影(RLIP)融合网络 。
真实的事件时间 t t t 和生成器输出的估计时间 t ^ \hat{t} t^ 都可作为输入 。判别器判断输入是真实数据(标记为√ )还是生成的虚假数据(标记为× ) 。
损失函数
- 监督损失(Supervision loss, L s l \mathcal{L}_{sl} Lsl ):用于优化条件生成器,使生成的时间估计更接近真实值 。
- 条件生成对抗网络损失(cGAN loss, L c g a n \mathcal{L}_{cgan} Lcgan ):在生成器和判别器之间对抗博弈,提升生成器生成数据的真实性和判别器的判别能力 。
图中还通过箭头标识了前向推理(forward inference)、反向传播(back propagation)路径,以及可选路径(optional path) ,清晰呈现了AdvMIL的运行机制。
三、AdvMIL 复现流程概述
3-1:研究背景与贡献
AdvMIL 是一种基于对抗性多示例学习(MIL)的框架,专门用于处理千兆像素级别的全切片图像(WSI)的生存分析。其核心创新在于:
-
对抗性时间事件建模:通过生成器和判别器的对抗训练,直接估计WSI的生存时间分布。
-
灵活性与兼容性:可结合现有MIL网络(如ABMIL、PatchGCN等)提升预测性能。
-
半监督学习能力:有效利用未标注的WSI数据。
-
鲁棒性增强:对图像遮挡、模糊和颜色变化具有较强鲁棒性。
3-2:环境配置与数据准备
软件
-
Python ≥ 3.6, PyTorch ≥ 1.9.0, CUDA ≥ 11.1
-
依赖库:wandb, numpy, pandas
工具准备
安装CLAM工具包用于WSI预处理。
3-3:Level 2分块(16倍下采样)
# 在CLAM目录下运行
python create_patches_fp.py \--source DATA_DIRECTORY \--save_dir /data/nlst/processed/tiles-l2-s256 \--patch_level 2 --patch_size 256 --seg --patch --stitch
作用:在低分辨率层级(level 2)检测组织区域,保存区块坐标。
输出:/data/nlst/processed/tiles-l2-s256
包含每个WSI的区块坐标和分割掩码。
3-4:Level 1分块(4倍下采样)
# 在AdvMIL的tools目录下运行
python3 big_to_small_patching.py \/data/nlst/processed/tiles-l2-s256 \/data/nlst/processed/tiles-l1-s256
作用:根据level 2的坐标生成更高分辨率(level 1)的区块坐标。
原理:通过坐标映射,将低分辨率区块转换为高分辨率对应区域。
3-5:特征提取
# 在CLAM目录下运行
CUDA_VISIBLE_DEVICES=0,1 python extract_features_fp.py \--data_h5_dir /data/nlst/processed/tiles-l1-s256 \--data_slide_dir DATA_DIRECTORY \--csv_path /data/nlst/processed/tiles-l1-s256/process_list_autogen.csv \--feat_dir /data/nlst/processed/feat-l1-RN50-B \--batch_size 512 --slide_ext .svs
作用:使用ResNet-50提取每个区块的特征。
输出:/data/nlst/processed/feat-l1-RN50-B
包含每个WSI的.pt
特征文件。
3-6:数据目录结构验证
确保生成以下目录结构:
/data/nlst/processed/
├── feat-l1-RN50-B/ # 特征文件
│ └── pt_files/
│ ├── 10015.pt
│ └── ...
├── tiles-l1-s256/ # Level 1区块坐标
│ ├── patches/
│ │ ├── 10015.h5
│ │ └── ...
│ └── process_list_autogen.csv
└── tiles-l2-s256/ # Level 2区块坐标(中间结果)
3-7:网络训练与测试
配置文件设置
编辑config/cfg_nlst.yaml
,关键参数说明:
save_path: "/results/nlst" # 结果保存路径
wandb_prj: "AdvMIL-NLST" # Weights & Biases项目名
bcb_mode: "patch" # 骨干网络(可选:patch, graph, cluster, abmil)
disc_prj_iprd: "instance" # 融合方式(instance=RLIP, bag=常规融合)
semi_training: False # 是否启用半监督学习
test: False # 是否为测试模式
test_load_path: "/pretrained/model.pt" # 测试模式下的模型路径
模式1:常规训练/验证/测试
# 多折交叉验证
python3 main.py \--config config/cfg_nlst.yaml \--handler adv \--multi_run
输出:在save_path
下生成模型文件、预测结果和评估指标。
模式2:测试模式
- 修改配置文件:
test: True test_load_path: "/path/to/pretrained_model.pt"
- 运行命令:
python3 main.py --config config/cfg_nlst.yaml --handler adv
模式3:半监督训练
-
修改配置文件:
semi_training: True ssl_unlabel_csv: "/path/to/unlabeled_data.csv" # 未标注数据路径
-
运行常规训练命令。
-
可选模型结构
图模型(Graph-based):生成患者级图结构
python3 tools/patchgcn_graph_s2.py nlst
聚类模型(Cluster-based):生成区块聚类标签
python3 tools/deepattnmisl_cluster.py nlst 8 # 8个聚类
3-8:扩展应用
- 自定义数据集:修改
process_list_autogen.csv
和nlst-foldk.npz
以适应新数据。 - 新骨干网络:在
bcb_mode
中添加自定义模型,需在代码中实现对应的特征处理逻辑。
结束语
本期推文的内容就到这里啦,如果需要获取医学AI领域的最新发展动态,请关注小罗的推送!如需进一步深入研究,获取相关资料,欢迎加入我的知识星球!
相关文章:
Medical Image Nnalysis发表对抗多实例学习框架,基于病理切片进行生存分析
小罗碎碎念 在医学AI领域,全切片图像(WSI)的生存分析对疾病预后评估至关重要。 现有基于WSI的生存分析方法存在局限性,经典生存分析规则使模型只能给出事件发生时间的点估计,缺乏预测稳健性和可解释性;且全…...
Ubuntu20.04部署Dify(Docker方式)
Ubuntu20.04部署Dify(Docker方式) Ubuntu20.04 DifyInstall DockerInstall Docker ComposeRun DifyRunning Ollama 由于写这篇博客的时候电脑还没装输入法,所以先用半吊子英文顶着了…关于最后运行ollama的部分可以无视,因为我修改…...
常见的六种大语言模型微调框架
六大主流微调框架详细解析 框架简介优势劣势Hugging Face PEFT专注于「参数高效微调」(LoRA、Prefix、Prompt-tuning等)的小型库,直接挂在Transformers上用。简单稳定,兼容性好,文档丰富,适配各种小模型到中…...
高精度3D圆弧拟合 (C++)
本文的目的是实现高精度的3D圆弧拟合,若对精度要求不高,可使用PCL的圆拟合接口,参见 PCL拟合空间3D圆周 fit3DCircle-CSDN博客 ---------------------------------------------------------------------------------------------------------…...
WPF定义扩展属性和依赖属性
WPF扩展属性与依赖属性详解 一、依赖属性(Dependency Property)详解 1. 什么是依赖属性? 依赖属性是WPF框架的核心特性之一,它允许属性值依赖于: 父元素的属性值(继承)样式和模板动画数据绑定资源查找2. 依赖属性的特点 属性值继承:子元素可以继承父元素的属性…...
微信小程序 - 根据经纬度打开导航
一、获取到指定的经纬度后 二、设置打开导航 onReady() {this.mapCtx wx.createMapContext(myMap)},openMap() {this.mapCtx.openMapApp({latitude: this.data.latitude,longitude: this.data.longitude,destination: this.data.destination,success: (res) > {console.log…...
WPF实现类似Microsoft Visual Studio2022界面效果及动态生成界面技术
WPF实现类似VS2022界面效果及动态生成界面技术 一、实现类似VS2022界面效果 1. 主窗口布局与主题 <!-- MainWindow.xaml --> <Window x:Class"VsStyleApp.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x…...
驱动开发(1)|鲁班猫rk356x内核编译,及helloworld驱动程序编译
前言 在进行驱动开发或内核定制时,编译内核源码是一个不可或缺的步骤。内核源码不仅为驱动模块的编译提供了必要的构建环境,还确保了驱动与操作系统内核之间的紧密兼容性。随着内核版本的不断更新,内核内部的数据结构、API接口或系统调用可能…...
深入剖析 Vue 组件:从基础到实践
引言 在前端开发领域,Vue.js 以其简洁易用和高效灵活的特点深受开发者喜爱。而 Vue 组件作为 Vue.js 的核心概念之一,是构建大型应用的基石。无论是简单的按钮、表单,还是复杂的页面布局、功能模块,都可以封装成组件,…...
C++武功秘籍 | 入门知识点
目录 0. 前言 1. C的第一个程序 2. 域 2.1 分类 2.2 作用 2.3 命名空间 2.3.1 定义 2.3.2 namespace概念 2.3.3 使用 3. 输入和输出 3.1 3.2 cin 3.3 cout 3.4 endl 4. 缺省参数 4.1 定义 4.2 分类 4.3 特点 5. 函数重载 5.1 定义 5.2 类型分类 5.2.1.参数类型不同 5.2.2. 参数…...
[官方IP] Shift RAM
Xilinx Shift RAM IP (PG122) 详细介绍 概述 Xilinx Shift RAM IP 是 AMD Xilinx 提供的一个 LogiCORE™ IP 核,用于在 FPGA 中实现高效的移位寄存器(Shift Register)。该 IP 核利用 FPGA 的分布式 RAM(Distributed RAM…...
Trae国际版+BrowserTools MCP yyds!!!
这是为您的博客优化的版本,结构更清晰、痛点更突出,并增加了技术细节和用户价值: 📢《告别手动抓狂!Trae国际版BrowserTools MCP 实现前端错误调试自动化》🚀 作为前端开发者,你是否经历过这些…...
Kdenlive 中的变形、畸变、透视相关功能
Kdenlive 中的变形、畸变、透视相关功能 flyfish Kdenlive 是一款开源、跨平台的非线性视频编辑软件,支持 Windows、macOS 和 Linux 系统. 滚动 通常指让画面内容(如字幕、图像)沿特定方向(垂直或水平)滚动显示。 用于…...
蓝桥杯 8. 移动距离
移动距离 原题目链接 题目描述 X 星球居民小区的楼房全是一样的,并且按矩阵样式排列。楼房的编号为 1, 2, 3, ⋯⋯。 当排满一行时,从下一行相邻的楼往反方向排号。 例如,当小区排号宽度为 6 时,排列如下: 1 2 …...
2025.04.26-美团春招笔试题-第三题
📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 03. 树上路径权值递增 问题描述 LYA正在开发一款基于树的图形渲染引擎,她需要实现一种特殊的路径增强效果。在这个效果中,她需要沿着树上的简单路径为节点赋予递增的权值增益。 …...
c++_csp-j算法 (5)
动态规划 介绍 动态规划(Dynamic Programming)是一种常用的解决优化问题的算法设计技术,常用于解决具有重叠子问题和最优子结构性质的问题。动态规划算法通过将问题划分为子问题,解决子问题并将子问题的解保存起来,最终构建出原问题的解。在本节中,我们将详细介绍动态规…...
力扣2444. 统计定界子数组的数目:Java三种解法详解
力扣2444. 统计定界子数组的数目:Java三种解法详解 题目描述 给定整数数组 nums 和两个整数 minK 和 maxK,统计满足以下条件的子数组数目: 子数组的最小值等于 minK;子数组的最大值等于 maxK。 示例: 输入…...
安全生产知识竞赛宣传口号160句
1. 安全生产是责任,每个人都有责任 2. 安全生产是保障,让我们远离危险 3. 安全生产是团结,共同守护每一天 4. 注重安全,守护明天 5. 安全生产无小事,关乎千家万户 6. 安全第一,人人有责 7. 安全生产无差别&…...
【Hive入门】Hive动态分区与静态分区:使用场景与性能对比完全指南
目录 1 Hive分区技术概述 2 静态分区详解 2.1 静态分区工作原理 2.2 使用场景 2.3 示例 3 动态分区深度解析 3.1 动态分区执行流程 3.2 使用场景 3.3 示例 4 使用场景对比 4.1 场景选择 5 性能对比与优化 5.1 插入性能 5.2 查询性能 5.3 小文件问题 6 最佳实践 6.1 混合分区策略…...
6.1腾讯技术岗2025面试趋势前瞻:大模型、云原生与安全隐私新动向
2025年腾讯技术岗面试趋势前瞻:大模型、云原生与安全隐私新动向 随着AI技术与云计算的深度融合,腾讯校招技术岗面试正呈现出三大核心趋势:AI大模型应用深化、云原生技术迭代加速、安全隐私技术刚需化。本文结合腾讯2025年最新技术布局&#…...
探秘卷积神经网络:深度学习的图像识别利器
在深度学习领域,卷积神经网络(Convolutional Neural Networks,CNN)是图像识别任务的关键技术。它的起源可以追溯到 20 世纪 80 - 90 年代,但受限于当时的软硬件条件,其发展一度停滞。随着深度学习理论的不断…...
x修改ssh版本号9.9可以躲过漏洞扫描器扫描
1. 查看当前系统的ssh版本号 ssh -V sshd -V 2. 查看ssh和sshd的位置 which ssh which sshd3. 查看ssh版本号有关的字符串 strings /usr/bin/ssh | grep OpenSSH strings /usr/sbin/sshd | grep OpenSSH4. 备份 cp /usr/bin/ssh /usr/bin/ssh.bak cp /usr/sbin/s…...
django之账号管理功能
账号管理功能 目录 1.账号管理页面 2.新增账号 3.修改账号 4.账号重置密码 5.删除账号功能 6.所有代码展示集合 7.运行结果 这一片文章, 我们需要新增账号管理功能, 今天我们写到的代码, 基本上都是用到以前所过的知识, 不过也有需要注意的细节。 一、账号管理界面 …...
Java24 抗量子加密:后量子时代的安全基石
一、量子计算威胁与 Java 的应对 随着量子计算机的快速发展,传统加密算法面临前所未有的挑战。Shor 算法可在多项式时间内破解 RSA、ECC 等公钥加密体系,而 Grover 算法能将对称加密的暴力破解效率提升至平方根级别。据 NIST 预测,具备实用价…...
ssm乡村合作社商贸网站设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
摘要 当今社会进入了科技进步、经济社会快速发展的新时代。国际信息和学术交流也不断加强,计算机技术对经济社会发展和人民生活改善的影响也日益突出,人类的生存和思考方式也产生了变化。传统乡村合作社商贸管理采取了人工的管理方法,但这种…...
多线程(1)——认识线程
目录 概念线程是什么为什么要有线程进程和线程的区别Java的线程 和 操作系统线程 的关系 创建线程方法1:继承Thread 类run和start方法 方法2:实现Runnable 接口方法1和方法2的区别 方法3:通过匿名内部类继承Thread方法4:通过匿名内…...
CSS3布局方式介绍
CSS3布局方式介绍 CSS3布局(Layout)系统是现代网页设计中用于构建页面结构和控制元素排列的一组强大工具。CSS3提供了多种布局方式,每种方式都有其适用场景,其中最常用的是Flexbox和CSS Grid。 先看传统上几种布局方式ÿ…...
4.换行和续写
一.FileOutputStream写出数据的两个小问题: 问题一:换行 假设在本地文件中要输出数据aweihaoshuai 666,在输出这个数据时要换行写出,如下图: 问题二:续写 假设在一个文本文件中已经存在数据aweihaoshuai…...
【数据结构与算法】从完全二叉树到堆再到优先队列
完全二叉树 CBT 设二叉树的深度为 h , 若非最底层的其他各层的节点数都达到最大个数 , 最底层 h 的所有节点都连续集中在左侧的二叉树叫做 完全二叉树 . 特点 对任意节点 , 其右分支下的叶子节点的最底层为 L , 则其左分支下的叶子节点的最低层一定是 L 或 L 1 .完全二叉树…...
冯·诺依曼与哈佛架构CPU的时序对比
以下是哈佛架构与冯诺依曼架构的时序对比及具体芯片实现案例的详细解析: 一、时序波形对比 1. 冯诺依曼架构时序 典型操作流程(读取指令后读取数据) 时钟周期 | 操作步骤 ---------------------------------------- T1 | 地址总线发送指令地址 T2 | 存储器通过…...
【漫话机器学习系列】225.张量(Tensors)
深度学习中的张量(Tensor)到底是什么?一文彻底讲清楚! 在机器学习和深度学习领域,无论是使用 TensorFlow、PyTorch 还是其他框架,我们都会频繁遇到一个术语:张量(Tensor)…...
前端开发中列表无限加载功能的实现与优化
在如今的 Web 应用开发中,为了给用户提供更加流畅、高效的体验,许多应用都会采用列表无限加载的技术,比如常见的社交媒体动态列表、电商商品列表等。 下面,我将结合实际项目,详细介绍列表无限加载功能的实现过程。 一…...
搜广推校招面经八十二
一、L1 和 L2 正则化的区别?对数据分布有什么要求,它们都能防止过拟合吗? 1.1. L1 与 L2 正则化的区别 特性L1 正则化(Lasso)L2 正则化(Ridge)正则项λ * ∑|wᵢ| λ ∗ ∑ ( w i 2 ) λ * ∑…...
机器学习——朴素贝叶斯法运用
一、朴素贝叶斯法 1.1 基本概念 朴素贝叶斯法是一种基于贝叶斯定理的简单概率分类方法,它假设特征之间相互独立。它适用于分类问题,尤其是在文本分类中表现良好。其核心思想是通过考虑各个特征的概率来预测分类(即对于给出的待分类样本&am…...
内存池管理项目——面试题总结
一.项目描述 项⽬概述:本项⽬通过实现⾸次拟合法和伙伴系统算法,完成对内存池的管理,旨在为程序提供⾼效、合理的内存分配与回收机制,优化内存使⽤效 率。 主要内容及技术: ⾸次拟合法实现:定义WORD结构体…...
基于Python+Neo4j实现新冠信息挖掘系统
软件说明书 一、引言 便携本使用说明的目的是充分叙述本软件所能实现的功能及运行环境,以便使用者了解本软件的使用范围和使用方法,并为软件的维护和更新提供必要的信息。 二、软件概述 2.1软件简介 新型冠状病毒肺炎肆虐全球,给人们的健…...
深入浅出理解并应用自然语言处理(NLP)中的 Transformer 模型
1 引言 随着信息技术的飞速发展,自然语言处理(Natural Language Processing, NLP)作为人工智能领域的一个重要分支,已经取得了长足的进步。从早期基于规则的方法到如今的深度学习技术,NLP 正在以前所未有的速度改变着我…...
AEB法规升级后的市场预测与分析:技术迭代、政策驱动与产业变革
文章目录 一、政策驱动:全球法规升级倒逼市场扩容二、技术迭代:从“基础防护”到“场景全覆盖”三、市场格局:竞争加剧与生态重构四、挑战与未来展望五、投资建议结语 近年来,全球汽车安全法规的加速升级正深刻重塑AEB(…...
《代码之美:静态分析工具与 CI 集成详解》
《代码之美:静态分析工具与 CI 集成详解》 引言 在现代软件开发的快节奏环境中,代码质量和效率始终是开发者关注的核心。无论您是初学者,还是经验丰富的资深开发者,一个强大的工具链都能让您如虎添翼。而 Python 的静态代码分析工具,如 pylint、flake8 和 mypy,正是提升…...
Adobe Photoshop(PS)2022 版安装与下载教程
Adobe Photoshop下载安装和使用教程 Adobe Photoshop,简称“PS”,是由Adobe Systems开发和发行的图像处理软件。Photoshop主要处理以像素所构成的数字图像。使用其众多的编修与绘图工具,可以有效地进行图片编辑和创造工作,…...
Universal Value Function Approximators 论文阅读(强化学习,迁移?)
前言 Universal Value Function Approximators 个人实现(请大佬指正) *关于UVFA如何迁移的问题,这也是我为什么反复看这篇文章的原因,我觉值函数逼近的最大用法就是如何迁移,如果仅仅是更改值函数的结构,…...
论文阅读:2024 arxiv HybridFlow: A Flexible and Efficient RLHF Framework
https://www.doubao.com/chat/3875396379023618 HybridFlow: A Flexible and Efficient RLHF Framework https://arxiv.org/pdf/2409.19256 https://github.com/volcengine/verl 速览 这篇论文主要介绍了一个名为HybridFlow的新型框架,旨在提升大语言模型&…...
WPF实现多语言切换
WPF实现多语言切换完整指南 一、基础实现方案 1. 资源文件准备 首先创建不同语言的资源文件: Resources/ ├── Strings.resx // 默认语言(英语) ├── Strings.zh-CN.resx // 简体中文 └── Strings.ja-JP.resx // 日语 Strings.resx (默认英…...
wpf操作主流数据
WPF 操作主流数据库详解 WPF(Windows Presentation Foundation)应用程序经常需要与数据库交互以实现数据的持久化和展示。主流的关系型数据库包括 SQL Server、MySQL、PostgreSQL 和 SQLite。本文将详细介绍如何在 WPF 应用程序中使用这些主…...
Docker Compose--在Ubuntu中安装Docker compose
原文网址:Docker Compose--在Ubuntu中安装Docker compose_IT利刃出鞘的博客-CSDN博客 简介 说明 本文介绍如何在Ubuntu中安装docker compose。 docker-compose是用于管理Docker的,相对于单纯使用Docker更方便、更强大。 如果还没安装docker…...
推荐几个免费提取音视频文案的工具(SRT格式、通义千问、飞书妙记、VideoCaptioner、AsrTools)
文章目录 1. 前言2. SRT格式2.1 SRT 格式的特点2.2 SRT 文件的组成2.3 SRT 文件示例 3. 通义千问3.1 官网3.2 上传音视频文件3.3 导出文案 4. 飞书妙记4.1 官网4.2 上传音视频文件4.3 导出文案4.4 缺点 5. VideoCaptioner5.1 GitHub地址5.2 下载5.2.1 通过GitHub下载5.2.2 通过…...
驱动汽车供应链数字化转型的标杆解决方案:全星研发项目管理APQP软件系统:
全星研发项目管理APQP软件系统:驱动汽车供应链数字化转型的标杆解决方案 一、行业痛点与转型迫切性 在汽车行业电动化、智能化浪潮下,主机厂对供应链企业的APQP(先期产品质量策划)合规性、开发效率及体系化管理能力提出严苛要求。…...
PyTorch数据加载与预处理
数据加载与预处理详解 1. 数据集类(Dataset和DataLoader) 1.1 Dataset基类 PyTorch中的Dataset是一个抽象类,所有自定义的数据集都应该继承这个类,并实现以下两个方法: __len__(): 返回数据集的大小__getitem__(): 根据索引返回一个样本 …...
MyBatis 官方子项目详细说明及表格总结
MyBatis 官方子项目详细说明及表格总结 1. 核心子项目说明 1.1 mybatis-3 GitHub 链接:https://github.com/mybatis/mybatis-3功能: MyBatis 核心框架的源码,提供 SQL 映射、动态 SQL、缓存、事务管理等核心功能。主要功能: 支持…...
Java学习手册:常用的内置工具类包
以下是常用 Java 内置工具包。 • 日期时间处理工具包 • java.time包(JSR 310):这是 Java 8 引入的一套全新的日期时间 API,旨在替代陈旧的java.util.Date和java.util.Calendar类。其中的LocalDate用于表示不带时区的日期&…...