-
Notifications
You must be signed in to change notification settings - Fork 9
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
Re-design AxisTensors #867
Comments
I'd like to see a clear description of the minimum functionality that we need (e.g., transformation covariant -> contravariant and inverse, in the horizontal and in 3d). That is, put down a set of requirements that need to be fulfilled, and then discuss the code structure that will fulfill them. From the description here, I have the impression that what we need is not so much an improved design of AxisTensors (how did we ever get to 3486 types?), but getting rid of it and replacing it by much simpler code. I'd be hesitant to invest resources in improving something just because we have sunken costs in it. |
Good point. Since @simonbyrne has some ideas about this, let's wait for when he returns.
In some ways yes. And it's not that we have 3486 types, it's that we can make 3486 (distinguishable) types. Some of these transformations are indistinguishable by changing coordinate systems. For example, transformations in a x-y plane are distinguishable from transformations in a y-z plane. I think @simonbyrne mentioned that we may be able to continue using what we have and just forward generic transformations to more generic methods (to avoid defining many methods). This would fix the many method issue, however, it wouldn't really address the documentation issue. On another note, timings in point 2 should be confirmed. I've since run other examples that didn't result in slowdown. It's possible that more inlining is needed. |
There are 3 main representations we make use of: covariant, contravariant, local (aka uvw). This means that there are 6 possible conversion directions. What really causes the blow up is dealing with subvectors (e.g. Additionally, we also currently define @charleskawczynski do you have a list of the methods we generate? Can you post them in a gist so I can see what we're using? That might help narrow down the scope |
Yes, here is the gist. It includes:
There are a lot, but as you've said, it still narrows down the scope |
There are actually more methods that I missed, which call project in a nested fashion, those should probably be written to minimize loads/stores/flops, too. |
For example: transform(
ax::ContravariantAxis,
v::CovariantTensor,
local_geometry::LocalGeometry,
) = project(
ax,
local_geometry.∂ξ∂x *
local_geometry.∂ξ∂x' *
project(dual(axes(local_geometry.∂ξ∂x, 1)), v),
) This is probably very slow. |
Purpose
The purpose of this SDI is to improve the design of AxisTensors. There are several issues with the existing design:
typeof(::AxisTensor)
which will not show the alias, but the concrete type ofAxisTensor
, creating a visual mismatch for people debugging.Link to any relevant PRs/issues.
Cost/benefits/risks
Producers
Components
AxisTensor
sInputs
There are many relations (e.g., conversions) that will need to be re-written, but most of this is related to the type design
Results and deliverables
A better design to AxisTensors
Task breakdown
A preliminary list of PRs and a preliminary timeline of PRs, milestones, and key results.
...
Reviewers
The text was updated successfully, but these errors were encountered: