文档章节

Java分布式神经网络库Deeplearning4j 环境搭建和运行一个例子

小帅帅丶
 小帅帅丶
发布于 2017/08/21 11:47
字数 1110
阅读 2838
收藏 63

DeeplearningforJava简单介绍:

deeplearning4j是一个Apache 2.0-licensed,开源的,分布式神经网络库编写的java和Scala。

主要模块:

datavec(数据载体)

用于将图像、文本和CSV数据转换成适合于深入学习的格式的库

nn(结构) 神经网络结构设计的核心神经网络结构多层网络和计算图
core 附加的功能建立在deeplearning4j NN
modelimport (模型导入) 加入Keras框架功能
nlp(自然语言处理) 包括vectorizers,模型的自然语言处理组件,样本数据集和渲染
scaleout(拓展功能) spark  、parallel-wraper 、aws
ui 可视化界面
  • 准备好jdk环境,maven环境,git环境,开发工具

开发工具 IntelliJ IDEA (建议)或 Eclipse
JDK 1.8 (仅支持64位版本)
MAVEN 最低不低于3.3.1
GIT 最新即可
  • 通过cmd输入git命令下载dl4j-examples项目并进行编译

                 

  • 进入dl4j-examples目录
 cd dl4j-examples/
  • maven编译项目 有可能需要执行多次
mvn clean install
  • 如果需要编译所有的项目。我在百度云上传了一份代码及文件(不包含maven库)
链接: https://pan.baidu.com/s/1bfqiNDfxkX4eUQH7ZpjDPQ 密码: 897e
  • 为了方便测试快速搭建。先注释了CUDA模块的加载。

  • 全部下载完如下图所示。下图是在家里自己的电脑上操作的(家里网速快些)

  • 编译完成导入到Intellij里面-9个截图

  1. 选择导入一个项目                    
  2. 找到项目径                                                                                                   
  3. 下一步默认选项                                                                                             
  4. 选中maven                                                                    
  5. 默认不选中jfx下一步                                                                              
  6. 添加一个JDK                                                                                 
  7. 找到1.8安装目录并选中                                          
  8. 选中项目                                                                                                 
  9. 给一个项目名称 默认即可                                                                           

后来是重新导入最后一步弹出窗可以忽略

运行一个例子看看

官网入门指南:https://deeplearning4j.org/cn/quickstart

示例绘画蒙娜丽莎画像

结束语:

至此搭建dl4j,并跑一个demo完成。开发工具的jdk环境maven环境这里不做配置说明。这个百度经验可以看到很多教程的。入门指南并不难。后续训练自己的人脸检测,NLP,OCR这个就需要大家自己去细心研究了。鄙人也会试着训练相关数据。

个人小程序有关于百度人脸检测和腾讯优图人脸检测的功能,可以扫码看看哦。

Deeplearning4j 例子示例

需要了解的名词:

Precision:精确率

Recall:召回率

Accuracy:准确率

F1 Score:F1分数

计算公式:

precision = TP / (TP + FP)
recall = TP / (TP + FN)
accuracy = (TP + TN) / (TP + FP + TN + FN)
F1 Score = P*R/2(P+R),其中P和R分别为 precision 和 recall

需要知道的TP、FP、TN、FN

- TP,True Positive
- FP,False Positive
- TN,True Negative
- FN,False Negative

大概意思是  真正 假正   真负 假负
例如:
举个简单的二元分类问题 例子:

假设,我们要对某一封邮件做出一个判定,判定这封邮件是垃圾邮件、还是这封邮件不是垃圾邮件?

如果判定是垃圾邮件,那就是做出(Positive)的判定;
如果判定不是垃圾邮件,那就做出(Negative)的判定。

True Positive(TP)意思表示做出Positive的判定,而且判定是正确的。因此,TP的数值表示正确的Positive判定的个数。
同理,False Positive(TP)数值表示错误的Positive判定的个数。
依此,True Negative(TN)数值表示正确的Negative判定个数。
False Negative(FN)数值表示错误的Negative判定个数。
原文链接:http://blog.csdn.net/simplelovecs/article/details/50520602

训练seed不同。精准,准确,召回的分数如下

有可能需要训练数据。不知道怎么找的。在我的百度云下载吧

链接: http://pan.baidu.com/s/1geNrvGn 密码: 8bkw

12345

123

Java分布式神经网络库Deeplearning4j之上手实践手写数字图像识别与模型训练

© 著作权归作者所有

共有 人打赏支持
小帅帅丶
粉丝 478
博文 91
码字总数 115967
作品 2
北京
后端工程师
加载中

评论(1)

tianxia007
tianxia007
666
Java调用Keras、Tensorflow模型

实现python离线训练模型,Java在线预测部署。查看原文 目前深度学习主流使用python训练自己的模型,有非常多的框架提供了能快速搭建神经网络的功能,其中Keras提供了high-level的语法,底层可...

ioiogoo
04/03
0
0
centos7 yum安装java运行环境,初识hadoop

安装java运行环境 1.实验机相关信息: [root@node2 ~]# cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core) [root@node2 ~]# uname -r 3.10.0-327.el7.x86_6 2.配置epel源,以y......

smile68
04/21
0
0
Couchbase之环境搭建 与 基于Java的测试

Couchbase Server (前身是 Membase) 是一个分布式的面向文档的 NoSQL 数据库管理系统,该系统联合了 CouchDB 的简单和可靠以及 Memcached 的高性能。 网上有MongoDB与Couchbase的对比,请参...

EugeneQiu
2013/08/23
0
1
Java程序员必读书单,家族又添新成员

点击关注异步图书,置顶公众号 每天与你分享IT好书 技术干货 职场知识 参与文末话题讨论,每日赠送异步图书。 ——异步小编 有些革命出其不意地吸引了全世界的眼球。Twitter、Linux操作系统和...

异步社区
05/09
0
0
黑马程序员.bobo.DAY.1

C:Program Files (x86)NVIDIA CorporationPhysXCommon;<span style="background:rgb(255,0,0)">%JAVA8HOME%bin;%JAVA8HOME%jrebin;</span>D:oracleproduct10.2.0db_1bin;C:Program Files (x8......

BobbyLou
2015/05/14
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

c语言之内存分配笔记

先看一个数组: short array[5] = {1,2} // 这儿定义的一个int类型的数组,数组第1和第2个元素值是1和2.其余后面默认会给值为0; 或者 short array[] = {1,2};//这儿数组第1和第2个元素,数组...

DannyCoder
47分钟前
0
0
Shell | linux安装包不用选择Y/N的方法

apt-get install -y packageOR echo "y" | sudo apt-get install package

云迹
今天
1
0
Hadoop的大数据生态圈

基于Hadoop的大数据的产品圈 大数据产品的一句话概括 Apache Hadoop: 是Apache开源组织的一个分布式计算开源框架,提供了一个分布式文件系统子项目(HDFS)和支持MapReduce分布式计算的软件架...

zimingforever
今天
4
0
八大包装类型的equals方法

先看其中一个源码 结论:八大包装类型的equals方法都是先判断类型是否相同,不相同则是false,相同则判断值是否相等 注意:包装类型不能直接用==来等值比较,否则编译报错,但是数值的基本类型...

xuklc
今天
2
0
NoSQL , Memcached介绍

什么是NoSQL 非关系型数据库就是NoSQL,关系型数据库代表MySQL 对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很耗...

TaoXu
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部