会模仿笔迹的AI,为你创造专属字体

笔迹模仿 AI 的研究背景

俗话说,见字如面,字如其人。相比呆板的打印字体,手写体更能体现书写者的个人特点。相信很多人都曾设想过,拥有一套属于自己的手写字体,用在社交软件中,更好的展示自己的个人风格。

然而,不同于英文字母,汉字数量是极其庞大的,想要创造一套自己的专属字体代价十分高昂。例如,最新发布的国标GB18030-2022中文字符集包含8万多个汉字。有报道称,某视频网站博主花了18个小时写完了7000多个汉字,中间耗费了足足13支笔,手都写麻了!

上述问题引发了论文作者的思考,能否设计一个文字自动生成模型,帮助解决专属字体创造代价高的问题呢?为了解决这一问题,研究者设想提出一个会笔迹模仿的 AI,仅需用户提供少量的手写样本(大约 10 几张),就能提取笔迹中蕴含的书写风格(例如字符的大小、倾斜程度、横宽比、笔画的长短和曲率等),并且临摹该风格去合成更多的文字,从而为用户高效合成一套完整的手写字体。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

会模仿笔迹的AI,为你创造专属字体

进一步地,论文作者从应用价值和用户体验两个角度出发,对该模型的输入和输出模态做了如下思考:1. 考虑到序列模态的在线字体 (online handwritings) 比图像模态的离线文字 (offline handwritings) 包含更丰富的信息(轨迹点的详细位置和书写顺序,如下图所示),将模型的输出模态设置为在线文字会有更广泛的应用前景,例如可以应用到机器人写字和书法教育上。2. 在日常生活中,相比通过平板和触摸笔等采集设备获取在线文字,人们利用手机拍照获取离线文字更加方便。因此,将生成模型的输入模态设为离线文字,用户使用起来会更加方便!

会模仿笔迹的AI,为你创造专属字体

总结起来,本文的研究目标是提出一个风格化的在线手写文字生成模型 (stylized online handwriting generation method)。该模型既能临摹用户提供的离线文字中所蕴含的书写风格,又能根据用户需要在线生成内容可控的手写笔迹。

会模仿笔迹的AI,为你创造专属字体

论文地址:https://arxiv.org/abs/2303.14736代码开源:https://github.com/dailenson/SDT

主要挑战

为了实现上述目标,研究者们分析了两个关键问题:1. 由于用户只能提供少量的字符样本,能否仅从这些少量的参考样本中学习用户独特的书写风格呢?换句话说,根据少量的参考样本临摹用户的书写风格是否可行?2. 本文的研究目标不仅需要满足生成的文字风格可控,还需要内容也可控。因此,在学习到用户的书写风格后,如何将该风格与文字内容高效的结合,从而生成满足用户期望的手写笔迹?接下来让我们看看这篇 CVPR 2023 提出的 SDT(style disentangled Transformer)方法是怎样解决这两个问题的吧。

解决方案

研究动机 研究者发现,个人笔迹中通常存在两种书写风格:1. 相同书写者的笔迹存在着一种整体上的风格共性,各个字符呈现出相似的倾斜程度和宽高比,且不同书写者的风格共性各不相同。由于这种特性可以用于区分出不同的书写者,研究者们称其为书写者风格。2. 除了整体上的风格共性,来自同一书写者的不同字符间存在着细节上的风格不一致。例如,对于 “黑” 和 “杰” 两个字符,二者在字符结构上具有相同的四点水部首,但该部首在不同的字符中存在微弱的书写差异,体现在笔画书写的长短、位置和曲率上。研究者们将这种字形上的细微的风格模式称为字形风格。受启发于上述观察,sdt 旨在从个人笔迹中解耦出书写者和字形风格,期望提升对用户笔迹的风格模仿能力。

会模仿笔迹的AI,为你创造专属字体

在学习到风格信息后,不同于以往的手写文字生成方法简单的将风格和内容特征进行简单的拼接,SDT 将内容特征作为查询向量,自适应的捕获风格信息,从而实现风格和内容的高效融合,生成符合用户预期的手写笔迹。

会模仿笔迹的AI,为你创造专属字体

方法框架 SDT 的整体框架如下图所示,包含双分支风格编码器、内容编码器和 transformer 解码器三部分。首先,本文提出两个互补的对比学习目标来引导风格编码器的书写者分支和字形分支分别学习对应的风格提取。然后,SDT 利用 transformer 的注意力机制 (multi-head attention) 对风格特征和内容编码器提取到的内容特征进行动态融合,渐进式的合成在线手写文字。

