iOS人工智能交流模型4-用CC_ANN实现DNN网络

2023-11-23 01:00

本文主要是介绍iOS人工智能交流模型4-用CC_ANN实现DNN网络,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大纲

  1. 神经网络学习
  2. 常用模型分析
  3. iOS中的CoreML等闭源库
  4. 通过bench_ios中的CC_ANN使用激活函数ReLU和Sigmoid实现DNN网络。
  5. caffe、tensorflow等对比

目录:

  1. 介绍一个CC_ANN使用例子
  2. 回顾神经网络的构成
  3. 进行一次完整计算

CC_ANN是用oc封装的一层和多层神经网络例子,支持激活函数Sigmoid和ReLU

调用例子

//一次乘法的学习
//创建一个ANN网络
CC_ANN *ann=[[CC_ANN alloc]init];//学习100次
int count=100
[ann autoTrainTwoToOne:@[@[@[@(0.2),@(0.6)],@(0.12)],@[@[@(0.4),@(0.6)],@(0.24)],@[@[@(0.3),@(0.4)],@(0.12)]] activeFunction:ActiveFunctionTypeSigmoid trainTimes:count];
double predict1=[ann calWithInput:@[@(0.2),@(0.6)]];
double predict2=[ann calWithInput:@[@(0.4),@(0.6)]];
double predict3=[ann calWithInput:@[@(0.3),@(0.4)]];
double predict4=[ann calWithInput:@[@(0.4),@(0.5)]];
NSLog(@"p1=%f p2=%f p3=%f p4=%f",predict1,predict2,predict3,predict4);

//打印结果
p1=0.121306 p2=0.237448 p3=0.122096 p4=0.208426
耗时0.002秒

//学习1000次
int count=1000
//打印结果
p1=0.120000 p2=0.239999 p3=0.120001 p4=0.209638
耗时0.026秒

//学习10000次
int count=10000
//打印结果
p1=0.120000 p2=0.240000 p3=0.120000 p4=0.209638
耗时0.28秒

例子结论:

  1. 学习次数越多,对例子的还原越正确。如2*6越来越接近12
  2. 学习次数到达一定次数后,对预测的精确度不会再提高。如我们没有教过4*5,但是预测答案接近20,在学习1000次后,达到20.9638,但是学习10000次也没有将精度再次提高

这个例子符合神经网络的特征

下面看下如何构建一层神经网络,具体的计算方法。
img1

线性函数和sigmoid函数
LinearRegression模型:img2
sigmoid函数:img3

隐层决定了最终的分类效果
img4

可以看到,隐层越多,分类效果越好,因为可以转折的点更多。实际上,Kolmogorov理论指出:双隐层感知器就足以解决任何复杂的分类问题。
但是,过多的隐层和神经元结点会带来过拟合问题,不要试图降低神经网络参数量来减缓过拟合,用正则化或者dropout。

神经网络结构
img5

传递函数/激活函数
每一层传递使用wx+b,对每一个输出使用sigmoid、tanh、relu等激活函数使线性的结果非线性化。
为什么需要传递函数?
简单理解上,如果不加激活函数,无论多少层隐层,最终的结果还是原始输入的线性变化,这样一层隐层就可以达到结果,就没有多层感知器的意义了。所以每个隐层都会配一个激活函数,提供非线性变化。

BP算法
一个反馈网络,类似生物的反馈网络,和人走路不会摔倒一样,每一次输出都会有反馈去修正误差,使下一次结果更接近理想结果。
img6

以三层感知器为例做计算:
网络结构
img7

可以用到的公式为:
img8
img9

代入参数:
img10

两个输入;
隐层: b1, w1, w2, w3, w4 (都有初始值) 计算一个合理的初始值可以使用前面提到的HE初始化、随机初始化和pre-train初始化
输出层:b2, w5, w6, w7, w8(赋了初始值)
这里使用sigmoid激活函数
img11

用E来衡量误差大小,为反馈提供支持:
img12

获得E后反向计算误差:
对E求导就可计算出误差梯度
img13

计算出w5、w6、w7、w8的误差梯度:
误差梯度乘以学习率即是需要调整的误差值
img14

同理,再向上一级推导出w1-w4的误差值:
img15

完成一次反向传播:
求误差对w5的偏导过程 参数更新: 求误差对w1的偏导 注意,w1对两个输出的误差都有影响
通过以上过程可以更新所有权重,就可以再次迭代更新了,直到满足条件。

可以提供的数学函数:

@interface CC_Math : NSObject+ (double)sign:(double)input;/***  激活函数*/
+ (double)sigmoid:(double)input;
+ (double)reLU:(double)input;/***  双s曲线*/
+ (double)doubleS:(int)input;/***  标准正态分布*/
+ (double)randn:(double)input;/***  获得初始化权重*  length w个数*/
+ (NSMutableArray *)getW_positive_unitball:(int)length;
/***  weight = np.random.randn(in_node, out_node)/np.sqrt(in_node)*/
+ (NSMutableArray *)getW_XavierFiller:(int)length;
/***  Xavier论文中使用的激活函数是tanh函数,而神经网络中使用较广泛的是relu激活函数,所以提出此方法。weight = np.random.randn(in_node, out_node)/np.sqrt(in_node/2)*/
+ (NSMutableArray *)getW_MSRAFiller:(int)length;@end

可以提供的ANN函数

typedef enum : NSUInteger {ActiveFunctionTypeReLU,ActiveFunctionTypeSigmoid,//如使用sigmoid 输入输出范围在[-1,1]
} ActiveFunctionType;@interface CC_ANN : NSObject/***  训练结束后可计算结果*/
- (double)calWithInput:(NSArray *)input;//- (double)calWithInput_twolevel:(NSArray *)input;/***  一层深度学习*  samples 学习样本 多个样本以数组形式例:@[@[@[@(0.2),@(0.6)],@(0.12)],@[@[@(0.4),@(0.6)],@(0.24)]]*  weights 初始化权重 一层深度 2个输入1个输出需要权重 2^2+2=6个初始值*  learningRate 学习率 选一个较小值 如0.4*  activeFunction 激活函数*  times 训练次数*/
- (void)trainTwoToOne:(NSArray *)samples weights:(NSArray *)weights learningRate:(double)learningRate activeFunction:(ActiveFunctionType)activeFunction trainTimes:(int)times;/***  一层深度学习 自动寻找最佳学习率 自动获取初始化权值w*  activeFunction 激活函数*  times 训练次数*/
- (void)autoTrainTwoToOne:(NSArray *)samples activeFunction:(ActiveFunctionType)activeFunction trainTimes:(int)times;/***  一层深度学习 自动寻找最佳学习率 自动获取初始化权值w*  errorRate 到最小错误率前不会停止学习*/
- (void)autoTrainTwoToOne:(NSArray *)samples activeFunction:(ActiveFunctionType)activeFunction untilErrorRate:(double)errorRate;- (void)trainTwoToOne:(NSArray *)samples trainTimes:(int)times deep:(int)deep;
- (void)trainTwoToOne:(NSArray *)samples trainTimes:(int)times;@end

demo下载
https://github.com/gwh111/bench_ios

这篇关于iOS人工智能交流模型4-用CC_ANN实现DNN网络的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/414184

相关文章

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2