B-spline Curves: Computing the Coefficients

 本博客转自前人的博客的翻译版本,前几章节是原来博主的翻译内容,但是后续章节博主不在提供翻译,后续章节我在完成相关的翻译学习。

 (原来博客网址:http://blog.csdn.net/tuqu/article/details/4749586)

 原来的博主翻译还是很好的,所以前几章节直接借鉴参考原博主的内容。


  尽管de Boor算法是一个计算对应于给定u的B-样条曲线上的点的标准方法, 我们许多情况下(例如,曲线插值和逼近)真正需要的是这些系数。我们将阐述一个简单方法来做这个。

  给定一个由 n+1个控制点P0, P1, ..., Pn, 和 m+1个节点 u0=u1=...=up=0, up+1, up+2, ..., um-p-1, um-p=um-p+1=...= um=1定义的pclamped B-样条曲线。对于任何给定在[0,1]上的 u ,我们想计算系数N0,p(u), N1,p(u), ..., Nn,p(u) 。一个简单方法是使用下列递推关系:

  

  但是这是一个非常耗时的过程。为了计算 Ni,p(u), 我们需要计算 Ni,p-1(u)和Ni+1,p-1(u). 为了计算Ni,p-1(u), 我们需要计算Ni,p-2(u) 和 Ni+1,p-2(u). 为了计算Ni+1,p-1(u), 我们需要Ni+1,p-2(u)和 Ni+2,p-2(u). 如你们所看到的, Ni+1,p-2(u)出现了两次,因此,递归计算会重复。当递归继续深入,会出现更多的重复计算。这与在页讨论的de Casteljau算法的递归版本很相似。因此,计算速度非常慢。

  有容易的方法。设 u 在节点区间[uk,uk+1)上。. B-样条基函数的重要性质 说明最多 p+1个p 次基函数在[uk,uk+1)上非零,即: Nk-p,p(u), Nk-p+1,p(u), Nk-p+2,p(u), ..., Nk-1,p(u), Nk,p(u)。通过定义,在 [uk,uk+1)上的0次仅有的非零基函数是Nk,0(u)。结果,从.Nk,0(u)出发计算系数是以一个 "fan-out" 三角形式,如下图所示:

  

  因为在 [uk,uk+1)上 Nk,0(u) = 1而其他0次B-样条基函数在[uk,uk+1)上是零,我们可以从 Nk,0(u)开始而计算1次基函数 Nk-1,1(u) 和 Nk,1(u)。从这两个值,我们可以计算2次基函数 Nk-2,2(u), Nk-1,2(u) 和Nk,2(u)。这个过程重复直到所有p+1 个非零系数计算出来。

  在这个计算中, “内部”值如 Nk-1,2(u)有一个西北向前驱 (即, Nk-1,1(u))和一个西南向的前驱 (即, Nk,1(u));上述三角如Nk-1,1(u)的东北方向边界上的值只有一个西南向前驱 (即, Nk,0(u));这个三角如 Nk,2(u)的东南方向边界上的值只有一个西北前驱 (即, Nk,1(u))。因此, 在东北 (resp., 东南)方向边界上的值使用定义中的递归关系的第二 (resp., 第一)项 。只有内部值使用全部两项。基于这个观察,我们有下列算法:

  

  

  上述算法不是很有效的算法。它的目的是为了以一个直觉容易理解的方式说明思想。 数组N[ ] 保存所有中间值和最后结果。对一个次数 d, N[i] 保存了Ni,d(u)的值,且,最后,N[k-d], N[k-d+1], ..., N[k] 含有非零系数。计算以 d=1开始因为我们知道仅有的非零基函数是 Nk,0(u)如果 u 在节点区间 [uk,uk+1)上。 外循环使得次数 d 从 1到  pbegin 后面的第一次赋值是仅使用一项(即,三角中的西南项, Nk-d+1,d-1(u)),计算 Nk-d,d(u) , 内部 for 循环计算 “内部”项,而外循环中最后一个语句仅使用一项(即,三角中的西北项,  Nk,d-1(u)) 计算 Nk,d(u)。

  你能使这个算法更有效吗?


B-spline Curves: A Special Case

  B-样条曲线:特例

  如果我们有 2n+2 个节点 u0 = u1 = ... = un = 0及 un+1 = un+2 = ... = u2n+1 = 1 (即,头 n+1 个是零,而后 n+1是1), n 次B-样条基函数是什么?

  因为每个 u 在 [0,1] = [un, un+1]上, n 次非零基函数是: N0,n(u), N1,n(u), ..., Nn,n(u)。回忆B-样条基函数的定义如下:

  

  因为仅有的 0次非零基函数是Nn,0(u),下标 i 只能在0 和n之间。因此, ui是零而 ui+nui+n+1是1。结果,上边第二个等式可重写为如下式:

  

  如果我们进行如页讨论的那样以一个三角形式计算N0,n(u), N1,n(u), ..., Nn,n(u) ,那么我们有下图。在该图中,每个东北(resp., 东南)边界箭头意味这乘1-u (resp., u)到在箭头尾部的项上。注意计算中有n 步骤,每步获得每列。因此, Nn,0(u) 对 N0,n(u)的贡献是 (1-u)n, 而Nn,0(u)的贡献对Nn,n(u)是un.

  

  现在,考虑一般项 Ni,n(u)的计算。 Nn,0(u) 对Ni,n(u)计算的贡献可用"path-counting"技术确定,其用来展示de Casteljau算法的正确 以及贝塞尔曲线的更高次导数的计算中。每个从 Nn,0(u) 到 Ni,n(u) 遇n 箭头其中i 是东南边界 而 n-i 是东北边界。 那些东北(resp., 东南)边界箭头意味着对尾部的项乘以1-u (resp., u)。因此,Nn,0(u) 对 Ni,n(u)的贡献沿着一个单path是 ui(1-u)n-i 。从 Nn,0(u) 到 Ni,n(u)的paths总数是C(n,i)。更准确地,paths的数目等于放置 i 个东南边界箭头在n 个位置不同方法的数目。剩余 n-i 位置用东北边界箭头充满。这 n 个箭头准确地描述了从 Nn,0(u) 到 Ni,n(u)的一个单路径(path)。因为每个路径(path)贡献  ui(1-u)n-i 给计算且因为有C(n,i) 个路径,Nn,0(u) 对 Ni,n(u)的总贡献是

  

  这就是 n次第i个贝塞尔基函数。因此,我们有下列结论:

  

B-spline Curves 学习之B样条曲线的系数计算与B样条曲线特例(6)的更多相关文章

  1. B-spline Curves 学习前言与动机(1)

    B-spline Curves 学习之前言 本博客转自前人的博客的翻译版本,前几章节是原来博主的翻译内容,但是后续章节博主不在提供翻译,后续章节我在完成相关的翻译学习. (原来博客网址:http:// ...

  2. ArcGIS案例学习笔记4_2_城乡规划容积率计算和建筑景观三维动画

    ArcGIS案例学习笔记4_2_城乡规划容积率计算和建筑景观三维动画 概述 计划时间:第4天下午 目的:城市规划容积率计算和建筑三维景观动画 教程: pdf page578 数据:实验数据\Chp13 ...

  3. [源码解析] 深度学习流水线并行 GPipe(3) ----重计算

    [源码解析] 深度学习流水线并行 GPipe(3) ----重计算 目录 [源码解析] 深度学习流水线并行 GPipe(3) ----重计算 0x00 摘要 0x01 概述 1.1 前文回顾 1.2 ...

  4. B-spline Curves 学习之B样条曲线性质(5)

    B-spline Curves: Important Properties 本博客转自前人的博客的翻译版本,前几章节是原来博主的翻译内容,但是后续章节博主不在提供翻译,后续章节我在完成相关的翻译学习. ...

  5. B-spline Curves 学习之B样条曲线的移动控制点、修改节点分析(7)

    B-spline Curves: Moving Control Points 本博客转自前人的博客的翻译版本,前几章节是原来博主的翻译内容,但是后续章节博主不在提供翻译,后续章节我在完成相关的翻译学习 ...

  6. B-spline Curves 学习之B样条曲线定义(4)

    B-spline Curves: Definition 本博客转自前人的博客的翻译版本,前几章节是原来博主的翻译内容,但是后续章节博主不在提供翻译,后续章节我在完成相关的翻译学习. (原来博客网址:h ...

  7. B-spline Curves 学习之B样条曲线的导数(8)

    Derivatives of a B-spline Curve 本博客转自前人的博客的翻译版本,前几章节是原来博主的翻译内容,但是后续章节博主不在提供翻译,后续章节我在完成相关的翻译学习. (原来博客 ...

  8. cad.net 依照旧样条曲线数据生成一条新样条曲线的代码段. spline生成

    Spline spl = entity as Spline; //拿到旧的spline图元... //样条曲线生成条件 var controlPoints = new Point3dCollectio ...

  9. B-spline Curves 学习之B样条基函数的定义与性质(2)

    B-spline Basis Functions 本博客转自前人的博客的翻译版本,前几章节是原来博主的翻译内容,但是后续章节博主不在提供翻译,后续章节我在完成相关的翻译学习. (原来博客网址:http ...

随机推荐

  1. Python 中单例模式 4种方法

    假设我们在一个与数据库交互的系统中,需要进行数据库操作,那么我们就有必要了解单例模式,单例模式使得我们不用每次进行数据库的操作时都去链接数据库. 我将循环渐进,由浅入深的写一下单例模式示例. 实例1: ...

  2. emacs之配置php

    php-setting.el (require 'php-mode) 以后丰富

  3. 黄聪:WordPress 多站点建站教程(一):怎样开启WordPress多站点功能,实现手机移动端主题开发,与主站用户数据共享

    为了开发手机移动端的wordpress,需要使用Wordpress的多站点功能. 1.打开WordPress根目录下的wp-config.php文件, 在文件的任何位置加上以下内容: define(' ...

  4. Bootstrap-CL:多媒体对象

    ylbtech-Bootstrap-CL:多媒体对象 1.返回顶部 1. Bootstrap 多媒体对象(Media Object) 本章我们将讲解 Bootstrap 中的多媒体对象(Media O ...

  5. 符合RESTful规范的API

    统一使用的utils,serializers: class BaseResponse: def __init__(self): self.code = 1000 self.data = None se ...

  6. unicat,multicast,broadcast区别

    单播.多播和广播单播”(Unicast).“多播”(Multicast)和“广播”(Broadcast)这三个术语都是用来描述网络节点之间通讯方式的术语.那么这些术语究竟是什么意思?区别何在? 1.单 ...

  7. --- no python application found, check your startup logs for errors

    --- no python application found, check your startup logs for errors 碰到这个问题,请留意下系统执行的python版本和自己的djan ...

  8. 好记性比如烂笔头--linux学习笔记7关于linux中的shell脚本编程

    之前看的各种面试,貌似都有shell脚本编程,没了解之前感觉很复杂,现在了解了些,没想象中那么难. 逻辑主要是这样的 编写.sh的脚本文件,文件里面的代码,就是在命令行输入的可执行命令的加强版,所谓加 ...

  9. IOS上架截屏 屏幕快照

    IOS上架截屏,屏幕快照,4种屏幕尺寸,每种尺寸5张软件功能截图. 大小等于对应设备的屏幕的像素大小.使用模拟器,command +s截图就可以了虚拟机里的手机截屏就保存在mac 桌面上了.jpg,p ...

  10. mac os 平台下载并编译android2.3.3源码

    现在在做有关android平台下的项目,最初对android环境各种不熟悉,搞了几个月终于有点眉目了,由于需要用到android本身提供的一些类似gps,tts等服务,单纯的看android提供的ja ...