Convolutional neural network explained

A convolutional neural network (CNN) is a regularized type of feed-forward neural network that learns features by itself via filter (or kernel) optimization. This type of deep learning network has been applied to process and make predictions from many different types of data including text, images and audio.[1] Convolution-based networks are the de-facto standard in deep learning-based approaches to computer vision and image processing, and have only recently have been replaced -- in some cases -- by newer deep learning architectures such as the transformer. Vanishing gradients and exploding gradients, seen during backpropagation in earlier neural networks, are prevented by using regularized weights over fewer connections.[2] [3] For example, for each neuron in the fully-connected layer, 10,000 weights would be required for processing an image sized 100 × 100 pixels. However, applying cascaded convolution (or cross-correlation) kernels,[4] [5] only 25 neurons are required to process 5x5-sized tiles.[6] Higher-layer features are extracted from wider context windows, compared to lower-layer features.

Some applications of CNNs include:

CNNs are also known as shift invariant or space invariant artificial neural networks, based on the shared-weight architecture of the convolution kernels or filters that slide along input features and provide translation-equivariant responses known as feature maps.[12] [13] Counter-intuitively, most convolutional neural networks are not invariant to translation, due to the downsampling operation they apply to the input.[14]

Feed-forward neural networks are usually fully connected networks, that is, each neuron in one layer is connected to all neurons in the next layer. The "full connectivity" of these networks makes them prone to overfitting data. Typical ways of regularization, or preventing overfitting, include: penalizing parameters during training (such as weight decay) or trimming connectivity (skipped connections, dropout, etc.) Robust datasets also increase the probability that CNNs will learn the generalized principles that characterize a given dataset rather than the biases of a poorly-populated set.[15]

Convolutional networks were inspired by biological processes[16] [17] in that the connectivity pattern between neurons resembles the organization of the animal visual cortex. Individual cortical neurons respond to stimuli only in a restricted region of the visual field known as the receptive field. The receptive fields of different neurons partially overlap such that they cover the entire visual field.

CNNs use relatively little pre-processing compared to other image classification algorithms. This means that the network learns to optimize the filters (or kernels) through automated learning, whereas in traditional algorithms these filters are hand-engineered. This independence from prior knowledge and human intervention in feature extraction is a major advantage.

Architecture

See main article: Layer (deep learning). A convolutional neural network consists of an input layer, hidden layers and an output layer. In a convolutional neural network, the hidden layers include one or more layers that perform convolutions. Typically this includes a layer that performs a dot product of the convolution kernel with the layer's input matrix. This product is usually the Frobenius inner product, and its activation function is commonly ReLU. As the convolution kernel slides along the input matrix for the layer, the convolution operation generates a feature map, which in turn contributes to the input of the next layer. This is followed by other layers such as pooling layers, fully connected layers, and normalization layers.Here it should be noted how close a convolutional neural network is to a matched filter.[18]

Convolutional layers

In a CNN, the input is a tensor with shape:

(number of inputs) × (input height) × (input width) × (input channels)

After passing through a convolutional layer, the image becomes abstracted to a feature map, also called an activation map, with shape:

(number of inputs) × (feature map height) × (feature map width) × (feature map channels).

Convolutional layers convolve the input and pass its result to the next layer. This is similar to the response of a neuron in the visual cortex to a specific stimulus.[19] Each convolutional neuron processes data only for its receptive field. Although fully connected feedforward neural networks can be used to learn features and classify data, this architecture is generally impractical for larger inputs (e.g., high-resolution images), which would require massive numbers of neurons because each pixel is a relevant input feature. A fully connected layer for an image of size 100 × 100 has 10,000 weights for each neuron in the second layer. Convolution reduces the number of free parameters, allowing the network to be deeper. For example, using a 5 × 5 tiling region, each with the same shared weights, requires only 25 neurons. Using regularized weights over fewer parameters avoids the vanishing gradients and exploding gradients problems seen during backpropagation in earlier neural networks.

To speed processing, standard convolutional layers can be replaced by depthwise separable convolutional layers,[20] which are based on a depthwise convolution followed by a pointwise convolution. The depthwise convolution is a spatial convolution applied independently over each channel of the input tensor, while the pointwise convolution is a standard convolution restricted to the use of

1 x 1

kernels.

Pooling layers

Convolutional networks may include local and/or global pooling layers along with traditional convolutional layers. Pooling layers reduce the dimensions of data by combining the outputs of neuron clusters at one layer into a single neuron in the next layer. Local pooling combines small clusters, tiling sizes such as 2 × 2 are commonly used. Global pooling acts on all the neurons of the feature map.[21] There are two common types of pooling in popular use: max and average. Max pooling uses the maximum value of each local cluster of neurons in the feature map,[22] [23] while average pooling takes the average value.

Fully connected layers

Fully connected layers connect every neuron in one layer to every neuron in another layer. It is the same as a traditional multilayer perceptron neural network (MLP). The flattened matrix goes through a fully connected layer to classify the images.

Receptive field

In neural networks, each neuron receives input from some number of locations in the previous layer. In a convolutional layer, each neuron receives input from only a restricted area of the previous layer called the neuron's receptive field. Typically the area is a square (e.g. 5 by 5 neurons). Whereas, in a fully connected layer, the receptive field is the entire previous layer. Thus, in each convolutional layer, each neuron takes input from a larger area in the input than previous layers. This is due to applying the convolution over and over, which takes the value of a pixel into account, as well as its surrounding pixels. When using dilated layers, the number of pixels in the receptive field remains constant, but the field is more sparsely populated as its dimensions grow when combining the effect of several layers.

To manipulate the receptive field size as desired, there are some alternatives to the standard convolutional layer. For example, atrous or dilated convolution[24] [25] expands the receptive field size without increasing the number of parameters by interleaving visible and blind regions. Moreover, a single dilated convolutional layer can comprise filters with multiple dilation ratios,[26] thus having a variable receptive field size.

Weights

Each neuron in a neural network computes an output value by applying a specific function to the input values received from the receptive field in the previous layer. The function that is applied to the input values is determined by a vector of weights and a bias (typically real numbers). Learning consists of iteratively adjusting these biases and weights.

The vectors of weights and biases are called filters and represent particular features of the input (e.g., a particular shape). A distinguishing feature of CNNs is that many neurons can share the same filter. This reduces the memory footprint because a single bias and a single vector of weights are used across all receptive fields that share that filter, as opposed to each receptive field having its own bias and vector weighting.[27]

Deconvolutional

A deconvolutional neural network is essentially the reverse of a CNN. It consists of deconvolutional layers and unpooling layers.[28]

A deconvolutional layer is the transpose of a convolutional layer. Specifically, a convolutional layer can be written as a multiplication with a matrix, and a deconvolutional layer is multiplication with the transpose of that matrix.

An unpooling layer expands the layer. The max-unpooling layer is the simplest, as it simply copies each entry multiple times. For example, a 2-by-2 max-unpooling layer is

[x]\mapsto\begin{bmatrix}x&x\x&x\end{bmatrix}

.

Deconvolution layers are used in image generators. By default, it creates periodic checkerboard artifact, which can be fixed by upscale-then-convolve.[29]

History

CNN are often compared to the way the brain achieves vision processing in living organisms.[30]

Receptive fields in the visual cortex

Work by Hubel and Wiesel in the 1950s and 1960s showed that cat visual cortices contain neurons that individually respond to small regions of the visual field. Provided the eyes are not moving, the region of visual space within which visual stimuli affect the firing of a single neuron is known as its receptive field. Neighboring cells have similar and overlapping receptive fields. Receptive field size and location varies systematically across the cortex to form a complete map of visual space. The cortex in each hemisphere represents the contralateral visual field.

Their 1968 paper identified two basic visual cell types in the brain:[31]

Hubel and Wiesel also proposed a cascading model of these two types of cells for use in pattern recognition tasks.[32] [33]

Neocognitron, origin of the CNN architecture

Inspired by Hubel and Wiesel's work, in 1969, Kunihiko Fukushima published a deep CNN that uses ReLU activation function.[34] Unlike most modern networks, this network used hand-designed kernels. It was not used in his neocognitron, since all the weights were nonnegative; lateral inhibition was used instead. The rectifier has become the most popular activation function for CNNs and deep neural networks in general.[35]

The "neocognitron" was introduced by Kunihiko Fukushima in 1979.[36] [37] The kernels were trained by unsupervised learning. It was inspired by the above-mentioned work of Hubel and Wiesel. The neocognitron introduced the two basic types of layers:

In a variant of the neocognitron called the cresceptron, instead of using Fukushima's spatial averaging with inhibition and saturation, J. Weng et al. in 1993 introduced a method called max-pooling where a downsampling unit computes the maximum of the activations of the units in its patch.[38] Max-pooling is often used in modern CNNs.[39]

Several supervised and unsupervised learning algorithms have been proposed over the decades to train the weights of a neocognitron.[16] Today, however, the CNN architecture is usually trained through backpropagation.

Convolution in time

The term "convolution" first appears in neural networks in a paper by Toshiteru Homma, Les Atlas, and Robert Marks II at the first Conference on Neural Information Processing Systems in 1987. Their paper replaced multiplication with convolution in time, inherently providing shift invariance, motivated by and connecting more directly to the signal-processing concept of a filter, and demonstrated it on a speech recognition task.[40] They also pointed out that as a data-trainable system, convolution is essentially equivalent to correlation since reversal of the weights does not affect the final learned function ("For convenience, we denote * as correlation instead of convolution. Note that convolving a(t) with b(t) is equivalent to correlating a(-t) with b(t).").[40] Modern CNN implementations typically do correlation and call it convolution, for convenience, as they did here.

Time delay neural networks

The time delay neural network (TDNN) was introduced in 1987 by Alex Waibel et al. for phoneme recognition and was one of the first convolutional networks, as it achieved shift-invariance.[41] A TDNN is a 1-D convolutional neural net where the convolution is performed along the time axis of the data. It is the first CNN utilizing weight sharing in combination with a training by gradient descent, using backpropagation.[42] Thus, while also using a pyramidal structure as in the neocognitron, it performed a global optimization of the weights instead of a local one.[41]

TDNNs are convolutional networks that share weights along the temporal dimension.[43] They allow speech signals to be processed time-invariantly. In 1990 Hampshire and Waibel introduced a variant that performs a two-dimensional convolution.[44] Since these TDNNs operated on spectrograms, the resulting phoneme recognition system was invariant to both time and frequency shifts, as with images processed by a neocognitron.

TDNNs improved the performance of far-distance speech recognition.[45]

Image recognition with CNNs trained by gradient descent

Denker et al. (1989) designed a 2-D CNN system to recognize hand-written ZIP Code numbers.[46] However, the lack of an efficient training method to determine the kernel coefficients of the involved convolutions meant that all the coefficients had to be laboriously hand-designed.[47]

Following the advances in the training of 1-D CNNs by Waibel et al. (1987), Yann LeCun et al. (1989)[47] used back-propagation to learn the convolution kernel coefficients directly from images of hand-written numbers. Learning was thus fully automatic, performed better than manual coefficient design, and was suited to a broader range of image recognition problems and image types. Wei Zhang et al. (1988)[12] [13] used back-propagation to train the convolution kernels of a CNN for alphabets recognition. The model was called shift-invariant pattern recognition neural network before the name CNN was coined later in the early 1990s. Wei Zhang et al. also applied the same CNN without the last fully connected layer for medical image object segmentation (1991) and breast cancer detection in mammograms (1994).

This approach became a foundation of modern computer vision.

Max pooling

In 1990 Yamaguchi et al. introduced the concept of max pooling, a fixed filtering operation that calculates and propagates the maximum value of a given region. They did so by combining TDNNs with max pooling to realize a speaker-independent isolated word recognition system.[22] In their system they used several TDNNs per word, one for each syllable. The results of each TDNN over the input signal were combined using max pooling and the outputs of the pooling layers were then passed on to networks performing the actual word classification.

LeNet-5

