Skip to content

Commit

Permalink
Merge branch 'common_trunk_upstream'
Browse files Browse the repository at this point in the history
  • Loading branch information
kareltucek committed Jul 3, 2022
2 parents b7474d7 + c1e2d6f commit adf68fb
Show file tree
Hide file tree
Showing 2 changed files with 676 additions and 4 deletions.
15 changes: 11 additions & 4 deletions doc-dev/reference-manual.md
Original file line number Diff line number Diff line change
Expand Up @@ -409,12 +409,19 @@ For the purpose of toggling functionality on and off, and for global constants m
- `deceleratedSpeed` - speed as affected by deceleration modifier
- `acceleratedSpeed` - speed as affected by acceleration modifier
- `axisSkew` - axis skew multiplies horizontal axis and divides vertical. Default value is 1.0, reasonable between 0.5-2.0 Useful for very niche usecases.
- `set module.MODULEID.{baseSpeed|speed|xceleration}` modifies speed characteristics of right side modules. Simplified formula is `speedMultiplier(normalizedSpeed) = baseSpeed + speed*(normalizedSpeed^xceleration)` where `normalizedSpeed = actualSpeed / midSpeed`. Therefore `appliedDistance(distance d, time t) = d*(baseSpeed*((d/t)/midSpeed) + d*speed*(((d/t)/midSpeed)^xceleration))`. (`d/t` is actual speed in px/s, `(d/t)/midSpeed` is normalizedSpeed which acts as base for the exponent)
- `baseSpeed` is base speed multiplier which is not affected by xceleration. I.e., if `speed = 0`, then traveled distance is `reportedDistance*baseSpeed`
- `set module.MODULEID.{baseSpeed|speed|xceleration}` modifies speed characteristics of right side modules.

Simply speaking, `xceleration` increases sensitivity at high speeds, while decreasing sensitivity at low speeds. Furthermore, `speed` controls contribution of the acceleration formula. The `baseSpeed` can be used to offset the low-speed-sensitivity-decrease effect by making some raw input be applied directlo to the output.

![speed relations](resources/mouse_speeds.svg)

Actual formula is is something like `speedMultiplier(normalizedSpeed) = baseSpeed + speed*(normalizedSpeed^xceleration)` where `normalizedSpeed = actualSpeed / midSpeed`. Therefore `appliedDistance(distance d, time t) = d*(baseSpeed*((d/t)/midSpeed) + d*speed*(((d/t)/midSpeed)^xceleration))`. (`d/t` is actual speed in px/s, `(d/t)/midSpeed` is normalizedSpeed which acts as base for the exponent).
- `baseSpeed` makes portion of the raw input contribute directly to the output. I.e., if `speed = 0`, then traveled distance is `reportedDistance*baseSpeed`
- `speed` multiplies effect of xceleration expression. I.e., simply multiplies the reported distance when the actual speed equals `midSpeed`.
- `xceleration` is exponent applied to the speed normalized w.r.t midSpeed. It makes cursor move relatively slower at low speeds and faster with aggresive swipes. It increases non-linearity of the curve, yet does not alone make the cursor faster and more responsive - thence "xceleration" rather than "acceleration" to avoid confusion. I.e., xceleration expression of the formula is `speed*(reportedSpeed/midSpeed)^(xceleration)`. I.e., no acceleration is xceleration = 0, reasonable (square root) acceleration is xceleration = 0.5. Highest recommended value is 1.0.
- `midSpeed` represents "middle" speed, where the user can easily imagine behaviour of the device (currently fixed 3000 px/s) and henceforth easily set the coefficient. At this speed, acceleration formula yields `1.0`, i.e., `speedModifier = (baseSpeed + speed)`.
- Generally:

General guidelines are:
- If your cursor is sluggish at low speeds, you want to:
- either lower xceleration
- or increase baseSpeed
Expand All @@ -426,7 +433,7 @@ For the purpose of toggling functionality on and off, and for global constants m
- or increase baseSpeed
- If you want to make cursor more responsive overall:
- you want to increase speed
- (Mostly) reasonable examples (`baseSpeed speed xceleration midSpeed`):
(Mostly) reasonable examples (`baseSpeed speed xceleration midSpeed`):
- `0.0 1.0 0.0 3000` (no xceleration)
- speed multiplier is always 1x at all speeds
- `0.0 1.0 0.5 3000` (square root multiplier)
Expand Down
Loading

0 comments on commit adf68fb

Please sign in to comment.