Problem with a special midi instrument
I’m writing a piece in MAX/MSP for a trumpeter who has gotten his hand on a Morrison Digital Trumpet (http://www.morrisondigitaltrumpet.com/).
My patch is complete, except I wrote it all and tested it with my MIDI-keyboard. Testing it with the trumpet, it only reports new notes on note-off while playing legato. Playing staccato, that is initiating a new velocity with the breath controller for every note, this is not a problem. So, the first note in a row is always correct, but then it will start to be "delayed" – while playing keeping a continuous stream of breath.
I’ve tried seeing if I can readjust the musical instrument, but well, it isn’t very friendly when it comes to interfacing. Could someone here who might have used a similar device, like an Akai EWI, direct me to some knowledge about how MIDI instruments works that keep me from making this work?
There isn’t any problem when using the instrument with other software, like ABleton and other DAWs.
- This topic was modified 1 year by mortrouge.
I’m having the same problem working with an Akai EWI USB – with a continuous stream of breath, after the first note, the note being reported is the previous one, not the current one.
I wonder if this has something to do with the fact that only the first note in a stream reports any velocity value above 0 – after that first note, each note puts out a velocity value of 0 when the note is played. Breath pressure (volume) is instead reported by aftertouch, also by control change. So it’s as though each note is reporting a note-off without ever having reported a note-on. Or maybe it’s as though the second note in a stream provides the note-off event for the first note – just speculating, I have no real idea what’s going on.
Don’t have much experience with breath based instrument controllers so this all comes with some guesswork, but from your respective descriptions it sounds like Breath control mode (or legato mode) is what is expected of the sound engine and the process would go something like as follows: A note on is expected to trigger a new event (as usual) while Note offs (velocity 0) are all accepted in terms of setting pitch but the velocity 0 /note off is ignored and BC or expression or Aftertouch (or whatever MIDI message) is actually used to control amplitude/sustain of the sound at least until its value returns to zero (where it may be the case that a note off of the last midi note is or should actually be transmitted). Also the sound engine would not actually respond to any velocity messages (in terms of amplitude/brightness) and typically have a sustain phase in its envelope that enabled the new pitch and amplitude variations to be expressed without triggering a new ‘note on event’ for each note message received (as in what would typically happen with a midi keyboard). Hope that makes some kind of sense. In any case, I would recommend a little research into the typical midi messaging of wind controllers and response of synth patches to suit them…
OK, I think I’ve figured out the problem – at least for the EWI USB.
During a continuous stream of notes, the MIDI note-off for the previous note is transmitted immediately AFTER the note-on for the current note – thus pre-empting the note-on so that there’s no indication of the current note until it transmits its own note-off, stepping on the next note in the series.
So printing it out in the Max window looks something like this
69 24 (beginning of stream – note #1 on)
71 24 (note #2 on)
69 0 (note #1 off)
72 16 (note #3 on)
71 0 (note #2 off)
65 27 (note #4 on)
72 0 (note #3 off)
65 0 (end of stream – note #4 off)
So now I just need to figure out a way to swap the order of the messages so that the note-off (for the previous note) takes effect BEFORE the note-on (for the current note).
So here’s a quick and dirty solution – I’m sure there are much better ways to do it, but anyway.
-- Pasted Max Patch, click to expand. --Copy all of the following text. Then, in Max, select New From Clipboard.----------begin_max5_patcher---------- 1965.3oc2a98iaZCG.+469qvBMsG1tdEaiMj835llpzVakpl1CSSUDhyEZSv Yf450V0929v1vEtqgfiC3R1CkT7Yfu9i+9K+qOc4Edy42wJ7.+D3uAWbwmt7 hKTEIK3h56uvaS7cIqiKTUyKguYCKS3ck9uIX2ITkmytgkwxiELPFWvdBe4x BvRdNXQZQRNqt3Bv6WUUsaY4f44rXwJv1bVQQYNCv92x30E.+l275zLVBuLS 85w0EtjmIJR+HSVFz+Z+5hmWNe9ZcgMUL+l4x62UG4GpRviEo7r2jyRD5Vc. gbM4J.NDWUSU0kW.+SySEKRVklcS6mfh0OQnrxvYH4OAzVOTV4lzr0LQQaIJ cghS74u8IytuQJaOYwaTht2uWljtHF7a4wYKXd6dW7RQyKyWV3mu7R4kqLrG Ki89pO5W0gUl8VdZl2gA6dZ93nYpl+LXS6tBBQ8050sAwG1xzuEOuqp+28OW K.EgsEP3gCPIqhytgA7s.QgJpfwpepTvrGQoRSM8O6ETnI.n1Fm7NP5I.p.h VWZ1gAEpSPsWz.sEMvgCMo67Td7TAEnzhPRyMKnRm5L9S.vTvVeJVVTMZBrT gYdkkcmNeBslOHK3SWwSKde7VfXECvyWTEsjurNrZVA36aEgcQYdEg.IURZZ Fur.THphqtoXzhh908IPjuJf.jpTTI9Gc7PZ3DHdn.rFL2BMRkSKbTn1i+I3 pWoTtOERJwkJjapxGK9F1WwGpe+Fr6OEKDUoRPCmYZJVDkOu.nBmZEJHcXBK PCl.d+LK2q8SSLRgQRHwTZpe.jF+A3wHgMJbBjGhzBd8waAGoRmGEPOYK38i FmFNoSz.OdvPq8o4q4ikfoqzPHQS.CQA.YsK+whKgmwomoIiuN+0vwH6LBcB XNcibZNrWygpbxPsM60tYyjHQguCVQAKTdf9pDHIzYslXgAJpOdJD0WlK9Wp BVSrmMyTA8I1p4TjdSV75ClrIZBXd8zpwTDdsMTRAFhjLxwOaIkVtlGueeyS goT3G+BfNyVWOj.eSRBrOEn857YJXhscUbAO+KVimZ6K+gGOgSAcmMB9R6gi Nev9LqfV.GrSmRpJ66pWh8tWzglzyYoEbP6d4P9fCOho+dabd0eWvxeCKKtd 5a7GLGzrOtHN4dMlaiyuWXhKE7Ur0aeSUE75lYggx3VTZ8771b8v1UsQw8dU VySjZO6.6nMSP+fLH8wqdT2TQQmzTSdHWHDWZkz0DS9GO+WdNPt1H8PHil6P RfZldPPk9A0PSp1oqLyblHaBI707b82tJQLe3LJ7p89+fOTHNQMstf41zDwJ vbV1hgfl0qLYCMIGOMCOqoY7xJ+f.AuLY0Pfy5EanAmziGmzyZb9pa1.dlZQ PGBZhhhtNBiwP78HMDe7HkbVizmUIz470CIV8gsTRihNZhddCzWwW+Avqp2C ICAOgv19PCCOZdddGP5EbAC7xrm9xkKGDsy1dPsvbG5eVPyAdK1noFLXDWvF naWvlxMyY4VCh5E8O7Dlo8CMbKHZpLbq4kBAOyqWfLSgBjey0iDHcSB7.NED V1mqmb7l97nwpOOXpzmaKmjazBhC.E4rGT5H5iNnnSFPMrQiZ32nFNJ7rHbT sxyHqIQO2s3pGSxnawM6+oVbM7aLs3NOL3pFO6NW2D7HoHEc9j+WMPFqD.wn weMnRWjVQwBl0CG.A0KCSvoZW7v8We+61dr0GKgPGZzPHs89NZFMA9mMVMMD YrrZBfe6G1T8b+2zqiFqd8ymwJ2PjQqWe.GrbuMl50hX7ZLAe6UgaZiisiKx YiJbyPuFsd8PGpB2jU6n0XhbRtKoYK4Vj5h5HxfLQw931YiHmtuhJ2vxJ6o0 mJXapORwdufIdOO+cfWyJJR4YxcgNv6J4ke8ud9S9yW+y2eufC9i36ZUg5BP dG7nMn1Uj5E5tucsUeNL5bnRnQIlGdnUKsMe5Y9mznL6LY4AQwT8lU6b1GcJ 0UMGY4ODWE7x7jFQqYqkA10lVvJDoYpyTSqJI2bdspzpzEKXYs65pH71pgxK pEhfH8twUerU2cytOSZgr2eQ2Knjox+iDsNjehMxOU6CVez0nOvU7vI+QlH+ x8N5Ak+ATdvFHOxiHK.5D4gRLQdvtiOHSz27cl7DXDePNSdB8MU+wQ8WFIOP mIOHScW4FyqPSTejaxzCJOOx8YsGShd3J5Sop5twv+uwM.+oi+JG5OmFLwjm Gpaue4g5N4gXR+Ek3V4wH93n3ul3+j3NGVxSRcu7QdHHcT+E1j7kntKdG02D 8G2EuSdLlMS+wQxC0D8mH2IOgSP9zq7D5t72LPbvNL8VSL2wtK7UnIV6NUZ5 CNxckfqzkMI2G7DarZAASK4wcgJBLYrQAtan9Alj5Sf63C1D0Yjay7A22Hqc q3f5afftUbB5S4g3V4gzm73XsGZexiuakm9hjBCmViq.5PmOlLO0X24bVtnS 81egc375YBePty95QoY0g8k6bOCMJ2Ppakmds2cm+YnIi6Jvc9efljLFzc16 PSl2GXfakmd4iCs2MYZvss6RuJywa2dKKun9cpjDuMwuUefBoWotMMSeqZ4v 8xY2l1T+PUIw4IqRErDg73nJWu66hndWJ+Ne9x+S1mP3N -----------end_max5_patcher-----------
The note sequence from the EWI you describe makes far more sense. i.e. sending the next note on before the previous note off means that with a (monophonic) sound engine, the note will not be ‘released’ (in a midi sense) , at least until the player stops producing ‘air’ altogether. It also means that there is no special case required for dealing with the last note or breath level and some of my previous assumptions were not entirely correct…
In terms of a patch to deal with the midi I would suggest that using something like [Borax] which is pretty much designed for the task: that is to keep track of the note sequence and that the sound engine be monophonic (pretty much the default in Max anyway) and pitch is set by the next received note on as usual.
-- Pasted Max Patch, click to expand. --Copy all of the following text. Then, in Max, select New From Clipboard.----------begin_max5_patcher---------- 1697.3oc2atziaaCD.97t+JHL5g9vwUjTRTtGJPJRQuTTTTf1KEAAzRzqUfr nAE89nAI+1KeHY6MgdE8KZGCrP1hhlZlONyvYnz9gauYvD9irlAfeB7ufat4 C2dyMllzMbS642LXN8w7JZioaCpYOvm79ACsWRxdTZZ9Npj00XYgoIU2dENs qwo7ZYMcNyboWKJoUadklx+ybEHdTTay0KmWVWwjlaKZci7kxtVgsstfJymU Ve26DrboUYfXznjgfTbpZ.AoliH3nHvaa+M1gQ9zBl8GLX.3s5q7wauUeX3g gieFD4hFIGWZrPvZX0RprjWugtiU+NktGiizZc2gUZt+LbLZDDoGo3w5AAm0 OEKqkGUP98eRI6NPIj3Dk+9x7xBJ32Dz5BlSjFsWHEEQFgIJTPfvCCpHBTO4 PRI5g.hLSUvrWhoMk2UqLP1KrNm0zPui8Eb8afJT3xFElDVvhFacPiONXMxL DwF+cXZv72qJqYZK0DWDMNvD0fxzLhGDE0OQQH8PjXFTurSGBFLgVeW.hmlc lVboEMsFsmivhR9RsP4fIGoEbg6p4BlXhjkBSLlKH+XxvC.M6dnsSien2lMX hIrDwhnKpXT3PfFT+nIFdADr4GUKKSbkzQ7Y2.BuQbmXT+TZZEmdbi77CexY n3jyMa5R32ZHg82B5XBmEynMbwmbvGB7xfODr0CK5rvm4R9TWz4HmyIbegSD 1WGqCANJmRkj4xHYGBCufJTWWxDuiUSmTY5YzAyHOVferMePnuAeNnHzr+qf luxh4dpXETnKk7YrpEuS0AWnbU7nJdtdh5YZbe9QQuPtewXakfY1XLwIcGCQ YujjybXjUpOYrIPaLwtEAmNukb974LcpheFh9KU0Oxg.UIPEM.0cDPqp.4KE BUmqdBnrMJ.E7GpA0bIqA7PobF3dlxZnTVpNmOc85X5Lix4KqMCL1A0WgTwc SL1Gih5MKasflyq3BKCT4cEAGmBG57aaln79mddWWmrbRaDg9KhAl09QRWlW 6mc7x4SXBWIcG0eAIdGK6XUrBjfFosZwIIZkOA6c0J6enrsYG+O7xbF30U53 T5R4A+gAki.+cCCHmU1.np+pAkJW6GARNPvlxD5uPMl1fGlwpAMRtPoipe.C vUGDp9OkKlaGxoB9bvuvEzGcZxibLsA+Jyle6qpmfSGQLS1lcDAmdbCUOYSr tIAQGmJwwNU6waWsaslayhgjsSUhuyebLQo1b14lZ.wmxc0.2GKgiG2wxjcm k6EglrTJ4NQwpM34vR4EYSboU0PQcG2tlc.0Yu0EGFeAt3fcNOgX+HDKMrU9 ftDW7Ts1YFYi3pmYDAu.QjpFICYhhN6oWXylPmtqMOXGYH6hpnqfk+SP1RUZ mFPHx54gipIH9RLEWHZTp4g2lFax08L6lFeIxHaBhwnrKfP8IWh.pyEBOFFt X8asRIa06OoClUVq5ktfGSIPeaDPUri46uhOc524huoWAQzV8BYXsXaygaui nsMP+mkpa8WPYWPkbE.018BnKNILN5DsLQ1EnGNBZeRsYWBY6dIVMvJeNLbb 3VGcadl+58pVAVBBTcVEOjJYE1c2rfUIouRVNmADrEbgz0C5M5qeOVjcJnaB AkkcRhB9hrdgIDIstnaOke5EX90vdo0kNYacwXL5j.82r1FdBS9.iU2tpdci KxdETlR69v2FAFlEEdi4hkB69DucSX7U.nsK00kJKhbZBa7lNXdOsZoJ0T86 nm44SYP8KkhJN9J.xHySTAmXgq8sM3KXrQFLOChO6cO2Lh51eN3a3KE4cKt1 8lTCVqJErFYYsA6a1ozm0oYkEEr5Mk+hxFcNDlYfHml.dKOodHO52Ql.IO5s jvO9.Ci7D6i7jDN9.8PdxBl3j4gz.CGcf93cACm0LzGqG8+Q.gRdHdHO5WUi .4cg8EOgQb7IVX3LdR7w3Ib9V93ZQf8HNyKKVvUEY1t5Iz9rdI1M3dyyVeiN ZJ.A5qw+dnAskxkz9HlLmeJzAulEh6wi4yzgURcl8+.CcBlqO+rpEgwzl3Ub nvEk1mTNBlz3STHR3DGnOAo0uBK.zt3ADaJkEa2VZDb0Ym.qeH1WMHPDE+rv Euf7DlUgM2JROxidKWCEezxSVexSVXkmj9jmjvJOw8IOwgUdv8IO3vJOn9jG XXkm9720u.OgTd5MdXf82S6Sd1W9X2AI5hE2yDMsioQTFLm9d6dgkNzbZYs8 TyVYMPvturq+IlVnh7YkRVtbovt6ZOlkN3V884i29+b0adTN -----------end_max5_patcher-----------
yeah, with borax you can pretty much do a [stripnote] and then use [borax] voice count to do [!=0], so your logic is basically saying "are there notes depressed, yes or no".
Forums > MaxMSP