RaisedCosineWindower API及加窗

2024-03-11 13:32

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





<span style="font-size:24px;">本类的构造方法
public RaisedCosineWindower( );空构造方法
public RaisedCosineWindower( double alpha, float windowSizeInMs, float windowShiftInMs );非空构造方法,初始化了必要的相关属性。
本类方法:
public void newProperties(PropertySheet ps);用于改变属性的值。
public void initialize();处理器初始化,new了一个空链接列表给outputQueue。
private void createWindow(int sampleRate);如果余弦窗口存在,且采样率与输入采样率相等则返回,否则,设置为输入采样率,并创建余弦窗口,得到窗口长度所含的采样数,和窗口移动所包含的采样数。对窗口中的每个点赋值为cosineWindow[i] = (1-alpha)-alpha * Math.cos(2 * Math.PI * i / ((double) cosineWindow.length - 1.0));并设置了overflowBuffer = new DoubleBuffer(windowSize);与窗口的采样数相同。
private static int getWindowCount(int arraySize, int windowSize,int windowShift);返回的是在给定数组,窗口长度,窗口移动的情况下,窗口的个数。分了两种情况:
1,	数组长度 arraySize小于窗口windowSize的情况,则窗口为0个,即返回为0.
2,	数组长度 arraySize大于或等于窗口windowSize的情况;开始窗口个数设为1;
以窗口长度反复加窗口移动值并与数组长度比较。
int windowCount = 1;for (int windowEnd = windowSize;windowEnd + windowShift <= arraySize;windowEnd += windowShift) {windowCount++;}
public float getWindowShiftInMs();获得窗口移动值。
public int getSampleRate();获得采样率
public long roundToFrames(long samples);
long mxNumShifts = samples / windowShift;for (int i = (int) mxNumShifts; ; i--) {long remainingSamples = samples - windowShift * i;if (remainingSamples > windowSize)return windowShift * (i + 1) + windowSize;}
public Data getData();返回data对象。如果输出存在数据就成输出列表中输出,没有的话从前一个处理器中读取数据进行窗口处理后,在存输出列表中输出。分为两种情况:
1,	outputQueue.isEmpty()即输出列表为空的情况:处理步骤为下:
1,	获得前一处理器的输出的data数据
2,	判断data的对象类型:
1,	为doubledata时1,创建余弦窗口2,对输入数据DoubleData进行窗口处理
2,	为信号的情况下的处理,都需要把信号加入输出列表中:A,为DataStartSignal对象时,创建窗口,并往信号的props的map对象中窗口处理过程的,窗口的长度,窗口的移动值。B,DataEndSignal和SpeechEndSignal,都会对上次窗口处理未处理的残留的采样数进行处理。C,SpeechStartSignal时仅对currentFirstSampleNumber进行了设置,使其值为-1.
private void process(DoubleData input);input为上个处理器的输出的doubledata数据。对input进行窗口处理,得到结果窗口缓存入于输出列表outputQueue中。处理流程如下: 
1,	得到一个输入的doubledata中所包含的采样。存入一个double数组中。并把doubledata添加入创建的链接列表中。
2,	得到double数组的长度加上上一次窗口处理残留为未进行处理的数据的长后并与余弦窗口比较,
1,	长度小于余弦窗口长度的情况;继续从前个处理器读取data数据,直到所有的doubledata数据中所包含的采样数之和大于或等于窗口长度为止,如果在读取的过程中碰到了dataendsignal信号,那会设置utteranceend标记,并退出循环。同时把所有的信号都添加入输出列表中。并把所有的读取到的doubledata中包含的采样,都存入一个数组中。此数组将会被用于进行余弦窗口处理,以得到窗口。
3,	把所有的采样(即所有从前一处理器读到的doubledata中包含的)进行余弦窗口处理。即窗口处理。
4,	查看窗口处理中是否有未进行窗口处理的采样数。如果有存入把未处理的采样都存入overflowbuffer中即DoubleBuffer对象中,并在此对象中记录位处理的采样的个数即对occupancy赋值。
5,	对从前一处理器读取的数据含有dataendsignal的情况进行处理,如果在此情况下窗口处理后仍然有残留未处理的,则需要对此残留的的进行窗口处理。private int applyRaisedCosineWindow(double[] in, int length);对in数组中的length个的元素进行升余弦窗口处理。分三中情况考虑:
1,	length小于余弦窗口的长度时,进行填充处理。与余弦窗口相乘一次,即窗口数为1。
2,	length等于余弦窗口的长度。与余弦窗口相乘一次,即窗口数为1。
3,	length大于余弦窗口的长度。首先计算出窗口数,通过length-窗口长度后得到的值来整除窗口的移动值后的值在加1即为窗口数,在与余弦窗口相乘窗口数次,第一次相乘时取in中的0——窗口长度-1个数,之后取in中窗口移动值——窗口长度+窗口移动-1。注意每次相乘时在in数组取的数目要与窗口长度相同,每次从in取数时,从窗口移动的倍数开始即0*窗口移动,1*窗口移动…直到窗口数为止。
myWindow[w] = in[s] * cosineWindow[w]
处理完以上的情况,后根据每次相乘后得到的数组(窗口),新建一个doubledata对象,然后把每次doubledata添加入输出列表中(outputqueue)。
返回的是最后一次相乘时的in数组中取的窗口长度的数据的开始的位置加上窗口移动值后的值。
private void processUtteranceEnd();对在窗口处理中的读取前一处理器的数据中包含dataendsignal信号的情况进行处理。</span>


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



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

相关文章

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

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 应