aboutsummaryrefslogtreecommitdiff
path: root/model/time_simple_mlp_tgtcls.py
blob: 35c8d8ad58dacb7ef5010dc9264435b4d3b49698 (plain) (blame)
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
import numpy
import theano
from theano import tensor
from blocks.bricks import application, Softmax

import error
from model.mlp import FFMLP, Stream


class Model(FFMLP):
    def __init__(self, config, **kwargs):
        super(Model, self, output_layer=Softmax).__init__(config, **kwargs)
        self.classes = theano.shared(numpy.array(config.tgtcls, dtype=theano.config.floatX), name='classes')
        self.inputs.append('input_time')

    @application(outputs=['duration'])
    def predict(self, **kwargs):
        cls_probas = super(Model, self).predict(**kwargs)
        return kwargs['input_time'] + tensor.dot(cls_probas, self.classes)

    @predict.property('inputs')
    def predict_inputs(self):
        return self.inputs

    @application(outputs=['cost'])
    def cost(self, **kwargs):
        y_hat = self.predict(**kwargs)
        y = kwargs['travel_time']
        return error.rmsle(y_hat.flatten(), y.flatten())

    @cost.property('inputs')
    def cost_inputs(self):
        return self.inputs + ['travel_time']