-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
1. Add sphinx conf and makefile 2. Add common files and images Signed-off-by: RibhuDP <[email protected]>
- Loading branch information
Showing
13 changed files
with
366 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
# Minimal makefile for Sphinx documentation | ||
# | ||
|
||
# You can set these variables from the command line, and also | ||
# from the environment for the first two. | ||
SPHINXOPTS ?= | ||
SPHINXBUILD ?= sphinx-build | ||
SOURCEDIR = source | ||
BUILDDIR = build | ||
|
||
# Put it first so that "make" without argument is like "make help". | ||
help: | ||
@$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) | ||
|
||
.PHONY: help Makefile | ||
|
||
# Catch-all target: route all unknown targets to Sphinx using the new | ||
# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS). | ||
%: Makefile | ||
@$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
@ECHO OFF | ||
|
||
pushd %~dp0 | ||
|
||
REM Command file for Sphinx documentation | ||
|
||
if "%SPHINXBUILD%" == "" ( | ||
set SPHINXBUILD=sphinx-build | ||
) | ||
set SOURCEDIR=source | ||
set BUILDDIR=build | ||
|
||
%SPHINXBUILD% >NUL 2>NUL | ||
if errorlevel 9009 ( | ||
echo. | ||
echo.The 'sphinx-build' command was not found. Make sure you have Sphinx | ||
echo.installed, then set the SPHINXBUILD environment variable to point | ||
echo.to the full path of the 'sphinx-build' executable. Alternatively you | ||
echo.may add the Sphinx directory to PATH. | ||
echo. | ||
echo.If you don't have Sphinx installed, grab it from | ||
echo.https://www.sphinx-doc.org/ | ||
exit /b 1 | ||
) | ||
|
||
if "%1" == "" goto help | ||
|
||
%SPHINXBUILD% -M %1 %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% | ||
goto end | ||
|
||
:help | ||
%SPHINXBUILD% -M help %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% | ||
|
||
:end | ||
popd |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
Data Streaming | ||
-------------- | ||
|
||
Remote data streaming to and from hardware is made available through `system object interfaces <https://www.mathworks.com/help/matlab/matlab_prog/what-are-system-objects.html>`_ , which are unique for each component or platform. The hardware interfacing system objects provide a since class to both configure a given platform and move data back and forth from the device. | ||
|
||
Command and control of hardware from MATLAB is accomplished by leveraging the `IIO drivers <https://wiki.analog.com/software/linux/docs/iio/iio>`_ built into the target platform's kernel and `libiio <https://wiki.analog.com/resources/tools-software/linux-software/libiio>`_ which provides remote backends to control drivers across different backends. Backends can be Ethernet/IP/USB based. Below is a diagram of the different components in the stack for a setup targeting the evaluation of the AD7380, but the setup will be nearly similar for other ADCs as well. | ||
|
||
.. image:: images/PCXEvalStack.png | ||
:width: 600 | ||
|
||
Since libiio is cross-platform it can be used from Windows, Linux, or macOS based systems. It is also a lower level library independent of MATLAB, so when moving toward production or untethered systems similar APIs that are used in MATLAB can be used in C, C++, Python, or other languages. | ||
|
||
============================ | ||
Connecting and Configuration | ||
============================ | ||
|
||
Connecting to hardware is done by setting the **uri** property of the system object interface. The **uri** for libiio always has the convention "*< backend >:< address >*", where *backend* can be ethernet, ip or usb. *address* will be specific to the backend. This is documented in the `libiio API <https://analogdevicesinc.github.io/libiio/master/libiio/group__Context.html#gafdcee40508700fa395370b6c636e16fe>`_ . | ||
|
||
Below is a basic example of setting up a generic ADC using an Ethernet/IP backend: | ||
|
||
.. code-block:: MATLAB | ||
rx = adi.ADxxxx.Rx; | ||
rx.uri = 'ip:analog.local'; | ||
data = rx(); | ||
With the code above, the hardware is not contacted until the operator or step method is called on line 3. Therefore, any properties that are set or defined before line 3 are not applied or updated on the hardware until after line 3. However, after line 3 has completed the object will become locked and certain configuration changes cannot be applied after this point. These will primarily sample rates and buffer sizes. | ||
|
||
The state of the object follows the flow of the diagram below triggered by line 3 above. | ||
|
||
Once the object becomes locked it must be released if the sample rate or buffers need to be modified. This will disconnect from the hardware: | ||
|
||
.. code-block:: MATLAB | ||
rx.release(); % Release object | ||
To provide a complete example we can do more advanced configuration like so to demonstrate property changes: | ||
|
||
.. code-block:: MATLAB | ||
rx = adi.ADxxxx.Rx; | ||
rx.uri = 'ip:analog.local'; | ||
rx.SamplesPerFrame = 1024; | ||
rx.SampleRate = 256000; | ||
data1 = rx(); | ||
% Update tunable property | ||
rx.SampleRate = 128000; | ||
data2 = rx(); | ||
% Update non-tunable property | ||
rx.release(); | ||
rx.SamplesPerFrame = 4096; | ||
dataLargerBuffer = rx(); | ||
============== | ||
Receiving Data | ||
============== | ||
|
||
To receive or capture data from a given device first you must instantiate that device's interface class. For a generic ADC, this would be as follows: | ||
|
||
.. code-block:: MATLAB | ||
rx = adi.ADxxxx.Rx; | ||
Once instantiated you can configure the number of samples to be captured by setting the property **SamplesPerFrame.** | ||
|
||
.. code-block:: MATLAB | ||
rx.SamplesPerFrame = 1e6; | ||
**SamplesPerFrame** is the number of samples per channel which will be captured. If your device produces complex data (I and Q) this is the number of complex samples. There will be a limit to the maximum samples which can be collected. By default this is set to 2^20, but it may be possible to make it larger depending on hardware. Once the operator methods are used for a give instantiation, the object will become locked and the **SamplesPerFrame** property cannot be changed. This is known as a non-tunable property. | ||
|
||
To actually collect the samples or perform the capture, the operator of the system object should be used or the **step** method as so: | ||
|
||
.. code-block:: MATLAB | ||
data = rx(); % Operator method | ||
data = rx.step(); % Step method | ||
Both method calls are equivalent, and the produced matrix **data** will be of size [SamplesPerFrame x length(EnabledChannels)]. **EnabledChannels** determines the channels which data will be collected from. **EnabledChannels** is a [1xN] vector with indexes starting at 1 of the desired channels. | ||
|
||
=========================== | ||
Continuous Data Acquisition | ||
=========================== | ||
|
||
If you are capturing multiple frames or buffers of data, then there might arise situations where discontinuities appear in the samples, when plotted. | ||
|
||
Some detail and tips are discussed in this wiki page on `IIO System Considerations, Tips and Tricks <https://wiki.analog.com/resources/tools-software/linux-software/libiio_tips_tricks>`_ | ||
|
||
The IIO buffer size is governed by the SamplesPerFrame property of the System Object classes. The kernelBuffersCount is also a property defined for the classes, and can be modified. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
Examples | ||
-------- | ||
|
||
Examples for streaming data are listed within the Toolbox documentation itself. To view run the following with MATLAB: | ||
|
||
.. code-block:: MATLAB | ||
doc adi | ||
They can also be viewed on GitHub: | ||
|
||
- `Streaming examples <https://github.com/analogdevicesinc/PrecisionToolbox/tree/master/examples>`_ |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
Installation | ||
------------ | ||
|
||
============ | ||
Dependencies | ||
============ | ||
|
||
The toolbox has different dependencies based on the features required. The base dependencies for streaming data are listed below. | ||
|
||
The base dependencies for the toolbox requires libiio and the libiio MATLAB bindings. There are three options for this install with different required MathWorks Toolboxes: | ||
|
||
- `Communications Toolbox Support Package for Xilinx Zynq-Based Radio <https://www.mathworks.com/help/supportpkg/xilinxzynqbasedradio/index.html>`_ | ||
- Communications Toolbox | ||
- Signal Processing Toolbox :sup:`TM` | ||
- DSP System Toolbox :sup:`TM` | ||
- `Communications Toolbox Support Package for Analog Devices ADALM-Pluto Radio <https://www.mathworks.com/help/supportpkg/plutoradio/index.html>`_ | ||
- Communications Toolbox | ||
- Signal Processing Toolbox :sup:`TM` | ||
- DSP System Toolbox :sup:`TM` | ||
- `libiio MATLAB Binding Standalone Installer (R2021b+) <https://github.com/mathworks/buildroot/releases/download/mathworks_zynq_R21.2.0/libiio.mlpkginstall>`_ | ||
- Signal Processing Toolbox :sup:`TM` | ||
|
||
|
||
========================= | ||
Precision Toolbox Install | ||
========================= | ||
|
||
The Precision Toolbox itself can be installed either from: | ||
|
||
- `MATLAB's Add-On Explorer <https://www.mathworks.com/products/matlab/add-on-explorer.html>`_ | ||
- `GitHub Releases page <https://github.com/analogdevicesinc/PrecisionToolbox/releases>`_ | ||
|
||
.. warning:: | ||
Before installing Precision Toolbox check the `Release Page <https://github.com/analogdevicesinc/PrecisionToolbox/releases>`_ to check for the latest supported version of MATLAB. The latest version is the one which is available in `Add-on Explorer <https://www.mathworks.com/products/matlab/add-on-explorer.html>`_ , since Add-On Explorer does not currently support hosting multiple versions. If you have an older release of MATLAB, download the MLTBX installer from matching release on the `Release Page <https://github.com/analogdevicesinc/PrecisionToolbox/releases>`_ . | ||
|
||
=========================== | ||
Add-On Explorer Walkthrough | ||
=========================== | ||
|
||
To install the toolbox from within MATLAB using the Add-On Explorer: | ||
|
||
- Launch the Add-Ons Explorer from MATLAB's Home tab | ||
- Search for 'Precision Toolbox' | ||
- Select Precision Toolbox from Analog Devices, Inc. from the results: | ||
- Install the toolbox |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
Limitations | ||
----------- | ||
|
||
Known Limitations, Bugs and Quirks | ||
================================== | ||
|
||
Some limitations and bugs are known to be present in the support for the ADCs relevant to the Precision Toolbox. They have been summarized below. | ||
|
||
**Libiio backend** | ||
|
||
Currently only ethernet/IP backends are supported for all the parts in the toolbox. For AD4030-24, AD4630-16 and AD4630-24 the usb backend can also be used. Serial backends are not supported. | ||
|
||
**AD7380** | ||
|
||
Trigger setup needs to be done before running any of the toolbox scripts that interact with the AD7380. Refer to the `Trigger Management section on the AD738x Linux IIO driver wiki page <https://wiki.analog.com/resources/tools-software/linux-drivers/iio-adc/ad738x#trigger_management>`_ | ||
|
||
**AD7768** | ||
|
||
The Linux IIO driver for the AD7768 returns data for all the channels whenever a data capture is requested. So, in order to get sensible outputs, ensure that the EnabledChannels array consists of indices for all the channels. | ||
|
||
**AD4030-24. AD4630-16, AD4630-24** | ||
|
||
The Linux IIO driver for the three parts (there's a common Linux driver that addresses all three parts) returns data for all the channels whenever a data capture is requested. In order to have sensible outputs, ensure that the EnabledChannels array consists of indices for all the channels. | ||
|
||
Another known issue here has to do with the case where the ADC sends out common mode voltage data along with the differential voltage data. The EnabledChannel property values that consist of more than two indices (even when there are 4 IIO channels), are not 'valid'. Of the possible groupings with two channel indices, the ones that correspond to {differential0, common_voltage0} and {differential1, common_voltage1} are also not 'valid' | ||
|
||
It is possible to get data (common-mode and differential) for all the ADC channels, by using a 'valid' channel grouping, setting the BufferTypeConversionEnable property to 'false' in the Base class for the AD463x family, and adding custom parsing logic to extract the data for all IIO channels, from the 32-bit raw words you get from the data capture. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
Support | ||
------- | ||
|
||
Support is provided online through the EngineerZone forums. If you have questions related to the hardware itself outside of this BSP, contact your local FAE or ask on the forums. | ||
|
||
Question regarding specific aspect of the BSP should be asked in the following places: | ||
|
||
- `Software Interface Tools <https://ez.analog.com/sw-interface-tools/f/q-a)>`_ for questions on the BSP itself | ||
- `Linux Software Drivers <https://ez.analog.com/linux-software-drivers/f/q-a)>`_ for libiio and iio driver questions |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
# Configuration file for the Sphinx documentation builder. | ||
# | ||
# For the full list of built-in configuration values, see the documentation: | ||
# https://www.sphinx-doc.org/en/master/usage/configuration.html | ||
|
||
# -- Project information ----------------------------------------------------- | ||
# https://www.sphinx-doc.org/en/master/usage/configuration.html#project-information | ||
|
||
project = 'Precision Toolbox for MATLAB' | ||
copyright = '2023, Analog Devices Inc.' | ||
author = 'Analog Devices Inc.' | ||
|
||
# -- General configuration --------------------------------------------------- | ||
# https://www.sphinx-doc.org/en/master/usage/configuration.html#general-configuration | ||
|
||
#extensions = [] | ||
# | ||
#templates_path = ['_templates'] | ||
#exclude_patterns = [] | ||
|
||
|
||
|
||
# -- Options for HTML output ------------------------------------------------- | ||
# https://www.sphinx-doc.org/en/master/usage/configuration.html#options-for-html-output | ||
|
||
#html_theme = 'alabaster' | ||
#html_static_path = ['_static'] | ||
|
||
|
||
extensions = [ | ||
'sphinx_toolbox.collapse' | ||
] | ||
|
||
templates_path = ['_templates'] | ||
exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store'] | ||
|
||
|
||
|
||
# -- Options for HTML output ------------------------------------------------- | ||
# https://www.sphinx-doc.org/en/master/usage/configuration.html#options-for-html-output | ||
|
||
html_theme = "bizstyle" | ||
html_static_path = ['_static'] | ||
|
||
html_logo = "adi_logo.png" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
.. pctlbx-docs documentation master file, created by | ||
sphinx-quickstart on Mon Apr 1 11:50:10 2024. | ||
You can adapt this file completely to your liking, but it should at least | ||
contain the root `toctree` directive. | ||
Precision Toolbox for MATLAB | ||
============================ | ||
|
||
.. image:: /pctlbxLogo.png | ||
:width: 600 | ||
|
||
ADI maintains a set of tools to interface with ADI precision converters within MATLAB and Simulink. These are combined into a single toolbox. The list of supported parts is provided below. | ||
|
||
The following have device-specific implementations in MATLAB and Simulink. If a device has an IIO driver, MATLAB support is possible, but a device-specific MATLAB or Simulink interface may not exist yet. | ||
|
||
.. toctree:: | ||
:maxdepth: 2 | ||
:caption: Contents: | ||
|
||
/common/installation.rst | ||
/common/data_streaming.rst | ||
/common/examples.rst | ||
/common/limitations.rst | ||
/common/support.rst | ||
|
||
|
||
.. csv-table:: Supported Parts | ||
:header: "Evaluation Card", "FPGA Board", "Streaming Support", "Targeting", "Variants and Minimum Supported Release" | ||
:widths: 30, 30, 30, 30, 30 | ||
|
||
"AD7380", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD7768", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD7768-1", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4030-24", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4630-16", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4630-24", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4858", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD2S1210", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4000", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4001", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4002", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4003", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4004", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4005", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4006", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4007", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4008", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4010", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4011", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4020", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4021", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD4022", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD7124-4", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
"AD7124-8", "Zedboard", "Yes", "No", "ADI (2021b)" | ||
|
||
|
||
Indices and tables | ||
================== | ||
|
||
* :ref:`genindex` | ||
* :ref:`modindex` | ||
* :ref:`search` |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
Evaluation Card,FPGA Board,Streaming Support,Targeting,Variants and Minimum Supported Release | ||
AD7380,,,, | ||
AD7768,,,, | ||
AD7768-1,,,, | ||
AD4030-24,,,, | ||
AD4630-16,,,, | ||
AD4858,,,, | ||
AD2S1210,,,, | ||
AD4000,,,, | ||
AD4001,,,, | ||
AD4002,,,, | ||
AD4003,,,, | ||
AD4004,,,, | ||
AD4005,,,, | ||
AD4006,,,, | ||
AD4007,,,, | ||
AD4008,,,, | ||
AD4010,,,, | ||
AD4011,,,, | ||
AD4020,,,, |