利用 JMetal 实现大规模聚类问题的研究(二) JMetal代码总览

之前完成了导入JMetal到自己的工程这一步。

在开始我们研究的问题之前,我们先对JMetal的源代码一个全局的认识。

JMetal很好地利用了面向对象的特性,对所有的优化问题做了高度的抽象,建议有空认真阅读源代码。

core 中的类是整个JMetal的基础类,非常重要。比如,所有的算法都继承于的Algorithm类。

encodings 是编码的方法,就是启发式算法中的各种解的表示方法。

experiments 这里面给出利用JMetal做实验的一些示例代码。

metaheuristics里面包含了各种最新的优化算法的实现,可以非常方便地做对照实验。

operators 是优化算法里面的各种操作,比如遗传算法需要交叉、变异、选择,也可以自定义操作。

problems 包括多目标的一些经典的问题,广泛应用于各种多目标论文中对照实验,比如WFG,DTLZ还收录了CEC2009的测试集。

qualityIndicator 里面是对各种解的一些质量评估的方法。包括Spread, Epsilon, HyperVolume这些经典的指标。

最后的util类,包含很多实用的算法类,比如求解向量的距离,排序等等,如果能够用上可以节约很多时间。

以后用到再更新。

时间: 2024-08-04 16:42:40

利用 JMetal 实现大规模聚类问题的研究(二) JMetal代码总览的相关文章

利用LDA进行文本聚类(hadoop, mahout)

项目原理概述 利用sqoop将数据从MySQL导入到HDFS中,利用mahout的LDA的cvb实现对输入数据进行聚类,并将结果更新到数据库中.数据流向图如下 mahout算法分析 输入数据格式为<IntegerWritable, VectorWritable>的matrix矩阵,key为待聚类文本的数字编号,value为待聚类文本的单词向量Vector, Vector的index为单词在字典中的编号, value为TFIDF值. 算法相关参数详解(不包含hadoop运行参数)项目中所有参数设

利用cvKMeans2()实现图像聚类(位置+颜色)

///利用opencv提供的函数cvKMeans2()实现图像聚类 ///////运行环境:VC6.0+opencv1.0 ///////////////使用的时候,改变flag的初始值,即可实现对灰度图.彩色图基于色彩的聚类,以及根据位置和色彩对彩色图像聚类. ////////////////最后结果显示的时候请注意pResult 和pResult3 #include "cv.h" #include "cxcore.h" #include "highgu

C++的开源跨平台日志库glog学习研究(二)--宏的使用

上一篇从整个工程上简单分析了glog,请看C++的开源跨平台日志库glog学习研究(一),这一篇对glog的实现代码入手,比如在其源码中以宏的使用最为广泛,接下来就先对各种宏的使用做一简单分析. 1. 日志输出宏 这里我们以一条最简单的日至输出为例说明: LOG(WARNING) << "This is a warning message"; 这里LOG是一个宏,其定义如下(logging.h line 487): #define LOG(severity) COMPACT

当年写的俄罗斯方块(现在更喜欢研究别人的代码)

这个东西大概是4年多前写的,那时写代码很疯狂,不知疲惫,一写就是好几万行.现在则更喜欢研究别人的代码,有时也写些测试代码,或者研究开源的东西.希望真正有些积累后, 再考虑写自己的东西. 感觉当时大的框架做的还行,源代码或许对新手有用. 源代码下载:sourceCode 上几个截图 单人游戏: 人机对战: 设置: posted on 2012-05-03 23:00 http://www.cppblog.com/weiym/archive/2012/05/03/173616.html http:/

(转载)Fiddler实战深入研究(二)

原文来源于:http://www.cnblogs.com/tugenhua0707/p/4637771.html,作者:涂根华 !个人觉得文章写的特别好,故收藏于此,感谢原作者的分享 Fiddler实战深入研究(二) 阅读目录 Fiddler不能捕获chrome的session的设置 理解数据包统计 请求重定向(AutoResponder) Composer选项卡 Filters选项卡断点调式 Fiddler 中的Stave插件 回到顶部 Fiddler不能捕获chrome的session的设置

智力题研究二

[IT思想类] 1. 有1000瓶水,其中有一瓶有毒,小白鼠只要尝一点带毒的水24小时后就会死亡,至少要多少只小白鼠才能在24小时时鉴别出那瓶水有毒?(中级) 2. 共有三类药,分别重1g,2g,3g,放到若干个瓶子中,现在能确定每个瓶子中只有其中一种药,且每瓶中的药片足够多,能只称一次就知道各个瓶子中都是盛的哪类药吗? 如果有4类药呢?5类呢?N类呢(N可数)?(高级) 如果是共有m个瓶子盛着n类药呢(m,n为正整数,药的质量各不相同但各种药的质量已知)?你能只称一次就知道每瓶的药是什么吗?

关于linux系统如何实现fork的研究(二)

本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 引言 前一篇关于linux系统如何实现fork的研究(一)通过代码已经说明了从用户态怎么通过软中断实现调用系统调用clone函数,而clone函数的精华copy_process函数就在此篇文章中进行分析.我们知道,在linux系统中,应用层可以创建子进程和子线程(轻量级进程)两种程序分支结构.而对于linux内核而且,并不详细区分子进程和子线程(轻量级进程)的区别,他们都使用的是task_struct结构(此

.NetCore技术研究-一套代码同时支持.NET Framework和.NET Core

在.NET Core的迁移过程中,我们将原有的.NET Framework代码迁移到.NET Core.如果线上只有一个小型的应用还好,迁移升级完成后,只需要维护.NET Core这个版本的代码. 但是,如果是一个大型分布式应用,几百台Server,上千个.NET 应用进程.这种场景下,在一定的时期内,我们需要同时维护.NET Framework和.NET Core两套代码,同一个产品 特性,需要分别在两套代码中实现,这种代码同步的工作量是非常大的.因此,在这种场景下,有必要使用同一套代码既支持

Facebook大规模Flash失效分析研究 - SIGMetrics, 2015

Facebook与卡内基梅隆大学最近在SIGMetrics ( June 15–19, 2015, Portland, OR, USA).发表一篇关于大规模应用下PCI-e flash失效研究的文章”A Large-Scale Study of Flash Memory Failures in the Field” .基于对Facebook数据中心近4年来大量flash失效数据的总结,揭示了一些有趣的现象,对flash,存储软件,全闪存阵列,应用者以及基础架构运维者有启发意义. 原文在  htt