2024年认证杯SPSSPRO杯数学建模B题(第二阶段)神经外科手术的定位与导航全过程文档及程序

2024年认证杯SPSSPRO杯数学建模

B题 神经外科手术的定位与导航

原题再现:

  人的大脑结构非常复杂,内部交织密布着神经和血管,所以在大脑内做手术具有非常高的精细和复杂程度。例如神经外科的肿瘤切除手术或血肿清除手术,通常需要将颅骨打开一个(或几个)圆形窗口,将病变部位暴露在术野中。但当病变部位较深时,就必须将上方的脑组织进行一定程度的牵拉、移位。这种牵拉和移位的幅度不能太大,而且具有损伤脑组织的风险。所以医生需要仔细设计手术方案,才能在尽量减小损伤的前提下完成手术目标。现在有CT或核磁共振等成像手段可以对颅内区域进行准确的透视和三维定位。但是在打开颅骨后,由于打开部位的颅骨约束作用消失,而且脑组织是柔软的,所以脑组织会产生一定程度的变形、移位,甚至在一定程度上膨出,以至于病变部位的位置发生了改变。如果想要在术中实时进行透视和定位,需要复杂的设备,术者也需经过特殊的训练,这都使得此类手术尚未完全普及。所以我们需要设计一个合理的数学模型,较为精细地预测手术部位在开颅后的位置改变情况。我们一定能够取得的数据是:
  1. 术前的CT成像结果,这包含了颅腔的三维形状以及手术部位在三维空间中的位置(在建模时可自行寻找并使用典型的颅脑CT成像数据);
  2. 术前的颅内压;
  3. 在颅骨上打开的窗口的大小以及位置;
  4. 开颅后在颅骨窗口处可观察到的脑组织膨出高度(通常以mm计);
  5. 在术前可以测量得到的其他生理指标。
  请你和你的团队建立合理的数学模型以解决下列问题。
  第二阶段问题:
  1. 假设患者的大脑中有一硬质占位性病变,我们通过术前的CT成像结果可以准确地知道它的位置。在术中可以测得颅内压。请尽可能精细地计算该占位性病变在开颅后的位移情况。
  2. 假设患者的大脑中有一血肿区域(内容物为液态血液)。我们通过术前的CT成像结果可以准确地知道它的位置。在术中可以测得颅内压。请尽可能精细地计算该血肿在开颅后的位移和可能的形变情况。

整体求解过程概述(摘要)

  神经外科手术,特别是涉及脑内深部病灶的手术,如肿瘤切除或血肿清除,面临着极高的技术挑战。这类手术要求在保护正常脑组织不受损伤的同时,精准定位并处理病灶。然而,开颅操作会导致颅内压变化,进而使脑组织发生难以预测的位移,影响术中病变位置的准确性,增加了手术难度和风险。为应对这一挑战,本文旨在通过综合考虑CT 图像、手术切口位置、脑组织力学特性、颅内压变化等因素,通过构建人工智能模型预测开颅后脑组织的位移情况。本文没有使用传统的有限元方法建模,有限元建模计算资源需求高、时间消耗长、非专业用户友好性极差,限制了其在临床环境中的广泛应用。而基于迁移学习的预训练-微调模型解决了这些问题,通过预先训练的模型共享参数后进行微调,极大的降低了运算资源以及数据需求量,对小样本问题友好;不需要丰富专业知识进行复杂物理建模分析,更好地服务于临床决策和手术规划。
  我们分析了人工智能在医学图像领域的工作以及预测可行性,根据上述思想设计了通用医学影像预训练-微调模型,首先通过特征工程对105个特征进行处理,使用person相关系进行分析,通过向预训练模块输入颅脑等器官CT影像数据,使模型学习医学影像通用信息,共享预训练模块学习到的通用参数,再向模型输入少量肿瘤位移前后影像信息以及临床文本信息进行微调,使模型学习到更有针对性的细节信息。最后通过神经网络,输出目标转移到大脑某区域位置概率。
  问题一,首先利用获取的CT图像获取占位性病变的精确尺寸、位置、形状以及与周围脑组织的关系,进行三维重建。对物理属性参数,如脑组织物理特性,粘弹性、颅内压、骨窗大小等特性进行分析,模拟硬质占位性病变位移范围,划定颅脑范围作为计算的输入参数。最后,通过医学影像预训练-微调模型预测位移概率。
  问题二,血肿与问题一中的硬质占位性病变不同,可以简单理解为固体与液体的区别,我们通过分析液体动力学、固体力学以及脑组织的非线性弹性行为,分析了血肿在开颅手术后的位移和形变。根据脑组织的力学属性和血肿的流体力学属性设计了新的损失函数。通过修改微调信息,来预测血肿在开颅后的位移和形变。
  最后,理想的神经外科手术导航系统应具备以下特点:提供高分辨率的实时影像引导,能够适应脑组织的动态变化,拥有精确的术中定位能力,并且便于外科医生操作,减少手术时间和并发症。随着计算机科学、图像处理技术、机器学习以及生物力学模型的不断进步,未来的神经外科手术有望实现更加个性化、精准的治疗方案,提高手术成功率并降低患者风险。

问题分析:

  在分析本题的过程中我们注意到,整个脑部组织及其他人体特征的多样性。首先在题目中提到的数据,如表一所示。
在这里插入图片描述
  针对数据问题:在Github的医学影像数据集集锦仓库1中,我们获得了具有各类模态以及各类器官约20个方向的80+个数据集。通过筛选选择了105个与本问题相关的参数,并且根据脑组的粘弹性等物理特性,开颅位置、大小以及膨出高度进行了数据模拟。
  针对问题一:在各类器官影像数据量大,而相关肿瘤开颅位移影像数据量稀少的情况下,我们将颅内组织位置通过使用迁移学习的思路,利用人工智能的方法对硬质占位性病变在开颅后的位移情况进行预测。首先采取迁移学习中经典的预训练-微调模型,通过向预训练模块输入大量各种器官的CT影像数据,使预训练模块学习与CT影像相关的大量通用信息;其次,根据(Schirmer,Gieseetal.2019)的文章我们将全脑划分为10个不同的位置,我们将少量的包含肿瘤位移前后信息的三维数据以及文本信息数据,输入到模型中进行微调;最后,模型输出硬质占位性病变转移位置的概率,通过联合损失函数,留一交叉验证对测试数据进行验证,用ACC、F1分数、HausdorffDistance(豪斯多夫距离)对模型进行评估。
  针对问题二:据脑组织的力学属性和血肿的流体力学属性,我们在问题一的基础上,仍然使用迁移学习进行预训练微调的方法,进行血肿位移和形变预测。在预训练模块不需要做任何改动,直接调用预训练模块的通用参数即可,对于微调模块,我们根据血肿的特性,通过分析液体动力学、固体力学以及脑组织的非线性弹性行为,设计了新的综合损失函数。最后通过模型预测血肿在开颅大致的位移和形变。根据已有的有限数据,我们可以通过计算机视觉模型来辅助判断出病变的类型。脑组织具有独特的生物力学特性,其中包括各向异性和粘弹性[1],这些特性对脑部病变的诊断和研究至关重要。各向异性指的是脑组织在不同方向上的力学性能不同,而粘弹性则描述了脑组织在应力作用下的变形行为及其时间依赖性。通过对这些生物力学特性的分析和计算,我们可以粗略估计出肿瘤的位置偏移。
  为了进一步提升预测的准确性和模型的泛化能力,我们采用迁移学习的方法。迁移学习是一种将已有知识应用到新的但相关问题上的技术。具体来说,我们使用目前已有关于出血性脑卒中的研究成果作为迁移学习的基础数据。这些研究成果包括大量的原始数据,这些数据经过充分的标注和分析,能够为我们的模型提供强大的先验知识基础。通过使用这些出血性脑卒中的原始数据,我们能够训练一个初始模型,该模型可以实现对血肿及水肿位置的预测。在此基础上,我们进一步将脑中病变及生理数据输入该模型,并对其进行微调。这一过程称为模型的微调(fine-tuning),旨在使模型更好地适应新的特定任务,从而提高其预测精度。通过这种方式,我们能够实现对病变位移的准确预测,为临床诊断和治疗提供有力的辅助工具。这一系列步骤展示了计算机视觉技术在医学影像分析中的巨大潜力,特别是在复杂脑部病变的诊断和治疗方面。

