Skip to main content

Python library and CLI for our custom electron gun slow-control system

Project description

Custom electron gun slow control Python communication library and GUI utlity

Work in progress

Communication library

The communication library from eguncom.py implements most of the communication protocol with the electron beam slow-control system.

class ElectronGunControl

The ElectronGunControl class implements asynchronous and synchronous communication with the serially / USB attached control system. The port file is passed to the constructor

ctrl = ElectronGunNotConnected(portFile = '/dev/...')

When no port file is passed it defaults to /dev/ttyU0.

The exposed public methods are:

Method Description Synchronous Asynchronous callback
id() Queries the current version with sync = True cbIdentify(controller, versionDate, versionRevision)
getPSUVoltage(channel) Queries the current voltage on the given channel with sync = True cbVoltage(controller, channel, voltageVolts)
getPSUCurrent(channel) Queries the current current on the given channel with sync = True cbCurrent(controller, channel, currentMicroamps)
getPSUModes() Checks if PSUs are off, in voltage limited or current limited mode with sync = True cbPSUMode(controller, states)
getFilamentCurrent() Queries the filament current with sync = True cbFilamentCurrent(controller, current)
off() Disabled all high voltage and filament currents
setPSUPolarity(channel, polarity) Sets polarity to POLARITY_POS or POLARITY_NEG
setPSUEnable(channel) Enables the given PSU channel
setPSUDisable(channel) Disables the given PSU channel
setPSUVoltage(channel, voltage) Sets the given channel to the given voltage
setFilamentCurrent(currentMa) Sets the filament current or target current to the specified milliamps
setFilamentOn() Enabled the filament supply
setFilamentOff() Disabled the filament supply
runInsulationTest() Runs an insulation test with low current limits with sync = True cbInsulation(isOk, listOfShorts)
beamOn() Runs the slow beam on sequence (slowly heating filament to previously set setFilamentCurrent, ramping up voltages) with sync = True cbBeamon()

Usage example

Synchronous sample (USB / serial)

Example to perform a synchronous:

  • Insulation check
  • Startup for 100 mA beam current
  • Looping through focus voltages
  • Shutting down
with ElectronGunControl() as ctrl:
    # Currently a hack to wait for the control system to reset when using the
    # primary port

    time.sleep(5)

    # We want to see the voltages reported by the system so we
    # define a lambda that just prints the voltages while ramping up
    # during insulation test and beam on sequence

    ctrl.cbVoltage = lambda c,chan,v : print("Voltage for channel {} is {} V".format(chan, v))

    # Query it's identity
    ret = ctrl.id(sync = True)
    print("ID call returned {}".format(ret))

    # Run insulation test
    print("Running insulation test")
    ret = ctrl.runInsulationTest(sync = True)
    print("Insulation test returned: {}".format(ret))

    # Run beam on sequence ...
    ret = ctrl.beamOn(sync = True)
    print("Beam on successfully returned: {}".format(ret))

    print("Sweeping focus voltage")
    for focusVoltage in range(1750,1950):
        print("New focus voltage {}".format(focusVoltage))
        ctrl.setPSUVoltage(3, focusVoltage)
        time.sleep(1)

    ctrl.off()
    print("Off, done ...")

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

File details

Details for the file electronsourcecontroller2-tspspi-0.0.8.tar.gz.

File metadata

File hashes

Hashes for electronsourcecontroller2-tspspi-0.0.8.tar.gz
Algorithm Hash digest
SHA256 180c3b4a6a92eb57b9c1f3a748e4177cc7d5bcfcfa24045c0e67f089ee11d0de
MD5 06011ae4d9466fd80c440500db05c428
BLAKE2b-256 0a8ddb99e2e8e2ee8a5322bd1eb9a548e26a5871a8769a3a17928329f8a811cd

See more details on using hashes here.

File details

Details for the file electronsourcecontroller2_tspspi-0.0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for electronsourcecontroller2_tspspi-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 58b60b3495ac4e1147ce09fd1a7c05a410365c0fb33247afd99a9057843a77d3
MD5 7aec3d3e19cfd899f2acf1423e14c97e
BLAKE2b-256 e9ad7fb4b36b2ea997b35f94d9fbb52b0b0beac552bb10f94ba49103a2cf3b70

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page