个人工具

“UbuntuHelp:MidiSoftwareSynthesisHowTo”的版本间的差异

来自Ubuntu中文

跳转至: 导航, 搜索
第1行: 第1行:
 
{{From|https://help.ubuntu.com/community/MidiSoftwareSynthesisHowTo}}
 
{{From|https://help.ubuntu.com/community/MidiSoftwareSynthesisHowTo}}
 
{{Languages|UbuntuHelp:MidiSoftwareSynthesisHowTo}}
 
{{Languages|UbuntuHelp:MidiSoftwareSynthesisHowTo}}
 
 
 
Use this guide to get MIDI sound working unless:
 
Use this guide to get MIDI sound working unless:
a. you have a [[UbuntuHelp:SoundcardsWithHardwareSynth|soundcard with a linux-supported hardware synth]]
+
# you have a [[UbuntuHelp:SoundcardsWithHardwareSynth|soundcard with a linux-supported hardware synth]]
a. you are using external MIDI instruments
+
# you are using external MIDI instruments
 
Most people need to setup MIDI sound using software synthesis.
 
Most people need to setup MIDI sound using software synthesis.
 
 
There are two main programs that do software synthesis, TiMidity++ and Fluidsynth. The installation and setup of TiMidity++ is covered in the majority of this guide, since FluidSynth has a nice GUI for it.
 
There are two main programs that do software synthesis, TiMidity++ and Fluidsynth. The installation and setup of TiMidity++ is covered in the majority of this guide, since FluidSynth has a nice GUI for it.
 
 
=== Installing TiMidity++ ===
 
=== Installing TiMidity++ ===
 
 
==== Install TiMidity++ ====
 
==== Install TiMidity++ ====
 
You will need the Universe repository enabled (see AddingRepositoriesHowto). Install the package `timidity` (see SynapticHowto).
 
You will need the Universe repository enabled (see AddingRepositoriesHowto). Install the package `timidity` (see SynapticHowto).
 
 
==== Install samples ====
 
==== Install samples ====
 
Next you need a set of samples. The easiest way is to install package 'freepats' (a 28 MB download), and you're done. Note that this sample set is incomplete at the moment and doesn't cover the whole General MIDI standard yet.
 
Next you need a set of samples. The easiest way is to install package 'freepats' (a 28 MB download), and you're done. Note that this sample set is incomplete at the moment and doesn't cover the whole General MIDI standard yet.
 
 
If you want better sound, add the following repository line to your /etc/apt/sources.list file:
 
If you want better sound, add the following repository line to your /etc/apt/sources.list file:
 
<pre><nowiki>
 
<pre><nowiki>
第23行: 第16行:
 
</nowiki></pre>
 
</nowiki></pre>
 
You may then install the package 'eawpatches' (a 31 MB download). Alternatively, if you don't want to add this repository, you may download the package here: http://www.fbriere.net/debian/dists/etch/misc/deb/
 
You may then install the package 'eawpatches' (a 31 MB download). Alternatively, if you don't want to add this repository, you may download the package here: http://www.fbriere.net/debian/dists/etch/misc/deb/
 
 
Once you have installed the package, change the following line in the /etc/timidity/timidity.cfg file:
 
Once you have installed the package, change the following line in the /etc/timidity/timidity.cfg file:
 
<pre><nowiki>
 
<pre><nowiki>
第32行: 第24行:
 
source /etc/timidity/eawpatches.cfg
 
source /etc/timidity/eawpatches.cfg
 
</nowiki></pre>
 
</nowiki></pre>
 
 
To use other samples, read 'Finding and setting up a soundfont' below.
 
To use other samples, read 'Finding and setting up a soundfont' below.
 
 
==== See if midi plays ====
 
==== See if midi plays ====
 
Once you've done that, you can try playing a midi file:
 
Once you've done that, you can try playing a midi file:
第41行: 第31行:
 
</nowiki></pre>
 
</nowiki></pre>
 
If all is well, you should hear delicate strains of synthesised music. If you have problems, read 'Reducing CPU usage' below.
 
If all is well, you should hear delicate strains of synthesised music. If you have problems, read 'Reducing CPU usage' below.
 
 
=== Setting up TiMidity++ as a MIDI server ===
 
=== Setting up TiMidity++ as a MIDI server ===
 
 
Issue the following commands: You may not need all these (I found it worked with just the first two).
 
Issue the following commands: You may not need all these (I found it worked with just the first two).
 
<pre><nowiki>
 
<pre><nowiki>
第63行: 第51行:
 
</nowiki></pre>
 
</nowiki></pre>
 
To close TiMidity++, press CTRL-C in the terminal it's running in.
 
To close TiMidity++, press CTRL-C in the terminal it's running in.
 
 
Launching the server as root may improve performance because of higher priorities given to the process.
 
Launching the server as root may improve performance because of higher priorities given to the process.
 
 
Notedit, or your score editor of choice can then be loaded and recognised the midi ports.
 
Notedit, or your score editor of choice can then be loaded and recognised the midi ports.
 
 
If the computer is busy doing something else other than playing music, you may hear scratches or have latency problems. This might be solved with a realtime kernel patch, but that is out of the scope of this HOWTO. If you're running Feisty, there is a supported kernel image available to you if you install the package 'linux-lowlatency'.
 
If the computer is busy doing something else other than playing music, you may hear scratches or have latency problems. This might be solved with a realtime kernel patch, but that is out of the scope of this HOWTO. If you're running Feisty, there is a supported kernel image available to you if you install the package 'linux-lowlatency'.
 
 
=== Automatically starting TiMidity++ on boot ===
 
=== Automatically starting TiMidity++ on boot ===
 
 
Ubuntu sets up scripts in /etc/init.d when you install TiMidity++. To start it on boot, edit /etc/default/timidity and uncomment the line
 
Ubuntu sets up scripts in /etc/init.d when you install TiMidity++. To start it on boot, edit /etc/default/timidity and uncomment the line
 
<pre><nowiki>
 
<pre><nowiki>
第77行: 第60行:
 
</nowiki></pre>
 
</nowiki></pre>
 
You'll also need to add the modules you loaded earlier to /etc/modules.
 
You'll also need to add the modules you loaded earlier to /etc/modules.
 
 
=== Finding and setting up a soundfont ===
 
=== Finding and setting up a soundfont ===
 
 
Websites: http://www.personalcopy.com (try Unison.sf2) http://www.hammersound.net/ or look up soundfonts in a search engine. A big list may be found at http://timidity.s11.xrea.com/files/readme_cfgp.htm in which the fifth soundfont from the top (SGM-whatever) is quite complete for general use with TiMidity++.
 
Websites: http://www.personalcopy.com (try Unison.sf2) http://www.hammersound.net/ or look up soundfonts in a search engine. A big list may be found at http://timidity.s11.xrea.com/files/readme_cfgp.htm in which the fifth soundfont from the top (SGM-whatever) is quite complete for general use with TiMidity++.
 
 
If you end up with a file ending with .sfArk, it's compressed in an annoying proprietary format. You may need a windows machine to decompress it, depending which version they've used. Details at http://melodymachine.com/sfark.htm There is a Linux version available on the website.
 
If you end up with a file ending with .sfArk, it's compressed in an annoying proprietary format. You may need a windows machine to decompress it, depending which version they've used. Details at http://melodymachine.com/sfark.htm There is a Linux version available on the website.
 
 
Then you need to edit the file /etc/timidity/timidity.cfg and add the following line (edit as appropriate):
 
Then you need to edit the file /etc/timidity/timidity.cfg and add the following line (edit as appropriate):
 
 
<pre><nowiki>
 
<pre><nowiki>
 
soundfont /pathtothesoundfontfile/soundfontfile.sf2
 
soundfont /pathtothesoundfontfile/soundfontfile.sf2
 
</nowiki></pre>
 
</nowiki></pre>
 
 
=== sfArk on Linux ===
 
=== sfArk on Linux ===
 
 
If you need to decompress sfArk compressed Soundfonts whenever the Linux version of the extractor does not work, then you can easily install sfArk into linux using WINE.  If you don't have WINE installed on your machine then you can install it with the following command:
 
If you need to decompress sfArk compressed Soundfonts whenever the Linux version of the extractor does not work, then you can easily install sfArk into linux using WINE.  If you don't have WINE installed on your machine then you can install it with the following command:
 
<pre><nowiki>
 
<pre><nowiki>
第101行: 第77行:
 
</nowiki></pre>
 
</nowiki></pre>
 
sfArk also works beautifully in Crossover Office 5 as well.
 
sfArk also works beautifully in Crossover Office 5 as well.
 
 
 
=== Reducing CPU usage ===
 
=== Reducing CPU usage ===
 
 
If TiMidity++ uses too much CPU on your slow machine, and you're running a version prior to Breezy Badger, try adding these lines to the start of /etc/timidity/timidity.cfg (you may need to create this file)
 
If TiMidity++ uses too much CPU on your slow machine, and you're running a version prior to Breezy Badger, try adding these lines to the start of /etc/timidity/timidity.cfg (you may need to create this file)
 
<pre><nowiki>
 
<pre><nowiki>
第113行: 第86行:
 
opt EFdelay=d          #disable delay
 
opt EFdelay=d          #disable delay
 
</nowiki></pre>
 
</nowiki></pre>
 
 
On Breezy Badger and Dapper Drake, simply uncomment all the lines in the section of the file that deals with a slow CPU. However, one of the lines contains a mistake. The "opt no-antialias" line should read "opt --no-anti-alias" instead. Also, make "opt p32a" say "opt p64a" because 32 voices just isn't enough, and keep "opt s32kHz" commented out because it greatly reduces quality for no noticeable gain at all.
 
On Breezy Badger and Dapper Drake, simply uncomment all the lines in the section of the file that deals with a slow CPU. However, one of the lines contains a mistake. The "opt no-antialias" line should read "opt --no-anti-alias" instead. Also, make "opt p32a" say "opt p64a" because 32 voices just isn't enough, and keep "opt s32kHz" commented out because it greatly reduces quality for no noticeable gain at all.
 
 
=== FluidSynth ===
 
=== FluidSynth ===
 
If you wish to use FluidSynth instead, which is better for SoundFont files, there's a nice GUI front-end for it. The easiest way to use this on Feisty and above is to install the low-latency kernel (package "linux-lowlatency") and ''qsynth'', then reboot. Then run Qsynth from the Multimedia or Sound and Video menu.
 
If you wish to use FluidSynth instead, which is better for SoundFont files, there's a nice GUI front-end for it. The easiest way to use this on Feisty and above is to install the low-latency kernel (package "linux-lowlatency") and ''qsynth'', then reboot. Then run Qsynth from the Multimedia or Sound and Video menu.
 
 
It will probably complain about JACK not running, but JACK isn't required to run Qsynth. Change the audio output driver to "alsa" if you want to run it without JACK. Once you do this, you should be able to use any MIDI player to play MIDI files.
 
It will probably complain about JACK not running, but JACK isn't required to run Qsynth. Change the audio output driver to "alsa" if you want to run it without JACK. Once you do this, you should be able to use any MIDI player to play MIDI files.
 
 
=== Discussion ===
 
=== Discussion ===
 
 
Ask questions at [http://ubuntuforums.org/showthread.php?p=336935]
 
Ask questions at [http://ubuntuforums.org/showthread.php?p=336935]
 
 
----
 
----
 
[[category:CategoryDocumentation]]
 
[[category:CategoryDocumentation]]
  
 
[[category:UbuntuHelp]]
 
[[category:UbuntuHelp]]

2007年11月30日 (五) 20:17的版本


Use this guide to get MIDI sound working unless:

  1. you have a soundcard with a linux-supported hardware synth
  2. you are using external MIDI instruments

Most people need to setup MIDI sound using software synthesis. There are two main programs that do software synthesis, TiMidity++ and Fluidsynth. The installation and setup of TiMidity++ is covered in the majority of this guide, since FluidSynth has a nice GUI for it.

Installing TiMidity++

Install TiMidity++

You will need the Universe repository enabled (see AddingRepositoriesHowto). Install the package `timidity` (see SynapticHowto).

Install samples

Next you need a set of samples. The easiest way is to install package 'freepats' (a 28 MB download), and you're done. Note that this sample set is incomplete at the moment and doesn't cover the whole General MIDI standard yet. If you want better sound, add the following repository line to your /etc/apt/sources.list file:

deb http://www.fbriere.net/debian/dists/etch misc/

You may then install the package 'eawpatches' (a 31 MB download). Alternatively, if you don't want to add this repository, you may download the package here: http://www.fbriere.net/debian/dists/etch/misc/deb/ Once you have installed the package, change the following line in the /etc/timidity/timidity.cfg file:

source /etc/timidity/freepats.cfg

It should read:

source /etc/timidity/eawpatches.cfg

To use other samples, read 'Finding and setting up a soundfont' below.

See if midi plays

Once you've done that, you can try playing a midi file:

timidity myfile.mid

If all is well, you should hear delicate strains of synthesised music. If you have problems, read 'Reducing CPU usage' below.

Setting up TiMidity++ as a MIDI server

Issue the following commands: You may not need all these (I found it worked with just the first two).

sudo modprobe snd-seq-device
sudo modprobe snd-seq-midi
sudo modprobe snd-seq-oss
sudo modprobe snd-seq-midi-event
sudo modprobe snd-seq

This loads missing modules. Then enter:

timidity -iA -B2,8 -Os1l -s 44100

This loads TiMidity++ as a midi server and opens 2 midi ports, 128:0 and 128:1. After issuing it, you should have midi players working. You can open another terminal and issue a command such as:

pmidi -p 128:0 music.mid
kmid music.mid

To close TiMidity++, press CTRL-C in the terminal it's running in. Launching the server as root may improve performance because of higher priorities given to the process. Notedit, or your score editor of choice can then be loaded and recognised the midi ports. If the computer is busy doing something else other than playing music, you may hear scratches or have latency problems. This might be solved with a realtime kernel patch, but that is out of the scope of this HOWTO. If you're running Feisty, there is a supported kernel image available to you if you install the package 'linux-lowlatency'.

Automatically starting TiMidity++ on boot

Ubuntu sets up scripts in /etc/init.d when you install TiMidity++. To start it on boot, edit /etc/default/timidity and uncomment the line

TIM_ALSASEQ=true

You'll also need to add the modules you loaded earlier to /etc/modules.

Finding and setting up a soundfont

Websites: http://www.personalcopy.com (try Unison.sf2) http://www.hammersound.net/ or look up soundfonts in a search engine. A big list may be found at http://timidity.s11.xrea.com/files/readme_cfgp.htm in which the fifth soundfont from the top (SGM-whatever) is quite complete for general use with TiMidity++. If you end up with a file ending with .sfArk, it's compressed in an annoying proprietary format. You may need a windows machine to decompress it, depending which version they've used. Details at http://melodymachine.com/sfark.htm There is a Linux version available on the website. Then you need to edit the file /etc/timidity/timidity.cfg and add the following line (edit as appropriate):

soundfont /pathtothesoundfontfile/soundfontfile.sf2

sfArk on Linux

If you need to decompress sfArk compressed Soundfonts whenever the Linux version of the extractor does not work, then you can easily install sfArk into linux using WINE. If you don't have WINE installed on your machine then you can install it with the following command:

sudo apt-get install wine

Next, you must obtain sfArk from this URL listed above. Once you have WINE installed, all you must do is change to the directory where you have downloaded sfArk and issue the following command:

wine nameoffile

sfArk also works beautifully in Crossover Office 5 as well.

Reducing CPU usage

If TiMidity++ uses too much CPU on your slow machine, and you're running a version prior to Breezy Badger, try adding these lines to the start of /etc/timidity/timidity.cfg (you may need to create this file)

opt EFresamp=l          #use linear resampling
opt EFvlpf=d            #disable VLPF
opt EFreverb=d          #disable reverb
opt EFchorus=d          #disable chorus
opt EFdelay=d           #disable delay

On Breezy Badger and Dapper Drake, simply uncomment all the lines in the section of the file that deals with a slow CPU. However, one of the lines contains a mistake. The "opt no-antialias" line should read "opt --no-anti-alias" instead. Also, make "opt p32a" say "opt p64a" because 32 voices just isn't enough, and keep "opt s32kHz" commented out because it greatly reduces quality for no noticeable gain at all.

FluidSynth

If you wish to use FluidSynth instead, which is better for SoundFont files, there's a nice GUI front-end for it. The easiest way to use this on Feisty and above is to install the low-latency kernel (package "linux-lowlatency") and qsynth, then reboot. Then run Qsynth from the Multimedia or Sound and Video menu. It will probably complain about JACK not running, but JACK isn't required to run Qsynth. Change the audio output driver to "alsa" if you want to run it without JACK. Once you do this, you should be able to use any MIDI player to play MIDI files.

Discussion

Ask questions at [1]