Example to Understand CNN - determine if image has X or O
data:image/s3,"s3://crabby-images/c62c5/c62c5962d23330e112c04a2d7c421a65d11cdb09" alt=""
data:image/s3,"s3://crabby-images/4f6a2/4f6a23516b96f5b2b3ab5f55c8a535748f67e602" alt=""
data:image/s3,"s3://crabby-images/c1278/c127870056f226179b7fb7e3a43eebad5168fea8" alt=""
How much training data --- examples for some forms of object recognition - could go into 100,000 samples or more. Sometimes like 10,000 or maybe for the really really simple example we show here we might get away with 200?
data:image/s3,"s3://crabby-images/44b0f/44b0f3e0d445ab0f988afe6d6e0a2537bf71d770" alt=""
data:image/s3,"s3://crabby-images/34612/34612de0c64d95924d60a33e57649dcdecda8f27" alt=""
CNN --- in "some way" can be thought of breaking it down and matching parts of image to each other ---
-
The matching is done through convolving the image with the MxM mask/filter
data:image/s3,"s3://crabby-images/334b0/334b0d147ecdde9df86299dce9974a1fd65790b0" alt=""
QUESTION: How many Filters do we apply at each level?????? ---here we show 3 filters/masks
data:image/s3,"s3://crabby-images/99fdc/99fdc79ac0bb9e8120f713e37b283ccc61cac13c" alt=""
RESULTS
data:image/s3,"s3://crabby-images/06278/06278c5e29c965c9e7bb831168566ee663540ae1" alt=""
These MxM filters/masks are applied convolutionally at each layer in our CNN - in the case of our input image we apply this at each raw input pixel (at each red, green, blue if color) and we can apply only 1 MxM filter or could have multiple filters like shown above the case is 3 -- in our binary image input this would result in 3 times the amount of input data for the 3 images.......
<< example where input image 32x32 pixels and have THREE MxM filters convolve with yielding 6 times data. Note here MxM =5x5 and we can not convolve with the first 2 and last 2 rows and columns (boundaries of image) --> so get THREE 28x28 size data values ---- YIKES bigger --- I want the output 2 have 2 nodes "X" and "Y". What am I going to do??? --> CNN does downsampling at each layer called Max Pooling
MAX Pooling - typically do on 2x2 (or maybe 3x3)
data:image/s3,"s3://crabby-images/e2187/e2187cf39a64bbbf071232dabdf0f815c1526ca3" alt=""
NOW we have THREE 14x14 data sets --thats a bit better
data:image/s3,"s3://crabby-images/561ac/561ac0c212d0a8b17d5c07eed9e4c055a8e57cf7" alt=""
RESULTS
data:image/s3,"s3://crabby-images/c763d/c763d5ceecc62b7e315c21a9a63e3d980cec41c3" alt=""
data:image/s3,"s3://crabby-images/d2603/d2603dc0969f193f228eec7b7419cc84eee016a4" alt=""
WAIT we not done --- we must introduce a non-linearity and do so for CNN at each data sample by applying Rectified Linear Units: set values < 0 to 0
data:image/s3,"s3://crabby-images/dac1c/dac1c68568999f550405455b0501414fee8e9828" alt="" data:image/s3,"s3://crabby-images/4cef3/4cef356ba876fb23ac62a33c07453bf1b8beffb4" alt=""
Convolution with set of (1-*) MxM filters + nonlinear + max pooling (downsample)
data:image/s3,"s3://crabby-images/4a54e/4a54e900393c74465c84a51835e245fa1baff33c" alt=""
Example with 3 Layers using convolution masks
data:image/s3,"s3://crabby-images/c611a/c611a6db54129edc43331a1ecb3b34279d6fabeb" alt=""
(you can have more than one layer at the end that is fully connected like this --but, minimum is 1)
data:image/s3,"s3://crabby-images/d31ed/d31ed49b1a0822044eb77871fe9800e44c4b60df" alt=""
After Training --making the decision at last layer
data:image/s3,"s3://crabby-images/3af5c/3af5cf0766d956b32449d23231d10f4736563a29" alt=""
data:image/s3,"s3://crabby-images/88a8f/88a8f369239899bd7a51d1c56f31f747124aab9b" alt=""
data:image/s3,"s3://crabby-images/e543b/e543b8247c11df9233801127c6e7b92f61341b32" alt=""
-
Question 1: How many layers of each type (convolution and fully connected)?
hard to answer - minimum 3 largest maybe 6-15 (but, that is changing) . For sure the more layers, the longer to train and in general more data needed. More complex the problem more layers. Simpler the problem less layers needed. Minimum 1 fully connected layer. NOT LEARNED, you decide
-
Question 2: How many masks at each layer?
hard to answer - could learn this. Minimum obviously 1. NOT LEARNED, you decide
-
Question 3: what size is the mask?
hard to answer - minimum is 3x3. Could be larger but, should not exceed 25% of image (?? of thumb). larger mask means larger scale pattern looking to match via convolution. NOT LEARNED, you decide
-
Question 4: What is content of MxM mask?
you learn this through training (backpropogation like traditional NN, use error between output and desired output to alter the parameters) LEARNED
-
Question 5: What are the weights in the fully connected layers?
you learn this through training (backpropogation like traditional NN, use error between output and desired output to alter the parameters) LEARNED
data:image/s3,"s3://crabby-images/9bd77/9bd77ff90d2116c0c5656dd2cec4330b9c1d3769" alt=""
data:image/s3,"s3://crabby-images/2d085/2d0852c30ca70ab9a54745c43b643e12ded8f0c0" alt=""
data:image/s3,"s3://crabby-images/6e68f/6e68ff8c20c34a50181a1413ff907291db9c93c4" alt=""
OUTCOME: CNN capture "local" spatial patterns at different scales (downsampling-max pooling) --- good for Image Applications
data:image/s3,"s3://crabby-images/7be86/7be86801c6127a28d22fb27eb4a4ad74cd614349" alt=""
|