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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
use super::Point;
use super::Vector;
use array_init::array_init;
use num_traits::NumOps;
use std::ops::Add;
use std::ops::AddAssign;
use std::ops::Index;
impl<'a, 'b, T, const N: usize> Add<&'a Vector<T, N>> for &'b Point<T, N>
where
for<'c> &'c T: Add<&'c T, Output = T>,
{
type Output = Point<T, N>;
fn add(self: &'b Point<T, N>, other: &'a Vector<T, N>) -> Self::Output {
Point {
array: array_init(|i| self.array.index(i) + other.0.index(i)),
}
}
}
impl<T, const N: usize> Add<Vector<T, N>> for Point<T, N>
where
for<'a> &'a T: Add<&'a T, Output = T>,
{
type Output = Point<T, N>;
fn add(self: Point<T, N>, other: Vector<T, N>) -> Self::Output {
self.add(&other)
}
}
impl<T, const N: usize> Add<&Vector<T, N>> for Point<T, N>
where
for<'a> &'a T: Add<&'a T, Output = T>,
{
type Output = Point<T, N>;
fn add(self: Point<T, N>, other: &Vector<T, N>) -> Self::Output {
(&self).add(other)
}
}
impl<T, const N: usize> AddAssign<&Vector<T, N>> for Point<T, N>
where
T: NumOps + Clone + AddAssign,
{
fn add_assign(&mut self, other: &Vector<T, N>) {
for i in 0..N {
self.array[i] += other.0.index(i).clone()
}
}
}
impl<T, const N: usize> AddAssign<Vector<T, N>> for Point<T, N>
where
T: NumOps + Clone + AddAssign,
{
fn add_assign(&mut self, other: Vector<T, N>) {
self.add_assign(&other)
}
}