eFLL (嵌入式模糊逻辑库) 技术文档
2024-12-28 03:07:31作者:平淮齐Percy
1. 安装指南
通用安装方式
步骤 1: 访问 eFLL 官方 GitHub 项目页面。
步骤 2: 使用 Git 克隆项目,或者点击“下载为 zip”按钮下载。
步骤 3: 将克隆或解压缩的文件移动到某个文件夹中,并建议将文件夹重命名为“eFLL”。
步骤 4: 编译并将库链接到您的代码中(参考 Makefile)。
Arduino 安装与导入
简单方法
步骤 1: 打开 Arduino IDE。
步骤 2: 在主菜单中,选择“草图” >> “包含库” >> “管理库”。
步骤 3: 搜索“eFLL”或“Fuzzy”。
步骤 4: 在列表中找到 eFLL,点击“安装”完成。现在您可以在草图(sketches)中包含 eFLL。
旧方法
步骤 1: 访问 eFLL 官方 GitHub 项目页面。
步骤 2: 使用 Git 克隆项目,或者点击“下载为 zip”按钮下载。
步骤 3: 将克隆或解压缩的文件移动到 Arduino 库文件夹中:
- Ubuntu:(/usr/share/arduino/libraries/),如果是通过 apt-get 安装的;
- Windows、Mac 或 Linux:(Arduino IDE 下载位置,库文件夹位于 Arduino IDE 内部)。
完成!库已准备好使用!
如果库安装成功,导入库非常简单:
步骤 4: 打开 Arduino IDE,在顶部菜单中选择“草图” >> “库” >> “导入 eFLL”。
2. 项目使用说明
项目使用 C++/C 语言编写,仅使用标准 C 语言库 "stdlib.h"。eFLL 库不仅适用于 Arduino,还适用于任何使用 C 语言编写的嵌入式系统。
它没有对模糊集、模糊规则、输入或输出的显式限制,这些限制取决于每个微控制器的处理能力和存储空间。
eFLL 使用以下流程进行推理和组合:(MAX-MIN)和(Mamdani 最小),以及(面积中心)进行去模糊化。
已使用 GTest 进行测试。
3. 项目 API 使用文档
以下是一些主要对象的简要说明:
- Fuzzy 对象:包含整个模糊系统,通过它,您可以操作模糊集合、语言规则、输入和输出。
- FuzzyInput 对象:将属于同一域的所有输入模糊集合分组。
- FuzzyOutput 对象:类似于 FuzzyInput,用于分组属于同一域的所有输出模糊集合。
- FuzzySet 对象:是模糊库的主要对象之一,每个集合都可以用来建模所研究的系统。当前库支持三角、梯形和单点隶属度函数,这些函数基于点 A、B、C 和 D 构建而成,它们作为参数传递给构造函数 FuzzySet(float a, float b, float c, float d)。
- FuzzyRule 对象:用于构建 Fuzzy 对象的基本规则,包含一个或多个此类对象。使用 FuzzyRule fr = new FuzzyRule (ID, antecedent, consequent) 实例化。
- FuzzyRuleAntecedent 对象:用于组合 FuzzyRule 对象,负责构建模糊规则的先决条件部分。
- FuzzyRuleConsequent 对象:用于呈现 FuzzyRule 对象,负责构建输出表达式。
以下是一些方法:
bool setInput(int id, float value);用于将 crisp 输入值传递给系统,注意第一个参数是 FuzzyInput 对象的 ID,该参数值是预期的。bool fuzzify();用于启动模糊化过程、组合和推理。float defuzzify(int id);用于去模糊化。
4. 项目安装方式
请参考上述“安装指南”部分进行项目安装。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
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发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
热门内容推荐
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
531
3.74 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
336
178
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
886
596
Ascend Extension for PyTorch
Python
340
403
暂无简介
Dart
772
191
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
986
247
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
416
4.21 K
React Native鸿蒙化仓库
JavaScript
303
355