ChangeLog

Version 116 (Vadim Pisarevsky, 2015-12-22 07:08 pm)

1 1
h1. OpenCV Change Logs
2 19 Vadim Pisarevsky
3 19 Vadim Pisarevsky
{{>toc}}
4 1
5 116 Vadim Pisarevsky
h2. version:2.4.6 coming...
6 116 Vadim Pisarevsky
7 116 Vadim Pisarevsky
__Summer, 2013__
8 116 Vadim Pisarevsky
9 116 Vadim Pisarevsky
List of contributors:
10 116 Vadim Pisarevsky
<pre>
11 116 Vadim Pisarevsky
~/Work/OpenCV/opencv> git shortlog --no-merges -n -s 2.4 --not 2.4.5
12 116 Vadim Pisarevsky
    42  yao
13 116 Vadim Pisarevsky
    36  peng xiao
14 116 Vadim Pisarevsky
    19  Vladislav Vinogradov
15 116 Vadim Pisarevsky
    18  Roman Donchenko
16 116 Vadim Pisarevsky
    13  Peng Xiao
17 116 Vadim Pisarevsky
    12  Alexander Smorkalov
18 116 Vadim Pisarevsky
     8  Andrey Kamaev
19 116 Vadim Pisarevsky
     8  Andrey Pavlenko
20 116 Vadim Pisarevsky
     5  alex77git
21 116 Vadim Pisarevsky
     4  Dominik Rose
22 116 Vadim Pisarevsky
     3  Ivan Korolev
23 116 Vadim Pisarevsky
     3  abidrahmank
24 116 Vadim Pisarevsky
     3  poiuytrez
25 116 Vadim Pisarevsky
     2  Kirill Kornyakov
26 116 Vadim Pisarevsky
     2  Sergei Nosov
27 116 Vadim Pisarevsky
     1  Alexander Shishkov
28 116 Vadim Pisarevsky
     1  Andrew Senin
29 116 Vadim Pisarevsky
     1  Bo Li
30 116 Vadim Pisarevsky
     1  Dustin Spicuzza
31 116 Vadim Pisarevsky
     1  Egbert van der Wal
32 116 Vadim Pisarevsky
     1  Gurpinder Singh Sandhu
33 116 Vadim Pisarevsky
     1  Jan Machacek
34 116 Vadim Pisarevsky
     1  Luis Díaz Más
35 116 Vadim Pisarevsky
     1  Peter Minin
36 116 Vadim Pisarevsky
     1  ShengyinWu
37 116 Vadim Pisarevsky
     1  Siva Prasad Varma
38 116 Vadim Pisarevsky
     1  caorong
39 116 Vadim Pisarevsky
     1  dave
40 116 Vadim Pisarevsky
     1  ograycode
41 116 Vadim Pisarevsky
</pre>
42 116 Vadim Pisarevsky
43 104 Vadim Pisarevsky
h2. version:2.4.5
44 104 Vadim Pisarevsky
45 104 Vadim Pisarevsky
__April, 2013__
46 104 Vadim Pisarevsky
47 108 Vadim Pisarevsky
p((((. !winrt_opencv.jpg!
48 106 Vadim Pisarevsky
49 113 Vadim Pisarevsky
* Experimental WinRT support (build for [[WindowsRT]] guide)
50 106 Vadim Pisarevsky
51 106 Vadim Pisarevsky
p((((. !superres.jpg!
52 106 Vadim Pisarevsky
53 106 Vadim Pisarevsky
* the new video super-resolution module has been added that implements the following papers:
54 109 Vadim Pisarevsky
55 109 Vadim Pisarevsky
  - S. Farsiu, D. Robinson, M. Elad, P. Milanfar. Fast and robust Super-Resolution. Proc 2003 IEEE Int Conf on Image Process, pp. 291–294, 2003.
56 109 Vadim Pisarevsky
  - D. Mitzel, T. Pock, T. Schoenemann, D. Cremers. Video super resolution using duality based TV-L1 optical flow. DAGM, 2009.
57 106 Vadim Pisarevsky
58 106 Vadim Pisarevsky
p((((. !clahe.jpg!
59 106 Vadim Pisarevsky
60 106 Vadim Pisarevsky
* CLAHE (adaptive histogram equalization) algorithm has been implemented, both CPU and GPU-accelerated versions (in imgproc and gpu modules, respectively)
61 106 Vadim Pisarevsky
62 1
p((((. !OpenCL.jpg!
63 1
64 111 Vadim Pisarevsky
* there are further improvements and extensions in ocl module:
65 111 Vadim Pisarevsky
   - 2 stereo correspondence algorithms: stereobm (block matching) and stereobp (belief propagation) have been added
66 111 Vadim Pisarevsky
   - many bugs fixed, including some crashes on Intel HD4000
67 1
68 111 Vadim Pisarevsky
p((((. !visual_studio_image_watch.png!
69 110 Vadim Pisarevsky
70 115 Vadim Pisarevsky
* The tutorial on displaying @cv::Mat@ inside Visual Studio 2012 debugger has been contributed by Wolf Kienzle from Microsoft Research. See http://opencv.org/image-debugger-plug-in-for-visual-studio.html
71 110 Vadim Pisarevsky
72 111 Vadim Pisarevsky
73 107 Vadim Pisarevsky
p((((. !github.jpg!
74 1
75 1
* 78 pull requests have been merged. Big thanks to everybody who contributed!
76 1
77 111 Vadim Pisarevsky
78 1
p((((. !http://code.opencv.org/attachments/949/bug.png!
79 110 Vadim Pisarevsky
80 115 Vadim Pisarevsky
* At least 25 bugs have been fixed since 2.4.4 (see http://code.opencv.org/projects/opencv/issues select closed issues with target version set to "2.4.5").
81 104 Vadim Pisarevsky
82 100 Vadim Pisarevsky
h2. version:2.4.4
83 86 Vadim Pisarevsky
84 100 Vadim Pisarevsky
__March, 2013__
85 86 Vadim Pisarevsky
86 88 Vadim Pisarevsky
p((((. !java_logo.svg.png!
87 86 Vadim Pisarevsky
88 102 Vadim Pisarevsky
* This is the biggest news in 2.4.4 - we've got full-featured OpenCV Java bindings on a desktop, not only Android! In fact you can use any JVM language, including functional Java or handy Groovy. Big thanks to "Eric Christiansen":https://plus.google.com/u/0/114834902961564956461 for the contribution! Check the "tutorial":http://docs.opencv.org/doc/tutorials/introduction/desktop_java/java_dev_intro.html for details and code samples.
89 86 Vadim Pisarevsky
90 87 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/960/android_ocv_small.png!
91 87 Vadim Pisarevsky
92 102 Vadim Pisarevsky
* Android application framework, samples, tutorials, OpenCV Manager are updated, see [[Android Release Notes]] for details.
93 87 Vadim Pisarevsky
94 86 Vadim Pisarevsky
p((((. !CUDA.jpg!
95 86 Vadim Pisarevsky
96 102 Vadim Pisarevsky
* Numerous improvements in @gpu@ module and the following new functionality & optimizations:
97 102 Vadim Pisarevsky
** Optimizations for the NVIDIA Kepler architecture
98 102 Vadim Pisarevsky
** NVIDIA CARMA platform support
99 102 Vadim Pisarevsky
** HoughLinesP for line segments detection
100 102 Vadim Pisarevsky
** Lab/Luv <-> RGB conversions
101 94 Vadim Pisarevsky
102 86 Vadim Pisarevsky
p((((. !OpenCL.jpg!
103 1
104 102 Vadim Pisarevsky
* Let us be more verbose here. The openCL-based hardware acceleration (ocl) module is now mature, and, with numerous bug fixes, it is largely bug-free. Correct operation has been verified on all tested platforms, including discrete GPUs (tested on NVIDIA and AMD boards), as well as integrated GPUs (AMD APUs as well as Intel Ivy Bridge iGPUs). On the host side, there has been exhaustive testing on 32/64 bit, Windows/Linux systems, making the ocl module a very serious and robust cross-platform GPU hardware acceleration solution. While we currently do not test on other devices that implement OpenCL (e.g. FPGA, ARM or other processors), it is expected that the ocl module will work well on such devices as well (provided the minimum requirements explained in the user guide are met).
105 102 Vadim Pisarevsky
Here are specific highlights of the 2.4.4 release:
106 102 Vadim Pisarevsky
** The @ocl::Mat@ can now use “special” memory (e.g. pinned memory, host-local or device-local).
107 102 Vadim Pisarevsky
** The ocl module can detect if the underlying hardware supports “integrated memory,” and if so use “device-local” memory by default for all operations.
108 102 Vadim Pisarevsky
** New arithmetic operations for @ocl::Mat@, providing significant ease of use for simple numerical manipulations.
109 102 Vadim Pisarevsky
** Interop with OpenCL enables very easy integration of OpenCV in existing OpenCL applications, and vice versa.
110 102 Vadim Pisarevsky
** New algorithms include Hough circles, more color conversions (including YUV, YCrCb), and Hu Moments.
111 102 Vadim Pisarevsky
** Numerous bug fixes, and optimizations, including in: blendLinear, square samples, erode/dilate, Canny, convolution fixes with AMD FFT library, mean shift filtering, Stereo BM.
112 102 Vadim Pisarevsky
** Platform specific bug fixes: PyrLK, bruteForceMatcher, faceDetect now works also on Intel Ivy Bridge chips (as well as on AMD APUs/GPUs and NVIDIA GPUs); erode/dilate also works on NVIDIA GPUs (as well as AMD APUs/GPUs and Intel iGPUs).
113 100 Vadim Pisarevsky
114 102 Vadim Pisarevsky
p((((. !update.jpg!
115 86 Vadim Pisarevsky
116 102 Vadim Pisarevsky
* Many people contributed their code in the form of "pull requests":https://github.com/Itseez/opencv/pulls?direction=desc&page=1&sort=created&state=closed. Here are some of the most interesting contributions, that were included into 2.4 branch:
117 102 Vadim Pisarevsky
** ">100":http://code.opencv.org/projects/opencv/versions/11 reported problems have been resolved since 2.4.3
118 102 Vadim Pisarevsky
** Oscar Deniz "submitted":https://github.com/Itseez/opencv/pulls?direction=desc&page=1&sort=created&state=closed smile detector and sample.
119 103 Vadim Pisarevsky
** Alexander Smorkalov created a "tutorial":http://docs.opencv.org/doc/tutorials/introduction/crosscompilation/arm_crosscompile_with_cmake.html#arm-linux-cross-compile on cross-compilation of OpenCV for Linux on ARM platforms.
120 86 Vadim Pisarevsky
121 84 Vadim Pisarevsky
h2. version:2.4.3
122 69 Vadim Pisarevsky
123 84 Vadim Pisarevsky
__November, 2012__
124 69 Vadim Pisarevsky
125 69 Vadim Pisarevsky
p((((. !threads.jpg!
126 69 Vadim Pisarevsky
127 84 Vadim Pisarevsky
* Added universal @parallel_for@ implementation using various backends: TBB (cross-platform: http://threadingbuildingblocks.org), OpenMP (cross-platform: http://en.wikipedia.org/wiki/OpenMP), Grand Central Dispatch (iOS/MacOSX: http://en.wikipedia.org/wiki/Grand_Central_Dispatch), Concurrency (Visual Studio 2010 or later: http://msdn.microsoft.com/en-us/library/dd492418.aspx), C= (http://www.hoopoesnest.com/cstripes/cstripes-details.htm). Many exiting parallel OpenCV algorithms have been converted to the new primitive. Therefore, you can enjoy performance improvements even without having to install TBB and ship it with OpenCV-based applications.
128 69 Vadim Pisarevsky
129 69 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/960/android_ocv_small.png!
130 69 Vadim Pisarevsky
131 78 Vadim Pisarevsky
* Improved OpenCV Manager, new Java samples framework, better camera support on Android, see [[Android Release Notes]] for details.
132 69 Vadim Pisarevsky
133 69 Vadim Pisarevsky
p((((. !ios6.jpg!
134 69 Vadim Pisarevsky
135 79 Vadim Pisarevsky
* *opencv2.framework* is now iOS6- and iPhone5- (armv7s) compatible. Thanks to the new threading mechanism several important OpenCV algorithms (e.g. face detection, bilateral filter, etc.) now run faster on A5 or newer dual-core chips. We also fixed bug in the framework build script and now the framework is built with "-O3" optimization instead of "-O0" in OpenCV 2.4.2. Finally, our GSoC students, Eduard Feicho and Charu Hans, have written detailed tutorials on how to add OpenCV to your iOS app, please, check http://docs.opencv.org/doc/tutorials/ios/table_of_content_ios/table_of_content_ios.html.
136 69 Vadim Pisarevsky
137 69 Vadim Pisarevsky
p((((. !python.png!
138 69 Vadim Pisarevsky
139 69 Vadim Pisarevsky
* Another our GSoC student, Alexander Mordvintsev, added several new exciting Python samples, including ASIFT, hand-written digit recognition, motion debluring and even the use of Amazon PiCloud. Check https://github.com/Itseez/opencv/tree/master/samples/python2
140 69 Vadim Pisarevsky
141 69 Vadim Pisarevsky
p((((. !profile.jpg!
142 69 Vadim Pisarevsky
143 69 Vadim Pisarevsky
* Yet another GSoC student Attila Novak has trained 2 new cascades, for silverware and profile faces. Check https://github.com/Itseez/opencv/tree/master/data/lbpcascades
144 69 Vadim Pisarevsky
145 69 Vadim Pisarevsky
p((((. !denoising.jpg!
146 69 Vadim Pisarevsky
147 69 Vadim Pisarevsky
* Another result from GSoC (that was a good year!): Victor Passichenko implemented non-local means denoising algorithm. It's not realtime, but quite decent. Please, check http://docs.opencv.org/trunk/modules/photo/doc/denoising.html
148 69 Vadim Pisarevsky
149 69 Vadim Pisarevsky
p((((. !optflow.jpg!
150 69 Vadim Pisarevsky
151 75 Vadim Pisarevsky
* Yet another result from GSoC (that was a good year indeed!): Yuri Zemlyansky implemented "simple flow" optical flow algorithm; check https://github.com/Itseez/opencv/tree/master/samples/cpp/simpleflow_demo.cpp.
152 69 Vadim Pisarevsky
153 82 Vadim Pisarevsky
p((((. !CUDA.jpg!
154 1
155 82 Vadim Pisarevsky
* Numerous improvements and new functionality in GPU module:
156 1
  - device layer opened for users; now users write CUDA device code using OpenCV.
157 1
  - LBP cascade support in cascade classifier
158 82 Vadim Pisarevsky
  - fast non local means image denoising
159 82 Vadim Pisarevsky
  - faster integral image calculation on Kepler
160 82 Vadim Pisarevsky
  - Hough circles, Hough lines and generalized Hough transform implementation
161 82 Vadim Pisarevsky
  - bilateral filter
162 82 Vadim Pisarevsky
  - generalized Flood Fill connected component labeling
163 82 Vadim Pisarevsky
  - background/foreground segmentation algorithms: Mixture of Gaussian, ViBe, GMG (A. Godbehere, A. Matsukawa, K. Goldberg) . 
164 82 Vadim Pisarevsky
  - added confidence calculation into HOG
165 82 Vadim Pisarevsky
166 82 Vadim Pisarevsky
p((((. !OpenCL.jpg!
167 82 Vadim Pisarevsky
168 82 Vadim Pisarevsky
* Technology-preview version of ocl - OpenCL-accelerated computer vision algorithms, contributed by the Chinese Academy of Science. It includes:
169 82 Vadim Pisarevsky
  - arithmetical operations
170 85 Vadim Pisarevsky
  - filtering
171 82 Vadim Pisarevsky
  - geometrical image transformations (resize, remap etc.)
172 82 Vadim Pisarevsky
  - cascade classifier (i.e. face detector)
173 82 Vadim Pisarevsky
  - optical flow
174 82 Vadim Pisarevsky
currently, it only runs on GPUs.
175 102 Vadim Pisarevsky
176 102 Vadim Pisarevsky
http://code.opencv.org/attachments/download/1147
177 69 Vadim Pisarevsky
178 69 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/949/bug.png!
179 69 Vadim Pisarevsky
180 69 Vadim Pisarevsky
* ~130 reported problems have been resolved since 2.4.2
181 69 Vadim Pisarevsky
182 1
p((((. !github.jpg!
183 1
184 1
* OpenCV has never been that social. We are at github now: http://github.com/itseez/opencv. Grab the latest versions from there, submit pull requests.
185 1
186 84 Vadim Pisarevsky
p((((. !update.jpg!
187 84 Vadim Pisarevsky
188 84 Vadim Pisarevsky
* Since 2.4.3rc we fixed several build problems (OpenCV-based applications on Xcode 4.5 & iOS6, OpenCV+TBB on Windows etc.) and closed a few issues, reported at code.opencv.org.
189 115 Vadim Pisarevsky
190 69 Vadim Pisarevsky
191 63 Vadim Pisarevsky
h2. version:2.4.2
192 50 Vadim Pisarevsky
193 50 Vadim Pisarevsky
__July, 2012__
194 50 Vadim Pisarevsky
195 66 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/960/android_ocv_small.png!
196 62 Vadim Pisarevsky
197 62 Vadim Pisarevsky
* Android package introduces a new service-based distribution model (see [[Android Release Notes]] for details).
198 62 Vadim Pisarevsky
199 59 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/951/freak.jpg!
200 1
201 59 Vadim Pisarevsky
* New keypoint descriptor FREAK has been contributed by EPFL group: Kirell Benzi, Raphael Ortiz, Alexandre Alahi and Pierre Vandergheynst. It's claimed to be superior to ORB and SURF descriptors, yet it's very fast (comparable to ORB). Please, see source://trunk/opencv/samples/cpp/freak_demo.cpp.
202 59 Vadim Pisarevsky
203 59 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/950/eigenfaces_opencv.png!
204 59 Vadim Pisarevsky
205 1
* Improved face recognizer and excellent tutorial on using it has been added by Philipp Wagner. Check the "face recognition tutorial":http://docs.opencv.org/modules/contrib/doc/facerec/facerec_tutorial.html.
206 1
207 59 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/948/100px-Apple_iOS_icon.png!
208 1
209 67 Vadim Pisarevsky
* *opencv2.framework* for iOS has been created. You can either download the binary from SourceForge or build it yourself using the simple guide: http://docs.opencv.org/doc/tutorials/introduction/ios_install/ios_install.html#ios-installation. Also, you may be interested to look at some OpenCV on iOS samples, created by our GSoC 2012 students Eduard and Charu: gsoc2012:source:/ios/trunk and read the slides of the tutorial: gsoc2012:source:/ios/trunk/doc/CVPR2012_OpenCV4IOS_Tutorial.pdf
210 1
211 59 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/949/bug.png!
212 59 Vadim Pisarevsky
213 61 Vadim Pisarevsky
* "Another 50 bugs":http://code.opencv.org/projects/opencv/issues?fixed_version_id=6&set_filter=1&status_id=5 have been fixed since 2.4.1 release.
214 59 Vadim Pisarevsky
215 59 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/952/logo.png!
216 50 Vadim Pisarevsky
217 67 Vadim Pisarevsky
* It's not about the code, but now we have the brand-new user site, http://opencv.org and the new stack overflow-like site with answers to the most popular questions http://answers.opencv.org
218 1
219 65 Vadim Pisarevsky
p((((. !http://code.opencv.org/attachments/956/cuda.png!
220 65 Vadim Pisarevsky
221 65 Vadim Pisarevsky
* GPU module:
222 65 Vadim Pisarevsky
  - reimplemented CUDA accelerated gpu::PyrLKOpticalFlow for dense and sparse cases. New implementation up 1.5 - 2 times faster then previous GPU  optimized. Updated optical flow samples
223 65 Vadim Pisarevsky
  - implemented resize with area interpolation. CUDA optimized version for integer matrix types up 30 - 35 faster then not optimized OpenCV implementation and up 7 in worst case of 3 channel floating point matrix.
224 65 Vadim Pisarevsky
225 64 Vadim Pisarevsky
h2. 2.4.1
226 63 Vadim Pisarevsky
227 45 Vadim Pisarevsky
__June, 2012__
228 46 Vadim Pisarevsky
229 45 Vadim Pisarevsky
* The GPU module now supports CUDA 4.1 and CUDA 4.2 and can be compiled with CUDA 5.0 preview.
230 45 Vadim Pisarevsky
231 67 Vadim Pisarevsky
* Added API for storing OpenCV data structures in text string and reading them back:
232 45 Vadim Pisarevsky
<pre><code class="cpp">
233 45 Vadim Pisarevsky
//==== storing data ====
234 45 Vadim Pisarevsky
FileStorage fs(".xml", FileStorage::WRITE + FileStorage::MEMORY);
235 45 Vadim Pisarevsky
fs << "date" << date_string << "mymatrix" << mymatrix;
236 45 Vadim Pisarevsky
string buf = fs.releaseAndGetString();
237 45 Vadim Pisarevsky
238 45 Vadim Pisarevsky
//==== reading it back ====
239 45 Vadim Pisarevsky
FileStorage fs(buf, FileStorage::READ + FileStorage::MEMORY);
240 45 Vadim Pisarevsky
fs["date"] >> date_string;
241 45 Vadim Pisarevsky
fs["mymatrix"] >> mymatrix;
242 45 Vadim Pisarevsky
</code></pre>
243 46 Vadim Pisarevsky
244 45 Vadim Pisarevsky
* "@cv::calcOpticalFlowPyrLK@":http://docs.opencv.org/modules/video/doc/motion_analysis_and_object_tracking.html#calcopticalflowpyrlk now supports precomputed pyramids as input.
245 45 Vadim Pisarevsky
246 45 Vadim Pisarevsky
* Function signatures in documentation are made consistent with source code.
247 45 Vadim Pisarevsky
248 45 Vadim Pisarevsky
* Restored python wrappers for SURF and MSER.
249 1
250 45 Vadim Pisarevsky
* "45 more bugs":http://code.opencv.org/projects/opencv/issues?fixed_version_id=5&set_filter=1&status_id=5 in our bug tracker have been fixed
251 45 Vadim Pisarevsky
252 42 Vadim Pisarevsky
253 63 Vadim Pisarevsky
h2. version:2.4.0
254 42 Vadim Pisarevsky
255 42 Vadim Pisarevsky
__May, 2012__
256 42 Vadim Pisarevsky
257 42 Vadim Pisarevsky
The major changes since 2.4 beta
258 42 Vadim Pisarevsky
259 67 Vadim Pisarevsky
* OpenCV now provides pretty complete build information via cv::getBuildInformation().
260 42 Vadim Pisarevsky
261 67 Vadim Pisarevsky
* reading/writing video via ffmpeg finally works and is now available on MacOS X too.
262 43 Vadim Pisarevsky
note 1: we now demand reasonably fresh versions of ffmpeg/libav with libswscale included.
263 67 Vadim Pisarevsky
note 2: if possible, try to avoid reading or writing more than one video simultaneously (even within a single thread) with ffmpeg 0.7.x or earlier, since they seem to use some global structures that are destroyed by the codecs executed synchronously. Either build and install a newer ffmpeg (0.10.x is recommended), or serialize your video i/o, or use parallel processes instead of threads.
264 42 Vadim Pisarevsky
265 42 Vadim Pisarevsky
* MOG2 background subtraction by Zoran Zivkovic was optimized using TBB.
266 42 Vadim Pisarevsky
267 67 Vadim Pisarevsky
* The reference manual has been updated to match OpenCV 2.4.0.
268 42 Vadim Pisarevsky
269 67 Vadim Pisarevsky
* More than 20 bugs have been closed in our bug tracker. (http://code.opencv.org/projects/opencv/roadmap).
270 43 Vadim Pisarevsky
271 42 Vadim Pisarevsky
* Asus Xtion is now properly supported for HighGUI. For now, you have to manually specify this device by using VideoCapture(CV_CAP_OPENNI_ASUS) instead of VideoCapture(CV_CAP_OPENNI).
272 42 Vadim Pisarevsky
273 5 Vadim Pisarevsky
274 5 Vadim Pisarevsky
h2. 2.4 beta
275 39 Vadim Pisarevsky
276 5 Vadim Pisarevsky
__April, 2012__
277 8 Vadim Pisarevsky
278 67 Vadim Pisarevsky
As usual, we created 2.4 branch in our repository (http://code.opencv.org/svn/opencv/branches/2.4), where we will further stabilize the code. You can check this branch for changes periodically, before as well as after 2.4 release.
279 5 Vadim Pisarevsky
280 5 Vadim Pisarevsky
h3. Common changes
281 36 Vadim Pisarevsky
282 67 Vadim Pisarevsky
* At the age of 12, OpenCV got its own home! http://code.opencv.org is now the primary site for OpenCV development and http://opencv.org will be the official OpenCV user site.
283 36 Vadim Pisarevsky
284 5 Vadim Pisarevsky
* Some of the old functionality from the modules @imgproc@, @video@, @calib3d@, @features2d@, @objdetect@ has been moved to legacy.
285 36 Vadim Pisarevsky
286 5 Vadim Pisarevsky
* CMake scripts have been substantially modified. Now it's very easy to add new modules - just put the directory with include, src, doc and test sub-directories to the modules directory, create a very simple @CMakeLists.txt@ and your module will be built as a part of OpenCV. Also, it's possible to exclude certain modules from build (the CMake variables "@BUILD_opencv_<modulename>@" control that).
287 5 Vadim Pisarevsky
288 5 Vadim Pisarevsky
h3. New functionality
289 21 Vadim Pisarevsky
290 67 Vadim Pisarevsky
 * A new essential class @cv::Algorithm@ has been introduced. It's planned to be the fundamental part of all of the "non-trivial" OpenCV functionality. All Algorithm-based classes have the following features:
291 21 Vadim Pisarevsky
 ** "virtual constructor", i.e. an algorithm instance can be created by name;
292 21 Vadim Pisarevsky
 ** there is a list of available algorithms;
293 21 Vadim Pisarevsky
 ** one can retrieve and set algorithm parameters by name;
294 5 Vadim Pisarevsky
 ** one can save algorithm parameters to XML/YAML file and then load them.
295 36 Vadim Pisarevsky
296 5 Vadim Pisarevsky
* A new ffmpeg wrapper has been created that features multi-threaded decoding, more robust video positioning etc. It's used with ffmpeg starting with 0.7.x versions.
297 36 Vadim Pisarevsky
298 5 Vadim Pisarevsky
* @features2d@ API has been cleaned up. There are no more numerous classes with duplicated functionality. The base classes @FeatureDetector@ and @DescriptorExtractor@ are now derivatives of @cv::Algorithm@. There is also the base @Feature2D@, using which you can detect keypoints and compute the descriptors in a single call. This is also more efficient.
299 36 Vadim Pisarevsky
300 5 Vadim Pisarevsky
* SIFT and SURF have been moved to a separate module named @nonfree@ to indicate possible legal issues of using those algorithms in user applications. Also, SIFT performance has been substantially improved (by factor of 3-4x).
301 36 Vadim Pisarevsky
302 5 Vadim Pisarevsky
* The current state-of-art textureless detection algorithm, Line-Mod by S. Hinterstoisser, has been contributed by Patrick Mihelich. See @objdetect/objdetect.hpp@, class @Detector@.
303 36 Vadim Pisarevsky
304 5 Vadim Pisarevsky
* 3 face recognition algorithms have been contributed by Philipp Wagner. Please, check @opencv/contrib/contrib.hpp@, @FaceRecognizer@ class, and @opencv/samples/cpp/facerec_demo.cpp@.
305 40 Vadim Pisarevsky
306 40 Vadim Pisarevsky
* 2 algorithms for solving PnP problem have been added. Please, check @flags@ parameter in @solvePnP@ and @solvePnPRansac@ functions.
307 36 Vadim Pisarevsky
308 5 Vadim Pisarevsky
* Enhanced @LogPolar@ implementation (that uses Blind-Spot model) has been contributed by Fabio Solari and Manuela Chessa, see @opencv/contrib/contrib.hpp@, @LogPolar_*@ classes and @opencv/samples/cpp/logpolar_bsm.cpp@ sample.
309 36 Vadim Pisarevsky
310 5 Vadim Pisarevsky
* A stub module @photo@ has been created to support a quickly growing "computational photography" area. Currently, it only contains @inpainting@ algorithm, moved from @imgproc@, but it's planned to add much more functionality.
311 36 Vadim Pisarevsky
312 5 Vadim Pisarevsky
* Another module @videostab@ (beta version) has been added that solves a specific yet very important task of video stabilization. The module is under active development. Please, check @opencv/samples/cpp/videostab.cpp@ sample. 
313 36 Vadim Pisarevsky
314 5 Vadim Pisarevsky
* @findContours@ can now find contours on a 32-bit integer image of labels (not only on a black-and-white 8-bit image). This is a step towards more convenient connected component analysis.
315 36 Vadim Pisarevsky
316 16 Vadim Pisarevsky
* @Canny@ edge detector can now be run on color images, which results in better edge maps 
317 36 Vadim Pisarevsky
318 12 Vadim Pisarevsky
* Python bindings can now be used within python threads, so one can write multi-threaded computer vision applications in Python.
319 5 Vadim Pisarevsky
320 30 Vadim Pisarevsky
h3. OpenCV on GPU
321 30 Vadim Pisarevsky
322 30 Vadim Pisarevsky
* Different Optical Flow algorithms have been added:
323 30 Vadim Pisarevsky
** Brox (contributed by NVidia)
324 34 Vadim Pisarevsky
** PyrLK - both Dense and Sparse variations
325 30 Vadim Pisarevsky
** Farneback
326 30 Vadim Pisarevsky
327 1
* New feature detectors and descriptors:
328 1
** @GoodFeaturesToTrack@
329 34 Vadim Pisarevsky
** FAST/ORB which is patent free replacement of SURF.
330 30 Vadim Pisarevsky
331 36 Vadim Pisarevsky
* Overall GPU module enhancements:
332 36 Vadim Pisarevsky
** The module now requires CUDA 4.1 or later;
333 36 Vadim Pisarevsky
** Improved similarity of results between CPU and GPU;
334 30 Vadim Pisarevsky
** Added border extrapolation support for many functions;
335 30 Vadim Pisarevsky
** Improved performance.
336 30 Vadim Pisarevsky
337 30 Vadim Pisarevsky
* @pyrUp@/@pyrDown@ implementations.
338 1
339 1
* Matrix multiplication on GPU (wrapper for the CUBLAS library). This is optional, user need to compile OpenCV with CUBLAS support.
340 30 Vadim Pisarevsky
341 30 Vadim Pisarevsky
* @OpenGL back-end@ has been implemented for @highgui@  module, that allows to display @GpuMat@ directly without downloading them to CPU.
342 39 Vadim Pisarevsky
343 35 Vadim Pisarevsky
h3. OpenCV4Android
344 39 Vadim Pisarevsky
345 1
See the [[Android Release Notes]].
346 35 Vadim Pisarevsky
347 1
h3. Performance
348 16 Vadim Pisarevsky
349 36 Vadim Pisarevsky
* A few OpenCV functions, like color conversion, morphology, data type conversions, brute-force feature matcher have been optimized using TBB and/or SSE intrinisics.
350 1
351 36 Vadim Pisarevsky
* Along with regression tests, now many OpenCV functions have got performance tests. Now for most modules one can build @opencv_perf_<modulename>@ executables that run various functions from the particular module and produce a XML file. Note that if you want to run those tests, as well as the normal regression tests, you will need to get (a rather big) http://code.opencv.org/svn/opencv/trunk/opencv_extra directory and set environment variable @OPENCV_TEST_DATA_PATH@ to "@<your_copy_of_opencv_extra>/testdata@".
352 39 Vadim Pisarevsky
353 1
h3. Bug fixes
354 1
355 67 Vadim Pisarevsky
* In this version we fixed literally hundreds of bugs. Please, check http://code.opencv.org/projects/opencv/versions/1 for a list of fixed issues.
356 39 Vadim Pisarevsky
357 1
h3. Known issues
358 1
359 1
* When OpenCV is built statically, dynamically created classes (via @Algorithm::create@) can fail because linker excludes the "unused" object files. To avoid this problem, create classes explicitly, e.g
360 36 Vadim Pisarevsky
361 8 Vadim Pisarevsky
 <pre><code class="cpp">Ptr<DescriptorExtractor> d = new BriefDescriptorExtractor;</code></pre>
362 1
363 1
h2. 2.3.1
364 39 Vadim Pisarevsky
365 1
__August, 2011__
366 39 Vadim Pisarevsky
367 23 Vadim Pisarevsky
h3. OpenCV4Android
368 1
369 1
OpenCV Java bindings for Android platform are released in ''Beta 2'' quality. A lot of work is done to make them more stable and easier to use. Currently Java API has about 700 different OpenCV functions and covers 8 OpenCV modules including full port of features2d.
370 1
371 1
h3. Other New Functionality and Features
372 36 Vadim Pisarevsky
373 1
* Retina module has been contributed by Alexandre Benoit (in @opencv_contrib@ module). See the new retina sample and https://sites.google.com/site/benoitalexandrevision/.
374 36 Vadim Pisarevsky
375 1
* Support for Ximea cameras (http://www.ximea.com/) in @highgui@ has been contributed by Ximea developers.
376 36 Vadim Pisarevsky
377 1
* Planar subdivisions construction (Delaunay triangulation and Voronoi tessellation) have been ported to C++. See the new @delaunay2.cpp@ sample.
378 36 Vadim Pisarevsky
379 1
* Several new Python samples have been added.
380 36 Vadim Pisarevsky
381 1
* @FLANN@ in OpenCV has been upgraded to v1.6. Also, added Python bindings for @FLANN@.
382 1
383 36 Vadim Pisarevsky
* We now support the latest FFMPEG (0.8.x) that features multi-threaded decoding. Reading videos in OpenCV has never been that fast.
384 1
385 1
h3. Documentation
386 1
387 36 Vadim Pisarevsky
* Quite a few new tutorials have been added. Check http://opencv.itseez.com/trunk for the up-to-date documentation.
388 1
389 1
h3. Optimization
390 1
391 1
* Performance of the sparse Lucas-Kanade optical flow has been greatly improved. On 4-core machine it is now 9x faster than the previous version.
392 1
393 1
h3. Bug Fixes
394 36 Vadim Pisarevsky
395 1
* Over 100 issues have been resolved since 2.3 release. Most of the issues (closed and still open) are listed at http://code.opencv.org/projects/opencv/issues?set_filter=1.
396 44 Vadim Pisarevsky
397 44 Vadim Pisarevsky
h3. Known issues
398 44 Vadim Pisarevsky
399 44 Vadim Pisarevsky
* TBB debug binaries are missed in the Windows installer. Here is a workaround:
400 44 Vadim Pisarevsky
** Download @tbb30_20110427oss_win.zip@ from the "TBB website":http://threadingbuildingblocks.org/ver.php?fid=171.
401 44 Vadim Pisarevsky
** Unzip and copy the @tbb*_debug.dll@ files from _bin/<ARCH>/<COMPILER>_ to the corresponding folder in the installed OpenCV location in _<OPENCVCV_ROOT>/build/common/tbb/<ARCH>/<COMPILER>_
402 1
403 1
h2. 2.3
404 39 Vadim Pisarevsky
405 1
__July, 2011__
406 1
407 1
h3. Modifications and Improvements since 2.3rc
408 36 Vadim Pisarevsky
409 1
* A few more bugs reported in the OpenCV bug tracker have been fixed.
410 36 Vadim Pisarevsky
411 67 Vadim Pisarevsky
* Documentation has been improved a lot! The new reference manual combines information for C++ and C interfaces, the OpenCV 1.x-style Python bindings and the new C++-style Python bindings. It has also been thoroughly checked for grammar, style and integrity.
412 1
413 36 Vadim Pisarevsky
  Besides, there are new and updated tutorials.
414 1
415 36 Vadim Pisarevsky
  The up-to-date online documentation is available at http://opencv.itseez.com.
416 1
417 36 Vadim Pisarevsky
* The new binary package includes various pre-compiled libs:
418 36 Vadim Pisarevsky
   https://sourceforge.net/projects/opencvlibrary/files/opencv-win/2.3/
419 1
420 36 Vadim Pisarevsky
   Unfortunately, it's not a full-scale installation package, but simply a self-extracting archive with a @readme.txt@ supplied.
421 4 Vadim Pisarevsky
   The installation package is probably to come in the next version.
422 36 Vadim Pisarevsky
423 1
* VS2005 should build OpenCV 2.3 out of the box, including @DirectShow@ support.
424 36 Vadim Pisarevsky
425 1
* ffmpeg bindings are now available for all Windows users via compiler- and configuration- and
426 1
    version-independent @opencv_ffmpeg.dll@ (for 32-bit compilers) and @opencv_ffmpeg_64.dll@ (for 64-bit compilers).
427 1
428 98 Vadim Pisarevsky
h2. 2.3 beta
429 39 Vadim Pisarevsky
430 1
__June, 2011__
431 1
432 1
h3. General Modifications and Improvements
433 36 Vadim Pisarevsky
434 67 Vadim Pisarevsky
* Buildbot-based Continuous Integration system is now continuously testing OpenCV snapshots. The current status is available at http://buildbot.itseez.com
435 36 Vadim Pisarevsky
436 67 Vadim Pisarevsky
* OpenCV switched to Google Test (http://code.google.com/p/googletest/) engine for regression and correctness tests. Each module now has "test" sub-directory which includes the corresponding tests.
437 36 Vadim Pisarevsky
438 1
439 1
h3. New Functionality, Features
440 36 Vadim Pisarevsky
441 1
* Many functions and methods now take @InputArray@/@OutputArray@ instead of @cv::Mat@ references. It retains compatibility with the existing code and yet brings more natural support for STL vectors and potentially other "foreign" data structures to OpenCV. See http://opencv.itseez.com/modules/core/doc/intro.html#inputarray-and-outputarray for details.
442 36 Vadim Pisarevsky
443 36 Vadim Pisarevsky
* @core@
444 67 Vadim Pisarevsky
** @LAPACK@ is not used by OpenCV anymore. The change decreased the library footprint and the compile time. We now use our own implementation of Jacobi SVD. SVD performance on small matrices (2x2 to 10x10) has been considerably improved; on larger matrices it is still pretty good. SVD accuracy on poorly-conditioned matrices has also been polished.
445 1
** Arithmetic operations now support mixed-type operands and arbitrary number of channels.
446 36 Vadim Pisarevsky
447 36 Vadim Pisarevsky
* @features2d@
448 36 Vadim Pisarevsky
** Completely new patent-free @BRIEF@ and @ORB@ feature descriptors have been added.
449 1
** Very fast LSH matcher for @BRIEF@ and @ORB@ descriptors will be added in 2.3.1.
450 36 Vadim Pisarevsky
451 36 Vadim Pisarevsky
* @calib3d@
452 24 Vadim Pisarevsky
** A new calibration pattern, "circles grid":http://code.opencv.org/svn/opencv/branches/2.3/opencv/doc/acircles_pattern.png, has been added. See findCirclesGrid() function and the updated calibration.cpp sample. With the new pattern calibration accuracy is usually much higher.
453 36 Vadim Pisarevsky
454 36 Vadim Pisarevsky
* @highgui@
455 1
** [Windows] @videoInput@ is now a part of @highgui@. If there are any problems with compiling @highgui@, set @WITH_VIDEOINPUT=OFF@ in CMake.
456 36 Vadim Pisarevsky
457 36 Vadim Pisarevsky
* @stitching@
458 1
** @opencv_stitching@ is a beta version of new application that makes a panorama out of a set of photos taken from the same point.
459 36 Vadim Pisarevsky
460 36 Vadim Pisarevsky
* @python@
461 1
** Now there are 2 extension modules: @cv@ and @cv2@. @cv2@ includes wrappers for OpenCV 2.x functionality. @opencv/samples/python2@ contain a few samples demonstrating @cv2@ in use.
462 36 Vadim Pisarevsky
463 38 Vadim Pisarevsky
* @contrib@
464 1
** A new experimental variational stereo correspondence algorithm @StereoVar@ has been added.
465 36 Vadim Pisarevsky
466 36 Vadim Pisarevsky
* @gpu@
467 1
** the module now requires CUDA 4.0 or later; Many improvements and bug fixes have been made.
468 36 Vadim Pisarevsky
469 1
h3. Android port
470 38 Vadim Pisarevsky
471 38 Vadim Pisarevsky
* With support from NVIDIA, OpenCV Android port (which is actually not a separate branch of OpenCV, it's the same code tree with additional build scripts) has been greatly improved, a few demos developed. Camera support has been added as well.
472 1
  See [[Android Release Notes#231-beta1]] for details.
473 36 Vadim Pisarevsky
474 1
h3. Documentation
475 36 Vadim Pisarevsky
476 1
* OpenCV documentation is now written in @ReStructured Text@ and built using @Sphinx@ (http://sphinx.pocoo.org).
477 36 Vadim Pisarevsky
478 1
* It's not a single reference manual now, it's 4 reference manuals (OpenCV 2.x C++ API, OpenCV 2.x Python API, OpenCV 1.x C API, OpenCV 1.x Python API), the emerging user guide and a set of tutorials for beginners.
479 36 Vadim Pisarevsky
480 1
* Style and grammar of the main reference manual (OpenCV 2.x C++ API) have been thoroughly checked and fixed.
481 36 Vadim Pisarevsky
482 1
* Online up-to-date version of the manual is available at http://opencv.itseez.com
483 1
484 1
485 1
h3. Samples
486 36 Vadim Pisarevsky
487 1
* Several samples using the new Python bindings (cv2 module) have been added: http://code.opencv.org/svn/opencv/branches/2.3/opencv/samples/python2
488 1
489 1
490 1
h3. Optimization
491 1
492 36 Vadim Pisarevsky
* Several ML algorithms have been threaded using TBB.
493 1
494 1
h3. Bug Fixes
495 1
496 36 Vadim Pisarevsky
* Over 250 issues have been resolved. Most of the issues (closed and still open) are listed at http://code.opencv.org/projects/opencv/issues?set_filter=1.
497 1
498 1
h3. Known Problems/Limitations
499 36 Vadim Pisarevsky
500 1
* Documentation (especially on the new Python bindings) is still being updated. Watch http://opencv.itseez.com for updates.
501 36 Vadim Pisarevsky
502 2 Vadim Pisarevsky
* Android port does not provide Java interface for OpenCV. It is going to be added to "2.3 branch":http://code.opencv.org/svn/opencv/branches/2.3/opencv in a few weeks.
503 1
504 1
505 1
h2. 2.2
506 39 Vadim Pisarevsky
507 1
__December, 2010__
508 1
509 1
h3. General Modifications and Improvements
510 37 Vadim Pisarevsky
511 37 Vadim Pisarevsky
* The library has been reorganized. Instead of @cxcore@, @cv@, @cvaux@, @highgui@ and @ml@ we now have several smaller modules:
512 37 Vadim Pisarevsky
** @opencv_core@ - core functionality (basic structures, arithmetics and linear algebra, dft, XML and YAML I/O ...).
513 37 Vadim Pisarevsky
** @opencv_imgproc@ - image processing (@filter@, @GaussianBlur@, @erode@, @dilate@, @resize@, @remap@, @cvtColor@, @calcHist@ etc.)
514 37 Vadim Pisarevsky
** @opencv_highgui@ - GUI and image & video I/O
515 37 Vadim Pisarevsky
** @opencv_ml@ - statistical machine learning models (SVM, Decision Trees, Boosting etc.)
516 37 Vadim Pisarevsky
** @opencv_features2d@ - 2D feature detectors and descriptors (SURF, FAST etc., including the new feature detectors-descriptor-matcher framework)
517 37 Vadim Pisarevsky
** @opencv_video@ - motion analysis and object tracking (optical flow, motion templates, background subtraction)
518 37 Vadim Pisarevsky
** @opencv_objdetect@ - object detection in images (Haar & LBP face detectors, HOG people detector etc.)
519 37 Vadim Pisarevsky
** @opencv_calib3d@ - camera calibration, stereo correspondence and elements of 3D data processing
520 37 Vadim Pisarevsky
** @opencv_flann@ - the Fast Library for Approximate Nearest Neighbors (@FLANN@ 1.5) and the OpenCV wrappers
521 37 Vadim Pisarevsky
** @opencv_contrib@ - contributed code that is not mature enough
522 37 Vadim Pisarevsky
** @opencv_legacy@ - obsolete code, preserved for backward compatibility
523 1
** @opencv_gpu@ - acceleration of some OpenCV functionality using @CUDA@ (relatively unstable, yet very actively developed part of OpenCV)
524 1
525 1
If you detected OpenCV and configured your make scripts using CMake or pkg-config tool, your code will likely build fine without any changes. Otherwise, you will need to modify linker parameters (change the library names) and update the include paths.
526 37 Vadim Pisarevsky
527 1
It is still possible to use @#include <cv.h>@ etc. but the recommended notation is:
528 37 Vadim Pisarevsky
529 37 Vadim Pisarevsky
<pre><code class="cpp">
530 37 Vadim Pisarevsky
#include "opencv2/imgproc/imgproc.hpp"
531 37 Vadim Pisarevsky
...
532 1
</code></pre>
533 1
534 1
Please, check the new C and C++ samples (http://code.opencv.org/svn/opencv/trunk/opencv/samples), which now include the new-style headers.
535 37 Vadim Pisarevsky
536 67 Vadim Pisarevsky
* The new-style wrappers now cover much more of OpenCV 2.x API. The documentation and samples are to be added later. You will need numpy in order to use the extra functionality.
537 28 Vadim Pisarevsky
   SWIG-based Python wrappers are not included anymore.
538 37 Vadim Pisarevsky
539 28 Vadim Pisarevsky
* OpenCV can now be built for Android (GSoC 2010 project), thanks to Ethan Rublee; and there are some samples too. Please, check [[OpenCV4Android]]
540 37 Vadim Pisarevsky
541 1
* The completely new @opencv_gpu@ acceleration module has been created with support by NVIDIA. See below for details.
542 1
543 28 Vadim Pisarevsky
544 28 Vadim Pisarevsky
h3. New Functionality, Features
545 37 Vadim Pisarevsky
546 37 Vadim Pisarevsky
* @core@
547 37 Vadim Pisarevsky
** The new @cv::Matx<T, m, n>@ type for fixed-type fixed-size matrices has been added. @Vec<T, n>@ is now derived from @Matx<T, n, 1>@. The class can be used for very small matrices, where @cv::Mat@ use implies too much overhead. The operators to convert @Matx@ to @Mat@ and backwards are available.
548 37 Vadim Pisarevsky
** @cv::Mat@ and @cv::MatND@ are made the same type: @typedef cv::Mat cv::MatND@.
549 37 Vadim Pisarevsky
    Note that many functions do not check the matrix dimensionality yet, so be careful when processing 3-, 4- ... dimensional matrices using OpenCV.
550 37 Vadim Pisarevsky
** Experimental support for Eigen 2.x/3.x is added (@WITH_EIGEN2@ option in CMake). Again, there are convertors from Eigen2 matrices to @cv::Mat@ and backwards. See @modules/core/include/opencv2/core/eigen.hpp@.
551 37 Vadim Pisarevsky
** @cv::Mat@ can now be print with "@<<@" operator. See @opencv/samples/cpp/cout_mat.cpp@.
552 1
** @cv::exp@ and @cv::log@ are now much faster thanks to SSE2 optimization.
553 37 Vadim Pisarevsky
554 37 Vadim Pisarevsky
* @imgproc@
555 37 Vadim Pisarevsky
** color conversion functions have been rewritten;
556 37 Vadim Pisarevsky
** RGB->Lab & RGB->Luv performance has been noticeably improved. Now the functions assume sRGB input color space (e.g. gamma=2.2). If you want the original linear RGB->L** conversion (i.e. with gamma=1), use @CV_LBGR2LAB@ etc.
557 37 Vadim Pisarevsky
** VNG algorithm for Bayer->RGB conversion has been added. It's much slower than the simple interpolation algorithm, but returns significantly more detailed images
558 37 Vadim Pisarevsky
** The new flavors of RGB->HSV/HLS conversion functions have been added for 8-bit images. They use the whole 0..255 range for the H channel instead of 0..179. The conversion codes are @CV_RGB2HSV_FULL@ etc.
559 1
** special variant of @initUndistortRectifyMap@ for wide-angle cameras has been added: @initWideAngleProjMap()@
560 37 Vadim Pisarevsky
561 37 Vadim Pisarevsky
* @features2d@
562 1
** the unified framework for keypoint extraction, computing the descriptors and matching them has been introduced. The previously available and some new detectors and descriptors, like @SURF@, @FAST@, @StarDetector@ etc. have been wrapped to be used through the framework. The key advantage of the new framework (besides the uniform API for different detectors and descriptors) is that it also provides high-level tools for image matching and textured object detection. Please, see documentation http://opencv.itseez.com/modules/features2d/doc/common_interfaces_of_feature_detectors.html
563 37 Vadim Pisarevsky
      and the C++ samples:
564 37 Vadim Pisarevsky
*** @descriptor_extractor_matcher.cpp@ - finding object in a scene using keypoints and their descriptors.
565 37 Vadim Pisarevsky
*** @generic_descriptor_matcher.cpp@ - variation of the above sample where the descriptors do not have to be computed explicitly.
566 37 Vadim Pisarevsky
*** @bagofwords_classification.cpp@ - example of extending the framework and using it to process data from the VOC databases: http://pascallin.ecs.soton.ac.uk/challenges/VOC/
567 1
** the newest super-fast keypoint descriptor BRIEF by Michael Calonder has been integrated by Ethan Rublee. See the sample @opencv/samples/cpp/video_homography.cpp@
568 37 Vadim Pisarevsky
** SURF keypoint detector has been parallelized using TBB (the patch is by imahon and yvo2m)
569 37 Vadim Pisarevsky
570 1
* @objdetect@
571 1
** LatentSVM object detector, implementing P. Felzenszwalb algorithm, has been contributed by Nizhniy Novgorod State University (NNSU) team. See @opencv/samples/c/latentsvmdetect.cpp@
572 37 Vadim Pisarevsky
573 37 Vadim Pisarevsky
* @calib3d@
574 1
** The new rational distortion model:
575 100 Vadim Pisarevsky
  
576 37 Vadim Pisarevsky
    @x' = x * (1@ + @k@~1~ * @r@^2^ + @k@~2~ * @r@^4^ + @k@~3~ * @r@^6^@)/(1@ + @k@~4~ * @r@^2^ + @k@~5~ * @r@^4^ + @k@~6~ * @r@^6^@) +@ _<tangential_distortion for @x@>_,
577 1
    @y' = y * (1@ + @k@~1~ * @r@^2^ + @k@~2~ * @r@^4^ + @k@~3~ * @r@^6^@)/(1@ + @k@~4~ * @r@^2^ + @k@~5~ * @r@^4^ + @k@~6~ * @r@^6^@) +@ _<tangential_distortion for @y@>_
578 37 Vadim Pisarevsky
579 37 Vadim Pisarevsky
    has been introduced. It is useful for calibration of cameras with wide-angle lenses. 
580 37 Vadim Pisarevsky
    Because of the increased number of parameters to optimize you need to supply more data to robustly estimate all of them. Or, simply initialize the distortion vectors with zeros and pass @CV_CALIB_RATIONAL_MODEL@ to enable the new model @CV_CALIB_FIX_K3 + CV_CALIB_FIX_K4 + CV_CALIB_FIX_K5@ or other such combinations to selectively enable or disable certain coefficients.
581 1
** rectification of trinocular camera setup, where all 3 heads are on the same line, is added. see @samples/cpp/3calibration.cpp@
582 37 Vadim Pisarevsky
583 37 Vadim Pisarevsky
* @ml@
584 1
** Gradient boosting trees model has been contributed by NNSU team.
585 37 Vadim Pisarevsky
586 37 Vadim Pisarevsky
* @highgui@
587 37 Vadim Pisarevsky
** Experimental Qt backend for OpenCV has been added as a result of GSoC 2010 project, completed by Yannick Verdie. The backend has a few extra features, not present in the other backends, like text rendering using TTF fonts, separate "control panel" with sliders, push-buttons, checkboxes and radio buttons, interactive zooming, panning of the images displayed in @highgui@ windows, "save as" etc. Please, check the youtube videos where Yannick demonstrates the new features: http://www.youtube.com/user/MrFrenchCookie#p/u
588 37 Vadim Pisarevsky
** The new API is described here: http://opencv.itseez.com/modules/highgui/doc/qt_new_functions.html To make use of the new API, you need to have Qt SDK (or @libqt4@ with development packages) installed on your machine, and build OpenCV with Qt support (pass @-DWITH_QT=ON@ to CMake; watch the output, make sure Qt is used as GUI backend)
589 37 Vadim Pisarevsky
** 16-bit and LZW-compressed TIFFs are now supported.
590 1
** You can now set the mode for IEEE1394 cameras on Linux.
591 37 Vadim Pisarevsky
592 37 Vadim Pisarevsky
* @contrib@
593 1
** Chamfer matching algorithm has been contributed by Marius Muja, Antonella Cascitelli, Marco Di Stefano and Stefano Fabri. See @samples/cpp/chamfer.cpp@
594 37 Vadim Pisarevsky
595 37 Vadim Pisarevsky
* @gpu@
596 1
    This is completely new part of OpenCV, created with the support by NVIDIA.
597 1
    Note that the package is at alpha, probably early beta state, so use it with care and check OpenCV SVN for updates.
598 1
599 1
    In order to use it, you need to have the latest NVidia CUDA SDK installed, and build OpenCV with CUDA support (@-DWITH_CUDA=ON@ CMake flag).
600 37 Vadim Pisarevsky
601 37 Vadim Pisarevsky
    All the functionality is put to @cv::gpu@ namespace. The full list of functions and classes can be found at
602 37 Vadim Pisarevsky
    @opencv/modules/gpu/include/opencv2/gpu/gpu.hpp@, and here are some major components of the API:
603 37 Vadim Pisarevsky
** image arithmetics, filtering operations, morphology, geometrical transformations, histograms
604 37 Vadim Pisarevsky
** 3 stereo correspondence algorithms: Block Matching, Belief Propagation and Constant-Space Belief Propagation.
605 37 Vadim Pisarevsky
** HOG-based object detector. It runs more than order of magnitude faster than the CPU version!
606 10 Vadim Pisarevsky
    See @opencv/samples/gpu@
607 37 Vadim Pisarevsky
608 37 Vadim Pisarevsky
* @python@ bindings
609 28 Vadim Pisarevsky
  A lot more of OpenCV 2.x functionality is now covered by Python bindings.
610 37 Vadim Pisarevsky
611 37 Vadim Pisarevsky
  These new wrappers require @numpy@ to be installed
612 1
  (see http://opencv.willowgarage.com/wiki/InstallGuide for details).
613 37 Vadim Pisarevsky
614 37 Vadim Pisarevsky
  Likewise the C++ API, in the new Python bindings you do not need to allocate output arrays.
615 1
  They will be automatically created by the functions.
616 37 Vadim Pisarevsky
617 1
  Here is a micro example:
618 37 Vadim Pisarevsky
619 37 Vadim Pisarevsky
  <pre><code class="python">
620 1
  import cv
621 37 Vadim Pisarevsky
622 37 Vadim Pisarevsky
  a=cv.imread("lena.jpg",0)
623 37 Vadim Pisarevsky
  b=cv.canny(a, 50, 100, apertureSize=3)
624 37 Vadim Pisarevsky
  cv.imshow("test",b)
625 1
  cv.waitKey(0)</code></pre>
626 37 Vadim Pisarevsky
627 1
  In the sample @a@ and @b@ are normal @numpy@ arrays, so the whole power of @numpy@ and @scipy@ can now be combined with OpenCV functionality.
628 1
629 1
h3. Documentation, Samples
630 37 Vadim Pisarevsky
631 68 Vadim Pisarevsky
* Links to wiki pages have been added to each function description, see http://opencv.willowgarage.com
632 37 Vadim Pisarevsky
633 68 Vadim Pisarevsky
* All the samples have been documented with default output ''(0 or incomplete number of parameters)'' set to print out "howto" run instructions; most samples have been converted to C++ to use the new OpenCV API.
634 1
635 1
h3. Bug Fixes
636 37 Vadim Pisarevsky
637 1
* Over 300 issues have been resolved. Most of the issues (closed and still open) are listed at http://code.opencv.org/projects/opencv/issues?set_filter=1
638 37 Vadim Pisarevsky
639 1
* The old bug tracker at https://sourceforge.net/projects/opencvlibrary/ is now closed for updates. As soon as all the still relevant bug reports will be moved to code.ros.org, the old bug tracker will be completely deleted. Please, use the new tracker from now on.
640 1
641 1
h3. Known Problems/Limitations
642 37 Vadim Pisarevsky
643 47 Vadim Pisarevsky
* Installation package for Windows is still 32-bit only and does not include TBB support. You can build parallel or 64-bit version of OpenCV from the source code.
644 49 Vadim Pisarevsky
645 47 Vadim Pisarevsky
h2. Previous versions
646 47 Vadim Pisarevsky
647 81 Vadim Pisarevsky
[[ChangeLog_v10-v21|ChangeLog v1.0 - v2.1]]