让CNN跑起来,以下是调参的所有秘密
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了让CNN跑起来,以下是调参的所有秘密相关的知识,希望对你有一定的参考价值。
知乎上看到的
- 收集高质量标注数据
- 输入输出数据做好归一化,以防出现数值问题,方法就是主成分分析啥的。
- 参数初始化很重要。太小了,参数根本走不动。一般权重参数0.01均方差,0均值的高斯分布是万能的,不行就试更大的。偏差参数全0即可。
- 用SGD ,minibatch size 128。或者更小size ,但那样吞吐量变小,计算效率变低。
- 用带momentum的SGD,二阶方法不用也罢。
- 梯度更新的步长很重要。一般0.1是个万能数值。调参可改进结果,具体做法是人肉监督:用另外的验证集观察测试错误率,一旦不降了,步长减半甚至更多。
- 梯度归一化:除以minibatch size ,这样就不显式依赖minibatch size
- 限制权重参数的最大值防止跑飞。一般最大行范数不超过2或者4,否则同比收缩到这个值。
- 梯度大致应该总是只改变参数的千分之一,偏离这个数字太远的,调之。
- dropout一定要用
- relu一定要用
授人以鱼不如授人与渔。cnn调参,最好的参考论文就是那篇nips2012用cnn做imagenet的,没有之一。dropout那篇文章可作为最佳补充。
以上是关于让CNN跑起来,以下是调参的所有秘密的主要内容,如果未能解决你的问题,请参考以下文章
机器学习系列调参GridsearchCV随机森林GBDTLightGBM和XGBoost调参顺序,外加一些加速调参的小技巧(主要介绍坐标下降)