|
@@ -16,75 +16,57 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
-import logging
|
|
|
|
-from collections import OrderedDict
|
|
|
|
-from time import sleep
|
|
|
|
-from typing import List, Iterator
|
|
|
|
-from Serial import Interface, drain_serial
|
|
|
|
|
|
|
|
-logger = logging.getLogger(__name__)
|
|
+from .Hardware import get_interfaces
|
|
|
|
+from .NanoVNA_V2 import NanoVNA_V2_H4
|
|
|
|
|
|
|
|
+class MetaVna(type):
|
|
|
|
+ def __call__(cls, *args, **kwargs):
|
|
|
|
+ return super(MetaVna, NanoVNA_V2_H4).__call__(*args, **kwargs)
|
|
|
|
|
|
-class VNA:
|
|
+class Vna:
|
|
- name = "VNA"
|
|
+ name = "Vna"
|
|
- wait = 0.05
|
|
|
|
|
|
|
|
- def __init__(self, iface: Interface):
|
|
+ def __init__(self, *args, **kwargs):
|
|
- self.iface = iface
|
|
+ super(Vna, self).__init__(*args, **kwargs)
|
|
- self.valid_freq = None
|
|
|
|
- self.valid_power = None
|
|
|
|
- self.valid_bw = None
|
|
|
|
- self.valid_points = None
|
|
|
|
|
|
|
|
|
|
|
|
- self.freq_start = None
|
|
|
|
- self.power = None
|
|
|
|
- self.points = None
|
|
|
|
- self.bw = None
|
|
|
|
-
|
|
|
|
def connect(self) -> bool:
|
|
def connect(self) -> bool:
|
|
- self.iface.open()
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
- return self.iface.isOpen()
|
|
|
|
|
|
|
|
def disconnect(self) -> bool:
|
|
def disconnect(self) -> bool:
|
|
- self.iface.close()
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
- return not self.iface.isOpen()
|
|
|
|
-
|
|
|
|
- def reconnect(self) -> bool:
|
|
|
|
- self.iface.close()
|
|
|
|
- sleep(self.wait)
|
|
|
|
- self.iface.open()
|
|
|
|
- return self.iface.isOpen()
|
|
|
|
|
|
|
|
def set_bw(self):
|
|
def set_bw(self):
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
def set_sweep(self, freq_start: float, freq_end: float, points: int):
|
|
def set_sweep(self, freq_start: float, freq_end: float, points: int):
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
def get_bw(self) -> float:
|
|
def get_bw(self) -> float:
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
- def get_sweep(self) -> List:
|
|
+ def get_sweep(self) -> list:
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
- def get_info(self) -> Dict:
|
|
+ def get_info(self) -> dict:
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
- def run(self) -> List:
|
|
+ def measure(self) -> list:
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
def set_power(self, power: float):
|
|
def set_power(self, power: float):
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
+
|
|
|
|
|
|
def get_power(self) -> float:
|
|
def get_power(self) -> float:
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
- def set_cal(self):
|
|
+ def set_cal(self):
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
def get_cal(self):
|
|
def get_cal(self):
|
|
- pass
|
|
+ assert NotImplementedError('Device does not support this method')
|
|
|
|
|
|
|
|
|
|
|
|
|