Ejemplo n.º 1
0
def main():
    mp.freeze_support()
    args = parser.parse_args()

    fix_path()
    if args.subcommand == 'align':
        run_align_corpus(args, acoustic_languages)
    elif args.subcommand == 'train':
        run_train_corpus(args)
    elif args.subcommand == 'g2p':
        run_g2p(args, g2p_languages)
    elif args.subcommand == 'train_g2p':
        run_train_g2p(args)
    elif args.subcommand == 'validate':
        run_validate_corpus(args)
    elif args.subcommand == 'download':
        run_download(args)
    elif args.subcommand == 'train_lm':
        run_train_lm(args)
    elif args.subcommand == 'train_ivector':
        run_train_ivector_extractor(args)
    elif args.subcommand == 'annotator':
        run_annotator(args)
    elif args.subcommand == 'thirdparty':
        run_thirdparty(args)
    elif args.subcommand == 'transcribe':
        run_transcribe_corpus(args)
    unfix_path()
Ejemplo n.º 2
0
def test_validate():
    args = ThirdpartyDummyArgs()
    with pytest.raises(ArgumentError):

        run_thirdparty(args)
    args.command = 'validate'
    run_thirdparty(args)
Ejemplo n.º 3
0
def test_download():
    bin_dir = os.path.join(TEMP_DIR, 'thirdparty', 'bin')
    if os.path.exists(bin_dir):
        shutil.rmtree(bin_dir, ignore_errors=True)

    assert not validate_kaldi_binaries()

    command = ['thirdparty', 'download']
    args, unknown = parser.parse_known_args(command)
    run_thirdparty(args)

    assert validate_kaldi_binaries()
Ejemplo n.º 4
0
def test_collect():
    bin_dir = os.path.join(TEMP_DIR, 'thirdparty', 'bin')
    backup_dir = os.path.join(TEMP_DIR, 'thirdparty', 'bin_backup')
    if os.path.exists(backup_dir):
        shutil.rmtree(backup_dir)
    assert validate_kaldi_binaries()

    shutil.move(bin_dir, backup_dir)

    assert not validate_kaldi_binaries()

    command = ['thirdparty', 'kaldi', backup_dir]
    args, unknown = parser.parse_known_args(command)
    run_thirdparty(args)

    assert validate_kaldi_binaries()
Ejemplo n.º 5
0
def test_validate():
    command = ['thirdparty', 'validate']
    args, unknown = parser.parse_known_args(command)
    run_thirdparty(args)
Ejemplo n.º 6
0
def main():
    mp.freeze_support()
    args, unknown = parser.parse_known_args()
    fix_path()
    if args.subcommand in ['align', 'train', 'train_ivector']:
        from montreal_forced_aligner.thirdparty.kaldi import validate_alignment_binaries
        if not validate_alignment_binaries():
            print(
                "There was an issue validating Kaldi binaries, please ensure you've downloaded them via the "
                "'mfa thirdparty download' command.  See 'mfa thirdparty validate' for more detailed information "
                "on why this check failed.")
            sys.exit(1)
    elif args.subcommand in ['transcribe']:
        from montreal_forced_aligner.thirdparty.kaldi import validate_transcribe_binaries
        if not validate_transcribe_binaries():
            print(
                "There was an issue validating Kaldi binaries, please ensure you've downloaded them via the "
                "'mfa thirdparty download' command.  See 'mfa thirdparty validate' for more detailed information "
                "on why this check failed.  If you are on MacOS, please note that the thirdparty binaries available "
                "via the download command do not contain the transcription ones.  To get this functionality working "
                "for the time being, please build kaldi locally and follow the instructions for running the "
                "'mfa thirdparty kaldi' command.")
            sys.exit(1)
    elif args.subcommand in ['train_dictionary']:
        from montreal_forced_aligner.thirdparty.kaldi import validate_train_dictionary_binaries
        if not validate_train_dictionary_binaries():
            print(
                "There was an issue validating Kaldi binaries, please ensure you've downloaded them via the "
                "'mfa thirdparty download' command.  See 'mfa thirdparty validate' for more detailed information "
                "on why this check failed.  If you are on MacOS, please note that the thirdparty binaries available "
                "via the download command do not contain the train_dictionary ones.  To get this functionality working "
                "for the time being, please build kaldi locally and follow the instructions for running the "
                "'mfa thirdparty kaldi' command.")
            sys.exit(1)
    elif args.subcommand in ['g2p', 'train_g2p']:
        try:
            import pynini
        except ImportError:
            print(
                "There was an issue importing Pynini, please ensure that it is installed. If you are on Windows, "
                "please use the Windows Subsystem for Linux to use g2p functionality."
            )
            sys.exit(1)
    if args.subcommand == 'align':
        run_align_corpus(args, unknown, acoustic_languages)
    elif args.subcommand == 'train':
        run_train_corpus(args)
    elif args.subcommand == 'g2p':
        run_g2p(args, g2p_languages)
    elif args.subcommand == 'train_g2p':
        run_train_g2p(args)
    elif args.subcommand == 'validate':
        run_validate_corpus(args)
    elif args.subcommand == 'download':
        run_download(args)
    elif args.subcommand == 'train_lm':
        run_train_lm(args)
    elif args.subcommand == 'train_dictionary':
        run_train_dictionary(args)
    elif args.subcommand == 'train_ivector':
        run_train_ivector_extractor(args)
    elif args.subcommand == 'classify_speakers':
        run_classify_speakers(args)
    elif args.subcommand == 'annotator':
        from montreal_forced_aligner.command_line.annotator import run_annotator
        run_annotator(args)
    elif args.subcommand == 'thirdparty':
        run_thirdparty(args)
    elif args.subcommand == 'transcribe':
        run_transcribe_corpus(args)
    elif args.subcommand == 'create_segments':
        run_create_segments(args, unknown)
    elif args.subcommand == 'version':
        print(__version__)
    unfix_path()