質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

4899閲覧

threading時に起こるpyaudioのエラー

YMD_kts

総合スコア23

Raspberry Pi

Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2018/07/11 08:33

編集2018/07/13 01:26

こちらの質問にあるように常時音を監視して一定異常の音量が鳴った回数を記録するプログラムとLEDの点灯を切り替えるプログラムをthreadingで並列処理させるプログラムを組んだのですが、並列処理はできているようなのデスがpyaudioでエラーが発生してしまいました。

Start Expression 'alsa_snd_pcm_mmap_begin( self->pcm, &areas, &self->offset, numFrames )' failed in 'src/hostapi/alsa/pa_linux_alsa.c', line: 3983 Expression 'PaAlsaStreamComponent_RegisterChannels( &self->capture, &self->bufferProcessor, &captureFrames, &xrun )' failed in 'src/hostapi/alsa/pa_linux_alsa.c', line: 4098 Expression 'PaAlsaStream_SetUpBuffers( stream, &framesGot, &xrun )' failed in 'src/hostapi/alsa/pa_linux_alsa.c', line: 4426 Exception in thread Thread-1: Traceback (most recent call last): File "/usr/lib/python2.7/threading.py", line 801, in __bootstrap_inner self.run() File "/usr/lib/python2.7/threading.py", line 754, in run self.__target(*self.__args, **self.__kwargs) File "/home/pi/Desktop/py/final/judgeFunction.py", line 32, in judgeFunc data = stream.read(CHUNK) File "/usr/lib/python2.7/dist-packages/pyaudio.py", line 608, in read return pa.read_stream(self._stream, num_frames, exception_on_overflow) IOError: [Errno -9999] Unanticipated host error End

このstartとendはLEDの切り替えの合図です
コードと関数を記します

python

1import threading 2import elcFunc as ef 3import judgeFunction as jf 4 5if __name__ == "__main__": 6 thread1 = threading.Thread(target = jf.judgeFunc) 7 thread2 = threading.Thread(target = ef.noteStart) 8 9 thread2.start() 10 thread1.start() 11 12 jf.judgeEnd()

python

1def judgeFunc(): 2 while True: 3 global score 4 data = stream.read(CHUNK) 5 x = np.frombuffer(data, dtype="int16") / 32768.0 6 if x.max() > threshold: 7 score += 1 8 print(score)

python

1def noteStart(): 2 3 global a,i 4 initAll() 5 6 while a == True: 7 print("Start") 8 wiringpi.digitalWrite(GPIO26, LOW) 9 wiringpi.digitalWrite(GPIO21, LOW) 10 11 lf.noteLeft(random.randint(0, 15)) 12 suc = rf.noteRight(random.randint(0, 15)) 13 time.sleep(2) 14 15 while i < 28: 16 lf.noteLeft(suc) 17 suc = rf.noteRight(random.randint(0, 15)) 18 time.sleep(2) 19 i = i+1 20 21 wiringpi.digitalWrite(GPIO21, HIGH) 22 rf.endRight() 23 24 lf.noteLeft(suc) 25 time.sleep(2) 26 27 wiringpi.digitalWrite(GPIO26, HIGH) 28 lf.endLeft() 29 30 a = False

エラーコードで検索をかけても情報が少なく解決できませんでした。
分かる方回答の方よろしくお願いいたします。

追記
jf.judgeEnd関数です。

python

1def judgeEnd(): 2 stream.close() 3 p.terminate()

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

umyu

2018/07/11 15:01 編集

jf.judgeEnd()の処理を質問文のコードに追記してくださいな。
YMD_kts

2018/07/13 01:26

追記しました。
guest

回答1

0

ベストアンサー

jf.judgeEnd()関数の追記ありがとうございました。
環境が無いので、憶測の回答になってしまいますが。

Python

1def judgeEnd(): 2 stream.close() #←原因はこの行です。 3 p.terminate()

そう判断した理由を書きます。

[Errno -9999] Unanticipated host errorで検索すると一番最初のページとして
Using any other values in pyaudio for rate / format / chunk give me the error: [Errno Input overflowed] -9981のページがHITします。

"open" and "close"がポイントだと分かります。

Python

1 thread1 = threading.Thread(target = jf.judgeFunc) 2 thread2 = threading.Thread(target = ef.noteStart) 3 4 thread2.start() 5 thread1.start() 6 7 jf.judgeEnd()

Threadstart()を行った後もメインスレッドの処理は続きます。
stream.close()を実行後に、data = stream.read(CHUNK)が呼び出されて、
質問文のエラーが発生したと思われます。

一度余分な機能のない、スレッドプログラム。
スレッドid(threading.get_ident())と時刻を出力するprint文のみを作成してみるのがいいと思います。

対策方法は
案1)judgeFunc内で、ループ終了時にjudgeEndを呼び出す。
案2)jf.judgeEnd()の前の行にthread1.join()を追加して、終了待ちをする。

投稿2018/07/13 02:18

編集2018/07/13 02:25
umyu

総合スコア5846

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

YMD_kts

2018/07/13 02:27

試しにjudgeEnd()をコメントアウトしたら無事並列処理できました! 勝手にThreadのstart()の部分で処理が止まっているもの太戸勘違いしてました... お早い回答有難うございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問