ipa: ipu3: agc: Compute the gain for each frame
Now that we have the real exposure applied at each frame, remove the early return based on a frame counter and compute the gain for each frame. Introduce a number of startup frames during which the filter speed is 1.0, meaning we apply instantly the exposure value calculated and not a slower filtered one. This is used to have a faster convergence, and those frames may be dropped in a future development to hide the convergance process from the viewer. Signed-off-by: Jean-Michel Hautbois <jeanmichel.hautbois@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Umang Jain <umang.jain@ideasonboard.com> Reviewed-by: Paul Elder <paul.elder@ideasonboard.com>
This commit is contained in:
parent
5614c95794
commit
4fdf1e4f5e
2 changed files with 11 additions and 16 deletions
|
@ -45,11 +45,6 @@ namespace ipa::ipu3::algorithms {
|
||||||
|
|
||||||
LOG_DEFINE_CATEGORY(IPU3Agc)
|
LOG_DEFINE_CATEGORY(IPU3Agc)
|
||||||
|
|
||||||
/* Number of frames to wait before calculating stats on minimum exposure */
|
|
||||||
static constexpr uint32_t kInitialFrameMinAECount = 4;
|
|
||||||
/* Number of frames to wait between new gain/shutter time estimations */
|
|
||||||
static constexpr uint32_t kFrameSkipCount = 6;
|
|
||||||
|
|
||||||
/* Limits for analogue gain values */
|
/* Limits for analogue gain values */
|
||||||
static constexpr double kMinAnalogueGain = 1.0;
|
static constexpr double kMinAnalogueGain = 1.0;
|
||||||
static constexpr double kMaxAnalogueGain = 8.0;
|
static constexpr double kMaxAnalogueGain = 8.0;
|
||||||
|
@ -69,10 +64,13 @@ static constexpr double kEvGainTarget = 0.5;
|
||||||
*/
|
*/
|
||||||
static constexpr uint32_t kMinCellsPerZoneRatio = 255 * 20 / 100;
|
static constexpr uint32_t kMinCellsPerZoneRatio = 255 * 20 / 100;
|
||||||
|
|
||||||
|
/* Number of frames to wait before calculating stats on minimum exposure */
|
||||||
|
static constexpr uint32_t kNumStartupFrames = 10;
|
||||||
|
|
||||||
Agc::Agc()
|
Agc::Agc()
|
||||||
: frameCount_(0), lastFrame_(0), iqMean_(0.0), lineDuration_(0s),
|
: frameCount_(0), iqMean_(0.0), lineDuration_(0s), minExposureLines_(0),
|
||||||
minExposureLines_(0), maxExposureLines_(0), filteredExposure_(0s),
|
maxExposureLines_(0), filteredExposure_(0s), currentExposure_(0s),
|
||||||
currentExposure_(0s), prevExposureValue_(0s)
|
prevExposureValue_(0s)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -159,6 +157,11 @@ void Agc::measureBrightness(const ipu3_uapi_stats_3a *stats,
|
||||||
void Agc::filterExposure()
|
void Agc::filterExposure()
|
||||||
{
|
{
|
||||||
double speed = 0.2;
|
double speed = 0.2;
|
||||||
|
|
||||||
|
/* Adapt instantly if we are in startup phase */
|
||||||
|
if (frameCount_ < kNumStartupFrames)
|
||||||
|
speed = 1.0;
|
||||||
|
|
||||||
if (filteredExposure_ == 0s) {
|
if (filteredExposure_ == 0s) {
|
||||||
/* DG stands for digital gain.*/
|
/* DG stands for digital gain.*/
|
||||||
filteredExposure_ = currentExposure_;
|
filteredExposure_ = currentExposure_;
|
||||||
|
@ -185,13 +188,6 @@ void Agc::filterExposure()
|
||||||
*/
|
*/
|
||||||
void Agc::computeExposure(IPAFrameContext &frameContext)
|
void Agc::computeExposure(IPAFrameContext &frameContext)
|
||||||
{
|
{
|
||||||
/* Algorithm initialization should wait for first valid frames */
|
|
||||||
/* \todo - have a number of frames given by DelayedControls ?
|
|
||||||
* - implement a function for IIR */
|
|
||||||
if ((frameCount_ < kInitialFrameMinAECount) || (frameCount_ - lastFrame_ < kFrameSkipCount))
|
|
||||||
return;
|
|
||||||
|
|
||||||
lastFrame_ = frameCount_;
|
|
||||||
|
|
||||||
/* Are we correctly exposed ? */
|
/* Are we correctly exposed ? */
|
||||||
if (std::abs(iqMean_ - kEvGainTarget * knumHistogramBins) <= 1) {
|
if (std::abs(iqMean_ - kEvGainTarget * knumHistogramBins) <= 1) {
|
||||||
|
|
|
@ -37,7 +37,6 @@ private:
|
||||||
void computeExposure(IPAFrameContext &frameContext);
|
void computeExposure(IPAFrameContext &frameContext);
|
||||||
|
|
||||||
uint64_t frameCount_;
|
uint64_t frameCount_;
|
||||||
uint64_t lastFrame_;
|
|
||||||
|
|
||||||
double iqMean_;
|
double iqMean_;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue