Project Icon

CTCWordBeamSearch

CTC解码器提升文本和语音识别的性能

CTC Word Beam Search是一种基于词典和语言模型的连接时序分类(CTC)解码器,支持Python 3.11和3.12版本。项目提供详细的安装和使用指南,并通过示例代码展示其在文本识别模型中的应用。算法具有四大特点:使用词典约束词语、允许词间出现任意非词字符、可选用词级语言模型(LM)以及比token传递算法更快。文档中提供了主要参数的说明和更多的技术细节及使用案例,适用于手写文本识别和自动语音识别。

CTCWordBeamSearch 项目介绍

CTCWordBeamSearch 是一个专门用于序列识别任务的解码算法项目,比如手写文本识别或自动语音识别。它的主要目的是通过词典和语言模型(LM)实现高效和准确的解码。在本文中,我们将详细介绍这个项目的特性、安装和使用方法。

项目更新

CTCWordBeamSearch 持续进行更新,包括对 Python 较新版本的支持:

  • 2024 年:支持 Python 版本 3.11 和 3.12。
  • 2021 年:Python 包成为默认的安装方式。
  • 2020 年:推出可安装的 Python 包。

安装方法

用户可以通过以下步骤简单地安装 CTCWordBeamSearch:

  1. 进入项目的根目录。
  2. 执行命令 pip install . 来安装项目。
  3. 进入 tests/ 目录并执行 pytest,以检查安装是否成功。

使用示例

以下是一个简化的示例,展示如何使用 Word Beam Search 进行解码:

假设有个模型可以识别三种字符:“a”、“b”以及空格。在这个示例中,语言模型从一个只包含两个单词“a”和“ba”的文本语料库中进行训练。以下代码片段展示了如何创建 Word Beam Search 的实例,以及对一个特定形状的 numpy 数组进行解码。

import numpy as np
from word_beam_search import WordBeamSearch

corpus = 'a ba'
chars = 'ab '
word_chars = 'ab'

mat = np.array([[[0.9, 0.1, 0.0, 0.0]],
                [[0.0, 0.0, 0.0, 1.0]],
                [[0.6, 0.4, 0.0, 0.0]]])

wbs = WordBeamSearch(25, 'Words', 0.0, corpus.encode('utf8'), chars.encode('utf8'), word_chars.encode('utf8'))

label_str = wbs.compute(mat)

解码器会返回一个包含每个批处理元素的解码标签字符串的列表。通过将标签映射到对应的字符,最终得到字符字符串:

char_str = []
for curr_label_str in label_str:
    s = ''.join([chars[label] for label in curr_label_str])
    char_str.append(s)

参数说明

CTCWordBeamSearch 的构造函数包含多个可配置参数:

  • Beam Width (beam_width):保存每个时间步中的束数目。
  • Scoring mode (lm_type):决定评分模式,选择之一,如“Words”、“NGrams”等,影响算法运行时所用的词典大小。
  • Smoothing (lm_smoothing):用于平滑处理的参数,适用于训练文本中未知的词对。
  • Text (corpus)Characters (chars)Word characters (word_chars):定义操作所需的语言模型和词典从中创建的文本和字符集。

算法特性

Word Beam Search 是一种 CTC 解码算法,具有以下特点:

  • 单词受限于词典。
  • 支持单词之间的任意数量非单词字符(如数字、标点)。
  • 支持可选的单词级别语言模型。
  • 比 Token Passing 方法更快速。

该算法相较于其他解码器,能够在保持词典一致性的同时识别任意字符串,如数字和标点符号等。

演示与更多信息

用户可以通过 tests/test_word_beam_search.py 文件查看示例代码,并在 extras/prototype/extras/tf/ 目录下找到 Python 原型及 TensorFlow 自定义操作的相关内容。

希望使用该算法进行研究的人员,请参考相关文献,并适当引用论文:

@inproceedings{scheidl2018wordbeamsearch,
    title = {Word Beam Search: A Connectionist Temporal Classification Decoding Algorithm},
    author = {Scheidl, H. and Fiel, S. and Sablatnig, R.},
    booktitle = {16th International Conference on Frontiers in Handwriting Recognition},
    pages = {253--258},
    year = {2018},
    organization = {IEEE}
}
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号