<!DOCTYPE html><!-- BaNnErBlUrFlE-BoDy-start -->
<!-- Preheader Text : BEGIN -->
<div style="display:none !important;display:none;visibility:hidden;mso-hide:all;font-size:1px;color:#ffffff;line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;">
 Il 14/05/24 15: 02, Matthew Knepley ha scritto: On Tue, May 14, 2024 at 12: 14 AM Matteo Semplice <matteo. semplice@ uninsubria. it> wrote: Dear petsc-users, I am playing with DMPlexGetCellCoordinates and observing that it returns correct
</div>
<!-- Preheader Text : END -->

<!-- Email Banner : BEGIN -->
<div style="display:none !important;display:none;visibility:hidden;mso-hide:all;font-size:1px;color:#ffffff;line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;">ZjQcmQRYFpfptBannerStart</div>

<!--[if ((ie)|(mso))]>
  <table border="0" cellspacing="0" cellpadding="0" width="100%" style="padding: 16px 0px 16px 0px; direction: ltr" ><tr><td>
    <table border="0" cellspacing="0" cellpadding="0" style="padding: 0px 10px 5px 6px; width: 100%; border-radius:4px; border-top:4px solid #90a4ae;background-color:#D0D8DC;"><tr><td valign="top">
      <table align="left" border="0" cellspacing="0" cellpadding="0" style="padding: 4px 8px 4px 8px">
        <tr><td style="color:#000000; font-family: 'Arial', sans-serif; font-weight:bold; font-size:14px; direction: ltr">
          This Message Is From an External Sender
        </td></tr>
        <tr><td style="color:#000000; font-weight:normal; font-family: 'Arial', sans-serif; font-size:12px; direction: ltr">
          This message came from outside your organization.
        </td></tr>

      </table>

    </td></tr></table>
  </td></tr></table>
<![endif]-->

<![if !((ie)|(mso))]>
  <div dir="ltr"  id="pfptBannerqsj2iih" style="all: revert !important; display:block !important; text-align: left !important; margin:16px 0px 16px 0px !important; padding:8px 16px 8px 16px !important; border-radius: 4px !important; min-width: 200px !important; background-color: #D0D8DC !important; background-color: #D0D8DC; border-top: 4px solid #90a4ae !important; border-top: 4px solid #90a4ae;">
    <div id="pfptBannerqsj2iih" style="all: unset !important; float:left !important; display:block !important; margin: 0px 0px 1px 0px !important; max-width: 600px !important;">
      <div id="pfptBannerqsj2iih" style="all: unset !important; display:block !important; visibility: visible !important; background-color: #D0D8DC !important; color:#000000 !important; color:#000000; font-family: 'Arial', sans-serif !important; font-family: 'Arial', sans-serif; font-weight:bold !important; font-weight:bold; font-size:14px !important; line-height:18px !important; line-height:18px">
        This Message Is From an External Sender
      </div>
      <div id="pfptBannerqsj2iih" style="all: unset !important; display:block !important; visibility: visible !important; background-color: #D0D8DC !important; color:#000000 !important; color:#000000; font-weight:normal; font-family: 'Arial', sans-serif !important; font-family: 'Arial', sans-serif; font-size:12px !important; line-height:18px !important; line-height:18px; margin-top:2px !important;">
This message came from outside your organization.
      </div>

    </div>

    <div style="clear: both !important; display: block !important; visibility: hidden !important; line-height: 0 !important; font-size: 0.01px !important; height: 0px"> </div>
  </div>
<![endif]>

<div style="display:none !important;display:none;visibility:hidden;mso-hide:all;font-size:1px;color:#ffffff;line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;">ZjQcmQRYFpfptBannerEnd</div>
<!-- Email Banner : END -->

<!-- BaNnErBlUrFlE-BoDy-end -->
<html><head><!-- BaNnErBlUrFlE-HeAdEr-start -->
<style>
  #pfptBannerqsj2iih { all: revert !important; display: block !important; 
    visibility: visible !important; opacity: 1 !important; 
    background-color: #D0D8DC !important; 
    max-width: none !important; max-height: none !important }
  .pfptPrimaryButtonqsj2iih:hover, .pfptPrimaryButtonqsj2iih:focus {
    background-color: #b4c1c7 !important; }
  .pfptPrimaryButtonqsj2iih:active {
    background-color: #90a4ae !important; }
</style>

<!-- BaNnErBlUrFlE-HeAdEr-end -->

<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  </head>
  <body>
    <div class="moz-cite-prefix">Il 14/05/24 15:02, Matthew Knepley ha
      scritto:<br>
    </div>
    <blockquote type="cite" cite="mid:CAMYG4G=kpMYw8LGxx63SmbpPN_PhswmDZJV84kU2Te3p_LCfZw@mail.gmail.com">
      
      <div dir="ltr">
        <div dir="ltr">On Tue, May 14, 2024 at 12:14 AM Matteo Semplice
          <<a href="mailto:matteo.semplice@uninsubria.it" moz-do-not-send="true" class="moz-txt-link-freetext">matteo.semplice@uninsubria.it</a>>
          wrote:<br>
        </div>
        <div class="gmail_quote">
          <blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
            <div class="msg-3285471884708579794">
              <div style="font-size:1px;color:rgb(255,255,255);line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;display:none">
                Dear petsc-users, I am playing with
                DMPlexGetCellCoordinates and observing that it returns
                correct periodic coordinates for cells, but not for
                faces. More precisely, adding
                PetscCall(DMPlexGetHeightStratum(dm, 1, &fStart,
                &fEnd)); for
              </div>
              <div style="font-size:1px;color:rgb(255,255,255);line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;display:none">ZjQcmQRYFpfptBannerStart</div>
              <div dir="ltr" id="m_-3285471884708579794pfptBannerzk2r54v" style="display:block;text-align:left;margin:16px 0px;padding:8px 16px;border-radius:4px;min-width:200px;background-color:rgb(208,216,220);border-top:4px solid rgb(144,164,174)">
                <div id="m_-3285471884708579794pfptBannerzk2r54v" style="float:left;display:block;margin:0px 0px 1px;max-width:600px">
                  <div id="m_-3285471884708579794pfptBannerzk2r54v" style="display:block;background-color:rgb(208,216,220);color:rgb(0,0,0);font-family:Arial,sans-serif;font-weight:bold;font-size:14px;line-height:18px">
                    This Message Is From an External Sender </div>
                  <div id="m_-3285471884708579794pfptBannerzk2r54v" style="font-weight:normal;display:block;background-color:rgb(208,216,220);color:rgb(0,0,0);font-family:Arial,sans-serif;font-size:12px;line-height:18px;margin-top:2px">
                    This message came from outside your organization. </div>
                </div>
                <div style="height:0px;clear:both;display:block;line-height:0;font-size:0.01px"> </div>
              </div>
              <div style="font-size:1px;color:rgb(255,255,255);line-height:1px;height:0px;max-height:0px;opacity:0;overflow:hidden;display:none">ZjQcmQRYFpfptBannerEnd</div>
              <div>
                <p>Dear petsc-users,</p>
                <p>    I am playing with DMPlexGetCellCoordinates and
                  observing that it returns correct periodic coordinates
                  for cells, but not for faces.</p>
                <p>More precisely, adding <br>
                </p>
                <p>    <font face="monospace">PetscCall(DMPlexGetHeightStratum(dm,
                    1, &fStart, &fEnd));<br>
                        for (f = fStart; f < fEnd; ++f) {<br>
                          const PetscScalar *array;<br>
                          PetscScalar       *x = NULL;<br>
                          PetscInt           ndof;<br>
                          PetscBool          isDG;<br>
                    <br>
                          PetscCall(DMPlexGetCellCoordinates(dm, f,
                    &isDG, &ndof, &array, &x));<br>
                          PetscCheck(ndof % cdim == 0, PETSC_COMM_SELF,
                    PETSC_ERR_ARG_INCOMP, "ndof not divisible by cdim");<br>
                          PetscCall(PetscPrintf(PETSC_COMM_SELF, "Face
                    #%" PetscInt_FMT " coordinates\n", f - fStart));<br>
                          for (PetscInt i = 0; i < ndof; i += cdim)
                    PetscCall(PetscScalarView(cdim, &x[i],
                    PETSC_VIEWER_STDOUT_SELF));<br>
                          PetscCall(DMPlexRestoreCellCoordinates(dm, f,
                    &isDG, &ndof, &array, &x));<br>
                        }</font><br>
                </p>
                <p>to src/dm/impls/plex/tutorials/ex8.c, I get <font face="monospace"><br>
                  </font></p>
                <p><font face="monospace">$ ./ex8 -dm_plex_dim 2
                    -petscspace_degree 1 -dm_plex_simplex 0
                    -dm_plex_box_faces 3,2 -dm_plex_box_bd periodic,none
                    -dm_view -view_coord <br>
                    DM Object: box 1 MPI process<br>
                      type: plex<br>
                    box in 2 dimensions:<br>
                      Number of 0-cells per rank: 9<br>
                      Number of 1-cells per rank: 15<br>
                      Number of 2-cells per rank: 6<br>
                    Periodic mesh (PERIODIC, NONE) coordinates localized<br>
                  </font></p>
                <p><font face="monospace">[...]</font></p>
                <p><font face="monospace">Element #2 coordinates<br>
                     0:   6.6667e-01   0.0000e+00<br>
                    <font color="#26a269"> 0:   1.0000e+00   0.0000e+00 
                      <<<----- correct<br>
                       0:   1.0000e+00   5.0000e-01</font><br>
                     0:   6.6667e-01   5.0000e-01<br>
                    [...]</font></p>
                <p><font face="monospace">Face #0 coordinates<br>
                     0:   0.0000e+00   0.0000e+00<br>
                     0:   3.3333e-01   0.0000e+00<br>
                    Face #1 coordinates<br>
                     0:   3.3333e-01   0.0000e+00<br>
                     0:   6.6667e-01   0.0000e+00<br>
                    Face #2 coordinates<br>
                    <font color="#a51d2d"> 0:   6.6667e-01   0.0000e+00<br>
                       0:   0.0000e+00   0.0000e+00  <<<----
                      should be (0.66,0.00) and (1.00,0.00)<br>
                    </font></font></p>
                <p>Is there a way to recover correct periodic
                  coordinates in the case of periodic DMPLex?</p>
              </div>
            </div>
          </blockquote>
          <div>The way that periodic coordinates work is that it stores
            a DG coordinate field by cell. Faces default back to the
            vertices. You could think about  also putting DG coordinates
            on faces, but no one had asked, and it is potentially
            expensive.</div>
          <div><br>
          </div>
          <div>If you really need them to keep going, face coordinates
            can be extracted from cell coordinates. Otherwise, I can do
            it after the PETSc Meeting. Or, we are happy to take
            contributions adding this.</div>
        </div>
      </div>
    </blockquote>
    <p>Hi.</p>
    <p>I mainly wanted to check that this was expected and not a result
      of a setup of my DM. No need to change Petsc now except maybe
      issuing a warning if the fallback to continuous coordinates will
      give wrong results. As for my code, I think I can extract the info
      from the cell coordinates in a pre-processing phase and if this
      crazy FV methods I am implementing will survive for long enough,
      I'll think about contributing.<br>
    </p>
    <p>Just to double-check, can I assume that the order in which <font face="monospace">DMPlexGetCellCoordinates</font> returns the
      coordinates matches the ordering of vertices in DMPlexGetCone for
      the uninterpolated DM, right?<br>
    </p>
    <p>Best</p>
    <p>    Matteo<br>
    </p>
  </body>
</html>