Intelligent Tactical Vest by Khandaker, Atif M et al.
Worcester Polytechnic Institute
Digital WPI
Major Qualifying Projects (All Years) Major Qualifying Projects
April 2011
Intelligent Tactical Vest
Atif M. Khandaker
Worcester Polytechnic Institute
Jeffrey Michael Ferrandino
Worcester Polytechnic Institute
Jeremy Zorrilla De Los Santos
Worcester Polytechnic Institute
Victor Brisan
Worcester Polytechnic Institute
Follow this and additional works at: https://digitalcommons.wpi.edu/mqp-all
This Unrestricted is brought to you for free and open access by the Major Qualifying Projects at Digital WPI. It has been accepted for inclusion in
Major Qualifying Projects (All Years) by an authorized administrator of Digital WPI. For more information, please contact digitalwpi@wpi.edu.
Repository Citation
Khandaker, A. M., Ferrandino, J. M., Zorrilla De Los Santos, J., & Brisan, V. (2011). Intelligent Tactical Vest. Retrieved from
https://digitalcommons.wpi.edu/mqp-all/2465
  
 
  
  	
[2011]	 
 
Worcester Polytechnic 
Institute 
 
Victor Brisan       
Jeffrey Ferrandino        
Atif Khandaker            
Jeremy Zorrilla 
 
[INTELLIGENT TACTICAL VEST] 
[The Intelligent Tactical Vest project is an attempt at solving the crucial issue of police officers 
becoming injured in the line of duty without the ability to call for help. The system is designed to 
collect data relevant to the health status of officers using a device built into ballistic vests and 
process that data into a usable form in order to transmit it to relevant responders.] 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | I. Introduction  2 
 
Contents 
I. Introduction .................................................................................................................................... 5 
II. Project Goals.................................................................................................................................. 6 
A. Unfeasible Goals .......................................................................................................................... 6 
B. Short Term Goals ......................................................................................................................... 6 
C. Long Term Goals ........................................................................................................................... 7 
III. Background Research .................................................................................................................. 8 
A. Prior Art ....................................................................................................................................... 8 
1. Impact helmet – Northeastern University ................................................................................. 9 
2. Helmet Impact Sensor – Shock SpotR ........................................................................................ 9 
3. Real‐Time impact detection and Object Discrimination for Pedestrian Protection ................... 10 
4. Ballistic Impact Detection System ‐ US patent # 7660692: ....................................................... 11 
5. Ballistic impact sensing and display system ‐ US patent # 4305142: ........................................ 11 
B. Medical Background Research .................................................................................................... 11 
1. Polar RS100 ............................................................................................................................ 12 
2. Timex Ironman Race Trainer Heart Rate Monitor .................................................................... 12 
3. Pulse Oximeter LM‐800........................................................................................................... 13 
4. PDA cortex Life Shirt ............................................................................................................... 13 
5. Piezoelectric Film Sensor ........................................................................................................ 13 
6. Cuff‐less PPG‐Based Blood Pressure Monitor .......................................................................... 14 
7. Interview with Professor Mendelson ...................................................................................... 14 
C. Officer Assault Statistics ............................................................................................................. 15 
1. Officers Assaulted ................................................................................................................... 16 
2. Officers Killed Accidentally ..................................................................................................... 16 
3. Officers Feloniously Killed ....................................................................................................... 16 
D. System Concept ......................................................................................................................... 18 
E. Systems Research ....................................................................................................................... 18 
1. Load/Force Cells ..................................................................................................................... 19 
2. Single/dual Axis Accelerometers ............................................................................................. 20 
3. Piezoelectric Sensors Viability ................................................................................................. 22 
4. Sensor choices ........................................................................................................................ 23 
4. Gain Stage Expected Specs ...................................................................................................... 23 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | I. Introduction  3 
 
5. FPGA System Requirements .................................................................................................... 25 
F. Basic System Block Diagram ....................................................................................................... 27 
IV. System Components ................................................................................................................... 29 
A. Plate Test Stand ......................................................................................................................... 29 
B. Piezoelectric Testing ................................................................................................................... 33 
C. Analog Application Schematic .................................................................................................... 35 
D. ADC Schematic ........................................................................................................................... 37 
E. Logic System Level Implementation ............................................................................................ 39 
1. Simulation and Testing ........................................................................................................... 41 
F. Asynchronous Memory Interface Controller ............................................................................... 41 
1. The Control Logic .................................................................................................................... 42 
2. The State‐machine .................................................................................................................. 43 
3. Simulation and On‐board Functionality Testing ...................................................................... 46 
4. PicoBlaze Embedded Core....................................................................................................... 50 
5. I/O Port .................................................................................................................................. 51 
6. UART & Clock Divider ............................................................................................................. 54 
7. The Assembly Programming ................................................................................................... 55 
8. Read Function ......................................................................................................................... 55 
9. Transmit Function ................................................................................................................... 56 
10. Write Function ...................................................................................................................... 56 
11. Simulation and Functional Testing ........................................................................................ 57 
G. Data Input Controller ................................................................................................................. 59 
1. Clock Multiplier ...................................................................................................................... 61 
2. Clock Divider .......................................................................................................................... 61 
3. Address Counter ..................................................................................................................... 61 
4. FIFO Buffer ............................................................................................................................. 62 
5. Control Multiplexer ................................................................................................................ 63 
6. State Controller ...................................................................................................................... 64 
7. Trigger Controller ................................................................................................................... 65 
8. Simulation and Testing ........................................................................................................... 67 
H. Printed Circuit Board Design ...................................................................................................... 68 
1. Definitions .............................................................................................................................. 68 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | I. Introduction  4 
 
2. Custom Parts .......................................................................................................................... 69 
3. PCB Layers .............................................................................................................................. 70 
I. Localization Calculations ............................................................................................................. 76 
V. Results .......................................................................................................................................... 80 
VI. Sources ........................................................................................................................................ 82 
APPENDIX I .................................................................................................................................... 84 
APPENDIX II ................................................................................................................................. 102 
 
  
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | I. Introduction  5 
 
I. Introduction 
 
The Intelligent Tactical Vest MQP is a project that deals with the design of a system for 
improving mortality rates among wearers of ballistic vests. The project achieves this purpose by 
using a sensor grid attached to a ballistic vest or its plates to gather data at each impact, data 
which will then be stored and then used in trilateration calculations to determine the position on 
the vest of any impacts, be they from gun shots, stab attempts, or blunt force trauma. Ultimately, 
this information is useful in improving mortality rates because the project could be expanded to 
include a way to transmit it to appropriate responders such as emergency medical services if the 
vest is worn by police officers or field medics if it is worn by soldiers. Other potential system 
components that could further the project’s goal but that were not implemented are using sensor 
data to determine impact type, adding sensors for detecting vitals, and tracking the user with 
GPS. 
The project initially tested various types of sensors such as resistive plates, microphones, and 
piezoelectric strips to determine which sensor would best fit the design's goals. For this purpose, 
simple test circuits were developed which provided an analog to digital converter with 
appropriate voltage versus time signals. At the same time, an FPGA was set up to efficiently 
store the data in a manner usable by the team for analysis. 
 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | II. Project Goals  6 
 
II. Project Goals 
This project's goals were divided into goals the team could finish during the year assigned to the 
project, and goals that would make the project better but were not feasibly achievable in the 
limited time period available. Also, at the start of the project, the achievable goals were split up 
into immediate goals achievable in the early project stages and long term goals achievable during 
the project's entire length. 
 
A. Unfeasible Goals 
As mentioned in the introduction, the purpose of the vest system is to store information so that 
the information can be sent to some sort of responder, such as paramedics for police officers and 
field medics for military use. This transmitting of information goal is complex enough on its own 
that it would take up all of the project’s time and was therefore excluded as unfeasible. Another 
goal taken out due to its complexity is the GPS localization of the vest wearer. 
 
B. Short Term Goals 
Early in the project, the team was focusing on testing the feasibility of various sensors and on 
setting up an FPGA to collect data for later analysis. For these purposes, the team decided to 
initially split itself up in order to cover four different aspects of the project: testing apparatus 
design, analog circuitry design, memory interface design, and core design. 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | II. Project Goals  7 
 
During this stage, various types of accelerometers, piezoelectric strips, and microphones were 
individually tested in order to find out what sort of gain is needed for each sensor. Since the 
piezoelectric devices, accelerometers, and microphones provide a similar voltage signal, a single 
design can be used to test all of these sensors. However, the magnitudes of the signals are vastly 
different since microphones are expected to output very low voltages, piezoelectrics output very 
high voltages, and accelerometers somewhere in between. All sensor signals needed to be 
amplified or decreased into a range from zero to as close as possible to the ADC's maximum 
input to get as clear a picture as possible. The simplest design that can achieve this is connecting 
each sensor to an ADC input through a gain stage that can be changed depending on which type 
of sensor is being tested at the time.  
At the same time, analog-to-digital converters were researched and requested. Then initial 
VHDL programs to poll the ADC and store the output of the ADC were written. Finally, the 
design needed a way to communicate with the Nexys2 board through RS232 and pull the 
information stored from the ADC. 
 
C. Long Term Goals 
After the short term goals above were accomplished, the team moved on to working on the 
yearlong goals. Using the data collected from the system designed in B term, the location and the 
type of the injury could be calculated and stored as data potentially transmittable to responders. 
Sections of the overall system could also be implemented to detect whether or not the detected 
blow penetrated the vest and to detect relevant vital signs. 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  8 
 
III. Background Research 
Background Research was a critical process which was necessary before building any kind of 
device. Background research for the intelligent vest involved searching for prior art, officer 
assaults, medical background, and potential system implementations.  
 
A. Prior Art 
Prior art is an important tool in the development process. It saves a lot of time by allowing us to 
see areas of investigation and research done by others. Prior art research for the intelligent vest 
involved finding products created for the specific purpose of injury localization and vital sign 
monitoring.  
The previous art on impact detection is important because they contain information on how 
different concepts were setup, an abundance of data, and reasons why inventors chose different 
features of their concepts. The ballistic impact detection system offered similar ideas to 
ours using piezoelectric sensors and acoustic sensors. The piezoelectric sensors are placed on the 
front of the body and are used to detect force applied to the body, and the acoustic sensors are 
placed on the front of the body and are able to detect whether the impact occurred on the right, 
left, or center of the body. The Ballistic impact sensing and display system is an excellent 
concept of impact localization if we implement piezoelectric sensors in a grid array. 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  9 
 
1. Impact helmet – Northeastern University  
There is another project in progress at northeastern university which has a similar function to this 
project. It is a helmet which is capable of impact detection and relaying information in the form 
of a message on an LCD. The purpose of the helmet is to detect severity of injuries on the head 
from snowboarding/skiing incidents to alert first responders of the significance of the damage.  
Unfortunately it is not revealed how the helmet functions in order to perform the impact 
detection and any assumptions would be baseless. However, the impact helmet is basically a 
helmet version of what the intelligent vest is out to accomplish, that is to detect, localize, and 
report the severity of the injury on the body. From the success of the Impact Helmet project we 
can derive that it is possible to localize and report injury, and it will be possible to detect and 
localize bullet impact.  
 
2. Helmet Impact Sensor – Shock SpotR  
The Shok SpotR is an interesting product which is calibrated to detect if a helmet has been 
damaged from impact. It is essentially an accelerometer which detects sudden changes in 
acceleration. If the change is significant enough it sets of an alert to make the user aware of 
possible damage to the helmet, or even the head.  
The product is marketed as being useful because of the inability to necessarily see observable 
damage to a helmet after an impact. This alerts users that the impact was significant enough, and 
there is potential significant damage to the helmet. This shows that accelerometers could be used 
to determine various kinds of impacts on the person wearing the vest. For example, one could 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  10 
 
record the sudden change in acceleration after an automobile impact, and post acceleration to 
determine whether the impact was fatal.    
 
3. Real-Time impact detection and Object Discrimination for Pedestrian Protection  
This is currently a project which is in progress by Andrew C. Kim sponsored by the BMW 
automotive group. The project uses several sensors in the bumper of the car to determine impact 
and take impulse measurements. Utilizing the different frequency responses of various objects 
hitting the bumper/sensor and the pressures measure an algorithm is able to compare the data 
from the impact to previously stored calibration data to determine what type of an object it is.  
Real-time impact detection is the primary purpose of the intelligent vest, and it is what is 
necessary determine the types of impact on the vest. This will however require much calibration 
in order to have the right base data to compare impact data with. However, this does seem like a 
simple method for determining different types of impact. Implementing this idea would require 
much calibration to different types of bullets, knives, and other impacts, and then storing the 
impulse data in the microcontroller, and upon impact checking the impulse response of the 
impact to that of those stored to determine exact impact type.     
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  11 
 
 4. Ballistic Impact Detection System - US patent # 7660692: 
Detects vibration with piezoelectric film sensing elements and measures the frequency and 
amplitude characteristics to determine injury. Two sound sensors are also placed on the body to 
“register high-energy acoustic signatures produced by ballistic impacts.” 
 
 5. Ballistic impact sensing and display system - US patent # 4305142: 
This device detects the location of a ballistic impact using sensors arranged in a grid. The sensors 
then pick up on the shock wave generated by the ballistic impact and then the location can be 
calculated depending on the time each of the sensors is activated. 
 
B. Medical Background Research 
 
In order to determine the future medical capabilities of the tactical vest, research was conducted 
on prior art. This research will provide with important features that should be incorporated in the 
product and market value for this product. It would be beneficial to determine which features 
apply to this product. According to EMT guidelines, the most important things to check on a 
victim that has suffered a bullet wound are the air ways and respiration of the victim, and 
checking blood circulation. An examination of prior art shows that most of the portable 
equipment used to measure vitality measures , heart rate, and O2 count, while a minority of these 
devices have plethysmograph capabilities.  
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  12 
 
1. Polar RS100  
The Polar RS100 is a device used for improving physical fitness by monitoring various vital 
signs. Most of these health monitoring tools have a general subset of features, some have 
features that make them stand out from the rest of the market. Some of the more standard 
features found in training monitors include heart rate and HRmax. One of the unique features this 
monitor has, however, is the automatic age-based target zone (bpm / %) which gives an expected 
heart rate of an individual. The measurement of maximum heart rate can be used as a warning 
sign for the observing paramedics and the user.  
 
2. Timex Ironman Race Trainer Heart Rate Monitor  
This heart rate trainer is very similar to the Polar RS100 but has very unique features which 
include the capabilities of measuring the recovery heart rate your heart rate after a strenuous 
activity, during or after your workout. It is also capable of protecting your data from cross talk 
with other heart rate monitors and electronic interference from exercise equipment. It also has a 
water-resistant hatch in heart rate sensor accommodates quick and easy battery changes. The 
most important feature to potentially include in the project would be the cross talk protection, as 
it would reduce the error rate of the actual measurements. Also it would be wise to create a 
product that is easily maintainable.  
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  13 
 
3. Pulse Oximeter LM-800  
There are two main types of oximeters: light sensor oximiters and plate oximiters. The Pulse 
Oximeter LM-800 is of the first type. This type of oximeter is usually placed on the finger and 
measures SpO2 value and pulse rate. This particular oximeter also has an auto shut-off after idle 
for 8 seconds and a low voltage indicator.  
 
