Saturday 11 February 2012

Installing Opencv 2.3 in Ubuntu

Opencv is an awesome library for Real-Time Computer Vision. You can read my article on the same blog  for details about Opencv. I found this atricle in the internet which is the best article for installing Opencv on Ubuntu. You can visit the following link or you can read it on my own blog.
http://thebitbangtheory.wordpress.com/2011/10/23/how-to-install-opencv-2-3-1-in-ubuntu-11-10-oneiric-ocelot-with-python-support/#comment-224
I will be commenting in between, on how I installed it and what problems I faced


This “how to” is a mix of two other great tutorials on OpenCV installations: A Compreehensive Guide to Installing and Configuring OpenCV 2.3.1 on Ubuntu from ozbots.org; and the OpenCV Installation Guide on Debian and Ubuntu from the OpenCV Wiki. I used this procedure to successfully install OpenCV on two amd64 computers (a laptop and a desktop) running Ubuntu 11.10 Oneiric Ocelot. However, if you find any problem you can check the Comprehensive OpenCV Installation Troubleshooting Guide from ozbots.
1. Remove any installed versions of ffmpeg and x264
1sudo apt-get remove ffmpeg x264 libx264-dev
2. Get all the dependencies
This will take lots of time seriously. The problem I faced here was that some of the packages are not there or are missing so It was not executing the command.Here is the trick that I used while Installing for the following steps
You can use the very first command as it is i.e. sudo apt-get install update
You can break the second apt-get command like this
sudo apt-get install build-essential
sudo apt-get install checkinstall
sudo apt-get install git
See and compare.
.... and so on
Copy all these commands in a file named try and save it. Now run the following command in the terminal
sudo bash try
This execute each command serially and so even if some packages are missing it will install the other packages. And don't worry about the missing packages..You will be doing fine without them.
1sudo apt-get update
2sudo apt-get install build-essential checkinstall git pkg-config cmake libpng12-0 libpng12-dev libpng++-dev libpng3 libpnglite-dev libpngwriter0-dev libpngwriter0c2 libfaac-dev libjack-jackd2-dev libjasper-dev libjasper-runtime libjasper1 libmp3lame-dev libopencore-amrnb-dev libopencore-amrwb-dev libsdl1.2-dev libtheora-dev libva-dev libvdpau-dev libvorbis-dev libx11-dev libxfixes-dev libxvidcore-dev texi2html yasm zlib1g-dev zlib1g-dbg zlib1g libgstreamer0.10-0 libgstreamer0.10-dev libgstreamer0.10-0-dbg gstreamer0.10-tools gstreamer0.10-plugins-base libgstreamer-plugins-base0.10-dev gstreamer0.10-plugins-good gstreamer0.10-plugins-ugly gstreamer0.10-plugins-bad gstreamer0.10-ffmpeg pngtools libtiff4-dev libtiff4 libtiffxx0c2 libtiff-tools libjpeg8 libjpeg8-dev libjpeg8-dbg libjpeg-prog libavcodec-dev libavcodec52 libavformat52 libavformat-dev libxine1-ffmpeg libxine-dev libxine1-bin libunicap2 libunicap2-dev libdc1394-22-dev libdc1394-22 libdc1394-utils swig python-numpy  libpython2.7 python-dev python2.7-dev libjpeg-progs libjpeg-dev libgtk2.0-0 libgtk2.0-dev gtk2-engines-pixbuf
3. Download and install x264 – download any recent stable snapshot from ftp://ftp.videolan.org/pub/videolan/x264/snapshots/  (I used x264-snapshot-20111012-2245-stable.tar.bz2) and extract it to a folder. Then enter the folder and configure and build it:
This step will not take much time
1./configure --enable-static
2make
3sudo make install
NOTE: In my computers (64-bit) I had to add the flags “–enable-pic –enable-shared” to the configuration. Otherwise I would get compilation errors when building OpenCV. If you get them too, run
1sudo make clean
and reconfigure and rebuild using
1./configure --enable-static --enable-pic --enable-shared
2make
3sudo make install
4. Download and install ffmpeg – download any recent stable snapshot from http://ffmpeg.org/download.html (I used ffmpeg-0.8.5.tar.gz) and extract it to a folder. Then enter the folder and configure and build it:
This may take some time.
1./configure --enable-gpl --enable-libfaac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libtheora --enable-libvorbis --enable-libx264 --enable-libxvid --enable-nonfree --enable-postproc --enable-version3 --enable-x11grab
2make
3sudo make install
NOTE: Once again, in my computers (64-bit) I had to add the flags “–enable-pic –enable-shared” to the configuration. Otherwise I would get compilation errors when building OpenCV. If you get them too, run
1sudo make clean
and reconfigure and rebuild using
1./configure --enable-gpl --enable-libfaac --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libtheora --enable-libvorbis --enable-libx264 --enable-libxvid --enable-nonfree --enable-postproc --enable-version3 --enable-x11grab --enable-pic --enable-shared
2make
3sudo make install
5. Download and install v4l – download any recent stable snapshot from http://www.linuxtv.org/downloads/v4l-utils/ (I used v4l-utils-0.8.5.tar.bz2) and extract it to a folder. Then enter the folder and build it:
1make
2sudo make install
6. Download and install OpenCV – download OpenCV 2.3.1 from  http://sourceforge.net/projects/opencvlibrary/files/ and extract it to a folder. Then enter the folder and build it:
This step can also take some time. Just sit behind and watch.
1mkdir release
2cd release
3cmake -D CMAKE_BUILD_TYPE=RELEASE -D CMAKE_INSTALL_PREFIX=/usr/local -D BUILD_PYTHON_SUPPORT=ON -D BUILD_EXAMPLES=ON ..
4make
5sudo make install
7. Configure Linux – add the following line to your .bashrc in order to tell linux where the shared libraries for OpenCV are located without having to enter it everytime you start a new terminal:
1export LD_LIBRARY_PATH=/usr/local/lib
using any text editor add the following lines to the end of your /etc/bash.bashrc file
root permission should be given to gedit. You cannot edit the bash.bashrc file without it.
The following command will work for you
sudo gedit /etc/bash.bashrc
1PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig
2export PKG_CONFIG_PATH
8. Reboot.
That’s it! If you perform all the steps indicated you should have OpenCV installed in your system. You can check the samples in <your opencv folder>/samples/ . To compile all the C/C++ samples at once you can enter the <your opencv folder>/samples/c folder and give the build_all.sh script permissions to be executed
1chmod +x build_all.sh
Then just run
1./build_all.sh
and all the samples will be compiled.
To make python work run
1python
2import cv2
If no error occurs, then the python wrappers are successfully installed.
To compile code that uses OpenCV libraries use
1g++ `pkg-config --cflags opencv` my_code.cpp -o my_code `pkg-config --libs opencv`
If you find any problems in this tutorial post them in the comments. I can’t promise that I’ll find the solution, since I’m not an expert, but I’ll try.
Update (24/10/11): I placed an entry on this blog on How to use CMake with OpenCV to build projects that use the OpenCV libraries.Check it out if you want
Update (29/01/12): As suggested by blog reader Cactus (thanks for your contribution :) ), I’ve added the packages “libopencore-amrnb-dev” and “gtk2-engines-pixbuf” to step 2.
Later I’ll post some basic projects using OpenCV.

 I successfully installed opencv on my system. Hoping same from your side. Gud Luck . Happy Coding.