作者:陈华荣,邱见明,孟一聪,本文获全国一等奖 血管的三维重建 摘要 本文针对医学中的经常遇到的三维图象重新组合这样一个典型问题进行分析与建模 对于本题三维血管重建这个实际问题,我们提出了四种不同的数学模型一重叠相加 法,断层扫描法,切线计算法和空间向量法。 重叠相加法是最简单的,其计算非常快,但它的成立需要一定的条件,如血管在空 间往ⅹOY的投影不能有重叠的地方,并且血管的半径必须相等等 断层扫描法直观明了,它实际上是应用计算机断层扫描技术。在对一个未知物体的 扫描时,非常有用,它已被大量用于实际的医疗技术中,可以得到物体内外部的特 征 ●切线计算法有一定的依据,该方法求直径较为准确而且计算也相对简单。 空间向量法是较为精确的一种方法,只要给出的图像的像点尽可能的多,从而可以 很精确的确定每一点的法线从而知道血管的半径和中心轴的坐标。而且它可以不受 太多的约束条件的限制,是一种很好的方法。 在数据的处理中由于题目给出的是数字图象,在处理过程中,将遇到图象像点不连续的 情况,因此我们应用了极大似然估计法和近似准则,抛弃了一些误差很大的点。根据空间向 量法得到的血管半径为29483,中心轴线近似为一条空间光滑曲线。最后,还给出一个检验 模型,用以比较根据计算所得的中心轴线和半径而恢复的血管与题目所给的血管图形的差 别 第1页〔共14页〕
第1页 共14页 作者:陈华荣 , 邱见明 , 孟一聪 , 本文获全国一等奖 血管的三维重建 摘 要 本文针对医学中的经常遇到的三维图象重新组合这样一个典型问题进行分析与建模 对于本题三维血管重建这个实际问题 我们提出了四种不同的数学模型 重叠相加 法 断层扫描法 切线计算法和空间向量法 l 重叠相加法是最简单的 其计算非常快 但它的成立需要一定的条件 如血管在空 间往 XOY 的投影不能有重叠的地方 并且血管的半径必须相等等 l 断层扫描法直观明了 它实际上是应用计算机断层扫描技术 在对一个未知物体的 扫描时 非常有用 它已被大量用于实际的医疗技术中 可以得到物体内外部的特 征 l 切线计算法有一定的依据 该方法求直径较为准确而且计算也相对简单 l 空间向量法是较为精确的一种方法 只要给出的图像的像点尽可能的多 从而可以 很精确的确定每一点的法线从而知道血管的半径和中心轴的坐标 而且它可以不受 太多的约束条件的限制 是一种很好的方法 在数据的处理中由于题目给出的是数字图象 在处理过程中 将遇到图象像点不连续的 情况 因此我们应用了极大似然估计法和近似准则 抛弃了一些误差很大的点 根据空间向 量法得到的血管半径为 29.483 中心轴线近似为一条空间光滑曲线 最后 还给出一个检验 模型 用以比较根据计算所得的中心轴线和半径而恢复的血管与题目所给的血管图形的差 别
问题提出 断面可用于了解生物组织、器官等的形态。如果用切片机连续不断地将样本切成数十、成百的平行 切片,可依次逐片观察。根据拍照并采样得到的平行切片数字图像,运用计算机可重建组织、器官等准 确的三维形态 假设某些血管可视为一类特殊的管道,该管道的表面是由球心沿着某一曲线的球滚动包络而成。现 有某管道的相继100张平行切片图像,记录了管道与切片的交。图像文件名依次为0.bmp、1.bmp、 99.bmp,格式均为BMP,宽、高均为512个象素( pixel)。并假设:管道中轴线与每张切片有且只有 个交点;球半径固定:切片间距以及图像象素的尺寸均为1 取坐标系的Z轴垂直于切片,第1张切片为平面Z=0,第100张切片为平面Z=99Z=z切片图像中象 素的坐标依它们在文件中出现的前后次序为 (-256 z),(-256,-255,z), 255,z), z),(-255,-255,z),“( 255 (255,-256,z),(255,-255,z),…(255,255,z) 试计算管道的中轴线与半径,给出具体的算法,并绘制中轴线在XY、YZ、ZX平面的投影图 二、问题分析 依题意,血管可以看作是一个半径为R的小球沿着一定的轨道在行进过程中所覆盖的所有体积。这 样球心轨迹实际就是中心轴线。小球半径就是 血管半径 而在给出的切面图形中,显然切面的最外 的黑 色曲线一定为血管壁的投影,而中间的部分则 可能为血 管壁或为血管内部的投影。在题目中,我们还 有一个重 要的信息:管道中轴线与每张切片有且只有一 个交点。 这将限制了血管的在空间的大致分布情况。 因此,本题的关键在于抓住100幅切片图 像 利用数学手段,将每一切片上有且仅有的与中 心轴线的 个交点找到,再通过插值等方法得到中心轴线与半径,从而完成血管等三维重建。 模型假设与符号说明 1.模型假设 ●在已给的图形中,由于其为象素点,每一点并非无限小,而只为整数坐标。故在解题时紧挨曲 线的整数象点近似为曲线上的点 ●由于象素点为整数,故考虑血管的切面时,紧挨着的四个点所构成的平面,近似看成是该点的 切面。 第2页〔共14页
第2页 共14页 一 问题提出 断面可用于了解生物组织 器官等的形态 如果用切片机连续不断地将样本切成数十 成百的平行 切片 可依次逐片观察 根据拍照并采样得到的平行切片数字图像 运用计算机可重建组织 器官等准 确的三维形态 假设某些血管可视为一类特殊的管道 该管道的表面是由球心沿着某一曲线的球滚动包络而成 现 有某管道的相继 100 张平行切片图像 记录了管道与切片的交 图像文件名依次为 0.bmp 1.bmp 99.bmp 格式均为 BMP 宽 高均为 512 个象素 pixel 并假设 管道中轴线与每张切片有且只有一 个交点 球半径固定 切片间距以及图像象素的尺寸均为 1 取坐标系的 Z 轴垂直于切片 第 1 张切片为平面 Z=0 第 100 张切片为平面 Z=99 Z=z 切片图像中象 素的坐标依它们在文件中出现的前后次序为 -256 -256 z -256 -255 z -256 255 z -255 -256 z -255 -255 z -255 255 z 255 -256 z 255 -255 z 255 255 z 试计算管道的中轴线与半径 给出具体的算法 并绘制中轴线在 XY YZ ZX 平面的投影图 二 问题分析 依题意 血管可以看作是一个半径为 R 的小球沿着一定的轨道在行进过程中所覆盖的所有体积 这 样球心轨迹实际就是中心轴线 小球半径就是 血管半径 R 而在给出的切面图形中 显然切面的最外 的 黑 色曲线一定为血管壁的投影 而中间的部分则 可能为血 管壁或为血管内部的投影 在题目中 我们还 有一个重 要的信息 管道中轴线与每张切片有且只有一 个交点 这将限制了血管的在空间的大致分布情况 因此 本题的关键在于抓住 100 幅切片图 像 利用数学手段 将每一切片上有且仅有的与中 心轴线的 一个交点找到 再通过插值等方法得到中心轴线与半径 从而完成血管等三维重建 三 模型假设与符号说明 1 模型假设 l 在已给的图形中 由于其为象素点 每一点并非无限小 而只为整数坐标 故在解题时紧挨曲 线的整数象点近似为曲线上的点 l 由于象素点为整数 故考虑血管的切面时 紧挨着的四个点所构成的平面 近似看成是该点的 切面
血管管道的表面是由球心沿着某一曲线的球滚动包络而成。其半径为固定的。 每一张切面与中心轴线有且只有一个交点 2.符号说明 切面Z为第Z个切面,即ZBmp M(x,y,z)为切面z上坐标为(x,y)的点 为切面Z与中心轴线的交点 中心轴线,l,l,l2xy、 lyz, Lz分别为1在xy、yzx面的投影 血管的半径 其他符号说明见文中 四、模型求解 模型一、重叠相加法 由分析可知,在每一幅图中,都将有且有一个点,该点为中心轴线与该图点交点。显然以O为球心, 血管半径R做一个球,则该球的投影将会被该黑色图形所包围。 并且由于管道的表面是由球心沿着某一曲线(称为中轴线)的球滚动包络而成。所以对于血管的 小段而言,无论投影到哪一个平面或被过中心轴线的平面所切,它在平面上最终形成的影子的口径 D>=2R 在这里我们考虑一种最简单的 方法, 即将100幅bmp的图像叠加在XOY 平面上。由 题目要求和假设,我们知道,此时 在XOY上 将会出现一条管道,该管道两头略 小,中间部 分基本成一环状,设该环状的宽为 d,则由上分 析知,R≤=d 如图示: 由几何知识,我们可以知道 若血管 的投影不会重叠(在XOY上),则 该环状物的 宽度即为血管的半径,即R=d 因为环状物 可以看作为小球轨迹在XOY平面 的投影。故 100幅图叠加后的图中的环状物的中心线L就是血管中心轴线在XOY平面上的投影 第3页〔共14页〕
第3页 共14页 l 血管管道的表面是由球心沿着某一曲线的球滚动包络而成 其半径为固定的 l 每一张切面与中心轴线有且只有一个交点 2 符号说明 切面 Z 为第 Z 个切面 即 Z.Bmp M(x y z) 为切面 z 上坐标为 x y 的点 Oz 为切面 Z 与中心轴线的交点 L 中心轴线 xy xz yz l ,l ,l lxy lyz lxz 分别为 l 在 xy yz xz 面的投影 R 血管的半径 其他符号说明见文中 四 模型求解 模型一 重叠相加法 由分析可知 在每一幅图中 都将有且有一个点 该点为中心轴线与该图点交点 显然以Oz 为球心 血管半径 R 做一个球 则该球的投影将会被该黑色图形所包围 并且由于管道的表面是由球心沿着某一曲线 称为中轴线 的球滚动包络而成 所以对于血管的一 小段而言 无论投影到哪一个平面或被过中心轴线的平面所切 它在平面上最终形成的影子的口径 D >= 2R 在这里我们考虑一种最简单的 方 法 即将 100 幅 bmp 的图像叠加在 XOY 平面上 由 题目要求和假设 我们知道 此时 在 XOY 上 将会出现一条管道 该管道两头略 小 中间部 分基本成一环状 设该环状的宽为 d 则由上分 析知 2 d R <= 如图示 由几何知识 我们可以知道 若血管 的投影不会重叠 在 XOY 上 则 该环状物的 宽度即为血管的半径 即 2 d R = 因为环状物 可以看作为小球轨迹在 XOY 平面 的投影 故 100 幅图叠加后的图中的环状物的中心线 L 就是血管中心轴线在 XOY 平面上的投影
过曲线L做一垂直与XOY平面的曲面Q,由上面的分析知道,血管的中心轴线必将在曲面Q上 曲面Q与每一个切面Z都会有一条交线l,显然O在l2上 在l上,任取一点A(xyz),以半径R做一圆,如果该圆恰好与切面上点黑色图相切(即有且有两 个交点),则该点即为中心轴线上的点 同理,在一百个切面上,可以找到一百个点A0A1,A2…,将该点拟合成一曲线,就是血管中心轴 线,且环宽的一半就是Ra 通过计算机计算,我们可以知道曲线的半径为 R=59.783/2=298915 其点如右图示 在三个垂直面的投影分别如下 125150 第4页〔共14页
第4页 共14页 过曲线 L 做一垂直与 XOY 平面的曲面 Q 由上面的分析知道 血管的中心轴线必将在曲面 Q 上 曲面 Q 与每一个切面 Z 都会有一条交线 z l 显然Oz 在 z l 上 在 z l 上 任取一点 A(x y z),以半径 R 做一圆 如果该圆恰好与切面上点黑色图相切 即有且有两 个交点 则该点即为中心轴线上的点 同理 在一百个切面上 可以找到一百个点 A0,A1,A2 … … ., 将该点拟合成一曲线 就是血管中心轴 线 且环宽的一半就是 R 通过计算机计算 我们可以知道曲线的半径为 R 59.783/2=29.8915 其点如右图示 在三个垂直面的投影分别如下 -150 25 50 75 100 125 150 20 40 60 80 25 50 75 100 125 150 -150 -100 -50 50 100
模型二、断层扫描法 在三维空间内,(p,a,)能唯一决定一个平面,其中,a为平面和xoy面的角度,O为平面和xoz 面的角度。这样我们可以在心血管的边界上随机选取一点,然后在这一点的基础上,和O取不同的角 度,就可以得到不同的平面,每个平面和心血管都有一条封闭的曲线,假如我们能够找到一个圆,那么 这个圆的半径就是心血管的半径,圆心就是心血管的中轴线上的一点。只要我们在心血管的边界上依次 取点,我们就可以找出中轴线。 我们利用计算机对这100幅切面图进行叠加,重建了一个血管的三维立体图。然后从在心血管的边 界上以一定的顺序取点。对于每一个点,搜索角度a和O,使得切割血管所得截面为正圆。 下面是如何判断一个图形是否为正圆 假设我们截得的图形边界上的点为A4(k∈Z,K≤N) 集合P={44|m∈z,n∈Z+,m≤N,n≤N} 则图形长轴为 2a= max 4m4 fA. A, 中心点O即在AnAn的中点 求出中心点O到图形边界上所有点的最小距离b=mn{OAB 设圆系数为p==≤1 ·P=1时图形为正圆 p越小离正圆的偏差越大 我们认为只要p>0.9就可以认为是正圆 上 出了 当断 层不 同时所 截 50175200225250 到的 不同面 通过计算机计算,我们可以知道,血管半径为30a当我们判断出所截图形为正圆时,显然圆的圆心 就是我们所要找的中心轴点。(投影图略) 第5页〔共14页
第5页 共14页 模型二 断层扫描法 在三维空间内 p a q 能唯一决定一个平面 其中 a 为平面和 xoy 面的角度 q 为平面和 xoz 面的角度 这样我们可以在心血管的边界上随机选取一点 然后在这一点的基础上 a 和q取不同的角 度 就可以得到不同的平面 每个平面和心血管都有一条封闭的曲线 假如我们能够找到一个圆 那么 这个圆的半径就是心血管的半径 圆心就是心血管的中轴线上的一点 只要我们在心血管的边界上依次 取点 我们就可以找出中轴线 我们利用计算机对这 100 幅切面图进行叠加 重建了一个血管的三维立体图 然后从在心血管的边 界上以一定的顺序取点 对于每一个点 搜索角度a 和q 使得切割血管所得截面为正圆 下面是如何判断一个图形是否为正圆 假设我们截得的图形边界上的点为 Ak (k Î Z ,K £ N) + 集合 P { A A | m Z ,n Z ,m N,n N} = m n Î Î £ £ + + 则图形长轴为 2 max { } m n A A P a A A m n Î = 中心点O 即在 Am An 的中点 求出中心点O 到图形边界上所有点的最小距离 min{ } b = OAk 设圆系数为 = £ 1 a b r l r = 1时图形为正圆 l r越小离正圆的偏差越大 我们认为只要 r > 0.9 就可以认为是正圆 上 图 给 出 了 当 断 层 不 同 时 所 截 到 的 不同面 通过计算机计算 我们可以知道 血管半径为 30 当我们判断出所截图形为正圆时 显然圆的圆心 就是我们所要找的中心轴点 投影图略 340 360 380 400 420 440 20 40 60 80 100 150 175 200 225 250 275 300 60 80 100 120
模型三、切线定点法 定理:在切面图形的边界上至少将存在一对点 其法线方向重 合,在所有满足条件的点中,距离最长的一对 点的连线的中 点即为血管的中心轴线上的点,该点到切面边 界的最小距离 即是血管的半径 证明:1.存在性 已知切面Q与中心轴线有且只有一个交 点,不 妨设为O,则以O为球心,R为半径的小球与 切面Q将有 个交面,此交面包含在血管在Q面上的投影中, 如下平面图 示。并且A、B点为血管、球面和Q面的共同 点。L为球与 血管相切面上的在Q面上的直线。显然,AOB Aw 共线,L与 AOB垂直交与A,同理,有一直线L与AOB 垂直交与B 点。所以至少存在两点,其法线重合(L、L平 行,ab共线) 2。确定性 当只存在两点满足条件时,显然将这两点 连线就 可 当存在多对点时,最长一对点A、B的中 心O1即 是中心轴点。假设存在一对更近的点C、D的 连线的中点为 中心轴点O2(且不和O1同为一点,在这里若,O1到边界的最小点为不为A、B而为另外的E、F,则 我们比较对象转为CD和EF)。由题目知,血管的表面是由球心沿着某一曲线(称为中轴线)的球滚动包 络而成。那么以该线段的中点为球心,其二分之一为半径作球,由C、D点的特征,我们知道该球将与血 管壁切与C、D点。那么将导致该球整体将落在血管内部。这显然是不可能的。故连线最长的中心点为中 心轴上的点。 由于象素点都为整数点即采样点的不连续性,我们不能保证一定可以找到一对法线相同的点,因此 我们求的是法线夹角最小的一对点,即认为是满足条件的两个点其具体实现如下表所示 切线定点法 1.把所有的边界点按图象的大致对称中心分为两类 2,计算出其中一类的点A的法线 3.求出另一类中距离法线最近的点B的坐标 4.判断法线是否为B点的法线,即A、B点的法线是否重合 5.若是,则AB记入集合S中,若不是转2 6.求出A、B点的中点O,则O就是中心轴线与切面的交点 7.求出O到切面边界的点的最小距离,即为血管的半径 其具体计算如下 第6页〔共14页
第6页 共14页 模型三 切线定点法 定 理 在切面图形的边界上至少将存在一对点 其法线方向重 合 在所有满足条件的点中 距离最长的一对 点的连线的中 点即为血管的中心轴线上的点 该点到切面边 界的最小距离 即是血管的半径 证 明 1 存在性 已知切面 Q 与中心轴线有且只有一个交 点 不 妨设为 O 则以 O 为球心 R 为半径的小球与 切面 Q 将有一 个交面 此交面包含在血管在 Q 面上的投影中 如下平面图 示 并且 A B 点为血管 球面和 Q 面的共同 点 L 为球与 血管相切面上的在 Q 面上的直线 显然 AOB 共 线 L 与 AOB 垂直交与 A 同理 有一直线 L’与 AOB 垂直交与 B 点 所以至少存在两点 其法线重合 L L’平 行 ab 共线 2 确定性 当只存在两点满足条件时 显然将这两点 连线就 可 当存在多对点时 最长一对点 A B 的中 心 O1 即 是中心轴点 假设存在一对更近的点 C D 的 连线的中点为 中心轴点 O2 且不和 O1 同为一点 在这里若 O1 到边界的最小点为不为 A B 而为另外的 E F 则 我们比较对象转为 CD 和 EF 由题目知 血管的表面是由球心沿着某一曲线 称为中轴线 的球滚动包 络而成 那么以该线段的中点为球心 其二分之一为半径作球 由 C D 点的特征 我们知道该球将与血 管壁切与 C D 点 那么将导致该球整体将落在血管内部 这显然是不可能的 故连线最长的中心点为中 心轴上的点 由于象素点都为整数点即采样点的不连续性 我们不能保证一定可以找到一对法线相同的点 因此 我们求的是法线夹角最小的一对点 即认为是满足条件的两个点其具体实现如下表所示 切线定点法 1 把所有的边界点按图象的大致对称中心分为两类 2 计算出其中一类的点 A 的法线 3 求出另一类中距离法线最近的点 B 的坐标 4 判断法线是否为 B 点的法线 即 A B 点的法线是否重合 5 若是 则 A B 记入集合 S 中 若不是转 2 6 求出 A B 点的中点 O 则 O 就是中心轴线与切面的交点 7 求出 O 到切面边界的点的最小距离 即为血管的半径 其具体计算如下
1、求曲线在M处的法线 在切面Z上任取一点M1(x1,y1),并在曲线上取与M1相邻的一点M2(x2y2),其中 X, VI M1M2=(x2-x1,y2-y1) 设曲线在M处的法线方程为 X, y 由于法线与垂直于切线,所以 m(x2-x1)+n(y2-y1)=0 加_y2 法线方程为 (x2-x1x-x1)+(y2-y1)(y-y1)= 2、求相同法线的另一点 设点M6(x0,y)为另一类边界点 点M到法线的距离为 (x2-x)x-x)+(y2-y)y0-y (x2-x)2+(y2-y)2 若存在M0(x0,y0)使得d=0,M(x0,y)与M1(x1,y)即所求。若d≠0,则记录该d和M1M0 并取另一个M1点,重新计算如上的过程,直到满足要求为止。若最后所有的d≠0,则从中选取最小的 d即可。 得到M1、M0后,计算其中心点O,即为中心轴线与切面Z的交点。 计算O到边界的最短距离,即为半径R 第7页〔共14页〕
第7页 共14页 1 求曲线在 M1处的法线 在切面 Z 上任取一点 ( , ) 1 1 1 M x y 并在曲线上取与 M1 相邻的一点 ( , ) 2 2 2 M x y 其中 x2 - x1 £ 1, y2 - y1 £ 1 则 ( , ) 1 2 2 1 2 1 M M = x - x y - y ® 设曲线在 M1 处的法线方程为 n y y m x x1 - 1 = - 由于法线与垂直于切线 所以 m(x2 - x1 ) + n( y2 - y1 ) = 0 2 1 2 1 x x y y n m - - = - 法线方程为 (x2 - x1 )( x - x1 ) + (y2 - y1 )( y - y1 ) = 0 2 求相同法线的另一点 设点 ( , ) 0 0 0 M x y 为另一类边界点 点 M0 到法线的距离为 2 2 1 2 2 1 2 1 0 1 2 1 0 1 ( ) ( ) ( )( ) ( )( ) x x y y x x x x y y y y d - + - - - + - - = 若存在 ( , ) 0 0 0 M x y 使得d 0 ( , ) 0 0 0 M x y 与 ( , ) 1 1 1 M x y 即所求 若d ¹ 0 则记录该 d 和M1 M0 并取另一个 M1 点 重新计算如上的过程 直到满足要求为止 若最后所有的d ¹ 0 则从中选取最小的 d 即可 l 得到 M1 M0 后 计算其中心点 O 即为中心轴线与切面 Z 的交点 l 计算 O 到边界的最短距离 即为半径 R
3、计算结果 中心轴点坐标 050 68(舍去) 96.225.0 596083 128.300.50 594811 95524355 55 60.8l1 208.382.55 955249,10 2215 60373898248516 6560321220638165 0.7649 626099 240.390.70 5598415965267,15 75 60.5 330.379.75 598415975272,20 80 1132 328.380.80 597746102.527735 8559269938553338 5961541055280540 0599083406249590 4559908312029045 9559039423524495 由于半径为一定的,我们最终通过取平均来确定半径为 R=299324 其三维图如下所示 在三个垂直面的投影如下:(分别为XOY,YOZ,XOZ平面) 模型 四 空间 向量 法 由 题目假 设可
第8页 共14页 3 计算结果 切面 半径 中心轴点坐标 切面 半径 中心轴点坐标 0 68(舍去) 96,225,0 50 59.6083 128,300,50 5 59.4811 95.5,243.5,5 55 60.811 208,382,55 10 60.0833 95.5,249,10 60 60.2215 209,382,60 16 60.3738 98,248.5,16 65 60.3212 206,381,65 20 60.7649 96,255.5,20 70 62.6099 240,390,70 25 59.8415 96.5,267,15 75 60.5 330,379,75 30 59.8415 97.5,272,20 80 61.1132 328,380,80 35 59.7746 102.5,277,35 85 59.2699 385.5,333,85 40 59.6154 105.5,280.5,40 90 59.9083 406,249.5,90 45 59.9083 120,290,45 95 59.0339 423.5,244,95 由于半径为一定的 我们最终通过取平均来确定半径为 R 29.9324 其三维图如下所示 在三个垂直面的投影如下 (分别为 XOY YOZ XOZ 平面) 模 型 四 空 间 向 量 法 由 题目假 设 可 100 200 300 400 20 40 60 80 100 100 200 300 400 20 40 60 80 100 100 200 300 400 100 200 300 400
知,血管可以看作是一类特殊的管道,其表面是由球心沿着某一曲线(称为中轴线)的球滚动包络而成 所以。血管可以看成是由半径为r的小球滚动而形成的。所以对于血管壁上任意一点都有一个小球与血管 壁曲面相切于此点。则血管壁曲线在此点的法线在血管内的部分即为小球的直径,其中点就是球心,既 为中轴线上的一点。于是我们可以通过空间向量的关系来找到血管的中心轴线并求出半径 同时由于象素点都为整数点,为了连续而又不重复的取到中轴线上的点,我们规定了一定的规则来 选取切点,从而实现我们的方案 空间向量法实现的方法与规则 1.在切片二==1(=1∈Z,=1≥0)的边界上选取一点M1(x,y12=1) 2.在切片x=(1∈Z,1≥0)的边界上另选取两个与M1相邻的点M2(x2,y2,z1), M3(x3,y3,=1)其中x2-x1=-1,x3-x1=1 3.在边界上选取两个点M4(x4,y1-1=4),M5=(x5,y1+,5) 4,可过M,M2,M4,M四点作一平面M 5.求得平面M的法线m 6.求出法线m与血管壁的另一个交点M6 7.小球直径d=2r=MMA,M与M的中点即为所求的中轴线上的点。 8.=1=1+1,转步骤1 对空间向量法具体的实现方法如下 1、求任意点的空间法线 设已知点切面上的点M1(x1,y1,1),则取 M2(x2,y2=1) M3(x3,y3,=1) 4(x4,y4,二4) Ms 其中满足条件 1,x3-x1=1,y4-y1=-1,ys5 所以我们有 第9页〔共14页
第9页 共14页 知 血管可以看作是一类特殊的管道 其表面是由球心沿着某一曲线 称为中轴线 的球滚动包络而成 所以 血管可以看成是由半径为 r 的小球滚动而形成的 所以对于血管壁上任意一点都有一个小球与血管 壁曲面相切于此点 则血管壁曲线在此点的法线在血管内的部分即为小球的直径 其中点就是球心 既 为中轴线上的一点 于是我们可以通过空间向量的关系来找到血管的中心轴线并求出半径 同时由于象素点都为整数点 为了连续而又不重复的取到中轴线上的点 我们规定了一定的规则来 选取切点 从而实现我们的方案 空间向量法实现的方法与规则 1 在切片 ( , 0) z = z1 z1 Î Z z1 ³ 的边界上选取一点 ( , , ) 1 1 1 1 M x y z 2 在切片 ( , 0) z = z1 z1 Î Z z1 ³ 的边界上另选取两个与 M1 相邻的点 ( , , ) 2 2 2 1 M x y z ( , , ) 3 3 3 1 M x y z 其中 x2 - x1 = -1 x3 - x1 = 1 3 在边界上选取两个点 ( , 1, ), ( , 1, ) 4 4 1 4 5 5 1 5 M x y - z M = x y + z 4 可过 2 3 4 5 M ,M ,M , M 四点作一平面 M 5 求得平面 M 的法线m 6 求出法线m 与血管壁的另一个交点 M6 7 小球直径 2 M1M6 d = r = M1 与 M6 的中点即为所求的中轴线上的点 8 z1 = z1 + 1 转步骤 1 对空间向量法具体的实现方法如下 1 求任意点的空间法线 设已知点切面上的点 ( , , ) 1 1 1 1 M x y z 则取 ( , , ) ( , , ) ( , , ) ( , , ) 5 5 5 5 4 4 4 4 3 3 3 1 2 2 2 1 M x y z M x y z M x y z M x y z 其中满足条件 x2 - x1 = -1, x3 - x1 = 1, y4 - y1 = -1, y5 - y1 = 1 所以我们有
M2M3=(2,y3-y20) 4M5=(x5-x4,2, 又有行列式 y3-y20 (y3-y2)(=4-25)+2(z4-5)j+[4-(x4-x5(y2-y3)k 可得血管壁曲线的切平面方程为为 (y3-y2)X=4-5x-x1)+2(=4-=5)(y-y1)+14-(x4-x3X(y2-y3)(-21)=0法线方程为 X, (y3-y2)(=4-25)2(=4-25)4-(x4-x5)(y2-y3) 2、小球半径的确定 对于小球半径,由于原始数据是离散,不一定存在点在法线上,因此我们只能根据假设求得离 法线最近的点。设此点为M0(x0,y0,二0) M到法线的距离为 M,MoX d (s为法线向量) 则 d=xr-x 21-20 y3-y2)(=4-5)2(4--5)4-(x4-x3)(y2- 水y-y2)=4-=5)+2(=4-=)+4-(x4-xy2-y3) 4(V1-y)+((x4-x5)=y1)y2-y3)+2(-0-=1(=4-25) (-4x+x(4-(x4-x)(y2-y2)+(V2-y3x(x-x)-(-=)(4-3)) (2x0-2x1-(-y)(2-y3)(-5-24) (y3-y2)(4-=)2+4(=;-3)2+[4-(x4-x3Xy2-y3 确定M后即可求出小球半径 第10页〔共14页
第10页 共14页 (2, ,0) 2 3 3 2 M M = y - y ® ( ,2, ) 4 5 5 4 5 4 M M = x - x z - z ® 又有行列式 5 4 2 x x i - 2 3 2 y y j - 5 4 0 z z k - =( y y )(z z )i 2(z z ) j [4 (x x )( y y )]k 3 - 2 4 - 5 + 4 - 5 + - 4 - 5 2 - 3 可得血管壁曲线的切平面方程为为 (y3 - y2 )(z4 - z5 )(x - x1 ) + 2(z4 - z5 )(y - y1 ) + [4 - (x4 - x5 )(y2 - y3 )](z - z1 ) = 0法线方程为 ( )( ) 2( ) 4 ( )( ) 4 5 2 3 1 4 5 1 3 2 4 5 1 x x y y z z z z y y y y z z x x - - - - = - - = - - - 2 小球半径的确定 对于小球半径 由于原始数据是离散 不一定存在点在法线上 因此我们只能根据假设求得离 法线最近的点 设此点为 ( , , ) 0 0 0 0 M x y z M0 到法线的距离为 s M M s d ® ´ = 1 0 s 为法线向量 则 ( )( ) 3 2 4 5 1 0 - - = - y y z x x i d 2( ) 4 5 1 0 z z y y j - - 4 ( )( ) 4 5 2 3 1 0 x x y y z z k - - - - / ( y y )(z z )i 2(z z ) j [4 (x x )( y y )]k 3 - 2 4 - 5 + 4 - 5 + - 4 - 5 2 - 3 2 0 1 0 1 2 3 5 4 2 0 0 4 5 2 3 2 3 1 4 5 0 1 4 5 2 1 0 4 5 0 1 2 3 0 1 4 5 ((2 2 ( )( ))( )) (( 4 (4 ( )( ) ( )( ( ) ( )( )))) (4( ) (( )( )( ) 2( )( ))) x x y y y y z z x x x x y y y y x x x z z z z y y x x y y y y z z z z + - - - - - + - + - - - + - - - - - - + - - - + - - = 2 4 5 2 3 2 4 5 2 3 2 4 5 (( y - y )(z - z )) + 4(z - z ) + [4 - (x - x )( y - y )] 确定 M0 后即可求出小球半径