- Sponsor
-
Notifications
You must be signed in to change notification settings - Fork 56.2k
OpenCV Change Logs
Alexander Smorkalov edited this page Jan 24, 2025
·
32 revisions
Previous Change Logs:
January, 2025
New Year update for OpenCV 4.x has been released.
-
Generic:
-
Core Module:
- Added int64 data type support for FileStorage #26434
- Fixed invalid attribute value handling in FileStorage #25955.
- Extended LUT for FP16 support #25787.
- Fixed stdDev tail filling with zeros with HAL in meanStdDev #25789.
- Set and check allocator pointer for all cv::Mat instances #25979
- Improved accuracy of Rect::contains #26022
- Fixed result offset in minMaxIdx with HAL in some cases #26080
- Replaced C++ operators with wrapper functions on universal intrinsics backends #26109
- Extended cv::TickMeter #26212
- Rewrote OpenCL-OpenGL-interop device discovery routine without extensions and with Apple support #26281
- Marked cv::Mat(Mat&&) as noexcept #25899
- Multiple Eigen library interop improvements #25751.
-
Calib3d module:
- Multiple chessboard detector improvements #25427, #25807, #25991, #26014
- Enabled checkerboard detection with a central / corner marker on a black tile #25808
- Fixed Rodrigues CV_32F and CV_64F type mismatch in projectPoints #25824
- Added fisheye::distort with non-identity projection matrix #25943
- SQPnP solver updates #26219
- Fixed vector access in USAC #26530
-
Imgproc Module:
- Added a new function that approximates the polygon bounding a convex hull with a certain number of sides #25607
- Added Weighted Hough Transform #21407
- Fixed bug in contours approximation #25672
- Fixed bug in divSpectrums #25738
- Fixed result buffer overflow in intersectConvexConvex_ for non-convex input #25725.
- Added flag to GaussianBlur for faster but not bit-exact implementation #25792
- Added flag to cvtColor for faster but not bit-exact implementation #25932
- Fixed fillPoly drawing over boundaries #26187
-
DNN Module:
- [GSoC] Blockwise quantization support #25644
- Faster implementation of blobFromImages for cpu nchw output #26127
- DNN optimization with RISC-V RVV #25883.
- Added DepthToSpace and SpaceToDepth #25779
- Yolo v10 support and related samples #25794
- Parallel implementation of nary elementwise operations #25630
- Support for Unflatten operation required by Attention layer #25861
- Erf and GELU layers optimization #25147
- Activations optimization with v_exp #25881
- Fixed compilation errors with different OpenVINO versions #25987
- Fixed matmul crash with CuDNN #26029
- Fixed CuDNN runtime version check for CuDNN 9+ #25841.
- Added ONNX TopK #23279
- Fixed buffer allocation in einsum (fixed random crash on 32-bit platforms) #26059
- Added Leaky RELU support for TFLite #26132.
- Switched to run-time dispatcher for Winograd #26155
-
Objdetect module:
-
Highgui module:
-
Imgcodecs module:
- [GSoC] New API for Animations with WEBP, AVIF and Animated PNG support #25608, #25715.
- [GSoC] Add GIF decode and encode for imgcodecs #25691
- Added experimental JPEG XL (jxl) codec support #26379
- Initial RGB layout support in imread and imdecode #25809
- Fixed imread output type for some cases #25703
- Fixed file descriptor leak in HDR decoder #25838
- Fixed corrupted JPEG decoding #25864
- Improved error handling in image codecs #25975
- Fixed Bayer2Gray SIMD for U8 #25968
- Avoid uninitialized value read in AVIF #26084
- Implemented imencodemulti() #26211
- Fixed compatibility with different OpenEXR versions #26478.
-
VideoIO module:
- Added VideoCapture constructor for in-memory data stream #25584
- Fixed bugs in native video encoding on Android #25716.
- Added BGRA streams support in GStreamer back-end #25602.
- Updated materials for Orbbec cameras support #25813, #25845, 25907
- Fixed cv::VideoWriter with FFmpeg timestamps encapsulation #25874
- Fixed memory leak in Dshow back-end #26045
- Fixed V4L NV12 color conversion #26081
- Android native camera feature enhancements #26627
- AndroidMediaNdkCapture pixel format enhancement #26656
- Fixed VideoCapture fails to read single image with digits in name #26637
- Fixed writer setProperty with FFmpeg plugin #26652
-
Video module:
- Fixed VitTrack in the case where crop size grows until out-of-memory when the input is black #25771
-
Features2d:
- Fixed out of bounds access in SIFT #26148
-
G-API module:
-
Optimizations:
- New FastCV-based HAL for Qualcomm SoCs (
-DWITH_FASTCV=ON
CMake option) #26556, #26617, 26619, 26621. - Added own vectorized version of v_exp #24941, v_log #25781, v_erf #25872, v_sin and v_cos #25892.
- KleidiCV HAL for ARM updated to KleidiCV 0.3 #26623 and it is turned on by default for Android builds. The supported operations and parameters are documentedhere.
- Initial version of HAL for RISC-V RVV 1.0 and RISC-V RVV 0.7.1 extensions #26216, #26624, 26675.
- Used LMUL=2 in the RISC-V Vector (RVV) backend of Universal Intrinsic. #26318
- More functions in NDSRVP HAL for RISC-V P extension #25786, #26088, #26364.
- Updated built-in IPP to version 2021.12. Fixed build issues with old and new Intel IPP layouts #25773
- New FastCV-based HAL for Qualcomm SoCs (
-
Platforms:
- HWAsan support on Android #25746
- Several CUDA fixes for old GPUs without FP16 support #25880
- Added getStdAllocator() to cv::cuda::GpuMat #25978
- Updated NPP calls to use the new NppStreamContext API if available #26245
- More convenient GpuMatND constructor #26472
- Added run-time GPU check to haveCUDA #26164.
- Add support for QNX #25832
-
OpenCV.js
- Extended API white-list and added more tests #26387
- Split white-list per module. Added opportunity to cover opencv_contrib modules #25986
- Fix incorrect string format in js build script #26374
- Emscripten build fixes with SIMD intrinsics #26537
- Added more public types for USAC support #26638
- Rename Mat::clone binding because it is used in Emscripten #26643
- Fixed C preprocessor stringification #26644
- Fix enum generation issues #26147
- Multiple test improvements #25732, #25757, #25961
contributors
git shortlog --no-merges -ns 4.10.0..4.11.0
57 Alexander Smorkalov
34 Maksim Shabunin
25 Vincent Rabaud
16 Rostislav Vasilikhin
15 Suleyman TURKMEN
13 Kumataro
12 Letu Ren
10 Yuantao Feng
9 Maxim Smolskiy
8 Dmitry Kurtaev
8 Alexander Lyulkov
7 Liutong HAN
7 kallaballa
5 Alexander Alekhin
5 Wanli
4 FantasqueX
4 cudawarped
3 Abduragim Shtanchaev
3 Rüdiger Ihle
2 Amir Hassan
2 Hao Chen
2 Junyan721113
2 KangJialiang
2 Manolis Lourakis
2 Maxim Milashchenko
2 Pierre Chatelier
2 chacha21
2 eplankin
2 ericmariasis
2 richard28039
2 zihaomu
1 Alberto Zurini
1 Alessandro de Oliveira Faria (A.K.A.CABELO)
1 Alexander Panov
1 Aliaksei Urbanski
1 Andy-SAKN
1 Arvind Iyer
1 Aven
1 Billy Robert O'Neal III
1 CSBVision
1 Christine Poerschke
1 Corentin Noël
1 Dan Mašek
1 Daniele Affinita
1 Dietmar Schabus
1 Dmitry Yurov
1 HAN Liutong
1 Hardik Kamboj
1 Ivan Afanasyev
1 James Choi
1 Javier Macias Sola
1 Karsten Wiese
1 Kimberly N. McGuire
1 Masahiro Ogawa
1 Miguel Daipré
1 Mikhail Khachayants
1 Mironov Arseny
1 MurtazaSaherwala
1 Neko Asakura
1 Nishanth
1 Octopus136
1 Onur Can KARAMAN
1 Oちゃん
1 Patrick Keane
1 Philip Lamb
1 Richard Barnes
1 Robert Lexmann
1 Robert Mitchell
1 Scott
1 Septimiu Neaga
1 ShengYu
1 Simon Kämpe
1 Skreg
1 Sourav Kumar
1 Super
1 TFiFiE
1 Thirumalai Nagalingam
1 Ujjayant Kadian
1 Vadim Levin
1 WU Jia
1 WangWeiLin-MV
1 Yang Chao
1 Yannis Guyon
1 Yoshiki Obinata
1 Zach Lowry
1 _Ayaka
1 adsha-quic
1 alex-urm
1 anandkaranubc
1 cDc
1 catree
1 fengyuentau
1 gblikas
1 george
1 inayd
1 j3knk
1 kaingwade
1 kozinove
1 lamiayous
1 llh721113
1 pasbi
1 penghuiho
1 quantizs
1 quic-apreetam
1 quic-xuezha
1 shengyu
1 shyama7004
1 stepkamipt
1 tingboliao
1 xkszltl
1 xndcn
1 武士风度的牛
December, 2024
The alpha release for the new OpenCV generation. The release is designed as technology preview and not ready for production usage yet.
The following notation is used to mark various items below:
- 5+4.x: the feature is not quite new, it's already put into the latest 4.x, but it's important enough to mention it here as well.
- 5.0: the item will be finished in 5.0 release; currently it's planned or in progress.
- 5.x: the item will be put in some form into 5.0 release, but will mostly be finished in subsequent 5.x releases.
- 5+4.x: Recent OpenCV 4.x (since OpenCV 4.5.0) and also OpenCV 5.0 are now distributed under Apache 2 license. We used BSD license before, but switched to Apache 2, because the latter is more refined and provides somewhat better protection (not ideal though) from patent-related issues.
- OpenCV now requires C++ 17 as a minimum C++ standard. It is built by default with C++ 17, but we also plan to make it compatible with C++ 20 and C++ 23.
- Python 2 support is removed. OpenCV now requires Python 3 (3.6+) and we only build Python 3 bindings.
- C API has been removed. We still use some
CV_
macros, such asCV_8U
, but all C functions (likecvCreateMat()
orcvFindContours()
) and structures (such asCvMat
) have been removed. Goodbye, good old OpenCV 1.x API, RIP :) - OpenVX support has been removed. If some vendors provide OpenVX kernels and want to use them for OpenCV acceleration, they can create a custom “non-CPU” HAL for that, see below.
-
Graph API
(G-API
) module has been moved toopencv_contrib
. - Classic
ML
module has been moved toopencv_contrib
. If you use Python, scikit-learn is a much better alternative. -
Features2D
module has been renamed toFeatures
. Scope of the renamed module has been extended to process feature vectors produced by the modern deep nets. Several obsolete feature detectors/descriptors have been moved to opencv_contrib.SIFT
,ORB
,FAST
,GoodFeaturesToTrack
,MSER
are still available, though. - 5.0:
FLANN
as a separate module will be gone. Annoy-based ANN (approximate nearest neighbor) search algorithm, which has been already added toFeatures
module, will replace it. - Cleaned
objdetect
module: Haar-based and HOG-based detectors have been moved toopencv_contrib
,xobjdetect
module. There are modern deep learning-based object/face detectors that are both faster and more accurate. -
Calib3d
module has been split into 3 modules:-
3d
— basic 3D geometry and 3D vision functionality -
calib
— camera calibration -
stereo
— algorithms for depth map estimation via stereo correspondence.
-
- Many obsolete samples (~50% of C++ samples and 5% of Python samples) have been removed. Many of the remaining samples have been revised.
- OpenCV now supports the extended set of data types:
-
uint8_t: CV_8U
,int8_t: CV_8S
,uint16_t: CV_16U
,int16_t: CV_16S
,int32_t: CV_32S
,float: CV_32F
,double: CV_64F
,hfloat
(a.k.a.half
orfloat16_t
or__fp16
):CV_16F
. - (new in OpenCV 5):
bfloat
(a.k.a.bfloat16_t
):CV_16BF
,uint32_t: CV_32U
,uint64_t: CV_64U
,int64_t: CV_64S
,bool: CV_Bool
. -
bool
type takes 1 byte per value, not 1 bit. Any non-zero byte is consideredtrue
, zero byte meansfalse
.cv::Mat
of typebool (CV_Bool)
can now be used as a mask for all functions where we usedcv::Mat
ofuchar/uint8_t
orschar/int8_t
before. - Operations on
hfloat
andbfloat
are always available, even on hardware that does not support those types natively. If necessary, internally we use efficient inline functions for scalar and vectorfloat<=>hfloat/bfloat
conversion. Support for the new types has been added tocv::Mat
,cv::UMat
,InputArray/OutputArray
, key modules (core, dnn, (5.x) imgproc etc.),FileStorage
, various programming language bindings etc.
-
- OpenCV now supports arrays of lower than 2 dimensionality, i.e. 1D (vectors) and 0D (scalars).
std::vector<T>
wrapped intoMat
orInputArray/OutputArray
is now a real 1D array, not 2D Nx1 or 1xN array (as in OpenCV 4.x). For 1D arraysMat::dims == Mat::rows == 1
,Mat::cols == Mat::total() == <number_of_elements>
. For 0D arraysMat::dims == 0
,Mat::rows == Mat::cols == Mat::total() == 1
. The safe method to distinguish between an empty matrix and a scalar is to use<some_mat>.empty()
, which is basically equivalent to (but is slightly faster than)<some_mat>.total() == 0
. - Lapack is now always available within OpenCV. In particular, it’s used for more efficient SVD and eigenvalue/eigenvector decomposition and the USAC framework. When there is no external Lapack library installed in the system, OpenCV builds and uses the internal small subset of Lapack.
- 5.0, 5.x: Further refactoring and improvements are expected before and after 5.0 release: https://github.com/opencv/opencv/issues/25011.
- Accelerated image warping functions: warpAffine, warpPerspective, remap. Acceleration factor varies from 10% to more than 300%, depending on the platform, image size, type and operation flags. More optimizations for those functions, as well as other important image processing functions are expected in 5.0 gold.
- Text rendering now uses STB-based truetype engine and the embedded variable truetype font. Users can also load and use custom fonts. Consequently, many Unicode symbols are now supported, with a few caveats though:
- some scripts, such as Arabic or Devanagari, are not rendered properly, we need to add Harfbuzz for that
- some compound Unicode symbols are not rendered properly for the same reason
- color emoji are not supported, as STB is a simple black-n-white engine.
- 5.0, 5.x: Further refactoring and improvements are expected before and after 5.0 release: https://github.com/opencv/opencv/issues/25012
- 5+4.x: Many new entries have been added to OpenCV HAL, allowing various vendors to provide custom acceleration to OpenCV functions. In 5.0 gold some more new HAL entries will be added.
- 5+4.x: In some cases vendors provide super-fast implementations that are unfortunately not 100% compatible with OpenCV. To let user to choose between speed and accuracy in some critical places, OpenCV introduced the optional
AlgorithmHint hint
parameter to several functions, which is set toALGO_HINT_DEFAULT
by default (which is equivalent toALGO_HINT_ACCURATE
unless user compiled OpenCV withALGO_HINT_DEFAULT=ALGO_HINT_FAST
(-DOPENCV_ALGO_HINT_DEFAULT=ALGO_HINT_APPROX
option in cmake). - 5+4.x: Universal intrinsics for math functions (
v_exp
,v_log
,v_erf
,v_sincos
) have been added to accelerate deep learning inference, image processing and other algorithms. - FP16 (i.e. half-precision) universal intrinsics have been added into ARMv8 NEON and RISC-V RVV backends. In both cases FP16 SIMD arithmetics is not available by default, the code needs to be built with special options. The corresponding parts of OpenCV use our runtime dispatching mechanism, which chooses the best-suited flavors of kernels depending on the actual client hardware.
- 5.0, 5.x: UMat will be extended to be able to store any CPU or non-CPU array/tensor. That is, from an OpenCL-only solution (T-API) we now migrate to a universal heterogeneous API (we might call it U-API or “non-CPU HAL”) and UMat will be the main data container for it. Many other improvements are expected as well: https://github.com/opencv/opencv/issues/25019, https://github.com/opencv/opencv/issues/25025
- The new engine has been introduced that now co-exists with the old engine. The new engine provides better support for dynamic shapes and other modern ONNX features. By 5.0 gold it will also provide much better coverage of ONNX specification than the old engine; now the coverage is comparable.
- Added parameter
int engine = ENGINE_AUTO
tocv::dnn::readNet()
to control which engine is used to load and further run the model. By default, we try the new engine first and if it fails to load the model, fall back to the old engine. We can also force the new engine or the old engine. Because of the different internal representation the engine cannot be switched after the model is loaded. - Parsers for ONNX, Caffe, TF and TFLite formats have been updated to support the engine selection.
- 5.0, 5.x: currently, the new engine only supports the default backend and CPU target. It’s planned to enable more backends and targets by 5.0 gold and even more backends in subsequent 5.x releases #26198.
- 5+4.x: Significantly more efficient USAC framework (especially in the case of noisy datasets) is now used for RANSAC-based algorithms to estimate homography, essential matrix, solve PnP problem etc. See https://docs.opencv.org/5.x/de/d3e/tutorial_usac.html
- New Levenberg–Marquardt algorithm implementation. It's faster and more accurate.
- Efficient multi-camera calibration framework has been added to calib module. It includes smart initialization and USAC-based optimization pipeline to compute relative positions of all simultaneously calibrated cameras w.r.t. the 1st camera. Various camera configurations are supported (all pinhole cameras, all fisheye cameras and the mixed case). See tutorial for more details.
- Initiated work on basic mesh processing and point cloud processing algorithms: TSDF, ICP, etc.
- Added importers and exporters for some popular point cloud formats, such as .ply and .obj.
- Revised the following deep learning samples: classification, segmentation, object detection, edge detection, tracking, person reid. All the samples use a collection of models that can be conveniently downloaded with
cd <opencv>/samples/dnn && python3 download_models.py
. - Added experimental samples for LLM (GPT2) and diffusion (LDM) models.
TBD
© Copyright 2019-2025, OpenCV team
- Home
- Deep Learning in OpenCV
- Running OpenCV on Various Platforms
- OpenCV 5
- OpenCV 4
- OpenCV 3
- Development process
- OpenCV GSoC
- Archive