4. PDA cortex Life Shirt  
The PDA cortex Life Shirt is a similar type of product that the medical aspect of this project is 
attempting to replicate. Its main purpose is far different from the original vision for this project. 
The Life Shirt is designed to reduce doctor visits of patients under medical trials. The product is 
capable of measuring pulse, blood oxygen, blood pressure, and temperature. The only thing 
differentiating the life shirt from other forms of fitness equipment would be is its capability to 
measure temperature.  It would be wise to incorporate this feature into the vest, because of the 
correlation between loss of blood pressure and temperature. 
 
5. Piezoelectric Film Sensor  
An alternative to PPG sensors or oximeters would be to use piezoelectric film sensors to capture 
arterial wave pulses. The experiment is focused in three directions, the reduction of noise in 
arterial pulse signals, different configurations, and sensitivity of the sensor. The experiment 
results concluded that the pressure of the sensor on the skin does reduce the amount of noise 
measured by the device. This is an important idea to keep in place because if the sensors are 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  14 
 
embedded on the vest they won’t be a vast amount of pressure between the skin and the sensor. 
Another important premise to take from the experiment would be that of the placement of the 
sensors is also proportional to the amount noise the system measures.  
 
6. Cuff-less PPG-Based Blood Pressure Monitor  
Another alternative to piezoelectric film would be to use photoplethysmograph sensors capable 
of measuring arterial pressure, which can be used to measure the uses blood pressure. The 
referenced article goes into great detail on the methodologies used to measure blood pressure in a 
noninvasive manner. The article mentions the use of Oscillometry, and height sensors utilizing 
accelerometers as well as the mathematics involved in the calculation of the resulting blood 
pressure.  
 
7. Interview with Professor Mendelson  
Yitzhak Mendelson is an associate professor at WPI and has a PhD in biomedical engineering 
from Case Western Reserve University.  Professor Mendelson is one of the leading researchers 
in Biosensors, microcomputer-based biomedical instrumentation and noninvasive blood gas 
monitoring. His particular background provides valuable information due to his expertise in the 
biomedical sensor field and is the reason an interview with him was conducted. 
During the meeting with Professor Mendelson, various technologies were discussed that may be 
used to measure important vital signs. He also discussed which vital signs are important when 
one is victim of a gunshot wound. According to the professor, the important vital signs to 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  15 
 
measure are heart rate, blood oxygen count, and blood pressure. However he did state that 
creating a non-invasive method for measuring one’s blood pressure is difficult enough to create 
in a Biomedical Engineering Major Qualifying Project. We also discussed various types of 
oximeters and locations on the body which would be appropriate to measure O2 in areas where 
the vests would cover. Professor Mendelson suggested the use of reflective oximeters which are 
used on foreheads and experiment to see if we can get similar results in the sternum and the 
cervical vertebrae. Lastly the issue of measuring the user’s heart rate was discussed, he suggested 
we modify some of the health monitoring equipment and apply it in our project. Another 
important tip the professor gave was to measure electro cardiogram instead of heart rate as the 
EKG gives more information to the paramedics. 
 
C. Officer Assault Statistics  
In order to see how the vest system could impact the target market, statistics of officers assaulted 
in the line of duty were looked into, specifically instances where a faster response time would 
have helped the officer survive. The major source for this research was the Federal Bureau of 
Investigation's database. The Federal Bureau of Investigation has a large database of statistics 
with regards to officer assaults that may have resulted in injury or death. The statistics are 
divided into the categories of officers that were killed feloniously, officers killed accidentally, 
and officers assaulted. The most recent data is drawn from 2008, with 518 120 officers serving 
226 million people, almost 75% of the population, making for an excellent sample size 
nationally. The database also has data from the year 1999 onward. 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  16 
 
1. Officers Assaulted 
Out of all assaulted officers in 2008, 26.1% were injured. The FBI separates the method of 
assault in the categories of attacks with personal weapons (hands, feet, etc.), knives or cutting 
instruments, firearms, and other dangerous weapons. The highest injury rate is from personal 
weapons at 27.8%, followed by 22.6% from other dangerous weapons, 13.4% from knives or 
cutting instruments, and 8.4% from firearms.  
 
2. Officers Killed Accidentally 
The number of officer deaths in much smaller than the raw number of assaults and are presented 
by the FBI directly instead of as percentages. 68 officers died accidentally in 2008: 
"...39 died as a result of automobile accidents. Thirteen officers were struck by vehicles, 6 
officers died in motorcycle accidents, 2 died in aircraft accidents, and 5 officers died during 
other types of accidents." 
 
3. Officers Feloniously Killed 
Of 41 officers killed feloniously in 2008, 35 were killed by firearms, 2 by bombs, 4 by a vehicle, 
and none by personal weapons, blunt objects or knives and cutting objects. Thirty-six of these 
officers were wearing their vests.  
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  17 
 
Of the 5 officers that had their weapon stolen, only 1 was killed with it. However, the FBI 
reports that 3 officers were killed with their own weapon despite it not being stolen from the 
officer.  
Out of the 36 cases where officers were feloniously killed while wearing their ballistic vests, 
very few deaths were caused by the failure of the vest. The majority of cases consists of the 
officer receiving wounds to the head or neck. Some cases that might be considered vest failure 
are: 
 CA officer shot in the chest by a .223 caliber rifle 
 LA officer shot in between the side panels of the vest by a .40 caliber hand gun 
 PA officer shot in the lower abdomen by a 7.62x39mm rifle 
 PA officer shot in the upper torso repeatedly by a .45 caliber hand gun 
The database, however, contains no specific data on why the vest allowed bullet penetration in 
the above cases. In most of the cases mentioned above, officers were shot somewhere outside the 
area covered by the ballistic vest they wore or were killed by something other than firearms, 
making the vital signs detection of our design quite important in detecting injury to the wearer. 
Impact type detection and penetration are still important for the vest failure cases. 
Many times the officers that were shot were accompanied by others that called for emergency 
help, making our system in these cases redundant. Our system is still important in cases where 
the officer was alone such as: 
 the CA officer shot in the chest by a .223 rifle while he was in pursuit of a suspect on foot 
alone 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  18 
 
 a lone IL officer shot with his own gun while in a struggle with a suspect 
 a LA officer responding to a burglary alone struck by the suspect's truck 
 a LA officer responding to a suspicious person in a strip mall parking lot by herself 
 a NC officer killed during a traffic stop 
 
D. System Concept 
Based on the prior research, a system capable of detecting bullet impacts must be designed. The system 
will need to be able to detect bullet impacts, and determine what type of impact it is. The system also 
needs to be able to store the bullet impact data so that paramedics are able to review impact data. It needs 
to also calculate the location of the bullet impact on the ballistic plate.  
 
Figure III.D.1 – System Concept Diagram 
 
E. Systems Research 
This section deals with the research done on how the entire project could be implemented and the 
components required to do so. First up, the various potential sensors such as load cells, 
Sensors Signal Processing Storage
Localization 
calculations
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  19 
 
accelerometers, and piezoelectrics are discussed, followed by the various requirements of 
components in order for them to fit into the overall system. 
 
1. Load/Force Cells 
A load cell is a transducer that is used to convert force into an electric signal. The conversion is 
indirect and happens in two stages. The strain gauge converts the stress to an electric signal. A 
load cell consists of four strain gauges in a Wheatstone bridge configuration. The electric signal 
is output in a few millivolts which must amplified using an operational amplifier before the 
signal can be used. The signal can be then used by a microcontroller to calculate force or impact.  
There are many different types of load cells available on the market. Unfortunately they have a 
large price tag. One of the cheaper load cells found in the market right now is the Transcell 
Single Beam Cell is $150 dollars which only has a 1000 lb Capacity.  
The Futek FBB300 40 Pound force sensor is a standard load sensor which priced at $90.00 per 
piece. It has a rated output of 2mV/V output. It is 1.25 inches in length, and 0.31 inches wide, 
and is fairly flat. The dimensions of the sensor would make an ideal piece to use as a sensor in 
our detection system. However, the major issue I see with this impact sensor is that it is only 
capable of measuring 40lb of force, and a typical bullet impact results in higher forces.  
When evaluating the need for sensors, we will definitely need a light weight solution. After 
talking to a marine, he has told me that they prefer everything to be light weight, and durable. 
“Marines will find a way to break everything” said Lt. Michael Bailey. The sensors need to be 
very durable because they will need to with stand harsh weather conditions.  
  
Load sen
practical 
consume
load, as w
 
2. Single
Accelero
accelerom
 Capa
capac
 Piezo
 Piezo
 Magn
 Heat 
 
sors do seem
choice. Loa
r. Load sen
e would ne
/dual Axis A
meters are a
eters availa
citive: Met
itance relate
electric: Cry
resistive: m
etoresistive
Transfer: Lo
F
 [2011]   [IN
 like a viab
d sensors ha
sors do not 
ed at reason
ccelerome
 simple wa
ble: 
al beam or
d to acceler
stals mount
icro machin
: Material re
cation of he
igure III.E.2
TELLIGENT 
Worcester P
le solution t
ve a hefty p
necessarily 
able cost.  
ters  
y to measur
 Micro ma
ation  
ed to mass v
ed whose re
sistivity cha
ated mass tr
.1 – Texas I
TACTICAL V
olytechnic In
o meet our 
rice tag whi
seem to be
e acceleratio
chined feat
oltage outp
sistance cha
nges in pres
acked durin
 
 
 
 
nstruments 
EST] 
stitute | III. B
goals; howe
ch will sign
 capable of 
n. There ar
ure produc
ut converted
nges with ac
ence of mag
g accelerati
Cost vs. Per
ackground R
ver they do 
ificantly rai
measuring 
e multiple d
es capacita
 to accelera
celeration 
netic field. 
on by sensin
formance 
esearch  20
not seem lik
se the end co
high amoun
ifferent typ
nce; change
tion 
 
g temperatu
 
e the 
st to 
ts of 
es of 
s in 
re 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  21 
 
The figure above from Texas instruments shows a good balance between cost and performance 
which amounts to accuracy is the Surface MM Capacitive sensors. The accelerometer measures 
the force of gravity in g’s. Based on the orientation measurement can be affected, If the 
accelerometer is oriented in a vertical position it will always read at 1g because of gravity’s pull 
on it.   
Accelerometer sensitivity will be important in measuring our bullet impact. Sensitivity of an 
accelerometer is a measure of how much the output of a sensor changes as the input acceleration 
changes. It is measured in Volts/g.  
ܵ݁݊ݏ݅ݐ݅ݒ݅ݐݕ ൌ 	∆ ௢ܸ௨௧∆݃ ൌ 	
௢ܸ௨௧,ାଵ௚	–	 ௢ܸ௨௧,ିଵ௚
2݃  
Rigid mounting is important, utilizing bolts, or double sided tape. During setup loose wires can 
cause false signals, so it’s important secure wires away from the accelerometer to the mounting 
body. Weight of the sensor should be approximately an order of magnitude less than the object 
being measured. A 1 degree tilt in the 0g mounting position creates an output error equivalent to 
a 10 degree tilt in the +1g or -1g positions. 0g is the most sensitive to mounting errors.  
There are several accelerometer applications such as measuring tilt/roll, vibration, vehicle skid 
detection, impact detection, and feedback for active suspension control systems.  
Type IIA armor protects against 8g 9x19mm Parabellum full metal jacket round nose bullets at a 
velocity of 373 m/s +/- 9.1 m/s, and targets struck by such bullets experience about fifty g’s. The 
accelerometer therefore needs to be capable of measuring at least fifty g’s if the design is to meet 
Type IIA expectations.  
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  22 
 
Accelerometers are a practical and affordable option for sensors which can potentially be used as 
a solution to our problem.  
  
3. Piezoelectric Sensors Viability 
The utilization of a piezoelectric sensor to measure velocity, force and localization seem to be 
the most versatile of any sensor we have contemplated with the only major issue brought up in 
any brainstorming session is the actual maximum resolution the piezoelectric sensor could 
actually identify. 
 It is important to know the physical capabilities of a sensor before it’s implemented in a design. 
For this particular application the only important features are the frequency range, maximum 
voltage, the relationship between voltage and size of the sensor and its mechanical strength and 
impact resistance. According to the Measurement Specialties Inc. technical manual on 
piezoelectric film it has a: 
• Wide frequency range—0.001 Hz to 10GHz. 
• Low acoustic impedance—close match to water, human tissue and adhesive systems. 
• High voltage output—10 times higher than piezoelectric ceramics for the same force input. 
• High mechanical strength and impact resistance (10^9—10^10 Pascal modulus). 
• Can be fabricated into unusual designs. 
• Can be glued with commercial adhesives. 
A major concern when discussing what type of sensors to use, is if the sensor will be capable 
(high enough resolution) of measuring at the short time interval of an actual bullet impact. 
According to the Measurement Specialties Piezo Film Sensors Technical Manual the lower the 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  23 
 
thickness of the piezoelectric film the higher resolution we are capable of measuring and since a 
28um thick film sensor typically has a 40MHz basic half wave resonance, film of similar 
thickness would be adequate. 
According to the same manual, piezoelectric cables are also used in a variety of applications like 
weigh in motion systems used for truck inspection and taxiway sensors for aircraft 
identification.  This cable is interesting because the force that creates the electrical energy is 
applied in a longitudinal stress. 
 
4. Sensor choices 
The sensor which will fit best for the application is the piezoelectric film. Piezoelectric film is typically 
resistant to impact, and would make the best choice for an impact detection application. The sensors are 
responsive to any form of deflection, especially at high speeds, and plate will encounter high amounts of 
deflection during impact. The piezoelectric film is also simple to mount onto the steel plate and can be 
easily moved to any location on it. The choice of using piezoelectric film is also a cost effective choice, as 
it is cheaper than accelerometers which were the secondary choice.   
 
4. Gain Stage Expected Specs 
  
In order to purchase appropriate components, approximations of the voltages produced by our 
sensors when bullets impact the plate of our system were needed. The only way to make sure 
components will satisfy the real world requirements based off of theoretical calculations is to 
assume the worst case scenario when testing the system. For starters, several arrangements were 
considered for the test plate in our most recent meeting, including placing the plate and sensors 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  24 
 
against a spring system, a human analog, or a close to immobile surface. Since the spring system 
and the human analog will have some give when the bullet strikes and will prolong the time 
period our system will be recording over, we will assume the test setup where the plate is up 
against a solid surface because this will produce the greatest slope of voltage over time from our 
highest voltage sensor, the piezoelectric strips. 
  
To find an actual slew rate requirement, the time period the bullet exerts force on the sensors is 
also needed. For this, several assumptions are made in order to simulate a worst case scenario. 
First, it is assumed that the bullet will travel through a vacuum for maximum possible velocity, 
and that no friction occurs between any of the components so that the only forces opposing the 
bullet are the material's strength and the normal force of the test set-up. It is also assumed that 
the bullet will stop and expend its energy before passing by the sensors, which will result in the 
biggest spike in output voltage. Next, it is assumed that the bullet striking the plate is the highest 
caliber and velocity bullet used against a police officer out of the recorded statistics in the 
background research, the Remington .223 caliber round, traveling at its highest recorded speed of 
1140 m/s at 1524 J of kinetic energy. Finally, It is assumed the sensor used to record the force of 
impact is our selected piezoelectric device, Measurement Specialties' LDT0-028K series.  
Calculations are begun with finding out the speed of the setup in a vacuum after being hit by the 
bullet using the conservation of energy equation with the assumption that the test set-up will 
weigh 80kg: 
1
2݉ݒ
ଶ ൌ 	12݉ݒ
ଶ 
1524ܬ ൌ 	12 ∗ 80 ∗ ݒ
ଶ	
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  25 
 
