逻辑回归实现多分类任务(python+TensorFlow+mnist)

逻辑回归实现多分类任务(python+TensorFlow+mnist)

       逻辑回归是统计学中的一种经典方法,虽然叫回归,但在机器学习领域,逻辑回归通常情况下当成一个分类任务,softmax就是由其演变而来,逻辑回归一般用于二分类任务,但通过softmax可以轻易的扩展至多分类任务。

下面的程序,通过逻辑回归实现对手写数字的分类:

  • 环境:python3.6、TensorFlow框架
  • 数据集:MNIST
# 逻辑回归实现手写数字分类
import tensorflow as tf
from tensorflow.examples.tutorials.mnist import input_data
import numpy as np
import matplotlib.pyplot as pltmnist = input_data.read_data_sets('D:\MNIST_data', one_hot=True)x = tf.placeholder(tf.float32, [None, 784])
y = tf.placeholder(tf.float32, [None, 10])
W = tf.Variable(tf.zeros([784, 10]), tf.float32)
b = tf.Variable(tf.zeros([10]), tf.float32)
pre = tf.nn.softmax(tf.matmul(x, W) + b)
# cost function
cost = tf.reduce_mean(tf.reduce_sum(-y*tf.log(pre), reduction_indices=1))
train = tf.train.GradientDescentOptimizer(0.01).minimize(cost)
pred = tf.equal(tf.argmax(y, 1), tf.argmax(pre, 1))
# accuracy
acc = tf.reduce_mean(tf.cast(pred, tf.float32))# initializer
init = tf.global_variables_initializer()
batch_size = 100
display_step = 5
step = 100
with tf.Session() as sess:sess.run(init)num_batch = int(mnist.train.num_examples/batch_size)for i in range(step):for j in range(num_batch):batch_xs, batch_ys = mnist.train.next_batch(100)sess.run(train, feed_dict={x: batch_xs, y: batch_ys})if i % display_step == 0:train_acc = sess.run(acc, feed_dict={x: batch_xs, y: batch_ys})test_acc = sess.run(acc, feed_dict={x: mnist.test.images, y: mnist.test.labels})print('Train accuracy:%2f'% train_acc, '  Test accuracy:%2f' % test_acc)

训练100次之后的测试精度为:

Train accuracy:0.940000 Test accuracy:0.921500

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/490682.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

物理哲学和生物哲学的对抗

来源:科学技术哲学相对论革命在上一讲中,我们提到第二次科学革命始于18世纪后期的化学革命,它的两大标志是:1. 近代西方科学的古典科学传统和培根科学传统融合,西方科学现代化;2. 科学和技术结合&#xff0…

pytorch将label转为one hot形式

label_one_hot torch.nn.functional.one_hot(labels, self.num_classes).float().to(self.device) https://pytorch.org/docs/stable/nn.functional.html#torch.nn.functional.one_hot

输入相关函数

1、cin>> &#xff08;1&#xff09;用法一&#xff1a;输入一个数字 #include using namespace std; main () { int a,b; cin>>a>>b; cout<<ab<<endl; } 输入&#xff1a; 2[回车]3[回车] 输出&#xff1a; 5 &#xff08;2&#xf…

cpu开核_新锐龙让AMD重返巅峰,但逆袭的50年里这些CPU也不应忘记

AMD从成立至今无疑有着许多神奇的经历&#xff0c;比如其创始人一开始只能艰难地筹集到5000美元创业&#xff0c;到如今AMD成为一家年营业额达到65亿美元的公司&#xff0c;这位创始人创始人杰里.桑德斯也赋予了AMD永不放弃&#xff0c;永不投降的精神。曾有过无比辉煌的历史&a…

二隐层的神经网络实现MNIST数据集分类

二隐层的神经网络实现MNIST数据集分类 传统的人工神经网络包含三部分&#xff0c;输入层、隐藏层和输出层。对于一个神经网络模型的确定需要考虑以下几个方面&#xff1a; 隐藏层的层数以及各层的神经元数量各层激活函数的选择输入层输入数据的shape输出层神经元的数量以上神经…

Android之SurfaceView

SurfaceView也是继承了View&#xff0c;但是我们并不需要去实现它的draw方法来绘制自己&#xff0c;为什么呢&#xff1f; 因为它和View有一个很大的区别&#xff0c;View在UI线程去更新自己&#xff1b;而SurfaceView则在一个子线程中去更新自己&#xff1b;这也显示出了它的…

MATLAB画图设置线条透明度

plot1 plot(x,y); plot1.Color(4) 0.5; 调节Color(4)这个参数可以设置不同的透明度

日韩决裂,半导体谁最受伤?

来源&#xff1a; 半导体行业观察日本政府于7月1日公布&#xff0c;要加强对韩国的出口管理&#xff0c;7月4日发起了“氟化聚酰亚胺&#xff08;Polymide&#xff09;”、“EUV Resist&#xff08;光阻剂&#xff09;”、“氟化氢”三种半导体材料的出口限制。根据此次出口限制…

