<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML><HEAD>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<META content="MSHTML 6.00.6000.17080" name=GENERATOR>
<STYLE>@font-face {
        font-family: ËÎÌå;
}
@font-face {
        font-family: Verdana;
}
@font-face {
        font-family: @ËÎÌå;
}
@page Section1 {size: 595.3pt 841.9pt; margin: 72.0pt 90.0pt 72.0pt 90.0pt; layout-grid: 15.6pt; }
P.MsoNormal {
        TEXT-JUSTIFY: inter-ideograph; FONT-SIZE: 10.5pt; MARGIN: 0cm 0cm 0pt; FONT-FAMILY: "Times New Roman"; TEXT-ALIGN: justify
}
LI.MsoNormal {
        TEXT-JUSTIFY: inter-ideograph; FONT-SIZE: 10.5pt; MARGIN: 0cm 0cm 0pt; FONT-FAMILY: "Times New Roman"; TEXT-ALIGN: justify
}
DIV.MsoNormal {
        TEXT-JUSTIFY: inter-ideograph; FONT-SIZE: 10.5pt; MARGIN: 0cm 0cm 0pt; FONT-FAMILY: "Times New Roman"; TEXT-ALIGN: justify
}
A:link {
        COLOR: blue; TEXT-DECORATION: underline
}
SPAN.MsoHyperlink {
        COLOR: blue; TEXT-DECORATION: underline
}
A:visited {
        COLOR: purple; TEXT-DECORATION: underline
}
SPAN.MsoHyperlinkFollowed {
        COLOR: purple; TEXT-DECORATION: underline
}
SPAN.EmailStyle17 {
        FONT-WEIGHT: normal; COLOR: windowtext; FONT-STYLE: normal; FONT-FAMILY: Verdana; TEXT-DECORATION: none; mso-style-type: personal-compose
}
DIV.Section1 {
        page: Section1
}
UNKNOWN {
        FONT-SIZE: 10pt
}
BLOCKQUOTE {
        MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px; MARGIN-LEFT: 2em
}
OL {
        MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px
}
UL {
        MARGIN-TOP: 0px; MARGIN-BOTTOM: 0px
}
</STYLE>
</HEAD>
<BODY style="FONT-SIZE: 10pt; MARGIN: 10px; FONT-FAMILY: verdana">
<DIV><FONT face=Verdana size=2>&gt;Message:&nbsp;8</DIV>
<DIV>
<DIV>&gt;Date:&nbsp;Sat,&nbsp;3&nbsp;Dec&nbsp;2011&nbsp;09:24:10&nbsp;+0800</DIV>
<DIV>&gt;From:&nbsp;"Feng-Chao&nbsp;Wang"&nbsp;&lt;wolfshow@gmail.com&gt;</DIV>
<DIV>&gt;Subject:&nbsp;Re:&nbsp;[petsc-users]&nbsp;How&nbsp;to&nbsp;output&nbsp;the&nbsp;values&nbsp;of&nbsp;a&nbsp;parallel</DIV>
<DIV>&gt;PETSc vector&nbsp;to&nbsp;a&nbsp;ASCII&nbsp;file</DIV>
<DIV>&gt;To:&nbsp;"petsc-users"&nbsp;&lt;petsc-users@mcs.anl.gov&gt;</DIV>
<DIV>&gt;Message-ID:&nbsp;&lt;201112030924087476065@gmail.com&gt;</DIV>
<DIV>&gt;Content-Type:&nbsp;text/plain;&nbsp;charset="gb2312"</DIV>
<DIV></DIV>
<DIV>&gt;Date:&nbsp;Fri,&nbsp;2&nbsp;Dec&nbsp;2011&nbsp;08:07:54&nbsp;-0600</DIV>
<DIV>&gt;From:&nbsp;Jed&nbsp;Brown&nbsp;&lt;jedbrown@mcs.anl.gov&gt;</DIV>
<DIV>&gt;Subject:&nbsp;Re:&nbsp;[petsc-users]&nbsp;How&nbsp;to&nbsp;output&nbsp;the&nbsp;values&nbsp;of&nbsp;a&nbsp;parallel</DIV>
<DIV>&gt;PETSc&nbsp;vector&nbsp;to&nbsp;a&nbsp;ASCII&nbsp;file</DIV>
<DIV>&gt;To:&nbsp;PETSc&nbsp;users&nbsp;list&nbsp;&lt;petsc-users@mcs.anl.gov&gt;</DIV>
<DIV>&gt;Message-ID:</DIV>
<DIV>&lt;CAM9tzSkSeN3Z11vdadF66XTe_KVbUo-eA=2hvAgROFkTJfsYZg@mail.gmail.com&gt;</DIV>
<DIV>&gt;Content-Type:&nbsp;text/plain;&nbsp;charset="utf-8"</DIV>
<DIV>&gt;On&nbsp;Fri,&nbsp;Dec&nbsp;2,&nbsp;2011&nbsp;at&nbsp;08:04,&nbsp;Feng-Chao&nbsp;Wang&nbsp;&lt;wolfshow@gmail.com&gt;&nbsp;wrote:</DIV>
<DIV>&gt;&nbsp;**</DIV>
<DIV>&gt;&nbsp;Dear&nbsp;all,</DIV>
<DIV>&gt;</DIV>
<DIV>&gt;&nbsp;I&nbsp;intend&nbsp;to&nbsp;postprocess&nbsp;the&nbsp;solution&nbsp;of&nbsp;a&nbsp;PDE&nbsp;(stored&nbsp;in&nbsp;a</DIV>
<DIV>&gt;&nbsp;parallel&nbsp;PETSc&nbsp;vector&nbsp;)&nbsp;using&nbsp;tecplot.&nbsp;Thus&nbsp;I&nbsp;want&nbsp;to&nbsp;&nbsp;output&nbsp;the&nbsp;values&nbsp;of</DIV>
<DIV>&gt;&nbsp;the&nbsp;parallel&nbsp;vector&nbsp;as&nbsp;well&nbsp;as&nbsp;other&nbsp;data&nbsp;(such&nbsp;as&nbsp;the&nbsp;grid&nbsp;information)&nbsp;to</DIV>
<DIV>&gt;&nbsp;a&nbsp;ASCII&nbsp;file.</DIV>
<DIV>&gt;</DIV>
<DIV>&gt;&nbsp;When&nbsp;I&nbsp;deal&nbsp;this&nbsp;with</DIV>
<DIV>&gt;</DIV>
<DIV>&gt;&nbsp;VecGetArray(U,&nbsp;&amp;u);</DIV>
<DIV>&gt;</DIV>
<DIV>&gt;&nbsp;for&nbsp;(i=0;&nbsp;i&lt;Mx*My;&nbsp;i++)</DIV>
<DIV>&gt;&nbsp;{</DIV>
<DIV>&gt;&nbsp;PetscViewerASCIIPrintf(viewer,"%F&nbsp;%F&nbsp;%F",&nbsp;x,&nbsp;y,&nbsp;u[i]);</DIV>
<DIV>&gt;&nbsp;}</DIV>
<DIV>&gt;</DIV>
<DIV>&gt;&nbsp;If&nbsp;more&nbsp;than&nbsp;1&nbsp;processor&nbsp;are&nbsp;used,&nbsp;I&nbsp;found&nbsp;that&nbsp;only&nbsp;part&nbsp;of&nbsp;the&nbsp;value&nbsp;of</DIV>
<DIV>&gt;&nbsp;u&nbsp;was&nbsp;output&nbsp;correctly&nbsp;(that&nbsp;stored&nbsp;on&nbsp;the&nbsp;first&nbsp;processor).</DIV>
<DIV>&gt;&nbsp;I&nbsp;found&nbsp;in&nbsp;the&nbsp;manual&nbsp;page&nbsp;of&nbsp;"PetscViewerASCIIPrintf"&nbsp;that&nbsp;"Not</DIV>
<DIV>&gt;&nbsp;Collective,&nbsp;but&nbsp;only&nbsp;first&nbsp;processor&nbsp;in&nbsp;set&nbsp;has&nbsp;any&nbsp;effect"</DIV>
<DIV>&gt;</DIV>
<DIV>&gt;If&nbsp;you&nbsp;can&nbsp;afford&nbsp;the&nbsp;memory:</DIV>
<DIV>&gt;http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Vec/VecScatterCreateToZero.html</DIV>
<DIV></DIV>
<DIV>Thank&nbsp;you&nbsp;very&nbsp;much!</DIV>
<DIV>I&nbsp;tried&nbsp;the&nbsp;Scatter&nbsp;method.&nbsp;I&nbsp;found&nbsp;that&nbsp;even&nbsp;I&nbsp;scatter&nbsp;the&nbsp;parallel&nbsp;vector&nbsp;to&nbsp;a&nbsp;sequential&nbsp;vector,&nbsp;when&nbsp;I&nbsp;want&nbsp;to&nbsp;output&nbsp;this&nbsp;sequential&nbsp;vector&nbsp;to&nbsp;the&nbsp;file,&nbsp;I&nbsp;still&nbsp;can&nbsp;not&nbsp;use&nbsp;"PetscViewerASCIIPrintf(viewer,"%F&nbsp;%F&nbsp;%F",&nbsp;x,&nbsp;y,&nbsp;u[i]);",&nbsp;because&nbsp;the&nbsp;vector&nbsp;can&nbsp;not&nbsp;be&nbsp;directly&nbsp;accessed&nbsp;for&nbsp;output?</DIV>
<DIV></DIV>
<DIV>&nbsp;Thus&nbsp;I&nbsp;used&nbsp;VecGetArray(U,&nbsp;&amp;u);&nbsp;and&nbsp;then&nbsp;PetscViewerASCIIPrintf.&nbsp;I&nbsp;still&nbsp;got&nbsp;part&nbsp;of&nbsp;the&nbsp;sequential&nbsp;vector,&nbsp;because&nbsp;the&nbsp;array&nbsp;u&nbsp;is&nbsp;stored&nbsp;on&nbsp;all&nbsp;the&nbsp;processor?</DIV>
<DIV>&nbsp;</DIV>
<DIV>&nbsp;</DIV>
<DIV><STRONG>Sorry, I think I made a mistake.</STRONG></DIV>
<DIV><STRONG></STRONG>&nbsp;</DIV>
<DIV><STRONG>After 
I&nbsp;&nbsp;scatter&nbsp;the&nbsp;parallel&nbsp;vector&nbsp;to&nbsp;a&nbsp;sequential&nbsp;vector 
and then use VecGetArray(U,&nbsp;&amp;u); and then output the u[i] to the file. 
I got the correct output. </STRONG></DIV>
<DIV><STRONG></STRONG>&nbsp;</DIV>
<DIV><STRONG>Thank Jed&nbsp;Brown and Matthew&nbsp;Knepley very much for the 
reply.</STRONG></DIV>
<DIV>&nbsp;</DIV>
<DIV></DIV>
<DIV>&gt;Slower:</DIV>
<DIV>&gt;http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Sys/PetscSynchronizedPrintf.html</DIV>
<DIV></DIV>
<DIV>I&nbsp;tried&nbsp;the&nbsp;PetscSynchronizedPrintf&nbsp;and&nbsp;got&nbsp;the&nbsp;same&nbsp;result.&nbsp;As&nbsp;a&nbsp;beginner&nbsp;of&nbsp;PETSc,&nbsp;I&nbsp;wonder&nbsp;if&nbsp;I&nbsp;can&nbsp;output&nbsp;the&nbsp;value&nbsp;of&nbsp;a&nbsp;vector&nbsp;U&nbsp;to&nbsp;the&nbsp;ASCII&nbsp;file&nbsp;using&nbsp;Printf("%f",&nbsp;U[i])?&nbsp;</DIV>
<DIV>If&nbsp;so,&nbsp;I&nbsp;can&nbsp;get&nbsp;the&nbsp;result&nbsp;I&nbsp;want.</DIV>
<DIV></DIV>
<DIV>Or,&nbsp;I&nbsp;must&nbsp;use&nbsp;VecGetArray(U,&nbsp;&amp;u);&nbsp;before&nbsp;I&nbsp;want&nbsp;to&nbsp;access&nbsp;the&nbsp;data&nbsp;stored&nbsp;in&nbsp;the&nbsp;vector?</DIV>
<DIV></DIV>
<DIV>Thank&nbsp;you!</DIV>
<DIV></DIV>
<DIV>&gt;Binary&nbsp;output&nbsp;can&nbsp;be&nbsp;written&nbsp;in&nbsp;parallel&nbsp;using</DIV>
<DIV>&gt;http://www.mcs.anl.gov/petsc/petsc-dev/docs/manualpages/Vec/VecView.html</DIV>
<DIV></DIV>
<DIV>Yes,&nbsp;the&nbsp;VecView&nbsp;can&nbsp;output&nbsp;the&nbsp;correct&nbsp;data&nbsp;stored&nbsp;in&nbsp;the&nbsp;parallel&nbsp;vector&nbsp;to&nbsp;a&nbsp;ASCII&nbsp;file.&nbsp;However,&nbsp;I&nbsp;want&nbsp;to&nbsp;output&nbsp;not&nbsp;only&nbsp;the&nbsp;vector&nbsp;value&nbsp;but&nbsp;also&nbsp;the&nbsp;grid&nbsp;information&nbsp;according&nbsp;to&nbsp;the&nbsp;tecplot&nbsp;file&nbsp;format,&nbsp;for&nbsp;example,&nbsp;there&nbsp;are&nbsp;three&nbsp;column&nbsp;of&nbsp;data&nbsp;in&nbsp;one&nbsp;file:</DIV>
<DIV></DIV>
<DIV>x[0]&nbsp;y[0]&nbsp;vec_value[0]</DIV>
<DIV>x[1]&nbsp;y[1]&nbsp;vec_value[1]</DIV>
<DIV>x[2]&nbsp;y[2]&nbsp;vec_value[2]</DIV>
<DIV>x[3]&nbsp;y[3]&nbsp;vec_value[3]</DIV>
<DIV>x[4]&nbsp;y[4]&nbsp;vec_value[4]</DIV>
<DIV>x[5]&nbsp;y[5]&nbsp;vec_value[5]</DIV>
<DIV>...&nbsp;&nbsp;&nbsp;...&nbsp;&nbsp;&nbsp;&nbsp;...</DIV>
<DIV></DIV>
<DIV></DIV>
<DIV></DIV>
<DIV>******************************************</DIV>
<DIV>--------------&nbsp;next&nbsp;part&nbsp;--------------</DIV>
<DIV>An&nbsp;HTML&nbsp;attachment&nbsp;was&nbsp;scrubbed...</DIV>
<DIV>URL:&nbsp;&lt;http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20111203/c22bd550/attachment.htm&gt;</DIV>
<DIV></DIV>
<DIV>------------------------------</DIV>
<DIV></DIV>
<DIV>_______________________________________________</DIV>
<DIV>petsc-users&nbsp;mailing&nbsp;list</DIV>
<DIV>petsc-users@mcs.anl.gov</DIV>
<DIV>https://lists.mcs.anl.gov/mailman/listinfo/petsc-users</DIV>
<DIV></DIV>
<DIV></DIV>
<DIV>End&nbsp;of&nbsp;petsc-users&nbsp;Digest,&nbsp;Vol&nbsp;36,&nbsp;Issue&nbsp;13</DIV>
<DIV>*******************************************</DIV></FONT></DIV></BODY></HTML>