See main article: LeNet. LeNet-5, a pioneering 7-level convolutional network by LeCun et al. in 1995,[48] classifies hand-written numbers on checks digitized in 32x32 pixel images. The ability to process higher-resolution images requires larger and more layers of convolutional neural networks, so this technique is constrained by the availability of computing resources.

It was superior than other commercial courtesy amount reading systems (as of 1995). The system was integrated in NCR's check reading systems, and fielded in several American banks since June 1996, reading millions of checks per day.[49]

Shift-invariant neural network

A shift-invariant neural network was proposed by Wei Zhang et al. for image character recognition in 1988.[12] [13] It is a modified Neocognitron by keeping only the convolutional interconnections between the image feature layers and the last fully connected layer. The model was trained with back-propagation. The training algorithm was further improved in 1991[50] to improve its generalization ability. The model architecture was modified by removing the last fully connected layer and applied for medical image segmentation (1991)[51] and automatic detection of breast cancer in mammograms (1994).[52]

A different convolution-based design was proposed in 1988[53] for application to decomposition of one-dimensional electromyography convolved signals via de-convolution. This design was modified in 1989 to other de-convolution-based designs.[54] [55]

GPU implementations

Although CNNs were invented in the 1980s, their breakthrough in the 2000s required fast implementations on graphics processing units (GPUs).

In 2004, it was shown by K. S. Oh and K. Jung that standard neural networks can be greatly accelerated on GPUs. Their implementation was 20 times faster than an equivalent implementation on CPU.[56] In 2005, another paper also emphasised the value of GPGPU for machine learning.[57]

The first GPU-implementation of a CNN was described in 2006 by K. Chellapilla et al. Their implementation was 4 times faster than an equivalent implementation on CPU.[58] In the same period, GPUs were also used for unsupervised training of deep belief networks.[59] [60] [61] [62]

In 2010, Dan Ciresan et al. at IDSIA trained deep feedforward networks on GPUs.[63] In 2011, they extended this to CNNs, accelerating by 60 compared to training CPU.[64] In 2011, the network win an image recognition contest where they achieved superhuman performance for the first time.[65] Then they won more competitions and achieved state of the art on several benchmarks.[66] [39] [23]

Subsequently, AlexNet, a similar GPU-based CNN by Alex Krizhevsky et al. won the ImageNet Large Scale Visual Recognition Challenge 2012. It was an early catalytic event for the AI boom.

Compared to the training of CNNs using GPUs, not much attention was given to CPU. (Viebke et al 2019) parallelizes CNN by thread- and SIMD-level parallelism that is available on the Intel Xeon Phi.[67] [68]

Distinguishing features

In the past, traditional multilayer perceptron (MLP) models were used for image recognition. However, the full connectivity between nodes caused the curse of dimensionality, and was computationally intractable with higher-resolution images. A 1000×1000-pixel image with RGB color channels has 3 million weights per fully-connected neuron, which is too high to feasibly process efficiently at scale.For example, in CIFAR-10, images are only of size 32×32×3 (32 wide, 32 high, 3 color channels), so a single fully connected neuron in the first hidden layer of a regular neural network would have 32*32*3 = 3,072 weights. A 200×200 image, however, would lead to neurons that have 200*200*3 = 120,000 weights.

Also, such network architecture does not take into account the spatial structure of data, treating input pixels which are far apart in the same way as pixels that are close together. This ignores locality of reference in data with a grid-topology (such as images), both computationally and semantically. Thus, full connectivity of neurons is wasteful for purposes such as image recognition that are dominated by spatially local input patterns.

Convolutional neural networks are variants of multilayer perceptrons, designed to emulate the behavior of a visual cortex. These models mitigate the challenges posed by the MLP architecture by exploiting the strong spatially local correlation present in natural images. As opposed to MLPs, CNNs have the following distinguishing features:

Together, these properties allow CNNs to achieve better generalization on vision problems. Weight sharing dramatically reduces the number of free parameters learned, thus lowering the memory requirements for running the network and allowing the training of larger, more powerful networks.

Building blocks

A CNN architecture is formed by a stack of distinct layers that transform the input volume into an output volume (e.g. holding the class scores) through a differentiable function. A few distinct types of layers are commonly used. These are further discussed below.

Convolutional layer

The convolutional layer is the core building block of a CNN. The layer's parameters consist of a set of learnable filters (or kernels), which have a small receptive field, but extend through the full depth of the input volume. During the forward pass, each filter is convolved across the width and height of the input volume, computing the dot product between the filter entries and the input, producing a 2-dimensional activation map of that filter. As a result, the network learns filters that activate when it detects some specific type of feature at some spatial position in the input.[70] [71]

Stacking the activation maps for all filters along the depth dimension forms the full output volume of the convolution layer. Every entry in the output volume can thus also be interpreted as an output of a neuron that looks at a small region in the input. Each entry in an activation map use the same set of parameters that define the filter.

Self-supervised learning has been adapted for use in convolutional layers by using sparse patches with a high-mask ratio and a global response normalization layer.

Local connectivity

When dealing with high-dimensional inputs such as images, it is impractical to connect neurons to all neurons in the previous volume because such a network architecture does not take the spatial structure of the data into account. Convolutional networks exploit spatially local correlation by enforcing a sparse local connectivity pattern between neurons of adjacent layers: each neuron is connected to only a small region of the input volume.

The extent of this connectivity is a hyperparameter called the receptive field of the neuron. The connections are local in space (along width and height), but always extend along the entire depth of the input volume. Such an architecture ensures that the learned filters produce the strongest response to a spatially local input pattern.

Spatial arrangement

Three hyperparameters control the size of the output volume of the convolutional layer: the depth, stride, and padding size:

The spatial size of the output volume is a function of the input volume size

W

, the kernel field size

K

of the convolutional layer neurons, the stride

S

, and the amount of zero padding

P

on the border. The number of neurons that "fit" in a given volume is then:

\frac + 1.

If this number is not an integer, then the strides are incorrect and the neurons cannot be tiled to fit across the input volume in a symmetric way. In general, setting zero padding to be P = (K-1)/2 when the stride is

S=1

ensures that the input volume and output volume will have the same size spatially. However, it is not always completely necessary to use all of the neurons of the previous layer. For example, a neural network designer may decide to use just a portion of padding.

Parameter sharing

A parameter sharing scheme is used in convolutional layers to control the number of free parameters. It relies on the assumption that if a patch feature is useful to compute at some spatial position, then it should also be useful to compute at other positions. Denoting a single 2-dimensional slice of depth as a depth slice, the neurons in each depth slice are constrained to use the same weights and bias.

Since all neurons in a single depth slice share the same parameters, the forward pass in each depth slice of the convolutional layer can be computed as a convolution of the neuron's weights with the input volume.[73] Therefore, it is common to refer to the sets of weights as a filter (or a kernel), which is convolved with the input. The result of this convolution is an activation map, and the set of activation maps for each different filter are stacked together along the depth dimension to produce the output volume. Parameter sharing contributes to the translation invariance of the CNN architecture.[14]

Sometimes, the parameter sharing assumption may not make sense. This is especially the case when the input images to a CNN have some specific centered structure; for which we expect completely different features to be learned on different spatial locations. One practical example is when the inputs are faces that have been centered in the image: we might expect different eye-specific or hair-specific features to be learned in different parts of the image. In that case it is common to relax the parameter sharing scheme, and instead simply call the layer a "locally connected layer".

Pooling layer

See main article: Pooling layer. Another important concept of CNNs is pooling, which is used as a form of non-linear down-sampling. Pooling provides downsampling because it reduces the spatial dimensions (height and width) of the input feature maps while retaining the most important information. There are several non-linear functions to implement pooling, where max pooling and average pooling are the most common. Pooling aggregates information from small regions of the input creating partitions of the input feature map, typically using a fixed-size window (like 2x2) and applying a stride (often 2) to move the window across the input.[74] Note that without using a stride greater than 1, pooling would not perform downsampling, as it would simply move the pooling window across the input one step at a time, without reducing the size of the feature map. In other words, the stride is what actually causes the downsampling by determining how much the pooling window moves over the input.

Intuitively, the exact location of a feature is less important than its rough location relative to other features. This is the idea behind the use of pooling in convolutional neural networks. The pooling layer serves to progressively reduce the spatial size of the representation, to reduce the number of parameters, memory footprint and amount of computation in the network, and hence to also control overfitting. This is known as down-sampling. It is common to periodically insert a pooling layer between successive convolutional layers (each one typically followed by an activation function, such as a ReLU layer) in a CNN architecture.[70] While pooling layers contribute to local translation invariance, they do not provide global translation invariance in a CNN, unless a form of global pooling is used.[14] [75] The pooling layer commonly operates independently on every depth, or slice, of the input and resizes it spatially. A very common form of max pooling is a layer with filters of size 2×2, applied with a stride of 2, which subsamples every depth slice in the input by 2 along both width and height, discarding 75% of the activations:f_(S)=\max_^1S_.In this case, every max operation is over 4 numbers. The depth dimension remains unchanged (this is true for other forms of pooling as well).

In addition to max pooling, pooling units can use other functions, such as average pooling or ℓ2-norm pooling. Average pooling was often used historically but has recently fallen out of favor compared to max pooling, which generally performs better in practice.[76]

Due to the effects of fast spatial reduction of the size of the representation, there is a recent trend towards using smaller filters[77] or discarding pooling layers altogether.[78]

Channel max pooling

A channel max pooling (CMP) operation layer conducts the MP operation along the channel side among the corresponding positions of the consecutive feature maps for the purpose of redundant information elimination. The CMP makes the significant features gather together within fewer channels, which is important for fine-grained image classification that needs more discriminating features. Meanwhile, another advantage of the CMP operation is to make the channel number of feature maps smaller before it connects to the first fully connected (FC) layer. Similar to the MP operation, we denote the input feature maps and output feature maps of a CMP layer as F ∈ R(C×M×N) and C ∈ R(c×M×N), respectively, where C and c are the channel numbers of the input and output feature maps, M and N are the widths and the height of the feature maps, respectively. Note that the CMP operation only changes the channel number of the feature maps. The width and the height of the feature maps are not changed, which is different from the MP operation.[79]

See [80] for reviews for pooling methods.

ReLU layer

ReLU is the abbreviation of rectified linear unit. It was proposed by Alston Householder in 1941,[81] and used in CNN by Kunihiko Fukushima in 1969.[34] ReLU applies the non-saturating activation function f(x)=\max(0,x).[82] It effectively removes negative values from an activation map by setting them to zero.[83] It introduces nonlinearity to the decision function and in the overall network without affecting the receptive fields of the convolution layers.In 2011, Xavier Glorot, Antoine Bordes and Yoshua Bengio found that ReLU enables better training of deeper networks,[84] compared to widely used activation functions prior to 2011.

Other functions can also be used to increase nonlinearity, for example the saturating hyperbolic tangent f(x)=\tanh(x), f(x)=|\tanh(x)|, and the sigmoid function \sigma(x)=(1+e^)^. ReLU is often preferred to other functions because it trains the neural network several times faster without a significant penalty to generalization accuracy.[85]

Fully connected layer

After several convolutional and max pooling layers, the final classification is done via fully connected layers. Neurons in a fully connected layer have connections to all activations in the previous layer, as seen in regular (non-convolutional) artificial neural networks. Their activations can thus be computed as an affine transformation, with matrix multiplication followed by a bias offset (vector addition of a learned or fixed bias term).

Loss layer

See main article: Loss function and Loss functions for classification. The "loss layer", or "loss function", specifies how training penalizes the deviation between the predicted output of the network, and the true data labels (during supervised learning). Various loss functions can be used, depending on the specific task.

The Softmax loss function is used for predicting a single class of K mutually exclusive classes.[86] Sigmoid cross-entropy loss is used for predicting K independent probability values in

[0,1]

. Euclidean loss is used for regressing to real-valued labels

(-infty,infty)

.

Hyperparameters

Hyperparameters are various settings that are used to control the learning process. CNNs use more hyperparameters than a standard multilayer perceptron (MLP).

Kernel size

The kernel is the number of pixels processed together. It is typically expressed as the kernel's dimensions, e.g., 2x2, or 3x3.

Padding

Padding is the addition of (typically) 0-valued pixels on the borders of an image. This is done so that the border pixels are not undervalued (lost) from the output because they would ordinarily participate in only a single receptive field instance. The padding applied is typically one less than the corresponding kernel dimension. For example, a convolutional layer using 3x3 kernels would receive a 2-pixel pad, that is 1 pixel on each side of the image.

Stride

The stride is the number of pixels that the analysis window moves on each iteration. A stride of 2 means that each kernel is offset by 2 pixels from its predecessor.

Number of filters

Since feature map size decreases with depth, layers near the input layer tend to have fewer filters while higher layers can have more. To equalize computation at each layer, the product of feature values va with pixel position is kept roughly constant across layers. Preserving more information about the input would require keeping the total number of activations (number of feature maps times number of pixel positions) non-decreasing from one layer to the next.

The number of feature maps directly controls the capacity and depends on the number of available examples and task complexity.

Filter size

Common filter sizes found in the literature vary greatly, and are usually chosen based on the data set. Typical filter sizes range from 1x1 to 7x7. As two famous examples, AlexNet used 3x3, 5x5, and 11x11. Inceptionv3 used 1x1, 3x3, and 5x5.

The challenge is to find the right level of granularity so as to create abstractions at the proper scale, given a particular data set, and without overfitting.

Pooling type and size

Max pooling is typically used, often with a 2x2 dimension. This implies that the input is drastically downsampled, reducing processing cost.

Greater pooling reduces the dimension of the signal, and may result in unacceptable information loss. Often, non-overlapping pooling windows perform best.[76]

Dilation

Dilation involves ignoring pixels within a kernel. This reduces processing memory potentially without significant signal loss. A dilation of 2 on a 3x3 kernel expands the kernel to 5x5, while still processing 9 (evenly spaced) pixels. Specifically, the processed pixels after the dilation are the cells (1,1), (1,3), (1,5), (3,1), (3,3), (3,5), (5,1), (5,3), (5,5), where (i,j) denotes the cell of the i-th row and j-th column in the expanded 5x5 kernel. Accordingly, dilation of 4 expands the kernel to 7x7.

Translation equivariance and aliasing

It is commonly assumed that CNNs are invariant to shifts of the input. Convolution or pooling layers within a CNN that do not have a stride greater than one are indeed equivariant to translations of the input.[75] However, layers with a stride greater than one ignore the Nyquist-Shannon sampling theorem and might lead to aliasing of the input signal[75] While, in principle, CNNs are capable of implementing anti-aliasing filters, it has been observed that this does not happen in practice [87] and yield models that are not equivariant to translations.Furthermore, if a CNN makes use of fully connected layers, translation equivariance does not imply translation invariance, as the fully connected layers are not invariant to shifts of the input.[88] [14] One solution for complete translation invariance is avoiding any down-sampling throughout the network and applying global average pooling at the last layer.[75] Additionally, several other partial solutions have been proposed, such as anti-aliasing before downsampling operations,[89] spatial transformer networks,[90] data augmentation, subsampling combined with pooling,[14] and capsule neural networks.[91]

Evaluation

The accuracy of the final model is based on a sub-part of the dataset set apart at the start, often called a test-set. Other times methods such as k-fold cross-validation are applied. Other strategies include using conformal prediction.[92] [93]

Regularization methods

See main article: Regularization (mathematics). Regularization is a process of introducing additional information to solve an ill-posed problem or to prevent overfitting. CNNs use various types of regularization.

Empirical

Dropout

Because a fully connected layer occupies most of the parameters, it is prone to overfitting. One method to reduce overfitting is dropout, introduced in 2014.[94] At each training stage, individual nodes are either "dropped out" of the net (ignored) with probability

1-p

or kept with probability

p

, so that a reduced network is left; incoming and outgoing edges to a dropped-out node are also removed. Only the reduced network is trained on the data in that stage. The removed nodes are then reinserted into the network with their original weights.

In the training stages,

p

is usually 0.5; for input nodes, it is typically much higher because information is directly lost when input nodes are ignored.

At testing time after training has finished, we would ideally like to find a sample average of all possible

2n

dropped-out networks; unfortunately this is unfeasible for large values of

n

. However, we can find an approximation by using the full network with each node's output weighted by a factor of

p

, so the expected value of the output of any node is the same as in the training stages. This is the biggest contribution of the dropout method: although it effectively generates

2n

neural nets, and as such allows for model combination, at test time only a single network needs to be tested.

By avoiding training all nodes on all training data, dropout decreases overfitting. The method also significantly improves training speed. This makes the model combination practical, even for deep neural networks. The technique seems to reduce node interactions, leading them to learn more robust features that better generalize to new data.

DropConnect

DropConnect is the generalization of dropout in which each connection, rather than each output unit, can be dropped with probability

1-p

. Each unit thus receives input from a random subset of units in the previous layer.[95]

DropConnect is similar to dropout as it introduces dynamic sparsity within the model, but differs in that the sparsity is on the weights, rather than the output vectors of a layer. In other words, the fully connected layer with DropConnect becomes a sparsely connected layer in which the connections are chosen at random during the training stage.

Stochastic pooling

A major drawback to Dropout is that it does not have the same benefits for convolutional layers, where the neurons are not fully connected.

Even before Dropout, in 2013 a technique called stochastic pooling,[96] the conventional deterministic pooling operations were replaced with a stochastic procedure, where the activation within each pooling region is picked randomly according to a multinomial distribution, given by the activities within the pooling region. This approach is free of hyperparameters and can be combined with other regularization approaches, such as dropout and data augmentation.

An alternate view of stochastic pooling is that it is equivalent to standard max pooling but with many copies of an input image, each having small local deformations. This is similar to explicit elastic deformations of the input images, which delivers excellent performance on the MNIST data set.[97] Using stochastic pooling in a multilayer model gives an exponential number of deformations since the selections in higher layers are independent of those below.

Artificial data

See main article: Data augmentation. Because the degree of model overfitting is determined by both its power and the amount of training it receives, providing a convolutional network with more training examples can reduce overfitting. Because there is often not enough available data to train, especially considering that some part should be spared for later testing, two approaches are to either generate new data from scratch (if possible) or perturb existing data to create new ones. The latter one is used since mid-1990s. For example, input images can be cropped, rotated, or rescaled to create new examples with the same labels as the original training set.[98]

Explicit

Early stopping

See main article: Early stopping. One of the simplest methods to prevent overfitting of a network is to simply stop the training before overfitting has had a chance to occur. It comes with the disadvantage that the learning process is halted.

Number of parameters

Another simple way to prevent overfitting is to limit the number of parameters, typically by limiting the number of hidden units in each layer or limiting network depth. For convolutional networks, the filter size also affects the number of parameters. Limiting the number of parameters restricts the predictive power of the network directly, reducing the complexity of the function that it can perform on the data, and thus limits the amount of overfitting. This is equivalent to a "zero norm".

Weight decay

A simple form of added regularizer is weight decay, which simply adds an additional error, proportional to the sum of weights (L1 norm) or squared magnitude (L2 norm) of the weight vector, to the error at each node. The level of acceptable model complexity can be reduced by increasing the proportionality constant('alpha' hyperparameter), thus increasing the penalty for large weight vectors.

L2 regularization is the most common form of regularization. It can be implemented by penalizing the squared magnitude of all parameters directly in the objective. The L2 regularization has the intuitive interpretation of heavily penalizing peaky weight vectors and preferring diffuse weight vectors. Due to multiplicative interactions between weights and inputs this has the useful property of encouraging the network to use all of its inputs a little rather than some of its inputs a lot.

L1 regularization is also common. It makes the weight vectors sparse during optimization. In other words, neurons with L1 regularization end up using only a sparse subset of their most important inputs and become nearly invariant to the noisy inputs. L1 with L2 regularization can be combined; this is called elastic net regularization.

Max norm constraints

Another form of regularization is to enforce an absolute upper bound on the magnitude of the weight vector for every neuron and use projected gradient descent to enforce the constraint. In practice, this corresponds to performing the parameter update as normal, and then enforcing the constraint by clamping the weight vector

\vec{w}

of every neuron to satisfy

\|\vec{w}\|2<c

. Typical values of

c

are order of 3–4. Some papers report improvements[99] when using this form of regularization.

Hierarchical coordinate frames

Pooling loses the precise spatial relationships between high-level parts (such as nose and mouth in a face image). These relationships are needed for identity recognition. Overlapping the pools so that each feature occurs in multiple pools, helps retain the information. Translation alone cannot extrapolate the understanding of geometric relationships to a radically new viewpoint, such as a different orientation or scale. On the other hand, people are very good at extrapolating; after seeing a new shape once they can recognize it from a different viewpoint.[100]

An earlier common way to deal with this problem is to train the network on transformed data in different orientations, scales, lighting, etc. so that the network can cope with these variations. This is computationally intensive for large data-sets. The alternative is to use a hierarchy of coordinate frames and use a group of neurons to represent a conjunction of the shape of the feature and its pose relative to the retina. The pose relative to the retina is the relationship between the coordinate frame of the retina and the intrinsic features' coordinate frame.[101]

Thus, one way to represent something is to embed the coordinate frame within it. This allows large features to be recognized by using the consistency of the poses of their parts (e.g. nose and mouth poses make a consistent prediction of the pose of the whole face). This approach ensures that the higher-level entity (e.g. face) is present when the lower-level (e.g. nose and mouth) agree on its prediction of the pose. The vectors of neuronal activity that represent pose ("pose vectors") allow spatial transformations modeled as linear operations that make it easier for the network to learn the hierarchy of visual entities and generalize across viewpoints. This is similar to the way the human visual system imposes coordinate frames in order to represent shapes.[102]

Applications

Image recognition

CNNs are often used in image recognition systems. In 2012, an error rate of 0.23% on the MNIST database was reported.[23] Another paper on using CNN for image classification reported that the learning process was "surprisingly fast"; in the same paper, the best published results as of 2011 were achieved in the MNIST database and the NORB database.[64] Subsequently, a similar CNN called AlexNet[103] won the ImageNet Large Scale Visual Recognition Challenge 2012.

When applied to facial recognition, CNNs achieved a large decrease in error rate.[104] Another paper reported a 97.6% recognition rate on "5,600 still images of more than 10 subjects".[17] CNNs were used to assess video quality in an objective way after manual training; the resulting system had a very low root mean square error.[105]

The ImageNet Large Scale Visual Recognition Challenge is a benchmark in object classification and detection, with millions of images and hundreds of object classes. In the ILSVRC 2014,[106] a large-scale visual recognition challenge, almost every highly ranked team used CNN as their basic framework. The winner GoogLeNet[107] (the foundation of DeepDream) increased the mean average precision of object detection to 0.439329, and reduced classification error to 0.06656, the best result to date. Its network applied more than 30 layers. That performance of convolutional neural networks on the ImageNet tests was close to that of humans.[108] The best algorithms still struggle with objects that are small or thin, such as a small ant on a stem of a flower or a person holding a quill in their hand. They also have trouble with images that have been distorted with filters, an increasingly common phenomenon with modern digital cameras. By contrast, those kinds of images rarely trouble humans. Humans, however, tend to have trouble with other issues. For example, they are not good at classifying objects into fine-grained categories such as the particular breed of dog or species of bird, whereas convolutional neural networks handle this.

In 2015, a many-layered CNN demonstrated the ability to spot faces from a wide range of angles, including upside down, even when partially occluded, with competitive performance. The network was trained on a database of 200,000 images that included faces at various angles and orientations and a further 20 million images without faces. They used batches of 128 images over 50,000 iterations.[109]

Video analysis

Compared to image data domains, there is relatively little work on applying CNNs to video classification. Video is more complex than images since it has another (temporal) dimension. However, some extensions of CNNs into the video domain have been explored. One approach is to treat space and time as equivalent dimensions of the input and perform convolutions in both time and space.[110] [111] Another way is to fuse the features of two convolutional neural networks, one for the spatial and one for the temporal stream.[112] [113] [114] Long short-term memory (LSTM) recurrent units are typically incorporated after the CNN to account for inter-frame or inter-clip dependencies.[115] [116] Unsupervised learning schemes for training spatio-temporal features have been introduced, based on Convolutional Gated Restricted Boltzmann Machines[117] and Independent Subspace Analysis.[118] Its application can be seen in text-to-video model.

