forked from goodfeli/ccw_tutorial_theano
-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathdoublec.py
33 lines (28 loc) · 947 Bytes
/
doublec.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
from theano import Op, Apply
from theano.tensor import as_tensor_variable
class DoubleC(Op):
__props__ = ()
def make_node(self, x):
x = as_tensor_variable(x)
if x.ndim != 1:
raise TypeError("DoubleC only works on 1D")
return Apply(self, [x], [x.type()])
def c_code(self, node, name, input_names,
output_names, sub):
return """
Py_XDECREF(%(out)s);
%(out)s = (PyArrayObject *)PyArray_NewLikeArray(
%(inp)s, NPY_ANYORDER, NULL, 0);
if (%(out)s == NULL) {
%(fail)s
}
for (npy_intp i = 0; i < PyArray_DIM(%(inp)s, 0); i++) {
*(dtype_%(out)s *)PyArray_GETPTR1(%(out)s, i) =
(*(dtype_%(inp)s *)PyArray_GETPTR1(%(inp)s, i)) * 2;
}
""" % dict(inp=input_names[0], out=output_names[0],
fail=sub["fail"])
def infer_shape(self, node, input_shapes):
return input_shapes
def grad(self, inputs, output_grads):
return [output_grads[0] * 2]