Skip to content

Commit

Permalink
docs: Add initial docs
Browse files Browse the repository at this point in the history
1. Add sphinx conf and makefile
2. Add common files and images

Signed-off-by: RibhuDP <[email protected]>
  • Loading branch information
ribdp committed Apr 1, 2024
1 parent 71b9497 commit b6cb299
Show file tree
Hide file tree
Showing 13 changed files with 366 additions and 0 deletions.
20 changes: 20 additions & 0 deletions docs/Makefile
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)
35 changes: 35 additions & 0 deletions docs/make.bat
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
Binary file added docs/source/adi_logo.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
91 changes: 91 additions & 0 deletions docs/source/common/data_streaming.rst
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.
12 changes: 12 additions & 0 deletions docs/source/common/examples.rst
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>`_
Binary file added docs/source/common/images/PCXEvalStack.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
45 changes: 45 additions & 0 deletions docs/source/common/installation.rst
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
27 changes: 27 additions & 0 deletions docs/source/common/limitations.rst
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.
9 changes: 9 additions & 0 deletions docs/source/common/support.rst
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
45 changes: 45 additions & 0 deletions docs/source/conf.py
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"
62 changes: 62 additions & 0 deletions docs/source/index.rst
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`
Binary file added docs/source/pctlbxLogo.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
20 changes: 20 additions & 0 deletions docs/source/supported_parts.csv
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,,,,

0 comments on commit b6cb299

Please sign in to comment.