What linear sensor for a keyboard? [on hold] The Next CEO of Stack OverflowKeyboard fixingusb keyboard with many simultaneous key pressesHow would I use this 12 key keyboard?Bluetooth keyboard?Hacking USB Keyboard for external keysBest linear position sensor for piston feedbackModern keyboard controllerWhat is this keyboard connector and how to connect it to MCU?Linearizing a 0-10V non linear sensorWhat kind of led would be used for this keyboard

WOW air has ceased operation, can I get my tickets refunded?

Oh, one short ode of love

How should I support this large drywall patch?

A "random" question: usage of "random" as adjective in Spanish

Why does the UK parliament need a vote on the political declaration?

Reduce array of object to totals by property object

Monthly twice production release for my software project

What can we do to stop prior company from asking us questions?

How to subset dataframe based on a "not equal to" criteria applied to a large number of columns?

How do we know the LHC results are robust?

Should I tutor a student who I know has cheated on their homework?

How long to clear the 'suck zone' of a turbofan after start is initiated?

At which OSI layer a user-generated data resides?

Clustering points and summing up attributes per cluster in QGIS

Is it professional to write unrelated content in an almost-emtpy email?

Science fiction short story involving a paper written by a schizophrenic

Return the Closest Prime Number

Why didn't Khan get resurrected in the Genesis Explosion?

Why do remote companies require working in the US?

How do you know when two objects are so called entangled?

Opposite of a diet

On model categories where every object is bifibrant

Help understanding this unsettling image of Titan, Epimetheus, and Saturn's rings?

How to draw dotted circle in Inkscape?



What linear sensor for a keyboard? [on hold]



The Next CEO of Stack OverflowKeyboard fixingusb keyboard with many simultaneous key pressesHow would I use this 12 key keyboard?Bluetooth keyboard?Hacking USB Keyboard for external keysBest linear position sensor for piston feedbackModern keyboard controllerWhat is this keyboard connector and how to connect it to MCU?Linearizing a 0-10V non linear sensorWhat kind of led would be used for this keyboard










8












$begingroup$


I'm trying to make a velocity-sensitive keyboard for playing music.



I have to measure the position of each key in order to know how loud the sound should be.



The volume of the sound is a function of the velocity of the keys at the end of the descent. I know the position can be recovered from the velocity by integrating it.



What would be the cheapest and easiest, yet still reasonably precise way to do it?



I don't know exactly what “reasonably precise” would mean in the context. I'll have to test it.



The length of the maximum displacement is about 2 cm.



EDIT: not as some answers seem to suggest, the loudness is NOT function of the mean velocity of the key.



EDIT2: The loudness is function of the hammer speed at the moment it hits the string, but the key isn't pushing the hammer until the end of its path. It is really like throwing a ball on a wall: the ball leaves the hand at one moment, before it hits the wall.










share|improve this question









New contributor




Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$



put on hold as too broad by Hearth, Dmitry Grigoryev, laptop2d, Brian Carlton, Dave Tweed Mar 26 at 4:38


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.













  • 4




    $begingroup$
    You could use an IR-diode and a photodiode next to each other below the key, the photodiode measuring the reflected light. The lower the postion of the key, the more reflected light reaches the photodiode. Then convert the photocurrent to a voltage using a transimpedance amplifier. You will have to play around to see what voltage or voltage change corresponds to which volume.
    $endgroup$
    – jusaca
    Mar 24 at 13:07










  • $begingroup$
    Have you considered putting an accelerometer on each key? Integrating acceleration gives you velocity, and integrating velocity gives you position. Since you're dealing with short distances & time periods you could probably ignore the accelerometers' small offset errors.
    $endgroup$
    – brhans
    Mar 24 at 13:11






  • 1




    $begingroup$
    @cat I'm familiar with Launchpads and I still have no idea what you are talking about. Can you be a little more helpful?
    $endgroup$
    – Elliot Alderson
    Mar 24 at 14:48






  • 1




    $begingroup$
    Yes I believe you are wrong. Compare a $1 accelerometer to an individual mechanical sensor on each key. Think of the reliability from zero moving parts (assuming you do the interconnects properly). You would need a reasonably capable microcontroller and a little experience writing firmware to pull it off though.
    $endgroup$
    – brhans
    Mar 24 at 18:30






  • 1




    $begingroup$
    @jusaca looks like that's already a product on the market: deskthority.net/wiki/Adomax_Flaretech :)
    $endgroup$
    – user60561
    Mar 24 at 19:46















8












$begingroup$


I'm trying to make a velocity-sensitive keyboard for playing music.



I have to measure the position of each key in order to know how loud the sound should be.



The volume of the sound is a function of the velocity of the keys at the end of the descent. I know the position can be recovered from the velocity by integrating it.



What would be the cheapest and easiest, yet still reasonably precise way to do it?



I don't know exactly what “reasonably precise” would mean in the context. I'll have to test it.



The length of the maximum displacement is about 2 cm.



EDIT: not as some answers seem to suggest, the loudness is NOT function of the mean velocity of the key.



EDIT2: The loudness is function of the hammer speed at the moment it hits the string, but the key isn't pushing the hammer until the end of its path. It is really like throwing a ball on a wall: the ball leaves the hand at one moment, before it hits the wall.










share|improve this question









New contributor




Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$



put on hold as too broad by Hearth, Dmitry Grigoryev, laptop2d, Brian Carlton, Dave Tweed Mar 26 at 4:38


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.













  • 4




    $begingroup$
    You could use an IR-diode and a photodiode next to each other below the key, the photodiode measuring the reflected light. The lower the postion of the key, the more reflected light reaches the photodiode. Then convert the photocurrent to a voltage using a transimpedance amplifier. You will have to play around to see what voltage or voltage change corresponds to which volume.
    $endgroup$
    – jusaca
    Mar 24 at 13:07










  • $begingroup$
    Have you considered putting an accelerometer on each key? Integrating acceleration gives you velocity, and integrating velocity gives you position. Since you're dealing with short distances & time periods you could probably ignore the accelerometers' small offset errors.
    $endgroup$
    – brhans
    Mar 24 at 13:11






  • 1




    $begingroup$
    @cat I'm familiar with Launchpads and I still have no idea what you are talking about. Can you be a little more helpful?
    $endgroup$
    – Elliot Alderson
    Mar 24 at 14:48






  • 1




    $begingroup$
    Yes I believe you are wrong. Compare a $1 accelerometer to an individual mechanical sensor on each key. Think of the reliability from zero moving parts (assuming you do the interconnects properly). You would need a reasonably capable microcontroller and a little experience writing firmware to pull it off though.
    $endgroup$
    – brhans
    Mar 24 at 18:30






  • 1




    $begingroup$
    @jusaca looks like that's already a product on the market: deskthority.net/wiki/Adomax_Flaretech :)
    $endgroup$
    – user60561
    Mar 24 at 19:46













8












8








8





$begingroup$


I'm trying to make a velocity-sensitive keyboard for playing music.



I have to measure the position of each key in order to know how loud the sound should be.



The volume of the sound is a function of the velocity of the keys at the end of the descent. I know the position can be recovered from the velocity by integrating it.



What would be the cheapest and easiest, yet still reasonably precise way to do it?



I don't know exactly what “reasonably precise” would mean in the context. I'll have to test it.



The length of the maximum displacement is about 2 cm.



EDIT: not as some answers seem to suggest, the loudness is NOT function of the mean velocity of the key.



EDIT2: The loudness is function of the hammer speed at the moment it hits the string, but the key isn't pushing the hammer until the end of its path. It is really like throwing a ball on a wall: the ball leaves the hand at one moment, before it hits the wall.










share|improve this question









New contributor




Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$




I'm trying to make a velocity-sensitive keyboard for playing music.



I have to measure the position of each key in order to know how loud the sound should be.



The volume of the sound is a function of the velocity of the keys at the end of the descent. I know the position can be recovered from the velocity by integrating it.



What would be the cheapest and easiest, yet still reasonably precise way to do it?



I don't know exactly what “reasonably precise” would mean in the context. I'll have to test it.



The length of the maximum displacement is about 2 cm.



EDIT: not as some answers seem to suggest, the loudness is NOT function of the mean velocity of the key.



EDIT2: The loudness is function of the hammer speed at the moment it hits the string, but the key isn't pushing the hammer until the end of its path. It is really like throwing a ball on a wall: the ball leaves the hand at one moment, before it hits the wall.







sensor keyboard






share|improve this question









New contributor




Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question









New contributor




Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question








edited Mar 24 at 20:59







Jonas Daverio













New contributor




Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked Mar 24 at 11:20









Jonas DaverioJonas Daverio

847




847




New contributor




Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Jonas Daverio is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.




put on hold as too broad by Hearth, Dmitry Grigoryev, laptop2d, Brian Carlton, Dave Tweed Mar 26 at 4:38


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.









put on hold as too broad by Hearth, Dmitry Grigoryev, laptop2d, Brian Carlton, Dave Tweed Mar 26 at 4:38


Please edit the question to limit it to a specific problem with enough detail to identify an adequate answer. Avoid asking multiple distinct questions at once. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.









  • 4




    $begingroup$
    You could use an IR-diode and a photodiode next to each other below the key, the photodiode measuring the reflected light. The lower the postion of the key, the more reflected light reaches the photodiode. Then convert the photocurrent to a voltage using a transimpedance amplifier. You will have to play around to see what voltage or voltage change corresponds to which volume.
    $endgroup$
    – jusaca
    Mar 24 at 13:07










  • $begingroup$
    Have you considered putting an accelerometer on each key? Integrating acceleration gives you velocity, and integrating velocity gives you position. Since you're dealing with short distances & time periods you could probably ignore the accelerometers' small offset errors.
    $endgroup$
    – brhans
    Mar 24 at 13:11






  • 1




    $begingroup$
    @cat I'm familiar with Launchpads and I still have no idea what you are talking about. Can you be a little more helpful?
    $endgroup$
    – Elliot Alderson
    Mar 24 at 14:48






  • 1




    $begingroup$
    Yes I believe you are wrong. Compare a $1 accelerometer to an individual mechanical sensor on each key. Think of the reliability from zero moving parts (assuming you do the interconnects properly). You would need a reasonably capable microcontroller and a little experience writing firmware to pull it off though.
    $endgroup$
    – brhans
    Mar 24 at 18:30






  • 1




    $begingroup$
    @jusaca looks like that's already a product on the market: deskthority.net/wiki/Adomax_Flaretech :)
    $endgroup$
    – user60561
    Mar 24 at 19:46












  • 4




    $begingroup$
    You could use an IR-diode and a photodiode next to each other below the key, the photodiode measuring the reflected light. The lower the postion of the key, the more reflected light reaches the photodiode. Then convert the photocurrent to a voltage using a transimpedance amplifier. You will have to play around to see what voltage or voltage change corresponds to which volume.
    $endgroup$
    – jusaca
    Mar 24 at 13:07










  • $begingroup$
    Have you considered putting an accelerometer on each key? Integrating acceleration gives you velocity, and integrating velocity gives you position. Since you're dealing with short distances & time periods you could probably ignore the accelerometers' small offset errors.
    $endgroup$
    – brhans
    Mar 24 at 13:11






  • 1




    $begingroup$
    @cat I'm familiar with Launchpads and I still have no idea what you are talking about. Can you be a little more helpful?
    $endgroup$
    – Elliot Alderson
    Mar 24 at 14:48






  • 1




    $begingroup$
    Yes I believe you are wrong. Compare a $1 accelerometer to an individual mechanical sensor on each key. Think of the reliability from zero moving parts (assuming you do the interconnects properly). You would need a reasonably capable microcontroller and a little experience writing firmware to pull it off though.
    $endgroup$
    – brhans
    Mar 24 at 18:30






  • 1




    $begingroup$
    @jusaca looks like that's already a product on the market: deskthority.net/wiki/Adomax_Flaretech :)
    $endgroup$
    – user60561
    Mar 24 at 19:46







4




4




$begingroup$
You could use an IR-diode and a photodiode next to each other below the key, the photodiode measuring the reflected light. The lower the postion of the key, the more reflected light reaches the photodiode. Then convert the photocurrent to a voltage using a transimpedance amplifier. You will have to play around to see what voltage or voltage change corresponds to which volume.
$endgroup$
– jusaca
Mar 24 at 13:07




$begingroup$
You could use an IR-diode and a photodiode next to each other below the key, the photodiode measuring the reflected light. The lower the postion of the key, the more reflected light reaches the photodiode. Then convert the photocurrent to a voltage using a transimpedance amplifier. You will have to play around to see what voltage or voltage change corresponds to which volume.
$endgroup$
– jusaca
Mar 24 at 13:07












$begingroup$
Have you considered putting an accelerometer on each key? Integrating acceleration gives you velocity, and integrating velocity gives you position. Since you're dealing with short distances & time periods you could probably ignore the accelerometers' small offset errors.
$endgroup$
– brhans
Mar 24 at 13:11




$begingroup$
Have you considered putting an accelerometer on each key? Integrating acceleration gives you velocity, and integrating velocity gives you position. Since you're dealing with short distances & time periods you could probably ignore the accelerometers' small offset errors.
$endgroup$
– brhans
Mar 24 at 13:11




1




1




$begingroup$
@cat I'm familiar with Launchpads and I still have no idea what you are talking about. Can you be a little more helpful?
$endgroup$
– Elliot Alderson
Mar 24 at 14:48




$begingroup$
@cat I'm familiar with Launchpads and I still have no idea what you are talking about. Can you be a little more helpful?
$endgroup$
– Elliot Alderson
Mar 24 at 14:48




1




1




$begingroup$
Yes I believe you are wrong. Compare a $1 accelerometer to an individual mechanical sensor on each key. Think of the reliability from zero moving parts (assuming you do the interconnects properly). You would need a reasonably capable microcontroller and a little experience writing firmware to pull it off though.
$endgroup$
– brhans
Mar 24 at 18:30




$begingroup$
Yes I believe you are wrong. Compare a $1 accelerometer to an individual mechanical sensor on each key. Think of the reliability from zero moving parts (assuming you do the interconnects properly). You would need a reasonably capable microcontroller and a little experience writing firmware to pull it off though.
$endgroup$
– brhans
Mar 24 at 18:30




1




1




$begingroup$
@jusaca looks like that's already a product on the market: deskthority.net/wiki/Adomax_Flaretech :)
$endgroup$
– user60561
Mar 24 at 19:46




$begingroup$
@jusaca looks like that's already a product on the market: deskthority.net/wiki/Adomax_Flaretech :)
$endgroup$
– user60561
Mar 24 at 19:46










9 Answers
9






active

oldest

votes


















2












$begingroup$

How about capacitive sensing? Tape some aluminum foil to the bottom of the key, ground the bottom of the keyboard, and measure the rise time through a 100k resistor.



This method can be made almost arbitrarily precise, as long as your processor is fast enough to discriminate the change in capacitance.



I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.






share|improve this answer











$endgroup$












  • $begingroup$
    So, I would have to pass AC in it, wouldn't I?
    $endgroup$
    – Jonas Daverio
    Mar 24 at 23:53






  • 1




    $begingroup$
    @JonasDaverio I'm not sure what you're connecting the keys to, but one GPIO per key would suffice.
    $endgroup$
    – 0xDBFB7
    Mar 25 at 1:19










  • $begingroup$
    I'm not sure how I am supposed to measure the capacitance. One plate is connected to ground and the other is connected to what? A constant voltage source?
    $endgroup$
    – Jonas Daverio
    Mar 25 at 11:29






  • 1




    $begingroup$
    The Teensy LC microcontroller[1] has 11 capacitive sensing inputs and a C++ library that makes it as easy as calling analogRead in Arduino. [1]: pjrc.com/teensy/teensyLC.html
    $endgroup$
    – hoosierEE
    Mar 25 at 14:12






  • 1




    $begingroup$
    @JonasDaverio sorry, I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.
    $endgroup$
    – 0xDBFB7
    Mar 25 at 14:50


















15












$begingroup$

Most keyboards simply use two contacts per key, configured so that they close (or open) at different positions in the key's travel. They estimate velocity from the time that elapses between the two events. Even the fancy weighted "piano action" keyboards use this basic sensing method.



Trying to measure position and/or velocity directly sounds like massive overkill.






share|improve this answer









$endgroup$








  • 3




    $begingroup$
    I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.
    $endgroup$
    – Jonas Daverio
    Mar 24 at 17:26







  • 9




    $begingroup$
    If one contact was at the bottom and the other contact was very near the bottom, you would not have this problem.
    $endgroup$
    – George White
    Mar 24 at 17:40






  • 1




    $begingroup$
    Every real instrument has its nuances and limitations. Musicians develop techniques to exploit these for musical effect. The player will soon learn to carry through to the bottom of stroke to get the desired effect.
    $endgroup$
    – Transistor
    Mar 24 at 21:07






  • 1




    $begingroup$
    @Transistor Yes, indeed, but my goal here is to try to simulate as close as possible a real piano. There are already plenty of keyboards available, but I never found one that did that. There are probably some really expensive one, though.
    $endgroup$
    – Jonas Daverio
    Mar 24 at 21:46






  • 1




    $begingroup$
    The point would be to have a midi output and the possibility to have more keys (for microtonality) while keeping all the sensation of a real piano. I know this will never be reached anyway. And I also want to keep it relatively cheap, but if I can't, I'll stick on the regular solution.
    $endgroup$
    – Jonas Daverio
    Mar 24 at 22:59


















9












$begingroup$


I have to measure the position of each key in order to know how loud the sound should be.




Normally key velocity is calculated by measuring the time between the normally closed up-switch breaking and the normally open down-switch making.





schematic





simulate this circuit – Schematic created using CircuitLab



Figure 1. A break-before-make keyboard contact is typically used for velocity measurement.




The volume of the sound is not only function of the velocity of the keys at the end of the descent. ...
The length of the maximum displacement is about 2 cm.




In this case you need to mechanically arrange the normally closed contact so that it breaks in the last few mm of travel.





schematic





simulate this circuit



Figure 2. The mechanical switching arrangement.



It seems to me that your best bet would be to modify an existing MIDI bass pedalboard to suit your purposes.




OP's comment to Dave Tweed:




I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.




That is why I proposed activating the changeover switch in the last few mm of travel.






share|improve this answer











