-
Notifications
You must be signed in to change notification settings - Fork 20
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support combos #44
Comments
Hi rayduck, Thank you for the interest in the project. I have heard about combos, but never actually tried them myself. I believe that implementing combos in the evaluator/optimizer is, in theory, possible. Having thought about it a little, it will not be that easy however. The current evaluator takes higher layers that are accessed by modifier keys into account. These behave somewhat similar to the combos that you describe as several keys need to be pressed simultaneously. (The difference is that modifiers are usually pressed before and released after the other keys.) For bigrams, this means that both the modifier and the other key are to be considered "consecutive". For instance for typing In the case of combos I believe that something similar would need to be done. With a slight difference that both keys are treated symmetrically (modifiers are treated somewhat special in our code). Now to actually implementing this. The project is still somewhat maintained (in particular by the awesome contributions of @Glitchy-Tozier ). I myself, however, find less and less time to spend on it (my family taking priority), so that I won't be able to carry out the implementations myself. I hope that @Glitchy-Tozier will be able to do so, but as this topic touches some quite technical parts of the code, I would understand if that turns out not feasible. |
I had the same thought!
Unfortunately, I'm not available for similar reasons as @dariogoetz.
We can leave the request up though, for other people who discover this project may be able to implement this functionality. |
Combos are a feature in QMK/ZMK where two or more keys pressed in a small window of time results in a specific output. For example, looking at the "mine" layout on the webapp, a combo may be hitting both G+Y to output ß. The keyboard yml suggests that the total keycost will be 5+14 < 25 and there seems to be room for significant reductions in costs. Another example may be changing an u to ü when combo'd with another key. In my experience, combos never misfire and are easy to press without disrupting the flow (esp. middle and ring finger combos since those fingers like to move together).
I'm not well versed in rust at all, hence I can't comment much about the implementation, but combos seem straight forward as a key with 2+ fingers in 2+ positions. Single finger bigram penalties will then be extended to avoiding bigrams that share the same fingers. I suppose just having all two finger combos as extra key positions will allow the simulated annealing algo to choose which ones they like.
This seems to be the best layout optimizer project that I have found and is actively developed. So it will be great if combos can be incorporated into the layouts!
The text was updated successfully, but these errors were encountered: