ipa/rpi/controller: Use fabs for calculating absolute values
diff mbox series

Message ID 20240815093715.165305-1-dev@lankhorst.se
State New
Headers show
Series
  • ipa/rpi/controller: Use fabs for calculating absolute values
Related show

Commit Message

Maarten Lankhorst Aug. 15, 2024, 9:37 a.m. UTC
I was getting the following error in clang:
../src/ipa/rpi/controller/rpi/awb.cpp:508:6: error: using integer absolute value function 'abs' when argument is of floating point type [-Werror,-Wabsolute-value]
        if (abs(denominator) > eps) {
            ^
../src/ipa/rpi/controller/rpi/awb.cpp:508:6: note: use function 'std::abs' instead
        if (abs(denominator) > eps) {
            ^~~
            std::abs

Signed-off-by: Maarten Lankhorst <dev@lankhorst.se>
---
 src/ipa/rpi/controller/rpi/awb.cpp | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Kieran Bingham Aug. 15, 2024, 9:51 a.m. UTC | #1
Hi Maarten,

Thank you for highlighting this. I'm curious that it hasn't come up in
our builds yet! What version of clang are you using?

Quoting Maarten Lankhorst (2024-08-15 10:37:15)
> I was getting the following error in clang:
> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: error: using integer absolute value function 'abs' when argument is of floating point type [-Werror,-Wabsolute-value]
>         if (abs(denominator) > eps) {
>             ^
> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: note: use function 'std::abs' instead

Is there a preference against the recommended std::abs?

>         if (abs(denominator) > eps) {
>             ^~~
>             std::abs
> 
> Signed-off-by: Maarten Lankhorst <dev@lankhorst.se>
> ---
>  src/ipa/rpi/controller/rpi/awb.cpp | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/src/ipa/rpi/controller/rpi/awb.cpp b/src/ipa/rpi/controller/rpi/awb.cpp
> index f45525bc..c5750c84 100644
> --- a/src/ipa/rpi/controller/rpi/awb.cpp
> +++ b/src/ipa/rpi/controller/rpi/awb.cpp
> @@ -505,7 +505,7 @@ static double interpolateQuadatric(ipa::Pwl::Point const &a, ipa::Pwl::Point con
>         const double eps = 1e-3;
>         ipa::Pwl::Point ca = c - a, ba = b - a;
>         double denominator = 2 * (ba.y() * ca.x() - ca.y() * ba.x());
> -       if (abs(denominator) > eps) {
> +       if (fabs(denominator) > eps) {
>                 double numerator = ba.y() * ca.x() * ca.x() - ca.y() * ba.x() * ba.x();
>                 double result = numerator / denominator + a.x();
>                 return std::max(a.x(), std::min(c.x(), result));
> -- 
> 2.39.2
>
Laurent Pinchart Aug. 15, 2024, 9:49 p.m. UTC | #2
On Thu, Aug 15, 2024 at 10:51:38AM +0100, Kieran Bingham wrote:
> Hi Maarten,
> 
> Thank you for highlighting this. I'm curious that it hasn't come up in
> our builds yet! What version of clang are you using?
> 
> Quoting Maarten Lankhorst (2024-08-15 10:37:15)
> > I was getting the following error in clang:
> > ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: error: using integer absolute value function 'abs' when argument is of floating point type [-Werror,-Wabsolute-value]
> >         if (abs(denominator) > eps) {
> >             ^
> > ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: note: use function 'std::abs' instead
> 
> Is there a preference against the recommended std::abs?

Documentation/coding-style.rst states

  Usage of the C compatibility headers is preferred, except for the
  math.h header. Where math.h defines separate functions for different
  argument types (e.g. abs(int), labs(long int), fabs(double) and
  fabsf(float)) and requires the developer to pick the right function,
  cmath defines overloaded functions (std::abs(int), std::abs(long int),
  std::abs(double) and std::abs(float) to let the compiler select the
  right function. This avoids potential errors such as calling abs(int)
  with a float argument, performing an unwanted implicit integer
  conversion. For this reason, cmath is preferred over math.h.

There's also a set of calls to abs() abd fabs() in
src/ipa/rpi/controller/rpi/alsc.cpp which should be replaced by
std::abs().

Maarten, would you like to submit a new version that addresses both ?

> >         if (abs(denominator) > eps) {
> >             ^~~
> >             std::abs
> > 
> > Signed-off-by: Maarten Lankhorst <dev@lankhorst.se>
> > ---
> >  src/ipa/rpi/controller/rpi/awb.cpp | 2 +-
> >  1 file changed, 1 insertion(+), 1 deletion(-)
> > 
> > diff --git a/src/ipa/rpi/controller/rpi/awb.cpp b/src/ipa/rpi/controller/rpi/awb.cpp
> > index f45525bc..c5750c84 100644
> > --- a/src/ipa/rpi/controller/rpi/awb.cpp
> > +++ b/src/ipa/rpi/controller/rpi/awb.cpp
> > @@ -505,7 +505,7 @@ static double interpolateQuadatric(ipa::Pwl::Point const &a, ipa::Pwl::Point con
> >         const double eps = 1e-3;
> >         ipa::Pwl::Point ca = c - a, ba = b - a;
> >         double denominator = 2 * (ba.y() * ca.x() - ca.y() * ba.x());
> > -       if (abs(denominator) > eps) {
> > +       if (fabs(denominator) > eps) {
> >                 double numerator = ba.y() * ca.x() * ca.x() - ca.y() * ba.x() * ba.x();
> >                 double result = numerator / denominator + a.x();
> >                 return std::max(a.x(), std::min(c.x(), result));
Milan Zamazal Aug. 16, 2024, 1:40 p.m. UTC | #3
Kieran Bingham <kieran.bingham@ideasonboard.com> writes:

> Hi Maarten,
>
> Thank you for highlighting this. I'm curious that it hasn't come up in
> our builds yet! What version of clang are you using?

It happens to me too, with clang 18.1.6 on Fedora 40.

> Quoting Maarten Lankhorst (2024-08-15 10:37:15)
>> I was getting the following error in clang:
>> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: error: using integer absolute value function 'abs' when argument is of floating point type [-Werror,-Wabsolute-value]
>>         if (abs(denominator) > eps) {
>>             ^
>> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: note: use function 'std::abs' instead
>
> Is there a preference against the recommended std::abs?
>
>>         if (abs(denominator) > eps) {
>>             ^~~
>>             std::abs
>> 
>> Signed-off-by: Maarten Lankhorst <dev@lankhorst.se>
>> ---
>>  src/ipa/rpi/controller/rpi/awb.cpp | 2 +-
>>  1 file changed, 1 insertion(+), 1 deletion(-)
>> 
>> diff --git a/src/ipa/rpi/controller/rpi/awb.cpp b/src/ipa/rpi/controller/rpi/awb.cpp
>> index f45525bc..c5750c84 100644
>> --- a/src/ipa/rpi/controller/rpi/awb.cpp
>> +++ b/src/ipa/rpi/controller/rpi/awb.cpp
>> @@ -505,7 +505,7 @@ static double interpolateQuadatric(ipa::Pwl::Point const &a, ipa::Pwl::Point con
>>         const double eps = 1e-3;
>>         ipa::Pwl::Point ca = c - a, ba = b - a;
>>         double denominator = 2 * (ba.y() * ca.x() - ca.y() * ba.x());
>> -       if (abs(denominator) > eps) {
>> +       if (fabs(denominator) > eps) {
>>                 double numerator = ba.y() * ca.x() * ca.x() - ca.y() * ba.x() * ba.x();
>>                 double result = numerator / denominator + a.x();
>>                 return std::max(a.x(), std::min(c.x(), result));
>> -- 
>> 2.39.2
>>
Laurent Pinchart Aug. 16, 2024, 2:04 p.m. UTC | #4
On Fri, Aug 16, 2024 at 03:40:45PM +0200, Milan Zamazal wrote:
> Kieran Bingham <kieran.bingham@ideasonboard.com> writes:
> 
> > Hi Maarten,
> >
> > Thank you for highlighting this. I'm curious that it hasn't come up in
> > our builds yet! What version of clang are you using?
> 
> It happens to me too, with clang 18.1.6 on Fedora 40.

I'm very surprised, I tested with clang 18.1.8 locally and didn't see
any error. I would have fixed it already otherwise :-)

> > Quoting Maarten Lankhorst (2024-08-15 10:37:15)
> >> I was getting the following error in clang:
> >> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: error: using integer absolute value function 'abs' when argument is of floating point type [-Werror,-Wabsolute-value]
> >>         if (abs(denominator) > eps) {
> >>             ^
> >> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: note: use function 'std::abs' instead
> >
> > Is there a preference against the recommended std::abs?
> >
> >>         if (abs(denominator) > eps) {
> >>             ^~~
> >>             std::abs
> >> 
> >> Signed-off-by: Maarten Lankhorst <dev@lankhorst.se>
> >> ---
> >>  src/ipa/rpi/controller/rpi/awb.cpp | 2 +-
> >>  1 file changed, 1 insertion(+), 1 deletion(-)
> >> 
> >> diff --git a/src/ipa/rpi/controller/rpi/awb.cpp b/src/ipa/rpi/controller/rpi/awb.cpp
> >> index f45525bc..c5750c84 100644
> >> --- a/src/ipa/rpi/controller/rpi/awb.cpp
> >> +++ b/src/ipa/rpi/controller/rpi/awb.cpp
> >> @@ -505,7 +505,7 @@ static double interpolateQuadatric(ipa::Pwl::Point const &a, ipa::Pwl::Point con
> >>         const double eps = 1e-3;
> >>         ipa::Pwl::Point ca = c - a, ba = b - a;
> >>         double denominator = 2 * (ba.y() * ca.x() - ca.y() * ba.x());
> >> -       if (abs(denominator) > eps) {
> >> +       if (fabs(denominator) > eps) {
> >>                 double numerator = ba.y() * ca.x() * ca.x() - ca.y() * ba.x() * ba.x();
> >>                 double result = numerator / denominator + a.x();
> >>                 return std::max(a.x(), std::min(c.x(), result));
Laurent Pinchart Aug. 17, 2024, 5:34 p.m. UTC | #5
On Fri, Aug 16, 2024 at 05:12:28PM +0200, Milan Zamazal wrote:
> Laurent Pinchart <laurent.pinchart@ideasonboard.com> writes:
> > On Fri, Aug 16, 2024 at 03:40:45PM +0200, Milan Zamazal wrote:
> >> Kieran Bingham <kieran.bingham@ideasonboard.com> writes:
> >> 
> >> > Hi Maarten,
> >> >
> >> > Thank you for highlighting this. I'm curious that it hasn't come up in
> >> > our builds yet! What version of clang are you using?
> >> 
> >> It happens to me too, with clang 18.1.6 on Fedora 40.
> >
> > I'm very surprised, I tested with clang 18.1.8 locally and didn't see
> > any error. I would have fixed it already otherwise :-)
> 
> Interesting.  I checked in another environment with clang 17.0.6 and it
> also reports the error.  Can it perhaps depend on particular C/C++
> header setup/version?  When I ask LSP about `abs' at the given place,
> it points me to the following from stdlib.h:
> 
>   extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur;

Well regardless of where the problem comes from, I think we should fix
it. I'll review a v2 that uses std::abs(), and ideally addresses
alsc.cpp too.

> >> > Quoting Maarten Lankhorst (2024-08-15 10:37:15)
> >> >> I was getting the following error in clang:
> >> >> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: error: using integer absolute value function 'abs' when argument is of floating point type [-Werror,-Wabsolute-value]
> >> >>         if (abs(denominator) > eps) {
> >> >>             ^
> >> >> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: note: use function 'std::abs' instead
> >> >
> >> > Is there a preference against the recommended std::abs?
> >> >
> >> >>         if (abs(denominator) > eps) {
> >> >>             ^~~
> >> >>             std::abs
> >> >> 
> >> >> Signed-off-by: Maarten Lankhorst <dev@lankhorst.se>
> >> >> ---
> >> >>  src/ipa/rpi/controller/rpi/awb.cpp | 2 +-
> >> >>  1 file changed, 1 insertion(+), 1 deletion(-)
> >> >> 
> >> >> diff --git a/src/ipa/rpi/controller/rpi/awb.cpp b/src/ipa/rpi/controller/rpi/awb.cpp
> >> >> index f45525bc..c5750c84 100644
> >> >> --- a/src/ipa/rpi/controller/rpi/awb.cpp
> >> >> +++ b/src/ipa/rpi/controller/rpi/awb.cpp
> >> >> @@ -505,7 +505,7 @@ static double interpolateQuadatric(ipa::Pwl::Point const &a, ipa::Pwl::Point con
> >> >>         const double eps = 1e-3;
> >> >>         ipa::Pwl::Point ca = c - a, ba = b - a;
> >> >>         double denominator = 2 * (ba.y() * ca.x() - ca.y() * ba.x());
> >> >> -       if (abs(denominator) > eps) {
> >> >> +       if (fabs(denominator) > eps) {
> >> >>                 double numerator = ba.y() * ca.x() * ca.x() - ca.y() * ba.x() * ba.x();
> >> >>                 double result = numerator / denominator + a.x();
> >> >>                 return std::max(a.x(), std::min(c.x(), result));
Milan Zamazal Aug. 19, 2024, 7:36 a.m. UTC | #6
Laurent Pinchart <laurent.pinchart@ideasonboard.com> writes:

> On Fri, Aug 16, 2024 at 05:12:28PM +0200, Milan Zamazal wrote:
>> Laurent Pinchart <laurent.pinchart@ideasonboard.com> writes:
>> > On Fri, Aug 16, 2024 at 03:40:45PM +0200, Milan Zamazal wrote:
>
>> >> Kieran Bingham <kieran.bingham@ideasonboard.com> writes:
>> >> 
>> >> > Hi Maarten,
>> >> >
>> >> > Thank you for highlighting this. I'm curious that it hasn't come up in
>> >> > our builds yet! What version of clang are you using?
>> >> 
>> >> It happens to me too, with clang 18.1.6 on Fedora 40.
>> >
>> > I'm very surprised, I tested with clang 18.1.8 locally and didn't see
>> > any error. I would have fixed it already otherwise :-)
>> 
>> Interesting.  I checked in another environment with clang 17.0.6 and it
>> also reports the error.  Can it perhaps depend on particular C/C++
>> header setup/version?  When I ask LSP about `abs' at the given place,
>> it points me to the following from stdlib.h:
>> 
>>   extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur;
>
> Well regardless of where the problem comes from, I think we should fix
> it. 

Definitely.  But it would be interesting to know why it hasn't been
caught by the CI.

> I'll review a v2 that uses std::abs(), and ideally addresses alsc.cpp
> too.

Thank you.

>> >> > Quoting Maarten Lankhorst (2024-08-15 10:37:15)
>> >> >> I was getting the following error in clang:
>> >> >> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: error: using integer absolute value function 'abs' when argument is of floating point type [-Werror,-Wabsolute-value]
>> >> >>         if (abs(denominator) > eps) {
>> >> >>             ^
>> >> >> ../src/ipa/rpi/controller/rpi/awb.cpp:508:6: note: use function 'std::abs' instead
>> >> >
>> >> > Is there a preference against the recommended std::abs?
>> >> >
>> >> >>         if (abs(denominator) > eps) {
>> >> >>             ^~~
>> >> >>             std::abs
>> >> >> 
>> >> >> Signed-off-by: Maarten Lankhorst <dev@lankhorst.se>
>> >> >> ---
>> >> >>  src/ipa/rpi/controller/rpi/awb.cpp | 2 +-
>> >> >>  1 file changed, 1 insertion(+), 1 deletion(-)
>> >> >> 
>> >> >> diff --git a/src/ipa/rpi/controller/rpi/awb.cpp b/src/ipa/rpi/controller/rpi/awb.cpp
>> >> >> index f45525bc..c5750c84 100644
>> >> >> --- a/src/ipa/rpi/controller/rpi/awb.cpp
>> >> >> +++ b/src/ipa/rpi/controller/rpi/awb.cpp
>> >> >> @@ -505,7 +505,7 @@ static double interpolateQuadatric(ipa::Pwl::Point const &a, ipa::Pwl::Point con
>> >> >>         const double eps = 1e-3;
>> >> >>         ipa::Pwl::Point ca = c - a, ba = b - a;
>> >> >>         double denominator = 2 * (ba.y() * ca.x() - ca.y() * ba.x());
>> >> >> -       if (abs(denominator) > eps) {
>> >> >> +       if (fabs(denominator) > eps) {
>> >> >>                 double numerator = ba.y() * ca.x() * ca.x() - ca.y() * ba.x() * ba.x();
>> >> >>                 double result = numerator / denominator + a.x();
>> >> >>                 return std::max(a.x(), std::min(c.x(), result));

Patch
diff mbox series

diff --git a/src/ipa/rpi/controller/rpi/awb.cpp b/src/ipa/rpi/controller/rpi/awb.cpp
index f45525bc..c5750c84 100644
--- a/src/ipa/rpi/controller/rpi/awb.cpp
+++ b/src/ipa/rpi/controller/rpi/awb.cpp
@@ -505,7 +505,7 @@  static double interpolateQuadatric(ipa::Pwl::Point const &a, ipa::Pwl::Point con
 	const double eps = 1e-3;
 	ipa::Pwl::Point ca = c - a, ba = b - a;
 	double denominator = 2 * (ba.y() * ca.x() - ca.y() * ba.x());
-	if (abs(denominator) > eps) {
+	if (fabs(denominator) > eps) {
 		double numerator = ba.y() * ca.x() * ca.x() - ca.y() * ba.x() * ba.x();
 		double result = numerator / denominator + a.x();
 		return std::max(a.x(), std::min(c.x(), result));