read_binarized.py 1.33 KB
Newer Older
Alexei Baevski's avatar
Alexei Baevski committed
1
#!/usr/bin/env python3
2
# Copyright (c) Facebook, Inc. and its affiliates.
Alexei Baevski's avatar
Alexei Baevski committed
3
#
4
5
# This source code is licensed under the MIT license found in the
# LICENSE file in the root directory of this source tree.
Alexei Baevski's avatar
Alexei Baevski committed
6
7
8

import argparse

Myle Ott's avatar
Myle Ott committed
9
from fairseq.data import data_utils, Dictionary, indexed_dataset
Alexei Baevski's avatar
Alexei Baevski committed
10
11
12
13
14


def get_parser():
    parser = argparse.ArgumentParser(
        description='writes text from binarized file to stdout')
15
    # fmt: off
16
    parser.add_argument('--dataset-impl', help='dataset implementation',
17
                        choices=indexed_dataset.get_available_dataset_impl())
18
    parser.add_argument('--dict', metavar='FP', help='dictionary containing known words', default=None)
Alexei Baevski's avatar
Alexei Baevski committed
19
    parser.add_argument('--input', metavar='FP', required=True, help='binarized file to read')
20
    # fmt: on
Alexei Baevski's avatar
Alexei Baevski committed
21
22
23
24

    return parser


25
26
27
28
29
def main():
    parser = get_parser()
    args = parser.parse_args()

    dictionary = Dictionary.load(args.dict) if args.dict is not None else None
Myle Ott's avatar
Myle Ott committed
30
31
32
33
34
35
    dataset = data_utils.load_indexed_dataset(
        args.input,
        dictionary,
        dataset_impl=args.dataset_impl,
        default='lazy',
    )
36
37
38
39
40
41
42
43

    for tensor_line in dataset:
        if dictionary is None:
            line = ' '.join([str(int(x)) for x in tensor_line])
        else:
            line = dictionary.string(tensor_line)

        print(line)
Alexei Baevski's avatar
Alexei Baevski committed
44
45
46


if __name__ == '__main__':
47
    main()