Adxl345 App Note an-1023

Embed Size (px)

Citation preview

  • 7/29/2019 Adxl345 App Note an-1023

    1/28

    AN-1023

    APPLICATION NOTEOneTechnologyWayP.O.Box9106Norwood,MA02062-9106,U.S.A.Tel:781.329.4700Fax:781.461.3113www.analog.com

    Fall Detection Application by Using 3-Axis Accelerometer ADXL345by Ning Jia

    Rev. 0 | Page 1 of 28

    INTRODUCTION

    Senior citizens often suffer accidental falls due to their dimi-

    nished self-care and self-protection ability. These accidents may

    possibly have serious consequences if no aid is given in time.

    Statistics show that the majority of serious consequences are not

    the direct result of the falls, but rather are due to a delay in

    assistance and treatment after a fall. In the event of a fall, the

    danger of post-fall consequences can be greatly reduced if relief

    personnel can be alerted in time. In light of this, there has been

    increased development of devices for detection and predictionof fall situations.

    In recent years, technological advancements in MEMS

    accelerometer sensors have made it possible to design a fall

    detector based on a 3-axis accelerometer sensor. These fall

    detectors operate on the principle of detecting changes in body

    position when moving by tracking acceleration changes in three

    orthogonal directions of an individual wearing a sensor. The

    data is then analyzed algorithmically to determine whether the

    individuals body is falling. If an individual falls, the device

    works with a GPS module and a wireless transmitter module to

    determine the position and issues an alert for assistance. The

    core part of the fall detector is therefore the detection principleand the algorithm to judge the existence of an emergency fall

    situation.

    TheADXL345is the latest 3-axis, digital output accelerometer

    from Analog Devices, Inc., and is well-suited for fall detector

    applications. This application note, based on the principle research

    of fall detection for an individual body, proposes a new solution

    for detection of such fall situations using the ADXL345.

    ADXL345 MEMS ACCELEROMETER

    Micro Electronic Mechanical Systems (MEMS) is a semiconductor

    technology that builds micromechanical structures and elec-

    trical circuits into a single silicon chip. The MEMS accelerometer

    is a sensor based on this technology to achieve acceleration sensing

    on single-axis, dual-axis, or tri-axis conditions. Depending on

    the application, the accelerometer may offer different ranges of

    detection from severalgto tens ofgof digital or analog output,

    and may have multiple interrupt modes. These features offer the

    user more convenient and flexible solutions.

    The ADXL345 is the latest MEMS 3-axis accelerometer with

    digital output from Analog Devices. It features a selectable 2g,

    4g, 8g, or 16gmeasurement range; up to 13-bit resolution;

    fixed 4 mg/LSB sensitivity; 3 mm 5 mm 1 mm ultrasmall

    package; 40 A to 145 A ultralow power consumption; standard

    I2C and SPI digital interface; 32-level FIFO storage; various

    built-in motion status detection options; and a flexible interrupt

    system. These features greatly simplify the algorithm for fall

    detection, and thus make ADXL345 an ideal accelerometer for

    fall detector applications. The fall detection solution, as proposed

    in this application note, is fully based on the ADXL345s interna

    functions of motion status detection and interrupt system, andthe complexity of the algorithm can be minimized with little

    requirement to access the actual acceleration values or to

    perform any other computations.

    The interrupt system of the ADXL345 is described in the

    Interrupts section. For more detailed specifications of the

    ADXL345, refer to the data sheet or visitwww.analog.com.

    Figure 1 shows the system block diagram and Figure 2 shows

    the pin definitions of the ADXL345.

    INT1

    INT2

    CS

    SDA/

    SDI/SDIO

    SDO/ALT

    ADDRESS

    SCL/SCLK

    VS VDD I/O

    DIGITAL

    FILTER

    32-LEAD

    FIFO

    ADC

    ADXL345

    3-AXIS

    SENSOR

    SENSE

    ELECTRONICS

    POWER

    MANAGEMENT

    CONTROL

    AND

    INTERRUPT

    LOGIC

    SERIAL I/O

    GND 08185-001

    Figure 1. ADXL345 System Block Diagram

    TOP VIEW

    (Not to Scale)

    14

    SCL/SCLK

    7

    1

    2

    3

    4

    5

    6

    VDD I/O

    GND

    RESERVED

    GND

    GND

    VS

    SDA/SDI/SDIO

    SDO/ALT ADDRESS

    RESERVED

    NC

    NC = NO CONNECT

    INT2

    INT1

    13

    12

    11

    10

    9

    8

    CS

    08185-002

    +Z

    +X

    +Y

    Figure 2. ADXL345 Pin Configuration

    http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/http://www.analog.com/http://www.analog.com/http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345
  • 7/29/2019 Adxl345 App Note an-1023

    2/28

    AN-1023 Application Note

    Rev. 0 | Page 2 of 28

    TABLE OF CONTENTSIntroduction ...................................................................................... 1ADXL345 MEMS Accelerometer ................................................... 1Interrupts ........................................................................................... 3Acceleration Change Characteristics during the Fall Process .... 4Typical Circuit Connection of the System .................................... 5

    Using the ADXL345 to Simplify Fall Detection Algorithms .......5Example Code ....................................................................................9Conclusion....................................................................................... 26References ........................................................................................ 26

  • 7/29/2019 Adxl345 App Note an-1023

    3/28

    Application Note AN-1023

    Rev. 0 | Page 3 of 28

    INTERRUPTS

    TheADXL345features two programmable interrupt pins, INT1

    and INT2, with a total of eight interrupts: DATA_READY,

    SINGLE_TAP, DOUBLE_TAP, activity, inactivity, FREE_FALL,

    watermark, and overrun. Each interrupt can be enabled or

    disabled independently by setting the appropriate bit in theINT_ENABLE register, with the option to map to either the

    INT1 or the INT2 pin.

    DATA_READY

    The DATA_READY bit is set when new data is available and

    cleared when no new data is available.

    SINGLE_TAP

    The SINGLE_TAP bit is set when a single acceleration event

    that is greater than the value in the THRESH_TAP register

    occurs for a shorter length of time than is specified in the DUR

    register.

    DOUBLE_TAPThe DOUBLE_TAP bit is set when two acceleration events that

    are greater than the value in the THRESH_TAP register occur

    for a shorter length of time than is specified in the DUR regis-

    ter, with the second tap starting after the time specified by the

    latent register and within the time specified in the window register.

    Figure 3 illustrates the valid SINGLE_TAP and DOUBLE_TAP

    interrupts.

    08185-003

    FIRST TAP

    TIME LIMIT FORTAPS (DUR)

    LATENCYTIME

    (LATENT)

    TIME WINDOW FORSECOND TAP (WINDOW)

    SECOND TAP

    SINGLE TAPINTERRUPT

    DOUBLE TAPINTERRUPT

    THRESHOLD(THRESH_TAP)

    X

    HIBW

    INTERRUPTS

    Figure 3. SINGLE_TAP and DOUBLE_TAP Interrupts

    Activity

    The activity bit is set when acceleration greater than the value

    stored in the THRESH_ACT register is experienced.

    Inactivity

    The inactivity bit is set when acceleration of less than the value

    stored in the THRESH_INACT register is experienced for a

    longer length of time than is specified in the TIME_INACT

    register. The maximum value for TIME_INACT is 255 sec. For

    the activity and inactivity interrupts, the user can individually

    enable or disable each x-, y-, or z-axis. For example, the activity

    interrupt for the x-axis can be enabled while disabling the

    interrupt for the y-axis and z-axis. Furthermore, the user can

    select between dc-coupled or ac-coupled operation mode for

    the activity and inactivity interrupts. In dc-coupled operation,

    the current acceleration is compared with THRESH_ACT and

    THRESH_INACT directly to determine whether activity or

    inactivity is detected. In ac-coupled operation for activity detec-

    tion, the acceleration value at the start of activity detection is

    taken as a reference value. New samples of acceleration are then

    compared to this reference value, and if the magnitude of the

    difference exceeds THRESH_ACT, the device triggers an activity

    interrupt. In ac-coupled operation for inactivity detection, a

    reference value is used again for comparison and is updated

    whenever the device exceeds the inactivity threshold. Once the

    reference value is selected, the device compares the magnitude

    of the difference between the reference value and the current

    acceleration with THRESH_INACT. If the difference is below

    THRESH_INACT for a total of TIME_INACT, the device is

    considered inactive and the inactivity interrupt is triggered.FREE_FALL

    The FREE_FALL bit is set when acceleration of less than the

    value stored in the THRESH_FF register is experienced for a

    longer length of time than is specified in the TIME_FF register.

    FREE_FALL interrupt is mainly used in detection of free-falling

    motion. As a result, the FREE_FALL interrupt differs from the

    inactivity interrupt in that all axes always participate, the timer

    period is much smaller (1.28 sec maximum), and it is always dc

    coupled.

    Watermark

    The watermark bit is set when the FIFO has filled up to the

    value stored in the samples register. It is cleared automatically

    when the FIFO is read and its content emptied below the value

    stored in the samples register. The FIFO in the ADXL345 has four

    operation modes: bypass mode, FIFO mode, stream mode, and

    trigger mode; and can store up to 32 samples (x-, y-, and z-

    axis). The FIFO function is an important and very useful

    feature for the ADXL345; however, the proposed solution for

    fall detection does not use the FIFO function and thus is not

    further discussed in this application note. For further details on

    the FIFO function, see the ADXL345 data sheet.

    Overrun

    The overrun bit is set when new data has replaced unread data.

    The precise operation of the overrun function depends on the

    FIFO mode. In bypass mode, the overrun bit is set when new

    data replaces unread data in the DATAX, DATAY, and DATAZ

    registers. In all other modes, the overrun bit is set when the

    FIFO is filled with 32 samples. The overrun bit is cleared by

    reading the FIFO contents, and is automatically cleared when

    the data is read.

    http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345
  • 7/29/2019 Adxl345 App Note an-1023

    4/28

    AN-1023 Application Note

    Rev. 0 | Page 4 of 28

    ACCELERATION CHANGE CHARACTERISTICSDURING THE FALL PROCESS

    The main research on the principles of fall detection focuses on

    the acceleration change characteristics during the process of a

    human body falling. Figure 4 to Figure 7 present the accelera-

    tion change curves during the motions of walking downstairs,walking upstairs, sitting down, and standing up from a chair.

    (The fall detector is belt-wired on the individuals body.)

    1024

    768

    512

    256

    0

    256

    512

    768

    1024

    1 51 101 151 201 251 301 351 401

    VALUE(256/g)

    SAMPLES (50/s)08185-004

    X-AXIS

    Y-AXIS

    Z-AXIS

    VECTOR SUM

    Figure 4. Acceleration Change Curves During Process of Walking Downstairs

    1024

    768

    512

    256

    0

    256

    512

    768

    1024

    1 51 101 151 201 251 301 351 401

    VALUE(256/g)

    SAMPLES (50/s)

    X-AXIS

    Y-AXIS

    Z-AXIS

    VECTOR SUM

    08185-005

    Figure 5. Acceleration Change Curves During Process of Walking Upstairs

    1024

    768

    512

    256

    0

    256

    512

    768

    1024

    1 51 101 151 201 251

    VALUE(256/g)

    SAMPLES (50/s)

    X-AXIS

    Y-AXIS

    Z-AXIS

    VECTOR SUM

    08185-006

    Figure 6. Acceleration Change Curves During Process of Sitting Down

    1024

    768

    512

    256

    0

    256

    512

    768

    1024

    1 51 101 151 201

    VALUE(256/g)

    SAMPLES (50/s)

    X-AXIS

    Y-AXIS

    Z-AXIS

    VECTOR SUM

    08185-007

    Figure 7. Acceleration Change Curves During Process of Standing Up

    512

    256

    0

    256

    512

    768

    1024

    1

    4 1 3

    2

    51 101 151 201

    VALUE(256/g)

    SAMPLES (50/s)

    X-AXIS

    Y-AXIS

    Z-AXIS

    VECTOR SUM

    2: IMPACT

    3: MOTIONLESS

    4: INITIAL STATUS

    1: WEIGHTLESSNESS

    08185-008

    Figure 8. Acceleration Change Curves During the Process of Falling

    Because the movement of senior citizens is comparatively slow,the acceleration change is not very conspicuous during the

    walking motions in Figure 4 and Figure 5. Figure 8 presents the

    acceleration change curves during the process of falling. By

    comparing Figure 8 with Figure 4 to Figure 7, it can be seen that

    there are four critical characteristics of a falling event. These

    four characteristics can be used as the criterion of the fall detec-

    tion. They are marked by the boxes in Figure 8 and explained in

    detail as follows.

    Weightlessness

    The phenomenon of weightlessness always occur at the start of

    a fall. This phenomenon becomes more significant during free-

    fall, and the vector sum of acceleration reduces to near 0g, Theduration depends on the height of the free-fall. Even though

    weightlessness during an ordinary fall is not as significant as

    that during a free-fall, the vector sum of acceleration is also less

    than 1g(generally greater than 1gunder normal conditions).

    Therefore, this is the first basis for determining the fall status

    that can be detected by the FREE_FALL interrupt of the ADXL345.

  • 7/29/2019 Adxl345 App Note an-1023

    5/28

    Application Note AN-1023

    Rev. 0 | Page 5 of 28

    Impact

    After experiencing weightlessness, the human body makes

    impact with the ground; the acceleration curve shows this as a

    large shock in Figure 8. This shock is detected by the activity

    interrupt of the ADXL345. Therefore, the second basis for

    determining a fall is the activity interrupt immediately after theFREE_FALL interrupt.

    Motionless

    Generally, the human body, after falling and making impact,

    cannot rise immediately. Instead, it remains in a motionless

    position for a short period. This is shown on the acceleration

    curve as a segment of a flat line in Figure 8, and is detected by the

    inactivity interrupt of the ADXL345. Therefore, the third basis

    for determining a fall situation is the inactivity interrupt after

    the activity interrupt.

    Initial Status

    After a fall, the human body turns over, so the acceleration in

    three axes is different from the initial status before the fall. If thefall detector is belt-wired on the human body to obtain the

    initial status of the acceleration, the acceleration data in three

    axes can be read after the inactivity interrupt, and the sampling

    data can then be compared with the initial status. Therefore, it

    is the fourth basis for determining a fall if the difference

    between sampling data and initial status exceeds a certain

    threshold, for example, 0.7g.

    The combination of these four bases of determination form the

    entire fall detection algorithm, and then the system can raise an

    alert accordingly for the fall status. The time interval between

    interrupts must be within a reasonable range. In normal cases,

    the time interval between the FREE_FALL interrupt (weightless-ness) and the activity interrupt (impact) should not be very long

    unless falling from a very tall distance. Similarly, the time interval

    between the activity interrupt (impact) and the inactivity inter-

    rupt (motionless) should not be very long. A practical example

    is given in the Using the ADXL345 to Simplify Fall Detection

    Algorithms section with a set of reasonable values. The related

    interrupt detection threshold and time parameters can be

    flexibly set as needed. Furthermore, if a fall results in serious

    consequences such as a coma, the human body remains

    motionless for an even longer period of time. This status can

    still be detected by the inactivity interrupt. Therefore, a critical

    alert can be sent out again if the inactive state was detected to

    continue for a certain long period of time after a fall.

    TYPICAL CIRCUIT CONNECTION OF THE SYSTEM

    The circuit connection between the ADXL345 and an MCU is

    very simple. For this application note, a test platform was

    created using the ADXL345 and theADuC7026microcontroller.

    Figure 9 shows the typical connection between the ADXL345

    and the ADuC7026. With the CS pin of the ADXL345 tied high,the ADXL345 works in I2C mode. The SDA and SCL are the

    data and the clock of the I2C bus, which are connected to the

    corresponding pins of the ADuC7026. A GPIO of the ADuC7026

    is connected to the SDO/ALT ADDRESS pin of the ADXL345

    to select the I2C address of the ADXL345. The INT1 pin of the

    ADXL345 is connected to an IRQ input of the ADuC7026 to

    generate the interrupt signal. Almost any MCU or processor

    can be used to access the ADXL345 with a circuit connection

    similar to the one shown in Figure 9. The ADXL345 can also

    work in SPI mode to achieve a higher data rate. For an example

    circuit for SPI connection, refer to the ADXL345 data sheet.

    ADXL345

    VS

    CS

    SDA/SDI/SDIO

    SCL/SCLK

    SDO/ALT ADDRESS

    INT1

    GND

    SDA

    SCL

    GPIO

    IRQ

    GND

    VDD I/OVDD

    3.3V

    ADuC702608185-009

    Figure 9. Typical Circuit Connection Between ADXL345 and MCU

    USING THE ADXL345 TO SIMPLIFY FALL

    DETECTION ALGORITHMSThis section presents the realization of the algorithm from the

    solution mentioned previously.

    Table 1 presents the function of each register and the values

    used in the present algorithm. Refer to the ADXL345 data

    sheet for detailed definitions of each register bit.

    Note that some of the registers presented in Table 1 have two

    algorithm setting values. This indicates that the algorithm

    switches between these two values to achieve different detection

    purposes. The algorithm flow chart is shown in Figure 10.

    http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADXL345
  • 7/29/2019 Adxl345 App Note an-1023

    6/28

    AN-1023 Application Note

    Rev. 0 | Page 6 of 28

    Table 1. ADXL345 Registers Function Descriptions

    HexAddress

    DecAddress Register Name Type

    ResetValue Description

    Settings inAlgorithm

    Function of the Settings inAlgorithm

    0x00 0 DEVID Read-only 0xE5 Device ID Read-only

    0x01 to0x1C

    1 to 28 Reserved Reserved Reserved, do notaccess

    Reserved

    0x1D 29 THRESH_TAP Read/write 0x00 Tap threshold Not used

    0x1E 30 OFSX Read/write 0x00 X-axis offset 0x06 X-axis offset compensation,obtain from initializationcalibration

    0x1F 31 OFSY Read/write 0x00 Y-axis offset 0xF9 Y-axis offset compensation,obtain from initializationcalibration

    0x20 32 OFSZ Read/write 0x00 Z-axis offset 0xFC Z-axis offset compensation,obtain from initializationcalibration

    0x21 33 DUR Read/write 0x00 Tap duration Not used

    0x22 34 Latent Read/write 0x00 Tap latency Not used

    0x23 35 Window Read/write 0x00 Tap window Not used

    0x24 36 THRESH_ACT Read/write 0x00 Activity threshold 0x20/0x08 Set activity threshold as2 g/0.5 g

    0x25 37 THRESH_INACT Read/write 0x00 Inactivity threshold 0x03 Set inactivity threshold as0.1875 g

    0x26 38 TIME_INACT Read/write 0x00 Inactivity time 0x02/0x0A Set inactivity time as 2 sec or10 sec

    0x27 39 ACT_INACT_CTL Read/write 0x00 Axis enable controlfor activity/inactivity

    0x7F/0xFF Enable activity and inactivityof x-, y-, z-axis, whereininactivity is ac-coupled mode,activity is dc-coupled/ac-coupled mode

    0x28 40 THRESH_FF Read/write 0x00 Free-fall threshold 0x0C Set free-fall threshold as 0.75 g

    0x29 41 TIME_FF Read/write 0x00 Free-fall time 0x06 Set free-fall time as 30 ms

    0x2A 42 TAP_AXES Read/write 0x00 Axis control for

    tap/double tap

    Not used

    0x2B 43 ACT_TAP_STATUS Read-only 0x00 Source ofactivity/tap

    Read-only

    0x2C 44 BW_RATE Read/write 0x0A Data rate and powermode control

    0x0A Set sample rate as 100 Hz

    0x2D 45 POWER_CTL Read/write 0x00 Power save featurescontrol

    0x00 Set as normal working mode

    0x2E 46 INT_ENABLE Read/write 0x00 Interrupt enablecontrol

    0x1C Enable activity, inactivity, free-fall interrupts

    0x2F 47 INT_MAP Read/write 0x00 Interrupt mappingcontrol

    0x00 Map all interrupts to INT1 pin

    0x30 48 INT_SOURCE Read-only 0x00 Source of interrupts Read-only

    0x31 49 DATA_FORMAT Read/write 0x00 Data format control 0x0B Set as 16 g measurement

    range, 13-bit right alignment,high level interrupt trigger, I2Cinterface

    0x32 50 DATAX0 Read-only 0x00 X-Axis Data 0 Read-only

    0x33 51 DATAX1 Read-only 0x00 X-Axis Data 1 Read-only

    0x34 52 DATAY0 Read-only 0x00 Y-Axis Data 0 Read-only

    0x35 53 DATAY1 Read-only 0x00 Y-Axis Data 1 Read-only

    0x36 54 DATAZ0 Read-only 0x00 Z-Axis Data 0 Read-only

    0x37 55 DATAZ1 Read-only 0x00 Z-Axis Data 1 Read-only

    0x38 56 FIFO_CTL Read/write 0x00 FIFO control Not used

    0x39 57 FIFO_STATUS Read-only 0x00 FIFO status Not used

  • 7/29/2019 Adxl345 App Note an-1023

    7/28

    Application Note AN-1023

    Rev. 0 | Page 7 of 28

    START

    INITIALIZATION

    NO

    NO

    YES

    YES

    YES

    YES

    YES

    YES

    YES

    YES

    YES

    NO

    NO

    NO

    NO

    NO

    NO

    NO

    FREE_FALL INTERRUPT

    ASSERTED?

    ACTIVITY INTERRUPTASSERTED?

    ACTIVITY INTERRUPT

    ASSERTED?

    INACTIVITY INTERRUPTASSERTED?

    INACTIVITY INTERRUPTASSERTED?

    STABLE STATUS IS DIFFERENTFROM INITIAL STATUS?

    TIMEOUT?

    GENERATE FALL ALERT

    GENERATECRITICAL ALERT

    GENERATE CRITICALFREE-FALL ALERT

    CONTINUOUS FREE_FALLDETECTED?

    TIMEOUT?

    08185-010

    Figure 10. Algorithm Flow Chart

  • 7/29/2019 Adxl345 App Note an-1023

    8/28

    AN-1023 Application Note

    Rev. 0 | Page 8 of 28

    Each interrupt threshold and related time parameter in the

    algorithm is as follows:

    1. After initialization, the system waits for the FREE_FALLinterrupt (weightlessness). THRESH_FF is set to 0.75gand

    TIME_FF is set to 30 ms.

    2.

    After the FREE_FALL interrupt is asserted, the systembegins waiting for the activity interrupt (impact).

    THRESH_ACT is set to 2gand the activity interrupt is

    operating in dc-coupled mode.

    3. The time interval between the FREE_FALL interrupt(weightlessness) and the activity interrupt (impact) is set to

    200 ms. If time between these two interrupts is greater than

    200 ms, then the status is not valid. The 200 ms counter is

    realized through the MCU timer.

    4. After the activity interrupt is asserted, the system beginswaiting for the inactivity interrupt (motionless after

    impact). THRESH_INACT is set to 0.1875gand

    TIME_INACT is set to 2 sec. The inactivity interrupt is

    operating in ac-coupled mode.5. The inactivity interrupt (motionless after impact) should

    be asserted within 3.5 sec after the activity interrupt

    (impact). Otherwise, the result is invalid. The 3.5 sec

    counter is realized through the MCU timer.

    6. If the acceleration difference between stable status andinitial status exceeds the 0.7gthreshold, a valid fall is

    detected and system raises a fall alert.

    7. After detecting a fall, the activity interrupt and inactivityinterrupt must be continuously monitored to determine if

    there is a long period of motionlessness after the fall. The

    THRESH_ACT is set to 0.5gand the activity interrupt is

    operating in ac-coupled mode. THRESH_INACT is set to

    0.1875g, TIME_INACT is set to 10 sec and the inactivity

    interrupt is operating in ac-coupled mode; that is, if the

    subjects body remains motionless for 10 sec, the inactivity

    interrupt is asserted and the system raises a critical alert.

    When the individuals body moves, the activity interrupt is

    generated and completes the entire sequence.

    8. The algorithm can also detect that if the human body freefalls from a tall distance. The two FREE_FALL interrupts

    are considered continuous if the interval between them is

    shorter than 100 ms. A critical free-fall alert is raised if the

    FREE_FALL interrupt (weightlessness) is continuously

    asserted for 300 ms

    m45.03.0102

    1

    2

    1 22 gtS

    This algorithm is developed in C language to be executed on the

    ADuC7026microcontroller. A test case is also presented with

    the proposed solution to verify the algorithm. Each position,including falling forward, falling backward, falling to the left,

    and falling to the right, is tested 20 times. The first 10 trials are

    the typical falls without prolonged motionless period after a fall

    and the second 10 trials are the typical falls with prolonged

    motionless period after fall. Table 2 presents the test results.

    From this experiment, the falling status can be effectively

    detected with the ADXL345-based proposed solution. Note that

    this is only a simple experiment and a more comprehensive,

    effective, and long-term experimentation is required to verify

    the reliability of this proposed solution.

    Table 2. Test Results

    Trial No.

    Test Condition Test ResultFalling Position

    With Prolonged MotionlessPeriod After Fall Fall Detected(No. of Times) Prolonged Motionless Detected(No. of Times)

    1 to 10 Falling forward No 10 0

    11 to 20 Falling forward Yes 10 10

    21 to 30 Falling backward No 10 0

    31 to 40 Falling backward Yes 10 10

    41 to 50 Falling to the left No 10 0

    51 to 60 Falling to the left Yes 10 10

    61 to 70 Falling to the right No 10 0

    71 to 80 Falling to the right Yes 10 10

    http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADuC7026
  • 7/29/2019 Adxl345 App Note an-1023

    9/28

    Application Note AN-1023

    Rev. 0 | Page 9 of 28

    EXAMPLE CODE

    This section presents the example C code of the proposed

    solution-based ADXL345 and ADuC7026 platform. There are

    four .h files and one .c file in the project, compiled by Keil UV3.

    The FallDetection.c file includes the fall detection algorithm.

    FallDetection.h details the definitions and variables used forthe fall detection algorithm, implementation of the ADXL345

    read/write functions, and ADXL345 initialization.

    ADuC7026Driver.h includes ADuC7026 GPIO control

    functions, I2C master read and write functions, and ADuC7026

    initialization. The xl345.h file includes ADXL345 registers and

    bit definitions. The xl345_io.h file includes wrapper functions

    for writing and reading bursts from/to the ADXL345 for both

    I2C and SPI.

    FallDetection.c

    #i ncl ude "Fal l Det ecti on. h" / / I ncl ude header f i l es

    voi d I RQ_Handl er ( ) __i r q / / I RQ i nt er r upt

    {

    unsi gned char i ;

    i f ( ( I RQSTA & GP_TI MER_BI T)==GP_TI MER_BI T) / / TI MER1 i nter r upt , i nter val 20ms

    {T1CLRI = 0; / / Cl ear TI MER1 i nt er r upt

    i f ( Det ect i onSt atus==0xF2) / / St r i ke af t er wei ght l essness i s det ect ed, wai t i ng f or st abl e

    {

    Ti mer Wai t For St abl e++;

    i f ( Ti merWai t ForStabl e>=STABLE_WI NDOW) / / Ti me out , r est ar t

    {

    I RQCLR = GP_TI MER_BI T; / / Di sabl e ADuC7026' s Ti mer1 i nter r upt

    Det ect i onStatus=0xF0;

    put char( Detect i onSt atus) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STRI KE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st er s[ XL345_TI ME_I NACT] =STABLE_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE | XL345_I NACT_Y_ ENABLE| XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE | XL345_ACT_X_ENABLE |XL345_ACT_DC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st ers[ XL345_THRESH_ACT] ) ;

    }

    }

    el se i f ( Det ect i onSt atus==0xF1) / / Wei ght l essness i s det ect ed, wai t i ng f or st r i ke

    {

    Ti mer Wai t For St r i ke++;

    i f ( Ti merWai t ForSt r i ke>=STRI KE_WI NDOW) / / Ti me out , r est art

    {

    I RQCLR = GP_TI MER_BI T; / / Di sabl e ADuC7026' s Ti mer1 i nter r uptDet ect i onStatus=0xF0;

    put char( Detect i onSt atus) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STRI KE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st er s[ XL345_TI ME_I NACT] =STABLE_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE | XL345_I NACT_Y_ ENABLE| XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE | XL345_ACT_X_ENABLE |XL345_ACT_DC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st ers[ XL345_THRESH_ACT] ) ;

    }

    http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADuC7026http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345
  • 7/29/2019 Adxl345 App Note an-1023

    10/28

    AN-1023 Application Note

    Rev. 0 | Page 10 of 28

    }

    }

    i f ( ( I RQSTA&SPM4_I O_BI T)==SPM4_I O_BI T) / / External i nter r upt f orm ADXL345 I NT0

    {

    I RQCLR = SPM4_I O_BI T; / / Di sabl e ADuC7026' s ext ernal i nter r upt

    xl 345Read( 1, XL345_I NT_SOURCE, &ADXL345Regi st er s[ XL345_I NT_SOURCE] ) ;i f ( ( ADXL345Regi st ers [ XL345_I NT_SOURCE]&XL345_ACTI VI TY) ==XL345_ACTI VI TY) / / Act i vi t y i nter r upt

    asser t ed

    {

    i f ( Det ect i onSt atus==0xF1) / / Wai t i ng f or st r i ke, and now st r i ke i s det ect ed

    {

    Detect i onStat us=0xF2; / / Go t o Stat us "F2"

    putchar ( Detect i onStat us) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STABLE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st ers[ XL345_TI ME_I NACT] =STABLE_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE | XL345_I NACT_Y_ ENABLE

    | XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE | XL345_ACT_X_ENABLE |XL345_ACT_AC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st er s[ XL345_THRESH_ACT] ) ;

    I RQEN| =GP_TI MER_BI T; / / Enabl e ADuC7026' s Ti mer1 i nter r upt

    Ti mer Wai t For St abl e=0;

    }

    el se i f ( Detect i onSt atus==0xF4) / / Wai t i ng f or l ong t i me moti onl ess, but a movement i sdet ected

    {

    Detect i onStat us=0xF0; / / Go t o St atus "F0", r estar t

    putchar ( Detect i onStat us) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STRI KE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st ers[ XL345_TI ME_I NACT] =STABLE_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE | XL345_I NACT_Y_ ENABLE| XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE | XL345_ACT_X_ENABLE |XL345_ACT_DC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st er s[ XL345_THRESH_ACT] ) ;

    }

    }

    el se i f ( ( ADXL345Regi st ers [ XL345_I NT_SOURCE]&XL345_I NACTI VI TY) ==XL345_I NACTI VI TY) / / I nact i vi t yi nt er rupt assert ed

    {

    i f ( Detect i onSt atus==0xF2) / / Wai t i ng f or stabl e, and now st abl e i s detect ed

    {

    Detect i onStat us=0xF3; / / Go t o Stat us "F3"I RQCLR = GP_TI MER_BI T;

    putchar ( Detect i onStat us) ;

    xl 345Read( 6, XL345_DATAX0, &ADXL345Regi st er s[ XL345_DATAX0] ) ;

    Del t aVect or Sum=0;

    f or( i =0; i

  • 7/29/2019 Adxl345 App Note an-1023

    11/28

    Application Note AN-1023

    Rev. 0 | Page 11 of 28

    Accel erat i on[ i ] =Accel erat i on[ i ] +0x1000;

    }

    el se / / i f ( Accel erati on[ i ] >= 0x1000)

    {

    Accel erati on[ i ] =Accel er at i on[ i ] - 0x1000;

    }i f (Accel erat i on[ i ]>I ni t i al Status [ i ] )

    {

    Del t aAccel erat i on[ i ] =Accel erat i on[ i ] - I ni t i al Status[ i ] ;

    }

    el se

    {

    Del t aAccel erat i on[ i ] =I ni t i al Status[ i ] - Accel erat i on[ i ] ;

    }

    Del t aVector Sum=Del t aVector Sum+Del t aAccel erat i on[ i ] *Del t aAccel erat i on[ i ] ;

    }

    i f ( Del t aVect orSum>DELTA_VECTOR_SUM_THRESHOLD) / / The st abl e st atus i s di f f erent

    f romt he ini t i al s tatus{

    Det ect i onSt at us=0xF4; / / Val i d f al l det ect i on

    put char( Detect i onSt atus) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STABLE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st er s[ XL345_TI ME_I NACT] =NOMOVEMENT_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE |XL345_I NACT_Y_ ENABLE | XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE |XL345_ACT_X_ENABLE | XL345_ACT_AC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st ers[ XL345_THRESH_ACT] ) ;

    }

    el se / / Del t a vect or sum does not exceed t he t hr eshol d

    {

    Detect i onSt atus=0xF0; / / Go t o Stat us "F0", r estar

    put char( Detect i onSt atus) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STRI KE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st er s[ XL345_TI ME_I NACT] =STABLE_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE |XL345_I NACT_Y_ ENABLE | XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE |XL345_ACT_X_ENABLE | XL345_ACT_DC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st ers[ XL345_THRESH_ACT] ) ;

    }

    }

    el se i f ( Detect i onSt atus==0xF4) / / Wai t f or l ong t i me moti onl ess, and now i t i s detect ed

    {

    Det ecti onSt at us=0xF5; / / Val i d cri t i cal f al l det ecti on

    put char( Detect i onSt atus) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STRI KE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st er s[ XL345_TI ME_I NACT] =STABLE_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE | XL345_I NACT_Y_ ENABLE| XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE | XL345_ACT_X_ENABLE |XL345_ACT_DC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st er s[ XL345_THRESH_ACT] ) ;

  • 7/29/2019 Adxl345 App Note an-1023

    12/28

    AN-1023 Application Note

    Rev. 0 | Page 12 of 28

    Detect i onStat us=0xF0; / / Go t o St atus "F0", r estar t

    putchar ( Detect i onStat us) ;

    }

    }

    el se i f ( ( ADXL345Regi st ers[ XL345_I NT_SOURCE]&XL345_FREEFALL) ==XL345_FREEFALL) / / Fr ee f al li nt er rupt assert ed

    {

    i f ( Detect i onSt atus==0xF0) / / Wai t i ng f or wei ght l ess, and now i t i s det ected

    {

    Detect i onStat us=0xF1; / / Go t o Stat us "F1"

    putchar ( Detect i onStat us) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STRI KE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st ers[ XL345_TI ME_I NACT] =STABLE_TI ME;

    ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE | XL345_I NACT_Y_ ENABLE| XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE | XL345_ACT_X_ENABLE |XL345_ACT_DC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st er s[ XL345_THRESH_ACT] ) ;

    I RQEN| =GP_TI MER_BI T; / / Enabl e ADuC7026' s Ti mer1 i nter r upt

    Ti mer Wai t For St r i ke=0;

    Ti mer Fr eeFal l =0;

    }

    el se i f ( Detect i onStat us==0xF1) / / Wai t i ng f or st r i ke af t er wei ght l ess, and now a newf ree f al l i s det ected

    {

    i f ( Ti mer Wai t For St r i ke=FREE_FALL_OVERTI ME) / / I f t he cont i nuous ti me of f r ee f al l i s l ongert han "FREE_FALL_ OVERTI ME"

    { / / Consi der t hat a f ree f al l fr om hi gh pl ace i s det ected

    Det ect i onStat us=0xFF;

    putchar ( Detect i onStat us) ;

    ADXL345Regi st er s[ XL345_THRESH_ACT] =STRI KE_THRESHOLD;

    ADXL345Regi st er s[ XL345_THRESH_I NACT] =NOMOVEMENT_THRESHOLD;

    ADXL345Regi st ers[ XL345_TI ME_I NACT] =STABLE_TI ME;ADXL345Regi st er s[ XL345_ACT_I NACT_CTL] =XL345_I NACT_Z_ENABLE | XL345_I NACT_Y_ ENABLE

    | XL345_I NACT_X_ENABLE | XL345_I NACT_AC | XL345_ACT_Z_ENABLE | XL345_ACT_Y_ ENABLE | XL345_ACT_X_ENABLE |XL345_ACT_DC;

    xl 345Wr i t e( 4, XL345_THRESH_ACT, &ADXL345Regi st er s[ XL345_THRESH_ACT] ) ;

    Det ect i onStat us=0xF0;

    putchar ( Detect i onStat us) ;

    }

    }

    el se

    {

  • 7/29/2019 Adxl345 App Note an-1023

    13/28

    Application Note AN-1023

    Rev. 0 | Page 13 of 28

    Ti mer Fr eeFal l =0;

    }

    }

    I RQEN | =SPM4_I O_BI T; / / Enabl e ADuC7026' s ext ernal i nter r upt

    }

    }

    voi d mai n(voi d)

    {

    ADuC7026_I ni t i ate() ; / / ADuC7026 i ni t i al i zat i on

    ADXL345_I ni t i at e( ) ; / / ADXL345 i ni t i al i zat i on

    Detecti onSt at us=0xF0; / / Cl ear det ect i on st at us, st ar t

    I ni t i al St atus[0]=0x1000; / / X axi s=0g, unsi gned shor t i nt , 13 bi t r esol ut i on, 0x1000 = 4096 = 0g,+/ - 0xFF = +/ - 256 = +/ - 1g

    I ni t i al St atus[1]=0x0F00; / / Y axi s=- 1g

    I ni t i al St atus[2]=0x1000; / / Z axi s=0g

    I RQEN =SPM4_I O_BI T; / / Enabl e ADuC7026' s ext ernal i nt err upt , t o r ecei ve t he i nter r upt f r omADXL345 I NT0

    whi l e( 1) / / Endl ess l oop, wai t f or i nt er rupt s

    {

    ;

    }

    }

  • 7/29/2019 Adxl345 App Note an-1023

    14/28

    AN-1023 Application Note

    Rev. 0 | Page 14 of 28

    FallDetection.h

    #i ncl ude " ADuC7026Dr i ver . h"

    #i ncl ude " xl 345. h"

    #i ncl ude "xl 345_i o. h"

    / / Def i ni t i ons used f or Fal l Det ecti on Al gori t hm

    #def i ne STRI KE_THRESHOLD 0x20 / / 62. 5mg/ LSB, 0x20=2g

    #def i ne STRI KE_WI NDOW 0x0A / / 20ms/ LSB, 0x0A=10=200ms

    #def i ne STABLE_THRESHOLD 0x08 / / 62. 5mg/ LSB, 0x10=0. 5g

    #def i ne STABLE_TI ME 0x02 / / 1s/ LSB, 0x02=2s

    #def i ne STABLE_WI NDOW 0xAF / / 20ms/ LSB, 0xAF=175=3. 5s

    #def i ne NOMOVEMENT_THRESHOLD 0x03 / / 62. 5mg/ LSB, 0x03=0. 1875g

    #def i ne NOMOVEMENT_TI ME 0x0A / / 1s/ LSB, 0x0A=10s

    #def i ne FREE_FALL_THRESHOLD 0x0C / / 62. 5mg/ LSB, 0x0C=0. 75g

    #def i ne FREE_FALL_TI ME 0x06 / / 5ms/ LSB, 0x06=30ms

    #def i ne FREE_FALL_ OVERTI ME 0x0F / / 20ms/ LSB, 0x0F=15=300ms

    #def i ne FREE_FALL_I NTERVAL 0x05 / / 20ms/ LSB, 0x05=100ms

    #def i ne DELTA_VECTOR_SUM_THRESHOLD 0x7D70 / / 1g=0xFF, 0x7D70=0. 7g 2

    / / Vari abl es used f or Fal l Det ecti on Al gori t hm

    unsi gned char Detect i onStat us; / / Detect i on st atus:

    / / 0xF0: St ar t

    / / 0xF1: Wei ght l essness

    / / 0xF2: St r i ke af t er wei ght l essness

    / / 0xF3: Stabl e af t er str i ke, val i d f al l detect i on

    / / 0xF4: Long t i me mot i onl ess, val i d cri t i cal f al l det ecti on

    / / 0xFF: Cont i nuous f ree f al l , f ree f al l f roma hi gh pl ace

    unsi gned char Ti mer Wai t For St abl e; / / Count er of t i me t hat wai t f or stabl e aft er st r i ke

    unsi gned char Ti mer Wai t For St r i ke; / / Count er of t i me t hat wai t f or str i ke aft er wei ght l ess

    unsi gned char Ti mer FreeFal l ; / / Count er of cont i nuous t i me f or f r ee f al l

    uns i gned short i nt I ni t i al Status [3] ; / / I ni t i al s tatus f or X- , Y- , Z- axi s

    unsi gned shor t i nt Accel erati on[ 3] ; / / Accel er at i on f or X- , Y- , Z- axi s

    unsi gned l ong i nt Del t aAccel erati on[ 3] ; / / Accel er at i on[ ] - I ni t i al _St at us[]

    unsi gned l ong i nt Del t aVector Sum; / / Vector sum of t he Del t aAccel erat i on[ ]

    BYTE ADXL345Regi st ers [ 57]; / / ADXL345 r egi st ers arr ay, t otal 57 r egi st ers i n ADXL345

    / / I mpl ement at i on of t he r ead f unct i on based ADuC7026

    voi d xl 345Read(unsi gned char count, unsi gned char r egaddr, unsi gned char *buf ){

    BYTE r ;

    WORD Regi st er Addr ess ;

    f or (r =0; r

  • 7/29/2019 Adxl345 App Note an-1023

    15/28

    Application Note AN-1023

    Rev. 0 | Page 15 of 28

    }

    / / I mpl ement at i on of t he wr i t e f unct i on based ADuC7026

    voi d xl 345Wr i t e(unsi gned char count, unsi gned char r egaddr, unsi gned char *buf )

    {

    BYTE r ;WORD Regi st er Address ;

    f or ( r =0; r

  • 7/29/2019 Adxl345 App Note an-1023

    16/28

    AN-1023 Application Note

    Rev. 0 | Page 16 of 28

    ADuC7026Driver.h

    #i ncl ude

    / / Def i ni t i ons of dat a t ype

    #def i ne BYTE unsi gned char / / 8_bi t s#def i ne WORD unsi gned shor t i nt / / 16_bi t s

    #def i ne DWORD unsi gned l ong i nt / / 32_bi t s

    #def i ne ADXL345_I 2C_ADDRESS_SELECT 0x40 / / GPI O: P4. 0, t o sel ect t he ADXL345' s I 2C addr ess

    / / Vari abl es for I 2C operat i on, t o i mpl ement bur st r ead/ wr i t e based ADuC7026, maxi mum number t o bur str ead/ wr i t e i s 8 bytes

    BYTE St eps, Stat us;

    BYTE ReadDat a[ 8] , Wr i t eData[ 9] ;

    / / Rewr i t e t he put char( ) f unct i on, send one byte dat a vi a UART

    i nt put char ( i nt ch){

    COMTX=ch;

    whi l e( ! ( 0x020==( COMSTA0 & 0x020) ) )

    {; }

    r eturn ch;

    }

    / / GPI O Cont r ol f unct i ons

    voi d Output Bi t ( BYTE GPI ONum, BYTE Data) / / Wr i t e t he pi n of "GPI ONum" wi t h "Dat a" (0 or 1)

    {

    DWORD Temp;

    Temp=14)

    {

    case 0:

    GP0DAT| =( Temp

  • 7/29/2019 Adxl345 App Note an-1023

    17/28

    Application Note AN-1023

    Rev. 0 | Page 17 of 28

    GP1SET=( Temp

  • 7/29/2019 Adxl345 App Note an-1023

    18/28

    AN-1023 Application Note

    Rev. 0 | Page 18 of 28

    / / M=1

    / / N=01101010101=853

    / / M+N/ 2048=1. 4165

    / / 41. 78MHz/ ( 16*2*2 CD*DL* ( M+N/ 2048)) / / CD=0 DL=0B=11

    / / 115. 2Kbps M+N/ 2048 =1. 0303 M=1, N=62=0x3EH=000 0011 1110

    / / comdi v2=0x883E}

    voi d I 2C1_I ni t i at e( ) / / ADuC7026 I 2C1 i ni t i al i zat i on, i ni t i at e t he I 2C1 Port t o 100kbps

    {

    GP1CON = 0x2211; / / I 2C on P1. 2 and P1. 3. Set up tx & r x pi ns on P1. 0 and P1. 1 f or UART

    I 2C1CFG = 0x82; / / Mast er Enabl e & Enabl e Generat i on of Mast er Cl ock

    I 2C1DI V = 0x3232; / / 0x3232 = 400kHz

    / / 0xCFCF = 100kHz

    FI QEN | = SM_MASTER1_BI T; / / Enabl e I 2C1 Mast er I nter upt

    }

    voi d Ti mer 1_I ni t i at e( ) / / ADuC7026 Ti mer 1 i ni t i al i zat i on, I nt erval = 20ms{

    T1LD = 0xCC010;

    T1CON = 0xC0;

    }

    voi d ADuC7026_I ni t i at e(voi d) / / ADuC7026 i ni t i al i zat i on, i ni t i at e the UART, I 2C1, Ti mer1, and GPI Os

    {

    UART_I ni t i at e( ) ;

    I 2C1_ I ni t i ate( ) ;

    Ti mer 1_I ni t i at e( ) ;

    Output Bi t ( ADXL345_I 2C_ADDRESS_SELECT, 0) ; / / Gr oundi ng t he SDO ( p4. 0) , I 2C addr ess f or wr i t i ng and

    r eadi ng i s 0xA6 and 0xA7}

    / / ADuC7026 I 2C1 Mast er , i mpl ement bur st r ead/ wr i t e based ADuC7026, maxi mum number t o burs t r ead/ wr i t e i s 8byt es

    / / suppor t 1 byt e addr ess and dual byt e addr ess

    / / enabl e I 2C1 i nt err upt as FI Q i nt err upt , bur st read/ wri t e i s real i zed i n t he FI Q i nt err upt

    voi d Wr i t eVi aI 2C( BYTE Devi ceAddr , BYTE Addr Type, BYTE Number Of Wr i t eByt es)

    / / Wr i t e "Number Of Wr i t eBytes" data t o "Devi ceAddr " address

    / / Addr Type=0, s i ngl e- byt e address; Addr Type=1, dual byt e address

    / / Data to wr i t e i s saved i n "Wr i t eDat a[ ] "

    {St at us=0;

    St eps=NumberOf Wr i t eBytes+Addr Type+1;

    I 2C1ADR = Devi ceAddr

  • 7/29/2019 Adxl345 App Note an-1023

    19/28

    Application Note AN-1023

    Rev. 0 | Page 19 of 28

    voi d ReadVi aI 2C( BYTE Devi ceAddr , BYTE Addr Type, BYTE NumberOf ReadByt es)

    / / Read "Number Of Wr i t eByt es" data f r om "Devi ceAddr " address

    / / Addr Type=0, si ngl e byt e address; Addr Type=1, dual byt e address

    / / Readback data i s saved i n "ReadData[ ] "

    {St at us=0;

    St eps=AddrType+1;

    I 2C1ADR = Devi ceAddr

  • 7/29/2019 Adxl345 App Note an-1023

    20/28

    AN-1023 Application Note

    Rev. 0 | Page 20 of 28

    xl345.h

    / * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

    The pr esent f i r mwar e, whi ch i s f or gui dance onl y, ai ms at pr ovi di ng

    cust omers wi t h codi ng i nf ormati on r egardi ng thei r pr oduct s i n or der

    f or t hem t o save t i me. As a r esul t , Anal og Devi ces shal l not be

    hel d l i abl e for any di r ect , i ndi r ect , or consequent i al damages wi t hr espect t o any cl ai ms ari si ng f r omt he cont ent of such fi r mware and/ or

    t he use made by cust omers of t he codi ng i nf ormat i on contai ned herei n

    i n connect i on wi t h thei r pr oducts.

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - * /

    #i f ndef _ _XL345_H

    #def i ne __ XL345_H

    / * - - - I 2C addresses - - - */

    / * The pr i mary sl ave addr ess i s used when the SDO pi n i s t i ed or pul l ed

    hi gh. The al t ernat e address i s sel ect ed when t he SDO pi n i s t i ed or

    pul l ed l ow. When bui l di ng t he har dware, i f you i nt end t o use I 2C,

    t he st ate of t he SDO pi n must be set . The SDO pi n i s al so used f or

    SPI communi cati on. To save syst empower, t here i s no i nt ernal pul l - up

    or pul l - down. */

    #def i ne XL345_SLAVE_ADDR 0x1d

    #def i ne XL345_ALT_ADDR 0x53

    / * addi t i onal I 2C def i nes f or communi cat i ons f unct i ons t hat need t he

    addr ess shi f t ed wi t h t he r ead/ wr i t e bi t appended */

    #def i ne XL345_SLAVE_READ XL345_SLAVE_ADDR

  • 7/29/2019 Adxl345 App Note an-1023

    21/28

    Application Note AN-1023

    Rev. 0 | Page 21 of 28

    #def i ne XL345_I NT_MAP 0x2f

    #def i ne XL345_I NT_SOURCE 0x30

    #def i ne XL345_DATA_FORMAT 0x31

    #def i ne XL345_DATAX0 0x32

    #def i ne XL345_DATAX1 0x33

    #def i ne XL345_DATAY0 0x34#def i ne XL345_DATAY1 0x35

    #def i ne XL345_DATAZ0 0x36

    #def i ne XL345_DATAZ1 0x37

    #def i ne XL345_FI FO_CTL 0x38

    #def i ne XL345_FI FO_STATUS 0x39

    / * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

    Bi t f i el d def i ni t i ons and regi ster val ues

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - * /

    / / #def i ne XL345_

    / * r egi st er val ues f or DEVI D */

    / * The devi ce I D shoul d al ways r ead thi s val ue, The cust omer does notneed t o use thi s val ue but i t can be r ead t o check t hat t he

    devi ce can communi cat e */

    #def i ne XL345_I D 0xe5

    / * Reser ved sof t r eset val ue */

    #def i ne XL345_SOFT_RESET 0x52

    / * Regi st ers THRESH_TAP t hrough TI ME_I NACT t ake onl y 8- bi t val ues

    There ar e no speci f i c bi t f i el ds i n t hese r egi st er s */

    / * Bi t val ues i n ACT_I NACT_CTL */

    #def i ne XL345_I NACT_Z_ENABLE 0x01

    #def i ne XL345_I NACT_Z_DI SABLE 0x00

    #def i ne XL345_I NACT_Y_ ENABLE 0x02

    #def i ne XL345_I NACT_Y_ DI SABLE 0x00

    #def i ne XL345_I NACT_X_ENABLE 0x04

    #def i ne XL345_I NACT_X_DI SABLE 0x00

    #def i ne XL345_I NACT_AC 0x08

    #def i ne XL345_I NACT_DC 0x00

    #def i ne XL345_ACT_Z_ENABLE 0x10

    #def i ne XL345_ACT_Z_DI SABLE 0x00

    #def i ne XL345_ACT_Y_ ENABLE 0x20

    #def i ne XL345_ACT_Y_ DI SABLE 0x00

    #def i ne XL345_ACT_X_ENABLE 0x40

    #def i ne XL345_ACT_X_DI SABLE 0x00

    #def i ne XL345_ACT_AC 0x80

    #def i ne XL345_ACT_DC 0x00

    / * Regi st ers THRESH_FF and TI ME_FF take onl y 8- bi t val ues

    There ar e no speci f i c bi t f i el ds i n t hese r egi st er s */

    / * Bi t val ues i n TAP_AXES */

  • 7/29/2019 Adxl345 App Note an-1023

    22/28

    AN-1023 Application Note

    Rev. 0 | Page 22 of 28

    #def i ne XL345_TAP_Z_ENABLE 0x01

    #def i ne XL345_TAP_Z_DI SABLE 0x00

    #def i ne XL345_TAP_Y_ENABLE 0x02

    #def i ne XL345_TAP_Y_DI SABLE 0x00

    #def i ne XL345_TAP_X_ENABLE 0x04

    #def i ne XL345_TAP_X_DI SABLE 0x00#def i ne XL345_TAP_SUPPRESS 0x08

    / * Bi t val ues i n ACT_TAP_STATUS */

    #def i ne XL345_TAP_Z_SOURCE 0x01

    #def i ne XL345_TAP_Y_ SOURCE 0x02

    #def i ne XL345_TAP_X_SOURCE 0x04

    #def i ne XL345_STAT_ASLEEP 0x08

    #def i ne XL345_ACT_Z_SOURCE 0x10

    #def i ne XL345_ACT_Y_SOURCE 0x20

    #def i ne XL345_ACT_X_SOURCE 0x40

    / * Bi t val ues i n BW_RATE *// * Expresed as output data r ate */

    #def i ne XL345_RATE_3200 0x0f

    #def i ne XL345_RATE_1600 0x0e

    #def i ne XL345_RATE_800 0x0d

    #def i ne XL345_RATE_400 0x0c

    #def i ne XL345_RATE_200 0x0b

    #def i ne XL345_RATE_100 0x0a

    #def i ne XL345_RATE_50 0x09

    #def i ne XL345_RATE_25 0x08

    #def i ne XL345_RATE_12_5 0x07

    #def i ne XL345_RATE_6_25 0x06

    #def i ne XL345_RATE_3_125 0x05

    #def i ne XL345_RATE_1_563 0x04

    #def i ne XL345_RATE__782 0x03

    #def i ne XL345_RATE__39 0x02

    #def i ne XL345_RATE__195 0x01

    #def i ne XL345_RATE__098 0x00

    / * Expressed as output bandwi dth * /

    / * Use ei t her t he bandwi dth or r ate code,

    whi chever i s more appropr i ate f or your appl i cati on */

    #def i ne XL345_BW_1600 0x0f

    #def i ne XL345_BW_800 0x0e

    #def i ne XL345_BW_400 0x0d

    #def i ne XL345_BW_200 0x0c

    #def i ne XL345_BW_100 0x0b

    #def i ne XL345_BW_50 0x0a

    #def i ne XL345_BW_25 0x09

    #def i ne XL345_BW_12_5 0x08

    #def i ne XL345_BW_6_25 0x07

    #def i ne XL345_BW_3_125 0x06

    #def i ne XL345_BW_1_563 0x05

    #def i ne XL345_BW__782 0x04

  • 7/29/2019 Adxl345 App Note an-1023

    23/28

    Application Note AN-1023

    Rev. 0 | Page 23 of 28

    #def i ne XL345_BW__39 0x03

    #def i ne XL345_BW__195 0x02

    #def i ne XL345_BW__098 0x01

    #def i ne XL345_BW__048 0x00

    #def i ne XL345_LOW_POWER 0x08#def i ne XL345_LOW_NOI SE 0x00

    / * Bi t val ues i n POWER_CTL */

    #def i ne XL345_WAKEUP_8HZ 0x00

    #def i ne XL345_WAKEUP_4HZ 0x01

    #def i ne XL345_WAKEUP_2HZ 0x02

    #def i ne XL345_WAKEUP_1HZ 0x03

    #def i ne XL345_SLEEP 0x04

    #def i ne XL345_MEASURE 0x08

    #def i ne XL345_STANDBY 0x00

    #def i ne XL345_AUTO_SLEEP 0x10

    #def i ne XL345_ACT_I NACT_SERI AL 0x20

    #def i ne XL345_ACT_I NACT_CONCURRENT 0x00

    / * Bi t val ues i n I NT_ENABLE, I NT_MAP, and I NT_SOURCE ar e i denti cal .

    Use t hese bi t val ues t o r ead or wr i t e any of t hese r egi st ers. */

    #def i ne XL345_OVERRUN 0x01

    #def i ne XL345_WATERMARK 0x02

    #def i ne XL345_FREEFALL 0x04

    #def i ne XL345_I NACTI VI TY 0x08

    #def i ne XL345_ACTI VI TY 0x10

    #def i ne XL345_DOUBLETAP 0x20

    #def i ne XL345_SI NGLETAP 0x40

    #def i ne XL345_DATAREADY 0x80

    / * Bi t val ues i n DATA_FORMAT */

    / * Regi st er val ues r ead i n DATAX0 t hrough DATAZ1 are dependent on the

    val ue speci f i ed i n data f ormat. Cust omer code wi l l need t o i nt erpret

    t he data as desi r ed. */

    #def i ne XL345_RANGE_2G 0x00

    #def i ne XL345_RANGE_4G 0x01

    #def i ne XL345_RANGE_8G 0x02

    #def i ne XL345_RANGE_16G 0x03

    #def i ne XL345_DATA_J UST_RI GHT 0x00

    #def i ne XL345_DATA_J UST_LEFT 0x04

    #def i ne XL345_10BI T 0x00

    #def i ne XL345_FULL_ RESOLUTI ON 0x08

    #def i ne XL345_I NT_LOW 0x20

    #def i ne XL345_I NT_HI GH 0x00

    #def i ne XL345_SPI 3WI RE 0x40

    #def i ne XL345_SPI 4WI RE 0x00

    #def i ne XL345_SELFTEST 0x80

    / * Bi t val ues i n FI FO_CTL */

    / * The l ow bi t s ar e a val ue 0 to 31 used f or t he watermark or t he number

  • 7/29/2019 Adxl345 App Note an-1023

    24/28

    AN-1023 Application Note

    Rev. 0 | Page 24 of 28

    of pre- t r i gger sampl es when i n t r i ggered mode */

    #def i ne XL345_TRI GGER_I NT1 0x00

    #def i ne XL345_TRI GGER_I NT2 0x20

    #def i ne XL345_FI FO_MODE_BYPASS 0x00

    #def i ne XL345_FI FO_RESET 0x00

    #def i ne XL345_FI FO_MODE_FI FO 0x40#def i ne XL345_FI FO_MODE_STREAM 0x80

    #def i ne XL345_FI FO_MODE_TRI GGER 0xc0

    / * Bi t val ues i n FI FO_STATUS */

    / * The l ow bi t s ar e a val ue 0 to 32 showi ng t he number of ent r i es

    curr ent l y avai l abl e i n t he FI FO buf f er */

    #def i ne XL345_FI FO_TRI GGERED 0x80

    #endi f / * _ _XL345_H */

  • 7/29/2019 Adxl345 App Note an-1023

    25/28

    Application Note AN-1023

    Rev. 0 | Page 25 of 28

    xl345_io.h

    / * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

    The present f i r mwar e, whi ch i s f or gui dance onl y, ai ms at pr ovi di ng

    cust omers wi t h codi ng i nf ormati on r egardi ng t hei r product s i n or der

    f or t hemt o save t i me. As a r esul t , Anal og Devi ces shal l not be

    hel d l i abl e for any di r ect , i ndi r ect , or consequent i al damages wi t hr espect t o any cl ai ms ari si ng f r omt he cont ent of such f i r mware and/ or

    t he use made by cust omers of t he codi ng i nf ormat i on contai ned herei n

    i n connect i on wi t h thei r pr oduct s.

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - * /

    #i f ndef __XL345_I O_H

    #def i ne __XL345_I O_H

    #i ncl ude "XL345. h"

    / * Wr apper f unct i ons f or r eadi ng and wr i t i ng burst s t o / f r omt he ADXL345

    These can use I 2C or SPI . Wi l l need t o be modi f i ed f or your hardware

    */

    / *

    The r ead f unct i on t akes a byt e count , a r egi st er address , and a

    poi nter t o t he buf f er wher e t o r eturn t he dat a. When t he r ead

    f unct i on r uns i n I 2C as an exampl e, i t goes through t he f ol l owi ng

    sequence:

    1) I 2C st art

    2) Send t he corr ect I 2C sl ave addr ess + wr i t e

    3) Send t he r egi st er address

    4) I 2C st op

    6) I 2C st art

    7) Send t he corr ect I 2C sl ave addr ess + r ead

    8) I 2C r ead f or each byt e but t he l ast one + ACK

    9) I 2C r ead f or t he l ast byte + NACK

    10) I 2C st op

    */

    voi d xl 345Read(unsi gned char count, unsi gned char r egaddr, unsi gned char *buf ) ;

    / *

    The wr i t e f unct i on t akes a byt e count and a poi nt er t o t he buf f er

    wi t h t he dat a. The f i r st byte of t he data shoul d be t he st art

    r egi st er addr ess, t he r emai ni ng bytes wi l l be wr i t t en st ar t i ng at

    t hat r egi st er. The mi ni mumbyt e count t hat shoul d be passed i s 2,

    one byte of address, f ol l owed by a byte of data. Mul t i pl e

    sequent i al r egi st ers can be wr i t t en wi t h l onger byte count s. When

    t he wr i t e f unct i on r uns i n I

    2

    C as an exampl e, i t goes t hrough t hef ol l owi ng sequence:

    1) I 2C st art

    2) Send t he corr ect I 2C sl ave addr ess + wr i t e

    3) Send t he number of byt es r equest ed f orm t he buf f er

    4) I 2C st op

    */

    voi d xl 345Wr i t e(unsi gned char count, unsi gned char r egaddr, unsi gned char *buf ) ;

    #endi f

  • 7/29/2019 Adxl345 App Note an-1023

    26/28

    AN-1023 Application Note

    Rev. 0 | Page 26 of 28

    CONCLUSION

    TheADXL345is a powerful and full-featured accelerometer

    from Analog Devices. This application note takes advantage of

    the various built-in motion status detection features and flexible

    interrupts to propose a new solution for fall detection. This

    solution is realized through full use of the ADXL345 hardware

    interrupts and has been tested to feature low algorithm

    complexity with high detection accuracy.

    REFERENCES

    ADXL345 Data Sheet. Analog Devices, Inc. 2009.

    http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345http://www.analog.com/ADXL345
  • 7/29/2019 Adxl345 App Note an-1023

    27/28

    Application Note AN-1023

    Rev. 0 | Page 27 of 28

    NOTES

  • 7/29/2019 Adxl345 App Note an-1023

    28/28

    AN-1023 Application Note

    NOTES

    2009 Analog Devices, Inc. All rights reserved. Trademarks andregistered trademarks are the property of their respective owners.