开发者社区> 【方向】> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

Java开发者必看!机器学习开发库精选!

简介: 本文将介绍一些目前流行的、强大的基于Java的机器学习库。
+关注继续查看

33998d6d00a647d89f138d529122ebc9d8c48da1
图片来源: Mindfire Solutions

摘要:现如今,拥有深度学习和机器学习领域的技术是科技界的趋势之一,并且企业则希望雇佣一些拥有良好的机器学习知识背景的程序开发工程师。本文将介绍一些目前流行的、强大的基于Java的机器学习库,希望给大家带来帮助。

 

事实上,Java已经成为开发新的机器学习算法的标准语言。学习Java语言有很多好处,并且在机器学习社区中也被人们所广泛接受,其优点包括:易维护、商业化、可读性、可移植性等等。根据2018年6月的编程语言排行榜TIOBE-index提供的数据显示,Java是目前最流行和使用最广泛的计算机编程语言,包括PHP、C语言、C++、Python和JavaScript等。如果企业想将机器学习业务整合到现有的Java商业应用程序中,那么就必须雇用Java开发人员。

下面我们将列出一些在现有的一些Java应用程序中实现机器学习的最佳类库。所有的这些库都是通过各种博客、网站和论坛的流行程度来编写的。

·Deeplearning4j

d5a610c96b35ad4687d75c8388385074895f8432 

这个机器学习库是专门为Java设计的,它是为开发深度学习算法提供了广泛支持的计算机框架。当涉及到机器学习领域时,Deeplearning4j被认为是Java的最杰出的贡献者之一,它是一个开源的深度学习库,为各种商业环境同时带来深度神经网络和强化深度学习。它通常还可以作为Java的DIY工具,而且还具有应对所有那些无限制的虚拟并发任务的能力。
另外,该库对于识别语音、文字和声音中的情绪和模式是很有帮助的。它也可以用于发现时间序列数据中的异常,如财务数据,都清楚地表明它可以用于实际的商业场景而不是单纯作为一个研究工具。

·ELKI

7bb45e858dd4aff9e17be8a705704ac9ab2368c4 

ELKI代表了开发KDD应用程序的环境,KDD应用是由索引结构支持的,它是另一个由Java开发的用于数据挖掘的开源机器学习库。ELKI是专门为研究人员和学生设计的,它提供了大量的可详细配置的算法参数。

ELKI主要是由正在寻求建立一些相关的数据库的院校研究生使用的,它的目的是开发和评估高级的数据挖掘算法及其与数据库索引结构的合作和交互。使用ELKI的Java开发人员可以使用任意的数据类型、文件格式等等。

·JavaML

a7d985f5a13a20b461223286ea0adebdbb102e0f 

JavaML是一个拥有大量机器学习的和数据挖掘的算法的Java类库,它是由科研工作人员和Java开发者共同开发的。这个库不含有GUI,但它为每个类型的算法提供了清晰的接口。当我们比较JavaML与其它的聚类算法时,就会发现它是非常的简单直接,并且提供给任何新算法的简单实现。更多的情况下,这些算法的实现是需要简单明了的程度代码和添加适当的注释,因此它可以作为一个很好的参考。这个库是用Java开发的。

·JSAT

81c6d31a78b336b03fff2796691f9c1da33ff1f9 

JSAT提供的是Java统计分析工具,是基于Java开发的用于解决机器学习问题的库,它可以在GPL3许可下使用,它的所有源代码都是包含在内的,没有任何外部依赖关系。JSAT拥有一个库中最大的机器学习算法集合,并被认为是运行最快的Java机器学习库之一,提供了高效性和灵活性。该库中的所有机器学习算法都是使用面向对象的框架来实现的。

·MALLET

e209b7c97e43d6baa7531b061df5ea67cd8aa000 

MALLET库是用于机器学习的语言工具包,它是Java源代码的合集,可应用的领域包括统计NLP、主题建模、聚类分析、文档分类和各种其它用于文本的机器学习应用。MALLET也可以被称为用于文本的Java机器学习工具包,它是由马萨诸塞大学和宾夕法尼亚大学的学生开发的,并为那些诸如决策树、朴素贝叶斯和最大熵模型等各种算法提供支持。

·Mahout


092a83a73283a316ef766f5e5e2c00c866846771 

Mahout是一个机器学习框架,带有集成的机器学习算法,能帮助开发人员创建自己的算法实现程序。Mahout还是一个代数相关的框架,被设计用来帮助数据科学工作者、数学工作者和分析人员运行自己的算法。这个机器学习库是可扩展的,并提供了丰富的组件集,允许你开发一个适用于各种机器学习算法的定制推荐系统。Mahout提供了高性能、灵活性和可扩展性,同时也是为商业化用途所设计的。

