Finitomata 项目教程
2024-09-12 22:50:17作者:冯梦姬Eddie
1. 项目介绍
Finitomata 是一个基于 Elixir 语言的有限状态机(FSM)实现库。它提供了一个模板,允许开发者专注于业务逻辑,而不是过程管理和状态转换的一致性调整。Finitomata 可以从 PlantUML 或 Mermaid 的文本表示中生成 FSM 实现,支持多种配置和回调,适用于复杂的业务流程管理。
2. 项目快速启动
安装
首先,确保你已经安装了 Elixir 和 Mix。然后,在你的项目中添加 Finitomata 作为依赖:
def deps do
[
{:finitomata, "~> 0.26"}
]
end
运行 mix deps.get 来安装依赖。
定义 FSM
创建一个新的 Elixir 模块来定义你的 FSM:
defmodule MyFSM do
@fsm """
[*] --> s1 : to_s1
s1 --> s2 : to_s2
s1 --> s3 : to_s3
s2 --> [*] : ok
s3 --> [*] : ok
"""
use Finitomata, fsm: @fsm, syntax: :state_diagram
@impl Finitomata
def on_transition(:s1, :to_s2, _event_payload, state_payload) do
{:ok, :s2, state_payload}
end
def on_transition(:s1, :to_s3, _event_payload, state_payload) do
{:ok, :s3, state_payload}
end
end
启动 FSM
在你的应用中启动 FSM:
{:ok, _pid} = Finitomata.start_link()
Finitomata.start_fsm(MyFSM, "My first FSM", %{foo: :bar})
# 触发状态转换
Finitomata.transition("My first FSM", [:to_s2, nil])
# 获取当前状态
Finitomata.state("My first FSM")
3. 应用案例和最佳实践
应用案例
Finitomata 可以用于各种需要状态管理的场景,例如:
- 订单处理:订单从创建到完成的各个状态转换。
- 工作流管理:任务从开始到结束的各个阶段。
- 用户状态管理:用户从注册到激活的各个状态。
最佳实践
- 明确状态和事件:在定义 FSM 时,确保每个状态和事件都有明确的含义。
- 使用回调:利用
on_transition等回调函数来处理状态转换时的业务逻辑。 - 测试覆盖:编写单元测试来确保 FSM 的每个状态转换都能正确执行。
4. 典型生态项目
Finitomata 可以与其他 Elixir 生态项目结合使用,例如:
- GenStage:用于处理数据流和任务分发。
- NimbleOptions:用于配置管理。
- NimbleParsec:用于解析复杂的文本格式。
通过结合这些项目,可以构建更加复杂和强大的应用。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
522
3.71 K
Ascend Extension for PyTorch
Python
327
384
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
875
576
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
334
161
暂无简介
Dart
762
184
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.32 K
744
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
React Native鸿蒙化仓库
JavaScript
302
349
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
112
134