$endgroup$












  • $begingroup$
    I responded back for why I think this is still insufficient.
    $endgroup$
    – Jonas Daverio
    Mar 24 at 20:55










  • $begingroup$
    I think you misread what I wrote. I meant "The volume of the sound is NOT only function of the velocity of the keys at the end of the descent."
    $endgroup$
    – Jonas Daverio
    Mar 24 at 21:48










  • $begingroup$
    Indeed, the energy depends on the speed over the time-length of the impact, which is a function of acceleration (and the jerk, if you don't assume constant acceleration). However, are sure that makes much of a difference? Can you characterize the specifics that you have or are looking for? I don't know what that would be. It might depend on the effect that it's supposed to have on the algorithm.
    $endgroup$
    – vectory
    Mar 25 at 22:39











  • $begingroup$
    @JonasDaverio Are you referring to escapement? Digital pianos accomplish this with a third sensor that fires slightly above where the key bottoms out (and above the sensor that sounds the note). If the key does not go high enough to release this 3rd sensor, then bottoming out the key will not sound a second note, just like a real piano does not release the hammer unless the key is raised high enough.
    $endgroup$
    – Toor
    Mar 25 at 23:45


















8












$begingroup$

You should take a look at analog keyboards. Take a look at this video. This is just an example of concept.



Edit:
Also, if optical switches are not working for you, take a look at this:



enter image description here



There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.



Source:
Reddit
Imgur






share|improve this answer










New contributor




Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






$endgroup$












  • $begingroup$
    Apparently, they use a pair of IR-LED and photosensor: blog.wooting.nl/flaretech-the-optical-keyboard-switch However, I'm not sure wether they measure the delay between the emission and the detection or wether they measure the intensity of the light that could make through the tunnel.
    $endgroup$
    – Jonas Daverio
    Mar 25 at 10:46











  • $begingroup$
    I linked that just for the example of analog keyboard. You can take a look at reddit.com/r/MechanicalKeyboards/comments/9ii6gw/… and imgur.com/gallery/ImrH7nO . I'am not too familiar with the subject, just trying to help to push you into right direction :)
    $endgroup$
    – Matt
    Mar 25 at 11:12






  • 1




    $begingroup$
    While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes. - From Review
    $endgroup$
    – Blair Fonville
    Mar 25 at 11:22






  • 1




    $begingroup$
    @BlairFonville Fair enough. Let me summarize it. There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.
    $endgroup$
    – Matt
    Mar 25 at 12:12


















7












$begingroup$

If the important variable is the impact of a "hammer" that you're trying to emulate, consider piezo sensors which allow you to measure this directly. They produce a pulse whose amplitude depends on the impact impulse.






share|improve this answer









$endgroup$




















    3












    $begingroup$

    One option could be Hall sensors, which sense the strength of a magnetic field. There are different types of Hall sensors for digital and analog sensing, you need one that has analog. For example SI7211 costs about 0.80 USD.



    You also need a small magnet underneath each key. When the magnet gets closer to the sensor, the magnetic field increases which increases the sensor's output voltage.






    share|improve this answer









    $endgroup$








    • 1




      $begingroup$
      Apparently, they use it on some music keyboards. I think this is a really simple and good solution. I will compare the costs with 0xDBFB7's solution.
      $endgroup$
      – Jonas Daverio
      Mar 25 at 16:46


















    2












    $begingroup$

    You can treat this as a hybrid digital/analog instrument by placing microphones[1] inside the keyboard, tuned to the sound of striking the keys. Signals from the microphones augment the traditional switch-based input, so the switch tells you which key is pressed, and the microphones tell you how loud the most recent keypress was.



    2 or more microphones along the keyboard's length would permit decoding a chord with loud/low notes and soft/high notes and vice versa.



    [1]: I keep saying "microphone", but I mean "generic vibration sensing device".






    share|improve this answer









    $endgroup$












    • $begingroup$
      That's pretty much how an E-Guitar works, I guess. However, the question didn't mention any acoustic parts, just keys.
      $endgroup$
      – vectory
      Mar 25 at 22:32


















    0












    $begingroup$

    You may want to research spring return variable resistors, spring return potentiometers, or linear position sensors. Here is one example:
    http://ecatalog.beisensors.com/item/linear-position-sensors/linear-position-sensor-9600-series-compact-spri/9610r3-4kl2-0



    Another possibility may be to use a small rotary encoder (and mechanically convert the linear key press motion to rotary motion). The encoder would output one or more sets of pulses as the shaft rotates. A higher pulse rate would indicate a higher velocity press. The encoder position could be tracked directly if the pulse groups are sent to additional digital logic. Here's an example part: https://www.mouser.com/ProductDetail/Bourns/PEC16-4220F-S0024?qs=6FD5PBp7ZtQte%252Bg7b%2FiMUw%3D%3D&gclid=EAIaIQobChMIrKbIjOSa4QIVCEsNCh3JAAKuEAQYAyABEgKM_fD_BwE






    share|improve this answer











    $endgroup$




















      0












      $begingroup$

      If you want super-accuracy at a reasonable price, how about using a linear encoder, attaching a Gray-coded strip (which you print yourself using a laser printer onto a transparent sheet, then cut up and attach one to each key) - more details of how they work under rotary encoders here. This way you need two (perhaps 3 so you get an accurate indication of end position) digital lines per key. This will allow you to measure velocity with very good accuracy and even position if that's relevant. The advantage of this is you could retrofit it to an old keyboard (even an acoustic keyboard).



      Caution: when I was a teenager (a long while ago) I wondered for ages whether I could make a realistic keyboard more cheaply than buying them. It seemed unlikely then and it seems even less likely now. The cost effective method is therefore probably "buy a velocity sensitive keyboard and take it apart" which is no fun.






      share|improve this answer









      $endgroup$








      • 1




        $begingroup$
        Yes, I'm not pretending this will end up cheaper than a commercial one, but I'm trying to construct a special arrangement of keys that doesn't exist on the market. For your answer, I'm not really sure what you mean. Do you mean making a linear encoder from scratch? I don't understand what's the point of the transparent strip. And 3 bits seems a bit low to encode precisely the position and to deduce the velocity from it.
        $endgroup$
        – Jonas Daverio
        Mar 25 at 10:56











      • $begingroup$
        A linear encoder will give you velocity with 2 bits only (see links) to a great resolution (you could get position to 256ths of the travel distance very easily). By timing the period between grey code bit transitions you will get a very accurate picture of velocity at different stages of travel of the key. 3rd bit gives you accurate 'hammer hits strings' signal. I was suggesting you use a linear encoder optical reader with your own 'tape' - transparent strip.
        $endgroup$
        – abligh
        Mar 25 at 22:29


















      9 Answers
      9






      active

      oldest

      votes








      9 Answers
      9






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      2












      $begingroup$

      How about capacitive sensing? Tape some aluminum foil to the bottom of the key, ground the bottom of the keyboard, and measure the rise time through a 100k resistor.



      This method can be made almost arbitrarily precise, as long as your processor is fast enough to discriminate the change in capacitance.



      I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.






      share|improve this answer











      $endgroup$












      • $begingroup$
        So, I would have to pass AC in it, wouldn't I?
        $endgroup$
        – Jonas Daverio
        Mar 24 at 23:53






      • 1




        $begingroup$
        @JonasDaverio I'm not sure what you're connecting the keys to, but one GPIO per key would suffice.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 1:19










      • $begingroup$
        I'm not sure how I am supposed to measure the capacitance. One plate is connected to ground and the other is connected to what? A constant voltage source?
        $endgroup$
        – Jonas Daverio
        Mar 25 at 11:29






      • 1




        $begingroup$
        The Teensy LC microcontroller[1] has 11 capacitive sensing inputs and a C++ library that makes it as easy as calling analogRead in Arduino. [1]: pjrc.com/teensy/teensyLC.html
        $endgroup$
        – hoosierEE
        Mar 25 at 14:12






      • 1




        $begingroup$
        @JonasDaverio sorry, I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 14:50















      2












      $begingroup$

      How about capacitive sensing? Tape some aluminum foil to the bottom of the key, ground the bottom of the keyboard, and measure the rise time through a 100k resistor.



      This method can be made almost arbitrarily precise, as long as your processor is fast enough to discriminate the change in capacitance.



      I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.






      share|improve this answer











      $endgroup$












      • $begingroup$
        So, I would have to pass AC in it, wouldn't I?
        $endgroup$
        – Jonas Daverio
        Mar 24 at 23:53






      • 1




        $begingroup$
        @JonasDaverio I'm not sure what you're connecting the keys to, but one GPIO per key would suffice.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 1:19










      • $begingroup$
        I'm not sure how I am supposed to measure the capacitance. One plate is connected to ground and the other is connected to what? A constant voltage source?
        $endgroup$
        – Jonas Daverio
        Mar 25 at 11:29






      • 1




        $begingroup$
        The Teensy LC microcontroller[1] has 11 capacitive sensing inputs and a C++ library that makes it as easy as calling analogRead in Arduino. [1]: pjrc.com/teensy/teensyLC.html
        $endgroup$
        – hoosierEE
        Mar 25 at 14:12






      • 1




        $begingroup$
        @JonasDaverio sorry, I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 14:50













      2












      2








      2





      $begingroup$

      How about capacitive sensing? Tape some aluminum foil to the bottom of the key, ground the bottom of the keyboard, and measure the rise time through a 100k resistor.



      This method can be made almost arbitrarily precise, as long as your processor is fast enough to discriminate the change in capacitance.



      I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.






      share|improve this answer











      $endgroup$



      How about capacitive sensing? Tape some aluminum foil to the bottom of the key, ground the bottom of the keyboard, and measure the rise time through a 100k resistor.



      This method can be made almost arbitrarily precise, as long as your processor is fast enough to discriminate the change in capacitance.



      I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.







      share|improve this answer














      share|improve this answer



      share|improve this answer








      edited Mar 26 at 4:20









      George White

      34727




      34727










      answered Mar 24 at 23:32









      0xDBFB70xDBFB7

      566517




      566517











      • $begingroup$
        So, I would have to pass AC in it, wouldn't I?
        $endgroup$
        – Jonas Daverio
        Mar 24 at 23:53






      • 1




        $begingroup$
        @JonasDaverio I'm not sure what you're connecting the keys to, but one GPIO per key would suffice.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 1:19










      • $begingroup$
        I'm not sure how I am supposed to measure the capacitance. One plate is connected to ground and the other is connected to what? A constant voltage source?
        $endgroup$
        – Jonas Daverio
        Mar 25 at 11:29






      • 1




        $begingroup$
        The Teensy LC microcontroller[1] has 11 capacitive sensing inputs and a C++ library that makes it as easy as calling analogRead in Arduino. [1]: pjrc.com/teensy/teensyLC.html
        $endgroup$
        – hoosierEE
        Mar 25 at 14:12






      • 1




        $begingroup$
        @JonasDaverio sorry, I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 14:50
















      • $begingroup$
        So, I would have to pass AC in it, wouldn't I?
        $endgroup$
        – Jonas Daverio
        Mar 24 at 23:53






      • 1




        $begingroup$
        @JonasDaverio I'm not sure what you're connecting the keys to, but one GPIO per key would suffice.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 1:19










      • $begingroup$
        I'm not sure how I am supposed to measure the capacitance. One plate is connected to ground and the other is connected to what? A constant voltage source?
        $endgroup$
        – Jonas Daverio
        Mar 25 at 11:29






      • 1




        $begingroup$
        The Teensy LC microcontroller[1] has 11 capacitive sensing inputs and a C++ library that makes it as easy as calling analogRead in Arduino. [1]: pjrc.com/teensy/teensyLC.html
        $endgroup$
        – hoosierEE
        Mar 25 at 14:12






      • 1




        $begingroup$
        @JonasDaverio sorry, I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.
        $endgroup$
        – 0xDBFB7
        Mar 25 at 14:50















      $begingroup$
      So, I would have to pass AC in it, wouldn't I?
      $endgroup$
      – Jonas Daverio
      Mar 24 at 23:53




      $begingroup$
      So, I would have to pass AC in it, wouldn't I?
      $endgroup$
      – Jonas Daverio
      Mar 24 at 23:53




      1




      1




      $begingroup$
      @JonasDaverio I'm not sure what you're connecting the keys to, but one GPIO per key would suffice.
      $endgroup$
      – 0xDBFB7
      Mar 25 at 1:19




      $begingroup$
      @JonasDaverio I'm not sure what you're connecting the keys to, but one GPIO per key would suffice.
      $endgroup$
      – 0xDBFB7
      Mar 25 at 1:19












      $begingroup$
      I'm not sure how I am supposed to measure the capacitance. One plate is connected to ground and the other is connected to what? A constant voltage source?
      $endgroup$
      – Jonas Daverio
      Mar 25 at 11:29




      $begingroup$
      I'm not sure how I am supposed to measure the capacitance. One plate is connected to ground and the other is connected to what? A constant voltage source?
      $endgroup$
      – Jonas Daverio
      Mar 25 at 11:29




      1




      1




      $begingroup$
      The Teensy LC microcontroller[1] has 11 capacitive sensing inputs and a C++ library that makes it as easy as calling analogRead in Arduino. [1]: pjrc.com/teensy/teensyLC.html
      $endgroup$
      – hoosierEE
      Mar 25 at 14:12




      $begingroup$
      The Teensy LC microcontroller[1] has 11 capacitive sensing inputs and a C++ library that makes it as easy as calling analogRead in Arduino. [1]: pjrc.com/teensy/teensyLC.html
      $endgroup$
      – hoosierEE
      Mar 25 at 14:12




      1




      1




      $begingroup$
      @JonasDaverio sorry, I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.
      $endgroup$
      – 0xDBFB7
      Mar 25 at 14:50




      $begingroup$
      @JonasDaverio sorry, I didn't explain the circuit very well. You connect a digital output to the key via a high value resistor, set it low to discharge any stray charge, and then set it high. You also connect a digital input directly to the key. The capacitance will slowly charge through the resistor, and you time how long it takes before the digital input turns on. This time is equal to the RC time constant of the circuit.
      $endgroup$
      – 0xDBFB7
      Mar 25 at 14:50













      15












      $begingroup$

      Most keyboards simply use two contacts per key, configured so that they close (or open) at different positions in the key's travel. They estimate velocity from the time that elapses between the two events. Even the fancy weighted "piano action" keyboards use this basic sensing method.



      Trying to measure position and/or velocity directly sounds like massive overkill.






      share|improve this answer









      $endgroup$








      • 3




        $begingroup$
        I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 17:26







      • 9




        $begingroup$
        If one contact was at the bottom and the other contact was very near the bottom, you would not have this problem.
        $endgroup$
        – George White
        Mar 24 at 17:40






      • 1




        $begingroup$
        Every real instrument has its nuances and limitations. Musicians develop techniques to exploit these for musical effect. The player will soon learn to carry through to the bottom of stroke to get the desired effect.
        $endgroup$
        – Transistor
        Mar 24 at 21:07






      • 1




        $begingroup$
        @Transistor Yes, indeed, but my goal here is to try to simulate as close as possible a real piano. There are already plenty of keyboards available, but I never found one that did that. There are probably some really expensive one, though.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:46






      • 1




        $begingroup$
        The point would be to have a midi output and the possibility to have more keys (for microtonality) while keeping all the sensation of a real piano. I know this will never be reached anyway. And I also want to keep it relatively cheap, but if I can't, I'll stick on the regular solution.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 22:59















      15












      $begingroup$

      Most keyboards simply use two contacts per key, configured so that they close (or open) at different positions in the key's travel. They estimate velocity from the time that elapses between the two events. Even the fancy weighted "piano action" keyboards use this basic sensing method.



      Trying to measure position and/or velocity directly sounds like massive overkill.






      share|improve this answer









      $endgroup$








      • 3




        $begingroup$
        I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 17:26







      • 9




        $begingroup$
        If one contact was at the bottom and the other contact was very near the bottom, you would not have this problem.
        $endgroup$
        – George White
        Mar 24 at 17:40






      • 1




        $begingroup$
        Every real instrument has its nuances and limitations. Musicians develop techniques to exploit these for musical effect. The player will soon learn to carry through to the bottom of stroke to get the desired effect.
        $endgroup$
        – Transistor
        Mar 24 at 21:07






      • 1




        $begingroup$
        @Transistor Yes, indeed, but my goal here is to try to simulate as close as possible a real piano. There are already plenty of keyboards available, but I never found one that did that. There are probably some really expensive one, though.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:46






      • 1




        $begingroup$
        The point would be to have a midi output and the possibility to have more keys (for microtonality) while keeping all the sensation of a real piano. I know this will never be reached anyway. And I also want to keep it relatively cheap, but if I can't, I'll stick on the regular solution.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 22:59













      15












      15








      15





      $begingroup$

      Most keyboards simply use two contacts per key, configured so that they close (or open) at different positions in the key's travel. They estimate velocity from the time that elapses between the two events. Even the fancy weighted "piano action" keyboards use this basic sensing method.



      Trying to measure position and/or velocity directly sounds like massive overkill.






      share|improve this answer









      $endgroup$



      Most keyboards simply use two contacts per key, configured so that they close (or open) at different positions in the key's travel. They estimate velocity from the time that elapses between the two events. Even the fancy weighted "piano action" keyboards use this basic sensing method.



      Trying to measure position and/or velocity directly sounds like massive overkill.







      share|improve this answer












      share|improve this answer



      share|improve this answer










      answered Mar 24 at 13:37









      Dave TweedDave Tweed

      122k9152265




      122k9152265







      • 3




        $begingroup$
        I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 17:26







      • 9




        $begingroup$
        If one contact was at the bottom and the other contact was very near the bottom, you would not have this problem.
        $endgroup$
        – George White
        Mar 24 at 17:40






      • 1




        $begingroup$
        Every real instrument has its nuances and limitations. Musicians develop techniques to exploit these for musical effect. The player will soon learn to carry through to the bottom of stroke to get the desired effect.
        $endgroup$
        – Transistor
        Mar 24 at 21:07






      • 1




        $begingroup$
        @Transistor Yes, indeed, but my goal here is to try to simulate as close as possible a real piano. There are already plenty of keyboards available, but I never found one that did that. There are probably some really expensive one, though.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:46






      • 1




        $begingroup$
        The point would be to have a midi output and the possibility to have more keys (for microtonality) while keeping all the sensation of a real piano. I know this will never be reached anyway. And I also want to keep it relatively cheap, but if I can't, I'll stick on the regular solution.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 22:59












      • 3




        $begingroup$
        I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 17:26







      • 9




        $begingroup$
        If one contact was at the bottom and the other contact was very near the bottom, you would not have this problem.
        $endgroup$
        – George White
        Mar 24 at 17:40






      • 1




        $begingroup$
        Every real instrument has its nuances and limitations. Musicians develop techniques to exploit these for musical effect. The player will soon learn to carry through to the bottom of stroke to get the desired effect.
        $endgroup$
        – Transistor
        Mar 24 at 21:07






      • 1




        $begingroup$
        @Transistor Yes, indeed, but my goal here is to try to simulate as close as possible a real piano. There are already plenty of keyboards available, but I never found one that did that. There are probably some really expensive one, though.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:46






      • 1




        $begingroup$
        The point would be to have a midi output and the possibility to have more keys (for microtonality) while keeping all the sensation of a real piano. I know this will never be reached anyway. And I also want to keep it relatively cheap, but if I can't, I'll stick on the regular solution.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 22:59







      3




      3




      $begingroup$
      I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 17:26





      $begingroup$
      I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 17:26





      9




      9




      $begingroup$
      If one contact was at the bottom and the other contact was very near the bottom, you would not have this problem.
      $endgroup$
      – George White
      Mar 24 at 17:40




      $begingroup$
      If one contact was at the bottom and the other contact was very near the bottom, you would not have this problem.
      $endgroup$
      – George White
      Mar 24 at 17:40




      1




      1




      $begingroup$
      Every real instrument has its nuances and limitations. Musicians develop techniques to exploit these for musical effect. The player will soon learn to carry through to the bottom of stroke to get the desired effect.
      $endgroup$
      – Transistor
      Mar 24 at 21:07




      $begingroup$
      Every real instrument has its nuances and limitations. Musicians develop techniques to exploit these for musical effect. The player will soon learn to carry through to the bottom of stroke to get the desired effect.
      $endgroup$
      – Transistor
      Mar 24 at 21:07




      1




      1




      $begingroup$
      @Transistor Yes, indeed, but my goal here is to try to simulate as close as possible a real piano. There are already plenty of keyboards available, but I never found one that did that. There are probably some really expensive one, though.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 21:46




      $begingroup$
      @Transistor Yes, indeed, but my goal here is to try to simulate as close as possible a real piano. There are already plenty of keyboards available, but I never found one that did that. There are probably some really expensive one, though.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 21:46




      1




      1




      $begingroup$
      The point would be to have a midi output and the possibility to have more keys (for microtonality) while keeping all the sensation of a real piano. I know this will never be reached anyway. And I also want to keep it relatively cheap, but if I can't, I'll stick on the regular solution.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 22:59




      $begingroup$
      The point would be to have a midi output and the possibility to have more keys (for microtonality) while keeping all the sensation of a real piano. I know this will never be reached anyway. And I also want to keep it relatively cheap, but if I can't, I'll stick on the regular solution.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 22:59











      9












      $begingroup$


      I have to measure the position of each key in order to know how loud the sound should be.




      Normally key velocity is calculated by measuring the time between the normally closed up-switch breaking and the normally open down-switch making.





      schematic





      simulate this circuit – Schematic created using CircuitLab



      Figure 1. A break-before-make keyboard contact is typically used for velocity measurement.




      The volume of the sound is not only function of the velocity of the keys at the end of the descent. ...
      The length of the maximum displacement is about 2 cm.




      In this case you need to mechanically arrange the normally closed contact so that it breaks in the last few mm of travel.





      schematic





      simulate this circuit



      Figure 2. The mechanical switching arrangement.



      It seems to me that your best bet would be to modify an existing MIDI bass pedalboard to suit your purposes.




      OP's comment to Dave Tweed:




      I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.




      That is why I proposed activating the changeover switch in the last few mm of travel.






      share|improve this answer











      $endgroup$












      • $begingroup$
        I responded back for why I think this is still insufficient.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 20:55










      • $begingroup$
        I think you misread what I wrote. I meant "The volume of the sound is NOT only function of the velocity of the keys at the end of the descent."
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:48










      • $begingroup$
        Indeed, the energy depends on the speed over the time-length of the impact, which is a function of acceleration (and the jerk, if you don't assume constant acceleration). However, are sure that makes much of a difference? Can you characterize the specifics that you have or are looking for? I don't know what that would be. It might depend on the effect that it's supposed to have on the algorithm.
        $endgroup$
        – vectory
        Mar 25 at 22:39











      • $begingroup$
        @JonasDaverio Are you referring to escapement? Digital pianos accomplish this with a third sensor that fires slightly above where the key bottoms out (and above the sensor that sounds the note). If the key does not go high enough to release this 3rd sensor, then bottoming out the key will not sound a second note, just like a real piano does not release the hammer unless the key is raised high enough.
        $endgroup$
        – Toor
        Mar 25 at 23:45















      9












      $begingroup$


      I have to measure the position of each key in order to know how loud the sound should be.




      Normally key velocity is calculated by measuring the time between the normally closed up-switch breaking and the normally open down-switch making.





      schematic





      simulate this circuit – Schematic created using CircuitLab



      Figure 1. A break-before-make keyboard contact is typically used for velocity measurement.




      The volume of the sound is not only function of the velocity of the keys at the end of the descent. ...
      The length of the maximum displacement is about 2 cm.




      In this case you need to mechanically arrange the normally closed contact so that it breaks in the last few mm of travel.





      schematic





      simulate this circuit



      Figure 2. The mechanical switching arrangement.



      It seems to me that your best bet would be to modify an existing MIDI bass pedalboard to suit your purposes.




      OP's comment to Dave Tweed:




      I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.




      That is why I proposed activating the changeover switch in the last few mm of travel.






      share|improve this answer











      $endgroup$












      • $begingroup$
        I responded back for why I think this is still insufficient.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 20:55










      • $begingroup$
        I think you misread what I wrote. I meant "The volume of the sound is NOT only function of the velocity of the keys at the end of the descent."
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:48










      • $begingroup$
        Indeed, the energy depends on the speed over the time-length of the impact, which is a function of acceleration (and the jerk, if you don't assume constant acceleration). However, are sure that makes much of a difference? Can you characterize the specifics that you have or are looking for? I don't know what that would be. It might depend on the effect that it's supposed to have on the algorithm.
        $endgroup$
        – vectory
        Mar 25 at 22:39











      • $begingroup$
        @JonasDaverio Are you referring to escapement? Digital pianos accomplish this with a third sensor that fires slightly above where the key bottoms out (and above the sensor that sounds the note). If the key does not go high enough to release this 3rd sensor, then bottoming out the key will not sound a second note, just like a real piano does not release the hammer unless the key is raised high enough.
        $endgroup$
        – Toor
        Mar 25 at 23:45













      9












      9








      9





      $begingroup$


      I have to measure the position of each key in order to know how loud the sound should be.




      Normally key velocity is calculated by measuring the time between the normally closed up-switch breaking and the normally open down-switch making.





      schematic





      simulate this circuit – Schematic created using CircuitLab



      Figure 1. A break-before-make keyboard contact is typically used for velocity measurement.




      The volume of the sound is not only function of the velocity of the keys at the end of the descent. ...
      The length of the maximum displacement is about 2 cm.




      In this case you need to mechanically arrange the normally closed contact so that it breaks in the last few mm of travel.





      schematic





      simulate this circuit



      Figure 2. The mechanical switching arrangement.



      It seems to me that your best bet would be to modify an existing MIDI bass pedalboard to suit your purposes.




      OP's comment to Dave Tweed:




      I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.




      That is why I proposed activating the changeover switch in the last few mm of travel.






      share|improve this answer











      $endgroup$




      I have to measure the position of each key in order to know how loud the sound should be.




      Normally key velocity is calculated by measuring the time between the normally closed up-switch breaking and the normally open down-switch making.





      schematic





      simulate this circuit – Schematic created using CircuitLab



      Figure 1. A break-before-make keyboard contact is typically used for velocity measurement.




      The volume of the sound is not only function of the velocity of the keys at the end of the descent. ...
      The length of the maximum displacement is about 2 cm.




      In this case you need to mechanically arrange the normally closed contact so that it breaks in the last few mm of travel.





      schematic





      simulate this circuit



      Figure 2. The mechanical switching arrangement.



      It seems to me that your best bet would be to modify an existing MIDI bass pedalboard to suit your purposes.




      OP's comment to Dave Tweed:




      I think this method is insufficient. Here's why: if I slowly push the key down half of the path, and then quickly push it down to the end, the sound would be loud on a real piano, and this method would think the key was pushed really slowly and therefore output a really quiet sound. In addition, if I want to repeat a note, I would have to let the key completely return to its original position, which is not at all what I would do on a real piano.




      That is why I proposed activating the changeover switch in the last few mm of travel.







      share|improve this answer














      share|improve this answer



      share|improve this answer








      edited Mar 24 at 18:02

























      answered Mar 24 at 13:36









      TransistorTransistor

      87.5k785189




      87.5k785189











      • $begingroup$
        I responded back for why I think this is still insufficient.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 20:55










      • $begingroup$
        I think you misread what I wrote. I meant "The volume of the sound is NOT only function of the velocity of the keys at the end of the descent."
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:48










      • $begingroup$
        Indeed, the energy depends on the speed over the time-length of the impact, which is a function of acceleration (and the jerk, if you don't assume constant acceleration). However, are sure that makes much of a difference? Can you characterize the specifics that you have or are looking for? I don't know what that would be. It might depend on the effect that it's supposed to have on the algorithm.
        $endgroup$
        – vectory
        Mar 25 at 22:39











      • $begingroup$
        @JonasDaverio Are you referring to escapement? Digital pianos accomplish this with a third sensor that fires slightly above where the key bottoms out (and above the sensor that sounds the note). If the key does not go high enough to release this 3rd sensor, then bottoming out the key will not sound a second note, just like a real piano does not release the hammer unless the key is raised high enough.
        $endgroup$
        – Toor
        Mar 25 at 23:45
















      • $begingroup$
        I responded back for why I think this is still insufficient.
        $endgroup$
        – Jonas Daverio
        Mar 24 at 20:55










      • $begingroup$
        I think you misread what I wrote. I meant "The volume of the sound is NOT only function of the velocity of the keys at the end of the descent."
        $endgroup$
        – Jonas Daverio
        Mar 24 at 21:48










      • $begingroup$
        Indeed, the energy depends on the speed over the time-length of the impact, which is a function of acceleration (and the jerk, if you don't assume constant acceleration). However, are sure that makes much of a difference? Can you characterize the specifics that you have or are looking for? I don't know what that would be. It might depend on the effect that it's supposed to have on the algorithm.
        $endgroup$
        – vectory
        Mar 25 at 22:39











      • $begingroup$
        @JonasDaverio Are you referring to escapement? Digital pianos accomplish this with a third sensor that fires slightly above where the key bottoms out (and above the sensor that sounds the note). If the key does not go high enough to release this 3rd sensor, then bottoming out the key will not sound a second note, just like a real piano does not release the hammer unless the key is raised high enough.
        $endgroup$
        – Toor
        Mar 25 at 23:45















      $begingroup$
      I responded back for why I think this is still insufficient.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 20:55




      $begingroup$
      I responded back for why I think this is still insufficient.
      $endgroup$
      – Jonas Daverio
      Mar 24 at 20:55












      $begingroup$
      I think you misread what I wrote. I meant "The volume of the sound is NOT only function of the velocity of the keys at the end of the descent."
      $endgroup$
      – Jonas Daverio
      Mar 24 at 21:48




      $begingroup$
      I think you misread what I wrote. I meant "The volume of the sound is NOT only function of the velocity of the keys at the end of the descent."
      $endgroup$
      – Jonas Daverio
      Mar 24 at 21:48












      $begingroup$
      Indeed, the energy depends on the speed over the time-length of the impact, which is a function of acceleration (and the jerk, if you don't assume constant acceleration). However, are sure that makes much of a difference? Can you characterize the specifics that you have or are looking for? I don't know what that would be. It might depend on the effect that it's supposed to have on the algorithm.
      $endgroup$
      – vectory
      Mar 25 at 22:39





      $begingroup$
      Indeed, the energy depends on the speed over the time-length of the impact, which is a function of acceleration (and the jerk, if you don't assume constant acceleration). However, are sure that makes much of a difference? Can you characterize the specifics that you have or are looking for? I don't know what that would be. It might depend on the effect that it's supposed to have on the algorithm.
      $endgroup$
      – vectory
      Mar 25 at 22:39













      $begingroup$
      @JonasDaverio Are you referring to escapement? Digital pianos accomplish this with a third sensor that fires slightly above where the key bottoms out (and above the sensor that sounds the note). If the key does not go high enough to release this 3rd sensor, then bottoming out the key will not sound a second note, just like a real piano does not release the hammer unless the key is raised high enough.
      $endgroup$
      – Toor
      Mar 25 at 23:45




      $begingroup$
      @JonasDaverio Are you referring to escapement? Digital pianos accomplish this with a third sensor that fires slightly above where the key bottoms out (and above the sensor that sounds the note). If the key does not go high enough to release this 3rd sensor, then bottoming out the key will not sound a second note, just like a real piano does not release the hammer unless the key is raised high enough.
      $endgroup$
      – Toor
      Mar 25 at 23:45











      8












      $begingroup$

      You should take a look at analog keyboards. Take a look at this video. This is just an example of concept.



      Edit:
      Also, if optical switches are not working for you, take a look at this:



      enter image description here



      There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.



      Source:
      Reddit
      Imgur






      share|improve this answer










      New contributor




      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      $endgroup$












      • $begingroup$
        Apparently, they use a pair of IR-LED and photosensor: blog.wooting.nl/flaretech-the-optical-keyboard-switch However, I'm not sure wether they measure the delay between the emission and the detection or wether they measure the intensity of the light that could make through the tunnel.
        $endgroup$
        – Jonas Daverio
        Mar 25 at 10:46











      • $begingroup$
        I linked that just for the example of analog keyboard. You can take a look at reddit.com/r/MechanicalKeyboards/comments/9ii6gw/… and imgur.com/gallery/ImrH7nO . I'am not too familiar with the subject, just trying to help to push you into right direction :)
        $endgroup$
        – Matt
        Mar 25 at 11:12






      • 1




        $begingroup$
        While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes. - From Review
        $endgroup$
        – Blair Fonville
        Mar 25 at 11:22






      • 1




        $begingroup$
        @BlairFonville Fair enough. Let me summarize it. There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.
        $endgroup$
        – Matt
        Mar 25 at 12:12















      8












      $begingroup$

      You should take a look at analog keyboards. Take a look at this video. This is just an example of concept.



      Edit:
      Also, if optical switches are not working for you, take a look at this:



      enter image description here



      There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.



      Source:
      Reddit
      Imgur






      share|improve this answer










      New contributor




      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      $endgroup$












      • $begingroup$
        Apparently, they use a pair of IR-LED and photosensor: blog.wooting.nl/flaretech-the-optical-keyboard-switch However, I'm not sure wether they measure the delay between the emission and the detection or wether they measure the intensity of the light that could make through the tunnel.
        $endgroup$
        – Jonas Daverio
        Mar 25 at 10:46











      • $begingroup$
        I linked that just for the example of analog keyboard. You can take a look at reddit.com/r/MechanicalKeyboards/comments/9ii6gw/… and imgur.com/gallery/ImrH7nO . I'am not too familiar with the subject, just trying to help to push you into right direction :)
        $endgroup$
        – Matt
        Mar 25 at 11:12






      • 1




        $begingroup$
        While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes. - From Review
        $endgroup$
        – Blair Fonville
        Mar 25 at 11:22






      • 1




        $begingroup$
        @BlairFonville Fair enough. Let me summarize it. There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.
        $endgroup$
        – Matt
        Mar 25 at 12:12













      8












      8








      8





      $begingroup$

      You should take a look at analog keyboards. Take a look at this video. This is just an example of concept.



      Edit:
      Also, if optical switches are not working for you, take a look at this:



      enter image description here



      There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.



      Source:
      Reddit
      Imgur






      share|improve this answer










      New contributor




      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      $endgroup$



      You should take a look at analog keyboards. Take a look at this video. This is just an example of concept.



      Edit:
      Also, if optical switches are not working for you, take a look at this:



      enter image description here



      There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.



      Source:
      Reddit
      Imgur







      share|improve this answer










      New contributor




      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this answer



      share|improve this answer








      edited Mar 26 at 9:18





















      New contributor




      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      answered Mar 25 at 8:55









      MattMatt

      1803




      1803




      New contributor




      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      Matt is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      • $begingroup$
        Apparently, they use a pair of IR-LED and photosensor: blog.wooting.nl/flaretech-the-optical-keyboard-switch However, I'm not sure wether they measure the delay between the emission and the detection or wether they measure the intensity of the light that could make through the tunnel.
        $endgroup$
        – Jonas Daverio
        Mar 25 at 10:46











      • $begingroup$
        I linked that just for the example of analog keyboard. You can take a look at reddit.com/r/MechanicalKeyboards/comments/9ii6gw/… and imgur.com/gallery/ImrH7nO . I'am not too familiar with the subject, just trying to help to push you into right direction :)
        $endgroup$
        – Matt
        Mar 25 at 11:12






      • 1




        $begingroup$
        While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes. - From Review
        $endgroup$
        – Blair Fonville
        Mar 25 at 11:22






      • 1




        $begingroup$
        @BlairFonville Fair enough. Let me summarize it. There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.
        $endgroup$
        – Matt
        Mar 25 at 12:12
















      • $begingroup$
        Apparently, they use a pair of IR-LED and photosensor: blog.wooting.nl/flaretech-the-optical-keyboard-switch However, I'm not sure wether they measure the delay between the emission and the detection or wether they measure the intensity of the light that could make through the tunnel.
        $endgroup$
        – Jonas Daverio
        Mar 25 at 10:46











      • $begingroup$
        I linked that just for the example of analog keyboard. You can take a look at reddit.com/r/MechanicalKeyboards/comments/9ii6gw/… and imgur.com/gallery/ImrH7nO . I'am not too familiar with the subject, just trying to help to push you into right direction :)
        $endgroup$
        – Matt
        Mar 25 at 11:12






      • 1




        $begingroup$
        While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes. - From Review
        $endgroup$
        – Blair Fonville
        Mar 25 at 11:22






      • 1




        $begingroup$
        @BlairFonville Fair enough. Let me summarize it. There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.
        $endgroup$
        – Matt
        Mar 25 at 12:12















      $begingroup$
      Apparently, they use a pair of IR-LED and photosensor: blog.wooting.nl/flaretech-the-optical-keyboard-switch However, I'm not sure wether they measure the delay between the emission and the detection or wether they measure the intensity of the light that could make through the tunnel.
      $endgroup$
      – Jonas Daverio
      Mar 25 at 10:46





      $begingroup$
      Apparently, they use a pair of IR-LED and photosensor: blog.wooting.nl/flaretech-the-optical-keyboard-switch However, I'm not sure wether they measure the delay between the emission and the detection or wether they measure the intensity of the light that could make through the tunnel.
      $endgroup$
      – Jonas Daverio
      Mar 25 at 10:46













      $begingroup$
      I linked that just for the example of analog keyboard. You can take a look at reddit.com/r/MechanicalKeyboards/comments/9ii6gw/… and imgur.com/gallery/ImrH7nO . I'am not too familiar with the subject, just trying to help to push you into right direction :)
      $endgroup$
      – Matt
      Mar 25 at 11:12




      $begingroup$
      I linked that just for the example of analog keyboard. You can take a look at reddit.com/r/MechanicalKeyboards/comments/9ii6gw/… and imgur.com/gallery/ImrH7nO . I'am not too familiar with the subject, just trying to help to push you into right direction :)
      $endgroup$
      – Matt
      Mar 25 at 11:12




      1




      1




      $begingroup$
      While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes. - From Review
      $endgroup$
      – Blair Fonville
      Mar 25 at 11:22




      $begingroup$
      While this link may answer the question, it is better to include the essential parts of the answer here and provide the link for reference. Link-only answers can become invalid if the linked page changes. - From Review
      $endgroup$
      – Blair Fonville
      Mar 25 at 11:22




      1




      1




      $begingroup$
      @BlairFonville Fair enough. Let me summarize it. There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.
      $endgroup$
      – Matt
      Mar 25 at 12:12




      $begingroup$
      @BlairFonville Fair enough. Let me summarize it. There is a PCB printed coil under each key cap. As you press the button coil measures the inductance change caused by key spring compressing and decompressing, therefore, you can get pretty accurate reading of the switch position.
      $endgroup$
      – Matt
      Mar 25 at 12:12











      7












      $begingroup$

      If the important variable is the impact of a "hammer" that you're trying to emulate, consider piezo sensors which allow you to measure this directly. They produce a pulse whose amplitude depends on the impact impulse.






      share|improve this answer









      $endgroup$

















        7












        $begingroup$

        If the important variable is the impact of a "hammer" that you're trying to emulate, consider piezo sensors which allow you to measure this directly. They produce a pulse whose amplitude depends on the impact impulse.






        share|improve this answer









        $endgroup$















          7












          7








          7





          $begingroup$

          If the important variable is the impact of a "hammer" that you're trying to emulate, consider piezo sensors which allow you to measure this directly. They produce a pulse whose amplitude depends on the impact impulse.






          share|improve this answer









          $endgroup$



          If the important variable is the impact of a "hammer" that you're trying to emulate, consider piezo sensors which allow you to measure this directly. They produce a pulse whose amplitude depends on the impact impulse.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Mar 24 at 17:54









          pjc50pjc50

          34.4k34288




          34.4k34288





















              3












              $begingroup$

              One option could be Hall sensors, which sense the strength of a magnetic field. There are different types of Hall sensors for digital and analog sensing, you need one that has analog. For example SI7211 costs about 0.80 USD.



              You also need a small magnet underneath each key. When the magnet gets closer to the sensor, the magnetic field increases which increases the sensor's output voltage.






              share|improve this answer









              $endgroup$








              • 1




                $begingroup$
                Apparently, they use it on some music keyboards. I think this is a really simple and good solution. I will compare the costs with 0xDBFB7's solution.
                $endgroup$
                – Jonas Daverio
                Mar 25 at 16:46















              3












              $begingroup$

              One option could be Hall sensors, which sense the strength of a magnetic field. There are different types of Hall sensors for digital and analog sensing, you need one that has analog. For example SI7211 costs about 0.80 USD.



              You also need a small magnet underneath each key. When the magnet gets closer to the sensor, the magnetic field increases which increases the sensor's output voltage.






              share|improve this answer









              $endgroup$








              • 1




                $begingroup$
                Apparently, they use it on some music keyboards. I think this is a really simple and good solution. I will compare the costs with 0xDBFB7's solution.
                $endgroup$
                – Jonas Daverio
                Mar 25 at 16:46













              3












              3








              3





              $begingroup$

              One option could be Hall sensors, which sense the strength of a magnetic field. There are different types of Hall sensors for digital and analog sensing, you need one that has analog. For example SI7211 costs about 0.80 USD.



              You also need a small magnet underneath each key. When the magnet gets closer to the sensor, the magnetic field increases which increases the sensor's output voltage.






              share|improve this answer









              $endgroup$



              One option could be Hall sensors, which sense the strength of a magnetic field. There are different types of Hall sensors for digital and analog sensing, you need one that has analog. For example SI7211 costs about 0.80 USD.



              You also need a small magnet underneath each key. When the magnet gets closer to the sensor, the magnetic field increases which increases the sensor's output voltage.







              share|improve this answer












              share|improve this answer



              share|improve this answer










              answered Mar 25 at 12:26









              jpajpa

              1,576711




              1,576711







              • 1




                $begingroup$
                Apparently, they use it on some music keyboards. I think this is a really simple and good solution. I will compare the costs with 0xDBFB7's solution.
                $endgroup$
                – Jonas Daverio
                Mar 25 at 16:46












              • 1




                $begingroup$
                Apparently, they use it on some music keyboards. I think this is a really simple and good solution. I will compare the costs with 0xDBFB7's solution.
                $endgroup$
                – Jonas Daverio
                Mar 25 at 16:46







              1




              1




              $begingroup$
              Apparently, they use it on some music keyboards. I think this is a really simple and good solution. I will compare the costs with 0xDBFB7's solution.
              $endgroup$
              – Jonas Daverio
              Mar 25 at 16:46




              $begingroup$
              Apparently, they use it on some music keyboards. I think this is a really simple and good solution. I will compare the costs with 0xDBFB7's solution.
              $endgroup$
              – Jonas Daverio
              Mar 25 at 16:46











              2












              $begingroup$

              You can treat this as a hybrid digital/analog instrument by placing microphones[1] inside the keyboard, tuned to the sound of striking the keys. Signals from the microphones augment the traditional switch-based input, so the switch tells you which key is pressed, and the microphones tell you how loud the most recent keypress was.



              2 or more microphones along the keyboard's length would permit decoding a chord with loud/low notes and soft/high notes and vice versa.



              [1]: I keep saying "microphone", but I mean "generic vibration sensing device".






              share|improve this answer









              $endgroup$












              • $begingroup$
                That's pretty much how an E-Guitar works, I guess. However, the question didn't mention any acoustic parts, just keys.
                $endgroup$
                – vectory
                Mar 25 at 22:32















              2












              $begingroup$

              You can treat this as a hybrid digital/analog instrument by placing microphones[1] inside the keyboard, tuned to the sound of striking the keys. Signals from the microphones augment the traditional switch-based input, so the switch tells you which key is pressed, and the microphones tell you how loud the most recent keypress was.



              2 or more microphones along the keyboard's length would permit decoding a chord with loud/low notes and soft/high notes and vice versa.



              [1]: I keep saying "microphone", but I mean "generic vibration sensing device".






              share|improve this answer









              $endgroup$












              • $begingroup$
                That's pretty much how an E-Guitar works, I guess. However, the question didn't mention any acoustic parts, just keys.
                $endgroup$
                – vectory
                Mar 25 at 22:32













              2












              2








              2





              $begingroup$

              You can treat this as a hybrid digital/analog instrument by placing microphones[1] inside the keyboard, tuned to the sound of striking the keys. Signals from the microphones augment the traditional switch-based input, so the switch tells you which key is pressed, and the microphones tell you how loud the most recent keypress was.



              2 or more microphones along the keyboard's length would permit decoding a chord with loud/low notes and soft/high notes and vice versa.



              [1]: I keep saying "microphone", but I mean "generic vibration sensing device".






              share|improve this answer









              $endgroup$



              You can treat this as a hybrid digital/analog instrument by placing microphones[1] inside the keyboard, tuned to the sound of striking the keys. Signals from the microphones augment the traditional switch-based input, so the switch tells you which key is pressed, and the microphones tell you how loud the most recent keypress was.



              2 or more microphones along the keyboard's length would permit decoding a chord with loud/low notes and soft/high notes and vice versa.



              [1]: I keep saying "microphone", but I mean "generic vibration sensing device".







              share|improve this answer












              share|improve this answer



              share|improve this answer










              answered Mar 24 at 21:41









              hoosierEEhoosierEE

              1,120714




              1,120714











              • $begingroup$
                That's pretty much how an E-Guitar works, I guess. However, the question didn't mention any acoustic parts, just keys.
                $endgroup$
                – vectory
                Mar 25 at 22:32
















              • $begingroup$
                That's pretty much how an E-Guitar works, I guess. However, the question didn't mention any acoustic parts, just keys.
                $endgroup$
                – vectory
                Mar 25 at 22:32















              $begingroup$
              That's pretty much how an E-Guitar works, I guess. However, the question didn't mention any acoustic parts, just keys.
              $endgroup$
              – vectory
              Mar 25 at 22:32




              $begingroup$
              That's pretty much how an E-Guitar works, I guess. However, the question didn't mention any acoustic parts, just keys.
              $endgroup$
              – vectory
              Mar 25 at 22:32











              0












              $begingroup$

              You may want to research spring return variable resistors, spring return potentiometers, or linear position sensors. Here is one example:
              http://ecatalog.beisensors.com/item/linear-position-sensors/linear-position-sensor-9600-series-compact-spri/9610r3-4kl2-0



              Another possibility may be to use a small rotary encoder (and mechanically convert the linear key press motion to rotary motion). The encoder would output one or more sets of pulses as the shaft rotates. A higher pulse rate would indicate a higher velocity press. The encoder position could be tracked directly if the pulse groups are sent to additional digital logic. Here's an example part: https://www.mouser.com/ProductDetail/Bourns/PEC16-4220F-S0024?qs=6FD5PBp7ZtQte%252Bg7b%2FiMUw%3D%3D&gclid=EAIaIQobChMIrKbIjOSa4QIVCEsNCh3JAAKuEAQYAyABEgKM_fD_BwE






              share|improve this answer











              $endgroup$

















                0












                $begingroup$

                You may want to research spring return variable resistors, spring return potentiometers, or linear position sensors. Here is one example:
                http://ecatalog.beisensors.com/item/linear-position-sensors/linear-position-sensor-9600-series-compact-spri/9610r3-4kl2-0



                Another possibility may be to use a small rotary encoder (and mechanically convert the linear key press motion to rotary motion). The encoder would output one or more sets of pulses as the shaft rotates. A higher pulse rate would indicate a higher velocity press. The encoder position could be tracked directly if the pulse groups are sent to additional digital logic. Here's an example part: https://www.mouser.com/ProductDetail/Bourns/PEC16-4220F-S0024?qs=6FD5PBp7ZtQte%252Bg7b%2FiMUw%3D%3D&gclid=EAIaIQobChMIrKbIjOSa4QIVCEsNCh3JAAKuEAQYAyABEgKM_fD_BwE






                share|improve this answer











                $endgroup$















                  0












                  0








                  0





                  $begingroup$

                  You may want to research spring return variable resistors, spring return potentiometers, or linear position sensors. Here is one example:
                  http://ecatalog.beisensors.com/item/linear-position-sensors/linear-position-sensor-9600-series-compact-spri/9610r3-4kl2-0



                  Another possibility may be to use a small rotary encoder (and mechanically convert the linear key press motion to rotary motion). The encoder would output one or more sets of pulses as the shaft rotates. A higher pulse rate would indicate a higher velocity press. The encoder position could be tracked directly if the pulse groups are sent to additional digital logic. Here's an example part: https://www.mouser.com/ProductDetail/Bourns/PEC16-4220F-S0024?qs=6FD5PBp7ZtQte%252Bg7b%2FiMUw%3D%3D&gclid=EAIaIQobChMIrKbIjOSa4QIVCEsNCh3JAAKuEAQYAyABEgKM_fD_BwE






                  share|improve this answer











                  $endgroup$



                  You may want to research spring return variable resistors, spring return potentiometers, or linear position sensors. Here is one example:
                  http://ecatalog.beisensors.com/item/linear-position-sensors/linear-position-sensor-9600-series-compact-spri/9610r3-4kl2-0



                  Another possibility may be to use a small rotary encoder (and mechanically convert the linear key press motion to rotary motion). The encoder would output one or more sets of pulses as the shaft rotates. A higher pulse rate would indicate a higher velocity press. The encoder position could be tracked directly if the pulse groups are sent to additional digital logic. Here's an example part: https://www.mouser.com/ProductDetail/Bourns/PEC16-4220F-S0024?qs=6FD5PBp7ZtQte%252Bg7b%2FiMUw%3D%3D&gclid=EAIaIQobChMIrKbIjOSa4QIVCEsNCh3JAAKuEAQYAyABEgKM_fD_BwE







                  share|improve this answer














                  share|improve this answer



                  share|improve this answer








                  edited Mar 24 at 12:42

























                  answered Mar 24 at 12:34









                  NeddNedd

                  4,378713




                  4,378713





















                      0












                      $begingroup$

                      If you want super-accuracy at a reasonable price, how about using a linear encoder, attaching a Gray-coded strip (which you print yourself using a laser printer onto a transparent sheet, then cut up and attach one to each key) - more details of how they work under rotary encoders here. This way you need two (perhaps 3 so you get an accurate indication of end position) digital lines per key. This will allow you to measure velocity with very good accuracy and even position if that's relevant. The advantage of this is you could retrofit it to an old keyboard (even an acoustic keyboard).



                      Caution: when I was a teenager (a long while ago) I wondered for ages whether I could make a realistic keyboard more cheaply than buying them. It seemed unlikely then and it seems even less likely now. The cost effective method is therefore probably "buy a velocity sensitive keyboard and take it apart" which is no fun.






                      share|improve this answer









                      $endgroup$








                      • 1




                        $begingroup$
                        Yes, I'm not pretending this will end up cheaper than a commercial one, but I'm trying to construct a special arrangement of keys that doesn't exist on the market. For your answer, I'm not really sure what you mean. Do you mean making a linear encoder from scratch? I don't understand what's the point of the transparent strip. And 3 bits seems a bit low to encode precisely the position and to deduce the velocity from it.
                        $endgroup$
                        – Jonas Daverio
                        Mar 25 at 10:56











                      • $begingroup$
                        A linear encoder will give you velocity with 2 bits only (see links) to a great resolution (you could get position to 256ths of the travel distance very easily). By timing the period between grey code bit transitions you will get a very accurate picture of velocity at different stages of travel of the key. 3rd bit gives you accurate 'hammer hits strings' signal. I was suggesting you use a linear encoder optical reader with your own 'tape' - transparent strip.
                        $endgroup$
                        – abligh
                        Mar 25 at 22:29
















                      0












                      $begingroup$

                      If you want super-accuracy at a reasonable price, how about using a linear encoder, attaching a Gray-coded strip (which you print yourself using a laser printer onto a transparent sheet, then cut up and attach one to each key) - more details of how they work under rotary encoders here. This way you need two (perhaps 3 so you get an accurate indication of end position) digital lines per key. This will allow you to measure velocity with very good accuracy and even position if that's relevant. The advantage of this is you could retrofit it to an old keyboard (even an acoustic keyboard).



                      Caution: when I was a teenager (a long while ago) I wondered for ages whether I could make a realistic keyboard more cheaply than buying them. It seemed unlikely then and it seems even less likely now. The cost effective method is therefore probably "buy a velocity sensitive keyboard and take it apart" which is no fun.






                      share|improve this answer









                      $endgroup$








                      • 1




                        $begingroup$
                        Yes, I'm not pretending this will end up cheaper than a commercial one, but I'm trying to construct a special arrangement of keys that doesn't exist on the market. For your answer, I'm not really sure what you mean. Do you mean making a linear encoder from scratch? I don't understand what's the point of the transparent strip. And 3 bits seems a bit low to encode precisely the position and to deduce the velocity from it.
                        $endgroup$
                        – Jonas Daverio
                        Mar 25 at 10:56











                      • $begingroup$
                        A linear encoder will give you velocity with 2 bits only (see links) to a great resolution (you could get position to 256ths of the travel distance very easily). By timing the period between grey code bit transitions you will get a very accurate picture of velocity at different stages of travel of the key. 3rd bit gives you accurate 'hammer hits strings' signal. I was suggesting you use a linear encoder optical reader with your own 'tape' - transparent strip.
                        $endgroup$
                        – abligh
                        Mar 25 at 22:29














                      0












                      0








                      0





                      $begingroup$

                      If you want super-accuracy at a reasonable price, how about using a linear encoder, attaching a Gray-coded strip (which you print yourself using a laser printer onto a transparent sheet, then cut up and attach one to each key) - more details of how they work under rotary encoders here. This way you need two (perhaps 3 so you get an accurate indication of end position) digital lines per key. This will allow you to measure velocity with very good accuracy and even position if that's relevant. The advantage of this is you could retrofit it to an old keyboard (even an acoustic keyboard).



                      Caution: when I was a teenager (a long while ago) I wondered for ages whether I could make a realistic keyboard more cheaply than buying them. It seemed unlikely then and it seems even less likely now. The cost effective method is therefore probably "buy a velocity sensitive keyboard and take it apart" which is no fun.






                      share|improve this answer









                      $endgroup$



                      If you want super-accuracy at a reasonable price, how about using a linear encoder, attaching a Gray-coded strip (which you print yourself using a laser printer onto a transparent sheet, then cut up and attach one to each key) - more details of how they work under rotary encoders here. This way you need two (perhaps 3 so you get an accurate indication of end position) digital lines per key. This will allow you to measure velocity with very good accuracy and even position if that's relevant. The advantage of this is you could retrofit it to an old keyboard (even an acoustic keyboard).



                      Caution: when I was a teenager (a long while ago) I wondered for ages whether I could make a realistic keyboard more cheaply than buying them. It seemed unlikely then and it seems even less likely now. The cost effective method is therefore probably "buy a velocity sensitive keyboard and take it apart" which is no fun.







                      share|improve this answer












                      share|improve this answer



                      share|improve this answer










                      answered Mar 25 at 6:19









                      ablighabligh

                      21716




                      21716







                      • 1




                        $begingroup$
                        Yes, I'm not pretending this will end up cheaper than a commercial one, but I'm trying to construct a special arrangement of keys that doesn't exist on the market. For your answer, I'm not really sure what you mean. Do you mean making a linear encoder from scratch? I don't understand what's the point of the transparent strip. And 3 bits seems a bit low to encode precisely the position and to deduce the velocity from it.
                        $endgroup$
                        – Jonas Daverio
                        Mar 25 at 10:56











                      • $begingroup$
                        A linear encoder will give you velocity with 2 bits only (see links) to a great resolution (you could get position to 256ths of the travel distance very easily). By timing the period between grey code bit transitions you will get a very accurate picture of velocity at different stages of travel of the key. 3rd bit gives you accurate 'hammer hits strings' signal. I was suggesting you use a linear encoder optical reader with your own 'tape' - transparent strip.
                        $endgroup$
                        – abligh
                        Mar 25 at 22:29













                      • 1




                        $begingroup$
                        Yes, I'm not pretending this will end up cheaper than a commercial one, but I'm trying to construct a special arrangement of keys that doesn't exist on the market. For your answer, I'm not really sure what you mean. Do you mean making a linear encoder from scratch? I don't understand what's the point of the transparent strip. And 3 bits seems a bit low to encode precisely the position and to deduce the velocity from it.
                        $endgroup$
                        – Jonas Daverio
                        Mar 25 at 10:56











                      • $begingroup$
                        A linear encoder will give you velocity with 2 bits only (see links) to a great resolution (you could get position to 256ths of the travel distance very easily). By timing the period between grey code bit transitions you will get a very accurate picture of velocity at different stages of travel of the key. 3rd bit gives you accurate 'hammer hits strings' signal. I was suggesting you use a linear encoder optical reader with your own 'tape' - transparent strip.
                        $endgroup$
                        – abligh
                        Mar 25 at 22:29








                      1




                      1




                      $begingroup$
                      Yes, I'm not pretending this will end up cheaper than a commercial one, but I'm trying to construct a special arrangement of keys that doesn't exist on the market. For your answer, I'm not really sure what you mean. Do you mean making a linear encoder from scratch? I don't understand what's the point of the transparent strip. And 3 bits seems a bit low to encode precisely the position and to deduce the velocity from it.
                      $endgroup$
                      – Jonas Daverio
                      Mar 25 at 10:56





                      $begingroup$
                      Yes, I'm not pretending this will end up cheaper than a commercial one, but I'm trying to construct a special arrangement of keys that doesn't exist on the market. For your answer, I'm not really sure what you mean. Do you mean making a linear encoder from scratch? I don't understand what's the point of the transparent strip. And 3 bits seems a bit low to encode precisely the position and to deduce the velocity from it.
                      $endgroup$
                      – Jonas Daverio
                      Mar 25 at 10:56













                      $begingroup$
                      A linear encoder will give you velocity with 2 bits only (see links) to a great resolution (you could get position to 256ths of the travel distance very easily). By timing the period between grey code bit transitions you will get a very accurate picture of velocity at different stages of travel of the key. 3rd bit gives you accurate 'hammer hits strings' signal. I was suggesting you use a linear encoder optical reader with your own 'tape' - transparent strip.
                      $endgroup$
                      – abligh
                      Mar 25 at 22:29





                      $begingroup$
                      A linear encoder will give you velocity with 2 bits only (see links) to a great resolution (you could get position to 256ths of the travel distance very easily). By timing the period between grey code bit transitions you will get a very accurate picture of velocity at different stages of travel of the key. 3rd bit gives you accurate 'hammer hits strings' signal. I was suggesting you use a linear encoder optical reader with your own 'tape' - transparent strip.
                      $endgroup$
                      – abligh
                      Mar 25 at 22:29




                      Popular posts from this blog

                      Adding axes to figuresAdding axes labels to LaTeX figuresLaTeX equivalent of ConTeXt buffersRotate a node but not its content: the case of the ellipse decorationHow to define the default vertical distance between nodes?TikZ scaling graphic and adjust node position and keep font sizeNumerical conditional within tikz keys?adding axes to shapesAlign axes across subfiguresAdding figures with a certain orderLine up nested tikz enviroments or how to get rid of themAdding axes labels to LaTeX figures

                      Luettelo Yhdysvaltain laivaston lentotukialuksista Lähteet | Navigointivalikko

                      Gary (muusikko) Sisällysluettelo Historia | Rockin' High | Lähteet | Aiheesta muualla | NavigointivalikkoInfobox OKTuomas "Gary" Keskinen Ancaran kitaristiksiProjekti Rockin' High