Python实现的卷积神经网络算法

卷积神经网络 1 算法介绍 2 实验代码 3 实验结果 4 实验总结 1 算法介绍 卷积神经网络(Convolutional Neural Network

本文包含相关资料包-----> 点击直达获取<-------

卷积神经网络

1 算法介绍

卷积神经网络(Convolutional Neural Network, CNN)是一种前馈神经网络,它的人工神经元可以响应一部分覆盖范围内的周围单元,对于大型图像处理有出色表现。卷积神经网络由一个或多个卷积层和顶端的全连通层(对应经典的神经网络)组成,同时也包括关联权重和池化层(pooling layer)。这一结构使得卷积神经网络能够利用输入数据的二维结构。

卷积神经网络中比较重要的一个概念是卷积操作,如下图所示,根据 learned weights 将若干块映射到一个新的矩阵上。

其实卷积操作并不陌生,在日常生活中 p 图时就经常会用到,例如对图片的锐化、模糊等操作,就是用一个特定的矩阵(图中的 learned weights 矩阵)对原图像进行卷积操作。下图就是一张图片卷积后的样子。

不难看出卷积操作后图片会变小,经过若干次的操作(相当于隐藏层),最后输出一个和上面介绍 BP 神经网络时一样的具有 10 个元素的向量,分别代表是某个数字的概率。如下图

不断优化中间参数的值,利用梯度下降或其他优化方法,就可以完成模型的训练。

2 实验代码

```python

下载、导入数据用到的函数包

import input_data

读取数据

mnist = input_data.read_data_sets('MNIST_data', one_hot=True)

tensorflow 2.x没有placeholder所以要用1.x的API

import tensorflow.compat.v1 as tf tf.disable_v2_behavior()

sess = tf.InteractiveSession()

我们在TensorFlow运行计算时输入这个值。我们希望能够输入任意数量的MNIST图像,每一张图展平成784维的向量。

x = tf.placeholder("float", shape=[None, 784])

为了计算交叉熵,我们首先需要添加一个新的占位符用于输入正确值

y_ = tf.placeholder("float", shape=[None, 10])

W的维度是[784,10],因为我们想要用784维的图片向量乘以它以得到一个10维的证据值向量

W = tf.Variable(tf.zeros([784,10]))

b的形状是[10],所以我们可以直接把它加到输出上面

b = tf.Variable(tf.zeros([10]))

初始化

sess.run(tf.initialize_all_variables())

计算每个分类的softmax概率值

y = tf.nn.softmax(tf.matmul(x,W) + b)

损失函数是目标类别和预测类别之间的交叉熵。

cross_entropy = -tf.reduce_sum(y_*tf.log(y))

用最速下降法让交叉熵下降,步长为0.01

train_step = tf.train.GradientDescentOptimizer(0.01).minimize(cross_entropy)

整个模型的训练可以通过反复地运行train_step来完成

for i in range(1000): batch = mnist.train.next_batch(50) train_step.run(feed_dict={x: batch[0], y_: batch[1]})

评估模型

correct_prediction = tf.equal(tf.argmax(y,1), tf.argmax(y_,1)) accuracy = tf.reduce_mean(tf.cast(correct_prediction, "float")) print (accuracy.eval(feed_dict={x: mnist.test.images, y_: mnist.test.labels}))

上面的代码是应用BP神经网络

下面将构建一个多层卷积网络

权重初始化

def weight_variable(shape): initial = tf.truncated_normal(shape, stddev=0.1) return tf.Variable(initial)

def bias_variable(shape): initial = tf.constant(0.1, shape=shape) return tf.Variable(initial)

卷积和池化

def conv2d(x, W): return tf.nn.conv2d(x, W, strides=[1, 1, 1, 1], padding='SAME')

def max_pool_2x2(x): return tf.nn.max_pool(x, ksize=[1, 2, 2, 1], strides=[1, 2, 2, 1], padding='SAME')

第一层卷积

W_conv1 = weight_variable([5, 5, 1, 32]) b_conv1 = bias_variable([32])

x_image = tf.reshape(x, [-1,28,28,1])

h_conv1 = tf.nn.relu(conv2d(x_image, W_conv1) + b_conv1) h_pool1 = max_pool_2x2(h_conv1)

第二层卷积

W_conv2 = weight_variable([5, 5, 32, 64]) b_conv2 = bias_variable([64])

h_conv2 = tf.nn.relu(conv2d(h_pool1, W_conv2) + b_conv2) h_pool2 = max_pool_2x2(h_conv2)

密集连接层

W_fc1 = weight_variable([7 * 7 * 64, 1024]) b_fc1 = bias_variable([1024])

h_pool2_flat = tf.reshape(h_pool2, [-1, 7 7 64]) h_fc1 = tf.nn.relu(tf.matmul(h_pool2_flat, W_fc1) + b_fc1)

Dropout

keep_prob = tf.placeholder("float") h_fc1_drop = tf.nn.dropout(h_fc1, keep_prob)

输出层

W_fc2 = weight_variable([1024, 10]) b_fc2 = bias_variable([10])

y_conv=tf.nn.softmax(tf.matmul(h_fc1_drop, W_fc2) + b_fc2)

训练和评估模型

cross_entropy = -tf.reduce_sum(y_*tf.log(y_conv)) train_step = tf.train.AdamOptimizer(1e-4).minimize(cross_entropy) correct_prediction = tf.equal(tf.argmax(y_conv,1), tf.argmax(y_,1)) accuracy = tf.reduce_mean(tf.cast(correct_prediction, "float")) sess.run(tf.initialize_all_variables()) for i in range(20000): batch = mnist.train.next_batch(50) if i%100 == 0: train_accuracy = accuracy.eval(feed_dict={ x:batch[0], y_: batch[1], keep_prob: 1.0}) print ("step %d, training accuracy %g"%(i, train_accuracy)) train_step.run(feed_dict={x: batch[0], y_: batch[1], keep_prob: 0.5})

print ("test accuracy %g"%accuracy.eval(feed_dict={ x: mnist.test.images, y_: mnist.test.labels, keep_prob: 1.0})) ```

3 实验结果

可以看出使用卷积神经网络训练的准确率要比 BP 神经网络高。

4 实验总结

1、我们看到一个的东西时,其实眼睛并没有注意到整个物体,而是把注意力集中在一小部分。比如说我们看到一个人时,首先注意到的是他的脸。卷积操作就相当于提取图片的特征信息,相当于将计算机的注意力放在图片的某一部分。我们将中间的隐藏层作为图片输出时,看到的东西会很奇怪,虽然我们看不懂,但这些相当于计算机对这张图片的一种抽象认识。

2、完成本篇实验报告后对卷积神经网络有了初步的认识。但对其中的激励层、池化层等概念还没有深入彻底的理解,只是模糊的知道大概是干什么的,对深度学习中的数学原理也没有很透彻的理解,还需要今后不断地学习。

参考文献

  • 基于用户长期偏好建模的推荐系统研究(吉林大学·邢哲哲)
  • 基于WEB技术的考试系统的研究与实现(电子科技大学·朱莹)
  • 基于图神经网络的TopN推荐算法的研究(哈尔滨理工大学·吕衍河)
  • 面向特定网页的Web爬虫的设计与实现(吉林大学·马慧)
  • 基于用户长期偏好建模的推荐系统研究(吉林大学·邢哲哲)
  • 基于深度学习的个性化推荐算法研究(北方工业大学·)
  • 基于深度学习的个性化推荐算法研究(北方工业大学·)
  • 基于深度学习的实体关系抽取技术研究(电子科技大学·王婷玉)
  • 基于遗传算法的智能组卷系统的设计(贵州师范大学·程亚飞)
  • 基于图神经网络表示学习的协同过滤推荐算法研究(江南大学·陆炜)
  • 基于深度学习的智能问答系统的研究与实现(沈阳师范大学·卓越)
  • 基于深度学习的网上书城推荐算法研究(大连交通大学·孙寒末)
  • Web漏洞扫描系统中的智能爬虫技术研究(杭州电子科技大学·黄亮)
  • 基于FPGA的可重构CNN加速器设计(燕山大学·黄文汉)
  • 基于卷积神经网络和协同过滤的图书推荐系统(山西大学·张华洁)

本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:代码小屋 ,原文地址:https://bishedaima.com/yuanma/35866.html

相关推荐

  • Web 模拟终端博客系统

    Web 模拟终端博客系统 前段时间做了一个非常有意思的模拟终端的展示页: http://ursb,me/terminal/ (没有做移动端适配
    2024年05月14日
    4 1 1
  • POI 智能推荐之Python

    基于多源数据融合的 POI 智能推荐 引言 针对交通事故频繁发送的今天需要分析下交通事故发送的原因和造成损失的因素等等, 关键技术方案 [介绍采用的关键技术方法
    2024年05月14日
    5 1 1
  • 基于SSM+layui框架开发酒店管理系统

    SSM-Graduation design(SSM-毕业设计) 一,系统介绍 这是本人2021年的毕业设计(基于SSM+layui框架开发的酒店管理系统)
    2024年05月14日
    9 1 2
  • 基于JavaWeb的个人博客系统

    一:项目介绍 项目名称: 基于JavaWeb的个人博客系统 演示地址: http://111,230,226,158 免密码登录 如有问题联系邮箱:songshuiyang@foxmail
    2024年05月14日
    9 1 1
  • 最小生成树之Python

    最小生成树 一,【实验名称】 最小生成树(可视化实现) 二,【实验原理】 程序基于 Python 实现其中利用了 Tkinter 库作为可视化界面的制作
    2024年05月14日
    1 1 1
  • Java+SSH框架实现论坛系统、javaweb+mysql

    这是一个🔥🔥SSH框架实现论坛系统,javaweb+mysql🔥🔥的项目源码,开发语言Java,开发环境Idea/Eclipse,这个 框架实现论坛系统开发技术栈为SSH项目
    2024年05月23日
    2 1 1
  • 基于SSM实现的云商城购物系统

    基于SSM实现的云商城购物系统 1,项目简介 1,1 背景分析 电子商城的普及,目前,越来越多的商业活动开始迁移到Inter中来进行,这种模式给商家和消费者带来了极大的便利
    2024年05月14日
    22 1 3
  • 海滨学院班级回忆录

    这是一个🔥🔥基于SpringBoot框架的海滨学院班级回忆录设计与实现🔥🔥的项目源码,开发语言Java,框架使用的SpringBoot+vue技术,开发环境Idea/Eclipse
    2024年05月23日
    2 1 2
  • 基于Java+SSH+mysql的实验课程管理系统

    这是一个🔥🔥基于SSH+mysql的实验课程管理系统🔥🔥的项目源码,开发语言Java,开发环境Idea/Eclipse,这个 实验课程管理系统开发技术栈为SSH项目,可以作为毕业设计课程设计作业基于Java+SSH框架+mysql数据库实现一个学生实验课程管理系统
    2024年05月23日
    13 1 2
  • 基于JSP和MySQL的网络图书管理系统

    基于JSP和MySQL的网络图书管理系统 1 开发背景 1,1 系统开发背景与意义 随着互联网的发展,越来越多的高校图书馆开始创建自己的网站,基于互联网的信息服务已经成为现代大学一项不可缺少的内容
    2024年05月14日
    8 1 4

发表回复

登录后才能评论