-
Notifications
You must be signed in to change notification settings - Fork 16
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
Add the GTPSA.jl backend #329
base: main
Are you sure you want to change the base?
Conversation
@mattsignorelli thank you for the contribution! |
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #329 +/- ##
===========================================
- Coverage 98.51% 54.75% -43.76%
===========================================
Files 108 103 -5
Lines 4297 4597 +300
===========================================
- Hits 4233 2517 -1716
- Misses 64 2080 +2016
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
…nterface.jl into pr/mattsignorelli/329
Sorry for the delay on this, I've had my hands tied with all different projects. Two weeks ago I pushed major updates/fixes and finishing touches to |
The structure of the tests has changed a little since the last time you checked, can you merge |
Sorry for taking so long to get back to you @mattsignorelli! I have brought your PR up to speed with the rest of the package, and taken into account the new version of ADTypes which includes function initialize!(xt::TPS, x::Number, dx::Number)
xt[0] = x
xt[1] = dx
return xt
end
function initialize!(xt::AbstractArray{<:TPS}, x::AbstractArray, dx::AbstractArray)
for i in eachindex(xt, x, dx)
initialize!(xt[i], x[i], dx[i])
end
return xt
end Can you maybe create similar functions to shorten the other operators? Just like |
Thanks for your work on this!
I think we need to be careful here. This would only apply for single-variable functions: julia> d = Descriptor(2,1); # two variables to first order
julia> f = TPS(use=d);
julia> f[0] = 1; f[1] = 2; f[2] = 3;
julia> print(f) # corresponds to f(dx1,dx2) = 1 + dx1 + dx2
TPS64:
Coefficient Order Exponent
1.0000000000000000e+00 0 0 0
2.0000000000000000e+00 1 1 0
3.0000000000000000e+00 1 0 1 Also, because the |
I think I understand what |
The expression "multiple seeds" is a bit unclear. For instance, for a function |
That's the setting considered in DI. Even with all the latest changes, there will only ever be one active variable |
Ah ok, I think I understand better. I'm admittedly not super familiar with the usual conventions used by most AD packages in Julia, only that in GTPSA, so I'm trying to connect the dots here. Let me explain how it works in GTPSA, and then maybe you can help better see how to fit it into DI: Basically with GTPSA, it calculates truncated power series in the variables, assuming the variables are small. So for example to calculate a Jacobian of a function Alternatively, one could do this one with variable, e.g. calculate |
That makes sense, thank you. But then I think the |
OK sorry for the big delay, I have been completely consumed by my other project but I'm ready to get back to this now.
That's a great idea. I'll look into this and see if I can come up with anything. I'll take a look at the latest code and dev guide to reorient myself, and be in touch soon. |
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #329 +/- ##
===========================================
- Coverage 97.61% 57.45% -40.16%
===========================================
Files 112 107 -5
Lines 5609 5888 +279
===========================================
- Hits 5475 3383 -2092
- Misses 134 2505 +2371
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
@gdalle This should be ready soon.. For HVP, I'm having difficulty understanding the tangents. For example one of the tests gives a 6x6 Hessian matrix but the tangent is a scalar number. Shouldn't the tangent be a vector? |
OK other than I'm having a bit of trouble with |
Actually, I realized I made a mistake in which tests are being run when I made my previous comment. I found the problem |
#316