Exemple #1
0
 def test_format(self):
     v = Vector(1, 2222, 33)
     self.assertLines(v.format(), [
         "   1",
         "2222",
         "  33",
     ])
Exemple #2
0
    def test_homogeneous_multiplication(self):
        # Swap X and Y axes and translate by <2, 3, 4>
        m = affine_matrix(Y, X, Z, [2, 3, 4])

        self.assertEqual(m.homogeneous_mul(Vector(0, 0, 0)), Vector(2, 3, 4))
        self.assertEqual(m.homogeneous_mul(Vector(10, 20, 30)),
                         Vector(22, 13, 34))
Exemple #3
0
    def test_construction(self):
        # Single size
        with self.assertNothingRaised(): Plane(Vector(1, 2, 3), 0)
        with self.assertNothingRaised(): Plane(      [1, 2, 3], 0)

        # Invalid
        with self.assertRaises(ValueError): Plane(Vector(0, 0, 0), 0)  # Zero normal
        with self.assertRaises(TypeError): Plane(Vector(1, 2, 3), "0")  # Wrong offset type
        with self.assertRaises(TypeError): Plane(Vector(1, 2, 3))  # Offset missing
        with self.assertRaises(TypeError): Plane(1, 0)  # Wrong type
Exemple #4
0
    def test_equality(self):
        v = Vector(1, 2, 3)

        self.assertEqual(v, Vector(1, 2, 3))
        self.assertNotEqual(v, Vector(1, 2, 3, 4))
        self.assertNotEqual(v, Vector(1, 2))
        self.assertNotEqual(v, Vector(1, 2, 4))
        self.assertNotEqual(v, None)
        self.assertNotEqual(v, [1, 2, 3])
        self.assertNotEqual(v, (1, 2, 3))
        self.assertNotEqual(v, "one")
Exemple #5
0
    def test_length(self):
        self.assertEqual(Vector().length, 0)

        self.assertEqual(Vector(2).length, 2)

        self.assertEqual(Vector(2, 0).length, 2)
        self.assertEqual(Vector(0, 2).length, 2)
        self.assertEqual(Vector(-2, 0).length, 2)
        self.assertEqual(Vector(0, -2).length, 2)

        self.assertEqual(Vector(3, 4).length, 5)
        self.assertEqual(Vector(2, 3, 6).length, 7)
        self.assertEqual(Vector(2, 6, -3).length, 7)
        self.assertEqual(Vector(0, 0, 0).length, 0)
Exemple #6
0
    def test_construction(self):
        # Valid
        with self.assertNothingRaised():
            Layer(Vector(1, 2, 3), 0, 5)
        with self.assertNothingRaised():
            Layer(Vector(1, 2, 3), 5, 0)
        with self.assertNothingRaised():
            Layer(Vector(1, 2, 3), 4, 5)
        with self.assertNothingRaised():
            Layer([1, 2, 3], 4, 5)

        # Zero size
        with self.assertWarnsRegex(UserWarning, r'offsets are equal'):
            Layer(X, 4, 4)

        # Invalid
        with self.assertRaises(ValueError):
            Layer(Vector(0, 0, 0), 4, 5)  # Zero normal
        with self.assertRaises(TypeError):
            Layer(Vector(1, 2, 3), "0", 5)
        with self.assertRaises(TypeError):
            Layer(Vector(1, 2, 3), 0, "5")
        with self.assertRaises(TypeError):
            Layer(Vector(1, 2, 3))  # Offsets missing
        with self.assertRaises(TypeError):
            Layer(Vector(1, 2, 3), 4)  # Offset missing
        with self.assertRaises(TypeError):
            Layer(1, 4, 5)  # Wrong type
Exemple #7
0
    def test_length_squared(self):
        self.assertEqual(Vector().length_squared, 0)

        self.assertEqual(Vector(2).length_squared, 4)

        self.assertEqual(Vector(2, 0).length_squared, 4)
        self.assertEqual(Vector(0, 2).length_squared, 4)
        self.assertEqual(Vector(-2, 0).length_squared, 4)
        self.assertEqual(Vector(0, -2).length_squared, 4)

        self.assertEqual(Vector(3, 4).length_squared, 25)
        self.assertEqual(Vector(2, 3, 6).length_squared, 49)
        self.assertEqual(Vector(2, 6, -3).length_squared, 49)
        self.assertEqual(Vector(0, 0, 0).length_squared, 0)
