summaryrefslogtreecommitdiff
path: root/src/ipa/rkisp1/algorithms/awb.cpp
diff options
context:
space:
mode:
authorStefan Klug <stefan.klug@ideasonboard.com>2025-04-03 17:49:18 +0200
committerStefan Klug <stefan.klug@ideasonboard.com>2025-05-20 11:20:08 +0200
commitc699d26573ebc3a6275d697a9032aedd9d19f974 (patch)
treedf7c5d0588cbbcc212318f32d5d9784a883bc040 /src/ipa/rkisp1/algorithms/awb.cpp
parent66e9604684ebc09ee848ecf7738beb329bd40c22 (diff)
libipa: awb: Make result of gainsFromColourTemp optional
In the grey world AWB case, if no colour gains are contained in the tuning file, the colour gains get reset to 1 when the colour temperature is set manually. This is unexpected and undesirable. Allow the gainsFromColourTemp() function to return a std::nullopt to handle that case. While at it, remove an unnecessary import from rkisp1/algorithms/awb.h. Signed-off-by: Stefan Klug <stefan.klug@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Paul Elder <paul.elder@ideasonboard.com>
Diffstat (limited to 'src/ipa/rkisp1/algorithms/awb.cpp')
-rw-r--r--src/ipa/rkisp1/algorithms/awb.cpp18
1 files changed, 12 insertions, 6 deletions
diff --git a/src/ipa/rkisp1/algorithms/awb.cpp b/src/ipa/rkisp1/algorithms/awb.cpp
index 8a8fccd5..601de9c4 100644
--- a/src/ipa/rkisp1/algorithms/awb.cpp
+++ b/src/ipa/rkisp1/algorithms/awb.cpp
@@ -127,8 +127,12 @@ int Awb::configure(IPAContext &context,
const IPACameraSensorInfo &configInfo)
{
context.activeState.awb.manual.gains = RGB<double>{ 1.0 };
- context.activeState.awb.automatic.gains =
- awbAlgo_->gainsFromColourTemperature(kDefaultColourTemperature);
+ auto gains = awbAlgo_->gainsFromColourTemperature(kDefaultColourTemperature);
+ if (gains)
+ context.activeState.awb.automatic.gains = *gains;
+ else
+ context.activeState.awb.automatic.gains = RGB<double>{ 1.0 };
+
context.activeState.awb.autoEnabled = true;
context.activeState.awb.manual.temperatureK = kDefaultColourTemperature;
context.activeState.awb.automatic.temperatureK = kDefaultColourTemperature;
@@ -185,11 +189,13 @@ void Awb::queueRequest(IPAContext &context,
*/
update = true;
} else if (colourTemperature) {
- const auto &gains = awbAlgo_->gainsFromColourTemperature(*colourTemperature);
- awb.manual.gains.r() = gains.r();
- awb.manual.gains.b() = gains.b();
awb.manual.temperatureK = *colourTemperature;
- update = true;
+ const auto &gains = awbAlgo_->gainsFromColourTemperature(*colourTemperature);
+ if (gains) {
+ awb.manual.gains.r() = gains->r();
+ awb.manual.gains.b() = gains->b();
+ update = true;
+ }
}
if (update)