Skip to content

Commit

Permalink
Merge branch 'master' into PR-update-version
Browse files Browse the repository at this point in the history
  • Loading branch information
xresende committed Feb 18, 2020
2 parents 73a763a + b0155cf commit a62024b
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 10 deletions.
9 changes: 4 additions & 5 deletions siriuspy/siriuspy/cycle/conn.py
Original file line number Diff line number Diff line change
Expand Up @@ -379,7 +379,6 @@ def check_on(self):
def set_current_zero(self):
"""Set PS current to zero ."""
status = _pv_conn_put(self['Current-SP'], 0)
_time.sleep(SLEEP_CAPUT)
return status

def check_current_zero(self, wait=5):
Expand Down Expand Up @@ -503,15 +502,15 @@ def check_final_state(self, mode):
if not status:
return 3 # indicate cycling not finished yet

status = self.check_intlks()
if not status:
return 4 # indicate interlock problems

status = self.set_opmode_slowref()
status &= self.check_opmode_slowref()
if not status:
return 2 # indicate opmode is not in slowref yet

status = self.check_intlks()
if not status:
return 4 # indicate interlock problems

return 0

def __getitem__(self, prop):
Expand Down
68 changes: 64 additions & 4 deletions siriuspy/siriuspy/cycle/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
TIMEOUT_SLEEP = 0.1
TIMEOUT_CHECK = 20
TIMEOUT_CONN = 0.5
TIMEOUT_CHECK_SI_CURRENTS = 41


class CycleController:
Expand Down Expand Up @@ -65,19 +66,24 @@ def __init__(self, cyclers=dict(), timing=None,

self.prepare_ps_size = 2*len(self.psnames)+1
self.prepare_ps_max_duration = 20
if 'SI' in self._sections:
# set and check currents to zero
self.prepare_ps_size += 3*len(self.psnames)
self.prepare_ps_max_duration += \
TIMEOUT_CHECK + TIMEOUT_CHECK_SI_CURRENTS

self.cycle_size = (len(self.psnames)+3 + # check params
len(self.psnames) + # check opmode
1+round(self._cycle_duration) + # cycle
len(self.psnames) + # check final
len(self.psnames)+2) # reset subsystems
self.cycle_max_duration = (
2 + # check params
2 + # check opmode
5 + # check params
5 + # check opmode
TIMEOUT_CHECK*3 + # wait for timing trigger
round(self._cycle_duration) + # cycle
2 + # check final
2) # reset subsystems
5 + # check final
5) # reset subsystems

# logger
self._logger = logger
Expand All @@ -97,6 +103,59 @@ def mode(self):
"""Mode."""
return self._mode

def set_check_si_pwrsupplies_currents_zero(self):
"""Zero currents of all SI power supplies."""
if 'SI' not in self._sections:
return

psnames = _PSSearch.get_psnames(
{'sec': 'SI', 'dis': 'PS', 'dev': '(B|Q|S|CH|CV)'})

# create cyclers, if needed
cyclers = dict()
for psname in psnames:
if psname in self.cyclers:
cyclers[psname] = self.cyclers[psname]
else:
self._update_log('Connecting to '+psname+'...')
cyclers[psname] = PSCycler(psname)

# wait for connections
for cycler in cyclers.values():
cycler.wait_for_connection()

# set currents to zero
for psname, cycler in cyclers.items():
self._update_log('Setting '+psname+' current to zero...')
cycler.set_current_zero()

# check currents zero
need_check = _dcopy(psnames)
self._checks_result = dict()
t = _time.time()
while _time.time() - t < TIMEOUT_CHECK_SI_CURRENTS:
for psname in psnames:
if psname not in need_check:
continue
if cyclers[psname].check_current_zero():
need_check.remove(psname)
self._checks_result[psname] = True
if not need_check:
break
_time.sleep(TIMEOUT_SLEEP)
for psname in need_check:
self._checks_result[psname] = False

status = True
for psname in psnames:
self._update_log('Checking '+psname+' currents...')
if self._checks_result[psname]:
self._update_log(done=True)
else:
self._update_log(psname+' current is not zero.', error=True)
status &= False
return status

def config_all_pwrsupplies(self, ppty):
"""Prepare power supplies to cycle according to mode."""
if ppty == 'opmode':
Expand Down Expand Up @@ -323,6 +382,7 @@ def prepare_timing(self):

def prepare_pwrsupplies_parameters(self):
"""Prepare to cycle."""
self.set_check_si_pwrsupplies_currents_zero()
self.config_all_pwrsupplies('parameters')
if not self.check_all_pwrsupplies('parameters'):
self._update_log(
Expand Down
2 changes: 1 addition & 1 deletion siriuspy/siriuspy/cycle/util.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

def get_psnames():
"""Return psnames."""
names = _PSSearch.get_psnames({'sec': '(LI|TB|BO|TS)', 'dis': 'PS'})
names = _PSSearch.get_psnames({'sec': '(LI|TB|TS)', 'dis': 'PS'})
names.extend(_PSSearch.get_psnames(
{'sec': 'SI', 'sub': 'Fam', 'dis': 'PS', 'dev': '(B|Q.*|S.*)'}))
names.extend(_PSSearch.get_psnames(
Expand Down

0 comments on commit a62024b

Please sign in to comment.