Exemple #8
0
    def test_scalar_division(self):
        v = Vector(1, 2, 3)

        # Vector / Number
        self.assertEqual(v / 1, Vector(1, 2, 3))
        self.assertEqual(v / 2, Vector(0.5, 1, 1.5))
        self.assertEqual(v / 0.5, Vector(2, 4, 6))

        # Vector / 0 is invalid
        with self.assertRaises(ZeroDivisionError):
            v / 0

        # Number / Vector is undefined
        with self.assertRaises(TypeError):
            1 / v
Exemple #9
0
    def test_iterable_immutability(self):
        v = Vector(1, 2, 3)

        self.assertEqual(list(v), [1, 2, 3])
        values = list(v)
        values[0] = 0
        self.assertEqual(list(v), [1, 2, 3])
Exemple #10
0
    def test_scalar_multiplication(self):
        v = Vector(1, 2, 3)

        # Vector * Number
        self.assertEqual(v * 1, Vector(1, 2, 3))
        self.assertEqual(v * 2, Vector(2, 4, 6))
        self.assertEqual(v * 0.5, Vector(0.5, 1, 1.5))
        self.assertEqual(v * 0, Vector(0, 0, 0))

        # Number * Vector
        self.assertEqual(1 * v, Vector(1, 2, 3))
        self.assertEqual(2 * v, Vector(2, 4, 6))
        self.assertEqual(0.5 * v, Vector(0.5, 1, 1.5))
        self.assertEqual(0 * v, Vector(0, 0, 0))
Exemple #11
0
    def test_is_zero(self):
        self.assertTrue(Vector().is_zero)
        self.assertTrue(Vector(0).is_zero)
        self.assertTrue(Vector(0, 0).is_zero)
        self.assertTrue(Vector(0, 0, 0).is_zero)

        self.assertTrue(Vector(0.0).is_zero)

        self.assertFalse(Vector(1).is_zero)
        self.assertFalse(Vector(1, 0).is_zero)
        self.assertFalse(Vector(1, 0, 0).is_zero)
Exemple #12
0
    def test_valid_type(self):
        self.assertTrue(Vector.valid_type(Vector(1, 2, 3)))
        self.assertTrue(Vector.valid_type((1, 2, 3)))
        self.assertTrue(Vector.valid_type([1, 2, 3]))

        self.assertFalse(Vector.valid_type(0))
        self.assertFalse(Vector.valid_type(1))
        self.assertFalse(Vector.valid_type("0"))
Exemple #13
0
    def __init__(self, normal, offset):
        super().__init__()

        normal = Vector.convert(normal, "normal", required_length=3)
        if normal.is_zero:
            raise ValueError("Normal vector is zero")

        offset = number.convert(offset, "offset")

        self._normal = normal
        self._offset = offset
Exemple #14
0
    def test_invalid_addition_subtraction(self):
        v = Vector(1, 2, 3)

        for invalid in [0, None, ""]:
            with self.assertRaises(TypeError):
                v + invalid
            with self.assertRaises(TypeError):
                invalid + v
            with self.assertRaises(TypeError):
                v - invalid
            with self.assertRaises(TypeError):
                invalid - v
Exemple #15
0
    def test_invalid_multiplication_division(self):
        v = Vector(1, 2, 3)

        for invalid in [None, ""]:
            with self.assertRaises(TypeError):
                v * invalid
            with self.assertRaises(TypeError):
                invalid * v
            with self.assertRaises(TypeError):
                v / invalid
            with self.assertRaises(TypeError):
                invalid / v
Exemple #16
0
    def test_construction(self):
        # Empty
        self.assertEqual(list(Vector()), [])

        # Non-empty
        self.assertEqual(Vector(1)._values, [1])
        self.assertEqual(Vector(1, 2)._values, [1, 2])
        self.assertEqual(Vector(1, 2, 3)._values, [1, 2, 3])

        with self.assertRaises(TypeError):
            Vector([1, 2])
        with self.assertRaises(TypeError):
            Vector([1, "2"])
        with self.assertRaises(TypeError):
            Vector([1, None])
Exemple #17
0
    def test_item(self):
        v = Vector(1, 2, 3)

        # Positive index
        self.assertEqual(v[0], 1)
        self.assertEqual(v[1], 2)
        self.assertEqual(v[2], 3)

        # Negative index counts from the end
        self.assertEqual(v[-1], 3)
        self.assertEqual(v[-2], 2)
        self.assertEqual(v[-3], 1)

        # Index out of range
        with self.assertRaises(IndexError):
            v[4]

        # Multi-index
        with self.assertRaises(TypeError):
            v[2, 0]
