Long overdue upgrade to 0.3.7

Added Sysctl.py to handle retrieving pid/vid of comports [db]

Changelog						[upstream]
=========

v0.3.7
------

- Added a delta marker
- Segments can now have exponential different step widths
  (see logarithmic sweeping)
- More different data points selectable
  (shorter are useful on logarithmic sweeping)
- Scrollable marker column
- Markers initialize on start, middle, end
- Frequency input is now more "lazy"
  10m, 50K and 1g are now valid for 10MHz, 50kHz and 1GHz
- Added a wavelength field to Markers
- 32 bit windows binaries build in actions
- Stability improvements due to better exception handling
- Workaround for wrong first S21mag value on V2 devices

v0.3.6
------

- Implemented bandwidth setting in device management

v0.3.5
------

- Sweep worker now initializes full dataset on setting changes.
  Therefore no resize of charts when doing multi segment sweep
- Changing datapoints in DeviceSettings are reflected in SweepSettings widget step size
- Simplified calibration code by just using scipy.interp1d with fill\_value
- Established Interface class to ease locking and allow non usb connections in future
- Cleaned up VNA code. Added some pause statements to get more robust readings
- Added MagLoopAnalysis
- Touchstone class can now generate interpolated Datapoints for a given frequency
  Will be usefull in future analysis code
- Fixed a bug in Version comparison

v0.3.4
------

- Refactored Analysis
- Add Antenna Analysis
- Fixed bug in Through Calibration
- Fixed bug in s2p saving
- Fixed crash when clicking connect with no device connected
- Fixed module error with source installation if
  pkg\_resources missing

v0.3.3
------

- Fixed data acquisition with S-A-A-2 / NanoVNA V2
- Refactored calibration code
- Calibration data between known datapoints in now
  interpolated by spline interpolation
- Fixed through calibration

v0.3.2
------

- fixed crash with averaging sweeps
  also averaging now discards reading by geometrical distance

v0.3.1
------

- fixed crash with calibration assistant

v0.3.0
------

- Support for S-A-A-2 / NanoVNA V2
- Support for 202 Datapoints/scan with NanoVNA-H
- Support for attenuator at S11
- Massive code separation to easy additon of
  Hardware, Charts, Analysis ...

Known Issues
------------

- -H / -H4 supports depends on Firmware
This commit is contained in:
Diane Bruce 2020-10-17 16:50:25 +00:00
parent 87138d3657
commit 6437cedaf2
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=552598
6 changed files with 70 additions and 47 deletions

View file

@ -2,8 +2,7 @@
PORTNAME= nanovna-saver
DISTVERSIONPREFIX= v
DISTVERSION= 0.2.2
PORTREVISION= 2
DISTVERSION= 0.3.7
CATEGORIES= comms hamradio
MAINTAINER= hamradio@FreeBSD.org
@ -27,4 +26,7 @@ GH_ACCOUNT= mihtjel
NO_ARCH= yes
post-extract:
${CP} ${FILESDIR}/Sysctl.py ${WRKSRC}/NanoVNASaver/Hardware/
.include <bsd.port.mk>

View file

@ -1,3 +1,3 @@
TIMESTAMP = 1578812631
SHA256 (mihtjel-nanovna-saver-v0.2.2_GH0.tar.gz) = 82fa37fcd487cbafebd07751f76fc5bad42f7e6f1276008f5463f0256e17748f
SIZE (mihtjel-nanovna-saver-v0.2.2_GH0.tar.gz) = 178819
TIMESTAMP = 1602611094
SHA256 (mihtjel-nanovna-saver-v0.3.7_GH0.tar.gz) = 4b2cb4e736855452ef0fcc198f4f467ab042857b7844aac973fa99de7eb128ad
SIZE (mihtjel-nanovna-saver-v0.3.7_GH0.tar.gz) = 359208

View file

