forked from Rufflewind/revad
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrevad.py
39 lines (32 loc) · 1023 Bytes
/
revad.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
import math
class Var:
def __init__(self, value):
self.value = value
self.children = []
self.grad_value = None
def grad(self):
if self.grad_value is None:
self.grad_value = sum(weight * var.grad()
for weight, var in self.children)
return self.grad_value
def __add__(self, other):
z = Var(self.value + other.value)
self.children.append((1.0, z))
other.children.append((1.0, z))
return z
def __mul__(self, other):
z = Var(self.value * other.value)
self.children.append((other.value, z))
other.children.append((self.value, z))
return z
def sin(x):
z = Var(math.sin(x.value))
x.children.append((math.cos(x.value), z))
return z
x = Var(0.5)
y = Var(4.2)
z = x * y + sin(x)
z.grad_value = 1.0
assert abs(z.value - 2.579425538604203) <= 1e-15
assert abs(x.grad() - (y.value + math.cos(x.value))) <= 1e-15
assert abs(y.grad() - x.value) <= 1e-15