Exemple #18
0
 def test_len(self):
     self.assertEqual(len(Vector()), 0)
     self.assertEqual(len(Vector(1)), 1)
     self.assertEqual(len(Vector(1, 2, 3)), 3)
Exemple #19
0
 def test_dimensions(self):
     self.assertEqual(Vector().dimensions, 0)
     self.assertEqual(Vector(1).dimensions, 1)
     self.assertEqual(Vector(1, 2, 3).dimensions, 3)
Exemple #20
0
 def test_inhomogeneous(self):
     self.assertEqual(Vector(0, 0, 0, 1).inhomogeneous(), Vector(0, 0, 0))
     self.assertEqual(Vector(1, 2, 3, 1).inhomogeneous(), Vector(1, 2, 3))
     self.assertEqual(Vector(2, 4, 6, 2).inhomogeneous(), Vector(1, 2, 3))
     with self.assertRaises(ValueError):
         Vector(1, 2, 3, 0).inhomogeneous()
Exemple #21
0
 def test_homogeneous(self):
     self.assertEqual(Vector(0, 0, 0).homogeneous(), Vector(0, 0, 0, 1))
     self.assertEqual(Vector(1, 2, 3).homogeneous(), Vector(1, 2, 3, 1))
Exemple #22
0
 def test_replace(self):
     self.assertEqual(Vector(1, 2, 3).replace(0, 1), Vector(1, 2, 3))
     self.assertEqual(Vector(0, 0, 3).replace(0, 1), Vector(1, 1, 3))
     self.assertEqual(
         Vector(1, 2, 3).replace(1, 0).replace(2, 0), Vector(0, 0, 3))
Exemple #23
0
    def test_closest_axis(self):
        # Axis vectors (2D)
        self.assertEqual(Vector(1, 0).closest_axis(), Vector(1, 0))
        self.assertEqual(Vector(0, 1).closest_axis(), Vector(0, 1))
        self.assertEqual(Vector(-1, 0).closest_axis(), Vector(-1, 0))
        self.assertEqual(Vector(0, -1).closest_axis(), Vector(0, -1))

        # Arbitrary vectors (2D)
        self.assertEqual(Vector(1, 2).closest_axis(), Vector(0, 1))
        self.assertEqual(Vector(-1, 2).closest_axis(), Vector(0, 1))
        self.assertEqual(Vector(1, -2).closest_axis(), Vector(0, -1))
        self.assertEqual(Vector(-1, -2).closest_axis(), Vector(0, -1))

        # Vectors along axis (3D)
        self.assertEqual(Vector(1, 0, 0).closest_axis(), X)
        self.assertEqual(Vector(0, 2, 0).closest_axis(), Y)
        self.assertEqual(Vector(0, 0, 3).closest_axis(), Z)
        self.assertEqual(Vector(-1, 0, 0).closest_axis(), -X)
        self.assertEqual(Vector(0, -2, 0).closest_axis(), -Y)
        self.assertEqual(Vector(0, 0, -3).closest_axis(), -Z)

        # Arbitrary vectors (3D)
        self.assertEqual(Vector(1, 2, 3).closest_axis(), Z)
        self.assertEqual(Vector(1, 3, 2).closest_axis(), Y)
        self.assertEqual(Vector(2, 1, 3).closest_axis(), Z)
        self.assertEqual(Vector(2, 3, 1).closest_axis(), Y)
        self.assertEqual(Vector(3, 1, 2).closest_axis(), X)
        self.assertEqual(Vector(3, 2, 1).closest_axis(), X)
Exemple #24
0
    def test_convert(self):
        # Regular call without length check
        self.assertEqual(Vector.convert(Vector(1, 2, 3), "dummy"),
                         Vector(1, 2, 3))  # From Vector
        self.assertEqual(Vector.convert([1, 2, 3], "dummy"),
                         Vector(1, 2, 3))  # From list
        self.assertEqual(Vector.convert((1, 2, 3), "dummy"),
                         Vector(1, 2, 3))  # From tuple

        # Calling with a vector does not construct a new vector
        v = Vector(1, 2, 3)
        self.assertIs(Vector.convert(v, "dummy"), v)

        # Empty
        self.assertEqual(Vector.convert([], "dummy"), Vector())

        # Length check
        self.assertEqual(Vector.convert([1, 2, 3], "dummy", required_length=3),
                         Vector(1, 2, 3))  # Success
        with self.assertRaises(ValueError):
            Vector.convert([1, 2, 3], "dummy", required_length=4)  # Failure

        # Invalid values
        with self.assertRaises(TypeError):
            Vector.convert(None, "dummy", None)
        with self.assertRaises(TypeError):
            Vector.convert(1, "dummy", None)
        with self.assertRaises(TypeError):
            Vector.convert("", "dummy", None)
        with self.assertRaises(TypeError):
            Vector.convert("123", "dummy", None)
        with self.assertRaises(TypeError):
            Vector.convert([1, 2, "3"], "dummy", None)
Exemple #25
0
    def test_collinear(self):
        # Same vector
        self.assertTrue(X.collinear(X))
        self.assertTrue(Y.collinear(Y))
        self.assertTrue(Z.collinear(Z))

        # Reverse direction
        self.assertTrue(X.collinear(-X))
        self.assertTrue(Y.collinear(-Y))
        self.assertTrue(Z.collinear(-Z))

        # Scaled
        self.assertTrue(X.collinear(2 * X))
        self.assertTrue(Y.collinear(2 * Y))
        self.assertTrue(Z.collinear(2 * Z))

        # Orthogonal
        self.assertFalse(X.collinear(Y))
        self.assertFalse(Y.collinear(Z))
        self.assertFalse(Z.collinear(X))

        # Arbitrary collinear
        self.assertTrue(Vector(1, 2, 3).collinear(Vector(1, 2, 3)))
        self.assertTrue(Vector(1, 2, 3).collinear(Vector(-1, -2, -3)))
        self.assertTrue(Vector(1, 2, 3).collinear(Vector(2, 4, 6)))
        self.assertTrue(Vector(1, 2, 3).collinear(Vector(-2, -4, -6)))

        # With zero
        self.assertTrue(Vector(1, 2, 0).collinear(Vector(1, 2, 0)))
        self.assertTrue(Vector(1, 2, 0).collinear(Vector(2, 4, 0)))

        # Arbitrary non-collinear
        self.assertFalse(Vector(1, 2, 3).collinear(Vector(1, 2, 4)))
        self.assertFalse(Vector(1, 2, 3).collinear(Vector(1, 2, 0)))
Exemple #26
0
    def test_normal(self):
        test_values = [
            # Different lengths
            Vector(1, 2),
            Vector(1, 2, 3),
            Vector(1, 2, 3, 4),

            # Different orders
            Vector(1, 2, 3),
            Vector(1, 3, 2),
            Vector(2, 1, 3),
            Vector(2, 3, 1),
            Vector(3, 1, 2),
            Vector(3, 2, 1),

            # Unit vectors (only one non-zero component)
            Vector(1, 0, 0),
            Vector(0, 1, 0),
            Vector(0, 0, 1),

            # Identical components
            Vector(1, 2, 2),
            Vector(2, 1, 2),
            Vector(2, 2, 1),
            Vector(2, 1, 1),
            Vector(1, 2, 1),
            Vector(1, 1, 2),
            Vector(1, 1, 1),
        ]

        for value in test_values:
            normal = value.normal()
            self.assertEqual(len(normal), len(value))
            self.assertNotEqual(normal.length, 0)
            self.assertNotEqual(value, normal)
            self.assertEqual(value.dot(normal), 0)

        # Invalid
        with self.assertRaises(ValueError):
            Vector().normal()
        with self.assertRaises(ValueError):
            Vector(1).normal()
        with self.assertRaises(ValueError):
            Vector(0, 0, 0).normal()
Exemple #27
0
    def test_angle(self):
        # Colinear 2D
        self.assertAlmostEqual(Vector(1, 0).angle(Vector(1, 0)), 0.0 * degree)
        self.assertAlmostEqual(
            Vector(2, 3.4).angle(Vector(2, 3.4)), 0.0 * degree)

        # Generic 2D
        self.assertAlmostEqual(Vector(1, 0).angle(Vector(1, 1)), 45.0 * degree)
        self.assertAlmostEqual(Vector(1, 0).angle(Vector(0, 2)), 90.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0).angle(Vector(-1, 1)), 135.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0).angle(Vector(-1, 0)), 180.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0).angle(Vector(-2, 0)), 180.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 1).angle(Vector(-1, 1)), 90.0 * degree)

        # Colinear 3D
        self.assertAlmostEqual(
            Vector(1, 0, 0).angle(Vector(1, 0, 0)), 0.0 * degree)
        self.assertAlmostEqual(
            Vector(2, 3.4, 0).angle(Vector(2, 3.4, 0)), 0.0 * degree)
        self.assertAlmostEqual(
            Vector(2, 3.4, -5.67).angle(Vector(2, 3.4, -5.67)), 0.0 * degree)

        # Planar 3D
        self.assertAlmostEqual(
            Vector(1, 0, 0).angle(Vector(1, 0, 0)), 0.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0, 0).angle(Vector(1, 1, 0)), 45.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0, 0).angle(Vector(0, 2, 0)), 90.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0, 0).angle(Vector(-1, 1, 0)), 135.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0, 0).angle(Vector(-1, 0, 0)), 180.0 * degree)
        self.assertAlmostEqual(
            Vector(1, 0, 0).angle(Vector(-2, 0, 0)), 180.0 * degree)

        # Generic 3D
        self.assertAlmostEqual(
            Vector(1, 1, 1).angle(Vector(-1, -1, -1)), 180.0 * degree)
