-
Notifications
You must be signed in to change notification settings - Fork 2
/
exercise2.py
45 lines (34 loc) · 1.27 KB
/
exercise2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
from __future__ import annotations
from math import isclose
from exercise1 import Vector
class Point2D:
def __init__(self, x: float, y: float) -> None:
self._coordinates = Vector([x, y])
@property
def x(self) -> float:
return self._coordinates[0]
@property
def y(self) -> float:
return self._coordinates[1]
def __iadd__(self, vector: Vector) -> Point2D:
assert len(vector._coordinates) == 2
return Point2D(self.x + vector[0], self.y + vector[1])
def __isub__(self, other: Vector) -> Point2D:
assert len(other._coordinates) == 2
return Point2D(self.x - other._coordinates[0], self.y - other._coordinates[1])
def test_point_construction() -> None:
point = Point2D(1.0, 42.0)
assert point.x == 1.0
assert point.y == 42.0
def test_point_vector_addition() -> None:
point = Point2D(1.0, 2.0)
# Task A: make the test below pass (implement __iadd__)
point += Vector([1.1, 2.2])
assert isclose(point.x, 2.1)
assert isclose(point.y, 4.2)
def test_point_vector_subtraction() -> None:
point = Point2D(1.0, 2.0)
# Task B: make the test below pass (implement __isub__)
point -= Vector([1.1, 2.2])
assert isclose(point.x, -0.1)
assert isclose(point.y, -0.2)