The first CNN appeared in the work of Fukushima in 1980 and was called Neocognitron. The basic architectural ideas behind the CNN (local receptive fields,shared weights, and spatial or temporal subsampling) allow such networks to achieve some degree of shift and deformation invariance and at the same time reduce the number of training parameters.
Since 1989, Yann LeCun and co-workers have introduced a series of CNNs with the general name LeNet, which contrary to the Neocognitron use supervised training. In this case, the major advantage is that the whole network is optimized for the given task, making this approach useable for real-world applications.
LeNet has been successfully applied to character recognition, generic object recognition, face detection and pose estimation, obstacle avoidance in an autonomous robot etc.
myCNN class allows to create, train and test generic convolutional networks (e.g., LeNet) as well as more general networks with features:
- any directed acyclic graph can be used for connecting the layers of the network;
- the network can have any number of arbitrarily sized input and output layers;
- the neuron’s receptive field (RF) can have an arbitrary stride (step of local RF tiling), which means that in the S-layer, RFs can overlap and in the C-layer the stride can differ from 1;
- any layer or feature map of the network can be switched from trainable to nontrainable (and vice versa) mode even during the training;
- a new layer type: softmax-like M-layer.
The archive contains the myCNN class source (with comments) and a simple example of LeNet5 creation and training.
All updates and new releases can be found here: http://sites.google.com/site/chumerin/projects/mycnn
Nikolay Chumerin (2020). myCNN (https://www.mathworks.com/matlabcentral/fileexchange/25247-mycnn), MATLAB Central File Exchange. Retrieved .
nice for learning
Hi, I tried working with this code. It is a commendable effort. I am able to see the code work fine for the handwritten application. However, when i try to solve one of my problem on the code, it pops out an error. Basically, the output of the network is not obtained. I tried debugging, and I see that at the fourth layer (second step of convolution), there is no output. Please help me with this.
Can any one tell me is it possible to implement face recognition application using neural networks cNN with eigenfaces i don knw muchh abt cNn . if possible please
send me a reply..
hi,i need to know how to insert alphabet characters (A-Z) into your code besides numeric characters (0-9). Any suggestions?
I'm testing your implementation for doing some work on face recognition. But I have to use more than 10 classes. I wonder if you can help me doing this modification on the code. I have been studying the code this day but I can't find where to modify for using 40 classes. I hope you can help me, please.
You did a great job! Thanks )
This requires the NN toolbox and this should be mentioned. For example, mapstd() is a function from this toolbox which is used.
[to Birkan Tunc]
Thank you for your response. Concerning your question...
The problem is in the way how the standard 2D convolution is done. Usually, when you convolve a matrix A (of format let say N-by-M) with a kernel k (of format n-by-m where n<=N and m<=M) you get a result C of format (N+n-1)-by-(M-m+1).
So, all kernels, except scalars (1-by-1), produce convolution result of format less then convolved matrix (A). Of course, you can use 'same' parameter in conv2 matlab function (e.g.
>> C = conv2(A, k, 'same');
and you will get the result of the same format as input (size(C) == size(A)).
But in this case you need to adapt the training routines as well. Theoretically it's a piece of cake, but technically it's not a trivial task (one has to properly handle borders during the backward convolution). Anyway, you can try. It would be nice to see the results of your work.
I have a few questions: I need a CNN for image processing instead of classification. That means I feed the network with an image and want get another image as the single output with the same size of input. How can I manage that? Is it possible by making simple modification to this code? Are there any references for this kind of CNNs?
I'll appreciate any kind of help
A respectable job have been done in this realization of CNN. There's a progress in comparison with my version. Particularly more flexible architecture of CNN, ability to make an arbitrary dimentions of kernel weight and other usefull things.
- a graphical demo (demo_myCNN) added (thanks to Mikhail Sitotenko, submission 24291)
- the first attempt to make the M-layer trainable
see ChangeLog inside the archive.
- fixed some bugs related to system dependencies;
Inspired by: CNN - Convolutional neural network class