Exemple #28
0
    def test_snap_to_axis(self):
        # Axis vectors (2D)
        self.assertEqual(Vector(1, 0).snap_to_axis(), Vector(1, 0))
        self.assertEqual(Vector(0, 1).snap_to_axis(), Vector(0, 1))
        self.assertEqual(Vector(-1, 0).snap_to_axis(), Vector(-1, 0))
        self.assertEqual(Vector(0, -1).snap_to_axis(), Vector(0, -1))

        # Arbitrary vectors (2D)
        self.assertEqual(Vector(1, 2).snap_to_axis(), Vector(0, 2))
        self.assertEqual(Vector(-1, 2).snap_to_axis(), Vector(0, 2))
        self.assertEqual(Vector(1, -2).snap_to_axis(), Vector(0, -2))
        self.assertEqual(Vector(-1, -2).snap_to_axis(), Vector(0, -2))

        # Vectors along axis (3D)
        self.assertEqual(Vector(1, 0, 0).snap_to_axis(), 1 * X)
        self.assertEqual(Vector(0, 2, 0).snap_to_axis(), 2 * Y)
        self.assertEqual(Vector(0, 0, 3).snap_to_axis(), 3 * Z)
        self.assertEqual(Vector(-1, 0, 0).snap_to_axis(), -1 * X)
        self.assertEqual(Vector(0, -2, 0).snap_to_axis(), -2 * Y)
        self.assertEqual(Vector(0, 0, -3).snap_to_axis(), -3 * Z)

        # Arbitrary vectors (3D)
        self.assertEqual(Vector(1, 2, 3).snap_to_axis(), 3 * Z)
        self.assertEqual(Vector(1, 3, 2).snap_to_axis(), 3 * Y)
        self.assertEqual(Vector(2, 1, 3).snap_to_axis(), 3 * Z)
        self.assertEqual(Vector(2, 3, 1).snap_to_axis(), 3 * Y)
        self.assertEqual(Vector(3, 1, 2).snap_to_axis(), 3 * X)
        self.assertEqual(Vector(3, 2, 1).snap_to_axis(), 3 * X)
Exemple #29
0
    def test_normalized(self):
        # 1D
        self.assertEqual(Vector(2).normalized(), Vector(1))
        self.assertEqual(Vector(-2).normalized(), Vector(-1))

        # 2D
        self.assertEqual(Vector(3, 4).normalized(), Vector(0.6, 0.8))
        self.assertEqual(Vector(-3, 4).normalized(), Vector(-0.6, 0.8))

        # 3D
        self.assertEqual(
            Vector(9, 12, 20).normalized(), Vector(0.36, 0.48, 0.8))
        self.assertEqual(
            Vector(-9, -12, 20).normalized(), Vector(-0.36, -0.48, 0.8))

        # Linear 3D
        self.assertEqual(Vector(2, 0, 0).normalized(), Vector(1, 0, 0))
        self.assertEqual(Vector(-2, 0, 0).normalized(), Vector(-1, 0, 0))

        # Planar 3D
        self.assertEqual(Vector(3, 4, 0).normalized(), Vector(0.6, 0.8, 0))
        self.assertEqual(Vector(-3, 4, 0).normalized(), Vector(-0.6, 0.8, 0))
Exemple #30
0
 def test_zero(self):
     self.assertEqual(list(Vector.zero(0)), [])
     self.assertEqual(list(Vector.zero(1)), [0])
     self.assertEqual(list(Vector.zero(2)), [0, 0])
     self.assertEqual(list(Vector.zero(3)), [0, 0, 0])