Changeset 13807


Ignore:
Timestamp:
05/21/12 19:40:51 (13 years ago)
Author:
neise
Message:
Evolving
Location:
fact/tools/PyDimCtrl
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • fact/tools/PyDimCtrl/fpydim.py

    r13805 r13807  
    2828        self.reg_state_cb()
    2929        self.reg_msg_cb()
     30        self.user_func = None
    3031
    3132    def _cmd(self, cmdstr, *args):
     
    9697            print "list_of_states too long, truncating..."
    9798            self.list_of_states = self.list_of_states[1000:]
     99           
     100        if self.user_func:
     101            self.user_func( self.stn )
     102       
    98103        if self.print_state:
    99104            print state
  • fact/tools/PyDimCtrl/service.py

    r13806 r13807  
    9999    time.sleep(CalmDownTime)
    100100    return True
    101 
    102 def PrepareBias( verbose = True):
    103     msg = MSG()
    104     msg.output = verbose
    105     bias = bias_control
    106 
    107     if feedback() != 12:
    108         msg.warn("feedback is not in Current Control")
    109         return False
    110 
    111     bias.set_global_dac(1)
    112     if not bias.wait(9, 10):
    113         msg.warn("bias not in Voltage ON after 10sec")
    114         return False
    115     if not bias.wait(5, 10):
    116         msg.warn("bias not Ramping after 10sec")
    117         return False
    118     if not bias.wait(9, 30):
    119         msg.warn("bias not fully ramped up after 30sec")
    120         return False
    121 
    122     msg("waiting 45sec...")   
    123     time.sleep(45)
    124     return True
    125 
    126101def TakePedestalOnRun( verbose = True ):
    127102    msg = MSG()
     
    188163    return True
    189164
    190 def TakeDrsCalibration( verbose = True):
    191     msg = MSG()
    192     msg.output = verbose
    193     bias = bias_control
    194     fad = fad_control
    195 
    196     bias.set_zero_voltage()
    197     if not bias.wait(7, 10):
    198         msg.warn("bias has not switched of after 10sec")
    199         return False
    200     fad.start_drs_calibration()
    201     Take( -1, 1000, 'drs-pedestal')
    202     Take( -1, 1000, 'drs-gain')
    203     Take( -1, 1000, 'drs-pedestal')
    204     fad.set_file_format(2)
    205     Take( -1, 1000, 'drs-pedestal')
    206     Take( -1, 1000, 'drs-time')
    207     Take( -1, 1000, 'drs-time-upshifted')
    208     fad.reset_secondary_drs_baseline()
    209     Take(-1, 1000, 'pedestal')
    210     fad.set_file_format(2)
    211     Take(-1, 1000, 'pedestal')
    212165
    213166def BlinkenLights(verbose = True):
     
    221174        time.sleep(1)
    222175
    223 def TakeAmplCalib( roi=1024, verbose=True):
    224     msg = MSG(verbose)
    225     bias = bias_control
    226     fad  = fad_control
    227     if (roi!=1024) and (roi!=300):
    228         raise ValueError('roi must be 300 or 1024')
    229     # I do not understand, why the out put needs to be ENABLED??
    230     feedback.enable_output(0)
    231     bias.set_zero_voltage()
    232     bias.wait(7) # VoltageOff
    233     fad.start_drs_calibration
    234    
    235     Take(-1, 1000, 'drs-pedestal')
    236     Take(-1, 1000, 'drs-gain')
    237     if roi == 300:
    238         Take(-1, 1000, 'pedestal')
    239     if roi == 1024:
    240         Take(-1, 1000, 'drs-pedestal')
    241 
    242     fad.set_file_format(2)
    243     if roi == 300:
    244         Take(-1, 1000, 'pedestal')
    245     if roi == 1024:
    246         Take(-1, 1000, 'drs-pedestal')
    247 
    248 def TakeTimeCalib( verbose=True ):
    249     msg = MSG( verbose )
    250     feedback.enable_output(0)
    251     if bias() != 7:
    252         bias.set_zero_voltage()
    253         if not bias.wait(7, 10):
    254             msg.warn("bias not ramped down after 10sec")
    255             return False
    256     fad.set_file_format(2)
    257     Take(-1, 1000, 'drs-time')
    258     Take(-1, 1000, 'drs-time-upshifted')
    259 
    260 
    261 
    262 
    263 def Connect( verbose=True ):
    264 
     176
     177
     178
     179#==============================================================================
     180def Connect():
    265181    prepare_ftm_control()
    266182    prepare_fsc_control()
     
    269185    prepare_feedback()
    270186    prepare_data_logger()
    271    
    272187
    273188def prepare_fsc_control( verbose = True, timeout = 10, delay = 0.2):
     
    516431
    517432
     433
     434#==============================================================================
     435def TakeDrsAmplitudeCalibration( roi = None, verbose = True):
     436    """ Takes DRS Amplitude Calibration
     437        *roy* integer: 300, 1024 or
     438        *roy* string : 'both'
     439        in case of both, the roi=300 calibration is done last.
     440       
     441        after each complete AmpliteCalibration a 4th pedestal run of the same
     442        roi is taken, for crosschecking.
     443        """
     444    msg = MSG( verbose )
     445    bias = bias_control
     446    fad = fad_control
     447    if not roi in [300,1024,'both']:
     448        raise ValueError("roi must be 300,1024 or the string 'both'")
     449
     450
     451    bias.set_zero_voltage()
     452    if not bias.wait(7, 10):
     453        msg.warn("bias has not switched of after 10sec")
     454        return False
     455
     456    fad.start_drs_calibration()
     457    Take( -1, 1000, 'drs-pedestal')
     458    Take( -1, 1000, 'drs-gain')
     459    if roi == 300:
     460        Take( -1, 1000, 'pedestal')
     461        fad.set_file_format(2)
     462        Take( -1, 1000, 'pedestal')
     463    elif roi == 1024:
     464        Take( -1, 1000, 'drs-pedestal')
     465        fad.set_file_format(2)
     466        Take( -1, 1000, 'drs-pedestal')
     467    elif roi == 'both':
     468        Take( -1, 1000, 'drs-pedestal')
     469        fad.set_file_format(2)
     470        Take( -1, 1000, 'drs-pedestal')
     471        fad.reset_secondary_drs_baseline()
     472        Take( -1, 1000, 'pedestal')
     473        fad.set_file_format(2)
     474        Take( -1, 1000, 'pedestal')
     475
     476
     477def TakeDrsTimeCalibration( mode = None, verbose = True):
     478    """ Takes DRS Time Calibration
     479        *mode* can be 'upshifted', 'old' or 'both'
     480    """
     481    msg = MSG( verbose )
     482    bias = bias_control
     483    fad = fad_control
     484    if not mode in ['upshifted', 'old', 'both']:
     485        raise ValueError("mode must be: 'upshifted','old' or 'both'")
     486
     487    bias.set_zero_voltage()
     488    if not bias.wait(7, 10):
     489        msg.warn("bias has not switched of after 10sec")
     490        return False
     491
     492    fad.set_file_format(2)
     493    if mode == 'old':
     494        Take(-1, 1000, 'drs-time')
     495    if mode == 'upshifted':
     496        Take(-1, 1000, 'drs-time-upshifted')
     497    if mode == 'both':
     498        Take(-1, 1000, 'drs-time')
     499        Take(-1, 1000, 'drs-time-upshifted')
     500
     501
     502def VoltageOn( mode = None, Watchdog = None, verbose = True):
     503    msg = MSG( verbose )
     504    bias = bias_control
     505    fb = feedback
     506
     507    if not mode in ['temperature', 'current', 'feedback']:
     508        raise ValueError("mode must be 'temperature', 'current' or 'feedback'")
     509   
     510    feedback.start(..... blaaaaa .....)
     511    hier muss noch ne menge passieren
     512   
     513    bias.set_global_dac(1)
     514    if not bias.wait(9, 10):
     515        msg.warn("bias not in Voltage ON after 10sec")
     516        return False
     517    if not bias.wait(5, 10):
     518        msg.warn("bias not Ramping after 10sec")
     519        return False
     520    if not bias.wait(9, 30):
     521        msg.warn("bias not fully ramped up after 30sec")
     522        return False
     523
     524    msg("waiting 45sec...")   
     525    time.sleep(45)
     526    return True
     527
     528# standard watchdogs:
     529def std_bias_watchdog( state, verbose=True ):
     530    msg = MSG(verbose)
     531    if state == 1: #Disconnected
     532        msg.warn("BIAS just DISCONNECTED .. trying to reconnect")
     533        msg.warn("current runnumber:"+fad_control.runnumber() )
     534        bias.reconnect()
     535        time.sleep(1)
     536        bias.set_zero_voltage()
     537        # TODO: This should work, but it is stupid.
     538        bias.reset_over_current_status()
     539        bias.reset_over_current_status()
     540        bias.set_zero_voltage()
     541        bias.reset_over_current_status()
     542        bias.set_global_dac(1)
    518543
    519544# create introduction:
Note: See TracChangeset for help on using the changeset viewer.