Thursday, February 27, 2014

Displaying the video with Open CV and C

In previous posts you have seen how we can load and display images with the Open CV and C language. Open CV can be used to process videos as well. Processing the videos is simple as the images with the Open CV. This is because the videos are made with the sequence of images. These images are called frames. Generally the videos has the frame rate of 24-30 called as fps. fps represents frames per seconds.

By using Open CV we will grab the each frame from the video from starting frame. After getting the frame from the video to memory we display it as a normal image. If we want to process the grabbed frame we can pass that frame to the processing function and we get result back.

The fallowing code snippet helps you to under stand this process.


#include "stdafx.h" 
#include "cv.h"
#include "highgui.h"
#include <string>
#include <dirent.h>
using namespace std;
CvCapture * capture;
    char* filename;
    string fullpath,path;
    DIR *dp;
    struct dirent *ep;
    const char* full_path;
class base
{
public:
virtual void input()=0;
virtual void process()=0;
virtual void play()=0;
virtual void destroy()=0;
};

class localfile:public base
{
public:
    localfile(char* file);
void input();
void process();
void play();
void destroy();
};
void localfile::input()
{
capture = cvCreateFileCapture(filename);
}
void localfile::process()
{
for ( ; ; )
    {
        play();
        cvWaitKey(33);
    }
}
void localfile::play()
{
 IplImage * frame = cvQueryFrame(capture);
 cvShowImage("Video",frame);
}
void localfile::destroy()
{
cvDestroyWindow("Video");
}
localfile::localfile(char* file)
{
filename=file;
}

int main(int argc,char** argv)
{
    char* path;
    printf("Enter the path to the Video");
    gets(path);
    localfile obj1(path);
    obj1.input();
    obj1.process();
    obj1.destroy();
    return 0;
}

When we run this code it asks for the path to the video file. Based on the path to the video the CvCapture structure will be initialized with the function cvCreateFileCapture which is available in Open CV . Now this structure helps us to get the frames as well as lot information called meta data of the video.

Open CV provides simple function called cvQueryFrame(); this function takes the CvCapture type variable as the argument. and returns the frame for each call to this function. It automatically returns the next frame from the video. After getting the frame we can display this frame as described in the previous posts.

Tuesday, February 25, 2014

Display Images as video with Open CV part-2

In previous post we have seen how we can display the sequence of images as video. But in that process we have seen a problem which can break our code. The basic condition we posed on our code is the folder contains only images. It does not have any other files which are not supported by Open CV.

In this post I will try to explain how we can get rid of this problem by using the regular expressions. These regular expressions are available now in c++ as well.To use this feature we need to include the regex header file. and we have to use the name space std::tr1

#include "stdafx.h"
#include "cv.h"
#include <regex>
#include "highgui.h"
#include <string>
#include <dirent.h>

using namespace std;
using namespace std::tr1;

char* filename;
string fullpath,path;
DIR *dp;
struct dirent *ep;
const char* full_path;

class base
{
public:
    virtual void input()=0;
    virtual void process()=0;
    virtual void destroy()=0;
};

class imagetovideo:public base
{
public:
    imagetovideo(char* folderpath);
    void input();
    void process();
    void destroy();
};

void imagetovideo::input()
{
    const char* mpath=path.c_str();
    dp=opendir(mpath);
}

void imagetovideo::process()
{
    std::tr1::regex rgx("(.jpg$)|(.png$)|(.jpeg$)|(.bmp$)|(.gif)");
    cmatch result;
    cvNamedWindow("Video",0);
    cvResizeWindow("Video",640,320);
        while(ep=readdir(dp))
        {
            regex_search(ep->d_name, result, rgx);
            if(!result.empty())   
            {
                puts(ep->d_name);
                fullpath=path+(ep->d_name);
                full_path=fullpath.c_str();
                puts(full_path);
                IplImage* img=cvLoadImage(full_path);
                cvShowImage("Video",img);
                    if(cvWaitKey(1000)==27)
                    {
                        cvDestroyWindow("Video");
                        break;
                    }
                cvReleaseImage(&img);
            }
            }
}

void imagetovideo::destroy()
{
    closedir (dp);
    cvDestroyWindow("Video");
}

imagetovideo::imagetovideo(char* folderpath)
{
    path=folderpath;
}

int main(int argc,char** argv)
{
    char* path;
    printf("Enter the path to the image");
    gets(path);
    imagetovideo obj1(path);
    obj1.input();
    obj1.process();
    obj1.destroy();
    return 0;
}

If you observe the above code nothing changed from the previous post code snippet. Only we have added the few lines of code which can control the flow of file paths to the cvShowImage function. Now the code is robust. This code will process only the image files. The regular expression filters out the other files which are not images.

