暴风中文 通过搜索各大小说站为您自动抓取各类小说的最快更新供您阅读!

随后,江寒操作着电脑,心无旁骛,很快就进入了状态。

夏雨菲也不再来打扰他,拿着手机,半躺在床上,自己上网、听歌。

江寒将高老师发送来的part012.rar和part013.rar下载下来,连同夏雨菲下载的前11个文件,放在了同一个文件夹中。

然后在第1个文件上点击鼠标右键,选择用WinRAR解压缩,很快就得到了数据包。

一共两个文件,train-images-idx3-ubyte与train-labels-idx1-ubyte。

idx3-ubyte和idx1-ubyte都是自定义的文件格式,官网上就有格式说明。

train-images文件大小超过1g,保存了20万张手写数字的图片信息。

而train-labels中则存储了20万个标签数据,与train-images一一对应。

和公开版本的MNIST不同,用于比赛的这个手写数字数据集,数据量要大出好几倍。

Kaggle官方将数据集分为两部分,训练集train向参赛选手公开,而测试集test则内部保存。

比赛的形式很简单,大家根据公开的训练集,编写自己的程序,提交给主办方。

主办方用不公开的测试集数据,对这些程序逐一进行测试,然后比较它们在测试集上的表现。

主要指标是识别率,次要指标是识别速度等。

这是“人工神经网络”在这类竞技场上的初次亮相,江寒可不想铩羽而归。

事实上,如果想追求更好的成绩,最好的办法,就是弄出卷积神经网络(CNN)来。

那玩意是图像识别算法的大杀器。

在“机器学习”这个江湖中,CNN的威力和地位,就相当于武侠世界中的倚天剑、屠龙刀。

CNN一出,谁与争锋!

只可惜,这个东西江寒现在还没研究出来。

现上轿现扎耳朵眼,也来不及了。

再说,饭要一口口吃,搞研究也得一步步来。

跨度不能太大喽,免得扯到蛋……

所以在这次比赛中,江寒最多只能祭出“带隐藏层的全连接神经网络”(FCN)。

有了这个限制,就好比戴着镣铐跳舞,给比赛平添了不少难度和变数。

那些发展了几十年的优秀算法,也不见得会输普通的FCN多少。

所以,现在妄言冠军十拿九稳,还有点为时过早。

不过,有挑战才更有趣味性嘛,稳赢的战斗打起来有什么意思呢?

江寒根据官网上找到的数据格式说明文档,编写了一个文件解析函数,用来从两个train文件中提取数据。

train-images-idx3-ubyte的格式挺简单的,从文件头部连续读取4个32位整形数据,就能得到4个参数。

用来标识文件类型的魔数m、图片数量n、每张图片的高度h和宽度w。

从偏移0016开始,保存的都是图片的像素数据。

颜色深度是8位,取值范围0~255,代表着256级灰度信息,每个像素用一个字节来保存。

然后,从文件头中可以得知,每张图片的分辨率都是28×28。

这样每张图片就需要784个字节来存储。

很容易就能计算出每张图片的起始地址,从而实现随机读取。

如果连续读取,那就更简单了,只需要每次读取784个字节,一共读取n次,就能恰好读取完整个文件。

需要注意的是,图像数据的像素值,在文件中存储类型为unsignedchar型,对应的format格式为B。

所以在Python程序中,在image_size(取值为784)这个参数的后面,还要加上B参数,这样才能读取一整张图片的全部像素。

如果忘了加B,则只能读取一个像素……

train-labels-idx1-ubyte格式更加简单。

前8个字节是两个32位整形,分别保存了魔数和图片数量,从偏移0009开始,就是unsignedbyte类型的标签数据了。

每个字节保存一张图片的标签,取值范围0~9。

江寒很快就将标签数据也解析了出来。

接下来,用Matplot的绘图功能,将读取出来的手写数字图片,绘制到屏幕上。

然后再将对应的标签数据,也打印到输出窗口,两者一比较,就能很轻松地检验解析函数是否有问题。

将解析函数调试通过后,就可以继续往下进行了。

首先要将图片的像素信息压缩一下,二值化或者归一化,以提高运算速度,节省存贮空间。

像素原本的取值范围是0~255。

二值化就是将大于阈值(通常设为中间值127)的数值看做1,否则看做0,这样图片数据就转换成了由0或者1组成的阵列。

