Skip to content

Latest commit

 

History

History
 
 

android

Android Library (High-Level API) and Demo Application

This section contains the source code for Android demo application. The application uses a high-level library, PorcupineManager, for wake word detection. The library can be used on its own to build always-listening Android applications. It manages all aspects of wake word detection including configuring Porcupine, recording input audio, and sending notifications.

Prerequisites

Consult the prerequisites section of Android binding.

Demo Application Usage

Using Android Studio open demo/android as an android project and then run the application. Note that you need an android phone with developer options enabled connected to your machine in order to run the application.

If you'd like to run tests navigate to androidTest using Android Studio, right click, and select Run Tests in ai.picovoice.porcupine.demo from drop down menu.

Library Installation and Usage

You can add PorcupineManager as a dependency to your Android app by consulting the documentation on Android Developers website.

PorcupineManager requires RECORD_AUDIO user permission. Be sure it is granted to your App. Furthermore, Porcupine performs data-intensive operations such as recording/processing audio which should not be run on the UI thread. Make sure you are following the best practices for data-intensive operations.

The library can be initialized using

    final String modelFilePath = ... // It is available at lib/common/porcupine_params.pv
    final String keywordFilePath = ...
    final float sensitivity = 0.5f;
    
    PorcupineManager manager = new PorcupineManager(
            modelFilePath,
            keywordFilePath,
            sensitivity,
            new KeywordCallback() {
                @Override
                public void run() {
                    // detection event logic/callback
                }
            });

When initialized, input audio can be monitored using manager.start() . When done be sure to stop the manager using manager.stop(). modelFilePath should point to model parameter file which contains neural network parameters. This file is shipped separately to reduce the size of library while supporting all ABIs. Furthermore, keywordFilePath should point to an Android keyword file available at resources/keyword_files. Custom keyword files for Android are provided with purchase of the commercial license. In order to purchase a commercial license please contact us at [email protected]. For more information about keyword files refer to tools/optimizer. Finally, sensitivity is the parameter that enables developers to trade miss rate for false alarm. It is a floating number within [0, 1]. A higher sensitivity reduces miss rate at cost of increased false alarm rate. For more information about this parameter refer to include/pv_porcupine.h.

If you'd like to run the tests navigate to androidTest using Android Studio, right click, and select Run Tests in ai.picovoice.porcupinemanager from drop down menu.