| libgphoto2 photo camera library (libgphoto2) API 2.4.14 | 
Adaptive Homogeneity-Directed Bayer array conversion routine. More...
#include <stdio.h>#include <stdlib.h>#include <string.h>#include <math.h>#include <time.h>#include "config.h"#include "bayer.h"#include <gphoto2/gphoto2-result.h>#include <gphoto2/gphoto2-port-log.h>
| Defines | |
| #define | GP_MODULE "ahd_bayer" | 
| #define | MAX(x, y) ((x < y) ? (y) : (x)) | 
| #define | MIN(x, y) ((x > y) ? (y) : (x)) | 
| #define | CLAMP(x) MAX(MIN(x,0xff),0) | 
| #define | RED 0 | 
| #define | GREEN 1 | 
| #define | BLUE 2 | 
| #define | AD(x, y, w) ((y)*(w)*3+3*(x)) | 
| Functions | |
| int | gp_ahd_interpolate (unsigned char *image, int w, int h, BayerTile tile) | 
| Interpolate a expanded bayer array into an RGB image. | |
| int | gp_ahd_decode (unsigned char *input, int w, int h, unsigned char *output, BayerTile tile) | 
| Convert a bayer raster style image to a RGB raster. | |
Adaptive Homogeneity-Directed Bayer array conversion routine.
| int gp_ahd_decode | ( | unsigned char * | input, | 
| int | w, | ||
| int | h, | ||
| unsigned char * | output, | ||
| BayerTile | tile | ||
| ) | 
Convert a bayer raster style image to a RGB raster.
| input | the bayer CCD array as linear input | 
| w | width of the above array | 
| h | height of the above array | 
| output | RGB output array (linear, 3 bytes of R,G,B for every pixel) | 
| tile | how the 2x2 bayer array is layed out | 
A regular CCD uses a raster of 2 green, 1 blue and 1 red components to cover a 2x2 pixel area. The camera or the driver then interpolates a 2x2 RGB pixel set out of this data.
This function expands and interpolates the bayer array to 3 times larger bitmap with RGB values interpolated. It does the same job as gp_bayer_decode() but it calls gp_ahd_interpolate() instead of calling gp_bayer_interpolate(). Use this instead of gp_bayer_decode() if you want to use or to test AHD interpolation in a camera library.
References gp_ahd_interpolate(), gp_bayer_expand(), and GP_OK.
| int gp_ahd_interpolate | ( | unsigned char * | image, | 
| int | w, | ||
| int | h, | ||
| BayerTile | tile | ||
| ) | 
Interpolate a expanded bayer array into an RGB image.
| image | the linear RGB array as both input and output | 
| w | width of the above array | 
| h | height of the above array | 
| tile | how the 2x2 bayer array is layed out | 
This function interpolates a bayer array which has been pre-expanded by gp_bayer_expand() to an RGB image. It applies the method of adaptive homogeneity-directed demosaicing.
References BAYER_TILE_BGGR, BAYER_TILE_BGGR_INTERLACED, BAYER_TILE_GBRG, BAYER_TILE_GBRG_INTERLACED, BAYER_TILE_GRBG, BAYER_TILE_GRBG_INTERLACED, BAYER_TILE_RGGB, BAYER_TILE_RGGB_INTERLACED, GP_ERROR_NO_MEMORY, and GP_OK.
Referenced by gp_ahd_decode().