If you’ve been following along with this series of blog posts, then you already know what a huge fan I am of Keras.
Keras is a super powerful, easy to use Python library for building neural networks and deep learning networks.
In the remainder of this blog post, I’ll demonstrate how to build a simple neural network using Python and Keras, and then apply it to the task of image classification.
Looking for the source code to this post?
Jump Right To The Downloads SectionA simple neural network with Python and Keras
To start this post, we’ll quickly review the most common neural network architecture — feedforward networks.
We’ll then discuss our project structure followed by writing some Python code to define our feedforward neural network and specifically apply it to the Kaggle Dogs vs. Cats classification challenge. The goal of this challenge is to correctly classify whether a given image contains a dog or a cat.
We’ll review the results of our simple neural network architecture and discuss methods to improve it.
Our final step will be to build a test script that will load images and classify them with OpenCV, Keras, and our trained model.
Feedforward neural networks
While there are many, many different neural network architectures, the most common architecture is the feedforward network:
In this type of architecture, a connection between two nodes is only permitted from nodes in layer i to nodes in layer i + 1 (hence the term feedforward; there are no backwards or inter-layer connections allowed).
Furthermore, the nodes in layer i are fully connected to the nodes in layer i + 1. This implies that every node in layer i connects to every node in layer i + 1. For example, in the figure above, there are a total of 2 x 3 = 6 connections between layer 0 and layer 1 — this is where the term “fully connected” or “FC” for short, comes from.
We normally use a sequence of integers to quickly and concisely describe the number of nodes in each layer.
For example, the network above is a 3-2-3-2 feedforward neural network:
- Layer 0 contains 3 inputs, our values. These could be raw pixel intensities or entries from a feature vector.
- Layers 1 and 2 are hidden layers, containing 2 and 3 nodes, respectively.
- Layer 3 is the output layer or the visible layer — this is where we obtain the overall output classification from our network. The output layer normally has as many nodes as class labels; one node for each potential output. In our Kaggle Dogs vs. Cats example, we have two output nodes — one for “dog” and another for “cat”.
Project directory structure
Before we begin, head to the “Downloads” section of this blog post, and download the files and data. From there you’ll be able to follow along as we work through today’s examples.
Once your zip is downloaded, extract the files.
From within the directory, let’s run the tree
command with two command line arguments to list our project structure:
$ tree --filelimit 10 --dirsfirst . ├── kaggle_dogs_vs_cats │ └── train [25000 entries exceeds filelimit, not opening dir] ├── test_images [50 entries exceeds filelimit, not opening dir] ├── output │ └── simple_neural_network.hdf5 ├── simple_neural_network.py └── test_network.py 4 directories, 4 files
The first command line argument is important as it prevents tree
from displaying all of the image files and cluttering our terminal.
The Kaggle Dogs vs. Cats dataset is in the relevant directory (kaggle_dogs_vs_cats
). All 25,000 images are contained in the train
subdirectory. This data came from the train.zip
dataset available on Kaggle.
I’ve also included 50 samples from the Kaggle test1.zip
available on their website.
The output
directory contains our serialized model that we’ll generate with Keras at the bottom of the first script.
We’ll review the two Python scripts, simple_neural_network.py
and test_network.py
, in the next sections.
Implementing our own neural network with Python and Keras
Now that we understand the basics of feedforward neural networks, let’s implement one for image classification using Python and Keras.
To start, you’ll want to follow the appropriate tutorial for your system to install TensorFlow and Keras:
- Configuring Ubuntu for deep learning with Python
- Setting up Ubuntu 16.04 + CUDA + GPU for deep learning with Python
- Configuring macOS for deep learning with Python
Note: A GPU is not needed for today’s blog post — your laptop can run this very elementary network easily. That being said, in general I do not recommend using a laptop for deep learning. Laptops are for productivity rather than working with TB sized datasets required for many deep learning activities. I recommend Amazon AWS using my pre-configured AMI or Microsoft’s DSVM. Both of these environments are ready to go in less than 5 minutes.
From there, open up a new file, name it simple_neural_network.py
, and we’ll get coding:
# import the necessary packages from sklearn.preprocessing import LabelEncoder from sklearn.model_selection import train_test_split from keras.models import Sequential from keras.layers import Activation from keras.optimizers import SGD from keras.layers import Dense from keras.utils import np_utils from imutils import paths import numpy as np import argparse import cv2 import os
We start off by importing our required Python packages. We’ll be using a number of scikit-learn implementations along with Keras layers and activation functions. If you do not already have your development environment configured for Keras, please see this blog post.
We’ll be also using imutils, my personal library of OpenCV convenience functions. If you do not already have imutils
installed on your system, you can install it via pip
:
$ pip install imutils
Next, let’s define a method to accept and image and describe it. In previous tutorials, we’ve extracted color histograms from images and used these distributions to characterize the contents of an image.
This time, let’s use the raw pixel intensities instead. To accomplish this, we define the image_to_feature_vector
function which accepts an input image
and resizes it to a fixed size
, ignoring the aspect ratio:
def image_to_feature_vector(image, size=(32, 32)): # resize the image to a fixed size, then flatten the image into # a list of raw pixel intensities return cv2.resize(image, size).flatten()
We resize our image
to fixed spatial dimensions to ensure each and every image in the input dataset has the same “feature vector” size. This is a requirement when utilizing our neural network — each image must be represented by a vector.
In this case, we resize our image to 32 x 32 pixels and then flatten the 32 x 32 x 3 image (where we have three channels, one for each Red, Green, and Blue channel, respectively) into a 3,072-d feature vector.
The next code block handles parsing our command line arguments and taking care of a few initializations:
# construct the argument parse and parse the arguments ap = argparse.ArgumentParser() ap.add_argument("-d", "--dataset", required=True, help="path to input dataset") ap.add_argument("-m", "--model", required=True, help="path to output model file") args = vars(ap.parse_args()) # grab the list of images that we'll be describing print("[INFO] describing images...") imagePaths = list(paths.list_images(args["dataset"])) # initialize the data matrix and labels list data = [] labels = []
We only need a single switch here, --dataset
, which is the path to the input directory containing the Kaggle Dogs vs. Cats images. This dataset can be downloaded from the official Kaggle Dogs vs. Cats competition page.
Line 30 grabs the paths to our --dataset
of images residing on disk. We then initialize the data
and labels
lists, respectively, on Lines 33 and 34.
Now that we have our imagePaths
, we can loop over them individually, load them from disk, convert the images to feature vectors, and the update the data
and labels
lists:
# loop over the input images for (i, imagePath) in enumerate(imagePaths): # load the image and extract the class label (assuming that our # path as the format: /path/to/dataset/{class}.{image_num}.jpg image = cv2.imread(imagePath) label = imagePath.split(os.path.sep)[-1].split(".")[0] # construct a feature vector raw pixel intensities, then update # the data matrix and labels list features = image_to_feature_vector(image) data.append(features) labels.append(label) # show an update every 1,000 images if i > 0 and i % 1000 == 0: print("[INFO] processed {}/{}".format(i, len(imagePaths)))
The data
list now contains the flattened 32 x 32 x 3 = 3,072-d representations of every image in our dataset. However, before we can train our neural network, we first need to perform a bit of preprocessing:
# encode the labels, converting them from strings to integers le = LabelEncoder() labels = le.fit_transform(labels) # scale the input image pixels to the range [0, 1], then transform # the labels into vectors in the range [0, num_classes] -- this # generates a vector for each label where the index of the label # is set to `1` and all other entries to `0` data = np.array(data) / 255.0 labels = np_utils.to_categorical(labels, 2) # partition the data into training and testing splits, using 75% # of the data for training and the remaining 25% for testing print("[INFO] constructing training/testing split...") (trainData, testData, trainLabels, testLabels) = train_test_split( data, labels, test_size=0.25, random_state=42)
Lines 61 and 62 handle scaling the input data to the range [0, 1], followed by converting the labels
from a set of integers to a set of vectors (a requirement for the cross-entropy loss function we will apply when training our neural network).
We then construct our training and testing splits on Lines 67 and 68, using 75% of the data for training and the remaining 25% for testing.
For a more detailed review of the data preprocessing stage, please see this blog post.
We are now ready to define our neural network using Keras:
# define the architecture of the network model = Sequential() model.add(Dense(768, input_dim=3072, init="uniform", activation="relu")) model.add(Dense(384, activation="relu", kernel_initializer="uniform")) model.add(Dense(2)) model.add(Activation("softmax"))
On Lines 71-76 we construct our neural network architecture — a 3072-768-384-2 feedforward neural network.
Our input layer has 3,072 nodes, one for each of the 32 x 32 x 3 = 3,072 raw pixel intensities in our flattened input images.
We then have two hidden layers, each with 768 and 384 nodes, respectively. These node counts were determined via a cross-validation and hyperparameter tuning experiment performed offline.
The output layer has 2 nodes — one for each of the “dog” and “cat” labels.
We then apply a softmax
activation function on top of the network — this will give us our actual output class label probabilities.
The next step is to train our model using Stochastic Gradient Descent (SGD):
# train the model using SGD print("[INFO] compiling model...") sgd = SGD(lr=0.01) model.compile(loss="binary_crossentropy", optimizer=sgd, metrics=["accuracy"]) model.fit(trainData, trainLabels, epochs=50, batch_size=128, verbose=1)
To train our model, we’ll set the learning rate parameter of SGD to 0.01. We’ll use the binary_crossentropy
loss function for the network as well.
In most cases, you’ll want to use just crossentropy
, but since there are only two class labels, we use binary_crossentropy
. For > 2 class labels, make sure you use crossentropy
.
The network is then allowed to train for a total of 50 epochs, meaning that the model “sees” each individual training example 50 times in an attempt to learn an underlying pattern.
The final code block evaluates our Keras neural network on the testing data:
# show the accuracy on the testing set print("[INFO] evaluating on testing set...") (loss, accuracy) = model.evaluate(testData, testLabels, batch_size=128, verbose=1) print("[INFO] loss={:.4f}, accuracy: {:.4f}%".format(loss, accuracy * 100)) # dump the network architecture and weights to file print("[INFO] dumping architecture and weights to file...") model.save(args["model"])
Classifying images using neural networks with Python and Keras
To execute our simple_neural_network.py
script, make sure you have already downloaded the source code and data for this post by using the “Downloads” section at the bottom of this tutorial.
The following command can be used to train our neural network using Python and Keras:
$ python simple_neural_network.py --dataset kaggle_dogs_vs_cats \ --model output/simple_neural_network.hdf5
The output of our script can be seen in the screenshot below:
On my Titan X GPU, the entire process of feature extraction, training the neural network, and evaluation took a total of 1m 15s with each epoch taking less than 0 seconds to complete.
At the end of the 50th epoch, we see that we are getting ~76% accuracy on the training data and 67% accuracy on the testing data.
This ~9% difference in accuracy implies that our network is overfitting a bit; however, it is very common to see ~10% gaps in training versus testing accuracy, especially if you have limited training data.
You should start to become very worried regarding overfitting when your training accuracy reaches 90%+ and your testing accuracy is substantially lower than that.
In either case, this 67.376% is the highest accuracy we’ve obtained thus far in this series of tutorials. As we’ll find out later on, we can easily obtain > 95% accuracy by utilizing Convolutional Neural Networks.
Classifying images using our Keras model
We’re going to build a test script to verify our results visually.
So let’s go ahead and create a new file named test_network.py
in your favorite editor and enter the following code:
# import the necessary packages from __future__ import print_function from keras.models import load_model from imutils import paths import numpy as np import argparse import imutils import cv2 def image_to_feature_vector(image, size=(32, 32)): # resize the image to a fixed size, then flatten the image into # a list of raw pixel intensities return cv2.resize(image, size).flatten() # construct the argument parse and parse the arguments ap = argparse.ArgumentParser() ap.add_argument("-m", "--model", required=True, help="path to output model file") ap.add_argument("-t", "--test-images", required=True, help="path to the directory of testing images") ap.add_argument("-b", "--batch-size", type=int, default=32, help="size of mini-batches passed to network") args = vars(ap.parse_args())
On Lines 2-8, we load necessary packages. These should be familiar as we used each of them above, with the exception of load_model
from keras.models
. The load_model
module simply loads the serialized Keras model from disk so that we can send images through the network and acquire predictions.
The image_to_feature_vector
function is identical and we include it in the test script because we want to preprocess our images in the same way as training.
Our script has three command line arguments which can be provided at runtime (Lines 16-23):
--model
: The path to our serialized model file.--test-images
: The path to the directory of test images.--batch-size
: Optionally, the size of mini-batches can be specified with the default being32
.
You do not need to modify Lines 16-23 — if you are unfamiliar with argparse
and command line arguments, just give this blog post a read.
Moving on, let’s define our classes and load our serialized model from disk:
# initialize the class labels for the Kaggle dogs vs cats dataset CLASSES = ["cat", "dog"] # load the network print("[INFO] loading network architecture and weights...") model = load_model(args["model"]) print("[INFO] testing on images in {}".format(args["test_images"]))
Line 26 creates a list of the classes we’re working with today — a cat and a dog.
From there we load the model into memory so that we can easily classify images as needed (Line 30).
Let’s begin looping over the test images and predicting whether each image is a feline or canine:
# loop over our testing images for imagePath in paths.list_images(args["test_images"]): # load the image, resize it to a fixed 32 x 32 pixels (ignoring # aspect ratio), and then extract features from it print("[INFO] classifying {}".format( imagePath[imagePath.rfind("/") + 1:])) image = cv2.imread(imagePath) features = image_to_feature_vector(image) / 255.0 features = np.array([features])
We begin looping over all images in the testing directory on Line 34.
First, we load the image and preprocess it (Lines 39-41).
From there, let’s send the image through the neural network:
# classify the image using our extracted features and pre-trained # neural network probs = model.predict(features)[0] prediction = probs.argmax(axis=0) # draw the class and probability on the test image and display it # to our screen label = "{}: {:.2f}%".format(CLASSES[prediction], probs[prediction] * 100) cv2.putText(image, label, (10, 35), cv2.FONT_HERSHEY_SIMPLEX, 1.0, (0, 255, 0), 3) cv2.imshow("Image", image) cv2.waitKey(0)
A prediction is made on Lines 45 and 46.
The remaining lines build a display label containing the class name and probability score and overlay it on the image (Lines 50-54). Each iteration of the loop, we wait for a keypress so that we can check images one at a time (Line 55).
Testing our neural network with Keras
Now that we’re finished implementing our test script, let’s run it and see our hard work in action. To grab the code and images, be sure to scroll down to the “Downloads” section of this blog post.
When you have the files extracted, to run our test_network.py
we simply execute it in the terminal and provide two command line arguments:
$ python test_network.py --model output/simple_neural_network.hdf5 \ --test-images test_images Using TensorFlow backend. [INFO] loading network architecture and weights... [INFO] testing on images in test_images [INFO] classifying 48.jpg [INFO] classifying 49.jpg [INFO] classifying 8.jpg [INFO] classifying 9.jpg [INFO] classifying 14.jpg [INFO] classifying 28.jpg
Did you see the following error message?
Using TensorFlow backend. usage: test_network.py [-h] -m MODEL -t TEST_IMAGES [-b BATCH_SIZE] test_network.py: error: the following arguments are required: -m/--model, -t/--test-images
This message describes how to use the script with command line arguments.
Are you unfamiliar with command line arguments and argparse? No worries — just give this blog post on command line arguments a quick read.
If everything worked correctly, after the model loads and runs the first inference, we’re presented with a picture of a dog:
The network classified the dog with 71% prediction accuracy. So far so good!
When you’re ready, press a key to cycle to the next image (the window must be active).
Our cute and cuddly cat with white chest hair passed the test with 77% accuracy!
Onto Lois, a dog:
Lois is definitely a dog — our model is 97% sure of it.
Let’s try another cat:
Yahoo! This ball of fur is correctly predicted to be a cat.
Let’s try a yet another dog:
DOH! Our network thinks this dog is a cat with 61% confidence. Clearly this is a misclassification.
How could that be? Well, our network is only 67% accurate as we demonstrated above. It will be common to see a number of misclassifications.
Our last image is of one of the most adorable kittens in the test_images folder. I’ve named this kitten Simba. But is Simba a cat according to our model?
Alas, our network has failed us, but only by 3.29 percent. I was almost sure that our network would classify Simba correctly, but I was wrong.
Not to worry — there are improvements we can make to rank on the Top-25 leaderboard of the Kaggle Dogs vs. Cats challenge.
In my new book, Deep Learning for Computer Vision with Python, I demonstrate how to do just that. In fact, I’ll go so far to say that you’ll probably achieve a Top-5 position with what you’ll learn in the book.
To pick up your copy, just use this link: Deep Learning for Computer Vision with Python.
What's next? We recommend PyImageSearch University.
84 total classes • 114+ hours of on-demand code walkthrough videos • Last updated: February 2024
★★★★★ 4.84 (128 Ratings) • 16,000+ Students Enrolled
I strongly believe that if you had the right teacher you could master computer vision and deep learning.
Do you think learning computer vision and deep learning has to be time-consuming, overwhelming, and complicated? Or has to involve complex mathematics and equations? Or requires a degree in computer science?
That’s not the case.
All you need to master computer vision and deep learning is for someone to explain things to you in simple, intuitive terms. And that’s exactly what I do. My mission is to change education and how complex Artificial Intelligence topics are taught.
If you're serious about learning computer vision, your next stop should be PyImageSearch University, the most comprehensive computer vision, deep learning, and OpenCV course online today. Here you’ll learn how to successfully and confidently apply computer vision to your work, research, and projects. Join me in computer vision mastery.
Inside PyImageSearch University you'll find:
- ✓ 86 courses on essential computer vision, deep learning, and OpenCV topics
- ✓ 86 Certificates of Completion
- ✓ 115+ hours of on-demand video
- ✓ Brand new courses released regularly, ensuring you can keep up with state-of-the-art techniques
- ✓ Pre-configured Jupyter Notebooks in Google Colab
- ✓ Run all code examples in your web browser — works on Windows, macOS, and Linux (no dev environment configuration required!)
- ✓ Access to centralized code repos for all 540+ tutorials on PyImageSearch
- ✓ Easy one-click downloads for code, datasets, pre-trained models, etc.
- ✓ Access on mobile, laptop, desktop, etc.
Summary
In today’s blog post, I demonstrated how to train a simple neural network using Python and Keras.
We then applied our neural network to the Kaggle Dogs vs. Cats dataset and obtained 67.376% accuracy utilizing only the raw pixel intensities of the images.
Starting next week, I’ll begin discussing optimization methods such as gradient descent and Stochastic Gradient Descent (SGD). I’ll also include a tutorial on backpropagation to help you understand the inner-workings of this important algorithm.
Before you go, be sure to enter your email address in the form below to be notified when future blog posts are published — you won’t want to miss them!
Download the Source Code and FREE 17-page Resource Guide
Enter your email address below to get a .zip of the code and a FREE 17-page Resource Guide on Computer Vision, OpenCV, and Deep Learning. Inside you'll find my hand-picked tutorials, books, courses, and libraries to help you master CV and DL!
Stan
That is awesome. Thanks. Please keep posting that stuff.
Adrian Rosebrock
Thanks Stan! I’ll certainly be doing more neural network and deep learning tutorials in the future.
Bogomil
Hi Adrian,
I used the default engine for keras – tensorflow and got the following:
Epoch 50/50
18750/18750 [==============================] – 12s – loss: 0.4859 – acc: 0.7707
[INFO] evaluating on testing set…
6250/6250 [==============================] – 1s
[INFO] loss=0.6020, accuracy: 68.0960%
is this difference normal ?
Adrian Rosebrock
Absolutely. Keep in mind that neural networks are stochastic algorithms meaning there is a level of randomness involved with them (specifically the weight initializations). It’s totally normal to see a bit of variance between training runs.
Gilad
Hi,
wonderful post!
I have a question – how did you manage to pick your parameters (including the NN scheme)?
No matter what I did (and I did a lot – including adding 2 more NN levels, adding dropout, changeling the SGD parameters and all other parameters), I didn’t manage to get more than your 67%.
Especially I wonder why adding more levels and increasing the depth of each, didn’t contribute to my score (but as expected contribute to my run time ;-))
Only when I increased the resolution to 64×64, and the depth of the 2 NN levels, I manage to get 68%, and I wonder why it is so low.
Adrian Rosebrock
Hey Gilad — as the blog post states, I determined the parameters to the network using hyperparameter tuning.
Regarding the accuracy, keep in mind that this is a simple feedforward neural network. 68% accuracy is actually quite good for only considering the raw pixel intensities. And again, as the blog post states, we require a more powerful network architecture (i.e., Convolutional Neural Networks) to obtain higher accuracy. I’ll be covering how to apply CNNs to the Dogs vs. Cats dataset in a future blog post. In the meantime, I would suggest reading this blog post on MNIST + LeNet to help you get started with CNNs.
Max Kostka
Yes, absolutely awesome Adrian, i am already totally eager for a simple convolutional neural network. I love your blog 🙂 Been following it for a year now. Keep up the great work.
Btw, i did this simple neural network on a raspberry Pi 2 and FYI it took almost 5 hours 😀
Adrian Rosebrock
Thanks for the kind words Max, I’m happy the tutorial helped you (and that you’ve been a long time reader)!
If you would like a simple CNN, take a look at this blog post on LeNet to help you get started. Future posts will discuss each of the layer types in detail, etc.
Max Kostka
i did that right away, another awesome post:D and fyi, the training there on a raspi 2 took almost about 19 hours.
Marios
You could also do an implementation of your NN using TensorFlow!
Adrian Rosebrock
Keras can use either Theano or TensorFlow as a backend — it’s really your choice. I personally like using Keras because it adds a layer of abstraction over what would otherwise be a lot more code to accomplish the same task. In future blog posts I’m planning on continuing using Keras, but I’ll also consider the “nitty-gritty” with TensorFlow as well!
roberto
Hello Adrian, awesome work!
I run the code, but i would like to use it to classify some images, but i dont want to run it every time. How can i save the model and use it to classify?
ps: I’ll be waiting for next post to improve the accuracy!
Regards!!!
Adrian Rosebrock
Once your model is saved you can actually serialize it to disk using
model.save
and then load it again viaload_model
. Take a look at the Keras documentation for more information and a code example.Atti
great article thanks for all the insights
Alberto Franzaroli
Now there is also a opensource library The Microsoft Cognitive Toolkit
would you like to try it and compare with Keras ?
Adrian Rosebrock
I haven’t used the Microsoft Cognitive Toolkit before, but I’ll look into it. I don’t normally use Microsoft products.
Dharma KC
Please can you provide the link to the tutorial with convolutional neural network to solve this problem with 95% accuracy. Thank you.
Adrian Rosebrock
I will be covering how to obtain 95%+ accuracy in the Dogs vs. Cats challenge in my upcoming deep learning book. Stay tuned!
UDAY
How much it will take to train without a GPU
and how we can get a GPU for trail.
Tajj kasem
Hi Adrian
How I can use model.predict() after training my neural network .
I have this error :
Exception: Error when checking : expected dense_input_1 to have 2 dimensions, but got array with shape (303, 400, 3)
How i fixed it ?
Adrian Rosebrock
You need to call
image_to_feature_vector
on your image before passing it intomodel.predict
.azhng
Thank you so much for this awesome tutorial. However, when I run the code on my laptop, the process with terminated with exit code of 137.
Any idea what does that mean?
Yunhwan Kim
Hi Adrian,
Thank you for awesome tutorial.
I just wonder how you could use Titan X GPU on your (seemingly) OSX machine. I see “ssh” in the top of the terminal window figure, and I guess that you access other (probably linux) machine with GPU from your OSX machine via ssh.
Then, do you have any plan to post about that process? It would be much helpful if I (and other readers) could use GPU in other machine from OSX machine.
Thank you again.
Yunhwan
Adrian Rosebrock
You are correct, Yunhwan — I am ssh’ing into my Ubuntu GPU box and then running any scripts over the SSH session. Does that help clarify your question? If you are looking to learn more about SSH and how to SSH into machines I would suggest reading up on SSH basics.
Vincent FOUCAULT
Hi Adrien,
didn’t you forget, in picture1, connection from first node in layer2 to second in layer3 ?
I’m impatient to see your next books.
CU.
Vincent
Foobar
Hi i am training an an ARM based device 4 cores 1GB RAM but i am getting a memory error when running the script it gets up to processing 24,000 images and crashes on a memory error but there is still 100MB of free space what am I doing wrong and how do I fix this?
Adrian Rosebrock
It’s hard to say without knowing which device you are using. I would confirm that the script will run on your desktop/laptop before moving on to other devices.
Foobar
It works on my laptop but I have been trying to run it on an Odroid C1. My Odroid is running a headless debian jessie for the odroid.
Adrian Rosebrock
I haven’t used Odroid before, so I’m not sure about the specifics. Debian Jessie seems like it would work just fine; however, I don’t have any experience with the Odroid so I’m not sure what the exact problem would be. Again, we typically don’t train networks on such small devices — only deploy them if memory allows.
DL
Getting this error while using Keras 1.0.7 in Anaconda
Any idea?
Thanks!
Adrian Rosebrock
Your class labels are not getting encoding properly. 99% of the time this is due to invalid paths to your training images. Double-check the path to the training images and ensure it’s correct. Also make sure you are not also using the paths to the Kaggle testing data as these filenames do not have “dog” or “cat” in them.
naitik
It’s really informative article you posted , but just curious that instead of having accuracy can i have detailed result of each image classified as wrong or right ?
Adrian Rosebrock
Can you clarify what you mean by “detailed result of each image classified as wrong or right”? I’m not sure what you mean.
Werner
Hi Adrian,
Nice post really love the work! I just have a question regarding the feedforward idea. From my understanding, feedforward network uses delta rule to learn, and does not backpropagate. How is this specified using Keras? If you were to write this feedforward Keras code using backpropagation, how would it be different?
Thanks!
Adrian Rosebrock
I think you might be confusing the standard Perceptron algorithm with multi-layer feedforward networks. The Perceptron uses the delta rule to learn while multi-layer feedforward networks use backpropagation. If you’re interested in learning more about these algorithms, how to train neural networks, and even build Convolutional Neural Networks that can understand the contents of an image, be sure to take a look at Deep Learning for Computer Vision with Python.
maxtri
thanks your work ,very good
chris
Simple question…got it to work but lets say I want to load in the test data (the pictures with just numbers) any trick to doing that?
Adrian Rosebrock
Hi Chris — can you elaborate more on what you mean by “the pictures with just numbers”? I’m not sure I understand.
chris
Sure 🙂 so in the data set of dogs and cats there is the training data that is labeled either a cat or a dog and its corresponding image number. Using this data we train and test our model (correct me if i’m wrong anywhere). Once this is done, model is trained and tested for accuracy, we could use it to predict if an image is a cat or a dog. So at kaggles site there is a set of images that you can download that is a mix of cats and dogs but minus the label of a cat or a dog. Its simply just numbered images. So how do we take that data and feed it into our model to predict if those images are cats or dogs. I want to use the model now to do actual predictions. Thanks for the prompt response.
Adrian Rosebrock
Thank you for the clarification on the question. Basically, you would like to know how take a test set and then pass it through the network to obtain the output classifications.
All you need to do is (1) pre-process your input data in the same way as your training data and (2) call the
.predict
method of the network.I would suggest taking a look at this blog post on LeNet where I demonstrate how to classify individual images.
Richard
Hi, fantastic posts – I love your blog.
I have a question, though!
In ‘SGD(lr=0.01)’, where does the 0.01 come from? You don’t say how you chose that value. Was it pie-in-the-sky, or was there some secret to your choice?
Thanks!
Adrian Rosebrock
Hi Richard — typical initial learning rates include 0.1, 0.01, and 0.001. It really depends on the specific architecture and your dataset, but those are typical starting points.
Will
I am having trouble getting the SGD algorithm to converge. The algorithm generally does well and decreases the loss, but sometimes (generally after a few epochs) the loss explodes in a few steps (by a factor of 10 or so) and does not recover. It does not simply seem to be fluctuations from navigating local minima of the objective function, it seems that there is something pathological going on. Which is bizzare because I am using the same code and hyperparameters.
Adrian Rosebrock
It sounds like you’re overfitting. Are you using the dataset in this blog post or your own custom dataset?
Shrinidhi Rao
Hi, Thanks for the tutorial. but for some reason I am not able to enter the for loop, which is giving me the error
Adrian Rosebrock
What is the error you are getting, Shrinidhi?
Foobar
I have managed to use the .predict function with this but I don’t know how to understand the data given by .predict
Adrian Rosebrock
The
.predict
method will return a NumPy with shape(N, M)
where N is the total number of data points passed into.predict
and M is your total number of class labels. You can use thenp.argmax
function to find the index with the largest class label probability for each row.Foobar
Thanks
Rolando
Hello Adrian
One question, I want to make a neural network probabilistica in python, you that you recommend me?
Adrian Rosebrock
Do Do you mean a neural network that predicts probabilities? This implementation can do that as well. Just use the
model.predict_proba
function.Rolando
Thanks, I mean a PNN type neural network
Muhammad Wahid
Hi Rolando,
Do you have an implementation of PNN in python/Keras?
Niki
Nice work! I used your code with the exact same data, but I could never reach an accuracy better than 50% on both training and test data. I tried to increase the resolution of the images, but it didn’t work. No matter what I tried I kept seeing the same pattern in the results; at the first few epochs the accuracy improved and the loss decreased, but then all of the sudden the loss became 8 or 9 times large. I thought this might be the result of overfitting, so finally I reduced both learning rate as well as the number of epochs. The best result that I got was 65.7% on training and 64.59% on the test data and this was achieved by setting learning rate = .005 and number of epochs = 25. I understand that using raw pixels as the input features does not make a strong feature vector, so I shouldn’t expect a high accuracy, but I was wondering why using exact same data and exact same code could result in such a big difference in the final result (in particular, my first results that couldn’t get any better than 50%, and this happened when I ran the code at least 7 or 8 times before making any changes)?
Adrian Rosebrock
It depends on (1) what version of Keras you are using and (2) whether you are using Theano or TensorFlow as your backend. Both of these can have different impacts on your accuracy. However, without physical access to your machine I can’t be 100% sure what the issue is.
Niki
Thank you for your response! These are the python, Keras, and Tensorflow (my keras backend engine) versions that I use:
Python 2.7.13 (anaconda 1.6.3), Tensorflow 1.2.1, Keras 2.0.5
Adrian Rosebrock
Hi Niki — thank you for sharing your Python and library versions. Unfortunately, I’m not sure what the exact issue is here. I wish I could be of more help, but like I said, without physical access to your machine, I can’t diagnose why there are such big discrepancies between the accuracies.
Diego
Hello Adrian, I am making a project where I need to classify gender using SIFT descriptor. I used those descriptors in this simple neural network but I am getting low accuracy in my train and test. What kind of neural network do you recommend me to train sift descriptors for gender classification?
Thanks!
Adrian Rosebrock
Hey Diego — I don’t recommend keypoint detectors and local invariant descriptors for this type of problem. An end-to-end Convolutional Neural network will work much better. In fact, I cover age + gender recognition inside my book, Deep Learning for Computer Vision with Python. Be sure to take a look!
Fraol
Hello Adrian, I downloaded the code and run it without a problem on the training data. but when i try to run in for the “test” directory it gives me this warning after some time
index 2 is out of bound for axis 1 with size 2
i am just beginning computer vision and machine learning and thank you for your work.
Adrian Rosebrock
The reason is because the testing data does not include the class label information (i.e., dog or cat) in the filename. To evaluate our model we need the class labels and since the training data only includes the class label we need to take a portion of the training data to compute our accuracy. If you wanted to submit your predictions to the Kaggle servers for evaluation you would need to serialize your model to disk and then run it on each of the testing images.
If you’re interested in studying computer vision and deep learning in more depth, be sure to take a look at my book, Deep Learning for Computer Vision with Python. Regardless if you’re a beginner or an advanced user you’ll find the book extremely helpful.
Katya
Thank you very much! It’s very good and clear tutorial
Adrian Rosebrock
Thanks Katya! 🙂
Maryam
Dear Adrian ,
awesome work!
In fact I am a beginner in learning deep learning for a bout 1 week. Thank you in advanced to publish a tutorial for teaching other neural network functions such as Recurrent network, Auto encoder networks , … .
Waiting for the mentioned tutorial as I know nothing about writing code on RNN, Auto encoders and other NNs.
Adrian Rosebrock
Hi Maryam — I actually have a number of tutorials on neural networks and deep learning. Take a look at them here. If you’re interested in taking a deeper dive into deep learning, I would suggest reading through my book, Deep Learning for Computer Vision with Python.
Maryam
Dear Adrian,
I am not interested in either computer vision or Image processing.
I want to start text processing especially text classification in Keras through different kinds of functions such as RNN, CNN, Auto encoders,…
would you mind please give us a tutorial about text classification by the mentioned functions???
Thank you for replying.
Adrian Rosebrock
I don’t cover text or audio classification here on PyImageSearch.com. Take a look at MachineLearningMastery. My friend Jason runs it and does a good job.
Adi
hello, Thank you for the tutorial. but for some reason I am not able run the code.can you please help me out.
Thanks.
errors :
Using TensorFlow backend.
usage: simple_neural_network.py [-h] -d DATASET
simple_neural_network.py: error: the following arguments are required: -d/–dataset
Process finished with exit code 2
Adrian Rosebrock
Hey Adi — make sure you are passing the command line arguments to the script when you execute it via the terminal (exactly as I do in the post). If you are new to command line arguments, that’s okay, but you’ll need to read up on them before continuing.
Daniel Saadia
For my part, it freezes when I want to test on the images from the directory test_images. It stays at the image 48.jpg..
Any ideas ?
Daniel Saadia
It is okay ! My bad 🙂
fedup
This must just be a joke because after the 4th attempt at clicking the pictures , just gave up
Adrian Rosebrock
I’m not sure what you mean by “4th attempt at clicking the pictures”? Could you clarify?
saka
Hello, Thank you for the tutorial. but for some reason I am not able run the code.can you please help me out.
Thanks.
errors :
ValueError: Error when checking input: expected dense_1_input to have shape (3072,) but got array with shape (1,)
Adrian Rosebrock
Double-check your input paths to your dataset directory — I’m willing to bet the class labels are not getting parsed properly.
Josh
Hey, a huge fan of the stuff that you do here. Quick question regarding your output: The output of your network is a .hdf5 file and I was wondering what that content of that file actually is an how to view? I have been doing some work with CNNs and the I was wanting to output the pixel information to .csv files. Are you outputting pixel values? And if so, how to output as .csv?
Adrian Rosebrock
The contents of the file are the weights for each layer in the network along with the optimizer state (if you ever wanted to restart training). These weights are not “viewable” in the classical sense.
Josh
Oh, that makes perfect sense. I have one more question: at any point do you randomize the data? When the images are split 75% training and 25% testing, is the data also randomized at that point?
Josh
Actually, I just noticed the random_state, but why 42? Sorry. I over-looked it the first time.
Adrian Rosebrock
It’s a Hitchhikers Gide to the Galaxy reference. I could include an explanation on how 42 is the answer to life, the universe, and everything, but perhaps that would be an entire blog post 😉 I kid, of course. We manually specify random seed values here so we can reproduce the experiment. If you’re new to working with random values you should read up on pseudorandom number generators.
Adrian Rosebrock
The data is shuffled/randomized when we create the training and testing splits.
Harish Kumar T
I am getting this error How to Solve This:
usage: simple_neural_network.py [-h] -d DATASET -m MODEL
simple_neural_network.py: error: the following arguments are required: -m/–model
Adrian Rosebrock
You need to supply the command line arguments to the script.
popandpeek
The confusion is due to the –model flag missing in the terminal entry you posted within the article –
1 $ python simple_neural_network.py –dataset kaggle_dogs_vs_cats
It’s not complete – just need to add –model model (or the path to the hd5 file in the output folder to overwrite it) to give it a place to dump the model, but the confusion is because readers are not sure if they are missing a file and the walk-through doesn’t explicitly mention this (probably because you’ve provided the model with the download and are expecting everyone to read everything and look through the folder contents, ha).
Adrian Rosebrock
Ah, I see. Thanks for catching that 🙂 I’ve updated the post.
emir
Thank you for the tutorial,
im havin’ this problem
data.append(features)
NameError: name ‘data’ is not defined
Adrian Rosebrock
Make sure you’re using the “Downloads” section to download the code rather than copying and pasting. You probably forgot to initialize the “data” list on line 33. But again, use the “Downloads” section.
Neelesh
Hi @Adrian, thanks so much for the blogs and all your help for the community. I benefitted from the blog post a lot.
A few things I learnt along the way that may help others.
I got this error on my MacBookPro:
“Your CPU supports instructions that this TensorFlow binary was not compiled to use: SSE4.1 SSE4.2 AVX AVX2 FMA”
The article on stack overflow on this error was the most informative:
https://stackoverflow.com/questions/47068709/your-cpu-supports-instructions-that-this-tensorflow-binary-was-not-compiled-to-u
The high-level gist is that the version of TensorFlow I installed is not compiled with support for the instruction set that supports matrix computations for better performance. This is true only if you are running on CPU’s. If you use GPU’s on your machine, you can ignore this warning.
2. I used Anaconda for my virtual environments and using the instructions in the blog for virtual python and simply following those along after creating an Anaconda environment worked well for me. It was great to get practical insight into why private environments are good for DL projects with the library dependencies.
3. While Simba got corrected classified as a cat, Soleil and Sapphire were categorized as dogs with about 79.48% confidence. The cats are so cute, I barely looked at the fact that the algorithm mis-classified them 🙂
4. What would be useful, perhaps as a follow up, is to see if there is mis-classficiation in the labeled data that could improve performance.
Overall, it was very useful to get my stand alone environment going on my MacBookPro. Look forward to more and the book.
Cheers,
Neelesh
Adrian Rosebrock
Thanks for the detailed writeup, Neelesh, I appreciate it. I’d also like to reiterate that this is not not an error message. It’s just a warning and one that does not have to be resolved. TensorFlow is just letting you know there are additional optimizations that can be leveraged if you so wish.
Asif
Hi adrian,
Thanks for your these simple tutorials. I tried building your code. 20 out of 50 test images giving wrong prediction, even after there are only 2 classes.
How can I can get more accuracy. Any suggestions are welcome.
Adrian Rosebrock
Hey Asif — I would suggest you read through Deep Learning for Computer Vision with Python where I provide my tips, best practices, and suggestions on how to improve your prediction accuracy.
Afiqah
Hi Adrian ,
i am a beginner in programming actually . i have problem in run my code. can you please help me out.
i have 4 class label and already change to crossentropy loss function but then i get error so i change this code :
labels = np_utils.to_categorical(labels, 2) to labels = np_utils.to_categorical(labels, 4) but i still cant settle this problem. would you help me ?
Adrian Rosebrock
What is the exact error that you are receiving? If you can let me know I can try to point you in the right direction.
I. Aliah
Great tutorial sir! But this is feed forward neural network right? What I need to do if I want to make the backpropagation neural network with python and keras too?
Adrian Rosebrock
This is a feedforward neural network. It’s also been trained via backpropagation. I get the impression that you may be new to deep learning and neural networks. That’s totally okay! It’s good to start your journey and I’m happy that I can accompany you on it as you study neural networks and Keras. My suggestion would be for you to read through my book, Deep Learning for Computer Vision with Python. The book will help teach you the fundamentals of Keras and deep learning, building up to more advanced applications. It will give you a very, very strong education and will prepare you for a career in DL.
Ozkan
Hi Dr. Rosenbrock,
I tried to read almost all question as it was hard to make control-F without knowing the keyword that I need. Everytime I run the simple_neural_network.py file it process the images so it takes a good deal of time with 25000 training dataset. Is there a way to avoid this repetition and just run the model on processed data? I hope I expressed my answer clearly… Thank you
Adrian Rosebrock
Is your goal to train the model once and then save it to disk, that way you don’t have to retrain it? If so, refer to this tutorial.
Hermawan Mulyono
Hi Adrian,
Thank you very much for this excellent tutorial. I was able to run the code for training. Unfortunately, when running testing_network.py, I had a problem related to GTK not being able to open display. I ran it on a virtual machine (Microsoft) with SSH. At the moment, I can use xterm and in the xterm window, I can run testing_network.py. However, I don’t really like explicitly typing xterm every time I want to run my code.
Do you have any better solutions?
Thank you!
Adrian Rosebrock
Enable X11 forwarding when SSH’ing into your system:
$ ssh -X username@your_ip_address
Anicetus
This is good Adrian. I really enjoy your style of presentation.
I use Windows platform but have a working implementation. However, I would like to use Ubuntu as your support is for Ubuntu. Please, how can I install Ubuntu in my Windows laptop?
Thanks very much.
Adrian Rosebrock
I would suggest you look into either (1) dual booting or (2) using a virtual machine. I offer a pre-configured Ubuntu VM that will run on Windows inside my book, Deep Learning for Computer Vision with Python.
Gaby Solano
Hi Adrian, I would like to ask a question. When we use deep Learning, with a dataset of images, should we apply gray scale and flatten function? or can we use a descriptor like HOG or LBP? I only have seen examples without applying descriptors such as HOG or LBP. I am a little confused.
Adrian Rosebrock
No, CNNs operate on the raw pixel intensties of the images. You don’t need to perform any additional feature extraction. I would suggest you read through Deep Learning for Computer Vision with Python so you can learn the fundamentals of Deep Learning with images.
Mannu Jha
Hi Adrian,
I need to do object detection using keras but with my own created neural network. So is there a tutorial for that ?
Any help will be appreciated.
Adrian Rosebrock
I cover object detection with Keras/TensorFlow inside my book, Deep Learning for Computer Vision with Python. I suggest you start there.
Maryam
Where are the weights ?? that is used for each neuron or node ??In the whole code, where are the weights ? and where the weights are updated ??
Adrian Rosebrock
The weights are updated via backpropagation. Keras automatically handles the weight update for you.
Maryam
But on which line of code the weights are updated ?? On where we call the backpropagation algorithm??
Adrian Rosebrock
The “.fit” method handles backpropagation and weight update automatically.
Danish
Why is it that when I use the dataset from kaggle, it takes significantly longer to process the images when compared to processing the dataset from the Downloads section that you have provided? Aren’t both the datasets the same?
Adrian Rosebrock
That’s incredibly strange. I doubt it’s Kaggle-related. Perhaps your image datasets from Kaggle are just significantly larger?