sysex again, it´s geting complicated...
sysex again, it´s geting complicated...
Hello,
the guys from elektron gave me pdf with the sysex documentation for the machinedrum.
so, i thought, i could fetch the current used machines and add a very important feature to the machinedrumcontroler, the ability to disaply the names of the tracks on the lemur.
however, it´s damn complicated and the data seems to be coded and needs to be decoded. i tried several things but didn´t come close to a solution.
i really hope one of you guys jumps in and gives me a proper hint on how to achieve my goal.
i allowed myself to attach the pdf with the informations, it´s sorta french to me ...
the infos i´d like to retrieve from the machine are on page four, especially "kitname' and 'selected drum model'.
thanks a lot in advance, ANY tip is really apprechiated.
cheers, martin
			
							the guys from elektron gave me pdf with the sysex documentation for the machinedrum.
so, i thought, i could fetch the current used machines and add a very important feature to the machinedrumcontroler, the ability to disaply the names of the tracks on the lemur.
however, it´s damn complicated and the data seems to be coded and needs to be decoded. i tried several things but didn´t come close to a solution.
i really hope one of you guys jumps in and gives me a proper hint on how to achieve my goal.
i allowed myself to attach the pdf with the informations, it´s sorta french to me ...
the infos i´d like to retrieve from the machine are on page four, especially "kitname' and 'selected drum model'.
thanks a lot in advance, ANY tip is really apprechiated.
cheers, martin
- Attachments
- 
			
		
		
				- md1_53-sysex-0_8.zip
- Machinedrum sysex documentation
- (58.75 KiB) Downloaded 307 times
 
Re: sysex again, it´s geting complicated...
Hi
Yeah - sysex can get complicated . . .
And they certainly did not do any favours in there sysex steup - seems slightly non-standard to my eyes . .
The 8-bit encoding stuff is a bit weird but I do recall seeing it previously somewhere, and there checksum/length methods are a bit weird too . . .
Also it is usual that info is provided for 'requests' to the midi device and also for 'returned data' - I don't see any request info?
Once you sort how and when the device sends the 'Kit Message' data - whether by request or automatically from device? -
You need to capture the sysex via an 'OnMIDI - System Exclusive' script matching the MachineDrum header and Kit message data . . .
You then need a subarray of that data from position 0x0A - 16bits long = KitName - which needs to be convert with arraytostring to display as text rather than ASCII numbers
Selected Drum Model seems to be a data structure within the message -16*4byte ints - but I am not sure what the data is meant to represent . . .
Hope that helps
Cheers
MM
			
			
									
						
							Yeah - sysex can get complicated . . .
And they certainly did not do any favours in there sysex steup - seems slightly non-standard to my eyes . .
The 8-bit encoding stuff is a bit weird but I do recall seeing it previously somewhere, and there checksum/length methods are a bit weird too . . .
Also it is usual that info is provided for 'requests' to the midi device and also for 'returned data' - I don't see any request info?
Once you sort how and when the device sends the 'Kit Message' data - whether by request or automatically from device? -
You need to capture the sysex via an 'OnMIDI - System Exclusive' script matching the MachineDrum header and Kit message data . . .
You then need a subarray of that data from position 0x0A - 16bits long = KitName - which needs to be convert with arraytostring to display as text rather than ASCII numbers
Selected Drum Model seems to be a data structure within the message -16*4byte ints - but I am not sure what the data is meant to represent . . .
Hope that helps
Cheers
MM
iMac 2.8G i7 12G 10.6.8/10.7.2, Legacy Dexter/Lemur, Liine Lemur/iPad2, KMI SoftStep, 12Step & QuNeo , B-Controls, Mackie C4 etc
MaxMSP, Live Suite, Native Instrument stuff, etc Modified Virtual Guitar System etc All Projects/Modules © CC-BY-NC-SA[*][/b]
			
						MaxMSP, Live Suite, Native Instrument stuff, etc Modified Virtual Guitar System etc All Projects/Modules © CC-BY-NC-SA[*][/b]