@ -0,0 +1,23 @@
import re
from ctypes import *
from ctypes.util import find_library
libc = cdll.LoadLibrary(find_library("c"))
sysctlbyname = libc.sysctlbyname
def posix_sysctlbyname(name):
_len = c_uint(0)
result = sysctlbyname(name,None , byref(_len), None, 0)
_mem = create_string_buffer(_len.value)
result = sysctlbyname(name, _mem, byref(_len), None, 0)
if result != 0:
raise Exception('sysctlbyname returned with error %s' % result)
return _mem.value
def usb_vid_pid(name):
digit = (re.search(r'\d',name)).group()
result = (posix_sysctlbyname(b'dev.umodem.'+bytes(digit,'ascii')+b'.%pnpinfo')).decode('ascii')
items=result.split(' ')
vendor=int(items[0].split('=')[1],0)
product=int(items[1].split('=')[1],0)
return([vendor,product])

View file

@ -0,0 +1,33 @@
--- NanoVNASaver/Hardware/Hardware.py.orig 2020-08-13 17:01:29 UTC
+++ NanoVNASaver/Hardware/Hardware.py
@@ -32,6 +32,7 @@ from NanoVNASaver.Hardware.NanoVNA_H import NanoVNA_H
from NanoVNASaver.Hardware.NanoVNA_H4 import NanoVNA_H4
from NanoVNASaver.Hardware.NanoVNA_V2 import NanoVNA_V2
from NanoVNASaver.Hardware.Serial import drain_serial, Interface
+from NanoVNASaver.Hardware.Sysctl import usb_vid_pid
logger = logging.getLogger(__name__)
@@ -61,8 +62,12 @@ def get_interfaces() -> List[Interface]:
interfaces = []
# serial like usb interfaces
for d in list_ports.comports():
- if platform.system() == 'Windows' and d.vid is None:
- d = _fix_v2_hwinfo(d)
+ if platform.system() == 'FreeBSD':
+ logger.debug("Found FreeBSD USB port %s", d.device)
+ vid_pid = usb_vid_pid(d.device)
+ d.vid = vid_pid[0]
+ d.pid = vid_pid[1]
+
for t in USBDEVICETYPES:
if d.vid != t.vid or d.pid != t.pid:
continue
@@ -72,7 +77,6 @@ def get_interfaces() -> List[Interface]:
iface.port = d.device
interfaces.append(iface)
return interfaces
-
def get_VNA(iface: Interface) -> 'VNA':
# serial_port.timeout = TIMEOUT

View file

@ -1,15 +0,0 @@
--- NanoVNASaver/NanoVNASaver.py.orig 2019-12-04 11:05:36 UTC
+++ NanoVNASaver/NanoVNASaver.py
@@ -540,11 +540,7 @@ class NanoVNASaver(QtWidgets.QWidget):
return_ports = []
device_list = list_ports.comports()
for d in device_list:
- if (d.vid == VID and
- d.pid == PID):
- port = d.device
- logger.info("Found NanoVNA (%04x %04x) on port %s", d.vid, d.pid, d.device)
- return_ports.append(port)
+ return_ports.append(d.device)
return return_ports
def exportFileS1P(self):

View file

@ -1,36 +1,16 @@
--- setup.py.orig 2019-12-04 11:05:36 UTC
--- setup.py.orig 2020-08-13 17:01:29 UTC
+++ setup.py
@@ -15,10 +15,11 @@
# along with this program. If not, see <https://www.gnu.org/licenses/>.
import sys
+import io
from NanoVNASaver.about import version
-if sys.version_info < (3, 7):
- print("You need at least Python 3.7 for this application!")
+if sys.version_info < (3, 3):
+ print("You need at least Python 3.3 for this application!")
if sys.version_info[0] < 3:
print("try running with python3 {}".format(" ".join(sys.argv)))
sys.exit(1)
@@ -30,7 +31,7 @@ except ImportError:
print("Try installing them with pip install setuptools")
sys.exit(1)
-with open("README.md", "r") as fh:
+with io.open("README.md", "r", encoding="utf-8") as fh:
long_description = fh.read()
setup(
@@ -48,10 +49,4 @@ setup(
@@ -37,12 +37,5 @@ setup(
'console_scripts': [
'NanoVNASaver = NanoVNASaver.__main__:main'
],
},
- },
- install_requires=[
- 'pyserial',
- 'PyQt5',
- 'numpy',
- 'scipy'
- 'scipy<1.5',
- 'cython',
- ],
+ }
)