FastFel解析一个公式的步骤

FastFel 查看源码后,理解的运算步骤:

1) 创建一个 FelEngine,FelEngine fel = new FelEngineIml();

2) 将表达式 exp 解析成为一个节点树 FelNode tree, fel.parse(exp);

3) 打印节点树FelNode tree,查看其结构。

可知其结构为 前缀表达式(波兰表达式),

如 a + b = + a b

a+(b+c) = + a + b c

a+(b-c)*d = + a * - b c d

4) 从树中获取 运算符节点。

当节点为  FunNode 时,且不为 . 时,此节点是运算符,

当节点为  VarAstNode 时,为变量节点

当节点为  ConstNode 时,为 常量节点

5)  得到所有的运算符节点,……

问题: 如何解析出表达式 的?是只能有已经解析的那么几个,还是可以自定义扩展?

posted @   panie2015  阅读(606)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示