3

私はここにいるのは初めてで、Pocketsphinx (NDK を使用) を使用した Android アプリで助けが得られることを願っています。

私は GPS を作成している学校のプロジェクトのためにこの作業を行っており、オフラインの音声認識を追加したいと考えていました。

静かに多くの修正と試行を行った後 (最初に Ubuntu のインストールと慣れ、ライブラリをコンパイルしようとしたときに発生したエラーの修正、.so ファイルを取得するために NDK でライブラリをビルドしようとした際のエラー、プロジェクトの問題Android用の適切なライブラリがなく、それを2.1プロジェクトに変換して電話でテストしました)プログラムを実行できました(ただし、何らかの理由で、電話に表示される前に2回3回起動する必要があります) .

デモプロジェクトを使用しようとすると問題が発生します。見た目がわからない場合は、単純なテキスト領域とボタンだけです。ボタンを押すと録音が開始され、話すと入力された音声が表示されますエリア内のテキストとして、このボタンをクリックするとすぐに閉じます。クラッシュしません。プロセスは停止しますが、スタックトレースは取得できません。デバッグ情報からわかることから、記録プロセスを開始しますが、その後クラッシュします。私の推測では、ネイティブ コードで作業を開始しようとするとクラッシュします。

私が取得した不明確なデバッグ情報から理解できることは、ネイティブ環境が閉じられていることです。タグ Zygote を含むデバッグからメッセージが表示され、「プロセス X はシグナルによって終了しました(11)」というメッセージが表示されます。私の検索から、これはセグメンテーション違反 (SIGSEGV) を意味する可能性が最も高いことがわかりました。

これは私が得た限りであり、セグメンテーション違反が何を意味するのか、この問題を解決する方法を本当に理解していません. 以下にログの一部を追加します。これは、プログラムが終了する前に表示されるものです。ログからの情報がさらに必要な場合は、どの情報が役立つかが非常にわからないため、何をどのように取得するか教えてください。

私は Eclipse と Android プラグインを使用して Ubuntu 11.10 に取り組んでいます。関連する場合、私の電話は Sony Ericsson Xperia であり、Android 2.1 のいくつかの Sony Ericsson バージョンを実行しています。sphinx ライブラリは Sphinx プロジェクト Web サイトの最新バージョンです。

ここの誰かがこれに取り組み続ける方法を教えてくれることを願っています。私は主に Java 開発者ですが、C++ でいくつかの作業を行ったことがあります。そこまで行く。

ログの抜粋は次のとおりです。

03-20 11:37:22.676: D/edu.cmu.pocketsphinx.demo.RecognizerTask(385): signalling START
03-20 11:37:22.676: D/edu.cmu.pocketsphinx.demo.RecognizerTask(385): signalled START
03-20 11:37:22.676: D/edu.cmu.pocketsphinx.demo.RecognizerTask(385): gotSTART
03-20 11:37:22.676: D/edu.cmu.pocketsphinx.demo.RecognizerTask(385): START
03-20 11:37:22.806: D/edu.cmu.pocketsphinx.demo.PocketSphinxDemo(385): Showing Dialog
03-20 11:37:22.826: I/AudioHardwareQSD(1066): AudioHardware PCM record is going to standby.
03-20 11:37:22.836: I/AudioHardwareQSD(1066): AudioHardware PCM record is going to standby.
03-20 11:37:22.836: D/dalvikvm(385): +++ not scanning '/system/lib/libwebcore.so' for 'Decoder_startUtt__SWIG_0' (wrong CL)
03-20 11:37:22.836: D/dalvikvm(385): +++ not scanning '/system/lib/libexif.so' for 'Decoder_startUtt__SWIG_0' (wrong CL)
03-20 11:37:22.846: I/DEBUG(1063): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
03-20 11:37:22.846: I/DEBUG(1063): Build fingerprint: 'SEMC/X10i_1234-9753/X10i/es209ra:2.1-update1/2.1.A.0.435/TP7d:user/release-keys'
03-20 11:37:22.846: I/DEBUG(1063): pid: 385, tid: 395  >>> edu.cmu.pocketsphinx.demo <<<
03-20 11:37:22.846: I/DEBUG(1063): signal 11 (SIGSEGV), fault addr 0000001c
03-20 11:37:22.846: I/DEBUG(1063):  r0 00000000  r1 00000000  r2 00000154  r3 8c6d703c
03-20 11:37:22.846: I/DEBUG(1063):  r4 00000000  r5 81356e14  r6 475c8d6c  r7 00000000
03-20 11:37:22.846: I/DEBUG(1063):  r8 475c8d6c  r9 00000154  10 43117f40  fp 00123e08
03-20 11:37:22.846: I/DEBUG(1063):  ip 8130c191  sp 475c8d18  lr 8130c1a1  pc 8130d568  cpsr 40000030
03-20 11:37:22.866: I/DEBUG(1063):          #00  pc 0000d568  /data/data/edu.cmu.pocketsphinx.demo/lib/libpocketsphinx_jni.so
03-20 11:37:22.866: I/DEBUG(1063):          #01  pc 0000c19c  /data/data/edu.cmu.pocketsphinx.demo/lib/libpocketsphinx_jni.so
03-20 11:37:22.876: I/DEBUG(1063):          #02  pc 0000edb4  /system/lib/libdvm.so
03-20 11:37:22.876: I/DEBUG(1063): code around pc:
03-20 11:37:22.876: I/DEBUG(1063): 8130d558 447db089 1c0458ab 681b1c0f 93074691 
03-20 11:37:22.876: I/DEBUG(1063): 8130d568 2b0069c3 e0d3d100 36301c06 f0331c30 
03-20 11:37:22.876: I/DEBUG(1063): code around lr:
03-20 11:37:22.876: I/DEBUG(1063): 8130c190 b083b500 21001c10 93019200 f9d6f001 
03-20 11:37:22.876: I/DEBUG(1063): 8130c1a0 bd00b003 b084b510 93019200 23001c10 
03-20 11:37:22.876: I/DEBUG(1063): 8130c1b0 93022400 f0009403 f030fe3b 9903fc47 
03-20 11:37:22.876: I/DEBUG(1063): stack:
03-20 11:37:22.876: I/DEBUG(1063):     475c8cd8  7fffffff  
03-20 11:37:22.876: I/DEBUG(1063):     475c8cdc  ab227f0f  /system/lib/libmedia.so
03-20 11:37:22.876: I/DEBUG(1063):     475c8ce0  afe3db7c  
03-20 11:37:22.876: I/DEBUG(1063):     475c8ce4  afe0f130  /system/lib/libc.so
03-20 11:37:22.876: I/DEBUG(1063):     475c8ce8  afe3db7c  
03-20 11:37:22.876: I/DEBUG(1063):     475c8cec  afe0f130  /system/lib/libc.so
03-20 11:37:22.876: I/DEBUG(1063):     475c8cf0  00000000  
03-20 11:37:22.876: I/DEBUG(1063):     475c8cf4  afe0f048  /system/lib/libc.so
03-20 11:37:22.876: I/DEBUG(1063):     475c8cf8  afe3d9c4  
03-20 11:37:22.876: I/DEBUG(1063):     475c8cfc  00002004  
03-20 11:37:22.876: I/DEBUG(1063):     475c8d00  00000001  
03-20 11:37:22.876: I/DEBUG(1063):     475c8d04  078bcd20  
03-20 11:37:22.876: I/DEBUG(1063):     475c8d08  00000209  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d0c  b0000463  /system/bin/linker
03-20 11:37:22.886: I/DEBUG(1063):     475c8d10  df002777  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d14  e3a070ad  
03-20 11:37:22.886: I/DEBUG(1063): #00 475c8d18  00000000  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d1c  afe0f048  /system/lib/libc.so
03-20 11:37:22.886: I/DEBUG(1063):     475c8d20  afe3d9c4  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d24  0014bac0  [heap]
03-20 11:37:22.886: I/DEBUG(1063):     475c8d28  003952b8  [heap]
03-20 11:37:22.886: I/DEBUG(1063):     475c8d2c  0000a000  [heap]
03-20 11:37:22.886: I/DEBUG(1063):     475c8d30  ad00ef40  /system/lib/libdvm.so
03-20 11:37:22.886: I/DEBUG(1063):     475c8d34  8c6d703c  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d38  0014ba78  [heap]
03-20 11:37:22.886: I/DEBUG(1063):     475c8d3c  475c8d6c  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d40  43117f54  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d44  475c8d90  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d48  00000004  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d4c  458ad8c8  /mspace/dalvik-heap/2 (deleted)
03-20 11:37:22.886: I/DEBUG(1063):     475c8d50  43117f60  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d54  8130c1a1  /data/data/edu.cmu.pocketsphinx.demo/lib/libpocketsphinx_jni.so
03-20 11:37:22.886: I/DEBUG(1063): #01 475c8d58  00000000  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d5c  00000000  
03-20 11:37:22.886: I/DEBUG(1063):     475c8d60  430fdfae  /data/dalvik-cache/data@app@edu.cmu.pocketsphinx.demo.apk@classes.dex
03-20 11:37:22.886: I/DEBUG(1063):     475c8d64  ad00edb8  /system/lib/libdvm.so
03-20 11:37:23.026: D/Zygote(1065): Process 385 terminated by signal (11)
03-20 11:37:23.056: I/ActivityManager(1140): Process edu.cmu.pocketsphinx.demo (pid 385) has died.
03-20 11:37:23.056: I/UsageStats(1140): Unexpected resume of com.android.launcher while already resumed in edu.cmu.pocketsphinx.demo
03-20 11:37:23.056: I/WindowManager(1140): WIN DEATH: Window{45f50c48 edu.cmu.pocketsphinx.demo/edu.cmu.pocketsphinx.demo.PocketSphinxDemo paused=false}
03-20 11:37:23.086: I/AudioHardwareQSD(1066): AudioHardware PCM record is going to standby.
03-20 11:37:23.116: W/InputManagerService(1140): Got RemoteException sending setActive(false) notification to pid 385 uid 10106

私は答えを見つけようとしてきましたが、見つけたほとんどのスレッドはアプリからログファイルを調べるように求められましたが、それらは通常スレッドの終わりでした.私のプロジェクトはログファイルを提供しません(作成するコードが1つはそこにあります)。私は次にどこを見ればよいか途方に暮れています。ここにいる誰かが私に手を差し伸べてくれることを願っています。

4

1 に答える 1

0

これは私が得た限りであり、セグメンテーション違反が何を意味するのか、またはこの問題を解決する方法を本当に理解していません

ソフトウェア開発者になりたい場合は、詳細に学習する必要があります。ウィキペディアからいくつかの出発点を見つけることができます

http://en.wikipedia.org/wiki/Segmentation_fault

通常、セグメンテーション違反は、アプリケーションまたは構成にバグがあることを意味します

そして、私が見つけたほとんどのスレッドはアプリからログファイルを調べるように求められ、それらは通常スレッドの終わりでした.私のプロジェクトはログファイルを提供しません(作成するコードがそこにある場合でも)

これはあなたにとっても完全に有効なアドバイスです。ファイル pocketphinx.log が作成されない理由を調べる必要があります。そのパスはソースで構成されています。ほとんどの場合、SD カードに作成されますが、別の場所を構成できます。このログの内容は、アプリケーションの問題を示しています。

于 2012-03-21T07:34:37.490 に答える