利用OpenCL对OpenCV并行化心得(2)
上文说到了没有ROI的情况下怎么优化add,现在看看有roi的情况。 ROI是opencv里面的一个特性,也可以说是图像处理库都有的特性,它的意思是对于整个一幅图像,只处理被ROI框起来的那一块,可以看做是一个mask。如果不注重性能,最简单的方法就是加上一个offse
上文说到了没有ROI的情况下怎么优化add,现在看看有roi的情况。
ROI是opencv里面的一个特性,也可以说是图像处理库都有的特性,它的意思是对于整个一幅图像,只处理被ROI框起来的那一块,可以看做是一个mask。如果不注重性能,最简单的方法就是加上一个offset即可
__kernel void matrix_add(__global uchar* src1,__global uchar* src2, __global uchar* dst, int rows, int cols,int src1_step,int src2_step,int dst_step,int src1_offset, int src2_offset, int dst_offset)
{
int x=get_global_id(0);
int y=get_global_id(1);
if(x
dst[mad24(y,dst_step,x+dst_offset)]=src1[mad24(y,src1t_step,x+src1_offset)]+src2[mad24(y,src2_step,x+src2_offset)];
}
但是在每次读4个点的时候不能这么做,因为这有对齐问题。比如一个矩阵是17列1行,ROI设置的是后16个点,起始地址就不会是4的整数倍,这样在指针强制转换的时候会出现未定义的情况,结果是错的。除此之外,长度不是4的倍数也会出现问题,所以要使用一些技巧。一个办法是可以先强制对齐地址,多读一些数据,判断是否是需要的,不是需要的就扔掉
__kernel void matrix_add (__global uchar *src1, int src1_step, int src1_offset,
__global uchar *src2, int src2_step, int src2_offset,
__global uchar *dst, int dst_step, int dst_offset,
int rows, int cols, int dst_step1)
{
int x = get_global_id(0);
int y = get_global_id(1);
if (x
{
x = x
#define dst_align (dst_offset & 3)
int src1_index = mad24(y, src1_step, x + src1_offset - dst_align);
int src2_index = mad24(y, src2_step, x + src2_offset - dst_align);
int dst_start = mad24(y, dst_step, dst_offset);
int dst_end = mad24(y, dst_step, dst_offset + dst_step1);
int dst_index = mad24(y, dst_step, dst_offset + x & (int)0xfffffffc);
uchar4 src1_data = vload4(0, src1 + src1_index);
uchar4 src2_data = vload4(0, src2 + src2_index);
uchar4 dst_data = *((__global uchar4 *)(dst + dst_index));
short4 tmp = convert_short4_sat(src1_data) + convert_short4_sat(src2_data);
uchar4 tmp_data = convert_uchar4_sat(tmp);
dst_data.x = ((dst_index + 0 >= dst_start) && (dst_index + 0
dst_data.y = ((dst_index + 1 >= dst_start) && (dst_index + 1
dst_data.z = ((dst_index + 2 >= dst_start) && (dst_index + 2
dst_data.w = ((dst_index + 3 >= dst_start) && (dst_index + 3
*((__global uchar4 *)(dst + dst_index)) = dst_data;
}
}

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Verwenden Sie den Befehl pip, um das OpenCV-Tutorial einfach zu installieren. OpenCV (OpenSource Computer Vision Library) ist eine Open-Source-Computer-Vision-Bibliothek. Sie enthält eine große Anzahl von Computer-Vision-Algorithmen, die Entwicklern beim schnellen Erstellen von Bildern helfen können und videoverarbeitungsbezogene Anwendungen. Bevor wir OpenCV verwenden können, müssen wir es zuerst installieren. Glücklicherweise bietet Python ein leistungsstarkes Tool zur Verwaltung von Bibliotheken von Drittanbietern

So verwenden Sie GitLab für die Projektdokumentenverwaltung 1. Hintergrundeinführung Im Softwareentwicklungsprozess sind Projektdokumente sehr wichtige Informationen. Sie können dem Entwicklungsteam nicht nur helfen, die Anforderungen und das Design des Projekts zu verstehen, sondern auch als Referenz für das Testteam dienen und Kunden. Um die Versionskontrolle und Teamzusammenarbeit von Projektdokumenten zu erleichtern, können wir GitLab für die Projektdokumentenverwaltung verwenden. GitLab ist ein auf Git basierendes Versionskontrollsystem. Es unterstützt nicht nur die Codeverwaltung, sondern kann auch Projektdokumente verwalten. 2. Einrichtung der GitLab-Umgebung Zuerst I

OpenCV ist eine Open-Source-Bibliothek für Computer Vision und Bildverarbeitung, die in den Bereichen maschinelles Lernen, Bilderkennung, Videoverarbeitung und anderen Bereichen weit verbreitet ist. Bei der Entwicklung mit OpenCV entscheiden sich viele Entwickler für die Verwendung von PyCharm, einer leistungsstarken integrierten Python-Entwicklungsumgebung, um Programme besser debuggen und ausführen zu können. Dieser Artikel bietet PyCharm-Benutzern ein Installations-Tutorial für OpenCV mit spezifischen Codebeispielen. Schritt eins: Python installieren Stellen Sie zunächst sicher, dass Python installiert ist

Das Paket org.opencv.imgproc der JavaOpenCV-Bibliothek enthält eine Klasse namens Imgproc, die verschiedene Methoden zum Verarbeiten von Eingabebildern bereitstellt. Es bietet eine Reihe von Methoden zum Zeichnen geometrischer Formen auf Bildern. Um eine Pfeillinie zu zeichnen, müssen Sie die Methode ArrowedLine() dieser Klasse aufrufen. Die Methode akzeptiert die folgenden Parameter: ein Mat-Objekt, das das Bild darstellt, auf dem die Linie gezeichnet werden soll. Ein Point-Objekt, das zwei Punkte zwischen Linien darstellt. gezeichnet. Ein Skalarobjekt, das die Linienfarbe darstellt. (BGR) Eine Ganzzahl, die die Linienstärke darstellt (Standard: 1). Beispiel importorg.opencv.core.Core;importo

Wie implementiert man die Videoverarbeitung mit PHP und der OpenCV-Bibliothek? Zusammenfassung: Die Videoverarbeitung ist zu einer wichtigen Technologie in modernen wissenschaftlichen und technologischen Anwendungen geworden. In diesem Artikel wird erläutert, wie Sie die Programmiersprache PHP in Kombination mit der OpenCV-Bibliothek verwenden, um einige grundlegende Videoverarbeitungsfunktionen zu implementieren, und entsprechende Codebeispiele anhängen. Schlüsselwörter: PHP, OpenCV, Videoverarbeitung, Codebeispiele Einführung: Mit der Entwicklung des Internets und der Popularität von Smartphones sind Videoinhalte zu einem unverzichtbaren Bestandteil des Lebens der Menschen geworden. Um jedoch Videobearbeitung zu erreichen und

Computer Vision (Computer Vision) ist einer der wichtigen Zweige im Bereich der künstlichen Intelligenz. Sie ermöglicht es Computern, visuelle Signale wie Bilder und Videos automatisch wahrzunehmen und zu verstehen und Anwendungsszenarien wie Mensch-Computer-Interaktion und automatisierte Steuerung zu realisieren. OpenCV (OpenSourceComputerVisionLibrary) ist eine beliebte Open-Source-Computer-Vision-Bibliothek, die in den Bereichen Computer Vision, maschinelles Lernen, Deep Learning und anderen Bereichen weit verbreitet ist. In diesem Artikel wird die Verwendung vorgestellt

Gängige Leistungsoptimierungs- und Code-Refactoring-Techniken und -Lösungen in C# Einführung: Im Softwareentwicklungsprozess sind Leistungsoptimierung und Code-Refactoring wichtige Zusammenhänge, die nicht ignoriert werden dürfen. Insbesondere bei der Entwicklung großer Anwendungen mit C# kann die Optimierung und Umgestaltung des Codes die Leistung und Wartbarkeit der Anwendung verbessern. In diesem Artikel werden einige gängige C#-Leistungsoptimierungs- und Code-Refactoring-Techniken vorgestellt und entsprechende Lösungen und spezifische Codebeispiele bereitgestellt. 1. Fähigkeiten zur Leistungsoptimierung: Wählen Sie den geeigneten Sammlungstyp: C# bietet eine Vielzahl von Sammlungstypen, z. B. List, Dict

Wie erreicht man eine Bildschärfung mithilfe der PHP- und OpenCV-Bibliothek? Überblick: Bildschärfung ist eine gängige Bildverarbeitungstechnik, die zur Verbesserung der Klarheit und Kantenstärke eines Bildes eingesetzt wird. In diesem Artikel erklären wir, wie man die Bildschärfung mit PHP und der OpenCV-Bibliothek implementiert. OpenCV ist eine leistungsstarke Open-Source-Computer-Vision-Bibliothek, die umfangreiche Bildverarbeitungsfunktionen bietet. Wir werden die PHP-Erweiterung von OpenCV verwenden, um den Bildschärfungsalgorithmus zu implementieren. Schritt 1: Installieren Sie OpenCV und PHP-Erweiterungen. Zuerst benötigen wir
