diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 349ca14..cc3838c 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -17,11 +17,11 @@ jobs: runs-on: ubuntu-latest steps: - name: Checkout code - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Set up Python - uses: actions/setup-python@v4 + uses: actions/setup-python@v5 with: - python-version: '3.8' + python-version: '3.12' - name: Install Dependencies run: pip install -r requirements.txt - name: Check pylint, mypy, black diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index 6f46ff3..39bb2db 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -17,7 +17,7 @@ jobs: runs-on: ubuntu-latest steps: - name: Checkout code - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Create Release id: create_release uses: actions/create-release@v1 @@ -40,11 +40,11 @@ jobs: runs-on: ubuntu-latest steps: - name: Checkout code - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Set up Python - uses: actions/setup-python@v4 + uses: actions/setup-python@v5 with: - python-version: '3.8' + python-version: '3.12' - name: Install Dependencies run: pip install build twine - name: Build Package diff --git a/.gitignore b/.gitignore index 0ec9c14..34e508a 100644 --- a/.gitignore +++ b/.gitignore @@ -2,6 +2,7 @@ __pycache__/ *.egg-info/ dist/ +.mypy_cache/ # Visual Studio .vs/ diff --git a/README.md b/README.md index 0f6058c..94a87f9 100644 --- a/README.md +++ b/README.md @@ -22,7 +22,7 @@ with dwf.AnalogDiscovery2() as device: - Low-level API with complete access to the Digilent Waveforms API. - Powerful high-level API that supports one-line configuration statements. - Supports all sub-modules, such as oscilloscope, arbitrary waveform generator, logic analyzer, pattern generator, digital I/O, and power supplies. -- Works with all WaveForms devices, such as the **Analog Discovery 2** or the **Digital Discovery**. +- Works with all WaveForms devices, such as the **Analog Discovery 2**, the **Analog Discovery 3**, or the **Digital Discovery**. ## Installing DwfPy @@ -32,7 +32,7 @@ You can install the [DwfPy package](https://pypi.org/project/dwfpy/) from PyPI u pip install dwfpy ``` -In order to use the **DwfPy** package, you need **Python 3.6** or higher. +In order to use the **DwfPy** package, you need **Python 3.8** or higher. As **DwfPy** builds on top of the WaveForms API, you need to install the [WaveForms software][WaveForms-Software], which includes the required runtime components to access the WaveForms devices. diff --git a/pyproject.toml b/pyproject.toml index 95a5232..0d756f8 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -8,18 +8,19 @@ build-backend = "setuptools.build_meta" [tool.pylint.messages_control] max-line-length = 120 disable = [ + "cyclic-import", + "duplicate-code", + "no-else-return", + "redefined-builtin", + "too-few-public-methods", "too-many-arguments", - "too-many-locals", + "too-many-branches", "too-many-instance-attributes", - "too-many-public-methods", "too-many-lines", - "too-many-branches", + "too-many-locals", + "too-many-positional-arguments", + "too-many-public-methods", "too-many-return-statements", - "too-few-public-methods", - "no-else-return", - "duplicate-code", - "cyclic-import", - "redefined-builtin", ] [[tool.mypy.overrides]] diff --git a/setup.cfg b/setup.cfg index 4ea8618..7500bd5 100644 --- a/setup.cfg +++ b/setup.cfg @@ -1,6 +1,6 @@ [metadata] name = dwfpy -version = 1.1.2 +version = 1.1.3 description = Python Bindings for Digilent WaveForms API long_description = file: README.md long_description_content_type = text/markdown @@ -8,7 +8,7 @@ url = https://github.com/mariusgreuel/dwfpy author = Marius Greuel author_email = greuelm@mgtek.com license = MIT -keywords = digilent,waveforms,analog discovery,digital discovery,ad2 +keywords = digilent,waveforms,analog discovery,digital discovery,ad2,ad3 classifiers = Programming Language :: Python :: 3 License :: OSI Approved :: MIT License @@ -20,7 +20,7 @@ project_urls = package_dir = = src packages = find: -python_requires = >=3.6 +python_requires = >=3.8 install_requires = numpy diff --git a/src/dwfpy/__init__.py b/src/dwfpy/__init__.py index dcf2cbe..549f70f 100644 --- a/src/dwfpy/__init__.py +++ b/src/dwfpy/__init__.py @@ -42,6 +42,7 @@ ElectronicsExplorer, AnalogDiscovery, AnalogDiscovery2, + AnalogDiscovery3, DigitalDiscovery, ) from dwfpy.application import Application diff --git a/src/dwfpy/bindings.py b/src/dwfpy/bindings.py index 0bbe969..9dea124 100644 --- a/src/dwfpy/bindings.py +++ b/src/dwfpy/bindings.py @@ -131,7 +131,10 @@ def errcheck(result, func, args): DEVID_DISCOVERY2 = 3 DEVID_DDISCOVERY = 4 DEVID_ADP3X50 = 6 +DEVID_ECLYPSE = 7 DEVID_ADP5250 = 8 +DEVID_DPS3340 = 9 +DEVID_DISCOVERY3 = 10 DwfDevVer = c_int DEVVER_EEXPLORER_C = 2 @@ -197,6 +200,7 @@ def errcheck(result, func, args): FILTER_DECIMATE = 0 FILTER_AVERAGE = 1 FILTER_MINMAX = 2 +FILTER_AVERAGEFIT = 3 DwfTrigType = c_int TRIGTYPE_EDGE = 0 @@ -241,6 +245,22 @@ def errcheck(result, func, args): FUNC_PLAY_PATTERN = 29 FUNC_CUSTOM = 30 FUNC_PLAY = 31 +FUNC_ANALOG_IN1 = 64 +FUNC_ANALOG_IN2 = 65 +FUNC_ANALOG_IN3 = 66 +FUNC_ANALOG_IN4 = 67 +FUNC_ANALOG_IN5 = 68 +FUNC_ANALOG_IN6 = 69 +FUNC_ANALOG_IN7 = 70 +FUNC_ANALOG_IN8 = 71 +FUNC_ANALOG_IN9 = 72 +FUNC_ANALOG_IN10 = 73 +FUNC_ANALOG_IN11 = 74 +FUNC_ANALOG_IN12 = 75 +FUNC_ANALOG_IN13 = 76 +FUNC_ANALOG_IN14 = 77 +FUNC_ANALOG_IN15 = 78 +FUNC_ANALOG_IN16 = 79 DwfAnalogIO = c_ubyte ANALOGIO_ENABLE = 1 @@ -254,6 +274,7 @@ def errcheck(result, func, args): ANALOGIO_TIME = 9 ANALOGIO_FREQUENCY = 10 ANALOGIO_RESISTANCE = 11 +ANALOGIO_SLEW = 12 DwfDmm = c_int DMM_RESISTANCE = 1 @@ -342,6 +363,10 @@ def errcheck(result, func, args): PARAM_FREQUENCY = 8 # Hz PARAM_EXT_FREQ = 9 # Hz PARAM_CLOCK_MODE = 10 # 0 internal, 1 output, 2 input, 3 IO +PARAM_TEMP_LIMIT = 11 +PARAM_FREQ_PHASE = 12 +PARAM_DIGITAL_VOLTAGE = 13 +PARAM_FREQ_PHASE_STEPS = 14 DwfWindow = c_int WINDOW_RECTANGULAR = 0 @@ -350,13 +375,32 @@ def errcheck(result, func, args): WINDOW_HANN = 3 WINDOW_COSINE = 4 WINDOW_BLACKMAN_HARRIS = 5 -WINDOW_FLATTOP = 6 +WINDOW_FLAT_TOP = 6 WINDOW_KAISER = 7 +WINDOW_BLACKMAN = 8 +WINDOW_FLAT_TOP_M = 9 DwfAnalogCoupling = c_int ANALOG_COUPLING_DC = 0 ANALOG_COUPLING_AC = 1 +DwfFiirMode = c_int +FIIR_WINDOW = 0 +FIIR_FIR = 1 +FIIR_IIR_BUTTERWORTH = 2 +FIIR_IIR_CHEBYSHEV = 3 + +DwfFiirType = c_int +FIIR_LOW_PASS = 0 +FIIR_HIGH_PASS = 1 +FIIR_BAND_PASS = 2 +FIIR_BAND_STOP = 3 + +DwfFiirInput = c_int +FIIR_RAW = 0 +FIIR_DECIMATE = 1 +FIIR_AVERAGE = 2 + # pylint:disable=line-too-long ### SYSTEM @@ -451,6 +495,12 @@ def errcheck(result, func, args): dwf_analog_in_buffer_size_set = _dwf_function('FDwfAnalogInBufferSizeSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'nSize')) dwf_analog_in_buffer_size_get = _dwf_function('FDwfAnalogInBufferSizeGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pnSize')) +if _version >= (3, 21, 0): + dwf_analog_in_buffers_info = _dwf_function('FDwfAnalogInBuffersInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pMax')) + dwf_analog_in_buffers_set = _dwf_function('FDwfAnalogInBuffersSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'n')) + dwf_analog_in_buffers_get = _dwf_function('FDwfAnalogInBuffersGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pn')) + dwf_analog_in_buffers_status = _dwf_function('FDwfAnalogInBuffersStatus', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pn')) + dwf_analog_in_noise_size_info = _dwf_function('FDwfAnalogInNoiseSizeInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pnSizeMax')) dwf_analog_in_noise_size_set = _dwf_function('FDwfAnalogInNoiseSizeSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'nSize')) dwf_analog_in_noise_size_get = _dwf_function('FDwfAnalogInNoiseSizeGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pnSize')) @@ -462,6 +512,8 @@ def errcheck(result, func, args): # Channel configuration dwf_analog_in_channel_count = _dwf_function('FDwfAnalogInChannelCount', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pcChannel')) +if _version >= (3, 21, 0): + dwf_analog_in_channel_counts = _dwf_function('FDwfAnalogInChannelCounts', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pcReal'), (_OUT, POINTER(c_int), 'pcFilter'), (_OUT, POINTER(c_int), 'pcTotal')) dwf_analog_in_channel_enable_set = _dwf_function('FDwfAnalogInChannelEnableSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_IN, c_int, 'fEnable')) dwf_analog_in_channel_enable_get = _dwf_function('FDwfAnalogInChannelEnableGet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_OUT, POINTER(c_int), 'pfEnable')) dwf_analog_in_channel_filter_info = _dwf_function('FDwfAnalogInChannelFilterInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pfsfilter')) @@ -486,6 +538,14 @@ def errcheck(result, func, args): dwf_analog_in_channel_coupling_set = _dwf_function('FDwfAnalogInChannelCouplingSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_IN, DwfAnalogCoupling, 'coupling')) dwf_analog_in_channel_coupling_get = _dwf_function('FDwfAnalogInChannelCouplingGet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_OUT, POINTER(DwfAnalogCoupling), 'pcoupling')) +# FIR and IIR filters + +if _version >= (3, 21, 0): + dwf_analog_in_channel_fiir_info = _dwf_function('FDwfAnalogInChannelFiirInfo', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_OUT, POINTER(c_int), 'cFIR'), (_OUT, POINTER(c_int), 'cIIR')) + dwf_analog_in_channel_fiir_set = _dwf_function('FDwfAnalogInChannelFiirSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_IN, DwfFiirInput, 'input'), (_IN, DwfFiirMode, 'fiir'), (_IN, DwfFiirType, 'pass'), (_IN, c_int, 'ord'), (_IN, c_double, 'hz1'), (_IN, c_double, 'hz2'), (_IN, c_double, 'ep')) + dwf_analog_in_channel_window_set = _dwf_function('FDwfAnalogInChannelWindowSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_IN, DwfWindow, 'win'), (_IN, c_int, 'size'), (_IN, c_double, 'beta')) + dwf_analog_in_channel_custom_window_set = _dwf_function('FDwfAnalogInChannelCustomWindowSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_IN, POINTER(c_double), 'rg'), (_IN, c_int, 'size'), (_IN, c_int, 'normalize')) + # Trigger configuration dwf_analog_in_trigger_source_set = _dwf_function('FDwfAnalogInTriggerSourceSet', (_IN, HDWF, 'hdwf'), (_IN, DwfTrigSrc, 'trigsrc')) @@ -675,6 +735,13 @@ def errcheck(result, func, args): dwf_digital_io_output_info = _dwf_function('FDwfDigitalIOOutputInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'pfsOutputMask')) dwf_digital_io_output_set = _dwf_function('FDwfDigitalIOOutputSet', (_IN, HDWF, 'hdwf'), (_IN, c_uint, 'fsOutput')) dwf_digital_io_output_get = _dwf_function('FDwfDigitalIOOutputGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'pfsOutput')) +if _version >= (3, 21, 0): + dwf_digital_io_pull_info = _dwf_function('FDwfDigitalIOPullInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'pfsUp'), (_OUT, POINTER(c_uint), 'pfsDown')) + dwf_digital_io_pull_set = _dwf_function('FDwfDigitalIOPullSet', (_IN, HDWF, 'hdwf'), (_IN, c_uint, 'pfsUp'), (_IN, c_uint, 'pfsDown')) + dwf_digital_io_pull_get = _dwf_function('FDwfDigitalIOPullGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'pfsUp'), (_OUT, POINTER(c_uint), 'pfsDown')) + dwf_digital_io_drive_info = _dwf_function('FDwfDigitalIODriveInfo', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'channel'), (_OUT, POINTER(c_double), 'ampMin'), (_OUT, POINTER(c_double), 'ampMax'), (_OUT, POINTER(c_double), 'ampSteps'), (_OUT, POINTER(c_double), 'pslewSteps')) + dwf_digital_io_drive_set = _dwf_function('FDwfDigitalIODriveSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'channel'), (_IN, c_double, 'amp'), (_IN, c_int, 'slew')) + dwf_digital_io_drive_get = _dwf_function('FDwfDigitalIODriveGet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'channel'), (_OUT, POINTER(c_double), 'pamp'), (_OUT, POINTER(c_int), 'pslew')) dwf_digital_io_input_info = _dwf_function('FDwfDigitalIOInputInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'pfsInputMask')) dwf_digital_io_input_status = _dwf_function('FDwfDigitalIOInputStatus', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'pfsInput')) dwf_digital_io_output_enable_info64 = _dwf_function('FDwfDigitalIOOutputEnableInfo64', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_ulonglong), 'pfsOutputEnableMask')) @@ -699,8 +766,16 @@ def errcheck(result, func, args): dwf_digital_in_status_auto_triggered = _dwf_function('FDwfDigitalInStatusAutoTriggered', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pfAuto')) dwf_digital_in_status_data = _dwf_function('FDwfDigitalInStatusData', (_IN, HDWF, 'hdwf'), (_IN, c_void_p, 'rgData'), (_IN, c_int, 'countOfDataBytes')) dwf_digital_in_status_data2 = _dwf_function('FDwfDigitalInStatusData2', (_IN, HDWF, 'hdwf'), (_IN, c_void_p, 'rgData'), (_IN, c_int, 'idxSample'), (_IN, c_int, 'countOfDataBytes')) +if _version >= (3, 21, 0): + dwf_digital_in_status_data3 = _dwf_function('FDwfDigitalInStatusData3', (_IN, HDWF, 'hdwf'), (_IN, c_void_p, 'rgData'), (_IN, c_int, 'idxSample'), (_IN, c_int, 'countOfDataBytes'), (_IN, c_int, 'bitShift')) dwf_digital_in_status_noise2 = _dwf_function('FDwfDigitalInStatusNoise2', (_IN, HDWF, 'hdwf'), (_IN, c_void_p, 'rgData'), (_IN, c_int, 'idxSample'), (_IN, c_int, 'countOfDataBytes')) +if _version >= (3, 21, 0): + dwf_digital_in_status_noise3 = _dwf_function('FDwfDigitalInStatusNoise3', (_IN, HDWF, 'hdwf'), (_IN, c_void_p, 'rgData'), (_IN, c_int, 'idxSample'), (_IN, c_int, 'countOfDataBytes'), (_IN, c_int, 'bitShift')) dwf_digital_in_status_record = _dwf_function('FDwfDigitalInStatusRecord', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pcdDataAvailable'), (_OUT, POINTER(c_int), 'pcdDataLost'), (_OUT, POINTER(c_int), 'pcdDataCorrupt')) +if _version >= (3, 21, 0): + dwf_digital_in_status_compress = _dwf_function('FDwfDigitalInStatusCompress', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pcdDataAvailable'), (_OUT, POINTER(c_int), 'pcdDataLost'), (_OUT, POINTER(c_int), 'pcdDataCorrupt')) + dwf_digital_in_status_compressed = _dwf_function('FDwfDigitalInStatusCompressed', (_IN, HDWF, 'hdwf'), (_IN, c_void_p, 'rgData'), (_IN, c_int, 'countOfBytes')) + dwf_digital_in_status_compressed2 = _dwf_function('FDwfDigitalInStatusCompressed2', (_IN, HDWF, 'hdwf'), (_IN, c_void_p, 'rgData'), (_IN, c_int, 'idxSample'), (_IN, c_int, 'countOfBytes')) if _version >= (3, 16, 3): dwf_digital_in_status_time = _dwf_function('FDwfDigitalInStatusTime', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'psecUtc'), (_OUT, POINTER(c_uint), 'ptick'), (_OUT, POINTER(c_uint), 'pticksPerSecond')) @@ -732,6 +807,12 @@ def errcheck(result, func, args): dwf_digital_in_buffer_size_set = _dwf_function('FDwfDigitalInBufferSizeSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'nSize')) dwf_digital_in_buffer_size_get = _dwf_function('FDwfDigitalInBufferSizeGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pnSize')) +if _version >= (3, 21, 0): + dwf_digital_in_buffers_info = _dwf_function('FDwfDigitalInBuffersInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pMax')) + dwf_digital_in_buffers_set = _dwf_function('FDwfDigitalInBuffersSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'n')) + dwf_digital_in_buffers_get = _dwf_function('FDwfDigitalInBuffersGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pn')) + dwf_digital_in_buffers_status = _dwf_function('FDwfDigitalInBuffersStatus', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pn')) + dwf_digital_in_sample_mode_info = _dwf_function('FDwfDigitalInSampleModeInfo', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pfsDwfDigitalInSampleMode')) dwf_digital_in_sample_mode_set = _dwf_function('FDwfDigitalInSampleModeSet', (_IN, HDWF, 'hdwf'), (_IN, DwfDigitalInSampleMode, 'v')) dwf_digital_in_sample_mode_get = _dwf_function('FDwfDigitalInSampleModeGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(DwfDigitalInSampleMode), 'pv')) @@ -766,7 +847,14 @@ def errcheck(result, func, args): dwf_digital_in_trigger_set = _dwf_function('FDwfDigitalInTriggerSet', (_IN, HDWF, 'hdwf'), (_IN, c_uint, 'fsLevelLow'), (_IN, c_uint, 'fsLevelHigh'), (_IN, c_uint, 'fsEdgeRise'), (_IN, c_uint, 'fsEdgeFall')) dwf_digital_in_trigger_get = _dwf_function('FDwfDigitalInTriggerGet', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_uint), 'pfsLevelLow'), (_OUT, POINTER(c_uint), 'pfsLevelHigh'), (_OUT, POINTER(c_uint), 'pfsEdgeRise'), (_OUT, POINTER(c_uint), 'pfsEdgeFall')) +if _version >= (3, 21, 0): + dwf_digital_in_trigger_info64 = _dwf_function('FDwfDigitalInTriggerInfo64', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_ulonglong), 'pfsLevelLow'), (_OUT, POINTER(c_ulonglong), 'pfsLevelHigh'), (_OUT, POINTER(c_ulonglong), 'pfsEdgeRise'), (_OUT, POINTER(c_ulonglong), 'pfsEdgeFall')) + dwf_digital_in_trigger_set64 = _dwf_function('FDwfDigitalInTriggerSet64', (_IN, HDWF, 'hdwf'), (_IN, c_ulonglong, 'fsLevelLow'), (_IN, c_ulonglong, 'fsLevelHigh'), (_IN, c_ulonglong, 'fsEdgeRise'), (_IN, c_ulonglong, 'fsEdgeFall')) + dwf_digital_in_trigger_get64 = _dwf_function('FDwfDigitalInTriggerGet64', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_ulonglong), 'pfsLevelLow'), (_OUT, POINTER(c_ulonglong), 'pfsLevelHigh'), (_OUT, POINTER(c_ulonglong), 'pfsEdgeRise'), (_OUT, POINTER(c_ulonglong), 'pfsEdgeFall')) + dwf_digital_in_trigger_reset_set = _dwf_function('FDwfDigitalInTriggerResetSet', (_IN, HDWF, 'hdwf'), (_IN, c_uint, 'fsLevelLow'), (_IN, c_uint, 'fsLevelHigh'), (_IN, c_uint, 'fsEdgeRise'), (_IN, c_uint, 'fsEdgeFall')) +if _version >= (3, 21, 0): + dwf_digital_in_trigger_reset_set64 = _dwf_function('FDwfDigitalInTriggerResetSet64', (_IN, HDWF, 'hdwf'), (_IN, c_ulonglong, 'fsLevelLow'), (_IN, c_ulonglong, 'fsLevelHigh'), (_IN, c_ulonglong, 'fsEdgeRise'), (_IN, c_ulonglong, 'fsEdgeFall')) dwf_digital_in_trigger_count_set = _dwf_function('FDwfDigitalInTriggerCountSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cCount'), (_IN, c_int, 'fRestart')) dwf_digital_in_trigger_length_set = _dwf_function('FDwfDigitalInTriggerLengthSet', (_IN, HDWF, 'hdwf'), (_IN, c_double, 'secMin'), (_IN, c_double, 'secMax'), (_IN, c_int, 'idxSync')) dwf_digital_in_trigger_match_set = _dwf_function('FDwfDigitalInTriggerMatchSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'iPin'), (_IN, c_uint, 'fsMask'), (_IN, c_uint, 'fsValue'), (_IN, c_int, 'cBitStuffing')) @@ -877,19 +965,35 @@ def errcheck(result, func, args): dwf_digital_spi_idle_set = _dwf_function('FDwfDigitalSpiIdleSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxDQ'), (_IN, DwfDigitalOutIdle, 'idle')) dwf_digital_spi_mode_set = _dwf_function('FDwfDigitalSpiModeSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'iMode')) dwf_digital_spi_order_set = _dwf_function('FDwfDigitalSpiOrderSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'fMSBFirst')) +if _version >= (3, 21, 0): + dwf_digital_spi_delay_set = _dwf_function('FDwfDigitalSpiDelaySet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cStart'), (_IN, c_int, 'cCmd'), (_IN, c_int, 'cWord'), (_IN, c_int, 'cStop')) + dwf_digital_spi_select_set = _dwf_function('FDwfDigitalSpiSelectSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxSelect'), (_IN, c_int, 'fIdle')) dwf_digital_spi_select = _dwf_function('FDwfDigitalSpiSelect', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel'), (_IN, c_int, 'level')) -dwf_digital_spi_write_read = _dwf_function('FDwfDigitalSpiWriteRead', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ubyte), 'rgTX'), (_IN, c_int, 'cTX'), (_IN, POINTER(c_ubyte), 'rgRX'), (_IN, c_int, 'cRX')) -dwf_digital_spi_write_read16 = _dwf_function('FDwfDigitalSpiWriteRead16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ushort), 'rgTX'), (_IN, c_int, 'cTX'), (_IN, POINTER(c_ushort), 'rgRX'), (_IN, c_int, 'cRX')) -dwf_digital_spi_write_read32 = _dwf_function('FDwfDigitalSpiWriteRead32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_uint), 'rgTX'), (_IN, c_int, 'cTX'), (_OUT, POINTER(c_uint), 'rgRX'), (_IN, c_int, 'cRX')) -dwf_digital_spi_read = _dwf_function('FDwfDigitalSpiRead', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ubyte), 'rgRX'), (_IN, c_int, 'cRX')) +dwf_digital_spi_write_read = _dwf_function('FDwfDigitalSpiWriteRead', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ubyte), 'rgTX'), (_IN, c_int, 'cTX'), (_OUT, POINTER(c_ubyte), 'rgRX'), (_IN, c_int, 'cRX')) +dwf_digital_spi_write_read16 = _dwf_function('FDwfDigitalSpiWriteRead16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ushort), 'rgTX'), (_IN, c_int, 'cTX'), (_OUT, POINTER(c_ushort), 'rgRX'), (_IN, c_int, 'cRX')) +dwf_digital_spi_write_read32 = _dwf_function('FDwfDigitalSpiWriteRead32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_uint), 'rgTX'), (_IN, c_int, 'cTX'), (_OUT, POINTER(c_uint), 'rgRX'), (_IN, c_int, 'cRX')) +dwf_digital_spi_read = _dwf_function('FDwfDigitalSpiRead', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_ubyte), 'rgRX'), (_IN, c_int, 'cRX')) dwf_digital_spi_read_one = _dwf_function('FDwfDigitalSpiReadOne', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_uint), 'pRX')) -dwf_digital_spi_read16 = _dwf_function('FDwfDigitalSpiRead16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ushort), 'rgRX'), (_IN, c_int, 'cRX')) +dwf_digital_spi_read16 = _dwf_function('FDwfDigitalSpiRead16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_ushort), 'rgRX'), (_IN, c_int, 'cRX')) dwf_digital_spi_read32 = _dwf_function('FDwfDigitalSpiRead32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_uint), 'rgRX'), (_IN, c_int, 'cRX')) dwf_digital_spi_write = _dwf_function('FDwfDigitalSpiWrite', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ubyte), 'rgTX'), (_IN, c_int, 'cTX')) dwf_digital_spi_write_one = _dwf_function('FDwfDigitalSpiWriteOne', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBits'), (_IN, c_uint, 'vTX')) dwf_digital_spi_write16 = _dwf_function('FDwfDigitalSpiWrite16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ushort), 'rgTX'), (_IN, c_int, 'cTX')) -dwf_digital_spi_write32 = _dwf_function('FDwfDigitalSpiWrite32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_uint), 'rgTX'), (_IN, c_int, 'cTX')) +dwf_digital_spi_write32 = _dwf_function('FDwfDigitalSpiWrite32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_uint), 'rgTX'), (_IN, c_int, 'cTX')) + +if _version >= (3, 21, 0): + dwf_digital_spi_cmd_write_read = _dwf_function('FDwfDigitalSpiCmdWriteRead', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ubyte), 'rgTX'), (_IN, c_int, 'cTX'), (_OUT, POINTER(c_ubyte), 'rgRX'), (_IN, c_int, 'cRX')) + dwf_digital_spi_cmd_write_read16 = _dwf_function('FDwfDigitalSpiCmdWriteRead16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ushort), 'rgTX'), (_IN, c_int, 'cTX'), (_OUT, POINTER(c_ushort), 'rgRX'), (_IN, c_int, 'cRX')) + dwf_digital_spi_cmd_write_read32 = _dwf_function('FDwfDigitalSpiCmdWriteRead32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_uint), 'rgTX'), (_IN, c_int, 'cTX'), (_OUT, POINTER(c_uint), 'rgRX'), (_IN, c_int, 'cRX')) + dwf_digital_spi_cmd_read = _dwf_function('FDwfDigitalSpiCmdRead', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_ubyte), 'rgRX'), (_IN, c_int, 'cRX')) + dwf_digital_spi_cmd_read_one = _dwf_function('FDwfDigitalSpiCmdReadOne', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_uint), 'pRX')) + dwf_digital_spi_cmd_read16 = _dwf_function('FDwfDigitalSpiCmdRead16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_ushort), 'rgRX'), (_IN, c_int, 'cRX')) + dwf_digital_spi_cmd_read32 = _dwf_function('FDwfDigitalSpiCmdRead32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_OUT, POINTER(c_uint), 'rgRX'), (_IN, c_int, 'cRX')) + dwf_digital_spi_cmd_write = _dwf_function('FDwfDigitalSpiCmdWrite', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ubyte), 'rgTX'), (_IN, c_int, 'cTX')) + dwf_digital_spi_cmd_write_one = _dwf_function('FDwfDigitalSpiCmdWriteOne', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, c_uint, 'vTX')) + dwf_digital_spi_cmd_write16 = _dwf_function('FDwfDigitalSpiCmdWrite16', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_ushort), 'rgTX'), (_IN, c_int, 'cTX')) + dwf_digital_spi_cmd_write32 = _dwf_function('FDwfDigitalSpiCmdWrite32', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cBitCmd'), (_IN, c_uint, 'cmd'), (_IN, c_int, 'cDummy'), (_IN, c_int, 'cDQ'), (_IN, c_int, 'cBitPerWord'), (_IN, POINTER(c_uint), 'rgTX'), (_IN, c_int, 'cTX')) # I2C @@ -924,6 +1028,22 @@ def errcheck(result, func, args): dwf_digital_can_tx = _dwf_function('FDwfDigitalCanTx', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'vID'), (_IN, c_int, 'fExtended'), (_IN, c_int, 'fRemote'), (_IN, c_int, 'cDLC'), (_IN, POINTER(c_ubyte), 'rgTX')) dwf_digital_can_rx = _dwf_function('FDwfDigitalCanRx', (_IN, HDWF, 'hdwf'), (_OUT, POINTER(c_int), 'pvID'), (_OUT, POINTER(c_int), 'pfExtended'), (_OUT, POINTER(c_int), 'pfRemote'), (_OUT, POINTER(c_int), 'pcDLC'), (_IN, POINTER(c_ubyte), 'rgRX'), (_IN, c_int, 'cRX'), (_OUT, POINTER(c_int), 'pvStatus')) +# SWD + +if _version >= (3, 21, 0): + dwf_digital_swd_reset = _dwf_function('FDwfDigitalSwdReset', (_IN, HDWF, 'hdwf'), ) + dwf_digital_swd_rate_set = _dwf_function('FDwfDigitalSwdRateSet', (_IN, HDWF, 'hdwf'), (_IN, c_double, 'hz')) + dwf_digital_swd_ck_set = _dwf_function('FDwfDigitalSwdCkSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel')) + dwf_digital_swd_io_set = _dwf_function('FDwfDigitalSwdIoSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'idxChannel')) + dwf_digital_swd_turn_set = _dwf_function('FDwfDigitalSwdTurnSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cTurn')) + dwf_digital_swd_trail_set = _dwf_function('FDwfDigitalSwdTrailSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cTrail')) + dwf_digital_swd_park_set = _dwf_function('FDwfDigitalSwdParkSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'fDrive')) + dwf_digital_swd_nak_set = _dwf_function('FDwfDigitalSwdNakSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'fContinue')) + dwf_digital_swd_io_idle_set = _dwf_function('FDwfDigitalSwdIoIdleSet', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'fHigh')) + dwf_digital_swd_clear = _dwf_function('FDwfDigitalSwdClear', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cReset'), (_IN, c_int, 'cTrail')) + dwf_digital_swd_write = _dwf_function('FDwfDigitalSwdWrite', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'APnDP'), (_IN, c_int, 'A32'), (_OUT, POINTER(c_int), 'pAck'), (_IN, c_uint, 'Write')) + dwf_digital_swd_read = _dwf_function('FDwfDigitalSwdRead', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'APnDP'), (_IN, c_int, 'A32'), (_OUT, POINTER(c_int), 'pAck'), (_OUT, POINTER(c_uint), 'pRead'), (_OUT, POINTER(c_int), 'pCrc')) + # Impedance if _version >= (3, 9, 1): @@ -956,3 +1076,5 @@ def errcheck(result, func, args): dwf_spectrum_window = _dwf_function('FDwfSpectrumWindow', (_IN, HDWF, 'hdwf'), (_IN, c_int, 'cdWin'), (_IN, DwfWindow, 'iWindow'), (_IN, c_double, 'vBeta'), (_OUT, POINTER(c_double), 'vNEBW')) dwf_spectrum_fft = _dwf_function('FDwfSpectrumFFT', (_IN, HDWF, 'hdwf'), (_IN, POINTER(c_double), 'rgdData'), (_IN, c_int, 'cdData'), (_IN, POINTER(c_double), 'rgdBin'), (_IN, POINTER(c_double), 'rgdPhase'), (_IN, c_int, 'cdBin')) dwf_spectrum_transform = _dwf_function('FDwfSpectrumTransform', (_IN, HDWF, 'hdwf'), (_IN, POINTER(c_double), 'rgdData'), (_IN, c_int, 'cdData'), (_IN, POINTER(c_double), 'rgdBin'), (_IN, POINTER(c_double), 'rgdPhase'), (_IN, c_int, 'cdBin'), (_IN, c_double, 'iFirst'), (_IN, c_double, 'iLast')) +if _version >= (3, 21, 0): + dwf_spectrum_goertzel = _dwf_function('FDwfSpectrumGoertzel', (_IN, HDWF, 'hdwf'), (_IN, POINTER(c_double), 'rgdData'), (_IN, c_int, 'cdData'), (_IN, c_double, 'pos'), (_IN, POINTER(c_double), 'pMag'), (_IN, c_double, 'pRad')) diff --git a/src/dwfpy/constants.py b/src/dwfpy/constants.py index 83ceeed..9c5c3ff 100644 --- a/src/dwfpy/constants.py +++ b/src/dwfpy/constants.py @@ -20,7 +20,10 @@ class DeviceId(enum.IntEnum): ANALOG_DISCOVERY2 = 3 DIGITAL_DISCOVERY = 4 ADP3X50 = 6 + ECLYPSE = 7 ADP5250 = 8 + DPS3340 = 9 + ANALOG_DISCOVERY3 = 10 class DeviceType(enum.IntEnum): diff --git a/src/dwfpy/device.py b/src/dwfpy/device.py index ce8f250..60bfa98 100644 --- a/src/dwfpy/device.py +++ b/src/dwfpy/device.py @@ -360,15 +360,36 @@ def _ensure_module(self, module, description): def _get_configuration(self): if isinstance(self._configuration, str): - if self._configuration == 'scope': - if self.id in (DeviceId.ANALOG_DISCOVERY, DeviceId.ANALOG_DISCOVERY2): + if self._configuration == 'generic': + return 0 + elif self._configuration == 'scope': + if self.id in ( + DeviceId.ANALOG_DISCOVERY, + DeviceId.ANALOG_DISCOVERY2, + DeviceId.ANALOG_DISCOVERY3, + ): return 1 - if self._configuration == 'pattern': - if self.id in (DeviceId.ANALOG_DISCOVERY, DeviceId.ANALOG_DISCOVERY2): + elif self._configuration == 'wavegen': + if self.id in ( + DeviceId.ANALOG_DISCOVERY, + DeviceId.ANALOG_DISCOVERY2, + DeviceId.ANALOG_DISCOVERY3, + ): return 2 elif self._configuration == 'logic': + if self.id in ( + DeviceId.ANALOG_DISCOVERY, + DeviceId.ANALOG_DISCOVERY2, + DeviceId.ANALOG_DISCOVERY3, + ): + return 3 + elif self.id == DeviceId.DIGITAL_DISCOVERY: + return 0 + elif self._configuration == 'pattern': if self.id in (DeviceId.ANALOG_DISCOVERY, DeviceId.ANALOG_DISCOVERY2): return 3 + elif self.id == DeviceId.ANALOG_DISCOVERY3: + return 4 elif self.id == DeviceId.DIGITAL_DISCOVERY: return 0 elif self._configuration == '1v8': @@ -382,7 +403,7 @@ def _get_configuration(self): else: raise WaveformsError( "Invalid configuration: " - "Must be 'scope', 'pattern', 'logic', '1v8', or 'logic-1v8'." + "Must be 'generic', 'scope', 'wavegen', 'logic', 'pattern', '1v8', or 'logic-1v8'." ) raise WaveformsError( @@ -848,12 +869,12 @@ def supplies(self) -> Supplies: @property def usb_voltage(self) -> float: - """Gets the USB line voltage.""" + """Gets the USB voltage.""" return self.analog_io[2][0].status @property def usb_current(self) -> float: - """Gets the USB line current.""" + """Gets the USB current.""" return self.analog_io[2][1].status @property @@ -992,12 +1013,12 @@ def supplies(self) -> Supplies: @property def usb_voltage(self) -> float: - """Gets the USB line voltage.""" + """Gets the USB voltage.""" return self.analog_io[2][0].status @property def usb_current(self) -> float: - """Gets the USB line current.""" + """Gets the USB current.""" return self.analog_io[2][1].status @property @@ -1016,6 +1037,175 @@ def aux_current(self) -> float: return self.analog_io[3][1].status +class AnalogDiscovery3(DeviceBase): + """Digilent Analog Discovery 3 device.""" + + class Supplies: + """The power supplies.""" + + class Positive: + """The positive power supply.""" + + def __init__(self, device): + self._device = device + + @property + def enabled(self) -> bool: + """Enables or disables the positive power supply.""" + return bool(self._device.analog_io[0][0].value) + + @enabled.setter + def enabled(self, value: bool) -> None: + self._device.analog_io[0][0].value = value + + @property + def voltage(self) -> float: + """Gets or sets the voltage of the positive power supply.""" + return self._device.analog_io[0][1].value + + @voltage.setter + def voltage(self, value: float) -> None: + self._device.analog_io[0][1].value = value + + def setup(self, voltage: float, enabled: bool = True) -> None: + """Sets up the positive power supply. + + Parameters + ---------- + voltage : float + The output voltage. + enabled : bool, optional + If True, then the power supply is enabled (default True). + """ + if voltage is not None: + self.voltage = voltage + if enabled is not None: + self.enabled = enabled + + class Negative: + """The negative power supply.""" + + def __init__(self, device): + self._device = device + + @property + def enabled(self) -> bool: + """Enables the negative power supply.""" + return bool(self._device.analog_io[1][0].value) + + @enabled.setter + def enabled(self, value: bool) -> None: + self._device.analog_io[1][0].value = value + + @property + def voltage(self) -> float: + """Gets or sets the voltage of the negative power supply.""" + return self._device.analog_io[1][1].value + + @voltage.setter + def voltage(self, value: float) -> None: + self._device.analog_io[1][1].value = value + + def setup(self, voltage: float, enabled: bool = True) -> None: + """Sets up the negative power supply. + + Parameters + ---------- + voltage : float + The output voltage (must be a negative value). + enabled : bool, optional + If True, then the power supply is enabled (default True). + """ + if voltage is not None: + self.voltage = voltage + if enabled is not None: + self.enabled = enabled + + def __init__(self, device): + self._device = device + self._positive = self.Positive(device) + self._negative = self.Negative(device) + + @property + def positive(self) -> Positive: + """Gets the positive power supply.""" + return self._positive + + @property + def negative(self) -> Negative: + """Gets the negative power supply.""" + return self._negative + + @property + def master_enable(self) -> bool: + """Gets or sets the master enable switch.""" + return self._device.analog_io.master_enable + + @master_enable.setter + def master_enable(self, value: bool) -> None: + self._device.analog_io.master_enable = value + + @property + def master_enable_status(self) -> bool: + """Gets the master enable status.""" + return self._device.analog_io.master_enable_status + + def __init__(self, configuration=None, serial_number=None, device_type=None, device_index=None): + super().__init__( + configuration=configuration, + serial_number=serial_number, + device_id=DeviceId.ANALOG_DISCOVERY3, + device_type=device_type, + device_index=device_index, + ) + self._supplies = self.Supplies(self) + + @property + def supplies(self) -> Supplies: + """Gets the power supplies.""" + return self._supplies + + @property + def pcb_temperature(self) -> float: + """Gets the temperature of the PCB.""" + return self.analog_io[2][0].status + + @property + def fpga_temperature(self) -> float: + """Gets the temperature of the FPGA.""" + return self.analog_io[2][1].status + + @property + def usb_voltage(self) -> float: + """Gets the USB voltage.""" + return self.analog_io[2][2].status + + @property + def usb_current(self) -> float: + """Gets the USB current.""" + return self.analog_io[2][3].status + + @property + def aux_voltage(self) -> float: + """Gets the AUX line voltage.""" + return self.analog_io[3][4].status + + @property + def aux_current(self) -> float: + """Gets the AUX line current.""" + return self.analog_io[3][5].status + + @property + def usb_cc1_voltage(self) -> float: + """Gets the USB CC1 voltage.""" + return self.analog_io[2][6].status + + @property + def usb_cc2_voltage(self) -> float: + """Gets the USB CC2 voltage.""" + return self.analog_io[2][7].status + + class DigitalDiscovery(DeviceBase): """Digilent Digital Discovery device.""" @@ -1157,12 +1347,12 @@ def vio_current(self) -> float: @property def usb_voltage(self) -> float: - """Gets the USB line voltage.""" + """Gets the USB voltage.""" return self.analog_io[2][0].status @property def usb_current(self) -> float: - """Gets the USB line current.""" + """Gets the USB current.""" return self.analog_io[2][1].status diff --git a/src/dwfpy/exceptions.py b/src/dwfpy/exceptions.py index ae1e7d0..671219e 100644 --- a/src/dwfpy/exceptions.py +++ b/src/dwfpy/exceptions.py @@ -19,14 +19,14 @@ def __init__(self, message: str, error: int = 0): class DeviceNotFound(WaveformsError): - """Device not found error""" + """Device not found error.""" def __init__(self, message): super().__init__(message) class DeviceNotOpenError(WaveformsError): - """Device is not open error""" + """Device is not open error.""" def __init__(self, message): super().__init__(message)