blob: 58758e82c997ce011e0ccc711bfb76fc347cd89c (
plain) (
tree)
|
|
local DuplicateLayer = nerv.class('nerv.DuplicateLayer', 'nerv.Layer')
function DuplicateLayer:__init(id, global_conf, layer_conf)
self.id = id
self.dim_in = layer_conf.dim_in
self.dim_out = layer_conf.dim_out
self.gconf = global_conf
self:check_dim_len(1, -1)
if #self.dim_out < 1 then
nerv.error('no output specified')
end
for i = 1, #self.dim_out do
if self.dim_out[i] ~= self.dim_in[1] then
nerv.error('mismatching dimensions of outputs')
end
end
end
function DuplicateLayer:init(batch_size)
end
function DuplicateLayer:batch_resize(batch_size)
end
function DuplicateLayer:update(bp_err, input, output)
end
function DuplicateLayer:propagate(input, output)
for i = 1, #self.dim_out do
output[i]:copy_from(input[1])
-- FIXME: use reference copy to speed up
end
end
function DuplicateLayer:back_propagate(bp_err, next_bp_err, input, output)
next_bp_err:copy_from(bp_err[1])
for i = 2, #self.dim_out do
next_bp_err:add(next_bp_err, bp_err[i], 1.0, 1.0)
end
end
|