aboutsummaryrefslogtreecommitdiff
path: root/nerv/layer/window.lua
blob: 364929fefb4f88ab732c1c915d059953ec47b3e8 (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
34
35
local WindowLayer = nerv.class("nerv.WindowLayer", "nerv.Layer")

function WindowLayer:__init(id, global_conf, layer_conf)
    nerv.Layer.__init(self, id, global_conf, layer_conf)
    self:check_dim_len(1, 1)
    self:bind_params()
end

function WindowLayer:bind_params()
    self.window = self:find_param("window", self.lconf, self.gconf,
                                nerv.BiasParam,
                                {1, self.dim_out[1]})
end

function WindowLayer:init()
    if self.dim_in[1] ~= self.window.trans:ncol() then
        nerv.error("mismatching dimensions of input and window parameter")
    end
    if self.dim_out[1] ~= self.window.trans:ncol() then
        nerv.error("mismatching dimensions of output and window parameter")
    end
end

function WindowLayer:batch_resize(batch_size)
    -- do nothing
end

function WindowLayer:propagate(input, output)
    output[1]:copy_from(input[1])
    output[1]:scale_rows_by_row(self.window.trans)
end

function WindowLayer:get_params()
    return nerv.ParamRepo({self.window}, self.loc_type)
end