ݒ ൌ 6.1725	݉/ݏ 
Using this information and the fact that the test plate is 6mm in width, the two remaining 
unknowns, the acceleration felt by the sensors and the time interval they accelerate for, can be 
found from the following kinematics equations: 
௙ܸ ൌ 	 ௜ܸ ൅ 	ܽݐ	
6.1725 ൌ 0 ൅ ܽݐ	
݀ ൌ ௜ܸݐ ൅	12 ܽݐ
ଶ	
0.006 ൌ 0 ൅ 12ܽݐ
ଶ	
 
Using substitution: 
ܽ ൌ 6.1725ݐ 	
0.006 ൌ 12 ∗ 6.172ݐ	
ݐ ൌ 1.944	݉ݏ	
ܽ ൌ 3174.98	݉/ݏଶ 
 Using these two values, the gain stage operational amplifier slew rate spec can be calculated: 
 Slew rate minimum = 25V/1.944ms = 12.86 mV/us 
 
5. FPGA System Requirements 
Clock speed is a critical factor for this FPGA application. Bullet impact detection is a time 
sensitive application and requires a high system clock speed. The bullet impact will be near 
instantaneous and the system will have to be able to respond/capture the data during that time. 
  
Unless, i
capable o
The table
The cloc
velocities
than duri
 U
th
th
th
 
 U
th
t is possible
f reading th
 below lists
k speed will
 unless the 
ng the impa
sing the spe
e bullet trav
e test plates
e bullet wil
sing the spe
e bullet trav
 [2011]   [IN
 to sample 
e data from 
 the velocitie
Table 
 have to be
senor is one
ct.  
ed for slowe
els at 900 ft
 are .6” thic
l travel throu
ed for a AK
els at 2300f
TELLIGENT 
Worcester P
at a high r
the sensor. 
s of a 9mm
III.E.5.1 – 9
 high enoug
 that record
r 9mm pisto
/sec  
k  
gh the plate
-47 (standar
t/sec  
TACTICAL V
olytechnic In
ate on the s
 parabellum
mm Parabel
h to detect a
s that an imp
ls (best cas
 in 55.56 m
d 7.62x39m
EST] 
stitute | III. B
ensor end, 
 bullet: 
lum Ballisti
 bullet imp
act has occ
e scenario): 
icroseconds
m):  
ackground R
and hold un
 
cs 
acting the s
urred after t
 
  
esearch  26
til the syste
ensor at the
he impact, r
 
m is 
 high 
ather 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | III. Background Research  27 
 
the test plates are .6” thick  
the bullet will travel through the plate in 21.74 microseconds 
  
 Using the speed for a Barrett M82A2 (standard 12.7x99mm):  
the bullet travels at 3000ft/sec  
the test plates are .6” thick  
the bullet will travel through the plate in 16.67 microseconds  
This means that all of the data needs to be captured within 16.67-55.56 microseconds. Using 
high speed parallel analog to digital converters will aid in gathering a strong sample set of the 
impact. The Analog Devices (ADI) AR9220, the ADC chosen for this project, is a 10 MHz (10 
MSPS) ADC which has a 12 bit digital output.   
 
F. Basic System Block Diagram 
The original overall system design is shown on the next page as Image III.F.1. The sensors 
chosen were the piezoelectric film, and the signals being output from them will pass through a 
fractional gain stage which will reduce the signal down to the input range of the analog to digital 
converter. Each sensor has its own gain stage because multiplexing them into one ADC would 
require a higher sample rate. The analog to digital converters will sample the signal and pass the 
data along to the FPGA which will be responsible for writing the data to RAM, and then 
transmitting the data to a PC for post processing. The PC will process the data, and localize the 
impact.  
  
 [2011]   [IN
Ima
TELLIGENT 
Worcester P
ge III.F.1 –
TACTICAL V
olytechnic In
System Blo
EST] 
stitute | III. B
ck Diagram
ackground Research  28 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  29 
 
IV. System Components 
The overall system design consists of several components such as the physical test stand, the 
FPGA logic controller, the custom designed add-on board, and triangulation calculations. These 
components work together to perform complete system functionality.  
 
A. Plate Test Stand 
In order to test the basic capabilities of the system, a prototype holder was designed. This holder 
needed to be able to hold a ballistic plate and its attached sensors in place while it was shot, and 
needed to last through repeated tests. Inspiration for this holder was drawn for various 
commercially available pistol targets.  
Since the plate is 8in or 20.3cm in both height and width, .6cm in thickness, and slightly angled 
in the center (shown in Image IV.A.1), the frame of the holder had to be at least its height, with 
an added thickness for the top section that would hold the plate from sliding out (shown in Image 
IV.A.2). The frame sits on a base plate that ensures stability and the falling mechanism was 
implemented with a simple hinge, but the system needed to be reset manually.  
  
  
        Ima
   
Since the
Image IV
slot. Bec
vibrating
plate, the
the plate
inwards t
ge IV.A.1 - 
 ends of th
.A.3), the fr
ause bendin
, a non-angl
 frame's wid
 stays put, 
owards the 
 [2011]   [IN
Ballistic Pla
e ballistic p
ame itself w
g the fram
ed configur
th W was c
and the 18.
center of the
TELLIGENT 
Worcester P
te Dimensio
late used a
ould either
e to fit the 
ation such a
hosen as 3c
85mm thick
 plate from 
TACTICAL V
olytechnic In
ns               
re always a
 needed to b
plate would
s that show
m in order 
ness T was
its outermos
EST] 
stitute | IV. 
     Image IV
t an angle t
e angled w
 restrict th
n in Image 
to provide a
 measured u
t edge.   
System Comp
.A.2 - Plate
o a flat sur
ith the plate
e plate from
1.3 was use
 deep enou
sing a Ver
onents  30
 Stand 
