70 static std::unique_ptr<CameraSensorHelper>
create(
const std::string &name);
72 static std::vector<CameraSensorHelperFactoryBase *> &
factories();
79 virtual std::unique_ptr<CameraSensorHelper> createInstance()
const = 0;
84template<
typename _Helper>
94 std::unique_ptr<CameraSensorHelper> createInstance()
const override
96 return std::make_unique<_Helper>();
100#define REGISTER_CAMERA_SENSOR_HELPER(name, helper) \
101static CameraSensorHelperFactory<helper> global_##helper##Factory(name);
Utilities to help constructing class interfaces.
#define LIBCAMERA_DISABLE_COPY_AND_MOVE(klass)
Disable copy and move construction and assignment of the klass.
Definition class.h:29
Base class for camera sensor helper factories.
Definition camera_sensor_helper.h:65
CameraSensorHelperFactoryBase(const std::string name)
Construct a camera sensor helper factory base.
Definition camera_sensor_helper.cpp:272
static std::vector< CameraSensorHelperFactoryBase * > & factories()
Retrieve the list of all camera sensor helper factories.
Definition camera_sensor_helper.cpp:321
static std::unique_ptr< CameraSensorHelper > create(const std::string &name)
Create an instance of the CameraSensorHelper corresponding to a named factory.
Definition camera_sensor_helper.cpp:287
Registration of CameraSensorHelperFactory classes and creation of instances.
Definition camera_sensor_helper.h:86
CameraSensorHelperFactory(const char *name)
Construct a camera sensor helper factory.
Definition camera_sensor_helper.h:88
Base class for computing sensor tuning parameters using sensor-specific constants.
Definition camera_sensor_helper.h:24
AnalogueGainType gainType_
The analogue gain model type.
Definition camera_sensor_helper.h:57
std::optional< int16_t > blackLevel() const
Construct a CameraSensorHelper instance.
Definition camera_sensor_helper.h:29
virtual uint32_t gainCode(double gain) const
Compute gain code from the analogue gain absolute value.
Definition camera_sensor_helper.cpp:87
AnalogueGainType
The gain calculation modes as defined by the MIPI CCS.
Definition camera_sensor_helper.h:34
@ AnalogueGainExponential
Gain is expressed using an exponential model.
Definition camera_sensor_helper.h:36
@ AnalogueGainLinear
Gain is computed using linear gain estimation.
Definition camera_sensor_helper.h:35
std::optional< int16_t > blackLevel_
The black level of the sensor.
Definition camera_sensor_helper.h:56
virtual double gain(uint32_t gainCode) const
Compute the real gain from the V4L2 subdev control gain code.
Definition camera_sensor_helper.cpp:119
AnalogueGainConstants gainConstants_
The analogue gain parameters used for calculation.
Definition camera_sensor_helper.h:58
Top-level libcamera namespace.
Definition backtrace.h:17
Analogue gain constants for the exponential gain model.
Definition camera_sensor_helper.h:46
double a
Constant used in the exponential gain coding/decoding.
Definition camera_sensor_helper.h:47
double m
Constant used in the exponential gain coding/decoding.
Definition camera_sensor_helper.h:48
Analogue gain constants for the linear gain model.
Definition camera_sensor_helper.h:39
int16_t m1
Constant used in the linear gain coding/decoding.
Definition camera_sensor_helper.h:42
int16_t m0
Constant used in the linear gain coding/decoding.
Definition camera_sensor_helper.h:40
int16_t c0
Constant used in the linear gain coding/decoding.
Definition camera_sensor_helper.h:41
int16_t c1
Constant used in the linear gain coding/decoding.
Definition camera_sensor_helper.h:43
Analogue gain model constants.
Definition camera_sensor_helper.h:51
AnalogueGainLinearConstants linear
Constants for the linear gain model.
Definition camera_sensor_helper.h:52
AnalogueGainExpConstants exp
Constants for the exponential gain model.
Definition camera_sensor_helper.h:53