The disclosure relates to body and body part orientation and posture monitoring in medical devices.
Medical devices designed to be worn by or implanted in a patient may automatically monitor a variety of physiologic variables in patients. In some examples, medical devices may monitor physiologic variables over time, such as blood pressure or cardiac rhythm to provide caregivers trend information that may be useful in understanding a patient's health condition in order to provide physicians with evidence as to disease progression or resolution. In other examples, medical devices may automatically adjust therapy based on the measured patient's physical parameters.
Medical devices that include accelerometers that may monitor patient parametrics such as body orientation, posture, activity level, heart rate, heart motion, and sound, including heart sounds, snoring, patient speech, and sound in the patient's environment. Posture sensing may be useful to provide posture trends, such as trends in sleeping orientations, that may help patients, caregivers, and physicians to be aware of recognize and track trends or sudden changes in activities of daily living such as sleep time, sleep quality, and active minutes.
In general, the disclosure is directed to techniques for determining a patient's body or body part orientation or posture using an accelerometer that is part of a medical device on or in a patient. In some examples, the medical device may be an implanted medical device. Processing circuitry, e.g. of the medical device, may use the accelerometer to measure patient or limb or whole body activity and the orientation of the medical device relative to gravity.
When the medical device is fixed in a known orientation on or implanted in the patient, the processing circuitry may use the signal(s) from the accelerometer to determine the orientation of the medical device, then perform a calculation to determine the orientation of the part of the body where the device is located and, in some examples, extrapolated to represent the orientation of the entire body. The calculation may include distance metrics such as the dot product to determine the angular distance between the accelerometer indicated orientation vector of the medical device and one or more known measured or calculated accelerometer orientational reference templates stored in a memory. In some examples, the processing circuitry may determine orientation of the body part by determining which of the one or more accelerometer reference orientation templates is closest to the medical device orientation vector, based on the any of a number of possible angular distance metrics, such as the dot product. In some examples, the processing circuitry may characterize overall orientation of the body or body part as one or more body angles, based on the dot product to compare relative body angle to body part orientation references. In some examples, the processing circuitry may also compare the body or body part angles to particular angle thresholds to recognize and characterize standard patient postures like laying on back, standing, laying on left side, etc. In particular, this disclosure describes a method to characterize the orientation of the device relative to the body part efficiently using one upright measured accelerometer reference measurement and in some cases one more laying reference if further refinement of the patient's body or body part orientation is needed.
In one example, the disclosure is directed to a method comprising: storing plurality of reference orientation templates, each of the plurality of reference orientation templates associated with a respective one of a plurality of different orientations of a patient's body part; receiving, by processing circuitry, outputs of a sensor, wherein the sensor is responsive to a gravitational field; determining, by the processing circuitry and based on the outputs of the sensor, an orientation vector of the sensor relative to a gravitational vector of the gravitational field; for each of the plurality of body part orientations, calculating, by the processing circuitry, an angular distance metric between the orientation vector and each of the reference orientation templates; determining, by the processing circuitry, which of the calculated angular distance metrics indicates the associated reference orientation template is closest to the orientation vector; selecting, by the processing circuitry, the one of the plurality of reference orientation templates associated with the closest angular distance metric as the current orientation of the patient's body part.
In another example, the disclosure is directed to a method comprising: storing a first reference orientation template and a second reference orientation template for determining a value representative of a body part angle of a patient, the first reference template orthogonal to the second reference template; receiving, by processing circuitry, outputs of a sensor, wherein the sensor is responsive to a gravitational field; determining, by the processing circuitry and based on the outputs of the sensor, an orientation vector of the sensor relative to a gravitational vector of the gravitational field; selecting, by the processing circuitry, one of the first reference template or the second reference template for determining the orientation value based on the orientation vector; and determining, by the processing circuitry, the value representative of the body part angle of the patient based on a dot product of the orientation vector and the selected one of the first reference template or the second reference template.
In another example, the disclosure is directed to a system comprising: a medical device, wherein the medical device is configured to be attached to a patient's body part in a fixed orientation relative to the patient's body part, the device comprising: a sensor, wherein the sensor is responsive to a gravitational field; processing circuitry operatively coupled to the sensor, wherein the processing circuitry is configured to: receive outputs of the sensor; calculate an orientation vector of the sensor, based on the outputs of the sensor, wherein a direction of the orientation vector is relative to the gravitational field; store a first reference orientation template and a second reference orientation template for determining a value representative of an orientation of the patient's body part, the first reference orientation template orthogonal to the second reference orientation template; select one of the first reference orientation template or the second reference orientation template for determining the value representative of the body angle of the patient's body part based on the orientation vector; and determine the value representative of the body part angle based on a dot product of the orientation vector and the selected one of the first reference orientation template or the second reference orientation template.
This summary is intended to provide an overview of the subject matter described in this disclosure. It is not intended to provide an exclusive or exhaustive explanation of the apparatus and methods described in detail within the accompanying drawings and description below. The details of one or more aspects of the disclosure are set forth in the accompanying drawings and the description below.
The disclosure is directed to techniques for determining a patient's body part orientation using an accelerometer or other orientation sensor that is part of a medical device carried by the patient. In some examples, the medical device may be an implanted medical device. The accelerometer in a medical device may be used to measure general patient or specific body part activity such as limb activity and the orientation of the medical device. When the medical device is fixed in a known or assumed orientation on the patient, the medical device may use the accelerometer to determine the orientation of the medical device relative to gravity, then perform a simple set of calculations to determine the orientation of the part of the patient where the device is implanted, which in many examples may be the chest or abdomen, but may also include head or neck, or limb or foot orientations in some examples.
The calculation may include an angle distance metric, such as a dot product vector multiplication between the accelerometer orientation vector of the medical device and one or more known reference orientation templates stored in a memory location in the medical device. A dot product may also be referred to as an inner product. In some examples, one or more processors may determine body part orientation by determining which of the one or more captured or calculated reference orientation templates is closest to the medical device accelerometer orientation vector, based on the angular distance metric. In some examples, the one or more processors may determine body part orientation based on the dot product, specifically the magnitude and sign of the dot product. In some examples, the one or more processors may perform threshold comparisons on the body part angle or angles to recognize and characterize standard patient body orientations like laying on back, standing, laying on left side, etc. In some examples one or more processors, which may also be referred to as processing circuitry, in the medical device may determine the body part orientation. In some examples, one or more processors external to the medical device, but in communication with the medical device may determine body part orientation, and may perform additional calculations, such as trending, graphs, and similar functions.
In some examples, the calculation to determine a body part orientation of a patient based on the accelerometer orientation vector of the medical device may require the one or more processors to perform complex trigonometric calculations. Complex calculations may require a high-performance processor and the instructions to perform the complex calculations may consume a significant amount of computing energy since the processor may need to be awake for more clock cycles when compared to performing a less computationally intensive referencing and template matching algorithms or dot product angle calculations. The less computationally intensive referencing and template matching algorithms or dot product angle calculations of this disclosure may be considered more efficient than other techniques that may consume more power. More efficient techniques may have advantages, for example for devices powered by a battery. The higher power processor and additional awake time may consume more battery energy, when compared to computing the referencing and template matching or dot product angle calculations, and therefore may be less desirable. Also, in some examples, a small size with a small battery for a medical device may be more desirable, especially for implanted medical devices, because a smaller device may be easier to implant, less invasive and more comfortable, especially for smaller patients.
A device configured to determine a patient's body part orientation using a referencing and template matching algorithm or dot product angle calculations may therefore be configured with a less complex processor that consumes less power and may be awake for less time when compared to a device configured to use more computationally intensive trigonometry calculations. Reduced power consumption may result in longer battery life, and in the example of an implanted medical device, may result in fewer surgeries for the patient to replace the medical device. The referencing and template matching or angle distance metric such as the dot product approaches may therefore have advantages over other techniques for determining a patient's body part orientation.
A dot product, or inner product, calculation between two vectors results in a scalar value that comprises the magnitude of each vector multiplied by the cosine of the angle between them. This may be represented by the below equation:
A·B=∥A∥*∥B∥cos Θ
where Θ is the angle between vectors A and B and ∥A∥ is the magnitude of vector A. By selecting the magnitude of each vector to be one, the dot product is then a scalar value of the cosine of the angle between each vector. Similarly, dividing the dot product by ∥A∥*∥B∥ will result in the scalar value of the cosine of the angle between the vectors. The cosine function is at a maximum when the angle between two vectors is zero. Therefore, the scalar value of the dot product between two 3 axis accelerometer vectors is at a maximum when the angle between the two vectors is zero. A reference template, such as the upright reference, may be a vector that describes the orientation vector a device when the patient is upright. When the device orientation vector is pointing in substantially the same direction as reference template direction, the angle between the orientation vector and the reference template direction is small, i.e. the cosine between the orientation vector and the reference template direction is large. A dot product for the upright reference template that is larger than the dot products for other reference templates (e.g. right side up, face, etc.), may indicate that the patient is closer in angle to upright than the other body orientations.
Determining the cosine between two angles may also be described as an “angle or angular distance calculation” or rather an “inverse angular distance calculation” between two 3-axis accelerometer vectors. The cosine between two accelerometer vectors describes the projection of one accelerometer vector on the other accelerometer vector, i.e. an angular distance. Therefore, when the cosine is large, the angle between the two vectors is small and the projection of one vector on the other is large.
Another example of an angular distance metric calculation for comparison to body reference orientation templates may include measuring the total magnitude of the absolute value of the differences between each of the X, Y and Z values of each vector. For example, when the angle between two vectors is small the difference between the X-values will be small (e.g. |X1−X2|=small). Similarly, the absolute value of the difference between the Y-values and Z-values will be small when the vectors have approximately the same angle and magnitude. Therefore, the angular distance calculation may be considered to be small when the angle is small between accelerometer vectors of the same relative magnitude. Some examples of techniques to calculate this type of angular distance calculation may include the absolute value of the difference or take the square root of the sum of the square of the differences of the X, Y and Z values of each vector.
Similarly, a patient's body part orientation may be represented as the patient's body part angle based on the patient's device orientation at any given time relative to one or two, or three orthogonal reference orientation vectors, such as an upright reference vector, a laying reference vector and a side reference vector. One useful body angle or body part angle can be defined as being the angle of the body part relative to the earth's plane. An example of this is depicted in
A processor may determine the relative angle of the midline of the chest (back-angle) by calculating a dot product between the device accelerometer vector and an upright reference template. The dot product value then represents the cosine of the angle between the midline of the chest and the upright reference. The device may translate the result to be relative to the orthogonal direction of the earth's plane by a 90-degree rotation. In some examples, the processor may directly use the dot product in calculations or other functions, rather than converting the dot product to an angle using the inverse-cosine function. Using the unconverted dot product may have advantages in reducing calculation complexity. In other examples, the dot product may be transmitted to an external device, which may perform additional calculations, such as converting the dot product to an angle.
In the example of
IMD 10A may include processing circuitry as well as a sensor, such as a 3-axis accelerometer, that is responsive to a gravitational field. The processing circuitry of IMD 10A may receive the outputs of the sensor and determine the posture of patient 2, based on the outputs of the sensor and the one or more reference templates.
In some examples, IMD 10A may be implanted outside of the thoracic cavity of patient 2 (e.g., subcutaneously or submuscularly, such as the pectoral location). IMD 10A may be positioned near the sternum near or just below the level of heart 4. In some examples, IMD 10A may take the form of a Reveal LINQ™ ICM, available from Medtronic plc, of Dublin, Ireland. In other examples, IMD 10A may take the form of a pacemaker, defibrillator, drug delivery system or other types of medical device.
IMD 10A may include a timer and processing circuitry configured to determine a time of day based on the timer value or may determine the amount of time between events (e.g., posture changes). IMD 10A may include wireless communication circuitry configured to transmit or receive a signal from another device, such as to or from one or more external devices 12, or to another implanted medical device, for example. IMD 10A may determine a patient's posture, for example, and transmit that determination to external device 12. IMD 10A may also configured to receive the one or more reference templates from external device 12 and store the reference templates in a memory location within IMD 10A.
IMD 10A may transmit data about the posture, and other physiological parameter data acquired by IMD 10A, to external device 12. IMD 10A may also transmit cardiovascular pressure measurements, for example, received from another implanted sensor device, not shown, to external device 12, such as when IMD 10A is functioning as a hub device. For example, IMD 10A may transmit any data described herein related to cardiovascular pressure, posture, heart rate, activity level, respiration rate, or other physiological parameters to external device 12. For purposes of this disclosure, a chest posture, or other physiological measurements may include one or more numerical values, multi-variable tables (e.g., such values as a function of time), or other techniques for storing such data.
External device 12 may include processing circuitry configured to communicate, execute programming instructions, provide alerts to a patient or others and perform other functions. In some examples, external device 12 may be a computing device (e.g., used in a home, ambulatory, clinic, or hospital setting) to communicate with IMD 10A via wireless telemetry. External device 12 may include or be coupled to a remote patient monitoring system, such as Carelink®, available from Medtronic plc, of Dublin, Ireland. External device 12 may be, as an example, a programmer, external monitor, or a consumer device (e.g., a smart phone). In some examples, external device 12 may receive data, alerts, patient instructions, or other information from IMD 10A. External device 12 may be used to program commands or operating parameters into IMD 10A for controlling its functioning (e.g., when configured as a programmer for IMD 10A). External device 12 may be used to interrogate IMD 10A to retrieve data, including device operational data as well as physiological data accumulated in IMD memory. The interrogation may be automatic, such as according to a schedule, or in response to a remote or local user command. Programmers, external monitors, and consumer devices are examples of external devices 12 that may be used to interrogate IMD 10A. Examples of communication techniques used by IMD 10A and external device 12 include radiofrequency (RF) telemetry, which may be an RF link established via Bluetooth, WiFi, or medical implant communication service (MICS). In other words, medical system 1 is an example of a medical device system configured to determine, monitor and track the chest orientation, posture, and activity of patient 2. The techniques described herein may be performed by processing circuitry of medical system 1, such as processing circuitry of one or more of IMD 10A, external device 12, and one or more other implanted or external devices not shown, individually, or collectively.
In the example of
Processing circuitry 80 controls sensing circuitry 84 to sense physiological signals via electrode combinations formed by electrodes in one or more electrode arrays. For example, sensing circuitry 84 may receive signals via electrodes on one or more leads 16A and 16B. Components described as processors, or processing circuitry within IMD 10, external device 12, as described above in relation to
Sensing circuitry 84 may be configured to switch between one or more sensing vectors via electrodes, such as in an electrode array. In some examples, sensing circuitry 84 may be configured to sense muscle activity, impedance changes and sensing electrical activity of the heart. Though not shown, some examples of medical devices that perform the orientation and activity sensing techniques of this disclosure may include medical devices that are configured to deliver therapy, such as drug therapy, or electrical stimulation therapy. Such medical devices may include therapy generation circuitry instead of or in addition to sensing circuitry, as well as chemical detection, light or temperature detection or other sensors. Some example medical devices may include a cardiac pacemaker, a cardioverter, a defibrillator and a neurostimulator.
In some examples, IMD 10 may additionally or alternatively be configured to sense one or more physiological parameters of patient 2. For example, physiological parameters may include heart rate, electromyography (EMG), an electroencephalogram (EEG), an electrocardiogram (ECG), temperature, respiration rate, or pH. These physiological parameters may be used by processing circuitry 80, in some examples, to confirm or reject changes in sensed orientation and activity state that may result from vibration, patient travel (e.g., in an aircraft, car or train), or some other false positive of orientation and activity state. In some examples, processing circuitry 80 may use heart rate, activity, and/or time of day (as examples) to assume or confirm a patient is upright (awake and active) or laying down (asleep and inactive).
Orientation and activity circuitry 86 allows IMD 10 to sense the patient orientation and activity state, e.g., orientation, activity or any other static orientation or motion of patient 2. Orientation and activity state circuitry 86 may include circuitry suitable for amplifying, filtering or otherwise processing signals received from orientation sensor 87. Orientation and activity state information generated by orientation and activity state circuitry 86 and processing circuitry 80 may correspond to an activity and/or orientation undertaken by patient 2 or a gross level of physical activity, e.g., activity counts based on footfalls or the like.
In the example of
In some examples, processing circuitry 80 processes the analog output of the orientation and activity sensor in orientation and activity state circuitry 86 to determine activity and/or orientation data. For example, processing circuitry 80 or a processor of orientation and activity circuitry 86 may process the raw signals provided by the orientation and activity sensor to determine activity counts. In some examples, processing circuitry 80 may process the signals provided by the orientation and activity state sensor to determine velocity of motion information along each axis. In this disclosure, the term “sensor” refers to an orientation and activity state sensor, such as an accelerometer, unless otherwise noted.
In one example, each of the x, y, and z signals provided by the orientation and activity state sensor has both a DC component and an AC component. The DC components may describe the gravitational force exerted upon the sensor and may thereby be used to determine orientation of the sensor within the gravitational field of the earth. In other words, the sensor may be responsive to a gravitational field. Assuming the orientation of the sensor is relatively fixed with respect to patient 2, the DC components of the x, y and z signals may be utilized to determine the patient's body part orientation within the gravitational field, and hence to determine the body orientation of the patient or the patient's body part orientation. In other words, processing circuitry 80 may receive the outputs of the orientation and activity state sensor and determine an orientation vector of the orientation and activity state sensor relative to a gravitational vector of the gravitational field. As a result of determining the orientation of the orientation and activity state sensor relative to the patient's body part orientation, processing circuitry 80 may determine the body part orientation or, in some examples, a posture of the patient. The x, y and z signals may be interpreted by processing circuitry 80 as an orientation vector of the sensor [ax, ay, az].
In some examples, processing circuitry 80 may select one of the reference templates or the for determining the body part angle orientation value based on the orientation vector. Processing circuitry 80 may determine a value representative of the body angle of patient 2 (shown in
In other examples, processing circuitry 80 may calculate a dot product of the orientation vector and each reference template associated with the posture for each of the plurality of postures. Processing circuitry 80 may select the one of the plurality of postures associated with the largest of the of dot products as the current posture of the patient. As described above in relation to
The AC component of the x, y and z signals may yield information about patient motion. In particular, the AC component of a signal may be used to derive a value for an activity describing the patient's motion in one or more combinations of axes. This activity may involve a level, direction of motion, or acceleration of patient 2.
One method for determining the activity is an activity count. An activity count may be used to indicate the activity or activity level of patient 2. For example, a signal processor may sum the magnitudes of the AC portion of an accelerometer signal for N consecutive samples. For instance, assuming sampling occurs as 25 Hz, N may be set to 25, so that count logic provides the sum of the samples that are obtained in one second. This sum may be referred to as an “activity count.”
The number “N” of consecutive samples may be selected by processing circuitry 80 or a processor of orientation and activity state circuitry 86 based on the current orientation and activity state, in some examples. The activity count may be the activity portion of the orientation and activity state parameter value that may be associated with the orientation portion. The resulting orientation and activity state parameter value may then incorporate both activity and orientation to generate an accurate indication of the motion of patient 2. In some examples, the posture portion of the orientation and activity state parameter may include the posture, e.g. upright, lying down, or a combination of back-angle and side-angle. In some examples, the orientation and activity state parameter may include the orientation vector of the sensor.
As another example, the activity portion of the orientation and activity state parameter value may describe a direction of motion. This activity parameter may be associated with a directional activity vector describing activity levels in 3 dimensions. Another example of an activity parameter relates to acceleration in particular directions. A value quantifying the magnitude and orientation of the largest directional change of motion over a period of time may be associated with the activity portion of an orientation and activity state parameter value.
Processing circuitry 80 may store orientation and activity state information in memory 82 for later review by a clinician, used to adjust therapy, present an orientation and activity state indication to patient 2, or some combination thereof. As an example, processing circuitry 80 may record the orientation and activity state parameter value, or output, of the 3-axis accelerometer and assign the orientation and activity state parameter value to a certain predefined posture indicated by the orientation and activity state parameter value. In this manner, IMD 10 may be able to track how often and how long patient 2 remains within a certain posture.
In some examples, processing circuitry 80 may also adjust therapy or sensing (e.g., change an electrode vector, stimulation waveform parameter, or sensing threshold for one or more physiological parameters) for a new orientation when orientation and activity state circuitry 86 indicates that patient 2 has in fact changed postures. Therefore, 1 MB 10 may be configured to provide posture responsive stimulation therapy or sensing to patient 2. Stimulation or sensing adjustments in response to orientation and activity state may be automatic or semi-automatic (e.g., subject to patient approval). In many cases, fully automatic adjustments may be desirable so that IMD 10 may react more quickly to orientation and activity state changes.
An orientation and activity state parameter value from orientation and activity state circuitry 86 that indicates the orientation and activity state may constantly vary throughout the day of patient 2. However, a certain activity (e.g., walking, running, or biking) or a posture (e.g., standing, sitting, or lying down) may include multiple orientation and activity state parameter values from orientation and activity state circuitry 86. Memory 82 may include definitions for each orientation and activity state of patient 2.
Posture responsive stimulation may allow IMD 10 to implement a certain level of automation in therapy adjustments. Automatically adjusting stimulation may free patient 2 from the constant task of manually adjusting therapy each time patient 2 changes posture or starts and stops a certain orientation and activity state. Such manual adjustment of stimulation parameters can be tedious, requiring patient 2 to, for example, depress one or more keys of external device 12 multiple times during the patient orientation and activity state to maintain adequate symptom control. In some examples, patient 2 may eventually be able to receive orientation and activity state responsive stimulation therapy without the need to continue making changes for different postures via external device 12. Instead, patient 2 may transition immediately or over time to fully automatic adjustments based on their orientation and activity state.
Wireless telemetry in IMD 10 with external device 12, or another device may be accomplished, for example, by radio frequency (RF) communication, proximal inductive interaction, or tissue conductance communication (TCC) of IMD 10 with device 12. Telemetry circuit 88 may send information to and receive information from external device 12 on a continuous basis, at periodic intervals, at non-periodic intervals, or upon request from the stimulator or programmer. To support wireless communication, telemetry circuit 88 may include appropriate electronic components, such as amplifiers, filters, mixers, encoders, decoders, and the like.
Power source 90 delivers operating power to the components of IMD 10. Power source 90 may include a small rechargeable or non-rechargeable battery and a power generation circuit to produce the operating power. Recharging may be accomplished through proximal inductive interaction between an external charger and an inductive charging coil within IMD 10. As one example, external device 12 may include the charger to recharge power source 90 of IMD 10. Hence, the programmer and charger may be integrated in the same device. Alternatively, in some cases, a charger unit may serve as an intermediate device that communicates with both the IMD and the programmer. In some examples, power requirements may be small enough to allow IMD 10 to utilize patient motion and implement a kinetic energy-scavenging device to trickle charge a rechargeable battery. In other examples, traditional batteries may be used for a limited period of time. As a further alternative, an external inductive power supply could transcutaneously power IMD 10 when needed or desired.
Memory 142 includes operation instructions for processing circuitry 140 and data related to patient 2 and/or IMD 10, e.g., received from IMD 10. In the example of
As described above, dot product functions 114, also called inner product, is a technique to multiply two vectors and yield the magnitude of the vectors multiplied by the cosine of the angle between the vectors. Dividing the dot product by the product of the vector magnitudes results in a scalar value representing the cosine of the vectors. External device 12, may use dot product functions 114 during compensation, post-processing or other operations.
Compensation functions 116 provide instructions to processing circuitry 140 for determining the orientation of the sensor relative to the patient. In other words, because IMD 10A, depicted in
Because the angle measurements may change part of the overall system approach may be to provide a means to update reference measurements to account for movement. For example, for an implanted IMD, the device may shift position until the pocket becomes stable. For a strapped, or otherwise attached device, the device may shift position. In some examples patients may display somewhat consistent lying down positions due to habit as well as substantially self-consistent daily body or body part angle measurements. In other examples given patient's change in sleeping habit, such as from sleeping on a different side, might not cause shifts in the measured orientation angle. In other examples, some patients may have any significant variability in angles due to soft tissue movement. It may be desirable to update references on device-to-patient orientation periodically, either manually or by automated means.
Trigonometry functions 110 may include functions such as cosine, sine, arccosine and similar functions that may be used during compensation, post-processing or other operations. As described above in relation to
As described above in relation to
Telemetry circuitry 146 allows the transfer of data to and from IMD 10. Telemetry circuit 146 may communicate automatically with IMD 10 at a scheduled time or when the telemetry circuit detects the proximity of the stimulator. Alternatively, telemetry circuit 146 may communicate with IMD 10 when signaled by a user through user interface 144. To support wireless communication, telemetry circuit 146 may include appropriate electronic components, such as amplifiers, filters, mixers, encoders, decoders, and the like. In some cases, external device 12 may be used when coupled to an alternating current (AC) outlet, i.e., AC line power, either directly or via an AC/DC adapter.
In the example of
Access point 160 may comprise a device, such as a home monitoring device, that connects to network 162 via any of a variety of connections, such as telephone dial-up, digital subscriber line (DSL), or cable modem connections. In other examples, access point 160 may be coupled to network 162 through different forms of connections, including wired or wireless connections.
During operation, IMD 10 may collect and store various forms of data. For example, IMD 10 may collect sensed orientation and activity state information that indicates how patient 2, as depicted in
In some cases, external device 12 or server 164 may process orientation and activity state information, raw orientation data, other physiological sensing information, and/or therapy information into a displayable orientation and activity state report, which may be displayed via external device 12 or one of computing devices 170A-170N. The orientation and activity state report may contain trend data for evaluation by a clinician, e.g., by visual inspection of graphic data. In some cases, the orientation and activity state report may include the number of activities patient 2 conducted, a percentage of time patient 2 was in each orientation and activity state, the average time patient 2 was continuously within an orientation and activity state, and information regarding sensing and therapy delivery during each activity, or any other information relevant to patient 2 therapy, based on analysis and evaluation performed automatically by IMD 10, external device 12 or server 164. A clinician or other trained professional may review and/or annotate the orientation and activity state report, and possibly identify any problems or issues with the physiological sensing or therapy that should be addressed.
In some cases, server 164 may be configured to provide a secure storage site for archival of orientation and activity state information that has been collected from IMD 10 and/or external device 12. Network 162 may comprise a local area network, wide area network, or global network, such as the Internet. In some cases, external device 12 or server 164 may assemble orientation and activity state information in web pages or other documents for viewing by trained professionals, such as clinicians, via viewing terminals associated with computing devices 170A-170N. System 120 may be implemented, in some aspects, with general network technology and functionality similar to that provided by the Medtronic CareLink® Network developed by Medtronic, Inc., of Minneapolis, Minn.
Although some examples of the disclosure may involve orientation and activity state information and data, system 120 may be employed to distribute any information relating to the treatment of patient 2 and the operation of any device associated therewith. For example, system 120 may allow therapy errors or device errors to be immediately reported to the clinician. In addition, system 120 may allow the clinician to remotely intervene and reprogram IMD 10, external device 12, or communicate with patient 2. In an additional example, the clinician may utilize system 120 to monitor multiple patients and share data with other clinicians in an effort to coordinate rapid evolution of effective treatment of patients.
Furthermore, techniques of this disclosure may be applicable to IMDs that convey other therapies in which orientation and activity state information is important, such as, e.g., deep brain stimulation (DBS), pelvic floor stimulation, gastric stimulation, occipital stimulation, functional electrical stimulation, cardiac pacing, anti-tachycardia therapies, and the like. Also, in some aspects, techniques for evaluating orientation and activity state information, as described in this disclosure, may be applied to IMDs that are generally dedicated to sensing or monitoring and do not include stimulation or other therapy components, such as IMD 10.
3-Axis accelerometers have been used externally for short periods of time and placed on or about the body surface to monitor the body orientation/position, activity level and/or orientation and/or movement of specific limbs, or sections of the body for various purposes such as to aid in the diagnosis of various movement disorders, or automatically detecting falls. 3-axis accelerometers may also be used in implanted devices to do the same types of monitoring, but for a much longer period of time, e.g. months to years. Medical devices that include such 3-axis accelerometers may be useful to measure activity and body position and orientation parameters that can help recognize when patients are getting sicker, such as those suffering from heart failure, also called congestive heart failure (CHF). Such parameters may be combined and complemented with other physiologic metrics that also relate to the health condition of a patient, such as activity, impedance, body temperature, blood pressure, and heart rate.
Some proposed daily metrics that can be extracted from a 3-axis accelerometer may include:
To correctly monitor body or body part orientation the axes of the accelerometers should be correctly aligned with the body or body part, or implement compensation means to correct for misalignment. In most external applications, the 3-axis accelerometers can be aligned in a consistent manner from subject to subject, by using holsters on a belt, or chest straps or tape. Device orientation compensation, however may still be necessary to account for differences in body shapes or differences in the orientation of body parts from patient to patient. The degree of compensation depending on the required accuracy of the orientation measurements. The longer timeframe of implanted devices means implanted devices may be subject to changes in their orientation with time, for example from a patient's twiddling with the devices, soft tissue effects or other device migration. The device orientation compensation settings, as described in this disclosure, may be updated periodically to account for these changes. For example, a recompensation may be accomplished during a normal patient follow up visit with a clinician.
When utilizing a 3-axis accelerometer or other orientation sensor in an implanted device, not only do differences in body shape and orientation of body parts cause variability of the implant orientation of the internal 3-axis accelerometer relative to the earth's gravity, but the orientation of the implant of the device may be chosen to, for example, for best use of the main diagnostic or therapeutic function of the device. For example, a medical device may be implanted in a position and orientation chosen to best receive ECG signals. Other factors in implanted device orientation and position may include to position the scar of the implant to minimize the visibility of the scar and optimize the performance of other sensors onboard the device, e.g. pH monitor, for example.
For some applications, it may be necessary to account for the yaw of the implant.
The example axis convention in this disclosure is just one example of possible conventions. The techniques of this disclosure apply equally to other conventions as shown in the table below.
For clarity, the conventions listed in the first row of the above table will be followed for Phix (ϕx), Phiy (ϕy), and Phiz (ϕz). In other words, all rotations are in a right-hand manner and the axes follow the right-hand rule. For example, Phix rotates in a right-hand way about the X-axis and is 0 degrees at the +Y axis, 90 degrees at the +Z axis on the XZ plane, and 180 degrees at the −Y axis. The other two axes follow this same convention, where the rotation Phiy rotates about the y-axis, and starts at 0 on the +X axis, to 90 degrees at the +Z axis, to 180 degrees on the −X axis. Phiz rotates about the z axis and is 0 degrees at the +X axis.
Converting the convention in row 1 for an accelerometer that follows the convention of example 2 may be done by inverting the x-axis output, or alternately switching the x and y axis definitions, and reorienting the accelerometer to have the new y axis pointing up. In another example, an accelerometer may be used with the convention as listed in example 3 by inverting the y and z axes so y and z point up when positive.
Using the conventions described above, this disclosure describes techniques for a medical device processor, such as processing circuitry 80 depicted in
As described above in relation to
In some examples, IMD 10 may transmit to an external computing device, such as external device 12, the orientation vector of the 3-axis accelerometer, based on the outputs of the 3-axis accelerometer, wherein the patient is in a predetermined compensation orientation, such as an upright orientation. External device 12 may perform compensation calculations and transmit one or more reference templates to IMD 10. IMD 10 may store the reference templates at a memory location, such as memory 82, which is operatively coupled to the processing circuitry 80. Processing circuitry 80 may perform simplified calculations to determine patient orientation using the reference templates. Periodically, the reference templates may be updated in memory 82 of IMD 10 to account for any movement of IMD 10 relative to patient 2, for example, during a follow up visit at a clinician. In some examples, IMD 10 may include an algorithm to automatically verify and compensate for some migration of IMD 10 after implant. In some examples the automatic compensation algorithm may compensate for only one of the angles, such as roll 202. In other examples, the automatic algorithm may compensate for two or more of the angles.
One example of a device orientation compensation procedure may begin with the patient in a predetermined posture, such as upright. In some examples, activity, heart rate, time of day, or the like may be used by processing circuitry 80 to determine whether patient is upright. Additionally or alternatively, processing circuitry 80 may sense tapping of the device by the patient or clinician indicating the patient is upright or in another calibration posture via the accelerometer.
The system, such as system 1 depicted in
Equations (1)-(14) below demonstrate one way to calculate roll and pitch using the upright posture as a predetermined compensation reference posture assuming no yaw:
Phix=arcsin(−az′) (1)
Phiz=arcos(ay′/cos(Phix)), (for Phix≠90°) (2)
Equations (1) and (2) result in four pairs of solutions:
Phix1=arcsin(az′), (3)
and if 0≤Phix1≤180 the second solution for Phix is:
Phix2=180−Phix1, (4)
but if −180≤Phix1≤0 the second solution for Phix is:
Phix2=−180−Phix1. (5)
The two solutions above are then associated with the four Phiz solutions via equation (2):
Phiz 1 and Phiz 2=±arcos(ay′/cos(Phix1) (6)
Phiz 3 and Phiz 4=±arcos(ay′/cos(Phix2) (7)
The relationships above may be summarized as shown in the table below. Using the ax′ and ay′ sign values and the table above one can identify which of the above 4 Phiz values is within the desired range, the correct Phix value is the one associated with the correct Phiz value.
To identify the correct Phiz values use magnitude and the sign values:
Sign(Phiz)=Sign(ax′) for ax≠0. (8)
If (ay′>0 and ax≠0) then choose Phiz such that 0<|Phiz|<90° (9)
If (ay′<0 and ax≠0) then choose Phiz such that 90<|Phiz|<180° (10)
There are specific ax′ and ay′ boundary values that result in values of Phiz with a simplified calculation. Some boundary values may not necessarily be correctly defined using equations (1) and (2):
If (ax′=0 and ay′>0) then use Phiz=0 (11)
If (ax′=0 and ay′<0) then use Phiz=±180 (12)
If (ay′=0 and ax′>0, then use |Phiz|=90° (13)
If (ay′=0 and ax′=0, then use Phiz=Not Available or NA (14)
Using equations (1)-(11), external device 12, as depicted in
One example technique to determine yaw angle 206 of the sensor, e.g. a 3-axis accelerometer which may be included in orientation sensor 87, as depicted in
In summary, the example technique to calculate yaw calculates the roll and pitch per the approach described above using equations (1)-(11) from the upright posture. Then compensate the second set of data from the second posture to remove the effects of the measured roll and pitch rotation using the following formula:
(axcorr,aycorr,azcorr)=Rx−1*Rz−1*(ax,ay,az). (15)
where: Rz−1 (inverse roll), and Rx−1 (inverse pitch) are 3×3 matrices:
In the Rz−1 and Rx−1 matrices, Phiz and Phix are the previously estimated roll and pitch correction. According to this example, after correction for roll and pitch angle, for each chosen posture, there are two equations each that can be used to calculate the yaw. For an accurate representation for Phiy it may be desirable to use arcsine for small angle outputs, e.g., less than ±45 degrees, and arccosine for larger angles, e.g., greater than 45 degrees. Therefore, in some examples, processing circuitry may apply the following rule to calculate the yaw values in the equations below: if |axcorr| or |azcorr|>0.707 (from equation (15) above), use the arcsine function, otherwise use the arccosine function for the equations.
Supine Yaw Equations:
Phiy=arcos(azcorr) or (16)
Phiy=arcsin(−axcorr) (17)
Face Down Yaw Equations:
Phiy=arcos(azcorr) or (18)
Phiy=arcsin(axcorr) (19)
Left Side Up Yaw Equations:
Phiy=arcos(axcorr) or (20)
Phiy=arcsin(azcorr) (21)
Right Side Up Yaw Equations:
Phiy=arcos(−axcorr) or (22)
Phiy=arcsin(azcorr) (23)
During calibration processing circuitry may compute reference orientation templates with the calculated yaw 206, pitch 204, and roll 202 rotation angles. During the operation, by comparing the outputs of the sensor (ax, ay, az) to five orthogonal posture vectors, IMD 10 may determine the posture of the patient is closest to one of the five ideal basis postures. Five examples of ideal basis posture vectors where the scales are adjusted so that 0=0 G and 1=1 G, may include:
Upright: (0,1,0)
Face Up: (0,0,1)
Face Down: (0,0,−1)
Right-Side Up: (−1,0,0)
Left-Side Up: (1,0,0)
The five orientation vectors above give a basic description of coarse patient orientations. In other examples, a more detailed estimate of patient orientation may include ten reference templates, such as upright, sitting forward, sitting back, sitting left side, sitting right side, lying left side, lying right side, lying face down, lying face up, and upside down. In other words, IMD 10 may store ten reference templates and compare the outputs of the sensor to the ten reference templates to determine which posture of the ten reference templates the patient is closest to their actual posture. In other examples, IMD 10 may store other reference templates used to determine patient body angle, or to compare dot products to threshold ranges to determine patient posture.
These basis posture vectors must be rotated (i.e. compensated for device orientation) using the estimated yaw 206, pitch 204, and roll 202 values to compute the five [(ax′, ay′, az′)] reference templates expected for the device orientation. The actual device orientation values are calculated using equation (24) below and the defined Rx, Ry, and Rz rotation matrices below. Note that these basis posture vectors also have to be multiplied by a device scale factor to match the expected ranges of the values stored in the particular device, otherwise, they do not represent true values as recorded in the device. The reference templates may then be transmitted by external device 12 and stored in a memory location of IMD 10 along with the original measured vectors used for compensation (e.g. upright vector). In other examples, the estimated yaw 206, pitch 204 and roll 202 angles may also be stored in a memory location either of IMD 10, or in another memory location such as computing devices 170 shown in
IMD 10 may determine the patient posture, or in other examples the patient's body angle, based on the reference templates. IMD 10 may output the reference posture compensation measurement (that is used to estimate yaw 206, pitch 204 and roll 202 angles), along with time stamped posture information to external device 12, or via access point 160 depicted in
The following rotation matrices can be used to calculate the effects of implant pitch, yaw and rotation on a measured value of the accelerometer signals (ax, ay, and az) from a 3-axis accelerometer. When compared to the inverse roll matrix (Rz−1), described above, the rotation matrix for roll (Rz) has sin (Phiz) and negative sin(Phiz) transposed.
[ax′,ay′,az′]=Rz*Rx*Ry*[ax,ay,az] (24)
For the upright reference template, substitute the upright vector (0,1,0) into equation (24) i.e. [ax, ay, az]=[0,1,0]. Multiplying out the matrices:
ax′=sin(Phiz)cos(Phix) (25)
ay′=cos(Phiz)cos(Phix) (26)
az′=−sin(Phix) (27)
The remaining reference templates may be determined in a similar manner. In the example in which IMD 10 determines a patient body angle, IMD 10 may store only the upright reference template, the supine (face-up) reference template and the right-side up reference template. In other examples, the system may use other vectors for compensation, e.g. left side up, which may depend on patient capability or other factors.
External device 12 depicted in
Phix=arcsin(−az′) (28)
The rotation angle Phiz can then be calculated from either equation (25) or equation (26), or both. Selecting equation (26):
Phiz=Arcos(ay′/cos(Phix)). (29)
In some examples, external device 12 may determine the remaining reference templates from the single, predetermined upright reference posture, based on equations (25)-(29). In other words, processing circuitry 140 of external device 12, depicted in
The techniques of this disclosure may have advantages over other techniques of determining reference templates and posture or orientation. Selecting the starting posture as upright [0,1,0], and selecting yaw as the first rotation angle, the yaw value, Phiy, has no effect on the measured values of ax′, ay′ and az′. This is only the case for this upright posture, or if the patient were standing on their head. In other words, for the coordinate system convention of this example, selecting the upright posture as the predetermined patient reference posture for compensation, and selecting the order of calculation for the rotation matrices as yaw, pitch then roll, simplifies the calculation of the rotation matrices. For example, choosing the order of angle rotations so that the roll angle is last, can create a direct relationship between the first two angles of rotation of the sensor in the medical device. Two rotation angles may define the plane of the body surface at the site of implant or attachment.
Also, by choosing yaw to be first and pitch to be second, the measurement of pitch can be made with the upright posture of the patient, because in the upright posture any arbitrary yaw value has no effect on the upright measurements of ax, ay and az, and the calculations to measure pitch and roll can then be easily made independently of the yaw. Choosing an upright posture as the reference compensation posture may be a convenient posture for patient 2. For example, an elderly patient may find it more difficult to place themselves in some postures and to move between a variety of postures. The techniques of this disclosure allow for a single reference compensation posture, such as an upright posture.
The procedure of selecting yaw, then pitch then roll corresponds to multiplying the rotation matrices in sequence per equation (24). For example, assume that initially, patient 2 is lying flat on their back on the procedure table, and that the orientation vector for the sensor is aligned with orientation vector's long y-axis parallel to the spine, and sensor vector's x-axis parallel to an arm-to-arm cross-chest line. For the selected coordinate convention, this corresponds to a completely un-rotated device, with the axes of the sensor in IMD 10 perfectly aligned with the patient axes.
The examples shown in
In some examples, pitch 204 is selected as the second angle of rotation, as depicted in
By defining the yaw angle followed by defining the pitch angle 204, the plane of the implant site, based on the direction of orientation vector 205A, has now been defined by these two rotations. The implant plane is parallel to orientation vector 205A and the x-axis of the implant plane is still parallel to the waist of the patient, as depicted in
An advantage of the techniques of this disclosure include using similar calculation for both upright and laying down vectors. Also, that that the two-dimensional plots of patient chest position during post-processing may be easy to visualize and more intuitive to translate when compared to other approaches. In other words, the techniques of this disclosure may allow plot outputs that are easy to interpret for both a caregiver and the patient and may allow better patient care.
Determining the back-angle 310 and side-angle, defines the patient body angle. When referring to a specific body part, the body angle may be referred to as the body part angle. The patient body angle may coincide with a posture as described above in
Said another way, the two position approach may be used to determine which category of positions the patient's body part may be oriented by determining threshold ranges for the back-angle and side-angle. In the example of a device implanted in a patient's chest, processing circuitry may determine the patient's posture by determining categories of positions based on combinations of ranges for the back-angle and the side-angle. For example, when back-angle 310 is between orthogonal and 45 to the gravity vector, while the side-angle is as shown in
Some advantages of defining the patient body angle with the two position angle approach include providing a range of body angles without having to store one reference template for each body angle of interest. Said another way, the two position angle approach may allow a more granular and less coarse determination of the daily body positions of patient 2. Compared to the reference template approach, the two position angle approach does not require a distance calculation (e.g. a dot product) for each different body angle reference template. As with the reference template approach, the angle calculations do not require a processor intensive arccosine function calculation or look up table. In this example approach, a linear fit to the arccosine curve simplifies the angle calculations, so that the device processor can do the calculation more efficiently, e.g. the processing circuitry of IMD 10 or external device 12 depicted in
The two position approach may still use the one-posture compensation for finding the device orientation described above in relation to
Processing circuitry implementing the two position angle approach may switch between orthogonal references, which may make the angle calculation more accurate for a low-resolution accelerometer data (e.g. an 8 or 9 bit accelerometer). This body position can be graphed in a 2D chart during post-processing and may be used to track the body angles in an intuitive manner for review directly as a 2D angle chart, or as a pattern of positions that can be characterized and compared for changes in patient health status. During post-processing, an external device may determine postures by comparing the body angle positions to angle thresholds. For example, by comparing the body angles to thresholds processing circuitry in an external device may determine which body angles are in the orthogonal primary postures of upright, lying face down, lying face up, lying on left side, lying on right side, or any sleep angles of interest.
The three reference templates include upright reference vector 302, supine, or laying reference vector 304 and right-side up reference vector 312. The three reference templates are each orthogonal to each other. As described above in relation to
During operation, processing circuitry, e.g. within the medical device, calculates the two angles (back-angle 310 and the side-angle) using the less computationally intensive dot product calculations. In some examples, processing circuitry may perform calculations with scaled 8-bit numbers. To avoid having to do relatively more complicated arc-cosine calculations, this two posture angle approach uses the three orthogonal references, switching between references at a threshold angle transitions to maintain a near linear relationship between the accelerometer output and the body angle. In some examples, the threshold angle is approximately 45 degrees. In some examples, to determine whether to switch between references, processing circuitry may determine the angle to the supine reference template 308 and the angle to the upright reference template 306.
For calculations by the medical device, the 8-bit numbers may be stored as re-scaled values. In some examples, post-processing, as described above in relation to
As described above in relation to
During compensation, a patient, such as patient 2 depicted in
Processing circuitry of medical device 410 may receive outputs of a sensor that is responsive to a gravitational field, such as a 3-axis accelerometer. The processing circuitry may determine an orientation vector of the sensor relative to a gravitational vector of the gravitational field based on the outputs of the sensor (420). An example gravitational vector is gravity vector 300 depicted in
Processing circuitry of external device 412 may calculate the yaw, pitch and roll of medical device 410 to determine the orientation vector of the sensor while patient 2 is in the predetermined compensation reference posture (422). Processing circuitry, such as processing circuitry 140 depicted in
Depending on the approach used to determine posture or body angle, i.e., the reference template approach, the two position angle approach or the threshold approach, external device 412 may calculate reference templates (428) using one or more uncalibrated ideal reference vectors (426), such as the upright vector (0,1,0). In one example, medical device 410 may be configured to determine that body position of patient 2 is nearest to one of five orthogonal scaled posture templates calculated by the external device 426 from five ideal unscaled reference vectors: upright (0,1,0), supine (0,0,1), prone (0,0, −1), left side (1,0,0), or right side (−1,0,0). In other examples, medical device 410 may be configured to determine that the body position of patient 2 is nearest to one of ten postures, as listed above in relation to
Processing circuitry of external device 412 may calculate a plurality of reference templates from ideal reference vectors, e.g. five, ten, or three, or some other number of reference templates, depending on the approach (428). The processing circuitry may transmit the reference templates to medical device 410, e.g. using telemetry circuitry 146 depicted in
Processing circuitry of medical device 410 may receive the plurality of reference templates from the external computing device 412 and store the plurality of reference templates at a memory location operatively coupled to the processing circuitry (432). An example of a memory location may include memory location 82 coupled to processing circuitry 80 as depicted in
A processor, such as processing circuitry 80 of IMD 10 depicted in
In some examples, the three native axis signals from the accelerometer may be combined at four different digital summers. Three of the digitally summed channels may be aligned with x, y, and z axes, and may be low-pass filtered at 0.5 Hz and decimated, for slowly changing orientation measurements. One of the channels may be high-passed filtered at 1 Hz and used for the activity measurements. In other examples the vector processing circuitry 452 may be configured to create three activity channels, one for each axis. The vector processing 452 may generate three orientation channels by choosing to use analog summers to create the 3 orientation axes.
The patient's posture, or body angle, determined by processing circuitry 80 (454) may be stored at memory location 456, which may be included in memory 82 of
In some examples, a medical device may determine posture either continuously or at regular timed intervals. However, posture calculations consume power, such as from power source 90 depicted in
In other examples, a patient's activity level may be high, such as during exercise, walking, and other activities. If the activity level is high, repeated posture calculations may not be as accurate. Trigger posture update 460 may only signal a posture calculation when the activity level is below a threshold, for example.
Determine patient posture 470 corresponds to determine patient posture 454 as depicted in
As described above, in relation to
For each triggered posture update signal 460, the processor may calculate an angular distance metric, such as inner product 476, based on the received signals from accelerometer 450 via 3-axis vector processing 452. The received signals indicate the posture vector of accelerometer 450 relative to the gravitational field. For the calculate inner products function 476, a processor may perform an inner product (i.e. dot product) calculation of the sensor orientation vector with each of the plurality of reference templates 474
A processor may select largest inner product 478 function based on the output of the scalar results of the plurality of inner product calculations. As described above, the cosine function is at a maximum when the angle between two vectors is zero. Therefore, the scalar value of the dot product between two vectors is at a maximum when the angle between the two vectors is zero. A reference template, such as the upright reference template, may be a vector that describes the orientation vector a device when the patient is upright. When the device orientation vector is pointing in substantially the same direction as reference template direction, the angle between the orientation vector and the reference template direction is small, i.e. the cosine between the orientation vector and the reference template direction is large. A dot product for the upright reference template that is larger than the dot products for other reference templates (e.g. right side up, face, etc.), may indicate that the patient is closest in angle to upright. In other words, the processor determines which scalar dot product is largest and the one of the plurality of postures associated with the largest of the plurality of dot products as the current posture of the patient.
The processor, e.g., processing circuitry 80, may store the updated posture at a storage location (480). The processor may also store other information, such as a timestamp, associated with the posture.
As described above in relation to
Determine patient posture 500 corresponds to determine patient posture 454 as depicted in
For each triggered posture update signal 460, the processor may calculate inner product 512 based on the received signals from accelerometer 450 via 3-axis vector processing 452. As described above in relation to
The processor may compare the scalar dot product to a set of thresholds (514). In some examples the threshold comparison may indicate that the patient is in a lying down posture (516). If the patient is in a lying down posture (YES of 516) the processor may use the heuristic sign (positive or negative) of the posture vector signals (ax, ay, az) and magnitude comparisons to classify which lying down posture that patient is in. For example, supine, prone, right-side up or left-side up (518).
If the patient is not in a lying down posture (NO of 516), the processor may compare the scalar dot product to one or more thresholds to determine which of the upright postures the patient is in (520). Some example upright postures may include standing upright, upside down or sitting. For either lying down or upright postures, the processor may store the information at a memory location (480).
The determine posture (500) steps may also be described in terms of a logic flow, similar to a computer program. The values in the below logic flow description (e.g. 0.5, 0.85) are for illustration purposes only. Other thresholds may be equally valid depending on the compensation, programming, selected hardware, accelerometer characteristics and other parameters. An example of heuristic logic flow steps may include:
If {(x, y, z)●Upright(X, Y, Z)≥0.85}⇒Upright
If {0.5≤(x, y, z)●Upright(X, Y, Z)<0.85}⇒Sitting
If {(x, y, z)●Upright(X, Y, Z)≥−0.707}⇒Upside Down
If {Not Upright, Sitting, or Upside Down}⇒Laying
If Not Face Down or Face Up⇒Check if LSU or RSU
Where:
Determine patient posture 600 corresponds to determine patient posture 454 as depicted in
The processor may receive outputs of accelerometer 450 via 3-axis vector processing 452. As described above, the processor, or other circuitry, may determine an orientation vector of accelerometer 450 relative to a gravitational vector of the gravitational field, based on the outputs of accelerometer 450.
The processor may select one of the upright reference template or the supine reference template for determining the posture value based on the orientation vector (606). In other words, the processor may determine the scaled back-angle dot product by selecting either the upright or the supine reference template, depending on which reference template is more different from the sensor orientation vector. As described in relation to
In some examples, as described above in relation to
In some examples, back-angle dot product (606) may also depend on which reference template was used to determine the side-angle dot product (612). The back-angle dot product (606) calculation may receive information about which template was used by the side-angle dot product (612) via supine flag 616. The side-angle dot product (612) passes the supine flag 616 to the back-angle dot product (606) when the side-angle dot product switches to the supine reference template (602). The supine flag 616 is to account for a blind-spot in the back-angle measurement. The blind-spot occurs because the back-angle dot product (606) cannot detect a posture transitions where the patient lies down directly from upright to either the right-side up posture or the left-side up posture. The supine flag signals the back-angle block to switch to the upright reference template (604).
Another way to describe the back-angle calculation is that only one inner-product is required in any patient body angle measurement cycle, because the back-angle only has to represent the angle of the long-axis of the chest with respect to the horizontal plane. The back-angle switches between two references templates, the measured upright reference template and the calculated supine reference template. The implementation of
The scaled back-angle dot product (606) passes the upright flag 618 to the scaled side-angle dot product (612). The upright flag 618 disables the face-down adjustment of the side-angle measurement and switch to only using the right-side up reference template (610), so that the side-angle value represents only a side-to-side-angle measurement when upright.
The processor may also store a third reference template, i.e. right-side up reference template (610). Right-side up reference template (610) is orthogonal to both the upright reference template and the supine reference template, as described above in relation to
As with the back-angle, the side-angle dot product may be a scaled value. The side-angle dot product may be considered a value indicative of the side-angle, rather than an actual angle in degrees. In some examples, the model or type of accelerometer 450 and how the accelerometer is configured, or trimmed, e.g. during manufacturing, may also impact the calculations of back-angle and side-angle. The configuration and other parameters of accelerometer 450 may need to be factored into the back-angle and side-angle calculations, as well as factored into the conversion and scaling calculations during post-processing.
In some examples, the side-angle dot product (612) may also depend on which reference template the processor used to determine the back-angle dot product (606). Side-angle dot product (612) may receive information on which reference template the processor used for the back-angle via upright flag 618.
As described above in relation to
Back-angle calculation 645 includes an output from template switching function 650 to the scaled back-angle dot product 606. Switching function 650 may be implemented, for example by logic circuitry, software or firmware instructions stored at a memory location, or by circuit components such as on an integrated circuit. A processor may switch the output from switching function 650 between upright reference template 604 and supine reference template 602. As described above in relation to
Before continuing to get the next data value, the scaled back-angle dot product (606) output may be tested against a threshold (630) to determine if the angle between the orientation vector from 3-axis vector processing (452) and the selected reference has now exceeded the threshold (e.g. a value indicative of 45°). If true (YES of 630), then the processor may switch reference template for the back-angle dot product (606) to the other reference template, e.g. control switching function 650 to switch to the other reference template. The processor may retrieve next set of accelerometer 450 output values, for example, when triggered by the trigger posture update function (460) described in relation to
For lying down postures (i.e. positions where the back-angle <45 degrees, as depicted in
For upright postures (orientations of the chest >45 degrees), the back-angle dot product (606) is measured using supine reference template (602). For upright postures, negative values indicate leaning forward and positive values indicate leaning back. The implementation of
In some examples, the actual implementation in a medical device may constrain the range to a value between 135 degrees. For example, the range may be between −25 degrees to 135 degrees. In a limited range example, the processor may flag all the values less than −25 degrees or just replace the values less than −25 degrees as being equal to −25 degrees. Range limitation may depend on a variety of factors including type of accelerometer, circuit configuration, power consumption limits, and so on.
The next paragraphs describe additional detail on the back-angle calculation 645, including related equations. As discussed in general terms above, when calculating the back-angle, a partially scaled inner-product may be calculated using one of the calculated reference values stored in memory. Instead of dividing by the exact amplitude of the signal, a power-of-2 division may be used to simplify calculations. For example, a scale factor of 64 results in a resolution of 1.45 degree/step. The scaled inner product for both back-angle and side-angle is according to the following equation:
scaled inner product=(ax_measured*ax_reference+ay_measured*ay_reference+az_measured*az_reference)/2n (30)
where (ax_measured, ay_measured, az_measured) is the sensor orientation vector. The value of n may be selected as a scaling division to keep the output signal within range (i.e. coerce the signal). Also, the processor may switch references when the scaled dot product satisfies a threshold. In some examples, the threshold is a scaled value indicative of 45 degrees.
As described below, the back-angle is the converted back-angle in degrees, such as after post-processing. Values that may be scaled and stored in a medical device with a less complex processor, such as IMD 10 described above in relation to
Back-angles from 45 to 135 degrees:
Back_Angle=[90−(S.F.)*(Scaled_B_Value)], (31)
Where:
S.F.=[(Number Bits per G)/38]*(2{circumflex over ( )}n/32) (32)
and n is the number of bits the processor shifts left to scale the inner-product result. For example, if there are 42 bits/G and n=6⇒
S.F.=(42/38)*(64/32)=2.2) (33)
Also for n=5, ⇒S.F.=1.1 (34)
For Back-angles from −45 to 45 degrees:
When using the Upright Reference in the Back-angle calculation, the
Back_Angle=[90−(S.F.)*(90*(1/(S.F.)−(Scaled_B_Value)] (35)
For side-angle calculation 660 block the processor, e.g., processing circuitry 80 of IMD 10, executes two inner products between the sensor orientation vector and reference templates, i.e. the supine dot product (662) and the right-side dot product (664). As depicted in the example of
After the processor determines the two inner products switching function 665 selects the desired inner-product, whether calculated using the supine reference template (602) or the right-side up reference template (610). To avoid having out of range numbers during activity, in some examples the processor may coerce the output signals of signals supine dot product (662) and right-side dot product (664) to a specific range. Once the processor selects the dot product, the dot product values are passed on to the final side-angle formula calculations (672) and stored (678). For post-processing (485) scale factors (e.g. S.F.) may be used convert the scaled values.
The sign for supine dot product (662) may be extracted and stored (670) along with the scaled side-angle value 672. Similarly, the sign of the right-side dot product (664) may be extracted and stored (674) along with the scaled side-angle value 672. During post-processing, the sign of the dot product may be used to convert the scaled values of the side-angle dot product 672 to degrees, for example. The sign of supine dot product (662) is used to determine face up (positive) or face down (negative). Similarly, the sign of the right-side dot product (664) is used to determine right-side up (positive) or left-side up (negative).
Similar to the back-angle calculation described above, before continuing to get the next data value, the processor may test selected scaled dot product against a threshold (676) to determine if the angle between the signal and the reference template has exceeded a threshold, such as approximately 45°. If true (YES of 676), then the processor may switch the reference template for side-angle calculation 660 to the other reference template. The processor may retrieve the next set of orientation vector values from 3-axis vector processing 452 and use the other reference vector. If not true (NO of 676), then the processor may continue by retrieving the next set of orientation vector values and determine the next dot product using the same reference template.
Additionally, for the side-angle calculation 660 it is desirable to distinguish face up from face down and left-side up from right-side up independently, for any side-angle over the entire ±180-degree range. Because face-up vs face down can only be distinguished by using the sign of the inner-product with the supine reference (602) and left-side-up and right-side-up can only be distinguished by using the sign of the inner-product with the right-side-up reference (610), the processor calculates both inner-products in parallel for any given side-angle measurement. Therefore, the switching between the two reference channels at switching function 665 is done after the calculation of the two inner-products.
Side-angle calculation 660 uses the right-side-up reference (610) for side-angles between −45 Degrees and 45 Degrees, between 135 degrees and 180 degrees, and between −135 degrees and −180 degrees. Similarly, side-angle calculation 660 uses the supine reference (602) for side-angles between 45 degrees and 135 degrees, and −45 degrees and −135 degrees. The implementation of
The two position angle approach may include some special posture situation checks. During the calculations of these scaled angle values, there may be several special posture situations in which it may be useful to switch the reference template selections to specific states. As described above in relation to
The back-angle threshold (630) test depicted in
In the example of side-angle calculation 660 while in an upright posture, the processor uses upright flag 618. As described above when upright, side-angle calculation 660 should not use supine reference (602) to calculate the side-angle, because the processor will be measuring the back-angle instead. To ensure side-angle calculation 660 uses right-side up reference template (610), the processor may check if back-angle calculation 645 used supine reference (602). If so, upright flag 618 forces switching function 665 to the right-side up reference template (610).
The next paragraphs describe additional detail on the side-angle calculation 660, including related equations. As discussed in general terms above, when calculating the side-angle, the processor may include steps to recognize face down from face up by using the sign of the inner-product between the orientation vector and the supine reference template (602). Also, the processor may recognize left side up from right side up using the sign of the inner-product between the orientation vector and right-side up reference template (610). As described below, “Side-angle” is the converted side-angle in degrees, such as after post-processing. Values that may be scaled and stored in a medical device with a less complex processor, such as IMD 10 described above in relation to
The side-angle calculations depend on what part of the range the side-angle is in. For example, when the processor uses right-side up reference template (610) this indicates the patient is on their back OR stomach AND:
For side-angles between 90 to 135 degrees:
Side-angle=(S.F.)*[180/(S.F.)−(Scaled_S_Value)] (36)
For side-angles from −90 to −135 degrees:
Side-angle=(S.F.)*[−180/(S.F.)−(Scaled_S_Value)] (37)
For side-angles from −45 to 45 degrees:
Side-angle=S.F.*(Scaled_S_Value) (38)
When the processor uses supine reference template (602), which indicates the patient is on one of their sides AND:
Side-angles from 45 to 90 degrees:
Side-angle=(S.F.)*(+1)*[90/(S.F.)−(Scaled_S_Value)] (39)
Side-angles from 45 to 90 degrees:
Side-angle=(S.F.)*(−1)*[90/(S.F.)−(Scaled_S_Value)] (40)
Posture change detector 800 is a power efficient angle tracking implementation suitable for low power applications, such as within IMD 10 depicted in
Reference templates 810 include combinations of the x, y and z axes, similar to axes depicted in
Posture change detector 800 may select a single reference vector (816) of the plurality of reference vector templates 810. Selecting a single reference vector may also be referred to as selecting a single channel. The single reference vector is selected to be the closest to the current orientation vector of accelerometer 450. By selecting the single reference vector (816) closest to the sensor orientation vector, allows a high sensitivity to posture changes.
Posture change detector 800 may determine the closest reference vector by calculating a dot product (814), as described above in relation to
In the example in which posture change detector 800 detects a posture change, then posture change detector 800 may increment the rotation counter 840 that indicates patient movement and trigger an updated posture determination (844). In some examples a processor, such as processing circuitry 80 depicted in
Low pass filter (LPF) 820 receives a selected single-axis vector from a 3-axis vector processing circuit 452 and outputs a filtered signal to threshold comparator 824. In some examples, low pass filter 820 may be similar to the 0.5 Hz low-pass filter as described above in relation to
When the retrieved vector rotation (822) satisfies a threshold (YES of 824) of angle comparator 824, then orientation change detector 800 may verify the stability (826) of the selected low-pass filtered vector. In the example in which the selected low-pass filtered vector satisfies a stability threshold (YES of 826), then orientation change detector 800 may check the patient's activity level (828).
Activity processing 830 receives accelerometer information from 3-axis vector processing 452 and outputs an indication of patient activity to activity threshold detect 828. In some examples, activity processing 830 may include filtering and other signal processing, similar to that described above in relation to
In the example in which the selected signal vector does not satisfy the posture change threshold (NO of 824), the selected signal vector is not stable (NO of 826) then orientation change detector 800 may wait for the predetermined interval (833), such as when a processor wakes up. Similarly, if the patient's activity level is high (NO of 828), the patient may be walking or otherwise active and orientation change detector 800 may not trigger an updated posture determination.
In one or more examples, the functions described above may be implemented in hardware, software, firmware, or any combination thereof. For example, the various components of
By way of example, and not limitation, such computer-readable storage media, such as memory 142 depicted in
Instructions may be executed by one or more processors, such as one or more DSPs, general purpose microprocessors, ASICs, FPGAs, or other equivalent integrated or discrete logic circuitry. Accordingly, the term “processor,” as used herein, such as processing circuitry 140, may refer to any of the foregoing structure or any other structure suitable for implementation of the techniques described herein. In addition, in some aspects, the functionality described herein may be provided within dedicated hardware and/or software modules configured for encoding and decoding, or incorporated in a combined codec. Also, the techniques, such as orientation change detector 800 could be fully implemented in one or more circuits or logic elements.
The techniques of this disclosure may be implemented in a wide variety of devices or apparatuses, including a wireless handset, an integrated circuit (IC) or a set of ICs (e.g., a chip set). Various components, modules, or units are described in this disclosure to emphasize functional aspects of devices configured to perform the disclosed techniques, but do not necessarily require realization by different hardware units. Rather, as described above, various units may be combined in a hardware unit or provided by a collection of interoperative hardware units, including one or more processors as described above, in conjunction with suitable software and/or firmware.
Various examples of the disclosure have been described. These and other examples are within the scope of the following claims.
This application claims the benefit of U.S. Provisional Application 62/678,841 filed May 31, 2018, the entire contents of which is incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
62678841 | May 2018 | US |