Keras 从零开始构建深度神经网络

本文介绍了Keras作为深度学习框架的基础,包括神经网络的预备知识,如感知器、线性代数在神经网络中的应用,以及深度神经网络的概念。通过实例展示了如何使用Keras的序列化模型和函数式API创建简单的深度神经网络模型。
摘要由CSDN通过智能技术生成

Keras 是一个用于定义和训练神经网络的高阶API。简单的说,Keras 是对 TensorFlow 等深度学习框架的更高一层的封装,以提供更加优雅,用户友好的接口设计。因此,Keras 不能独立运行,需要底层框架的支持,这个底层框架可以是 TensorFlow, CNTK, Theano。推荐使用 TensorFlow , 本文也是以 TensorFlow 为例。

1. 预备知识

1.1 什么是神经网络?

在人工智能领域,通常所说的“神经网络”,完整说法应该是“人工神经网络”。它是人类为了使机器具备人类的智力行为,使用计算机算法模拟人类神经系统,开发的一种机器学习技术。人类的神经系统是由一个个神经元彼此相连,构成的复杂网络系统。

下图是大脑神经元结构,神经元从它的多个树突(DENDRITES)接收输入(神经冲动),经过处理,判断是否通过轴突(AXON)输出神经冲动。

1.2 感知器 Perceptron

正如神经元是构成大脑神经系统的基本单元,感知器(Perceptron)是构人工神经网络的基本单元。它接收多个输入( x 1 , x 2 , … , x n x_1, x_2, \ldots, x_n x1,x2,,xn),通过线性函数和激活函数(Step Function 是激活函数的一种),得到输出 y ^ \hat{y} y^

线性函数:

f ( x ) = W x + b f(x) = \mathbf{W}\mathbf{x} + b f(x)=Wx+b

其中, W \mathbf{W} W x \mathbf{x} x 为向量, W = ( w 1 , w 2 , … , w n ) \mathbf{W}=(w_1, w_2, \ldots, w_n) W=(w1,w2,,wn), x = ( x 1 , x 2 , … , x n ) \mathbf{x}=(x_1, x_2, \ldots, x_n) x=(x1,x2,,x

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值