<html>
<head>
<style><!--
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 12pt;
font-family:Calibri
}
--></style></head>
<body class='hmmessage'><div dir='ltr'><br><div>> El 29/07/2013, a las 14:54, Heikki Virtanen escribió:<br>> <br>> > Hi, I try to solve an eigenvalue problem (Ax = lambda B x) where A <br>> > and B are complex matrices. Unfortunately, my data structures <br>> > are not capable of handling directly complex numbers, yet. So,<br>> > I have to use <br>> > <br>> > [re(A) -im(A)]<br>> > RealA = [ ]<br>> > [imA) re(A)] <br>> > <br>> > matrices instead. How should I allocate matrices if I know<br>> > compressed sparse row matrix formats of A and B matrices. I have used<br>> > something like this.<br>> > <br>> > ierr = MatCreate(PETSC_COMM_WORLD,&RealA); CHKERRQ(ierr); <br>> > ierr = MatSetSizes(RealA,PETSC_DECIDE,PETSC_DECIDE,2*n,2*n); CHKERRQ(ierr);<br>> > ierr = MatSetType(RealA,MATMPIBAIJ); CHKERRQ(ierr);<br>> > ierr = MatSetBlockSize(RealA,2);CHKERRQ(ierr);<br>> > ierr = MatSetFromOptions(RealA);CHKERRQ(ierr);<br>> > <br>> > ierr = MatMPIBAIJSetPreallocationCSR (RealA,2,rows,cols,0); CHKERRQ(ierr);<br>> > ierr = MatAssemblyBegin (RealA,MAT_FINAL_ASSEMBLY); CHKERRQ(ierr);<br>> > ierr = MatAssemblyEnd (RealA,MAT_FINAL_ASSEMBLY); CHKERRQ(ierr);<br>> > <br>> > where n is the global size of matrix A. rows and cols are csr arrays of A.<br>> > Each submatrix of RealA matrix have the same nonzero pattern than A.<br>> > But I am not sure if this is correct, because when I print my matrices out<br>> > they look more like band matrices than block matrices.<br>> > <br>> > -Heikki<br>> <br>> You are creating a BAIJ matrix with the nonzero pattern defined by (rows,cols), where each entry of the matrix is a 2x2 block, in your case<br>> [ re(a_ij) -im(a_ij) ]<br>> [ im(a_ij) re(a_ij) ]<br>> <br>> So the matrix you are creating is not this one<br>> [re(A) -im(A)]<br>> [imA) re(A)]<br>> but the one resulting from a perfect shuffle permutation. That's why you are not seeing a 2x2 block structure for the whole matrix.<br>> <br>> Jose<br>> <br><br>Hi, Sorry to bother you, but I still have problems with MATMPIBAIJ matrices. It is said here<br><br><a href="http://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Mat/MatCreateBAIJ.html" target="_blank">http://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Mat/MatCreateBAIJ.html</a><br><br>that these matrices are created using block compressed row format. It means this one<br><br><a href="http://www.cs.colostate.edu/~mroberts/toolbox/c++/sparseMatrix/sparse_matrix_compression.html" target="_blank">http://www.cs.colostate.edu/~mroberts/toolbox/c++/sparseMatrix/sparse_matrix_compression.html</a><br><br>or something else? (indices start here from 1 not from 0, but if this is fixed, then the format should be the same?)<br>I have also second question. What does "block size" mean? Is it number of elements per side of the Block?<br><br>-Heikki <br></div> </div></body>
</html>