`
Technoboy
  • 浏览: 158277 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

Introduction to Quartz(2)

阅读更多
7 JobStore
  Quartz 为所有类型的 Job 存储提供了一个接口。这个接口位于 org.quartz.spi 包中,叫做 JobStore。JobStore 用于对 Job、Trigger、Calendar、Listener和 Scheduler 状态进行存储。Quartz使用者通常不用直接访问JobStore接口的方法,它们在运行时被Scheduler访问。如果按照存储类型分类,Quartz提供了两种类型的JobStore,分别是非持久性JobStore(non-persistent JobStore)和持久性JobStore(persistent JobStore)。

7.1 Non-persistent JobStore
  Quartz的默认JobStore是RAMJobStore,它使用内存作为存储介质,因此它是非持久性的。RAMJobStore的配置十分简单,只需要在配置文件中添加如下一行即可:
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
RAMJobStore 是优点是速度快。但是由于RAMJobStore是非持久性的,因此Job 的易失性对于RAMJobStore不起作用,也就是说Job不会在应用关闭时被持久化保存。

7.2 Persistent JobStore
   Quartz 所带的所有的持久性的 JobStore 都扩展自 org.quartz.impl.jdbcjobstore.JobStoreSupport 类。JobStoreSupport是个抽象类,实现了 JobStore 接口。这个类的一个更好的名字本应该是 JDBCJobStoreSupport,因为这个类专门是为基于 JDBC 存储方案而设置的。Quartz 提供了两种不同类型的具体化的 JobStore,每一个设计为针对特定的数据库环境和配置:
  org.quartz.impl.jdbcjobstore.JobStoreTX。JobStoreTX 类设计为用于独立环境中,而不是与容器的事务集成。这并不意味着你不能在一个容器中使用 JobStoreTX,只不过它不是设计成接受容器的事务管理。
  org.quartz.impl.jdbcjobstore.JobStoreCMT。JobStoreCMT 类设计成接受容器的事务管理。它的名字来源于容器管理的事务(Container Managed Transactions (CMT))。
由于持久性的JobStore是基于 JDBC 的,因此需要在数据库中创建相关的表。你能在 <quartz_home>/docs/dbTables 目录下找到那些用于创建表的 SQL 脚本。Quartz  需要创建 如下12 张表:
  QRTZ_CALENDARS。 以 Blob 类型存储 Quartz 的 Calendar 信息。
  QRTZ_CRON_TRIGGERS。 存储 Cron Trigger,包括 Cron 表达式和时区信息。
  QRTZ_FIRED_TRIGGERS。 存储与已触发的 Trigger 相关的状态信息,以及相联 Job 的执行信息。
  QRTZ_PAUSED_TRIGGER_GRPS。存储已暂停的 Trigger 组的信息。
  QRTZ_SCHEDULER_STATE。存储少量的有关 Scheduler 的状态信息,和别的 Scheduler 实例(假如是用于一个集群中)。
  QRTZ_LOCKS。存储程序的非观锁的信息(假如使用了悲观锁) 。
  QRTZ_JOB_DETAILS。存储每一个已配置的 Job 的详细信息。
  QRTZ_JOB_LISTENERS。存储有关已配置的 JobListener 的信息。
  QRTZ_SIMPLE_TRIGGERS。存储SimpleTriggers,包括重复次数、间隔以及已触发的次数。
  QRTZ_BLOB_TRIGGERS。Trigger 作为 Blob 类型存储(用于 Quartz 用户用 JDBC 创建他们自己定制的 Trigger 类型,JobStore 并不知道如何存储实例的时候)。
  QRTZ_TRIGGER_LISTENERS。存储已配置的 TriggerListener 的信息。QRTZ_TRIGGERS 存储已配置的 Trigger 的信息。
以上所有的表都是以默前缀 QRTZ_ 开始。可以通过在 quartz.properties 文件中提供一个指定的前缀来改变它。
  JDBC API 依赖于专属于某个数据库平台的 JDBC 驱动,同样的,Quartz 依赖于某个 DriverDelegate 来与给定数据库进行通信。顾名思义, Scheduler 通过 JobStore 对数据库的调用是委托给一个预配置的 DriverDelegate 实例。这个代理承担起所有与 JDBC driver 也就是数据库的通信。所有的 DriverDelegate 类都继承自 org.quartz.impl.jdbcjobstore.StdDriverDelegate 类。StdDriverDelegte 只有所有代理可用的,平台无关性的基本功能。然而,在不同的数据库平台间还是存在太多的差异,因此可能需要为某个平台创建特定的代理。
  当使用持久性 JobStore 时,Quartz 需要一个数据源。Java中所有的数据源要实现 java.sql.Datasource 接口。Quartz 默认使用DBCP,也可以通过 JNDI 查找应用服务器中定义的 DataSource。
  以下是一个JDBC持久化job的例子:
org.quartz.scheduler.instanceName = DefaultQuartzScheduler
org.quartz.scheduler.rmi.export = false
org.quartz.scheduler.rmi.proxy = false
org.quartz.scheduler.wrapJobExecutionInUserTransaction = false

org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 10
org.quartz.threadPool.threadPriority = 5
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true

org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.tablePrefix=QRTZ_
org.quartz.jobStore.dataSource=qzDS

org.quartz.dataSource.qzDS.driver=com.mysql.jdbc.Driver
org.quartz.dataSource.qzDS.URL=jdbc:mysql://localhost:3306/quartz
org.quartz.dataSource.qzDS.user=root
org.quartz.dataSource.qzDS.password=root

  首先在类路劲下创建如上quartz.properties文件,假设使用MySQL innodb引擎,找到Quartz完整发布包下的docs/dbTables,执行tables_mysql_innodb.sql。然后运行SimpleTriggerRunner:
public class SimpleTriggerRunner {

	public static void main(String[] args) {
		try {
			JobDetail jobDetail = new JobDetail("job1_1", "jgroup1", SimpleJob.class);
			SimpleTrigger simpleTrigger = new SimpleTrigger("trigger1_1", "tgroup1"); 
			simpleTrigger.setStartTime(new Date());
			simpleTrigger.setRepeatInterval(2000);
			simpleTrigger.setRepeatCount(100);
			
			SchedulerFactory factory = new StdSchedulerFactory();
			Scheduler scheduler = factory.getScheduler();
			scheduler.scheduleJob(jobDetail, simpleTrigger);
			scheduler.start();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

public class SimpleJob implements Job{

	@Override
	public void execute(JobExecutionContext context)
			throws JobExecutionException {
		System.out.println("go!!!");
	}
}

  SimpleTriggerRunner执行一段时间后,停止,模拟程序退出。由于配置了JobStoreTX,trigger以及jobdetail的运行信息都会保存在数据库中。我们可以到数据库中查看qrtz_simple_triggers表:

  REPEAT_COUNT表示需要运行的总次数,TIMES_TRIGGERED表示已运行的次数。
  我们可以通过JDBCJobStoreRunner,根据记录在数据库中的任务数据,恢复任务的调度:
import org.quartz.Scheduler;
import org.quartz.SchedulerFactory;
import org.quartz.SimpleTrigger;
import org.quartz.Trigger;
import org.quartz.impl.StdSchedulerFactory;

public class JDBCJobStoreRunner {
	
	public static void main(String[] args) {
		try {
			SchedulerFactory factory = new StdSchedulerFactory();
			Scheduler scheduler = factory.getScheduler();
			String[] triggerGroupNames = scheduler.getTriggerGroupNames();
			for(int i = 0; i < triggerGroupNames.length; i ++){
				String[] triggers = scheduler.getTriggerNames(triggerGroupNames[i]);
				for(int j = 0; j < triggers.length; j++){
					Trigger trigger = scheduler.getTrigger(triggers[j], triggerGroupNames[i]);
					if((trigger instanceof SimpleTrigger) && (trigger.getFullName().equals("tgroup1.trigger1_1"))){
						scheduler.rescheduleJob(triggers[j], triggerGroupNames[i], trigger);
					}
				}
			}
			scheduler.start();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

  运营一段时间后退出,这时qrtz_simple_triggers表中的数据如下:

首先,Quartz会将原REPEAT_COUNT-TIMES_TRIGGERED得到新的REPEAT_COUNT值,并记录一运行的次数(重新从0开始计算)。
  重新启动JDBCJobStoreRunner后,数据又将发生变化:

  TIMES_TRIGGERED重新从0开始计数,而REPEAT_COUNT在原有基础上重新调整。
  继续运行JDBCJobStoreRunner,直至完成所有剩余次数,然后查看qrtz_simple_triggers表:

  这时,该表中的数据已经变为空。
  需要注意的是,如果使用JDBC保存任务调度数据,运行SimpleTriggerRunner,然后退出,当再次运营时,会抛异常:
org.quartz.ObjectAlreadyExistsException: Unable to store Job with name: 'job1_1' and group: 'jgroup1', because one already exists with this identification.

  这是因为每次调用scheduler.scheduleJob方法时,Quartz都会将JobDetail和Trigger的信息保存到数据库中,如果在数据库中有同名的JobDetail和Trigger,异常就产生了。
  最后提醒大家,如果按照以上步骤操作,报数据库字段异常时,可能是由于Quartz的发布包中tables_mysql_innodb.sql脚本少字段或建表有问题,可以考虑使用附件的脚本。当初笔者在调试时,发现tables_mysql_innodb脚本中,数据不完整,进行了部分修改。另外,笔者建议,在做这块的时候,将log4j打开,方便调试。

8 Features
8.1 Remoting
  借助于 RMI, Quartz允许在不同的JVM中部署和调度Job。Quartz的服务器端和客户端需要不同的配置,下面是服务器端的配置文件quartz_rmi_server.properties的例子:
#==============================================================  
# Configure Main Scheduler Properties  
#==============================================================   
org.quartz.scheduler.instanceName = RMIScheduler
org.quartz.scheduler.instanceId = AUTO

#==============================================================  
# Configure RMI Properties  
#==============================================================   
org.quartz.scheduler.rmi.export = true  
org.quartz.scheduler.rmi.registryHost = localhost   
org.quartz.scheduler.rmi.registryPort = 1099   
org.quartz.scheduler.rmi.serverPort = 0   
org.quartz.scheduler.rmi.createRegistry = true 

#==============================================================  
# Configure ThreadPool  
#==============================================================   
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool   
org.quartz.threadPool.threadCount = 10   
org.quartz.threadPool.threadPriority = 5  

#==============================================================  
# Configure JobStore  
#==============================================================   
org.quartz.jobStore.misfireThreshold = 60000
org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass=org.quartz.impl.jdbcjobstore.StdJDBCDelegate
org.quartz.jobStore.useProperties=false
org.quartz.jobStore.dataSource=mysql
org.quartz.jobStore.tablePrefix=QRTZ_ 
org.quartz.dataSource.mysql.driver=com.mysql.jdbc.Driver 
org.quartz.dataSource.mysql.URL=jdbc:mysql://localhost:3306/quartz 
org.quartz.dataSource.mysql.user=root 
org.quartz.dataSource.mysql.password=123456 
org.quartz.dataSource.mysql.maxConnections=5

  其中org.quartz.scheduler.rmi相关属性的含义如下:
    org.quartz.scheduler.rmi.export。要使 Quartz 调度器作为一个可用的 RMI 对象,这个标记必须设置为 true,默认值是false。
    org.quartz.scheduler.rmi.registryHost。运行 RMI 注册表所在的主机。
    org.quartz.scheduler.rmi.registryPort。 RMI 注册服务监听所用的端口号(通常是1099)。
    org.quartz.scheduler.rmi.createRegistry。Quartz 是否会创建 RMI 注册服务。如果你不希望 Quartz 创建注册服务就设置为 false 或 never。如果是希望 Quartz 首先尝试去使用已存在的注册服务,如果失败的话自行创建一个就设置为 true 或 as_needed。
    org.quartz.scheduler.rmi.serverPort。Quartz 调度器服务所绑定的端口号,在其中监听到来的连接。默认情况下,RMI 服务会随机选择一个端口号作为调度器绑定到 RMI 注册服务的端口。
  下面是Quartz服务器端程序的例子:
public class QuartzRmiServer {
	
	public static void main(String[] args) throws Exception {
		System.out.println("starting QuartzRmiServer...");
		
		//
		System.setProperty("org.quartz.properties", "quartz_rmi_server.properties");  
		Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();   
		scheduler.start();

		//
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		while (true) {
			String line = br.readLine();
			if (line.equalsIgnoreCase("exit") || line.equalsIgnoreCase("quit")) {
				break;
			}
		}
		br.close();
		scheduler.shutdown(true);
	}   
}


  下面是服务器端的配置文件quartz_rmi_client.properties的例子:
#=============================================================  
# Configure Main Scheduler Properties  
#=============================================================   
org.quartz.scheduler.instanceName = RMIScheduler  
org.quartz.scheduler.instanceId = AUTO  

#==============================================================  
#Configure RMI Properties  
#==============================================================   
org.quartz.scheduler.rmi.registryHost=localhost   
org.quartz.scheduler.rmi.registryPort=1099   
org.quartz.scheduler.rmi.proxy= true

   其中org.quartz.scheduler.rmi相关属性的含义如下:
     org.quartz.scheduler.rmi.registryHost。运行 RMI 注册服务所在的主机,需要同服务器端的配置相同。
     org.quartz.scheduler.rmi.registryPort。运行 RMI 注册服务所监听的端口(通常是 1099),需要同服务器端的配置相同。
     org.quartz.scheduler.rmi.proxy。如果希望连接到远程服务端的调度器,这个属性必须是true。
  此外,属性 org.quartz.scheduler.instanceName 在 RMI 客户端和服务端必须一致。不然,客户将无法在注册服务中查找到服务对象,会收一个客户端无法获取到远程调度器句柄的异常。
  下面是Quartz客户端程序的例子:
public class QuartzRmiClient {
	
	public static void main(String[] args) throws Exception {
		System.out.println("starting QuartzRmiClient...");
		
		//
		System.setProperty("org.quartz.properties", "quartz_rmi_client.properties");
		Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();   

		//
		Random random = new Random();
		int id = Math.abs(random.nextInt());
		String name = "simpleJob" + id;
		JobDetail jd = new JobDetail(name, "group1", SimpleStatefulJob.class);
		jd.setVolatility(false);
		
		//
		CronTrigger trigger = new CronTrigger("cronTrigger" + id, "group1");
  		CronExpression cronExpression = new CronExpression("0/5 * * * * ?");
  		trigger.setCronExpression(cronExpression);
  		trigger.setVolatility(false);
  		scheduler.scheduleJob(jd, trigger);
	}   
}

  首先启动服务端程序,然后运行客户端程序。由于客户端的配置文件中org.quartz.scheduler.rmi.proxy 的值是 true,因此在客户端程序启动后,从StdSchedulerFactory的到的Scheduler是服务器端Scheduler的远程代理,因此在客户端部署的Job实际上会被远程的Scheduler执行。启动客户端部署一个Job后就会退出。如果一切正常,在服务器端的控制台就能看到客户端部署的Job所打印的消息。你也可以再次启动客户端以便部署更多的Job。如果在服务器端的控制台输入exit或者quit,那么服务器端的程序会退出。由于服务器端使用了持久化的JobStore,而且客户端部署的Job和Trigger的volatility属性值是false,因此如果再次启动服务器端程序,之前部署的Job仍然会被执行。
分享到:
评论

相关推荐

    人类预期寿命数据(世界各国)1960-2022年.xlsx

    介绍 人类预期寿命是指在特定年龄出生的人群,按照当前的死亡率水平,预期平均能够存活的年数。预期寿命衡量一个国家和地区卫生健康状况、社会经济发展水平和生活条件的重要参数 数据来源为世界银行、第四-七次全国人口普查数据 ## 一、人类预期寿命趋势 2022年,全球人类预期平均寿命为72岁。其中女性为74.5岁,男性为69.6岁 世界银行的数据显示,1960-2022年期间,人类预期寿命整体呈上升趋势。随着医疗技术的进步、公共卫生的改善、营养条件的提升以及生活方式的改变,这62年间,人类平均预期寿命提升了21岁。受到新冠疫情的影响,2021年,预期寿命有所下降,但在2022年有所回升

    光伏超级电容与蓄电池混合储能系统能量管理仿真:模型、算法及应用场景

    内容概要:本文深入探讨了光伏超级电容与蓄电池混合储能系统在能量管理方面的仿真研究。主要内容涵盖光伏Boost模块的最大功率点跟踪(MPPT)算法实现、蓄电池与超级电容的分工及其控制策略、仿真工况的设计与分析。文中不仅提供了详细的数学模型和控制算法,还展示了具体的仿真案例,如200Hz投切负载和光照突降测试,验证了系统的动态响应能力和稳定性。此外,文章强调了仿真过程中需要注意的关键技术和参数设置,为实际应用提供了宝贵的理论支持和技术指导。 适合人群:从事新能源技术研发的专业人士、高校师生及相关领域的研究人员。 使用场景及目标:适用于光伏储能系统的研究与开发,旨在提高系统的能量利用效率和稳定性,特别是在面对复杂工况时的表现。通过仿真研究,可以优化系统设计,降低成本,提升性能。 其他说明:文中提供的代码片段和仿真模型仅供参考,在实际应用中需要结合具体情况进行调整和完善。同时,建议参考更多相关领域的权威文献,以确保研究成果的科学性和可靠性。

    基于FPGA与Verilog的多波形实时可调DDS信号发生器设计

    内容概要:本文详细介绍了利用FPGA和Verilog实现的一个能够实时切换六种波形并进行频率调节的DDS信号发生器的设计。文中首先阐述了波形切换机制,通过ROM查表法实现不同波形的数据存储与读取;接着讲解了按键交互设计,确保用户可以通过三个按键轻松地控制设备的功能;然后讨论了频率调节方法,采用相位累加器实现精确的频率控制;此外,还探讨了ASK和FSK调制的具体实现方式以及一些优化技巧如PWM替代DAC等。最终经过测试验证,该发生器可以在1kHz到10MHz范围内平稳运行,具有良好的性能表现。 适合人群:对FPGA开发有一定了解的技术爱好者、电子工程专业学生或者从事相关领域的工程师。 使用场景及目标:适用于需要生成多种标准波形并且可以灵活调整输出频率的应用场合,例如实验室环境下的教学演示、科研实验或是产品原型开发阶段。 其他说明:文中提供了大量具体的Verilog代码片段作为参考,帮助读者更好地理解和复现整个项目。同时提到了一些常见问题及其解决方案,有助于初学者避开潜在陷阱。

    ABAQUS有限元软件中刀盘切削竹材模型的构建与应用

    内容概要:本文详细介绍了使用 ABAQUS 有限元软件构建刀盘切削竹材模型的方法。首先,设定了刀具的工作参数,如转速和进给速度。接着,通过创建部件、定义材料属性、装配部件、设置分析步和划分网格等步骤完成了整个模型的建立。文中还强调了材料定义的关键性,特别是竹材作为复合材料层时使用的 Hashin 准则。此外,讨论了刀具运动的设置方法,包括旋转和平移动态的组合。对于接触设置部分,则探讨了摩擦系数和损伤耦合的影响。最后,提供了模型验证的一些技巧,确保仿真结果的有效性和准确性。 适合人群:从事机械工程、材料科学及相关领域的研究人员和技术人员,尤其是对有限元分析有一定基础的人群。 使用场景及目标:适用于需要研究刀具切削竹材过程的工程项目,旨在帮助工程师们更好地理解和优化切削工艺,提高生产效率和产品质量。 其他说明:文章不仅涵盖了理论知识,还包括了大量的代码片段和实践经验,有助于读者快速掌握相关技能并在实际工作中加以运用。

    光电探测器仿真:温度特性仿真.zip

    光电材料仿真,电子仿真等;从入门到精通教程;含代码案例解析。

    Python计算机课程设计项目:基于改进UNet和GAN的图像修复系统

    基于生成对抗网络(GAN)的图像修复算法,旨在通过利用深度学习技术修复图像中的缺陷和损坏区域。算法中包括两个主要组件:一个生成器(Generator)和一个判别器(Discriminator)。生成器使用的是无注意力机制的全卷积架构UNet,而判别器采用的是PatchGAN架构。预处理过程中,加载图像和掩码文件并调整大小,进行随机掩码应用,准备模型输入。生成器根据对抗损失、感知损失和结构一致性损失调整其参数,以改善生成图像的质量和真实性。判别器评估两类图像:真实的未损坏图像和生成器产生的修复图像。通过设计生成器和判别器,算法能够有效地处理和修复图像中的缺陷。

    基于PLC1200与Factory IO的虚拟工厂仿真设计及调试经验分享

    内容概要:本文详细介绍了利用西门子TIA Portal V15.1和Factory IO构建虚拟工厂仿真的全过程。首先讲述了环境搭建,包括选择合适的PLC型号(如S7-1200)、正确配置通信参数(如IP地址)以及启用必要的通信权限。接着深入探讨了Factory IO场景的创建,强调了合理的信号映射和物理属性设置对于仿真效果的影响。随后展示了PLC程序的设计思路,特别是状态机的应用和关键逻辑的实现方法。文中还记录了一些常见的调试问题及其解决方案,例如因变量映射错误导致的传送带异常加速现象。最后分享了作者在联机调试过程中积累的经验教训,如使用Ping命令检查网络连通性和调整定时器参数避免误触发等。 适合人群:从事工业自动化领域的工程师和技术爱好者,尤其是对PLC编程和虚拟仿真感兴趣的初学者。 使用场景及目标:帮助读者掌握如何使用TIA Portal和Factory IO进行虚拟工厂仿真系统的搭建与调试,提高编程技能并减少实际项目中的试错成本。 其他说明:文中提供了大量实用的技术细节和实战案例,有助于加深理解和应用。同时提醒读者注意一些容易忽视的小问题,如IP地址配置、变量映射等,这些都是确保系统稳定运行的关键因素。

    Comsol金属贴片建模与多极子展开分析:电磁学领域的透反射计算及应用

    内容概要:本文详细介绍了如何使用Comsol进行金属贴片建模及其多极子展开分析,特别关注于透反射计算。首先,文章讲解了金属贴片建模的具体步骤,包括选择合适的物理场、绘制几何图形、设定材料属性等。接着,探讨了多极子展开的基础理论及其在Comsol中的实现方式,解释了多极子如电偶极子和磁偶极子如何影响电磁波的散射行为。随后,讨论了透反射计算的方法,强调了边界条件和求解器设置的重要性,并展示了如何通过多极子分解来分析透反射系数的变化。最后,文章还分享了一些实用技巧,如参数化扫描、网格优化和多极子分解的实际操作方法。 适合人群:从事电磁学研究的专业人士、研究生及以上学历的研究人员、对电磁仿真感兴趣的工程师。 使用场景及目标:适用于科研项目中涉及金属贴片结构的设计与分析,帮助研究人员更好地理解和预测金属贴片在不同电磁环境下的表现,尤其是透反射特性和多极子效应的应用。 其他说明:文中提供了详细的建模步骤和代码片段,便于读者动手实践并加深理解。同时,针对可能出现的问题给出了具体的解决方案,确保仿真的准确性。

    郑予彬-生成式AI提升开发者效能.pdf

    郑予彬-生成式AI提升开发者效能.pdf

    基于MATLAB的三自由度车辆动力学模型与CKF算法的质心侧偏角估计及联合仿真

    内容概要:本文详细介绍了基于MATLAB的三自由度车辆动力学模型以及利用容积卡尔曼滤波(CKF)进行车辆质心侧偏角估计的方法。首先,文章解释了三自由度模型的基本原理,包括状态方程的构建和线性轮胎模型的应用。接着,深入探讨了CKF算法的具体实现,包括容积点生成、预测和更新步骤,并展示了其相对于扩展卡尔曼滤波(EKF)的优势。此外,文章还讨论了与CarSim软件的联合仿真过程中遇到的问题及解决方案,如时钟同步和参数调试技巧。最终,通过实验验证了CKF在车辆状态估计中的高效性和准确性。 适合人群:从事车辆动力学研究、自动驾驶技术研发的专业人士,尤其是有一定MATLAB编程基础的研究人员和技术人员。 使用场景及目标:适用于需要精确估计车辆状态(如质心侧偏角、横摆角速度等)的场合,旨在提高自动驾驶系统的感知能力和控制精度。目标是帮助研究人员更好地理解和应用CKF算法,优化车辆控制系统的设计。 其他说明:文中提供了详细的代码片段和调试经验分享,有助于读者快速上手并解决实际问题。同时,强调了在特定工况下(如低附着力路面)采用自适应CKF的重要性。

    轴承故障诊断中的一维CNN与MMD-Coral迁移学习方法及其应用

    内容概要:本文详细介绍了使用一维CNN结合MMD(最大均值差异)和Coral(协方差对齐)进行轴承故障诊断的迁移学习方法。主要内容涵盖数据预处理、网络模型设计、域适应技术以及训练技巧等方面。文中使用西储大学CWRU数据集进行实验,通过滑动窗口切片、归一化等手段处理振动信号,并构建了一维CNN模型,利用MMD和Coral实现源域和目标域的特征对齐。最终模型取得了99%的准确率,验证了方法的有效性。 适合人群:对机器学习特别是迁移学习感兴趣的初学者和技术爱好者。 使用场景及目标:适用于需要解决不同工况下轴承故障诊断问题的研究人员和工程师。主要目标是通过迁移学习提高模型在新环境下的泛化能力。 其他说明:文章不仅提供了详细的理论解释,还包括具体的代码实现和可视化工具的应用,如损失曲线图、准确率曲线图、混淆矩阵和t-SNE图等,有助于读者更好地理解和评估模型性能。此外,作者还分享了一些实用的经验和技巧,例如如何设置超参数、选择合适的学习率调度器等。

    电子信息工程巴特沃斯低通滤波器设计与仿真

    打包了西安电子科技大学B级测试低通滤波器设计,属于巴特沃斯低通滤波器,包含电路仿真、报告、matlab仿真,适合初学者以及西电学生作参考使用。

    光电探测器仿真:光电探测器基础理论.zip

    光电材料仿真,电子仿真等;从入门到精通教程;含代码案例解析。

    natsort-6.0.0-py2.py3-none-any.whl

    该资源为natsort-6.0.0-py2.py3-none-any.whl,欢迎下载使用哦!

    这篇文章详细介绍了基于积分时滞模型(Integral Delay Model, ID Model)的渠道水位预测控制算法的研究与实现,主要围绕模型预测控制(MPC)展开 论文复现或解答具体内容如下:

    内容概要:本文详细介绍了基于积分时滞模型(ID Model)的渠道水位预测控制算法,主要聚焦于模型预测控制(MPC)框架下的实现。文章首先概述了论文的核心内容,即通过MPC结合渠道仿真模型和简化预测模型来实现水位控制。接着,通过详细的代码实现展示了从环境准备、渠道参数设置、SWMM模型构建、简化预测模型、MPC控制器实现到最后的完整仿真流程。文中还深入解析了积分时滞模型的数学原理及其参数辨识方法,并通过状态空间模型构建和滚动优化策略,实现了多渠段渠道水位的精准控制。此外,文章还提供了完整的性能评估和可视化展示,确保算法的有效性和适应性。 适合人群:具备一定编程基础,尤其是熟悉Python编程语言的研发人员,以及从事水利、自动化控制领域研究的专业人士。 使用场景及目标:①帮助读者理解如何利用SWMM模型和MPC算法实现渠道水位控制;②掌握积分时滞模型的数学原理及其在预测控制中的应用;③学习如何通过Python代码实现从模型构建到性能评估的完整流程;④提供实际案例,便于研究人员和工程师在实际项目中应用和改进该算法。 其他说明:本文不仅提供了详细的代码实现和理论解析,还强调了实际应用中的关键技术和创新点。读者可以通过跟随代码逐步实践,深入理解MPC在渠道水位控制中的应用,并根据具体需求进行扩展和优化。

    espidf启动流程基于esp32c3

    espidf启动流程

    基于COMSOL与Matlab接口的三维随机裂隙网络模型构建及其应用

    内容概要:本文介绍了利用COMSOL与Matlab接口编程生成三维随机裂隙网络模型的方法和技术细节。首先阐述了裂隙网络模拟的重要性和传统方法的局限性,然后详细讲解了从二维到三维裂隙网络的数字化重构过程,强调了三维模型在捕捉地质结构复杂空间关系方面的优势。接着讨论了裂隙的随机性与多样性,通过Matlab中的随机数生成函数模拟裂隙的各种特性。随后介绍了多组裂隙的联合模拟以及模型的可扩展性和实用性,展示了该模型在地下水污染研究、油气资源开发和地质碳封存等多个领域的广泛应用前景。最后分享了一些实用技巧,如避免裂隙交叉、优化网格剖分等。 适合人群:从事地质学、水文学及相关领域研究的专业人士,尤其是那些希望深入了解并掌握三维裂隙网络建模技术的研究人员和工程师。 使用场景及目标:适用于需要精确模拟地下裂隙系统的研究项目,旨在帮助研究人员更好地理解和预测地下水流动、污染物迁移、油气开采效率等问题。同时,也为相关工程决策提供科学依据。 其他说明:文中提供的代码示例和操作指南有助于读者快速上手实践,附带的示范视频和详细的注释使学习更加便捷高效。此外,作者还提到了一些常见的坑点及解决方案,确保模型生成过程顺利进行。

    永磁同步电机无位置传感器控制中滑模观测器(SMO)的MATLAB仿真与优化

    内容概要:本文详细介绍了永磁同步电机(PMSM)无位置传感器控制中滑模观测器(SMO)的设计与仿真实现。首先阐述了系统的整体架构,包括速度环和电流环的工作机制。接着深入探讨了滑模观测器的关键实现步骤,如滑模增益选择、符号函数的应用以及低通滤波器的作用。文中还涉及了坐标变换(Clarke变换和Park变换)、PI参数整定、SVPWM调制等重要环节的具体实现方法和技术难点。此外,作者分享了多个调试过程中遇到的问题及解决方案,如波形抖振、电流采样延时、扇区判断错误等。最后展示了仿真结果,证明了所提方案的有效性和可行性。 适合人群:从事电机控制系统研究与开发的技术人员,尤其是对无位置传感器控制感兴趣的工程师。 使用场景及目标:适用于希望深入了解并掌握永磁同步电机无位置传感器控制技术的研究人员和工程师。目标是帮助读者理解滑模观测器的工作原理,掌握其设计与调试技巧,从而应用于实际项目中。 其他说明:文中提供了丰富的代码片段和实践经验,有助于读者更好地理解和应用理论知识。同时提醒读者注意离散化步长的选择和滑模增益的调整,这些都是确保系统稳定运行的重要因素。

    【汽车电子领域】ARXML文件详解:基于AUTOSAR标准的EEA架构描述与配置系统设计

    内容概要:本文详细介绍了ARXML文件在汽车电子架构中的作用及其分类。ARXML(AUTOSAR XML)是AUTOSAR标准中定义的一种基于XML的文件格式,主要用于描述整车电子电气架构中的软件组件、通信矩阵、ECU配置等信息,是AUTOSAR工具链中数据交换的核心载体。文章从标准化数据交换、分层建模支持、工具链集成三个方面阐述了ARXML文件的核心作用。接着,根据系统级、应用级、基础软件级三个层次分别介绍了ARXML文件的内容和用途。系统级ARXML文件描述了系统架构、网络拓扑、通信矩阵和SWC到ECU的映射;应用级ARXML文件定义了SWC的实现细节,包括接口、数据类型、内部行为等;基础软件级ARXML文件则描述了BSW模块的配置,确保其能与应用程序软件和硬件抽象层正确交互。 适合人群:汽车电子工程师、嵌入式软件开发者、AUTOSAR架构师等相关技术人员。 使用场景及目标:①帮助工程师理解ARXML文件在AUTOSAR架构中的重要性和具体应用;②指导工程师如何利用ARXML文件进行系统设计、软件开发和集成测试;③提高工程师对AUTOSAR标准的理解和掌握,提升项目开发效率和质量。 其他说明:ARXML文件如同一棵树状结构,从根部扩展到底端,每个元素都可以有子元素、文本内容和属性。合理的ARXML配置是AUTOSAR系统成功实现的基础,建议使用专业的配置工具如EB tresos、Vector DaVinci Configurator等来管理和生成ARXML文件。

    爬虫.md

    爬虫.md

Global site tag (gtag.js) - Google Analytics