[libcamera-devel] [PATCH v4 25/32] ipa: rkisp1: awb: Use frame context to fix gains calculations

Kieran Bingham kieran.bingham at ideasonboard.com
Wed Sep 21 01:19:19 CEST 2022


Quoting Laurent Pinchart via libcamera-devel (2022-09-08 02:41:53)
> The AWB statistics are computed after the ISP applies the colour gains.
> This means that the red, green and blue means do not match the data
> coming directly from the sensor, but are multiplied by the colour gains
> that were used for the frame on which the statistics have been computed.
> The AWB algorithm needs to take this into account when calculating the
> colour gains for the next frame. Do so by dividing the means by the
> gains that were applied to the frame, retrieved from the frame context.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> ---
>  src/ipa/rkisp1/algorithms/awb.cpp | 9 +++++++++
>  1 file changed, 9 insertions(+)
> 
> diff --git a/src/ipa/rkisp1/algorithms/awb.cpp b/src/ipa/rkisp1/algorithms/awb.cpp
> index bb0f6c27fc7d..b711e93b73ba 100644
> --- a/src/ipa/rkisp1/algorithms/awb.cpp
> +++ b/src/ipa/rkisp1/algorithms/awb.cpp
> @@ -207,6 +207,15 @@ void Awb::process(IPAContext &context,
>         double greenMean = 1.1636 * yMean - 0.4045 * cbMean - 0.7949 * crMean;
>         double blueMean = 1.1636 * yMean + 1.9912 * cbMean - 0.0250 * crMean;
>  
> +       /*
> +        * The ISP computes the AWB means after applying the colour gains,
> +        * divide by the gains that were used to get the raw means from the
> +        * sensor.
> +        */
> +       redMean /= frameContext.awb.gains.red;
> +       greenMean /= frameContext.awb.gains.green;
> +       blueMean /= frameContext.awb.gains.blue;
> +

Sounds so easy now I see it in code.

Reviewed-by: Kieran Bingham <kieran.bingham at ideasonboard.com>

>         frameContext.awb.temperatureK = estimateCCT(redMean, greenMean, blueMean);
>  
>         /* Estimate the red and blue gains to apply in a grey world. */
> -- 
> Regards,
> 
> Laurent Pinchart
>


More information about the libcamera-devel mailing list