Skip to content
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

The P(r) inversion perspective takes extremely long on initial loading #3063

Open
butlerpd opened this issue Aug 18, 2024 · 4 comments
Open
Assignees
Labels
Critical High priority

Comments

@butlerpd
Copy link
Member

Describe the bug
When first switching to the P(r) inversion perspective, the perspective GUI appears nearly instantly. All buttons are grayed out as they should be with no data.

Sending the first data set to the perspective however takes roughly 15 s. before anything happens. All buttons, including values for the suggested parameter value buttons become active together. From now on, sending new data updates the suggested value parameters nearly instantly.

The fact that even the Remove data button also stays grayed out, coupled with the fact that this is only on the very first data load, suggests that there is some extra initialization happening when loading the first data set?

Note that while this extra 15s exists in 5.0.6 as well, everything is nearly instantaneous in version 4.2.2. So some strange 15 second wait time seems to have been introduced between 4.2.2 and 5.0.6.

To Reproduce
Steps to reproduce the behavior:

  1. load some data (e.g. apoferritin)
  2. send to Inversion (P(r)) and start a timer
  3. stop the timer once the boxes are populated
  4. Do the same in version 4.2.2

Expected behavior
The speed of 4.2.2 should be regained. At the very least, if there is some new computations needed for the initial setup they should start as soon as the inversion is requested. Or perhaps in a separate thread but on startup?

SasView version (please complete the following information):

  • Version: 6.0.0b2 and 5.0.6

Operating system (please complete the following information):

  • OS: Windows 10

Additional context
Identified while tracking and verifying bugs reported from the NIST CNR summer school. This also may be the source of a few reports that have not been possible to reproduce that "PR does not work" or "when sending data to inversion nothing happens".

@butlerpd butlerpd added the Critical High priority label Aug 18, 2024
@rozyczko rozyczko self-assigned this Aug 20, 2024
@rozyczko
Copy link
Member

There is a delay (6.0.0 installer, win10) but it's about 3-4s on my machine.
I'll profile the issue and see if it can be easily fixed for 6.0

@rozyczko
Copy link
Member

rozyczko commented Jan 9, 2025

The issue is the initial numba jit compilation of decorated methods in src\sas\sascalc\pr\calc.py, e.g.

@njit('f8[:](f8, u8, f8[:])')
def ortho(d_max, n, r):

This can't really be avoided completely, but can be cached. The first run will always incur the penalty of compilation (we don't want to include this in the startup, but instead make this part of the first invocation of P(r))

However, we can cache the compiled code and effectively remove the loading time for the follow up instantiations/file loads.

@rozyczko
Copy link
Member

rozyczko commented Jan 9, 2025

3063-the-pr-inversion-perspective-takes-extremely-long-on-initial-loading

@rozyczko
Copy link
Member

rozyczko commented Jan 9, 2025

The same situation happens on the initial load of the GSC - very long compile step for the numba-ized methods.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Critical High priority
Projects
None yet
Development

No branches or pull requests

2 participants