深度学习常用算子

2024-09-03 10:58
文章标签 学习 深度 常用 算子

本文主要是介绍深度学习常用算子,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

深度学习常用算子

算子功能
ReluReLU(x)=max(0,x)
LeakyReluLeakyRelu(x) = (x >= 0 ? x : x*negative_slope)
Relu6LeakyRelu(x) = max(max(x, 0), 6)
Tantanh(x)=(exp(x)-exp(-x))/(exp(x)+exp(-x))
sigmoidsigmoid(x) = 1. / (1. + exp(x))
PReluf(x) = max(x, 0) + slope_data[c] * min(x, 0)
Add+
Sub-
Mul*
RealDiv/
BiasAdd用于增加bias操作,通常bias是一维Tensor
MatMul矩阵乘
Axpy向量求和,公式:y += a * x
EltwiseOp多个Tensor对应位置元素进行相乘、相加、取最大值中一种操作
BatchNorm加快神经网络的训练收敛速度
LRNLocal Response Normalization,即局部响应归一化层 LRN这个概念和运用是出现在AlexNet中。LRN最初是生物学里的概念“相邻神经元抑制”,对局部神经元的活动创建竞争机制。使用LRN增加了泛化能力(使输出中响应比较大的值变得相对更大,并抑制其他响应较小的神经元),做了平滑处理,提高了1%~2%的识别率。
SsdNormalize作用:限制了一次归一化的范围 使用网络:SSD
Convolution分区域进行特征值提取
FullConnection看作一种特殊卷积层,或者看作矩阵乘;整个输入作为feature map,进行特征提取FC是一种迁移学习的结果,通常FC后面接Softmax,所以FC层的功能还包括矩阵维度变换,将维度变换为Softmax对应的维度
Correlation功能
DeConvolution采用分步计算的方法,完成普通3D核的计算,其好处在于提升卷积计算的效率
PoolingPooling的作用是将输入的图像划分为若干个矩形区域,对每个子区域输出最大值或平均值。Pooling减少了参数的数量,防止过拟合现象的发生。
Mean只有取均值功能的滑窗算子
ROIPooling对ROI进行pooling操作,从不同大小的方框得到固定大小相应 的feature maps 使用网络:Faster RCNN
ROIAlign作用:解决ROIPooling两次量化带来的问题,使用线性插值的方式来解决。使用网络:Mask-RCNN
PSROIPooling使用网络:R-FCN
Flatten将输入tensor中从start_axis维度到end_axis维度合并为1维
Reshape将输入Tensor描述转换为新的shape
FreespaceExtract将h维变成1,其他维度不变,从而完成对h的采样,采样值所在位置由输入的index参数决定
PackPack算子为TensorFlow原生算子,最新的版本已经改名为:Stack。该算子以指定的轴axis,将一个维度为R的张量数组转变成一个维度为R+1的张量。
Pad进行数据扩充
Permute调整Tensor的输入维度顺序
ShuffleChannel作用:调整C维的排序 使用网络:ShuffleNet
Title将输入数据在每个维度上复制指定次数来生成输出数据
Rsqrty = 1 / sqrt{x}
Scaley(x)=scale*x+bias
AbsValy(x)=
Powerf(x)= (scale * x + shift) ^ power
Softmax通常作为分类网络的最后一层,输出每类的概率
ClipBoxes将输入的框坐标限制在[0,img_w-1]和[0,img_h-1]之间。
DecodeBoxes将输入框的长宽坐标转换为描点坐标(框中心点坐标和长宽),然后进行修正,修正后再替换回长宽坐标
DetectPostProcess(1)对输入的框进行修正;(2)按照得分进行排序;(3)使用NMS进行过滤;(4)每个分类取前N个框输出。
FasterRcnnPredictions获取得分最高的N个框,需要进行NMS处理。
FSRDectionOutput作用:获取得分最高的N个框,需要进行NMS处理 输入数据:每个分类的得分数据、roi坐标、roi偏移、feature map的长和宽 使用网络:FasterRcnn
GenerateRPNProposals作用:根据输入rois坐标和得分,输出排序和NMS处理后的前N个框,框坐标形式为左上角和右下角 使用网络:Mask Rcnn
Proposal作用:根据锚点前后得分、锚点偏移、原始图片的长宽缩放,来获取得分最高的N个预选框;特点:对特征图上的每个点,生成scale*ratio个固定大小的窗口;即候选窗口是该算子生成的。
SsdDetectionOutput作用:用来生成预测框相对原图的真实坐标,并对所有预测框进行过滤,得到最终物体检测的结果。输出的每个预测框的信息包括image id ,lable, confidence以及四个坐标值。使用网络:SSD
SsdPriorBox作用:生成预选框 使用网络:SSD
Concat实现多个算子的拼接
spatial transform在CNN之前对feature map进行旋转、缩放、平移、剪切等操作.使用网络:Spatial Transformer Networks(STN)

这篇关于深度学习常用算子的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python打包成exe常用的四种方法小结

《Python打包成exe常用的四种方法小结》本文主要介绍了Python打包成exe常用的四种方法,包括PyInstaller、cx_Freeze、Py2exe、Nuitka,文中通过示例代码介绍的非... 目录一.PyInstaller11.安装:2. PyInstaller常用参数下面是pyinstal

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

python语言中的常用容器(集合)示例详解

《python语言中的常用容器(集合)示例详解》Python集合是一种无序且不重复的数据容器,它可以存储任意类型的对象,包括数字、字符串、元组等,下面:本文主要介绍python语言中常用容器(集合... 目录1.核心内置容器1. 列表2. 元组3. 集合4. 冻结集合5. 字典2.collections模块

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2