归一化也比较简单,只需要将每个像素的取值除以最大值255,那么每个像素的取值空间,就变成了介于0和1之间的浮点数。

两种手段各有利弊,江寒决定每种都试一下,看看在实践中,哪个表现更好一些。

由于江寒使用的是全连接网络,而不是卷积神经网络,所以还要将2维的图片,转换成1维的向量。

这个步骤非常简单,将二维的图片像素信息,一行接一行按顺序存入一维数组就行。

事实上,在解析数据文件的时候,已经顺便完成了这一步,所以并不需要额外的操作。

20万张图片,就是20万行数据。

将这些数据按顺序放入一个×784的二维数组里,就得到了Feature。

Lable的处理比较简单,定义一个具有20万个元素的一维整形数组,按顺序读入即可。

江寒根据这次的任务需求,将20万条训练数据划分成了2类。

随机挑选了18万个数据,作为训练集,剩余2万个数据,则作为验证集validate。

这样一来,就可以先用训练集训练神经网络,学习算法,然后再用未学习过的验证集进行测试。

根据FCN网络在陌生数据上的表现,就能大体推断出提交给主办方后,在真正的测试集上的表现。

写完数据文件解析函数,接下来,就可以构建“带隐藏层的全连接人工神经网络”FCN了。

类似的程序,江寒当初为了写论文,编写过许多次。

可这一次有所不同。

这是真正的实战,必须将理论上的性能优势,转化为实实在在、有说服力的成绩。

因此必须认真一些。

打造一个神经网络,首先需要确定模型的拓扑结构。

输入层有多少个神经元?

输出层有多少个神经元?

设置多少个隐藏层?

每个隐藏层容纳多少个神经元?

这都是在初始设计阶段,就要确定的问题。

放在MNIST数据集上,输入层毫无疑问,应该与每张图片的大小相同。

也就是说,一共有784个输入神经元,每个神经元负责读取一个像素的取值。

输出层的神经元个数,一般应该与输出结果的分类数相同。

数字手写识别,是一个10分类任务,共有10种不同的输出,因此,输出层就应该拥有10个神经元。

当输出层的某个神经元被激活时,就代表图片被识别为其所代表的数字。

这里一般用softmax函数实现多分类。

先把来自上一层的输入,映射为0~1之间的实数,进行归一化处理,保证多分类的概率之和刚好为1。

然后用softmax分别计算10个数字的概率,选择其中最大的一个,激活对应的神经元,完成整个网络的输出。

至于隐藏层的数量,以及其中包含的神经元数目,并没有什么一定的规范,完全可以随意设置。

隐藏层越多,模型的学习能力和表现力就越强,但也更加容易产生过拟合。

所以需要权衡利弊,选取一个最优的方案。

起步阶段,暂时先设定一个隐藏层,其中包含100个神经元,然后在实践中,根据反馈效果慢慢调整……

确定了网络的拓扑结构后,接下来就可以编写代码并调试了。

调试通过,就加载数据集,进行训练,最后用训练好的网络,进行预测。

就是这么一个过程。

江寒先写了一个标准的FCN模板,让其能利用训练数据集,进行基本的训练。

理论上来说,可以将18万条数据,整体放进网络中进行训练。

但这种做法有很多缺点。

一来消耗内存太多,二来运算压力很大,训练起来速度极慢。

要想避免这些问题,就要采取一定的策略。

暴风中文推荐阅读:反腐风云之收官之战重生之权臣的掌中娇和亲公主之冷霸汗王的心尖宠大梦我仙诀食香离谱!谁家召唤师开局召唤龙王总裁大人,V587!我的老爹是重生花神不花小王公锦鲤少女逃荒种田二十五岁才激活神豪系统?开局被富婆包围,校花:那我走?让你扮演胡桃,你把全网当客户?七公子1腹黑老公,严肃点!女主请自重,我真的只想刷奖励啊火葬场奇谈小时候救的校花,长大后她倒追我蛇蝎毒妃:本宫不下嫁换嫁八零:新婚夜队长起来洗床单暴君爹爹的团宠小娇包灾难艺术家溺宠俏妻:傲娇总裁狠狠爱全民女神:重生腹黑千金穿成恶毒后娘后她带崽野翻了!渣男系统:在恋爱游戏里大放异彩替嫁神医:腹黑世子,甩不掉带一帮靓妞去修仙我官场崛起,退婚的女友开始倒追黄金庭院:从灵开始的现世生活不凡法师都市魔神:渡劫失败,夺舍重修娱乐圈最强替补工厂里的夫妻都市之神帝驾到重生了,此时不浪何时浪邻居是热芭?我有个大胆的想法!欺骗世界,我打造了现代超凡文明妻子背叛:摇身一变成太子至高使命分身强度拉满,我杀穿高武世界修真三千年,校花竟是我老婆嫡女虐渣手册国庆回家多了个姐姐大小姐失忆后,前任纷纷回头了阿姨,你也不想这事被孩子知道吧重生之我只想做个贪财好色的俗人重生1978:我的媳妇是女知青妖女满堂?明明是仙子忠诚!天师莫十七重生77:一根鱼竿开启财富人生
暴风中文搜藏榜:我成了五个大佬的白月光舞动娱乐圈夺梦九帝斩天诀直上青云:从高考落榜开始蜜宠娇妻:BOSS夫人拽又甜每天一个战神技能华枝春满隋末扬旌都市修真:无敌杀伐开局操作蝙蝠侠重生60年代开始奋斗盛宠娇妻理论上可行东京大律师:开局律所破产苟不住的空间主豪门盛宠:司少,轻宠混世龙医这趟穿越有点险美女校花的全能保镖勒少的心尖萌妻婚后交锋之辣妻难驯重生87退婚后,前妻一家急疯了嫡女凶猛都市极品小仙医风水:姐,我不想努力了入狱成为天机神算,国家请我出山冥公子濒死病人,一首大不为震惊全网穿成男神电脑怎么破现代都市的鉴宝王者农门旺女:皇后,快来给朕抱抱!不敢在群里喊老婆,怕她们全回话重活之逍遥大明星重生空间之媳妇逆袭挂机修炼的我不敢躺平风雨兼程度十年从四合院开始的操蛋人生恶魔99次蜜吻:老公,宠太猛透视神医女婿天才萌宝,妈咪一个亿龙影战神:王者归来爱上女处长:一念翻身原神之古雨魔神我重生断绝关系,你们还没完了都市之绝世高手穿书后病娇暴君只在我怀里撒娇娇拍卖缅北噶腰团伙,警察关注我重生后我成了地产大亨群众官念
暴风中文最新小说:民国恶女求生游戏苟分日常七零:娇气包大小姐随军闹翻天六零娇娇作精,糙汉老公带我躺赢前夫处处护青梅,重生改嫁他疯了被换命格后,玄门大佬杀疯了撩倒五个男主后,娇美寡妇跑路了刚大一就与女神老师被强制结婚逃荒有空间,嫁绝嗣糙汉一胎多宝守寡后,我逼疯了满朝文武去种田八零:换嫁小渔村,我成全家团宠重生八零小豆丁,手握空间聊天群SSSSSSSSSSSSSS满级神医清穿:救命!太子妃她又在揍人啦锦鲤崽崽穿六零,捡来爹娘宠上天拒绝SSS级天赋被封杀,我成唯一真神凤隐锦杀被抄家流放,飒爽嫡女在边关盖大楼!渣男兼祧吃绝户?改嫁皇叔他急了我的暴君系统天天想噶我老公炽吻失氧侧妃进门我让位,死遁了你疯什么雾色迷津和权臣一夜共感后,我女儿身暴露SSSSSSSSSS级狂龙出狱八零随军:大小姐认错老公被亲哭我是废雌?可哥哥们是大佬六零换嫁,大小姐随军西北赢麻了醉染赤水桃花劫引朱鸾沪上大小姐下乡,闪婚糙汉被宠哭夫君沉迷造反,却有四个忠臣崽崽市井娇厨离婚后,我权势滔天,你哭什么腰软娇娇超会撩,禁欲世子沦陷了都当女帝了,后宫三千很合理吧?狂龙战枭京夜娇宠情劫黑月光她专克病娇乡村花香领证爽约?我转嫁你哥哭什么弹幕剧透,婉拒男模抱紧老公大腿八十岁老太勇闯娇宠虐文回京认亲被嫌,听劝换爹后成团宠无人区:开局肉身点满被流放后,五岁奶团带全家致富灵事录穿书当小妾:炮灰女配选择躺赢绑定预知梦,我靠演戏救偏执对头