The input for the path must be like D:/x/ in this D is the local disk drive number and the x is the folder containing the images. If the folder path is not specified in this manner code will not work.

In this code I used regular expressions to identify the file format. If the file is image then only file is passed to the cvShowImage function. I will explain the regular expression code lines used in this post.

std::tr1::regex rgx("(.jpg$)|(.png$)|(.jpeg$)|(.bmp$)|(.gif)");

observe the above line. You can see the extensions for the images as well as they ended with the dollar symbol. and they are separated with the | symbol. Here $ symbol indicates that in the given string search for the .jpg or .png or .jpeg etc at the end of the string.

cmatch result;

here result is the resul coming out from the  regex_search(ep->d_name, result, rgx); expression. This expression processes the string passed in the first argument the third argument is the regular expression and the second one is the cmatch type.

If this method finds the match it will store that in the cmatch type variable. If the match is found the match will be stored here. So if this not empty the file is image file. else the file is not image.

Saturday, February 22, 2014

Display Images as Video with Open CV

Till now we have seen how we can use Open CV with the C and C++ to display images. You may wonder is there any way to display the images continuously. Yes definitely we can do. Just we have to place the image display code in a loop. Is this enough... Think for a while...
How to write a loop we can use for loop or while loop or any other loop. But before that we must have knowledge of number of images as well as names of the images moreover we must know the directory where the images are stored. From this we can infer that we must get the names of the images from the desired directory. for this we can use dirent.h header file. Which hides all the implementation details of the process. It returns the file names with the file format as well. You can refer this link for more details.
The fallowing code is useful for this.

#include "stdafx.h"
#include "cv.h"
#include "highgui.h"
#include <string>
#include <dirent.h>
using namespace std;

char* filename;
    string fullpath,path;
    DIR *dp;
    struct dirent *ep;
const char* full_path;
class base
{
public:
virtual void input()=0;
virtual void process()=0;
virtual void destroy()=0;
};

class imagetovideo:public base
{
public:
imagetovideo(char* folderpath);
void input();
void process();
void destroy();
};

void imagetovideo::input()
{
const char* mpath=path.c_str();
dp=opendir(mpath);
}
void imagetovideo::process()
{
cvNamedWindow("Video",0);
cvResizeWindow("Video",640,320);
int c=0;
while(ep=readdir(dp))
{

c++;
if(c>2)
{
puts(ep->d_name);
fullpath=path+(ep->d_name);
full_path=fullpath.c_str();
puts(full_path);
IplImage* img=cvLoadImage(full_path);
cvShowImage("Video",img);
if(cvWaitKey(1000)==27)
{
cvDestroyWindow("Video");
break;
}
cvReleaseImage(&img);
}
}
}

void imagetovideo::destroy()
{
closedir (dp);
cvDestroyWindow("Video");
}
imagetovideo::imagetovideo(char* folderpath)
{
path=folderpath;
}
int main(int argc,char** argv)
{
char* path;
printf("Enter the path to the image");
gets(path);
imagetovideo obj1(path);
obj1.input();
obj1.process();
obj1.destroy();
return 0;
}

Here we have a base class. Which is implemented as abstract class. Our main class which has code is inherited from the base class. This derived class provides the functionality for our program. It contains three methods and one constructor. The constructor initializes the  path to the folder path. init method initializes the variables available in the dirent header file. The process method gets the file names one by one from the folder and displays the corresponding image in the window. The destroy method releases all the resources used by the Open CV as well as the dirent header file.

Caution: If the folder contains files other than the images the code breaks. Because the dirent header file gets all the files irrespective of the file format even hidden files. We are directly displaying the images with out any filtering. we assumed that the folder contains only images. The reason behind code breaking is the cvload image display only images. If we passed files other than the images this function having no knowledge of the processing. So the code breaks.

Wednesday, February 19, 2014

Displaying Image with Open CV and C++

In first three posts of image processing I explained how we can use Open CV along with C language to display the image. I already stated that Open CV is not limited to C language. We can use C++ language as well with Open CV.
In C++ wrapper of Open CV images are treated as the two dimensional arrays. In other words they are treated as matrices. In this post I will explain how we can use C++ with Open CV.

Fallowing is the code snippet to achieve the above mentioned

#include "StdAfx.h"
#include <iostream>
#include "cv.h"
#include "highgui.h"

using namespace cv;
using namespace std;

