EfficientWord-Net

EfficientWord-Net

开源的少样本自定义唤醒词检测引擎

EfficientWord-Net是一个开源的热词检测引擎,基于少样本学习技术,支持开发者添加自定义唤醒词。该项目采用Google的TFLite实现实时推理,架构灵感源自FaceNet的孪生网络。EfficientWord-Net使用Python开发,兼容3.6至3.9版本,提供自定义唤醒词生成和多唤醒词同时检测等功能,适用于家庭助手等应用场景。

EfficientWord-Net热词检测少样本学习语音助手PythonGithub开源项目

EfficientWord-Net

版本:3.6、3.7、3.8、3.9

基于少样本学习的唤醒词检测

家庭助手需要特殊短语作为唤醒词来激活(例如:"OK Google")。 EfficientWord-Net 是一个基于少样本学习的唤醒词检测引擎,允许开发者免费为他们的程序添加自定义唤醒词。该库完全用 Python 编写,并使用 Google 的 Tflite 实现来实现更快的实时推理。它的灵感来自 FaceNet 的孪生网络架构,当直接从用户收集 3-4 个唤醒词样本时,效果最佳。

EfficientWord-Net 在树莓派上的演示

https://user-images.githubusercontent.com/44740048/139785995-3330d65a-cfe1-4e92-8769-ee389a122acc.mp4

访问训练文件

训练文件

数据集

以下是链接:https://drive.google.com/file/d/1f6dp72D9WxErXvaZP6KIBLv4-eKpvLZa/view?usp=sharing, https://drive.google.com/file/d/19QUTiAZvF1pFy5BeaV_rc83MeDu8yojv/view?usp=sharing

访问论文

研究论文

Python 版本要求

该库适用于以下 Python 版本: 3.6 到 3.9

依赖项安装

在运行库的 pip 安装命令之前,需要手动安装一些依赖项。

tflite 包无法列在 requirements.txt 中,因此当包在系统中初始化时会自动安装。

librosa 包仅在推理时不需要,但当调用 generate_reference 时会自动安装。

包安装

运行以下 pip 命令

pip install EfficientWord-Net

导入运行

import eff_word_net

演示

安装包后,您可以运行库内置的演示脚本(确保您有一个可用的麦克风)。

访问文档:https://ant-brain.github.io/EfficientWord-Net/

运行演示的命令

python -m eff_word_net.engine

生成自定义唤醒词

对于任何新的唤醒词,库需要有关唤醒词的信息,这些信息从名为 {wakeword}_ref.json 的文件中获取。 例如:对于唤醒词 'alexa',库需要名为 alexa_ref.json 的文件

可以通过以下步骤生成这些文件:

需要收集给定唤醒词的 4 到 10 个独特发音。然后将它们放入一个单独的文件夹中,该文件夹不包含其他内容。

或者可以使用以下命令为给定单词生成音频文件,使用 IBM 神经 TTS 演示 API。请不要为了我们过度使用它。

python -m eff_word_net.ibm_generate

最后运行此命令,它会询问输入文件夹的位置(包含音频文件)和输出文件夹(存储 _ref.json 文件的位置)。

python -m eff_word_net.generate_reference

生成的唤醒词的路径名需要传递给 HotwordDetector 检测器实例。

HotwordDetector( hotword="hello", model = Resnet_50_Arc_loss(), reference_file = "/full/path/name/of/hello_ref.json"), threshold=0.9, #考虑触发所需的最小置信度 relaxation_time = 0.8 #默认值,单位为秒 )

model 变量可以接收 Resnet_50_Arc_loss 或 First_Iteration_Siamese 的实例。

relaxation_time 参数用于确定任意两次触发之间的最小时间,在 relaxation_time 之前的任何潜在触发都将被取消。 检测器采用滑动窗口方法,导致单次唤醒词utterance产生多次触发,可以使用 relaxation_time 参数来控制多次触发,在大多数情况下 0.8 秒(默认值)就足够了。

现成的示例唤醒词

对于一些唤醒词,如 MycroftGoogleFirefoxAlexaMobileSiri,库中已经预定义了现成的嵌入,可以在库安装目录中找到,其路径可以通过以下变量获取

from eff_word_net import samples_loc

尝试您的第一个单一唤醒词检测脚本

import os from eff_word_net.streams import SimpleMicStream from eff_word_net.engine import HotwordDetector from eff_word_net.audio_processing import Resnet50_Arc_loss from eff_word_net import samples_loc base_model = Resnet50_Arc_loss() mycroft_hw = HotwordDetector( hotword="mycroft", model = base_model, reference_file=os.path.join(samples_loc, "mycroft_ref.json"), threshold=0.7, relaxation_time=2 ) mic_stream = SimpleMicStream( window_length_secs=1.5, sliding_window_secs=0.75, ) mic_stream.start_stream() print("说 Mycroft ") while True : frame = mic_stream.getFrame() result = mycroft_hw.scoreFrame(frame) if result==None : #无语音活动 continue if(result["match"]): print("唤醒词已说出",result["confidence"])

