-
Notifications
You must be signed in to change notification settings - Fork 161
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
Fix for Cofunction
self-assignment via interpolation
#3939
base: master
Are you sure you want to change the base?
Changes from 2 commits
b8c5252
98f8c1e
63b74ca
a2b6002
2dc087a
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -34,6 +34,13 @@ def f1(mesh, V1): | |
return Function(V1).interpolate(expr) | ||
|
||
|
||
def test_interp_self(V1): | ||
a = assemble(TestFunction(V1) * dx) | ||
b = assemble(TestFunction(V1) * dx) | ||
a.interpolate(a) | ||
assert (a.dat.data_ro == b.dat.data_ro).all() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Not sure if this should be a There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think you're right as written. No flops should be performed so that should be an equality. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't think it's actually no flops, it's interpolation which happens to be the identify except for roundoff. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Changed to |
||
|
||
|
||
def test_assemble_interp_operator(V2, f1): | ||
# Check type | ||
If1 = Interpolate(f1, V2) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Shouldn't a no-op be the right thing?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think so, e.g.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see, it only is a no-op in the MFE from the issue:
assemble(L(w), tensor=w)
withL
being the identity.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe it'd be good to add a more complicated test then
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Done. I think there are also be issues with complex here (transpose should be Hermitian for the adjoint actions?).