会模仿笔迹的AI,为你创造专属字体

(a) 书写者风格对比学习 SDT 提出面向书写者风格提取的有监督对比学习目标(WriterNCE),将属于相同书写者的字符样本聚集在一起,推远属于不同书写者的手写样本,显示地引导书写者分支关注个人笔迹中的风格共性。

(b) 字形风格对比学习 为了学习更加细节的字形风格,SDT 提出无监督的对比学习目标 (GlyphNCE),用于最大化相同字符不同视角间的互信息,鼓励字形分支专注学习字符中的细节模式。具体如下图所示,首先对同一张手写字符做两次独立的采样,获取一对含有笔画细节信息的正样本

会模仿笔迹的AI,为你创造专属字体

会模仿笔迹的AI,为你创造专属字体

,然后从其他字符中采样得到负样本

会模仿笔迹的AI,为你创造专属字体

。每次采样时,随机选择少量样本块作为包含原始样本细节的新视角。样本块的采样服从均匀分布,避免字符的某些区域被过度采样。为了更好的引导字形分支,采样过程直接作用于字形分支输出的特征序列上。

会模仿笔迹的AI,为你创造专属字体

(c) 风格和内容信息的融合策略 获取了两种风格特征后,如何将其与内容编码器学习到的内容编码进行高效融合呢?为了解决这一问题,在任意的解码时刻 t,SDT 将内容特征视作初始点,然后结合 q 和 t 时刻之前输出的轨迹点

会模仿笔迹的AI,为你创造专属字体

形成新的内容上下文

会模仿笔迹的AI,为你创造专属字体

。接着,内容上下文被视为 query 向量,风格信息作为 key & value 向量。在交叉注意力机制的融合下,内容上下文与两种风格信息依次完成动态聚合。

实验

定量评价 SDT 在中文、日文、印度文和英文数据集上都取得了最优异的性能,尤其是在风格分数指标上,相比之前的 SOTA 方法,SDT 取得了较大突破。

话袋AI笔记 话袋AI笔记

话袋AI笔记, 像聊天一样随时随地记录每一个想法,打造属于你的个人知识库,成为你的外挂大脑

话袋AI笔记 47 查看详情 话袋AI笔记

会模仿笔迹的AI,为你创造专属字体

会模仿笔迹的AI,为你创造专属字体

定性评价 在中文生成方面,相比以前的方法,SDT 生成的手写字符既能避免字符的崩坏又能很好的临摹用户的书写风格。得益于字形风格学习,SDT 在字符的笔画细节生成方面也能做的很好。

会模仿笔迹的AI,为你创造专属字体

在其他语言上 SDT 也表现良好。尤其在印度文生成方面,现有主流方法很容易生成崩溃的字符,而我们的 SDT 依旧能够维持字符内容的正确性。

会模仿笔迹的AI,为你创造专属字体

不同模块对算法性能的影响 如下表所示,本文提出的各个模块具有协同作用,有效提升了对用户笔迹的临摹性能。具体来说,书写者风格的加入提升了 SDT 对字符整体风格的模仿,例如字符的倾斜程度和长宽比等,而字形风格的加入改善了生成字符的笔画细节。相比已有方法简单的融合策略,在各项指标上 SDT 的自适应动态融合策略全面增强了字符的生成性能。

会模仿笔迹的AI,为你创造专属字体

会模仿笔迹的AI,为你创造专属字体

两种风格的可视化分析 对两种风格特征进行傅里叶变换得到如下的频谱图,从图中观察到,书写者风格包含更多的低频成分,而字形风格主要关注高频成分。事实上,低频成分包含目标的整体轮廓,高频成分则更加关注物体的细节。这一发现进一步验证和解释了解耦书写风格的有效性。

会模仿笔迹的AI,为你创造专属字体

展望

大家可以通过笔迹 AI 创造自己的专属字体,在社交平台上更好的表达自我!

以上就是会模仿笔迹的AI,为你创造专属字体的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/519873.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 04:59:11
下一篇 2025年11月9日 04:59:57

相关推荐

  • PHP 并发文件操作中的数据完整性保障:使用文件锁防止数据丢失

    本文旨在解决服务器端在处理高并发文件写入时可能发生的数据丢失问题。当多个请求同时尝试修改同一文件时,可能导致竞态条件。通过引入 PHP 的文件锁(`flock`)机制,可以确保文件在写入过程中被独占访问,从而有效防止数据损坏或丢失,保障数据传输和存储的原子性与一致性。 在现代 Web 应用中,客户端…

    2025年12月12日
    000
  • Elementor主题构建器中动态显示分类归档文章的最佳实践

    Elementor主题构建器允许通过“文章归档”小部件和“当前查询”设置,轻松实现在分类归档页面动态显示对应分类文章。本教程将指导您如何利用这一功能,避免不必要的复杂自定义代码,高效构建动态内容页面,确保分类页面的文章内容与当前分类上下文自动匹配。 在构建WordPress网站时,尤其是在使用Ele…

    2025年12月12日
    000
  • PHP命令怎么执行版本控制操作_PHP命令行Git/SVN操作

    通过PHP系统调用函数可执行Git或SVN命令实现自动化版本控制,如使用shell_exec()获取状态、exec()提交推送,需注意权限、安全及返回码处理,适用于部署脚本与CI/CD流程。 在PHP开发中,通过命令行执行版本控制操作是日常工作的常见需求。虽然PHP本身不直接提供Git或SVN功能,…

    2025年12月12日
    000
  • PHP三元运算符与逻辑判断_PHP三元运算符逻辑组合

    三元运算符用于简洁条件判断,语法为“条件 ? 值1 : 值2”,适用于赋值与输出场景,如 $status = $isLoggedIn ? ‘已登录’ : ‘未登录’;可嵌套处理多条件,如 $result = $score >= 90 ? &#82…

    2025年12月12日
    000
  • PHP/SQL:检测数据库中是否存在表

    本文将介绍如何使用sql命令结合php来检测一个数据库中是否包含任何数据表。通过执行特定的sql查询,并解析其结果,开发者可以有效地判断数据库的结构状态,从而在应用程序中实现基于表存在与否的逻辑分支,例如在首次运行时进行初始化设置或显示特定消息。 在开发Web应用程序时,有时我们需要判断一个数据库是…

    2025年12月12日
    000
  • PHP实现CSV文件ID自增及数据追加教程

    本教程详细阐述了如何在csv文件中实现类似数据库的id自增功能,并在每次追加新数据时自动分配唯一的递增id。我们将通过解析现有csv数据、查找最大id、生成新id,并将表单提交的新用户数据连同新id一并写入csv文件,确保数据完整性和id的连续性。 在许多Web应用场景中,我们需要将用户提交的数据存…

    2025年12月12日
    000
  • 如何使用PDO迭代函数返回的变量

    本文旨在解决在使用PHP PDO(PHP Data Objects)时,如何正确地迭代从函数返回的结果集的问题。我们将通过示例代码,详细讲解如何获取和遍历PDOStatement对象中的数据,避免常见的错误,并提供最佳实践建议,确保你能有效地处理数据库查询结果。 在使用PHP PDO时,经常会遇到需…

    2025年12月12日
    000
  • CSV文件数据追加与自增ID处理教程

    本教程详细介绍了如何将web表单提交的新数据追加到csv文件中,并自动生成一个递增的唯一id。文章涵盖了从现有csv数据中获取最大id、构建新数据行、将新行写入csv文件,以及处理并发写入、数据验证和错误处理等关键注意事项,旨在提供一个健壮且实用的解决方案。 1. 引言:CSV文件作为轻量级数据存储…

    2025年12月12日
    000
  • CSV文件数据管理:实现ID自动增长与表单数据写入

    本文详细介绍了如何利用php处理web表单数据,并将其追加到csv文件中。核心内容在于实现类似数据库的id自增机制,通过读取现有csv文件获取最大id并递增,从而为新记录生成唯一标识符,确保数据管理的有序性和便捷性。 在许多轻量级应用或数据收集场景中,将用户提交的表单数据存储到CSV(Comma S…

    2025年12月12日
    000
  • 实现带前缀的自动递增编号:基于数据库自增ID的策略

    本教程详细阐述了如何在Web应用中,特别是使用CodeIgniter等框架时,实现一种安全可靠的自动递增编号生成机制。通过利用数据库的自增主键ID,我们可以在用户提交表单后,生成带有特定前缀(如“LP”)和零填充格式(如“LP00001”)的唯一引用编号,有效避免了并发提交可能导致的编号冲突问题。 …

    2025年12月12日
    000
  • mPDF中绝对定位元素字体大小失效问题:原因与解决方案

    本文深入探讨了在使用mpdf生成pdf时,绝对定位html元素内联字体大小设置不生效的常见问题。核心原因在于mpdf对具有固定宽高和绝对定位的元素进行内容自适应调整。教程提供了详细的解释和实用的解决方案,强调通过合理调整元素的宽度和高度来确保字体大小正确渲染,从而实现预期的排版效果。 mPDF中绝对…

    2025年12月12日
    000
  • React 应用中 Axios 数据加载状态的优雅处理

    在react应用中使用axios进行异步数据请求时,管理加载状态是提升用户体验的关键。本文将探讨两种主要策略:一是条件渲染,即在数据完全加载前不显示任何内容;二是展示加载指示器(如加载动画或骨架屏),告知用户数据正在获取中。我们将通过代码示例和最佳实践,帮助开发者有效地处理数据加载过程中的ui反馈,…

    2025年12月12日
    000
  • 使用 Docker Compose 在 PHP 容器中执行 Artisan 命令

    本文旨在解决在使用 Docker Compose 搭建 Laravel 开发环境时,如何正确执行 `php artisan` 命令的问题。通过简化命令路径,避免因路径错误导致的问题,并提供清晰的执行方式,帮助开发者顺利在 Docker 容器中运行 Artisan 命令,从而更高效地进行 Larave…

    2025年12月12日
    000
  • 使用MySQL窗口函数和PHP高效计算每日数据变化量

    本文详细介绍了如何利用mysql 8.0+的窗口函数`first_value`,结合php(pdo或mysqli)从数据库中提取每日数据的起始和结束值,进而计算出每日的数据增长或减少量。教程将涵盖数据库表结构、sql查询构建、php集成代码示例以及相关注意事项,旨在提供一个专业且实用的数据分析解决方…

    2025年12月12日
    000
  • 使用数据库数据计算每日增量:SQL窗口函数与PHP实现

    本文详细介绍了如何利用mysql 8.0及更高版本提供的窗口函数,结合php编程语言,从包含时间戳和计数数据的数据库表中高效计算每日的增量。教程涵盖了sql查询的构建、php中pdo和mysqli的集成示例,并指导读者如何从数据库中提取每日的初始值和最终值,进而计算出每日变化量。 在许多数据监控和分…

    2025年12月12日
    000
  • 使用SQL窗口函数和PHP计算数据库中每日数据增量

    本教程将详细介绍如何利用mysql 8.0及以上版本的窗口函数(`first_value`)结合php,从数据库中高效地计算出特定日期内某个数值的每日增量。文章涵盖了数据库查询逻辑、sql语句构建、以及在php(pdo和mysqli)中集成并处理结果的完整过程,旨在帮助开发者实现“过去24小时内,数…

    2025年12月12日
    000
  • PHP页面按需加载CSS和JS资源优化指南

    本教程详细介绍了如何在php项目中实现css和javascript文件的按需加载,避免不必要的资源引用,从而提升页面性能和缓存效率。通过构建一个集中式资源库和动态引用机制,确保每个页面只加载其必需的样式和脚本,有效优化用户体验。 引言:优化前端资源加载的重要性 在现代Web开发中,页面加载速度是用户…

    2025年12月12日
    000
  • 使用 Blade 模板引擎静态添加自定义指令

    本文介绍了如何在 Craig Duncan 的 Blade 模板引擎中静态添加自定义指令,特别是针对修改 CSS 和 JavaScript 资源路径的需求。通过示例代码,详细讲解了如何利用 `Blade::directive` 方法以及 `assetify` 函数实现自定义指令,并提供了多种解决方案…

    2025年12月12日
    000
  • 解决 Symfony FormType 扩展中“块名称重复”错误

    当在 symfony 中扩展 formtype 并遇到“块名称重复”错误时,通常是由于子 formtype 的块前缀与父 formtype 的块前缀发生冲突所致。本文将深入探讨此问题的根源,并提供通过重写 `getblockprefix()` 方法来确保 formtype 命名唯一性的解决方案,从而…

    2025年12月12日
    000
  • 配置PHP框架的日志系统_通过Symfony完成php框架怎么用的记录

    Symfony通过集成Monolog提供强大日志功能,可在不同环境配置日志级别与输出路径,如开发环境记录debug信息、生产环境仅记录error;在控制器中注入LoggerInterface可记录请求流程、业务逻辑及异常行为;支持自定义日志通道实现模块化追踪,如分离支付或认证日志;结合配置与代码埋点…

    2025年12月12日
    000

发表回复

登录后才能评论
关注微信