summaryrefslogtreecommitdiff
path: root/lua/main.lua
blob: 684efac0db0f528535a9ea266ec448b5e7bfa8c4 (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
36
37
38
39
40
41
42
43
nerv.include('reader.lua')
nerv.include('timer.lua')
nerv.include('config.lua')
nerv.include(arg[1])

local global_conf = get_global_conf()
local timer = global_conf.timer

timer:tic('IO')

local data_path = 'nerv/nerv/examples/lmptb/PTBdata/'
local train_reader = nerv.Reader(data_path .. 'vocab', data_path .. 'ptb.train.txt.adds')
local val_reader = nerv.Reader(data_path .. 'vocab', data_path .. 'ptb.valid.txt.adds')

local train_data = train_reader:get_all_batch(global_conf)
local val_data = val_reader:get_all_batch(global_conf)

local layers = get_layers(global_conf)
local connections = get_connections(global_conf)

local NN = nerv.NN(global_conf, train_data, val_data, layers, connections)

timer:toc('IO')
timer:check('IO')
io.flush()

timer:tic('global')
local best_cv = 1e10
for i = 1, global_conf.max_iter do
    timer:tic('Epoch' .. i)
    local train_ppl, val_ppl = NN:epoch()
    if val_ppl < best_cv then
        best_cv = val_ppl
    else
        global_conf.lrate = global_conf.lrate / 2.0
    end
    nerv.printf('Epoch %d: %f %f %f\n', i, global_conf.lrate, train_ppl, val_ppl)
    timer:toc('Epoch' .. i)
    timer:check('Epoch' .. i)
    io.flush()
end
timer:toc('global')
timer:check('global')