『设计』Laura.Compute 设计思路
前言:
前一篇文章 《『开源』也顺手写一个 科学计算器:重磅开源》 ,继 Laura.Compute 算法开源之后,有 博客园 园友 希望公开一下 Laura.Compute算法 的 设计思路——就是本文了。
算法思想:
模拟人为思考过程的算法 —— 算法没有任何 取巧 的成分;
唯一的优势 在于 算法的抽象思想,算法的架构,算法的 先分析,后运算 的执行模式,还有 算法的 简单的插件扩展方式;
执行过程:
比方说 我们要计算 1 + 2 – 3 * 4 / 5 + LEN('ShuXiaolong'), 我们知道 最终结果 是 11.6
算法 初始化: 算法 会 寻找所有 可用的扩展插件——算法内置 插件 就多达 30多个;
算法 分析:
需用插件: 通过关键字,找出 +,-,*,/,LEN 这几个 执行插件——排除多余 不会被用到 执行插件,节省效率;
拆析表达式: 事先分析元数据和参数,按照 运算优先级,一步步 将 表达式 分析为 唯一片段,具体如下:
1 + 2 – 3 * 4 / 5 + LEN('ShuXiaolong')
{Express_0} + {Express_1} - {Express_2} * {Express_3} / {Express_4} + LEN({Express_5})
{Express_0} + {Express_1} - {Express_6} / {Express_4} + LEN({Express_5})
{Express_0} + {Express_1} - {Express_7} + LEN({Express_5})
{Express_0} + {Express_1} - {Express_7} + {Express_8}
{Express_9} - {Express_7} + {Express_8}
{Express_10} + {Express_8}
{Express_11}
算法 执行:
最后的 唯一片段 为 {Express_11},他的 参数片段 为 {Express_10},{Express_8} ,他的 运算插件 为 +;
运算插件+ 需要 先计算 {Express_10} {Express_8} 的值,
而 {Express_10} 的 参数片段 为 {Express_9},{Express_7},他的 运算插件 为 -;
以此递归 …
算法抽象:
抽象,是 一种 求同 的过程 —— 在 不同需求逻辑中,找出其共性,并 设计出 最少核心类,最易扩展性 的过程;
于是,根据 上面的 执行过程,我们 的 核心对象就是:
表达式片段对象: {Express_数字} 这是他们的 唯一键值;他具备 参数片段集合;他有 运算插件;
运算插件对象:表达式中 的 不同 关键字,对应的 运算方式 —— 还得适应 后期的修改维护;
Ps.算法的王牌之处:运算符(+-*/),函数(LEN) 使用的是 同一抽象对象,同一扩展方式;
算法元数据:
算法元数据类型包括: String,Int,Double,Boolean,Array
算法不足:
算法 最大的 不足 在于:算法 的 元数据类型 是 固定的,算法的分析 是 内置的;
—— 元数据 不具备 扩展性 是 算法 最大的不足;
最后的总结:
其实,上面的 算法拆析过程,想必 各位 已经知道 算法的核心思想了;
而至于 算法 的 内存检索,内存排序 这些 高级功能,都只是 基于算法功能 的 额外顺手 实现,并没有多少 技术含量;
『设计』Laura.Compute 设计思路的更多相关文章
- 『开源』Slithice 2013 服务器集群 设计和源码
相关介绍文章: <『设计』Slithice 分布式架构设计-支持一体式开发,分布式发布> <『集群』001 Slithice 服务器集群 概述> <『集群』002 Sli ...
- 『设计』Slithice 分布式架构设计-支持一体式开发,分布式发布
项目原因: 参与过各种 分布式项目,有 Socket,Remoting,WCF,当然还有最常用的可以跨平台的 WebService. 分布式编码的时间浪费: 但是,无一例外的,开发分布式程序的开发遵循 ...
- 『重构--改善既有代码的设计』读书笔记----Extract Method
在编程中,比较忌讳的一件事情就是长函数.因为长函数代表了你这段代码不能很好的复用以及内部可能出现很多别的地方的重复代码,而且这段长函数内部的处理逻辑你也不能很好的看清楚.因此,今天重构第一个手法就是处 ...
- 『重构--改善既有代码的设计』读书笔记----Replace Method with Method Object
有时候,当你遇到一个大型函数,里面的临时变量和参数多的让你觉得根本无法进行Extract Method.重构中也大力的推荐短小函数的好处,它所带来的解释性,复用性让你收益无穷.但如果你遇到上种情况,你 ...
- 『计算机视觉』Mask-RCNN_从服装关键点检测看KeyPoints分支
下图Github地址:Mask_RCNN Mask_RCNN_KeyPoints『计算机视觉』Mask-RCNN_论文学习『计算机视觉』Mask-RCNN_项目文档翻译『计算机视觉』Mas ...
- 『计算机视觉』Mask-RCNN_训练网络其二:train网络结构&损失函数
Github地址:Mask_RCNN 『计算机视觉』Mask-RCNN_论文学习 『计算机视觉』Mask-RCNN_项目文档翻译 『计算机视觉』Mask-RCNN_推断网络其一:总览 『计算机视觉』M ...
- 『计算机视觉』FPN:feature pyramid networks for object detection
对用卷积神经网络进行目标检测方法的一种改进,通过提取多尺度的特征信息进行融合,进而提高目标检测的精度,特别是在小物体检测上的精度.FPN是ResNet或DenseNet等通用特征提取网络的附加组件,可 ...
- 『摄影欣赏』16幅 Romantic 风格照片欣赏【组图】
今天,我们将继续分享人类情感的系列文章.爱是人类最重要的感觉,也可能是各种形式的艺术(电影,音乐,书,画等)最常表达的主题 .这里有40个最美丽的爱的照片,将激励和给你一个全新的视觉角度为这种情绪.我 ...
- 『转载』Debussy快速上手(Verdi相似)
『转载』Debussy快速上手(Verdi相似) Debussy 是NOVAS Software, Inc(思源科技)发展的HDL Debug & Analysis tool,这套软体主要不是 ...
随机推荐
- Java GC 面试问题
转自:http://icyfenix.iteye.com/blog/715301 这个帖子的背景是今晚看到je上这张贴:http://www.iteye.com/topic/715256,心血来潮写下 ...
- 使用jsonp进行跨域访问
一.使用场景 当我们请求非本服务器的资源的时候,浏览器会禁止访问,并提示不允许跨域访问.此时我们可以使用jsonp这种请求方式,从其他服务器获取资源.在客户端调用提供jsonp支持的接口,获取json ...
- hibernate多对多映射关系实现
Course.hbm.xml: <?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC &q ...
- 修改mysql默认字符集的方案
mysql默认字符集能否进行修改呢?答案是肯定的,下面就将教您两种修改mysql默认字符集的方法,希望对您学习mysql默认字符集方面能有所启迪. (1) 最简单的修改方法,就是修改mysql的my. ...
- Python pass语句作用与用法
Python中的pass语句作用是什么?表示它不做任何事情,一般用做占位语句.pass语句具体作用及使用方法,我们往下看. pass语句在函数中的作用 当你在编写一个程序时,执行语句部分思路还没有完成 ...
- 《TCP/IP详解 卷一》读书笔记-----第三章 IP
1.Network byte order:数据在网络中的传输是按照大端模式来的,即如果需要传递一个四个字节的int变量,先传递最高的字节,然后依次类推.因此无论主机存储数据用的是大端模式还是小端模式, ...
- 二分+动态规划 POJ 1973 Software Company
Software Company Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 1112 Accepted: 482 D ...
- 怎样用ZBrush雕刻人体造型
之前我们通过学习使用ZBrush®中的Curves和Insert笔刷快速创建模型的躯干.四肢以及手指.经过老师耐心的讲解我们也收获了很多,知道了创建模型的流程和雕刻技巧.今天的ZBrush教程我们将结 ...
- 有向图的拓扑排序算法JAVA实现
一,问题描述 给定一个有向图G=(V,E),将之进行拓扑排序,如果图有环,则提示异常. 要想实现图的算法,如拓扑排序.最短路径……并运行看输出结果,首先就得构造一个图.由于构造图的方式有很多种,这里假 ...
- 《The Django Book》实战--第二章--动态网页基础
这章演示了一些最基本的Django开发动态网页的实例,由于版本不一样,我用的是Django 1.,6.3,有些地方按书上的做是不行的,所以又改了一些,写出来让大家参考. 这是一个用python写的一个 ...