The disclosure relates to medical devices and, more particularly, to medical devices that detect patient posture state.
A variety of medical devices are used for chronic, e.g., long-term, delivery of therapy to patients suffering from a variety of conditions, such as chronic pain, tremor, Parkinson's disease, epilepsy, urinary or fecal incontinence, sexual dysfunction, obesity, or gastroparesis. As examples, electrical stimulation generators are used for chronic delivery of electrical stimulation therapies such as cardiac pacing, neurostimulation, muscle stimulation, or the like. Pumps or other fluid delivery devices may be used for chronic delivery of therapeutic agents, such as drugs. Typically, such devices provide therapy continuously or periodically according to parameters contained within a program. A program may comprise respective values for each of a plurality of parameters, specified by a clinician.
Initially, a clinician uses an external device, e.g., a clinician programmer, to provide a set, or multiple sets, of stimulation parameters that instruct the medical device how to deliver the therapy to the patient. In the case of an implantable medical device, this “programming” task usually occurs once the medical device is implanted in the patient and ready for operation. In some cases, the initial stimulation parameters are the best estimate of the clinician as to what type of therapy will alleviate the patient of their physiological symptoms or conditions. The patient may thus need to visit the clinician periodically to subsequently adjust the stimulation parameters for more effective treatment.
In some cases, the patient may be allowed to activate and/or modify the therapy delivered by the medical device. For example, a patient may be provided with a patient programming device. The patient programming device communicates with a medical device to allow the patient to activate therapy and/or adjust therapy parameters. For example, an implantable medical device (IMD), such as an implantable neurostimulator, may be accompanied by an external patient programmer that permits the patient to activate and deactivate neurostimulation therapy and/or adjust the intensity of the delivered neurostimulation. The patient programmer may communicate with the IMD via wireless telemetry to control the IMD and/or retrieve information from the IMD.
In general, the disclosure relates therapy systems including an external display device that presents graphical representations, such as, e.g., avatars and/or other indicators (e.g., graphical indicators) of patient posture state, to a user based on posture state data received from a medical device. The medical device could be an implantable medical device or an external medical device. In some examples, the medical device may be configured to deliver therapy to a patient according to the detected posture state of the patient. In such cases, the medical device may detect the posture state of a patient via a posture state module of the medical device. In other examples, the medical device may be configured to detect the posture state of a patient via a posture state module but not deliver therapy to the patient based on the detected posture state.
Based on posture state data, which in some examples may be received in or near real-time from the medical device, the external display device may present one or more indicators indicative of patient posture state to a user. In some examples, the external display may update an indicator of patient posture state substantially continuously (e.g., at a relatively high refresh rate) such that the posture state indicator reflects the posture state of the patient substantially simultaneously with actual patient movement.
In some examples, the external display device may present multiple indicators to represent two or more posture state, where each posture state is identified according to different posture state detection criteria. As one example, the external display device may present indicators for two or more of the real-time posture state, asserted posture state, and stable posture state of a patient. Each of the real-time posture state, asserted posture state, and stable posture state of the patient displayed by the external device may be determined based on posture state sensor data received from the posture state module of the medical device, although the detection criteria (e.g., detection algorithm) used to define each posture state from the sensor may be different for each type of posture state. In some examples, the external display may present indicators to represent both a stable posture state and unstable posture state of the patient.
In one example, the disclosure relates to a method comprising receiving posture state data for a patient from a medical device; and presenting an indicator indicative of two or more posture states based on the received posture state data, wherein each posture state of the two or more posture states is determined based on different detection criteria.
In another example, the disclosure relates to a display device comprising a processor that receives posture state data from a medical device; and a user interface that presents an indicator indicative of two or more posture states based on the received posture state data, wherein each posture state of the two or more posture states is determined based on different detection criteria.
In another example, the disclosure relates to a system comprising means for receiving posture state data for a patient from a medical device; and means presenting an indicator indicative of two or more posture states based on the received posture state data, wherein each posture state of the two or more posture states is determined based on different detection criteria.
In another example, the disclosure relates to a non-transitory computer-readable storage medium comprising instructions that cause one or more processors to receive posture state data for a patient from a medical device; and control a user interface to present an indicator indicative of two or more posture states based on the received posture state data, wherein each posture state of the two or more posture states is determined based on different detection criteria.
In another example, the disclosure is directed to a non-transitory computer-readable storage medium comprising instructions. The instructions cause a programmable processor to perform any part of the techniques described herein. The instructions may be, for example, software instructions, such as those used to define a software or computer program. The computer-readable medium may be a computer-readable storage medium such as a storage device (e.g., a disk drive, or an optical drive), memory (e.g., a Flash memory, random access memory or RAM) or any other type of volatile or non-volatile memory that stores instructions (e.g., in the form of a computer program or other executable) to cause a programmable processor to perform the techniques described herein. The computer-readable storage medium may be an article of manufacture, and may be non-transitory.
The details of one or more aspects of the disclosure are set forth in the accompanying drawings and the description below. Other features, objects, and advantages will be apparent from the description and drawings, and from the claims.
As described above, in some examples, a medical device may be configured to deliver therapy based upon the posture state of the patient. For example, in the case of an IMD that delivers electrical stimulation therapy, the IMD may utilize information regarding the detected posture state of patient to determine what stimulation parameters are used for therapy to target certain symptoms that may change with different anatomical positions that may be occupied by a patient. These therapeutic changes due to posture states can be important to therapy programming, and it may be useful for the clinician and patient to visualize how patient physiological conditions (e.g., physiological symptoms) and the therapy delivered to the patient changes with the posture state of a patient.
Changes in the posture state of a patient receiving therapy from an IMD may cause changes in therapeutic efficacy. In some examples, such changes may be due to changes in distances between electrodes or other therapy delivery elements, e.g., due to temporary migration of leads or catheters with respect to patient physiology caused by forces or stresses associated with different postures of the patient, or from changes in compression of patient tissue in different posture states.
To maintain the delivery of effective therapy, it may be desirable to adjust therapy parameters based on different postures and/or activities engaged by the patient. In the case of electrical stimulation therapy delivered in pulses, therapy parameters may include amplitude (voltage or current), pulse rate, pulse width, electrode polarity, and electrode combination. Such therapy parameter values may be adjusted individually or by selecting different programs or groups of programs defining different sets of therapy parameters. Without posture-based therapy, the patient may need to continually manage therapy by manually adjusting the values of certain therapy parameters or selecting different therapy programs to achieve more efficacious therapy throughout many different posture states.
As described above, in some aspects, the disclosure relates to therapy systems including an external display device that presents graphical representations, such as, e.g., avatars and/or other indicators (e.g., graphical indicators) of patient posture state, to a user based on posture state data received from a medical device. In some examples, the medical device may be configured to deliver therapy to a patient according to the detected posture state of the patient. In such cases, the medical device may detect the posture state of a patient via a posture state module of the medical device.
The medical device may be an external or implantable medical device. Furthermore, while examples of the disclosure are described primarily with regard to an IMD or other medical device configured to deliver therapy to a patient based on the patient posture state, examples include medical devices configured to detect the posture state of a patient via a posture state module but not deliver therapy to the patient. For instance, a medical device configured to detect patient posture state may be used for diagnostic purposes, such as diagnosing a need for therapy, or determining how a patient is responding to existing therapy. In some examples, the medical may be configured to delivery therapy to a patient, but not on a posture state responsive basis.
Based on posture state data, which in some examples may be received in or near real-time from the medical device, the external display device may present one or more indicators indicative of patient posture state to a user. In some examples, the external display may update an indicator of patient posture state substantially continuously based on posture state data transmitted from a medical device in or near real-time such that the posture state indicator reflects the posture state of the patient substantially simultaneously with actual patient movement.
In some examples, the external display device may present multiple indicators to represent two or more patient posture states, where each posture state type is identified according to different posture state detection criteria. As one example, the external display device may present indicators for two or more of real-time posture state, asserted posture state, and stable posture state of a patient. Each of the real-time posture state, asserted posture state, and stable posture state of the patient displayed by the external device may be determined based on posture state sensor data received from the posture state module of the medical device, although the detection criteria (e.g., detection algorithm) used to define each posture state from the sensor may be different for each type of posture state.
In some examples, the external display may present indicators to represent both a stable posture state and unstable posture state of the patient based on received posture state data. The presentation of the indicators of the various types of patient posture state may allow a user to evaluate the performance of the medical device for detecting patient posture state, including evaluating the performance in terms of the temporal relationship between patient posture states derived from different posture state detection criteria.
An indicator for a posture state presented by the external display device may be a visible, audible or tactile indication delivered via a user interface associated with a programmer. A visible indication may be a graphical representation of the patient's posture state (which may include a patient posture or activity), a symbolic icon, a word, a number, or even arrows. An audible indication may be spoken words stating a posture state, different audible tones, different numbers of tones, or other audible information generated by the programmer to indicate the posture state. A tactile indication may be different numbers of vibratory pulses delivered in sequence or vibratory pulses of different lengths, amplitudes, or frequencies. Examples systems and techniques for presenting indicators indicative of a patient posture state to a user via an external display device may include one or more examples described in U.S. patent application Ser. No. 12/433,103, titled, “POSTURE STATE DISPLAY ON MEDICAL DEVICE USER INTERFACE” and filed on Apr. 30, 2009, the entire content of which is incorporated herein by reference.
As will be described further below, the posture state data that is transmitted to the external display device for posture state identification may include posture state parameter values generated by one or more posture state sensors used to sense the posture state of a patient. For example, in the case of a medical device including a three-axis accelerometer sensor to detect the posture state of a patient, the posture state parameters values may include sensor information from one or more of the x, y, and z signals generated by the three-axis accelerometer. The sensor information from the x, y, and z signals may include raw x, y, and z signal data, sampled values of the x, y, and z signals, and/or a sample sensed coordinate vector calculated from sampled signal values of the x, y, and z signals.
Such posture state data may be transmitted to the external display device or other computing device to determine the postures state of patient. For example, the external device may process the posture state data using one or more posture state detection algorithms reflecting desired detection criteria to determine patient posture state. In some examples, the external device may process the posture state data to determine one or more of the real-time posture state, asserted posture state, or stable posture state of a patient to determine the posture state indicators presented to a user on the display.
Additionally or alternatively, the posture state data received from the medical device may include an indication of one or more patient posture states, such as, the real-time patient posture state, asserted patient posture state, and/or stable patient posture state, as determined by the medical device prior to being transmitted to the external device. In such a case, the analysis and processing of the posture state sensor signal information may be performed by the medical device and then the identified posture state(s) of the patient may be transmitted to an external display for presentation of one or more indicators indicative of the identified posture state(s).
In some examples, the external display device may present an avatar or other graphical indicator directly representative of one or more sampled values of the x, y, and z signals of a posture sensor. For example, rather than analyzing sampled values of the x, y, and z signals of a posture sensor to characterize the values as a posture state that is defined to encompass a plurality of x, y, and z, values (which may be used to generate a sensed coordinate vector), the external display device may present an avatar or other graphical indicator to substantially match the sampled value(s) within a posture state space represented on the external display device. In some examples, the external display device or other device may convert sampled x, y, and z signal values into a sensed coordinate vector. The external device may then generated and present a graphical indicator to represent the particular sensed vector to a user on the external display. The external device may update the graphical indicator continuously or periodically to represent newly sampled sensor values and/or sensed coordinate vectors. In some examples, each sensed coordinate vector may be characterized as a unique posture state of the patient or a posture state of the patient may be defined to include a plurality of different sensed coordinate vectors.
In some examples, the posture state data may be streamed or otherwise transmitted from the medical device to the external display device in or near real-time, and the external display device may continuously or periodically update the presented indicators of patient state to reflect the posture state data received from the medical device. The timing of the posture state data transfer, as well as the rate at which indicator(s) of patient posture state are updated on the external display, may be such that any changes in the actual posture state of the patient are reflected substantially simultaneously by the real-time posture state indicator or other posture state indicator presented on the external display. In this manner, a user may be allowed to observe changes to patient posture state indicated by the real-time posture state indicator or other indicator to confirm that posture state data transmitted from the medical device is consistent with the actual posture state of a patient. In response to the one or more indicators presented by the external device, the clinician may monitor, adjust, or re-calibrate the posture state detection algorithm(s) to accurately represent the patient posture state.
In some examples, a medical device may characterize posture states of a patient as unstable or stable posture states using one or more suitable detection algorithms used to process sampled sensor signal data. In the case of a medical device configured to deliver therapy to a patient, it may be undesirable to modify or adjust therapy immediately upon the detection of sampled sensor signal data indicative of the patient transitioning from one posture state to another. For example, since a patient may move between two or more posture states in a relatively short period of time, the patient may not benefit from the relatively fast changes in therapy parameters that could accompany such movement if the therapy was changed for every posture state occupied by patient 12. As such, in some examples, only when patient 12 is within a posture state for a predetermined period of time does IMD 14 recognize the posture state as a stable posture state for changing therapy according to the detected patient posture state. In some cases, the predetermined amount of time may be referred to as a “dwell time.” Until a posture state is determined to be a stable posture state, such a posture state may be referred to as an unstable posture state.
Although a medical device may adjust therapy based on changes to stable posture states, the medical device may monitor sampled signal data to detect unstable posture states of a patient. One example of an unstable posture state may be referred to herein as a “real-time posture state.” A real-time posture state of a patient may refer to the posture state of a patient corresponding to one or more recently sampled sensor signal values. In some examples, a posture state detection algorithm may be configured to detect the real-time posture state of a patient based on the most recently sampled set of sensor signal values, or some rolling average of two or more recently sampled sets of sensor signals values. In this manner, the detection algorithm for use in detecting the real-time posture state of a patient may be such that the real-time posture state of a patient changes at a relatively high frequency and also tracks patient posture state movement with greater precision, e.g., as compared to a stable posture state.
Another example of an unstable posture state may be referred to herein as an “asserted posture state.” An asserted posture state of a patient may refer to the posture state of a patient corresponding to a plurality of recently sampled sensor signals values that are processed using a sampling algorithm to determine the posture state of a patient. For example, for continuous sampling of sensor signals, a sampling algorithm may utilize a rolling sampling window that analyzes a preset number of recently sampled sets of sensor signal values (e.g., the five most recently sampled signal values). If the signal values within the sampling windows satisfy some preset criteria, (e.g., four of the five sets of values within the sampling window indicate the same posture state), then the medical device may make a positive detection of the posture state corresponding to the sets of values in the sampling window. One example of a sampling algorithm used to determine an asserted posture state of a patient may be referred to as an M of N filter. Other sampling algorithms are contemplated. In most cases, the detection criteria for the asserted posture state of a patient is such that it changes less frequently than the real-time posture state but more frequently than the stable posture state.
The detection criteria for unstable posture states versus stable posture states is such that changes to unstable postures states may be detected more frequently than changes to stable posture states. While such frequent changes can be undesirable for posture responsive therapy delivery, the unstable posture state(s) of a patient may be useful for more precisely tracking patient movement. In the example of an external display configured to continuously update a patient posture state based on posture state data, such as, sampled sensor signal values, the presentation of one or more indicators of unstable posture state(s) may be useful to better represent the movement of a patient in real-time, e.g., as compared to an indicator representative of the stable posture state due to the lag time that may accompany changes in a stable posture state compared to that of actual patient movement. Moreover, in some examples, the presentation of indicators of both stable and unstable posture states on the same temporal basis to a user may permit the user to gauge the performance of one or more detection algorithms in detecting patient posture state as well as gauge dwell times associated with one or more stable posture states.
One or more techniques for detecting and/or characterizing the posture state of a patient, in essence, as stable or unstable, or stable, real-time, and asserted, for example, may include one or examples described in U.S. patent application Ser. No. 12/433,004, titled “POSTURE STATE DETECTION SYSTEM AND METHOD,” filed Apr. 30, 2009, the entire content of which is incorporated by reference herein.
In some examples, the external display device may also present the raw posture state data, and/or an activity level of the patient associated with the posture state. The external display device may also allow the clinician to adjust the values of one or more therapy parameters or adjust how the medical device detects the posture state of the patient receiving therapy. Further, the external display device may allow the user to review historical posture state data via a playback feature of a user interface of the display device. Although the display device may be any external computing device capable of presenting indicators of patient posture state on a display, the display device may also take the form of a patient or clinician programmer typically used to program and control delivered therapy.
As shown in
Although
Each of leads 16 may include one or more electrodes (not shown in
In the example of
The stimulation may be delivered via selected combinations of electrodes carried by one or both of leads 16. The target tissue may be any tissue affected by electrical stimulation energy, such as electrical stimulation pulses or waveforms. Such tissue includes nerves, smooth muscle, and skeletal muscle. In the example illustrated by
The deployment of electrodes via leads 16 is described for purposes of illustration, but arrays of electrodes may be deployed in different ways. For example, a housing associated with a leadless stimulator may carry arrays of electrodes, e.g., rows and/or columns (or other patterns), to which shifting operations may be applied. Such electrodes may be arranged as surface electrodes, ring electrodes, or protrusions. As a further alternative, electrode arrays may be formed by rows and/or columns of electrodes on one or more paddle leads. In some embodiments, electrode arrays may include electrode segments, which may be arranged at respective positions around a periphery of a lead, e.g., arranged in the form of one or more segmented rings around a circumference of a cylindrical lead.
In the example of
In some examples, IMD 14 may deliver stimulation therapy according to one or more programs. A program defines one or more stimulation parameters that define an aspect of the therapy delivered by IMD 14 according to that program. For example, a program that controls delivery of stimulation by IMD 14 in the form of pulses may define one or more therapy parameters such as a voltage or current pulse amplitude, a pulse width, a pulse rate, for stimulation pulses delivered by IMD 14 according to that program. Moreover, therapy may be delivered according to multiple programs, wherein multiple programs are contained within each of a multiple of groups.
Each program group may support an alternative therapy selectable by patient 12, and IMD 14 may deliver therapy according to the multiple programs. IMD 14 may rotate through the multiple programs of the group when delivering stimulation such that numerous conditions of patient 12 are treated. As an illustration, in some cases, stimulation pulses formulated according to parameters defined by different programs may be delivered on a time-interleaved basis. For example, a group may include a program directed to leg pain, a program directed to lower back pain, and a program directed to abdominal pain. In this manner, IMD 14 may treat different symptoms substantially simultaneously.
During use of IMD 14 to treat patient 12, movement of patient 12 among different posture states may affect the ability of IMD 14 to deliver consistent efficacious therapy. For example, leads 16 may migrate toward IMD 14 when patient 12 bends over, resulting in displacement of electrodes and possible disruption in delivery of effective therapy. For example, stimulation energy transferred to target tissue may be reduced due to electrode migration, causing reduced efficacy in terms of relief of symptoms such as pain. As another example, leads 16 may be compressed towards spinal cord 18 when patient 12 lies down. Such compression may cause an increase in the amount of stimulation energy transferred to target tissue. In this case, the amplitude of stimulation therapy may need to be decreased to avoid causing patient 12 additional pain or unusual sensations, which may be considered undesirable side effects that undermine overall efficacy.
Also, posture state changes may present changes in pain level. In some examples, to avoid interruptions in effective therapy, IMD 14 may include a posture state module that detects the patient posture state. The IMD automatically adjusts stimulation according to the detected posture state of patient 12, thereby providing posture state responsive therapy. For example, the posture state module may include one or more accelerometers that detect when patient 12 occupies a posture state in which it is appropriate to decrease the stimulation amplitude, e.g., when patient 12 lies down. The IMD may automatically reduce stimulation amplitude so that patient 12 does not manually have to do so. Example posture states may include “Upright,” “Upright and Active,” “Lying Front,” “Lying Left,” “Lying Right,” “Lying Back,” and the like.
In some examples, IMD 14 provides posture responsive therapy, e.g., IMD 14 or an external programmer 20 detects changes in patient posture and automatically adjusts therapy based on the patient posture. These therapy adjustments may be manually programmed in IMD 14 or an external programmer 20, e.g., a clinician may specify one or more therapy programs for each patient posture. In addition, automatic therapy adjustments due to changes in patient posture may also be based on recorded associations between manual patient therapy adjustments and patient posture, e.g., IMD 14 or an external programmer 20 associate manual patient therapy adjustments with patient postures and then automatically repeat those therapy adjustments for the corresponding patient postures.
In response to a posture state detected by the posture state module, IMD 14 may change program group, program, stimulation amplitude, pulse width, pulse rate, and/or one or more other parameters, groups or programs to maintain therapeutic efficacy. When a patient lies down, for example, IMD 14 may automatically reduce stimulation amplitude so that patient 12 does not need to reduce stimulation amplitude manually. In other cases, IMD 14 may automatically increase stimulation amplitude based on posture state. In some cases, IMD 14 may communicate with external programmer 20, e.g., a display device, to present a proposed change in stimulation in response to a posture state change, and receive approval or rejection of the change from a user, such as patient 12 or a clinician, before automatically applying the therapy change. In some examples, posture state detection may also be used to provide notifications, such as providing notification via a wireless link to a care giver that a patient has potentially experienced a fall.
Referring still to
The user interface of external programmer 20 may present an indicator to indicate to the user the posture state in which the patient 12 currently occupies. This patient posture state may be a static posture that does not take into account activity level, an activity level that does not take into account posture, or some combination of the posture and activity level that describes the physical position and movement of patient 12. As an example, posture may be characterized as one of the following postures: standing, sitting, lying down on back, lying down on front, lying down on left side, lying down on right side. Activity level may be characterized as one of: high, medium and low, or, e.g., walking, biking, running, or the like.
Posture state may indicate a combination of one of the above postures with one of the above activity levels. For some postures, such as lying down postures, the posture state may not need to consider activity level, as the patient may be less likely to undertake any significant activity in such postures. In other cases, all posture states may take into account posture and activity level, even if there is minimal activity in a particular posture. Posture state may be determined based on detected posture information and/or activity level information generated by a posture state module, which may include one or more accelerometers or other posture or activity level sensors. System 10 may utilize fewer or more different types of posture states depending upon the needs of patient 12.
The patient posture state may be represented by an avatar of patient 12 or some other posture state indicator presented to patient 12 and generated by the user interface of programmer 20 as a visible, audible, or tactile indication. As described above, in some cases, a patient posture state may include a real-time patient posture state, an asserted patient posture state, and a stable patient posture state. In some examples, programmer 20 presents and updates one or more posture state indicators substantially continuously according to data transmitted in or near real-time from IMD 14. When presented as a different visible indication, a posture state indication may be, for example, a graphical representation, a symbolic icon, a textual representation such as word or number, an arrow, or any other type of indication. An avatar (e.g., a three-dimensional avatar) and other visible indications of patient posture state may be presented via a display, such as an a liquid crystal display (LCD), dot matrix display, organic light-emitting diode (OLED) display, touch screen, or the like. In other cases, a visible indication may be provided in a translucent area that is selectively backlit to indicate a posture. An audible indication may also be produced by programmer 20 to supplement a graphical indicator as spoken words stating a posture state, or different audible tones, different numbers of tones, or other audible information generated by the programmer to indicate posture state. Additionally, a tactile indication may be produced by programmer 20 different numbers of vibratory pulses delivered in sequence or vibratory pulses of different lengths, amplitudes, or frequencies for the benefit of patient 12 during therapy.
IMD 14 may transmit posture state data to programmer 20 in a continuous real-time manner. However, IMD 14 may also transmit posture state data on a periodic or intermittent basis or in response to a posture state change. Alternatively, programmer 20 may request a posture state detection from IMD 14 on a periodic, intermittent or continuous basis. The posture state data provided from IMD 14 to programmer 20 may be a posture state value that is raw data later interpreted to identify the posture state of patient 12, or simply a post-processed indication of the detected posture state, e.g., upright, lying front, lying back, lying left, lying right, or the like. In some examples, the raw data may be processed via according to different detection criteria, e.g., to determine one or more of real-time posture state, asserted posture state, and/or stable posture state of a patient based on the raw sensor data. External programmer 20 then may generate and present a posture state indicator in the appropriate configuration to represent the corresponding posture state based upon the posture state data transmitted from IMD 14 in real-time. In some examples, the indicator presented by external programmer to a user may be representative a particular sensed coordinate vector (e.g., in the case of sampled x, y, and z axis sensor values).
In some cases, external programmer 20 may be characterized as a physician or clinician programmer if it is primarily intended for use by a physician or clinician. In other cases, external programmer 20 may be characterized as a patient programmer if it is primarily intended for use by a patient. A patient programmer is generally accessible to patient 12 and, in many cases, may be a portable device that may accompany the patient throughout the patient's daily routine. In general, a physician or clinician programmer may support selection and generation of programs by a clinician for use by stimulator 14, whereas a patient programmer may support adjustment and selection of such programs by a patient during ordinary use. In examples in which IMD 14 is configured to monitor patient posture state but not delivery therapy, programmer 20 may be used to display posture state information to a user but not program therapy delivery. In any case, external programmer 20 may be a display device that presents an indicator of one or more posture state of patient 12. In some examples, the indicator of patient posture state be reflective of postures state data received in or near real-time from IMD 14.
In general, as will be described below, external programmer 20 may be one example of a display device including a processor that receives posture state data from a medical device; and a user interface that presents an indicator indicative of two or more posture states based on the received posture state data, where each posture state of the two or more posture states is determined based on different detection criteria.
IMD 14 may be constructed with a biocompatible housing, such as titanium or stainless steel, or a polymeric material such as silicone or polyurethane, and surgically implanted at a site in patient 18 near the pelvis. IMD 14 may also be implanted in patient 12 at a location minimally noticeable to patient 12. Alternatively, IMD 14 may be external with percutaneously implanted leads. For SCS, IMD 14 may be located in the lower abdomen, lower back, upper buttocks, or other location to secure IMD 14. Leads 16 may be tunneled from IMD 14 through tissue to reach the target tissue adjacent to spinal cord 18 for stimulation delivery.
At the distal tips of leads 16 are one or more electrodes (not shown) that transfer the electrical stimulation from the lead to the tissue. The electrodes may be electrode pads on a paddle lead, circular (e.g., ring) electrodes surrounding the body of leads 16, conformable electrodes, cuff electrodes, segmented electrodes, or any other type of electrodes capable of forming unipolar, bipolar or multipolar electrode configurations for therapy. In general, ring electrodes arranged at different axial positions at the distal ends of leads 16 will be described for purposes of illustration.
For example, leads 16A and 16B could include four electrodes, while lead 16C includes eight or sixteen electrodes, thereby forming a so-called 4-8-4 or 4-16-4 lead configuration. Other lead configurations, such as 8-16-8, 8-4-8, 16-8-16, 16-4-16, are possible. In some cases, electrodes on lead 16C may be smaller in size and/or closer together than the electrodes of leads 16A or 16B. Movement of lead 16C due to changing activities or postures of patient 12 may, in some instances, more severely affect stimulation efficacy than movement of leads 16A or 16B. Patient 12 may further benefit from the ability of IMD 14 to detect posture states and associated changes and automatically adjust stimulation therapy to maintain therapy efficacy in a three lead system 22.
Although IMD 26 is shown as coupled to only one catheter 28 positioned along spinal cord 18, additional catheters may also be coupled to IMD 26. Multiple catheters may deliver drugs or other therapeutic agents to the same anatomical location or the same tissue or organ. Alternatively, each catheter may deliver therapy to different tissues within patient 12 for the purpose of treating multiple symptoms or conditions. In some embodiments, IMD 26 may be an external device which includes a percutaneous catheter that forms catheter 28 or that is coupled to catheter 28, e.g., via a fluid coupler. In other embodiments, IMD 26 may include both electrical stimulation as described in IMD 14 and drug delivery therapy.
IMD 26 may also operate using therapy parameters that define the method of drug delivery. IMD 26 may include programs, or groups of programs, that define different delivery methods for patient 14. For example, a program that controls delivery of a drug or other therapeutic agent may include a titration rate or information controlling the timing of bolus deliveries. Patient 14 may use external programmer 20 to adjust the programs or groups of programs to regulate the therapy delivery.
Similar to IMD 14, IMD 26 may include a posture state module that monitors the patient posture state. IMD 26 may adjust therapy based on posture state. For example, the posture state module may indicate that patient 12 transitions from lying down to standing up. IMD 26 may automatically increase the rate of drug delivered to patient 12 in the standing position if patient 12 has indicated that pain increased when standing. This automated adjustment to therapy based upon posture state may be activated for all or only a portion of the programs used by IMD 26 to deliver therapy.
Patient programmer 30 also includes display 36, power button 38, increase button 52, decrease button 50, sync button 58, stimulation ON button 54, and stimulation OFF button 56. Cover 34 protects display 36 from being damaged during use of patient programmer 30. Patient programmer 30 also includes control pad 40 which allows a user to navigate through items displayed on display 36 in the direction of arrows 42, 44, 46, and 48. In some embodiments, the buttons and pad 40 may take the form of soft keys (e.g., with functions and contexts indicated on display 36), with functionality that may change, for example, based on current programming operation or user preference. In alternative embodiments, display 36 may be a touch screen in which patient 12 may interact directly with display 36 without the use of control pad 40 or even increase button 52 and decrease button 50.
In the illustrated embodiment, patient programmer 30 is a hand held device. Patient programmer 30 may accompany patient 12 throughout a daily routine. In some cases, patient programmer 30 may be used by a clinician when patient 12 visits the clinician in a hospital or clinic. In other embodiments, patient programmer 30 may be a clinician programmer that remains with the clinician or in the clinic and is used by the clinician and/or patient 12 when the patient is in the clinic. In the case of a clinician programmer, small size and portability may be less important. Accordingly, a clinician programmer may be sized larger than a patient programmer, and it may provide a larger screen for more full-featured programming.
Housing 32 may be constructed of a polymer, metal alloy, composite, or combination material suitable to protect and contain components of patient programmer 30. In addition, housing 32 may be partially or completely sealed such that fluids, gases, or other elements may not penetrate the housing and affect components therein. Power button 38 may turn patient programmer 30 ON or OFF as desired by patient 12. Patient 12 may control the illumination level, or backlight level, of display 36 by using control pad 40 to navigate through the user interface and increase or decrease the illumination level with decrease and increase buttons 50 and 52, respectively. In some embodiments, illumination of display 36 may be controlled by a knob that rotates clockwise and counter-clockwise. Patient programmer 30 may be prevented from turning OFF during telemetry with IMD 14 or another device to prevent the loss of transmitted data or the stalling of normal operation. Alternatively, patient programmer 30 and IMD 14 may include instructions that handle possible unplanned telemetry interruption, such as battery failure or inadvertent device shutdown.
Display 36 may be a liquid crystal display (LCD), dot matrix display, organic light-emitting diode (OLED) display, touch screen, or similar monochrome or color display capable of providing visible information to patient 12. Display 36 may provide a user interface regarding current stimulation therapy, posture state information, provide a user interface for receiving feedback or medication input from patient 12, display an active group of stimulation programs, and display operational status of patient programmer 30 or IMDs 14 or 26. For example, patient programmer 30 may provide a scrollable list of groups, and a scrollable list of programs within each group, via display 36. In addition, display 36 may present a visible posture state indication based on the posture state(s) detected by IMD 14. In some examples, this posture state indication may be the avatar of patient 12 or other graphical indicator updated continuously in or near real-time according to posture state data transmitted from IMD 14. However, patient programmer 30 may typically present other posture state indications such as a small icon or text representation along with regular therapy.
Further, display 36 may present therapy adjustment information stored during a record mode of IMD 14, in which IMD 14 records posture state transitions, therapy adjustments, or other information, and even present nominal or suggested therapy parameters for a plurality of programs. This therapy adjustment information may be presented along with an indicator of the posture state of the patient in a playback mode. Patient 12 may then selectively set the plurality of programs to the respective nominal or suggested therapy parameters via a single confirmation input. As described herein, patient programmer 30 may be configured to perform any tasks described with respect to clinician programmer 60 or another external programmer 20. In addition, patient programmer 30 may accept input from patient 12 identifying symptoms such as pain or paresthesia that the patient recognizes during therapy or without any therapy being delivered.
Control pad 40 allows patient 12 to navigate through items displayed on display 36. Patient 12 may press control pad 40 on any of arrows 42, 44, 46, and 48 in order to move to another item on display 36 or move to another screen not currently shown on the display. In some embodiments, pressing the middle of control pad 40 may select any item highlighted in display 36. In other embodiments, scroll bars, a scroll wheel, individual buttons, or a joystick may perform the complete or partial functions of control pad 40. In alternative embodiments, control pad 40 may be a touch pad that allows patient 12 to move a cursor within the user interface displayed on display 36 to manage therapy.
Decrease button 50 and increase button 52 provide an input mechanism for patient 12. In general, decrease button 50 may decrease the value of a highlighted stimulation parameter every time the decrease button is pressed. In contrast, increase button 52 may increase the value of a highlighted stimulation parameter one step every time the increase button is pressed. While buttons 50 and 52 may be used to control the value of any stimulation parameter, buttons 50 and 52 may also control patient feedback input. When either of buttons 50 and 52 is selected, patient programmer 30 may initialize communication with IMD 14 or 26 to change therapy accordingly.
When depressed by patient 12, stimulation ON button 54 directs programmer 30 to generate a command for communication to IMD 14 that turns on stimulation therapy. Stimulation OFF button 56 turns off stimulation therapy when depressed by patient 12. Sync button 58 forces patient programmer 30 to communicate with IMD 14. When patient 12 enters an automatic posture response screen of the user interface, pressing sync button 58 turns on the automatic posture response to allow IMD 14 to automatically change therapy according to the posture state of patient 12. Pressing sync button 58 again, when the automatic posture response screen is displayed, turns off the automatic posture response. In the example of
In some embodiments, buttons 54 and 56 may be configured to perform operational functions related to stimulation therapy or the use of patient programmer 30. For example, buttons 54 and 56 may control the volume of audible sounds produced by patient programmer 30, wherein button 54 increases the volume and button 56 decreases the volume. Button 58 may be pressed to enter an operational menu that allows patient 12 to configure the user interface of patient programmer 30 to the desires of patient 12. For example, patient 12 may be able to select a language, backlight delay time, display brightness and contrast, or other similar options. In alternative embodiments, buttons 50 and 52 may control all operational and selection functions, such as those related to audio volume or stimulation therapy.
Patient programmer 30 may take other shapes or sizes not described herein. For example, patient programmer 30 may take the form of a clam-shell shape, similar to some cellular phone designs. When patient programmer 30 is closed, some or all elements of the user interface may be protected within the programmer. When patient programmer 30 is opened, one side of the programmer may contain a display while the other side may contain input mechanisms. In any shape, patient programmer 30 may be capable of performing the requirements described herein. Alternative embodiments of patient programmer 30 may include other input mechanisms such as a keypad, microphone, camera lens, or any other media input that allows the user to interact with the user interface provided by patient programmer 30.
In alternative embodiments, the buttons of patient programmer 30 may perform different functions than the functions provided in
Clinician programmer 60 is generally used by the clinician or other user to modify and review therapy to patient 12. The clinician may define each therapy parameter value for each of the programs that define stimulation therapy. The therapy parameters, such as amplitude, may be defined specifically for each of the posture states that patient 12 will be engaged in during therapy. The clinician may use clinician programmer 60 to calibrate, adjust, or define each posture state of patient 12 by using posture cones or other posture volumes as described herein or other techniques for associating posture state sensor output to the posture state of patient 12. Further, the clinician may use clinician programmer 60 to present an avatar or other indicator of a postures state of patient 12 based upon posture state data transmitted from IMD 14, e.g., in or near real-time. For example, programmer 60 may generate the appropriate anatomical configuration of the avatar to reflect a currently detected posture state and update this configuration as posture state data is transmitted from IMD 14.
Clinician programmer 60 includes display 64 and power button 66. In the example of
In the illustrated embodiment, clinician programmer 60 is a hand held device. Clinician programmer 60 may be used within the clinic or on in-house patient calls. Clinician programmer 60 may be used to communicate with multiple IMDs 14 and 26 within different patients. In this manner, clinician programmer 60 may be capable of communicating with many different devices and retain patient data separate for other patient data. In some embodiments, clinician programmer 60 may be a larger device that may be less portable, such as a notebook computer, tablet computer, workstation, or even a remote computer that communicates with IMD 14 or 26 via a remote telemetry device to display example user interfaces 200, 232, or 250.
Most, if not all, of the functions of clinician programmer may be completed via the touch screen of display 64. The user may program stimulation therapy, modify programs or groups, retrieve stored therapy data, retrieve posture state information, define posture states and other activity information, change the contrast and backlighting of display 64, or any other therapy related function. In addition, clinician programmer 60 may be capable of communicating with a networked server in order to send or receive an email or other message, retrieve programming instructions, access a help guide, send an error message, or perform any other function that may be beneficial to prompt therapy.
In some cases, all processing may be performed in IMD 14 and distributed to clinician programmer 60 only for presentation to the clinician. Alternatively, two or more of IMD 14, clinician programmer 60, patient programmer 30, or another computing device may share in the processing duties of processing therapy adjustment information and any other data prior to presenting the information on clinician programmer 60. For example, IMD 14 may transmit posture state data that includes the raw sampled signal values generated by one or more sensors of the posture state module. Then programmer 60 may analyze this raw signal data according to a detection algorithm to identify the posture state of patient 12. As described above, in some examples, the identified posture state may be one or more of a real-time posture state, an asserted posture state, and a stable posture state. Alternatively, IMD 14 may perform the processing and analysis of the raw sampled signal values and then transmit the identified posture state(s) of patient 12 to programmer 60 or other external device. It should be noted that the processing and analysis of posture state data, including posture state sensor data, for example, for patient 12 could also be shared between the transmitting and receiving devices.
Housing 62 may be constructed of a polymer, metal alloy, composite, or combination material suitable to protect and contain components of clinician programmer 60. In addition, housing 62 may be partially or completely sealed such that fluids, gases, or other elements may not penetrate the housing and affect components therein. Power button 66 may turn clinician programmer 600N or OFF as desired by the user. Clinician programmer 60 may require a password, biometric input, or other security measure to be entered and accepted before the user can use clinician programmer 60.
Clinician programmer 60 may take other shapes or sizes not described herein. For example, clinician programmer 60 may take the form of a clam-shell shape, similar to some cellular phone designs. When clinician programmer 60 is closed, at least a portion of display 64 is protected within housing 62. When clinician programmer 60 is opened, one side of the programmer may contain a display while the other side may contain input mechanisms. In any shape, clinician programmer 60 may be capable of performing the requirements described herein.
Memory 82 may be considered, in some examples, a non-transitory computer-readable storage medium comprising instructions that cause one or more processors, such as, e.g., processor 80, to implement one or more of the example techniques described in this disclosure. The term “non-transitory” may indicate that the storage medium is not embodied in a carrier wave or a propagated signal. However, the term “non-transitory” should not be interpreted to mean that memory 82 is non-movable. As one example, memory 82 may be removed from IMD 14, and moved to another device. In certain examples, a non-transitory storage medium may store data that can, over time, change (e.g., in RAM).
Processor 80 controls stimulation generator 84 to deliver electrical stimulation via electrode combinations formed by electrodes in one or more electrode arrays. For example, stimulation generator 84 may deliver electrical stimulation therapy via electrodes on one or more leads 16, e.g., as stimulation pulses or continuous waveforms. Components described as processors within IMD 14, external programmer 20 or any other device described in this disclosure may each comprise one or more processors, such as one or more microprocessors, digital signal processors (DSPs), application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), programmable logic circuitry, or the like, either alone or in any suitable combination.
Stimulation generator 84 may include stimulation generation circuitry to generate stimulation pulses or waveforms and switching circuitry to switch the stimulation across different electrode combinations, e.g., in response to control by processor 80. In particular, processor 80 may control the switching circuitry on a selective basis to cause stimulation generator 84 to deliver electrical stimulation to selected electrode combinations and to shift the electrical stimulation to different electrode combinations in a first direction or a second direction when the therapy must be delivered to a different location within patient 12. In other embodiments, stimulation generator 84 may include multiple current sources to drive more than one electrode combination at one time. In this case, stimulation generator 84 may decrease current to the first electrode combination and simultaneously increase current to the second electrode combination to shift the stimulation therapy.
An electrode combination may be represented by a data stored in a memory location, e.g., in memory 82, of IMD 14. Processor 80 may access the memory location to determine the electrode combination and control stimulation generator 84 to deliver electrical stimulation via the indicated electrode combination. To change electrode combinations, amplitudes, pulse rates, or pulse widths, processor 80 may command stimulation generator 84 to make the appropriate change or changes to therapy according to instructions within memory 82 and rewrite the memory location to indicate the changed therapy. In other embodiments, rather than rewriting a single memory location, processor 80 may make use of two or more memory locations.
When activating stimulation, processor 80 may access not only the memory location specifying the electrode combination but also other memory locations specifying various stimulation parameters such as voltage or current amplitude, pulse width and pulse rate. Stimulation generator 84, e.g., under control of processor 80, then makes use of the electrode combination and parameters in formulating and delivering the electrical stimulation to patient 12.
In some examples, stimulation parameters or other therapy parameters may be adjusted to modify stimulation therapy delivered by IMD 14 based on the detected posture state of patient 12. In some examples, processor 80 may detect a posture state of patient 12 via posture state module 86 that indicates that a modification of the stimulation therapy is appropriate, e.g., according to instructions stored in memory 82. Processor 80 may access instructions for modifying the stimulation therapy based on the patient 12 posture state, e.g., by changing from a stimulation program appropriate for the previous posture state to a stimulation program appropriate for patient's current posture state.
An exemplary range of electrical stimulation parameters likely to be effective in treating chronic pain, e.g., when applied to spinal cord 18, are listed below. However, other parameter values are contemplated. While stimulation pulses are described, stimulation signals may be of any of a variety of forms such as sine waves or the like.
Pulse Rate: between approximately 0.5 Hz and 1200 Hz, more preferably between approximately 5 Hz and 250 Hz, and still more preferably between approximately 30 Hz and 130 Hz.
Amplitude: between approximately 0.1 volts and 50 volts, more preferably between approximately 0.5 volts and 20 volts, and still more preferably between approximately 1 volt and 10 volts. In other embodiments, a current amplitude may be defined as the biological load in the voltage that is delivered. For example, the range of current amplitude may be between 0.1 milliamps (mA) and 50 mA.
Pulse Width: between about 10 microseconds and 5000 microseconds, more preferably between approximately 100 microseconds and 1000 microseconds, and still more preferably between approximately 180 microseconds and 450 microseconds.
In other applications, different ranges of parameter values may be used. For deep brain stimulation (DBS), as one example, alleviation or reduction of symptoms associated with Parkinson's disease, essential tremor, epilepsy or other disorders may make use of stimulation having a pulse rate in the range of approximately 0.5 to 1200 Hz, more preferably 5 to 250 Hz, and still more preferably 30 to 185 Hz, and a pulse width in the range of approximately 10 microseconds and 5000 microseconds, more preferably between approximately 60 microseconds and 1000 microseconds, still more preferably between approximately 60 microseconds and 450 microseconds, and even more preferably between approximately 60 microseconds and 150 microseconds. Amplitude ranges such as those described above with reference to SCS, or other amplitude ranges, may be used for different DBS applications. Parameter values other than those described above are contemplated
Processor 80 accesses stimulation parameters in memory 82, e.g., as programs and groups of programs. Upon selection of a particular program group, processor 80 may control stimulation generator 84 to deliver stimulation according to the programs in the groups, e.g., simultaneously or on a time-interleaved basis. A group may include a single program or multiple programs. As mentioned previously, each program may specify a set of stimulation therapy parameters, such as amplitude, pulse width and pulse rate. In addition, each program may specify a particular electrode combination for delivery of stimulation. Again, the electrode combination may specify particular electrodes in a single array or multiple arrays, e.g., on a single lead or among multiple leads.
Posture state module 86 allows IMD 14 to sense or detect a current patient posture state, e.g., posture, activity or any other static position or motion of patient 12. In the example of
Posture state data from posture state module 86 may be stored in memory 82 for later review by a clinician, used to adjust therapy, present one or more posture state indicators to patient 12, or some combination thereof. As an example, processor 80 may record the posture state parameter value (e.g., raw signal output) of the 3-axis accelerometer and assign the posture state parameter value to a certain predefined posture indicated by the posture state parameter value. In this manner, IMD 14 may be able to track how often patient 12 remains within a certain posture state. IMD 14 may also store which group or program was being used to deliver therapy when patient 12 was in the sensed posture. Further, processor 80 may also adjust therapy for a new posture state when posture state module 86 indicates that patient 12 has in fact changed posture states. Therefore, IMD 14 may be configured to provide posture responsive stimulation therapy to patient 12. Stimulation adjustments in response to posture state may be automatic or semi-automatic (subject to patient approval). In many cases, fully automatic adjustments may be desirable so that IMD 14 may react more quickly to posture state changes.
A posture state parameter value from posture state module 86 that indicates the posture state may constantly vary throughout the day of patient 12. However, a certain activity (e.g., walking, running, or biking) or a posture (e.g., standing, sitting, or lying (front, back, left, right)) may include multiple posture state parameter values from posture state module 86. Memory 82 may include definitions for each posture state of patient 12. In one example, the detection algorithm for posture states may include definitions of each posture state may be illustrated as a cone in three-dimensional space. Whenever the posture state parameter value (e.g., a vector derived from sampled x, y, and z signal values) from the three-axis accelerometer of posture state module 86 resides within a predefined cone, volume or other zone, processor 80 indicates that patient 12 is in the posture state of the cone, volume, or other zone. In other examples, a posture state parameter value from the 3-axis accelerometer may be compared to values in a look-up table or equation to determine the posture state in which patient 12 currently resides.
Posture state responsive stimulation may allow IMD 14 to implement a certain level of automation in therapy adjustments. Automatically adjusting stimulation may free patient 12 from the constant task of manually adjusting therapy each time patient 12 changes posture or starts and stops a certain posture state. Such manual adjustment of stimulation parameters can be tedious, requiring patient 14 to, for example, depress one or more keys of patient programmer 30 multiple times during the patient posture state to maintain adequate symptom control. In some embodiments, patient 12 may eventually be able to enjoy posture state responsive stimulation therapy without the need to continue making changes for different postures via patient programmer 30. Instead, patient 12 may transition immediately or over time to fully automatic adjustments based on posture state.
As described above, the posture state of patient 12 detected by IMD 14 or other device based on posture state data from posture state module 86 may include a real-time posture state, an asserted posture state, and a stable posture state of patient. In some examples, IMD 14 may adjust therapy delivered to a patient upon a change in the stable posture state, for example, rather than a change in real-time posture state or asserted posture state. Indicators of two or more of such posture states may be displayed simultaneously in or near real-time on an external display device such as programmer 20, 30, or 60. In other examples, indicators of two or more of such patient posture states may be displayed simultaneously and on the same temporal basis on an external display but may reflect a historical review of patient posture states rather than a real-time representation.
Although posture state module 86 is described as containing the 3-axis accelerometer, posture state module 86 may contain multiple single-axis accelerometers, dual-axis accelerometers, 3-axis accelerometers, or some combination thereof. In some examples, an accelerometer or other sensor may be located within or on IMD 14, on one of leads 16 (e.g., at the distal tip or at an intermediate position), an additional lead including a sensor positioned somewhere within patient 12, within an independent implantable sensor, or an accelerometer or other sensor externally worn on patient 12. In one example, one or more microsensors may be implanted within patient 12 or externally worn to communicate posture state information wirelessly to IMD 14 or other device. In this manner, a posture state of patient 12 may be determined from multiple activity sensors placed at various locations on or within the body of patient 12.
In some examples, processor 80 processes the analog output of the posture state sensor in posture state module 86 to determine activity and/or posture data. For example, where the posture state sensor comprises an accelerometer, processor 80 or a processor of posture state module 86 may process the raw sensor signals provided by the posture state sensor to determine activity counts. In some embodiments, processor 80 may process the sensor signals provided by the posture state sensor to determine velocity of motion information along each axis.
In one example, each of the x, y, and z signals provided by the posture state sensor has both a DC component and an AC component. The DC components may describe the gravitational force exerted upon the sensor and can thereby be used to determine orientation of the sensor within the gravitational field of the earth. Assuming the orientation of the sensor is relatively fixed with respect to the patient, the DC components of the x, y and z signals may be utilized to determine the patient's orientation within the gravitational field, and hence to determine the posture of the patient. 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. This activity may involve a level, direction of motion, or acceleration of the patient.
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 12. 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 the processor based on the current posture state, if desired. The activity count may be the activity portion of the activity parameter value that is added to the posture portion. The resulting activity parameter value may then incorporate both activity and posture to generate an accurate indication of the motion of patient 12.
As another example, the activity parameter value may be defined as describing a direction of motion. This activity parameter value may be associated with a vector and an associated tolerance, which may be a distance from the vector. Another example of an activity parameter value relates to acceleration. The value quantifying a level of change of motion over time in a particular direction may be associated with this parameter referenced in the activity parameter value.
In other embodiments, posture state module 86 may additionally or alternatively be configured to sense one or more physiological parameters of patient 12. 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 processor 80, in some examples, to confirm or reject changes in sensed posture state that may result from vibration, patient travel (e.g., in an aircraft, car or train), or some other false positive of posture state.
Posture state module 86 may sample output of the postures state sensor(s) at any sample rate suitable for therapy or desired to present one or more posture state indicators in or near real-time via an external display. The sample rate may indicate how often processor 80 samples the output of the posture state sensor signals of posture state module 86. In some examples, output of the posture state sensor of posture state module 86 is sampled at a sample rate between about 1 Hz and about 60 Hz, such as, e.g., between about 10 Hz and about 40 Hz. However, the sample rate may be any slower or faster rate supported by the processing capabilities of IMD 14 circuitry. In some examples, it may be beneficial to sample at the slowest rate needed for effective posture state detection to conserve battery life.
Wireless telemetry in IMD 14 with external programmer 20 or other display device, e.g., patient programmer 30 or clinician programmer 60, or another device may be accomplished by radio frequency (RF) communication or proximal inductive interaction of IMD 14 with external programmer 20. In some examples, telemetry circuit 88 may support Bluetooth-based communication between IMD 14 and external programmer 20 or other external device. Telemetry circuit 88 may send information to and receive information from external programmer 20, on a continuous basis, at periodic intervals, at non-periodic intervals, or upon request from the stimulator or programmer.
Processor 80 controls telemetry circuit 88 to send and receive information to and from external programmer 20. For example, processor 80 commands telemetry circuit 88 to transmit information, e.g., posture state data, in or near real-time when communicating to any external display device. For posture state data transmitted in or near real-time, telemetry circuit 88 may send the most recently detected posture state(s) or sampled sensor signal values, or a rolling average posture state and/or sample sensor signal values at or near the fasted rate supported by the telemetry circuit. The posture state data may be transmitted to an external device at a rate between about every two seconds and about ten times per second, such as, e.g., between about every second and about three time per second. Other posture state data transmission rates are contemplated. However, processor 80 may transmit posture state data via telemetry circuit 88 at a slower or faster rate depending upon the requirements of the user viewing the real-time display of patient posture state and the display capabilities of the display device, e.g., the rate at which the display may be refreshed.
In some examples, the posture state data may be transmitted from IMD 14 to external programmer 20 or other display device at a rate substantially the same as the rate processor 80 samples the posture sensor signal of posture state module 86. In other examples, the posture state data may be transmitted from IMD 14 to external programmer 20 or other external display device at rate that is less than the sensor sampling rate. In such case, the posture sensor data transmitted from IMD 14 to the external display device may include information regarding only a single sampled sensor value or a plurality of sensor values, e.g., those sensor values sampled since the prior transmission to the external device. To support RF communication, telemetry circuit 88 may include appropriate electronic components, such as amplifiers, filters, mixers, encoders, decoders, and the like. In some examples, the rate at which the posture state data is transmitted from IMD 14 to external programmer 20 or other display device may depend on the graphic capability of the display device (e.g., rate at which graphical representations may be updated on a display screen), rate of patient movement (e.g., the rate at which patient 12 may be able to physically change posture states), and/or the sampling rate of the posture state sensor of IMD 14.
In non-continuous transmission applications, processor 80 may control the transmission of posture state data differently. For example, when processor 80 determines that patient 12 has changed to a different posture state via posture state module 86, processor 80 may communicate with patient programmer 30 via telemetry circuitry 88 to indicate the newly detected posture state currently occupied by patient 12. In this manner, processor 80 may force patient programmer 30 to present a different posture state indication based upon the sensed posture state parameter value of the patient posture state. In particular, processor 80 may transmit a new posture state detection to patient programmer 30 to indicate the currently detected posture state occupied by the patient. Alternatively, processor 80 may periodically or non-periodically send posture state information to patient programmer 30 either unilaterally or in response to a request from patient programmer 30. For example, patient programmer 30 may request the posture state parameter value or currently detected posture state, either of which indicates detected posture state, and independently change the posture state indication when it is appropriate to do so.
Power source 90 delivers operating power to the components of IMD 14. 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 14. In some embodiments, power requirements may be small enough to allow IMD 14 to utilize patient motion and implement a kinetic energy-scavenging device to trickle charge a rechargeable battery. In other embodiments, rechargeable or non-rechargeable batteries may be used for a limited period of time. As a further alternative, an external inductive power supply could transcutaneously power IMD 14 when needed or desired.
Processor 92 may control pump module 96 according to therapy instructions stored within memory 94. For example, memory 94 may contain the programs or groups of programs that define the drug delivery therapy for patient 12. A program may indicate the bolus size or flow rate of the drug, and processor 92 may accordingly deliver therapy. Processor 92 may also use posture state information from posture state module 98 to adjust drug delivery therapy when patient 12 changes posture states, e.g., adjusts their posture.
User interface 106 may include a screen or display and one or more input buttons, as in the example of patient programmer 30, that allow external programmer 20 to receive input from a user. Alternatively, user interface 106 may additionally or only utilize a touch screen display, as in the example of clinician programmer 60. As described herein, user interface may be embodied as example user interfaces 200, 232, or 250. The screen may be a liquid crystal display (LCD), dot matrix display, organic light-emitting diode (OLED) display, touch screen, or any other device capable of delivering and/or accepting information. For an avatar posture state indicator or other visible posture state indicators, a display screen may suffice. For audible and/or tactile posture state indicators, programmer 20 may further include one or more audio speakers, voice synthesizer chips, piezoelectric buzzers, or the like.
Input buttons for user interface 106 may include a touch pad, increase and decrease buttons, emergency shut off button, and other buttons needed to control the stimulation therapy, as described above with regard to patient programmer 30. Processor 104 controls user interface 106, retrieves data from memory 108 and stores data within memory 108. Processor 104 also controls the transmission of data through telemetry circuit 110 to IMDs 14 or 26. Memory 108 includes operation instructions for processor 104 and data related to patient 12 therapy.
Telemetry circuit 110 allows the transfer of data to and from IMD 14, or IMD 26. When presenting the avatar in real-time, telemetry circuit 110 may communicate automatically with IMD 14 in or near real-time. Telemetry circuit 110 may receive the posture state data from IMD 14 or 26 in or near real-time, and immediately send the posture state data to processor 104 for any analysis before processor 104 generates and presents one or more posture state indicators based on the received posture state data on user interface 106.
In addition, telemetry circuit 110 may communicate at a scheduled time or when the telemetry circuit detects the proximity of the stimulator. User interface 106 may then update displayed information accordingly. Alternatively, telemetry circuit 110 may communicate with IMD 14 when signaled by a user through user interface 106. To support RF communication, telemetry circuit 110 may include appropriate electronic components, such as amplifiers, filters, mixers, encoders, decoders, and the like. Power source 112 may be a rechargeable battery, such as a lithium ion or nickel metal hydride battery. Other rechargeable or conventional batteries may also be used. In some cases, external programmer 20 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 some examples, external programmer 20 may be configured to recharge IMD 14 in addition to programming IMD 14. Alternatively, a recharging device may be capable of communication with IMD 14. Then, the recharging device may be able to transfer programming information, data, or any other information described herein to IMD 14. In this manner, the recharging device may be able to act as an intermediary communication device between external programmer 20 and IMD 14. In other cases, the programmer may be integrated with a recharging functionality in the combined programming/recharging device. The techniques described herein may be communicated between IMD 14 via any type of external device capable of communication with IMD 14.
Processor 104 may also analyze the posture state data transmitted, e.g., in or near real-time, from IMD 14 when the transmitted posture state data is the raw posture sensor signal from the posture state module. Processor 104 may utilize the same detection algorithm(s) of IMD 14 to identify the posture state of patient 12 from the raw or unprocessed posture state data. Alternatively, processor 104 may use an alternative detection algorithm as requested by the user. If the real-time indicator or other posture state indicator presented by external programmer 20 is not correlating with actual patient 12 posture states, the user may desire to use a different detection algorithm that may more accurately identify the patient posture state. In this manner, processor 104 may toggle between different detection algorithms as requested by the user. If a different detection algorithm is selected for use, processor 104 may transmit the new algorithm to IMD 14 or 26 for use during therapy.
In the example of
Access point 128 may comprise a device, such as a home monitoring device, that connects to network 126 via any of a variety of connections, such as telephone dial-up, digital subscriber line (DSL), or cable modem connections. In other embodiments, access point 128 may be coupled to network 126 through different forms of connections, including wired or wireless connections.
During operation, IMD 14 may collect and store various forms of data. For example, IMD 14 may collect sensed posture state information during therapy that indicate how patient 12 moves throughout each day. In some cases, IMD 14 may directly analyze the collected data to evaluate the patient 12 posture state, such as what percentage of time patient 12 was in each identified posture. In other cases, however, IMD 14 may send stored data relating to posture state information to external programmer 20 and/or server 122, either wirelessly or via access point 128 and network 126, for remote processing and analysis.
For example, IMD 14 may sense, process, trend and evaluate the sensed posture state information, including posture state data. This communication may occur in or near real-time, and network 126 may allow a remote clinician to review the current patient posture state by receiving a presentation of posture state indicator(s) along with other therapy information on a remote display device, e.g., computing device 124A. For example, the remote clinician may view a real-time posture state indicator of patient 12 or indicator of other identified patient posture state in a location separate to that of patient 12. Alternatively, processing, trending and evaluation functions may be distributed to other devices such as external programmer 20 or server 122, which are coupled to network 126. In addition, posture state information may be archived by any of such devices, e.g., for later retrieval and analysis by a clinician.
In some cases, IMD 14, external programmer 20 or server 122 may process posture state information or raw data and/or therapy information into a displayable posture state report, which may be displayed via external programmer 20 or one of computing devices 124A-124N. The posture state report may contain trend data for evaluation by a clinician, e.g., by visual inspection of graphic data. In some cases, the posture state report may include the number of activities patient 12 conducted, a percentage of time patient 12 was in each posture state, the average time patient 12 was continuously within a posture state, what group or program was being used to deliver therapy during each activity, the number of adjustments to therapy during each respective posture state, or any other information relevant to patient 12 therapy, based on analysis and evaluation performed automatically by IMD 14, external programmer 20 or server 122. A clinician or other trained professional may review the historical therapy information including the stimulation parameters, symptoms, and posture states to possibly identify any problems or issues with the therapy that should be addressed.
In addition, network 126 may be configured to facilitate substantially real-time communication between IMD 14 and computing device 124A for programming with the current posture state of the patient. Although there may be some slight time delay in the transfer of information, this may still be considered real-time programming utilizing any user interface such as user interfaces 200, 232, or 250. The clinician may be able to remotely visit with patient 12, review stored therapy information, and make any programming changes, e.g., in or near real-time, using system 120.
In some cases, server 122 may be configured to provide a secure storage site for archival of posture state information that has been collected from IMD 14 and/or external programmer 20. Network 126 may comprise a local area network, wide area network, or global network, such as the Internet. In other cases, external programmer 20 or server 122 may assemble posture state information in web pages or other documents for viewing by trained professionals, such as clinicians, via viewing terminals associated with computing devices 124A-124N. 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 posture state information and data, system 120 may be employed to distribute any information relating to the treatment of patient 12 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 in the therapy and reprogram IMD 14, patient programmer 30, or communicate with patient 12. 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. Further, posture state detection may also be used to provide notifications, such as providing notification via a wireless link to a care giver that a patient has potentially experienced a fall.
Furthermore, although the disclosure is described with respect to SCS therapy, such techniques may be applicable to IMDs that convey other therapies in which posture state information is important, such as, e.g., DBS, pelvic floor stimulation, gastric stimulation, occipital stimulation, functional electrical stimulation, and the like. Also, in some aspects, techniques for evaluating posture state information, as described in this disclosure, may be applied to IMDs or external medical devices that are generally dedicated to sensing or monitoring and do not include stimulation or other therapy components. For example, an implantable monitoring device may be implanted in conjunction with an implantable stimulation device, and be configured to evaluate sensing integrity of leads or electrodes associated with the implantable monitoring device based on sensed signals evoked by delivery of stimulation by the implantable stimulation device.
In some cases, one or more posture state regions may be defined as posture state cones. Posture state cones may be used to define a posture state of patient 12 based on the output from a posture state sensor of a posture state module according to an example method for posture state detection. A posture state cone may be centered about a posture state reference coordinate vector that corresponds to a particular posture state. In the examples of
A posture cone may be defined by a reference coordinate vector for a given posture state in combination with a distance or angle defining a range of coordinate vectors within a cone surrounding the posture reference coordinate vector. Alternatively, a posture cone may be defined by a reference coordinate vector and a range of cosine values computed using the reference coordinate vector as an adjacent vector and any of the outermost vectors of the cone as a hypotenuse vector. If a sensed posture state vector is within an applicable angle or distance of the reference coordinate vector, or if the sensed posture state vector and the reference coordinate vector produce a cosine value in a specified cosine range, then posture state vector is determined to reside within the posture cone defined by the reference coordinate vector.
Posture state space 140 is segmented into different posture cones that are indicative of a certain posture state of patient 12. In the example of
Vertical axis 141 and horizontal axis 143 are provided for orientation of posture state area 140, and are shown as orthogonal for purposes of illustration. However, posture cones may have respective posture reference coordinate vectors that are not orthogonal in some cases. For example, individual reference coordinate vectors for cones 142 and 146 may not share the same axis, and reference coordinate vectors for cones 144 and 148 may not share the same axis. Also, reference coordinate vectors for cones 144 and 148 may or may not be orthogonal to reference coordinates vectors for cones 142, 146. Moreover, the reference coordinate vectors need not reside in the same plane. Therefore, although orthogonal axes are shown in
IMD 14 may monitor the posture state parameter value of the posture state sensor to produce a sensed coordinate vector and identify the current posture of patient 12 by identifying which cone the sensed coordinated vector of the posture state sensor module 86 resides. For example, if the posture state parameter value corresponds to a sensed coordinate vector that falls within lying front cone 144, IMD 14 determines that patient 12 is lying down on their chest. IMD 14 may store this posture state information as a determined posture state or as raw output from the posture state sensor, change therapy according to the posture, or both. Additionally, IMD 14 may communicate the posture state information to patient programmer 30 so that the patient programmer can present a posture state indication to patient 12, e.g., via programmer 20.
In addition, posture state area 140 may include hysteresis zones 150A, 150B, 150C, and 150D (collectively “hysteresis zones 150”). Hysteresis zones 150 are positions within posture state area 140 where no posture cones have been defined. Hysteresis zones 150 may be particularly useful when IMD 14 utilizes the posture state information and posture cones to adjust therapy automatically. If the posture state sensor indicates that patient 12 is in upright cone 142, IMD 14 would not detect that patient 12 has entered a new posture cone until the posture state parameter value indicates a different posture cone. For example, if IMD 14 determines that patient 12 moves to within hysteresis zone 150A from upright cone 142, IMD 14 retains the posture as upright. In this manner, IMD 14 does not change the corresponding therapy until patient 12 fully enters a different posture cone. Hysteresis zones 150 prevent IMD 14 from continually oscillating between different therapies when patient 12's posture state resides near a posture cone boundary.
Each posture cone 142, 144, 146, 148 may be defined by an angle in relation to a reference coordinate vector defined for the respective posture cone. Alternatively, some posture cones may be defined by an angle relative to a reference coordinate vector for another posture cone. For example, lying postures may be defined by an angle with respect to a reference coordinate vector for an upright posture cone. In each case, as described in further detail below, each posture cone may be defined by an angle in relation to a reference coordinate posture vector defined for a particular posture state. The reference coordinate vector may be defined based on posture sensor data generated by a posture state sensor while patient 12 occupies a particular posture state desired to be defined using the reference coordinate vector. For example, a patient may be asked to occupy a posture so that a reference coordinate vector can be sensed for the respective posture. In this manner, vertical axis 141 may be specified according to the patient's actual orientation. Then, a posture cone can be defined using the reference coordinate vector as the center of the cone.
Vertical axis 141 in
Posture cones may be defined by the same angle or different angles, symmetrical to either axis, or asymmetrical to either axis. For example, upright cone 142 may have an angle of eighty degrees, +40 degrees to −40 degrees from the positive vertical axis 141. In some cases, lying cones may be defined relative to the reference coordinate vector of the upright cone 142. For example, lying up cone 148 may have an angle of eighty degrees, −50 degrees to −130 degrees from the positive vertical axis 141. Inverted cone 146 may have an angle of eighty degrees, −140 degrees to +140 degrees from vertical axis 141. In addition, lying down cone 144 may have an angle of eighty degrees, +50 degrees to +130 degrees from the positive vertical axis 141. In other examples, each posture cone may have varying angle definitions, and the angles may change during therapy delivery to achieve the most effective therapy for patient 12.
Alternatively or additionally, instead of an angle, posture cones 144, 146, 148, 148 may be defined by a cosine value or range of cosine values in relation to vertical axis 141, horizontal axis 143, or some other axis, such as, e.g., individual reference coordinate vectors for the respective cones. For example, a posture cone may be defined by a cosine value that defines the minimum cosine value, calculated using a reference coordinate vector and a respective coordinate vector sensed by a posture state sensor at any point in time. In the cosine computation, the value (adjacent/hypotenuse) can be computed using the magnitude of the coordinate reference vector as the adjacent and a vector at the outermost extent of the cone as the hypotenuse to define a range of cosine values consistent with the outer bound of the cone.
For upright cone 142, the cosine range may extend from the maximum cosine value of 1.0, corresponding to a sensed vector that matches the reference coordinate vector of the upright cone, to a minimum cosine value that corresponds to a sensed vector at the outer limit of the upright cone. As another example, for lying cone 144, the cosine range may extend from the maximum cosine value of 1.0, corresponding to a sensed vector that matches the reference coordinate vector of the lying cone, to a minimum cosine value that corresponds to a sensed vector at the outer limit of the lying cone. Alternatively, the lying cone 144 may be defined with reference to the upright cone 142, such that the cosine range may extend between a maximum and minimum values determined relative to the reference coordinate vector for the upright cone.
In other examples, posture state area 140 may include additional posture cones than those shown in
Posture cones 154, 156 and 158 also are defined by a respective center line 153A, 153B, or 153C, and associated cone angle A, B or C. For example, upright cone 154 is defined by center line 153A that runs through the center of upright cone 154. Center line 153A may correspond to an axis of the posture state sensor or some other calibrated vector. In some embodiments, each center line 153A, 153B, 153C may correspond to a posture reference coordinate vectors defined for the respective postures, e.g., the upright posture. For instance, assuming that patient 12 is standing, the DC portion of the x, y, and z signals detected by the posture state sensor of posture state module 86 define a posture vector that corresponds to center line 153A.
The x, y, and z signals may be measured while patient 12 is known to be in a specified position, e.g., standing, and the measured vector may be correlated with the upright posture state. Thereafter, when the DC portions of the posture state sensor signal are within some predetermined cone tolerance or proximity, e.g., as defined by an angle, distance or cosine value, of the posture reference coordinate vector (i.e., center line 153A), it may be determined that patient 12 is in the upright posture. In this manner, a sensed posture coordinate vector may be initially measured based on the output of one or more posture state sensors of posture state module 86, associated with a posture state, such as upright, as a reference coordinate vector, and then later used to detect a patient's posture state.
As previously indicated, it may be desirable to allow some tolerance to be associated with a defined posture state, thereby defining a posture cone or other volume. For instance, in regard to the upright posture state, it may be desirable to determine that a patient who is upright but leaning slightly is still in the same upright posture state. Thus, the definition of a posture state may generally include not only a posture reference coordinate vector (e.g., center line 153A), but also a specified tolerance. One way to specify a tolerance is by providing an angle, such as cone angle A, relative to coordinate reference vector 153A, which results in posture cone 154 as described herein. Cone angle A is the deflection angle, or radius, of upright cone 154. The total angle that each posture cone spans is double the cone angle. The cone angles A, B, and C may be generally between approximately 1 degree and approximately 70 degrees. In other examples, cone angles A, B, and C may be between approximately 10 degrees and 30 degrees. In the example of
In some examples, a tolerance may be specified by a cosine value or range of cosine values. The use of cosine values, in some cases, may provide substantial processing efficiencies. As described above, for example, a minimum cosine value, determined using the reference coordinate vector as adjacent and sensed coordinate vector as hypotenuse, indicates the range of vectors inside the cone. If a sensed coordinate vector, in conjunction with the reference coordinate vector for a posture cone, produces a cosine value that is less than the minimum cosine value for the posture cone, the sensed coordinate vector does not reside within the pertinent posture cone. In this manner, the minimum cosine value may define the outer bound of a range of cosine values within a particular posture cone defined in part by a reference coordinate vector.
While center lines 153A, 153B, 153C of each of the posture cones 154, 156, 158, respectively, are shown in
In some cases, all of the posture cones may be individually defined based on actual reference coordinate vectors. Alternatively, in some cases, some posture cones may be defined with reference to one or more reference coordinate vectors for one or more other posture cones. For example, lying reference coordinate vectors could be assumed to be orthogonal to an upright reference coordinate vector. Alternatively, lying reference coordinate vectors could be individually determined based on sensed coordinate vectors when the patient is in respective lying postures. Hence, the actual reference coordinate vectors for different postures may be orthogonal or non-orthogonal with respect to one another, and need not reside within a same plane.
In addition to upright cone 154, lying back cone 156, and lying front cone 158, posture state space 152 may include additional posture cones. For example, a lying right cone may be provided to define a patient posture in which patient 12 is lying on his right side and a lying left cone may be provided to define a patient posture in which patient 12 is lying on his left side. In some cases, the lying right cone and lying left cone may be positioned approximately orthogonal to upright cones 154, in approximately the same plane as lying back cone 156 and lying front cone 158. Moreover, posture state space 152 may include an inverted cone positioned approximately opposite of upright cone 154. Such a cone indicates that the patient's posture is inverted from the upright posture, i.e., upside down.
In some examples, to detect the posture state of a patient, posture state module 86 of IMD 14 may determine a sensed coordinate vector based on the posture sensor data generated by one or more posture state sensors, and then analyze the sensed coordinate vector with respect to posture cones 154, 156, 158 of
Posture state module 86 may analyze the sensed coordinate vector in posture state space 152 with respect to each individual defined posture cone, such as posture cones 156 and 158, in such a manner to determine the posture state of patient 12. For example, posture state module 86 may determine the angle between the sensed coordinate vector and reference coordinate vector of individual posture cones defined for the posture state, and compare the determined angle to the tolerance angle defined for the respective posture cone. In this manner, a sensed coordinate vector may be evaluated against each posture cone until a match is detected, i.e., until the sensed coordinate vector is found to reside in one of the posture cones. Hence, a cone-by-cone analysis is one option for posture detection.
In other examples, different posture detection analysis techniques may be applied. For example, instead of testing a sensed coordinate vector against posture cones on a cone-by-cone basis, a phased approach may be applied where the sensed coordinate vector is classified as either upright or not upright. In this case, if the sensed coordinate vector is not in the upright cone, posture state module 86 may determine whether the sensed coordinate vector is in a lying posture, either by testing the sensed coordinate vector against individual lying posture cones or testing the sensed coordinate vector against a generalized lying posture volume, such as a donut- or toroid-like volume that includes all of the lying postures, and may be defined using an angle or cosine range relative to the upright vector, or relative to a modified or virtual upright vector as will be described. In some cases, if lying postures are defined by cones, the lying volume could be defined as a logical OR of the donut- or toroid-like volume and the volumes of the lying posture cones. If the cones are larger such that some portions extend beyond the lying volume, then those portions can be added to the lying volume using the logical OR-like operation.
If the sensed coordinate vector resides within the donut- or toroid-like lying volume, then the sensed coordinate vector may be tested against each of a plurality of lying posture cones in the lying volume. Alternatively, the posture detection technique may not use lying cones. Instead, a posture detection technique may rely on a proximity test between the sensed coordinate vector and each of the reference coordinate vectors for the respective lying postures. The proximity test may rely on angle, cosine value or distance to determine which of the lying posture reference coordinate vectors is closest to the sensed coordinate vector. For example, the reference coordinate vector that produces the largest cosine value with the sensed coordinate vector as hypotenuse and the reference coordinate vector as adjacent is the closest reference coordinate vector. In this case, the lying posture associated with the reference coordinate vector producing the largest cosine value is the detected posture. Hence, there are a variety of ways to detect posture, such as using posture cones, using an upright posture cone with lying volume and lying posture cone test, or using an upright posture cone with lying volume and lying vector proximity test.
As a further illustration of an example posture detection technique, posture state module 86 may first determine whether patient 12 is generally in a lying posture state or upright posture state by analyzing the sensed coordinate vector in posture state space 152 with respect to an axis 153A for the upright posture state. Axis 153A may correspond to the upright reference coordinate vector. For example, angle “A” may be used to define upright posture cone 154, as described above, and angles “D” and “E” may be used to define the vector space in which patient 12 may be generally considered to be in the lying posture state, regardless of the particular posture state cone, e.g., lying front cone 158, lying back cone 156, lying right cone (not shown), or lying left cone (not shown), in which the sensed coordinate vector falls.
If it is determined that a sensed coordinate vector is not within an angle A of the axis 153A, then it may be determined that the patient is not in the upright posture indicated by the upright posture cone. In this case, it may next be determined whether a sensed coordinated vector is generally in a lying posture space volume, which may be considered somewhat donut- or toroid-like, and may be defined relative to the upright reference coordinate vector 153A. As shown, angles “D” and “E” define the minimum and maximum angle values, respectively, that a sensed vector may form with respect to axis 153A of patient 12 for a determination to be made that the patient is generally in the lying posture state. Again, cosine values may be used instead of angles to determine the positions of sensed coordinate vectors relative to posture cones or other posture volumes, or relative to reference coordinate vectors.
As illustrated, angles “D” and “E’ may be defined with respect to vertical axis 153A (which may correspond to an upright reference coordinate vector), which is the reference coordinate vector for the upright posture cone, rather than with respect to a reference coordinate vector of a lying posture state cone. If a sensed vector is within the angular range of D to E, relative to axis 153A, then it can be determined by posture state module 86 that the patient is generally in a lying posture. Alternatively, in some examples, an angle C could be defined according to a generally horizontal axis 153C (which may correspond to one of the lying reference coordinate vectors). In this case, if a sensed vector is within angle C of axis 153C, it can be determined by posture state module 86 that the patient is in a lying posture. In each case, the region generally defining the lying posture state may be referred to as a posture donut or posture toroid, rather than a posture cone. The posture donut may generally encompass a range of vectors that are considered to be representative of various lying down postures.
As an alternative, posture state module 86 may rely on cosine values or a range of cosine values to define the posture donut or toroid with respect to axis 153A. When the sensed vector falls within the vector space defined by axis 153A and angles “D” and “E”, or produces a cosine value with the reference coordinate vector 153A in a prescribed range, posture state module 86 may determine that patient 12 is generally in a lying posture state. For example, if the sensed vector and reference coordinate vector 153 produce a cosine value in a first range, the posture is upright. If the cosine value is in a second range, the posture is lying. If the cosine value is outside of the first and second ranges, the posture may be indeterminate. The first range may correspond to the range of cosine values that would be produced by vectors in posture cone 154 defined by angle A, and the second range may be correspond to cosine values that would be produced by vectors in the posture donut defined by angles D and E.
When the sensed vector fall within the vector space defined by axis 153A and angles “D” and “E”, as indicated by angle or cosine value, posture state module 86 may then determine the particular lying posture state occupied by patient 12, e.g., lying front, lying back, lying right, or lying left. To determine the particular lying posture state occupied by patient 12, posture state module 86 may analyze the sensed vector with respect to reference coordinate vectors for individual lying posture state cones, e.g., lying front cone 156, lying back cone 158, lying right cone (not shown), and lying left cone (not shown), using one more techniques previously described, such as angle or cosine techniques. For example, posture state module 86 may determine whether the sensed coordinated vector resides within one of the lying posture state cones and, if so, select the posture state corresponding to that cone as the detected posture state.
As shown in
In some examples, to determine the posture state of patient 12, posture state module 85 may determine whether a sensed coordinate vector is within upright posture cone 157 by analyzing the sensed coordinate vector in view of the tolerance angle or cosine value(s) defined with respect to upright posture reference coordinate vector 167, or whether the sensed vector is within a posture donut or toroid defined by a range of angles (as in
If posture state module 86 determines that patient 12 is occupying a general lying posture state, posture state module 86 may then calculate the cosine value of the sensed coordinate vector with respect to each lying reference coordinate vectors 159, 161, 163, 165. In such a case, posture state module 86 determines the particular lying posture state of patient 12, i.e., lying left, lying right, lying front, lying back, based on which cosine value is the greatest of the four cosine values. For example, if the cosine value calculated with the sensed vector as the hypotenuse and the lying front reference vector 163 as the adjacent vector is the largest value of the four cosine values, the sensed vector may be considered closest in proximity to lying front reference vector out of the four total reference vectors 159, 161, 163, 165. Accordingly, posture state module 85 may determine that patient 12 is occupying a lying front posture state.
In some examples, posture state module 86 may determine whether patient 12 is generally in a lying posture state based on the relationship of a sensed vector to upright reference vector 167. For example, as described above, a lying posture donut or toroid may be defined with respect to upright posture reference vector 167, e.g., using angles D and E as in
To account for non-orthogonal reference vectors, in other examples, a lying posture donut or toroid may be defined with respect to a modified or virtual upright reference vector 169 rather than that actual upright posture reference vector 167. Again, such a technique may be used in situations in which the lying reference vectors 159, 161, 163, 165 are not in a common plane, or the common plane of reference vector 159, 161, 163, 165 is not substantially orthogonal to upright reference vector 167. However, use of the example technique is not limited to such situations.
To define virtual upright reference vector 169, posture state module 86 may compute the cross-products of various combinations of lying reference vectors 159, 161, 163, 165 and average the cross product values. In the example of
Using virtual upright reference vector 169, posture state module 86 may define a lying posture donut or toroid in a manner similar to that described with respect to upright reference vector 167, but instead with respect to virtual upright reference vector 169. In particular, when posture state module 86 determines that the patient is not in the upright posture, the posture state module determines whether the patient is in a lying posture based on an angle or cosine value with respect to the virtual upright reference vector 169.
Posture state module 86 may still determine whether patient 12 is in an upright posture state using upright posture cone 157. If posture state module 86 determines that patient 12 is occupying a general lying posture state based on the analysis of the sensed coordinate vector with respect to virtual upright reference vector 169, posture state module 86 may then calculate the cosine value of the sensed coordinate vector (as hypotenuse) with respect to each lying reference coordinate vectors 159, 161, 163, 165 (as adjacent).
In such a case, posture state module 86 determines the particular lying posture state of patient 12, i.e., lying left, lying right, lying front, lying back, based on which cosine value is the greatest of the four cosine values. For example, if the cosine value calculated with the lying front reference vector 163 is the largest value of the four cosine values, the sensed vector may be considered closest in proximity to lying front reference vector out of the four total reference vectors 159, 161, 163, 165. Accordingly, posture state module 85 may determine that patient 12 is occupying a lying front posture state.
Additionally, posture state definitions are not limited to posture cones. For example, a definition of a posture state may involve a posture vector and a tolerance, such as a maximum distance from the posture vector. So long as a detected posture vector is within this maximum distance from the posture vector that is included in the definition of the posture state, patient 12 may be classified as being in that posture state. This alternative method may allow posture states to be detected without calculating angles, as is exemplified above in the discussion related to posture cones.
Further to the foregoing, posture states may be defined that are specific to a particular patient's activities and/or profession. For instance, a bank teller may spend a significant portion of his working day leaning forward at a particular angle. A patient-specific “Leaning Forward” posture state including this angle may be defined. The cone angle or other tolerance value selected for this posture state may be specific to the particular posture state definition for this patient. In this manner, the defined posture states may be tailored to a specific user, and need not be “hard-coded” in the IMD.
In some examples, individual posture states may be linked together, thereby tying posture states to a common set of posture reference data and a common set of therapy parameter values. This may, in effect, merge multiple posture cones for purposes of posture state-based selection of therapy parameter values. For example, all lying posture state cones (back, front, left, right) could be treated as one cone or a donut/toroid, e.g., using a technique the same as or similar to that described with respect to
Merging posture cones or otherwise linking a plurality of posture states together may be useful for examples in which a common set of therapy parameter values provides efficacious therapy to patient 12 for the plurality of posture states. In such an example, linking a plurality of posture states together may help decrease the power consumption required to provide posture-responsive therapy to patient 12 because the computation required to track patient posture states and provide responsive therapy adjustments may be minimized when a plurality of posture states are linked together.
Linking of posture states also may permit a therapy parameter value adjustment in one posture state to be associated with multiple posture states at the same time. For example, the same amplitude level for one or more programs may be applied to all of the posture states in a linked set of posture states. Alternatively, the lying down posture states may all reside within a “donut” or toroid that would be used instead of separate comes 156 and 158, for example. The toroid may be divided into sectional segments that each correspond to different posture states, such as lying (back), lying (front), lying (right), lying (left) instead of individual cones. In this case, different posture reference data and therapy parameter values may be assigned to the different sectional segments of the toroid.
As will be described further below, in response to the presentation of one or more posture state indicators presented on programmer 20 in or near real-time as described in some examples herein, the user may desire to adjust any of the cones of spaces 140, 150, and 155, or other posture zones used to define the posture state of patient 12 based on the output of one or more posture sensors. For example, if one or more of the posture state indicators presented does not match the actual posture state of patient 12, the user may desire to adjust the detection algorithms that identify patient posture state. The user may perform this re-calibration or adjustment of the posture state module at any time, and once performed, the avatar may reflect the changes. One or more example techniques for reorienting IMD 14 or other medical device may be described in U.S. patent application Ser. No. 12/433,623, titled “REORIENTATION OF PATIENT POSTURE STATES FOR POSTURE-RESPONSIVE THERAPY,” filed Apr. 30, 2009, the entire content of which is incorporated by reference herein.
As shown in
Before user interface 200 begins to present substantially real-time information to the user, screen 202 provides a pop-up window of connection prompt 216. Once the user has indicated that a real-time indicators of patient posture state are to be presented by programmer 20, user interface 200 displays connection prompt 216 to ensure that real-time streaming of posture state data (or other transfer of posture state data in accordance with examples of the disclosure) from IMD 14 or 26 should commence. If the user selects no button 220, user interface 200 returns to the previous menu or a main menu. If the user selects yes button 218, user interface 200 instructs processor 104 of programmer 20 to communicate with IMD 14 that real-time streaming of posture state data should commence. In other examples, connection prompt 216 may allow the user to specify details about the real-time streaming of posture state data (e.g., the particular rate at which postures state data is transferred from IMD 14 to programmer 20).
Avatar 214 may be displayed by user interface 200 in different anatomical configurations to graphically represent the posture state of patient 12 which is updated in or near real-time in relation to the actual posture state of patient 12. In the examples shown in
In some examples, the posture state indicated by avatar 214 and real-time text 208 displayed on user interface 200 may change substantially simultaneously with changes in the actual posture state of patient 12. In cases in which the real-time posture state data reflects the posture state of patient 12 computed according to the each sampled set of posture state sensor values (e.g., sampled values for x, y, and z signals), user interface 200 may update avatar 214 and real-time posture state indicator text 208 at a rate substantially the same as the signal sampling rate.
As shown in
Avatar 214 is a graphical representation of the posture state of the patient and is presented in an anatomical configuration based upon the posture state data transmitted, e.g., streamed, from IMD 14 in or near real-time. Here, avatar 214 is shown in the upright or standing posture state. Ground indicator 215 is shown as a shadow of avatar 14 to indicate to the user the direction of gravity. In other examples, ground indicator 215 may not be utilized.
Although avatar 214 is shown as a generic grey human model, avatar 214 may be any type of graphical representation of a human form. For example, avatar 214 may be generated from a picture or medical image of patient 12 so that the avatar looks very similar to patient 12. In other examples, avatar 214 may be a more simplistic human representation useful for visually indicating the posture state of patient to a user determined based on the received posture state data. Simplistic representations may include block segments of extremities, stick figures, or other generic shapes. User interface 200 may allow the user to change avatar 214 to a different form or use different patient information as desired. Additionally or alternatively, avatar 214 may be modified to indicate one or more other physiological parameters of patient 12. For example, avatar 214 may change color depending upon the heart rate or temperature of patient 12. Avatar 214 is one example of a visual representation of patient posture state that may be present to a user via user interface 200 of external programmer 20. Other visual representations of patient posture state are contemplated. In some examples, non-visual representations may be additionally or alternatively presented to a user via user interface 200 to indicate a detected patient posture state.
Avatar 214 may be shown in any anatomical configuration that represents the posture state of patient 12. Example anatomical configurations of avatar 214 include an upright configuration, a reclining configuration, a lying back configuration, a lying front configuration, a lying left configuration, a lying right configuration, a walking configuration, a running configuration, and a biking configuration. In some examples, avatar 214 may be capable representing any patient posture state detectable by IMD 14 via postures state module 86. Although changes in avatar 214 configurations may be between discrete posture states, alternative examples of user interface 200 may provide an animated avatar that moves with patient 12 in or near real-time. In some examples, avatar 214 may be oriented to reflect the particular sensed vector coordinates derived from sample sensor signals. For example, the sensed vector coordinate may be computed from a sampled set of x, y, and z signal values. In this manner, avatar 214 may provide a representation of patient 14 configuration that not only indicates the real-time patient posture state, but also a more precise position within the real-time patient posture state. An example of such a case is illustrated further in
Real-time posture state text 208, asserted posture state text 209, and stable posture state text 210 are visual posture state indicators that supplement the presentation of avatar 214. Real-time posture text 208 substantially mirrors the anatomical configuration represented by avatar 214 by providing a textual indication of the current real-time posture state of patient according to the posture state data received from IMD 14. Although indicators for each of real-time posture state, asserted posture state, and stable posture state are concurrently display on screen 222, other examples are contemplated with one, two, or more than two of real-time posture state, asserted posture state, stable posture state or the like are selectively indicated by screen 222.
Similar to real-time posture text 208, asserted posture state text 209 and/or stable posture text 210 may mirror the anatomical configuration represented by avatar 214 even though avatar 214 is indicative of the real-time posture state of patient 12. However, asserted posture state text 209 and stable posture text 210 may not always mirror avatar 214 and real-time posture state text 208.
As described above, stable posture text 210 may indicate the posture state currently used by IMD 14, for example, to deliver therapy to patient 12, based on the result of a detection algorithm, and is not necessarily the current or real-time posture state occupied by patient 12 based on recently sample sensor signal values. Since patient 12 may move between two or more posture states in a relatively short period of time, patient 12 may not benefit from the relatively fast changes in therapy parameters that could accompany such movement if the therapy was changed for every posture state occupied by patient 12. As such, in some examples, only when patient 12 is within a single posture state for a predetermined period of time does IMD 14 recognize the posture state as stable for changing therapy according to the detected patient posture state. In some cases, the predetermined amount of time may be referred to as a “dwell time.” Therefore, stable posture text 210 may be equal to real-time posture text 208 only after patient 12 occupies the real-time posture state for the dwell time. Similarly, in some examples, patient 12 may occupy the same asserted posture state for a dwell time for that posture state to also be considered the stable posture state of patient 12.
By displaying stable posture text 210 concurrently with avatar 214 and real-time posture text 208 on the same temporal basis, a user may be able to gauge the amount of time that patient 12 must occupy a posture state prior to IMD 14 adjusting the therapy delivered to patient. In some examples, a user may set and/or adjust one or more posture state dwell times for patient 12 based at least in part on the “real-time” display of the stable posture of patient 12 relative avatar 214, when avatar 214 is representative of real-time posture state.
In a similar fashion, by displaying asserted posture state text 209 concurrently with avatar 214 and real-time posture state text 208 on the same temporal basis, a user may be able to gauge the amount of time between a user occupying a real-time posture state prior to the posture state also being detected as an asserted posture state. Furthermore, a user may be able to gauge the number of occurrences that the real-time posture state of patient 12 is different from that of the asserted posture state of patient 12, e.g., while still maintaining the same asserted posture state. In this manner, a user may be able to evaluate the performance of one or more posture state detection algorithms for detecting a patient posture state. In particular, in the case when the asserted posture state of patient 12 lags behind the real-time posture state of patient 12 for an undesirable length of time, a user may adjust the sampling algorithm (e.g., M of N filter algorithm) used to detect the asserted posture state of patient 12.
Activity level 212 displays the activity of patient 12 as indicated by the activity count from posture state module 86. When activity level 212 is low, patient 12 is relatively stationary and not accelerating in any direction, as shown in screen 222. If activity level 212 is high, patient 12 is moving actively. In other examples, activity level 212 may provide the actual activity count data generated by posture state module 86 instead of, or in addition to, the graph of activity level 212.
In some examples of user interface 200, the user may be able to toggle between different posture state detection algorithms. For example, if a clinician determines that real-time avatar 214 or asserted posture state text 209 is not accurately representing the current posture state actually engaged by patient 12 and/or actual changes between patient posture state, the clinician may desire to change the manner in which IMD 14 identifies the posture state of patient 12 from the sampled signal values of the one or more accelerometers of posture state module 86. Once the clinician has toggled to a desired detection algorithm, IMD 14 may be commanded via programmer to set the new algorithm for use during therapy delivered by IMD 14. In some examples, a new posture state detection algorithm may be trialed on user interface 200 using avatar 214, for example, prior to or concurrently with the implementation of the posture state detection algorithm for user during therapy delivered to patient 12 via IMD 14.
As shown in
However, as the posture state data received by programmer 20 indicates that the stable posture state of patient 12 has not yet changed to the “recline” posture state but instead remains in the “upright” posture state. This may be the case, for example, if the real-time and/or asserted posture state of patient 12 has not been in the “recline” posture state for the dwell time associated with the posture state or posture state transition. Instead, patient 12 may have only recently transitioned to the “recline” posture state from the “upright” posture state and has not occupied the “recline” posture state for longer than the predefined dwell time.
As shown in
As shown in
As shown in
Other activities may be similarly identified with avatar 214. For example, avatar 214 or other posture state indicators may be shown to reflect a biking or a walking posture state based upon the activity level and orientation of patient 12. In such examples, the configuration of avatar 214 may represent the real-time posture state stable posture state, or asserted posture state of patient 12.
If the user desires to monitor the actual raw sensor data for each axis of posture state module 86, the user can select posture data button 240 to display this information. Screen 234 is presenting the raw posture state sensor data in raw data graph 242 as the parameter values for each x, y, and z axis in real-time. Raw sensor data graph 242 is a scrolling graph, but any other types of graphs may be used. In other examples, raw sensor data graph 242 may additionally or alternatively present numerical values for each axis. The user may monitor this raw sensor data to further review and adjust detection algorithm(s) used to generate the real-time posture state, asserted posture state, and/or stable posture state indicated by avatar 214 as well as text indicators 208, 209, and 210.
Screen 234 also presents information about the processing and streaming of posture state data. Refresh rate indicator 236 indicates the current rate at which the posture state of patient 12 is being determined and updated on screen 234. In the example of
As shown in
The user may also select play button 264 to progress sequentially through the posture state information as experienced by patient 12. Although the play mode may move in the real-time of prior events, this play may be too slow for effective review. Therefore, the play move may be an accelerated movement through time, either as a present pace or according to the total period of the previous real-time session. If the user wants to pause or stop at a certain time point, the user can select pause button 262.
As time position 258 moves through the time represented by time bar 256, the information displayed by any of avatar 214, real-time posture indicator 208, stable posture indicator 210, and activity level 212 changes according to those values of the specific time. Although avatar 214, real-time posture indicator 208, stable posture indicator 210, and activity level 212 represent posture state data from a previous time, the indicated information concurrently presented on screen 250 is presented on the same temporal basis with one another. In this manner, as user may be able to evaluate temporal relationships between different types of detected posture states (e.g., real-time posture state, asserted posture state, and/or stable posture state) even though the screen is presenting historical posture state data. In the example of
The movement of avatar 214 or other visual representation to represent the sensed posture state coordinates may allow a user to evaluate the position of a patient within a posture state rather than presenting all positions for a posture state using an avatar or other visual representation in substantially the same configuration on screen 250. In some examples, such a technique may be used to more precisely portray the position of patient within a more broadly defined posture space. Furthermore, such precision may provide for the movement of avatar or other representation to move fluidly when updated in a continuous manner on screen 250, e.g., compared to that of an avatar that periodically “jumps” between various patient posture states positions based on received posture state data.
Posture state cone 215 displayed on screen 250 provides a reference for position of a patient within the posture space generally and also within “upright” posture cone. In some examples, multiple posture state cones may be overlaid on avatar 214 or avatar may be presented without a graphical representation of one or more posture cones. In some examples, the representation of avatar 214 or other graphical indicator may be presented based on a sensed vector computed, for example, from sampled x, y, and z axis signals to assist a user in defining and/or adjusting posture cones or other regions for posture state detection. One or more examples of graphically manipulating posture zones/cones and parameters (e.g., posture transition times) using an external device may be described in co-pending United States Provisional patent application, to Davis, et al., filed Jan. 8, 2010, titled “GRAPHICAL MANIPULATION OF POSTURE ZONES FOR POSTURE-RESPONSIVE THERAPY,” and bearing attorney docket no. 1023-920USP1/P0037161.00.
As shown in
If programmer 20 receives posture state data from IMD 14 that indicates patient 12 has changed to a different posture state (278), processor 104 generates a new avatar in the appropriate anatomical configuration based upon the streamed posture state data (280). User interface 200 then displays the latest avatar configuration, posture text, and activity levels in real-time as indicated by the posture state data (282). If there is no change to the posture state data (278), user interface 200 continues to present the latest avatar (or other graphical indicator) and posture information to the user (282).
If there is no request by the user to stop streaming (284), programmer 20 continues to check for changes in patient posture state based on the received posture state data (278) and presents the latest appropriate avatar and other posture information (282). If user interface 200 receives an input to stop streaming posture state data and presenting the avatar in real-time (284), then programmer 20 stops updating the avatar and requests that IMD 14 cancels posture state streaming (286). Programmer 20 continues to allow the user to navigate user interface 200 (270).
In addition to this technique for presenting an avatar in real-time according to real-time streamed posture state data, the technique may include any other concepts described herein. For example, user interface 232 may similarly update raw data graph 242 as new posture state data is received from IMD 14 in real-time. Further, the technique may support real-time changes to detection algorithms, re-calibration of posture state module 86, or any other programming functions associated with therapy to patient 12.
As shown in
If user interface 250 receives a playback command (292), user interface 250 displays the new avatar and other posture information of the new specified time according to the playback command (294). If the playback command was to present a sequence or continual change, user interface 250 continues to change the avatar and posture information presented according to the new specified time. If user interface 250 receives a selection of pause button 262 (296), then user interface 250 freezes the currently displayed avatar and posture information on the display (298). If there is no command received to exit the screen of user interface 250 (300), user interface 250 does not change the displayed avatar and posture information until another playback command is received (292). If user interface 250 receives an exit command from the user (300), user interface 250 exits the screen of user interface 250 and external programmer 20 leaves the playback screen for a different menu (302).
The disclosure describes a system that may be capable of providing many features to a user. For example, presenting a real-time avatar or other posture state indicator may allow a clinician to quickly identify how the medical device is detecting one or more posture states of a patient. If the detected posture state is not accurate, the clinician may re-calibrate or adjust the posture detection algorithm. Further, the real-time avatar or other posture state indicator may aid the clinician in programming therapy that is responsive to various posture states of the patient. The clinician may also be able to review a previous real-time session to determine any problems with therapy after the patient has left the clinic.
The techniques described in this disclosure may be implemented, at least in part, in hardware, software, firmware or any combination thereof. For example, various aspects of the techniques may be implemented within one or more microprocessors, DSPs, ASICs, FPGAs, or any other equivalent integrated or discrete logic circuitry, as well as any combinations of such components, embodied in programmers, such as physician or patient programmers, stimulators, or other devices. The term “processor” or “processing circuitry” may generally refer to any of the foregoing logic circuitry, alone or in combination with other logic circuitry, or any other equivalent circuitry.
Such hardware, software, and firmware may be implemented within the same device or within separate devices to support the various operations and functions described in this disclosure. In addition, any of the described units, modules or components may be implemented together or separately as discrete but interoperable logic devices. Depiction of different features as modules or units is intended to highlight different functional aspects and does not necessarily imply that such modules or units must be realized by separate hardware or software components. Rather, functionality associated with one or more modules or units may be performed by separate hardware or software components, or integrated within common or separate hardware or software components.
When implemented in software, the functionality ascribed to the systems and devices described in this disclosure may be embodied as instructions on a computer-readable medium such as RAM, ROM, NVRAM, EEPROM, FLASH memory, magnetic media, optical media, or the like. The instructions may be executed to support one or more aspects of the functionality described in this disclosure.
If implemented in software, the techniques described in this disclosure may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media may include non-transitory computer storage media or communication media including any medium that facilitates transfer of a computer program from one place to another. Data storage media may be any available media that can be accessed by one or more computers or one or more processors to retrieve instructions, code and/or data structures for implementation of the techniques described in this disclosure. By way of example, and not limitation, such data storage media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage, or other magnetic storage devices, flash memory, or any other medium that can be used to store desired program code in the form of instructions or data structures and that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
The code may be executed by one or more processors, such as one or more digital signal processors (DSPs), general purpose microprocessors, application specific integrated circuits (ASICs), field programmable logic arrays (FPGAs), or other equivalent integrated or discrete logic circuitry. Accordingly, the term “processor,” as used herein may refer to any of the foregoing structure or any other structure suitable for implementation of the techniques described herein. Also, the techniques could be fully implemented in one or more circuits or logic elements.
In addition, it should be noted that the systems described herein may not be limited to treatment of a human patient. In alternative embodiments, these systems may be implemented in non-human patients, e.g., primates, canines, equines, pigs, and felines. These animals may undergo clinical or research therapies that may benefit from the subject matter of this disclosure.
Many embodiments of the disclosure have been described. Various modifications may be made without departing from the scope of the claims. These and other embodiments are within the scope of the following claims.
This application is a continuation application of U.S. patent application Ser. No. 12/985,965, filed Jan. 6, 2011, which claims the benefit of U.S. Provisional Application No. 61/293,538, filed on Jan. 8, 2010, the entire content of each of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4297685 | Brainard, II | Oct 1981 | A |
4365633 | Loughman | Dec 1982 | A |
4543955 | Schroeppel | Oct 1985 | A |
4550736 | Broughton et al. | Nov 1985 | A |
4566456 | Koning et al. | Jan 1986 | A |
4771780 | Sholder | Sep 1988 | A |
4776345 | Cohen et al. | Oct 1988 | A |
4846180 | Buffet | Jul 1989 | A |
4846195 | Alt | Jul 1989 | A |
5031618 | Mullett | Jul 1991 | A |
5040534 | Mann et al. | Aug 1991 | A |
5040536 | Riff | Aug 1991 | A |
5058584 | Bourgeois | Oct 1991 | A |
5125412 | Thornton | Jun 1992 | A |
5154180 | Blanchet et al. | Oct 1992 | A |
5158078 | Bennett et al. | Oct 1992 | A |
5167229 | Peckham et al. | Dec 1992 | A |
5233984 | Thompson | Aug 1993 | A |
5275159 | Griebel | Jan 1994 | A |
5312446 | Holschbach et al. | May 1994 | A |
5335657 | Terry, Jr. et al. | Aug 1994 | A |
5337758 | Moore et al. | Aug 1994 | A |
5342409 | Mullett | Aug 1994 | A |
5354317 | Alt | Oct 1994 | A |
5425750 | Moberg | Jun 1995 | A |
5469861 | Piscopo et al. | Nov 1995 | A |
5476483 | Bornzin et al. | Dec 1995 | A |
5487755 | Snell et al. | Jan 1996 | A |
5513645 | Jacobson et al. | May 1996 | A |
5514162 | Bornzin et al. | May 1996 | A |
5558640 | Pfeiler et al. | Sep 1996 | A |
5562707 | Prochazka et al. | Oct 1996 | A |
5593431 | Sheldon | Jan 1997 | A |
5622428 | Bonnet | Apr 1997 | A |
5628317 | Starkebaum et al. | May 1997 | A |
5643332 | Stein | Jul 1997 | A |
5645053 | Remmers et al. | Jul 1997 | A |
5674258 | Henschel et al. | Oct 1997 | A |
5711316 | Elsberry et al. | Jan 1998 | A |
5720770 | Nappholz et al. | Feb 1998 | A |
5732696 | Rapoport et al. | Mar 1998 | A |
5741310 | Wittkampf | Apr 1998 | A |
5782884 | Stotts et al. | Jul 1998 | A |
5814093 | Stein | Sep 1998 | A |
5832932 | Elsberry et al. | Nov 1998 | A |
5833709 | Rise et al. | Nov 1998 | A |
5836989 | Shelton | Nov 1998 | A |
5851193 | Arikka et al. | Dec 1998 | A |
5865760 | Lidman et al. | Feb 1999 | A |
5885471 | Ruben et al. | Mar 1999 | A |
5893883 | Torgerson et al. | Apr 1999 | A |
5895371 | Levitas et al. | Apr 1999 | A |
5904708 | Goedeke | May 1999 | A |
5911738 | Sikorski et al. | Jun 1999 | A |
5913727 | Ahdoot | Jun 1999 | A |
5919149 | Allum | Jul 1999 | A |
5938690 | Law et al. | Aug 1999 | A |
5941906 | Barreras, Sr. et al. | Aug 1999 | A |
5944680 | Christopherson et al. | Aug 1999 | A |
5957957 | Sheldon | Sep 1999 | A |
5984368 | Cain | Nov 1999 | A |
6027456 | Feler et al. | Feb 2000 | A |
6038475 | Sikorski et al. | Mar 2000 | A |
6044297 | Sheldon et al. | Mar 2000 | A |
6045513 | Stone et al. | Apr 2000 | A |
6059576 | Brann | May 2000 | A |
6095991 | Krausman et al. | Aug 2000 | A |
6099479 | Christopherson et al. | Aug 2000 | A |
6102874 | Stone et al. | Aug 2000 | A |
6120467 | Schallhorn | Sep 2000 | A |
6128534 | Park et al. | Oct 2000 | A |
6134459 | Roberts et al. | Oct 2000 | A |
6152890 | Kupfer et al. | Nov 2000 | A |
6157857 | Dimpfel | Dec 2000 | A |
6165143 | Van Lummel | Dec 2000 | A |
6216537 | Henschel et al. | Apr 2001 | B1 |
6259948 | Florio et al. | Jul 2001 | B1 |
6280409 | Stone et al. | Aug 2001 | B1 |
6296606 | Goldberg et al. | Oct 2001 | B1 |
6308098 | Meyer | Oct 2001 | B1 |
6308099 | Fox et al. | Oct 2001 | B1 |
6315740 | Singh | Nov 2001 | B1 |
6327501 | Levine et al. | Dec 2001 | B1 |
6341236 | Osorio et al. | Jan 2002 | B1 |
6351672 | Park et al. | Feb 2002 | B1 |
6368284 | Bardy | Apr 2002 | B1 |
6381496 | Meadows et al. | Apr 2002 | B1 |
6393325 | Mann et al. | May 2002 | B1 |
6438408 | Mulligan et al. | Aug 2002 | B1 |
6440090 | Schallhorn | Aug 2002 | B1 |
6449508 | Sheldon et al. | Sep 2002 | B1 |
6459934 | Kadhiresan | Oct 2002 | B1 |
6466821 | Pianca et al. | Oct 2002 | B1 |
6468234 | Van der Loos et al. | Oct 2002 | B1 |
6507757 | Swain et al. | Jan 2003 | B1 |
6514218 | Yamamoto | Feb 2003 | B2 |
6516749 | Salasidis | Feb 2003 | B1 |
6539249 | Kadhiresan et al. | Mar 2003 | B1 |
6547755 | Lippe et al. | Apr 2003 | B1 |
6572557 | Tchou et al. | Jun 2003 | B2 |
6574507 | Bonnet | Jun 2003 | B1 |
6605038 | Teller et al. | Aug 2003 | B1 |
6609031 | Law et al. | Aug 2003 | B1 |
6611783 | Kelly, Jr. et al. | Aug 2003 | B2 |
6620151 | Blischak et al. | Sep 2003 | B2 |
6625493 | Kroll et al. | Sep 2003 | B2 |
6635048 | Ullestad et al. | Oct 2003 | B1 |
6641542 | Cho et al. | Nov 2003 | B2 |
6658292 | Kroll et al. | Dec 2003 | B2 |
6659968 | McClure | Dec 2003 | B1 |
6662047 | Sorensen et al. | Dec 2003 | B2 |
6665558 | Kalgren et al. | Dec 2003 | B2 |
6668188 | Sun et al. | Dec 2003 | B2 |
6687538 | Hrdlicka et al. | Feb 2004 | B1 |
6731984 | Cho et al. | May 2004 | B2 |
6740075 | Lebel et al. | May 2004 | B2 |
6748276 | Daignault, Jr. et al. | Jun 2004 | B1 |
6752766 | Kowallik et al. | Jun 2004 | B2 |
6773404 | Poezevera et al. | Aug 2004 | B2 |
6782315 | Lu et al. | Aug 2004 | B2 |
6817979 | Nihtilä | Nov 2004 | B2 |
6820025 | Bachmann et al. | Nov 2004 | B2 |
6829507 | Lidman et al. | Dec 2004 | B1 |
6832113 | Belalcazar | Dec 2004 | B2 |
6834436 | Townsend | Dec 2004 | B2 |
6853863 | Carter et al. | Feb 2005 | B2 |
6878121 | Krausman et al. | Apr 2005 | B2 |
6884596 | Civelli et al. | Apr 2005 | B2 |
6890306 | Poezevera | May 2005 | B2 |
6895341 | Barrey et al. | May 2005 | B2 |
6922587 | Weinberg | Jul 2005 | B2 |
6923784 | Stein | Aug 2005 | B2 |
6928324 | Park et al. | Aug 2005 | B2 |
6937899 | Sheldon et al. | Aug 2005 | B2 |
6937900 | Pianca et al. | Aug 2005 | B1 |
6945934 | Bardy | Sep 2005 | B2 |
6964641 | Cho et al. | Nov 2005 | B2 |
6975904 | Sloman | Dec 2005 | B1 |
6997882 | Parker et al. | Feb 2006 | B1 |
6999817 | Park et al. | Feb 2006 | B2 |
7016730 | Ternes | Mar 2006 | B2 |
7031772 | Condie | Apr 2006 | B2 |
7043305 | KenKnight et al. | May 2006 | B2 |
7054687 | Andersen | May 2006 | B1 |
7066910 | Bauhahn et al. | Jun 2006 | B2 |
7082333 | Bauhahn | Jul 2006 | B1 |
7092759 | Nehls et al. | Aug 2006 | B2 |
7095424 | Satoh et al. | Aug 2006 | B2 |
7110820 | Tcheng et al. | Sep 2006 | B2 |
7117036 | Florio | Oct 2006 | B2 |
7123967 | Weinberg | Oct 2006 | B2 |
7130681 | Gebhardt et al. | Oct 2006 | B2 |
7130689 | Turcott | Oct 2006 | B1 |
7141026 | Aminian et al. | Nov 2006 | B2 |
7142921 | Mattes et al. | Nov 2006 | B2 |
7149579 | Koh et al. | Dec 2006 | B1 |
7149584 | Koh et al. | Dec 2006 | B1 |
7151961 | Whitehurst et al. | Dec 2006 | B1 |
7155279 | Whitehurst et al. | Dec 2006 | B2 |
7160252 | Cho et al. | Jan 2007 | B2 |
7162304 | Bradley | Jan 2007 | B1 |
7167743 | Heruth et al. | Jan 2007 | B2 |
7167751 | Whitehurst et al. | Jan 2007 | B1 |
7181281 | Kroll | Feb 2007 | B1 |
7189204 | Ni et al. | Mar 2007 | B2 |
7207947 | Koh et al. | Apr 2007 | B2 |
7210240 | Townsend et al. | May 2007 | B2 |
7212862 | Park et al | May 2007 | B2 |
7214197 | Prass | May 2007 | B2 |
7218964 | Hill et al. | May 2007 | B2 |
7218968 | Condie et al. | May 2007 | B2 |
7221979 | Zhou et al. | May 2007 | B2 |
7231254 | DiLorenzo | Jun 2007 | B2 |
7242983 | Frei et al. | Jul 2007 | B2 |
7252640 | Ni et al. | Aug 2007 | B2 |
7266412 | Stypulkowski | Sep 2007 | B2 |
7308311 | Sorensen et al. | Dec 2007 | B2 |
7313440 | Miesel | Dec 2007 | B2 |
7317948 | King et al. | Jan 2008 | B1 |
7330760 | Heruth et al. | Feb 2008 | B2 |
7366569 | Belalcazar | Apr 2008 | B2 |
7366572 | Heruth et al. | Apr 2008 | B2 |
7387610 | Stahmann | Jun 2008 | B2 |
7389147 | Wahlstrand et al. | Jun 2008 | B2 |
7395113 | Heruth | Jul 2008 | B2 |
7403820 | DiLorenzo | Jul 2008 | B2 |
7406351 | Wesselink | Jul 2008 | B2 |
7415308 | Gerber et al. | Aug 2008 | B2 |
7447545 | Heruth et al. | Nov 2008 | B2 |
7471290 | Wang et al. | Dec 2008 | B2 |
7471980 | Koshiol | Dec 2008 | B2 |
7489970 | Lee et al. | Feb 2009 | B2 |
7491181 | Heruth et al. | Feb 2009 | B2 |
7505815 | Lee et al. | Mar 2009 | B2 |
7519431 | Goetz et al. | Apr 2009 | B2 |
7542803 | Heruth et al. | Jun 2009 | B2 |
7548786 | Lee et al. | Jun 2009 | B2 |
7559901 | Maile | Jul 2009 | B2 |
7572225 | Stahmann | Aug 2009 | B2 |
7577479 | Hartley et al. | Aug 2009 | B2 |
7580752 | Gerber et al. | Aug 2009 | B2 |
7584808 | Dolgin et al. | Sep 2009 | B2 |
7590453 | Heruth | Sep 2009 | B2 |
7590455 | Heruth et al. | Sep 2009 | B2 |
7590481 | Lu et al. | Sep 2009 | B2 |
7591265 | Lee et al. | Sep 2009 | B2 |
7603170 | Hatlestad et al. | Oct 2009 | B2 |
7623919 | Goetz et al. | Nov 2009 | B2 |
7634379 | Noble | Dec 2009 | B2 |
7664546 | Hartley et al. | Feb 2010 | B2 |
7672806 | Tronconi | Mar 2010 | B2 |
7717848 | Heruth et al. | May 2010 | B2 |
7769464 | Gerber et al. | Aug 2010 | B2 |
7792583 | Heruth et al. | Sep 2010 | B2 |
8032229 | Gerber et al. | Oct 2011 | B2 |
8150531 | Skelton et al. | Apr 2012 | B2 |
8175720 | Skelton et al. | May 2012 | B2 |
8200340 | Skelton et al. | Jun 2012 | B2 |
8209028 | Skelton et al. | Jun 2012 | B2 |
8219206 | Skelton et al. | Jul 2012 | B2 |
8231555 | Skelton et al. | Jul 2012 | B2 |
8231556 | Skelton et al. | Jul 2012 | B2 |
8249718 | Skelton et al. | Aug 2012 | B2 |
8282580 | Skelton et al. | Oct 2012 | B2 |
8290726 | Schmidt et al. | Oct 2012 | B2 |
8315710 | Skelton et al. | Nov 2012 | B2 |
8323218 | Davis et al. | Dec 2012 | B2 |
8326420 | Skelton et al. | Dec 2012 | B2 |
8332041 | Skelton et al. | Dec 2012 | B2 |
8352039 | Davis et al. | Jan 2013 | B2 |
8388555 | Panken et al. | Mar 2013 | B2 |
8401666 | Skelton et al. | Mar 2013 | B2 |
8437861 | Skelton et al. | May 2013 | B2 |
8447411 | Skelton et al. | May 2013 | B2 |
8515549 | Panken et al. | Aug 2013 | B2 |
8515550 | Skelton et al. | Aug 2013 | B2 |
8579834 | Davis et al. | Nov 2013 | B2 |
8583252 | Skelton et al. | Nov 2013 | B2 |
8631008 | G. et al. | Jan 2014 | B1 |
20020038137 | Stein | Mar 2002 | A1 |
20020091308 | Kipshidze et al. | Jul 2002 | A1 |
20020107553 | Hill et al. | Aug 2002 | A1 |
20020115939 | Mulligan et al. | Aug 2002 | A1 |
20020151824 | Fischer | Oct 2002 | A1 |
20020165586 | Hill et al. | Nov 2002 | A1 |
20020169485 | Pless et al. | Nov 2002 | A1 |
20020170193 | Townsend et al. | Nov 2002 | A1 |
20030004423 | Lavie et al. | Jan 2003 | A1 |
20030036783 | Bauhahn et al. | Feb 2003 | A1 |
20030045910 | Sorensen et al. | Mar 2003 | A1 |
20030065370 | Lebel et al. | Apr 2003 | A1 |
20030088185 | Prass | May 2003 | A1 |
20030149457 | Tcheng et al. | Aug 2003 | A1 |
20030171791 | KenKnight et al. | Sep 2003 | A1 |
20030181960 | Carter et al. | Sep 2003 | A1 |
20030204211 | Condie et al. | Oct 2003 | A1 |
20040015103 | Aminian et al. | Jan 2004 | A1 |
20040049132 | Barron et al. | Mar 2004 | A1 |
20040088020 | Condie et al. | May 2004 | A1 |
20040102814 | Sorensen et al. | May 2004 | A1 |
20040133248 | Frei et al. | Jul 2004 | A1 |
20040138716 | Kon et al. | Jul 2004 | A1 |
20040147975 | Popovic et al. | Jul 2004 | A1 |
20040199215 | Lee et al. | Oct 2004 | A1 |
20040199216 | Lee et al. | Oct 2004 | A1 |
20040199217 | Lee et al. | Oct 2004 | A1 |
20040199218 | Lee et al. | Oct 2004 | A1 |
20040215286 | Stypulkowski | Oct 2004 | A1 |
20040220621 | Zhou et al. | Nov 2004 | A1 |
20040225332 | Gebhardt et al. | Nov 2004 | A1 |
20040257693 | Ehrlich | Dec 2004 | A1 |
20050042589 | Hatlestad et al. | Feb 2005 | A1 |
20050043767 | Belalcazar | Feb 2005 | A1 |
20050060001 | Singhal et al. | Mar 2005 | A1 |
20050061320 | Lee et al. | Mar 2005 | A1 |
20050085738 | Stahmann et al. | Apr 2005 | A1 |
20050113710 | Stahmann et al. | May 2005 | A1 |
20050113887 | Bauhahn | May 2005 | A1 |
20050126026 | Townsend et al. | Jun 2005 | A1 |
20050137627 | Koshiol et al. | Jun 2005 | A1 |
20050145246 | Hartley et al. | Jul 2005 | A1 |
20050172311 | Hjelt et al. | Aug 2005 | A1 |
20050177192 | Rezai et al. | Aug 2005 | A1 |
20050209511 | Heruth et al. | Sep 2005 | A1 |
20050209512 | Heruth et al. | Sep 2005 | A1 |
20050209513 | Heruth et al. | Sep 2005 | A1 |
20050209643 | Heruth et al. | Sep 2005 | A1 |
20050209644 | Heruth et al. | Sep 2005 | A1 |
20050209645 | Heruth et al. | Sep 2005 | A1 |
20050215847 | Heruth et al. | Sep 2005 | A1 |
20050215947 | Heruth et al. | Sep 2005 | A1 |
20050216064 | Heruth et al. | Sep 2005 | A1 |
20050222522 | Heruth et al. | Oct 2005 | A1 |
20050222638 | Foley et al. | Oct 2005 | A1 |
20050228455 | Kramer et al. | Oct 2005 | A1 |
20050234514 | Heruth et al. | Oct 2005 | A1 |
20050234518 | Heruth et al. | Oct 2005 | A1 |
20050240242 | DiLorenzo | Oct 2005 | A1 |
20050245988 | Miesel | Nov 2005 | A1 |
20050270163 | Littell | Dec 2005 | A1 |
20050283210 | Blischak et al. | Dec 2005 | A1 |
20060190049 | Gerber et al. | Aug 2006 | A1 |
20060190050 | Gerber et al. | Aug 2006 | A1 |
20060190051 | Gerber et al. | Aug 2006 | A1 |
20060195051 | Schnapp et al. | Aug 2006 | A1 |
20060206167 | Flaherty et al. | Sep 2006 | A1 |
20060212080 | Hartley et al. | Sep 2006 | A1 |
20060213267 | Tronconi et al. | Sep 2006 | A1 |
20060235289 | Wesselink et al. | Oct 2006 | A1 |
20060235472 | Goetz et al. | Oct 2006 | A1 |
20060241513 | Hatlestad et al. | Oct 2006 | A1 |
20060247732 | Wesselink | Nov 2006 | A1 |
20060247739 | Wahlstrand et al. | Nov 2006 | A1 |
20060259099 | Goetz et al. | Nov 2006 | A1 |
20060262120 | Rosenberg | Nov 2006 | A1 |
20060265025 | Goetz et al. | Nov 2006 | A1 |
20060287686 | Cullen et al. | Dec 2006 | A1 |
20070015976 | Miesel et al. | Jan 2007 | A1 |
20070038265 | Tcheng et al. | Feb 2007 | A1 |
20070050715 | Behar | Mar 2007 | A1 |
20070073355 | DiLorenzo | Mar 2007 | A1 |
20070115277 | Wang et al. | May 2007 | A1 |
20070118056 | Wang et al. | May 2007 | A1 |
20070123758 | Miesel et al. | May 2007 | A1 |
20070129622 | Bourget et al. | Jun 2007 | A1 |
20070129641 | Sweeney | Jun 2007 | A1 |
20070129769 | Bourget et al. | Jun 2007 | A1 |
20070129774 | Bourget et al. | Jun 2007 | A1 |
20070150026 | Bourget et al. | Jun 2007 | A1 |
20070150029 | Bourget et al. | Jun 2007 | A1 |
20071050026 | Bourget | Jun 2007 | |
20070213789 | Nolan et al. | Sep 2007 | A1 |
20070249968 | Miesel et al. | Oct 2007 | A1 |
20070250121 | Miesel et al. | Oct 2007 | A1 |
20070250134 | Miesel et al. | Oct 2007 | A1 |
20070255118 | Miesel et al. | Nov 2007 | A1 |
20070255154 | Lu et al. | Nov 2007 | A1 |
20070265664 | Gerber et al. | Nov 2007 | A1 |
20070265681 | Gerber et al. | Nov 2007 | A1 |
20070276439 | Miesel et al. | Nov 2007 | A1 |
20070293737 | Heruth et al. | Dec 2007 | A1 |
20070293917 | Thompson | Dec 2007 | A1 |
20080071150 | Miesel et al. | Mar 2008 | A1 |
20080071324 | Miesel et al. | Mar 2008 | A1 |
20080071326 | Heruth et al. | Mar 2008 | A1 |
20080071327 | Miesel et al. | Mar 2008 | A1 |
20080079444 | Denison | Apr 2008 | A1 |
20080081958 | Denison et al. | Apr 2008 | A1 |
20080114219 | Zhang et al. | May 2008 | A1 |
20080164979 | Otto | Jul 2008 | A1 |
20080177355 | Miesel et al. | Jul 2008 | A1 |
20080188901 | Sanghera et al. | Aug 2008 | A1 |
20080188909 | Bradley | Aug 2008 | A1 |
20080194998 | Holmstrom et al. | Aug 2008 | A1 |
20080204255 | Flexer et al. | Aug 2008 | A1 |
20080269812 | Gerber et al. | Oct 2008 | A1 |
20080269843 | Gerber | Oct 2008 | A1 |
20080281376 | Gerber et al. | Nov 2008 | A1 |
20080281379 | Wesselink | Nov 2008 | A1 |
20080281381 | Gerber et al. | Nov 2008 | A1 |
20080288200 | Noble | Nov 2008 | A1 |
20080300449 | Gerber et al. | Dec 2008 | A1 |
20080300470 | Gerber et al. | Dec 2008 | A1 |
20090030263 | Heruth et al. | Jan 2009 | A1 |
20090036951 | Heruth et al. | Feb 2009 | A1 |
20090046056 | Rosenberg et al. | Feb 2009 | A1 |
20090076343 | James et al. | Mar 2009 | A1 |
20090082829 | Panken et al. | Mar 2009 | A1 |
20090099627 | Molnar et al. | Apr 2009 | A1 |
20090105785 | Wei et al. | Apr 2009 | A1 |
20090118599 | Heruth et al. | May 2009 | A1 |
20090137933 | Lieberman et al. | May 2009 | A1 |
20090228841 | Hildreth | Sep 2009 | A1 |
20090233770 | Vincent et al. | Sep 2009 | A1 |
20090259216 | Drew et al. | Oct 2009 | A1 |
20090264789 | Molnar et al. | Oct 2009 | A1 |
20090270747 | van Dam et al. | Oct 2009 | A1 |
20090306740 | Heruth et al. | Dec 2009 | A1 |
20100010380 | Panken et al. | Jan 2010 | A1 |
20100010381 | Skelton et al. | Jan 2010 | A1 |
20100010382 | Panken | Jan 2010 | A1 |
20100010383 | Skelton et al. | Jan 2010 | A1 |
20100010384 | Panken et al. | Jan 2010 | A1 |
20100010385 | Skelton et al. | Jan 2010 | A1 |
20100010386 | Skelton et al. | Jan 2010 | A1 |
20100010388 | Panken et al. | Jan 2010 | A1 |
20100010389 | Davis et al. | Jan 2010 | A1 |
20100010390 | Skelton et al. | Jan 2010 | A1 |
20100010391 | Skelton et al. | Jan 2010 | A1 |
20100010392 | Skelton et al. | Jan 2010 | A1 |
20100010571 | Skelton et al. | Jan 2010 | A1 |
20100010572 | Skelton et al. | Jan 2010 | A1 |
20100010573 | Skelton et al. | Jan 2010 | A1 |
20100010574 | Skelton et al. | Jan 2010 | A1 |
20100010575 | Skelton et al. | Jan 2010 | A1 |
20100010576 | Skelton et al. | Jan 2010 | A1 |
20100010577 | Skelton et al. | Jan 2010 | A1 |
20100010578 | Skelton et al. | Jan 2010 | A1 |
20100010579 | Skelton et al. | Jan 2010 | A1 |
20100010580 | Skelton et al. | Jan 2010 | A1 |
20100010583 | Panken et al. | Jan 2010 | A1 |
20100010584 | Skelton et al. | Jan 2010 | A1 |
20100010585 | Davis et al. | Jan 2010 | A1 |
20100010586 | Skelton et al. | Jan 2010 | A1 |
20100010587 | Skelton et al. | Jan 2010 | A1 |
20100010588 | Skelton et al. | Jan 2010 | A1 |
20100010589 | Skelton et al. | Jan 2010 | A1 |
20100010590 | Skelton et al. | Jan 2010 | A1 |
20100030286 | Goetz et al. | Feb 2010 | A1 |
20100076525 | Skelton et al. | Mar 2010 | A1 |
20100174155 | Heruth et al. | Jul 2010 | A1 |
20100280500 | Skelton et al. | Nov 2010 | A1 |
20100280578 | Skelton et al. | Nov 2010 | A1 |
20110172562 | Sahasrabudhe et al. | Jul 2011 | A1 |
20110172738 | Davis et al. | Jul 2011 | A1 |
Number | Date | Country |
---|---|---|
19831109 | Jan 2000 | DE |
10024103 | Nov 2001 | DE |
0564803 | Oct 1993 | EP |
0845240 | Jun 1998 | EP |
0849715 | Jun 1998 | EP |
1195139 | Apr 2002 | EP |
1291036 | Mar 2003 | EP |
1308182 | May 2003 | EP |
1331022 | Jul 2003 | EP |
1391846 | Feb 2004 | EP |
1437159 | Jul 2004 | EP |
1731088 | Dec 2006 | EP |
1870128 | Dec 2007 | EP |
1938862 | Jul 2008 | EP |
2110067 | Oct 2009 | EP |
2330912 | May 1999 | GB |
2408342 | May 2005 | GB |
2447647 | Sep 2008 | GB |
9405371 | Mar 1994 | WO |
9629007 | Sep 1996 | WO |
9704705 | Feb 1997 | WO |
9749455 | Dec 1997 | WO |
9800197 | Jan 1998 | WO |
9956820 | Nov 1999 | WO |
0137930 | May 2001 | WO |
0228282 | Apr 2002 | WO |
0241771 | May 2002 | WO |
02087433 | Nov 2002 | WO |
02096512 | Dec 2002 | WO |
02100267 | Dec 2002 | WO |
03051356 | Jun 2003 | WO |
03065891 | Aug 2003 | WO |
2005028029 | Mar 2005 | WO |
2005035050 | Apr 2005 | WO |
2005079487 | Sep 2005 | WO |
2005089646 | Sep 2005 | WO |
2005089647 | Sep 2005 | WO |
2005089860 | Sep 2005 | WO |
2005102499 | Nov 2005 | WO |
2005120348 | Dec 2005 | WO |
2007009088 | Jan 2007 | WO |
2007051196 | May 2007 | WO |
2007064682 | Jun 2007 | WO |
2007064936 | Jun 2007 | WO |
2007127445 | Nov 2007 | WO |
2008026970 | Mar 2008 | WO |
Entry |
---|
“Design Competition: Runners-Up for the Best Three Designs,” EPN, vol. 26 No. 1, Jan. 2002, 1 pp. |
“IBM and Citizen Watch develop Linux-Based WatchPad,” http:/wwwlinuxdevices.com/news/NS6580187845.html, Oct. 11, 2001, 5 pp. |
“MiniMitter® Physiological and Behavioral Monitoring for Humans and Animals,” retrieved on Feb. 20, 2006, 3 pp. |
“Watch,” Wikipedia, http://en.wikipedia.org/wiki/Watch, retrieved on Feb. 20, 2006, 6 pp. |
Aminian et al., “Physical Activity Monitoring Based on Accelerometry: Validation and Comparison with Video Observation,” Medical & Biological Engineering & Computing, vol. 37, May 1, 1999, pp. 304-308, 5 pp. |
Amzica, “Physiology of Sleep and Wakefulness as it Relates to the Physiology of Epilepsy,” Journal of Clinical Neurophysiology, American Clinical Neurophysiology Society, vol. 19 No. 6, Dec. 2002, pp. 488-503, pp. 16. |
Ang et al., “Physical model of a MEMS accelerometer for low-g motion tracking applications,” 2004 IEEE International Conference on Robotics and Automation, vol. 2?, Apr. 2004, pp. 1345-1351, 7 pp. |
Buchser et al., “Improved Physical Activity in Patients Treated for Chronic Pain by Spinal Cord Stimulation,” Neuromodulation, vol. 8 Issue 1, Mar. 30, 2005, pp. 40-48, 8 pp. |
Crago et al., “An Elbow Extension Neuroprosthesis for Individuals with Tetraplegia,” IEEE Transactions on Rehabilitation Engineering, vol. 6 No. 1, Mar. 1998, pp. 1-6, 6 pp. |
Dejnabadi et al., “Estimation and Visualization of Sagittal Kinematics of Lower Limbs Orientation Using Body-Fixed Sensors,” IEEE Transactions on Biomedical Engineering, vol. 53 No. 7, Jul. 2006, pp. 1385-1393, 9 pp. |
Dinner, “Effect of Sleep on Epilepsy,” Journal of Clinical Neurophysiology, American Clinical Neurophysiology Society, vol. 19 No. 6, Dec. 2002, pp. 504-513, 10 pp. |
Foerster et al., “Motion Pattern and Posture: Correctly Assessed by Calibrated Accelerometers,” Forschungsgrupe Psychophysiologie, Universität Freiburg, Germany, Mar. 2000, 28 pp. |
Foldvary-Schaefer, “Sleep Complaints and Epilepsy: The Role of Seizures, Antiepileptic Drugs and Sleep Disorders,” Journal of Clinical Neurophysiology, American Clinical Neurophysiology Society, vol. 19 No. 6, Dec. 2002, pp. 514-521, 8 pp. |
Fourcade et al., “Modeling Phase Transitions in Human Posture,” Studies in Perception and Action VII, Sheena Rogers & Judith Effken (eds), Lawrence Erlbaum Associated, Inc., Jul. 13-18, 2003, pp. 99-103, 13 pp. |
Giansanti et al., “The development and test of a device for the reconstruction of 3-D position and orientation by means of a kinematic sensor assembly with rate gyroscopes and accelerometers,” IEEE Transactions on Biomedical Engineering, vol. 52 No. 7, Jun. 13, 2005, pp. 1271-1277, 7 pp. |
Goodrich et al., “The Prediction of Pain Using Measures of Sleep Quality,” Pain Digest, 1998, pp. 8:23-25, 3 pp. |
Heinz et al., “Using Wearable Sensors for Real-time Recognition Tasks in Games of Martial Arts—An Initial Experiment,” Institute for Computer Systems and Networks (CSN), UMIT—University of Health Systems, Medical Informatics and Technology Hall in Tyrol, Austria, retrieve from internet: http://eis.comp.lancs.ac.uk/fileadmin/relate/publication/2006-WearableSensors.pdf, May 22-24, 2006, 5 pp. |
Hendelman et al., “Validity of Accelerometry for the Assessment of Moderate Intensity Physical Activity in the Field,” Medicine & Science in Sports & Exercise, Sep. 2000, pp. S442-S449, 8 pp. |
Hinckley et al., “Sensing Techniques for Mobile Interaction,” ACM UIST 2000 Symposium on User Interface Software & Technology, CHI Letters vol. 2 No. 2, Nov. 2000, pp. 91-100, 10 pp. |
Husak, “Model of Tilt Sensor Systems,” ICECS 2002, 9th IEEE International Conference on Electronics, Circuits and Systems, vol. 1, Sep. 15-18, 2002, pp. 227-230, 4 pp. |
International Search Report and Written Opinion dated May 9, 2011 for corresponding PCT Application No. PCT/US2011/020564, 9 pp. |
Karantonis et al., “Implementation of a Real-Time Human Movement Classifier Using a Triaxial Accelerometer for Ambulatory Monitoring,” IEEE Transactions on Information Technology in Biomedicine, vol. 10/No. 1, Jan. 10, 2006, pp. 156-167, pp. 12. |
Kassam, “2005 EDP Topic “MK4”: Tremor Data-Logger for Parkinson's Disease Patients,” 2005 or Feb. 20, 2006, 3 pp. |
Kerr et al., “Analysis of the sit-stand-sit movement cycle in normal subjects,” Clinical Biomechanics, vol. 12 No. 4, Jun. 1997, pp. 236-245, pp. 10. |
Kiani et al., “Computerized Analysis of Daily Life Motor Activity for Ambulatory Monitoring,” Technology and Health Care 5, Oct. 1997, pp. 307-318, pp. 12. |
Kitchin et al., “Compensating for the 0 g Offset Drift of the ADXL50 Accelerometer,” Analog Devices Application Note AN-380, May 1994, 2 pp. |
Lau et al., “Strategies for Generating Prolonged Functional Standing Using Intramuscular Stimulation or Intraspinal Microstimulation,” IEEE Transactions on Neural Systems and Rehabilitation Engineering, vol. 15 No. 2, Jun. 15, 2007, pp. 273-285, 12 pp. |
Leiper et al., “Sensory Feedback for Head Control in Cerebral Palsy,” Physical Therapy, vol. 61 No. 4, Apr. 1981, pp. 512-518, 6pp. |
Lorussi, “Wearable, Redundant Fabric-Based Sensor Arrays for Reconstruction of Body Segment Posture,” IEEE Sensors Journal, vol. 4 No. 6, Nov. 22, 2004, pp. 808-817, 12 pp. |
Mäkikallio, “Analysis of heart rate dynamics by methods derived from non-linear mathematics: Clinical applicability and prognostic significance,” retrieved on internet: http://herkules.oulu.fi/isbn9514250133/isbn9514250133.pdf, May 4, 1998, pp. 1-63, 64 pp. |
Mathie et al., “A Pilot Study of Long-Term Monitoring of Human Movements in the Home Using Accelerometer,” Journal of Telemedicine and Telecare10, Jun. 2007, 144-151, 7 pp. |
Mathie et al., “Determining Activity Using a Triaxial Accelerometer,” Proceedings of the Second Joint EMBS/BMES Conference, Houston, TX, Oct. 23-26, 2002, pp. 2481-2482, 2 pp. |
Mattmann et al., “Recognizing Upper Body Postures Using Textile Strain Sensors,” Proceedings Eleventh IEEE International Symposium on Wearable Computers, ISWC, Oct. 11-13, 2007, pp. 29-36, 7 pp. |
Mendez et al., “Interactions Between Sleep and Epilepsy,” Journal of Clinical Neurophysiology, American Clinical Neurophysiology Society, 18(2), Mar. 7, 2001, pp. 106-127, 21 pp. |
Muhannad Quwaider, Subir Biswas: “Body Posture Identification using Hidden Markov Model with a Wearable Sensor Network,” Bodynets '08 Proceedings of ICST 3rd International Conference on Body Area Networks, XP002632420, Mar. 13-17, 2008, 8 pp. |
Paraschiv-Ionescu et al., “Ambulatory System for the Quantitative and Qualitative Analysis of Patients Treated with Spinal Cord Stimulation,” Gait and Posture, vol. 20 Issue 2, Oct. 2004, pp. 113-125, 12 pp. |
Slyper et al., “Action Capture with Accelerometers,” Eurographics/ACM SIGGRAPH Symposium on Computer Animation, Carnegie Mellon University, Jul. 7-9, 2008, 7 pp. |
Smith et al., “How do sleep disturbance and chronic pain inter-relate? Insights from the longitudinal and cognitive-behavioral clinical trials literature,” Sleep Medicine Reviews vol. 8 No. 6, Apr. 2004, 119-132 pp., 13 pp. |
Smith et al., “Presleep cognitions in Patients with Insomnia Secondary to Chronic Pain,” Journal of Behavioral Medicine, vol. 24 No. 1, Feb. 2, 2001, pp. 93-114, 21 pp. |
Emmanuel Munguia Tapia, “Activity Recognition from Accelerometer Data for Videogame Applications,” http://alumni.media.mit.edu/˜emunguia/html/videogames.htm, Dec. 2, 2003, 7 pp. |
Trolier-Mckinstry et al., “Thin Film Piezoelectrics for MEMS,” Journal of Electroceramics, v. 12, No. 1-2, Jan. 1, 2004, pp. 7-17, 10 pp. |
Tuck, “Implementing Auto-Zero Calibration Technique for Accelerometers,” Freescale Semiconductor Application Note AN3447, Mar. 27, 2007, 5 pp. |
Tuisku, “Motor Activity Measured by Actometry in Neuropsychiatric Disorders,” Department of Psychiatry, University of Helsinki, Helsinki, Finland, Dec. 13, 2002, 115 pp. |
Vega-Gonzalez, “Upper Limb Activity Monitoring,” Arch Physical Medicine and Rehabilitation, vol. 86 No. 3, Mar. 2005, pp. 541-548, 7 pp. |
Velten et al., “A New Three-Axis Accelerometer,” Sensor '99—9th Int'l Traide Fair and Conference for Sensors/Transducers & Systems, Nürnberg, Germany, Sensor '99 Proceedings II, A 5.2, May 18-20, 1999, pp. 47-52, 5 pp. |
Prosecution History from U.S. Pat. No. 8,579,834, dated Dec. 18, 2012 through Oct. 18, 2013, 31 pp. |
Prosecution History from U.S. Appl. No. 12/433,103, dated Feb. 5, 2013 through Nov. 4, 2013, 57 pp. |
Office Action from U.S. Appl. No. 12/433,103, dated Sep. 18, 2014, 14 pp. |
Response to Office Action dated Sep. 18, 2014, from U.S. Appl. No. 12/433,103, dated Dec. 18, 2014, 14 pp. |
Notice of Allowance from U.S. Appl. No. 12/433,103, dated Jan. 14, 2015, 11 pp. |
Office Action from U.S. Appl. No. 14/699,847, dated Jun. 12, 2015, 11 pp. |
Number | Date | Country | |
---|---|---|---|
20140066796 A1 | Mar 2014 | US |
Number | Date | Country | |
---|---|---|---|
61293538 | Jan 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12985965 | Jan 2011 | US |
Child | 14076702 | US |