Strength training, also referred to as resistance training or weight lifting, is an important part of any fitness routine. It promotes the building of muscle, the burning of fat, and improvement of a number of metabolic factors including insulin sensitivity and lipid levels. Many users seek a more efficient and safe method of strength training.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
Digital strength training is disclosed. In one embodiment, a user's handle/actuator is coupled via a cable to a motor controlled at least in part by a filter. The filter is controlled by a digital computer to dynamically adjust torque on the motor to make physical exercise more efficient, effective, safe, and/or enjoyable for the user.
Strength Training. For a user, benefits from weight lifting depend greatly on execution of the exercise, including but not limited to: form comprising movement path/pattern, intensity comprising amount of weight/resistance, tempo comprising how fast/slow is the movement, number of sets/repetitions, and timing comprising how long to wait between repetitions and sets. Furthermore, maximal gains are found when the user exercising is pushed to and beyond failure; the point at which they may no longer lift the weight and must go through recovery allowing the muscle to rebuild itself stronger.
A number of additional techniques exist to strengthen a user further. Important ones include the use of concentric, eccentric, and isometric training. Concentric movements are when muscles contract under load, for example using a bicep muscle to initiate lifting a weight. Isometric movements are when a muscle remains stable or at the same position under load, for example once the bicep muscle has lifted the weight, isometric movement is holding the weight in place. Eccentric is when a muscle lengthens under load, for example using a bicep muscle to resist gravity as the weight is being lowered back down.
Collectively, factors comprising form, intensity, tempo, number of sets/repetitions, timing, concentric movements, isometric movements, and eccentric movements are termed “protocols”. Traditionally most resistance training involves symmetric concentric and eccentric loads, such that the same amount of weight is used in both directions. For example, a user may lift a weight and then resist gravity under the same weight load when lowering it.
Exercise protocols exist that rely on asymmetric movements, including pure concentric, pure eccentric, and/or blended asymmetric concentric-eccentric movements. The term “concentric loading” is used when the concentric phase has more weight applied to it than the eccentric phase. The term “eccentric loading” is used when the eccentric phase has more weight applied to it than the concentric phase. These protocols, and many variants on them, for example mixtures of concentric-isometric-eccentric combinations, as well as plyometric explosive movements, are well known to any person having ordinary skill in the art. There are communities of users who value asymmetric protocols for health and efficient training. Users engage in strength training not only to strengthen/build muscles, but also the connective tissue such as tendons around the muscles. Eccentric loading has been shown to build tendon more effectively, particularly in the presence of tendinopathy.
In practice actually achieving asymmetric protocols is challenging. A physical weight such as a dumbbell cannot spontaneously change in weight without violating the laws of physics. Hence, achieving a protocol such as eccentric loading is difficult, where the weight on the eccentric phase is heavier than the concentric phase. A user may try to use makeshift solutions such as elastic bands, stepstools, and/or a second user to address asymmetry, but a user must also maintain proper form and proper timing in order to reap a full benefit from asymmetric protocols which is challenging with makeshift solutions.
Another aspect to strength training is that humans are different from each other. For example, each muscle as moved through its range of motion has an optimal length at which point it achieves peak tension, that is, it is at its strongest. Plotted on an X-Y axis as a “muscle-tension curve”, the X axis plots position on range of motion, and the Y axis plots tension. There is a point on the muscle-tension curve where tension peaks. This point of optimal length differs from person to person depending on individual DNA, environment, strength, and/or conditioning levels.
Furthermore, a muscle's ability to withstand tension/strength changes as a user fatigues throughout a workout session, such that the shape of the muscle-tension curve changes over time. Having a user move a weight that provides a fixed amount of tension throughout the range of motion is sub-optimal when considering that a muscle's ability to withstand tension varies through its range of motion because the muscle-tension curve is not a flat line. Furthermore, a muscle-tension curve differs for concentric, isometric, and eccentric movements.
Traditionally, the vast majority of strength training methods and/or apparatuses fall into the following categories:
While gravity is the primary source of tension and/or resistance in all of the above, tension has also been achieved using springs and/or flexing nylon rods as with Bowflex, elastics comprising rubber bands/resistance bands as with TheraBand, pneumatics, and hydraulics. These systems have various characteristics with their own applied tension curve.
Electronic Resistance. Using electricity to generate tension/resistance is disclosed. In one embodiment, an electromagnetic field is used to generate tension/resistance. In some embodiments, an electronic motor is used to generate tension/resistance. In one embodiment, a three-phase brushless direct-current motor is used to generate tension/resistance. Alternatively, an induction alternating-current motor or other electrical system is used to generate tension/resistance.
A strength trainer using electricity to generate tension/resistance may be smaller and lighter than traditional strength training systems such as a weight stack. A strength trainer using electricity to generate tension/resistance may also be versatile by way of electronic and/or digital control. Electronic control enables the use of software to control and direct tension. By contrast, traditional systems require tension to be changed physically/manually; in the case of a weight stack, a pin has to be moved by a user from one metal plate to another.
Such a digital strength trainer using electricity to generate tension/resistance is also versatile by way of using dynamic resistance, such that tension/resistance may be changed nearly instantaneously. When tension is coupled to position of a user against their range of motion, the digital strength trainer may apply arbitrary applied tension curves, both in terms of position and in terms of phase of the movement: concentric, eccentric, and/or isometric. Furthermore, the shape of these curves may be changed continuously and/or in response to events; the tension may be controlled continuously as a function of a number of internal and external variables including position and phase, and the resulting applied tension curve may be pre-determined and/or adjusted continuously in real time.
In one embodiment, a three-phase brushless DC motor (1006) is used with the following:
In some embodiments, the controller circuit (1002, 1004) is programmed to drive the motor in a direction such that it draws the cable (1008) towards the motor (1006). The user pulls on the actuator (1010) coupled to cable (1008) against the direction of pull of the motor (1006).
One purpose of this setup is to provide an experience to a user similar to using a traditional cable-based strength training machine, where the cable is attached to a weight stack being acted on by gravity. Rather than the user resisting the pull of gravity, they are instead resisting the pull of the motor (1006).
Note that with a traditional cable-based strength training machine, a weight stack may be moving in two directions: away from the ground or towards the ground. When a user pulls with sufficient tension, the weight stack rises, and as that user reduces tension, gravity overpowers the user and the weight stack returns to the ground.
By contrast in a digital strength trainer, there is no actual weight stack. The notion of the weight stack is one modeled by the system. The physical embodiment is an actuator (1010) coupled to a cable (1008) coupled to a motor (1006). A “weight moving” is instead translated into a motor rotating. As the circumference of the spool is known and how fast it is rotating is known, the linear motion of the cable may be calculated to provide an equivalency to the linear motion of a weight stack. Each rotation of the spool equals a linear motion of one circumference or 2πr for radius r. Likewise, torque of the motor (1006) may be converted into linear force by multiplying it by radius r.
If the virtual/perceived “weight stack” is moving away from the ground, motor (1006) rotates in one direction. If the “weight stack” is moving towards the ground, motor (1006) is rotates in the opposite direction. Note that the motor (1006) is pulling towards the cable (1008) onto the spool. If the cable (1008) is unspooling, it is because a user has overpowered the motor (1006). Thus, note a distinction between the direction the motor (1006) is pulling, and the direction the motor (1006) is actually turning.
If the controller circuit (1002, 1004) is set to drive the motor (1006) with a constant torque in the direction that spools the cable, corresponding to the same direction as a weight stack being pulled towards the ground, then this translates to a specific force/tension on the cable (1008) and actuator (1010). Calling this force “Target Tension”, this force may be calculated as a function of torque multiplied by the radius of the spool that the cable (1008) is wrapped around, accounting for any additional stages such as gear boxes or belts that may affect the relationship between cable tension and torque. If a user pulls on the actuator (1010) with more force than the Target Tension, then that user overcomes the motor (1006) and the cable (1008) unspools moving towards that user, being the virtual equivalent of the weight stack rising. However, if that user applies less tension than the Target Tension, then the motor (1006) overcomes the user and the cable (1008) spools onto and move towards the motor (1006), being the virtual equivalent of the weight stack returning.
Setting the controller circuit to drive the motor with constant torque is an example of a filter (1002): Throughout this specification, the equations by which the controller circuit (1004) is configured to drive the motor (1006) are collectively referred to as a “filter”. A basic filter comprises position as a mandatory input of a filter, for example position of the actuator (1010) and/or cable (1008). One example of a basic filter is one that drives the motor (1006) with constant torque. An analogy to a digital strength training filter is a digital camera filter such as a sepia filter, or Polaroid filter, which includes equations that govern how the digital information from a camera sensor are processed to produce an image. Sometimes digital camera filters mimic something from the analog world such as film, which include chemicals on plastic film that react to the exposure of light. Similarly, by way of digital control, a digital strength training filter may make the resulting system feel like a weight stack being acted on by gravity on planet Earth, a weight stack being acted on by gravity on the moon, a weight stack connected via a pulley system acted on by gravity on planet Earth, a spring, a pneumatic cylinder, or an entirely new experience.
The set of equations that describe the behavior of the motor (1006) are its filter (1002). This filter (1002) ultimately affects how the system feels to a user, how it behaves to a user, and how it is controlled. A motor may be controlled in many ways: voltage, current, torque, speed, and other parameters. This is an important part of a filter (1002), because the filter includes equations that define the relationship between the intended behavior of the motor (1006) relative to how the motor (1006) is controlled.
The system described above with the controller circuit (1004) being set to drive the motor (1006) with constant torque is a basic filter (1002). Throughout this specification this filter is referred to as a “Constant Torque Filter”. In such a case, the user experiences a fixed tension on the actuator (1010) assuming low overall system friction. With a Constant Torque Filter, when the system is to behave like an ideal strength training machine with a weight corresponding to a mass m, then m is the specified Target Tension described above. The ideal strength training machine is considered ideal in the sense that it exhibits no friction, momentum, or intertia.
The Constant Torque Filter does not exhibit all of the characteristics of a weight stack acted on by gravity. Such a weight stack has to obey the equations of gravity, has momentum, and has a top speed achievable while falling. A filter mimicking such behavior is called a “Weight Stack Filter” throughout this specification.
A Weight Stack Filter must mirror the behavior of a weight machine with a weight stack. The physics of such a machine are described by a number of equations including:
F=m·α or Force=Mass multiplied by Acceleration;
Wherein: α=g (acceleration is the speed of gravity), and m is the mass of the weight stack, for the force F pulling the weight stack towards the ground.
The weight stack has two forces acting upon it: first, gravity pulling it to the ground; and second, tension from the cable (1008) pulling it up. If the gravity force is greater than the tension, the weight stack moves towards the ground until it bottoms out and/or reaches ground position. If the tension force is greater, then the weight stack moves up away from the ground. If the two forces are equal, then the velocity/speed of the weight stack does not change. If the two forces are equal when the velocity is zero, then the weight stack remains suspended at a fixed position.
The weight stack also experiences friction, which applies in all three cases of the gravity force being greater than tension, gravity force being less than tension, and gravity force being equal to the tension force. The net force determines the acceleration that the weight stack experiences, which over time also determines its velocity, as velocity is the integral of acceleration over time. As F=m·α, or rearranged mathematically
acceleration on the weight stack is the force it is experiencing divided by the mass. As described above, the weight stack experiences two forces added together: F1=−m·g being the gravity force, with the negative convention because gravity is pulling down, and F2=Tg being the tension force, wherein g is used as the gauges are calibrated using weight with respects to the planet. That is, a 101b weight experiences less force on the moon because of the gravitational pull of the moon being lower. As all strain gauges are calibrated using a weight hanging against gravity on this planet, the g for gravity on earth is included in this equation.
Continuing the analytical solution, F=F1+F2, so as
To account for friction in a simple way, gravity g is multiplied by a number between 0 and 1, where a 1 indicates no friction and a 0 indicates so much friction that gravity is completely negated.
wherein r is this friction factor.
In one embodiment, a value of r=0.7 is used from empirical data. This is a simple friction model for illustration. A more complex model may factor in speed, and different friction coefficients for static and dynamic friction. Any person having ordinary skill in the art may produce relevant equations as found in kinematics/physics textbooks.
For a Weight Stack Filter, the above equations define acceleration a as a function of tension T. To complete the Weight Stack Filter, this equation must be related to the way the motor (1006) is being controlled.
In one embodiment, tension T is sampled every 10 milliseconds, that is 100 times per second. In some embodiments, torque on the motor (1006) is controlled using the same methods as the Constant Torque Filter. The equations above defines the acceleration that the weight stack, and hence the user, experiences. At a rate of 100 times per second, tension T is measured and acceleration a calculated, to adjust torque on the motor (1006) such that motor (1006) behaves in a manner consistent with that acceleration. At a rate of 100 times per second motor position, directly or indirectly by measured cable or spool position, is measured. Velocity is then calculated as the change in position divided by the change in time of 10 ms. Acceleration is then calculated as the change in velocity divided by the change in time of 10 ms.
When measured acceleration is compared with the calculated acceleration governed by the equation, if measured acceleration is too high, then motor torque is increased. If we measured acceleration is too low, then motor torque is reduced. In one embodiment, both cases are performed using a PID loop.
In some embodiments, instead of measuring cable tension to calculate velocity, torque is calculated directly. In order to control torque of the motor (1006) directly, a series of calculations are made to model the tension on a cable (1008) of a weight stack moving. In this case, torque/tension is calculated as it is controlled by the controller. The tension on a cable (1008) of a moving weight stack is not static, and varies with the speed/velocity and kinetic energy of the weight stack, which may be calculated by changes in potential energy.
The kinetic energy equation for a moving mass is:
and the potential energy of a weight stack is:
E=m·g·h
where m is the mass,g is the gravitational acceleration, and h is the height from the ground.
As energy expended/work between two points in time is force times distance:
W=ΔE=F·d
Combining these equations, the force exhibited by a moving weight stack is:
Where ν1 is the velocity at the start of a time period, ν2 is the velocity at the end of a time period, d is the distance the mass travels during that time period. Throughout this specification this equation is called the “kinetic force equation”.
Put another way:
Force F as calculated in the above equation is the torque that is applied to the motor using the same method as that of the Constant Torque Filter.
Alternately, a simple equation to accomplish this is the standard relationship F=m·α: If the acceleration the weight stack experienced during a period of time is known, the net force/resistance that the user experiences may be calculated using this equation. The end result is the same, which may also be derived by using the kinetic force equation taking the limit as d goes to zero. Which equation is used in a particular embodiment depends on whether acceleration may be measured/calculated with enough accuracy.
In one embodiment, an adjustment loop is:
This process represents a case when the weight stack is being pulled by a user away from the ground. If the weight stack is falling to the ground, the process is similar; and acceleration is expected due to gravity. If the motor accelerates slower than gravity, it is because the user is resisting, and the force exerted by the motor/torque is adjusted accordingly such that F=m·g+m·α, where a is the additional acceleration from the user.
These equations enable a goal to model a weight stack. The benefits of a Weight Stack Filter is that it feels to a user like a traditional weight machine, and also allows the user to utilize kinetic energy, or energy that has been stored in the form of velocity, to their advantage to finish the exercise. However, some benefits to the user occur by not allowing them to store kinetic energy and later take it back, which some exercise professionals consider a form of cheating. Throughout this specification, the terms “torque” and “tension” are used interchangeably, as one may be calculated from the other—torque is tension multiplied by radius of the hub.
In a constant torque system, the motor (1006) provides a fixed torque that is not adjusted by acceleration, and is set to a torque of m·g·r, which is not adjusted up or down based on changes in velocity and/or acceleration. Throughout this specification this is termed a “no cheat mode” or “momentum free mode”. Some fitness experts suggest that a user should not be allowed to generate momentum because that reduces the amount of work required in the balance of the range of motion. The use of a no cheat mode is a trade-off between feeling “natural” and forcing the user to not cheat.
As an aside, another benefit of the gravity “natural” model of the Weight Stack Filter is that at times the user experiences tension in excess of mg. Some may not consider this cheating as it provides additional strain on the user. Hence, a “true no cheat mode” may be designed with the disclosed techniques that performs all of the calculations for the gravity model, and allows the case of additional tension during acceleration of the weight stack, but not the case of reduced tension during deceleration of the weight stack:
torque=m·r·(g+max(0,α))
where max(0, α) either selects 0 or positive values of a, acceleration experienced by the weight stack as measured by changes in velocity of the cable/actuator (1008, 1010) attached to the hub.
Filters. As described earlier using the analogy of the digital camera to partially explain them, filters govern a specified behavior. To accomplish this, it often requires that this specified behavior be expressed in different forms of variables, and as such it becomes the responsibility of the filter to convert between these forms.
Splitting into two stages is conceptual as different motor configurations are controlled differently. A system may be referred to as the combination of three stages: i) motor abstraction filter (154), ii) controller, and iii) motor. This system has a Variable Under Control (VUC), which is the variable most directly controlled by the system. Consider the following examples:
In each of the above configurations, different types of sensors are required depending on the VUC and the type of controller and motor.
In all of the Torque VUC modes above, a proxy for torque is used: current draw for BLDC motors, and slip for induction motors. Conversion between this proxy and torque in the required units, such as ft-lbs, is another step to be accomplished. Such a calibration is performed by characterizing the system. The accuracy of this conversion may vary based on a number of variables including motor temperature and age. One option may be to measure true torque using a sensor, or some other variable that is used to calculate torque, then use a PID loop to correct for this inaccuracy.
Is shown above, the VUC may be speed, position, or torque. If a given physics model is desired, then further equations could be written to translate between the desired physical behavior and the VUC.
As stated earlier, these stages may be combined into a single stage, for example:
In the domain of fitness equipment intended for strength training, an optimal option for direct control of torque is appropriate, the consequence is the use of a Torque VUC with either a BLDC or Induction motor as a suitable choice. The choice between current based modulation or PWM depends on a number of factors, including the price and availability of components. In one embodiment, PWM control is more prevalent and hence lower cost.
Force may be indirectly controlled if the system includes a spring mechanism. In one embodiment, a linear spring is coupled to the cable (1008). Alternatively, a rotational spring is coupled to the rotation of the motor (1006). With a spring mechanism, controlling force becomes a matter of controlling motor position. Hence, a VUC may be the amount of compression of the spring controlled by motor position.
Position Control. A traditional way to control motor position is to use a standard stepper motor. As well, three-phase brushless DC motors, brush DC motors, and/or induction motors may be precisely position controlled using methods such as a PID loop.
For a suitable stepper motor, position may be controlled directly. Stepper motors are controlled by pulses rather than voltage/current. The pulses command the motor to move one step at a time via shifting electromagnetic fields in the stator of the motor. A control system for a stepper motor is simpler to directly control position rather than velocity. While it is possible to control a stepper motor via velocity by controlling the frequency of the pulses being driven into the motor, position may be preferred in an embodiment.
The equations above describe velocity based control, which may be analytically formed for position based control as, similar to how velocity may be accumulated by summing acceleration over time, position may be accumulated by summing velocity over time.
Pmodel
thus
Perror=Pactual−Pmodel
which tells the controller how many pulses need to be sent to the motor to adjust its position.
In a position based system, it is possible to more easily control tension by adding elasticity, such as a spring, into the system. One example is a rotational spring added to the shaft referred to as a series elastic actuator. A series elastic actuator may be a spring integrated into the shaft between the motor/gearbox (1006) and the hub, wherein the hub is the part that the cable (1008) wraps around. If the hub remains in a fixed position, but the shaft rotates, hence increasing the tension on the spring, that additional tension translates into tension on the cable, or if the motor shaft remains fixed and the hub rotates a similar occurrence happens.
Hence, if the position of the motor (1006) and the position of the hub are measured, then tension may be easily inferred using the characteristics of the spring mechanism. Likewise, if tension were measured directly using a strain gauge for example, then the relative position of the hub to the shaft may be easily calculated. A stepper motor may directly control tension in the system by controlling the relative position of the motor (1006) as compared to the hub. In one embodiment, the controller (1004) calculates a desired relative position between the hub and the shaft in order to produce the tension desired, compares that to the current relative position between the hub and the shaft, then sends the appropriate number of pulses to the stepper motor (1006) to adjust its position to match.
For example, if a series elastic actuator is selected to flex up to 90 degrees, and generates tension from 0 lbs to 200 lbs over those 90 degrees when coupled to a hub and a cable wrapped around that hub, to control tension in 0.5 lb increments a minimum of 400 steps is required in that 90 degree range since 400 steps=200 lbs/0.5 lbs/step.
This is the equivalent of 1600 steps per rotation of the hub as 1600 steps/rotation=400*(360/90). If a stepper motor only had 32 steps per rotation, then a gearbox with a 50×ratio creates the level of desired resolution, as 1600=32×50. Using a 50× gearbox reduces the amount of output torque required by the motor a factor of 50×. Also note that the motor (1006) needs to be designed to resist the torque applied to it when 200 lbs of force is pulled on the cable (1008) in this example, which may be calculated using the radius of the hub and the ratio of the gearbox. An equivalency is a reduction in speed such that the motor could drive the hub by 50×. The selection of a motor also affects noise of the finished system. Some motors are louder than others and gearboxes also generate noise.
The above description is for a sample embodiment with certain characteristics, and demonstrate certain calculations and design parameters/techniques/philosophies. Any person having ordinary skill in the art of motor-driven-system design may perform these calculations using standard equations and make trade-off based decisions to arrive at a final design including selecting which variables to control using a control system.
Position Measurement. Motor position may be measured using a number of methods, including:
Motor Selection. The choice of whether to choose an induction motor or a BLDC, and the parameters of the chosen motor depends on cost, size, weight, thermal constraints, for example how hot the motor gets and how is it cooled, and desired reliability and/or duty cycle. While many motors exist that run in thousands of revolutions per second, an application such as fitness equipment designed for strength training has different requirements and is by comparison a low speed, high torque type application.
In one embodiment, a requirement of such a motor (1006) is that a cable (1008) wrapped around a spool of a given diameter, directly coupled to a motor (1006), behave like a 200 lbs weight stack, with the user pulling the cable at a maximum linear speed of 62 inches per second. A number of motor parameters may be calculated based on the diameter of the spool.
Thus, a motor with 67.79 Nm of force and a top speed of 395 RPM, coupled to a spool with a 3 inch diameter meets these requirements. 395 RPM is slower than most motors available, and 68 Nm is more torque than most motors on the market as well.
Hub motors are three-phase permanent magnet BLDC direct drive motors in an “out-runner” configuration: throughout this specification out-runner means that the permanent magnets are placed outside the stator rather than inside, as opposed to many motors which have a permanent magnet rotor placed on the inside of the stator as they designed for more speed than torque. Out-runners have the magnets on the outside, allowing for a larger magnet and pole count and are designed for torque over speed.
Hub motors also tend to be “pancake style”, meaning they are higher in diameter and lower in depth than most motors. Pancake style motors are advantageous for a wall mount, subfloor mount, and/or floor mount application where maintaining a low depth is desirable, such as a piece of fitness equipment to be mounted in a consumer's home or in an exercise facility/area.
Motors may also be “direct drive”, meaning that the motor does not incorporate or require a gear box stage. Many motors are inherently high speed low torque but incorporate an internal gearbox to gear down the motor to a lower speed with higher torque and may be called gear motors. Direct drive motors may be explicitly called as such to indicate that they are not gear motors.
If a motor does not exactly meet the requirements illustrated in the table above, the ratio between speed and torque may be adjusted by using gears or belts to adjust. A motor coupled to a 9″ sprocket, coupled via a belt to a spool coupled to a 4.5″ sprocket doubles the speed and halves the torque of the motor. Alternately, a 2:1 gear ratio may be used to accomplish the same thing. Likewise, the diameter of the spool may be adjusted to accomplish the same.
Alternately, a motor with 100× the speed and 100th the torque may also be used with a 100:1 gearbox. As such a gearbox also multiplies the friction and/or motor inertia by 100×, torque control schemes become challenging to design for fitness equipment/strength training applications. Friction may then dominate what a user experiences. In other applications friction may be present, but is low enough that it is compensated for, but when it becomes dominant, it is difficult to control for. For these reasons, speed or position VUC are more appropriate for fitness equipment/strength training systems. For Position VUC, motors such as stepper motors may be good options. Stepper motors with a high holding torque may be controlled very accurately.
Constant Torque Filter. A motor (1006) may be controlled to provide a fixed amount of torque, and respond to changes in position and speed to maintain that torque. The method to accomplish this may depend on the type of motor.
The torque of an induction motor is nearly linear and proportional to the amount of “slip”. Throughout this specification slip is defined as the ratio between the actual speed of an AC motor and the frequency being driven into the AC motor. The greater the slip, the greater the torque. The relationship between slip and torque may be determined by characterizing the motor, whereby a test is run and the relationship between slip and torque is plotted manually. Once a relationship has been determined, in some cases it may be approximated by a linear equation.
An induction motor, such as a three-phase alternating current (AC) induction motor, is controlled by driving three sinusoidal waves into each of the three leads of the motors. The input three sinusoidal waves are matched in frequency and amplitude, and separated by 120 degrees of phase difference. A motor with no load/zero torque rotates at the same frequency as the input. As load is added and the motor must exhibit torque to drive that load, the motor slows down. The difference between the speed of the motor and/or rotor, and the input is its slip and is directly proportional to the torque of the motor. Multiple schemes may be used to determine the correct combination of amplitude and frequency to accomplish a certain amount of slip. A common scheme is referred to as “volts per hertz”.
Controlling a motor precisely requires application of a variable under control, the measurement of that variable using a sensor, and a feedback loop, such as a PID loop to perform correction. At times, multiple PID loops may be used either in series, in parallel, or in recursion with a loop within a loop, which the “plant” being controlled by the outer loop includes a PID loop within itself. Throughout this specification, a plant is the portion of system under control for a PID loop.
Torque of a BLDC may be nearly linear and proportional to the amount of current being drawn by the motor. By measuring the current being drawn and adjusting the voltage, torque may be accurately controlled. Determining the relationship between current and torque may be performed by characterizing the motor, whereby a test is run and the relationship between current and torque is plotted. Once the relationship has been determined, in some cases it may be approximated by a linear equation.
In the case of constant torque, a strain gauge is not strictly necessary, although there may be other design decisions that lead to one being used. In induction motors, measuring the speed of the motor which may be calculated by measuring the position of the motor is sufficient in order to determine tension. In a BLDC motor, measuring the current draw of the motor is sufficient in order to determine tension.
Converting slip or current to an amount of torque with high accuracy may be challenging across variations of motors, temperature, and age of the system. If higher accuracy is desired, torque may be measured empirically and a correction factor may be applied. This correction factor may be applied through a PID loop, meant to ensure that measured torque is equal to the desired target torque, with the PID loop adjusting the correction factor until the two are matched. Such a PID loop may be very slow, taking on the order of seconds or minutes to converge.
Because friction in the motor or system may affect the relationship between slip or current, and actual output torque, two correction factors may be calculated, one for each direction analogous to a hysteresis curve. This is because in one direction the torque experienced by a user is that of the motor plus friction, and in the other direction it is that of the motor minus friction. Alternatively, a number of friction models may be utilized such as those described below.
Background references for motor and control include “AC Induction Motor Volts per Hertz Control, Driven by eTPU on MCF523x” by Freescale Semiconductor, Wikipedia articles on: “Induction Motor”; “Brushless DC Electric Motor”; and “PID Controller”, “PID for Dummies” (http://www.csimn.com/CSI_pages/PIDforDummies.html), “PID Without a PhD”, by Tim Wescott of Wescott Design Services, “Sensorless Field Oriented Control of 3-Phase Permanent Magnet Synchronous Motors” by Texas Instruments, “InstaSPIN-FOC and InstaSPIN-MOTION User's Guide” by Texas Instruments, and “TMS320x2806x Piccolo Technical Reference Manual” by Texas Instruments.
Sensors—Tension and Torque. To measure tension on the cable (1008) and/or actuator (1010), the “force” on the cable (1008) and/or actuator (1010) must be measured. For motor based systems where the cable (1008) wraps around a spool, force may be converted to torque by multiplying the force by the radius of the spool.
Torque on the motor may be estimated using techniques such as current draw for a BLDC motor, or slip for an induction motor. Measuring tension directly is a different means of accomplishing the same measurement. There are advantages of doing both, including compensating for drift over temperature and age, as well as friction in the system.
In one embodiment, tension is measured by using a strain gauge in-line in the cable (1008) in a Wheatstone bridge or similar configuration. In such a case an ADC, possibly after an op-amp stage, measures the voltage at the output of the Wheatstone bridge. Before use the tension measurement system must be calibrated. Various weights may be hung on the cable (1008) against gravity, and the measured voltage plotted against the weight. In this way, voltage may be translated into weight by reversing the function plotted. In some cases, the relationship may be approximated by a linear function.
In both the cases of
A third way to measure tension is to apply a strain gauge to the mount holding the motor, also with a Wheatstone bridge. As in other examples, the tension measurement system is calibrated. Various weights may be hung on the cable against gravity, which may cause a force to be applied to the motor mount and thus to the strain gauge, and plot measured voltage against weight. In this way, voltage may be translated into weight by referencing the plot. In many cases, the relationship may be approximated by a linear function.
Sensors—Speed and Position. Measuring velocity may be determined using a number of sensors. In one embodiment, a sensor is a shaft encoder. A shaft encoder measures the rotational position of the shaft of the motor. As the motor rotates the shaft encoder produces an output, for example a pulse every quarter rotation. Counting the edges of these pulses yields position. A pulse may be conceptualized as a voltage level that rises then drops, with two edges per pulse and two opportunities for counting.
For example, consider a motor (1006) with a shaft encoder that produces 8 counts per rotation. The motor (1006) is attached to a gearbox with a 70× reduction ratio. The output shaft of the gearbox is connected to a hub with a 0.15 meter (˜6 inch) diameter.
It may be determined then that the circumference of the hub is approximately meters. Hence, the hub completes one full rotation when the cable moves 0.471 meters. There are 560 counts, from 8 counts per rotation multiplied by the 70× reduction ration, off the shaft encoder for every rotation of the hub. Thus, every count corresponds to a movement of meters (or 0.841 millimeters).
Selection of sensor type, number of pulses, and so forth is driven by the desired sensitivity of the system. Some shaft encoders give an analog sinusoidal output rather than digital pulses, such that output may be read using an ADC. In such a case the sensitivity and/or number of bits of the ADC is also significant. Other sensors may include optical sensors or accelerometers monitoring the rotation of the hub/shaft/gearbox and/or the movement of the cable. The selection of the right sensor may depend on desired characteristics and cost.
The control systems described above were designed to model a weight stack and control a motor where the variable under control is velocity. In various embodiments, a different variable is controlled, such as position, acceleration, or even tension as measured. Determining which variables to control may depend on available sensors, sensor cost, sensor maximum frequency, sensor performance, sensor latency/delay, sensor accuracy, and characteristics of the system including characteristics of the motor, gearbox if any, and elasticity of the cable.
Due to the characteristics of each type of motor, while any variable is controlled on any motor, it may be preferable to: directly control torque on AC motors; directly control speed on DC motors; and directly control position on stepper motors. In addition, torque control on DC motors may be possible by controlling current rather than voltage. As well, depending on the type of motor being used, it may be simpler to directly infer some variables rather than measure them.
For example, the system above described using a strain gauge or similar to measure tension. However, the output torque of an AC three-phase induction motor may be calculated if the output speed is known. In such a case, it may not be necessary to use a strain gauge to measure tension. Instead, the speed of the motor may be measured, using a number of techniques, such as a shaft encoder, and the torque/tension may be inferred/calculated. Different speed sensors have different characteristics in terms of cost, maximum speed, resolution, and so on.
In some embodiments, multiple sensors are combined to achieve measurement across a variety of speeds while maintaining low cost, termed throughout this specification as “sensor fusion”. In the case of a BLDC motor, motor position may be calculated by using a Hall sensor and/or measuring the back-EMF voltage at the leads of the motor. These techniques yield a reading more than accurate enough to control the motor. However, the accuracy of the reading decreases as the speed of the motor decreases. Sensors that measure the physical position of the motor directly increase in cost as their required top speed increases. In addition, at high speed it is more likely that such sensors accumulates error.
In one embodiment, a Hall sensor is used to determine motor position at high speed, and a physical position sensor is used to measure motor position at low speed. Fusing these two readings may be done with an algorithm as follows:
Thus, the change in position is constantly being calculated from both the low-speed sensor and the high-speed sensor in each iteration of the loop. In one embodiment, at any one time only one of the two readings is being trusted for the sensor fusion. Alternatively, the two readings may be linearly or non-linearly combined. This is the reading that is being added to POS. Also note that change in position may be both negative and positive depending on the direction of rotation of the motor.
In order to properly/precisely control a motor, a motor control algorithm may need to know absolute motor position. This is the position of the rotor relative to the stator; the magnets relative to the coils. This absolute position is sometimes referred to as motor angle or magnetic angle, and used such that a motor control algorithm may decide which electrical angle to drive in order to yield the desired result.
The Fast Sensor may use a Hall Sensor and/or voltage at the motor leads, which are directly correlated to the position of the magnets relative to the coils; the Fast Sensor has information about the absolute position of the motor. The Slow Sensor, while higher resolution, only provides relative information about the position of the motor. By combining information from both sensors, the absolute position of the motor may be determined regardless of which sensor is being monitored. For example, after getting information from the Fast Sensor, motor absolute position is known. After switching to the Slow Sensor, relative motor movements are accumulated, and the absolute position of the motor is maintained because it was known at the time when system switched from using the Fast Sensor to the Slow Sensor. Additional details about this process are detailed in the example below.
In one embodiment, a Hall Sensor is used in combination with an encoder. The encoder provides high resolution position information and the Hall Sensor provides low resolution position information. A two-state Hall Sensor provides two outputs: a digital 1 if a magnet is present, and a 0 if no magnet is present. If in a three-phase brushless motor, three Hall Sensors are installed next to three adjacent coils, then the combination of outputs from those Hall sensors determines the absolute position of the motor. This produces combinations of outputs that isolate motor position to one of six regions of motor angle: 0-60 degrees, 60-120 degrees, 120-180 degrees, 180-240 degrees, 240-300 degrees, and 300-360 degrees of electrical angle position.
Because two-state Hall Sensors may report the same values throughout an entire region such as 0-60 degrees, the Hall Sensors cannot be used to detect small movements of the motor. However, whenever the Hall Sensors change state, for example flipping from a 0 to a 1, or a 1 to a 0, it is then known exactly which boundary the motor is at: 0, 60, 120, 180, 240, or 300.
If this information is combined with a high resolution sensor such as an encoder, the two can be combined to derive absolute position with high resolution, using an algorithm such as:
In the above examples, the relationship between the encoder resolution and the angle resolution is important. For example, an encoder may generate a certain number of count per 360 degree electrical rotation. This ratio is important in correlating encoder movement and motor angle movement.
Delta_Motor_Angle_Degree=Delta_Encoder_Position/Encoder_Count_Per_Motor_Angle_Degree
In the Example Above:
Motor_Angle=(ANGLE+(POS−POS_ANGLE)/Encoder_Count_per_motorAngle_Degree)mod 360
Many encoders have a top speed after which they become unreliable, but a fusion system like this may rely on the Hall Sensors once the speed passes a certain threshold. In such a case, once the motor is running at a high speed:
As described above these techniques fuse multiple sensors that each provide information that on their own may not provide a description of the complete system, but using these fusing techniques, information from multiple sensors may be combined to get a strong set of information about motor position.
Friction, Momentum, and Inertia Compensation. As described above, a filter (1002) controls a motor (1006) to produce a certain amount of tension on a cable/actuator (1008/1010), varied over time to accomplish a certain goal including a given feel for the user.
In one embodiment, the motor (1006) is controlled to produce a fixed amount of tension at all times. This fixed amount of tension may be maintained regardless of the speed or acceleration of the motor (1006) or the cable (1008) coupled to the motor. Without limitation, a motor (1006) may vary tension over time based on some other goal/filter, but this simple case is illustrative. The cable (1008) is spooled onto a spool coupled to the motor (1006). The motor rotor and spool have mass to them. The cable (1008) may route through a number of pulleys as it traverses the rest of the system in
With an appropriate filter, these unintended effects may be compensated for. For friction compensation, such a filter adjusts the tension generated by the motor so that the tension experienced by the user after the cable has passed through all the pulleys and other friction sources is as intended. In a simple model, a friction compensation ratio is a percentage of tension that is added during spooling, termed “positive velocity”, and subtracted during unspooling, termed “negative velocity”.
For example, if the friction compensation ratio is set to 15% as measured empirically while friction compensation is not applied to the system, then tension generated by the motor is increased by 15% during spooling, and decreased by 15% during unspooling in order to compensate for that friction. For example, for a goal of 100 lb, the filter will set 115 lb and 85 lb of motor tension for spooling and unspooling, respectively. As the system transitions between spooling and unspooling, the friction compensation filter avoids a discontinuity and smooths where motor tension jumps between 85 lbs and 115 lbs. The filter adds tension based on a saturating linear function of speed. For example, the function is a linear transition from 85 lbs to 115 lbs from a cable speed −2 inches per second to 2 inches per second, wherein the linear function saturates to 115 lbs for velocity over 2 inches per second, and saturates to 85 lbs for velocity below −2 inches per second. The thresholds in the example above at +/−2 inches per second may be adjusted based on the amount of tension such as to effect the fastest transition possible, without ever exceeding a maximum allowed slope. For larger tensions the thresholds are increased, and for lower tensions the thresholds are decreased.
In an alternative embodiment, an advanced function such as a saturating sine or a logistic function is used. Another example of an advanced filter is one that implements a mathematical function derived from the physics equations that model the friction in the system compensated for.
Similarly, a filter may be designed to compensate for momentum/inertia. Such a filter is a function of acceleration rather than speed, because of the definition of momentum according to physics equations. When there is momentum caused by mass, then during acceleration, the tension experienced by the user is higher than intended, and hence the motor tension is reduced. During deceleration the tension experienced by the user is less than intended, and hence the motor tension is increased. The compensation filter is a linear function of acceleration. The slope of this filter may be calculated based on the known mass of the system, or determined empirically by characterizing the behavior of an actual system with momentum compensation turned off.
In an alternative embodiment, an advanced filter may model the kinetic energy of the system, and decrease motor tension whenever kinetic energy of the system is increasing, and increase motor tension whenever kinetic energy is decreasing. This ensures the user is not exhibiting any of the work that is contributing to or benefiting from the kinetic energy of the system. Instead, the motor (1006) compensates for such an effect. For example, the angular momentum of the system may be modeled based on the mass and shape of the motor rotor combined with spool. More complex models also include linear momentum, as well as the momentum of gearboxes, pulleys, and other elements of the system. Another filter may continuously calculate the kinetic energy of the system, and compare it to the amount of kinetic compensation the motor has absorbed through the addition or removal of tension, then calculate how much additional tension compensation should be applied.
Trainer Intelligence. When a user is performing an exercise, the part of their body being exercised moves through a range of motion necessary to perform that exercise. For example, a bicep exercise might move from the elbow being fully extended wherein the bicep muscle is fully elongated, to the elbow being fully bent wherein the bicep is fully contracted. This presents an opportunity for “Trainer Intelligence” as described below.
In some embodiments, for a user performing the exercise with the system of
Strength training exercises are divided into sets. Each set includes one or more repetitions. A user typically performs one or more sets of a given exercise. In order to determine a percent range of motion, the systems in
A user may momentarily change direction of travel at a point that does not demark the beginning or end of a repetition. This may happen if a user is struggling. Such movements may be filtered out for the purposes of determining range of motion, or noted in another way.
Constantly recording and updating the start point, end point, and the calculated stride length are important to calculations. Points change over time, as a user taking a step away from the machine shifts the start and end points the equivalent distance. If the stride length has not changed, the true range of motion may not be changed but be offset, which may be filtered or dealt with appropriately with a calculated offset. The start points and end points may be updated with each repetition, or an average, moving average, or weighted average of the last plurality of recorded samples are used, and may include samples from previous sets.
In some embodiments, range of motion and repetitions are extracted from a series of position updates. Hysteresis is used to filter out small movements that may be mistaken for a new repetition, such as when a user is struggling, and this learns over time by averaging the position of the start and end of the range of motion. Averaging may also occur over weighted averages and/or moving averages. Sample code includes:
Significant changes in stride are noted as they indicate that the user is not completing the full range of motion on the exercise. This is particularly true if the start point is the same, but the end point has changed resulting in a reduced range of motion. This may be an indication of a user that is fatigued or being lazy.
In some embodiments, significant changes in stride are detected through the use of thresholds. For example, a reasonable range of motion for a healthy repetition begins at between 0% and 10%, and ends at between 90% and 100%. If the user ends a repetition at a lower point, such as 83% rather than greater than 90%, then this is considered a significant reduction in range of motion, at which point a user may be alerted and/or coached.
The concentric phase of an exercise is reflected when range of motion is increasing, for example 0% to 100%, and the eccentric phase of an exercise is reflected when range of motion is decreasing, for example from 100% to 0%. The bounds of 0% and 100% need not be actually reached as the user may be lazy or exceeding their average. When range of motion changes from increasing to decreasing, or decreasing to increase, is sufficient to determine a transition from concentric to eccentric or eccentric to concentric.
As shown in
In one embodiment, instead of determining an amount of perceived mass based on either a concentric or eccentric phase, mass is determined simply based on the direction. If the weight stack is rising, a certain mass, Mass-Up, is selected and if the weight stack is falling, a certain mass, Mass-Down, is selected.
The examples above, including concentric loading and eccentric loading, and those that follow, are collectively referred to throughout this specification as “Variable Strength Curves” (VSCs). A number of techniques make the system feel better and/or more comfortable/natural to the user.
In one example, if a user were to pull the cable (1008) halfway under concentric motion to 80%, then reverse direction, for the purposes of mapping to this plot, the 80% point maps to the 100% of the eccentric portion of
One disadvantage of M1(x) is that a user may not experience the full eccentric load during the entire range of motion. Focusing initially on the eccentric range between 100% and 80% as shown
Consider an alternate function M2(x,t) as follows:
If the user violates the hold time goal of 2 seconds and releases the cable (1008) sooner, then the mass m is increased with range of motion, and it is set such that function M1(x) is used instead. Thus, the combined function may be expressed as:
max[M1(x),M2(x,t)]
as whichever function, M1 or M2, increase mass more quickly is the one that is actuated.
In one embodiment, in order to aid the user in meeting the hold time goal, a visual cue, audio cue, and/or other coaching/training/teaching mechanism may be given to the user to indicate and/or encourage the user to hold for the full goal, for example 2 seconds. An example of a visual cue is a light that lights up, or words on a screen, or a bar/slider/circle that fills over a 2 second hold time, and/or a combination of these.
Timing in weight lifting is important as the amount of time spent moving through the range of motion in both the concentric and eccentric phase may affect the benefits of the workout depending on goals. In some cases, a fast speed may be required and in others a slow speed may be required. Visual cues may be given to the user to guide them as to speed—such as a bar that shows where the user actually is in the range of motion as compared to where they should be given the desired speed.
Dynamic Spotting Protocol. Consider a scenario where a user is in the middle of a concentric phase and reaches a point where they cannot complete the range of motion because they are fatigued. This is a common scenario in weight lifting, and may be considered poor form because the user cannot complete the range of motion. However, if the system detects this scenario it “spots” the user, analogous to a human spotter for weight lifting, for example:
The above procedure describes an embodiment corresponding to one spotting protocol, and other protocols exist. In one embodiment, during the concentric phase m is reduced such that velocity of the cable/actuator (1008/1010) does not fall below a pre-determined velocity threshold. If a user's velocity drops below that threshold, m is reduced by a corresponding amount in order to aid the user to maintain a minimum velocity. Such a system may also prevent the user from exceeding a maximum velocity by increasing m if the velocity rises above a target threshold. In a further embodiment, this is accomplished using linear formulas or a PID loop.
In one embodiment, the logic described above is implemented by a series of if statements in software. Alternatively, the logic described above is implemented by a rules engine. Alternatively, the logic described above is implemented using equations. Alternatively, the logic described above is implemented using look-up tables.
Such a spotting procedure may enable “forced repetitions” where a user is aided in completing their full range of motion by being spotted when they get stuck rather than being forced to prematurely end their repetition. This may have health/efficiency benefits for the user.
In this example, after each repetition the user made it past 80% but not to the full 100%, so the system responded by adjusting the mass function after each of the 4 example repetitions. In one embodiment, the logic described above is implemented by a series of if statements in software. Alternatively, the logic described above is implemented by a rules engine. Alternatively, the logic described above is implemented using equations. Alternatively, the logic described above is implemented using look-up tables.
As shown in
If a user gets stuck between 0% and 20% of range of motion in the concentric phase, it may indicate that the mass m is far too high for this given repetition. In such a case, the system may automatically adjust m as follows:
Escalation Service.
Other useful protocols also exist.
Throughout this specification, “Dynamic Resistance” refers to the technique of using a mass function that varies throughout range of motion, through concentric and eccentric phases, and peak-mass that varies through repetitions in a set, spotting a user, and adjustment of m based on a user's ability or when they get stuck. Dynamic Resistance is enabled by electronic control of tension. In one embodiment, electronic control of tension is performed in part by using an electric motor. Alternatively, electronic control of tension is performed without any electric motor.
BLDC Motor Embodiment. In one embodiment, a BLDC motor (1006) is used as part of a technique for electronic control of tension.
Spool (109) has a (1008) cable (110) wrapped around it. Cable (110) may be a cord made up of at least one of the following: steel, nylon, polyester, and/or kevlar cord. Cable (110) may be a belt, a rope, a chain, or a similar cable. Cable (110) has an attachment point (111) at the end of it. This attachment point is an actuator (1010) that may be either a handle that the user pulls on and/or a connector that a handle or accessory such as a bar, strap, or more complex system may be attached to upon which a user pulls directly or indirectly.
Attachment point (111) is part of an exercise machine, such as a chest press machine or a smith machine; many traditional machines use a cable (1008) to interface to a weight stack. Such a cable (1008) is connected to a (1010) member or handle that the user pushes or pulls on, directly or indirectly through an attachment point.
In one embodiment, pulley (106) is mounted on a load cell (104). As the motor (1006) generates torque, which is translated into force on the belt, that force excites load cell (104). The electrical output of a load cell (104) is connected in a Wheatstone bridge (103) configuration, and the output of the Wheatstone bridge is the reading from the load cell (134). This reading is used to determine the amount of torque being generated by the motor in units of weight.
Load cells are calibrated for an accurate reading, wherein the calibration takes into account belt tension generating a pre-load condition on the load cell. Calibration may be performed by first measuring the load cell sensor reading (134) with no weight on the cable (110)/attachment point (111). This reading may be marked as corresponding to zero “0” lb. The motor is then locked in position and a 20 lb weight hung on the cable (110)/attachment point (111), the load cell sensor reading (134) is taken, and this reading may be marked as corresponding to 20 lbs. By using linear interpolation and extrapolation, all load cell sensor readings may be converted to 1b, kg, oz, g, and so forth. The motor is coupled to a rotary encoder motor position sensor (102) that produces a motor position sensor reading (133).
In one embodiment, motor phase control signals (126), (127), and 128 are driven by a standard six-transistor H-Bridge. The H-Bridge comprises transistors (120), (121), (122), (123), (124), and (125); and draws from between motor power supply voltage (132) and ground (133), and is driven by six transistor PWM control signals (135). In one embodiment, the H-Bridge uses electrical current measurement resistors that drive electrical current measurement (140). This may be accomplished by measuring the voltage drop across the resistor, which is directly proportional to the amount of current flowing through the resistor. Because one side of the resistor is grounded, only the supply side of the resistor connected to the transistor need be measured using an ADC. Note that it is only necessary to measure the current flowing on two of the three legs, since the net current flowing in the system is zero. The third may be calculated from the two that are measured.
The voltage on each of the three motor phases at points (129), (130), and (131) are measured using an ADC. These three motor phase voltages (141) may be used to calculate motor position using a position estimator as any person having ordinary skill in the art may understand.
The six PWM control signals (135) are digital signals driven by a control processor (137), running software to implement a control loop (136). The control processor (137) takes as inputs electrical current measurement on each of the motor phases (140), voltage measurement on each of the motor phases (141), motor position from encoder (133), and load cell sensor reading (134) as inputs. In addition, the processor is coupled to interactive user interface (100).
The technique to driving the three phases of a 3-phase BLDC motor is dependent on the position of the motor (1006). Each physical position of the motor corresponds to an electrical angle that depends on the number of poles that the motor physically is built with. Each electrical angle corresponds to a relationship of voltages between the three phases, in which each phase is driven with a sinusoid such that each of the three phases is phase shifted by 120 degrees relative to the remaining two phases in the set. Determining the electrical angle that the motor must be driven with depends on determining an accurate physical position of the motor (152).
In one embodiment, motor back-EMF may be measured by measuring voltage on the motor phases (141). While the motor is rotating, this back-EMF is generated, and the relative voltage generated on each of the three phases of the motor is directly related to the position of the motor. Any person having ordinary skill in the art may understand determining motor position from voltage measurement. This is a primary function of position estimator (154). A limitation of position estimator (154) is that it does not function unless the motor speed is sufficiently high. For low speeds, a motor position may be determined using an encoder (133) or similar device. A position calculator (153) applies sensor fusion to combine data from motor position (133) and position estimator (154) in order to produce an accurate motor position (152).
Advantages of applying sensor fusion to combine low speed and high speed data to determine motor position comprise: i) it is resilient to encoder slip in the event the encoder is coupled to the motor using a friction based mechanism that may slip; ii) it does not require an encoder to operate at high speeds which may be costly or complex; and iii) it provides a direct correlation between encoder position and motor electrical angle, which otherwise has to be calibrated—and in some cases every time the system is powered up. Motor position (152) may also be used to calculate velocity, and velocity may be used to calculate acceleration.
If a relationship between target torque and target current is known, then a simple lookup table and/or equation may be used to convert between the two. Such a scheme may be susceptible to variation over time and instance from a number of factors including temperature, wear, age, manufacturing variance, and so forth. If the torque output of the motor may be measured directly or indirectly, it is used to establish and/or calibrate for the relationship between target torque and target current (162).
Throughout this specification, the terms target torque (163) and target weight (163) may be used interchangeably because weight and torque are converted directly between one another. In one embodiment, a PID control loop (156) compares target torque (163) to a reading from a load cell sensor (134) and adjusts target current (162) to match. In a further embodiment, because the system is dynamic, the time constants of this PID loop are long.
In one embodiment, as described above in calibration of the load cell sensor, the load cell sensor reading (134) is converted to the same units as target torque (163). This is performed by weight calculator (166) that converts the load cell reading (134) to weight reading (165). Target torque (163) has a direct and linear relationship to a target weight (163) desired in terms of cable tension on the cable (1008), which is directly proportional to the radius of the spool (109) that the cable (110) is wrapped around, and the relative ratio of the radii of the two sprockets (113) and (112).
In some embodiments, a constant torque filter is used and this system is sufficient. Alternatively, the system instead models/mimics the physics of another environment such as a weight lifting machine with a weight stack, and a physics model (157) may adjust target torque (163) to produce the desired behavior. Note that such a physics model affects both output torque and output speed because the two are related. A physics model (157) takes as input motor position (152) and/or weight readings (165), and based on physics model input parameters (158), uses a series of equations in a loop to continuously calculate target torque in order to cause the system to have in a manner that mimics the behavior of the target environment, such as a weight stack filter modeling a weight lifting machine with a weight stack. In one embodiment, the loop runs between 100 Hz and 20 kHz.
The system may include multiple physics models that may be selected and/or combined. Furthermore, the parameters to the physics model may be user accessible. For example, a user may indicate the amount of momentum they wish a weight stack to be allowed to have, or the amount of friction they wish a weight stack to experience.
Physics model input parameters (158) may be static based on user input including “please behave like a 50 lbs weight stack”. Physics model input parameters (15) may be dynamic and change over time, such as in the case of implementing Trainer Intelligence, implementing Variable Strength Curves, implementing Dynamic Resistance, and/or implementing a Spotting Protocol. Such Trainer Intelligence and/or Dynamic Resistance may require the monitoring of both motor position (152) and/or weight reading (165). Both position (152) and weight (165) may be used to implement the extracting repetition information and/or range of motion information, or other parameters used in Trainer Intelligence and/or Dynamic Resistance.
Preferably, the control subsystem (101) is coupled to a User Interface (100). The User Interface (100) may have a means of taking user input, such as a touch screen, buttons, dials, or similar, and may have a means of giving user feedback, such as a screen, lights, and/or audible sound generator such as a speaker. Such a user interface may be directly coupled to the system, or indirectly coupled, such as the case of an mobile application on a mobile device such as a phone or tablet, coupled to the embodiment over a wireless and/or wired connection, such as USB, Ethernet, Bluetooth, or Wi-Fi.
Induction Motor Embodiment. Another embodiment besides the BLDC motor embodiment described above is one that utilizes an induction motor rather than a BLDC motor (1006). There are the following notable differences between the BLDC motor and induction motor systems:
Thus, the primary variable under control changes from current for BLDC motors to motor slip for induction motors.
Other Embodiments. Aside from the BLDC motor embodiment and induction motor embodiment described above, other embodiments of the disclosed include:
In one embodiment, a controller programed/configured/designed to emulate a gravity-and-metal based cable machine is used, and so a Weight Stack Filter is used. In one embodiment, a controller uses a microprocessor such as a MIPS or 8051 based micro-controller running instructions/code to implement a control system. Every interval, such as every five milliseconds corresponding to 200 times per second, the system may:
where Δt is the interval of time since velocity was last calculated. That is, five milliseconds ago wherein the velocity calculated at that time is referred to as νmodel
With velocity modeled, it is compared to actual velocity measured:
νerror=∇actual−∇model
wherein νerror may be used by the controller to modify the amount of voltage/current being driven into the motor.
The virtual weight stack may move in two directions. It may move away from the ground or towards the ground. The notion of the weight stack is one modeled in equations, as there is no physical weight stack. The physical embodiment is a cable (1008) wrapped around the shaft of a motor (1006), possibly coupled with a hub. So, a weight moving may be translated into a motor rotating. As the circumference of the hub is known, and how fast the motor (1006) is rotating is known, the linear motion of the cable (1008) may be calculated, which is equivalent to the linear motion of a weight stack. Each rotation of the hub equals a linear motion of one circumference or 2πr for hub radius r. Similarly, torque of the motor may be translated into linear force by multiplying it by radius r.
A convention of established such that if the “weight stack” is moving away from the ground, the motor is rotating in one direction, and if moving towards the ground the motor is rotating in the opposite direction. Thus, the system is nearly always applying voltage/current/power to motor (1006) so that it rotates or nearly rotates in the direction corresponding to a weight stack affected by gravity.
In one case, the tension on the cable is so high, that the calculated acceleration is in the direction away from the ground, and hence that acceleration over a period of time accumulates into a velocity that corresponds with the weight stack moving away from the ground. When that occurs, the power applied to the motor is in the direction of driving the weight stack towards the ground, but the force of the user pulling on the cable overcomes the force of the motor causing it to rotate in the opposite direction. In such a case, if the motor is rotating faster than the model dictates, in order to slow it down, the controller has to increase the power to the motor so that it resists the user more heavily.
In the opposite case, when the weight stack is moving towards the ground, and the motor is rotating in the direction corresponding the weight stack moving towards the ground, if the motor rotates too fast compared to the model, then to slow the motor down, the controller (1002) has to reduce the power to the motor (1006). Therefore, the controller not only accounts for the error in velocity, but also the direction of that velocity.
The voltage being driven into the motor is adjusted as follows:
Vnew=Vold−c1·νerror
wherein c1 is a constant that represents how aggressively the voltage is adjusted in response to an error. Larger values result in overshoot, ringing, and instability. Lower values result in slow convergence.
Changing if voltage is increased or decreased depending on the direction of travel is automatically handled because the sign of νerror may reverse when the velocity reverses, since in one case positive velocity is one direction and the other direction is negative velocity. In one embodiment, c1 is not a static constant but adjusted depending at least in part on the direction of travel:
wherein c2 is a more suitable constant when the velocity is negative/moving away from the ground, and moving at a negative rate greater in magnitude than ν2;
wherein c3 is a more suitable constant when the velocity is positive/moving towards the ground, and moving at a positive rate greater in magnitude than ν3.
As shown in the equation, at outer bounds the ideal constants are selected, and a linear function is used between the outer bounds to select the correct constant.
In general, for the disclosed techniques any transfer function may be selected, and a transfer function need not necessarily be linear. As shown in the example above, the system is flexible to accept νactual and/or νmodel The system is flexible to accept designs with static constants or dynamic factors like the aggressive c1 and accept different designs with different design consequences. In one embodiment, a linear control loop is used for control. Alternatively, a PID control loop is used for more sophisticated control.
A weight stack may be modeled in the case when the virtual weight stack reaches the “ground”. At this point, velocity is zero. A control system may thus monitor position at all times, and stops the rotation of the motor when the position reaches zero and/or ground position. Similarly, the starting case is that a weight stack does not move until the tension on the cable exceeds the weight of the stack. Thus, the system may measure tension and using that result to decide when to release the motor and allow it to start rotating. The motor may not be released until tension exceeds the weight of the weight stack. There are numerous ways to brake a motor and/or hold it in position, including controlling voltage into the motor to resist any force trying to move that motor, using the equations above wherein νmodel=0. Braking a motor may also be used in an emergency and/or safety situation wherein the system senses a loss of control. In one embodiment, the controller (1004) provides a ‘motor firewall’ for a user to protect the user with braking using failsafe switches and techniques. This provides a measure of safety for the user.
Any person having ordinary skill in the art of control system design and theory may use tradeoffs to fine tune the system to achieve the desired result. This fine tuning may depend on factors including the characteristics of the exact motor being used, the gearbox if any, and/or the elasticity of the cable.
Applying manual power to a motor (1006) in order to slow it down and/or resisting rotation in the opposite direction that power is being applied may result in the motor generating power in the form of output voltage/current in excess of the voltage/current applied to the motor. Using a transistor as a switch and a capacitor to store this excess power, and then later using that power to drive the motor may result in a system that utilizes less power and generates less waste/heat.
In some embodiments, a motor is controlled in the manner described above such that a user pulling on a cable (10008) wrapped around a hub coupled to that motor (1006), possibly through a gearbox and with one or more sensors on that motor, may experience a tension equivalent to that of a weight stack. In one embodiment, a modified model is used as a “no cheat” or “true no cheat” model as described above.
With regards to motors, currently DC brush motors are least reliable. Permanent magnet motors such as DC brush and brushless motors also suffer drawbacks currently of being more expensive and risk demagnetization of the magnets over time. They may currently also have less torque requiring a gearbox. Higher ratio gearboxes currently may have more friction, making them harder to control. Stepper motors currently are loud and may be expensive. Series elastic actuators currently reduce the reliability of the system and add expense.
One simple and reliable preferred system uses an AC motor, such as a three-phase induction motor, with a motor powerful enough to not require a gearbox. Sizing the hub changes the amount of torque required to achieve a given amount of force, as the greater the radius of the hub, the more torque required. Systems with BLDC or stepper motors may be advantageous due to cost, performance, and/or availability.
Models discussed above rely on a variable m or some proxy for m, such as air pressure in a pneumatic system, voltage/current in an electro-magnetic-mechanical system, and so forth, which represents the mass of the weight stack. Some equations described above assume that m was a static variable that does not change, but the disclosed techniques may without limitation use protocols where m is not fixed. The mass variable m may change continuously causing the user to experience a weight stack that changes weight. In resistance training, a standard weight lifting setup is based on static resistance—one where the mass of the weight is constant. However, by changing m, we achieve dynamic resistance—one where the effective mass changes based on a number of factors. This has numerous health and efficiency benefits for the user.
In step 3402, an information related to the position of an actuator (1010) coupled to a cable (1008) which is coupled to a motor (1006) is received. In one embodiment, the actuator (1010) is a handle. In one embodiment, the motor (1006) is a three-phase motor, for example an AC induction motor. In one embodiment, the information related to the position of the cable includes a plurality of points in time to derive velocity of the cable.
In step 3404, a filter (1002) computes motor position based on sensor fusion comprising a high speed sensor to determine motor position at high speed and a low speed sensor to determine motor position at low speed. In one embodiment, the filter (1002) computes motor position based on sensor fusion comprising a magnet sensor to determine motor position based on magnetism and an optical sensor to determine motor position based on optics.
In an optional step 3406, the filter receives a second information related to the force applied on the cable. Force applied to the cable coupled with actuator position enhances information on the user to calculate momentum and so forth.
In step 3408, an input to a motor controller (1004) coupled to the motor (1006) is provided by using the filter (1002), to adjust torque on the motor (1006) such that a strength curve is implemented relative to the position of the actuator (1010). In one embodiment, the filter (1002) is a digital filter.
As described above, the strength curve may be a constant torque filter to drive the actuator (1010) with a constant torque. The strength curve may be a weight stack filter, mirroring to the actuator (1010) behavior of a weight machine with a weight stack. In one embodiment, the weight stack filter mirrors to the actuator (1010) behavior of a weight machine with a weight stack with at least ten pounds of accuracy. In one embodiment, the weight stack filter mirrors to the actuator (1010) behavior of a weight machine with a weight stack with at least five pounds of accuracy. In one embodiment, the weight stack filter mirrors to the actuator (1010) behavior of a weight machine with a weight stack with at least three pounds of accuracy. In one embodiment, the weight stack filter mirrors to the actuator (1010) behavior of a weight machine with a weight stack with at least one pound of accuracy.
The strength curve may be a momentum free weight stack filter, mirroring to the actuator (1010) behavior of a weight machine with a weight stack without momentum. For a momentum free weight stack filter, the filter may calculate an actuator momentum of the actuator (1010) and compensate for the actuator momentum and/or calculate an actuator friction being applied to the actuator and compensate for the actuator friction being applied. In one embodiment, the calculation of the actuator friction comprises a percentage of the mirrored weight stack weight.
In one embodiment, the strength curve includes an asymmetry, providing eccentric loading service to the actuator (1010). In a further embodiment, the strength curve includes a dynamic Spotter Protocol, providing a weight spotter service to a user using the actuator (1010). In a further embodiment, the strength curve includes a Trainer Intelligence protocol, for example a dynamic repetition protocol, including: a pyramid service, an escalation service, and/or a drop service. In a further embodiment, the strength curve comprises a dynamic nonlinear strength curve that changes over time.
Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
This application is a continuation of U.S. patent application Ser. No. 17/836,382, entitled DIGITAL STRENGTH TRAINING filed Jun. 9, 2022 which is incorporated herein by reference for all purposes, which is a continuation of U.S. patent application Ser. No. 17/179,288, entitled DIGITAL STRENGTH TRAINING filed Feb. 18, 2021, now U.S. Pat. No. 11,389,687, which is incorporated herein by reference for all purposes, which is a continuation of U.S. patent application Ser. No. 16/737,684, entitled DIGITAL STRENGTH TRAINING filed Jan. 8, 2020, now U.S. Pat. No. 11,465,006, which is incorporated herein by reference for all purposes, which is a continuation of U.S. patent application Ser. No. 15/655,682, entitled DIGITAL STRENGTH TRAINING filed Jul. 20, 2017, now U.S. Pat. No. 10,661,112, which is incorporated herein by reference for all purposes, which claims priority to U.S. Provisional Patent Application No. 62/366,573 entitled METHOD AND APPARATUS FOR DIGITAL STRENGTH TRAINING filed Jul. 25, 2016 which is incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
3465592 | Perrine | Sep 1969 | A |
3511225 | Gunpei | May 1970 | A |
3953025 | Mazman | Apr 1976 | A |
4261562 | Flavell | Apr 1981 | A |
4616823 | Yang | Oct 1986 | A |
4798378 | Jones | Jan 1989 | A |
4817939 | Augspurger | Apr 1989 | A |
4869497 | Stewart | Sep 1989 | A |
4898381 | Gordon | Feb 1990 | A |
5020794 | Englehardt | Jun 1991 | A |
5042798 | Sawicky | Aug 1991 | A |
5104121 | Webb | Apr 1992 | A |
5117170 | Keane | May 1992 | A |
5265589 | Wang | Nov 1993 | A |
5277684 | Harris | Jan 1994 | A |
5360382 | Chi | Nov 1994 | A |
5433678 | Chi | Jul 1995 | A |
5569121 | Sellier | Oct 1996 | A |
5583403 | Anjanappa | Dec 1996 | A |
5588938 | Schneider | Dec 1996 | A |
5624353 | Naidus | Apr 1997 | A |
5697869 | Ehrenfried | Dec 1997 | A |
5830116 | Gautier | Nov 1998 | A |
5897444 | Hellyer | Apr 1999 | A |
5993356 | Houston | Nov 1999 | A |
6027429 | Daniels | Feb 2000 | A |
6142919 | Jorgensen | Nov 2000 | A |
6227047 | Livingston | May 2001 | B1 |
6238323 | Simonson | May 2001 | B1 |
6280361 | Harvey | Aug 2001 | B1 |
6443877 | Hoecht | Sep 2002 | B1 |
6508748 | Ish, III | Jan 2003 | B1 |
6547702 | Heidecke | Apr 2003 | B1 |
7682287 | Hsieh | Mar 2010 | B1 |
7686746 | Koyama | Mar 2010 | B2 |
7695418 | Ish, III | Apr 2010 | B2 |
7885785 | Pekarek | Feb 2011 | B1 |
7909742 | Ish, III | Mar 2011 | B2 |
7985166 | Farnsworth | Jul 2011 | B2 |
7998033 | Schroeder | Aug 2011 | B1 |
7998036 | Ish, III | Aug 2011 | B2 |
8057367 | Giannelli | Nov 2011 | B2 |
8096926 | Batca | Jan 2012 | B1 |
8287434 | Zavadsky | Oct 2012 | B2 |
8308620 | Lyszczarz | Nov 2012 | B2 |
8333681 | Schmidt | Dec 2012 | B2 |
8337364 | Ishii | Dec 2012 | B2 |
8388499 | Rindfleisch | Mar 2013 | B1 |
8475338 | Greenhill | Jul 2013 | B2 |
8517899 | Zhou | Aug 2013 | B2 |
8727946 | Greenhill | May 2014 | B2 |
8834328 | Batca | Sep 2014 | B1 |
8845499 | Boatwright | Sep 2014 | B1 |
8900097 | Griggs | Dec 2014 | B1 |
8900099 | Boyette | Dec 2014 | B1 |
8968155 | Bird | Mar 2015 | B2 |
9211434 | Giannelli | Dec 2015 | B2 |
9457220 | Olson | Oct 2016 | B2 |
9656116 | Giannelli | May 2017 | B2 |
9700753 | Boatwright | Jul 2017 | B1 |
9861856 | Miller | Jan 2018 | B1 |
9901766 | Ross | Feb 2018 | B2 |
9901768 | Wu | Feb 2018 | B1 |
9999795 | Jarosz | Jun 2018 | B1 |
10004945 | Sauter | Jun 2018 | B2 |
10143880 | Boatwright | Dec 2018 | B1 |
10220235 | Norris | Mar 2019 | B2 |
10258821 | Jeong | Apr 2019 | B2 |
10265572 | Bach | Apr 2019 | B2 |
10286253 | Johnson | May 2019 | B1 |
10335626 | Orady | Jul 2019 | B2 |
10441840 | Dalebout | Oct 2019 | B2 |
10486015 | Valente | Nov 2019 | B2 |
10500442 | Hong | Dec 2019 | B2 |
10549152 | Walker | Feb 2020 | B2 |
10589163 | Orady | Mar 2020 | B2 |
10596056 | Hou | Mar 2020 | B2 |
10709925 | Dalebout | Jul 2020 | B2 |
10758767 | Olson | Sep 2020 | B2 |
11040231 | Rubin | Jun 2021 | B2 |
11097148 | Kennington | Aug 2021 | B2 |
11110317 | Valente | Sep 2021 | B2 |
11123592 | Orady | Sep 2021 | B2 |
20010023221 | Simonson | Sep 2001 | A1 |
20030017918 | Webb | Jan 2003 | A1 |
20030032535 | Wang | Feb 2003 | A1 |
20030134722 | Greenland | Jul 2003 | A1 |
20030153438 | Gordon | Aug 2003 | A1 |
20030171192 | Wu | Sep 2003 | A1 |
20030176261 | Simonson | Sep 2003 | A1 |
20030207734 | Paul | Nov 2003 | A1 |
20040009848 | Lee | Jan 2004 | A1 |
20040082438 | Lastayo | Apr 2004 | A1 |
20040092369 | Slawinski | May 2004 | A1 |
20040157711 | Regev | Aug 2004 | A1 |
20050143226 | Heidecke | Jun 2005 | A1 |
20050143230 | Dalebout | Jun 2005 | A1 |
20060006836 | Miehlich | Jan 2006 | A1 |
20060040799 | Pompile | Feb 2006 | A1 |
20060069336 | Krebs | Mar 2006 | A1 |
20060229164 | Einav | Oct 2006 | A1 |
20060234832 | Toyama | Oct 2006 | A1 |
20060234840 | Watson | Oct 2006 | A1 |
20070015096 | Soller | Jan 2007 | A1 |
20070054785 | Drechsler | Mar 2007 | A1 |
20070117691 | Sechrest | May 2007 | A1 |
20070129223 | Kolomeir | Jun 2007 | A1 |
20070135264 | Rosenberg | Jun 2007 | A1 |
20070142187 | Kolomeir | Jun 2007 | A1 |
20070155587 | Huang | Jul 2007 | A1 |
20070161470 | Berryman | Jul 2007 | A1 |
20070161472 | Drechsler | Jul 2007 | A1 |
20070173384 | Sechrest | Jul 2007 | A1 |
20070202992 | Grasshoff | Aug 2007 | A1 |
20070224582 | Hayashino | Sep 2007 | A1 |
20070259759 | Sumners | Nov 2007 | A1 |
20080051263 | Rasmussen | Feb 2008 | A1 |
20080051267 | Ish, III | Feb 2008 | A1 |
20080161733 | Einav | Jul 2008 | A1 |
20080248926 | Cole | Oct 2008 | A1 |
20080294074 | Tong | Nov 2008 | A1 |
20080300116 | Eder | Dec 2008 | A1 |
20090023561 | Ross | Jan 2009 | A1 |
20090029835 | Ellis | Jan 2009 | A1 |
20090036277 | Ish, III | Feb 2009 | A1 |
20090075791 | Kissel | Mar 2009 | A1 |
20090111666 | Wang | Apr 2009 | A1 |
20090114892 | Lesko | May 2009 | A1 |
20090170675 | Giannelli | Jul 2009 | A1 |
20090221403 | Chan | Sep 2009 | A1 |
20100001177 | Dolenti | Jan 2010 | A1 |
20100069202 | Olsen | Mar 2010 | A1 |
20100144496 | Schmidt | Jun 2010 | A1 |
20100144497 | Clark | Jun 2010 | A1 |
20100216600 | Noffsinger | Aug 2010 | A1 |
20100298097 | Preumont | Nov 2010 | A1 |
20100311552 | Sumners | Dec 2010 | A1 |
20100331148 | Huang | Dec 2010 | A1 |
20110152045 | Horne | Jun 2011 | A1 |
20110172058 | Deaconu | Jul 2011 | A1 |
20110183816 | Giannelli | Jul 2011 | A1 |
20110275481 | Greenhill | Nov 2011 | A1 |
20110294630 | Reyes | Dec 2011 | A1 |
20120021876 | Hsiung | Jan 2012 | A1 |
20120053014 | Zhu | Mar 2012 | A1 |
20120088634 | Heidecke | Apr 2012 | A1 |
20120231929 | Hsieh | Sep 2012 | A1 |
20120279801 | Watson | Nov 2012 | A1 |
20130095978 | Sauter | Apr 2013 | A1 |
20130157816 | Lyszczarz | Jun 2013 | A1 |
20130172153 | Watterson | Jul 2013 | A1 |
20130289452 | Smith | Oct 2013 | A1 |
20130296144 | Gvoich | Nov 2013 | A1 |
20130331239 | Richards | Dec 2013 | A1 |
20140038777 | Bird | Feb 2014 | A1 |
20140113779 | Loach | Apr 2014 | A1 |
20140121071 | Strom | May 2014 | A1 |
20140194250 | Reich | Jul 2014 | A1 |
20140194251 | Reich | Jul 2014 | A1 |
20140226963 | Ryan | Aug 2014 | A1 |
20140228174 | Olsen | Aug 2014 | A1 |
20140228175 | Lemos | Aug 2014 | A1 |
20140287876 | Etter | Sep 2014 | A1 |
20150020620 | Garner | Jan 2015 | A1 |
20150133828 | Hachisuka | May 2015 | A1 |
20150148194 | Bird | May 2015 | A1 |
20150165272 | Bird | Jun 2015 | A1 |
20150190667 | Balandis | Jul 2015 | A1 |
20150190678 | Golsby | Jul 2015 | A1 |
20150258381 | Suzuki | Sep 2015 | A1 |
20150297934 | Agrawal | Oct 2015 | A1 |
20150335950 | Eder | Nov 2015 | A1 |
20150335951 | Eder | Nov 2015 | A1 |
20150367162 | Mueller | Dec 2015 | A1 |
20160101322 | Potter | Apr 2016 | A1 |
20160114211 | Schmidt | Apr 2016 | A1 |
20160151675 | Chazalon | Jun 2016 | A1 |
20160158603 | Darwood | Jun 2016 | A1 |
20160193497 | Arst | Jul 2016 | A1 |
20160243402 | Finadri | Aug 2016 | A1 |
20160249832 | Carter | Sep 2016 | A1 |
20160332019 | Rollins | Nov 2016 | A1 |
20160332020 | Chen | Nov 2016 | A1 |
20160346617 | Srugo | Dec 2016 | A1 |
20160354638 | Carr | Dec 2016 | A1 |
20160361597 | Cole | Dec 2016 | A1 |
20170173396 | Lu | Jun 2017 | A1 |
20170197103 | Rau | Jul 2017 | A1 |
20170239124 | Cunningham | Aug 2017 | A1 |
20170239517 | Jeong | Aug 2017 | A1 |
20170246507 | Kennington | Aug 2017 | A1 |
20170266481 | Dalebout | Sep 2017 | A1 |
20170282015 | Wicks | Oct 2017 | A1 |
20170319905 | O'Connor | Nov 2017 | A1 |
20170333756 | Bird | Nov 2017 | A1 |
20170361165 | Miller | Dec 2017 | A1 |
20180001181 | Von Prellwitz | Jan 2018 | A1 |
20180021614 | Taft | Jan 2018 | A1 |
20180021616 | Orady | Jan 2018 | A1 |
20180160943 | Fyfe | Jun 2018 | A1 |
20180214729 | Rubin | Aug 2018 | A1 |
20180214730 | Larose | Aug 2018 | A1 |
20180243600 | Kennington | Aug 2018 | A1 |
20180290001 | Baek | Oct 2018 | A1 |
20180326243 | Badi | Nov 2018 | A1 |
20180361200 | Walker | Dec 2018 | A1 |
20190001183 | Liao | Jan 2019 | A1 |
20190046830 | Chiavegato | Feb 2019 | A1 |
20190099632 | Orady | Apr 2019 | A1 |
20190099633 | Orady | Apr 2019 | A1 |
20190099637 | Valente | Apr 2019 | A1 |
20190099652 | Orady | Apr 2019 | A1 |
20190126099 | Hoang | May 2019 | A1 |
20190160324 | Leopoldo Da Camara Filho | May 2019 | A1 |
Number | Date | Country |
---|---|---|
2441509 | Aug 2001 | CN |
2681776 | Mar 2005 | CN |
2683184 | Mar 2005 | CN |
2817911 | Sep 2006 | CN |
101007205 | Aug 2007 | CN |
201631963 | Nov 2010 | CN |
102458593 | May 2012 | CN |
202554808 | Nov 2012 | CN |
102671346 | Apr 2014 | CN |
204219688 | Mar 2015 | CN |
105498151 | Apr 2016 | CN |
205360399 | Jul 2016 | CN |
206508201 | Sep 2017 | CN |
202006006751 | Jun 2006 | DE |
202009006018 | Jul 2009 | DE |
3202465 | Aug 2017 | EP |
2968571 | Jan 2013 | FR |
S62179478 | Aug 1987 | JP |
H07227439 | Aug 1995 | JP |
H10203467 | Aug 1998 | JP |
11342226 | Dec 1999 | JP |
U3096472 | Sep 2003 | JP |
2006187317 | Jul 2006 | JP |
2015031511 | Feb 2015 | JP |
100847515 | Jul 2008 | KR |
101160960 | Jun 2012 | KR |
101166981 | Jul 2012 | KR |
20140124161 | Oct 2014 | KR |
M397837 | Feb 2011 | TW |
1988001185 | Feb 1988 | WO |
1991012854 | Sep 1991 | WO |
2009061178 | May 2009 | WO |
2009143808 | Dec 2009 | WO |
2016171799 | Oct 2016 | WO |
2018022465 | Feb 2018 | WO |
Entry |
---|
Brakel, J.P.G. Van. “Robust peak detection algorithm using z-scores”. Stack Overflow. 2014 (version: Nov. 8, 2020). |
Espacenet, Machine translation of KR20140124161 Description (Year: 2014). |
Number | Date | Country | |
---|---|---|---|
20240024724 A1 | Jan 2024 | US |
Number | Date | Country | |
---|---|---|---|
62366573 | Jul 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17836382 | Jun 2022 | US |
Child | 18375282 | US | |
Parent | 17179288 | Feb 2021 | US |
Child | 17836382 | US | |
Parent | 16737684 | Jan 2020 | US |
Child | 17179288 | US | |
Parent | 15655682 | Jul 2017 | US |
Child | 16737684 | US |