summaryrefslogtreecommitdiff
path: root/audio/maplay/pkg/DESCR
diff options
context:
space:
mode:
Diffstat (limited to 'audio/maplay/pkg/DESCR')
-rw-r--r--audio/maplay/pkg/DESCR186
1 files changed, 186 insertions, 0 deletions
diff --git a/audio/maplay/pkg/DESCR b/audio/maplay/pkg/DESCR
new file mode 100644
index 00000000000..5eb691764c0
--- /dev/null
+++ b/audio/maplay/pkg/DESCR
@@ -0,0 +1,186 @@
+/*
+ * @(#) MPEG Audio Player maplay 1.2, last edit of this file: 6/23/94 13:02:49
+ * @(#) Copyright (C) 1993, 1994 Tobias Bading (bading@cs.tu-berlin.de)
+ * @(#) Berlin University of Technology
+ *
+ * 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 2 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, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+
+This is the README file of the MPEG Audio Player maplay, Version 1.2.
+Besides this file, you should now own a copy of the following files:
+
+ ANNOUNCEMENT the announcement for this release
+ INSTALL infos about compiling and installing the program
+ COPYING the GNU General Public License
+ Makefile a makefile
+ configuration.sh a shell script used by the makefile
+
+and the source files
+
+ all.h maplay.cc subband_layer_1.h
+ crc.cc obuffer.cc subband_layer_2.cc
+ crc.h obuffer.h subband_layer_2.h
+ header.cc scalefactors.cc synthesis_filter.cc
+ header.h scalefactors.h synthesis_filter.h
+ ibitstream.cc subband.h ulaw.cc
+ ibitstream.h subband_layer_1.cc ulaw.h
+
+-------------------------------------------------------------------------------
+
+0) Introduction
+
+MPEG is a standard created by the ISO (International Organization for
+Standardization) and the IEC (International Electrotechnical Commission).
+The full name of this standard is "ISO/IEC DIS 11172: Information
+Technology - Coding of moving pictures and associated audio for digital
+storage media ut to about 1.5 Mbit/s". As the name already states,
+it deals with digital video and audio. The video part of this standard has
+inspired many people to write decoders and a few encoders for it.
+Best known should be the Berkeley player. Players for the audio part on
+the other hand are very rare. The ones I know are the XING player for Windoze
+and a sample implementation of the ISO, which also includes an encoder.
+
+The audio part of the MPEG standard specifies three layers, whereat each
+layer specifies its own file format. All three layers are using similar
+audio coding techniques, but they vary in efficiency and complexity.
+Layer I needs the fewest calculation time for en-/decoding a stream, layer III
+the most. But a layer I MPEG audio stream is bigger than a layer III stream
+at the same quality. This program is able to decode and play only layer I
+and II streams, layer III is not supported (yet?!?).
+
+Like the MPEG video standard, the audio part also uses a lossy compression
+algorithm, which means that you can't get back 100% the original from a
+MPEG audio stream. Layer II MPEG audio streams are compressed by ratios
+from 1:3 up to 1:24 compared to raw PCM data, like on an audio CD.
+But the quality is still very (very) near to the original at ratios between
+1:5 and 1:12. You'll love it... :-)
+
+-------------------------------------------------------------------------------
+
+1) What does maplay?
+
+maplay version 1.2 is the second release of my MPEG audio player/decoder.
+It decodes layer I and layer II MPEG audio streams and plays them
+using a CD-quality audio device. Currently supported devices are the
+dbri device of SPARC 10 computers and the audio ports of Silicon
+Graphics Indigo machines. Thanks to Louis P. Kruger (lpkruger@phoenix.
+Princeton.EDU), maplay 1.2 can also use the /dev/dsp device under Linux.
+Louis has tested it with the Pro Audio Spectrum 16 soundcard. Sound Blaster 16
+and Gravis Ultrasound cards should also work, but a bug in the dsp driver
+prevents stereo playback on Gravis Ultrasound cards. An amd device of a
+SPARC 2/IPX/... machine can be used, too, but this device is only capable of
+producing audio output at 8 kHz in u-law format, which sounds like transmitted
+through a telephone. Other audio device are not supported directly, but can be
+used with the "decode to stdout" option and an audio format converter.
+Besides it shouldn't be a problem to adapt the program to other audio devices.
+
+The player supports all modes, which are single channel, stereo,
+joint stereo and dual channel, and all bitrates except free mode.
+The missing free mode support should not be a problem for now,
+because I haven't seen such a stream yet.
+
+maplay needs approximately 46% CPU time on SPARC 10/40 machines and 50%
+on Indigos for realtime stereo playback of a 44.1 kHz 128 kbit/s stream.
+Single channel playback needs about the half CPU time. On a SPARCstation IPX,
+maplay needs about 43% CPU time for realtime mono playback. Stereo playback
+is not possible via an amd device.
+
+Besides realtime playing of audio streams, maplay can decode streams to
+stdout for further conversions. The output consists of 16 bit signed PCM
+values. For stereo streams, the values are interleaved, which means that
+a value for the left channel is followed by a value for the right channel
+and so on. If maplay has been compiled for u-law output, the output consists
+of 8 bit u-law samples at a rate of 8 kHz, no matter what frequency the stream
+uses.
+
+-------------------------------------------------------------------------------
+
+2) How to create a maplay binary?
+
+Please read the install file for this topic.
+
+-------------------------------------------------------------------------------
+
+3) How to start the program?
+
+For a quick mono test enter "./maplay -v -l filename", where filename is the
+name of an audio stream, like "things.mp2". This stream has been posted along
+with the sources and is the beginning of Roxette's song "Things Will Never Be
+The Same". It is coded in joint stereo mode with 128 kbit/s, which is a
+compression ratio of 1:11. If the output is ok, you can test stereo playback
+by leaving out the -l option. If the stereo output stutters, the problem is
+not enough free CPU time in most cases. Stereo output is not possible when
+using an amd u-law device. If maplay shows error messages like
+"ioctl AUDIO_GETDEV on /dev/audio: ..."
+and maplay was compiled for u-law output, please try out the -amd option.
+This option forces maplay to treat /dev/audio as an amd device and may be
+required on SPARC clones.
+
+To convert a MPEG audio stream into other audio formats, you can use
+"maplay -v -s filename | your_converter". Unfortunately, I can't be of much
+help for you to find such a converter. The only good converter I know is the
+"soundfiler" on Indigos. But if you would have an Indigo, you wouldn't need a
+converter...
+
+-------------------------------------------------------------------------------
+
+4) Command line options
+
+maplay [-v] [-s] [-l] [-r] [-us] [-uh] [-ul] [-amd] [-c] [-f ushort] filename
+
+with these options:
+ filename filename of a MPEG audio stream or - for stdin
+ -h short help
+ -v verbose mode
+ You will get information about the stream, like mode, bitrate,
+ copyright etc., if you use this option.
+ -s stdout mode
+ This option tells the program to decode the stream to stdout.
+ The created output contains 16 bit signed PCM samples. If the
+ binary has been compiled for 8 kHz u-law format usage, the
+ output consists of 8 bit u-law samples at a 8 kHz rate. If the
+ stream is in stereo mode, the samples of both channels are
+ interleaved, the sample for the left channel first.
+ -l maplay decodes (and plays) the left channel of stereo streams
+ only. This option halves the required CPU time.
+ -r Same as above, but decodes the right channel only
+ -us, -uh These options are available on SPARCstations only.
+ They specify where the audio signal should be send to:
+ "-us" means speaker and "-uh" headphone jack.
+ -ul This option is available on machines with the dbri device
+ and sends the audio output to the line out jack.
+ -amd This option forces maplay to treat /dev/audio as an amd
+ device. Use it if your SPARC clone has an amd device, but
+ maplay doesn't recognize it. You may also use this option on a
+ machine with a dbri device, because the dbri device can also
+ produce u-law output. But I suggest to recompile the program
+ without the ULAW define in this case to get the CD-quality
+ output.
+ -c This option instructs the program to report filter range
+ violations to stderr. Sometimes PCM values calculated by
+ the synthesis filter exceede the 16 bit boundary and must
+ be mapped to these boundaries. If you can hear this, you
+ may use the next option.
+ -f ushort maplay uses this scalefactor instead of the default value 32768
+ for the synthesis filter. You can reduce or eliminate range
+ violations with this option, but lower scalefactor values
+ reduce the signal-to-noise ratio, too. I can't remember when
+ I used this option the last time myself.
+
+
+Ok, that's all for now and this release,
+I hope you like it,
+ Tobias Bading (bading@cs.tu-berlin.de)