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
56
57
|
/*
Copyright (c) by respective owners including Yahoo!, Microsoft, and
individual contributors. All rights reserved. Released under a BSD
license as described in the file LICENSE.
*/
#ifndef OAA_H
#define OAA_H
#include "io_buf.h"
#include "parse_primitives.h"
#include "global_data.h"
#include "example.h"
#include "parse_args.h"
#include "v_hashmap.h"
namespace OAA
{
struct mc_label {
float label;
float weight;
};
learner setup(vw& all, std::vector<std::string>&, po::variables_map& vm, po::variables_map& vm_file);
size_t read_cached_label(shared_data*, void* v, io_buf& cache);
void cache_label(void* v, io_buf& cache);
void default_label(void* v);
void parse_label(parser* p, shared_data*, void* v, v_array<substring>& words);
void delete_label(void* v);
float weight(void* v);
float initial(void* v);
const label_parser mc_label_parser = {default_label, parse_label,
cache_label, read_cached_label,
delete_label, weight, initial,
NULL,
sizeof(mc_label)};
void output_example(vw& all, example* ec);
inline int example_is_newline(example* ec)
{
// if only index is constant namespace or no index
return ((ec->indices.size() == 0) ||
((ec->indices.size() == 1) &&
(ec->indices.last() == constant_namespace)));
}
inline int example_is_test(example* ec)
{
return (((OAA::mc_label*)ec->ld)->label == (uint32_t)-1);
}
}
#endif
|