Re: sysex again, it´s geting complicated...
Hi,
I´m that far to request the current kit data (which should include all of the kit data from the pdf) and to use the Monitor to display it on the lemur.
each of the values are the code for a "machine", there´s a sheet where you see what machine has what number, as soon as i have them numbers accessible i could write a script which outputs the name of the machine (for example: TRX-BD) compared to a number, should be easy.
how do i know what position in the sysexstring holds this values ?
thanks you, your help is very apprechiated!
cheers
			
			
									
						
										
						I´m that far to request the current kit data (which should include all of the kit data from the pdf) and to use the Monitor to display it on the lemur.
This data is meant to represent the current loaded machine on all 16 tracks, should look a lot like this:Selected Drum Model seems to be a data structure within the message -16*4byte ints - but I am not sure what the data is meant to represent . . .
Code: Select all
112,4,76,86...how do i know what position in the sysexstring holds this values ?
thanks you, your help is very apprechiated!
cheers
Re: sysex again, it´s geting complicated...
Hey,
with the arraytohex(array) script posted by mbncp (thank you), i was able to get the following data, which should represent the sysexdump i needed to get.
01 is the end of the header data, according to the  elektron sysex sheet 45 should hold 16 values representing my machines on the 16 tracks, if i´m right, once it´s 'unpacked', so they say in the manual.
so, assuming i´m right, how to "unpack" this data?
again, more than thankfull for any hints, code, whatever could help me
cheers,
martin
			
			
									
						
										
						with the arraytohex(array) script posted by mbncp (thank you), i was able to get the following data, which should represent the sysexdump i needed to get.
Code: Select all
00 20 3c 02 00 52 04 01 0B 4E 45 57 20 4B 49 54 00 30 12 00
so, assuming i´m right, how to "unpack" this data?
again, more than thankfull for any hints, code, whatever could help me

cheers,
martin
Re: sysex again, it´s geting complicated...
I think that they don't want you to fool with sysex, so they made it as difficult as possible 
Well, first you need to convert the blue part to 8 bits as it is coded in 7 bits. Most machines work with 8 bits (or 16,32,..) but for the MIDI spec all values larger than 7 bits are status byte, so you can't use them. The trick is to convert to 7 bits and back to 8 by using an extra byte that has the 8th bit value for the 7 following bytes.
I think bitwise operators are working on the lemur so that should be ok, so a function script could handle that.
But the problem I see here is the length of the data, I'm not even sure that the Lemur receives or can handle such big sysex message. Remember you figured out that the largest array size is 255 bytes. Are you receiving multiple arrays ?
And how do you get the data, is there some parameter request function ? As it doesn't seem documented on that pdf. Or do you have to trigger some function on the MD ?
On Korg machines you can query a single parameter which would be easier to deal with. Don't know about the MD.
			
			
									
						
										
						
Well, first you need to convert the blue part to 8 bits as it is coded in 7 bits. Most machines work with 8 bits (or 16,32,..) but for the MIDI spec all values larger than 7 bits are status byte, so you can't use them. The trick is to convert to 7 bits and back to 8 by using an extra byte that has the 8th bit value for the 7 following bytes.
I think bitwise operators are working on the lemur so that should be ok, so a function script could handle that.
But the problem I see here is the length of the data, I'm not even sure that the Lemur receives or can handle such big sysex message. Remember you figured out that the largest array size is 255 bytes. Are you receiving multiple arrays ?
And how do you get the data, is there some parameter request function ? As it doesn't seem documented on that pdf. Or do you have to trigger some function on the MD ?
On Korg machines you can query a single parameter which would be easier to deal with. Don't know about the MD.
Re: sysex again, it´s geting complicated...
hey, thanks for joining.
there´s actually an other option called kit sysex dump.
after 0x52 it requests Kit Data Bytes to be sent, any idea what that could be? maybe that´s how we could query single values?
cheers,
martin
edit: i attached a screenshot from the sysexpart in the manual.
			
							oh, i think that´s what they reffering to on page one, how the 7 bit encoding is generated?Well, first you need to convert the blue part to 8 bits as it is coded in 7 bits. Most machines work with 8 bits (or 16,32,..) but for the MIDI spec all values larger than 7 bits are status byte, so you can't use them. The trick is to convert to 7 bits and back to 8 by using an extra byte that has the 8th bit value for the 7 following bytes.