从音频流中检测多个唤醒词

该库提供了一种计算友好的方式来从给定流中检测多个唤醒词,而不是单独运行每个唤醒词的 scoreFrame()

import os from eff_word_net.streams import SimpleMicStream from eff_word_net import samples_loc print(samples_loc) base_model = Resnet50_Arc_loss() mycroft_hw = HotwordDetector( hotword="mycroft", model = base_model, reference_file=os.path.join(samples_loc,"mycroft_ref.json"), threshold=0.7, relaxation_time=2 ) alexa_hw = HotwordDetector( hotword="alexa", model=base_model, reference_file=os.path.join(samples_loc,"alexa_ref.json"), threshold=0.7, relaxation_time=2, #verbose=True ) computer_hw = HotwordDetector( hotword="computer", model=base_model, reference_file=os.path.join(samples_loc,"computer_ref.json"), threshold=0.7, relaxation_time=2, #verbose=True ) multi_hotword_detector = MultiHotwordDetector( [mycroft_hw, alexa_hw, computer_hw], model=base_model, continuous=True, ) mic_stream = SimpleMicStream(window_length_secs=1.5, sliding_window_secs=0.75) mic_stream.start_stream() print("说 ", " / ".join([x.hotword for x in multi_hotword_detector.detector_collection])) while True: frame = mic_stream.getFrame() result = multi_hotword_detector.findBestMatch(frame) if None not in result: print(result[0], f",置信度 {result[1]:0.4f}") 可以从这里访问库的文档:https://ant-brain.github.io/EfficientWord-Net/ ## 从0.2.2到v1.0.1的变更说明 ### 新增模型Resnet_50_Arc_loss,带来巨大改进!! 使用从MLCommons提取的经过修改的蒸馏数据集从头训练了一个新模型,使用Arcloss函数替代了三元组损失函数。 生成的新模型存储为resnet_50_arcloss。 新模型表现出对背景噪音更好的抗干扰能力,并且需要更少的样本就能达到良好的准确率。 对API流程进行了微小调整,以便于轻松添加新模型。 新模型可以处理1.5秒的固定窗口长度。 仍可通过first_iteration_siamese访问旧模型。 ## 从v0.1.1到0.2.2的变更说明 对处理每次语音中多个触发词的复杂逻辑进行了重大改变,使用了更简单的逻辑和更简单的API供程序员使用。 引入了破坏性变更 ## 当前模型的局限性 - 仅针对单个词进行训练,因此在使用"嘿xxx"这样的短语时可能会产生奇怪的行为。 - 音频处理窗口限制为1秒。因此对于较长的热词效果不佳。 ## 常见问题: * **热词性能不佳**:如果遇到这样的问题,请随时在[讨论区](https://github.com/Ant-Brain/EfficientWord-Net/discussions/4)中询问。 * **它能在Arduino这样的FPGA上运行吗?**:不能,新模型Resnet_50_Arcloss太大(大约88MB),无法在Arduino上运行。我们很快会添加对模型剪枝版本的支持,使其足够轻量以在微型设备上运行。目前它应该能在树莓派这样的设备上运行。 ## 贡献: * 如果你有让项目变得更好的想法,请随时在[讨论区](https://github.com/Ant-Brain/EfficientWord-Net/discussions/3)中联系我们。 * 当前的[logmelcalc.tflite](/eff_word_net/logmelcalc.tflite)图每次只能将1个音频帧转换为对数梅尔频谱图。如果有TensorFlow专家能在这方面帮助我们,将不胜感激。 ## 待办事项: * 在数据流中添加音频文件处理器。欢迎提交PR。 * 移除librosa依赖,以鼓励直接在边缘设备上生成参考文件。 * 添加更详细的文档,解释滑动窗口概念。 * 添加模型微调支持。 * 添加稀疏和细粒度剪枝支持,生成的模型可用于微调(已在进行中)。 ## 支持我们: 与Porcupine相比,我们的热词检测器性能明显较低。我们已经考虑了更好的神经网络架构,希望能超越Porcupine。这是我们的本科项目。因此,你的支持和鼓励将激励我们继续开发这个引擎。如果你喜欢这个项目,请向你的同行推荐,在GitHub上给我们一个🌟,在[medium](https://link.medium.com/yMBmWGM03kb)上给我们一个掌声👏。 更新:你们的星星鼓励我们创建了一个更好的新模型,让我们一起壮大这个社区吧! ## 许可证:[Apache License 2.0](/LICENSE.md)

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多