- 浏览: 326799 次
- 性别:
- 来自: 北京
-
文章分类
- 全部博客 (254)
- java (178)
- tomcat (6)
- 邮件 (1)
- smtp (1)
- Linux (2)
- 编码 (2)
- 导入工程 (1)
- Specification Level (1)
- hibernate (10)
- 字段类型 (1)
- 字段类型匹配 (1)
- 数据库 (3)
- sql (9)
- struts2 (8)
- 类型转换 (2)
- java,MyEclipse,SVN (1)
- Myecplise (4)
- 输入校验 (1)
- JFrame (2)
- Oracle (8)
- google (1)
- Swing (3)
- Fusioncharts (1)
- 找工作 (0)
- js (4)
- jsp (11)
- displaytag (1)
- spring (8)
- 工作 (1)
- String (1)
- 算法 (2)
- IO (1)
- xml (3)
- 设计模式 (1)
- UML (1)
- 文档 (1)
- ajax (1)
- 日常 (7)
- sql server (1)
- mysql (3)
- git (1)
- Maven (1)
- mongodb (1)
- postman (1)
最新评论
这篇文章是在前面的“AWT事件总结”博客文章的基础上总结的,其实前面的讲到AWT事件就是一个典型的观察者模式使用场景(一个典型的应用示例),这样顺序的讲解目的是为了让我们能用AWT事件来深刻的理解观察者模式。
下面讲解观察者模式:
那么在上面事件的调用过程中,为什么监听器比如ActionListener实现类里面特定事件的方法会在事件发生的时候被调用呢?这里用到了一种模式,观察者模式。
观察者模式(Observer):
观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个猪蹄对象。这个主题对象在状态上发生变化时,会通知所有观察者对象,让他们能够自动更新自己。
观察者模式的组成:
1、抽象主题角色:把所有对观察者对象的引用保存在一个集合中,每个抽象主题角色都可以有任意数量的观察者。抽象主题提供一个接口,可以增加和扇车观察者角色。一般用一个抽象类或接口来实现。
2、抽象观察者角色:为所有具体的观察者定义一个接口,在得到主题的通知时更新自己。
3、具体主题角色:在具体主题内部状态改变时,给所有登记过的观察者发出通知。具体主题角色通常用一个子类实现。
4、具体观察者角色:该角色实现抽象观察者角色所要求的更新接口,以便使本身的状态与主题的状态相协调。如果需要,具体观察者角色可以保存一个指向具体主题角色的引用。通常用一个子类实现。
所谓的注册就是将一个观察者的对象应用存放到了主题里面去了么(一般是集合)。我们的方法最后肯定是主题来执行的呀,一定不是平白无故的自己就去执行了呀。永远没有自动调用这一回事,自动调用只是一种表面现象,是你还没有明白底层是怎么实现的。
下面的几个类是一个简单的典型的观察者模式程序:
观察者模式在Java语言中的地位极其重要。
JDK都认为观察者模式非常重要,所以它也内置了观察者模式的支持,而其他模式不会有这样的待遇。JDK为观察者模式提供了一种支持,为其提供了类提供了接口来支持它。
Observable类用于创建可以观测到你的程序中其他部分的子类【它是一个主题角色,它是一对多里面一的那一方,是有多个人去观测它】。当这种子类的对象发生变化时,观测类被通知。观测类必须实现定义了update()方法的Observer接口。当一个观测程序被通知到一个被观测对象的改变时,update()方法被调用。
Observable是我们的主题角色(我们继承这个类来创建我们自己的主题对象)。Observer是抽象的观察者,我们实现它来定义自己的具体观察者。
一定要重点查看Observable类的源码,一定要重点查看。仔细查看完之后Observable类的源码和我们最初自己实现的那个简单的观察者模式里面的ConcreteWatched 类代码特别相似,只是多了一个主题是否改变的Boolean变量和对它操纵的几个方法以及机制而已。
Observable(观测):
注意notifyObservers()有两种形式:一种带有参数而另一种没有。当用参数调用notifyObservers()方法时,该对象被传给观测程序的update()方法作为其第二个参数。否则,将给update()方法传递一个null。可以使用第二个参数传递适合于你的应用程序的任何类型的对象。
为了观测一个可观测的对象,必须实现Observer接口。这个接口仅仅定义了如下所示的一个方法:
---void update(Observable observOb,Object arg)
---这里,observOb是被观测的对象,而arg是由notifyObservers(Object arg)方法传递的值。当被观测对象发生了改变,调用update()方法。
这里是一个说明可观测对象的例子。该程序创建了一个叫Watcher的类,该类实现了Observer接口。被监控的类叫做Being Watched,它继承了Observable。在Being Watched里,是counter()方法,该方法仅是从一个指定的值开始递减计数。每次计数改变时,notifyObservers()方法被调用,而当前的计数被作为参数传递给notifyObservers()方法。这导致了Watcher中的update()方法被调用,显示当前的计数值。在main()内,分别调用observing和observed的Watcher和Being Watched对象被创建。然后,observing被增加到对observed的观测程序列表。这意味着每次counter()调用notifyObservers()方法时,observing.update()方法将被调用。
一个被观测的对象必须服从下面两个简单规则。第一,如果它被改变了,它必须调用setChanged()方法。第二,当它准备通知观测程序它的改变时,它必须调用notifyObservers()方法。这导致了在观测对象中对update()方法的调用。注意---当对象在调用notifyObservers()方法之前,没有调用setChanged()方法,就不会有什么动作发生。在update()被调用之前,被观测对象必须调用setChanged()和notifyObservers()两种方法。
下面是针对观察者模式留的一个作业:
作业:
1)阅读Observable类的源代码,理解Observable类与Observer接口之间的调用关系。
2)编写一个程序,声明一个类,该类继承自Observable(因此该类是个主题角色),有一个int 类型的变量,初始值为10,编写一个for 循环,将该数字每次递减1,一直到0为止,每次变化时,都将该数字传递给它的观察者,观察者会打印出该数字;第二个观察者在该数字变为5之后开始打印该数字。
下面两个类是自己的作业完成情况(没有经过修改):
下面的代码是老师最后最后针对作业完成的标准代码,他只用了一个类:
下面讲解观察者模式:
那么在上面事件的调用过程中,为什么监听器比如ActionListener实现类里面特定事件的方法会在事件发生的时候被调用呢?这里用到了一种模式,观察者模式。
观察者模式(Observer):
观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个猪蹄对象。这个主题对象在状态上发生变化时,会通知所有观察者对象,让他们能够自动更新自己。
观察者模式的组成:
1、抽象主题角色:把所有对观察者对象的引用保存在一个集合中,每个抽象主题角色都可以有任意数量的观察者。抽象主题提供一个接口,可以增加和扇车观察者角色。一般用一个抽象类或接口来实现。
2、抽象观察者角色:为所有具体的观察者定义一个接口,在得到主题的通知时更新自己。
3、具体主题角色:在具体主题内部状态改变时,给所有登记过的观察者发出通知。具体主题角色通常用一个子类实现。
4、具体观察者角色:该角色实现抽象观察者角色所要求的更新接口,以便使本身的状态与主题的状态相协调。如果需要,具体观察者角色可以保存一个指向具体主题角色的引用。通常用一个子类实现。
所谓的注册就是将一个观察者的对象应用存放到了主题里面去了么(一般是集合)。我们的方法最后肯定是主题来执行的呀,一定不是平白无故的自己就去执行了呀。永远没有自动调用这一回事,自动调用只是一种表面现象,是你还没有明白底层是怎么实现的。
下面的几个类是一个简单的典型的观察者模式程序:
package com.shengshiyuan.observer; /** * 抽象观察者角色 * 类: Watcher <br> * 描述: TODO <br> * 作者: * 时间: Nov 5, 2013 5:36:14 PM */ public interface Watcher { // 在得到主题的通知时更新自己 public void udpate(String str); }
package com.shengshiyuan.observer; /** * 抽象主题角色 * 类: Watched <br> * 描述: TODO <br> * 作者: * 时间: Nov 5, 2013 5:34:56 PM */ public interface Watched { // 添加观察者 public void addWatcher(Watcher watcher); // 移除观察者 public void removeWatcher(Watcher watcher); // 通知观察者 public void notifyWatchers(String str); }
package com.shengshiyuan.observer; /** * 具体观察者角色 * 类: ConcreteWatcher <br> * 描述: TODO <br> * 作者: * 时间: Nov 5, 2013 5:51:47 PM */ public class ConcreteWatcher implements Watcher { public void udpate(String str) { System.out.println(str); } }
package com.shengshiyuan.observer; import java.util.ArrayList; import java.util.List; /** * 具体主题角色 * 类: ConcreteWatched <br> * 描述: TODO <br> * 作者: * 时间: Nov 5, 2013 5:44:06 PM */ public class ConcreteWatched implements Watched { // 一个主题会有多个观察者,多个观察者会放到一个集合里面,起到维护的作用。这个集合用来承载观察我的哪些观察者 private List<Watcher> list = new ArrayList<Watcher>(); public void addWatcher(Watcher watcher) { list.add(watcher); } // 通知观察者 public void notifyWatchers(String str) { for (Watcher watcher : list) { watcher.udpate(str); } } public void removeWatcher(Watcher watcher) { list.remove(watcher); } }
package com.shengshiyuan.observer; /** * 测试类 * 类: Test <br> * 描述: TODO <br> * 作者: * 时间: Nov 5, 2013 7:42:46 PM */ public class Test { public static void main(String[] args) { // 女为悦己者容(女孩有好多追求者) Watched girl = new ConcreteWatched(); // 为其添加观察者 Watcher watcher1 = new ConcreteWatcher(); Watcher watcher2 = new ConcreteWatcher(); Watcher watcher3 = new ConcreteWatcher(); girl.addWatcher(watcher1); girl.addWatcher(watcher2); girl.addWatcher(watcher3); girl.notifyWatchers("开心,爽"); // 女孩不喜欢第二个追求者,将他删除(移除观察者) girl.removeWatcher(watcher2); girl.notifyWatchers("爽!"); } }
观察者模式在Java语言中的地位极其重要。
JDK都认为观察者模式非常重要,所以它也内置了观察者模式的支持,而其他模式不会有这样的待遇。JDK为观察者模式提供了一种支持,为其提供了类提供了接口来支持它。
Observable类用于创建可以观测到你的程序中其他部分的子类【它是一个主题角色,它是一对多里面一的那一方,是有多个人去观测它】。当这种子类的对象发生变化时,观测类被通知。观测类必须实现定义了update()方法的Observer接口。当一个观测程序被通知到一个被观测对象的改变时,update()方法被调用。
Observable是我们的主题角色(我们继承这个类来创建我们自己的主题对象)。Observer是抽象的观察者,我们实现它来定义自己的具体观察者。
一定要重点查看Observable类的源码,一定要重点查看。仔细查看完之后Observable类的源码和我们最初自己实现的那个简单的观察者模式里面的ConcreteWatched 类代码特别相似,只是多了一个主题是否改变的Boolean变量和对它操纵的几个方法以及机制而已。
Observable(观测):
注意notifyObservers()有两种形式:一种带有参数而另一种没有。当用参数调用notifyObservers()方法时,该对象被传给观测程序的update()方法作为其第二个参数。否则,将给update()方法传递一个null。可以使用第二个参数传递适合于你的应用程序的任何类型的对象。
为了观测一个可观测的对象,必须实现Observer接口。这个接口仅仅定义了如下所示的一个方法:
---void update(Observable observOb,Object arg)
---这里,observOb是被观测的对象,而arg是由notifyObservers(Object arg)方法传递的值。当被观测对象发生了改变,调用update()方法。
这里是一个说明可观测对象的例子。该程序创建了一个叫Watcher的类,该类实现了Observer接口。被监控的类叫做Being Watched,它继承了Observable。在Being Watched里,是counter()方法,该方法仅是从一个指定的值开始递减计数。每次计数改变时,notifyObservers()方法被调用,而当前的计数被作为参数传递给notifyObservers()方法。这导致了Watcher中的update()方法被调用,显示当前的计数值。在main()内,分别调用observing和observed的Watcher和Being Watched对象被创建。然后,observing被增加到对observed的观测程序列表。这意味着每次counter()调用notifyObservers()方法时,observing.update()方法将被调用。
一个被观测的对象必须服从下面两个简单规则。第一,如果它被改变了,它必须调用setChanged()方法。第二,当它准备通知观测程序它的改变时,它必须调用notifyObservers()方法。这导致了在观测对象中对update()方法的调用。注意---当对象在调用notifyObservers()方法之前,没有调用setChanged()方法,就不会有什么动作发生。在update()被调用之前,被观测对象必须调用setChanged()和notifyObservers()两种方法。
下面是针对观察者模式留的一个作业:
作业:
1)阅读Observable类的源代码,理解Observable类与Observer接口之间的调用关系。
2)编写一个程序,声明一个类,该类继承自Observable(因此该类是个主题角色),有一个int 类型的变量,初始值为10,编写一个for 循环,将该数字每次递减1,一直到0为止,每次变化时,都将该数字传递给它的观察者,观察者会打印出该数字;第二个观察者在该数字变为5之后开始打印该数字。
下面两个类是自己的作业完成情况(没有经过修改):
package com.shengshiyuan.observer2; import java.util.Observable; /** * 主题角色 * 类: RealObservable <br> * 描述: TODO <br> * 作者: * 时间: Nov 6, 2013 6:02:32 PM */ public class RealObservable extends Observable { private static int a; /** * 其实重写这个方法没有多大用处 * 方法: notifyObservers <br> * 描述: TODO * @param arg * @see java.util.Observable#notifyObservers(java.lang.Object) */ @Override public void notifyObservers(Object arg) { super.setChanged();// 告诉Observable自己的这个主题已经发生了改变(一个标志位) super.notifyObservers(arg); } /** * 测试类 * 方法: main <br> * 描述: TODO <br> * 作者: * 时间: Nov 6, 2013 6:01:55 PM * @param args */ public static void main(String[] args) { RealObserver observer1 = new RealObserver(); RealObserver observer2 = new RealObserver(); RealObservable observable = new RealObservable(); observable.addObserver(observer1); for (a = 10; a >= 0; a--) { if (a == 5) { observable.addObserver(observer2); } observable.notifyObservers(a); } } }
package com.shengshiyuan.observer2; import java.util.Observable; import java.util.Observer; /** * 观察者 * 类: RealObserver <br> * 描述: TODO <br> * 作者: * 时间: Nov 6, 2013 6:03:12 PM */ public class RealObserver implements Observer { public void update(Observable o, Object arg) { System.out.println(arg); } }
下面的代码是老师最后最后针对作业完成的标准代码,他只用了一个类:
package com.shengshiyuan.observer2; import java.util.Observable; import java.util.Observer; /** * 主题对象 * 类: BeingWatched <br> * 描述: TODO <br> * 作者: * 时间: Nov 6, 2013 5:14:01 PM */ class BeingWatched extends Observable { void counter(int number) { // number每递减一就通知一次下面的观察者 for (; number >= 0; number--) { // 调用此方法修改标志位 this.setChanged(); // 通知观察者 this.notifyObservers(number); } } } /** * 观察者对象 * 类: Watcher1 <br> * 描述: TODO <br> * 作者: * 时间: Nov 6, 2013 5:13:55 PM */ class Watcher1 implements Observer { public void update(Observable o, Object arg) { System.out.println("Watcher1's count is" + arg); } } /** * 第二个观察者对象 * 类: Watcher2 <br> * 描述: TODO <br> * 作者: * 时间: Nov 6, 2013 5:15:58 PM */ class Watcher2 implements Observer { public void update(Observable o, Object arg) { if (((Integer) arg).intValue() <= 5) { System.out.println("Watcher2's count is" + arg); } } } /** * 测试类 * 类: TwoObservers <br> * 描述: TODO <br> * 作者: * 时间: Nov 6, 2013 5:17:53 PM */ public class TwoObservers { public static void main(String[] args) { BeingWatched watched = new BeingWatched(); Watcher1 watcher1 = new Watcher1(); Watcher2 watcher2 = new Watcher2(); watched.addObserver(watcher1); watched.addObserver(watcher2); watched.counter(10); } }
发表评论
-
领域精通涉及技术点(不分先后)
2017-12-20 19:35 630Java8 netty jvm kafaka消息队列 上传下载 ... -
计算机各种单位讲解及换算
2017-12-13 13:54 1657我还听过有UK的 一、最小单位:位(bit,缩写为b) 在原 ... -
JAVA字符串格式化-String.format()和MessageFormat的使用
2017-12-05 10:39 1481String.format()常规类型的格式化 Stri ... -
eclipse启动项目常见问题
2017-11-16 17:46 1195今儿遇到了个问题,ecli ... -
字符编码笔记:ASCII,Unicode和UTF-8
2017-10-23 16:37 462讲的太牛逼了: http://ww ... -
emoji简单讲解
2017-10-23 15:17 983emoji处理方式大起底 http://blog.csdn.n ... -
BigDecimal讲解
2017-10-12 15:58 453BigDecimal 由任意精度的整数非标度值 和 32 位的 ... -
eclips 控制台console上不打印信息
2017-09-06 21:53 5891、进windows菜单 -> show view -& ... -
详解RequestMappingHandlerMapping和RequestMappingHandlerAdapter
2017-08-29 17:08 3010http://donald-draper.iteye.com/ ... -
用@ExceptionHandler 来进行切面异常处理
2017-08-29 11:47 2328有时候我们想处理某个类里Controller中抛出的异常怎么搞 ... -
Spring 注解@Component、@Repository、@Service、@Controller区别
2017-08-28 15:27 1030spring 2.5 中除了提供 @Com ... -
线程的一点小总结
2017-08-23 20:36 716java中main方法启动的是一个进程还是一个线程? 答:是一 ... -
线程池
2017-08-23 17:35 536诸如Web 服务器、数据库 ... -
Class源码大概讲解
2017-08-23 16:47 526http://blog.csdn.net/a327369238 ... -
Spring 事务相关
2017-08-14 12:10 479Transactionz注解的readOnly ... -
把时间当做朋友-前言
2017-08-13 20:47 415要管理的不是时间,而是自己。人们生活在同一个世界,却又各自 ... -
单例里面的方法讲解
2017-08-11 14:55 494spring里的controller是单例的。系统针对每个co ... -
eclipse拷贝出来的项目名称还是原来的
2017-07-26 16:46 1092需要修改的有如下几个地方: 1、pom.xml里面打包的名字一 ... -
自定义hibernate方言,新增自定义函数
2017-06-27 10:47 887按位与运算(&)在许多数据库中都是支持的,遗憾的是,H ... -
http请求参数:header body paramter三种参数区别、联系
2017-06-19 10:46 490412345
相关推荐
了解并掌握一些常见的设计模式,如单例模式、工厂模式、观察者模式等。这些模式不仅可以提高代码的复用性,还能增强系统的灵活性和可维护性。 ### 九、J2EE框架 #### 9.1 J2EE概述 J2EE(Java Platform, ...
11KW OBC两电平pfc+cllc仿真源码实现:单相与三相兼容版双向控制研究,11KW OBC两电平pfc+cllc仿真源码实现:单相与三相兼容版,实现双向控制策略,11KW OBC两电平pfc+cllc仿真,源代码实现。 注意:已成单相,三相兼容版仿真文件。 双向控制。 ,核心关键词:11KW OBC两电平pfc; CLLC仿真; 源代码实现; 单相三相兼容; 双向控制。,11KW OBC单相与三相兼容版仿真:两电平PFC+CLLC双向控制源代码实现
3GPP R15 38.331 5G NR无线资源控制(RRC)协议规范解析
五运六气YUNQI_V471_SRC_D1023
19考试真题最近的t63.txt
基于MATLAB的牛拉法电力系统潮流计算程序,结合BPA方法,附参考文献,适合基础学习与拓展创新,基于MATLAB的牛拉法电力系统潮流计算程序:涵盖基础学习与拓展创新,附参考文献,牛拉法电力系统潮流计算 MATLAB编写潮流计算程序 BPA计算潮流 另外包含参考文献 这个程序把潮流计算的一般流程包括了,非常适合基础学习,并进一步的进行拓展创新 ,牛拉法; 电力系统潮流计算; MATLAB; BPA计算; 程序编写; 流程; 基础学习; 创新拓展,基于MATLAB的牛拉法电力系统潮流计算程序:基础学习与拓展创新指南
YOLOv11m权重文件
高一-语文-2025年1月张家界市高一期末联考-缺考不计、违纪不计、0分不计_2025-01-16-12-21 (1).zip
android kotlin 版本的贪吃蛇游戏
19考试真题最近的t57.txt
基于疫情封控区域的生活物资配送优化模型:结合遗传算法与模拟退火,实现时间最短和综合满意率最高的路径优化。,疫情下封控区域生活物资配送优化模型:结合遗传算法与模拟退火算法求解路径优化问题,实现时间与满意率双重目标优化。,模型及MATLAB代码:考充分考虑并结合疫情下封控区域生活物资配送问题及车辆路径问题的特点构建物资配送优化模型。 在一般单一目标——时间最短的基础上,加入综合满意率优化目标的路径优化问题 关键词:遗传算法、改进、模拟 火算法,路径优化、CVRP 完整模型+代码+注释 主要内容:以配送时间最短及综合满足率最高为目标,充分考虑并结合疫情下封控区域生活物资配送问题及车辆路径问题的特点构建物资配送优化模型,为疫情下生活物资配送找到了更好的思路。 在模型设计与求解问题上,首先设计标准遗传算法,继而对算法加以改进,最后设计出了改进遗传-模拟 火算法对模型进行求解。 还有参数灵敏度分析等。 服务内容:脚本 工具 部分展示如下: ,关键词:疫情下物资配送;车辆路径问题;优化模型;遗传算法;改进;模拟退火算法;CVRP;参数灵敏度分析;脚本工具;时间最短;综合满意率。 核心关键词用分号分
## 01、数据介绍 动态能力理论最早由提斯(Teece)与皮萨洛(Pisano)于1994年正式提出,他们将动态能力定义为“能够创造新产品和新过程,以及对变化的市场环境做出响应的一系列能力”。 动态能力具体体现在吸收能力、创新能力和适应能力三个方面。这些能力使公司能够快速适应市场变化,抓住新的商业机会,从而保持或提升竞争优势。 数据名称:上市公司-动态能力数据 数据年份:2012-2023年 ## 02、相关数据及指标 证券代码 证券名称 年份 Symbol RD IA ACV DC
基于ASIO的插件式服务器,支持TCP, UDP, 串口,Http, Websocket,统一化的数据接口,隔离开发人员和IO之间的操作。可以快速迭代。PSS 是针对不同 IO 逻辑的插件管理系统。您可以忽略 IO 建立的细节,构建自己的 logic 应用程序。PSS 封装了 Tcp、udp、kcp、串行端口、http、websocket 和 ssl 的统一接口。您可以使用 配置文件 或 统一接口 来创建和使用它们。logic plug-in 是完成数据到达后的 logic 处理,全部以动态库的形式加载,将 IO 和 logic 本身的耦合分开。简单的逻辑开发。本项目由三部分组成 (1) 主机(2) 数据包分析插件(3) 逻辑处理插件。您可以实现后两个插件来完成您的业务逻辑部署。
电机控制器源码:通用无感BLDC方波控制,高效参数化启动,转速达12w,环控系统一键调节,电机控制器源码:通用无感BLDC方波控制,高效调速,参数宏定义便捷调试,最高电转速达12w,电机控制器,低压无感BLDC方波控制,全部源码,方便调试移植 1.通用性极高,图片中的电机,一套参数即可启动。 2. ADC方案 3.电转速最高12w 4.电感法和普通三段式 5.按键启动和调速 6.开环,速度环,限流环 7.参数调整全部宏定义,方便调试 代码全部源码 ,电机控制器;低压无感BLDC方波控制;全部源码;通用性极高;电转速最高12w;电感法与普通三段式;按键启动调速;开环、速度环、限流环;参数调整宏定义。,通用电机控制器:低压无感BLDC方波控制源码,支持高转速12W,便捷调试移植
基于MPC的电动汽车分布式协同自适应巡航控制:上下分层控制与仿真结果展示,基于MPC的电动汽车协同自适应巡航控制:上下分层控制与仿真结果展示,基于MPC的分布式电动汽车协同自适应巡航控制,采用上下分层控制方式,上层控制器采用模型预测控制mpc方式,产生期望的加速度,下层根据期望的加速度分配扭矩;仿真结果良好,能够实现前车在加减速情况下,规划期望的跟车距离,产生期望的加速度进行自适应巡航控制。 ,关键词:MPC(模型预测控制); 分布式电动汽车; 协同自适应巡航控制; 上下分层控制方式; 期望加速度; 扭矩分配; 仿真结果良好; 前车加减速; 跟车距离。,基于MPC的分层控制电动汽车自适应巡航系统,仿真实现前车加减速跟车距离自适应
多维度购电与售电模型构建及基于CVaR与WOA优化的收益风险评估方法研究,基于CVaR风险评价及WOA优化的新型售电公司购售电模型与策略仿真研究,建立了一个电公司的购电侧模型和电侧模型,其中购电侧模型包括长期市场业务,现市场业务,可再生能源购电市场业务,分布式电源购电市场业务以及储能租赁市场业务五种类型。 电侧包括均 电价合同和实时电价合同两种类型。 然后在购电模型的基础上,提出了一种基于CVaR的购电收益风险评价方法。 根据电公司的CVaR购电收益风险数学模型,提出了一种基于WOA优化算法的新型购电收益计算方法。 该方法将购电收益风险计算公式作为WOA优化算法的目标函数,然后通过WOA的鲸鱼行走觅食、鲸鱼包围以及鲸鱼螺旋捕食三个步骤计算电公司的最优购电策略。 最后,通过MATLAB仿真工具对本文所研究的基于WOA优化的新型购电收益计算方法进行了仿真分析。 仿真结论验证了通过WOA优化算法得到的购电策略为最优购电策略。 matlab代码 仿真平台:MATLAB平台 代码具有一定的深度和创新性,注释清晰 ,关键词: 1. 购电侧模型; 2. 售电侧模型; 3. 长期/现货/可再生
迅雷软件下载原理介绍.md
## 01、数据简介 碳排放是指在人类活动中,如能源消耗、工业生产、交通运输、农业活动等过程中向大气中释放的二氧化碳等温室气体的行为。这些温室气体在大气中形成隔热层,导致地球气温升高,引发全球气候变化。分行业碳排放则是指按照不同的经济活动或产业部门来划分和统计碳排放量。 按省市县整理成面板数据,其中包括电力行业、工业过程、工业燃烧、建筑物能源、浪费、农业、燃料能源和运输八种指标排放量各省市县的最大值、最小值、平均值、总和。 数据名称:省市县分行业碳排放月度数据 数据年份:2023年 ## 02、相关数据 name 指标 时间 数值 更多数据 ## 03、数据截图
基于OpenCV 相机校准 姿势估计 线性几何 立体图像的深度图