验证码随机生成

验证码随机生成 这里主要使用到的库是captcha库&#xff0c;下载的命令如下&#xff1a; pip install captcha 验证码随机生成代码&#xff0c;(python 版本&#xff1a;3.6 captcha 版本&#xff1a;0.3) from captcha.image import ImageCaptcha import numpy as np …

oracle的基本数据类型(转载)

数据类型是在设计表结构中需要定义的&#xff0c;选择适当的数据类型可以节省存储空间&#xff0c;提高运算效率。 Oracle数据类型主要包括 1.字符型 适合保存字符串类型的数据&#xff0c;如姓名、地址、简介等等。 如&#xff1a;char(2000),nchar(2000),varchar(4000),nvarc…

台式电脑麦克风_还有人买台式PC吗?这份新品推荐攻略值得收藏

【科技犬】新品一&#xff0c;联想发布新款天逸510S台式机联想现已推出天逸 510S 小型主机&#xff0c;搭载了英特尔最新的十代酷睿处理器 i5-10400&#xff0c;8GB 内存 512GB SSD 售价 3499 元。联想新款天逸 510S 将于 7 月 23 日开卖&#xff0c;适合企业办公用户使用。天…

MATLAB将两条曲线画在同一个图上

在MATLAB中将两条曲线画在同一个图上&#xff0c;如果直接采用下面的代码&#xff0c;那么画的第二个图会将第一个图覆盖 plot(x,p1,LineWidth,2); plot(x,p2,LineWidth,2); 正确的做法是在两条语句中间添加hold on; plot(x,p1,LineWidth,2); hold on; plot(x,p2,LineWidth,…

天基物联,毫瓦服务,商业航天撬动万亿市场

来源&#xff1a; 卫星与网络2019年8月17日12时11分&#xff0c;酒泉卫星发射中心&#xff0c;北京国电高科科技有限公司&#xff08;以下简称“国电高科”&#xff09;研制的天启沧州号&#xff08;又名“忻中一号”&#xff09;卫星由首次发射的捷龙一号商业火箭成功送入太空…

GitHub如何上传超过100MB的文件

GitHub如何上传超过100MB的文件 平时在GitHub上上传项目文件时&#xff0c;遇到比较大的文件&#xff0c;就会出现无法上传的情况&#xff1a; this exceeds GitHubs file size limit of 100.00 MB 解决方法如下&#xff1a; 在所要上传文件的目录下打开Git 首先&#xff0c;…

python的matplotlib生成colorbar

当有些画图的库不能生成colorbar时&#xff0c;需要手动生成colorbar&#xff1a;plt.colorbar(h)&#xff0c;h为图的句柄 举个例子&#xff0c;mne.viz.plot_topomap函数不支持显示colorbar&#xff0c;因此需要通过matplotlib库来先设置colorbar再显示 im, cn mne.viz.pl…

学好基础,展翅飞翔

1 学习的东东 学习java基础&#xff0c;java虚拟机知识&#xff0c;计算机操作系统&#xff0c;计算机网络&#xff0c;数据结构和算法&#xff0c;Android基础。 然后Android项目实践。 锻炼好身体&#xff0c;注意养身&#xff0c;毕竟是革命的本钱。 锻炼好情商&#xff0c;…

电脑出货量_Q3季度全球笔记本电脑出货量增长34%,惠普出货量首次超过联想

相关推荐将联想拯救者电竞手机Pro关机&#xff0c;取出卡托&#xff0c;卡托上并没有硅胶圈。手机后盖与内支撑通过胶固定&#xff0c;热风枪加热....我快闭嘴 发表于11-17 16:40 •48次 阅读 联想来酷B2411/H产品出发点其实很简单&#xff0c;这款产品并不是为那些追求新奇&am…

人的智商到底有多高?

图片来源&#xff1a;verywell.com来源&#xff1a;生物谷人的智商到底有多高&#xff1f;来自慕尼黑大学的Markus Buhner教授表示&#xff0c;其实日常生活中我们认为的很多事实实际上或许都是误解&#xff0c;这里&#xff0c;研究人员对8种陈词滥调的有效性证据进行了权衡分…

解决问题:Couldn't open file: data/coco.names

错误&#xff1a;Couldn’t open file: data/coco.names darknet GitHub&#xff1a;https://github.com/pjreddie/darknet YOLO官网&#xff1a;https://pjreddie.com/darknet/yolo/ 在进行yolo效果测试时&#xff0c;出现了该错误。通过如下命令下载darknet&#xff1a; git…

1766 装果子

传送门 #include<cstdio> #define N 110000 long long n,m,sum0,ans,max0; long long a[N]; void find(long long l,long long r) {if (l>r) return;long long mid(lr)/2,s0,k0;for (int i1;i<n;i){sa[i];if (s>mid) k,sa[i];}if (s) k;if (k>m) find(mid1,r…