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

<!-- BaNnErBlUrFlE-HeAdEr-end -->
</head><!-- 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;">
 Hi PETSc community, I've been looking at using Spack to build PETSc, in particular I need to disable the default metis/parmetis dependencies and use PTScotch instead, for our software. I've had quite a bit of trouble with this - it
</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="pfptBannery13tap5" 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="pfptBannery13tap5" style="all: unset !important; float:left !important; display:block !important; margin: 0px 0px 1px 0px !important; max-width: 600px !important;">
      <div id="pfptBannery13tap5" 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="pfptBannery13tap5" 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 -->
<div dir="ltr"><div>Hi PETSc community,</div><div><br></div><div>I've been looking at using Spack to build PETSc, in particular I need to disable the default metis/parmetis dependencies and use PTScotch instead, for our software.</div><div>I've had quite a bit of trouble with this - it seems like something in the resulting build of our simulator ends up badly optimised and an mpi bottleneck, when I build against </div><div>PETSc built with Spack.</div><div><br></div><div>I've been trying to track this down, and noticed this in the PETSc Spack build recipe:</div><div><br></div><div>    # PTScotch: Currently disable Parmetis wrapper, this means<br>    # nested disection won't be available thought PTScotch<br>    depends_on("scotch+esmumps~metis+mpi", when="+ptscotch")<br>    depends_on("scotch+int64", when="+ptscotch+int64")</div><div><br></div><div><br></div><div>Sure enough - when I compare the build with Spack and a traditional build with ./configure etc, I see that, in the traditional build, Scotch is always built with the parmetis wrapper,</div><div>but not in the Scotch build. In fact, I'm not sure how to turn off the parmetis wrapper option for scotch, in the case of a traditional build (i.e. there doesn't seem to be a flag in the <br></div><div>configure script for it) - which would be a very useful test for me (I can of course do similar experiments by doing a classical build of petsc against ptscotch built separately without the</div><div>wrappers, etc - will try that).</div><div><br></div><div>Does anyone know why the parmetis wrapper is always disabled in the spack build options? Is there something about Spack that would prevent it from working? It's notable - but I might <br></div><div>be missing it - that there's no warning that there's a difference in the way ptscotch is built between the spack and classical builds:</div><div>- classical: ptscotch will always be built with parmetis wrappers, can't seem to turn off</div><div>- spack: ptscotch will always be built without parmetis wrappers, can't turn on</div><div><br></div><div>Any insight at all would be great, I'm new to Spack and am not super familiar with the logic that goes into setting up builds for the system.<br></div><div><br></div><div>Here is the kind of command I give to Spack for PETSc builds, which may well be less than ideal:</div><div><br></div><div>spack install petsc@3.19.1 ~metis +ptscotch ^hdf5 +fortran +hl</div><div><br></div><div>Separate tiny note: when building with hdf5, I have to ensure that the fortran flag is set for it, as above. There's a fortran flag for the petsc module, default true, and a fortran flag for the hdf5</div><div>module, default false. A naive user (i.e. me), will see the fortran flag for the petsc module, and assume that all dependencies will correspondingly be built with fortran capability - then see that</div><div>hdf5.mod is missing when trying to build their software against petsc. It's the old "did you forget --with-hdf5-fortran-bindings?" issue, resurrected for a new build system.</div><div><br></div><div>Thanks,</div><div><br></div><div>Daniel<br></div></div>