Natural language processing

CNNs have also been explored for natural language processing. CNN models are effective for various NLP problems and achieved excellent results in semantic parsing,[119] search query retrieval,[120] sentence modeling,[121] classification,[122] prediction[123] and other traditional NLP tasks.[124] Compared to traditional language processing methods such as recurrent neural networks, CNNs can represent different contextual realities of language that do not rely on a series-sequence assumption, while RNNs are better suitable when classical time series modeling is required.[125] [126] [127] [128]

Anomaly detection

A CNN with 1-D convolutions was used on time series in the frequency domain (spectral residual) by an unsupervised model to detect anomalies in the time domain.[129]

Drug discovery

CNNs have been used in drug discovery. Predicting the interaction between molecules and biological proteins can identify potential treatments. In 2015, Atomwise introduced AtomNet, the first deep learning neural network for structure-based drug design.[130] The system trains directly on 3-dimensional representations of chemical interactions. Similar to how image recognition networks learn to compose smaller, spatially proximate features into larger, complex structures,[131] AtomNet discovers chemical features, such as aromaticity, sp3 carbons, and hydrogen bonding. Subsequently, AtomNet was used to predict novel candidate biomolecules for multiple disease targets, most notably treatments for the Ebola virus[132] and multiple sclerosis.[133]

Checkers game

CNNs have been used in the game of checkers. From 1999 to 2001, Fogel and Chellapilla published papers showing how a convolutional neural network could learn to play checker using co-evolution. The learning process did not use prior human professional games, but rather focused on a minimal set of information contained in the checkerboard: the location and type of pieces, and the difference in number of pieces between the two sides. Ultimately, the program (Blondie24) was tested on 165 games against players and ranked in the highest 0.4%.[134] [135] It also earned a win against the program Chinook at its "expert" level of play.[136]

Go

CNNs have been used in computer Go. In December 2014, Clark and Storkey published a paper showing that a CNN trained by supervised learning from a database of human professional games could outperform GNU Go and win some games against Monte Carlo tree search Fuego 1.1 in a fraction of the time it took Fuego to play.[137] Later it was announced that a large 12-layer convolutional neural network had correctly predicted the professional move in 55% of positions, equalling the accuracy of a 6 dan human player. When the trained convolutional network was used directly to play games of Go, without any search, it beat the traditional search program GNU Go in 97% of games, and matched the performance of the Monte Carlo tree search program Fuego simulating ten thousand playouts (about a million positions) per move.[138]

A couple of CNNs for choosing moves to try ("policy network") and evaluating positions ("value network") driving MCTS were used by AlphaGo, the first to beat the best human player at the time.[139]

Time series forecasting

Recurrent neural networks are generally considered the best neural network architectures for time series forecasting (and sequence modeling in general), but recent studies show that convolutional networks can perform comparably or even better.[140] [11] Dilated convolutions[141] might enable one-dimensional convolutional neural networks to effectively learn time series dependences.[142] Convolutions can be implemented more efficiently than RNN-based solutions, and they do not suffer from vanishing (or exploding) gradients.[143] Convolutional networks can provide an improved forecasting performance when there are multiple similar time series to learn from.[144] CNNs can also be applied to further tasks in time series analysis (e.g., time series classification[145] or quantile forecasting[146]).

Cultural heritage and 3D-datasets

As archaeological findings such as clay tablets with cuneiform writing are increasingly acquired using 3D scanners, benchmark datasets are becoming available, including HeiCuBeDa providing almost 2000 normalized 2-D and 3-D datasets prepared with the GigaMesh Software Framework. So curvature-based measures are used in conjunction with geometric neural networks (GNNs), e.g. for period classification of those clay tablets being among the oldest documents of human history.

Fine-tuning

For many applications, training data is not very available. Convolutional neural networks usually require a large amount of training data in order to avoid overfitting. A common technique is to train the network on a larger data set from a related domain. Once the network parameters have converged an additional training step is performed using the in-domain data to fine-tune the network weights, this is known as transfer learning. Furthermore, this technique allows convolutional network architectures to successfully be applied to problems with tiny training sets.[147]

Human interpretable explanations

End-to-end training and prediction are common practice in computer vision. However, human interpretable explanations are required for critical systems such as a self-driving cars.[148] With recent advances in visual salience, spatial attention, and temporal attention, the most critical spatial regions/temporal instants could be visualized to justify the CNN predictions.[149] [150]

Related architectures

Deep Q-networks

A deep Q-network (DQN) is a type of deep learning model that combines a deep neural network with Q-learning, a form of reinforcement learning. Unlike earlier reinforcement learning agents, DQNs that utilize CNNs can learn directly from high-dimensional sensory inputs via reinforcement learning.[151]

Preliminary results were presented in 2014, with an accompanying paper in February 2015.[152] The research described an application to Atari 2600 gaming. Other deep reinforcement learning models preceded it.[153]

Deep belief networks

See main article: Deep belief network. Convolutional deep belief networks (CDBN) have structure very similar to convolutional neural networks and are trained similarly to deep belief networks. Therefore, they exploit the 2D structure of images, like CNNs do, and make use of pre-training like deep belief networks. They provide a generic structure that can be used in many image and signal processing tasks. Benchmark results on standard image datasets like CIFAR[154] have been obtained using CDBNs.[155]

Neural abstraction pyramid

The feed-forward architecture of convolutional neural networks was extended in the neural abstraction pyramid[156] by lateral and feedback connections. The resulting recurrent convolutional network allows for the flexible incorporation of contextual information to iteratively resolve local ambiguities. In contrast to previous models, image-like outputs at the highest resolution were generated, e.g., for semantic segmentation, image reconstruction, and object localization tasks.

Notable libraries

A library for convolutional neural networks. Created by the Berkeley Vision and Learning Center (BVLC). It supports both CPU and GPU. Developed in C++, and has Python and MATLAB wrappers.

Deep learning in Java and Scala on multi-GPU-enabled Spark. A general-purpose deep learning library for the JVM production stack running on a C++ scientific computing engine. Allows the creation of custom layers. Integrates with Hadoop and Kafka.

A toolkit for making real world machine learning and data analysis applications in C++.

A deep learning toolkit written by Microsoft with several unique features enhancing scalability over multiple nodes. It supports full-fledged interfaces for training in C++ and Python and with additional support for model inference in C# and Java.

Apache 2.0-licensed Theano-like library with support for CPU, GPU, Google's proprietary tensor processing unit (TPU),[157] and mobile devices.

The reference deep-learning library for Python with an API largely compatible with the popular NumPy library. Allows user to write symbolic mathematical expressions, then automatically generates their derivatives, saving the user from having to code gradients or backpropagation. These symbolic expressions are automatically compiled to CUDA code for a fast, on-the-GPU implementation.

A scientific computing framework with wide support for machine learning algorithms, written in C and Lua.

See also

External links

Notes and References

  1. LeCun . Yann . Bengio . Yoshua . Hinton . Geoffrey . 2015-05-28 . Deep learning . Nature . 521 . 7553 . 436–444 . 10.1038/nature14539 . 1476-4687 . 26017442. 2015Natur.521..436L .
  2. Book: Venkatesan . Ragav . Convolutional Neural Networks in Visual Computing: A Concise Guide . Li . Baoxin . 2017-10-23 . CRC Press . 978-1-351-65032-8 . en . 2020-12-13 . 2023-10-16 . https://web.archive.org/web/20231016190415/https://books.google.com/books?id=bAM7DwAAQBAJ&q=vanishing+gradient#v=snippet&q=vanishing%20gradient&f=false . live .
  3. Book: Balas . Valentina E. . Recent Trends and Advances in Artificial Intelligence and Internet of Things . Kumar . Raghvendra . Srivastava . Rajshree . 2019-11-19 . Springer Nature . 978-3-030-32644-9 . en . 2020-12-13 . 2023-10-16 . https://web.archive.org/web/20231016190414/https://books.google.com/books?id=XRS_DwAAQBAJ&q=exploding+gradient#v=snippet&q=exploding%20gradient&f=false . live .
  4. Zhang. Yingjie. Soon. Hong Geok. Ye. Dongsen. Fuh. Jerry Ying Hsi. Zhu. Kunpeng. September 2020. Powder-Bed Fusion Process Monitoring by Machine Vision With Hybrid Convolutional Neural Networks. IEEE Transactions on Industrial Informatics. 16. 9. 5769–5779. 10.1109/TII.2019.2956078. 213010088. 1941-0050. 2023-08-12. 2023-07-31. https://web.archive.org/web/20230731120013/https://ieeexplore.ieee.org/document/8913613/. live.
  5. Chervyakov. N.I.. Lyakhov. P.A.. Deryabin. M.A.. Nagornov. N.N.. Valueva. M.V.. Valuev. G.V.. September 2020. Residue Number System-Based Solution for Reducing the Hardware Cost of a Convolutional Neural Network. Neurocomputing. en. 407. 439–453. 10.1016/j.neucom.2020.04.018. 219470398. Convolutional neural networks represent deep learning architectures that are currently used in a wide range of applications, including computer vision, speech recognition, malware dedection, time series analysis in finance, and many others.. 2023-08-12. 2023-06-29. https://web.archive.org/web/20230629155646/https://linkinghub.elsevier.com/retrieve/pii/S092523122030583X. live.
  6. Book: Habibi, Aghdam, Hamed . Guide to convolutional neural networks : a practical application to traffic-sign detection and classification . Heravi, Elnaz Jahani . 9783319575490 . Cham, Switzerland . 987790957 . 2017-05-30.
  7. Valueva . M.V. . Nagornov . N.N. . Lyakhov . P.A. . Valuev . G.V. . Chervyakov . N.I. . Application of the residue number system to reduce hardware costs of the convolutional neural network implementation . Mathematics and Computers in Simulation . Elsevier BV . 177 . 2020 . 0378-4754 . 10.1016/j.matcom.2020.04.031 . 232–243 . 218955622 . Convolutional neural networks are a promising tool for solving the problem of pattern recognition..
  8. Book: Deep content-based music recommendation . van den Oord . Aaron . Dieleman . Sander . Schrauwen . Benjamin . 2013-01-01 . Curran Associates, Inc. . Burges . C. J. C. . 2643–2651 . Bottou . L. . Welling . M. . Ghahramani . Z. . Weinberger . K. Q. . 2022-03-31 . 2022-03-07 . https://web.archive.org/web/20220307172303/https://proceedings.neurips.cc/paper/2013/file/b3ba8f1bee1238a2f37603d90b58898d-Paper.pdf . live .
  9. Book: Collobert . Ronan . Weston . Jason . Proceedings of the 25th international conference on Machine learning - ICML '08 . A unified architecture for natural language processing . 2008-01-01 . New York, NY, US . ACM . 160–167 . 10.1145/1390156.1390177 . 978-1-60558-205-4 . 2617020.
  10. Book: Avilov . Oleksii . Rimbert . Sebastien . Popov . Anton . Bougrain . Laurent . 2020 42nd Annual International Conference of the IEEE Engineering in Medicine & Biology Society (EMBC) . Deep Learning Techniques to Improve Intraoperative Awareness Detection from Electroencephalographic Signals . July 2020 . https://ieeexplore.ieee.org/document/9176228 . 2020 . Montreal, QC, Canada . IEEE . 142–145 . 10.1109/EMBC44109.2020.9176228 . 33017950 . 978-1-7281-1990-8 . 221386616 . 2023-07-21 . 2022-05-19 . https://web.archive.org/web/20220519135428/https://hal.inria.fr/hal-02920320/file/Avilov_EMBC2020.pdf . live .
  11. Book: Tsantekidis . Avraam . Passalis . Nikolaos . Tefas . Anastasios . Kanniainen . Juho . Gabbouj . Moncef . Iosifidis . Alexandros . 2017 IEEE 19th Conference on Business Informatics (CBI) . Forecasting Stock Prices from the Limit Order Book Using Convolutional Neural Networks . July 2017 . Thessaloniki, Greece . IEEE . 7–12 . 10.1109/CBI.2017.23 . 978-1-5386-3035-8 . 4950757.
  12. Zhang . Wei . 1988 . Shift-invariant pattern recognition neural network and its optical architecture . Proceedings of Annual Conference of the Japan Society of Applied Physics . 2020-06-22 . 2020-06-23 . https://web.archive.org/web/20200623051222/https://drive.google.com/file/d/1nN_5odSG_QVae54EsQN_qSz-0ZsX6wA0/view?usp=sharing . live .
  13. Zhang . Wei . 1990 . Parallel distributed processing model with local space-invariant interconnections and its optical architecture . Applied Optics . 29 . 32 . 4790–7 . 10.1364/AO.29.004790 . 20577468 . 1990ApOpt..29.4790Z . 2016-09-22 . 2017-02-06 . https://web.archive.org/web/20170206111407/https://drive.google.com/file/d/0B65v6Wo67Tk5ODRzZmhSR29VeDg/view?usp=sharing . live .
  14. Book: Mouton . Coenraad . Myburgh . Johannes C. . Davel . Marelie H. . Artificial Intelligence Research . Stride and Translation Invariance in CNNs . 2020 . Gerber . Aurona . https://link.springer.com/chapter/10.1007%2F978-3-030-66151-9_17 . Communications in Computer and Information Science . 1342 . en . Cham . Springer International Publishing . 267–281 . 10.1007/978-3-030-66151-9_17 . 2103.10097 . 978-3-030-66151-9 . 232269854 . 2021-03-26 . 2021-06-27 . https://web.archive.org/web/20210627074505/https://link.springer.com/chapter/10.1007%2F978-3-030-66151-9_17 . live .
  15. Kurtzman . Thomas . August 20, 2019 . Hidden bias in the DUD-E dataset leads to misleading performance of deep learning in structure-based virtual screening . PLOS ONE. 14 . 8 . e0220113 . 10.1371/journal.pone.0220113 . 31430292 . 6701836 . 2019PLoSO..1420113C . free .
  16. Fukushima . K. . 2007 . Neocognitron . Scholarpedia . 2 . 1 . 1717 . 2007SchpJ...2.1717F . 10.4249/scholarpedia.1717 . free.
  17. Matusugu . Masakazu . 2003 . Subject independent facial expression recognition with robust face detection using a convolutional neural network . Neural Networks . 16 . 5 . 555–559 . 10.1016/S0893-6080(03)00115-1 . 12850007 . Katsuhiko Mori . Yusuke Mitari . Yuji Kaneda . 17 November 2013 . 13 December 2013 . https://web.archive.org/web/20131213022740/http://www.iro.umontreal.ca/~pift6080/H09/documents/papers/sparse/matsugo_etal_face_expression_conv_nnet.pdf . live .
  18. Convolutional Neural Networks Demystified: A Matched Filtering Perspective Based Tutorial https://arxiv.org/abs/2108.11663v3
  19. Web site: Convolutional Neural Networks (LeNet) – DeepLearning 0.1 documentation . DeepLearning 0.1 . LISA Lab . 31 August 2013 . 28 December 2017 . https://web.archive.org/web/20171228091645/http://deeplearning.net/tutorial/lenet.html . dead .
  20. Chollet . François . 2017-04-04 . Xception: Deep Learning with Depthwise Separable Convolutions . cs.CV . 1610.02357 .
  21. Web site: . Alex . ImageNet Classification with Deep Convolutional Neural Networks . 17 November 2013 . 25 April 2021 . https://web.archive.org/web/20210425025127/http://www.image-net.org/static_files/files/supervision.pdf . live .
  22. A Neural Network for Speaker-Independent Isolated Word Recognition . Yamaguchi . Kouichi . Sakamoto . Kenji . Akabane . Toshio . Fujimoto . Yoshiji . November 1990 . Kobe, Japan . First International Conference on Spoken Language Processing (ICSLP 90) . 2019-09-04 . 2021-03-07 . https://web.archive.org/web/20210307233750/https://www.isca-speech.org/archive/icslp_1990/i90_1077.html . dead .
  23. Book: Ciresan . Dan . Ueli . Meier . Jürgen . Schmidhuber . 2012 IEEE Conference on Computer Vision and Pattern Recognition . Multi-column deep neural networks for image classification . June 2012 . 3642–3649 . 10.1109/CVPR.2012.6248110 . 1202.2745 . 978-1-4673-1226-4 . 812295155 . Institute of Electrical and Electronics Engineers (IEEE) . New York, NY . 10.1.1.300.3283 . 2161592.
  24. Yu . Fisher . Koltun . Vladlen . 2016-04-30 . Multi-Scale Context Aggregation by Dilated Convolutions . cs.CV . 1511.07122 .
  25. Chen . Liang-Chieh . Papandreou . George . Schroff . Florian . Adam . Hartwig . 2017-12-05 . Rethinking Atrous Convolution for Semantic Image Segmentation . cs.CV . 1706.05587 .
  26. Duta . Ionut Cosmin . Georgescu . Mariana Iuliana . Ionescu . Radu Tudor . 2021-08-16 . Contextual Convolutional Neural Networks . cs.CV . 2108.07387 .
  27. Web site: LeNet-5, convolutional neural networks . LeCun . Yann . 16 November 2013 . 24 February 2021 . https://web.archive.org/web/20210224225707/http://yann.lecun.com/exdb/lenet/ . live .
  28. Book: Zeiler . Matthew D. . Taylor . Graham W. . Fergus . Rob . Adaptive deconvolutional networks for mid and high level feature learning . November 2011 . 2018–2025 . 2011 International Conference on Computer Vision . http://dx.doi.org/10.1109/iccv.2011.6126474 . IEEE . 10.1109/iccv.2011.6126474. 978-1-4577-1102-2 .
  29. Odena . Augustus . Dumoulin . Vincent . Olah . Chris . 2016-10-17 . Deconvolution and Checkerboard Artifacts . Distill . en . 1 . 10 . e3 . 10.23915/distill.00003 . 2476-0757. free .
  30. van Dyck . Leonard Elia . Kwitt . Roland . Denzler . Sebastian Jochen . Gruber . Walter Roland . 2021 . Comparing Object Recognition in Humans and Deep Convolutional Neural Networks—An Eye Tracking Study . Frontiers in Neuroscience . 15 . 750639 . 10.3389/fnins.2021.750639 . 34690686 . 8526843 . 1662-453X . free .
  31. Receptive fields and functional architecture of monkey striate cortex . The Journal of Physiology . 1968-03-01 . 0022-3751 . 1557912 . 4966457 . 215–243 . 195 . 1 . D. H. . Hubel . T. N. . Wiesel . 10.1113/jphysiol.1968.sp008455.
  32. Book: Brain and visual perception: the story of a 25-year collaboration. David H. Hubel and Torsten N. Wiesel. Oxford University Press US. 2005. 978-0-19-517618-6. 106. 2019-01-18. 2023-10-16. https://web.archive.org/web/20231016190414/https://books.google.com/books?id=8YrxWojxUA4C&pg=PA106#v=onepage&q&f=false. live.
  33. 1363130 . 14403679 . 148 . 3 . Receptive fields of single neurones in the cat's striate cortex . October 1959 . J. Physiol. . 574–91 . Hubel . DH . Wiesel . TN . 10.1113/jphysiol.1959.sp006308.
  34. Fukushima . K. . 1969 . Visual feature extraction by a multilayered network of analog threshold elements . IEEE Transactions on Systems Science and Cybernetics . 5 . 4 . 322–333 . 10.1109/TSSC.1969.300225.
  35. 1710.05941 . cs.NE . Prajit . Ramachandran . Zoph . Barret . Searching for Activation Functions . October 16, 2017 . Quoc . V. Le.
  36. Fukushima . Kunihiko . October 1979 . 位置ずれに影響されないパターン認識機構の神経回路のモデル --- ネオコグニトロン --- . Neural network model for a mechanism of pattern recognition unaffected by shift in position — Neocognitron — . Trans. IECE . ja . J62-A . 10 . 658–665.
  37. Fukushima . Kunihiko . Neocognitron: A Self-organizing Neural Network Model for a Mechanism of Pattern Recognition Unaffected by Shift in Position . Biological Cybernetics . 1980 . 36 . 4 . 193–202 . 16 November 2013 . 10.1007/BF00344251 . 7370364 . 206775608 . 3 June 2014 . https://web.archive.org/web/20140603013137/http://www.cs.princeton.edu/courses/archive/spr08/cos598B/Readings/Fukushima1980.pdf . live .
  38. Book: 1993 (4th) International Conference on Computer Vision. J . Weng . N . Ahuja . TS . Huang. Learning recognition and segmentation of 3-D objects from 2-D images . https://ieeexplore.ieee.org/document/378228. IEEE. 121–128 . 1993. 10.1109/ICCV.1993.378228 . 0-8186-3870-2. 8619176 .
  39. Schmidhuber . Jürgen . 2015 . Deep Learning . live . Scholarpedia . 10 . 11 . 1527–54 . 10.1.1.76.1541 . 10.1162/neco.2006.18.7.1527 . 16764513 . 2309950 . https://web.archive.org/web/20160419024349/http://www.scholarpedia.org/article/Deep_Learning . 2016-04-19 . 2019-01-20.
  40. Homma . Toshiteru . Les Atlas . Robert Marks II . 1987 . An Artificial Neural Network for Spatio-Temporal Bipolar Patterns: Application to Phoneme Classification . Advances in Neural Information Processing Systems . 1 . 31–40 . 2022-03-31 . 2022-03-31 . https://web.archive.org/web/20220331211142/https://proceedings.neurips.cc/paper/1987/file/98f13708210194c475687be6106a3b84-Paper.pdf . live . The notion of convolution or correlation used in the models presented is popular in engineering disciplines and has been applied extensively to designing filters, control systems, etc..
  41. Phoneme Recognition Using Time-Delay Neural Networks . Waibel . Alex . December 1987 . Tokyo, Japan . Meeting of the Institute of Electrical, Information and Communication Engineers (IEICE) .
  42. [Alex Waibel|Alexander Waibel]
  43. Encyclopedia: LeCun . Yann . Bengio . Yoshua . Arbib . Michael A. . Convolutional networks for images, speech, and time series . The handbook of brain theory and neural networks . Second . 1995 . The MIT press . 276–278 . 2019-12-03 . 2020-07-28 . https://web.archive.org/web/20200728164116/https://www.researchgate.net/publication/2453996_Convolutional_Networks_for_Images_Speech_and_Time-Series . live .
  44. John B. Hampshire and Alexander Waibel, Connectionist Architectures for Multi-Speaker Phoneme Recognition , Advances in Neural Information Processing Systems, 1990, Morgan Kaufmann.
  45. A Study on Data Augmentation of Reverberant Speech for Robust Speech Recognition . Ko . Tom . Peddinti . Vijayaditya . Povey . Daniel . Seltzer . Michael L. . Khudanpur . Sanjeev . March 2018 . New Orleans, LA, US . The 42nd IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP 2017) . 2019-09-04 . 2018-07-08 . https://web.archive.org/web/20180708072725/http://danielpovey.com/files/2017_icassp_reverberation.pdf . live .
  46. Denker, J S, Gardner, W R, Graf, H. P, Henderson, D, Howard, R E, Hubbard, W, Jackel, L D, BaIrd, H S, and Guyon (1989) Neural network recognizer for hand-written zip code digits, AT&T Bell Laboratories
  47. Y. LeCun, B. Boser, J. S. Denker, D. Henderson, R. E. Howard, W. Hubbard, L. D. Jackel, Backpropagation Applied to Handwritten Zip Code Recognition ; AT&T Bell Laboratories
  48. Book: Learning algorithms for classification: A comparison on handwritten digit recognition. Lecun, Y.. Jackel, L. D.. Bottou, L.. Cortes, C.. Denker, J. S.. Drucker, H.. Guyon, I.. Muller, U. A.. Sackinger, E.. Simard, P.. Vapnik, V.. 261–276. World Scientific. August 1995. 10.1142/2808. 978-981-02-2324-3. live. https://web.archive.org/web/20230502220356/http://yann.lecun.com/exdb/publis/pdf/lecun-95a.pdf. 2 May 2023.
  49. Lecun . Y. . Bottou . L. . Bengio . Y. . Haffner . P. . November 1998 . Gradient-based learning applied to document recognition . Proceedings of the IEEE . 86 . 11 . 2278–2324 . 10.1109/5.726791.
  50. Zhang . Wei . 1991 . Error Back Propagation with Minimum-Entropy Weights: A Technique for Better Generalization of 2-D Shift-Invariant NNs . Proceedings of the International Joint Conference on Neural Networks . 2016-09-22 . 2017-02-06 . https://web.archive.org/web/20170206155801/https://drive.google.com/file/d/0B65v6Wo67Tk5dkJTcEMtU2c5Znc/view?usp=sharing . live .
  51. Zhang . Wei . 1991 . Image processing of human corneal endothelium based on a learning network . Applied Optics . 30 . 29 . 4211–7 . 10.1364/AO.30.004211 . 20706526 . 1991ApOpt..30.4211Z . 2016-09-22 . 2017-02-06 . https://web.archive.org/web/20170206122612/https://drive.google.com/file/d/0B65v6Wo67Tk5cm5DTlNGd0NPUmM/view?usp=sharing . live .
  52. Zhang . Wei . 1994 . Computerized detection of clustered microcalcifications in digital mammograms using a shift-invariant artificial neural network . Medical Physics . 21 . 4 . 517–24 . 10.1118/1.597177 . 8058017 . 1994MedPh..21..517Z . 2016-09-22 . 2017-02-06 . https://web.archive.org/web/20170206030321/https://drive.google.com/file/d/0B65v6Wo67Tk5Ml9qeW5nQ3poVTQ/view?usp=sharing . live .
  53. Daniel Graupe, Ruey Wen Liu, George S Moschytz."Applications of neural networks to medical signal processing ". In Proc. 27th IEEE Decision and Control Conf., pp. 343–347, 1988.
  54. Daniel Graupe, Boris Vern, G. Gruener, Aaron Field, and Qiu Huang. "Decomposition of surface EMG signals into single fiber action potentials by means of neural network ". Proc. IEEE International Symp. on Circuits and Systems, pp. 1008–1011, 1989.
  55. Qiu Huang, Daniel Graupe, Yi Fang Huang, Ruey Wen Liu."Identification of firing patterns of neuronal signals." In Proc. 28th IEEE Decision and Control Conf., pp. 266–271, 1989. https://ieeexplore.ieee.org/document/70115
  56. Oh . KS . Jung . K . GPU implementation of neural networks. . Pattern Recognition . 2004 . 37 . 6 . 1311–1314 . 10.1016/j.patcog.2004.01.013 . 2004PatRe..37.1311O.
  57. Dave Steinkraus . Patrice Simard . Ian Buck . 12th International Conference on Document Analysis and Recognition (ICDAR 2005) . 2005 . 1115–1119 . https://www.computer.org/csdl/proceedings-article/icdar/2005/24201115/12OmNylKAVX . Using GPUs for Machine Learning Algorithms . 10.1109/ICDAR.2005.251 . 2022-03-31 . 2022-03-31 . https://web.archive.org/web/20220331211138/https://www.computer.org/csdl/proceedings-article/icdar/2005/24201115/12OmNylKAVX . live .
  58. Book: Kumar Chellapilla . Sid Puri . Patrice Simard . Lorette . Guy . Tenth International Workshop on Frontiers in Handwriting Recognition . 2006 . Suvisoft . https://hal.inria.fr/inria-00112631/document . High Performance Convolutional Neural Networks for Document Processing . 2016-03-14 . 2020-05-18 . https://web.archive.org/web/20200518193413/https://hal.inria.fr/inria-00112631/document . live .
  59. Hinton . GE . Osindero . S . Teh . YW . A fast learning algorithm for deep belief nets. . Neural Computation . Jul 2006 . 18 . 7 . 1527–54 . 16764513 . 10.1162/neco.2006.18.7.1527 . 10.1.1.76.1541 . 2309950.
  60. Bengio . Yoshua . Lamblin . Pascal . Popovici . Dan . Larochelle . Hugo . Greedy Layer-Wise Training of Deep Networks . Advances in Neural Information Processing Systems . 2007 . 153–160 . 2022-03-31 . 2022-06-02 . https://web.archive.org/web/20220602144141/https://proceedings.neurips.cc/paper/2006/file/5da713a690c067105aeb2fae32403405-Paper.pdf . live .
  61. Ranzato . MarcAurelio . Poultney . Christopher . Chopra . Sumit . LeCun . Yann . Efficient Learning of Sparse Representations with an Energy-Based Model . Advances in Neural Information Processing Systems . 2007 . 2014-06-26 . 2016-03-22 . https://web.archive.org/web/20160322112400/http://yann.lecun.com/exdb/publis/pdf/ranzato-06.pdf . live .
  62. Book: Large-scale deep unsupervised learning using graphics processors. Raina . R . Madhavan . A . Ng . Andrew. Proceedings of the 26th Annual International Conference on Machine Learning . http://robotics.stanford.edu/~ang/papers/icml09-LargeScaleUnsupervisedDeepLearningGPU.pdf. ICML '09: Proceedings of the 26th Annual International Conference on Machine Learning. 14 June 2009. 873–880 . 22 December 2023. 10.1145/1553374.1553486. 9781605585161 . 392458 . live. 8 December 2020. https://web.archive.org/web/20201208104513/http://robotics.stanford.edu/~ang/papers/icml09-LargeScaleUnsupervisedDeepLearningGPU.pdf.
  63. Ciresan . Dan . Meier . Ueli . Gambardella . Luca . Schmidhuber . Jürgen . Deep big simple neural nets for handwritten digit recognition. . Neural Computation . 2010 . 22 . 12 . 3207–3220 . 10.1162/NECO_a_00052 . 20858131 . 1003.0358 . 1918673.
  64. Ciresan . Dan . Ueli Meier . Jonathan Masci . Luca M. Gambardella . Jurgen Schmidhuber . Flexible, High Performance Convolutional Neural Networks for Image Classification . Proceedings of the Twenty-Second International Joint Conference on Artificial Intelligence-Volume Volume Two . 2011 . 2 . 1237–1242 . 17 November 2013 . 5 April 2022 . https://web.archive.org/web/20220405190128/https://people.idsia.ch/~juergen/ijcai2011.pdf . live .
  65. Web site: IJCNN 2011 Competition result table . OFFICIAL IJCNN2011 COMPETITION . en-US . 2019-01-14 . 2010 . 2021-01-17 . https://web.archive.org/web/20210117024729/https://benchmark.ini.rub.de/gtsrb_results.html . live .
  66. Web site: History of computer vision contests won by deep CNNs on GPU . Schmidhuber . Jürgen . en-US . 14 January 2019 . 17 March 2017 . 19 December 2018 . https://web.archive.org/web/20181219224934/http://people.idsia.ch/~juergen/computer-vision-contests-won-by-gpu-cnns.html . live .
  67. Viebke . Andre . Memeti . Suejb . Pllana . Sabri . Abraham . Ajith . 2019 . CHAOS: a parallelization scheme for training convolutional neural networks on Intel Xeon Phi . The Journal of Supercomputing . 75 . 1 . 197–227 . 1702.07908 . 10.1007/s11227-017-1994-x . 14135321.
  68. Viebke . Andre . Pllana . Sabri . 2015 . 2015 IEEE 17th International Conference on High Performance Computing and Communications, 2015 IEEE 7th International Symposium on Cyberspace Safety and Security, and 2015 IEEE 12th International Conference on Embedded Software and Systems . IEEE 2015 . 758–765 . 10.1109/HPCC-CSS-ICESS.2015.45 . 978-1-4799-8937-9 . https://web.archive.org/web/20230306003530/http://lnu.diva-portal.org/smash/record.jsf?pid=diva2:877421&dswid=4277 . 2023-03-06 . 2022-03-31 . The Potential of the Intel (R) Xeon Phi for Supervised Deep Learning . IEEE Xplore . 15411954 . http://lnu.diva-portal.org/smash/record.jsf?pid=diva2%3A877421&dswid=4277 . live.
  69. Hinton . Geoffrey . 2012 . ImageNet Classification with Deep Convolutional Neural Networks . NIPS'12: Proceedings of the 25th International Conference on Neural Information Processing Systems - Volume 1 . 1 . 1097–1105 . ACM . 2021-03-26 . 2019-12-20 . https://web.archive.org/web/20191220014019/https://dl.acm.org/citation.cfm?id=2999134.2999257 . live .
  70. Book: Géron. Aurélien. Hands-on Machine Learning with Scikit-Learn, Keras, and TensorFlow. 2019. O'Reilly Media. Sebastopol, CA. 978-1-492-03264-9., pp. 448
  71. When applied to other types of data than image data, such as sound data, "spatial position" may variously correspond to different points in the time domain, frequency domain, or other mathematical spaces.
  72. Web site: CS231n Convolutional Neural Networks for Visual Recognition . cs231n.github.io . 2017-04-25 . 2019-10-23 . https://web.archive.org/web/20191023031945/https://cs231n.github.io/convolutional-networks/ . live .
  73. hence the name "convolutional layer"
  74. Nirthika . Rajendran . Manivannan . Siyamalan . Ramanan . Amirthalingam . Wang . Ruixuan . 2022-04-01 . Pooling in convolutional neural networks for medical image analysis: a survey and an empirical study . Neural Computing and Applications . en . 34 . 7 . 5321–5347 . 10.1007/s00521-022-06953-8 . 1433-3058 . 8804673 . 35125669.
  75. Azulay . Aharon . Weiss . Yair . 2019 . Why do deep convolutional networks generalize so poorly to small image transformations? . Journal of Machine Learning Research . 20 . 184 . 1–25 . 1533-7928 . 2022-03-31 . 2022-03-31 . https://web.archive.org/web/20220331211138/https://jmlr.org/papers/v20/19-519.html . live .
  76. Evaluation of Pooling Operations in Convolutional Architectures for Object Recognition. Scherer. Dominik. Müller. Andreas C.. Behnke. Sven. 2010. Springer. Artificial Neural Networks (ICANN), 20th International Conference on. 92–101. Thessaloniki, Greece. 2016-12-28. 2018-04-03. https://web.archive.org/web/20180403185041/http://ais.uni-bonn.de/papers/icann2010_maxpool.pdf. live.
  77. Fractional Max-Pooling . 1412.6071 . 2014-12-18 . Benjamin . Graham . cs.CV.
  78. Striving for Simplicity: The All Convolutional Net . 1412.6806 . 2014-12-21 . Jost Tobias . Springenberg . Alexey . Dosovitskiy . Thomas . Brox . Martin . Riedmiller . cs.LG.
  79. Ma . Zhanyu . Chang . Dongliang . Xie . Jiyang . Ding . Yifeng . Wen . Shaoguo . Li . Xiaoxu . Si . Zhongwei . Guo . Jun . Fine-Grained Vehicle Classification With Channel Max Pooling Modified CNNs . IEEE Transactions on Vehicular Technology . Institute of Electrical and Electronics Engineers (IEEE) . 68 . 4 . 2019 . 0018-9545 . 10.1109/tvt.2019.2899972 . 3224–3233. 86674074 .
  80. Zafar . Afia . Aamir . Muhammad . Mohd Nawi . Nazri . Arshad . Ali . Riaz . Saman . Alruban . Abdulrahman . Dutta . Ashit Kumar . Almotairi . Sultan . 2022-08-29 . A Comparison of Pooling Methods for Convolutional Neural Networks . Applied Sciences . en . 12 . 17 . 8643 . 10.3390/app12178643 . free . 2076-3417.
  81. Householder . Alston S. . June 1941 . A theory of steady-state activity in nerve-fiber networks: I. Definitions and preliminary lemmas . The Bulletin of Mathematical Biophysics . en . 3 . 2 . 63–69 . 10.1007/BF02478220 . 0007-4985.
  82. Krizhevsky . Alex . Sutskever . Ilya . Hinton . Geoffrey E. . 2017-05-24 . ImageNet classification with deep convolutional neural networks . Communications of the ACM . 60 . 6 . 84–90 . 10.1145/3065386 . 195908774 . 0001-0782 . 2018-12-04 . 2017-05-16 . https://web.archive.org/web/20170516174757/http://papers.nips.cc/paper/4824-imagenet-classification-with-deep-convolutional-neural-networks.pdf . live .
  83. Romanuke . Vadim . Appropriate number and allocation of ReLUs in convolutional neural networks . Research Bulletin of NTUU "Kyiv Polytechnic Institute" . 2017 . 1 . 1 . 69–78 . 10.20535/1810-0546.2017.1.88156 . free.
  84. Xavier Glorot . Antoine Bordes . . 2011 . Deep sparse rectifier neural networks . AISTATS . Rectifier and softplus activation functions. The second one is a smooth version of the first. . 2023-04-10 . 2016-12-13 . https://web.archive.org/web/20161213022121/http://jmlr.org/proceedings/papers/v15/glorot11a/glorot11a.pdf . dead .
  85. Krizhevsky . A. . Sutskever, I. . Hinton, G. E. . Imagenet classification with deep convolutional neural networks . Advances in Neural Information Processing Systems . 1 . 2012 . 1097–1105 . 2022-03-31 . 2022-03-31 . https://web.archive.org/web/20220331224736/https://proceedings.neurips.cc/paper/2012/file/c399862d3b9d6b76c8436e924a68c45b-Paper.pdf . live .
  86. So-called categorical data.
  87. Book: Ribeiro . Antonio H. . Schön . Thomas B.. ICASSP 2021 - 2021 IEEE International Conference on Acoustics, Speech and Signal Processing (ICASSP) . How Convolutional Neural Networks Deal with Aliasing . 2021 . 2755–2759 . 2102.07757 . 10.1109/ICASSP39728.2021.9414627. 978-1-7281-7605-5 . 231925012 .
  88. Book: Myburgh . Johannes C. . Mouton . Coenraad . Davel . Marelie H. . Artificial Intelligence Research . Tracking Translation Invariance in CNNS . 2020 . Gerber . Aurona . https://link.springer.com/chapter/10.1007%2F978-3-030-66151-9_18 . Communications in Computer and Information Science . 1342 . en . Cham . Springer International Publishing . 282–295 . 10.1007/978-3-030-66151-9_18 . 2104.05997 . 978-3-030-66151-9 . 233219976 . 2021-03-26 . 2022-01-22 . https://web.archive.org/web/20220122015258/http://link.springer.com/chapter/10.1007/978-3-030-66151-9_18 . live .
  89. Book: Richard, Zhang . Making Convolutional Networks Shift-Invariant Again . 2019-04-25 . 1106340711.
  90. Jadeberg, Simonyan, Zisserman, Kavukcuoglu . Max, Karen, Andrew, Koray . 2015 . Spatial Transformer Networks . Advances in Neural Information Processing Systems . 28 . NIPS . 2021-03-26 . 2021-07-25 . https://web.archive.org/web/20210725115312/https://proceedings.neurips.cc/paper/2015/file/33ceb07bf4eeb3da587e268d663aba1a-Paper.pdf . live .
  91. Book: E, Sabour, Sara Frosst, Nicholas Hinton, Geoffrey . Dynamic Routing Between Capsules . 2017-10-26 . 1106278545.
  92. 2019-06-01 . Inductive conformal predictor for convolutional neural networks: Applications to active learning for image classification . Pattern Recognition . en . 90 . 172–182 . 10.1016/j.patcog.2019.01.035 . 0031-3203 . Matiz . Sergio . Barner . Kenneth E. . Kenneth E. Barner . 2019PatRe..90..172M . 127253432 . 2021-09-29 . 2021-09-29 . https://web.archive.org/web/20210929092610/https://www.sciencedirect.com/science/article/abs/pii/S003132031930055X . live .
  93. Wieslander . Håkan . Harrison . Philip J. . Skogberg . Gabriel . Jackson . Sonya . Fridén . Markus . Karlsson . Johan . Spjuth . Ola . Wählby . Carolina . February 2021 . Deep Learning With Conformal Prediction for Hierarchical Analysis of Large-Scale Whole-Slide Tissue Images . IEEE Journal of Biomedical and Health Informatics . 25 . 2 . 371–380 . 10.1109/JBHI.2020.2996300 . 32750907 . 219885788 . 2168-2208 . free .
  94. Srivastava . Nitish . C. Geoffrey Hinton . Alex Krizhevsky . Ilya Sutskever . Ruslan Salakhutdinov . Dropout: A Simple Way to Prevent Neural Networks from overfitting . Journal of Machine Learning Research . 2014 . 15 . 1 . 1929–1958 . 2015-01-03 . 2016-01-19 . https://web.archive.org/web/20160119155849/http://www.cs.toronto.edu/~rsalakhu/papers/srivastava14a.pdf . live .
  95. Regularization of Neural Networks using DropConnect ICML 2013 JMLR W&CP . 1058–1066 . jmlr.org . 2015-12-17 . 2013-02-13 . 2017-08-12 . https://web.archive.org/web/20170812080411/http://proceedings.mlr.press/v28/wan13.html . live .
  96. Stochastic Pooling for Regularization of Deep Convolutional Neural Networks . 1301.3557 . 2013-01-15 . Matthew D. . Zeiler . Rob . Fergus . cs.LG.
  97. Best Practices for Convolutional Neural Networks Applied to Visual Document Analysis – Microsoft Research . Microsoft Research . 2015-12-17 . August 2003 . Platt . John . Steinkraus . Dave . Simard . Patrice Y. . 2017-11-07 . https://web.archive.org/web/20171107112839/https://www.microsoft.com/en-us/research/publication/best-practices-for-convolutional-neural-networks-applied-to-visual-document-analysis/?from=http%3A%2F%2Fresearch.microsoft.com%2Fapps%2Fpubs%2F%3Fid%3D68920 . live .
  98. Improving neural networks by preventing co-adaptation of feature detectors . 1207.0580 . Hinton . Geoffrey E. . Srivastava . Nitish . Krizhevsky . Alex . Sutskever . Ilya . Salakhutdinov . Ruslan R. . cs.NE . 2012.
  99. Web site: Dropout: A Simple Way to Prevent Neural Networks from Overfitting . jmlr.org . 2015-12-17 . 2016-03-05 . https://web.archive.org/web/20160305010425/http://jmlr.org/papers/v15/srivastava14a.html . live .
  100. Hinton . Geoffrey . 1979 . Some demonstrations of the effects of structural descriptions in mental imagery . Cognitive Science . 3 . 3 . 231–250 . 10.1016/s0364-0213(79)80008-7.
  101. Rock, Irvin. "The frame of reference." The legacy of Solomon Asch: Essays in cognition and social psychology (1990): 243–268.
  102. J. Hinton, Coursera lectures on Neural Networks, 2012, Url: https://www.coursera.org/learn/neural-networks
  103. Web site: Quartz. Dave Gershgorn. The inside story of how AI got good enough to dominate Silicon Valley. 18 June 2018. 5 October 2018. 12 December 2019. https://web.archive.org/web/20191212224842/https://qz.com/1307091/the-inside-story-of-how-ai-got-good-enough-to-dominate-silicon-valley/. live.
  104. Lawrence . Steve . C. Lee Giles . Ah Chung Tsoi . Andrew D. Back . Face Recognition: A Convolutional Neural Network Approach . IEEE Transactions on Neural Networks . 1997 . 8 . 1 . 98–113 . 10.1.1.92.5813 . 10.1109/72.554195 . 18255614. 2883848 .
  105. Le Callet . Patrick . Christian Viard-Gaudin . Dominique Barba . 2006 . A Convolutional Neural Network Approach for Objective Video Quality Assessment . IEEE Transactions on Neural Networks . 17 . 5 . 1316–1327 . 10.1109/TNN.2006.879766 . 17001990 . 221185563 . 17 November 2013 . 24 February 2021 . https://web.archive.org/web/20210224123804/https://hal.archives-ouvertes.fr/file/index/docid/287426/filename/A_convolutional_neural_network_approach_for_objective_video_quality_assessment_completefinal_manuscript.pdf . live .
  106. Web site: ImageNet Large Scale Visual Recognition Competition 2014 (ILSVRC2014) . 30 January 2016 . 5 February 2016 . https://web.archive.org/web/20160205153105/http://www.image-net.org/challenges/LSVRC/2014/results . live .
  107. Szegedy . Christian . Liu . Wei . Jia . Yangqing . Sermanet . Pierre . Reed . Scott E. . Anguelov . Dragomir . Erhan . Dumitru . Vanhoucke . Vincent . Rabinovich . Andrew . 1409.4842 . Going deeper with convolutions . 10.1109/CVPR.2015.7298594 . 1–9 . IEEE Computer Society . IEEE Conference on Computer Vision and Pattern Recognition, CVPR 2015, Boston, MA, USA, June 7–12, 2015 . 2015. 978-1-4673-6964-0 .
  108. 1409.0575 . Russakovsky . Olga . Image Net Large Scale Visual Recognition Challenge . Deng . Jia . Su . Hao . Krause . Jonathan . Satheesh . Sanjeev . Ma . Sean . Huang . Zhiheng . Karpathy . Andrej . Andrej Karpathy . Khosla . Aditya . Bernstein . Michael . Berg . Alexander C. . Fei-Fei . Li . cs.CV . 2014 . Olga Russakovsky.
  109. News: The Face Detection Algorithm Set To Revolutionize Image Search . February 16, 2015 . Technology Review . 27 October 2017 . 20 September 2020 . https://web.archive.org/web/20200920130711/https://www.technologyreview.com/2015/02/16/169357/the-face-detection-algorithm-set-to-revolutionize-image-search/ . live .
  110. Book: Springer Berlin Heidelberg . 2011-11-16 . 978-3-642-25445-1 . 29–39 . Lecture Notes in Computer Science . Moez . Baccouche . Franck . Mamalet . Christian . Wolf . Christophe . Garcia . Atilla . Baskurt . Albert Ali . Salah . Bruno . Lepri . 10.1007/978-3-642-25446-8_4 . Sequential Deep Learning for Human Action Recognition . Human Behavior Unterstanding . 7065 . 10.1.1.385.4740.
  111. 3D Convolutional Neural Networks for Human Action Recognition . IEEE Transactions on Pattern Analysis and Machine Intelligence . 2013-01-01 . 0162-8828 . 221–231 . 35 . 1 . 10.1109/TPAMI.2012.59 . 22392705 . Shuiwang . Ji . Wei . Xu . Ming . Yang . Kai . Yu . 10.1.1.169.4046 . 1923924.
  112. Huang . Jie . Zhou . Wengang . Zhang . Qilin . Li . Houqiang . Li . Weiping . Video-based Sign Language Recognition without Temporal Segmentation . 1801.10111 . cs.CV . 2018.
  113. Karpathy, Andrej, et al. "Large-scale video classification with convolutional neural networks ." IEEE Conference on Computer Vision and Pattern Recognition (CVPR). 2014.
  114. 1406.2199 . Simonyan . Karen . Two-Stream Convolutional Networks for Action Recognition in Videos . Zisserman . Andrew . cs.CV . 2014. (2014).
  115. Wang . Le . Duan . Xuhuan . Zhang . Qilin . Niu . Zhenxing . Hua . Gang . Zheng . Nanning . Segment-Tube: Spatio-Temporal Action Localization in Untrimmed Videos with Per-Frame Segmentation . Sensors . 18 . 5 . 2018-05-22 . 1424-8220 . 10.3390/s18051657 . 29789447 . 5982167 . 1657 . 2018Senso..18.1657W . free . 2018-09-14 . 2021-03-01 . https://web.archive.org/web/20210301195518/https://qilin-zhang.github.io/_pages/pdfs/Segment-Tube_Spatio-Temporal_Action_Localization_in_Untrimmed_Videos_with_Per-Frame_Segmentation.pdf . live .
  116. Duan . Xuhuan . Wang . Le . Zhai . Changbo . Zheng . Nanning . Zhang . Qilin . Niu . Zhenxing . Hua . Gang . 2018 25th IEEE International Conference on Image Processing (ICIP) . Joint Spatio-Temporal Action Localization in Untrimmed Videos with Per-Frame Segmentation . 25th IEEE International Conference on Image Processing (ICIP) . 2018 . 918–922 . 978-1-4799-7061-2 . 10.1109/icip.2018.8451692.
  117. Convolutional Learning of Spatio-temporal Features . Springer-Verlag . Proceedings of the 11th European Conference on Computer Vision: Part VI . 2010-01-01 . Berlin, Heidelberg . 978-3-642-15566-6 . 140–153 . ECCV'10 . Graham W. . Taylor . Rob . Fergus . Yann . LeCun . Christoph . Bregler . 2022-03-31 . 2022-03-31 . https://web.archive.org/web/20220331211137/https://dl.acm.org/doi/10.5555/1888212 . live .
  118. Book: IEEE Computer Society . 2011-01-01 . Washington, DC, US . 978-1-4577-0394-2 . 3361–3368 . CVPR '11 . 10.1109/CVPR.2011.5995496 . Q. V. . Le . W. Y. . Zou . S. Y. . Yeung . A. Y. . Ng . CVPR 2011 . Learning hierarchical invariant spatio-temporal features for action recognition with independent subspace analysis . 10.1.1.294.5948 . 6006618.
  119. A Deep Architecture for Semantic Parsing . 1404.7296 . 2014-04-29 . Edward . Grefenstette . Phil . Blunsom . Nando . de Freitas . Karl Moritz . Hermann . cs.CL.
  120. Learning Semantic Representations Using Convolutional Neural Networks for Web Search – Microsoft Research . Microsoft Research . 2015-12-17 . April 2014 . Mesnil . Gregoire . Deng . Li . Gao . Jianfeng . He . Xiaodong . Shen . Yelong . 2017-09-15 . https://web.archive.org/web/20170915160617/https://www.microsoft.com/en-us/research/publication/learning-semantic-representations-using-convolutional-neural-networks-for-web-search/?from=http%3A%2F%2Fresearch.microsoft.com%2Fapps%2Fpubs%2Fdefault.aspx%3Fid%3D214617 . live .
  121. A Convolutional Neural Network for Modelling Sentences . 1404.2188 . 2014-04-08 . Nal . Kalchbrenner . Edward . Grefenstette . Phil . Blunsom . cs.CL.
  122. Convolutional Neural Networks for Sentence Classification . 1408.5882 . 2014-08-25 . Yoon . Kim . cs.CL.
  123. Collobert, Ronan, and Jason Weston. "A unified architecture for natural language processing: Deep neural networks with multitask learning ."Proceedings of the 25th international conference on Machine learning. ACM, 2008.
  124. Natural Language Processing (almost) from Scratch . 1103.0398 . 2011-03-02 . Ronan . Collobert . Jason . Weston . Leon . Bottou . Michael . Karlen . Koray . Kavukcuoglu . Pavel . Kuksa . cs.LG.
  125. Comparative study of CNN and RNN for natural language processing . 1702.01923 . 2017-03-02 . W . Yin . K . Kann . M . Yu . H . Schütze . cs.LG.
  126. An empirical evaluation of generic convolutional and recurrent networks for sequence modeling . 1803.01271 . S. . Bai . J.S. . Kolter . V. . Koltun . 2018 . cs.LG.
  127. Detecting dynamics of action in text with a recurrent neural network . Neural Computing and Applications . 2021 . 33 . Gruber . N. . 12 . 15709–15718 . 10.1007/S00521-021-06190-5 . 236307579 .
  128. Approximation Theory of Convolutional Architectures for Time Series Modelling . International Conference on Machine Learning . 2021 . Haotian . J. . Zhong . Li . Qianxiao . Li . 2107.09355.
  129. Time-Series Anomaly Detection Service at Microsoft Proceedings of the 25th ACM SIGKDD International Conference on Knowledge Discovery & Data Mining. EN. 1906.03821. Ren. Hansheng. Xu. Bixiong. Wang. Yujing. Yi. Chao. Huang. Congrui. Kou. Xiaoyu. Xing. Tony. Yang. Mao. Tong. Jie. Zhang. Qi. 2019. 10.1145/3292500.3330680. 182952311.
  130. AtomNet: A Deep Convolutional Neural Network for Bioactivity Prediction in Structure-based Drug Discovery . 1510.02855 . 2015-10-09 . Izhar . Wallach . Michael . Dzamba . Abraham . Heifets . cs.LG.
  131. Understanding Neural Networks Through Deep Visualization . 1506.06579 . 2015-06-22 . Jason . Yosinski . Jeff . Clune . Anh . Nguyen . Thomas . Fuchs . Hod . Lipson . cs.CV.
  132. News: Toronto startup has a faster way to discover effective medicines . The Globe and Mail . 2015-11-09 . 2015-10-20 . https://web.archive.org/web/20151020040115/http://www.theglobeandmail.com/report-on-business/small-business/starting-out/toronto-startup-has-a-faster-way-to-discover-effective-medicines/article25660419/ . live .
  133. Web site: Startup Harnesses Supercomputers to Seek Cures . KQED Future of You . 2015-11-09 . en-us . 2015-05-27 . 2018-12-06 . https://web.archive.org/web/20181206234956/https://www.kqed.org/futureofyou/3461/startup-harnesses-supercomputers-to-seek-cures . live .
  134. 18252639 . 10.1109/72.809083 . 10 . 6 . Evolving neural networks to play checkers without relying on expert knowledge . IEEE Trans Neural Netw . 1382–91 . Chellapilla . K . Fogel . DB . 1999.
  135. 10.1109/4235.942536 . Evolving an expert checkers playing program without using human expertise . IEEE Transactions on Evolutionary Computation . 5 . 4 . 422–428 . 2001 . Chellapilla . K. . Fogel . D.B..
  136. Book: Fogel, David . 2001 . Blondie24: Playing at the Edge of AI . San Francisco, CA . Morgan Kaufmann . 978-1558607835 . David B. Fogel.
  137. 1412.3409 . Clark . Christopher . Teaching Deep Convolutional Neural Networks to Play Go . Storkey . Amos . cs.AI . 2014.
  138. 1412.6564 . Maddison . Chris J. . Move Evaluation in Go Using Deep Convolutional Neural Networks . Huang . Aja . Sutskever . Ilya . Silver . David . cs.LG . 2014.
  139. Web site: AlphaGo – Google DeepMind . 30 January 2016 . https://web.archive.org/web/20160130230207/http://www.deepmind.com/alpha-go.html . 30 January 2016 . dead.
  140. Bai . Shaojie . Kolter . J. Zico . Koltun . Vladlen . An Empirical Evaluation of Generic Convolutional and Recurrent Networks for Sequence Modeling . 2018-04-19 . 1803.01271 . cs.LG.
  141. Yu . Fisher . Koltun . Vladlen . Multi-Scale Context Aggregation by Dilated Convolutions . 2016-04-30 . 1511.07122 . cs.CV.
  142. Borovykh . Anastasia . Bohte . Sander . Oosterlee . Cornelis W. . Conditional Time Series Forecasting with Convolutional Neural Networks . 2018-09-17 . 1703.04691 . stat.ML.
  143. Mittelman . Roni . Time-series modeling with undecimated fully convolutional neural networks . 2015-08-03 . 1508.00317 . stat.ML.
  144. Chen . Yitian . Kang . Yanfei . Chen . Yixiong . Wang . Zizhuo . Probabilistic Forecasting with Temporal Convolutional Neural Network . 2019-06-11 . 1906.04397 . stat.ML.
  145. Zhao . Bendong . Lu . Huanzhang . Chen . Shangfeng . Liu . Junliang . Wu . Dongya . 2017-02-01 . Convolutional neural networks for time series classi . Journal of Systems Engineering and Electronics . 28 . 1 . 162–169 . 10.21629/JSEE.2017.01.18.
  146. Petneházi . Gábor . QCNN: Quantile Convolutional Neural Network . 2019-08-21 . 1908.07978 . cs.LG.
  147. Durjoy Sen Maitra; Ujjwal Bhattacharya; S.K. Parui, "CNN based common approach to handwritten character recognition of multiple scripts", in Document Analysis and Recognition (ICDAR), 2015 13th International Conference on, vol., no., pp.1021–1025, 23–26 Aug. 2015
  148. Web site: NIPS 2017 . Interpretable ML Symposium . 2017-10-20 . 2018-09-12 . 2019-09-07 . https://web.archive.org/web/20190907063237/http://interpretable.ml/ . dead .
  149. Book: Zang . Jinliang . Wang . Le . Liu . Ziyi . Zhang . Qilin . Hua . Gang . Zheng . Nanning . Artificial Intelligence Applications and Innovations . IFIP Advances in Information and Communication Technology . 519 . Attention-Based Temporal Weighted Convolutional Neural Network for Action Recognition . Springer International Publishing . Cham . 2018 . 978-3-319-92006-1 . 1868-4238 . 10.1007/978-3-319-92007-8_9 . 97–108 . 1803.07179 . 4058889.
  150. Wang . Le . Zang . Jinliang . Zhang . Qilin . Niu . Zhenxing . Hua . Gang . Zheng . Nanning . Action Recognition by an Attention-Aware Temporal Weighted Convolutional Neural Network . Sensors . 18 . 7 . 2018-06-21 . 1424-8220 . 10.3390/s18071979 . 29933555 . 6069475 . 1979 . 2018Senso..18.1979W . free . 2018-09-14 . 2018-09-13 . https://web.archive.org/web/20180913040055/https://qilin-zhang.github.io/_pages/pdfs/sensors-18-01979-Action_Recognition_by_an_Attention-Aware_Temporal_Weighted_Convolutional_Neural_Network.pdf . live .
  151. Ong . Hao Yi . Chavez . Kevin . Hong . Augustus . Distributed Deep Q-Learning . 2015-08-18 . cs.LG . 1508.04186v2.
  152. Mnih . Volodymyr . etal . 2015 . Human-level control through deep reinforcement learning . Nature . 518 . 7540 . 529–533 . 10.1038/nature14236 . 25719670 . 2015Natur.518..529M . 205242740.
  153. Sun . R. . Sessions . C. . June 2000 . Self-segmentation of sequences: automatic formation of hierarchies of sequential behaviors . IEEE Transactions on Systems, Man, and Cybernetics - Part B: Cybernetics . 30 . 3 . 403–418 . 10.1109/3477.846230 . 18252373 . 1083-4419 . 10.1.1.11.226.
  154. Web site: Convolutional Deep Belief Networks on CIFAR-10. 2017-08-18. 2017-08-30. https://web.archive.org/web/20170830060223/http://www.cs.toronto.edu/~kriz/conv-cifar10-aug2010.pdf. live.
  155. Book: Lee . Honglak . Grosse . Roger . Ranganath . Rajesh . Ng . Andrew Y. . Proceedings of the 26th Annual International Conference on Machine Learning . Convolutional deep belief networks for scalable unsupervised learning of hierarchical representations . 1 January 2009 . ACM . 609–616 . 10.1145/1553374.1553453 . 9781605585161 . 10.1.1.149.6800 . 12008458.
  156. Book: Behnke . Sven . Hierarchical Neural Networks for Image Interpretation . Springer . 2003 . 978-3-540-40722-5 . Lecture Notes in Computer Science . 2766 . 10.1007/b11963 . 2016-12-28 . https://web.archive.org/web/20170810020001/http://www.ais.uni-bonn.de/books/LNCS2766.pdf . 2017-08-10 . live . 1304548.
  157. News: Google Built Its Very Own Chips to Power Its AI Bots . Cade Metz . May 18, 2016 . Wired . March 6, 2017 . January 13, 2018 . https://web.archive.org/web/20180113150305/https://www.wired.com/2016/05/google-tpu-custom-chips/ . live .