# Rocket Cam Low Frequency Analog Transmission of Digital Video

by

Thomas J. Higdon

Advisor: Wayne Pilkington

Senior Project

# ELECTRICAL ENGINEERING DEPARTMENT

California Polytechnic State University

San Luis Obispo

2015

| <i>Section</i> Page                                                 |
|---------------------------------------------------------------------|
| Abstract4                                                           |
| I. Introduction                                                     |
| II. Product Design Engineering Requirements 5                       |
| IV. System Design - Functional Decomposition (Level 1)              |
| V. Technology Choices and Design Approach Alternatives Considered12 |
| VI. Project Design Discretion14                                     |
| VII. Physical Construction and Integration19                        |
| VIII. Integrated System Tests and Results                           |
| IX. Conclusions                                                     |
| References                                                          |
| Appendices                                                          |
| A. Senior Project Analysis                                          |
| B. Parts List and Costs                                             |
| C. Project Schedule - Time Estimates & Actuals43                    |
| D. Program Listings                                                 |

# TABLE OF CONTENTS

# LIST OF TABLES AND FIGURES

| Tables I                                                 | Page |
|----------------------------------------------------------|------|
| I. Requirements and Specifications                       | 6    |
| II. Level 0 Functional Requirements                      | 7    |
| III. Level 1 Functional Requirements                     | 9    |
| IV. Level 1 Data Flow Signals                            | 11   |
| V. Actual and Reconstruct Video                          | 22   |
| A1. Estimated Expected Parts and Equipment Costs         | 27   |
| A2. Estimated Expected Labor Costs                       | 27   |
| A3. Actual Parts and Equipment Costs                     | 28   |
| A4. Actual (Approximate) Labor Costs                     | 28   |
| A5. Planning Gantt Charts                                |      |
| (a) Fall Quarter and Winter Break                        | 29   |
| (b) Winter Quarter 2015                                  | 30   |
| (c) Spring Quarter 2015                                  | 31   |
| A6. Actual Development Gantt Charts                      |      |
| (a) Fall Quarter and Winter Break                        | 32   |
| (b) Winter Quarter 2015                                  | 33   |
| (c) Spring Quarter 2015                                  | 34   |
| B1: Actual Parts and Equipment Costs                     | 42   |
| B2: Estimated Production Model Parts and Equipment Costs | 42   |
| C1: Estimated Planned Development Time                   | 43   |
| C2: Approximant Actual Development Time                  | 43   |
| C3. Planning Gantt Charts                                |      |

|         | (a) Fall Quarter and Winter Break                        | 44 |
|---------|----------------------------------------------------------|----|
|         | (b) Winter Quarter 2015                                  | 45 |
|         | (c) Spring Quarter 2015                                  | 46 |
| C       | C4. Actual Development Gantt Charts                      |    |
|         | (a) Fall Quarter and Winter Break                        | 47 |
|         | (b) Winter Quarter 2015                                  | 48 |
|         | (c) Spring Quarter 2015                                  | 49 |
| Figures |                                                          |    |
| I.      | . Level 0 Block Diagram                                  | 7  |
| I       | I. Level 1 Hierarchical Decomposition                    | 8  |
| I       | II. Level 1 Block Diagram                                | 8  |
| Г       | V. Level 1 Implementation Concept Block Diagram          | 10 |
| V       | V. Level 2 Implementation Concept Block Diagram          | 16 |
| V       | VI. AD7245A Pinout and Wiring Schematic                  | 17 |
| V       | VII. Tiva C Launchpad Pinout and Wiring Schematic        | 18 |
| V       | VIII. Raspberry Pi B+ Pinout and Wiring Schematic        | 19 |
| Ľ       | X. Rocket Cam: Final Prototype                           | 21 |
| Х       | X. Rocket Cam: Final Prototype DAC                       | 21 |
| Х       | XI. Difference Between Reconstructed & Actual Bytes      | 23 |
| Х       | XI. Test Data Used to Determine Settling Error Threshold | 23 |
|         |                                                          |    |

# Abstract

The camera module provides data for improving models of dynamic events on Orbital ATK Corp. rockets and aids in troubleshooting, if necessary. Video images provide a valuable addition to the strain, vibration, shock, and acoustic data used for modeling dynamic events, such as stage separations. The cameras can record a duration of video data suitable for capturing a dynamic event and of high enough quality to aid in its modeling. The module readily integrates into the rocket's current analog data collection systems. The project has further relevance to any other application that necessitates video data transmission over similar limited-bandwidth, analog data channels.

Though errorless data transmission was not achieve, over 99% of the digital by bytes transmitted where recovered to within 99% accuracy. This level of error is not suitable for compressed data. However, the primary sources of error can potentially be resolved by adaption to a more permanent prototype platform.

# I. Introduction

The camera module records dynamic events on Orbital ATK Incorporated rockets. Examples of dynamic events include stage separations and payload (satellite) deployments. Video data provides a valuable addition to previously existing sensors such as strain gages, accelerometers (vibration and shock), and microphones (for acoustic information). Teams then use the information from these sensors to improve models of the events, and to troubleshoot any undesired outcomes [1].

Groups internal to Orbital ATK have done some work on developing an inexpensive camera module for this task, however, their versions do not currently satisfy all of the needs of other departments in the corporation. Unfortunately, Orbital ATK has not approved for public release the details of the status of current development. However, this project focuses on the need to utilize an existing data channel that has minimal impact on the resources of the larger rocket system (the same type of data channel which the accelerometers use) [2]. The data channel consists of an analog data line, with relatively low bandwidth when compared to typical video data channels. The primary constraint to the bandwidth comes from the receiver unit consisting of an ADC with a maximum sampling rate of 10 kilo-samples per second, with a maximum of 12 bits of resolution [2]. Fortunately, the video data utilizes buffering before transmission and does not need to achieve real time transmission. However, the severely limited bandwidth still places significant limitations and consequences on the design. Though no need exists for real time transmission, the module must still transmit the video sample within a widow constrained by the minimum flight time of the rocket after the dynamic event. Other groups have done some work on "low-bandwidth" video data transmission [3]. But it remains an under-developed area, because of the limited number of applications that necessitate it.

Because of the data bandwidth limitations, effective compression before its transmission must also occur, in order to minimize the necessary transmission time. In contrast to the "low-bandwidth" concerns, video compression remains an area of significant and active development. The MPEG-4 AVC/H.264 lossy compression standard illustrates a method with widespread use [4]. In addition, groups have also researched the implementation of compression algorithms in embedded applications, both using microprocessors [5] and using FPGAs [6].

However, the author believes that this project typifies one of very few that require the compression of video data, and its transmission through such a narrow bandwidth analog data channel.

# **II. Production Design Engineering Requirements**

#### **Customer Needs Assessment**

Orbital ATK Incorporated needs a low-cost module to provide video data for improving models of dynamic events and for troubleshooting. It needs to be relatively stand-alone, and require minimal effort to integrate into their existing rocket system; and it should have minimal impact on their existing resources [1, 2].

#### **Requirements and Specifications**

The marketing requirements and engineering specifications listed in Table I below, primarily come from the need to integrate the module into the existing systems of the rocket. However, marketing requirements 1 & 2 and the first three specifications relate to the need to obtain sufficient data for useful study of dynamic events.

Orbital ATK deems that 0.5 to 3 seconds of video, with a resolution of 640x480 pixels, with 8-bit depth grayscale pixels, and a rate of 30 frames per second, is sufficient for aiding in their modeling and troubleshooting of typical dynamic events [1, 2]. The module must be able to transmit the data through of the previously existing data channel (the analog data line), and the data must be recoverable after receipt by their previously existing hardware (the ADC). In order to make better use of the limited bandwidth, the data must be compressed before transmission. The

transmission of the video sample must take less than 10 minutes. The module must also store the original, followed by the compressed, data, before being ordered by a dedicated 1-bit "Transmit Command" line send it. Recording and compression should start after the receipt of a signal from a dedicated 1-bit "Record Command" line. The device's addition to the larger rocket system should not constitute a significant increase to the cost of the overall system [1, 2]. The module must be safe and minimize its environmental impacts.

| Marketing     | Engineering                                   | Justification                                     |
|---------------|-----------------------------------------------|---------------------------------------------------|
| Requirements  | Specifications                                | Justification                                     |
| [1], [2]      | Capable of recording at between 0.5 and 3     | Sufficient time to observe event (i.e. stage      |
|               | seconds of video                              | separation)                                       |
| [4]           | At least 640x480 pixel image resolution, at 8 | Sufficient for useful image of event.             |
|               | bits per pixel                                |                                                   |
| [1], [2], [3] | Captures at between 30 and 60 frames per      | Fast enough to track dynamics, but slow           |
|               | second                                        | enough to not produce excessive data.             |
| [2], [3], [6] | Sufficient memory to store captured data and  | Necessary to hold data and send it only when      |
|               | to perform compression operations on the      | requested.                                        |
|               | data                                          |                                                   |
| [4]           | Output data over analog line                  | Existing data interface that has the minimum      |
|               |                                               | system impact.                                    |
| [4]           | Data recoverable after analog signal is       | This describes the existing system that           |
|               | sampled by an ADC with 12 bit maximum         | receives the transmitted data.                    |
|               | resolution, at 10,000 samples per second      |                                                   |
| [5]           | Inputs 2 separate, 1-bit command lines. One   | Minimal interfacing between an otherwise          |
|               | signals the module to begin recording; the    | stand-alone module and the larger system.         |
|               | other to transmit recorded data.              |                                                   |
| [6]           | Sufficient video data compression such that   | Due to the limited bandwidth of the necessary     |
|               | sample transmission requires less than 10     | data channel, it's critical to reduce the size of |
|               | minutes (minimum compression factor of 2      | the data, so that transmission fits within        |
|               | to 1)                                         | available time                                    |
| [7]           | Finished production units should cost no      | Desire a relatively inexpensive module to         |
|               | more than \$200.                              | complement existing sensors.                      |
| [8]           | Use at least 70% ROHS compliant               | ROHS provides a good general standard for         |
|               | components.                                   | minimizing health and environmental impacts       |
|               |                                               | of component materials                            |

#### TABLE I

#### ROCKET CAM MODULE REQUIREMENTS AND SPECIFICATIONS

#### **Marketing Requirements**

- 1. Provide short duration video data of dynamic events
- 2. Video data has sufficient quality to aid in event modeling and troubleshooting
- 3. Internally store the captured data until transmission
- 4. Use existing data interfaces on the rocket
- 5. Require minimal command interfacing
- 6. Transmit data in less than 10 minutes
- 7. Be "low-cost"
- 8. Be safe and relatively environmentally-friendly

#### Black Box Diagram (Level 0)

As its overall function, the design inputs light data, and then outputs an analog voltage representation of that data. The module also accepts two 1-bit command signals, the record and transmit commands, and it inputs power. Figure 1 shows this overall Level 0 functionality within the context of the larger rocket system, and Table III elaborates on each facet of it.



FIGURE I Rocket Cam – Level 0 Block Diagram

| TABLE II                             |
|--------------------------------------|
| ROCKET CAM – FUNCTIONAL REQUIREMENTS |

| Module          | Rocket Camera                                                                             |  |
|-----------------|-------------------------------------------------------------------------------------------|--|
| Inputs –        | Record Command: Bi-level optical signal or 1-bit TTL level signal                         |  |
|                 | Transmit Command: Bi-level optical signal or 1-bit TTL level signal                       |  |
|                 | Image Field: Incident light from the surrounding environment                              |  |
|                 | Power: Sufficient power for the module to function on                                     |  |
| Outputs –       | Video Data: Analog signal, 8 to 12 bit resolution, sampled at 10,000 samples per second   |  |
| Functionality – | Upon receipt of the Record Command, it records and stores 0.5 to 3 seconds of video data. |  |
| Functionality – |                                                                                           |  |
|                 | Then, upon receipt of the Transmit Command, it outputs the analog Video Data              |  |

Bi-level optical signal and 1-bit TTL level signals represent the existing command line infrastructure available in the rocket system. The bi-level optical signals have the advantage of providing optical isolation between the camera module, and rockets more critical control systems. The 1-bit TTL signals have the advantage of being faster, cheaper, and easier to implement and integrate. The analog data line represents the available, and lowest impact, data channel [1,2].

# **IV: System Design – Functional Decomposition (Level 1)**

### **Functional Block Diagrams**

Figure II illustrates the primary subcomponents of the module in hierarchical decomposition format. Figure III shows them in function structure format. In words, the control unit receives the Record and Transmit Commands from the outside world and controls the other sub-modules' operations so that the device performs these tasks. Upon receipt of the Record Command, the video camera activates, takes in visual data and outputs an uncompressed digital representation of this data, which the memory access peripheral routes into memory. The control & data processing unit then communicates with memory, in order to perform compression and encoding operations on the video data. The compressed and encoded version of the data gets stored back in memory. Upon receipt of the Transmit Command, the compressed and encoded data gets read from memory, routed by the peripheral, and sent to the digital-to-analog converter, which converts it to its final analog form and outputs it to the outside world. During all of these operations, the power regulation unit provides appropriate power to all of the other sub-modules. The Control Unit contains the Memory Access Peripheral shown in the functional structure diagram, however, the peripheral can operate largely autonomously from the rest of the Control Unit, and is functionally distinct and significant enough to warrant separate mention at this level.







FIGURE III Rocket Cam – Level 1 Block Diagram

Table IV provides a breakdown of the inputs, outputs, and functional requirements of each sub-module.

| Module          | Power Regulator                                                                              |
|-----------------|----------------------------------------------------------------------------------------------|
| Inputs –        | External Power: 3 to 13V, constant voltage source at up to 100mA [1]                         |
|                 | Or programmable 28V (max) voltage source, with unspecified current capability                |
| Outputs –       | Regulated Power: Power at voltage levels acceptable to all of the other components           |
| Functionality – | Regulates externally supplied power to a level safe and usable by the other sub-modules      |
| Module          | Video Camera                                                                                 |
| Inputs –        | Camera Control Lines: Digital. Controls operation and settings.                              |
|                 | Image Field: Optical. Incident light from the surrounding environment.                       |
|                 | Regulated Power: DC voltage source.                                                          |
| Outputs –       | Raw Image Data: Digital. Uncompressed (raw) video image data.                                |
| Functionality – | After receiving instruction from the Control Unit, it inputs optical information from the    |
|                 | surroundings and converts it into an uncompressed digital representation, which it outputs.  |
| Module          | Control & Data Processing Unit                                                               |
|                 |                                                                                              |
| Inputs –        | Record Command: 1-Bit external control signal                                                |
|                 | Transmit Command: 1-Bit external control signal                                              |
|                 | Memory Data Bus: Digital. Accesses data stored in the Memory sub-module.                     |
|                 | Regulated Power: DC voltage source.                                                          |
| Outputs –       | Camera Control Lines: Digital. Instructs the Video Camera sub-module when to activate and    |
|                 | controls its settings.                                                                       |
|                 | DAC Control Lines: Digital. Controls settings of the DAC sub-module.                         |
|                 | Memory Control Lines: Digital. Control setting of the Memory sub-module.                     |
|                 | Memory Data Bus: Digital. Send data to the Memory sub-module for storage.                    |
| Functionality – | Inputs the Transmit and Receive Commands from the outside world. Controls the other sub-     |
|                 | modules and overall behavior of the device. Takes raw video data from memory, compresses and |
|                 | encodes it, then stores it back in memory.                                                   |
| Module          | Memory Access Peripheral                                                                     |
| Wiodule         | Memory Access T empheral                                                                     |
| Inputs –        | Address Information: Digital. From the main part of the Control Unit module.                 |
|                 | Data In: Digital.                                                                            |
|                 | Regulated Power: DC voltage source.                                                          |
| Outputs –       | Memory Control Lines: Digital. Controls address access and settings of Memory sub-module.    |
|                 | Memory Data Bus: Digital. Sends data to the Memory sub-module for storage.                   |
| Functionality - | Controls and formats data access from and storage in the Memory Sub-module. Physically       |
|                 | integrated into the Control Unit sub-module, but can operate largely autonomously and        |
|                 | considered functionally distinct and significant enough to warrant separate mention.         |

 TABLE III

 ROCKET CAM – LEVEL 1 FUNCTIONAL REQUIREMENTS

| TABLE III (continued)                        |  |
|----------------------------------------------|--|
| ROCKET CAM – LEVEL 1 FUNCTIONAL REQUIREMENTS |  |

| Module          | Memory                                                                                           |
|-----------------|--------------------------------------------------------------------------------------------------|
| Inputs –        | Control Lines: Controls operation and settings.                                                  |
|                 | Address Line: Controls accessed address for read or write operations.                            |
|                 | Data Bus In: Digital.                                                                            |
|                 | Regulated Power: DC voltage source.                                                              |
| Outputs –       | Data Bus Out: Digital.                                                                           |
|                 |                                                                                                  |
| Functionality - | Stores values placed in it by the Control Unit or the Memory Access Peripheral. Allows retrieval |
|                 | of these stored values.                                                                          |
|                 |                                                                                                  |
| Module          | Digital-to-Analog Converter                                                                      |
| Inputs –        | Control Lines: Controls operation and settings.                                                  |
|                 | Data Bus: Digital.                                                                               |
|                 | Regulated Power: DC voltage source.                                                              |
| Outputs –       | Analog Data Line: Analog. Transmitted to outside world. Converted at a resolution of higher      |
|                 | than 8-bits, and a rate of 10,000 samples per second.                                            |
| Functionality - | Takes digital data sent to it and converts it into an analog representation.                     |

# **Implementation Concept Block Diagram**

