1

同様のエラー メッセージの質問を確認しましたが、私の状況にぴったり合うものは見つかりませんでした。HTK、Prosodylab-aligner、および SoX を使用して、.wav ファイルを .lab ファイルと時間調整しようとしています。

これが私の入力です(Prosodylab-alignerを使用):

./align.py /path/to/files

表示されるのは、次のコード行だけです。

Command 'sox' returned non-zero exit status 2

このコードの意味を調べたところ、コマンドまたはキーワードが欠落していることを意味しているようです

問題はalign.pyファイルにあると思いますが、正確な場所はわかりません。SoX を参照するファイルの領域は次のとおりです。

def _check_aud(self, wav_list, train=False):
    """
    Check audio files, mixing down to mono and downsampling if
    necessary. Writes copy_scp and the training or testing SCP files
    """
    copy_scp = open(self.copy_scp, 'a')
    check_scp = open(self.train_scp if train else self.test_scp, 'w')
    i = 0
    if self.has_sox:
        for wav in wav_list:
            head = os.path.splitext(os.path.split(wav)[1])[0]
            mfc = os.path.join(self.aud_dir, head + '.mfc')
            w = wave.open(wav, 'r')
            pids = []  # pids
            if (w.getframerate() != self.sr) or (w.getnchannels() > 1):
                new_wav = os.path.join(self.aud_dir, head + '.wav')
                pids.append(Popen(['sox', '-G', wav, '-b', '16',
                                   new_wav, 'remix', '-',
                                   'rate', str(self.sr),
                                   'dither', '-s'], stderr=PIPE))
                wav = new_wav
            for pid in pids:  # do a join
                retcode = pid.wait()
                if retcode != 0:
                    raise CalledProcessError(retcode, 'sox')
            print >> copy_scp, '"{0}" "{1}"'.format(wav, mfc)
            print >> check_scp, '"{0}"'.format(mfc)
            w.close()
    else:
        for wav in wav_list:
            head = os.path.splitext(wav)[0]
            mfc = os.path.join(self.aud_dir, head + '.mfc')
            w = wave.open(wav, 'r')
            if (w.getframerate() != self.sr) or (w.getnchannels() != 1):
                error('File {0} needs resampled but Sox not found ', w)
            print >> copy_scp, '"{0}" "{1}"'.format(wav, mfc)
            print >> check_scp, '"{0}"'.format(mfc)
            w.close()
    copy_scp.close()
    check_scp.close()
4

1 に答える 1

0

呼び出しのsoxコマンド ラインを のpids.append(Popen(...))ような変数に分解し、cmdそれを実行する前に出力します。

これにより、問題を再現できるコマンドラインが得られ、より説明的なエラーメッセージが表示され、引数を微調整して問題を絞り込むことができます。

            # ...
            new_wav = os.path.join(self.aud_dir, head + '.wav')

            cmd = ['sox', '-G', wav, '-b', '16', 
                   new_wav, 'remix', '-', 'rate',
                   str(self.sr), 'dither', '-s']
            print "About to execute command:\n%s" % ' '.join(cmd)
            pids.append(Popen(cmd, stderr=PIPE))

            wav = new_wav
            # ...
于 2014-06-16T19:29:09.850 に答える