XML2PMX Readme
(***************************************************************************)
(****************Copyright 2015 -- 2020 Dieter Gloetzel ******************)
(***************************************************************************)
    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
    
	You should have received a copy of the GNU General Public License
    along with this program.  If not, see . 
	
1.  Introduction
	"MusicXML", ( http://www.musicxml.com/ ) originally developed by Recordare INC
	and now owned by Finale ( https://www.finalemusic.com/ ), is the leading 
	music data exchange format. XML2PMX provides an import facility for 
	sheet music stored in MusicXML format to PMX and MusiXTeX, the leading free 
	software for musical typesetting. Thus PMX is able to import published 
	MusicXML sources as well as MusicXML sources created by OCR scanning, 
	e.g. with Sharpeye of VISIV ( http://www.visiv.co.uk )or PhotoScore.
2. PMX  
	developed by Don Simons (dsimons(at)roadrunner(dot)com) is an easy to use, 
    yet powerful preprocessor for the musical typesetting system MusiXTeX.
        http://icking-music-archive.org/software/htdocs/index.html
	An excellent introduction to using PMX is
		http://icking-music-archive.org/software/pmx/pmxccn.pdf
	In order to work successfully with XML2PMX a good knowledge of 
	PMX is required, and of MusiXTeX will be helpful.
3. XML2PMX 
	has been developed by the author with "Oberon Plugin for Windows 
	Version 2.5" of ETHZ Zürich on Windows 10.
	https://github.com/Spirit-of-Oberon/ETH-Oberon-PlugIn-Win32
	and OLR (Oberon Linux Revival)
	http://oberon.wikidot.com/oberon-linux-revival-olr
	
    XML2PMX is available as Windows-EXE (32 Bit) and as Linux binary (32 Bit).
	XML2PMX requires a TeX, MusiXTeX and PMX installation.
	For Unix please see:   https://tug.org/texlive/
	For Windows please see: https://miktex.org/2.9/setup
	
4. Coverage of MusicXML features
	The following MusicXML features are detected and translated to PMX:
		- 24 staves/voices and 600 bars 
		- 83 notes per instrument and bar
    	- two voices per staff
    	- maximum of two staves per instrument
    	- notes and rests up to 64th, including tuplets and grace notes, 
    	- maximum of 2 dots
    	- chords, accidentals
    	- some annotations like Fermata, Staccato, Tremolo etc. 
    	- ties, slurs and beams
    	- definition of meter, fifths, clefs and their changes on the fly
    	- dynamic marks: hairpins, "ff" etc., piano damping pedal
    	- title and composer, and texts above or below the staff
    	- barlines, repeats, volta
    	- instrument names,
    	- Accepts Windows files  (records ended by 0DX OAX) 
		  as well as Unix files  (records ended by 0AX).
		- Resulting PMX-file on Unix has records ended by 0AX.
		- Resulting PMX-file on Windows has records ended by 0DX 0AX.
		- will not accept UTF16
	
5. Additional features:
	- command line input fields: "options" and "maxbar". 
	  "options" may contain one or several of the nine letters "pdvalstgr"
	  in arbitrary sequence in upper or lower case and without spaces.
	  Option "r" removes any note which has been marked in XML with  
	  print-object = "no".
	  "maxbar" is a limit on the number of bars to be processed. 
	  When maxbar = 0 then all bars will be processed.
	- With option = "L" Lyrics can be extracted and stored in a separate file: "songtext.txt".
	- Automatic detection of pickup
	
6. Limitations
	Some more elaborate situations like beams crossing staves or chords crossing staves
	have not yet been covered.
	MusicXML attributes are enclosed with double quotes.
7. Usage on MS Windows command line (quotes not required): 
    ============================================================================
	XML2PMX_2020.exe 
	"xml-file with path" "pmx-result-file with path" "output options" "maxbar"
	============================================================================
	There are two obligatory inputs: "xml-file" and "pmx-result-file".
	"output options" and "maxbar" are optional parameters. 
	"output options" contains a sequence (without blanks) of one or several of 
	the letters  "p", "d", "v", "a", "l", "r", "s", "t" and "g" .
	Their meaning is the following:
	 _____ _______________________________________________________
	|  p  | XML parser: can produce much output                   |
	|-------------------------------------------------------------|
	|  d  | information on "directions" (dynamical marks etc)     |
	|-------------------------------------------------------------|
	|  v  | distribution of voices over instruments and measures  |
	|-------------------------------------------------------------|
	|  a  | statistics of MusicXML tags like , ,   |
	|-------------------------------------------------------------|
	|  l  | extracts lyrics in a separate file                    |
	|-------------------------------------------------------------|
	|  s  | removes all slurs                                     |
	|-------------------------------------------------------------|
	|  t  | removes all ties                                      |
	|-------------------------------------------------------------|
	|  g  | uses PMX slur option inside grace note                |                 |
	|-------------------------------------------------------------|
	|  r  | remove Notes with Print-object = "no"                 |
    ---------------------------------------------------------------
	The generated PMX file will in general be complete and can be 
	processed by PMX.If not, you can often solve the problem with 
	minor changes in the PMX code. 
	Depending on the options chosen, you will find intermediate results in the 
	console window which may be helpful for debugging.
	
8.1 MusicXML test data 	
    You will find MusicXML-sources for testing under:
	http://www.musicxml.com/music-in-musicxml/example-set/
	
	The following pieces from this source (and a few more) have been tested:
	
	- Schubert: "Ave Maria" (Ellen’s Gesang III), D. 839 "SchbAvMaSample.xml"
	 
	- Beethoven: "An die ferne Geliebte", Op. 98 "BeetAnGeSample.xml"
	  
	- Mahler: "Lieder eines fahrenden Gesellen", "MahlFaGe4Sample.xml"
	
8.2 OCR scanned sheet music
	MusicXML results from the tool Sharpeye of VISIV 
	(http://www.visiv.co.uk/) have been tested successfully.
9.1 Contents for Windows:
	Main folder "XML2PMX_Windows_2020" contains:
		- this Readme.txt
		- Folder "XML", containing the MusicXML code of 
		  a Telemann Fantasy for Recorder: "Telemann.xml"
                - Folder "PMX", will take the test results  *.pmx, *.pdf 
		- Folder "example" with sample results for comparison  
		- Folder "source" with the Oberon source code for Windows
		- XML2PMX_2020.exe: Windows-Exe
		- GNU-GPL.txt: GNU Licence
        	- Runxml_Telemann.bat : sample batch file
9.2 Contents Linux:
	Main folder "XML2PMX_LINUX_2020" contains:
		- this Readme.txt
		- Folder "XML", containing the MusicXML code of 
		  a Telemann Fantasy for Recorder: "Telemann.xml" 
		- Folder "PMX" holds the test results *.pmx, *.pdf
		- Folder "example" with sample results for comparison
		- Folder "source" with the Oberon source code for LINUX
		- XML2PMX_2020: LINUX Binary
		- GNU-GPL.txt: GNU Licence
        	- RunTelemann : sample command
		
10. XML2PMX installation 
	10.1 Prerequisites: TeXLive installation on Unix or 
	     MikTeX installation on Windows  
	     including MusiXTeX and PMX.
	10.2 unpack the folder XML2PMX_LINUX_2020 
	     or XML2PMX_Windows_2020 to a convenient place.
	10.3 for Windows: register XML2PMX_2020.exe, i.e. doubleclick on 		     XML2PMX.reg.
        
	
11. Usage example
11.1 XML2PMX usage example Windows
	 double click on runxml_Telemann.bat
11.2 XML2PMX usage example Linux
	open a command line
	move to folder XML2PMX_LINUX_2020
	enter in the command line and execute:  ./RunTelemann
12. Contact: 
	Feel free to join me under  in order to report 	 errors, propose improvements or other comments.