Recognizer API

2023-10-30 15:59
文章标签 api recognizer

本文主要是介绍Recognizer API,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

public class Recognizer implements Configurable, ResultProducer

此为识别了设置了相应的状态,以防止在某些方法在其必要的条件之前被调用。使用了异常处理。靠继承RuntimeException来实现新的异常类。

Sphinx4识别器。此是sphinx4的主要的入口。一个识别器的典型使用如下:

public void recognizeDigits() {

      URLdigitsConfig = new URL(“file:./digits.xml”);

     ConfigurationManager cm = new ConfigurationManager(digitsConfig);

      RecognizersphinxDigitsRecognizer

          =(Recognizer) cm.lookup(“digitsRecognizer”“);

      boolean done =false;

      Result result;
       sphinxDigitsRecognizer.allocate();
      // echo spoken digits, quit when’nine’ is spoken
       while (!done) {

           result =sphinxDigitsRecognizer.recognize();

          System.out.println(“Result: ” + result);

           done =result.toString().equals(“nine”);

      }

     sphinxDigitsRecognizer.deallocate();

  }

本类的属性:

 @S4Component(type =Decoder.class)

public final static String PROP_DECODER = “decoder”;识别器所使用的解码器。

 @S4ComponentList(type =Monitor.class)

public final static String PROP_MONITORS = “monitors”;此识别器所使用的监视器的集合。

 public static enum State { DEALLOCATED, ALLOCATING, ALLOCATED, READY, RECOGNIZING, DEALLOCATING, ERROR };定义了识别器的所有可能的状态。

 private String name;识别器的名字。

 private Decoder decoder;使用的解码器

private State currentState = State.DEALLOCATED;当前状态为未分配资源的状态。

 private finalList<StateListener> stateListeners = Collections.synchronizedList(new ArrayList<StateListener>());为状态监听器列表

 private List<Monitor> monitors;使用的监听器列表。

本类的构造方法:

public Recognizer();为空的构造方法。

 public Recognizer(Decoder decoder,List<Monitor> monitors);给定解码器和监听器列表来创建对象。

本类的方法:

public void newProperties(PropertySheetps);对属性进行设置。

  public String toString();为此对象的字符串表示。为名字和当前状态。

 public voidremoveStateListener(StateListener stateListener);从监听器列表中移除给定的监听器。此方法可以再任何状态调用。

 public void removeResultListener(ResultListenerresultListener);移除给定的结果监听器。此方法可以再任何状态被调用。此方法调用解码器的方法来实现的。

public void addStateListener(StateListener stateListener);为此识别器添加一个状态监听器,即添加到监听器列表中。 无论何时当识别器的状态改变时,此状态监听器被调用,此方法可以在任何状态被调用。

 public voidaddResultListener(ResultListener resultListener);为此识别器添加一个结果监听器。无论何时当一个新的结果被识别器产生时,此结果监听器被调用。此方法可以在任何时候被调用。是通过解码器来实现的。

 public void resetMonitors() ;为此识别器重新设置监听器即Resets the monitorsmonitoring this recognizer

 public State getState();获得此识别器的状态,此方法可以在任何时候被调用。返回的当前状态属性。

 public void deallocate();释放此识别器的资源,此方法仅仅在识别器处于已经分配的状态下才被调用。

  public void allocate();为此识别器分配必要的资源。注意此方法需要一些时间才能完成。此方法仅仅在识别器处于已经被释放资源的状态下才能被调用。如果识别器不在DEALLOCATED状态,则会抛出异常。

 private void setState(State newState);设置当前状态。把所有的状态监听器都该变成当前的状态。输入为:新的状态。

private void checkState(State desiredState);检查确保识别器处于给定的状态。输入:desiredState为识别器应该处于的状态。如果识别器不做给定的状态,则会抛出异常。

 public Result recognize();对给定输入数量的特征帧矢量进行识别处理,或者直到一个最终结果(final result)被产生。此方法仅在识别器处于allocated已经分配状态 才能被调用。返回的是一个识别的结果集result。如果识别器不处于allocated状态,则会抛出异常。

 public Result recognize(String referenceText);对给定输入数量的特征帧矢量进行识别处理,或者直到一个最终结果(final result)被产生。此方法仅在识别器处于allocated已经分配状态 才能被调用。返回的是一个识别的结果集result。如果识别器不处于allocated状态,则会抛出异常。在其中主要靠解码器的decode方法来完成识别。

转自:http://blog.csdn.net/taiyb/article/details/42610281

这篇关于Recognizer API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/309024

相关文章

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

python通过curl实现访问deepseek的API

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... API申请和充值下面是deepeek的API网站https://platform.deepsee

Java对接Dify API接口的完整流程

《Java对接DifyAPI接口的完整流程》Dify是一款AI应用开发平台,提供多种自然语言处理能力,通过调用Dify开放API,开发者可以快速集成智能对话、文本生成等功能到自己的Java应用中,本... 目录Java对接Dify API接口完整指南一、Dify API简介二、准备工作三、基础对接实现1.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo