Boost logo

Ublas :

Subject: [ublas] Fwd: Bug in 1.59 in file boost/numeric/ublas/detail/concepts.hpp
From: dariomt_at_[hidden]
Date: 2015-12-01 03:50:44


Corss-posting to ublas list:

To me it seems that the regression was introduced in commit
https://github.com/uBLAS/ublas/commit/d6e77ccdf47d8f9f7935f576b820cdb25263b95a

Regards!

---------- Forwarded message ----------
From: <dariomt_at_[hidden]>
Date: 2015-11-30 15:24 GMT+01:00
Subject: [Ublas] Bug in 1.59 in file boost/numeric/ublas/detail/concepts.hpp
To: boost-users_at_[hidden]

In the migration from Boost 1.55.0 to 1.59.0 I found a bug in Ublas.

For instance, in 1.55.0 function OneElement() declared in
boost/numeric/ublas/detail/concepts.hpp line 716 looks like this:

template<> double OneElement (double) { return 1.; }

However, in 1.59.0 I think there is a copy'n'paste typo, because the
corresponding function (which has been refactored) looks like this:

template<class T> T OneElement (T) { return T(0.0); }

Please note that the latter version returns a *zero*, instead of a *one*.

This same bug affects the vector overload of the function, but the matrix
version looks correct (it returns identity_matrix).

This looks like a copy'n'paste typo, from a similar function
called ZeroElement(), that, of course, returns a zero.

I'm not sure if there is time to get a fix for this in the 1.60 release...

Regards!