class ImageProcessing
{
private:

string path;
Mat image;
int choice,color;

public:

ImageProcessing()
{
cout<<"Enter the path for the Image\n";
cin>>path;

cout<<"Choose from the fallowing\n";
cout<<"1. To load as color image\n";
cout<<"2.To load as gray scale image\n";
cout<<"3. To load the image as unchanged\n";
cin>>color;

cout<<"Select the behaviour of window\n";
cout<<"1. For WINDOW_NORMAL\n";
cout<<"2. For WINDOW_AUTOSIZE\n";
cout<<"3. For WINDOW_OPENGL\n";
cin>>choice;
}

void loadImage()
{
switch(color)
{
case 1:
image=imread(path,CV_LOAD_IMAGE_COLOR);
break;
case 2:
image=imread(path,CV_LOAD_IMAGE_GRAYSCALE);
break;
case 3:
image=imread(path,CV_LOAD_IMAGE_UNCHANGED);
break;
default:
image=imread(path,CV_LOAD_IMAGE_UNCHANGED);
}
}

void displayImage()
{
switch(choice)
{
case 1:
namedWindow("Image",WINDOW_NORMAL);
break;
case 2:
namedWindow("Image",WINDOW_AUTOSIZE);
break;
case 3:
namedWindow("Image",WINDOW_OPENGL);
break;
default :
namedWindow("Image",WINDOW_NORMAL);
}

imshow("Image",image);
cout<<"Press ESC key to close the window";
if(cvWaitKey(1000)==27)
{
destroyWindow("Image");
}
cout<<"Press any key to exit";
}
};

int main()
{
ImageProcessing *ip=new ImageProcessing();
ip->loadImage();
ip->displayImage();
return 0;
}

The code starts with name spaces. We imported two name spaces they are cv and std. cv is name space containing all the declarations for the Open CV. std contains all declarations for the C++. Next we have class having two methods and constructor. Constructor is invoked when the object for the class is  created .
The code inside the constructor gets executed. This initiates the variables of the class with the values provided by the user.
The subsequent methods are useful for loading the image and displaying it. Now closely observe the loadimage method. It has one function from the Open CV imread. Imread is used for loading the image from the memory typically from the secondary memory it initialises the Mat type variables with the images the second parameter is to control the colour of the image.
It's turn for the displayimage method. The code is almost same as the C code the only change is we left the cv term before the method names. But all these methods are defined in the cv namespace.
If you ommit the using namespace cv; command the compiler generates the error saying that I am unable to locate the method.

                                                                                                                                         

Tuesday, February 18, 2014

Displaying Image based on user input

In previous post I explained how to display the image with the help of Open CV and C. In this post I will explain how we can give the user control so that he can control the output based on his input. To do this we need to provide the user a choice to select the window size as well as the path to the image to be displayed.
Fallowing is the code snippet:

void main()
{
char* path;
int choice;
printf("Enter the path to the image");
gets(path);
IplImage* image=cvLoadImage(path);
printf("Select the behaviour of window\n");
printf("1. For WINDOW_NORMAL\n");
printf("2. For WINDOW_AUTOSIZE\n");
printf("3. For WINDOW_OPENGL\n");
scanf("%d",&choice);
switch(choice)
{
case 1:
cvNamedWindow("Image",WINDOW_NORMAL);
break;
case 2:
cvNamedWindow("Image",WINDOW_AUTOSIZE);
break;
case 3:
cvNamedWindow("Image",WINDOW_OPENGL);
break;
default :
cvNamedWindow("Image",WINDOW_NORMAL);
}

cvShowImage("Image",image);
printf("Press ESC key to close the window");
if(cvWaitKey(1000)==27)
{
cvDestroyWindow("Image");
}
printf("Press any key to exit");
getch();
}

I will explain the code line by line. We need two variables to hold the path to the image to be displayed and second one is for to hold the user choice for window behavior. char * path is for holding the path for the image int choice for holding the user choice for holding the window behavior. The rest of the code explanation is same as for the previous post code snippet.
We can add one more functionality to the previous code snippet. that is we can add one more condition that user can use to load the image as color or gray scale image. In first post I explained how to specify the second argument for the cvLoadImage function. which felicitates us to control the behavior of function.

CV_LOAD_IMAGE_COLOR the loaded image is forced to be a 3-channel color image
CV_LOAD_IMAGE_GRAYSCALE the loaded image is forced to be grayscale
CV_LOAD_IMAGE_UNCHANGED the loaded image will be loaded as is

