summaryrefslogtreecommitdiff
path: root/kaldi_io/tools/kaldi_to_nerv.cpp
blob: 1edb0f2c7743eb4f8ef75d99ea761818944d0a22 (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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#include <cstdio>
#include <fstream>
#include <string>
#include <cstring>
#include <cassert>

char token[1024];
char output[1024];
double mat[4096][4096];
int main(int argc, char **argv) {
    std::ofstream fout;
    fout.open(argv[1]);
    int cnt = 0;
    bool shift;
    while (scanf("%s", token) != EOF)
    {
        int nrow, ncol;
        int i, j;
        if (strcmp(token, "<AffineTransform>") == 0)
        {
            double lrate, blrate, mnorm;
            scanf("%d %d", &ncol, &nrow);
            scanf("%s %lf %s %lf %s %lf",
                    token, &lrate, token, &blrate, token, &mnorm);
            scanf("%s", token);
            assert(*token == '[');
            printf("%d %d\n", nrow, ncol);
            for (j = 0; j < ncol; j++)
                for (i = 0; i < nrow; i++)
                    scanf("%lf", mat[i] + j);
            long base = fout.tellp();
            sprintf(output, "%16d", 0);
            fout << output;
            sprintf(output, "{type=\"nerv.LinearTransParam\",id=\"affine%d_ltp\"}\n",
                    cnt);
            fout << output;
            sprintf(output, "%d %d\n", nrow, ncol);
            fout << output;
            for (i = 0; i < nrow; i++)
            {
                for (j = 0; j < ncol; j++)
                    fout << mat[i][j] << " ";
                fout << std::endl;
            }
            long length = fout.tellp() - base;
            fout.seekp(base);
            sprintf(output, "[%13lu]\n", length);
            fout << output;
            fout.seekp(0, std::ios_base::end);
            scanf("%s", token);
            assert(*token == ']');
            if (scanf("%s", token) == 1 && *token == '[')
            {
                base = fout.tellp();
                for (j = 0; j < ncol; j++)
                    scanf("%lf", mat[0] + j);
                sprintf(output, "%16d", 0);
                fout << output;
                sprintf(output, "{type=\"nerv.BiasParam\",id=\"affine%d_bp\"}\n",
                        cnt);
                fout << output;
                sprintf(output, "1 %d\n", ncol);
                fout << output;
                for (j = 0; j < ncol; j++)
                    fout << mat[0][j] << " ";
                fout << std::endl;
                length = fout.tellp() - base;
                fout.seekp(base);
                sprintf(output, "[%13lu]\n", length);
                fout << output;
                fout.seekp(0, std::ios_base::end);
                cnt++;
            }
        }
        else if ((shift = (strcmp(token, "<AddShift>") == 0)) ||
                strcmp(token, "<Rescale>") == 0)
        {
            double lrate, blrate, mnorm;
            scanf("%d %d", &ncol, &ncol);
            scanf("%s %lf",
                    token, &lrate);
            scanf("%s", token);
            assert(*token == '[');
            printf("%d\n", ncol);
            for (j = 0; j < ncol; j++)
                    scanf("%lf", mat[0] + j);
            long base = fout.tellp();
            sprintf(output, "%16d", 0);
            fout << output;
            sprintf(output, "{type=\"nerv.BiasParam\",id=\"%s%d\"}\n",
                    shift ? "bias" : "window",
                    cnt);
            fout << output;
            sprintf(output, "%d %d\n", 1, ncol);
            fout << output;
            for (j = 0; j < ncol; j++)
                fout << mat[0][j] << " ";
            fout << std::endl;
            long length = fout.tellp() - base;
            fout.seekp(base);
            sprintf(output, "[%13lu]\n", length);
            fout << output;
            fout.seekp(0, std::ios_base::end);
            scanf("%s", token);
            assert(*token == ']');
        }
    }
    return 0;
}