/* SPDX-License-Identifier: BSD-2-Clause */ /* * Copyright (C) 2019, Raspberry Pi Ltd * * ISP control algorithm interface */ #pragma once /* * All algorithms should be derived from this class and made available to the * Controller. */ #include #include #include #include "libcamera/internal/yaml_parser.h" #include "controller.h" namespace RPiController { /* This defines the basic interface for all control algorithms. */ class Algorithm { public: Algorithm(Controller *controller) : controller_(controller) { } virtual ~Algorithm() = default; virtual char const *name() const = 0; virtual int read(const libcamera::YamlObject ¶ms); virtual void initialise(); virtual void switchMode(CameraMode const &cameraMode, Metadata *metadata); virtual void prepare(Metadata *imageMetadata); virtual void process(StatisticsPtr &stats, Metadata *imageMetadata); Metadata &getGlobalMetadata() const { return controller_->getGlobalMetadata(); } const std::string &getTarget() const { return controller_->getTarget(); } const Controller::HardwareConfig &getHardwareConfig() const { return controller_->getHardwareConfig(); } private: Controller *controller_; }; /* * This code is for automatic registration of Front End algorithms with the * system. */ typedef Algorithm *(*AlgoCreateFunc)(Controller *controller); struct RegisterAlgorithm { RegisterAlgorithm(char const *name, AlgoCreateFunc createFunc); }; std::map const &getAlgorithms(); } /* namespace RPiController */ href='/libcamera/vivid.git/tree/test/v4l2_videodevice/capture_async.cpp?h=vivid-pre-0e1ff86e78ae&id=08ce394465b5f2e1741145bf653e0da64fd73f07'>treecommitdiff
blob: accdb34a699cbab9bb6af530e9419de3750dfa43 (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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91