-
Notifications
You must be signed in to change notification settings - Fork 32
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
import sgkit
takes ~1.5s
#931
Comments
I agree that deferring some of the imports could help. I think numba compilation is still a significant part of this, see #363, although we now have numba caching on so it's faster the second time. Not sure if we could defer this until it's needed too. |
Thanks @tomwhite I'll check the |
It would be great if we could take advantage of forward references. Do you think xarray itself is doing unnecessary imports - like the tutorial? |
Yes, planning on checking and raising a PR/issue upstream, unless it looks like a rabbit-hole! |
Also see pydata/xarray#6726, seems they are aware of the issue. |
If we're importing some things just for typing purposes, then I'd be +1 for making the typing less strict. |
Pandas is not used very much in the codebase, so it might be possible to import it lazily. Similarly, the distance API is pretty niche so making that lazier would be good too. |
For tools using the CLI this amount of delay feels excessive. Around 1s of this time is performing imports. Here's the import flame graph:
(0.1s on
xarray.tutorial
?!?)I assume some of these could be imported only when they are needed - although given that many of the imports are referenced in typing specifications that might not be possible.
I'm not sure yet what the remaining 0.5s is - a cProfile callgraph is pretty useless on import but I think there is a way around that by profiling the individual sgkit files.
The text was updated successfully, but these errors were encountered: