-
Notifications
You must be signed in to change notification settings - Fork 160
Firedrake meeting 2022 06 23
Date and time 2022-06-23 12:00UTC (13:00BST 22:00AEST)
- Pick Chair and Minuter (RNH to pick).
- ALL: (ongoing) triage the open issues and confirm if they are indeed still open (and perhaps provide labels)
- KS: Test PETSc main against current Firedrake
- JB: Look into updating the
@parallel
test marker (ongoing) - DH: talk to Jemma about Firedrake 2022
- ?: Decide who will organise SIAM CSE23 Minisymposium/minisymposterium
Present: JB, DH, AM, KS, JW, RNH, CW, SK, SV, RK
Apologies:
Joe has 2 new parallel plex-to-plex interpolation MRs on PETSc: #5345 and #5354. How can we best get this working with Firedrake? My (RNH's) thoughts are:
- DMSwarmSetPointCoordinates (which we called prior to the merging of #2437) calls DMLocatePoints which, were we to revert to using it, would solve the issue of out-of-rank points (see issue #2178 and discussion #2450)
- Because of the missing link between PETSc coordinate fields and Firedrake coordinate fields (issue #2185) meshes created from coordinate fields, fixed in #2437, would not work by reverting to calling DMSwarmSetPointCoordinates.
JW: Parallel interp doesn't work in PETSc, details available in MR. Serial is fine.
DH: This comes from the PETSc FE stuff. There's an easy part and a hard part. Easy: in DMPlex there should be a description of nodes and basis functions wrt a reference cell (like in Firedrake). Hard: orientation, PETSc has one concept of this, Firedrake is missing this, but Koki has implemented this for CG/DG. More fundamental problem is there is no common field data format between FEM packages.
(General discussion on how to incorporate these changes into Firedrake.)
RNH: How does this affect VertexOnlyMesh?
DH: DMSwarm is mapped to a parent mesh, so is a special case of interpolation.
AM: What happens with manifolds?
DH: This is a different problem, needs someone to do the work. We have a mathematically correct solution, we just need to ensure the code is implementing this.
AM: What about a horrible circle?
DH: There is a question about how we choose candidate cells so it's not expensive. This is what we use libspatialindex for, in combination with bounding boxes.
AM: Is someone going to do this for us?
DH: No.
DH: Also we need to think about what happens with extruded meshes.
KS: Arising in PR for IO. Need to generate mesh from mesh coordinates directly.
DH: We need to think about the circumstances we actually want to do this. Probably always, although we need to be careful with mesh hierarchies. Does IO support dumping hierarchies? (KS: No) This should be implemented, but not in this PR.
DH: Everything is working, but SK is still seeing an issue. I am implementing fancy checkpointing with chunking in revolve. Revolve is 20 years old though, but want to use an updated version from Inria. James Maddison has also made an implementation, but covers fewer cases.
The issue SK is seeing is with determining what things need checkpointing (things that are being input and things getting output).
RK: Orientations are in Fiat now, something goes wrong with serendipity elements. Can this be fixed?
DH: Koki fixed some of this.
DH: Merge stuff from branches if you want things fixed (this is a PSA). There may be an issue with orienting serendipity, needs careful thinking about. Orientation needs fixing properly.
None
Next meeting: 1200 UTC 2022-06-30
Building locally
Tips
- Running Firedrake tests with different subpackage branches
- Modifying and Rebuilding PETSc and petsc4py
- Vectorisation
- Debugging C kernels with
lldb
on MacOS - Parallel MPI Debugging with
tmux-mpi
,pdb
andgdb
- Parallel MPI Debugging with VSCode and
debugpy
- Modifying generated code
- Kernel profiling with LIKWID
- breakpoint() builtin not working
- Debugging pytest with multiple processing
Developers Notes
- Upcoming meeting 2024-08-21
- 2024-08-07
- 2024-07-24
- 2024-07-17
- 2024-07-10
- 2024-06-26
- 2024-06-19
- 2024-06-05
- 2024-05-29
- 2024-05-15
- 2024-05-08
- 2024-05-01
- 2024-04-28
- 2024-04-17
- 2024-04-10
- 2024-04-03
- 2024-03-27
- 2024-03-20
- 2024-03-06
- 2024-02-28
- 2024-02-28
- 2024-02-21
- 2024-02-14
- 2024-02-07
- 2024-01-31
- 2024-01-24
- 2024-01-17
- 2024-01-10
- 2023-12-13
- 2023-12-06
- 2023-11-29
- 2023-11-22
- 2023-11-15
- 2023-11-08
- 2023-11-01
- 2023-10-25
- 2023-10-18
- 2023-10-11
- 2023-10-04
- 2023-09-27
- 2023-09-20
- 2023-09-06
- 2023-08-30
- 2023-08-23
- 2023-07-12
- 2023-07-05
- 2023-06-21
- 2023-06-14
- 2023-06-07
- 2023-05-17
- 2023-05-10
- 2023-03-08
- 2023-02-22
- 2023-02-15
- 2023-02-08
- 2023-01-18
- 2023-01-11
- 2023-12-14
- 2022-12-07
- 2022-11-23
- 2022-11-16
- 2022-11-09
- 2022-11-02
- 2022-10-26
- 2022-10-12
- 2022-10-05
- 2022-09-28
- 2022-09-21
- 2022-09-14
- 2022-09-07
- 2022-08-25
- 2022-08-11
- 2022-08-04
- 2022-07-28
- 2022-07-21
- 2022-07-07
- 2022-06-30
- 2022-06-23
- 2022-06-16
- 2022-05-26
- 2022-05-19
- 2022-05-12
- 2022-05-05
- 2022-04-21
- 2022-04-07
- 2022-03-17
- 2022-03-03
- 2022-02-24
- 2022-02-10
- 2022-02-03
- 2022-01-27
- 2022-01-20
- 2022-01-13
- 2021-12-15
- 2021-12-09
- 2021-11-25
- 2021-11-18
- 2021-11-11
- 2021-11-04
- 2021-10-28
- 2021-10-21
- 2021-10-14
- 2021-10-07
- 2021-09-30
- 2021-09-23
- 2021-09-09
- 2021-09-02
- 2021-08-26
- 2021-08-18
- 2021-08-11
- 2021-08-04
- 2021-07-28
- 2021-07-21
- 2021-07-14
- 2021-07-07
- 2021-06-30
- 2021-06-23
- 2021-06-16
- 2021-06-09
- 2021-06-02
- 2021-05-19
- 2021-05-12
- 2021-05-05
- 2021-04-28
- 2021-04-21
- 2021-04-14
- 2021-04-07
- 2021-03-17
- 2021-03-10
- 2021-02-24
- 2021-02-17
- 2021-02-10
- 2021-02-03
- 2021-01-27
- 2021-01-20
- 2021-01-13
- 2021-01-06