blob: a12f6bbbfc233af24bacad02212ad16b26c974b5 (
plain)
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
44
45
46
47
48
49
50
51
52
53
54
55
|
#include "global_data.h"
#include "parser.h"
#include "learner.h"
void save_predictor(vw& all, string reg_name, size_t current_pass);
namespace LEARNER
{
void generic_driver(vw* all)
{
example* ec = NULL;
all->l->init_driver();
while ( true )
{
if ((ec = VW::get_example(all->p)) != NULL)//semiblocking operation.
{
if (ec->indices.size() > 1) // 1+ nonconstant feature. (most common case first)
{
all->l->learn(*ec);
all->l->finish_example(*all, *ec);
}
else if (ec->end_pass)
{
all->l->end_pass();
VW::finish_example(*all,ec);
}
else if (ec->tag.size() >= 4 && !strncmp((const char*) ec->tag.begin, "save", 4))
{// save state command
string final_regressor_name = all->final_regressor_name;
if ((ec->tag).size() >= 6 && (ec->tag)[4] == '_')
final_regressor_name = string(ec->tag.begin+5, (ec->tag).size()-5);
if (!all->quiet)
cerr << "saving regressor to " << final_regressor_name << endl;
save_predictor(*all, final_regressor_name, 0);
VW::finish_example(*all,ec);
}
else // empty example
{
all->l->learn(*ec);
all->l->finish_example(*all, *ec);
}
}
else if (parser_done(all->p))
{
all->l->end_examples();
return;
}
}
}
}
|