模型假设:

   假设获取的全部数据是准确无误的;
   假设脑组织的特性符合粘弹性这一材料属性的各项指标;
   假设颅骨内各个关联组织之间无相对运动;
   假设正常脑组织和病变组织均质地均匀;
   假设忽略脑中的微观结构;
   假设开颅过程是理想情况,一切操作均符合相关规范要求。

完整论文缩略图

在这里插入图片描述
在这里插入图片描述

全部论文及代码请见下方“ 只会建模 QQ名片” 点击QQ名片即可

部分程序代码:

import os
import torch
import torchvision as tv
import torchvision.transforms as transforms
import torch.nn as nn
import torch.optim as optim
import argparse
import skimage.data
import skimage.io
import skimage.transform
import numpy as np
import matplotlib.pyplot as plt
import torchvision.models as models
from PIL import Image
import cv2#提取某一层网络特征图
class FeatureExtractor(nn.Module):def __init__(self, submodule, extracted_layers):super(FeatureExtractor, self).__init__()self.submodule = submoduleself.extracted_layers = extracted_layersdef forward(self, x):outputs = {}for name, module in self.submodule._modules.items():if "fc" in name:x = x.view(x.size(0), -1)x = module(x)print(name)if (self.extracted_layers is None) or (name in self.extracted_layers and 'fc' not in name):outputs[name] = x# print(outputs)return outputsdef get_picture(pic_name, transform):img = skimage.io.imread(pic_name)img = skimage.transform.resize(img, (256, 256)) #读入图片时将图片resize成(256,256)的img = np.asarray(img, dtype=np.float32)return transform(img)def make_dirs(path):if os.path.exists(path) is False:os.makedirs(path)pic_dir = 'dataset/brain/train/1700.jpg'
transform = transforms.ToTensor()
img = get_picture(pic_dir, transform)
# 插入维度
img = img.unsqueeze(0)device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
img = img.to(device)net = models.resnet101(pretrained=True).to(device)dst = './feautures'
therd_size = 256myexactor = FeatureExtractor(submodule=net, extracted_layers=None)
output = myexactor(img)
#output是dict
#dict_keys(['conv1', 'bn1', 'relu', 'maxpool', 'layer1', 'layer2', 'layer3', 'layer4', 'avgpool', 'fc'])for idx,val in enumerate(output.items()):k,v = valfeatures = v[0]iter_range = features.shape[0]for i in range(iter_range):# plt.imshow(features.data.cpu().numpy()[i,:,:],cmap='jet')if 'fc' in k:  #不可视化fc层continuefeature = features.data.cpu().numpy()feature_img = feature[i, :, :]feature_img = np.asarray(feature_img * 255, dtype=np.uint8)dst_path = os.path.join(dst, str(idx)+'-'+k)make_dirs(dst_path)feature_img = cv2.applyColorMap(feature_img, cv2.COLORMAP_JET)if feature_img.shape[0] < therd_size:tmp_file = os.path.join(dst_path, str(i) + '_' + str(therd_size) + '.png')tmp_img = feature_img.copy()tmp_img = cv2.resize(tmp_img, (therd_size, therd_size), interpolation=cv2.INTER_NEAREST)cv2.imwrite(tmp_file, tmp_img)dst_file = os.path.join(dst_path, str(i) + '.png')cv2.imwrite(dst_file, feature_img)
全部论文及代码请见下方“ 只会建模 QQ名片” 点击QQ名片即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/73316.shtml

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

