| Re: [eigen] How to get triangular lower part of a matrix with dev 	branche ? | 
[ Thread Index | 
Date Index
| More lists.tuxfamily.org/eigen Archives
] 
- To: eigen@xxxxxxxxxxxxxxxxxxx
- Subject: Re: [eigen] How to get triangular lower part of a matrix with dev 	branche ?
- From: Benoit Jacob <jacob.benoit.1@xxxxxxxxx>
- Date: Thu, 20 May 2010 08:08:51 -0400
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed;        d=gmail.com; s=gamma;        h=domainkey-signature:mime-version:received:received:in-reply-to         :references:date:message-id:subject:from:to:content-type;        bh=3KV/fC4UoTo08GLDbKpcjxwWtki1XY5yCadUzzXKmc8=;        b=u9qADqSJChuw1mwScIp2QPTKDf21YrdLSxe54C/qeDZoG1X6rEiV3xfeuzq4r+sXtW         xOQ+oUM7iDzCEZH21KFA3/xo81K81l1Lmc8f2c1vFKo6mqH7/vbT5b4WrS1EE+/tJVJK         bGdE5lJqfTdShQCcbXqvMrV7RQc23RglGVHTI=
- Domainkey-signature: a=rsa-sha1; c=nofws;        d=gmail.com; s=gamma;        h=mime-version:in-reply-to:references:date:message-id:subject:from:to         :content-type;        b=ayB99TfwnkMpYx6tzhQIn3MZ0KLHehWRqphABi39QtCPOdzGI6KQ2j/Gpd1E7zly9V         wPS9UttiAC9k4iWLg1DY6LN9EjbYmJhamwdSTpQcOnWNYji12BMRD5wRxMw8b9RqPjq1         fGv7uzE3j9ph6gReCOTZaNQAXpkroVgyd1gGg=
Fun coincidence: the problem you were hitting was exaclty issue A2 in
the link that Hauke just sent to this list (see thread "very
interesting...").
You can't bind a ref-to-non-const to a temporary.
The solution in your case is to make that temporary a named variable.
Not any more inefficient than what you were trying to do.
See attached file.
Benoit
2010/5/20  <vincent.lejeune@xxxxxxxxxx>:
>
> Of course :
>
>
>
> #include <QR.h>
>
> using namespace Eigen;
>
>
>
> typedef  Matrix<double,4,4> MAT;
>
> typedef  Matrix<double,4,1> VECT;
>
>
>
>  template<typename MatrixType>
>
>  MatrixType triangfactor(MatrixType& V,
>
>      Matrix<typename MatrixType::Scalar,MatrixType::RowsAtCompileTime,1>&
>
> coeffs)
>
>  {
>
>    typedef typename MatrixType::Scalar Scalar;
>
>    const int k=coeffs.size();
>
>
>
>    ei_assert(V.cols()==k && V.rows()>=k && "Vector storing Matrix must
>
> have same columns than coeffs size and more rows than columns");
>
>
>
>
>
>    MatrixType ret=MatrixType::Zero(k,k);
>
>    const int j=k;
>
>
>
>    for(int i=0;i<k;i++)
>
>    {
>
>      Scalar Vii=V(i,i);
>
>      V(i,i)=1;
>
>      ret.block(0,i,i,1) = - coeffs(i,0) * V.block(i,0,j-i,i).transpose()
>
> * V.block(i,i,j-i,1);
>
>      V(i,i)=Vii;
>
>      ret.block(0,i,i,1)=ret.block(0,0,i,i)*ret.block(0,i,i,1);
>
>      ret(i,i)=coeffs(i,0);
>
>    }
>
>    return ret;
>
>  }
>
>
>
> int main()
>
> {
>
>  MAT mat=MAT::Random();
>
>  VECT vect=VECT::Random();
>
>  MAT tst=triangfactor(MAT(mat.triangularView<Lower>()),vect);
>
>  cout<<tst<<endl<<endl;
>
>
>
>  return 0;
>
> }
>
>
>
>
>
>
>
>
>
>
>
> On Thu, 20 May 2010 07:16:26 -0400, Benoit Jacob
>
> <jacob.benoit.1@xxxxxxxxx>
>
> wrote:
>
>> 2010/5/20  <vincent.lejeune@xxxxxxxxxx>:
>
>>>
>
>>> Hi,
>
>>>
>
>>>
>
>>>
>
>>> I'm trying to get the lower triangular part of a (non-square) matrix,
>
> but
>
>>>
>
>>> it seems that the part() function is deprecated in Eigen 2.91.
>
>>>
>
>>> Using mat.triangularView<Lower>(), I meet the following compile error :
>
>>
>
>> Sounds like  a bug. Can you send us a test program reproducing it?
>
>>
>
>> Benoit
>
>>
>
>>
>
>>>
>
>>>
>
>>>
>
>>> error: invalid initialization of non-const reference of type
>
>>>
>
>>> ‘Eigen::TriangularView<Eigen::Matrix<double, 4, 4, 0, 4, 4>, 1u>&’ from
>
>>> a
>
>>>
>
>>> temporary of type ‘Eigen::TriangularView<Eigen::Matrix<double, 4, 4, 0,
>
>>> 4,
>
>>>
>
>>> 4>, 1u>’
>
>>>
>
>>>
>
>>>
>
>>> That I do not really understand...
>
>>>
>
>>>
>
>>>
>
>>> Thx
>
>>>
>
>>>
>
>>>
>
>
>
#include<iostream>
#include <Eigen/QR>
using namespace std;
using namespace Eigen;
typedef  Matrix<double,4,4> MAT;
typedef  Matrix<double,4,1> VECT;
 template<typename MatrixType>
 MatrixType triangfactor(MatrixType& V,
     Matrix<typename MatrixType::Scalar,MatrixType::RowsAtCompileTime,1>&
coeffs)
 {
   typedef typename MatrixType::Scalar Scalar;
   const int k=coeffs.size();
   ei_assert(V.cols()==k && V.rows()>=k && "Vector storing Matrix must\
 have same columns than coeffs size and\
 more rows than columns");
   MatrixType ret=MatrixType::Zero(k,k);
   const int j=k;
   for(int i=0;i<k;i++)
   {
     Scalar Vii=V(i,i);
     V(i,i)=1;
     ret.block(0,i,i,1) = - coeffs(i,0) * V.block(i,0,j-i,i).transpose()
* V.block(i,i,j-i,1);
     V(i,i)=Vii;
     ret.block(0,i,i,1)=ret.block(0,0,i,i)*ret.block(0,i,i,1);
     ret(i,i)=coeffs(i,0);
   }
   return ret;
 }
int main()
{
 MAT mat=MAT::Random();
 VECT vect=VECT::Random();
 MAT tmp(mat.triangularView<Lower>());
 MAT tst=triangfactor(tmp,vect);
 cout<<tst<<endl<<endl;
 return 0;
}