summaryrefslogtreecommitdiff
path: root/test/libtest/test.cpp
blob: af37b4dd28ffc22424b88b472fc3fcd8c976121d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
 * Copyright (C) 2018, Google Inc.
 *
 * test.cpp - libcamera test base class
 */

#include <stdlib.h>

#include "test.h"

Test::Test()
{
}

Test::~Test()
{
}

void Test::setArgs([[maybe_unused]] int argc, char *argv[])
{
	self_ = argv[0];
}

int Test::execute()
{
	int ret;

	ret = init();
	if (ret)
		return ret;

	ret = run();

	cleanup();

	return ret;
}
/span> "../noise_status.h" #include "noise.hpp" using namespace RPiController; using namespace libcamera; LOG_DEFINE_CATEGORY(RPiNoise) #define NAME "rpi.noise" Noise::Noise(Controller *controller) : Algorithm(controller), mode_factor_(1.0) { } char const *Noise::Name() const { return NAME; } void Noise::SwitchMode(CameraMode const &camera_mode, [[maybe_unused]] Metadata *metadata) { // For example, we would expect a 2x2 binned mode to have a "noise // factor" of sqrt(2x2) = 2. (can't be less than one, right?) mode_factor_ = std::max(1.0, camera_mode.noise_factor); } void Noise::Read(boost::property_tree::ptree const &params) { reference_constant_ = params.get<double>("reference_constant"); reference_slope_ = params.get<double>("reference_slope"); } void Noise::Prepare(Metadata *image_metadata) { struct DeviceStatus device_status; device_status.analogue_gain = 1.0; // keep compiler calm if (image_metadata->Get("device.status", device_status) == 0) { // There is a slight question as to exactly how the noise // profile, specifically the constant part of it, scales. For // now we assume it all scales the same, and we'll revisit this // if it proves substantially wrong. NOTE: we may also want to // make some adjustments based on the camera mode (such as // binning), if we knew how to discover it... double factor = sqrt(device_status.analogue_gain) / mode_factor_; struct NoiseStatus status; status.noise_constant = reference_constant_ * factor; status.noise_slope = reference_slope_ * factor; image_metadata->Set("noise.status", status); LOG(RPiNoise, Debug) << "constant " << status.noise_constant << " slope " << status.noise_slope; } else LOG(RPiNoise, Warning) << " no metadata"; } // Register algorithm with the system. static Algorithm *Create(Controller *controller) { return new Noise(controller); } static RegisterAlgorithm reg(NAME, &Create);