相关文章

尝试在软考62天前开始成为软件设计师-信息系统安全

安全属性 保密性:最小授权原则(能干活的最小权限)、防暴露(隐藏)、信息加密、物理保密完整性(防篡改):安全协议、校验码、密码校验、数字签名、公证 可用性:综合保障( IP过滤、业务流控制、路由选择控制、审计跟踪)不可抵赖性:数字签名 对称加密 DES :替换移位 3重DESAESR…

Rocky9.5基于sealos快速部署k8s集群

首先需要下载 Sealos 命令行工具&#xff0c;sealos 是一个简单的 Golang 二进制文件&#xff0c;可以安装在大多数 Linux 操作系统中。 以下是一些基本的安装要求&#xff1a; 每个集群节点应该有不同的主机名。主机名不要带下划线。 所有节点的时间需要同步。 需要在 K8s …

G口服务器和普通服务器之间的区别

今天小编主要来为大家介绍一下G口服务器和普通服务器之间的区别&#xff01; 首先&#xff0c;从硬件配置上看&#xff0c;普通服务器通常都会配备中央处理器、内存和硬盘等基本的硬件配置&#xff0c;能够适用于各种应用程序和服务&#xff1b;G口服务器除了基础的硬件配置还增…

Cursor软件如何刷新机器码流程

一.退出Cursor软件账号 打开Cursor软件&#xff0c;点击设置-->General-->Account-->Log out,现将Cursor软件上登录的账户退出。 二.将Cursor官网上登录的Cursor账户也清空掉 点击头像--> ACCOUNT SETTINGS -->Account-->Advanced-->Delete Account-->…

类与对象(中)(详解)

【本节目标】 1. 类的6个默认成员函数 2. 构造函数 3. 析构函数 4. 拷贝构造函数 5. 赋值运算符重载 6. const成员函数 7. 取地址及const取地址操作符重载 1.类的6个默认成员函数 如果一个类中什么成员都没有&#xff0c;简称为空类。 空类中真的什么都没有吗&…

开发语言漫谈-groovy

groovy是一门脚本语言&#xff0c;在前期的脚本语言中简单介绍了下。现在再深入介绍下&#xff0c;因为它是本平台上选用的脚本语言。所谓脚本语言就是不用编译&#xff0c;直接执行。这种特色非常适合做嵌入编程&#xff0c;即编即用。我们知道平台后台的业务开发语言是Java&a…

React+Ant Design的Layout布局实现暗黑模式切换

目录 效果预览完整代码我遇到的BUG问题代码BUG1&#xff1a;暗黑模式下内容区不变成深色BUG2&#xff1a;光亮模式下的左右区域是深色 补充知识ConfigProvider是什么&#xff1f;Ant Design中的theme如何使用&#xff1f;theme 配置的常见字段主题算法通过 useToken 获取主题 效…

TCP 三次握手与四次挥手过程

TCP 作为一种面向连接的、可靠的传输层协议&#xff0c;其连接管理机制对于保障数据的可靠传输至关重要。 三次握手&#xff08;建立连接&#xff09; 三次握手是 TCP 建立连接时所采用的机制&#xff0c;其目的在于确保客户端和服务器双方都具备发送和接收数据的能力&#x…

【线程安全的单例模式和STL是否是线程安全/智能指针是否是线程安全】

文章目录 一、单例模式的特点二、饿汉模式实现单例三、懒汉模式实现单例四、STL线程安全吗&#xff1f;五、智能指针线程安全吗&#xff1f; 一、单例模式的特点 一个类&#xff0c;只应该实例化了一个对象&#xff0c;就是单例。 二、饿汉模式实现单例 举个饿汉模式的例子&…

力扣DAY24 | 热100 | 回文链表

前言 简单 √ 是反转链表的衍生题&#xff0c;很快写完了。不过没考虑到恢复链表结构的问题。 题目 给你一个单链表的头节点 head &#xff0c;请你判断该链表是否为回文链表。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 示例 1&#xff1a; 输…

