Introduction
- Given a set of points:
- We can plot them on a graph:
data:image/s3,"s3://crabby-images/0d080/0d0802655e927e2ae13d95b149ee74609af193c7" alt="a linear interpolation of the points"
- But we only have values for 3 points.
- This means that we need to use interpolation for every other value.
- Using linear interpolation (above) is simple but not very smooth.
- Instead, we can use a polynomial:
data:image/s3,"s3://crabby-images/36d2a/36d2a9a658fe1ec27f0dad69164261f92598f8f2" alt="a lagrange interpolation of the points"
- This is now nice and smooth.
- Lagrange interpolation is a method for finding this equation.
Calculating the Lagrange Interpolation
- Lagrange Interpolation can be performed for any number of points.
- But let's keep things simple and just use 3 for now:
data:image/s3,"s3://crabby-images/f1fbd/f1fbd0eb14e9e14a900ac076f00338fcb911e764" alt="(0, 0.1), (0.5, 0.2), (1,"
- A polynomial that interpolates N points needs a degree of N - 1
- A quadratic equation can be used to interpolate 3 points:
data:image/s3,"s3://crabby-images/b991c/b991c046052e3632dca76c7ecc9da5209eae89ce" alt="y = ax^2 + bx + c"
- We know that the equation will have a value of yi for each xi in our set of points P
- The equation can be split into 3 sub-equations:
- Each sub-equation deals with a single point
- It will have a value of y at x
- And a value of 0 at all other points in P
data:image/s3,"s3://crabby-images/04826/0482693d3c00a70ed82ff9a939a5376fab110a0f" alt="all 3 sub-equations plotted on a graph"
- The final equation will be a sum of the three sub-equations:
data:image/s3,"s3://crabby-images/32e96/32e967b3dc22bad70ecd8eef09f3149e9f9625d9" alt="all 3 sub-equations ang lagrange plotted on a graph"
Sub-equation 1
- For our first equation:
- y = 0.1 when x = 0
- y = 0 when x = 0.5
- y = 0 when x = 1
- Let's start with the second and third conditions.
- If we write the quadratic equation in its factorized form:
data:image/s3,"s3://crabby-images/ade4d/ade4d25bc19b0ffa6ed17028828239dd870deedf" alt="y = (x - r_1)(x - r_2)"
- Then we know y will be 0 when either:
- We get our equation by setting r1 and r2 to 0.5 and 1
data:image/s3,"s3://crabby-images/e6c31/e6c314fb440370bbf0924b51625a356e808bd170" alt="y = x^2 - 1.5x + 0.5"
- We can plot this to visualize and check:
data:image/s3,"s3://crabby-images/c91df/c91df07754fe9b521a8f9d0ebbec7f71b0a6c0b9" alt="sub-equation 1 plotted on a graph"
- Let's handle our first condition:
- Our second and third condition generated a function that produces 0 at x = 0.5 and x = 1.
- We can multiply our function by a constant without affecting this property.
- Our first condition resolved by:
- Multiplying the function by a constant such that:
- Then multiply the function by 0.1
- This will mean that y = 0.1 when x = 0
- We have our equation:
data:image/s3,"s3://crabby-images/7f05f/7f05fdd25c152662f5abc26e43b40c3c99b02d8f" alt="y = (x - 0.5)(x - 1)"
- When x = 0:
data:image/s3,"s3://crabby-images/def59/def59f1e6dc446f2e29a4bf8a7253d730e388890" alt="y = 0.5"
- If we divide this by 0.5 then:
data:image/s3,"s3://crabby-images/5e873/5e873ca717156fa9f663a6c077eba58d77c955cb" alt="\begin{align} y &= \frac"
- Or more generally:
data:image/s3,"s3://crabby-images/1b611/1b6115429d8c24ee5986e68b83d2332eb5a397a4" alt="y = \frac{(x - 0.5)(x - 1"
- Lastly, we multiply by 0.1:
data:image/s3,"s3://crabby-images/74639/746394684337faf5a07c0d03a69052e8b6c414d2" alt="y = \frac{0.1(x - 0.5)(x"
- And expanding gives us:
data:image/s3,"s3://crabby-images/89037/89037177f31fdd5225a4662b40eb9768d7270333" alt="y = 0.2 x^2 - 0.3 x + 0.1"
- Let's plot this to make sure we are right:
data:image/s3,"s3://crabby-images/221ef/221ef51a4f7de6152269ef1ebaf38d8513517af2" alt="scaled sub-equation 1 plotted on a graph"
- Sub-equation 1 is now:
- 0.1 at x = 0
- 0 at x = 0.5
- 0 at x = 1
Sub-equation 2
- For our second sub-equation:
- y = 0.2 when x = 0.5
- y = 0 when x = 0
- y = 0 when x = 1
- Our unscaled sub-equation will be:
data:image/s3,"s3://crabby-images/ecf15/ecf15999023a1eb58c2ade6adf2240521edbb03a" alt="y = (x - 0)(x - 1)"
- And scaled:
data:image/s3,"s3://crabby-images/57102/57102305a41507e623ec41f9b9ca919261489bfe" alt="y = \frac{0.2(x - 0)(x -"
- Expanded:
data:image/s3,"s3://crabby-images/c1412/c141276dde67c1e14dd0945452825d79b59a9d44" alt="scaled sub-equation 2 plotted on a graph"
Sub-equation 3
- Following the same method as above we get:
data:image/s3,"s3://crabby-images/8707d/8707d57b8085873ea167aeb8edc1849bf0a1fd41" alt="y = \frac{1(x - 0.5)(x -"
- Expanded:
data:image/s3,"s3://crabby-images/53279/53279a50316412f0c11cad3c6e2298da6c549dbf" alt="scaled sub-equation 3 plotted on a graph"
- Our three equations are:
data:image/s3,"s3://crabby-images/04826/0482693d3c00a70ed82ff9a939a5376fab110a0f" alt="all 3 sub-equations plotted on a graph"
- If we add these 3 equations together we get:
data:image/s3,"s3://crabby-images/45251/45251efdb8c52931953882c2b53b5b60e0296135" alt="all 3 sub-equations plotted on a graph"
Generalized form of Lagrange Interpolation
- n is the number of points
- The set of points is:
data:image/s3,"s3://crabby-images/2e890/2e890634fe86af68bbb80858cb9304e51f918404" alt="(x_1, y_1), (x_2, y_2) \d"
- We get a set of n - 1 equations:
data:image/s3,"s3://crabby-images/ebb8d/ebb8dcf5000919dd1f85dbb0f15bd3b5cce2f2e6" alt="\begin{align} y &= \frac"
- Which are summed together.
- In summation and product notation, it can be reduced to:
data:image/s3,"s3://crabby-images/64eaa/64eaa99b9ed8c0ce819b8d3c9dc3526dc0c55b51" alt="\sum_{j = 1}^{n}\left( \p"
Code (Python) without SciPy
import numpy as np
from numpy.polynomial import Polynomial
points = np.array([
[0, 0.1],
[0.5, 0.2],
[1, 1]])
n = len(points)
poly = Polynomial(np.zeros(n))
for j in range(n):
k = [k for k in range(n) if k != j]
roots = -1 * points[k, 0]
sub_poly = Polynomial.fromroots(points[k, 0])
scale = points[j, 1] / np.prod(points[j, 0] - points[k, 0])
sub_poly.coef *= scale
poly.coef += sub_poly.coef
print(poly)
Code (Python) with SciPy
import numpy as np
from scipy.interpolate import lagrange
points = np.array([
[0, 0.1],
[0.5, 0.2],
[1, 1]])
poly = lagrange(points[:, 0], points[:, 1])
print(poly)