本框架提供了有关粒子群算法(PSO)和遗传算法(GA)的完整实现,以及一套关于改进、应用、测试、结果输出的完整框架。
本框架对粒子群算法与遗传算法进行逻辑解耦,对其中的改进点予以封装,进行模块化,使用者可以采取自己对该模块的改进替换默认实现组成新的改进算法与已有算法进行对比试验。
试验结果基于Excel文件输出,并可通过设定不同的迭代结束方式选择试验数据的输出方式,包括:1.输出随迭代次数变化的平均达优率数据(设定终止条件区间大于0)。
2.输出随迭代次数变化的平均最优值数据(设定终止条件区间等于0)。
本框架了包含了常用基准函数的实现以及遗传算法与粒子群算法对其的求解方案实现和对比,如TSP,01背包,Banana函数,Griewank函数等。
并提供大量工具方法,如KMeans,随机序列生成与无效序列修补方法等等。
对遗传算法的二进制编码,整数编码,实数编码,整数序列编码(用于求解TSP等),粒子群算法的各种拓扑结构,以及两种算法的参数各种更新方式均有实现,并提供接口供使用者实现新的改进方式并整合入框架进行试验。
其中还包括对PSO进行离散化的支持接口,和自己的设计一种离散PSO方法及其用以求解01背包问题的实现样例。
欢迎参考并提出宝贵意见,特别欢迎愿意协同更新修补代码的朋友(邮箱starffly@foxmail.com)。
代码已作为lakeast项目托管在GoogleCode:http://code.google.com/p/lakeasthttp://code.google.com/p/lakeast/downloads/list某些类的功能说明:org.lakest.common中:BoundaryType定义了一个枚举,表示变量超出约束范围时为恢复到约束范围所采用的处理方式,分别是NONE(不处理),WRAP(加减若干整数个区间长度),BOUNCE(超出部分向区间内部折叠),STICK(取超出方向的最大限定值)。
Constraint定义了一个代表变量约束范围的类。
Functions定义了一系列基准函数的具体实现以供其他类统一调用。
InitializeException定义了一个代表程序初始化出现错误的异常类。
Randoms类的各个静态方法用以产生各种类型的随机数以及随机序列的快速产生。
Range类的实现了用以判断变量是否超出约束范围以及将超出约束范围的变量根据一定原则修补到约束范围的方法。
ToStringBuffer是一个将数组转换为其字符串表示的类。
org.lakeast.ga.skeleton中:AbstractChromosome定义了染色体的公共方法。
AbstractDomain是定义问题域有关的计算与参数的抽象类。
AbstractFactorGenerator定义产生交叉概率和变异概率的共同方法。
BinaryChromosome是采用二进制编码的染色体的具体实现类。
ConstantFactorGenerator是一个把交叉概率和变异概率定义为常量的参数产生器。
ConstraintSet用于在计算过程中保存和获取应用问题的各个维度的约束。
Domain是遗传算法求解中所有问题域必须实现的接口。
EncodingType是一个表明染色体编码类型的枚举,包括BINARY(二进制),REAL(实数),INTEGER(整型)。
Factor是交叉概率和变异概率的封装。
IFactorGenerator参数产生器的公共接口。
Population定义了染色体种群的行为,包括种群的迭代,轮盘赌选择和交叉以及最优个体的保存。
org.lakeast.ga.chromosome中:BinaryChromosome二进制编码染色体实现。
IntegerChromosome整数编码染色体实现。
RealChromosome实数编码染色体实现。
SequenceIntegerChromosome整数序列染色体实现。
org.lakeast.pso.skeleton中:AbstractDomain提供一个接口,将粒子的位置向量解释到离散空间,同时不干扰粒子的更新方式。
AbstractF
2024/10/11 21:51:28 1.42MB 遗传算法 粒子群算法 GA PSO
1
双向隔离型DC-DC变换器simulink模型,基本上就是双向隔离DC/DC+DC/AC组成的电路
2024/10/11 7:40:50 78KB DC-D simuli
1
人工智能—一种现代的方法课后习题Wumpus世界是一个由多个房间组成并连接起来的山洞。
在洞穴的某处隐藏着一只怪兽(Wumpus),它会吃掉进入它房间的任何人。
探险者(Agent)可以射杀怪兽,但是探险者只有一支箭。
某些房间是无底洞,任何人漫游到这些房间都会被无底洞吞噬(怪兽除外,他由于太大可以幸免)。
生活在该环境下的唯一希望是存在发现一堆金子的可能性。
2024/10/11 7:51:15 107.63MB AI 怪兽世界 C++ MFC
1
发明专利信息管理系统发明专利信息管理系统是建立在以网络为基础的一种专利信息管理系统,它的及时性,互动性,专业性等方面,是传统专利管理方式无法逾越的,它有着传统专利管理方式无法比拟的优势。
计算机发明专利信息管理系统作为现代专利管理的重要组成部分在保障专利管理方面起着不可替代的作用,已经获得了越来越多的人青睐。
但是由于它的发展起步较晚,技术上还很不成熟。
2024/10/11 0:23:39 943KB 专利信息管理
1
GDI+SDK参考(翻译版本)序言 4目标 4适用范围 4适用读者 4运行环境 4文档组织 4相关主题 4GDI+的安全考虑 6检验构造函数调用成功与否 6分配缓冲区 6错误校验 8线程同步 9相关主题 10关于GDI+ 11GDI+介绍 11GDI+概览 11GDI+的三个组成部分 11基于类的接口架构 12GDI+提供了哪些新东西? 12新特征 12编程模式的改变 15线条、曲线和图形 19矢量图概览 19钢笔、线条和矩形 20椭圆和弧 22多边形 22基数样条 23贝塞尔样条 24路径 25画刷和填充图形 27开放与闭合曲线 29区域 30裁剪 31路径平直化 32线条和曲线的抗锯齿功能 32图象、位图和图元文件 33位图类型 34图元文件 37绘制、定位和复制图片 39裁剪和缩放图象 40坐标系统和转换 42坐标系统类型 42以矩阵来表示转换 44全局和局部转换 48图形容器 51使用GDI+ 56使用入门 56绘制线条 56绘制字符串 58使用钢笔绘制线条和形状 59使用钢笔绘制线条和矩形 59设置钢笔的宽度和对齐方式 60绘制具有线帽的线条 61联接线条 62绘制自定义虚线 62绘制用纹理填充的线条 63使用画笔填充形状 63用纯色填充形状 64用阴影图案填充形状 64用图像纹理填充形状 64在形状中平铺图像 65用渐变色填充形状 68使用图像、位图和图元文件 68加载和显示位图 68加载和显示图元文件 69记录图元文件 69剪裁和缩放图像 71旋转、反射和扭曲图像 72缩放时使用插值模式控制图像质量 73创建缩略图像 75采用高速缓存位图来提高性能 76通过避免自动缩放改善性能 76读取图像元数据 77使用图像编码器和解码器 83列出已安装的编码器 83列出已安装的解码器 84获取解码器的类标识符 86获取编码器的参数列表 88将BMP图像转换为PNG图像 100设定JPEG的压缩等级 101对JPEG图像进行无损变换 102创建和保存多帧图像 105从多帧图像中复制单帧 107Alpha混合线条和填充 109绘制不透明和半透明的线条 109用不透明和半透明的画笔绘制 110使用复合模式控制Alpha混合 111使用颜色矩阵设置图像中的Alpha值 112设置单个象素的alpha值 114使用字体和文本 115构造字体系列和字体 115绘制文本 116格式化文本 117枚举已安装的字体 120创建专用的字体集合 122获取字体规格 126对文本使用消除锯齿效果 130构造并绘制曲线 131绘制基数样条曲线 131绘制贝塞尔样条 133用渐变画刷填充形状 134创建线性渐变 134创建路径渐变 137将Gamma校正应用于渐变 144构造并绘制路径 145使用线条、曲线和形状创建图形 145填充开放式图形 147使用图形容器 147管理Graphics对象的状态 148使用嵌套的Graphics容器 151变换 154使用世界变换 154为什么变换顺序非常重要 155使用区域 156对区域使用点击检测 156对区域使用剪辑 157对图像重新着色 158使用颜色矩阵对单色进行变换 158转换图像颜色 160缩放颜色 161旋转颜色 164剪取颜色 166使用颜色重映射表 168打印 169将GDI+输出至打印机 169显示一个打印对话框 172通过提供打印机句柄优化打印 173附录:GDI+参考 176
2024/10/10 11:31:03 1.75MB GDI+ GDI+中文 GDI+帮助
1
针对工程应用中钢轨监测传感网现场调试的实际需求,研制了一种可用于无线传感网在线调试的网关,设计并实现了网关的硬件电路,开发了由数据接口层、业务逻辑层及用户界面层组成的上位机在线调试软件,制定了一种可减少现场数据丢失率的完整性维护策略。
实验结果表明:研制的在线调试网关数据传输可靠、响应速度快、体积小、便于携带,适用于钢轨监测传感网现场的快速调试和维护。
1
本系统主要由单片机和GSM短信模块组成,借助最可靠、最成熟的GSM移动网络,以最直观的中文短消息或电话形式,直接把报警地点的情况反映到您的手机屏幕上。
它采用主动式红外传感器进行检测,变有形的传统防盗网防盗窗为无形,给火灾时的逃生提供方便。
并配备烟雾传感器和燃气泄漏传感器,实现防火、防燃气泄漏的作用。
2024/10/6 3:17:57 527B GSM 传感器
1
编制质量手册涉及组织结构、职责权限的划分及调整理顺,以及各生产、服务过程环节、质量活动内容的控制办法,是一项十分复杂的系统工程。
要使这项工作有计划、有步骤、按期、按质、按量地完成,就必须加强组织领导。
尤其是组织管理者,具有不可推卸的责任。
管理者不参与手册编写这件事本身,就已经违背了标准的规定。
自然也不是要管理者事必躬亲,可成立质量手册(质量文件)编写领导小组,其成员由各主管领导组成,其主要任务是:
2024/10/5 9:46:11 23KB 质量手册编制的基本程序
1
###《对象入门指南》第二版——面向对象软件开发的全面介绍####知识点一:面向对象编程(OOP)的概念及其优势**标题**:“TheObjectPrimer2ndEdition”**描述**:这本书是面向对象(OO)软件的一种结构化步骤介绍,采用教学风格编写,易于初学者阅读。
面向对象编程是一种编程范式,它通过“对象”来组织代码结构。
这些对象通常包含了数据和可以操作这些数据的方法。
《对象入门指南》第二版为读者提供了深入理解面向对象编程的基础知识和实践技巧。
该书强调了OOP的主要优势,包括但不限于:-**增加重用性**:通过继承机制,新类可以从现有类中继承属性和方法,从而减少了重复编码的需求。
-**增强可扩展性**:面向对象设计允许在不影响其他部分的情况下轻松添加新的功能或修改现有功能。
-**提高质量**:封装机制有助于保护数据不被外部访问,从而提高了代码的健壮性和安全性。
-**经济效益**:由于提高了代码质量和开发效率,长期来看能够降低项目的总成本。
-**提高项目成功率**:良好的设计和结构化流程有助于确保项目的顺利进行。
-**减轻维护负担**:模块化的代码更易于理解和修改,降低了维护成本。
-**减少应用程序积压**:更快的开发周期意味着可以更快地处理更多任务。
-**管理复杂度**:通过抽象、封装等技术,OOP帮助开发者更好地管理复杂的系统。
####知识点二:面向对象软件过程与标准**标题**:“TheObjectPrimer2ndEdition”**描述**:本书是一本关于面向对象软件开发的指南,涵盖了从概念到实现的整个过程。
面向对象软件开发不仅涉及编程技术,还包括整个软件开发生命周期中的多个阶段。
《对象入门指南》第二版探讨了面向对象软件过程的关键组成部分,如需求分析、设计、实现、测试和维护。
此外,书中还提到了几个重要的面向对象标准,例如统一建模语言(UML),这是一种广泛使用的图形化语言,用于软件系统的可视化建模。
UML提供了一套标准化的符号和规则,帮助开发者清晰地表达软件设计的各个方面,包括但不限于:-**类图**:描述类、接口和它们之间的关系。
-**序列图**:展示对象之间如何交互以及消息传递的时间顺序。
-**活动图**:描述工作流或业务流程。
-**组件图**:展示系统中物理构件的组织结构。
-**部署图**:显示系统中硬件节点以及节点上运行的软件构件的配置情况。
####知识点三:面向对象编程的挑战与未来发展**标题**:“TheObjectPrimer2ndEdition”**描述**:本书讨论了面向对象编程的潜在缺点以及其在软件开发领域的持久影响力。
虽然面向对象编程带来了许多优势,但它也有一些潜在的挑战。
例如,过度依赖继承可能导致系统变得僵化,难以适应未来的变化。
此外,面向对象设计的复杂性有时可能对新手开发者构成挑战。
不过,《对象入门指南》第二版强调了面向对象编程的重要性和持久性,认为它将继续作为软件开发的核心方法论之一存在和发展。
随着技术的进步,面向对象方法也在不断演进,例如引入领域驱动设计(DDD)、微服务架构等新理念和技术,以更好地解决现代软件工程中的问题。
《对象入门指南》第二版不仅是一本适合初学者的面向对象编程入门书籍,也为经验丰富的开发者提供了深入理解和应用面向对象设计原则的机会。
通过学习本书,读者将能够掌握面向对象编程的基本概念、优势、挑战以及面向对象软件开发过程中的最佳实践。
2024/10/5 10:13:01 397KB UML Object Oriented
1
基于TS4231的VR定位,包括Lighthouse的驱动,以及32个TS4231组成的标签MESH。
2024/10/4 0:48:47 731KB VR/FPGA/TS42
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