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.3.tar.gz.

File metadata

File hashes

Hashes for electronsourcecontroller2-tspspi-0.0.3.tar.gz
Algorithm Hash digest
SHA256 1262ced15d9a0a154a4712cc65aa078eb9ed82130f28d2fdd300a4e62c251b4a
MD5 54b7afa48cbbefd0c0b46028b4936fcf
BLAKE2b-256 996961539fb66652b3edae9d1e1f8486b1d4f4bffd3156ff15915a6262e2c62f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for electronsourcecontroller2_tspspi-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d80f06b2d24f804f213b91b1b6b2ea5867b12cad0ac277e213ab2f51249d7753
MD5 6ae345a98d676102eec946e372493631
BLAKE2b-256 62be49a77b16e81d3a97e543488dc0505a0a5975d25834c4a8be3725b6791c75

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