DL之NN:NN算法(本地数据集50000张训练集图片)进阶优化之三种参数改进,进一步提高手写数字图片识别的准确率


wanfeng
一起吹晚风吧 2022-09-20 11:19:22 50573
分类专栏: 资讯

DL之NN:NN算法(本地数据集50000张训练集图片)进阶优化之三种参数改进,进一步提高手写数字图片识别的准确率

导读
上一篇文章,比较了三种算法实现对手写数字识别,其中,SVM和神经网络算法表现非常好准确率都在90%以上,本文章进一步探讨对神经网络算法优化,进一步提高准确率,通过测试发现,准确率提高了很多。

相关文章
CNN:人工智能之神经网络算法进阶优化,六种不同优化算法实现手写数字识别逐步提高,应用案例自动驾驶之捕捉并识别周围车牌号

 

 

思路设计

首先,改变之一:

先在初始化权重的部分,采取一种更为好的随机初始化方法,我们依旧保持正态分布的均值不变,只对标准差进行改动,

初始化权重改变前,

  1. def large_weight_initializer(self):
  2. self.biases = [np.random.randn(y, 1) for y in self.sizes[1:]]
  3. self.weights = [np.random.randn(y, x) for x, y in zip(self.sizes[:-1], self.sizes[1:])]

初始化权重改变后,

  1. def default_weight_initializer(self):
  2. self.biases = [np.random.randn(y, 1) for y in self.sizes[1:]]
  3. self.weights = [np.random.randn(y, x)/np.sqrt(x) for x, y in zip(self.sizes[:-1], self.sizes[1:])]

改变之二:

为了减少Overfitting,降低数据局部噪音影响,将原先的目标函数由 quadratic cost 改为 cross-enrtopy cost

  1. class CrossEntropyCost(object):
  2. def fn(a, y):
  3. return np.sum(np.nan_to_num(-y*np.log(a)-(1-y)*np.log(1-a)))
  4. def delta(z, a, y):
  5. return (a-y)

改变之三:

将S函数改为Softmax函数

  1. class SoftmaxLayer(object):
  2. def __init__(self, n_in, n_out, p_dropout=0.0):
  3. self.n_in = n_in
  4. self.n_out = n_out
  5. self.p_dropout = p_dropout
  6. self.w = theano.shared(
  7. np.zeros((n_in, n_out), dtype=theano.config.floatX),
  8. name='w', borrow=True)
  9. self.b = theano.shared(
  10. np.zeros((n_out,), dtype=theano.config.floatX),
  11. name='b', borrow=True)
  12. self.params = [self.w, self.b]
  13. def set_inpt(self, inpt, inpt_dropout, mini_batch_size):
  14. self.inpt = inpt.reshape((mini_batch_size, self.n_in))
  15. self.output = softmax((1-self.p_dropout)*T.dot(self.inpt, self.w) + self.b)
  16. self.y_out = T.argmax(self.output, axis=1)
  17. self.inpt_dropout = dropout_layer(
  18. inpt_dropout.reshape((mini_batch_size, self.n_in)), self.p_dropout)
  19. self.output_dropout = softmax(T.dot(self.inpt_dropout, self.w) + self.b)
  20. def cost(self, net):
  21. "Return the log-likelihood cost."
  22. return -T.mean(T.log(self.output_dropout)[T.arange(net.y.shape[0]), net.y])
  23. def accuracy(self, y):
  24. "Return the accuracy for the mini-batch."
  25. return T.mean(T.eq(y, self.y_out))
文章知识点与官方知识档案匹配,可进一步学习相关知识
算法技能树进阶任务算法问答19817 人正在系统学习中

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=4264
赞同 0
评论 0 条
一起吹晚风吧L0
粉丝 0 发表 7 + 关注 私信
上周热门
如何使用 StarRocks 管理和优化数据湖中的数据?  2944
【软件正版化】软件正版化工作要点  2863
统信UOS试玩黑神话:悟空  2823
信刻光盘安全隔离与信息交换系统  2718
镜舟科技与中启乘数科技达成战略合作,共筑数据服务新生态  1251
grub引导程序无法找到指定设备和分区  1217
华为全联接大会2024丨软通动力分论坛精彩议程抢先看!  163
点击报名 | 京东2025校招进校行程预告  162
2024海洋能源产业融合发展论坛暨博览会同期活动-海洋能源与数字化智能化论坛成功举办  160
华为纯血鸿蒙正式版9月底见!但Mate 70的内情还得接着挖...  157
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

加入交流群

请使用微信扫一扫!