libcamera: ipa: raspberrypi: Add sharpness strength control
The sharpness control is, loosely speaking, a gain applied to the amount of sharpening added to an image. We also report the sharpness setting used back to the caller in metadata. Signed-off-by: David Plowman <david.plowman@raspberrypi.com> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
This commit is contained in:
parent
58e63a6e7e
commit
0dbc6a507c
4 changed files with 50 additions and 7 deletions
|
@ -17,7 +17,7 @@ using namespace RPi;
|
||||||
#define NAME "rpi.sharpen"
|
#define NAME "rpi.sharpen"
|
||||||
|
|
||||||
Sharpen::Sharpen(Controller *controller)
|
Sharpen::Sharpen(Controller *controller)
|
||||||
: Algorithm(controller)
|
: SharpenAlgorithm(controller), user_strength_(1.0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,14 +42,32 @@ void Sharpen::Read(boost::property_tree::ptree const ¶ms)
|
||||||
limit_ = params.get<double>("limit", 1.0);
|
limit_ = params.get<double>("limit", 1.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Sharpen::SetStrength(double strength)
|
||||||
|
{
|
||||||
|
// Note that this method is how an application sets the overall
|
||||||
|
// sharpening "strength". We call this the "user strength" field
|
||||||
|
// as there already is a strength_ field - being an internal gain
|
||||||
|
// parameter that gets passed to the ISP control code. Negative
|
||||||
|
// values are not allowed - coerce them to zero (no sharpening).
|
||||||
|
user_strength_ = std::max(0.0, strength);
|
||||||
|
}
|
||||||
|
|
||||||
void Sharpen::Prepare(Metadata *image_metadata)
|
void Sharpen::Prepare(Metadata *image_metadata)
|
||||||
{
|
{
|
||||||
|
// The user_strength_ affects the algorithm's internal gain directly, but
|
||||||
|
// we adjust the limit and threshold less aggressively. Using a sqrt
|
||||||
|
// function is an arbitrary but gentle way of accomplishing this.
|
||||||
|
double user_strength_sqrt = sqrt(user_strength_);
|
||||||
struct SharpenStatus status;
|
struct SharpenStatus status;
|
||||||
// Binned modes seem to need the sharpening toned down with this
|
// Binned modes seem to need the sharpening toned down with this
|
||||||
// pipeline.
|
// pipeline, thus we use the mode_factor here. Also avoid
|
||||||
status.threshold = threshold_ * mode_factor_;
|
// divide-by-zero with the user_strength_sqrt.
|
||||||
status.strength = strength_ / mode_factor_;
|
status.threshold = threshold_ * mode_factor_ /
|
||||||
status.limit = limit_ / mode_factor_;
|
std::max(0.01, user_strength_sqrt);
|
||||||
|
status.strength = strength_ / mode_factor_ * user_strength_;
|
||||||
|
status.limit = limit_ / mode_factor_ * user_strength_sqrt;
|
||||||
|
// Finally, report any application-supplied parameters that were used.
|
||||||
|
status.user_strength = user_strength_;
|
||||||
image_metadata->Set("sharpen.status", status);
|
image_metadata->Set("sharpen.status", status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,20 +6,21 @@
|
||||||
*/
|
*/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "../algorithm.hpp"
|
#include "../sharpen_algorithm.hpp"
|
||||||
#include "../sharpen_status.h"
|
#include "../sharpen_status.h"
|
||||||
|
|
||||||
// This is our implementation of the "sharpen algorithm".
|
// This is our implementation of the "sharpen algorithm".
|
||||||
|
|
||||||
namespace RPi {
|
namespace RPi {
|
||||||
|
|
||||||
class Sharpen : public Algorithm
|
class Sharpen : public SharpenAlgorithm
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Sharpen(Controller *controller);
|
Sharpen(Controller *controller);
|
||||||
char const *Name() const override;
|
char const *Name() const override;
|
||||||
void SwitchMode(CameraMode const &camera_mode, Metadata *metadata) override;
|
void SwitchMode(CameraMode const &camera_mode, Metadata *metadata) override;
|
||||||
void Read(boost::property_tree::ptree const ¶ms) override;
|
void Read(boost::property_tree::ptree const ¶ms) override;
|
||||||
|
void SetStrength(double strength) override;
|
||||||
void Prepare(Metadata *image_metadata) override;
|
void Prepare(Metadata *image_metadata) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -27,6 +28,7 @@ private:
|
||||||
double strength_;
|
double strength_;
|
||||||
double limit_;
|
double limit_;
|
||||||
double mode_factor_;
|
double mode_factor_;
|
||||||
|
double user_strength_;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace RPi
|
} // namespace RPi
|
||||||
|
|
21
src/ipa/raspberrypi/controller/sharpen_algorithm.hpp
Normal file
21
src/ipa/raspberrypi/controller/sharpen_algorithm.hpp
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
/* SPDX-License-Identifier: BSD-2-Clause */
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2020, Raspberry Pi (Trading) Limited
|
||||||
|
*
|
||||||
|
* sharpen_algorithm.hpp - sharpness control algorithm interface
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "algorithm.hpp"
|
||||||
|
|
||||||
|
namespace RPi {
|
||||||
|
|
||||||
|
class SharpenAlgorithm : public Algorithm
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
SharpenAlgorithm(Controller *controller) : Algorithm(controller) {}
|
||||||
|
// A sharpness control algorithm must provide the following:
|
||||||
|
virtual void SetStrength(double strength) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace RPi
|
|
@ -19,6 +19,8 @@ struct SharpenStatus {
|
||||||
double strength;
|
double strength;
|
||||||
// upper limit of the allowed sharpening response
|
// upper limit of the allowed sharpening response
|
||||||
double limit;
|
double limit;
|
||||||
|
// The sharpening strength requested by the user or application.
|
||||||
|
double user_strength;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue