diff options
author | Eugeniy E. Mikhailov <evgmik@gmail.com> | 2024-07-17 21:27:21 -0400 |
---|---|---|
committer | Eugeniy E. Mikhailov <evgmik@gmail.com> | 2024-07-17 21:27:21 -0400 |
commit | 9daa9285e29e1baa66830dc6c9baed56c21f4c2f (patch) | |
tree | 40c464f1158d58baa6dcf5f9957532ebcd514a69 /qolab/hardware | |
parent | a590a578a57891922dba0c95d9e883f5489af655 (diff) | |
download | qolab-9daa9285e29e1baa66830dc6c9baed56c21f4c2f.tar.gz qolab-9daa9285e29e1baa66830dc6c9baed56c21f4c2f.zip |
refactor power supply to avoid circular loads
Diffstat (limited to 'qolab/hardware')
-rw-r--r-- | qolab/hardware/power_supply/__init__.py | 43 | ||||
-rw-r--r-- | qolab/hardware/power_supply/_basic.py | 44 | ||||
-rw-r--r-- | qolab/hardware/power_supply/keysight_e3612a.py | 2 |
3 files changed, 48 insertions, 41 deletions
diff --git a/qolab/hardware/power_supply/__init__.py b/qolab/hardware/power_supply/__init__.py index 6635584..76b812c 100644 --- a/qolab/hardware/power_supply/__init__.py +++ b/qolab/hardware/power_supply/__init__.py @@ -1,42 +1,5 @@ -from qolab.hardware.scpi import SCPIinstr -from qolab.hardware.basic import BasicInstrument +"""Power supplies.""" +from .keysight_e3612a import KeysightE3612A -class PowerSupply(BasicInstrument): - """Base class for a Power Supply. - - Contains minimal set of methods to be implemented by a Power Supply. - - Intended to be used as a parent for hardware aware power supplies. - """ - - def __init__(self, *args, **kwds): - BasicInstrument.__init__(self, *args, **kwds) - self.config["Device type"] = "PowerSupply" - self.config["Device model"] = ( - "Generic Power Supply generator Without Hardware interface" - ) - self.config["FnamePrefix"] = "power_supply" - self.deviceProperties.update({}) - - -class PowerSupplySCPI(SCPIinstr, PowerSupply): - """SCPI aware power supply. - - Intended to be used as a parent for hardware aware power supplies. - - Example - ------- - - >>> rm = pyvisa.ResourceManager() - >>> PowerSupplySCPI(rm.open_resource('TCPIP::192.168.0.2::INSTR')) - - or - - >>> PowerSupplySCPI(rm.open_resource('USB0::10893::4354::MY61001869::0::INSTR')) - """ - - def __init__(self, resource, *args, **kwds): - SCPIinstr.__init__(self, resource) - PowerSupply.__init__(self, *args, **kwds) - self.config["DeviceId"] = str.strip(self.idn) +__all__ = ["KeysightE3612A"] diff --git a/qolab/hardware/power_supply/_basic.py b/qolab/hardware/power_supply/_basic.py new file mode 100644 index 0000000..265ee32 --- /dev/null +++ b/qolab/hardware/power_supply/_basic.py @@ -0,0 +1,44 @@ +"""Basic class to build hardware avare classes of power supplies.""" + +from qolab.hardware.scpi import SCPIinstr +from qolab.hardware.basic import BasicInstrument + + +class PowerSupply(BasicInstrument): + """Base class for a Power Supply. + + Contains minimal set of methods to be implemented by a Power Supply. + + Intended to be used as a parent for hardware aware power supplies. + """ + + def __init__(self, *args, **kwds): + BasicInstrument.__init__(self, *args, **kwds) + self.config["Device type"] = "PowerSupply" + self.config[ + "Device model" + ] = "Generic Power Supply generator Without Hardware interface" + self.config["FnamePrefix"] = "power_supply" + self.deviceProperties.update({}) + + +class PowerSupplySCPI(SCPIinstr, PowerSupply): + """SCPI aware power supply. + + Intended to be used as a parent for hardware aware power supplies. + + Example + ------- + + >>> rm = pyvisa.ResourceManager() + >>> PowerSupplySCPI(rm.open_resource('TCPIP::192.168.0.2::INSTR')) + + or + + >>> PowerSupplySCPI(rm.open_resource('USB0::10893::4354::MY61001869::0::INSTR')) + """ + + def __init__(self, resource, *args, **kwds): + SCPIinstr.__init__(self, resource) + PowerSupply.__init__(self, *args, **kwds) + self.config["DeviceId"] = str.strip(self.idn) diff --git a/qolab/hardware/power_supply/keysight_e3612a.py b/qolab/hardware/power_supply/keysight_e3612a.py index f843795..62336e3 100644 --- a/qolab/hardware/power_supply/keysight_e3612a.py +++ b/qolab/hardware/power_supply/keysight_e3612a.py @@ -1,5 +1,5 @@ from qolab.hardware.basic import BasicInstrument -from qolab.hardware.power_supply import PowerSupplySCPI +from ._basic import PowerSupplySCPI import time |