`
- 浏览:
112428 次
- 性别:
- 来自:
广州
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- package org.drools.examples
-
- import org.drools.examples.conway.Cell;
- import org.drools.examples.conway.CellGrid;
- import org.drools.examples.conway.Neighbor;
- import org.drools.examples.conway.Phase;
- import org.drools.examples.conway.CellState;
-
- import org.drools.WorkingMemory;
- import org.drools.common.InternalWorkingMemoryActions;
- import org.drools.RuleBase;
-
-
-
-
-
-
-
- # 建立格子与其右上角格子的邻居关系
- rule "register north east"
- ruleflow-group "register neighbor"
- when
- # 获得棋盘列数
- CellGrid( $numberOfColumns : numberOfColumns )
- # 获得棋盘内的每个格子,最右边除外,因为最右边没有右上角
- $cell: Cell( $row : row > 0, $col : col < ( $numberOfColumns - 1 ) )
- # 获得上面格子的东北角格子
- $northEast : Cell( row == ($row - 1), col == ( $col + 1 ) )
- then
- # 为这两个格子建立邻居关系
- insert( new Neighbor( $cell, $northEast ) );
- insert( new Neighbor( $northEast, $cell ) );
- end
-
- # 建立格子与其正上方格子的邻居关系
- rule "register north"
- ruleflow-group "register neighbor"
- when
- $cell: Cell( $row : row > 0, $col : col )
- $north : Cell( row == ($row - 1), col == $col )
- then
- insert( new Neighbor( $cell, $north ) );
- insert( new Neighbor( $north, $cell ) );
- end
-
- # 建立格子与其左上角格子的邻居关系
- rule "register north west"
- ruleflow-group "register neighbor"
- when
- $cell: Cell( $row : row > 0, $col : col > 0 )
- $northWest : Cell( row == ($row - 1), col == ( $col - 1 ) )
- then
- insert( new Neighbor( $cell, $northWest ) );
- insert( new Neighbor( $northWest, $cell ) );
- end
-
- # 建立格子与其左边格子的邻居关系
- rule "register west"
- ruleflow-group "register neighbor"
- when
- $cell: Cell( $row : row >= 0, $col : col > 0 )
- $west : Cell( row == $row, col == ( $col - 1 ) )
- then
- insert( new Neighbor( $cell, $west ) );
- insert( new Neighbor( $west, $cell ) );
- end
-
-
-
-
-
-
-
-
- # 将格子的邻居中少于两个是生存状态的格子的状态设为死
- rule "Kill The Lonely"
- ruleflow-group "evaluate"
- no-loop
- when
- # A live cell has fewer than 2 live neighbors
- theCell: Cell(liveNeighbors < 2, cellState == CellState.LIVE, phase == Phase.EVALUATE)
- then
- theCell.setPhase(Phase.KILL);
- update( theCell );
- end
-
- # 将格子的邻居中超过3个状态是生存的格子状态设为死
- rule "Kill The Overcrowded"
- ruleflow-group "evaluate"
- no-loop
- when
- # A live cell has more than 3 live neighbors
- theCell: Cell(liveNeighbors > 3, cellState == CellState.LIVE, phase == Phase.EVALUATE)
- then
- theCell.setPhase(Phase.KILL);
- update( theCell );
- end
-
- # 将格子的邻居中正好有3个是生存状态的死亡格子变为生
- rule "Give Birth"
- ruleflow-group "evaluate"
- no-loop
- when
- # A dead cell has 3 live neighbors
- theCell: Cell(liveNeighbors == 3, cellState == CellState.DEAD, phase == Phase.EVALUATE)
- then
- theCell.setPhase(Phase.BIRTH);
- update( theCell );
- end
-
- # 取消ruleflow-group为"calculate"的所有激活规则
- # clearRuleFlowGroup - Clears the RuleFlow group, cancelling all its Activations
- # 因为在"generation"后,"calculate"组的规则还留在引擎中,如果不事先取消,就会引起无限循环
- rule "reset calculate"
- ruleflow-group "reset calculate"
- when
- then
- WorkingMemory wm = drools.getWorkingMemory();
- wm.clearRuleFlowGroup( "calculate" );
- end
-
- # 将所有格子的Phase为Kill的格子状态设置为死,并将处理阶段Phase设置为DONE
- rule "kill"
- ruleflow-group "kill"
- no-loop
- when
- theCell: Cell(phase == Phase.KILL)
- then
- theCell.setCellState(CellState.DEAD);
- theCell.setPhase(Phase.DONE);
- update( theCell );
- end
-
- # 将所有格子的Phase为Birth的格子状态设置为生,并将处理阶段Phase设置为完成
- rule "birth"
- ruleflow-group "birth"
- no-loop
- when
- theCell: Cell(phase == Phase.BIRTH)
- then
- theCell.setCellState(CellState.LIVE);
- theCell.setPhase(Phase.DONE);
- update( theCell );
- end
-
- # 根据格子的生存状态改变邻居格子中LiveNeighbors属性的计数
- rule "Calculate Live"
- ruleflow-group "calculate"
- lock-on-active # 本规则更新的数据在规则流处理完成前不激活新的规则
- when
- # 获得状态为生存的格子
- theCell: Cell(cellState == CellState.LIVE)
- # 找到该格子的每一个邻居
- Neighbor(cell == theCell, $neighbor : neighbor)
- then
- # 为这个格子的每一个邻居的LiveNeighbors属性加1
- $neighbor.setLiveNeighbors( $neighbor.getLiveNeighbors() + 1 );
- # 将邻居格子的处理阶段Phase设置为EVALUATE
- $neighbor.setPhase( Phase.EVALUATE );
- update( $neighbor );
- System.out.println( "--live--" );
- System.out.println( "theCell: row"+theCell.getRow()+"col"+theCell.getCol());
- System.out.println ( "Neighbor: row:"+$neighbor.getRow()+"col"+$neighbor.getCol()+";LiveNeighbors:"+ $neighbor.getLiveNeighbors()) ;
- end
-
- # 类似上一规则,只是进行递减操作
- # 对于这个规则,不太熟悉规则引擎的程序员可能会有所迷惑,所有的格子初始化状态都是DEAD
- # 那这样的话很多格子的LiveNeighbors就会变成负数了,有这样的想法是因为忽略了规则引擎不是从数据里找到规则合适的地方
- # 而是在数据插入或发生变化时找到规则,一开始初始化所有格子为DEAD时确实激活了"Calculate Dead"的很多实例,但是在
- # setPattern时首先执行了"reset calculate",这取消了之前的所有"Calculate Dead"的激活实例
- # 然后运行"kill all"规则,如果是第一次,该规则不改变任何数据也不会激发新的规则
- # 然后是根据数据设置格子的生存状态,此时上面的"Calculate Live"规则被激活
- # 在后面的规则运算中每次执行"evalaute"规则组都要运行"reset calculate"也是这个原因
- # 然后在运行了"birth"和"kill"规则后才执行"Calculate Live"和"Calculate Dead"规则
- rule "Calculate Dead"
- ruleflow-group "calculate"
- lock-on-active # 本规则更新的数据在规则流处理完成前不激活新的规则
- when
- theCell: Cell(cellState == CellState.DEAD)
- Neighbor(cell == theCell, $neighbor : neighbor )
- then
- $neighbor.setLiveNeighbors( $neighbor.getLiveNeighbors() - 1 );
- $neighbor.setPhase( Phase.EVALUATE );
- update( $neighbor );
- System.out.println( "--dead--" );
- System.out.println( "theCell: row"+theCell.getRow()+"col"+theCell.getCol());
- System.out.println ( "Neighbor: row:"+$neighbor.getRow()+"col"+$neighbor.getCol()+";LiveNeighbors:"+ $neighbor.getLiveNeighbors()) ;
- end
-
- # 将所有生存状态的格子设为死亡
- rule "Kill All"
- ruleflow-group "kill all"
- no-loop
- when
- theCell: Cell(cellState == CellState.LIVE)
- then
- theCell.setCellState(CellState.DEAD);
- update( theCell );
- end
分享到:
Global site tag (gtag.js) - Google Analytics
相关推荐
David Wallace Croft在2008年11月6日向达拉斯规则组展示了一个名为“DroolsGameofLifeExample”的案例,该案例使用Drools规则引擎实现了Conway的生命游戏。生命游戏是一种零玩家游戏,初始状态后的变化完全由其规则...
碳交易机制下考虑需求响应的综合能源系统优化运行模型及有效性分析,碳交易机制下需求响应的综合能源系统优化运行策略探索:低碳减排的实践路径,碳交易机制下考虑需求响应的综合能源系统优化运行 综合能源系统是实现“双碳”目标的有效途径,为进一步挖掘其需求侧可调节潜力对碳减排的作用,提出了一种碳交易机制下考虑需求响应的综合能源系统优化运行模型。 首先,根据负荷响应特性将需求响应分为价格型和替代型 2 类,分别建立了基于价格弹性矩阵的价格型需求响应模型,及考虑用能侧电能和热能相互转的替代型需求响应模型; 其次,采用基准线法为系统无偿分配碳排放配额,并考虑燃气轮机和燃气锅炉的实际碳排放量,构建一种面向综合能源系统的碳交易机制; 最后,以购能成本、碳交易成本及运维成本之和最小为目标函数,建立综合能源系统低碳优化运行模型,并通过 4 类典型场景对所提模型的有效性进行了验证。 通过对需求响应灵敏度、燃气轮机热分配比例和不同碳交易价格下系统的运行状态分析发现,合理分配价格型和替代型需求响应及燃气轮机产热比例有利于提高系统运行经济性,制定合理的碳交易价格可以实现系统经济性和低碳性协同。 关键词: 碳交易机制;
MATLAB演示程序:涡旋拉盖尔-高斯光束的横模特性与拓扑荷数及径向指数的影响分析,涡旋拉盖尔高斯光束MATLAB演示程序,涡旋拉盖尔高斯光束横模MATLAB演示程序 拓扑荷数l : 决定了光束的轨道角动量。 具有不同拓扑荷数的涡旋拉盖尔 - 高斯光束携带不同大小的轨道角动量。 影响光束的相位分布。 当l≠0时,光束具有螺旋相位结构,即相位随着角向坐标以的周期变化。 可以通过光学方法进行调控和测量,在量子信息处理、光学镊子等领域有重要应用。 径向指数p : 表示径向方向上的节点数。 p值越大,光束在径向方向上的能量分布变化越复杂,会出现更多的节点和暗区。 与拓扑荷数一起决定了光束的整体形状和强度分布。 ,涡旋拉盖尔-高斯光束; 拓扑荷数l; 径向指数p; MATLAB演示程序; 螺旋相位结构; 角向坐标变化; 轨道角动量。,MATLAB演示涡旋拉盖尔-高斯光束横模:拓扑荷数与径向指数的影响
PFC5.0算例代码解析:含矿物岩石材料,PFC5.0代码解析:探究由三种矿物构成的岩石与类岩石材料在GBM条件下的单轴压缩2D模拟算例,助力学习与技能提升,PFC5.0代码,含三种矿物组成的岩石或者类岩石材料,GBM,单轴压缩2d,算例代码仅供学习以及提升 ,关键词:PFC5.0代码;三种矿物组成;岩石或类岩石材料;GBM;单轴压缩2d;算例代码;学习;提升; 关键词:PFC5.0; 矿物组成; 岩石/类岩石; GBM; 单轴压缩; 算例学习; 提升;,PFC5.0模拟:含三种矿物岩石材料单轴压缩算例
Matlab三维A*算法详解:Astar三维路径规划及自定义地图、障碍物与代函数设定指南,Matlab三维A星算法路径规划工具箱,matlab三维A*算法 Astar三维路径规划 超详细注释 可自定义地图 自定义障碍物栅格数量和颜色 路径颜色 修改代价函数 预设5种常见评价指标 可 ,matlab; A*算法; 三维路径规划; 详细注释; 自定义地图; 自定义障碍物; 栅格数量和颜色; 路径颜色; 代价函数; 评价指标。,Matlab三维A*算法:超详细注释,自定义地图与障碍物路径规划
win32汇编环境,对话框中使用树形视图示例三
**基于SVPWM与死区补偿的PMSM dq轴电感离线辨识方法:高频注入法与电流极性分析**,SVPWM死区补偿技术下的PMSM电感离线辨识方法研究——基于电流极性与高频注入法的高效识别策略,SVPWM+死区补偿(基于电流极性)+高频注入法辨识PMSM的dq轴电感(离线辨识) 1.模型的中的电机,为采用自建的电机模型 2.适用于spmsm和ipmsm, 3.基于两相静止坐标轴电压注入,可通过设置合理的电压幅值和频率,在静止状态下准确辨识电感(更电机后,由于电机额定电压与转速的不同,可能需要调整原有的高频注入参数以获取满意的辨识效果)(不适用在线辨识) 4.死区补偿,是基于电流矢量极性判断 5.可进行有、无死区补偿下的辨识效果对比(资料中包含多个模型,为笔者当初在有无死区补偿,不同设置条件下的进行参数辨识效果对比,以及模型中包含的一些注释,或可供参考) 6.如果模型运行提示Ts未定义,可在命令行窗口输入Ts=0.0001,以解决该报错 7.模型与参考的期刊lunwen一一对应,可互相印证,其建模方式和思想,适合小白入门学习(不建议初学者无参考lunwen的模型) ,SVPWM; 死区补偿
关于电容电流反馈在有源阻尼谐振抑制及SVPWM策略中的运用及其结合单电流环与中点电位平衡控制的综合研究(参考《某领域文献》《另一些领域的研究》等),电容电流反馈SVPWM控制,电容电流反馈有源阻尼谐振抑制+SVPWM 含: [1]有源阻尼谐振抑制+SVPWM [2]单电流环控制 [3]中点电位平衡控制 提供相关参考文献 ,有源阻尼谐振抑制; SVPPM; 电容电流反馈; 谐振抑制; 中点电位平衡控制; 文献暂无。,电容电流反馈结合SVPWM与有源阻尼谐振抑制的研究与实现
易福门RFID:高效控制标准块,多重调用易管理,轻松修改编号与硬件标识符,RFID控制标准块多重调用便捷设,易福门RFID控制标准块,可以多重调用,只需要更改编号和硬件标识符。 ,易福门RFID;控制标准块;多重调用;编号;硬件标识符,易福门RFID标准控制块:多调高效,只需更改编号和硬件标识
TypeScript 基础语法,本人亲自整理的资料
基于博途西门子PLC的多种液体混合控制系统设计与实现:一份包含全流程的电子程序资料,基于博途西门子PLC的多种液体混合控制系统设计与实现:一份包含全流程的电子程序资料,基于plc多种液体混合控制系统设计 博途 西门子plc 本为电子程序资料 一、包含内容: ①西门子PLC程序+HMI仿真工程 (博途V14或以上) 一份; ②配套有IO点表+PLC接线图+主电路图+控制流程图 (CAD源文件可编辑); ,基于plc多种液体混合控制系统设计; 博途V14; 西门子plc; 混合控制; 控制系统设计; 程序仿真; IO点表; PLC接线图; 主电路图; 控制流程图。,基于博途V14的西门子PLC多种液体混合控制系统设计资料
寻找热泵最佳压力的优化算法 输入Cop和高压值,以找到最大化Cop的最佳高压 Optimization algorithm to find optimal pressure of heat pump Inputs of Cop and high pressure values to find optimal high pressure that maxes out COP
三相变压器空载合闸励磁涌流仿真研究:特点分析与观察,变压器空载合闸:三相励磁涌流仿真研究及特性分析,【1】变压器空载合闸时励磁涌流的仿真 仿真目的:分析三相变压器空载合闸过程中,观察励磁涌流的特点 仿真结果:励磁涌流的特点和分析过程可详细咨询。 ,励磁涌流;变压器空载合闸;仿真目的;分析特点;仿真结果。,变压器空载合闸仿真:励磁涌流分析
孪生模型环境安装及其训练方法
更多毕业设计https://cv2022.blog.csdn.net/article/details/124463185
315MHz与433MHz无线遥控接收解码Keil源程序及AD格式电路图详解,315MHz和433MHz无线遥控接收解码源程序,附带Keil源程序和AD格式电路图,315 433MHZ无线遥控接收解码源程序 Keil源程序 含AD格式电路图 ,315MHz无线遥控接收; 433MHz无线解码源程序; Keil源程序; AD格式电路图,基于Keil的315/433MHz无线遥控解码源程序解析及AD格式电路图详解
MATLAB滚动轴承故障诊断程序:采用西楚凯斯大学数据,基于变分模态分解(VMD)算法与包络谱分析的故障诊断比较实现,MATLAB滚动轴承故障诊断程序:采用西楚凯斯大学数据,基于变分模态分解(VMD)算法与包络谱分析的故障诊断比较实现,MATLAB滚动轴承故障诊断程序:采用西楚凯斯大学数据,首先通过变分模态分解(VMD)算法处理,而后分别通过包络谱分析实现故障诊断 ps.通过尖峰对应的频率与计算出的故障频率比较,实现故障诊断 ,核心关键词:MATLAB; 滚动轴承故障诊断; 西楚凯斯大学数据; 变分模态分解(VMD)算法; 包络谱分析; 故障频率比较。,MATLAB基于VMD算法的滚动轴承故障诊断程序:西楚凯斯大学数据包络谱分析
个人ii c的一个说明的资料
更多毕业设计https://cv2022.blog.csdn.net/article/details/124463185
python语言,窗口形式 单机的形式,CS模式 mysql 1.重点是算法比较 各个算法参数 产生的图和数据足够了 做影评参照 2.自适应svm 既然加了自适应 那它比svm的优势在哪,自适应也是逐步完善的算法 拿新的和旧的比较一下 3.分析结果显示 调图标库即可,条状图 饼状图之类的 不是网站