Data Acquisition Box

From UCLA Miniscope
Revision as of 15:07, 3 May 2017 by Marshallshuler (talk | contribs)$7

(diff) ← Older revision | Approved revision (diff) | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search
OverviewDAQHardware.png


Overview

Design, fabrication, and assembly files can be found at the Miniscope DAQ PCB Github repository.

The Data Acquisition (DAQ) Box sits between the head mounted microscope and PC and mediates communication between the two. The DAQ box connects over super speed USB (USB3.0) to the PC and enumerates as a generic webcam using the USB Video Class (UVC) device protocol. This means that other open source or commercial webcam software should be able to control and stream data for the system. Below shows the default configuration of the DAQ hardware using the firmware provided on this wiki.

DAQBox.png

The PCB is roughly 3" x 2.25" and housed in a 3D printed box. The PCB is a 4 layer board with controlled impedance for the USB data lines.

DAQPCB.png

Below is the schematic of the DAQ hardware.

DAQPCBSchematic.png


Connectors

GPIOSMA.png


Status LEDs

StatusLEDs.png


Jumper Settings

PowerJumper.png


Switch and Boot Mode Settings

SwitchSettings.png
BootMode.png


Firmware

The firmware image and firmware source code can be found at the Miniscope DAQ firmware repository.

The firmware running the DAQ box consists of a USB descriptor, General Peripheral Interface (GPIF II) state machine, and ARM Cortex programming. All three of these components were written, and can be modified, using the Cypress EZ-USB FX3 SDK. The SDK also provides the needed software to flash the firmware onto the DAQ board through the USB connection. Below is a short description of the firmware components.

USB Descriptor

The USB descriptor is based on the USB Video Class (UVC) descriptor structure which causes the DAQ board to enumerate as a generic webcam. The descriptor conveys supported configurations, frame size, ect. to the PC.

General Peripheral Interface

The General Peripheral Interface (GPIF II) configures the GPIOs of the USB Host Controller as well as defines the state machine for handling a raw video data stream. The GPIF connects to the parallel output of the imaging sensor as well as the imaging sensor's sync signals (Frame Valid, Line Valid, Pixel Clock) and the state machine defines how the imaging data gets packaged before being sent over the USB interface.

ARM Cortex Programming


Guides and Tutorials

System Assembly

Software and Firmware Setup