<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'>Thanks, I will write the stand alone code for it. One more question about the global and local vector below.<br><br><div>> Subject: Re: [petsc-users] local Vec to global Vec and global 3-D array<br>> From: bsmith@mcs.anl.gov<br>> Date: Wed, 15 May 2013 14:09:42 -0500<br>> To: pengxwang@hotmail.com; petsc-users@mcs.anl.gov<br>> <br>> <br>> On May 15, 2013, at 12:41 PM, Roc Wang <pengxwang@hotmail.com> wrote:<br>> <br>> > Thanks, please take a look my further questions. <br>> > <br>> > > Subject: Re: [petsc-users] local Vec to global Vec and global 3-D array<br>> > > From: bsmith@mcs.anl.gov<br>> > > Date: Wed, 15 May 2013 11:40:03 -0500<br>> > > CC: petsc-users@mcs.anl.gov<br>> > > To: pengxwang@hotmail.com<br>> > > <br>> > > <br>> > > On May 15, 2013, at 10:19 AM, Roc Wang <pengxwang@hotmail.com> wrote:<br>> > > <br>> > > > Hello, <br>> > > > <br>> > > > 1. I am trying to save the solution of a PDE for a 3-D geometry domain. I used DM to manage the matrix and vector.<br>> > > > The solution vector was converted to local 3D arrays on each process successfully. But there was errors when the functions DMLocalToGlobalBegin() and DMLocalToGlobalEnd() were called.<br>> > > > <br>> > > > I built the code by following the example in /petsc-3.3-p6/src/dm/examples/tutorials/ex3.c. The codes for this are as followings :<br>> > > > <br>> > > > /*Get the solution vec */<br>> > > > ierr = KSPSolve(ksp,PETSC_NULL,PETSC_NULL);CHKERRQ(ierr);<br>> > > > ierr = KSPGetSolution(ksp,&x);CHKERRQ(ierr);<br>> > > > <br>> > > > /* local 3d arrays */ <br>> > > > ierr = DMDAVecGetArray(da, x, &localArray3d ); CHKERRQ(ierr);<br>> > > > <br>> > > > /* global 3d array */ <br>> > > > ierr = DMCreateGlobalVector(da,&gsol3d);CHKERRQ(ierr);<br>> > > > ierr = DMLocalToGlobalBegin(da,x,INSERT_VALUES,gsol3d);CHKERRQ(ierr);<br>> > > > ierr = DMLocalToGlobalEnd(da,x,INSERT_VALUES,gsol3d);CHKERRQ(ierr);<br>> > > <br>> > > The x here must not have been obtained from this da. You need to have obtained the x somewhere before with DMCreateLocalVector(da,&x) or with a VecDuplicate from such a vector. Likely the vector put into the KSP is not from this da.<br>> > <br>> > !***************************************<br>> > The procedure of creating x is like this:<br>> > <br>> > call KSPCreate() to build ksp;<br>> > call DMDACreate3d() to build da;<br>> > ierr = KSPSetDM(ksp,da); // associate da with ksp;<br>> > <br>> > Then after ksp was solved:<br>> > <br>> > ierr = KSPSolve(ksp,PETSC_NULL,PETSC_NULL);CHKERRQ(ierr);<br>> > ierr = KSPGetSolution(ksp,&x);CHKERRQ(ierr);<br>> > ierr = DMDAVecGetArray(da, x, &localArray3d ); CHKERRQ(ierr);<br>> > <br>> > Here, da was associated with the ksp by calling ierr = KSPSetDM(ksp,da).<br>> > The x here was obtained by calling the KSPGetSolution(ksp,&x), before this I didn't call DMCreateLocalVector(da,&x). It seems Vec x is associated with da since there is no errors when DMDAVecGetArray(da, x, &localArray3d ) was called. <br>> <br>> The x from KSPGetSolution() IS a global vector, it is not a global vector. You cannot do a local to global from the x global vector.<br><br>!*******************************<br>The x from KSPGetSolution() IS a global vector, it is not a "local" vector? (It should be a typo :) )<br> So Can I convert the global x to a 3d array directly? Thank. <br><br>> <br>> > Do you mean I should call DMCreateLocalVector(da,&x) explicitly before ierr = KSPGetSolution(ksp,&x)?<br>> > !***************************************<br>> > <br>> > > > <br>> > > > <br>> > > > 2. I am trying to visualize the solution in a 3-D domain by using some software such as Tecplot. To my understand, I need to output the solution in the format of 3-D array. The vectors of KSP solution in PETSc are local vectors on each process. So they have to be assembled to a global vector and then converted to a 3-D global array. I am not sure if my approach is a good way and if there is some functions in PETSc to output the global solutions directly?<br>> > > <br>> > > Yes. VecView() on DMDA vectors automatically reorders the entries on the file to use the natural ordering. There are variety of possible viewers you can use including binary, ASCII (no good for anything but tiny problems), VTK, HDF5 <br>> > <br>> > !***************************************<br>> > VecView only outputs the vector itself. How to output the indexes of nodes in 3 dimemsions (i,j,k) for each element of the vector, such as:<br>> > <br>> > i j k x<br>> > 0 0 0 1.0<br>> > 0 0 1 2.0<br>> > ...<br>> > m n p 10.0<br>> > !***************************************<br>> <br>> If you want some ASCII format like that, then write a STAND ALONE sequential program that reads from the binary file with VecLoad() and then outputs the format you want. Never Never ever try to do a parallel output of data in this kind of format, it will be slow and hard to write and there is no reason to write it.<br>> <br>> Barry<br>> <br>> > > <br>> > > Barry<br>> > > <br>> > > > <br>> > > > Part of the error information when DMLocalToGlobalBegin() and DMLocalToGlobalEnd() were called <br>> > > > <br>> > > > [0]PETSC ERROR: [1]PETSC ERROR: [2]PETSC ERROR: --------------------- Error Message ------------------------------------<br>> > > > [3]PETSC ERROR: --------------------- Error Message ------------------------------------<br>> > > > [2]PETSC ERROR: [3]PETSC ERROR: --------------------- Error Message ------------------------------------<br>> > > > Nonconforming object sizes!<br>> > > > Nonconforming object sizes!<br>> > > > [2]PETSC ERROR: [3]PETSC ERROR: Vector wrong size 30 for scatter 60 (scatter forward and vector from != ctx from size)!<br>> > > > Vector wrong size 20 for scatter 45 (scatter forward and vector from != ctx from size)!<br>> > ><br>> <br></div> </div></body>
</html>