Skip to main content

CLI for setting up ufo camera test station

Project description

ufotest

Logo https://img.shields.io/pypi/v/ufotest.svg https://img.shields.io/travis/the16thpythonist/ufotest.svg Documentation Status

The ufotest project provides a command line interface to install and test the UFO camera, which was developed at the Institute of Data Processing (IPE) of the Karlsruhe Institute of Technology (KIT).

Installation

The easiest way to install this package is by using PIP. This will automatically install all the requirements and also register the CLI commands to be usable. (Note that the “sudo” is important to make the commands register correctly within the operating system)

$ sudo pip3 install ufotest
$ ufotest init

Usage

The command line can be accessed through the ufotest command within the console. Use the –help option to display a list of all available commands or consilt the Documentation for a more detailed explanation

$ ufotest --help

Features

  • Global configuration file

  • Automatic installation of all dependencies for a barebones operation of the UFO camera

Credits

The following software was used in the creation of the project:

History

0.1.0 (2020-08-13)

  • First release on PyPI.

0.2.0 (2020-08-23)

  • First actual release with content
    • “install” command to install ufotest command automatically

    • “config” command to edit global configuration file

    • “frame” command to acquire and display a single frame

0.3.0 (2020-08-24)

  • Added additional package for SUSE which installs c++ compiler

  • Fixed unhandled exception in “frame”

  • Added additional output if a cmake installation fails

  • fixed readme

  • Added “init” command, which will setup the installation folder and the config file

0.3.1 (2020-08-25)

  • Small adjustments to the documentation

  • Added “status.sh” and “reset.sh” scripts from michele to the main code folder.

0.4.0 (2020-08-27)

  • Added installation packages for OpenSUSE to the documentation

  • Copied the power up and power down scripts from the IPE

  • Copied the vivado start script from the IPE

  • Now checking for a valid ufotest installation before every command, thus preventing running into an obvious exception.

  • Added jinja2 to the requirements

  • Added module “camera.py” instead of “capture.py” to contain all the camera related functionality

  • Modified config file
    • Added “scripts” section, which allows the user to register custom commands.

  • Added the “script” command: Executes (bash) scripts, which were registered in the project

  • Added functions which setup and teardown the camera state
    • Execute them in “frame” command

  • Added an option to “config” which allows to specify the editor

0.4.1 (2020-08-27)

  • Fixed the MANIFEST.in file, which did not include the bash scripts in the distribution package

0.4.2 (2020-09-01)

  • Removed the setup and teardown process from the “frame” command, because as of right now, the power up and down should not be called too often, because there are problems with the FPGA regarding that.

  • registered 2 new scripts
    • pcie_init

    • reset_fpga

  • Changed the parameter type for the output of the frame command from Path to File in the hopes of making it able to overwrite like this

  • Fixed the image display using matplotlib

0.5.0 (2020-09-01)

  • Moved the code to import a number N of raw images from a file to it’s own function in camera.py

  • Added commands:
    • setup: Will enable the camera to work

    • teardown: Will disable the camera to work. Be careful not to use this while the FPGA still has problems with power down

    • list-scripts: Displays a list of all scripts

  • Registered scripts
    • reset_tp: Resets the fpag and enables the test pattern

    • reset_dma: Resets the DMA settings of the fpga

  • Moved the scripts into their own folder

  • Removed the installation of vivado. This is the responsibility of the user. Installation path can be given in the config file

  • Added the necessary scripts for the flashing of the fpga

  • changed “execute_script” so that changes folder to the script folder first

TODO

  • Add the installation of vivado.
    • Can we add the installer to the repository? If not download using curl

  • I could write a “Camera” context manager object…?

  • Make a real help text for the init command

  • Update documentation
    • Add init command

    • (Add frame command)

    • Add script command

    • Add option to define scripts in the config section

  • Setup Sphinx autodoc for this project

  • Make “init” add the necessary stuff to the bashrc file. use jinja2?

  • Figure out how to flash a bit file to the controller programmatically

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ufotest-0.5.0.tar.gz (29.6 kB view hashes)

Uploaded Source

Built Distribution

ufotest-0.5.0-py2.py3-none-any.whl (22.7 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page