2011-02-03 08:36:24 -08:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
|
|
|
|
from interp import baker
|
|
|
|
from interp.grid import grid
|
|
|
|
import numpy as np
|
|
|
|
|
2011-06-07 20:43:03 -07:00
|
|
|
from interp.grid import contains
|
2011-02-03 08:36:24 -08:00
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
|
2011-02-03 08:36:24 -08:00
|
|
|
def exact_func(point):
|
2011-09-17 14:38:49 -07:00
|
|
|
x = point[0]
|
|
|
|
y = point[1]
|
|
|
|
return 0.5 + x * x + y
|
|
|
|
|
2011-02-03 08:36:24 -08:00
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
def calculate_error_term(self, a, b, c, d, e, f):
|
2011-02-03 08:36:24 -08:00
|
|
|
B = np.array([
|
2011-09-17 14:38:49 -07:00
|
|
|
self.p1[a] * self.p1[b], self.p1[c] * self.p1[d], self.p1[e] * self.p1[f],
|
|
|
|
self.p2[a] * self.p2[b], self.p2[c] * self.p2[d], self.p2[e] * self.p2[f],
|
|
|
|
self.p3[a] * self.p3[b], self.p3[c] * self.p3[d], self.p3[e] * self.p3[f],
|
|
|
|
self.p4[a] * self.p4[b], self.p4[c] * self.p4[d], self.p4[e] * self.p4[f],
|
|
|
|
])
|
|
|
|
|
|
|
|
B.shape = (4, 3)
|
2011-02-03 08:36:24 -08:00
|
|
|
|
|
|
|
A = np.dot(B.T, B)
|
|
|
|
rhs = np.dot(B.T, self.w)
|
2011-09-17 14:38:49 -07:00
|
|
|
abc = np.linalg.solve(A, rhs)
|
2011-02-03 08:36:24 -08:00
|
|
|
|
|
|
|
err = \
|
2011-09-17 14:38:49 -07:00
|
|
|
abc[0] * self.phis[a] * self.phis[b] + \
|
|
|
|
abc[1] * self.phis[c] * self.phis[d] + \
|
|
|
|
abc[2] * self.phis[e] * self.phis[f]
|
2011-02-03 08:36:24 -08:00
|
|
|
return err
|
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
|
2011-02-15 10:27:45 -08:00
|
|
|
class Test(unittest.TestCase):
|
2011-09-17 14:38:49 -07:00
|
|
|
def setUp(self):
|
|
|
|
self.verts = [
|
|
|
|
[2, 3], # 0
|
|
|
|
[7, 4], # 1
|
|
|
|
[4, 8], # 2
|
|
|
|
[0, 7], # 3, 1
|
|
|
|
[5, 0], # 4, 2
|
|
|
|
[0, 5], # 5, 3
|
|
|
|
[8, 9], # 6, 4
|
|
|
|
]
|
|
|
|
|
|
|
|
self.q = [exact_func(v) for v in self.verts]
|
|
|
|
|
2011-09-17 23:17:06 -07:00
|
|
|
self.g = grid()
|
|
|
|
self.g.verts = self.verts
|
|
|
|
self.g.q = self.q
|
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
self.R, self.R_q = (self.verts[:3], self.q[:3])
|
|
|
|
self.S, self.S_q = (self.verts[3:], self.q[3:])
|
|
|
|
|
|
|
|
self.p1, self.ql1 = baker.qlinear(self.verts[3], self.R, self.q)
|
|
|
|
self.p2, self.ql2 = baker.qlinear(self.verts[4], self.R, self.q)
|
|
|
|
self.p3, self.ql3 = baker.qlinear(self.verts[5], self.R, self.q)
|
|
|
|
self.p4, self.ql4 = baker.qlinear(self.verts[6], self.R, self.q)
|
|
|
|
|
|
|
|
self.q1 = exact_func(self.verts[3])
|
|
|
|
self.q2 = exact_func(self.verts[4])
|
|
|
|
self.q3 = exact_func(self.verts[5])
|
|
|
|
self.q4 = exact_func(self.verts[6])
|
|
|
|
|
|
|
|
self.w = np.array([
|
|
|
|
self.q1 - self.ql1,
|
|
|
|
self.q2 - self.ql2,
|
|
|
|
self.q3 - self.ql3,
|
|
|
|
self.q4 - self.ql4,
|
|
|
|
])
|
|
|
|
|
|
|
|
self.X = [4, 5]
|
|
|
|
|
|
|
|
self.phis, self.qlin = baker.qlinear(self.X, self.R, self.q)
|
|
|
|
self.exact = exact_func(self.X)
|
2011-09-17 14:39:01 -07:00
|
|
|
self.answer = baker.interpolate(self.X, self.R,
|
2011-09-17 14:38:49 -07:00
|
|
|
self.R_q, self.S, self.S_q)
|
2011-02-03 08:36:24 -08:00
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
def test_R_contains_X(self):
|
|
|
|
self.assertTrue(contains(self.X, self.R))
|
2011-02-03 08:36:24 -08:00
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
def test_1(self):
|
|
|
|
a, b, c, d, e, f = (0, 1, 1, 2, 2, 0)
|
|
|
|
err = calculate_error_term(self, a, b, c, d, e, f)
|
2011-09-17 14:39:01 -07:00
|
|
|
self.assertAlmostEqual(err, self.answer.error)
|
2011-02-03 08:36:24 -08:00
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
def test_swap_first_elements(self):
|
|
|
|
a, b, c, d, e, f = (1, 0, 1, 2, 2, 0)
|
|
|
|
err = calculate_error_term(self, a, b, c, d, e, f)
|
2011-09-17 14:39:01 -07:00
|
|
|
self.assertAlmostEqual(err, self.answer.error)
|
2011-02-03 08:36:24 -08:00
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
def test_swap_two_pairs(self):
|
|
|
|
a, b, c, d, e, f = (1, 2, 0, 1, 2, 0)
|
|
|
|
err = calculate_error_term(self, a, b, c, d, e, f)
|
2011-09-17 14:39:01 -07:00
|
|
|
self.assertAlmostEqual(err, self.answer.error)
|
2011-02-03 08:36:24 -08:00
|
|
|
|
2011-09-17 14:38:49 -07:00
|
|
|
def test_swap_all_pairs(self):
|
|
|
|
a, b, c, d, e, f = (0, 2, 0, 1, 2, 1)
|
|
|
|
err = calculate_error_term(self, a, b, c, d, e, f)
|
2011-09-17 14:39:01 -07:00
|
|
|
self.assertAlmostEqual(err, self.answer.error)
|
2011-02-03 08:36:24 -08:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2011-09-17 14:38:49 -07:00
|
|
|
suite = unittest.TestLoader().loadTestsFromTestCase(Test)
|
|
|
|
unittest.TextTestRunner(verbosity=3).run(suite)
|