face (angle 
 or have a w
 deflecting
d. For our 
gh slot to en
nier caliper
 
 
X in 
ider 
 and 
6mm 
sure 
 3cm 
  
  
 
Originall
compone
hinges to
serving a
dimensio
I
y, the proto
nts were at
 a 14in. wid
s the base o
ns of the ho
 [2011]   [IN
mage IV.A
type of the
tached usin
e and 3/4in
f the system
lder and the
TELLIGENT 
Worcester P
.3 - Wood F
 plate hold
g wood scr
. thick plan
. The plan
 effects of th
TACTICAL V
olytechnic In
rame Specif
er shown i
ews and na
k cut to fit t
k itself was
e test on the
EST] 
stitute | IV. 
ications (To
n Image IV
ils. At the 
he length o
 attached to
m are expla
System Comp
p View) 
.A.4 below
time, it wa
f the bin ho
 the bin us
ined below 
onents  31
 was tested
s attached u
lding the ce
ing J-hooks
the image.
 
 
. Its 
sing 
ment 
. The 
  
A - This 
back of t
struck by
possibly 
straight b
B - Thes
by 3/8 in
plate's 8 
from shra
piece is a 9
he holder. T
 the bullet. 
confirming 
eforehand a
e couple of 
. rabbit cut 
in. width sn
pnel impact
 [2011]   [IN
 and 3/4 in. 
his piece i
After the te
the suspicio
s this was n
pieces are 1
out of one 
ugly betwee
 by plates o
TELLIGENT 
Worcester P
Image IV.A
wide, 10 in
s also suspe
st, this back
n. However
ot tested. 
0 in. tall pil
of the corne
n these piec
f metal attac
TACTICAL V
olytechnic In
.4 – Plate H
. tall, and 3/
cted of abso
 piece was 
, we cannot 
lars with a b
rs along the
es and the b
hed besides
EST] 
stitute | IV. 
older 
4 in. thick p
rbing a lot 
slightly ben
know for su
ase of 1.5 i
 height of e
ack plank. 
 the rabbits 
System Comp
iece of wo
of energy w
t outward t
re if the pie
n by 1.5 in
ach pillar i
These piece
facing inwa
onents  32
od serving a
hen the pla
owards the 
ce was perf
. with a 11/1
n order to f
s were prot
rds. 
 
 
s the 
te is 
back, 
ectly 
6 in. 
it the 
ected 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  33 
 
C - This piece is a 9 and 3/4 in by 2 and 3/4 in piece of wood serving as a base for the plate to 
rest on and as an attachment point for the hinges. The piece used in the test was 3/4 in. thick, 
although this particular value is not important to the functionality of the system and can be 
adjusted in future versions. 
The main failures of the holder occurred between the vertical pieces and the back plank, around 
the edges of the holder struck by fragments, and in the hinges. Three more holders were made in 
which these issues were addressed in the following ways: since pieces B came loose from the 
back plank, the nails present were replaced with screws and the pieces were also glues together; 
to prevent shrapnel from eventually digging clean through the wood of piece C, metal plates 
such as those on pieces B were added; stronger hinges were used in order to avoid them failing 
after repeated use. 
 
B. Piezoelectric Testing 
 
With the new plate holders finished, the testing of the piezoelectric sensors could begin. Before 
this test, it was now known if these sensors would work for this application at all, and if they did, 
what sort of voltage output would be generated. The test was performed on the ballistic plate in 
one of the new plate holders and a hammer as the source of impact. A single piezoelectric sensor 
was attached flat to the center of the back of the plate using adhesive tape, and several blows 
from the hammer were delivered over the center of the opposite side while the sensor output was 
recorded on an oscilloscope. The best result of the series is shown below in Image IV.B.1.  
  
From the
similar t
voltages,
of impac
se results, w
o the gener
 periods, an
t, making pi
 [2011]   [IN
Image IV
e can assu
alized wave
d arrival tim
ezoelectric s
TELLIGENT 
Worcester P
.B.1 – Oscil
me that the
form shown
es of vario
ensors the b
TACTICAL V
olytechnic In
loscope Sen
 output from
 in Image 
us sensors, 
est choice f
EST] 
stitute | IV. 
sor Measure
 the sensor
IV.B.2 belo
we can theo
or use in the
System Comp
ment 
s will usua
w. From th
retically ex
 project. 
onents  34
 
lly be some
e multiple 
tract the loc
 
thing 
peak 
ation 
  
 
C. Analo
In order t
needed s
subsystem
outputtin
gate array
For this 
piezoelec
be versat
g Applicati
o create a sy
o that the v
 settled on
g to one AD
 that would
particular d
tric film and
ile and sim
 [2011]   [IN
Imag
on Schema
stem capab
est can hand
 was made u
C per sens
 handle the 
esign there
 an electrol
ple enough 
TELLIGENT 
Worcester P
e P.H.2 – G
tic 
le of utilizin
le varying 
p of gain st
or, which w
storing of da
 are two di
ytic microph
to accomm
TACTICAL V
olytechnic In
eneralized S
g different f
voltage sign
ages taking 
ould in turn
ta. 
fferent inpu
one. With t
odate differ
EST] 
stitute | IV. 
ensor Outpu
orms of inp
als from dif
input from t
 output sign
t methods 
his in mind,
ent input sig
System Comp
t 
ut sensors, a
ferent types
he ballistic 
als to a fie
that this sy
 the analog 
nals. To ac
onents  35
 sub-system
 of sensors
plate sensor
ld programm
stem can u
subsection h
complish th
 
 
 was 
. The 
s and 
able 
se: a 
as to 
is, a 
  
simple n
However
Under ne
positive 
configura
typical gr
All op-am
input sig
(5mV-8m
offset of 
This resp
signal, th
on-inverting
 the use of a
gative feedb
input volta
tion, the vir
ound refere
Image IV
ps have so
nal. The off
V). With th
+/- (.125-.2V
onse is con
e observed o
 [2011]   [IN
 amplifier 
n op-amp w
ack configu
ge. Given 
tual referen
nce seen wit
.C.1 – Non-
me sort of i
set voltage 
is offset one
) due to the
firmed from
utput shoul
TELLIGENT 
Worcester P
is used for
ith a single 
ration, an o
that the 
ce voltage i
h dual supp
inverting Am
nput offset 
range detai
 should exp
 gain of the
 the simul
d behave in 
TACTICAL V
olytechnic In
 its adaptab
source has i
p-amp force
system des
s now equal
ly configura
plifier Wit
 
voltage; this
led in the L
ect the outp
 system.  
ations which
the manner 
EST] 
stitute | IV. 
ility and m
ts complicat
s the negati
ign utilizes
 to half of t
tion. 
h a Vcc/2 R
 voltage ca
M6152 dat
ut voltage t
 yielded si
shown in th
System Comp
inimalistic
ions. 
ve input vol
 a single 
he rail volta
 
eference Vo
n either add
a sheet is a
o respond by
milar result
e equations 
onents  36
 design pro
tage to equa
supply op
ge instead o
ltage 
 or detract t
pproximatel
 adding an 
s. With a 5
below:  
 
cess. 
l the 
-amp 
f the 
o the 
y +/- 
extra 
0mV 
  
Ima
D. ADC 
The ADC
analog to
internal 
instructio
order to h
ge IV.C.2 -
Schematic 
 will opera
 digital con
reference ca
ns provided
ave a input 
 [2011]   [IN
Vo
 Simulation 
te in a singl
verters wil
pabilities o
 in the data
range of 0 t
TELLIGENT 
Worcester P
 = (Vin+Vo
Vo = (50m
Vo = 1.25s
Vo = 1.2
of a Single 
e ended inp
l operate at
f the ADC
 sheet. Ref
o 5V, the SE
TACTICAL V
olytechnic In
s)*(R3/R4+
v+5mv)*(25
in (wt) +.12
5sin (wt) +2
Source Op-A
 
ut with a 0 t
 0 to 5V, w
, and the p
ering to pag
NSE pin m
EST] 
stitute | IV. 
1) + Vref 
) + 2.5 
5+2.5 
.625 
mp With a
o 2xVref ra
hich is ma
in configur
e 19, and f
ust be short
System Comp
 2.5 Referen
nge. For th
x AVDD. I
ation will b
igure 21, w
ed to the RE
onents  37
 
ce Voltage
is applicatio
t will utiliz
e based on
e can see th
FCOM pin.
 
n the 
e the 
 the 
at in 
 Vref 
  
and VINB
capacitor
internal 
decouple
digital an
source.  
The digit
the clock
3, leaving
 must be b
.  Regardle
circuitry wi
 these pins 
d analog vo
al output of
 input pin. P
 only 2 pin
 [2011]   [IN
ypassed to t
ss of using 
ll appear ac
with their s
ltage rail wi
 the ADC w
in 1:12 will
s on the FX2
Fig
TELLIGENT 
Worcester P
he REFCOM
external, or
ross CAPT
uggested de
ll both be 5V
ill be tied t
 be for ADC
 connector.
ure IV.D.1 A
TACTICAL V
olytechnic In
 pin with a
 internal ref
 and CAPB
coupling ne
, therefore
o the male 
 1, Pin 13:1
 
DC Circuit
EST] 
stitute | IV. 
 10 uf capac
erence, the 
 pins, and 
twork as ca
 AVDD, and
end of the F
5 for ADC 2
 Schematic
System Comp
itor in parra
actual volta
therefore it
n be seen i
 DVDD are
X2 connect
, and 26:38
 
onents  38
lel with a 0
ges used b
 is necessa
n figure 10
 tied to the 
or. Pin 0 w
 will be for 
 
.1 uF 
y the 
ry to 
. The 
same 
ill be 
ADC 
  
E. Logic
The logic
Core, the
from the 
the system
provide a
the state 
The abov
below 
 System Lev
 design for 
 Memory I
three ADCs
 clock. It p
 10 MHZ cl
of the mach
e system is
 [2011]   [IN
el Impleme
this entire s
nterface, an
, a transmit
rovides the 
ock. There 
ine. The sys
Image IV
 composed 
TELLIGENT 
Worcester P
ntation 
ystem is bro
d the Data 
 switch, a re
required sig
are also sev
tem I/O requ
.E.1 - Implem
of several s
TACTICAL V
olytechnic In
ken up into
Input contro
set button, 
nals to oper
eral signals 
irements ar
entation Lev
 
maller comp
EST] 
stitute | IV. 
 three crucia
ller. The o
Receive pin
ate the mem
which are co
e seen in the
 
el System Sy
onents whi
System Comp
l componen
verall syste
 on the seria
ory, transm
nnected to 
 figure belo
mbol 
ch can be s
onents  39
ts: the Pico
m requires 
l connected
it serial data
LEDs to ob
w. 
een in the f
 
blaze 
input 
, and 
, and 
serve 
igure 
  
The data
the inten
interface 
that task 
give cont
The pico
Therefor
interface 
 
input contro
ded system
while the sy
is complete
rol of the m
blaze will n
e, both the 
without inte
 [2011]   [IN
Image IV.E
ller and the
 functionali
stem is trig
 it will rest
emory inte
ot take con
Picoblaze an
rference fro
TELLIGENT 
Worcester P
.2 - Impleme
 picoblaze c
ty the Data
gered and u
ore control 
rface to the 
trol back u
d Data inp
m the other 
TACTICAL V
olytechnic In
 
ntation Leve
 
ore act as c
 input contr
ntil the desi
to the picob
data input c
nless the d
ut controller
component.
EST] 
stitute | IV. 
l System Sch
ontrollers fo
oller will h
red data has
laze. The m
ontroller un
ata input co
 will be all
 
System Comp
ematic 
r the memo
ave control
 been writte
ultiplexer i
less the pic
ntroller is 
owed to uti
onents  40
ry interface
 of the me
n to RAM. 
s not allow
oblaze allow
in its hold 
lize the me
 
. For 
mory 
Once 
ed to 
s it. 
state. 
mory 
  
1. Simula
The abov
Once the
to RAM 
the data 
the syste
addresses
  
F. Async
The mem
responsib
tion and Te
e simulatio
 system trig
while outpu
input contro
m is capabl
 while adhe
hronous M
ory interfa
le for perfo
 [2011]   [IN
sting 
Image
n shows tha
gers the me
tting data fr
ller has con
e of writing
ring to the t
emory Inte
ce controll
rming async
TELLIGENT 
Worcester P
 IV.E.1.1 - In
t the memo
mory interf
om the FIFO
trol of the m
 the data b
iming requir
rface Contr
er is a cru
hronous rea
TACTICAL V
olytechnic In
tegration Le
ry interface
ace begins a
 buffer and
emory inte
eing input 
ements of th
oller 
cial part o
ds and write
EST] 
stitute | IV. 
vel Simulatio
 is sitting id
sserting the
 incrementi
rface. The a
from the AD
e RAM. 
f the entire
s from the o
System Comp
n 
le until the
 appropriate
ng the addr
bove simula
Cs to RAM
 design. T
n board Mi
onents  41
 system trig
 signals to 
ess. At this 
tion assure
 at approp
he controll
cron SRAM
 
gers. 
write 
point 
s that 
riate 
er is 
. The 
  
controlle
mind, an
 
1. The Co
The cont
device. T
simple c
combinat
sram_rea
properly.
need to b
r is specific
d can be adj
Imag
ntrol Logic
roller has se
he controlle
ontrol logi
ional logic 
d, sram_wr
 An address
e valid only
 [2011]   [IN
ally designe
usted to be u
e IV.F.1 - M
 
veral inputs
r is designe
c which al
capable of 
ite, 23-bit 
 must be pro
 when a SR
TELLIGENT 
Worcester P
d with the ti
se with othe
emory Inte
 and output
d to operate
lows it to 
providing th
address, an
vided at all
AM write o
TACTICAL V
olytechnic In
ming constr
r memory d
rface Contr
s which are
 on a fifty m
interface t
e appropria
d 16 bit d
 times when
peration is 
EST] 
stitute | IV. 
aints of the
evices whic
 
oller Schem
 crucial to t
egahertz cl
o a proce
te signals. 
ata output 
 performing
being perfo
System Comp
 Micron SR
h use a simi
atic Symbol
he operatio
ock input. T
ssor core, 
The device 
signals in 
 a read or w
rmed. Asser
onents  42
AM control
lar interface
 
n of the me
he controlle
or any kin
requires a 
order to op
rite. Data o
ting ‘sram_
 
ler in 
.  
mory 
r has 
d of 
reset, 
erate 
utput 
read’ 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  43 
 
to logic high will generate data on the ‘data_in’ bus from the address provided. The truth table 
below highlights the control signals, and the combinations in which they must be asserted. 
 
Operation Control Signals 
 Clock Reset Sram_read Sram_write Address Data_out 
Reset XX 1 X X XXXX XXXX 
Read 50 Mhz  0 1 0 23 Bit valid XXXX 
Write 50 Mhz 0 0 1 23 Bit valid 16 Bit valid 
 
Table IV.F.1.1 – Control Logic 
 
2. The State-machine 
The memory controller is designed as simple state machine which has several states for each 
operation. Since the memory controller was designed with the Micron memory controller in 
mind, each operation consists of five states, and the controller expects a clock input of 50 
Megahertz. Therefore each state lasts 20 nanoseconds and each read or write cycle lasts for 100 
nanoseconds, well beyond the required threshold of an asynchronous read/write. The following 
state diagram highlights the states which the machine traverses through to perform a read or 
write.  
  
The follo
State 
RamCS 
FlashCS 
MemW
R 
MemOE 
RamUB 
RamLB 
RamCR
E 
wing table s
WS
4 
W
0 0 
1 1 
1 0 
1 1 
0 0 
0 0 
1 1 
 [2011]   [IN
Image IV.
hows the co
S3 WS2 
0 
1 
0 
1 
0 
0 
1 
TELLIGENT 
Worcester P
F.2.1 - Mem
rresponding
WS1 W
0 0
1 1
0 1
1 1
0 0
0 0
1 1
TACTICAL V
olytechnic In
ory Control
 signals whi
S Stand
y 
 1 
 1 
 1 
 1 
 1 
 1 
 1 
EST] 
stitute | IV. 
ler State Ma
ch are asser
b RS R
0 0
1 1
1 1
0 0
0 0
0 0
1 1
System Comp
chine 
ted in each 
S1 RS2 
 0 
 1 
 1 
 0 
 0 
 0 
 1 
onents  44
state.  
RS3 
0 
1 
1 
0 
0 
0 
1 
 
 
RS4 
0 
1 
1 
0 
0 
0 
1 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  45 
 
RamAdv 0 0 0 0 0 1 0 0 0 0 0 
RamClk 0 0 0 0 0 1 0 0 0 0 0 
DataIn XX XX XX XX XX XX XX XX MemD
B 
XX XX 
MemAd
dr 
Vali
d 
Valid Valid Valid Vali
d 
XX Vali
d 
Vali
d 
Valid Vali
d 
Vali
d 
MemDB XX Outp
ut 
Outp
ut 
Outp
ut 
XX XX XX RA
M 
RAM RA
M 
RA
M 
 
Table IV.F.2.1 - Memory Controller State Output Table 
 
During the write cycle, the chip select, Ram upper/lower byte, Ram ADV, and clock signals are 
asserted low first, then 20 nanoseconds later the Memory Write signal is asserted low. And stays 
low for 60 nanoseconds after which it is asserted high, and the data on the memory data bus is 
latched by the memory device. The write cycle finishes when the chip select signal is asserted 
high. The read cycle is a simpler implementation because all of the signals are asserted low 
simultaneously along with the Memory Output Enable and then data is read in after the data on 
the memory data bus is valid. The time for the data to become valid is 20 nanoseconds, but to 
assure that the data is valid the controller waits 40 nanoseconds.  
 
  
3. Simula
The Mem
order to t
combinat
input. It 
compone
following
The abov
sheet, the
read cycl
RAM da
because 
requested
tion and On
ory interfa
est the cont
ional circuit
also takes i
nts a VHDL
 simulation
e test benc
refore it can
e will funct
ta sheet. In 
the simulato
 using the s
 [2011]   [IN
-board Func
ce controlle
roller, a sim
 takes in an
n the outpu
 test bench
 shows the s
Imag
h is similar
 be conclud
ion correctl
this test ben
r is not ne
ignals.  
TELLIGENT 
Worcester P
tionality Te
r was tested
ple combina
 8-bit input 
t from the 
 was create
ignals for a 
e IV.F.3.1 -
 to the test 
ed that whe
y. The figur
ch simulatio
cessarily ca
TACTICAL V
olytechnic In
sting 
 independen
tional logic
and converts
RAM and 
d (See App
read cycle. 
 
 Read Cycle
bench that 
n the signa
e below sh
n the mem
pable of o
EST] 
stitute | IV. 
t from the 
 parent cont
 it into a 23
converts to 
endix A-1 
 Test Bench
can be foun
ls are assert
ows the test
ory data bus
utputting si
System Comp
remainder o
roller was im
 bit address
a 3 bit out
for Test Be
 
d in the M
ed to the ph
 bench foun
 is in high 
mulated “R
onents  46
f the system
plemented
 and a 16 bit
put. Using 
nch Code)
icron RAM
ysical devic
d in the M
impedance m
AM data” 
 
. In 
. The 
 data 
these 
. The 
 data 
e the 
icron 
ode 
when 
  
The follo
figure sh
wing test be
ows the writ
 [2011]   [IN
Image IV
nch shows t
e cycle from
Imag
TELLIGENT 
Worcester P
.F.3.2 - Rea
he write cyc
 the data sh
e IV.F.3.3 -
TACTICAL V
olytechnic In
d Cycle for 
le for the m
eet.  
 
 Write Cycle
EST] 
stitute | IV. 
the Micron R
emory cont
 Test Bench
System Comp
AM 
roller, and th
 
onents  47
 
e correspon
 
ding 
  
During th
then retu
similar to
Enable si
The write
then retu
until the 
The next
compone
switches)
were use
read, and
e write cyc
rns the data
 the test be
gnal must b
 and read c
rns low beca
next clock c
 step in the p
nts were m
 on the boa
d to generat
 reset respec
 [2011]   [IN
le it can be 
 bus to a h
nch from th
e asserted hi
Image IV
ycles do not
use the mac
ycle.  
rocess was 
apped and r
rd were use
e data to be
tively. Pres
TELLIGENT 
Worcester P
observed th
igh impedan
e data shee
gh before ch
.F.3.4 - Writ
 actually be
hine is in th
to test the p
outed to the
d to generat
 written to m
sing the butt
TACTICAL V
olytechnic In
at data is be
ce state. T
t. The data 
ip enable is
e Cycle for 
gin until sra
e standby s
hysical func
 FPGA. Th
e an address
emory. Th
on would be
EST] 
stitute | IV. 
ing placed o
he write cy
sheet fails 
 asserted hi
