`
adamed
  • 浏览: 183893 次
社区版块
存档分类
最新评论

Quartz Job Scheduling Framework第8章翻译初稿 续

阅读更多
 

You can have as many properties as you need to configure your plug-in.

你可以用多个属性配置插件。

Plug-In Properties Must Have set() Methods<o:p></o:p>

插件属性必须含有set()方法<o:p></o:p>

You must provide a setXXX() method for each property you intend to pass to the plug-in class. Quartz throws a SchedulerException and halts the Scheduler if it can't find a public setXXX() method for the property. Based on the JavaBean specification, you should provide both get() and set() methods for the properties.

<o:p> </o:p>

你必须为预传递插件类的每个属性提供setXXX()方法。如果Scheduler找不到属性publicsetXXX()方法Quartz会抛出SchedulerException并中断Scheduler。依据JavaBean规范,你必须提供每个属性的get()set()方法。

<o:p> </o:p>

The Quartz framework converts the property values to the type specified in the plug-in, assuming that it's a primitive type. For example, you can specify properties of type int and expect Quartz to convert the String from the quartz.properties file to an int. The framework, however, will not convert 1 to an integer class.

<o:p> </o:p>

Quartz会将属性值转换为插件中定义的类型,假定该类型是基本数据类型。例如你可以指定参数为intQuartz会将quartz.properties中的字符串转换为int值。然而框架不会将1转换为Integer类。

<o:p> </o:p>

Quartz Uses Introspection to Set Values<o:p></o:p>

Quartz使用反射机制赋值<o:p></o:p>

<o:p> </o:p>

Quartz uses introspection and reflection to convert the parameter values in the quartz.properties file to their correct type in the plug-in class. You might have guessed that it uses the Common BeanUtils from Jakarata, but this isn't the case yet.

Quartz使用自省(introspection译者注:Introspection就是类的getset方法,也就是类设定和获取自身属性值的方法。)和反射机制将quartz.properties内的信息转换为插件中需要的类型。你可能猜测框架使用了Jakarata的公共BeanUtils,但事实并非如此。



Creating the Job File for the JobLoaderPlugin<o:p></o:p>

创建JobLoaderPlugin使用的Job文件<o:p></o:p>

<o:p> </o:p>

The JobLoaderPlugin looks for all XML files in the specified directory and assumes that each file is a valid Quartz jobs file. By "valid," we mean that the XML file adheres to the latest job-scheduling XSD file, which at the time of this writing is job_scheduling_data_1_5.xsd.

<o:p> </o:p>

JobLoaderPlugin在指定的文件夹中查找所有的XML文件并假定这些文件都是合法的Quartz job定义文件。所谓“合法”值XML遵循最新的作业调度XSD文件。在本书编写时最新的版本是job_scheduling_data_1_5.xsd

<o:p> </o:p>

To make the JobLoaderPlugin more useful, we put each job, along with its job detail and trigger information, in a single XML file. This enables us to add and remove complete jobs just by putting the file into the directory or taking it out. This is very helpful in a development environment when you want to test only certain jobs. A single job XML file is shown in Listing 8.4.

<o:p> </o:p>

为了让JobLoaderPlugin更加有用,我们将每个job与它的job detail、触发器信息单独作为一个XML文件。这使得我们添加移除整个job时候只需要将文件添加或移出文件夹。在开发环境中如果我们需要测试某个单独的job的时候这是非常有帮助的。一个单独的job XML文件如列表8.4

<o:p> </o:p>

Listing 8.4. A Job XML File Read by the JobLoaderPlugin<o:p></o:p>

列表8.4 JobLoaderPlugin读取的一个Job XML文件

xml 代码
  1. <?xml version='1.0' encoding='utf-8'?>  
  2.   
  3.   
  4. <quartz xmlns="http://www.opensymphony.com/quartz/JobSchedulingData"  
  5.  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  6.  xsi:schemaLocation="http://www.opensymphony.com/quartz/JobSchedulingData   
  7.  http://www.opensymphony.com/quartz/xml/job_scheduling_data_1_5.xsd"   
  8.  version="1.5">  
  9.   
  10.  <job>  
  11.    <job-detail>  
  12.      <name>PrintInfoJob1</name>  
  13.      <group>DEFAULT</group>  
  14.      <job-class>  
  15.        org.cavaness.quartzbook.chapter3.ScanDirectoryJob   
  16.      </job-class>  
  17.      <volatility>false</volatility>  
  18.      <durability>false</durability>  
  19.      <recover>false</recover>  
  20.   
  21.      <job-data-map allows-transient-data="true">  
  22.        <entry>  
  23.          <key>SCAN_DIR</key>  
  24.          <value>c:\quartz-book\input1</value>  
  25.        </entry>  
  26.      </job-data-map>  
  27.    </job-detail>  
  28.   
  29.    <trigger>  
  30.      <simple>  
  31.        <name>trigger1</name>  
  32.        <group>DEFAULT</group>  
  33.        <job-name>PrintInfoJob1</job-name>  
  34.        <job-group>DEFAULT</job-group>  
  35.        <start-time>2005-07-30T16:04:00</start-time>  
  36.   
  37.        <!-- repeat indefinitely every 10 seconds -->  
  38.        <repeat-count>-1</repeat-count>  
  39.        <repeat-interval>10000</repeat-interval>  
  40.      </simple>  
  41.    </trigger>  
  42.  </job>  
  43.   
  44.   
  45. </quartz>  
  46.   

 

The job file is Listing 8.4 contains all the information necessary for the JobLoaderPlugin to schedule the job. This file also contains an entry for the JobDataMap, which is available to the job class at runtime. The example in Listing 8.4 uses a configured SimpleTrigger to schedule an infinitely repeating trigger that fires every 10 seconds. To further test the plug-in, we created a second job file, which differs from the first in some small way. Listing 8.5 shows the second job file.

<o:p> </o:p>

列表8.4显示的job文件包含所有的供JobLoaderPlugin调度job所需要的信息。这个文件还包含一个可以在类中实时供JobDataMap调用的实体。列表8.4战士的例子使用SimpleTrigger。它频率是没10秒一次,无限循环。为了更进一步测试插件,我们创建第2job文件,与第一个相比有一些小不同。列表8.5显示了第2job文件。

<o:p> </o:p>

Listing 8.5. A Second Job XML File Loaded by the JobLoaderPlugin<o:p></o:p>

列表8.5 JobLoaderPlugin加载的第2个job XML文件<o:p></o:p>

xml 代码
  1. <?xml version='1.0' encoding='utf-8'?>  
  2.   
  3. <quartz xmlns="http://www.opensymphony.com/quartz/JobSchedulingData"  
  4.  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.  xsi:schemaLocation="http://www.opensymphony.com/quartz/JobSchedulingData   
  6.  http://www.opensymphony.com/quartz/xml/job_scheduling_data_1_5.xsd"   
  7.  version="1.5">  
  8.   
  9.  <job>  
  10.    <job-detail>  
  11.      <name>PrintInfoJob2</name>  
  12.      <group>DEFAULT</group>  
  13.      <job-class>  
  14.        org.cavaness.quartzbook.chapter3.ScanDirectoryJob</job-class>  
  15.      <volatility>false</volatility>  
  16.      <durability>false</durability>  
  17.      <recover>false</recover>  
  18.   
  19.      <job-data-map allows-transient-data="true">  
  20.         <entry>  
  21.          <key>SCAN_DIR</key>  
  22.           <value>c:\quartz-book\input2</value>  
  23.         </entry>  
  24.      </job-data-map>  
  25.   
  26.    </job-detail>  
  27.   
  28.     <trigger>  
  29.      <simple>  
  30.        <name>trigger2</name>  
  31.        <group>DEFAULT</group>  
  32.        <job-name>PrintInfoJob2</job-name>  
  33.        <job-group>DEFAULT</job-group>  
  34.        <start-time>2005-07-30T16:04:00</start-time>  
  35.        <!-- repeat indefinitely every 10 seconds -->  
  36.        <repeat-count>-1</repeat-count>  
  37.        <repeat-interval>60000</repeat-interval>  
  38.      </simple>  
  39.    </trigger>  
  40.  </job>  
  41.   
  42. </quartz>  
  43.   

 

The second job file in Listing 8.5 differs only slightly from the one in Listing 8.4. We've changed the directory for the job, which is scanned and changed the trigger schedule. The point here is that you can have multiple jobs in the jobs directory, and the JobLoaderPlugin will load them all and schedule them individually with the Scheduler.

<o:p> </o:p>

列表8.5显示的第2job文件与8.4显示的第一个相比只有一点不同。我们改变了搜索改变触发调度作业的文件夹。有一点注意的是你可以放多个job文件到文件夹中,JobLoaderPlugin将分别加载并用Scheduler调度他们。(老外就是这样说了好几遍还罗嗦^_^

<o:p> </o:p>

<v:shapetype id="_x0000_t75" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75" coordsize="21600,21600"><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></v:path><o:lock aspectratio="t" v:ext="edit"></o:lock></v:shapetype><v:shape id="_x0000_i1025" style="WIDTH: 0.75pt; HEIGHT: 0.75pt" o:button="t" alt="" type="#_x0000_t75"></v:shape>

Using Multiple Plug-Ins<o:p></o:p>

使用多个插件<o:p></o:p>

You can register as many plug-ins in the quartz.properties file as you like. However, the order of loading and initialization can't be guaranteed because Quartz loads all the properties into a map and then loops through the plug-ins in the order that they are retrieved from the map.

<o:p> </o:p>

你可以在quartz.properties文件中注册任意多个插件。然而加载初始化的顺序不能保证,因为Quartz加载所有的属性到Map中然后按map的中的顺序查找插件。

<o:p> </o:p>

To get around this limitation, you can create a Quartz plug-in that acts as a parent plug-in and loads multiple other plug-ins in a given order. Listing 8.6 shows what the ParentPlugin looks like.

<o:p> </o:p>

为绕开这一限制,你可以建立一个Quartz插件做为其他插件的父插件。该插件按指定顺序加载其他插件。列表8.6展示了父插件的样子。

<o:p> </o:p>

Listing 8.6. The ParentPlugin Can Load Child Plug-Ins in a Specified Order<o:p></o:p>

列表8.6 父插件可以按指定顺序加载子插件<o:p></o:p>

java 代码
  1. package org.cavaness.quartzbook.chapter8;   
  2.   
  3. import java.util.ArrayList;   
  4. import java.util.List;   
  5. import java.util.StringTokenizer;   
  6.   
  7. import org.apache.commons.logging.Log;   
  8. import org.apache.commons.logging.LogFactory;   
  9. import org.quartz.Scheduler;   
  10. import org.quartz.SchedulerConfigException;   
  11. import org.quartz.SchedulerException;   
  12. import org.quartz.spi.SchedulerPlugin;   
  13.   
  14. public class ParentPlugin implements SchedulerPlugin {   
  15.     private static Log logger = LogFactory.getLog(ParentPlugin.class);   
  16.   
  17. // A list of child plug-ins   
  18. //子插件列表   
  19.     private List childPlugins = new ArrayList();   
  20.   
  21.     private String childPluginNames;   
  22.   
  23.     private String pluginName;   
  24.   
  25.     private Scheduler scheduler;   
  26.   
  27.     /**  
  28.      * Default no-arg Constructor  
  29.      *  
  30.      */  
  31.     public ParentPlugin() {   
  32.     }   
  33.   
  34.     /**  
  35.      * Pass the initialize call on to the child plug-ins.  
  36.      *  
  37.      * @throws SchedulerConfigException  
  38.      *             if there is an error initializing.  
  39.      */  
  40.   
  41. public void initialize(String name, final Scheduler scheduler)   
  42.               throws SchedulerException {   
  43.   
  44.          this.pluginName = name;   
  45.          this.scheduler = scheduler;   
  46.   
  47.          logger.info("Searching for child plugins to load");   
  48.   
  49.          // The child plug-ins are comma-separated   
  50.          StringTokenizer tokenizer =   
  51.               new StringTokenizer(childPluginNames, ",");   
  52.   
  53.          while (tokenizer.hasMoreElements()) {   
  54.               String pluginClassname = tokenizer.nextToken();   
  55.   
  56.               try {   
  57.                    Class pluginClass =   
  58.                         Class.forName(pluginClassname);   
  59.   
  60.                    Object obj = pluginClass.newInstance();   
  61.   
  62.                    // Make sure the specified class is a plug-in   
  63.                    if (obj instanceof SchedulerPlugin) {   
  64.                         // Initialize the Plugin   
  65.                         SchedulerPlugin childPlugin =   
  66.                               (SchedulerPlugin) obj;   
  67.   
  68.                              logger.info("Init child Plugin " +   
  69.                                   pluginClassname);   
  70.   
  71.                         childPlugin.initialize(pluginClassname,   
  72.                              scheduler);   
  73.   
  74.                         // Store the child plug-in in the list   
  75.                         childPlugins.add(childPlugin);   
  76.                    } else {   
  77.                         // Skip loading class   
  78.                         logger.error("Class is not a plugin " +   
  79.                              pluginClass);   
  80.                    }   
  81.   
  82.               } catch (Exception ex) {   
  83.                    // On error, log and go to next child plug-in   
  84.                    logger.error("Error loading plugin " +   
  85.                         pluginClassname, ex);   
  86.               }   
  87.          }   
  88.     }   
  89.     public void start() {   
  90.          // Start each child plug-in   
  91.          int size = childPlugins.size();   
  92.          for (int i = 0; i < size; i++) {   
  93.               SchedulerPlugin childPlugin =   
  94.                    ((SchedulerPlugin) childPlugins.get(i));   
  95.   
  96.               logger.info("Starting Child Plugin " + childPlugin);   
  97.               childPlugin.start();   
  98.          }   
  99.     }   
  100.   
  101.     public void shutdown() {   
  102.          // Stop each child plug-in   
  103.          int size = childPlugins.size();   
  104.          for (int i = 0; i < size; i++) {   
  105.               SchedulerPlugin childPlugin =   
  106.                    ((SchedulerPlugin) childPlugins.get(i));   
  107.   
  108.               logger.info("Stopping Plugin " + childPlugin);   
  109.               childPlugin.shutdown();   
  110.          }   
  111.     }   
  112.   
  113.     public String getPluginName() {   
  114.          return pluginName;   
  115.     }   
  116.   
  117.     public void setPluginName(String pluginName) {   
  118.          this.pluginName = pluginName;   
  119.     }   
  120.   
  121.     public String getChildPluginNames() {   
  122.          return childPluginNames;   
  123.     }   
  124.   
  125.     public void setChildPluginNames(String childPluginNames) {   
  126.          this.childPluginNames = childPluginNames;   
  127.     }   
  128. }   
  129.  &nbs
评论

相关推荐

    Quartz Job Scheduling Framework第11章翻译初稿

    Quartz Job Scheduling Framework是一个强大的、开放源代码的作业调度框架,它使应用程序能够在指定的时间执行任务,无需人工干预。这个框架广泛应用于Java应用程序中,用于实现定时任务和工作流管理。在第11章中,...

    Quartz Job Scheduling Framework第5章翻译初稿

    在阅读《Quartz Job Scheduling Framework》第5章时,你会了解到如何创建和配置Cron Triggers,如何结合SimpleTrigger和CalendarIntervalTrigger实现不同类型的定时任务,以及如何优化Quartz的配置以适应大规模的...

    Quartz Job Scheduling Framework第2章翻译初稿

    Quartz Job Scheduling Framework第2章翻译初稿 博文链接:https://adamed.iteye.com/blog/135880

    Quartz Job Scheduling Framework第7章翻译初稿

    Quartz Job Scheduling Framework是一个强大的、开源的作业调度框架,用于在Java应用程序中安排任务执行。这个框架允许开发者创建和管理作业,以及定义作业的触发时间。第7章的主题聚焦于实现Quartz监听器,这是一个...

    基于COMSOL的电磁场与光学仿真:多极分解通用模型探讨石墨烯临界耦合光吸收与费米能级可调性,COMSOL 多极分解,分方向多级展开通用模型,电磁场,面上箭头,透射率光学 BIC 仿真 COMSOL

    基于COMSOL的电磁场与光学仿真:多极分解通用模型探讨石墨烯临界耦合光吸收与费米能级可调性,COMSOL 多极分解,分方向多级展开通用模型,电磁场,面上箭头,透射率光学 BIC 仿真。 COMSOL 准 BIC控制石墨烯临界耦合光吸收。 COMSOL 光学仿真,石墨烯,光吸收,费米能级可调 ,关键词:COMSOL; 多极分解; 分方向多级展开通用模型; 电磁场; 面上箭头; 透射率; BIC 仿真; 准 BIC; 控制石墨烯; 临界耦合光吸收; 光学仿真; 石墨烯; 光吸收; 费米能级可调。,COMSOL多极分解法仿真石墨烯光吸收特性及费米能级调控

    Matlab Simulink下的单相光伏储能模型:可再生能源发电与蓄电池储能系统建模与仿真,涵盖MPPT电导增量法及并网技术,Matlab simulink模型,单相光伏储能模型可再生能源发电 太阳

    Matlab Simulink下的单相光伏储能模型:可再生能源发电与蓄电池储能系统建模与仿真,涵盖MPPT电导增量法及并网技术,Matlab simulink模型,单相光伏储能模型可再生能源发电 太阳能发电蓄电池储能建模与仿真 可调节光照强度,采用MPPT电导增量法最大功率点跟踪双向DC DC蓄电池储能及补偿。 额定功率2500w,并网等级311v有效值220v ,Matlab Simulink模型; 单相光伏储能模型; 可再生能源发电; 太阳能发电; 蓄电池储能建模与仿真; 调节光照强度; MPPT电导增量法; 最大功率点跟踪; 双向DC DC; 额定功率2500w; 并网等级311v; 有效值220v,基于Matlab Simulink的单相光伏储能模型:MPPT跟踪与蓄电池储能补偿研究

    基于springboot的音乐网站与分享平台lw+ppt

    包含项目论文和毕业答辩PPT,详情请看博客:https://blog.csdn.net/2401_87429224/article/details/145231201 论文主要包括以下内容: 1、中英文摘要; 2、目录; 3、绪论,包括背景、意义、开发工具、国内外现状等; 4、系统分析,包括可行性分析、设计原则、需求分析、业务流程分析等; 5、系统设计,包括功能设计、数据库设计等; 6、系统实现,包括各模块实现; 7、软件测试,包括测试环境、测试条件、运行情况等。

    "图腾柱PFC电路仿真研究:电压电流双闭环PI控制下的动态响应与稳定性验证及主电路设计说明",图腾柱(totem pole)PFC电路仿真,采用电压电流双闭环PI控制 输出特性好 仿真中模拟了给定

    "图腾柱PFC电路仿真研究:电压电流双闭环PI控制下的动态响应与稳定性验证及主电路设计说明",图腾柱(totem pole)PFC电路仿真,采用电压电流双闭环PI控制。 输出特性好。 仿真中模拟了给定电压变化时的动态响应情况。 可验证闭环控制的稳定性。 另也有图腾柱PFC主电路参数的设计说明 matlab simulink plecs等环境 ,totem_pole; PFC电路仿真; 电压电流双闭环PI控制; 动态响应; 闭环控制稳定性; 主电路参数设计; Matlab Simulink; PLECS。,"图腾柱PFC电路仿真与参数设计研究,电压电流双闭环PI控制稳定性的验证"

    2025年材料员网络培训考试题库及答案.docx

    2025年材料员网络培训考试题库及答案.docx

    **Qt CPP多列时间轴控件:事件线发展故事大纲的可视化编辑器**,Qt CPP实现的多列时间轴控件、可与多段字符串格式自由转、也可手动添加列表项、专门用来以时间轴作为事件线发展顺序的故事大纲 时

    **Qt CPP多列时间轴控件:事件线发展故事大纲的可视化编辑器**,Qt CPP实现的多列时间轴控件、可与多段字符串格式自由转、也可手动添加列表项、专门用来以时间轴作为事件线发展顺序的故事大纲。 时间可输入任意内容,不限于时间,每一时间段允许多列,即多个文字节点,行与行、列与列 之间任意拖拽更顺序,可与文字自由转,按需修改快捷键,所有的编辑可撤销,美观的调整动画。 源码: 使用Qt5.13.1_MinGW编译通过。 ,Qt CPP时间轴控件; 多列时间节点; 自由转换字符串格式; 手动添加列表项; 时间轴事件线; 拖拽更换顺序; 快捷键自定义; 编辑可撤销; 动画调整。,基于Qt C++的多功能多列时间轴故事线管理控件

    红外解码 红外遥控,个人学习整理,仅供参考

    ===下载后有不懂的可以私信我。==== 红外解码与红外遥控是电子工程领域中常见的一种技术,主要应用于家用电器、智能家居设备以及遥控玩具等。本文将深入探讨这两个概念,并结合"28.红外遥控解码数码管显示实验"这一主题,为你提供丰富的学习内容。 我们要理解红外(Infrared,简称IR)的基本原理。红外是一种电磁波,频率范围在300GHz到400THz之间,位于可见光的红色光谱之外。在遥控系统中,红外通信通常采用的是近红外频段,即约940nm左右的波长。它具有传输距离近、功耗低、抗干扰能力较弱的特点,适用于室内短距离通信。 红外遥控系统由两部分组成:发射器(遥控器)和接收器(解码器)。发射器通常包含一个微控制器和红外LED,用于编码并发射控制信号。这些信号是通过特定的编码方式,如RC5、NEC、SIRC等编码协议发送的,以确保数据的准确性和唯一性。接收器则含有一个红外光电传感器,用于捕捉这些信号并进行解码。 红外解码是接收器的核心功能。当接收到红外信号后,解码器会对其进行解调,然后解析出编码的指令。解码过程包括信号放大、滤波、峰值检测和脉冲计数等步骤。不同的编码协议有不同的解码方法,例如NEC协议的解码需要识别前导码、地址码、命令码和校验码等组成部分。 数码管显示在红外遥控实验中扮演了重要角色。数码管,也称为数字管或七段显示器,可以用来显示数字、字母和一些特殊字符。在红外遥控解码实验中,一旦解码成功,通常会通过数码管将接收到的指令代码或状态信息呈现出来,便于观察和调试。 "28.红外遥控解码数码管显示实验"可能是一个实践项目,旨在帮助学习者亲手搭建一个简单的红外遥控系统。这个实验可能涵盖了以下内容: 1. 硬件搭建:包括红外接收模块、微控制器(如Arduino或AVR)、数码管及其驱动电路。 2. 软件编程:编写微控制器的程序来实现红外信号的接收、解码以及数码管的显示控制。这涉及到对红外解码协议的理解和编程实现。 3. 实验操作:调整遥控器,发送不同指令,观察数码管的反馈,验证解码的正确性。 通过这样的实验,你可以亲身体验红外遥控系统的完整流程,加深对红外解码原理和实践应用的理解。同时,这也是提升动手能力和解决问题能力的良好机会。 红外解码和红外遥控是电子工程师必备的技能之一。掌握这些知识不仅可以让你理解和设计自己的遥控系统,还为进入更高级的嵌入式系统开发打下基础。希望这个资源能对你在红外学习的道路上有所帮助,祝你在探索科技的旅程中不断进步。。内容来源于网络分享,如有侵权请联系我删除。

    Java毕业设计-springboot-vue-图书个性化推荐系统(源码+sql脚本+29页零基础部署图文详解+38页论文+15页答辩+环境工具+教程+视频+模板).zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档切片混合解析和叠加展示风格,请放心使用。 2:29页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解),旨在为更多的人甚至零基础的人也能运行、使用和学习。 3:配套毕业论文,万字长文,word文档,支持二次编辑。 4:配套答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关电子教程、视频教学资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在 IDEA 中开发。服务端用 Java 并借 Spring Boot 框架搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 使用Spring Boot搭建后台。VUE 框架构建前端交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

    【Unity动画烘焙插件】GPU ECS Animation Baker

    【Unity动画烘焙插件】GPU ECS Animation Baker

    MATLAB轴承动力学模拟:滚动轴承故障建模与ODE45数值计算(含正常、外圈故障、内圈故障及滚动体故障分析),MATLAB轴承动力学代码(正常、外圈故障、内圈故障、滚动体故障),根据滚动轴承故障机理

    MATLAB轴承动力学模拟:滚动轴承故障建模与ODE45数值计算(含正常、外圈故障、内圈故障及滚动体故障分析),MATLAB轴承动力学代码(正常、外圈故障、内圈故障、滚动体故障),根据滚动轴承故障机理建模(含数学方程建立和公式推导)并在MATLAB中采用ODE45进行数值计算。 可模拟不同轴承故障类型,输出时域加速度波形、滚道接触力、相图。 ,核心关键词:MATLAB; 轴承动力学代码; 故障机理建模; 数学方程建立; 公式推导; ODE45数值计算; 不同轴承故障类型; 时域加速度波形; 滚道接触力; 相图。,MATLAB滚动轴承故障动力学模型及数值模拟分析系统

    智能控制第5版仿真程序(MATLAB)

    原作者:刘金琨教授

    2024最强Java面试八股文-最新面试题

    《2024最强Java面试八股文》是一份针对Java面试的全面指南,内容涵盖JVM、MQ、MyBatis、MySQL、Redis、Spring Boot、Spring Cloud以及设计模式等多个方面。这份资料旨在帮助求职者系统地复习和掌握Java及相关技术的核心知识点,从而在面试中取得更好的成绩。 该资源不仅适用于校招,也适用于社招。无论您是一名即将毕业的学生还是已经有一定工作经验的开发者,都可以通过这份资料深入了解Java面试的常见考点和难点,提升自己的技能和知识储备。 在内容上,这份资料对每个技术点都进行了深入浅出的讲解,并配有大量的实例和案例分析。此外,还提供了丰富的题目和答案,帮助您更好地掌握每个知识点的运用。 总的来说,《2024最强Java面试八股文》是一份不可多得的Java面试宝典,它系统地梳理了Java面试的核心知识点,并提供了一系列的实战技巧和经验。无论您是正在准备面试的求职者,还是希望深入了解Java技术的开发者,都可以从这份资料中受益匪浅。

    计算机视觉领域中基于CLIP模型的语言驱动双像素图像散焦去模糊网络

    内容概要:本文提出了一个名为LDP(Language-driven DP)的新框架,旨在利用预训练的对比语言-图像模型CLIP来估计双像素(DP)图像对的模糊图,从而实现高质量的无监督去模糊任务。研究解决了以往需要额外数据进行监督的问题,首次通过文本提示引导CLIP来估计模糊程度并应用自定义格式处理立体图像对,进一步提出了三种损失函数和一个先验注意力模块以确保恢复图像的质量。该方法通过广泛的实验验证,在标准测试集上取得了当前最优性能。 适合人群:计算机视觉研究人员以及从事深度学习和图像处理的技术人员。 使用场景及目标:用于从具有视差相关模糊问题的双像素传感器获取到的图片对恢复清晰的全焦点图片,尤其适用于单张拍摄情况下的图像修复工作。此外,该研究可以推动更多利用大规模预训练视觉语言模型应用于低级视觉任务的可能性。 其他说明:文中还提供了详细的实证比较和其他现有方法的优势分析,证明了所提出的架构能够提高去模糊效果的同时显著降低了推理时间。同时给出了模型的不同组件及其损失设置的消融实验细节与模型局限性的探讨,补充材料中有更深入的具体实验参数介绍及更多的定性和定量评估。

    【预定SCI2区】基于matlab被囊群算法TSA-BiTCN-BiGRU-Attention风电预测【含Matlab源码 11048期】.zip

    CSDN海神之光上传的全部代码均可运行,亲测可用,直接替换数据即可,适合小白; 1、代码压缩包内容 主函数:Main .m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开除Main.m的其他m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作

    Simulink光伏储能VSG仿真模型:完美波形运行,实现光储一次调频、削峰填谷及直流母线电压控制功能,simulink仿真模型光伏储能VSG,加电容,正常运行,波形完美一一光储一次调频、储能削峰填谷

    Simulink光伏储能VSG仿真模型:完美波形运行,实现光储一次调频、削峰填谷及直流母线电压控制功能,simulink仿真模型光伏储能VSG,加电容,正常运行,波形完美一一光储一次调频、储能削峰填谷、 直流母线电压控制。 2018b及以上都可运行哈 ,simulink仿真;光伏储能;VSG;加电容;正常运行;波形完美;光储一次调频;储能削峰填谷;直流母线电压控制;2018b及以上版本。,Simulink光伏储能VSG模型:电容增强与优化调频调压功能解析

    三相VIENNA整流器仿真研究:T型整流器双闭环PI控制及中点电位平衡控制策略,SPWM调制与高效能表现,三相VIENNA整流器仿真 matlab仿真 T型vienna整流器仿真 双闭环PI控制,中点

    三相VIENNA整流器仿真研究:T型整流器双闭环PI控制及中点电位平衡控制策略,SPWM调制与高效能表现,三相VIENNA整流器仿真 matlab仿真 T型vienna整流器仿真 双闭环PI控制,中点电位平衡控制,SPWM调制,三相锁相环。 图3为三相电流波形,图4THD为1.01%,电感仅为2mL。 图4直流侧电压波形,能准确跟踪给定值750V,图5为直流母线侧上下电容电压,中点电位波动极小。 功率因数为99%以上。 ,三相VIENNA整流器仿真; Matlab仿真; T型vienna整流器仿真; 双闭环PI控制; 中点电位平衡控制; SPWM调制; 三相锁相环; 电流波形; THD; 电感; 直流侧电压波形; 直流母线侧电容电压; 功率因数。,三相Vienna整流器:仿真、控制与性能优化分析

Global site tag (gtag.js) - Google Analytics