-
Notifications
You must be signed in to change notification settings - Fork 101
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
including Jacobi polynomials and Wigner functions #267
Comments
Why aren't you calculating it using a Clenshaw algorithm using the 3-term recurrence? That's the typical way to evaluate orthogonal polynomials, and seems a lot more efficient than evaluating lots of |
See also #175, #124, #24, #136. I feel like evaluating orthogonal polynomials is kind of a different category of problem than evaluating transcendental functions, and perhaps there should be a separate package (SpecialPolynomials.jl?). I think that there should be a package for these, in part because a lot of people want them, and also because they are easy to implement badly, but combining them with SpecialFunctions.jl may complicate maintenance more than it is worth… I think @dlfivefifty may have been working on something along these lines in https://github.com/JuliaApproximation/OrthogonalPolynomialsQuasi.jl and similar? |
Yes, and it works pretty well: julia> a,b = 0.1,0.2; x = 0.3;
julia> @time Jacobi(a,b)[x,1:100_000_000] # Evaluate P_n^(a,b)(x) for n=0:99_999_999
1.066723 seconds (36 allocations: 762.942 MiB, 15.73% gc time)
100000000-element Array{Float64,1}:
1.0
0.295
-0.40136250000000007
-0.4040010625000001
0.09190393023437506
0.3755560868932033
0.12997481357103505
-0.25062955253876074
⋮
-6.12822549513539e-5
-8.111091463677328e-5
1.2615705799800099e-5
8.868033726769704e-5
4.059249642093418e-5
-6.432483865011064e-5
-7.918739901210108e-5 There is some discussion of pulling the evaluation code into a separate, more lightweight package that doesn't use the ContinuumArrays.jl language (CC @guilgautier): JuliaApproximation/OrthogonalPolynomialsQuasi.jl#54 (comment) This would still use InfiniteArrays.jl and LazyArrays.jl as it allows for fast recurrence evaluations without having to rewrite the forward recurrence for each polynomial. |
That is interesting, I was not aware of the Clenshaw algorithm. When it is beneficial? |
@dlfivefifty do you also have wigner d-functions codded with quasi arrays? |
I was also wondering what is the best way to allow for the call of the polynomial functions with symbolic input. |
No but @MikaelSlevinsky might have something
Anytime you need to generate all OPs in a sequence: even
Probably |
Even for evaluating a single Jacobi polynomial of degree n, both the Clenshaw algorithm and @mmikhasenko's implementation are O(n), but the Clenshaw algorithm should be faster because it involves no transcendental functions. The Clenshaw algorithm also works better for a broader range of input types, e.g. symbolic inputs, because it only involves |
I do not use |
As for Gaunt (Clebsch--Gordan) coefficients, you may find this implementation interesting https://github.com/JuliaApproximation/FastTransforms.jl/blob/master/src/gaunt.jl. There may be others in other packages. |
Thanks! I have the coefficients coded in Julia, it works fine. |
The package description suggests that it is c++ wrapper. That is not the right place for my code. |
In my opinion, |
@dlfivefifty , do you think the Wigner d fit to OrthogonalPolynomiasQuasi.jl ? From here https://en.m.wikipedia.org/wiki/Wigner_D-matrix |
https://github.com/JuliaApproximation/SphericalHarmonics.jl might make more sense. Though unfortunately I don't have time at the moment to flesh that out. |
you can pin me once you get there |
@dlfivefifty hey, now, as we have got |
No I haven't. I don't think I have a need for Wigner d at the moment so no plans on implementing it, but happy to help if you are interested |
ok, thanks.
I believe that the recursive way of computing will be the way to go, but the details will change. |
I have the functions coded in julia in the
PartialWaveFunctions
package.jacobi_pols
https://github.com/mmikhasenko/PartialWaveFunctions.jl/blob/master/src/wignerd.jl#L10
wignerd
,wignerD
https://github.com/mmikhasenko/PartialWaveFunctions.jl/blob/master/src/wignerd.jl#L60
Does it fit the
SpecialFunctions.jl
package? Do you accept PR?What is about
clebsch_gordan
coefficients?The text was updated successfully, but these errors were encountered: