【仿真建模-anylogic】EventCondition原理解析

2024-06-15 17:44

本文主要是介绍【仿真建模-anylogic】EventCondition原理解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Author:赵志乾
Date:2024-06-15
Declaration:All Right Reserved!!!

1. 类图

2. 原理解析

2.1 核心函数
函数功能
EventCondition(Agent owner)构造函数,入参设定事件的owner
void start()启动事件上的条件检测;如果启动时条件为true,则事件会被立即执行
void reset()取消当前的事件调度
void restart()重新在条件上启动检测
void onChange()变更发生时执行
boolean isMonitoring()判定当前是否在条件上做检测
2.2 代码解析

          由于Anylogic内核做了代码混淆,以下代码为二次加工后的逻辑:

//**************************核心字段************************
// 条件是否处于检测中
private boolean monitoring = false;//**************************构造函数************************
//设定事件的owner
public EventCondition(Agent owner) {super(owner);
}//*************************启动函数**************************
//在owner的start()函数中调用
public void start() {// 禁用超时事件--条件和超时拥有共同的基类this.disableTimeoutEvent();// 在引擎中注册该事件this.getAgent().getEngine().register(this);// 设置检测状态this.monitoring = true;// 首次判定,如果此刻条件满足,则立即执行if (this.getAgent().testConditionOf(this)) {this.enableTimeOutEvent(0.0); // 超时时间为0,即为立即开始执行}
}//************************取消检测与重启检测*********************
//取消检测
public void reset() {// 禁用超时事件this.disableTimeoutEvent();// 设置检测状态为取消this.monitoring = false;// 引擎中移除事件this.getAgent().getEngine().unregister(this);
}
// 重启检测
public void restart() {// 禁用超时事件this.disableTimeoutEvent();// 设置检测状态为启用this.monitoring = true;// 引擎中注册事件this.getAgent().getEngine().register(this);
}public boolean isMonitoring() {return this.monitoring;
}//***************************变更**********************************
public void onChange() {// 未检测时不执行if (!this.monitoring) {return;}// 未触发检测条件时,再次禁用超时事件if (!this.getAgent().testConditionOf(this)) {this.disableTimeoutEvent();return;}// 如果事件未做超时规划,则规划0时长超时触发,即立刻执行if (!this.isActive()) {this.enableTimeOutEvent(0.0);}
}//******************************执行逻辑****************************
void execute() {super.execute();Agent owner = this.getAgent();// 条件未满足则不执行if (!owner.testConditionOf(this)) {this.getAgent().nothingChanged();return;}// 设置检测状态为取消this.monitoring = false;try {// 执行自定义逻辑owner.executeActionOf(this);} finally {// 如果处于未检测状态则从引擎中移除事件,所以如果想再次启用检测需要调用restart方法if (!this.monitoring) {owner.getEngine().unregister(this);}}
}

3. 应用场景

        图形编辑窗口拖拽Event组件,并选择Trigger Type为Condition时,Anylogic会自动生成EventCondition实例;当指定的检测条件为true时,自定义逻辑会被执行;

        如果条件使用连续变化量,则数值引擎会持续检测条件是否发生;

        如果是纯离散模型,则只会在变更发生时才会进行检测,即在onChange函数中检测;

这篇关于【仿真建模-anylogic】EventCondition原理解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1064139

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit

OWASP十大安全漏洞解析

OWASP(开放式Web应用程序安全项目)发布的“十大安全漏洞”列表是Web应用程序安全领域的权威指南,它总结了Web应用程序中最常见、最危险的安全隐患。以下是对OWASP十大安全漏洞的详细解析: 1. 注入漏洞(Injection) 描述:攻击者通过在应用程序的输入数据中插入恶意代码,从而控制应用程序的行为。常见的注入类型包括SQL注入、OS命令注入、LDAP注入等。 影响:可能导致数据泄

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。