From 70b29f69a4585c75b02d0c4b7f3b79de22ee7361 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ingmar=20In=CA=92o=20Splitt?= Date: Wed, 9 Feb 2022 12:05:03 +0100 Subject: [PATCH 1/2] Update keithley_driver.py add support for "with ..." context-manager --- keithley2600/keithley_driver.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/keithley2600/keithley_driver.py b/keithley2600/keithley_driver.py index a80e5bd..730a6c4 100644 --- a/keithley2600/keithley_driver.py +++ b/keithley2600/keithley_driver.py @@ -568,6 +568,13 @@ def __init__( def __repr__(self) -> str: return f"<{self.__class__.__name__}({self.visa_address})>" + + def __enter__(self): + self.connection.write("errorqueue.clear()") + return self + + def __exit__(self, *args): + self.disconnect() # ============================================================================= # Connect to keithley From 37d98dc5ec87bd6bfd79f0908adc8611be9313eb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ingmar=20In=CA=92o=20Splitt?= Date: Fri, 23 Sep 2022 12:58:09 +0200 Subject: [PATCH 2/2] add documentation --- README.md | 20 ++++++++++++++++++++ keithley2600/keithley_driver.py | 8 ++++++++ 2 files changed, 28 insertions(+) diff --git a/README.md b/README.md index 2a247cf..9390d5d 100644 --- a/README.md +++ b/README.md @@ -52,6 +52,7 @@ $ pip install git+https://github.com/OE-FET/keithley2600 ## Usage Connect to the Keithley 2600 and perform some base commands: + ```python from keithley2600 import Keithley2600 @@ -65,6 +66,25 @@ i = k.smua.measure.i() # measures current at smuA k.smua.measure.v(k.smua.nvbuffer1) # measures the voltage, stores the result in buffer k.smua.nvbuffer1.clear() # clears nvbuffer1 of SMUA ``` + +Alternatively, the device can be used in a context: + +```python +from keithley2600 import Keithley2600 + +with Keithley2600('TCPIP0::192.168.2.121::INSTR') as kth: + kth.reset() + smu = kth.smua + smu.sense = smu.SENSE_REMOTE + smu.source.limiti = 0.01 # mA + smu.source.autorangev = smu.AUTORANGE_ON + smu.source.func = smu.OUTPUT_DCVOLTS + smu.measure.autozero = smu.AUTOZERO_AUTO + smu.measure.autorangei = smu.AUTORANGE_ON + smu.measure.nplc = 16 + smu.source.levelv = 3.3 + smu.source.output = smu.OUTPUT_ON +``` Higher level commands defined in the driver: ```python diff --git a/keithley2600/keithley_driver.py b/keithley2600/keithley_driver.py index 730a6c4..c9b662a 100644 --- a/keithley2600/keithley_driver.py +++ b/keithley2600/keithley_driver.py @@ -570,6 +570,14 @@ def __repr__(self) -> str: return f"<{self.__class__.__name__}({self.visa_address})>" def __enter__(self): + """ + Allows usage in contexts ("with Keithley2600() as kth:") + + - cleaning the error-queue helps with faulty scripts that leave the SMU in a + weird state + - restarting the script often fails at basic tasks (like accessing keithley.smua) + because the TSP-Command-Set wasn't read successfully (or other weird behavior). + """ self.connection.write("errorqueue.clear()") return self