aboutsummaryrefslogtreecommitdiff
path: root/qolab/hardware/power_supply
diff options
context:
space:
mode:
authorEugeniy E. Mikhailov <evgmik@gmail.com>2024-07-17 21:27:21 -0400
committerEugeniy E. Mikhailov <evgmik@gmail.com>2024-07-17 21:27:21 -0400
commit9daa9285e29e1baa66830dc6c9baed56c21f4c2f (patch)
tree40c464f1158d58baa6dcf5f9957532ebcd514a69 /qolab/hardware/power_supply
parenta590a578a57891922dba0c95d9e883f5489af655 (diff)
downloadqolab-9daa9285e29e1baa66830dc6c9baed56c21f4c2f.tar.gz
qolab-9daa9285e29e1baa66830dc6c9baed56c21f4c2f.zip
refactor power supply to avoid circular loads
Diffstat (limited to 'qolab/hardware/power_supply')
-rw-r--r--qolab/hardware/power_supply/__init__.py43
-rw-r--r--qolab/hardware/power_supply/_basic.py44
-rw-r--r--qolab/hardware/power_supply/keysight_e3612a.py2
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