16#ifdef USE_OTA_STATE_LISTENER
20#include <freertos/event_groups.h>
23#include <frontend_util.h>
35#ifdef USE_OTA_STATE_LISTENER
41 void setup()
override;
46#ifdef USE_OTA_STATE_LISTENER
69#ifdef USE_MICRO_WAKE_WORD_VAD
70 void add_vad_model(
const uint8_t *model_start, uint8_t probability_cutoff,
size_t sliding_window_size,
71 size_t tensor_arena_size);
89#ifdef USE_MICRO_WAKE_WORD_VAD
133 int8_t features_buffer[PREPROCESSOR_FEATURE_SIZE],
size_t *processed_samples);
Helper for FreeRTOS static task management.
void resume_task_()
Resumes the inference task.
microphone::MicrophoneSource * microphone_source_
void set_task_stack_in_psram(bool task_stack_in_psram)
QueueHandle_t detection_queue_
static void inference_task(void *params)
void process_probabilities_()
Processes any new probabilities for each model.
EventGroupHandle_t event_group_
void set_stop_after_detection(bool stop_after_detection)
void set_state_(State state)
std::vector< WakeWordModel * > wake_word_models_
bool task_stack_in_psram_
void suspend_task_()
Suspends the inference task.
float get_setup_priority() const override
Trigger< std::string > wake_word_detected_trigger_
void add_wake_word_model(WakeWordModel *model)
bool generate_features_(const int16_t *audio_buffer, size_t samples_available, int8_t features_buffer[PREPROCESSOR_FEATURE_SIZE], size_t *processed_samples)
Generates a spectrogram feature from an input buffer of audio samples.
void dump_config() override
bool stop_after_detection_
uint8_t features_step_size_
bool update_model_probabilities_(const int8_t audio_features[PREPROCESSOR_FEATURE_SIZE])
Runs an inference with each model using the new spectrogram features.
struct FrontendConfig frontend_config_
std::unique_ptr< VADModel > vad_model_
std::weak_ptr< ring_buffer::RingBuffer > ring_buffer_
void add_vad_model(const uint8_t *model_start, uint8_t probability_cutoff, size_t sliding_window_size, size_t tensor_arena_size)
void set_features_step_size(uint8_t step_size)
void set_microphone_source(microphone::MicrophoneSource *microphone_source)
void unload_models_()
Deletes each model's TFLite interpreters and frees tensor arena memory.
std::vector< WakeWordModel * > get_wake_words()
StaticTask inference_task_
struct FrontendState frontend_state_
void on_ota_global_state(ota::OTAState state, float progress, uint8_t error, ota::OTAComponent *comp) override
Trigger< std::string > * get_wake_word_detected_trigger()
Listener interface for global OTA state changes (includes OTA component pointer).