Figure IV below displays the implementation concept block diagram, indicating the physical component breakdown of the system. The control/processing unit consists of two processors, one which primarily controls the video capture and processing, and one which primarily controls the analog data transmission. The video data is captured by a digital camera unit. The non-volatile memory consists of a microSD card inserteded into the video processors board (on which the video processor's operating system is also stored). The digital-to-analog converter also exists on a separate chip, and steps are taken to reduce the effect of noise generated by the digital circuitry it. The power regulation system is actually comprised of multiple regulators associated with each submodule in order to provide the voltage levels necessary for all of the components and subcomponents.



| FIGURE IV                                         |
|---------------------------------------------------|
| ROCKET CAM – IMPLEMENTATION CONCEPT BLOCK DIAGRAM |

Table IV describes in greater detail, important data flow signals shown in Figure IV.

| ROCKET CAM – DATA FLOW SIGNALS |                       |                                                                          |
|--------------------------------|-----------------------|--------------------------------------------------------------------------|
| Source                         | Signal                | Format/Function                                                          |
| Outside                        | Record Command –      | 1-Bit external control signal                                            |
| World                          | Transmit Command –    | 1-Bit external control signal                                            |
|                                | Image Field –         | Physical light striking the sensor                                       |
|                                | Power –               | DC 3 to 13V, constant voltage source at up to 100mA                      |
|                                |                       | or programmable 28V (max) voltage source, with unspecified current       |
|                                |                       | capability (higher than 100mA)                                           |
| Image                          | Raw Image Data –      | Camera Serial Interface (CSI-2), 15 pin interface [7]                    |
| Sensor                         |                       |                                                                          |
| Rasp. Pi                       | Raw Image             | Camera Serial Interface (CSI-2), 15 pin interface                        |
| w/ Cam                         | Data/Camera Control – |                                                                          |
| Rasp. Pi                       | Compressed Data –     | 8-pins parallel data + 2-pins control (data ready & more data available) |
|                                |                       |                                                                          |
| Tiva C.                        | Buffered Data –       | 8-pins parallel data + 1-pins control (write enable)                     |
|                                | Request Data –        | 1-pin control                                                            |

1-pin. 0-10 V analog value with minimum of 8-bit accuracy.

# TABLE IV

Additional, parameters necessary for functional components in the design are summarized below.

Control/Processing Unit -

Analog Video Data -

DAC

Capable of inputting image data at real time video speeds •

- $\circ \geq 27.648 * 10^6 \text{ Bps} \left( 640 * 480 \frac{pixels}{frame} * 3 \frac{Byte}{pixel} * 30 \text{ fps} \right) \text{ [YCbCr format]}$
- Capable of storing image data to memory at real time video speeds

$$\circ \geq 9.216 * 10^{6} \text{ Bps} \quad \left(640 * 480 \frac{pixels}{frame} * 1 \frac{Byte}{pixel} * 30 \text{ fps}\right) \quad [\text{Grayscale format}]$$

- Capable of outputting a byte to the DAC at consistent frequencies up to 5 kHz
  - Maximum hypothetical unsynchronized transmission rate, the Nyquist Rate
    - $\circ$  Maximum allowable timing deviation, 20 µs (10%)
- Compression takes less than 2 minutes to complete
  - Any processing time beyond this mark must either be more than compensated in reduced transmission time, or must occur concurrently with transmission of earlier data
- Cost less than \$60

Image Sensor -

- Capable of VGA quality resolution at 30 frames per second
  - o 640x480 pixels @ 30 fps
- Minimum of 8-bit luma depth
  - 8-bit grayscale can be extracted

#### Memory -

• Capable of inputting image data at real time video speeds

$$\circ \geq 9.216 * 10^{6} \text{ Bps} \quad \left(640 * 480 \frac{pixels}{frame} * 1 \frac{Byte}{pixel} * 30 \text{ fps}\right) \quad [\text{Grayscale format}]$$

• Sufficient memory to store both raw and compressed video data

$$\circ \geq 9.216 * 10^{6} \text{ Bytes} \qquad 2 * \left( 640 * 480 \frac{pixels}{frame} * 1 \frac{Byte}{pixel} * 30 \text{ fps} * 0.5 \text{ s} \right)$$

Digital-to-analog converter -

- Output levels of 0-10 V (unipolar operation)
  - The values read by the existing ADC
- Slew + settling time (to within 10/256 V) should be less than  $100 \ \mu s$ 
  - Operating at 3.33 kHz this means that at least 2/3 of the period should be at the correct level, and with the external ADC sampling 3 times for each period, two out of three samples should contain the correct value.
- Monotonic
  - An increase in value always equates to an increase in voltage
  - Total Unadjusted Error should be less than 10/256 V and INL < the 8<sup>th</sup> bit (1 LSB if a 8-bit DAC) [8]
    - The importance of these requirement can be reduced by sending a calibration signal over the line, prior to any data transmission, and accounting for existing offsets.

#### V. Technology Choices and Design Approach Alternatives Considered

The primary technology choice central to this design, was how to implement the control/processing unit. Several possibilities were investigated. The two primary alternatives categories were: a low-cost ARM microcontroller with direct C programing and real time operation (typically targeted at controls applications), or a more expensive ARM microprocessor built for mobile applications and running a full operating system. Below are listed some of the pros and cons of each option.

ARM "Controls" family -

Pros:

• Low-cost (with development boards as low as \$13) [9]

- C environment gives designer a large degree of control over the behavior of the processor
- Interrupt driven, real time operation is possible
- Existing code for serial interfaces available for specific devices
- Existing C code for video compression could potentially be adapted for device

Cons:

- Small on-chip memory means video data must be stored off-chip
- Clock speeds and data transfer rates are on the edge of not being able to handle the live video data, especially with the need to immediately send it to external memory (though DMA's could help with this, that removes the possibility of performing any processing to the data before storage (i.e. convert to grayscale to save memory space))
- Compression algorithms would likely take significant time, and could be challenging to run simultaneously with data transmission

#### ARM "Mobile" family -

Pros:

- Sufficient data rates to handle video
- Active and helpful development communities and documentation (esp. for BeagleBone and Raspberry Pi)
- Existing projects and software for camera integration and video compression
- Either larger on chip memory, or relatively inexpensive development board with memory onboard

#### Cons:

• Non-real time operating systems make timings unreliable

#### FPGA -

Pros:

- Can be designed to handle capturing and moving video data into memory in real time, even with some preprocessing
- Various operations can be performed in parallel
- Hardware based compression algorithms could potentially run very fast
- Open source hobbyist community [10]
- Most flexible option

Cons:

- Most expensive option
- Requires external memory (or very large, and expense chip)
- HDL coding and implementation are potentially more challenging than software implementation

In the end, I choose a hybrid approach, utilizing both a low-cost "controls" ARM and a higher performance "mobile" ARM. This solution takes advantage of the benefits of both families. The higher performance processor can handle video capture and storage, and perform the computationally intensive compression operations; and it can make use of the large development communities, a higher level of abstraction, and available open source software, to streamline the development process. While the lower-performance controls ARM can control the analog data output with consistent, reliable timing, for little additional cost. This solution is still significantly less expensive than using an FPGA, and is also less expensive than high performance, real-time operation (single) ARM processors. The approach does have higher complexity than a single processor and requires the two to communicate with each other, but it also allows a greater degree of design flexibility.

A color image sensor was chosen, despite only needing grayscale data, because color image sensors are more prevalent, more supported, and actually cheaper. In specific an image sensor already supported by the "mobile" ARM processor was chosen.

A digital-to-analog converter that met all of the performance parameters discussed above was chosen.

Specifically the Raspberry Pi Model B+ development platform serves as the video capture, processing, and storage control role. The Raspberry Pi's low cost, large open-source development community, specifically supported low-cost camera unit, and existing software for performing H.264 video compression (included with the Raspbian operating system), caused its selection platform. The Raspberry Pi features a Broadcom BCM2835 system-on-a-chip, containing an ARM11 floating point CPU and Videocore 4 GPU [11]. For the analog data output control, the design uses the Tiva C Launchpad development platform, which features a Texas Instruments TM4C123GH6PM microcontroller with an ARM Cortex-M4 processor core and 32 KB of on-chip SRAM [12]. The Tiva C was chosen for its sufficient memory to buffer the video data, sufficient processing capabilities to control the data output and retrieval from the Raspberry Pi, and low-cost. The Raspberry Pi Camera Module's compatibility and support with Raspberry Pi determined its selection. The AD7245A digital-to-analog converter's compliance with the minimum static and dynamic performance parameters determined in the previous section, and its 0-10V unipolar operating mode allowed its consideration [13]. Its relatively simple parallel digital interface, and its availability in a PDIP package conducive to early prototyping furthered its selection.

# **VI. Project Design Description**

#### **Component Integration**

The Level 2 Block Diagram of the final design with additional signal and interconnection detail is shown in Figure V. It contains all functional submodule connections.



#### FIGURE V

### ROCKET CAM – IMPLEMENTATION CONCEPT BLOCK DIAGRAM LEVEL 2

The connection between the Raspberry Pi B+ and the Raspberry Pi Camera Module follows the MIPI standard and is controlled using existing drivers. The communication between the Raspberry Pi and the Tiva C consists of a custom parallel data interface (coded by the project designer). The Tiva C controls the AD7245A via a single-latched, parallel data loading structure (the AD7245A contains a double latched input, however, the design is configure so that one latch is left transparent).

For simplicity the schematic wiring diagrams showing specific pinouts are broken into 3 diagrams, centered around the 3 main subcomponents. This prevents crossing wires in the diagrams. Signal names correspond to those shown in Figure V.

Figure VI shows the pin connections for the AD7245A DAC. The DAC is configured in unipolar-mode, with the LDAC latch held transparent, the chip select engage, and latch clearing disabled. The design only makes use the upper 8 data bits and the lower 4 are tied to ground; this allows the design to make use of the higher precision the AD7245A has over most 8-bit DACs, without pushing the resolution to its limit and incurring less noise and drift resilience. The device configuration is primarily based on the unipolar configuration and microprocessor interfacing application notes contained within its datasheet [13].





Figure VII shows the pin connections for the Tiva C Launchpad evaluation board. In the design, the Tiva C serves the function of controlling the analog data output with reliable timing. After being informed that the Raspberry Pi has data ready for it, it buffers data from the RPi and sends it to the DAC at consistent time intervals. When the amount of data stored in the buffer falls below a minimum value, it requests the next byte from the RPi.



FIGURE VII TIVA C LAUNCHPAD PINOUT AND WIRING SCHEMATIC

Figure VIII shows the pin connections on the Raspberry Pi B+. The RPi's function is to receive record and transmit commands, control video data collection, perform video compression, store the video data, and send it to the Tiva C when requested. For the purposes of testing and debugging, the receive and transmit commands are instructions sent over an SSH connection from the designer's computer, rather than the specified 1-bit lines. However, switching to 1-bit TTL-level commands takes minimal effort (the RPi's gpio ports are already compliant with TTL-levels).



# FIGURE VIII RASPBERRY PI B+ PINOUT AND WIRING SCHEMATIC (IMAGE BASED ON RASPBERRYPI-SPY.CO.UK IMAGE [14])

# **Design Operation**

The final analog output of the design is at 256 discrete levels, corresponding to one full byte of data. Because of the inability to synchronize transmission and reception, the design faces Nyquist rate limitations. The DAC outputs the next byte at intervals of 300  $\mu$ s (or slightly longer), so that the receiving end will have at least 3 samples for every new voltage level (every new byte). If transition (slew) and settling times are below 100  $\mu$ s total, then (assuming negligible noise) there will be 2 settled samples with voltages correctly representing the byte of data, for each byte sent. Thus the analog data decoding algorithms on the receiving end can look for two consecutive readings at the same voltage level, to determine the byte value. The output interval is controlled by the Tiva C's timers, which are set to trigger at 3330 Hz. This necessity for settling in under 100  $\mu$ s, was a primary reason behind the choice of the AD7245A, as mentioned in Section V. Before actual data is sent, a calibration signal containing 2 full 300  $\mu$ s periods of every voltage level (byte value) is output, so that the decoding algorithm can adjust and calibrate for any offsets and persistent non-idealities of the DAC's output levels.

The Tiva C uses a 512-byte array as a circular type buffer. A byte received from the Raspberry Pi is stored into the array at one index location, while bytes sent to the DAC are read from a different index location. The program attempts to keep the receive index 500 elements in the lead of the send index, with the indices wrapping around when they reach the end of the array. The 500 element buffer length was chosen, because, during a test of the impact of the Linux's background multithreading on gpio output performance, the largest undesired delay (during a 3 minute measurement period) was approximately 5.3 ms with multiple others on the order of 4 ms. The 500 element buffering length, combined with the output interval of 300 µs, means that the buffer stores enough information for 150 ms, or roughly 30 times the maximum observed delay. This better than order of magnitude safety margin, which is desirable to protect against the possible danger if multiple delays are stacked before the buffer can be fully replenished. In the Tiva C's code, the receive and store process is run in the main program, while the read and send process occurs within an interrupt service routine (triggered by the timers).

The communication between the Raspberry Pi and the Tiva C uses the following pattern:

Begin: RPi: MoreData = 1; //To tell the TC there is data available
Repeat: TC: If the buffer is not full, set Send=1, else wait; //TC requests next byte from RP
RPi: Load the byte onto the Data[7:0] pins;
RPi: Set Ready=1; //Tell TC that the byte is ready
TC: Read byte
TC: Send = 0; //Acknowledge receipt of data
RPi: If no more data (file end reached), MoreData = 0;
RPi: Ready=0; //Prepare for the next loop iteration
TC: If MoreData==1, repeat, else break loop.

This communication method was specifically designed to be resilient to interrupts, both from the Tiva C's timers and from background threads in the Raspberry Pi's non-real time operating system (Raspbian Linux), and to neither lose its place in the process nor miss data that was sent, due to timing errors. Thus its asynchronous nature. This provides a reliable communication scheme, which can still be quite fast when compared to the 300 µs per byte that it must exceed, because (when not interrupted) the next step runs as soon as the previous step is completed (and the outputs are stable), at the clock speeds the two processors are configured for.

The code for the Tiva C was rewritten in C using Texas Instruments' Code Composer Studio IDE. During compiling, the optimization level for set to 1, while optimize-for-speed was set 5 (maximum), because sufficiently fast operation is critical to the buffer's reliability. The gpio interactions of the Raspberry Pi were written in C in a simple text editor, before being compiled in Linux terminal commands using the GCC compiler with standard compilation and optimization options. The code made use of the WiringPi library for gpio control [15]. Running the exiting video capture and compression code, as well as higher level program flow control, takes place in Linux shell scripts. The compressed H.264 video data is wrapped in .mp4 format using the MP4Box application [16]. The analog data capture for testing purposes used an Analog Discovery's oscilloscope, which was being controlled by a Python script provided with the beta 2.8.13 Version of its software development kit (WaveformsSDK)[17][18]. Decoding of analog data and reconstruction into a digital file is performed in Matlab. Samples of all the source code developed for the project are included in Appendix D.

#### **VII. Physical Construction and Integration**

For prototyping purposes the design consists of the Tiva C Launchpad and Raspberry Pi B+ development boards, and an AD7245A in a PDIP package on a breadboard, all interconnected via wire-leads and jumpers, as shown in Figure IX.



FIGURE IX Rocket Cam: Final Prototype

On the breadboard, all ground connections (especially for analog references) are made as physically close together as practical, and capacitive coupling is added between all nodes that are supposed to have fixed DC values. Figure X is a closer image of the bread board section.



FIGURE X Rocket Cam: Final Prototype - DAC

For the prototype, power for the AD7245A is provided by a voltage source set to 12.5 V. Power (5V) for the Tiva C Launchpad is provided over a micro-USB connection. When debugging this is typically connected to the designer's computer. Power (5V) for the Raspberry Pi B+ is also provided via a micro-USB connection. This connection is typically to a wall outlet adapter.

# **VIII. Integrated System Tests and Results**

For testing purposes the recovered, processed, and reconstructed video data from the analog output of the module is compared with the raw video data stored in the modules memory (accessed via an Ethernet connection). The reconstructed byte-array in Matlab is compared to the original file viewed as a byte-array. The following numbers are based off of a specific test of the video capture and transmission.

The first statistic to consider is the number of times the Matlab code detected that it had failed to read a byte, these points are stored in the byte array as NaN's (Not-a-Number's). This occurs when Matlab does not detect a settled value within 4 samples of the previous byte. The resulting count was:

NaN Count: 1025

The next relevant statistic is the length of the reconstructed data array, vs the actual data array. This gives a general starting point for comparison of the too samples.

| Actual Video Data Length:  | 959038 bytes |
|----------------------------|--------------|
| Reconstructed Data Length: | 959034 bytes |

Which means that the decoding algorithm failed to read at least 4 bytes, which it did not explicitly detect as failed reads and use a NaN as a placeholder for. Also note that this also allows the calculation of the percentage of detected unreadable bytes, 1025/959038 = 0.107%.

Table V shows a comparison of the first 12 and the last 12 bytes of the actual and the reconstructed data. The sets clearly correlate, however there are several single bit errors present, most likely due either to inaccurate calibration of the decoding, or to noise on the analog line.

|               | -      |        |       | ·     | -     |       |       |       |       |       |       |     |
|---------------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----|
| Index         | 1      | 2      | 3     | 4     | 5     | 6     | 7     | 8     | 9     | 10    | 11    | 12  |
| Actual        | 0      | 0      | 0     | 24    | 102   | 116   | 121   | 112   | 105   | 115   | 111   | 109 |
| Reconstructed | 0      | 0      | 0     | 24    | 102   | 116   | 121   | 112   | 104   | 115   | 111   | 109 |
|               |        |        |       |       |       |       |       |       |       |       |       |     |
| Index         | end-11 | end-10 | end-9 | end-8 | end-7 | end-6 | end-5 | end-4 | end-3 | end-2 | end-1 | end |
| Actual        | 67     | 32     | 48    | 46    | 53    | 46    | 48    | 45    | 114   | 101   | 118   | 0   |
| Reconstructed | 68     | 32     | 48    | 47    | 53    | 47    | 48    | 45    | 114   | 101   | 119   | 0   |

TABLE V

A plot of the between the first 50,000 bytes of the two arrays shows that up to the 24,138th byte, there was at most single, least significant bit errors. Figure XI shows this.



The 24,139th byte represents the appearance of an index offset, after which the array values no longer match up.

The primary cause of unreadable bytes is parasitic RC delays that increase the settling time of large code transitions to the point that two settled sample values are not detected before the output transition to a new value. Using the test file whose analog output is shown in Figure XII, it was determined that at code transitions of greater than about 50, byte detection became unreliable.



Because of the various errors present, the reconstructed file could not be opened by normal .mp4 players.

Summarizing, over 99% of the digital by bytes transmitted were recovered to within 99% accuracy; however, this is not sufficient for corruption free transmission of .mp4 files.

# **IX.** Conclusions

The complete specifications were not met. Because of the noise and delay errors, the reconstructed, compressed video data file was corrupted and unreadable. In part this is due to the unforgiving nature of H264 compression, and compression in general, to errors. Compression involves the reduction of statistical redundancy in data, and reduction of redundancy also means a reduction in resilience to errors [19]. In its current state, the channel and reconstruction likely has sufficient accuracy for uncompressed video data to be sent and recovered with adequate quality. However, uncompressed video cannot have the specified video duration and resolution and still be transmitted in the specified time. In addition, although documentation to the contrary exists, the drivers for the Raspberry Pi Camera Module do not currently support 30 frames per second capture, the videos are actually captured at 25 fps (83% the specified speed) [20].

Despite its inability (in its current form) to meet all of the specifications simultaneously, this project serves as a solid proof of concept for the technology. In the trials discussed above, less than 0.2% of all bytes transmitted were unreadable, and of those that were readable almost all were within one least significant bit of the correct value. Moving forward with this project to a PCB design would most likely resolve the primary issues preventing the project from fully meeting all of the specifications. A well designed PCB will have significantly lower parasitic capacitances than a breadboard circuit, allowing the time until a settled value, to be decreased, potentially to less than 100 µs for a full 10 V swing. Furthermore, implementation of noise suppression techniques and methods for isolating analog components from digital noise, should greatly reduce the number of least significant bit errors. This combined with improved reconstruction algorithms could potentially remove them altogether, allowing for complete, uncorrupted reconstruction of the compressed video data and achievement of all of the specifications.

Specifications that the design currently fully meets are: capable of recording at between 0.5 and 3 seconds of video; at least 640x480 pixel image resolution, at 8 bits per pixel; sufficient memory to store captured data and to perform compression operations on the data; output data over analog line; sufficient video data compression such that sample transmission requires less than 10 minutes (minimum compression factor of 2 to 1); finished production units should cost no more than \$200 (Note: the component costs of the final prototype are at less than \$100); and use at least 70% ROHS compliant components. The 1-bit TTL-level record and transmit were not implemented in the final design for debug and testing reasons, but would be trivial to add to it.

Overall the project meets the majority of its specifications, and meets each of the remaining specifications by better than 80%, and there are clear routes that can improve the design until all of the specifications are met.

#### References

[1] Orbital Sciences Corporation, "Rocket Camera Proposal," *Orbital Sciences Corporation*, Unknown Date. [Online]. Available: Cal Poly Polylearn: EE460. [Accessed: Aug. 27, 2014].

[2] Orbital Sciences Corporation, "Rocket Camera Proposal – Revised 10/21/14," *Orbital Sciences Corporation*, Oct. 2014. Unpublished.

[3] M. Noonen, K. Deierling, K. Barraclough, and B. Martin, "Video compression and decompression arrangement having reconfigurable camera and low-bandwidth transmission capability," U.S. Patent 5 926 208, July 20, 1999.

[4] G.J. Sullivan and T. Wiegand, "Video Compression - From Concepts to the H.264/AVC Standard," Proceedings of the IEEE, vol.93, no.1, pp.18,31, Jan. 2005. Available: IEEE Xplore, <u>http://www.ieee.org</u> [Accessed: 10/20/14]

[5] Kyusam Lim; Jeonghun Kim; Hwangyoung So; Sejin Kang; Suki Kim, "A Low Power QXGA Camera Signal Processor for Mobile Camera Applications," International Conference on Consumer Electronics, 2007. ICCE 2007. Digest of Technical Papers., vol., no., pp.1,2, 10-14 Jan. 2007. Available: IEEE Xplore, <u>http://www.ieee.org</u> [Accessed: 10/20/14]

[6] M.L. Kaddachi, L. Makkaoui, A. Soudani, V. Lecuire, and J. Moureaux, "FPGA-based image compression for low-power Wireless Camera Sensor Networks," 3rd International Conference on Next Generation Networks and Services (NGNS), 2011, vol., no., pp.68,71, 18-20 Dec. 2011. Available: IEEE Xplore, <u>http://www.ieee.org</u> [Accessed: 10/20/14]

[7] D. Braun, "EE 460 Gantt Chart – Fall 2014," Cal Poly Courseware – EE. [Online]. Available: https://courseware.ee.calpoly.edu/~dbraun/courses/ee460/EE460Gantt.html. [Acessed: 10/27/14]

[8] I. Wahidah, A.B. Suksmono, Hendrawan, and T.L.R. Mengko, "Compressive sampling for digital video signal compression involving dynamic sparsity," 7th International Conference on Telecommunication Systems, Services, and Applications (TSSA), 2012, vol., no., pp.46,50, 30-31 Oct. 2012. Available: IEEE Xplore, <u>http://www.ieee.org</u> [Accessed: 10/20/14]

[9] Aptina Imaging, "1/4-Inch VGA Digital Sensor - MT9V011 Data Sheet," Aptina Imaging. [Online]. Available: Aptina, www.aptina.com . [Accessed: 11/15/14]

[10] Cypress Perform, "4-Mbit (256 K x 16) Static Ram - CY7C1041DV33 Data Sheet," Cypress Perform. [Online]. Available: Cypress, <u>www.cypress.com</u>. [Accessed: 11/15/14]

[11] Cypress Perform, "4-Mbit (256 K x 16) Static Ram," CY7C1041DV33 datasheet [Online]. Available: Cypress, www.cypress.com. [Accessed: 11/15/14]

[12] Analog Devices, "LC2MOS 12-Bit DACPORTs," AD7245A/AD7248A datasheet [Online] Available: Analog, www.analog.com. [Accessed: 6/12/15]

[13] Analog Devices, "LC2MOS 12-Bit Serial DACPORTs," AD7243 datasheet [Online] Available: Analog, <u>www.analog.com</u>. [Accessed: 6/12/15]

[14] Analog Devices, "12-Bit 100 kSPS A/D Converter," AD7243 datasheet [Online] Available: Analog, <u>www.analog.com</u>. [Accessed: 6/12/15]

[15] Linear Technology, "10kHz to 150kHz Digitally Controlled Antialiasing Filter and 4-Bit P.G.A," LTC1564 datasheet [Online] Available: Linear, <u>www.linear.com</u>. [Accessed: 6/12/15]

[16] Digilent, "PmodSF2 Reference Manual," [Online] Available http://www.digilentinc.com. [Accessed: 6/12/15]

[17] Numonyx, "Numonyx® OmneoTM P5Q PCM," P5Q PCM datasheet, [Online] Available, Digilent Inc, <u>http://www.digilentinc.com</u>. [Accessed: 6/12/15]

[18] E2e.ti.com, "SPI Speed on ARM microprocessors (Tiva for example) - TM4C Microcontrollers Forum - TM4C Microcontrollers - TI E2E Community," 2015. [Online]. Available: http://e2e.ti.com/support/microcontrollers/tiva\_arm/f/908/p/274452/958695. [Accessed: 6/12/15].

[19] Elinux.org, "RPi Low-level peripherals - eLinux.org," 2015. [Online]. Available: <u>http://elinux.org/RPi Low-level peripherals#GPIO Code examples</u>. [Accessed: 6/12/15].

[20] Wiringpi.com, 'WiringPi', 2015. [Online]. Available: http://wiringpi.com/. [Accessed: 6/12/15].

[21] Raspberrypi.org, "Raspberry Pi Forums - DMA and SPI and Interrupts - cant get it to work," 2015. [Online]. Available: <u>https://www.raspberrypi.org/forums/viewtopic.php?f=71&t=19797</u>. [Accessed: 6/12/15].

[22] Raspberrypi.org, "Raspberry Pi Forums - DMA on GPIO," 2015. [Online]. Available: https://www.raspberrypi.org/forums/viewtopic.php?f=44&t=8376. [Accessed: 6/12/15].

[23] Wallacoloo, "Wallacoloo/Raspberry-Pi-DMA-Example," GitHub, 2014. [Online]. Available: https://github.com/Wallacoloo/Raspberry-Pi-DMA-Example/blob/master/dma-gpio.c. [Accessed: 6/12/15].

[24] J. Pihlajamaa, 'Benchmarking Raspberry Pi GPIO Speed | Code and Life', Codeandlife.com, 2012. [Online]. Available: http://codeandlife.com/2012/07/03/benchmarking-raspberry-pi-gpio-speed/. [Accessed: 6/12/15].

[25] Raspberrypi.stackexchange.com, 'How to compile C files in terminal', 2015. [Online]. Available: http://raspberrypi.stackexchange.com/questions/5599/how-to-compile-c-files-in-terminal. [Accessed: 6/12/15].

[26] Raspberrypi.org, "Raspberry Pi Camera Module -Applications," Raspberry Pi Documentation 2015. [Online]. Available: https://www.raspberrypi.org/documentation/raspbian/applications/camera.md. [Accessed: 6/12/15].

[27] Raspberrypi.org, "Camera - Hardware," Raspberry Pi Documentation 2015. [Online]. Available: https://www.raspberrypi.org/documentation/hardware/camera.md. [Accessed: 6/12/15].

[28]A. Allain, "C File I/O Tutorial - Cprogramming.com." Cprogramming.com, 2015. [Online]. Available: http://www.cprogramming.com/. [Accessed: 6/12/15].

[29] Codingunit.com, "C Tutorial – Binary File I/O | CodingUnit Programming Tutorials," 2015. [Online]. Available: <u>http://www.codingunit.com/c-tutorial-binary-file-io</u>. [Accessed: 6/12/15].

[30] M. Samek, "Are We Shooting Ourselves in the Foot with Stack Overflow?", Embeddedgurus.com, 2015. [Online]. Available: <u>http://embeddedgurus.com/state-space/2014/02/are-we-shooting-ourselves-in-the-foot-with-stack-overflow</u>. [Accessed: 6/12/15].

[31] N. Jones, "Efficient C Tip #13 – use the modulus (%) operator with caution," Embeddedgurus.com, 2015. [Online]. Available: <u>http://embeddedgurus.com/stack-overflow/2011/02/efficient-c-tip-13-use-the-modulus-operator-with-caution/</u>. [Accessed: 6/12/15].

[32] Oshpark, "OSH Park ~ Pricing and Specifications," 2015. [Online]. Available: <u>https://oshpark.com/pricing</u>. [Accessed: 6/12/15].

[33] R. Gonzalez, and R Woods, Digital Image Processing, 3rd ed. Upper Saddle River: Prentice Hall, 2007.

# Appendix A – Analysis of Senior Project Design

Project Title: Rocket Cam: Low Frequency Analog Transmission of Digital Video

Student's Name: Thomas Higdon

Advisor's Name: Professor Wayne Pilkington

#### **1. Summary of Functional Requirements**

The design's overall function inputs visible light video image data, and then to outputs an analog voltage representation of that data. The module also accepts two commands, record and transmit. Upon receipt of the record command, the module captures and stores 3 seconds of video data. Upon receipt of the transmit command, the module sends that data over the analog data line [1],[2].

#### 2. Primary Constraints

The primary challenges came from the need to transmit the video data over a narrow bandwidth analog data channel. The available channel is sampled at 10,000 samples per second (at most), with 12 bit resolution. Thus, the primary challenges to overcome in order to meet product specifications involved: devising an effective analog encoding scheme within this bandwidth; compressing the data so that it takes a short enough duration to transmit (sending entire sample within mean flight time; keeping the noise from the module components off of the analog channel; maximizing the signals resilience to noise; and handling bit errors that occur. A supplemental challenge was establishing reliable communications between components.

#### 3. Economic

The product's design and creation utilized multiple forms of capital. In human terms, a variety of individuals have contributed to the project's success (discussed further in terms of direct and indirect stakeholders in the Social and Political section). In addition, the project made use of third party services such as major components vendors, component manufacturers, and delivery infrastructure. In this way, the project utilizes the existing infrastructure of these organizations, rather than necessitating the construction of entirely new facilities. Lastly, the materials used to manufacture the product come from the planet itself, as does the energy used in the manufacturing process and in operation.

The direct monetary investment in the project, for physical component and equipment purchases, rounds to approximately \$200. However, the equivalent monetary value of the labor provided in the development process approaches \$8,000 dollars. Tables A1 and A2 below, detail the preliminary planning estimates of costs for components and labor (estimated using \$30/hour). The formula, *estimated* = (min + 4\*typical + max)/6, yields the PERT values listed. Further below, Tables A3 and A4 detail the actual final costs for part and labor.

| LSTIMA          |      | AKIS    | AND EQU     | IPMENT CO  | 212 |       |
|-----------------|------|---------|-------------|------------|-----|-------|
| Estimated Dev   | velo | pmer    | nt Costs    | (Equipme   | nt) |       |
| Final Prototype |      |         |             |            |     |       |
| System          | Min  |         | Тур         | Max        | PE  | RT    |
| Camera          |      | \$5     | \$10        | \$40       | \$  | 14.17 |
| Controller      |      | \$10    | \$25        | \$80       | \$  | 31.67 |
| Data Storage    |      | \$2     | \$8         | \$30       | \$  | 10.67 |
| DAC             |      | \$2     | \$10        | \$20       | \$  | 10.33 |
| Misc. Passive   |      | \$1     | \$5         | \$20       | \$  | 6.83  |
| Power Systems   |      | \$4     | \$6         | \$25       | \$  | 8.83  |
| PCB             |      | \$40    | \$75        | \$150      | \$  | 81.67 |
| Total -         |      | \$64    | \$139       | \$365      |     | \$164 |
|                 |      |         |             |            |     |       |
| Development C   | ycle | 's 1 ar | nd 2 (Not I | PCB Versic | n)  |       |
| System          | Min  |         | Тур         | Max        | PE  | RT    |
| Total           |      | \$24    | \$64        | \$215      | \$  | 82.50 |
|                 |      |         |             |            |     |       |
| Development a   | nd T | est Eq  | uipment     |            |     |       |
| System          | Min  |         | Тур         | Max        | PE  | RT    |
| Total           |      | \$20    | \$35        | \$120      | \$  | 82.50 |
|                 |      |         |             |            |     |       |
| Equip. Total    | Min  |         | Тур         | Max        | PE  | RT    |
|                 |      | \$108   | \$238       | \$700      |     | \$329 |

# TABLE A1

# ESTIMATED PARTS AND EQUIPMENT COSTS

# TABLE A2

## ESTIMATED LABOR COSTS

| Estimated Dev  | velopmer  | nt Costs ( | Labor)    |           |
|----------------|-----------|------------|-----------|-----------|
| Labor (Weekly) |           |            |           |           |
| Person         | Min       | Тур        | Max       | PERT      |
| Myself (hrs)   | 8         | 18         | 30        | 18.3      |
| Myself (\$)    | \$ 240.00 | \$ 540.00  | \$ 900.00 | \$ 550.00 |
|                |           |            |           |           |
| Labor (Total)  |           |            |           |           |
| Person         | Min       | Тур        | Max       | PERT      |
| Myself (hrs)   | 160       | 360        | 600       | 366.7     |
| Myself (\$)    | \$4,800   | \$10,800   | \$18,000  | \$11,000  |
| Others (hrs)   | 10        | 15         | 40        | 18.3      |
| Myself (\$)    | \$300     | \$450      | \$1,200   | \$549     |
|                |           |            |           |           |
| Grand Total    | Min       | Тур        | Max       | PERT      |
|                | \$5,100   | \$11,250   | \$19,200  | \$11,549  |

These estimated costs corresponded to the planned development cycle illustrated in the Gantt charts in Tables A5 (a), A5 (b), & A5 (c).

Tables A3 and A4 detail the actual final costs for part and labor (approximated using an updated \$35/hour) for the project. The parts whose costs are listed at N/A, are ones which were already owned before the start of the project, but are important enough to the final prototype, to warrant explicit mentioning in the table. Components and devices used for early prototyping, and for development and testing, but not purchased specifically for the project are not listed.

#### TABLE A3

| ACTUAL PARTS AND EQUIPMENT COSTS |  |
|----------------------------------|--|

| Actual Developmen    | nt Costs (Equipment)     |           |                     |      |         |       |          |
|----------------------|--------------------------|-----------|---------------------|------|---------|-------|----------|
| Final Prototype      |                          |           |                     |      |         |       |          |
| System               | Part Name/Number         | Vender    | Manufacturer        | Base | e Price | Cost  | (w∕ Tax) |
| Camera               | Raspeberry Pi 5MP Camera | Amazon    | Raspberry Pi Foun.  | \$   | 26.95   | \$    | 29.38    |
| Video Data Processor | Raspberry Pi - Model B+  | MCM Elec. | Raspberry Pi Foun.  | \$   | 25.00   | N/A   |          |
| Memory               | 16 GB Micro SD Card      | Amazon    | Kingston Digital    | \$   | 6.95    | N/A   |          |
| DAC                  | AD7245AANZ               | DigiKey   | Analog Devices      | \$   | 19.37   | \$    | 20.92    |
| D/A Control Unit     | Tiva C TM4C123GXL Eval   | DigiKey   | Texas Instruments   | \$   | 16.68   | \$    | 18.01    |
| Misc. Passive        | Caps/Resistors/Leads     | N/A       | N/A                 | \$   | 2.00    | N/A   |          |
|                      |                          |           | Total -             | \$   | 96.95   |       | \$68     |
| Early Prototype      |                          |           |                     |      |         |       |          |
| System               | Part Name                | Vender    | Manufacturer        | Base | e Price | Cost  | (w/ Tax) |
| Camera               | OV7670 300KP VGA Module  | Amazon    | Atomic Market       | \$   | 10.99   | \$    | 10.99    |
| Memory               | PmodSF2 - Serial PCM     | Amazon    | Digilent            | \$   | 14.95   | \$    | 14.95    |
| DAC                  | AD7243ANZ                | DigiKey   | Analog Devices      | \$   | 16.68   | \$    | 16.68    |
|                      |                          |           | Total:              | \$   | 42.62   | \$    | 42.62    |
| Development and Te   | st Equipment             |           |                     |      |         |       |          |
| Function             | Part Name                | Vender    | Manufacturer        | Base | e Price | Cost  | (w/ Tax) |
| ADC                  | AD1674JNZ                | DigiKey   | Analog Devices      | \$   | 29.17   | \$    | 31.50    |
| USB-UART Cable       | 768-1204                 | DigiKey   | FTDI                | \$   | 15.00   | \$    | 16.20    |
| Antialiasing Filter  | LTC1564IG#PBF            | DigiKey   | Linear Technologies | \$   | 17.59   | \$    | 19.00    |
| Breakout BNC         | FEMALE-20AWG LEADS       | DigiKey   | Pomona Electronics  | \$   | 17.10   | \$    | 18.47    |
|                      |                          |           | Total:              | \$   | 78.86   | \$    | 85.17    |
|                      | Shipping and Handing:    |           |                     |      |         |       |          |
| Total                | \$16.50                  |           | Equip. Total        | Base | e Price | Actua | l Cost   |
|                      |                          |           | S&H: \$16.50        | \$   | 218.43  | \$    | 196.10   |

# TABLE A4Actual (Approx.) Labor Costs

| Approximant I | Developn  | nent Cost | s (Labor) |           |
|---------------|-----------|-----------|-----------|-----------|
| Labor (Weekly | Averaged) |           |           |           |
| Person        | Min       | Тур       | Max       | PERT      |
| Myself (hrs)  | 8         | 10        | 15        | 10.5      |
| Myself (\$)   | \$ 280.00 | \$ 350.00 | \$ 525.00 | \$ 367.50 |
|               |           |           |           |           |
| Labor (Total) |           |           |           |           |
| Person        | Min       | Тур       | Max       | PERT      |
| Myself (hrs)  | 160       | 200       | 300       | 210.0     |
| Myself (\$)   | \$5,600   | \$7,000   | \$10,500  | \$7,350   |
| Others (hrs)  | 12        | 18        | 25        | 18.2      |
| Others (\$)   | \$420     | \$630     | \$875     | \$636     |
|               |           |           |           |           |
| Grand Total   | Min       | Тур       | Max       | PERT      |
|               | \$6,020   | \$7,630   | \$11,375  | \$7,986   |

The initial planning timeline for project development is shown in Tables A5 (a), A5 (b), & A5 (c) below.

# TABLE A5 (a)

# PLANNING GANTT CHART – FALL QUARTER AND WINTER BREAK 2014 [21]

| EE 460 Gantt Chart                |          |          |        |        |          |    |        |         |         |          |     |       |          |     |     |       |            |       |        |       |        |          |       |        |               |        |          |      |     |         |         |      |   |          |    |      |
|-----------------------------------|----------|----------|--------|--------|----------|----|--------|---------|---------|----------|-----|-------|----------|-----|-----|-------|------------|-------|--------|-------|--------|----------|-------|--------|---------------|--------|----------|------|-----|---------|---------|------|---|----------|----|------|
| Fall 2014                         |          |          |        |        |          |    |        |         |         |          |     |       |          |     |     |       |            |       |        |       |        |          |       |        |               |        |          |      |     |         |         |      |   |          |    |      |
|                                   |          | eek 1    |        |        | eek 2    |    | Week   |         |         | Week 4   |     |       | eek 5/   |     |     | eek 6 |            |       | Veek ' |       |        | Wee      |       |        |               | eek 9  |          |      | eek |         |         | Weel |   |          |    | nals |
|                                   |          | WR       |        |        | W R I    | _  |        | R F     |         | T W F    | t F |       | WR       | _   |     | W R   | F          | _     | WI     | ιF    |        |          | R     |        |               | WR     | t F      |      | W   | R F     | Μ       | ΤW   | R | F M      | ΤV | W R  |
| Project Plan                      | 22       |          |        | 29     |          | 6  |        |         | 13      |          | _   | 20    |          | _   | 27  | _     |            | 3     |        | _     | 10     | _        |       | 1      | 17            |        | _        | 24   |     |         | 1       |      |   | 8        | _  | _    |
| Abstract (Proposal) V1            |          |          |        |        |          |    |        |         |         |          |     |       |          |     |     |       |            |       |        |       | _      |          |       |        |               |        |          |      |     |         |         |      |   | T        |    |      |
| Requirements and Specifications   |          |          |        |        |          |    | 0      | -       |         |          | -   |       |          | -   |     | _     | _          |       | _      |       | _      |          |       | -      | _             |        |          | _    | _   | _       |         | -    |   |          | _  |      |
| Block Diagram                     |          |          |        |        |          |    |        |         | h . /   | <b>)</b> |     |       |          | -   |     | NO    | <b>)TE</b> | Du    | ıe d   | late  | es /   | AND      | ) fe  | ed     | ba            | ck ı   | req      | uire | d   |         |         |      |   |          |    |      |
| Literature search                 |          |          |        |        |          |    |        |         |         | J        |     | ▲     |          | -   |     |       |            |       |        |       |        |          |       |        |               |        |          |      |     |         | -       |      |   |          |    |      |
| Gantt Chart                       |          |          |        |        |          |    |        |         |         |          |     |       | 2        |     | A - | -     |            | -     |        | -     | _      |          |       |        |               |        | -        |      |     |         |         |      |   |          |    |      |
| Cost Estimates                    |          |          |        |        |          | _  |        |         |         |          |     |       |          |     |     | _     |            | _     |        |       | _      |          |       |        |               |        | -        |      |     | _       | -       | _    |   |          | _  |      |
| ABET Sr. Project Analysis         |          |          |        |        |          | _  |        | _       |         |          |     |       |          |     |     |       |            | ▲     |        |       | _      | _        |       |        |               |        | -        |      |     |         | -       |      |   |          |    |      |
| Requirements and Specifications V | )   In++ | ~        |        |        |          | _  |        | _       |         |          |     |       |          | T   |     |       |            | - U   | 1      |       |        |          |       |        |               |        |          |      |     |         |         |      |   |          |    |      |
| Report VI                         | 2 + 1111 | 0        |        |        |          |    |        |         |         |          |     |       |          |     |     |       |            |       |        |       | 1-     | Ŷ        |       | ^      |               |        | ·        |      |     | _       | -       |      |   |          |    |      |
| Advisor Feedback Due              |          |          |        |        |          |    |        |         |         |          |     |       | 2        |     |     |       |            |       |        |       |        |          | ,     | _      |               | -      |          |      |     | 2       | -       | -    |   |          | _  |      |
| Report V2                         |          |          |        |        |          | _  |        |         |         |          |     |       | <b>4</b> | -   |     | _     |            | _     |        |       | _      |          |       |        |               |        |          |      |     | 4       | ,       |      |   | <u> </u> |    | _    |
| Report V2                         |          |          |        | _      |          | -  |        | _       |         |          |     |       |          | -   |     | _     |            | _     |        |       | -      | -        |       |        | _             |        |          |      |     |         |         |      |   | ┭≏       |    |      |
| Presentations                     |          |          |        |        |          | _  |        |         |         |          |     |       |          |     |     |       |            |       |        |       |        | -        |       |        |               |        | -        |      |     |         |         |      |   |          |    |      |
| Requirements and Specifications   |          |          |        |        |          | _  |        |         | $\odot$ |          |     |       |          |     |     |       |            |       |        |       |        |          |       |        |               |        |          |      |     |         |         | _    |   |          |    |      |
| Report V1                         |          |          |        |        |          | _  |        | _       |         |          |     |       |          | -   |     | _     |            | _     |        |       | _      |          |       |        |               |        |          |      |     |         | <u></u> |      |   |          |    |      |
| Report VI                         |          |          | -      |        |          | -  |        |         |         |          | -   |       |          |     |     | -     |            | -     |        | -     | -      | -        |       |        |               |        | -        |      |     | -       | 9       | -    |   | _        |    |      |
| HW1 Resume & Cover Lette          |          |          |        |        | -        | -  |        | -       |         |          |     |       |          |     |     |       |            |       |        | -     |        | -        |       | +      |               |        | -        |      |     |         |         |      |   |          |    |      |
| Due                               |          |          |        |        |          | _  |        | -       |         |          |     |       |          | -   |     |       |            |       |        | -     | -      |          |       |        |               |        | -        |      |     |         |         |      |   |          |    |      |
| HW 2 Sensitivity Analysis         |          |          |        | 4      | <u> </u> | -  |        | _       | -       |          | _   |       |          |     |     | -     |            | _     |        | _     | -      |          |       | -      |               |        |          |      | -   |         | -       | _    |   | _        |    |      |
| Due                               |          |          |        |        |          | _  |        |         |         |          |     |       |          |     |     |       |            | _     |        | _     | _      |          |       |        |               |        | -        |      |     | _       | -       | _    |   |          |    | _    |
|                                   |          |          |        |        |          | -  |        |         |         |          |     |       | _        | -   |     |       |            |       |        |       |        | <u> </u> |       |        |               |        | <u> </u> |      |     |         |         | _    |   |          |    |      |
| HW 3 Reverse Engineering          |          |          | _      |        |          |    | _      | _       |         |          | _   |       | _        | _   |     | _     |            | _     |        | _     | -      | _        |       | - (    | 6             | 60     | ))—      |      |     |         | -       | _    |   |          |    | _    |
| Due                               |          |          |        | _      |          | _  |        | _       |         |          | _   |       |          | _   |     | _     |            | _     |        | _     | -      | _        |       |        | V Contraction | YEX IN | <u>y</u> |      |     |         | -       | _    |   | _        | _  |      |
| Final Exam                        |          |          |        |        |          | _  |        |         |         |          | _   |       |          |     |     | _     |            |       |        | _     | _      | _        |       |        | _             | _      | _        |      |     |         |         | _    |   | :        |    |      |
|                                   |          | . т.     | eam A  | aian   | nant     | ~  | Feedb  | nal: De |         | vd.      | •   | Accir | nment    | Due |     |       | 5 Du       | in to | Advis  | or b  | - Inci |          | In al |        |               |        | at       | -    | Ad  | visor I | Foodl   | book |   | _        | _  | _    |
| (0                                |          |          | eann A | ssigin | nem      | v  | reeub  | ack Re  | quite   | a        |     | Assig | innent   | Due | 13  | ₩ V1. | .5 Du      |       | Auvis  | 501 a | c ms   | u. 🥪     | m-ci  | lass a | assig         | ginner | iit.     | - 🝊  | Au  | VISOI   | reeut   | Jack |   | _        |    |      |
| K                                 |          | <u>y</u> |        |        |          |    |        |         |         |          |     |       |          |     |     |       |            | _     |        |       |        |          |       |        |               |        | -        |      |     |         |         |      |   |          |    |      |
|                                   | $\smile$ |          |        |        |          | EE | 460 C  | antt    | Char    | rt i     | -   |       |          | -   |     | _     | -          |       |        | +     |        | _        |       |        |               |        | _        |      |     |         |         |      |   |          |    |      |
|                                   |          |          |        |        |          | Wi | nter B | reak    | 2014    |          |     |       |          |     |     |       |            |       |        |       |        |          |       |        |               |        |          |      |     |         |         |      |   |          |    |      |
|                                   |          |          |        |        |          |    |        |         |         |          |     |       | Week     | 1   | W   | eek 2 |            | W     | eek 3  |       |        |          |       |        |               |        |          |      |     |         |         |      |   |          |    |      |
|                                   |          |          |        |        |          |    |        |         |         |          |     | M     | TWI      | R F | ΜT  | WR    | F          | ΜT    | WR     | F     |        |          |       |        |               |        |          |      |     |         |         |      |   |          |    |      |

|                           |   |    | W | leel | k 1 |   |    | W | Veel | s 2 |      |    | V | Veel | k 3 |     |
|---------------------------|---|----|---|------|-----|---|----|---|------|-----|------|----|---|------|-----|-----|
|                           | 1 | М  | Т | W    | R   | F | М  | Т | W    | R   | F    | М  | Т | W    | R   | F   |
|                           |   | 15 |   |      |     |   | 22 |   |      |     |      | 29 |   |      |     |     |
| Research                  |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     |     |
| Compression               |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     |     |
| Encoding / Comm Protocols |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     |     |
| Noise Reduction           |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     |     |
| Handling Bit Errors       |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     |     |
| ADCs & DACs               |   | _  | _ |      | _   | _ |    |   | _    |     |      |    |   | _    | _   | _   |
| Design                    |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     |     |
| Block Diagrams            |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     |     |
| Preliminary Parts Lists   |   |    |   |      |     |   |    |   |      |     |      |    |   |      |     | FF1 |
|                           |   |    |   |      |     |   | E  |   | Orc  | ler | Part | s  |   |      |     |     |

# TABLE A5 (b)

## PLANNING GANTT CHART – WINTER 2015

| EE 460 Gantt Chart                |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
|-----------------------------------|---|-----|---|---|-----|----|-----|------|-------------------|-------|------|-----|-----|------|-------|------|-----|------|---|------------------|-----|------|------|------|------|---|-----|-----|----|---|-------|-----|---|-----|------|-----|-----|----|---|-------------------------|---|-----|------|---|---|
| Winter 2015                       |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
|                                   |   | Wee |   |   |     | We |     |      |                   |       | ek 3 |     | W   | Veel | κ4    |      |     | Veel |   |                  |     | We   |      |      |      |   | eek |     |    |   | eek 8 |     |   |     | /eek |     |     |    |   | x 10                    |   |     | Fina |   |   |
|                                   | Μ | TW  | R | F | М   | ΤV | V R | F    | Μ                 | TW    | R    | F 1 | M T | W    | R     | F    | M T | W    | R | F                | М   | ΤV   | VF   | R F  | Μ    | Т | W   | R F | Μ  | Т | WF    | t F | N | 1 T | W    | R   | F 1 | ЛT | W | R                       | F | M T | W    | R | F |
|                                   | 5 |     |   |   | 12  |    |     |      | 19                |       |      |     | 26  |      |       |      | 2   |      |   |                  | 9   |      |      |      | 16   |   |     |     | 23 |   |       |     |   | 2   |      |     |     | 9  |   |                         |   | 16  |      |   |   |
| Cycle 1 (Prelim)                  |   | -   |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   | $oldsymbol{eta}$ |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Design Functioning Camera         |   | -   | - |   | ET. |    |     |      | $\mathbf{\Delta}$ |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Assemble Camera                   |   |     |   |   |     |    |     | -    |                   |       | -    | Δ   |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Design Prelim Analog Channel      |   |     |   |   |     |    |     |      | E.                |       |      |     |     |      |       |      | Δ   |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Assemble Prelim Analog Channel    |   |     |   |   |     |    |     |      |                   |       |      |     |     |      | -     |      |     | -    |   | $oldsymbol{eta}$ |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Cycle 2                           |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     | -  |   |       |     |   |     |      |     |     |    |   | 0                       |   |     |      |   |   |
| Implement Compression             |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   | t                |     |      | -    | -    |      |   | -   | -   | Δ  |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Improve Encoding Scheme           |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     | -  |   | -     | -   |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Optimize Compres/Encod Together   |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   | -     | +   |   | -   |      | Δ   |     |    |   |                         |   |     |      |   |   |
| Improve Reliability               |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   | ļ                |     |      | +    | -    |      | - | -   | -   |    | - | -     | -   |   | -   |      | Δ   |     |    |   |                         |   |     |      |   |   |
| Handle Errors / Reduce Corruption |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   | -     | -   | - | -   | -    | -   | _ 4 | 7  |   |                         |   |     |      |   |   |
| Last Minute Troubleshooting       |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
|                                   |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Research                          |   |     |   |   |     |    |     |      |                   |       | -    |     |     |      |       |      |     |      |   |                  |     |      |      |      | -    |   |     |     | -  |   |       |     |   |     |      | ▲   |     |    |   |                         |   |     |      |   |   |
| Compression                       |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Encoding / Comm Protocols         |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Noise Reduction                   |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Handling Bit Errors               |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
|                                   |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Document Cycle 1                  |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  | ◉   |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Camera, Memory, Controller        |   |     | - |   |     |    |     |      | _                 | _     |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Analog Data Channel               |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       | _    |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Whole System                      |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     | 1    |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Document Cycle 2                  |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      | -    |   | ÷.  |     | _  |   | ÷.    | ÷.  | - |     |      | - i |     | ,  |   | 0                       |   |     |      |   |   |
| Compression                       |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   | ļ                |     |      |      | -    |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Encoding                          |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Reliability / Noise Reduction     |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   | ļ                |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Compress + Encoding               |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |
| Whole System                      |   |     |   |   |     |    |     |      |                   |       |      |     |     |      |       |      |     |      |   |                  |     |      |      |      |      |   |     |     |    |   |       |     |   |     |      |     |     |    |   | $\overline{\mathbf{O}}$ |   |     |      |   |   |
|                                   |   |     |   |   |     | 4  | M   | inor | Mile              | estor | ne   | E   |     | Ord  | ler P | arts | 3   | (    |   | Ma               | jor | Targ | et I | Dead | line |   |     |     |    |   |       |     |   |     |      |     |     |    |   |                         |   |     |      |   |   |

# TABLE A5 (c)Planning Gantt Chart – Spring 2015



In the initial timeline planning, the first design-build-test cycle corresponds to implementing a basic version of the design on a breadboard. The second design-build-test cycle involves creating an improved version on perf-board. And the last cycle implements a final version of the design on a printed circuit board and with included packaging.

Tables A6 (a), A6 (b), and A6 (c) contain the timeline that the development actually followed.

# TABLE A6 (a)Actual Development Gantt Chart – Fall Quarter and Winter Break 2014 [21]

| Fall 2014                         |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
|-----------------------------------|---------|--------------|-------|-----|-------|------|----|-----|------|-------|---------|----------|------|---|-------|------|------|----|------------|----------|-------|--------------|-------|-------|------|------|------------|------|------|-------|----------------|-----|----|-----|------|-------|------|------|-----|----------|-----|------|
|                                   | I       | Veel         | :1    |     | We    | ek 2 |    | V   | Veek | 3     |         | We       | ek 4 |   | W     | /eek | 5    |    | We         | ek 6     |       | W            | eek 7 | r i   | 1    | Weel | k 8        |      | V    | Vee   | k 9            |     | We | eek | 10   | 1     | We   | ek 1 | 11  |          | Fii | nals |
|                                   | ΜT      | W            | R F   | M   | ΤW    | R    | F  |     |      |       | M       | ΤV       | V R  | F | ΜT    | W    | R F  | М  | ΤV         | V R      | F N   |              |       |       | M    | W    | R          | F I  | ΜТ   | W     | R              | F M | Т  | W   | R F  | M     | 1 T  | WI   | R F | М        | Т   | WR   |
|                                   | 22      |              |       | 29  |       |      |    | 6   |      |       | 13      |          |      |   | 20    |      |      | 27 |            |          |       | 3            |       |       | 10   |      |            |      | 17   | 1     |                | 24  | _  |     |      |       | 1    |      |     | 8        |     |      |
| Project Plan                      |         |              |       | -   |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      | -     |      |      |     |          |     |      |
| Abstract (Proposal) V1            |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          | _     |              | _     | _     | _    | _    | _          | _    | _    |       |                | _   |    | _   | _    |       |      |      |     |          |     |      |
| Requirements and Specifications   |         |              | -     | -   |       | -    |    | ∆ { |      |       |         | rie .    |      |   |       |      |      |    |            | ~        | тг    | <b>D</b>     |       | - 4 - |      |      | <u>، ،</u> |      | -    |       |                |     |    | -1  |      |       |      |      |     |          |     |      |
| Block Diagram                     |         |              |       |     |       |      |    |     | Í 📫  | -     |         | U        |      |   |       |      |      |    |            | NO       | IE    | Du           | e aa  | ate   | SA   | INL  | τε         | ee   | apa  | ICK   | re             | qui | re | a   |      |       |      |      |     |          |     |      |
| Literature search                 |         |              |       |     |       | -    |    |     |      |       | -       | <u> </u> |      |   | ∆ { ] |      |      |    | T-         |          | - 1   |              |       |       |      |      |            | 1    |      |       |                | 1   |    |     |      |       |      |      |     |          |     |      |
| Gantt Chart                       |         |              |       |     |       |      |    |     |      |       |         |          |      |   | Ŭ     |      |      |    | 0          |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| Cost Estimates                    |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       | -    | -    |    | $\bigcirc$ |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| ABET Sr. Project Analysis         |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       | $\mathbf{Q}$ |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| Requirements and Specifications V | 2 + Int | ro           |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              | -     |       | Δ {  | 2    |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| Report V1                         |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            | ⊿    |      |       |                | 3   |    |     |      |       |      |      |     |          |     |      |
| Advisor Feedback Due              |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       | 2    |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                | ΞA- |    |     | 2    | 6     |      |      |     |          |     |      |
| Report V2                         |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    | -   |      |       |      | -    |     | $\Delta$ |     |      |
| •                                 |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| Presentations                     |         |              |       |     |       |      |    |     |      |       | -       |          |      |   |       | -    |      | -  |            |          |       |              |       |       | -    |      |            | _    | -    |       |                | -   |    | -   |      | -     |      | -    | 1   |          |     |      |
| Requirements and Specifications   |         |              |       |     |       |      |    |     |      |       | $\odot$ |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| Report V1                         |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
|                                   |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| IW 1 Resume & Cover Lette         |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| Due                               |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| IW 2 Sensitivity Analysis         |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       |       |      |      |            |      |      | 1     |                |     |    |     |      |       |      |      |     |          |     |      |
| Due                               |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            | <u>\</u> |       |              |       |       |      |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| IW 3 Reverse Engineering          |         |              |       |     |       |      |    |     |      |       |         | _        |      |   | _     |      |      |    |            | _        |       |              |       |       | ÷    |      |            |      |      |       |                |     |    |     |      |       |      |      |     |          |     |      |
| Due                               |         |              |       |     |       |      |    |     |      |       |         |          |      |   |       |      |      |    |            |          |       |              |       | -     |      |      |            |      |      |       | $(\mathbf{Q})$ |     |    | -   |      |       |      |      | -   |          |     |      |
| Final Exam                        |         | <u> </u>     | _     | +   |       |      |    | -   |      | -     |         |          |      |   | _     | -    | _    |    |            |          |       | -            | _     | -     | -    | -    | -          |      |      | - Man | -              | +   |    | -   |      | +     | +++  | -    |     | $\odot$  |     |      |
|                                   |         |              | _     |     |       |      | -  | -   |      | -     |         |          |      |   |       | -    | _    |    | $\vdash$   |          |       | ++           |       | -     | -    |      |            |      | -    | -     |                |     | ++ | -   | -    |       |      | -    | -   |          | -   | _    |
|                                   |         | $\leftarrow$ | Tean  |     | igne  | ont  |    |     | andh | ack 1 | Requi   | rad      |      | • | Assig | nm   | nt D | 10 | 1          | 👌 V1.    | 5 Dua |              | dvic  | or 8. | Inct | . 👝  | In a       | lass | 000  | ian   | nent           | _   | -  | Adv | isor | Fac   | dbac | .k   | -   | —        | -   | _    |
| (                                 | 18 2    |              | reall | ASS | ignff | юш   | Ĭ, | ĵ Г | ceub | aun   | wqui    | ieu      | _    |   | nssig | inne | an D | ue | 15         | VI.      | 5 Due | 10 P         | uvis( | σια   | msti | . 🥑  | m-c        | ass  | assi | gш    | uent           | _   | Ø. | Auv | 1501 | 1.660 | uvac | л.,  | _   |          |     |      |

| Winter Break 2014         |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
|---------------------------|----|---|------|-----|---|----|---|------|-----|---|----|---|------|-----|---|
|                           |    | V | Veel | k 1 |   |    | V | Veel | k 2 |   |    | V | Veel | k 3 |   |
|                           | M  | Т | W    | R   | F | М  | Т | W    | R   | F | М  | Т | W    | R   | F |
|                           | 15 |   |      |     |   | 22 |   |      |     |   | 29 |   |      |     |   |
| Research                  |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Compression               |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Encoding / Comm Protocols |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Noise Reduction           |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Handling Bit Errors       |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| ADCs & DACs               |    |   | _    |     |   | _  |   |      | _   | _ |    |   |      | _   |   |
| Design                    |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Block Diagrams            |    |   |      |     |   |    | - |      |     |   | -  |   |      |     |   |
| Preliminary Parts Lists   |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |

# TABLE A6 (b)Actual Development Gantt Chart –Winter 2015

| Senior Project: Actual Timelin<br>Winter 2015 |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
|-----------------------------------------------|---|--------|---|-----|------|-----|------------|-----|-----|----|----|-------|---|---|------|----|---|-----|-----|-----------|-----|------|---|----|------|-----|-----|----|------|-----|---|-----|----|----|------|-----|
| winter 2013                                   | W | Veek 1 | 1 | , I | Neel | - 7 |            | Wee | 1-2 |    | We | olz A | - | v | Veek | 5  |   | Wee | k 6 | _         | Wee | 12 7 |   | v  | Veek | 6   |     | We | ek 9 | -   | w | eek | 10 |    | Fina | olc |
|                                               |   |        |   |     |      |     | EM         |     | RI  |    |    |       | Б |   |      |    |   |     |     | EM        |     |      | Б |    |      |     | 2 M |    |      | F N |   |     |    |    |      |     |
|                                               | 5 | VV K   | Г | 12  | vv   | ĸ   | F NI<br>19 |     | K I | 26 |    | K     | Г | 2 | w    | КГ | 9 | 1 1 | ĸ   | г M<br>16 |     | ĸ    |   | 23 | vv   | K F | 2   |    | N K  |     | 9 | w   | КГ | 16 | 1 W  | ĸ   |
| Requirements & Specifications                 |   |        |   |     |      |     | -          |     |     | 20 |    |       |   | 2 |      |    | Í |     |     | 10        |     |      |   | 23 |      |     | -   |    |      |     | , |     |    | 10 |      |     |
| Request Elaboration on Needs                  |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   | _   |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| and Requirments                               |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Modify Specifications                         |   |        |   |     | _    |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Further Research                              |   |        |   |     | _    |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Simulations                                   |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     | - 4  | Δ |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Conceptually Design                           |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Study & Simulate Encoding                     |   |        |   |     |      |     | _          |     |     | -  |    | -     |   | - |      | -  |   | -   |     |           |     |      |   | -  |      | -   |     |    |      |     |   |     |    |    |      |     |
| Block Diagram                                 |   |        | - |     | -    |     |            |     |     | -  |    | -     |   | - |      |    |   | -   |     |           |     |      |   |    |      | -   | _   |    |      |     |   |     |    |    |      |     |
| Select Parts                                  |   |        |   |     |      |     |            |     |     |    |    | -     |   | _ |      | _  | - | -   |     |           |     |      | F | 5  |      |     |     |    |      | E   |   |     |    |    |      |     |
| Tiva C Based System                           |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Get Dev Envir to Work                         |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Learn Basics of the MCU                       |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Develop Interfaces                            |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| FPGA Based System                             |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| Research Hobbyist Work                        |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   | -   |    |    | -    |     |
| Integrate Camera & FPGA                       |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   | -   |    | i  |      | 4   |
| Try to integrate DAC                          |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    | +    |     |
|                                               |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     | _  |    | _    |     |
| Research                                      |   |        | _ |     |      |     |            |     |     |    |    |       |   |   |      | _  |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     | _  |    | _    |     |
| Compression                                   |   |        | _ |     |      |     |            |     |     | _  |    | _     |   |   |      |    |   | _   |     |           |     | _    |   |    |      |     |     |    | _    |     |   |     |    |    | _    |     |
| Encoding / Comm Protocols                     | _ |        | _ |     |      |     |            |     |     | _  |    | _     |   |   |      |    |   | _   |     |           |     | _    |   | _  |      |     |     |    |      |     |   |     |    |    | _    |     |
| Noise Reduction                               |   |        | _ |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    | _    |     |
| Handling Bit Errors                           |   |        | _ |     |      |     |            |     |     |    |    |       | _ |   |      |    |   |     |     | _         |     |      |   | _  |      |     | _   |    |      |     | _ | _   | _  |    | _    |     |
| Document Cycle                                |   |        |   |     |      |     |            |     |     | +  |    |       |   |   |      |    |   | -   |     |           |     |      |   |    |      |     | +   |    |      |     |   |     |    |    |      |     |
| Update Req and Spec                           |   |        |   |     | -    |     | 1          |     |     | -  |    |       |   | - | 1    |    |   |     | 1 1 |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |
| opulate Req and Spee                          |   |        |   |     |      |     |            |     |     |    |    |       |   |   |      |    |   |     |     |           |     |      |   |    |      |     |     |    |      |     |   |     |    |    |      |     |

# TABLE A6 (c)Actual Development Gantt Chart – Spring 2015

| Senior Project: Actual Timeline  | - Gan | tt Char | t |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
|----------------------------------|-------|---------|---|------|-------|-------|-------|----------|-----|--------|------|-----|------|-----|--------|-------|----------|-------|-------|-------|-----|----|-----|------------|-----|----|----------|-----|-----|-------|-----|----------|----------|
| Spring 2015                      |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
|                                  | W     | eek 1   | 1 | Week | x 2   | W     | eek 3 | 3        | W   | Veek 4 | 4    | I   | Neek | 5   |        | Wee   | k 6      |       | W     | eek 7 | 7   |    | Wee | <u>s 8</u> |     | We |          |     | Wee | ek 10 |     | Fin      | als      |
|                                  | MT    | WRF     | M | ΤW   | R F   | M T   | WR    | F        | M T | WF     | R F  | МТ  | W    | R F | М      | T W   | R        | F M   | 1 T ' | WF    | R F | М  | TW  | R          | F M | ΤW | / R      | F 1 | ИTV | V R   | F M | T W      | R F      |
|                                  | 30    |         | 6 |      |       | 13    |       |          | 20  |        |      | 27  |      |     | 4      |       |          |       | 11    |       |     | 18 |     |            | 25  |    |          |     | 1   |       | 8   |          |          |
| FPGA Based System                |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Research Hobbyist Work           |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Try to integrate DAC             |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Try to integrate Ext. Memory     |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Raspberry Pi Based System        |       |         |   |      |       |       |       | ET.      |     |        |      |     |      |     |        |       |          |       | -     |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Intergrating Pi & Camera         |       |         |   |      |       |       |       | <b>—</b> |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Improving Capture & Compression  |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Try to Impliment DMA Timing      |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          | _     | -     |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Raspberry Pi + Tiva C System     |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     | E          |     |    |          |     |     |       |     | •        |          |
| Establish Commbetw RPi & Tiva    |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            | -   |    | <u>۱</u> |     |     |       |     |          |          |
| Impl Tiva Timers For Output Ctrl |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Integrate DAC (w/ Timed Output)  |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Fix Bug in Comm betw RPi & Tiva  |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Reduce Noise and Settling Error  |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     | <b></b>  |          |
| Estab Reciever for Testing       |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       | -     |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Create Code for Decod Analog Dat |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Improve Decode Accuracy          |       |         | + | +    | _     |       |       |          |     |        | -    | +   |      | _   |        | _     | $\vdash$ | _     | ++-   | +     | _   |    |     |            | _   |    |          | _   | ++- |       |     | <u>)</u> |          |
| Document Cycles                  |       |         |   | + +  |       |       |       |          |     |        | ÷    |     |      |     |        |       |          |       | + +   |       |     |    |     |            |     |    |          |     |     |       | -   |          |          |
| FPGA Doucumentation              |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Raspberry Pi Documentation       |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       | 1 1      |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| RPI + Tiva C Documentation       |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
| Final Documentation              |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       | _   |          |          |
| ABET Senior Project Anal (Final) |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       | —   |          | <u> </u> |
| Final Report                     |       |         |   |      |       |       |       |          |     |        |      |     |      |     |        |       |          |       |       |       |     |    |     |            |     |    |          |     |     |       |     |          |          |
|                                  |       |         |   |      | Minor | Miles | tone  |          | H   | Parts  | Arri | ive |      | ) M | ajor 🛛 | Farge | t Dea    | dline | e 🗌   |       |     |    |     |            |     |    |          |     |     |       |     |          |          |

#### 4. If manufactured on a commercial basis

The project has a small direct market, consisting of Orbital ATK itself. The market does have the possibility for expansion to any customers who need a camera module capable of recording and transmitting buffered video data over a low-bandwidth analog data channel. However, considering only Orbital ATK's business, we estimate the possibility of 10-20 rocket launches in the next 10 years, which utilize an average of 3-4 of the modules (corresponding to multiple stages and payload deployments). Assuming the purchase of a few spare units, this brings the total number of modules to the order of 60 units. This averages to 6 units per year. Estimating a manufacturing cost, for a finished unit, of \$130-170 (\$70-80 in components, \$15-30 for OSH Park PCB, and \$45-60 assembly). Setting a corresponding \$180-220 price point (a \$50 profit-margin per unit), this means an estimated \$300 dollars of profit per year.

The primary expected cost for the user, after purchase, comes from the installation of the module as well as any required modifications to their existing systems to incorporate the module. Since the module is specifically intended to take minimal effort to integrate into their existing systems, , we expect minimal modification costs. The module itself, however, may require application specific outer packaging (\$40-100). The other primary costs come from the labor to install the module, which we estimate as around \$60 (2 hours of work, mostly spent verifying and triple checking, at \$30 an hour). The module does also draw power, however, a commercial version's power requirement should be low compared to the existing systems on the rocket. In addition, costs associated with the fuel burned to lift the module's weight exist, but compared to the weight of the payload and the rocket itself, the impact is essentially negligible. Unfortunately, all of these costs accrue on a single launch, with little chance of reuse for the module, both because of the harsh operating environment it faces and because Orbital ATK does not directly reuse components after a mission, due to reliability and safety issues.

### 5. Environmental

Materials that come from limited natural resources compose the product. A few examples of materials used in some fashion include: laminates & resins (PCBs); copper (PCB & wires/cables); silicon (ICs); polymers (IC packages); ceramics (discrete capacitors and resistors); aluminum (metal layers in ICs); tin (solder); and miscellaneous trace heavy metals. The manufacturing processes, both of the module and of its components, also use energy, which may come from any of the typical sources, fossil fuels, nuclear, solar, wind, hydro-electric, etc. In addition, the component manufacture processes also inevitably produce wastes, which, if not properly disposed of or recycled, could potentially get released into the environment.

Unfortunately, if the customer does not take care to properly recycle or dispose of the product, at the end of its lifecycle it could end up as waste or litter. Coupled with its short life cycle (Orbital ATK does not directly reuse components after a mission, due to reliability and safety issues) and manufacturing wastes, this could have a negative impact on other species in the environment. Hopefully, however, the use of 100% ROHS compliant components, the limited quantity produced, and any steps that the customer may take towards properly disposing of the product, should help mitigate the short term and long term environmental impacts.

#### 6. Manufacturability

The design uses all readily available, "off-the-shelf" components. Thus the primary manufacturing challenges consist of the fabrication of the PCB board, and assembling of the components into the completed module (potentially very time consuming), and the programing of the control unit (also costs some time). But perhaps most significantly, the manufacture of the mechanical packaging of the module, and the assembly of the electrical components into the finished package, presents a major production challenge.

### 7. Sustainability

Unfortunately, the camera operates in a harsh, destructive environment, which makes maintaining the completed device exceedingly difficult. In addition, since reliability constitutes a critical safety issue, Orbital ATK does not directly reuse rocket systems. Thus sustainable use of project resources focuses on proper disposal and recycling of the design at the end of its mission. The limited production quantities help to also improve the sustainability of the overall product.

Improvements or upgrades could potentially include lower power consumption, reduced manufacture and component costs, improved reliability/survivability, additional features that could broaden the potential market (perhaps alternative data channels, and the ability to transmit in real time), and reduction in environmentally harmful components (increase in percentage of ROHS compliant components). The first major upgrade should be implementation on a single, custom PCB board. This will allow for improved reliability, smaller size / lower weight, lower power consumption, and reduced noise. Then improved decoding algorithms can be tuned to utilize the improved noise and delay characteristics of the single board. However, these upgrades involve a significant increase in design time and cost, as it necessitates a lower level focus on the requirements of the processors used, and it entails the higher cost of custom PCBs.

# 8. Ethical

Considering the project from the framework of utilitarianism, we arrive at the following conclusions. Though the manufacture of the project produces waste and the product itself (if not properly disposed of) may become waste, the target application provides data for modelling and troubleshooting dynamic events on large scale rocket systems. A failure during a dynamic event, could lead to severe repercussions for the rocket system, and if it causes an overall failure of the rocket, this could lead to significant littering and environmental harm, and possibly even risk to human life. Thus if improved models resulting from the use of this module help to prevent failures during dynamic events, then I would argue that the benefit in reducing the risk of large scale damage to the environment outweighs the relatively small harm the production wastes constitute. In addition, reducing the risk of a failure reduces the risk to both human health/safety, and the risk of financial harm, both to Orbital ATK and to their customers (who often pay Orbital ATK to deliver their products to space). From the framework of utilitarianism, creating this product performs greater good than not creating it.

From the framework of ethical egoism, the creation of this senior project helped the student (myself) to gain valuable experience and skills. Both technical skills and project management/develop experience, will help me to perform better engineering, by better meeting customer requirements, and by creating more reliable, sustainable, and beneficial designs in the future.

These arguments are also consistent with the IEEE Code of Ethics. The module provides data for improving the understanding of dynamic events and the technologies used in them, which directly ties into the 5<sup>th</sup> point of the code. Improvement of these models could help reduce the risk to public health, welfare, and property (points 1. and 8.). Lastly, it gave the designer the opportunity to develop and improve technical competence in several areas (point 6.)

Like any other technology, people could potentially misuse the product for unethical purposes. The module suffers from similar possible misuses to those other camera technologies face (such as "spying"), however, the product does not lend itself well to these misuses. The limited video duration and the narrow bandwidth data channel would hinder, or at least not provide advantage, for most unethical applications I can think of. There already exist a plentiful number of camera modules available that exhibit both lower cost and better suited features for illicit purposes. Thus the chance of unethical misuse of this project remains minimal.

#### 9. Health and Safety

There always exists health and safety concerns associated with any product. During the design and testing process, the designer had to take care to avoid contact with any potentially harmful substances, and ensure that no one else came into contact with them. In addition, the designer had to take care to avoid burns, cuts, and electrocution. Assembly of the completed project features the same safety concerns. The manufacture of the components incorporated also have their associated health concerns, however, the manufacturers from which we purchase the parts deal with these themselves, via established procedures. Use of the design involves the same risks from dealing with the power source connected to the design. The module itself draws low enough power and current so that it's not directly dangerous, however, damage or defect could cause an unintended short and dangerous amounts of current to flow. The design does use 100% ROHS compliant parts, which reduces the risk from toxicity. Installation into a larger system involves the same risks/concerns as any other work on the larger system, and as well as risks stemming directly from the act of installing (for instance, jabbing your hand with a screwdriver, getting your fingers pinched, or cutting your hand).

#### **10. Social and Political**

Various individuals have contributed to the project's success, including the project's advisor, Professor Wayne Pilkington, and the company liaison, Johnathan Chan. In addition, the project made use of third party services such as major components vendors, component manufacturers, delivery infrastructure, and caffeine providers. Inside of each of these organizations, a number of individuals worked to complete the contracted tasks. The organizations also inevitably made use of various other suppliers and subcontractors of their own. Lastly, numerous other persons provided advice on developmental challenges of the project, when consulted by the project designer. These persons range from engineering faculty and students, to friends and family of the lead designer, and a generous responder on a help forum. All of the individuals in the supplier, contractor, and subcontractor organizations benefit in a small way from business received from this project. Johnathan Chan and other Orbital ATK employees benefit from a module that they can potentially use or modify to use with their products.

A negative impacted on an indirect stakeholder could include if someone (or creature) is harmed by wastes due to manufacture or improper disposal of the product.

#### **11. Development**

During the course of the project, I learned about a number of fields in which I previously had little background. I studied lossy video compression schemes, analog data encoding schemes, and how to reduce noise & bit errors. I learned how to utilize Linux terminal commands and shell scripting, as well as how to write and implement C code in a Linux environment. I experienced using ARM based microcontrollers, making use of (and debugging) manufacturer provided driver libraries, and adjusting optimization and compiler (in particular, stack size) settings. And I gained practice using Matlab for large scale data manipulation, algorithm prototyping, and conceptual simulations.

Please see the Literature Search section for resources I used while developing this knowledge.

# **Literature Search**

[1] Orbital Sciences Corporation, "Rocket Camera Proposal," *Orbital Sciences Corporation*, Unknown Date. [Online]. Available: Cal Poly Polylearn: EE460. [Accessed: Aug. 27, 2014].

[2] Orbital Sciences Corporation, "Rocket Camera Proposal – Revised 10/21/14," *Orbital Sciences Corporation*, Oct. 2014. Unpublished.

[3] M. Noonen, K. Deierling, K. Barraclough, and B. Martin, "Video compression and decompression arrangement having reconfigurable camera and low-bandwidth transmission capability," U.S. Patent 5 926 208, July 20, 1999.

[4] G.J. Sullivan and T. Wiegand, "Video Compression - From Concepts to the H.264/AVC Standard," Proceedings of the IEEE, vol.93, no.1, pp.18,31, Jan. 2005. Available: IEEE Xplore, <u>http://www.ieee.org</u> [Accessed: 10/20/14]

[5] Kyusam Lim; Jeonghun Kim; Hwangyoung So; Sejin Kang; Suki Kim, "A Low Power QXGA Camera Signal Processor for Mobile Camera Applications," International Conference on Consumer Electronics, 2007. ICCE 2007. Digest of Technical Papers., vol., no., pp.1,2, 10-14 Jan. 2007. Available: IEEE Xplore, <u>http://www.ieee.org</u> [Accessed: 10/20/14]

[6] M.L. Kaddachi, L. Makkaoui, A. Soudani, V. Lecuire, and J. Moureaux, "FPGA-based image compression for low-power Wireless Camera Sensor Networks," 3rd International Conference on Next Generation Networks and Services (NGNS), 2011, vol., no., pp.68,71, 18-20 Dec. 2011. Available: IEEE Xplore, <u>http://www.ieee.org</u> [Accessed: 10/20/14]

[7] Elinux.org, "RPi Low-level peripherals - eLinux.org," 2015. [Online]. Available: <u>http://elinux.org/RPi\_Low-level\_peripherals#GPIO\_Code\_examples</u>. [Accessed: 6/12/15].

[8] Analog Devices, "Data Converter Fundamentals Training Module - Analog Devices | DigiKey," 2015. [Online]. Available: <u>http://www.digikey.com/en/ptm/a/analog-devices/data-converters-data-converter-fundamentals?WT.pn\_sku=AD5601BKSZ-REEL7TR-ND&WT.z\_part\_id=760552&WT.z\_video\_source=Part\_Detail. [Accessed: 6/12/15].</u>

[9] Texas Instruments, "Connected LaunchPad Kits," Texas Instruments, 2015. [Online]. Available: http://www.ti.com/ww/en/launchpad/launchpads-connected.html#tabs. [Accessed: 6/12/15].

[10] M. Field, "OV7670 camera - Hamsterworks Wiki!," Hamsterworks.co.nz, 2015. [Online]. Available: http://hamsterworks.co.nz/mediawiki/index.php/OV7670 camera#The camera.27s interface. [Accessed: 6/12/15].

[11] Raspberry-projects.com, 'BCM2835 SoC – Raspberry Pi Projects', 2015. [Online]. Available: <u>http://www.raspberry-projects.com/pi/pi-hardware/bcm2835</u>. [Accessed: 6/12/15].

[12] Texas Instruments, "Tiva TM4C123GH6PM Microcontroller," TM4C123GH6PM datasheet, [Online] Available, www.ti.com. [Accessed: 2/27/15]

[13] Analog Devices, "LC2MOS 12-Bit DACPORTs," AD7245A/AD7248A datasheet [Online] Available: Analog, www.analog.com. [Accessed: 6/12/15]

[14] Raspberrypi-spy.co.uk, 'Raspberry Pi B+ GPIO Header Details And Pinout', 2014. [Online]. Available: http://www.raspberrypi-spy.co.uk/2014/07/raspberry-pi-b-gpio-header-details-and-pinout/. [Accessed: 6/12/15].

[15] Wiringpi.com, 'WiringPi', 2015. [Online]. Available: http://wiringpi.com/. [Accessed: 6/12/15].

[16] A. Eames, 'Another way to convert Raspberry Pi Camera .h264 output to .mp4', RasPi.TV, 2013. [Online]. Available: http://raspi.tv/2013/another-way-to-convert-raspberry-pi-camera-h264-output-to-mp4. [Accessed: 6/12/15].

[17] Digilent, "WaveForms SDK Reference Manual," Jan 26, 2015 [Online] Available <u>http://www.digilentinc.com</u>. [Accessed: 5/16/15]

[18] Digilent Forum, "Using ScanShift Acquisition Mode in WaveForms SDK," 2015. [Online]. Available: https://forum.digilentinc.com/topic/613-using-scanshift-acquisition-mode-in-waveforms-sdk/. [Accessed: 6/12/15].

[19] R. Gonzalez, and R Woods, *Digital Image Processing*, 3rd ed. Upper Saddle River: Prentice Hall, 2007.

[20] Raspberrypi.org, "Raspberry Pi Camera Module -Applications," Raspberry Pi Documentation 2015. [Online]. Available: https://www.raspberrypi.org/documentation/raspbian/applications/camera.md. [Accessed: 6/12/15].

[21] D. Braun, "EE 460 Gantt Chart – Fall 2014," Cal Poly Courseware – EE. [Online]. Available: https://courseware.ee.calpoly.edu/~dbraun/courses/ee460/EE460Gantt.html. [Acessed: 10/27/14]

[22] I. Wahidah, A.B. Suksmono, Hendrawan, and T.L.R. Mengko, "Compressive sampling for digital video signal compression involving dynamic sparsity," 7th International Conference on Telecommunication Systems, Services, and Applications (TSSA), 2012, vol., no., pp.46,50, 30-31 Oct. 2012. Available: IEEE Xplore, <a href="http://www.ieee.org">http://www.ieee.org</a> [Accessed: 10/20/14]

[23] Analog Devices, "LC2MOS 12-Bit Serial DACPORTs," AD7243 datasheet [Online] Available: Analog, <u>www.analog.com</u>. [Accessed: 6/12/15]

[24] Analog Devices, "12-Bit 100 kSPS A/D Converter," AD7243 datasheet [Online] Available: Analog, <u>www.analog.com</u>. [Accessed: 6/12/15]

[25] Linear Technology, "10kHz to 150kHz Digitally Controlled Antialiasing Filter and 4-Bit P.G.A," LTC1564 datasheet [Online] Available: Linear, <u>www.linear.com</u>. [Accessed: 6/12/15]

[26] Digilent, "PmodSF2 Reference Manual," [Online] Available http://www.digilentinc.com. [Accessed: 6/12/15]

[27] Numonyx, "Numonyx® OmneoTM P5Q PCM," P5Q PCM datasheet, [Online] Available, Digilent Inc, <u>http://www.digilentinc.com</u>. [Accessed: 6/12/15]

[28] E2e.ti.com, "SPI Speed on ARM microprocessors (Tiva for example) - TM4C Microcontrollers Forum - TM4C Microcontrollers - TI E2E Community," 2015. [Online]. Available: http://e2e.ti.com/support/microcontrollers/tiva\_arm/f/908/p/274452/958695. [Accessed: 6/12/15].

[29] Wiringpi.com, 'WiringPi', 2015. [Online]. Available: http://wiringpi.com/. [Accessed: 6/12/15].

[30] Raspberrypi.org, "Raspberry Pi Forums - DMA and SPI and Interrupts - cant get it to work," 2015. [Online]. Available: https://www.raspberrypi.org/forums/viewtopic.php?f=71&t=19797. [Accessed: 6/12/15].

[31] Raspberrypi.org, "Raspberry Pi Forums - DMA on GPIO," 2015. [Online]. Available: https://www.raspberrypi.org/forums/viewtopic.php?f=44&t=8376. [Accessed: 6/12/15].

[32] Wallacoloo, "Wallacoloo/Raspberry-Pi-DMA-Example," GitHub, 2014. [Online]. Available: <u>https://github.com/Wallacoloo/Raspberry-Pi-DMA-Example/blob/master/dma-gpio.c</u>. [Accessed: 6/12/15].

[33] J. Pihlajamaa, 'Benchmarking Raspberry Pi GPIO Speed | Code and Life', Codeandlife.com, 2012. [Online]. Available: http://codeandlife.com/2012/07/03/benchmarking-raspberry-pi-gpio-speed/. [Accessed: 6/12/15].

[34] Raspberrypi.stackexchange.com, 'How to compile C files in terminal', 2015. [Online]. Available: <u>http://raspberrypi.stackexchange.com/questions/5599/how-to-compile-c-files-in-terminal</u>. [Accessed: 6/12/15].

[35] Raspberrypi.org, "Camera - Hardware," Raspberry Pi Documentation 2015. [Online]. Available: https://www.raspberrypi.org/documentation/hardware/camera.md. [Accessed: 6/12/15].

[36] A. Allain, "C File I/O Tutorial - Cprogramming.com." Cprogramming.com, 2015. [Online]. Available: <u>http://www.cprogramming.com/</u>. [Accessed: 6/12/15].

[37] Codingunit.com, "C Tutorial – Binary File I/O | CodingUnit Programming Tutorials," 2015. [Online]. Available: <u>http://www.codingunit.com/c-tutorial-binary-file-io</u>. [Accessed: 6/12/15].

[38] M. Samek, "Are We Shooting Ourselves in the Foot with Stack Overflow?", Embeddedgurus.com, 2015. [Online]. Available: <u>http://embeddedgurus.com/state-space/2014/02/are-we-shooting-ourselves-in-the-foot-with-stack-overflow</u>. [Accessed: 6/12/15].

[39] N. Jones, "Efficient C Tip #13 – use the modulus (%) operator with caution," Embeddedgurus.com, 2015. [Online]. Available: <u>http://embeddedgurus.com/stack-overflow/2011/02/efficient-c-tip-13-use-the-modulus-operator-with-caution/</u>. [Accessed: 6/12/15].

[40] Oshpark, "OSH Park ~ Pricing and Specifications," 2015. [Online]. Available: <u>https://oshpark.com/pricing</u>. [Accessed: 6/12/15].

# Appendix B – Parts List and Costs

# **Actual Prototyping Parts Costs:**

Table B1 shows the actual cost of prototyping materials from the project.

#### TABLE B1

# ACTUAL PARTS AND EQUIPMENT COSTS

| Actual Developme     | nt Costs (Equipment)     |           |                     |      |        |      |          |
|----------------------|--------------------------|-----------|---------------------|------|--------|------|----------|
| Final Prototype      |                          |           |                     |      |        |      |          |
| System               | Part Name/Number         | Vender    | Manufacturer        | Base | Price  | Cost | (w/ Tax) |
| Camera               | Raspeberry Pi 5MP Camera | Amazon    | Raspberry Pi Foun.  | \$   | 26.95  | \$   | 29.38    |
| Video Data Processor | Raspberry Pi - Model B+  | MCM Elec. | Raspberry Pi Foun.  | \$   | 25.00  | N/A  |          |
| Memory               | 16 GB Micro SD Card      | Amazon    | Kingston Digital    | \$   | 6.95   | N/A  |          |
| DAC                  | AD7245AANZ               | DigiKey   | Analog Devices      | \$   | 19.37  | \$   | 20.92    |
| D/A Control Unit     | Tiva C TM4C123GXL Eval   | DigiKey   | Texas Instruments   | \$   | 16.68  | \$   | 18.01    |
| Misc. Passive        | Caps/Resistors/Leads     | N/A       | N/A                 | \$   | 2.00   | N/A  |          |
|                      |                          |           | Total -             | \$   | 96.95  |      | \$68     |
| Early Prototype      |                          |           |                     |      |        |      |          |
| System               | Part Name                | Vender    | Manufacturer        | Base | Price  | Cost | (w/ Tax) |
| Camera               | OV7670 300KP VGA Module  | Amazon    | Atomic Market       | \$   | 10.99  | \$   | 10.99    |
| Memory               | PmodSF2 - Serial PCM     | Amazon    | Digilent            | \$   | 14.95  | \$   | 14.95    |
| DAC                  | AD7243ANZ                | DigiKey   | Analog Devices      | \$   | 16.68  | \$   | 16.68    |
|                      |                          |           | Total:              | \$   | 42.62  | \$   | 42.62    |
| Development and Te   | st Equipment             |           |                     |      |        |      |          |
| Function             | Part Name                | Vender    | Manufacturer        | Base | Price  | Cost | (w/ Tax) |
| ADC                  | AD1674JNZ                | DigiKey   | Analog Devices      | \$   | 29.17  | \$   | 31.50    |
| USB-UART Cable       | 768-1204                 | DigiKey   | FTDI                | \$   | 15.00  | \$   | 16.20    |
| Antialiasing Filter  | LTC1564IG#PBF            | DigiKey   | Linear Technologies | \$   | 17.59  | \$   | 19.00    |
| Breakout BNC         | FEMALE-20AWG LEADS       | DigiKey   | Pomona Electronics  | \$   | 17.10  | \$   | 18.47    |
|                      |                          |           | Total:              | \$   | 78.86  | \$   | 85.17    |
|                      | Shipping and Handing:    |           |                     |      |        |      |          |
| Total                | \$16.50                  |           | Equip. Total        | Base | Price  | Actu | al Cost  |
|                      |                          |           | S&H: \$16.50        | \$   | 218.43 | \$   | 196.10   |

### **Estimates of Production Model Parts Costs:**

Table B2 shows an estimate of how much a production model of the design would cost, assuming a production quantity of 1000 per year. It shows both per unit and grand total costs.

#### TABLE B2

### ESTIMATED PRODUCTION MODEL PARTS AND EQUIPMENT COSTS

| Parts Costs - Comr    | nercial Basis             |          |                    |      |       |    |           |
|-----------------------|---------------------------|----------|--------------------|------|-------|----|-----------|
| Production Model      |                           |          |                    |      |       |    |           |
| System                | Part Name/Number          | Vender   | Manufacturer       | Unit | Price | 10 | 00 Units  |
| Camera                | Raspeberry Pi 5MP Camera  | Amazon   | Raspberry Pi Foun. | \$   | 26.95 | \$ | 26,950.00 |
| Video Data Processor  | Raspeberry Compute Module | Newark   | Raspberry Pi Foun. | \$   | 30.00 | \$ | 30,000.00 |
| Memory                | 16 GB Micro SD Card       |          | Kingston Digital   | \$   | 4.00  | \$ | 4,000.00  |
| DAC                   | AD7245AARZ                | DigiKey  | Analog Devices     | \$   | 11.37 | \$ | 11,371.50 |
| D/A Control Unit      | TM4C123GXL                | DigiKey  | Texas Instruments  | \$   | 3.57  | \$ | 3,570.00  |
| Misc. Passive         | Caps/Resistors/Leads      | N/A      | N/A                | \$   | 0.10  | \$ | 100.00    |
| РСВ                   | N/A                       | OSH Park | OSH Park           | \$   | 12.00 | \$ | 12,000.00 |
| Shipping and Handing: | N/A                       | USPS     | N/A                | \$   | 0.50  | \$ | 500.00    |
|                       |                           |          | Equip. Total       | Unit | Price | 10 | 00 Units  |
|                       |                           |          |                    | \$   | 88.49 | \$ | 88,491.50 |

# Appendix C – Project Schedule

TABLE C1

#### **Planning and Actual Time Estimates:**

Table C1 shows the initially planned estimate of hours to work on the project.

| ESTIM         | ATED I | PLAN | NED D | EVE | LOPMI  | ент Т | IME  |       |
|---------------|--------|------|-------|-----|--------|-------|------|-------|
| Estimated P   | lanne  | ed D | evelo | pme | ent Ti | ime   |      |       |
| Labor (Weekl  | y)     |      |       |     |        |       |      |       |
| Person        | Min    |      | Тур   |     | Max    |       | PERT |       |
| Myself (hrs)  |        | 8    |       | 18  |        | 30    |      | 18.3  |
|               |        |      |       |     |        |       |      |       |
| Labor (Total) |        |      |       |     |        |       |      |       |
| Person        | Min    |      | Тур   |     | Max    |       | PERT |       |
| Myself (hrs)  |        | 160  |       | 360 |        | 600   |      | 366.7 |
| Others (hrs)  |        | 10   |       | 15  |        | 40    |      | 18.3  |
|               |        |      |       |     |        |       |      |       |
| Total         | Min    |      | Тур   |     | Max    |       | PERT |       |
|               |        | 170  |       | 375 |        | 640   |      | 385   |

Table C2 shows the actual estimated of hours of work on the project.

| APPROX        | KIMAN  | T AC  | TUAL | DEVI | ELOPN | 1ENT | TIME |       |
|---------------|--------|-------|------|------|-------|------|------|-------|
| Approx. Actu  | ual De | evelo | opme | nt T | ime   |      |      |       |
| Labor (Weekl  | y Ave  | rage  | d)   |      |       |      |      |       |
| Person        | Min    |       | Тур  |      | Max   |      | PERT |       |
| Myself (hrs)  |        | 8     |      | 10   |       | 15   |      | 10.5  |
| Labor (Total) |        |       |      |      |       |      |      |       |
| Person        | Min    |       | Тур  |      | Max   |      | PERT |       |
| Myself (hrs)  |        | 160   |      | 200  |       | 300  |      | 210.0 |
| Others (hrs)  |        | 12    |      | 18   |       | 25   |      | 18.2  |
| Total         | Min    |       | Тур  |      | Max   |      | PERT |       |
|               |        | 172   |      | 218  |       | 325  |      | 228   |

TABLE C2Approximant Actual Development Time

# **Planning and Actual Timelines:**

The initial planning timeline for project development is shown in Tables C3 (a), C3 (b), & C3 (c) below

# TABLE C3 (a)

# PLANNING GANTT CHART – FALL QUARTER AND WINTER BREAK 2014 [21]

| EE 460 Gantt Chart                |          |          |       |          |     |                    |         |        |       |    |       |       |        |    |          |        |       |          |       |             |        |        |         |       |     |      |           |         |          |      |          |          |      |   |
|-----------------------------------|----------|----------|-------|----------|-----|--------------------|---------|--------|-------|----|-------|-------|--------|----|----------|--------|-------|----------|-------|-------------|--------|--------|---------|-------|-----|------|-----------|---------|----------|------|----------|----------|------|---|
| Fall 2014                         |          |          |       |          |     |                    |         |        |       |    |       |       |        |    |          |        |       |          |       |             |        |        |         |       |     |      |           |         |          |      |          |          |      |   |
|                                   |          | Veek 1   |       | Week     |     |                    | eek 3   |        | Wee   |    |       | Weel  |        |    | Week     |        |       | Veek 1   |       |             | eek 8/ |        |         | Veek  |     |      | Veek      |         |          | Neek |          |          | Fina |   |
|                                   |          | WR       | _     | M T W    | R F |                    | WR      |        |       | RF | _     | _     | R F    | _  | W        | R F    |       | WF       | R F   |             | WR     | F      | _       | WI    | R F | _    | W         | R F     | M T      | W    | R F      | M        | ΓW   | R |
| Project Plan                      | 22       |          |       | 29       |     | 6                  | _       |        | 13    |    | 20    | _     | _      | 27 |          | _      | 3     |          | _     | 10          |        |        | 17      |       |     | 24   | ╘         |         | 1        | ╧╧╧  | <u> </u> | 8        | _    |   |
| Abstract (Proposal) V1            |          |          |       |          |     |                    |         |        |       |    |       | _     |        |    |          |        |       |          |       |             |        |        | _       |       | _   |      |           |         |          |      |          | <b>T</b> |      |   |
| Requirements and Specifications   |          |          |       |          |     |                    |         |        |       |    | -     | _     |        |    |          | _      | _     |          | _     |             | _      | -      | _       |       | _   | _    | i di la   | _       |          |      |          |          | _    |   |
|                                   | -        |          |       |          |     | <mark>⊅</mark> ⊿ € | 1       |        |       |    | -     | _     |        |    | N        | OTE    | ΕDι   | le d     | ate   | s Al        | ND f   | fee    | dba     | ack   | rea | uire | be        |         |          |      |          |          | _    | _ |
| Block Diagram                     | _        | _        |       |          |     |                    |         |        |       |    |       |       |        |    |          | • • •  |       |          |       |             |        |        |         |       |     |      |           |         | $\vdash$ |      |          |          | _    | _ |
| Literature search                 | _        |          |       |          | _   |                    |         |        |       |    | J ∧ T | 0_    |        | 1. |          |        |       |          | _     |             |        |        |         |       |     |      | —         |         | -        |      |          |          | _    | _ |
| Gantt Chart                       | _        |          |       |          |     |                    |         |        |       |    | _     |       |        |    |          |        |       |          | _     |             |        |        |         |       | _   |      |           |         |          |      |          |          | _    |   |
| Cost Estimates                    | _        |          |       |          |     |                    |         |        |       |    | _     |       |        |    | <b>)</b> |        |       |          | _     |             |        |        |         |       | _   |      |           |         |          |      |          |          |      |   |
| ABET Sr. Project Analysis         |          |          |       |          |     |                    |         |        |       |    |       |       |        |    |          |        | ∖∆₹   | <u>}</u> |       |             |        |        |         |       |     |      |           |         |          |      |          |          |      |   |
| Requirements and Specifications V | 2 + Intr | 0        |       |          |     |                    |         |        |       |    |       |       |        |    |          |        |       |          |       | A<br>\<br>\ | ĵ      |        |         |       |     |      |           |         |          |      |          |          |      |   |
| Report V1                         |          |          |       |          |     |                    |         |        |       |    |       |       |        |    |          |        |       |          |       |             |        |        |         |       | -   |      |           | _       |          |      |          |          |      |   |
| Advisor Feedback Due              |          |          |       |          |     |                    |         |        |       |    |       | - 🗸   |        |    |          |        |       |          |       |             |        |        |         |       |     |      |           | 2       |          |      |          |          |      |   |
| Report V2                         |          |          |       |          |     |                    |         |        |       |    |       |       |        |    |          |        |       |          |       |             |        |        |         |       |     |      |           |         |          |      | -        |          |      |   |
| Presentations                     |          |          |       | _        | _   |                    | _       |        |       |    |       |       |        |    |          |        |       |          |       |             |        |        |         |       |     |      |           |         |          |      | -        |          | _    |   |
| Requirements and Specifications   |          |          |       |          | _   |                    |         | 6      | )     |    |       | _     |        |    |          |        |       |          |       |             |        |        |         |       | _   |      |           |         |          |      |          |          |      |   |
|                                   |          |          | -     |          | _   |                    |         | 6      | /     |    | -     | _     | _      |    |          | _      |       |          |       |             |        |        |         |       | _   |      |           | _       | <u></u>  |      |          |          |      |   |
| Report V1                         |          |          |       |          | _   |                    |         |        |       |    |       |       | _      |    |          | _      |       |          | -     |             |        | -      | -       |       | -   |      |           | -       |          |      |          |          |      |   |
| HW 1 Resume & Cover Lette         |          |          |       |          |     |                    |         |        |       |    |       |       |        |    |          |        |       |          |       |             |        |        |         |       |     |      | -         |         |          | -    |          |          |      |   |
| Due                               |          |          |       | Δ        |     |                    |         |        |       |    |       |       |        |    |          |        |       |          |       |             |        |        |         |       |     |      |           |         |          |      |          |          |      |   |
| HW 2 Sensitivity Analysis         |          |          |       |          |     |                    |         |        |       |    | 1 1   |       |        |    |          |        |       |          |       |             |        |        |         |       |     |      | _         |         |          |      |          |          |      |   |
| Due                               |          |          |       |          |     |                    |         |        |       |    |       |       |        |    | Δ        |        |       |          |       |             |        |        |         | _     |     |      |           |         |          |      |          |          |      |   |
| HW 3 Reverse Engineering          |          |          |       |          |     |                    |         |        |       |    |       | _     |        |    |          | _      |       |          | -     |             | _      |        |         |       | 7   |      |           |         |          |      | _        |          | _    |   |
| Due                               | -        |          | -     |          | -   |                    |         |        |       |    | -     |       | _      |    |          | _      |       |          |       |             |        |        | (6      |       |     |      |           |         |          |      |          |          |      |   |
| Final Exam                        |          |          | -     |          | _   |                    |         |        |       |    | -     | +     | _      |    |          | -      |       |          |       |             |        | -      | <u></u> |       | 2   |      |           |         | +        | ++   |          | <u>.</u> | _    |   |
| Finai Exam                        |          |          |       |          | _   |                    |         |        |       |    | -     | _     | _      |    |          | _      |       |          | -     |             |        |        | _       |       | _   |      | $\vdash$  |         |          | +-+  |          |          | _    |   |
| /                                 |          | Те       | eam A | ssignmer | nt  | Fe                 | edback  | c Req  | uired | 4  | Ass   | signm | ent Du | e  | ۱ 😂      | /1.5 D | ue to | Advis    | sor & | Instr.      | 🙂 In   | -class | s as s  | ignme | nt  | 2    | Adv       | visor I | Reedb    | ack  |          |          |      |   |
| (                                 |          | <b>V</b> |       |          |     | <b>*</b>           |         |        |       |    |       |       | _      |    |          | _      |       |          | _     |             |        |        |         |       | _   |      | $\square$ | _       | $\vdash$ | +    |          | +        | _    | _ |
|                                   |          | r        |       |          |     | EE 40              | 60 Gan  | ntt Cl | nart  |    | +     |       | _      |    |          | _      |       |          | -     |             |        |        |         |       |     |      | <u> </u>  |         |          |      |          |          |      |   |
|                                   |          |          |       |          |     | Winte              | er Brea | ak 20  | 14    |    |       |       |        |    |          |        |       |          |       | 1           |        |        |         |       |     |      |           |         |          |      |          |          |      |   |
|                                   |          |          |       |          |     |                    |         |        |       |    |       | W     | eek 1  | 1  | Week     | 2      | W     | Veek 3   |       | -1          |        |        |         |       |     |      |           |         |          |      |          |          |      |   |

| Winter Break 2014         |    |   |      |     |   |    |   |      |     |      |    |   |      |     |    |
|---------------------------|----|---|------|-----|---|----|---|------|-----|------|----|---|------|-----|----|
|                           |    | V | Veel | k 1 |   |    | V | Veel | k 2 |      |    | W | Veel | k 3 |    |
|                           | M  | Т | W    | R   | F | М  | Т | W    | R   | F    | М  | Т | W    | R   | F  |
|                           | 15 |   |      |     |   | 22 |   |      |     |      | 29 |   |      |     |    |
| Research                  |    |   |      |     |   |    |   |      |     |      |    |   |      |     |    |
| Compression               |    |   |      |     |   |    |   |      |     |      |    |   |      |     |    |
| Encoding / Comm Protocols |    |   |      |     |   |    |   |      |     |      |    |   |      |     |    |
| Noise Reduction           |    |   |      |     |   |    |   |      |     |      |    |   |      |     |    |
| Handling Bit Errors       |    |   |      |     |   |    |   |      |     |      |    |   |      |     |    |
| ADCs & DACs               |    |   |      | _   | _ |    |   |      |     |      |    |   | _    |     |    |
| Design                    |    | - | -    | -   | - |    |   |      |     |      |    |   | _    | _   |    |
| Block Diagrams            |    |   |      |     |   |    |   |      |     |      |    |   |      |     |    |
| Preliminary Parts Lists   |    | Γ |      |     |   |    |   |      |     |      |    |   |      |     | É. |
|                           |    | Γ |      |     |   | Ē  |   | Ore  | der | Part | S  |   |      |     |    |

# TABLE C3 (b)

## PLANNING GANTT CHART – WINTER 2015

| EE 460 Gantt Chart                |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     | ] |
|-----------------------------------|---|---|-----|----|----|----|-----|---|-----|--------------|-------|------|-----|----|----|------|------|-----|-----|------|---|------------------|-----|-----|-----|-----|------|-----|-----|---|---|----|-----|-------|-----|---|---|------|---|----|----|---|------|---|----|----|------|-----|---|
| Winter 2015                       |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    | П   |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
|                                   |   |   | eek |    |    |    | Vee |   |     |              |       | ek 3 |     |    |    | eek  |      |     |     | Veel |   |                  |     |     | eek |     |      |     | Vee |   |   |    |     | eek 8 |     |   |   | /eek |   |    |    |   | k 10 |   |    |    | nals |     |   |
|                                   | М | Т | W I | RF | FN | ΜT | W   | R | F   | М            | ΤV    | N R  | R F | М  | ΤV | W    | R F  | M   | 1 T | W    | R | F                | М   | T   | W   | R I | F I  | M T | W   | R | F | М  | Т   | WF    | t F | M | Т | W    | R | FN | ΛT | W | R    | F | М  | ΤW | V R  | R F |   |
|                                   | 5 |   |     |    |    | 12 |     |   |     | 19           |       |      |     | 26 |    |      |      |     | 2   |      |   |                  | 9   |     |     |     |      | 16  |     |   |   | 23 |     |       |     | 2 | 2 |      |   |    | 9  |   |      |   | 16 |    |      |     |   |
| Cycle 1 (Prelim)                  |   |   |     |    |    |    |     |   |     | -            |       |      |     | -  |    |      |      |     |     |      | - | $oldsymbol{eta}$ |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Design Functioning Camera         |   |   |     |    | F  | 7- |     |   |     | $\mathbf{A}$ |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Assemble Camera                   |   |   |     |    |    | -  |     | - | -   |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Design Prelim Analog Channel      |   |   | -   | -  |    | -  |     | - | -   | E.           | -     |      |     | -  |    | -    | -    |     | ۱ I |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Assemble Prelim Analog Channel    |   |   |     |    |    |    |     |   |     |              |       |      |     |    | -  | -    | +    |     | -   |      |   | $oldsymbol{eta}$ |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Cycle 2                           |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   | 0    |   |    |    |      |     |   |
| Implement Compression             |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   | t                |     |     |     |     |      |     |     |   |   | Δ  |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Improve Encoding Scheme           |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      | -   |     |   |   | -  |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Optimize Compres/Encod Together   |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    | -   | -     | -   | - | - | _    | 4 |    |    |   |      |   |    |    |      |     |   |
| Improve Reliability               |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   | ļ                |     | -   | -   | -   |      | -   | -   | - | - | -  | -   |       | -   |   | - |      | ▲ |    |    |   |      |   |    |    |      |     |   |
| Handle Errors / Reduce Corruption |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    | -   |       | -   |   | - |      | - |    | 7  |   |      |   |    |    |      |     |   |
| Last Minute Troubleshooting       |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   | •    |   |    |    |      |     |   |
|                                   |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    | П   |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Research                          |   |   |     |    |    |    |     |   |     |              |       |      |     | -  |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   | - 4  | ▲ |    |    |   |      |   |    |    |      |     |   |
| Compression                       |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Encoding / Comm Protocols         |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Noise Reduction                   |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Handling Bit Errors               |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
|                                   |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Document Cycle 1                  |   |   | į.  |    |    | ÷. | ,   |   | į.  |              |       |      |     |    |    | ÷.   | ĺ.   |     |     |      |   |                  | •   |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Camera, Memory, Controller        |   |   |     |    | -  |    | -   |   | -   |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Analog Data Channel               |   |   |     |    |    |    |     | Γ |     |              |       |      |     |    |    |      |      | _   |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Whole System                      |   |   |     |    |    |    |     |   |     |              |       |      |     | _  |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Document Cycle 2                  |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   | -  |     |       |     | - |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Compression                       |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     | -   |     |      |     |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Encoding                          |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      | -   | 1   |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Reliability / Noise Reduction     |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   | ļ                |     |     |     |     | _    |     | -   | - | 1 | 1  |     |       |     | - |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Compress + Encoding               |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    | 1 1 |       |     | - |   |      |   |    |    |   |      |   |    |    |      |     |   |
| Whole System                      |   |   |     |    |    |    |     |   |     |              |       |      |     |    |    |      |      |     |     |      |   |                  |     |     |     |     |      |     |     |   |   |    |     |       |     |   |   | -    | - | _  | -  |   | 10   |   |    |    |      |     |   |
|                                   |   |   |     |    |    |    | Δ   | M | ino | r Mi         | lesto | one  |     | E  | (  | Drde | r Pa | rts |     | (    |   | Ma               | jor | Tar | get | Dea | dlin | ne  |     |   |   |    |     |       |     |   |   |      |   |    |    |   |      |   |    |    |      |     |   |

# TABLE C3 (c)Planning Gantt Chart – Spring 2015



In the initial timeline planning, the first design-build-test cycle corresponds to implementing a basic version of the design on a breadboard. The second design-build-test cycle involves creating an improved version on perf-board. And the last cycle implements a final version of the design on a printed circuit board and with included packaging.

Tables C4 (a), C4 (b), and C4 (c) contain the timeline that the development actually followed.

# TABLE C4 (a)Actual Development Gantt Chart – Fall Quarter and Winter Break 2014 [21]

| Fall 2014                         |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
|-----------------------------------|--------|------|------|-----|----------|-----|----------|-----|------|-------|---------|-----|------|---|-----|------|------|-----|-----|------|------|-------|----------|------|------|------|------|-------|----------|-------|---------|------|-----|-----|-----|-------|-----|------|------|-----|---------|---|------|---|
|                                   |        | Weel |      |     | We       |     |          |     | eek  |       |         |     | ek 4 |   |     | Wee  |      |     |     | Neel |      |       |          | Veek |      |      |      | eek 8 |          |       | Wee     |      |     |     | eek |       |     |      | ek 1 |     |         |   | nals |   |
|                                   | Μ      | ΓW   | R F  | Μ   | ΤW       | R   | F 1      | ΜT  | W    | R F   | Μ       | ΤV  | V R  | F | Μ   | ΓW   | R    | F   | ΜT  | W    | R    | F N   | ΤN       | W    | R F  | F    | 1 T  | WF    | R F      | Μ     | TW      | R    | F N | ΛT  | W   | R F   | FM  | T    | WR   | R F | Μ       | Т | WF   | R |
|                                   | 22     |      |      | 29  |          |     |          | 6   |      |       | 13      |     |      |   | 20  |      |      |     | 27  |      |      |       | 3        |      |      | 1    | 0    |       |          | 17    |         |      | 1   | 24  |     |       |     | 1    |      |     | 8       |   |      |   |
| Project Plan                      |        |      |      | +   |          | -   | -        |     |      |       | -       |     |      | - |     | -    |      |     | -   |      |      |       |          |      |      | -    | -    | -     | -        |       |         | -    | _   |     |     |       |     | -    | -    | -   | •       |   |      |   |
| Abstract (Proposal) V1            |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     | -    | _    | _     | _        |      | _    |      |      |       | _        |       | _       |      | _   |     |     | _     | _   |      |      |     |         |   |      |   |
| Requirements and Specifications   |        |      | -    |     |          | -   | <b>_</b> | ∆ ( |      |       |         | ÷.  |      |   |     |      |      |     |     |      | 107  | TC    | <b>D</b> |      |      |      |      |       | <b>.</b> | ما ام |         |      |     | •   |     |       |     |      |      |     |         |   |      |   |
| Block Diagram                     |        |      |      |     |          |     |          |     |      | -     |         | O   |      |   |     |      |      |     |     |      | UV   | IE    | DU       | ie d | at   | es   | Ar   | ND    | Tee      | ap    | aci     | c re | equ | ire | a   |       |     |      |      |     |         |   |      |   |
| Literature search                 |        |      |      |     |          | -   |          |     |      | -     |         | Ĭ   |      | - | ¢∆{ |      |      |     |     |      |      |       |          |      |      | Т    |      |       |          |       |         | I I  | - 1 |     |     |       |     |      |      |     |         |   |      |   |
| Gantt Chart                       |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     | Ĩ 🗖  |      | _   | Δ 🌈 |      |      |       |          |      |      |      |      |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| Cost Estimates                    |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      | -   | Δ   | Ĵ    |      |       | _        |      |      |      |      |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| ABET Sr. Project Analysis         |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     | -   |      |      |       | ∆ {      |      |      |      | ~    |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| Requirements and Specifications V | 2 + In | tro  |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          | í 📫  |      |      | ۰O   |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| Report V1                         |        |      |      | -   |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          |       |         | 3    | 2   |     |     |       |     |      |      |     |         |   |      |   |
| Advisor Feedback Due              |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      | ¢    |     |     |      |      |       |          |      |      |      |      |       |          |       |         |      |     |     |     | 2     |     |      |      |     |         |   |      |   |
| Report V2                         |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          |       |         |      |     |     |     |       |     |      |      |     | ▲       |   |      |   |
|                                   | _      |      |      | _   |          |     |          |     |      | _     |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          |       |         |      |     |     |     |       |     |      |      | _   | _       | _ |      | _ |
| Presentations                     |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      | _    |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| Requirements and Specifications   |        |      |      |     |          |     |          |     |      | _     | $\odot$ |     | _    |   |     |      |      |     |     |      |      |       | _        |      | _    |      |      |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| Report V1                         |        |      |      |     |          |     |          |     |      | _     |         |     | _    | _ |     | _    |      |     |     |      |      |       |          |      |      |      |      |       |          |       |         |      |     | _   |     |       | 0   | )    |      |     |         | _ |      | _ |
|                                   |        |      |      |     |          |     | _        |     | _    | _     |         |     | _    | _ |     | _    |      |     | _   |      |      | _     | _        |      | _    | _    | _    | _     |          |       | _       |      | _   | _   |     | _     |     |      | _    | _   | _       | _ | _    | _ |
| HW 1 Resume & Cover Lette         | -      |      |      |     |          |     |          |     | _    | _     | _       |     |      |   |     | _    |      |     | _   |      |      |       |          |      | _    |      |      | _     | _        | _     |         |      |     |     |     |       |     |      | _    | _   |         | _ | _    | _ |
| Due                               |        | _    |      |     | <u> </u> | 4   |          | _   |      | _     |         |     |      | _ |     | _    |      |     | _   | _    |      |       | _        |      | _    |      |      |       | _        |       | _       |      |     | _   |     |       |     |      | _    | _   |         |   | _    | _ |
| HW 2 Sensitivity Analysis         |        |      |      | _   |          |     |          |     |      |       | _       |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          | _     |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| Due                               |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     | Δ    |      |       |          |      |      |      |      |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
| HW 3 Reverse Engineering          |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          | 1 (   |         | b)   |     |     |     |       |     |      |      |     |         |   |      |   |
| Due                               |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          | Y I   | 2       | ×    |     |     |     |       |     |      |      |     |         |   |      |   |
| Final Exam                        |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          |       | $\succ$ |      |     |     |     |       |     |      |      |     | $\odot$ |   |      |   |
|                                   |        |      |      |     |          |     |          |     |      |       |         |     |      |   |     |      |      |     |     |      |      |       |          |      |      |      |      |       |          |       |         |      |     |     |     |       |     |      |      |     |         |   |      |   |
|                                   |        |      | Tean | Ass | ignm     | ent | 1        | Fe  | edba | ick F | leaui   | red |      |   | Ass | ignr | nent | Due | Т   | 2    | V1.5 | 5 Due | e to .   | Advi | sord | & In | str. | D In  | 1-clas   | ss as | sign    | ment |     | - 🧖 | Ad  | visor | Fee | dbac | k 🗌  |     |         |   |      |   |

| Winter Break 2014         |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
|---------------------------|----|---|------|-----|---|----|---|------|-----|---|----|---|------|-----|---|
|                           |    | V | Veel | k 1 |   |    | V | Veel | k 2 |   |    | V | Veel | k 3 |   |
|                           | М  | Т | W    | R   | F | М  | Т | W    | R   | F | М  | Т | W    | R   | F |
|                           | 15 |   |      |     |   | 22 |   |      |     |   | 29 |   |      |     |   |
| Research                  |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Compression               |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Encoding / Comm Protocols |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Noise Reduction           |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| Handling Bit Errors       |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |
| ADCs & DACs               |    |   |      |     | _ |    |   | _    | _   | _ |    |   |      |     |   |
| Design                    |    |   | -    |     |   |    |   |      |     |   |    |   |      |     |   |
| Block Diagrams            |    |   |      |     |   |    |   |      |     |   | -  |   |      |     |   |
| Preliminary Parts Lists   |    |   |      |     |   |    |   |      |     |   |    |   |      |     |   |

# TABLE C4 (b)Actual Development Gantt Chart –Winter 2015

| Senior Project: Actual Timeline | - Ga | antt | t Ch | art |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | L |
|---------------------------------|------|------|------|-----|----|----|-----|---|----|------|-----|----|----|------|---|-----|------|--------|-----|----|------|---|------|------|-------|-----|---|----|------|---|----|-----|--------|---|-----|----|-------|---|----|--------------|----------|---|
| Winter 2015                     |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
|                                 |      | Wee  |      |     |    | We |     |   |    | Veel |     |    |    | ek 4 |   |     | Wee  |        |     |    | Neel |   |      |      | Wee   |     |   |    | Weel |   |    |     | Veek 9 |   |     |    | ek 10 |   |    | Fina         |          | _ |
|                                 | Μ    | ΤW   | / R  | F   | М  | ΤW | / R | F |    | W    | R F | M  | ΤV | NR   | F | М   | ΓW   | R      | F   | МT | W    | R | F    | ΜΊ   | W     | R   | F | МT | W    | R | FN | 1 T | WF     | ۲ | М   | ΤV | V R   | F | ΜT | W            | R        | L |
|                                 | 5    |      |      |     | 12 |    |     |   | 19 |      |     | 26 |    |      |   | 2   |      |        |     | 9  |      |   |      | 16   |       |     |   | 23 |      |   |    | 2   |        |   | 9   |    | _     |   | 16 |              |          |   |
| Requirements & Specifications   |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Request Elaboration on Needs    |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| and Requirments                 |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Modify Specifications           |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     | -  |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Further Research                |      |      |      |     |    |    |     |   |    |      |     |    |    | -    |   |     | -    |        |     | -  |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Simulations                     |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      | -    |       | - 4 | 7 |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Conceptually Design             |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | þ |
| Study & Simulate Encoding       |      |      | -    |     |    |    | -   | - |    |      |     | -  | -  |      |   |     | -    | -      | -   | -  |      |   |      |      | -     | -   |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Block Diagram                   | 1    |      | -    |     |    |    | -   |   |    |      |     | -  | -  | -    | - |     | -    |        | Þ   | -  |      |   |      |      | -     | -   |   |    |      |   |    | +   |        | - |     |    |       |   |    |              |          |   |
| Select Parts                    |      |      |      |     |    |    |     |   |    |      |     |    | -  |      | - |     | -    |        |     |    |      |   |      | -    | -     |     | F | f. |      |   |    |     |        | 1 | ET. |    |       |   |    |              |          |   |
| Tiva C Based System             |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Get Dev Envir to Work           |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Learn Basics of the MCU         |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          |   |
| Develop Interfaces              |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    | 7     |   |    |              |          |   |
| FPGA Based System               |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | Ċ |
| Research Hobbyist Work          |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | È |
| Integrate Camera & FPGA         |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              | <u> </u> | ľ |
| Try to integrate DAC            |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | h |
|                                 |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | ľ |
| Research                        |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        | 1 |     |    |       |   |    |              |          | ľ |
| Compression                     |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | ľ |
| Encoding / Comm Protocols       |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | ľ |
| Noise Reduction                 |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | ľ |
| Handling Bit Errors             |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | Î |
|                                 |      |      |      |     |    |    |     |   |    |      |     |    | 11 |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | ľ |
| Document Cycle                  |      |      |      |     |    |    |     |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    |     |        |   |     |    |       |   |    | 0            |          | ľ |
| Update Req and Spec             |      |      | -    |     |    |    | -   | - |    |      |     | +  |    |      |   |     |      |        | -   |    |      |   |      |      | -     |     |   |    |      |   |    |     |        |   |     |    |       |   |    |              |          | ľ |
| Design Documentation            |      |      |      |     |    |    | 1   |   |    |      |     |    |    |      |   |     |      |        |     |    |      |   |      |      |       |     |   |    |      |   |    | -   |        | - | 1   |    |       |   |    | $\mathbf{O}$ |          | ľ |
|                                 |      |      | 1    |     |    |    | 1   | 1 |    |      |     |    |    |      | Δ | Min | or M | filest | one |    | E.   |   | Part | s Aı | rrive |     |   |    |      |   |    |     |        |   | 1   |    | 1     |   |    |              |          | Ĩ |

# TABLE C4 (c)Actual Development Gantt Chart – Spring 2015

| Senior Project: Actual Timeline  | - Gaı | ntt Cl | hart |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
|----------------------------------|-------|--------|------|----------|------|-------|--------|-------|-----|----|-----|-------|------|-----|------|-----|--------|-------|-------|-------|----|------|----|----|----|------|---|-----|--------|-----|----------|------|-----|---|------|-----|
| Spring 2015                      |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
|                                  |       | Veek 1 |      |          | Veek |       |        | Weel  |     |    | Wee |       |      |     | /eek |     |        | Wee   |       |       |    | Neek |    |    |    | ek 8 |   |     | Veek 9 |     |          | Veek | 1   |   | Fina |     |
|                                  | M T   | WR     | ۲    | M T      | W    | R F   | M      | ΓW    | R F | M  | ΤW  | R     | F    | M T | W    | R F | М      | ΤW    | R     | F     | ΜT | W    | RF | M  | ΤV | V R  | F | M T | WR     | R F | Μ        | ΓW   | R F | М | ΓW   | R F |
|                                  | 30    |        |      | 6        |      |       | 13     |       |     | 20 | _   | +     |      | 27  |      | _   | 4      | _     |       | _     | 11 |      |    | 18 |    | _    | _ | 25  |        |     | 1        |      | _   | 8 |      | _   |
| FPGA Based System                |       |        |      |          |      |       |        |       |     | _  | _   |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        | _   |          |      |     |   |      |     |
| Research Hobbyist Work           |       |        |      |          |      |       |        |       |     | _  | _   |       |      |     |      |     |        |       |       |       |    |      |    |    |    | _    |   |     |        | _   |          |      |     |   |      |     |
| Try to integrate DAC             |       |        | _    |          | 1    |       |        |       |     | _  |     |       | _    |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        | _   |          |      |     |   |      |     |
| Try to integrate Ext. Memory     |       |        |      | <u> </u> |      | _     |        | _     |     |    |     |       |      |     |      | _   |        | _     |       |       |    |      |    |    |    | _    |   |     |        | _   |          |      |     |   |      |     |
| Raspberry Pi Based System        |       |        |      |          |      |       |        |       | E.  |    |     |       |      |     |      |     |        |       |       |       |    |      |    | •  |    |      |   |     |        |     |          |      |     |   |      |     |
| Intergrating Pi & Camera         |       |        |      |          |      |       |        |       |     |    |     |       | 1    |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| Improving Capture & Compression  |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       | Δ  |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| Try to Impliment DMA Timing      |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| Raspberry Pi + Tiva C System     |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    | E.   |   |     |        |     |          |      |     |   |      |     |
| Establish Commbetw RPi & Tiva    |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    | -    |    |    |    |      |   | -   |        |     |          |      |     |   |      |     |
| Impl Tiva Timers For Output Ctrl |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        | ÷.  |          |      |     |   |      |     |
| Integrate DAC (w/ Timed Output)  |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     | <u> </u> | 7    |     |   |      |     |
| Fix Bug in Comm betw RPi & Tiva  |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     | Δ |      |     |
| Reduce Noise and Settling Error  |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   | 7    |     |
| Estab Reciever for Testing       |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          | 7    |     |   |      |     |
| Create Code for Decod Analog Dat |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| Improve Decode Accuracy          |       |        |      |          |      |       |        |       |     | -  | _   |       | _    |     |      | _   |        |       |       | _     | _  |      |    |    |    | _    |   | _   |        |     |          |      |     |   |      | _   |
| Document Cycles                  |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          | -    |     |   | -    |     |
| FPGA Doucumentation              |       |        | _    |          | -    |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| Raspberry Pi Documentation       |       |        |      |          |      |       |        |       |     |    | -   |       | _    |     |      |     |        |       | -     |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| RPI + Tiva C Documentation       |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| Final Documentation              |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      | _   |
| ABET Senior Project Anal (Final) |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
| Final Report                     |       |        |      |          |      |       |        |       |     |    |     |       |      |     |      |     |        |       |       |       |    |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |
|                                  |       |        |      |          |      | Minoi | r Mile | stone | e   | E  | Pa  | rts A | rriv | e   |      | M   | ajor ' | Targe | et De | eadli | ne |      |    |    |    |      |   |     |        |     |          |      |     |   |      |     |

#### **Appendix D – Program Listings**

#### **Raspberry Pi Code:**

Shell Script for Video Capture, Compression, and Wrapping in .mp4 file – Vid\_script\_Pi:

```
C code for sending video data to the Tiva C - ComProtVidPlus:
/*
-- Author: Thomas Higdon
-- Last Modification: 6/8/15
*/
```

```
//----Libraries-----
#include <wiringPi.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
//----Definitions-----
#define BCM2 2
#define BCM3 3
#define BCM4 4
#define BCM5 5
#define BCM6 6
#define BCM7 7
#define BCM8 8
#define BCM9 9
#define SendSig 21
#define ReadyPin 20
#define MoreDataPinO 16
//----Pre-declare Functions-----
inline void BCM writeByte(char Byte);
void BCM ByteOut Ini();
int main()
{
   //-----Variable Declaration-----
   //int I;
   //uint8 t I8;
   uint8 t NextByte=0;
```

```
FILE *infile;
uint8 t successful read;
//-----Initialization-----
if (wiringPiSetupGpio() == -1)
   exit(1);
BCM ByteOut Ini();
if(piHiPri(99))
{
   printf("Error setting high priority\n");
   return 1;
};
pinMode(ReadyPin,OUTPUT);
pinMode (MoreDataPinO,OUTPUT);
pinMode (SendSig, INPUT);
   pullUpDnControl (SendSig, PUD DOWN);
//-----
//----Data to Send-----
printf("Opening File to be sent...");
infile = fopen("scriptest.mp4","rb");
if (!infile)
{
   printf("Unable to open file(scriptest.mp4)");
   return 1;
}
printf("opened.\n");
//-----
//----Data Transfer-----
// I8=0;//!!!!!Just for testing send
//wiringPiISR(HaltSig, INT EDGE RISING, &HaltFunc);
digitalWrite (MoreDataPinO,1);
while(1)
Ł
   successful read = fread(&NextByte, 1, 1, infile);
   if (successful read != 1) { break; }
   //---More File Data Ready---
   digitalWrite(ReadyPin,0);
    //printf("Ready Low\n");
    //or//Same
       //I8++;//!!!!Just for testing send
       //printf("New Index: %d",I8);
//---Wait to send---
   while(!digitalRead(SendSig)); //trap until not 0
    //printf("\nDetected a Send Request\n");
//---Send Byte---
   BCM writeByte (NextByte);
   //printf("Sent: %d (from I=%d)\n",NextByte,I8);
//---Signal Ready---
   digitalWrite(ReadyPin,1);
   //printf("Ready High\n");
//---Wait for Send==0---
```

```
while(digitalRead(SendSig)); //trap until not 1
        //printf("Send Low Detected\n");
    /*
    //---Signal Ready---
        digitalWrite(ReadyPin,0);
        printf("Ready Low\n");
        //or//Same
             I8++;//!!!!Just for testing send
             //printf("New Index: %d",I8);
    */
    }
    digitalWrite (MoreDataPinO, 0);
    digitalWrite(ReadyPin,0);
    printf("\nDone Reading File and Sending Data.\n");
    NextByte = 0 \times 00;
    fclose(infile);
    return 0;
}
inline void BCM writeByte(char Byte)
ł
    int val;
    val = 0 \times 01 & Byte;
                               //Bit-masking
    digitalWrite(BCM2, val); //treats any nonzero as high
    val = 0 \times 02 & Byte;
    digitalWrite(BCM3, val); //treats any nonzero as high
    val = 0 \times 04 & Byte;
    digitalWrite(BCM4, val); //treats any nonzero as high
    val = 0 \times 08 & Byte;
    digitalWrite(BCM5, val); //treats any nonzero as high
    val = 0 \times 10 & Byte;
    digitalWrite(BCM6, val); //treats any nonzero as high
    val = 0 \times 20 & Byte;
    digitalWrite(BCM7, val); //treats any nonzero as high
    val = 0 \times 40 & Byte;
    digitalWrite(BCM8, val); //treats any nonzero as high
    val = 0 \times 80 & Byte;
    digitalWrite(BCM9, val); //treats any nonzero as high
}
void BCM ByteOut Ini()
{
    int I;
    for (I = 2; I < 10; I++)</pre>
    {
        pinMode(I, OUTPUT);
    }
}
```

### Tiva C Code:

*The C code for Buffering Data from the RPi to the DAC – Com\_with\_Pi\_Timer:* /\* --Author: Thomas Higdon --Last Modification: 6/8/15 - ---Based in part on Texas Instruments Code Samples for using the Tiva C --included with the Tiva C development package --The sample projects: project0.c and timers.c --TI's copyright statement and disclaimer are below: 11 // project0.c - Example to demonstrate minimal TivaWare setup // timers.c - Timers example. 11 // Copyright (c) 2012-2013 Texas Instruments Incorporated. All rights reserved. // Software License Agreement 11 // Texas Instruments (TI) is supplying this software for use solely and // exclusively on TI's microcontroller products. The software is owned by // TI and/or its suppliers, and is protected under applicable copyright // laws. You may not combine this software with "viral" open-source // software in order to form a larger program. 11 // THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS. // NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT // NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR // A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY // CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL // DAMAGES, FOR ANY REASON WHATSOEVER. 11 // This is part of revision 1.1 of the EK-TM4C123GXL Firmware Package. 11 \*/ //For talking to Pi #include <stdint.h> #include <stdbool.h> #include "inc/hw types.h" #include "inc/hw memmap.h" #include "driverlib/sysctl.h" #include "driverlib/gpio.h" #include "driverlib/debug.h" //For Timers #include "inc/hw\_ints.h" //#include "driverlib/fpu.h" #include "driverlib/interrupt.h" #include "driverlib/pin map.h" #include "driverlib/rom.h"

```
#include "driverlib/timer.h"
11
// Define pin mapping.
11
#define RED LED GPIO PIN 1
#define BLUE LED GPIO PIN 2
#define GREEN LED GPIO PIN 3
#define SendPinO GPIO PIN 0
#define ReadyPinI 0x02
#define MoreDataPinI GPIO PIN 5
#define DAC_nWR_0 GPI0_PIN_3
#define Buff_Full_0 GPI0_PIN_7
#define Buff Low O GPIO PIN 4
11
// The error routine that is called if the driver library encounters an error.
11
#ifdef DEBUG
void
_error__(char *pcFilename, uint32_t ui32Line)
{
}
#endif
11
// Global Variables
11
static uint fast8 t gbl storedData[512]={0};
volatile int gbl_ReceiveIndex;
volatile int gbl_SendIndex;
volatile int32_t gbl_BuffLeadSize;
volatile uint fast8 t gbl SendMode=0;
volatile uint_fast32_t gbl_SendCount=0;
const uint_fast32_t MinBuff = 500;
//Function Declarations
//*********
           void init_gpio();
uint fast8 t read Pi Byte();
void write_DAC_Byte(uint_fast8_t Byte);
void Timer0IntHandler(void);
void init_timers();
11
```

```
// Main 'C'
11
//*******
          int
main(void)
{
      //-----<u>Initiallization</u>-----
      gbl ReceiveIndex=-1;
      gbl SendIndex=-1;
      //int I=0;
      //uint fast8 t testbyte = 0xAA;
      uint_fast8_t readbyte;
      //uint fast8 t storedData[512];
   /* //
   // Setup the system clock to run at 50 Mhz from PLL with crystal reference
   //
   SysCtlClockSet(SYSCTL SYSDIV 4|SYSCTL USE PLL|SYSCTL XTAL 16MHZ|
                   SYSCTL OSC MAIN);*/
      11
      // Set the clocking to run directly from the crystal.
      11
      //ROM_SysCtlClockSet(SYSCTL_SYSDIV_1 | SYSCTL_USE_OSC | SYSCTL_OSC_MAIN
                                        //SYSCTL XTAL 16MHZ); //Timer Interrupt
Original
      ROM SysCtlClockSet(SYSCTL SYSDIV 4 | SYSCTL USE PLL | SYSCTL OSC MAIN |
                                  SYSCTL XTAL 16MHZ); //TH: Modded to 50 Mhz PLL
   SysCtlPeripheralEnable(SYSCTL PERIPH GPIOF); //For debug
   GPIOPinTypeGPI0Output(GPI0_PORTF_BASE, RED_LED|BLUE_LED|GREEN_LED); //For debug
   //GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED, RED LED); //For debug
   init gpio();
   write DAC Byte(0x00);
   init_timers();
   GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED, BLUE LED);
   //-----Start of Communication with RPi Loop------
   while(GPIOPinRead(GPIO PORTB BASE,MoreDataPinI)>0) //For Testing
   {
      while(gbl BuffLeadSize >= MinBuff); //Wait until buffLead < 500</pre>
                  //GPIOPinWrite(GPIO_PORTF_BASE, RED_LED|BLUE_LED|GREEN_LED,
GREEN LED BLUE LED); //For debug
      GPIOPinWrite(GPIO PORTB BASE, SendPinO, 0xFF); //Request Next Byte from Pi
                  //GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED,
GREEN LED RED LED); //For debug
      while((GPIOPinRead(GPIO_PORTB_BASE,ReadyPinI)&ReadyPinI)==0); //Wait until Pi
says the data is Ready
                  //GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED,
RED LED BLUE LED); //For debug
      readbyte = read_Pi_Byte(); //Read the actual data in from the Pi
```

```
//GPIOPinWrite(GPIO_PORTF_BASE, RED_LED|BLUE_LED|GREEN_LED,
GREEN LED);
     GPIOPinWrite(GPIO PORTB BASE, SendPinO, 0x00); //Tell Pi Data has been
received
     gbl_ReceiveIndex++;
           //gbl ReceiveIndex=gbl ReceiveIndex%512; //Too slow, if statement faster
           if(gbl_ReceiveIndex>511)
           {
                 gbl ReceiveIndex=0;
           }
     gbl storedData[gbl ReceiveIndex] = readbyte; //For Testing
           //write DAC Byte(readbyte); //For Testing
     while((GPIOPinRead(GPIO_PORTB_BASE,ReadyPinI)&ReadyPinI)!=0); //Wait for
acknowledge/reset from Pi
     //----Update BuffLeadSize-----
           if((gbl ReceiveIndex-gbl SendIndex) >= 0)
           {
                 gbl_BuffLeadSize=gbl_ReceiveIndex-gbl_SendIndex;
           }
           else
           {
                 gbl BuffLeadSize=gbl ReceiveIndex-gbl SendIndex+512;
           }
     //Begin again
   } //Receive Data Loop
   while(gbl SendMode!=5); //Wait to finish sending what is stored in the buffer
   ROM_IntMasterDisable(); //Disable timers
   write_DAC_Byte(0x00); //Turn everything off . . .
   GPIOPinWrite(GPIO_PORTF_BASE, RED_LED|BLUE_LED|GREEN_LED, 0x00);
   return 0;
} //----End of Main-----
***
void init_gpio()
{
     //-----Receiving End------
     GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED, RED LED); //For
debug
     SysCtlPeripheralEnable(SYSCTL PERIPH GPIOB); //Enable Port B
     SysCtlPeripheralEnable(SYSCTL PERIPH GPIOD); //Enable Port D
     SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOE); //Enable Port E
     //GPIOPinTypeGPIOInput(GPIO_PORTE_BASE,
GPI0_PIN_4|GPI0_PIN_3|GPI0_PIN_2|GPI0_PIN_1); //PE:
GPIO PIN 4 GPIO PIN 3 GPIO PIN 2 GPIO PIN 1 0x1E
```

// Check the arguments. ASSERT( GPIOBaseValid(GPIO PORTE BASE)); // Make the pin(s) be inputs. **GPIODirModeSet**(GPIO PORTE BASE, GPIO\_PIN\_4|GPIO\_PIN\_3|GPIO\_PIN\_2|GPIO\_PIN\_1, GPIO\_DIR\_MODE\_IN); // Set the pad(s) for standard push-pull operation. GPIOPadConfigSet(GPI0\_PORTE\_BASE, GPI0\_PIN\_4|GPI0\_PIN\_3|GPI0\_PIN\_2|GPI0\_PIN\_1, GPI0\_STRENGTH\_2MA, GPIO PIN TYPE STD WPD); //////GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED, GREEN LED RED LED); //For debug //GPIOPinTypeGPIOInput(GPIO PORTD BASE, 0x0F ); //PD: GPIO PIN 3|GPIO PIN 2|GPIO PIN 1|GPIO PIN 0 <---- This was causing stack overflow, the following was not // Check the arguments. ASSERT( GPIOBaseValid(GPIO PORTD BASE)); // Make the pin(s) be inputs. GPIODirModeSet(GPIO\_PORTD\_BASE, 0x0F, GPIO\_DIR\_MODE\_IN); // Set the pad(s) for standard push-pull operation. GPIOPadConfigSet(GPIO\_PORTD\_BASE, 0x0F, GPIO\_STRENGTH\_2MA, GPIO\_PIN\_TYPE\_STD\_WPD); //////GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED, BLUE LED RED LED); //For debug //GPIOPinTypeGPIOInput(GPIO PORTB BASE, ReadyPinI ); //PB GPIO PIN 1 <-----</pre> This was // Check the arguments. ASSERT( GPIOBaseValid(GPIO PORTB BASE)); // Make the pin(s) be inputs. GPIODirModeSet(GPIO\_PORTB\_BASE, ReadyPinI|MoreDataPinI, GPIO DIR MODE IN); // Set the pad(s) for standard push-pull operation. GPIOPadConfigSet(GPIO PORTB BASE, ReadyPinI | MoreDataPinI, GPIO STRENGTH 2MA, GPIO PIN TYPE STD WPD); //////GPIOPinWrite(GPIO\_PORTF\_BASE, RED\_LED|BLUE\_LED|GREEN\_LED, BLUE\_LED|GREEN\_LED|RED\_LED); //For debug GPIOPinTypeGPIOOutput(GPIO PORTB BASE, SendPinO ); //PB GPIO PIN 1|pin5 //-----Sending End------SysCtlPeripheralEnable(SYSCTL\_PERIPH\_GPIOC); //Enable Port C SysCtlPeripheralEnable(SYSCTL\_PERIPH\_GPIOA); //Enable Port A //FOR DEBUG, REMOVED: SysCtlPeripheralEnable(SYSCTL\_PERIPH\_GPIOF); //Enable Port F **GPIOPinTypeGPIOOutput**(GPIO PORTC BASE, 0xF0 ); //PC: GPIO PIN 7 GPIO PIN 6 GPIO PIN 5 GPIO PIN 4 GPIOPinTypeGPIOOutput(GPIO\_PORTA\_BASE, 0x1C ); //PA: GPIO PIN 4 GPIO PIN 3 GPIO PIN 2 GPIOPinTypeGPIOOutput(GPIO\_PORTB\_BASE, GPIO\_PIN\_2); //PB: GPIO\_PIN\_2

```
GPIOPinTypeGPIOOutput(GPIO_PORTB_BASE, DAC_nWR_0); //PB: GPIO_PIN_3 controls
DAC's nWR
      GPIOPinWrite(GPIO PORTB BASE, DAC nWR O, DAC nWR O); //Initialize High,
because active low
      GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED, BLUE LED); //For
debug
      return;
}
uint_fast8_t read_Pi_Byte()
{
      uint_fast32_t Byte = 0x00;
      //GPIOPinWrite(GPIO_PORTF_BASE, BLUE_LED|GREEN_LED, BLUE_LED);
      Byte = (GPIOPinRead(GPIO PORTE BASE, 0x1E )<<3); //PE:</pre>
GPIO PIN 4 GPIO PIN 3 GPIO PIN 2 GPIO PIN 1
      Byte |= GPIOPinRead(GPIO PORTD BASE, 0x0F); //PD:
GPIO_PIN_3|GPIO_PIN_2|GPIO_PIN_1|GPIO_PIN_0
      //GPIOPinWrite(GPIO PORTF BASE, BLUE LED|GREEN LED, 0);
      return Byte;
}
void write DAC Byte(uint fast8 t Byte)
{
      //uint fast32 t BigInt;
      //BigInt = Byte;
      //GPIOPinWrite(GPIO_PORTF_BASE, BLUE_LED|GREEN_LED, BLUE_LED);
      GPIOPinWrite(GPIO PORTB BASE, DAC nWR 0, 0x00); //nWR low to read data to DAC
      SysCtlDelay(ROM_SysCtlClockGet()/11000000); //delay 91 ns
      GPIOPinWrite(GPIO_PORTC_BASE, 0xF0, Byte);//PC:
GPIO PIN 7 GPIO PIN 6 GPIO PIN 5 GPIO PIN 4
      //////GPIOPinWrite(GPIO PORTF BASE, RED LED|BLUE LED|GREEN LED, RED LED);
      GPIOPinWrite(GPIO PORTA_BASE, 0x1C, (Byte<<1)); //PA:</pre>
GPIO PIN 4 GPIO PIN 3 GPIO PIN 2
      ///////GPIOPinWrite(GPIO PORTF BASE, RED LED BLUE LED GREEN LED,
RED LED GREEN LED);
      GPIOPinWrite(GPIO_PORTB_BASE, GPIO_PIN_2, (Byte<<2)); //PB: GPIO_PIN_2
      SysCtlDelay(1); //delay 20 ns
      GPIOPinWrite(GPIO PORTB BASE, DAC nWR 0, DAC nWR 0); //nWR high to latch data
to DAC
      //GPIOPinWrite(GPIO PORTF BASE, BLUE LED|GREEN LED, GREEN LED);
      return;
}
void
Timer0IntHandler(void)
{
   //char cOne, cTwo;
   11
   // Clear the timer interrupt.
   //
   ROM TimerIntClear(TIMER0 BASE, TIMER TIMA TIMEOUT);
```

```
11
    // -----Send To DAC-----
    11
    if(gbl_SendMode == 3) //Mode-3=Sending Data from Buffer; Most timing critical
mode is first tested for
      {
             gbl_SendIndex++;
             //gbl SendIndex=gbl SendIndex%512;
             if(gbl_SendIndex>511)
             {
                    gbl_SendIndex=0;
             }
             write_DAC_Byte(gbl_storedData[gbl_SendIndex]);
             //Update BuffLeadSize
             int temp_sub_int = gbl_ReceiveIndex-gbl_SendIndex;
             if((temp_sub_int) > 0)
             {
                    gbl_BuffLeadSize=gbl_ReceiveIndex-gbl_SendIndex;
             }
             else if(temp_sub_int<0)</pre>
             {
                    gbl BuffLeadSize=gbl ReceiveIndex-gbl SendIndex+512;
             }
             else
             {
                    gbl_SendMode=5;
             }
      }else
      if (gbl SendMode == 0) //Initially send 20 zeros
      {
             write_DAC_Byte(0x00);
             gbl_SendCount++;
             if (gbl_SendCount>19)
             {
                    gbl_SendCount = 0;
                    gbl_SendMode = 1;
             }
      }
      else
      if(gbl_SendMode == 1) //Send callibration ramp
      {
             uint_fast32_t calli_data;
             calli_data = gbl_SendCount>>1; //Sends same byte twice before moving on
             write DAC Byte(calli data);
             gbl SendCount++;
             if (gbl_SendCount>511)
             {
                    gbl_SendCount = 0;
                    gbl SendMode = 2;
             }
      }
      else
```

```
if(gbl_SendMode == 2) //Send 20 zeros after callibration
      {
             write_DAC_Byte(0x00);
             gbl_SendCount++;
             if (gbl_SendCount>19)
             {
                    gbl_SendCount = 0;
                    gbl_SendMode = 3;
             }
      }
      else // Just send zero, final state
      {
             write DAC Byte(0x00);
             GPIOPinWrite(GPIO_PORTF_BASE, BLUE_LED|GREEN_LED|RED_LED, RED_LED);
      }
    //
    // Update the interrupt status on the display.
    11
    ROM_IntMasterDisable();
    ROM_IntMasterEnable();
}
void init_timers()
{
      //
      // Enable the peripheral used by this example.
      11
      ROM SysCtlPeripheralEnable(SYSCTL PERIPH TIMER0);
      //
      // Enable processor interrupts.
      11
      ROM IntMasterEnable();
      11
      // Configure the two{one} 32-bit periodic timers.
      11
    ROM_TimerConfigure(TIMER0_BASE, TIMER_CFG_PERIODIC);
    ROM_TimerLoadSet(TIMER0_BASE, TIMER_A, ROM_SysCtlClockGet()/3330);
    11
      // Setup the interrupts for the timer timeouts.
      11
      ROM_IntEnable(INT_TIMER0A);
      ROM_TimerIntEnable(TIMER0_BASE, TIMER_TIMA_TIMEOUT);
      //
      // Enable the timers{timer}.
      11
      ROM_TimerEnable(TIMER0_BASE, TIMER_A);
}
```

#### Analog Data Decoding and Digital Data Reconstruction (Matlab):

The primary piece of reconstruction code is an m-script: ana2file\_script\_B.m, however it calls 3 functions also created by the project designer, whose code will follow ana2file\_script\_B.m's code. The functions are: clust\_callibration.m, findbin.m, and writebytes2file.m An alternatice to clust\_callibrated.m is dev\_callibration.m

```
Main Script for translated analog readings back into a digital file – ana2file_script_B.m:
% ana2file script B.m
%--Author: Tom Higdon
%--Date Modified: 6/13/15
an data=importdata('ana vid data2.csv');
max an=max(an data);
min an=min(an data);
range=max an-min an;
%-----Callibrate-----
% -- Find Callibration Signal --
start_sig=find( an_data<(1.1*abs(min an)), 1, 'first');</pre>
trig start=find( an data(start sig:end)>(max an/5),1,'first' );
trig start=start sig+trig start;
trig stop=find( an data(start sig:end)>(max an*4/5),1,'first' );
trig stop=start sig+trig stop;
8 -----
%Old: % calli data=an data((trig start-326):(trig stop+326));
%(255/5)*6+20=326
% Using data from beginning middle and end to try to reduce any component
% drift issues. Adaptive Callibration might further improve.
stop data=find(an data>0.100,1,'last');
mid point=round(mean(trig start, stop data));
calli part1=an data((trig start-326):trig start+15000); % Beginning
calli part2=an data((mid point-7500):(mid point+7500)); % Middle
calli part3=an data((stop data-15000):stop data);
                                                    % End
calli data=vertcat(calli part1, calli part2, calli part3);
zer noise=(calli data<0);</pre>
calli data(zer noise)=[];
% To generate callibrated byte code levels
[cent, numpoint2]=clust callibrate(calli data); % User created function
%[level, dev groups]=dev callibration(calli data); % Alt created function
mid fin=cent; %!!!!!!!!!!!!!!Change if you change which callib type!
%mid fin=level;
brder=zeros(255,1); % Create borders that can be used to put readings into
for I=2:256 % Bins
   brder(I-1) = (mid fin(I) + mid fin(I-1))/2;
end
```

'Callibrated.'

% Initiallize for Interpretation loop
continue reading=1;

```
Bfnd flg=0;
nBfnd cnt=0;
skip cnt=0;
old samp=NaN;
samp=0;
nan count=0;
nan loc=[];
nan loc an=[];
smp num=(trig stop+326); %
I=1;
I B=1;
binned data=zeros((length(an data)-smp num),1);
Byte data=zeros(ceil(length(binned data)/3),1);
while(continue reading==1)
    if (Bfnd flg==0) % If you haven't just found a Byte, look for one
        [ samp ]=findbin(an data(smp num), brder); %put anlg data in dig bin
        % findbin() is User Created Function
        if (abs(an data(smp num)-an data(smp num-1))<0.045) % compare with
previous sample
Byte data(I B)=findbin(0.8*an data(smp num)+0.2*an data(smp num),brder); % if
equal, you found a Byte
            Bfnd flq=1; % set flag that a Byte has been found
            nBfnd cnt=0; % reset counter since last Byte found
            I B=I B+1; % increment Byte array's index
        else % if not equal
            old samp=samp; % get ready to check the next pair
            nBfnd cnt=nBfnd cnt+1; % increment the byte not found counter
        end
         if ((nBfnd cnt>=2)) % Let me know if something is wrong
             Byte data(I B)=NaN;
             nan count=nan count+1;
             I B=I B+1;
             %nan loc=[nan loc,I];
             %nan loc an=[nan loc an, smp num];
             nBfnd cnt=0;
         endxlabel('Index')
    else % If you have found a byte recently
        skip cnt=skip cnt+1; % increment skip counter
        if(skip cnt>=2) % after 2 loops (so completely skiping 1 an samples)
            skip cnt=0; % reset skip counter
            Bfnd flg=0; % reset Byte found flag
            nBfnd cnt=0; % reset Byte not found counter
            % load 1st analog sample after the skipped sample into old samp
            old samp=findbin(an data(smp num), brder);
        end
    end
    binned data(I)=samp; % save the digital equivalents of all of the samps
    smp num=smp num+1; % increment the index in the original data array
    I=I+1; % increment the index for the shorted binned array
    if (smp num>(length(an data))) % stop when at the end of data
```

```
continue reading=0;
    end
00
      if(I B>100)
00
          if (sum (Byte data((I B-10):(I B-1)))==0)
00
              continue reading=0;
8
              'Stopped Binning Early Because zeros'
2
          end
8
     end
end
Start data=find(Byte data>0,1,'first');
End data=find(Byte data>10,1,'last');
% .mp4 has 3 leading zeros and one trailing zero, I think
Vid array = vertcat([0;0;0],Byte data(Start data:End data),[0]);
'Vid array ready!' %#ok<NOPTS>
success=writebytes2file(uint8(Vid array), 'DecodedVid.mp4');
if(success == 1)
    'Wrote to the File!' %#ok<NOPTS>
end
```

Function that finds calibrated voltage levels by clusting readings into 256 clusters – clust\_callibrate.m:

```
function [ cent, pointsperclust ] = clust callibrate( calli data )
%--Author: Tom Higdon
%--Date Modified: 6/9/15
len cal=length(calli data);
max_an=max(calli data);
min_an=min(calli_data);
range=max an-min an;
%-----cent initiallization-----
cent=zeros(256,1);
cent(1)=0;
for I=1:256
    %cent(I) = (range*(I-1) / (256-1)) + min_an;
    cent(I)=(2*5)*(16*(I-1)/4096); %From DAC (AD7345A) Datasheet pg 10
end
dtocent=zeros(len cal,256);
pointsperclust=zeros(8,1);
catag=zeros(len cal,1); %#ok<NASGU>
catag old=catag;
clust long=zeros(len cal,256);
iterate = 1;
iter count=0;
while iterate==1
    %-----Distance from centroid Calulation-----
    for I=1:256
        dtocent(:,I)=abs(calli data-cent(I));
    end
```

```
%Catagorizing
    [~,catag]= min( dtocent, [], 2 ); %Dimension-2
    %----- Recalculating centroid locations -------
    for I=1:256
        clust temp=zeros(len cal,1);
        cl temp ind=find(catag==I);
        size cl=length(cl temp ind);
        clust temp(1:size cl)=calli data(cl temp ind);
        %if (size cl ~= 0)
            cent(I) = sum(clust temp)./size cl;
        %end
        pointsperclust(I)=size cl;
        clust long(1:size cl,I)=clust temp(1:size cl);
    end
    iter count = iter count+1;
    if (iter count >= 3)
        compar catag = (catag~=catag old);
        percent diff = sum(compar catag)/len cal;
        if (percent_diff <= 0.05)</pre>
               iterate = 0;
           elseif (iter count > 35)
               'Could not converge!' %#ok<NOPTS>
               iterate = 0;
        end
    end
    catag old=catag;
end %while
```

```
end
```

Alternative Function that finds calibrated voltage levels based on ramp structure of the calibration signal – dev\_callibration.m:

```
function [ level, clust ] = dev_callibration( calli_data )
%--Author: Tom Higdon
%--Date Modified: 6/9/15
len_cal=length(calli_data);
sort_calli=sort(calli_data, 'descend');
clust(256,:)=sort_calli(1:7);
clust(256,:);
cl_mean=mean(clust(256,:));
cl_med_dev=median_deviation(clust(256,:));
for CI=1:7
    if (abs(clust(256,CI)-cl_mean)>(1.5*cl_med_dev))
        clust(256,CI)=NaN;
    else
        last_in_clust=CI;
    end %if
```

```
end %Inter-cluster for
temp clust=clust(256,(isfinite(clust(256,1:7)))); % Temp array with all non
                                                      %NaN numbers
level(256) = mean(temp clust);
Start = 1 + last in clust;
I=255;
while (I>1)
    last in clust=0;
    clust(I,:)=sort calli((Start):(Start+6));
    cl mean=mean(clust(I,:));
    cl med dev=median deviation(clust(I,:));
    for CI=1:7
        if (abs(clust(I,CI)-cl mean)>(1.5*cl med dev))
            clust(I,CI)=NaN;
        else
            last in clust=CI;
        end %if
    end %Inter-cluster for
    Start=Start+last in clust;
    temp clust=clust(I,(isfinite(clust(I,1:7))));
    level(I) = mean(temp clust);
    I=I-1;
end
```

*Function that returns the byte "bin" of the analog data, based on boundries – findbin.m:* 

```
function [ bin_value ] = findbin( analog_sample, boundry )
%--Author: Tom Higdon
%--Date Modified: 6/9/15
below=find(boundry<analog_sample,1,'last');
above=find(boundry>analog_sample,1,'first');
if(~isempty(below))
    bin_value=below; %not below+1 because Matlab 1-indexed and value 0-ind
elseif(~isempty(above))
    bin_value=above-1; %should only occur for the case of above==1, val==0
else
    'error, neither high nor low!' %#ok<NOPRT>
    bin_value=NaN;
    %return
end
```

```
Function that writes bytes to a binary file - writebytes2file.m:
function [ success ] = writebytes2file( Byte_vector, filename )
% Essentially taken from Mathwork Documention
fid = fopen(filename, 'w');
fwrite(fid,Byte_vector); % Default is one byte at a time
fclose(fid);
success=1;
end
```