.wp-block-jetpack-rating-star span.screen-reader-text { border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; word-wrap: normal; }

サイトアイコン NegativeMindException

OpenCV バージョン4がリリースされた!

alpha, beta, rcを経て、ついにOpenCVのバージョン4がリリースされたぞ!

OpenCV 4.0

リリースハイライト:
  • 現在OpenCVはC++11のライブラリであり、C++11準拠のコンパイラが必要です。CMakeはバージョン3.5.1以上が必要となります。
  • OpenCV 1.xから続いていた多くのC APIを廃止しました。
  • coreモジュールの永続データ機能(XML, YAML, JSONへの構造化データの保存・読み込み)は全てC++で再実装し、C APIを廃止しました。
  • 新しくG-APIモジュールを追加しました。これは非常に効率的なグラフベースの画像処理パイプラインエンジンとして機能します。
  • dnnモジュールには試験的にVulkanバックエンドを実装、ONNX形式のネットワークもサポートしました。
  • 一般的なKinect FusionアルゴリズムをCPUとGPU(OpenCL)用に実装して最適化しました。
  • objdetectモジュールにQRコード検出器とデコーダを追加しました。
  • 非常に効率的かつ高品質なDIS dense optical flowアルゴリズムをopencv_contribからvideoジュールへ移動しました。
  • 詳細は過去のアナウンスに記載されています: 4.0-alpha, 4.0-beta, 4.0-rc, changelog

ドキュメントはこちら↓
https://docs.opencv.org/4.0.0/

バージョン4からついにC APIが廃止になったけど、ここ最近はCどころかC++よりもPythonから利用されることの方が多いんじゃなかろうか。(DeepLearning系のライブラリが大体Pythonメインだから)



バージョン3のリリースからもう3年半経ってるんだなぁ。



GitHubでは数日前からopencvおよびopencv_contribのバージョン4.0.0のコードが公開されてはいた。
https://github.com/opencv/opencv/releases/tag/4.0.0
https://github.com/opencv/opencv_contrib/releases/tag/4.0.0

https://qiita.com/dandelion1124/items/eae435e601fba2adb0d1

追記:OpenCvSharpもバージョン4に対応したようです↓
https://www.nuget.org/packages/OpenCvSharp3-AnyCPU/4.0.0.20181129

OpenCV 4.0.0のChangeLogを読んでいて個人的に面白いなぁと思ったのは、QRコードを検出・デコードする機能が標準で入ったこと。サンプルコードもある↓
https://github.com/opencv/opencv/blob/master/samples/cpp/qrcode.cpp

そして、G-APIという新しいモジュール。グラフベースのパイプラインって、ノードを繋いでいくビジュアルプログラミングみたいなやつ?

早速試した方もいるようだ↓
https://neno-garden.com/blog/2018/11/20/opencv4-g-api/

dandelion先生の新刊で勉強しよう↓


スポンサーリンク



2019年4月9日 追記:OpenCV 4.1がリリースされた↓

OpenCV 4.1

リリースハイライト:
  • core, imgprocモジュールの巨大な関数セットの処理がruntime時に最適化できるようになりました。
  • dnnモジュールの以下のように改良しました:
    • 推論エンジンのバックエンドをIntel® Neural Compute Stick 2でサポートされているNN Builder APIに切り替えました。
    • ピーク時のメモリ消費量を削減し、TensorFlowの複数の新しいネットワークをサポートしました。
  • videoioモジュールにAndroid Media NDK APIのサポートを追加しました。
  • Perceptually Uniform Sequential Colormapsを追加しました。
  • opencv_contribに新しいImage Quality Analysisモジュール(quality)を追加し、PSNRやSSIMなどと同様にReferenceless BRISQUE(Image Spatial Quality Evaluator)アルゴリズムを実装しました。
  • opencv_contrib/optflow moduleモジュールにRobust Local Optical Flowアルゴリズムを追加しました。
  • opencv_contrib/stereoモジュールにQuasi Dense Stereo matchingアルゴリズムを実装しました。
  • Hand-Eye Calibration手法を追加しました。

より詳しい情報はChangelogをご覧ください。

2019年12月 追記:OpenCV 4.2がリリースされたぞ↓

OpenCV 4.2


スポンサーリンク

関連記事

OpenVDB:3Dボリュームデータ処理ライブラリ

ブラウザ操作自動化ツール『Selenium』を試す

viser:Pythonで使える3D可視化ライブラリ

Paul Debevec

GoB:ZBrushとBlenderを連携させるアドオン

Adobeの手振れ補正機能『ワープスタビライザー』の秘密

DCGAN (Deep Convolutional GAN):畳み込みニューラルネットワークによる敵...

Python.NET:Pythonと.NETを連携させるパッケージ

Geogram:C++の3D幾何アルゴリズムライブラリ

Seleniumを使ったFXや株の自動取引

畳み込みニューラルネットワーク (CNN: Convolutional Neural Network...

Faceshiftで表情をキャプチャしてBlender上でMakeHumanのメッシュを動かすデモ

OpenCVのバージョン3が正式リリースされたぞ

3Dスキャンに基づくプロシージャルフェイシャルアニメーション

OpenCLに対応したオープンソースの物理ベースレンダラ『LuxRender(ルクスレンダー)』

DensePose:画像中の人物表面のUV座標を推定する

自前のShaderがおかしい件

Raspberry PiでIoTごっこ

OpenAR:OpenCVベースのマーカーARライブラリ

OpenCVで顔のモーフィングを実装する

C++の抽象クラス

OpenMesh:オープンソースの3Dメッシュデータライブラリ

法線マップを用意してCanvas上でShadingするサンプル

Photogrammetry (写真測量法)

uvでWindows11のPython環境を管理する

顔追跡による擬似3D表示『Dynamic Perspective』

Unity ARKitプラグインサンプルのチュートリアルを読む

AfterEffectsプラグイン開発

Pylearn2:ディープラーニングに対応したPythonの機械学習ライブラリ

Raspberry Pi 2のGPIOピン配置

Regard3D:オープンソースのStructure from Motionツール

Mask R-CNN:ディープラーニングによる一般物体検出・Instance Segmentatio...

Manim:Pythonで使える数学アニメーションライブラリ

Digital Emily Project:人間の顔をそっくりそのままCGで復元する

Pythonの自然言語処理ライブラリ『NLTK(Natural Language Toolkit)』

Iterator

PeopleSansPeople:機械学習用の人物データをUnityで生成する

スクラッチで既存のキャラクターを立体化したい

ポリゴンジオメトリ処理ライブラリ『pmp-library (Polygon Mesh Process...

Leap MotionでMaya上のオブジェクトを操作できるプラグイン

画像生成AI Stable Diffusionで遊ぶ

Web経由でRaspberry PiのGPIOを操作したい

モバイルバージョンを終了