aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEugeniy E. Mikhailov <evgmik@gmail.com>2021-12-01 11:26:39 -0500
committerEugeniy E. Mikhailov <evgmik@gmail.com>2021-12-01 11:26:39 -0500
commit9f1c2db9d296dc17f86e1f22634a14063b1d0a72 (patch)
tree1b50709ed0ef78888bcb61e2b0e97ec6916589a8
parent642c6f937a2826cb92b8f83b5b61a4c17d551e2c (diff)
downloadqolab-9f1c2db9d296dc17f86e1f22634a14063b1d0a72.tar.gz
qolab-9f1c2db9d296dc17f86e1f22634a14063b1d0a72.zip
improve hardware definitions
-rw-r--r--hardware/scope/__init__.py23
-rw-r--r--hardware/scope/sds1104x.py6
-rw-r--r--hardware/scpi.py (renamed from scpi.py)4
3 files changed, 20 insertions, 13 deletions
diff --git a/hardware/scope/__init__.py b/hardware/scope/__init__.py
index e6b6573..23462a7 100644
--- a/hardware/scope/__init__.py
+++ b/hardware/scope/__init__.py
@@ -2,21 +2,30 @@
Provide basic class to operate scope
Created by Eugeniy E. Mikhailov 2021/11/29
"""
-import scpi
+from hardware.scpi import SCPIinstr
-class Scope(scpi.SCPIinstr):
- """
- Do not instantiate directly, use
- rm = pyvisa.ResourceManager()
- Scope(rm.open_resource('TCPIP::192.168.0.2::INSTR'))
- """
+class Scope:
# Minimal set of methods to be implemented by a scope.
# Should work with minimal arguments list
# but might be faster if parameters provided: less IO requests
+ def __init__(self):
+ self.numberOfChannels = 0
+
def getTrace(self, chNum, availableNpnts=None, maxRequiredPoints=None):
warnings.warn( 'this function is not implemented' )
+class ScopeSCPI(SCPIinstr, Scope):
+ """
+ Do not instantiate directly, use
+ rm = pyvisa.ResourceManager()
+ ScopeSCPI(rm.open_resource('TCPIP::192.168.0.2::INSTR'))
+ """
+ pass
+ def __init__(self, resource):
+ SCPIinstr.__init__(self, resource)
+ Scope.__init__(self)
+
from .sds1104x import SDS1104X
diff --git a/hardware/scope/sds1104x.py b/hardware/scope/sds1104x.py
index 53e945a..23ac1be 100644
--- a/hardware/scope/sds1104x.py
+++ b/hardware/scope/sds1104x.py
@@ -3,19 +3,19 @@ Provide basic class to operate scope
Created by Eugeniy E. Mikhailov 2021/11/29
"""
-from hardware.scope import Scope
+from hardware.scope import ScopeSCPI
from datatrace import DataTrace
import re
import numpy as np
-class SDS1104X(Scope):
+class SDS1104X(ScopeSCPI):
""" Siglent SDS1104x scope """
vertDivOnScreen = 10
horizDivOnScreen = 14
- numberOfChannels = 4
def __init__(self, resource):
super().__init__(resource)
self.resource.read_termination='\n'
+ self.numberOfChannels = 4
self.maxRequiredPoints = 1000; # desired number of points per channel, can return twice more
def response2numStr(self, strIn, firstSeparator=None, unit=None):
diff --git a/scpi.py b/hardware/scpi.py
index 5e548ef..279ef24 100644
--- a/scpi.py
+++ b/hardware/scpi.py
@@ -1,9 +1,7 @@
"""
-provide basic class to operate Lock-in
+provide basic class to operate SCPI capable instruments
"""
-import pyvisa
-
class SCPIinstr:
""" Basic class which support SCPI commands """
"""