-
Notifications
You must be signed in to change notification settings - Fork 160
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
DO NOT SQUASH Add PyOP2 to Firedrake repository #3817
Conversation
Make PETSc and petsc4py for CI use Firedrake not pip
actions: Build docs at end of successful test run
* Change requirements on loopy to point at the loopy sprint branch. * Replace lp.register_callable_kernel with lp.merge knl = lp.register_callable_kernel(knl, callee) is now knl = lp.merge([knl, callee]) . Reason given for loopy breaking back-compat: earlier they had a notion of a special "root_kernel" which only permitted one level of nesting loopy kernel calls and that was too restrictive. * Loopy callables: adapt to new API for registering. * Loopy Callables: register callables on a kernel not functions. * name is static property on SolveCallable and INVCallable * Loopy callables: register the callables rather than functions and remove the lookup functions. * Some progress * Loopy callables: Adapt API of with_types. * INVCallable has name "inverse" in loopy rep * Always pass a target when generating loopy kernels, otherwise we cannot merge them with wrapper kernels. * flake8 * Maybe generate call to inner kernel correctly Still doesn't work later. * Revert "Maybe generate call to inner kernel correctly" This reverts commit 009ca19f3fb133d53affeab53cd016c9b55620a9. * Revert "Revert "Maybe generate call to inner kernel correctly"" This reverts commit c85b60e6382b4762076b2744227fa5a6d903b830. * Remove dead code * rep2loopy: get name of callee kernel for matching the args. * Add missing code target * Maybe handle loopy argument access correctly dat.zero still doesn't work * Promote dats with shape (n,) to shape (n, 1) This enables sweeping indices to pick up a direct loop. * Set lang_version on all make_function calls * Fix disjoint arguments to C-string kernels * Resolve review comments * Rename function_args -> kernel_parameters * WIP Match args for all kernels in the callables table besides for LACallables? Why? * Only match args for callables that are CallableKernels. * Pin decorator Decorator version 5 changes the API in ways that break the argument type checking in PyOP2. We're therefore pinning on the version that works. * catch up with numpy type changes * Set within_inames_is_final on instructions * Squash numpy warning * Set strides on GlobalArgs * Caching: produce key for loop Programs. * Check if kernel is a loopy Program. * loopy.program.Program -> loopy.Program * Adapt to loopy interface changes. * Maintain loopy automatic reshaping (was in loopy) Everything in loopycompat.py file was in loopy/transform/callable.py but is removed in inducer/loopy#327. This commit maintains compatibility but should be phased out. * Fix loopy.program -> loopy.translation_unit * dont lint automatic reshaping (was in loopy) * Lint to pass flake8 * Fix loopy automatic reshaping (was in loopy) Changes were copied from an out of date branch by accident. * Fix type case error (recursively) This mirrors inducer/loopy#326 * ? Maybe fix the last dimension error mismatch. Not sure this will break things in other places. * Codegen: Don't merge indices of extent 1, so that the instructions are schedulable. This will fix e.g. the failure of tests/extrusion/test_steady_advection_2D_extr.py * Testing: Update loopy branch * Squashed commit of the following: commit 5a89bfc Author: Connor Ward <[email protected]> Date: Mon May 10 10:44:33 2021 +0100 Use Firedrake PETSc and petsc4py commit 948cb7d Author: David Ham <[email protected]> Date: Wed Apr 21 13:30:50 2021 +0100 Pin decorator Decorator version 5 changes the API in ways that break the argument type checking in PyOP2. We're therefore pinning on the version that works. commit 121c2a6 Author: David Ham <[email protected]> Date: Wed Apr 21 13:45:58 2021 +0100 catch up with numpy type changes * Revert "Squashed commit of the following:" This reverts commit bd1916142f883d6a4f0371ca6de2c344f0c7e78a. * Squashed commit of the following: commit 9a90c9f Merge: f1daf21 c8d7ff6 Author: Lawrence Mitchell <[email protected]> Date: Tue May 11 12:07:33 2021 +0100 Merge pull request #618 from OP2/wence/fix/actions-doc-build actions: Build docs at end of successful test run commit c8d7ff6 Author: Lawrence Mitchell <[email protected]> Date: Tue May 11 11:41:20 2021 +0100 actions: Build docs at end of successful test run commit f1daf21 Merge: d0cc348 5a89bfc Author: Lawrence Mitchell <[email protected]> Date: Mon May 10 20:32:24 2021 +0100 Merge pull request #617 from connorjward/test-ci Make PETSc and petsc4py for CI use Firedrake not pip commit 5a89bfc Author: Connor Ward <[email protected]> Date: Mon May 10 10:44:33 2021 +0100 Use Firedrake PETSc and petsc4py commit 948cb7d Author: David Ham <[email protected]> Date: Wed Apr 21 13:30:50 2021 +0100 Pin decorator Decorator version 5 changes the API in ways that break the argument type checking in PyOP2. We're therefore pinning on the version that works. commit 121c2a6 Author: David Ham <[email protected]> Date: Wed Apr 21 13:45:58 2021 +0100 catch up with numpy type changes * Lint. * Jenkins * Make import global. * Drop package branches. Co-authored-by: Sophia Vorderwuelbecke <[email protected]> Co-authored-by: Lawrence Mitchell <[email protected]> Co-authored-by: Connor Ward <[email protected]> Co-authored-by: David Ham <[email protected]> Co-authored-by: Kaushik Kulkarni <[email protected]>
Something like this will be necessary if we want general symmetry group stuff in the maps. It is also convenient if you want to stage in a permutation from the canonical FIAT order.
Instead of pattern matching on node names to determine whether nodes should be relabelled, just use a name generation scheme for everything. Now we have one less problem.
Add PETSc decorator to compile
More loopy interface changes: arg_id_to_val -> arg_id_to_arg
* Add petsc_raises fixture to catch PETSc callback exceptions
* Fix assembly of Real matrices
* Refactor test_demos, avoid mpiexec invocation * Fix multigrid test, __main__ is not valid when importing
* Get value_shape from FunctionSpace * Define FunctionSpace.block_size as the number of dofs per node * sort_domains --------- Co-authored-by: ksagiyam <[email protected]>
* DO NOT MERGE * Test VOM with point variant * Update .github/workflows/build.yml * Test Regge point variant * add continuity test * Test H(curl div) element (#3843) * Test H(curl div) element * test Hu-Zhang * checkout ufl master branch * checkout master branches
Signed-off-by: Umberto Zerbinati <[email protected]> Co-authored-by: Umberto Zerbinati <[email protected]>
* Disk checkpointing managing start, pause and continue checkpointing. * AdjointDiskCheckpoint --------- Co-authored-by: David A. Ham <[email protected]>
* Moves PyOP2 code into Firedrake repository. * Adds a pyproject.toml for Firedrake * Enables (with some caveats) one to `pip install firedrake`! * Adds a new pip workflow to make sure things work * Moves Firedrake tests into a `tests/firedrake` subdirectory.
463eb23
to
1bceac4
Compare
I did a clean install using the branch. Wanted to test
|
Thanks for noticing this. Will fix ASAP.
Specifically what failed? I thought I tried this and things worked. |
|
But that's not what I have... https://github.com/firedrakeproject/firedrake/pull/3817/files#diff-e86a30193cf50f52a86c9839c05da17a3f06c2ff5d082571efc52644f7f79771L1407-R1400 Strange. I think that running |
To be clear, I installed current firedrake/scripts/firedrake-install Line 1407 in b783253
|
01273f3
to
8bcb96f
Compare
Ah I see. This is a case I had not (and certainly should have) considered. |
* Remove import of firedrake_configuration package - Monkey-patch u_restrict property required by newer PETSc TS - Package is no longer available due to pip install migration * Fix unit test failures - Migrate adjoint.py to newer interpolate API - Set max SNES failures to make TS retry steps * Migrate examples to newer VTKFile output API - Silences deprecation warning emitted from Firedrake * Adapt DAEProblem class to use to restricted solution - Duck typing compatible with VariationalProblem class - Use the new member everywhere * Remove unused & forgotten LOC --- This PR removes the (actually unused) import of `firedrake_configuration` package that is no longer present in recent (2 weeks or so) versions of [Firedrake Docker Hub image](https://hub.docker.com/r/firedrakeproject/firedrake/tags). Root cause of the issue is the migration of Firedrake to be `pip`-installable. There's details about the topic [here](firedrakeproject/firedrake#3877). Specifically, the problem started with [the PR that migrates _PyOP2_ into the main _Firedrake_ repo](firedrakeproject/firedrake#3817). --- It seems like the obvious fix, i.e. just remove the import, worked. The `firedrake_configuration` module wasn't used for anything directly within the `firedrake_ts` package. Besides this, the PR contains a few small fixes to make the unit tests and examples work. It seems like PETSc 3.22 upgrage that's bundled in the Firedrake 2024-12 image doesn't set the [`ts_max_snes_failures`](https://petsc.org/release/manualpages/TS/TSSetMaxSNESFailures/) option anymore. Somehow the default value causes the inner SNES solver never to retry any linear solves. So the TS solver has no other option but to fail whenever it happens instead of retrying. I also migrated the example applications to use the newer interpolate and VTK output Firedrake API.
Description
The big merge!
Closes #3877
Key changes introduced by this PR
tests/firedrake
subdirectorypyproject.toml
pip install git+https://github.com/firedrakeproject/firedrake.git
becomes a viable install method (subject to setting a number of environment variables). This ultimately will be our path to a Firedrake wheel.firedrake_configuration
. The information is all accessible by inspecting PETSc variables.Outstanding tasks
firedrake-install
,firedrake-update
,firedrake-status
andfiredrake-clean
pass locally (these are not fully tested in the CI).git rebase -i
to try and keep a clean history.firedrake-zenodo
as PyOP2 repo is going away.Following feedback
firedrake-update
using an existing installationfiredrake-zenodo
should be foundFuture work
pip install libsupermesh
(nearly ready to go: JDBetteridge/pip install libsupermesh#10)