【GL010】C++

1.C中的const关键字有哪些用法&#xff1f; 1.修饰变量&#xff1a;表示变量的值不可修改。 const int a 10; 2.修饰指针&#xff1a; const int* p&#xff1a; // 指针指向的内容不可修改。 int* const p&#xff1a; // 指针本身不可修改。 const int* const…

金融行业 UE/UI 设计:解锁高效体验,重塑行业界面

在数字化浪潮中&#xff0c;金融行业的竞争日益激烈&#xff0c;用户体验&#xff08;UE&#xff09;和用户界面&#xff08;UI&#xff09;设计成为企业脱颖而出的关键。兰亭妙微凭借丰富的经验和创新的方法&#xff0c;为金融行业打造了一套行之有效的 UE/UI 解决方案&#x…

C语言字符函数,字符串函数以及内存函数

那么博主写这一片博客的目的就是为下一篇c的string类做铺垫&#xff0c;那么下面就请期待博主的下一篇文章吧。 目录 1.字符函数 2.字符串函数&#xff08;均在string.h头文件中&#xff09; strlen的使用和模拟实现 strcpy 的使用和模拟实现 strcat 的使用和模拟实现 s…

_DISPATCHER_HEADER结构中的WaitListHead和_KWAIT_BLOCK的关系

第一部分&#xff1a; // // Wait block // // begin_ntddk begin_wdm begin_nthal begin_ntifs begin_ntosp typedef struct _KWAIT_BLOCK { LIST_ENTRY WaitListEntry; struct _KTHREAD *RESTRICTED_POINTER Thread; PVOID Object; struct _KWAIT_BLOCK *R…

flutter 自定义控件RenderObjectWidget使用

CustomWidget的自定义组件的注释还是比较清晰的 参考文档Flutter实战 import package:flutter/cupertino.dart; import package:flutter/gestures.dart; import package:flutter/material.dart; /* * 如果组件不会包含子组件&#xff0c;则我们可以直接继承自 LeafRenderObject…

机器视觉场景应用中,有没有超景深的工业镜头

在机器视觉领域,确实存在具有超景深特性的工业镜头,这类镜头通过特殊的光学设计或技术手段,能够显著扩大清晰成像的纵向范围,从而满足复杂检测场景中对多平面物体清晰成像的需求。以下是相关技术要点及典型镜头类型: 1. 远心镜头 远心镜头是超景深镜头的典型代表,其特点包…

【Linux】同步原理剖析及模拟BlockQueue生产消费模型

&#x1f4e2;博客主页&#xff1a;https://blog.csdn.net/2301_779549673 &#x1f4e2;博客仓库&#xff1a;https://gitee.com/JohnKingW/linux_test/tree/master/lesson &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01; &…

光流 | 基于KLT算法的人脸检测与跟踪原理及公式,算法改进,matlab代码

===================================================== github:https://github.com/MichaelBeechan CSDN:https://blog.csdn.net/u011344545 ===================================================== 人脸检测与跟踪 一、KLT算法原理与分析1. 核心思想2. 数学模型二、人脸…

<数据集>轨道异物识别数据集<目标检测>

数据集下载链接&#xff1a;https://download.csdn.net/download/qq_53332949/90527370 数据集格式&#xff1a;VOCYOLO格式 图片数量&#xff1a;1659张 标注数量(xml文件个数)&#xff1a;1659 标注数量(txt文件个数)&#xff1a;1659 标注类别数&#xff1a;6 标注类别…

LabVIEW液压振动锤控制系统

在现代工程机械领域&#xff0c;液压振动锤的高效与精准控制日益显得重要。本文通过LabVIEW软件&#xff0c;展开液压振动锤启停共振控制技术的研究与应用&#xff0c;探讨如何通过改进控制系统来优化液压振动锤的工作性能&#xff0c;确保其在复杂工况下的稳定性与效率。 ​ …