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

Settling times for the SR-570 Preamplifier #910

Merged
merged 11 commits into from
Jan 23, 2024

Conversation

canismarko
Copy link
Collaborator

When changing gain on the SR-570 pre-amp, the voltage output spikes momentarily, and then settles down. Lower gain values settle faster. This PR adds a settling time to gain-related signals that depends on the target gain, based on measurements of the pre-amps at sector 25-ID-C. Presumably, other SR-570 preamps should be similar.

Fixes #906

@canismarko canismarko requested a review from prjemian January 18, 2024 21:42
@canismarko
Copy link
Collaborator Author

By the way, this PR does add a lot of tests (~72), but they're parameterized and run in under a second. Hopefully that's okay. They basically test all the possible combinations of gain values.

return super().set(value, timeout=timeout, settle_time=_settle_time)


class GainSignal(GainMixin, EpicsSignal):
Copy link
Contributor

Choose a reason for hiding this comment

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

Is it necessary to separate the code of GainMixin from GainSignal? In addition to the use here, will the mixin be used somewhere else?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

It was originally going to be used in a pcdsdevices MultiDerivedSignal class. I re-factored it to no longer need it that way. Happy to re-combine the mixin with the signal.

Copy link
Contributor

Choose a reason for hiding this comment

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

Better to recombine if you do not see an additional use.

@prjemian
Copy link
Contributor

All tests pass locally. Noting that GainMixin is not tested explicitly:

$ git grep GainMixin
apstools/devices/srs570_preamplifier.py:class GainMixin:
apstools/devices/srs570_preamplifier.py:class GainSignal(GainMixin, EpicsSignal):


Used to introduce a specific settle time when setting to account
for the amp's R–C relaxation time when changing gain.

Copy link
Contributor

Choose a reason for hiding this comment

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

this blank line can be deleted

--------
Signal.set
EpicsSignal.set

Copy link
Contributor

Choose a reason for hiding this comment

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

Is this blank line needed?


Used to introduce a specific settle time when setting to account
for the amp's R–C relaxation time when changing gain.

Copy link
Contributor

Choose a reason for hiding this comment

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

Is this blank line needed?

@canismarko
Copy link
Collaborator Author

I got rid of the GainMixin class. And also the _settle_time method since it's a static method and works just as well as a function. Assuming the tests pass, I think this is good?

Copy link
Contributor

@prjemian prjemian left a comment

Choose a reason for hiding this comment

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

LGTM! @canismarko - Please press the big green Merge button.

@canismarko canismarko merged commit 777d3cb into BCDA-APS:main Jan 23, 2024
11 of 13 checks passed
@canismarko canismarko deleted the gain_settling branch January 23, 2024 15:22
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

settling for SRS-570 Pre-amp gain settings
2 participants