Skip to content

Latest commit

 

History

History
97 lines (54 loc) · 4.04 KB

File metadata and controls

97 lines (54 loc) · 4.04 KB

Image-Steganography-Using-Deep-Learning

Deep Learning

Deep Learning in simple words is an Artificial Intelligence that initiates the working of human brain in processing data and creating patterns for use in decision making.

Refer:-

For Deep Learning https://www.ibm.com/cloud/learn/deep-learning

For Neural Networks https://www.ibm.com/cloud/learn/neural-networks

The diagram belowe shows the pictorial representation of neural networks.

image

Types of Activation Function

image

With the use of Simple Neurons,algorithm can learn complex structure present in the dataset.

CONVOLUTIOAL NEURAL NETWORK

In this project, I am going to use Covolutional Neural Network. Reason being CNN works well with Image classification. Whenever we use DL Neural Netowrk, it performs overfitting. n order to avoid overfitting, we have to coe up with a way that can identify essential features (which are more important then anything else present in data).

How CNN learns ?

There is a technique called template matching. Template matching is a technique in Digital Image processing for find small parts of the image which match the given template.

To understand the important features of image data, we do some operations / processing on the input image. This is called convolutioal operation.

image

The central matrix is called kernel. The kernel moved left to right and top to bottom. The dot product of kernal values with input image value occurs and transformed values are projected in a new matrix. (Simply, we are applying some filters so that all essential features can be estimated properly).

PADDING LAYER Padding layer adds some extra dimesionality to the input image so that at the time of processing, no dimesnionality will be missed(when advanced filtering tehniques are used).

POOLING LAYER We have two types of pooling layer 1) Max pooling layer 2) Average pooling layer

In max pooling layer, the kernel is placed at the specifi portion and takes maximum value of the portion as transformed value.

*The next step after processing of image is Flattening Operattion

Flattening is the reduction of 2D array into 1D array.

Input image -> Processing + Max Pooling -> (to an number of hidden layers) + Processing + Max_pooling -> Fully Connected Neural Network -> Output

image

File 1 (code) performs simple classifiation using CNN.

IMPORTANT TERMS

->Dense Networks ->Sequential Model

For Regression Tasks - The Output has only one neuron (with no activation function) For Binary Classification - The output has 1 neuron (with sigmoid activation function) For Multiclass classifcation - The output has k-neurons (with softmax activation function)

HOW TO GET TO KNOW HOW MANY NEURONS CAN BE USED IN HIDDEN LAYERS. There is no direct rule, but the strategies used are

  1. Trail and Error
  2. Research Papers
  3. Other Already Built Networks

Steganography

Steganography is the practice of concealing a message within another message or a physical object.

As Previously stated, I have used CNN to train the model.

The Dataset used is Tiny ImageNet Visual Recognition Challenge.

Working

image

Note -

Directly writing the code or going through the code is quite difficult, until unless I understand the concept of AutoEncoders. I have attended the webinar organised by edureka on Image cryptograpgy using deep learning. I have taken some refernce of code through webinar.

Go through the concept and then look for code The concept seems to be easy but its not......

References -

https://github.com/junaidiqbalsyed/Deep_Steg/blob/main/deep_steganography.ipynb