In the fallowing snippet I added the previous condition.
void main()
{
char* path;
int choice,color;
IplImage* image;
printf("Enter the path to the image");
gets(path);
printf("Choose from the fallowing\n");
printf("1. To load as color image\n");
printf("2.To load as gray scale image\n");
printf("3. To load the image as unchanged\n");
scanf("%d",&color);
switch(color)
{
case 1:
image=cvLoadImage(path,CV_LOAD_IMAGE_COLOR);
break;
case 2:
image=cvLoadImage(path,CV_LOAD_IMAGE_GRAYSCALE);
break;
case 3:
image=cvLoadImage(path,CV_LOAD_IMAGE_UNCHANGED);
break;
default:
image=cvLoadImage(path,CV_LOAD_IMAGE_UNCHANGED);
}
printf("Select the behaviour of window\n");
printf("1. For WINDOW_NORMAL\n");
printf("2. For WINDOW_AUTOSIZE\n");
printf("3. For WINDOW_OPENGL\n");
scanf("%d",&choice);
switch(choice)
{
case 1:
cvNamedWindow("Image",WINDOW_NORMAL);
break;
case 2:
cvNamedWindow("Image",WINDOW_AUTOSIZE);
break;
case 3:
cvNamedWindow("Image",WINDOW_OPENGL);
break;
default :
cvNamedWindow("Image",WINDOW_NORMAL);
}

cvShowImage("Image",image);
printf("Press ESC key to close the window");
if(cvWaitKey(1000)==27)
{
cvDestroyWindow("Image");
}
printf("Press any key to exit");
getch();
}


Thursday, February 13, 2014

Displaying the Image with Open CV and C

This is the second post in Image processing. In previous post I explained the very basic code written with Open CV in C language which is useful for loading the image into the program and displaying it.

In this post I will elaborate the steps involved in displaying the image with Open CV and C.

void main()
{
IplImage* image=cvLoadImage("E:\\Capture.jpg");
cvNamedWindow("Image",WINDOW_AUTOSIZE);
cvShowImage("Image",image);
if(cvWaitKey(1000)==27)
{
cvDestroyWindow("Image");
}
}

This is same as the program in previous post. only change is you explicitly created the window to show the image. and you changed the integer passed to the cvWaitKey function. I guess you know that the ASCII value of the escape is 27. To close the window we compared the ASCII value of the escape key with the ASCII value returned by the waitkey function. If those are equal you are destroying the window so image no longer visible to you.

The cvNamedWindow function takes the two arguments first one is the name of the window and second is the parameter which controls the behavior of the window.

WINDOW_NORMAL If this is set, the user can resize the window (no constraint).
WINDOW_AUTOSIZE If this is set, the window size is automatically adjusted to fit the displayed image (see imshow() ), and you cannot change the window size manually.
WINDOW_OPENGL If this is set, the window will be created with OpenGL support.

In next post I will explain the enhanced version of the code.

                                                                                                                                         

Loading Images into the Program


   In real life we are dealing with lot of images. Especially after advancement of computers and processing capabilities of computers image processing become more easy. For  easy processing of images we can use lot of image processing libraries like Open CV, Emgu CV or well known MATLAB. In this tutorial I will demonstrate  how to use Open CV for image processing.

Software requirements:

1. Open CV
2. Visual studio

To process any image first we need to load it into the computer memory. This is very easy. Open CV provides lot of functions among those we have one function which helps us to load the image into the program. Basically Open CV supports C,C++,Java as well as Python. we can use any programming language along with Open CV based on your comfort.

I will use C and C++ to demonstrate the loading of image into the program.

The basic program to display the image using Open CV is

void main()
{
IplImage* image=cvLoadImage("E:\\Capture.jpg");
cvShowImage("Image",image);
cvWaitKey(1);
getch();
}


IplImage* is a structure holding the image data. It points to the memory location of the image. cvLoadImage function is useful for loading the image. Generally it takes to arguments first one is the path to the image to be loaded second one specifies weather the image to be loaded as color image or gray scale image or unchanged. 
CV_LOAD_IMAGE_COLOR the loaded image is forced to be a 3-channel color image
CV_LOAD_IMAGE_GRAYSCALE the loaded image is forced to be grayscale
CV_LOAD_IMAGE_UNCHANGED the loaded image will be loaded as is.

cvShowImage is useful for displaying the image on a window. the first argument takes the name of the window. and second argument takes the variable of type iplImage*. We can generate the image explicitly and we can pass the name of that window to the function other wise the function generates it for us implicitly.

cvWaitKey is the delay function which gives the time for the processor to load the image on to the window.
if forget to specify this function image can not be displayed. it takes the integer as the argument and returns the ASCII key value of the pressed key.

In next post i will try to explain the process in detail with more detailed code and its explanation and examples.

DC motor control with Pulse Width Modulation Part 1

DC Motor intro DC motor is a device which converts electrical energy into kinetic energy. It converts the DC power into movement. The typica...