<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<style type="text/css" style="display:none;"> P {margin-top:0;margin-bottom:0;} </style>
</head>
<body dir="ltr">
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Hi <font size="2"><span style="font-size:11pt">Berend</span></font>,</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<font size="2"><span style="font-size:11pt">DMPlexCreateFromfile</span></font>(), in your case, internally calls DMLoad(), which calls DMPlexTopologyLoad(), DMPlexLabelsLoad(), and DMPlexCoordinatesLoad(), so, to get what you want, you would need to do something
like:</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
DMPlexTopologyView(dm, viewer);</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
DMPlexLabelsView(dm, viewer);</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
DMPlexCoordinatesView(dm, viewer);</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
for saving, and:</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
DMPlexTopologyLoad(dm, viewer, <font size="2"><span style="font-size:11pt">&sfO</span></font>);<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
DMPlexLabelsLoad(dm, viewer);</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
DMPlexCoordinatesLoad(dm, viewer);<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
DMPlexDistribute(..., &sfDist, ...);<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
for loading.<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Please note that the interface for DMPlexCoordinatesLoad() may change in the near future so that it would take an SF as argument (This is to view coordinates just like other fields). After the change, you will need to do:<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<span style="font-size:12pt">DMPlexTopologyLoad(dm, viewer, <font size="2"><span style="font-size:11pt">&sfO</span></font>);</span>
<div style="font-size:12pt">DMPlexLabelsLoad(dm, viewer);</div>
<div style="font-size:12pt">DMPlexCoordinatesLoad(dm, viewer, sfO);<br>
</div>
<span style="font-size:12pt">DMPlexDistribute(..., &sfDist, ...);</span><br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
or:<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<span style="font-size:12pt">DMPlexTopologyLoad(dm, viewer, <font size="2"><span style="font-size:11pt">&sfO</span></font>);</span>
<div style="font-size:12pt">DMPlexLabelsLoad(dm, viewer);<span style="font-size:12pt"><br>
</span></div>
<span style="font-size:12pt">DMPlexDistribute(..., &sfDist, ...);<span style="font-size:12pt"></span></span></div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<span style="font-size:12pt"><span style="font-size:12pt">PetscSFCompose(sfO, sfDist, &sf);</span></span></div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<span style="font-size:12pt"><span style="font-size:12pt">DMPlexCoordinatesLoad(..., viewer, sf);</span></span><br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
The latter will load coordinates in parallel directly on the redistributed DMPlex, so will be preferred.<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
The example (`src/dm/impls/plex/tutorials/ex12.c`) will also be updated accordingly.<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
<br>
</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Thanks,</div>
<div style="font-family: Calibri, Arial, Helvetica, sans-serif; font-size: 12pt; color: rgb(0, 0, 0);">
Koki<br>
</div>
<div id="appendonsend"></div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> petsc-users <petsc-users-bounces@mcs.anl.gov> on behalf of Berend van Wachem <berend.vanwachem@ovgu.de><br>
<b>Sent:</b> Thursday, September 30, 2021 12:02 PM<br>
<b>To:</b> Hapla Vaclav <vaclav.hapla@erdw.ethz.ch><br>
<b>Cc:</b> PETSc users list <petsc-users@mcs.anl.gov><br>
<b>Subject:</b> Re: [petsc-users] DMView and DMLoad</font>
<div> </div>
</div>
<div class="BodyFragment"><font size="2"><span style="font-size:11pt;">
<div class="PlainText"><br>
*******************<br>
This email originates from outside Imperial. Do not click on links and attachments unless you recognise the sender.
<br>
If you trust the sender, add them to your safe senders list <a href="https://spam.ic.ac.uk/SpamConsole/Senders.aspx">
https://spam.ic.ac.uk/SpamConsole/Senders.aspx</a> to disable email stamping for this address.<br>
*******************<br>
Dear Vaclav, Lawrence,<br>
<br>
following your example, we have managed to save the DM with a wrapped <br>
Vector in h5 format (PETSC_VIEWER_HDF5_PETSC) with:<br>
<br>
DMPlexTopologyView(dm, viewer);<br>
DMClone(dm, &sdm);<br>
...<br>
DMPlexSectionView(dm, viewer, sdm);<br>
DMGetLocalVector(sdm, &vec);<br>
...<br>
DMPlexLocalVectorView(dm, viewer, sdm, vec);<br>
<br>
The problem comes with the loading of the "DM+Vec.h5" with:<br>
<br>
DMCreate(PETSC_COMM_WORLD, &dm);<br>
DMSetType(dm, DMPLEX);<br>
...<br>
DMPlexTopologyLoad(dm, viewer, &sfO);<br>
...<br>
PetscSFCompose(sfO, sfDist, &sf);<br>
...<br>
DMClone(dm, &sdm);<br>
DMPlexSectionLoad(dm, viewer, sdm, sf, &globalDataSF, &localDataSF);<br>
DMGetLocalVector(sdm, &vec);<br>
...<br>
DMPlexLocalVectorLoad(dm, H5Viewer, sdm, localDataSF, vec);<br>
<br>
The loaded DM is different to the one created with DMPlexCreateFromfile <br>
(for instance, no "coordinates" are recovered with the use of <br>
DMGetCoordinatesLocal). This conflicts with our code, which relies on <br>
features of the DM as delivered by the DMPlexCreateFromfile function.<br>
<br>
We have also noticed that the "DM+Vec.h5" can not be loaded directly <br>
with DMPlexCreateFromfile because it contains only the groups "topology" <br>
and "topologies" while the groups "geometry" and "labels" are missing <br>
(and probably other conflicts).<br>
<br>
Is this something which can be changed? We would need to reload a DM <br>
similar to the one created with DMPlexCreateFromfile.<br>
<br>
Best regards,<br>
<br>
Berend.<br>
<br>
<br>
<br>
On 9/22/21 8:59 PM, Hapla Vaclav wrote:<br>
> To avoid confusions here, Berend seems to be specifically demanding XDMF <br>
> (PETSC_VIEWER_HDF5_XDMF). The stuff we are now working on is parallel <br>
> checkpointing in our own HDF5 format (PETSC_VIEWER_HDF5_PETSC), I will <br>
> make a series of MRs on this topic in the following days.<br>
> <br>
> For XDMF, we are specifically missing the ability to write/load DMLabels <br>
> properly. XDMF uses specific cell-local numbering for faces for <br>
> specification of face sets, and face-local numbering for specification <br>
> of edge sets, which is not great wrt DMPlex design. And ParaView doesn't <br>
> show any of these properly so it's hard to debug. Matt, we should talk <br>
> about this soon.<br>
> <br>
> Berend, for now, could you just load the mesh initially from XDMF and <br>
> then use our PETSC_VIEWER_HDF5_PETSC format for subsequent saving/loading?<br>
> <br>
> Thanks,<br>
> <br>
> Vaclav<br>
> <br>
>> On 17 Sep 2021, at 15:46, Lawrence Mitchell <wence@gmx.li <br>
>> <<a href="mailto:wence@gmx.li">mailto:wence@gmx.li</a>>> wrote:<br>
>><br>
>> Hi Berend,<br>
>><br>
>>> On 14 Sep 2021, at 12:23, Matthew Knepley <knepley@gmail.com <br>
>>> <<a href="mailto:knepley@gmail.com">mailto:knepley@gmail.com</a>>> wrote:<br>
>>><br>
>>> On Tue, Sep 14, 2021 at 5:15 AM Berend van Wachem <br>
>>> <berend.vanwachem@ovgu.de <<a href="mailto:berend.vanwachem@ovgu.de">mailto:berend.vanwachem@ovgu.de</a>>> wrote:<br>
>>> Dear PETSc-team,<br>
>>><br>
>>> We are trying to save and load distributed DMPlex and its associated<br>
>>> physical fields (created with DMCreateGlobalVector) (Uvelocity,<br>
>>> VVelocity, ...) in HDF5_XDMF format. To achieve this, we do the <br>
>>> following:<br>
>>><br>
>>> 1) save in the same xdmf.h5 file:<br>
>>> DMView( DM , H5_XDMF_Viewer );<br>
>>> VecView( UVelocity, H5_XDMF_Viewer );<br>
>>><br>
>>> 2) load the dm:<br>
>>> DMPlexCreateFromfile(PETSC_COMM_WORLD, Filename, PETSC_TRUE, DM);<br>
>>><br>
>>> 3) load the physical field:<br>
>>> VecLoad( UVelocity, H5_XDMF_Viewer );<br>
>>><br>
>>> There are no errors in the execution, but the loaded DM is distributed<br>
>>> differently to the original one, which results in the incorrect<br>
>>> placement of the values of the physical fields (UVelocity etc.) in the<br>
>>> domain.<br>
>>><br>
>>> This approach is used to restart the simulation with the last saved DM.<br>
>>> Is there something we are missing, or there exists alternative routes to<br>
>>> this goal? Can we somehow get the IS of the redistribution, so we can<br>
>>> re-distribute the vector data as well?<br>
>>><br>
>>> Many thanks, best regards,<br>
>>><br>
>>> Hi Berend,<br>
>>><br>
>>> We are in the midst of rewriting this. We want to support saving <br>
>>> multiple meshes, with fields attached to each,<br>
>>> and preserving the discretization (section) information, and allowing <br>
>>> us to load up on a different number of<br>
>>> processes. We plan to be done by October. Vaclav and I are doing this <br>
>>> in collaboration with Koki Sagiyama,<br>
>>> David Ham, and Lawrence Mitchell from the Firedrake team.<br>
>><br>
>> The core load/save cycle functionality is now in PETSc main. So if <br>
>> you're using main rather than a release, you can get access to it now. <br>
>> This section of the manual shows an example of how to do <br>
>> thingshttps://petsc.org/main/docs/manual/dmplex/#saving-and-loading-data-with-hdf5
<br>
>> <<a href="https://petsc.org/main/docs/manual/dmplex/#saving-and-loading-data-with-hdf5">https://petsc.org/main/docs/manual/dmplex/#saving-and-loading-data-with-hdf5</a>><br>
>><br>
>> Let us know if things aren't clear!<br>
>><br>
>> Thanks,<br>
>><br>
>> Lawrence<br>
> <br>
</div>
</span></font></div>
</body>
</html>