/libaps2

C/C++ driver for BBN APSv2

Primary LanguageC++Apache License 2.0Apache-2.0

C/C++ Driver for the BBN APSv2

Linux build

Build status

This repository provides the C++ (with a C calling API) driver for controlling the second generation BBN Arbitrary Pulse Sequencer. In addition to the C driver we provide thin wrappers for Matlab and Julia.

Documentation

Read the online manual.

License

This code is licensed under the Apache v2 license. See the LICENSE file for more information.

Building

Only necessary for those wishing to develop or build the driver from source. Prebuilt binaries for Windows are available on the releases tab.

Clone repository

We get the asio, Catch, and plog dependencies via submodules with the --recursive switch

git clone --recursive git@github.com:BBN-Q/libaps2.git

Dependencies

  • C++ compiler with good C++11 support. See below for OS specific compilers tested.
  • cmake: Cmake build tool version 2.8 or higher (http://www.cmake.org/)

Linux

Use your distribution's package manager to install the dependencies and it should work out of the box. Here is how to build the library and utilities using a Debian-base package manager:

sudo apt update
sudo apt install git
sudo apt install build-essential
sudo apt install cmake

git clone https://github.com/BBN-Q/libaps2.git
git submodule update --init --recursive

mkdir build
cd build
cmake ../src
make

Then install the python driver if you'd like:

cd src/python
pip install .

Tested on:

  • Linux Mint 18.1 with 5.4.0
  • CentOS 7
  • Ubuntu 16.04 - 18.04

OS X

  1. Install the command-line developer tools.
  2. Use Homebrew to install cmake.
  3. Then a standard cmake ../src and make should build.

Tested on:

  • OS X 10.10 Yosemite with Apple clang 6.0
  • Xcode 9.4 & 10.1 with clang++

Windows

Visual Studio

We currently only support Windows builds in MinGW. It is possible to build the library and utilities in Visual Studio though this process tends to be brittle.

MSYS2 and MinGW-w64

The most painless way to use gcc on Windows has been using MSYS2 and the MinGW-w64 gcc compiler stack.

  1. Download the MSYS2 installer and follow the instructions to install and update in place.
  2. Use pacman package manager to install some additional tools and libraries:
pacman -S make
pacman -S mingw64/mingw-w64-x86_64-cmake
pacman -S mingw64/mingw-w64-x86_64-gcc
pacman -S mingw64/mingw-w64-x86_64-gdb
  1. Finally build in the libaps2 folder
mkdir build
cd build
cmake -G "MSYS Makefiles" -DCMAKE_BUILD_TYPE=Debug ../src/
make

Tested on:

  • Windows 10 Professional with gcc 6.1.0

For the adventurous, the Appveyor build artifacts are available for download here. These are binaries build from the master branch.

Funding

This software was funded in part by the Office of the Director of National Intelligence (ODNI), Intelligence Advanced Research Projects Activity (IARPA), through the Army Research Office contract No. W911NF-10-1-0324 and No. W911NF-14-1-0114. All statements of fact, opinion or conclusions contained herein are those of the authors and should not be construed as representing the official views or policies of IARPA, the ODNI, or the US Government.