I think bitwise operators are working on the lemur so that should be ok, so a function script could handle that.
i´m not sure either, that´s what i´ve read on the web. i will contact the support and ask for clarification on this. would be a major bummer. mail sent.But the problem I see here is the length of the data, I'm not even sure that the Lemur receives or can handle such big sysex message. Remember you figured out that the largest array size is 255 bytes. Are you receiving multiple arrays ?
i send, what they call, a kit request. it´s a sysey string where i also send the number of the kit i want to have the data from. once i´ve send the request the machinedrum responds with an array of roughly 30 values in an array.And how do you get the data, is there some parameter request function ? As it doesn't seem documented on that pdf. Or do you have to trigger some function on the MD ?
there´s actually an other option called kit sysex dump.
after 0x52 it requests Kit Data Bytes to be sent, any idea what that could be? maybe that´s how we could query single values?
cheers,
martin
edit: i attached a screenshot from the sysexpart in the manual.
- Attachments
- 
			
		
		
				- sysexscreen.zip
- sysex screenshot
- (13.41 KiB) Downloaded 231 times
 
Re: sysex again, it´s geting complicated...
Do you have the doc concerning these request sys messages ?i send, what they call, a kit request. it´s a sysey string where i also send the number of the kit i want to have the data from. once i´ve send the request the machinedrum responds with an array of roughly 30 values in an array.
there´s actually an other option called kit sysex dump.
after 0x52 it requests Kit Data Bytes to be sent, any idea what that could be? maybe that´s how we could query single values?
Don't know what they mean by after, but 0x52 seems to be the Kit Message, declared in the header.
Re: sysex again, it´s getting complicated...
you´re right! Sadly i don´t have any more documents then the manual with all available sysex commands and the pdf attached in my first postDon't know what they mean by after, but 0x52 seems to be the Kit Message, declared in the header.

i tried to send the 0x52 command, the machinedrum receives but doesn´t send back anything then.
how would you go from here?
edit: added a picture of the lemur with the values sent from the MD
- Attachments
- 
			
		
		
				- Screen.PNG.zip
- received string from kit request
- (30.8 KiB) Downloaded 210 times
 
Re: sysex again, it´s geting complicated...
Ok, got it, all sysex commands are listed in the manual in appendix C. Kit dump command is 0x53 and it replies with 0x52.
Anyway, I will go thru that doc to see what's available, create the 7to8bits and 8to7 bits functions on the lemur and some helpers to extract those data.
As I don't have an MD I will probably need you to send me some stuff. Also it would be good to download a sysex librarian so you can send me the files I need to test.
As I think that you're on mac there is this one : http://www.snoize.com/SysExLibrarian/, should be fairly simple to use.
Once the functions are working, I'll post them here for reference, but in the meantime, I think it's better that we discuss and test this stuff off forum.
I'll pm you when I need something, just be aware that it may take a day or two as I'm a bit busy right now, and pray that I'm done before I get my tempest and little phatty
			
			
									
						
										
						Anyway, I will go thru that doc to see what's available, create the 7to8bits and 8to7 bits functions on the lemur and some helpers to extract those data.
As I don't have an MD I will probably need you to send me some stuff. Also it would be good to download a sysex librarian so you can send me the files I need to test.
As I think that you're on mac there is this one : http://www.snoize.com/SysExLibrarian/, should be fairly simple to use.
Once the functions are working, I'll post them here for reference, but in the meantime, I think it's better that we discuss and test this stuff off forum.
I'll pm you when I need something, just be aware that it may take a day or two as I'm a bit busy right now, and pray that I'm done before I get my tempest and little phatty

Re: sysex again, it´s geting complicated...
man, this is awesome!
i´ll supply whatever you need, just let me know and thanks for spending your time with this.
you sure will have some fun with your new toys
cheers,
martin
			
			
									
						
										
						i´ll supply whatever you need, just let me know and thanks for spending your time with this.
you sure will have some fun with your new toys

cheers,
martin