·Weka

052bb74f3ffc96716b412f8409f5d9c71f9e23ef 

Weka是另一个非常流行的基于Java的机器学习库,可以用于数据挖掘和数据分析工作,其中可以将算法直接应用到一个数据集,或者使用Java源代码自己创建新的算法。这个Java库包含了许多的工具,如:回归、聚类、分类和可视化等等。该库不仅是免费的,而且还便于使用,支持特征选择、异常检测、时间序列预测等等。Weka的全称是怀卡托智能分析环境(Waikato Environment for Knowledge Analysis),它可以被定义为用于预测建模和数据分析以及图形用户界面(GUI)的算法和工具的集合。

结论

在过去的几年中,机器学习领域有了新的趋势。事实上,上述大多数的库都是开源的,这就意味着开发者可以很容易地掌握机器学习的开发能力和获取到相关的技术信息,并且所有的开发者都必须得考虑利用这些库都可以做些什么。基于Java的机器学习技术将彻底改变应用程序的工作模式。

 

数十款阿里云产品限时折扣中,赶紧点击领劵开始云上实践吧!

本文由北邮@爱可可-爱生活 老师推荐,阿里云云栖社区组织翻译。

文章原标题《Best Machine Learning Libraries For Java Development》

作者:Mantra Malhotra

译者:奥特曼,审校:袁虎。

文章为简译,更为详细的内容,请查看原文

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
杭电2037java实现
输入数据包含多个测试实例,每个测试实例的第一行只有一个整数n(n<=100),表示你喜欢看的节目的总数,然后是n行数据,每行包括两个数据Ti_s,Ti_e (1<=i<=n),分别表示第i个节目的开始和结束时间,为了简化问题,每个时间都用一个正整数表示。n=0表示输入结束,不做处理。
11 0
杭电2062java实现
考虑总= { 1,2,…,n }。例如,A1 = { 1 },A3 = { 1,2,3 }。子集序列被定义为非空子集的数组。对词典编纂顺序中的所有子集进行排序。你的任务是找到第m个。
40 0
杭电1789贪心java实现
伊格内修斯有很多功课要做。每个老师都会给他一个交作业的截止日期。如果在截止日期之后提交作业,老师会减少他的最终考试成绩。现在我们假设每个人做功课都需要一天的时间。所以希望你帮助他安排作业的次序,以尽量减少分数。
20 0
软件测试面试题:java+Selenium实现截屏的操作?
软件测试面试题:java+Selenium实现截屏的操作?
8 0
Rhino -- 基于java的javascript实现
这几天突然对js引擎非常感兴趣,大概了解了一下,记下来备忘。javascript引擎大家比较熟悉的应该是当前比较火的Chrome V8引擎。以快速闻名。v8基于c++开发。这里就不多阐述了。另外一个是 基于java的Rhino引擎,这个想来大家不是很了解。
1873 0
一起谈.NET技术,JAVA与.NET的相互调用——通过Web服务实现相互调用
  JAVA与.NET是现今世界竞争激烈的两大开发媒体,两者语言有很多相似的地方。而在很多大型的开发项目里面,往往需要使用两种语言进行集成开发。而很多的开发人员都会偏向于其中一种语言,在使用集成开发的时候对另一种语言感觉到畏惧。
882 0
JAVA与.NET“.NET技术”的相互调用——通过Web服务实现相互调用
  JAVA与.NET是现今世界竞争激烈的两大开发媒体,两者语言有很多相似的地方。而在很多大型的开发项目里面,往往需要使用两种语言进行集成开发。而很多的开发人员都会偏向于其中一种语言,在使用集成开发的时候对另一种语言感觉到畏惧。
781 0
JAVA与.NET的相互调用——通过Web服务实现“.NET研究”相互调用
  JAVA与.NET是现今世界竞争激烈的两大开发媒体,两者语言有很多相似的地方。而在很多大型的开发项目里面,往往需要使用两种语言进行集成开发。而很多的开发人员都会偏向于其中一种语言,在使用集成开发的时候对另一种语言感觉到畏惧。
813 0
+关注
【方向】
欢迎各位对内容方向及质量提需求,我们尽量满足,将国外优质的内容呈现给大家!
文章
问答
文章排行榜
最热
最新
相关电子书
更多
从《阿里巴巴Java开发手册》编写推广谈技术成长
立即下载
云栖专家带你技术进阶之理解Java内存管理机制
立即下载
Java工程师必读手册
立即下载