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

Iterate object tracing #1882

Open
wants to merge 12 commits into
base: develop
Choose a base branch
from
Open

Iterate object tracing #1882

wants to merge 12 commits into from

Conversation

rcooke-ast
Copy link
Collaborator

A user reported that the object traces are sometimes bad. I looked into this, and it appears to occur when the slit edges are not known, and the initial trace profile is no good. Successively iterating over the trace profile improve the result considerably. See screenshots below of the before (left) and after (right) when the masking near the bottom of the image disappears in the new version. Running dev suite now.

image

Copy link
Collaborator

@kbwestfall kbwestfall left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have one minor comment. I'm mostly selecting "request changes" just to make sure we run tests.

@@ -4206,6 +4206,11 @@ def __init__(self, trace_npoly=None, snr_thresh=None, find_trim_edge=None,
dtypes['find_maxdev'] = [int, float]
descr['find_maxdev'] = 'Maximum deviation of pixels from polynomial fit to trace used to reject bad pixels in trace fitting.'

defaults['find_numiterfit'] = 10
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm wary of changing the default behavior for all datasets. Is that justified? Can we instead set this to 1 (or whatever the equivalent is to recover the current behavior) and then advertise that this option now exists and how it can improve traces? That will give us some time to decide if we want to change the default behavior.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, I think that's a fair point 👍 In principle, a good trace should simply break out of the loop during the 2nd iteration, since the only thing that changes is the initial guess. If the initial guess is close to the final position, nothing should change in the second iteration for a good fit.

@rcooke-ast
Copy link
Collaborator Author

Tests pass...
image

Copy link
Collaborator

@kbwestfall kbwestfall left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the updates and confirming the tests pass!

Copy link
Collaborator

@jhennawi jhennawi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @rcooke-ast I don't agree with this PR.

  1. The fit_trace function that is being called is already performing iterations. So now you are just performing iterations on top of iterations in a double loop. There are already maxdev criteria implemented in that routine as well, and now you apply them again. This outer loop complicates the code with no added value or functionality, since all that functionality is already provided in fit_trace. It is possible that more iterations are needed or better trace converge criteria are needed, but those should be implemented in fit_trace not objs_in slit.

  2. There are detailed QA options to show these fits and how they are progressing in fit_trace, by enabling the debug option. None of those plots are being shown. Instead you just show a screenshot of a bright object which does not provide any insight on the source of the problem. Furthermore, those traces look identical by eye, which is why we developed the detailed QA in fit_trace.

  3. I'm not following your point about the slit edges not being known, but it suggests that the issue with the slit edges and not the object tracing. Nevertheless, we want the tracing to be robust against such cases. But I suspect the issue here is that your slits appear to be at a detector boundary. In that case, slit edges can end up being vertical lines, which is bad for object tracing. We have built in functionality already to make sure that the slit edge at the boundary is replaced by a curve with the shape of the well traced boundary, to deal with this problem. It could be something is not working properly there, so pasting on extra code in object tracing is not a good solution to such a problem if that is indeed the issue.

Take a look at my suggestions and let's then diagnose the problem properly and figure out how to make the code more robust if there are still issues.

@rcooke-ast
Copy link
Collaborator Author

Thanks for your thoughts @jhennawi. When debug=True, here is the QA (response to your point 2):

image
  1. The fit_trace function that is being called is already performing iterations.

When you say "performing iterations", do you mean that it uses a first guess, and then re-calculates the trace based on a better initial guess? This is the only repeated calculation that is performed. I'm proposing that we iterate over the second step, if needs be.

I'm not following your point about the slit edges not being known, but it suggests that the issue with the slit edges and not the object tracing.

You are correct, the detector edges are not known, and are simply vertical lines. Also, this is the standard star trace, so we cannot use that as a crutch.

@jhennawi
Copy link
Collaborator

No fit_trace does iterative fitting already with an initial guess/crutch that is dynamically updated. Let's discuss on Slack.

@rcooke-ast
Copy link
Collaborator Author

Thanks @jhennawi for the suggestion. I've now implemented the number of iterations as a free parameter, instead of being hard-coded. This produces equally good results.

Copy link
Collaborator

@jhennawi jhennawi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks @rcooke-ast. A very minor change requested related than orphan line. But otherwise approved.

@@ -1904,17 +1911,18 @@ def objs_in_slit(image, ivar, thismask, slit_left, slit_righ,
msgs.info("Automatic finding routine found {0:d} objects".format(len(sobjs)))

# Fit the object traces
tolerance = 0.1 # Tolerance in pixels before the trace fit has converged
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This line should be removed right, tolerance since it is no longer used?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good catch - I've removed this.

@rcooke-ast
Copy link
Collaborator Author

Tests pass, except for one failure in skysub, which is a failure that is also in the develop branch, so unrelated to this PR.


this PR tests:

image

develop tests:

image

# Conflicts:
#	doc/releases/1.17.2dev.rst
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants