B-spline
En el subcampo matemático de análisis numérico, una B-spline o Basis spline (o traducido una línea polinómica suave básica), es una función spline que tiene el mínimo soporte con respecto a un determinado grado, suavidad y partición del dominio. Un teorema fundamental establece que cada función spline de un determinado grado, suavidad y partición del dominio, se puede representar como una combinación lineal de B-splines del mismo grado y suavidad, y sobre la misma partición.[1] El término B-spline fue acuñado por Isaac Jacob Schoenberg y es la abreviatura de spline básica.[2] Las B-splines pueden ser evaluadas de una manera numéricamente estable por el algoritmo de De Boor. De un modo simplificado, se han creado variantes potencialmente más rápidas que el algoritmo de Boor, pero adolecen comparativamente de una menor estabilidad.[3][4]
En el subcampo de la informática de diseño asistido por computadora y de gráficos por computadora, el término B-spline se refiere con frecuencia a una curva parametrizada por otras funciones spline, que se expresan como combinaciones lineales de B-splines (en el sentido matemático anterior). Una B-spline es simplemente una generalización de una curva de Bézier, que puede evitar el fenómeno Runge sin necesidad de aumentar el grado de la B-spline.
Definición
editarDado m valores reales ti, llamados nodos, con
una B-spline de grado n es una curva paramétrica
compuesta por una combinación lineal de B-splines básicas bi,n de grado n
- .
Los Pi se llaman puntos de control o puntos de Boor. Hay m-(n+1) puntos de control que forman una envoltura convexa.
Las m-(n+1) B-splines básicas de grado n se pueden definir mediante la fórmula de recursión Cox-de Boor
Cuando los nodos son equidistantes, la B-spline se dice que es uniforme, de otro modo sería no uniforme. Si dos nodos tj son idénticos, cualquiera de las posibles formas indeterminadas 0/0 se consideran 0.
Nótese que j+n+1 no puede exceder de m-1, lo que limita tanto a j como a n.
B-spline uniforme
editarCuando la B-spline es uniforme, las B-splines básicas para un determinado grado n son solo copias cambiadas de una a otra. Una alternativa no recursiva de la definición de la B-splines m-n+1 básica es
con
y
dónde
es la función de potencia truncada definida como
B-spline cardinal
editarSi se define B0 como la función característica de , y Bk recursivamente como el producto convolución
entonces Bk se llaman B-splines cardinales (centradas). Esta definición se remonta a Schoenberg.
Bk tiene soporte compacto y es una función impar. Como las B-splines cardinales normalizadas tienden a la función de Gauss.[5]
Notas
editarCuando el número de puntos de control de Boor es el mismo que el grado, la B-Spline degenera en una curva de Bézier. La forma de las funciones base es determinada por la posición de los nodos. Escalar o trasladar el vector de nodo no altera las funciones de base.
El spline está contenido en el casco convexo de sus puntos de control. Una B-spline básica de grado n
es distinta de cero solo en el intervalo [ti, ti+n+1] esto es
En otras palabras si manipulamos un punto de control cambiamos solo el comportamiento local de la curva y no el comportamiento global como con las curvas de Bézier.
La función base se pueda obtener del polinomio de Bernstein.
Ejemplos
editarA continuación se muestran una serie de ejemplos de diversos tipos de B-splines.
B-spline constante
editarLa B-spline constante es la spline más simple. Se define en un solo tramo de nodo y ni siquiera es continua en los nodos. Es solo la función indicador de los diferentes tramos de nodo.
B-spline lineal
editarLa B-spline lineal se define en dos tramos de nodo consecutivos y es continua sobre los nodos, pero no diferenciable.
B-spline cuadrática uniforme
editarLas B-splines cuadráticas con nodo-vector uniforme es una forma común de B-spline. La función base puede ser calculada fácilmente , y es igual para cada segmento, en este caso.
Puesto en forma de matriz, esto es:[6]
- para
B-spline cúbica
editarUna formulación B-spline para un solo segmento puede ser escrita como:
donde Si es el imo segmento B-spline y P es el conjunto de puntos de control, el segmento i y k es el índice del punto de control local. Un conjunto de puntos de control sería P donde el es el peso, tirando de la curva hacia el punto de control mientras que aumenta o se desplazan fuera de la curva, a la vez que disminuye.
Toda una serie de segmentos, las curvas m-2 ( ) definidas por m+1 puntos de control ( ) como un B-spline en t, se definiría como:
donde i es el número de puntos de control y t es un parámetro global dados los valores de los nodos. Esta formulación expresa una curva B-spline como una combinación lineal de funciones B-spline básicas, de ahí el nombre.
Hay dos tipos de B-spline - uniforme y no uniforme. Una B-spline no uniforme es una curva donde los intervalos entre los puntos sucesivos de control no son, o no necesariamente son, iguales (el vector de nodos de espacios de nodo interiores no son iguales). Una forma común es donde los intervalos se reducen sucesivamente a cero, interpolando los puntos de control.
B-spline cúbica uniforme
editarLa B-spline cúbica con vector-nodo uniforme es la forma más usual de B-spline. La función base puede ser fácilmente calculada, y es igual para cada segmento, en este caso. Puesto en forma de matriz, esto es:
- para
Véase también
editarReferencias
editar- ↑ Carl de Boor (1978). A Practical Guide to Splines. Springer-Verlag. pp. 113–114.
- ↑ Carl de Boor (1978). A Practical Guide to Splines. Springer-Verlag. pp. 114–115.
- ↑ Lee, E. T. Y. (diciembre de 1982). «A Simplified B-Spline Computation Routine». Computing (Springer-Verlag) 29 (4): 365-371. doi:10.1007/BF02246763.
- ↑ Lee, E. T. Y. (1986). «Comments on some B-spline algorithms». Computing (Springer-Verlag) 36 (3): 229-238. doi:10.1007/BF02240069.
- ↑ Brinks R: On the convergence of derivatives of B-splines to derivatives of the Gaussian function, Comp. Appl. Math., 27, 1, 2008
- ↑ «Splitting a uniform B-spline curve». Archivado desde el original el 14 de abril de 2009. Consultado el 20 de junio de 2009.