2016-06-01 6 views
1

Ich weiß nicht, wie das Projekt zu starten, dies umzusetzen:Bildberechnungs OpenCL und dann Bildschirm Rendering

  1. Eine Matrix von 16-Bit-Integer in GPU-Speicher geladen (Dies ist ein Graustufenbild Radiologie) (Kontraststeigerungs Algorithmus zum Beispiel)
  2. ein Bereich von Interesse der zweiten Matrix umgewandelt wird in ein RGB-Bild für die Bildschirmanzeige
  3. eine zweite Matrix aus 16 Bits der ganzen Zahlen wird von dem ersten Array, berechnet durch eine Funktion der Anwendung .

Ich kann Schritt eins und zwei tun, und ich bin auf Schritt 3 fest! Ich habe das alles in der CPU implementiert, also geht es hier nicht darum, Graustufen- oder RGB-Bilder zu bearbeiten oder Bitmaps für die Anzeige zu erstellen. Ich habe auch die ersten beiden Schritte in OpenCL implementiert und dann die resultierende Matrix im CPU-Speicher für RGB-Bitmap-Konvertierung gelesen und dann angezeigt. Aber das ist natürlich langsam, weil Daten zwischen CPU- und GPU-Speicher hin und her bewegt werden (Bilder sind wirklich groß: mehr als 100 Megapixel).

Jede Hilfe wird geschätzt. Ich programmiere mit Delphi 10, aber Beispielcode in C/C++ ist in Ordnung. Ich habe VC2010 und erfolgreich NVidia OpenCL oclNbody Beispielanwendung neu erstellen.

+0

Was hast du schon versucht, hat nicht funktioniert? Sie können OpenCL-Bilder für die Graustufenquelle und das RGB- oder RGBA-Ergebnis erstellen und an die Rechenkerne übergeben. – Dithermaster

+0

Für Schritt 3 habe ich nichts erstellt, da ich keine Ahnung habe, wie es geht. Genau darum bitte ich. Ich weiß nicht, wie man ein Bild in OpenCL (clCreateImage) auf dem Bildschirm in einem Fenster anzeigt, das von Windows API CreateWindow erstellt wurde. – fpiette

+0

Ich habe etwas Quellcode gefunden, der ziemlich nah an dem ist, was ich brauche (http://amd-dev.wpengine.netdna-cdn.com/wordpress/media/2013/12/AMD_OpenCL_Programming_User_Guide2.pdf Kapitel E.1.1 Erstellen eines CL-Kontextes von einem GL Kontext, mit Win32 API). Unglücklicherweise erzeugt der Aufruf von clGetGLContextInfoKHR eine Zugriffsverletzung, die durch eine Plattformvariable verursacht wird, die an das Funktion-durch-Eigenschaft-Argument übergeben wird. Ich habe diesen Quellcode nach Delphi portiert und dies könnte der Schuldige sein. Wenn ich das vollständige Beispielprogramm in C hätte, könnte ich diese C-Version zur Laufzeit mit meiner Delphi-Version vergleichen und verstehen, was falsch ist. – fpiette

Antwort

0

Die Lösung Ihres Problems hängt stark davon ab, was Sie rendern möchten. Wahrscheinlich, wenn Sie medizinische Bilder verarbeiten, müssen Sie qualitativ hochwertige Bilder anzeigen.

Basierend auf Ihren Worten ist ROI-Auflösung viel größer als die der Anzeige. Ich weiß nicht viel über die Qualität der integrierten OpenGL-Bildskalierungsfilter, also würde ich zuerst testen, ob OpenGL eine Option ist, bevor ich den komplexen OpenCL-OpenGL-Interop-Code schreibe. Jedenfalls hätte ich lieber einen Skalierungsfilter, den ich anpassen kann.

Die flexibelste Option besteht also darin, zwei OpenCL-Puffer gleicher Größe zu erstellen, um die Auflösung anzuzeigen. Dann implementieren OpenCL-Kernel, die Graustufen -> RGB-Konvertierung & Downsampling durchführen.

Pseudo-Code lautet wie folgt:

// Original grayscale image; 
cl_mem orig_image = clCreateBuffer(sizeof(uint16_t)*orig_width*orig_heigth); 

// Grayscale ROI, downscaled to dispaly resolution, still 16 bits; 
cl_mem disp_grayscale = clCreateBuffer(sizeof(uint16_t)*disp_width*disp_heigth); 

// RGB image to display; 
cl_mem disp_rgb = clCreateBuffer(sizeof(uint8_t)*3*disp_width*disp_heigth); 

clEnqueueNDRangeKernel(DownscaleFilter, orig_image, disp_grayscale); 
clEnqueueNDRangeKernel(GrayscaleToRGb, disp_grayscale, disp_rgb); 

uint8_t *pixels = clEnqueueMapBuffer(disp_rgb); 
// Deal with it as with usual image; 

clEnqueueUnmapMemoryObject(disp_rgb); 
// pixels are no longer available; 

IMO, das komplexeste Problem hierbei ist, qualitativ hochwertige absteuernd Filter zu entwickeln. Ich habe einen 8-Tap-Downscale-Filter vom neuen HEVC-Videocodierungsstandard getestet, das war ziemlich gut.