u/aeg: Add log functions

This commit is contained in:
Mateo de Mayo 2022-05-17 18:17:37 -03:00 committed by Jakob Bornecrantz
parent 63b477d250
commit bf311f3c2e

View file

@ -9,7 +9,9 @@
#include "math/m_api.h" #include "math/m_api.h"
#include "util/u_autoexpgain.h" #include "util/u_autoexpgain.h"
#include "util/u_debug.h"
#include "util/u_format.h" #include "util/u_format.h"
#include "util/u_logging.h"
#include "util/u_misc.h" #include "util/u_misc.h"
#include "util/u_var.h" #include "util/u_var.h"
@ -17,13 +19,27 @@
#include <math.h> #include <math.h>
#include <stdint.h> #include <stdint.h>
#define MIN(a, b) ((a) < (b) ? (a) : (b)) DEBUG_GET_ONCE_LOG_OPTION(aeg_log, "AEG_LOG", U_LOGGING_WARN)
#define MAX(a, b) ((a) > (b) ? (a) : (b))
#define CLAMP(X, A, B) (MIN(MAX((X), (A)), (B))) #define AEG_TRACE(...) U_LOG_IFL_T(aeg->log_level, __VA_ARGS__)
#define AEG_DEBUG(...) U_LOG_IFL_D(aeg->log_level, __VA_ARGS__)
#define AEG_INFO(...) U_LOG_IFL_I(aeg->log_level, __VA_ARGS__)
#define AEG_WARN(...) U_LOG_IFL_W(aeg->log_level, __VA_ARGS__)
#define AEG_ERROR(...) U_LOG_IFL_E(aeg->log_level, __VA_ARGS__)
#define AEG_ASSERT(predicate, ...) \
do { \
bool p = predicate; \
if (!p) { \
U_LOG(U_LOGGING_ERROR, __VA_ARGS__); \
assert(false && "AEG_ASSERT failed: " #predicate); \
exit(EXIT_FAILURE); \
} \
} while (false);
#define AEG_ASSERT_(predicate) AEG_ASSERT(predicate, "Assertion failed " #predicate)
#define LEVELS 256 //!< Possible pixel intensity values, only 8-bit supported #define LEVELS 256 //!< Possible pixel intensity values, only 8-bit supported
#define INITIAL_BRIGHTNESS 0.5 #define INITIAL_BRIGHTNESS 0.5
#define INITIAL_MAX_BRIGHTNES_STEP 0.05 //!< 0.1 is faster but introduces oscilations more often #define INITIAL_MAX_BRIGHTNESS_STEP 0.05 //!< 0.1 is faster but introduces oscillations more often
#define INITIAL_THRESHOLD 0.1 #define INITIAL_THRESHOLD 0.1
#define GRID_COLS 40 //!< Amount of columns for the histogram sample grid #define GRID_COLS 40 //!< Amount of columns for the histogram sample grid
@ -32,6 +48,8 @@ struct u_autoexpgain
{ {
bool enable; //!< Whether to enable auto exposure and gain adjustment bool enable; //!< Whether to enable auto exposure and gain adjustment
enum u_logging_level log_level;
//! Algorithm strategy that affects how score and brightness are computed //! Algorithm strategy that affects how score and brightness are computed
enum u_aeg_strategy strategy; enum u_aeg_strategy strategy;
struct u_var_combo strategy_combo; //!< UI combo box for selecting `strategy` struct u_var_combo strategy_combo; //!< UI combo box for selecting `strategy`
@ -97,7 +115,7 @@ brightness_to_expgain(struct u_autoexpgain *aeg, float brightness, float *out_ex
steps = steps_dr; steps = steps_dr;
steps_count = sizeof(steps_dr) / sizeof(struct step); steps_count = sizeof(steps_dr) / sizeof(struct step);
} else { } else {
assert(false && "unexpected branch taken"); AEG_ASSERT(false, "Unexpected strategy=%d", aeg->strategy);
} }
// Other simpler tables that might work for WMR are: // Other simpler tables that might work for WMR are:
@ -105,10 +123,10 @@ brightness_to_expgain(struct u_autoexpgain *aeg, float brightness, float *out_ex
// {{0, 120, 16}, {0.2, 6000, 16}, {0.9, 6000, 255}, {1.0, 9000, 255}}; // {{0, 120, 16}, {0.2, 6000, 16}, {0.9, 6000, 255}, {1.0, 9000, 255}};
// Assertions // Assertions
assert(steps_count >= 2 && "Exoected at least two steps"); AEG_ASSERT(steps_count >= 2, "Expected at least two steps but %d found", steps_count);
assert(steps[0].b == 0 && "First step should be at b=0"); AEG_ASSERT(steps[0].b == 0, "First step should be at b=0");
assert(steps[steps_count - 1].b == 1 && "Last step should be at b=1"); AEG_ASSERT(steps[steps_count - 1].b == 1, "Last step should be at b=1");
assert(brightness >= 0 && brightness <= 1); AEG_ASSERT(brightness >= 0 && brightness <= 1, "Invalid brightness=%f", brightness);
// Compute the piecewise function result from `steps` // Compute the piecewise function result from `steps`
float exposure = 0; float exposure = 0;
@ -140,11 +158,7 @@ update_expgain(struct u_autoexpgain *aeg)
} }
aeg->last_brightness = brightness; aeg->last_brightness = brightness;
float exposure = -1; brightness_to_expgain(aeg, brightness, &aeg->exposure, &aeg->gain);
float gain = -1;
brightness_to_expgain(aeg, brightness, &exposure, &gain);
aeg->exposure = (uint16_t)exposure;
aeg->gain = (uint8_t)gain;
} }
//! Returns a value in the range [-1, 1] describing how dark-bright the image //! Returns a value in the range [-1, 1] describing how dark-bright the image
@ -183,7 +197,7 @@ get_score(struct u_autoexpgain *aeg, struct xrt_frame *xf)
float score = 0; float score = 0;
// Score that tries to make the mean reach TARGET_MEAN. // Score that tries to make the mean reach a `target_mean`.
float target_mean = -1; float target_mean = -1;
if (aeg->strategy == U_AEG_STRATEGY_TRACKING) { if (aeg->strategy == U_AEG_STRATEGY_TRACKING) {
@ -192,6 +206,8 @@ get_score(struct u_autoexpgain *aeg, struct xrt_frame *xf)
target_mean = LEVELS / 4; target_mean = LEVELS / 4;
} else if (aeg->strategy == U_AEG_STRATEGY_DYNAMIC_RANGE) { } else if (aeg->strategy == U_AEG_STRATEGY_DYNAMIC_RANGE) {
target_mean = LEVELS / 2; target_mean = LEVELS / 2;
} else {
AEG_ASSERT(false, "Unexpected strategy=%d", aeg->strategy);
} }
const float range_size = mean < target_mean ? target_mean : (LEVELS - target_mean); const float range_size = mean < target_mean ? target_mean : (LEVELS - target_mean);
@ -201,7 +217,6 @@ get_score(struct u_autoexpgain *aeg, struct xrt_frame *xf)
return score; return score;
} }
static void static void
update_brightness(struct u_autoexpgain *aeg, struct xrt_frame *xf) update_brightness(struct u_autoexpgain *aeg, struct xrt_frame *xf)
{ {
@ -240,6 +255,7 @@ u_autoexpgain_create(enum u_aeg_strategy strategy, bool enabled_from_start, uint
struct u_autoexpgain *aeg = U_TYPED_CALLOC(struct u_autoexpgain); struct u_autoexpgain *aeg = U_TYPED_CALLOC(struct u_autoexpgain);
aeg->enable = enabled_from_start; aeg->enable = enabled_from_start;
aeg->log_level = debug_get_log_option_aeg_log();
aeg->strategy = strategy; aeg->strategy = strategy;
aeg->strategy_combo.count = U_AEG_STRATEGY_COUNT; aeg->strategy_combo.count = U_AEG_STRATEGY_COUNT;
aeg->strategy_combo.options = "Tracking\0Dynamic Range\0\0"; aeg->strategy_combo.options = "Tracking\0Dynamic Range\0\0";
@ -253,7 +269,7 @@ u_autoexpgain_create(enum u_aeg_strategy strategy, bool enabled_from_start, uint
aeg->brightness.step = 0.002; aeg->brightness.step = 0.002;
aeg->brightness.val = INITIAL_BRIGHTNESS; aeg->brightness.val = INITIAL_BRIGHTNESS;
aeg->last_brightness = INITIAL_BRIGHTNESS; aeg->last_brightness = INITIAL_BRIGHTNESS;
aeg->max_brightness_step = INITIAL_MAX_BRIGHTNES_STEP; aeg->max_brightness_step = INITIAL_MAX_BRIGHTNESS_STEP;
aeg->threshold = INITIAL_THRESHOLD; aeg->threshold = INITIAL_THRESHOLD;
aeg->frame_counter = 0; aeg->frame_counter = 0;
@ -267,7 +283,7 @@ u_autoexpgain_create(enum u_aeg_strategy strategy, bool enabled_from_start, uint
void void
u_autoexpgain_add_vars(struct u_autoexpgain *aeg, void *root) u_autoexpgain_add_vars(struct u_autoexpgain *aeg, void *root)
{ {
u_var_add_bool(root, &aeg->enable, "Enable AEG"); u_var_add_bool(root, &aeg->enable, "Update brightness automatically");
u_var_add_u8(root, &aeg->update_every, "Update every X frames"); u_var_add_u8(root, &aeg->update_every, "Update every X frames");
u_var_add_combo(root, &aeg->strategy_combo, "Strategy"); u_var_add_combo(root, &aeg->strategy_combo, "Strategy");
u_var_add_draggable_f32(root, &aeg->brightness, "Brightness"); u_var_add_draggable_f32(root, &aeg->brightness, "Brightness");
@ -275,6 +291,7 @@ u_autoexpgain_add_vars(struct u_autoexpgain *aeg, void *root)
u_var_add_f32(root, &aeg->max_brightness_step, "Max brightness step"); u_var_add_f32(root, &aeg->max_brightness_step, "Max brightness step");
u_var_add_ro_f32(root, &aeg->current_score, "Image score"); u_var_add_ro_f32(root, &aeg->current_score, "Image score");
u_var_add_histogram_f32(root, &aeg->histogram_ui, "Intensity histogram"); u_var_add_histogram_f32(root, &aeg->histogram_ui, "Intensity histogram");
u_var_add_log_level(root, &aeg->log_level, "AEG log level");
} }
void void