OpenCV
OpenCV | |
---|---|
Basisdaten | |
Entwickler | Intel, Willow Garage |
Erscheinungsjahr | Juni 2000 |
Aktuelle Version | 4.9.0[1] (28. Dezember 2023) |
Betriebssystem | plattformunabhängig |
Programmiersprache | C++ |
Kategorie | Programmbibliothek für: Bildverarbeitung Computer-Vision Kamerakalibrierung |
Lizenz | Apache-Lizenz, Version 2.0[2] |
deutschsprachig | nein |
opencv.org |
OpenCV (englische Abk. für Open Source Computer Vision Library[3]) ist eine freie Programmbibliothek mit Algorithmen für die Bildverarbeitung und Computer Vision. Sie ist für die Programmiersprachen C, C++, Python und Java geschrieben und steht als freie Software unter den Bedingungen der Apache 2 License. Die Entwicklung der Bibliothek wurde von Intel initiiert und bis 2013 von Willow Garage gepflegt. Nach deren Auflösung wurde sie von Itseez fortgeführt, das mittlerweile von Intel übernommen wurde.[4]
Im September 2006 wurde die Version 1.0 herausgegeben. Ende September 2009 folgte nach längerer Pause die Version 2.0.0, welche die Bezeichnung „Gold“ trägt. Anfang Juni 2015 erschien Version 3.0, die erstmals OpenCL unterstützte.[5]
Die Stärke von OpenCV liegt in ihrer Geschwindigkeit und in der großen Menge der Algorithmen aus neuesten Forschungsergebnissen.
Anwendungsbereiche
Die Bibliothek umfasst unter anderem Algorithmen für Gesichtserkennung, 3D-Funktionalität, Haar-Klassifikatoren, verschiedene sehr schnelle Filter (z. B. Sobel, Canny, Gauß) und Funktionen für die Kamerakalibrierung.
OpenCV besteht aus Modulen für verschiedene Anwendungsfelder:
- 2D- und 3D-Merkmale (z. B. Interest-Operator oder Deskriptoren)
- Eigenbewegungsschätzung, siehe Photogrammetrie: Rückwärtsschnitt
- Gesichtserkennung
- Gestenerkennung
- Mensch-Computer-Interaktion (HCI)
- Mobile Roboter
- Klassifizierung mit Hilfe der Viola-Jones-Methode
- Segmentierung und Erkennung
- Stereoskopisches Sehen (Stereopsis), ergibt Tiefenbilder
- Structure from Motion (SfM), siehe Computer Vision
- Optisches Tracking, Motion Compensation und Optischer Fluss
- Kalman-Filter zum Tracking
Ferner beinhaltet OpenCV eine Bibliothek für Maschinelles Lernen mit folgendem Funktionsumfang:
- Boosting (automatische Klassifizierung)
- Lernen eines Entscheidungsbaumes
- EM-Algorithmus (Expectation-Maximization)
- Nächste-Nachbarn-Klassifikation
- Bayes-Klassifikator
- Künstliche neuronale Netze, inkl. DNN
- Random Forest
- Support Vector Machine (SVM)
Deep Learning
Das DNN-Modul von OpenCV kann die von gängigen Deep Learning Frameworks vortrainierten Netze einlesen und auf ihnen einen Forward Pass ausführen. D. h., es werden Werte in der sichtbaren Eingangsschicht (englisch input layer) des künstlichen neuronalen Netzwerks eingelesen und beim Durchlaufen aller Schichten des Netzwerks verarbeitet, bis sie dann an der sichtbaren letzten Schicht (output layer) ausgegeben werden.[6] Objekterkennung mit z. B. YOLO wurde auf diese Weise realisiert. Das seit OpenCV 3.1 existierende DNN-Modul wurde mit Release 3.3 in das Haupt-Repository verschoben und ist somit leichter, also ohne Kompilierung des Quellcodes, benutzbar.
Unterstützt werden folgende Bibliotheken:
- Caffe
- TensorFlow
- Torch
- Darknet
- Modelle im ONNX Format
Einzelnachweise
- ↑ Release 4.9.0. 28. Dezember 2023 (abgerufen am 19. Januar 2024).
- ↑ License. (englisch, abgerufen am 4. Dezember 2021).
- ↑ opencv/opencv. OpenCV, 23. Februar 2023, abgerufen am 23. Februar 2023.
- ↑ Intel acquires Itseez - OpenCV library. Abgerufen am 27. April 2018 (englisch).
- ↑ OpenCV 3.0 – The Transparent API and OpenCL™ Acceleration, Harris Gasparakis, 15. Oktober 2014
- ↑ Deep-Learning-in-OpenCV. In: GitHub. OpenCV, 17. Januar 2019, abgerufen am 17. Januar 2019 (englisch).
Literatur
- Gary Bradski, Adrian Kaehler: Learning OpenCV Computer Vision with the OpenCV Library. O’Reilly, 2008, ISBN 978-0-596-51613-0.
Weblinks
Auf dieser Seite verwendete Medien
Autor/Urheber: (MTheiler), Lizenz: CC BY-SA 4.0
Objects detected with OpenCV's Deep Neural Network module (dnn). Reading a network model stored in Darknet model files.It uses a YOLOv3 model trained on COCO dataset capable of detecting 80 common objects in context. Original image: Schreibtisch-mit-Objekten.jpg
Autor/Urheber:
- Jimmy answering questions.jpg: Wikimania2009 Beatrice Murch
- derivative work: Sylenius (Diskussion)
Illustration of automatic face detection.
The OpenCV logo is composed of the 3 capital letters O, C, V arranged in a triangle. The logo combines several motifs in the spirit of Open Source and Computer Vision.