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]

B-spline respecto a una línea compuesta de varios segmentos rectos

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

editar

Dado 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

editar

Cuando 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

editar

Si 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]

Cuando 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

editar

A continuación se muestran una serie de ejemplos de diversos tipos de B-splines.

B-spline constante

editar

La 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

editar

La 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

editar

Las 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

editar

Una 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

editar

La 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

editar

Referencias

editar
  1. Carl de Boor (1978). A Practical Guide to Splines. Springer-Verlag. pp. 113–114. 
  2. Carl de Boor (1978). A Practical Guide to Splines. Springer-Verlag. pp. 114–115. 
  3. Lee, E. T. Y. (diciembre de 1982). «A Simplified B-Spline Computation Routine». Computing (Springer-Verlag) 29 (4): 365-371. doi:10.1007/BF02246763. 
  4. Lee, E. T. Y. (1986). «Comments on some B-spline algorithms». Computing (Springer-Verlag) 36 (3): 229-238. doi:10.1007/BF02240069. 
  5. Brinks R: On the convergence of derivatives of B-splines to derivatives of the Gaussian function, Comp. Appl. Math., 27, 1, 2008
  6. «Splitting a uniform B-spline curve». Archivado desde el original el 14 de abril de 2009. Consultado el 20 de junio de 2009.