[PATCH v4 01/11] libipa: Centralise Fixed / Floating point convertors

Laurent Pinchart laurent.pinchart at ideasonboard.com
Fri Dec 6 19:11:16 CET 2024


Hi Dan,

Thank you for the patch.

On Fri, Nov 15, 2024 at 12:25:30PM +0000, Daniel Scally wrote:
> The rkisp1 IPA has some utility functions to convert between fixed
> and floating point numbers. Move those to libipa so they're available
> for use in other IPA modules too.
> 
> Signed-off-by: Daniel Scally <dan.scally at ideasonboard.com>

Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

> ---
> Changes in v4:
> 
> 	- New patch
> 
>  .../{rkisp1/utils.cpp => libipa/fixedpoint.cpp}  | 10 +++++-----
>  src/ipa/{rkisp1/utils.h => libipa/fixedpoint.h}  |  6 +++---
>  src/ipa/libipa/meson.build                       |  2 ++
>  src/ipa/rkisp1/algorithms/ccm.cpp                |  4 ++--
>  src/ipa/rkisp1/meson.build                       |  1 -
>  .../rkisp1-utils.cpp => libipa/fixedpoint.cpp}   | 16 ++++++++--------
>  test/ipa/libipa/meson.build                      |  1 +
>  test/ipa/meson.build                             |  1 -
>  test/ipa/rkisp1/meson.build                      | 15 ---------------
>  9 files changed, 21 insertions(+), 35 deletions(-)
>  rename src/ipa/{rkisp1/utils.cpp => libipa/fixedpoint.cpp} (87%)
>  rename src/ipa/{rkisp1/utils.h => libipa/fixedpoint.h} (93%)
>  rename test/ipa/{rkisp1/rkisp1-utils.cpp => libipa/fixedpoint.cpp} (85%)
>  delete mode 100644 test/ipa/rkisp1/meson.build
> 
> diff --git a/src/ipa/rkisp1/utils.cpp b/src/ipa/libipa/fixedpoint.cpp
> similarity index 87%
> rename from src/ipa/rkisp1/utils.cpp
> rename to src/ipa/libipa/fixedpoint.cpp
> index 960ec64e..6b698fc5 100644
> --- a/src/ipa/rkisp1/utils.cpp
> +++ b/src/ipa/libipa/fixedpoint.cpp
> @@ -2,18 +2,18 @@
>  /*
>   * Copyright (C) 2024, Paul Elder <paul.elder at ideasonboard.com>
>   *
> - * Miscellaneous utility functions specific to rkisp1
> + * Fixed / floating point conversions
>   */
>  
> -#include "utils.h"
> +#include "fixedpoint.h"
>  
>  /**
> - * \file utils.h
> + * \file fixedpoint.h
>   */
>  
>  namespace libcamera {
>  
> -namespace ipa::rkisp1::utils {
> +namespace ipa {
>  
>  /**
>   * \fn R floatingToFixedPoint(T number)
> @@ -37,6 +37,6 @@ namespace ipa::rkisp1::utils {
>   * \return The converted value
>   */
>  
> -} /* namespace ipa::rkisp1::utils */
> +} /* namespace ipa */
>  
>  } /* namespace libcamera */
> diff --git a/src/ipa/rkisp1/utils.h b/src/ipa/libipa/fixedpoint.h
> similarity index 93%
> rename from src/ipa/rkisp1/utils.h
> rename to src/ipa/libipa/fixedpoint.h
> index 5f38b50b..709cf50f 100644
> --- a/src/ipa/rkisp1/utils.h
> +++ b/src/ipa/libipa/fixedpoint.h
> @@ -2,7 +2,7 @@
>  /*
>   * Copyright (C) 2024, Paul Elder <paul.elder at ideasonboard.com>
>   *
> - * Miscellaneous utility functions specific to rkisp1
> + * Fixed / floating point conversions
>   */
>  
>  #pragma once
> @@ -12,7 +12,7 @@
>  
>  namespace libcamera {
>  
> -namespace ipa::rkisp1::utils {
> +namespace ipa {
>  
>  #ifndef __DOXYGEN__
>  template<unsigned int I, unsigned int F, typename R, typename T,
> @@ -60,6 +60,6 @@ constexpr R fixedToFloatingPoint(T number)
>  	return static_cast<R>(t) / static_cast<R>(1 << F);
>  }
>  
> -} /* namespace ipa::rkisp1::utils */
> +} /* namespace ipa */
>  
>  } /* namespace libcamera */
> diff --git a/src/ipa/libipa/meson.build b/src/ipa/libipa/meson.build
> index 788d037a..a1d662c9 100644
> --- a/src/ipa/libipa/meson.build
> +++ b/src/ipa/libipa/meson.build
> @@ -7,6 +7,7 @@ libipa_headers = files([
>      'colours.h',
>      'exposure_mode_helper.h',
>      'fc_queue.h',
> +    'fixedpoint.h',
>      'histogram.h',
>      'interpolator.h',
>      'lsc_polynomial.h',
> @@ -23,6 +24,7 @@ libipa_sources = files([
>      'colours.cpp',
>      'exposure_mode_helper.cpp',
>      'fc_queue.cpp',
> +    'fixedpoint.cpp',
>      'histogram.cpp',
>      'interpolator.cpp',
>      'lsc_polynomial.cpp',
> diff --git a/src/ipa/rkisp1/algorithms/ccm.cpp b/src/ipa/rkisp1/algorithms/ccm.cpp
> index 6b7d2e2c..e2b5cf4d 100644
> --- a/src/ipa/rkisp1/algorithms/ccm.cpp
> +++ b/src/ipa/rkisp1/algorithms/ccm.cpp
> @@ -18,7 +18,7 @@
>  
>  #include "libcamera/internal/yaml_parser.h"
>  
> -#include "../utils.h"
> +#include "libipa/fixedpoint.h"
>  #include "libipa/interpolator.h"
>  
>  /**
> @@ -72,7 +72,7 @@ void Ccm::setParameters(struct rkisp1_cif_isp_ctk_config &config,
>  	for (unsigned int i = 0; i < 3; i++) {
>  		for (unsigned int j = 0; j < 3; j++)
>  			config.coeff[i][j] =
> -				utils::floatingToFixedPoint<4, 7, uint16_t, double>(matrix[i][j]);
> +				floatingToFixedPoint<4, 7, uint16_t, double>(matrix[i][j]);
>  	}
>  
>  	for (unsigned int i = 0; i < 3; i++)
> diff --git a/src/ipa/rkisp1/meson.build b/src/ipa/rkisp1/meson.build
> index 34844f14..26a9fa40 100644
> --- a/src/ipa/rkisp1/meson.build
> +++ b/src/ipa/rkisp1/meson.build
> @@ -9,7 +9,6 @@ rkisp1_ipa_sources = files([
>      'ipa_context.cpp',
>      'params.cpp',
>      'rkisp1.cpp',
> -    'utils.cpp',
>  ])
>  
>  rkisp1_ipa_sources += rkisp1_ipa_algorithms
> diff --git a/test/ipa/rkisp1/rkisp1-utils.cpp b/test/ipa/libipa/fixedpoint.cpp
> similarity index 85%
> rename from test/ipa/rkisp1/rkisp1-utils.cpp
> rename to test/ipa/libipa/fixedpoint.cpp
> index b1863894..99eb662d 100644
> --- a/test/ipa/rkisp1/rkisp1-utils.cpp
> +++ b/test/ipa/libipa/fixedpoint.cpp
> @@ -2,7 +2,7 @@
>  /*
>   * Copyright (C) 2024, Paul Elder <paul.elder at ideasonboard.com>
>   *
> - * Miscellaneous utility tests
> + * Fixed / Floating point utility tests
>   */
>  
>  #include <cmath>
> @@ -10,22 +10,22 @@
>  #include <map>
>  #include <stdint.h>
>  
> -#include "../src/ipa/rkisp1/utils.h"
> +#include "../src/ipa/libipa/fixedpoint.h"
>  
>  #include "test.h"
>  
>  using namespace std;
>  using namespace libcamera;
> -using namespace ipa::rkisp1;
> +using namespace ipa;
>  
> -class RkISP1UtilsTest : public Test
> +class FixedPointUtilsTest : public Test
>  {
>  protected:
>  	/* R for real, I for integer */
>  	template<unsigned int IntPrec, unsigned int FracPrec, typename I, typename R>
>  	int testFixedToFloat(I input, R expected)
>  	{
> -		R out = utils::fixedToFloatingPoint<IntPrec, FracPrec, R>(input);
> +		R out = fixedToFloatingPoint<IntPrec, FracPrec, R>(input);
>  		R prec = 1.0 / (1 << FracPrec);
>  		if (std::abs(out - expected) > prec) {
>  			cerr << "Reverse conversion expected " << input
> @@ -40,7 +40,7 @@ protected:
>  	template<unsigned int IntPrec, unsigned int FracPrec, typename T>
>  	int testSingleFixedPoint(double input, T expected)
>  	{
> -		T ret = utils::floatingToFixedPoint<IntPrec, FracPrec, T>(input);
> +		T ret = floatingToFixedPoint<IntPrec, FracPrec, T>(input);
>  		if (ret != expected) {
>  			cerr << "Expected " << input << " to convert to "
>  			     << expected << ", got " << ret << std::endl;
> @@ -51,7 +51,7 @@ protected:
>  		 * The precision check is fairly arbitrary but is based on what
>  		 * the rkisp1 is capable of in the crosstalk module.
>  		 */
> -		double f = utils::fixedToFloatingPoint<IntPrec, FracPrec, double>(ret);
> +		double f = fixedToFloatingPoint<IntPrec, FracPrec, double>(ret);
>  		if (std::abs(f - input) > 0.005) {
>  			cerr << "Reverse conversion expected " << ret
>  			     << " to convert to " << input
> @@ -105,4 +105,4 @@ protected:
>  	}
>  };
>  
> -TEST_REGISTER(RkISP1UtilsTest)
> +TEST_REGISTER(FixedPointUtilsTest)
> diff --git a/test/ipa/libipa/meson.build b/test/ipa/libipa/meson.build
> index 4d2427db..281e6b1f 100644
> --- a/test/ipa/libipa/meson.build
> +++ b/test/ipa/libipa/meson.build
> @@ -1,6 +1,7 @@
>  # SPDX-License-Identifier: CC0-1.0
>  
>  libipa_test = [
> +    {'name': 'fixedpoint', 'sources': ['fixedpoint.cpp']},
>      {'name': 'interpolator', 'sources': ['interpolator.cpp']},
>  ]
>  
> diff --git a/test/ipa/meson.build b/test/ipa/meson.build
> index 63820de5..ceed15ba 100644
> --- a/test/ipa/meson.build
> +++ b/test/ipa/meson.build
> @@ -1,7 +1,6 @@
>  # SPDX-License-Identifier: CC0-1.0
>  
>  subdir('libipa')
> -subdir('rkisp1')
>  
>  ipa_test = [
>      {'name': 'ipa_module_test', 'sources': ['ipa_module_test.cpp']},
> diff --git a/test/ipa/rkisp1/meson.build b/test/ipa/rkisp1/meson.build
> deleted file mode 100644
> index 894523da..00000000
> --- a/test/ipa/rkisp1/meson.build
> +++ /dev/null
> @@ -1,15 +0,0 @@
> -# SPDX-License-Identifier: CC0-1.0
> -
> -rkisp1_ipa_test = [
> -    {'name': 'rkisp1-utils', 'sources': ['rkisp1-utils.cpp']},
> -]
> -
> -foreach test : rkisp1_ipa_test
> -    exe = executable(test['name'], test['sources'],
> -                     dependencies : [libcamera_private, libipa_dep],
> -                     link_with : [test_libraries],
> -                     include_directories : [test_includes_internal,
> -                                            '../../../src/ipa/rkisp1/'])
> -
> -    test(test['name'], exe, suite : 'ipa')
> -endforeach

-- 
Regards,

Laurent Pinchart


More information about the libcamera-devel mailing list