the Micron 
m_read/ sra
tate and doe
tionality of 
e high 4 bi
; the lower 
e first three 
gin the read
System Comp
n the memo
cle in the te
to show tha
gh.  
RAM 
m_write is a
s not switch
the memory
ts of the sw
four bits (la
buttons wer
 or write cy
onents  48
ry data bus
st bench is 
t Memory W
 
sserted high
 to the next
 device. Th
itches (first
st four swit
e used for w
cle. This me
 
, and 
very 
rite 
 and 
 state 
e test 
 four 
ches) 
rite, 
thod 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  49 
 
seemed to provide greatest control, and allowed time to setup the address and data. The 
following sequence of actions was used to test the RAM, and conclude that the controller is 
functional.  
1. Set address switches to 1h, generating address 000010h 
2. Set data switches to Ah, generating 000Ah.  
3. Press write button 
4. Set address switches to 2h, generating address 000020h 
5. Set data switches to Fh, generating 000Fh 
6. Press write button 
7. Set address switches to Fh, generating address 0000F0h 
8. Set data switches to Eh, generating 000Eh 
9. Press write button 
10. Set address switches to 1h, generating address 000010h 
11. Press read button 
12. Observe LEDs and match up LED pattern to Ah 
13. Set address switches to 2h, generating address 000020h 
14. Press read button 
15. Observe LEDs and match up LED pattern to Fh 
16. Set address switches to Fh, generating address 0000F0h 
17. Press read button 
18. Observe LEDs and match up LED pattern to Eh 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  50 
 
The above sequence of tests proved conclusive because the data which was written to the 
addresses were read back and output on the LEDs. The tests all concluded that the memory 
device, as well as the controller is functional on the board.  
 
4. PicoBlaze Embedded Core 
The PicoBlaze is an 8-bit embedded microcontroller core for any FPGA which uses a minimal 
amount of logic cores. The PicoBlaze package consists of the core and UART controllers. There 
was no actual design work done on the core or the UART controllers and were implemented as 
is. All credit for the PicoBlaze design is attributed to the respective designers. The PicoBlaze is 
being used to control the memory interface and UART interface to read and transmit data to a PC 
from the on-board Micron RAM. The design work which was needed however was the port 
multiplexer which interfaces all of the components to function with the core. The following 
schematic shows the PicoBlaze and its interface to the remaining components.  
  
 
5. I/O Po
The I/O 
multiple 
compone
rt 
port is a c
components
nt acts as a 
 [2011]   [IN
Imag
rucial comp
 with three
specialized m
TELLIGENT 
Worcester P
e IV.F.4.1 -
onent becau
 signals: po
ultiplexer. 
TACTICAL V
olytechnic In
 PicoBlaze C
se it allow
rt_id, read_
 
EST] 
stitute | IV. 
ore System
s the PicoB
strobe, and
System Comp
 
laze archite
 write_strob
onents  51
cture to co
e. The I/O
 
ntrol 
 port 
 
  
Due to th
takes the
read the 
I/O port. 
PO
01h
02h
03h
04h
05h
e lack of I/
 port ID and
values on th
 
RT_ID WR
 1 
 1 
 1 
 1 
 1 
 [2011]   [IN
Imag
O ports foun
 the strobe 
e port. The 
ITE_STRO
TELLIGENT 
Worcester P
e IV.F.5.1 -
d on the em
signals to d
following t
BE READ
0 
0 
0 
0 
0 
TACTICAL V
olytechnic In
 I/O Port sy
 
bedded cor
etermine wh
able shows 
_STROBE
EST] 
stitute | IV. 
stem symbo
e, this comp
ether to lat
the port map
PORT 
Address(7
Address(
Address(2
Data Out 
Data Out(
System Comp
 
l 
onent had t
ch the data 
ping used 
 : 0) 
15 : 8) 
3 : 16) 
(7 : 0) 
15 : 8) 
onents  52
o be design
onto the po
to implemen
 
ed. It 
rt, or 
t the 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  53 
 
04h 0 1 Data In (7 : 0) 
05h 0 1 Data In (15 : 8) 
06h 1 0 UART TX(7 : 0)  
0Ch 0 1 UART RX(7 : 0) 
09h 0 1 Trig_Address(7 :0) 
0Ah 0 1 Trig_Address(15:8) 
0Bh 0 1 Trig_Address(23:16) 
10h 0 1 Sram_read 
10h 1 0 Sram_write 
0Fh 1 0 Reset Port 
0Dh 1 0 General I/O 
12h 1 0 Write Port 
 
Table IV.F.4.1 - Port Mapping Table 
 
The port IDs were arbitrarily chosen, and there is no special meaning behind them. Due to the 8-
bit nature of the processor, the I/O port must use three separate ports and latch the values to their 
8 bit slots to generate the 24 bit address, and two ports each to latch the output data and the input 
data. The components also require read/write signals which are generated simultaneously on the 
same port ID for the UART components, however due to the nature of the memory controller the 
memory read and write are implemented on different ports. The data and addresses must be setup 
and be valid before a read or write operation can occur.  
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  54 
 
6. UART & Clock Divider 
The UART controllers included in the PicoBlaze kit are very simple to implement. They each 
have a 8 bit, 16 Byte FIFO buffers. In the transmitter, data is written to the buffer by the 
microcontroller and then transmitted each byte at a time. The transmitter component asserts a 
“buffer full” signal once the FIFO buffer fills up, and the processor must be stalled until a slot in 
the buffer opens for another byte to be written.  
The transmitter and receiver components function on a divided clock which must be calculated to 
match the desired baud rate.  The components require that the clock input be 16 times the desired 
baud rate. The clock is divided by a counter, and every time the counter reaches the calculated 
integer it outputs a clock high pulse to the components. The following calculations show how to 
calculate the integer needed. 
Desired baud rate: 38,400Hz 
ܾܽݑ݀௖௢௨௡௧ ൌ ܵݕݏݐ݁݉	ܥ݈݋ܿ݇16	ݔ	ܤܽݑ݀	ܴܽݐ݁ௗ௘௦௜௥௘ௗ ൌ
50ܯ݄ݖ
16	ݔ	38400ܪݖ ൌ 81.38		 
The value is required to be an integer and not a floating point value, therefore the nearest integer 
value of 81 is used. Therefore, the actual baud rate is:  
ܤܽݑ݀	ܴܽݐ ஺݁௖௧௨௔௟ ൌ ܵݕݏݐ݁݉	ܥ݈݋ܿ݇16	ݔ	ܤܽݑ݀஼௢௨௡௧ ൌ
50ܯ݄ݖ
16	ݔ	81 ൌ 38,580ܪݖ	 
The actual baud rate by using a baud count value of 81 is within 0.3% error and should not be of 
issue. Anything within 1% error will allow room for inaccurate clock rates and poor switching 
times on the antiquated RS232 protocol.  
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  55 
 
7. The Assembly Programming 
The program is a simple program consisting of three functions of which two are necessary for 
this application. The program’s goal is to read from memory using the memory interface, and 
then write to the UART transmit buffer. The program checks if the buffer is full before writing to 
the UART buffer, therefore it prevents the program from reading the memory faster than it can 
transmit. The program uses several registers. It uses three registers to store the 24 bit address, 
two registers to store the upper and lower byte of data, and a buffer register to check the UART 
buffer. The program will output an address before each read or write, and output the data before 
a write.  
 
 
Image IV.F.7.1 - PicoBlaze Program Flow Chart 
 
8. Read Function 
The purpose of the read function is to operate the memory interface controller and receive data 
from the RAM and store into a register. The function performs the following steps: 
Read from 
RAM
Increment 
Address 
Counter
Check 
UART 
Buffer
Write to 
UART`
Output 
Address
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  56 
 
1. Output 24 bit address to ports: address1_port, address2_port, address3_port 
2. Write to the read port initiating the read operation on the memory interface 
3. Read in the upper and lower bytes from memory 
4. Increment the address by 1 bit.  
Once the read is complete, the data is stored to two data registers and returns to the main 
program for the transmit function to perform the next step. 
 
9. Transmit Function 
The purpose of the transmit function is to write to the UART buffer after verifying that there is 
room for data to be written. The function performs the following steps: 
1. Check if the UART buffer is full by comparing the UART_BUFFER register and 01h. 
2. If it is full read the UART Buffer status until it is writeable, then write the lower byte 
3. Check the UART buffer again, and write upper byte if its writeable 
Once both the upper and lower bytes are written then the function returns to the main program 
and the loop is started all over again.  
 
10. Write Function 
The write function writes whatever data is present in the upper byte and lower byte registers. 
Therefore, data must be setup on those two registers before they are written to memory. The 
write function performs the following steps: 
1. Output address on address ports 
  
2. O
3. O
4. W
cy
The w
written fo
11. Simu
The test 
port is co
which th
shows th
being uti
utput data u
utput data lo
rite data to
cle.  
rite functio
r testing pu
lation and F
setup is a si
nnected to a
e serial por
e memory i
lized by the 
 [2011]   [IN
pper byte to
wer byte to
the write po
n will not 
rposes to ve
unctional Te
mple setup.
 USB to Se
t is connect
nterface bei
PicoBlaze.  
Im
TELLIGENT 
Worcester P
 the upper b
 the lower b
rt asserting
be used for
rify the func
sting 
 The Nexys
rial adapter.
ed to. A te
ng utilized 
age IV.F.11
TACTICAL V
olytechnic In
yte port 
yte port 
 a high on th
 the primary
tionality of 
2 board is p
 PuTTy is th
st bench of
by the read 
.1 - VHDL T
EST] 
stitute | IV. 
e memory 
 purpose o
the ram.  
owered by 
en being us
 the overall
and write f
est bench
System Comp
interface an
f the overa
a USB Port
ed to monit
 system is 
unctions, an
onents  57
d starting a 
ll system. It
, and the R
or the COM
generated w
d the serial
 
write 
 was 
S232 
 port 
hich 
 port 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  58 
 
The above test bench shows that there are five writes being performed, and then they are being 
“read” by five read cycles. Because the test bench is incapable of “reading” from RAM the data 
is not necessarily accurate, but provides foresight as to what to expect the physical device to do.  
In order to test the physical device data was written to memory using the write function, and then 
read back, as seen in the test bench above. The sequence which was written to memory was: 
Address Data 
000000h 5057h 
000002h 2049h 
000004h 5552h 
000006h 454Ch 
000008h 2053h 
 
Table IV.F.11.1 - Memory layout after write completed 
 
The data was then read back and transmitted to the computer the Nexys 2 board is connected to 
generating the following results: 
  
Image I
From the
perform 
UART. 
 
G. Data 
The purp
composed
a multiple
and how e
V.F.11.2 - P
 above resu
read and wr
Input Cont
ose of the da
 of several p
xer, an addr
ach compone
 [2011]   [IN
uTTY Wind
lt it can be 
ite function
roller 
ta input con
arts: a clock m
ess counter, t
nt is connect
TELLIGENT 
Worcester P
ow After D
concluded th
s with the R
troller is to 
ultiplier, thr
rigger, and w
ed to the oth
TACTICAL V
olytechnic In
 
oing a Write
at the syste
AM as wel
control the f
ee 12 bit FIF
rite controll
er. 
EST] 
stitute | IV. 
 and Read U
m is functio
l as perform
low of incom
O (first in fir
er. The schem
System Comp
sing the Pi
nal and is t
 transmit fu
ing ADC d
st out) buffe
atic below 
onents  59
coBlaze Sys
imed proper
nctions wit
ata to RAM
rs, a clock di
shows the sy
 
tem 
ly to 
h the 
. It is 
vider, 
stem, 
  
The data 
to run th
machines
is in idle
from the
which co
“triggere
writing i
microcon
input contro
e system. A
. It also req
 state and r
 3 ADCs vi
ntrols the 
d” signal ale
ncoming d
troller the s
 [2011]   [IN
Image 
ller has sev
 reset sign
uires a SRA
eady for an
a the FX-H
memory int
rting the hi
ata to mem
tarting addre
TELLIGENT 
Worcester P
IV.G.1 - Data
eral inputs/o
al is neces
M Ready in
other operat
irose conne
erface, and 
gher level s
ory. It also
ss. 
TACTICAL V
olytechnic In
 Input Contr
 
utputs at its
sary to init
put signal w
ion. The co
ctor. The co
when it w
ystem that t
 outputs a
EST] 
stitute | IV. 
oller Schema
 highest leve
ialize the s
hich alerts
ntroller also
ntroller out
ill write to
he data inpu
 trigger ad
System Comp
tic 
l. A clock i
tates of the
 the controll
 requires th
puts an SR
 memory. I
t controller
dress givin
onents  60
nput is nece
 numerous 
er that the R
at there is 
AM write s
t also outp
 is operating
g the PicoB
 
ssary 
state 
AM 
input 
ignal 
uts a 
 and 
laze 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  61 
 
 
1. Clock Multiplier 
The clock multiplier is designated as “CLOCK” on the system schematic. It implements the 
internal DCM of the Xilinx FPGA and multiplies the clock from 50 MHZ to 100 MHZ. There 
are several reasons why the clock multiplier must be implemented of which include its primary 
purpose of providing a clock for the numerous FIFO buffers as well as a clock for the clock 
divider. 
 
2. Clock Divider 
The clock divider, designated as “ClockWrite” on the above schematic, serves two functions. Its 
primary function is to provide a 10MHZ sample clock to the analog to digital converters. Its 
second purpose is to generate a write enable signal for the three FIFO buffers. The write enable 
signal is asserted high for 10 ns every 100 ns. There is a delay of 30 ns from when the 10 MHZ 
clock is asserted high to when the write enable signal because that is the minimum delay 
necessary for the ADCs to process and generate new sample data. 
 
3. Address Counter 
The address counter is a simple 23 bit counter which is incremented every time the state 
controller reaches state four. Once it reaches its max value it will clear itself and start counting 
over again. The address counter is crucial to the system as it determines where the data will be 
written. Typically every time the read counter on the state controller FIFO buffer is incremented 
so is the address on the address counter. 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  62 
 
4. FIFO Buffer 
The FIFO buffers serve a very important purpose, as they allow the system to generate a queue 
of incoming data to write to RAM. Due to the constrains of an asynchronous write to RAM, the 
data being input will be at a much higher rate than the data being written. Therefore, the queue is 
necessary in order to prevent any data from being lost during the write process. A queue data 
structure (FIFO) is fairly simple, the data which entered the system first must be read first, and 
the data which has entered the system last will be read last. 
The FIFO buffer was generated using the IPCore generator and utilizes the internal BRAM on 
the FPGA. It has a fairly simple operation, as it requires a 100 MHZ clock, a write, a read, and 
valid data to be written. When the write signal is asserted high, the data is latched into the buffer 
at the bottom of the stack. When the read signal is asserted high the data at the top of the stack 
will be read. The table below shows the operation of the FIFO buffer. 
Data In Write Read Read Pointer Write Pointer Data out 
Valid 1 0 RP<= RP WP <= WP+1 DATA[RP] 
Valid 0 1 RP<= RP+1 WP <= WP DATA[RP] 
 
Table IV.G.4.1 - FIFO Buffer Truth table 
 
The buffer when reset has both of its read and write pointers pointing to the top of the stack, and 
when a write signal is asserted it will write to the stack and increment the pointer to the next spot 
on the stack. It will also read from the stack and increment the read pointer when a read signal is 
asserted. When the read pointer and write pointer are equal to each other, the buffer is empty, 
and when the write pointer is equal to read pointer minus one spot the buffer is full. 
 
  
5. Contro
The purp
appendin
data into
FIFO buf
to the bu
buffer aft
control m
 
The cont
the excep
data from
is not wr
l Multiplexe
ose of the 
g the ADC 
 RAM. The
fers. When 
ffer inside th
er it has rea
ultiplexer. 
rol multiplex
tion of the 
 a respectiv
iting data to 
 [2011]   [IN
r 
control mu
number, and
 multiplexe
the data bec
e state cont
d the previo
Image IV.G.
er traverses
transition fr
e ADC buff
the state con
TELLIGENT 
Worcester P
ltiplexer is
 writing the
r remains in
omes availa
roller compo
us value. Th
5.1 - State Di
 through fou
om state on
er, and writ
troller whe
TACTICAL V
olytechnic In
 to control 
 data to stat
 idle mode
ble, it begin
nent. The c
e state diagr
agram for the
r states, an
e to state tw
es to the stat
n there is no
EST] 
stitute | IV. 
reading fro
e_controller
 until there 
s to read fr
ontroller wi
am below s
 Control Mu
d changes st
o. In each 
e controller
thing to wri
System Comp
m the thre
 which in tu
is data pre
om each bu
ll assert a re
hows the fu
ltiplexer 
ates at each
state the mu
. It has an id
te. 
onents  63
e FIFO bu
rn will writ
sent in the 
ffer and wri
ad signal to
nctionality o
 
 clock cycle
ltiplexer ou
le state so t
 
ffers, 
e the 
ADC 
tes it 
 each 
f the 
 with 
tputs 
hat it 
  
6. State C
The state
state mac
mode. O
roughly 1
signal to 
The state
in state o
half_full(
two it wi
that reall
machine 
ontroller 
 controller i
hine reads f
therwise, if 
/4th of the b
the buffer.  
 machine re
ne the buff
programme
ll continuou
y does not 
will allow t
 [2011]   [IN
s a combina
rom the FIF
it is not trig
uffer size it
The state dia
Image 
mains in sta
er is filling
d full) signa
sly read from
fit in the t
he buffer to
TELLIGENT 
Worcester P
tion of two 
O buffer an
gered, and 
 will increm
gram below
IV.G.6.1 - St
te one while
 up. When 
l and sets th
 the top of
ime frame 
 fill past th
TACTICAL V
olytechnic In
components
d writes it to
the buffer h
ent the read
 shows the 
ate Controlle
 it is waiting
the buffer b
e system to
 the buffer a
that is need
e programm
EST] 
stitute | IV. 
, a FIFO bu
 SRAM wh
as filled up
 pointer of t
functionality
r State Diagra
 for the sys
ecomes 1/4
 state two. W
nd discard t
ed. Once t
ed full poi
System Comp
ffer and a st
en the syste
 to the 2 K
he buffer by
 of the cont
m 
tem to trigg
th full the 
hen the sy
he data beca
he system t
nt and conti
onents  64
ate machine
m is in trigg
b mark whi
 asserting a
roller. 
 
er, and whil
FIFO assert
stem enters
use it is old
riggers the 
nuously wr
 
. The 
ered 
ch is 
 read 
e it is 
s the 
 state 
 data 
state 
ite to 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  65 
 
RAM and read from the buffer as the memory interface becomes available to perform an 
operation. The “ram_ready” signal is crucial to the system operation, if the memory interface 
controller fails to become available the whole system will freeze and there will no longer be any 
data written to the RAM. Once the system reaches state four it will also assert an “increment” 
signal so that the address counter increments and the next piece of data is written to the next 
address in RAM. 
 
7. Trigger Controller 
The purpose of the trigger controller is to initiate the write to RAM. The system will trigger once 
the most significant bit of one of the three ADCs has a high output, representing that something 
strong enough has impacted the plate to begin recording of the data which is present in the buffer 
to RAM. The trigger will output two signals, a “Trigger” and “Ready” signal. When the 
“Trigger” signal is asserted high it will send the picoblaze into a loop assuring that it does not 
perform any operations on the memory controller or execute any further instructions, as well as 
take full control of the memory interface. The “ready “ signal will assert high once it triggers and 
enable the State controller which will begin asserting signals to the memory interface to write the 
data which is on the data bus to the address on the address bus. 
  
In state o
where bi
asserts a 
if the ad
trigger w
the memo
 
ne the trigg
t number 11
high on bot
dress at whi
ill enter stat
ry interface
 [2011]   [IN
Imag
er will con
 is high in w
h ready and
ch it trigge
e three in w
 controller t
TELLIGENT 
Worcester P
e IV.G.7.1 
tinuously ch
hich case i
 trigger. The
red and the 
hich it will 
o the PicoB
TACTICAL V
olytechnic In
- Trigger St
 
eck the inc
t will trigge
 trigger wil
current add
assert all of 
laze. 
EST] 
stitute | IV. 
ate Diagram
oming data
r. Once it tr
l then samp
ress are equ
its signals t
System Comp
 
 
 until it find
iggers it ent
le the addre
al. Once th
o low and tr
onents  66
s a byte of
ers state two
ss bus and c
ey are equa
ansfer contr
 
 data 
 and 
heck 
l the 
ol of 
  
8. Simula
Simulatio
needs to 
ADC inp
which th
system c
as the da
store rou
being inc
no data w
data and 
tion and Te
n of the da
be functiona
uts are incr
e system tr
ritical data. 
ta being inp
ghly 300 sa
remented ea
hich is bei
then pausin
 [2011]   [IN
sting 
Image I
ta controlle
l in order to
ementing d
iggers is th
Firstly notic
ut, which d
mples prior
ch time the
ng overwrit
g and repea
TELLIGENT 
Worcester P
V.G.8.1 - Da
r will be th
 do any phy
ata from 00
e most cruc
e that the d
emonstrates
  to the trig
re is an SR
ten. Prior to
ting itself b
TACTICAL V
olytechnic In
ta Input contr
 
e optimal m
sical testin
0h to FFFh
ial, as the d
ata being ou
 that the FI
ger point f
AM write w
 the trigger
ecause at th
EST] 
stitute | IV. 
oller Simulat
ethod of t
g. For the p
. For observ
ata being o
tput on the 
FO buffers 
or each AD
hich is imp
 point the d
is point the
System Comp
ion 
esting, as th
urposes of t
ation purpo
utput from
data out bu
are working
C. Secondl
ortant to en
ata bus is r
 data buffer
onents  67
e whole sy
his test, the 
ses, the po
 this point 
s is not the 
, and are ab
y, the addre
sure that the
apidly switc
 has reache
 
 
stem 
three 
int at 
on is 
same 
le to 
ss is 
re is 
hing 
d the 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  68 
 
designated point and it is removing unwanted samples. It is also outputting the 10 Mhz clock 
which will be routed to the sample clocks on the ADCs. 
It can be concluded that the data input controller is working as intended because of these reasons: 
 Address and Data are being simultaneously incremented 
 Trigger address is being set to the last known address, so the picoblaze will begin reading 
from that address. 
 It switches into triggered mode when DataIn(11) reaches high 
 It is removing unwanted data at the designated mark 
 It begins asserting the proper signals to SRAM once it triggers 
 
 
 
H. Printed Circuit Board Design 
In order to bring the schematic design to a physical implementation, a PCB was created. In a 
PCB there are many things that must be taken into account, from user specifications, part 
restrictions as well as manufacturing limitations. 
 
1. Definitions 
To effectively utilize the Ultiboard program, there are a few technical words that should be 
defined to facilitate the creation of any PCB. These are: 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  69 
 
Via -  a conductive hole that connects two layers of a PCB. By manufacturer design these holes 
are automatically given solder pads on each side.    
Solder mask -  a lacquer-like layer of polymer that resist solder which decreases the chances of 
stray solder, that could cause shorts in the PCB.  
Solder silkscreen -  a physical dawning that is used to assure that the component is placed in 
the correct orientation. 
Board outline - an outline of outer limits of the PCB. 
 
2. Custom Parts 
There are several integral components that must be placed on the PCB. In order to place these 
components solder pads must be created of each unique part package. In order to create these 
custom part outlines the Ultiboard part wizard was used. This wizard has features that can 
determine the technology, package type, package dimensions, 3d color settings, pad type and 
dimensions, number of pins and pad numbering. The combination of the Ultiboard wizard and 
the mechanical information found in the particular component datasheet is enough to create 
solder pads for any component. Below are examples of all of the types of components used and 
their corresponding solder pad. The wizard is the most useful method of creating a custom solder 
pad but it's not the only way. If the component is not found in the Ultiboard databases, the user 
must create the component manually. This was the case for the 100-pin FX-2 Hirose connector, 
which was used to attach the PCB and the Xilinx board together. In order to properly fit the 100-
pin connector, the X and Y coordinate for each pin was calculated and recorded. With the 
coordinate of each pin found, a "via" was placed in the corresponding coordinate. With the via's 
in place the custom component need to attached to the traces on the Top Copper layer.         
  
 
3. PCB L
There are
to solder
implemen
 
Imag
ayers 
 several lay
 mask laye
ted in this d
 [2011]   [IN
Image IV.H
e IV.H.2.2 
Ima
ers that com
rs. Below i
esign. 
TELLIGENT 
Worcester P
.2.1 - Voltag
- Operation 
ge IV.H.3.3
pose every
s a descript
TACTICAL V
olytechnic In
e Regulator
Amplifier -
 - ADC- AD
 PCB desig
ion on each
EST] 
stitute | IV. 
 
- VoltReg-L
 
Op-Amp-LM
 
9220ARZ
n, these laye
 layer, its 
System Comp
P38690 
6154BCM
rs range fro
importance 
onents  70
 
m copper l
and how it
 
ayers 
 was 
  
a. Coppe
This laye
this proje
selected. 
noise a l
command
b. Coppe
This lay
superimp
that conn
would be
allows th
r Top: 
r shows the
ct. These tr
Keep in mi
arge ground
 one is capa
r Bottom: 
er was use
ose the Top
ect the top 
 no direct c
e designer t
 [2011]   [IN
 top traces o
aces were c
nd that line
 area was c
ble of creat
Im
d to circum
 Copper lay
Copper and
onnections 
o weave a tr
TELLIGENT 
Worcester P
f copper us
reated with 
 dimensions
reated with
ing different
age IV.H.3.
vent any d
er and the B
 the Bottom
between lay
ace through
TACTICAL V
olytechnic In
ed for both 
the use of "
 can be cha
 the use of 
 shapes for 
a.1 - Top Co
 
ead ends f
ottom Cop
 Copper la
ers. The us
 other traces
EST] 
stitute | IV. 
the analog 
place line" 
nged where
the "place 
circles to ro
pper layer
ound in th
per layer, y
yer. If thes
e of via's an
, which mak
System Comp
side and the
command w
 needed. In
shape" com
unded rectan
e top copp
ou would fin
e via's are n
d multiple 
es it easier 
onents  71
 digital aspe
ith the top 
 order to re
mand. With
gles.    
 
er layer. If
d there are
ot created 
layers of co
to connect n
 
ct of 
layer 
duce 
 this 
 you 
 via's 
there 
pper 
odes 
  
in the de
circuit. T
In reality
traces, an
c. Silkscr
In this lay
locate an
signing proc
he blue circ
 the blue c
d or use as t
een Top 
er a silkscr
d place com
 [2011]   [IN
ess. This ty
les seen in b
ircles repre
est points. 
Imag
een is placed
ponent parts
TELLIGENT 
Worcester P
pe of conne
oth the Top
sent the exp
e IV.H.3.b.
 where each
 in the corre
TACTICAL V
olytechnic In
ction also a
 Copper laye
osed coppe
1 - Bottom C
 
 componen
ct orientatio
EST] 
stitute | IV. 
llows for a 
r and the B
r in which
opper layer
t is needed. 
n. 
System Comp
single cohe
ottom Copp
 one can so
 
This layer i
onents  72
sive and flo
er layer are 
lder to, con
 
s used to vis
 
wing 
via's. 
nect 
ually 
  
d. Solder
Solder m
is not su
with sold
the top a
soldering
not have
copper th
either so
while cre
allows th
Gerber fi
 Mask Top a
asks are use
pposed to (
er mask. It i
nd the bot
 holes as we
 solder mas
en, one can
lder mask la
ating a PCB
e user to glo
le setting. G
 [2011]   [IN
Imag
nd Bottom 
d to prevent
stray copper
s up to the u
tom layers 
ll as the pa
k exposed 
 use the "p
yer selecte
, as the ma
bally add s
erber files a
TELLIGENT 
Worcester P
e IV.H.3.c.
 shorts betw
). However
ser to decid
of solder m
ds for all su
by default. 
lace shape 
d. Solder m
nufacture w
older mask 
re a type of 
TACTICAL V
olytechnic In
1 - Silkscree
 
een copper 
, when Ulti
e the locatio
ask are us
rface mount
If there wa
command" 
ask relief is
ill reject an
relief to all 
format man
EST] 
stitute | IV. 
n Top layer
traces, as w
board is us
n of expose
ed to expos
 component
s any need 
and or the 
 an importa
 order due 
components
y PCB manu
System Comp
 
ell as solder
ed, the entir
d copper. In
e the annu
s. Regular h
to manually
"place line 
nt element 
to it. There
. This featur
facturers us
onents  73
 
 melting wh
e board is 
 the case of
lar rings fo
oles howev
 create exp
command" 
to keep in 
 is a feature
e is found i
e.    
 
ere it 
filled 
 both 
r the 
er do 
osed 
with 
mind 
 that 
n the 
  
 
 [2011]   [IN
Im
Imag
TELLIGENT 
Worcester P
age IV.H.3.d
e IV.H.3.d.
TACTICAL V
olytechnic In
.1 - Solder 
2 - Solder M
EST] 
stitute | IV. 
masks Top
ask Bottom
System Comp
 
onents  74
 
 
 
  
e. Gerber
In order 
feature e
limitation
trace dis
these err
files mus
required 
has a com
the order
stoppers"
 Files and M
to manufact
mbedded in
s straight i
tances and 
ors are fixe
t be export
Gerber files
pany based
. Their DR
.  
 [2011]   [IN
Image
anufacturin
ure the PCB
 the Ultibo
nto the prog
are importan
d. Once the
ed. The man
 and NCdril
 DRC calle
C automatic
TELLIGENT 
Worcester P
 IV.H.3.d.3 
g Limitation
, it needs t
ard program
ram. These
t because 
 PCB passe
ufacturer fo
l files to pla
d FreeDFM
ally fixes s
TACTICAL V
olytechnic In
– PCB Laye
 
s 
o first pass 
 which all
 manufactur
the manufac
s the user c
r this parti
ce a PCB or
 which can b
ome comm
EST] 
stitute | IV. 
r Compilati
the design r
ows the us
ing limitati
turer will n
reated DRC
cular board 
der. The ma
e used to c
on mistakes
System Comp
on 
ules checke
er to set th
ons range f
ot process 
, manufactu
was Advan
nufacturer 
heck the fil
 and shows
onents  75
r. The DRC
e manufact
rom hole si
the project 
re specific 
ce Circuits,
for this PCB
es before pl
 the user "
 
 
 is a 
uring 
ze to 
until 
PCB 
 they 
 also 
acing 
show 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  76 
 
I. Localization Calculations 
The data from multiple sensors is useless by itself and needs to be analyzed. Since the main 
remaining goal of the project was to identify the location of an impact on the plate, data analysis 
was focused on this. All attempts to find a way to calculate the exact position of an impact on the 
ballistic plate from the information given by three sensors stemmed from the following basic 
trilateration equations: 
R1 = sqrt( (x-x1)2 + (y-y1)2 ) 
R2 = sqrt( (x-x2)2 + (y-y2)2 ) 
R3 = sqrt( (x-x3)2 + (y-y3)2 ) 
where R1, R2, and R3 are the radii from the impact point to each of the three sensors, x1, y1, x2, 
y2, x3, and y3 are the locations of the sensors, and x and y are the coordinates of the impact 
point that need to be solved for. 
The original attempt to solve this problem started by assigning each sensor a position based on 
known dimensions, that is, sensor 1 was located in the top left of the plate, making x1, y1 equal 
to 0, h, where h is the height of the plate, sensor two was located in the top right of the plate, 
making x2, y2 equal to w, h, where w is the width of the plate, and sensor 3 was located in the 
middle of the bottom of the plate, making x3, y3 equal to w/2, 0. Afterwards, x and y can be 
solved for using the three resulting equations and result in: 
x = ( R12 - R22 + w2)/2w 
y = (2R32 + R22 - R12 + 2h2 + 3/2w2)/4h 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  77 
 
This method runs into a couple of issues, however. The first stems from the fact that R1, R2, and 
R3 cannot be directly measured. They are each formed by the measured arrival time of the signal 
to a sensor minus the impact time over the speed of the wave through the plate, and while the 
speed of the wave can be measured, the impact time is another unknown that must be solved for. 
Additionally, there might be some error in the arrival times, which this method does not account 
for. 
Due to these issues, the next attempt to solve for x and y used matrices to go through guesses for 
the radii compared to their actual values in a somewhat standard approach to trilateration. This 
method started off by adding the additional condition to the original radius equation of each 
radius being equal to the velocity of the impact wave through the plate multiplied by the 
difference between the time of recording the wave of each sensor, t1, t2, and t3, and the 
unknown time of impact t0. This addition is valid because both the original equations and the 
added condition are valid ways of calculating a radius between the two points. The appended 
equations are as follows: 
R1 = sqrt( (x-x1)2 + (y-y1)2 ) = v*(t1-t0) 
R2 = sqrt( (x-x2)2 + (y-y2)2 ) = v*(t2-t0) 
R3 = sqrt( (x-x3)2 + (y-y3)2 ) = v*(t3-t0) 
The next step was to take the Taylor Series transforms of R1, R2, and R3 about an estimation 
point xe, ye in order to make the equations more matrix friendly and to incorporate the 
estimation point for use in the iterative process of this method. The first two terms of the 
transforms about xe, ye are: 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  78 
 
R1 = sqrt( (xe-x1) 2 + (ye-y1) 2) + (xe-x)*(xe-x1)/R1 + (ye-y)*(ye-y1)/R1 
R2 = sqrt( (xe-x2) 2 + (ye-y2) 2) + (xe-x)*(xe-x2)/R2 + (ye-y)*(ye-y2)/R2 
R3 = sqrt( (xe-x3) 2 + (ye-y3) 2) + (xe-x)*(xe-x3)/R3 + (ye-y)*(ye-y3)/R3 
Since these are Taylor Series transforms, these equations are still equal to the velocity multiplied 
by the time difference discussed earlier, and the terms xe-x and ye-y are the error terms Δx and 
Δy that will be solved for. However, that means they still contain the unknown t0, but that term 
can be canceled out by subtracting R3 from R1 and R2 from R1 as follows: 
R1 – R2 = v*(t1-t2) + sqrt( (xe-x2) 2 + (ye-y2) 2) - sqrt( (xe-x1) 2 + (ye-y1) 2) =  
= Δx*((xe-x1)/R1 – (xe-y2)/R2) + Δy*((ye-y1)/R1 – (ye-y2)/R2) 
R1 – R3 = v*(t1-t3) + sqrt( (xe-x3) 2 + (ye-y3) 2) - sqrt( (xe-x1) 2 + (ye-y1) 2) =  
= Δx*((xe-x1)/R1 – (xe-y3)/R3) + Δy*((ye-y1)/R1 – (ye-y3)/R3) 
These equations can finally be put in matrix form as such: 
[v*(t1-t2) + a   v*(t1-t3) + b] = [Δx   Δy]A 
Where: 
a = sqrt( (xe-x2) 2 + (ye-y2) 2) - sqrt( (xe-x1) 2 + (ye-y1) 2) 
b = sqrt( (xe-x3) 2 + (ye-y3) 2) - sqrt( (xe-x1) 2 + (ye-y1) 2) 
And A is a 2 by 2 matrix with terms: 
A1 = (xe-x1)/R1 – (xe-y2)/R2 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | IV. System Components  79 
 
A2 = (xe-x1)/R1 – (xe-y3)/R3 
A3 = (ye-y1)/R1 – (ye-y2)/R2 
A4 = (ye-y1)/R1 – (ye-y3)/R3 
The central idea behind this method is that an iterative process will result in a very good 
approximation of the impact position by choosing an estimation point arbitrarily, inserting it into 
the above matrix and solving for the error terms every iteration:  
[Δx   Δy] = [v*(t1-t2) + a   v*(t1-t3) + b] / A 
Then, the resulting error terms of one iteration are used to calculate a new estimation point which 
is used in the next iteration. After a few iterations, as few as three or four, the resulting error 
terms should be small enough to consider the next calculated estimation point the actual x, y. 
These calculations were simulated in MATLAB using simulated dimensions and specifications, 
and the code for them is available in Appendix II.  
 
 
 
 
 
 
  
V. Resu
 
The syste
the input
were wor
was put i
began rec
analyzed
lts 
m was first 
s of the ana
king togeth
nto the inpu
ording the d
 and plotted
 [2011]   [IN
tested in a l
log to digit
er in unison
t of the AD
ata into RA
. The result 
Figure V.1
TELLIGENT 
aboratory se
al converte
. For the pur
C, triggerin
M, and then
of this system
 – Result of 
TACTICAL V
Worcester
tting in whi
rs to verify 
poses of thi
g the system
 the data wa
 test was th
the PSRAM
 
 
EST] 
 Polytechnic 
ch a function
that the log
s test, a 20 k
 when it re
s transferre
e following
 Memory T
Institute | V.
 generator 
ic system a
Hz five volt
ached 2.6 V
d to a comp
 graph: 
ransfer 
 Results  80
was connect
nd ADC sy
 sinusoidal 
olts. The sy
uter system 
 
 
ed to 
stem 
wave 
stem 
to be 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | V. Results  81 
 
Following the first test, a more realistic set-up was attempted. The sensors were directly attached 
to the 8in by 6in ballistic plate, which was then inserted into its holder. With the entire system 
assembled, the plate was struck several times using a hammer. The hammer blows were expected 
to produce a large enough signal from the piezoelectric sensors to trigger the ADCs and begin 
the recording process. However, the system only recorded the “at rest” signal from the sensors, 
indicating that the trigger was a false positive or that the voltage was high enough to trigger 
temporarily, but that the waveform died down before the recording process began. The possible 
problem could be in a few places, but the issue most likely lies with the system not reacting fast 
enough to the sensory input chosen. 
Since the hammer test did not yield usable results, the localization calculations could not be 
tested with actual data. They were, however, tested using dummy data through the MATLAB 
code provided in Appendix II. The code tests if the method works for two points, 10, 5, and 7, 2, 
on an imaginary plate 12 by 12 units in area. The code proves that the method is a valid one, with 
a possible result within ~10% of actual being achieved within three to four iterations. 
 
 
 
 
 
 
 
 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | VI. Sources  82 
 
VI. Sources 
"223 Remington." Accurate Powders. Accurate Powders. Web. 27 Apr. 2011. 
<http://www.accuratepowder.com/>. 
"Accellerometers and How They Work." USFIRST.org - Welcome to FIRST. USFIRST. Web. 27 Apr. 
2011. <http://www.usfirst.org/>. 
"Building a Better Safety Helmet." PhysOrg.com - Science News, Technology, Physics, 
Nanotechnology, Space Science, Earth Science, Medicine. Northeastern University, 13 July 
2010. Web. 27 Apr. 2011. <http://www.physorg.com/news198249870.html>. 
FBI. "Law Enforcement Officers Killed and Assaulted, 2008." FBI. Web. 27 Apr. 2011. 
<http://www2.fbi.gov/ucr/killed/2008/>. 
"Force Sensor | Force Sensors." Load Cell, Torque Sensor, Force Sensor, Pressure Sensor, Custom Load 
Cell & Related Instruments. Web. 27 Apr. 2011. 
<http://www.futek.com/product.aspx?stock=FSH01939>. 
"Frequently Asked Questions." Shok SpotR - The First Helmet Sensor. Shock SpotR. Web. 27 Apr. 
2011. <http://www.shok-spotr.com/faq.asp>. 
Kim, Andrew C. "Real-time Impact Detection and Object Discrimination for Pedestrian Protection." 
SACL. Stanford University. Web. 27 Apr. 2011. 
<http://structure.stanford.edu/Project/ResearchProjects/ackim/Andy_Kim.pdf>. 
Measurement Specialties, Inc. "LDT with Crimps Vibration Sensor/Switch." Measurement Specialties. 
Measurement Specialties, 13 Oct. 2008. Web. 27 Apr. 2011. <http://www.meas-
spec.com/downloads/LDT_Series.pdf>. 
Measurement Specialties Inc. "Piezo Film Sensors Technical Manual." Measurement Specialties. MIT, 
02 Apr. 1999. Web. 27 Apr. 2011. 
<http://www.media.mit.edu/resenv/classes/MAS836/Readings/MSI-techman.pdf>. 
PDA Cortex. "LifeShirt New Era in Ambulatory Monitoring." PDA Cortex: The Largest Selection of 
Medical & Nursing PDA Software. PDA Cortex. Web. 27 Apr. 2011. 
<http://www.pdacortex.com/VivoMetrics.htm>. 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | VI. Sources  83 
 
Polar. "RS 100 Training Computer." RS 100 Training Computer. Polar. Web. 27 Apr. 2011. 
<http://www.polarusa.com/us-en/products/get_active/running_multisport/RS100>. 
Tadinada, Akhila. "Piezo Film Sensor for Capture of Arterial Wave Pulse." Connexions - Sharing 
Knowledge and Building Communities. Web. 27 Apr. 2011. 
<http://cnx.org/content/m15670/latest/>. 
Timex. "IRONMAN Race Trainer." Timex Online Store. Timex. Web. 27 Apr. 2011. 
<http://www.timex.com/Timex-IRONMAN-Race-Trainer/dp/B001RQ97LY?ie=UTF8>. 
"Transcell SBS 1000 Lb. Single End Shear Beam Load Cells." 1800scales.com. Transcell. Web. 27 Apr. 
2011. <http://www.1800scales.com/Transcell-SBS-1K-cells.html>. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX I  84 
 
APPENDIX I 
 
Objective: 
Create a memory controller to input data from ADCs and store the data in the onboard PSRAM for future 
analysis. 
 
 
Approach: 
To create a PSRAM memory controller, the following sub-components had to be constructed: 
 Digital Clock  Manager 
 Memory Interface 
◦ BCR Write 
◦ BCR Read 
◦ SRAM Write 
◦ SRAM Read 
◦ Burst Write 
◦ Burst Read 
 ADC Simulator 
 
 
 
 
 
 
 
 
 
 
  
PSRAM
 
 
 
 
 Memo
 [2011]   [IN
ry Speci
Figure 1.0
TELLIGENT 
fications
 – Burst Wri
TACTICAL V
Worcester P
: 
te Cycle Tim
EST] 
olytechnic In
ing Requirem
stitute | APP
ents 
ENDIX I  85 
  
 
 
 [2011]   [IN
Figur
TELLIGENT 
e 1.1 – Burst 
TACTICAL V
Worcester P
write cycle ti
EST] 
olytechnic In
ming diagram
stitute | APP
 
ENDIX I  86 
  
 
 
 
 
 
 
 [2011]   [IN
Fig
TELLIGENT 
ure 1.2 – BC
TACTICAL V
Worcester P
R write timin
EST] 
olytechnic In
g diagram 
stitute | APPENDIX I  87 
  
 
 
 
 
 
 
 [2011]   [IN
Figure 
TELLIGENT 
1.3 – Bus con
TACTICAL V
Worcester P
figuration re
EST] 
olytechnic In
gister definit
stitute | APP
ion 
ENDIX I  88 
  
Comp
 
Digital Cl
 
Inputs: 
 R
 C
 
Outputs: 
 C
 C
 C
 
The digita
desired fre
output fre
of the PSR
 
The DCM
board. Th
before ref
clock cycl
ADC Sim
onents: 
ock Manager
ST_IN – A re
LKIN_IN – T
LKFX_OUT
LKFX180_O
LKIN_IBUF
l clock mana
quency. The
quency has b
AM and it is
 generates a 
e configuratio
reshing the P
es which wil
ulator: 
 [2011]   [IN
: 
Fig
set pin 
he input cloc
 – The output
UT – The ou
G_OUT – Op
ger takes an i
 DCM output
een chosen to
 fast enough
clock that sat
n of the burs
SRAM. With
l take 2.2 mic
TELLIGENT 
. 1.4 – Xilinx
k that will b
 clock 
tput clock, sh
en output pin
nput clock, t
s the clock th
 be 60MHz b
to write data
isfies the low
t configuratio
 a clock frequ
roseconds. 
TACTICAL V
Worcester P
 Digital Cloc
 
e modified 
ifted in phas
 
he 50MHz sq
at is used by
ecause it lies
 from 3 ADC
est speed gra
n register fo
ency of 60M
EST] 
olytechnic In
k Manager 
e by 180 deg
uare wave, a
 the rest of th
 under the m
s simultaneou
de memory t
r continuous 
Hz, this enti
stitute | APP
rees 
nd outputs a 
e memory co
aximum oper
sly. 
hat could be 
mode will wr
re write sequ
ENDIX I  89
square wave 
ntroller. The
ating frequen
on the Nexys
ite 128 word
ence should 1
 
of a 
 
cy 
2 
s 
32 
  
 
Inputs: 
 re
ou
 cl
 
Outputs: 
 ce
 da
 
The ADC
and an arr
The ADC
is driven l
 
ady – The re
tput is enabl
k – The 60M
 – The outpu
ta(15:0) – Th
 simulator co
ay is full, the
 simulator co
ow when the
 [2011]   [IN
ady signal fro
ed. When thi
Hz clock inp
t to chip enab
e data bus to
mponent fills
 state machin
ntrols the chi
 ready signal 
Fi
TELLIGENT 
Figure 1.7
m the PSRA
s signal is low
ut from the X
le pin of the
 the PSRAM
 up an array w
e iterates tho
p enable pin 
is high and th
gure 1.8 – AD
TACTICAL V
Worcester P
 – ADC Simu
 
M memory c
, the output 
ilinx digital c
 PSRAM mem
 memory con
ith a pre-de
ugh the array
on the PSRA
e ADC is ab
C simulator
EST] 
olytechnic In
lator 
ontroller. Wh
is disabled. 
lock manage
ory controll
troller to sim
fined pattern
 and outputs 
M memory c
out to output
 test bench 
stitute | APP
en this signa
r. 
er 
ulate output 
. When the re
the next wor
ontroller. The
 data to the P
ENDIX I  90
l is high, the 
from the AD
ady signal is 
d to the data b
 chip enable
SRAM. 
 
Cs. 
high, 
us. 
 pin 
  
 
PSRAM M
Inputs: 
 cl
 re
 re
 w
emory Cont
k – The clock
set – A reset 
ady – A read
aits – An inp
 [2011]   [IN
roller: 
Fig
 input from t
input tied to 
y signal inpu
ut from the o
TELLIGENT 
ure 1.9 – PSR
he 50MHz o
a button inpu
t tied to a sw
utput of the P
TACTICAL V
Worcester P
AM memor
 
scillator 
t on the Nexy
itch on the N
SRAM devic
EST] 
olytechnic In
y controller 
s2 board 
exys2 board
e to give inf
stitute | APP
ormation on t
ENDIX I  91
 
he status of t
 
he 
  
P
 sr
as
 sr
as
 as
as
 bc
as
 bc
as
 ad
as
Outputs: 
 M
 M
 ad
 da
 le
 ce
P
 cl
 
The PSRA
Xilinx Dig
the row of
words, an
and the to
clock cycl
SRAM devic
am_read – A
ynchronous r
am_write - A
ynchronous w
witch – An i
ynchronous m
r_write - An
ynchronous w
r_read - An 
ynchronous r
ata_out – Inp
ynchronous w
emory Contr
emDB_reg(1
dr(22:0) – O
ta(15:0) – O
d(7:0) – Deb
_disable – T
SRAM devic
k2 – A 60MH
M controller
ital Clock M
 memory unt
d if we opera
tal time spen
es where we 
 [2011]   [IN
e 
n input from 
ead 
n input from
rite 
nput from a s
ode to sync
 input from a
rite to the B
input from a 
ead from the
uts from the
rite 
ol Logic – ad
5:0) – discon
utputs the ad
utputs data to
ugging LEDs
he out to disa
e 
z output clo
Figur
 is the compo
anager. Cont
il it reaches t
te the memor
t writing the r
do not write 
TELLIGENT 
a button on th
 a button on t
witch on the 
hronous burs
 button on th
us Configura
button on the
 Bus Configu
 switches on 
v, lb, ub, oe,
nected legac
dress to the P
 the PSRAM
 
ble the Flash
ck 
e 1.10 – PSR
nent that con
inuous burst 
he end of the
y controller a
ow of data is
data to memo
TACTICAL V
Worcester P
e Nexys2 bo
he Nexys2 bo
Nexys2 boar
t mode 
e Nexys2 boa
tion Register
 Nexys2 boar
ration Regist
the Nexys2 B
 we, ce, cre –
y port 
SRAM addre
 data bus 
 device that s
AM burst wr
 
tains the AD
mode just co
 row. The row
t 60MHz the
 2.2 microsec
ry because o
EST] 
olytechnic In
ard to tell the
ard to tell th
d to tell the P
rd to tell the 
 
d to tell the P
er 
oard to dicta
 Controls PS
ss bus 
hares the add
ite test bench
C simulator,
ntinually wri
s of the MT
n we are writ
onds which 
f the row bou
stitute | APP
 PSRAM de
e PSRAM de
SRAM devic
PSRAM dev
SRAM devi
te what to wr
RAM 
ress and data
 
 BCR write c
tes to the seq
45W8MW16
ing data for 2
means that th
ndary crossi
ENDIX I  92
vice to do an
vice to do an
e to switch fr
ice to do an 
ce to do an 
ite during an
 buses with t
omponent, an
uential colum
contain128 
.13 microsec
ere will be 4 
ng functional
 
 
 
om 
 
he 
d the 
n in 
onds 
ity in 
  
CellularR
ADCs eve
up we bur
number o
When we 
values in 
useless.  
 
 
 
 
 
 
 
 
 
AM. A imple
ry 100 nanos
st all of the d
f ADCs) micr
are bursting 
the second ar
 [2011]   [IN
mentation id
econds and s
ata in the arr
oseconds to 
data from one
ray, and cont
Figure –
TELLIGENT 
ea is 2 arrays
tore the data 
ay to the PSR
fill up and 2.2
 of the array
inue to altern
 1.11 – SRA
TACTICAL V
Worcester P
 of 128 std_lo
sequentially 
AM. It will t
 microsecon
s to PSRAM,
ate arrays un
M_Controlle
EST] 
olytechnic In
gic_vectors(
in the array a
ake the buffe
ds to dump th
 we continue
til the inform
r2 internal vi
stitute | APP
15 downto 0
nd when one
r around 12.8
e informatio
 to poll the A
ation from th
ew 
ENDIX I  93
) and we poll
 of the arrays
/n (n being t
n into PSRAM
DCs and stor
e ADCs is 
 
 the 
 fills 
he 
. 
e the 
  
Memory I
The memo
asynchron
 
Inputs: 
 cl
 cl
 re
 sr
m
nterface: 
ry interface 
ous writes, b
k – 60MHz i
k2 – 60 MHz
set – reset pi
am_read - An
achine 
 [2011]   [IN
holds the cor
urst reads, bu
nput clock 
 input clock 
n to reset stat
 input from 
TELLIGENT 
e state machi
rst writes, BC
Figure 1.12 
(180 degrees 
e machine 
a button on th
TACTICAL V
Worcester P
nes that allow
R reads, and
– Memory In
 
phase shift o
e Nexys2 bo
EST] 
olytechnic In
 the system t
 BCR writes
terface 
f clk) 
ard to start th
stitute | APP
o do asynchr
. 
 
e asynchrono
ENDIX I  94
onous reads,
us read state
 
 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX I  95 
 
 sram_write - An input from a button on the Nexys2 board to start the asynchronous write state 
machine 
 bcr_read - An input from a button on the Nexys2 board to start the bcr asynchronous read state 
machine 
 bcr_write - An input from a button on the Nexys2 board to start the bcr asynchronous write state 
machine 
 waits – An input from memory asserted when it is refreshing 
 burst_switch – A input from a switch on the Nexys2 board to start the burst write state machine 
 ces_reg – An input from the ADC simulator telling it that the buffers have started to fill up 
 address(22:0) – an address input to dictate where to start an asynchronous read or write, as well as 
a synchronous read or write 
 data_out(7:0) – An input from the switches on the Nexys2 board to dictate what to write in 
asynchronous mode 
 data_input(15:0) – Data input from the ADC simulator 
Outputs” 
 Memory Control Logic - bcr_loaded, RamCS, FlashCS, MemWR, MemOE, RamUB, RamLB, 
RamCRE, RamADV, RamClk 
 Data_in(15:0) – Data output read by sream_controller2 
 Ledout(2:0) – Diagnostic LED output 
 MemAdr(22:0) – 23-bit memory address bus 
 MemDB(15:0) – 16-bit memory data bus 
 
 
  
 [2011]   [INTELLIGENT 
Figure 1
TACTICAL V
Worcester P
.13 – BCR W
 
EST] 
olytechnic In
rite 
stitute | APPENDIX I  96 
  
 [2011]   [INTELLIGENT 
Figure 1.14 –
TACTICAL V
Worcester P
 Load interna
 
EST] 
olytechnic In
l buffers 
stitute | APPENDIX I  97 
  
 [2011]   [IN
F
TELLIGENT 
igure 1.15 –
TACTICAL V
Worcester P
 Initialize Bu
EST] 
olytechnic In
rst Write 
stitute | APPENDIX I  98 
  
The Mem
a burst rea
details of 
push, an a
will be wr
burst_swi
its interna
begins. Fi
writing to
from a de
 
 
 
ory interface 
dy switch, an
what the mem
synchronous
itten to the B
tch is turned 
l buffers, the
gure 5 shows
 memory, the
sired address
 [2011]   [IN
simply moni
d a ready sig
ory interfac
 write occurs 
CR and the c
on. When bur
n when an int
 a closer look
n the content
.  
TELLIGENT 
Figure 1.16 –
tors for butto
nal from the 
e accomplish
with slight m
re pin is asse
st_switch is 
ernal buffer i
 at the initial
s of the mem
TACTICAL V
Worcester P
 Asynchrono
 
ns for the asy
ADC simula
es. In figure 
odifications.
rted high. Fig
enabled, the A
s filled ces_r
ization of a b
ory can be ve
 
EST] 
olytechnic In
us Read 
nchronous re
tor. Figures 1
1.13, the first
 The address 
ure 1.14 sho
DC simulat
eg goes low 
urst write. A
rified with a
stitute | APP
ads and write
.13, 1.14, 1.1
 process occu
bus is specif
ws what happ
or starts stori
and a burst w
fter the system
 manual asyn
ENDIX I  99
s, a reset sw
5, and 1.16 s
rs with a but
ied a value th
ens when 
ng informatio
rite process 
 is done bur
chronous rea
 
itch, 
how 
ton 
at 
n in 
st 
d 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX I  100 
 
Process: 
The following is the process for the complete burst write to memory: 
 BCR Write 
 Toggle Burst_Switch 
 Fill internal buffers with input from ADCs 
 Burst write information from buffers to memory 
 Asynchronously read back the information stored into memory 
 
The first step in this process is to use the configuration register to configure the BCR. The BCR is 
configured by applying the desired binary sequence on the 23-bit address line and then doing an 
asynchronous write with the CRE pin high. This process will overwrite the BCR, RCR, or DIDR 
depending on what address bits 18 and 19 are set to. The following attributes were chosen to configure 
the BCR: 
 Select BCR register 
 Synchronous mode 
 Fixed latency 
 Latency code 3 
 Wait active low 
 Wait asserted during delay  
 Full drive strength 
 No wrap 
 Continuous burst mode 
By selecting all of these options, the address needed to be set to “00010000101100000001111”. Selecting 
the BCR register, and synchronous mode sets the memory to be ready for a burst write or a burst read. 
The latency mode and the latency code are used instead of monitoring the wait pin back from memory. 
Using fixed latency, the data will start writing after a desired amount of clock cycles from the CE and he 
ADV pin going low. A fixed latency has been chosen over a variable latency for the same reason, 
avoiding the monitoring of the wait pin. Wait is active low which means that just before it starts writing 
data to memory the wait pin will be asserted low for 3 clock cycles before writing data. Full drive strength 
was chosen because power is not as issue in this problem. No wrap was selected because it is the way the 
end of the row writing was designed. Continuous burst mode was chosen to get the data out of the buffers 
as fast as possible, in continuous burst mode data is written until the end of the row of memory (up to 128 
words). 
 
The second step is simply waiting for an external switch to be set so that the buffers could start filling up. 
The third step is then to fill up two internal buffers with data from the ADCs, these buffers are the size of 
128 words so that it can write an entire row into memory. While an individual buffer was being dumped 
into memory, a second buffer is storing information from the ADCs so that data is not lost, and then when 
that second buffer fills up it is dumped into memory while the first starts to fill again. The burst write 
process is identified in figure 1.1 and shows which signals to toggle at which times. Once the data is 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX I  101 
 
written into memory, an asynchronous read can then be done to verify the contents of a specific memory 
address. 
 
Project Issues Using Burst Write: 
 
Due to a lack of time, burst write is not implemented in our final design. Our final design includes an 
asynchronous system and several fifo buffers. The system was able to write synchronously to memory but 
when the data was read back it did not match expected results. There were several issues that needed to be 
focused on. The largest issue that needed attention was the possibility of failure implementing fixed 
latency and specifying a latency code instead of using variable latency and monitoring the wait signal. 
Verifying the correct synthesis of the ADC simulator and making sure that the data was input at the 
correct times into the memory interface was also an important debugging step that we did not have time to 
complete. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX II  102 
 
APPENDIX II 
 
%MQP Trilateration Simulation 
  
%For the purposes of this simulation, we assume a plate 12cm by 12cm will  
%be used. On it, there are three sensors at locations (1,11), (11,11), and  
%(6,1), that are capable of detecting the exact time at which a wave  
%travelling from an impact point strikes them. The time of impact, t0, is  
%unknown; therefore each sensor n, where n=1, 2 or 3, can only detect times  
%tn-t0. 
  
%We also assume the speed of said wave in this plate is 10000 cm/s and that 
%the impact happens at point (10,5). This value is never used in the 
%simulation calculations but must be solved for, and is only used to  
%calculate the results that the sensors would generate: 
  
%v = 10000 
  
%R1 = sqrt(9^2 + 6^2) = 10.817 
%R2 = sqrt(1^2 + 6^2) = 6.083 
%R3 = sqrt(4^2 + 4^2) = 5.657 
  
%t1-t0 = 10.817/v = .0010817 = 1.082 ms 
%t2-t0 = 6.083/v = .0006083 = .608 ms 
%t3-t0 = 5.657/v = .0005657 = .566 ms 
  
%Assuming impact happens at some time t0=5ms, the sensors would return the 
%following data: 
  
%s1 - 6.082ms 
%s2 - 5.608ms 
%s3 - 5.566ms 
  
%Other than the predetermined locations of the sensors, this is the only 
%information the below simulation can use to find the impact point. 
  
  
%Defining sensor locations 
  
global x1 x2 x3 y1 y2 y3 
  
x1 = 1 
y1 = 11 
  
x2 = 11 
y2 = 11 
  
x3 = 6 
y3 = 1 
  
  
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX II  103 
 
%Defining sensor results and speed of wave 
  
global t1 t2 t3 v 
  
t1 = .006082 
t2 = .005608 
t3 = .005566 
  
v = 10000 
  
  
%Selecting the original estimation point in the center of the plate 
  
global xe1 ye1 
  
xe1 = 6 
ye1 = 6 
  
  
%Start of first iteration 
  
global R1 R2 R3 dx1 dy1 
  
R11 = sqrt(((xe1-x1)^2)+((ye1-y1)^2)) 
R21 = sqrt(((xe1-x2)^2)+((ye1-y2)^2)) 
R31 = sqrt(((xe1-x3)^2)+((ye1-y3)^2)) 
  
T1 = [0 0] 
T1(1) = (v*(t1-t2))+sqrt(((xe1-x2)^2)+((ye1-y2)^2))-sqrt(((xe1-x1)^2)+((ye1-y1)^2)) 
T1(2) = (v*(t1-t3))+sqrt(((xe1-x3)^2)+((ye1-y3)^2))-sqrt(((xe1-x1)^2)+((ye1-y1)^2)) 
  
A1 = [ 0 0; 0 0] 
A1(1) = (((xe1-x1)/R11)-((xe1-x2)/R21)) 
A1(2) = (((xe1-x1)/R11)-((xe1-x3)/R31)) 
A1(3) = (((ye1-y1)/R11)-((ye1-y2)/R21)) 
A1(4) = (((ye1-y1)/R11)-((ye1-y3)/R31)) 
  
E1 = [0 0] 
  
B1 = inv(A1) 
  
E1 = T1*B1 
  
dx1 = E1(1) 
dy1 = E1(2) 
  
  
%Start of second iteration 
  
global xe2 ye2 dx2 dy2 
  
xe2 = xe1 + dx1 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX II  104 
 
ye2 = ye1 + dy1 
  
R12 = sqrt(((xe2-x1)^2)+((ye2-y1)^2)) 
R22 = sqrt(((xe2-x2)^2)+((ye2-y2)^2)) 
R32 = sqrt(((xe2-x3)^2)+((ye2-y3)^2)) 
  
T2 = [0 0] 
T2(1) = (v*(t1-t2))+sqrt(((xe2-x2)^2)+((ye2-y2)^2))-sqrt(((xe2-x1)^2)+((ye2-y1)^2)) 
T2(2) = (v*(t1-t3))+sqrt(((xe2-x3)^2)+((ye2-y3)^2))-sqrt(((xe2-x1)^2)+((ye2-y1)^2)) 
  
A2 = [ 0 0; 0 0] 
A2(1) = (((xe2-x1)/R12)-((xe2-x2)/R22)) 
A2(2) = (((xe2-x1)/R12)-((xe2-x3)/R32)) 
A2(3) = (((ye2-y1)/R12)-((ye2-y2)/R22)) 
A2(4) = (((ye2-y1)/R12)-((ye2-y3)/R32)) 
  
E2 = [0 0] 
  
B2 = inv(A2) 
  
E2 = T2*B2 
  
dx2 = E2(1) 
dy2 = E2(2) 
  
  
%Start of third iteration 
  
global xe3 ye3 dx3 dy3 
  
xe3 = xe2 + dx2 
ye3 = ye2 + dy2 
  
R13 = sqrt(((xe3-x1)^2)+((ye3-y1)^2)) 
R23 = sqrt(((xe3-x2)^2)+((ye3-y2)^2)) 
R33 = sqrt(((xe3-x3)^2)+((ye3-y3)^2)) 
  
T3 = [0 0] 
T3(1) = (v*(t1-t2))+sqrt(((xe3-x2)^2)+((ye3-y2)^2))-sqrt(((xe3-x1)^2)+((ye3-y1)^2)) 
T3(2) = (v*(t1-t3))+sqrt(((xe3-x3)^2)+((ye3-y3)^2))-sqrt(((xe3-x1)^2)+((ye3-y1)^2)) 
  
A3 = [ 0 0; 0 0] 
A3(1) = (((xe3-x1)/R13)-((xe3-x2)/R23)) 
A3(2) = (((xe3-x1)/R13)-((xe3-x3)/R33)) 
A3(3) = (((ye3-y1)/R13)-((ye3-y2)/R23)) 
A3(4) = (((ye3-y1)/R13)-((ye3-y3)/R33)) 
  
E3 = [0 0] 
  
B3 = inv(A3) 
  
E3 = T3*B3 
 [2011]   [INTELLIGENT TACTICAL VEST] 
 
Worcester Polytechnic Institute | APPENDIX II  105 
 
  
dx3 = E3(1) 
dy3 = E3(2) 
  
  
%Start of fourth iteration 
  
global xe4 ye4 dx4 dy4 
  
xe4 = xe3 + dx3 
ye4 = ye3 + dx3 
  
R14 = sqrt(((xe4-x1)^2)+((ye4-y1)^2)) 
R24 = sqrt(((xe4-x2)^2)+((ye4-y2)^2)) 
R34 = sqrt(((xe4-x3)^2)+((ye4-y3)^2)) 
  
T4 = [0 0] 
T4(1) = (v*(t1-t2))+sqrt(((xe4-x2)^2)+((ye4-y2)^2))-sqrt(((xe4-x1)^2)+((ye4-y1)^2)) 
T4(2) = (v*(t1-t3))+sqrt(((xe4-x3)^2)+((ye4-y3)^2))-sqrt(((xe4-x1)^2)+((ye4-y1)^2)) 
  
A4 = [ 0 0; 0 0] 
A4(1) = (((xe4-x1)/R14)-((xe4-x2)/R24)) 
A4(2) = (((xe4-x1)/R14)-((xe4-x3)/R34)) 
A4(3) = (((ye4-y1)/R14)-((ye4-y2)/R24)) 
A4(4) = (((ye4-y1)/R14)-((ye4-y3)/R34)) 
  
E4 = [0 0] 
  
B4 = inv(A4) 
  
E4 = T4*B4 
  
dx4 = E4(1) 
dy4 = E4(2) 
  
  
  
  
  
  
   
  
  
 
 
