Git init
authorKibum Kim <kb0929.kim@samsung.com>
Fri, 6 Jan 2012 16:12:02 +0000 (01:12 +0900)
committerKibum Kim <kb0929.kim@samsung.com>
Fri, 6 Jan 2012 16:12:02 +0000 (01:12 +0900)
183 files changed:
AUTHORS [new file with mode: 0644]
CHANGES [new file with mode: 0644]
COPYING [new file with mode: 0644]
LICENSE [new file with mode: 0644]
Makefile.am [new file with mode: 0644]
Makefile.in [new file with mode: 0644]
README [new file with mode: 0644]
SConstruct [new file with mode: 0644]
aclocal.m4 [new file with mode: 0644]
autogen.sh [new file with mode: 0755]
compile [new file with mode: 0755]
config.guess [new file with mode: 0755]
config.h.in [new file with mode: 0644]
config.sub [new file with mode: 0755]
configure [new file with mode: 0755]
configure.ac [new file with mode: 0644]
debian/README.Debian [new file with mode: 0644]
debian/changelog [new file with mode: 0644]
debian/compat [new file with mode: 0644]
debian/control [new file with mode: 0644]
debian/copyright [new file with mode: 0644]
debian/dirs [new file with mode: 0644]
debian/docs [new file with mode: 0644]
debian/libtheora-dev.install [new file with mode: 0644]
debian/libtheora0.install [new file with mode: 0644]
debian/rules [new file with mode: 0755]
depcomp [new file with mode: 0755]
doc/Doxyfile.in [new file with mode: 0644]
doc/Makefile.am [new file with mode: 0644]
doc/Makefile.in [new file with mode: 0644]
doc/color.html [new file with mode: 0644]
doc/draft-ietf-avt-rtp-theora-00.txt [new file with mode: 0644]
doc/draft-ietf-avt-rtp-theora-00.xml [new file with mode: 0644]
doc/spec/Makefile.am [new file with mode: 0644]
doc/spec/Makefile.in [new file with mode: 0644]
doc/spec/Theora.pdf [new file with mode: 0644]
doc/spec/fdct.fig [new file with mode: 0644]
doc/spec/hilbert-block.fig [new file with mode: 0644]
doc/spec/hilbert-mb.fig [new file with mode: 0644]
doc/spec/idct.fig [new file with mode: 0644]
doc/spec/lflim.fig [new file with mode: 0644]
doc/spec/ltablex.sty [new file with mode: 0644]
doc/spec/macroblock.fig [new file with mode: 0644]
doc/spec/pic-frame.fig [new file with mode: 0644]
doc/spec/pic_even.fig [new file with mode: 0644]
doc/spec/pic_even_odd.fig [new file with mode: 0644]
doc/spec/pic_odd.fig [new file with mode: 0644]
doc/spec/pic_odd_even.fig [new file with mode: 0644]
doc/spec/pixel420.fig [new file with mode: 0644]
doc/spec/pixel422.fig [new file with mode: 0644]
doc/spec/pixel444.fig [new file with mode: 0644]
doc/spec/raster-block.fig [new file with mode: 0644]
doc/spec/reference-frames.fig [new file with mode: 0644]
doc/spec/spec.bib [new file with mode: 0644]
doc/spec/spec.tex [new file with mode: 0644]
doc/spec/superblock.fig [new file with mode: 0644]
doc/spec/vp3huff.c [new file with mode: 0644]
doc/spec/xifish.fig [new file with mode: 0644]
doc/vp3-format.txt [new file with mode: 0644]
examples/Makefile.am [new file with mode: 0644]
examples/Makefile.in [new file with mode: 0644]
examples/dump_psnr.c [new file with mode: 0644]
examples/dump_video.c [new file with mode: 0644]
examples/encoder_example.c [new file with mode: 0644]
examples/player_example.c [new file with mode: 0644]
examples/png2theora.c [new file with mode: 0644]
include/Makefile.am [new file with mode: 0644]
include/Makefile.in [new file with mode: 0644]
include/theora/Makefile.am [new file with mode: 0644]
include/theora/Makefile.in [new file with mode: 0644]
include/theora/codec.h [new file with mode: 0644]
include/theora/theora.h [new file with mode: 0644]
include/theora/theoradec.h [new file with mode: 0644]
include/theora/theoraenc.h [new file with mode: 0644]
install-sh [new file with mode: 0755]
lib/Makefile.am [new file with mode: 0644]
lib/Makefile.in [new file with mode: 0644]
lib/Version_script [new file with mode: 0644]
lib/Version_script-dec [new file with mode: 0644]
lib/Version_script-enc [new file with mode: 0644]
lib/analyze.c [new file with mode: 0644]
lib/apiwrapper.c [new file with mode: 0644]
lib/apiwrapper.h [new file with mode: 0644]
lib/bitpack.c [new file with mode: 0644]
lib/bitpack.h [new file with mode: 0644]
lib/cpu.c [new file with mode: 0644]
lib/cpu.h [new file with mode: 0644]
lib/dct.h [new file with mode: 0644]
lib/decapiwrapper.c [new file with mode: 0644]
lib/decinfo.c [new file with mode: 0644]
lib/decint.h [new file with mode: 0644]
lib/decode.c [new file with mode: 0644]
lib/dequant.c [new file with mode: 0644]
lib/dequant.h [new file with mode: 0644]
lib/encapiwrapper.c [new file with mode: 0644]
lib/encfrag.c [new file with mode: 0644]
lib/encinfo.c [new file with mode: 0644]
lib/encint.h [new file with mode: 0644]
lib/encode.c [new file with mode: 0644]
lib/encoder_disabled.c [new file with mode: 0644]
lib/enquant.c [new file with mode: 0644]
lib/enquant.h [new file with mode: 0644]
lib/fdct.c [new file with mode: 0644]
lib/fragment.c [new file with mode: 0644]
lib/huffdec.c [new file with mode: 0644]
lib/huffdec.h [new file with mode: 0644]
lib/huffenc.c [new file with mode: 0644]
lib/huffenc.h [new file with mode: 0644]
lib/huffman.h [new file with mode: 0644]
lib/idct.c [new file with mode: 0644]
lib/info.c [new file with mode: 0644]
lib/internal.c [new file with mode: 0644]
lib/internal.h [new file with mode: 0644]
lib/mathops.c [new file with mode: 0644]
lib/mathops.h [new file with mode: 0644]
lib/mcenc.c [new file with mode: 0644]
lib/modedec.h [new file with mode: 0644]
lib/ocintrin.h [new file with mode: 0644]
lib/quant.c [new file with mode: 0644]
lib/quant.h [new file with mode: 0644]
lib/rate.c [new file with mode: 0644]
lib/state.c [new file with mode: 0644]
lib/theora.exp [new file with mode: 0644]
lib/theoradec.exp [new file with mode: 0644]
lib/theoraenc.exp [new file with mode: 0644]
lib/tokenize.c [new file with mode: 0644]
lib/x86/mmxencfrag.c [new file with mode: 0644]
lib/x86/mmxfdct.c [new file with mode: 0644]
lib/x86/mmxfrag.c [new file with mode: 0644]
lib/x86/mmxfrag.h [new file with mode: 0644]
lib/x86/mmxidct.c [new file with mode: 0644]
lib/x86/mmxloop.h [new file with mode: 0644]
lib/x86/mmxstate.c [new file with mode: 0644]
lib/x86/sse2fdct.c [new file with mode: 0644]
lib/x86/x86enc.c [new file with mode: 0644]
lib/x86/x86enc.h [new file with mode: 0644]
lib/x86/x86int.h [new file with mode: 0644]
lib/x86/x86state.c [new file with mode: 0644]
lib/x86_vc/mmxencfrag.c [new file with mode: 0644]
lib/x86_vc/mmxfdct.c [new file with mode: 0644]
lib/x86_vc/mmxfrag.c [new file with mode: 0644]
lib/x86_vc/mmxfrag.h [new file with mode: 0644]
lib/x86_vc/mmxidct.c [new file with mode: 0644]
lib/x86_vc/mmxloop.h [new file with mode: 0644]
lib/x86_vc/mmxstate.c [new file with mode: 0644]
lib/x86_vc/x86enc.c [new file with mode: 0644]
lib/x86_vc/x86enc.h [new file with mode: 0644]
lib/x86_vc/x86int.h [new file with mode: 0644]
lib/x86_vc/x86state.c [new file with mode: 0644]
libtheora.spec.in [new file with mode: 0644]
ltmain.sh [new file with mode: 0755]
m4/Makefile.am [new file with mode: 0644]
m4/Makefile.in [new file with mode: 0644]
m4/as-ac-expand.m4 [new file with mode: 0644]
m4/ogg.m4 [new file with mode: 0644]
m4/pkg.m4 [new file with mode: 0644]
m4/sdl.m4 [new file with mode: 0644]
m4/vorbis.m4 [new file with mode: 0644]
macosx/English.lproj/InfoPlist.strings [new file with mode: 0644]
macosx/Info.plist [new file with mode: 0644]
macosx/Theora.xcodeproj/project.pbxproj [new file with mode: 0644]
macosx/Theora_Prefix.pch [new file with mode: 0644]
missing [new file with mode: 0755]
mkinstalldirs [new file with mode: 0755]
packaging/libtheora.spec [new file with mode: 0644]
symbian/bld.inf [new file with mode: 0644]
symbian/config.h [new file with mode: 0644]
symbian/theora.mmp [new file with mode: 0644]
tests/Makefile.am [new file with mode: 0644]
tests/Makefile.in [new file with mode: 0644]
tests/comment.c [new file with mode: 0644]
tests/comment_theora.c [new file with mode: 0644]
tests/granulepos.c [new file with mode: 0644]
tests/granulepos_theora.c [new file with mode: 0644]
tests/noop.c [new file with mode: 0644]
tests/noop_theora.c [new file with mode: 0644]
tests/tests.h [new file with mode: 0644]
theora-uninstalled.pc.in [new file with mode: 0644]
theora.pc.in [new file with mode: 0644]
theoradec-uninstalled.pc.in [new file with mode: 0644]
theoradec.pc.in [new file with mode: 0644]
theoraenc-uninstalled.pc.in [new file with mode: 0644]
theoraenc.pc.in [new file with mode: 0644]

diff --git a/AUTHORS b/AUTHORS
new file mode 100644 (file)
index 0000000..493eef3
--- /dev/null
+++ b/AUTHORS
@@ -0,0 +1,49 @@
+Monty <monty@xiph.org>
+       - Original VP3 port
+
+Ralph Giles
+Timothy B. Terriberry
+Monty
+       - Ongoing development
+       
+Dan B. Miller
+       - Pre alpha3 development
+       
+Rudolf Marek
+Wim Tayman
+Dan Lenski
+Nils Pipenbrinck
+Monty
+       - MMX optimized functions
+       
+Aaron Colwell
+Thomas Vander Stichele
+Jan Gerber
+Conrad Parker
+Cristian Adam
+Sebastian Pippin
+Simon Hosie
+       - Bug fixes, enhancements, build systems.
+       
+Mauricio Piacentini
+       - Original win32 projects and example ports
+       - VP3->Theora transcoder
+
+Silvia Pfeiffer
+       - Figures for the spec
+
+Michael Smith
+Andre Pang
+calc
+Chris Cheney
+Brendan Cully
+Edward Hervey
+Adam Moss
+Colin Ward
+Jeremy C. Reed
+Arc Riley
+Rodolphe Ortalo
+       - Bug fixes
+
+
+and other Xiph.org contributors
diff --git a/CHANGES b/CHANGES
new file mode 100644 (file)
index 0000000..b30327e
--- /dev/null
+++ b/CHANGES
@@ -0,0 +1,231 @@
+libtheora 1.1.1 (2009 October 1)
+
+ - Fix problems with MSVC inline assembly
+ - Add the missing encoder_disabled.c to the distribution
+ - build updates: autogen.sh should work better after switching systems
+   and the MSVC project now defaults to the dynamic runtime library
+ - Namespace some variables to avoid conflicts on wince.
+
+libtheora 1.1.0 (2009 September 24)
+
+ - Fix various small issues with the example and telemetry code
+ - Fix handing a zero-byte packet as the first frame
+ - Documentation cleanup
+ - Two minor build fixes
+
+libtheora 1.1beta3 (2009 August 22)
+
+ - Rate control fixes to smooth quality
+ - MSVC build now exports all of the 1.0 api
+ - Assorted small bug fixes
+
+libtheora 1.1beta2 (2009 August 12)
+
+ - Fix a rate control problem with difficult input
+ - Build fixes for OpenBSD and Apple Xcode
+ - Examples now all use the 1.0 api
+ - TH_ENCCTL_SET_SPLEVEL works again
+ - Various bug fixes and source tree rearrangement
+
+libtheora 1.1beta1 (2009 August 5)
+
+ - Support for two-pass encoding
+ - Performance optimization of both encoder and decoder
+ - Encoder supports dynamic adjustment of quality and 
+   bitrate targets
+ - Encoder is generally more configurable, and all
+   rate control modes perform better
+ - Encoder now accepts 4:2:2 and 4:4:4 chroma sampling
+ - Decoder telemetry output shows quantization choice
+   and a breakdown of bitrate usage in the frame
+ - MSVC assembly optimizations up to date and functional
+
+libtheora 1.1alpha2 (2009 May 26)
+
+ - Reduce lambda for small quantizers.
+ - New encoder fDCT does better on smooth gradients
+ - Use SATD for mode decisions (1-2% bitrate reduction)
+ - Assembly rewrite for new features and general speed up
+ - Share code between the encoder and decoder for performance
+ - Fix 4:2:2 decoding and telemetry
+ - MSVC project files updated, but assembly is disabled.
+ - New configure option --disable-spec to work around toolchain
+   detection failures.
+ - Limit symbol exports on MacOS X.
+ - Port remaining unit tests from the 1.0 release.
+
+libtheora 1.1alpha1 (2009 March 27)
+
+ - Encoder rewrite with much improved vbr quality/bitrate and
+   better tracking of the target rate in cbr mode.
+ - MSVC project files do not work in this release.
+
+libtheora 1.0 (2008 November 3)
+
+ - Merge x86 assembly for forward DCT from Thusnelda branch.
+ - Update 32 bit MMX with loop filter fix.
+ - Check for an uninitialized state before dereferencing in propagating
+   decode calls.
+ - Remove all TH_DEBUG statements.
+ - Rename the bitpacker source files copied from libogg to avoid
+   confusing simple build systems using both libraries.
+ - Declare bitfield entries to be explicitly signed for Solaris cc.
+ - Set quantization parameters to default values when an empty buffer is
+   passed with TH_ENCCTL_SET_QUANT_PARAMS.
+ - Split encoder and decoder tests depending on configure settings.
+ - Return lstylex.sty to the distribution.
+ - Disable inline assembly on gcc versions prior to 3.1.
+ - Remove extern references for OC_*_QUANT_MIN.
+ - Make various data tables static const so they can be read-only.
+ - Remove ENCCTL codes from the old encoder API.
+ - Implement TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE ctl.
+ - Fix segfault when exactly one of the width or height is not a multiple
+   of 16, but the other is.
+ - Compute the correct vertical offset for chroma.
+ - cpuid assembly fix for MSVC.
+ - Add VS2008 project files.
+ - Build updates for 64-bit platforms, Mingw32, VS and XCode.
+ - Do not clobber the cropping rectangle.
+ - Declare ourselves 1.0final to pkg-config to sort after beta releases.
+ - Fix the scons build to include asm in libtheoradec/enc.
+
+libtheora 1.0beta3 (2008 April 16)
+
+ - Build new libtheoradec and libtheoraenc libraries
+   supporting the new API from theora-exp. This API should
+   not be considered stable yet.
+ - Change granule_frame() to return an index as documented.
+   This is a change of behaviour from 1.0beta1.
+ - Document that granule_time() returns the end of the
+   presentation interval.
+ - Use a custom copy of the libogg bitpacker in the decoder
+   to avoid function call overhead.
+ - MMX code improved and ported to MSVC.
+ - Fix a problem with the MMX code on SELinux.
+ - Fix a problem with decoder quantizer initialization.
+ - Fix a page queue problem with png2theora.
+ - Improved robustness.
+ - Updated VS2005 project files.
+ - Dropped build support for Microsoft VS2003.
+ - Dropped build support for the unreleased libogg2.
+ - Added the specification to the autotools build.
+ - Specification corrections.
+
+libtheora 1.0beta2 (2007 October 12)
+
+ - Fix a crash bug on char-is-unsigned architectures (PowerPC)
+ - Fix a buffer sizing issue that caused rare encoder crashes
+ - Fix a buffer alignment issue
+ - Build fixes for MingW32, MSVC
+ - Improved format documentation.
+
+libtheora 1.0beta1 (2007 September 22)
+
+ - Granulepos scheme modified to match other codecs. This bumps
+   the bitstream revision to 3.2.1. Bitstreams marked 3.2.0 are
+   handled correctly by this decoder. Older decoders will show
+   a one frame sync error in the less noticable direction.
+
+libtheora 1.0alpha8 (2007 September 18)
+
+ - Switch to new spec compliant decoder from theora-exp branch.
+   Written by Dr. Timothy Terriberry.
+ - Add support to the encoder for using quantization settings
+   provided by the application.
+ - more assembly optimizations
+
+libtheora 1.0alpha7 (2006 June 20)
+
+ - Enable mmx assembly by default
+ - Avoid some relocations that caused problems on SELinux
+ - Other build fixes
+ - time testing mode (-f) for the dump_video example
+
+libtheora 1.0alpha6 (2006 May 30)
+
+ * Merge theora-mmx simd acceleration (x86_32 and x86_64)
+ * Major RTP payload specification update
+ * Minor format specification updates
+ * Fix some spurious calls to free() instead of _ogg_free()
+ * Fix invalid array indexing in PixelLineSearch()
+ * Improve robustness against invalid input
+ * General warning cleanup
+ * The offset_y member now means what every application thought it meant
+   (offset from the top). This will mean some old files (those with a 
+   non-centered image created with a buggy encoder) will display differently.
+
+libtheora 1.0alpha5 (2005 August 20)
+
+ * Fixed bitrate management bugs that caused popping and encode
+   errors
+ * Fixed a crash problem with the theora_state internals not
+   being intialized properly.
+ * new utility function:
+   - theora_granule_shift()
+ * dump_video example now makes YUV4MPEG files by default, so
+   the results can be fed back to encoder_example and similar
+   tools. The old behavior is restored through the '-r' switch.
+ * ./configure now prints a summary
+ * simple unit test of the comment api under 'make check'
+ * misc code cleanup, warning and leak fixes
+
+libtheora 1.0alpha4 (2004 December 15)
+
+ * first draft of the Theora I Format Specification
+ * API documentation generated from theora.h with Doxygen
+ * fix a double-update bug in the motion analysis
+ * apply the loop filter before filling motion vector border 
+   in the reference frame
+ * new utility functions:
+   - theora_packet_isheader(),
+   - theora_packet_iskeyframe()
+   - theora_granule_frame()
+ * optional support for building without floating point
+ * optional support for building without encode support 
+ * various build and packaging fixes
+ * pkg-config support
+ * SymbianOS build support
+
+libtheora 1.0alpha3 (2004 March 20)
+
+ UPDATE: on 2004 July 1 the Theora I bitstream format was frozen. Files
+ produced by the libtheora 1.0alpha3 reference encoder will always be
+ decodable by the Theora I spec.
+
+ * Bitstream info header FORMAT CHANGES:
+   - move the granulepos shift field to maintain byte alignment longer.
+   - reserve 5 additional bits for subsampling and interlace flags.
+ * Bitstream setup header FORMAT CHANGES:
+   - support for a range of interpolated quant matricies.
+   - include the in-loop block filter coeff.
+ * Bitsteam data packet FORMAT CHANGES:
+   - Reserve a bit for per-block Q index selection.
+   - Flip the coded image orientation for compatibility with VP3.
+     This allows lossless transcoding of VP3 content, but files
+     encoded with earlier theora releases would play upside down.
+ * example VP3 lossless transcoder
+ * optional support for libogg2
+ * timing improvements in the example player
+ * packaging and build system updates and fixes
+
+libtheora 1.0alpha2 (2003 June 9)
+
+ * bitstream FORMAT CHANGES:
+   - store the quant tables in a third setup header for
+     future encoder flexibility
+   - store the huffman tables in the third setup header
+   - add a field for marking the colorspace to the info header
+   - add crop parameters for non-multiple-of-16 frame sizes
+   - add a second vorbiscomment-style metadata header
+ * API changes to handle multiple headers with a single 
+   theora_decode_header() call, like libvorbis
+ * code cleanup and minor fixes
+ * new dump_video code example/utility
+ * experimental win32 code examples
+
+libtheora 1.0alpha1 (2002 September 25)
+
+ * First release of the theora reference implementation
+ * Port of the newly opened VP3 code to the Ogg container
+ * Rewrite of the code for portability and to use the libogg bitpacker
+
diff --git a/COPYING b/COPYING
new file mode 100644 (file)
index 0000000..c8ccce4
--- /dev/null
+++ b/COPYING
@@ -0,0 +1,28 @@
+Copyright (C) 2002-2009 Xiph.org Foundation
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions
+are met:
+
+- Redistributions of source code must retain the above copyright
+notice, this list of conditions and the following disclaimer.
+
+- Redistributions in binary form must reproduce the above copyright
+notice, this list of conditions and the following disclaimer in the
+documentation and/or other materials provided with the distribution.
+
+- Neither the name of the Xiph.org Foundation nor the names of its
+contributors may be used to endorse or promote products derived from
+this software without specific prior written permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION
+OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/LICENSE b/LICENSE
new file mode 100644 (file)
index 0000000..5e5ec08
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,18 @@
+Please see the file COPYING for the copyright license for this software.
+
+In addition to and irrespective of the copyright license associated
+with this software, On2 Technologies, Inc. makes the following statement
+regarding technology used in this software:
+
+  On2 represents and warrants that it shall not assert any rights 
+  relating to infringement of On2's registered patents, nor initiate
+  any litigation asserting such rights, against any person who, or
+  entity which utilizes the On2 VP3 Codec Software, including any 
+  use, distribution, and sale of said Software; which make changes, 
+  modifications, and improvements in said Software; and to use,
+  distribute, and sell said changes as well as applications for other 
+  fields of use.
+
+This reference implementation is originally derived from the On2 VP3
+Codec Software, and the Theora video format is essentially compatible
+with the VP3 video format, consisting of a backward-compatible superset.
diff --git a/Makefile.am b/Makefile.am
new file mode 100644 (file)
index 0000000..5b48188
--- /dev/null
@@ -0,0 +1,35 @@
+## Process this file with automake to produce Makefile.in
+
+AUTOMAKE_OPTIONS = foreign 1.6 dist-zip dist-bzip2
+
+if THEORA_ENABLE_EXAMPLES
+EXAMPLES_DIR = examples
+else
+EXAMPLES_DIR =
+endif
+
+SUBDIRS = lib include doc tests m4 $(EXAMPLES_DIR)
+
+
+# we include the whole debian/ dir in EXTRA_DIST because there's a problem
+# with autotools and HFS+ MacOSX file systems that caused debian/Makefile.am
+# to pick up on the lowercase changelog file and add ChangeLog to DIST_COMMON
+# because of it, breaking make dist.  This works just as well.
+EXTRA_DIST = \
+       README CHANGES COPYING LICENSE \
+       autogen.sh macosx symbian SConstruct \
+       libtheora.spec libtheora.spec.in \
+       theora-uninstalled.pc.in
+
+pkgconfigdir = $(libdir)/pkgconfig
+pkgconfig_DATA = theora.pc theoradec.pc theoraenc.pc
+
+# Remove the .svn folders included in the tarball
+dist-hook:
+       find $(distdir) -type d -name '.svn' | xargs rm -rf
+
+debug:
+       $(MAKE) all CFLAGS="@DEBUG@"
+
+profile:
+       $(MAKE) all CFLAGS="@PROFILE@"
diff --git a/Makefile.in b/Makefile.in
new file mode 100644 (file)
index 0000000..524f0cb
--- /dev/null
@@ -0,0 +1,597 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = .
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+
+AUTOMAKE_OPTIONS = foreign 1.6 dist-zip dist-bzip2
+
+@THEORA_ENABLE_EXAMPLES_TRUE@EXAMPLES_DIR = examples
+@THEORA_ENABLE_EXAMPLES_FALSE@EXAMPLES_DIR = 
+
+SUBDIRS = lib include doc tests m4 $(EXAMPLES_DIR)
+
+# we include the whole debian/ dir in EXTRA_DIST because there's a problem
+# with autotools and HFS+ MacOSX file systems that caused debian/Makefile.am
+# to pick up on the lowercase changelog file and add ChangeLog to DIST_COMMON
+# because of it, breaking make dist.  This works just as well.
+EXTRA_DIST = \
+       README CHANGES COPYING LICENSE \
+       autogen.sh win32 macosx symbian SConstruct \
+       libtheora.spec libtheora.spec.in \
+       theora-uninstalled.pc.in
+
+
+pkgconfigdir = $(libdir)/pkgconfig
+pkgconfig_DATA = theora.pc theoradec.pc theoraenc.pc
+subdir = .
+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = config.h
+CONFIG_CLEAN_FILES = libtheora.spec theora.pc theora-uninstalled.pc \
+       theoradec.pc theoradec-uninstalled.pc theoraenc.pc \
+       theoraenc-uninstalled.pc
+DIST_SOURCES =
+DATA = $(pkgconfig_DATA)
+
+
+RECURSIVE_TARGETS = info-recursive dvi-recursive install-info-recursive \
+       uninstall-info-recursive all-recursive install-data-recursive \
+       install-exec-recursive installdirs-recursive install-recursive \
+       uninstall-recursive check-recursive installcheck-recursive
+DIST_COMMON = README AUTHORS COPYING Makefile.am Makefile.in aclocal.m4 \
+       compile config.guess config.h.in config.sub configure \
+       configure.ac depcomp install-sh libtheora.spec.in ltmain.sh \
+       missing mkinstalldirs theora-uninstalled.pc.in theora.pc.in \
+       theoradec-uninstalled.pc.in theoradec.pc.in \
+       theoraenc-uninstalled.pc.in theoraenc.pc.in
+DIST_SUBDIRS = lib include doc tests m4 examples
+all: config.h
+       $(MAKE) $(AM_MAKEFLAGS) all-recursive
+
+.SUFFIXES:
+
+am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
+ configure.lineno
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --foreign  Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)
+
+$(top_builddir)/config.status: $(srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+       $(SHELL) ./config.status --recheck
+$(srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(srcdir)/configure.ac $(ACLOCAL_M4) $(CONFIGURE_DEPENDENCIES)
+       cd $(srcdir) && $(AUTOCONF)
+
+$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ configure.ac 
+       cd $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS)
+
+config.h: stamp-h1
+       @if test ! -f $@; then \
+         rm -f stamp-h1; \
+         $(MAKE) stamp-h1; \
+       else :; fi
+
+stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status
+       @rm -f stamp-h1
+       cd $(top_builddir) && $(SHELL) ./config.status config.h
+
+$(srcdir)/config.h.in: @MAINTAINER_MODE_TRUE@ $(top_srcdir)/configure.ac $(ACLOCAL_M4) 
+       cd $(top_srcdir) && $(AUTOHEADER)
+       touch $(srcdir)/config.h.in
+
+distclean-hdr:
+       -rm -f config.h stamp-h1
+libtheora.spec: $(top_builddir)/config.status libtheora.spec.in
+       cd $(top_builddir) && $(SHELL) ./config.status $@
+theora.pc: $(top_builddir)/config.status theora.pc.in
+       cd $(top_builddir) && $(SHELL) ./config.status $@
+theora-uninstalled.pc: $(top_builddir)/config.status theora-uninstalled.pc.in
+       cd $(top_builddir) && $(SHELL) ./config.status $@
+theoradec.pc: $(top_builddir)/config.status theoradec.pc.in
+       cd $(top_builddir) && $(SHELL) ./config.status $@
+theoradec-uninstalled.pc: $(top_builddir)/config.status theoradec-uninstalled.pc.in
+       cd $(top_builddir) && $(SHELL) ./config.status $@
+theoraenc.pc: $(top_builddir)/config.status theoraenc.pc.in
+       cd $(top_builddir) && $(SHELL) ./config.status $@
+theoraenc-uninstalled.pc: $(top_builddir)/config.status theoraenc-uninstalled.pc.in
+       cd $(top_builddir) && $(SHELL) ./config.status $@
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+pkgconfigDATA_INSTALL = $(INSTALL_DATA)
+install-pkgconfigDATA: $(pkgconfig_DATA)
+       @$(NORMAL_INSTALL)
+       $(mkinstalldirs) $(DESTDIR)$(pkgconfigdir)
+       @list='$(pkgconfig_DATA)'; for p in $$list; do \
+         if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " $(pkgconfigDATA_INSTALL) $$d$$p $(DESTDIR)$(pkgconfigdir)/$$f"; \
+         $(pkgconfigDATA_INSTALL) $$d$$p $(DESTDIR)$(pkgconfigdir)/$$f; \
+       done
+
+uninstall-pkgconfigDATA:
+       @$(NORMAL_UNINSTALL)
+       @list='$(pkgconfig_DATA)'; for p in $$list; do \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " rm -f $(DESTDIR)$(pkgconfigdir)/$$f"; \
+         rm -f $(DESTDIR)$(pkgconfigdir)/$$f; \
+       done
+
+# This directory's subdirectories are mostly independent; you can cd
+# into them and run `make' without going through this Makefile.
+# To change the values of `make' variables: instead of editing Makefiles,
+# (1) if the variable is set in `config.status', edit `config.status'
+#     (which will cause the Makefiles to be regenerated when you run `make');
+# (2) otherwise, pass the desired values on the `make' command line.
+$(RECURSIVE_TARGETS):
+       @set fnord $$MAKEFLAGS; amf=$$2; \
+       dot_seen=no; \
+       target=`echo $@ | sed s/-recursive//`; \
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         echo "Making $$target in $$subdir"; \
+         if test "$$subdir" = "."; then \
+           dot_seen=yes; \
+           local_target="$$target-am"; \
+         else \
+           local_target="$$target"; \
+         fi; \
+         (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+          || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
+       done; \
+       if test "$$dot_seen" = "no"; then \
+         $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
+       fi; test -z "$$fail"
+
+mostlyclean-recursive clean-recursive distclean-recursive \
+maintainer-clean-recursive:
+       @set fnord $$MAKEFLAGS; amf=$$2; \
+       dot_seen=no; \
+       case "$@" in \
+         distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
+         *) list='$(SUBDIRS)' ;; \
+       esac; \
+       rev=''; for subdir in $$list; do \
+         if test "$$subdir" = "."; then :; else \
+           rev="$$subdir $$rev"; \
+         fi; \
+       done; \
+       rev="$$rev ."; \
+       target=`echo $@ | sed s/-recursive//`; \
+       for subdir in $$rev; do \
+         echo "Making $$target in $$subdir"; \
+         if test "$$subdir" = "."; then \
+           local_target="$$target-am"; \
+         else \
+           local_target="$$target"; \
+         fi; \
+         (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+          || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
+       done && test -z "$$fail"
+tags-recursive:
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \
+       done
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS: tags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         if test "$$subdir" = .; then :; else \
+           test -f $$subdir/TAGS && tags="$$tags -i $$here/$$subdir/TAGS"; \
+         fi; \
+       done; \
+       list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = .
+distdir = $(PACKAGE)-$(VERSION)
+
+am__remove_distdir = \
+  { test ! -d $(distdir) \
+    || { find $(distdir) -type d ! -perm -200 -exec chmod u+w {} ';' \
+         && rm -fr $(distdir); }; }
+
+GZIP_ENV = --best
+distcleancheck_listfiles = find . -type f -print
+
+distdir: $(DISTFILES)
+       $(am__remove_distdir)
+       mkdir $(distdir)
+       $(mkinstalldirs) $(distdir)/. $(distdir)/doc
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+       list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
+         if test "$$subdir" = .; then :; else \
+           test -d $(distdir)/$$subdir \
+           || mkdir $(distdir)/$$subdir \
+           || exit 1; \
+           (cd $$subdir && \
+             $(MAKE) $(AM_MAKEFLAGS) \
+               top_distdir="$(top_distdir)" \
+               distdir=../$(distdir)/$$subdir \
+               distdir) \
+             || exit 1; \
+         fi; \
+       done
+       $(MAKE) $(AM_MAKEFLAGS) \
+         top_distdir="${top_distdir}" distdir="$(distdir)" \
+         dist-hook
+       -find $(distdir) -type d ! -perm -777 -exec chmod a+rwx {} \; -o \
+         ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
+         ! -type d ! -perm -400 -exec chmod a+r {} \; -o \
+         ! -type d ! -perm -444 -exec $(SHELL) $(install_sh) -c -m a+r {} {} \; \
+       || chmod -R a+r $(distdir)
+dist-gzip: distdir
+       $(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
+       $(am__remove_distdir)
+
+dist-bzip2: distdir
+       $(AMTAR) chof - $(distdir) | bzip2 -9 -c >$(distdir).tar.bz2
+       $(am__remove_distdir)
+
+dist-zip: distdir
+       -rm -f $(distdir).zip
+       zip -rq $(distdir).zip $(distdir)
+       $(am__remove_distdir)
+
+dist dist-all: distdir
+       $(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
+       $(AMTAR) chof - $(distdir) | bzip2 -9 -c >$(distdir).tar.bz2
+       -rm -f $(distdir).zip
+       zip -rq $(distdir).zip $(distdir)
+       $(am__remove_distdir)
+
+# This target untars the dist file and tries a VPATH configuration.  Then
+# it guarantees that the distribution is self-contained by making another
+# tarfile.
+distcheck: dist
+       $(am__remove_distdir)
+       GZIP=$(GZIP_ENV) gunzip -c $(distdir).tar.gz | $(AMTAR) xf -
+       chmod -R a-w $(distdir); chmod a+w $(distdir)
+       mkdir $(distdir)/=build
+       mkdir $(distdir)/=inst
+       chmod a-w $(distdir)
+       dc_install_base=`$(am__cd) $(distdir)/=inst && pwd` \
+         && cd $(distdir)/=build \
+         && ../configure --srcdir=.. --prefix=$$dc_install_base \
+           $(DISTCHECK_CONFIGURE_FLAGS) \
+         && $(MAKE) $(AM_MAKEFLAGS) \
+         && $(MAKE) $(AM_MAKEFLAGS) dvi \
+         && $(MAKE) $(AM_MAKEFLAGS) check \
+         && $(MAKE) $(AM_MAKEFLAGS) install \
+         && $(MAKE) $(AM_MAKEFLAGS) installcheck \
+         && $(MAKE) $(AM_MAKEFLAGS) uninstall \
+         && (test `find $$dc_install_base -type f -print | wc -l` -le 1 \
+             || { echo "ERROR: files left after uninstall:" ; \
+                  find $$dc_install_base -type f -print ; \
+                  exit 1; } >&2 ) \
+         && $(MAKE) $(AM_MAKEFLAGS) dist-gzip \
+         && rm -f $(distdir).tar.gz \
+         && $(MAKE) $(AM_MAKEFLAGS) distcleancheck
+       $(am__remove_distdir)
+       @echo "$(distdir).tar.gz is ready for distribution" | \
+         sed 'h;s/./=/g;p;x;p;x'
+distcleancheck: distclean
+       if test '$(srcdir)' = . ; then \
+         echo "ERROR: distcleancheck can only run from a VPATH build" ; \
+         exit 1 ; \
+       fi
+       test `$(distcleancheck_listfiles) | wc -l` -eq 0 \
+         || { echo "ERROR: files left after distclean:" ; \
+              $(distcleancheck_listfiles) ; \
+              exit 1; } >&2
+check-am: all-am
+check: check-recursive
+all-am: Makefile $(DATA) config.h
+installdirs: installdirs-recursive
+installdirs-am:
+       $(mkinstalldirs) $(DESTDIR)$(pkgconfigdir)
+
+install: install-recursive
+install-exec: install-exec-recursive
+install-data: install-data-recursive
+uninstall: uninstall-recursive
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-recursive
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-recursive
+
+clean-am: clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-recursive
+       -rm -f $(am__CONFIG_DISTCLEAN_FILES)
+distclean-am: clean-am distclean-generic distclean-hdr distclean-libtool \
+       distclean-tags
+
+dvi: dvi-recursive
+
+dvi-am:
+
+info: info-recursive
+
+info-am:
+
+install-data-am: install-pkgconfigDATA
+
+install-exec-am:
+
+install-info: install-info-recursive
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-recursive
+       -rm -f $(am__CONFIG_DISTCLEAN_FILES)
+       -rm -rf autom4te.cache
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-recursive
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+uninstall-am: uninstall-info-am uninstall-pkgconfigDATA
+
+uninstall-info: uninstall-info-recursive
+
+.PHONY: $(RECURSIVE_TARGETS) GTAGS all all-am check check-am clean \
+       clean-generic clean-libtool clean-recursive dist dist-all \
+       dist-bzip2 dist-gzip dist-zip distcheck distclean \
+       distclean-generic distclean-hdr distclean-libtool \
+       distclean-recursive distclean-tags distcleancheck distdir dvi \
+       dvi-am dvi-recursive info info-am info-recursive install \
+       install-am install-data install-data-am install-data-recursive \
+       install-exec install-exec-am install-exec-recursive \
+       install-info install-info-am install-info-recursive install-man \
+       install-pkgconfigDATA install-recursive install-strip \
+       installcheck installcheck-am installdirs installdirs-am \
+       installdirs-recursive maintainer-clean maintainer-clean-generic \
+       maintainer-clean-recursive mostlyclean mostlyclean-generic \
+       mostlyclean-libtool mostlyclean-recursive tags tags-recursive \
+       uninstall uninstall-am uninstall-info-am \
+       uninstall-info-recursive uninstall-pkgconfigDATA \
+       uninstall-recursive
+
+
+# Remove the .svn folders included in the tarball
+dist-hook:
+       find $(distdir) -type d -name '.svn' | xargs rm -rf
+
+debug:
+       $(MAKE) all CFLAGS="@DEBUG@"
+
+profile:
+       $(MAKE) all CFLAGS="@PROFILE@"
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/README b/README
new file mode 100644 (file)
index 0000000..135c62d
--- /dev/null
+++ b/README
@@ -0,0 +1,152 @@
+-------------------------------------------------------------------------
+             The Xiph.org Foundation's libtheora 1.1 
+-------------------------------------------------------------------------
+
+*** What is Theora?
+
+Theora is Xiph.Org's first publicly released video codec, intended
+for use within the Foundation's Ogg multimedia streaming system.
+Theora is derived directly from On2's VP3 codec, adds new features
+while allow it a longer useful lifetime as an competitive codec.
+
+The 1.0 release decoder supported all the new features, but the
+encoder is nearly identical to the VP3 code.
+
+The 1.1 release features a completely rewritten encoder, offering
+better performance and compression, and making more complete use
+of the format's feature set. Files produced by both encoders can
+be decoded by either release.
+
+*** Where is Theora?
+
+Theora's main site is www.theora.org.  Theora and related libraries
+can be gotten from www.theora.org or the main Xiph.Org site at
+www.xiph.org.  Development source is kept in an open subversion 
+repository, see http://theora.org/svn/ for instructions.
+
+-------------------------------------------------------------------------
+Getting started with the code
+-------------------------------------------------------------------------
+
+*** What do I need to build the source?
+
+Requirements summary:
+
+  For libtheora:
+
+      libogg 1.1 or newer.
+
+  For example encoder:
+
+      as above,
+
+      libvorbis and libvorbisenc 1.0.1 or newer.
+
+  For creating a source distribution package:
+
+      as above,
+
+      Doxygen to build the API documentation,
+      pdflatex and fig2dev to build the format specification
+        (transfig package in Ubuntu).
+
+  For the player only:
+
+      as above,
+
+      SDL (Simple Direct media Layer) libraries and headers,
+      OSS audio driver and development headers.
+
+The provided build system is the GNU automake/autoconf system, and
+the main library, libtheora, should already build smoothly on any
+system.  Failure of libtheora to build on a GNU-enabled system is
+considered a bug; please report problems to theora-dev@xiph.org.
+
+Windows build support is included in the win32 directory.
+
+Project files for Apple XCode are included in the macosx directory.
+
+There is also an experimental scons build.
+
+*** How do I use the sample encoder?
+
+The sample encoder takes raw video in YUV4MPEG2 format, as used by
+lavtools, mjpeg-tools and other packages. The encoder expects audio,
+if any, in a separate wave WAV file. Try 'encoder_example -h' for a 
+complete list of options.
+
+An easy way to get raw video and audio files is to use MPlayer as an
+export utility.  The options " -ao pcm -vo yuv4mpeg " will export a
+wav file named audiodump.wav and a YUV video file in the correct
+format for encoder_example as stream.yuv.  Be careful when exporting
+video alone; MPlayer may drop frames to 'keep up' with the audio
+timer.  The example encoder can't properly synchronize input audio and
+video file that aren't in sync to begin with.  
+
+The encoder will also take video or audio on stdin if '-' is specified
+as the input file name.
+
+There is also a 'png2theora' example which accepts a set of image
+files in that format.
+
+*** How do I use the sample player?
+
+The sample player takes an Ogg file on standard in; the file may be
+audio alone, video alone or video with audio.
+
+*** What other tools are available?
+
+The programs in the examples directory are intended as tutorial source 
+for developers using the library. As such they sacrifice features and 
+robustness in the interests of comprehension and should not be 
+considered serious applications.
+
+If you're wanting to just use theora, consider the programs linked
+from http://www.theora.org/. There is playback support in a number
+of common free players, and plugins for major media frameworks.
+Jan Gerber's ffmpeg2theora is an excellent encoding front end.
+
+-------------------------------------------------------------------------
+Troubleshooting the build process
+-------------------------------------------------------------------------
+
+*** Compile error, such as:
+
+encoder_internal.h:664: parse error before `ogg_uint16_t'
+
+This means you have version of libogg prior to 1.1. A *complete* new Ogg 
+install, libs and headers is needed.
+
+Also be sure that there aren't multiple copies of Ogg installed in
+/usr and /usr/local; an older one might be first on the search path
+for libs and headers.
+
+*** Link error, such as:
+
+undefined reference to `oggpackB_stream'
+
+See above; you need libogg 1.1 or later.
+
+*** Link error, such as:
+
+undefined reference to `vorbis_granule_time'
+
+You need libvorbis and libvorbisenc from the 1.0.1 release or later.
+
+*** Link error, such as:
+
+/usr/lib/libSDL.a(SDL_esdaudio.lo): In function `ESD_OpenAudio':
+SDL_esdaudio.lo(.text+0x25d): undefined reference to `esd_play_stream'
+
+Be sure to use an SDL that's built to work with OSS.  If you use an
+SDL that is also built with ESD and/or ALSA support, it will try to
+suck in all those extra libraries at link time too.  That will only
+work if the extra libraries are also installed.
+
+*** Link warning, such as:
+
+libtool: link: warning: library `/usr/lib/libogg.la' was moved.
+libtool: link: warning: library `/usr/lib/libogg.la' was moved.
+
+Re-run theora/autogen.sh after an Ogg or Vorbis rebuild/reinstall
+
diff --git a/SConstruct b/SConstruct
new file mode 100644 (file)
index 0000000..01bcfb4
--- /dev/null
@@ -0,0 +1,225 @@
+# see http://www.scons.org if you do not have this tool
+from os.path import join
+import SCons
+
+# TODO: should use lamda and map to work on python 1.5
+def path(prefix, list): return [join(prefix, x) for x in list]
+
+encoder_sources = """
+       apiwrapper.c
+       fragment.c
+       idct.c
+       internal.c
+       state.c
+       quant.c
+       analyze.c
+       encfrag.c
+       encapiwrapper.c
+       encinfo.c
+       encode.c
+       enquant.c
+       fdct.c
+       huffenc.c
+       mathops.c
+       mcenc.c
+       rate.c
+       tokenize.c
+"""
+
+decoder_sources = """
+        apiwrapper.c
+       bitpack.c
+        decapiwrapper.c
+        decinfo.c
+        decode.c
+        dequant.c
+        fragment.c
+        huffdec.c
+        idct.c
+        info.c
+        internal.c
+        quant.c
+        state.c
+"""
+
+env = Environment()
+if env['CC'] == 'gcc':
+  env.Append(CCFLAGS=["-g", "-O2", "-Wall", "-Wno-parentheses"])
+
+def CheckPKGConfig(context, version): 
+  context.Message( 'Checking for pkg-config... ' ) 
+  ret = context.TryAction('pkg-config --atleast-pkgconfig-version=%s' % version)[0] 
+  context.Result( ret ) 
+  return ret 
+
+def CheckPKG(context, name): 
+  context.Message( 'Checking for %s... ' % name )
+  ret = context.TryAction('pkg-config --exists %s' % name)[0]
+  context.Result( ret ) 
+  return ret
+     
+def CheckSDL(context):
+  name = "sdl-config"
+  context.Message( 'Checking for %s... ' % name )
+  ret = SCons.Util.WhereIs('sdl-config')
+  context.Result( ret ) 
+  return ret
+
+# check for appropriate inline asm support
+host_x86_32_test = """
+    int main(int argc, char **argv) {
+#if !defined(__i386__)
+  #error not an x86 host: preprocessor macro __i386__ not defined
+#endif
+  return 0;
+    }
+    """
+def CheckHost_x86_32(context):
+  context.Message('Checking for an x86 host...')
+  result = context.TryCompile(host_x86_32_test, '.c')
+  context.Result(result)
+  return result
+
+host_x86_64_test = """
+    int main(int argc, char **argv) {
+#if !defined(__x86_64__)
+  #error not an x86_64 host: preprocessor macro __x86_64__ not defined
+#endif
+  return 0;
+    }
+    """
+def CheckHost_x86_64(context):
+  context.Message('Checking for an x86_64 host...')
+  result = context.TryCompile(host_x86_64_test, '.c')
+  context.Result(result)
+  return result
+
+conf = Configure(env, custom_tests = {
+  'CheckPKGConfig' : CheckPKGConfig,
+  'CheckPKG' : CheckPKG,
+  'CheckSDL' : CheckSDL,
+  'CheckHost_x86_32' : CheckHost_x86_32,
+  'CheckHost_x86_64' : CheckHost_x86_64,
+  })
+  
+if not conf.CheckPKGConfig('0.15.0'): 
+   print 'pkg-config >= 0.15.0 not found.' 
+   Exit(1)
+
+if not conf.CheckPKG('ogg'): 
+  print 'libogg not found.' 
+  Exit(1) 
+
+if conf.CheckPKG('vorbis vorbisenc'):
+  have_vorbis=True
+else:
+  have_vorbis=False
+
+if conf.CheckPKG('libpng'):
+  have_libpng=True
+else:
+  have_libpng=False
+  
+build_player_example=True
+if not conf.CheckHeader('sys/soundcard.h'):
+  build_player_example=False
+if build_player_example and not conf.CheckSDL():
+  build_player_example=False
+
+if conf.CheckHost_x86_32():
+  env.Append(CPPDEFINES='OC_X86_ASM')
+  decoder_sources += """
+        x86/mmxidct.c
+        x86/mmxfrag.c
+        x86/mmxstate.c
+        x86/x86state.c
+  """
+  encoder_sources += """
+       x86/mmxencfrag.c
+       x86/mmxfdct.c
+       x86/x86enc.c
+       x86/mmxfrag.c
+       x86/mmxidct.c
+       x86/mmxstate.c
+       x86/x86state.c
+  """
+elif conf.CheckHost_x86_64():
+  env.Append(CPPDEFINES=['OC_X86_ASM', 'OC_X86_64_ASM'])
+  decoder_sources += """
+        x86/mmxidct.c
+        x86/mmxfrag.c
+        x86/mmxstate.c
+        x86/x86state.c
+  """
+  encoder_sources += """
+       x86/mmxencfrag.c
+       x86/mmxfdct.c
+       x86/x86enc.c
+       x86/sse2fdct.c
+       x86/mmxfrag.c
+       x86/mmxidct.c
+       x86/mmxstate.c
+       x86/x86state.c
+  """
+
+env = conf.Finish()
+
+env.Append(CPPPATH=['include'])
+env.ParseConfig('pkg-config --cflags --libs ogg')
+
+libtheoradec_Sources = Split(decoder_sources)
+libtheoraenc_Sources = Split(encoder_sources)
+
+libtheoradec_a = env.Library('lib/theoradec',
+       path('lib', libtheoradec_Sources))
+libtheoradec_so = env.SharedLibrary('lib/theoradec',
+       path('lib', libtheoradec_Sources))
+
+libtheoraenc_a = env.Library('lib/theoraenc',
+       path('lib', libtheoraenc_Sources))
+libtheoraenc_so = env.SharedLibrary('lib/theoraenc',
+       path('lib', libtheoraenc_Sources) + [libtheoradec_so])
+
+#installing
+prefix='/usr'
+lib_dir = prefix + '/lib'
+env.Alias('install', prefix)
+env.Install(lib_dir, [libtheoradec_a, libtheoradec_so])
+env.Install(lib_dir, [libtheoraenc_a, libtheoraenc_so])
+
+# example programs
+dump_video = env.Clone()
+dump_video_Sources = Split("""dump_video.c ../lib/libtheoradec.a""")
+dump_video.Program('examples/dump_video', path('examples', dump_video_Sources))
+
+dump_psnr = env.Clone()
+dump_psnr.Append(LIBS='m')
+dump_psnr_Sources = Split("""dump_psnr.c ../lib/libtheoradec.a""")
+dump_psnr.Program('examples/dump_psnr', path('examples', dump_psnr_Sources))
+
+if have_vorbis:
+  encex = dump_video.Clone()
+  encex.ParseConfig('pkg-config --cflags --libs vorbisenc vorbis')
+  encex_Sources = Split("""
+       encoder_example.c
+       ../lib/libtheoraenc.a 
+       ../lib/libtheoradec.a
+  """)
+  encex.Program('examples/encoder_example', path('examples', encex_Sources))
+
+  if build_player_example:
+    plyex = encex.Clone()
+    plyex_Sources = Split("""
+       player_example.c
+       ../lib/libtheoradec.a
+    """)
+    plyex.ParseConfig('sdl-config --cflags --libs')
+    plyex.Program('examples/player_example', path('examples', plyex_Sources))
+
+png2theora = env.Clone()
+png2theora_Sources = Split("""png2theora.c
+       ../lib/libtheoraenc.a
+       ../lib/libtheoradec.a
+""")
+png2theora.ParseConfig('pkg-config --cflags --libs libpng')
+png2theora.Program('examples/png2theora', path('examples', png2theora_Sources))
diff --git a/aclocal.m4 b/aclocal.m4
new file mode 100644 (file)
index 0000000..a050e7e
--- /dev/null
@@ -0,0 +1,10370 @@
+# aclocal.m4 generated automatically by aclocal 1.6.3 -*- Autoconf -*-
+
+# Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This file is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+# Like AC_CONFIG_HEADER, but automatically create stamp file. -*- Autoconf -*-
+
+# Copyright 1996, 1997, 2000, 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+AC_PREREQ([2.52])
+
+# serial 6
+
+# When config.status generates a header, we must update the stamp-h file.
+# This file resides in the same directory as the config header
+# that is generated.  We must strip everything past the first ":",
+# and everything past the last "/".
+
+# _AM_DIRNAME(PATH)
+# -----------------
+# Like AS_DIRNAME, only do it during macro expansion
+AC_DEFUN([_AM_DIRNAME],
+       [m4_if(regexp([$1], [^.*[^/]//*[^/][^/]*/*$]), -1,
+             m4_if(regexp([$1], [^//\([^/]\|$\)]), -1,
+                   m4_if(regexp([$1], [^/.*]), -1,
+                         [.],
+                         patsubst([$1], [^\(/\).*], [\1])),
+                   patsubst([$1], [^\(//\)\([^/].*\|$\)], [\1])),
+             patsubst([$1], [^\(.*[^/]\)//*[^/][^/]*/*$], [\1]))[]dnl
+])# _AM_DIRNAME
+
+
+# The stamp files are numbered to have different names.
+# We could number them on a directory basis, but that's additional
+# complications, let's have a unique counter.
+m4_define([_AM_STAMP_Count], [0])
+
+
+# _AM_STAMP(HEADER)
+# -----------------
+# The name of the stamp file for HEADER.
+AC_DEFUN([_AM_STAMP],
+[m4_define([_AM_STAMP_Count], m4_incr(_AM_STAMP_Count))dnl
+AS_ESCAPE(_AM_DIRNAME(patsubst([$1],
+                               [:.*])))/stamp-h[]_AM_STAMP_Count])
+
+
+# _AM_CONFIG_HEADER(HEADER[:SOURCES], COMMANDS, INIT-COMMANDS)
+# ------------------------------------------------------------
+# We used to try to get a real timestamp in stamp-h.  But the fear is that
+# that will cause unnecessary cvs conflicts.
+AC_DEFUN([_AM_CONFIG_HEADER],
+[# Add the stamp file to the list of files AC keeps track of,
+# along with our hook.
+AC_CONFIG_HEADERS([$1],
+                  [# update the timestamp
+echo 'timestamp for $1' >"_AM_STAMP([$1])"
+$2],
+                  [$3])
+])# _AM_CONFIG_HEADER
+
+
+# AM_CONFIG_HEADER(HEADER[:SOURCES]..., COMMANDS, INIT-COMMANDS)
+# --------------------------------------------------------------
+AC_DEFUN([AM_CONFIG_HEADER],
+[AC_FOREACH([_AM_File], [$1], [_AM_CONFIG_HEADER(_AM_File, [$2], [$3])])
+])# AM_CONFIG_HEADER
+
+# Do all the work for Automake.                            -*- Autoconf -*-
+
+# This macro actually does too much some checks are only needed if
+# your package does certain things.  But this isn't really a big deal.
+
+# Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# serial 8
+
+# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be
+# written in clear, in which case automake, when reading aclocal.m4,
+# will think it sees a *use*, and therefore will trigger all it's
+# C support machinery.  Also note that it means that autoscan, seeing
+# CC etc. in the Makefile, will ask for an AC_PROG_CC use...
+
+
+AC_PREREQ([2.52])
+
+# Autoconf 2.50 wants to disallow AM_ names.  We explicitly allow
+# the ones we care about.
+m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl
+
+# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE])
+# AM_INIT_AUTOMAKE([OPTIONS])
+# -----------------------------------------------
+# The call with PACKAGE and VERSION arguments is the old style
+# call (pre autoconf-2.50), which is being phased out.  PACKAGE
+# and VERSION should now be passed to AC_INIT and removed from
+# the call to AM_INIT_AUTOMAKE.
+# We support both call styles for the transition.  After
+# the next Automake release, Autoconf can make the AC_INIT
+# arguments mandatory, and then we can depend on a new Autoconf
+# release and drop the old call support.
+AC_DEFUN([AM_INIT_AUTOMAKE],
+[AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl
+ AC_REQUIRE([AC_PROG_INSTALL])dnl
+# test to see if srcdir already configured
+if test "`cd $srcdir && pwd`" != "`pwd`" &&
+   test -f $srcdir/config.status; then
+  AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
+fi
+
+# Define the identity of the package.
+dnl Distinguish between old-style and new-style calls.
+m4_ifval([$2],
+[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl
+ AC_SUBST([PACKAGE], [$1])dnl
+ AC_SUBST([VERSION], [$2])],
+[_AM_SET_OPTIONS([$1])dnl
+ AC_SUBST([PACKAGE], [AC_PACKAGE_TARNAME])dnl
+ AC_SUBST([VERSION], [AC_PACKAGE_VERSION])])dnl
+
+_AM_IF_OPTION([no-define],,
+[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package])
+ AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl
+
+# Some tools Automake needs.
+AC_REQUIRE([AM_SANITY_CHECK])dnl
+AC_REQUIRE([AC_ARG_PROGRAM])dnl
+AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version})
+AM_MISSING_PROG(AUTOCONF, autoconf)
+AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version})
+AM_MISSING_PROG(AUTOHEADER, autoheader)
+AM_MISSING_PROG(MAKEINFO, makeinfo)
+AM_MISSING_PROG(AMTAR, tar)
+AM_PROG_INSTALL_SH
+AM_PROG_INSTALL_STRIP
+# We need awk for the "check" target.  The system "awk" is bad on
+# some platforms.
+AC_REQUIRE([AC_PROG_AWK])dnl
+AC_REQUIRE([AC_PROG_MAKE_SET])dnl
+
+_AM_IF_OPTION([no-dependencies],,
+[AC_PROVIDE_IFELSE([AC_PROG_][CC],
+                  [_AM_DEPENDENCIES(CC)],
+                  [define([AC_PROG_][CC],
+                          defn([AC_PROG_][CC])[_AM_DEPENDENCIES(CC)])])dnl
+AC_PROVIDE_IFELSE([AC_PROG_][CXX],
+                  [_AM_DEPENDENCIES(CXX)],
+                  [define([AC_PROG_][CXX],
+                          defn([AC_PROG_][CXX])[_AM_DEPENDENCIES(CXX)])])dnl
+])
+])
+
+# Copyright 2002  Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+
+# AM_AUTOMAKE_VERSION(VERSION)
+# ----------------------------
+# Automake X.Y traces this macro to ensure aclocal.m4 has been
+# generated from the m4 files accompanying Automake X.Y.
+AC_DEFUN([AM_AUTOMAKE_VERSION],[am__api_version="1.6"])
+
+# AM_SET_CURRENT_AUTOMAKE_VERSION
+# -------------------------------
+# Call AM_AUTOMAKE_VERSION so it can be traced.
+# This function is AC_REQUIREd by AC_INIT_AUTOMAKE.
+AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
+        [AM_AUTOMAKE_VERSION([1.6.3])])
+
+# Helper functions for option handling.                    -*- Autoconf -*-
+
+# Copyright 2001, 2002  Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# serial 2
+
+# _AM_MANGLE_OPTION(NAME)
+# -----------------------
+AC_DEFUN([_AM_MANGLE_OPTION],
+[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])])
+
+# _AM_SET_OPTION(NAME)
+# ------------------------------
+# Set option NAME.  Presently that only means defining a flag for this option.
+AC_DEFUN([_AM_SET_OPTION],
+[m4_define(_AM_MANGLE_OPTION([$1]), 1)])
+
+# _AM_SET_OPTIONS(OPTIONS)
+# ----------------------------------
+# OPTIONS is a space-separated list of Automake options.
+AC_DEFUN([_AM_SET_OPTIONS],
+[AC_FOREACH([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])])
+
+# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET])
+# -------------------------------------------
+# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
+AC_DEFUN([_AM_IF_OPTION],
+[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
+
+#
+# Check to make sure that the build environment is sane.
+#
+
+# Copyright 1996, 1997, 2000, 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# serial 3
+
+# AM_SANITY_CHECK
+# ---------------
+AC_DEFUN([AM_SANITY_CHECK],
+[AC_MSG_CHECKING([whether build environment is sane])
+# Just in case
+sleep 1
+echo timestamp > conftest.file
+# Do `set' in a subshell so we don't clobber the current shell's
+# arguments.  Must try -L first in case configure is actually a
+# symlink; some systems play weird games with the mod time of symlinks
+# (eg FreeBSD returns the mod time of the symlink's containing
+# directory).
+if (
+   set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null`
+   if test "$[*]" = "X"; then
+      # -L didn't work.
+      set X `ls -t $srcdir/configure conftest.file`
+   fi
+   rm -f conftest.file
+   if test "$[*]" != "X $srcdir/configure conftest.file" \
+      && test "$[*]" != "X conftest.file $srcdir/configure"; then
+
+      # If neither matched, then we have a broken ls.  This can happen
+      # if, for instance, CONFIG_SHELL is bash and it inherits a
+      # broken ls alias from the environment.  This has actually
+      # happened.  Such a system could not be considered "sane".
+      AC_MSG_ERROR([ls -t appears to fail.  Make sure there is not a broken
+alias in your environment])
+   fi
+
+   test "$[2]" = conftest.file
+   )
+then
+   # Ok.
+   :
+else
+   AC_MSG_ERROR([newly created file is older than distributed files!
+Check your system clock])
+fi
+AC_MSG_RESULT(yes)])
+
+#  -*- Autoconf -*-
+
+
+# Copyright 1997, 1999, 2000, 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# serial 3
+
+# AM_MISSING_PROG(NAME, PROGRAM)
+# ------------------------------
+AC_DEFUN([AM_MISSING_PROG],
+[AC_REQUIRE([AM_MISSING_HAS_RUN])
+$1=${$1-"${am_missing_run}$2"}
+AC_SUBST($1)])
+
+
+# AM_MISSING_HAS_RUN
+# ------------------
+# Define MISSING if not defined so far and test if it supports --run.
+# If it does, set am_missing_run to use it, otherwise, to nothing.
+AC_DEFUN([AM_MISSING_HAS_RUN],
+[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
+test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing"
+# Use eval to expand $SHELL
+if eval "$MISSING --run true"; then
+  am_missing_run="$MISSING --run "
+else
+  am_missing_run=
+  AC_MSG_WARN([`missing' script is too old or missing])
+fi
+])
+
+# AM_AUX_DIR_EXPAND
+
+# Copyright 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets
+# $ac_aux_dir to `$srcdir/foo'.  In other projects, it is set to
+# `$srcdir', `$srcdir/..', or `$srcdir/../..'.
+#
+# Of course, Automake must honor this variable whenever it calls a
+# tool from the auxiliary directory.  The problem is that $srcdir (and
+# therefore $ac_aux_dir as well) can be either absolute or relative,
+# depending on how configure is run.  This is pretty annoying, since
+# it makes $ac_aux_dir quite unusable in subdirectories: in the top
+# source directory, any form will work fine, but in subdirectories a
+# relative path needs to be adjusted first.
+#
+# $ac_aux_dir/missing
+#    fails when called from a subdirectory if $ac_aux_dir is relative
+# $top_srcdir/$ac_aux_dir/missing
+#    fails if $ac_aux_dir is absolute,
+#    fails when called from a subdirectory in a VPATH build with
+#          a relative $ac_aux_dir
+#
+# The reason of the latter failure is that $top_srcdir and $ac_aux_dir
+# are both prefixed by $srcdir.  In an in-source build this is usually
+# harmless because $srcdir is `.', but things will broke when you
+# start a VPATH build or use an absolute $srcdir.
+#
+# So we could use something similar to $top_srcdir/$ac_aux_dir/missing,
+# iff we strip the leading $srcdir from $ac_aux_dir.  That would be:
+#   am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"`
+# and then we would define $MISSING as
+#   MISSING="\${SHELL} $am_aux_dir/missing"
+# This will work as long as MISSING is not called from configure, because
+# unfortunately $(top_srcdir) has no meaning in configure.
+# However there are other variables, like CC, which are often used in
+# configure, and could therefore not use this "fixed" $ac_aux_dir.
+#
+# Another solution, used here, is to always expand $ac_aux_dir to an
+# absolute PATH.  The drawback is that using absolute paths prevent a
+# configured tree to be moved without reconfiguration.
+
+# Rely on autoconf to set up CDPATH properly.
+AC_PREREQ([2.50])
+
+AC_DEFUN([AM_AUX_DIR_EXPAND], [
+# expand $ac_aux_dir to an absolute path
+am_aux_dir=`cd $ac_aux_dir && pwd`
+])
+
+# AM_PROG_INSTALL_SH
+# ------------------
+# Define $install_sh.
+
+# Copyright 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+AC_DEFUN([AM_PROG_INSTALL_SH],
+[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
+install_sh=${install_sh-"$am_aux_dir/install-sh"}
+AC_SUBST(install_sh)])
+
+# AM_PROG_INSTALL_STRIP
+
+# Copyright 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# One issue with vendor `install' (even GNU) is that you can't
+# specify the program used to strip binaries.  This is especially
+# annoying in cross-compiling environments, where the build's strip
+# is unlikely to handle the host's binaries.
+# Fortunately install-sh will honor a STRIPPROG variable, so we
+# always use install-sh in `make install-strip', and initialize
+# STRIPPROG with the value of the STRIP variable (set by the user).
+AC_DEFUN([AM_PROG_INSTALL_STRIP],
+[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
+# Installed binaries are usually stripped using `strip' when the user
+# run `make install-strip'.  However `strip' might not be the right
+# tool to use in cross-compilation environments, therefore Automake
+# will honor the `STRIP' environment variable to overrule this program.
+dnl Don't test for $cross_compiling = yes, because it might be `maybe'.
+if test "$cross_compiling" != no; then
+  AC_CHECK_TOOL([STRIP], [strip], :)
+fi
+INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s"
+AC_SUBST([INSTALL_STRIP_PROGRAM])])
+
+# serial 4                                             -*- Autoconf -*-
+
+# Copyright 1999, 2000, 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+
+# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be
+# written in clear, in which case automake, when reading aclocal.m4,
+# will think it sees a *use*, and therefore will trigger all it's
+# C support machinery.  Also note that it means that autoscan, seeing
+# CC etc. in the Makefile, will ask for an AC_PROG_CC use...
+
+
+
+# _AM_DEPENDENCIES(NAME)
+# ----------------------
+# See how the compiler implements dependency checking.
+# NAME is "CC", "CXX", "GCJ", or "OBJC".
+# We try a few techniques and use that to set a single cache variable.
+#
+# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was
+# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular
+# dependency, and given that the user is not expected to run this macro,
+# just rely on AC_PROG_CC.
+AC_DEFUN([_AM_DEPENDENCIES],
+[AC_REQUIRE([AM_SET_DEPDIR])dnl
+AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl
+AC_REQUIRE([AM_MAKE_INCLUDE])dnl
+AC_REQUIRE([AM_DEP_TRACK])dnl
+
+ifelse([$1], CC,   [depcc="$CC"   am_compiler_list=],
+       [$1], CXX,  [depcc="$CXX"  am_compiler_list=],
+       [$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'],
+       [$1], GCJ,  [depcc="$GCJ"  am_compiler_list='gcc3 gcc'],
+                   [depcc="$$1"   am_compiler_list=])
+
+AC_CACHE_CHECK([dependency style of $depcc],
+               [am_cv_$1_dependencies_compiler_type],
+[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
+  # We make a subdir and do the tests there.  Otherwise we can end up
+  # making bogus files that we don't know about and never remove.  For
+  # instance it was reported that on HP-UX the gcc test will end up
+  # making a dummy file named `D' -- because `-MD' means `put the output
+  # in D'.
+  mkdir conftest.dir
+  # Copy depcomp to subdir because otherwise we won't find it if we're
+  # using a relative directory.
+  cp "$am_depcomp" conftest.dir
+  cd conftest.dir
+
+  am_cv_$1_dependencies_compiler_type=none
+  if test "$am_compiler_list" = ""; then
+     am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp`
+  fi
+  for depmode in $am_compiler_list; do
+    # We need to recreate these files for each test, as the compiler may
+    # overwrite some of them when testing with obscure command lines.
+    # This happens at least with the AIX C compiler.
+    echo '#include "conftest.h"' > conftest.c
+    echo 'int i;' > conftest.h
+    echo "${am__include} ${am__quote}conftest.Po${am__quote}" > confmf
+
+    case $depmode in
+    nosideeffect)
+      # after this tag, mechanisms are not by side-effect, so they'll
+      # only be used when explicitly requested
+      if test "x$enable_dependency_tracking" = xyes; then
+       continue
+      else
+       break
+      fi
+      ;;
+    none) break ;;
+    esac
+    # We check with `-c' and `-o' for the sake of the "dashmstdout"
+    # mode.  It turns out that the SunPro C++ compiler does not properly
+    # handle `-M -o', and we need to detect this.
+    if depmode=$depmode \
+       source=conftest.c object=conftest.o \
+       depfile=conftest.Po tmpdepfile=conftest.TPo \
+       $SHELL ./depcomp $depcc -c conftest.c -o conftest.o >/dev/null 2>&1 &&
+       grep conftest.h conftest.Po > /dev/null 2>&1 &&
+       ${MAKE-make} -s -f confmf > /dev/null 2>&1; then
+      am_cv_$1_dependencies_compiler_type=$depmode
+      break
+    fi
+  done
+
+  cd ..
+  rm -rf conftest.dir
+else
+  am_cv_$1_dependencies_compiler_type=none
+fi
+])
+AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type])
+])
+
+
+# AM_SET_DEPDIR
+# -------------
+# Choose a directory name for dependency files.
+# This macro is AC_REQUIREd in _AM_DEPENDENCIES
+AC_DEFUN([AM_SET_DEPDIR],
+[rm -f .deps 2>/dev/null
+mkdir .deps 2>/dev/null
+if test -d .deps; then
+  DEPDIR=.deps
+else
+  # MS-DOS does not allow filenames that begin with a dot.
+  DEPDIR=_deps
+fi
+rmdir .deps 2>/dev/null
+AC_SUBST([DEPDIR])
+])
+
+
+# AM_DEP_TRACK
+# ------------
+AC_DEFUN([AM_DEP_TRACK],
+[AC_ARG_ENABLE(dependency-tracking,
+[  --disable-dependency-tracking Speeds up one-time builds
+  --enable-dependency-tracking  Do not reject slow dependency extractors])
+if test "x$enable_dependency_tracking" != xno; then
+  am_depcomp="$ac_aux_dir/depcomp"
+  AMDEPBACKSLASH='\'
+fi
+AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno])
+AC_SUBST([AMDEPBACKSLASH])
+])
+
+# Generate code to set up dependency tracking.   -*- Autoconf -*-
+
+# Copyright 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+#serial 2
+
+# _AM_OUTPUT_DEPENDENCY_COMMANDS
+# ------------------------------
+AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
+[for mf in $CONFIG_FILES; do
+  # Strip MF so we end up with the name of the file.
+  mf=`echo "$mf" | sed -e 's/:.*$//'`
+  # Check whether this is an Automake generated Makefile or not.
+  # We used to match only the files named `Makefile.in', but
+  # some people rename them; so instead we look at the file content.
+  # Grep'ing the first line is not enough: some people post-process
+  # each Makefile.in and add a new line on top of each file to say so.
+  # So let's grep whole file.
+  if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then
+    dirpart=`AS_DIRNAME("$mf")`
+  else
+    continue
+  fi
+  grep '^DEP_FILES *= *[[^ @%:@]]' < "$mf" > /dev/null || continue
+  # Extract the definition of DEP_FILES from the Makefile without
+  # running `make'.
+  DEPDIR=`sed -n -e '/^DEPDIR = / s///p' < "$mf"`
+  test -z "$DEPDIR" && continue
+  # When using ansi2knr, U may be empty or an underscore; expand it
+  U=`sed -n -e '/^U = / s///p' < "$mf"`
+  test -d "$dirpart/$DEPDIR" || mkdir "$dirpart/$DEPDIR"
+  # We invoke sed twice because it is the simplest approach to
+  # changing $(DEPDIR) to its actual value in the expansion.
+  for file in `sed -n -e '
+    /^DEP_FILES = .*\\\\$/ {
+      s/^DEP_FILES = //
+      :loop
+       s/\\\\$//
+       p
+       n
+       /\\\\$/ b loop
+      p
+    }
+    /^DEP_FILES = / s/^DEP_FILES = //p' < "$mf" | \
+       sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do
+    # Make sure the directory exists.
+    test -f "$dirpart/$file" && continue
+    fdir=`AS_DIRNAME(["$file"])`
+    AS_MKDIR_P([$dirpart/$fdir])
+    # echo "creating $dirpart/$file"
+    echo '# dummy' > "$dirpart/$file"
+  done
+done
+])# _AM_OUTPUT_DEPENDENCY_COMMANDS
+
+
+# AM_OUTPUT_DEPENDENCY_COMMANDS
+# -----------------------------
+# This macro should only be invoked once -- use via AC_REQUIRE.
+#
+# This code is only required when automatic dependency tracking
+# is enabled.  FIXME.  This creates each `.P' file that we will
+# need in order to bootstrap the dependency handling code.
+AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
+[AC_CONFIG_COMMANDS([depfiles],
+     [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
+     [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
+])
+
+# Copyright 2001 Free Software Foundation, Inc.             -*- Autoconf -*-
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# serial 2
+
+# AM_MAKE_INCLUDE()
+# -----------------
+# Check to see how make treats includes.
+AC_DEFUN([AM_MAKE_INCLUDE],
+[am_make=${MAKE-make}
+cat > confinc << 'END'
+doit:
+       @echo done
+END
+# If we don't find an include directive, just comment out the code.
+AC_MSG_CHECKING([for style of include used by $am_make])
+am__include="#"
+am__quote=
+_am_result=none
+# First try GNU make style include.
+echo "include confinc" > confmf
+# We grep out `Entering directory' and `Leaving directory'
+# messages which can occur if `w' ends up in MAKEFLAGS.
+# In particular we don't look at `^make:' because GNU make might
+# be invoked under some other name (usually "gmake"), in which
+# case it prints its new name instead of `make'.
+if test "`$am_make -s -f confmf 2> /dev/null | fgrep -v 'ing directory'`" = "done"; then
+   am__include=include
+   am__quote=
+   _am_result=GNU
+fi
+# Now try BSD make style include.
+if test "$am__include" = "#"; then
+   echo '.include "confinc"' > confmf
+   if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then
+      am__include=.include
+      am__quote="\""
+      _am_result=BSD
+   fi
+fi
+AC_SUBST(am__include)
+AC_SUBST(am__quote)
+AC_MSG_RESULT($_am_result)
+rm -f confinc confmf
+])
+
+# AM_CONDITIONAL                                              -*- Autoconf -*-
+
+# Copyright 1997, 2000, 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# serial 5
+
+AC_PREREQ(2.52)
+
+# AM_CONDITIONAL(NAME, SHELL-CONDITION)
+# -------------------------------------
+# Define a conditional.
+AC_DEFUN([AM_CONDITIONAL],
+[ifelse([$1], [TRUE],  [AC_FATAL([$0: invalid condition: $1])],
+        [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl
+AC_SUBST([$1_TRUE])
+AC_SUBST([$1_FALSE])
+if $2; then
+  $1_TRUE=
+  $1_FALSE='#'
+else
+  $1_TRUE='#'
+  $1_FALSE=
+fi
+AC_CONFIG_COMMANDS_PRE(
+[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then
+  AC_MSG_ERROR([conditional \"$1\" was never defined.
+Usually this means the macro was only invoked conditionally.])
+fi])])
+
+# Add --enable-maintainer-mode option to configure.
+# From Jim Meyering
+
+# Copyright 1996, 1998, 2000, 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# serial 1
+
+AC_DEFUN([AM_MAINTAINER_MODE],
+[AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles])
+  dnl maintainer-mode is disabled by default
+  AC_ARG_ENABLE(maintainer-mode,
+[  --enable-maintainer-mode enable make rules and dependencies not useful
+                          (and sometimes confusing) to the casual installer],
+      USE_MAINTAINER_MODE=$enableval,
+      USE_MAINTAINER_MODE=no)
+  AC_MSG_RESULT([$USE_MAINTAINER_MODE])
+  AM_CONDITIONAL(MAINTAINER_MODE, [test $USE_MAINTAINER_MODE = yes])
+  MAINT=$MAINTAINER_MODE_TRUE
+  AC_SUBST(MAINT)dnl
+]
+)
+
+# serial 2
+
+# AM_PROG_CC_C_O
+# --------------
+# Like AC_PROG_CC_C_O, but changed for automake.
+
+# Copyright 1999, 2000, 2001 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+AC_DEFUN([AM_PROG_CC_C_O],
+[AC_REQUIRE([AC_PROG_CC_C_O])dnl
+AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
+# FIXME: we rely on the cache variable name because
+# there is no other way.
+set dummy $CC
+ac_cc=`echo $[2] | sed ['s/[^a-zA-Z0-9_]/_/g;s/^[0-9]/_/']`
+if eval "test \"`echo '$ac_cv_prog_cc_'${ac_cc}_c_o`\" != yes"; then
+   # Losing compiler, so override with the script.
+   # FIXME: It is wrong to rewrite CC.
+   # But if we don't then we get into trouble of one sort or another.
+   # A longer-term fix would be to have automake use am__CC in this case,
+   # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)"
+   CC="$am_aux_dir/compile $CC"
+fi
+])
+
+# Helper functions for option handling.                    -*- Autoconf -*-
+#
+#   Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
+#   Written by Gary V. Vaughan, 2004
+#
+# This file is free software; the Free Software Foundation gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+
+# serial 6 ltoptions.m4
+
+# This is to help aclocal find these macros, as it can't see m4_define.
+AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])])
+
+
+# _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME)
+# ------------------------------------------
+m4_define([_LT_MANGLE_OPTION],
+[[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])])
+
+
+# _LT_SET_OPTION(MACRO-NAME, OPTION-NAME)
+# ---------------------------------------
+# Set option OPTION-NAME for macro MACRO-NAME, and if there is a
+# matching handler defined, dispatch to it.  Other OPTION-NAMEs are
+# saved as a flag.
+m4_define([_LT_SET_OPTION],
+[m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl
+m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]),
+        _LT_MANGLE_DEFUN([$1], [$2]),
+    [m4_warning([Unknown $1 option `$2'])])[]dnl
+])
+
+
+# _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET])
+# ------------------------------------------------------------
+# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
+m4_define([_LT_IF_OPTION],
+[m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])])
+
+
+# _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET)
+# -------------------------------------------------------
+# Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME
+# are set.
+m4_define([_LT_UNLESS_OPTIONS],
+[m4_foreach([_LT_Option], m4_split(m4_normalize([$2])),
+           [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option),
+                     [m4_define([$0_found])])])[]dnl
+m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3
+])[]dnl
+])
+
+
+# _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST)
+# ----------------------------------------
+# OPTION-LIST is a space-separated list of Libtool options associated
+# with MACRO-NAME.  If any OPTION has a matching handler declared with
+# LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about
+# the unknown option and exit.
+m4_defun([_LT_SET_OPTIONS],
+[# Set options
+m4_foreach([_LT_Option], m4_split(m4_normalize([$2])),
+    [_LT_SET_OPTION([$1], _LT_Option)])
+
+m4_if([$1],[LT_INIT],[
+  dnl
+  dnl Simply set some default values (i.e off) if boolean options were not
+  dnl specified:
+  _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no
+  ])
+  _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no
+  ])
+  dnl
+  dnl If no reference was made to various pairs of opposing options, then
+  dnl we run the default mode handler for the pair.  For example, if neither
+  dnl `shared' nor `disable-shared' was passed, we enable building of shared
+  dnl archives by default:
+  _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED])
+  _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC])
+  _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC])
+  _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install],
+                  [_LT_ENABLE_FAST_INSTALL])
+  ])
+])# _LT_SET_OPTIONS
+
+
+
+# _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME)
+# -----------------------------------------
+m4_define([_LT_MANGLE_DEFUN],
+[[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])])
+
+
+# LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE)
+# -----------------------------------------------
+m4_define([LT_OPTION_DEFINE],
+[m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl
+])# LT_OPTION_DEFINE
+
+
+# dlopen
+# ------
+LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes
+])
+
+AU_DEFUN([AC_LIBTOOL_DLOPEN],
+[_LT_SET_OPTION([LT_INIT], [dlopen])
+AC_DIAGNOSE([obsolete],
+[$0: Remove this warning and the call to _LT_SET_OPTION when you
+put the `dlopen' option into LT_INIT's first parameter.])
+])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], [])
+
+
+# win32-dll
+# ---------
+# Declare package support for building win32 dll's.
+LT_OPTION_DEFINE([LT_INIT], [win32-dll],
+[enable_win32_dll=yes
+
+case $host in
+*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-cegcc*)
+  AC_CHECK_TOOL(AS, as, false)
+  AC_CHECK_TOOL(DLLTOOL, dlltool, false)
+  AC_CHECK_TOOL(OBJDUMP, objdump, false)
+  ;;
+esac
+
+test -z "$AS" && AS=as
+_LT_DECL([], [AS],      [0], [Assembler program])dnl
+
+test -z "$DLLTOOL" && DLLTOOL=dlltool
+_LT_DECL([], [DLLTOOL], [0], [DLL creation program])dnl
+
+test -z "$OBJDUMP" && OBJDUMP=objdump
+_LT_DECL([], [OBJDUMP], [0], [Object dumper program])dnl
+])# win32-dll
+
+AU_DEFUN([AC_LIBTOOL_WIN32_DLL],
+[AC_REQUIRE([AC_CANONICAL_HOST])dnl
+_LT_SET_OPTION([LT_INIT], [win32-dll])
+AC_DIAGNOSE([obsolete],
+[$0: Remove this warning and the call to _LT_SET_OPTION when you
+put the `win32-dll' option into LT_INIT's first parameter.])
+])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], [])
+
+
+# _LT_ENABLE_SHARED([DEFAULT])
+# ----------------------------
+# implement the --enable-shared flag, and supports the `shared' and
+# `disable-shared' LT_INIT options.
+# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
+m4_define([_LT_ENABLE_SHARED],
+[m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl
+AC_ARG_ENABLE([shared],
+    [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@],
+       [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])],
+    [p=${PACKAGE-default}
+    case $enableval in
+    yes) enable_shared=yes ;;
+    no) enable_shared=no ;;
+    *)
+      enable_shared=no
+      # Look at the argument we got.  We use all the common list separators.
+      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      for pkg in $enableval; do
+       IFS="$lt_save_ifs"
+       if test "X$pkg" = "X$p"; then
+         enable_shared=yes
+       fi
+      done
+      IFS="$lt_save_ifs"
+      ;;
+    esac],
+    [enable_shared=]_LT_ENABLE_SHARED_DEFAULT)
+
+    _LT_DECL([build_libtool_libs], [enable_shared], [0],
+       [Whether or not to build shared libraries])
+])# _LT_ENABLE_SHARED
+
+LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])])
+LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])])
+
+# Old names:
+AC_DEFUN([AC_ENABLE_SHARED],
+[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared])
+])
+
+AC_DEFUN([AC_DISABLE_SHARED],
+[_LT_SET_OPTION([LT_INIT], [disable-shared])
+])
+
+AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)])
+AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AM_ENABLE_SHARED], [])
+dnl AC_DEFUN([AM_DISABLE_SHARED], [])
+
+
+
+# _LT_ENABLE_STATIC([DEFAULT])
+# ----------------------------
+# implement the --enable-static flag, and support the `static' and
+# `disable-static' LT_INIT options.
+# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
+m4_define([_LT_ENABLE_STATIC],
+[m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl
+AC_ARG_ENABLE([static],
+    [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@],
+       [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])],
+    [p=${PACKAGE-default}
+    case $enableval in
+    yes) enable_static=yes ;;
+    no) enable_static=no ;;
+    *)
+     enable_static=no
+      # Look at the argument we got.  We use all the common list separators.
+      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      for pkg in $enableval; do
+       IFS="$lt_save_ifs"
+       if test "X$pkg" = "X$p"; then
+         enable_static=yes
+       fi
+      done
+      IFS="$lt_save_ifs"
+      ;;
+    esac],
+    [enable_static=]_LT_ENABLE_STATIC_DEFAULT)
+
+    _LT_DECL([build_old_libs], [enable_static], [0],
+       [Whether or not to build static libraries])
+])# _LT_ENABLE_STATIC
+
+LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])])
+LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])])
+
+# Old names:
+AC_DEFUN([AC_ENABLE_STATIC],
+[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static])
+])
+
+AC_DEFUN([AC_DISABLE_STATIC],
+[_LT_SET_OPTION([LT_INIT], [disable-static])
+])
+
+AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)])
+AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AM_ENABLE_STATIC], [])
+dnl AC_DEFUN([AM_DISABLE_STATIC], [])
+
+
+
+# _LT_ENABLE_FAST_INSTALL([DEFAULT])
+# ----------------------------------
+# implement the --enable-fast-install flag, and support the `fast-install'
+# and `disable-fast-install' LT_INIT options.
+# DEFAULT is either `yes' or `no'.  If omitted, it defaults to `yes'.
+m4_define([_LT_ENABLE_FAST_INSTALL],
+[m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl
+AC_ARG_ENABLE([fast-install],
+    [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@],
+    [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])],
+    [p=${PACKAGE-default}
+    case $enableval in
+    yes) enable_fast_install=yes ;;
+    no) enable_fast_install=no ;;
+    *)
+      enable_fast_install=no
+      # Look at the argument we got.  We use all the common list separators.
+      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      for pkg in $enableval; do
+       IFS="$lt_save_ifs"
+       if test "X$pkg" = "X$p"; then
+         enable_fast_install=yes
+       fi
+      done
+      IFS="$lt_save_ifs"
+      ;;
+    esac],
+    [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT)
+
+_LT_DECL([fast_install], [enable_fast_install], [0],
+        [Whether or not to optimize for fast installation])dnl
+])# _LT_ENABLE_FAST_INSTALL
+
+LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])])
+LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])])
+
+# Old names:
+AU_DEFUN([AC_ENABLE_FAST_INSTALL],
+[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install])
+AC_DIAGNOSE([obsolete],
+[$0: Remove this warning and the call to _LT_SET_OPTION when you put
+the `fast-install' option into LT_INIT's first parameter.])
+])
+
+AU_DEFUN([AC_DISABLE_FAST_INSTALL],
+[_LT_SET_OPTION([LT_INIT], [disable-fast-install])
+AC_DIAGNOSE([obsolete],
+[$0: Remove this warning and the call to _LT_SET_OPTION when you put
+the `disable-fast-install' option into LT_INIT's first parameter.])
+])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], [])
+dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], [])
+
+
+# _LT_WITH_PIC([MODE])
+# --------------------
+# implement the --with-pic flag, and support the `pic-only' and `no-pic'
+# LT_INIT options.
+# MODE is either `yes' or `no'.  If omitted, it defaults to `both'.
+m4_define([_LT_WITH_PIC],
+[AC_ARG_WITH([pic],
+    [AS_HELP_STRING([--with-pic],
+       [try to use only PIC/non-PIC objects @<:@default=use both@:>@])],
+    [pic_mode="$withval"],
+    [pic_mode=default])
+
+test -z "$pic_mode" && pic_mode=m4_default([$1], [default])
+
+_LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl
+])# _LT_WITH_PIC
+
+LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])])
+LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])])
+
+# Old name:
+AU_DEFUN([AC_LIBTOOL_PICMODE],
+[_LT_SET_OPTION([LT_INIT], [pic-only])
+AC_DIAGNOSE([obsolete],
+[$0: Remove this warning and the call to _LT_SET_OPTION when you
+put the `pic-only' option into LT_INIT's first parameter.])
+])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_PICMODE], [])
+
+
+m4_define([_LTDL_MODE], [])
+LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive],
+                [m4_define([_LTDL_MODE], [nonrecursive])])
+LT_OPTION_DEFINE([LTDL_INIT], [recursive],
+                [m4_define([_LTDL_MODE], [recursive])])
+LT_OPTION_DEFINE([LTDL_INIT], [subproject],
+                [m4_define([_LTDL_MODE], [subproject])])
+
+m4_define([_LTDL_TYPE], [])
+LT_OPTION_DEFINE([LTDL_INIT], [installable],
+                [m4_define([_LTDL_TYPE], [installable])])
+LT_OPTION_DEFINE([LTDL_INIT], [convenience],
+                [m4_define([_LTDL_TYPE], [convenience])])
+
+# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*-
+#
+#   Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
+#                 2006, 2007, 2008 Free Software Foundation, Inc.
+#   Written by Gordon Matzigkeit, 1996
+#
+# This file is free software; the Free Software Foundation gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+
+m4_define([_LT_COPYING], [dnl
+#   Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
+#                 2006, 2007, 2008 Free Software Foundation, Inc.
+#   Written by Gordon Matzigkeit, 1996
+#
+#   This file is part of GNU Libtool.
+#
+# GNU Libtool 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.
+#
+# As a special exception to the GNU General Public License,
+# if you distribute this file as part of a program or library that
+# is built using GNU Libtool, you may include this file under the
+# same distribution terms that you use for the rest of that program.
+#
+# GNU Libtool 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 GNU Libtool; see the file COPYING.  If not, a copy
+# can be downloaded from http://www.gnu.org/licenses/gpl.html, or
+# obtained by writing to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+])
+
+# serial 56 LT_INIT
+
+
+# LT_PREREQ(VERSION)
+# ------------------
+# Complain and exit if this libtool version is less that VERSION.
+m4_defun([LT_PREREQ],
+[m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1,
+       [m4_default([$3],
+                  [m4_fatal([Libtool version $1 or higher is required],
+                            63)])],
+       [$2])])
+
+
+# _LT_CHECK_BUILDDIR
+# ------------------
+# Complain if the absolute build directory name contains unusual characters
+m4_defun([_LT_CHECK_BUILDDIR],
+[case `pwd` in
+  *\ * | *\    *)
+    AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;;
+esac
+])
+
+
+# LT_INIT([OPTIONS])
+# ------------------
+AC_DEFUN([LT_INIT],
+[AC_PREREQ([2.58])dnl We use AC_INCLUDES_DEFAULT
+AC_BEFORE([$0], [LT_LANG])dnl
+AC_BEFORE([$0], [LT_OUTPUT])dnl
+AC_BEFORE([$0], [LTDL_INIT])dnl
+m4_require([_LT_CHECK_BUILDDIR])dnl
+
+dnl Autoconf doesn't catch unexpanded LT_ macros by default:
+m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl
+m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl
+dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4
+dnl unless we require an AC_DEFUNed macro:
+AC_REQUIRE([LTOPTIONS_VERSION])dnl
+AC_REQUIRE([LTSUGAR_VERSION])dnl
+AC_REQUIRE([LTVERSION_VERSION])dnl
+AC_REQUIRE([LTOBSOLETE_VERSION])dnl
+m4_require([_LT_PROG_LTMAIN])dnl
+
+dnl Parse OPTIONS
+_LT_SET_OPTIONS([$0], [$1])
+
+# This can be used to rebuild libtool when needed
+LIBTOOL_DEPS="$ltmain"
+
+# Always use our own libtool.
+LIBTOOL='$(SHELL) $(top_builddir)/libtool'
+AC_SUBST(LIBTOOL)dnl
+
+_LT_SETUP
+
+# Only expand once:
+m4_define([LT_INIT])
+])# LT_INIT
+
+# Old names:
+AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT])
+AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_PROG_LIBTOOL], [])
+dnl AC_DEFUN([AM_PROG_LIBTOOL], [])
+
+
+# _LT_CC_BASENAME(CC)
+# -------------------
+# Calculate cc_basename.  Skip known compiler wrappers and cross-prefix.
+m4_defun([_LT_CC_BASENAME],
+[for cc_temp in $1""; do
+  case $cc_temp in
+    compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;;
+    distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;;
+    \-*) ;;
+    *) break;;
+  esac
+done
+cc_basename=`$ECHO "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"`
+])
+
+
+# _LT_FILEUTILS_DEFAULTS
+# ----------------------
+# It is okay to use these file commands and assume they have been set
+# sensibly after `m4_require([_LT_FILEUTILS_DEFAULTS])'.
+m4_defun([_LT_FILEUTILS_DEFAULTS],
+[: ${CP="cp -f"}
+: ${MV="mv -f"}
+: ${RM="rm -f"}
+])# _LT_FILEUTILS_DEFAULTS
+
+
+# _LT_SETUP
+# ---------
+m4_defun([_LT_SETUP],
+[AC_REQUIRE([AC_CANONICAL_HOST])dnl
+AC_REQUIRE([AC_CANONICAL_BUILD])dnl
+_LT_DECL([], [host_alias], [0], [The host system])dnl
+_LT_DECL([], [host], [0])dnl
+_LT_DECL([], [host_os], [0])dnl
+dnl
+_LT_DECL([], [build_alias], [0], [The build system])dnl
+_LT_DECL([], [build], [0])dnl
+_LT_DECL([], [build_os], [0])dnl
+dnl
+AC_REQUIRE([AC_PROG_CC])dnl
+AC_REQUIRE([LT_PATH_LD])dnl
+AC_REQUIRE([LT_PATH_NM])dnl
+dnl
+AC_REQUIRE([AC_PROG_LN_S])dnl
+test -z "$LN_S" && LN_S="ln -s"
+_LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl
+dnl
+AC_REQUIRE([LT_CMD_MAX_LEN])dnl
+_LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl
+_LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl
+dnl
+m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+m4_require([_LT_CHECK_SHELL_FEATURES])dnl
+m4_require([_LT_CMD_RELOAD])dnl
+m4_require([_LT_CHECK_MAGIC_METHOD])dnl
+m4_require([_LT_CMD_OLD_ARCHIVE])dnl
+m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl
+
+_LT_CONFIG_LIBTOOL_INIT([
+# See if we are running on zsh, and set the options which allow our
+# commands through without removal of \ escapes INIT.
+if test -n "\${ZSH_VERSION+set}" ; then
+   setopt NO_GLOB_SUBST
+fi
+])
+if test -n "${ZSH_VERSION+set}" ; then
+   setopt NO_GLOB_SUBST
+fi
+
+_LT_CHECK_OBJDIR
+
+m4_require([_LT_TAG_COMPILER])dnl
+_LT_PROG_ECHO_BACKSLASH
+
+case $host_os in
+aix3*)
+  # AIX sometimes has problems with the GCC collect2 program.  For some
+  # reason, if we set the COLLECT_NAMES environment variable, the problems
+  # vanish in a puff of smoke.
+  if test "X${COLLECT_NAMES+set}" != Xset; then
+    COLLECT_NAMES=
+    export COLLECT_NAMES
+  fi
+  ;;
+esac
+
+# Sed substitution that helps us do robust quoting.  It backslashifies
+# metacharacters that are still active within double-quoted strings.
+sed_quote_subst='s/\([["`$\\]]\)/\\\1/g'
+
+# Same as above, but do not quote variable references.
+double_quote_subst='s/\([["`\\]]\)/\\\1/g'
+
+# Sed substitution to delay expansion of an escaped shell variable in a
+# double_quote_subst'ed string.
+delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g'
+
+# Sed substitution to delay expansion of an escaped single quote.
+delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g'
+
+# Sed substitution to avoid accidental globbing in evaled expressions
+no_glob_subst='s/\*/\\\*/g'
+
+# Global variables:
+ofile=libtool
+can_build_shared=yes
+
+# All known linkers require a `.a' archive for static linking (except MSVC,
+# which needs '.lib').
+libext=a
+
+with_gnu_ld="$lt_cv_prog_gnu_ld"
+
+old_CC="$CC"
+old_CFLAGS="$CFLAGS"
+
+# Set sane defaults for various variables
+test -z "$CC" && CC=cc
+test -z "$LTCC" && LTCC=$CC
+test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS
+test -z "$LD" && LD=ld
+test -z "$ac_objext" && ac_objext=o
+
+_LT_CC_BASENAME([$compiler])
+
+# Only perform the check for file, if the check method requires it
+test -z "$MAGIC_CMD" && MAGIC_CMD=file
+case $deplibs_check_method in
+file_magic*)
+  if test "$file_magic_cmd" = '$MAGIC_CMD'; then
+    _LT_PATH_MAGIC
+  fi
+  ;;
+esac
+
+# Use C for the default configuration in the libtool script
+LT_SUPPORTED_TAG([CC])
+_LT_LANG_C_CONFIG
+_LT_LANG_DEFAULT_CONFIG
+_LT_CONFIG_COMMANDS
+])# _LT_SETUP
+
+
+# _LT_PROG_LTMAIN
+# ---------------
+# Note that this code is called both from `configure', and `config.status'
+# now that we use AC_CONFIG_COMMANDS to generate libtool.  Notably,
+# `config.status' has no value for ac_aux_dir unless we are using Automake,
+# so we pass a copy along to make sure it has a sensible value anyway.
+m4_defun([_LT_PROG_LTMAIN],
+[m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl
+_LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir'])
+ltmain="$ac_aux_dir/ltmain.sh"
+])# _LT_PROG_LTMAIN
+
+
+
+# So that we can recreate a full libtool script including additional
+# tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS
+# in macros and then make a single call at the end using the `libtool'
+# label.
+
+
+# _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS])
+# ----------------------------------------
+# Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later.
+m4_define([_LT_CONFIG_LIBTOOL_INIT],
+[m4_ifval([$1],
+          [m4_append([_LT_OUTPUT_LIBTOOL_INIT],
+                     [$1
+])])])
+
+# Initialize.
+m4_define([_LT_OUTPUT_LIBTOOL_INIT])
+
+
+# _LT_CONFIG_LIBTOOL([COMMANDS])
+# ------------------------------
+# Register COMMANDS to be passed to AC_CONFIG_COMMANDS later.
+m4_define([_LT_CONFIG_LIBTOOL],
+[m4_ifval([$1],
+          [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS],
+                     [$1
+])])])
+
+# Initialize.
+m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS])
+
+
+# _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS])
+# -----------------------------------------------------
+m4_defun([_LT_CONFIG_SAVE_COMMANDS],
+[_LT_CONFIG_LIBTOOL([$1])
+_LT_CONFIG_LIBTOOL_INIT([$2])
+])
+
+
+# _LT_FORMAT_COMMENT([COMMENT])
+# -----------------------------
+# Add leading comment marks to the start of each line, and a trailing
+# full-stop to the whole comment if one is not present already.
+m4_define([_LT_FORMAT_COMMENT],
+[m4_ifval([$1], [
+m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])],
+              [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.])
+)])
+
+
+
+
+
+# _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?])
+# -------------------------------------------------------------------
+# CONFIGNAME is the name given to the value in the libtool script.
+# VARNAME is the (base) name used in the configure script.
+# VALUE may be 0, 1 or 2 for a computed quote escaped value based on
+# VARNAME.  Any other value will be used directly.
+m4_define([_LT_DECL],
+[lt_if_append_uniq([lt_decl_varnames], [$2], [, ],
+    [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name],
+       [m4_ifval([$1], [$1], [$2])])
+    lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3])
+    m4_ifval([$4],
+       [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])])
+    lt_dict_add_subkey([lt_decl_dict], [$2],
+       [tagged?], [m4_ifval([$5], [yes], [no])])])
+])
+
+
+# _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION])
+# --------------------------------------------------------
+m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])])
+
+
+# lt_decl_tag_varnames([SEPARATOR], [VARNAME1...])
+# ------------------------------------------------
+m4_define([lt_decl_tag_varnames],
+[_lt_decl_filter([tagged?], [yes], $@)])
+
+
+# _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..])
+# ---------------------------------------------------------
+m4_define([_lt_decl_filter],
+[m4_case([$#],
+  [0], [m4_fatal([$0: too few arguments: $#])],
+  [1], [m4_fatal([$0: too few arguments: $#: $1])],
+  [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)],
+  [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)],
+  [lt_dict_filter([lt_decl_dict], $@)])[]dnl
+])
+
+
+# lt_decl_quote_varnames([SEPARATOR], [VARNAME1...])
+# --------------------------------------------------
+m4_define([lt_decl_quote_varnames],
+[_lt_decl_filter([value], [1], $@)])
+
+
+# lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...])
+# ---------------------------------------------------
+m4_define([lt_decl_dquote_varnames],
+[_lt_decl_filter([value], [2], $@)])
+
+
+# lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...])
+# ---------------------------------------------------
+m4_define([lt_decl_varnames_tagged],
+[m4_assert([$# <= 2])dnl
+_$0(m4_quote(m4_default([$1], [[, ]])),
+    m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]),
+    m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))])
+m4_define([_lt_decl_varnames_tagged],
+[m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])])
+
+
+# lt_decl_all_varnames([SEPARATOR], [VARNAME1...])
+# ------------------------------------------------
+m4_define([lt_decl_all_varnames],
+[_$0(m4_quote(m4_default([$1], [[, ]])),
+     m4_if([$2], [],
+          m4_quote(lt_decl_varnames),
+       m4_quote(m4_shift($@))))[]dnl
+])
+m4_define([_lt_decl_all_varnames],
+[lt_join($@, lt_decl_varnames_tagged([$1],
+                       lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl
+])
+
+
+# _LT_CONFIG_STATUS_DECLARE([VARNAME])
+# ------------------------------------
+# Quote a variable value, and forward it to `config.status' so that its
+# declaration there will have the same value as in `configure'.  VARNAME
+# must have a single quote delimited value for this to work.
+m4_define([_LT_CONFIG_STATUS_DECLARE],
+[$1='`$ECHO "X$][$1" | $Xsed -e "$delay_single_quote_subst"`'])
+
+
+# _LT_CONFIG_STATUS_DECLARATIONS
+# ------------------------------
+# We delimit libtool config variables with single quotes, so when
+# we write them to config.status, we have to be sure to quote all
+# embedded single quotes properly.  In configure, this macro expands
+# each variable declared with _LT_DECL (and _LT_TAGDECL) into:
+#
+#    <var>='`$ECHO "X$<var>" | $Xsed -e "$delay_single_quote_subst"`'
+m4_defun([_LT_CONFIG_STATUS_DECLARATIONS],
+[m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames),
+    [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])])
+
+
+# _LT_LIBTOOL_TAGS
+# ----------------
+# Output comment and list of tags supported by the script
+m4_defun([_LT_LIBTOOL_TAGS],
+[_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl
+available_tags="_LT_TAGS"dnl
+])
+
+
+# _LT_LIBTOOL_DECLARE(VARNAME, [TAG])
+# -----------------------------------
+# Extract the dictionary values for VARNAME (optionally with TAG) and
+# expand to a commented shell variable setting:
+#
+#    # Some comment about what VAR is for.
+#    visible_name=$lt_internal_name
+m4_define([_LT_LIBTOOL_DECLARE],
+[_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1],
+                                          [description])))[]dnl
+m4_pushdef([_libtool_name],
+    m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl
+m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])),
+    [0], [_libtool_name=[$]$1],
+    [1], [_libtool_name=$lt_[]$1],
+    [2], [_libtool_name=$lt_[]$1],
+    [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl
+m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl
+])
+
+
+# _LT_LIBTOOL_CONFIG_VARS
+# -----------------------
+# Produce commented declarations of non-tagged libtool config variables
+# suitable for insertion in the LIBTOOL CONFIG section of the `libtool'
+# script.  Tagged libtool config variables (even for the LIBTOOL CONFIG
+# section) are produced by _LT_LIBTOOL_TAG_VARS.
+m4_defun([_LT_LIBTOOL_CONFIG_VARS],
+[m4_foreach([_lt_var],
+    m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)),
+    [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])])
+
+
+# _LT_LIBTOOL_TAG_VARS(TAG)
+# -------------------------
+m4_define([_LT_LIBTOOL_TAG_VARS],
+[m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames),
+    [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])])
+
+
+# _LT_TAGVAR(VARNAME, [TAGNAME])
+# ------------------------------
+m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])])
+
+
+# _LT_CONFIG_COMMANDS
+# -------------------
+# Send accumulated output to $CONFIG_STATUS.  Thanks to the lists of
+# variables for single and double quote escaping we saved from calls
+# to _LT_DECL, we can put quote escaped variables declarations
+# into `config.status', and then the shell code to quote escape them in
+# for loops in `config.status'.  Finally, any additional code accumulated
+# from calls to _LT_CONFIG_LIBTOOL_INIT is expanded.
+m4_defun([_LT_CONFIG_COMMANDS],
+[AC_PROVIDE_IFELSE([LT_OUTPUT],
+       dnl If the libtool generation code has been placed in $CONFIG_LT,
+       dnl instead of duplicating it all over again into config.status,
+       dnl then we will have config.status run $CONFIG_LT later, so it
+       dnl needs to know what name is stored there:
+        [AC_CONFIG_COMMANDS([libtool],
+            [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])],
+    dnl If the libtool generation code is destined for config.status,
+    dnl expand the accumulated commands and init code now:
+    [AC_CONFIG_COMMANDS([libtool],
+        [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])])
+])#_LT_CONFIG_COMMANDS
+
+
+# Initialize.
+m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT],
+[
+
+# The HP-UX ksh and POSIX shell print the target directory to stdout
+# if CDPATH is set.
+(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
+
+sed_quote_subst='$sed_quote_subst'
+double_quote_subst='$double_quote_subst'
+delay_variable_subst='$delay_variable_subst'
+_LT_CONFIG_STATUS_DECLARATIONS
+LTCC='$LTCC'
+LTCFLAGS='$LTCFLAGS'
+compiler='$compiler_DEFAULT'
+
+# Quote evaled strings.
+for var in lt_decl_all_varnames([[ \
+]], lt_decl_quote_varnames); do
+    case \`eval \\\\\$ECHO "X\\\\\$\$var"\` in
+    *[[\\\\\\\`\\"\\\$]]*)
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"X\\\$\$var\\" | \\\$Xsed -e \\"\\\$sed_quote_subst\\"\\\`\\\\\\""
+      ;;
+    *)
+      eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
+      ;;
+    esac
+done
+
+# Double-quote double-evaled strings.
+for var in lt_decl_all_varnames([[ \
+]], lt_decl_dquote_varnames); do
+    case \`eval \\\\\$ECHO "X\\\\\$\$var"\` in
+    *[[\\\\\\\`\\"\\\$]]*)
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"X\\\$\$var\\" | \\\$Xsed -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\""
+      ;;
+    *)
+      eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
+      ;;
+    esac
+done
+
+# Fix-up fallback echo if it was mangled by the above quoting rules.
+case \$lt_ECHO in
+*'\\\[$]0 --fallback-echo"')dnl "
+  lt_ECHO=\`\$ECHO "X\$lt_ECHO" | \$Xsed -e 's/\\\\\\\\\\\\\\\[$]0 --fallback-echo"\[$]/\[$]0 --fallback-echo"/'\`
+  ;;
+esac
+
+_LT_OUTPUT_LIBTOOL_INIT
+])
+
+
+# LT_OUTPUT
+# ---------
+# This macro allows early generation of the libtool script (before
+# AC_OUTPUT is called), incase it is used in configure for compilation
+# tests.
+AC_DEFUN([LT_OUTPUT],
+[: ${CONFIG_LT=./config.lt}
+AC_MSG_NOTICE([creating $CONFIG_LT])
+cat >"$CONFIG_LT" <<_LTEOF
+#! $SHELL
+# Generated by $as_me.
+# Run this file to recreate a libtool stub with the current configuration.
+
+lt_cl_silent=false
+SHELL=\${CONFIG_SHELL-$SHELL}
+_LTEOF
+
+cat >>"$CONFIG_LT" <<\_LTEOF
+AS_SHELL_SANITIZE
+_AS_PREPARE
+
+exec AS_MESSAGE_FD>&1
+exec AS_MESSAGE_LOG_FD>>config.log
+{
+  echo
+  AS_BOX([Running $as_me.])
+} >&AS_MESSAGE_LOG_FD
+
+lt_cl_help="\
+\`$as_me' creates a local libtool stub from the current configuration,
+for use in further configure time tests before the real libtool is
+generated.
+
+Usage: $[0] [[OPTIONS]]
+
+  -h, --help      print this help, then exit
+  -V, --version   print version number, then exit
+  -q, --quiet     do not print progress messages
+  -d, --debug     don't remove temporary files
+
+Report bugs to <bug-libtool@gnu.org>."
+
+lt_cl_version="\
+m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl
+m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION])
+configured by $[0], generated by m4_PACKAGE_STRING.
+
+Copyright (C) 2008 Free Software Foundation, Inc.
+This config.lt script is free software; the Free Software Foundation
+gives unlimited permision to copy, distribute and modify it."
+
+while test $[#] != 0
+do
+  case $[1] in
+    --version | --v* | -V )
+      echo "$lt_cl_version"; exit 0 ;;
+    --help | --h* | -h )
+      echo "$lt_cl_help"; exit 0 ;;
+    --debug | --d* | -d )
+      debug=: ;;
+    --quiet | --q* | --silent | --s* | -q )
+      lt_cl_silent=: ;;
+
+    -*) AC_MSG_ERROR([unrecognized option: $[1]
+Try \`$[0] --help' for more information.]) ;;
+
+    *) AC_MSG_ERROR([unrecognized argument: $[1]
+Try \`$[0] --help' for more information.]) ;;
+  esac
+  shift
+done
+
+if $lt_cl_silent; then
+  exec AS_MESSAGE_FD>/dev/null
+fi
+_LTEOF
+
+cat >>"$CONFIG_LT" <<_LTEOF
+_LT_OUTPUT_LIBTOOL_COMMANDS_INIT
+_LTEOF
+
+cat >>"$CONFIG_LT" <<\_LTEOF
+AC_MSG_NOTICE([creating $ofile])
+_LT_OUTPUT_LIBTOOL_COMMANDS
+AS_EXIT(0)
+_LTEOF
+chmod +x "$CONFIG_LT"
+
+# configure is writing to config.log, but config.lt does its own redirection,
+# appending to config.log, which fails on DOS, as config.log is still kept
+# open by configure.  Here we exec the FD to /dev/null, effectively closing
+# config.log, so it can be properly (re)opened and appended to by config.lt.
+if test "$no_create" != yes; then
+  lt_cl_success=:
+  test "$silent" = yes &&
+    lt_config_lt_args="$lt_config_lt_args --quiet"
+  exec AS_MESSAGE_LOG_FD>/dev/null
+  $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false
+  exec AS_MESSAGE_LOG_FD>>config.log
+  $lt_cl_success || AS_EXIT(1)
+fi
+])# LT_OUTPUT
+
+
+# _LT_CONFIG(TAG)
+# ---------------
+# If TAG is the built-in tag, create an initial libtool script with a
+# default configuration from the untagged config vars.  Otherwise add code
+# to config.status for appending the configuration named by TAG from the
+# matching tagged config vars.
+m4_defun([_LT_CONFIG],
+[m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+_LT_CONFIG_SAVE_COMMANDS([
+  m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl
+  m4_if(_LT_TAG, [C], [
+    # See if we are running on zsh, and set the options which allow our
+    # commands through without removal of \ escapes.
+    if test -n "${ZSH_VERSION+set}" ; then
+      setopt NO_GLOB_SUBST
+    fi
+
+    cfgfile="${ofile}T"
+    trap "$RM \"$cfgfile\"; exit 1" 1 2 15
+    $RM "$cfgfile"
+
+    cat <<_LT_EOF >> "$cfgfile"
+#! $SHELL
+
+# `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services.
+# Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION
+# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`:
+# NOTE: Changes made to this file will be lost: look at ltmain.sh.
+#
+_LT_COPYING
+_LT_LIBTOOL_TAGS
+
+# ### BEGIN LIBTOOL CONFIG
+_LT_LIBTOOL_CONFIG_VARS
+_LT_LIBTOOL_TAG_VARS
+# ### END LIBTOOL CONFIG
+
+_LT_EOF
+
+  case $host_os in
+  aix3*)
+    cat <<\_LT_EOF >> "$cfgfile"
+# AIX sometimes has problems with the GCC collect2 program.  For some
+# reason, if we set the COLLECT_NAMES environment variable, the problems
+# vanish in a puff of smoke.
+if test "X${COLLECT_NAMES+set}" != Xset; then
+  COLLECT_NAMES=
+  export COLLECT_NAMES
+fi
+_LT_EOF
+    ;;
+  esac
+
+  _LT_PROG_LTMAIN
+
+  # We use sed instead of cat because bash on DJGPP gets confused if
+  # if finds mixed CR/LF and LF-only lines.  Since sed operates in
+  # text mode, it properly converts lines to CR/LF.  This bash problem
+  # is reportedly fixed, but why not run on old versions too?
+  sed '/^# Generated shell functions inserted here/q' "$ltmain" >> "$cfgfile" \
+    || (rm -f "$cfgfile"; exit 1)
+
+  _LT_PROG_XSI_SHELLFNS
+
+  sed -n '/^# Generated shell functions inserted here/,$p' "$ltmain" >> "$cfgfile" \
+    || (rm -f "$cfgfile"; exit 1)
+
+  mv -f "$cfgfile" "$ofile" ||
+    (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile")
+  chmod +x "$ofile"
+],
+[cat <<_LT_EOF >> "$ofile"
+
+dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded
+dnl in a comment (ie after a #).
+# ### BEGIN LIBTOOL TAG CONFIG: $1
+_LT_LIBTOOL_TAG_VARS(_LT_TAG)
+# ### END LIBTOOL TAG CONFIG: $1
+_LT_EOF
+])dnl /m4_if
+],
+[m4_if([$1], [], [
+    PACKAGE='$PACKAGE'
+    VERSION='$VERSION'
+    TIMESTAMP='$TIMESTAMP'
+    RM='$RM'
+    ofile='$ofile'], [])
+])dnl /_LT_CONFIG_SAVE_COMMANDS
+])# _LT_CONFIG
+
+
+# LT_SUPPORTED_TAG(TAG)
+# ---------------------
+# Trace this macro to discover what tags are supported by the libtool
+# --tag option, using:
+#    autoconf --trace 'LT_SUPPORTED_TAG:$1'
+AC_DEFUN([LT_SUPPORTED_TAG], [])
+
+
+# C support is built-in for now
+m4_define([_LT_LANG_C_enabled], [])
+m4_define([_LT_TAGS], [])
+
+
+# LT_LANG(LANG)
+# -------------
+# Enable libtool support for the given language if not already enabled.
+AC_DEFUN([LT_LANG],
+[AC_BEFORE([$0], [LT_OUTPUT])dnl
+m4_case([$1],
+  [C],                 [_LT_LANG(C)],
+  [C++],               [_LT_LANG(CXX)],
+  [Java],              [_LT_LANG(GCJ)],
+  [Fortran 77],                [_LT_LANG(F77)],
+  [Fortran],           [_LT_LANG(FC)],
+  [Windows Resource],  [_LT_LANG(RC)],
+  [m4_ifdef([_LT_LANG_]$1[_CONFIG],
+    [_LT_LANG($1)],
+    [m4_fatal([$0: unsupported language: "$1"])])])dnl
+])# LT_LANG
+
+
+# _LT_LANG(LANGNAME)
+# ------------------
+m4_defun([_LT_LANG],
+[m4_ifdef([_LT_LANG_]$1[_enabled], [],
+  [LT_SUPPORTED_TAG([$1])dnl
+  m4_append([_LT_TAGS], [$1 ])dnl
+  m4_define([_LT_LANG_]$1[_enabled], [])dnl
+  _LT_LANG_$1_CONFIG($1)])dnl
+])# _LT_LANG
+
+
+# _LT_LANG_DEFAULT_CONFIG
+# -----------------------
+m4_defun([_LT_LANG_DEFAULT_CONFIG],
+[AC_PROVIDE_IFELSE([AC_PROG_CXX],
+  [LT_LANG(CXX)],
+  [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])])
+
+AC_PROVIDE_IFELSE([AC_PROG_F77],
+  [LT_LANG(F77)],
+  [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])])
+
+AC_PROVIDE_IFELSE([AC_PROG_FC],
+  [LT_LANG(FC)],
+  [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])])
+
+dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal
+dnl pulling things in needlessly.
+AC_PROVIDE_IFELSE([AC_PROG_GCJ],
+  [LT_LANG(GCJ)],
+  [AC_PROVIDE_IFELSE([A][M_PROG_GCJ],
+    [LT_LANG(GCJ)],
+    [AC_PROVIDE_IFELSE([LT_PROG_GCJ],
+      [LT_LANG(GCJ)],
+      [m4_ifdef([AC_PROG_GCJ],
+       [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])])
+       m4_ifdef([A][M_PROG_GCJ],
+       [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])])
+       m4_ifdef([LT_PROG_GCJ],
+       [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])])
+
+AC_PROVIDE_IFELSE([LT_PROG_RC],
+  [LT_LANG(RC)],
+  [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])])
+])# _LT_LANG_DEFAULT_CONFIG
+
+# Obsolete macros:
+AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)])
+AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)])
+AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)])
+AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_CXX], [])
+dnl AC_DEFUN([AC_LIBTOOL_F77], [])
+dnl AC_DEFUN([AC_LIBTOOL_FC], [])
+dnl AC_DEFUN([AC_LIBTOOL_GCJ], [])
+
+
+# _LT_TAG_COMPILER
+# ----------------
+m4_defun([_LT_TAG_COMPILER],
+[AC_REQUIRE([AC_PROG_CC])dnl
+
+_LT_DECL([LTCC], [CC], [1], [A C compiler])dnl
+_LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl
+_LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl
+_LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl
+
+# If no C compiler was specified, use CC.
+LTCC=${LTCC-"$CC"}
+
+# If no C compiler flags were specified, use CFLAGS.
+LTCFLAGS=${LTCFLAGS-"$CFLAGS"}
+
+# Allow CC to be a program name with arguments.
+compiler=$CC
+])# _LT_TAG_COMPILER
+
+
+# _LT_COMPILER_BOILERPLATE
+# ------------------------
+# Check for compiler boilerplate output or warnings with
+# the simple compiler test code.
+m4_defun([_LT_COMPILER_BOILERPLATE],
+[m4_require([_LT_DECL_SED])dnl
+ac_outfile=conftest.$ac_objext
+echo "$lt_simple_compile_test_code" >conftest.$ac_ext
+eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err
+_lt_compiler_boilerplate=`cat conftest.err`
+$RM conftest*
+])# _LT_COMPILER_BOILERPLATE
+
+
+# _LT_LINKER_BOILERPLATE
+# ----------------------
+# Check for linker boilerplate output or warnings with
+# the simple link test code.
+m4_defun([_LT_LINKER_BOILERPLATE],
+[m4_require([_LT_DECL_SED])dnl
+ac_outfile=conftest.$ac_objext
+echo "$lt_simple_link_test_code" >conftest.$ac_ext
+eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err
+_lt_linker_boilerplate=`cat conftest.err`
+$RM -r conftest*
+])# _LT_LINKER_BOILERPLATE
+
+# _LT_REQUIRED_DARWIN_CHECKS
+# -------------------------
+m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[
+  case $host_os in
+    rhapsody* | darwin*)
+    AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:])
+    AC_CHECK_TOOL([NMEDIT], [nmedit], [:])
+    AC_CHECK_TOOL([LIPO], [lipo], [:])
+    AC_CHECK_TOOL([OTOOL], [otool], [:])
+    AC_CHECK_TOOL([OTOOL64], [otool64], [:])
+    _LT_DECL([], [DSYMUTIL], [1],
+      [Tool to manipulate archived DWARF debug symbol files on Mac OS X])
+    _LT_DECL([], [NMEDIT], [1],
+      [Tool to change global to local symbols on Mac OS X])
+    _LT_DECL([], [LIPO], [1],
+      [Tool to manipulate fat objects and archives on Mac OS X])
+    _LT_DECL([], [OTOOL], [1],
+      [ldd/readelf like tool for Mach-O binaries on Mac OS X])
+    _LT_DECL([], [OTOOL64], [1],
+      [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4])
+
+    AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod],
+      [lt_cv_apple_cc_single_mod=no
+      if test -z "${LT_MULTI_MODULE}"; then
+       # By default we will add the -single_module flag. You can override
+       # by either setting the environment variable LT_MULTI_MODULE
+       # non-empty at configure time, or by adding -multi_module to the
+       # link flags.
+       rm -rf libconftest.dylib*
+       echo "int foo(void){return 1;}" > conftest.c
+       echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \
+-dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD
+       $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \
+         -dynamiclib -Wl,-single_module conftest.c 2>conftest.err
+        _lt_result=$?
+       if test -f libconftest.dylib && test ! -s conftest.err && test $_lt_result = 0; then
+         lt_cv_apple_cc_single_mod=yes
+       else
+         cat conftest.err >&AS_MESSAGE_LOG_FD
+       fi
+       rm -rf libconftest.dylib*
+       rm -f conftest.*
+      fi])
+    AC_CACHE_CHECK([for -exported_symbols_list linker flag],
+      [lt_cv_ld_exported_symbols_list],
+      [lt_cv_ld_exported_symbols_list=no
+      save_LDFLAGS=$LDFLAGS
+      echo "_main" > conftest.sym
+      LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym"
+      AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])],
+       [lt_cv_ld_exported_symbols_list=yes],
+       [lt_cv_ld_exported_symbols_list=no])
+       LDFLAGS="$save_LDFLAGS"
+    ])
+    case $host_os in
+    rhapsody* | darwin1.[[012]])
+      _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;;
+    darwin1.*)
+      _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+    darwin*) # darwin 5.x on
+      # if running on 10.5 or later, the deployment target defaults
+      # to the OS version, if on x86, and 10.4, the deployment
+      # target defaults to 10.4. Don't you love it?
+      case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in
+       10.0,*86*-darwin8*|10.0,*-darwin[[91]]*)
+         _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+       10.[[012]]*)
+         _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+       10.*)
+         _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+      esac
+    ;;
+  esac
+    if test "$lt_cv_apple_cc_single_mod" = "yes"; then
+      _lt_dar_single_mod='$single_module'
+    fi
+    if test "$lt_cv_ld_exported_symbols_list" = "yes"; then
+      _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym'
+    else
+      _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}'
+    fi
+    if test "$DSYMUTIL" != ":"; then
+      _lt_dsymutil='~$DSYMUTIL $lib || :'
+    else
+      _lt_dsymutil=
+    fi
+    ;;
+  esac
+])
+
+
+# _LT_DARWIN_LINKER_FEATURES
+# --------------------------
+# Checks for linker and compiler features on darwin
+m4_defun([_LT_DARWIN_LINKER_FEATURES],
+[
+  m4_require([_LT_REQUIRED_DARWIN_CHECKS])
+  _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+  _LT_TAGVAR(hardcode_direct, $1)=no
+  _LT_TAGVAR(hardcode_automatic, $1)=yes
+  _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
+  _LT_TAGVAR(whole_archive_flag_spec, $1)=''
+  _LT_TAGVAR(link_all_deplibs, $1)=yes
+  _LT_TAGVAR(allow_undefined_flag, $1)="$_lt_dar_allow_undefined"
+  case $cc_basename in
+     ifort*) _lt_dar_can_shared=yes ;;
+     *) _lt_dar_can_shared=$GCC ;;
+  esac
+  if test "$_lt_dar_can_shared" = "yes"; then
+    output_verbose_link_cmd=echo
+    _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}"
+    _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}"
+    _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}"
+    _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}"
+    m4_if([$1], [CXX],
+[   if test "$lt_cv_apple_cc_single_mod" != "yes"; then
+      _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}"
+      _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}"
+    fi
+],[])
+  else
+  _LT_TAGVAR(ld_shlibs, $1)=no
+  fi
+])
+
+# _LT_SYS_MODULE_PATH_AIX
+# -----------------------
+# Links a minimal program and checks the executable
+# for the system default hardcoded library path. In most cases,
+# this is /usr/lib:/lib, but when the MPI compilers are used
+# the location of the communication and MPI libs are included too.
+# If we don't find anything, use the default library path according
+# to the aix ld manual.
+m4_defun([_LT_SYS_MODULE_PATH_AIX],
+[m4_require([_LT_DECL_SED])dnl
+AC_LINK_IFELSE(AC_LANG_PROGRAM,[
+lt_aix_libpath_sed='
+    /Import File Strings/,/^$/ {
+       /^0/ {
+           s/^0  *\(.*\)$/\1/
+           p
+       }
+    }'
+aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
+# Check for a 64-bit object if we didn't find anything.
+if test -z "$aix_libpath"; then
+  aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
+fi],[])
+if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi
+])# _LT_SYS_MODULE_PATH_AIX
+
+
+# _LT_SHELL_INIT(ARG)
+# -------------------
+m4_define([_LT_SHELL_INIT],
+[ifdef([AC_DIVERSION_NOTICE],
+            [AC_DIVERT_PUSH(AC_DIVERSION_NOTICE)],
+        [AC_DIVERT_PUSH(NOTICE)])
+$1
+AC_DIVERT_POP
+])# _LT_SHELL_INIT
+
+
+# _LT_PROG_ECHO_BACKSLASH
+# -----------------------
+# Add some code to the start of the generated configure script which
+# will find an echo command which doesn't interpret backslashes.
+m4_defun([_LT_PROG_ECHO_BACKSLASH],
+[_LT_SHELL_INIT([
+# Check that we are running under the correct shell.
+SHELL=${CONFIG_SHELL-/bin/sh}
+
+case X$lt_ECHO in
+X*--fallback-echo)
+  # Remove one level of quotation (which was required for Make).
+  ECHO=`echo "$lt_ECHO" | sed 's,\\\\\[$]\\[$]0,'[$]0','`
+  ;;
+esac
+
+ECHO=${lt_ECHO-echo}
+if test "X[$]1" = X--no-reexec; then
+  # Discard the --no-reexec flag, and continue.
+  shift
+elif test "X[$]1" = X--fallback-echo; then
+  # Avoid inline document here, it may be left over
+  :
+elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' ; then
+  # Yippee, $ECHO works!
+  :
+else
+  # Restart under the correct shell.
+  exec $SHELL "[$]0" --no-reexec ${1+"[$]@"}
+fi
+
+if test "X[$]1" = X--fallback-echo; then
+  # used as fallback echo
+  shift
+  cat <<_LT_EOF
+[$]*
+_LT_EOF
+  exit 0
+fi
+
+# The HP-UX ksh and POSIX shell print the target directory to stdout
+# if CDPATH is set.
+(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
+
+if test -z "$lt_ECHO"; then
+  if test "X${echo_test_string+set}" != Xset; then
+    # find a string as large as possible, as long as the shell can cope with it
+    for cmd in 'sed 50q "[$]0"' 'sed 20q "[$]0"' 'sed 10q "[$]0"' 'sed 2q "[$]0"' 'echo test'; do
+      # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ...
+      if { echo_test_string=`eval $cmd`; } 2>/dev/null &&
+        { test "X$echo_test_string" = "X$echo_test_string"; } 2>/dev/null
+      then
+        break
+      fi
+    done
+  fi
+
+  if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' &&
+     echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` &&
+     test "X$echo_testing_string" = "X$echo_test_string"; then
+    :
+  else
+    # The Solaris, AIX, and Digital Unix default echo programs unquote
+    # backslashes.  This makes it impossible to quote backslashes using
+    #   echo "$something" | sed 's/\\/\\\\/g'
+    #
+    # So, first we look for a working echo in the user's PATH.
+
+    lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+    for dir in $PATH /usr/ucb; do
+      IFS="$lt_save_ifs"
+      if (test -f $dir/echo || test -f $dir/echo$ac_exeext) &&
+         test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' &&
+         echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` &&
+         test "X$echo_testing_string" = "X$echo_test_string"; then
+        ECHO="$dir/echo"
+        break
+      fi
+    done
+    IFS="$lt_save_ifs"
+
+    if test "X$ECHO" = Xecho; then
+      # We didn't find a better echo, so look for alternatives.
+      if test "X`{ print -r '\t'; } 2>/dev/null`" = 'X\t' &&
+         echo_testing_string=`{ print -r "$echo_test_string"; } 2>/dev/null` &&
+         test "X$echo_testing_string" = "X$echo_test_string"; then
+        # This shell has a builtin print -r that does the trick.
+        ECHO='print -r'
+      elif { test -f /bin/ksh || test -f /bin/ksh$ac_exeext; } &&
+          test "X$CONFIG_SHELL" != X/bin/ksh; then
+        # If we have ksh, try running configure again with it.
+        ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh}
+        export ORIGINAL_CONFIG_SHELL
+        CONFIG_SHELL=/bin/ksh
+        export CONFIG_SHELL
+        exec $CONFIG_SHELL "[$]0" --no-reexec ${1+"[$]@"}
+      else
+        # Try using printf.
+        ECHO='printf %s\n'
+        if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' &&
+          echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` &&
+          test "X$echo_testing_string" = "X$echo_test_string"; then
+         # Cool, printf works
+         :
+        elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` &&
+            test "X$echo_testing_string" = 'X\t' &&
+            echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` &&
+            test "X$echo_testing_string" = "X$echo_test_string"; then
+         CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL
+         export CONFIG_SHELL
+         SHELL="$CONFIG_SHELL"
+         export SHELL
+         ECHO="$CONFIG_SHELL [$]0 --fallback-echo"
+        elif echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` &&
+            test "X$echo_testing_string" = 'X\t' &&
+            echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` &&
+            test "X$echo_testing_string" = "X$echo_test_string"; then
+         ECHO="$CONFIG_SHELL [$]0 --fallback-echo"
+        else
+         # maybe with a smaller string...
+         prev=:
+
+         for cmd in 'echo test' 'sed 2q "[$]0"' 'sed 10q "[$]0"' 'sed 20q "[$]0"' 'sed 50q "[$]0"'; do
+           if { test "X$echo_test_string" = "X`eval $cmd`"; } 2>/dev/null
+           then
+             break
+           fi
+           prev="$cmd"
+         done
+
+         if test "$prev" != 'sed 50q "[$]0"'; then
+           echo_test_string=`eval $prev`
+           export echo_test_string
+           exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "[$]0" ${1+"[$]@"}
+         else
+           # Oops.  We lost completely, so just stick with echo.
+           ECHO=echo
+         fi
+        fi
+      fi
+    fi
+  fi
+fi
+
+# Copy echo and quote the copy suitably for passing to libtool from
+# the Makefile, instead of quoting the original, which is used later.
+lt_ECHO=$ECHO
+if test "X$lt_ECHO" = "X$CONFIG_SHELL [$]0 --fallback-echo"; then
+   lt_ECHO="$CONFIG_SHELL \\\$\[$]0 --fallback-echo"
+fi
+
+AC_SUBST(lt_ECHO)
+])
+_LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts])
+_LT_DECL([], [ECHO], [1],
+    [An echo program that does not interpret backslashes])
+])# _LT_PROG_ECHO_BACKSLASH
+
+
+# _LT_ENABLE_LOCK
+# ---------------
+m4_defun([_LT_ENABLE_LOCK],
+[AC_ARG_ENABLE([libtool-lock],
+  [AS_HELP_STRING([--disable-libtool-lock],
+    [avoid locking (might break parallel builds)])])
+test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes
+
+# Some flags need to be propagated to the compiler or linker for good
+# libtool support.
+case $host in
+ia64-*-hpux*)
+  # Find out which ABI we are using.
+  echo 'int i;' > conftest.$ac_ext
+  if AC_TRY_EVAL(ac_compile); then
+    case `/usr/bin/file conftest.$ac_objext` in
+      *ELF-32*)
+       HPUX_IA64_MODE="32"
+       ;;
+      *ELF-64*)
+       HPUX_IA64_MODE="64"
+       ;;
+    esac
+  fi
+  rm -rf conftest*
+  ;;
+*-*-irix6*)
+  # Find out which ABI we are using.
+  echo '[#]line __oline__ "configure"' > conftest.$ac_ext
+  if AC_TRY_EVAL(ac_compile); then
+    if test "$lt_cv_prog_gnu_ld" = yes; then
+      case `/usr/bin/file conftest.$ac_objext` in
+       *32-bit*)
+         LD="${LD-ld} -melf32bsmip"
+         ;;
+       *N32*)
+         LD="${LD-ld} -melf32bmipn32"
+         ;;
+       *64-bit*)
+         LD="${LD-ld} -melf64bmip"
+       ;;
+      esac
+    else
+      case `/usr/bin/file conftest.$ac_objext` in
+       *32-bit*)
+         LD="${LD-ld} -32"
+         ;;
+       *N32*)
+         LD="${LD-ld} -n32"
+         ;;
+       *64-bit*)
+         LD="${LD-ld} -64"
+         ;;
+      esac
+    fi
+  fi
+  rm -rf conftest*
+  ;;
+
+x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \
+s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
+  # Find out which ABI we are using.
+  echo 'int i;' > conftest.$ac_ext
+  if AC_TRY_EVAL(ac_compile); then
+    case `/usr/bin/file conftest.o` in
+      *32-bit*)
+       case $host in
+         x86_64-*kfreebsd*-gnu)
+           LD="${LD-ld} -m elf_i386_fbsd"
+           ;;
+         x86_64-*linux*)
+           LD="${LD-ld} -m elf_i386"
+           ;;
+         ppc64-*linux*|powerpc64-*linux*)
+           LD="${LD-ld} -m elf32ppclinux"
+           ;;
+         s390x-*linux*)
+           LD="${LD-ld} -m elf_s390"
+           ;;
+         sparc64-*linux*)
+           LD="${LD-ld} -m elf32_sparc"
+           ;;
+       esac
+       ;;
+      *64-bit*)
+       case $host in
+         x86_64-*kfreebsd*-gnu)
+           LD="${LD-ld} -m elf_x86_64_fbsd"
+           ;;
+         x86_64-*linux*)
+           LD="${LD-ld} -m elf_x86_64"
+           ;;
+         ppc*-*linux*|powerpc*-*linux*)
+           LD="${LD-ld} -m elf64ppc"
+           ;;
+         s390*-*linux*|s390*-*tpf*)
+           LD="${LD-ld} -m elf64_s390"
+           ;;
+         sparc*-*linux*)
+           LD="${LD-ld} -m elf64_sparc"
+           ;;
+       esac
+       ;;
+    esac
+  fi
+  rm -rf conftest*
+  ;;
+
+*-*-sco3.2v5*)
+  # On SCO OpenServer 5, we need -belf to get full-featured binaries.
+  SAVE_CFLAGS="$CFLAGS"
+  CFLAGS="$CFLAGS -belf"
+  AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf,
+    [AC_LANG_PUSH(C)
+     AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no])
+     AC_LANG_POP])
+  if test x"$lt_cv_cc_needs_belf" != x"yes"; then
+    # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
+    CFLAGS="$SAVE_CFLAGS"
+  fi
+  ;;
+sparc*-*solaris*)
+  # Find out which ABI we are using.
+  echo 'int i;' > conftest.$ac_ext
+  if AC_TRY_EVAL(ac_compile); then
+    case `/usr/bin/file conftest.o` in
+    *64-bit*)
+      case $lt_cv_prog_gnu_ld in
+      yes*) LD="${LD-ld} -m elf64_sparc" ;;
+      *)
+       if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then
+         LD="${LD-ld} -64"
+       fi
+       ;;
+      esac
+      ;;
+    esac
+  fi
+  rm -rf conftest*
+  ;;
+esac
+
+need_locks="$enable_libtool_lock"
+])# _LT_ENABLE_LOCK
+
+
+# _LT_CMD_OLD_ARCHIVE
+# -------------------
+m4_defun([_LT_CMD_OLD_ARCHIVE],
+[AC_CHECK_TOOL(AR, ar, false)
+test -z "$AR" && AR=ar
+test -z "$AR_FLAGS" && AR_FLAGS=cru
+_LT_DECL([], [AR], [1], [The archiver])
+_LT_DECL([], [AR_FLAGS], [1])
+
+AC_CHECK_TOOL(STRIP, strip, :)
+test -z "$STRIP" && STRIP=:
+_LT_DECL([], [STRIP], [1], [A symbol stripping program])
+
+AC_CHECK_TOOL(RANLIB, ranlib, :)
+test -z "$RANLIB" && RANLIB=:
+_LT_DECL([], [RANLIB], [1],
+    [Commands used to install an old-style archive])
+
+# Determine commands to create old-style static archives.
+old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs'
+old_postinstall_cmds='chmod 644 $oldlib'
+old_postuninstall_cmds=
+
+if test -n "$RANLIB"; then
+  case $host_os in
+  openbsd*)
+    old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$oldlib"
+    ;;
+  *)
+    old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$oldlib"
+    ;;
+  esac
+  old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib"
+fi
+_LT_DECL([], [old_postinstall_cmds], [2])
+_LT_DECL([], [old_postuninstall_cmds], [2])
+_LT_TAGDECL([], [old_archive_cmds], [2],
+    [Commands used to build an old-style archive])
+])# _LT_CMD_OLD_ARCHIVE
+
+
+# _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS,
+#              [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE])
+# ----------------------------------------------------------------
+# Check whether the given compiler option works
+AC_DEFUN([_LT_COMPILER_OPTION],
+[m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+m4_require([_LT_DECL_SED])dnl
+AC_CACHE_CHECK([$1], [$2],
+  [$2=no
+   m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4])
+   echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+   lt_compiler_flag="$3"
+   # Insert the option either (1) after the last *FLAGS variable, or
+   # (2) before a word containing "conftest.", or (3) at the end.
+   # Note that $ac_compile itself does not contain backslashes and begins
+   # with a dollar sign (not a hyphen), so the echo should work correctly.
+   # The option is referenced via a variable to avoid confusing sed.
+   lt_compile=`echo "$ac_compile" | $SED \
+   -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
+   -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \
+   -e 's:$: $lt_compiler_flag:'`
+   (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD)
+   (eval "$lt_compile" 2>conftest.err)
+   ac_status=$?
+   cat conftest.err >&AS_MESSAGE_LOG_FD
+   echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD
+   if (exit $ac_status) && test -s "$ac_outfile"; then
+     # The compiler can only warn and ignore the option if not recognized
+     # So say no if there are warnings other than the usual output.
+     $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp
+     $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2
+     if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then
+       $2=yes
+     fi
+   fi
+   $RM conftest*
+])
+
+if test x"[$]$2" = xyes; then
+    m4_if([$5], , :, [$5])
+else
+    m4_if([$6], , :, [$6])
+fi
+])# _LT_COMPILER_OPTION
+
+# Old name:
+AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], [])
+
+
+# _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS,
+#                  [ACTION-SUCCESS], [ACTION-FAILURE])
+# ----------------------------------------------------
+# Check whether the given linker option works
+AC_DEFUN([_LT_LINKER_OPTION],
+[m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+m4_require([_LT_DECL_SED])dnl
+AC_CACHE_CHECK([$1], [$2],
+  [$2=no
+   save_LDFLAGS="$LDFLAGS"
+   LDFLAGS="$LDFLAGS $3"
+   echo "$lt_simple_link_test_code" > conftest.$ac_ext
+   if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
+     # The linker can only warn and ignore the option if not recognized
+     # So say no if there are warnings
+     if test -s conftest.err; then
+       # Append any errors to the config.log.
+       cat conftest.err 1>&AS_MESSAGE_LOG_FD
+       $ECHO "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp
+       $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2
+       if diff conftest.exp conftest.er2 >/dev/null; then
+         $2=yes
+       fi
+     else
+       $2=yes
+     fi
+   fi
+   $RM -r conftest*
+   LDFLAGS="$save_LDFLAGS"
+])
+
+if test x"[$]$2" = xyes; then
+    m4_if([$4], , :, [$4])
+else
+    m4_if([$5], , :, [$5])
+fi
+])# _LT_LINKER_OPTION
+
+# Old name:
+AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], [])
+
+
+# LT_CMD_MAX_LEN
+#---------------
+AC_DEFUN([LT_CMD_MAX_LEN],
+[AC_REQUIRE([AC_CANONICAL_HOST])dnl
+# find the maximum length of command line arguments
+AC_MSG_CHECKING([the maximum length of command line arguments])
+AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
+  i=0
+  teststring="ABCD"
+
+  case $build_os in
+  msdosdjgpp*)
+    # On DJGPP, this test can blow up pretty badly due to problems in libc
+    # (any single argument exceeding 2000 bytes causes a buffer overrun
+    # during glob expansion).  Even if it were fixed, the result of this
+    # check would be larger than it should be.
+    lt_cv_sys_max_cmd_len=12288;    # 12K is about right
+    ;;
+
+  gnu*)
+    # Under GNU Hurd, this test is not required because there is
+    # no limit to the length of command line arguments.
+    # Libtool will interpret -1 as no limit whatsoever
+    lt_cv_sys_max_cmd_len=-1;
+    ;;
+
+  cygwin* | mingw* | cegcc*)
+    # On Win9x/ME, this test blows up -- it succeeds, but takes
+    # about 5 minutes as the teststring grows exponentially.
+    # Worse, since 9x/ME are not pre-emptively multitasking,
+    # you end up with a "frozen" computer, even though with patience
+    # the test eventually succeeds (with a max line length of 256k).
+    # Instead, let's just punt: use the minimum linelength reported by
+    # all of the supported platforms: 8192 (on NT/2K/XP).
+    lt_cv_sys_max_cmd_len=8192;
+    ;;
+
+  amigaos*)
+    # On AmigaOS with pdksh, this test takes hours, literally.
+    # So we just punt and use a minimum line length of 8192.
+    lt_cv_sys_max_cmd_len=8192;
+    ;;
+
+  netbsd* | freebsd* | openbsd* | darwin* | dragonfly*)
+    # This has been around since 386BSD, at least.  Likely further.
+    if test -x /sbin/sysctl; then
+      lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax`
+    elif test -x /usr/sbin/sysctl; then
+      lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax`
+    else
+      lt_cv_sys_max_cmd_len=65536      # usable default for all BSDs
+    fi
+    # And add a safety zone
+    lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4`
+    lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3`
+    ;;
+
+  interix*)
+    # We know the value 262144 and hardcode it with a safety zone (like BSD)
+    lt_cv_sys_max_cmd_len=196608
+    ;;
+
+  osf*)
+    # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure
+    # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not
+    # nice to cause kernel panics so lets avoid the loop below.
+    # First set a reasonable default.
+    lt_cv_sys_max_cmd_len=16384
+    #
+    if test -x /sbin/sysconfig; then
+      case `/sbin/sysconfig -q proc exec_disable_arg_limit` in
+        *1*) lt_cv_sys_max_cmd_len=-1 ;;
+      esac
+    fi
+    ;;
+  sco3.2v5*)
+    lt_cv_sys_max_cmd_len=102400
+    ;;
+  sysv5* | sco5v6* | sysv4.2uw2*)
+    kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null`
+    if test -n "$kargmax"; then
+      lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[[        ]]//'`
+    else
+      lt_cv_sys_max_cmd_len=32768
+    fi
+    ;;
+  *)
+    lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null`
+    if test -n "$lt_cv_sys_max_cmd_len"; then
+      lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4`
+      lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3`
+    else
+      # Make teststring a little bigger before we do anything with it.
+      # a 1K string should be a reasonable start.
+      for i in 1 2 3 4 5 6 7 8 ; do
+        teststring=$teststring$teststring
+      done
+      SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}}
+      # If test is not a shell built-in, we'll probably end up computing a
+      # maximum length that is only half of the actual maximum length, but
+      # we can't tell.
+      while { test "X"`$SHELL [$]0 --fallback-echo "X$teststring$teststring" 2>/dev/null` \
+                = "XX$teststring$teststring"; } >/dev/null 2>&1 &&
+             test $i != 17 # 1/2 MB should be enough
+      do
+        i=`expr $i + 1`
+        teststring=$teststring$teststring
+      done
+      # Only check the string length outside the loop.
+      lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1`
+      teststring=
+      # Add a significant safety factor because C++ compilers can tack on
+      # massive amounts of additional arguments before passing them to the
+      # linker.  It appears as though 1/2 is a usable value.
+      lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2`
+    fi
+    ;;
+  esac
+])
+if test -n $lt_cv_sys_max_cmd_len ; then
+  AC_MSG_RESULT($lt_cv_sys_max_cmd_len)
+else
+  AC_MSG_RESULT(none)
+fi
+max_cmd_len=$lt_cv_sys_max_cmd_len
+_LT_DECL([], [max_cmd_len], [0],
+    [What is the maximum length of a command?])
+])# LT_CMD_MAX_LEN
+
+# Old name:
+AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], [])
+
+
+# _LT_HEADER_DLFCN
+# ----------------
+m4_defun([_LT_HEADER_DLFCN],
+[AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl
+])# _LT_HEADER_DLFCN
+
+
+# _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE,
+#                      ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING)
+# ----------------------------------------------------------------
+m4_defun([_LT_TRY_DLOPEN_SELF],
+[m4_require([_LT_HEADER_DLFCN])dnl
+if test "$cross_compiling" = yes; then :
+  [$4]
+else
+  lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
+  lt_status=$lt_dlunknown
+  cat > conftest.$ac_ext <<_LT_EOF
+[#line __oline__ "configure"
+#include "confdefs.h"
+
+#if HAVE_DLFCN_H
+#include <dlfcn.h>
+#endif
+
+#include <stdio.h>
+
+#ifdef RTLD_GLOBAL
+#  define LT_DLGLOBAL          RTLD_GLOBAL
+#else
+#  ifdef DL_GLOBAL
+#    define LT_DLGLOBAL                DL_GLOBAL
+#  else
+#    define LT_DLGLOBAL                0
+#  endif
+#endif
+
+/* We may have to define LT_DLLAZY_OR_NOW in the command line if we
+   find out it does not work in some platform. */
+#ifndef LT_DLLAZY_OR_NOW
+#  ifdef RTLD_LAZY
+#    define LT_DLLAZY_OR_NOW           RTLD_LAZY
+#  else
+#    ifdef DL_LAZY
+#      define LT_DLLAZY_OR_NOW         DL_LAZY
+#    else
+#      ifdef RTLD_NOW
+#        define LT_DLLAZY_OR_NOW       RTLD_NOW
+#      else
+#        ifdef DL_NOW
+#          define LT_DLLAZY_OR_NOW     DL_NOW
+#        else
+#          define LT_DLLAZY_OR_NOW     0
+#        endif
+#      endif
+#    endif
+#  endif
+#endif
+
+void fnord() { int i=42;}
+int main ()
+{
+  void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW);
+  int status = $lt_dlunknown;
+
+  if (self)
+    {
+      if (dlsym (self,"fnord"))       status = $lt_dlno_uscore;
+      else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore;
+      /* dlclose (self); */
+    }
+  else
+    puts (dlerror ());
+
+  return status;
+}]
+_LT_EOF
+  if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then
+    (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null
+    lt_status=$?
+    case x$lt_status in
+      x$lt_dlno_uscore) $1 ;;
+      x$lt_dlneed_uscore) $2 ;;
+      x$lt_dlunknown|x*) $3 ;;
+    esac
+  else :
+    # compilation failed
+    $3
+  fi
+fi
+rm -fr conftest*
+])# _LT_TRY_DLOPEN_SELF
+
+
+# LT_SYS_DLOPEN_SELF
+# ------------------
+AC_DEFUN([LT_SYS_DLOPEN_SELF],
+[m4_require([_LT_HEADER_DLFCN])dnl
+if test "x$enable_dlopen" != xyes; then
+  enable_dlopen=unknown
+  enable_dlopen_self=unknown
+  enable_dlopen_self_static=unknown
+else
+  lt_cv_dlopen=no
+  lt_cv_dlopen_libs=
+
+  case $host_os in
+  beos*)
+    lt_cv_dlopen="load_add_on"
+    lt_cv_dlopen_libs=
+    lt_cv_dlopen_self=yes
+    ;;
+
+  mingw* | pw32* | cegcc*)
+    lt_cv_dlopen="LoadLibrary"
+    lt_cv_dlopen_libs=
+    ;;
+
+  cygwin*)
+    lt_cv_dlopen="dlopen"
+    lt_cv_dlopen_libs=
+    ;;
+
+  darwin*)
+  # if libdl is installed we need to link against it
+    AC_CHECK_LIB([dl], [dlopen],
+               [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],[
+    lt_cv_dlopen="dyld"
+    lt_cv_dlopen_libs=
+    lt_cv_dlopen_self=yes
+    ])
+    ;;
+
+  *)
+    AC_CHECK_FUNC([shl_load],
+         [lt_cv_dlopen="shl_load"],
+      [AC_CHECK_LIB([dld], [shl_load],
+           [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"],
+       [AC_CHECK_FUNC([dlopen],
+             [lt_cv_dlopen="dlopen"],
+         [AC_CHECK_LIB([dl], [dlopen],
+               [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],
+           [AC_CHECK_LIB([svld], [dlopen],
+                 [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"],
+             [AC_CHECK_LIB([dld], [dld_link],
+                   [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"])
+             ])
+           ])
+         ])
+       ])
+      ])
+    ;;
+  esac
+
+  if test "x$lt_cv_dlopen" != xno; then
+    enable_dlopen=yes
+  else
+    enable_dlopen=no
+  fi
+
+  case $lt_cv_dlopen in
+  dlopen)
+    save_CPPFLAGS="$CPPFLAGS"
+    test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
+
+    save_LDFLAGS="$LDFLAGS"
+    wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\"
+
+    save_LIBS="$LIBS"
+    LIBS="$lt_cv_dlopen_libs $LIBS"
+
+    AC_CACHE_CHECK([whether a program can dlopen itself],
+         lt_cv_dlopen_self, [dnl
+         _LT_TRY_DLOPEN_SELF(
+           lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes,
+           lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross)
+    ])
+
+    if test "x$lt_cv_dlopen_self" = xyes; then
+      wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\"
+      AC_CACHE_CHECK([whether a statically linked program can dlopen itself],
+         lt_cv_dlopen_self_static, [dnl
+         _LT_TRY_DLOPEN_SELF(
+           lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes,
+           lt_cv_dlopen_self_static=no,  lt_cv_dlopen_self_static=cross)
+      ])
+    fi
+
+    CPPFLAGS="$save_CPPFLAGS"
+    LDFLAGS="$save_LDFLAGS"
+    LIBS="$save_LIBS"
+    ;;
+  esac
+
+  case $lt_cv_dlopen_self in
+  yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;;
+  *) enable_dlopen_self=unknown ;;
+  esac
+
+  case $lt_cv_dlopen_self_static in
+  yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;;
+  *) enable_dlopen_self_static=unknown ;;
+  esac
+fi
+_LT_DECL([dlopen_support], [enable_dlopen], [0],
+        [Whether dlopen is supported])
+_LT_DECL([dlopen_self], [enable_dlopen_self], [0],
+        [Whether dlopen of programs is supported])
+_LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0],
+        [Whether dlopen of statically linked programs is supported])
+])# LT_SYS_DLOPEN_SELF
+
+# Old name:
+AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], [])
+
+
+# _LT_COMPILER_C_O([TAGNAME])
+# ---------------------------
+# Check to see if options -c and -o are simultaneously supported by compiler.
+# This macro does not hard code the compiler like AC_PROG_CC_C_O.
+m4_defun([_LT_COMPILER_C_O],
+[m4_require([_LT_DECL_SED])dnl
+m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+m4_require([_LT_TAG_COMPILER])dnl
+AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext],
+  [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)],
+  [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no
+   $RM -r conftest 2>/dev/null
+   mkdir conftest
+   cd conftest
+   mkdir out
+   echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+
+   lt_compiler_flag="-o out/conftest2.$ac_objext"
+   # Insert the option either (1) after the last *FLAGS variable, or
+   # (2) before a word containing "conftest.", or (3) at the end.
+   # Note that $ac_compile itself does not contain backslashes and begins
+   # with a dollar sign (not a hyphen), so the echo should work correctly.
+   lt_compile=`echo "$ac_compile" | $SED \
+   -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
+   -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \
+   -e 's:$: $lt_compiler_flag:'`
+   (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD)
+   (eval "$lt_compile" 2>out/conftest.err)
+   ac_status=$?
+   cat out/conftest.err >&AS_MESSAGE_LOG_FD
+   echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD
+   if (exit $ac_status) && test -s out/conftest2.$ac_objext
+   then
+     # The compiler can only warn and ignore the option if not recognized
+     # So say no if there are warnings
+     $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp
+     $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2
+     if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then
+       _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes
+     fi
+   fi
+   chmod u+w . 2>&AS_MESSAGE_LOG_FD
+   $RM conftest*
+   # SGI C++ compiler will create directory out/ii_files/ for
+   # template instantiation
+   test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files
+   $RM out/* && rmdir out
+   cd ..
+   $RM -r conftest
+   $RM conftest*
+])
+_LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1],
+       [Does compiler simultaneously support -c and -o options?])
+])# _LT_COMPILER_C_O
+
+
+# _LT_COMPILER_FILE_LOCKS([TAGNAME])
+# ----------------------------------
+# Check to see if we can do hard links to lock some files if needed
+m4_defun([_LT_COMPILER_FILE_LOCKS],
+[m4_require([_LT_ENABLE_LOCK])dnl
+m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+_LT_COMPILER_C_O([$1])
+
+hard_links="nottested"
+if test "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then
+  # do not overwrite the value of need_locks provided by the user
+  AC_MSG_CHECKING([if we can lock with hard links])
+  hard_links=yes
+  $RM conftest*
+  ln conftest.a conftest.b 2>/dev/null && hard_links=no
+  touch conftest.a
+  ln conftest.a conftest.b 2>&5 || hard_links=no
+  ln conftest.a conftest.b 2>/dev/null && hard_links=no
+  AC_MSG_RESULT([$hard_links])
+  if test "$hard_links" = no; then
+    AC_MSG_WARN([`$CC' does not support `-c -o', so `make -j' may be unsafe])
+    need_locks=warn
+  fi
+else
+  need_locks=no
+fi
+_LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?])
+])# _LT_COMPILER_FILE_LOCKS
+
+
+# _LT_CHECK_OBJDIR
+# ----------------
+m4_defun([_LT_CHECK_OBJDIR],
+[AC_CACHE_CHECK([for objdir], [lt_cv_objdir],
+[rm -f .libs 2>/dev/null
+mkdir .libs 2>/dev/null
+if test -d .libs; then
+  lt_cv_objdir=.libs
+else
+  # MS-DOS does not allow filenames that begin with a dot.
+  lt_cv_objdir=_libs
+fi
+rmdir .libs 2>/dev/null])
+objdir=$lt_cv_objdir
+_LT_DECL([], [objdir], [0],
+         [The name of the directory that contains temporary libtool files])dnl
+m4_pattern_allow([LT_OBJDIR])dnl
+AC_DEFINE_UNQUOTED(LT_OBJDIR, "$lt_cv_objdir/",
+  [Define to the sub-directory in which libtool stores uninstalled libraries.])
+])# _LT_CHECK_OBJDIR
+
+
+# _LT_LINKER_HARDCODE_LIBPATH([TAGNAME])
+# --------------------------------------
+# Check hardcoding attributes.
+m4_defun([_LT_LINKER_HARDCODE_LIBPATH],
+[AC_MSG_CHECKING([how to hardcode library paths into programs])
+_LT_TAGVAR(hardcode_action, $1)=
+if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" ||
+   test -n "$_LT_TAGVAR(runpath_var, $1)" ||
+   test "X$_LT_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then
+
+  # We can hardcode non-existent directories.
+  if test "$_LT_TAGVAR(hardcode_direct, $1)" != no &&
+     # If the only mechanism to avoid hardcoding is shlibpath_var, we
+     # have to relink, otherwise we might link with an installed library
+     # when we should be linking with a yet-to-be-installed one
+     ## test "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" != no &&
+     test "$_LT_TAGVAR(hardcode_minus_L, $1)" != no; then
+    # Linking always hardcodes the temporary library directory.
+    _LT_TAGVAR(hardcode_action, $1)=relink
+  else
+    # We can link without hardcoding, and we can hardcode nonexisting dirs.
+    _LT_TAGVAR(hardcode_action, $1)=immediate
+  fi
+else
+  # We cannot hardcode anything, or else we can only hardcode existing
+  # directories.
+  _LT_TAGVAR(hardcode_action, $1)=unsupported
+fi
+AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)])
+
+if test "$_LT_TAGVAR(hardcode_action, $1)" = relink ||
+   test "$_LT_TAGVAR(inherit_rpath, $1)" = yes; then
+  # Fast installation is not supported
+  enable_fast_install=no
+elif test "$shlibpath_overrides_runpath" = yes ||
+     test "$enable_shared" = no; then
+  # Fast installation is not necessary
+  enable_fast_install=needless
+fi
+_LT_TAGDECL([], [hardcode_action], [0],
+    [How to hardcode a shared library path into an executable])
+])# _LT_LINKER_HARDCODE_LIBPATH
+
+
+# _LT_CMD_STRIPLIB
+# ----------------
+m4_defun([_LT_CMD_STRIPLIB],
+[m4_require([_LT_DECL_EGREP])
+striplib=
+old_striplib=
+AC_MSG_CHECKING([whether stripping libraries is possible])
+if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then
+  test -z "$old_striplib" && old_striplib="$STRIP --strip-debug"
+  test -z "$striplib" && striplib="$STRIP --strip-unneeded"
+  AC_MSG_RESULT([yes])
+else
+# FIXME - insert some real tests, host_os isn't really good enough
+  case $host_os in
+  darwin*)
+    if test -n "$STRIP" ; then
+      striplib="$STRIP -x"
+      old_striplib="$STRIP -S"
+      AC_MSG_RESULT([yes])
+    else
+      AC_MSG_RESULT([no])
+    fi
+    ;;
+  *)
+    AC_MSG_RESULT([no])
+    ;;
+  esac
+fi
+_LT_DECL([], [old_striplib], [1], [Commands to strip libraries])
+_LT_DECL([], [striplib], [1])
+])# _LT_CMD_STRIPLIB
+
+
+# _LT_SYS_DYNAMIC_LINKER([TAG])
+# -----------------------------
+# PORTME Fill in your ld.so characteristics
+m4_defun([_LT_SYS_DYNAMIC_LINKER],
+[AC_REQUIRE([AC_CANONICAL_HOST])dnl
+m4_require([_LT_DECL_EGREP])dnl
+m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+m4_require([_LT_DECL_OBJDUMP])dnl
+m4_require([_LT_DECL_SED])dnl
+AC_MSG_CHECKING([dynamic linker characteristics])
+m4_if([$1],
+       [], [
+if test "$GCC" = yes; then
+  case $host_os in
+    darwin*) lt_awk_arg="/^libraries:/,/LR/" ;;
+    *) lt_awk_arg="/^libraries:/" ;;
+  esac
+  lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e "s,=/,/,g"`
+  if $ECHO "$lt_search_path_spec" | $GREP ';' >/dev/null ; then
+    # if the path contains ";" then we assume it to be the separator
+    # otherwise default to the standard path separator (i.e. ":") - it is
+    # assumed that no part of a normal pathname contains ";" but that should
+    # okay in the real world where ";" in dirpaths is itself problematic.
+    lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED -e 's/;/ /g'`
+  else
+    lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED  -e "s/$PATH_SEPARATOR/ /g"`
+  fi
+  # Ok, now we have the path, separated by spaces, we can step through it
+  # and add multilib dir if necessary.
+  lt_tmp_lt_search_path_spec=
+  lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+  for lt_sys_path in $lt_search_path_spec; do
+    if test -d "$lt_sys_path/$lt_multi_os_dir"; then
+      lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir"
+    else
+      test -d "$lt_sys_path" && \
+       lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path"
+    fi
+  done
+  lt_search_path_spec=`$ECHO $lt_tmp_lt_search_path_spec | awk '
+BEGIN {RS=" "; FS="/|\n";} {
+  lt_foo="";
+  lt_count=0;
+  for (lt_i = NF; lt_i > 0; lt_i--) {
+    if ($lt_i != "" && $lt_i != ".") {
+      if ($lt_i == "..") {
+        lt_count++;
+      } else {
+        if (lt_count == 0) {
+          lt_foo="/" $lt_i lt_foo;
+        } else {
+          lt_count--;
+        }
+      }
+    }
+  }
+  if (lt_foo != "") { lt_freq[[lt_foo]]++; }
+  if (lt_freq[[lt_foo]] == 1) { print lt_foo; }
+}'`
+  sys_lib_search_path_spec=`$ECHO $lt_search_path_spec`
+else
+  sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
+fi])
+library_names_spec=
+libname_spec='lib$name'
+soname_spec=
+shrext_cmds=".so"
+postinstall_cmds=
+postuninstall_cmds=
+finish_cmds=
+finish_eval=
+shlibpath_var=
+shlibpath_overrides_runpath=unknown
+version_type=none
+dynamic_linker="$host_os ld.so"
+sys_lib_dlsearch_path_spec="/lib /usr/lib"
+need_lib_prefix=unknown
+hardcode_into_libs=no
+
+# when you set need_version to no, make sure it does not cause -set_version
+# flags to be left without arguments
+need_version=unknown
+
+case $host_os in
+aix3*)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
+  shlibpath_var=LIBPATH
+
+  # AIX 3 has no versioning support, so we append a major version to the name.
+  soname_spec='${libname}${release}${shared_ext}$major'
+  ;;
+
+aix[[4-9]]*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  hardcode_into_libs=yes
+  if test "$host_cpu" = ia64; then
+    # AIX 5 supports IA64
+    library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
+    shlibpath_var=LD_LIBRARY_PATH
+  else
+    # With GCC up to 2.95.x, collect2 would create an import file
+    # for dependence libraries.  The import file would start with
+    # the line `#! .'.  This would cause the generated library to
+    # depend on `.', always an invalid library.  This was fixed in
+    # development snapshots of GCC prior to 3.0.
+    case $host_os in
+      aix4 | aix4.[[01]] | aix4.[[01]].*)
+      if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)'
+          echo ' yes '
+          echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then
+       :
+      else
+       can_build_shared=no
+      fi
+      ;;
+    esac
+    # AIX (on Power*) has no versioning support, so currently we can not hardcode correct
+    # soname into executable. Probably we can add versioning support to
+    # collect2, so additional links can be useful in future.
+    if test "$aix_use_runtimelinking" = yes; then
+      # If using run time linking (on AIX 4.2 or later) use lib<name>.so
+      # instead of lib<name>.a to let people know that these are not
+      # typical AIX shared libraries.
+      library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    else
+      # We preserve .a as extension for shared libraries through AIX4.2
+      # and later when we are not doing run time linking.
+      library_names_spec='${libname}${release}.a $libname.a'
+      soname_spec='${libname}${release}${shared_ext}$major'
+    fi
+    shlibpath_var=LIBPATH
+  fi
+  ;;
+
+amigaos*)
+  case $host_cpu in
+  powerpc)
+    # Since July 2007 AmigaOS4 officially supports .so libraries.
+    # When compiling the executable, add -use-dynld -Lsobjs: to the compileline.
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    ;;
+  m68k)
+    library_names_spec='$libname.ixlibrary $libname.a'
+    # Create ${libname}_ixlibrary.a entries in /sys/libs.
+    finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$ECHO "X$lib" | $Xsed -e '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
+    ;;
+  esac
+  ;;
+
+beos*)
+  library_names_spec='${libname}${shared_ext}'
+  dynamic_linker="$host_os ld.so"
+  shlibpath_var=LIBRARY_PATH
+  ;;
+
+bsdi[[45]]*)
+  version_type=linux
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib"
+  sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib"
+  # the default ld.so.conf also contains /usr/contrib/lib and
+  # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow
+  # libtool to hard-code these into programs
+  ;;
+
+cygwin* | mingw* | pw32* | cegcc*)
+  version_type=windows
+  shrext_cmds=".dll"
+  need_version=no
+  need_lib_prefix=no
+
+  case $GCC,$host_os in
+  yes,cygwin* | yes,mingw* | yes,pw32* | yes,cegcc*)
+    library_names_spec='$libname.dll.a'
+    # DLL is installed to $(libdir)/../bin by postinstall_cmds
+    postinstall_cmds='base_file=`basename \${file}`~
+      dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+      dldir=$destdir/`dirname \$dlpath`~
+      test -d \$dldir || mkdir -p \$dldir~
+      $install_prog $dir/$dlname \$dldir/$dlname~
+      chmod a+x \$dldir/$dlname~
+      if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then
+        eval '\''$striplib \$dldir/$dlname'\'' || exit \$?;
+      fi'
+    postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~
+      dlpath=$dir/\$dldll~
+       $RM \$dlpath'
+    shlibpath_overrides_runpath=yes
+
+    case $host_os in
+    cygwin*)
+      # Cygwin DLLs use 'cyg' prefix rather than 'lib'
+      soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
+      sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib"
+      ;;
+    mingw* | cegcc*)
+      # MinGW DLLs use traditional 'lib' prefix
+      soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
+      sys_lib_search_path_spec=`$CC -print-search-dirs | $GREP "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"`
+      if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then
+        # It is most probably a Windows format PATH printed by
+        # mingw gcc, but we are running on Cygwin. Gcc prints its search
+        # path with ; separators, and with drive letters. We can handle the
+        # drive letters (cygwin fileutils understands them), so leave them,
+        # especially as we might pass files found there to a mingw objdump,
+        # which wouldn't understand a cygwinified path. Ahh.
+        sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
+      else
+        sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED  -e "s/$PATH_SEPARATOR/ /g"`
+      fi
+      ;;
+    pw32*)
+      # pw32 DLLs use 'pw' prefix rather than 'lib'
+      library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
+      ;;
+    esac
+    ;;
+
+  *)
+    library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib'
+    ;;
+  esac
+  dynamic_linker='Win32 ld.exe'
+  # FIXME: first we should search . and the directory the executable is in
+  shlibpath_var=PATH
+  ;;
+
+darwin* | rhapsody*)
+  dynamic_linker="$host_os dyld"
+  version_type=darwin
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext'
+  soname_spec='${libname}${release}${major}$shared_ext'
+  shlibpath_overrides_runpath=yes
+  shlibpath_var=DYLD_LIBRARY_PATH
+  shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`'
+m4_if([$1], [],[
+  sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"])
+  sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib'
+  ;;
+
+dgux*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  ;;
+
+freebsd1*)
+  dynamic_linker=no
+  ;;
+
+freebsd* | dragonfly*)
+  # DragonFly does not have aout.  When/if they implement a new
+  # versioning mechanism, adjust this.
+  if test -x /usr/bin/objformat; then
+    objformat=`/usr/bin/objformat`
+  else
+    case $host_os in
+    freebsd[[123]]*) objformat=aout ;;
+    *) objformat=elf ;;
+    esac
+  fi
+  version_type=freebsd-$objformat
+  case $version_type in
+    freebsd-elf*)
+      library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+      need_version=no
+      need_lib_prefix=no
+      ;;
+    freebsd-*)
+      library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
+      need_version=yes
+      ;;
+  esac
+  shlibpath_var=LD_LIBRARY_PATH
+  case $host_os in
+  freebsd2*)
+    shlibpath_overrides_runpath=yes
+    ;;
+  freebsd3.[[01]]* | freebsdelf3.[[01]]*)
+    shlibpath_overrides_runpath=yes
+    hardcode_into_libs=yes
+    ;;
+  freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \
+  freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1)
+    shlibpath_overrides_runpath=no
+    hardcode_into_libs=yes
+    ;;
+  *) # from 4.6 on, and DragonFly
+    shlibpath_overrides_runpath=yes
+    hardcode_into_libs=yes
+    ;;
+  esac
+  ;;
+
+gnu*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  hardcode_into_libs=yes
+  ;;
+
+hpux9* | hpux10* | hpux11*)
+  # Give a soname corresponding to the major version so that dld.sl refuses to
+  # link against other versions.
+  version_type=sunos
+  need_lib_prefix=no
+  need_version=no
+  case $host_cpu in
+  ia64*)
+    shrext_cmds='.so'
+    hardcode_into_libs=yes
+    dynamic_linker="$host_os dld.so"
+    shlibpath_var=LD_LIBRARY_PATH
+    shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    if test "X$HPUX_IA64_MODE" = X32; then
+      sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
+    else
+      sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
+    fi
+    sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+    ;;
+  hppa*64*)
+    shrext_cmds='.sl'
+    hardcode_into_libs=yes
+    dynamic_linker="$host_os dld.sl"
+    shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH
+    shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64"
+    sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+    ;;
+  *)
+    shrext_cmds='.sl'
+    dynamic_linker="$host_os dld.sl"
+    shlibpath_var=SHLIB_PATH
+    shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    ;;
+  esac
+  # HP-UX runs *really* slowly unless shared libraries are mode 555.
+  postinstall_cmds='chmod 555 $lib'
+  ;;
+
+interix[[3-9]]*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  hardcode_into_libs=yes
+  ;;
+
+irix5* | irix6* | nonstopux*)
+  case $host_os in
+    nonstopux*) version_type=nonstopux ;;
+    *)
+       if test "$lt_cv_prog_gnu_ld" = yes; then
+               version_type=linux
+       else
+               version_type=irix
+       fi ;;
+  esac
+  need_lib_prefix=no
+  need_version=no
+  soname_spec='${libname}${release}${shared_ext}$major'
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}'
+  case $host_os in
+  irix5* | nonstopux*)
+    libsuff= shlibsuff=
+    ;;
+  *)
+    case $LD in # libtool.m4 will add one of these switches to LD
+    *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ")
+      libsuff= shlibsuff= libmagic=32-bit;;
+    *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ")
+      libsuff=32 shlibsuff=N32 libmagic=N32;;
+    *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ")
+      libsuff=64 shlibsuff=64 libmagic=64-bit;;
+    *) libsuff= shlibsuff= libmagic=never-match;;
+    esac
+    ;;
+  esac
+  shlibpath_var=LD_LIBRARY${shlibsuff}_PATH
+  shlibpath_overrides_runpath=no
+  sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}"
+  sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}"
+  hardcode_into_libs=yes
+  ;;
+
+# No shared lib support for Linux oldld, aout, or coff.
+linux*oldld* | linux*aout* | linux*coff*)
+  dynamic_linker=no
+  ;;
+
+# This must be Linux ELF.
+linux* | k*bsd*-gnu)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  # Some binutils ld are patched to set DT_RUNPATH
+  save_LDFLAGS=$LDFLAGS
+  save_libdir=$libdir
+  eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \
+       LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\""
+  AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])],
+    [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null],
+       [shlibpath_overrides_runpath=yes])])
+  LDFLAGS=$save_LDFLAGS
+  libdir=$save_libdir
+
+  # This implies no fast_install, which is unacceptable.
+  # Some rework will be needed to allow for fast_install
+  # before this can be enabled.
+  hardcode_into_libs=yes
+
+  # Add ABI-specific directories to the system library path.
+  sys_lib_dlsearch_path_spec="/lib64 /usr/lib64 /lib /usr/lib"
+
+  # Append ld.so.conf contents to the search path
+  if test -f /etc/ld.so.conf; then
+    lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[  ]*hwcap[        ]/d;s/[:,      ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '`
+    sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec $lt_ld_extra"
+  fi
+
+  # We used to test for /lib/ld.so.1 and disable shared libraries on
+  # powerpc, because MkLinux only supported shared libraries with the
+  # GNU dynamic linker.  Since this was broken with cross compilers,
+  # most powerpc-linux boxes support dynamic linking these days and
+  # people can always --disable-shared, the test was removed, and we
+  # assume the GNU/Linux dynamic linker is in use.
+  dynamic_linker='GNU/Linux ld.so'
+  ;;
+
+netbsd*)
+  version_type=sunos
+  need_lib_prefix=no
+  need_version=no
+  if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+    finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
+    dynamic_linker='NetBSD (a.out) ld.so'
+  else
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    dynamic_linker='NetBSD ld.elf_so'
+  fi
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  hardcode_into_libs=yes
+  ;;
+
+newsos6)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  ;;
+
+*nto* | *qnx*)
+  version_type=qnx
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  hardcode_into_libs=yes
+  dynamic_linker='ldqnx.so'
+  ;;
+
+openbsd*)
+  version_type=sunos
+  sys_lib_dlsearch_path_spec="/usr/lib"
+  need_lib_prefix=no
+  # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs.
+  case $host_os in
+    openbsd3.3 | openbsd3.3.*) need_version=yes ;;
+    *)                         need_version=no  ;;
+  esac
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+  finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+    case $host_os in
+      openbsd2.[[89]] | openbsd2.[[89]].*)
+       shlibpath_overrides_runpath=no
+       ;;
+      *)
+       shlibpath_overrides_runpath=yes
+       ;;
+      esac
+  else
+    shlibpath_overrides_runpath=yes
+  fi
+  ;;
+
+os2*)
+  libname_spec='$name'
+  shrext_cmds=".dll"
+  need_lib_prefix=no
+  library_names_spec='$libname${shared_ext} $libname.a'
+  dynamic_linker='OS/2 ld.exe'
+  shlibpath_var=LIBPATH
+  ;;
+
+osf3* | osf4* | osf5*)
+  version_type=osf
+  need_lib_prefix=no
+  need_version=no
+  soname_spec='${libname}${release}${shared_ext}$major'
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  shlibpath_var=LD_LIBRARY_PATH
+  sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib"
+  sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec"
+  ;;
+
+rdos*)
+  dynamic_linker=no
+  ;;
+
+solaris*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  hardcode_into_libs=yes
+  # ldd complains unless libraries are executable
+  postinstall_cmds='chmod +x $lib'
+  ;;
+
+sunos4*)
+  version_type=sunos
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+  finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  if test "$with_gnu_ld" = yes; then
+    need_lib_prefix=no
+  fi
+  need_version=yes
+  ;;
+
+sysv4 | sysv4.3*)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  case $host_vendor in
+    sni)
+      shlibpath_overrides_runpath=no
+      need_lib_prefix=no
+      runpath_var=LD_RUN_PATH
+      ;;
+    siemens)
+      need_lib_prefix=no
+      ;;
+    motorola)
+      need_lib_prefix=no
+      need_version=no
+      shlibpath_overrides_runpath=no
+      sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib'
+      ;;
+  esac
+  ;;
+
+sysv4*MP*)
+  if test -d /usr/nec ;then
+    version_type=linux
+    library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
+    soname_spec='$libname${shared_ext}.$major'
+    shlibpath_var=LD_LIBRARY_PATH
+  fi
+  ;;
+
+sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
+  version_type=freebsd-elf
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  hardcode_into_libs=yes
+  if test "$with_gnu_ld" = yes; then
+    sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib'
+  else
+    sys_lib_search_path_spec='/usr/ccs/lib /usr/lib'
+    case $host_os in
+      sco3.2v5*)
+        sys_lib_search_path_spec="$sys_lib_search_path_spec /lib"
+       ;;
+    esac
+  fi
+  sys_lib_dlsearch_path_spec='/usr/lib'
+  ;;
+
+tpf*)
+  # TPF is a cross-target only.  Preferred cross-host = GNU/Linux.
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  hardcode_into_libs=yes
+  ;;
+
+uts4*)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  ;;
+
+*)
+  dynamic_linker=no
+  ;;
+esac
+AC_MSG_RESULT([$dynamic_linker])
+test "$dynamic_linker" = no && can_build_shared=no
+
+variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
+if test "$GCC" = yes; then
+  variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
+fi
+
+if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then
+  sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec"
+fi
+if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then
+  sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec"
+fi
+
+_LT_DECL([], [variables_saved_for_relink], [1],
+    [Variables whose values should be saved in libtool wrapper scripts and
+    restored at link time])
+_LT_DECL([], [need_lib_prefix], [0],
+    [Do we need the "lib" prefix for modules?])
+_LT_DECL([], [need_version], [0], [Do we need a version for libraries?])
+_LT_DECL([], [version_type], [0], [Library versioning type])
+_LT_DECL([], [runpath_var], [0],  [Shared library runtime path variable])
+_LT_DECL([], [shlibpath_var], [0],[Shared library path variable])
+_LT_DECL([], [shlibpath_overrides_runpath], [0],
+    [Is shlibpath searched before the hard-coded library search path?])
+_LT_DECL([], [libname_spec], [1], [Format of library name prefix])
+_LT_DECL([], [library_names_spec], [1],
+    [[List of archive names.  First name is the real one, the rest are links.
+    The last name is the one that the linker finds with -lNAME]])
+_LT_DECL([], [soname_spec], [1],
+    [[The coded name of the library, if different from the real name]])
+_LT_DECL([], [postinstall_cmds], [2],
+    [Command to use after installation of a shared archive])
+_LT_DECL([], [postuninstall_cmds], [2],
+    [Command to use after uninstallation of a shared archive])
+_LT_DECL([], [finish_cmds], [2],
+    [Commands used to finish a libtool library installation in a directory])
+_LT_DECL([], [finish_eval], [1],
+    [[As "finish_cmds", except a single script fragment to be evaled but
+    not shown]])
+_LT_DECL([], [hardcode_into_libs], [0],
+    [Whether we should hardcode library paths into libraries])
+_LT_DECL([], [sys_lib_search_path_spec], [2],
+    [Compile-time system search path for libraries])
+_LT_DECL([], [sys_lib_dlsearch_path_spec], [2],
+    [Run-time system search path for libraries])
+])# _LT_SYS_DYNAMIC_LINKER
+
+
+# _LT_PATH_TOOL_PREFIX(TOOL)
+# --------------------------
+# find a file program which can recognize shared library
+AC_DEFUN([_LT_PATH_TOOL_PREFIX],
+[m4_require([_LT_DECL_EGREP])dnl
+AC_MSG_CHECKING([for $1])
+AC_CACHE_VAL(lt_cv_path_MAGIC_CMD,
+[case $MAGIC_CMD in
+[[\\/*] |  ?:[\\/]*])
+  lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+  ;;
+*)
+  lt_save_MAGIC_CMD="$MAGIC_CMD"
+  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+dnl $ac_dummy forces splitting on constant user-supplied paths.
+dnl POSIX.2 word splitting is done only on the output of word expansions,
+dnl not every word.  This closes a longstanding sh security hole.
+  ac_dummy="m4_if([$2], , $PATH, [$2])"
+  for ac_dir in $ac_dummy; do
+    IFS="$lt_save_ifs"
+    test -z "$ac_dir" && ac_dir=.
+    if test -f $ac_dir/$1; then
+      lt_cv_path_MAGIC_CMD="$ac_dir/$1"
+      if test -n "$file_magic_test_file"; then
+       case $deplibs_check_method in
+       "file_magic "*)
+         file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"`
+         MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+         if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null |
+           $EGREP "$file_magic_regex" > /dev/null; then
+           :
+         else
+           cat <<_LT_EOF 1>&2
+
+*** Warning: the command libtool uses to detect shared libraries,
+*** $file_magic_cmd, produces output that libtool cannot recognize.
+*** The result is that libtool may fail to recognize shared libraries
+*** as such.  This will affect the creation of libtool libraries that
+*** depend on shared libraries, but programs linked with such libtool
+*** libraries will work regardless of this problem.  Nevertheless, you
+*** may want to report the problem to your system manager and/or to
+*** bug-libtool@gnu.org
+
+_LT_EOF
+         fi ;;
+       esac
+      fi
+      break
+    fi
+  done
+  IFS="$lt_save_ifs"
+  MAGIC_CMD="$lt_save_MAGIC_CMD"
+  ;;
+esac])
+MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+if test -n "$MAGIC_CMD"; then
+  AC_MSG_RESULT($MAGIC_CMD)
+else
+  AC_MSG_RESULT(no)
+fi
+_LT_DECL([], [MAGIC_CMD], [0],
+        [Used to examine libraries when file_magic_cmd begins with "file"])dnl
+])# _LT_PATH_TOOL_PREFIX
+
+# Old name:
+AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], [])
+
+
+# _LT_PATH_MAGIC
+# --------------
+# find a file program which can recognize a shared library
+m4_defun([_LT_PATH_MAGIC],
+[_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH)
+if test -z "$lt_cv_path_MAGIC_CMD"; then
+  if test -n "$ac_tool_prefix"; then
+    _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH)
+  else
+    MAGIC_CMD=:
+  fi
+fi
+])# _LT_PATH_MAGIC
+
+
+# LT_PATH_LD
+# ----------
+# find the pathname to the GNU or non-GNU linker
+AC_DEFUN([LT_PATH_LD],
+[AC_REQUIRE([AC_PROG_CC])dnl
+AC_REQUIRE([AC_CANONICAL_HOST])dnl
+AC_REQUIRE([AC_CANONICAL_BUILD])dnl
+m4_require([_LT_DECL_SED])dnl
+m4_require([_LT_DECL_EGREP])dnl
+
+AC_ARG_WITH([gnu-ld],
+    [AS_HELP_STRING([--with-gnu-ld],
+       [assume the C compiler uses GNU ld @<:@default=no@:>@])],
+    [test "$withval" = no || with_gnu_ld=yes],
+    [with_gnu_ld=no])dnl
+
+ac_prog=ld
+if test "$GCC" = yes; then
+  # Check if gcc -print-prog-name=ld gives a path.
+  AC_MSG_CHECKING([for ld used by $CC])
+  case $host in
+  *-*-mingw*)
+    # gcc leaves a trailing carriage return which upsets mingw
+    ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
+  *)
+    ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
+  esac
+  case $ac_prog in
+    # Accept absolute paths.
+    [[\\/]]* | ?:[[\\/]]*)
+      re_direlt='/[[^/]][[^/]]*/\.\./'
+      # Canonicalize the pathname of ld
+      ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'`
+      while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do
+       ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"`
+      done
+      test -z "$LD" && LD="$ac_prog"
+      ;;
+  "")
+    # If it fails, then pretend we aren't using GCC.
+    ac_prog=ld
+    ;;
+  *)
+    # If it is relative, then search for the first ld in PATH.
+    with_gnu_ld=unknown
+    ;;
+  esac
+elif test "$with_gnu_ld" = yes; then
+  AC_MSG_CHECKING([for GNU ld])
+else
+  AC_MSG_CHECKING([for non-GNU ld])
+fi
+AC_CACHE_VAL(lt_cv_path_LD,
+[if test -z "$LD"; then
+  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+  for ac_dir in $PATH; do
+    IFS="$lt_save_ifs"
+    test -z "$ac_dir" && ac_dir=.
+    if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
+      lt_cv_path_LD="$ac_dir/$ac_prog"
+      # Check to see if the program is GNU ld.  I'd rather use --version,
+      # but apparently some variants of GNU ld only accept -v.
+      # Break only if it was the GNU/non-GNU ld that we prefer.
+      case `"$lt_cv_path_LD" -v 2>&1 </dev/null` in
+      *GNU* | *'with BFD'*)
+       test "$with_gnu_ld" != no && break
+       ;;
+      *)
+       test "$with_gnu_ld" != yes && break
+       ;;
+      esac
+    fi
+  done
+  IFS="$lt_save_ifs"
+else
+  lt_cv_path_LD="$LD" # Let the user override the test with a path.
+fi])
+LD="$lt_cv_path_LD"
+if test -n "$LD"; then
+  AC_MSG_RESULT($LD)
+else
+  AC_MSG_RESULT(no)
+fi
+test -z "$LD" && AC_MSG_ERROR([no acceptable ld found in \$PATH])
+_LT_PATH_LD_GNU
+AC_SUBST([LD])
+
+_LT_TAGDECL([], [LD], [1], [The linker used to build libraries])
+])# LT_PATH_LD
+
+# Old names:
+AU_ALIAS([AM_PROG_LD], [LT_PATH_LD])
+AU_ALIAS([AC_PROG_LD], [LT_PATH_LD])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AM_PROG_LD], [])
+dnl AC_DEFUN([AC_PROG_LD], [])
+
+
+# _LT_PATH_LD_GNU
+#- --------------
+m4_defun([_LT_PATH_LD_GNU],
+[AC_CACHE_CHECK([if the linker ($LD) is GNU ld], lt_cv_prog_gnu_ld,
+[# I'd rather use --version here, but apparently some GNU lds only accept -v.
+case `$LD -v 2>&1 </dev/null` in
+*GNU* | *'with BFD'*)
+  lt_cv_prog_gnu_ld=yes
+  ;;
+*)
+  lt_cv_prog_gnu_ld=no
+  ;;
+esac])
+with_gnu_ld=$lt_cv_prog_gnu_ld
+])# _LT_PATH_LD_GNU
+
+
+# _LT_CMD_RELOAD
+# --------------
+# find reload flag for linker
+#   -- PORTME Some linkers may need a different reload flag.
+m4_defun([_LT_CMD_RELOAD],
+[AC_CACHE_CHECK([for $LD option to reload object files],
+  lt_cv_ld_reload_flag,
+  [lt_cv_ld_reload_flag='-r'])
+reload_flag=$lt_cv_ld_reload_flag
+case $reload_flag in
+"" | " "*) ;;
+*) reload_flag=" $reload_flag" ;;
+esac
+reload_cmds='$LD$reload_flag -o $output$reload_objs'
+case $host_os in
+  darwin*)
+    if test "$GCC" = yes; then
+      reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs'
+    else
+      reload_cmds='$LD$reload_flag -o $output$reload_objs'
+    fi
+    ;;
+esac
+_LT_DECL([], [reload_flag], [1], [How to create reloadable object files])dnl
+_LT_DECL([], [reload_cmds], [2])dnl
+])# _LT_CMD_RELOAD
+
+
+# _LT_CHECK_MAGIC_METHOD
+# ----------------------
+# how to check for library dependencies
+#  -- PORTME fill in with the dynamic library characteristics
+m4_defun([_LT_CHECK_MAGIC_METHOD],
+[m4_require([_LT_DECL_EGREP])
+m4_require([_LT_DECL_OBJDUMP])
+AC_CACHE_CHECK([how to recognize dependent libraries],
+lt_cv_deplibs_check_method,
+[lt_cv_file_magic_cmd='$MAGIC_CMD'
+lt_cv_file_magic_test_file=
+lt_cv_deplibs_check_method='unknown'
+# Need to set the preceding variable on all platforms that support
+# interlibrary dependencies.
+# 'none' -- dependencies not supported.
+# `unknown' -- same as none, but documents that we really don't know.
+# 'pass_all' -- all dependencies passed with no checks.
+# 'test_compile' -- check by making test program.
+# 'file_magic [[regex]]' -- check by looking for files in library path
+# which responds to the $file_magic_cmd with a given extended regex.
+# If you have `file' or equivalent on your system and you're not sure
+# whether `pass_all' will *always* work, you probably want this one.
+
+case $host_os in
+aix[[4-9]]*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+beos*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+bsdi[[45]]*)
+  lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib)'
+  lt_cv_file_magic_cmd='/usr/bin/file -L'
+  lt_cv_file_magic_test_file=/shlib/libc.so
+  ;;
+
+cygwin*)
+  # func_win32_libid is a shell function defined in ltmain.sh
+  lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
+  lt_cv_file_magic_cmd='func_win32_libid'
+  ;;
+
+mingw* | pw32*)
+  # Base MSYS/MinGW do not provide the 'file' command needed by
+  # func_win32_libid shell function, so use a weaker test based on 'objdump',
+  # unless we find 'file', for example because we are cross-compiling.
+  if ( file / ) >/dev/null 2>&1; then
+    lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
+    lt_cv_file_magic_cmd='func_win32_libid'
+  else
+    lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?'
+    lt_cv_file_magic_cmd='$OBJDUMP -f'
+  fi
+  ;;
+
+cegcc)
+  # use the weaker test based on 'objdump'. See mingw*.
+  lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?'
+  lt_cv_file_magic_cmd='$OBJDUMP -f'
+  ;;
+
+darwin* | rhapsody*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+freebsd* | dragonfly*)
+  if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then
+    case $host_cpu in
+    i*86 )
+      # Not sure whether the presence of OpenBSD here was a mistake.
+      # Let's accept both of them until this is cleared up.
+      lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library'
+      lt_cv_file_magic_cmd=/usr/bin/file
+      lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*`
+      ;;
+    esac
+  else
+    lt_cv_deplibs_check_method=pass_all
+  fi
+  ;;
+
+gnu*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+hpux10.20* | hpux11*)
+  lt_cv_file_magic_cmd=/usr/bin/file
+  case $host_cpu in
+  ia64*)
+    lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64'
+    lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so
+    ;;
+  hppa*64*)
+    [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]']
+    lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl
+    ;;
+  *)
+    lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]].[[0-9]]) shared library'
+    lt_cv_file_magic_test_file=/usr/lib/libc.sl
+    ;;
+  esac
+  ;;
+
+interix[[3-9]]*)
+  # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here
+  lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$'
+  ;;
+
+irix5* | irix6* | nonstopux*)
+  case $LD in
+  *-32|*"-32 ") libmagic=32-bit;;
+  *-n32|*"-n32 ") libmagic=N32;;
+  *-64|*"-64 ") libmagic=64-bit;;
+  *) libmagic=never-match;;
+  esac
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+# This must be Linux ELF.
+linux* | k*bsd*-gnu)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+netbsd*)
+  if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then
+    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$'
+  else
+    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$'
+  fi
+  ;;
+
+newos6*)
+  lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)'
+  lt_cv_file_magic_cmd=/usr/bin/file
+  lt_cv_file_magic_test_file=/usr/lib/libnls.so
+  ;;
+
+*nto* | *qnx*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+openbsd*)
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$'
+  else
+    lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$'
+  fi
+  ;;
+
+osf3* | osf4* | osf5*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+rdos*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+solaris*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+sysv4 | sysv4.3*)
+  case $host_vendor in
+  motorola)
+    lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]'
+    lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*`
+    ;;
+  ncr)
+    lt_cv_deplibs_check_method=pass_all
+    ;;
+  sequent)
+    lt_cv_file_magic_cmd='/bin/file'
+    lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )'
+    ;;
+  sni)
+    lt_cv_file_magic_cmd='/bin/file'
+    lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib"
+    lt_cv_file_magic_test_file=/lib/libc.so
+    ;;
+  siemens)
+    lt_cv_deplibs_check_method=pass_all
+    ;;
+  pc)
+    lt_cv_deplibs_check_method=pass_all
+    ;;
+  esac
+  ;;
+
+tpf*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+esac
+])
+file_magic_cmd=$lt_cv_file_magic_cmd
+deplibs_check_method=$lt_cv_deplibs_check_method
+test -z "$deplibs_check_method" && deplibs_check_method=unknown
+
+_LT_DECL([], [deplibs_check_method], [1],
+    [Method to check whether dependent libraries are shared objects])
+_LT_DECL([], [file_magic_cmd], [1],
+    [Command to use when deplibs_check_method == "file_magic"])
+])# _LT_CHECK_MAGIC_METHOD
+
+
+# LT_PATH_NM
+# ----------
+# find the pathname to a BSD- or MS-compatible name lister
+AC_DEFUN([LT_PATH_NM],
+[AC_REQUIRE([AC_PROG_CC])dnl
+AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM,
+[if test -n "$NM"; then
+  # Let the user override the test.
+  lt_cv_path_NM="$NM"
+else
+  lt_nm_to_check="${ac_tool_prefix}nm"
+  if test -n "$ac_tool_prefix" && test "$build" = "$host"; then
+    lt_nm_to_check="$lt_nm_to_check nm"
+  fi
+  for lt_tmp_nm in $lt_nm_to_check; do
+    lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+    for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do
+      IFS="$lt_save_ifs"
+      test -z "$ac_dir" && ac_dir=.
+      tmp_nm="$ac_dir/$lt_tmp_nm"
+      if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then
+       # Check to see if the nm accepts a BSD-compat flag.
+       # Adding the `sed 1q' prevents false positives on HP-UX, which says:
+       #   nm: unknown option "B" ignored
+       # Tru64's nm complains that /dev/null is an invalid object file
+       case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in
+       */dev/null* | *'Invalid file or object type'*)
+         lt_cv_path_NM="$tmp_nm -B"
+         break
+         ;;
+       *)
+         case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in
+         */dev/null*)
+           lt_cv_path_NM="$tmp_nm -p"
+           break
+           ;;
+         *)
+           lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but
+           continue # so that we can try to find one that supports BSD flags
+           ;;
+         esac
+         ;;
+       esac
+      fi
+    done
+    IFS="$lt_save_ifs"
+  done
+  : ${lt_cv_path_NM=no}
+fi])
+if test "$lt_cv_path_NM" != "no"; then
+  NM="$lt_cv_path_NM"
+else
+  # Didn't find any BSD compatible name lister, look for dumpbin.
+  AC_CHECK_TOOLS(DUMPBIN, ["dumpbin -symbols" "link -dump -symbols"], :)
+  AC_SUBST([DUMPBIN])
+  if test "$DUMPBIN" != ":"; then
+    NM="$DUMPBIN"
+  fi
+fi
+test -z "$NM" && NM=nm
+AC_SUBST([NM])
+_LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl
+
+AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface],
+  [lt_cv_nm_interface="BSD nm"
+  echo "int some_variable = 0;" > conftest.$ac_ext
+  (eval echo "\"\$as_me:__oline__: $ac_compile\"" >&AS_MESSAGE_LOG_FD)
+  (eval "$ac_compile" 2>conftest.err)
+  cat conftest.err >&AS_MESSAGE_LOG_FD
+  (eval echo "\"\$as_me:__oline__: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD)
+  (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out)
+  cat conftest.err >&AS_MESSAGE_LOG_FD
+  (eval echo "\"\$as_me:__oline__: output\"" >&AS_MESSAGE_LOG_FD)
+  cat conftest.out >&AS_MESSAGE_LOG_FD
+  if $GREP 'External.*some_variable' conftest.out > /dev/null; then
+    lt_cv_nm_interface="MS dumpbin"
+  fi
+  rm -f conftest*])
+])# LT_PATH_NM
+
+# Old names:
+AU_ALIAS([AM_PROG_NM], [LT_PATH_NM])
+AU_ALIAS([AC_PROG_NM], [LT_PATH_NM])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AM_PROG_NM], [])
+dnl AC_DEFUN([AC_PROG_NM], [])
+
+
+# LT_LIB_M
+# --------
+# check for math library
+AC_DEFUN([LT_LIB_M],
+[AC_REQUIRE([AC_CANONICAL_HOST])dnl
+LIBM=
+case $host in
+*-*-beos* | *-*-cygwin* | *-*-pw32* | *-*-darwin*)
+  # These system don't have libm, or don't need it
+  ;;
+*-ncr-sysv4.3*)
+  AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw")
+  AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm")
+  ;;
+*)
+  AC_CHECK_LIB(m, cos, LIBM="-lm")
+  ;;
+esac
+AC_SUBST([LIBM])
+])# LT_LIB_M
+
+# Old name:
+AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_CHECK_LIBM], [])
+
+
+# _LT_COMPILER_NO_RTTI([TAGNAME])
+# -------------------------------
+m4_defun([_LT_COMPILER_NO_RTTI],
+[m4_require([_LT_TAG_COMPILER])dnl
+
+_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
+
+if test "$GCC" = yes; then
+  _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin'
+
+  _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions],
+    lt_cv_prog_compiler_rtti_exceptions,
+    [-fno-rtti -fno-exceptions], [],
+    [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"])
+fi
+_LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1],
+       [Compiler flag to turn off builtin functions])
+])# _LT_COMPILER_NO_RTTI
+
+
+# _LT_CMD_GLOBAL_SYMBOLS
+# ----------------------
+m4_defun([_LT_CMD_GLOBAL_SYMBOLS],
+[AC_REQUIRE([AC_CANONICAL_HOST])dnl
+AC_REQUIRE([AC_PROG_CC])dnl
+AC_REQUIRE([LT_PATH_NM])dnl
+AC_REQUIRE([LT_PATH_LD])dnl
+m4_require([_LT_DECL_SED])dnl
+m4_require([_LT_DECL_EGREP])dnl
+m4_require([_LT_TAG_COMPILER])dnl
+
+# Check for command to grab the raw symbol name followed by C symbol from nm.
+AC_MSG_CHECKING([command to parse $NM output from $compiler object])
+AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe],
+[
+# These are sane defaults that work on at least a few old systems.
+# [They come from Ultrix.  What could be older than Ultrix?!! ;)]
+
+# Character class describing NM global symbol codes.
+symcode='[[BCDEGRST]]'
+
+# Regexp to match symbols that can be accessed directly from C.
+sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)'
+
+# Define system-specific variables.
+case $host_os in
+aix*)
+  symcode='[[BCDT]]'
+  ;;
+cygwin* | mingw* | pw32* | cegcc*)
+  symcode='[[ABCDGISTW]]'
+  ;;
+hpux*)
+  if test "$host_cpu" = ia64; then
+    symcode='[[ABCDEGRST]]'
+  fi
+  ;;
+irix* | nonstopux*)
+  symcode='[[BCDEGRST]]'
+  ;;
+osf*)
+  symcode='[[BCDEGQRST]]'
+  ;;
+solaris*)
+  symcode='[[BDRT]]'
+  ;;
+sco3.2v5*)
+  symcode='[[DT]]'
+  ;;
+sysv4.2uw2*)
+  symcode='[[DT]]'
+  ;;
+sysv5* | sco5v6* | unixware* | OpenUNIX*)
+  symcode='[[ABDT]]'
+  ;;
+sysv4)
+  symcode='[[DFNSTU]]'
+  ;;
+esac
+
+# If we're using GNU nm, then use its standard symbol codes.
+case `$NM -V 2>&1` in
+*GNU* | *'with BFD'*)
+  symcode='[[ABCDGIRSTW]]' ;;
+esac
+
+# Transform an extracted symbol line into a proper C declaration.
+# Some systems (esp. on ia64) link data and code symbols differently,
+# so use this general approach.
+lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'"
+
+# Transform an extracted symbol line into symbol name and symbol address
+lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/  {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/  {\"\2\", (void *) \&\2},/p'"
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([[^ ]]*\) $/  {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \(lib[[^ ]]*\)$/  {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/  {\"lib\2\", (void *) \&\2},/p'"
+
+# Handle CRLF in mingw tool chain
+opt_cr=
+case $build_os in
+mingw*)
+  opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp
+  ;;
+esac
+
+# Try without a prefix underscore, then with it.
+for ac_symprfx in "" "_"; do
+
+  # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol.
+  symxfrm="\\1 $ac_symprfx\\2 \\2"
+
+  # Write the raw and C identifiers.
+  if test "$lt_cv_nm_interface" = "MS dumpbin"; then
+    # Fake it for dumpbin and say T for any non-static function
+    # and D for any global variable.
+    # Also find C++ and __fastcall symbols from MSVC++,
+    # which start with @ or ?.
+    lt_cv_sys_global_symbol_pipe="$AWK ['"\
+"     {last_section=section; section=\$ 3};"\
+"     /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\
+"     \$ 0!~/External *\|/{next};"\
+"     / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\
+"     {if(hide[section]) next};"\
+"     {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\
+"     {split(\$ 0, a, /\||\r/); split(a[2], s)};"\
+"     s[1]~/^[@?]/{print s[1], s[1]; next};"\
+"     s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\
+"     ' prfx=^$ac_symprfx]"
+  else
+    lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[    ]]\($symcode$symcode*\)[[       ]][[    ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'"
+  fi
+
+  # Check to see that the pipe works correctly.
+  pipe_works=no
+
+  rm -f conftest*
+  cat > conftest.$ac_ext <<_LT_EOF
+#ifdef __cplusplus
+extern "C" {
+#endif
+char nm_test_var;
+void nm_test_func(void);
+void nm_test_func(void){}
+#ifdef __cplusplus
+}
+#endif
+int main(){nm_test_var='a';nm_test_func();return(0);}
+_LT_EOF
+
+  if AC_TRY_EVAL(ac_compile); then
+    # Now try to grab the symbols.
+    nlist=conftest.nm
+    if AC_TRY_EVAL(NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist) && test -s "$nlist"; then
+      # Try sorting and uniquifying the output.
+      if sort "$nlist" | uniq > "$nlist"T; then
+       mv -f "$nlist"T "$nlist"
+      else
+       rm -f "$nlist"T
+      fi
+
+      # Make sure that we snagged all the symbols we need.
+      if $GREP ' nm_test_var$' "$nlist" >/dev/null; then
+       if $GREP ' nm_test_func$' "$nlist" >/dev/null; then
+         cat <<_LT_EOF > conftest.$ac_ext
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+_LT_EOF
+         # Now generate the symbol file.
+         eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext'
+
+         cat <<_LT_EOF >> conftest.$ac_ext
+
+/* The mapping between symbol names and symbols.  */
+const struct {
+  const char *name;
+  void       *address;
+}
+lt__PROGRAM__LTX_preloaded_symbols[[]] =
+{
+  { "@PROGRAM@", (void *) 0 },
+_LT_EOF
+         $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/  {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
+         cat <<\_LT_EOF >> conftest.$ac_ext
+  {0, (void *) 0}
+};
+
+/* This works around a problem in FreeBSD linker */
+#ifdef FREEBSD_WORKAROUND
+static const void *lt_preloaded_setup() {
+  return lt__PROGRAM__LTX_preloaded_symbols;
+}
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+_LT_EOF
+         # Now try linking the two files.
+         mv conftest.$ac_objext conftstm.$ac_objext
+         lt_save_LIBS="$LIBS"
+         lt_save_CFLAGS="$CFLAGS"
+         LIBS="conftstm.$ac_objext"
+         CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)"
+         if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then
+           pipe_works=yes
+         fi
+         LIBS="$lt_save_LIBS"
+         CFLAGS="$lt_save_CFLAGS"
+       else
+         echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD
+       fi
+      else
+       echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD
+      fi
+    else
+      echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD
+    fi
+  else
+    echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD
+    cat conftest.$ac_ext >&5
+  fi
+  rm -rf conftest* conftst*
+
+  # Do not use the global_symbol_pipe unless it works.
+  if test "$pipe_works" = yes; then
+    break
+  else
+    lt_cv_sys_global_symbol_pipe=
+  fi
+done
+])
+if test -z "$lt_cv_sys_global_symbol_pipe"; then
+  lt_cv_sys_global_symbol_to_cdecl=
+fi
+if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then
+  AC_MSG_RESULT(failed)
+else
+  AC_MSG_RESULT(ok)
+fi
+
+_LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1],
+    [Take the output of nm and produce a listing of raw symbols and C names])
+_LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1],
+    [Transform the output of nm in a proper C declaration])
+_LT_DECL([global_symbol_to_c_name_address],
+    [lt_cv_sys_global_symbol_to_c_name_address], [1],
+    [Transform the output of nm in a C name address pair])
+_LT_DECL([global_symbol_to_c_name_address_lib_prefix],
+    [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1],
+    [Transform the output of nm in a C name address pair when lib prefix is needed])
+]) # _LT_CMD_GLOBAL_SYMBOLS
+
+
+# _LT_COMPILER_PIC([TAGNAME])
+# ---------------------------
+m4_defun([_LT_COMPILER_PIC],
+[m4_require([_LT_TAG_COMPILER])dnl
+_LT_TAGVAR(lt_prog_compiler_wl, $1)=
+_LT_TAGVAR(lt_prog_compiler_pic, $1)=
+_LT_TAGVAR(lt_prog_compiler_static, $1)=
+
+AC_MSG_CHECKING([for $compiler option to produce PIC])
+m4_if([$1], [CXX], [
+  # C++ specific cases for pic, static, wl, etc.
+  if test "$GXX" = yes; then
+    _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+    _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+
+    case $host_os in
+    aix*)
+      # All AIX code is PIC.
+      if test "$host_cpu" = ia64; then
+       # AIX 5 now supports IA64 processor
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      fi
+      ;;
+
+    amigaos*)
+      case $host_cpu in
+      powerpc)
+            # see comment about AmigaOS4 .so support
+            _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+        ;;
+      m68k)
+            # FIXME: we need at least 68020 code to build shared libraries, but
+            # adding the `-m68020' flag to GCC prevents building anything better,
+            # like `-m68040'.
+            _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
+        ;;
+      esac
+      ;;
+
+    beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*)
+      # PIC is the default for these OSes.
+      ;;
+    mingw* | cygwin* | os2* | pw32* | cegcc*)
+      # This hack is so that the source file can tell whether it is being
+      # built for inclusion in a dll (and should export symbols for example).
+      # Although the cygwin gcc ignores -fPIC, still need this for old-style
+      # (--disable-auto-import) libraries
+      m4_if([$1], [GCJ], [],
+       [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+      ;;
+    darwin* | rhapsody*)
+      # PIC is the default on this platform
+      # Common symbols not allowed in MH_DYLIB files
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common'
+      ;;
+    *djgpp*)
+      # DJGPP does not support shared libraries at all
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)=
+      ;;
+    interix[[3-9]]*)
+      # Interix 3.x gcc -fpic/-fPIC options generate broken code.
+      # Instead, we relocate shared libraries at runtime.
+      ;;
+    sysv4*MP*)
+      if test -d /usr/nec; then
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic
+      fi
+      ;;
+    hpux*)
+      # PIC is the default for 64-bit PA HP-UX, but not for 32-bit
+      # PA HP-UX.  On IA64 HP-UX, PIC is the default but the pic flag
+      # sets the default TLS model and affects inlining.
+      case $host_cpu in
+      hppa*64*)
+       ;;
+      *)
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+       ;;
+      esac
+      ;;
+    *qnx* | *nto*)
+      # QNX uses GNU C++, but need to define -shared option too, otherwise
+      # it will coredump.
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared'
+      ;;
+    *)
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+      ;;
+    esac
+  else
+    case $host_os in
+      aix[[4-9]]*)
+       # All AIX code is PIC.
+       if test "$host_cpu" = ia64; then
+         # AIX 5 now supports IA64 processor
+         _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+       else
+         _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp'
+       fi
+       ;;
+      chorus*)
+       case $cc_basename in
+       cxch68*)
+         # Green Hills C++ Compiler
+         # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a"
+         ;;
+       esac
+       ;;
+      dgux*)
+       case $cc_basename in
+         ec++*)
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+           ;;
+         ghcx*)
+           # Green Hills C++ Compiler
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      freebsd* | dragonfly*)
+       # FreeBSD uses GNU C++
+       ;;
+      hpux9* | hpux10* | hpux11*)
+       case $cc_basename in
+         CC*)
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
+           if test "$host_cpu" != ia64; then
+             _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
+           fi
+           ;;
+         aCC*)
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
+           case $host_cpu in
+           hppa*64*|ia64*)
+             # +Z the default
+             ;;
+           *)
+             _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
+             ;;
+           esac
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      interix*)
+       # This is c89, which is MS Visual C++ (no shared libs)
+       # Anyone wants to do a port?
+       ;;
+      irix5* | irix6* | nonstopux*)
+       case $cc_basename in
+         CC*)
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
+           # CC pic flag -KPIC is the default.
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      linux* | k*bsd*-gnu)
+       case $cc_basename in
+         KCC*)
+           # KAI C++ Compiler
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,'
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+           ;;
+         ecpc* )
+           # old Intel C++ for x86_64 which still supported -KPIC.
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+           ;;
+         icpc* )
+           # Intel C++, used to be incompatible with GCC.
+           # ICC 10 doesn't accept -KPIC any more.
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+           ;;
+         pgCC* | pgcpp*)
+           # Portland Group C++ compiler
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+           ;;
+         cxx*)
+           # Compaq C++
+           # Make sure the PIC flag is empty.  It appears that all Alpha
+           # Linux and Compaq Tru64 Unix objects are PIC.
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)=
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
+           ;;
+         xlc* | xlC*)
+           # IBM XL 8.0 on PPC
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink'
+           ;;
+         *)
+           case `$CC -V 2>&1 | sed 5q` in
+           *Sun\ C*)
+             # Sun C++ 5.9
+             _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+             _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+             _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld '
+             ;;
+           esac
+           ;;
+       esac
+       ;;
+      lynxos*)
+       ;;
+      m88k*)
+       ;;
+      mvs*)
+       case $cc_basename in
+         cxx*)
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall'
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      netbsd*)
+       ;;
+      *qnx* | *nto*)
+        # QNX uses GNU C++, but need to define -shared option too, otherwise
+        # it will coredump.
+        _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared'
+        ;;
+      osf3* | osf4* | osf5*)
+       case $cc_basename in
+         KCC*)
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,'
+           ;;
+         RCC*)
+           # Rational C++ 2.4.1
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
+           ;;
+         cxx*)
+           # Digital/Compaq C++
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           # Make sure the PIC flag is empty.  It appears that all Alpha
+           # Linux and Compaq Tru64 Unix objects are PIC.
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)=
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      psos*)
+       ;;
+      solaris*)
+       case $cc_basename in
+         CC*)
+           # Sun C++ 4.2, 5.x and Centerline C++
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld '
+           ;;
+         gcx*)
+           # Green Hills C++ Compiler
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      sunos4*)
+       case $cc_basename in
+         CC*)
+           # Sun C++ 4.x
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+           ;;
+         lcc*)
+           # Lucid
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*)
+       case $cc_basename in
+         CC*)
+           _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+           _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+           ;;
+       esac
+       ;;
+      tandem*)
+       case $cc_basename in
+         NCC*)
+           # NonStop-UX NCC 3.20
+           _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+           ;;
+         *)
+           ;;
+       esac
+       ;;
+      vxworks*)
+       ;;
+      *)
+       _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
+       ;;
+    esac
+  fi
+],
+[
+  if test "$GCC" = yes; then
+    _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+    _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+
+    case $host_os in
+      aix*)
+      # All AIX code is PIC.
+      if test "$host_cpu" = ia64; then
+       # AIX 5 now supports IA64 processor
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      fi
+      ;;
+
+    amigaos*)
+      case $host_cpu in
+      powerpc)
+            # see comment about AmigaOS4 .so support
+            _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+        ;;
+      m68k)
+            # FIXME: we need at least 68020 code to build shared libraries, but
+            # adding the `-m68020' flag to GCC prevents building anything better,
+            # like `-m68040'.
+            _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
+        ;;
+      esac
+      ;;
+
+    beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*)
+      # PIC is the default for these OSes.
+      ;;
+
+    mingw* | cygwin* | pw32* | os2* | cegcc*)
+      # This hack is so that the source file can tell whether it is being
+      # built for inclusion in a dll (and should export symbols for example).
+      # Although the cygwin gcc ignores -fPIC, still need this for old-style
+      # (--disable-auto-import) libraries
+      m4_if([$1], [GCJ], [],
+       [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+      ;;
+
+    darwin* | rhapsody*)
+      # PIC is the default on this platform
+      # Common symbols not allowed in MH_DYLIB files
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common'
+      ;;
+
+    hpux*)
+      # PIC is the default for 64-bit PA HP-UX, but not for 32-bit
+      # PA HP-UX.  On IA64 HP-UX, PIC is the default but the pic flag
+      # sets the default TLS model and affects inlining.
+      case $host_cpu in
+      hppa*64*)
+       # +Z the default
+       ;;
+      *)
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+       ;;
+      esac
+      ;;
+
+    interix[[3-9]]*)
+      # Interix 3.x gcc -fpic/-fPIC options generate broken code.
+      # Instead, we relocate shared libraries at runtime.
+      ;;
+
+    msdosdjgpp*)
+      # Just because we use GCC doesn't mean we suddenly get shared libraries
+      # on systems that don't support them.
+      _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
+      enable_shared=no
+      ;;
+
+    *nto* | *qnx*)
+      # QNX uses GNU C++, but need to define -shared option too, otherwise
+      # it will coredump.
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared'
+      ;;
+
+    sysv4*MP*)
+      if test -d /usr/nec; then
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic
+      fi
+      ;;
+
+    *)
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+      ;;
+    esac
+  else
+    # PORTME Check for flag to pass linker flags through the system compiler.
+    case $host_os in
+    aix*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+      if test "$host_cpu" = ia64; then
+       # AIX 5 now supports IA64 processor
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      else
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp'
+      fi
+      ;;
+
+    mingw* | cygwin* | pw32* | os2* | cegcc*)
+      # This hack is so that the source file can tell whether it is being
+      # built for inclusion in a dll (and should export symbols for example).
+      m4_if([$1], [GCJ], [],
+       [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+      ;;
+
+    hpux9* | hpux10* | hpux11*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+      # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but
+      # not for PA HP-UX.
+      case $host_cpu in
+      hppa*64*|ia64*)
+       # +Z the default
+       ;;
+      *)
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
+       ;;
+      esac
+      # Is there a better lt_prog_compiler_static that works with the bundled CC?
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
+      ;;
+
+    irix5* | irix6* | nonstopux*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+      # PIC (with -KPIC) is the default.
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
+      ;;
+
+    linux* | k*bsd*-gnu)
+      case $cc_basename in
+      # old Intel for x86_64 which still supported -KPIC.
+      ecc*)
+       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+        ;;
+      # icc used to be incompatible with GCC.
+      # ICC 10 doesn't accept -KPIC any more.
+      icc* | ifort*)
+       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+        ;;
+      # Lahey Fortran 8.1.
+      lf95*)
+       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared'
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='--static'
+       ;;
+      pgcc* | pgf77* | pgf90* | pgf95*)
+        # Portland Group compilers (*not* the Pentium gcc compiler,
+       # which looks to be a dead project)
+       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic'
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+        ;;
+      ccc*)
+        _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+        # All Alpha code is PIC.
+        _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
+        ;;
+      xl*)
+       # IBM XL C 8.0/Fortran 10.1 on PPC
+       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic'
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink'
+       ;;
+      *)
+       case `$CC -V 2>&1 | sed 5q` in
+       *Sun\ C*)
+         # Sun C 5.9
+         _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+         _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+         _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+         ;;
+       *Sun\ F*)
+         # Sun Fortran 8.3 passes all unrecognized flags to the linker
+         _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+         _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+         _LT_TAGVAR(lt_prog_compiler_wl, $1)=''
+         ;;
+       esac
+       ;;
+      esac
+      ;;
+
+    newsos6)
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      ;;
+
+    *nto* | *qnx*)
+      # QNX uses GNU C++, but need to define -shared option too, otherwise
+      # it will coredump.
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared'
+      ;;
+
+    osf3* | osf4* | osf5*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+      # All OSF/1 code is PIC.
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
+      ;;
+
+    rdos*)
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
+      ;;
+
+    solaris*)
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      case $cc_basename in
+      f77* | f90* | f95*)
+       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';;
+      *)
+       _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';;
+      esac
+      ;;
+
+    sunos4*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld '
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      ;;
+
+    sysv4 | sysv4.2uw2* | sysv4.3*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      ;;
+
+    sysv4*MP*)
+      if test -d /usr/nec ;then
+       _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic'
+       _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      fi
+      ;;
+
+    sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      ;;
+
+    unicos*)
+      _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+      _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
+      ;;
+
+    uts4*)
+      _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic'
+      _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+      ;;
+
+    *)
+      _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no
+      ;;
+    esac
+  fi
+])
+case $host_os in
+  # For platforms which do not support PIC, -DPIC is meaningless:
+  *djgpp*)
+    _LT_TAGVAR(lt_prog_compiler_pic, $1)=
+    ;;
+  *)
+    _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])"
+    ;;
+esac
+AC_MSG_RESULT([$_LT_TAGVAR(lt_prog_compiler_pic, $1)])
+_LT_TAGDECL([wl], [lt_prog_compiler_wl], [1],
+       [How to pass a linker flag through the compiler])
+
+#
+# Check to make sure the PIC flag actually works.
+#
+if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then
+  _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works],
+    [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)],
+    [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [],
+    [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in
+     "" | " "*) ;;
+     *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;;
+     esac],
+    [_LT_TAGVAR(lt_prog_compiler_pic, $1)=
+     _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no])
+fi
+_LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1],
+       [Additional compiler flags for building library objects])
+
+#
+# Check to make sure the static flag actually works.
+#
+wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\"
+_LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works],
+  _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1),
+  $lt_tmp_static_flag,
+  [],
+  [_LT_TAGVAR(lt_prog_compiler_static, $1)=])
+_LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1],
+       [Compiler flag to prevent dynamic linking])
+])# _LT_COMPILER_PIC
+
+
+# _LT_LINKER_SHLIBS([TAGNAME])
+# ----------------------------
+# See if the linker supports building shared libraries.
+m4_defun([_LT_LINKER_SHLIBS],
+[AC_REQUIRE([LT_PATH_LD])dnl
+AC_REQUIRE([LT_PATH_NM])dnl
+m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+m4_require([_LT_DECL_EGREP])dnl
+m4_require([_LT_DECL_SED])dnl
+m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl
+m4_require([_LT_TAG_COMPILER])dnl
+AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries])
+m4_if([$1], [CXX], [
+  _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
+  case $host_os in
+  aix[[4-9]]*)
+    # If we're using GNU nm, then we don't want the "-C" option.
+    # -C means demangle to AIX nm, but means don't demangle with GNU nm
+    if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
+      _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+    else
+      _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+    fi
+    ;;
+  pw32*)
+    _LT_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds"
+  ;;
+  cygwin* | mingw* | cegcc*)
+    _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;/^.*[[ ]]__nm__/s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols'
+  ;;
+  *)
+    _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
+  ;;
+  esac
+  _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*']
+], [
+  runpath_var=
+  _LT_TAGVAR(allow_undefined_flag, $1)=
+  _LT_TAGVAR(always_export_symbols, $1)=no
+  _LT_TAGVAR(archive_cmds, $1)=
+  _LT_TAGVAR(archive_expsym_cmds, $1)=
+  _LT_TAGVAR(compiler_needs_object, $1)=no
+  _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no
+  _LT_TAGVAR(export_dynamic_flag_spec, $1)=
+  _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
+  _LT_TAGVAR(hardcode_automatic, $1)=no
+  _LT_TAGVAR(hardcode_direct, $1)=no
+  _LT_TAGVAR(hardcode_direct_absolute, $1)=no
+  _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
+  _LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)=
+  _LT_TAGVAR(hardcode_libdir_separator, $1)=
+  _LT_TAGVAR(hardcode_minus_L, $1)=no
+  _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
+  _LT_TAGVAR(inherit_rpath, $1)=no
+  _LT_TAGVAR(link_all_deplibs, $1)=unknown
+  _LT_TAGVAR(module_cmds, $1)=
+  _LT_TAGVAR(module_expsym_cmds, $1)=
+  _LT_TAGVAR(old_archive_from_new_cmds, $1)=
+  _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)=
+  _LT_TAGVAR(thread_safe_flag_spec, $1)=
+  _LT_TAGVAR(whole_archive_flag_spec, $1)=
+  # include_expsyms should be a list of space-separated symbols to be *always*
+  # included in the symbol list
+  _LT_TAGVAR(include_expsyms, $1)=
+  # exclude_expsyms can be an extended regexp of symbols to exclude
+  # it will be wrapped by ` (' and `)$', so one must not match beginning or
+  # end of line.  Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc',
+  # as well as any symbol that contains `d'.
+  _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*']
+  # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out
+  # platforms (ab)use it in PIC code, but their linkers get confused if
+  # the symbol is explicitly referenced.  Since portable code cannot
+  # rely on this symbol name, it's probably fine to never include it in
+  # preloaded symbol tables.
+  # Exclude shared library initialization/finalization symbols.
+dnl Note also adjust exclude_expsyms for C++ above.
+  extract_expsyms_cmds=
+
+  case $host_os in
+  cygwin* | mingw* | pw32* | cegcc*)
+    # FIXME: the MSVC++ port hasn't been tested in a loooong time
+    # When not using gcc, we currently assume that we are using
+    # Microsoft Visual C++.
+    if test "$GCC" != yes; then
+      with_gnu_ld=no
+    fi
+    ;;
+  interix*)
+    # we just hope/assume this is gcc and not c89 (= MSVC++)
+    with_gnu_ld=yes
+    ;;
+  openbsd*)
+    with_gnu_ld=no
+    ;;
+  esac
+
+  _LT_TAGVAR(ld_shlibs, $1)=yes
+  if test "$with_gnu_ld" = yes; then
+    # If archive_cmds runs LD, not CC, wlarc should be empty
+    wlarc='${wl}'
+
+    # Set some defaults for GNU ld with shared library support. These
+    # are reset later if shared libraries are not supported. Putting them
+    # here allows them to be overridden if necessary.
+    runpath_var=LD_RUN_PATH
+    _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+    _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+    # ancient GNU ld didn't support --whole-archive et. al.
+    if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then
+      _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+    else
+      _LT_TAGVAR(whole_archive_flag_spec, $1)=
+    fi
+    supports_anon_versioning=no
+    case `$LD -v 2>&1` in
+      *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11
+      *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ...
+      *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ...
+      *\ 2.11.*) ;; # other 2.11 versions
+      *) supports_anon_versioning=yes ;;
+    esac
+
+    # See if GNU ld supports shared libraries.
+    case $host_os in
+    aix[[3-9]]*)
+      # On AIX/PPC, the GNU linker is very broken
+      if test "$host_cpu" != ia64; then
+       _LT_TAGVAR(ld_shlibs, $1)=no
+       cat <<_LT_EOF 1>&2
+
+*** Warning: the GNU linker, at least up to release 2.9.1, is reported
+*** to be unable to reliably create shared libraries on AIX.
+*** Therefore, libtool is disabling shared libraries support.  If you
+*** really care for shared libraries, you may want to modify your PATH
+*** so that a non-GNU linker is found, and then restart.
+
+_LT_EOF
+      fi
+      ;;
+
+    amigaos*)
+      case $host_cpu in
+      powerpc)
+            # see comment about AmigaOS4 .so support
+            _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            _LT_TAGVAR(archive_expsym_cmds, $1)=''
+        ;;
+      m68k)
+            _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)'
+            _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+            _LT_TAGVAR(hardcode_minus_L, $1)=yes
+        ;;
+      esac
+      ;;
+
+    beos*)
+      if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+       _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+       # Joseph Beckenbach <jrb3@best.com> says some releases of gcc
+       # support --undefined.  This deserves some investigation.  FIXME
+       _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+      else
+       _LT_TAGVAR(ld_shlibs, $1)=no
+      fi
+      ;;
+
+    cygwin* | mingw* | pw32* | cegcc*)
+      # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
+      # as there is no search path for DLLs.
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+      _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+      _LT_TAGVAR(always_export_symbols, $1)=no
+      _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
+      _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols'
+
+      if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
+        _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+       # If the export-symbols file already is a .def file (1st line
+       # is EXPORTS), use it as is; otherwise, prepend...
+       _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
+         cp $export_symbols $output_objdir/$soname.def;
+       else
+         echo EXPORTS > $output_objdir/$soname.def;
+         cat $export_symbols >> $output_objdir/$soname.def;
+       fi~
+       $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+      else
+       _LT_TAGVAR(ld_shlibs, $1)=no
+      fi
+      ;;
+
+    interix[[3-9]]*)
+      _LT_TAGVAR(hardcode_direct, $1)=no
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+      # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
+      # Instead, shared libraries are loaded at an image base (0x10000000 by
+      # default) and relocated if they conflict, which is a slow very memory
+      # consuming and fragmenting process.  To avoid this, we pick a random,
+      # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
+      # time.  Moving up from 0x10000000 also allows more sbrk(2) space.
+      _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      ;;
+
+    gnu* | linux* | tpf* | k*bsd*-gnu)
+      tmp_diet=no
+      if test "$host_os" = linux-dietlibc; then
+       case $cc_basename in
+         diet\ *) tmp_diet=yes;;       # linux-dietlibc with static linking (!diet-dyn)
+       esac
+      fi
+      if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \
+        && test "$tmp_diet" = no
+      then
+       tmp_addflag=
+       tmp_sharedflag='-shared'
+       case $cc_basename,$host_cpu in
+        pgcc*)                         # Portland Group C compiler
+         _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+         tmp_addflag=' $pic_flag'
+         ;;
+       pgf77* | pgf90* | pgf95*)       # Portland Group f77 and f90 compilers
+         _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+         tmp_addflag=' $pic_flag -Mnomain' ;;
+       ecc*,ia64* | icc*,ia64*)        # Intel C compiler on ia64
+         tmp_addflag=' -i_dynamic' ;;
+       efc*,ia64* | ifort*,ia64*)      # Intel Fortran compiler on ia64
+         tmp_addflag=' -i_dynamic -nofor_main' ;;
+       ifc* | ifort*)                  # Intel Fortran compiler
+         tmp_addflag=' -nofor_main' ;;
+       lf95*)                          # Lahey Fortran 8.1
+         _LT_TAGVAR(whole_archive_flag_spec, $1)=
+         tmp_sharedflag='--shared' ;;
+       xl[[cC]]*)                      # IBM XL C 8.0 on PPC (deal with xlf below)
+         tmp_sharedflag='-qmkshrobj'
+         tmp_addflag= ;;
+       esac
+       case `$CC -V 2>&1 | sed 5q` in
+       *Sun\ C*)                       # Sun C 5.9
+         _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+         _LT_TAGVAR(compiler_needs_object, $1)=yes
+         tmp_sharedflag='-G' ;;
+       *Sun\ F*)                       # Sun Fortran 8.3
+         tmp_sharedflag='-G' ;;
+       esac
+       _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+
+        if test "x$supports_anon_versioning" = xyes; then
+          _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~
+           cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+           echo "local: *; };" >> $output_objdir/$libname.ver~
+           $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+        fi
+
+       case $cc_basename in
+       xlf*)
+         # IBM XL Fortran 10.1 on PPC cannot create shared libs itself
+         _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive'
+         _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
+         _LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='-rpath $libdir'
+         _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $compiler_flags -soname $soname -o $lib'
+         if test "x$supports_anon_versioning" = xyes; then
+           _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~
+             cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+             echo "local: *; };" >> $output_objdir/$libname.ver~
+             $LD -shared $libobjs $deplibs $compiler_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
+         fi
+         ;;
+       esac
+      else
+        _LT_TAGVAR(ld_shlibs, $1)=no
+      fi
+      ;;
+
+    netbsd*)
+      if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
+       _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib'
+       wlarc=
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+      fi
+      ;;
+
+    solaris*)
+      if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then
+       _LT_TAGVAR(ld_shlibs, $1)=no
+       cat <<_LT_EOF 1>&2
+
+*** Warning: The releases 2.8.* of the GNU linker cannot reliably
+*** create shared libraries on Solaris systems.  Therefore, libtool
+*** is disabling shared libraries support.  We urge you to upgrade GNU
+*** binutils to release 2.9.1 or newer.  Another option is to modify
+*** your PATH or compiler configuration so that the native linker is
+*** used, and then restart.
+
+_LT_EOF
+      elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+      else
+       _LT_TAGVAR(ld_shlibs, $1)=no
+      fi
+      ;;
+
+    sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*)
+      case `$LD -v 2>&1` in
+        *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*)
+       _LT_TAGVAR(ld_shlibs, $1)=no
+       cat <<_LT_EOF 1>&2
+
+*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not
+*** reliably create shared libraries on SCO systems.  Therefore, libtool
+*** is disabling shared libraries support.  We urge you to upgrade GNU
+*** binutils to release 2.16.91.0.3 or newer.  Another option is to modify
+*** your PATH or compiler configuration so that the native linker is
+*** used, and then restart.
+
+_LT_EOF
+       ;;
+       *)
+         # For security reasons, it is highly recommended that you always
+         # use absolute paths for naming shared libraries, and exclude the
+         # DT_RUNPATH tag from executables and libraries.  But doing so
+         # requires that you compile everything twice, which is a pain.
+         if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+           _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+           _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+         else
+           _LT_TAGVAR(ld_shlibs, $1)=no
+         fi
+       ;;
+      esac
+      ;;
+
+    sunos4*)
+      _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags'
+      wlarc=
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    *)
+      if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+      else
+       _LT_TAGVAR(ld_shlibs, $1)=no
+      fi
+      ;;
+    esac
+
+    if test "$_LT_TAGVAR(ld_shlibs, $1)" = no; then
+      runpath_var=
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)=
+      _LT_TAGVAR(whole_archive_flag_spec, $1)=
+    fi
+  else
+    # PORTME fill in a description of your system's linker (not GNU ld)
+    case $host_os in
+    aix3*)
+      _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+      _LT_TAGVAR(always_export_symbols, $1)=yes
+      _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname'
+      # Note: this linker hardcodes the directories in LIBPATH if there
+      # are no directories specified by -L.
+      _LT_TAGVAR(hardcode_minus_L, $1)=yes
+      if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then
+       # Neither direct hardcoding nor static linking is supported with a
+       # broken collect2.
+       _LT_TAGVAR(hardcode_direct, $1)=unsupported
+      fi
+      ;;
+
+    aix[[4-9]]*)
+      if test "$host_cpu" = ia64; then
+       # On IA64, the linker does run time linking by default, so we don't
+       # have to do anything special.
+       aix_use_runtimelinking=no
+       exp_sym_flag='-Bexport'
+       no_entry_flag=""
+      else
+       # If we're using GNU nm, then we don't want the "-C" option.
+       # -C means demangle to AIX nm, but means don't demangle with GNU nm
+       if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
+         _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+       else
+         _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+       fi
+       aix_use_runtimelinking=no
+
+       # Test if we are trying to use run time linking or normal
+       # AIX style linking. If -brtl is somewhere in LDFLAGS, we
+       # need to do runtime linking.
+       case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*)
+         for ld_flag in $LDFLAGS; do
+         if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
+           aix_use_runtimelinking=yes
+           break
+         fi
+         done
+         ;;
+       esac
+
+       exp_sym_flag='-bexport'
+       no_entry_flag='-bnoentry'
+      fi
+
+      # When large executables or shared objects are built, AIX ld can
+      # have problems creating the table of contents.  If linking a library
+      # or program results in "error TOC overflow" add -mminimal-toc to
+      # CXXFLAGS/CFLAGS for g++/gcc.  In the cases where that is not
+      # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS.
+
+      _LT_TAGVAR(archive_cmds, $1)=''
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
+      _LT_TAGVAR(hardcode_libdir_separator, $1)=':'
+      _LT_TAGVAR(link_all_deplibs, $1)=yes
+      _LT_TAGVAR(file_list_spec, $1)='${wl}-f,'
+
+      if test "$GCC" = yes; then
+       case $host_os in aix4.[[012]]|aix4.[[012]].*)
+       # We only want to do this on AIX 4.2 and lower, the check
+       # below for broken collect2 doesn't work under 4.3+
+         collect2name=`${CC} -print-prog-name=collect2`
+         if test -f "$collect2name" &&
+          strings "$collect2name" | $GREP resolve_lib_name >/dev/null
+         then
+         # We have reworked collect2
+         :
+         else
+         # We have old collect2
+         _LT_TAGVAR(hardcode_direct, $1)=unsupported
+         # It fails to find uninstalled libraries when the uninstalled
+         # path is not listed in the libpath.  Setting hardcode_minus_L
+         # to unsupported forces relinking
+         _LT_TAGVAR(hardcode_minus_L, $1)=yes
+         _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+         _LT_TAGVAR(hardcode_libdir_separator, $1)=
+         fi
+         ;;
+       esac
+       shared_flag='-shared'
+       if test "$aix_use_runtimelinking" = yes; then
+         shared_flag="$shared_flag "'${wl}-G'
+       fi
+      else
+       # not using gcc
+       if test "$host_cpu" = ia64; then
+       # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
+       # chokes on -Wl,-G. The following line is correct:
+         shared_flag='-G'
+       else
+         if test "$aix_use_runtimelinking" = yes; then
+           shared_flag='${wl}-G'
+         else
+           shared_flag='${wl}-bM:SRE'
+         fi
+       fi
+      fi
+
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall'
+      # It seems that -bexpall does not export symbols beginning with
+      # underscore (_), so it is better to generate a list of symbols to export.
+      _LT_TAGVAR(always_export_symbols, $1)=yes
+      if test "$aix_use_runtimelinking" = yes; then
+       # Warning - without using the other runtime loading flags (-brtl),
+       # -berok will link without error, but may produce a broken library.
+       _LT_TAGVAR(allow_undefined_flag, $1)='-berok'
+        # Determine the default libpath from the value encoded in an
+        # empty executable.
+        _LT_SYS_MODULE_PATH_AIX
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+        _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then $ECHO "X${wl}${allow_undefined_flag}" | $Xsed; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+      else
+       if test "$host_cpu" = ia64; then
+         _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
+         _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
+         _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+       else
+        # Determine the default libpath from the value encoded in an
+        # empty executable.
+        _LT_SYS_MODULE_PATH_AIX
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+         # Warning - without using the other run time loading flags,
+         # -berok will link without error, but may produce a broken library.
+         _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
+         _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
+         # Exported symbols can be pulled into shared objects from archives
+         _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience'
+         _LT_TAGVAR(archive_cmds_need_lc, $1)=yes
+         # This is similar to how AIX traditionally builds its shared libraries.
+         _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+       fi
+      fi
+      ;;
+
+    amigaos*)
+      case $host_cpu in
+      powerpc)
+            # see comment about AmigaOS4 .so support
+            _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            _LT_TAGVAR(archive_expsym_cmds, $1)=''
+        ;;
+      m68k)
+            _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)'
+            _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+            _LT_TAGVAR(hardcode_minus_L, $1)=yes
+        ;;
+      esac
+      ;;
+
+    bsdi[[45]]*)
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic
+      ;;
+
+    cygwin* | mingw* | pw32* | cegcc*)
+      # When not using gcc, we currently assume that we are using
+      # Microsoft Visual C++.
+      # hardcode_libdir_flag_spec is actually meaningless, as there is
+      # no search path for DLLs.
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' '
+      _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+      # Tell ltmain to make .lib files, not .a files.
+      libext=lib
+      # Tell ltmain to make .dll files, not .so files.
+      shrext_cmds=".dll"
+      # FIXME: Setting linknames here is a bad hack.
+      _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `$ECHO "X$deplibs" | $Xsed -e '\''s/ -lc$//'\''` -link -dll~linknames='
+      # The linker will automatically build a .lib file if we build a DLL.
+      _LT_TAGVAR(old_archive_from_new_cmds, $1)='true'
+      # FIXME: Should let the user specify the lib program.
+      _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs'
+      _LT_TAGVAR(fix_srcfile_path, $1)='`cygpath -w "$srcfile"`'
+      _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
+      ;;
+
+    darwin* | rhapsody*)
+      _LT_DARWIN_LINKER_FEATURES($1)
+      ;;
+
+    dgux*)
+      _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    freebsd1*)
+      _LT_TAGVAR(ld_shlibs, $1)=no
+      ;;
+
+    # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor
+    # support.  Future versions do this automatically, but an explicit c++rt0.o
+    # does not break anything, and helps significantly (at the cost of a little
+    # extra space).
+    freebsd2.2*)
+      _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    # Unfortunately, older versions of FreeBSD 2 do not have this feature.
+    freebsd2*)
+      _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_minus_L, $1)=yes
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    # FreeBSD 3 and greater uses gcc -shared to do shared libraries.
+    freebsd* | dragonfly*)
+      _LT_TAGVAR(archive_cmds, $1)='$CC -shared -o $lib $libobjs $deplibs $compiler_flags'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    hpux9*)
+      if test "$GCC" = yes; then
+       _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+      fi
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+
+      # hardcode_minus_L: Not really in the search PATH,
+      # but as the default location of the library.
+      _LT_TAGVAR(hardcode_minus_L, $1)=yes
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+      ;;
+
+    hpux10*)
+      if test "$GCC" = yes -a "$with_gnu_ld" = no; then
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
+      fi
+      if test "$with_gnu_ld" = no; then
+       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+       _LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir'
+       _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+       _LT_TAGVAR(hardcode_direct, $1)=yes
+       _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
+       _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+       # hardcode_minus_L: Not really in the search PATH,
+       # but as the default location of the library.
+       _LT_TAGVAR(hardcode_minus_L, $1)=yes
+      fi
+      ;;
+
+    hpux11*)
+      if test "$GCC" = yes -a "$with_gnu_ld" = no; then
+       case $host_cpu in
+       hppa*64*)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       ia64*)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       *)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       esac
+      else
+       case $host_cpu in
+       hppa*64*)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       ia64*)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       *)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       esac
+      fi
+      if test "$with_gnu_ld" = no; then
+       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+       _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+
+       case $host_cpu in
+       hppa*64*|ia64*)
+         _LT_TAGVAR(hardcode_direct, $1)=no
+         _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+         ;;
+       *)
+         _LT_TAGVAR(hardcode_direct, $1)=yes
+         _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
+         _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+
+         # hardcode_minus_L: Not really in the search PATH,
+         # but as the default location of the library.
+         _LT_TAGVAR(hardcode_minus_L, $1)=yes
+         ;;
+       esac
+      fi
+      ;;
+
+    irix5* | irix6* | nonstopux*)
+      if test "$GCC" = yes; then
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+       # Try to use the -exported_symbol ld option, if it does not
+       # work, assume that -exports_file does not work either and
+       # implicitly export all symbols.
+        save_LDFLAGS="$LDFLAGS"
+        LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null"
+        AC_LINK_IFELSE(int foo(void) {},
+          _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib'
+        )
+        LDFLAGS="$save_LDFLAGS"
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib'
+      fi
+      _LT_TAGVAR(archive_cmds_need_lc, $1)='no'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+      _LT_TAGVAR(inherit_rpath, $1)=yes
+      _LT_TAGVAR(link_all_deplibs, $1)=yes
+      ;;
+
+    netbsd*)
+      if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
+       _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'  # a.out
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags'      # ELF
+      fi
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    newsos6)
+      _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    *nto* | *qnx*)
+      ;;
+
+    openbsd*)
+      if test -f /usr/libexec/ld.so; then
+       _LT_TAGVAR(hardcode_direct, $1)=yes
+       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+       _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
+       if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+         _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+         _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols'
+         _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+         _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+       else
+         case $host_os in
+          openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*)
+            _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
+            _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+            ;;
+          *)
+            _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+            _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+            ;;
+         esac
+       fi
+      else
+       _LT_TAGVAR(ld_shlibs, $1)=no
+      fi
+      ;;
+
+    os2*)
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+      _LT_TAGVAR(hardcode_minus_L, $1)=yes
+      _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+      _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$ECHO DATA >> $output_objdir/$libname.def~$ECHO " SINGLE NONSHARED" >> $output_objdir/$libname.def~$ECHO EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def'
+      _LT_TAGVAR(old_archive_from_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def'
+      ;;
+
+    osf3*)
+      if test "$GCC" = yes; then
+       _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+      else
+       _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+      fi
+      _LT_TAGVAR(archive_cmds_need_lc, $1)='no'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+      ;;
+
+    osf4* | osf5*)     # as osf3* with the addition of -msym flag
+      if test "$GCC" = yes; then
+       _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+      else
+       _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~
+       $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp'
+
+       # Both c and cxx compiler support -rpath directly
+       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
+      fi
+      _LT_TAGVAR(archive_cmds_need_lc, $1)='no'
+      _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+      ;;
+
+    solaris*)
+      _LT_TAGVAR(no_undefined_flag, $1)=' -z defs'
+      if test "$GCC" = yes; then
+       wlarc='${wl}'
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+         $CC -shared ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+      else
+       case `$CC -V 2>&1` in
+       *"Compilers 5.0"*)
+         wlarc=''
+         _LT_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
+         _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+         $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
+         ;;
+       *)
+         wlarc='${wl}'
+         _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags'
+         _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+         $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+         ;;
+       esac
+      fi
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      case $host_os in
+      solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
+      *)
+       # The compiler driver will combine and reorder linker options,
+       # but understands `-z linker_flag'.  GCC discards it without `$wl',
+       # but is careful enough not to reorder.
+       # Supported since Solaris 2.6 (maybe 2.5.1?)
+       if test "$GCC" = yes; then
+         _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+       else
+         _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract'
+       fi
+       ;;
+      esac
+      _LT_TAGVAR(link_all_deplibs, $1)=yes
+      ;;
+
+    sunos4*)
+      if test "x$host_vendor" = xsequent; then
+       # Use $CC to link under sequent, because it throws in some extra .o
+       # files that make .init and .fini sections work.
+       _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags'
+      fi
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+      _LT_TAGVAR(hardcode_direct, $1)=yes
+      _LT_TAGVAR(hardcode_minus_L, $1)=yes
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    sysv4)
+      case $host_vendor in
+       sni)
+         _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+         _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true???
+       ;;
+       siemens)
+         ## LD is ld it makes a PLAMLIB
+         ## CC just makes a GrossModule.
+         _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags'
+         _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs'
+         _LT_TAGVAR(hardcode_direct, $1)=no
+        ;;
+       motorola)
+         _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+         _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie
+       ;;
+      esac
+      runpath_var='LD_RUN_PATH'
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    sysv4.3*)
+      _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport'
+      ;;
+
+    sysv4*MP*)
+      if test -d /usr/nec; then
+       _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+       runpath_var=LD_RUN_PATH
+       hardcode_runpath_var=yes
+       _LT_TAGVAR(ld_shlibs, $1)=yes
+      fi
+      ;;
+
+    sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*)
+      _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+      _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      runpath_var='LD_RUN_PATH'
+
+      if test "$GCC" = yes; then
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      fi
+      ;;
+
+    sysv5* | sco3.2v5* | sco5v6*)
+      # Note: We can NOT use -z defs as we might desire, because we do not
+      # link with -lc, and that would cause any symbols used from libc to
+      # always be unresolved, which means just about no library would
+      # ever link correctly.  If we're not using GNU ld we use -z text
+      # though, which does catch some bad symbols but isn't as heavy-handed
+      # as -z defs.
+      _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+      _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs'
+      _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir'
+      _LT_TAGVAR(hardcode_libdir_separator, $1)=':'
+      _LT_TAGVAR(link_all_deplibs, $1)=yes
+      _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport'
+      runpath_var='LD_RUN_PATH'
+
+      if test "$GCC" = yes; then
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      fi
+      ;;
+
+    uts4*)
+      _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      ;;
+
+    *)
+      _LT_TAGVAR(ld_shlibs, $1)=no
+      ;;
+    esac
+
+    if test x$host_vendor = xsni; then
+      case $host in
+      sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
+       _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Blargedynsym'
+       ;;
+      esac
+    fi
+  fi
+])
+AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)])
+test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
+
+_LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld
+
+_LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl
+_LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl
+_LT_DECL([], [extract_expsyms_cmds], [2],
+    [The commands to extract the exported symbol list from a shared archive])
+
+#
+# Do we need to explicitly link libc?
+#
+case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in
+x|xyes)
+  # Assume -lc should be added
+  _LT_TAGVAR(archive_cmds_need_lc, $1)=yes
+
+  if test "$enable_shared" = yes && test "$GCC" = yes; then
+    case $_LT_TAGVAR(archive_cmds, $1) in
+    *'~'*)
+      # FIXME: we may have to deal with multi-command sequences.
+      ;;
+    '$CC '*)
+      # Test whether the compiler implicitly links with -lc since on some
+      # systems, -lgcc has to come before -lc. If gcc already passes -lc
+      # to ld, don't add -lc before -lgcc.
+      AC_MSG_CHECKING([whether -lc should be explicitly linked in])
+      $RM conftest*
+      echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+
+      if AC_TRY_EVAL(ac_compile) 2>conftest.err; then
+        soname=conftest
+        lib=conftest
+        libobjs=conftest.$ac_objext
+        deplibs=
+        wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1)
+       pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1)
+        compiler_flags=-v
+        linker_flags=-v
+        verstring=
+        output_objdir=.
+        libname=conftest
+        lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1)
+        _LT_TAGVAR(allow_undefined_flag, $1)=
+        if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1)
+        then
+         _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+        else
+         _LT_TAGVAR(archive_cmds_need_lc, $1)=yes
+        fi
+        _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag
+      else
+        cat conftest.err 1>&5
+      fi
+      $RM conftest*
+      AC_MSG_RESULT([$_LT_TAGVAR(archive_cmds_need_lc, $1)])
+      ;;
+    esac
+  fi
+  ;;
+esac
+
+_LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0],
+    [Whether or not to add -lc for building shared libraries])
+_LT_TAGDECL([allow_libtool_libs_with_static_runtimes],
+    [enable_shared_with_static_runtimes], [0],
+    [Whether or not to disallow shared libs when runtime libs are static])
+_LT_TAGDECL([], [export_dynamic_flag_spec], [1],
+    [Compiler flag to allow reflexive dlopens])
+_LT_TAGDECL([], [whole_archive_flag_spec], [1],
+    [Compiler flag to generate shared objects directly from archives])
+_LT_TAGDECL([], [compiler_needs_object], [1],
+    [Whether the compiler copes with passing no objects directly])
+_LT_TAGDECL([], [old_archive_from_new_cmds], [2],
+    [Create an old-style archive from a shared archive])
+_LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2],
+    [Create a temporary old-style archive to link instead of a shared archive])
+_LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive])
+_LT_TAGDECL([], [archive_expsym_cmds], [2])
+_LT_TAGDECL([], [module_cmds], [2],
+    [Commands used to build a loadable module if different from building
+    a shared archive.])
+_LT_TAGDECL([], [module_expsym_cmds], [2])
+_LT_TAGDECL([], [with_gnu_ld], [1],
+    [Whether we are building with GNU ld or not])
+_LT_TAGDECL([], [allow_undefined_flag], [1],
+    [Flag that allows shared libraries with undefined symbols to be built])
+_LT_TAGDECL([], [no_undefined_flag], [1],
+    [Flag that enforces no undefined symbols])
+_LT_TAGDECL([], [hardcode_libdir_flag_spec], [1],
+    [Flag to hardcode $libdir into a binary during linking.
+    This must work even if $libdir does not exist])
+_LT_TAGDECL([], [hardcode_libdir_flag_spec_ld], [1],
+    [[If ld is used when linking, flag to hardcode $libdir into a binary
+    during linking.  This must work even if $libdir does not exist]])
+_LT_TAGDECL([], [hardcode_libdir_separator], [1],
+    [Whether we need a single "-rpath" flag with a separated argument])
+_LT_TAGDECL([], [hardcode_direct], [0],
+    [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes
+    DIR into the resulting binary])
+_LT_TAGDECL([], [hardcode_direct_absolute], [0],
+    [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes
+    DIR into the resulting binary and the resulting library dependency is
+    "absolute", i.e impossible to change by setting ${shlibpath_var} if the
+    library is relocated])
+_LT_TAGDECL([], [hardcode_minus_L], [0],
+    [Set to "yes" if using the -LDIR flag during linking hardcodes DIR
+    into the resulting binary])
+_LT_TAGDECL([], [hardcode_shlibpath_var], [0],
+    [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR
+    into the resulting binary])
+_LT_TAGDECL([], [hardcode_automatic], [0],
+    [Set to "yes" if building a shared library automatically hardcodes DIR
+    into the library and all subsequent libraries and executables linked
+    against it])
+_LT_TAGDECL([], [inherit_rpath], [0],
+    [Set to yes if linker adds runtime paths of dependent libraries
+    to runtime path list])
+_LT_TAGDECL([], [link_all_deplibs], [0],
+    [Whether libtool must link a program against all its dependency libraries])
+_LT_TAGDECL([], [fix_srcfile_path], [1],
+    [Fix the shell variable $srcfile for the compiler])
+_LT_TAGDECL([], [always_export_symbols], [0],
+    [Set to "yes" if exported symbols are required])
+_LT_TAGDECL([], [export_symbols_cmds], [2],
+    [The commands to list exported symbols])
+_LT_TAGDECL([], [exclude_expsyms], [1],
+    [Symbols that should not be listed in the preloaded symbols])
+_LT_TAGDECL([], [include_expsyms], [1],
+    [Symbols that must always be exported])
+_LT_TAGDECL([], [prelink_cmds], [2],
+    [Commands necessary for linking programs (against libraries) with templates])
+_LT_TAGDECL([], [file_list_spec], [1],
+    [Specify filename containing input files])
+dnl FIXME: Not yet implemented
+dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1],
+dnl    [Compiler flag to generate thread safe objects])
+])# _LT_LINKER_SHLIBS
+
+
+# _LT_LANG_C_CONFIG([TAG])
+# ------------------------
+# Ensure that the configuration variables for a C compiler are suitably
+# defined.  These variables are subsequently used by _LT_CONFIG to write
+# the compiler configuration to `libtool'.
+m4_defun([_LT_LANG_C_CONFIG],
+[m4_require([_LT_DECL_EGREP])dnl
+lt_save_CC="$CC"
+AC_LANG_PUSH(C)
+
+# Source file extension for C test sources.
+ac_ext=c
+
+# Object file extension for compiled C test sources.
+objext=o
+_LT_TAGVAR(objext, $1)=$objext
+
+# Code to be used in simple compile tests
+lt_simple_compile_test_code="int some_variable = 0;"
+
+# Code to be used in simple link tests
+lt_simple_link_test_code='int main(){return(0);}'
+
+_LT_TAG_COMPILER
+# Save the default compiler, since it gets overwritten when the other
+# tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP.
+compiler_DEFAULT=$CC
+
+# save warnings/boilerplate of simple test code
+_LT_COMPILER_BOILERPLATE
+_LT_LINKER_BOILERPLATE
+
+if test -n "$compiler"; then
+  _LT_COMPILER_NO_RTTI($1)
+  _LT_COMPILER_PIC($1)
+  _LT_COMPILER_C_O($1)
+  _LT_COMPILER_FILE_LOCKS($1)
+  _LT_LINKER_SHLIBS($1)
+  _LT_SYS_DYNAMIC_LINKER($1)
+  _LT_LINKER_HARDCODE_LIBPATH($1)
+  LT_SYS_DLOPEN_SELF
+  _LT_CMD_STRIPLIB
+
+  # Report which library types will actually be built
+  AC_MSG_CHECKING([if libtool supports shared libraries])
+  AC_MSG_RESULT([$can_build_shared])
+
+  AC_MSG_CHECKING([whether to build shared libraries])
+  test "$can_build_shared" = "no" && enable_shared=no
+
+  # On AIX, shared libraries and static libraries use the same namespace, and
+  # are all built from PIC.
+  case $host_os in
+  aix3*)
+    test "$enable_shared" = yes && enable_static=no
+    if test -n "$RANLIB"; then
+      archive_cmds="$archive_cmds~\$RANLIB \$lib"
+      postinstall_cmds='$RANLIB $lib'
+    fi
+    ;;
+
+  aix[[4-9]]*)
+    if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
+      test "$enable_shared" = yes && enable_static=no
+    fi
+    ;;
+  esac
+  AC_MSG_RESULT([$enable_shared])
+
+  AC_MSG_CHECKING([whether to build static libraries])
+  # Make sure either enable_shared or enable_static is yes.
+  test "$enable_shared" = yes || enable_static=yes
+  AC_MSG_RESULT([$enable_static])
+
+  _LT_CONFIG($1)
+fi
+AC_LANG_POP
+CC="$lt_save_CC"
+])# _LT_LANG_C_CONFIG
+
+
+# _LT_PROG_CXX
+# ------------
+# Since AC_PROG_CXX is broken, in that it returns g++ if there is no c++
+# compiler, we have our own version here.
+m4_defun([_LT_PROG_CXX],
+[
+pushdef([AC_MSG_ERROR], [_lt_caught_CXX_error=yes])
+AC_PROG_CXX
+if test -n "$CXX" && ( test "X$CXX" != "Xno" &&
+    ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) ||
+    (test "X$CXX" != "Xg++"))) ; then
+  AC_PROG_CXXCPP
+else
+  _lt_caught_CXX_error=yes
+fi
+popdef([AC_MSG_ERROR])
+])# _LT_PROG_CXX
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([_LT_PROG_CXX], [])
+
+
+# _LT_LANG_CXX_CONFIG([TAG])
+# --------------------------
+# Ensure that the configuration variables for a C++ compiler are suitably
+# defined.  These variables are subsequently used by _LT_CONFIG to write
+# the compiler configuration to `libtool'.
+m4_defun([_LT_LANG_CXX_CONFIG],
+[AC_REQUIRE([_LT_PROG_CXX])dnl
+m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+m4_require([_LT_DECL_EGREP])dnl
+
+AC_LANG_PUSH(C++)
+_LT_TAGVAR(archive_cmds_need_lc, $1)=no
+_LT_TAGVAR(allow_undefined_flag, $1)=
+_LT_TAGVAR(always_export_symbols, $1)=no
+_LT_TAGVAR(archive_expsym_cmds, $1)=
+_LT_TAGVAR(compiler_needs_object, $1)=no
+_LT_TAGVAR(export_dynamic_flag_spec, $1)=
+_LT_TAGVAR(hardcode_direct, $1)=no
+_LT_TAGVAR(hardcode_direct_absolute, $1)=no
+_LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
+_LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)=
+_LT_TAGVAR(hardcode_libdir_separator, $1)=
+_LT_TAGVAR(hardcode_minus_L, $1)=no
+_LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
+_LT_TAGVAR(hardcode_automatic, $1)=no
+_LT_TAGVAR(inherit_rpath, $1)=no
+_LT_TAGVAR(module_cmds, $1)=
+_LT_TAGVAR(module_expsym_cmds, $1)=
+_LT_TAGVAR(link_all_deplibs, $1)=unknown
+_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds
+_LT_TAGVAR(no_undefined_flag, $1)=
+_LT_TAGVAR(whole_archive_flag_spec, $1)=
+_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no
+
+# Source file extension for C++ test sources.
+ac_ext=cpp
+
+# Object file extension for compiled C++ test sources.
+objext=o
+_LT_TAGVAR(objext, $1)=$objext
+
+# No sense in running all these tests if we already determined that
+# the CXX compiler isn't working.  Some variables (like enable_shared)
+# are currently assumed to apply to all compilers on this platform,
+# and will be corrupted by setting them based on a non-working compiler.
+if test "$_lt_caught_CXX_error" != yes; then
+  # Code to be used in simple compile tests
+  lt_simple_compile_test_code="int some_variable = 0;"
+
+  # Code to be used in simple link tests
+  lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }'
+
+  # ltmain only uses $CC for tagged configurations so make sure $CC is set.
+  _LT_TAG_COMPILER
+
+  # save warnings/boilerplate of simple test code
+  _LT_COMPILER_BOILERPLATE
+  _LT_LINKER_BOILERPLATE
+
+  # Allow CC to be a program name with arguments.
+  lt_save_CC=$CC
+  lt_save_LD=$LD
+  lt_save_GCC=$GCC
+  GCC=$GXX
+  lt_save_with_gnu_ld=$with_gnu_ld
+  lt_save_path_LD=$lt_cv_path_LD
+  if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then
+    lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx
+  else
+    $as_unset lt_cv_prog_gnu_ld
+  fi
+  if test -n "${lt_cv_path_LDCXX+set}"; then
+    lt_cv_path_LD=$lt_cv_path_LDCXX
+  else
+    $as_unset lt_cv_path_LD
+  fi
+  test -z "${LDCXX+set}" || LD=$LDCXX
+  CC=${CXX-"c++"}
+  compiler=$CC
+  _LT_TAGVAR(compiler, $1)=$CC
+  _LT_CC_BASENAME([$compiler])
+
+  if test -n "$compiler"; then
+    # We don't want -fno-exception when compiling C++ code, so set the
+    # no_builtin_flag separately
+    if test "$GXX" = yes; then
+      _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin'
+    else
+      _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
+    fi
+
+    if test "$GXX" = yes; then
+      # Set up default GNU C++ configuration
+
+      LT_PATH_LD
+
+      # Check if GNU C++ uses GNU ld as the underlying linker, since the
+      # archiving commands below assume that GNU ld is being used.
+      if test "$with_gnu_ld" = yes; then
+        _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
+        _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+        _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+
+        # If archive_cmds runs LD, not CC, wlarc should be empty
+        # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to
+        #     investigate it a little bit more. (MM)
+        wlarc='${wl}'
+
+        # ancient GNU ld didn't support --whole-archive et. al.
+        if eval "`$CC -print-prog-name=ld` --help 2>&1" |
+         $GREP 'no-whole-archive' > /dev/null; then
+          _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+        else
+          _LT_TAGVAR(whole_archive_flag_spec, $1)=
+        fi
+      else
+        with_gnu_ld=no
+        wlarc=
+
+        # A generic and very simple default shared library creation
+        # command for GNU C++ for the case where it uses the native
+        # linker, instead of GNU ld.  If possible, this setting should
+        # overridden to take advantage of the native linker features on
+        # the platform it is being used on.
+        _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib'
+      fi
+
+      # Commands to make compiler produce verbose output that lists
+      # what "hidden" libraries, object files and flags are used when
+      # linking a shared library.
+      output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"'
+
+    else
+      GXX=no
+      with_gnu_ld=no
+      wlarc=
+    fi
+
+    # PORTME: fill in a description of your system's C++ link characteristics
+    AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries])
+    _LT_TAGVAR(ld_shlibs, $1)=yes
+    case $host_os in
+      aix3*)
+        # FIXME: insert proper C++ library support
+        _LT_TAGVAR(ld_shlibs, $1)=no
+        ;;
+      aix[[4-9]]*)
+        if test "$host_cpu" = ia64; then
+          # On IA64, the linker does run time linking by default, so we don't
+          # have to do anything special.
+          aix_use_runtimelinking=no
+          exp_sym_flag='-Bexport'
+          no_entry_flag=""
+        else
+          aix_use_runtimelinking=no
+
+          # Test if we are trying to use run time linking or normal
+          # AIX style linking. If -brtl is somewhere in LDFLAGS, we
+          # need to do runtime linking.
+          case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*)
+           for ld_flag in $LDFLAGS; do
+             case $ld_flag in
+             *-brtl*)
+               aix_use_runtimelinking=yes
+               break
+               ;;
+             esac
+           done
+           ;;
+          esac
+
+          exp_sym_flag='-bexport'
+          no_entry_flag='-bnoentry'
+        fi
+
+        # When large executables or shared objects are built, AIX ld can
+        # have problems creating the table of contents.  If linking a library
+        # or program results in "error TOC overflow" add -mminimal-toc to
+        # CXXFLAGS/CFLAGS for g++/gcc.  In the cases where that is not
+        # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS.
+
+        _LT_TAGVAR(archive_cmds, $1)=''
+        _LT_TAGVAR(hardcode_direct, $1)=yes
+        _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
+        _LT_TAGVAR(hardcode_libdir_separator, $1)=':'
+        _LT_TAGVAR(link_all_deplibs, $1)=yes
+        _LT_TAGVAR(file_list_spec, $1)='${wl}-f,'
+
+        if test "$GXX" = yes; then
+          case $host_os in aix4.[[012]]|aix4.[[012]].*)
+          # We only want to do this on AIX 4.2 and lower, the check
+          # below for broken collect2 doesn't work under 4.3+
+         collect2name=`${CC} -print-prog-name=collect2`
+         if test -f "$collect2name" &&
+            strings "$collect2name" | $GREP resolve_lib_name >/dev/null
+         then
+           # We have reworked collect2
+           :
+         else
+           # We have old collect2
+           _LT_TAGVAR(hardcode_direct, $1)=unsupported
+           # It fails to find uninstalled libraries when the uninstalled
+           # path is not listed in the libpath.  Setting hardcode_minus_L
+           # to unsupported forces relinking
+           _LT_TAGVAR(hardcode_minus_L, $1)=yes
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+           _LT_TAGVAR(hardcode_libdir_separator, $1)=
+         fi
+          esac
+          shared_flag='-shared'
+         if test "$aix_use_runtimelinking" = yes; then
+           shared_flag="$shared_flag "'${wl}-G'
+         fi
+        else
+          # not using gcc
+          if test "$host_cpu" = ia64; then
+         # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
+         # chokes on -Wl,-G. The following line is correct:
+         shared_flag='-G'
+          else
+           if test "$aix_use_runtimelinking" = yes; then
+             shared_flag='${wl}-G'
+           else
+             shared_flag='${wl}-bM:SRE'
+           fi
+          fi
+        fi
+
+        _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall'
+        # It seems that -bexpall does not export symbols beginning with
+        # underscore (_), so it is better to generate a list of symbols to
+       # export.
+        _LT_TAGVAR(always_export_symbols, $1)=yes
+        if test "$aix_use_runtimelinking" = yes; then
+          # Warning - without using the other runtime loading flags (-brtl),
+          # -berok will link without error, but may produce a broken library.
+          _LT_TAGVAR(allow_undefined_flag, $1)='-berok'
+          # Determine the default libpath from the value encoded in an empty
+          # executable.
+          _LT_SYS_MODULE_PATH_AIX
+          _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+
+          _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then $ECHO "X${wl}${allow_undefined_flag}" | $Xsed; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+        else
+          if test "$host_cpu" = ia64; then
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
+           _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
+           _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+          else
+           # Determine the default libpath from the value encoded in an
+           # empty executable.
+           _LT_SYS_MODULE_PATH_AIX
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+           # Warning - without using the other run time loading flags,
+           # -berok will link without error, but may produce a broken library.
+           _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
+           _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
+           # Exported symbols can be pulled into shared objects from archives
+           _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience'
+           _LT_TAGVAR(archive_cmds_need_lc, $1)=yes
+           # This is similar to how AIX traditionally builds its shared
+           # libraries.
+           _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+          fi
+        fi
+        ;;
+
+      beos*)
+       if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+         _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+         # Joseph Beckenbach <jrb3@best.com> says some releases of gcc
+         # support --undefined.  This deserves some investigation.  FIXME
+         _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+       else
+         _LT_TAGVAR(ld_shlibs, $1)=no
+       fi
+       ;;
+
+      chorus*)
+        case $cc_basename in
+          *)
+         # FIXME: insert proper C++ library support
+         _LT_TAGVAR(ld_shlibs, $1)=no
+         ;;
+        esac
+        ;;
+
+      cygwin* | mingw* | pw32* | cegcc*)
+        # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
+        # as there is no search path for DLLs.
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+        _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+        _LT_TAGVAR(always_export_symbols, $1)=no
+        _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
+
+        if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
+          _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+          # If the export-symbols file already is a .def file (1st line
+          # is EXPORTS), use it as is; otherwise, prepend...
+          _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
+           cp $export_symbols $output_objdir/$soname.def;
+          else
+           echo EXPORTS > $output_objdir/$soname.def;
+           cat $export_symbols >> $output_objdir/$soname.def;
+          fi~
+          $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+        else
+          _LT_TAGVAR(ld_shlibs, $1)=no
+        fi
+        ;;
+      darwin* | rhapsody*)
+        _LT_DARWIN_LINKER_FEATURES($1)
+       ;;
+
+      dgux*)
+        case $cc_basename in
+          ec++*)
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+          ghcx*)
+           # Green Hills C++ Compiler
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+          *)
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+        esac
+        ;;
+
+      freebsd[[12]]*)
+        # C++ shared libraries reported to be fairly broken before
+       # switch to ELF
+        _LT_TAGVAR(ld_shlibs, $1)=no
+        ;;
+
+      freebsd-elf*)
+        _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+        ;;
+
+      freebsd* | dragonfly*)
+        # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF
+        # conventions
+        _LT_TAGVAR(ld_shlibs, $1)=yes
+        ;;
+
+      gnu*)
+        ;;
+
+      hpux9*)
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+        _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+        _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+        _LT_TAGVAR(hardcode_direct, $1)=yes
+        _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH,
+                                            # but as the default
+                                            # location of the library.
+
+        case $cc_basename in
+          CC*)
+            # FIXME: insert proper C++ library support
+            _LT_TAGVAR(ld_shlibs, $1)=no
+            ;;
+          aCC*)
+            _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+            # Commands to make compiler produce verbose output that lists
+            # what "hidden" libraries, object files and flags are used when
+            # linking a shared library.
+            #
+            # There doesn't appear to be a way to prevent this compiler from
+            # explicitly linking system object files so we need to strip them
+            # from the output so that they don't get included in the library
+            # dependencies.
+            output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed'
+            ;;
+          *)
+            if test "$GXX" = yes; then
+              _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+            else
+              # FIXME: insert proper C++ library support
+              _LT_TAGVAR(ld_shlibs, $1)=no
+            fi
+            ;;
+        esac
+        ;;
+
+      hpux10*|hpux11*)
+        if test $with_gnu_ld = no; then
+         _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+         _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+
+          case $host_cpu in
+            hppa*64*|ia64*)
+              ;;
+            *)
+             _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+              ;;
+          esac
+        fi
+        case $host_cpu in
+          hppa*64*|ia64*)
+            _LT_TAGVAR(hardcode_direct, $1)=no
+            _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+            ;;
+          *)
+            _LT_TAGVAR(hardcode_direct, $1)=yes
+            _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
+            _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH,
+                                                # but as the default
+                                                # location of the library.
+            ;;
+        esac
+
+        case $cc_basename in
+          CC*)
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+          aCC*)
+           case $host_cpu in
+             hppa*64*)
+               _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+               ;;
+             ia64*)
+               _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+               ;;
+             *)
+               _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+               ;;
+           esac
+           # Commands to make compiler produce verbose output that lists
+           # what "hidden" libraries, object files and flags are used when
+           # linking a shared library.
+           #
+           # There doesn't appear to be a way to prevent this compiler from
+           # explicitly linking system object files so we need to strip them
+           # from the output so that they don't get included in the library
+           # dependencies.
+           output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed'
+           ;;
+          *)
+           if test "$GXX" = yes; then
+             if test $with_gnu_ld = no; then
+               case $host_cpu in
+                 hppa*64*)
+                   _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+                   ;;
+                 ia64*)
+                   _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+                   ;;
+                 *)
+                   _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+                   ;;
+               esac
+             fi
+           else
+             # FIXME: insert proper C++ library support
+             _LT_TAGVAR(ld_shlibs, $1)=no
+           fi
+           ;;
+        esac
+        ;;
+
+      interix[[3-9]]*)
+       _LT_TAGVAR(hardcode_direct, $1)=no
+       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+       _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+       # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
+       # Instead, shared libraries are loaded at an image base (0x10000000 by
+       # default) and relocated if they conflict, which is a slow very memory
+       # consuming and fragmenting process.  To avoid this, we pick a random,
+       # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
+       # time.  Moving up from 0x10000000 also allows more sbrk(2) space.
+       _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+       _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+       ;;
+      irix5* | irix6*)
+        case $cc_basename in
+          CC*)
+           # SGI C++
+           _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+
+           # Archives containing C++ object files must be created using
+           # "CC -ar", where "CC" is the IRIX C++ compiler.  This is
+           # necessary to make sure instantiated templates are included
+           # in the archive.
+           _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs'
+           ;;
+          *)
+           if test "$GXX" = yes; then
+             if test "$with_gnu_ld" = no; then
+               _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+             else
+               _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` -o $lib'
+             fi
+           fi
+           _LT_TAGVAR(link_all_deplibs, $1)=yes
+           ;;
+        esac
+        _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+        _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+        _LT_TAGVAR(inherit_rpath, $1)=yes
+        ;;
+
+      linux* | k*bsd*-gnu)
+        case $cc_basename in
+          KCC*)
+           # Kuck and Associates, Inc. (KAI) C++ Compiler
+
+           # KCC will only create a shared library if the output file
+           # ends with ".so" (or ".sl" for HP-UX), so rename the library
+           # to its proper name (with version) after linking.
+           _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
+           _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib'
+           # Commands to make compiler produce verbose output that lists
+           # what "hidden" libraries, object files and flags are used when
+           # linking a shared library.
+           #
+           # There doesn't appear to be a way to prevent this compiler from
+           # explicitly linking system object files so we need to strip them
+           # from the output so that they don't get included in the library
+           # dependencies.
+           output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed'
+
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+           _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+
+           # Archives containing C++ object files must be created using
+           # "CC -Bstatic", where "CC" is the KAI C++ compiler.
+           _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs'
+           ;;
+         icpc* | ecpc* )
+           # Intel C++
+           with_gnu_ld=yes
+           # version 8.0 and above of icpc choke on multiply defined symbols
+           # if we add $predep_objects and $postdep_objects, however 7.1 and
+           # earlier do not add the objects themselves.
+           case `$CC -V 2>&1` in
+             *"Version 7."*)
+               _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
+               _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+               ;;
+             *)  # Version 8.0 or newer
+               tmp_idyn=
+               case $host_cpu in
+                 ia64*) tmp_idyn=' -i_dynamic';;
+               esac
+               _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+               _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+               ;;
+           esac
+           _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+           _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+           _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+           ;;
+          pgCC* | pgcpp*)
+            # Portland Group C++ compiler
+           case `$CC -V` in
+           *pgCC\ [[1-5]]* | *pgcpp\ [[1-5]]*)
+             _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~
+               rm -rf $tpldir~
+               $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~
+               compile_command="$compile_command `find $tpldir -name \*.o | $NL2SP`"'
+             _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~
+               rm -rf $tpldir~
+               $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~
+               $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | $NL2SP`~
+               $RANLIB $oldlib'
+             _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~
+               rm -rf $tpldir~
+               $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+               $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
+             _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~
+               rm -rf $tpldir~
+               $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+               $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
+             ;;
+           *) # Version 6 will use weak symbols
+             _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
+             _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
+             ;;
+           esac
+
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir'
+           _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+           _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+            ;;
+         cxx*)
+           # Compaq C++
+           _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
+           _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname  -o $lib ${wl}-retain-symbols-file $wl$export_symbols'
+
+           runpath_var=LD_RUN_PATH
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
+           _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+
+           # Commands to make compiler produce verbose output that lists
+           # what "hidden" libraries, object files and flags are used when
+           # linking a shared library.
+           #
+           # There doesn't appear to be a way to prevent this compiler from
+           # explicitly linking system object files so we need to strip them
+           # from the output so that they don't get included in the library
+           # dependencies.
+           output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`$ECHO "X$templist" | $Xsed -e "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed'
+           ;;
+         xl*)
+           # IBM XL 8.0 on PPC, with GNU ld
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+           _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+           _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+           if test "x$supports_anon_versioning" = xyes; then
+             _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~
+               cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+               echo "local: *; };" >> $output_objdir/$libname.ver~
+               $CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+           fi
+           ;;
+         *)
+           case `$CC -V 2>&1 | sed 5q` in
+           *Sun\ C*)
+             # Sun C++ 5.9
+             _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs'
+             _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+             _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols'
+             _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+             _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+             _LT_TAGVAR(compiler_needs_object, $1)=yes
+
+             # Not sure whether something based on
+             # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1
+             # would be better.
+             output_verbose_link_cmd='echo'
+
+             # Archives containing C++ object files must be created using
+             # "CC -xar", where "CC" is the Sun C++ compiler.  This is
+             # necessary to make sure instantiated templates are included
+             # in the archive.
+             _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs'
+             ;;
+           esac
+           ;;
+       esac
+       ;;
+
+      lynxos*)
+        # FIXME: insert proper C++ library support
+       _LT_TAGVAR(ld_shlibs, $1)=no
+       ;;
+
+      m88k*)
+        # FIXME: insert proper C++ library support
+        _LT_TAGVAR(ld_shlibs, $1)=no
+       ;;
+
+      mvs*)
+        case $cc_basename in
+          cxx*)
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+         *)
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+       esac
+       ;;
+
+      netbsd*)
+        if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
+         _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable  -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags'
+         wlarc=
+         _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+         _LT_TAGVAR(hardcode_direct, $1)=yes
+         _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+       fi
+       # Workaround some broken pre-1.5 toolchains
+       output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"'
+       ;;
+
+      *nto* | *qnx*)
+        _LT_TAGVAR(ld_shlibs, $1)=yes
+       ;;
+
+      openbsd2*)
+        # C++ shared libraries are fairly broken
+       _LT_TAGVAR(ld_shlibs, $1)=no
+       ;;
+
+      openbsd*)
+       if test -f /usr/libexec/ld.so; then
+         _LT_TAGVAR(hardcode_direct, $1)=yes
+         _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+         _LT_TAGVAR(hardcode_direct_absolute, $1)=yes
+         _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib'
+         _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+         if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+           _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib'
+           _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+           _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+         fi
+         output_verbose_link_cmd=echo
+       else
+         _LT_TAGVAR(ld_shlibs, $1)=no
+       fi
+       ;;
+
+      osf3* | osf4* | osf5*)
+        case $cc_basename in
+          KCC*)
+           # Kuck and Associates, Inc. (KAI) C++ Compiler
+
+           # KCC will only create a shared library if the output file
+           # ends with ".so" (or ".sl" for HP-UX), so rename the library
+           # to its proper name (with version) after linking.
+           _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
+
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+           _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+
+           # Archives containing C++ object files must be created using
+           # the KAI C++ compiler.
+           case $host in
+             osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;;
+             *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;;
+           esac
+           ;;
+          RCC*)
+           # Rational C++ 2.4.1
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+          cxx*)
+           case $host in
+             osf3*)
+               _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
+               _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && $ECHO "X${wl}-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+               _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+               ;;
+             *)
+               _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
+               _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+               _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~
+                 echo "-hidden">> $lib.exp~
+                 $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname ${wl}-input ${wl}$lib.exp  `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib~
+                 $RM $lib.exp'
+               _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
+               ;;
+           esac
+
+           _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+
+           # Commands to make compiler produce verbose output that lists
+           # what "hidden" libraries, object files and flags are used when
+           # linking a shared library.
+           #
+           # There doesn't appear to be a way to prevent this compiler from
+           # explicitly linking system object files so we need to strip them
+           # from the output so that they don't get included in the library
+           # dependencies.
+           output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`$ECHO "X$templist" | $Xsed -e "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; $ECHO "X$list" | $Xsed'
+           ;;
+         *)
+           if test "$GXX" = yes && test "$with_gnu_ld" = no; then
+             _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
+             case $host in
+               osf3*)
+                 _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+                 ;;
+               *)
+                 _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+                 ;;
+             esac
+
+             _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+             _LT_TAGVAR(hardcode_libdir_separator, $1)=:
+
+             # Commands to make compiler produce verbose output that lists
+             # what "hidden" libraries, object files and flags are used when
+             # linking a shared library.
+             output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"'
+
+           else
+             # FIXME: insert proper C++ library support
+             _LT_TAGVAR(ld_shlibs, $1)=no
+           fi
+           ;;
+        esac
+        ;;
+
+      psos*)
+        # FIXME: insert proper C++ library support
+        _LT_TAGVAR(ld_shlibs, $1)=no
+        ;;
+
+      sunos4*)
+        case $cc_basename in
+          CC*)
+           # Sun C++ 4.x
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+          lcc*)
+           # Lucid
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+          *)
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+        esac
+        ;;
+
+      solaris*)
+        case $cc_basename in
+          CC*)
+           # Sun C++ 4.2, 5.x and Centerline C++
+            _LT_TAGVAR(archive_cmds_need_lc,$1)=yes
+           _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs'
+           _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag}  -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+           _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+             $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+
+           _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
+           _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+           case $host_os in
+             solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
+             *)
+               # The compiler driver will combine and reorder linker options,
+               # but understands `-z linker_flag'.
+               # Supported since Solaris 2.6 (maybe 2.5.1?)
+               _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract'
+               ;;
+           esac
+           _LT_TAGVAR(link_all_deplibs, $1)=yes
+
+           output_verbose_link_cmd='echo'
+
+           # Archives containing C++ object files must be created using
+           # "CC -xar", where "CC" is the Sun C++ compiler.  This is
+           # necessary to make sure instantiated templates are included
+           # in the archive.
+           _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs'
+           ;;
+          gcx*)
+           # Green Hills C++ Compiler
+           _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+
+           # The C++ compiler must be used to create the archive.
+           _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs'
+           ;;
+          *)
+           # GNU C++ compiler with Solaris linker
+           if test "$GXX" = yes && test "$with_gnu_ld" = no; then
+             _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs'
+             if $CC --version | $GREP -v '^2\.7' > /dev/null; then
+               _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+               _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+                 $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+
+               # Commands to make compiler produce verbose output that lists
+               # what "hidden" libraries, object files and flags are used when
+               # linking a shared library.
+               output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"'
+             else
+               # g++ 2.7 appears to require `-G' NOT `-shared' on this
+               # platform.
+               _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+               _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+                 $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+
+               # Commands to make compiler produce verbose output that lists
+               # what "hidden" libraries, object files and flags are used when
+               # linking a shared library.
+               output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP "\-L"'
+             fi
+
+             _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir'
+             case $host_os in
+               solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
+               *)
+                 _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+                 ;;
+             esac
+           fi
+           ;;
+        esac
+        ;;
+
+    sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*)
+      _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+      _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+      _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+      runpath_var='LD_RUN_PATH'
+
+      case $cc_basename in
+        CC*)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+         _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       *)
+         _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+         _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+      esac
+      ;;
+
+      sysv5* | sco3.2v5* | sco5v6*)
+       # Note: We can NOT use -z defs as we might desire, because we do not
+       # link with -lc, and that would cause any symbols used from libc to
+       # always be unresolved, which means just about no library would
+       # ever link correctly.  If we're not using GNU ld we use -z text
+       # though, which does catch some bad symbols but isn't as heavy-handed
+       # as -z defs.
+       _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+       _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs'
+       _LT_TAGVAR(archive_cmds_need_lc, $1)=no
+       _LT_TAGVAR(hardcode_shlibpath_var, $1)=no
+       _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir'
+       _LT_TAGVAR(hardcode_libdir_separator, $1)=':'
+       _LT_TAGVAR(link_all_deplibs, $1)=yes
+       _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport'
+       runpath_var='LD_RUN_PATH'
+
+       case $cc_basename in
+          CC*)
+           _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+           _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+           ;;
+         *)
+           _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+           _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+           ;;
+       esac
+      ;;
+
+      tandem*)
+        case $cc_basename in
+          NCC*)
+           # NonStop-UX NCC 3.20
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+          *)
+           # FIXME: insert proper C++ library support
+           _LT_TAGVAR(ld_shlibs, $1)=no
+           ;;
+        esac
+        ;;
+
+      vxworks*)
+        # FIXME: insert proper C++ library support
+        _LT_TAGVAR(ld_shlibs, $1)=no
+        ;;
+
+      *)
+        # FIXME: insert proper C++ library support
+        _LT_TAGVAR(ld_shlibs, $1)=no
+        ;;
+    esac
+
+    AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)])
+    test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
+
+    _LT_TAGVAR(GCC, $1)="$GXX"
+    _LT_TAGVAR(LD, $1)="$LD"
+
+    ## CAVEAT EMPTOR:
+    ## There is no encapsulation within the following macros, do not change
+    ## the running order or otherwise move them around unless you know exactly
+    ## what you are doing...
+    _LT_SYS_HIDDEN_LIBDEPS($1)
+    _LT_COMPILER_PIC($1)
+    _LT_COMPILER_C_O($1)
+    _LT_COMPILER_FILE_LOCKS($1)
+    _LT_LINKER_SHLIBS($1)
+    _LT_SYS_DYNAMIC_LINKER($1)
+    _LT_LINKER_HARDCODE_LIBPATH($1)
+
+    _LT_CONFIG($1)
+  fi # test -n "$compiler"
+
+  CC=$lt_save_CC
+  LDCXX=$LD
+  LD=$lt_save_LD
+  GCC=$lt_save_GCC
+  with_gnu_ld=$lt_save_with_gnu_ld
+  lt_cv_path_LDCXX=$lt_cv_path_LD
+  lt_cv_path_LD=$lt_save_path_LD
+  lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld
+  lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld
+fi # test "$_lt_caught_CXX_error" != yes
+
+AC_LANG_POP
+])# _LT_LANG_CXX_CONFIG
+
+
+# _LT_SYS_HIDDEN_LIBDEPS([TAGNAME])
+# ---------------------------------
+# Figure out "hidden" library dependencies from verbose
+# compiler output when linking a shared library.
+# Parse the compiler output and extract the necessary
+# objects, libraries and library flags.
+m4_defun([_LT_SYS_HIDDEN_LIBDEPS],
+[m4_require([_LT_FILEUTILS_DEFAULTS])dnl
+# Dependencies to place before and after the object being linked:
+_LT_TAGVAR(predep_objects, $1)=
+_LT_TAGVAR(postdep_objects, $1)=
+_LT_TAGVAR(predeps, $1)=
+_LT_TAGVAR(postdeps, $1)=
+_LT_TAGVAR(compiler_lib_search_path, $1)=
+
+dnl we can't use the lt_simple_compile_test_code here,
+dnl because it contains code intended for an executable,
+dnl not a library.  It's possible we should let each
+dnl tag define a new lt_????_link_test_code variable,
+dnl but it's only used here...
+m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF
+int a;
+void foo (void) { a = 0; }
+_LT_EOF
+], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF
+class Foo
+{
+public:
+  Foo (void) { a = 0; }
+private:
+  int a;
+};
+_LT_EOF
+], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF
+      subroutine foo
+      implicit none
+      integer*4 a
+      a=0
+      return
+      end
+_LT_EOF
+], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF
+      subroutine foo
+      implicit none
+      integer a
+      a=0
+      return
+      end
+_LT_EOF
+], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF
+public class foo {
+  private int a;
+  public void bar (void) {
+    a = 0;
+  }
+};
+_LT_EOF
+])
+dnl Parse the compiler output and extract the necessary
+dnl objects, libraries and library flags.
+if AC_TRY_EVAL(ac_compile); then
+  # Parse the compiler output and extract the necessary
+  # objects, libraries and library flags.
+
+  # Sentinel used to keep track of whether or not we are before
+  # the conftest object file.
+  pre_test_object_deps_done=no
+
+  for p in `eval "$output_verbose_link_cmd"`; do
+    case $p in
+
+    -L* | -R* | -l*)
+       # Some compilers place space between "-{L,R}" and the path.
+       # Remove the space.
+       if test $p = "-L" ||
+          test $p = "-R"; then
+        prev=$p
+        continue
+       else
+        prev=
+       fi
+
+       if test "$pre_test_object_deps_done" = no; then
+        case $p in
+        -L* | -R*)
+          # Internal compiler library paths should come after those
+          # provided the user.  The postdeps already come after the
+          # user supplied libs so there is no need to process them.
+          if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then
+            _LT_TAGVAR(compiler_lib_search_path, $1)="${prev}${p}"
+          else
+            _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} ${prev}${p}"
+          fi
+          ;;
+        # The "-l" case would never come before the object being
+        # linked, so don't bother handling this case.
+        esac
+       else
+        if test -z "$_LT_TAGVAR(postdeps, $1)"; then
+          _LT_TAGVAR(postdeps, $1)="${prev}${p}"
+        else
+          _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} ${prev}${p}"
+        fi
+       fi
+       ;;
+
+    *.$objext)
+       # This assumes that the test object file only shows up
+       # once in the compiler output.
+       if test "$p" = "conftest.$objext"; then
+        pre_test_object_deps_done=yes
+        continue
+       fi
+
+       if test "$pre_test_object_deps_done" = no; then
+        if test -z "$_LT_TAGVAR(predep_objects, $1)"; then
+          _LT_TAGVAR(predep_objects, $1)="$p"
+        else
+          _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p"
+        fi
+       else
+        if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then
+          _LT_TAGVAR(postdep_objects, $1)="$p"
+        else
+          _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p"
+        fi
+       fi
+       ;;
+
+    *) ;; # Ignore the rest.
+
+    esac
+  done
+
+  # Clean up.
+  rm -f a.out a.exe
+else
+  echo "libtool.m4: error: problem compiling $1 test program"
+fi
+
+$RM -f confest.$objext
+
+# PORTME: override above test on systems where it is broken
+m4_if([$1], [CXX],
+[case $host_os in
+interix[[3-9]]*)
+  # Interix 3.5 installs completely hosed .la files for C++, so rather than
+  # hack all around it, let's just trust "g++" to DTRT.
+  _LT_TAGVAR(predep_objects,$1)=
+  _LT_TAGVAR(postdep_objects,$1)=
+  _LT_TAGVAR(postdeps,$1)=
+  ;;
+
+linux*)
+  case `$CC -V 2>&1 | sed 5q` in
+  *Sun\ C*)
+    # Sun C++ 5.9
+
+    # The more standards-conforming stlport4 library is
+    # incompatible with the Cstd library. Avoid specifying
+    # it if it's in CXXFLAGS. Ignore libCrun as
+    # -library=stlport4 depends on it.
+    case " $CXX $CXXFLAGS " in
+    *" -library=stlport4 "*)
+      solaris_use_stlport4=yes
+      ;;
+    esac
+
+    if test "$solaris_use_stlport4" != yes; then
+      _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun'
+    fi
+    ;;
+  esac
+  ;;
+
+solaris*)
+  case $cc_basename in
+  CC*)
+    # The more standards-conforming stlport4 library is
+    # incompatible with the Cstd library. Avoid specifying
+    # it if it's in CXXFLAGS. Ignore libCrun as
+    # -library=stlport4 depends on it.
+    case " $CXX $CXXFLAGS " in
+    *" -library=stlport4 "*)
+      solaris_use_stlport4=yes
+      ;;
+    esac
+
+    # Adding this requires a known-good setup of shared libraries for
+    # Sun compiler versions before 5.6, else PIC objects from an old
+    # archive will be linked into the output, leading to subtle bugs.
+    if test "$solaris_use_stlport4" != yes; then
+      _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun'
+    fi
+    ;;
+  esac
+  ;;
+esac
+])
+
+case " $_LT_TAGVAR(postdeps, $1) " in
+*" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;;
+esac
+ _LT_TAGVAR(compiler_lib_search_dirs, $1)=
+if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then
+ _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | ${SED} -e 's! -L! !g' -e 's!^ !!'`
+fi
+_LT_TAGDECL([], [compiler_lib_search_dirs], [1],
+    [The directories searched by this compiler when creating a shared library])
+_LT_TAGDECL([], [predep_objects], [1],
+    [Dependencies to place before and after the objects being linked to
+    create a shared library])
+_LT_TAGDECL([], [postdep_objects], [1])
+_LT_TAGDECL([], [predeps], [1])
+_LT_TAGDECL([], [postdeps], [1])
+_LT_TAGDECL([], [compiler_lib_search_path], [1],
+    [The library search path used internally by the compiler when linking
+    a shared library])
+])# _LT_SYS_HIDDEN_LIBDEPS
+
+
+# _LT_PROG_F77
+# ------------
+# Since AC_PROG_F77 is broken, in that it returns the empty string
+# if there is no fortran compiler, we have our own version here.
+m4_defun([_LT_PROG_F77],
+[
+pushdef([AC_MSG_ERROR], [_lt_disable_F77=yes])
+AC_PROG_F77
+if test -z "$F77" || test "X$F77" = "Xno"; then
+  _lt_disable_F77=yes
+fi
+popdef([AC_MSG_ERROR])
+])# _LT_PROG_F77
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([_LT_PROG_F77], [])
+
+
+# _LT_LANG_F77_CONFIG([TAG])
+# --------------------------
+# Ensure that the configuration variables for a Fortran 77 compiler are
+# suitably defined.  These variables are subsequently used by _LT_CONFIG
+# to write the compiler configuration to `libtool'.
+m4_defun([_LT_LANG_F77_CONFIG],
+[AC_REQUIRE([_LT_PROG_F77])dnl
+AC_LANG_PUSH(Fortran 77)
+
+_LT_TAGVAR(archive_cmds_need_lc, $1)=no
+_LT_TAGVAR(allow_undefined_flag, $1)=
+_LT_TAGVAR(always_export_symbols, $1)=no
+_LT_TAGVAR(archive_expsym_cmds, $1)=
+_LT_TAGVAR(export_dynamic_flag_spec, $1)=
+_LT_TAGVAR(hardcode_direct, $1)=no
+_LT_TAGVAR(hardcode_direct_absolute, $1)=no
+_LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
+_LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)=
+_LT_TAGVAR(hardcode_libdir_separator, $1)=
+_LT_TAGVAR(hardcode_minus_L, $1)=no
+_LT_TAGVAR(hardcode_automatic, $1)=no
+_LT_TAGVAR(inherit_rpath, $1)=no
+_LT_TAGVAR(module_cmds, $1)=
+_LT_TAGVAR(module_expsym_cmds, $1)=
+_LT_TAGVAR(link_all_deplibs, $1)=unknown
+_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds
+_LT_TAGVAR(no_undefined_flag, $1)=
+_LT_TAGVAR(whole_archive_flag_spec, $1)=
+_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no
+
+# Source file extension for f77 test sources.
+ac_ext=f
+
+# Object file extension for compiled f77 test sources.
+objext=o
+_LT_TAGVAR(objext, $1)=$objext
+
+# No sense in running all these tests if we already determined that
+# the F77 compiler isn't working.  Some variables (like enable_shared)
+# are currently assumed to apply to all compilers on this platform,
+# and will be corrupted by setting them based on a non-working compiler.
+if test "$_lt_disable_F77" != yes; then
+  # Code to be used in simple compile tests
+  lt_simple_compile_test_code="\
+      subroutine t
+      return
+      end
+"
+
+  # Code to be used in simple link tests
+  lt_simple_link_test_code="\
+      program t
+      end
+"
+
+  # ltmain only uses $CC for tagged configurations so make sure $CC is set.
+  _LT_TAG_COMPILER
+
+  # save warnings/boilerplate of simple test code
+  _LT_COMPILER_BOILERPLATE
+  _LT_LINKER_BOILERPLATE
+
+  # Allow CC to be a program name with arguments.
+  lt_save_CC="$CC"
+  lt_save_GCC=$GCC
+  CC=${F77-"f77"}
+  compiler=$CC
+  _LT_TAGVAR(compiler, $1)=$CC
+  _LT_CC_BASENAME([$compiler])
+  GCC=$G77
+  if test -n "$compiler"; then
+    AC_MSG_CHECKING([if libtool supports shared libraries])
+    AC_MSG_RESULT([$can_build_shared])
+
+    AC_MSG_CHECKING([whether to build shared libraries])
+    test "$can_build_shared" = "no" && enable_shared=no
+
+    # On AIX, shared libraries and static libraries use the same namespace, and
+    # are all built from PIC.
+    case $host_os in
+      aix3*)
+        test "$enable_shared" = yes && enable_static=no
+        if test -n "$RANLIB"; then
+          archive_cmds="$archive_cmds~\$RANLIB \$lib"
+          postinstall_cmds='$RANLIB $lib'
+        fi
+        ;;
+      aix[[4-9]]*)
+       if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
+         test "$enable_shared" = yes && enable_static=no
+       fi
+        ;;
+    esac
+    AC_MSG_RESULT([$enable_shared])
+
+    AC_MSG_CHECKING([whether to build static libraries])
+    # Make sure either enable_shared or enable_static is yes.
+    test "$enable_shared" = yes || enable_static=yes
+    AC_MSG_RESULT([$enable_static])
+
+    _LT_TAGVAR(GCC, $1)="$G77"
+    _LT_TAGVAR(LD, $1)="$LD"
+
+    ## CAVEAT EMPTOR:
+    ## There is no encapsulation within the following macros, do not change
+    ## the running order or otherwise move them around unless you know exactly
+    ## what you are doing...
+    _LT_COMPILER_PIC($1)
+    _LT_COMPILER_C_O($1)
+    _LT_COMPILER_FILE_LOCKS($1)
+    _LT_LINKER_SHLIBS($1)
+    _LT_SYS_DYNAMIC_LINKER($1)
+    _LT_LINKER_HARDCODE_LIBPATH($1)
+
+    _LT_CONFIG($1)
+  fi # test -n "$compiler"
+
+  GCC=$lt_save_GCC
+  CC="$lt_save_CC"
+fi # test "$_lt_disable_F77" != yes
+
+AC_LANG_POP
+])# _LT_LANG_F77_CONFIG
+
+
+# _LT_PROG_FC
+# -----------
+# Since AC_PROG_FC is broken, in that it returns the empty string
+# if there is no fortran compiler, we have our own version here.
+m4_defun([_LT_PROG_FC],
+[
+pushdef([AC_MSG_ERROR], [_lt_disable_FC=yes])
+AC_PROG_FC
+if test -z "$FC" || test "X$FC" = "Xno"; then
+  _lt_disable_FC=yes
+fi
+popdef([AC_MSG_ERROR])
+])# _LT_PROG_FC
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([_LT_PROG_FC], [])
+
+
+# _LT_LANG_FC_CONFIG([TAG])
+# -------------------------
+# Ensure that the configuration variables for a Fortran compiler are
+# suitably defined.  These variables are subsequently used by _LT_CONFIG
+# to write the compiler configuration to `libtool'.
+m4_defun([_LT_LANG_FC_CONFIG],
+[AC_REQUIRE([_LT_PROG_FC])dnl
+AC_LANG_PUSH(Fortran)
+
+_LT_TAGVAR(archive_cmds_need_lc, $1)=no
+_LT_TAGVAR(allow_undefined_flag, $1)=
+_LT_TAGVAR(always_export_symbols, $1)=no
+_LT_TAGVAR(archive_expsym_cmds, $1)=
+_LT_TAGVAR(export_dynamic_flag_spec, $1)=
+_LT_TAGVAR(hardcode_direct, $1)=no
+_LT_TAGVAR(hardcode_direct_absolute, $1)=no
+_LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
+_LT_TAGVAR(hardcode_libdir_flag_spec_ld, $1)=
+_LT_TAGVAR(hardcode_libdir_separator, $1)=
+_LT_TAGVAR(hardcode_minus_L, $1)=no
+_LT_TAGVAR(hardcode_automatic, $1)=no
+_LT_TAGVAR(inherit_rpath, $1)=no
+_LT_TAGVAR(module_cmds, $1)=
+_LT_TAGVAR(module_expsym_cmds, $1)=
+_LT_TAGVAR(link_all_deplibs, $1)=unknown
+_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds
+_LT_TAGVAR(no_undefined_flag, $1)=
+_LT_TAGVAR(whole_archive_flag_spec, $1)=
+_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no
+
+# Source file extension for fc test sources.
+ac_ext=${ac_fc_srcext-f}
+
+# Object file extension for compiled fc test sources.
+objext=o
+_LT_TAGVAR(objext, $1)=$objext
+
+# No sense in running all these tests if we already determined that
+# the FC compiler isn't working.  Some variables (like enable_shared)
+# are currently assumed to apply to all compilers on this platform,
+# and will be corrupted by setting them based on a non-working compiler.
+if test "$_lt_disable_FC" != yes; then
+  # Code to be used in simple compile tests
+  lt_simple_compile_test_code="\
+      subroutine t
+      return
+      end
+"
+
+  # Code to be used in simple link tests
+  lt_simple_link_test_code="\
+      program t
+      end
+"
+
+  # ltmain only uses $CC for tagged configurations so make sure $CC is set.
+  _LT_TAG_COMPILER
+
+  # save warnings/boilerplate of simple test code
+  _LT_COMPILER_BOILERPLATE
+  _LT_LINKER_BOILERPLATE
+
+  # Allow CC to be a program name with arguments.
+  lt_save_CC="$CC"
+  lt_save_GCC=$GCC
+  CC=${FC-"f95"}
+  compiler=$CC
+  GCC=$ac_cv_fc_compiler_gnu
+
+  _LT_TAGVAR(compiler, $1)=$CC
+  _LT_CC_BASENAME([$compiler])
+
+  if test -n "$compiler"; then
+    AC_MSG_CHECKING([if libtool supports shared libraries])
+    AC_MSG_RESULT([$can_build_shared])
+
+    AC_MSG_CHECKING([whether to build shared libraries])
+    test "$can_build_shared" = "no" && enable_shared=no
+
+    # On AIX, shared libraries and static libraries use the same namespace, and
+    # are all built from PIC.
+    case $host_os in
+      aix3*)
+        test "$enable_shared" = yes && enable_static=no
+        if test -n "$RANLIB"; then
+          archive_cmds="$archive_cmds~\$RANLIB \$lib"
+          postinstall_cmds='$RANLIB $lib'
+        fi
+        ;;
+      aix[[4-9]]*)
+       if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
+         test "$enable_shared" = yes && enable_static=no
+       fi
+        ;;
+    esac
+    AC_MSG_RESULT([$enable_shared])
+
+    AC_MSG_CHECKING([whether to build static libraries])
+    # Make sure either enable_shared or enable_static is yes.
+    test "$enable_shared" = yes || enable_static=yes
+    AC_MSG_RESULT([$enable_static])
+
+    _LT_TAGVAR(GCC, $1)="$ac_cv_fc_compiler_gnu"
+    _LT_TAGVAR(LD, $1)="$LD"
+
+    ## CAVEAT EMPTOR:
+    ## There is no encapsulation within the following macros, do not change
+    ## the running order or otherwise move them around unless you know exactly
+    ## what you are doing...
+    _LT_SYS_HIDDEN_LIBDEPS($1)
+    _LT_COMPILER_PIC($1)
+    _LT_COMPILER_C_O($1)
+    _LT_COMPILER_FILE_LOCKS($1)
+    _LT_LINKER_SHLIBS($1)
+    _LT_SYS_DYNAMIC_LINKER($1)
+    _LT_LINKER_HARDCODE_LIBPATH($1)
+
+    _LT_CONFIG($1)
+  fi # test -n "$compiler"
+
+  GCC=$lt_save_GCC
+  CC="$lt_save_CC"
+fi # test "$_lt_disable_FC" != yes
+
+AC_LANG_POP
+])# _LT_LANG_FC_CONFIG
+
+
+# _LT_LANG_GCJ_CONFIG([TAG])
+# --------------------------
+# Ensure that the configuration variables for the GNU Java Compiler compiler
+# are suitably defined.  These variables are subsequently used by _LT_CONFIG
+# to write the compiler configuration to `libtool'.
+m4_defun([_LT_LANG_GCJ_CONFIG],
+[AC_REQUIRE([LT_PROG_GCJ])dnl
+AC_LANG_SAVE
+
+# Source file extension for Java test sources.
+ac_ext=java
+
+# Object file extension for compiled Java test sources.
+objext=o
+_LT_TAGVAR(objext, $1)=$objext
+
+# Code to be used in simple compile tests
+lt_simple_compile_test_code="class foo {}"
+
+# Code to be used in simple link tests
+lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }'
+
+# ltmain only uses $CC for tagged configurations so make sure $CC is set.
+_LT_TAG_COMPILER
+
+# save warnings/boilerplate of simple test code
+_LT_COMPILER_BOILERPLATE
+_LT_LINKER_BOILERPLATE
+
+# Allow CC to be a program name with arguments.
+lt_save_CC="$CC"
+lt_save_GCC=$GCC
+GCC=yes
+CC=${GCJ-"gcj"}
+compiler=$CC
+_LT_TAGVAR(compiler, $1)=$CC
+_LT_TAGVAR(LD, $1)="$LD"
+_LT_CC_BASENAME([$compiler])
+
+# GCJ did not exist at the time GCC didn't implicitly link libc in.
+_LT_TAGVAR(archive_cmds_need_lc, $1)=no
+
+_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds
+
+if test -n "$compiler"; then
+  _LT_COMPILER_NO_RTTI($1)
+  _LT_COMPILER_PIC($1)
+  _LT_COMPILER_C_O($1)
+  _LT_COMPILER_FILE_LOCKS($1)
+  _LT_LINKER_SHLIBS($1)
+  _LT_LINKER_HARDCODE_LIBPATH($1)
+
+  _LT_CONFIG($1)
+fi
+
+AC_LANG_RESTORE
+
+GCC=$lt_save_GCC
+CC="$lt_save_CC"
+])# _LT_LANG_GCJ_CONFIG
+
+
+# _LT_LANG_RC_CONFIG([TAG])
+# -------------------------
+# Ensure that the configuration variables for the Windows resource compiler
+# are suitably defined.  These variables are subsequently used by _LT_CONFIG
+# to write the compiler configuration to `libtool'.
+m4_defun([_LT_LANG_RC_CONFIG],
+[AC_REQUIRE([LT_PROG_RC])dnl
+AC_LANG_SAVE
+
+# Source file extension for RC test sources.
+ac_ext=rc
+
+# Object file extension for compiled RC test sources.
+objext=o
+_LT_TAGVAR(objext, $1)=$objext
+
+# Code to be used in simple compile tests
+lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }'
+
+# Code to be used in simple link tests
+lt_simple_link_test_code="$lt_simple_compile_test_code"
+
+# ltmain only uses $CC for tagged configurations so make sure $CC is set.
+_LT_TAG_COMPILER
+
+# save warnings/boilerplate of simple test code
+_LT_COMPILER_BOILERPLATE
+_LT_LINKER_BOILERPLATE
+
+# Allow CC to be a program name with arguments.
+lt_save_CC="$CC"
+lt_save_GCC=$GCC
+GCC=
+CC=${RC-"windres"}
+compiler=$CC
+_LT_TAGVAR(compiler, $1)=$CC
+_LT_CC_BASENAME([$compiler])
+_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes
+
+if test -n "$compiler"; then
+  :
+  _LT_CONFIG($1)
+fi
+
+GCC=$lt_save_GCC
+AC_LANG_RESTORE
+CC="$lt_save_CC"
+])# _LT_LANG_RC_CONFIG
+
+
+# LT_PROG_GCJ
+# -----------
+AC_DEFUN([LT_PROG_GCJ],
+[m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ],
+  [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ],
+    [AC_CHECK_TOOL(GCJ, gcj,)
+      test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2"
+      AC_SUBST(GCJFLAGS)])])[]dnl
+])
+
+# Old name:
+AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([LT_AC_PROG_GCJ], [])
+
+
+# LT_PROG_RC
+# ----------
+AC_DEFUN([LT_PROG_RC],
+[AC_CHECK_TOOL(RC, windres,)
+])
+
+# Old name:
+AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([LT_AC_PROG_RC], [])
+
+
+# _LT_DECL_EGREP
+# --------------
+# If we don't have a new enough Autoconf to choose the best grep
+# available, choose the one first in the user's PATH.
+m4_defun([_LT_DECL_EGREP],
+[AC_REQUIRE([AC_PROG_EGREP])dnl
+AC_REQUIRE([AC_PROG_FGREP])dnl
+test -z "$GREP" && GREP=grep
+_LT_DECL([], [GREP], [1], [A grep program that handles long lines])
+_LT_DECL([], [EGREP], [1], [An ERE matcher])
+_LT_DECL([], [FGREP], [1], [A literal string matcher])
+dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too
+AC_SUBST([GREP])
+])
+
+
+# _LT_DECL_OBJDUMP
+# --------------
+# If we don't have a new enough Autoconf to choose the best objdump
+# available, choose the one first in the user's PATH.
+m4_defun([_LT_DECL_OBJDUMP],
+[AC_CHECK_TOOL(OBJDUMP, objdump, false)
+test -z "$OBJDUMP" && OBJDUMP=objdump
+_LT_DECL([], [OBJDUMP], [1], [An object symbol dumper])
+AC_SUBST([OBJDUMP])
+])
+
+
+# _LT_DECL_SED
+# ------------
+# Check for a fully-functional sed program, that truncates
+# as few characters as possible.  Prefer GNU sed if found.
+m4_defun([_LT_DECL_SED],
+[AC_PROG_SED
+test -z "$SED" && SED=sed
+Xsed="$SED -e 1s/^X//"
+_LT_DECL([], [SED], [1], [A sed program that does not truncate output])
+_LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"],
+    [Sed that helps us avoid accidentally triggering echo(1) options like -n])
+])# _LT_DECL_SED
+
+m4_ifndef([AC_PROG_SED], [
+# NOTE: This macro has been submitted for inclusion into   #
+#  GNU Autoconf as AC_PROG_SED.  When it is available in   #
+#  a released version of Autoconf we should remove this    #
+#  macro and use it instead.                               #
+
+m4_defun([AC_PROG_SED],
+[AC_MSG_CHECKING([for a sed that does not truncate output])
+AC_CACHE_VAL(lt_cv_path_SED,
+[# Loop through the user's path and test for sed and gsed.
+# Then use that list of sed's as ones to test for truncation.
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for lt_ac_prog in sed gsed; do
+    for ac_exec_ext in '' $ac_executable_extensions; do
+      if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then
+        lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext"
+      fi
+    done
+  done
+done
+IFS=$as_save_IFS
+lt_ac_max=0
+lt_ac_count=0
+# Add /usr/xpg4/bin/sed as it is typically found on Solaris
+# along with /bin/sed that truncates output.
+for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do
+  test ! -f $lt_ac_sed && continue
+  cat /dev/null > conftest.in
+  lt_ac_count=0
+  echo $ECHO_N "0123456789$ECHO_C" >conftest.in
+  # Check for GNU sed and select it if it is found.
+  if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then
+    lt_cv_path_SED=$lt_ac_sed
+    break
+  fi
+  while true; do
+    cat conftest.in conftest.in >conftest.tmp
+    mv conftest.tmp conftest.in
+    cp conftest.in conftest.nl
+    echo >>conftest.nl
+    $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break
+    cmp -s conftest.out conftest.nl || break
+    # 10000 chars as input seems more than enough
+    test $lt_ac_count -gt 10 && break
+    lt_ac_count=`expr $lt_ac_count + 1`
+    if test $lt_ac_count -gt $lt_ac_max; then
+      lt_ac_max=$lt_ac_count
+      lt_cv_path_SED=$lt_ac_sed
+    fi
+  done
+done
+])
+SED=$lt_cv_path_SED
+AC_SUBST([SED])
+AC_MSG_RESULT([$SED])
+])#AC_PROG_SED
+])#m4_ifndef
+
+# Old name:
+AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([LT_AC_PROG_SED], [])
+
+
+# _LT_CHECK_SHELL_FEATURES
+# ------------------------
+# Find out whether the shell is Bourne or XSI compatible,
+# or has some other useful features.
+m4_defun([_LT_CHECK_SHELL_FEATURES],
+[AC_MSG_CHECKING([whether the shell understands some XSI constructs])
+# Try some XSI features
+xsi_shell=no
+( _lt_dummy="a/b/c"
+  test "${_lt_dummy##*/},${_lt_dummy%/*},"${_lt_dummy%"$_lt_dummy"}, \
+      = c,a/b,, \
+    && eval 'test $(( 1 + 1 )) -eq 2 \
+    && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \
+  && xsi_shell=yes
+AC_MSG_RESULT([$xsi_shell])
+_LT_CONFIG_LIBTOOL_INIT([xsi_shell='$xsi_shell'])
+
+AC_MSG_CHECKING([whether the shell understands "+="])
+lt_shell_append=no
+( foo=bar; set foo baz; eval "$[1]+=\$[2]" && test "$foo" = barbaz ) \
+    >/dev/null 2>&1 \
+  && lt_shell_append=yes
+AC_MSG_RESULT([$lt_shell_append])
+_LT_CONFIG_LIBTOOL_INIT([lt_shell_append='$lt_shell_append'])
+
+if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
+  lt_unset=unset
+else
+  lt_unset=false
+fi
+_LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl
+
+# test EBCDIC or ASCII
+case `echo X|tr X '\101'` in
+ A) # ASCII based system
+    # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr
+  lt_SP2NL='tr \040 \012'
+  lt_NL2SP='tr \015\012 \040\040'
+  ;;
+ *) # EBCDIC based system
+  lt_SP2NL='tr \100 \n'
+  lt_NL2SP='tr \r\n \100\100'
+  ;;
+esac
+_LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl
+_LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl
+])# _LT_CHECK_SHELL_FEATURES
+
+
+# _LT_PROG_XSI_SHELLFNS
+# ---------------------
+# Bourne and XSI compatible variants of some useful shell functions.
+m4_defun([_LT_PROG_XSI_SHELLFNS],
+[case $xsi_shell in
+  yes)
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_dirname file append nondir_replacement
+# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
+# otherwise set result to NONDIR_REPLACEMENT.
+func_dirname ()
+{
+  case ${1} in
+    */*) func_dirname_result="${1%/*}${2}" ;;
+    *  ) func_dirname_result="${3}" ;;
+  esac
+}
+
+# func_basename file
+func_basename ()
+{
+  func_basename_result="${1##*/}"
+}
+
+# func_dirname_and_basename file append nondir_replacement
+# perform func_basename and func_dirname in a single function
+# call:
+#   dirname:  Compute the dirname of FILE.  If nonempty,
+#             add APPEND to the result, otherwise set result
+#             to NONDIR_REPLACEMENT.
+#             value returned in "$func_dirname_result"
+#   basename: Compute filename of FILE.
+#             value retuned in "$func_basename_result"
+# Implementation must be kept synchronized with func_dirname
+# and func_basename. For efficiency, we do not delegate to
+# those functions but instead duplicate the functionality here.
+func_dirname_and_basename ()
+{
+  case ${1} in
+    */*) func_dirname_result="${1%/*}${2}" ;;
+    *  ) func_dirname_result="${3}" ;;
+  esac
+  func_basename_result="${1##*/}"
+}
+
+# func_stripname prefix suffix name
+# strip PREFIX and SUFFIX off of NAME.
+# PREFIX and SUFFIX must not contain globbing or regex special
+# characters, hashes, percent signs, but SUFFIX may contain a leading
+# dot (in which case that matches only a dot).
+func_stripname ()
+{
+  # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
+  # positional parameters, so assign one to ordinary parameter first.
+  func_stripname_result=${3}
+  func_stripname_result=${func_stripname_result#"${1}"}
+  func_stripname_result=${func_stripname_result%"${2}"}
+}
+
+# func_opt_split
+func_opt_split ()
+{
+  func_opt_split_opt=${1%%=*}
+  func_opt_split_arg=${1#*=}
+}
+
+# func_lo2o object
+func_lo2o ()
+{
+  case ${1} in
+    *.lo) func_lo2o_result=${1%.lo}.${objext} ;;
+    *)    func_lo2o_result=${1} ;;
+  esac
+}
+
+# func_xform libobj-or-source
+func_xform ()
+{
+  func_xform_result=${1%.*}.lo
+}
+
+# func_arith arithmetic-term...
+func_arith ()
+{
+  func_arith_result=$(( $[*] ))
+}
+
+# func_len string
+# STRING may not start with a hyphen.
+func_len ()
+{
+  func_len_result=${#1}
+}
+
+_LT_EOF
+    ;;
+  *) # Bourne compatible functions.
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_dirname file append nondir_replacement
+# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
+# otherwise set result to NONDIR_REPLACEMENT.
+func_dirname ()
+{
+  # Extract subdirectory from the argument.
+  func_dirname_result=`$ECHO "X${1}" | $Xsed -e "$dirname"`
+  if test "X$func_dirname_result" = "X${1}"; then
+    func_dirname_result="${3}"
+  else
+    func_dirname_result="$func_dirname_result${2}"
+  fi
+}
+
+# func_basename file
+func_basename ()
+{
+  func_basename_result=`$ECHO "X${1}" | $Xsed -e "$basename"`
+}
+
+dnl func_dirname_and_basename
+dnl A portable version of this function is already defined in general.m4sh
+dnl so there is no need for it here.
+
+# func_stripname prefix suffix name
+# strip PREFIX and SUFFIX off of NAME.
+# PREFIX and SUFFIX must not contain globbing or regex special
+# characters, hashes, percent signs, but SUFFIX may contain a leading
+# dot (in which case that matches only a dot).
+# func_strip_suffix prefix name
+func_stripname ()
+{
+  case ${2} in
+    .*) func_stripname_result=`$ECHO "X${3}" \
+           | $Xsed -e "s%^${1}%%" -e "s%\\\\${2}\$%%"`;;
+    *)  func_stripname_result=`$ECHO "X${3}" \
+           | $Xsed -e "s%^${1}%%" -e "s%${2}\$%%"`;;
+  esac
+}
+
+# sed scripts:
+my_sed_long_opt='1s/^\(-[[^=]]*\)=.*/\1/;q'
+my_sed_long_arg='1s/^-[[^=]]*=//'
+
+# func_opt_split
+func_opt_split ()
+{
+  func_opt_split_opt=`$ECHO "X${1}" | $Xsed -e "$my_sed_long_opt"`
+  func_opt_split_arg=`$ECHO "X${1}" | $Xsed -e "$my_sed_long_arg"`
+}
+
+# func_lo2o object
+func_lo2o ()
+{
+  func_lo2o_result=`$ECHO "X${1}" | $Xsed -e "$lo2o"`
+}
+
+# func_xform libobj-or-source
+func_xform ()
+{
+  func_xform_result=`$ECHO "X${1}" | $Xsed -e 's/\.[[^.]]*$/.lo/'`
+}
+
+# func_arith arithmetic-term...
+func_arith ()
+{
+  func_arith_result=`expr "$[@]"`
+}
+
+# func_len string
+# STRING may not start with a hyphen.
+func_len ()
+{
+  func_len_result=`expr "$[1]" : ".*" 2>/dev/null || echo $max_cmd_len`
+}
+
+_LT_EOF
+esac
+
+case $lt_shell_append in
+  yes)
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_append var value
+# Append VALUE to the end of shell variable VAR.
+func_append ()
+{
+  eval "$[1]+=\$[2]"
+}
+_LT_EOF
+    ;;
+  *)
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_append var value
+# Append VALUE to the end of shell variable VAR.
+func_append ()
+{
+  eval "$[1]=\$$[1]\$[2]"
+}
+
+_LT_EOF
+    ;;
+  esac
+])
+
+# ltdl.m4 - Configure ltdl for the target system. -*-Autoconf-*-
+#
+#   Copyright (C) 1999-2006, 2007, 2008 Free Software Foundation, Inc.
+#   Written by Thomas Tanner, 1999
+#
+# This file is free software; the Free Software Foundation gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+
+# serial 17 LTDL_INIT
+
+# LT_CONFIG_LTDL_DIR(DIRECTORY, [LTDL-MODE])
+# ------------------------------------------
+# DIRECTORY contains the libltdl sources.  It is okay to call this
+# function multiple times, as long as the same DIRECTORY is always given.
+AC_DEFUN([LT_CONFIG_LTDL_DIR],
+[AC_BEFORE([$0], [LTDL_INIT])
+_$0($*)
+])# LT_CONFIG_LTDL_DIR
+
+# We break this out into a separate macro, so that we can call it safely
+# internally without being caught accidentally by the sed scan in libtoolize.
+m4_defun([_LT_CONFIG_LTDL_DIR],
+[dnl remove trailing slashes
+m4_pushdef([_ARG_DIR], m4_bpatsubst([$1], [/*$]))
+m4_case(_LTDL_DIR,
+       [], [dnl only set lt_ltdl_dir if _ARG_DIR is not simply `.'
+            m4_if(_ARG_DIR, [.],
+                    [],
+                [m4_define([_LTDL_DIR], _ARG_DIR)
+                 _LT_SHELL_INIT([lt_ltdl_dir=']_ARG_DIR['])])],
+    [m4_if(_ARG_DIR, _LTDL_DIR,
+           [],
+       [m4_fatal([multiple libltdl directories: `]_LTDL_DIR[', `]_ARG_DIR['])])])
+m4_popdef([_ARG_DIR])
+])# _LT_CONFIG_LTDL_DIR
+
+# Initialise:
+m4_define([_LTDL_DIR], [])
+
+
+# _LT_BUILD_PREFIX
+# ----------------
+# If Autoconf is new enough, expand to `${top_build_prefix}', otherwise
+# to `${top_builddir}/'.
+m4_define([_LT_BUILD_PREFIX],
+[m4_ifdef([AC_AUTOCONF_VERSION],
+   [m4_if(m4_version_compare(m4_defn([AC_AUTOCONF_VERSION]), [2.62]),
+         [-1], [m4_ifdef([_AC_HAVE_TOP_BUILD_PREFIX],
+                         [${top_build_prefix}],
+                         [${top_builddir}/])],
+         [${top_build_prefix}])],
+   [${top_builddir}/])[]dnl
+])
+
+
+# LTDL_CONVENIENCE
+# ----------------
+# sets LIBLTDL to the link flags for the libltdl convenience library and
+# LTDLINCL to the include flags for the libltdl header and adds
+# --enable-ltdl-convenience to the configure arguments.  Note that
+# AC_CONFIG_SUBDIRS is not called here.  LIBLTDL will be prefixed with
+# '${top_build_prefix}' if available, otherwise with '${top_builddir}/',
+# and LTDLINCL will be prefixed with '${top_srcdir}/' (note the single
+# quotes!).  If your package is not flat and you're not using automake,
+# define top_build_prefix, top_builddir, and top_srcdir appropriately
+# in your Makefiles.
+AC_DEFUN([LTDL_CONVENIENCE],
+[AC_BEFORE([$0], [LTDL_INIT])dnl
+dnl Although the argument is deprecated and no longer documented,
+dnl LTDL_CONVENIENCE used to take a DIRECTORY orgument, if we have one
+dnl here make sure it is the same as any other declaration of libltdl's
+dnl location!  This also ensures lt_ltdl_dir is set when configure.ac is
+dnl not yet using an explicit LT_CONFIG_LTDL_DIR.
+m4_ifval([$1], [_LT_CONFIG_LTDL_DIR([$1])])dnl
+_$0()
+])# LTDL_CONVENIENCE
+
+# AC_LIBLTDL_CONVENIENCE accepted a directory argument in older libtools,
+# now we have LT_CONFIG_LTDL_DIR:
+AU_DEFUN([AC_LIBLTDL_CONVENIENCE],
+[_LT_CONFIG_LTDL_DIR([m4_default([$1], [libltdl])])
+_LTDL_CONVENIENCE])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBLTDL_CONVENIENCE], [])
+
+
+# _LTDL_CONVENIENCE
+# -----------------
+# Code shared by LTDL_CONVENIENCE and LTDL_INIT([convenience]).
+m4_defun([_LTDL_CONVENIENCE],
+[case $enable_ltdl_convenience in
+  no) AC_MSG_ERROR([this package needs a convenience libltdl]) ;;
+  "") enable_ltdl_convenience=yes
+      ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;;
+esac
+LIBLTDL='_LT_BUILD_PREFIX'"${lt_ltdl_dir+$lt_ltdl_dir/}libltdlc.la"
+LTDLDEPS=$LIBLTDL
+LTDLINCL='-I${top_srcdir}'"${lt_ltdl_dir+/$lt_ltdl_dir}"
+
+AC_SUBST([LIBLTDL])
+AC_SUBST([LTDLDEPS])
+AC_SUBST([LTDLINCL])
+
+# For backwards non-gettext consistent compatibility...
+INCLTDL="$LTDLINCL"
+AC_SUBST([INCLTDL])
+])# _LTDL_CONVENIENCE
+
+
+# LTDL_INSTALLABLE
+# ----------------
+# sets LIBLTDL to the link flags for the libltdl installable library
+# and LTDLINCL to the include flags for the libltdl header and adds
+# --enable-ltdl-install to the configure arguments.  Note that
+# AC_CONFIG_SUBDIRS is not called from here.  If an installed libltdl
+# is not found, LIBLTDL will be prefixed with '${top_build_prefix}' if
+# available, otherwise with '${top_builddir}/', and LTDLINCL will be
+# prefixed with '${top_srcdir}/' (note the single quotes!).  If your
+# package is not flat and you're not using automake, define top_build_prefix,
+# top_builddir, and top_srcdir appropriately in your Makefiles.
+# In the future, this macro may have to be called after LT_INIT.
+AC_DEFUN([LTDL_INSTALLABLE],
+[AC_BEFORE([$0], [LTDL_INIT])dnl
+dnl Although the argument is deprecated and no longer documented,
+dnl LTDL_INSTALLABLE used to take a DIRECTORY orgument, if we have one
+dnl here make sure it is the same as any other declaration of libltdl's
+dnl location!  This also ensures lt_ltdl_dir is set when configure.ac is
+dnl not yet using an explicit LT_CONFIG_LTDL_DIR.
+m4_ifval([$1], [_LT_CONFIG_LTDL_DIR([$1])])dnl
+_$0()
+])# LTDL_INSTALLABLE
+
+# AC_LIBLTDL_INSTALLABLE accepted a directory argument in older libtools,
+# now we have LT_CONFIG_LTDL_DIR:
+AU_DEFUN([AC_LIBLTDL_INSTALLABLE],
+[_LT_CONFIG_LTDL_DIR([m4_default([$1], [libltdl])])
+_LTDL_INSTALLABLE])
+
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIBLTDL_INSTALLABLE], [])
+
+
+# _LTDL_INSTALLABLE
+# -----------------
+# Code shared by LTDL_INSTALLABLE and LTDL_INIT([installable]).
+m4_defun([_LTDL_INSTALLABLE],
+[if test -f $prefix/lib/libltdl.la; then
+  lt_save_LDFLAGS="$LDFLAGS"
+  LDFLAGS="-L$prefix/lib $LDFLAGS"
+  AC_CHECK_LIB([ltdl], [lt_dlinit], [lt_lib_ltdl=yes])
+  LDFLAGS="$lt_save_LDFLAGS"
+  if test x"${lt_lib_ltdl-no}" = xyes; then
+    if test x"$enable_ltdl_install" != xyes; then
+      # Don't overwrite $prefix/lib/libltdl.la without --enable-ltdl-install
+      AC_MSG_WARN([not overwriting libltdl at $prefix, force with `--enable-ltdl-install'])
+      enable_ltdl_install=no
+    fi
+  elif test x"$enable_ltdl_install" = xno; then
+    AC_MSG_WARN([libltdl not installed, but installation disabled])
+  fi
+fi
+
+# If configure.ac declared an installable ltdl, and the user didn't override
+# with --disable-ltdl-install, we will install the shipped libltdl.
+case $enable_ltdl_install in
+  no) ac_configure_args="$ac_configure_args --enable-ltdl-install=no"
+      LIBLTDL="-lltdl"
+      LTDLDEPS=
+      LTDLINCL=
+      ;;
+  *)  enable_ltdl_install=yes
+      ac_configure_args="$ac_configure_args --enable-ltdl-install"
+      LIBLTDL='_LT_BUILD_PREFIX'"${lt_ltdl_dir+$lt_ltdl_dir/}libltdl.la"
+      LTDLDEPS=$LIBLTDL
+      LTDLINCL='-I${top_srcdir}'"${lt_ltdl_dir+/$lt_ltdl_dir}"
+      ;;
+esac
+
+AC_SUBST([LIBLTDL])
+AC_SUBST([LTDLDEPS])
+AC_SUBST([LTDLINCL])
+
+# For backwards non-gettext consistent compatibility...
+INCLTDL="$LTDLINCL"
+AC_SUBST([INCLTDL])
+])# LTDL_INSTALLABLE
+
+
+# _LTDL_MODE_DISPATCH
+# -------------------
+m4_define([_LTDL_MODE_DISPATCH],
+[dnl If _LTDL_DIR is `.', then we are configuring libltdl itself:
+m4_if(_LTDL_DIR, [],
+       [],
+    dnl if _LTDL_MODE was not set already, the default value is `subproject':
+    [m4_case(m4_default(_LTDL_MODE, [subproject]),
+         [subproject], [AC_CONFIG_SUBDIRS(_LTDL_DIR)
+                         _LT_SHELL_INIT([lt_dlopen_dir="$lt_ltdl_dir"])],
+         [nonrecursive], [_LT_SHELL_INIT([lt_dlopen_dir="$lt_ltdl_dir"; lt_libobj_prefix="$lt_ltdl_dir/"])],
+         [recursive], [],
+       [m4_fatal([unknown libltdl mode: ]_LTDL_MODE)])])dnl
+dnl Be careful not to expand twice:
+m4_define([$0], [])
+])# _LTDL_MODE_DISPATCH
+
+
+# _LT_LIBOBJ(MODULE_NAME)
+# -----------------------
+# Like AC_LIBOBJ, except that MODULE_NAME goes into _LT_LIBOBJS instead
+# of into LIBOBJS.
+AC_DEFUN([_LT_LIBOBJ], [
+  m4_pattern_allow([^_LT_LIBOBJS$])
+  _LT_LIBOBJS="$_LT_LIBOBJS $1.$ac_objext"
+])# _LT_LIBOBJS
+
+
+# LTDL_INIT([OPTIONS])
+# --------------------
+# Clients of libltdl can use this macro to allow the installer to
+# choose between a shipped copy of the ltdl sources or a preinstalled
+# version of the library.  If the shipped ltdl sources are not in a
+# subdirectory named libltdl, the directory name must be given by
+# LT_CONFIG_LTDL_DIR.
+AC_DEFUN([LTDL_INIT],
+[dnl Parse OPTIONS
+_LT_SET_OPTIONS([$0], [$1])
+
+dnl We need to keep our own list of libobjs separate from our parent project,
+dnl and the easiest way to do that is redefine the AC_LIBOBJs macro while
+dnl we look for our own LIBOBJs.
+m4_pushdef([AC_LIBOBJ], m4_defn([_LT_LIBOBJ]))
+m4_pushdef([AC_LIBSOURCES])
+
+dnl If not otherwise defined, default to the 1.5.x compatible subproject mode:
+m4_if(_LTDL_MODE, [],
+        [m4_define([_LTDL_MODE], m4_default([$2], [subproject]))
+        m4_if([-1], [m4_bregexp(_LTDL_MODE, [\(subproject\|\(non\)?recursive\)])],
+                [m4_fatal([unknown libltdl mode: ]_LTDL_MODE)])])
+
+AC_ARG_WITH([included_ltdl],
+    [AS_HELP_STRING([--with-included-ltdl],
+                    [use the GNU ltdl sources included here])])
+
+if test "x$with_included_ltdl" != xyes; then
+  # We are not being forced to use the included libltdl sources, so
+  # decide whether there is a useful installed version we can use.
+  AC_CHECK_HEADER([ltdl.h],
+      [AC_CHECK_DECL([lt_dlinterface_register],
+          [AC_CHECK_LIB([ltdl], [lt_dladvise_preload],
+              [with_included_ltdl=no],
+              [with_included_ltdl=yes])],
+          [with_included_ltdl=yes],
+          [AC_INCLUDES_DEFAULT
+           #include <ltdl.h>])],
+      [with_included_ltdl=yes],
+      [AC_INCLUDES_DEFAULT]
+  )
+fi
+
+dnl If neither LT_CONFIG_LTDL_DIR, LTDL_CONVENIENCE nor LTDL_INSTALLABLE
+dnl was called yet, then for old times' sake, we assume libltdl is in an
+dnl eponymous directory:
+AC_PROVIDE_IFELSE([LT_CONFIG_LTDL_DIR], [], [_LT_CONFIG_LTDL_DIR([libltdl])])
+
+AC_ARG_WITH([ltdl_include],
+    [AS_HELP_STRING([--with-ltdl-include=DIR],
+                    [use the ltdl headers installed in DIR])])
+
+if test -n "$with_ltdl_include"; then
+  if test -f "$with_ltdl_include/ltdl.h"; then :
+  else
+    AC_MSG_ERROR([invalid ltdl include directory: `$with_ltdl_include'])
+  fi
+else
+  with_ltdl_include=no
+fi
+
+AC_ARG_WITH([ltdl_lib],
+    [AS_HELP_STRING([--with-ltdl-lib=DIR],
+                    [use the libltdl.la installed in DIR])])
+
+if test -n "$with_ltdl_lib"; then
+  if test -f "$with_ltdl_lib/libltdl.la"; then :
+  else
+    AC_MSG_ERROR([invalid ltdl library directory: `$with_ltdl_lib'])
+  fi
+else
+  with_ltdl_lib=no
+fi
+
+case ,$with_included_ltdl,$with_ltdl_include,$with_ltdl_lib, in
+  ,yes,no,no,)
+       m4_case(m4_default(_LTDL_TYPE, [convenience]),
+           [convenience], [_LTDL_CONVENIENCE],
+           [installable], [_LTDL_INSTALLABLE],
+         [m4_fatal([unknown libltdl build type: ]_LTDL_TYPE)])
+       ;;
+  ,no,no,no,)
+       # If the included ltdl is not to be used, then use the
+       # preinstalled libltdl we found.
+       AC_DEFINE([HAVE_LTDL], [1],
+         [Define this if a modern libltdl is already installed])
+       LIBLTDL=-lltdl
+       LTDLDEPS=
+       LTDLINCL=
+       ;;
+  ,no*,no,*)
+       AC_MSG_ERROR([`--with-ltdl-include' and `--with-ltdl-lib' options must be used together])
+       ;;
+  *)   with_included_ltdl=no
+       LIBLTDL="-L$with_ltdl_lib -lltdl"
+       LTDLDEPS=
+       LTDLINCL="-I$with_ltdl_include"
+       ;;
+esac
+INCLTDL="$LTDLINCL"
+
+# Report our decision...
+AC_MSG_CHECKING([where to find libltdl headers])
+AC_MSG_RESULT([$LTDLINCL])
+AC_MSG_CHECKING([where to find libltdl library])
+AC_MSG_RESULT([$LIBLTDL])
+
+_LTDL_SETUP
+
+dnl restore autoconf definition.
+m4_popdef([AC_LIBOBJ])
+m4_popdef([AC_LIBSOURCES])
+
+AC_CONFIG_COMMANDS_PRE([
+    _ltdl_libobjs=
+    _ltdl_ltlibobjs=
+    if test -n "$_LT_LIBOBJS"; then
+      # Remove the extension.
+      _lt_sed_drop_objext='s/\.o$//;s/\.obj$//'
+      for i in `for i in $_LT_LIBOBJS; do echo "$i"; done | sed "$_lt_sed_drop_objext" | sort -u`; do
+        _ltdl_libobjs="$_ltdl_libobjs $lt_libobj_prefix$i.$ac_objext"
+        _ltdl_ltlibobjs="$_ltdl_ltlibobjs $lt_libobj_prefix$i.lo"
+      done
+    fi
+    AC_SUBST([ltdl_LIBOBJS], [$_ltdl_libobjs])
+    AC_SUBST([ltdl_LTLIBOBJS], [$_ltdl_ltlibobjs])
+])
+
+# Only expand once:
+m4_define([LTDL_INIT])
+])# LTDL_INIT
+
+# Old names:
+AU_DEFUN([AC_LIB_LTDL], [LTDL_INIT($@)])
+AU_DEFUN([AC_WITH_LTDL], [LTDL_INIT($@)])
+AU_DEFUN([LT_WITH_LTDL], [LTDL_INIT($@)])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LIB_LTDL], [])
+dnl AC_DEFUN([AC_WITH_LTDL], [])
+dnl AC_DEFUN([LT_WITH_LTDL], [])
+
+
+# _LTDL_SETUP
+# -----------
+# Perform all the checks necessary for compilation of the ltdl objects
+#  -- including compiler checks and header checks.  This is a public
+# interface  mainly for the benefit of libltdl's own configure.ac, most
+# other users should call LTDL_INIT instead.
+AC_DEFUN([_LTDL_SETUP],
+[AC_REQUIRE([AC_PROG_CC])dnl
+AC_REQUIRE([LT_SYS_MODULE_EXT])dnl
+AC_REQUIRE([LT_SYS_MODULE_PATH])dnl
+AC_REQUIRE([LT_SYS_DLSEARCH_PATH])dnl
+AC_REQUIRE([LT_LIB_DLLOAD])dnl
+AC_REQUIRE([LT_SYS_SYMBOL_USCORE])dnl
+AC_REQUIRE([LT_FUNC_DLSYM_USCORE])dnl
+AC_REQUIRE([LT_SYS_DLOPEN_DEPLIBS])dnl
+AC_REQUIRE([gl_FUNC_ARGZ])dnl
+
+m4_require([_LT_CHECK_OBJDIR])dnl
+m4_require([_LT_HEADER_DLFCN])dnl
+m4_require([_LT_CHECK_DLPREOPEN])dnl
+m4_require([_LT_DECL_SED])dnl
+
+dnl Don't require this, or it will be expanded earlier than the code
+dnl that sets the variables it relies on:
+_LT_ENABLE_INSTALL
+
+dnl _LTDL_MODE specific code must be called at least once:
+_LTDL_MODE_DISPATCH
+
+# In order that ltdl.c can compile, find out the first AC_CONFIG_HEADERS
+# the user used.  This is so that ltdl.h can pick up the parent projects
+# config.h file, The first file in AC_CONFIG_HEADERS must contain the
+# definitions required by ltdl.c.
+# FIXME: Remove use of undocumented AC_LIST_HEADERS (2.59 compatibility).
+AC_CONFIG_COMMANDS_PRE([dnl
+m4_pattern_allow([^LT_CONFIG_H$])dnl
+m4_ifset([AH_HEADER],
+    [LT_CONFIG_H=AH_HEADER],
+    [m4_ifset([AC_LIST_HEADERS],
+           [LT_CONFIG_H=`echo "AC_LIST_HEADERS" | $SED 's,^[[      ]]*,,;s,[[ :]].*$,,'`],
+       [])])])
+AC_SUBST([LT_CONFIG_H])
+
+AC_CHECK_HEADERS([unistd.h dl.h sys/dl.h dld.h mach-o/dyld.h dirent.h],
+       [], [], [AC_INCLUDES_DEFAULT])
+
+AC_CHECK_FUNCS([closedir opendir readdir], [], [AC_LIBOBJ([lt__dirent])])
+AC_CHECK_FUNCS([strlcat strlcpy], [], [AC_LIBOBJ([lt__strl])])
+
+AC_DEFINE_UNQUOTED([LT_LIBEXT],["$libext"],[The archive extension])
+
+name=ltdl
+LTDLOPEN=`eval "\\$ECHO \"$libname_spec\""`
+AC_SUBST([LTDLOPEN])
+])# _LTDL_SETUP
+
+
+# _LT_ENABLE_INSTALL
+# ------------------
+m4_define([_LT_ENABLE_INSTALL],
+[AC_ARG_ENABLE([ltdl-install],
+    [AS_HELP_STRING([--enable-ltdl-install], [install libltdl])])
+
+case ,${enable_ltdl_install},${enable_ltdl_convenience} in
+  *yes*) ;;
+  *) enable_ltdl_convenience=yes ;;
+esac
+
+m4_ifdef([AM_CONDITIONAL],
+[AM_CONDITIONAL(INSTALL_LTDL, test x"${enable_ltdl_install-no}" != xno)
+ AM_CONDITIONAL(CONVENIENCE_LTDL, test x"${enable_ltdl_convenience-no}" != xno)])
+])# _LT_ENABLE_INSTALL
+
+
+# LT_SYS_DLOPEN_DEPLIBS
+# ---------------------
+AC_DEFUN([LT_SYS_DLOPEN_DEPLIBS],
+[AC_REQUIRE([AC_CANONICAL_HOST])dnl
+AC_CACHE_CHECK([whether deplibs are loaded by dlopen],
+  [lt_cv_sys_dlopen_deplibs],
+  [# PORTME does your system automatically load deplibs for dlopen?
+  # or its logical equivalent (e.g. shl_load for HP-UX < 11)
+  # For now, we just catch OSes we know something about -- in the
+  # future, we'll try test this programmatically.
+  lt_cv_sys_dlopen_deplibs=unknown
+  case $host_os in
+  aix3*|aix4.1.*|aix4.2.*)
+    # Unknown whether this is true for these versions of AIX, but
+    # we want this `case' here to explicitly catch those versions.
+    lt_cv_sys_dlopen_deplibs=unknown
+    ;;
+  aix[[4-9]]*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  amigaos*)
+    case $host_cpu in
+    powerpc)
+      lt_cv_sys_dlopen_deplibs=no
+      ;;
+    esac
+    ;;
+  darwin*)
+    # Assuming the user has installed a libdl from somewhere, this is true
+    # If you are looking for one http://www.opendarwin.org/projects/dlcompat
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  freebsd* | dragonfly*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  gnu* | linux* | k*bsd*-gnu)
+    # GNU and its variants, using gnu ld.so (Glibc)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  hpux10*|hpux11*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  interix*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  irix[[12345]]*|irix6.[[01]]*)
+    # Catch all versions of IRIX before 6.2, and indicate that we don't
+    # know how it worked for any of those versions.
+    lt_cv_sys_dlopen_deplibs=unknown
+    ;;
+  irix*)
+    # The case above catches anything before 6.2, and it's known that
+    # at 6.2 and later dlopen does load deplibs.
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  netbsd*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  openbsd*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  osf[[1234]]*)
+    # dlopen did load deplibs (at least at 4.x), but until the 5.x series,
+    # it did *not* use an RPATH in a shared library to find objects the
+    # library depends on, so we explicitly say `no'.
+    lt_cv_sys_dlopen_deplibs=no
+    ;;
+  osf5.0|osf5.0a|osf5.1)
+    # dlopen *does* load deplibs and with the right loader patch applied
+    # it even uses RPATH in a shared library to search for shared objects
+    # that the library depends on, but there's no easy way to know if that
+    # patch is installed.  Since this is the case, all we can really
+    # say is unknown -- it depends on the patch being installed.  If
+    # it is, this changes to `yes'.  Without it, it would be `no'.
+    lt_cv_sys_dlopen_deplibs=unknown
+    ;;
+  osf*)
+    # the two cases above should catch all versions of osf <= 5.1.  Read
+    # the comments above for what we know about them.
+    # At > 5.1, deplibs are loaded *and* any RPATH in a shared library
+    # is used to find them so we can finally say `yes'.
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  qnx*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  solaris*)
+    lt_cv_sys_dlopen_deplibs=yes
+    ;;
+  sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
+    libltdl_cv_sys_dlopen_deplibs=yes
+    ;;
+  esac
+  ])
+if test "$lt_cv_sys_dlopen_deplibs" != yes; then
+ AC_DEFINE([LTDL_DLOPEN_DEPLIBS], [1],
+    [Define if the OS needs help to load dependent libraries for dlopen().])
+fi
+])# LT_SYS_DLOPEN_DEPLIBS
+
+# Old name:
+AU_ALIAS([AC_LTDL_SYS_DLOPEN_DEPLIBS], [LT_SYS_DLOPEN_DEPLIBS])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LTDL_SYS_DLOPEN_DEPLIBS], [])
+
+
+# LT_SYS_MODULE_EXT
+# -----------------
+AC_DEFUN([LT_SYS_MODULE_EXT],
+[m4_require([_LT_SYS_DYNAMIC_LINKER])dnl
+AC_CACHE_CHECK([which extension is used for runtime loadable modules],
+  [libltdl_cv_shlibext],
+[
+module=yes
+eval libltdl_cv_shlibext=$shrext_cmds
+  ])
+if test -n "$libltdl_cv_shlibext"; then
+  m4_pattern_allow([LT_MODULE_EXT])dnl
+  AC_DEFINE_UNQUOTED([LT_MODULE_EXT], ["$libltdl_cv_shlibext"],
+    [Define to the extension used for runtime loadable modules, say, ".so".])
+fi
+])# LT_SYS_MODULE_EXT
+
+# Old name:
+AU_ALIAS([AC_LTDL_SHLIBEXT], [LT_SYS_MODULE_EXT])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LTDL_SHLIBEXT], [])
+
+
+# LT_SYS_MODULE_PATH
+# ------------------
+AC_DEFUN([LT_SYS_MODULE_PATH],
+[m4_require([_LT_SYS_DYNAMIC_LINKER])dnl
+AC_CACHE_CHECK([which variable specifies run-time module search path],
+  [lt_cv_module_path_var], [lt_cv_module_path_var="$shlibpath_var"])
+if test -n "$lt_cv_module_path_var"; then
+  m4_pattern_allow([LT_MODULE_PATH_VAR])dnl
+  AC_DEFINE_UNQUOTED([LT_MODULE_PATH_VAR], ["$lt_cv_module_path_var"],
+    [Define to the name of the environment variable that determines the run-time module search path.])
+fi
+])# LT_SYS_MODULE_PATH
+
+# Old name:
+AU_ALIAS([AC_LTDL_SHLIBPATH], [LT_SYS_MODULE_PATH])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LTDL_SHLIBPATH], [])
+
+
+# LT_SYS_DLSEARCH_PATH
+# --------------------
+AC_DEFUN([LT_SYS_DLSEARCH_PATH],
+[m4_require([_LT_SYS_DYNAMIC_LINKER])dnl
+AC_CACHE_CHECK([for the default library search path],
+  [lt_cv_sys_dlsearch_path],
+  [lt_cv_sys_dlsearch_path="$sys_lib_dlsearch_path_spec"])
+if test -n "$lt_cv_sys_dlsearch_path"; then
+  sys_dlsearch_path=
+  for dir in $lt_cv_sys_dlsearch_path; do
+    if test -z "$sys_dlsearch_path"; then
+      sys_dlsearch_path="$dir"
+    else
+      sys_dlsearch_path="$sys_dlsearch_path$PATH_SEPARATOR$dir"
+    fi
+  done
+  m4_pattern_allow([LT_DLSEARCH_PATH])dnl
+  AC_DEFINE_UNQUOTED([LT_DLSEARCH_PATH], ["$sys_dlsearch_path"],
+    [Define to the system default library search path.])
+fi
+])# LT_SYS_DLSEARCH_PATH
+
+# Old name:
+AU_ALIAS([AC_LTDL_SYSSEARCHPATH], [LT_SYS_DLSEARCH_PATH])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LTDL_SYSSEARCHPATH], [])
+
+
+# _LT_CHECK_DLPREOPEN
+# -------------------
+m4_defun([_LT_CHECK_DLPREOPEN],
+[m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl
+AC_CACHE_CHECK([whether libtool supports -dlopen/-dlpreopen],
+  [libltdl_cv_preloaded_symbols],
+  [if test -n "$lt_cv_sys_global_symbol_pipe"; then
+    libltdl_cv_preloaded_symbols=yes
+  else
+    libltdl_cv_preloaded_symbols=no
+  fi
+  ])
+if test x"$libltdl_cv_preloaded_symbols" = xyes; then
+  AC_DEFINE([HAVE_PRELOADED_SYMBOLS], [1],
+    [Define if libtool can extract symbol lists from object files.])
+fi
+])# _LT_CHECK_DLPREOPEN
+
+
+# LT_LIB_DLLOAD
+# -------------
+AC_DEFUN([LT_LIB_DLLOAD],
+[m4_pattern_allow([^LT_DLLOADERS$])
+LT_DLLOADERS=
+AC_SUBST([LT_DLLOADERS])
+
+AC_LANG_PUSH([C])
+
+LIBADD_DLOPEN=
+AC_SEARCH_LIBS([dlopen], [dl],
+       [AC_DEFINE([HAVE_LIBDL], [1],
+                  [Define if you have the libdl library or equivalent.])
+       if test "$ac_cv_search_dlopen" != "none required" ; then
+         LIBADD_DLOPEN="-ldl"
+       fi
+       libltdl_cv_lib_dl_dlopen="yes"
+       LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dlopen.la"],
+    [AC_LINK_IFELSE([AC_LANG_PROGRAM([[#if HAVE_DLFCN_H
+#  include <dlfcn.h>
+#endif
+    ]], [[dlopen(0, 0);]])],
+           [AC_DEFINE([HAVE_LIBDL], [1],
+                      [Define if you have the libdl library or equivalent.])
+           libltdl_cv_func_dlopen="yes"
+           LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dlopen.la"],
+       [AC_CHECK_LIB([svld], [dlopen],
+               [AC_DEFINE([HAVE_LIBDL], [1],
+                        [Define if you have the libdl library or equivalent.])
+               LIBADD_DLOPEN="-lsvld" libltdl_cv_func_dlopen="yes"
+               LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dlopen.la"])])])
+if test x"$libltdl_cv_func_dlopen" = xyes || test x"$libltdl_cv_lib_dl_dlopen" = xyes
+then
+  lt_save_LIBS="$LIBS"
+  LIBS="$LIBS $LIBADD_DLOPEN"
+  AC_CHECK_FUNCS([dlerror])
+  LIBS="$lt_save_LIBS"
+fi
+AC_SUBST([LIBADD_DLOPEN])
+
+LIBADD_SHL_LOAD=
+AC_CHECK_FUNC([shl_load],
+       [AC_DEFINE([HAVE_SHL_LOAD], [1],
+                  [Define if you have the shl_load function.])
+       LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}shl_load.la"],
+    [AC_CHECK_LIB([dld], [shl_load],
+           [AC_DEFINE([HAVE_SHL_LOAD], [1],
+                      [Define if you have the shl_load function.])
+           LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}shl_load.la"
+           LIBADD_SHL_LOAD="-ldld"])])
+AC_SUBST([LIBADD_SHL_LOAD])
+
+case $host_os in
+darwin[[1567]].*)
+# We only want this for pre-Mac OS X 10.4.
+  AC_CHECK_FUNC([_dyld_func_lookup],
+       [AC_DEFINE([HAVE_DYLD], [1],
+                  [Define if you have the _dyld_func_lookup function.])
+       LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dyld.la"])
+  ;;
+beos*)
+  LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}load_add_on.la"
+  ;;
+cygwin* | mingw* | os2* | pw32*)
+  AC_CHECK_DECLS([cygwin_conv_path], [], [], [[#include <sys/cygwin.h>]])
+  LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}loadlibrary.la"
+  ;;
+esac
+
+AC_CHECK_LIB([dld], [dld_link],
+       [AC_DEFINE([HAVE_DLD], [1],
+                  [Define if you have the GNU dld library.])
+               LT_DLLOADERS="$LT_DLLOADERS ${lt_dlopen_dir+$lt_dlopen_dir/}dld_link.la"])
+AC_SUBST([LIBADD_DLD_LINK])
+
+m4_pattern_allow([^LT_DLPREOPEN$])
+LT_DLPREOPEN=
+if test -n "$LT_DLLOADERS"
+then
+  for lt_loader in $LT_DLLOADERS; do
+    LT_DLPREOPEN="$LT_DLPREOPEN-dlpreopen $lt_loader "
+  done
+  AC_DEFINE([HAVE_LIBDLLOADER], [1],
+            [Define if libdlloader will be built on this platform])
+fi
+AC_SUBST([LT_DLPREOPEN])
+
+dnl This isn't used anymore, but set it for backwards compatibility
+LIBADD_DL="$LIBADD_DLOPEN $LIBADD_SHL_LOAD"
+AC_SUBST([LIBADD_DL])
+
+AC_LANG_POP
+])# LT_LIB_DLLOAD
+
+# Old name:
+AU_ALIAS([AC_LTDL_DLLIB], [LT_LIB_DLLOAD])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LTDL_DLLIB], [])
+
+
+# LT_SYS_SYMBOL_USCORE
+# --------------------
+# does the compiler prefix global symbols with an underscore?
+AC_DEFUN([LT_SYS_SYMBOL_USCORE],
+[m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl
+AC_CACHE_CHECK([for _ prefix in compiled symbols],
+  [lt_cv_sys_symbol_underscore],
+  [lt_cv_sys_symbol_underscore=no
+  cat > conftest.$ac_ext <<_LT_EOF
+void nm_test_func(){}
+int main(){nm_test_func;return 0;}
+_LT_EOF
+  if AC_TRY_EVAL(ac_compile); then
+    # Now try to grab the symbols.
+    ac_nlist=conftest.nm
+    if AC_TRY_EVAL(NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $ac_nlist) && test -s "$ac_nlist"; then
+      # See whether the symbols have a leading underscore.
+      if grep '^. _nm_test_func' "$ac_nlist" >/dev/null; then
+        lt_cv_sys_symbol_underscore=yes
+      else
+        if grep '^. nm_test_func ' "$ac_nlist" >/dev/null; then
+         :
+        else
+         echo "configure: cannot find nm_test_func in $ac_nlist" >&AS_MESSAGE_LOG_FD
+        fi
+      fi
+    else
+      echo "configure: cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD
+    fi
+  else
+    echo "configure: failed program was:" >&AS_MESSAGE_LOG_FD
+    cat conftest.c >&AS_MESSAGE_LOG_FD
+  fi
+  rm -rf conftest*
+  ])
+  sys_symbol_underscore=$lt_cv_sys_symbol_underscore
+  AC_SUBST([sys_symbol_underscore])
+])# LT_SYS_SYMBOL_USCORE
+
+# Old name:
+AU_ALIAS([AC_LTDL_SYMBOL_USCORE], [LT_SYS_SYMBOL_USCORE])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LTDL_SYMBOL_USCORE], [])
+
+
+# LT_FUNC_DLSYM_USCORE
+# --------------------
+AC_DEFUN([LT_FUNC_DLSYM_USCORE],
+[AC_REQUIRE([LT_SYS_SYMBOL_USCORE])dnl
+if test x"$lt_cv_sys_symbol_underscore" = xyes; then
+  if test x"$libltdl_cv_func_dlopen" = xyes ||
+     test x"$libltdl_cv_lib_dl_dlopen" = xyes ; then
+       AC_CACHE_CHECK([whether we have to add an underscore for dlsym],
+         [libltdl_cv_need_uscore],
+         [libltdl_cv_need_uscore=unknown
+          save_LIBS="$LIBS"
+          LIBS="$LIBS $LIBADD_DLOPEN"
+         _LT_TRY_DLOPEN_SELF(
+           [libltdl_cv_need_uscore=no], [libltdl_cv_need_uscore=yes],
+           [],                          [libltdl_cv_need_uscore=cross])
+         LIBS="$save_LIBS"
+       ])
+  fi
+fi
+
+if test x"$libltdl_cv_need_uscore" = xyes; then
+  AC_DEFINE([NEED_USCORE], [1],
+    [Define if dlsym() requires a leading underscore in symbol names.])
+fi
+])# LT_FUNC_DLSYM_USCORE
+
+# Old name:
+AU_ALIAS([AC_LTDL_DLSYM_USCORE], [LT_FUNC_DLSYM_USCORE])
+dnl aclocal-1.4 backwards compatibility:
+dnl AC_DEFUN([AC_LTDL_DLSYM_USCORE], [])
+
+# Portability macros for glibc argz.                    -*- Autoconf -*-
+#
+#   Copyright (C) 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
+#   Written by Gary V. Vaughan <gary@gnu.org>
+#
+# This file is free software; the Free Software Foundation gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+
+# serial 5 argz.m4
+
+AC_DEFUN([gl_FUNC_ARGZ],
+[gl_PREREQ_ARGZ
+
+AC_CHECK_HEADERS([argz.h], [], [], [AC_INCLUDES_DEFAULT])
+
+AC_CHECK_TYPES([error_t],
+  [],
+  [AC_DEFINE([error_t], [int],
+   [Define to a type to use for `error_t' if it is not otherwise available.])
+   AC_DEFINE([__error_t_defined], [1], [Define so that glibc/gnulib argp.h
+    does not typedef error_t.])],
+  [#if defined(HAVE_ARGZ_H)
+#  include <argz.h>
+#endif])
+
+ARGZ_H=
+AC_CHECK_FUNCS([argz_add argz_append argz_count argz_create_sep argz_insert \
+       argz_next argz_stringify], [], [ARGZ_H=argz.h; AC_LIBOBJ([argz])])
+
+dnl if have system argz functions, allow forced use of
+dnl libltdl-supplied implementation (and default to do so
+dnl on "known bad" systems). Could use a runtime check, but
+dnl (a) detecting malloc issues is notoriously unreliable
+dnl (b) only known system that declares argz functions,
+dnl     provides them, yet they are broken, is cygwin
+dnl     releases prior to 16-Mar-2007 (1.5.24 and earlier)
+dnl So, it's more straightforward simply to special case
+dnl this for known bad systems.
+AS_IF([test -z "$ARGZ_H"],
+    [AC_CACHE_CHECK(
+        [if argz actually works],
+        [lt_cv_sys_argz_works],
+        [[case $host_os in #(
+        *cygwin*)
+          lt_cv_sys_argz_works=no
+          if test "$cross_compiling" != no; then
+            lt_cv_sys_argz_works="guessing no"
+          else
+            lt_sed_extract_leading_digits='s/^\([0-9\.]*\).*/\1/'
+            save_IFS=$IFS
+            IFS=-.
+            set x `uname -r | sed -e "$lt_sed_extract_leading_digits"`
+            IFS=$save_IFS
+            lt_os_major=${2-0}
+            lt_os_minor=${3-0}
+            lt_os_micro=${4-0}
+            if test "$lt_os_major" -gt 1 \
+               || { test "$lt_os_major" -eq 1 \
+                 && { test "$lt_os_minor" -gt 5 \
+                   || { test "$lt_os_minor" -eq 5 \
+                     && test "$lt_os_micro" -gt 24; }; }; }; then
+              lt_cv_sys_argz_works=yes
+            fi
+          fi
+          ;; #(
+        *) lt_cv_sys_argz_works=yes ;;
+        esac]])
+     AS_IF([test $lt_cv_sys_argz_works = yes],
+        [AC_DEFINE([HAVE_WORKING_ARGZ], 1,
+                   [This value is set to 1 to indicate that the system argz facility works])],
+        [ARGZ_H=argz.h
+        AC_LIBOBJ([argz])])])
+
+AC_SUBST([ARGZ_H])
+])
+
+# Prerequisites of lib/argz.c.
+AC_DEFUN([gl_PREREQ_ARGZ], [:])
+
+# ltsugar.m4 -- libtool m4 base layer.                         -*-Autoconf-*-
+#
+# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
+# Written by Gary V. Vaughan, 2004
+#
+# This file is free software; the Free Software Foundation gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+
+# serial 6 ltsugar.m4
+
+# This is to help aclocal find these macros, as it can't see m4_define.
+AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])])
+
+
+# lt_join(SEP, ARG1, [ARG2...])
+# -----------------------------
+# Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their
+# associated separator.
+# Needed until we can rely on m4_join from Autoconf 2.62, since all earlier
+# versions in m4sugar had bugs.
+m4_define([lt_join],
+[m4_if([$#], [1], [],
+       [$#], [2], [[$2]],
+       [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])])
+m4_define([_lt_join],
+[m4_if([$#$2], [2], [],
+       [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])])
+
+
+# lt_car(LIST)
+# lt_cdr(LIST)
+# ------------
+# Manipulate m4 lists.
+# These macros are necessary as long as will still need to support
+# Autoconf-2.59 which quotes differently.
+m4_define([lt_car], [[$1]])
+m4_define([lt_cdr],
+[m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])],
+       [$#], 1, [],
+       [m4_dquote(m4_shift($@))])])
+m4_define([lt_unquote], $1)
+
+
+# lt_append(MACRO-NAME, STRING, [SEPARATOR])
+# ------------------------------------------
+# Redefine MACRO-NAME to hold its former content plus `SEPARATOR'`STRING'.
+# Note that neither SEPARATOR nor STRING are expanded; they are appended
+# to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked).
+# No SEPARATOR is output if MACRO-NAME was previously undefined (different
+# than defined and empty).
+#
+# This macro is needed until we can rely on Autoconf 2.62, since earlier
+# versions of m4sugar mistakenly expanded SEPARATOR but not STRING.
+m4_define([lt_append],
+[m4_define([$1],
+          m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])])
+
+
+
+# lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...])
+# ----------------------------------------------------------
+# Produce a SEP delimited list of all paired combinations of elements of
+# PREFIX-LIST with SUFFIX1 through SUFFIXn.  Each element of the list
+# has the form PREFIXmINFIXSUFFIXn.
+# Needed until we can rely on m4_combine added in Autoconf 2.62.
+m4_define([lt_combine],
+[m4_if(m4_eval([$# > 3]), [1],
+       [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl
+[[m4_foreach([_Lt_prefix], [$2],
+            [m4_foreach([_Lt_suffix],
+               ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[,
+       [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])])
+
+
+# lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ])
+# -----------------------------------------------------------------------
+# Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited
+# by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ.
+m4_define([lt_if_append_uniq],
+[m4_ifdef([$1],
+         [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1],
+                [lt_append([$1], [$2], [$3])$4],
+                [$5])],
+         [lt_append([$1], [$2], [$3])$4])])
+
+
+# lt_dict_add(DICT, KEY, VALUE)
+# -----------------------------
+m4_define([lt_dict_add],
+[m4_define([$1($2)], [$3])])
+
+
+# lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE)
+# --------------------------------------------
+m4_define([lt_dict_add_subkey],
+[m4_define([$1($2:$3)], [$4])])
+
+
+# lt_dict_fetch(DICT, KEY, [SUBKEY])
+# ----------------------------------
+m4_define([lt_dict_fetch],
+[m4_ifval([$3],
+       m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]),
+    m4_ifdef([$1($2)], [m4_defn([$1($2)])]))])
+
+
+# lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE])
+# -----------------------------------------------------------------
+m4_define([lt_if_dict_fetch],
+[m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4],
+       [$5],
+    [$6])])
+
+
+# lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...])
+# --------------------------------------------------------------
+m4_define([lt_dict_filter],
+[m4_if([$5], [], [],
+  [lt_join(m4_quote(m4_default([$4], [[, ]])),
+           lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]),
+                     [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl
+])
+
+# ltversion.m4 -- version numbers                      -*- Autoconf -*-
+#
+#   Copyright (C) 2004 Free Software Foundation, Inc.
+#   Written by Scott James Remnant, 2004
+#
+# This file is free software; the Free Software Foundation gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+
+# Generated from ltversion.in.
+
+# serial 3012 ltversion.m4
+# This file is part of GNU Libtool
+
+m4_define([LT_PACKAGE_VERSION], [2.2.6])
+m4_define([LT_PACKAGE_REVISION], [1.3012])
+
+AC_DEFUN([LTVERSION_VERSION],
+[macro_version='2.2.6'
+macro_revision='1.3012'
+_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?])
+_LT_DECL(, macro_revision, 0)
+])
+
+# lt~obsolete.m4 -- aclocal satisfying obsolete definitions.    -*-Autoconf-*-
+#
+#   Copyright (C) 2004, 2005, 2007 Free Software Foundation, Inc.
+#   Written by Scott James Remnant, 2004.
+#
+# This file is free software; the Free Software Foundation gives
+# unlimited permission to copy and/or distribute it, with or without
+# modifications, as long as this notice is preserved.
+
+# serial 4 lt~obsolete.m4
+
+# These exist entirely to fool aclocal when bootstrapping libtool.
+#
+# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN)
+# which have later been changed to m4_define as they aren't part of the
+# exported API, or moved to Autoconf or Automake where they belong.
+#
+# The trouble is, aclocal is a bit thick.  It'll see the old AC_DEFUN
+# in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us
+# using a macro with the same name in our local m4/libtool.m4 it'll
+# pull the old libtool.m4 in (it doesn't see our shiny new m4_define
+# and doesn't know about Autoconf macros at all.)
+#
+# So we provide this file, which has a silly filename so it's always
+# included after everything else.  This provides aclocal with the
+# AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything
+# because those macros already exist, or will be overwritten later.
+# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. 
+#
+# Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here.
+# Yes, that means every name once taken will need to remain here until
+# we give up compatibility with versions before 1.7, at which point
+# we need to keep only those names which we still refer to.
+
+# This is to help aclocal find these macros, as it can't see m4_define.
+AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])])
+
+m4_ifndef([AC_LIBTOOL_LINKER_OPTION],  [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])])
+m4_ifndef([AC_PROG_EGREP],             [AC_DEFUN([AC_PROG_EGREP])])
+m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH],        [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])])
+m4_ifndef([_LT_AC_SHELL_INIT],         [AC_DEFUN([_LT_AC_SHELL_INIT])])
+m4_ifndef([_LT_AC_SYS_LIBPATH_AIX],    [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])])
+m4_ifndef([_LT_PROG_LTMAIN],           [AC_DEFUN([_LT_PROG_LTMAIN])])
+m4_ifndef([_LT_AC_TAGVAR],             [AC_DEFUN([_LT_AC_TAGVAR])])
+m4_ifndef([AC_LTDL_ENABLE_INSTALL],    [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])])
+m4_ifndef([AC_LTDL_PREOPEN],           [AC_DEFUN([AC_LTDL_PREOPEN])])
+m4_ifndef([_LT_AC_SYS_COMPILER],       [AC_DEFUN([_LT_AC_SYS_COMPILER])])
+m4_ifndef([_LT_AC_LOCK],               [AC_DEFUN([_LT_AC_LOCK])])
+m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE],        [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])])
+m4_ifndef([_LT_AC_TRY_DLOPEN_SELF],    [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])])
+m4_ifndef([AC_LIBTOOL_PROG_CC_C_O],    [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])])
+m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])])
+m4_ifndef([AC_LIBTOOL_OBJDIR],         [AC_DEFUN([AC_LIBTOOL_OBJDIR])])
+m4_ifndef([AC_LTDL_OBJDIR],            [AC_DEFUN([AC_LTDL_OBJDIR])])
+m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])])
+m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP],  [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])])
+m4_ifndef([AC_PATH_MAGIC],             [AC_DEFUN([AC_PATH_MAGIC])])
+m4_ifndef([AC_PROG_LD_GNU],            [AC_DEFUN([AC_PROG_LD_GNU])])
+m4_ifndef([AC_PROG_LD_RELOAD_FLAG],    [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])])
+m4_ifndef([AC_DEPLIBS_CHECK_METHOD],   [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])])
+m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])])
+m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])])
+m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])])
+m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])])
+m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])])
+m4_ifndef([LT_AC_PROG_EGREP],          [AC_DEFUN([LT_AC_PROG_EGREP])])
+m4_ifndef([LT_AC_PROG_SED],            [AC_DEFUN([LT_AC_PROG_SED])])
+m4_ifndef([_LT_CC_BASENAME],           [AC_DEFUN([_LT_CC_BASENAME])])
+m4_ifndef([_LT_COMPILER_BOILERPLATE],  [AC_DEFUN([_LT_COMPILER_BOILERPLATE])])
+m4_ifndef([_LT_LINKER_BOILERPLATE],    [AC_DEFUN([_LT_LINKER_BOILERPLATE])])
+m4_ifndef([_AC_PROG_LIBTOOL],          [AC_DEFUN([_AC_PROG_LIBTOOL])])
+m4_ifndef([AC_LIBTOOL_SETUP],          [AC_DEFUN([AC_LIBTOOL_SETUP])])
+m4_ifndef([_LT_AC_CHECK_DLFCN],                [AC_DEFUN([_LT_AC_CHECK_DLFCN])])
+m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER],     [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])])
+m4_ifndef([_LT_AC_TAGCONFIG],          [AC_DEFUN([_LT_AC_TAGCONFIG])])
+m4_ifndef([AC_DISABLE_FAST_INSTALL],   [AC_DEFUN([AC_DISABLE_FAST_INSTALL])])
+m4_ifndef([_LT_AC_LANG_CXX],           [AC_DEFUN([_LT_AC_LANG_CXX])])
+m4_ifndef([_LT_AC_LANG_F77],           [AC_DEFUN([_LT_AC_LANG_F77])])
+m4_ifndef([_LT_AC_LANG_GCJ],           [AC_DEFUN([_LT_AC_LANG_GCJ])])
+m4_ifndef([AC_LIBTOOL_RC],             [AC_DEFUN([AC_LIBTOOL_RC])])
+m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG],  [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])])
+m4_ifndef([_LT_AC_LANG_C_CONFIG],      [AC_DEFUN([_LT_AC_LANG_C_CONFIG])])
+m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG],        [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])])
+m4_ifndef([_LT_AC_LANG_CXX_CONFIG],    [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])])
+m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG],        [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])])
+m4_ifndef([_LT_AC_LANG_F77_CONFIG],    [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])])
+m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG],        [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])])
+m4_ifndef([_LT_AC_LANG_GCJ_CONFIG],    [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])])
+m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])])
+m4_ifndef([_LT_AC_LANG_RC_CONFIG],     [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])])
+m4_ifndef([AC_LIBTOOL_CONFIG],         [AC_DEFUN([AC_LIBTOOL_CONFIG])])
+m4_ifndef([_LT_AC_FILE_LTDLL_C],       [AC_DEFUN([_LT_AC_FILE_LTDLL_C])])
+
+# pkg.m4 - Macros to locate and utilise pkg-config.            -*- Autoconf -*-
+#
+# Copyright © 2004 Scott James Remnant <scott@netsplit.com>.
+#
+# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+#
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+# PKG_PROG_PKG_CONFIG([MIN-VERSION])
+# ----------------------------------
+AC_DEFUN([PKG_PROG_PKG_CONFIG],
+[m4_pattern_forbid([^_?PKG_[A-Z_]+$])
+m4_pattern_allow([^PKG_CONFIG(_PATH)?$])
+AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility])dnl
+if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then
+       AC_PATH_TOOL([PKG_CONFIG], [pkg-config])
+fi
+if test -n "$PKG_CONFIG"; then
+       _pkg_min_version=m4_default([$1], [0.9.0])
+       AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version])
+       if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then
+               AC_MSG_RESULT([yes])
+       else
+               AC_MSG_RESULT([no])
+               PKG_CONFIG=""
+       fi
+
+fi[]dnl
+])# PKG_PROG_PKG_CONFIG
+
+# PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
+#
+# Check to see whether a particular set of modules exists.  Similar
+# to PKG_CHECK_MODULES(), but does not set variables or print errors.
+#
+#
+# Similar to PKG_CHECK_MODULES, make sure that the first instance of
+# this or PKG_CHECK_MODULES is called, or make sure to call
+# PKG_CHECK_EXISTS manually
+# --------------------------------------------------------------
+AC_DEFUN([PKG_CHECK_EXISTS],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+if test -n "$PKG_CONFIG" && \
+    AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then
+  m4_ifval([$2], [$2], [:])
+m4_ifvaln([$3], [else
+  $3])dnl
+fi])
+
+
+# _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES])
+# ---------------------------------------------
+m4_define([_PKG_CONFIG],
+[if test -n "$PKG_CONFIG"; then
+    if test -n "$$1"; then
+        pkg_cv_[]$1="$$1"
+    else
+        PKG_CHECK_EXISTS([$3],
+                         [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null`],
+                        [pkg_failed=yes])
+    fi
+else
+       pkg_failed=untried
+fi[]dnl
+])# _PKG_CONFIG
+
+# _PKG_SHORT_ERRORS_SUPPORTED
+# -----------------------------
+AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])
+if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
+        _pkg_short_errors_supported=yes
+else
+        _pkg_short_errors_supported=no
+fi[]dnl
+])# _PKG_SHORT_ERRORS_SUPPORTED
+
+
+# PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND],
+# [ACTION-IF-NOT-FOUND])
+#
+#
+# Note that if there is a possibility the first call to
+# PKG_CHECK_MODULES might not happen, you should be sure to include an
+# explicit call to PKG_PROG_PKG_CONFIG in your configure.ac
+#
+#
+# --------------------------------------------------------------
+AC_DEFUN([PKG_CHECK_MODULES],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl
+AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl
+
+pkg_failed=no
+AC_MSG_CHECKING([for $1])
+
+_PKG_CONFIG([$1][_CFLAGS], [cflags], [$2])
+_PKG_CONFIG([$1][_LIBS], [libs], [$2])
+
+m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS
+and $1[]_LIBS to avoid the need to call pkg-config.
+See the pkg-config man page for more details.])
+
+if test $pkg_failed = yes; then
+        _PKG_SHORT_ERRORS_SUPPORTED
+        if test $_pkg_short_errors_supported = yes; then
+               $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "$2"`
+        else
+               $1[]_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "$2"`
+        fi
+       # Put the nasty error message in config.log where it belongs
+       echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD
+
+       ifelse([$4], , [AC_MSG_ERROR(dnl
+[Package requirements ($2) were not met:
+
+$$1_PKG_ERRORS
+
+Consider adjusting the PKG_CONFIG_PATH environment variable if you
+installed software in a non-standard prefix.
+
+_PKG_TEXT
+])],
+               [AC_MSG_RESULT([no])
+                $4])
+elif test $pkg_failed = untried; then
+       ifelse([$4], , [AC_MSG_FAILURE(dnl
+[The pkg-config script could not be found or is too old.  Make sure it
+is in your PATH or set the PKG_CONFIG environment variable to the full
+path to pkg-config.
+
+_PKG_TEXT
+
+To get pkg-config, see <http://pkg-config.freedesktop.org/>.])],
+               [$4])
+else
+       $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS
+       $1[]_LIBS=$pkg_cv_[]$1[]_LIBS
+        AC_MSG_RESULT([yes])
+       ifelse([$3], , :, [$3])
+fi[]dnl
+])# PKG_CHECK_MODULES
+
+# Configure paths for libogg
+# Jack Moffitt <jack@icecast.org> 10-21-2000
+# Shamelessly stolen from Owen Taylor and Manish Singh
+
+dnl XIPH_PATH_OGG([ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]])
+dnl Test for libogg, and define OGG_CFLAGS and OGG_LIBS
+dnl
+AC_DEFUN([XIPH_PATH_OGG],
+[dnl 
+dnl Get the cflags and libraries
+dnl
+AC_ARG_WITH(ogg,AC_HELP_STRING([--with-ogg=PFX],[Prefix where libogg is installed (optional)]), ogg_prefix="$withval", ogg_prefix="")
+AC_ARG_WITH(ogg-libraries,AC_HELP_STRING([--with-ogg-libraries=DIR],[Directory where libogg library is installed (optional)]), ogg_libraries="$withval", ogg_libraries="")
+AC_ARG_WITH(ogg-includes,AC_HELP_STRING([--with-ogg-includes=DIR],[Directory where libogg header files are installed (optional)]), ogg_includes="$withval", ogg_includes="")
+AC_ARG_ENABLE(oggtest,AC_HELP_STRING([--disable-oggtest],[Do not try to compile and run a test Ogg program]),, enable_oggtest=yes)
+
+  if test "x$ogg_libraries" != "x" ; then
+    OGG_LIBS="-L$ogg_libraries"
+  elif test "x$ogg_prefix" = "xno" || test "x$ogg_prefix" = "xyes" ; then
+    OGG_LIBS=""
+  elif test "x$ogg_prefix" != "x" ; then
+    OGG_LIBS="-L$ogg_prefix/lib"
+  elif test "x$prefix" != "xNONE" ; then
+    OGG_LIBS="-L$libdir"
+  fi
+
+  if test "x$ogg_prefix" != "xno" ; then
+    OGG_LIBS="$OGG_LIBS -logg"
+  fi
+
+  if test "x$ogg_includes" != "x" ; then
+    OGG_CFLAGS="-I$ogg_includes"
+  elif test "x$ogg_prefix" = "xno" || test "x$ogg_prefix" = "xyes" ; then
+    OGG_CFLAGS=""
+  elif test "x$ogg_prefix" != "x" ; then
+    OGG_CFLAGS="-I$ogg_prefix/include"
+  elif test "x$prefix" != "xNONE"; then
+    OGG_CFLAGS=""
+  fi
+
+  AC_MSG_CHECKING(for Ogg)
+  if test "x$ogg_prefix" = "xno" ; then
+    no_ogg="disabled"
+    enable_oggtest="no"
+  else
+    no_ogg=""
+  fi
+
+
+  if test "x$enable_oggtest" = "xyes" ; then
+    ac_save_CFLAGS="$CFLAGS"
+    ac_save_LIBS="$LIBS"
+    CFLAGS="$CFLAGS $OGG_CFLAGS"
+    LIBS="$LIBS $OGG_LIBS"
+dnl
+dnl Now check if the installed Ogg is sufficiently new.
+dnl
+      rm -f conf.oggtest
+      AC_TRY_RUN([
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+
+int main ()
+{
+  system("touch conf.oggtest");
+  return 0;
+}
+
+],, no_ogg=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+  fi
+
+  if test "x$no_ogg" = "xdisabled" ; then
+     AC_MSG_RESULT(no)
+     ifelse([$2], , :, [$2])
+  elif test "x$no_ogg" = "x" ; then
+     AC_MSG_RESULT(yes)
+     ifelse([$1], , :, [$1])
+  else
+     AC_MSG_RESULT(no)
+     if test -f conf.oggtest ; then
+       :
+     else
+       echo "*** Could not run Ogg test program, checking why..."
+       CFLAGS="$CFLAGS $OGG_CFLAGS"
+       LIBS="$LIBS $OGG_LIBS"
+       AC_TRY_LINK([
+#include <stdio.h>
+#include <ogg/ogg.h>
+],     [ return 0; ],
+       [ echo "*** The test program compiled, but did not run. This usually means"
+       echo "*** that the run-time linker is not finding Ogg or finding the wrong"
+       echo "*** version of Ogg. If it is not finding Ogg, you'll need to set your"
+       echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+       echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+       echo "*** is required on your system"
+       echo "***"
+       echo "*** If you have an old version installed, it is best to remove it, although"
+       echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"],
+       [ echo "*** The test program failed to compile or link. See the file config.log for the"
+       echo "*** exact error that occured. This usually means Ogg was incorrectly installed"
+       echo "*** or that you have moved Ogg since it was installed." ])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+     OGG_CFLAGS=""
+     OGG_LIBS=""
+     ifelse([$2], , :, [$2])
+  fi
+  AC_SUBST(OGG_CFLAGS)
+  AC_SUBST(OGG_LIBS)
+  rm -f conf.oggtest
+])
+
+# Configure paths for libvorbis
+# Jack Moffitt <jack@icecast.org> 10-21-2000
+# Shamelessly stolen from Owen Taylor and Manish Singh
+# thomasvs added check for vorbis_bitrate_addblock which is new in rc3
+
+dnl XIPH_PATH_VORBIS([ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]])
+dnl Test for libvorbis, and define VORBIS_CFLAGS and VORBIS_LIBS
+dnl
+AC_DEFUN([XIPH_PATH_VORBIS],
+[dnl 
+dnl Get the cflags and libraries
+dnl
+AC_ARG_WITH(vorbis,[  --with-vorbis=PFX   Prefix where libvorbis is installed (optional)], vorbis_prefix="$withval", vorbis_prefix="")
+AC_ARG_WITH(vorbis-libraries,[  --with-vorbis-libraries=DIR   Directory where libvorbis library is installed (optional)], vorbis_libraries="$withval", vorbis_libraries="")
+AC_ARG_WITH(vorbis-includes,[  --with-vorbis-includes=DIR   Directory where libvorbis header files are installed (optional)], vorbis_includes="$withval", vorbis_includes="")
+AC_ARG_ENABLE(vorbistest, [  --disable-vorbistest    Do not try to compile and run a test Vorbis program],, enable_vorbistest=yes)
+
+  if test "x$vorbis_libraries" != "x" ; then
+    VORBIS_LIBS="-L$vorbis_libraries"
+  elif test "x$vorbis_prefix" != "x" ; then
+    VORBIS_LIBS="-L$vorbis_prefix/lib"
+  elif test "x$prefix" != "xNONE"; then
+    VORBIS_LIBS="-L$libdir"
+  fi
+
+  VORBIS_LIBS="$VORBIS_LIBS -lvorbis -lm"
+  VORBISFILE_LIBS="-lvorbisfile"
+  VORBISENC_LIBS="-lvorbisenc"
+
+  if test "x$vorbis_includes" != "x" ; then
+    VORBIS_CFLAGS="-I$vorbis_includes"
+  elif test "x$vorbis_prefix" != "x" ; then
+    VORBIS_CFLAGS="-I$vorbis_prefix/include"
+  elif test "x$prefix" != "xNONE"; then
+    VORBIS_CFLAGS=""
+  fi
+
+
+  AC_MSG_CHECKING(for Vorbis)
+  no_vorbis=""
+
+
+  if test "x$enable_vorbistest" = "xyes" ; then
+    ac_save_CFLAGS="$CFLAGS"
+    ac_save_LIBS="$LIBS"
+    CFLAGS="$CFLAGS $VORBIS_CFLAGS $OGG_CFLAGS"
+    LIBS="$LIBS $VORBIS_LIBS $VORBISENC_LIBS $OGG_LIBS"
+dnl
+dnl Now check if the installed Vorbis is sufficiently new.
+dnl
+      rm -f conf.vorbistest
+      AC_TRY_RUN([
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <vorbis/codec.h>
+#include <vorbis/vorbisenc.h>
+
+int main ()
+{
+    vorbis_block       vb;
+    vorbis_dsp_state   vd;
+    vorbis_info                vi;
+
+    vorbis_info_init (&vi);
+    vorbis_encode_init (&vi, 2, 44100, -1, 128000, -1);
+    vorbis_analysis_init (&vd, &vi);
+    vorbis_block_init (&vd, &vb);
+    /* this function was added in 1.0rc3, so this is what we're testing for */
+    vorbis_bitrate_addblock (&vb);
+
+    system("touch conf.vorbistest");
+    return 0;
+}
+
+],, no_vorbis=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+  fi
+
+  if test "x$no_vorbis" = "x" ; then
+     AC_MSG_RESULT(yes)
+     ifelse([$1], , :, [$1])     
+  else
+     AC_MSG_RESULT(no)
+     if test -f conf.vorbistest ; then
+       :
+     else
+       echo "*** Could not run Vorbis test program, checking why..."
+       CFLAGS="$CFLAGS $VORBIS_CFLAGS"
+       LIBS="$LIBS $VORBIS_LIBS $OGG_LIBS"
+       AC_TRY_LINK([
+#include <stdio.h>
+#include <vorbis/codec.h>
+],     [ return 0; ],
+       [ echo "*** The test program compiled, but did not run. This usually means"
+       echo "*** that the run-time linker is not finding Vorbis or finding the wrong"
+       echo "*** version of Vorbis. If it is not finding Vorbis, you'll need to set your"
+       echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+       echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+       echo "*** is required on your system"
+       echo "***"
+       echo "*** If you have an old version installed, it is best to remove it, although"
+       echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"],
+       [ echo "*** The test program failed to compile or link. See the file config.log for the"
+       echo "*** exact error that occured. This usually means Vorbis was incorrectly installed"
+       echo "*** or that you have moved Vorbis since it was installed." ])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+     VORBIS_CFLAGS=""
+     VORBIS_LIBS=""
+     VORBISFILE_LIBS=""
+     VORBISENC_LIBS=""
+     ifelse([$2], , :, [$2])
+  fi
+  AC_SUBST(VORBIS_CFLAGS)
+  AC_SUBST(VORBIS_LIBS)
+  AC_SUBST(VORBISFILE_LIBS)
+  AC_SUBST(VORBISENC_LIBS)
+  rm -f conf.vorbistest
+])
+
+# Configure paths for SDL
+# Sam Lantinga 9/21/99
+# stolen from Manish Singh
+# stolen back from Frank Belew
+# stolen from Manish Singh
+# Shamelessly stolen from Owen Taylor
+
+dnl AM_PATH_SDL([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]])
+dnl Test for SDL, and define SDL_CFLAGS and SDL_LIBS
+dnl
+AC_DEFUN([AM_PATH_SDL],
+[dnl 
+dnl Get the cflags and libraries from the sdl-config script
+dnl
+AC_ARG_WITH(sdl-prefix,[  --with-sdl-prefix=PFX   Prefix where SDL is installed (optional)],
+            sdl_prefix="$withval", sdl_prefix="")
+AC_ARG_WITH(sdl-exec-prefix,[  --with-sdl-exec-prefix=PFX Exec prefix where SDL is installed (optional)],
+            sdl_exec_prefix="$withval", sdl_exec_prefix="")
+AC_ARG_ENABLE(sdltest, [  --disable-sdltest       Do not try to compile and run a test SDL program],
+                   , enable_sdltest=yes)
+
+  if test x$sdl_exec_prefix != x ; then
+     sdl_args="$sdl_args --exec-prefix=$sdl_exec_prefix"
+     if test x${SDL_CONFIG+set} != xset ; then
+        SDL_CONFIG=$sdl_exec_prefix/bin/sdl-config
+     fi
+  fi
+  if test x$sdl_prefix != x ; then
+     sdl_args="$sdl_args --prefix=$sdl_prefix"
+     if test x${SDL_CONFIG+set} != xset ; then
+        SDL_CONFIG=$sdl_prefix/bin/sdl-config
+     fi
+  fi
+
+  AC_REQUIRE([AC_CANONICAL_TARGET])
+  PATH="$prefix/bin:$prefix/usr/bin:$PATH"
+  AC_PATH_PROG(SDL_CONFIG, sdl-config, no, [$PATH])
+  min_sdl_version=ifelse([$1], ,0.11.0,$1)
+  AC_MSG_CHECKING(for SDL - version >= $min_sdl_version)
+  no_sdl=""
+  if test "$SDL_CONFIG" = "no" ; then
+    no_sdl=yes
+  else
+    SDL_CFLAGS=`$SDL_CONFIG $sdlconf_args --cflags`
+    SDL_LIBS=`$SDL_CONFIG $sdlconf_args --libs`
+
+    sdl_major_version=`$SDL_CONFIG $sdl_args --version | \
+           sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
+    sdl_minor_version=`$SDL_CONFIG $sdl_args --version | \
+           sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
+    sdl_micro_version=`$SDL_CONFIG $sdl_config_args --version | \
+           sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
+    if test "x$enable_sdltest" = "xyes" ; then
+      ac_save_CFLAGS="$CFLAGS"
+      ac_save_CXXFLAGS="$CXXFLAGS"
+      ac_save_LIBS="$LIBS"
+      CFLAGS="$CFLAGS $SDL_CFLAGS"
+      CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
+      LIBS="$LIBS $SDL_LIBS"
+dnl
+dnl Now check if the installed SDL is sufficiently new. (Also sanity
+dnl checks the results of sdl-config to some extent
+dnl
+      rm -f conf.sdltest
+      AC_TRY_RUN([
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include "SDL.h"
+
+char*
+my_strdup (char *str)
+{
+  char *new_str;
+  
+  if (str)
+    {
+      new_str = (char *)malloc ((strlen (str) + 1) * sizeof(char));
+      strcpy (new_str, str);
+    }
+  else
+    new_str = NULL;
+  
+  return new_str;
+}
+
+int main (int argc, char *argv[])
+{
+  int major, minor, micro;
+  char *tmp_version;
+
+  /* This hangs on some systems (?)
+  system ("touch conf.sdltest");
+  */
+  { FILE *fp = fopen("conf.sdltest", "a"); if ( fp ) fclose(fp); }
+
+  /* HP/UX 9 (%@#!) writes to sscanf strings */
+  tmp_version = my_strdup("$min_sdl_version");
+  if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
+     printf("%s, bad version string\n", "$min_sdl_version");
+     exit(1);
+   }
+
+   if (($sdl_major_version > major) ||
+      (($sdl_major_version == major) && ($sdl_minor_version > minor)) ||
+      (($sdl_major_version == major) && ($sdl_minor_version == minor) && ($sdl_micro_version >= micro)))
+    {
+      return 0;
+    }
+  else
+    {
+      printf("\n*** 'sdl-config --version' returned %d.%d.%d, but the minimum version\n", $sdl_major_version, $sdl_minor_version, $sdl_micro_version);
+      printf("*** of SDL required is %d.%d.%d. If sdl-config is correct, then it is\n", major, minor, micro);
+      printf("*** best to upgrade to the required version.\n");
+      printf("*** If sdl-config was wrong, set the environment variable SDL_CONFIG\n");
+      printf("*** to point to the correct copy of sdl-config, and remove the file\n");
+      printf("*** config.cache before re-running configure\n");
+      return 1;
+    }
+}
+
+],, no_sdl=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+       CFLAGS="$ac_save_CFLAGS"
+       CXXFLAGS="$ac_save_CXXFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+  fi
+  if test "x$no_sdl" = x ; then
+     AC_MSG_RESULT(yes)
+     ifelse([$2], , :, [$2])     
+  else
+     AC_MSG_RESULT(no)
+     if test "$SDL_CONFIG" = "no" ; then
+       echo "*** The sdl-config script installed by SDL could not be found"
+       echo "*** If SDL was installed in PREFIX, make sure PREFIX/bin is in"
+       echo "*** your path, or set the SDL_CONFIG environment variable to the"
+       echo "*** full path to sdl-config."
+     else
+       if test -f conf.sdltest ; then
+        :
+       else
+          echo "*** Could not run SDL test program, checking why..."
+          CFLAGS="$CFLAGS $SDL_CFLAGS"
+          CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
+          LIBS="$LIBS $SDL_LIBS"
+          AC_TRY_LINK([
+#include <stdio.h>
+#include "SDL.h"
+
+int main(int argc, char *argv[])
+{ return 0; }
+#undef  main
+#define main K_and_R_C_main
+],      [ return 0; ],
+        [ echo "*** The test program compiled, but did not run. This usually means"
+          echo "*** that the run-time linker is not finding SDL or finding the wrong"
+          echo "*** version of SDL. If it is not finding SDL, you'll need to set your"
+          echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+          echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+          echo "*** is required on your system"
+         echo "***"
+          echo "*** If you have an old version installed, it is best to remove it, although"
+          echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"],
+        [ echo "*** The test program failed to compile or link. See the file config.log for the"
+          echo "*** exact error that occured. This usually means SDL was incorrectly installed"
+          echo "*** or that you have moved SDL since it was installed. In the latter case, you"
+          echo "*** may want to edit the sdl-config script: $SDL_CONFIG" ])
+          CFLAGS="$ac_save_CFLAGS"
+          CXXFLAGS="$ac_save_CXXFLAGS"
+          LIBS="$ac_save_LIBS"
+       fi
+     fi
+     SDL_CFLAGS=""
+     SDL_LIBS=""
+     ifelse([$3], , :, [$3])
+  fi
+  AC_SUBST(SDL_CFLAGS)
+  AC_SUBST(SDL_LIBS)
+  rm -f conf.sdltest
+])
+
+dnl as-ac-expand.m4 0.2.0
+dnl autostars m4 macro for expanding directories using configure's prefix
+dnl thomas@apestaart.org
+
+dnl AS_AC_EXPAND(VAR, CONFIGURE_VAR)
+dnl example
+dnl AS_AC_EXPAND(SYSCONFDIR, $sysconfdir)
+dnl will set SYSCONFDIR to /usr/local/etc if prefix=/usr/local
+
+AC_DEFUN([AS_AC_EXPAND],
+[
+  EXP_VAR=[$1]
+  FROM_VAR=[$2]
+
+  dnl first expand prefix and exec_prefix if necessary
+  prefix_save=$prefix
+  exec_prefix_save=$exec_prefix
+
+  dnl if no prefix given, then use /usr/local, the default prefix
+  if test "x$prefix" = "xNONE"; then
+    prefix="$ac_default_prefix"
+  fi
+  dnl if no exec_prefix given, then use prefix
+  if test "x$exec_prefix" = "xNONE"; then
+    exec_prefix=$prefix
+  fi
+
+  full_var="$FROM_VAR"
+  dnl loop until it doesn't change anymore
+  while true; do
+    new_full_var="`eval echo $full_var`"
+    if test "x$new_full_var" = "x$full_var"; then break; fi
+    full_var=$new_full_var
+  done
+
+  dnl clean up
+  full_var=$new_full_var
+  AC_SUBST([$1], "$full_var")
+
+  dnl restore prefix and exec_prefix
+  prefix=$prefix_save
+  exec_prefix=$exec_prefix_save
+])
+
diff --git a/autogen.sh b/autogen.sh
new file mode 100755 (executable)
index 0000000..bbca69d
--- /dev/null
@@ -0,0 +1,129 @@
+#!/bin/sh
+# Run this to set up the build system: configure, makefiles, etc.
+# (based on the version in enlightenment's cvs)
+
+package="theora"
+
+ACLOCAL_FLAGS="-I m4"
+
+olddir=`pwd`
+srcdir=`dirname $0`
+test -z "$srcdir" && srcdir=.
+
+cd "$srcdir"
+DIE=0
+
+echo "checking for autoconf... "
+(autoconf --version) < /dev/null > /dev/null 2>&1 || {
+        echo
+        echo "You must have autoconf installed to compile $package."
+        echo "Download the appropriate package for your distribution,"
+        echo "or get the source tarball at ftp://ftp.gnu.org/pub/gnu/"
+        DIE=1
+}
+
+VERSIONGREP="sed -e s/.*[^0-9\.]\([0-9][0-9]*\.[0-9][0-9]*\).*/\1/"
+VERSIONMKMAJ="sed -e s/\([0-9][0-9]*\)[^0-9].*/\\1/"
+VERSIONMKMIN="sed -e s/.*[0-9][0-9]*\.//"
+
+# do we need automake?
+if test -r Makefile.am; then
+  AM_OPTIONS=`fgrep AUTOMAKE_OPTIONS Makefile.am`
+  AM_NEEDED=`echo $AM_OPTIONS | $VERSIONGREP`
+  if test x"$AM_NEEDED" = "x$AM_OPTIONS"; then
+    AM_NEEDED=""
+  fi
+  if test -z $AM_NEEDED; then
+    echo -n "checking for automake... "
+    AUTOMAKE=automake
+    ACLOCAL=aclocal
+    if ($AUTOMAKE --version < /dev/null > /dev/null 2>&1); then
+      echo "yes"
+    else
+      echo "no"
+      AUTOMAKE=
+    fi
+  else
+    echo -n "checking for automake $AM_NEEDED or later... "
+    majneeded=`echo $AM_NEEDED | $VERSIONMKMAJ`
+    minneeded=`echo $AM_NEEDED | $VERSIONMKMIN`
+    for am in automake-$AM_NEEDED automake$AM_NEEDED \
+       automake automake-1.7 automake-1.8 automake-1.9 automake-1.10; do
+      ($am --version < /dev/null > /dev/null 2>&1) || continue
+      ver=`$am --version < /dev/null | head -n 1 | $VERSIONGREP`
+      maj=`echo $ver | $VERSIONMKMAJ`
+      min=`echo $ver | $VERSIONMKMIN`
+      if test $maj -eq $majneeded -a $min -ge $minneeded; then
+        AUTOMAKE=$am
+        echo $AUTOMAKE
+        break
+      fi
+    done
+    test -z $AUTOMAKE &&  echo "no"
+    echo -n "checking for aclocal $AM_NEEDED or later... "
+    for ac in aclocal-$AM_NEEDED aclocal$AM_NEEDED \
+       aclocal aclocal-1.7 aclocal-1.8 aclocal-1.9 aclocal-1.10; do
+      ($ac --version < /dev/null > /dev/null 2>&1) || continue
+      ver=`$ac --version < /dev/null | head -n 1 | $VERSIONGREP`
+      maj=`echo $ver | $VERSIONMKMAJ`
+      min=`echo $ver | $VERSIONMKMIN`
+      if test $maj -eq $majneeded -a $min -ge $minneeded; then
+        ACLOCAL=$ac
+        echo $ACLOCAL
+        break
+      fi
+    done
+    test -z $ACLOCAL && echo "no"
+  fi
+  test -z $AUTOMAKE || test -z $ACLOCAL && {
+        echo
+        echo "You must have automake installed to compile $package."
+        echo "Download the appropriate package for your distribution,"
+        echo "or get the source tarball at ftp://ftp.gnu.org/pub/gnu/"
+        exit 1
+  }
+fi
+
+echo -n "checking for libtool... "
+for LIBTOOLIZE in libtoolize glibtoolize nope; do
+  ($LIBTOOLIZE --version) < /dev/null > /dev/null 2>&1 && break
+done
+if test x$LIBTOOLIZE = xnope; then
+  echo "nope."
+  LIBTOOLIZE=libtoolize
+else
+  echo $LIBTOOLIZE
+fi
+($LIBTOOLIZE --version) < /dev/null > /dev/null 2>&1 || {
+       echo
+       echo "You must have libtool installed to compile $package."
+       echo "Download the appropriate package for your system,"
+       echo "or get the source from one of the GNU ftp sites"
+       echo "listed in http://www.gnu.org/order/ftp.html"
+       DIE=1
+}
+
+if test "$DIE" -eq 1; then
+        exit 1
+fi
+
+if test -z "$*"; then
+        echo "I am going to run ./configure with no arguments - if you wish "
+        echo "to pass any to it, please specify them on the $0 command line."
+fi
+
+echo "Generating configuration files for $package, please wait...."
+
+echo "  $ACLOCAL $ACLOCAL_FLAGS"
+$ACLOCAL $ACLOCAL_FLAGS || exit 1
+echo "  $LIBTOOLIZE --automake --force"
+$LIBTOOLIZE --automake --force || exit 1
+echo "  autoheader"
+autoheader || exit 1
+echo "  $AUTOMAKE --add-missing $AUTOMAKE_FLAGS"
+$AUTOMAKE --add-missing $AUTOMAKE_FLAGS || exit 1
+echo "  autoconf"
+autoconf || exit 1
+
+cd $olddir
+$srcdir/configure --enable-maintainer-mode "$@" && echo
diff --git a/compile b/compile
new file mode 100755 (executable)
index 0000000..9bb997a
--- /dev/null
+++ b/compile
@@ -0,0 +1,99 @@
+#! /bin/sh
+
+# Wrapper for compilers which do not understand `-c -o'.
+
+# Copyright 1999, 2000 Free Software Foundation, Inc.
+# Written by Tom Tromey <tromey@cygnus.com>.
+#
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+# Usage:
+# compile PROGRAM [ARGS]...
+# `-o FOO.o' is removed from the args passed to the actual compile.
+
+prog=$1
+shift
+
+ofile=
+cfile=
+args=
+while test $# -gt 0; do
+   case "$1" in
+    -o)
+       # configure might choose to run compile as `compile cc -o foo foo.c'.
+       # So we do something ugly here.
+       ofile=$2
+       shift
+       case "$ofile" in
+       *.o | *.obj)
+          ;;
+       *)
+          args="$args -o $ofile"
+          ofile=
+          ;;
+       esac
+       ;;
+    *.c)
+       cfile=$1
+       args="$args $1"
+       ;;
+    *)
+       args="$args $1"
+       ;;
+   esac
+   shift
+done
+
+if test -z "$ofile" || test -z "$cfile"; then
+   # If no `-o' option was seen then we might have been invoked from a
+   # pattern rule where we don't need one.  That is ok -- this is a
+   # normal compilation that the losing compiler can handle.  If no
+   # `.c' file was seen then we are probably linking.  That is also
+   # ok.
+   exec "$prog" $args
+fi
+
+# Name of file we expect compiler to create.
+cofile=`echo $cfile | sed -e 's|^.*/||' -e 's/\.c$/.o/'`
+
+# Create the lock directory.
+# Note: use `[/.-]' here to ensure that we don't use the same name
+# that we are using for the .o file.  Also, base the name on the expected
+# object file name, since that is what matters with a parallel build.
+lockdir=`echo $cofile | sed -e 's|[/.-]|_|g'`.d
+while true; do
+   if mkdir $lockdir > /dev/null 2>&1; then
+      break
+   fi
+   sleep 1
+done
+# FIXME: race condition here if user kills between mkdir and trap.
+trap "rmdir $lockdir; exit 1" 1 2 15
+
+# Run the compile.
+"$prog" $args
+status=$?
+
+if test -f "$cofile"; then
+   mv "$cofile" "$ofile"
+fi
+
+rmdir $lockdir
+exit $status
diff --git a/config.guess b/config.guess
new file mode 100755 (executable)
index 0000000..45bee13
--- /dev/null
@@ -0,0 +1,1465 @@
+#! /bin/sh
+# Attempt to guess a canonical system name.
+#   Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
+#   2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
+
+timestamp='2005-04-22'
+
+# This file 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+#
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+# Originally written by Per Bothner <per@bothner.com>.
+# Please send patches to <config-patches@gnu.org>.  Submit a context
+# diff and a properly formatted ChangeLog entry.
+#
+# This script attempts to guess a canonical system name similar to
+# config.sub.  If it succeeds, it prints the system name on stdout, and
+# exits with 0.  Otherwise, it exits with 1.
+#
+# The plan is that this can be called by configure scripts if you
+# don't specify an explicit build system type.
+
+me=`echo "$0" | sed -e 's,.*/,,'`
+
+usage="\
+Usage: $0 [OPTION]
+
+Output the configuration name of the system \`$me' is run on.
+
+Operation modes:
+  -h, --help         print this help, then exit
+  -t, --time-stamp   print date of last modification, then exit
+  -v, --version      print version number, then exit
+
+Report bugs and patches to <config-patches@gnu.org>."
+
+version="\
+GNU config.guess ($timestamp)
+
+Originally written by Per Bothner.
+Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
+Free Software Foundation, Inc.
+
+This is free software; see the source for copying conditions.  There is NO
+warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
+
+help="
+Try \`$me --help' for more information."
+
+# Parse command line
+while test $# -gt 0 ; do
+  case $1 in
+    --time-stamp | --time* | -t )
+       echo "$timestamp" ; exit 0 ;;
+    --version | -v )
+       echo "$version" ; exit 0 ;;
+    --help | --h* | -h )
+       echo "$usage"; exit 0 ;;
+    -- )     # Stop option processing
+       shift; break ;;
+    - )        # Use stdin as input.
+       break ;;
+    -* )
+       echo "$me: invalid option $1$help" >&2
+       exit 1 ;;
+    * )
+       break ;;
+  esac
+done
+
+if test $# != 0; then
+  echo "$me: too many arguments$help" >&2
+  exit 1
+fi
+
+trap 'exit 1' 1 2 15
+
+# CC_FOR_BUILD -- compiler used by this script. Note that the use of a
+# compiler to aid in system detection is discouraged as it requires
+# temporary files to be created and, as you can see below, it is a
+# headache to deal with in a portable fashion.
+
+# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
+# use `HOST_CC' if defined, but it is deprecated.
+
+# Portable tmp directory creation inspired by the Autoconf team.
+
+set_cc_for_build='
+trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ;
+trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ;
+: ${TMPDIR=/tmp} ;
+ { tmp=`(umask 077 && mktemp -d -q "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } ||
+ { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } ||
+ { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } ||
+ { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ;
+dummy=$tmp/dummy ;
+tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ;
+case $CC_FOR_BUILD,$HOST_CC,$CC in
+ ,,)    echo "int x;" > $dummy.c ;
+       for c in cc gcc c89 c99 ; do
+         if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then
+            CC_FOR_BUILD="$c"; break ;
+         fi ;
+       done ;
+       if test x"$CC_FOR_BUILD" = x ; then
+         CC_FOR_BUILD=no_compiler_found ;
+       fi
+       ;;
+ ,,*)   CC_FOR_BUILD=$CC ;;
+ ,*,*)  CC_FOR_BUILD=$HOST_CC ;;
+esac ;'
+
+# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
+# (ghazi@noc.rutgers.edu 1994-08-24)
+if (test -f /.attbin/uname) >/dev/null 2>&1 ; then
+       PATH=$PATH:/.attbin ; export PATH
+fi
+
+UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown
+UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
+UNAME_SYSTEM=`(uname -s) 2>/dev/null`  || UNAME_SYSTEM=unknown
+UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
+
+# Note: order is significant - the case branches are not exclusive.
+
+case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
+    *:NetBSD:*:*)
+       # NetBSD (nbsd) targets should (where applicable) match one or
+       # more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*,
+       # *-*-netbsdecoff* and *-*-netbsd*.  For targets that recently
+       # switched to ELF, *-*-netbsd* would select the old
+       # object file format.  This provides both forward
+       # compatibility and a consistent mechanism for selecting the
+       # object file format.
+       #
+       # Note: NetBSD doesn't particularly care about the vendor
+       # portion of the name.  We always set it to "unknown".
+       sysctl="sysctl -n hw.machine_arch"
+       UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \
+           /usr/sbin/$sysctl 2>/dev/null || echo unknown)`
+       case "${UNAME_MACHINE_ARCH}" in
+           armeb) machine=armeb-unknown ;;
+           arm*) machine=arm-unknown ;;
+           sh3el) machine=shl-unknown ;;
+           sh3eb) machine=sh-unknown ;;
+           *) machine=${UNAME_MACHINE_ARCH}-unknown ;;
+       esac
+       # The Operating System including object format, if it has switched
+       # to ELF recently, or will in the future.
+       case "${UNAME_MACHINE_ARCH}" in
+           arm*|i386|m68k|ns32k|sh3*|sparc|vax)
+               eval $set_cc_for_build
+               if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
+                       | grep __ELF__ >/dev/null
+               then
+                   # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout).
+                   # Return netbsd for either.  FIX?
+                   os=netbsd
+               else
+                   os=netbsdelf
+               fi
+               ;;
+           *)
+               os=netbsd
+               ;;
+       esac
+       # The OS release
+       # Debian GNU/NetBSD machines have a different userland, and
+       # thus, need a distinct triplet. However, they do not need
+       # kernel version information, so it can be replaced with a
+       # suitable tag, in the style of linux-gnu.
+       case "${UNAME_VERSION}" in
+           Debian*)
+               release='-gnu'
+               ;;
+           *)
+               release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
+               ;;
+       esac
+       # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
+       # contains redundant information, the shorter form:
+       # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
+       echo "${machine}-${os}${release}"
+       exit 0 ;;
+    amd64:OpenBSD:*:*)
+       echo x86_64-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    amiga:OpenBSD:*:*)
+       echo m68k-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    cats:OpenBSD:*:*)
+       echo arm-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    hp300:OpenBSD:*:*)
+       echo m68k-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    luna88k:OpenBSD:*:*)
+       echo m88k-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    mac68k:OpenBSD:*:*)
+       echo m68k-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    macppc:OpenBSD:*:*)
+       echo powerpc-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    mvme68k:OpenBSD:*:*)
+       echo m68k-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    mvme88k:OpenBSD:*:*)
+       echo m88k-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    mvmeppc:OpenBSD:*:*)
+       echo powerpc-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    sgi:OpenBSD:*:*)
+       echo mips64-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    sun3:OpenBSD:*:*)
+       echo m68k-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    *:OpenBSD:*:*)
+       echo ${UNAME_MACHINE}-unknown-openbsd${UNAME_RELEASE}
+       exit 0 ;;
+    *:ekkoBSD:*:*)
+       echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE}
+       exit 0 ;;
+    macppc:MirBSD:*:*)
+       echo powerppc-unknown-mirbsd${UNAME_RELEASE}
+       exit 0 ;;
+    *:MirBSD:*:*)
+       echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE}
+       exit 0 ;;
+    alpha:OSF1:*:*)
+       case $UNAME_RELEASE in
+       *4.0)
+               UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'`
+               ;;
+       *5.*)
+               UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'`
+               ;;
+       esac
+       # According to Compaq, /usr/sbin/psrinfo has been available on
+       # OSF/1 and Tru64 systems produced since 1995.  I hope that
+       # covers most systems running today.  This code pipes the CPU
+       # types through head -n 1, so we only detect the type of CPU 0.
+       ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^  The alpha \(.*\) processor.*$/\1/p' | head -n 1`
+       case "$ALPHA_CPU_TYPE" in
+           "EV4 (21064)")
+               UNAME_MACHINE="alpha" ;;
+           "EV4.5 (21064)")
+               UNAME_MACHINE="alpha" ;;
+           "LCA4 (21066/21068)")
+               UNAME_MACHINE="alpha" ;;
+           "EV5 (21164)")
+               UNAME_MACHINE="alphaev5" ;;
+           "EV5.6 (21164A)")
+               UNAME_MACHINE="alphaev56" ;;
+           "EV5.6 (21164PC)")
+               UNAME_MACHINE="alphapca56" ;;
+           "EV5.7 (21164PC)")
+               UNAME_MACHINE="alphapca57" ;;
+           "EV6 (21264)")
+               UNAME_MACHINE="alphaev6" ;;
+           "EV6.7 (21264A)")
+               UNAME_MACHINE="alphaev67" ;;
+           "EV6.8CB (21264C)")
+               UNAME_MACHINE="alphaev68" ;;
+           "EV6.8AL (21264B)")
+               UNAME_MACHINE="alphaev68" ;;
+           "EV6.8CX (21264D)")
+               UNAME_MACHINE="alphaev68" ;;
+           "EV6.9A (21264/EV69A)")
+               UNAME_MACHINE="alphaev69" ;;
+           "EV7 (21364)")
+               UNAME_MACHINE="alphaev7" ;;
+           "EV7.9 (21364A)")
+               UNAME_MACHINE="alphaev79" ;;
+       esac
+       # A Pn.n version is a patched version.
+       # A Vn.n version is a released version.
+       # A Tn.n version is a released field test version.
+       # A Xn.n version is an unreleased experimental baselevel.
+       # 1.2 uses "1.2" for uname -r.
+       echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
+       exit 0 ;;
+    Alpha\ *:Windows_NT*:*)
+       # How do we know it's Interix rather than the generic POSIX subsystem?
+       # Should we change UNAME_MACHINE based on the output of uname instead
+       # of the specific Alpha model?
+       echo alpha-pc-interix
+       exit 0 ;;
+    21064:Windows_NT:50:3)
+       echo alpha-dec-winnt3.5
+       exit 0 ;;
+    Amiga*:UNIX_System_V:4.0:*)
+       echo m68k-unknown-sysv4
+       exit 0;;
+    *:[Aa]miga[Oo][Ss]:*:*)
+       echo ${UNAME_MACHINE}-unknown-amigaos
+       exit 0 ;;
+    *:[Mm]orph[Oo][Ss]:*:*)
+       echo ${UNAME_MACHINE}-unknown-morphos
+       exit 0 ;;
+    *:OS/390:*:*)
+       echo i370-ibm-openedition
+       exit 0 ;;
+    *:z/VM:*:*)
+       echo s390-ibm-zvmoe
+       exit 0 ;;
+    *:OS400:*:*)
+        echo powerpc-ibm-os400
+       exit 0 ;;
+    arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
+       echo arm-acorn-riscix${UNAME_RELEASE}
+       exit 0;;
+    SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
+       echo hppa1.1-hitachi-hiuxmpp
+       exit 0;;
+    Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
+       # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE.
+       if test "`(/bin/universe) 2>/dev/null`" = att ; then
+               echo pyramid-pyramid-sysv3
+       else
+               echo pyramid-pyramid-bsd
+       fi
+       exit 0 ;;
+    NILE*:*:*:dcosx)
+       echo pyramid-pyramid-svr4
+       exit 0 ;;
+    DRS?6000:unix:4.0:6*)
+       echo sparc-icl-nx6
+       exit 0 ;;
+    DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*)
+       case `/usr/bin/uname -p` in
+           sparc) echo sparc-icl-nx7 && exit 0 ;;
+       esac ;;
+    sun4H:SunOS:5.*:*)
+       echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+       exit 0 ;;
+    sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*)
+       echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+       exit 0 ;;
+    i86pc:SunOS:5.*:*)
+       echo i386-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+       exit 0 ;;
+    sun4*:SunOS:6*:*)
+       # According to config.sub, this is the proper way to canonicalize
+       # SunOS6.  Hard to guess exactly what SunOS6 will be like, but
+       # it's likely to be more like Solaris than SunOS4.
+       echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+       exit 0 ;;
+    sun4*:SunOS:*:*)
+       case "`/usr/bin/arch -k`" in
+           Series*|S4*)
+               UNAME_RELEASE=`uname -v`
+               ;;
+       esac
+       # Japanese Language versions have a version number like `4.1.3-JL'.
+       echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'`
+       exit 0 ;;
+    sun3*:SunOS:*:*)
+       echo m68k-sun-sunos${UNAME_RELEASE}
+       exit 0 ;;
+    sun*:*:4.2BSD:*)
+       UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null`
+       test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3
+       case "`/bin/arch`" in
+           sun3)
+               echo m68k-sun-sunos${UNAME_RELEASE}
+               ;;
+           sun4)
+               echo sparc-sun-sunos${UNAME_RELEASE}
+               ;;
+       esac
+       exit 0 ;;
+    aushp:SunOS:*:*)
+       echo sparc-auspex-sunos${UNAME_RELEASE}
+       exit 0 ;;
+    # The situation for MiNT is a little confusing.  The machine name
+    # can be virtually everything (everything which is not
+    # "atarist" or "atariste" at least should have a processor
+    # > m68000).  The system name ranges from "MiNT" over "FreeMiNT"
+    # to the lowercase version "mint" (or "freemint").  Finally
+    # the system name "TOS" denotes a system which is actually not
+    # MiNT.  But MiNT is downward compatible to TOS, so this should
+    # be no problem.
+    atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*)
+        echo m68k-atari-mint${UNAME_RELEASE}
+       exit 0 ;;
+    atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*)
+       echo m68k-atari-mint${UNAME_RELEASE}
+        exit 0 ;;
+    *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*)
+        echo m68k-atari-mint${UNAME_RELEASE}
+       exit 0 ;;
+    milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*)
+        echo m68k-milan-mint${UNAME_RELEASE}
+        exit 0 ;;
+    hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*)
+        echo m68k-hades-mint${UNAME_RELEASE}
+        exit 0 ;;
+    *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*)
+        echo m68k-unknown-mint${UNAME_RELEASE}
+        exit 0 ;;
+    m68k:machten:*:*)
+       echo m68k-apple-machten${UNAME_RELEASE}
+       exit 0 ;;
+    powerpc:machten:*:*)
+       echo powerpc-apple-machten${UNAME_RELEASE}
+       exit 0 ;;
+    RISC*:Mach:*:*)
+       echo mips-dec-mach_bsd4.3
+       exit 0 ;;
+    RISC*:ULTRIX:*:*)
+       echo mips-dec-ultrix${UNAME_RELEASE}
+       exit 0 ;;
+    VAX*:ULTRIX*:*:*)
+       echo vax-dec-ultrix${UNAME_RELEASE}
+       exit 0 ;;
+    2020:CLIX:*:* | 2430:CLIX:*:*)
+       echo clipper-intergraph-clix${UNAME_RELEASE}
+       exit 0 ;;
+    mips:*:*:UMIPS | mips:*:*:RISCos)
+       eval $set_cc_for_build
+       sed 's/^        //' << EOF >$dummy.c
+#ifdef __cplusplus
+#include <stdio.h>  /* for printf() prototype */
+       int main (int argc, char *argv[]) {
+#else
+       int main (argc, argv) int argc; char *argv[]; {
+#endif
+       #if defined (host_mips) && defined (MIPSEB)
+       #if defined (SYSTYPE_SYSV)
+         printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0);
+       #endif
+       #if defined (SYSTYPE_SVR4)
+         printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0);
+       #endif
+       #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD)
+         printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0);
+       #endif
+       #endif
+         exit (-1);
+       }
+EOF
+       $CC_FOR_BUILD -o $dummy $dummy.c \
+         && $dummy `echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` \
+         && exit 0
+       echo mips-mips-riscos${UNAME_RELEASE}
+       exit 0 ;;
+    Motorola:PowerMAX_OS:*:*)
+       echo powerpc-motorola-powermax
+       exit 0 ;;
+    Motorola:*:4.3:PL8-*)
+       echo powerpc-harris-powermax
+       exit 0 ;;
+    Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*)
+       echo powerpc-harris-powermax
+       exit 0 ;;
+    Night_Hawk:Power_UNIX:*:*)
+       echo powerpc-harris-powerunix
+       exit 0 ;;
+    m88k:CX/UX:7*:*)
+       echo m88k-harris-cxux7
+       exit 0 ;;
+    m88k:*:4*:R4*)
+       echo m88k-motorola-sysv4
+       exit 0 ;;
+    m88k:*:3*:R3*)
+       echo m88k-motorola-sysv3
+       exit 0 ;;
+    AViiON:dgux:*:*)
+        # DG/UX returns AViiON for all architectures
+        UNAME_PROCESSOR=`/usr/bin/uname -p`
+       if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ]
+       then
+           if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \
+              [ ${TARGET_BINARY_INTERFACE}x = x ]
+           then
+               echo m88k-dg-dgux${UNAME_RELEASE}
+           else
+               echo m88k-dg-dguxbcs${UNAME_RELEASE}
+           fi
+       else
+           echo i586-dg-dgux${UNAME_RELEASE}
+       fi
+       exit 0 ;;
+    M88*:DolphinOS:*:*)        # DolphinOS (SVR3)
+       echo m88k-dolphin-sysv3
+       exit 0 ;;
+    M88*:*:R3*:*)
+       # Delta 88k system running SVR3
+       echo m88k-motorola-sysv3
+       exit 0 ;;
+    XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3)
+       echo m88k-tektronix-sysv3
+       exit 0 ;;
+    Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD)
+       echo m68k-tektronix-bsd
+       exit 0 ;;
+    *:IRIX*:*:*)
+       echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'`
+       exit 0 ;;
+    ????????:AIX?:[12].1:2)   # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
+       echo romp-ibm-aix      # uname -m gives an 8 hex-code CPU id
+       exit 0 ;;              # Note that: echo "'`uname -s`'" gives 'AIX '
+    i*86:AIX:*:*)
+       echo i386-ibm-aix
+       exit 0 ;;
+    ia64:AIX:*:*)
+       if [ -x /usr/bin/oslevel ] ; then
+               IBM_REV=`/usr/bin/oslevel`
+       else
+               IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
+       fi
+       echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
+       exit 0 ;;
+    *:AIX:2:3)
+       if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
+               eval $set_cc_for_build
+               sed 's/^                //' << EOF >$dummy.c
+               #include <sys/systemcfg.h>
+
+               main()
+                       {
+                       if (!__power_pc())
+                               exit(1);
+                       puts("powerpc-ibm-aix3.2.5");
+                       exit(0);
+                       }
+EOF
+               $CC_FOR_BUILD -o $dummy $dummy.c && $dummy && exit 0
+               echo rs6000-ibm-aix3.2.5
+       elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
+               echo rs6000-ibm-aix3.2.4
+       else
+               echo rs6000-ibm-aix3.2
+       fi
+       exit 0 ;;
+    *:AIX:*:[45])
+       IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
+       if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
+               IBM_ARCH=rs6000
+       else
+               IBM_ARCH=powerpc
+       fi
+       if [ -x /usr/bin/oslevel ] ; then
+               IBM_REV=`/usr/bin/oslevel`
+       else
+               IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
+       fi
+       echo ${IBM_ARCH}-ibm-aix${IBM_REV}
+       exit 0 ;;
+    *:AIX:*:*)
+       echo rs6000-ibm-aix
+       exit 0 ;;
+    ibmrt:4.4BSD:*|romp-ibm:BSD:*)
+       echo romp-ibm-bsd4.4
+       exit 0 ;;
+    ibmrt:*BSD:*|romp-ibm:BSD:*)            # covers RT/PC BSD and
+       echo romp-ibm-bsd${UNAME_RELEASE}   # 4.3 with uname added to
+       exit 0 ;;                           # report: romp-ibm BSD 4.3
+    *:BOSX:*:*)
+       echo rs6000-bull-bosx
+       exit 0 ;;
+    DPX/2?00:B.O.S.:*:*)
+       echo m68k-bull-sysv3
+       exit 0 ;;
+    9000/[34]??:4.3bsd:1.*:*)
+       echo m68k-hp-bsd
+       exit 0 ;;
+    hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*)
+       echo m68k-hp-bsd4.4
+       exit 0 ;;
+    9000/[34678]??:HP-UX:*:*)
+       HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
+       case "${UNAME_MACHINE}" in
+           9000/31? )            HP_ARCH=m68000 ;;
+           9000/[34]?? )         HP_ARCH=m68k ;;
+           9000/[678][0-9][0-9])
+               if [ -x /usr/bin/getconf ]; then
+                   sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
+                    sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
+                    case "${sc_cpu_version}" in
+                      523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0
+                      528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1
+                      532)                      # CPU_PA_RISC2_0
+                        case "${sc_kernel_bits}" in
+                          32) HP_ARCH="hppa2.0n" ;;
+                          64) HP_ARCH="hppa2.0w" ;;
+                         '') HP_ARCH="hppa2.0" ;;   # HP-UX 10.20
+                        esac ;;
+                    esac
+               fi
+               if [ "${HP_ARCH}" = "" ]; then
+                   eval $set_cc_for_build
+                   sed 's/^              //' << EOF >$dummy.c
+
+              #define _HPUX_SOURCE
+              #include <stdlib.h>
+              #include <unistd.h>
+
+              int main ()
+              {
+              #if defined(_SC_KERNEL_BITS)
+                  long bits = sysconf(_SC_KERNEL_BITS);
+              #endif
+                  long cpu  = sysconf (_SC_CPU_VERSION);
+
+                  switch (cpu)
+               {
+               case CPU_PA_RISC1_0: puts ("hppa1.0"); break;
+               case CPU_PA_RISC1_1: puts ("hppa1.1"); break;
+               case CPU_PA_RISC2_0:
+              #if defined(_SC_KERNEL_BITS)
+                   switch (bits)
+                       {
+                       case 64: puts ("hppa2.0w"); break;
+                       case 32: puts ("hppa2.0n"); break;
+                       default: puts ("hppa2.0"); break;
+                       } break;
+              #else  /* !defined(_SC_KERNEL_BITS) */
+                   puts ("hppa2.0"); break;
+              #endif
+               default: puts ("hppa1.0"); break;
+               }
+                  exit (0);
+              }
+EOF
+                   (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy`
+                   test -z "$HP_ARCH" && HP_ARCH=hppa
+               fi ;;
+       esac
+       if [ ${HP_ARCH} = "hppa2.0w" ]
+       then
+           # avoid double evaluation of $set_cc_for_build
+           test -n "$CC_FOR_BUILD" || eval $set_cc_for_build
+           if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E -) | grep __LP64__ >/dev/null
+           then
+               HP_ARCH="hppa2.0w"
+           else
+               HP_ARCH="hppa64"
+           fi
+       fi
+       echo ${HP_ARCH}-hp-hpux${HPUX_REV}
+       exit 0 ;;
+    ia64:HP-UX:*:*)
+       HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
+       echo ia64-hp-hpux${HPUX_REV}
+       exit 0 ;;
+    3050*:HI-UX:*:*)
+       eval $set_cc_for_build
+       sed 's/^        //' << EOF >$dummy.c
+       #include <unistd.h>
+       int
+       main ()
+       {
+         long cpu = sysconf (_SC_CPU_VERSION);
+         /* The order matters, because CPU_IS_HP_MC68K erroneously returns
+            true for CPU_PA_RISC1_0.  CPU_IS_PA_RISC returns correct
+            results, however.  */
+         if (CPU_IS_PA_RISC (cpu))
+           {
+             switch (cpu)
+               {
+                 case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break;
+                 case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break;
+                 case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break;
+                 default: puts ("hppa-hitachi-hiuxwe2"); break;
+               }
+           }
+         else if (CPU_IS_HP_MC68K (cpu))
+           puts ("m68k-hitachi-hiuxwe2");
+         else puts ("unknown-hitachi-hiuxwe2");
+         exit (0);
+       }
+EOF
+       $CC_FOR_BUILD -o $dummy $dummy.c && $dummy && exit 0
+       echo unknown-hitachi-hiuxwe2
+       exit 0 ;;
+    9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* )
+       echo hppa1.1-hp-bsd
+       exit 0 ;;
+    9000/8??:4.3bsd:*:*)
+       echo hppa1.0-hp-bsd
+       exit 0 ;;
+    *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
+       echo hppa1.0-hp-mpeix
+       exit 0 ;;
+    hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
+       echo hppa1.1-hp-osf
+       exit 0 ;;
+    hp8??:OSF1:*:*)
+       echo hppa1.0-hp-osf
+       exit 0 ;;
+    i*86:OSF1:*:*)
+       if [ -x /usr/sbin/sysversion ] ; then
+           echo ${UNAME_MACHINE}-unknown-osf1mk
+       else
+           echo ${UNAME_MACHINE}-unknown-osf1
+       fi
+       exit 0 ;;
+    parisc*:Lites*:*:*)
+       echo hppa1.1-hp-lites
+       exit 0 ;;
+    C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*)
+       echo c1-convex-bsd
+        exit 0 ;;
+    C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*)
+       if getsysinfo -f scalar_acc
+       then echo c32-convex-bsd
+       else echo c2-convex-bsd
+       fi
+        exit 0 ;;
+    C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*)
+       echo c34-convex-bsd
+        exit 0 ;;
+    C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*)
+       echo c38-convex-bsd
+        exit 0 ;;
+    C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*)
+       echo c4-convex-bsd
+        exit 0 ;;
+    CRAY*Y-MP:*:*:*)
+       echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+       exit 0 ;;
+    CRAY*[A-Z]90:*:*:*)
+       echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
+       | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
+             -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
+             -e 's/\.[^.]*$/.X/'
+       exit 0 ;;
+    CRAY*TS:*:*:*)
+       echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+       exit 0 ;;
+    CRAY*T3E:*:*:*)
+       echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+       exit 0 ;;
+    CRAY*SV1:*:*:*)
+       echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+       exit 0 ;;
+    *:UNICOS/mp:*:*)
+       echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+       exit 0 ;;
+    F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
+       FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
+        FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
+        FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
+        echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
+        exit 0 ;;
+    5000:UNIX_System_V:4.*:*)
+        FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
+        FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'`
+        echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
+       exit 0 ;;
+    i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
+       echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
+       exit 0 ;;
+    sparc*:BSD/OS:*:*)
+       echo sparc-unknown-bsdi${UNAME_RELEASE}
+       exit 0 ;;
+    *:BSD/OS:*:*)
+       echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE}
+       exit 0 ;;
+    *:FreeBSD:*:*)
+       echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
+       exit 0 ;;
+    i*:CYGWIN*:*)
+       echo ${UNAME_MACHINE}-pc-cygwin
+       exit 0 ;;
+    i*:MINGW*:*)
+       echo ${UNAME_MACHINE}-pc-mingw32
+       exit 0 ;;
+    i*:PW*:*)
+       echo ${UNAME_MACHINE}-pc-pw32
+       exit 0 ;;
+    x86:Interix*:[34]*)
+       echo i586-pc-interix${UNAME_RELEASE}|sed -e 's/\..*//'
+       exit 0 ;;
+    [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*)
+       echo i${UNAME_MACHINE}-pc-mks
+       exit 0 ;;
+    i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
+       # How do we know it's Interix rather than the generic POSIX subsystem?
+       # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
+       # UNAME_MACHINE based on the output of uname instead of i386?
+       echo i586-pc-interix
+       exit 0 ;;
+    i*:UWIN*:*)
+       echo ${UNAME_MACHINE}-pc-uwin
+       exit 0 ;;
+    amd64:CYGWIN*:*:*)
+       echo x86_64-unknown-cygwin
+       exit 0 ;;
+    p*:CYGWIN*:*)
+       echo powerpcle-unknown-cygwin
+       exit 0 ;;
+    prep*:SunOS:5.*:*)
+       echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+       exit 0 ;;
+    *:GNU:*:*)
+       # the GNU system
+       echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
+       exit 0 ;;
+    *:GNU/*:*:*)
+       # other systems with GNU libc and userland
+       echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu
+       exit 0 ;;
+    i*86:Minix:*:*)
+       echo ${UNAME_MACHINE}-pc-minix
+       exit 0 ;;
+    arm*:Linux:*:*)
+       echo ${UNAME_MACHINE}-unknown-linux-gnu
+       exit 0 ;;
+    cris:Linux:*:*)
+       echo cris-axis-linux-gnu
+       exit 0 ;;
+    crisv32:Linux:*:*)
+       echo crisv32-axis-linux-gnu
+       exit 0 ;;
+    frv:Linux:*:*)
+       echo frv-unknown-linux-gnu
+       exit 0 ;;
+    ia64:Linux:*:*)
+       echo ${UNAME_MACHINE}-unknown-linux-gnu
+       exit 0 ;;
+    m32r*:Linux:*:*)
+       echo ${UNAME_MACHINE}-unknown-linux-gnu
+       exit 0 ;;
+    m68*:Linux:*:*)
+       echo ${UNAME_MACHINE}-unknown-linux-gnu
+       exit 0 ;;
+    mips:Linux:*:*)
+       eval $set_cc_for_build
+       sed 's/^        //' << EOF >$dummy.c
+       #undef CPU
+       #undef mips
+       #undef mipsel
+       #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
+       CPU=mipsel
+       #else
+       #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
+       CPU=mips
+       #else
+       CPU=
+       #endif
+       #endif
+EOF
+       eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^CPU=`
+       test x"${CPU}" != x && echo "${CPU}-unknown-linux-gnu" && exit 0
+       ;;
+    mips64:Linux:*:*)
+       eval $set_cc_for_build
+       sed 's/^        //' << EOF >$dummy.c
+       #undef CPU
+       #undef mips64
+       #undef mips64el
+       #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
+       CPU=mips64el
+       #else
+       #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
+       CPU=mips64
+       #else
+       CPU=
+       #endif
+       #endif
+EOF
+       eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^CPU=`
+       test x"${CPU}" != x && echo "${CPU}-unknown-linux-gnu" && exit 0
+       ;;
+    ppc:Linux:*:*)
+       echo powerpc-unknown-linux-gnu
+       exit 0 ;;
+    ppc64:Linux:*:*)
+       echo powerpc64-unknown-linux-gnu
+       exit 0 ;;
+    alpha:Linux:*:*)
+       case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
+         EV5)   UNAME_MACHINE=alphaev5 ;;
+         EV56)  UNAME_MACHINE=alphaev56 ;;
+         PCA56) UNAME_MACHINE=alphapca56 ;;
+         PCA57) UNAME_MACHINE=alphapca56 ;;
+         EV6)   UNAME_MACHINE=alphaev6 ;;
+         EV67)  UNAME_MACHINE=alphaev67 ;;
+         EV68*) UNAME_MACHINE=alphaev68 ;;
+        esac
+       objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null
+       if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi
+       echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC}
+       exit 0 ;;
+    parisc:Linux:*:* | hppa:Linux:*:*)
+       # Look for CPU level
+       case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
+         PA7*) echo hppa1.1-unknown-linux-gnu ;;
+         PA8*) echo hppa2.0-unknown-linux-gnu ;;
+         *)    echo hppa-unknown-linux-gnu ;;
+       esac
+       exit 0 ;;
+    parisc64:Linux:*:* | hppa64:Linux:*:*)
+       echo hppa64-unknown-linux-gnu
+       exit 0 ;;
+    s390:Linux:*:* | s390x:Linux:*:*)
+       echo ${UNAME_MACHINE}-ibm-linux
+       exit 0 ;;
+    sh64*:Linux:*:*)
+       echo ${UNAME_MACHINE}-unknown-linux-gnu
+       exit 0 ;;
+    sh*:Linux:*:*)
+       echo ${UNAME_MACHINE}-unknown-linux-gnu
+       exit 0 ;;
+    sparc:Linux:*:* | sparc64:Linux:*:*)
+       echo ${UNAME_MACHINE}-unknown-linux-gnu
+       exit 0 ;;
+    x86_64:Linux:*:*)
+       echo x86_64-unknown-linux-gnu
+       exit 0 ;;
+    i*86:Linux:*:*)
+       # The BFD linker knows what the default object file format is, so
+       # first see if it will tell us. cd to the root directory to prevent
+       # problems with other programs or directories called `ld' in the path.
+       # Set LC_ALL=C to ensure ld outputs messages in English.
+       ld_supported_targets=`cd /; LC_ALL=C ld --help 2>&1 \
+                        | sed -ne '/supported targets:/!d
+                                   s/[         ][      ]*/ /g
+                                   s/.*supported targets: *//
+                                   s/ .*//
+                                   p'`
+        case "$ld_supported_targets" in
+         elf32-i386)
+               TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu"
+               ;;
+         a.out-i386-linux)
+               echo "${UNAME_MACHINE}-pc-linux-gnuaout"
+               exit 0 ;;
+         coff-i386)
+               echo "${UNAME_MACHINE}-pc-linux-gnucoff"
+               exit 0 ;;
+         "")
+               # Either a pre-BFD a.out linker (linux-gnuoldld) or
+               # one that does not give us useful --help.
+               echo "${UNAME_MACHINE}-pc-linux-gnuoldld"
+               exit 0 ;;
+       esac
+       # Determine whether the default compiler is a.out or elf
+       eval $set_cc_for_build
+       sed 's/^        //' << EOF >$dummy.c
+       #include <features.h>
+       #ifdef __ELF__
+       # ifdef __GLIBC__
+       #  if __GLIBC__ >= 2
+       LIBC=gnu
+       #  else
+       LIBC=gnulibc1
+       #  endif
+       # else
+       LIBC=gnulibc1
+       # endif
+       #else
+       #ifdef __INTEL_COMPILER
+       LIBC=gnu
+       #else
+       LIBC=gnuaout
+       #endif
+       #endif
+       #ifdef __dietlibc__
+       LIBC=dietlibc
+       #endif
+EOF
+       eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^LIBC=`
+       test x"${LIBC}" != x && echo "${UNAME_MACHINE}-pc-linux-${LIBC}" && exit 0
+       test x"${TENTATIVE}" != x && echo "${TENTATIVE}" && exit 0
+       ;;
+    i*86:DYNIX/ptx:4*:*)
+       # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
+       # earlier versions are messed up and put the nodename in both
+       # sysname and nodename.
+       echo i386-sequent-sysv4
+       exit 0 ;;
+    i*86:UNIX_SV:4.2MP:2.*)
+        # Unixware is an offshoot of SVR4, but it has its own version
+        # number series starting with 2...
+        # I am not positive that other SVR4 systems won't match this,
+       # I just have to hope.  -- rms.
+        # Use sysv4.2uw... so that sysv4* matches it.
+       echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
+       exit 0 ;;
+    i*86:OS/2:*:*)
+       # If we were able to find `uname', then EMX Unix compatibility
+       # is probably installed.
+       echo ${UNAME_MACHINE}-pc-os2-emx
+       exit 0 ;;
+    i*86:XTS-300:*:STOP)
+       echo ${UNAME_MACHINE}-unknown-stop
+       exit 0 ;;
+    i*86:atheos:*:*)
+       echo ${UNAME_MACHINE}-unknown-atheos
+       exit 0 ;;
+       i*86:syllable:*:*)
+       echo ${UNAME_MACHINE}-pc-syllable
+       exit 0 ;;
+    i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.0*:*)
+       echo i386-unknown-lynxos${UNAME_RELEASE}
+       exit 0 ;;
+    i*86:*DOS:*:*)
+       echo ${UNAME_MACHINE}-pc-msdosdjgpp
+       exit 0 ;;
+    i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
+       UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
+       if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
+               echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
+       else
+               echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
+       fi
+       exit 0 ;;
+    i*86:*:5:[78]*)
+       case `/bin/uname -X | grep "^Machine"` in
+           *486*)           UNAME_MACHINE=i486 ;;
+           *Pentium)        UNAME_MACHINE=i586 ;;
+           *Pent*|*Celeron) UNAME_MACHINE=i686 ;;
+       esac
+       echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
+       exit 0 ;;
+    i*86:*:3.2:*)
+       if test -f /usr/options/cb.name; then
+               UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
+               echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
+       elif /bin/uname -X 2>/dev/null >/dev/null ; then
+               UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')`
+               (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486
+               (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \
+                       && UNAME_MACHINE=i586
+               (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \
+                       && UNAME_MACHINE=i686
+               (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \
+                       && UNAME_MACHINE=i686
+               echo ${UNAME_MACHINE}-pc-sco$UNAME_REL
+       else
+               echo ${UNAME_MACHINE}-pc-sysv32
+       fi
+       exit 0 ;;
+    pc:*:*:*)
+       # Left here for compatibility:
+        # uname -m prints for DJGPP always 'pc', but it prints nothing about
+        # the processor, so we play safe by assuming i386.
+       echo i386-pc-msdosdjgpp
+        exit 0 ;;
+    Intel:Mach:3*:*)
+       echo i386-pc-mach3
+       exit 0 ;;
+    paragon:*:*:*)
+       echo i860-intel-osf1
+       exit 0 ;;
+    i860:*:4.*:*) # i860-SVR4
+       if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
+         echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
+       else # Add other i860-SVR4 vendors below as they are discovered.
+         echo i860-unknown-sysv${UNAME_RELEASE}  # Unknown i860-SVR4
+       fi
+       exit 0 ;;
+    mini*:CTIX:SYS*5:*)
+       # "miniframe"
+       echo m68010-convergent-sysv
+       exit 0 ;;
+    mc68k:UNIX:SYSTEM5:3.51m)
+       echo m68k-convergent-sysv
+       exit 0 ;;
+    M680?0:D-NIX:5.3:*)
+       echo m68k-diab-dnix
+       exit 0 ;;
+    M68*:*:R3V[5678]*:*)
+       test -r /sysV68 && echo 'm68k-motorola-sysv' && exit 0 ;;
+    3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0)
+       OS_REL=''
+       test -r /etc/.relid \
+       && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
+       /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
+         && echo i486-ncr-sysv4.3${OS_REL} && exit 0
+       /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
+         && echo i586-ncr-sysv4.3${OS_REL} && exit 0 ;;
+    3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
+        /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
+          && echo i486-ncr-sysv4 && exit 0 ;;
+    m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
+       echo m68k-unknown-lynxos${UNAME_RELEASE}
+       exit 0 ;;
+    mc68030:UNIX_System_V:4.*:*)
+       echo m68k-atari-sysv4
+       exit 0 ;;
+    TSUNAMI:LynxOS:2.*:*)
+       echo sparc-unknown-lynxos${UNAME_RELEASE}
+       exit 0 ;;
+    rs6000:LynxOS:2.*:*)
+       echo rs6000-unknown-lynxos${UNAME_RELEASE}
+       exit 0 ;;
+    PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.0*:*)
+       echo powerpc-unknown-lynxos${UNAME_RELEASE}
+       exit 0 ;;
+    SM[BE]S:UNIX_SV:*:*)
+       echo mips-dde-sysv${UNAME_RELEASE}
+       exit 0 ;;
+    RM*:ReliantUNIX-*:*:*)
+       echo mips-sni-sysv4
+       exit 0 ;;
+    RM*:SINIX-*:*:*)
+       echo mips-sni-sysv4
+       exit 0 ;;
+    *:SINIX-*:*:*)
+       if uname -p 2>/dev/null >/dev/null ; then
+               UNAME_MACHINE=`(uname -p) 2>/dev/null`
+               echo ${UNAME_MACHINE}-sni-sysv4
+       else
+               echo ns32k-sni-sysv
+       fi
+       exit 0 ;;
+    PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort
+                      # says <Richard.M.Bartel@ccMail.Census.GOV>
+        echo i586-unisys-sysv4
+        exit 0 ;;
+    *:UNIX_System_V:4*:FTX*)
+       # From Gerald Hewes <hewes@openmarket.com>.
+       # How about differentiating between stratus architectures? -djm
+       echo hppa1.1-stratus-sysv4
+       exit 0 ;;
+    *:*:*:FTX*)
+       # From seanf@swdc.stratus.com.
+       echo i860-stratus-sysv4
+       exit 0 ;;
+    i*86:VOS:*:*)
+       # From Paul.Green@stratus.com.
+       echo ${UNAME_MACHINE}-stratus-vos
+       exit 0 ;;
+    *:VOS:*:*)
+       # From Paul.Green@stratus.com.
+       echo hppa1.1-stratus-vos
+       exit 0 ;;
+    mc68*:A/UX:*:*)
+       echo m68k-apple-aux${UNAME_RELEASE}
+       exit 0 ;;
+    news*:NEWS-OS:6*:*)
+       echo mips-sony-newsos6
+       exit 0 ;;
+    R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
+       if [ -d /usr/nec ]; then
+               echo mips-nec-sysv${UNAME_RELEASE}
+       else
+               echo mips-unknown-sysv${UNAME_RELEASE}
+       fi
+        exit 0 ;;
+    BeBox:BeOS:*:*)    # BeOS running on hardware made by Be, PPC only.
+       echo powerpc-be-beos
+       exit 0 ;;
+    BeMac:BeOS:*:*)    # BeOS running on Mac or Mac clone, PPC only.
+       echo powerpc-apple-beos
+       exit 0 ;;
+    BePC:BeOS:*:*)     # BeOS running on Intel PC compatible.
+       echo i586-pc-beos
+       exit 0 ;;
+    SX-4:SUPER-UX:*:*)
+       echo sx4-nec-superux${UNAME_RELEASE}
+       exit 0 ;;
+    SX-5:SUPER-UX:*:*)
+       echo sx5-nec-superux${UNAME_RELEASE}
+       exit 0 ;;
+    SX-6:SUPER-UX:*:*)
+       echo sx6-nec-superux${UNAME_RELEASE}
+       exit 0 ;;
+    Power*:Rhapsody:*:*)
+       echo powerpc-apple-rhapsody${UNAME_RELEASE}
+       exit 0 ;;
+    *:Rhapsody:*:*)
+       echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE}
+       exit 0 ;;
+    *:Darwin:*:*)
+       UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
+       case $UNAME_PROCESSOR in
+           *86) UNAME_PROCESSOR=i686 ;;
+           unknown) UNAME_PROCESSOR=powerpc ;;
+       esac
+       echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
+       exit 0 ;;
+    *:procnto*:*:* | *:QNX:[0123456789]*:*)
+       UNAME_PROCESSOR=`uname -p`
+       if test "$UNAME_PROCESSOR" = "x86"; then
+               UNAME_PROCESSOR=i386
+               UNAME_MACHINE=pc
+       fi
+       echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE}
+       exit 0 ;;
+    *:QNX:*:4*)
+       echo i386-pc-qnx
+       exit 0 ;;
+    NSE-?:NONSTOP_KERNEL:*:*)
+       echo nse-tandem-nsk${UNAME_RELEASE}
+       exit 0 ;;
+    NSR-?:NONSTOP_KERNEL:*:*)
+       echo nsr-tandem-nsk${UNAME_RELEASE}
+       exit 0 ;;
+    *:NonStop-UX:*:*)
+       echo mips-compaq-nonstopux
+       exit 0 ;;
+    BS2000:POSIX*:*:*)
+       echo bs2000-siemens-sysv
+       exit 0 ;;
+    DS/*:UNIX_System_V:*:*)
+       echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
+       exit 0 ;;
+    *:Plan9:*:*)
+       # "uname -m" is not consistent, so use $cputype instead. 386
+       # is converted to i386 for consistency with other x86
+       # operating systems.
+       if test "$cputype" = "386"; then
+           UNAME_MACHINE=i386
+       else
+           UNAME_MACHINE="$cputype"
+       fi
+       echo ${UNAME_MACHINE}-unknown-plan9
+       exit 0 ;;
+    *:TOPS-10:*:*)
+       echo pdp10-unknown-tops10
+       exit 0 ;;
+    *:TENEX:*:*)
+       echo pdp10-unknown-tenex
+       exit 0 ;;
+    KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*)
+       echo pdp10-dec-tops20
+       exit 0 ;;
+    XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*)
+       echo pdp10-xkl-tops20
+       exit 0 ;;
+    *:TOPS-20:*:*)
+       echo pdp10-unknown-tops20
+       exit 0 ;;
+    *:ITS:*:*)
+       echo pdp10-unknown-its
+       exit 0 ;;
+    SEI:*:*:SEIUX)
+        echo mips-sei-seiux${UNAME_RELEASE}
+       exit 0 ;;
+    *:DragonFly:*:*)
+       echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
+       exit 0 ;;
+    *:*VMS:*:*)
+       UNAME_MACHINE=`(uname -p) 2>/dev/null`
+       case "${UNAME_MACHINE}" in
+           A*) echo alpha-dec-vms && exit 0 ;;
+           I*) echo ia64-dec-vms && exit 0 ;;
+           V*) echo vax-dec-vms && exit 0 ;;
+       esac ;;
+    *:XENIX:*:SysV)
+       echo i386-pc-xenix
+       exit 0 ;;
+esac
+
+#echo '(No uname command or uname output not recognized.)' 1>&2
+#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2
+
+eval $set_cc_for_build
+cat >$dummy.c <<EOF
+#ifdef _SEQUENT_
+# include <sys/types.h>
+# include <sys/utsname.h>
+#endif
+main ()
+{
+#if defined (sony)
+#if defined (MIPSEB)
+  /* BFD wants "bsd" instead of "newsos".  Perhaps BFD should be changed,
+     I don't know....  */
+  printf ("mips-sony-bsd\n"); exit (0);
+#else
+#include <sys/param.h>
+  printf ("m68k-sony-newsos%s\n",
+#ifdef NEWSOS4
+          "4"
+#else
+         ""
+#endif
+         ); exit (0);
+#endif
+#endif
+
+#if defined (__arm) && defined (__acorn) && defined (__unix)
+  printf ("arm-acorn-riscix"); exit (0);
+#endif
+
+#if defined (hp300) && !defined (hpux)
+  printf ("m68k-hp-bsd\n"); exit (0);
+#endif
+
+#if defined (NeXT)
+#if !defined (__ARCHITECTURE__)
+#define __ARCHITECTURE__ "m68k"
+#endif
+  int version;
+  version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`;
+  if (version < 4)
+    printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version);
+  else
+    printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version);
+  exit (0);
+#endif
+
+#if defined (MULTIMAX) || defined (n16)
+#if defined (UMAXV)
+  printf ("ns32k-encore-sysv\n"); exit (0);
+#else
+#if defined (CMU)
+  printf ("ns32k-encore-mach\n"); exit (0);
+#else
+  printf ("ns32k-encore-bsd\n"); exit (0);
+#endif
+#endif
+#endif
+
+#if defined (__386BSD__)
+  printf ("i386-pc-bsd\n"); exit (0);
+#endif
+
+#if defined (sequent)
+#if defined (i386)
+  printf ("i386-sequent-dynix\n"); exit (0);
+#endif
+#if defined (ns32000)
+  printf ("ns32k-sequent-dynix\n"); exit (0);
+#endif
+#endif
+
+#if defined (_SEQUENT_)
+    struct utsname un;
+
+    uname(&un);
+
+    if (strncmp(un.version, "V2", 2) == 0) {
+       printf ("i386-sequent-ptx2\n"); exit (0);
+    }
+    if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */
+       printf ("i386-sequent-ptx1\n"); exit (0);
+    }
+    printf ("i386-sequent-ptx\n"); exit (0);
+
+#endif
+
+#if defined (vax)
+# if !defined (ultrix)
+#  include <sys/param.h>
+#  if defined (BSD)
+#   if BSD == 43
+      printf ("vax-dec-bsd4.3\n"); exit (0);
+#   else
+#    if BSD == 199006
+      printf ("vax-dec-bsd4.3reno\n"); exit (0);
+#    else
+      printf ("vax-dec-bsd\n"); exit (0);
+#    endif
+#   endif
+#  else
+    printf ("vax-dec-bsd\n"); exit (0);
+#  endif
+# else
+    printf ("vax-dec-ultrix\n"); exit (0);
+# endif
+#endif
+
+#if defined (alliant) && defined (i860)
+  printf ("i860-alliant-bsd\n"); exit (0);
+#endif
+
+  exit (1);
+}
+EOF
+
+$CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null && $dummy && exit 0
+
+# Apollos put the system type in the environment.
+
+test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit 0; }
+
+# Convex versions that predate uname can use getsysinfo(1)
+
+if [ -x /usr/convex/getsysinfo ]
+then
+    case `getsysinfo -f cpu_type` in
+    c1*)
+       echo c1-convex-bsd
+       exit 0 ;;
+    c2*)
+       if getsysinfo -f scalar_acc
+       then echo c32-convex-bsd
+       else echo c2-convex-bsd
+       fi
+       exit 0 ;;
+    c34*)
+       echo c34-convex-bsd
+       exit 0 ;;
+    c38*)
+       echo c38-convex-bsd
+       exit 0 ;;
+    c4*)
+       echo c4-convex-bsd
+       exit 0 ;;
+    esac
+fi
+
+cat >&2 <<EOF
+$0: unable to guess system type
+
+This script, last modified $timestamp, has failed to recognize
+the operating system you are using. It is advised that you
+download the most up to date version of the config scripts from
+
+  http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.guess
+and
+  http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.sub
+
+If the version you run ($0) is already up to date, please
+send the following data and any information you think might be
+pertinent to <config-patches@gnu.org> in order to provide the needed
+information to handle your system.
+
+config.guess timestamp = $timestamp
+
+uname -m = `(uname -m) 2>/dev/null || echo unknown`
+uname -r = `(uname -r) 2>/dev/null || echo unknown`
+uname -s = `(uname -s) 2>/dev/null || echo unknown`
+uname -v = `(uname -v) 2>/dev/null || echo unknown`
+
+/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null`
+/bin/uname -X     = `(/bin/uname -X) 2>/dev/null`
+
+hostinfo               = `(hostinfo) 2>/dev/null`
+/bin/universe          = `(/bin/universe) 2>/dev/null`
+/usr/bin/arch -k       = `(/usr/bin/arch -k) 2>/dev/null`
+/bin/arch              = `(/bin/arch) 2>/dev/null`
+/usr/bin/oslevel       = `(/usr/bin/oslevel) 2>/dev/null`
+/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
+
+UNAME_MACHINE = ${UNAME_MACHINE}
+UNAME_RELEASE = ${UNAME_RELEASE}
+UNAME_SYSTEM  = ${UNAME_SYSTEM}
+UNAME_VERSION = ${UNAME_VERSION}
+EOF
+
+exit 1
+
+# Local variables:
+# eval: (add-hook 'write-file-hooks 'time-stamp)
+# time-stamp-start: "timestamp='"
+# time-stamp-format: "%:y-%02m-%02d"
+# time-stamp-end: "'"
+# End:
diff --git a/config.h.in b/config.h.in
new file mode 100644 (file)
index 0000000..d065693
--- /dev/null
@@ -0,0 +1,86 @@
+/* config.h.in.  Generated from configure.ac by autoheader.  */
+
+/* libcairo is available for visual debugging output */
+#undef HAVE_CAIRO
+
+/* Define to 1 if you have the <dlfcn.h> header file. */
+#undef HAVE_DLFCN_H
+
+/* Define to 1 if you have the <inttypes.h> header file. */
+#undef HAVE_INTTYPES_H
+
+/* Define to 1 if you have the <machine/soundcard.h> header file. */
+#undef HAVE_MACHINE_SOUNDCARD_H
+
+/* Define to 1 if you have the <memory.h> header file. */
+#undef HAVE_MEMORY_H
+
+/* Define to 1 if you have the <soundcard.h> header file. */
+#undef HAVE_SOUNDCARD_H
+
+/* Define to 1 if you have the <stdint.h> header file. */
+#undef HAVE_STDINT_H
+
+/* Define to 1 if you have the <stdlib.h> header file. */
+#undef HAVE_STDLIB_H
+
+/* Define to 1 if you have the <strings.h> header file. */
+#undef HAVE_STRINGS_H
+
+/* Define to 1 if you have the <string.h> header file. */
+#undef HAVE_STRING_H
+
+/* Define to 1 if you have the <sys/soundcard.h> header file. */
+#undef HAVE_SYS_SOUNDCARD_H
+
+/* Define to 1 if you have the <sys/stat.h> header file. */
+#undef HAVE_SYS_STAT_H
+
+/* Define to 1 if you have the <sys/types.h> header file. */
+#undef HAVE_SYS_TYPES_H
+
+/* Define to 1 if you have the <unistd.h> header file. */
+#undef HAVE_UNISTD_H
+
+/* Define to the sub-directory in which libtool stores uninstalled libraries.
+   */
+#undef LT_OBJDIR
+
+/* Define to 1 if your C compiler doesn't accept -c and -o together. */
+#undef NO_MINUS_C_MINUS_O
+
+/* make use of x86_64 asm optimization */
+#undef OC_X86_64_ASM
+
+/* make use of x86 asm optimization */
+#undef OC_X86_ASM
+
+/* Name of package */
+#undef PACKAGE
+
+/* Define to the address where bug reports for this package should be sent. */
+#undef PACKAGE_BUGREPORT
+
+/* Define to the full name of this package. */
+#undef PACKAGE_NAME
+
+/* Define to the full name and version of this package. */
+#undef PACKAGE_STRING
+
+/* Define to the one symbol short name of this package. */
+#undef PACKAGE_TARNAME
+
+/* Define to the version of this package. */
+#undef PACKAGE_VERSION
+
+/* Define to 1 if you have the ANSI C header files. */
+#undef STDC_HEADERS
+
+/* Define to exclude encode support from the build */
+#undef THEORA_DISABLE_ENCODE
+
+/* Define to exclude floating point code from the build */
+#undef THEORA_DISABLE_FLOAT
+
+/* Version number of package */
+#undef VERSION
diff --git a/config.sub b/config.sub
new file mode 100755 (executable)
index 0000000..87a1ee4
--- /dev/null
@@ -0,0 +1,1569 @@
+#! /bin/sh
+# Configuration validation subroutine script.
+#   Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
+#   2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
+
+timestamp='2005-04-22'
+
+# This file is (in principle) common to ALL GNU software.
+# The presence of a machine in this file suggests that SOME GNU software
+# can handle that machine.  It does not imply ALL GNU software can.
+#
+# This file 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., 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
+
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+# Please send patches to <config-patches@gnu.org>.  Submit a context
+# diff and a properly formatted ChangeLog entry.
+#
+# Configuration subroutine to validate and canonicalize a configuration type.
+# Supply the specified configuration type as an argument.
+# If it is invalid, we print an error message on stderr and exit with code 1.
+# Otherwise, we print the canonical config type on stdout and succeed.
+
+# This file is supposed to be the same for all GNU packages
+# and recognize all the CPU types, system types and aliases
+# that are meaningful with *any* GNU software.
+# Each package is responsible for reporting which valid configurations
+# it does not support.  The user should be able to distinguish
+# a failure to support a valid configuration from a meaningless
+# configuration.
+
+# The goal of this file is to map all the various variations of a given
+# machine specification into a single specification in the form:
+#      CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM
+# or in some cases, the newer four-part form:
+#      CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
+# It is wrong to echo any other type of specification.
+
+me=`echo "$0" | sed -e 's,.*/,,'`
+
+usage="\
+Usage: $0 [OPTION] CPU-MFR-OPSYS
+       $0 [OPTION] ALIAS
+
+Canonicalize a configuration name.
+
+Operation modes:
+  -h, --help         print this help, then exit
+  -t, --time-stamp   print date of last modification, then exit
+  -v, --version      print version number, then exit
+
+Report bugs and patches to <config-patches@gnu.org>."
+
+version="\
+GNU config.sub ($timestamp)
+
+Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
+Free Software Foundation, Inc.
+
+This is free software; see the source for copying conditions.  There is NO
+warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
+
+help="
+Try \`$me --help' for more information."
+
+# Parse command line
+while test $# -gt 0 ; do
+  case $1 in
+    --time-stamp | --time* | -t )
+       echo "$timestamp" ; exit 0 ;;
+    --version | -v )
+       echo "$version" ; exit 0 ;;
+    --help | --h* | -h )
+       echo "$usage"; exit 0 ;;
+    -- )     # Stop option processing
+       shift; break ;;
+    - )        # Use stdin as input.
+       break ;;
+    -* )
+       echo "$me: invalid option $1$help"
+       exit 1 ;;
+
+    *local*)
+       # First pass through any local machine types.
+       echo $1
+       exit 0;;
+
+    * )
+       break ;;
+  esac
+done
+
+case $# in
+ 0) echo "$me: missing argument$help" >&2
+    exit 1;;
+ 1) ;;
+ *) echo "$me: too many arguments$help" >&2
+    exit 1;;
+esac
+
+# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
+# Here we must recognize all the valid KERNEL-OS combinations.
+maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
+case $maybe_os in
+  nto-qnx* | linux-gnu* | linux-dietlibc | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | \
+  kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | storm-chaos* | os2-emx* | rtmk-nova*)
+    os=-$maybe_os
+    basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
+    ;;
+  *)
+    basic_machine=`echo $1 | sed 's/-[^-]*$//'`
+    if [ $basic_machine != $1 ]
+    then os=`echo $1 | sed 's/.*-/-/'`
+    else os=; fi
+    ;;
+esac
+
+### Let's recognize common machines as not being operating systems so
+### that things like config.sub decstation-3100 work.  We also
+### recognize some manufacturers as not being operating systems, so we
+### can provide default operating systems below.
+case $os in
+       -sun*os*)
+               # Prevent following clause from handling this invalid input.
+               ;;
+       -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \
+       -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \
+       -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \
+       -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
+       -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
+       -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
+       -apple | -axis | -knuth | -cray)
+               os=
+               basic_machine=$1
+               ;;
+       -sim | -cisco | -oki | -wec | -winbond)
+               os=
+               basic_machine=$1
+               ;;
+       -scout)
+               ;;
+       -wrs)
+               os=-vxworks
+               basic_machine=$1
+               ;;
+       -chorusos*)
+               os=-chorusos
+               basic_machine=$1
+               ;;
+       -chorusrdb)
+               os=-chorusrdb
+               basic_machine=$1
+               ;;
+       -hiux*)
+               os=-hiuxwe2
+               ;;
+       -sco5)
+               os=-sco3.2v5
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -sco4)
+               os=-sco3.2v4
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -sco3.2.[4-9]*)
+               os=`echo $os | sed -e 's/sco3.2./sco3.2v/'`
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -sco3.2v[4-9]*)
+               # Don't forget version if it is 3.2v4 or newer.
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -sco*)
+               os=-sco3.2v2
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -udk*)
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -isc)
+               os=-isc2.2
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -clix*)
+               basic_machine=clipper-intergraph
+               ;;
+       -isc*)
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+               ;;
+       -lynx*)
+               os=-lynxos
+               ;;
+       -ptx*)
+               basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'`
+               ;;
+       -windowsnt*)
+               os=`echo $os | sed -e 's/windowsnt/winnt/'`
+               ;;
+       -psos*)
+               os=-psos
+               ;;
+       -mint | -mint[0-9]*)
+               basic_machine=m68k-atari
+               os=-mint
+               ;;
+esac
+
+# Decode aliases for certain CPU-COMPANY combinations.
+case $basic_machine in
+       # Recognize the basic CPU types without company name.
+       # Some are omitted here because they have special meanings below.
+       1750a | 580 \
+       | a29k \
+       | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
+       | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \
+       | am33_2.0 \
+       | arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr \
+       | bfin \
+       | c4x | clipper \
+       | d10v | d30v | dlx | dsp16xx \
+       | fr30 | frv \
+       | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
+       | i370 | i860 | i960 | ia64 \
+       | ip2k | iq2000 \
+       | m32r | m32rle | m68000 | m68k | m88k | maxq | mcore \
+       | mips | mipsbe | mipseb | mipsel | mipsle \
+       | mips16 \
+       | mips64 | mips64el \
+       | mips64vr | mips64vrel \
+       | mips64orion | mips64orionel \
+       | mips64vr4100 | mips64vr4100el \
+       | mips64vr4300 | mips64vr4300el \
+       | mips64vr5000 | mips64vr5000el \
+       | mipsisa32 | mipsisa32el \
+       | mipsisa32r2 | mipsisa32r2el \
+       | mipsisa64 | mipsisa64el \
+       | mipsisa64r2 | mipsisa64r2el \
+       | mipsisa64sb1 | mipsisa64sb1el \
+       | mipsisa64sr71k | mipsisa64sr71kel \
+       | mipstx39 | mipstx39el \
+       | mn10200 | mn10300 \
+       | msp430 \
+       | ns16k | ns32k \
+       | openrisc | or32 \
+       | pdp10 | pdp11 | pj | pjl \
+       | powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \
+       | pyramid \
+       | sh | sh[1234] | sh[23]e | sh[34]eb | shbe | shle | sh[1234]le | sh3ele \
+       | sh64 | sh64le \
+       | sparc | sparc64 | sparc64b | sparc86x | sparclet | sparclite \
+       | sparcv8 | sparcv9 | sparcv9b \
+       | strongarm \
+       | tahoe | thumb | tic4x | tic80 | tron \
+       | v850 | v850e \
+       | we32k \
+       | x86 | xscale | xscalee[bl] | xstormy16 | xtensa \
+       | z8k)
+               basic_machine=$basic_machine-unknown
+               ;;
+       m6811 | m68hc11 | m6812 | m68hc12)
+               # Motorola 68HC11/12.
+               basic_machine=$basic_machine-unknown
+               os=-none
+               ;;
+       m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
+               ;;
+
+       # We use `pc' rather than `unknown'
+       # because (1) that's what they normally are, and
+       # (2) the word "unknown" tends to confuse beginning users.
+       i*86 | x86_64)
+         basic_machine=$basic_machine-pc
+         ;;
+       # Object if more than one company name word.
+       *-*-*)
+               echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
+               exit 1
+               ;;
+       # Recognize the basic CPU types with company name.
+       580-* \
+       | a29k-* \
+       | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
+       | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \
+       | alphapca5[67]-* | alpha64pca5[67]-* | arc-* \
+       | arm-*  | armbe-* | armle-* | armeb-* | armv*-* \
+       | avr-* \
+       | bfin-* | bs2000-* \
+       | c[123]* | c30-* | [cjt]90-* | c4x-* | c54x-* | c55x-* | c6x-* \
+       | clipper-* | craynv-* | cydra-* \
+       | d10v-* | d30v-* | dlx-* \
+       | elxsi-* \
+       | f30[01]-* | f700-* | fr30-* | frv-* | fx80-* \
+       | h8300-* | h8500-* \
+       | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
+       | i*86-* | i860-* | i960-* | ia64-* \
+       | ip2k-* | iq2000-* \
+       | m32r-* | m32rle-* \
+       | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \
+       | m88110-* | m88k-* | maxq-* | mcore-* \
+       | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \
+       | mips16-* \
+       | mips64-* | mips64el-* \
+       | mips64vr-* | mips64vrel-* \
+       | mips64orion-* | mips64orionel-* \
+       | mips64vr4100-* | mips64vr4100el-* \
+       | mips64vr4300-* | mips64vr4300el-* \
+       | mips64vr5000-* | mips64vr5000el-* \
+       | mipsisa32-* | mipsisa32el-* \
+       | mipsisa32r2-* | mipsisa32r2el-* \
+       | mipsisa64-* | mipsisa64el-* \
+       | mipsisa64r2-* | mipsisa64r2el-* \
+       | mipsisa64sb1-* | mipsisa64sb1el-* \
+       | mipsisa64sr71k-* | mipsisa64sr71kel-* \
+       | mipstx39-* | mipstx39el-* \
+       | mmix-* \
+       | msp430-* \
+       | none-* | np1-* | ns16k-* | ns32k-* \
+       | orion-* \
+       | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
+       | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \
+       | pyramid-* \
+       | romp-* | rs6000-* \
+       | sh-* | sh[1234]-* | sh[23]e-* | sh[34]eb-* | shbe-* \
+       | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \
+       | sparc-* | sparc64-* | sparc64b-* | sparc86x-* | sparclet-* \
+       | sparclite-* \
+       | sparcv8-* | sparcv9-* | sparcv9b-* | strongarm-* | sv1-* | sx?-* \
+       | tahoe-* | thumb-* \
+       | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \
+       | tron-* \
+       | v850-* | v850e-* | vax-* \
+       | we32k-* \
+       | x86-* | x86_64-* | xps100-* | xscale-* | xscalee[bl]-* \
+       | xstormy16-* | xtensa-* \
+       | ymp-* \
+       | z8k-*)
+               ;;
+       # Recognize the various machine names and aliases which stand
+       # for a CPU type and a company and sometimes even an OS.
+       386bsd)
+               basic_machine=i386-unknown
+               os=-bsd
+               ;;
+       3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc)
+               basic_machine=m68000-att
+               ;;
+       3b*)
+               basic_machine=we32k-att
+               ;;
+       a29khif)
+               basic_machine=a29k-amd
+               os=-udi
+               ;;
+       abacus)
+               basic_machine=abacus-unknown
+               ;;
+       adobe68k)
+               basic_machine=m68010-adobe
+               os=-scout
+               ;;
+       alliant | fx80)
+               basic_machine=fx80-alliant
+               ;;
+       altos | altos3068)
+               basic_machine=m68k-altos
+               ;;
+       am29k)
+               basic_machine=a29k-none
+               os=-bsd
+               ;;
+       amd64)
+               basic_machine=x86_64-pc
+               ;;
+       amd64-*)
+               basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       amdahl)
+               basic_machine=580-amdahl
+               os=-sysv
+               ;;
+       amiga | amiga-*)
+               basic_machine=m68k-unknown
+               ;;
+       amigaos | amigados)
+               basic_machine=m68k-unknown
+               os=-amigaos
+               ;;
+       amigaunix | amix)
+               basic_machine=m68k-unknown
+               os=-sysv4
+               ;;
+       apollo68)
+               basic_machine=m68k-apollo
+               os=-sysv
+               ;;
+       apollo68bsd)
+               basic_machine=m68k-apollo
+               os=-bsd
+               ;;
+       aux)
+               basic_machine=m68k-apple
+               os=-aux
+               ;;
+       balance)
+               basic_machine=ns32k-sequent
+               os=-dynix
+               ;;
+       c90)
+               basic_machine=c90-cray
+               os=-unicos
+               ;;
+       convex-c1)
+               basic_machine=c1-convex
+               os=-bsd
+               ;;
+       convex-c2)
+               basic_machine=c2-convex
+               os=-bsd
+               ;;
+       convex-c32)
+               basic_machine=c32-convex
+               os=-bsd
+               ;;
+       convex-c34)
+               basic_machine=c34-convex
+               os=-bsd
+               ;;
+       convex-c38)
+               basic_machine=c38-convex
+               os=-bsd
+               ;;
+       cray | j90)
+               basic_machine=j90-cray
+               os=-unicos
+               ;;
+       craynv)
+               basic_machine=craynv-cray
+               os=-unicosmp
+               ;;
+       cr16c)
+               basic_machine=cr16c-unknown
+               os=-elf
+               ;;
+       crds | unos)
+               basic_machine=m68k-crds
+               ;;
+       crisv32 | crisv32-* | etraxfs*)
+               basic_machine=crisv32-axis
+               ;;
+       cris | cris-* | etrax*)
+               basic_machine=cris-axis
+               ;;
+       crx)
+               basic_machine=crx-unknown
+               os=-elf
+               ;;
+       da30 | da30-*)
+               basic_machine=m68k-da30
+               ;;
+       decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn)
+               basic_machine=mips-dec
+               ;;
+       decsystem10* | dec10*)
+               basic_machine=pdp10-dec
+               os=-tops10
+               ;;
+       decsystem20* | dec20*)
+               basic_machine=pdp10-dec
+               os=-tops20
+               ;;
+       delta | 3300 | motorola-3300 | motorola-delta \
+             | 3300-motorola | delta-motorola)
+               basic_machine=m68k-motorola
+               ;;
+       delta88)
+               basic_machine=m88k-motorola
+               os=-sysv3
+               ;;
+       djgpp)
+               basic_machine=i586-pc
+               os=-msdosdjgpp
+               ;;
+       dpx20 | dpx20-*)
+               basic_machine=rs6000-bull
+               os=-bosx
+               ;;
+       dpx2* | dpx2*-bull)
+               basic_machine=m68k-bull
+               os=-sysv3
+               ;;
+       ebmon29k)
+               basic_machine=a29k-amd
+               os=-ebmon
+               ;;
+       elxsi)
+               basic_machine=elxsi-elxsi
+               os=-bsd
+               ;;
+       encore | umax | mmax)
+               basic_machine=ns32k-encore
+               ;;
+       es1800 | OSE68k | ose68k | ose | OSE)
+               basic_machine=m68k-ericsson
+               os=-ose
+               ;;
+       fx2800)
+               basic_machine=i860-alliant
+               ;;
+       genix)
+               basic_machine=ns32k-ns
+               ;;
+       gmicro)
+               basic_machine=tron-gmicro
+               os=-sysv
+               ;;
+       go32)
+               basic_machine=i386-pc
+               os=-go32
+               ;;
+       h3050r* | hiux*)
+               basic_machine=hppa1.1-hitachi
+               os=-hiuxwe2
+               ;;
+       h8300hms)
+               basic_machine=h8300-hitachi
+               os=-hms
+               ;;
+       h8300xray)
+               basic_machine=h8300-hitachi
+               os=-xray
+               ;;
+       h8500hms)
+               basic_machine=h8500-hitachi
+               os=-hms
+               ;;
+       harris)
+               basic_machine=m88k-harris
+               os=-sysv3
+               ;;
+       hp300-*)
+               basic_machine=m68k-hp
+               ;;
+       hp300bsd)
+               basic_machine=m68k-hp
+               os=-bsd
+               ;;
+       hp300hpux)
+               basic_machine=m68k-hp
+               os=-hpux
+               ;;
+       hp3k9[0-9][0-9] | hp9[0-9][0-9])
+               basic_machine=hppa1.0-hp
+               ;;
+       hp9k2[0-9][0-9] | hp9k31[0-9])
+               basic_machine=m68000-hp
+               ;;
+       hp9k3[2-9][0-9])
+               basic_machine=m68k-hp
+               ;;
+       hp9k6[0-9][0-9] | hp6[0-9][0-9])
+               basic_machine=hppa1.0-hp
+               ;;
+       hp9k7[0-79][0-9] | hp7[0-79][0-9])
+               basic_machine=hppa1.1-hp
+               ;;
+       hp9k78[0-9] | hp78[0-9])
+               # FIXME: really hppa2.0-hp
+               basic_machine=hppa1.1-hp
+               ;;
+       hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893)
+               # FIXME: really hppa2.0-hp
+               basic_machine=hppa1.1-hp
+               ;;
+       hp9k8[0-9][13679] | hp8[0-9][13679])
+               basic_machine=hppa1.1-hp
+               ;;
+       hp9k8[0-9][0-9] | hp8[0-9][0-9])
+               basic_machine=hppa1.0-hp
+               ;;
+       hppa-next)
+               os=-nextstep3
+               ;;
+       hppaosf)
+               basic_machine=hppa1.1-hp
+               os=-osf
+               ;;
+       hppro)
+               basic_machine=hppa1.1-hp
+               os=-proelf
+               ;;
+       i370-ibm* | ibm*)
+               basic_machine=i370-ibm
+               ;;
+# I'm not sure what "Sysv32" means.  Should this be sysv3.2?
+       i*86v32)
+               basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+               os=-sysv32
+               ;;
+       i*86v4*)
+               basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+               os=-sysv4
+               ;;
+       i*86v)
+               basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+               os=-sysv
+               ;;
+       i*86sol2)
+               basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+               os=-solaris2
+               ;;
+       i386mach)
+               basic_machine=i386-mach
+               os=-mach
+               ;;
+       i386-vsta | vsta)
+               basic_machine=i386-unknown
+               os=-vsta
+               ;;
+       iris | iris4d)
+               basic_machine=mips-sgi
+               case $os in
+                   -irix*)
+                       ;;
+                   *)
+                       os=-irix4
+                       ;;
+               esac
+               ;;
+       isi68 | isi)
+               basic_machine=m68k-isi
+               os=-sysv
+               ;;
+       m88k-omron*)
+               basic_machine=m88k-omron
+               ;;
+       magnum | m3230)
+               basic_machine=mips-mips
+               os=-sysv
+               ;;
+       merlin)
+               basic_machine=ns32k-utek
+               os=-sysv
+               ;;
+       mingw32)
+               basic_machine=i386-pc
+               os=-mingw32
+               ;;
+       miniframe)
+               basic_machine=m68000-convergent
+               ;;
+       *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*)
+               basic_machine=m68k-atari
+               os=-mint
+               ;;
+       mips3*-*)
+               basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`
+               ;;
+       mips3*)
+               basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown
+               ;;
+       monitor)
+               basic_machine=m68k-rom68k
+               os=-coff
+               ;;
+       morphos)
+               basic_machine=powerpc-unknown
+               os=-morphos
+               ;;
+       msdos)
+               basic_machine=i386-pc
+               os=-msdos
+               ;;
+       mvs)
+               basic_machine=i370-ibm
+               os=-mvs
+               ;;
+       ncr3000)
+               basic_machine=i486-ncr
+               os=-sysv4
+               ;;
+       netbsd386)
+               basic_machine=i386-unknown
+               os=-netbsd
+               ;;
+       netwinder)
+               basic_machine=armv4l-rebel
+               os=-linux
+               ;;
+       news | news700 | news800 | news900)
+               basic_machine=m68k-sony
+               os=-newsos
+               ;;
+       news1000)
+               basic_machine=m68030-sony
+               os=-newsos
+               ;;
+       news-3600 | risc-news)
+               basic_machine=mips-sony
+               os=-newsos
+               ;;
+       necv70)
+               basic_machine=v70-nec
+               os=-sysv
+               ;;
+       next | m*-next )
+               basic_machine=m68k-next
+               case $os in
+                   -nextstep* )
+                       ;;
+                   -ns2*)
+                     os=-nextstep2
+                       ;;
+                   *)
+                     os=-nextstep3
+                       ;;
+               esac
+               ;;
+       nh3000)
+               basic_machine=m68k-harris
+               os=-cxux
+               ;;
+       nh[45]000)
+               basic_machine=m88k-harris
+               os=-cxux
+               ;;
+       nindy960)
+               basic_machine=i960-intel
+               os=-nindy
+               ;;
+       mon960)
+               basic_machine=i960-intel
+               os=-mon960
+               ;;
+       nonstopux)
+               basic_machine=mips-compaq
+               os=-nonstopux
+               ;;
+       np1)
+               basic_machine=np1-gould
+               ;;
+       nsr-tandem)
+               basic_machine=nsr-tandem
+               ;;
+       op50n-* | op60c-*)
+               basic_machine=hppa1.1-oki
+               os=-proelf
+               ;;
+       or32 | or32-*)
+               basic_machine=or32-unknown
+               os=-coff
+               ;;
+       os400)
+               basic_machine=powerpc-ibm
+               os=-os400
+               ;;
+       OSE68000 | ose68000)
+               basic_machine=m68000-ericsson
+               os=-ose
+               ;;
+       os68k)
+               basic_machine=m68k-none
+               os=-os68k
+               ;;
+       pa-hitachi)
+               basic_machine=hppa1.1-hitachi
+               os=-hiuxwe2
+               ;;
+       paragon)
+               basic_machine=i860-intel
+               os=-osf
+               ;;
+       pbd)
+               basic_machine=sparc-tti
+               ;;
+       pbb)
+               basic_machine=m68k-tti
+               ;;
+       pc532 | pc532-*)
+               basic_machine=ns32k-pc532
+               ;;
+       pentium | p5 | k5 | k6 | nexgen | viac3)
+               basic_machine=i586-pc
+               ;;
+       pentiumpro | p6 | 6x86 | athlon | athlon_*)
+               basic_machine=i686-pc
+               ;;
+       pentiumii | pentium2 | pentiumiii | pentium3)
+               basic_machine=i686-pc
+               ;;
+       pentium4)
+               basic_machine=i786-pc
+               ;;
+       pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*)
+               basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       pentiumpro-* | p6-* | 6x86-* | athlon-*)
+               basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*)
+               basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       pentium4-*)
+               basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       pn)
+               basic_machine=pn-gould
+               ;;
+       power)  basic_machine=power-ibm
+               ;;
+       ppc)    basic_machine=powerpc-unknown
+               ;;
+       ppc-*)  basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       ppcle | powerpclittle | ppc-le | powerpc-little)
+               basic_machine=powerpcle-unknown
+               ;;
+       ppcle-* | powerpclittle-*)
+               basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       ppc64)  basic_machine=powerpc64-unknown
+               ;;
+       ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       ppc64le | powerpc64little | ppc64-le | powerpc64-little)
+               basic_machine=powerpc64le-unknown
+               ;;
+       ppc64le-* | powerpc64little-*)
+               basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'`
+               ;;
+       ps2)
+               basic_machine=i386-ibm
+               ;;
+       pw32)
+               basic_machine=i586-unknown
+               os=-pw32
+               ;;
+       rom68k)
+               basic_machine=m68k-rom68k
+               os=-coff
+               ;;
+       rm[46]00)
+               basic_machine=mips-siemens
+               ;;
+       rtpc | rtpc-*)
+               basic_machine=romp-ibm
+               ;;
+       s390 | s390-*)
+               basic_machine=s390-ibm
+               ;;
+       s390x | s390x-*)
+               basic_machine=s390x-ibm
+               ;;
+       sa29200)
+               basic_machine=a29k-amd
+               os=-udi
+               ;;
+       sb1)
+               basic_machine=mipsisa64sb1-unknown
+               ;;
+       sb1el)
+               basic_machine=mipsisa64sb1el-unknown
+               ;;
+       sei)
+               basic_machine=mips-sei
+               os=-seiux
+               ;;
+       sequent)
+               basic_machine=i386-sequent
+               ;;
+       sh)
+               basic_machine=sh-hitachi
+               os=-hms
+               ;;
+       sh64)
+               basic_machine=sh64-unknown
+               ;;
+       sparclite-wrs | simso-wrs)
+               basic_machine=sparclite-wrs
+               os=-vxworks
+               ;;
+       sps7)
+               basic_machine=m68k-bull
+               os=-sysv2
+               ;;
+       spur)
+               basic_machine=spur-unknown
+               ;;
+       st2000)
+               basic_machine=m68k-tandem
+               ;;
+       stratus)
+               basic_machine=i860-stratus
+               os=-sysv4
+               ;;
+       sun2)
+               basic_machine=m68000-sun
+               ;;
+       sun2os3)
+               basic_machine=m68000-sun
+               os=-sunos3
+               ;;
+       sun2os4)
+               basic_machine=m68000-sun
+               os=-sunos4
+               ;;
+       sun3os3)
+               basic_machine=m68k-sun
+               os=-sunos3
+               ;;
+       sun3os4)
+               basic_machine=m68k-sun
+               os=-sunos4
+               ;;
+       sun4os3)
+               basic_machine=sparc-sun
+               os=-sunos3
+               ;;
+       sun4os4)
+               basic_machine=sparc-sun
+               os=-sunos4
+               ;;
+       sun4sol2)
+               basic_machine=sparc-sun
+               os=-solaris2
+               ;;
+       sun3 | sun3-*)
+               basic_machine=m68k-sun
+               ;;
+       sun4)
+               basic_machine=sparc-sun
+               ;;
+       sun386 | sun386i | roadrunner)
+               basic_machine=i386-sun
+               ;;
+       sv1)
+               basic_machine=sv1-cray
+               os=-unicos
+               ;;
+       symmetry)
+               basic_machine=i386-sequent
+               os=-dynix
+               ;;
+       t3e)
+               basic_machine=alphaev5-cray
+               os=-unicos
+               ;;
+       t90)
+               basic_machine=t90-cray
+               os=-unicos
+               ;;
+       tic54x | c54x*)
+               basic_machine=tic54x-unknown
+               os=-coff
+               ;;
+       tic55x | c55x*)
+               basic_machine=tic55x-unknown
+               os=-coff
+               ;;
+       tic6x | c6x*)
+               basic_machine=tic6x-unknown
+               os=-coff
+               ;;
+       tx39)
+               basic_machine=mipstx39-unknown
+               ;;
+       tx39el)
+               basic_machine=mipstx39el-unknown
+               ;;
+       toad1)
+               basic_machine=pdp10-xkl
+               os=-tops20
+               ;;
+       tower | tower-32)
+               basic_machine=m68k-ncr
+               ;;
+       tpf)
+               basic_machine=s390x-ibm
+               os=-tpf
+               ;;
+       udi29k)
+               basic_machine=a29k-amd
+               os=-udi
+               ;;
+       ultra3)
+               basic_machine=a29k-nyu
+               os=-sym1
+               ;;
+       v810 | necv810)
+               basic_machine=v810-nec
+               os=-none
+               ;;
+       vaxv)
+               basic_machine=vax-dec
+               os=-sysv
+               ;;
+       vms)
+               basic_machine=vax-dec
+               os=-vms
+               ;;
+       vpp*|vx|vx-*)
+               basic_machine=f301-fujitsu
+               ;;
+       vxworks960)
+               basic_machine=i960-wrs
+               os=-vxworks
+               ;;
+       vxworks68)
+               basic_machine=m68k-wrs
+               os=-vxworks
+               ;;
+       vxworks29k)
+               basic_machine=a29k-wrs
+               os=-vxworks
+               ;;
+       w65*)
+               basic_machine=w65-wdc
+               os=-none
+               ;;
+       w89k-*)
+               basic_machine=hppa1.1-winbond
+               os=-proelf
+               ;;
+       xbox)
+               basic_machine=i686-pc
+               os=-mingw32
+               ;;
+       xps | xps100)
+               basic_machine=xps100-honeywell
+               ;;
+       ymp)
+               basic_machine=ymp-cray
+               os=-unicos
+               ;;
+       z8k-*-coff)
+               basic_machine=z8k-unknown
+               os=-sim
+               ;;
+       none)
+               basic_machine=none-none
+               os=-none
+               ;;
+
+# Here we handle the default manufacturer of certain CPU types.  It is in
+# some cases the only manufacturer, in others, it is the most popular.
+       w89k)
+               basic_machine=hppa1.1-winbond
+               ;;
+       op50n)
+               basic_machine=hppa1.1-oki
+               ;;
+       op60c)
+               basic_machine=hppa1.1-oki
+               ;;
+       romp)
+               basic_machine=romp-ibm
+               ;;
+       mmix)
+               basic_machine=mmix-knuth
+               ;;
+       rs6000)
+               basic_machine=rs6000-ibm
+               ;;
+       vax)
+               basic_machine=vax-dec
+               ;;
+       pdp10)
+               # there are many clones, so DEC is not a safe bet
+               basic_machine=pdp10-unknown
+               ;;
+       pdp11)
+               basic_machine=pdp11-dec
+               ;;
+       we32k)
+               basic_machine=we32k-att
+               ;;
+       sh3 | sh4 | sh[34]eb | sh[1234]le | sh[23]ele)
+               basic_machine=sh-unknown
+               ;;
+       sh64)
+               basic_machine=sh64-unknown
+               ;;
+       sparc | sparcv8 | sparcv9 | sparcv9b)
+               basic_machine=sparc-sun
+               ;;
+       cydra)
+               basic_machine=cydra-cydrome
+               ;;
+       orion)
+               basic_machine=orion-highlevel
+               ;;
+       orion105)
+               basic_machine=clipper-highlevel
+               ;;
+       mac | mpw | mac-mpw)
+               basic_machine=m68k-apple
+               ;;
+       pmac | pmac-mpw)
+               basic_machine=powerpc-apple
+               ;;
+       *-unknown)
+               # Make sure to match an already-canonicalized machine name.
+               ;;
+       *)
+               echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
+               exit 1
+               ;;
+esac
+
+# Here we canonicalize certain aliases for manufacturers.
+case $basic_machine in
+       *-digital*)
+               basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'`
+               ;;
+       *-commodore*)
+               basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'`
+               ;;
+       *)
+               ;;
+esac
+
+# Decode manufacturer-specific aliases for certain operating systems.
+
+if [ x"$os" != x"" ]
+then
+case $os in
+        # First match some system type aliases
+        # that might get confused with valid system types.
+       # -solaris* is a basic system type, with this one exception.
+       -solaris1 | -solaris1.*)
+               os=`echo $os | sed -e 's|solaris1|sunos4|'`
+               ;;
+       -solaris)
+               os=-solaris2
+               ;;
+       -svr4*)
+               os=-sysv4
+               ;;
+       -unixware*)
+               os=-sysv4.2uw
+               ;;
+       -gnu/linux*)
+               os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'`
+               ;;
+       # First accept the basic system types.
+       # The portable systems comes first.
+       # Each alternative MUST END IN A *, to match a version number.
+       # -sysv* is not here because it comes later, after sysvr4.
+       -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
+             | -*vms* | -sco* | -esix* | -isc* | -aix* | -sunos | -sunos[34]*\
+             | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \
+             | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \
+             | -aos* \
+             | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
+             | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
+             | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* | -openbsd* \
+             | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \
+             | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
+             | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
+             | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
+             | -chorusos* | -chorusrdb* \
+             | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
+             | -mingw32* | -linux-gnu* | -linux-uclibc* | -uxpv* | -beos* | -mpeix* | -udk* \
+             | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
+             | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
+             | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \
+             | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \
+             | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \
+             | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly*)
+       # Remember, each alternative MUST END IN *, to match a version number.
+               ;;
+       -qnx*)
+               case $basic_machine in
+                   x86-* | i*86-*)
+                       ;;
+                   *)
+                       os=-nto$os
+                       ;;
+               esac
+               ;;
+       -nto-qnx*)
+               ;;
+       -nto*)
+               os=`echo $os | sed -e 's|nto|nto-qnx|'`
+               ;;
+       -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \
+             | -windows* | -osx | -abug | -netware* | -os9* | -beos* \
+             | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*)
+               ;;
+       -mac*)
+               os=`echo $os | sed -e 's|mac|macos|'`
+               ;;
+       -linux-dietlibc)
+               os=-linux-dietlibc
+               ;;
+       -linux*)
+               os=`echo $os | sed -e 's|linux|linux-gnu|'`
+               ;;
+       -sunos5*)
+               os=`echo $os | sed -e 's|sunos5|solaris2|'`
+               ;;
+       -sunos6*)
+               os=`echo $os | sed -e 's|sunos6|solaris3|'`
+               ;;
+       -opened*)
+               os=-openedition
+               ;;
+        -os400*)
+               os=-os400
+               ;;
+       -wince*)
+               os=-wince
+               ;;
+       -osfrose*)
+               os=-osfrose
+               ;;
+       -osf*)
+               os=-osf
+               ;;
+       -utek*)
+               os=-bsd
+               ;;
+       -dynix*)
+               os=-bsd
+               ;;
+       -acis*)
+               os=-aos
+               ;;
+       -atheos*)
+               os=-atheos
+               ;;
+       -syllable*)
+               os=-syllable
+               ;;
+       -386bsd)
+               os=-bsd
+               ;;
+       -ctix* | -uts*)
+               os=-sysv
+               ;;
+       -nova*)
+               os=-rtmk-nova
+               ;;
+       -ns2 )
+               os=-nextstep2
+               ;;
+       -nsk*)
+               os=-nsk
+               ;;
+       # Preserve the version number of sinix5.
+       -sinix5.*)
+               os=`echo $os | sed -e 's|sinix|sysv|'`
+               ;;
+       -sinix*)
+               os=-sysv4
+               ;;
+        -tpf*)
+               os=-tpf
+               ;;
+       -triton*)
+               os=-sysv3
+               ;;
+       -oss*)
+               os=-sysv3
+               ;;
+       -svr4)
+               os=-sysv4
+               ;;
+       -svr3)
+               os=-sysv3
+               ;;
+       -sysvr4)
+               os=-sysv4
+               ;;
+       # This must come after -sysvr4.
+       -sysv*)
+               ;;
+       -ose*)
+               os=-ose
+               ;;
+       -es1800*)
+               os=-ose
+               ;;
+       -xenix)
+               os=-xenix
+               ;;
+       -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
+               os=-mint
+               ;;
+       -aros*)
+               os=-aros
+               ;;
+       -kaos*)
+               os=-kaos
+               ;;
+       -zvmoe)
+               os=-zvmoe
+               ;;
+       -none)
+               ;;
+       *)
+               # Get rid of the `-' at the beginning of $os.
+               os=`echo $os | sed 's/[^-]*-//'`
+               echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2
+               exit 1
+               ;;
+esac
+else
+
+# Here we handle the default operating systems that come with various machines.
+# The value should be what the vendor currently ships out the door with their
+# machine or put another way, the most popular os provided with the machine.
+
+# Note that if you're going to try to match "-MANUFACTURER" here (say,
+# "-sun"), then you have to tell the case statement up towards the top
+# that MANUFACTURER isn't an operating system.  Otherwise, code above
+# will signal an error saying that MANUFACTURER isn't an operating
+# system, and we'll never get to this point.
+
+case $basic_machine in
+       *-acorn)
+               os=-riscix1.2
+               ;;
+       arm*-rebel)
+               os=-linux
+               ;;
+       arm*-semi)
+               os=-aout
+               ;;
+    c4x-* | tic4x-*)
+        os=-coff
+        ;;
+       # This must come before the *-dec entry.
+       pdp10-*)
+               os=-tops20
+               ;;
+       pdp11-*)
+               os=-none
+               ;;
+       *-dec | vax-*)
+               os=-ultrix4.2
+               ;;
+       m68*-apollo)
+               os=-domain
+               ;;
+       i386-sun)
+               os=-sunos4.0.2
+               ;;
+       m68000-sun)
+               os=-sunos3
+               # This also exists in the configure program, but was not the
+               # default.
+               # os=-sunos4
+               ;;
+       m68*-cisco)
+               os=-aout
+               ;;
+       mips*-cisco)
+               os=-elf
+               ;;
+       mips*-*)
+               os=-elf
+               ;;
+       or32-*)
+               os=-coff
+               ;;
+       *-tti)  # must be before sparc entry or we get the wrong os.
+               os=-sysv3
+               ;;
+       sparc-* | *-sun)
+               os=-sunos4.1.1
+               ;;
+       *-be)
+               os=-beos
+               ;;
+       *-ibm)
+               os=-aix
+               ;;
+       *-knuth)
+               os=-mmixware
+               ;;
+       *-wec)
+               os=-proelf
+               ;;
+       *-winbond)
+               os=-proelf
+               ;;
+       *-oki)
+               os=-proelf
+               ;;
+       *-hp)
+               os=-hpux
+               ;;
+       *-hitachi)
+               os=-hiux
+               ;;
+       i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent)
+               os=-sysv
+               ;;
+       *-cbm)
+               os=-amigaos
+               ;;
+       *-dg)
+               os=-dgux
+               ;;
+       *-dolphin)
+               os=-sysv3
+               ;;
+       m68k-ccur)
+               os=-rtu
+               ;;
+       m88k-omron*)
+               os=-luna
+               ;;
+       *-next )
+               os=-nextstep
+               ;;
+       *-sequent)
+               os=-ptx
+               ;;
+       *-crds)
+               os=-unos
+               ;;
+       *-ns)
+               os=-genix
+               ;;
+       i370-*)
+               os=-mvs
+               ;;
+       *-next)
+               os=-nextstep3
+               ;;
+       *-gould)
+               os=-sysv
+               ;;
+       *-highlevel)
+               os=-bsd
+               ;;
+       *-encore)
+               os=-bsd
+               ;;
+       *-sgi)
+               os=-irix
+               ;;
+       *-siemens)
+               os=-sysv4
+               ;;
+       *-masscomp)
+               os=-rtu
+               ;;
+       f30[01]-fujitsu | f700-fujitsu)
+               os=-uxpv
+               ;;
+       *-rom68k)
+               os=-coff
+               ;;
+       *-*bug)
+               os=-coff
+               ;;
+       *-apple)
+               os=-macos
+               ;;
+       *-atari*)
+               os=-mint
+               ;;
+       *)
+               os=-none
+               ;;
+esac
+fi
+
+# Here we handle the case where we know the os, and the CPU type, but not the
+# manufacturer.  We pick the logical manufacturer.
+vendor=unknown
+case $basic_machine in
+       *-unknown)
+               case $os in
+                       -riscix*)
+                               vendor=acorn
+                               ;;
+                       -sunos*)
+                               vendor=sun
+                               ;;
+                       -aix*)
+                               vendor=ibm
+                               ;;
+                       -beos*)
+                               vendor=be
+                               ;;
+                       -hpux*)
+                               vendor=hp
+                               ;;
+                       -mpeix*)
+                               vendor=hp
+                               ;;
+                       -hiux*)
+                               vendor=hitachi
+                               ;;
+                       -unos*)
+                               vendor=crds
+                               ;;
+                       -dgux*)
+                               vendor=dg
+                               ;;
+                       -luna*)
+                               vendor=omron
+                               ;;
+                       -genix*)
+                               vendor=ns
+                               ;;
+                       -mvs* | -opened*)
+                               vendor=ibm
+                               ;;
+                       -os400*)
+                               vendor=ibm
+                               ;;
+                       -ptx*)
+                               vendor=sequent
+                               ;;
+                       -tpf*)
+                               vendor=ibm
+                               ;;
+                       -vxsim* | -vxworks* | -windiss*)
+                               vendor=wrs
+                               ;;
+                       -aux*)
+                               vendor=apple
+                               ;;
+                       -hms*)
+                               vendor=hitachi
+                               ;;
+                       -mpw* | -macos*)
+                               vendor=apple
+                               ;;
+                       -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
+                               vendor=atari
+                               ;;
+                       -vos*)
+                               vendor=stratus
+                               ;;
+               esac
+               basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
+               ;;
+esac
+
+echo $basic_machine$os
+exit 0
+
+# Local variables:
+# eval: (add-hook 'write-file-hooks 'time-stamp)
+# time-stamp-start: "timestamp='"
+# time-stamp-format: "%:y-%02m-%02d"
+# time-stamp-end: "'"
+# End:
diff --git a/configure b/configure
new file mode 100755 (executable)
index 0000000..9703bcb
--- /dev/null
+++ b/configure
@@ -0,0 +1,16495 @@
+#! /bin/sh
+# Guess values for system-dependent variables and create Makefiles.
+# Generated by GNU Autoconf 2.63 for libtheora 1.1.1.
+#
+# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001,
+# 2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
+# This configure script is free software; the Free Software Foundation
+# gives unlimited permission to copy, distribute and modify it.
+## --------------------- ##
+## M4sh Initialization.  ##
+## --------------------- ##
+
+# Be more Bourne compatible
+DUALCASE=1; export DUALCASE # for MKS sh
+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
+  emulate sh
+  NULLCMD=:
+  # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
+  # is contrary to our usage.  Disable this feature.
+  alias -g '${1+"$@"}'='"$@"'
+  setopt NO_GLOB_SUBST
+else
+  case `(set -o) 2>/dev/null` in
+  *posix*) set -o posix ;;
+esac
+
+fi
+
+
+
+
+# PATH needs CR
+# Avoid depending upon Character Ranges.
+as_cr_letters='abcdefghijklmnopqrstuvwxyz'
+as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ'
+as_cr_Letters=$as_cr_letters$as_cr_LETTERS
+as_cr_digits='0123456789'
+as_cr_alnum=$as_cr_Letters$as_cr_digits
+
+as_nl='
+'
+export as_nl
+# Printing a long string crashes Solaris 7 /usr/bin/printf.
+as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\'
+as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo
+as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo
+if (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then
+  as_echo='printf %s\n'
+  as_echo_n='printf %s'
+else
+  if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then
+    as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"'
+    as_echo_n='/usr/ucb/echo -n'
+  else
+    as_echo_body='eval expr "X$1" : "X\\(.*\\)"'
+    as_echo_n_body='eval
+      arg=$1;
+      case $arg in
+      *"$as_nl"*)
+       expr "X$arg" : "X\\(.*\\)$as_nl";
+       arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;;
+      esac;
+      expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl"
+    '
+    export as_echo_n_body
+    as_echo_n='sh -c $as_echo_n_body as_echo'
+  fi
+  export as_echo_body
+  as_echo='sh -c $as_echo_body as_echo'
+fi
+
+# The user is always right.
+if test "${PATH_SEPARATOR+set}" != set; then
+  PATH_SEPARATOR=:
+  (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && {
+    (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 ||
+      PATH_SEPARATOR=';'
+  }
+fi
+
+# Support unset when possible.
+if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
+  as_unset=unset
+else
+  as_unset=false
+fi
+
+
+# IFS
+# We need space, tab and new line, in precisely that order.  Quoting is
+# there to prevent editors from complaining about space-tab.
+# (If _AS_PATH_WALK were called with IFS unset, it would disable word
+# splitting by setting IFS to empty value.)
+IFS=" ""       $as_nl"
+
+# Find who we are.  Look in the path if we contain no directory separator.
+case $0 in
+  *[\\/]* ) as_myself=$0 ;;
+  *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break
+done
+IFS=$as_save_IFS
+
+     ;;
+esac
+# We did not find ourselves, most probably we were run as `sh COMMAND'
+# in which case we are not to be found in the path.
+if test "x$as_myself" = x; then
+  as_myself=$0
+fi
+if test ! -f "$as_myself"; then
+  $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2
+  { (exit 1); exit 1; }
+fi
+
+# Work around bugs in pre-3.0 UWIN ksh.
+for as_var in ENV MAIL MAILPATH
+do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var
+done
+PS1='$ '
+PS2='> '
+PS4='+ '
+
+# NLS nuisances.
+LC_ALL=C
+export LC_ALL
+LANGUAGE=C
+export LANGUAGE
+
+# Required to use basename.
+if expr a : '\(a\)' >/dev/null 2>&1 &&
+   test "X`expr 00001 : '.*\(...\)'`" = X001; then
+  as_expr=expr
+else
+  as_expr=false
+fi
+
+if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then
+  as_basename=basename
+else
+  as_basename=false
+fi
+
+
+# Name of the executable.
+as_me=`$as_basename -- "$0" ||
+$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \
+        X"$0" : 'X\(//\)$' \| \
+        X"$0" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X/"$0" |
+    sed '/^.*\/\([^/][^/]*\)\/*$/{
+           s//\1/
+           q
+         }
+         /^X\/\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\/\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+
+# CDPATH.
+$as_unset CDPATH
+
+
+if test "x$CONFIG_SHELL" = x; then
+  if (eval ":") 2>/dev/null; then
+  as_have_required=yes
+else
+  as_have_required=no
+fi
+
+  if test $as_have_required = yes &&    (eval ":
+(as_func_return () {
+  (exit \$1)
+}
+as_func_success () {
+  as_func_return 0
+}
+as_func_failure () {
+  as_func_return 1
+}
+as_func_ret_success () {
+  return 0
+}
+as_func_ret_failure () {
+  return 1
+}
+
+exitcode=0
+if as_func_success; then
+  :
+else
+  exitcode=1
+  echo as_func_success failed.
+fi
+
+if as_func_failure; then
+  exitcode=1
+  echo as_func_failure succeeded.
+fi
+
+if as_func_ret_success; then
+  :
+else
+  exitcode=1
+  echo as_func_ret_success failed.
+fi
+
+if as_func_ret_failure; then
+  exitcode=1
+  echo as_func_ret_failure succeeded.
+fi
+
+if ( set x; as_func_ret_success y && test x = \"\$1\" ); then
+  :
+else
+  exitcode=1
+  echo positional parameters were not saved.
+fi
+
+test \$exitcode = 0) || { (exit 1); exit 1; }
+
+(
+  as_lineno_1=\$LINENO
+  as_lineno_2=\$LINENO
+  test \"x\$as_lineno_1\" != \"x\$as_lineno_2\" &&
+  test \"x\`expr \$as_lineno_1 + 1\`\" = \"x\$as_lineno_2\") || { (exit 1); exit 1; }
+") 2> /dev/null; then
+  :
+else
+  as_candidate_shells=
+    as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  case $as_dir in
+        /*)
+          for as_base in sh bash ksh sh5; do
+            as_candidate_shells="$as_candidate_shells $as_dir/$as_base"
+          done;;
+       esac
+done
+IFS=$as_save_IFS
+
+
+      for as_shell in $as_candidate_shells $SHELL; do
+        # Try only shells that exist, to save several forks.
+        if { test -f "$as_shell" || test -f "$as_shell.exe"; } &&
+               { ("$as_shell") 2> /dev/null <<\_ASEOF
+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
+  emulate sh
+  NULLCMD=:
+  # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
+  # is contrary to our usage.  Disable this feature.
+  alias -g '${1+"$@"}'='"$@"'
+  setopt NO_GLOB_SUBST
+else
+  case `(set -o) 2>/dev/null` in
+  *posix*) set -o posix ;;
+esac
+
+fi
+
+
+:
+_ASEOF
+}; then
+  CONFIG_SHELL=$as_shell
+              as_have_required=yes
+              if { "$as_shell" 2> /dev/null <<\_ASEOF
+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
+  emulate sh
+  NULLCMD=:
+  # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
+  # is contrary to our usage.  Disable this feature.
+  alias -g '${1+"$@"}'='"$@"'
+  setopt NO_GLOB_SUBST
+else
+  case `(set -o) 2>/dev/null` in
+  *posix*) set -o posix ;;
+esac
+
+fi
+
+
+:
+(as_func_return () {
+  (exit $1)
+}
+as_func_success () {
+  as_func_return 0
+}
+as_func_failure () {
+  as_func_return 1
+}
+as_func_ret_success () {
+  return 0
+}
+as_func_ret_failure () {
+  return 1
+}
+
+exitcode=0
+if as_func_success; then
+  :
+else
+  exitcode=1
+  echo as_func_success failed.
+fi
+
+if as_func_failure; then
+  exitcode=1
+  echo as_func_failure succeeded.
+fi
+
+if as_func_ret_success; then
+  :
+else
+  exitcode=1
+  echo as_func_ret_success failed.
+fi
+
+if as_func_ret_failure; then
+  exitcode=1
+  echo as_func_ret_failure succeeded.
+fi
+
+if ( set x; as_func_ret_success y && test x = "$1" ); then
+  :
+else
+  exitcode=1
+  echo positional parameters were not saved.
+fi
+
+test $exitcode = 0) || { (exit 1); exit 1; }
+
+(
+  as_lineno_1=$LINENO
+  as_lineno_2=$LINENO
+  test "x$as_lineno_1" != "x$as_lineno_2" &&
+  test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2") || { (exit 1); exit 1; }
+
+_ASEOF
+}; then
+  break
+fi
+
+fi
+
+      done
+
+      if test "x$CONFIG_SHELL" != x; then
+  for as_var in BASH_ENV ENV
+       do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var
+       done
+       export CONFIG_SHELL
+       exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"}
+fi
+
+
+    if test $as_have_required = no; then
+  echo This script requires a shell more modern than all the
+      echo shells that I found on your system.  Please install a
+      echo modern shell, or manually run the script under such a
+      echo shell if you do have one.
+      { (exit 1); exit 1; }
+fi
+
+
+fi
+
+fi
+
+
+
+(eval "as_func_return () {
+  (exit \$1)
+}
+as_func_success () {
+  as_func_return 0
+}
+as_func_failure () {
+  as_func_return 1
+}
+as_func_ret_success () {
+  return 0
+}
+as_func_ret_failure () {
+  return 1
+}
+
+exitcode=0
+if as_func_success; then
+  :
+else
+  exitcode=1
+  echo as_func_success failed.
+fi
+
+if as_func_failure; then
+  exitcode=1
+  echo as_func_failure succeeded.
+fi
+
+if as_func_ret_success; then
+  :
+else
+  exitcode=1
+  echo as_func_ret_success failed.
+fi
+
+if as_func_ret_failure; then
+  exitcode=1
+  echo as_func_ret_failure succeeded.
+fi
+
+if ( set x; as_func_ret_success y && test x = \"\$1\" ); then
+  :
+else
+  exitcode=1
+  echo positional parameters were not saved.
+fi
+
+test \$exitcode = 0") || {
+  echo No shell found that supports shell functions.
+  echo Please tell bug-autoconf@gnu.org about your system,
+  echo including any error possibly output before this message.
+  echo This can help us improve future autoconf versions.
+  echo Configuration will now proceed without shell functions.
+}
+
+
+
+  as_lineno_1=$LINENO
+  as_lineno_2=$LINENO
+  test "x$as_lineno_1" != "x$as_lineno_2" &&
+  test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2" || {
+
+  # Create $as_me.lineno as a copy of $as_myself, but with $LINENO
+  # uniformly replaced by the line number.  The first 'sed' inserts a
+  # line-number line after each line using $LINENO; the second 'sed'
+  # does the real work.  The second script uses 'N' to pair each
+  # line-number line with the line containing $LINENO, and appends
+  # trailing '-' during substitution so that $LINENO is not a special
+  # case at line end.
+  # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the
+  # scripts with optimization help from Paolo Bonzini.  Blame Lee
+  # E. McMahon (1931-1989) for sed's syntax.  :-)
+  sed -n '
+    p
+    /[$]LINENO/=
+  ' <$as_myself |
+    sed '
+      s/[$]LINENO.*/&-/
+      t lineno
+      b
+      :lineno
+      N
+      :loop
+      s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/
+      t loop
+      s/-\n.*//
+    ' >$as_me.lineno &&
+  chmod +x "$as_me.lineno" ||
+    { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2
+   { (exit 1); exit 1; }; }
+
+  # Don't try to exec as it changes $[0], causing all sort of problems
+  # (the dirname of $[0] is not the place where we might find the
+  # original and so on.  Autoconf is especially sensitive to this).
+  . "./$as_me.lineno"
+  # Exit status is that of the last command.
+  exit
+}
+
+
+if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then
+  as_dirname=dirname
+else
+  as_dirname=false
+fi
+
+ECHO_C= ECHO_N= ECHO_T=
+case `echo -n x` in
+-n*)
+  case `echo 'x\c'` in
+  *c*) ECHO_T='        ';;     # ECHO_T is single tab character.
+  *)   ECHO_C='\c';;
+  esac;;
+*)
+  ECHO_N='-n';;
+esac
+if expr a : '\(a\)' >/dev/null 2>&1 &&
+   test "X`expr 00001 : '.*\(...\)'`" = X001; then
+  as_expr=expr
+else
+  as_expr=false
+fi
+
+rm -f conf$$ conf$$.exe conf$$.file
+if test -d conf$$.dir; then
+  rm -f conf$$.dir/conf$$.file
+else
+  rm -f conf$$.dir
+  mkdir conf$$.dir 2>/dev/null
+fi
+if (echo >conf$$.file) 2>/dev/null; then
+  if ln -s conf$$.file conf$$ 2>/dev/null; then
+    as_ln_s='ln -s'
+    # ... but there are two gotchas:
+    # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail.
+    # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable.
+    # In both cases, we have to default to `cp -p'.
+    ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe ||
+      as_ln_s='cp -p'
+  elif ln conf$$.file conf$$ 2>/dev/null; then
+    as_ln_s=ln
+  else
+    as_ln_s='cp -p'
+  fi
+else
+  as_ln_s='cp -p'
+fi
+rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file
+rmdir conf$$.dir 2>/dev/null
+
+if mkdir -p . 2>/dev/null; then
+  as_mkdir_p=:
+else
+  test -d ./-p && rmdir ./-p
+  as_mkdir_p=false
+fi
+
+if test -x / >/dev/null 2>&1; then
+  as_test_x='test -x'
+else
+  if ls -dL / >/dev/null 2>&1; then
+    as_ls_L_option=L
+  else
+    as_ls_L_option=
+  fi
+  as_test_x='
+    eval sh -c '\''
+      if test -d "$1"; then
+       test -d "$1/.";
+      else
+       case $1 in
+       -*)set "./$1";;
+       esac;
+       case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in
+       ???[sx]*):;;*)false;;esac;fi
+    '\'' sh
+  '
+fi
+as_executable_p=$as_test_x
+
+# Sed expression to map a string onto a valid CPP name.
+as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'"
+
+# Sed expression to map a string onto a valid variable name.
+as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'"
+
+
+
+
+# Check that we are running under the correct shell.
+SHELL=${CONFIG_SHELL-/bin/sh}
+
+case X$lt_ECHO in
+X*--fallback-echo)
+  # Remove one level of quotation (which was required for Make).
+  ECHO=`echo "$lt_ECHO" | sed 's,\\\\\$\\$0,'$0','`
+  ;;
+esac
+
+ECHO=${lt_ECHO-echo}
+if test "X$1" = X--no-reexec; then
+  # Discard the --no-reexec flag, and continue.
+  shift
+elif test "X$1" = X--fallback-echo; then
+  # Avoid inline document here, it may be left over
+  :
+elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' ; then
+  # Yippee, $ECHO works!
+  :
+else
+  # Restart under the correct shell.
+  exec $SHELL "$0" --no-reexec ${1+"$@"}
+fi
+
+if test "X$1" = X--fallback-echo; then
+  # used as fallback echo
+  shift
+  cat <<_LT_EOF
+$*
+_LT_EOF
+  exit 0
+fi
+
+# The HP-UX ksh and POSIX shell print the target directory to stdout
+# if CDPATH is set.
+(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
+
+if test -z "$lt_ECHO"; then
+  if test "X${echo_test_string+set}" != Xset; then
+    # find a string as large as possible, as long as the shell can cope with it
+    for cmd in 'sed 50q "$0"' 'sed 20q "$0"' 'sed 10q "$0"' 'sed 2q "$0"' 'echo test'; do
+      # expected sizes: less than 2Kb, 1Kb, 512 bytes, 16 bytes, ...
+      if { echo_test_string=`eval $cmd`; } 2>/dev/null &&
+        { test "X$echo_test_string" = "X$echo_test_string"; } 2>/dev/null
+      then
+        break
+      fi
+    done
+  fi
+
+  if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' &&
+     echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` &&
+     test "X$echo_testing_string" = "X$echo_test_string"; then
+    :
+  else
+    # The Solaris, AIX, and Digital Unix default echo programs unquote
+    # backslashes.  This makes it impossible to quote backslashes using
+    #   echo "$something" | sed 's/\\/\\\\/g'
+    #
+    # So, first we look for a working echo in the user's PATH.
+
+    lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+    for dir in $PATH /usr/ucb; do
+      IFS="$lt_save_ifs"
+      if (test -f $dir/echo || test -f $dir/echo$ac_exeext) &&
+         test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' &&
+         echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` &&
+         test "X$echo_testing_string" = "X$echo_test_string"; then
+        ECHO="$dir/echo"
+        break
+      fi
+    done
+    IFS="$lt_save_ifs"
+
+    if test "X$ECHO" = Xecho; then
+      # We didn't find a better echo, so look for alternatives.
+      if test "X`{ print -r '\t'; } 2>/dev/null`" = 'X\t' &&
+         echo_testing_string=`{ print -r "$echo_test_string"; } 2>/dev/null` &&
+         test "X$echo_testing_string" = "X$echo_test_string"; then
+        # This shell has a builtin print -r that does the trick.
+        ECHO='print -r'
+      elif { test -f /bin/ksh || test -f /bin/ksh$ac_exeext; } &&
+          test "X$CONFIG_SHELL" != X/bin/ksh; then
+        # If we have ksh, try running configure again with it.
+        ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh}
+        export ORIGINAL_CONFIG_SHELL
+        CONFIG_SHELL=/bin/ksh
+        export CONFIG_SHELL
+        exec $CONFIG_SHELL "$0" --no-reexec ${1+"$@"}
+      else
+        # Try using printf.
+        ECHO='printf %s\n'
+        if test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t' &&
+          echo_testing_string=`{ $ECHO "$echo_test_string"; } 2>/dev/null` &&
+          test "X$echo_testing_string" = "X$echo_test_string"; then
+         # Cool, printf works
+         :
+        elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "$0" --fallback-echo '\t') 2>/dev/null` &&
+            test "X$echo_testing_string" = 'X\t' &&
+            echo_testing_string=`($ORIGINAL_CONFIG_SHELL "$0" --fallback-echo "$echo_test_string") 2>/dev/null` &&
+            test "X$echo_testing_string" = "X$echo_test_string"; then
+         CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL
+         export CONFIG_SHELL
+         SHELL="$CONFIG_SHELL"
+         export SHELL
+         ECHO="$CONFIG_SHELL $0 --fallback-echo"
+        elif echo_testing_string=`($CONFIG_SHELL "$0" --fallback-echo '\t') 2>/dev/null` &&
+            test "X$echo_testing_string" = 'X\t' &&
+            echo_testing_string=`($CONFIG_SHELL "$0" --fallback-echo "$echo_test_string") 2>/dev/null` &&
+            test "X$echo_testing_string" = "X$echo_test_string"; then
+         ECHO="$CONFIG_SHELL $0 --fallback-echo"
+        else
+         # maybe with a smaller string...
+         prev=:
+
+         for cmd in 'echo test' 'sed 2q "$0"' 'sed 10q "$0"' 'sed 20q "$0"' 'sed 50q "$0"'; do
+           if { test "X$echo_test_string" = "X`eval $cmd`"; } 2>/dev/null
+           then
+             break
+           fi
+           prev="$cmd"
+         done
+
+         if test "$prev" != 'sed 50q "$0"'; then
+           echo_test_string=`eval $prev`
+           export echo_test_string
+           exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "$0" ${1+"$@"}
+         else
+           # Oops.  We lost completely, so just stick with echo.
+           ECHO=echo
+         fi
+        fi
+      fi
+    fi
+  fi
+fi
+
+# Copy echo and quote the copy suitably for passing to libtool from
+# the Makefile, instead of quoting the original, which is used later.
+lt_ECHO=$ECHO
+if test "X$lt_ECHO" = "X$CONFIG_SHELL $0 --fallback-echo"; then
+   lt_ECHO="$CONFIG_SHELL \\\$\$0 --fallback-echo"
+fi
+
+
+
+
+exec 7<&0 </dev/null 6>&1
+
+# Name of the host.
+# hostname on some systems (SVR3.2, Linux) returns a bogus exit status,
+# so uname gets run too.
+ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q`
+
+#
+# Initializations.
+#
+ac_default_prefix=/usr/local
+ac_clean_files=
+ac_config_libobj_dir=.
+LIBOBJS=
+cross_compiling=no
+subdirs=
+MFLAGS=
+MAKEFLAGS=
+SHELL=${CONFIG_SHELL-/bin/sh}
+
+# Identity of this package.
+PACKAGE_NAME='libtheora'
+PACKAGE_TARNAME='libtheora'
+PACKAGE_VERSION='1.1.1'
+PACKAGE_STRING='libtheora 1.1.1'
+PACKAGE_BUGREPORT=''
+
+ac_unique_file="lib/fdct.c"
+# Factoring default headers for most tests.
+ac_includes_default="\
+#include <stdio.h>
+#ifdef HAVE_SYS_TYPES_H
+# include <sys/types.h>
+#endif
+#ifdef HAVE_SYS_STAT_H
+# include <sys/stat.h>
+#endif
+#ifdef STDC_HEADERS
+# include <stdlib.h>
+# include <stddef.h>
+#else
+# ifdef HAVE_STDLIB_H
+#  include <stdlib.h>
+# endif
+#endif
+#ifdef HAVE_STRING_H
+# if !defined STDC_HEADERS && defined HAVE_MEMORY_H
+#  include <memory.h>
+# endif
+# include <string.h>
+#endif
+#ifdef HAVE_STRINGS_H
+# include <strings.h>
+#endif
+#ifdef HAVE_INTTYPES_H
+# include <inttypes.h>
+#endif
+#ifdef HAVE_STDINT_H
+# include <stdint.h>
+#endif
+#ifdef HAVE_UNISTD_H
+# include <unistd.h>
+#endif"
+
+ac_subst_vars='DOCDIR
+BINDIR
+INCLUDEDIR
+LIBDIR
+LTLIBOBJS
+LIBOBJS
+PROFILE
+DEBUG
+BUILDABLE_EXAMPLES
+GETOPT_OBJS
+THEORA_ENABLE_EXAMPLES_FALSE
+THEORA_ENABLE_EXAMPLES_TRUE
+THEORA_DISABLE_ENCODE_FALSE
+THEORA_DISABLE_ENCODE_TRUE
+THEORA_DISABLE_FLOAT_FALSE
+THEORA_DISABLE_FLOAT_TRUE
+CAIRO_LIBS
+CAIRO_CFLAGS
+PNG_LIBS
+PNG_CFLAGS
+OSS_LIBS
+SDL_LIBS
+SDL_CFLAGS
+SDL_CONFIG
+VORBISFILE_LIBS
+VORBISENC_LIBS
+VORBIS_LIBS
+VORBIS_CFLAGS
+OGG_LIBS
+OGG_CFLAGS
+PKG_CONFIG
+HAVE_PKG_CONFIG
+THEORA_LDFLAGS
+THEORAENC_LDFLAGS
+THEORADEC_LDFLAGS
+CPU_x86_32_FALSE
+CPU_x86_32_TRUE
+CPU_x86_64_FALSE
+CPU_x86_64_TRUE
+VALGRIND_ENVIRONMENT
+HAVE_VALGRIND
+BUILD_SPEC_FALSE
+BUILD_SPEC_TRUE
+HAVE_TRANSFIG
+HAVE_BIBTEX
+HAVE_PDFLATEX
+HAVE_DOXYGEN_FALSE
+HAVE_DOXYGEN_TRUE
+HAVE_DOXYGEN
+ACLOCAL_AMFLAGS
+OTOOL64
+OTOOL
+LIPO
+NMEDIT
+DSYMUTIL
+lt_ECHO
+RANLIB
+AR
+LN_S
+NM
+ac_ct_DUMPBIN
+DUMPBIN
+LD
+FGREP
+EGREP
+GREP
+SED
+LIBTOOL
+OBJDUMP
+DLLTOOL
+AS
+CPP
+CCDEPMODE
+AMDEPBACKSLASH
+AMDEP_FALSE
+AMDEP_TRUE
+am__quote
+am__include
+DEPDIR
+OBJEXT
+EXEEXT
+ac_ct_CC
+CPPFLAGS
+LDFLAGS
+CFLAGS
+CC
+THENC_LIB_AGE
+THENC_LIB_REVISION
+THENC_LIB_CURRENT
+THDEC_LIB_AGE
+THDEC_LIB_REVISION
+THDEC_LIB_CURRENT
+TH_LIB_AGE
+TH_LIB_REVISION
+TH_LIB_CURRENT
+MAINT
+MAINTAINER_MODE_FALSE
+MAINTAINER_MODE_TRUE
+SET_MAKE
+AWK
+INSTALL_STRIP_PROGRAM
+STRIP
+install_sh
+AMTAR
+MAKEINFO
+AUTOHEADER
+AUTOMAKE
+AUTOCONF
+ACLOCAL
+VERSION
+PACKAGE
+INSTALL_DATA
+INSTALL_SCRIPT
+INSTALL_PROGRAM
+target_os
+target_vendor
+target_cpu
+target
+host_os
+host_vendor
+host_cpu
+host
+build_os
+build_vendor
+build_cpu
+build
+target_alias
+host_alias
+build_alias
+LIBS
+ECHO_T
+ECHO_N
+ECHO_C
+DEFS
+mandir
+localedir
+libdir
+psdir
+pdfdir
+dvidir
+htmldir
+infodir
+docdir
+oldincludedir
+includedir
+localstatedir
+sharedstatedir
+sysconfdir
+datadir
+datarootdir
+libexecdir
+sbindir
+bindir
+program_transform_name
+prefix
+exec_prefix
+PACKAGE_BUGREPORT
+PACKAGE_STRING
+PACKAGE_VERSION
+PACKAGE_TARNAME
+PACKAGE_NAME
+PATH_SEPARATOR
+SHELL'
+ac_subst_files=''
+ac_user_opts='
+enable_option_checking
+enable_maintainer_mode
+enable_dependency_tracking
+enable_shared
+enable_static
+with_pic
+enable_fast_install
+with_gnu_ld
+enable_libtool_lock
+enable_spec
+enable_valgrind_testing
+enable_asm
+with_ogg
+with_ogg_libraries
+with_ogg_includes
+enable_oggtest
+with_vorbis
+with_vorbis_libraries
+with_vorbis_includes
+enable_vorbistest
+with_sdl_prefix
+with_sdl_exec_prefix
+enable_sdltest
+enable_telemetry
+enable_float
+enable_encode
+enable_examples
+'
+      ac_precious_vars='build_alias
+host_alias
+target_alias
+CC
+CFLAGS
+LDFLAGS
+LIBS
+CPPFLAGS
+CPP
+PKG_CONFIG
+OGG_CFLAGS
+OGG_LIBS
+VORBIS_CFLAGS
+VORBIS_LIBS
+PNG_CFLAGS
+PNG_LIBS
+CAIRO_CFLAGS
+CAIRO_LIBS'
+
+
+# Initialize some variables set by options.
+ac_init_help=
+ac_init_version=false
+ac_unrecognized_opts=
+ac_unrecognized_sep=
+# The variables have the same names as the options, with
+# dashes changed to underlines.
+cache_file=/dev/null
+exec_prefix=NONE
+no_create=
+no_recursion=
+prefix=NONE
+program_prefix=NONE
+program_suffix=NONE
+program_transform_name=s,x,x,
+silent=
+site=
+srcdir=
+verbose=
+x_includes=NONE
+x_libraries=NONE
+
+# Installation directory options.
+# These are left unexpanded so users can "make install exec_prefix=/foo"
+# and all the variables that are supposed to be based on exec_prefix
+# by default will actually change.
+# Use braces instead of parens because sh, perl, etc. also accept them.
+# (The list follows the same order as the GNU Coding Standards.)
+bindir='${exec_prefix}/bin'
+sbindir='${exec_prefix}/sbin'
+libexecdir='${exec_prefix}/libexec'
+datarootdir='${prefix}/share'
+datadir='${datarootdir}'
+sysconfdir='${prefix}/etc'
+sharedstatedir='${prefix}/com'
+localstatedir='${prefix}/var'
+includedir='${prefix}/include'
+oldincludedir='/usr/include'
+docdir='${datarootdir}/doc/${PACKAGE_TARNAME}'
+infodir='${datarootdir}/info'
+htmldir='${docdir}'
+dvidir='${docdir}'
+pdfdir='${docdir}'
+psdir='${docdir}'
+libdir='${exec_prefix}/lib'
+localedir='${datarootdir}/locale'
+mandir='${datarootdir}/man'
+
+ac_prev=
+ac_dashdash=
+for ac_option
+do
+  # If the previous option needs an argument, assign it.
+  if test -n "$ac_prev"; then
+    eval $ac_prev=\$ac_option
+    ac_prev=
+    continue
+  fi
+
+  case $ac_option in
+  *=*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;;
+  *)   ac_optarg=yes ;;
+  esac
+
+  # Accept the important Cygnus configure options, so we can diagnose typos.
+
+  case $ac_dashdash$ac_option in
+  --)
+    ac_dashdash=yes ;;
+
+  -bindir | --bindir | --bindi | --bind | --bin | --bi)
+    ac_prev=bindir ;;
+  -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*)
+    bindir=$ac_optarg ;;
+
+  -build | --build | --buil | --bui | --bu)
+    ac_prev=build_alias ;;
+  -build=* | --build=* | --buil=* | --bui=* | --bu=*)
+    build_alias=$ac_optarg ;;
+
+  -cache-file | --cache-file | --cache-fil | --cache-fi \
+  | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c)
+    ac_prev=cache_file ;;
+  -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \
+  | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*)
+    cache_file=$ac_optarg ;;
+
+  --config-cache | -C)
+    cache_file=config.cache ;;
+
+  -datadir | --datadir | --datadi | --datad)
+    ac_prev=datadir ;;
+  -datadir=* | --datadir=* | --datadi=* | --datad=*)
+    datadir=$ac_optarg ;;
+
+  -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \
+  | --dataroo | --dataro | --datar)
+    ac_prev=datarootdir ;;
+  -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \
+  | --dataroot=* | --dataroo=* | --dataro=* | --datar=*)
+    datarootdir=$ac_optarg ;;
+
+  -disable-* | --disable-*)
+    ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'`
+    # Reject names that are not valid shell variable names.
+    expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null &&
+      { $as_echo "$as_me: error: invalid feature name: $ac_useropt" >&2
+   { (exit 1); exit 1; }; }
+    ac_useropt_orig=$ac_useropt
+    ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'`
+    case $ac_user_opts in
+      *"
+"enable_$ac_useropt"
+"*) ;;
+      *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig"
+        ac_unrecognized_sep=', ';;
+    esac
+    eval enable_$ac_useropt=no ;;
+
+  -docdir | --docdir | --docdi | --doc | --do)
+    ac_prev=docdir ;;
+  -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*)
+    docdir=$ac_optarg ;;
+
+  -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv)
+    ac_prev=dvidir ;;
+  -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*)
+    dvidir=$ac_optarg ;;
+
+  -enable-* | --enable-*)
+    ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'`
+    # Reject names that are not valid shell variable names.
+    expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null &&
+      { $as_echo "$as_me: error: invalid feature name: $ac_useropt" >&2
+   { (exit 1); exit 1; }; }
+    ac_useropt_orig=$ac_useropt
+    ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'`
+    case $ac_user_opts in
+      *"
+"enable_$ac_useropt"
+"*) ;;
+      *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig"
+        ac_unrecognized_sep=', ';;
+    esac
+    eval enable_$ac_useropt=\$ac_optarg ;;
+
+  -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \
+  | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \
+  | --exec | --exe | --ex)
+    ac_prev=exec_prefix ;;
+  -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \
+  | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \
+  | --exec=* | --exe=* | --ex=*)
+    exec_prefix=$ac_optarg ;;
+
+  -gas | --gas | --ga | --g)
+    # Obsolete; use --with-gas.
+    with_gas=yes ;;
+
+  -help | --help | --hel | --he | -h)
+    ac_init_help=long ;;
+  -help=r* | --help=r* | --hel=r* | --he=r* | -hr*)
+    ac_init_help=recursive ;;
+  -help=s* | --help=s* | --hel=s* | --he=s* | -hs*)
+    ac_init_help=short ;;
+
+  -host | --host | --hos | --ho)
+    ac_prev=host_alias ;;
+  -host=* | --host=* | --hos=* | --ho=*)
+    host_alias=$ac_optarg ;;
+
+  -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht)
+    ac_prev=htmldir ;;
+  -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \
+  | --ht=*)
+    htmldir=$ac_optarg ;;
+
+  -includedir | --includedir | --includedi | --included | --include \
+  | --includ | --inclu | --incl | --inc)
+    ac_prev=includedir ;;
+  -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \
+  | --includ=* | --inclu=* | --incl=* | --inc=*)
+    includedir=$ac_optarg ;;
+
+  -infodir | --infodir | --infodi | --infod | --info | --inf)
+    ac_prev=infodir ;;
+  -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*)
+    infodir=$ac_optarg ;;
+
+  -libdir | --libdir | --libdi | --libd)
+    ac_prev=libdir ;;
+  -libdir=* | --libdir=* | --libdi=* | --libd=*)
+    libdir=$ac_optarg ;;
+
+  -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \
+  | --libexe | --libex | --libe)
+    ac_prev=libexecdir ;;
+  -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \
+  | --libexe=* | --libex=* | --libe=*)
+    libexecdir=$ac_optarg ;;
+
+  -localedir | --localedir | --localedi | --localed | --locale)
+    ac_prev=localedir ;;
+  -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*)
+    localedir=$ac_optarg ;;
+
+  -localstatedir | --localstatedir | --localstatedi | --localstated \
+  | --localstate | --localstat | --localsta | --localst | --locals)
+    ac_prev=localstatedir ;;
+  -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \
+  | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*)
+    localstatedir=$ac_optarg ;;
+
+  -mandir | --mandir | --mandi | --mand | --man | --ma | --m)
+    ac_prev=mandir ;;
+  -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*)
+    mandir=$ac_optarg ;;
+
+  -nfp | --nfp | --nf)
+    # Obsolete; use --without-fp.
+    with_fp=no ;;
+
+  -no-create | --no-create | --no-creat | --no-crea | --no-cre \
+  | --no-cr | --no-c | -n)
+    no_create=yes ;;
+
+  -no-recursion | --no-recursion | --no-recursio | --no-recursi \
+  | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r)
+    no_recursion=yes ;;
+
+  -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \
+  | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \
+  | --oldin | --oldi | --old | --ol | --o)
+    ac_prev=oldincludedir ;;
+  -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \
+  | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \
+  | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*)
+    oldincludedir=$ac_optarg ;;
+
+  -prefix | --prefix | --prefi | --pref | --pre | --pr | --p)
+    ac_prev=prefix ;;
+  -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*)
+    prefix=$ac_optarg ;;
+
+  -program-prefix | --program-prefix | --program-prefi | --program-pref \
+  | --program-pre | --program-pr | --program-p)
+    ac_prev=program_prefix ;;
+  -program-prefix=* | --program-prefix=* | --program-prefi=* \
+  | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*)
+    program_prefix=$ac_optarg ;;
+
+  -program-suffix | --program-suffix | --program-suffi | --program-suff \
+  | --program-suf | --program-su | --program-s)
+    ac_prev=program_suffix ;;
+  -program-suffix=* | --program-suffix=* | --program-suffi=* \
+  | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*)
+    program_suffix=$ac_optarg ;;
+
+  -program-transform-name | --program-transform-name \
+  | --program-transform-nam | --program-transform-na \
+  | --program-transform-n | --program-transform- \
+  | --program-transform | --program-transfor \
+  | --program-transfo | --program-transf \
+  | --program-trans | --program-tran \
+  | --progr-tra | --program-tr | --program-t)
+    ac_prev=program_transform_name ;;
+  -program-transform-name=* | --program-transform-name=* \
+  | --program-transform-nam=* | --program-transform-na=* \
+  | --program-transform-n=* | --program-transform-=* \
+  | --program-transform=* | --program-transfor=* \
+  | --program-transfo=* | --program-transf=* \
+  | --program-trans=* | --program-tran=* \
+  | --progr-tra=* | --program-tr=* | --program-t=*)
+    program_transform_name=$ac_optarg ;;
+
+  -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd)
+    ac_prev=pdfdir ;;
+  -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*)
+    pdfdir=$ac_optarg ;;
+
+  -psdir | --psdir | --psdi | --psd | --ps)
+    ac_prev=psdir ;;
+  -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*)
+    psdir=$ac_optarg ;;
+
+  -q | -quiet | --quiet | --quie | --qui | --qu | --q \
+  | -silent | --silent | --silen | --sile | --sil)
+    silent=yes ;;
+
+  -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
+    ac_prev=sbindir ;;
+  -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
+  | --sbi=* | --sb=*)
+    sbindir=$ac_optarg ;;
+
+  -sharedstatedir | --sharedstatedir | --sharedstatedi \
+  | --sharedstated | --sharedstate | --sharedstat | --sharedsta \
+  | --sharedst | --shareds | --shared | --share | --shar \
+  | --sha | --sh)
+    ac_prev=sharedstatedir ;;
+  -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \
+  | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \
+  | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \
+  | --sha=* | --sh=*)
+    sharedstatedir=$ac_optarg ;;
+
+  -site | --site | --sit)
+    ac_prev=site ;;
+  -site=* | --site=* | --sit=*)
+    site=$ac_optarg ;;
+
+  -srcdir | --srcdir | --srcdi | --srcd | --src | --sr)
+    ac_prev=srcdir ;;
+  -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*)
+    srcdir=$ac_optarg ;;
+
+  -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \
+  | --syscon | --sysco | --sysc | --sys | --sy)
+    ac_prev=sysconfdir ;;
+  -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \
+  | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*)
+    sysconfdir=$ac_optarg ;;
+
+  -target | --target | --targe | --targ | --tar | --ta | --t)
+    ac_prev=target_alias ;;
+  -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*)
+    target_alias=$ac_optarg ;;
+
+  -v | -verbose | --verbose | --verbos | --verbo | --verb)
+    verbose=yes ;;
+
+  -version | --version | --versio | --versi | --vers | -V)
+    ac_init_version=: ;;
+
+  -with-* | --with-*)
+    ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'`
+    # Reject names that are not valid shell variable names.
+    expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null &&
+      { $as_echo "$as_me: error: invalid package name: $ac_useropt" >&2
+   { (exit 1); exit 1; }; }
+    ac_useropt_orig=$ac_useropt
+    ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'`
+    case $ac_user_opts in
+      *"
+"with_$ac_useropt"
+"*) ;;
+      *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig"
+        ac_unrecognized_sep=', ';;
+    esac
+    eval with_$ac_useropt=\$ac_optarg ;;
+
+  -without-* | --without-*)
+    ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'`
+    # Reject names that are not valid shell variable names.
+    expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null &&
+      { $as_echo "$as_me: error: invalid package name: $ac_useropt" >&2
+   { (exit 1); exit 1; }; }
+    ac_useropt_orig=$ac_useropt
+    ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'`
+    case $ac_user_opts in
+      *"
+"with_$ac_useropt"
+"*) ;;
+      *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig"
+        ac_unrecognized_sep=', ';;
+    esac
+    eval with_$ac_useropt=no ;;
+
+  --x)
+    # Obsolete; use --with-x.
+    with_x=yes ;;
+
+  -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \
+  | --x-incl | --x-inc | --x-in | --x-i)
+    ac_prev=x_includes ;;
+  -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \
+  | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*)
+    x_includes=$ac_optarg ;;
+
+  -x-libraries | --x-libraries | --x-librarie | --x-librari \
+  | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l)
+    ac_prev=x_libraries ;;
+  -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \
+  | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*)
+    x_libraries=$ac_optarg ;;
+
+  -*) { $as_echo "$as_me: error: unrecognized option: $ac_option
+Try \`$0 --help' for more information." >&2
+   { (exit 1); exit 1; }; }
+    ;;
+
+  *=*)
+    ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='`
+    # Reject names that are not valid shell variable names.
+    expr "x$ac_envvar" : ".*[^_$as_cr_alnum]" >/dev/null &&
+      { $as_echo "$as_me: error: invalid variable name: $ac_envvar" >&2
+   { (exit 1); exit 1; }; }
+    eval $ac_envvar=\$ac_optarg
+    export $ac_envvar ;;
+
+  *)
+    # FIXME: should be removed in autoconf 3.0.
+    $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2
+    expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null &&
+      $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2
+    : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}
+    ;;
+
+  esac
+done
+
+if test -n "$ac_prev"; then
+  ac_option=--`echo $ac_prev | sed 's/_/-/g'`
+  { $as_echo "$as_me: error: missing argument to $ac_option" >&2
+   { (exit 1); exit 1; }; }
+fi
+
+if test -n "$ac_unrecognized_opts"; then
+  case $enable_option_checking in
+    no) ;;
+    fatal) { $as_echo "$as_me: error: unrecognized options: $ac_unrecognized_opts" >&2
+   { (exit 1); exit 1; }; } ;;
+    *)     $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;;
+  esac
+fi
+
+# Check all directory arguments for consistency.
+for ac_var in  exec_prefix prefix bindir sbindir libexecdir datarootdir \
+               datadir sysconfdir sharedstatedir localstatedir includedir \
+               oldincludedir docdir infodir htmldir dvidir pdfdir psdir \
+               libdir localedir mandir
+do
+  eval ac_val=\$$ac_var
+  # Remove trailing slashes.
+  case $ac_val in
+    */ )
+      ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'`
+      eval $ac_var=\$ac_val;;
+  esac
+  # Be sure to have absolute directory names.
+  case $ac_val in
+    [\\/$]* | ?:[\\/]* )  continue;;
+    NONE | '' ) case $ac_var in *prefix ) continue;; esac;;
+  esac
+  { $as_echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2
+   { (exit 1); exit 1; }; }
+done
+
+# There might be people who depend on the old broken behavior: `$host'
+# used to hold the argument of --host etc.
+# FIXME: To remove some day.
+build=$build_alias
+host=$host_alias
+target=$target_alias
+
+# FIXME: To remove some day.
+if test "x$host_alias" != x; then
+  if test "x$build_alias" = x; then
+    cross_compiling=maybe
+    $as_echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host.
+    If a cross compiler is detected then cross compile mode will be used." >&2
+  elif test "x$build_alias" != "x$host_alias"; then
+    cross_compiling=yes
+  fi
+fi
+
+ac_tool_prefix=
+test -n "$host_alias" && ac_tool_prefix=$host_alias-
+
+test "$silent" = yes && exec 6>/dev/null
+
+
+ac_pwd=`pwd` && test -n "$ac_pwd" &&
+ac_ls_di=`ls -di .` &&
+ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` ||
+  { $as_echo "$as_me: error: working directory cannot be determined" >&2
+   { (exit 1); exit 1; }; }
+test "X$ac_ls_di" = "X$ac_pwd_ls_di" ||
+  { $as_echo "$as_me: error: pwd does not report name of working directory" >&2
+   { (exit 1); exit 1; }; }
+
+
+# Find the source files, if location was not specified.
+if test -z "$srcdir"; then
+  ac_srcdir_defaulted=yes
+  # Try the directory containing this script, then the parent directory.
+  ac_confdir=`$as_dirname -- "$as_myself" ||
+$as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+        X"$as_myself" : 'X\(//\)[^/]' \| \
+        X"$as_myself" : 'X\(//\)$' \| \
+        X"$as_myself" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X"$as_myself" |
+    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)[^/].*/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+  srcdir=$ac_confdir
+  if test ! -r "$srcdir/$ac_unique_file"; then
+    srcdir=..
+  fi
+else
+  ac_srcdir_defaulted=no
+fi
+if test ! -r "$srcdir/$ac_unique_file"; then
+  test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .."
+  { $as_echo "$as_me: error: cannot find sources ($ac_unique_file) in $srcdir" >&2
+   { (exit 1); exit 1; }; }
+fi
+ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work"
+ac_abs_confdir=`(
+       cd "$srcdir" && test -r "./$ac_unique_file" || { $as_echo "$as_me: error: $ac_msg" >&2
+   { (exit 1); exit 1; }; }
+       pwd)`
+# When building in place, set srcdir=.
+if test "$ac_abs_confdir" = "$ac_pwd"; then
+  srcdir=.
+fi
+# Remove unnecessary trailing slashes from srcdir.
+# Double slashes in file names in object file debugging info
+# mess up M-x gdb in Emacs.
+case $srcdir in
+*/) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;;
+esac
+for ac_var in $ac_precious_vars; do
+  eval ac_env_${ac_var}_set=\${${ac_var}+set}
+  eval ac_env_${ac_var}_value=\$${ac_var}
+  eval ac_cv_env_${ac_var}_set=\${${ac_var}+set}
+  eval ac_cv_env_${ac_var}_value=\$${ac_var}
+done
+
+#
+# Report the --help message.
+#
+if test "$ac_init_help" = "long"; then
+  # Omit some internal or obsolete options to make the list less imposing.
+  # This message is too long to be a string in the A/UX 3.1 sh.
+  cat <<_ACEOF
+\`configure' configures libtheora 1.1.1 to adapt to many kinds of systems.
+
+Usage: $0 [OPTION]... [VAR=VALUE]...
+
+To assign environment variables (e.g., CC, CFLAGS...), specify them as
+VAR=VALUE.  See below for descriptions of some of the useful variables.
+
+Defaults for the options are specified in brackets.
+
+Configuration:
+  -h, --help              display this help and exit
+      --help=short        display options specific to this package
+      --help=recursive    display the short help of all the included packages
+  -V, --version           display version information and exit
+  -q, --quiet, --silent   do not print \`checking...' messages
+      --cache-file=FILE   cache test results in FILE [disabled]
+  -C, --config-cache      alias for \`--cache-file=config.cache'
+  -n, --no-create         do not create output files
+      --srcdir=DIR        find the sources in DIR [configure dir or \`..']
+
+Installation directories:
+  --prefix=PREFIX         install architecture-independent files in PREFIX
+                          [$ac_default_prefix]
+  --exec-prefix=EPREFIX   install architecture-dependent files in EPREFIX
+                          [PREFIX]
+
+By default, \`make install' will install all the files in
+\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc.  You can specify
+an installation prefix other than \`$ac_default_prefix' using \`--prefix',
+for instance \`--prefix=\$HOME'.
+
+For better control, use the options below.
+
+Fine tuning of the installation directories:
+  --bindir=DIR            user executables [EPREFIX/bin]
+  --sbindir=DIR           system admin executables [EPREFIX/sbin]
+  --libexecdir=DIR        program executables [EPREFIX/libexec]
+  --sysconfdir=DIR        read-only single-machine data [PREFIX/etc]
+  --sharedstatedir=DIR    modifiable architecture-independent data [PREFIX/com]
+  --localstatedir=DIR     modifiable single-machine data [PREFIX/var]
+  --libdir=DIR            object code libraries [EPREFIX/lib]
+  --includedir=DIR        C header files [PREFIX/include]
+  --oldincludedir=DIR     C header files for non-gcc [/usr/include]
+  --datarootdir=DIR       read-only arch.-independent data root [PREFIX/share]
+  --datadir=DIR           read-only architecture-independent data [DATAROOTDIR]
+  --infodir=DIR           info documentation [DATAROOTDIR/info]
+  --localedir=DIR         locale-dependent data [DATAROOTDIR/locale]
+  --mandir=DIR            man documentation [DATAROOTDIR/man]
+  --docdir=DIR            documentation root [DATAROOTDIR/doc/libtheora]
+  --htmldir=DIR           html documentation [DOCDIR]
+  --dvidir=DIR            dvi documentation [DOCDIR]
+  --pdfdir=DIR            pdf documentation [DOCDIR]
+  --psdir=DIR             ps documentation [DOCDIR]
+_ACEOF
+
+  cat <<\_ACEOF
+
+Program names:
+  --program-prefix=PREFIX            prepend PREFIX to installed program names
+  --program-suffix=SUFFIX            append SUFFIX to installed program names
+  --program-transform-name=PROGRAM   run sed PROGRAM on installed program names
+
+System types:
+  --build=BUILD     configure for building on BUILD [guessed]
+  --host=HOST       cross-compile to build programs to run on HOST [BUILD]
+  --target=TARGET   configure for building compilers for TARGET [HOST]
+_ACEOF
+fi
+
+if test -n "$ac_init_help"; then
+  case $ac_init_help in
+     short | recursive ) echo "Configuration of libtheora 1.1.1:";;
+   esac
+  cat <<\_ACEOF
+
+Optional Features:
+  --disable-option-checking  ignore unrecognized --enable/--with options
+  --disable-FEATURE       do not include FEATURE (same as --enable-FEATURE=no)
+  --enable-FEATURE[=ARG]  include FEATURE [ARG=yes]
+  --enable-maintainer-mode enable make rules and dependencies not useful
+                          (and sometimes confusing) to the casual installer
+  --disable-dependency-tracking Speeds up one-time builds
+  --enable-dependency-tracking  Do not reject slow dependency extractors
+  --enable-shared[=PKGS]  build shared libraries [default=yes]
+  --enable-static[=PKGS]  build static libraries [default=yes]
+  --enable-fast-install[=PKGS]
+                          optimize for fast installation [default=yes]
+  --disable-libtool-lock  avoid locking (might break parallel builds)
+  --disable-spec          do not build spec
+  --enable-valgrind-testing     enable running of tests inside Valgrind
+  --disable-asm           disable assembly optimizations
+  --disable-oggtest       Do not try to compile and run a test Ogg program
+  --disable-vorbistest    Do not try to compile and run a test Vorbis program
+  --disable-sdltest       Do not try to compile and run a test SDL program
+  --enable-telemetry      enable debugging output controls
+  --disable-float         disable use of floating point code
+  --disable-encode        disable encoding support
+  --disable-examples      disable examples
+
+Optional Packages:
+  --with-PACKAGE[=ARG]    use PACKAGE [ARG=yes]
+  --without-PACKAGE       do not use PACKAGE (same as --with-PACKAGE=no)
+  --with-pic              try to use only PIC/non-PIC objects [default=use
+                          both]
+  --with-gnu-ld           assume the C compiler uses GNU ld [default=no]
+  --with-ogg=PFX          Prefix where libogg is installed (optional)
+  --with-ogg-libraries=DIR
+                          Directory where libogg library is installed
+                          (optional)
+  --with-ogg-includes=DIR Directory where libogg header files are installed
+                          (optional)
+  --with-vorbis=PFX   Prefix where libvorbis is installed (optional)
+  --with-vorbis-libraries=DIR   Directory where libvorbis library is installed (optional)
+  --with-vorbis-includes=DIR   Directory where libvorbis header files are installed (optional)
+  --with-sdl-prefix=PFX   Prefix where SDL is installed (optional)
+  --with-sdl-exec-prefix=PFX Exec prefix where SDL is installed (optional)
+
+Some influential environment variables:
+  CC          C compiler command
+  CFLAGS      C compiler flags
+  LDFLAGS     linker flags, e.g. -L<lib dir> if you have libraries in a
+              nonstandard directory <lib dir>
+  LIBS        libraries to pass to the linker, e.g. -l<library>
+  CPPFLAGS    C/C++/Objective C preprocessor flags, e.g. -I<include dir> if
+              you have headers in a nonstandard directory <include dir>
+  CPP         C preprocessor
+  PKG_CONFIG  path to pkg-config utility
+  OGG_CFLAGS  C compiler flags for OGG, overriding pkg-config
+  OGG_LIBS    linker flags for OGG, overriding pkg-config
+  VORBIS_CFLAGS
+              C compiler flags for VORBIS, overriding pkg-config
+  VORBIS_LIBS linker flags for VORBIS, overriding pkg-config
+  PNG_CFLAGS  C compiler flags for PNG, overriding pkg-config
+  PNG_LIBS    linker flags for PNG, overriding pkg-config
+  CAIRO_CFLAGS
+              C compiler flags for CAIRO, overriding pkg-config
+  CAIRO_LIBS  linker flags for CAIRO, overriding pkg-config
+
+Use these variables to override the choices made by `configure' or to help
+it to find libraries and programs with nonstandard names/locations.
+
+_ACEOF
+ac_status=$?
+fi
+
+if test "$ac_init_help" = "recursive"; then
+  # If there are subdirs, report their specific --help.
+  for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue
+    test -d "$ac_dir" ||
+      { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } ||
+      continue
+    ac_builddir=.
+
+case "$ac_dir" in
+.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;;
+*)
+  ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'`
+  # A ".." for each directory in $ac_dir_suffix.
+  ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'`
+  case $ac_top_builddir_sub in
+  "") ac_top_builddir_sub=. ac_top_build_prefix= ;;
+  *)  ac_top_build_prefix=$ac_top_builddir_sub/ ;;
+  esac ;;
+esac
+ac_abs_top_builddir=$ac_pwd
+ac_abs_builddir=$ac_pwd$ac_dir_suffix
+# for backward compatibility:
+ac_top_builddir=$ac_top_build_prefix
+
+case $srcdir in
+  .)  # We are building in place.
+    ac_srcdir=.
+    ac_top_srcdir=$ac_top_builddir_sub
+    ac_abs_top_srcdir=$ac_pwd ;;
+  [\\/]* | ?:[\\/]* )  # Absolute name.
+    ac_srcdir=$srcdir$ac_dir_suffix;
+    ac_top_srcdir=$srcdir
+    ac_abs_top_srcdir=$srcdir ;;
+  *) # Relative name.
+    ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix
+    ac_top_srcdir=$ac_top_build_prefix$srcdir
+    ac_abs_top_srcdir=$ac_pwd/$srcdir ;;
+esac
+ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix
+
+    cd "$ac_dir" || { ac_status=$?; continue; }
+    # Check for guested configure.
+    if test -f "$ac_srcdir/configure.gnu"; then
+      echo &&
+      $SHELL "$ac_srcdir/configure.gnu" --help=recursive
+    elif test -f "$ac_srcdir/configure"; then
+      echo &&
+      $SHELL "$ac_srcdir/configure" --help=recursive
+    else
+      $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2
+    fi || ac_status=$?
+    cd "$ac_pwd" || { ac_status=$?; break; }
+  done
+fi
+
+test -n "$ac_init_help" && exit $ac_status
+if $ac_init_version; then
+  cat <<\_ACEOF
+libtheora configure 1.1.1
+generated by GNU Autoconf 2.63
+
+Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001,
+2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
+This configure script is free software; the Free Software Foundation
+gives unlimited permission to copy, distribute and modify it.
+_ACEOF
+  exit
+fi
+cat >config.log <<_ACEOF
+This file contains any messages produced by compilers while
+running configure, to aid debugging if configure makes a mistake.
+
+It was created by libtheora $as_me 1.1.1, which was
+generated by GNU Autoconf 2.63.  Invocation command line was
+
+  $ $0 $@
+
+_ACEOF
+exec 5>>config.log
+{
+cat <<_ASUNAME
+## --------- ##
+## Platform. ##
+## --------- ##
+
+hostname = `(hostname || uname -n) 2>/dev/null | sed 1q`
+uname -m = `(uname -m) 2>/dev/null || echo unknown`
+uname -r = `(uname -r) 2>/dev/null || echo unknown`
+uname -s = `(uname -s) 2>/dev/null || echo unknown`
+uname -v = `(uname -v) 2>/dev/null || echo unknown`
+
+/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown`
+/bin/uname -X     = `(/bin/uname -X) 2>/dev/null     || echo unknown`
+
+/bin/arch              = `(/bin/arch) 2>/dev/null              || echo unknown`
+/usr/bin/arch -k       = `(/usr/bin/arch -k) 2>/dev/null       || echo unknown`
+/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown`
+/usr/bin/hostinfo      = `(/usr/bin/hostinfo) 2>/dev/null      || echo unknown`
+/bin/machine           = `(/bin/machine) 2>/dev/null           || echo unknown`
+/usr/bin/oslevel       = `(/usr/bin/oslevel) 2>/dev/null       || echo unknown`
+/bin/universe          = `(/bin/universe) 2>/dev/null          || echo unknown`
+
+_ASUNAME
+
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  $as_echo "PATH: $as_dir"
+done
+IFS=$as_save_IFS
+
+} >&5
+
+cat >&5 <<_ACEOF
+
+
+## ----------- ##
+## Core tests. ##
+## ----------- ##
+
+_ACEOF
+
+
+# Keep a trace of the command line.
+# Strip out --no-create and --no-recursion so they do not pile up.
+# Strip out --silent because we don't want to record it for future runs.
+# Also quote any args containing shell meta-characters.
+# Make two passes to allow for proper duplicate-argument suppression.
+ac_configure_args=
+ac_configure_args0=
+ac_configure_args1=
+ac_must_keep_next=false
+for ac_pass in 1 2
+do
+  for ac_arg
+  do
+    case $ac_arg in
+    -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;;
+    -q | -quiet | --quiet | --quie | --qui | --qu | --q \
+    | -silent | --silent | --silen | --sile | --sil)
+      continue ;;
+    *\'*)
+      ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;;
+    esac
+    case $ac_pass in
+    1) ac_configure_args0="$ac_configure_args0 '$ac_arg'" ;;
+    2)
+      ac_configure_args1="$ac_configure_args1 '$ac_arg'"
+      if test $ac_must_keep_next = true; then
+       ac_must_keep_next=false # Got value, back to normal.
+      else
+       case $ac_arg in
+         *=* | --config-cache | -C | -disable-* | --disable-* \
+         | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \
+         | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \
+         | -with-* | --with-* | -without-* | --without-* | --x)
+           case "$ac_configure_args0 " in
+             "$ac_configure_args1"*" '$ac_arg' "* ) continue ;;
+           esac
+           ;;
+         -* ) ac_must_keep_next=true ;;
+       esac
+      fi
+      ac_configure_args="$ac_configure_args '$ac_arg'"
+      ;;
+    esac
+  done
+done
+$as_unset ac_configure_args0 || test "${ac_configure_args0+set}" != set || { ac_configure_args0=; export ac_configure_args0; }
+$as_unset ac_configure_args1 || test "${ac_configure_args1+set}" != set || { ac_configure_args1=; export ac_configure_args1; }
+
+# When interrupted or exit'd, cleanup temporary files, and complete
+# config.log.  We remove comments because anyway the quotes in there
+# would cause problems or look ugly.
+# WARNING: Use '\'' to represent an apostrophe within the trap.
+# WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug.
+trap 'exit_status=$?
+  # Save into config.log some information that might help in debugging.
+  {
+    echo
+
+    cat <<\_ASBOX
+## ---------------- ##
+## Cache variables. ##
+## ---------------- ##
+_ASBOX
+    echo
+    # The following way of writing the cache mishandles newlines in values,
+(
+  for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do
+    eval ac_val=\$$ac_var
+    case $ac_val in #(
+    *${as_nl}*)
+      case $ac_var in #(
+      *_cv_*) { $as_echo "$as_me:$LINENO: WARNING: cache variable $ac_var contains a newline" >&5
+$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;;
+      esac
+      case $ac_var in #(
+      _ | IFS | as_nl) ;; #(
+      BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #(
+      *) $as_unset $ac_var ;;
+      esac ;;
+    esac
+  done
+  (set) 2>&1 |
+    case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #(
+    *${as_nl}ac_space=\ *)
+      sed -n \
+       "s/'\''/'\''\\\\'\'''\''/g;
+         s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p"
+      ;; #(
+    *)
+      sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p"
+      ;;
+    esac |
+    sort
+)
+    echo
+
+    cat <<\_ASBOX
+## ----------------- ##
+## Output variables. ##
+## ----------------- ##
+_ASBOX
+    echo
+    for ac_var in $ac_subst_vars
+    do
+      eval ac_val=\$$ac_var
+      case $ac_val in
+      *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;;
+      esac
+      $as_echo "$ac_var='\''$ac_val'\''"
+    done | sort
+    echo
+
+    if test -n "$ac_subst_files"; then
+      cat <<\_ASBOX
+## ------------------- ##
+## File substitutions. ##
+## ------------------- ##
+_ASBOX
+      echo
+      for ac_var in $ac_subst_files
+      do
+       eval ac_val=\$$ac_var
+       case $ac_val in
+       *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;;
+       esac
+       $as_echo "$ac_var='\''$ac_val'\''"
+      done | sort
+      echo
+    fi
+
+    if test -s confdefs.h; then
+      cat <<\_ASBOX
+## ----------- ##
+## confdefs.h. ##
+## ----------- ##
+_ASBOX
+      echo
+      cat confdefs.h
+      echo
+    fi
+    test "$ac_signal" != 0 &&
+      $as_echo "$as_me: caught signal $ac_signal"
+    $as_echo "$as_me: exit $exit_status"
+  } >&5
+  rm -f core *.core core.conftest.* &&
+    rm -f -r conftest* confdefs* conf$$* $ac_clean_files &&
+    exit $exit_status
+' 0
+for ac_signal in 1 2 13 15; do
+  trap 'ac_signal='$ac_signal'; { (exit 1); exit 1; }' $ac_signal
+done
+ac_signal=0
+
+# confdefs.h avoids OS command line length limits that DEFS can exceed.
+rm -f -r conftest* confdefs.h
+
+# Predefined preprocessor variables.
+
+cat >>confdefs.h <<_ACEOF
+#define PACKAGE_NAME "$PACKAGE_NAME"
+_ACEOF
+
+
+cat >>confdefs.h <<_ACEOF
+#define PACKAGE_TARNAME "$PACKAGE_TARNAME"
+_ACEOF
+
+
+cat >>confdefs.h <<_ACEOF
+#define PACKAGE_VERSION "$PACKAGE_VERSION"
+_ACEOF
+
+
+cat >>confdefs.h <<_ACEOF
+#define PACKAGE_STRING "$PACKAGE_STRING"
+_ACEOF
+
+
+cat >>confdefs.h <<_ACEOF
+#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT"
+_ACEOF
+
+
+# Let the site file select an alternate cache file if it wants to.
+# Prefer an explicitly selected file to automatically selected ones.
+ac_site_file1=NONE
+ac_site_file2=NONE
+if test -n "$CONFIG_SITE"; then
+  ac_site_file1=$CONFIG_SITE
+elif test "x$prefix" != xNONE; then
+  ac_site_file1=$prefix/share/config.site
+  ac_site_file2=$prefix/etc/config.site
+else
+  ac_site_file1=$ac_default_prefix/share/config.site
+  ac_site_file2=$ac_default_prefix/etc/config.site
+fi
+for ac_site_file in "$ac_site_file1" "$ac_site_file2"
+do
+  test "x$ac_site_file" = xNONE && continue
+  if test -r "$ac_site_file"; then
+    { $as_echo "$as_me:$LINENO: loading site script $ac_site_file" >&5
+$as_echo "$as_me: loading site script $ac_site_file" >&6;}
+    sed 's/^/| /' "$ac_site_file" >&5
+    . "$ac_site_file"
+  fi
+done
+
+if test -r "$cache_file"; then
+  # Some versions of bash will fail to source /dev/null (special
+  # files actually), so we avoid doing that.
+  if test -f "$cache_file"; then
+    { $as_echo "$as_me:$LINENO: loading cache $cache_file" >&5
+$as_echo "$as_me: loading cache $cache_file" >&6;}
+    case $cache_file in
+      [\\/]* | ?:[\\/]* ) . "$cache_file";;
+      *)                      . "./$cache_file";;
+    esac
+  fi
+else
+  { $as_echo "$as_me:$LINENO: creating cache $cache_file" >&5
+$as_echo "$as_me: creating cache $cache_file" >&6;}
+  >$cache_file
+fi
+
+# Check that the precious variables saved in the cache have kept the same
+# value.
+ac_cache_corrupted=false
+for ac_var in $ac_precious_vars; do
+  eval ac_old_set=\$ac_cv_env_${ac_var}_set
+  eval ac_new_set=\$ac_env_${ac_var}_set
+  eval ac_old_val=\$ac_cv_env_${ac_var}_value
+  eval ac_new_val=\$ac_env_${ac_var}_value
+  case $ac_old_set,$ac_new_set in
+    set,)
+      { $as_echo "$as_me:$LINENO: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5
+$as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;}
+      ac_cache_corrupted=: ;;
+    ,set)
+      { $as_echo "$as_me:$LINENO: error: \`$ac_var' was not set in the previous run" >&5
+$as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;}
+      ac_cache_corrupted=: ;;
+    ,);;
+    *)
+      if test "x$ac_old_val" != "x$ac_new_val"; then
+       # differences in whitespace do not lead to failure.
+       ac_old_val_w=`echo x $ac_old_val`
+       ac_new_val_w=`echo x $ac_new_val`
+       if test "$ac_old_val_w" != "$ac_new_val_w"; then
+         { $as_echo "$as_me:$LINENO: error: \`$ac_var' has changed since the previous run:" >&5
+$as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;}
+         ac_cache_corrupted=:
+       else
+         { $as_echo "$as_me:$LINENO: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5
+$as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;}
+         eval $ac_var=\$ac_old_val
+       fi
+       { $as_echo "$as_me:$LINENO:   former value:  \`$ac_old_val'" >&5
+$as_echo "$as_me:   former value:  \`$ac_old_val'" >&2;}
+       { $as_echo "$as_me:$LINENO:   current value: \`$ac_new_val'" >&5
+$as_echo "$as_me:   current value: \`$ac_new_val'" >&2;}
+      fi;;
+  esac
+  # Pass precious variables to config.status.
+  if test "$ac_new_set" = set; then
+    case $ac_new_val in
+    *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;;
+    *) ac_arg=$ac_var=$ac_new_val ;;
+    esac
+    case " $ac_configure_args " in
+      *" '$ac_arg' "*) ;; # Avoid dups.  Use of quotes ensures accuracy.
+      *) ac_configure_args="$ac_configure_args '$ac_arg'" ;;
+    esac
+  fi
+done
+if $ac_cache_corrupted; then
+  { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+  { $as_echo "$as_me:$LINENO: error: changes in the environment can compromise the build" >&5
+$as_echo "$as_me: error: changes in the environment can compromise the build" >&2;}
+  { { $as_echo "$as_me:$LINENO: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&5
+$as_echo "$as_me: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&2;}
+   { (exit 1); exit 1; }; }
+fi
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
+
+
+ac_aux_dir=
+for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do
+  if test -f "$ac_dir/install-sh"; then
+    ac_aux_dir=$ac_dir
+    ac_install_sh="$ac_aux_dir/install-sh -c"
+    break
+  elif test -f "$ac_dir/install.sh"; then
+    ac_aux_dir=$ac_dir
+    ac_install_sh="$ac_aux_dir/install.sh -c"
+    break
+  elif test -f "$ac_dir/shtool"; then
+    ac_aux_dir=$ac_dir
+    ac_install_sh="$ac_aux_dir/shtool install -c"
+    break
+  fi
+done
+if test -z "$ac_aux_dir"; then
+  { { $as_echo "$as_me:$LINENO: error: cannot find install-sh or install.sh in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" >&5
+$as_echo "$as_me: error: cannot find install-sh or install.sh in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" >&2;}
+   { (exit 1); exit 1; }; }
+fi
+
+# These three variables are undocumented and unsupported,
+# and are intended to be withdrawn in a future Autoconf release.
+# They can cause serious problems if a builder's source tree is in a directory
+# whose full name contains unusual characters.
+ac_config_guess="$SHELL $ac_aux_dir/config.guess"  # Please don't use this var.
+ac_config_sub="$SHELL $ac_aux_dir/config.sub"  # Please don't use this var.
+ac_configure="$SHELL $ac_aux_dir/configure"  # Please don't use this var.
+
+
+# Make sure we can run config.sub.
+$SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 ||
+  { { $as_echo "$as_me:$LINENO: error: cannot run $SHELL $ac_aux_dir/config.sub" >&5
+$as_echo "$as_me: error: cannot run $SHELL $ac_aux_dir/config.sub" >&2;}
+   { (exit 1); exit 1; }; }
+
+{ $as_echo "$as_me:$LINENO: checking build system type" >&5
+$as_echo_n "checking build system type... " >&6; }
+if test "${ac_cv_build+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_build_alias=$build_alias
+test "x$ac_build_alias" = x &&
+  ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"`
+test "x$ac_build_alias" = x &&
+  { { $as_echo "$as_me:$LINENO: error: cannot guess build type; you must specify one" >&5
+$as_echo "$as_me: error: cannot guess build type; you must specify one" >&2;}
+   { (exit 1); exit 1; }; }
+ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` ||
+  { { $as_echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $ac_build_alias failed" >&5
+$as_echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $ac_build_alias failed" >&2;}
+   { (exit 1); exit 1; }; }
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_build" >&5
+$as_echo "$ac_cv_build" >&6; }
+case $ac_cv_build in
+*-*-*) ;;
+*) { { $as_echo "$as_me:$LINENO: error: invalid value of canonical build" >&5
+$as_echo "$as_me: error: invalid value of canonical build" >&2;}
+   { (exit 1); exit 1; }; };;
+esac
+build=$ac_cv_build
+ac_save_IFS=$IFS; IFS='-'
+set x $ac_cv_build
+shift
+build_cpu=$1
+build_vendor=$2
+shift; shift
+# Remember, the first character of IFS is used to create $*,
+# except with old shells:
+build_os=$*
+IFS=$ac_save_IFS
+case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac
+
+
+{ $as_echo "$as_me:$LINENO: checking host system type" >&5
+$as_echo_n "checking host system type... " >&6; }
+if test "${ac_cv_host+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test "x$host_alias" = x; then
+  ac_cv_host=$ac_cv_build
+else
+  ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` ||
+    { { $as_echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&5
+$as_echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $host_alias failed" >&2;}
+   { (exit 1); exit 1; }; }
+fi
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_host" >&5
+$as_echo "$ac_cv_host" >&6; }
+case $ac_cv_host in
+*-*-*) ;;
+*) { { $as_echo "$as_me:$LINENO: error: invalid value of canonical host" >&5
+$as_echo "$as_me: error: invalid value of canonical host" >&2;}
+   { (exit 1); exit 1; }; };;
+esac
+host=$ac_cv_host
+ac_save_IFS=$IFS; IFS='-'
+set x $ac_cv_host
+shift
+host_cpu=$1
+host_vendor=$2
+shift; shift
+# Remember, the first character of IFS is used to create $*,
+# except with old shells:
+host_os=$*
+IFS=$ac_save_IFS
+case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac
+
+
+{ $as_echo "$as_me:$LINENO: checking target system type" >&5
+$as_echo_n "checking target system type... " >&6; }
+if test "${ac_cv_target+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test "x$target_alias" = x; then
+  ac_cv_target=$ac_cv_host
+else
+  ac_cv_target=`$SHELL "$ac_aux_dir/config.sub" $target_alias` ||
+    { { $as_echo "$as_me:$LINENO: error: $SHELL $ac_aux_dir/config.sub $target_alias failed" >&5
+$as_echo "$as_me: error: $SHELL $ac_aux_dir/config.sub $target_alias failed" >&2;}
+   { (exit 1); exit 1; }; }
+fi
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_target" >&5
+$as_echo "$ac_cv_target" >&6; }
+case $ac_cv_target in
+*-*-*) ;;
+*) { { $as_echo "$as_me:$LINENO: error: invalid value of canonical target" >&5
+$as_echo "$as_me: error: invalid value of canonical target" >&2;}
+   { (exit 1); exit 1; }; };;
+esac
+target=$ac_cv_target
+ac_save_IFS=$IFS; IFS='-'
+set x $ac_cv_target
+shift
+target_cpu=$1
+target_vendor=$2
+shift; shift
+# Remember, the first character of IFS is used to create $*,
+# except with old shells:
+target_os=$*
+IFS=$ac_save_IFS
+case $target_os in *\ *) target_os=`echo "$target_os" | sed 's/ /-/g'`;; esac
+
+
+# The aliases save the names the user supplied, while $host etc.
+# will get canonicalized.
+test -n "$target_alias" &&
+  test "$program_prefix$program_suffix$program_transform_name" = \
+    NONENONEs,x,x, &&
+  program_prefix=${target_alias}-
+
+# Add the stamp file to the list of files AC keeps track of,
+# along with our hook.
+ac_config_headers="$ac_config_headers config.h"
+
+
+
+
+am__api_version="1.6"
+# Find a good install program.  We prefer a C program (faster),
+# so one script is as good as another.  But avoid the broken or
+# incompatible versions:
+# SysV /etc/install, /usr/sbin/install
+# SunOS /usr/etc/install
+# IRIX /sbin/install
+# AIX /bin/install
+# AmigaOS /C/install, which installs bootblocks on floppy discs
+# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag
+# AFS /usr/afsws/bin/install, which mishandles nonexistent args
+# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff"
+# OS/2's system install, which has a completely different semantic
+# ./install, which can be erroneously created by make from ./install.sh.
+# Reject install programs that cannot install multiple files.
+{ $as_echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5
+$as_echo_n "checking for a BSD-compatible install... " >&6; }
+if test -z "$INSTALL"; then
+if test "${ac_cv_path_install+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  # Account for people who put trailing slashes in PATH elements.
+case $as_dir/ in
+  ./ | .// | /cC/* | \
+  /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \
+  ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \
+  /usr/ucb/* ) ;;
+  *)
+    # OSF1 and SCO ODT 3.0 have their own names for install.
+    # Don't use installbsd from OSF since it installs stuff as root
+    # by default.
+    for ac_prog in ginstall scoinst install; do
+      for ac_exec_ext in '' $ac_executable_extensions; do
+       if { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; }; then
+         if test $ac_prog = install &&
+           grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then
+           # AIX install.  It has an incompatible calling convention.
+           :
+         elif test $ac_prog = install &&
+           grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then
+           # program-specific install script used by HP pwplus--don't use.
+           :
+         else
+           rm -rf conftest.one conftest.two conftest.dir
+           echo one > conftest.one
+           echo two > conftest.two
+           mkdir conftest.dir
+           if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" &&
+             test -s conftest.one && test -s conftest.two &&
+             test -s conftest.dir/conftest.one &&
+             test -s conftest.dir/conftest.two
+           then
+             ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c"
+             break 3
+           fi
+         fi
+       fi
+      done
+    done
+    ;;
+esac
+
+done
+IFS=$as_save_IFS
+
+rm -rf conftest.one conftest.two conftest.dir
+
+fi
+  if test "${ac_cv_path_install+set}" = set; then
+    INSTALL=$ac_cv_path_install
+  else
+    # As a last resort, use the slow shell script.  Don't cache a
+    # value for INSTALL within a source directory, because that will
+    # break other packages using the cache if that directory is
+    # removed, or if the value is a relative name.
+    INSTALL=$ac_install_sh
+  fi
+fi
+{ $as_echo "$as_me:$LINENO: result: $INSTALL" >&5
+$as_echo "$INSTALL" >&6; }
+
+# Use test -z because SunOS4 sh mishandles braces in ${var-val}.
+# It thinks the first close brace ends the variable substitution.
+test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}'
+
+test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}'
+
+test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644'
+
+{ $as_echo "$as_me:$LINENO: checking whether build environment is sane" >&5
+$as_echo_n "checking whether build environment is sane... " >&6; }
+# Just in case
+sleep 1
+echo timestamp > conftest.file
+# Do `set' in a subshell so we don't clobber the current shell's
+# arguments.  Must try -L first in case configure is actually a
+# symlink; some systems play weird games with the mod time of symlinks
+# (eg FreeBSD returns the mod time of the symlink's containing
+# directory).
+if (
+   set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null`
+   if test "$*" = "X"; then
+      # -L didn't work.
+      set X `ls -t $srcdir/configure conftest.file`
+   fi
+   rm -f conftest.file
+   if test "$*" != "X $srcdir/configure conftest.file" \
+      && test "$*" != "X conftest.file $srcdir/configure"; then
+
+      # If neither matched, then we have a broken ls.  This can happen
+      # if, for instance, CONFIG_SHELL is bash and it inherits a
+      # broken ls alias from the environment.  This has actually
+      # happened.  Such a system could not be considered "sane".
+      { { $as_echo "$as_me:$LINENO: error: ls -t appears to fail.  Make sure there is not a broken
+alias in your environment" >&5
+$as_echo "$as_me: error: ls -t appears to fail.  Make sure there is not a broken
+alias in your environment" >&2;}
+   { (exit 1); exit 1; }; }
+   fi
+
+   test "$2" = conftest.file
+   )
+then
+   # Ok.
+   :
+else
+   { { $as_echo "$as_me:$LINENO: error: newly created file is older than distributed files!
+Check your system clock" >&5
+$as_echo "$as_me: error: newly created file is older than distributed files!
+Check your system clock" >&2;}
+   { (exit 1); exit 1; }; }
+fi
+{ $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+test "$program_prefix" != NONE &&
+  program_transform_name="s&^&$program_prefix&;$program_transform_name"
+# Use a double $ so make ignores it.
+test "$program_suffix" != NONE &&
+  program_transform_name="s&\$&$program_suffix&;$program_transform_name"
+# Double any \ or $.
+# By default was `s,x,x', remove it if useless.
+ac_script='s/[\\$]/&&/g;s/;s,x,x,$//'
+program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"`
+
+
+# expand $ac_aux_dir to an absolute path
+am_aux_dir=`cd $ac_aux_dir && pwd`
+
+test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing"
+# Use eval to expand $SHELL
+if eval "$MISSING --run true"; then
+  am_missing_run="$MISSING --run "
+else
+  am_missing_run=
+  { $as_echo "$as_me:$LINENO: WARNING: \`missing' script is too old or missing" >&5
+$as_echo "$as_me: WARNING: \`missing' script is too old or missing" >&2;}
+fi
+
+for ac_prog in gawk mawk nawk awk
+do
+  # Extract the first word of "$ac_prog", so it can be a program name with args.
+set dummy $ac_prog; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_AWK+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$AWK"; then
+  ac_cv_prog_AWK="$AWK" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_AWK="$ac_prog"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+AWK=$ac_cv_prog_AWK
+if test -n "$AWK"; then
+  { $as_echo "$as_me:$LINENO: result: $AWK" >&5
+$as_echo "$AWK" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  test -n "$AWK" && break
+done
+
+{ $as_echo "$as_me:$LINENO: checking whether ${MAKE-make} sets \$(MAKE)" >&5
+$as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; }
+set x ${MAKE-make}
+ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'`
+if { as_var=ac_cv_prog_make_${ac_make}_set; eval "test \"\${$as_var+set}\" = set"; }; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.make <<\_ACEOF
+SHELL = /bin/sh
+all:
+       @echo '@@@%%%=$(MAKE)=@@@%%%'
+_ACEOF
+# GNU make sometimes prints "make[1]: Entering...", which would confuse us.
+case `${MAKE-make} -f conftest.make 2>/dev/null` in
+  *@@@%%%=?*=@@@%%%*)
+    eval ac_cv_prog_make_${ac_make}_set=yes;;
+  *)
+    eval ac_cv_prog_make_${ac_make}_set=no;;
+esac
+rm -f conftest.make
+fi
+if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then
+  { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+  SET_MAKE=
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+  SET_MAKE="MAKE=${MAKE-make}"
+fi
+
+ # test to see if srcdir already configured
+if test "`cd $srcdir && pwd`" != "`pwd`" &&
+   test -f $srcdir/config.status; then
+  { { $as_echo "$as_me:$LINENO: error: source directory already configured; run \"make distclean\" there first" >&5
+$as_echo "$as_me: error: source directory already configured; run \"make distclean\" there first" >&2;}
+   { (exit 1); exit 1; }; }
+fi
+
+# Define the identity of the package.
+ PACKAGE=libtheora
+ VERSION=1.1.1
+
+
+cat >>confdefs.h <<_ACEOF
+#define PACKAGE "$PACKAGE"
+_ACEOF
+
+
+cat >>confdefs.h <<_ACEOF
+#define VERSION "$VERSION"
+_ACEOF
+
+# Some tools Automake needs.
+
+ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"}
+
+
+AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"}
+
+
+AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"}
+
+
+AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"}
+
+
+MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
+
+
+AMTAR=${AMTAR-"${am_missing_run}tar"}
+
+install_sh=${install_sh-"$am_aux_dir/install-sh"}
+
+# Installed binaries are usually stripped using `strip' when the user
+# run `make install-strip'.  However `strip' might not be the right
+# tool to use in cross-compilation environments, therefore Automake
+# will honor the `STRIP' environment variable to overrule this program.
+if test "$cross_compiling" != no; then
+  if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args.
+set dummy ${ac_tool_prefix}strip; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_STRIP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$STRIP"; then
+  ac_cv_prog_STRIP="$STRIP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_STRIP="${ac_tool_prefix}strip"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+STRIP=$ac_cv_prog_STRIP
+if test -n "$STRIP"; then
+  { $as_echo "$as_me:$LINENO: result: $STRIP" >&5
+$as_echo "$STRIP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_STRIP"; then
+  ac_ct_STRIP=$STRIP
+  # Extract the first word of "strip", so it can be a program name with args.
+set dummy strip; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_STRIP"; then
+  ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_STRIP="strip"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP
+if test -n "$ac_ct_STRIP"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5
+$as_echo "$ac_ct_STRIP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_STRIP" = x; then
+    STRIP=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    STRIP=$ac_ct_STRIP
+  fi
+else
+  STRIP="$ac_cv_prog_STRIP"
+fi
+
+fi
+INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s"
+
+# We need awk for the "check" target.  The system "awk" is bad on
+# some platforms.
+
+
+
+{ $as_echo "$as_me:$LINENO: checking whether to enable maintainer-specific portions of Makefiles" >&5
+$as_echo_n "checking whether to enable maintainer-specific portions of Makefiles... " >&6; }
+    # Check whether --enable-maintainer-mode was given.
+if test "${enable_maintainer_mode+set}" = set; then
+  enableval=$enable_maintainer_mode; USE_MAINTAINER_MODE=$enableval
+else
+  USE_MAINTAINER_MODE=no
+fi
+
+  { $as_echo "$as_me:$LINENO: result: $USE_MAINTAINER_MODE" >&5
+$as_echo "$USE_MAINTAINER_MODE" >&6; }
+
+
+if test $USE_MAINTAINER_MODE = yes; then
+  MAINTAINER_MODE_TRUE=
+  MAINTAINER_MODE_FALSE='#'
+else
+  MAINTAINER_MODE_TRUE='#'
+  MAINTAINER_MODE_FALSE=
+fi
+
+  MAINT=$MAINTAINER_MODE_TRUE
+
+
+
+
+TH_LIB_CURRENT=3
+TH_LIB_REVISION=10
+TH_LIB_AGE=3
+
+
+
+
+THDEC_LIB_CURRENT=2
+THDEC_LIB_REVISION=4
+THDEC_LIB_AGE=1
+
+
+
+
+THENC_LIB_CURRENT=2
+THENC_LIB_REVISION=2
+THENC_LIB_AGE=1
+
+
+
+
+THEORA_LDFLAGS=""
+
+
+cflags_save="$CFLAGS"
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args.
+set dummy ${ac_tool_prefix}gcc; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_CC+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$CC"; then
+  ac_cv_prog_CC="$CC" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_CC="${ac_tool_prefix}gcc"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+CC=$ac_cv_prog_CC
+if test -n "$CC"; then
+  { $as_echo "$as_me:$LINENO: result: $CC" >&5
+$as_echo "$CC" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_CC"; then
+  ac_ct_CC=$CC
+  # Extract the first word of "gcc", so it can be a program name with args.
+set dummy gcc; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_CC+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_CC"; then
+  ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_CC="gcc"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_CC=$ac_cv_prog_ac_ct_CC
+if test -n "$ac_ct_CC"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_CC" >&5
+$as_echo "$ac_ct_CC" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_CC" = x; then
+    CC=""
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    CC=$ac_ct_CC
+  fi
+else
+  CC="$ac_cv_prog_CC"
+fi
+
+if test -z "$CC"; then
+          if test -n "$ac_tool_prefix"; then
+    # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args.
+set dummy ${ac_tool_prefix}cc; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_CC+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$CC"; then
+  ac_cv_prog_CC="$CC" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_CC="${ac_tool_prefix}cc"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+CC=$ac_cv_prog_CC
+if test -n "$CC"; then
+  { $as_echo "$as_me:$LINENO: result: $CC" >&5
+$as_echo "$CC" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  fi
+fi
+if test -z "$CC"; then
+  # Extract the first word of "cc", so it can be a program name with args.
+set dummy cc; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_CC+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$CC"; then
+  ac_cv_prog_CC="$CC" # Let the user override the test.
+else
+  ac_prog_rejected=no
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then
+       ac_prog_rejected=yes
+       continue
+     fi
+    ac_cv_prog_CC="cc"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+if test $ac_prog_rejected = yes; then
+  # We found a bogon in the path, so make sure we never use it.
+  set dummy $ac_cv_prog_CC
+  shift
+  if test $# != 0; then
+    # We chose a different compiler from the bogus one.
+    # However, it has the same basename, so the bogon will be chosen
+    # first if we set CC to just the basename; use the full file name.
+    shift
+    ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@"
+  fi
+fi
+fi
+fi
+CC=$ac_cv_prog_CC
+if test -n "$CC"; then
+  { $as_echo "$as_me:$LINENO: result: $CC" >&5
+$as_echo "$CC" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$CC"; then
+  if test -n "$ac_tool_prefix"; then
+  for ac_prog in cl.exe
+  do
+    # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args.
+set dummy $ac_tool_prefix$ac_prog; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_CC+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$CC"; then
+  ac_cv_prog_CC="$CC" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_CC="$ac_tool_prefix$ac_prog"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+CC=$ac_cv_prog_CC
+if test -n "$CC"; then
+  { $as_echo "$as_me:$LINENO: result: $CC" >&5
+$as_echo "$CC" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+    test -n "$CC" && break
+  done
+fi
+if test -z "$CC"; then
+  ac_ct_CC=$CC
+  for ac_prog in cl.exe
+do
+  # Extract the first word of "$ac_prog", so it can be a program name with args.
+set dummy $ac_prog; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_CC+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_CC"; then
+  ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_CC="$ac_prog"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_CC=$ac_cv_prog_ac_ct_CC
+if test -n "$ac_ct_CC"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_CC" >&5
+$as_echo "$ac_ct_CC" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  test -n "$ac_ct_CC" && break
+done
+
+  if test "x$ac_ct_CC" = x; then
+    CC=""
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    CC=$ac_ct_CC
+  fi
+fi
+
+fi
+
+
+test -z "$CC" && { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+{ { $as_echo "$as_me:$LINENO: error: no acceptable C compiler found in \$PATH
+See \`config.log' for more details." >&5
+$as_echo "$as_me: error: no acceptable C compiler found in \$PATH
+See \`config.log' for more details." >&2;}
+   { (exit 1); exit 1; }; }; }
+
+# Provide some information about the compiler.
+$as_echo "$as_me:$LINENO: checking for C compiler version" >&5
+set X $ac_compile
+ac_compiler=$2
+{ (ac_try="$ac_compiler --version >&5"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compiler --version >&5") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }
+{ (ac_try="$ac_compiler -v >&5"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compiler -v >&5") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }
+{ (ac_try="$ac_compiler -V >&5"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compiler -V >&5") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }
+
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+ac_clean_files_save=$ac_clean_files
+ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out"
+# Try to create an executable without -o first, disregard a.out.
+# It will help us diagnose broken compilers, and finding out an intuition
+# of exeext.
+{ $as_echo "$as_me:$LINENO: checking for C compiler default output file name" >&5
+$as_echo_n "checking for C compiler default output file name... " >&6; }
+ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'`
+
+# The possible output files:
+ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*"
+
+ac_rmfiles=
+for ac_file in $ac_files
+do
+  case $ac_file in
+    *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;;
+    * ) ac_rmfiles="$ac_rmfiles $ac_file";;
+  esac
+done
+rm -f $ac_rmfiles
+
+if { (ac_try="$ac_link_default"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link_default") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  # Autoconf-2.13 could set the ac_cv_exeext variable to `no'.
+# So ignore a value of `no', otherwise this would lead to `EXEEXT = no'
+# in a Makefile.  We should not override ac_cv_exeext if it was cached,
+# so that the user can short-circuit this test for compilers unknown to
+# Autoconf.
+for ac_file in $ac_files ''
+do
+  test -f "$ac_file" || continue
+  case $ac_file in
+    *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj )
+       ;;
+    [ab].out )
+       # We found the default executable, but exeext='' is most
+       # certainly right.
+       break;;
+    *.* )
+        if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no;
+       then :; else
+          ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'`
+       fi
+       # We set ac_cv_exeext here because the later test for it is not
+       # safe: cross compilers may not add the suffix if given an `-o'
+       # argument, so we may need to know it at that point already.
+       # Even if this section looks crufty: it has the advantage of
+       # actually working.
+       break;;
+    * )
+       break;;
+  esac
+done
+test "$ac_cv_exeext" = no && ac_cv_exeext=
+
+else
+  ac_file=''
+fi
+
+{ $as_echo "$as_me:$LINENO: result: $ac_file" >&5
+$as_echo "$ac_file" >&6; }
+if test -z "$ac_file"; then
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+{ { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+{ { $as_echo "$as_me:$LINENO: error: C compiler cannot create executables
+See \`config.log' for more details." >&5
+$as_echo "$as_me: error: C compiler cannot create executables
+See \`config.log' for more details." >&2;}
+   { (exit 77); exit 77; }; }; }
+fi
+
+ac_exeext=$ac_cv_exeext
+
+# Check that the compiler produces executables we can run.  If not, either
+# the compiler is broken, or we cross compile.
+{ $as_echo "$as_me:$LINENO: checking whether the C compiler works" >&5
+$as_echo_n "checking whether the C compiler works... " >&6; }
+# FIXME: These cross compiler hacks should be removed for Autoconf 3.0
+# If not cross compiling, check that we can run a simple program.
+if test "$cross_compiling" != yes; then
+  if { ac_try='./$ac_file'
+  { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; }; then
+    cross_compiling=no
+  else
+    if test "$cross_compiling" = maybe; then
+       cross_compiling=yes
+    else
+       { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+{ { $as_echo "$as_me:$LINENO: error: cannot run C compiled programs.
+If you meant to cross compile, use \`--host'.
+See \`config.log' for more details." >&5
+$as_echo "$as_me: error: cannot run C compiled programs.
+If you meant to cross compile, use \`--host'.
+See \`config.log' for more details." >&2;}
+   { (exit 1); exit 1; }; }; }
+    fi
+  fi
+fi
+{ $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+
+rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out
+ac_clean_files=$ac_clean_files_save
+# Check that the compiler produces executables we can run.  If not, either
+# the compiler is broken, or we cross compile.
+{ $as_echo "$as_me:$LINENO: checking whether we are cross compiling" >&5
+$as_echo_n "checking whether we are cross compiling... " >&6; }
+{ $as_echo "$as_me:$LINENO: result: $cross_compiling" >&5
+$as_echo "$cross_compiling" >&6; }
+
+{ $as_echo "$as_me:$LINENO: checking for suffix of executables" >&5
+$as_echo_n "checking for suffix of executables... " >&6; }
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  # If both `conftest.exe' and `conftest' are `present' (well, observable)
+# catch `conftest.exe'.  For instance with Cygwin, `ls conftest' will
+# work properly (i.e., refer to `conftest.exe'), while it won't with
+# `rm'.
+for ac_file in conftest.exe conftest conftest.*; do
+  test -f "$ac_file" || continue
+  case $ac_file in
+    *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;;
+    *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'`
+         break;;
+    * ) break;;
+  esac
+done
+else
+  { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+{ { $as_echo "$as_me:$LINENO: error: cannot compute suffix of executables: cannot compile and link
+See \`config.log' for more details." >&5
+$as_echo "$as_me: error: cannot compute suffix of executables: cannot compile and link
+See \`config.log' for more details." >&2;}
+   { (exit 1); exit 1; }; }; }
+fi
+
+rm -f conftest$ac_cv_exeext
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_exeext" >&5
+$as_echo "$ac_cv_exeext" >&6; }
+
+rm -f conftest.$ac_ext
+EXEEXT=$ac_cv_exeext
+ac_exeext=$EXEEXT
+{ $as_echo "$as_me:$LINENO: checking for suffix of object files" >&5
+$as_echo_n "checking for suffix of object files... " >&6; }
+if test "${ac_cv_objext+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.o conftest.obj
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  for ac_file in conftest.o conftest.obj conftest.*; do
+  test -f "$ac_file" || continue;
+  case $ac_file in
+    *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;;
+    *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'`
+       break;;
+  esac
+done
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+{ { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+{ { $as_echo "$as_me:$LINENO: error: cannot compute suffix of object files: cannot compile
+See \`config.log' for more details." >&5
+$as_echo "$as_me: error: cannot compute suffix of object files: cannot compile
+See \`config.log' for more details." >&2;}
+   { (exit 1); exit 1; }; }; }
+fi
+
+rm -f conftest.$ac_cv_objext conftest.$ac_ext
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_objext" >&5
+$as_echo "$ac_cv_objext" >&6; }
+OBJEXT=$ac_cv_objext
+ac_objext=$OBJEXT
+{ $as_echo "$as_me:$LINENO: checking whether we are using the GNU C compiler" >&5
+$as_echo_n "checking whether we are using the GNU C compiler... " >&6; }
+if test "${ac_cv_c_compiler_gnu+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+#ifndef __GNUC__
+       choke me
+#endif
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  ac_compiler_gnu=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_compiler_gnu=no
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+ac_cv_c_compiler_gnu=$ac_compiler_gnu
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_c_compiler_gnu" >&5
+$as_echo "$ac_cv_c_compiler_gnu" >&6; }
+if test $ac_compiler_gnu = yes; then
+  GCC=yes
+else
+  GCC=
+fi
+ac_test_CFLAGS=${CFLAGS+set}
+ac_save_CFLAGS=$CFLAGS
+{ $as_echo "$as_me:$LINENO: checking whether $CC accepts -g" >&5
+$as_echo_n "checking whether $CC accepts -g... " >&6; }
+if test "${ac_cv_prog_cc_g+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_save_c_werror_flag=$ac_c_werror_flag
+   ac_c_werror_flag=yes
+   ac_cv_prog_cc_g=no
+   CFLAGS="-g"
+   cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  ac_cv_prog_cc_g=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       CFLAGS=""
+      cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  :
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_c_werror_flag=$ac_save_c_werror_flag
+        CFLAGS="-g"
+        cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  ac_cv_prog_cc_g=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+   ac_c_werror_flag=$ac_save_c_werror_flag
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cc_g" >&5
+$as_echo "$ac_cv_prog_cc_g" >&6; }
+if test "$ac_test_CFLAGS" = set; then
+  CFLAGS=$ac_save_CFLAGS
+elif test $ac_cv_prog_cc_g = yes; then
+  if test "$GCC" = yes; then
+    CFLAGS="-g -O2"
+  else
+    CFLAGS="-g"
+  fi
+else
+  if test "$GCC" = yes; then
+    CFLAGS="-O2"
+  else
+    CFLAGS=
+  fi
+fi
+{ $as_echo "$as_me:$LINENO: checking for $CC option to accept ISO C89" >&5
+$as_echo_n "checking for $CC option to accept ISO C89... " >&6; }
+if test "${ac_cv_prog_cc_c89+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_cv_prog_cc_c89=no
+ac_save_CC=$CC
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <stdarg.h>
+#include <stdio.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+/* Most of the following tests are stolen from RCS 5.7's src/conf.sh.  */
+struct buf { int x; };
+FILE * (*rcsopen) (struct buf *, struct stat *, int);
+static char *e (p, i)
+     char **p;
+     int i;
+{
+  return p[i];
+}
+static char *f (char * (*g) (char **, int), char **p, ...)
+{
+  char *s;
+  va_list v;
+  va_start (v,p);
+  s = g (p, va_arg (v,int));
+  va_end (v);
+  return s;
+}
+
+/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default.  It has
+   function prototypes and stuff, but not '\xHH' hex character constants.
+   These don't provoke an error unfortunately, instead are silently treated
+   as 'x'.  The following induces an error, until -std is added to get
+   proper ANSI mode.  Curiously '\x00'!='x' always comes out true, for an
+   array size at least.  It's necessary to write '\x00'==0 to get something
+   that's true only with -std.  */
+int osf4_cc_array ['\x00' == 0 ? 1 : -1];
+
+/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters
+   inside strings and character constants.  */
+#define FOO(x) 'x'
+int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1];
+
+int test (int i, double x);
+struct s1 {int (*f) (int a);};
+struct s2 {int (*f) (double a);};
+int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int);
+int argc;
+char **argv;
+int
+main ()
+{
+return f (e, argv, 0) != argv[0]  ||  f (e, argv, 1) != argv[1];
+  ;
+  return 0;
+}
+_ACEOF
+for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \
+       -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__"
+do
+  CC="$ac_save_CC $ac_arg"
+  rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  ac_cv_prog_cc_c89=$ac_arg
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+
+fi
+
+rm -f core conftest.err conftest.$ac_objext
+  test "x$ac_cv_prog_cc_c89" != "xno" && break
+done
+rm -f conftest.$ac_ext
+CC=$ac_save_CC
+
+fi
+# AC_CACHE_VAL
+case "x$ac_cv_prog_cc_c89" in
+  x)
+    { $as_echo "$as_me:$LINENO: result: none needed" >&5
+$as_echo "none needed" >&6; } ;;
+  xno)
+    { $as_echo "$as_me:$LINENO: result: unsupported" >&5
+$as_echo "unsupported" >&6; } ;;
+  *)
+    CC="$CC $ac_cv_prog_cc_c89"
+    { $as_echo "$as_me:$LINENO: result: $ac_cv_prog_cc_c89" >&5
+$as_echo "$ac_cv_prog_cc_c89" >&6; } ;;
+esac
+
+
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+rm -f .deps 2>/dev/null
+mkdir .deps 2>/dev/null
+if test -d .deps; then
+  DEPDIR=.deps
+else
+  # MS-DOS does not allow filenames that begin with a dot.
+  DEPDIR=_deps
+fi
+rmdir .deps 2>/dev/null
+
+
+ac_config_commands="$ac_config_commands depfiles"
+
+
+am_make=${MAKE-make}
+cat > confinc << 'END'
+doit:
+       @echo done
+END
+# If we don't find an include directive, just comment out the code.
+{ $as_echo "$as_me:$LINENO: checking for style of include used by $am_make" >&5
+$as_echo_n "checking for style of include used by $am_make... " >&6; }
+am__include="#"
+am__quote=
+_am_result=none
+# First try GNU make style include.
+echo "include confinc" > confmf
+# We grep out `Entering directory' and `Leaving directory'
+# messages which can occur if `w' ends up in MAKEFLAGS.
+# In particular we don't look at `^make:' because GNU make might
+# be invoked under some other name (usually "gmake"), in which
+# case it prints its new name instead of `make'.
+if test "`$am_make -s -f confmf 2> /dev/null | fgrep -v 'ing directory'`" = "done"; then
+   am__include=include
+   am__quote=
+   _am_result=GNU
+fi
+# Now try BSD make style include.
+if test "$am__include" = "#"; then
+   echo '.include "confinc"' > confmf
+   if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then
+      am__include=.include
+      am__quote="\""
+      _am_result=BSD
+   fi
+fi
+
+
+{ $as_echo "$as_me:$LINENO: result: $_am_result" >&5
+$as_echo "$_am_result" >&6; }
+rm -f confinc confmf
+
+# Check whether --enable-dependency-tracking was given.
+if test "${enable_dependency_tracking+set}" = set; then
+  enableval=$enable_dependency_tracking;
+fi
+
+if test "x$enable_dependency_tracking" != xno; then
+  am_depcomp="$ac_aux_dir/depcomp"
+  AMDEPBACKSLASH='\'
+fi
+
+
+if test "x$enable_dependency_tracking" != xno; then
+  AMDEP_TRUE=
+  AMDEP_FALSE='#'
+else
+  AMDEP_TRUE='#'
+  AMDEP_FALSE=
+fi
+
+
+
+
+depcc="$CC"   am_compiler_list=
+
+{ $as_echo "$as_me:$LINENO: checking dependency style of $depcc" >&5
+$as_echo_n "checking dependency style of $depcc... " >&6; }
+if test "${am_cv_CC_dependencies_compiler_type+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
+  # We make a subdir and do the tests there.  Otherwise we can end up
+  # making bogus files that we don't know about and never remove.  For
+  # instance it was reported that on HP-UX the gcc test will end up
+  # making a dummy file named `D' -- because `-MD' means `put the output
+  # in D'.
+  mkdir conftest.dir
+  # Copy depcomp to subdir because otherwise we won't find it if we're
+  # using a relative directory.
+  cp "$am_depcomp" conftest.dir
+  cd conftest.dir
+
+  am_cv_CC_dependencies_compiler_type=none
+  if test "$am_compiler_list" = ""; then
+     am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp`
+  fi
+  for depmode in $am_compiler_list; do
+    # We need to recreate these files for each test, as the compiler may
+    # overwrite some of them when testing with obscure command lines.
+    # This happens at least with the AIX C compiler.
+    echo '#include "conftest.h"' > conftest.c
+    echo 'int i;' > conftest.h
+    echo "${am__include} ${am__quote}conftest.Po${am__quote}" > confmf
+
+    case $depmode in
+    nosideeffect)
+      # after this tag, mechanisms are not by side-effect, so they'll
+      # only be used when explicitly requested
+      if test "x$enable_dependency_tracking" = xyes; then
+       continue
+      else
+       break
+      fi
+      ;;
+    none) break ;;
+    esac
+    # We check with `-c' and `-o' for the sake of the "dashmstdout"
+    # mode.  It turns out that the SunPro C++ compiler does not properly
+    # handle `-M -o', and we need to detect this.
+    if depmode=$depmode \
+       source=conftest.c object=conftest.o \
+       depfile=conftest.Po tmpdepfile=conftest.TPo \
+       $SHELL ./depcomp $depcc -c conftest.c -o conftest.o >/dev/null 2>&1 &&
+       grep conftest.h conftest.Po > /dev/null 2>&1 &&
+       ${MAKE-make} -s -f confmf > /dev/null 2>&1; then
+      am_cv_CC_dependencies_compiler_type=$depmode
+      break
+    fi
+  done
+
+  cd ..
+  rm -rf conftest.dir
+else
+  am_cv_CC_dependencies_compiler_type=none
+fi
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $am_cv_CC_dependencies_compiler_type" >&5
+$as_echo "$am_cv_CC_dependencies_compiler_type" >&6; }
+CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type
+
+
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+{ $as_echo "$as_me:$LINENO: checking how to run the C preprocessor" >&5
+$as_echo_n "checking how to run the C preprocessor... " >&6; }
+# On Suns, sometimes $CPP names a directory.
+if test -n "$CPP" && test -d "$CPP"; then
+  CPP=
+fi
+if test -z "$CPP"; then
+  if test "${ac_cv_prog_CPP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+      # Double quotes because CPP needs to be expanded
+    for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp"
+    do
+      ac_preproc_ok=false
+for ac_c_preproc_warn_flag in '' yes
+do
+  # Use a header file that comes with gcc, so configuring glibc
+  # with a fresh cross-compiler works.
+  # Prefer <limits.h> to <assert.h> if __STDC__ is defined, since
+  # <limits.h> exists even on freestanding compilers.
+  # On the NeXT, cc -E runs the code through the compiler's parser,
+  # not just through cpp. "Syntax error" is here to catch this case.
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#ifdef __STDC__
+# include <limits.h>
+#else
+# include <assert.h>
+#endif
+                    Syntax error
+_ACEOF
+if { (ac_try="$ac_cpp conftest.$ac_ext"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } >/dev/null && {
+        test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       }; then
+  :
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+  # Broken: fails on valid input.
+continue
+fi
+
+rm -f conftest.err conftest.$ac_ext
+
+  # OK, works on sane cases.  Now check whether nonexistent headers
+  # can be detected and how.
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <ac_nonexistent.h>
+_ACEOF
+if { (ac_try="$ac_cpp conftest.$ac_ext"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } >/dev/null && {
+        test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       }; then
+  # Broken: success on invalid input.
+continue
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+  # Passes both tests.
+ac_preproc_ok=:
+break
+fi
+
+rm -f conftest.err conftest.$ac_ext
+
+done
+# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped.
+rm -f conftest.err conftest.$ac_ext
+if $ac_preproc_ok; then
+  break
+fi
+
+    done
+    ac_cv_prog_CPP=$CPP
+
+fi
+  CPP=$ac_cv_prog_CPP
+else
+  ac_cv_prog_CPP=$CPP
+fi
+{ $as_echo "$as_me:$LINENO: result: $CPP" >&5
+$as_echo "$CPP" >&6; }
+ac_preproc_ok=false
+for ac_c_preproc_warn_flag in '' yes
+do
+  # Use a header file that comes with gcc, so configuring glibc
+  # with a fresh cross-compiler works.
+  # Prefer <limits.h> to <assert.h> if __STDC__ is defined, since
+  # <limits.h> exists even on freestanding compilers.
+  # On the NeXT, cc -E runs the code through the compiler's parser,
+  # not just through cpp. "Syntax error" is here to catch this case.
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#ifdef __STDC__
+# include <limits.h>
+#else
+# include <assert.h>
+#endif
+                    Syntax error
+_ACEOF
+if { (ac_try="$ac_cpp conftest.$ac_ext"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } >/dev/null && {
+        test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       }; then
+  :
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+  # Broken: fails on valid input.
+continue
+fi
+
+rm -f conftest.err conftest.$ac_ext
+
+  # OK, works on sane cases.  Now check whether nonexistent headers
+  # can be detected and how.
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <ac_nonexistent.h>
+_ACEOF
+if { (ac_try="$ac_cpp conftest.$ac_ext"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } >/dev/null && {
+        test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       }; then
+  # Broken: success on invalid input.
+continue
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+  # Passes both tests.
+ac_preproc_ok=:
+break
+fi
+
+rm -f conftest.err conftest.$ac_ext
+
+done
+# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped.
+rm -f conftest.err conftest.$ac_ext
+if $ac_preproc_ok; then
+  :
+else
+  { { $as_echo "$as_me:$LINENO: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+{ { $as_echo "$as_me:$LINENO: error: C preprocessor \"$CPP\" fails sanity check
+See \`config.log' for more details." >&5
+$as_echo "$as_me: error: C preprocessor \"$CPP\" fails sanity check
+See \`config.log' for more details." >&2;}
+   { (exit 1); exit 1; }; }; }
+fi
+
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
+CFLAGS="$cflags_save"
+
+if test "x$CC" != xcc; then
+  { $as_echo "$as_me:$LINENO: checking whether $CC and cc understand -c and -o together" >&5
+$as_echo_n "checking whether $CC and cc understand -c and -o together... " >&6; }
+else
+  { $as_echo "$as_me:$LINENO: checking whether cc understands -c and -o together" >&5
+$as_echo_n "checking whether cc understands -c and -o together... " >&6; }
+fi
+set dummy $CC; ac_cc=`$as_echo "$2" |
+                     sed 's/[^a-zA-Z0-9_]/_/g;s/^[0-9]/_/'`
+if { as_var=ac_cv_prog_cc_${ac_cc}_c_o; eval "test \"\${$as_var+set}\" = set"; }; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+# Make sure it works both with $CC and with simple cc.
+# We do the test twice because some compilers refuse to overwrite an
+# existing .o file with -o, though they will create one.
+ac_try='$CC -c conftest.$ac_ext -o conftest2.$ac_objext >&5'
+rm -f conftest2.*
+if { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } &&
+   test -f conftest2.$ac_objext && { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); };
+then
+  eval ac_cv_prog_cc_${ac_cc}_c_o=yes
+  if test "x$CC" != xcc; then
+    # Test first that cc exists at all.
+    if { ac_try='cc -c conftest.$ac_ext >&5'
+  { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; }; then
+      ac_try='cc -c conftest.$ac_ext -o conftest2.$ac_objext >&5'
+      rm -f conftest2.*
+      if { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } &&
+        test -f conftest2.$ac_objext && { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); };
+      then
+       # cc works too.
+       :
+      else
+       # cc exists but doesn't like -o.
+       eval ac_cv_prog_cc_${ac_cc}_c_o=no
+      fi
+    fi
+  fi
+else
+  eval ac_cv_prog_cc_${ac_cc}_c_o=no
+fi
+rm -f core conftest*
+
+fi
+if eval test \$ac_cv_prog_cc_${ac_cc}_c_o = yes; then
+  { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+
+cat >>confdefs.h <<\_ACEOF
+#define NO_MINUS_C_MINUS_O 1
+_ACEOF
+
+fi
+
+# FIXME: we rely on the cache variable name because
+# there is no other way.
+set dummy $CC
+ac_cc=`echo $2 | sed 's/[^a-zA-Z0-9_]/_/g;s/^[0-9]/_/'`
+if eval "test \"`echo '$ac_cv_prog_cc_'${ac_cc}_c_o`\" != yes"; then
+   # Losing compiler, so override with the script.
+   # FIXME: It is wrong to rewrite CC.
+   # But if we don't then we get into trouble of one sort or another.
+   # A longer-term fix would be to have automake use am__CC in this case,
+   # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)"
+   CC="$am_aux_dir/compile $CC"
+fi
+
+enable_win32_dll=yes
+
+case $host in
+*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-cegcc*)
+  if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}as", so it can be a program name with args.
+set dummy ${ac_tool_prefix}as; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_AS+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$AS"; then
+  ac_cv_prog_AS="$AS" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_AS="${ac_tool_prefix}as"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+AS=$ac_cv_prog_AS
+if test -n "$AS"; then
+  { $as_echo "$as_me:$LINENO: result: $AS" >&5
+$as_echo "$AS" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_AS"; then
+  ac_ct_AS=$AS
+  # Extract the first word of "as", so it can be a program name with args.
+set dummy as; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_AS+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_AS"; then
+  ac_cv_prog_ac_ct_AS="$ac_ct_AS" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_AS="as"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_AS=$ac_cv_prog_ac_ct_AS
+if test -n "$ac_ct_AS"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_AS" >&5
+$as_echo "$ac_ct_AS" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_AS" = x; then
+    AS="false"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    AS=$ac_ct_AS
+  fi
+else
+  AS="$ac_cv_prog_AS"
+fi
+
+  if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args.
+set dummy ${ac_tool_prefix}dlltool; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_DLLTOOL+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$DLLTOOL"; then
+  ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+DLLTOOL=$ac_cv_prog_DLLTOOL
+if test -n "$DLLTOOL"; then
+  { $as_echo "$as_me:$LINENO: result: $DLLTOOL" >&5
+$as_echo "$DLLTOOL" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_DLLTOOL"; then
+  ac_ct_DLLTOOL=$DLLTOOL
+  # Extract the first word of "dlltool", so it can be a program name with args.
+set dummy dlltool; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_DLLTOOL+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_DLLTOOL"; then
+  ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_DLLTOOL="dlltool"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL
+if test -n "$ac_ct_DLLTOOL"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_DLLTOOL" >&5
+$as_echo "$ac_ct_DLLTOOL" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_DLLTOOL" = x; then
+    DLLTOOL="false"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    DLLTOOL=$ac_ct_DLLTOOL
+  fi
+else
+  DLLTOOL="$ac_cv_prog_DLLTOOL"
+fi
+
+  if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args.
+set dummy ${ac_tool_prefix}objdump; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_OBJDUMP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$OBJDUMP"; then
+  ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+OBJDUMP=$ac_cv_prog_OBJDUMP
+if test -n "$OBJDUMP"; then
+  { $as_echo "$as_me:$LINENO: result: $OBJDUMP" >&5
+$as_echo "$OBJDUMP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_OBJDUMP"; then
+  ac_ct_OBJDUMP=$OBJDUMP
+  # Extract the first word of "objdump", so it can be a program name with args.
+set dummy objdump; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_OBJDUMP"; then
+  ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_OBJDUMP="objdump"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP
+if test -n "$ac_ct_OBJDUMP"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_OBJDUMP" >&5
+$as_echo "$ac_ct_OBJDUMP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_OBJDUMP" = x; then
+    OBJDUMP="false"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    OBJDUMP=$ac_ct_OBJDUMP
+  fi
+else
+  OBJDUMP="$ac_cv_prog_OBJDUMP"
+fi
+
+  ;;
+esac
+
+test -z "$AS" && AS=as
+
+
+
+
+
+test -z "$DLLTOOL" && DLLTOOL=dlltool
+
+
+
+
+
+test -z "$OBJDUMP" && OBJDUMP=objdump
+
+
+
+
+
+
+
+case `pwd` in
+  *\ * | *\    *)
+    { $as_echo "$as_me:$LINENO: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5
+$as_echo "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;;
+esac
+
+
+
+macro_version='2.2.6'
+macro_revision='1.3012'
+
+
+
+
+
+
+
+
+
+
+
+
+
+ltmain="$ac_aux_dir/ltmain.sh"
+
+{ $as_echo "$as_me:$LINENO: checking for a sed that does not truncate output" >&5
+$as_echo_n "checking for a sed that does not truncate output... " >&6; }
+if test "${ac_cv_path_SED+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+            ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/
+     for ac_i in 1 2 3 4 5 6 7; do
+       ac_script="$ac_script$as_nl$ac_script"
+     done
+     echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed
+     $as_unset ac_script || ac_script=
+     if test -z "$SED"; then
+  ac_path_SED_found=false
+  # Loop through the user's path and test for each of PROGNAME-LIST
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_prog in sed gsed; do
+    for ac_exec_ext in '' $ac_executable_extensions; do
+      ac_path_SED="$as_dir/$ac_prog$ac_exec_ext"
+      { test -f "$ac_path_SED" && $as_test_x "$ac_path_SED"; } || continue
+# Check for GNU ac_path_SED and select it if it is found.
+  # Check for GNU $ac_path_SED
+case `"$ac_path_SED" --version 2>&1` in
+*GNU*)
+  ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;;
+*)
+  ac_count=0
+  $as_echo_n 0123456789 >"conftest.in"
+  while :
+  do
+    cat "conftest.in" "conftest.in" >"conftest.tmp"
+    mv "conftest.tmp" "conftest.in"
+    cp "conftest.in" "conftest.nl"
+    $as_echo '' >> "conftest.nl"
+    "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break
+    diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break
+    ac_count=`expr $ac_count + 1`
+    if test $ac_count -gt ${ac_path_SED_max-0}; then
+      # Best one so far, save it but keep looking for a better one
+      ac_cv_path_SED="$ac_path_SED"
+      ac_path_SED_max=$ac_count
+    fi
+    # 10*(2^10) chars as input seems more than enough
+    test $ac_count -gt 10 && break
+  done
+  rm -f conftest.in conftest.tmp conftest.nl conftest.out;;
+esac
+
+      $ac_path_SED_found && break 3
+    done
+  done
+done
+IFS=$as_save_IFS
+  if test -z "$ac_cv_path_SED"; then
+    { { $as_echo "$as_me:$LINENO: error: no acceptable sed could be found in \$PATH" >&5
+$as_echo "$as_me: error: no acceptable sed could be found in \$PATH" >&2;}
+   { (exit 1); exit 1; }; }
+  fi
+else
+  ac_cv_path_SED=$SED
+fi
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_SED" >&5
+$as_echo "$ac_cv_path_SED" >&6; }
+ SED="$ac_cv_path_SED"
+  rm -f conftest.sed
+
+test -z "$SED" && SED=sed
+Xsed="$SED -e 1s/^X//"
+
+
+
+
+
+
+
+
+
+
+
+{ $as_echo "$as_me:$LINENO: checking for grep that handles long lines and -e" >&5
+$as_echo_n "checking for grep that handles long lines and -e... " >&6; }
+if test "${ac_cv_path_GREP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -z "$GREP"; then
+  ac_path_GREP_found=false
+  # Loop through the user's path and test for each of PROGNAME-LIST
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_prog in grep ggrep; do
+    for ac_exec_ext in '' $ac_executable_extensions; do
+      ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext"
+      { test -f "$ac_path_GREP" && $as_test_x "$ac_path_GREP"; } || continue
+# Check for GNU ac_path_GREP and select it if it is found.
+  # Check for GNU $ac_path_GREP
+case `"$ac_path_GREP" --version 2>&1` in
+*GNU*)
+  ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;;
+*)
+  ac_count=0
+  $as_echo_n 0123456789 >"conftest.in"
+  while :
+  do
+    cat "conftest.in" "conftest.in" >"conftest.tmp"
+    mv "conftest.tmp" "conftest.in"
+    cp "conftest.in" "conftest.nl"
+    $as_echo 'GREP' >> "conftest.nl"
+    "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break
+    diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break
+    ac_count=`expr $ac_count + 1`
+    if test $ac_count -gt ${ac_path_GREP_max-0}; then
+      # Best one so far, save it but keep looking for a better one
+      ac_cv_path_GREP="$ac_path_GREP"
+      ac_path_GREP_max=$ac_count
+    fi
+    # 10*(2^10) chars as input seems more than enough
+    test $ac_count -gt 10 && break
+  done
+  rm -f conftest.in conftest.tmp conftest.nl conftest.out;;
+esac
+
+      $ac_path_GREP_found && break 3
+    done
+  done
+done
+IFS=$as_save_IFS
+  if test -z "$ac_cv_path_GREP"; then
+    { { $as_echo "$as_me:$LINENO: error: no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5
+$as_echo "$as_me: error: no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;}
+   { (exit 1); exit 1; }; }
+  fi
+else
+  ac_cv_path_GREP=$GREP
+fi
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_GREP" >&5
+$as_echo "$ac_cv_path_GREP" >&6; }
+ GREP="$ac_cv_path_GREP"
+
+
+{ $as_echo "$as_me:$LINENO: checking for egrep" >&5
+$as_echo_n "checking for egrep... " >&6; }
+if test "${ac_cv_path_EGREP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if echo a | $GREP -E '(a|b)' >/dev/null 2>&1
+   then ac_cv_path_EGREP="$GREP -E"
+   else
+     if test -z "$EGREP"; then
+  ac_path_EGREP_found=false
+  # Loop through the user's path and test for each of PROGNAME-LIST
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_prog in egrep; do
+    for ac_exec_ext in '' $ac_executable_extensions; do
+      ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext"
+      { test -f "$ac_path_EGREP" && $as_test_x "$ac_path_EGREP"; } || continue
+# Check for GNU ac_path_EGREP and select it if it is found.
+  # Check for GNU $ac_path_EGREP
+case `"$ac_path_EGREP" --version 2>&1` in
+*GNU*)
+  ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;;
+*)
+  ac_count=0
+  $as_echo_n 0123456789 >"conftest.in"
+  while :
+  do
+    cat "conftest.in" "conftest.in" >"conftest.tmp"
+    mv "conftest.tmp" "conftest.in"
+    cp "conftest.in" "conftest.nl"
+    $as_echo 'EGREP' >> "conftest.nl"
+    "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break
+    diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break
+    ac_count=`expr $ac_count + 1`
+    if test $ac_count -gt ${ac_path_EGREP_max-0}; then
+      # Best one so far, save it but keep looking for a better one
+      ac_cv_path_EGREP="$ac_path_EGREP"
+      ac_path_EGREP_max=$ac_count
+    fi
+    # 10*(2^10) chars as input seems more than enough
+    test $ac_count -gt 10 && break
+  done
+  rm -f conftest.in conftest.tmp conftest.nl conftest.out;;
+esac
+
+      $ac_path_EGREP_found && break 3
+    done
+  done
+done
+IFS=$as_save_IFS
+  if test -z "$ac_cv_path_EGREP"; then
+    { { $as_echo "$as_me:$LINENO: error: no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5
+$as_echo "$as_me: error: no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;}
+   { (exit 1); exit 1; }; }
+  fi
+else
+  ac_cv_path_EGREP=$EGREP
+fi
+
+   fi
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_EGREP" >&5
+$as_echo "$ac_cv_path_EGREP" >&6; }
+ EGREP="$ac_cv_path_EGREP"
+
+
+{ $as_echo "$as_me:$LINENO: checking for fgrep" >&5
+$as_echo_n "checking for fgrep... " >&6; }
+if test "${ac_cv_path_FGREP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1
+   then ac_cv_path_FGREP="$GREP -F"
+   else
+     if test -z "$FGREP"; then
+  ac_path_FGREP_found=false
+  # Loop through the user's path and test for each of PROGNAME-LIST
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_prog in fgrep; do
+    for ac_exec_ext in '' $ac_executable_extensions; do
+      ac_path_FGREP="$as_dir/$ac_prog$ac_exec_ext"
+      { test -f "$ac_path_FGREP" && $as_test_x "$ac_path_FGREP"; } || continue
+# Check for GNU ac_path_FGREP and select it if it is found.
+  # Check for GNU $ac_path_FGREP
+case `"$ac_path_FGREP" --version 2>&1` in
+*GNU*)
+  ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;;
+*)
+  ac_count=0
+  $as_echo_n 0123456789 >"conftest.in"
+  while :
+  do
+    cat "conftest.in" "conftest.in" >"conftest.tmp"
+    mv "conftest.tmp" "conftest.in"
+    cp "conftest.in" "conftest.nl"
+    $as_echo 'FGREP' >> "conftest.nl"
+    "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break
+    diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break
+    ac_count=`expr $ac_count + 1`
+    if test $ac_count -gt ${ac_path_FGREP_max-0}; then
+      # Best one so far, save it but keep looking for a better one
+      ac_cv_path_FGREP="$ac_path_FGREP"
+      ac_path_FGREP_max=$ac_count
+    fi
+    # 10*(2^10) chars as input seems more than enough
+    test $ac_count -gt 10 && break
+  done
+  rm -f conftest.in conftest.tmp conftest.nl conftest.out;;
+esac
+
+      $ac_path_FGREP_found && break 3
+    done
+  done
+done
+IFS=$as_save_IFS
+  if test -z "$ac_cv_path_FGREP"; then
+    { { $as_echo "$as_me:$LINENO: error: no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&5
+$as_echo "$as_me: error: no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" >&2;}
+   { (exit 1); exit 1; }; }
+  fi
+else
+  ac_cv_path_FGREP=$FGREP
+fi
+
+   fi
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_path_FGREP" >&5
+$as_echo "$ac_cv_path_FGREP" >&6; }
+ FGREP="$ac_cv_path_FGREP"
+
+
+test -z "$GREP" && GREP=grep
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# Check whether --with-gnu-ld was given.
+if test "${with_gnu_ld+set}" = set; then
+  withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes
+else
+  with_gnu_ld=no
+fi
+
+ac_prog=ld
+if test "$GCC" = yes; then
+  # Check if gcc -print-prog-name=ld gives a path.
+  { $as_echo "$as_me:$LINENO: checking for ld used by $CC" >&5
+$as_echo_n "checking for ld used by $CC... " >&6; }
+  case $host in
+  *-*-mingw*)
+    # gcc leaves a trailing carriage return which upsets mingw
+    ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
+  *)
+    ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
+  esac
+  case $ac_prog in
+    # Accept absolute paths.
+    [\\/]* | ?:[\\/]*)
+      re_direlt='/[^/][^/]*/\.\./'
+      # Canonicalize the pathname of ld
+      ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'`
+      while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do
+       ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"`
+      done
+      test -z "$LD" && LD="$ac_prog"
+      ;;
+  "")
+    # If it fails, then pretend we aren't using GCC.
+    ac_prog=ld
+    ;;
+  *)
+    # If it is relative, then search for the first ld in PATH.
+    with_gnu_ld=unknown
+    ;;
+  esac
+elif test "$with_gnu_ld" = yes; then
+  { $as_echo "$as_me:$LINENO: checking for GNU ld" >&5
+$as_echo_n "checking for GNU ld... " >&6; }
+else
+  { $as_echo "$as_me:$LINENO: checking for non-GNU ld" >&5
+$as_echo_n "checking for non-GNU ld... " >&6; }
+fi
+if test "${lt_cv_path_LD+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -z "$LD"; then
+  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+  for ac_dir in $PATH; do
+    IFS="$lt_save_ifs"
+    test -z "$ac_dir" && ac_dir=.
+    if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
+      lt_cv_path_LD="$ac_dir/$ac_prog"
+      # Check to see if the program is GNU ld.  I'd rather use --version,
+      # but apparently some variants of GNU ld only accept -v.
+      # Break only if it was the GNU/non-GNU ld that we prefer.
+      case `"$lt_cv_path_LD" -v 2>&1 </dev/null` in
+      *GNU* | *'with BFD'*)
+       test "$with_gnu_ld" != no && break
+       ;;
+      *)
+       test "$with_gnu_ld" != yes && break
+       ;;
+      esac
+    fi
+  done
+  IFS="$lt_save_ifs"
+else
+  lt_cv_path_LD="$LD" # Let the user override the test with a path.
+fi
+fi
+
+LD="$lt_cv_path_LD"
+if test -n "$LD"; then
+  { $as_echo "$as_me:$LINENO: result: $LD" >&5
+$as_echo "$LD" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+test -z "$LD" && { { $as_echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5
+$as_echo "$as_me: error: no acceptable ld found in \$PATH" >&2;}
+   { (exit 1); exit 1; }; }
+{ $as_echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5
+$as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; }
+if test "${lt_cv_prog_gnu_ld+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  # I'd rather use --version here, but apparently some GNU lds only accept -v.
+case `$LD -v 2>&1 </dev/null` in
+*GNU* | *'with BFD'*)
+  lt_cv_prog_gnu_ld=yes
+  ;;
+*)
+  lt_cv_prog_gnu_ld=no
+  ;;
+esac
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_gnu_ld" >&5
+$as_echo "$lt_cv_prog_gnu_ld" >&6; }
+with_gnu_ld=$lt_cv_prog_gnu_ld
+
+
+
+
+
+
+
+
+
+{ $as_echo "$as_me:$LINENO: checking for BSD- or MS-compatible name lister (nm)" >&5
+$as_echo_n "checking for BSD- or MS-compatible name lister (nm)... " >&6; }
+if test "${lt_cv_path_NM+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$NM"; then
+  # Let the user override the test.
+  lt_cv_path_NM="$NM"
+else
+  lt_nm_to_check="${ac_tool_prefix}nm"
+  if test -n "$ac_tool_prefix" && test "$build" = "$host"; then
+    lt_nm_to_check="$lt_nm_to_check nm"
+  fi
+  for lt_tmp_nm in $lt_nm_to_check; do
+    lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+    for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do
+      IFS="$lt_save_ifs"
+      test -z "$ac_dir" && ac_dir=.
+      tmp_nm="$ac_dir/$lt_tmp_nm"
+      if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then
+       # Check to see if the nm accepts a BSD-compat flag.
+       # Adding the `sed 1q' prevents false positives on HP-UX, which says:
+       #   nm: unknown option "B" ignored
+       # Tru64's nm complains that /dev/null is an invalid object file
+       case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in
+       */dev/null* | *'Invalid file or object type'*)
+         lt_cv_path_NM="$tmp_nm -B"
+         break
+         ;;
+       *)
+         case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in
+         */dev/null*)
+           lt_cv_path_NM="$tmp_nm -p"
+           break
+           ;;
+         *)
+           lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but
+           continue # so that we can try to find one that supports BSD flags
+           ;;
+         esac
+         ;;
+       esac
+      fi
+    done
+    IFS="$lt_save_ifs"
+  done
+  : ${lt_cv_path_NM=no}
+fi
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_path_NM" >&5
+$as_echo "$lt_cv_path_NM" >&6; }
+if test "$lt_cv_path_NM" != "no"; then
+  NM="$lt_cv_path_NM"
+else
+  # Didn't find any BSD compatible name lister, look for dumpbin.
+  if test -n "$ac_tool_prefix"; then
+  for ac_prog in "dumpbin -symbols" "link -dump -symbols"
+  do
+    # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args.
+set dummy $ac_tool_prefix$ac_prog; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_DUMPBIN+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$DUMPBIN"; then
+  ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+DUMPBIN=$ac_cv_prog_DUMPBIN
+if test -n "$DUMPBIN"; then
+  { $as_echo "$as_me:$LINENO: result: $DUMPBIN" >&5
+$as_echo "$DUMPBIN" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+    test -n "$DUMPBIN" && break
+  done
+fi
+if test -z "$DUMPBIN"; then
+  ac_ct_DUMPBIN=$DUMPBIN
+  for ac_prog in "dumpbin -symbols" "link -dump -symbols"
+do
+  # Extract the first word of "$ac_prog", so it can be a program name with args.
+set dummy $ac_prog; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_DUMPBIN+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_DUMPBIN"; then
+  ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_DUMPBIN="$ac_prog"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN
+if test -n "$ac_ct_DUMPBIN"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_DUMPBIN" >&5
+$as_echo "$ac_ct_DUMPBIN" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  test -n "$ac_ct_DUMPBIN" && break
+done
+
+  if test "x$ac_ct_DUMPBIN" = x; then
+    DUMPBIN=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    DUMPBIN=$ac_ct_DUMPBIN
+  fi
+fi
+
+
+  if test "$DUMPBIN" != ":"; then
+    NM="$DUMPBIN"
+  fi
+fi
+test -z "$NM" && NM=nm
+
+
+
+
+
+
+{ $as_echo "$as_me:$LINENO: checking the name lister ($NM) interface" >&5
+$as_echo_n "checking the name lister ($NM) interface... " >&6; }
+if test "${lt_cv_nm_interface+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_nm_interface="BSD nm"
+  echo "int some_variable = 0;" > conftest.$ac_ext
+  (eval echo "\"\$as_me:5101: $ac_compile\"" >&5)
+  (eval "$ac_compile" 2>conftest.err)
+  cat conftest.err >&5
+  (eval echo "\"\$as_me:5104: $NM \\\"conftest.$ac_objext\\\"\"" >&5)
+  (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out)
+  cat conftest.err >&5
+  (eval echo "\"\$as_me:5107: output\"" >&5)
+  cat conftest.out >&5
+  if $GREP 'External.*some_variable' conftest.out > /dev/null; then
+    lt_cv_nm_interface="MS dumpbin"
+  fi
+  rm -f conftest*
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_nm_interface" >&5
+$as_echo "$lt_cv_nm_interface" >&6; }
+
+{ $as_echo "$as_me:$LINENO: checking whether ln -s works" >&5
+$as_echo_n "checking whether ln -s works... " >&6; }
+LN_S=$as_ln_s
+if test "$LN_S" = "ln -s"; then
+  { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no, using $LN_S" >&5
+$as_echo "no, using $LN_S" >&6; }
+fi
+
+# find the maximum length of command line arguments
+{ $as_echo "$as_me:$LINENO: checking the maximum length of command line arguments" >&5
+$as_echo_n "checking the maximum length of command line arguments... " >&6; }
+if test "${lt_cv_sys_max_cmd_len+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+    i=0
+  teststring="ABCD"
+
+  case $build_os in
+  msdosdjgpp*)
+    # On DJGPP, this test can blow up pretty badly due to problems in libc
+    # (any single argument exceeding 2000 bytes causes a buffer overrun
+    # during glob expansion).  Even if it were fixed, the result of this
+    # check would be larger than it should be.
+    lt_cv_sys_max_cmd_len=12288;    # 12K is about right
+    ;;
+
+  gnu*)
+    # Under GNU Hurd, this test is not required because there is
+    # no limit to the length of command line arguments.
+    # Libtool will interpret -1 as no limit whatsoever
+    lt_cv_sys_max_cmd_len=-1;
+    ;;
+
+  cygwin* | mingw* | cegcc*)
+    # On Win9x/ME, this test blows up -- it succeeds, but takes
+    # about 5 minutes as the teststring grows exponentially.
+    # Worse, since 9x/ME are not pre-emptively multitasking,
+    # you end up with a "frozen" computer, even though with patience
+    # the test eventually succeeds (with a max line length of 256k).
+    # Instead, let's just punt: use the minimum linelength reported by
+    # all of the supported platforms: 8192 (on NT/2K/XP).
+    lt_cv_sys_max_cmd_len=8192;
+    ;;
+
+  amigaos*)
+    # On AmigaOS with pdksh, this test takes hours, literally.
+    # So we just punt and use a minimum line length of 8192.
+    lt_cv_sys_max_cmd_len=8192;
+    ;;
+
+  netbsd* | freebsd* | openbsd* | darwin* | dragonfly*)
+    # This has been around since 386BSD, at least.  Likely further.
+    if test -x /sbin/sysctl; then
+      lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax`
+    elif test -x /usr/sbin/sysctl; then
+      lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax`
+    else
+      lt_cv_sys_max_cmd_len=65536      # usable default for all BSDs
+    fi
+    # And add a safety zone
+    lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4`
+    lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3`
+    ;;
+
+  interix*)
+    # We know the value 262144 and hardcode it with a safety zone (like BSD)
+    lt_cv_sys_max_cmd_len=196608
+    ;;
+
+  osf*)
+    # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure
+    # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not
+    # nice to cause kernel panics so lets avoid the loop below.
+    # First set a reasonable default.
+    lt_cv_sys_max_cmd_len=16384
+    #
+    if test -x /sbin/sysconfig; then
+      case `/sbin/sysconfig -q proc exec_disable_arg_limit` in
+        *1*) lt_cv_sys_max_cmd_len=-1 ;;
+      esac
+    fi
+    ;;
+  sco3.2v5*)
+    lt_cv_sys_max_cmd_len=102400
+    ;;
+  sysv5* | sco5v6* | sysv4.2uw2*)
+    kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null`
+    if test -n "$kargmax"; then
+      lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[         ]//'`
+    else
+      lt_cv_sys_max_cmd_len=32768
+    fi
+    ;;
+  *)
+    lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null`
+    if test -n "$lt_cv_sys_max_cmd_len"; then
+      lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4`
+      lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3`
+    else
+      # Make teststring a little bigger before we do anything with it.
+      # a 1K string should be a reasonable start.
+      for i in 1 2 3 4 5 6 7 8 ; do
+        teststring=$teststring$teststring
+      done
+      SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}}
+      # If test is not a shell built-in, we'll probably end up computing a
+      # maximum length that is only half of the actual maximum length, but
+      # we can't tell.
+      while { test "X"`$SHELL $0 --fallback-echo "X$teststring$teststring" 2>/dev/null` \
+                = "XX$teststring$teststring"; } >/dev/null 2>&1 &&
+             test $i != 17 # 1/2 MB should be enough
+      do
+        i=`expr $i + 1`
+        teststring=$teststring$teststring
+      done
+      # Only check the string length outside the loop.
+      lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1`
+      teststring=
+      # Add a significant safety factor because C++ compilers can tack on
+      # massive amounts of additional arguments before passing them to the
+      # linker.  It appears as though 1/2 is a usable value.
+      lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2`
+    fi
+    ;;
+  esac
+
+fi
+
+if test -n $lt_cv_sys_max_cmd_len ; then
+  { $as_echo "$as_me:$LINENO: result: $lt_cv_sys_max_cmd_len" >&5
+$as_echo "$lt_cv_sys_max_cmd_len" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: none" >&5
+$as_echo "none" >&6; }
+fi
+max_cmd_len=$lt_cv_sys_max_cmd_len
+
+
+
+
+
+
+: ${CP="cp -f"}
+: ${MV="mv -f"}
+: ${RM="rm -f"}
+
+{ $as_echo "$as_me:$LINENO: checking whether the shell understands some XSI constructs" >&5
+$as_echo_n "checking whether the shell understands some XSI constructs... " >&6; }
+# Try some XSI features
+xsi_shell=no
+( _lt_dummy="a/b/c"
+  test "${_lt_dummy##*/},${_lt_dummy%/*},"${_lt_dummy%"$_lt_dummy"}, \
+      = c,a/b,, \
+    && eval 'test $(( 1 + 1 )) -eq 2 \
+    && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \
+  && xsi_shell=yes
+{ $as_echo "$as_me:$LINENO: result: $xsi_shell" >&5
+$as_echo "$xsi_shell" >&6; }
+
+
+{ $as_echo "$as_me:$LINENO: checking whether the shell understands \"+=\"" >&5
+$as_echo_n "checking whether the shell understands \"+=\"... " >&6; }
+lt_shell_append=no
+( foo=bar; set foo baz; eval "$1+=\$2" && test "$foo" = barbaz ) \
+    >/dev/null 2>&1 \
+  && lt_shell_append=yes
+{ $as_echo "$as_me:$LINENO: result: $lt_shell_append" >&5
+$as_echo "$lt_shell_append" >&6; }
+
+
+if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
+  lt_unset=unset
+else
+  lt_unset=false
+fi
+
+
+
+
+
+# test EBCDIC or ASCII
+case `echo X|tr X '\101'` in
+ A) # ASCII based system
+    # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr
+  lt_SP2NL='tr \040 \012'
+  lt_NL2SP='tr \015\012 \040\040'
+  ;;
+ *) # EBCDIC based system
+  lt_SP2NL='tr \100 \n'
+  lt_NL2SP='tr \r\n \100\100'
+  ;;
+esac
+
+
+
+
+
+
+
+
+
+{ $as_echo "$as_me:$LINENO: checking for $LD option to reload object files" >&5
+$as_echo_n "checking for $LD option to reload object files... " >&6; }
+if test "${lt_cv_ld_reload_flag+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_ld_reload_flag='-r'
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_ld_reload_flag" >&5
+$as_echo "$lt_cv_ld_reload_flag" >&6; }
+reload_flag=$lt_cv_ld_reload_flag
+case $reload_flag in
+"" | " "*) ;;
+*) reload_flag=" $reload_flag" ;;
+esac
+reload_cmds='$LD$reload_flag -o $output$reload_objs'
+case $host_os in
+  darwin*)
+    if test "$GCC" = yes; then
+      reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs'
+    else
+      reload_cmds='$LD$reload_flag -o $output$reload_objs'
+    fi
+    ;;
+esac
+
+
+
+
+
+
+
+
+
+if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args.
+set dummy ${ac_tool_prefix}objdump; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_OBJDUMP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$OBJDUMP"; then
+  ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+OBJDUMP=$ac_cv_prog_OBJDUMP
+if test -n "$OBJDUMP"; then
+  { $as_echo "$as_me:$LINENO: result: $OBJDUMP" >&5
+$as_echo "$OBJDUMP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_OBJDUMP"; then
+  ac_ct_OBJDUMP=$OBJDUMP
+  # Extract the first word of "objdump", so it can be a program name with args.
+set dummy objdump; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_OBJDUMP"; then
+  ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_OBJDUMP="objdump"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP
+if test -n "$ac_ct_OBJDUMP"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_OBJDUMP" >&5
+$as_echo "$ac_ct_OBJDUMP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_OBJDUMP" = x; then
+    OBJDUMP="false"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    OBJDUMP=$ac_ct_OBJDUMP
+  fi
+else
+  OBJDUMP="$ac_cv_prog_OBJDUMP"
+fi
+
+test -z "$OBJDUMP" && OBJDUMP=objdump
+
+
+
+
+
+
+{ $as_echo "$as_me:$LINENO: checking how to recognize dependent libraries" >&5
+$as_echo_n "checking how to recognize dependent libraries... " >&6; }
+if test "${lt_cv_deplibs_check_method+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_file_magic_cmd='$MAGIC_CMD'
+lt_cv_file_magic_test_file=
+lt_cv_deplibs_check_method='unknown'
+# Need to set the preceding variable on all platforms that support
+# interlibrary dependencies.
+# 'none' -- dependencies not supported.
+# `unknown' -- same as none, but documents that we really don't know.
+# 'pass_all' -- all dependencies passed with no checks.
+# 'test_compile' -- check by making test program.
+# 'file_magic [[regex]]' -- check by looking for files in library path
+# which responds to the $file_magic_cmd with a given extended regex.
+# If you have `file' or equivalent on your system and you're not sure
+# whether `pass_all' will *always* work, you probably want this one.
+
+case $host_os in
+aix[4-9]*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+beos*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+bsdi[45]*)
+  lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)'
+  lt_cv_file_magic_cmd='/usr/bin/file -L'
+  lt_cv_file_magic_test_file=/shlib/libc.so
+  ;;
+
+cygwin*)
+  # func_win32_libid is a shell function defined in ltmain.sh
+  lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
+  lt_cv_file_magic_cmd='func_win32_libid'
+  ;;
+
+mingw* | pw32*)
+  # Base MSYS/MinGW do not provide the 'file' command needed by
+  # func_win32_libid shell function, so use a weaker test based on 'objdump',
+  # unless we find 'file', for example because we are cross-compiling.
+  if ( file / ) >/dev/null 2>&1; then
+    lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
+    lt_cv_file_magic_cmd='func_win32_libid'
+  else
+    lt_cv_deplibs_check_method='file_magic file format pei*-i386(.*architecture: i386)?'
+    lt_cv_file_magic_cmd='$OBJDUMP -f'
+  fi
+  ;;
+
+cegcc)
+  # use the weaker test based on 'objdump'. See mingw*.
+  lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?'
+  lt_cv_file_magic_cmd='$OBJDUMP -f'
+  ;;
+
+darwin* | rhapsody*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+freebsd* | dragonfly*)
+  if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then
+    case $host_cpu in
+    i*86 )
+      # Not sure whether the presence of OpenBSD here was a mistake.
+      # Let's accept both of them until this is cleared up.
+      lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library'
+      lt_cv_file_magic_cmd=/usr/bin/file
+      lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*`
+      ;;
+    esac
+  else
+    lt_cv_deplibs_check_method=pass_all
+  fi
+  ;;
+
+gnu*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+hpux10.20* | hpux11*)
+  lt_cv_file_magic_cmd=/usr/bin/file
+  case $host_cpu in
+  ia64*)
+    lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64'
+    lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so
+    ;;
+  hppa*64*)
+    lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]'
+    lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl
+    ;;
+  *)
+    lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9].[0-9]) shared library'
+    lt_cv_file_magic_test_file=/usr/lib/libc.sl
+    ;;
+  esac
+  ;;
+
+interix[3-9]*)
+  # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here
+  lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$'
+  ;;
+
+irix5* | irix6* | nonstopux*)
+  case $LD in
+  *-32|*"-32 ") libmagic=32-bit;;
+  *-n32|*"-n32 ") libmagic=N32;;
+  *-64|*"-64 ") libmagic=64-bit;;
+  *) libmagic=never-match;;
+  esac
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+# This must be Linux ELF.
+linux* | k*bsd*-gnu)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+netbsd*)
+  if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then
+    lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$'
+  else
+    lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$'
+  fi
+  ;;
+
+newos6*)
+  lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)'
+  lt_cv_file_magic_cmd=/usr/bin/file
+  lt_cv_file_magic_test_file=/usr/lib/libnls.so
+  ;;
+
+*nto* | *qnx*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+openbsd*)
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+    lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$'
+  else
+    lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$'
+  fi
+  ;;
+
+osf3* | osf4* | osf5*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+rdos*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+solaris*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+
+sysv4 | sysv4.3*)
+  case $host_vendor in
+  motorola)
+    lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]'
+    lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*`
+    ;;
+  ncr)
+    lt_cv_deplibs_check_method=pass_all
+    ;;
+  sequent)
+    lt_cv_file_magic_cmd='/bin/file'
+    lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )'
+    ;;
+  sni)
+    lt_cv_file_magic_cmd='/bin/file'
+    lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib"
+    lt_cv_file_magic_test_file=/lib/libc.so
+    ;;
+  siemens)
+    lt_cv_deplibs_check_method=pass_all
+    ;;
+  pc)
+    lt_cv_deplibs_check_method=pass_all
+    ;;
+  esac
+  ;;
+
+tpf*)
+  lt_cv_deplibs_check_method=pass_all
+  ;;
+esac
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_deplibs_check_method" >&5
+$as_echo "$lt_cv_deplibs_check_method" >&6; }
+file_magic_cmd=$lt_cv_file_magic_cmd
+deplibs_check_method=$lt_cv_deplibs_check_method
+test -z "$deplibs_check_method" && deplibs_check_method=unknown
+
+
+
+
+
+
+
+
+
+
+
+
+if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}ar", so it can be a program name with args.
+set dummy ${ac_tool_prefix}ar; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_AR+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$AR"; then
+  ac_cv_prog_AR="$AR" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_AR="${ac_tool_prefix}ar"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+AR=$ac_cv_prog_AR
+if test -n "$AR"; then
+  { $as_echo "$as_me:$LINENO: result: $AR" >&5
+$as_echo "$AR" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_AR"; then
+  ac_ct_AR=$AR
+  # Extract the first word of "ar", so it can be a program name with args.
+set dummy ar; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_AR+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_AR"; then
+  ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_AR="ar"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_AR=$ac_cv_prog_ac_ct_AR
+if test -n "$ac_ct_AR"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_AR" >&5
+$as_echo "$ac_ct_AR" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_AR" = x; then
+    AR="false"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    AR=$ac_ct_AR
+  fi
+else
+  AR="$ac_cv_prog_AR"
+fi
+
+test -z "$AR" && AR=ar
+test -z "$AR_FLAGS" && AR_FLAGS=cru
+
+
+
+
+
+
+
+
+
+
+
+if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args.
+set dummy ${ac_tool_prefix}strip; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_STRIP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$STRIP"; then
+  ac_cv_prog_STRIP="$STRIP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_STRIP="${ac_tool_prefix}strip"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+STRIP=$ac_cv_prog_STRIP
+if test -n "$STRIP"; then
+  { $as_echo "$as_me:$LINENO: result: $STRIP" >&5
+$as_echo "$STRIP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_STRIP"; then
+  ac_ct_STRIP=$STRIP
+  # Extract the first word of "strip", so it can be a program name with args.
+set dummy strip; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_STRIP"; then
+  ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_STRIP="strip"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP
+if test -n "$ac_ct_STRIP"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5
+$as_echo "$ac_ct_STRIP" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_STRIP" = x; then
+    STRIP=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    STRIP=$ac_ct_STRIP
+  fi
+else
+  STRIP="$ac_cv_prog_STRIP"
+fi
+
+test -z "$STRIP" && STRIP=:
+
+
+
+
+
+
+if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args.
+set dummy ${ac_tool_prefix}ranlib; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_RANLIB+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$RANLIB"; then
+  ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+RANLIB=$ac_cv_prog_RANLIB
+if test -n "$RANLIB"; then
+  { $as_echo "$as_me:$LINENO: result: $RANLIB" >&5
+$as_echo "$RANLIB" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_RANLIB"; then
+  ac_ct_RANLIB=$RANLIB
+  # Extract the first word of "ranlib", so it can be a program name with args.
+set dummy ranlib; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_RANLIB+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_RANLIB"; then
+  ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_RANLIB="ranlib"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB
+if test -n "$ac_ct_RANLIB"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_RANLIB" >&5
+$as_echo "$ac_ct_RANLIB" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_RANLIB" = x; then
+    RANLIB=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    RANLIB=$ac_ct_RANLIB
+  fi
+else
+  RANLIB="$ac_cv_prog_RANLIB"
+fi
+
+test -z "$RANLIB" && RANLIB=:
+
+
+
+
+
+
+# Determine commands to create old-style static archives.
+old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs'
+old_postinstall_cmds='chmod 644 $oldlib'
+old_postuninstall_cmds=
+
+if test -n "$RANLIB"; then
+  case $host_os in
+  openbsd*)
+    old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$oldlib"
+    ;;
+  *)
+    old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$oldlib"
+    ;;
+  esac
+  old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib"
+fi
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# If no C compiler was specified, use CC.
+LTCC=${LTCC-"$CC"}
+
+# If no C compiler flags were specified, use CFLAGS.
+LTCFLAGS=${LTCFLAGS-"$CFLAGS"}
+
+# Allow CC to be a program name with arguments.
+compiler=$CC
+
+
+# Check for command to grab the raw symbol name followed by C symbol from nm.
+{ $as_echo "$as_me:$LINENO: checking command to parse $NM output from $compiler object" >&5
+$as_echo_n "checking command to parse $NM output from $compiler object... " >&6; }
+if test "${lt_cv_sys_global_symbol_pipe+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+
+# These are sane defaults that work on at least a few old systems.
+# [They come from Ultrix.  What could be older than Ultrix?!! ;)]
+
+# Character class describing NM global symbol codes.
+symcode='[BCDEGRST]'
+
+# Regexp to match symbols that can be accessed directly from C.
+sympat='\([_A-Za-z][_A-Za-z0-9]*\)'
+
+# Define system-specific variables.
+case $host_os in
+aix*)
+  symcode='[BCDT]'
+  ;;
+cygwin* | mingw* | pw32* | cegcc*)
+  symcode='[ABCDGISTW]'
+  ;;
+hpux*)
+  if test "$host_cpu" = ia64; then
+    symcode='[ABCDEGRST]'
+  fi
+  ;;
+irix* | nonstopux*)
+  symcode='[BCDEGRST]'
+  ;;
+osf*)
+  symcode='[BCDEGQRST]'
+  ;;
+solaris*)
+  symcode='[BDRT]'
+  ;;
+sco3.2v5*)
+  symcode='[DT]'
+  ;;
+sysv4.2uw2*)
+  symcode='[DT]'
+  ;;
+sysv5* | sco5v6* | unixware* | OpenUNIX*)
+  symcode='[ABDT]'
+  ;;
+sysv4)
+  symcode='[DFNSTU]'
+  ;;
+esac
+
+# If we're using GNU nm, then use its standard symbol codes.
+case `$NM -V 2>&1` in
+*GNU* | *'with BFD'*)
+  symcode='[ABCDGIRSTW]' ;;
+esac
+
+# Transform an extracted symbol line into a proper C declaration.
+# Some systems (esp. on ia64) link data and code symbols differently,
+# so use this general approach.
+lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'"
+
+# Transform an extracted symbol line into symbol name and symbol address
+lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([^ ]*\) $/  {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/  {\"\2\", (void *) \&\2},/p'"
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([^ ]*\) $/  {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \(lib[^ ]*\)$/  {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/  {\"lib\2\", (void *) \&\2},/p'"
+
+# Handle CRLF in mingw tool chain
+opt_cr=
+case $build_os in
+mingw*)
+  opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp
+  ;;
+esac
+
+# Try without a prefix underscore, then with it.
+for ac_symprfx in "" "_"; do
+
+  # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol.
+  symxfrm="\\1 $ac_symprfx\\2 \\2"
+
+  # Write the raw and C identifiers.
+  if test "$lt_cv_nm_interface" = "MS dumpbin"; then
+    # Fake it for dumpbin and say T for any non-static function
+    # and D for any global variable.
+    # Also find C++ and __fastcall symbols from MSVC++,
+    # which start with @ or ?.
+    lt_cv_sys_global_symbol_pipe="$AWK '"\
+"     {last_section=section; section=\$ 3};"\
+"     /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\
+"     \$ 0!~/External *\|/{next};"\
+"     / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\
+"     {if(hide[section]) next};"\
+"     {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\
+"     {split(\$ 0, a, /\||\r/); split(a[2], s)};"\
+"     s[1]~/^[@?]/{print s[1], s[1]; next};"\
+"     s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\
+"     ' prfx=^$ac_symprfx"
+  else
+    lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[     ]\($symcode$symcode*\)[         ][      ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'"
+  fi
+
+  # Check to see that the pipe works correctly.
+  pipe_works=no
+
+  rm -f conftest*
+  cat > conftest.$ac_ext <<_LT_EOF
+#ifdef __cplusplus
+extern "C" {
+#endif
+char nm_test_var;
+void nm_test_func(void);
+void nm_test_func(void){}
+#ifdef __cplusplus
+}
+#endif
+int main(){nm_test_var='a';nm_test_func();return(0);}
+_LT_EOF
+
+  if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
+  (eval $ac_compile) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+    # Now try to grab the symbols.
+    nlist=conftest.nm
+    if { (eval echo "$as_me:$LINENO: \"$NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist\"") >&5
+  (eval $NM conftest.$ac_objext \| $lt_cv_sys_global_symbol_pipe \> $nlist) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && test -s "$nlist"; then
+      # Try sorting and uniquifying the output.
+      if sort "$nlist" | uniq > "$nlist"T; then
+       mv -f "$nlist"T "$nlist"
+      else
+       rm -f "$nlist"T
+      fi
+
+      # Make sure that we snagged all the symbols we need.
+      if $GREP ' nm_test_var$' "$nlist" >/dev/null; then
+       if $GREP ' nm_test_func$' "$nlist" >/dev/null; then
+         cat <<_LT_EOF > conftest.$ac_ext
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+_LT_EOF
+         # Now generate the symbol file.
+         eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext'
+
+         cat <<_LT_EOF >> conftest.$ac_ext
+
+/* The mapping between symbol names and symbols.  */
+const struct {
+  const char *name;
+  void       *address;
+}
+lt__PROGRAM__LTX_preloaded_symbols[] =
+{
+  { "@PROGRAM@", (void *) 0 },
+_LT_EOF
+         $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/  {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
+         cat <<\_LT_EOF >> conftest.$ac_ext
+  {0, (void *) 0}
+};
+
+/* This works around a problem in FreeBSD linker */
+#ifdef FREEBSD_WORKAROUND
+static const void *lt_preloaded_setup() {
+  return lt__PROGRAM__LTX_preloaded_symbols;
+}
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+_LT_EOF
+         # Now try linking the two files.
+         mv conftest.$ac_objext conftstm.$ac_objext
+         lt_save_LIBS="$LIBS"
+         lt_save_CFLAGS="$CFLAGS"
+         LIBS="conftstm.$ac_objext"
+         CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag"
+         if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5
+  (eval $ac_link) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && test -s conftest${ac_exeext}; then
+           pipe_works=yes
+         fi
+         LIBS="$lt_save_LIBS"
+         CFLAGS="$lt_save_CFLAGS"
+       else
+         echo "cannot find nm_test_func in $nlist" >&5
+       fi
+      else
+       echo "cannot find nm_test_var in $nlist" >&5
+      fi
+    else
+      echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5
+    fi
+  else
+    echo "$progname: failed program was:" >&5
+    cat conftest.$ac_ext >&5
+  fi
+  rm -rf conftest* conftst*
+
+  # Do not use the global_symbol_pipe unless it works.
+  if test "$pipe_works" = yes; then
+    break
+  else
+    lt_cv_sys_global_symbol_pipe=
+  fi
+done
+
+fi
+
+if test -z "$lt_cv_sys_global_symbol_pipe"; then
+  lt_cv_sys_global_symbol_to_cdecl=
+fi
+if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then
+  { $as_echo "$as_me:$LINENO: result: failed" >&5
+$as_echo "failed" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: ok" >&5
+$as_echo "ok" >&6; }
+fi
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# Check whether --enable-libtool-lock was given.
+if test "${enable_libtool_lock+set}" = set; then
+  enableval=$enable_libtool_lock;
+fi
+
+test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes
+
+# Some flags need to be propagated to the compiler or linker for good
+# libtool support.
+case $host in
+ia64-*-hpux*)
+  # Find out which ABI we are using.
+  echo 'int i;' > conftest.$ac_ext
+  if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
+  (eval $ac_compile) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+    case `/usr/bin/file conftest.$ac_objext` in
+      *ELF-32*)
+       HPUX_IA64_MODE="32"
+       ;;
+      *ELF-64*)
+       HPUX_IA64_MODE="64"
+       ;;
+    esac
+  fi
+  rm -rf conftest*
+  ;;
+*-*-irix6*)
+  # Find out which ABI we are using.
+  echo '#line 6310 "configure"' > conftest.$ac_ext
+  if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
+  (eval $ac_compile) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+    if test "$lt_cv_prog_gnu_ld" = yes; then
+      case `/usr/bin/file conftest.$ac_objext` in
+       *32-bit*)
+         LD="${LD-ld} -melf32bsmip"
+         ;;
+       *N32*)
+         LD="${LD-ld} -melf32bmipn32"
+         ;;
+       *64-bit*)
+         LD="${LD-ld} -melf64bmip"
+       ;;
+      esac
+    else
+      case `/usr/bin/file conftest.$ac_objext` in
+       *32-bit*)
+         LD="${LD-ld} -32"
+         ;;
+       *N32*)
+         LD="${LD-ld} -n32"
+         ;;
+       *64-bit*)
+         LD="${LD-ld} -64"
+         ;;
+      esac
+    fi
+  fi
+  rm -rf conftest*
+  ;;
+
+x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \
+s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
+  # Find out which ABI we are using.
+  echo 'int i;' > conftest.$ac_ext
+  if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
+  (eval $ac_compile) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+    case `/usr/bin/file conftest.o` in
+      *32-bit*)
+       case $host in
+         x86_64-*kfreebsd*-gnu)
+           LD="${LD-ld} -m elf_i386_fbsd"
+           ;;
+         x86_64-*linux*)
+           LD="${LD-ld} -m elf_i386"
+           ;;
+         ppc64-*linux*|powerpc64-*linux*)
+           LD="${LD-ld} -m elf32ppclinux"
+           ;;
+         s390x-*linux*)
+           LD="${LD-ld} -m elf_s390"
+           ;;
+         sparc64-*linux*)
+           LD="${LD-ld} -m elf32_sparc"
+           ;;
+       esac
+       ;;
+      *64-bit*)
+       case $host in
+         x86_64-*kfreebsd*-gnu)
+           LD="${LD-ld} -m elf_x86_64_fbsd"
+           ;;
+         x86_64-*linux*)
+           LD="${LD-ld} -m elf_x86_64"
+           ;;
+         ppc*-*linux*|powerpc*-*linux*)
+           LD="${LD-ld} -m elf64ppc"
+           ;;
+         s390*-*linux*|s390*-*tpf*)
+           LD="${LD-ld} -m elf64_s390"
+           ;;
+         sparc*-*linux*)
+           LD="${LD-ld} -m elf64_sparc"
+           ;;
+       esac
+       ;;
+    esac
+  fi
+  rm -rf conftest*
+  ;;
+
+*-*-sco3.2v5*)
+  # On SCO OpenServer 5, we need -belf to get full-featured binaries.
+  SAVE_CFLAGS="$CFLAGS"
+  CFLAGS="$CFLAGS -belf"
+  { $as_echo "$as_me:$LINENO: checking whether the C compiler needs -belf" >&5
+$as_echo_n "checking whether the C compiler needs -belf... " >&6; }
+if test "${lt_cv_cc_needs_belf+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
+     cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  lt_cv_cc_needs_belf=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       lt_cv_cc_needs_belf=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+     ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_cc_needs_belf" >&5
+$as_echo "$lt_cv_cc_needs_belf" >&6; }
+  if test x"$lt_cv_cc_needs_belf" != x"yes"; then
+    # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
+    CFLAGS="$SAVE_CFLAGS"
+  fi
+  ;;
+sparc*-*solaris*)
+  # Find out which ABI we are using.
+  echo 'int i;' > conftest.$ac_ext
+  if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
+  (eval $ac_compile) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+    case `/usr/bin/file conftest.o` in
+    *64-bit*)
+      case $lt_cv_prog_gnu_ld in
+      yes*) LD="${LD-ld} -m elf64_sparc" ;;
+      *)
+       if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then
+         LD="${LD-ld} -64"
+       fi
+       ;;
+      esac
+      ;;
+    esac
+  fi
+  rm -rf conftest*
+  ;;
+esac
+
+need_locks="$enable_libtool_lock"
+
+
+  case $host_os in
+    rhapsody* | darwin*)
+    if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args.
+set dummy ${ac_tool_prefix}dsymutil; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_DSYMUTIL+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$DSYMUTIL"; then
+  ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+DSYMUTIL=$ac_cv_prog_DSYMUTIL
+if test -n "$DSYMUTIL"; then
+  { $as_echo "$as_me:$LINENO: result: $DSYMUTIL" >&5
+$as_echo "$DSYMUTIL" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_DSYMUTIL"; then
+  ac_ct_DSYMUTIL=$DSYMUTIL
+  # Extract the first word of "dsymutil", so it can be a program name with args.
+set dummy dsymutil; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_DSYMUTIL+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_DSYMUTIL"; then
+  ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_DSYMUTIL="dsymutil"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL
+if test -n "$ac_ct_DSYMUTIL"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_DSYMUTIL" >&5
+$as_echo "$ac_ct_DSYMUTIL" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_DSYMUTIL" = x; then
+    DSYMUTIL=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    DSYMUTIL=$ac_ct_DSYMUTIL
+  fi
+else
+  DSYMUTIL="$ac_cv_prog_DSYMUTIL"
+fi
+
+    if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args.
+set dummy ${ac_tool_prefix}nmedit; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_NMEDIT+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$NMEDIT"; then
+  ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+NMEDIT=$ac_cv_prog_NMEDIT
+if test -n "$NMEDIT"; then
+  { $as_echo "$as_me:$LINENO: result: $NMEDIT" >&5
+$as_echo "$NMEDIT" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_NMEDIT"; then
+  ac_ct_NMEDIT=$NMEDIT
+  # Extract the first word of "nmedit", so it can be a program name with args.
+set dummy nmedit; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_NMEDIT+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_NMEDIT"; then
+  ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_NMEDIT="nmedit"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT
+if test -n "$ac_ct_NMEDIT"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_NMEDIT" >&5
+$as_echo "$ac_ct_NMEDIT" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_NMEDIT" = x; then
+    NMEDIT=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    NMEDIT=$ac_ct_NMEDIT
+  fi
+else
+  NMEDIT="$ac_cv_prog_NMEDIT"
+fi
+
+    if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args.
+set dummy ${ac_tool_prefix}lipo; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_LIPO+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$LIPO"; then
+  ac_cv_prog_LIPO="$LIPO" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_LIPO="${ac_tool_prefix}lipo"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+LIPO=$ac_cv_prog_LIPO
+if test -n "$LIPO"; then
+  { $as_echo "$as_me:$LINENO: result: $LIPO" >&5
+$as_echo "$LIPO" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_LIPO"; then
+  ac_ct_LIPO=$LIPO
+  # Extract the first word of "lipo", so it can be a program name with args.
+set dummy lipo; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_LIPO+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_LIPO"; then
+  ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_LIPO="lipo"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO
+if test -n "$ac_ct_LIPO"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_LIPO" >&5
+$as_echo "$ac_ct_LIPO" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_LIPO" = x; then
+    LIPO=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    LIPO=$ac_ct_LIPO
+  fi
+else
+  LIPO="$ac_cv_prog_LIPO"
+fi
+
+    if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args.
+set dummy ${ac_tool_prefix}otool; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_OTOOL+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$OTOOL"; then
+  ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_OTOOL="${ac_tool_prefix}otool"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+OTOOL=$ac_cv_prog_OTOOL
+if test -n "$OTOOL"; then
+  { $as_echo "$as_me:$LINENO: result: $OTOOL" >&5
+$as_echo "$OTOOL" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_OTOOL"; then
+  ac_ct_OTOOL=$OTOOL
+  # Extract the first word of "otool", so it can be a program name with args.
+set dummy otool; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_OTOOL+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_OTOOL"; then
+  ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_OTOOL="otool"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL
+if test -n "$ac_ct_OTOOL"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_OTOOL" >&5
+$as_echo "$ac_ct_OTOOL" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_OTOOL" = x; then
+    OTOOL=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    OTOOL=$ac_ct_OTOOL
+  fi
+else
+  OTOOL="$ac_cv_prog_OTOOL"
+fi
+
+    if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args.
+set dummy ${ac_tool_prefix}otool64; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_OTOOL64+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$OTOOL64"; then
+  ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+OTOOL64=$ac_cv_prog_OTOOL64
+if test -n "$OTOOL64"; then
+  { $as_echo "$as_me:$LINENO: result: $OTOOL64" >&5
+$as_echo "$OTOOL64" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_OTOOL64"; then
+  ac_ct_OTOOL64=$OTOOL64
+  # Extract the first word of "otool64", so it can be a program name with args.
+set dummy otool64; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_ac_ct_OTOOL64+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$ac_ct_OTOOL64"; then
+  ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_ac_ct_OTOOL64="otool64"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64
+if test -n "$ac_ct_OTOOL64"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_ct_OTOOL64" >&5
+$as_echo "$ac_ct_OTOOL64" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_ct_OTOOL64" = x; then
+    OTOOL64=":"
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    OTOOL64=$ac_ct_OTOOL64
+  fi
+else
+  OTOOL64="$ac_cv_prog_OTOOL64"
+fi
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+    { $as_echo "$as_me:$LINENO: checking for -single_module linker flag" >&5
+$as_echo_n "checking for -single_module linker flag... " >&6; }
+if test "${lt_cv_apple_cc_single_mod+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_apple_cc_single_mod=no
+      if test -z "${LT_MULTI_MODULE}"; then
+       # By default we will add the -single_module flag. You can override
+       # by either setting the environment variable LT_MULTI_MODULE
+       # non-empty at configure time, or by adding -multi_module to the
+       # link flags.
+       rm -rf libconftest.dylib*
+       echo "int foo(void){return 1;}" > conftest.c
+       echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \
+-dynamiclib -Wl,-single_module conftest.c" >&5
+       $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \
+         -dynamiclib -Wl,-single_module conftest.c 2>conftest.err
+        _lt_result=$?
+       if test -f libconftest.dylib && test ! -s conftest.err && test $_lt_result = 0; then
+         lt_cv_apple_cc_single_mod=yes
+       else
+         cat conftest.err >&5
+       fi
+       rm -rf libconftest.dylib*
+       rm -f conftest.*
+      fi
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_apple_cc_single_mod" >&5
+$as_echo "$lt_cv_apple_cc_single_mod" >&6; }
+    { $as_echo "$as_me:$LINENO: checking for -exported_symbols_list linker flag" >&5
+$as_echo_n "checking for -exported_symbols_list linker flag... " >&6; }
+if test "${lt_cv_ld_exported_symbols_list+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_ld_exported_symbols_list=no
+      save_LDFLAGS=$LDFLAGS
+      echo "_main" > conftest.sym
+      LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym"
+      cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  lt_cv_ld_exported_symbols_list=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       lt_cv_ld_exported_symbols_list=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+       LDFLAGS="$save_LDFLAGS"
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_ld_exported_symbols_list" >&5
+$as_echo "$lt_cv_ld_exported_symbols_list" >&6; }
+    case $host_os in
+    rhapsody* | darwin1.[012])
+      _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;;
+    darwin1.*)
+      _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+    darwin*) # darwin 5.x on
+      # if running on 10.5 or later, the deployment target defaults
+      # to the OS version, if on x86, and 10.4, the deployment
+      # target defaults to 10.4. Don't you love it?
+      case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in
+       10.0,*86*-darwin8*|10.0,*-darwin[91]*)
+         _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+       10.[012]*)
+         _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+       10.*)
+         _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+      esac
+    ;;
+  esac
+    if test "$lt_cv_apple_cc_single_mod" = "yes"; then
+      _lt_dar_single_mod='$single_module'
+    fi
+    if test "$lt_cv_ld_exported_symbols_list" = "yes"; then
+      _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym'
+    else
+      _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}'
+    fi
+    if test "$DSYMUTIL" != ":"; then
+      _lt_dsymutil='~$DSYMUTIL $lib || :'
+    else
+      _lt_dsymutil=
+    fi
+    ;;
+  esac
+
+
+{ $as_echo "$as_me:$LINENO: checking for ANSI C header files" >&5
+$as_echo_n "checking for ANSI C header files... " >&6; }
+if test "${ac_cv_header_stdc+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <stdlib.h>
+#include <stdarg.h>
+#include <string.h>
+#include <float.h>
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  ac_cv_header_stdc=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_header_stdc=no
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+
+if test $ac_cv_header_stdc = yes; then
+  # SunOS 4.x string.h does not declare mem*, contrary to ANSI.
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <string.h>
+
+_ACEOF
+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 |
+  $EGREP "memchr" >/dev/null 2>&1; then
+  :
+else
+  ac_cv_header_stdc=no
+fi
+rm -f conftest*
+
+fi
+
+if test $ac_cv_header_stdc = yes; then
+  # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI.
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <stdlib.h>
+
+_ACEOF
+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 |
+  $EGREP "free" >/dev/null 2>&1; then
+  :
+else
+  ac_cv_header_stdc=no
+fi
+rm -f conftest*
+
+fi
+
+if test $ac_cv_header_stdc = yes; then
+  # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi.
+  if test "$cross_compiling" = yes; then
+  :
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <ctype.h>
+#include <stdlib.h>
+#if ((' ' & 0x0FF) == 0x020)
+# define ISLOWER(c) ('a' <= (c) && (c) <= 'z')
+# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c))
+#else
+# define ISLOWER(c) \
+                  (('a' <= (c) && (c) <= 'i') \
+                    || ('j' <= (c) && (c) <= 'r') \
+                    || ('s' <= (c) && (c) <= 'z'))
+# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c))
+#endif
+
+#define XOR(e, f) (((e) && !(f)) || (!(e) && (f)))
+int
+main ()
+{
+  int i;
+  for (i = 0; i < 256; i++)
+    if (XOR (islower (i), ISLOWER (i))
+       || toupper (i) != TOUPPER (i))
+      return 2;
+  return 0;
+}
+_ACEOF
+rm -f conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && { ac_try='./conftest$ac_exeext'
+  { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; }; then
+  :
+else
+  $as_echo "$as_me: program exited with status $ac_status" >&5
+$as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+( exit $ac_status )
+ac_cv_header_stdc=no
+fi
+rm -rf conftest.dSYM
+rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext
+fi
+
+
+fi
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_header_stdc" >&5
+$as_echo "$ac_cv_header_stdc" >&6; }
+if test $ac_cv_header_stdc = yes; then
+
+cat >>confdefs.h <<\_ACEOF
+#define STDC_HEADERS 1
+_ACEOF
+
+fi
+
+# On IRIX 5.3, sys/types and inttypes.h are conflicting.
+
+
+
+
+
+
+
+
+
+for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \
+                 inttypes.h stdint.h unistd.h
+do
+as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
+{ $as_echo "$as_me:$LINENO: checking for $ac_header" >&5
+$as_echo_n "checking for $ac_header... " >&6; }
+if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+$ac_includes_default
+
+#include <$ac_header>
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  eval "$as_ac_Header=yes"
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       eval "$as_ac_Header=no"
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+fi
+ac_res=`eval 'as_val=${'$as_ac_Header'}
+                $as_echo "$as_val"'`
+              { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
+$as_echo "$ac_res" >&6; }
+as_val=`eval 'as_val=${'$as_ac_Header'}
+                $as_echo "$as_val"'`
+   if test "x$as_val" = x""yes; then
+  cat >>confdefs.h <<_ACEOF
+#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
+_ACEOF
+
+fi
+
+done
+
+
+
+for ac_header in dlfcn.h
+do
+as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
+{ $as_echo "$as_me:$LINENO: checking for $ac_header" >&5
+$as_echo_n "checking for $ac_header... " >&6; }
+if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+$ac_includes_default
+
+#include <$ac_header>
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  eval "$as_ac_Header=yes"
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       eval "$as_ac_Header=no"
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+fi
+ac_res=`eval 'as_val=${'$as_ac_Header'}
+                $as_echo "$as_val"'`
+              { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
+$as_echo "$ac_res" >&6; }
+as_val=`eval 'as_val=${'$as_ac_Header'}
+                $as_echo "$as_val"'`
+   if test "x$as_val" = x""yes; then
+  cat >>confdefs.h <<_ACEOF
+#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
+_ACEOF
+
+fi
+
+done
+
+
+
+# Set options
+
+
+
+        enable_dlopen=no
+
+
+
+            # Check whether --enable-shared was given.
+if test "${enable_shared+set}" = set; then
+  enableval=$enable_shared; p=${PACKAGE-default}
+    case $enableval in
+    yes) enable_shared=yes ;;
+    no) enable_shared=no ;;
+    *)
+      enable_shared=no
+      # Look at the argument we got.  We use all the common list separators.
+      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      for pkg in $enableval; do
+       IFS="$lt_save_ifs"
+       if test "X$pkg" = "X$p"; then
+         enable_shared=yes
+       fi
+      done
+      IFS="$lt_save_ifs"
+      ;;
+    esac
+else
+  enable_shared=yes
+fi
+
+
+
+
+
+
+
+
+
+  # Check whether --enable-static was given.
+if test "${enable_static+set}" = set; then
+  enableval=$enable_static; p=${PACKAGE-default}
+    case $enableval in
+    yes) enable_static=yes ;;
+    no) enable_static=no ;;
+    *)
+     enable_static=no
+      # Look at the argument we got.  We use all the common list separators.
+      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      for pkg in $enableval; do
+       IFS="$lt_save_ifs"
+       if test "X$pkg" = "X$p"; then
+         enable_static=yes
+       fi
+      done
+      IFS="$lt_save_ifs"
+      ;;
+    esac
+else
+  enable_static=yes
+fi
+
+
+
+
+
+
+
+
+
+
+# Check whether --with-pic was given.
+if test "${with_pic+set}" = set; then
+  withval=$with_pic; pic_mode="$withval"
+else
+  pic_mode=default
+fi
+
+
+test -z "$pic_mode" && pic_mode=default
+
+
+
+
+
+
+
+  # Check whether --enable-fast-install was given.
+if test "${enable_fast_install+set}" = set; then
+  enableval=$enable_fast_install; p=${PACKAGE-default}
+    case $enableval in
+    yes) enable_fast_install=yes ;;
+    no) enable_fast_install=no ;;
+    *)
+      enable_fast_install=no
+      # Look at the argument we got.  We use all the common list separators.
+      lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+      for pkg in $enableval; do
+       IFS="$lt_save_ifs"
+       if test "X$pkg" = "X$p"; then
+         enable_fast_install=yes
+       fi
+      done
+      IFS="$lt_save_ifs"
+      ;;
+    esac
+else
+  enable_fast_install=yes
+fi
+
+
+
+
+
+
+
+
+
+
+
+# This can be used to rebuild libtool when needed
+LIBTOOL_DEPS="$ltmain"
+
+# Always use our own libtool.
+LIBTOOL='$(SHELL) $(top_builddir)/libtool'
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+test -z "$LN_S" && LN_S="ln -s"
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+if test -n "${ZSH_VERSION+set}" ; then
+   setopt NO_GLOB_SUBST
+fi
+
+{ $as_echo "$as_me:$LINENO: checking for objdir" >&5
+$as_echo_n "checking for objdir... " >&6; }
+if test "${lt_cv_objdir+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  rm -f .libs 2>/dev/null
+mkdir .libs 2>/dev/null
+if test -d .libs; then
+  lt_cv_objdir=.libs
+else
+  # MS-DOS does not allow filenames that begin with a dot.
+  lt_cv_objdir=_libs
+fi
+rmdir .libs 2>/dev/null
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_objdir" >&5
+$as_echo "$lt_cv_objdir" >&6; }
+objdir=$lt_cv_objdir
+
+
+
+
+
+cat >>confdefs.h <<_ACEOF
+#define LT_OBJDIR "$lt_cv_objdir/"
+_ACEOF
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+case $host_os in
+aix3*)
+  # AIX sometimes has problems with the GCC collect2 program.  For some
+  # reason, if we set the COLLECT_NAMES environment variable, the problems
+  # vanish in a puff of smoke.
+  if test "X${COLLECT_NAMES+set}" != Xset; then
+    COLLECT_NAMES=
+    export COLLECT_NAMES
+  fi
+  ;;
+esac
+
+# Sed substitution that helps us do robust quoting.  It backslashifies
+# metacharacters that are still active within double-quoted strings.
+sed_quote_subst='s/\(["`$\\]\)/\\\1/g'
+
+# Same as above, but do not quote variable references.
+double_quote_subst='s/\(["`\\]\)/\\\1/g'
+
+# Sed substitution to delay expansion of an escaped shell variable in a
+# double_quote_subst'ed string.
+delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g'
+
+# Sed substitution to delay expansion of an escaped single quote.
+delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g'
+
+# Sed substitution to avoid accidental globbing in evaled expressions
+no_glob_subst='s/\*/\\\*/g'
+
+# Global variables:
+ofile=libtool
+can_build_shared=yes
+
+# All known linkers require a `.a' archive for static linking (except MSVC,
+# which needs '.lib').
+libext=a
+
+with_gnu_ld="$lt_cv_prog_gnu_ld"
+
+old_CC="$CC"
+old_CFLAGS="$CFLAGS"
+
+# Set sane defaults for various variables
+test -z "$CC" && CC=cc
+test -z "$LTCC" && LTCC=$CC
+test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS
+test -z "$LD" && LD=ld
+test -z "$ac_objext" && ac_objext=o
+
+for cc_temp in $compiler""; do
+  case $cc_temp in
+    compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
+    distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
+    \-*) ;;
+    *) break;;
+  esac
+done
+cc_basename=`$ECHO "X$cc_temp" | $Xsed -e 's%.*/%%' -e "s%^$host_alias-%%"`
+
+
+# Only perform the check for file, if the check method requires it
+test -z "$MAGIC_CMD" && MAGIC_CMD=file
+case $deplibs_check_method in
+file_magic*)
+  if test "$file_magic_cmd" = '$MAGIC_CMD'; then
+    { $as_echo "$as_me:$LINENO: checking for ${ac_tool_prefix}file" >&5
+$as_echo_n "checking for ${ac_tool_prefix}file... " >&6; }
+if test "${lt_cv_path_MAGIC_CMD+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  case $MAGIC_CMD in
+[\\/*] |  ?:[\\/]*)
+  lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+  ;;
+*)
+  lt_save_MAGIC_CMD="$MAGIC_CMD"
+  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+  ac_dummy="/usr/bin$PATH_SEPARATOR$PATH"
+  for ac_dir in $ac_dummy; do
+    IFS="$lt_save_ifs"
+    test -z "$ac_dir" && ac_dir=.
+    if test -f $ac_dir/${ac_tool_prefix}file; then
+      lt_cv_path_MAGIC_CMD="$ac_dir/${ac_tool_prefix}file"
+      if test -n "$file_magic_test_file"; then
+       case $deplibs_check_method in
+       "file_magic "*)
+         file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"`
+         MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+         if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null |
+           $EGREP "$file_magic_regex" > /dev/null; then
+           :
+         else
+           cat <<_LT_EOF 1>&2
+
+*** Warning: the command libtool uses to detect shared libraries,
+*** $file_magic_cmd, produces output that libtool cannot recognize.
+*** The result is that libtool may fail to recognize shared libraries
+*** as such.  This will affect the creation of libtool libraries that
+*** depend on shared libraries, but programs linked with such libtool
+*** libraries will work regardless of this problem.  Nevertheless, you
+*** may want to report the problem to your system manager and/or to
+*** bug-libtool@gnu.org
+
+_LT_EOF
+         fi ;;
+       esac
+      fi
+      break
+    fi
+  done
+  IFS="$lt_save_ifs"
+  MAGIC_CMD="$lt_save_MAGIC_CMD"
+  ;;
+esac
+fi
+
+MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+if test -n "$MAGIC_CMD"; then
+  { $as_echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5
+$as_echo "$MAGIC_CMD" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+
+
+
+if test -z "$lt_cv_path_MAGIC_CMD"; then
+  if test -n "$ac_tool_prefix"; then
+    { $as_echo "$as_me:$LINENO: checking for file" >&5
+$as_echo_n "checking for file... " >&6; }
+if test "${lt_cv_path_MAGIC_CMD+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  case $MAGIC_CMD in
+[\\/*] |  ?:[\\/]*)
+  lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+  ;;
+*)
+  lt_save_MAGIC_CMD="$MAGIC_CMD"
+  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+  ac_dummy="/usr/bin$PATH_SEPARATOR$PATH"
+  for ac_dir in $ac_dummy; do
+    IFS="$lt_save_ifs"
+    test -z "$ac_dir" && ac_dir=.
+    if test -f $ac_dir/file; then
+      lt_cv_path_MAGIC_CMD="$ac_dir/file"
+      if test -n "$file_magic_test_file"; then
+       case $deplibs_check_method in
+       "file_magic "*)
+         file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"`
+         MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+         if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null |
+           $EGREP "$file_magic_regex" > /dev/null; then
+           :
+         else
+           cat <<_LT_EOF 1>&2
+
+*** Warning: the command libtool uses to detect shared libraries,
+*** $file_magic_cmd, produces output that libtool cannot recognize.
+*** The result is that libtool may fail to recognize shared libraries
+*** as such.  This will affect the creation of libtool libraries that
+*** depend on shared libraries, but programs linked with such libtool
+*** libraries will work regardless of this problem.  Nevertheless, you
+*** may want to report the problem to your system manager and/or to
+*** bug-libtool@gnu.org
+
+_LT_EOF
+         fi ;;
+       esac
+      fi
+      break
+    fi
+  done
+  IFS="$lt_save_ifs"
+  MAGIC_CMD="$lt_save_MAGIC_CMD"
+  ;;
+esac
+fi
+
+MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+if test -n "$MAGIC_CMD"; then
+  { $as_echo "$as_me:$LINENO: result: $MAGIC_CMD" >&5
+$as_echo "$MAGIC_CMD" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  else
+    MAGIC_CMD=:
+  fi
+fi
+
+  fi
+  ;;
+esac
+
+# Use C for the default configuration in the libtool script
+
+lt_save_CC="$CC"
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
+
+# Source file extension for C test sources.
+ac_ext=c
+
+# Object file extension for compiled C test sources.
+objext=o
+objext=$objext
+
+# Code to be used in simple compile tests
+lt_simple_compile_test_code="int some_variable = 0;"
+
+# Code to be used in simple link tests
+lt_simple_link_test_code='int main(){return(0);}'
+
+
+
+
+
+
+
+# If no C compiler was specified, use CC.
+LTCC=${LTCC-"$CC"}
+
+# If no C compiler flags were specified, use CFLAGS.
+LTCFLAGS=${LTCFLAGS-"$CFLAGS"}
+
+# Allow CC to be a program name with arguments.
+compiler=$CC
+
+# Save the default compiler, since it gets overwritten when the other
+# tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP.
+compiler_DEFAULT=$CC
+
+# save warnings/boilerplate of simple test code
+ac_outfile=conftest.$ac_objext
+echo "$lt_simple_compile_test_code" >conftest.$ac_ext
+eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err
+_lt_compiler_boilerplate=`cat conftest.err`
+$RM conftest*
+
+ac_outfile=conftest.$ac_objext
+echo "$lt_simple_link_test_code" >conftest.$ac_ext
+eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err
+_lt_linker_boilerplate=`cat conftest.err`
+$RM -r conftest*
+
+
+if test -n "$compiler"; then
+
+lt_prog_compiler_no_builtin_flag=
+
+if test "$GCC" = yes; then
+  lt_prog_compiler_no_builtin_flag=' -fno-builtin'
+
+  { $as_echo "$as_me:$LINENO: checking if $compiler supports -fno-rtti -fno-exceptions" >&5
+$as_echo_n "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; }
+if test "${lt_cv_prog_compiler_rtti_exceptions+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_prog_compiler_rtti_exceptions=no
+   ac_outfile=conftest.$ac_objext
+   echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+   lt_compiler_flag="-fno-rtti -fno-exceptions"
+   # Insert the option either (1) after the last *FLAGS variable, or
+   # (2) before a word containing "conftest.", or (3) at the end.
+   # Note that $ac_compile itself does not contain backslashes and begins
+   # with a dollar sign (not a hyphen), so the echo should work correctly.
+   # The option is referenced via a variable to avoid confusing sed.
+   lt_compile=`echo "$ac_compile" | $SED \
+   -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
+   -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
+   -e 's:$: $lt_compiler_flag:'`
+   (eval echo "\"\$as_me:7925: $lt_compile\"" >&5)
+   (eval "$lt_compile" 2>conftest.err)
+   ac_status=$?
+   cat conftest.err >&5
+   echo "$as_me:7929: \$? = $ac_status" >&5
+   if (exit $ac_status) && test -s "$ac_outfile"; then
+     # The compiler can only warn and ignore the option if not recognized
+     # So say no if there are warnings other than the usual output.
+     $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp
+     $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2
+     if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then
+       lt_cv_prog_compiler_rtti_exceptions=yes
+     fi
+   fi
+   $RM conftest*
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_rtti_exceptions" >&5
+$as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; }
+
+if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then
+    lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions"
+else
+    :
+fi
+
+fi
+
+
+
+
+
+
+  lt_prog_compiler_wl=
+lt_prog_compiler_pic=
+lt_prog_compiler_static=
+
+{ $as_echo "$as_me:$LINENO: checking for $compiler option to produce PIC" >&5
+$as_echo_n "checking for $compiler option to produce PIC... " >&6; }
+
+  if test "$GCC" = yes; then
+    lt_prog_compiler_wl='-Wl,'
+    lt_prog_compiler_static='-static'
+
+    case $host_os in
+      aix*)
+      # All AIX code is PIC.
+      if test "$host_cpu" = ia64; then
+       # AIX 5 now supports IA64 processor
+       lt_prog_compiler_static='-Bstatic'
+      fi
+      ;;
+
+    amigaos*)
+      case $host_cpu in
+      powerpc)
+            # see comment about AmigaOS4 .so support
+            lt_prog_compiler_pic='-fPIC'
+        ;;
+      m68k)
+            # FIXME: we need at least 68020 code to build shared libraries, but
+            # adding the `-m68020' flag to GCC prevents building anything better,
+            # like `-m68040'.
+            lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4'
+        ;;
+      esac
+      ;;
+
+    beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*)
+      # PIC is the default for these OSes.
+      ;;
+
+    mingw* | cygwin* | pw32* | os2* | cegcc*)
+      # This hack is so that the source file can tell whether it is being
+      # built for inclusion in a dll (and should export symbols for example).
+      # Although the cygwin gcc ignores -fPIC, still need this for old-style
+      # (--disable-auto-import) libraries
+      lt_prog_compiler_pic='-DDLL_EXPORT'
+      ;;
+
+    darwin* | rhapsody*)
+      # PIC is the default on this platform
+      # Common symbols not allowed in MH_DYLIB files
+      lt_prog_compiler_pic='-fno-common'
+      ;;
+
+    hpux*)
+      # PIC is the default for 64-bit PA HP-UX, but not for 32-bit
+      # PA HP-UX.  On IA64 HP-UX, PIC is the default but the pic flag
+      # sets the default TLS model and affects inlining.
+      case $host_cpu in
+      hppa*64*)
+       # +Z the default
+       ;;
+      *)
+       lt_prog_compiler_pic='-fPIC'
+       ;;
+      esac
+      ;;
+
+    interix[3-9]*)
+      # Interix 3.x gcc -fpic/-fPIC options generate broken code.
+      # Instead, we relocate shared libraries at runtime.
+      ;;
+
+    msdosdjgpp*)
+      # Just because we use GCC doesn't mean we suddenly get shared libraries
+      # on systems that don't support them.
+      lt_prog_compiler_can_build_shared=no
+      enable_shared=no
+      ;;
+
+    *nto* | *qnx*)
+      # QNX uses GNU C++, but need to define -shared option too, otherwise
+      # it will coredump.
+      lt_prog_compiler_pic='-fPIC -shared'
+      ;;
+
+    sysv4*MP*)
+      if test -d /usr/nec; then
+       lt_prog_compiler_pic=-Kconform_pic
+      fi
+      ;;
+
+    *)
+      lt_prog_compiler_pic='-fPIC'
+      ;;
+    esac
+  else
+    # PORTME Check for flag to pass linker flags through the system compiler.
+    case $host_os in
+    aix*)
+      lt_prog_compiler_wl='-Wl,'
+      if test "$host_cpu" = ia64; then
+       # AIX 5 now supports IA64 processor
+       lt_prog_compiler_static='-Bstatic'
+      else
+       lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp'
+      fi
+      ;;
+
+    mingw* | cygwin* | pw32* | os2* | cegcc*)
+      # This hack is so that the source file can tell whether it is being
+      # built for inclusion in a dll (and should export symbols for example).
+      lt_prog_compiler_pic='-DDLL_EXPORT'
+      ;;
+
+    hpux9* | hpux10* | hpux11*)
+      lt_prog_compiler_wl='-Wl,'
+      # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but
+      # not for PA HP-UX.
+      case $host_cpu in
+      hppa*64*|ia64*)
+       # +Z the default
+       ;;
+      *)
+       lt_prog_compiler_pic='+Z'
+       ;;
+      esac
+      # Is there a better lt_prog_compiler_static that works with the bundled CC?
+      lt_prog_compiler_static='${wl}-a ${wl}archive'
+      ;;
+
+    irix5* | irix6* | nonstopux*)
+      lt_prog_compiler_wl='-Wl,'
+      # PIC (with -KPIC) is the default.
+      lt_prog_compiler_static='-non_shared'
+      ;;
+
+    linux* | k*bsd*-gnu)
+      case $cc_basename in
+      # old Intel for x86_64 which still supported -KPIC.
+      ecc*)
+       lt_prog_compiler_wl='-Wl,'
+       lt_prog_compiler_pic='-KPIC'
+       lt_prog_compiler_static='-static'
+        ;;
+      # icc used to be incompatible with GCC.
+      # ICC 10 doesn't accept -KPIC any more.
+      icc* | ifort*)
+       lt_prog_compiler_wl='-Wl,'
+       lt_prog_compiler_pic='-fPIC'
+       lt_prog_compiler_static='-static'
+        ;;
+      # Lahey Fortran 8.1.
+      lf95*)
+       lt_prog_compiler_wl='-Wl,'
+       lt_prog_compiler_pic='--shared'
+       lt_prog_compiler_static='--static'
+       ;;
+      pgcc* | pgf77* | pgf90* | pgf95*)
+        # Portland Group compilers (*not* the Pentium gcc compiler,
+       # which looks to be a dead project)
+       lt_prog_compiler_wl='-Wl,'
+       lt_prog_compiler_pic='-fpic'
+       lt_prog_compiler_static='-Bstatic'
+        ;;
+      ccc*)
+        lt_prog_compiler_wl='-Wl,'
+        # All Alpha code is PIC.
+        lt_prog_compiler_static='-non_shared'
+        ;;
+      xl*)
+       # IBM XL C 8.0/Fortran 10.1 on PPC
+       lt_prog_compiler_wl='-Wl,'
+       lt_prog_compiler_pic='-qpic'
+       lt_prog_compiler_static='-qstaticlink'
+       ;;
+      *)
+       case `$CC -V 2>&1 | sed 5q` in
+       *Sun\ C*)
+         # Sun C 5.9
+         lt_prog_compiler_pic='-KPIC'
+         lt_prog_compiler_static='-Bstatic'
+         lt_prog_compiler_wl='-Wl,'
+         ;;
+       *Sun\ F*)
+         # Sun Fortran 8.3 passes all unrecognized flags to the linker
+         lt_prog_compiler_pic='-KPIC'
+         lt_prog_compiler_static='-Bstatic'
+         lt_prog_compiler_wl=''
+         ;;
+       esac
+       ;;
+      esac
+      ;;
+
+    newsos6)
+      lt_prog_compiler_pic='-KPIC'
+      lt_prog_compiler_static='-Bstatic'
+      ;;
+
+    *nto* | *qnx*)
+      # QNX uses GNU C++, but need to define -shared option too, otherwise
+      # it will coredump.
+      lt_prog_compiler_pic='-fPIC -shared'
+      ;;
+
+    osf3* | osf4* | osf5*)
+      lt_prog_compiler_wl='-Wl,'
+      # All OSF/1 code is PIC.
+      lt_prog_compiler_static='-non_shared'
+      ;;
+
+    rdos*)
+      lt_prog_compiler_static='-non_shared'
+      ;;
+
+    solaris*)
+      lt_prog_compiler_pic='-KPIC'
+      lt_prog_compiler_static='-Bstatic'
+      case $cc_basename in
+      f77* | f90* | f95*)
+       lt_prog_compiler_wl='-Qoption ld ';;
+      *)
+       lt_prog_compiler_wl='-Wl,';;
+      esac
+      ;;
+
+    sunos4*)
+      lt_prog_compiler_wl='-Qoption ld '
+      lt_prog_compiler_pic='-PIC'
+      lt_prog_compiler_static='-Bstatic'
+      ;;
+
+    sysv4 | sysv4.2uw2* | sysv4.3*)
+      lt_prog_compiler_wl='-Wl,'
+      lt_prog_compiler_pic='-KPIC'
+      lt_prog_compiler_static='-Bstatic'
+      ;;
+
+    sysv4*MP*)
+      if test -d /usr/nec ;then
+       lt_prog_compiler_pic='-Kconform_pic'
+       lt_prog_compiler_static='-Bstatic'
+      fi
+      ;;
+
+    sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*)
+      lt_prog_compiler_wl='-Wl,'
+      lt_prog_compiler_pic='-KPIC'
+      lt_prog_compiler_static='-Bstatic'
+      ;;
+
+    unicos*)
+      lt_prog_compiler_wl='-Wl,'
+      lt_prog_compiler_can_build_shared=no
+      ;;
+
+    uts4*)
+      lt_prog_compiler_pic='-pic'
+      lt_prog_compiler_static='-Bstatic'
+      ;;
+
+    *)
+      lt_prog_compiler_can_build_shared=no
+      ;;
+    esac
+  fi
+
+case $host_os in
+  # For platforms which do not support PIC, -DPIC is meaningless:
+  *djgpp*)
+    lt_prog_compiler_pic=
+    ;;
+  *)
+    lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC"
+    ;;
+esac
+{ $as_echo "$as_me:$LINENO: result: $lt_prog_compiler_pic" >&5
+$as_echo "$lt_prog_compiler_pic" >&6; }
+
+
+
+
+
+
+#
+# Check to make sure the PIC flag actually works.
+#
+if test -n "$lt_prog_compiler_pic"; then
+  { $as_echo "$as_me:$LINENO: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5
+$as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; }
+if test "${lt_cv_prog_compiler_pic_works+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_prog_compiler_pic_works=no
+   ac_outfile=conftest.$ac_objext
+   echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+   lt_compiler_flag="$lt_prog_compiler_pic -DPIC"
+   # Insert the option either (1) after the last *FLAGS variable, or
+   # (2) before a word containing "conftest.", or (3) at the end.
+   # Note that $ac_compile itself does not contain backslashes and begins
+   # with a dollar sign (not a hyphen), so the echo should work correctly.
+   # The option is referenced via a variable to avoid confusing sed.
+   lt_compile=`echo "$ac_compile" | $SED \
+   -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
+   -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
+   -e 's:$: $lt_compiler_flag:'`
+   (eval echo "\"\$as_me:8264: $lt_compile\"" >&5)
+   (eval "$lt_compile" 2>conftest.err)
+   ac_status=$?
+   cat conftest.err >&5
+   echo "$as_me:8268: \$? = $ac_status" >&5
+   if (exit $ac_status) && test -s "$ac_outfile"; then
+     # The compiler can only warn and ignore the option if not recognized
+     # So say no if there are warnings other than the usual output.
+     $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' >conftest.exp
+     $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2
+     if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then
+       lt_cv_prog_compiler_pic_works=yes
+     fi
+   fi
+   $RM conftest*
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_pic_works" >&5
+$as_echo "$lt_cv_prog_compiler_pic_works" >&6; }
+
+if test x"$lt_cv_prog_compiler_pic_works" = xyes; then
+    case $lt_prog_compiler_pic in
+     "" | " "*) ;;
+     *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;;
+     esac
+else
+    lt_prog_compiler_pic=
+     lt_prog_compiler_can_build_shared=no
+fi
+
+fi
+
+
+
+
+
+
+#
+# Check to make sure the static flag actually works.
+#
+wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\"
+{ $as_echo "$as_me:$LINENO: checking if $compiler static flag $lt_tmp_static_flag works" >&5
+$as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; }
+if test "${lt_cv_prog_compiler_static_works+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_prog_compiler_static_works=no
+   save_LDFLAGS="$LDFLAGS"
+   LDFLAGS="$LDFLAGS $lt_tmp_static_flag"
+   echo "$lt_simple_link_test_code" > conftest.$ac_ext
+   if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
+     # The linker can only warn and ignore the option if not recognized
+     # So say no if there are warnings
+     if test -s conftest.err; then
+       # Append any errors to the config.log.
+       cat conftest.err 1>&5
+       $ECHO "X$_lt_linker_boilerplate" | $Xsed -e '/^$/d' > conftest.exp
+       $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2
+       if diff conftest.exp conftest.er2 >/dev/null; then
+         lt_cv_prog_compiler_static_works=yes
+       fi
+     else
+       lt_cv_prog_compiler_static_works=yes
+     fi
+   fi
+   $RM -r conftest*
+   LDFLAGS="$save_LDFLAGS"
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_static_works" >&5
+$as_echo "$lt_cv_prog_compiler_static_works" >&6; }
+
+if test x"$lt_cv_prog_compiler_static_works" = xyes; then
+    :
+else
+    lt_prog_compiler_static=
+fi
+
+
+
+
+
+
+
+  { $as_echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5
+$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; }
+if test "${lt_cv_prog_compiler_c_o+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_prog_compiler_c_o=no
+   $RM -r conftest 2>/dev/null
+   mkdir conftest
+   cd conftest
+   mkdir out
+   echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+
+   lt_compiler_flag="-o out/conftest2.$ac_objext"
+   # Insert the option either (1) after the last *FLAGS variable, or
+   # (2) before a word containing "conftest.", or (3) at the end.
+   # Note that $ac_compile itself does not contain backslashes and begins
+   # with a dollar sign (not a hyphen), so the echo should work correctly.
+   lt_compile=`echo "$ac_compile" | $SED \
+   -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
+   -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
+   -e 's:$: $lt_compiler_flag:'`
+   (eval echo "\"\$as_me:8369: $lt_compile\"" >&5)
+   (eval "$lt_compile" 2>out/conftest.err)
+   ac_status=$?
+   cat out/conftest.err >&5
+   echo "$as_me:8373: \$? = $ac_status" >&5
+   if (exit $ac_status) && test -s out/conftest2.$ac_objext
+   then
+     # The compiler can only warn and ignore the option if not recognized
+     # So say no if there are warnings
+     $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp
+     $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2
+     if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then
+       lt_cv_prog_compiler_c_o=yes
+     fi
+   fi
+   chmod u+w . 2>&5
+   $RM conftest*
+   # SGI C++ compiler will create directory out/ii_files/ for
+   # template instantiation
+   test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files
+   $RM out/* && rmdir out
+   cd ..
+   $RM -r conftest
+   $RM conftest*
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o" >&5
+$as_echo "$lt_cv_prog_compiler_c_o" >&6; }
+
+
+
+
+
+
+  { $as_echo "$as_me:$LINENO: checking if $compiler supports -c -o file.$ac_objext" >&5
+$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; }
+if test "${lt_cv_prog_compiler_c_o+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  lt_cv_prog_compiler_c_o=no
+   $RM -r conftest 2>/dev/null
+   mkdir conftest
+   cd conftest
+   mkdir out
+   echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+
+   lt_compiler_flag="-o out/conftest2.$ac_objext"
+   # Insert the option either (1) after the last *FLAGS variable, or
+   # (2) before a word containing "conftest.", or (3) at the end.
+   # Note that $ac_compile itself does not contain backslashes and begins
+   # with a dollar sign (not a hyphen), so the echo should work correctly.
+   lt_compile=`echo "$ac_compile" | $SED \
+   -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
+   -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
+   -e 's:$: $lt_compiler_flag:'`
+   (eval echo "\"\$as_me:8424: $lt_compile\"" >&5)
+   (eval "$lt_compile" 2>out/conftest.err)
+   ac_status=$?
+   cat out/conftest.err >&5
+   echo "$as_me:8428: \$? = $ac_status" >&5
+   if (exit $ac_status) && test -s out/conftest2.$ac_objext
+   then
+     # The compiler can only warn and ignore the option if not recognized
+     # So say no if there are warnings
+     $ECHO "X$_lt_compiler_boilerplate" | $Xsed -e '/^$/d' > out/conftest.exp
+     $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2
+     if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then
+       lt_cv_prog_compiler_c_o=yes
+     fi
+   fi
+   chmod u+w . 2>&5
+   $RM conftest*
+   # SGI C++ compiler will create directory out/ii_files/ for
+   # template instantiation
+   test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files
+   $RM out/* && rmdir out
+   cd ..
+   $RM -r conftest
+   $RM conftest*
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_compiler_c_o" >&5
+$as_echo "$lt_cv_prog_compiler_c_o" >&6; }
+
+
+
+
+hard_links="nottested"
+if test "$lt_cv_prog_compiler_c_o" = no && test "$need_locks" != no; then
+  # do not overwrite the value of need_locks provided by the user
+  { $as_echo "$as_me:$LINENO: checking if we can lock with hard links" >&5
+$as_echo_n "checking if we can lock with hard links... " >&6; }
+  hard_links=yes
+  $RM conftest*
+  ln conftest.a conftest.b 2>/dev/null && hard_links=no
+  touch conftest.a
+  ln conftest.a conftest.b 2>&5 || hard_links=no
+  ln conftest.a conftest.b 2>/dev/null && hard_links=no
+  { $as_echo "$as_me:$LINENO: result: $hard_links" >&5
+$as_echo "$hard_links" >&6; }
+  if test "$hard_links" = no; then
+    { $as_echo "$as_me:$LINENO: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5
+$as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;}
+    need_locks=warn
+  fi
+else
+  need_locks=no
+fi
+
+
+
+
+
+
+  { $as_echo "$as_me:$LINENO: checking whether the $compiler linker ($LD) supports shared libraries" >&5
+$as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; }
+
+  runpath_var=
+  allow_undefined_flag=
+  always_export_symbols=no
+  archive_cmds=
+  archive_expsym_cmds=
+  compiler_needs_object=no
+  enable_shared_with_static_runtimes=no
+  export_dynamic_flag_spec=
+  export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
+  hardcode_automatic=no
+  hardcode_direct=no
+  hardcode_direct_absolute=no
+  hardcode_libdir_flag_spec=
+  hardcode_libdir_flag_spec_ld=
+  hardcode_libdir_separator=
+  hardcode_minus_L=no
+  hardcode_shlibpath_var=unsupported
+  inherit_rpath=no
+  link_all_deplibs=unknown
+  module_cmds=
+  module_expsym_cmds=
+  old_archive_from_new_cmds=
+  old_archive_from_expsyms_cmds=
+  thread_safe_flag_spec=
+  whole_archive_flag_spec=
+  # include_expsyms should be a list of space-separated symbols to be *always*
+  # included in the symbol list
+  include_expsyms=
+  # exclude_expsyms can be an extended regexp of symbols to exclude
+  # it will be wrapped by ` (' and `)$', so one must not match beginning or
+  # end of line.  Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc',
+  # as well as any symbol that contains `d'.
+  exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'
+  # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out
+  # platforms (ab)use it in PIC code, but their linkers get confused if
+  # the symbol is explicitly referenced.  Since portable code cannot
+  # rely on this symbol name, it's probably fine to never include it in
+  # preloaded symbol tables.
+  # Exclude shared library initialization/finalization symbols.
+  extract_expsyms_cmds=
+
+  case $host_os in
+  cygwin* | mingw* | pw32* | cegcc*)
+    # FIXME: the MSVC++ port hasn't been tested in a loooong time
+    # When not using gcc, we currently assume that we are using
+    # Microsoft Visual C++.
+    if test "$GCC" != yes; then
+      with_gnu_ld=no
+    fi
+    ;;
+  interix*)
+    # we just hope/assume this is gcc and not c89 (= MSVC++)
+    with_gnu_ld=yes
+    ;;
+  openbsd*)
+    with_gnu_ld=no
+    ;;
+  esac
+
+  ld_shlibs=yes
+  if test "$with_gnu_ld" = yes; then
+    # If archive_cmds runs LD, not CC, wlarc should be empty
+    wlarc='${wl}'
+
+    # Set some defaults for GNU ld with shared library support. These
+    # are reset later if shared libraries are not supported. Putting them
+    # here allows them to be overridden if necessary.
+    runpath_var=LD_RUN_PATH
+    hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+    export_dynamic_flag_spec='${wl}--export-dynamic'
+    # ancient GNU ld didn't support --whole-archive et. al.
+    if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then
+      whole_archive_flag_spec="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+    else
+      whole_archive_flag_spec=
+    fi
+    supports_anon_versioning=no
+    case `$LD -v 2>&1` in
+      *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11
+      *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ...
+      *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ...
+      *\ 2.11.*) ;; # other 2.11 versions
+      *) supports_anon_versioning=yes ;;
+    esac
+
+    # See if GNU ld supports shared libraries.
+    case $host_os in
+    aix[3-9]*)
+      # On AIX/PPC, the GNU linker is very broken
+      if test "$host_cpu" != ia64; then
+       ld_shlibs=no
+       cat <<_LT_EOF 1>&2
+
+*** Warning: the GNU linker, at least up to release 2.9.1, is reported
+*** to be unable to reliably create shared libraries on AIX.
+*** Therefore, libtool is disabling shared libraries support.  If you
+*** really care for shared libraries, you may want to modify your PATH
+*** so that a non-GNU linker is found, and then restart.
+
+_LT_EOF
+      fi
+      ;;
+
+    amigaos*)
+      case $host_cpu in
+      powerpc)
+            # see comment about AmigaOS4 .so support
+            archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            archive_expsym_cmds=''
+        ;;
+      m68k)
+            archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)'
+            hardcode_libdir_flag_spec='-L$libdir'
+            hardcode_minus_L=yes
+        ;;
+      esac
+      ;;
+
+    beos*)
+      if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+       allow_undefined_flag=unsupported
+       # Joseph Beckenbach <jrb3@best.com> says some releases of gcc
+       # support --undefined.  This deserves some investigation.  FIXME
+       archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+      else
+       ld_shlibs=no
+      fi
+      ;;
+
+    cygwin* | mingw* | pw32* | cegcc*)
+      # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless,
+      # as there is no search path for DLLs.
+      hardcode_libdir_flag_spec='-L$libdir'
+      allow_undefined_flag=unsupported
+      always_export_symbols=no
+      enable_shared_with_static_runtimes=yes
+      export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols'
+
+      if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
+        archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+       # If the export-symbols file already is a .def file (1st line
+       # is EXPORTS), use it as is; otherwise, prepend...
+       archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
+         cp $export_symbols $output_objdir/$soname.def;
+       else
+         echo EXPORTS > $output_objdir/$soname.def;
+         cat $export_symbols >> $output_objdir/$soname.def;
+       fi~
+       $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+      else
+       ld_shlibs=no
+      fi
+      ;;
+
+    interix[3-9]*)
+      hardcode_direct=no
+      hardcode_shlibpath_var=no
+      hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
+      export_dynamic_flag_spec='${wl}-E'
+      # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
+      # Instead, shared libraries are loaded at an image base (0x10000000 by
+      # default) and relocated if they conflict, which is a slow very memory
+      # consuming and fragmenting process.  To avoid this, we pick a random,
+      # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
+      # time.  Moving up from 0x10000000 also allows more sbrk(2) space.
+      archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      archive_expsym_cmds='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+      ;;
+
+    gnu* | linux* | tpf* | k*bsd*-gnu)
+      tmp_diet=no
+      if test "$host_os" = linux-dietlibc; then
+       case $cc_basename in
+         diet\ *) tmp_diet=yes;;       # linux-dietlibc with static linking (!diet-dyn)
+       esac
+      fi
+      if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \
+        && test "$tmp_diet" = no
+      then
+       tmp_addflag=
+       tmp_sharedflag='-shared'
+       case $cc_basename,$host_cpu in
+        pgcc*)                         # Portland Group C compiler
+         whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+         tmp_addflag=' $pic_flag'
+         ;;
+       pgf77* | pgf90* | pgf95*)       # Portland Group f77 and f90 compilers
+         whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test  -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+         tmp_addflag=' $pic_flag -Mnomain' ;;
+       ecc*,ia64* | icc*,ia64*)        # Intel C compiler on ia64
+         tmp_addflag=' -i_dynamic' ;;
+       efc*,ia64* | ifort*,ia64*)      # Intel Fortran compiler on ia64
+         tmp_addflag=' -i_dynamic -nofor_main' ;;
+       ifc* | ifort*)                  # Intel Fortran compiler
+         tmp_addflag=' -nofor_main' ;;
+       lf95*)                          # Lahey Fortran 8.1
+         whole_archive_flag_spec=
+         tmp_sharedflag='--shared' ;;
+       xl[cC]*)                        # IBM XL C 8.0 on PPC (deal with xlf below)
+         tmp_sharedflag='-qmkshrobj'
+         tmp_addflag= ;;
+       esac
+       case `$CC -V 2>&1 | sed 5q` in
+       *Sun\ C*)                       # Sun C 5.9
+         whole_archive_flag_spec='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; $ECHO \"$new_convenience\"` ${wl}--no-whole-archive'
+         compiler_needs_object=yes
+         tmp_sharedflag='-G' ;;
+       *Sun\ F*)                       # Sun Fortran 8.3
+         tmp_sharedflag='-G' ;;
+       esac
+       archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+
+        if test "x$supports_anon_versioning" = xyes; then
+          archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~
+           cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+           echo "local: *; };" >> $output_objdir/$libname.ver~
+           $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+        fi
+
+       case $cc_basename in
+       xlf*)
+         # IBM XL Fortran 10.1 on PPC cannot create shared libs itself
+         whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive'
+         hardcode_libdir_flag_spec=
+         hardcode_libdir_flag_spec_ld='-rpath $libdir'
+         archive_cmds='$LD -shared $libobjs $deplibs $compiler_flags -soname $soname -o $lib'
+         if test "x$supports_anon_versioning" = xyes; then
+           archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~
+             cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+             echo "local: *; };" >> $output_objdir/$libname.ver~
+             $LD -shared $libobjs $deplibs $compiler_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
+         fi
+         ;;
+       esac
+      else
+        ld_shlibs=no
+      fi
+      ;;
+
+    netbsd*)
+      if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
+       archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib'
+       wlarc=
+      else
+       archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+       archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+      fi
+      ;;
+
+    solaris*)
+      if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then
+       ld_shlibs=no
+       cat <<_LT_EOF 1>&2
+
+*** Warning: The releases 2.8.* of the GNU linker cannot reliably
+*** create shared libraries on Solaris systems.  Therefore, libtool
+*** is disabling shared libraries support.  We urge you to upgrade GNU
+*** binutils to release 2.9.1 or newer.  Another option is to modify
+*** your PATH or compiler configuration so that the native linker is
+*** used, and then restart.
+
+_LT_EOF
+      elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+       archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+       archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+      else
+       ld_shlibs=no
+      fi
+      ;;
+
+    sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*)
+      case `$LD -v 2>&1` in
+        *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*)
+       ld_shlibs=no
+       cat <<_LT_EOF 1>&2
+
+*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not
+*** reliably create shared libraries on SCO systems.  Therefore, libtool
+*** is disabling shared libraries support.  We urge you to upgrade GNU
+*** binutils to release 2.16.91.0.3 or newer.  Another option is to modify
+*** your PATH or compiler configuration so that the native linker is
+*** used, and then restart.
+
+_LT_EOF
+       ;;
+       *)
+         # For security reasons, it is highly recommended that you always
+         # use absolute paths for naming shared libraries, and exclude the
+         # DT_RUNPATH tag from executables and libraries.  But doing so
+         # requires that you compile everything twice, which is a pain.
+         if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+           hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+           archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+           archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+         else
+           ld_shlibs=no
+         fi
+       ;;
+      esac
+      ;;
+
+    sunos4*)
+      archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags'
+      wlarc=
+      hardcode_direct=yes
+      hardcode_shlibpath_var=no
+      ;;
+
+    *)
+      if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
+       archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+       archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+      else
+       ld_shlibs=no
+      fi
+      ;;
+    esac
+
+    if test "$ld_shlibs" = no; then
+      runpath_var=
+      hardcode_libdir_flag_spec=
+      export_dynamic_flag_spec=
+      whole_archive_flag_spec=
+    fi
+  else
+    # PORTME fill in a description of your system's linker (not GNU ld)
+    case $host_os in
+    aix3*)
+      allow_undefined_flag=unsupported
+      always_export_symbols=yes
+      archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname'
+      # Note: this linker hardcodes the directories in LIBPATH if there
+      # are no directories specified by -L.
+      hardcode_minus_L=yes
+      if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then
+       # Neither direct hardcoding nor static linking is supported with a
+       # broken collect2.
+       hardcode_direct=unsupported
+      fi
+      ;;
+
+    aix[4-9]*)
+      if test "$host_cpu" = ia64; then
+       # On IA64, the linker does run time linking by default, so we don't
+       # have to do anything special.
+       aix_use_runtimelinking=no
+       exp_sym_flag='-Bexport'
+       no_entry_flag=""
+      else
+       # If we're using GNU nm, then we don't want the "-C" option.
+       # -C means demangle to AIX nm, but means don't demangle with GNU nm
+       if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
+         export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+       else
+         export_symbols_cmds='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+       fi
+       aix_use_runtimelinking=no
+
+       # Test if we are trying to use run time linking or normal
+       # AIX style linking. If -brtl is somewhere in LDFLAGS, we
+       # need to do runtime linking.
+       case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*)
+         for ld_flag in $LDFLAGS; do
+         if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
+           aix_use_runtimelinking=yes
+           break
+         fi
+         done
+         ;;
+       esac
+
+       exp_sym_flag='-bexport'
+       no_entry_flag='-bnoentry'
+      fi
+
+      # When large executables or shared objects are built, AIX ld can
+      # have problems creating the table of contents.  If linking a library
+      # or program results in "error TOC overflow" add -mminimal-toc to
+      # CXXFLAGS/CFLAGS for g++/gcc.  In the cases where that is not
+      # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS.
+
+      archive_cmds=''
+      hardcode_direct=yes
+      hardcode_direct_absolute=yes
+      hardcode_libdir_separator=':'
+      link_all_deplibs=yes
+      file_list_spec='${wl}-f,'
+
+      if test "$GCC" = yes; then
+       case $host_os in aix4.[012]|aix4.[012].*)
+       # We only want to do this on AIX 4.2 and lower, the check
+       # below for broken collect2 doesn't work under 4.3+
+         collect2name=`${CC} -print-prog-name=collect2`
+         if test -f "$collect2name" &&
+          strings "$collect2name" | $GREP resolve_lib_name >/dev/null
+         then
+         # We have reworked collect2
+         :
+         else
+         # We have old collect2
+         hardcode_direct=unsupported
+         # It fails to find uninstalled libraries when the uninstalled
+         # path is not listed in the libpath.  Setting hardcode_minus_L
+         # to unsupported forces relinking
+         hardcode_minus_L=yes
+         hardcode_libdir_flag_spec='-L$libdir'
+         hardcode_libdir_separator=
+         fi
+         ;;
+       esac
+       shared_flag='-shared'
+       if test "$aix_use_runtimelinking" = yes; then
+         shared_flag="$shared_flag "'${wl}-G'
+       fi
+      else
+       # not using gcc
+       if test "$host_cpu" = ia64; then
+       # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
+       # chokes on -Wl,-G. The following line is correct:
+         shared_flag='-G'
+       else
+         if test "$aix_use_runtimelinking" = yes; then
+           shared_flag='${wl}-G'
+         else
+           shared_flag='${wl}-bM:SRE'
+         fi
+       fi
+      fi
+
+      export_dynamic_flag_spec='${wl}-bexpall'
+      # It seems that -bexpall does not export symbols beginning with
+      # underscore (_), so it is better to generate a list of symbols to export.
+      always_export_symbols=yes
+      if test "$aix_use_runtimelinking" = yes; then
+       # Warning - without using the other runtime loading flags (-brtl),
+       # -berok will link without error, but may produce a broken library.
+       allow_undefined_flag='-berok'
+        # Determine the default libpath from the value encoded in an
+        # empty executable.
+        cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+
+lt_aix_libpath_sed='
+    /Import File Strings/,/^$/ {
+       /^0/ {
+           s/^0  *\(.*\)$/\1/
+           p
+       }
+    }'
+aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
+# Check for a 64-bit object if we didn't find anything.
+if test -z "$aix_libpath"; then
+  aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
+fi
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi
+
+        hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
+        archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then $ECHO "X${wl}${allow_undefined_flag}" | $Xsed; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+      else
+       if test "$host_cpu" = ia64; then
+         hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib'
+         allow_undefined_flag="-z nodefs"
+         archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+       else
+        # Determine the default libpath from the value encoded in an
+        # empty executable.
+        cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+
+lt_aix_libpath_sed='
+    /Import File Strings/,/^$/ {
+       /^0/ {
+           s/^0  *\(.*\)$/\1/
+           p
+       }
+    }'
+aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
+# Check for a 64-bit object if we didn't find anything.
+if test -z "$aix_libpath"; then
+  aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
+fi
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi
+
+        hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
+         # Warning - without using the other run time loading flags,
+         # -berok will link without error, but may produce a broken library.
+         no_undefined_flag=' ${wl}-bernotok'
+         allow_undefined_flag=' ${wl}-berok'
+         # Exported symbols can be pulled into shared objects from archives
+         whole_archive_flag_spec='$convenience'
+         archive_cmds_need_lc=yes
+         # This is similar to how AIX traditionally builds its shared libraries.
+         archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+       fi
+      fi
+      ;;
+
+    amigaos*)
+      case $host_cpu in
+      powerpc)
+            # see comment about AmigaOS4 .so support
+            archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+            archive_expsym_cmds=''
+        ;;
+      m68k)
+            archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)'
+            hardcode_libdir_flag_spec='-L$libdir'
+            hardcode_minus_L=yes
+        ;;
+      esac
+      ;;
+
+    bsdi[45]*)
+      export_dynamic_flag_spec=-rdynamic
+      ;;
+
+    cygwin* | mingw* | pw32* | cegcc*)
+      # When not using gcc, we currently assume that we are using
+      # Microsoft Visual C++.
+      # hardcode_libdir_flag_spec is actually meaningless, as there is
+      # no search path for DLLs.
+      hardcode_libdir_flag_spec=' '
+      allow_undefined_flag=unsupported
+      # Tell ltmain to make .lib files, not .a files.
+      libext=lib
+      # Tell ltmain to make .dll files, not .so files.
+      shrext_cmds=".dll"
+      # FIXME: Setting linknames here is a bad hack.
+      archive_cmds='$CC -o $lib $libobjs $compiler_flags `$ECHO "X$deplibs" | $Xsed -e '\''s/ -lc$//'\''` -link -dll~linknames='
+      # The linker will automatically build a .lib file if we build a DLL.
+      old_archive_from_new_cmds='true'
+      # FIXME: Should let the user specify the lib program.
+      old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs'
+      fix_srcfile_path='`cygpath -w "$srcfile"`'
+      enable_shared_with_static_runtimes=yes
+      ;;
+
+    darwin* | rhapsody*)
+
+
+  archive_cmds_need_lc=no
+  hardcode_direct=no
+  hardcode_automatic=yes
+  hardcode_shlibpath_var=unsupported
+  whole_archive_flag_spec=''
+  link_all_deplibs=yes
+  allow_undefined_flag="$_lt_dar_allow_undefined"
+  case $cc_basename in
+     ifort*) _lt_dar_can_shared=yes ;;
+     *) _lt_dar_can_shared=$GCC ;;
+  esac
+  if test "$_lt_dar_can_shared" = "yes"; then
+    output_verbose_link_cmd=echo
+    archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}"
+    module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}"
+    archive_expsym_cmds="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}"
+    module_expsym_cmds="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}"
+
+  else
+  ld_shlibs=no
+  fi
+
+      ;;
+
+    dgux*)
+      archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      hardcode_libdir_flag_spec='-L$libdir'
+      hardcode_shlibpath_var=no
+      ;;
+
+    freebsd1*)
+      ld_shlibs=no
+      ;;
+
+    # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor
+    # support.  Future versions do this automatically, but an explicit c++rt0.o
+    # does not break anything, and helps significantly (at the cost of a little
+    # extra space).
+    freebsd2.2*)
+      archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o'
+      hardcode_libdir_flag_spec='-R$libdir'
+      hardcode_direct=yes
+      hardcode_shlibpath_var=no
+      ;;
+
+    # Unfortunately, older versions of FreeBSD 2 do not have this feature.
+    freebsd2*)
+      archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
+      hardcode_direct=yes
+      hardcode_minus_L=yes
+      hardcode_shlibpath_var=no
+      ;;
+
+    # FreeBSD 3 and greater uses gcc -shared to do shared libraries.
+    freebsd* | dragonfly*)
+      archive_cmds='$CC -shared -o $lib $libobjs $deplibs $compiler_flags'
+      hardcode_libdir_flag_spec='-R$libdir'
+      hardcode_direct=yes
+      hardcode_shlibpath_var=no
+      ;;
+
+    hpux9*)
+      if test "$GCC" = yes; then
+       archive_cmds='$RM $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+      else
+       archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+      fi
+      hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+      hardcode_libdir_separator=:
+      hardcode_direct=yes
+
+      # hardcode_minus_L: Not really in the search PATH,
+      # but as the default location of the library.
+      hardcode_minus_L=yes
+      export_dynamic_flag_spec='${wl}-E'
+      ;;
+
+    hpux10*)
+      if test "$GCC" = yes -a "$with_gnu_ld" = no; then
+       archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
+      fi
+      if test "$with_gnu_ld" = no; then
+       hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+       hardcode_libdir_flag_spec_ld='+b $libdir'
+       hardcode_libdir_separator=:
+       hardcode_direct=yes
+       hardcode_direct_absolute=yes
+       export_dynamic_flag_spec='${wl}-E'
+       # hardcode_minus_L: Not really in the search PATH,
+       # but as the default location of the library.
+       hardcode_minus_L=yes
+      fi
+      ;;
+
+    hpux11*)
+      if test "$GCC" = yes -a "$with_gnu_ld" = no; then
+       case $host_cpu in
+       hppa*64*)
+         archive_cmds='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       ia64*)
+         archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       *)
+         archive_cmds='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       esac
+      else
+       case $host_cpu in
+       hppa*64*)
+         archive_cmds='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       ia64*)
+         archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       *)
+         archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+         ;;
+       esac
+      fi
+      if test "$with_gnu_ld" = no; then
+       hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+       hardcode_libdir_separator=:
+
+       case $host_cpu in
+       hppa*64*|ia64*)
+         hardcode_direct=no
+         hardcode_shlibpath_var=no
+         ;;
+       *)
+         hardcode_direct=yes
+         hardcode_direct_absolute=yes
+         export_dynamic_flag_spec='${wl}-E'
+
+         # hardcode_minus_L: Not really in the search PATH,
+         # but as the default location of the library.
+         hardcode_minus_L=yes
+         ;;
+       esac
+      fi
+      ;;
+
+    irix5* | irix6* | nonstopux*)
+      if test "$GCC" = yes; then
+       archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+       # Try to use the -exported_symbol ld option, if it does not
+       # work, assume that -exports_file does not work either and
+       # implicitly export all symbols.
+        save_LDFLAGS="$LDFLAGS"
+        LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null"
+        cat >conftest.$ac_ext <<_ACEOF
+int foo(void) {}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib'
+
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+        LDFLAGS="$save_LDFLAGS"
+      else
+       archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+       archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib'
+      fi
+      archive_cmds_need_lc='no'
+      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      hardcode_libdir_separator=:
+      inherit_rpath=yes
+      link_all_deplibs=yes
+      ;;
+
+    netbsd*)
+      if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
+       archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'  # a.out
+      else
+       archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags'      # ELF
+      fi
+      hardcode_libdir_flag_spec='-R$libdir'
+      hardcode_direct=yes
+      hardcode_shlibpath_var=no
+      ;;
+
+    newsos6)
+      archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      hardcode_direct=yes
+      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      hardcode_libdir_separator=:
+      hardcode_shlibpath_var=no
+      ;;
+
+    *nto* | *qnx*)
+      ;;
+
+    openbsd*)
+      if test -f /usr/libexec/ld.so; then
+       hardcode_direct=yes
+       hardcode_shlibpath_var=no
+       hardcode_direct_absolute=yes
+       if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+         archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+         archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols'
+         hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
+         export_dynamic_flag_spec='${wl}-E'
+       else
+         case $host_os in
+          openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*)
+            archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
+            hardcode_libdir_flag_spec='-R$libdir'
+            ;;
+          *)
+            archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+            hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
+            ;;
+         esac
+       fi
+      else
+       ld_shlibs=no
+      fi
+      ;;
+
+    os2*)
+      hardcode_libdir_flag_spec='-L$libdir'
+      hardcode_minus_L=yes
+      allow_undefined_flag=unsupported
+      archive_cmds='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$ECHO DATA >> $output_objdir/$libname.def~$ECHO " SINGLE NONSHARED" >> $output_objdir/$libname.def~$ECHO EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def'
+      old_archive_from_new_cmds='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def'
+      ;;
+
+    osf3*)
+      if test "$GCC" = yes; then
+       allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*'
+       archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+      else
+       allow_undefined_flag=' -expect_unresolved \*'
+       archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+      fi
+      archive_cmds_need_lc='no'
+      hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      hardcode_libdir_separator=:
+      ;;
+
+    osf4* | osf5*)     # as osf3* with the addition of -msym flag
+      if test "$GCC" = yes; then
+       allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*'
+       archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && $ECHO "X${wl}-set_version ${wl}$verstring" | $Xsed` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+       hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+      else
+       allow_undefined_flag=' -expect_unresolved \*'
+       archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib'
+       archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~
+       $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "X-set_version $verstring" | $Xsed` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp'
+
+       # Both c and cxx compiler support -rpath directly
+       hardcode_libdir_flag_spec='-rpath $libdir'
+      fi
+      archive_cmds_need_lc='no'
+      hardcode_libdir_separator=:
+      ;;
+
+    solaris*)
+      no_undefined_flag=' -z defs'
+      if test "$GCC" = yes; then
+       wlarc='${wl}'
+       archive_cmds='$CC -shared ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+       archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+         $CC -shared ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+      else
+       case `$CC -V 2>&1` in
+       *"Compilers 5.0"*)
+         wlarc=''
+         archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
+         archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+         $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
+         ;;
+       *)
+         wlarc='${wl}'
+         archive_cmds='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags'
+         archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
+         $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+         ;;
+       esac
+      fi
+      hardcode_libdir_flag_spec='-R$libdir'
+      hardcode_shlibpath_var=no
+      case $host_os in
+      solaris2.[0-5] | solaris2.[0-5].*) ;;
+      *)
+       # The compiler driver will combine and reorder linker options,
+       # but understands `-z linker_flag'.  GCC discards it without `$wl',
+       # but is careful enough not to reorder.
+       # Supported since Solaris 2.6 (maybe 2.5.1?)
+       if test "$GCC" = yes; then
+         whole_archive_flag_spec='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+       else
+         whole_archive_flag_spec='-z allextract$convenience -z defaultextract'
+       fi
+       ;;
+      esac
+      link_all_deplibs=yes
+      ;;
+
+    sunos4*)
+      if test "x$host_vendor" = xsequent; then
+       # Use $CC to link under sequent, because it throws in some extra .o
+       # files that make .init and .fini sections work.
+       archive_cmds='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags'
+      fi
+      hardcode_libdir_flag_spec='-L$libdir'
+      hardcode_direct=yes
+      hardcode_minus_L=yes
+      hardcode_shlibpath_var=no
+      ;;
+
+    sysv4)
+      case $host_vendor in
+       sni)
+         archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+         hardcode_direct=yes # is this really true???
+       ;;
+       siemens)
+         ## LD is ld it makes a PLAMLIB
+         ## CC just makes a GrossModule.
+         archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags'
+         reload_cmds='$CC -r -o $output$reload_objs'
+         hardcode_direct=no
+        ;;
+       motorola)
+         archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+         hardcode_direct=no #Motorola manual says yes, but my tests say they lie
+       ;;
+      esac
+      runpath_var='LD_RUN_PATH'
+      hardcode_shlibpath_var=no
+      ;;
+
+    sysv4.3*)
+      archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      hardcode_shlibpath_var=no
+      export_dynamic_flag_spec='-Bexport'
+      ;;
+
+    sysv4*MP*)
+      if test -d /usr/nec; then
+       archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+       hardcode_shlibpath_var=no
+       runpath_var=LD_RUN_PATH
+       hardcode_runpath_var=yes
+       ld_shlibs=yes
+      fi
+      ;;
+
+    sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*)
+      no_undefined_flag='${wl}-z,text'
+      archive_cmds_need_lc=no
+      hardcode_shlibpath_var=no
+      runpath_var='LD_RUN_PATH'
+
+      if test "$GCC" = yes; then
+       archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      fi
+      ;;
+
+    sysv5* | sco3.2v5* | sco5v6*)
+      # Note: We can NOT use -z defs as we might desire, because we do not
+      # link with -lc, and that would cause any symbols used from libc to
+      # always be unresolved, which means just about no library would
+      # ever link correctly.  If we're not using GNU ld we use -z text
+      # though, which does catch some bad symbols but isn't as heavy-handed
+      # as -z defs.
+      no_undefined_flag='${wl}-z,text'
+      allow_undefined_flag='${wl}-z,nodefs'
+      archive_cmds_need_lc=no
+      hardcode_shlibpath_var=no
+      hardcode_libdir_flag_spec='${wl}-R,$libdir'
+      hardcode_libdir_separator=':'
+      link_all_deplibs=yes
+      export_dynamic_flag_spec='${wl}-Bexport'
+      runpath_var='LD_RUN_PATH'
+
+      if test "$GCC" = yes; then
+       archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      else
+       archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+       archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+      fi
+      ;;
+
+    uts4*)
+      archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
+      hardcode_libdir_flag_spec='-L$libdir'
+      hardcode_shlibpath_var=no
+      ;;
+
+    *)
+      ld_shlibs=no
+      ;;
+    esac
+
+    if test x$host_vendor = xsni; then
+      case $host in
+      sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
+       export_dynamic_flag_spec='${wl}-Blargedynsym'
+       ;;
+      esac
+    fi
+  fi
+
+{ $as_echo "$as_me:$LINENO: result: $ld_shlibs" >&5
+$as_echo "$ld_shlibs" >&6; }
+test "$ld_shlibs" = no && can_build_shared=no
+
+with_gnu_ld=$with_gnu_ld
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+#
+# Do we need to explicitly link libc?
+#
+case "x$archive_cmds_need_lc" in
+x|xyes)
+  # Assume -lc should be added
+  archive_cmds_need_lc=yes
+
+  if test "$enable_shared" = yes && test "$GCC" = yes; then
+    case $archive_cmds in
+    *'~'*)
+      # FIXME: we may have to deal with multi-command sequences.
+      ;;
+    '$CC '*)
+      # Test whether the compiler implicitly links with -lc since on some
+      # systems, -lgcc has to come before -lc. If gcc already passes -lc
+      # to ld, don't add -lc before -lgcc.
+      { $as_echo "$as_me:$LINENO: checking whether -lc should be explicitly linked in" >&5
+$as_echo_n "checking whether -lc should be explicitly linked in... " >&6; }
+      $RM conftest*
+      echo "$lt_simple_compile_test_code" > conftest.$ac_ext
+
+      if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
+  (eval $ac_compile) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } 2>conftest.err; then
+        soname=conftest
+        lib=conftest
+        libobjs=conftest.$ac_objext
+        deplibs=
+        wl=$lt_prog_compiler_wl
+       pic_flag=$lt_prog_compiler_pic
+        compiler_flags=-v
+        linker_flags=-v
+        verstring=
+        output_objdir=.
+        libname=conftest
+        lt_save_allow_undefined_flag=$allow_undefined_flag
+        allow_undefined_flag=
+        if { (eval echo "$as_me:$LINENO: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\"") >&5
+  (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }
+        then
+         archive_cmds_need_lc=no
+        else
+         archive_cmds_need_lc=yes
+        fi
+        allow_undefined_flag=$lt_save_allow_undefined_flag
+      else
+        cat conftest.err 1>&5
+      fi
+      $RM conftest*
+      { $as_echo "$as_me:$LINENO: result: $archive_cmds_need_lc" >&5
+$as_echo "$archive_cmds_need_lc" >&6; }
+      ;;
+    esac
+  fi
+  ;;
+esac
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+  { $as_echo "$as_me:$LINENO: checking dynamic linker characteristics" >&5
+$as_echo_n "checking dynamic linker characteristics... " >&6; }
+
+if test "$GCC" = yes; then
+  case $host_os in
+    darwin*) lt_awk_arg="/^libraries:/,/LR/" ;;
+    *) lt_awk_arg="/^libraries:/" ;;
+  esac
+  lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e "s,=/,/,g"`
+  if $ECHO "$lt_search_path_spec" | $GREP ';' >/dev/null ; then
+    # if the path contains ";" then we assume it to be the separator
+    # otherwise default to the standard path separator (i.e. ":") - it is
+    # assumed that no part of a normal pathname contains ";" but that should
+    # okay in the real world where ";" in dirpaths is itself problematic.
+    lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED -e 's/;/ /g'`
+  else
+    lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED  -e "s/$PATH_SEPARATOR/ /g"`
+  fi
+  # Ok, now we have the path, separated by spaces, we can step through it
+  # and add multilib dir if necessary.
+  lt_tmp_lt_search_path_spec=
+  lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+  for lt_sys_path in $lt_search_path_spec; do
+    if test -d "$lt_sys_path/$lt_multi_os_dir"; then
+      lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir"
+    else
+      test -d "$lt_sys_path" && \
+       lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path"
+    fi
+  done
+  lt_search_path_spec=`$ECHO $lt_tmp_lt_search_path_spec | awk '
+BEGIN {RS=" "; FS="/|\n";} {
+  lt_foo="";
+  lt_count=0;
+  for (lt_i = NF; lt_i > 0; lt_i--) {
+    if ($lt_i != "" && $lt_i != ".") {
+      if ($lt_i == "..") {
+        lt_count++;
+      } else {
+        if (lt_count == 0) {
+          lt_foo="/" $lt_i lt_foo;
+        } else {
+          lt_count--;
+        }
+      }
+    }
+  }
+  if (lt_foo != "") { lt_freq[lt_foo]++; }
+  if (lt_freq[lt_foo] == 1) { print lt_foo; }
+}'`
+  sys_lib_search_path_spec=`$ECHO $lt_search_path_spec`
+else
+  sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
+fi
+library_names_spec=
+libname_spec='lib$name'
+soname_spec=
+shrext_cmds=".so"
+postinstall_cmds=
+postuninstall_cmds=
+finish_cmds=
+finish_eval=
+shlibpath_var=
+shlibpath_overrides_runpath=unknown
+version_type=none
+dynamic_linker="$host_os ld.so"
+sys_lib_dlsearch_path_spec="/lib /usr/lib"
+need_lib_prefix=unknown
+hardcode_into_libs=no
+
+# when you set need_version to no, make sure it does not cause -set_version
+# flags to be left without arguments
+need_version=unknown
+
+case $host_os in
+aix3*)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
+  shlibpath_var=LIBPATH
+
+  # AIX 3 has no versioning support, so we append a major version to the name.
+  soname_spec='${libname}${release}${shared_ext}$major'
+  ;;
+
+aix[4-9]*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  hardcode_into_libs=yes
+  if test "$host_cpu" = ia64; then
+    # AIX 5 supports IA64
+    library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
+    shlibpath_var=LD_LIBRARY_PATH
+  else
+    # With GCC up to 2.95.x, collect2 would create an import file
+    # for dependence libraries.  The import file would start with
+    # the line `#! .'.  This would cause the generated library to
+    # depend on `.', always an invalid library.  This was fixed in
+    # development snapshots of GCC prior to 3.0.
+    case $host_os in
+      aix4 | aix4.[01] | aix4.[01].*)
+      if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)'
+          echo ' yes '
+          echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then
+       :
+      else
+       can_build_shared=no
+      fi
+      ;;
+    esac
+    # AIX (on Power*) has no versioning support, so currently we can not hardcode correct
+    # soname into executable. Probably we can add versioning support to
+    # collect2, so additional links can be useful in future.
+    if test "$aix_use_runtimelinking" = yes; then
+      # If using run time linking (on AIX 4.2 or later) use lib<name>.so
+      # instead of lib<name>.a to let people know that these are not
+      # typical AIX shared libraries.
+      library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    else
+      # We preserve .a as extension for shared libraries through AIX4.2
+      # and later when we are not doing run time linking.
+      library_names_spec='${libname}${release}.a $libname.a'
+      soname_spec='${libname}${release}${shared_ext}$major'
+    fi
+    shlibpath_var=LIBPATH
+  fi
+  ;;
+
+amigaos*)
+  case $host_cpu in
+  powerpc)
+    # Since July 2007 AmigaOS4 officially supports .so libraries.
+    # When compiling the executable, add -use-dynld -Lsobjs: to the compileline.
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    ;;
+  m68k)
+    library_names_spec='$libname.ixlibrary $libname.a'
+    # Create ${libname}_ixlibrary.a entries in /sys/libs.
+    finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$ECHO "X$lib" | $Xsed -e '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
+    ;;
+  esac
+  ;;
+
+beos*)
+  library_names_spec='${libname}${shared_ext}'
+  dynamic_linker="$host_os ld.so"
+  shlibpath_var=LIBRARY_PATH
+  ;;
+
+bsdi[45]*)
+  version_type=linux
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib"
+  sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib"
+  # the default ld.so.conf also contains /usr/contrib/lib and
+  # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow
+  # libtool to hard-code these into programs
+  ;;
+
+cygwin* | mingw* | pw32* | cegcc*)
+  version_type=windows
+  shrext_cmds=".dll"
+  need_version=no
+  need_lib_prefix=no
+
+  case $GCC,$host_os in
+  yes,cygwin* | yes,mingw* | yes,pw32* | yes,cegcc*)
+    library_names_spec='$libname.dll.a'
+    # DLL is installed to $(libdir)/../bin by postinstall_cmds
+    postinstall_cmds='base_file=`basename \${file}`~
+      dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+      dldir=$destdir/`dirname \$dlpath`~
+      test -d \$dldir || mkdir -p \$dldir~
+      $install_prog $dir/$dlname \$dldir/$dlname~
+      chmod a+x \$dldir/$dlname~
+      if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then
+        eval '\''$striplib \$dldir/$dlname'\'' || exit \$?;
+      fi'
+    postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~
+      dlpath=$dir/\$dldll~
+       $RM \$dlpath'
+    shlibpath_overrides_runpath=yes
+
+    case $host_os in
+    cygwin*)
+      # Cygwin DLLs use 'cyg' prefix rather than 'lib'
+      soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+      sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib"
+      ;;
+    mingw* | cegcc*)
+      # MinGW DLLs use traditional 'lib' prefix
+      soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+      sys_lib_search_path_spec=`$CC -print-search-dirs | $GREP "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"`
+      if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then
+        # It is most probably a Windows format PATH printed by
+        # mingw gcc, but we are running on Cygwin. Gcc prints its search
+        # path with ; separators, and with drive letters. We can handle the
+        # drive letters (cygwin fileutils understands them), so leave them,
+        # especially as we might pass files found there to a mingw objdump,
+        # which wouldn't understand a cygwinified path. Ahh.
+        sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
+      else
+        sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED  -e "s/$PATH_SEPARATOR/ /g"`
+      fi
+      ;;
+    pw32*)
+      # pw32 DLLs use 'pw' prefix rather than 'lib'
+      library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+      ;;
+    esac
+    ;;
+
+  *)
+    library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib'
+    ;;
+  esac
+  dynamic_linker='Win32 ld.exe'
+  # FIXME: first we should search . and the directory the executable is in
+  shlibpath_var=PATH
+  ;;
+
+darwin* | rhapsody*)
+  dynamic_linker="$host_os dyld"
+  version_type=darwin
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext'
+  soname_spec='${libname}${release}${major}$shared_ext'
+  shlibpath_overrides_runpath=yes
+  shlibpath_var=DYLD_LIBRARY_PATH
+  shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`'
+
+  sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"
+  sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib'
+  ;;
+
+dgux*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  ;;
+
+freebsd1*)
+  dynamic_linker=no
+  ;;
+
+freebsd* | dragonfly*)
+  # DragonFly does not have aout.  When/if they implement a new
+  # versioning mechanism, adjust this.
+  if test -x /usr/bin/objformat; then
+    objformat=`/usr/bin/objformat`
+  else
+    case $host_os in
+    freebsd[123]*) objformat=aout ;;
+    *) objformat=elf ;;
+    esac
+  fi
+  version_type=freebsd-$objformat
+  case $version_type in
+    freebsd-elf*)
+      library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+      need_version=no
+      need_lib_prefix=no
+      ;;
+    freebsd-*)
+      library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
+      need_version=yes
+      ;;
+  esac
+  shlibpath_var=LD_LIBRARY_PATH
+  case $host_os in
+  freebsd2*)
+    shlibpath_overrides_runpath=yes
+    ;;
+  freebsd3.[01]* | freebsdelf3.[01]*)
+    shlibpath_overrides_runpath=yes
+    hardcode_into_libs=yes
+    ;;
+  freebsd3.[2-9]* | freebsdelf3.[2-9]* | \
+  freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1)
+    shlibpath_overrides_runpath=no
+    hardcode_into_libs=yes
+    ;;
+  *) # from 4.6 on, and DragonFly
+    shlibpath_overrides_runpath=yes
+    hardcode_into_libs=yes
+    ;;
+  esac
+  ;;
+
+gnu*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  hardcode_into_libs=yes
+  ;;
+
+hpux9* | hpux10* | hpux11*)
+  # Give a soname corresponding to the major version so that dld.sl refuses to
+  # link against other versions.
+  version_type=sunos
+  need_lib_prefix=no
+  need_version=no
+  case $host_cpu in
+  ia64*)
+    shrext_cmds='.so'
+    hardcode_into_libs=yes
+    dynamic_linker="$host_os dld.so"
+    shlibpath_var=LD_LIBRARY_PATH
+    shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    if test "X$HPUX_IA64_MODE" = X32; then
+      sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
+    else
+      sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
+    fi
+    sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+    ;;
+  hppa*64*)
+    shrext_cmds='.sl'
+    hardcode_into_libs=yes
+    dynamic_linker="$host_os dld.sl"
+    shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH
+    shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64"
+    sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+    ;;
+  *)
+    shrext_cmds='.sl'
+    dynamic_linker="$host_os dld.sl"
+    shlibpath_var=SHLIB_PATH
+    shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    ;;
+  esac
+  # HP-UX runs *really* slowly unless shared libraries are mode 555.
+  postinstall_cmds='chmod 555 $lib'
+  ;;
+
+interix[3-9]*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  hardcode_into_libs=yes
+  ;;
+
+irix5* | irix6* | nonstopux*)
+  case $host_os in
+    nonstopux*) version_type=nonstopux ;;
+    *)
+       if test "$lt_cv_prog_gnu_ld" = yes; then
+               version_type=linux
+       else
+               version_type=irix
+       fi ;;
+  esac
+  need_lib_prefix=no
+  need_version=no
+  soname_spec='${libname}${release}${shared_ext}$major'
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}'
+  case $host_os in
+  irix5* | nonstopux*)
+    libsuff= shlibsuff=
+    ;;
+  *)
+    case $LD in # libtool.m4 will add one of these switches to LD
+    *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ")
+      libsuff= shlibsuff= libmagic=32-bit;;
+    *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ")
+      libsuff=32 shlibsuff=N32 libmagic=N32;;
+    *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ")
+      libsuff=64 shlibsuff=64 libmagic=64-bit;;
+    *) libsuff= shlibsuff= libmagic=never-match;;
+    esac
+    ;;
+  esac
+  shlibpath_var=LD_LIBRARY${shlibsuff}_PATH
+  shlibpath_overrides_runpath=no
+  sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}"
+  sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}"
+  hardcode_into_libs=yes
+  ;;
+
+# No shared lib support for Linux oldld, aout, or coff.
+linux*oldld* | linux*aout* | linux*coff*)
+  dynamic_linker=no
+  ;;
+
+# This must be Linux ELF.
+linux* | k*bsd*-gnu)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  # Some binutils ld are patched to set DT_RUNPATH
+  save_LDFLAGS=$LDFLAGS
+  save_libdir=$libdir
+  eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \
+       LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\""
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+int
+main ()
+{
+
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  if  ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then
+  shlibpath_overrides_runpath=yes
+fi
+
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+  LDFLAGS=$save_LDFLAGS
+  libdir=$save_libdir
+
+  # This implies no fast_install, which is unacceptable.
+  # Some rework will be needed to allow for fast_install
+  # before this can be enabled.
+  hardcode_into_libs=yes
+
+  # Add ABI-specific directories to the system library path.
+  sys_lib_dlsearch_path_spec="/lib64 /usr/lib64 /lib /usr/lib"
+
+  # Append ld.so.conf contents to the search path
+  if test -f /etc/ld.so.conf; then
+    lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[      ]*hwcap[        ]/d;s/[:,      ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;/^$/d' | tr '\n' ' '`
+    sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec $lt_ld_extra"
+  fi
+
+  # We used to test for /lib/ld.so.1 and disable shared libraries on
+  # powerpc, because MkLinux only supported shared libraries with the
+  # GNU dynamic linker.  Since this was broken with cross compilers,
+  # most powerpc-linux boxes support dynamic linking these days and
+  # people can always --disable-shared, the test was removed, and we
+  # assume the GNU/Linux dynamic linker is in use.
+  dynamic_linker='GNU/Linux ld.so'
+  ;;
+
+netbsd*)
+  version_type=sunos
+  need_lib_prefix=no
+  need_version=no
+  if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+    finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
+    dynamic_linker='NetBSD (a.out) ld.so'
+  else
+    library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
+    soname_spec='${libname}${release}${shared_ext}$major'
+    dynamic_linker='NetBSD ld.elf_so'
+  fi
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  hardcode_into_libs=yes
+  ;;
+
+newsos6)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  ;;
+
+*nto* | *qnx*)
+  version_type=qnx
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  hardcode_into_libs=yes
+  dynamic_linker='ldqnx.so'
+  ;;
+
+openbsd*)
+  version_type=sunos
+  sys_lib_dlsearch_path_spec="/usr/lib"
+  need_lib_prefix=no
+  # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs.
+  case $host_os in
+    openbsd3.3 | openbsd3.3.*) need_version=yes ;;
+    *)                         need_version=no  ;;
+  esac
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+  finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+    case $host_os in
+      openbsd2.[89] | openbsd2.[89].*)
+       shlibpath_overrides_runpath=no
+       ;;
+      *)
+       shlibpath_overrides_runpath=yes
+       ;;
+      esac
+  else
+    shlibpath_overrides_runpath=yes
+  fi
+  ;;
+
+os2*)
+  libname_spec='$name'
+  shrext_cmds=".dll"
+  need_lib_prefix=no
+  library_names_spec='$libname${shared_ext} $libname.a'
+  dynamic_linker='OS/2 ld.exe'
+  shlibpath_var=LIBPATH
+  ;;
+
+osf3* | osf4* | osf5*)
+  version_type=osf
+  need_lib_prefix=no
+  need_version=no
+  soname_spec='${libname}${release}${shared_ext}$major'
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  shlibpath_var=LD_LIBRARY_PATH
+  sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib"
+  sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec"
+  ;;
+
+rdos*)
+  dynamic_linker=no
+  ;;
+
+solaris*)
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  hardcode_into_libs=yes
+  # ldd complains unless libraries are executable
+  postinstall_cmds='chmod +x $lib'
+  ;;
+
+sunos4*)
+  version_type=sunos
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+  finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  if test "$with_gnu_ld" = yes; then
+    need_lib_prefix=no
+  fi
+  need_version=yes
+  ;;
+
+sysv4 | sysv4.3*)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  case $host_vendor in
+    sni)
+      shlibpath_overrides_runpath=no
+      need_lib_prefix=no
+      runpath_var=LD_RUN_PATH
+      ;;
+    siemens)
+      need_lib_prefix=no
+      ;;
+    motorola)
+      need_lib_prefix=no
+      need_version=no
+      shlibpath_overrides_runpath=no
+      sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib'
+      ;;
+  esac
+  ;;
+
+sysv4*MP*)
+  if test -d /usr/nec ;then
+    version_type=linux
+    library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
+    soname_spec='$libname${shared_ext}.$major'
+    shlibpath_var=LD_LIBRARY_PATH
+  fi
+  ;;
+
+sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
+  version_type=freebsd-elf
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=yes
+  hardcode_into_libs=yes
+  if test "$with_gnu_ld" = yes; then
+    sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib'
+  else
+    sys_lib_search_path_spec='/usr/ccs/lib /usr/lib'
+    case $host_os in
+      sco3.2v5*)
+        sys_lib_search_path_spec="$sys_lib_search_path_spec /lib"
+       ;;
+    esac
+  fi
+  sys_lib_dlsearch_path_spec='/usr/lib'
+  ;;
+
+tpf*)
+  # TPF is a cross-target only.  Preferred cross-host = GNU/Linux.
+  version_type=linux
+  need_lib_prefix=no
+  need_version=no
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  shlibpath_var=LD_LIBRARY_PATH
+  shlibpath_overrides_runpath=no
+  hardcode_into_libs=yes
+  ;;
+
+uts4*)
+  version_type=linux
+  library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+  soname_spec='${libname}${release}${shared_ext}$major'
+  shlibpath_var=LD_LIBRARY_PATH
+  ;;
+
+*)
+  dynamic_linker=no
+  ;;
+esac
+{ $as_echo "$as_me:$LINENO: result: $dynamic_linker" >&5
+$as_echo "$dynamic_linker" >&6; }
+test "$dynamic_linker" = no && can_build_shared=no
+
+variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
+if test "$GCC" = yes; then
+  variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
+fi
+
+if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then
+  sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec"
+fi
+if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then
+  sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec"
+fi
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+  { $as_echo "$as_me:$LINENO: checking how to hardcode library paths into programs" >&5
+$as_echo_n "checking how to hardcode library paths into programs... " >&6; }
+hardcode_action=
+if test -n "$hardcode_libdir_flag_spec" ||
+   test -n "$runpath_var" ||
+   test "X$hardcode_automatic" = "Xyes" ; then
+
+  # We can hardcode non-existent directories.
+  if test "$hardcode_direct" != no &&
+     # If the only mechanism to avoid hardcoding is shlibpath_var, we
+     # have to relink, otherwise we might link with an installed library
+     # when we should be linking with a yet-to-be-installed one
+     ## test "$_LT_TAGVAR(hardcode_shlibpath_var, )" != no &&
+     test "$hardcode_minus_L" != no; then
+    # Linking always hardcodes the temporary library directory.
+    hardcode_action=relink
+  else
+    # We can link without hardcoding, and we can hardcode nonexisting dirs.
+    hardcode_action=immediate
+  fi
+else
+  # We cannot hardcode anything, or else we can only hardcode existing
+  # directories.
+  hardcode_action=unsupported
+fi
+{ $as_echo "$as_me:$LINENO: result: $hardcode_action" >&5
+$as_echo "$hardcode_action" >&6; }
+
+if test "$hardcode_action" = relink ||
+   test "$inherit_rpath" = yes; then
+  # Fast installation is not supported
+  enable_fast_install=no
+elif test "$shlibpath_overrides_runpath" = yes ||
+     test "$enable_shared" = no; then
+  # Fast installation is not necessary
+  enable_fast_install=needless
+fi
+
+
+
+
+
+
+  if test "x$enable_dlopen" != xyes; then
+  enable_dlopen=unknown
+  enable_dlopen_self=unknown
+  enable_dlopen_self_static=unknown
+else
+  lt_cv_dlopen=no
+  lt_cv_dlopen_libs=
+
+  case $host_os in
+  beos*)
+    lt_cv_dlopen="load_add_on"
+    lt_cv_dlopen_libs=
+    lt_cv_dlopen_self=yes
+    ;;
+
+  mingw* | pw32* | cegcc*)
+    lt_cv_dlopen="LoadLibrary"
+    lt_cv_dlopen_libs=
+    ;;
+
+  cygwin*)
+    lt_cv_dlopen="dlopen"
+    lt_cv_dlopen_libs=
+    ;;
+
+  darwin*)
+  # if libdl is installed we need to link against it
+    { $as_echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5
+$as_echo_n "checking for dlopen in -ldl... " >&6; }
+if test "${ac_cv_lib_dl_dlopen+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_check_lib_save_LIBS=$LIBS
+LIBS="-ldl  $LIBS"
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char dlopen ();
+int
+main ()
+{
+return dlopen ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_lib_dl_dlopen=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_lib_dl_dlopen=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+LIBS=$ac_check_lib_save_LIBS
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5
+$as_echo "$ac_cv_lib_dl_dlopen" >&6; }
+if test "x$ac_cv_lib_dl_dlopen" = x""yes; then
+  lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"
+else
+
+    lt_cv_dlopen="dyld"
+    lt_cv_dlopen_libs=
+    lt_cv_dlopen_self=yes
+
+fi
+
+    ;;
+
+  *)
+    { $as_echo "$as_me:$LINENO: checking for shl_load" >&5
+$as_echo_n "checking for shl_load... " >&6; }
+if test "${ac_cv_func_shl_load+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+/* Define shl_load to an innocuous variant, in case <limits.h> declares shl_load.
+   For example, HP-UX 11i <limits.h> declares gettimeofday.  */
+#define shl_load innocuous_shl_load
+
+/* System header to define __stub macros and hopefully few prototypes,
+    which can conflict with char shl_load (); below.
+    Prefer <limits.h> to <assert.h> if __STDC__ is defined, since
+    <limits.h> exists even on freestanding compilers.  */
+
+#ifdef __STDC__
+# include <limits.h>
+#else
+# include <assert.h>
+#endif
+
+#undef shl_load
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char shl_load ();
+/* The GNU C library defines this for functions which it implements
+    to always fail with ENOSYS.  Some functions are actually named
+    something starting with __ and the normal name is an alias.  */
+#if defined __stub_shl_load || defined __stub___shl_load
+choke me
+#endif
+
+int
+main ()
+{
+return shl_load ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_func_shl_load=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_func_shl_load=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_shl_load" >&5
+$as_echo "$ac_cv_func_shl_load" >&6; }
+if test "x$ac_cv_func_shl_load" = x""yes; then
+  lt_cv_dlopen="shl_load"
+else
+  { $as_echo "$as_me:$LINENO: checking for shl_load in -ldld" >&5
+$as_echo_n "checking for shl_load in -ldld... " >&6; }
+if test "${ac_cv_lib_dld_shl_load+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_check_lib_save_LIBS=$LIBS
+LIBS="-ldld  $LIBS"
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char shl_load ();
+int
+main ()
+{
+return shl_load ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_lib_dld_shl_load=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_lib_dld_shl_load=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+LIBS=$ac_check_lib_save_LIBS
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dld_shl_load" >&5
+$as_echo "$ac_cv_lib_dld_shl_load" >&6; }
+if test "x$ac_cv_lib_dld_shl_load" = x""yes; then
+  lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"
+else
+  { $as_echo "$as_me:$LINENO: checking for dlopen" >&5
+$as_echo_n "checking for dlopen... " >&6; }
+if test "${ac_cv_func_dlopen+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+/* Define dlopen to an innocuous variant, in case <limits.h> declares dlopen.
+   For example, HP-UX 11i <limits.h> declares gettimeofday.  */
+#define dlopen innocuous_dlopen
+
+/* System header to define __stub macros and hopefully few prototypes,
+    which can conflict with char dlopen (); below.
+    Prefer <limits.h> to <assert.h> if __STDC__ is defined, since
+    <limits.h> exists even on freestanding compilers.  */
+
+#ifdef __STDC__
+# include <limits.h>
+#else
+# include <assert.h>
+#endif
+
+#undef dlopen
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char dlopen ();
+/* The GNU C library defines this for functions which it implements
+    to always fail with ENOSYS.  Some functions are actually named
+    something starting with __ and the normal name is an alias.  */
+#if defined __stub_dlopen || defined __stub___dlopen
+choke me
+#endif
+
+int
+main ()
+{
+return dlopen ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_func_dlopen=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_func_dlopen=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_dlopen" >&5
+$as_echo "$ac_cv_func_dlopen" >&6; }
+if test "x$ac_cv_func_dlopen" = x""yes; then
+  lt_cv_dlopen="dlopen"
+else
+  { $as_echo "$as_me:$LINENO: checking for dlopen in -ldl" >&5
+$as_echo_n "checking for dlopen in -ldl... " >&6; }
+if test "${ac_cv_lib_dl_dlopen+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_check_lib_save_LIBS=$LIBS
+LIBS="-ldl  $LIBS"
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char dlopen ();
+int
+main ()
+{
+return dlopen ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_lib_dl_dlopen=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_lib_dl_dlopen=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+LIBS=$ac_check_lib_save_LIBS
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlopen" >&5
+$as_echo "$ac_cv_lib_dl_dlopen" >&6; }
+if test "x$ac_cv_lib_dl_dlopen" = x""yes; then
+  lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"
+else
+  { $as_echo "$as_me:$LINENO: checking for dlopen in -lsvld" >&5
+$as_echo_n "checking for dlopen in -lsvld... " >&6; }
+if test "${ac_cv_lib_svld_dlopen+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_check_lib_save_LIBS=$LIBS
+LIBS="-lsvld  $LIBS"
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char dlopen ();
+int
+main ()
+{
+return dlopen ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_lib_svld_dlopen=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_lib_svld_dlopen=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+LIBS=$ac_check_lib_save_LIBS
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_svld_dlopen" >&5
+$as_echo "$ac_cv_lib_svld_dlopen" >&6; }
+if test "x$ac_cv_lib_svld_dlopen" = x""yes; then
+  lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"
+else
+  { $as_echo "$as_me:$LINENO: checking for dld_link in -ldld" >&5
+$as_echo_n "checking for dld_link in -ldld... " >&6; }
+if test "${ac_cv_lib_dld_dld_link+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_check_lib_save_LIBS=$LIBS
+LIBS="-ldld  $LIBS"
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char dld_link ();
+int
+main ()
+{
+return dld_link ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_lib_dld_dld_link=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_lib_dld_dld_link=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+LIBS=$ac_check_lib_save_LIBS
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dld_dld_link" >&5
+$as_echo "$ac_cv_lib_dld_dld_link" >&6; }
+if test "x$ac_cv_lib_dld_dld_link" = x""yes; then
+  lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"
+fi
+
+
+fi
+
+
+fi
+
+
+fi
+
+
+fi
+
+
+fi
+
+    ;;
+  esac
+
+  if test "x$lt_cv_dlopen" != xno; then
+    enable_dlopen=yes
+  else
+    enable_dlopen=no
+  fi
+
+  case $lt_cv_dlopen in
+  dlopen)
+    save_CPPFLAGS="$CPPFLAGS"
+    test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
+
+    save_LDFLAGS="$LDFLAGS"
+    wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\"
+
+    save_LIBS="$LIBS"
+    LIBS="$lt_cv_dlopen_libs $LIBS"
+
+    { $as_echo "$as_me:$LINENO: checking whether a program can dlopen itself" >&5
+$as_echo_n "checking whether a program can dlopen itself... " >&6; }
+if test "${lt_cv_dlopen_self+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+         if test "$cross_compiling" = yes; then :
+  lt_cv_dlopen_self=cross
+else
+  lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
+  lt_status=$lt_dlunknown
+  cat > conftest.$ac_ext <<_LT_EOF
+#line 11227 "configure"
+#include "confdefs.h"
+
+#if HAVE_DLFCN_H
+#include <dlfcn.h>
+#endif
+
+#include <stdio.h>
+
+#ifdef RTLD_GLOBAL
+#  define LT_DLGLOBAL          RTLD_GLOBAL
+#else
+#  ifdef DL_GLOBAL
+#    define LT_DLGLOBAL                DL_GLOBAL
+#  else
+#    define LT_DLGLOBAL                0
+#  endif
+#endif
+
+/* We may have to define LT_DLLAZY_OR_NOW in the command line if we
+   find out it does not work in some platform. */
+#ifndef LT_DLLAZY_OR_NOW
+#  ifdef RTLD_LAZY
+#    define LT_DLLAZY_OR_NOW           RTLD_LAZY
+#  else
+#    ifdef DL_LAZY
+#      define LT_DLLAZY_OR_NOW         DL_LAZY
+#    else
+#      ifdef RTLD_NOW
+#        define LT_DLLAZY_OR_NOW       RTLD_NOW
+#      else
+#        ifdef DL_NOW
+#          define LT_DLLAZY_OR_NOW     DL_NOW
+#        else
+#          define LT_DLLAZY_OR_NOW     0
+#        endif
+#      endif
+#    endif
+#  endif
+#endif
+
+void fnord() { int i=42;}
+int main ()
+{
+  void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW);
+  int status = $lt_dlunknown;
+
+  if (self)
+    {
+      if (dlsym (self,"fnord"))       status = $lt_dlno_uscore;
+      else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore;
+      /* dlclose (self); */
+    }
+  else
+    puts (dlerror ());
+
+  return status;
+}
+_LT_EOF
+  if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5
+  (eval $ac_link) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then
+    (./conftest; exit; ) >&5 2>/dev/null
+    lt_status=$?
+    case x$lt_status in
+      x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;;
+      x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;;
+      x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;;
+    esac
+  else :
+    # compilation failed
+    lt_cv_dlopen_self=no
+  fi
+fi
+rm -fr conftest*
+
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_dlopen_self" >&5
+$as_echo "$lt_cv_dlopen_self" >&6; }
+
+    if test "x$lt_cv_dlopen_self" = xyes; then
+      wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\"
+      { $as_echo "$as_me:$LINENO: checking whether a statically linked program can dlopen itself" >&5
+$as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; }
+if test "${lt_cv_dlopen_self_static+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+         if test "$cross_compiling" = yes; then :
+  lt_cv_dlopen_self_static=cross
+else
+  lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
+  lt_status=$lt_dlunknown
+  cat > conftest.$ac_ext <<_LT_EOF
+#line 11323 "configure"
+#include "confdefs.h"
+
+#if HAVE_DLFCN_H
+#include <dlfcn.h>
+#endif
+
+#include <stdio.h>
+
+#ifdef RTLD_GLOBAL
+#  define LT_DLGLOBAL          RTLD_GLOBAL
+#else
+#  ifdef DL_GLOBAL
+#    define LT_DLGLOBAL                DL_GLOBAL
+#  else
+#    define LT_DLGLOBAL                0
+#  endif
+#endif
+
+/* We may have to define LT_DLLAZY_OR_NOW in the command line if we
+   find out it does not work in some platform. */
+#ifndef LT_DLLAZY_OR_NOW
+#  ifdef RTLD_LAZY
+#    define LT_DLLAZY_OR_NOW           RTLD_LAZY
+#  else
+#    ifdef DL_LAZY
+#      define LT_DLLAZY_OR_NOW         DL_LAZY
+#    else
+#      ifdef RTLD_NOW
+#        define LT_DLLAZY_OR_NOW       RTLD_NOW
+#      else
+#        ifdef DL_NOW
+#          define LT_DLLAZY_OR_NOW     DL_NOW
+#        else
+#          define LT_DLLAZY_OR_NOW     0
+#        endif
+#      endif
+#    endif
+#  endif
+#endif
+
+void fnord() { int i=42;}
+int main ()
+{
+  void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW);
+  int status = $lt_dlunknown;
+
+  if (self)
+    {
+      if (dlsym (self,"fnord"))       status = $lt_dlno_uscore;
+      else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore;
+      /* dlclose (self); */
+    }
+  else
+    puts (dlerror ());
+
+  return status;
+}
+_LT_EOF
+  if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5
+  (eval $ac_link) 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && test -s conftest${ac_exeext} 2>/dev/null; then
+    (./conftest; exit; ) >&5 2>/dev/null
+    lt_status=$?
+    case x$lt_status in
+      x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;;
+      x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;;
+      x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;;
+    esac
+  else :
+    # compilation failed
+    lt_cv_dlopen_self_static=no
+  fi
+fi
+rm -fr conftest*
+
+
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_dlopen_self_static" >&5
+$as_echo "$lt_cv_dlopen_self_static" >&6; }
+    fi
+
+    CPPFLAGS="$save_CPPFLAGS"
+    LDFLAGS="$save_LDFLAGS"
+    LIBS="$save_LIBS"
+    ;;
+  esac
+
+  case $lt_cv_dlopen_self in
+  yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;;
+  *) enable_dlopen_self=unknown ;;
+  esac
+
+  case $lt_cv_dlopen_self_static in
+  yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;;
+  *) enable_dlopen_self_static=unknown ;;
+  esac
+fi
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+striplib=
+old_striplib=
+{ $as_echo "$as_me:$LINENO: checking whether stripping libraries is possible" >&5
+$as_echo_n "checking whether stripping libraries is possible... " >&6; }
+if test -n "$STRIP" && $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then
+  test -z "$old_striplib" && old_striplib="$STRIP --strip-debug"
+  test -z "$striplib" && striplib="$STRIP --strip-unneeded"
+  { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+else
+# FIXME - insert some real tests, host_os isn't really good enough
+  case $host_os in
+  darwin*)
+    if test -n "$STRIP" ; then
+      striplib="$STRIP -x"
+      old_striplib="$STRIP -S"
+      { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+    else
+      { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+    fi
+    ;;
+  *)
+    { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+    ;;
+  esac
+fi
+
+
+
+
+
+
+
+
+
+
+
+
+  # Report which library types will actually be built
+  { $as_echo "$as_me:$LINENO: checking if libtool supports shared libraries" >&5
+$as_echo_n "checking if libtool supports shared libraries... " >&6; }
+  { $as_echo "$as_me:$LINENO: result: $can_build_shared" >&5
+$as_echo "$can_build_shared" >&6; }
+
+  { $as_echo "$as_me:$LINENO: checking whether to build shared libraries" >&5
+$as_echo_n "checking whether to build shared libraries... " >&6; }
+  test "$can_build_shared" = "no" && enable_shared=no
+
+  # On AIX, shared libraries and static libraries use the same namespace, and
+  # are all built from PIC.
+  case $host_os in
+  aix3*)
+    test "$enable_shared" = yes && enable_static=no
+    if test -n "$RANLIB"; then
+      archive_cmds="$archive_cmds~\$RANLIB \$lib"
+      postinstall_cmds='$RANLIB $lib'
+    fi
+    ;;
+
+  aix[4-9]*)
+    if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
+      test "$enable_shared" = yes && enable_static=no
+    fi
+    ;;
+  esac
+  { $as_echo "$as_me:$LINENO: result: $enable_shared" >&5
+$as_echo "$enable_shared" >&6; }
+
+  { $as_echo "$as_me:$LINENO: checking whether to build static libraries" >&5
+$as_echo_n "checking whether to build static libraries... " >&6; }
+  # Make sure either enable_shared or enable_static is yes.
+  test "$enable_shared" = yes || enable_static=yes
+  { $as_echo "$as_me:$LINENO: result: $enable_static" >&5
+$as_echo "$enable_static" >&6; }
+
+
+
+
+fi
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
+CC="$lt_save_CC"
+
+
+
+
+
+
+
+
+
+
+
+
+
+        ac_config_commands="$ac_config_commands libtool"
+
+
+
+
+# Only expand once:
+
+
+
+ACLOCAL_AMFLAGS="-I m4"
+
+
+# Extract the first word of "doxygen", so it can be a program name with args.
+set dummy doxygen; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_HAVE_DOXYGEN+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$HAVE_DOXYGEN"; then
+  ac_cv_prog_HAVE_DOXYGEN="$HAVE_DOXYGEN" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_HAVE_DOXYGEN="true"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+  test -z "$ac_cv_prog_HAVE_DOXYGEN" && ac_cv_prog_HAVE_DOXYGEN="false"
+fi
+fi
+HAVE_DOXYGEN=$ac_cv_prog_HAVE_DOXYGEN
+if test -n "$HAVE_DOXYGEN"; then
+  { $as_echo "$as_me:$LINENO: result: $HAVE_DOXYGEN" >&5
+$as_echo "$HAVE_DOXYGEN" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+
+
+if $HAVE_DOXYGEN; then
+  HAVE_DOXYGEN_TRUE=
+  HAVE_DOXYGEN_FALSE='#'
+else
+  HAVE_DOXYGEN_TRUE='#'
+  HAVE_DOXYGEN_FALSE=
+fi
+
+if test $HAVE_DOXYGEN = "false"; then
+        { $as_echo "$as_me:$LINENO: WARNING: *** doxygen not found, API documentation will not be built" >&5
+$as_echo "$as_me: WARNING: *** doxygen not found, API documentation will not be built" >&2;}
+fi
+
+BUILD_SPEC="false"
+ac_build_spec=yes
+# Check whether --enable-spec was given.
+if test "${enable_spec+set}" = set; then
+  enableval=$enable_spec;
+       if test "x$enableval" = "xno"; then
+         ac_build_spec=$enableval
+       fi
+
+else
+
+       ac_build_spec=yes
+
+fi
+
+if test "x$ac_build_spec" = "xyes"; then
+  # Extract the first word of "pdflatex", so it can be a program name with args.
+set dummy pdflatex; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_HAVE_PDFLATEX+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$HAVE_PDFLATEX"; then
+  ac_cv_prog_HAVE_PDFLATEX="$HAVE_PDFLATEX" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_HAVE_PDFLATEX="yes"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+HAVE_PDFLATEX=$ac_cv_prog_HAVE_PDFLATEX
+if test -n "$HAVE_PDFLATEX"; then
+  { $as_echo "$as_me:$LINENO: result: $HAVE_PDFLATEX" >&5
+$as_echo "$HAVE_PDFLATEX" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  # Extract the first word of "bibtex", so it can be a program name with args.
+set dummy bibtex; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_HAVE_BIBTEX+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$HAVE_BIBTEX"; then
+  ac_cv_prog_HAVE_BIBTEX="$HAVE_BIBTEX" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_HAVE_BIBTEX="yes"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+HAVE_BIBTEX=$ac_cv_prog_HAVE_BIBTEX
+if test -n "$HAVE_BIBTEX"; then
+  { $as_echo "$as_me:$LINENO: result: $HAVE_BIBTEX" >&5
+$as_echo "$HAVE_BIBTEX" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  # Extract the first word of "fig2dev", so it can be a program name with args.
+set dummy fig2dev; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_HAVE_TRANSFIG+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$HAVE_TRANSFIG"; then
+  ac_cv_prog_HAVE_TRANSFIG="$HAVE_TRANSFIG" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_HAVE_TRANSFIG="yes"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+HAVE_TRANSFIG=$ac_cv_prog_HAVE_TRANSFIG
+if test -n "$HAVE_TRANSFIG"; then
+  { $as_echo "$as_me:$LINENO: result: $HAVE_TRANSFIG" >&5
+$as_echo "$HAVE_TRANSFIG" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  if test -r doc/spec/spec.tex; then
+   if test "x$HAVE_PDFLATEX" = "xyes"; then
+    if test "x$HAVE_BIBTEX" = "xyes"; then
+      if test "x$HAVE_TRANSFIG" = "xyes"; then
+        tex_pkg_list=`fgrep usepackage doc/spec/spec.tex | grep \{ | grep -v ltablex`
+        tex_pkg_ok="yes"
+        for pkg_line in $tex_pkg_list; do
+         pkg_name=`echo $pkg_line | sed -e 's/.*{\(.*\)}.*/\1/'`
+         { $as_echo "$as_me:$LINENO: checking for Tex package $pkg_name" >&5
+$as_echo_n "checking for Tex package $pkg_name... " >&6; }
+          cat >conftest.tex <<_ACEOF
+\\documentclass{book}
+$pkg_line
+\\begin{document}
+Hello World.
+\\end{document}
+_ACEOF
+         if pdflatex -interaction batchmode -halt-on-error conftest < /dev/null > /dev/null 2>&1; then
+            { $as_echo "$as_me:$LINENO: result: ok" >&5
+$as_echo "ok" >&6; }
+          else
+           tex_pkg_ok="no"
+           { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+          fi
+        done
+        if test -w conftest.tex; then rm conftest.tex; fi
+        if test -w conftest.tex; then rm conftest.aux; fi
+        if test -w conftest.pdf; then rm conftest.pdf; fi
+        if test "x$tex_pkg_ok" = "xyes"; then
+          BUILD_SPEC="true"
+        fi
+      fi
+    fi
+   fi
+  fi
+fi
+
+
+if $BUILD_SPEC; then
+  BUILD_SPEC_TRUE=
+  BUILD_SPEC_FALSE='#'
+else
+  BUILD_SPEC_TRUE='#'
+  BUILD_SPEC_FALSE=
+fi
+
+if test $BUILD_SPEC = "false"; then
+       { $as_echo "$as_me:$LINENO: WARNING: *** Format Specification will not built." >&5
+$as_echo "$as_me: WARNING: *** Format Specification will not built." >&2;}
+fi
+
+VALGRIND_ENVIRONMENT=""
+ac_enable_valgrind=no
+# Check whether --enable-valgrind-testing was given.
+if test "${enable_valgrind_testing+set}" = set; then
+  enableval=$enable_valgrind_testing;  ac_enable_valgrind=yes
+else
+   ac_enable_valgrind=no
+fi
+
+
+if test "x${ac_enable_valgrind}" = xyes ; then
+  if test "x${enable_shared}" = xyes ; then
+    VALGRIND_ENVIRONMENT="libtool --mode=execute "
+  fi
+
+  # Extract the first word of "valgrind", so it can be a program name with args.
+set dummy valgrind; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_HAVE_VALGRIND+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$HAVE_VALGRIND"; then
+  ac_cv_prog_HAVE_VALGRIND="$HAVE_VALGRIND" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_HAVE_VALGRIND="yes"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+  test -z "$ac_cv_prog_HAVE_VALGRIND" && ac_cv_prog_HAVE_VALGRIND="no"
+fi
+fi
+HAVE_VALGRIND=$ac_cv_prog_HAVE_VALGRIND
+if test -n "$HAVE_VALGRIND"; then
+  { $as_echo "$as_me:$LINENO: result: $HAVE_VALGRIND" >&5
+$as_echo "$HAVE_VALGRIND" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  if test "x$HAVE_VALGRIND" = xyes ; then
+    VALGRIND_ENVIRONMENT="$VALGRIND_ENVIRONMENT valgrind -q --leak-check=yes --show-reachable=yes --num-callers=100"
+
+    TESTS_INFO="Type 'make check' to run test suite. Tests will be run under:
+  ${VALGRIND_ENVIRONMENT}"
+  else
+    TESTS_INFO="Type 'make check' to run test suite (Valgrind not found)"
+  fi
+else
+  TESTS_INFO="Type 'make check' to run test suite (Valgrind testing not enabled)"
+fi
+
+
+
+cflags_save="$CFLAGS"
+if test -z "$GCC"; then
+        case $host in
+        *)
+                DEBUG="-g -DDEBUG"
+                CFLAGS="-O"
+                PROFILE="-g -p -DDEBUG" ;;
+        esac
+else
+
+        case $host in
+        *)
+                DEBUG="-g -Wall -Wno-parentheses -DDEBUG -D__NO_MATH_INLINES"
+                CFLAGS="-Wall -Wno-parentheses -O3 -fforce-addr -fomit-frame-pointer -finline-functions -funroll-loops"
+                PROFILE="-Wall -Wno-parentheses -pg -g -O3 -fno-inline-functions -DDEBUG";;
+        esac
+fi
+CFLAGS="$CFLAGS $cflags_save"
+
+cpu_x86_64=no
+cpu_x86_32=no
+# Check whether --enable-asm was given.
+if test "${enable_asm+set}" = set; then
+  enableval=$enable_asm;  ac_enable_asm=$enableval
+else
+   ac_enable_asm=yes
+fi
+
+
+if test "x${ac_enable_asm}" = xyes; then
+  cpu_optimization="no optimization for your platform, please send a patch"
+  case $target_cpu in
+  i[3456]86)
+    cpu_x86_32=yes
+    cpu_optimization="32 bit x86"
+
+cat >>confdefs.h <<\_ACEOF
+#define OC_X86_ASM /**/
+_ACEOF
+
+    if test "x$target_vendor" = "xapple"; then
+      THEORA_LDFLAGS="$THEORA_LDFLAGS  -Wl,-read_only_relocs,suppress"
+    fi
+      ;;
+  x86_64)
+    cpu_x86_64=yes
+    cpu_optimization="64 bit x86"
+
+cat >>confdefs.h <<\_ACEOF
+#define OC_X86_ASM /**/
+_ACEOF
+
+
+cat >>confdefs.h <<\_ACEOF
+#define OC_X86_64_ASM /**/
+_ACEOF
+
+    ;;
+  esac
+else
+  cpu_optimization="disabled"
+fi
+
+
+if test x$cpu_x86_64 = xyes; then
+  CPU_x86_64_TRUE=
+  CPU_x86_64_FALSE='#'
+else
+  CPU_x86_64_TRUE='#'
+  CPU_x86_64_FALSE=
+fi
+
+
+
+if test x$cpu_x86_32 = xyes; then
+  CPU_x86_32_TRUE=
+  CPU_x86_32_FALSE='#'
+else
+  CPU_x86_32_TRUE='#'
+  CPU_x86_32_FALSE=
+fi
+
+
+# Test whenever ld supports -version-script
+
+
+# Check whether --with-gnu-ld was given.
+if test "${with_gnu_ld+set}" = set; then
+  withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes
+else
+  with_gnu_ld=no
+fi
+
+ac_prog=ld
+if test "$GCC" = yes; then
+  # Check if gcc -print-prog-name=ld gives a path.
+  { $as_echo "$as_me:$LINENO: checking for ld used by $CC" >&5
+$as_echo_n "checking for ld used by $CC... " >&6; }
+  case $host in
+  *-*-mingw*)
+    # gcc leaves a trailing carriage return which upsets mingw
+    ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
+  *)
+    ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
+  esac
+  case $ac_prog in
+    # Accept absolute paths.
+    [\\/]* | ?:[\\/]*)
+      re_direlt='/[^/][^/]*/\.\./'
+      # Canonicalize the pathname of ld
+      ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'`
+      while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do
+       ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"`
+      done
+      test -z "$LD" && LD="$ac_prog"
+      ;;
+  "")
+    # If it fails, then pretend we aren't using GCC.
+    ac_prog=ld
+    ;;
+  *)
+    # If it is relative, then search for the first ld in PATH.
+    with_gnu_ld=unknown
+    ;;
+  esac
+elif test "$with_gnu_ld" = yes; then
+  { $as_echo "$as_me:$LINENO: checking for GNU ld" >&5
+$as_echo_n "checking for GNU ld... " >&6; }
+else
+  { $as_echo "$as_me:$LINENO: checking for non-GNU ld" >&5
+$as_echo_n "checking for non-GNU ld... " >&6; }
+fi
+if test "${lt_cv_path_LD+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -z "$LD"; then
+  lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+  for ac_dir in $PATH; do
+    IFS="$lt_save_ifs"
+    test -z "$ac_dir" && ac_dir=.
+    if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
+      lt_cv_path_LD="$ac_dir/$ac_prog"
+      # Check to see if the program is GNU ld.  I'd rather use --version,
+      # but apparently some variants of GNU ld only accept -v.
+      # Break only if it was the GNU/non-GNU ld that we prefer.
+      case `"$lt_cv_path_LD" -v 2>&1 </dev/null` in
+      *GNU* | *'with BFD'*)
+       test "$with_gnu_ld" != no && break
+       ;;
+      *)
+       test "$with_gnu_ld" != yes && break
+       ;;
+      esac
+    fi
+  done
+  IFS="$lt_save_ifs"
+else
+  lt_cv_path_LD="$LD" # Let the user override the test with a path.
+fi
+fi
+
+LD="$lt_cv_path_LD"
+if test -n "$LD"; then
+  { $as_echo "$as_me:$LINENO: result: $LD" >&5
+$as_echo "$LD" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+test -z "$LD" && { { $as_echo "$as_me:$LINENO: error: no acceptable ld found in \$PATH" >&5
+$as_echo "$as_me: error: no acceptable ld found in \$PATH" >&2;}
+   { (exit 1); exit 1; }; }
+{ $as_echo "$as_me:$LINENO: checking if the linker ($LD) is GNU ld" >&5
+$as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; }
+if test "${lt_cv_prog_gnu_ld+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  # I'd rather use --version here, but apparently some GNU lds only accept -v.
+case `$LD -v 2>&1 </dev/null` in
+*GNU* | *'with BFD'*)
+  lt_cv_prog_gnu_ld=yes
+  ;;
+*)
+  lt_cv_prog_gnu_ld=no
+  ;;
+esac
+fi
+{ $as_echo "$as_me:$LINENO: result: $lt_cv_prog_gnu_ld" >&5
+$as_echo "$lt_cv_prog_gnu_ld" >&6; }
+with_gnu_ld=$lt_cv_prog_gnu_ld
+
+
+
+
+
+
+
+{ $as_echo "$as_me:$LINENO: checking how to control symbol export" >&5
+$as_echo_n "checking how to control symbol export... " >&6; }
+
+THDEC_VERSION_ARG=""
+THENC_VERSION_ARG=""
+TH_VERSION_ARG=""
+if test "x$lt_cv_prog_gnu_ld" = "xyes"; then
+ case "$target_os" in
+  *mingw*)
+    THEORA_LDFLAGS="$THEORA_LDFLAGS -no-undefined"
+    THDEC_VERSION_ARG="-export-symbols \$(top_srcdir)/win32/xmingw32/libtheoradec-all.def"
+    THENC_VERSION_ARG="-export-symbols \$(top_srcdir)/win32/xmingw32/libtheoraenc-all.def"
+    THENC_VERSION_ARG="$THENC_VERSION_ARG -ltheoradec"
+    THC_VERSION_ARG="-export-symbols \$(top_srcdir)/win32/libtheora.def"
+    { $as_echo "$as_me:$LINENO: result: -export-symbols" >&5
+$as_echo "-export-symbols" >&6; }
+    ;;
+  linux* | solaris* )
+    THDEC_VERSION_ARG='-Wl,--version-script=$(srcdir)/Version_script-dec'
+    THENC_VERSION_ARG='-Wl,--version-script=$(srcdir)/Version_script-enc'
+    TH_VERSION_ARG='-Wl,--version-script=$(srcdir)/Version_script'
+    { $as_echo "$as_me:$LINENO: result: --version-script" >&5
+$as_echo "--version-script" >&6; }
+    ;;
+  *)
+    # build without versioning
+    { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+    ;;
+ esac
+else
+ case "$target_os" in
+  darwin*)
+    THDEC_VERSION_ARG='-Wl,-exported_symbols_list,$(srcdir)/theoradec.exp'
+    THENC_VERSION_ARG='-Wl,-exported_symbols_list,$(srcdir)/theoraenc.exp'
+    TH_VERSION_ARG='-Wl,-exported_symbols_list,$(srcdir)/theora.exp'
+    { $as_echo "$as_me:$LINENO: result: -exported_symbols_list" >&5
+$as_echo "-exported_symbols_list" >&6; }
+    ;;
+  *)
+    # build without versioning
+    { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+    ;;
+ esac
+fi
+
+THEORADEC_LDFLAGS="$THEORA_LDFLAGS $THDEC_VERSION_ARG"
+THEORAENC_LDFLAGS="$THEORA_LDFLAGS $THENC_VERSION_ARG"
+THEORA_LDFLAGS="$THEORA_LDFLAGS $TH_VERSION_ARG"
+
+
+
+
+
+HAVE_OGG=no
+
+
+# Extract the first word of "pkg-config", so it can be a program name with args.
+set dummy pkg-config; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_prog_HAVE_PKG_CONFIG+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  if test -n "$HAVE_PKG_CONFIG"; then
+  ac_cv_prog_HAVE_PKG_CONFIG="$HAVE_PKG_CONFIG" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_prog_HAVE_PKG_CONFIG="yes"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+fi
+fi
+HAVE_PKG_CONFIG=$ac_cv_prog_HAVE_PKG_CONFIG
+if test -n "$HAVE_PKG_CONFIG"; then
+  { $as_echo "$as_me:$LINENO: result: $HAVE_PKG_CONFIG" >&5
+$as_echo "$HAVE_PKG_CONFIG" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+if test "x$HAVE_PKG_CONFIG" = "xyes"
+then
+
+
+if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then
+       if test -n "$ac_tool_prefix"; then
+  # Extract the first word of "${ac_tool_prefix}pkg-config", so it can be a program name with args.
+set dummy ${ac_tool_prefix}pkg-config; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_path_PKG_CONFIG+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  case $PKG_CONFIG in
+  [\\/]* | ?:[\\/]*)
+  ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path.
+  ;;
+  *)
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_path_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+  ;;
+esac
+fi
+PKG_CONFIG=$ac_cv_path_PKG_CONFIG
+if test -n "$PKG_CONFIG"; then
+  { $as_echo "$as_me:$LINENO: result: $PKG_CONFIG" >&5
+$as_echo "$PKG_CONFIG" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_path_PKG_CONFIG"; then
+  ac_pt_PKG_CONFIG=$PKG_CONFIG
+  # Extract the first word of "pkg-config", so it can be a program name with args.
+set dummy pkg-config; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_path_ac_pt_PKG_CONFIG+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  case $ac_pt_PKG_CONFIG in
+  [\\/]* | ?:[\\/]*)
+  ac_cv_path_ac_pt_PKG_CONFIG="$ac_pt_PKG_CONFIG" # Let the user override the test with a path.
+  ;;
+  *)
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_path_ac_pt_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+  ;;
+esac
+fi
+ac_pt_PKG_CONFIG=$ac_cv_path_ac_pt_PKG_CONFIG
+if test -n "$ac_pt_PKG_CONFIG"; then
+  { $as_echo "$as_me:$LINENO: result: $ac_pt_PKG_CONFIG" >&5
+$as_echo "$ac_pt_PKG_CONFIG" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+  if test "x$ac_pt_PKG_CONFIG" = x; then
+    PKG_CONFIG=""
+  else
+    case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:$LINENO: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+    PKG_CONFIG=$ac_pt_PKG_CONFIG
+  fi
+else
+  PKG_CONFIG="$ac_cv_path_PKG_CONFIG"
+fi
+
+fi
+if test -n "$PKG_CONFIG"; then
+       _pkg_min_version=0.9.0
+       { $as_echo "$as_me:$LINENO: checking pkg-config is at least version $_pkg_min_version" >&5
+$as_echo_n "checking pkg-config is at least version $_pkg_min_version... " >&6; }
+       if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then
+               { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+       else
+               { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+               PKG_CONFIG=""
+       fi
+
+fi
+
+pkg_failed=no
+{ $as_echo "$as_me:$LINENO: checking for OGG" >&5
+$as_echo_n "checking for OGG... " >&6; }
+
+if test -n "$PKG_CONFIG"; then
+    if test -n "$OGG_CFLAGS"; then
+        pkg_cv_OGG_CFLAGS="$OGG_CFLAGS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"ogg >= 1.1\"") >&5
+  ($PKG_CONFIG --exists --print-errors "ogg >= 1.1") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_OGG_CFLAGS=`$PKG_CONFIG --cflags "ogg >= 1.1" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+if test -n "$PKG_CONFIG"; then
+    if test -n "$OGG_LIBS"; then
+        pkg_cv_OGG_LIBS="$OGG_LIBS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"ogg >= 1.1\"") >&5
+  ($PKG_CONFIG --exists --print-errors "ogg >= 1.1") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_OGG_LIBS=`$PKG_CONFIG --libs "ogg >= 1.1" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+
+
+
+if test $pkg_failed = yes; then
+
+if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
+        _pkg_short_errors_supported=yes
+else
+        _pkg_short_errors_supported=no
+fi
+        if test $_pkg_short_errors_supported = yes; then
+               OGG_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "ogg >= 1.1"`
+        else
+               OGG_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "ogg >= 1.1"`
+        fi
+       # Put the nasty error message in config.log where it belongs
+       echo "$OGG_PKG_ERRORS" >&5
+
+       { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+                HAVE_OGG=no
+elif test $pkg_failed = untried; then
+       HAVE_OGG=no
+else
+       OGG_CFLAGS=$pkg_cv_OGG_CFLAGS
+       OGG_LIBS=$pkg_cv_OGG_LIBS
+        { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+       HAVE_OGG=yes
+fi
+fi
+if test "x$HAVE_OGG" = "xno"
+then
+
+# Check whether --with-ogg was given.
+if test "${with_ogg+set}" = set; then
+  withval=$with_ogg; ogg_prefix="$withval"
+else
+  ogg_prefix=""
+fi
+
+
+# Check whether --with-ogg-libraries was given.
+if test "${with_ogg_libraries+set}" = set; then
+  withval=$with_ogg_libraries; ogg_libraries="$withval"
+else
+  ogg_libraries=""
+fi
+
+
+# Check whether --with-ogg-includes was given.
+if test "${with_ogg_includes+set}" = set; then
+  withval=$with_ogg_includes; ogg_includes="$withval"
+else
+  ogg_includes=""
+fi
+
+# Check whether --enable-oggtest was given.
+if test "${enable_oggtest+set}" = set; then
+  enableval=$enable_oggtest;
+else
+  enable_oggtest=yes
+fi
+
+
+  if test "x$ogg_libraries" != "x" ; then
+    OGG_LIBS="-L$ogg_libraries"
+  elif test "x$ogg_prefix" = "xno" || test "x$ogg_prefix" = "xyes" ; then
+    OGG_LIBS=""
+  elif test "x$ogg_prefix" != "x" ; then
+    OGG_LIBS="-L$ogg_prefix/lib"
+  elif test "x$prefix" != "xNONE" ; then
+    OGG_LIBS="-L$libdir"
+  fi
+
+  if test "x$ogg_prefix" != "xno" ; then
+    OGG_LIBS="$OGG_LIBS -logg"
+  fi
+
+  if test "x$ogg_includes" != "x" ; then
+    OGG_CFLAGS="-I$ogg_includes"
+  elif test "x$ogg_prefix" = "xno" || test "x$ogg_prefix" = "xyes" ; then
+    OGG_CFLAGS=""
+  elif test "x$ogg_prefix" != "x" ; then
+    OGG_CFLAGS="-I$ogg_prefix/include"
+  elif test "x$prefix" != "xNONE"; then
+    OGG_CFLAGS=""
+  fi
+
+  { $as_echo "$as_me:$LINENO: checking for Ogg" >&5
+$as_echo_n "checking for Ogg... " >&6; }
+  if test "x$ogg_prefix" = "xno" ; then
+    no_ogg="disabled"
+    enable_oggtest="no"
+  else
+    no_ogg=""
+  fi
+
+
+  if test "x$enable_oggtest" = "xyes" ; then
+    ac_save_CFLAGS="$CFLAGS"
+    ac_save_LIBS="$LIBS"
+    CFLAGS="$CFLAGS $OGG_CFLAGS"
+    LIBS="$LIBS $OGG_LIBS"
+      rm -f conf.oggtest
+      if test "$cross_compiling" = yes; then
+  echo $ac_n "cross compiling; assumed OK... $ac_c"
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+
+int main ()
+{
+  system("touch conf.oggtest");
+  return 0;
+}
+
+
+_ACEOF
+rm -f conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && { ac_try='./conftest$ac_exeext'
+  { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; }; then
+  :
+else
+  $as_echo "$as_me: program exited with status $ac_status" >&5
+$as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+( exit $ac_status )
+no_ogg=yes
+fi
+rm -rf conftest.dSYM
+rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext
+fi
+
+
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+  fi
+
+  if test "x$no_ogg" = "xdisabled" ; then
+     { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+     { { $as_echo "$as_me:$LINENO: error:
+    libogg is required to build this package!
+    please see http://www.xiph.org/ for how to
+    obtain a copy.
+  " >&5
+$as_echo "$as_me: error:
+    libogg is required to build this package!
+    please see http://www.xiph.org/ for how to
+    obtain a copy.
+  " >&2;}
+   { (exit 1); exit 1; }; }
+  elif test "x$no_ogg" = "x" ; then
+     { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+     :
+  else
+     { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+     if test -f conf.oggtest ; then
+       :
+     else
+       echo "*** Could not run Ogg test program, checking why..."
+       CFLAGS="$CFLAGS $OGG_CFLAGS"
+       LIBS="$LIBS $OGG_LIBS"
+       cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+#include <stdio.h>
+#include <ogg/ogg.h>
+
+int
+main ()
+{
+ return 0;
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+   echo "*** The test program compiled, but did not run. This usually means"
+       echo "*** that the run-time linker is not finding Ogg or finding the wrong"
+       echo "*** version of Ogg. If it is not finding Ogg, you'll need to set your"
+       echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+       echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+       echo "*** is required on your system"
+       echo "***"
+       echo "*** If you have an old version installed, it is best to remove it, although"
+       echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+        echo "*** The test program failed to compile or link. See the file config.log for the"
+       echo "*** exact error that occured. This usually means Ogg was incorrectly installed"
+       echo "*** or that you have moved Ogg since it was installed."
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+     OGG_CFLAGS=""
+     OGG_LIBS=""
+     { { $as_echo "$as_me:$LINENO: error:
+    libogg is required to build this package!
+    please see http://www.xiph.org/ for how to
+    obtain a copy.
+  " >&5
+$as_echo "$as_me: error:
+    libogg is required to build this package!
+    please see http://www.xiph.org/ for how to
+    obtain a copy.
+  " >&2;}
+   { (exit 1); exit 1; }; }
+  fi
+
+
+  rm -f conf.oggtest
+
+  cflags_save=$CFLAGS
+  libs_save=$LIBS
+  CFLAGS="$CFLAGS $OGG_CFLAGS"
+  LIBS="$LIBS $OGG_LIBS"
+  { $as_echo "$as_me:$LINENO: checking for oggpackB_read" >&5
+$as_echo_n "checking for oggpackB_read... " >&6; }
+if test "${ac_cv_func_oggpackB_read+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+/* Define oggpackB_read to an innocuous variant, in case <limits.h> declares oggpackB_read.
+   For example, HP-UX 11i <limits.h> declares gettimeofday.  */
+#define oggpackB_read innocuous_oggpackB_read
+
+/* System header to define __stub macros and hopefully few prototypes,
+    which can conflict with char oggpackB_read (); below.
+    Prefer <limits.h> to <assert.h> if __STDC__ is defined, since
+    <limits.h> exists even on freestanding compilers.  */
+
+#ifdef __STDC__
+# include <limits.h>
+#else
+# include <assert.h>
+#endif
+
+#undef oggpackB_read
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char oggpackB_read ();
+/* The GNU C library defines this for functions which it implements
+    to always fail with ENOSYS.  Some functions are actually named
+    something starting with __ and the normal name is an alias.  */
+#if defined __stub_oggpackB_read || defined __stub___oggpackB_read
+choke me
+#endif
+
+int
+main ()
+{
+return oggpackB_read ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_func_oggpackB_read=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_func_oggpackB_read=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_oggpackB_read" >&5
+$as_echo "$ac_cv_func_oggpackB_read" >&6; }
+if test "x$ac_cv_func_oggpackB_read" = x""yes; then
+  :
+else
+
+    { { $as_echo "$as_me:$LINENO: error: newer libogg version (1.1 or later) required" >&5
+$as_echo "$as_me: error: newer libogg version (1.1 or later) required" >&2;}
+   { (exit 1); exit 1; }; }
+
+fi
+
+  CFLAGS=$cflags_save
+  LIBS=$libs_save
+fi
+
+
+HAVE_VORBIS=no
+
+
+if test "x$HAVE_PKG_CONFIG" = "xyes"
+then
+
+pkg_failed=no
+{ $as_echo "$as_me:$LINENO: checking for VORBIS" >&5
+$as_echo_n "checking for VORBIS... " >&6; }
+
+if test -n "$PKG_CONFIG"; then
+    if test -n "$VORBIS_CFLAGS"; then
+        pkg_cv_VORBIS_CFLAGS="$VORBIS_CFLAGS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"vorbis >= 1.0.1\"") >&5
+  ($PKG_CONFIG --exists --print-errors "vorbis >= 1.0.1") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_VORBIS_CFLAGS=`$PKG_CONFIG --cflags "vorbis >= 1.0.1" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+if test -n "$PKG_CONFIG"; then
+    if test -n "$VORBIS_LIBS"; then
+        pkg_cv_VORBIS_LIBS="$VORBIS_LIBS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"vorbis >= 1.0.1\"") >&5
+  ($PKG_CONFIG --exists --print-errors "vorbis >= 1.0.1") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_VORBIS_LIBS=`$PKG_CONFIG --libs "vorbis >= 1.0.1" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+
+
+
+if test $pkg_failed = yes; then
+
+if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
+        _pkg_short_errors_supported=yes
+else
+        _pkg_short_errors_supported=no
+fi
+        if test $_pkg_short_errors_supported = yes; then
+               VORBIS_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "vorbis >= 1.0.1"`
+        else
+               VORBIS_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "vorbis >= 1.0.1"`
+        fi
+       # Put the nasty error message in config.log where it belongs
+       echo "$VORBIS_PKG_ERRORS" >&5
+
+       { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+                HAVE_VORBIS=no
+elif test $pkg_failed = untried; then
+       HAVE_VORBIS=no
+else
+       VORBIS_CFLAGS=$pkg_cv_VORBIS_CFLAGS
+       VORBIS_LIBS=$pkg_cv_VORBIS_LIBS
+        { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+       HAVE_VORBIS=yes
+fi
+        VORBISENC_LIBS="-lvorbisenc"
+
+fi
+if test "x$HAVE_VORBIS" = "xno"
+then
+
+# Check whether --with-vorbis was given.
+if test "${with_vorbis+set}" = set; then
+  withval=$with_vorbis; vorbis_prefix="$withval"
+else
+  vorbis_prefix=""
+fi
+
+
+# Check whether --with-vorbis-libraries was given.
+if test "${with_vorbis_libraries+set}" = set; then
+  withval=$with_vorbis_libraries; vorbis_libraries="$withval"
+else
+  vorbis_libraries=""
+fi
+
+
+# Check whether --with-vorbis-includes was given.
+if test "${with_vorbis_includes+set}" = set; then
+  withval=$with_vorbis_includes; vorbis_includes="$withval"
+else
+  vorbis_includes=""
+fi
+
+# Check whether --enable-vorbistest was given.
+if test "${enable_vorbistest+set}" = set; then
+  enableval=$enable_vorbistest;
+else
+  enable_vorbistest=yes
+fi
+
+
+  if test "x$vorbis_libraries" != "x" ; then
+    VORBIS_LIBS="-L$vorbis_libraries"
+  elif test "x$vorbis_prefix" != "x" ; then
+    VORBIS_LIBS="-L$vorbis_prefix/lib"
+  elif test "x$prefix" != "xNONE"; then
+    VORBIS_LIBS="-L$libdir"
+  fi
+
+  VORBIS_LIBS="$VORBIS_LIBS -lvorbis -lm"
+  VORBISFILE_LIBS="-lvorbisfile"
+  VORBISENC_LIBS="-lvorbisenc"
+
+  if test "x$vorbis_includes" != "x" ; then
+    VORBIS_CFLAGS="-I$vorbis_includes"
+  elif test "x$vorbis_prefix" != "x" ; then
+    VORBIS_CFLAGS="-I$vorbis_prefix/include"
+  elif test "x$prefix" != "xNONE"; then
+    VORBIS_CFLAGS=""
+  fi
+
+
+  { $as_echo "$as_me:$LINENO: checking for Vorbis" >&5
+$as_echo_n "checking for Vorbis... " >&6; }
+  no_vorbis=""
+
+
+  if test "x$enable_vorbistest" = "xyes" ; then
+    ac_save_CFLAGS="$CFLAGS"
+    ac_save_LIBS="$LIBS"
+    CFLAGS="$CFLAGS $VORBIS_CFLAGS $OGG_CFLAGS"
+    LIBS="$LIBS $VORBIS_LIBS $VORBISENC_LIBS $OGG_LIBS"
+      rm -f conf.vorbistest
+      if test "$cross_compiling" = yes; then
+  echo $ac_n "cross compiling; assumed OK... $ac_c"
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <vorbis/codec.h>
+#include <vorbis/vorbisenc.h>
+
+int main ()
+{
+    vorbis_block       vb;
+    vorbis_dsp_state   vd;
+    vorbis_info                vi;
+
+    vorbis_info_init (&vi);
+    vorbis_encode_init (&vi, 2, 44100, -1, 128000, -1);
+    vorbis_analysis_init (&vd, &vi);
+    vorbis_block_init (&vd, &vb);
+    /* this function was added in 1.0rc3, so this is what we're testing for */
+    vorbis_bitrate_addblock (&vb);
+
+    system("touch conf.vorbistest");
+    return 0;
+}
+
+
+_ACEOF
+rm -f conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && { ac_try='./conftest$ac_exeext'
+  { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; }; then
+  :
+else
+  $as_echo "$as_me: program exited with status $ac_status" >&5
+$as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+( exit $ac_status )
+no_vorbis=yes
+fi
+rm -rf conftest.dSYM
+rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext
+fi
+
+
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+  fi
+
+  if test "x$no_vorbis" = "x" ; then
+     { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+     HAVE_VORBIS=yes
+  else
+     { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+     if test -f conf.vorbistest ; then
+       :
+     else
+       echo "*** Could not run Vorbis test program, checking why..."
+       CFLAGS="$CFLAGS $VORBIS_CFLAGS"
+       LIBS="$LIBS $VORBIS_LIBS $OGG_LIBS"
+       cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+#include <stdio.h>
+#include <vorbis/codec.h>
+
+int
+main ()
+{
+ return 0;
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+   echo "*** The test program compiled, but did not run. This usually means"
+       echo "*** that the run-time linker is not finding Vorbis or finding the wrong"
+       echo "*** version of Vorbis. If it is not finding Vorbis, you'll need to set your"
+       echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+       echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+       echo "*** is required on your system"
+       echo "***"
+       echo "*** If you have an old version installed, it is best to remove it, although"
+       echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+        echo "*** The test program failed to compile or link. See the file config.log for the"
+       echo "*** exact error that occured. This usually means Vorbis was incorrectly installed"
+       echo "*** or that you have moved Vorbis since it was installed."
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+     VORBIS_CFLAGS=""
+     VORBIS_LIBS=""
+     VORBISFILE_LIBS=""
+     VORBISENC_LIBS=""
+     HAVE_VORBIS=no
+  fi
+
+
+
+
+  rm -f conf.vorbistest
+
+fi
+
+HAVE_SDL=no
+
+
+# Check whether --with-sdl-prefix was given.
+if test "${with_sdl_prefix+set}" = set; then
+  withval=$with_sdl_prefix; sdl_prefix="$withval"
+else
+  sdl_prefix=""
+fi
+
+
+# Check whether --with-sdl-exec-prefix was given.
+if test "${with_sdl_exec_prefix+set}" = set; then
+  withval=$with_sdl_exec_prefix; sdl_exec_prefix="$withval"
+else
+  sdl_exec_prefix=""
+fi
+
+# Check whether --enable-sdltest was given.
+if test "${enable_sdltest+set}" = set; then
+  enableval=$enable_sdltest;
+else
+  enable_sdltest=yes
+fi
+
+
+  if test x$sdl_exec_prefix != x ; then
+     sdl_args="$sdl_args --exec-prefix=$sdl_exec_prefix"
+     if test x${SDL_CONFIG+set} != xset ; then
+        SDL_CONFIG=$sdl_exec_prefix/bin/sdl-config
+     fi
+  fi
+  if test x$sdl_prefix != x ; then
+     sdl_args="$sdl_args --prefix=$sdl_prefix"
+     if test x${SDL_CONFIG+set} != xset ; then
+        SDL_CONFIG=$sdl_prefix/bin/sdl-config
+     fi
+  fi
+
+
+  PATH="$prefix/bin:$prefix/usr/bin:$PATH"
+  # Extract the first word of "sdl-config", so it can be a program name with args.
+set dummy sdl-config; ac_word=$2
+{ $as_echo "$as_me:$LINENO: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if test "${ac_cv_path_SDL_CONFIG+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  case $SDL_CONFIG in
+  [\\/]* | ?:[\\/]*)
+  ac_cv_path_SDL_CONFIG="$SDL_CONFIG" # Let the user override the test with a path.
+  ;;
+  *)
+  as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  for ac_exec_ext in '' $ac_executable_extensions; do
+  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then
+    ac_cv_path_SDL_CONFIG="$as_dir/$ac_word$ac_exec_ext"
+    $as_echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
+    break 2
+  fi
+done
+done
+IFS=$as_save_IFS
+
+  test -z "$ac_cv_path_SDL_CONFIG" && ac_cv_path_SDL_CONFIG="no"
+  ;;
+esac
+fi
+SDL_CONFIG=$ac_cv_path_SDL_CONFIG
+if test -n "$SDL_CONFIG"; then
+  { $as_echo "$as_me:$LINENO: result: $SDL_CONFIG" >&5
+$as_echo "$SDL_CONFIG" >&6; }
+else
+  { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+  min_sdl_version=0.11.0
+  { $as_echo "$as_me:$LINENO: checking for SDL - version >= $min_sdl_version" >&5
+$as_echo_n "checking for SDL - version >= $min_sdl_version... " >&6; }
+  no_sdl=""
+  if test "$SDL_CONFIG" = "no" ; then
+    no_sdl=yes
+  else
+    SDL_CFLAGS=`$SDL_CONFIG $sdlconf_args --cflags`
+    SDL_LIBS=`$SDL_CONFIG $sdlconf_args --libs`
+
+    sdl_major_version=`$SDL_CONFIG $sdl_args --version | \
+           sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\1/'`
+    sdl_minor_version=`$SDL_CONFIG $sdl_args --version | \
+           sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\2/'`
+    sdl_micro_version=`$SDL_CONFIG $sdl_config_args --version | \
+           sed 's/\([0-9]*\).\([0-9]*\).\([0-9]*\)/\3/'`
+    if test "x$enable_sdltest" = "xyes" ; then
+      ac_save_CFLAGS="$CFLAGS"
+      ac_save_CXXFLAGS="$CXXFLAGS"
+      ac_save_LIBS="$LIBS"
+      CFLAGS="$CFLAGS $SDL_CFLAGS"
+      CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
+      LIBS="$LIBS $SDL_LIBS"
+      rm -f conf.sdltest
+      if test "$cross_compiling" = yes; then
+  echo $ac_n "cross compiling; assumed OK... $ac_c"
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include "SDL.h"
+
+char*
+my_strdup (char *str)
+{
+  char *new_str;
+
+  if (str)
+    {
+      new_str = (char *)malloc ((strlen (str) + 1) * sizeof(char));
+      strcpy (new_str, str);
+    }
+  else
+    new_str = NULL;
+
+  return new_str;
+}
+
+int main (int argc, char *argv[])
+{
+  int major, minor, micro;
+  char *tmp_version;
+
+  /* This hangs on some systems (?)
+  system ("touch conf.sdltest");
+  */
+  { FILE *fp = fopen("conf.sdltest", "a"); if ( fp ) fclose(fp); }
+
+  /* HP/UX 9 (%@#!) writes to sscanf strings */
+  tmp_version = my_strdup("$min_sdl_version");
+  if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
+     printf("%s, bad version string\n", "$min_sdl_version");
+     exit(1);
+   }
+
+   if (($sdl_major_version > major) ||
+      (($sdl_major_version == major) && ($sdl_minor_version > minor)) ||
+      (($sdl_major_version == major) && ($sdl_minor_version == minor) && ($sdl_micro_version >= micro)))
+    {
+      return 0;
+    }
+  else
+    {
+      printf("\n*** 'sdl-config --version' returned %d.%d.%d, but the minimum version\n", $sdl_major_version, $sdl_minor_version, $sdl_micro_version);
+      printf("*** of SDL required is %d.%d.%d. If sdl-config is correct, then it is\n", major, minor, micro);
+      printf("*** best to upgrade to the required version.\n");
+      printf("*** If sdl-config was wrong, set the environment variable SDL_CONFIG\n");
+      printf("*** to point to the correct copy of sdl-config, and remove the file\n");
+      printf("*** config.cache before re-running configure\n");
+      return 1;
+    }
+}
+
+
+_ACEOF
+rm -f conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && { ac_try='./conftest$ac_exeext'
+  { (case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_try") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; }; then
+  :
+else
+  $as_echo "$as_me: program exited with status $ac_status" >&5
+$as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+( exit $ac_status )
+no_sdl=yes
+fi
+rm -rf conftest.dSYM
+rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext
+fi
+
+
+       CFLAGS="$ac_save_CFLAGS"
+       CXXFLAGS="$ac_save_CXXFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+  fi
+  if test "x$no_sdl" = x ; then
+     { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+
+  HAVE_SDL=yes
+  SDL_LIBS=`$SDL_CONFIG --libs`
+
+  else
+     { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+     if test "$SDL_CONFIG" = "no" ; then
+       echo "*** The sdl-config script installed by SDL could not be found"
+       echo "*** If SDL was installed in PREFIX, make sure PREFIX/bin is in"
+       echo "*** your path, or set the SDL_CONFIG environment variable to the"
+       echo "*** full path to sdl-config."
+     else
+       if test -f conf.sdltest ; then
+        :
+       else
+          echo "*** Could not run SDL test program, checking why..."
+          CFLAGS="$CFLAGS $SDL_CFLAGS"
+          CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
+          LIBS="$LIBS $SDL_LIBS"
+          cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+#include <stdio.h>
+#include "SDL.h"
+
+int main(int argc, char *argv[])
+{ return 0; }
+#undef  main
+#define main K_and_R_C_main
+
+int
+main ()
+{
+ return 0;
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+   echo "*** The test program compiled, but did not run. This usually means"
+          echo "*** that the run-time linker is not finding SDL or finding the wrong"
+          echo "*** version of SDL. If it is not finding SDL, you'll need to set your"
+          echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+          echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+          echo "*** is required on your system"
+         echo "***"
+          echo "*** If you have an old version installed, it is best to remove it, although"
+          echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+        echo "*** The test program failed to compile or link. See the file config.log for the"
+          echo "*** exact error that occured. This usually means SDL was incorrectly installed"
+          echo "*** or that you have moved SDL since it was installed. In the latter case, you"
+          echo "*** may want to edit the sdl-config script: $SDL_CONFIG"
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+          CFLAGS="$ac_save_CFLAGS"
+          CXXFLAGS="$ac_save_CXXFLAGS"
+          LIBS="$ac_save_LIBS"
+       fi
+     fi
+     SDL_CFLAGS=""
+     SDL_LIBS=""
+     { $as_echo "$as_me:$LINENO: WARNING: *** Unable to find SDL -- Not compiling example players ***" >&5
+$as_echo "$as_me: WARNING: *** Unable to find SDL -- Not compiling example players ***" >&2;}
+  fi
+
+
+  rm -f conf.sdltest
+
+
+HAVE_OSS=no
+
+
+
+for ac_header in sys/soundcard.h soundcard.h machine/soundcard.h
+do
+as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
+if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then
+  { $as_echo "$as_me:$LINENO: checking for $ac_header" >&5
+$as_echo_n "checking for $ac_header... " >&6; }
+if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then
+  $as_echo_n "(cached) " >&6
+fi
+ac_res=`eval 'as_val=${'$as_ac_Header'}
+                $as_echo "$as_val"'`
+              { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
+$as_echo "$ac_res" >&6; }
+else
+  # Is the header compilable?
+{ $as_echo "$as_me:$LINENO: checking $ac_header usability" >&5
+$as_echo_n "checking $ac_header usability... " >&6; }
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+$ac_includes_default
+#include <$ac_header>
+_ACEOF
+rm -f conftest.$ac_objext
+if { (ac_try="$ac_compile"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_compile") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest.$ac_objext; then
+  ac_header_compiler=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_header_compiler=no
+fi
+
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+{ $as_echo "$as_me:$LINENO: result: $ac_header_compiler" >&5
+$as_echo "$ac_header_compiler" >&6; }
+
+# Is the header present?
+{ $as_echo "$as_me:$LINENO: checking $ac_header presence" >&5
+$as_echo_n "checking $ac_header presence... " >&6; }
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+#include <$ac_header>
+_ACEOF
+if { (ac_try="$ac_cpp conftest.$ac_ext"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_cpp conftest.$ac_ext") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } >/dev/null && {
+        test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       }; then
+  ac_header_preproc=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+  ac_header_preproc=no
+fi
+
+rm -f conftest.err conftest.$ac_ext
+{ $as_echo "$as_me:$LINENO: result: $ac_header_preproc" >&5
+$as_echo "$ac_header_preproc" >&6; }
+
+# So?  What about this header?
+case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in
+  yes:no: )
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5
+$as_echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;}
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5
+$as_echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;}
+    ac_header_preproc=yes
+    ;;
+  no:yes:* )
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5
+$as_echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;}
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header:     check for missing prerequisite headers?" >&5
+$as_echo "$as_me: WARNING: $ac_header:     check for missing prerequisite headers?" >&2;}
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5
+$as_echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;}
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header:     section \"Present But Cannot Be Compiled\"" >&5
+$as_echo "$as_me: WARNING: $ac_header:     section \"Present But Cannot Be Compiled\"" >&2;}
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5
+$as_echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;}
+    { $as_echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5
+$as_echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;}
+
+    ;;
+esac
+{ $as_echo "$as_me:$LINENO: checking for $ac_header" >&5
+$as_echo_n "checking for $ac_header... " >&6; }
+if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then
+  $as_echo_n "(cached) " >&6
+else
+  eval "$as_ac_Header=\$ac_header_preproc"
+fi
+ac_res=`eval 'as_val=${'$as_ac_Header'}
+                $as_echo "$as_val"'`
+              { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
+$as_echo "$ac_res" >&6; }
+
+fi
+as_val=`eval 'as_val=${'$as_ac_Header'}
+                $as_echo "$as_val"'`
+   if test "x$as_val" = x""yes; then
+  cat >>confdefs.h <<_ACEOF
+#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
+_ACEOF
+
+  HAVE_OSS=yes
+  break
+
+fi
+
+done
+
+if test x$HAVE_OSS != xyes; then
+  { $as_echo "$as_me:$LINENO: WARNING: OSS audio support not found -- not compiling player_example" >&5
+$as_echo "$as_me: WARNING: OSS audio support not found -- not compiling player_example" >&2;}
+fi
+
+OSS_LIBS=
+case "$target_os" in
+  openbsd*)
+    OSS_LIBS='-lossaudio'
+    ;;
+esac
+
+
+HAVE_PNG=no
+if test "x$HAVE_PKG_CONFIG" = "xyes"
+then
+
+pkg_failed=no
+{ $as_echo "$as_me:$LINENO: checking for PNG" >&5
+$as_echo_n "checking for PNG... " >&6; }
+
+if test -n "$PKG_CONFIG"; then
+    if test -n "$PNG_CFLAGS"; then
+        pkg_cv_PNG_CFLAGS="$PNG_CFLAGS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"libpng\"") >&5
+  ($PKG_CONFIG --exists --print-errors "libpng") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_PNG_CFLAGS=`$PKG_CONFIG --cflags "libpng" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+if test -n "$PKG_CONFIG"; then
+    if test -n "$PNG_LIBS"; then
+        pkg_cv_PNG_LIBS="$PNG_LIBS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"libpng\"") >&5
+  ($PKG_CONFIG --exists --print-errors "libpng") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_PNG_LIBS=`$PKG_CONFIG --libs "libpng" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+
+
+
+if test $pkg_failed = yes; then
+
+if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
+        _pkg_short_errors_supported=yes
+else
+        _pkg_short_errors_supported=no
+fi
+        if test $_pkg_short_errors_supported = yes; then
+               PNG_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "libpng"`
+        else
+               PNG_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "libpng"`
+        fi
+       # Put the nasty error message in config.log where it belongs
+       echo "$PNG_PKG_ERRORS" >&5
+
+       { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+                HAVE_PNG=no
+elif test $pkg_failed = untried; then
+       HAVE_PNG=no
+else
+       PNG_CFLAGS=$pkg_cv_PNG_CFLAGS
+       PNG_LIBS=$pkg_cv_PNG_LIBS
+        { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+       HAVE_PNG=yes
+fi
+fi
+
+
+
+HAVE_CAIRO=no
+# Check whether --enable-telemetry was given.
+if test "${enable_telemetry+set}" = set; then
+  enableval=$enable_telemetry;  ac_enable_telemetry=$enableval
+else
+   ac_enable_telemetry=no
+fi
+
+
+if test "x${ac_enable_telemetry}" = xyes; then
+   if test "x$HAVE_PKG_CONFIG" = "xyes"
+   then
+
+pkg_failed=no
+{ $as_echo "$as_me:$LINENO: checking for CAIRO" >&5
+$as_echo_n "checking for CAIRO... " >&6; }
+
+if test -n "$PKG_CONFIG"; then
+    if test -n "$CAIRO_CFLAGS"; then
+        pkg_cv_CAIRO_CFLAGS="$CAIRO_CFLAGS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"cairo\"") >&5
+  ($PKG_CONFIG --exists --print-errors "cairo") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_CAIRO_CFLAGS=`$PKG_CONFIG --cflags "cairo" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+if test -n "$PKG_CONFIG"; then
+    if test -n "$CAIRO_LIBS"; then
+        pkg_cv_CAIRO_LIBS="$CAIRO_LIBS"
+    else
+        if test -n "$PKG_CONFIG" && \
+    { ($as_echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"cairo\"") >&5
+  ($PKG_CONFIG --exists --print-errors "cairo") 2>&5
+  ac_status=$?
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); }; then
+  pkg_cv_CAIRO_LIBS=`$PKG_CONFIG --libs "cairo" 2>/dev/null`
+else
+  pkg_failed=yes
+fi
+    fi
+else
+       pkg_failed=untried
+fi
+
+
+
+if test $pkg_failed = yes; then
+
+if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
+        _pkg_short_errors_supported=yes
+else
+        _pkg_short_errors_supported=no
+fi
+        if test $_pkg_short_errors_supported = yes; then
+               CAIRO_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "cairo"`
+        else
+               CAIRO_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "cairo"`
+        fi
+       # Put the nasty error message in config.log where it belongs
+       echo "$CAIRO_PKG_ERRORS" >&5
+
+       { $as_echo "$as_me:$LINENO: result: no" >&5
+$as_echo "no" >&6; }
+                HAVE_CAIRO=no
+elif test $pkg_failed = untried; then
+       HAVE_CAIRO=no
+else
+       CAIRO_CFLAGS=$pkg_cv_CAIRO_CFLAGS
+       CAIRO_LIBS=$pkg_cv_CAIRO_LIBS
+        { $as_echo "$as_me:$LINENO: result: yes" >&5
+$as_echo "yes" >&6; }
+       HAVE_CAIRO=yes
+fi
+
+cat >>confdefs.h <<\_ACEOF
+#define HAVE_CAIRO /**/
+_ACEOF
+
+   fi
+   if test x$HAVE_CAIRO != xyes; then
+     { $as_echo "$as_me:$LINENO: WARNING: libcairo not found -- not compiling telemetry output support " >&5
+$as_echo "$as_me: WARNING: libcairo not found -- not compiling telemetry output support " >&2;}
+   fi
+
+
+fi
+
+
+
+ac_enable_float=yes
+# Check whether --enable-float was given.
+if test "${enable_float+set}" = set; then
+  enableval=$enable_float;  ac_enable_float=$enableval
+else
+   ac_enable_float=yes
+fi
+
+
+if test "x${ac_enable_float}" != xyes ; then
+
+cat >>confdefs.h <<\_ACEOF
+#define THEORA_DISABLE_FLOAT /**/
+_ACEOF
+
+fi
+
+
+if test "x${ac_enable_float}" != xyes; then
+  THEORA_DISABLE_FLOAT_TRUE=
+  THEORA_DISABLE_FLOAT_FALSE='#'
+else
+  THEORA_DISABLE_FLOAT_TRUE='#'
+  THEORA_DISABLE_FLOAT_FALSE=
+fi
+
+
+
+ac_enable_encode=yes
+# Check whether --enable-encode was given.
+if test "${enable_encode+set}" = set; then
+  enableval=$enable_encode;  ac_enable_encode=$enableval
+else
+   ac_enable_encode=yes
+fi
+
+
+if test "x${ac_enable_encode}" != xyes ; then
+
+cat >>confdefs.h <<\_ACEOF
+#define THEORA_DISABLE_ENCODE /**/
+_ACEOF
+
+else
+    if test x$HAVE_VORBIS = xyes; then
+      BUILDABLE_EXAMPLES="$BUILDABLE_EXAMPLES encoder_example\$(EXEEXT)"
+    else
+      { $as_echo "$as_me:$LINENO: Vorbis missing, cannot build example encoder" >&5
+$as_echo "$as_me: Vorbis missing, cannot build example encoder" >&6;}
+    fi
+fi
+
+
+if test "x${ac_enable_encode}" != xyes; then
+  THEORA_DISABLE_ENCODE_TRUE=
+  THEORA_DISABLE_ENCODE_FALSE='#'
+else
+  THEORA_DISABLE_ENCODE_TRUE='#'
+  THEORA_DISABLE_ENCODE_FALSE=
+fi
+
+
+
+ac_enable_examples=yes
+# Check whether --enable-examples was given.
+if test "${enable_examples+set}" = set; then
+  enableval=$enable_examples;  ac_enable_examples=$enableval
+else
+   ac_enable_examples=yes
+fi
+
+
+
+if test "x${ac_enable_examples}" != xno; then
+  THEORA_ENABLE_EXAMPLES_TRUE=
+  THEORA_ENABLE_EXAMPLES_FALSE='#'
+else
+  THEORA_ENABLE_EXAMPLES_TRUE='#'
+  THEORA_ENABLE_EXAMPLES_FALSE=
+fi
+
+
+
+
+
+
+
+{ $as_echo "$as_me:$LINENO: checking for library containing ftime" >&5
+$as_echo_n "checking for library containing ftime... " >&6; }
+if test "${ac_cv_search_ftime+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  ac_func_search_save_LIBS=$LIBS
+cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char ftime ();
+int
+main ()
+{
+return ftime ();
+  ;
+  return 0;
+}
+_ACEOF
+for ac_lib in '' compat; do
+  if test -z "$ac_lib"; then
+    ac_res="none required"
+  else
+    ac_res=-l$ac_lib
+    LIBS="-l$ac_lib  $ac_func_search_save_LIBS"
+  fi
+  rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_search_ftime=$ac_res
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext
+  if test "${ac_cv_search_ftime+set}" = set; then
+  break
+fi
+done
+if test "${ac_cv_search_ftime+set}" = set; then
+  :
+else
+  ac_cv_search_ftime=no
+fi
+rm conftest.$ac_ext
+LIBS=$ac_func_search_save_LIBS
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_search_ftime" >&5
+$as_echo "$ac_cv_search_ftime" >&6; }
+ac_res=$ac_cv_search_ftime
+if test "$ac_res" != no; then
+  test "$ac_res" = "none required" || LIBS="$ac_res $LIBS"
+
+fi
+
+
+{ $as_echo "$as_me:$LINENO: checking for getopt_long" >&5
+$as_echo_n "checking for getopt_long... " >&6; }
+if test "${ac_cv_func_getopt_long+set}" = set; then
+  $as_echo_n "(cached) " >&6
+else
+  cat >conftest.$ac_ext <<_ACEOF
+/* confdefs.h.  */
+_ACEOF
+cat confdefs.h >>conftest.$ac_ext
+cat >>conftest.$ac_ext <<_ACEOF
+/* end confdefs.h.  */
+/* Define getopt_long to an innocuous variant, in case <limits.h> declares getopt_long.
+   For example, HP-UX 11i <limits.h> declares gettimeofday.  */
+#define getopt_long innocuous_getopt_long
+
+/* System header to define __stub macros and hopefully few prototypes,
+    which can conflict with char getopt_long (); below.
+    Prefer <limits.h> to <assert.h> if __STDC__ is defined, since
+    <limits.h> exists even on freestanding compilers.  */
+
+#ifdef __STDC__
+# include <limits.h>
+#else
+# include <assert.h>
+#endif
+
+#undef getopt_long
+
+/* Override any GCC internal prototype to avoid an error.
+   Use char because int might match the return type of a GCC
+   builtin and then its argument prototype would still apply.  */
+#ifdef __cplusplus
+extern "C"
+#endif
+char getopt_long ();
+/* The GNU C library defines this for functions which it implements
+    to always fail with ENOSYS.  Some functions are actually named
+    something starting with __ and the normal name is an alias.  */
+#if defined __stub_getopt_long || defined __stub___getopt_long
+choke me
+#endif
+
+int
+main ()
+{
+return getopt_long ();
+  ;
+  return 0;
+}
+_ACEOF
+rm -f conftest.$ac_objext conftest$ac_exeext
+if { (ac_try="$ac_link"
+case "(($ac_try" in
+  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;;
+  *) ac_try_echo=$ac_try;;
+esac
+eval ac_try_echo="\"\$as_me:$LINENO: $ac_try_echo\""
+$as_echo "$ac_try_echo") >&5
+  (eval "$ac_link") 2>conftest.er1
+  ac_status=$?
+  grep -v '^ *+' conftest.er1 >conftest.err
+  rm -f conftest.er1
+  cat conftest.err >&5
+  $as_echo "$as_me:$LINENO: \$? = $ac_status" >&5
+  (exit $ac_status); } && {
+        test -z "$ac_c_werror_flag" ||
+        test ! -s conftest.err
+       } && test -s conftest$ac_exeext && {
+        test "$cross_compiling" = yes ||
+        $as_test_x conftest$ac_exeext
+       }; then
+  ac_cv_func_getopt_long=yes
+else
+  $as_echo "$as_me: failed program was:" >&5
+sed 's/^/| /' conftest.$ac_ext >&5
+
+       ac_cv_func_getopt_long=no
+fi
+
+rm -rf conftest.dSYM
+rm -f core conftest.err conftest.$ac_objext conftest_ipa8_conftest.oo \
+      conftest$ac_exeext conftest.$ac_ext
+fi
+{ $as_echo "$as_me:$LINENO: result: $ac_cv_func_getopt_long" >&5
+$as_echo "$ac_cv_func_getopt_long" >&6; }
+if test "x$ac_cv_func_getopt_long" = x""yes; then
+  GETOPT_OBJS=''
+else
+  GETOPT_OBJS='getopt.$(OBJEXT) getopt1.$(OBJEXT)'
+fi
+
+
+
+if test x$HAVE_SDL = xyes -a x$HAVE_OSS = xyes -a x$HAVE_VORBIS = xyes; then
+  BUILDABLE_EXAMPLES="$BUILDABLE_EXAMPLES player_example\$(EXEEXT)"
+fi
+if test x$HAVE_PNG = xyes; then
+  BUILDABLE_EXAMPLES="$BUILDABLE_EXAMPLES png2theora\$(EXEEXT)"
+fi
+
+
+
+
+
+
+ac_config_files="$ac_config_files Makefile lib/Makefile include/Makefile include/theora/Makefile examples/Makefile doc/Makefile doc/Doxyfile doc/spec/Makefile tests/Makefile m4/Makefile libtheora.spec theora.pc theora-uninstalled.pc theoradec.pc theoradec-uninstalled.pc theoraenc.pc theoraenc-uninstalled.pc"
+
+cat >confcache <<\_ACEOF
+# This file is a shell script that caches the results of configure
+# tests run on this system so they can be shared between configure
+# scripts and configure runs, see configure's option --config-cache.
+# It is not useful on other systems.  If it contains results you don't
+# want to keep, you may remove or edit it.
+#
+# config.status only pays attention to the cache file if you give it
+# the --recheck option to rerun configure.
+#
+# `ac_cv_env_foo' variables (set or unset) will be overridden when
+# loading this file, other *unset* `ac_cv_foo' will be assigned the
+# following values.
+
+_ACEOF
+
+# The following way of writing the cache mishandles newlines in values,
+# but we know of no workaround that is simple, portable, and efficient.
+# So, we kill variables containing newlines.
+# Ultrix sh set writes to stderr and can't be redirected directly,
+# and sets the high bit in the cache file unless we assign to the vars.
+(
+  for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do
+    eval ac_val=\$$ac_var
+    case $ac_val in #(
+    *${as_nl}*)
+      case $ac_var in #(
+      *_cv_*) { $as_echo "$as_me:$LINENO: WARNING: cache variable $ac_var contains a newline" >&5
+$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;;
+      esac
+      case $ac_var in #(
+      _ | IFS | as_nl) ;; #(
+      BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #(
+      *) $as_unset $ac_var ;;
+      esac ;;
+    esac
+  done
+
+  (set) 2>&1 |
+    case $as_nl`(ac_space=' '; set) 2>&1` in #(
+    *${as_nl}ac_space=\ *)
+      # `set' does not quote correctly, so add quotes (double-quote
+      # substitution turns \\\\ into \\, and sed turns \\ into \).
+      sed -n \
+       "s/'/'\\\\''/g;
+         s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p"
+      ;; #(
+    *)
+      # `set' quotes correctly as required by POSIX, so do not add quotes.
+      sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p"
+      ;;
+    esac |
+    sort
+) |
+  sed '
+     /^ac_cv_env_/b end
+     t clear
+     :clear
+     s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/
+     t end
+     s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/
+     :end' >>confcache
+if diff "$cache_file" confcache >/dev/null 2>&1; then :; else
+  if test -w "$cache_file"; then
+    test "x$cache_file" != "x/dev/null" &&
+      { $as_echo "$as_me:$LINENO: updating cache $cache_file" >&5
+$as_echo "$as_me: updating cache $cache_file" >&6;}
+    cat confcache >$cache_file
+  else
+    { $as_echo "$as_me:$LINENO: not updating unwritable cache $cache_file" >&5
+$as_echo "$as_me: not updating unwritable cache $cache_file" >&6;}
+  fi
+fi
+rm -f confcache
+
+test "x$prefix" = xNONE && prefix=$ac_default_prefix
+# Let make expand exec_prefix.
+test "x$exec_prefix" = xNONE && exec_prefix='${prefix}'
+
+DEFS=-DHAVE_CONFIG_H
+
+ac_libobjs=
+ac_ltlibobjs=
+for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue
+  # 1. Remove the extension, and $U if already installed.
+  ac_script='s/\$U\././;s/\.o$//;s/\.obj$//'
+  ac_i=`$as_echo "$ac_i" | sed "$ac_script"`
+  # 2. Prepend LIBOBJDIR.  When used with automake>=1.10 LIBOBJDIR
+  #    will be set to the directory where LIBOBJS objects are built.
+  ac_libobjs="$ac_libobjs \${LIBOBJDIR}$ac_i\$U.$ac_objext"
+  ac_ltlibobjs="$ac_ltlibobjs \${LIBOBJDIR}$ac_i"'$U.lo'
+done
+LIBOBJS=$ac_libobjs
+
+LTLIBOBJS=$ac_ltlibobjs
+
+
+if test -z "${MAINTAINER_MODE_TRUE}" && test -z "${MAINTAINER_MODE_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"MAINTAINER_MODE\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"MAINTAINER_MODE\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"AMDEP\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"AMDEP\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${HAVE_DOXYGEN_TRUE}" && test -z "${HAVE_DOXYGEN_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"HAVE_DOXYGEN\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"HAVE_DOXYGEN\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${BUILD_SPEC_TRUE}" && test -z "${BUILD_SPEC_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"BUILD_SPEC\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"BUILD_SPEC\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${CPU_x86_64_TRUE}" && test -z "${CPU_x86_64_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"CPU_x86_64\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"CPU_x86_64\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${CPU_x86_32_TRUE}" && test -z "${CPU_x86_32_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"CPU_x86_32\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"CPU_x86_32\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${THEORA_DISABLE_FLOAT_TRUE}" && test -z "${THEORA_DISABLE_FLOAT_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"THEORA_DISABLE_FLOAT\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"THEORA_DISABLE_FLOAT\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${THEORA_DISABLE_ENCODE_TRUE}" && test -z "${THEORA_DISABLE_ENCODE_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"THEORA_DISABLE_ENCODE\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"THEORA_DISABLE_ENCODE\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+if test -z "${THEORA_ENABLE_EXAMPLES_TRUE}" && test -z "${THEORA_ENABLE_EXAMPLES_FALSE}"; then
+  { { $as_echo "$as_me:$LINENO: error: conditional \"THEORA_ENABLE_EXAMPLES\" was never defined.
+Usually this means the macro was only invoked conditionally." >&5
+$as_echo "$as_me: error: conditional \"THEORA_ENABLE_EXAMPLES\" was never defined.
+Usually this means the macro was only invoked conditionally." >&2;}
+   { (exit 1); exit 1; }; }
+fi
+
+: ${CONFIG_STATUS=./config.status}
+ac_write_fail=0
+ac_clean_files_save=$ac_clean_files
+ac_clean_files="$ac_clean_files $CONFIG_STATUS"
+{ $as_echo "$as_me:$LINENO: creating $CONFIG_STATUS" >&5
+$as_echo "$as_me: creating $CONFIG_STATUS" >&6;}
+cat >$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+#! $SHELL
+# Generated by $as_me.
+# Run this file to recreate the current configuration.
+# Compiler output produced by configure, useful for debugging
+# configure, is in config.log if it exists.
+
+debug=false
+ac_cs_recheck=false
+ac_cs_silent=false
+SHELL=\${CONFIG_SHELL-$SHELL}
+_ACEOF
+
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+## --------------------- ##
+## M4sh Initialization.  ##
+## --------------------- ##
+
+# Be more Bourne compatible
+DUALCASE=1; export DUALCASE # for MKS sh
+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
+  emulate sh
+  NULLCMD=:
+  # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
+  # is contrary to our usage.  Disable this feature.
+  alias -g '${1+"$@"}'='"$@"'
+  setopt NO_GLOB_SUBST
+else
+  case `(set -o) 2>/dev/null` in
+  *posix*) set -o posix ;;
+esac
+
+fi
+
+
+
+
+# PATH needs CR
+# Avoid depending upon Character Ranges.
+as_cr_letters='abcdefghijklmnopqrstuvwxyz'
+as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ'
+as_cr_Letters=$as_cr_letters$as_cr_LETTERS
+as_cr_digits='0123456789'
+as_cr_alnum=$as_cr_Letters$as_cr_digits
+
+as_nl='
+'
+export as_nl
+# Printing a long string crashes Solaris 7 /usr/bin/printf.
+as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\'
+as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo
+as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo
+if (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then
+  as_echo='printf %s\n'
+  as_echo_n='printf %s'
+else
+  if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then
+    as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"'
+    as_echo_n='/usr/ucb/echo -n'
+  else
+    as_echo_body='eval expr "X$1" : "X\\(.*\\)"'
+    as_echo_n_body='eval
+      arg=$1;
+      case $arg in
+      *"$as_nl"*)
+       expr "X$arg" : "X\\(.*\\)$as_nl";
+       arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;;
+      esac;
+      expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl"
+    '
+    export as_echo_n_body
+    as_echo_n='sh -c $as_echo_n_body as_echo'
+  fi
+  export as_echo_body
+  as_echo='sh -c $as_echo_body as_echo'
+fi
+
+# The user is always right.
+if test "${PATH_SEPARATOR+set}" != set; then
+  PATH_SEPARATOR=:
+  (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && {
+    (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 ||
+      PATH_SEPARATOR=';'
+  }
+fi
+
+# Support unset when possible.
+if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
+  as_unset=unset
+else
+  as_unset=false
+fi
+
+
+# IFS
+# We need space, tab and new line, in precisely that order.  Quoting is
+# there to prevent editors from complaining about space-tab.
+# (If _AS_PATH_WALK were called with IFS unset, it would disable word
+# splitting by setting IFS to empty value.)
+IFS=" ""       $as_nl"
+
+# Find who we are.  Look in the path if we contain no directory separator.
+case $0 in
+  *[\\/]* ) as_myself=$0 ;;
+  *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+  IFS=$as_save_IFS
+  test -z "$as_dir" && as_dir=.
+  test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break
+done
+IFS=$as_save_IFS
+
+     ;;
+esac
+# We did not find ourselves, most probably we were run as `sh COMMAND'
+# in which case we are not to be found in the path.
+if test "x$as_myself" = x; then
+  as_myself=$0
+fi
+if test ! -f "$as_myself"; then
+  $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2
+  { (exit 1); exit 1; }
+fi
+
+# Work around bugs in pre-3.0 UWIN ksh.
+for as_var in ENV MAIL MAILPATH
+do ($as_unset $as_var) >/dev/null 2>&1 && $as_unset $as_var
+done
+PS1='$ '
+PS2='> '
+PS4='+ '
+
+# NLS nuisances.
+LC_ALL=C
+export LC_ALL
+LANGUAGE=C
+export LANGUAGE
+
+# Required to use basename.
+if expr a : '\(a\)' >/dev/null 2>&1 &&
+   test "X`expr 00001 : '.*\(...\)'`" = X001; then
+  as_expr=expr
+else
+  as_expr=false
+fi
+
+if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then
+  as_basename=basename
+else
+  as_basename=false
+fi
+
+
+# Name of the executable.
+as_me=`$as_basename -- "$0" ||
+$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \
+        X"$0" : 'X\(//\)$' \| \
+        X"$0" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X/"$0" |
+    sed '/^.*\/\([^/][^/]*\)\/*$/{
+           s//\1/
+           q
+         }
+         /^X\/\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\/\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+
+# CDPATH.
+$as_unset CDPATH
+
+
+
+  as_lineno_1=$LINENO
+  as_lineno_2=$LINENO
+  test "x$as_lineno_1" != "x$as_lineno_2" &&
+  test "x`expr $as_lineno_1 + 1`" = "x$as_lineno_2" || {
+
+  # Create $as_me.lineno as a copy of $as_myself, but with $LINENO
+  # uniformly replaced by the line number.  The first 'sed' inserts a
+  # line-number line after each line using $LINENO; the second 'sed'
+  # does the real work.  The second script uses 'N' to pair each
+  # line-number line with the line containing $LINENO, and appends
+  # trailing '-' during substitution so that $LINENO is not a special
+  # case at line end.
+  # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the
+  # scripts with optimization help from Paolo Bonzini.  Blame Lee
+  # E. McMahon (1931-1989) for sed's syntax.  :-)
+  sed -n '
+    p
+    /[$]LINENO/=
+  ' <$as_myself |
+    sed '
+      s/[$]LINENO.*/&-/
+      t lineno
+      b
+      :lineno
+      N
+      :loop
+      s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/
+      t loop
+      s/-\n.*//
+    ' >$as_me.lineno &&
+  chmod +x "$as_me.lineno" ||
+    { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2
+   { (exit 1); exit 1; }; }
+
+  # Don't try to exec as it changes $[0], causing all sort of problems
+  # (the dirname of $[0] is not the place where we might find the
+  # original and so on.  Autoconf is especially sensitive to this).
+  . "./$as_me.lineno"
+  # Exit status is that of the last command.
+  exit
+}
+
+
+if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then
+  as_dirname=dirname
+else
+  as_dirname=false
+fi
+
+ECHO_C= ECHO_N= ECHO_T=
+case `echo -n x` in
+-n*)
+  case `echo 'x\c'` in
+  *c*) ECHO_T='        ';;     # ECHO_T is single tab character.
+  *)   ECHO_C='\c';;
+  esac;;
+*)
+  ECHO_N='-n';;
+esac
+if expr a : '\(a\)' >/dev/null 2>&1 &&
+   test "X`expr 00001 : '.*\(...\)'`" = X001; then
+  as_expr=expr
+else
+  as_expr=false
+fi
+
+rm -f conf$$ conf$$.exe conf$$.file
+if test -d conf$$.dir; then
+  rm -f conf$$.dir/conf$$.file
+else
+  rm -f conf$$.dir
+  mkdir conf$$.dir 2>/dev/null
+fi
+if (echo >conf$$.file) 2>/dev/null; then
+  if ln -s conf$$.file conf$$ 2>/dev/null; then
+    as_ln_s='ln -s'
+    # ... but there are two gotchas:
+    # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail.
+    # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable.
+    # In both cases, we have to default to `cp -p'.
+    ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe ||
+      as_ln_s='cp -p'
+  elif ln conf$$.file conf$$ 2>/dev/null; then
+    as_ln_s=ln
+  else
+    as_ln_s='cp -p'
+  fi
+else
+  as_ln_s='cp -p'
+fi
+rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file
+rmdir conf$$.dir 2>/dev/null
+
+if mkdir -p . 2>/dev/null; then
+  as_mkdir_p=:
+else
+  test -d ./-p && rmdir ./-p
+  as_mkdir_p=false
+fi
+
+if test -x / >/dev/null 2>&1; then
+  as_test_x='test -x'
+else
+  if ls -dL / >/dev/null 2>&1; then
+    as_ls_L_option=L
+  else
+    as_ls_L_option=
+  fi
+  as_test_x='
+    eval sh -c '\''
+      if test -d "$1"; then
+       test -d "$1/.";
+      else
+       case $1 in
+       -*)set "./$1";;
+       esac;
+       case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in
+       ???[sx]*):;;*)false;;esac;fi
+    '\'' sh
+  '
+fi
+as_executable_p=$as_test_x
+
+# Sed expression to map a string onto a valid CPP name.
+as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'"
+
+# Sed expression to map a string onto a valid variable name.
+as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'"
+
+
+exec 6>&1
+
+# Save the log message, to keep $[0] and so on meaningful, and to
+# report actual input values of CONFIG_FILES etc. instead of their
+# values after options handling.
+ac_log="
+This file was extended by libtheora $as_me 1.1.1, which was
+generated by GNU Autoconf 2.63.  Invocation command line was
+
+  CONFIG_FILES    = $CONFIG_FILES
+  CONFIG_HEADERS  = $CONFIG_HEADERS
+  CONFIG_LINKS    = $CONFIG_LINKS
+  CONFIG_COMMANDS = $CONFIG_COMMANDS
+  $ $0 $@
+
+on `(hostname || uname -n) 2>/dev/null | sed 1q`
+"
+
+_ACEOF
+
+case $ac_config_files in *"
+"*) set x $ac_config_files; shift; ac_config_files=$*;;
+esac
+
+case $ac_config_headers in *"
+"*) set x $ac_config_headers; shift; ac_config_headers=$*;;
+esac
+
+
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+# Files that config.status was made for.
+config_files="$ac_config_files"
+config_headers="$ac_config_headers"
+config_commands="$ac_config_commands"
+
+_ACEOF
+
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+ac_cs_usage="\
+\`$as_me' instantiates files from templates according to the
+current configuration.
+
+Usage: $0 [OPTION]... [FILE]...
+
+  -h, --help       print this help, then exit
+  -V, --version    print version number and configuration settings, then exit
+  -q, --quiet, --silent
+                   do not print progress messages
+  -d, --debug      don't remove temporary files
+      --recheck    update $as_me by reconfiguring in the same conditions
+      --file=FILE[:TEMPLATE]
+                   instantiate the configuration file FILE
+      --header=FILE[:TEMPLATE]
+                   instantiate the configuration header FILE
+
+Configuration files:
+$config_files
+
+Configuration headers:
+$config_headers
+
+Configuration commands:
+$config_commands
+
+Report bugs to <bug-autoconf@gnu.org>."
+
+_ACEOF
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+ac_cs_version="\\
+libtheora config.status 1.1.1
+configured by $0, generated by GNU Autoconf 2.63,
+  with options \\"`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`\\"
+
+Copyright (C) 2008 Free Software Foundation, Inc.
+This config.status script is free software; the Free Software Foundation
+gives unlimited permission to copy, distribute and modify it."
+
+ac_pwd='$ac_pwd'
+srcdir='$srcdir'
+INSTALL='$INSTALL'
+AWK='$AWK'
+test -n "\$AWK" || AWK=awk
+_ACEOF
+
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+# The default lists apply if the user does not specify any file.
+ac_need_defaults=:
+while test $# != 0
+do
+  case $1 in
+  --*=*)
+    ac_option=`expr "X$1" : 'X\([^=]*\)='`
+    ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'`
+    ac_shift=:
+    ;;
+  *)
+    ac_option=$1
+    ac_optarg=$2
+    ac_shift=shift
+    ;;
+  esac
+
+  case $ac_option in
+  # Handling of the options.
+  -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r)
+    ac_cs_recheck=: ;;
+  --version | --versio | --versi | --vers | --ver | --ve | --v | -V )
+    $as_echo "$ac_cs_version"; exit ;;
+  --debug | --debu | --deb | --de | --d | -d )
+    debug=: ;;
+  --file | --fil | --fi | --f )
+    $ac_shift
+    case $ac_optarg in
+    *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;;
+    esac
+    CONFIG_FILES="$CONFIG_FILES '$ac_optarg'"
+    ac_need_defaults=false;;
+  --header | --heade | --head | --hea )
+    $ac_shift
+    case $ac_optarg in
+    *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;;
+    esac
+    CONFIG_HEADERS="$CONFIG_HEADERS '$ac_optarg'"
+    ac_need_defaults=false;;
+  --he | --h)
+    # Conflict between --help and --header
+    { $as_echo "$as_me: error: ambiguous option: $1
+Try \`$0 --help' for more information." >&2
+   { (exit 1); exit 1; }; };;
+  --help | --hel | -h )
+    $as_echo "$ac_cs_usage"; exit ;;
+  -q | -quiet | --quiet | --quie | --qui | --qu | --q \
+  | -silent | --silent | --silen | --sile | --sil | --si | --s)
+    ac_cs_silent=: ;;
+
+  # This is an error.
+  -*) { $as_echo "$as_me: error: unrecognized option: $1
+Try \`$0 --help' for more information." >&2
+   { (exit 1); exit 1; }; } ;;
+
+  *) ac_config_targets="$ac_config_targets $1"
+     ac_need_defaults=false ;;
+
+  esac
+  shift
+done
+
+ac_configure_extra_args=
+
+if $ac_cs_silent; then
+  exec 6>/dev/null
+  ac_configure_extra_args="$ac_configure_extra_args --silent"
+fi
+
+_ACEOF
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+if \$ac_cs_recheck; then
+  set X '$SHELL' '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion
+  shift
+  \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6
+  CONFIG_SHELL='$SHELL'
+  export CONFIG_SHELL
+  exec "\$@"
+fi
+
+_ACEOF
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+exec 5>>config.log
+{
+  echo
+  sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX
+## Running $as_me. ##
+_ASBOX
+  $as_echo "$ac_log"
+} >&5
+
+_ACEOF
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+#
+# INIT-COMMANDS
+#
+AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
+
+
+# The HP-UX ksh and POSIX shell print the target directory to stdout
+# if CDPATH is set.
+(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
+
+sed_quote_subst='$sed_quote_subst'
+double_quote_subst='$double_quote_subst'
+delay_variable_subst='$delay_variable_subst'
+AS='`$ECHO "X$AS" | $Xsed -e "$delay_single_quote_subst"`'
+DLLTOOL='`$ECHO "X$DLLTOOL" | $Xsed -e "$delay_single_quote_subst"`'
+OBJDUMP='`$ECHO "X$OBJDUMP" | $Xsed -e "$delay_single_quote_subst"`'
+macro_version='`$ECHO "X$macro_version" | $Xsed -e "$delay_single_quote_subst"`'
+macro_revision='`$ECHO "X$macro_revision" | $Xsed -e "$delay_single_quote_subst"`'
+enable_shared='`$ECHO "X$enable_shared" | $Xsed -e "$delay_single_quote_subst"`'
+enable_static='`$ECHO "X$enable_static" | $Xsed -e "$delay_single_quote_subst"`'
+pic_mode='`$ECHO "X$pic_mode" | $Xsed -e "$delay_single_quote_subst"`'
+enable_fast_install='`$ECHO "X$enable_fast_install" | $Xsed -e "$delay_single_quote_subst"`'
+host_alias='`$ECHO "X$host_alias" | $Xsed -e "$delay_single_quote_subst"`'
+host='`$ECHO "X$host" | $Xsed -e "$delay_single_quote_subst"`'
+host_os='`$ECHO "X$host_os" | $Xsed -e "$delay_single_quote_subst"`'
+build_alias='`$ECHO "X$build_alias" | $Xsed -e "$delay_single_quote_subst"`'
+build='`$ECHO "X$build" | $Xsed -e "$delay_single_quote_subst"`'
+build_os='`$ECHO "X$build_os" | $Xsed -e "$delay_single_quote_subst"`'
+SED='`$ECHO "X$SED" | $Xsed -e "$delay_single_quote_subst"`'
+Xsed='`$ECHO "X$Xsed" | $Xsed -e "$delay_single_quote_subst"`'
+GREP='`$ECHO "X$GREP" | $Xsed -e "$delay_single_quote_subst"`'
+EGREP='`$ECHO "X$EGREP" | $Xsed -e "$delay_single_quote_subst"`'
+FGREP='`$ECHO "X$FGREP" | $Xsed -e "$delay_single_quote_subst"`'
+LD='`$ECHO "X$LD" | $Xsed -e "$delay_single_quote_subst"`'
+NM='`$ECHO "X$NM" | $Xsed -e "$delay_single_quote_subst"`'
+LN_S='`$ECHO "X$LN_S" | $Xsed -e "$delay_single_quote_subst"`'
+max_cmd_len='`$ECHO "X$max_cmd_len" | $Xsed -e "$delay_single_quote_subst"`'
+ac_objext='`$ECHO "X$ac_objext" | $Xsed -e "$delay_single_quote_subst"`'
+exeext='`$ECHO "X$exeext" | $Xsed -e "$delay_single_quote_subst"`'
+lt_unset='`$ECHO "X$lt_unset" | $Xsed -e "$delay_single_quote_subst"`'
+lt_SP2NL='`$ECHO "X$lt_SP2NL" | $Xsed -e "$delay_single_quote_subst"`'
+lt_NL2SP='`$ECHO "X$lt_NL2SP" | $Xsed -e "$delay_single_quote_subst"`'
+reload_flag='`$ECHO "X$reload_flag" | $Xsed -e "$delay_single_quote_subst"`'
+reload_cmds='`$ECHO "X$reload_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+deplibs_check_method='`$ECHO "X$deplibs_check_method" | $Xsed -e "$delay_single_quote_subst"`'
+file_magic_cmd='`$ECHO "X$file_magic_cmd" | $Xsed -e "$delay_single_quote_subst"`'
+AR='`$ECHO "X$AR" | $Xsed -e "$delay_single_quote_subst"`'
+AR_FLAGS='`$ECHO "X$AR_FLAGS" | $Xsed -e "$delay_single_quote_subst"`'
+STRIP='`$ECHO "X$STRIP" | $Xsed -e "$delay_single_quote_subst"`'
+RANLIB='`$ECHO "X$RANLIB" | $Xsed -e "$delay_single_quote_subst"`'
+old_postinstall_cmds='`$ECHO "X$old_postinstall_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+old_postuninstall_cmds='`$ECHO "X$old_postuninstall_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+old_archive_cmds='`$ECHO "X$old_archive_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+CC='`$ECHO "X$CC" | $Xsed -e "$delay_single_quote_subst"`'
+CFLAGS='`$ECHO "X$CFLAGS" | $Xsed -e "$delay_single_quote_subst"`'
+compiler='`$ECHO "X$compiler" | $Xsed -e "$delay_single_quote_subst"`'
+GCC='`$ECHO "X$GCC" | $Xsed -e "$delay_single_quote_subst"`'
+lt_cv_sys_global_symbol_pipe='`$ECHO "X$lt_cv_sys_global_symbol_pipe" | $Xsed -e "$delay_single_quote_subst"`'
+lt_cv_sys_global_symbol_to_cdecl='`$ECHO "X$lt_cv_sys_global_symbol_to_cdecl" | $Xsed -e "$delay_single_quote_subst"`'
+lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "X$lt_cv_sys_global_symbol_to_c_name_address" | $Xsed -e "$delay_single_quote_subst"`'
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "X$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $Xsed -e "$delay_single_quote_subst"`'
+objdir='`$ECHO "X$objdir" | $Xsed -e "$delay_single_quote_subst"`'
+SHELL='`$ECHO "X$SHELL" | $Xsed -e "$delay_single_quote_subst"`'
+ECHO='`$ECHO "X$ECHO" | $Xsed -e "$delay_single_quote_subst"`'
+MAGIC_CMD='`$ECHO "X$MAGIC_CMD" | $Xsed -e "$delay_single_quote_subst"`'
+lt_prog_compiler_no_builtin_flag='`$ECHO "X$lt_prog_compiler_no_builtin_flag" | $Xsed -e "$delay_single_quote_subst"`'
+lt_prog_compiler_wl='`$ECHO "X$lt_prog_compiler_wl" | $Xsed -e "$delay_single_quote_subst"`'
+lt_prog_compiler_pic='`$ECHO "X$lt_prog_compiler_pic" | $Xsed -e "$delay_single_quote_subst"`'
+lt_prog_compiler_static='`$ECHO "X$lt_prog_compiler_static" | $Xsed -e "$delay_single_quote_subst"`'
+lt_cv_prog_compiler_c_o='`$ECHO "X$lt_cv_prog_compiler_c_o" | $Xsed -e "$delay_single_quote_subst"`'
+need_locks='`$ECHO "X$need_locks" | $Xsed -e "$delay_single_quote_subst"`'
+DSYMUTIL='`$ECHO "X$DSYMUTIL" | $Xsed -e "$delay_single_quote_subst"`'
+NMEDIT='`$ECHO "X$NMEDIT" | $Xsed -e "$delay_single_quote_subst"`'
+LIPO='`$ECHO "X$LIPO" | $Xsed -e "$delay_single_quote_subst"`'
+OTOOL='`$ECHO "X$OTOOL" | $Xsed -e "$delay_single_quote_subst"`'
+OTOOL64='`$ECHO "X$OTOOL64" | $Xsed -e "$delay_single_quote_subst"`'
+libext='`$ECHO "X$libext" | $Xsed -e "$delay_single_quote_subst"`'
+shrext_cmds='`$ECHO "X$shrext_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+extract_expsyms_cmds='`$ECHO "X$extract_expsyms_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+archive_cmds_need_lc='`$ECHO "X$archive_cmds_need_lc" | $Xsed -e "$delay_single_quote_subst"`'
+enable_shared_with_static_runtimes='`$ECHO "X$enable_shared_with_static_runtimes" | $Xsed -e "$delay_single_quote_subst"`'
+export_dynamic_flag_spec='`$ECHO "X$export_dynamic_flag_spec" | $Xsed -e "$delay_single_quote_subst"`'
+whole_archive_flag_spec='`$ECHO "X$whole_archive_flag_spec" | $Xsed -e "$delay_single_quote_subst"`'
+compiler_needs_object='`$ECHO "X$compiler_needs_object" | $Xsed -e "$delay_single_quote_subst"`'
+old_archive_from_new_cmds='`$ECHO "X$old_archive_from_new_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+old_archive_from_expsyms_cmds='`$ECHO "X$old_archive_from_expsyms_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+archive_cmds='`$ECHO "X$archive_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+archive_expsym_cmds='`$ECHO "X$archive_expsym_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+module_cmds='`$ECHO "X$module_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+module_expsym_cmds='`$ECHO "X$module_expsym_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+with_gnu_ld='`$ECHO "X$with_gnu_ld" | $Xsed -e "$delay_single_quote_subst"`'
+allow_undefined_flag='`$ECHO "X$allow_undefined_flag" | $Xsed -e "$delay_single_quote_subst"`'
+no_undefined_flag='`$ECHO "X$no_undefined_flag" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_libdir_flag_spec='`$ECHO "X$hardcode_libdir_flag_spec" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_libdir_flag_spec_ld='`$ECHO "X$hardcode_libdir_flag_spec_ld" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_libdir_separator='`$ECHO "X$hardcode_libdir_separator" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_direct='`$ECHO "X$hardcode_direct" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_direct_absolute='`$ECHO "X$hardcode_direct_absolute" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_minus_L='`$ECHO "X$hardcode_minus_L" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_shlibpath_var='`$ECHO "X$hardcode_shlibpath_var" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_automatic='`$ECHO "X$hardcode_automatic" | $Xsed -e "$delay_single_quote_subst"`'
+inherit_rpath='`$ECHO "X$inherit_rpath" | $Xsed -e "$delay_single_quote_subst"`'
+link_all_deplibs='`$ECHO "X$link_all_deplibs" | $Xsed -e "$delay_single_quote_subst"`'
+fix_srcfile_path='`$ECHO "X$fix_srcfile_path" | $Xsed -e "$delay_single_quote_subst"`'
+always_export_symbols='`$ECHO "X$always_export_symbols" | $Xsed -e "$delay_single_quote_subst"`'
+export_symbols_cmds='`$ECHO "X$export_symbols_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+exclude_expsyms='`$ECHO "X$exclude_expsyms" | $Xsed -e "$delay_single_quote_subst"`'
+include_expsyms='`$ECHO "X$include_expsyms" | $Xsed -e "$delay_single_quote_subst"`'
+prelink_cmds='`$ECHO "X$prelink_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+file_list_spec='`$ECHO "X$file_list_spec" | $Xsed -e "$delay_single_quote_subst"`'
+variables_saved_for_relink='`$ECHO "X$variables_saved_for_relink" | $Xsed -e "$delay_single_quote_subst"`'
+need_lib_prefix='`$ECHO "X$need_lib_prefix" | $Xsed -e "$delay_single_quote_subst"`'
+need_version='`$ECHO "X$need_version" | $Xsed -e "$delay_single_quote_subst"`'
+version_type='`$ECHO "X$version_type" | $Xsed -e "$delay_single_quote_subst"`'
+runpath_var='`$ECHO "X$runpath_var" | $Xsed -e "$delay_single_quote_subst"`'
+shlibpath_var='`$ECHO "X$shlibpath_var" | $Xsed -e "$delay_single_quote_subst"`'
+shlibpath_overrides_runpath='`$ECHO "X$shlibpath_overrides_runpath" | $Xsed -e "$delay_single_quote_subst"`'
+libname_spec='`$ECHO "X$libname_spec" | $Xsed -e "$delay_single_quote_subst"`'
+library_names_spec='`$ECHO "X$library_names_spec" | $Xsed -e "$delay_single_quote_subst"`'
+soname_spec='`$ECHO "X$soname_spec" | $Xsed -e "$delay_single_quote_subst"`'
+postinstall_cmds='`$ECHO "X$postinstall_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+postuninstall_cmds='`$ECHO "X$postuninstall_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+finish_cmds='`$ECHO "X$finish_cmds" | $Xsed -e "$delay_single_quote_subst"`'
+finish_eval='`$ECHO "X$finish_eval" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_into_libs='`$ECHO "X$hardcode_into_libs" | $Xsed -e "$delay_single_quote_subst"`'
+sys_lib_search_path_spec='`$ECHO "X$sys_lib_search_path_spec" | $Xsed -e "$delay_single_quote_subst"`'
+sys_lib_dlsearch_path_spec='`$ECHO "X$sys_lib_dlsearch_path_spec" | $Xsed -e "$delay_single_quote_subst"`'
+hardcode_action='`$ECHO "X$hardcode_action" | $Xsed -e "$delay_single_quote_subst"`'
+enable_dlopen='`$ECHO "X$enable_dlopen" | $Xsed -e "$delay_single_quote_subst"`'
+enable_dlopen_self='`$ECHO "X$enable_dlopen_self" | $Xsed -e "$delay_single_quote_subst"`'
+enable_dlopen_self_static='`$ECHO "X$enable_dlopen_self_static" | $Xsed -e "$delay_single_quote_subst"`'
+old_striplib='`$ECHO "X$old_striplib" | $Xsed -e "$delay_single_quote_subst"`'
+striplib='`$ECHO "X$striplib" | $Xsed -e "$delay_single_quote_subst"`'
+
+LTCC='$LTCC'
+LTCFLAGS='$LTCFLAGS'
+compiler='$compiler_DEFAULT'
+
+# Quote evaled strings.
+for var in SED \
+GREP \
+EGREP \
+FGREP \
+LD \
+NM \
+LN_S \
+lt_SP2NL \
+lt_NL2SP \
+reload_flag \
+deplibs_check_method \
+file_magic_cmd \
+AR \
+AR_FLAGS \
+STRIP \
+RANLIB \
+CC \
+CFLAGS \
+compiler \
+lt_cv_sys_global_symbol_pipe \
+lt_cv_sys_global_symbol_to_cdecl \
+lt_cv_sys_global_symbol_to_c_name_address \
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \
+SHELL \
+ECHO \
+lt_prog_compiler_no_builtin_flag \
+lt_prog_compiler_wl \
+lt_prog_compiler_pic \
+lt_prog_compiler_static \
+lt_cv_prog_compiler_c_o \
+need_locks \
+DSYMUTIL \
+NMEDIT \
+LIPO \
+OTOOL \
+OTOOL64 \
+shrext_cmds \
+export_dynamic_flag_spec \
+whole_archive_flag_spec \
+compiler_needs_object \
+with_gnu_ld \
+allow_undefined_flag \
+no_undefined_flag \
+hardcode_libdir_flag_spec \
+hardcode_libdir_flag_spec_ld \
+hardcode_libdir_separator \
+fix_srcfile_path \
+exclude_expsyms \
+include_expsyms \
+file_list_spec \
+variables_saved_for_relink \
+libname_spec \
+library_names_spec \
+soname_spec \
+finish_eval \
+old_striplib \
+striplib; do
+    case \`eval \\\\\$ECHO "X\\\\\$\$var"\` in
+    *[\\\\\\\`\\"\\\$]*)
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"X\\\$\$var\\" | \\\$Xsed -e \\"\\\$sed_quote_subst\\"\\\`\\\\\\""
+      ;;
+    *)
+      eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
+      ;;
+    esac
+done
+
+# Double-quote double-evaled strings.
+for var in reload_cmds \
+old_postinstall_cmds \
+old_postuninstall_cmds \
+old_archive_cmds \
+extract_expsyms_cmds \
+old_archive_from_new_cmds \
+old_archive_from_expsyms_cmds \
+archive_cmds \
+archive_expsym_cmds \
+module_cmds \
+module_expsym_cmds \
+export_symbols_cmds \
+prelink_cmds \
+postinstall_cmds \
+postuninstall_cmds \
+finish_cmds \
+sys_lib_search_path_spec \
+sys_lib_dlsearch_path_spec; do
+    case \`eval \\\\\$ECHO "X\\\\\$\$var"\` in
+    *[\\\\\\\`\\"\\\$]*)
+      eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"X\\\$\$var\\" | \\\$Xsed -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\""
+      ;;
+    *)
+      eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
+      ;;
+    esac
+done
+
+# Fix-up fallback echo if it was mangled by the above quoting rules.
+case \$lt_ECHO in
+*'\\\$0 --fallback-echo"')  lt_ECHO=\`\$ECHO "X\$lt_ECHO" | \$Xsed -e 's/\\\\\\\\\\\\\\\$0 --fallback-echo"\$/\$0 --fallback-echo"/'\`
+  ;;
+esac
+
+ac_aux_dir='$ac_aux_dir'
+xsi_shell='$xsi_shell'
+lt_shell_append='$lt_shell_append'
+
+# See if we are running on zsh, and set the options which allow our
+# commands through without removal of \ escapes INIT.
+if test -n "\${ZSH_VERSION+set}" ; then
+   setopt NO_GLOB_SUBST
+fi
+
+
+    PACKAGE='$PACKAGE'
+    VERSION='$VERSION'
+    TIMESTAMP='$TIMESTAMP'
+    RM='$RM'
+    ofile='$ofile'
+
+
+
+
+_ACEOF
+
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+
+# Handling of arguments.
+for ac_config_target in $ac_config_targets
+do
+  case $ac_config_target in
+    "config.h") CONFIG_HEADERS="$CONFIG_HEADERS config.h" ;;
+    "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;;
+    "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;;
+    "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;;
+    "lib/Makefile") CONFIG_FILES="$CONFIG_FILES lib/Makefile" ;;
+    "include/Makefile") CONFIG_FILES="$CONFIG_FILES include/Makefile" ;;
+    "include/theora/Makefile") CONFIG_FILES="$CONFIG_FILES include/theora/Makefile" ;;
+    "examples/Makefile") CONFIG_FILES="$CONFIG_FILES examples/Makefile" ;;
+    "doc/Makefile") CONFIG_FILES="$CONFIG_FILES doc/Makefile" ;;
+    "doc/Doxyfile") CONFIG_FILES="$CONFIG_FILES doc/Doxyfile" ;;
+    "doc/spec/Makefile") CONFIG_FILES="$CONFIG_FILES doc/spec/Makefile" ;;
+    "tests/Makefile") CONFIG_FILES="$CONFIG_FILES tests/Makefile" ;;
+    "m4/Makefile") CONFIG_FILES="$CONFIG_FILES m4/Makefile" ;;
+    "libtheora.spec") CONFIG_FILES="$CONFIG_FILES libtheora.spec" ;;
+    "theora.pc") CONFIG_FILES="$CONFIG_FILES theora.pc" ;;
+    "theora-uninstalled.pc") CONFIG_FILES="$CONFIG_FILES theora-uninstalled.pc" ;;
+    "theoradec.pc") CONFIG_FILES="$CONFIG_FILES theoradec.pc" ;;
+    "theoradec-uninstalled.pc") CONFIG_FILES="$CONFIG_FILES theoradec-uninstalled.pc" ;;
+    "theoraenc.pc") CONFIG_FILES="$CONFIG_FILES theoraenc.pc" ;;
+    "theoraenc-uninstalled.pc") CONFIG_FILES="$CONFIG_FILES theoraenc-uninstalled.pc" ;;
+
+  *) { { $as_echo "$as_me:$LINENO: error: invalid argument: $ac_config_target" >&5
+$as_echo "$as_me: error: invalid argument: $ac_config_target" >&2;}
+   { (exit 1); exit 1; }; };;
+  esac
+done
+
+
+# If the user did not use the arguments to specify the items to instantiate,
+# then the envvar interface is used.  Set only those that are not.
+# We use the long form for the default assignment because of an extremely
+# bizarre bug on SunOS 4.1.3.
+if $ac_need_defaults; then
+  test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files
+  test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers
+  test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands
+fi
+
+# Have a temporary directory for convenience.  Make it in the build tree
+# simply because there is no reason against having it here, and in addition,
+# creating and moving files from /tmp can sometimes cause problems.
+# Hook for its removal unless debugging.
+# Note that there is a small window in which the directory will not be cleaned:
+# after its creation but before its name has been assigned to `$tmp'.
+$debug ||
+{
+  tmp=
+  trap 'exit_status=$?
+  { test -z "$tmp" || test ! -d "$tmp" || rm -fr "$tmp"; } && exit $exit_status
+' 0
+  trap '{ (exit 1); exit 1; }' 1 2 13 15
+}
+# Create a (secure) tmp directory for tmp files.
+
+{
+  tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` &&
+  test -n "$tmp" && test -d "$tmp"
+}  ||
+{
+  tmp=./conf$$-$RANDOM
+  (umask 077 && mkdir "$tmp")
+} ||
+{
+   $as_echo "$as_me: cannot create a temporary directory in ." >&2
+   { (exit 1); exit 1; }
+}
+
+# Set up the scripts for CONFIG_FILES section.
+# No need to generate them if there are no CONFIG_FILES.
+# This happens for instance with `./config.status config.h'.
+if test -n "$CONFIG_FILES"; then
+
+
+ac_cr='\r'
+ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' </dev/null 2>/dev/null`
+if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then
+  ac_cs_awk_cr='\\r'
+else
+  ac_cs_awk_cr=$ac_cr
+fi
+
+echo 'BEGIN {' >"$tmp/subs1.awk" &&
+_ACEOF
+
+
+{
+  echo "cat >conf$$subs.awk <<_ACEOF" &&
+  echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' &&
+  echo "_ACEOF"
+} >conf$$subs.sh ||
+  { { $as_echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
+$as_echo "$as_me: error: could not make $CONFIG_STATUS" >&2;}
+   { (exit 1); exit 1; }; }
+ac_delim_num=`echo "$ac_subst_vars" | grep -c '$'`
+ac_delim='%!_!# '
+for ac_last_try in false false false false false :; do
+  . ./conf$$subs.sh ||
+    { { $as_echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
+$as_echo "$as_me: error: could not make $CONFIG_STATUS" >&2;}
+   { (exit 1); exit 1; }; }
+
+  ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X`
+  if test $ac_delim_n = $ac_delim_num; then
+    break
+  elif $ac_last_try; then
+    { { $as_echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
+$as_echo "$as_me: error: could not make $CONFIG_STATUS" >&2;}
+   { (exit 1); exit 1; }; }
+  else
+    ac_delim="$ac_delim!$ac_delim _$ac_delim!! "
+  fi
+done
+rm -f conf$$subs.sh
+
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+cat >>"\$tmp/subs1.awk" <<\\_ACAWK &&
+_ACEOF
+sed -n '
+h
+s/^/S["/; s/!.*/"]=/
+p
+g
+s/^[^!]*!//
+:repl
+t repl
+s/'"$ac_delim"'$//
+t delim
+:nl
+h
+s/\(.\{148\}\).*/\1/
+t more1
+s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/
+p
+n
+b repl
+:more1
+s/["\\]/\\&/g; s/^/"/; s/$/"\\/
+p
+g
+s/.\{148\}//
+t nl
+:delim
+h
+s/\(.\{148\}\).*/\1/
+t more2
+s/["\\]/\\&/g; s/^/"/; s/$/"/
+p
+b
+:more2
+s/["\\]/\\&/g; s/^/"/; s/$/"\\/
+p
+g
+s/.\{148\}//
+t delim
+' <conf$$subs.awk | sed '
+/^[^""]/{
+  N
+  s/\n//
+}
+' >>$CONFIG_STATUS || ac_write_fail=1
+rm -f conf$$subs.awk
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+_ACAWK
+cat >>"\$tmp/subs1.awk" <<_ACAWK &&
+  for (key in S) S_is_set[key] = 1
+  FS = "\a"
+
+}
+{
+  line = $ 0
+  nfields = split(line, field, "@")
+  substed = 0
+  len = length(field[1])
+  for (i = 2; i < nfields; i++) {
+    key = field[i]
+    keylen = length(key)
+    if (S_is_set[key]) {
+      value = S[key]
+      line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3)
+      len += length(value) + length(field[++i])
+      substed = 1
+    } else
+      len += 1 + keylen
+  }
+
+  print line
+}
+
+_ACAWK
+_ACEOF
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then
+  sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g"
+else
+  cat
+fi < "$tmp/subs1.awk" > "$tmp/subs.awk" \
+  || { { $as_echo "$as_me:$LINENO: error: could not setup config files machinery" >&5
+$as_echo "$as_me: error: could not setup config files machinery" >&2;}
+   { (exit 1); exit 1; }; }
+_ACEOF
+
+# VPATH may cause trouble with some makes, so we remove $(srcdir),
+# ${srcdir} and @srcdir@ from VPATH if srcdir is ".", strip leading and
+# trailing colons and then remove the whole line if VPATH becomes empty
+# (actually we leave an empty line to preserve line numbers).
+if test "x$srcdir" = x.; then
+  ac_vpsub='/^[         ]*VPATH[        ]*=/{
+s/:*\$(srcdir):*/:/
+s/:*\${srcdir}:*/:/
+s/:*@srcdir@:*/:/
+s/^\([^=]*=[    ]*\):*/\1/
+s/:*$//
+s/^[^=]*=[      ]*$//
+}'
+fi
+
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+fi # test -n "$CONFIG_FILES"
+
+# Set up the scripts for CONFIG_HEADERS section.
+# No need to generate them if there are no CONFIG_HEADERS.
+# This happens for instance with `./config.status Makefile'.
+if test -n "$CONFIG_HEADERS"; then
+cat >"$tmp/defines.awk" <<\_ACAWK ||
+BEGIN {
+_ACEOF
+
+# Transform confdefs.h into an awk script `defines.awk', embedded as
+# here-document in config.status, that substitutes the proper values into
+# config.h.in to produce config.h.
+
+# Create a delimiter string that does not exist in confdefs.h, to ease
+# handling of long lines.
+ac_delim='%!_!# '
+for ac_last_try in false false :; do
+  ac_t=`sed -n "/$ac_delim/p" confdefs.h`
+  if test -z "$ac_t"; then
+    break
+  elif $ac_last_try; then
+    { { $as_echo "$as_me:$LINENO: error: could not make $CONFIG_HEADERS" >&5
+$as_echo "$as_me: error: could not make $CONFIG_HEADERS" >&2;}
+   { (exit 1); exit 1; }; }
+  else
+    ac_delim="$ac_delim!$ac_delim _$ac_delim!! "
+  fi
+done
+
+# For the awk script, D is an array of macro values keyed by name,
+# likewise P contains macro parameters if any.  Preserve backslash
+# newline sequences.
+
+ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]*
+sed -n '
+s/.\{148\}/&'"$ac_delim"'/g
+t rset
+:rset
+s/^[    ]*#[    ]*define[       ][      ]*/ /
+t def
+d
+:def
+s/\\$//
+t bsnl
+s/["\\]/\\&/g
+s/^ \('"$ac_word_re"'\)\(([^()]*)\)[    ]*\(.*\)/P["\1"]="\2"\
+D["\1"]=" \3"/p
+s/^ \('"$ac_word_re"'\)[        ]*\(.*\)/D["\1"]=" \2"/p
+d
+:bsnl
+s/["\\]/\\&/g
+s/^ \('"$ac_word_re"'\)\(([^()]*)\)[    ]*\(.*\)/P["\1"]="\2"\
+D["\1"]=" \3\\\\\\n"\\/p
+t cont
+s/^ \('"$ac_word_re"'\)[        ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p
+t cont
+d
+:cont
+n
+s/.\{148\}/&'"$ac_delim"'/g
+t clear
+:clear
+s/\\$//
+t bsnlc
+s/["\\]/\\&/g; s/^/"/; s/$/"/p
+d
+:bsnlc
+s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p
+b cont
+' <confdefs.h | sed '
+s/'"$ac_delim"'/"\\\
+"/g' >>$CONFIG_STATUS || ac_write_fail=1
+
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+  for (key in D) D_is_set[key] = 1
+  FS = "\a"
+}
+/^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ {
+  line = \$ 0
+  split(line, arg, " ")
+  if (arg[1] == "#") {
+    defundef = arg[2]
+    mac1 = arg[3]
+  } else {
+    defundef = substr(arg[1], 2)
+    mac1 = arg[2]
+  }
+  split(mac1, mac2, "(") #)
+  macro = mac2[1]
+  prefix = substr(line, 1, index(line, defundef) - 1)
+  if (D_is_set[macro]) {
+    # Preserve the white space surrounding the "#".
+    print prefix "define", macro P[macro] D[macro]
+    next
+  } else {
+    # Replace #undef with comments.  This is necessary, for example,
+    # in the case of _POSIX_SOURCE, which is predefined and required
+    # on some systems where configure will not decide to define it.
+    if (defundef == "undef") {
+      print "/*", prefix defundef, macro, "*/"
+      next
+    }
+  }
+}
+{ print }
+_ACAWK
+_ACEOF
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+  { { $as_echo "$as_me:$LINENO: error: could not setup config headers machinery" >&5
+$as_echo "$as_me: error: could not setup config headers machinery" >&2;}
+   { (exit 1); exit 1; }; }
+fi # test -n "$CONFIG_HEADERS"
+
+
+eval set X "  :F $CONFIG_FILES  :H $CONFIG_HEADERS    :C $CONFIG_COMMANDS"
+shift
+for ac_tag
+do
+  case $ac_tag in
+  :[FHLC]) ac_mode=$ac_tag; continue;;
+  esac
+  case $ac_mode$ac_tag in
+  :[FHL]*:*);;
+  :L* | :C*:*) { { $as_echo "$as_me:$LINENO: error: invalid tag $ac_tag" >&5
+$as_echo "$as_me: error: invalid tag $ac_tag" >&2;}
+   { (exit 1); exit 1; }; };;
+  :[FH]-) ac_tag=-:-;;
+  :[FH]*) ac_tag=$ac_tag:$ac_tag.in;;
+  esac
+  ac_save_IFS=$IFS
+  IFS=:
+  set x $ac_tag
+  IFS=$ac_save_IFS
+  shift
+  ac_file=$1
+  shift
+
+  case $ac_mode in
+  :L) ac_source=$1;;
+  :[FH])
+    ac_file_inputs=
+    for ac_f
+    do
+      case $ac_f in
+      -) ac_f="$tmp/stdin";;
+      *) # Look for the file first in the build tree, then in the source tree
+        # (if the path is not absolute).  The absolute path cannot be DOS-style,
+        # because $ac_f cannot contain `:'.
+        test -f "$ac_f" ||
+          case $ac_f in
+          [\\/$]*) false;;
+          *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";;
+          esac ||
+          { { $as_echo "$as_me:$LINENO: error: cannot find input file: $ac_f" >&5
+$as_echo "$as_me: error: cannot find input file: $ac_f" >&2;}
+   { (exit 1); exit 1; }; };;
+      esac
+      case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac
+      ac_file_inputs="$ac_file_inputs '$ac_f'"
+    done
+
+    # Let's still pretend it is `configure' which instantiates (i.e., don't
+    # use $as_me), people would be surprised to read:
+    #    /* config.h.  Generated by config.status.  */
+    configure_input='Generated from '`
+         $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g'
+       `' by configure.'
+    if test x"$ac_file" != x-; then
+      configure_input="$ac_file.  $configure_input"
+      { $as_echo "$as_me:$LINENO: creating $ac_file" >&5
+$as_echo "$as_me: creating $ac_file" >&6;}
+    fi
+    # Neutralize special characters interpreted by sed in replacement strings.
+    case $configure_input in #(
+    *\&* | *\|* | *\\* )
+       ac_sed_conf_input=`$as_echo "$configure_input" |
+       sed 's/[\\\\&|]/\\\\&/g'`;; #(
+    *) ac_sed_conf_input=$configure_input;;
+    esac
+
+    case $ac_tag in
+    *:-:* | *:-) cat >"$tmp/stdin" \
+      || { { $as_echo "$as_me:$LINENO: error: could not create $ac_file" >&5
+$as_echo "$as_me: error: could not create $ac_file" >&2;}
+   { (exit 1); exit 1; }; } ;;
+    esac
+    ;;
+  esac
+
+  ac_dir=`$as_dirname -- "$ac_file" ||
+$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+        X"$ac_file" : 'X\(//\)[^/]' \| \
+        X"$ac_file" : 'X\(//\)$' \| \
+        X"$ac_file" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X"$ac_file" |
+    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)[^/].*/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+  { as_dir="$ac_dir"
+  case $as_dir in #(
+  -*) as_dir=./$as_dir;;
+  esac
+  test -d "$as_dir" || { $as_mkdir_p && mkdir -p "$as_dir"; } || {
+    as_dirs=
+    while :; do
+      case $as_dir in #(
+      *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'(
+      *) as_qdir=$as_dir;;
+      esac
+      as_dirs="'$as_qdir' $as_dirs"
+      as_dir=`$as_dirname -- "$as_dir" ||
+$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+        X"$as_dir" : 'X\(//\)[^/]' \| \
+        X"$as_dir" : 'X\(//\)$' \| \
+        X"$as_dir" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X"$as_dir" |
+    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)[^/].*/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+      test -d "$as_dir" && break
+    done
+    test -z "$as_dirs" || eval "mkdir $as_dirs"
+  } || test -d "$as_dir" || { { $as_echo "$as_me:$LINENO: error: cannot create directory $as_dir" >&5
+$as_echo "$as_me: error: cannot create directory $as_dir" >&2;}
+   { (exit 1); exit 1; }; }; }
+  ac_builddir=.
+
+case "$ac_dir" in
+.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;;
+*)
+  ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'`
+  # A ".." for each directory in $ac_dir_suffix.
+  ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'`
+  case $ac_top_builddir_sub in
+  "") ac_top_builddir_sub=. ac_top_build_prefix= ;;
+  *)  ac_top_build_prefix=$ac_top_builddir_sub/ ;;
+  esac ;;
+esac
+ac_abs_top_builddir=$ac_pwd
+ac_abs_builddir=$ac_pwd$ac_dir_suffix
+# for backward compatibility:
+ac_top_builddir=$ac_top_build_prefix
+
+case $srcdir in
+  .)  # We are building in place.
+    ac_srcdir=.
+    ac_top_srcdir=$ac_top_builddir_sub
+    ac_abs_top_srcdir=$ac_pwd ;;
+  [\\/]* | ?:[\\/]* )  # Absolute name.
+    ac_srcdir=$srcdir$ac_dir_suffix;
+    ac_top_srcdir=$srcdir
+    ac_abs_top_srcdir=$srcdir ;;
+  *) # Relative name.
+    ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix
+    ac_top_srcdir=$ac_top_build_prefix$srcdir
+    ac_abs_top_srcdir=$ac_pwd/$srcdir ;;
+esac
+ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix
+
+
+  case $ac_mode in
+  :F)
+  #
+  # CONFIG_FILE
+  #
+
+  case $INSTALL in
+  [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;;
+  *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;;
+  esac
+_ACEOF
+
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+# If the template does not know about datarootdir, expand it.
+# FIXME: This hack should be removed a few years after 2.60.
+ac_datarootdir_hack=; ac_datarootdir_seen=
+
+ac_sed_dataroot='
+/datarootdir/ {
+  p
+  q
+}
+/@datadir@/p
+/@docdir@/p
+/@infodir@/p
+/@localedir@/p
+/@mandir@/p
+'
+case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in
+*datarootdir*) ac_datarootdir_seen=yes;;
+*@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*)
+  { $as_echo "$as_me:$LINENO: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5
+$as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;}
+_ACEOF
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+  ac_datarootdir_hack='
+  s&@datadir@&$datadir&g
+  s&@docdir@&$docdir&g
+  s&@infodir@&$infodir&g
+  s&@localedir@&$localedir&g
+  s&@mandir@&$mandir&g
+    s&\\\${datarootdir}&$datarootdir&g' ;;
+esac
+_ACEOF
+
+# Neutralize VPATH when `$srcdir' = `.'.
+# Shell code in configure.ac might set extrasub.
+# FIXME: do we really want to maintain this feature?
+cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
+ac_sed_extra="$ac_vpsub
+$extrasub
+_ACEOF
+cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
+:t
+/@[a-zA-Z_][a-zA-Z_0-9]*@/!b
+s|@configure_input@|$ac_sed_conf_input|;t t
+s&@top_builddir@&$ac_top_builddir_sub&;t t
+s&@top_build_prefix@&$ac_top_build_prefix&;t t
+s&@srcdir@&$ac_srcdir&;t t
+s&@abs_srcdir@&$ac_abs_srcdir&;t t
+s&@top_srcdir@&$ac_top_srcdir&;t t
+s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t
+s&@builddir@&$ac_builddir&;t t
+s&@abs_builddir@&$ac_abs_builddir&;t t
+s&@abs_top_builddir@&$ac_abs_top_builddir&;t t
+s&@INSTALL@&$ac_INSTALL&;t t
+$ac_datarootdir_hack
+"
+eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$tmp/subs.awk" >$tmp/out \
+  || { { $as_echo "$as_me:$LINENO: error: could not create $ac_file" >&5
+$as_echo "$as_me: error: could not create $ac_file" >&2;}
+   { (exit 1); exit 1; }; }
+
+test -z "$ac_datarootdir_hack$ac_datarootdir_seen" &&
+  { ac_out=`sed -n '/\${datarootdir}/p' "$tmp/out"`; test -n "$ac_out"; } &&
+  { ac_out=`sed -n '/^[         ]*datarootdir[  ]*:*=/p' "$tmp/out"`; test -z "$ac_out"; } &&
+  { $as_echo "$as_me:$LINENO: WARNING: $ac_file contains a reference to the variable \`datarootdir'
+which seems to be undefined.  Please make sure it is defined." >&5
+$as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir'
+which seems to be undefined.  Please make sure it is defined." >&2;}
+
+  rm -f "$tmp/stdin"
+  case $ac_file in
+  -) cat "$tmp/out" && rm -f "$tmp/out";;
+  *) rm -f "$ac_file" && mv "$tmp/out" "$ac_file";;
+  esac \
+  || { { $as_echo "$as_me:$LINENO: error: could not create $ac_file" >&5
+$as_echo "$as_me: error: could not create $ac_file" >&2;}
+   { (exit 1); exit 1; }; }
+ ;;
+  :H)
+  #
+  # CONFIG_HEADER
+  #
+  if test x"$ac_file" != x-; then
+    {
+      $as_echo "/* $configure_input  */" \
+      && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs"
+    } >"$tmp/config.h" \
+      || { { $as_echo "$as_me:$LINENO: error: could not create $ac_file" >&5
+$as_echo "$as_me: error: could not create $ac_file" >&2;}
+   { (exit 1); exit 1; }; }
+    if diff "$ac_file" "$tmp/config.h" >/dev/null 2>&1; then
+      { $as_echo "$as_me:$LINENO: $ac_file is unchanged" >&5
+$as_echo "$as_me: $ac_file is unchanged" >&6;}
+    else
+      rm -f "$ac_file"
+      mv "$tmp/config.h" "$ac_file" \
+       || { { $as_echo "$as_me:$LINENO: error: could not create $ac_file" >&5
+$as_echo "$as_me: error: could not create $ac_file" >&2;}
+   { (exit 1); exit 1; }; }
+    fi
+  else
+    $as_echo "/* $configure_input  */" \
+      && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" \
+      || { { $as_echo "$as_me:$LINENO: error: could not create -" >&5
+$as_echo "$as_me: error: could not create -" >&2;}
+   { (exit 1); exit 1; }; }
+  fi
+ ;;
+
+  :C)  { $as_echo "$as_me:$LINENO: executing $ac_file commands" >&5
+$as_echo "$as_me: executing $ac_file commands" >&6;}
+ ;;
+  esac
+
+
+  case $ac_file$ac_mode in
+    "config.h":H) # update the timestamp
+echo 'timestamp for config.h' >"./stamp-h1"
+ ;;
+    "depfiles":C) test x"$AMDEP_TRUE" != x"" || for mf in $CONFIG_FILES; do
+  # Strip MF so we end up with the name of the file.
+  mf=`echo "$mf" | sed -e 's/:.*$//'`
+  # Check whether this is an Automake generated Makefile or not.
+  # We used to match only the files named `Makefile.in', but
+  # some people rename them; so instead we look at the file content.
+  # Grep'ing the first line is not enough: some people post-process
+  # each Makefile.in and add a new line on top of each file to say so.
+  # So let's grep whole file.
+  if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then
+    dirpart=`$as_dirname -- "$mf" ||
+$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+        X"$mf" : 'X\(//\)[^/]' \| \
+        X"$mf" : 'X\(//\)$' \| \
+        X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X"$mf" |
+    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)[^/].*/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+  else
+    continue
+  fi
+  grep '^DEP_FILES *= *[^ #]' < "$mf" > /dev/null || continue
+  # Extract the definition of DEP_FILES from the Makefile without
+  # running `make'.
+  DEPDIR=`sed -n -e '/^DEPDIR = / s///p' < "$mf"`
+  test -z "$DEPDIR" && continue
+  # When using ansi2knr, U may be empty or an underscore; expand it
+  U=`sed -n -e '/^U = / s///p' < "$mf"`
+  test -d "$dirpart/$DEPDIR" || mkdir "$dirpart/$DEPDIR"
+  # We invoke sed twice because it is the simplest approach to
+  # changing $(DEPDIR) to its actual value in the expansion.
+  for file in `sed -n -e '
+    /^DEP_FILES = .*\\\\$/ {
+      s/^DEP_FILES = //
+      :loop
+       s/\\\\$//
+       p
+       n
+       /\\\\$/ b loop
+      p
+    }
+    /^DEP_FILES = / s/^DEP_FILES = //p' < "$mf" | \
+       sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do
+    # Make sure the directory exists.
+    test -f "$dirpart/$file" && continue
+    fdir=`$as_dirname -- "$file" ||
+$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+        X"$file" : 'X\(//\)[^/]' \| \
+        X"$file" : 'X\(//\)$' \| \
+        X"$file" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X"$file" |
+    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)[^/].*/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+    { as_dir=$dirpart/$fdir
+  case $as_dir in #(
+  -*) as_dir=./$as_dir;;
+  esac
+  test -d "$as_dir" || { $as_mkdir_p && mkdir -p "$as_dir"; } || {
+    as_dirs=
+    while :; do
+      case $as_dir in #(
+      *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'(
+      *) as_qdir=$as_dir;;
+      esac
+      as_dirs="'$as_qdir' $as_dirs"
+      as_dir=`$as_dirname -- "$as_dir" ||
+$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+        X"$as_dir" : 'X\(//\)[^/]' \| \
+        X"$as_dir" : 'X\(//\)$' \| \
+        X"$as_dir" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X"$as_dir" |
+    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)[^/].*/{
+           s//\1/
+           q
+         }
+         /^X\(\/\/\)$/{
+           s//\1/
+           q
+         }
+         /^X\(\/\).*/{
+           s//\1/
+           q
+         }
+         s/.*/./; q'`
+      test -d "$as_dir" && break
+    done
+    test -z "$as_dirs" || eval "mkdir $as_dirs"
+  } || test -d "$as_dir" || { { $as_echo "$as_me:$LINENO: error: cannot create directory $as_dir" >&5
+$as_echo "$as_me: error: cannot create directory $as_dir" >&2;}
+   { (exit 1); exit 1; }; }; }
+    # echo "creating $dirpart/$file"
+    echo '# dummy' > "$dirpart/$file"
+  done
+done
+ ;;
+    "libtool":C)
+
+    # See if we are running on zsh, and set the options which allow our
+    # commands through without removal of \ escapes.
+    if test -n "${ZSH_VERSION+set}" ; then
+      setopt NO_GLOB_SUBST
+    fi
+
+    cfgfile="${ofile}T"
+    trap "$RM \"$cfgfile\"; exit 1" 1 2 15
+    $RM "$cfgfile"
+
+    cat <<_LT_EOF >> "$cfgfile"
+#! $SHELL
+
+# `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services.
+# Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION
+# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`:
+# NOTE: Changes made to this file will be lost: look at ltmain.sh.
+#
+#   Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
+#                 2006, 2007, 2008 Free Software Foundation, Inc.
+#   Written by Gordon Matzigkeit, 1996
+#
+#   This file is part of GNU Libtool.
+#
+# GNU Libtool 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.
+#
+# As a special exception to the GNU General Public License,
+# if you distribute this file as part of a program or library that
+# is built using GNU Libtool, you may include this file under the
+# same distribution terms that you use for the rest of that program.
+#
+# GNU Libtool 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 GNU Libtool; see the file COPYING.  If not, a copy
+# can be downloaded from http://www.gnu.org/licenses/gpl.html, or
+# obtained by writing to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+
+
+# The names of the tagged configurations supported by this script.
+available_tags=""
+
+# ### BEGIN LIBTOOL CONFIG
+
+# Assembler program.
+AS=$AS
+
+# DLL creation program.
+DLLTOOL=$DLLTOOL
+
+# Object dumper program.
+OBJDUMP=$OBJDUMP
+
+# Which release of libtool.m4 was used?
+macro_version=$macro_version
+macro_revision=$macro_revision
+
+# Whether or not to build shared libraries.
+build_libtool_libs=$enable_shared
+
+# Whether or not to build static libraries.
+build_old_libs=$enable_static
+
+# What type of objects to build.
+pic_mode=$pic_mode
+
+# Whether or not to optimize for fast installation.
+fast_install=$enable_fast_install
+
+# The host system.
+host_alias=$host_alias
+host=$host
+host_os=$host_os
+
+# The build system.
+build_alias=$build_alias
+build=$build
+build_os=$build_os
+
+# A sed program that does not truncate output.
+SED=$lt_SED
+
+# Sed that helps us avoid accidentally triggering echo(1) options like -n.
+Xsed="\$SED -e 1s/^X//"
+
+# A grep program that handles long lines.
+GREP=$lt_GREP
+
+# An ERE matcher.
+EGREP=$lt_EGREP
+
+# A literal string matcher.
+FGREP=$lt_FGREP
+
+# A BSD- or MS-compatible name lister.
+NM=$lt_NM
+
+# Whether we need soft or hard links.
+LN_S=$lt_LN_S
+
+# What is the maximum length of a command?
+max_cmd_len=$max_cmd_len
+
+# Object file suffix (normally "o").
+objext=$ac_objext
+
+# Executable file suffix (normally "").
+exeext=$exeext
+
+# whether the shell understands "unset".
+lt_unset=$lt_unset
+
+# turn spaces into newlines.
+SP2NL=$lt_lt_SP2NL
+
+# turn newlines into spaces.
+NL2SP=$lt_lt_NL2SP
+
+# How to create reloadable object files.
+reload_flag=$lt_reload_flag
+reload_cmds=$lt_reload_cmds
+
+# Method to check whether dependent libraries are shared objects.
+deplibs_check_method=$lt_deplibs_check_method
+
+# Command to use when deplibs_check_method == "file_magic".
+file_magic_cmd=$lt_file_magic_cmd
+
+# The archiver.
+AR=$lt_AR
+AR_FLAGS=$lt_AR_FLAGS
+
+# A symbol stripping program.
+STRIP=$lt_STRIP
+
+# Commands used to install an old-style archive.
+RANLIB=$lt_RANLIB
+old_postinstall_cmds=$lt_old_postinstall_cmds
+old_postuninstall_cmds=$lt_old_postuninstall_cmds
+
+# A C compiler.
+LTCC=$lt_CC
+
+# LTCC compiler flags.
+LTCFLAGS=$lt_CFLAGS
+
+# Take the output of nm and produce a listing of raw symbols and C names.
+global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe
+
+# Transform the output of nm in a proper C declaration.
+global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl
+
+# Transform the output of nm in a C name address pair.
+global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address
+
+# Transform the output of nm in a C name address pair when lib prefix is needed.
+global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix
+
+# The name of the directory that contains temporary libtool files.
+objdir=$objdir
+
+# Shell to use when invoking shell scripts.
+SHELL=$lt_SHELL
+
+# An echo program that does not interpret backslashes.
+ECHO=$lt_ECHO
+
+# Used to examine libraries when file_magic_cmd begins with "file".
+MAGIC_CMD=$MAGIC_CMD
+
+# Must we lock files when doing compilation?
+need_locks=$lt_need_locks
+
+# Tool to manipulate archived DWARF debug symbol files on Mac OS X.
+DSYMUTIL=$lt_DSYMUTIL
+
+# Tool to change global to local symbols on Mac OS X.
+NMEDIT=$lt_NMEDIT
+
+# Tool to manipulate fat objects and archives on Mac OS X.
+LIPO=$lt_LIPO
+
+# ldd/readelf like tool for Mach-O binaries on Mac OS X.
+OTOOL=$lt_OTOOL
+
+# ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4.
+OTOOL64=$lt_OTOOL64
+
+# Old archive suffix (normally "a").
+libext=$libext
+
+# Shared library suffix (normally ".so").
+shrext_cmds=$lt_shrext_cmds
+
+# The commands to extract the exported symbol list from a shared archive.
+extract_expsyms_cmds=$lt_extract_expsyms_cmds
+
+# Variables whose values should be saved in libtool wrapper scripts and
+# restored at link time.
+variables_saved_for_relink=$lt_variables_saved_for_relink
+
+# Do we need the "lib" prefix for modules?
+need_lib_prefix=$need_lib_prefix
+
+# Do we need a version for libraries?
+need_version=$need_version
+
+# Library versioning type.
+version_type=$version_type
+
+# Shared library runtime path variable.
+runpath_var=$runpath_var
+
+# Shared library path variable.
+shlibpath_var=$shlibpath_var
+
+# Is shlibpath searched before the hard-coded library search path?
+shlibpath_overrides_runpath=$shlibpath_overrides_runpath
+
+# Format of library name prefix.
+libname_spec=$lt_libname_spec
+
+# List of archive names.  First name is the real one, the rest are links.
+# The last name is the one that the linker finds with -lNAME
+library_names_spec=$lt_library_names_spec
+
+# The coded name of the library, if different from the real name.
+soname_spec=$lt_soname_spec
+
+# Command to use after installation of a shared archive.
+postinstall_cmds=$lt_postinstall_cmds
+
+# Command to use after uninstallation of a shared archive.
+postuninstall_cmds=$lt_postuninstall_cmds
+
+# Commands used to finish a libtool library installation in a directory.
+finish_cmds=$lt_finish_cmds
+
+# As "finish_cmds", except a single script fragment to be evaled but
+# not shown.
+finish_eval=$lt_finish_eval
+
+# Whether we should hardcode library paths into libraries.
+hardcode_into_libs=$hardcode_into_libs
+
+# Compile-time system search path for libraries.
+sys_lib_search_path_spec=$lt_sys_lib_search_path_spec
+
+# Run-time system search path for libraries.
+sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec
+
+# Whether dlopen is supported.
+dlopen_support=$enable_dlopen
+
+# Whether dlopen of programs is supported.
+dlopen_self=$enable_dlopen_self
+
+# Whether dlopen of statically linked programs is supported.
+dlopen_self_static=$enable_dlopen_self_static
+
+# Commands to strip libraries.
+old_striplib=$lt_old_striplib
+striplib=$lt_striplib
+
+
+# The linker used to build libraries.
+LD=$lt_LD
+
+# Commands used to build an old-style archive.
+old_archive_cmds=$lt_old_archive_cmds
+
+# A language specific compiler.
+CC=$lt_compiler
+
+# Is the compiler the GNU compiler?
+with_gcc=$GCC
+
+# Compiler flag to turn off builtin functions.
+no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag
+
+# How to pass a linker flag through the compiler.
+wl=$lt_lt_prog_compiler_wl
+
+# Additional compiler flags for building library objects.
+pic_flag=$lt_lt_prog_compiler_pic
+
+# Compiler flag to prevent dynamic linking.
+link_static_flag=$lt_lt_prog_compiler_static
+
+# Does compiler simultaneously support -c and -o options?
+compiler_c_o=$lt_lt_cv_prog_compiler_c_o
+
+# Whether or not to add -lc for building shared libraries.
+build_libtool_need_lc=$archive_cmds_need_lc
+
+# Whether or not to disallow shared libs when runtime libs are static.
+allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes
+
+# Compiler flag to allow reflexive dlopens.
+export_dynamic_flag_spec=$lt_export_dynamic_flag_spec
+
+# Compiler flag to generate shared objects directly from archives.
+whole_archive_flag_spec=$lt_whole_archive_flag_spec
+
+# Whether the compiler copes with passing no objects directly.
+compiler_needs_object=$lt_compiler_needs_object
+
+# Create an old-style archive from a shared archive.
+old_archive_from_new_cmds=$lt_old_archive_from_new_cmds
+
+# Create a temporary old-style archive to link instead of a shared archive.
+old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds
+
+# Commands used to build a shared archive.
+archive_cmds=$lt_archive_cmds
+archive_expsym_cmds=$lt_archive_expsym_cmds
+
+# Commands used to build a loadable module if different from building
+# a shared archive.
+module_cmds=$lt_module_cmds
+module_expsym_cmds=$lt_module_expsym_cmds
+
+# Whether we are building with GNU ld or not.
+with_gnu_ld=$lt_with_gnu_ld
+
+# Flag that allows shared libraries with undefined symbols to be built.
+allow_undefined_flag=$lt_allow_undefined_flag
+
+# Flag that enforces no undefined symbols.
+no_undefined_flag=$lt_no_undefined_flag
+
+# Flag to hardcode \$libdir into a binary during linking.
+# This must work even if \$libdir does not exist
+hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec
+
+# If ld is used when linking, flag to hardcode \$libdir into a binary
+# during linking.  This must work even if \$libdir does not exist.
+hardcode_libdir_flag_spec_ld=$lt_hardcode_libdir_flag_spec_ld
+
+# Whether we need a single "-rpath" flag with a separated argument.
+hardcode_libdir_separator=$lt_hardcode_libdir_separator
+
+# Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes
+# DIR into the resulting binary.
+hardcode_direct=$hardcode_direct
+
+# Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes
+# DIR into the resulting binary and the resulting library dependency is
+# "absolute",i.e impossible to change by setting \${shlibpath_var} if the
+# library is relocated.
+hardcode_direct_absolute=$hardcode_direct_absolute
+
+# Set to "yes" if using the -LDIR flag during linking hardcodes DIR
+# into the resulting binary.
+hardcode_minus_L=$hardcode_minus_L
+
+# Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR
+# into the resulting binary.
+hardcode_shlibpath_var=$hardcode_shlibpath_var
+
+# Set to "yes" if building a shared library automatically hardcodes DIR
+# into the library and all subsequent libraries and executables linked
+# against it.
+hardcode_automatic=$hardcode_automatic
+
+# Set to yes if linker adds runtime paths of dependent libraries
+# to runtime path list.
+inherit_rpath=$inherit_rpath
+
+# Whether libtool must link a program against all its dependency libraries.
+link_all_deplibs=$link_all_deplibs
+
+# Fix the shell variable \$srcfile for the compiler.
+fix_srcfile_path=$lt_fix_srcfile_path
+
+# Set to "yes" if exported symbols are required.
+always_export_symbols=$always_export_symbols
+
+# The commands to list exported symbols.
+export_symbols_cmds=$lt_export_symbols_cmds
+
+# Symbols that should not be listed in the preloaded symbols.
+exclude_expsyms=$lt_exclude_expsyms
+
+# Symbols that must always be exported.
+include_expsyms=$lt_include_expsyms
+
+# Commands necessary for linking programs (against libraries) with templates.
+prelink_cmds=$lt_prelink_cmds
+
+# Specify filename containing input files.
+file_list_spec=$lt_file_list_spec
+
+# How to hardcode a shared library path into an executable.
+hardcode_action=$hardcode_action
+
+# ### END LIBTOOL CONFIG
+
+_LT_EOF
+
+  case $host_os in
+  aix3*)
+    cat <<\_LT_EOF >> "$cfgfile"
+# AIX sometimes has problems with the GCC collect2 program.  For some
+# reason, if we set the COLLECT_NAMES environment variable, the problems
+# vanish in a puff of smoke.
+if test "X${COLLECT_NAMES+set}" != Xset; then
+  COLLECT_NAMES=
+  export COLLECT_NAMES
+fi
+_LT_EOF
+    ;;
+  esac
+
+
+ltmain="$ac_aux_dir/ltmain.sh"
+
+
+  # We use sed instead of cat because bash on DJGPP gets confused if
+  # if finds mixed CR/LF and LF-only lines.  Since sed operates in
+  # text mode, it properly converts lines to CR/LF.  This bash problem
+  # is reportedly fixed, but why not run on old versions too?
+  sed '/^# Generated shell functions inserted here/q' "$ltmain" >> "$cfgfile" \
+    || (rm -f "$cfgfile"; exit 1)
+
+  case $xsi_shell in
+  yes)
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_dirname file append nondir_replacement
+# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
+# otherwise set result to NONDIR_REPLACEMENT.
+func_dirname ()
+{
+  case ${1} in
+    */*) func_dirname_result="${1%/*}${2}" ;;
+    *  ) func_dirname_result="${3}" ;;
+  esac
+}
+
+# func_basename file
+func_basename ()
+{
+  func_basename_result="${1##*/}"
+}
+
+# func_dirname_and_basename file append nondir_replacement
+# perform func_basename and func_dirname in a single function
+# call:
+#   dirname:  Compute the dirname of FILE.  If nonempty,
+#             add APPEND to the result, otherwise set result
+#             to NONDIR_REPLACEMENT.
+#             value returned in "$func_dirname_result"
+#   basename: Compute filename of FILE.
+#             value retuned in "$func_basename_result"
+# Implementation must be kept synchronized with func_dirname
+# and func_basename. For efficiency, we do not delegate to
+# those functions but instead duplicate the functionality here.
+func_dirname_and_basename ()
+{
+  case ${1} in
+    */*) func_dirname_result="${1%/*}${2}" ;;
+    *  ) func_dirname_result="${3}" ;;
+  esac
+  func_basename_result="${1##*/}"
+}
+
+# func_stripname prefix suffix name
+# strip PREFIX and SUFFIX off of NAME.
+# PREFIX and SUFFIX must not contain globbing or regex special
+# characters, hashes, percent signs, but SUFFIX may contain a leading
+# dot (in which case that matches only a dot).
+func_stripname ()
+{
+  # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
+  # positional parameters, so assign one to ordinary parameter first.
+  func_stripname_result=${3}
+  func_stripname_result=${func_stripname_result#"${1}"}
+  func_stripname_result=${func_stripname_result%"${2}"}
+}
+
+# func_opt_split
+func_opt_split ()
+{
+  func_opt_split_opt=${1%%=*}
+  func_opt_split_arg=${1#*=}
+}
+
+# func_lo2o object
+func_lo2o ()
+{
+  case ${1} in
+    *.lo) func_lo2o_result=${1%.lo}.${objext} ;;
+    *)    func_lo2o_result=${1} ;;
+  esac
+}
+
+# func_xform libobj-or-source
+func_xform ()
+{
+  func_xform_result=${1%.*}.lo
+}
+
+# func_arith arithmetic-term...
+func_arith ()
+{
+  func_arith_result=$(( $* ))
+}
+
+# func_len string
+# STRING may not start with a hyphen.
+func_len ()
+{
+  func_len_result=${#1}
+}
+
+_LT_EOF
+    ;;
+  *) # Bourne compatible functions.
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_dirname file append nondir_replacement
+# Compute the dirname of FILE.  If nonempty, add APPEND to the result,
+# otherwise set result to NONDIR_REPLACEMENT.
+func_dirname ()
+{
+  # Extract subdirectory from the argument.
+  func_dirname_result=`$ECHO "X${1}" | $Xsed -e "$dirname"`
+  if test "X$func_dirname_result" = "X${1}"; then
+    func_dirname_result="${3}"
+  else
+    func_dirname_result="$func_dirname_result${2}"
+  fi
+}
+
+# func_basename file
+func_basename ()
+{
+  func_basename_result=`$ECHO "X${1}" | $Xsed -e "$basename"`
+}
+
+
+# func_stripname prefix suffix name
+# strip PREFIX and SUFFIX off of NAME.
+# PREFIX and SUFFIX must not contain globbing or regex special
+# characters, hashes, percent signs, but SUFFIX may contain a leading
+# dot (in which case that matches only a dot).
+# func_strip_suffix prefix name
+func_stripname ()
+{
+  case ${2} in
+    .*) func_stripname_result=`$ECHO "X${3}" \
+           | $Xsed -e "s%^${1}%%" -e "s%\\\\${2}\$%%"`;;
+    *)  func_stripname_result=`$ECHO "X${3}" \
+           | $Xsed -e "s%^${1}%%" -e "s%${2}\$%%"`;;
+  esac
+}
+
+# sed scripts:
+my_sed_long_opt='1s/^\(-[^=]*\)=.*/\1/;q'
+my_sed_long_arg='1s/^-[^=]*=//'
+
+# func_opt_split
+func_opt_split ()
+{
+  func_opt_split_opt=`$ECHO "X${1}" | $Xsed -e "$my_sed_long_opt"`
+  func_opt_split_arg=`$ECHO "X${1}" | $Xsed -e "$my_sed_long_arg"`
+}
+
+# func_lo2o object
+func_lo2o ()
+{
+  func_lo2o_result=`$ECHO "X${1}" | $Xsed -e "$lo2o"`
+}
+
+# func_xform libobj-or-source
+func_xform ()
+{
+  func_xform_result=`$ECHO "X${1}" | $Xsed -e 's/\.[^.]*$/.lo/'`
+}
+
+# func_arith arithmetic-term...
+func_arith ()
+{
+  func_arith_result=`expr "$@"`
+}
+
+# func_len string
+# STRING may not start with a hyphen.
+func_len ()
+{
+  func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len`
+}
+
+_LT_EOF
+esac
+
+case $lt_shell_append in
+  yes)
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_append var value
+# Append VALUE to the end of shell variable VAR.
+func_append ()
+{
+  eval "$1+=\$2"
+}
+_LT_EOF
+    ;;
+  *)
+    cat << \_LT_EOF >> "$cfgfile"
+
+# func_append var value
+# Append VALUE to the end of shell variable VAR.
+func_append ()
+{
+  eval "$1=\$$1\$2"
+}
+
+_LT_EOF
+    ;;
+  esac
+
+
+  sed -n '/^# Generated shell functions inserted here/,$p' "$ltmain" >> "$cfgfile" \
+    || (rm -f "$cfgfile"; exit 1)
+
+  mv -f "$cfgfile" "$ofile" ||
+    (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile")
+  chmod +x "$ofile"
+
+ ;;
+
+  esac
+done # for ac_tag
+
+
+{ (exit 0); exit 0; }
+_ACEOF
+chmod +x $CONFIG_STATUS
+ac_clean_files=$ac_clean_files_save
+
+test $ac_write_fail = 0 ||
+  { { $as_echo "$as_me:$LINENO: error: write failure creating $CONFIG_STATUS" >&5
+$as_echo "$as_me: error: write failure creating $CONFIG_STATUS" >&2;}
+   { (exit 1); exit 1; }; }
+
+
+# configure is writing to config.log, and then calls config.status.
+# config.status does its own redirection, appending to config.log.
+# Unfortunately, on DOS this fails, as config.log is still kept open
+# by configure, so config.status won't be able to write to it; its
+# output is simply discarded.  So we exec the FD to /dev/null,
+# effectively closing config.log, so it can be properly (re)opened and
+# appended to by config.status.  When coming back to configure, we
+# need to make the FD available again.
+if test "$no_create" != yes; then
+  ac_cs_success=:
+  ac_config_status_args=
+  test "$silent" = yes &&
+    ac_config_status_args="$ac_config_status_args --quiet"
+  exec 5>/dev/null
+  $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false
+  exec 5>>config.log
+  # Use ||, not &&, to avoid exiting from the if with $? = 1, which
+  # would make configure fail if this is the last instruction.
+  $ac_cs_success || { (exit 1); exit 1; }
+fi
+if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then
+  { $as_echo "$as_me:$LINENO: WARNING: unrecognized options: $ac_unrecognized_opts" >&5
+$as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;}
+fi
+
+
+
+  EXP_VAR=LIBDIR
+  FROM_VAR=${libdir}
+
+    prefix_save=$prefix
+  exec_prefix_save=$exec_prefix
+
+    if test "x$prefix" = "xNONE"; then
+    prefix="$ac_default_prefix"
+  fi
+    if test "x$exec_prefix" = "xNONE"; then
+    exec_prefix=$prefix
+  fi
+
+  full_var="$FROM_VAR"
+    while true; do
+    new_full_var="`eval echo $full_var`"
+    if test "x$new_full_var" = "x$full_var"; then break; fi
+    full_var=$new_full_var
+  done
+
+    full_var=$new_full_var
+  LIBDIR="$full_var"
+
+
+    prefix=$prefix_save
+  exec_prefix=$exec_prefix_save
+
+
+  EXP_VAR=INCLUDEDIR
+  FROM_VAR=${includedir}
+
+    prefix_save=$prefix
+  exec_prefix_save=$exec_prefix
+
+    if test "x$prefix" = "xNONE"; then
+    prefix="$ac_default_prefix"
+  fi
+    if test "x$exec_prefix" = "xNONE"; then
+    exec_prefix=$prefix
+  fi
+
+  full_var="$FROM_VAR"
+    while true; do
+    new_full_var="`eval echo $full_var`"
+    if test "x$new_full_var" = "x$full_var"; then break; fi
+    full_var=$new_full_var
+  done
+
+    full_var=$new_full_var
+  INCLUDEDIR="$full_var"
+
+
+    prefix=$prefix_save
+  exec_prefix=$exec_prefix_save
+
+
+  EXP_VAR=BINDIR
+  FROM_VAR=${bindir}
+
+    prefix_save=$prefix
+  exec_prefix_save=$exec_prefix
+
+    if test "x$prefix" = "xNONE"; then
+    prefix="$ac_default_prefix"
+  fi
+    if test "x$exec_prefix" = "xNONE"; then
+    exec_prefix=$prefix
+  fi
+
+  full_var="$FROM_VAR"
+    while true; do
+    new_full_var="`eval echo $full_var`"
+    if test "x$new_full_var" = "x$full_var"; then break; fi
+    full_var=$new_full_var
+  done
+
+    full_var=$new_full_var
+  BINDIR="$full_var"
+
+
+    prefix=$prefix_save
+  exec_prefix=$exec_prefix_save
+
+
+  EXP_VAR=DOCDIR
+  FROM_VAR=${datadir}/doc
+
+    prefix_save=$prefix
+  exec_prefix_save=$exec_prefix
+
+    if test "x$prefix" = "xNONE"; then
+    prefix="$ac_default_prefix"
+  fi
+    if test "x$exec_prefix" = "xNONE"; then
+    exec_prefix=$prefix
+  fi
+
+  full_var="$FROM_VAR"
+    while true; do
+    new_full_var="`eval echo $full_var`"
+    if test "x$new_full_var" = "x$full_var"; then break; fi
+    full_var=$new_full_var
+  done
+
+    full_var=$new_full_var
+  DOCDIR="$full_var"
+
+
+    prefix=$prefix_save
+  exec_prefix=$exec_prefix_save
+
+
+if test $HAVE_DOXYGEN = "false"; then
+  doc_build="no"
+else
+  doc_build="yes"
+fi
+if test $BUILD_SPEC = "false"; then
+  spec_build="no"
+else
+  spec_build="yes"
+fi
+
+{ $as_echo "$as_me:$LINENO: result:
+------------------------------------------------------------------------
+  $PACKAGE $VERSION:  Automatic configuration OK.
+
+  General configuration:
+
+    Encoding support: ........... ${ac_enable_encode}
+    Floating point support: ..... ${ac_enable_float}
+    Assembly optimization: ...... ${cpu_optimization}
+    Debugging telemetry: ........ ${ac_enable_telemetry}
+    Build example code: ......... ${ac_enable_examples}
+    API Documentation: .......... ${doc_build}
+    Format Documentation: ....... ${spec_build}
+
+  Installation paths:
+
+    libtheora: ................... ${LIBDIR}
+    C header files: .............. ${INCLUDEDIR}/theora
+    Documentation: ............... ${DOCDIR}/$PACKAGE
+
+  Building:
+
+    Type 'make' to compile $PACKAGE.
+
+    Type 'make install' to install $PACKAGE.
+
+    ${TESTS_INFO}
+
+  Example programs will be built but not installed.
+------------------------------------------------------------------------
+" >&5
+$as_echo "
+------------------------------------------------------------------------
+  $PACKAGE $VERSION:  Automatic configuration OK.
+
+  General configuration:
+
+    Encoding support: ........... ${ac_enable_encode}
+    Floating point support: ..... ${ac_enable_float}
+    Assembly optimization: ...... ${cpu_optimization}
+    Debugging telemetry: ........ ${ac_enable_telemetry}
+    Build example code: ......... ${ac_enable_examples}
+    API Documentation: .......... ${doc_build}
+    Format Documentation: ....... ${spec_build}
+
+  Installation paths:
+
+    libtheora: ................... ${LIBDIR}
+    C header files: .............. ${INCLUDEDIR}/theora
+    Documentation: ............... ${DOCDIR}/$PACKAGE
+
+  Building:
+
+    Type 'make' to compile $PACKAGE.
+
+    Type 'make install' to install $PACKAGE.
+
+    ${TESTS_INFO}
+
+  Example programs will be built but not installed.
+------------------------------------------------------------------------
+" >&6; }
+
diff --git a/configure.ac b/configure.ac
new file mode 100644 (file)
index 0000000..8260bdf
--- /dev/null
@@ -0,0 +1,516 @@
+dnl Process this file with autoconf to produce a configure script
+
+dnl ------------------------------------------------
+dnl Initialization and Versioning
+dnl ------------------------------------------------
+
+AC_INIT(libtheora,[1.1.1])
+
+AC_CANONICAL_HOST
+AC_CANONICAL_TARGET
+
+AM_CONFIG_HEADER([config.h])
+AC_CONFIG_SRCDIR([lib/fdct.c])
+AM_INIT_AUTOMAKE
+AM_MAINTAINER_MODE
+
+dnl Library versioning
+dnl CURRENT, REVISION, AGE
+dnl - library source changed -> increment REVISION
+dnl - interfaces added/removed/changed -> increment CURRENT, REVISION = 0
+dnl - interfaces added -> increment AGE
+dnl - interfaces removed -> AGE = 0
+
+TH_LIB_CURRENT=3
+TH_LIB_REVISION=10
+TH_LIB_AGE=3
+AC_SUBST(TH_LIB_CURRENT)
+AC_SUBST(TH_LIB_REVISION)
+AC_SUBST(TH_LIB_AGE)
+
+THDEC_LIB_CURRENT=2
+THDEC_LIB_REVISION=4
+THDEC_LIB_AGE=1
+AC_SUBST(THDEC_LIB_CURRENT)
+AC_SUBST(THDEC_LIB_REVISION)
+AC_SUBST(THDEC_LIB_AGE)
+
+THENC_LIB_CURRENT=2
+THENC_LIB_REVISION=2
+THENC_LIB_AGE=1
+AC_SUBST(THENC_LIB_CURRENT)
+AC_SUBST(THENC_LIB_REVISION)
+AC_SUBST(THENC_LIB_AGE)
+
+dnl Extra linker options (for version script)
+THEORA_LDFLAGS=""
+
+dnl --------------------------------------------------  
+dnl Check for programs
+dnl --------------------------------------------------  
+
+dnl save $CFLAGS since AC_PROG_CC likes to insert "-g -O2"
+dnl if $CFLAGS is blank
+cflags_save="$CFLAGS"
+AC_PROG_CC
+AC_PROG_CPP
+CFLAGS="$cflags_save"
+
+AM_PROG_CC_C_O
+AC_LIBTOOL_WIN32_DLL
+AM_PROG_LIBTOOL
+
+dnl Add parameters for aclocal
+AC_SUBST(ACLOCAL_AMFLAGS, "-I m4")
+
+dnl Check for doxygen
+AC_CHECK_PROG(HAVE_DOXYGEN, doxygen, true, false)
+AM_CONDITIONAL(HAVE_DOXYGEN,$HAVE_DOXYGEN)
+if test $HAVE_DOXYGEN = "false"; then
+        AC_MSG_WARN([*** doxygen not found, API documentation will not be built])
+fi
+
+dnl Check for tools used to build the format specification
+BUILD_SPEC="false"
+ac_build_spec=yes
+AC_ARG_ENABLE(spec,
+     [  --disable-spec          do not build spec ],
+     [
+       if test "x$enableval" = "xno"; then
+         ac_build_spec=$enableval
+       fi
+     ], [
+       ac_build_spec=yes
+     ] )
+if test "x$ac_build_spec" = "xyes"; then
+  AC_CHECK_PROG(HAVE_PDFLATEX, pdflatex, yes)
+  AC_CHECK_PROG(HAVE_BIBTEX, bibtex, yes)
+  AC_CHECK_PROG(HAVE_TRANSFIG, fig2dev, yes)
+  if test -r doc/spec/spec.tex; then
+   if test "x$HAVE_PDFLATEX" = "xyes"; then
+    if test "x$HAVE_BIBTEX" = "xyes"; then
+      if test "x$HAVE_TRANSFIG" = "xyes"; then
+        tex_pkg_list=`fgrep usepackage doc/spec/spec.tex | grep \{ | grep -v ltablex`
+        tex_pkg_ok="yes"
+        for pkg_line in $tex_pkg_list; do
+         pkg_name=`echo $pkg_line | sed -e 's/.*{\(.*\)}.*/\1/'`
+         AC_MSG_CHECKING([for Tex package $pkg_name])
+          cat >conftest.tex <<_ACEOF
+\\documentclass{book}
+$pkg_line
+\\begin{document}
+Hello World.
+\\end{document}
+_ACEOF
+         if pdflatex -interaction batchmode -halt-on-error conftest < /dev/null > /dev/null 2>&1; then
+            AC_MSG_RESULT([ok])
+          else
+           tex_pkg_ok="no"
+           AC_MSG_RESULT([no])
+          fi
+        done
+        if test -w conftest.tex; then rm conftest.tex; fi
+        if test -w conftest.tex; then rm conftest.aux; fi
+        if test -w conftest.pdf; then rm conftest.pdf; fi
+        if test "x$tex_pkg_ok" = "xyes"; then
+          BUILD_SPEC="true"
+        fi
+      fi
+    fi
+   fi
+  fi
+fi
+AM_CONDITIONAL(BUILD_SPEC, $BUILD_SPEC)
+if test $BUILD_SPEC = "false"; then
+       AC_MSG_WARN([*** Format Specification will not built.])
+fi
+
+dnl Check for valgrind
+VALGRIND_ENVIRONMENT=""
+ac_enable_valgrind=no
+AC_ARG_ENABLE(valgrind-testing,
+     [  --enable-valgrind-testing     enable running of tests inside Valgrind ],     [ ac_enable_valgrind=yes ], [ ac_enable_valgrind=no] )
+
+if test "x${ac_enable_valgrind}" = xyes ; then
+  if test "x${enable_shared}" = xyes ; then
+    VALGRIND_ENVIRONMENT="libtool --mode=execute "
+  fi
+
+  AC_CHECK_PROG(HAVE_VALGRIND, valgrind, yes, no)
+  if test "x$HAVE_VALGRIND" = xyes ; then
+    VALGRIND_ENVIRONMENT="$VALGRIND_ENVIRONMENT valgrind -q --leak-check=yes --show-reachable=yes --num-callers=100"
+    AC_SUBST(VALGRIND_ENVIRONMENT)
+    TESTS_INFO="Type 'make check' to run test suite. Tests will be run under:
+  ${VALGRIND_ENVIRONMENT}"
+  else
+    TESTS_INFO="Type 'make check' to run test suite (Valgrind not found)"
+  fi
+else
+  TESTS_INFO="Type 'make check' to run test suite (Valgrind testing not enabled)"
+fi
+
+dnl --------------------------------------------------
+dnl Set build flags based on environment
+dnl --------------------------------------------------
+
+dnl Set some target options
+
+cflags_save="$CFLAGS"
+if test -z "$GCC"; then
+        case $host in 
+        *)
+                DEBUG="-g -DDEBUG"
+                CFLAGS="-O"
+                PROFILE="-g -p -DDEBUG" ;;
+        esac
+else
+
+        case $host in 
+        *)
+                DEBUG="-g -Wall -Wno-parentheses -DDEBUG -D__NO_MATH_INLINES"
+                CFLAGS="-Wall -Wno-parentheses -O3 -fforce-addr -fomit-frame-pointer -finline-functions -funroll-loops"
+                PROFILE="-Wall -Wno-parentheses -pg -g -O3 -fno-inline-functions -DDEBUG";;
+        esac
+fi
+CFLAGS="$CFLAGS $cflags_save"
+
+cpu_x86_64=no
+cpu_x86_32=no
+AC_ARG_ENABLE(asm,
+    [  --disable-asm           disable assembly optimizations ],
+    [ ac_enable_asm=$enableval ], [ ac_enable_asm=yes] )
+
+if test "x${ac_enable_asm}" = xyes; then
+  cpu_optimization="no optimization for your platform, please send a patch"
+  case $target_cpu in
+  i[[3456]]86)
+    cpu_x86_32=yes 
+    cpu_optimization="32 bit x86"
+    AC_DEFINE([OC_X86_ASM], [],  [make use of x86 asm optimization])
+    if test "x$target_vendor" = "xapple"; then
+      THEORA_LDFLAGS="$THEORA_LDFLAGS  -Wl,-read_only_relocs,suppress"
+    fi
+      ;;
+  x86_64)
+    cpu_x86_64=yes
+    cpu_optimization="64 bit x86"
+    AC_DEFINE([OC_X86_ASM], [],  [make use of x86 asm optimization])
+    AC_DEFINE([OC_X86_64_ASM], [],  [make use of x86_64 asm optimization])
+    ;;
+  esac
+else
+  cpu_optimization="disabled"
+fi
+AM_CONDITIONAL([CPU_x86_64], [test x$cpu_x86_64 = xyes])
+AM_CONDITIONAL([CPU_x86_32], [test x$cpu_x86_32 = xyes])
+
+# Test whenever ld supports -version-script
+AC_PROG_LD
+AC_PROG_LD_GNU
+AC_MSG_CHECKING([how to control symbol export])
+
+THDEC_VERSION_ARG=""
+THENC_VERSION_ARG=""
+TH_VERSION_ARG=""
+if test "x$lt_cv_prog_gnu_ld" = "xyes"; then
+ case "$target_os" in
+  *mingw*)
+    THEORA_LDFLAGS="$THEORA_LDFLAGS -no-undefined"
+    THDEC_VERSION_ARG="-export-symbols \$(top_srcdir)/win32/xmingw32/libtheoradec-all.def"
+    THENC_VERSION_ARG="-export-symbols \$(top_srcdir)/win32/xmingw32/libtheoraenc-all.def"
+    THENC_VERSION_ARG="$THENC_VERSION_ARG -ltheoradec"
+    THC_VERSION_ARG="-export-symbols \$(top_srcdir)/win32/libtheora.def"
+    AC_MSG_RESULT([-export-symbols])
+    ;;
+  linux* | solaris* )
+    THDEC_VERSION_ARG='-Wl,--version-script=$(srcdir)/Version_script-dec'
+    THENC_VERSION_ARG='-Wl,--version-script=$(srcdir)/Version_script-enc'
+    TH_VERSION_ARG='-Wl,--version-script=$(srcdir)/Version_script'
+    AC_MSG_RESULT([--version-script])
+    ;;
+  *)
+    # build without versioning
+    AC_MSG_RESULT([no])
+    ;;
+ esac
+else
+ case "$target_os" in
+  darwin*)
+    THDEC_VERSION_ARG='-Wl,-exported_symbols_list,$(srcdir)/theoradec.exp'
+    THENC_VERSION_ARG='-Wl,-exported_symbols_list,$(srcdir)/theoraenc.exp'
+    TH_VERSION_ARG='-Wl,-exported_symbols_list,$(srcdir)/theora.exp'
+    AC_MSG_RESULT([-exported_symbols_list])
+    ;;
+  *)
+    # build without versioning
+    AC_MSG_RESULT([no])
+    ;;
+ esac
+fi
+THEORADEC_LDFLAGS="$THEORA_LDFLAGS $THDEC_VERSION_ARG"
+THEORAENC_LDFLAGS="$THEORA_LDFLAGS $THENC_VERSION_ARG"
+THEORA_LDFLAGS="$THEORA_LDFLAGS $TH_VERSION_ARG"
+AC_SUBST(THEORADEC_LDFLAGS)
+AC_SUBST(THEORAENC_LDFLAGS)
+AC_SUBST(THEORA_LDFLAGS)
+
+dnl --------------------------------------------------
+dnl Checks for support libraries and headers
+dnl --------------------------------------------------
+
+dnl check for Ogg
+HAVE_OGG=no
+
+dnl first check through pkg-config since it's more flexible
+
+dnl check for pkg-config itself so we don't try the m4 macro without pkg-config
+AC_CHECK_PROG(HAVE_PKG_CONFIG, pkg-config, yes)
+if test "x$HAVE_PKG_CONFIG" = "xyes"
+then
+  PKG_CHECK_MODULES(OGG, ogg >= 1.1, HAVE_OGG=yes, HAVE_OGG=no)
+fi
+if test "x$HAVE_OGG" = "xno"
+then
+  dnl fall back to the old school test
+  XIPH_PATH_OGG(, AC_MSG_ERROR([
+    libogg is required to build this package!
+    please see http://www.xiph.org/ for how to
+    obtain a copy.
+  ]))
+  cflags_save=$CFLAGS
+  libs_save=$LIBS
+  CFLAGS="$CFLAGS $OGG_CFLAGS"
+  LIBS="$LIBS $OGG_LIBS"
+  AC_CHECK_FUNC(oggpackB_read, , [
+    AC_MSG_ERROR([newer libogg version (1.1 or later) required])
+  ])
+  CFLAGS=$cflags_save
+  LIBS=$libs_save
+fi
+
+
+dnl check for Vorbis
+HAVE_VORBIS=no
+
+dnl first check through pkg-config since it's more flexible
+
+if test "x$HAVE_PKG_CONFIG" = "xyes"
+then
+  PKG_CHECK_MODULES(VORBIS, vorbis >= 1.0.1, HAVE_VORBIS=yes, HAVE_VORBIS=no)
+  dnl also set VORBISENC_LIBS since an examples needs it
+  dnl the old .m4 sets this to a value to use on top of VORBIS_LIBS,
+  dnl so we do the same here.
+  VORBISENC_LIBS="-lvorbisenc"
+  AC_SUBST(VORBISENC_LIBS)
+fi
+if test "x$HAVE_VORBIS" = "xno"
+then
+  dnl fall back to the old school test
+  XIPH_PATH_VORBIS(HAVE_VORBIS=yes, HAVE_VORBIS=no)
+fi
+
+dnl check for SDL
+HAVE_SDL=no
+
+AM_PATH_SDL(,[
+  HAVE_SDL=yes
+  SDL_LIBS=`$SDL_CONFIG --libs`
+],AC_MSG_WARN([*** Unable to find SDL -- Not compiling example players ***]))
+
+dnl check for OSS
+HAVE_OSS=no
+AC_CHECK_HEADERS([sys/soundcard.h soundcard.h machine/soundcard.h],[
+  HAVE_OSS=yes
+  break
+])
+if test x$HAVE_OSS != xyes; then
+  AC_MSG_WARN([OSS audio support not found -- not compiling player_example])
+fi
+
+dnl OpenBSD needs -lossaudio to use the oss interface
+OSS_LIBS=
+case "$target_os" in
+  openbsd*)
+    OSS_LIBS='-lossaudio'
+    ;;
+esac
+AC_SUBST(OSS_LIBS)
+
+dnl check for libpng
+HAVE_PNG=no
+if test "x$HAVE_PKG_CONFIG" = "xyes"
+then
+  PKG_CHECK_MODULES(PNG, libpng, HAVE_PNG=yes, HAVE_PNG=no)
+fi
+AC_SUBST(PNG_CFLAGS)
+AC_SUBST(PNG_LIBS)
+
+dnl check for libcairo
+HAVE_CAIRO=no
+AC_ARG_ENABLE(telemetry,
+    [  --enable-telemetry      enable debugging output controls ],
+    [ ac_enable_telemetry=$enableval ], [ ac_enable_telemetry=no] )
+
+if test "x${ac_enable_telemetry}" = xyes; then
+   if test "x$HAVE_PKG_CONFIG" = "xyes"
+   then
+     PKG_CHECK_MODULES(CAIRO, cairo, HAVE_CAIRO=yes, HAVE_CAIRO=no)
+     AC_DEFINE([HAVE_CAIRO], [],  [libcairo is available for visual debugging output])  
+   fi
+   if test x$HAVE_CAIRO != xyes; then
+     AC_MSG_WARN([libcairo not found -- not compiling telemetry output support ])
+   fi
+   AC_SUBST(CAIRO_CFLAGS)
+   AC_SUBST(CAIRO_LIBS)
+fi
+
+dnl --------------------------------------------------
+dnl Overall build configuration options
+dnl --------------------------------------------------
+
+dnl Configuration option for building of floating point code.
+
+ac_enable_float=yes
+AC_ARG_ENABLE(float,
+     [  --disable-float         disable use of floating point code ],
+     [ ac_enable_float=$enableval ], [ ac_enable_float=yes] )
+
+if test "x${ac_enable_float}" != xyes ; then
+    AC_DEFINE([THEORA_DISABLE_FLOAT], [], 
+  [Define to exclude floating point code from the build])
+fi
+AM_CONDITIONAL(THEORA_DISABLE_FLOAT, [test "x${ac_enable_float}" != xyes])
+
+dnl Configuration option for building of encoding support.
+
+ac_enable_encode=yes
+AC_ARG_ENABLE(encode,
+     [  --disable-encode        disable encoding support ],
+     [ ac_enable_encode=$enableval ], [ ac_enable_encode=yes] )
+
+if test "x${ac_enable_encode}" != xyes ; then
+    AC_DEFINE([THEORA_DISABLE_ENCODE], [],
+  [Define to exclude encode support from the build])
+else
+    if test x$HAVE_VORBIS = xyes; then
+      BUILDABLE_EXAMPLES="$BUILDABLE_EXAMPLES encoder_example\$(EXEEXT)"
+    else
+      AC_MSG_NOTICE([Vorbis missing, cannot build example encoder])
+    fi
+fi
+AM_CONDITIONAL(THEORA_DISABLE_ENCODE, [test "x${ac_enable_encode}" != xyes])
+
+dnl Configuration option for examples
+
+ac_enable_examples=yes
+AC_ARG_ENABLE(examples,
+     [  --disable-examples      disable examples ],
+     [ ac_enable_examples=$enableval ], [ ac_enable_examples=yes] )
+AM_CONDITIONAL(THEORA_ENABLE_EXAMPLES, [test "x${ac_enable_examples}" != xno])
+
+dnl --------------------------------------------------
+dnl Check for headers
+dnl --------------------------------------------------
+
+dnl none here
+
+dnl --------------------------------------------------
+dnl Check for typedefs, structures, etc
+dnl --------------------------------------------------
+
+dnl none
+
+dnl --------------------------------------------------
+dnl Check for library functions
+dnl --------------------------------------------------
+
+dnl OpenBSD needs -lcompat for ftime() used by dump_video.c
+AC_SEARCH_LIBS([ftime], [compat])
+
+dnl substitute the included getopt if the system doesn't support long options
+AC_CHECK_FUNC(getopt_long,
+              [GETOPT_OBJS=''],
+              [GETOPT_OBJS='getopt.$(OBJEXT) getopt1.$(OBJEXT)'])
+AC_SUBST(GETOPT_OBJS)
+
+if test x$HAVE_SDL = xyes -a x$HAVE_OSS = xyes -a x$HAVE_VORBIS = xyes; then
+  BUILDABLE_EXAMPLES="$BUILDABLE_EXAMPLES player_example\$(EXEEXT)"
+fi
+if test x$HAVE_PNG = xyes; then
+  BUILDABLE_EXAMPLES="$BUILDABLE_EXAMPLES png2theora\$(EXEEXT)"
+fi
+AC_SUBST(BUILDABLE_EXAMPLES)
+
+dnl --------------------------------------------------
+dnl Do substitutions
+dnl --------------------------------------------------
+
+AC_SUBST(DEBUG)
+AC_SUBST(PROFILE)
+
+AC_OUTPUT([
+  Makefile 
+  lib/Makefile
+  include/Makefile include/theora/Makefile
+  examples/Makefile
+  doc/Makefile doc/Doxyfile doc/spec/Makefile
+  tests/Makefile
+  m4/Makefile
+  libtheora.spec
+  theora.pc
+  theora-uninstalled.pc
+  theoradec.pc
+  theoradec-uninstalled.pc
+  theoraenc.pc
+  theoraenc-uninstalled.pc
+])
+
+AS_AC_EXPAND(LIBDIR, ${libdir})
+AS_AC_EXPAND(INCLUDEDIR, ${includedir})
+AS_AC_EXPAND(BINDIR, ${bindir})
+AS_AC_EXPAND(DOCDIR, ${datadir}/doc)
+
+if test $HAVE_DOXYGEN = "false"; then
+  doc_build="no"
+else
+  doc_build="yes"
+fi
+if test $BUILD_SPEC = "false"; then
+  spec_build="no"
+else
+  spec_build="yes"
+fi
+
+AC_MSG_RESULT([
+------------------------------------------------------------------------
+  $PACKAGE $VERSION:  Automatic configuration OK.
+
+  General configuration:
+
+    Encoding support: ........... ${ac_enable_encode}
+    Floating point support: ..... ${ac_enable_float}
+    Assembly optimization: ...... ${cpu_optimization}
+    Debugging telemetry: ........ ${ac_enable_telemetry}
+    Build example code: ......... ${ac_enable_examples}
+    API Documentation: .......... ${doc_build}
+    Format Documentation: ....... ${spec_build}
+
+  Installation paths:
+
+    libtheora: ................... ${LIBDIR}
+    C header files: .............. ${INCLUDEDIR}/theora
+    Documentation: ............... ${DOCDIR}/$PACKAGE
+
+  Building:
+
+    Type 'make' to compile $PACKAGE.
+
+    Type 'make install' to install $PACKAGE.
+
+    ${TESTS_INFO}
+
+  Example programs will be built but not installed.
+------------------------------------------------------------------------
+])
+
diff --git a/debian/README.Debian b/debian/README.Debian
new file mode 100644 (file)
index 0000000..d272617
--- /dev/null
@@ -0,0 +1,6 @@
+libtheora for Debian
+--------------------
+
+<possible notes regarding this package - if none, delete this file>
+
+ -- unknown <seungbae.shin>  Fri, 12 Mar 2010 17:27:39 +0900
diff --git a/debian/changelog b/debian/changelog
new file mode 100644 (file)
index 0000000..d142955
--- /dev/null
@@ -0,0 +1,8 @@
+libtheora (1.1.1-1slp4) unstable; urgency=low
+
+  * Initial Release
+  * Git: unmodified/libtheora
+  * Tag: libtheora_1.1.1-1slp4
+
+ -- Hyunseok Lee <hs7388.lee@samsung.com>  Wed, 07 Dec 2011 11:38:09 +0900
+
diff --git a/debian/compat b/debian/compat
new file mode 100644 (file)
index 0000000..7ed6ff8
--- /dev/null
@@ -0,0 +1 @@
+5
diff --git a/debian/control b/debian/control
new file mode 100644 (file)
index 0000000..8a7230a
--- /dev/null
@@ -0,0 +1,37 @@
+Source: libtheora
+Section: libs
+Priority: optional
+Maintainer: Seungbae Shin <seungbae.shin@samsung.com>
+Build-Depends: autotools-dev, cdbs (>= 0.4.27-3), debhelper (>> 4.0.0), devscripts, doxygen, libogg-dev (>= 1.1.0), libvorbis-dev, python, libtool, automake, quilt, libpng12-dev
+Standards-Version: 3.7.2
+
+Package: libtheora0
+Architecture: any
+Section: libs
+Depends: ${shlibs:Depends}
+Description: The Theora Video Compression Codec
+ Theora is an open video codec being developed by the Xiph.org
+ Foundation as part of their Ogg project (It is a project that aims to
+ integrate On2's VP3 video codec, Ogg Vorbis audio codec and Ogg
+ multimedia container formats into a multimedia solution that can
+ compete with MPEG-4 format).  Theora is derived directly from On2's
+ VP3 codec; currently the two are nearly identical, varying only in
+ framing headers, but Theora will diverge and improve from the main
+ VP3 development lineage as time progresses.
+
+Package: libtheora-dev
+Architecture: any
+Section: libdevel
+Depends: libtheora0 (= ${binary:Version}), libogg-dev
+Description: The Theora Video Compression Codec (development files)
+ Theora is a fully open, non-proprietary, patent-and-royalty-free,
+ general-purpose compressed video format.
+ .
+ This package contains the header files and documentation needed to develop
+ applications with libtheora.
+
+Package: libtheora-dbg
+Section: debug
+Architecture: any
+Depends: ${shlibs:Depends}, ${misc:Depends}, libtheora0 (= ${Source-Version})
+Description: The Theora Video Compression Codec (unstripped)
diff --git a/debian/copyright b/debian/copyright
new file mode 100644 (file)
index 0000000..bda5898
--- /dev/null
@@ -0,0 +1,6 @@
+Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
+Copyright (c) 2011 Hyunseok Lee <hs7388.lee@samsung.com>
+
+and is free software; you can redistribute it and/or modify
+it under the terms of the GNU Lesser General Public License version 2.1.
+
diff --git a/debian/dirs b/debian/dirs
new file mode 100644 (file)
index 0000000..ca882bb
--- /dev/null
@@ -0,0 +1,2 @@
+usr/bin
+usr/sbin
diff --git a/debian/docs b/debian/docs
new file mode 100644 (file)
index 0000000..e845566
--- /dev/null
@@ -0,0 +1 @@
+README
diff --git a/debian/libtheora-dev.install b/debian/libtheora-dev.install
new file mode 100644 (file)
index 0000000..09c716d
--- /dev/null
@@ -0,0 +1,5 @@
+usr/include/theora/*
+usr/lib/*.a
+usr/lib/*.la
+usr/lib/pkgconfig/*.pc
+usr/share/doc/libtheora-1.1.1/html/*
diff --git a/debian/libtheora0.install b/debian/libtheora0.install
new file mode 100644 (file)
index 0000000..c497a89
--- /dev/null
@@ -0,0 +1 @@
+usr/lib/libtheora*.so*
diff --git a/debian/rules b/debian/rules
new file mode 100755 (executable)
index 0000000..f2e48e0
--- /dev/null
@@ -0,0 +1,119 @@
+#!/usr/bin/make -f
+# -*- makefile -*-
+# Sample debian/rules that uses debhelper.
+# This file was originally written by Joey Hess and Craig Small.
+# As a special exception, when this file is copied by dh-make into a
+# dh-make output file, you may use that output file without restriction.
+# This special exception was added by Craig Small in version 0.37 of dh-make.
+
+# Uncomment this to turn on verbose mode.
+#export DH_VERBOSE=1
+
+
+# These are used for cross-compiling and for saving the configure script
+# from having to guess our platform (since we know it already)
+DEB_HOST_GNU_TYPE   ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE)
+DEB_BUILD_GNU_TYPE  ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE)
+
+CFLAGS ?= -Wall -g -fPIC
+LDFLAGS ?= 
+PREFIX ?= /usr
+DATADIR ?= /opt
+
+ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS)))
+       CFLAGS += -O0
+else
+       CFLAGS += -O2
+endif
+
+LDFLAGS += -Wl,--rpath=$(PREFIX)/lib -Wl,--hash-style=both -Wl,--as-needed
+
+config.status: configure
+       dh_testdir
+       # Add here commands to configure the package.
+       CFLAGS="$(CFLAGS)" LDFLAGS="$(LDFLAGS)" ./configure --prefix=$(PREFIX) 
+
+build: build-stamp
+
+build-stamp:  config.status
+       dh_testdir
+
+       # Add here commands to compile the package.
+       $(MAKE)
+       #docbook-to-man debian/iniparser.sgml > iniparser.1
+
+       for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+               cat $$f > $${f%.in}; \
+               sed -i -e "s#@PREFIX@#$(PREFIX)#g" $${f%.in}; \
+               sed -i -e "s#@DATADIR@#$(DATADIR)#g" $${f%.in}; \
+       done
+
+       touch $@
+
+clean:
+       dh_testdir
+       dh_testroot
+       rm -f build-stamp 
+
+       # Add here commands to clean up after the build process.
+       -$(MAKE) distclean
+ifneq "$(wildcard /usr/share/misc/config.sub)" ""
+       cp -f /usr/share/misc/config.sub config.sub
+endif
+ifneq "$(wildcard /usr/share/misc/config.guess)" ""
+       cp -f /usr/share/misc/config.guess config.guess
+endif
+
+       for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+               rm -f $${f%.in}; \
+       done
+
+       dh_clean 
+
+install: build
+       dh_testdir
+       dh_testroot
+       dh_clean -k 
+       dh_installdirs
+
+       # Add here commands to install the package into debian/iniparser.
+       $(MAKE) DESTDIR=$(CURDIR)/debian/tmp install
+
+
+# Build architecture-independent files here.
+binary-indep: build install
+# We have nothing to do by default.
+
+# Build architecture-dependent files here.
+binary-arch: build install
+       dh_testdir
+       dh_testroot
+       dh_installchangelogs 
+       dh_installdocs
+       dh_installexamples
+       dh_install --sourcedir=debian/tmp
+#      dh_installmenu
+#      dh_installdebconf       
+#      dh_installlogrotate
+#      dh_installemacsen
+#      dh_installpam
+#      dh_installmime
+#      dh_python
+#      dh_installinit
+#      dh_installcron
+#      dh_installinfo
+       dh_installman
+       dh_link
+       dh_strip --dbg-package=libtheora-dbg
+       dh_compress
+       dh_fixperms
+#      dh_perl
+       dh_makeshlibs
+       dh_installdeb
+       dh_shlibdeps
+       dh_gencontrol
+       dh_md5sums
+       dh_builddeb
+
+binary: binary-indep binary-arch
+.PHONY: build clean binary-indep binary-arch binary install 
diff --git a/depcomp b/depcomp
new file mode 100755 (executable)
index 0000000..807b991
--- /dev/null
+++ b/depcomp
@@ -0,0 +1,423 @@
+#! /bin/sh
+
+# depcomp - compile a program generating dependencies as side-effects
+# Copyright 1999, 2000 Free Software Foundation, Inc.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
+
+if test -z "$depmode" || test -z "$source" || test -z "$object"; then
+  echo "depcomp: Variables source, object and depmode must be set" 1>&2
+  exit 1
+fi
+# `libtool' can also be set to `yes' or `no'.
+
+if test -z "$depfile"; then
+   base=`echo "$object" | sed -e 's,^.*/,,' -e 's,\.\([^.]*\)$,.P\1,'`
+   dir=`echo "$object" | sed 's,/.*$,/,'`
+   if test "$dir" = "$object"; then
+      dir=
+   fi
+   # FIXME: should be _deps on DOS.
+   depfile="$dir.deps/$base"
+fi
+
+tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
+
+rm -f "$tmpdepfile"
+
+# Some modes work just like other modes, but use different flags.  We
+# parameterize here, but still list the modes in the big case below,
+# to make depend.m4 easier to write.  Note that we *cannot* use a case
+# here, because this file can only contain one case statement.
+if test "$depmode" = hp; then
+  # HP compiler uses -M and no extra arg.
+  gccflag=-M
+  depmode=gcc
+fi
+
+if test "$depmode" = dashXmstdout; then
+   # This is just like dashmstdout with a different argument.
+   dashmflag=-xM
+   depmode=dashmstdout
+fi
+
+case "$depmode" in
+gcc3)
+## gcc 3 implements dependency tracking that does exactly what
+## we want.  Yay!  Note: for some reason libtool 1.4 doesn't like
+## it if -MD -MP comes after the -MF stuff.  Hmm.
+  "$@" -MT "$object" -MD -MP -MF "$tmpdepfile"
+  stat=$?
+  if test $stat -eq 0; then :
+  else
+    rm -f "$tmpdepfile"
+    exit $stat
+  fi
+  mv "$tmpdepfile" "$depfile"
+  ;;
+
+gcc)
+## There are various ways to get dependency output from gcc.  Here's
+## why we pick this rather obscure method:
+## - Don't want to use -MD because we'd like the dependencies to end
+##   up in a subdir.  Having to rename by hand is ugly.
+##   (We might end up doing this anyway to support other compilers.)
+## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
+##   -MM, not -M (despite what the docs say).
+## - Using -M directly means running the compiler twice (even worse
+##   than renaming).
+  if test -z "$gccflag"; then
+    gccflag=-MD,
+  fi
+  "$@" -Wp,"$gccflag$tmpdepfile"
+  stat=$?
+  if test $stat -eq 0; then :
+  else
+    rm -f "$tmpdepfile"
+    exit $stat
+  fi
+  rm -f "$depfile"
+  echo "$object : \\" > "$depfile"
+  alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
+## The second -e expression handles DOS-style file names with drive letters.
+  sed -e 's/^[^:]*: / /' \
+      -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
+## This next piece of magic avoids the `deleted header file' problem.
+## The problem is that when a header file which appears in a .P file
+## is deleted, the dependency causes make to die (because there is
+## typically no way to rebuild the header).  We avoid this by adding
+## dummy dependencies for each header file.  Too bad gcc doesn't do
+## this for us directly.
+  tr ' ' '
+' < "$tmpdepfile" |
+## Some versions of gcc put a space before the `:'.  On the theory
+## that the space means something, we add a space to the output as
+## well.
+## Some versions of the HPUX 10.20 sed can't process this invocation
+## correctly.  Breaking it into two sed invocations is a workaround.
+    sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
+  rm -f "$tmpdepfile"
+  ;;
+
+hp)
+  # This case exists only to let depend.m4 do its work.  It works by
+  # looking at the text of this script.  This case will never be run,
+  # since it is checked for above.
+  exit 1
+  ;;
+
+sgi)
+  if test "$libtool" = yes; then
+    "$@" "-Wp,-MDupdate,$tmpdepfile"
+  else
+    "$@" -MDupdate "$tmpdepfile"
+  fi
+  stat=$?
+  if test $stat -eq 0; then :
+  else
+    rm -f "$tmpdepfile"
+    exit $stat
+  fi
+  rm -f "$depfile"
+
+  if test -f "$tmpdepfile"; then  # yes, the sourcefile depend on other files
+    echo "$object : \\" > "$depfile"
+
+    # Clip off the initial element (the dependent).  Don't try to be
+    # clever and replace this with sed code, as IRIX sed won't handle
+    # lines with more than a fixed number of characters (4096 in
+    # IRIX 6.2 sed, 8192 in IRIX 6.5).  We also remove comment lines;
+    # the IRIX cc adds comments like `#:fec' to the end of the
+    # dependency line.
+    tr ' ' '
+' < "$tmpdepfile" \
+    | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
+    tr '
+' ' ' >> $depfile
+    echo >> $depfile
+
+    # The second pass generates a dummy entry for each header file.
+    tr ' ' '
+' < "$tmpdepfile" \
+   | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
+   >> $depfile
+  else
+    # The sourcefile does not contain any dependencies, so just
+    # store a dummy comment line, to avoid errors with the Makefile
+    # "include basename.Plo" scheme.
+    echo "#dummy" > "$depfile"
+  fi
+  rm -f "$tmpdepfile"
+  ;;
+
+aix)
+  # The C for AIX Compiler uses -M and outputs the dependencies
+  # in a .u file.  This file always lives in the current directory.
+  # Also, the AIX compiler puts `$object:' at the start of each line;
+  # $object doesn't have directory information.
+  stripped=`echo "$object" | sed -e 's,^.*/,,' -e 's/\(.*\)\..*$/\1/'`
+  tmpdepfile="$stripped.u"
+  outname="$stripped.o"
+  if test "$libtool" = yes; then
+    "$@" -Wc,-M
+  else
+    "$@" -M
+  fi
+
+  stat=$?
+  if test $stat -eq 0; then :
+  else
+    rm -f "$tmpdepfile"
+    exit $stat
+  fi
+
+  if test -f "$tmpdepfile"; then
+    # Each line is of the form `foo.o: dependent.h'.
+    # Do two passes, one to just change these to
+    # `$object: dependent.h' and one to simply `dependent.h:'.
+    sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile"
+    sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
+  else
+    # The sourcefile does not contain any dependencies, so just
+    # store a dummy comment line, to avoid errors with the Makefile
+    # "include basename.Plo" scheme.
+    echo "#dummy" > "$depfile"
+  fi
+  rm -f "$tmpdepfile"
+  ;;
+
+tru64)
+   # The Tru64 compiler uses -MD to generate dependencies as a side
+   # effect.  `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
+   # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
+   # dependencies in `foo.d' instead, so we check for that too.
+   # Subdirectories are respected.
+   dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
+   test "x$dir" = "x$object" && dir=
+   base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
+
+   if test "$libtool" = yes; then
+      tmpdepfile1="$dir.libs/$base.lo.d"
+      tmpdepfile2="$dir.libs/$base.d"
+      "$@" -Wc,-MD
+   else
+      tmpdepfile1="$dir$base.o.d"
+      tmpdepfile2="$dir$base.d"
+      "$@" -MD
+   fi
+
+   stat=$?
+   if test $stat -eq 0; then :
+   else
+      rm -f "$tmpdepfile1" "$tmpdepfile2"
+      exit $stat
+   fi
+
+   if test -f "$tmpdepfile1"; then
+      tmpdepfile="$tmpdepfile1"
+   else
+      tmpdepfile="$tmpdepfile2"
+   fi
+   if test -f "$tmpdepfile"; then
+      sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
+      # That's a space and a tab in the [].
+      sed -e 's,^.*\.[a-z]*:[  ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
+   else
+      echo "#dummy" > "$depfile"
+   fi
+   rm -f "$tmpdepfile"
+   ;;
+
+#nosideeffect)
+  # This comment above is used by automake to tell side-effect
+  # dependency tracking mechanisms from slower ones.
+
+dashmstdout)
+  # Important note: in order to support this mode, a compiler *must*
+  # always write the proprocessed file to stdout, regardless of -o.
+  "$@" || exit $?
+
+  # Remove the call to Libtool.
+  if test "$libtool" = yes; then
+    while test $1 != '--mode=compile'; do
+      shift
+    done
+    shift
+  fi
+
+  # Remove `-o $object'.  We will use -o /dev/null later,
+  # however we can't do the remplacement now because
+  # `-o $object' might simply not be used
+  IFS=" "
+  for arg
+  do
+    case $arg in
+    -o)
+      shift
+      ;;
+    $object)
+      shift
+      ;;
+    *)
+      set fnord "$@" "$arg"
+      shift # fnord
+      shift # $arg
+      ;;
+    esac
+  done
+
+  test -z "$dashmflag" && dashmflag=-M
+  "$@" -o /dev/null $dashmflag | sed 's:^[^:]*\:[      ]*:'"$object"'\: :' > "$tmpdepfile"
+  rm -f "$depfile"
+  cat < "$tmpdepfile" > "$depfile"
+  tr ' ' '
+' < "$tmpdepfile" | \
+## Some versions of the HPUX 10.20 sed can't process this invocation
+## correctly.  Breaking it into two sed invocations is a workaround.
+    sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
+  rm -f "$tmpdepfile"
+  ;;
+
+dashXmstdout)
+  # This case only exists to satisfy depend.m4.  It is never actually
+  # run, as this mode is specially recognized in the preamble.
+  exit 1
+  ;;
+
+makedepend)
+  "$@" || exit $?
+  # X makedepend
+  shift
+  cleared=no
+  for arg in "$@"; do
+    case $cleared in
+    no)
+      set ""; shift
+      cleared=yes ;;
+    esac
+    case "$arg" in
+    -D*|-I*)
+      set fnord "$@" "$arg"; shift ;;
+    -*)
+      ;;
+    *)
+      set fnord "$@" "$arg"; shift ;;
+    esac
+  done
+  obj_suffix="`echo $object | sed 's/^.*\././'`"
+  touch "$tmpdepfile"
+  ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
+  rm -f "$depfile"
+  cat < "$tmpdepfile" > "$depfile"
+  sed '1,2d' "$tmpdepfile" | tr ' ' '
+' | \
+## Some versions of the HPUX 10.20 sed can't process this invocation
+## correctly.  Breaking it into two sed invocations is a workaround.
+    sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
+  rm -f "$tmpdepfile" "$tmpdepfile".bak
+  ;;
+
+cpp)
+  # Important note: in order to support this mode, a compiler *must*
+  # always write the proprocessed file to stdout.
+  "$@" || exit $?
+
+  # Remove the call to Libtool.
+  if test "$libtool" = yes; then
+    while test $1 != '--mode=compile'; do
+      shift
+    done
+    shift
+  fi
+
+  # Remove `-o $object'.
+  IFS=" "
+  for arg
+  do
+    case $arg in
+    -o)
+      shift
+      ;;
+    $object)
+      shift
+      ;;
+    *)
+      set fnord "$@" "$arg"
+      shift # fnord
+      shift # $arg
+      ;;
+    esac
+  done
+
+  "$@" -E |
+    sed -n '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
+    sed '$ s: \\$::' > "$tmpdepfile"
+  rm -f "$depfile"
+  echo "$object : \\" > "$depfile"
+  cat < "$tmpdepfile" >> "$depfile"
+  sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
+  rm -f "$tmpdepfile"
+  ;;
+
+msvisualcpp)
+  # Important note: in order to support this mode, a compiler *must*
+  # always write the proprocessed file to stdout, regardless of -o,
+  # because we must use -o when running libtool.
+  "$@" || exit $?
+  IFS=" "
+  for arg
+  do
+    case "$arg" in
+    "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
+       set fnord "$@"
+       shift
+       shift
+       ;;
+    *)
+       set fnord "$@" "$arg"
+       shift
+       shift
+       ;;
+    esac
+  done
+  "$@" -E |
+  sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile"
+  rm -f "$depfile"
+  echo "$object : \\" > "$depfile"
+  . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::   \1 \\:p' >> "$depfile"
+  echo "       " >> "$depfile"
+  . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile"
+  rm -f "$tmpdepfile"
+  ;;
+
+none)
+  exec "$@"
+  ;;
+
+*)
+  echo "Unknown depmode $depmode" 1>&2
+  exit 1
+  ;;
+esac
+
+exit 0
diff --git a/doc/Doxyfile.in b/doc/Doxyfile.in
new file mode 100644 (file)
index 0000000..43b5e99
--- /dev/null
@@ -0,0 +1,1142 @@
+# Doxyfile 1.3.7
+
+# This file describes the settings to be used by the documentation system
+# doxygen (www.doxygen.org) for a project
+#
+# All text after a hash (#) is considered a comment and will be ignored
+# The format is:
+#       TAG = value [value, ...]
+# For lists items can also be appended using:
+#       TAG += value [value, ...]
+# Values that contain spaces should be placed between quotes (" ")
+
+#---------------------------------------------------------------------------
+# Project related configuration options
+#---------------------------------------------------------------------------
+
+# The PROJECT_NAME tag is a single word (or a sequence of words surrounded 
+# by quotes) that should identify the project.
+
+PROJECT_NAME           = @PACKAGE@
+
+# The PROJECT_NUMBER tag can be used to enter a project or revision number. 
+# This could be handy for archiving the generated documentation or 
+# if some version control system is used.
+
+PROJECT_NUMBER         = @VERSION@
+
+# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute) 
+# base path where the generated documentation will be put. 
+# If a relative path is entered, it will be relative to the location 
+# where doxygen was started. If left blank the current directory will be used.
+
+OUTPUT_DIRECTORY       = libtheora
+
+# If the CREATE_SUBDIRS tag is set to YES, then doxygen will create 
+# 2 levels of 10 sub-directories under the output directory of each output 
+# format and will distribute the generated files over these directories. 
+# Enabling this option can be useful when feeding doxygen a huge amount of source 
+# files, where putting all generated files in the same directory would otherwise 
+# cause performance problems for the file system.
+
+CREATE_SUBDIRS         = NO
+
+# The OUTPUT_LANGUAGE tag is used to specify the language in which all 
+# documentation generated by doxygen is written. Doxygen will use this 
+# information to generate all constant output in the proper language. 
+# The default language is English, other supported languages are: 
+# Brazilian, Catalan, Chinese, Chinese-Traditional, Croatian, Czech, Danish, Dutch, 
+# Finnish, French, German, Greek, Hungarian, Italian, Japanese, Japanese-en 
+# (Japanese with English messages), Korean, Korean-en, Norwegian, Polish, Portuguese, 
+# Romanian, Russian, Serbian, Slovak, Slovene, Spanish, Swedish, and Ukrainian.
+
+OUTPUT_LANGUAGE        = English
+
+# This tag can be used to specify the encoding used in the generated output. 
+# The encoding is not always determined by the language that is chosen, 
+# but also whether or not the output is meant for Windows or non-Windows users. 
+# In case there is a difference, setting the USE_WINDOWS_ENCODING tag to YES 
+# forces the Windows encoding (this is the default for the Windows binary), 
+# whereas setting the tag to NO uses a Unix-style encoding (the default for 
+# all platforms other than Windows).
+#This tag is now obsolete, according to doxygen 1.5.2
+#USE_WINDOWS_ENCODING   = NO
+
+# If the BRIEF_MEMBER_DESC tag is set to YES (the default) Doxygen will 
+# include brief member descriptions after the members that are listed in 
+# the file and class documentation (similar to JavaDoc). 
+# Set to NO to disable this.
+
+BRIEF_MEMBER_DESC      = YES
+
+# If the REPEAT_BRIEF tag is set to YES (the default) Doxygen will prepend 
+# the brief description of a member or function before the detailed description. 
+# Note: if both HIDE_UNDOC_MEMBERS and BRIEF_MEMBER_DESC are set to NO, the 
+# brief descriptions will be completely suppressed.
+
+REPEAT_BRIEF           = YES
+
+# This tag implements a quasi-intelligent brief description abbreviator 
+# that is used to form the text in various listings. Each string 
+# in this list, if found as the leading text of the brief description, will be 
+# stripped from the text and the result after processing the whole list, is used 
+# as the annotated text. Otherwise, the brief description is used as-is. If left 
+# blank, the following values are used ("$name" is automatically replaced with the 
+# name of the entity): "The $name class" "The $name widget" "The $name file" 
+# "is" "provides" "specifies" "contains" "represents" "a" "an" "the"
+
+ABBREVIATE_BRIEF       = 
+
+# If the ALWAYS_DETAILED_SEC and REPEAT_BRIEF tags are both set to YES then 
+# Doxygen will generate a detailed section even if there is only a brief 
+# description.
+
+ALWAYS_DETAILED_SEC    = NO
+
+# If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all inherited 
+# members of a class in the documentation of that class as if those members were 
+# ordinary class members. Constructors, destructors and assignment operators of 
+# the base classes will not be shown.
+
+INLINE_INHERITED_MEMB  = NO
+
+# If the FULL_PATH_NAMES tag is set to YES then Doxygen will prepend the full 
+# path before files name in the file list and in the header files. If set 
+# to NO the shortest path that makes the file name unique will be used.
+
+FULL_PATH_NAMES        = NO
+
+# If the FULL_PATH_NAMES tag is set to YES then the STRIP_FROM_PATH tag 
+# can be used to strip a user-defined part of the path. Stripping is 
+# only done if one of the specified strings matches the left-hand part of 
+# the path. The tag can be used to show relative paths in the file list. 
+# If left blank the directory from which doxygen is run is used as the 
+# path to strip.
+
+STRIP_FROM_PATH        = 
+
+# The STRIP_FROM_INC_PATH tag can be used to strip a user-defined part of 
+# the path mentioned in the documentation of a class, which tells 
+# the reader which header file to include in order to use a class. 
+# If left blank only the name of the header file containing the class 
+# definition is used. Otherwise one should specify the include paths that 
+# are normally passed to the compiler using the -I flag.
+
+STRIP_FROM_INC_PATH    = 
+
+# If the SHORT_NAMES tag is set to YES, doxygen will generate much shorter 
+# (but less readable) file names. This can be useful is your file systems 
+# doesn't support long names like on DOS, Mac, or CD-ROM.
+
+SHORT_NAMES            = NO
+
+# If the JAVADOC_AUTOBRIEF tag is set to YES then Doxygen 
+# will interpret the first line (until the first dot) of a JavaDoc-style 
+# comment as the brief description. If set to NO, the JavaDoc 
+# comments will behave just like the Qt-style comments (thus requiring an 
+# explicit @brief command for a brief description.
+
+JAVADOC_AUTOBRIEF      = YES
+
+# The MULTILINE_CPP_IS_BRIEF tag can be set to YES to make Doxygen 
+# treat a multi-line C++ special comment block (i.e. a block of //! or /// 
+# comments) as a brief description. This used to be the default behaviour. 
+# The new default is to treat a multi-line C++ comment block as a detailed 
+# description. Set this tag to YES if you prefer the old behaviour instead.
+
+MULTILINE_CPP_IS_BRIEF = NO
+
+# If the DETAILS_AT_TOP tag is set to YES then Doxygen 
+# will output the detailed description near the top, like JavaDoc.
+# If set to NO, the detailed description appears after the member 
+# documentation.
+
+DETAILS_AT_TOP         = NO
+
+# If the INHERIT_DOCS tag is set to YES (the default) then an undocumented 
+# member inherits the documentation from any documented member that it 
+# re-implements.
+
+INHERIT_DOCS           = YES
+
+# If member grouping is used in the documentation and the DISTRIBUTE_GROUP_DOC 
+# tag is set to YES, then doxygen will reuse the documentation of the first 
+# member in the group (if any) for the other members of the group. By default 
+# all members of a group must be documented explicitly.
+
+DISTRIBUTE_GROUP_DOC   = NO
+
+# The TAB_SIZE tag can be used to set the number of spaces in a tab. 
+# Doxygen uses this value to replace tabs by spaces in code fragments.
+
+TAB_SIZE               = 8
+
+# This tag can be used to specify a number of aliases that acts 
+# as commands in the documentation. An alias has the form "name=value". 
+# For example adding "sideeffect=\par Side Effects:\n" will allow you to 
+# put the command \sideeffect (or @sideeffect) in the documentation, which 
+# will result in a user-defined paragraph with heading "Side Effects:". 
+# You can put \n's in the value part of an alias to insert newlines.
+
+ALIASES                = 
+
+# Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C sources 
+# only. Doxygen will then generate output that is more tailored for C. 
+# For instance, some of the names that are used will be different. The list 
+# of all members will be omitted, etc.
+
+OPTIMIZE_OUTPUT_FOR_C  = YES
+
+# Set the OPTIMIZE_OUTPUT_JAVA tag to YES if your project consists of Java sources 
+# only. Doxygen will then generate output that is more tailored for Java. 
+# For instance, namespaces will be presented as packages, qualified scopes 
+# will look different, etc.
+
+OPTIMIZE_OUTPUT_JAVA   = NO
+
+# Set the SUBGROUPING tag to YES (the default) to allow class member groups of 
+# the same type (for instance a group of public functions) to be put as a 
+# subgroup of that type (e.g. under the Public Functions section). Set it to 
+# NO to prevent subgrouping. Alternatively, this can be done per class using 
+# the \nosubgrouping command.
+
+SUBGROUPING            = YES
+
+#---------------------------------------------------------------------------
+# Build related configuration options
+#---------------------------------------------------------------------------
+
+# If the EXTRACT_ALL tag is set to YES doxygen will assume all entities in 
+# documentation are documented, even if no documentation was available. 
+# Private class members and static file members will be hidden unless 
+# the EXTRACT_PRIVATE and EXTRACT_STATIC tags are set to YES
+
+EXTRACT_ALL            = YES
+
+# If the EXTRACT_PRIVATE tag is set to YES all private members of a class 
+# will be included in the documentation.
+
+EXTRACT_PRIVATE        = NO
+
+# If the EXTRACT_STATIC tag is set to YES all static members of a file 
+# will be included in the documentation.
+
+EXTRACT_STATIC         = NO
+
+# If the EXTRACT_LOCAL_CLASSES tag is set to YES classes (and structs) 
+# defined locally in source files will be included in the documentation. 
+# If set to NO only classes defined in header files are included.
+
+EXTRACT_LOCAL_CLASSES  = YES
+
+# This flag is only useful for Objective-C code. When set to YES local 
+# methods, which are defined in the implementation section but not in 
+# the interface are included in the documentation. 
+# If set to NO (the default) only methods in the interface are included.
+
+EXTRACT_LOCAL_METHODS  = NO
+
+# If the HIDE_UNDOC_MEMBERS tag is set to YES, Doxygen will hide all 
+# undocumented members of documented classes, files or namespaces. 
+# If set to NO (the default) these members will be included in the 
+# various overviews, but no documentation section is generated. 
+# This option has no effect if EXTRACT_ALL is enabled.
+
+HIDE_UNDOC_MEMBERS     = NO
+
+# If the HIDE_UNDOC_CLASSES tag is set to YES, Doxygen will hide all 
+# undocumented classes that are normally visible in the class hierarchy. 
+# If set to NO (the default) these classes will be included in the various 
+# overviews. This option has no effect if EXTRACT_ALL is enabled.
+
+HIDE_UNDOC_CLASSES     = NO
+
+# If the HIDE_FRIEND_COMPOUNDS tag is set to YES, Doxygen will hide all 
+# friend (class|struct|union) declarations. 
+# If set to NO (the default) these declarations will be included in the 
+# documentation.
+
+HIDE_FRIEND_COMPOUNDS  = NO
+
+# If the HIDE_IN_BODY_DOCS tag is set to YES, Doxygen will hide any 
+# documentation blocks found inside the body of a function. 
+# If set to NO (the default) these blocks will be appended to the 
+# function's detailed documentation block.
+
+HIDE_IN_BODY_DOCS      = NO
+
+# The INTERNAL_DOCS tag determines if documentation 
+# that is typed after a \internal command is included. If the tag is set 
+# to NO (the default) then the documentation will be excluded. 
+# Set it to YES to include the internal documentation.
+
+INTERNAL_DOCS          = NO
+
+# If the CASE_SENSE_NAMES tag is set to NO then Doxygen will only generate 
+# file names in lower-case letters. If set to YES upper-case letters are also 
+# allowed. This is useful if you have classes or files whose names only differ 
+# in case and if your file system supports case sensitive file names. Windows 
+# users are advised to set this option to NO.
+
+CASE_SENSE_NAMES       = YES
+
+# If the HIDE_SCOPE_NAMES tag is set to NO (the default) then Doxygen 
+# will show members with their full class and namespace scopes in the 
+# documentation. If set to YES the scope will be hidden.
+
+HIDE_SCOPE_NAMES       = NO
+
+# If the SHOW_INCLUDE_FILES tag is set to YES (the default) then Doxygen 
+# will put a list of the files that are included by a file in the documentation 
+# of that file.
+
+SHOW_INCLUDE_FILES     = YES
+
+# If the INLINE_INFO tag is set to YES (the default) then a tag [inline] 
+# is inserted in the documentation for inline members.
+
+INLINE_INFO            = YES
+
+# If the SORT_MEMBER_DOCS tag is set to YES (the default) then doxygen 
+# will sort the (detailed) documentation of file and class members 
+# alphabetically by member name. If set to NO the members will appear in 
+# declaration order.
+
+SORT_MEMBER_DOCS       = YES
+
+# If the SORT_BRIEF_DOCS tag is set to YES then doxygen will sort the 
+# brief documentation of file, namespace and class members alphabetically 
+# by member name. If set to NO (the default) the members will appear in 
+# declaration order.
+
+SORT_BRIEF_DOCS        = NO
+
+# If the SORT_BY_SCOPE_NAME tag is set to YES, the class list will be 
+# sorted by fully-qualified names, including namespaces. If set to 
+# NO (the default), the class list will be sorted only by class name, 
+# not including the namespace part. 
+# Note: This option is not very useful if HIDE_SCOPE_NAMES is set to YES.
+# Note: This option applies only to the class list, not to the 
+# alphabetical list.
+
+SORT_BY_SCOPE_NAME     = NO
+
+# The GENERATE_TODOLIST tag can be used to enable (YES) or 
+# disable (NO) the todo list. This list is created by putting \todo 
+# commands in the documentation.
+
+GENERATE_TODOLIST      = YES
+
+# The GENERATE_TESTLIST tag can be used to enable (YES) or 
+# disable (NO) the test list. This list is created by putting \test 
+# commands in the documentation.
+
+GENERATE_TESTLIST      = YES
+
+# The GENERATE_BUGLIST tag can be used to enable (YES) or 
+# disable (NO) the bug list. This list is created by putting \bug 
+# commands in the documentation.
+
+GENERATE_BUGLIST       = YES
+
+# The GENERATE_DEPRECATEDLIST tag can be used to enable (YES) or 
+# disable (NO) the deprecated list. This list is created by putting 
+# \deprecated commands in the documentation.
+
+GENERATE_DEPRECATEDLIST= YES
+
+# The ENABLED_SECTIONS tag can be used to enable conditional 
+# documentation sections, marked by \if sectionname ... \endif.
+
+ENABLED_SECTIONS       = 
+
+# The MAX_INITIALIZER_LINES tag determines the maximum number of lines 
+# the initial value of a variable or define consists of for it to appear in 
+# the documentation. If the initializer consists of more lines than specified 
+# here it will be hidden. Use a value of 0 to hide initializers completely. 
+# The appearance of the initializer of individual variables and defines in the 
+# documentation can be controlled using \showinitializer or \hideinitializer 
+# command in the documentation regardless of this setting.
+
+MAX_INITIALIZER_LINES  = 30
+
+# Set the SHOW_USED_FILES tag to NO to disable the list of files generated 
+# at the bottom of the documentation of classes and structs. If set to YES the 
+# list will mention the files that were used to generate the documentation.
+
+SHOW_USED_FILES        = YES
+
+#---------------------------------------------------------------------------
+# configuration options related to warning and progress messages
+#---------------------------------------------------------------------------
+
+# The QUIET tag can be used to turn on/off the messages that are generated 
+# by doxygen. Possible values are YES and NO. If left blank NO is used.
+
+QUIET                  = NO
+
+# The WARNINGS tag can be used to turn on/off the warning messages that are 
+# generated by doxygen. Possible values are YES and NO. If left blank 
+# NO is used.
+
+WARNINGS               = YES
+
+# If WARN_IF_UNDOCUMENTED is set to YES, then doxygen will generate warnings 
+# for undocumented members. If EXTRACT_ALL is set to YES then this flag will 
+# automatically be disabled.
+
+WARN_IF_UNDOCUMENTED   = YES
+
+# If WARN_IF_DOC_ERROR is set to YES, doxygen will generate warnings for 
+# potential errors in the documentation, such as not documenting some 
+# parameters in a documented function, or documenting parameters that 
+# don't exist or using markup commands wrongly.
+
+WARN_IF_DOC_ERROR      = YES
+
+# The WARN_FORMAT tag determines the format of the warning messages that 
+# doxygen can produce. The string should contain the $file, $line, and $text 
+# tags, which will be replaced by the file and line number from which the 
+# warning originated and the warning text.
+
+WARN_FORMAT            = "$file:$line: $text"
+
+# The WARN_LOGFILE tag can be used to specify a file to which warning 
+# and error messages should be written. If left blank the output is written 
+# to stderr.
+
+WARN_LOGFILE           = 
+
+#---------------------------------------------------------------------------
+# configuration options related to the input files
+#---------------------------------------------------------------------------
+
+# The INPUT tag can be used to specify the files and/or directories that contain 
+# documented source files. You may enter file names like "myfile.cpp" or 
+# directories like "/usr/src/myproject". Separate the files or directories 
+# with spaces.
+
+INPUT                  = @top_srcdir@/include/theora
+
+# If the value of the INPUT tag contains directories, you can use the 
+# FILE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp 
+# and *.h) to filter out the source-files in the directories. If left 
+# blank the following patterns are tested: 
+# *.c *.cc *.cxx *.cpp *.c++ *.java *.ii *.ixx *.ipp *.i++ *.inl *.h *.hh *.hxx *.hpp 
+# *.h++ *.idl *.odl *.cs *.php *.php3 *.inc *.m *.mm
+
+FILE_PATTERNS          = 
+
+# The RECURSIVE tag can be used to turn specify whether or not subdirectories 
+# should be searched for input files as well. Possible values are YES and NO. 
+# If left blank NO is used.
+
+RECURSIVE              = NO
+
+# The EXCLUDE tag can be used to specify files and/or directories that should 
+# excluded from the INPUT source files. This way you can easily exclude a 
+# subdirectory from a directory tree whose root is specified with the INPUT tag.
+
+EXCLUDE                = 
+
+# The EXCLUDE_SYMLINKS tag can be used select whether or not files or directories 
+# that are symbolic links (a Unix filesystem feature) are excluded from the input.
+
+EXCLUDE_SYMLINKS       = NO
+
+# If the value of the INPUT tag contains directories, you can use the 
+# EXCLUDE_PATTERNS tag to specify one or more wildcard patterns to exclude 
+# certain files from those directories.
+
+EXCLUDE_PATTERNS       = 
+
+# The EXAMPLE_PATH tag can be used to specify one or more files or 
+# directories that contain example code fragments that are included (see 
+# the \include command).
+
+EXAMPLE_PATH           = 
+
+# If the value of the EXAMPLE_PATH tag contains directories, you can use the 
+# EXAMPLE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp 
+# and *.h) to filter out the source-files in the directories. If left 
+# blank all files are included.
+
+EXAMPLE_PATTERNS       = 
+
+# If the EXAMPLE_RECURSIVE tag is set to YES then subdirectories will be 
+# searched for input files to be used with the \include or \dontinclude 
+# commands irrespective of the value of the RECURSIVE tag. 
+# Possible values are YES and NO. If left blank NO is used.
+
+EXAMPLE_RECURSIVE      = NO
+
+# The IMAGE_PATH tag can be used to specify one or more files or 
+# directories that contain image that are included in the documentation (see 
+# the \image command).
+
+IMAGE_PATH             = 
+
+# The INPUT_FILTER tag can be used to specify a program that doxygen should 
+# invoke to filter for each input file. Doxygen will invoke the filter program 
+# by executing (via popen()) the command <filter> <input-file>, where <filter> 
+# is the value of the INPUT_FILTER tag, and <input-file> is the name of an 
+# input file. Doxygen will then use the output that the filter program writes 
+# to standard output.
+
+INPUT_FILTER           = 
+
+# If the FILTER_SOURCE_FILES tag is set to YES, the input filter (if set using 
+# INPUT_FILTER) will be used to filter the input files when producing source 
+# files to browse (i.e. when SOURCE_BROWSER is set to YES).
+
+FILTER_SOURCE_FILES    = NO
+
+#---------------------------------------------------------------------------
+# configuration options related to source browsing
+#---------------------------------------------------------------------------
+
+# If the SOURCE_BROWSER tag is set to YES then a list of source files will 
+# be generated. Documented entities will be cross-referenced with these sources. 
+# Note: To get rid of all source code in the generated output, make sure also 
+# VERBATIM_HEADERS is set to NO.
+
+SOURCE_BROWSER         = NO
+
+# Setting the INLINE_SOURCES tag to YES will include the body 
+# of functions and classes directly in the documentation.
+
+INLINE_SOURCES         = NO
+
+# Setting the STRIP_CODE_COMMENTS tag to YES (the default) will instruct 
+# doxygen to hide any special comment blocks from generated source code 
+# fragments. Normal C and C++ comments will always remain visible.
+
+STRIP_CODE_COMMENTS    = YES
+
+# If the REFERENCED_BY_RELATION tag is set to YES (the default) 
+# then for each documented function all documented 
+# functions referencing it will be listed.
+
+REFERENCED_BY_RELATION = YES
+
+# If the REFERENCES_RELATION tag is set to YES (the default) 
+# then for each documented function all documented entities 
+# called/used by that function will be listed.
+
+REFERENCES_RELATION    = YES
+
+# If the VERBATIM_HEADERS tag is set to YES (the default) then Doxygen 
+# will generate a verbatim copy of the header file for each class for 
+# which an include is specified. Set to NO to disable this.
+
+VERBATIM_HEADERS       = YES
+
+#---------------------------------------------------------------------------
+# configuration options related to the alphabetical class index
+#---------------------------------------------------------------------------
+
+# If the ALPHABETICAL_INDEX tag is set to YES, an alphabetical index 
+# of all compounds will be generated. Enable this if the project 
+# contains a lot of classes, structs, unions or interfaces.
+
+ALPHABETICAL_INDEX     = NO
+
+# If the alphabetical index is enabled (see ALPHABETICAL_INDEX) then 
+# the COLS_IN_ALPHA_INDEX tag can be used to specify the number of columns 
+# in which this list will be split (can be a number in the range [1..20])
+
+COLS_IN_ALPHA_INDEX    = 5
+
+# In case all classes in a project start with a common prefix, all 
+# classes will be put under the same header in the alphabetical index. 
+# The IGNORE_PREFIX tag can be used to specify one or more prefixes that 
+# should be ignored while generating the index headers.
+
+IGNORE_PREFIX          = 
+
+#---------------------------------------------------------------------------
+# configuration options related to the HTML output
+#---------------------------------------------------------------------------
+
+# If the GENERATE_HTML tag is set to YES (the default) Doxygen will 
+# generate HTML output.
+
+GENERATE_HTML          = YES
+
+# The HTML_OUTPUT tag is used to specify where the HTML docs will be put. 
+# If a relative path is entered the value of OUTPUT_DIRECTORY will be 
+# put in front of it. If left blank `html' will be used as the default path.
+
+HTML_OUTPUT            = html
+
+# The HTML_FILE_EXTENSION tag can be used to specify the file extension for 
+# each generated HTML page (for example: .htm,.php,.asp). If it is left blank 
+# doxygen will generate files with .html extension.
+
+HTML_FILE_EXTENSION    = .html
+
+# The HTML_HEADER tag can be used to specify a personal HTML header for 
+# each generated HTML page. If it is left blank doxygen will generate a 
+# standard header.
+
+HTML_HEADER            = 
+
+# The HTML_FOOTER tag can be used to specify a personal HTML footer for 
+# each generated HTML page. If it is left blank doxygen will generate a 
+# standard footer.
+
+HTML_FOOTER            = 
+
+# The HTML_STYLESHEET tag can be used to specify a user-defined cascading 
+# style sheet that is used by each HTML page. It can be used to 
+# fine-tune the look of the HTML output. If the tag is left blank doxygen 
+# will generate a default style sheet. Note that doxygen will try to copy 
+# the style sheet file to the HTML output directory, so don't put your own 
+# stylesheet in the HTML output directory as well, or it will be erased!
+
+HTML_STYLESHEET        = 
+
+# If the HTML_ALIGN_MEMBERS tag is set to YES, the members of classes, 
+# files or namespaces will be aligned in HTML using tables. If set to 
+# NO a bullet list will be used.
+
+HTML_ALIGN_MEMBERS     = YES
+
+# If the GENERATE_HTMLHELP tag is set to YES, additional index files 
+# will be generated that can be used as input for tools like the 
+# Microsoft HTML help workshop to generate a compressed HTML help file (.chm) 
+# of the generated HTML documentation.
+
+GENERATE_HTMLHELP      = NO
+
+# If the GENERATE_HTMLHELP tag is set to YES, the CHM_FILE tag can 
+# be used to specify the file name of the resulting .chm file. You 
+# can add a path in front of the file if the result should not be 
+# written to the html output directory.
+
+CHM_FILE               = 
+
+# If the GENERATE_HTMLHELP tag is set to YES, the HHC_LOCATION tag can 
+# be used to specify the location (absolute path including file name) of 
+# the HTML help compiler (hhc.exe). If non-empty doxygen will try to run 
+# the HTML help compiler on the generated index.hhp.
+
+HHC_LOCATION           = 
+
+# If the GENERATE_HTMLHELP tag is set to YES, the GENERATE_CHI flag 
+# controls if a separate .chi index file is generated (YES) or that 
+# it should be included in the master .chm file (NO).
+
+GENERATE_CHI           = NO
+
+# If the GENERATE_HTMLHELP tag is set to YES, the BINARY_TOC flag 
+# controls whether a binary table of contents is generated (YES) or a 
+# normal table of contents (NO) in the .chm file.
+
+BINARY_TOC             = NO
+
+# The TOC_EXPAND flag can be set to YES to add extra items for group members 
+# to the contents of the HTML help documentation and to the tree view.
+
+TOC_EXPAND             = NO
+
+# The DISABLE_INDEX tag can be used to turn on/off the condensed index at 
+# top of each HTML page. The value NO (the default) enables the index and 
+# the value YES disables it.
+
+DISABLE_INDEX          = NO
+
+# This tag can be used to set the number of enum values (range [1..20]) 
+# that doxygen will group on one line in the generated HTML documentation.
+
+ENUM_VALUES_PER_LINE   = 4
+
+# If the GENERATE_TREEVIEW tag is set to YES, a side panel will be
+# generated containing a tree-like index structure (just like the one that 
+# is generated for HTML Help). For this to work a browser that supports 
+# JavaScript, DHTML, CSS and frames is required (for instance Mozilla 1.0+, 
+# Netscape 6.0+, Internet explorer 5.0+, or Konqueror). Windows users are 
+# probably better off using the HTML help feature.
+
+GENERATE_TREEVIEW      = NO
+
+# If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be 
+# used to set the initial width (in pixels) of the frame in which the tree 
+# is shown.
+
+TREEVIEW_WIDTH         = 250
+
+#---------------------------------------------------------------------------
+# configuration options related to the LaTeX output
+#---------------------------------------------------------------------------
+
+# If the GENERATE_LATEX tag is set to YES (the default) Doxygen will 
+# generate Latex output.
+
+GENERATE_LATEX         = YES
+
+# The LATEX_OUTPUT tag is used to specify where the LaTeX docs will be put. 
+# If a relative path is entered the value of OUTPUT_DIRECTORY will be 
+# put in front of it. If left blank `latex' will be used as the default path.
+
+LATEX_OUTPUT           = latex
+
+# The LATEX_CMD_NAME tag can be used to specify the LaTeX command name to be 
+# invoked. If left blank `latex' will be used as the default command name.
+
+LATEX_CMD_NAME         = latex
+
+# The MAKEINDEX_CMD_NAME tag can be used to specify the command name to 
+# generate index for LaTeX. If left blank `makeindex' will be used as the 
+# default command name.
+
+MAKEINDEX_CMD_NAME     = makeindex
+
+# If the COMPACT_LATEX tag is set to YES Doxygen generates more compact 
+# LaTeX documents. This may be useful for small projects and may help to 
+# save some trees in general.
+
+COMPACT_LATEX          = NO
+
+# The PAPER_TYPE tag can be used to set the paper type that is used 
+# by the printer. Possible values are: a4, a4wide, letter, legal and 
+# executive. If left blank a4wide will be used.
+
+PAPER_TYPE             = a4wide
+
+# The EXTRA_PACKAGES tag can be to specify one or more names of LaTeX 
+# packages that should be included in the LaTeX output.
+
+EXTRA_PACKAGES         = 
+
+# The LATEX_HEADER tag can be used to specify a personal LaTeX header for 
+# the generated latex document. The header should contain everything until 
+# the first chapter. If it is left blank doxygen will generate a 
+# standard header. Notice: only use this tag if you know what you are doing!
+
+LATEX_HEADER           = 
+
+# If the PDF_HYPERLINKS tag is set to YES, the LaTeX that is generated 
+# is prepared for conversion to pdf (using ps2pdf). The pdf file will 
+# contain links (just like the HTML output) instead of page references 
+# This makes the output suitable for online browsing using a pdf viewer.
+
+PDF_HYPERLINKS         = NO
+
+# If the USE_PDFLATEX tag is set to YES, pdflatex will be used instead of 
+# plain latex in the generated Makefile. Set this option to YES to get a 
+# higher quality PDF documentation.
+
+USE_PDFLATEX           = NO
+
+# If the LATEX_BATCHMODE tag is set to YES, doxygen will add the \\batchmode. 
+# command to the generated LaTeX files. This will instruct LaTeX to keep 
+# running if errors occur, instead of asking the user for help. 
+# This option is also used when generating formulas in HTML.
+
+LATEX_BATCHMODE        = NO
+
+# If LATEX_HIDE_INDICES is set to YES then doxygen will not 
+# include the index chapters (such as File Index, Compound Index, etc.) 
+# in the output.
+
+LATEX_HIDE_INDICES     = NO
+
+#---------------------------------------------------------------------------
+# configuration options related to the RTF output
+#---------------------------------------------------------------------------
+
+# If the GENERATE_RTF tag is set to YES Doxygen will generate RTF output 
+# The RTF output is optimized for Word 97 and may not look very pretty with 
+# other RTF readers or editors.
+
+GENERATE_RTF           = NO
+
+# The RTF_OUTPUT tag is used to specify where the RTF docs will be put. 
+# If a relative path is entered the value of OUTPUT_DIRECTORY will be 
+# put in front of it. If left blank `rtf' will be used as the default path.
+
+RTF_OUTPUT             = rtf
+
+# If the COMPACT_RTF tag is set to YES Doxygen generates more compact 
+# RTF documents. This may be useful for small projects and may help to 
+# save some trees in general.
+
+COMPACT_RTF            = NO
+
+# If the RTF_HYPERLINKS tag is set to YES, the RTF that is generated 
+# will contain hyperlink fields. The RTF file will 
+# contain links (just like the HTML output) instead of page references. 
+# This makes the output suitable for online browsing using WORD or other 
+# programs which support those fields. 
+# Note: wordpad (write) and others do not support links.
+
+RTF_HYPERLINKS         = NO
+
+# Load stylesheet definitions from file. Syntax is similar to doxygen's 
+# config file, i.e. a series of assignments. You only have to provide 
+# replacements, missing definitions are set to their default value.
+
+RTF_STYLESHEET_FILE    = 
+
+# Set optional variables used in the generation of an rtf document. 
+# Syntax is similar to doxygen's config file.
+
+RTF_EXTENSIONS_FILE    = 
+
+#---------------------------------------------------------------------------
+# configuration options related to the man page output
+#---------------------------------------------------------------------------
+
+# If the GENERATE_MAN tag is set to YES (the default) Doxygen will 
+# generate man pages
+
+GENERATE_MAN           = NO
+
+# The MAN_OUTPUT tag is used to specify where the man pages will be put. 
+# If a relative path is entered the value of OUTPUT_DIRECTORY will be 
+# put in front of it. If left blank `man' will be used as the default path.
+
+MAN_OUTPUT             = man
+
+# The MAN_EXTENSION tag determines the extension that is added to 
+# the generated man pages (default is the subroutine's section .3)
+
+MAN_EXTENSION          = .3
+
+# If the MAN_LINKS tag is set to YES and Doxygen generates man output, 
+# then it will generate one additional man file for each entity 
+# documented in the real man page(s). These additional files 
+# only source the real man page, but without them the man command 
+# would be unable to find the correct page. The default is NO.
+
+MAN_LINKS              = NO
+
+#---------------------------------------------------------------------------
+# configuration options related to the XML output
+#---------------------------------------------------------------------------
+
+# If the GENERATE_XML tag is set to YES Doxygen will 
+# generate an XML file that captures the structure of 
+# the code including all documentation.
+
+GENERATE_XML           = NO
+
+# The XML_OUTPUT tag is used to specify where the XML pages will be put. 
+# If a relative path is entered the value of OUTPUT_DIRECTORY will be 
+# put in front of it. If left blank `xml' will be used as the default path.
+
+XML_OUTPUT             = xml
+
+# The XML_SCHEMA tag can be used to specify an XML schema, 
+# which can be used by a validating XML parser to check the 
+# syntax of the XML files.
+
+XML_SCHEMA             = 
+
+# The XML_DTD tag can be used to specify an XML DTD, 
+# which can be used by a validating XML parser to check the 
+# syntax of the XML files.
+
+XML_DTD                = 
+
+# If the XML_PROGRAMLISTING tag is set to YES Doxygen will 
+# dump the program listings (including syntax highlighting 
+# and cross-referencing information) to the XML output. Note that 
+# enabling this will significantly increase the size of the XML output.
+
+XML_PROGRAMLISTING     = YES
+
+#---------------------------------------------------------------------------
+# configuration options for the AutoGen Definitions output
+#---------------------------------------------------------------------------
+
+# If the GENERATE_AUTOGEN_DEF tag is set to YES Doxygen will 
+# generate an AutoGen Definitions (see autogen.sf.net) file 
+# that captures the structure of the code including all 
+# documentation. Note that this feature is still experimental 
+# and incomplete at the moment.
+
+GENERATE_AUTOGEN_DEF   = NO
+
+#---------------------------------------------------------------------------
+# configuration options related to the Perl module output
+#---------------------------------------------------------------------------
+
+# If the GENERATE_PERLMOD tag is set to YES Doxygen will 
+# generate a Perl module file that captures the structure of 
+# the code including all documentation. Note that this 
+# feature is still experimental and incomplete at the 
+# moment.
+
+GENERATE_PERLMOD       = NO
+
+# If the PERLMOD_LATEX tag is set to YES Doxygen will generate 
+# the necessary Makefile rules, Perl scripts and LaTeX code to be able 
+# to generate PDF and DVI output from the Perl module output.
+
+PERLMOD_LATEX          = NO
+
+# If the PERLMOD_PRETTY tag is set to YES the Perl module output will be 
+# nicely formatted so it can be parsed by a human reader.  This is useful 
+# if you want to understand what is going on.  On the other hand, if this 
+# tag is set to NO the size of the Perl module output will be much smaller 
+# and Perl will parse it just the same.
+
+PERLMOD_PRETTY         = YES
+
+# The names of the make variables in the generated doxyrules.make file 
+# are prefixed with the string contained in PERLMOD_MAKEVAR_PREFIX. 
+# This is useful so different doxyrules.make files included by the same 
+# Makefile don't overwrite each other's variables.
+
+PERLMOD_MAKEVAR_PREFIX = 
+
+#---------------------------------------------------------------------------
+# Configuration options related to the preprocessor   
+#---------------------------------------------------------------------------
+
+# If the ENABLE_PREPROCESSING tag is set to YES (the default) Doxygen will 
+# evaluate all C-preprocessor directives found in the sources and include 
+# files.
+
+ENABLE_PREPROCESSING   = YES
+
+# If the MACRO_EXPANSION tag is set to YES Doxygen will expand all macro 
+# names in the source code. If set to NO (the default) only conditional 
+# compilation will be performed. Macro expansion can be done in a controlled 
+# way by setting EXPAND_ONLY_PREDEF to YES.
+
+MACRO_EXPANSION        = NO
+
+# If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES 
+# then the macro expansion is limited to the macros specified with the 
+# PREDEFINED and EXPAND_AS_PREDEFINED tags.
+
+EXPAND_ONLY_PREDEF     = NO
+
+# If the SEARCH_INCLUDES tag is set to YES (the default) the includes files 
+# in the INCLUDE_PATH (see below) will be search if a #include is found.
+
+SEARCH_INCLUDES        = YES
+
+# The INCLUDE_PATH tag can be used to specify one or more directories that 
+# contain include files that are not input files but should be processed by 
+# the preprocessor.
+
+INCLUDE_PATH           = 
+
+# You can use the INCLUDE_FILE_PATTERNS tag to specify one or more wildcard 
+# patterns (like *.h and *.hpp) to filter out the header-files in the 
+# directories. If left blank, the patterns specified with FILE_PATTERNS will 
+# be used.
+
+INCLUDE_FILE_PATTERNS  = 
+
+# The PREDEFINED tag can be used to specify one or more macro names that 
+# are defined before the preprocessor is started (similar to the -D option of 
+# gcc). The argument of the tag is a list of macros of the form: name 
+# or name=definition (no spaces). If the definition and the = are 
+# omitted =1 is assumed.
+
+PREDEFINED             = 
+
+# If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then 
+# this tag can be used to specify a list of macro names that should be expanded. 
+# The macro definition that is found in the sources will be used. 
+# Use the PREDEFINED tag if you want to use a different macro definition.
+
+EXPAND_AS_DEFINED      = 
+
+# If the SKIP_FUNCTION_MACROS tag is set to YES (the default) then 
+# doxygen's preprocessor will remove all function-like macros that are alone 
+# on a line, have an all uppercase name, and do not end with a semicolon. Such 
+# function macros are typically used for boiler-plate code, and will confuse the 
+# parser if not removed.
+
+SKIP_FUNCTION_MACROS   = YES
+
+#---------------------------------------------------------------------------
+# Configuration::additions related to external references   
+#---------------------------------------------------------------------------
+
+# The TAGFILES option can be used to specify one or more tagfiles. 
+# Optionally an initial location of the external documentation 
+# can be added for each tagfile. The format of a tag file without 
+# this location is as follows: 
+#   TAGFILES = file1 file2 ... 
+# Adding location for the tag files is done as follows: 
+#   TAGFILES = file1=loc1 "file2 = loc2" ... 
+# where "loc1" and "loc2" can be relative or absolute paths or 
+# URLs. If a location is present for each tag, the installdox tool 
+# does not have to be run to correct the links.
+# Note that each tag file must have a unique name
+# (where the name does NOT include the path)
+# If a tag file is not located in the directory in which doxygen 
+# is run, you must also specify the path to the tagfile here.
+
+TAGFILES               = 
+
+# When a file name is specified after GENERATE_TAGFILE, doxygen will create 
+# a tag file that is based on the input files it reads.
+
+GENERATE_TAGFILE       = 
+
+# If the ALLEXTERNALS tag is set to YES all external classes will be listed 
+# in the class index. If set to NO only the inherited external classes 
+# will be listed.
+
+ALLEXTERNALS           = NO
+
+# If the EXTERNAL_GROUPS tag is set to YES all external groups will be listed 
+# in the modules index. If set to NO, only the current project's groups will 
+# be listed.
+
+EXTERNAL_GROUPS        = YES
+
+# The PERL_PATH should be the absolute path and name of the perl script 
+# interpreter (i.e. the result of `which perl').
+
+PERL_PATH              = /usr/bin/perl
+
+#---------------------------------------------------------------------------
+# Configuration options related to the dot tool   
+#---------------------------------------------------------------------------
+
+# If the CLASS_DIAGRAMS tag is set to YES (the default) Doxygen will 
+# generate a inheritance diagram (in HTML, RTF and LaTeX) for classes with base or 
+# super classes. Setting the tag to NO turns the diagrams off. Note that this 
+# option is superseded by the HAVE_DOT option below. This is only a fallback. It is 
+# recommended to install and use dot, since it yields more powerful graphs.
+
+CLASS_DIAGRAMS         = YES
+
+# If set to YES, the inheritance and collaboration graphs will hide 
+# inheritance and usage relations if the target is undocumented 
+# or is not a class.
+
+HIDE_UNDOC_RELATIONS   = YES
+
+# If you set the HAVE_DOT tag to YES then doxygen will assume the dot tool is 
+# available from the path. This tool is part of Graphviz, a graph visualization 
+# toolkit from AT&T and Lucent Bell Labs. The other options in this section 
+# have no effect if this option is set to NO (the default)
+
+HAVE_DOT               = NO
+
+# If the CLASS_GRAPH and HAVE_DOT tags are set to YES then doxygen 
+# will generate a graph for each documented class showing the direct and 
+# indirect inheritance relations. Setting this tag to YES will force the 
+# the CLASS_DIAGRAMS tag to NO.
+
+CLASS_GRAPH            = YES
+
+# If the COLLABORATION_GRAPH and HAVE_DOT tags are set to YES then doxygen 
+# will generate a graph for each documented class showing the direct and 
+# indirect implementation dependencies (inheritance, containment, and 
+# class references variables) of the class with other documented classes.
+
+COLLABORATION_GRAPH    = YES
+
+# If the UML_LOOK tag is set to YES doxygen will generate inheritance and 
+# collaboration diagrams in a style similar to the OMG's Unified Modeling 
+# Language.
+
+UML_LOOK               = NO
+
+# If set to YES, the inheritance and collaboration graphs will show the 
+# relations between templates and their instances.
+
+TEMPLATE_RELATIONS     = NO
+
+# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDE_GRAPH, and HAVE_DOT 
+# tags are set to YES then doxygen will generate a graph for each documented 
+# file showing the direct and indirect include dependencies of the file with 
+# other documented files.
+
+INCLUDE_GRAPH          = YES
+
+# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDED_BY_GRAPH, and 
+# HAVE_DOT tags are set to YES then doxygen will generate a graph for each 
+# documented header file showing the documented files that directly or 
+# indirectly include this file.
+
+INCLUDED_BY_GRAPH      = YES
+
+# If the CALL_GRAPH and HAVE_DOT tags are set to YES then doxygen will 
+# generate a call dependency graph for every global function or class method. 
+# Note that enabling this option will significantly increase the time of a run. 
+# So in most cases it will be better to enable call graphs for selected 
+# functions only using the \callgraph command.
+
+CALL_GRAPH             = NO
+
+# If the GRAPHICAL_HIERARCHY and HAVE_DOT tags are set to YES then doxygen 
+# will graphical hierarchy of all classes instead of a textual one.
+
+GRAPHICAL_HIERARCHY    = YES
+
+# The DOT_IMAGE_FORMAT tag can be used to set the image format of the images 
+# generated by dot. Possible values are png, jpg, or gif
+# If left blank png will be used.
+
+DOT_IMAGE_FORMAT       = png
+
+# The tag DOT_PATH can be used to specify the path where the dot tool can be 
+# found. If left blank, it is assumed the dot tool can be found on the path.
+
+DOT_PATH               = 
+
+# The DOTFILE_DIRS tag can be used to specify one or more directories that 
+# contain dot files that are included in the documentation (see the 
+# \dotfile command).
+
+DOTFILE_DIRS           = 
+
+# The MAX_DOT_GRAPH_WIDTH tag can be used to set the maximum allowed width 
+# (in pixels) of the graphs generated by dot. If a graph becomes larger than 
+# this value, doxygen will try to truncate the graph, so that it fits within 
+# the specified constraint. Beware that most browsers cannot cope with very 
+# large images.
+#This tag is now obsolete, according to doxygen 1.5.2
+#MAX_DOT_GRAPH_WIDTH    = 1024
+
+# The MAX_DOT_GRAPH_HEIGHT tag can be used to set the maximum allows height 
+# (in pixels) of the graphs generated by dot. If a graph becomes larger than 
+# this value, doxygen will try to truncate the graph, so that it fits within 
+# the specified constraint. Beware that most browsers cannot cope with very 
+# large images.
+#This tag is now obsolete, according to doxygen 1.5.2
+#MAX_DOT_GRAPH_HEIGHT   = 1024
+
+# The MAX_DOT_GRAPH_DEPTH tag can be used to set the maximum depth of the 
+# graphs generated by dot. A depth value of 3 means that only nodes reachable 
+# from the root by following a path via at most 3 edges will be shown. Nodes that 
+# lay further from the root node will be omitted. Note that setting this option to 
+# 1 or 2 may greatly reduce the computation time needed for large code bases. Also 
+# note that a graph may be further truncated if the graph's image dimensions are 
+# not sufficient to fit the graph (see MAX_DOT_GRAPH_WIDTH and MAX_DOT_GRAPH_HEIGHT). 
+# If 0 is used for the depth value (the default), the graph is not depth-constrained.
+#This tag is now obsolete, according to doxygen 1.5.2
+#MAX_DOT_GRAPH_DEPTH    = 0
+
+# If the GENERATE_LEGEND tag is set to YES (the default) Doxygen will 
+# generate a legend page explaining the meaning of the various boxes and 
+# arrows in the dot generated graphs.
+
+GENERATE_LEGEND        = YES
+
+# If the DOT_CLEANUP tag is set to YES (the default) Doxygen will 
+# remove the intermediate dot files that are used to generate 
+# the various graphs.
+
+DOT_CLEANUP            = YES
+
+#---------------------------------------------------------------------------
+# Configuration::additions related to the search engine   
+#---------------------------------------------------------------------------
+
+# The SEARCHENGINE tag specifies whether or not a search engine should be 
+# used. If set to NO the values of all tags below this one will be ignored.
+
+SEARCHENGINE           = NO
diff --git a/doc/Makefile.am b/doc/Makefile.am
new file mode 100644 (file)
index 0000000..30eaad8
--- /dev/null
@@ -0,0 +1,74 @@
+## Process this file with automake to produce Makefile.in
+
+SUBDIRS = spec
+
+docdir = $(datadir)/doc/$(PACKAGE)-$(VERSION)
+
+static_docs = vp3-format.txt color.html \
+       draft-ietf-avt-rtp-theora-00.xml \
+       draft-ietf-avt-rtp-theora-00.txt
+
+doc_DATA = $(static_docs) doxygen-build.stamp
+
+EXTRA_DIST = $(static_docs) Doxyfile.in
+
+if HAVE_DOXYGEN
+doxygen-build.stamp: Doxyfile $(top_srcdir)/include/theora/*.h
+       doxygen
+       touch doxygen-build.stamp
+else
+doxygen-build.stamp:
+       echo "*** Warning: Doxygen not found; documentation will not be built."
+       touch doxygen-build.stamp
+endif
+
+dist_docdir = $(distdir)/libtheora
+
+dist-hook:
+       if test -d libtheora; then \
+         mkdir $(dist_docdir); \
+         echo -n "copying built documenation..."; \
+         for dir in libtheora/*; do \
+           b=`basename $$dir`; \
+           if test $$b != ".svn"; then \
+             if test -d $$dir; then \
+               mkdir $(dist_docdir)/$$b; \
+               for f in $$dir/*; do \
+                 cp -p $$f $(dist_docdir)/$$b; \
+               done; \
+             fi; \
+           fi; \
+         done; \
+         echo "OK"; \
+       fi
+       for item in $(EXTRA_DIST); do \
+         if test -d $$item; then \
+           echo -n "cleaning $$item dir for distribution..."; \
+           rm -rf `find $(distdir)/$$item -name .svn`; \
+           echo "OK"; \
+         fi; \
+       done
+
+
+
+install-data-local: doxygen-build.stamp
+       $(mkinstalldirs) $(DESTDIR)$(docdir)
+       if test -d libtheora; then \
+         for dir in libtheora/*; do \
+           if test -d $$dir; then \
+             b=`basename $$dir`; \
+             $(mkinstalldirs) $(DESTDIR)$(docdir)/$$b; \
+             for f in $$dir/*; do \
+               $(INSTALL_DATA) $$f $(DESTDIR)$(docdir)/$$b; \
+             done \
+           fi \
+         done \
+       fi
+
+uninstall-local:
+       rm -rf $(DESTDIR)$(docdir)
+
+clean-local:
+       if test -d libtheora; then rm -rf libtheora; fi
+       if test -f doxygen-build.stamp; then rm -f doxygen-build.stamp; fi
+
diff --git a/doc/Makefile.in b/doc/Makefile.in
new file mode 100644 (file)
index 0000000..aae84ac
--- /dev/null
@@ -0,0 +1,508 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+
+SUBDIRS = spec
+
+docdir = $(datadir)/doc/$(PACKAGE)-$(VERSION)
+
+static_docs = vp3-format.txt color.html \
+       draft-ietf-avt-rtp-theora-00.xml \
+       draft-ietf-avt-rtp-theora-00.txt
+
+
+doc_DATA = $(static_docs) doxygen-build.stamp
+
+EXTRA_DIST = $(static_docs) Doxyfile.in
+
+dist_docdir = $(distdir)/libtheora
+subdir = doc
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES = Doxyfile
+DIST_SOURCES =
+DATA = $(doc_DATA)
+
+
+RECURSIVE_TARGETS = info-recursive dvi-recursive install-info-recursive \
+       uninstall-info-recursive all-recursive install-data-recursive \
+       install-exec-recursive installdirs-recursive install-recursive \
+       uninstall-recursive check-recursive installcheck-recursive
+DIST_COMMON = Doxyfile.in Makefile.am Makefile.in
+DIST_SUBDIRS = $(SUBDIRS)
+all: all-recursive
+
+.SUFFIXES:
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  doc/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+Doxyfile: $(top_builddir)/config.status Doxyfile.in
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+docDATA_INSTALL = $(INSTALL_DATA)
+install-docDATA: $(doc_DATA)
+       @$(NORMAL_INSTALL)
+       $(mkinstalldirs) $(DESTDIR)$(docdir)
+       @list='$(doc_DATA)'; for p in $$list; do \
+         if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " $(docDATA_INSTALL) $$d$$p $(DESTDIR)$(docdir)/$$f"; \
+         $(docDATA_INSTALL) $$d$$p $(DESTDIR)$(docdir)/$$f; \
+       done
+
+uninstall-docDATA:
+       @$(NORMAL_UNINSTALL)
+       @list='$(doc_DATA)'; for p in $$list; do \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " rm -f $(DESTDIR)$(docdir)/$$f"; \
+         rm -f $(DESTDIR)$(docdir)/$$f; \
+       done
+
+# This directory's subdirectories are mostly independent; you can cd
+# into them and run `make' without going through this Makefile.
+# To change the values of `make' variables: instead of editing Makefiles,
+# (1) if the variable is set in `config.status', edit `config.status'
+#     (which will cause the Makefiles to be regenerated when you run `make');
+# (2) otherwise, pass the desired values on the `make' command line.
+$(RECURSIVE_TARGETS):
+       @set fnord $$MAKEFLAGS; amf=$$2; \
+       dot_seen=no; \
+       target=`echo $@ | sed s/-recursive//`; \
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         echo "Making $$target in $$subdir"; \
+         if test "$$subdir" = "."; then \
+           dot_seen=yes; \
+           local_target="$$target-am"; \
+         else \
+           local_target="$$target"; \
+         fi; \
+         (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+          || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
+       done; \
+       if test "$$dot_seen" = "no"; then \
+         $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
+       fi; test -z "$$fail"
+
+mostlyclean-recursive clean-recursive distclean-recursive \
+maintainer-clean-recursive:
+       @set fnord $$MAKEFLAGS; amf=$$2; \
+       dot_seen=no; \
+       case "$@" in \
+         distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
+         *) list='$(SUBDIRS)' ;; \
+       esac; \
+       rev=''; for subdir in $$list; do \
+         if test "$$subdir" = "."; then :; else \
+           rev="$$subdir $$rev"; \
+         fi; \
+       done; \
+       rev="$$rev ."; \
+       target=`echo $@ | sed s/-recursive//`; \
+       for subdir in $$rev; do \
+         echo "Making $$target in $$subdir"; \
+         if test "$$subdir" = "."; then \
+           local_target="$$target-am"; \
+         else \
+           local_target="$$target"; \
+         fi; \
+         (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+          || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
+       done && test -z "$$fail"
+tags-recursive:
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \
+       done
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS: tags-recursive $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         if test "$$subdir" = .; then :; else \
+           test -f $$subdir/TAGS && tags="$$tags -i $$here/$$subdir/TAGS"; \
+         fi; \
+       done; \
+       list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         if test "$$subdir" = .; then :; else \
+           test -d $(distdir)/$$subdir \
+           || mkdir $(distdir)/$$subdir \
+           || exit 1; \
+           (cd $$subdir && \
+             $(MAKE) $(AM_MAKEFLAGS) \
+               top_distdir="$(top_distdir)" \
+               distdir=../$(distdir)/$$subdir \
+               distdir) \
+             || exit 1; \
+         fi; \
+       done
+       $(MAKE) $(AM_MAKEFLAGS) \
+         top_distdir="${top_distdir}" distdir="$(distdir)" \
+         dist-hook
+check-am: all-am
+check: check-recursive
+all-am: Makefile $(DATA)
+installdirs: installdirs-recursive
+installdirs-am:
+       $(mkinstalldirs) $(DESTDIR)$(docdir)
+
+install: install-recursive
+install-exec: install-exec-recursive
+install-data: install-data-recursive
+uninstall: uninstall-recursive
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-recursive
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-recursive
+
+clean-am: clean-generic clean-libtool clean-local mostlyclean-am
+
+distclean: distclean-recursive
+
+distclean-am: clean-am distclean-generic distclean-libtool \
+       distclean-tags
+
+dvi: dvi-recursive
+
+dvi-am:
+
+info: info-recursive
+
+info-am:
+
+install-data-am: install-data-local install-docDATA
+
+install-exec-am:
+
+install-info: install-info-recursive
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-recursive
+
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-recursive
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+uninstall-am: uninstall-docDATA uninstall-info-am uninstall-local
+
+uninstall-info: uninstall-info-recursive
+
+.PHONY: $(RECURSIVE_TARGETS) GTAGS all all-am check check-am clean \
+       clean-generic clean-libtool clean-local clean-recursive \
+       distclean distclean-generic distclean-libtool \
+       distclean-recursive distclean-tags distdir dvi dvi-am \
+       dvi-recursive info info-am info-recursive install install-am \
+       install-data install-data-am install-data-local \
+       install-data-recursive install-docDATA install-exec \
+       install-exec-am install-exec-recursive install-info \
+       install-info-am install-info-recursive install-man \
+       install-recursive install-strip installcheck installcheck-am \
+       installdirs installdirs-am installdirs-recursive \
+       maintainer-clean maintainer-clean-generic \
+       maintainer-clean-recursive mostlyclean mostlyclean-generic \
+       mostlyclean-libtool mostlyclean-recursive tags tags-recursive \
+       uninstall uninstall-am uninstall-docDATA uninstall-info-am \
+       uninstall-info-recursive uninstall-local uninstall-recursive
+
+
+@HAVE_DOXYGEN_TRUE@doxygen-build.stamp: Doxyfile $(top_srcdir)/include/theora/*.h
+@HAVE_DOXYGEN_TRUE@    doxygen
+@HAVE_DOXYGEN_TRUE@    touch doxygen-build.stamp
+@HAVE_DOXYGEN_FALSE@doxygen-build.stamp:
+@HAVE_DOXYGEN_FALSE@   echo "*** Warning: Doxygen not found; documentation will not be built."
+@HAVE_DOXYGEN_FALSE@   touch doxygen-build.stamp
+
+dist-hook:
+       if test -d libtheora; then \
+         mkdir $(dist_docdir); \
+         echo -n "copying built documenation..."; \
+         for dir in libtheora/*; do \
+           b=`basename $$dir`; \
+           if test $$b != ".svn"; then \
+             if test -d $$dir; then \
+               mkdir $(dist_docdir)/$$b; \
+               for f in $$dir/*; do \
+                 cp -p $$f $(dist_docdir)/$$b; \
+               done; \
+             fi; \
+           fi; \
+         done; \
+         echo "OK"; \
+       fi
+       for item in $(EXTRA_DIST); do \
+         if test -d $$item; then \
+           echo -n "cleaning $$item dir for distribution..."; \
+           rm -rf `find $(distdir)/$$item -name .svn`; \
+           echo "OK"; \
+         fi; \
+       done
+
+install-data-local: doxygen-build.stamp
+       $(mkinstalldirs) $(DESTDIR)$(docdir)
+       if test -d libtheora; then \
+         for dir in libtheora/*; do \
+           if test -d $$dir; then \
+             b=`basename $$dir`; \
+             $(mkinstalldirs) $(DESTDIR)$(docdir)/$$b; \
+             for f in $$dir/*; do \
+               $(INSTALL_DATA) $$f $(DESTDIR)$(docdir)/$$b; \
+             done \
+           fi \
+         done \
+       fi
+
+uninstall-local:
+       rm -rf $(DESTDIR)$(docdir)
+
+clean-local:
+       if test -d libtheora; then rm -rf libtheora; fi
+       if test -f doxygen-build.stamp; then rm -f doxygen-build.stamp; fi
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/doc/color.html b/doc/color.html
new file mode 100644 (file)
index 0000000..9bc2450
--- /dev/null
@@ -0,0 +1,602 @@
+<HTML>
+<HEAD><TITLE>xiph.org: Ogg Theora documentation</TITLE></HEAD>
+<BODY BGCOLOR="#FFFFFF" TEXT="#202020" LINK="#006666" VLINK="#000000">
+<H1><FONT COLOR="#000070">
+Ogg Theora I specification: color space conventions
+</FONT></H1>
+<H1>Overview</H1>
+<P>
+There are a large number of different color standards used in digital video.
+Since Theora is a lossy codec, it restricts itself to only a few of them to
+ simplify playback.
+Unlike the alternate method of describing all the parameters of the color
+ model, this allows a few dedicated routines for color conversion to be written
+ and heavily optimized in a decoder.
+More flexible conversion functions should instead be specified in an encoder,
+ where additional computational complexity is more easily tolerated.
+The color spaces were selected to give a fair representation of color standards
+ in use around the world today.
+Most of the standards that do not exactly match one of these can be converted
+ to one fairly easily.
+</P>
+<P>
+The Theora codec identification header contains an 8-bit value that describes
+ the color space.
+This merely selects one of the color spaces available from an enumerated list.
+Currently, only two color spaces are defined, with a third possibility that
+ indicates the color space is "unknown".
+All of them are Y'C<SUB>b</SUB>C<SUB>r</SUB> color spaces with one luma channel
+ and two chroma channels.
+Each channel contains 8-bit discrete values in the range 0-255, which represent
+ non-linear gamma pre-corrected signals.
+</P>
+<H2>color space parameters</H2>
+<P>
+The parameters which describe each color space are listed below.
+These are the parameters needed to map colors from the encoded
+ Y'C<SUB>b</SUB>C<SUB>r</SUB> representation to the device-independent color
+ space CIE XYZ (1931).
+</P>
+<DL>
+<DT>Y'C<SUB>b</SUB>C<SUB>r</SUB> to Y'P<SUB>b</SUB>P<SUB>r</SUB></DT>
+<DD>
+<P>
+This conversion takes 8-bit discrete values in the range 0-255 and maps them to
+ real values in the range [0,1] for Y and [-1/2,1/2] for P<SUB>b</SUB>
+ and P<SUB>r</SUB>.
+Because some values may fall outside the offset and excursion defined for each
+ channel in the Y'C<SUB>b</SUB>C<SUB>r</SUB> space, the results may fall
+ outside these ranges in Y'P<SUB>b</SUB>P<SUB>r</SUB> space.
+No clamping should be done at this stage.
+</P>
+<P>
+Parameters: <EM>Offset<SUB>Y,C<SUB>b</SUB>,C<SUB>r</SUB></SUB></EM>,
+ <EM>Excursion<SUB>Y,C<SUB>b</SUB>,C<SUB>r</SUB>,</SUB></EM>
+</P>
+<TABLE>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">Y'<SUB>out</SUB></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">
+(Y'<SUB>in</SUB>-<EM>Offset<SUB>Y</SUB></EM>)/
+ <EM>Excursion<SUB>Y</SUB></EM>
+</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">P<SUB>b</SUB></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">
+(C<SUB>b</SUB>-<EM>Offset<SUB>C<SUB>b</SUB></SUB></EM>)/
+ <EM>Excursion<SUB>C<SUB>b</SUB></SUB></EM>
+</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">P<SUB>r</SUB></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">
+(C<SUB>r</SUB>-<EM>Offset<SUB>C<SUB>r</SUB></SUB></EM>)/
+ <EM>Excursion<SUB>C<SUB>r</SUB></SUB></EM>
+</TD>
+</TR>
+</TABLE>
+</DD>
+<DT>Y'P<SUB>b</SUB>P<SUB>r</SUB> to R'G'B'</DT>
+<DD>
+<P>
+This conversion takes the one luma and two chroma channel representation and
+ maps it to the non-linear R'G'B' space used to drive actual output devices.
+Values should be clamped into the range [0,1] after this stage.
+<P>
+Parameters: <EM>K<SUB>b</SUB></EM>, <EM>K<SUB>r</SUB></EM>
+</P>
+<TABLE>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">R'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">Y' + 2(1-<EM>K<SUB>r</SUB></EM>)P<SUB>r</SUB></TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">G'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">
+Y' +
+ 2((<EM>K<SUB>b</SUB></EM>-1)<EM>K<SUB>b</SUB></EM>/
+ (1-<EM>K<SUB>b</SUB></EM>-<EM>K<SUB>r</SUB></EM>))P<SUB>b</SUB> +
+ 2((<EM>K<SUB>r</SUB></EM>-1)<EM>K<SUB>r</SUB></EM>/
+ (1-<EM>K<SUB>b</SUB></EM>-<EM>K<SUB>r</SUB></EM>))P<SUB>r</SUB>
+</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">B'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">Y' + 2(1-<EM>K<SUB>b</SUB></EM>)P<SUB>b</SUB></TD>
+</TR>
+</TABLE>
+</DD>
+<DT>R'G'B' to RGB (Output device gamma correction)</DT>
+<DD>
+<P>
+This conversion takes the non-linear R'G'B' voltage levels and maps it to the
+ linear light levels produced by the actual output device.
+Note that this conversion is only that of the output device, and its inverse is
+ <EM>not</EM> that used by the input device.
+Because a dim viewing environment is assumed in most television standards, the
+ overall gamma between the input and output devices is usually around 1.1 to
+ 1.2, and not a strict 1.0.
+</P>
+<P>
+For calibration with actual output devices, the model
+<TABLE>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">L</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">(E'+&Delta;)<SUP><EM>&gamma;</EM></SUP></TD>
+</TR>
+</TABLE>
+should be used, with &Delta; the free parameter and <EM>&gamma;</EM> held
+ fixed to the value specified in this document.
+The conversion function presented here is an idealized version with &Delta;=0.
+</P>
+<P>
+Parameters: <EM>&gamma;</EM>
+</P>
+<TABLE>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">R</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">R'<SUP><EM>&gamma;</EM></SUP></TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">G</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">G'<SUP><EM>&gamma;</EM></SUP></TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">B</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">B'<SUP><EM>&gamma;</EM></SUP></TD>
+</TR>
+</TABLE>
+</DD>
+<DT>RGB to R'G'B' (Input device gamma correction)</DT>
+<DD>
+<P>
+This conversion takes linear light levels and maps them to the non-linear
+ voltage levels used to drive the actual output device.
+This information is merely informative.
+It is not required for building a decoder or for converting between the various
+ formats and the actual output capabilities of a particular device.
+</P>
+<P>
+A linear segment is introduced on the low end to reduce noise in dark areas of
+ the image.
+The rest of the scale is adjusted so that the power segment of the curve
+ intersects the linear segment with the proper slope, and so that it still maps
+ 0 to 0 and 1 to 1.
+</P>
+<P>
+Parameters: <EM>&beta;</EM>, <EM>&alpha;</EM>, <EM>&delta;</EM>,
+ <EM>&epsilon;</EM>
+</P>
+<TABLE>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">R'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">
+(1+<EM>&epsilon;</EM>)R<SUP>&beta;</SUP>-<EM>&epsilon;</EM>
+</TD>
+<TD>for <EM>&delta;</EM> &le; R &le; 1</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">R'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT"><EM>&alpha;</EM>R</TD>
+<TD>for 0 &le; R &lt; <EM>&delta;</EM></TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">G'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">
+(1+<EM>&epsilon;</EM>)G<SUP>&beta;</SUP>-<EM>&epsilon;</EM>
+</TD>
+<TD>for <EM>&delta;</EM> &le; G &le; 1</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">G'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT"><EM>&alpha;</EM>G</TD>
+<TD>for 0 &le; G &lt; <EM>&delta;</EM></TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">B'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">
+(1+<EM>&epsilon;</EM>)B<SUP>&beta;</SUP>-<EM>&epsilon;</EM>
+</TD>
+<TD>for <EM>&delta;</EM> &le; B &le; 1</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">B'</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT"><EM>&alpha;</EM>B</TD>
+<TD>for 0 &le; B &lt; <EM>&delta;</EM></TD>
+</TR>
+</TABLE>
+</DD>
+<DT>RGB to CIE XYZ (1931)</DT>
+<DD>
+<P>
+This conversion maps a device-dependent linear RGB space to the
+ device-independent linear CIE XYZ space.
+The parameters are the CIE chromaticity coordinates of the three primaries,
+ red, green, and blue, as well as the chromaticity coordinates of the white
+ point of the device.
+This is how hardware manufacturers and standards typically describe a
+ particular RGB space.
+The math required to convert these parameters into a useful transformation
+ matrix is reproduced below.
+</P>
+<P>
+Parameters: <EM>x<SUB>r,g,b,w</SUB></EM>, <EM>y<SUB>r,g,b,w</SUB></EM>
+</P>
+<TABLE>
+<TR>
+<TD ALIGN="RIGHT">F</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT"><TABLE><TR>
+<TD><FONT SIZE="300%">(</FONT></TD>
+<TD><TABLE>
+<TR>
+<TD ALIGN="CENTER"><EM>x<SUB>r</SUB></EM>/<EM>y<SUB>r</SUB></EM></TD>
+<TD ALIGN="CENTER"><EM>x<SUB>g</SUB></EM>/<EM>y<SUB>g</SUB></EM></TD>
+<TD ALIGN="CENTER"><EM>x<SUB>b</SUB></EM>/<EM>y<SUB>b</SUB></EM></TD>
+</TR>
+<TR>
+<TD ALIGN="CENTER">1</TD>
+<TD ALIGN="CENTER">1</TD>
+<TD ALIGN="CENTER">1</TD>
+</TR>
+<TR>
+<TD ALIGN="CENTER">
+(1-<EM>x<SUB>r</SUB></EM>-<EM>y<SUB>r</SUB></EM>)/<EM>y<SUB>r</SUB></EM>
+</TD>
+<TD ALIGN="CENTER">
+(1-<EM>x<SUB>g</SUB></EM>-<EM>y<SUB>g</SUB></EM>)/<EM>y<SUB>g</SUB></EM>
+</TD>
+<TD ALIGN="CENTER">
+(1-<EM>x<SUB>b</SUB></EM>-<EM>y<SUB>b</SUB></EM>)/<EM>y<SUB>b</SUB></EM>
+</TD>
+</TR>
+</TABLE></TD>
+<TD<FONT SIZE="300%">)</FONT></TD>
+</TR></TABLE></TD>
+</TR>
+<TR>
+<TD ALIGN="RIGHT"><TABLE><TR>
+<TD><FONT SIZE="300%">(</FONT></TD>
+<TD><TABLE>
+<TR><TD ALIGN="CENTER">s<SUB>r</SUB></TD></TR>
+<TR><TD ALIGN="CENTER">s<SUB>g</SUB></TD></TR>
+<TR><TD ALIGN="CENTER">s<SUB>b</SUB></TD></TR>
+</TABLE></TD>
+<TD><FONT SIZE="300%">)</FONT></TD>
+</TR></TABLE></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT"><TABLE><TR>
+<TD>F<SUP>-1</SUP><FONT SIZE="300%">(</FONT></TD>
+<TD><TABLE>
+<TR><TD ALIGN="CENTER"><EM>x<SUB>w</SUB></EM>/<EM>y<SUB>w</SUB></EM></TD></TR>
+<TR><TD ALIGN="CENTER">1</TD></TR>
+<TR><TD ALIGN="CENTER">
+(1-<EM>x<SUB>w</SUB></EM>-<EM>y<SUB>w</SUB></EM>)/<EM>y<SUB>w</SUB></EM>
+</TD></TR>
+</TABLE></TD>
+<TD><FONT SIZE="300%">)</FONT></TD>
+</TR></TABLE></TD>
+</TR>
+<TR>
+<TD ALIGN="RIGHT"><TABLE><TR>
+<TD><FONT SIZE="300%">(</FONT></TD>
+<TD><TABLE>
+<TR><TD ALIGN="CENTER">X</TD></TR>
+<TR><TD ALIGN="CENTER">Y</TD></TR>
+<TR><TD ALIGN="CENTER">Z</TD></TR>
+</TABLE></TD>
+<TD><FONT SIZE="300%">)</FONT></TD>
+</TR></TABLE></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT"><TABLE><TR>
+<TD>F<FONT SIZE="300%">(</FONT></TD>
+<TD><TABLE>
+<TR><TD ALIGN="CENTER">s<SUB>r</SUB>R</TD></TR>
+<TR><TD ALIGN="CENTER">s<SUB>g</SUB>G</TD></TR>
+<TR><TD ALIGN="CENTER">s<SUB>b</SUB>B</TD></TR>
+</TABLE></TD>
+<TD><FONT SIZE="300%">)</FONT></TD>
+</TR></TABLE></TD>
+</TR>
+</TABLE>
+</DD>
+</DL>
+<H2>available color spaces</H2>
+<P>
+These are the color spaces currently defined for use by Ogg Theora video.
+Each one has a short name, with which it is referred to in this document, and
+ a more detailed specification of the standards from which its parameters are
+ derived.
+Some standards do not specify all the parameters necessary.
+For these unspecified parameters, this document serves as the definition of
+ what should be used when encoding or decoding Ogg Theora video.
+<H3>Rec 470M (Rec. ITU-R BT.470-6 System M/NTSC with Rec. ITU-R BT.601-5)</H3>
+<P>
+This color space is used by broadcast television and DVDs in much of the
+ Americas, Japan, Korea, and the Union of Myanmar
+ [<A HREF="#Rec470">Rec470</A>].
+This color space may also be used for System M/PAL (Brazil), with an
+ appropriate conversion supplied by the encoder to compensate for the
+ different gamma value.
+See the Rec 470BG section for an appropriate gamma value to assume for M/PAL
+ input.
+</P>
+<P>
+In the US, studio monitors are adjusted to a D65 white point
+ (<EM>x<SUB>w</SUB></EM>,<EM>y<SUB>w</SUB></EM>=0.313,0.329).
+In Japan, studio monitors are adjusted to a D white of 9300K
+ (<EM>x<SUB>w</SUB></EM>,<EM>y<SUB>w</SUB></EM>=0.285,0.293).
+</P>
+<P>
+Rec 470 does not specify a digital encoding of the color signals.
+For Ogg Theora, Rec. ITU-R BT.601-5 is used, starting from the R'G'B' signals
+ specified by Rec 470 [<A HREF="#Rec601">Rec601</A>].
+</P>
+<P>
+<P>
+Rec 470 does not specify an input gamma function.
+For Ogg Theora, the Rec 709 input function is used.
+This is the same as that specified by SMPTE 170M, which claims to reflect
+ modern practice in the creation of NTSC signals (c. 1994)
+ [<A HREF="#SMPTE170M">SMPTE170M</A>].
+</P>
+<H4>parameters</H4>
+<TABLE>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>Offset<SUB>Y,C<SUB>b</SUB>,C<SUB>r</SUB></SUB></EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">(16,128,128)</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">
+<EM>Excursion<SUB>Y,C<SUB>b</SUB>,C<SUB>r</SUB></SUB></EM>
+</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">(219,224,224)</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>K<SUB>b</SUB></EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">0.114</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>K<SUB>r</SUB></EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">0.299</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&gamma;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">2.2</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&beta;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">0.45</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&alpha;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">4.5</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&delta;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">0.018</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&epsilon;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">0.099</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>x<SUB>r</SUB></EM>,<EM>y<SUB>r</SUB></EM></TD>
+<TD>=</TD>
+<TD>0.67,</TD>
+<TD>0.33</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>x<SUB>g</SUB></EM>,<EM>y<SUB>g</SUB></EM></TD>
+<TD>=</TD>
+<TD>0.21,</TD>
+<TD>0.71</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>x<SUB>b</SUB></EM>,<EM>y<SUB>b</SUB></EM></TD>
+<TD>=</TD>
+<TD>0.14,</TD>
+<TD>0.08</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">
+(Illuminant C) <EM>x<SUB>w</SUB></EM>,<EM>y<SUB>w</SUB></EM>
+</TD>
+<TD>=</TD>
+<TD>0.310,</TD>
+<TD>0.316</TD>
+</TR>
+</TABLE>
+<H3>
+Rec 470BG (Rec. ITU-R BT.470-6 Systems B and G with Rec. ITU-R BT.601-5)
+</H3>
+<P>
+This color space is used by the PAL and SECAM systems in much of the rest of
+ the world [<A HREF="#Rec470">Rec470</A>].
+This can be used directly by systems (B, B1, D, D1, G, H, I, K, N)/PAL and (B,
+ D, G, H, K, K1, L)/SECAM.
+</P>
+<P>
+Note that the Rec 470BG chromaticity values are different from those specified
+ in Rec 470M.
+When PAL and SECAM systems were first designed, they were based upon the same
+ primaries as NTSC.
+However, as methods of making color picture tubes have changed, the primaries
+ used have changed as well.
+The US recommends using correction circuitry to approximate the existing,
+ standard NTSC primaries.
+Current PAL and SECAM systems have standardized on primaries in accord with
+ more recent technology.
+</P>
+<P>
+Rec 470 provisionally permits the use of the NTSC chromaticity values (given
+ above) with legacy PAL and SECAM equipment.
+In Ogg Theora, material must be decoded assuming the new PAL and SECAM
+ primaries.
+Material intended for display on old legacy devices should be converted by the
+ decoder.
+</P>
+<P>
+The official Rec 470BG specifies a gamma value of <EM>&gamma;</EM>=2.8.
+However, in practice this value is unrealistically high
+ [<A HREF="#RefPoy97">Poy97</A>].
+Rec 470BG states that the overall system gamma should be approximately
+ <EM>&gamma;</EM>/<EM>&beta;</EM>=1.2.
+However, most cameras pre-correct with a gamma value of <EM>&beta;</EM>=0.45,
+ which suggests an output device gamma of approximately <EM>&gamma;</EM>=2.67.
+This is the value recommended for use with PAL systems in Ogg Theora.
+</P>
+<P>
+Rec 470 does not specify a digital encoding of the color signals.
+For Ogg Theora, Rec. ITU-R BT.601-5 is used, starting from the R'G'B' signals
+ specified by Rec 470 [<A HREF="#Rec601">Rec601</A>].
+</P>
+<P>
+Rec 470 does not specify an input gamma function.
+For Ogg Theora, the Rec 709 input function is used.
+</P>
+<H4>parameters</H4>
+<TABLE>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>Offset<SUB>Y,C<SUB>b</SUB>,C<SUB>r</SUB></SUB></EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">(16,128,128)</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">
+<EM>Excursion<SUB>Y,C<SUB>b</SUB>,C<SUB>r</SUB></SUB></EM>
+</TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">(219,224,224)</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>K<SUB>b</SUB></EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">0.114</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>K<SUB>r</SUB></EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT" COLSPAN="2">0.299</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&gamma;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">2.67</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&beta;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">0.45</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&alpha;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">4.5</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&delta;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">0.018</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>&epsilon;</EM></TD>
+<TD>=</TD>
+<TD ALIGN="LEFT">0.099</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>x<SUB>r</SUB></EM>,<EM>y<SUB>r</SUB></EM></TD>
+<TD>=</TD>
+<TD>0.64,</TD>
+<TD>0.33</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>x<SUB>g</SUB></EM>,<EM>y<SUB>g</SUB></EM></TD>
+<TD>=</TD>
+<TD>0.29,</TD>
+<TD>0.60</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT"><EM>x<SUB>b</SUB></EM>,<EM>y<SUB>b</SUB></EM></TD>
+<TD>=</TD>
+<TD>0.15,</TD>
+<TD>0.06</TD>
+</TR>
+<TR VALIGN="BOTTOM">
+<TD ALIGN="RIGHT">
+(D65) <EM>x<SUB>w</SUB></EM>,<EM>y<SUB>w</SUB></EM>
+</TD>
+<TD>=</TD>
+<TD>0.313,</TD>
+<TD>0.329</TD>
+</TR>
+</TABLE>
+<H2>references</H2>
+<DL>
+<DT>[<A NAME="Poy97">Poy97</A>]</DT>
+<DD>
+Poynton, Charles, <I>Frequently-Asked Questions about Gamma</I>.
+ <A HREF="http://www.poynton.com/GammaFAQ.html">http://www.poynton.com/GammaFAQ/html</A>,
+ Feb. 1997.
+</DD>
+<DT>[<A NAME="Rec470">Rec470</A>]</DT>
+<DD>
+Recommendation ITU-R BT.470-6, <I>Conventional Television Systems</I>
+ (1970, revised 1998). International Telecommunications Union, 1211 Geneva 20,
+ Switzerland.
+</DD>
+<DT>[<A NAME="Rec601">Rec601</A>]</DT>
+<DD>
+Recommendation ITU-R BT.601-5, <I>Studio Encoding Parameters of
+ Digital Television for Standard 4:3 and Wide-Screen 16:9 Aspect Ratios</I>
+ (1982, revised 1995). International Telecommunications Union, 1211 Geneva 20,
+ Switzerland.
+</DD>
+<DT>[<A NAME="Rec709">Rec709</A>]</DT>
+<DD>
+Recommendation ITU-R BT.709-5, <I>Parameter values for the
+ HDTV standards for production and international programme exchange</I>
+ (1990, revised 2002). International Telecommunications Union, 1211 Geneva 20,
+ Switzerland.
+</DD>
+<DT>[<A NAME="SMPTE170M">SMPTE170M</A>]</DT>
+<DD>
+Society of Motion Picture and Television Engineers, <I>Television &mdash;
+ Composite Analog Video Signal &mdash; NTSC for Studio Applications</I>.
+ SMPTE-170M, 1994
+</DD>
+<DT>[<A NAME="SMPTE240M">SMPTE240M</A>]</DT>
+<DD>
+Society of Motion Picture and Television Engineers, <I>Television &mdash;
+ Signal Parameters &mdash; 1125-Line High-Definition Production</I>.
+ SMPTE-240M, 1999.
+</DD>
+</DL>
+</BODY>
+</HTML>
diff --git a/doc/draft-ietf-avt-rtp-theora-00.txt b/doc/draft-ietf-avt-rtp-theora-00.txt
new file mode 100644 (file)
index 0000000..f759aef
--- /dev/null
@@ -0,0 +1,1400 @@
+
+
+
+AVT Working Group                                             L. Barbato
+Internet-Draft                                                  Xiph.Org
+Expires: January 22, 2007                                  July 21, 2006
+
+
+                      draft-ietf-avt-rtp-theora-00
+              RTP Payload Format for Theora Encoded Video
+
+Status of this Memo
+
+   By submitting this Internet-Draft, each author represents that any
+   applicable patent or other IPR claims of which he or she is aware
+   have been or will be disclosed, and any of which he or she becomes
+   aware will be disclosed, in accordance with Section 6 of BCP 79.
+
+   Internet-Drafts are working documents of the Internet Engineering
+   Task Force (IETF), its areas, and its working groups.  Note that
+   other groups may also distribute working documents as Internet-
+   Drafts.
+
+   Internet-Drafts are draft documents valid for a maximum of six months
+   and may be updated, replaced, or obsoleted by other documents at any
+   time.  It is inappropriate to use Internet-Drafts as reference
+   material or to cite them other than as "work in progress."
+
+   The list of current Internet-Drafts can be accessed at
+   http://www.ietf.org/ietf/1id-abstracts.txt.
+
+   The list of Internet-Draft Shadow Directories can be accessed at
+   http://www.ietf.org/shadow.html.
+
+   This Internet-Draft will expire on January 22, 2007.
+
+Copyright Notice
+
+   Copyright (C) The Internet Society (2006).
+
+Abstract
+
+   This document describes a RTP payload format for transporting Theora
+   encoded video.  It details the RTP encapsulation mechanism for raw
+   Theora data and configuration headers necessary to configure the
+   decoder.
+
+   Also included within the document are the necessary details for the
+   use of Theora with MIME and Session Description Protocol (SDP).
+
+Editors Note
+
+
+
+Barbato                 Expires January 22, 2007                [Page 1]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   All references to RFC XXXX are to be replaced by references to the
+   RFC number of this memo, when published.
+
+
+Table of Contents
+
+   1.  Introduction . . . . . . . . . . . . . . . . . . . . . . . . .  3
+     1.1.  Terminology  . . . . . . . . . . . . . . . . . . . . . . .  4
+   2.  Payload Format . . . . . . . . . . . . . . . . . . . . . . . .  4
+     2.1.  RTP Header . . . . . . . . . . . . . . . . . . . . . . . .  4
+     2.2.  Payload Header . . . . . . . . . . . . . . . . . . . . . .  5
+     2.3.  Payload Data . . . . . . . . . . . . . . . . . . . . . . .  6
+     2.4.  Example RTP Packet . . . . . . . . . . . . . . . . . . . .  7
+   3.  Configuration Headers  . . . . . . . . . . . . . . . . . . . .  8
+     3.1.  In-band Header Transmission  . . . . . . . . . . . . . . .  9
+       3.1.1.  Packed Configuration . . . . . . . . . . . . . . . . .  9
+     3.2.  Out of Band Transmission . . . . . . . . . . . . . . . . . 10
+       3.2.1.  Packed Headers . . . . . . . . . . . . . . . . . . . . 11
+     3.3.  Loss of Configuration Headers  . . . . . . . . . . . . . . 13
+   4.  Comment Headers  . . . . . . . . . . . . . . . . . . . . . . . 13
+   5.  Frame Packetizing  . . . . . . . . . . . . . . . . . . . . . . 14
+     5.1.  Example Fragmented Theora Packet . . . . . . . . . . . . . 15
+     5.2.  Packet Loss  . . . . . . . . . . . . . . . . . . . . . . . 17
+   6.  IANA Considerations  . . . . . . . . . . . . . . . . . . . . . 18
+     6.1.  Mapping MIME Parameters into SDP . . . . . . . . . . . . . 19
+       6.1.1.  SDP Example  . . . . . . . . . . . . . . . . . . . . . 20
+     6.2.  Usage with the SDP Offer/Answer Model  . . . . . . . . . . 20
+   7.  Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
+     7.1.  Stream Video . . . . . . . . . . . . . . . . . . . . . . . 21
+   8.  Security Considerations  . . . . . . . . . . . . . . . . . . . 21
+   9.  Acknowledgments  . . . . . . . . . . . . . . . . . . . . . . . 22
+   10. References . . . . . . . . . . . . . . . . . . . . . . . . . . 22
+     10.1. Normative References . . . . . . . . . . . . . . . . . . . 22
+     10.2. Informative References . . . . . . . . . . . . . . . . . . 23
+   Author's Address . . . . . . . . . . . . . . . . . . . . . . . . . 24
+   Intellectual Property and Copyright Statements . . . . . . . . . . 25
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007                [Page 2]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+1.  Introduction
+
+   Theora is a general purpose, lossy video codec.  It is based on the
+   VP3 video codec produced by On2 Technologies and has been donated to
+   the Xiph.org Foundation.
+
+   Theora I is a block-based lossy transform codec that utilizes an 8 x
+   8 Type-II Discrete Cosine Transform and block-based motion
+   compensation.  This places it in the same class of codecs as MPEG-1,
+   MPEG-2, MPEG-4, and H.263.  The details of how individual blocks are
+   organized and how DCT coefficients are stored in the bitstream differ
+   substantially from these codecs, however.  Theora supports only intra
+   frames (I frames in MPEG) and inter frames (P frames in MPEG).
+
+   Theora provides none of its own framing, synchronization, or
+   protection against transmission errors.  Instead, the codec expects
+   to receive a discrete sequence of data packets.  Theora is a free-
+   form variable bit rate (VBR) codec, and these packets have no minimum
+   size, maximum size, or fixed/expected size.  Theora packets are thus
+   intended to be used with a transport mechanism that provides free-
+   form framing, synchronization, positioning, and error correction in
+   accordance with these design assumptions, such as Ogg [1] or RTP/AVP
+   [3].
+
+   Theora I currently supports progressive video data of arbitrary
+   dimensions at a constant frame rate in one of several Y'CbCr color
+   spaces.  Three different chroma subsampling formats are supported:
+   4:2:0, 4:2:2, and 4:4:4.  The Theora I format does not support
+   interlaced material, variable frame rates, bit-depths larger than 8
+   bits per component, nor alternate color spaces such as RGB or
+   arbitrary multi-channel spaces.  Black and white content can be
+   efficiently encoded, however, because the uniform chroma planes
+   compress well.  For performance reason, arbitrary frame sizes will be
+   encoded rounding both dimensions to the upper multiple of 16.  The
+   original width and height will be encoded in the header and the
+   decoder will use this information to clip the decoded frame to the
+   right dimensions.
+
+   Theora is similar to the Vorbis audio [10] in that the decoder reads
+   the probability model for the entropy coder and all quantization
+   parameters from special "header" packets at the start of the
+   compressed data.  It is therefore impossible to decode any video data
+   without having previously fetched the codec info and codec setup
+   headers, although Theora can begin to decode at an arbitrary intra-
+   frame packet so long as the codec has been initialized with the
+   associated headers.
+
+
+
+
+
+Barbato                 Expires January 22, 2007                [Page 3]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+1.1.  Terminology
+
+   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
+   "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
+   document are to be interpreted as described in RFC 2119 [2].
+
+
+2.  Payload Format
+
+   For RTP based transportation of Theora encoded video the standard RTP
+   header is followed by a 4 octets payload header, then the payload
+   data.  The payload headers are used to associate the Theora data with
+   its associated decoding codebooks as well as indicating if the
+   following packet contains fragmented Theora data and/or the number of
+   whole Theora data frames.  The payload data contains the raw Theora
+   bitstream information.
+
+   For RTP based transport of Theora encoded video the standard RTP
+   header is followed by a 4 octets payload header, then the payload
+   data.
+
+2.1.  RTP Header
+
+   The format of the RTP header is specified in [3] and shown in Figure
+   1.  This payload format uses the fields of the header in a manner
+   consistent with that specification.
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |V=2|P|X|  CC   |M|     PT      |       sequence number         |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                           timestamp                           |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |           synchronization source (SSRC) identifier            |
+      +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+      |            contributing source (CSRC) identifiers             |
+      |                              ...                              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 1: RTP Header
+
+   The RTP header begins with an octet of fields (V, P, X, and CC) to
+   support specialized RTP uses (see [3] and [4] for details).  For
+   Theora RTP, the following values are used.
+
+   Version (V): 2 bits
+
+
+
+
+Barbato                 Expires January 22, 2007                [Page 4]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   This field identifies the version of RTP.  The version used by this
+   specification is two (2).
+
+   Padding (P): 1 bit
+
+   Padding MAY be used with this payload format according to section 5.1
+   of [3].
+
+   Extension (X): 1 bit
+
+   The Extension bit is used in accordance with [3].
+
+   CSRC count (CC): 4 bits
+
+   The CSRC count is used in accordance with [3].
+
+   Marker (M): 1 bit
+
+   The Marker bit is used in accordance with [3].
+
+   Payload Type (PT): 7 bits
+
+   An RTP profile for a class of applications is expected to assign a
+   payload type for this format, or a dynamically allocated payload type
+   SHOULD be chosen which designates the payload as Theora.
+
+   Sequence number: 16 bits
+
+   The sequence number increments by one for each RTP data packet sent,
+   and may be used by the receiver to detect packet loss and to restore
+   packet sequence.  This field is detailed further in [3].
+
+   Timestamp: 32 bits
+
+   A timestamp representing the presentation time of the first sample of
+   the first Theora packet in the RTP packet.  The clock frequency MUST
+   be set to 90kHz.
+
+   SSRC/CSRC identifiers:
+
+   These two fields, 32 bits each with one SSRC field and a maximum of
+   16 CSRC fields, are as defined in [3].
+
+2.2.  Payload Header
+
+   The 4 octets following the RTP Header section represent the Payload
+   Header.  This header is split into a number of bitfields detailing
+   the format of the following Payload Datagrams.
+
+
+
+Barbato                 Expires January 22, 2007                [Page 5]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |               Configuration Ident             | F |TDT|# pkts.|
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+      +-+-+-+-+-+-+-+-+
+
+   Figure 2: Payload Header
+
+   Configuration Ident: 24 bits
+
+   This 24 bit field is used to associate the Theora data to a decoding
+   Packed Configuration.
+
+   Fragment type (F): 2 bit
+
+   This field is set according to the following list
+
+      0 = Not Fragmented
+      1 = Start Fragment
+      2 = Continuation Fragment
+      3 = End Fragment
+
+   This field must be zero if the number of packets field is non-zero.
+
+   Theora Data Type (TDT): 2 bits
+
+   This field sets the packet payload type for the Theora data.  There
+   are currently three Theora payload types currently used and one
+   reserved for future use.
+
+      0 = Raw Theora payload
+      1 = Theora Packed Configuration payload
+      2 = Legacy Theora Comment payload
+      3 = Reserved
+
+   The packets with a TDT of value 3 MUST be ignored
+
+   The last 4 bits represent the number of complete packets in this
+   payload.  This provides a maximum number of 15 Theora packets in the
+   payload.  If the packet contains fragmented data the number of
+   packets MUST be set to 0.
+
+2.3.  Payload Data
+
+   Each Theora payload section starts with a two octets length header
+   that is used to represent the size of the following data payload,
+
+
+
+Barbato                 Expires January 22, 2007                [Page 6]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   followed by the raw Theora packet data.
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |        Payload Length         |          Theora Data         ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 3: Payload Data
+
+   The Theora codec uses relatively unstructured raw packets containing
+   binary integer fields of arbitrary width that often do not fall on an
+   octet boundary.  When a Theora encoder produces packets, unused space
+   in the last byte of a packet is always zeroed during the encoding
+   process.  Thus, should this unused space be read, it will return
+   binary zeros.
+
+   For payloads which consist of multiple Theora packets the payload
+   data consists of the payload length field followed by the first
+   Theora packet's data, then the payload length followed by the second
+   Theora packet, and so on for each of the Theora packets in the
+   payload.
+
+2.4.  Example RTP Packet
+
+   Here is an example RTP packet containing two Theora packets.
+
+   RTP Packet Header:
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      | 2 |0|0|  0    |0|      PT     |       sequence number         |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                           timestamp                           |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |          synchronisation source (SSRC) identifier             |
+      +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+      |            contributing source (CSRC) identifiers             |
+      |                              ...                              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 4: Example RTP Packet
+
+   Payload Data:
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007                [Page 7]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |               Configuration Ident             | 0 | 0 | 2 pks |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |        Payload Length         |                              ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Theora data                          ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..           data               |        Payload Length         |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Theora data                           |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 5: Example Theora Payload Packet
+
+   The payload portion of the packet begins with the 24 bit
+   Configuration ident field followed by 8 bits describing the payload.
+   The Fragment type field is set to 0, indicating that this packet
+   contains whole Theora frame data.  The Data type field is set to 0
+   (theora raw data).  The number of whole Theora data packets is set to
+   2.
+
+   Each of the payload blocks starts with the two octets length field
+   followed by the variable length Theora packet data.
+
+
+3.  Configuration Headers
+
+   To decode a Theora stream three configuration header packets are
+   needed.  The first (Identification Header) indicates frame
+   dimensions, quality, blocks used and Theora encoder version.  The
+   second (Comment Header) contains stream metadata and the third (Setup
+   Header) contains details of the dequantization and Huffman tables.
+
+   Since this information must be transmitted reliably, and as the RTP
+   stream may change certain configuration data mid-session, there are
+   different methods for delivering this configuration data to a client,
+   both in-band and out-of-band, which are detailed below.  SDP delivery
+   is used to set up an initial state for the client application.  The
+   changes may be due to different dequantization and Huffman tables as
+   well as different bitrates of the stream.
+
+   The delivery vectors in use are specified by an SDP attribute that
+   indicates the method and the optional URI where the Theora Packed
+   Configuration (Section 3.1.1) Packets could be fetched.  Different
+   delivery methods MAY be advertised for the same session.  The in-band
+   codebook delivery SHOULD be considered as baseline, out-of-band
+
+
+
+Barbato                 Expires January 22, 2007                [Page 8]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   delivery methods that don't use RTP will not be described in this
+   document.  For non chained streams, the RECOMMENDED Configuration
+   delivery method is inline the Packed Configuration (Section 3.1.1) in
+   the SDP as explained in the IANA considerations (Section 6.1)
+
+   The 24 bit Ident field is used to map which Configuration will be
+   used to decode a packet.  When the Ident field changes, it indicates
+   that a change in the stream has taken place.  The client application
+   MUST have in advance the correct configuration and if the client
+   detects a change in the Ident value and does not have this
+   information it MUST NOT decode the raw data associated until it has
+   fetched the correct Configuration.
+
+3.1.  In-band Header Transmission
+
+   The Packed Configuration (Section 3.1.1) Payload is sent in-band with
+   the packet type bits set to match the payload type.  Clients MUST be
+   capable of dealing with periodic re-transmission of the configuration
+   headers.
+
+3.1.1.  Packed Configuration
+
+   A Theora Packed Configuration is identified by a payload type field
+   of 1.  Of the three headers, defined in the Theora I specification
+   [16], the identification and the setup will be packed together, while
+   the comment header will be completely suppressed.  It is up to the
+   client to provide a minimal size comment header to the decoder if
+   required by the implementation.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007                [Page 9]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |V=2|P|X|  CC   |M|     PT      |             xxxx              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                             xxxxx                             |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |           synchronization source (SSRC) identifier            |
+      +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+      |            contributing source (CSRC) identifiers             |
+      |                              ...                              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |               Configuration Ident             | 0 | 1 |      1|
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |             length            |          Identification      ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Identification                       ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Identification                       ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Identification                        |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..              |                      Setup                   ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                            Setup                            ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                            Setup                             |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 6: Packed Configuration Figure
+
+   The Ident field is set with the value that will be used by the Raw
+   Payload Packets to address this Configuration.  The Fragment type is
+   set to 0 since the packet bears full Packed configuration, the number
+   of packet is set to 1.  In practice, Packed Headers usually need to
+   be fragmented to fit the path MTU.
+
+3.2.  Out of Band Transmission
+
+   This section, as stated above, does not cover all the possible out-
+   of-band delivery methods since they rely on different protocols and
+   are linked to specific applications.  The following packet definition
+   SHOULD be used in out-of-band delivery and MUST be used when
+   Configuration is inlined in the SDP.
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 10]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+3.2.1.  Packed Headers
+
+   As mentioned above, the recommended delivery vector for Theora
+   configuration data is via a retrieval method that can be performed
+   using a reliable transport protocol.  As the RTP headers are not
+   required for this method of delivery the structure of the
+   configuration data is slightly different.  The packed header starts
+   with a 32 bit count field which details the number of packed headers
+   that are contained in the bundle.  Next is the Packed header payload
+   for each setup id.
+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                     Number of packed headers                  |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                          Packed header                        |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                          Packed header                        |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 7: Packed Headers Overview
+
+   Since the Configuration Ident and the Identification Header are fixed
+   length there is only a 16bit Length tag to define the length of the
+   packed headers.
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |              Configuration Ident              |              ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..   Length     |              Identification Header           ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                    Identification Header                     |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                         Setup Header                         ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Setup Header                          |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 8: Packed Headers Detail
+
+   The key difference from the in-band format is that there is no need
+   for the payload header octet.
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 11]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+3.2.1.1.  Packed Headers IANA Considerations
+
+   The following IANA considerations MUST only be applied to the packed
+   headers.
+
+   MIME media type name: audio
+
+   MIME subtype: theora-config
+
+   Required Parameters:
+
+      None
+
+   Optional Parameters:
+
+      None
+
+   Encoding considerations:
+
+      This media type contains binary data.
+
+   Security Considerations:
+
+      See Section 6 of RFC XXXX.
+
+   Interoperability considerations:
+
+      None
+
+   Published specification:
+
+      RFC XXXX [RFC Editor: please replace by the RFC number of this
+      memo, when published]
+
+   Applications which use this media type:
+
+      Theora encoded video, configuration data.
+
+   Additional information:
+
+      None
+
+   Person & email address to contact for further information:
+
+      Luca Barbato: <lu_zero@gentoo.org>
+      IETF Audio/Video Transport Working Group
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 12]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   Intended usage: COMMON
+
+   Restriction on usage:
+
+      This media type does not depend on the transport.
+
+   Author:
+
+      Luca Barbato
+
+   Change controller:
+
+      IETF AVT Working Group
+
+3.3.  Loss of Configuration Headers
+
+   Unlike the loss of raw Theora payload data, the loss of a
+   configuration header can lead to a situation where it will not be
+   possible to successfully decode the stream.
+
+   A loss of a Configuration Packet causes the stream decoder to halt
+   and SHOULD be reported to the client as well as a loss report sent
+   via RTCP.
+
+
+4.  Comment Headers
+
+   When the payload type is set to 2, the packet contains comment
+   metadata such as artist name, track title and so on.  These metadata
+   messages are not intended to be fully descriptive but to offer basic
+   title information.  Clients MAY choose to completely ignore them.
+   The details on the comments format can be found in the Theora
+   documentation [16].
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 13]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |V=2|P|X|  CC   |M|     PT      |             xxxx              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                             xxxxx                             |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |           synchronization source (SSRC) identifier            |
+      +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+      |            contributing source (CSRC) identifiers             |
+      |                              ...                              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |              Configuration Ident              | 0 | 2 |      1|
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |            length             |            Comment           ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                           Comment                           ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                           Comment                            |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 9: Comment Packet
+
+   The 2 byte length field is necessary since this Theora packet could
+   be fragmented.
+
+
+5.  Frame Packetizing
+
+   Each RTP packet contains either one complete Theora packet, one
+   Theora packet fragment, or an integer number of complete Theora
+   packets (up to a maximum of 15 packets, since the number of packets
+   is defined by a 4 bit value).
+
+   Any Theora data packet that is less than path MTU SHOULD be bundled
+   in the RTP packet with as many Theora packets as will fit, up to a
+   maximum of 15.  Path MTU is detailed in [7] and [8].
+
+   A fragmented packet has a zero in the last four bits of the payload
+   header.  The RTP packet containing the first fragment will set the
+   Fragment type to 1.  Each RTP packet after the first will set the
+   Fragment type to 2 in the payload header.  The RTP packet containing
+   the last fragment of the Theora packet will have the Fragment type
+   set to 3.  If the fragmented Theora packet spans only two RTP
+   packets, the first will set the Fragment type field to 1 and the
+   second will set it to 2.  To maintain the correct sequence for
+   fragmented packet reception the timestamp field of fragmented packets
+
+
+
+Barbato                 Expires January 22, 2007               [Page 14]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   MUST be the same as the first packet sent, with the sequence number
+   incremented as normal for the subsequent RTP packets.
+
+5.1.  Example Fragmented Theora Packet
+
+   Here is an example fragmented Theora packet split over three RTP
+   packets.  Each packet contains the standard RTP headers as well as
+   the 4 octets Theora headers.
+
+      Packet 1:
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |V=2|P|X|  CC   |M|     PT      |           1000                |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                             xxxxx                             |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |           synchronization source (SSRC) identifier            |
+      +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+      |            contributing source (CSRC) identifiers             |
+      |                              ...                              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |              Configuration Ident              | 1 | 0 |      0|
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |        Payload Length         |           Theora data        ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Theora data                          ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 10: Example Fragmented Packet (Packet 1)
+
+   In this packet the initial sequence number is 1000 and the timestamp
+   is xxxxx.  The Fragment type field is set to one, indicating it is
+   the start packet of a serie of fragments.  The number of packets
+   field is set to 0, and as the payload is raw Theora data the Theora
+   payload type field is set to 0.
+
+
+
+
+
+
+
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 15]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+      Packet 2:
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |V=2|P|X|  CC   |M|     PT      |           1001                |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                             xxxxx                             |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |           synchronization source (SSRC) identifier            |
+      +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+      |            contributing source (CSRC) identifiers             |
+      |                              ...                              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |              Configuration Ident              | 2 | 0 |      0|
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |        Payload Length         |              ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                        Theora data                          ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 11: Example Fragmented Packet (Packet 2)
+
+   The Fragment type field is set to 2 and the number of packets field
+   is set to 0.  For large Theora fragments there can be several of
+   these type of payload packets.  The maximum RTP packet size SHOULD be
+   no greater than the path MTU, including all RTP and payload headers.
+   The sequence number has been incremented by one but the timestamp
+   field remains the same as the initial packet.
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 16]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+      Packet 3:
+
+       0                   1                   2                   3
+       0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |V=2|P|X|  CC   |M|     PT      |           1002                |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |                             xxxxx                             |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |           synchronization source (SSRC) identifier            |
+      +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+      |            contributing source (CSRC) identifiers             |
+      |                              ...                              |
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |              Configuration Ident              | 3 | 0 |      0|
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      |        Payload Length         |                              ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+      ..                         Theora data                         ..
+      +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+
+   Figure 12: Example Fragmented Packet (Packet 3)
+
+   This is the last Theora fragment packet.  The Fragment type filed is
+   set to 3 and the packet count remains set to 0.  As in the previous
+   packets the timestamp remains set to the first packet in the sequence
+   and the sequence number has been incremented.
+
+5.2.  Packet Loss
+
+   As there is no error correction within the Theora stream, packet loss
+   will result in a loss of signal.  Packet loss is more of an issue for
+   fragmented Theora packets as the client will have to cope with the
+   handling of the Fragment type field.  If we use the fragmented Theora
+   packet example above and the first packet is lost the client MUST
+   detect that the next packet has the packet count field set to 0 and
+   the Fragment type is set to 2 and MUST drop it.  The next packet,
+   which is the final fragmented packet, MUST be dropped in the same
+   manner.  Feedback reports on lost and dropped packets MUST be sent
+   back via RTCP.[note: reordering]
+
+   If a particular multicast session has a large number of participants
+   care must be taken to prevent an RTCP feedback implosion, [9], in the
+   event of packet loss from a large number of participants.
+
+   Loss of any of the Configuration fragment will result in the loss of
+   the full Configuration packet as detailed in the Loss of
+
+
+
+Barbato                 Expires January 22, 2007               [Page 17]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   Configuration Headers (Section 3.3) section.
+
+
+6.  IANA Considerations
+
+   MIME media type name: video
+
+   MIME subtype: theora
+
+   Required Parameters:
+
+      sampling: Determines the chroma subsampling format.
+
+      width: Determines the number of pixels per line.  This is an
+         integer between 1 and 1048561 and MUST be in multiples of 16.
+
+      height: Determines the number of lines per frame encoded.  This is
+         an integer between 1 and 1048561 and MUST be in multiples of
+         16.
+
+      delivery-method: indicates the delivery methods in use, the
+         possible values are: inline, in_band, out_band/specific_name
+         Where "specific_name" is the name of the out of band delivery
+         method.
+
+      configuration: the base16 [11] (hexadecimal) representation of the
+         Packed Headers (Section 3.2.1).
+
+   Optional Parameters:
+
+      configuration-uri: the URI of the configuration headers in case of
+         out of band transmission.  In the form of
+         "protocol://path/to/resource/".  Depending on the specific
+         method the single ident packets could be retrived by their
+         number or aggregated in a single stream, aggregates MAY be
+         compressed using gzip [12] or bzip2 [14] and an sha1 [13]
+         checksum MAY be provided in the form of
+         "protocol://path/to/resource/aggregated.bz2!sha1hash"
+
+   Encoding considerations:
+
+      This media type is framed and contains binary data.
+
+   Security Considerations:
+
+      See Section 6 of RFC XXXX.
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 18]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   Interoperability considerations:
+
+      None
+
+   Published specification:
+
+      RFC XXXX [RFC Editor: please replace by the RFC number of this
+      memo, when published]
+
+      Ogg Theora I specification: Codec setup and packet decode.
+      Available from the Xiph website, http://www.xiph.org
+
+   Applications which use this media type:
+
+      Audio streaming and conferencing tools
+
+   Additional information:
+
+      None
+
+   Person & email address to contact for further information:
+
+      Luca Barbato: <lu_zero@gentoo.org>
+      IETF Audio/Video Transport Working Group
+
+   Intended usage:
+
+      COMMON
+
+   Restriction on usage:
+
+      This media type depends on RTP framing, and hence is only defined
+      for transfer via RTP [3]
+
+   Author:
+
+      Luca Barbato
+
+   Change controller:
+
+      IETF AVT Working Group
+
+
+6.1.  Mapping MIME Parameters into SDP
+
+   The information carried in the MIME media type specification has a
+   specific mapping to fields in the Session Description Protocol (SDP)
+   [6], which is commonly used to describe RTP sessions.  When SDP is
+
+
+
+Barbato                 Expires January 22, 2007               [Page 19]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   used to specify sessions the mapping are as follows:
+
+   o  The MIME type ("video") goes in SDP "m=" as the media name.
+
+   o  The MIME subtype ("theora") goes in SDP "a=rtpmap" as the encoding
+      name.
+
+   o  The clock rate in the "a=rtpmap" line MUST be 90000
+
+   o  The mandated parameters "delivery-method" and "configuration" MUST
+      be included in the SDP "a=fmpt" attribute.
+
+   o  The optional parameter "configuration-uri", when present, MUST be
+      included in the SDP "a=fmpt" attribute and MUST follow the
+      delivery-method that applies.
+
+   If the stream uses multiple decoder setup configurations and all of
+   them are known in advance, the Configuration Packet for each file
+   SHOULD be packaged together and passed to the client using the
+   configuration attribute.
+
+   The URI specified in the configuration-uri attribute MUST point to a
+   location where all of the Configuration Packets needed for the life
+   of the session reside.
+
+6.1.1.  SDP Example
+
+   The following example shows a basic SDP for a single stream.  The
+   first configuration packet is inlined in the sdp, other
+   configurations could be fetched at any time from the first provided
+   uri using or all the known configuration could be downloaded using
+   the second uri.  The inline base16 [11] configuration string is
+   omitted because of the lenght.
+      c=IN IP4 192.0.0.1
+      m=video RTP/AVP 98
+      a=rtpmap:98 theora/90000
+      a=fmtp:98 sampling=YCbCr-4:2:2; width=1280; height=720; delivery-
+      method=inline; configuration=base16string1; delivery-
+      method=out_band/rtsp; delivery-method=out_band/rtsp;
+      configuration-uri=rtsp://path/to/resource/; delivery-
+      method=out_band/http; configuration-uri=http://another/path/to/
+      resource/aggregate.bz2!sha1hash;
+
+6.2.  Usage with the SDP Offer/Answer Model
+
+   The offer, as described in An Offer/Answer Model Session Description
+   Protocol [5], may contain a large number of delivery methods per
+   single fmtp attribute, the answerer MUST remove every delivery-method
+
+
+
+Barbato                 Expires January 22, 2007               [Page 20]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   and configuration-uri not supported.  All the parameters MUST not be
+   altered on answer otherwise.
+
+
+7.  Examples
+
+   The following examples are common usage patterns that MAY be applied
+   in such situations, the main scope of this section is to explain
+   better usage of the transmission vectors.
+
+7.1.  Stream Video
+
+   This is one of the most common situation: one single server streaming
+   content in multicast, the clients may start a session at random time.
+   The content itself could be a mix of live stream, as the wj's voice
+   or studio scenes, and stored streams, as the music she plays.
+
+   In this situation we don't know in advance how many codebooks we will
+   use.  The clients can join anytime and users expect to start the
+   fruition of the content in a short time.
+
+   On join the client will receive the current Configuration necessary
+   to decode the current streams inlined in the SDP so that the decoding
+   will start immediately after.
+
+   When the streamed content changes the new Configuration is sent in-
+   band before the actual stream, and the Configuration that has to be
+   sent inline in the SDP updated.  Since the inline method is
+   unreliable, an out of band fallback is provided.
+
+   The client could choose to fetch the Configuration from the alternate
+   source as soon it discovers a Configuration packet got lost inline or
+   use selective retransmission [17], if the server supports the
+   feature.
+
+   A serverside optimization would be to keep an hash list of the
+   Configurations per session to avoid packing all of them and send the
+   same Configuration with different Ident tags
+
+   A clientside optimization would be to keep a tag list of the
+   Configurations per session and don't process configuration packets
+   already known.
+
+
+8.  Security Considerations
+
+   RTP packets using this payload format are subject to the security
+   considerations discussed in the RTP specification [3].  This implies
+
+
+
+Barbato                 Expires January 22, 2007               [Page 21]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+   that the confidentiality of the media stream is achieved by using
+   encryption.  Because the data compression used with this payload
+   format is applied end-to-end, encryption may be performed on the
+   compressed data.  Where the size of a data block is set care MUST be
+   taken to prevent buffer overflows in the client applications.
+
+
+9.  Acknowledgments
+
+   This document is a continuation of draft-kerr-avt-theora-rtp-00.txt
+
+   Thanks to the AVT, Ogg Theora Communities / Xiph.org, Fluendo, Ralph
+   Giles, Mike Smith, Phil Kerr, Timothy Terriberry, Stefan Ehmann,
+   Alessandro Salvatori, Politecnico di Torino (LS)^3/IMG Group in
+   particular Federico Ridolfo, Francesco Varano, Giampaolo Mancini,
+   Juan Carlos De Martin.
+
+
+10.  References
+
+10.1.  Normative References
+
+   [1]   Pfeiffer, S., "The Ogg Encapsulation Format Version 0",
+         RFC 3533.
+
+   [2]   Bradner, S., "Key words for use in RFCs to Indicate Requirement
+         Levels", RFC 2119.
+
+   [3]   Schulzrinne, H., Casner, S., Frederick, R., and V. Jacobson,
+         "RTP: A Transport Protocol for real-time applications",
+         RFC 3550.
+
+   [4]   Schulzrinne, H. and S. Casner, "RTP Profile for video and Video
+         Conferences with Minimal Control.", RFC 3551.
+
+   [5]   Rosenberg, J. and H. Schulzrinne, "An Offer/Answer Model with
+         Session Description Protocol (SDP)", RFC 3264.
+
+   [6]   Handley, M. and V. Jacobson, "SDP: Session Description
+         Protocol", RFC 2327.
+
+   [7]   Mogul et al., J., "Path MTU Discovery", RFC 1063.
+
+   [8]   McCann et al., J., "Path MTU Discovery for IP version 6",
+         RFC 1981.
+
+   [9]   Ott, J., Wenger, S., Sato, N., Burmeister, C., and J. Rey,
+         "Extended RTP Profile for RTCP-based Feedback (RTP/AVPF)",
+
+
+
+Barbato                 Expires January 22, 2007               [Page 22]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+         Internet Draft (draft-ietf-avt-rtcp-feedback-11: Work in
+         progress).
+
+   [10]  Barbato, L., "RTP Payload Format for Vorbis Encoded Audio -
+         draft-ietf-avt-vorbis-rtp-00", Internet Draft (Work in
+         progress).
+
+   [11]  Josefsson, S., "The Base16, Base32, and Base64 Data Encodings",
+         RFC 3548.
+
+   [12]  Deutsch, P., "GZIP file format specification version 4.3",
+         RFC 1952.
+
+   [13]  National Institute of Standards and Technology, "Secure Hash
+         Standard", May 1993.
+
+   [14]  Seward, J., "libbz2 and bzip2".
+
+10.2.  Informative References
+
+   [15]  "libTheora: Available from the Xiph website,
+         http://www.xiph.org".
+
+   [16]  "Theora I specification:  Codec setup and packet decode.
+         http://www.xiph.org/theora/doc/Theora_I_spec.pdf".
+
+   [17]  Friedman, T., Caceres, R., and A. Clark, "RTP Control Protocol
+         Extended Reports (RTCP XR)", RFC 3611, November 2003.
+
+   [18]  "ITU-T Recommendation V.42, 1994, Rev. 1. Error-correcting
+         Procedures for DCEs Using Asynchronous-to-Synchronous
+         Conversion. International Telecommunications Union. Available
+         from the ITU website, http://www.itu.int".
+
+   [19]  "ISO 3309, October 1984, 3rd Edition. Information Processing
+         Systems--Data Communication High-Level Data Link Control
+         Procedure--Frame Structure. International Organization for
+         Standardization.".
+
+
+
+
+
+
+
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 23]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+Author's Address
+
+   Luca Barbato
+   Xiph.Org
+
+   Email: lu_zero@gentoo.org
+   URI:   http://www.xiph.org/
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 24]
+\f
+Internet-Draft        draft-ietf-avt-rtp-theora-00             July 2006
+
+
+Intellectual Property Statement
+
+   The IETF takes no position regarding the validity or scope of any
+   Intellectual Property Rights or other rights that might be claimed to
+   pertain to the implementation or use of the technology described in
+   this document or the extent to which any license under such rights
+   might or might not be available; nor does it represent that it has
+   made any independent effort to identify any such rights.  Information
+   on the procedures with respect to rights in RFC documents can be
+   found in BCP 78 and BCP 79.
+
+   Copies of IPR disclosures made to the IETF Secretariat and any
+   assurances of licenses to be made available, or the result of an
+   attempt made to obtain a general license or permission for the use of
+   such proprietary rights by implementers or users of this
+   specification can be obtained from the IETF on-line IPR repository at
+   http://www.ietf.org/ipr.
+
+   The IETF invites any interested party to bring to its attention any
+   copyrights, patents or patent applications, or other proprietary
+   rights that may cover technology that may be required to implement
+   this standard.  Please address the information to the IETF at
+   ietf-ipr@ietf.org.
+
+
+Disclaimer of Validity
+
+   This document and the information contained herein are provided on an
+   "AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS
+   OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY AND THE INTERNET
+   ENGINEERING TASK FORCE DISCLAIM ALL WARRANTIES, EXPRESS OR IMPLIED,
+   INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE
+   INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED
+   WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
+
+
+Copyright Statement
+
+   Copyright (C) The Internet Society (2006).  This document is subject
+   to the rights, licenses and restrictions contained in BCP 78, and
+   except as set forth therein, the authors retain all their rights.
+
+
+Acknowledgment
+
+   Funding for the RFC Editor function is currently provided by the
+   Internet Society.
+
+
+
+
+Barbato                 Expires January 22, 2007               [Page 25]
+\f
diff --git a/doc/draft-ietf-avt-rtp-theora-00.xml b/doc/draft-ietf-avt-rtp-theora-00.xml
new file mode 100644 (file)
index 0000000..2f8af39
--- /dev/null
@@ -0,0 +1,1146 @@
+<?xml version='1.0'?>
+<!DOCTYPE rfc SYSTEM 'rfc2629.dtd'>
+<?rfc toc="yes" ?>
+<?rfc compact='yes'?>
+
+<rfc ipr="full3978" docName="RTP Payload Format for Theora Encoded Video">
+
+<front>
+<title>draft-ietf-avt-rtp-theora-00</title>
+
+<author initials="L" surname="Barbato" fullname="Luca Barbato">
+<organization>Xiph.Org</organization>
+<address>
+<email>lu_zero@gentoo.org</email>
+<uri>http://www.xiph.org/</uri>
+</address>
+</author>
+
+<date day="21" month="July" year="2006" /> 
+<area>General</area>
+<workgroup>AVT Working Group</workgroup>
+<keyword>I-D</keyword>
+
+<keyword>Internet-Draft</keyword>
+<keyword>Theora</keyword>
+<keyword>RTP</keyword>
+
+<abstract>
+<t>
+This document describes a RTP payload format for transporting Theora encoded video. It details the RTP encapsulation mechanism for raw Theora data and configuration headers necessary to configure the decoder.
+</t>
+
+<t>
+Also included within the document are the necessary details for the use of Theora with MIME and Session Description Protocol (SDP).
+</t>
+
+</abstract>
+
+<note title="Editors Note">
+<t>
+All references to RFC XXXX are to be replaced by references to the RFC number of this memo, when published.
+</t>
+</note>
+
+</front>
+
+<middle>
+
+<section anchor="Introduction" title="Introduction">
+<t>
+Theora is a general purpose, lossy video codec. It is based on the VP3 video codec produced by On2 Technologies and has been donated to the Xiph.org Foundation.</t>
+
+<t>
+Theora I is a block-based lossy transform codec that utilizes an 8 x 8 Type-II Discrete Cosine Transform and block-based motion compensation.  This places it in the same class of codecs as MPEG-1, MPEG-2, MPEG-4, and H.263. The details of how individual blocks are organized and how DCT coefficients are stored in the bitstream differ substantially from these codecs, however. Theora supports only intra frames (I frames in MPEG) and inter frames (P frames in MPEG).
+</t>
+
+<t>
+Theora provides none of its own framing, synchronization, or protection against transmission errors. Instead, the codec expects to receive a discrete sequence of data packets. Theora is a free-form variable bit rate (VBR) codec, and these packets have no minimum size, maximum size, or fixed/expected size. Theora packets are thus intended to be used with a transport mechanism that provides free-form framing, synchronization, positioning, and error correction in accordance with these design assumptions, such as Ogg <xref target="rfc3533"></xref> or RTP/AVP <xref target="rfc3550"></xref>.
+</t>
+
+<t>
+Theora I currently supports progressive video data of arbitrary dimensions at a constant frame rate in one of several Y'CbCr color spaces.
+Three different chroma subsampling formats are supported: 4:2:0, 4:2:2, and 4:4:4. The Theora I format does not support interlaced material, variable frame rates, bit-depths larger than 8 bits per component, nor alternate color spaces such as RGB or arbitrary multi-channel spaces. Black and white content can be efficiently encoded, however, because the uniform chroma planes compress well. For performance reason, arbitrary frame sizes will be encoded rounding both dimensions to the upper multiple of 16. The original width and height will be encoded in the header and the decoder will use this information to clip the decoded frame to the right dimensions.
+</t>
+
+<t>
+Theora is similar to the Vorbis audio <xref target="vorbisrtp"></xref> in that the decoder reads the probability model for the entropy coder and all quantization parameters from special "header" packets at the start of the compressed data. It is therefore impossible to decode any video data without having previously fetched the codec info and codec setup headers, although Theora can begin to decode at an arbitrary intra-frame packet so long as the codec has been initialized with the associated headers.
+</t>
+
+<section anchor="Terminology" title="Terminology">
+
+<t>
+The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", 
+and "OPTIONAL" in this document are to be interpreted as described in RFC 2119 <xref target="rfc2119"></xref>.
+</t>
+
+</section>
+</section>
+
+<section anchor="Payload Format" title="Payload Format">
+
+<t>
+For RTP based transportation of Theora encoded video the standard RTP header is followed by a 4 octets payload header, then the payload data. The payload headers are used to associate the Theora data with its associated decoding codebooks as well as indicating if the following packet contains fragmented Theora data and/or the number of whole Theora data frames. The payload data contains the raw Theora bitstream information.
+</t>
+
+<t>
+For RTP based transport of Theora encoded video the standard RTP header is followed by a 4 octets payload header, then the payload data.
+</t>
+
+<section anchor="RTP Header" title="RTP Header">
+
+<t>
+The format of the RTP header is specified in <xref target="rfc3550"></xref> and shown in Figure 1. This payload format uses the fields of the header in a manner consistent with that specification. 
+</t>
+
+<figure anchor="RTP Header Figure" title="RTP Header">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |V=2|P|X|  CC   |M|     PT      |       sequence number         |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                           timestamp                           |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |           synchronization source (SSRC) identifier            |
+   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+   |            contributing source (CSRC) identifiers             |
+   |                              ...                              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+The RTP header begins with an octet of fields (V, P, X, and CC) to support specialized RTP uses (see <xref target="rfc3550"></xref> and <xref target="rfc3551"></xref> for details). For Theora RTP, the following values are used.
+</t>
+
+<t>
+Version (V): 2 bits</t><t>
+This field identifies the version of RTP. The version used by this specification is two (2).
+</t>
+
+<t>
+Padding (P): 1 bit</t><t>
+Padding MAY be used with this payload format according to section 5.1 of <xref target="rfc3550"></xref>.
+</t>
+
+<t>
+Extension (X): 1 bit</t><t>
+The Extension bit is used in accordance with <xref target="rfc3550"></xref>.
+</t>
+
+<t>
+CSRC count (CC): 4 bits</t><t>
+The CSRC count is used in accordance with <xref target="rfc3550"></xref>.
+</t>
+
+<t>
+Marker (M): 1 bit</t><t>
+The Marker bit is used in accordance with <xref target="rfc3550"></xref>.
+</t>
+
+<t>
+Payload Type (PT): 7 bits</t><t>
+An RTP profile for a class of applications is expected to assign a payload type for this format, or a dynamically allocated payload type SHOULD be chosen which designates the payload as Theora.
+</t>
+
+<t>
+Sequence number: 16 bits</t><t>
+The sequence number increments by one for each RTP data packet sent, and may be used by the receiver to detect packet loss and to restore packet sequence. This field is detailed further in <xref target="rfc3550"></xref>.
+</t>
+
+<t>
+Timestamp: 32 bits</t><t>
+A timestamp representing the presentation time of the first sample of the first Theora packet in the RTP packet. The clock frequency MUST be set to 90kHz.
+</t>
+
+<t>
+SSRC/CSRC identifiers: </t><t>
+These two fields, 32 bits each with one SSRC field and a maximum of 16 CSRC fields, are as defined in <xref target="rfc3550"></xref>.
+</t>
+
+</section>
+
+<section anchor="Payload Header" title="Payload Header">
+
+<t>
+The 4 octets following the RTP Header section represent the Payload Header. This header is split into a number of bitfields detailing the format of the following Payload Datagrams.
+</t>
+
+<figure anchor="Payload Header Figure" title="Payload Header">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |               Configuration Ident             | F |TDT|# pkts.| 
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   
+   +-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+Configuration Ident: 24 bits</t>
+<t>
+This 24 bit field is used to associate the Theora data to a decoding Packed Configuration.
+</t>
+
+<t>
+Fragment type (F): 2 bit</t>
+<t>
+This field is set according to the following list
+</t>
+<vspace blankLines="1" />
+<list style="empty">
+<t>      0 = Not Fragmented</t>
+<t>      1 = Start Fragment</t>
+<t>      2 = Continuation Fragment</t>
+<t>      3 = End Fragment</t>
+</list>
+
+<t>This field must be zero if the number of packets field is non-zero.</t>
+
+<t>
+Theora Data Type (TDT): 2 bits</t>
+<t>
+This field sets the packet payload type for the Theora data.  There are currently three Theora payload types currently used and one reserved for future use. 
+</t>
+
+<vspace blankLines="1" />
+<list style="empty">
+<t>      0 = Raw Theora payload</t>
+<t>      1 = Theora Packed Configuration payload</t>
+<t>      2 = Legacy Theora Comment payload</t>
+<t>      3 = Reserved</t>
+</list>
+
+<t> The packets with a TDT of value 3 MUST be ignored </t>
+
+<t>
+The last 4 bits represent the number of complete packets in this payload. This provides a maximum number of 15 Theora packets in the payload. If the packet contains fragmented data the number of packets MUST be set to 0.
+</t>
+
+</section>
+
+<section anchor="Payload Data" title="Payload Data">
+
+<t>
+Each Theora payload section starts with a two octets length header that is used to represent the size of the following data payload, followed by the raw Theora packet data.
+</t>
+
+<figure anchor="Payload Data Figure" title="Payload Data">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |        Payload Length         |          Theora Data         ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+The Theora codec uses relatively unstructured raw packets containing binary integer fields of arbitrary width that often do not fall on an octet boundary. When a Theora encoder produces packets, unused space in the last byte of a packet is always zeroed during the encoding process. Thus, should this unused space be read, it will return binary zeros.
+</t>
+
+<t>
+For payloads which consist of multiple Theora packets the payload data consists of the payload length field followed by the first Theora packet's data, then the payload length followed by the second Theora packet, and so on for each of the Theora packets in the payload.
+</t>
+
+</section>
+
+<section anchor="Example RTP Packet" title="Example RTP Packet">
+
+<t>
+Here is an example RTP packet containing two Theora packets.
+</t>
+<t>
+RTP Packet Header:
+</t>
+
+<figure anchor="Example RTP Packet Figure" title="Example RTP Packet">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   | 2 |0|0|  0    |0|      PT     |       sequence number         |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                           timestamp                           |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |          synchronisation source (SSRC) identifier             |
+   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+   |            contributing source (CSRC) identifiers             |
+   |                              ...                              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+
+<t>
+Payload Data:
+</t>
+
+<figure anchor="Example Theora Payload Figure" title="Example Theora Payload Packet">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |               Configuration Ident             | 0 | 0 | 2 pks |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |        Payload Length         |                              ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Theora data                          ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..           data               |        Payload Length         |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Theora data                           |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+The payload portion of the packet begins with the 24 bit Configuration ident field followed by 8 bits describing the payload. The Fragment type field is set to 0, indicating that this packet contains whole Theora frame data. The Data type field is set to 0 (theora raw data). The number of whole Theora data packets is set to 2.
+</t>
+
+<t>
+Each of the payload blocks starts with the two octets length field followed
+by the variable length Theora packet data.
+</t>
+
+</section>
+</section>
+
+<section anchor="Configuration Headers" title="Configuration Headers">
+
+<t>
+To decode a Theora stream three configuration header packets are needed.  The first (Identification Header) indicates frame dimensions, quality, blocks used and Theora encoder version. The second (Comment Header) contains stream metadata and the third (Setup Header) contains details of the dequantization and Huffman tables.
+</t>
+
+<t>
+Since this information must be transmitted reliably, and as the RTP stream may change certain configuration data mid-session, there are different methods for delivering this configuration data to a client, both in-band and out-of-band, which are detailed below. SDP delivery is used to set up an initial state for the client application. The changes may be due to different dequantization and Huffman tables as well as different bitrates of the stream.
+</t>
+
+<t>
+The delivery vectors in use are specified by an SDP attribute that indicates the method and the optional URI where the Theora <xref target="Packed Configuration">Packed Configuration</xref> Packets could be fetched. Different delivery methods MAY be advertised for the same session. The in-band codebook delivery SHOULD be considered as baseline, out-of-band delivery methods that don't use RTP will not be described in this document. For non chained streams, the RECOMMENDED Configuration delivery method is inline the <xref target="Packed Configuration">Packed Configuration</xref> in the SDP as explained in the <xref target="Mapping MIME Parameters into SDP"> IANA considerations</xref>
+</t>
+
+<t>
+The 24 bit Ident field is used to map which Configuration will be used to decode a packet. When the Ident field changes, it indicates that a change in the stream has taken place. The client application MUST have in advance the correct configuration and if the client detects a change in the Ident value and does not have this information it MUST NOT decode the raw data associated until it has fetched the correct Configuration.
+</t>
+
+
+<section anchor="In-band Header Transmission" title="In-band Header Transmission">
+
+<t>
+The <xref target="Packed Configuration">Packed Configuration</xref> Payload is sent in-band with the packet type bits set to match the payload type. Clients MUST be capable of dealing with periodic re-transmission of the configuration headers.
+</t>
+
+<section anchor="Packed Configuration" title="Packed Configuration">
+
+<t>
+A Theora Packed Configuration is identified by a payload type field of 1. Of the three headers, defined in the <xref target="theora-spec-ref">Theora I specification</xref>, the identification and the setup will be packed together, while the comment header will be completely suppressed. It is up to the client to provide a minimal size comment header to the decoder if required by the implementation.
+</t>
+
+<figure anchor="Packed Configuration Figure" title="Packed Configuration Figure">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |V=2|P|X|  CC   |M|     PT      |             xxxx              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                             xxxxx                             |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |           synchronization source (SSRC) identifier            |
+   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+   |            contributing source (CSRC) identifiers             |
+   |                              ...                              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |               Configuration Ident             | 0 | 1 |      1|
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |             length            |          Identification      ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Identification                       ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Identification                       ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Identification                        |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..              |                      Setup                   ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                            Setup                            ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                            Setup                             |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+<t>The Ident field is set with the value that will be used by the Raw Payload Packets to address this Configuration. The Fragment type is set to 0 since the packet bears full Packed configuration, the number of packet is set to 1. In practice, Packed Headers usually need to be fragmented to fit the path MTU.
+</t>
+
+</section>
+
+</section>
+
+<section anchor="Out of Band Transmission" title="Out of Band Transmission">
+
+<t>
+This section, as stated above, does not cover all the possible out-of-band delivery methods since they rely on different protocols and are linked to specific applications. The following packet definition SHOULD be used in out-of-band delivery and MUST be used when Configuration is inlined in the SDP.
+</t>
+
+<section anchor="Packed Headers" title="Packed Headers"> 
+
+<t>
+As mentioned above, the recommended delivery vector for Theora configuration data is via a retrieval method that can be performed using a reliable transport protocol. As the RTP headers are not required for this method of delivery the structure of the configuration data is slightly different. The packed header starts with a 32 bit count field which details the number of packed headers that are contained in the bundle. Next is the Packed header payload for each setup id.
+</t>
+
+<figure anchor="Packed Headers Overview Figure" title="Packed Headers Overview">
+<artwork><![CDATA[
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                     Number of packed headers                  |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                          Packed header                        |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                          Packed header                        |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+Since the Configuration Ident and the Identification Header are fixed length there is only a 16bit Length tag to define the length of the packed headers.
+</t>
+
+<figure anchor="Packed Headers Detail Figure" title="Packed Headers Detail">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |              Configuration Ident              |              ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..   Length     |              Identification Header           ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                    Identification Header                     |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                         Setup Header                         ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Setup Header                          |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork></figure>
+
+<t>The key difference from the in-band format is that there is no need for the payload header octet.
+</t>
+
+<section anchor="Packed Headers IANA Considerations" title="Packed Headers IANA Considerations"> 
+
+<t>
+The following IANA considerations MUST only be applied to the packed headers.
+</t>
+
+<vspace blankLines="1" />
+
+<list style="hanging">
+<t hangText="MIME media type name:"> video </t>
+
+<vspace blankLines="1" />
+
+<t hangText="MIME subtype:"> theora-config </t>
+
+<vspace blankLines="1" />
+
+<t hangText="Required Parameters:">
+<vspace blankLines="1" />
+None
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Optional Parameters:">
+<vspace blankLines="1" />
+None
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Encoding considerations:">
+<vspace blankLines="1" />
+This media type contains binary data.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Security Considerations:">
+<vspace blankLines="1" />
+See Section 6 of RFC XXXX.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Interoperability considerations:">
+<vspace blankLines="1" />
+None
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Published specification:">
+<vspace blankLines="1" />
+RFC XXXX [RFC Editor: please replace by the RFC number of  this memo,
+       when published]
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Applications which use this media type:">
+<vspace blankLines="1" />
+Theora encoded video, configuration data.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Additional information:"> 
+<vspace blankLines="1" />
+None
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Person &amp; email address to contact for further information:">
+<vspace blankLines="1" />
+Luca Barbato: &lt;lu_zero@gentoo.org&gt;
+<vspace blankLines="0" />
+IETF Audio/Video Transport Working Group
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Intended usage:">
+COMMON
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Restriction on usage:">
+<vspace blankLines="1" />
+This media type does not depend on the transport.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Author:">
+<vspace blankLines="1" />
+Luca Barbato</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Change controller:">
+<vspace blankLines="1" />
+IETF AVT Working Group</t>
+</list>
+
+</section>
+</section>
+
+</section>
+
+<section anchor="Loss of Configuration Headers" title="Loss of Configuration Headers"> 
+
+<t>
+Unlike the loss of raw Theora payload data, the loss of a configuration header can lead to a situation where it will not be possible to successfully decode the stream.
+</t>
+
+<t>
+A loss of a Configuration Packet causes the stream decoder to halt and SHOULD be reported to the client as well as a loss report sent via RTCP.
+</t>
+
+</section>
+
+</section>
+
+<section anchor="Comment Headers" title="Comment Headers">
+
+<t>
+When the payload type is set to 2, the packet contains comment metadata such as artist name, track title and so on. These metadata messages are not intended to be fully descriptive but to offer basic title information. Clients MAY choose to completely ignore them. The details on the comments format can be found in the <xref target="theora-spec-ref">Theora documentation</xref>.
+</t>
+
+<figure anchor="Comment Packet Figure" title="Comment Packet">
+<artwork><![CDATA[
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |V=2|P|X|  CC   |M|     PT      |             xxxx              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                             xxxxx                             |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |           synchronization source (SSRC) identifier            |
+   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+   |            contributing source (CSRC) identifiers             |
+   |                              ...                              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |              Configuration Ident              | 0 | 2 |      1|
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |            length             |            Comment           ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                           Comment                           ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                           Comment                            |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>The 2 byte length field is necessary since this Theora packet could be fragmented.</t>
+
+</section>
+
+<section anchor="Frame Packetizing" title="Frame Packetizing">
+
+<t>
+Each RTP packet contains either one complete Theora packet, one Theora packet fragment, or an integer number of complete Theora packets (up to a maximum of 15 packets, since the number of packets is defined by a 4 bit value).
+</t>
+
+<t>
+Any Theora data packet that is less than path MTU SHOULD be bundled in the RTP packet with as many Theora packets as will fit, up to a maximum of 15.  Path MTU is detailed in <xref target="rfc1063"></xref> and <xref target="rfc1981"></xref>.
+</t>
+
+<t>
+A fragmented packet has a zero in the last four bits of the payload header. The RTP packet containing the first fragment will set the Fragment type to 1. Each RTP packet after the first will set the Fragment type to 2 in the payload header.  The RTP packet containing the last fragment of the Theora packet will have the Fragment type set to 3. If the fragmented Theora packet spans only two RTP packets, the first will set the Fragment type field to 1 and the second will set it to 2.  To maintain the correct sequence for fragmented packet reception the timestamp field of fragmented packets MUST be the same as the first packet sent, with the sequence number incremented as normal for the subsequent RTP packets.</t>
+
+<section anchor="Example Fragmented Theora Packet" title="Example Fragmented Theora Packet">
+
+<t>
+Here is an example fragmented Theora packet split over three RTP packets.  Each packet contains the standard RTP headers as well as the 4 octets Theora headers.
+</t>
+
+<figure anchor="Example Fragmented Packet (Packet 1)" title="Example Fragmented Packet (Packet 1)">
+<artwork><![CDATA[
+   Packet 1:
+
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |V=2|P|X|  CC   |M|     PT      |           1000                |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                             xxxxx                             |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |           synchronization source (SSRC) identifier            |
+   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+   |            contributing source (CSRC) identifiers             |
+   |                              ...                              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |              Configuration Ident              | 1 | 0 |      0|
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |        Payload Length         |           Theora data        ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Theora data                          ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+In this packet the initial sequence number is 1000 and the timestamp is xxxxx.  The Fragment type field is set to one, indicating it is the start packet of a serie of fragments. The number of packets field is set to 0, and as the payload is raw Theora data the Theora payload type field is set to 0.
+</t>
+
+<figure anchor="Example Fragmented Packet (Packet 2)" title="Example Fragmented Packet (Packet 2)">
+<artwork><![CDATA[
+   Packet 2:
+
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |V=2|P|X|  CC   |M|     PT      |           1001                |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                             xxxxx                             |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |           synchronization source (SSRC) identifier            |
+   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+   |            contributing source (CSRC) identifiers             |
+   |                              ...                              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |              Configuration Ident              | 2 | 0 |      0|
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |        Payload Length         |              ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                        Theora data                          ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+The Fragment type field is set to 2 and the number of packets field is set to 0. For large Theora fragments there can be several of these type of payload packets. The maximum RTP packet size SHOULD be no greater than the path MTU, including all RTP and payload headers. The sequence number has been incremented by one but the timestamp field remains the same as the initial packet.
+</t>
+
+<figure anchor="Example Fragmented Packet (Packet 3)" title="Example Fragmented Packet (Packet 3)">
+<artwork><![CDATA[
+   Packet 3:
+
+    0                   1                   2                   3
+    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |V=2|P|X|  CC   |M|     PT      |           1002                |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |                             xxxxx                             |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |           synchronization source (SSRC) identifier            |
+   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
+   |            contributing source (CSRC) identifiers             |
+   |                              ...                              |
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |              Configuration Ident              | 3 | 0 |      0|
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   |        Payload Length         |                              ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+   ..                         Theora data                         ..
+   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+]]></artwork>
+</figure>
+
+<t>
+This is the last Theora fragment packet. The Fragment type filed is set to 3 and the packet count remains set to 0. As in the previous packets the timestamp remains set to the first packet in the sequence and the sequence number has been incremented.
+</t>
+
+</section>
+
+<section anchor="Packet Loss" title="Packet Loss">
+
+<t>
+As there is no error correction within the Theora stream, packet loss will result in a loss of signal. Packet loss is more of an issue for fragmented Theora packets as the client will have to cope with the handling of the Fragment type field. If we use the fragmented Theora packet example above and the first packet is lost the client MUST detect that the next packet has the packet count field set to 0 and the Fragment type is set to 2 and MUST drop it. The next packet, which is the final fragmented packet, MUST be dropped in the same manner. Feedback reports on lost and dropped packets MUST be sent back via RTCP.[note: reordering]
+</t>
+
+<t>
+If a particular multicast session has a large number of participants care must be taken to prevent an RTCP feedback implosion, <xref target="rtcp-feedback"></xref>, in the event of packet loss from a large number of participants.
+</t>
+
+<t>
+Loss of any of the Configuration fragment will result in the loss of the full Configuration packet as detailed in the <xref target="Loss of Configuration Headers">Loss of Configuration Headers</xref> section.
+</t>
+
+</section>
+</section>
+
+<section anchor="IANA Considerations" title="IANA Considerations"> 
+
+<vspace blankLines="1" />
+
+<list style="hanging">
+<t hangText="MIME media type name:"> video </t>
+
+<vspace blankLines="1" />
+
+<t hangText="MIME subtype:"> theora </t>
+
+<vspace blankLines="1" />
+
+<t hangText="Required Parameters:">
+
+<vspace blankLines="1" />
+
+<list style="hanging">
+
+<t hangText="sampling:"> Determines the chroma subsampling format.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="width:"> Determines the number of pixels per line. This is an integer between 1 and 1048561 and MUST be in multiples of 16. 
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="height:">Determines the number of lines per frame encoded. This is an integer between 1 and 1048561 and MUST be in multiples of 16.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="delivery-method:"> indicates the delivery methods in use, the possible values are: inline, in_band, out_band/specific_name<vspace blankLines="0" />
+Where "specific_name" is the name of the out of band delivery method.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="configuration:"> the <xref target="rfc3548">base16</xref> (hexadecimal) representation of the <xref target="Packed Headers">Packed Headers</xref>.
+</t>
+</list>
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Optional Parameters:">
+
+<vspace blankLines="1" />
+
+<list style="hanging">
+<t hangText="configuration-uri:"> the URI of the configuration headers in case of out of band transmission.  In the form of "protocol://path/to/resource/".  Depending on the specific method the single ident packets could be retrived by their number or aggregated in a single stream, aggregates MAY be compressed using <xref target="rfc1952">gzip</xref> or <xref target="BZ2">bzip2</xref> and an <xref target="FIPS180">sha1</xref> checksum MAY be provided in the form of "protocol://path/to/resource/aggregated.bz2!sha1hash"</t>
+</list>
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Encoding considerations:">
+<vspace blankLines="1" />
+This media type is framed and contains binary data.
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Security Considerations:">
+<vspace blankLines="1" />
+See Section 6 of RFC XXXX.</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Interoperability considerations:">
+<vspace blankLines="1" />
+None</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Published specification:">
+
+<vspace blankLines="1" />
+
+<t> RFC XXXX [RFC Editor: please replace by the RFC number of  this memo, when published]</t>
+<vspace blankLines="1" />
+<t>Ogg Theora I specification:  Codec setup and packet decode. Available from the Xiph website, http://www.xiph.org</t>
+
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Applications which use this media type:">
+<vspace blankLines="1"/>
+Video streaming and conferencing tools </t>
+
+<vspace blankLines="1" />
+
+<t hangText="Additional information:">
+<vspace blankLines="1" />
+None </t>
+
+<vspace blankLines="1" />
+
+<t hangText="Person &amp; email address to contact for further information:">
+
+<vspace blankLines="1" />
+
+<t>Luca Barbato: &lt;lu_zero@gentoo.org&gt;</t>
+<t>IETF Audio/Video Transport Working Group</t>
+
+</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Intended usage:">
+<vspace blankLines="1" />
+COMMON</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Restriction on usage:">
+<vspace blankLines="1" />
+This media type depends on RTP framing, and hence is only defined for transfer via <xref target="rfc3550">RTP</xref></t>
+
+<vspace blankLines="1" />
+
+<t hangText="Author:">
+<vspace blankLines="1"/>Luca Barbato</t>
+
+<vspace blankLines="1" />
+
+<t hangText="Change controller:"><vspace blankLines="1"/> IETF AVT Working Group</t>
+
+<vspace blankLines="1" />
+
+</list>
+
+<section anchor="Mapping MIME Parameters into SDP" title="Mapping MIME Parameters into SDP"> 
+
+<t>
+The information carried in the MIME media type specification has a specific mapping to fields in the Session Description Protocol (SDP) <xref target="rfc2327"></xref>, which is commonly used to describe RTP sessions.  When SDP is used to specify sessions the mapping are as follows:
+</t>
+
+<vspace blankLines="1" />
+<list style="symbols">
+
+<t>The MIME type ("video") goes in SDP "m=" as the media name.</t>
+<vspace blankLines="1" />
+
+<t>The MIME subtype ("theora") goes in SDP "a=rtpmap" as the encoding name.</t>
+<vspace blankLines="1" />
+
+<t>The clock rate in the "a=rtpmap" line MUST be 90000</t>
+<vspace blankLines="1" />
+
+<t>The mandated parameters "delivery-method" and "configuration" MUST be included in the SDP "a=fmpt" attribute.</t>
+<vspace blankLines="1" />
+
+<t>The optional parameter "configuration-uri", when present, MUST be included in the SDP "a=fmpt" attribute and MUST follow the delivery-method that applies.</t>
+</list>
+
+
+<t>
+If the stream uses multiple decoder setup configurations and all of them are known in advance, the Configuration Packet for each file SHOULD be packaged together and passed to the client using the configuration attribute.
+</t>
+
+<t>
+The URI specified in the configuration-uri attribute MUST point to a location where all of the Configuration Packets needed for the life of the session reside.
+</t>
+
+<section anchor="SDP Example" title="SDP Example">
+<t>The following example shows a basic SDP for a single stream. The first configuration packet is inlined in the sdp, other configurations could be fetched at any time from the first provided uri using or all the known configuration could be downloaded using the second uri. The inline <xref target="rfc3548">base16</xref> configuration string is omitted because of the lenght.</t>
+
+<list style="empty">
+<t>c=IN IP4 192.0.0.1</t>
+<t>m=video  RTP/AVP 98</t>
+<t>a=rtpmap:98 theora/90000</t>
+<t>a=fmtp:98 sampling=YCbCr-4:2:2; width=1280; height=720; delivery-method=inline; configuration=base16string1; delivery-method=out_band/rtsp; delivery-method=out_band/rtsp; configuration-uri=rtsp://path/to/resource/; delivery-method=out_band/http; configuration-uri=http://another/path/to/resource/aggregate.bz2!sha1hash;</t>
+</list>
+</section>
+
+</section>
+
+<section anchor="Usage with the SDP Offer/Answer Mode" title="Usage with the SDP Offer/Answer Model">
+
+<t>
+The offer, as described in <xref target="rfc3264">An Offer/Answer Model Session Description Protocol</xref>, may contain a large number of delivery methods per single fmtp attribute, the answerer MUST remove every delivery-method and configuration-uri not supported. All the parameters MUST not be altered on answer otherwise.
+</t>
+
+</section>
+
+</section>
+
+<section anchor="Examples" title="Examples">
+
+<t>
+The following examples are common usage patterns that MAY be applied in such situations, the main scope of this section is to explain better usage of the transmission vectors.
+</t>
+<!--
+
+<section anchor="Peer to Peer Internet Messaging" title="Peer to Peer Internet Messaging">
+
+<t>This scenario implies two peers linked through a best effort network, the bandwidth isn't guaranteed and may have large variance, in order to keep the latency low enough dynamic adaptation tecniques [missing reference] are required.</t>
+
+<t>Each peer will receive 2 streams (voice and video) from the other. To determine the quality of the stream and ensure the latency is bearable [put maximum latency here] a form of handshake is required. SIP or Jingle or TINS could be used in this phase.</t>
+
+<t>Since changes in the bitrates will reflect on the setup header, the simplest way to get dynamic adaptation is to consider each stream as a completely different coded, have a payload number for each of them and use the dynamic coding change tecniques.</t>
+
+<t>Due the latency requirement even if sending the Configuration in-band MAY be possible, usually it SHOULD be avoided. Other out of band methods that send Configuration on demand, since they would affect latency as the in-band method, SHOULD be avoided as well. Agree on a set of Configurations related to different bitrates during the session initiation is the best method.</t>
+
+</section>
+-->
+<section anchor="Stream Video" title="Stream Video">
+
+<t>This is one of the most common situation: one single server streaming content in multicast, the clients may start a session at random time. The content itself could be a mix of live stream, as the wj's voice or studio scenes, and stored streams, as the music she plays.</t>
+
+<t>In this situation we don't know in advance how many codebooks we will use. The clients can join anytime and users expect to start the fruition of the content in a short time.</t>
+
+<t>On join the client will receive the current Configuration necessary to decode the current streams inlined in the SDP so that the decoding will start immediately after.</t>
+
+<t>When the streamed content changes the new Configuration is sent in-band before the actual stream, and the Configuration that has to be sent inline in the SDP updated. Since the inline method is unreliable, an out of band fallback is provided.</t>
+
+<t>The client could choose to fetch the Configuration from the alternate source as soon it discovers a Configuration packet got lost inline or use <xref target="rfc3611">selective retransmission</xref>, if the server supports the feature.</t>
+
+<t>A serverside optimization would be to keep an hash list of the Configurations per session to avoid packing all of them and send the same Configuration with different Ident tags</t>
+
+<t>A clientside optimization would be to keep a tag list of the Configurations per session and don't process configuration packets already known.</t>
+
+</section>
+
+</section>
+
+<section anchor="Security Considerations" title="Security Considerations"> 
+<t>
+RTP packets using this payload format are subject to the security considerations discussed in the RTP specification <xref target="rfc3550"></xref>. This implies that the confidentiality of the media stream is achieved by using encryption. Because the data compression used with this payload format is applied end-to-end, encryption may be performed on the compressed data. Where the size of a data block is set care MUST be taken to prevent buffer overflows in the client applications.
+</t>
+
+</section> 
+
+<section anchor="Acknowledgments" title="Acknowledgments"> 
+
+<t>This document is a continuation of draft-kerr-avt-theora-rtp-00.txt</t>
+
+<t>
+Thanks to the AVT, Ogg Theora Communities / Xiph.org, Fluendo, Ralph Giles, Mike Smith, Phil Kerr, Timothy Terriberry, Stefan Ehmann, Alessandro Salvatori, Politecnico di Torino (LS)³/IMG Group in particular Federico Ridolfo, Francesco Varano, Giampaolo Mancini, Juan Carlos De Martin.
+</t>
+
+</section> 
+
+</middle>
+
+<back>
+
+<references title="Normative References">
+
+<reference anchor="rfc3533">
+<front>
+<title>The Ogg Encapsulation Format Version 0</title>
+<author initials="S." surname="Pfeiffer" fullname="Silvia Pfeiffer"></author>
+</front>
+<seriesInfo name="RFC" value="3533" />
+</reference>
+
+<reference anchor="rfc2119">
+<front>
+<title>Key words for use in RFCs to Indicate Requirement Levels </title>
+<author initials="S." surname="Bradner" fullname="Scott Bradner"></author>
+</front>
+<seriesInfo name="RFC" value="2119" />
+</reference> 
+
+<reference anchor="rfc3550">
+<front>
+<title>RTP: A Transport Protocol for real-time applications</title>
+<author initials="H." surname="Schulzrinne" fullname=""></author>
+<author initials="S." surname="Casner" fullname=""></author>
+<author initials="R." surname="Frederick" fullname=""></author>
+<author initials="V." surname="Jacobson" fullname=""></author>
+</front>
+<seriesInfo name="RFC" value="3550" />
+</reference> 
+
+<reference anchor="rfc3551">
+<front>
+<title>RTP Profile for video and Video Conferences with Minimal Control.</title>
+<author initials="H." surname="Schulzrinne" fullname=""></author>
+<author initials="S." surname="Casner" fullname=""></author>
+</front>
+<date month="July" year="2003" />
+<seriesInfo name="RFC" value="3551" />
+</reference> 
+
+<reference anchor="rfc3264">
+<front>
+<title>An Offer/Answer Model with Session Description Protocol (SDP)</title>
+<author initials="J." surname="Rosenberg" fullname="Jonathan Rosenberg"></author>
+<author initials="H." surname="Schulzrinne" fullname="Henning Schulzrinne"></author>
+</front>
+<seriesInfo name="RFC" value="3264" />
+</reference> 
+
+<reference anchor="rfc2327">
+<front>
+<title>SDP: Session Description Protocol</title>
+<author initials="M." surname="Handley" fullname="Mark Handley"></author>
+<author initials="V." surname="Jacobson" fullname="Van Jacobson"></author>
+</front>
+<seriesInfo name="RFC" value="2327" />
+</reference>
+
+<reference anchor="rfc1063">
+<front>
+<title>Path MTU Discovery</title>
+<author initials="J." surname="Mogul et al." fullname="J. Mogul et al."></author>
+</front>
+<seriesInfo name="RFC" value="1063" />
+</reference> 
+
+<reference anchor="rfc1981">
+<front>
+<title>Path MTU Discovery for IP version 6</title>
+<author initials="J." surname="McCann et al." fullname="J. McCann et al."></author>
+</front>
+<seriesInfo name="RFC" value="1981" />
+</reference> 
+
+<reference anchor="rtcp-feedback">
+<front>
+<title>Extended RTP Profile for RTCP-based Feedback (RTP/AVPF)</title>
+<author initials="J." surname="Ott" fullname="Joerg Ott"></author>
+<author initials="S." surname="Wenger" fullname="Stephan Wenger"></author>
+<author initials="N." surname="Sato" fullname="Noriyuki Sato"></author>
+<author initials="C." surname="Burmeister" fullname="Carsten Burmeister"></author>
+<author initials="J." surname="Rey" fullname="Jose Rey"></author>
+</front>
+<seriesInfo name="Internet Draft" value="(draft-ietf-avt-rtcp-feedback-11: Work in progress)" />
+</reference> 
+
+<reference anchor="vorbisrtp">
+<front>
+<title>RTP Payload Format for Vorbis Encoded Audio - draft-ietf-avt-vorbis-rtp-00</title>
+<author initials="L." surname="Barbato" fullname="Luca Barbato"></author>
+</front>
+<seriesInfo name="Internet Draft" value="(Work in progress)" />
+</reference> 
+
+<reference anchor="rfc3548">
+<front>
+<title>The Base16, Base32, and Base64 Data Encodings</title>
+<author initials="S." surname="Josefsson" fullname="Simon Josefsson"></author>
+</front>
+<seriesInfo name="RFC" value="3548" />
+</reference>
+
+<reference anchor="rfc1952">
+<front>
+<title>GZIP file format specification version 4.3</title>
+<author initials="P" surname="Deutsch" fullname="L. Peter Deutsch"></author>
+</front>
+<seriesInfo name="RFC" value="1952" />
+</reference>
+
+<reference anchor="FIPS180">
+<front>
+<title>Secure Hash Standard</title>
+<author>
+<organization>National Institute of Standards and Technology</organization>
+</author>
+<date month="May" year="1993"/>
+</front>
+</reference>
+
+<reference anchor="BZ2">
+<front>
+<title>libbz2 and bzip2</title>
+<author initials="J" surname="Seward" fullname="Julian Seward" />
+</front>
+</reference>
+
+</references>
+
+<references title="Informative References">
+<reference anchor="libTheora">
+<front>
+<title>libTheora: Available from the Xiph website, http://www.xiph.org</title>
+</front>
+</reference>
+
+<reference anchor="theora-spec-ref">
+<front>
+<title>Theora I specification:  Codec setup and packet decode.  http://www.xiph.org/theora/doc/Theora_I_spec.pdf</title>
+</front>
+</reference> 
+
+<reference anchor='rfc3611'>
+
+<front>
+<title>RTP Control Protocol Extended Reports (RTCP XR)</title>
+<author initials='T.' surname='Friedman' fullname='T. Friedman'>
+<organization /></author>
+<author initials='R.' surname='Caceres' fullname='R. Caceres'>
+<organization /></author>
+<author initials='A.' surname='Clark' fullname='A. Clark'>
+<organization /></author>
+<date year='2003' month='November' /></front>
+<seriesInfo name='RFC' value='3611' />
+</reference>
+
+
+<reference anchor="ITU-T V42">
+<front>
+<title>
+ITU-T Recommendation V.42, 1994, Rev. 1. Error-correcting Procedures for DCEs Using Asynchronous-to-Synchronous Conversion. International Telecommunications Union. Available from the ITU website, http://www.itu.int
+</title>
+</front>
+</reference>
+
+<reference anchor="ISO 3309">
+<front>
+<title>ISO 3309, October 1984, 3rd Edition. Information Processing Systems--Data Communication High-Level Data Link Control Procedure--Frame Structure. International Organization for Standardization.
+</title>
+</front>
+</reference>
+</references>
+</back>
+</rfc>
diff --git a/doc/spec/Makefile.am b/doc/spec/Makefile.am
new file mode 100644 (file)
index 0000000..3a181a2
--- /dev/null
@@ -0,0 +1,83 @@
+## Process this file with automake to produce Makefile.in
+
+# makefile to generate the spec document from sources
+# requires transfig and pdflatex
+
+docdir = $(datadir)/doc/$(PACKAGE)-$(VERSION)
+
+built_docs = Theora.pdf
+
+if BUILD_SPEC
+doc_DATA = $(built_docs)
+endif
+
+SPEC_SRCS = spec.tex spec.bib
+
+FIG_SRCS = pic-frame.fig hilbert-mb.fig hilbert-block.fig xifish.fig \
+           superblock.fig macroblock.fig raster-block.fig reference-frames.fig \
+           pixel444.fig pixel422.fig pixel420.fig idct.fig fdct.fig \
+           pic_even.fig pic_even_odd.fig pic_odd.fig pic_odd_even.fig \
+           lflim.fig
+
+FIG_TEXS = $(FIG_SRCS:.fig=.tex)
+FIG_AUXS = $(FIG_SRCS:.fig=.aux)
+FIG_PDFS = $(FIG_SRCS:.fig=.pdf)
+
+# add any native-pdf figures here
+FIG_OBJS = $(FIG_PDFS)
+
+EXTRA_DIST = $(built_docs) $(SPEC_SRCS) $(FIG_SRCS) ltablex.sty
+
+if BUILD_SPEC
+# latex three times is the charm with references
+# long tables require the .aux file to start from scratch
+Theora.pdf : $(SPEC_SRCS) $(FIG_OBJS) vp3huff.tex spec.bib
+       -$(RM) spec.aux
+       pdflatex -interaction nonstopmode spec.tex
+       bibtex spec.aux
+       pdflatex -interaction nonstopmode spec.tex
+       pdflatex -interaction nonstopmode spec.tex
+       mv spec.pdf $@
+else
+Theora.pdf : 
+        echo "*** Warning: Missing tools; $@ will not be built."
+endif
+
+vp3huff.tex : vp3huff
+       ./vp3huff > $@
+
+noinst_PROGRAMS = vp3huff
+vp3huff_SOURCES = vp3huff.c
+figures : $(FIG_OBJS)
+
+# rules to generate latex and pdf versions of the xfig figures
+.fig.tex:
+       fig2dev -L latex $< $@
+
+.fig.pdf:
+       fig2dev -L pdf -p 0 $< $@
+
+SUFFIXES = .fig .tex .pdf
+
+# clean targets
+clean-local:
+       -$(RM) $(FIG_TEXS)
+       -$(RM) $(FIG_AUXS)
+       -$(RM) $(FIG_PDFS)
+       -$(RM) vp3huff
+       -$(RM) vp3huff.tex
+       -$(RM) vp3huff.aux
+       -$(RM) spec.aux
+       -$(RM) spec.log
+       -$(RM) spec.lof
+       -$(RM) spec.lot
+       -$(RM) spec.out
+       -$(RM) spec.bbl
+       -$(RM) spec.blg
+       -$(RM) spec.toc
+
+maintainer-clean-local:
+       -$(RM) $(built_docs)
+
+maintainerclean: maintainer-clean
diff --git a/doc/spec/Makefile.in b/doc/spec/Makefile.in
new file mode 100644 (file)
index 0000000..6bde8fc
--- /dev/null
@@ -0,0 +1,498 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+
+# makefile to generate the spec document from sources
+# requires transfig and pdflatex
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ../..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+
+docdir = $(datadir)/doc/$(PACKAGE)-$(VERSION)
+
+built_docs = Theora.pdf
+
+@BUILD_SPEC_TRUE@doc_DATA = $(built_docs)
+
+SPEC_SRCS = spec.tex spec.bib
+
+FIG_SRCS = pic-frame.fig hilbert-mb.fig hilbert-block.fig xifish.fig \
+           superblock.fig macroblock.fig raster-block.fig reference-frames.fig \
+           pixel444.fig pixel422.fig pixel420.fig idct.fig fdct.fig \
+           pic_even.fig pic_even_odd.fig pic_odd.fig pic_odd_even.fig \
+           lflim.fig
+
+
+FIG_TEXS = $(FIG_SRCS:.fig=.tex)
+FIG_AUXS = $(FIG_SRCS:.fig=.aux)
+FIG_PDFS = $(FIG_SRCS:.fig=.pdf)
+
+# add any native-pdf figures here
+FIG_OBJS = $(FIG_PDFS)
+
+EXTRA_DIST = $(built_docs) $(SPEC_SRCS) $(FIG_SRCS) ltablex.sty
+
+noinst_PROGRAMS = vp3huff
+vp3huff_SOURCES = vp3huff.c
+
+SUFFIXES = .fig .tex .pdf
+subdir = doc/spec
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES =
+noinst_PROGRAMS = vp3huff$(EXEEXT)
+PROGRAMS = $(noinst_PROGRAMS)
+
+am_vp3huff_OBJECTS = vp3huff.$(OBJEXT)
+vp3huff_OBJECTS = $(am_vp3huff_OBJECTS)
+vp3huff_LDADD = $(LDADD)
+vp3huff_DEPENDENCIES =
+vp3huff_LDFLAGS =
+
+DEFS = @DEFS@
+DEFAULT_INCLUDES =  -I. -I$(srcdir) -I$(top_builddir)
+CPPFLAGS = @CPPFLAGS@
+LDFLAGS = @LDFLAGS@
+LIBS = @LIBS@
+depcomp = $(SHELL) $(top_srcdir)/depcomp
+am__depfiles_maybe = depfiles
+@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/vp3huff.Po
+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
+       $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) \
+       $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+CCLD = $(CC)
+LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+       $(AM_LDFLAGS) $(LDFLAGS) -o $@
+CFLAGS = @CFLAGS@
+DIST_SOURCES = $(vp3huff_SOURCES)
+DATA = $(doc_DATA)
+
+DIST_COMMON = Makefile.am Makefile.in
+SOURCES = $(vp3huff_SOURCES)
+
+all: all-am
+
+.SUFFIXES:
+.SUFFIXES: .fig .tex .pdf .c .lo .o .obj
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  doc/spec/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+
+clean-noinstPROGRAMS:
+       @list='$(noinst_PROGRAMS)'; for p in $$list; do \
+         f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \
+         echo " rm -f $$p $$f"; \
+         rm -f $$p $$f ; \
+       done
+vp3huff$(EXEEXT): $(vp3huff_OBJECTS) $(vp3huff_DEPENDENCIES) 
+       @rm -f vp3huff$(EXEEXT)
+       $(LINK) $(vp3huff_LDFLAGS) $(vp3huff_OBJECTS) $(vp3huff_LDADD) $(LIBS)
+
+mostlyclean-compile:
+       -rm -f *.$(OBJEXT) core *.core
+
+distclean-compile:
+       -rm -f *.tab.c
+
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/vp3huff.Po@am__quote@
+
+distclean-depend:
+       -rm -rf ./$(DEPDIR)
+
+.c.o:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `test -f '$<' || echo '$(srcdir)/'`$<
+
+.c.obj:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `cygpath -w $<`
+
+.c.lo:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LTCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$<
+CCDEPMODE = @CCDEPMODE@
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+docDATA_INSTALL = $(INSTALL_DATA)
+install-docDATA: $(doc_DATA)
+       @$(NORMAL_INSTALL)
+       $(mkinstalldirs) $(DESTDIR)$(docdir)
+       @list='$(doc_DATA)'; for p in $$list; do \
+         if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " $(docDATA_INSTALL) $$d$$p $(DESTDIR)$(docdir)/$$f"; \
+         $(docDATA_INSTALL) $$d$$p $(DESTDIR)$(docdir)/$$f; \
+       done
+
+uninstall-docDATA:
+       @$(NORMAL_UNINSTALL)
+       @list='$(doc_DATA)'; for p in $$list; do \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " rm -f $(DESTDIR)$(docdir)/$$f"; \
+         rm -f $(DESTDIR)$(docdir)/$$f; \
+       done
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ../..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+check-am: all-am
+check: check-am
+all-am: Makefile $(PROGRAMS) $(DATA)
+
+installdirs:
+       $(mkinstalldirs) $(DESTDIR)$(docdir)
+
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-generic clean-libtool clean-local clean-noinstPROGRAMS \
+       mostlyclean-am
+
+distclean: distclean-am
+
+distclean-am: clean-am distclean-compile distclean-depend \
+       distclean-generic distclean-libtool distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+info: info-am
+
+info-am:
+
+install-data-am: install-docDATA
+
+install-exec-am:
+
+install-info: install-info-am
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+
+maintainer-clean-am: distclean-am maintainer-clean-generic \
+       maintainer-clean-local
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-compile mostlyclean-generic \
+       mostlyclean-libtool
+
+uninstall-am: uninstall-docDATA uninstall-info-am
+
+.PHONY: GTAGS all all-am check check-am clean clean-generic \
+       clean-libtool clean-local clean-noinstPROGRAMS distclean \
+       distclean-compile distclean-depend distclean-generic \
+       distclean-libtool distclean-tags distdir dvi dvi-am info \
+       info-am install install-am install-data install-data-am \
+       install-docDATA install-exec install-exec-am install-info \
+       install-info-am install-man install-strip installcheck \
+       installcheck-am installdirs maintainer-clean \
+       maintainer-clean-generic maintainer-clean-local mostlyclean \
+       mostlyclean-compile mostlyclean-generic mostlyclean-libtool \
+       tags uninstall uninstall-am uninstall-docDATA uninstall-info-am
+
+
+# latex three times is the charm with references
+# long tables require the .aux file to start from scratch
+@BUILD_SPEC_TRUE@Theora.pdf : $(SPEC_SRCS) $(FIG_OBJS) vp3huff.tex spec.bib
+@BUILD_SPEC_TRUE@      -$(RM) spec.aux
+@BUILD_SPEC_TRUE@      pdflatex -interaction nonstopmode spec.tex
+@BUILD_SPEC_TRUE@      bibtex spec.aux
+@BUILD_SPEC_TRUE@      pdflatex -interaction nonstopmode spec.tex
+@BUILD_SPEC_TRUE@      pdflatex -interaction nonstopmode spec.tex
+@BUILD_SPEC_TRUE@      mv spec.pdf $@
+@BUILD_SPEC_FALSE@Theora.pdf : 
+@BUILD_SPEC_FALSE@        echo "*** Warning: Missing tools; $@ will not be built."
+
+vp3huff.tex : vp3huff
+       ./vp3huff > $@
+
+figures : $(FIG_OBJS)
+
+# rules to generate latex and pdf versions of the xfig figures
+.fig.tex:
+       fig2dev -L latex $< $@
+
+.fig.pdf:
+       fig2dev -L pdf -p 0 $< $@
+
+# clean targets
+clean-local:
+       -$(RM) $(FIG_TEXS)
+       -$(RM) $(FIG_AUXS)
+       -$(RM) $(FIG_PDFS)
+       -$(RM) vp3huff
+       -$(RM) vp3huff.tex
+       -$(RM) vp3huff.aux
+       -$(RM) spec.aux
+       -$(RM) spec.log
+       -$(RM) spec.lof
+       -$(RM) spec.lot
+       -$(RM) spec.out
+       -$(RM) spec.bbl
+       -$(RM) spec.blg
+       -$(RM) spec.toc
+
+maintainer-clean-local:
+       -$(RM) $(built_docs)
+
+maintainerclean: maintainer-clean
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/doc/spec/Theora.pdf b/doc/spec/Theora.pdf
new file mode 100644 (file)
index 0000000..9e1e3be
--- /dev/null
@@ -0,0 +1,20770 @@
+%PDF-1.4
+%ÐÔÅØ
+5 0 obj
+<< /S /GoTo /D (chapter.1) >>
+endobj
+8 0 obj
+(Introduction)
+endobj
+9 0 obj
+<< /S /GoTo /D (section.1.1) >>
+endobj
+12 0 obj
+(VP3 and Theora)
+endobj
+13 0 obj
+<< /S /GoTo /D (section.1.2) >>
+endobj
+16 0 obj
+(Video Formats)
+endobj
+17 0 obj
+<< /S /GoTo /D (section.1.3) >>
+endobj
+20 0 obj
+(Classification)
+endobj
+21 0 obj
+<< /S /GoTo /D (section.1.4) >>
+endobj
+24 0 obj
+(Assumptions)
+endobj
+25 0 obj
+<< /S /GoTo /D (section.1.5) >>
+endobj
+28 0 obj
+(Codec Setup and Probability Model)
+endobj
+29 0 obj
+<< /S /GoTo /D (section.1.6) >>
+endobj
+32 0 obj
+(Format Conformance)
+endobj
+33 0 obj
+<< /S /GoTo /D (chapter.2) >>
+endobj
+36 0 obj
+(Coded Video Structure)
+endobj
+37 0 obj
+<< /S /GoTo /D (section.2.1) >>
+endobj
+40 0 obj
+(Frame Layout)
+endobj
+41 0 obj
+<< /S /GoTo /D (section.2.2) >>
+endobj
+44 0 obj
+(Picture Region)
+endobj
+45 0 obj
+<< /S /GoTo /D (section.2.3) >>
+endobj
+48 0 obj
+(Blocks and Super Blocks)
+endobj
+49 0 obj
+<< /S /GoTo /D (section.2.4) >>
+endobj
+52 0 obj
+(Macro Blocks)
+endobj
+53 0 obj
+<< /S /GoTo /D (section.2.5) >>
+endobj
+56 0 obj
+(Coding Modes and Prediction)
+endobj
+57 0 obj
+<< /S /GoTo /D (section.2.6) >>
+endobj
+60 0 obj
+(DCT Coefficients)
+endobj
+61 0 obj
+<< /S /GoTo /D (chapter.3) >>
+endobj
+64 0 obj
+(Decoding Overview)
+endobj
+65 0 obj
+<< /S /GoTo /D (section.3.1) >>
+endobj
+68 0 obj
+(Decoder Configuration)
+endobj
+69 0 obj
+<< /S /GoTo /D (subsection.3.1.1) >>
+endobj
+72 0 obj
+(Global Configuration)
+endobj
+73 0 obj
+<< /S /GoTo /D (subsection.3.1.2) >>
+endobj
+76 0 obj
+(Quantization Matrices)
+endobj
+77 0 obj
+<< /S /GoTo /D (subsection.3.1.3) >>
+endobj
+80 0 obj
+(Huffman Codebooks)
+endobj
+81 0 obj
+<< /S /GoTo /D (section.3.2) >>
+endobj
+84 0 obj
+(High-Level Decode Process)
+endobj
+85 0 obj
+<< /S /GoTo /D (subsection.3.2.1) >>
+endobj
+88 0 obj
+(Decoder Setup)
+endobj
+89 0 obj
+<< /S /GoTo /D (subsection.3.2.2) >>
+endobj
+92 0 obj
+(Decode Procedure)
+endobj
+93 0 obj
+<< /S /GoTo /D (chapter.4) >>
+endobj
+96 0 obj
+(Video Formats)
+endobj
+97 0 obj
+<< /S /GoTo /D (section.4.1) >>
+endobj
+100 0 obj
+(Color Space Conventions)
+endobj
+101 0 obj
+<< /S /GoTo /D (section.4.2) >>
+endobj
+104 0 obj
+(Color Space Conversions and Parameters)
+endobj
+105 0 obj
+<< /S /GoTo /D (section.4.3) >>
+endobj
+108 0 obj
+(Available Color Spaces)
+endobj
+109 0 obj
+<< /S /GoTo /D (subsection.4.3.1) >>
+endobj
+112 0 obj
+(Rec. 470M \(Rec. ITU-R BT.470-6 System M/NTSC with Rec. ITU-R BT.601-5\))
+endobj
+113 0 obj
+<< /S /GoTo /D (subsection.4.3.2) >>
+endobj
+116 0 obj
+(Rec. 470BG \(Rec. ITU-R BT.470-6 Systems B and G with Rec. ITU-R BT.601-5\))
+endobj
+117 0 obj
+<< /S /GoTo /D (section.4.4) >>
+endobj
+120 0 obj
+(Pixel Formats)
+endobj
+121 0 obj
+<< /S /GoTo /D (subsection.4.4.1) >>
+endobj
+124 0 obj
+(4:4:4 Subsampling)
+endobj
+125 0 obj
+<< /S /GoTo /D (subsection.4.4.2) >>
+endobj
+128 0 obj
+(4:2:2 Subsampling)
+endobj
+129 0 obj
+<< /S /GoTo /D (subsection.4.4.3) >>
+endobj
+132 0 obj
+(4:2:0 Subsampling)
+endobj
+133 0 obj
+<< /S /GoTo /D (subsection.4.4.4) >>
+endobj
+136 0 obj
+(Subsampling and the Picture Region)
+endobj
+137 0 obj
+<< /S /GoTo /D (chapter.5) >>
+endobj
+140 0 obj
+(Bitpacking Convention)
+endobj
+141 0 obj
+<< /S /GoTo /D (section.5.1) >>
+endobj
+144 0 obj
+(Overview)
+endobj
+145 0 obj
+<< /S /GoTo /D (subsection.5.1.1) >>
+endobj
+148 0 obj
+(Octets and Bytes)
+endobj
+149 0 obj
+<< /S /GoTo /D (subsection.5.1.2) >>
+endobj
+152 0 obj
+(Words and Byte Order)
+endobj
+153 0 obj
+<< /S /GoTo /D (subsection.5.1.3) >>
+endobj
+156 0 obj
+(Bit Order)
+endobj
+157 0 obj
+<< /S /GoTo /D (section.5.2) >>
+endobj
+160 0 obj
+(Coding Bits into Bytes)
+endobj
+161 0 obj
+<< /S /GoTo /D (subsection.5.2.1) >>
+endobj
+164 0 obj
+(Signedness)
+endobj
+165 0 obj
+<< /S /GoTo /D (subsection.5.2.2) >>
+endobj
+168 0 obj
+(Encoding Example)
+endobj
+169 0 obj
+<< /S /GoTo /D (subsection.5.2.3) >>
+endobj
+172 0 obj
+(Decoding Example)
+endobj
+173 0 obj
+<< /S /GoTo /D (subsection.5.2.4) >>
+endobj
+176 0 obj
+(End-of-Packet Alignment)
+endobj
+177 0 obj
+<< /S /GoTo /D (subsection.5.2.5) >>
+endobj
+180 0 obj
+(Reading Zero Bit Integers)
+endobj
+181 0 obj
+<< /S /GoTo /D (chapter.6) >>
+endobj
+184 0 obj
+(Bitstream Headers)
+endobj
+185 0 obj
+<< /S /GoTo /D (section.6.1) >>
+endobj
+188 0 obj
+(Common Header Decode)
+endobj
+189 0 obj
+<< /S /GoTo /D (section.6.2) >>
+endobj
+192 0 obj
+(Identification Header Decode)
+endobj
+193 0 obj
+<< /S /GoTo /D (section.6.3) >>
+endobj
+196 0 obj
+(Comment Header)
+endobj
+197 0 obj
+<< /S /GoTo /D (subsection.6.3.1) >>
+endobj
+200 0 obj
+(Comment Length Decode)
+endobj
+201 0 obj
+<< /S /GoTo /D (subsection.6.3.2) >>
+endobj
+204 0 obj
+(Comment Header Decode)
+endobj
+205 0 obj
+<< /S /GoTo /D (subsection.6.3.3) >>
+endobj
+208 0 obj
+(User Comment Format)
+endobj
+209 0 obj
+<< /S /GoTo /D (section.6.4) >>
+endobj
+212 0 obj
+(Setup Header)
+endobj
+213 0 obj
+<< /S /GoTo /D (subsection.6.4.1) >>
+endobj
+216 0 obj
+(Loop Filter Limit Table Decode)
+endobj
+217 0 obj
+<< /S /GoTo /D (subsection.6.4.2) >>
+endobj
+220 0 obj
+(Quantization Parameters Decode)
+endobj
+221 0 obj
+<< /S /GoTo /D (subsection.6.4.3) >>
+endobj
+224 0 obj
+(Computing a Quantization Matrix)
+endobj
+225 0 obj
+<< /S /GoTo /D (subsection.6.4.4) >>
+endobj
+228 0 obj
+(DCT Token Huffman Tables)
+endobj
+229 0 obj
+<< /S /GoTo /D (subsection.6.4.5) >>
+endobj
+232 0 obj
+(Setup Header Decode)
+endobj
+233 0 obj
+<< /S /GoTo /D (chapter.7) >>
+endobj
+236 0 obj
+(Frame Decode)
+endobj
+237 0 obj
+<< /S /GoTo /D (section.7.1) >>
+endobj
+240 0 obj
+(Frame Header Decode)
+endobj
+241 0 obj
+<< /S /GoTo /D (section.7.2) >>
+endobj
+244 0 obj
+(Run-Length Encoded Bit Strings)
+endobj
+245 0 obj
+<< /S /GoTo /D (subsection.7.2.1) >>
+endobj
+248 0 obj
+(Long-Run Bit String Decode)
+endobj
+249 0 obj
+<< /S /GoTo /D (subsection.7.2.2) >>
+endobj
+252 0 obj
+(Short-Run Bit String Decode)
+endobj
+253 0 obj
+<< /S /GoTo /D (section.7.3) >>
+endobj
+256 0 obj
+(Coded Block Flags Decode)
+endobj
+257 0 obj
+<< /S /GoTo /D (section.7.4) >>
+endobj
+260 0 obj
+(Macro Block Coding Modes)
+endobj
+261 0 obj
+<< /S /GoTo /D (section.7.5) >>
+endobj
+264 0 obj
+(Motion Vectors)
+endobj
+265 0 obj
+<< /S /GoTo /D (subsection.7.5.1) >>
+endobj
+268 0 obj
+(Motion Vector Decode)
+endobj
+269 0 obj
+<< /S /GoTo /D (subsection.7.5.2) >>
+endobj
+272 0 obj
+(Macro Block Motion Vector Decode)
+endobj
+273 0 obj
+<< /S /GoTo /D (section.7.6) >>
+endobj
+276 0 obj
+(Block-Level qi Decode)
+endobj
+277 0 obj
+<< /S /GoTo /D (section.7.7) >>
+endobj
+280 0 obj
+(DCT Coefficients)
+endobj
+281 0 obj
+<< /S /GoTo /D (subsection.7.7.1) >>
+endobj
+284 0 obj
+(EOB Token Decode)
+endobj
+285 0 obj
+<< /S /GoTo /D (subsection.7.7.2) >>
+endobj
+288 0 obj
+(Coefficient Token Decode)
+endobj
+289 0 obj
+<< /S /GoTo /D (subsection.7.7.3) >>
+endobj
+292 0 obj
+(DCT Coefficient Decode)
+endobj
+293 0 obj
+<< /S /GoTo /D (section.7.8) >>
+endobj
+296 0 obj
+(Undoing DC Prediction)
+endobj
+297 0 obj
+<< /S /GoTo /D (subsection.7.8.1) >>
+endobj
+300 0 obj
+(Computing the DC Predictor)
+endobj
+301 0 obj
+<< /S /GoTo /D (subsection.7.8.2) >>
+endobj
+304 0 obj
+(Inverting the DC Prediction Process)
+endobj
+305 0 obj
+<< /S /GoTo /D (section.7.9) >>
+endobj
+308 0 obj
+(Reconstruction)
+endobj
+309 0 obj
+<< /S /GoTo /D (subsection.7.9.1) >>
+endobj
+312 0 obj
+(Predictors)
+endobj
+313 0 obj
+<< /S /GoTo /D (subsection.7.9.2) >>
+endobj
+316 0 obj
+(Dequantization)
+endobj
+317 0 obj
+<< /S /GoTo /D (subsection.7.9.3) >>
+endobj
+320 0 obj
+(The Inverse DCT)
+endobj
+321 0 obj
+<< /S /GoTo /D (subsection.7.9.4) >>
+endobj
+324 0 obj
+(The Complete Reconstruction Algorithm)
+endobj
+325 0 obj
+<< /S /GoTo /D (section.7.10) >>
+endobj
+328 0 obj
+(Loop Filtering)
+endobj
+329 0 obj
+<< /S /GoTo /D (subsection.7.10.1) >>
+endobj
+332 0 obj
+(Horizontal Filter)
+endobj
+333 0 obj
+<< /S /GoTo /D (subsection.7.10.2) >>
+endobj
+336 0 obj
+(Vertical Filter)
+endobj
+337 0 obj
+<< /S /GoTo /D (subsection.7.10.3) >>
+endobj
+340 0 obj
+(Complete Loop Filter)
+endobj
+341 0 obj
+<< /S /GoTo /D (section.7.11) >>
+endobj
+344 0 obj
+(Complete Frame Decode)
+endobj
+345 0 obj
+<< /S /GoTo /D (appendix.A) >>
+endobj
+348 0 obj
+(Ogg Bitstream Encapsulation)
+endobj
+349 0 obj
+<< /S /GoTo /D (section.A.1) >>
+endobj
+352 0 obj
+(Overview)
+endobj
+353 0 obj
+<< /S /GoTo /D (subsection.A.1.1) >>
+endobj
+356 0 obj
+(MIME type)
+endobj
+357 0 obj
+<< /S /GoTo /D (section.A.2) >>
+endobj
+360 0 obj
+(Embedding in a logical bitstream)
+endobj
+361 0 obj
+<< /S /GoTo /D (subsection.A.2.1) >>
+endobj
+364 0 obj
+(Headers)
+endobj
+365 0 obj
+<< /S /GoTo /D (subsection.A.2.2) >>
+endobj
+368 0 obj
+(Frame data)
+endobj
+369 0 obj
+<< /S /GoTo /D (subsection.A.2.3) >>
+endobj
+372 0 obj
+(Granule position)
+endobj
+373 0 obj
+<< /S /GoTo /D (section.A.3) >>
+endobj
+376 0 obj
+(Multiplexed stream mapping)
+endobj
+377 0 obj
+<< /S /GoTo /D (subsection.A.3.1) >>
+endobj
+380 0 obj
+(Chained streams)
+endobj
+381 0 obj
+<< /S /GoTo /D (subsection.A.3.2) >>
+endobj
+384 0 obj
+(Grouped streams)
+endobj
+385 0 obj
+<< /S /GoTo /D (appendix.B) >>
+endobj
+388 0 obj
+(VP3)
+endobj
+389 0 obj
+<< /S /GoTo /D (section.B.1) >>
+endobj
+392 0 obj
+(VP3 Compatibility)
+endobj
+393 0 obj
+<< /S /GoTo /D (section.B.2) >>
+endobj
+396 0 obj
+(Loop Filter Limit Values)
+endobj
+397 0 obj
+<< /S /GoTo /D (section.B.3) >>
+endobj
+400 0 obj
+(Quantization Parameters)
+endobj
+401 0 obj
+<< /S /GoTo /D (section.B.4) >>
+endobj
+404 0 obj
+(Huffman Tables)
+endobj
+405 0 obj
+<< /S /GoTo /D (appendix.C) >>
+endobj
+408 0 obj
+(Colophon)
+endobj
+409 0 obj
+<< /S /GoTo /D [410 0 R  /FitH ] >>
+endobj
+412 0 obj <<
+/Length 183       
+/Filter /FlateDecode
+>>
+stream
+xÚuÏ1\ eÂ0\f@ѽ§ð\98H4ØNÒ$+\12 ±\92\ 1    \18 \ 4Ú\81¶ªàþ¤tDLöò\9fe\84\a l\vü3W±XnÈ\ 29Åd\rÄ;0z\85\81ÀX«\ 2k\8878\8aؤ~¼ÈR#\8bý K®DªÛ\13\92©/¯¶ïä9î2T\ 1\91
+Öò\ 4eSg§4Zy]ÍΡ\1d\1aÕ\8f\8f,eb#=\89þÝÝ&C\92ø2 \15U\ eJöÊ\a\9e³}\1a^é)Ù\89k¾íD\1ag\80ÍbZ\9cà\#\86©ÿùq\1d\8b\ feÂ=\8a
+endstream
+endobj
+410 0 obj <<
+/Type /Page
+/Contents 412 0 R
+/Resources 411 0 R
+/MediaBox [0 0 612 792]
+/Parent 417 0 R
+>> endobj
+413 0 obj <<
+/D [410 0 R /FitH 686.127]
+>> endobj
+414 0 obj <<
+/D [410 0 R /FitH 668.127]
+>> endobj
+411 0 obj <<
+/Font << /F15 415 0 R /F16 416 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+420 0 obj <<
+/Length 19        
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppç2ÀA\ 3\0c(\ 5á
+endstream
+endobj
+419 0 obj <<
+/Type /Page
+/Contents 420 0 R
+/Resources 418 0 R
+/MediaBox [0 0 612 792]
+/Parent 417 0 R
+>> endobj
+421 0 obj <<
+/D [419 0 R /FitH 686.127]
+>> endobj
+418 0 obj <<
+/ProcSet [ /PDF ]
+>> endobj
+454 0 obj <<
+/Length 1207      
+/Filter /FlateDecode
+>>
+stream
+xÚå\99Mw\9b8\14\86÷ù\15\ 2ªO\90\96\8d3u;§\99ÉÄÌlÚY\10[u8\83C\ eàtÚ_?\12\12\8a\r´6iNC2+>\84%xîÕ}ï½\86ÞÚ\83Þü\ 4Úãiròê\rå\1e¦aÌcä%\9f<\ 4£\90GÂc1\ f1\13^²ò>\80Yqã\13\ 4ji\ e\95ÿwòë   RS@¯\{æär®ç\12\9e\bE\84#=\15ô\82\b\87(\8eÍ$È\ f\ 4\9d\9a\ 3\83º,ü@\1dWÛe\9d©Ùõ\84í[y\1f\ 2\1cAÎÔ/¾µ\ eßY\ 6ÑPPê\ 5\b\87\18"»V¨VC\10cð×\ 5Q\v\11
\e\1f\81\959O®eQ¦ÝEcAAè\a\f§8P!~àç\9dOA\8cS\8b¯½ÛǨ\r¤¡µÈp\8b,[ÉÂ\80zã«y\8ar\93Z\9bï,!\9e\ 6ÓÔ \11\vm\96§U\95}\84\88.Ó!\8f\8ecüô¸\1e\ 5ó\105|$µûýI-·×UµÝÜjb}\ f\8bÐó£s´£á\91\8eÆZGS[\13\92K½E     XÈz{Û\86¸\95¹wQ\16WéU\96gµ¯\1eýbn\9e·?Ìû[\99ýL`\8fã@\91å¡B\141!Ê|¦ÒªOúòf)»+QH\9e<æü\18&r\0SG\81\83V\e1\ e\89¾¥Ña£Ã3+ÀRû\8cBØF}µÊ¢.\95,oË\1e@\f#.\0{°,c'Ë\8dÕÊt#\8dÑÞ§ÆQq\f\8amݳ\e\8d§i¢G±)\e\15\b°\93é\8bÌبÙú\97r= :\1cò\97H,\1aI¬ÕèÓÜ\84À¥v¶\7fªNÐ\è0ª\ 6di®»OwÞ\84ðiËR\1f\1c\ 1ñÈ(\8b\9dL\9f§ËÒæ\84\86K¬¹Ä\ 3\"\8c_ðf\15#]¯«ÚÙͺ£Æ\95¹¶nH\95vËU6X\14QƦ\9a9C\9d9£ÑÞÕjøÙ,1\1f?3®%U\1e\1d©ü\ 6\81L\95\9c
+S¿ü`\91x1uÇQô\8e\91vb¤ýL.­¸\ewS;ÿ÷;]uËò.ÓTåç\9e²cH      @d´´Û\85\9d°\9bµ\eÏ.]B¦Ë¢õ¶\1c,\8c\18ÅÏ!B\fÚìP:æ)ã\bÔI\82\14«\86\16¢\14Ìs\95¨ç­ï\7f\97\13ahâ     êqH`Ço\9a|F³øc\9bÞhI©³¯\ 6\80\89\93i]fKÙßÿ1{\11\1c\82X\12o·Ê\11\88*av\82¢ÞPWMp4WÅ\80òr1±ºf\90\f=D&ØÝ5-\9d6ë}\9b­¯\83÷òN«\82Ô±,7~²\13w\\rlÒ7Yõ;\vljYÉ )6&¼8P.¸\9cÉFB\8d¤ÚpLm¿ [(Pú\1cKâã(õv\1av1§\83¨ÍÀl\82+W\ 350gÑ4\13Û\aÁéf\15$\ e9ãûY\ 55Y\85k\10\10\vö\8d¶0¦T      :~xë\9eºTbVäEë´·>\ 2ic+é²
+\1d\ 2L\1c°ºá7\96D@wúûõ\1aASÉÿ\8e6\1f\1e×\8d¦.J\1e\8f®¬\9aÖk§\7f¨\87\9e©Õ\ 3ýWCâ'ú0\1eÛ\e¤®à\7f}ç«\9a)Íòô*w\1foɨ\82ÿ6\1dH,(Å\93\8e\81ß#EÇ\v\86\82å\ 4ãÒDCµ\ 6\81\fÐ\18\9eë³\b|\84\fª1{ÿ]ògpi\ 6N\93P=\15Df`ñ¥ª\e\98ëóW¿%\8b\99yòsV_ë\97ó\b
+9Gê\rP(\183ï`çV&içÖm\86$\8c 
+\98Z\1cõ+a>ÕÖþqv\b\1c\86}¿uÂto
+Lcm\8aÓ¹>å;¶ÐW\96\97>½·\85¾jl±©ì\9094Û[\9fÌͬÿ/\9b\1cL\13T%\1aÆ\82ío\ eê\9a­ÿÊüà\7f¢£cdzé}5\b÷û®n\181\16\93\ 6vïÌÙÞ³¿$'ÿ\ 1±¹\8dº
+endstream
+endobj
+453 0 obj <<
+/Type /Page
+/Contents 454 0 R
+/Resources 452 0 R
+/MediaBox [0 0 612 792]
+/Parent 417 0 R
+/Annots [ 422 0 R 423 0 R 424 0 R 425 0 R 426 0 R 427 0 R 428 0 R 429 0 R 430 0 R 431 0 R 432 0 R 433 0 R 434 0 R 435 0 R 436 0 R 437 0 R 438 0 R 439 0 R 440 0 R 441 0 R 442 0 R 443 0 R 444 0 R 445 0 R 446 0 R 447 0 R 448 0 R 459 0 R 449 0 R 460 0 R 450 0 R ]
+>> endobj
+422 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 515.086 185.975 523.997]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.1) >>
+>> endobj
+423 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 502.885 218.672 511.796]
+/Subtype /Link
+/A << /S /GoTo /D (section.1.1) >>
+>> endobj
+424 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 490.685 209.872 499.596]
+/Subtype /Link
+/A << /S /GoTo /D (section.1.2) >>
+>> endobj
+425 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 478.484 203.396 487.395]
+/Subtype /Link
+/A << /S /GoTo /D (section.1.3) >>
+>> endobj
+426 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 464.347 201.515 475.084]
+/Subtype /Link
+/A << /S /GoTo /D (section.1.4) >>
+>> endobj
+427 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 452.146 302.802 462.995]
+/Subtype /Link
+/A << /S /GoTo /D (section.1.5) >>
+>> endobj
+428 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 441.883 238.072 450.794]
+/Subtype /Link
+/A << /S /GoTo /D (section.1.6) >>
+>> endobj
+429 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 419.557 239.725 428.468]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.2) >>
+>> endobj
+430 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 405.419 206.634 416.156]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.1) >>
+>> endobj
+431 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 393.219 210.785 403.956]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.2) >>
+>> endobj
+432 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 381.018 253.791 391.866]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.3) >>
+>> endobj
+433 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 370.755 204.891 379.666]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.4) >>
+>> endobj
+434 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 356.617 276.29 367.466]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.5) >>
+>> endobj
+435 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 346.354 220.914 355.265]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.6) >>
+>> endobj
+436 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 322.09 220.505 332.939]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.3) >>
+>> endobj
+437 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 309.89 244.437 320.738]
+/Subtype /Link
+/A << /S /GoTo /D (section.3.1) >>
+>> endobj
+438 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 297.69 269.579 308.538]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.3.1.1) >>
+>> endobj
+439 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 285.489 275.1 296.227]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.3.1.2) >>
+>> endobj
+440 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 275.226 266.216 284.137]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.3.1.3) >>
+>> endobj
+441 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 261.088 263.615 271.937]
+/Subtype /Link
+/A << /S /GoTo /D (section.3.2) >>
+>> endobj
+442 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 248.888 241.42 259.736]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.3.2.1) >>
+>> endobj
+443 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 238.625 256.807 247.536]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.3.2.2) >>
+>> endobj
+444 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 216.298 196.61 225.209]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.4) >>
+>> endobj
+445 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 202.161 254.289 213.009]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.1) >>
+>> endobj
+446 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 189.96 324.913 200.809]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.2) >>
+>> endobj
+447 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 177.76 245.433 188.608]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.3) >>
+>> endobj
+448 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 165.006 451.577 176.961]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.1) >>
+>> endobj
+459 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 153.051 276.262 165.006]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.1) >>
+>> endobj
+449 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 140.85 451.577 152.806]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.2) >>
+>> endobj
+460 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 128.895 276.262 140.85]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.2) >>
+>> endobj
+450 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 119.186 206.69 128.097]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.4) >>
+>> endobj
+456 0 obj <<
+/D [453 0 R /FitH 538.408]
+>> endobj
+452 0 obj <<
+/Font << /F48 455 0 R /F49 457 0 R /F8 458 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+506 0 obj <<
+/Length 1409      
+/Filter /FlateDecode
+>>
+stream
+xÚí\9a]s\9bF\14\86ïý+¸\84\v\bû½\9b»Z\91\93tì8µÔv¦i/\88´\91\19Kà"ä¤ýõ]Ø\ 5! F¢²\8d:\9dÌÈXÑ°Þ\87sÞó\9e³ò­\85å[oÏΧg¯.¸%<A!µ¦_,@}\8fRfQN=\0\995\9d[\9fì0tþ\98þøê\82¡Ê'!g\1e\0\Ý&ÿÌèúÃtüa:É>yæ\9bÛ\ 3õê[ÉÂÒ\177ok«¹\10\v\ f\12¡.\98z\13é[a\ f{Àq\ 1ÀØƯÕ?ÇE\bÛ\93Íçu°º_\86Ñbg\11ë\93Ë        ±=Ç%¾\7f\84\1fX\88£Ý¬öw\ 2\9fc\e²\ eFêÕ\ 5Ðó\ 5Øò\80%\ fø\1aþÏÃC\15\1eþ\7f\8c\aïÁ\ 3\e\1eU\b9\95 \9ag\17ÈNo¥¾ø\18ÎÒMb~¹\91\8b0\8eê\7f\a\16ðØLZw*:Õ\ 2\8bª\ æñ\- §6«wO\1cW@b\9f\87é}0s\10´ïôÞÕýGjgê\8d\87ìEæ\97iËf¡\8f\11ÊßïR,\80=¡VÞáOrµò!´¯\1f\1cÈm\99<\84òk}\19\ 1\87\16|O\17Â\ 6æ#!¬\9e \0¤Á±ÔýëY*Óu-\84ÏÿJåº\11«\98\r\8cÈîCêÇÇo¢)JÀ¯\ eGv\9cÌ×\1a\8a¡\83s:ú­ëd.\93úÂÙ\7f<ÿî\8f\182-H\8a\92_3hÝ9Ý;BN$»p\17*·=½ \91©Qì¸J§æ¦H \8c\9fɵ0Ê\14,\8d\1fI8ÄÑÐ\12n?rh\ f\ 1WêÒ$\Dr\1eÉõº¹\0`Ã4\19Ç\8f/¿     ¨P§q4«G×ø[æHd}-Bè0\13±\95   éÁ¤\90§7ro&j©ÓÑ!Ú\83        .ãdîÆ_Ü\8f\99Ü(ß\ 6\99}\97{§Tóùa©\12m%µ\1a5ì<\ 5\ 3#Áz\90 \86Ä\8d\fæ¥]ÿM&q©Éúâ}\94ÑIåB&\rÑ!\f\ eL;Ø\11,=--ý:Md°rò\9aóNqjA\0afõ\91èmßiißGñj¥ú\83üAèÕô\13Øæo#a\11\19¶©h}FâÀh¥¥sx?7)\19þî\ 3<\vò~ê\10^\9c\fºôaÿ`4¨\12<R§ª¦`\88¼p»òÔÓ
+LúX*\85­´T98um\e±Ïá]Êh\91Þv\86\13#\ 3kc0=<\80JïÔJbÏÄb\b\rKe0ëA¢pL?¯õ\96q\99V%\8f\vÝþ®\82\86-\80|Ðv ó^m\eÍ-S¦0\13\99nîwÔ¶Ñè\82¡L=\9e\82\9fè§4ÛÃ\84K\9d<ñ½\89¤p\99\16av\19®
+¿5Í\ 2,ø¼\94\9d9\a\19y\96òÕ\8f\86ß\ 4Q\bÍO\9bÀ\94ñ¿3¹QeÜ\ 1vQɵ%O\82\95L3»Õ\ 5\81`üü¹Dü\1e»G[\99½ß¤Û       ¹Þb\85Iik\90}\15¤Iø­!¶@<çfQ\8fÍ\16\9bÑToS\855¶ã»Ì H³¹w\eåâÐ*\88j\81ßôØ\84\ fd\82Ch\ f\16E§Õ\14Юà\16\90\r¹¤\10þoº-¢ 1Ým]8\82ÚYÖë³\13\r\ 5Á6ÙÃTa¡ wÇÅÊ\8e+/æfÑ\1d¯S\1d\9a(mjÚ\1dÆ\a6çßû¡\19\870+Û¯\9bMän\9d1¶Ç
+M9o\93Å9@QÈ&Jº¢E#\99)\1d\98S¤½N\8bXe*{\19G\vWÁi\ 5ÐÝ\93rúâ1\81\ e\8f\89²\9aOnã$í¿}ÊÈK[;JzYcVi¾«9\80ìó¥~c\96Uô;Íåb\19,ºí\fð\ 1>\81\19\ e¥\a\aLÑF\\ 53=cÄ\ 6\13³Íü5gÓ8\1cº*P5§\8f\ 2\9f\82Þò\83Q\91\ 2U¼u\82¿d¥JÎÒ¸9\82¤\88\ eûD¬\1f8\ 6úé2)uyË\ fgü°æ·O}'H\fù \91\1d^ÃI©×\1d   Ø\1et{T1ô\1cÂÃPO©¦&§v¥YÙ\99\87¼%Y\9a¯\18ú\15ïȨÇ\99(¾aø§ù\16â\8e»\ 4\9e`¸øÄcE\8e\80a\1e¬íA¼³ÓWÏ^ÙzT'Î\fñ²\ 5\1cé`\93ªëË\9e\86=\vÍd­©ìT\9c\82jíÍ\90÷´\98¬\94²ñõùwûèÇ\1aHt
+ßGâ\87ÛOV\99Zç{Ï£JGTy\ 4\92O\14b}°ÛÍ\8a\ 31,\95ç¤\a\16T\1f¼4ù\94³ìG``\ 6\a\19*b7Tê?ÇÓ³\7f\0Yla!
+endstream
+endobj
+505 0 obj <<
+/Type /Page
+/Contents 506 0 R
+/Resources 504 0 R
+/MediaBox [0 0 612 792]
+/Parent 417 0 R
+/Annots [ 451 0 R 461 0 R 462 0 R 463 0 R 464 0 R 465 0 R 466 0 R 467 0 R 468 0 R 469 0 R 470 0 R 471 0 R 472 0 R 473 0 R 474 0 R 475 0 R 476 0 R 477 0 R 478 0 R 479 0 R 480 0 R 481 0 R 482 0 R 483 0 R 484 0 R 485 0 R 486 0 R 487 0 R 488 0 R 489 0 R 490 0 R 491 0 R 492 0 R 493 0 R 494 0 R 495 0 R 496 0 R 497 0 R 498 0 R 499 0 R 500 0 R 501 0 R 502 0 R ]
+>> endobj
+451 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 655.231 310.606 666.079]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.4.1) >>
+>> endobj
+461 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 643.14 310.606 653.988]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.4.2) >>
+>> endobj
+462 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 631.049 310.606 641.897]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.4.3) >>
+>> endobj
+463 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 618.958 391.718 629.806]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.4.4) >>
+>> endobj
+464 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [159.671 596.814 291.053 607.662]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.5) >>
+>> endobj
+465 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 586.66 240.23 595.46]
+/Subtype /Link
+/A << /S /GoTo /D (section.5.1) >>
+>> endobj
+466 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 572.632 306.925 583.48]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.1.1) >>
+>> endobj
+467 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 560.541 331.306 571.389]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.1.2) >>
+>> endobj
+468 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 550.387 273.937 559.298]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.1.3) >>
+>> endobj
+469 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 536.359 299.813 547.207]
+/Subtype /Link
+/A << /S /GoTo /D (section.5.2) >>
+>> endobj
+470 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 524.268 278.005 535.116]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.2.1) >>
+>> endobj
+471 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 512.176 313.594 523.025]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.2.2) >>
+>> endobj
+472 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 500.085 313.318 510.934]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.2.3) >>
+>> endobj
+473 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 487.994 341.545 498.843]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.2.4) >>
+>> endobj
+474 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 475.903 344.423 486.752]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.5.2.5) >>
+>> endobj
+475 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [159.671 455.696 270.916 464.607]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.6) >>
+>> endobj
+476 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 443.605 307.893 452.516]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.1) >>
+>> endobj
+477 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 431.514 326.158 440.425]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.2) >>
+>> endobj
+478 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 419.423 275.93 428.334]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.3) >>
+>> endobj
+479 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 405.395 342.652 416.243]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.3.1) >>
+>> endobj
+480 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 395.241 342.818 404.152]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.3.2) >>
+>> endobj
+481 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 383.15 331.831 391.951]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.3.3) >>
+>> endobj
+482 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 369.122 258.495 379.97]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.4) >>
+>> endobj
+483 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 357.031 370.63 367.879]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.1) >>
+>> endobj
+484 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 344.94 375.695 355.788]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.2) >>
+>> endobj
+485 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 332.849 381.7 343.586]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.3) >>
+>> endobj
+486 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 322.695 355.299 331.606]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.4) >>
+>> endobj
+487 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 308.667 325.383 319.515]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.5) >>
+>> endobj
+488 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [159.671 288.46 248.56 297.371]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.7) >>
+>> endobj
+489 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 276.369 295.883 285.28]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.1) >>
+>> endobj
+490 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 262.341 343.51 273.189]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.2) >>
+>> endobj
+491 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 250.25 356.793 261.098]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.1) >>
+>> endobj
+492 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 238.159 358.897 249.007]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.2) >>
+>> endobj
+493 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 226.068 316.777 236.916]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.3) >>
+>> endobj
+494 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 213.977 320.956 224.825]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.4) >>
+>> endobj
+495 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 203.823 266.299 212.623]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.5) >>
+>> endobj
+496 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 191.732 329.258 200.643]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+497 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 179.641 387.816 188.552]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.2) >>
+>> endobj
+498 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 165.612 297.147 176.461]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.6) >>
+>> endobj
+499 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [174.615 155.459 274.712 164.37]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.7) >>
+>> endobj
+500 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 143.368 317.607 152.279]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.1) >>
+>> endobj
+501 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 131.277 341.96 140.188]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.2) >>
+>> endobj
+502 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [197.529 119.186 337.671 128.097]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.3) >>
+>> endobj
+504 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+539 0 obj <<
+/Length 1090      
+/Filter /FlateDecode
+>>
+stream
+xÚÝ\99Aw\9b8\10Çïù\14\1cá\0\914BHÇر\93îk\9an\97Í¥Ý\ 3±Y\87÷°ñbÜÝöÓï\b\81ã\0­cºMð^\föÃ\12ü4ó\9fÿ\bb-,b]\9d\8d³ói\0\96ò\94
+ÿ´(\11\9e\14Ê\12Rx\94\ 5V8·>ÚãÛwáä]ø\9bóGøËùTî]\ eà{\9c(\1c¬¼0I\12\19©Æ§øI¬|a\99\93\ fWg\96\v\8cx\ø\96Ë\ 2\1c\ 6Ì\1f\ 3O:.%\8cÙ¿¯æY²Z8.\0Ø\97c}äöû<\9e'³"ÉVO\86·>ºR\80í9®OÈ0\ f\8dÛ¥D\82­Ä!H\8cy\8arË¥ÔS¾¿CäQ\84D9·ÇÙ\12ÏìµCímQÑâvñ\10ïc\83\1a[\967oC\0¼.\ 4þ\f\b¤ýü¬zþ7+\87\ 5ög\87I;Î\8b]¸4\0<\89\9b
+Hæ¸ø§Y¼Ù¼\0\93Æ\f>®=%ä`\86t¯¾ª\12äC<ËV\9b"ßvæC è@ó\81\93\1aGj¬_ʨ]Êìr¡µð\9c\a\83\96\90£#\8c\1d\9dYj\97Y\97ñ_̮ۨ"ù\1auE\98¯\82>«úêdt\14\ 5Ï%#\1eÉ@E&4âbÄGÖ⳩~¼\1c\87Í)A\88Aç`'!Õ#vx\93\10\96§u\1a\17\95\187\ 4«¼â"]dyR<`\ 1[6oD\ 5þ\7f¼îTöÔ\JpXÔÜ·¦ldkóDÓ$-â\\97\9dÆlÌ\87\97\17N\1fæ÷\13aJ´
+\v\8c\90k\ô¯\99\91\97\87Ùªc\84\9d\96ðj>Ç[\1a\f\9a;\aµ[\9b\99Ù÷Á\0å'^ËÙñ*\8c\98À`Ús¾µÂðîôlu
+R\f%\e;©¨¾\1aE\8d\8b.·§\ e\ e\9aG˺<¡\ 6\97\8cæqËþ\ 4üä,\ e\1c²8çS®öÚT\97rOqDÇ\10\1d\95\ 6Ý\ 5F\14Pûv¡»\a\1cu\94\14X¥âhi¾NV³h½Ù¦\9d&\88
+\ e\ 2ïÃ,Z×üû]r=ûþÂ]hM\f\ 2fßVNâs\12ÿÝ*\85ìä\vɳ\13\0T\9fê\82\185H©¸}óæfR5Â\9aè\97u\19ð­x÷\85\1a\8a:þl`n71f\ 2o²Ô\98î\r¥ù|×E'\95G\8bÌ×4[<Ö¤û]\8e\bÔë\95\9e.:\9cô\v'V\87Óu\1cÍãv·(|õ\7f̾øH\9b\143¤¦ÚºÔµ\ 6ìyTD-j\81\1c´Où       \9cÄ#'0\9c®rÓYoÓ\8a\94Q¨l\93tîä\0?¹ö\91\93\9e\92\ 4F\92n¶i\91 \8bù'\9e\e\82\8c0\96ÑzÝÑs)N\87lU8í§CPëÐø!JV\86\a¯xlÚ±"\ 6í\f:c\85\1e­8P+ÎU\9em«ò^\a\8aî
+\8a\1cÛ\82X\9fu0ò\81\9e\9cÏ=Ȩés!ð¤/\9fúÜ\11ú\Éì»÷ÐÚ®P\84û8\vôv±£2J±%Õ£\97\v¡Û\10´Ì÷I\9a\18\eÖz°\1fÚÞ\19P\1fËáÈ\0\1e\95áK¿Õ¯\96ço\93%r+sýN·pQº\8d\fÜ?=\83Á\8f¦\ 5\86Ö¯å\86´|Ü\906¯rt%\8dtÂGå\8e\0v¾m³Æ|yzºÈ\8ft\18\ 1«A]o?\11
+˨"\14j[\16ݧíøáT\9cì\e\8fï©¥ÿ#»\ 2õ»nTKì\10ÇY\9a­\1fÚ®\8c        ®\17I>Ýê\8f\93ðì_.~Q§
+endstream
+endobj
+538 0 obj <<
+/Type /Page
+/Contents 539 0 R
+/Resources 537 0 R
+/MediaBox [0 0 612 792]
+/Parent 417 0 R
+/Annots [ 503 0 R 509 0 R 510 0 R 511 0 R 512 0 R 513 0 R 514 0 R 515 0 R 516 0 R 517 0 R 518 0 R 519 0 R 520 0 R 521 0 R 522 0 R 523 0 R 524 0 R 525 0 R 526 0 R 527 0 R 528 0 R 529 0 R 530 0 R 531 0 R 532 0 R 533 0 R 534 0 R 535 0 R 536 0 R ]
+>> endobj
+503 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 655.231 248.976 666.079]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.8) >>
+>> endobj
+509 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 643.276 305.514 654.124]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.8.1) >>
+>> endobj
+510 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 631.321 336.508 642.169]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.8.2) >>
+>> endobj
+511 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 621.303 211.256 630.103]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.9) >>
+>> endobj
+512 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 609.347 222.132 618.258]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.1) >>
+>> endobj
+513 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 595.455 243.883 606.193]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.2) >>
+>> endobj
+514 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 585.437 253.929 594.348]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.3) >>
+>> endobj
+515 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 571.545 356.351 582.393]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.4) >>
+>> endobj
+516 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 559.59 208.571 570.438]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.10) >>
+>> endobj
+517 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 549.572 250.581 558.483]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.1) >>
+>> endobj
+518 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 537.616 238.957 546.527]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.2) >>
+>> endobj
+519 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 523.724 272 534.572]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.3) >>
+>> endobj
+520 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 511.769 252.85 522.617]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.11) >>
+>> endobj
+521 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 489.851 270.646 500.699]
+/Subtype /Link
+/A << /S /GoTo /D (appendix.A) >>
+>> endobj
+522 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 479.833 186.432 488.633]
+/Subtype /Link
+/A << /S /GoTo /D (section.A.1) >>
+>> endobj
+523 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 465.941 228.663 476.678]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.A.1.1) >>
+>> endobj
+524 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 453.986 290.957 464.834]
+/Subtype /Link
+/A << /S /GoTo /D (section.A.2) >>
+>> endobj
+525 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 443.968 212.28 452.879]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.A.2.1) >>
+>> endobj
+526 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 432.012 227.583 440.923]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.A.2.2) >>
+>> endobj
+527 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 418.12 250.262 428.968]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.A.2.3) >>
+>> endobj
+528 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 406.165 271.447 417.013]
+/Subtype /Link
+/A << /S /GoTo /D (section.A.3) >>
+>> endobj
+529 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 396.147 250.248 405.058]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.A.3.1) >>
+>> endobj
+530 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [143.731 382.255 252.282 393.103]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.A.3.2) >>
+>> endobj
+531 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 362.274 145.032 371.102]
+/Subtype /Link
+/A << /S /GoTo /D (appendix.B) >>
+>> endobj
+532 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 348.382 228.607 359.23]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.1) >>
+>> endobj
+533 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 336.426 254.151 347.275]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.2) >>
+>> endobj
+534 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 324.471 255.008 335.209]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.3) >>
+>> endobj
+535 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 314.453 214.687 323.364]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.4) >>
+>> endobj
+536 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 290.598 170.547 301.446]
+/Subtype /Link
+/A << /S /GoTo /D (appendix.C) >>
+>> endobj
+540 0 obj <<
+/D [538 0 R /FitH 686.127]
+>> endobj
+537 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+543 0 obj <<
+/Length 96        
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppçr
+áÒw³P°Ô³432S\bIS043Ð333W0³0Ó342W\bIQ\88ÖÈ,Ó\8c\rñÒw37FRida®ghh\ 14\ 6¬ÆÙß/ÄÕ/$\18¤\92Ë\0j<:í\1aÂ\ 5\0jm\1a¢
+endstream
+endobj
+542 0 obj <<
+/Type /Page
+/Contents 543 0 R
+/Resources 541 0 R
+/MediaBox [0 0 612 792]
+/Parent 417 0 R
+>> endobj
+544 0 obj <<
+/D [542 0 R /FitH 686.127]
+>> endobj
+541 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+570 0 obj <<
+/Length 1117      
+/Filter /FlateDecode
+>>
+stream
+xÚÝXI\93\9b:\10¾Ï¯à\88\ f\10I\bIäø\92x\92WsH%>e90\ 6;ÔÃà\ 2<Y~}Z\eÆÀ\8cÍlñK¹
+\84ÜH꯿Þ@ÎÚAÎå\ 5\7f\16\17/æT8\84ú\pì,V\ e\17,rB.|Ê\ 2g\918\9fÝ«¬nf^ÀC·\éû<[華\9e}]ü{\81a-äTkG\ f>\¢Â\89ü\88\11¦\96¤~D©ã1ìs&ô\8aÄÇ3\ f#BÜ«ræ\11á.ã&+\vX<\bô&\ 1uWU¼IõT\$z°Í\96\rì¬\ 5ª\19va\88ݵ|\17»ú<V;ç³\17\85Èõg^\88\9eøÖÛ\16\87\82ºì`v\b\12\=\8cý(\f-$Ä@òqw­0I²\9b¬î¡\ 2P\fÀÉ\8a\19H7¥þã:\97\88rw9\83Ë\7fu\ f¿z·Uk§\95~ÖÒBJ\v)ÝÓ$Àø±ðà\93ñ\b\f\1e\1fâºÑç¥nY%i\95\15ë\16\13XôÅ\1cã.ßPè\a"\80õÔ:\85\11¡\1d\11áã\88Z\81/\b\91\91eÔÈÊl´À\ 1­\89\8fÀQ\8cÀ1\1cÁ\16ÏAÄÞ\8dFÑÝF\11Ç\8câá ô\19\12Æ6ÌÚ\86\1aÛ¼ÍòkC¨FÛd¹«n$\bé-\ 6\e¥\9d\12ý\9e5ß²¢Ãòctí«DÅÃi\1aM¦iø(n»\89\97Uy\9aOÂ^ÏJ\14\ 4°`4\19\17ö0\8a´\80Ü\12Ò\ 6\86-ܵÁâð½¾^¡\10G\19qOÕ¹QýÍ\8fx³Í­\9aF±*]¥UZ,\r\r\14#\8c\a¬ÊÊÆë\ 3\8eX\854{z\87\14"|ü\f¦\14Ç\93\15\17FñOÙÚû\15¯;öíïÀù\1f\89\88\ fó\8cÓ¡#'@G\0:l
+"Ú\16Dï³\1finø\0\fNÒDÏÐ\97ð\e0\0G\7fNýG¡\1a\99Z\1dжZ:\86\17yIþB¼Äd¼\82\93ñB\7f!^'§ufñ¢]¼\0\1c\82ÜeYAÓ£+\92²HL\f\87?®uÚid\9eù®2[ZØWr\15Ó\ 1Ám\1e\17*ÐôL^z\94êLhÄ÷í\r<\94_\10\ e<yp\87\10\b\15ôФuÚ\1c\14÷´»V¿Uª³_\83ÄA#|ÖÑvÌ\90ÁÑdì\8daEÛ*Í\9a\13\9b\93wÌi
+Q\8da\17Q
+\88B\93¹\94\r\83\91ÅVÙih\rãY\89}WZC7¬£\ 6éæF\f\8aâÉ\1eÎ®5\93a\7f\1d\1c(F÷=ä\1doÜ¥\15\9c\rÝG-þLjõmý\ 4öêf|ÖfüWåfS\9amߦqb\9b\9d÷ò<±iut|QóW±\9cú)/å®\19´\a\8c\9e§çNí¬X\9bâß\81\85U\1d\9c\81åèþSÑQ¸úÐÐèÌ\ 2Þ\18P\94L\ 6Êæö«´Xk\a\18Ëíu³ï²ò;9Ä\19>_\84\ 2\97²\89Ù\9cµÙ\ú\9a$\13w\8d3u\19Ô:\16\1f\ 3%bgÚ£\8c\92\88O&Qû\1d#md\1f­Á\91É.NìwV\83\13\10i§ãé`k\1cýïzµ\10M\8cܼ\8dÜ\1f³u\11ç\1a\94y^êòO=]VñÖd"ÓÔS\17<³M'øµþó\9d
+l7*^UµIP¯_-\ 6\1e\13Ó&T\1dÿÔôÌ÷_­\1f\8cÅ|\ 6¾]Vª\80\8e«äV,"Á\9f\16\ 4>\19\ 4\e\80\17ß\8cNæËS¹Õ\8f2oå\8d\8d3\9d\9a|µ+\96\rOÄÉÙ¸\8bB\87\84ãe\10\ e¡'\17\81D\86ù"ä\1a\9a\9b\ 3á7\8b\8bßJù³\1e
+endstream
+endobj
+569 0 obj <<
+/Type /Page
+/Contents 570 0 R
+/Resources 568 0 R
+/MediaBox [0 0 612 792]
+/Parent 576 0 R
+/Annots [ 545 0 R 546 0 R 547 0 R 548 0 R 549 0 R 550 0 R 551 0 R 552 0 R 553 0 R 554 0 R 555 0 R 556 0 R 575 0 R 557 0 R 558 0 R 559 0 R 560 0 R 561 0 R 562 0 R 563 0 R 564 0 R 565 0 R 566 0 R 567 0 R ]
+>> endobj
+545 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 513.761 310.107 524.61]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.1) >>
+>> endobj
+546 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 501.806 370.714 512.654]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.2) >>
+>> endobj
+547 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 489.851 285.316 500.699]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.3) >>
+>> endobj
+548 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 477.896 376.774 488.744]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.4) >>
+>> endobj
+549 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 467.878 324.111 476.789]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.5) >>
+>> endobj
+550 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 453.986 406.69 464.834]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.6) >>
+>> endobj
+551 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 442.03 349.488 452.879]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.7) >>
+>> endobj
+552 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 430.075 203.341 440.923]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.8) >>
+>> endobj
+553 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 410.095 233.921 419.006]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.1) >>
+>> endobj
+554 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 398.139 233.921 407.051]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.2) >>
+>> endobj
+555 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 386.184 233.921 395.095]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.3) >>
+>> endobj
+556 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 372.292 451.577 383.14]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.4) >>
+>> endobj
+575 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [105.873 360.337 252.684 371.185]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.4) >>
+>> endobj
+557 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 348.382 434.502 359.23]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.5) >>
+>> endobj
+558 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 336.426 431.458 347.275]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.6) >>
+>> endobj
+559 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 324.471 434.502 335.32]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.7) >>
+>> endobj
+560 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 302.553 284.952 313.402]
+/Subtype /Link
+/A << /S /GoTo /D (figure.6.1) >>
+>> endobj
+561 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 292.535 269.593 301.447]
+/Subtype /Link
+/A << /S /GoTo /D (figure.6.2) >>
+>> endobj
+562 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 278.643 273.246 289.491]
+/Subtype /Link
+/A << /S /GoTo /D (figure.6.3) >>
+>> endobj
+563 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 266.688 255.756 277.536]
+/Subtype /Link
+/A << /S /GoTo /D (figure.6.4) >>
+>> endobj
+564 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 254.733 247.426 265.581]
+/Subtype /Link
+/A << /S /GoTo /D (figure.6.5) >>
+>> endobj
+565 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 232.815 335.36 243.663]
+/Subtype /Link
+/A << /S /GoTo /D (figure.7.1) >>
+>> endobj
+566 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 220.86 340.729 231.708]
+/Subtype /Link
+/A << /S /GoTo /D (figure.7.2) >>
+>> endobj
+567 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 208.905 290.625 219.753]
+/Subtype /Link
+/A << /S /GoTo /D (figure.7.3) >>
+>> endobj
+571 0 obj <<
+/D [569 0 R /FitH 686.127]
+>> endobj
+572 0 obj <<
+/D [569 0 R /FitH 533.793]
+>> endobj
+568 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F11 573 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+602 0 obj <<
+/Length 110       
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppçr
+áÒw³P°Ô³432S\bIS043Ð333W0³0Ó342W\bIQ\88Ö(ËÔ\8c\rñÒw37FRidjªgdd\ 24\ 6¬ÆÇ38DS×ØØXÃß\rD\9bh¸yº\87\ 6¹\ 6\83´r\19@íC§]C¸\0\1eB
+endstream
+endobj
+601 0 obj <<
+/Type /Page
+/Contents 602 0 R
+/Resources 600 0 R
+/MediaBox [0 0 612 792]
+/Parent 576 0 R
+>> endobj
+603 0 obj <<
+/D [601 0 R /FitH 686.127]
+>> endobj
+600 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+630 0 obj <<
+/Length 1137      
+/Filter /FlateDecode
+>>
+stream
+xÚÕ\99ÏWÛ8\10Çïü\15\87¨ú-ùX(ÐÝ\a»,ÉÛ\1eº{0\89\88m\9eãðJÿúJ\96ì&¶Yb6\94pÁ¶¬È\9e\8fg¾3#`0\ f`p~\ 4ýñxrôá\8cÊ\0S ¤@Áä6@\90\ 3Éã\80          ('Ád\16|\r/ôª\8cFD°0¿uÇI\14Ó0¹YªUôïä÷#d\96\83A1\ fÜÉõ¹YW\ 61\889æÕª\14Ä\94\ 6#\8e\80àÒ-\8a\ 1\8aF\bb\1c\9eä˼0ë\12\1a^-#\14&\99rW¿e3=õ\8f¨ß9ø:"\94\86 \1a1\b\ fæ@ãø\99)-\e\10\934d[£]\88æï\b#\10#\8f\8c4ÈþZ'Y\84eXêïI©óÌñ\9aØ¡Çûhd\ e\15Bò$B\8eÞ\ eÅ\10LÐ`Bt 'ÚpºVSàØP\ 1/\1d\92+K))\92T\95ªè\90aæW\aæ\»q"!ÞÅ\9f\90áÄXÍ ÷q:>ß\ 5\94ÀôW:Æ^<  ó\81\9eÄ\ 1ñ\84N«x[§ªHJ5s¬¼.\1aT\95.\9aã\86\94\8dï\93\9eÀãæ;\1dTpQ:Ði8 \83\90\éojén\9e\81y\91&e\87Küz\8240\8a(\e\f\84\7f¬SKäÆ       °÷\83\9aÃxm\85YXaFaáÆ\8e\97y5wj\7fv·r\83·µ\a©¤\1a_´8\12Ë\918\8e\9d \94¯\149/ Âw¡²w\ 2\8c\90wá3HFU®¹Ô\99N]\1c9\9bûR;      ÿ¶\ 6'ËuWQbÄ\ f2\e±¡Z+\1a­­¾®Í;ÎvSÖ\88ðÑ\14\86\e\95\rµDh?\11ú®
+Ãÿ\b:\8e\aº\95\0Â#ü¼þ\a"\92&¾2<É+í\99©\95»ö\11\8b<\9b»³ëµ\9f{¡²y¹èf.\81Þ,oó\9d\93\14¯A äâkW\10ãE^\94½$\8cãu]\8c¿!\f>Ø+\1a±I¦EîlsÂ+¬ð\8að®®^ª\0\9béÚ'.ý@7ÆXL\ f¼Á²¨\ 4\1c\8e*Þ      UCÆ{\8fËS*íQ#I\ e¾wx\11)L\86EØeÞJgjZÖ÷NòÔ\89{\9e)\97ýºúcFÿ·Ëô\99.Ñ`Ó\897ýôÏãºó¶\95í\9d}så9\8c×i\9a\14\8f¯R¡½M4I:\1c\94\17\1e¯,Êx
+\9fjÿ\89\84GG\9eBÇy|`èz)\89Á¹\8aâÞHªÈØM6wy^ä¦\85èKFP¼×-\8b\98\rv)Ê\1d¬ku«
+\95MÕFoikƶì\9c\10?Õɧ8ê\84ÜÊUûý°$¿^\86c9\9c\87p<¾T\92ªç\v/\9f\95ñIæûòOúA¯òb»ÁòpDÝ`\8dU«wÿø\101\16&zY{! ?\9dø\9d\89EÕËÎÌ\99¶RÞÝe\94\8aÝÿDpxÖáÌ\99\8bøèF{    ùxoã¤kcÊ7\9dVmÓjÛ\92±ÎjÏðLlÒYU£m\99¡â\95u¢²\1d½ ¸g½®\7fµL¼qä§qcýýéP0\ fþp&àæ\ e½$@`i\9eY=«0BDÝ´Ö>>b¤\9ed\9fÕ³R\f\88\9cû¥Þ2³µ\9e\ 4\98ÕS÷\1dP\15eS¤<Cy\84    \ 3\fâ6lÙÀ\9e\1ao*\8bõ´ÙäÚ\ap\f    \88\91\13\a\10Å{\ 3õ\f6\12"\82\9eÇ\86!\80\90µs\99ôõó\17=+\17-\11úÜÈÓfp\1aQ^\14&~óÔªIâ÷z6\1078+¹\19¾%$\11ÚÍèmñmn#\86\0CÖRûϱ\98:S\1fôö\17;\9d\1cý\0^ɾd
+endstream
+endobj
+629 0 obj <<
+/Type /Page
+/Contents 630 0 R
+/Resources 628 0 R
+/MediaBox [0 0 612 792]
+/Parent 576 0 R
+/Annots [ 604 0 R 605 0 R 606 0 R 607 0 R 608 0 R 609 0 R 610 0 R 611 0 R 612 0 R 613 0 R 614 0 R 615 0 R 616 0 R 617 0 R 618 0 R 619 0 R 620 0 R 621 0 R 622 0 R 623 0 R 624 0 R 625 0 R 626 0 R 627 0 R ]
+>> endobj
+604 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 515.699 230.904 524.61]
+/Subtype /Link
+/A << /S /GoTo /D (table.2.1) >>
+>> endobj
+605 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 491.844 261.733 502.692]
+/Subtype /Link
+/A << /S /GoTo /D (table.3.1) >>
+>> endobj
+606 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 471.863 244.631 480.663]
+/Subtype /Link
+/A << /S /GoTo /D (table.4.1) >>
+>> endobj
+607 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 459.908 250.373 468.708]
+/Subtype /Link
+/A << /S /GoTo /D (table.4.2) >>
+>> endobj
+608 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 436.053 289.518 446.901]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.3) >>
+>> endobj
+609 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 426.035 294.499 434.946]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.4) >>
+>> endobj
+610 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 412.143 350.539 422.991]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.5) >>
+>> endobj
+611 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 402.125 322.007 411.036]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.6) >>
+>> endobj
+612 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 388.232 279.445 399.08]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.18) >>
+>> endobj
+613 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 366.314 230.351 377.163]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.3) >>
+>> endobj
+614 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 354.359 312.875 365.207]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.7) >>
+>> endobj
+615 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 342.404 314.978 353.252]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.11) >>
+>> endobj
+616 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 330.449 267.157 341.297]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.18) >>
+>> endobj
+617 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 320.431 268.264 329.342]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.19) >>
+>> endobj
+618 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 306.539 352.061 317.387]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.23) >>
+>> endobj
+619 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 294.583 242.057 305.432]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.33) >>
+>> endobj
+620 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 282.628 266.41 293.476]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.38) >>
+>> endobj
+621 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 270.673 245.779 281.521]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.42) >>
+>> endobj
+622 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 258.718 324.498 269.566]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+623 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 246.763 416.431 257.611]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.47) >>
+>> endobj
+624 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 234.808 336.37 245.656]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.65) >>
+>> endobj
+625 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 222.852 351.77 233.701]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.75) >>
+>> endobj
+626 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 210.897 338.503 221.745]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.85) >>
+>> endobj
+627 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [120.817 198.942 404.476 209.79]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.89) >>
+>> endobj
+631 0 obj <<
+/D [629 0 R /FitH 686.127]
+>> endobj
+632 0 obj <<
+/D [629 0 R /FitH 538.613]
+>> endobj
+628 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+659 0 obj <<
+/Length 114       
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppçr
+áÒw³P°Ô³432S\bIS043Ð333W0³0Ó342W\bIQ\88Ö(ËÌÌÔ\8c\rñÒw37FRk\ 4Tkad\ 14\b¬ÊÇ38DS×ØØXÃß\rD\9bh\84hZ\98h8:ù¸\ 6\83ts\19@-E§]C¸\0     \84\1f}
+endstream
+endobj
+658 0 obj <<
+/Type /Page
+/Contents 659 0 R
+/Resources 657 0 R
+/MediaBox [0 0 612 792]
+/Parent 576 0 R
+>> endobj
+660 0 obj <<
+/D [658 0 R /FitH 686.127]
+>> endobj
+657 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+663 0 obj <<
+/Length 1819      
+/Filter /FlateDecode
+>>
+stream
+xÚÍXKoÜ6\10¾ûWè¨\ 5²\f)\92\12\95\87¶Hú\0Z ¨\81\1eâ\1ch\89^+ÕJ\8e¤uìþúÎp(YÚÕºI\8b\0½x)>æñÍÇ\99¡y´\8bxôÃ\ 5\ f¿ß]^¼|£L\94(\96\99LD\977\91à)3i\1eé,cy\96E\97eô6þµ\1dìPµÍf+3\1dÛ¦¤Á÷0#E|\8f\7f\1c\f\93\18\9bw\97?¿|c¢\9cåi\92¢P\1emuÂ\92<!qßÖõf«´\8aïlg÷np\9b­\88»\8d\88{\9cÖ±«\86\8d[z\í]IßUC¿mG{ÛÃ\10&nhÂÒgé\8av³ML\VÍ\8eVî@CG\93\85+\ f\9d\v\ah â]u¿\815×Ð<hò\8e¨|é\89\10,×)yr\r@$q[# RÆ7¶p§Þ+ÅÒ\ÂQ\7f\84á\86h\9bä,\ 3É[\91\ 4-]Þ\82%\892ñ]箸P\ f$+Ssa)ËR1
+»>Õ\96±\8cOʪ¦¬
+;¸\9eä\ e·v\18G^U\1eß´uÝ¢Û\1f=N¸v¿ÑilëCØQ\8d\87[ú½ö\b\ 6K\ 1\18\\a&\ f\18#\9c´=\9d´á@ÕØî\91ÜNs¦¸      j2Ò\8b8ìño\90Ý!\9c*¾â\9aCÌ®\89\ 2\8e0N`Vx\10'\1a\8f¿G±\ 2Vç<\ 3¨\ 5\93&èzý`÷wµ{u\8a\e\b\9d\81@e\0\85&(V#\91\b=EB\bÁ\ 5ç+á×L¤j\8aHO\92Ý\87\83­ÉM\ 4\16§\86Q+p·Ú\8f«³hà\9a\10i`\90ÐH\9d\9f·\eÙs\14\ 2Oe2Q\84?\9c\9a,4¸¦VH\84\92\87QÅ4\b\1cÊ\ 2\87pjf5~VãÙ\96~'\ eùÅ\ 6Ïz\ em|\98Eì©\84k6\1c´ä³\11L\19±¤Ï­{°3ÄdìÅ\9dòIz>\ 1\99F$Óÿ'\93øC¦N\85\82  \89\92_\80ER0\9d\88à\9b\9a%è$ÇÜ\b©\182tUÐwéIÕø\8b\9e§\0/ ûHKíO\140êï\bõ¢ÂÍE¨\1c¸2î\80\88\15\f¢\vÅãGÊ@\187G9¸{\ 1\86r  µf¦¢s6Ø\15\r>@x\94:ÉÌ^\ ej4|Ì|0*}\ 5\10è\1a2\ 1§>VÞ_\9c¬\81\81Þ\ eëõ\86ÓO)\ f>¼å­·+ØJ\89\ f÷\81[0ó'    ó       \13\1c¹\vÖ\80\9a\9dÅ:\16\16ýo\7fÛv\ 3­¶]é:
+\ f_R\9dØdrº$$¶êÂÜ:ì¸RX\1cä3?p¶Búî]0®¤\1d\87Þ_a\o\9bú\91FMÛ\11\91ò\8534Ñ¢Z\88[g·k&û\8e\0¬\81.\9eVÒH:\83ÈYj\18`RQ\1dÆ\81g2ì\9aY«V¬\85É\8fÀN\1aõ\ap:-ª°\81,Wqm»\9d#ic\96¡(à\8c¯*íªÑ\9e-ÞR<\14Â\f\1at ª\17\ e°6í´Ï·\15Å¡ó¾êø\ fè`\82\91p sý¡\1e\ fÜ\ 4¯é³h÷h\r¶(\87©×B·\83­\84\89\9ac\ 2\93Ý¡Y\ 5\1d³µïÑÂÁ\8côd\98\ 2¡&¸rÛW\7fÑ\ e\19ô>Ògç tô\ 1GoÉ\8bÑ\roL¦Â}AqOæÀ\87{¸««¢"ða[\ 3B[jîJ\18"0©ö\1c^1\19\r\82cZÌÛ0©9\14\97\8e\ 6Ö+Õ"ä²®²×5Ö$\9cò\96i\1e \86ÁÞ>TûP\aüÄz\93\ 1G} `Ãu5\ 4!\8d\a\1dƹ~h»`ß\98\92æN\84¤3ϲ)Ýmü\rt\82ÑÜtÄ#QñOc\aµwee\87p\14øp\17\88ÐOÂÆ\8cÓÖ÷tKÏʦ\99½=µ4ÀÝAå Ì\ 1Õ`O¾IåA Ì3åÔãþÔ÷¹³\82\ f\91ÝÑáÙ­n»P l7U£P9^-
+îË7b^  §T\9eHx\85\84\9eª¡\10ór\b\19«¡\r\e\16M\ eKÒtÜðþHçQ¿¬ÌI¹¶×}[\1f\ 6·Z==e$Ý)ê7\88ZÔ×`.\±X(è]òc\9bÍ9\93Ù\8aO[l\ 2$v|Æ¿Ñ\9eE'û<t\8eMÑrjH¾     \ 2æÎp¦E\8a\0\9eßuÅe²¢       ù£! ø\9a\1c7\8e]òÂæE\1cìW\905`\9f\7fBd&þúÔD\992­&\1fÖ$náá\95äG}\81\97\9c\81È5X¤d°4ʼâ\89\8dÉõ¹Þ9\9b\17\ 6$"g\ 2\8c\ 4\1f\98ÌõùxdLÍÔr¹\8a\8fÈõâÝw\86Ð9Kô\14ü_ àT\98\96Ç\9a2ÑW\12}Õjf\¡oÂa¬\9e¡¯aÚdO\ 6RÛöÙz´að¦9ÿ¼\85\90fzqIæèó(\ 5\9eI\13Ð\87dbàº\b ßHSoøÅëË\8b\ f\17ؤóH@D\rã©\8eDf\98Ì¢b\7fñö\1d\8fJX\83´       q3ÑG¿s\ fÊe\82§êè÷\8bßè¿'\v\95(IAk/2Ì\9aê\9fc\ 5dâ&\8f$SòéYQ`BÏó¸¬î«\9e¢\ 6_>j¹ñhÂ'uÀ\90|çy\87þ\8f²\16\17DþLð\804ê$vy>Óö       ±K\ 1­§ës&xÓÕ\81¶B  \r\ fÕð\7f\9aCAEíI+u\96ÐBPëVA\aðH 4m3öþFûeYÜ\96\1c\e/ölå\99½ñü¿Âf.,\9cTÀÏO¯<ų\17Uñü¤òø\96µ\1fÈð#O`Õõ}xïÝÚñ>wg\1f\83¡BÑÃéÓ/a\ 2µÊ<Ë\97ÓZu\1eØ\14\9e·P¬\17È\96ÿ\19Y÷ÙÈöð\88ñ\1d#´u4s\ 2ï\ e\90\1aFÖ|Q\84S¸ó:ûw\b#Ûa£\91\80)lã\ 1Óêa±\vrÜßõ\84i\9b
+endstream
+endobj
+662 0 obj <<
+/Type /Page
+/Contents 663 0 R
+/Resources 661 0 R
+/MediaBox [0 0 612 792]
+/Parent 576 0 R
+>> endobj
+664 0 obj <<
+/D [662 0 R /FitH 686.127]
+>> endobj
+665 0 obj <<
+/D [662 0 R /FitH 538.126]
+>> endobj
+661 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F49 457 0 R /F74 666 0 R /F14 574 0 R /F11 573 0 R /F1 667 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+671 0 obj <<
+/Length 2207      
+/Filter /FlateDecode
+>>
+stream
+xÚÍYMsÛÈ\11½ëWà\92
+X      Æóý\91µ}Hj\9dÊ\1e¶j\13ݬ=Ð"$c#\81^\12²wÿ}Þ|\0\ 4À!HEªTN$\a\83\9e\99î~¯_\ fiq_ÐâïW\7f½¾zóÁ\16\8e8Íuq}W0M\89Ö¦ÐV\13ÆMq½)>\96¿­~¾þáÍ\a3\9eÈ©!B(X  S~Üv+mÊõJë²k¶íª\12\ 6\8dÿbË¿mÛ¯uë\1fì½­+\9aÖï?ß|`ld¼ê­WÜ`PÄ5ÖïÞ}\9a¼=Ý:\97DZÝoè\1fí\8aÛ²«ïë\1d¶ d¹i¾6û¸3!Êí]<ÓdYË\88s¶·°\8e3ÆKX¢¬é\9f\7fò\vü\9e\ 4±b4íÈ\8c\f\e%\19\v\15#\9aÆÓKǦ§\9f\1d\9aÃ\16ïm½K¶Æ\9b¡D1]0I¨Lἡ\82û\89\ 5ãD*QPÂú\aT'\v´ÐÄ\19a½ E\QIÂú÷\83c®¾¿¾úõ\8aaeZ°BHA\ 4\85#\²âöñêãÏ´Øàá\ f°/àÕoaê#\ e\7fí¡ø×ÕO1\ 1'«ySÆi\98\82I¦&N\1c\1fL\11FmÁ\18QT\rÛ7\19gj"4|i   MûÿnU1J)Î\ 1\aÛòí±W\ 5#|È\ 3z¼v%\1d¡\9a\17\95 Î\1eV\97/t\1eÂÍ\90Á¯á<\8e\13èçùN=Ïwq²\9cP\ 21Zön»¡\\1d{6¥ãص§I\80+b-¼\8c\84S¨T8ê\0·?äpM\ 4å\13<\9e \10\1a,]\7f®#WìêÇuÓnz"¹Ûm\1fã\83®\9fÑ\fd\ 3÷\94»8x\ 1á0ë\80\7fÁ8\94\82>ák\rS˾Öç|-\16vbÀCbÎWìd\86äòÌø\8d\ eYF)`ÌyùKÎ\16'f¾\99\89\97¡\86ý\12\rÁ¤Èð('Ì\98\19\8fr\9dY\14Id\80y\140jOcÞ\80:àIe$qÒ-aÞ\11;\87üø\b\83\88æª?Êñ¾à\vmÎ9C\1f\9c\ 2\11J1PníP0¸9\ e\9c\v'¨¤\9f«\a\85àÑb(`³îðM»ò[Ó}îÇ\9a}\1cÛÔ7\94ɶñbáÏþ¡K8ì]½\7fzHï\86ù\18[?|ó°X\al¤±vÛVm}¿î\9a¯~8½\1dÕ\b^}¨÷A\86à¬\15HЩä5l¬Íñ\9a@M;rÌܵö\19yv\ÆÇ\ 6È"+ª¨\88àdb¸ì\13,V²·þÓ,R\9cPD)5å8¸äëJ)¸ò)ýÜ~ê@yõ&:.ñNòÝ]Wí?7w]ÓÞÇ¡!<\9d\9f\17¢±ýc\8aÄíöñËCýXG\82\8ccÍH\9ae|i-ÑN,r¢;\84ã$'V\80\1fª¸\9d\868ËHvd®éödU)æÊ\ f+\vÚöd®lùåi÷\ 5ÎÅÉöõ>\ e\81ÑñéúÔÅÈ>N©o\e\9f·ë>\85µ,·+nÊ\98\8c;<TÛèªðZ|\1d\19}ßnwõ&½\11³Õ[Ý\8eÖñY[Å\1d\15l ÌÔ¿>5)\96\a\9fûRµ\8dÅ«\99ÊbQ>úß\0Uóå¡\89;\8e\13óõÊ\18b\14{f½
+ëð\8c6b\16ÔfÁ+\9a©\85ÒEiPZäe|p\817 Cr\0yÿþ¿\ 3\bå\13\80àç\b T\1c\ e\8a'»æþ³\ fvDÉ\8a\95      (´×\v\98Óù # `h\ 4\14\13\82\86±s@\ 1Ë.k\a_\88^\r'\1a°´c\9c Q¹f¥Ïõ\87\87pH.\83\16
+\9fá°\ÊÀ\18\8fÛ}\17\87ý\8bñ\9bÇÏh¢(Ûú[ü2òµÿ\19«\84ÿFÓ\12¹Üäh=\9cZp\87\ eîhÒ&\8e*E\0\18W\10Ú\10T\13\97D@",,F3»\vá%«Z\ e\8a\1doÂ[j\91%A9\1eö\ 1\ e\92@áuä\16\9f\vûÔ\84Ó±1\88\a1(Û\16=ø±à\86à:È©D\ f:ÑÃ\90i\81\1e¨\98Ñ\ 3\1e\8cD,=%báxvØÅ\85\89\18ì\9d \ 5Åø\ 5¤À\8eI\ 1#L\13:DN÷w\ 1û®^\83Xs
+Q\86.\13´\ 1Ru§ÙbF\12èØ$» íf\84*{Z8@-ã¬\95ßÃ\82\94ðBBäStC\vJ\11\85Ñ\8a©T\9cl:Ú¡h\11û=å\ 2\80\9c\82¾ãÄ\1a»Ô@:\88a\85ÜJ\fûïl÷è\98\v¡\18\9cð\97\ 5æ­8\82§9Þà\90\02\ 5o·}j77TÑ\1cæ=\ 3.eÞ¤]\81\116Y¾øX)ô²ÿô+\0f\92\v\1fzÿ\11\14jã§XÓs\fì8ánau4wvH\12\ f1o:Ð]X£^CÏvñÇ\bx U)ub½ðFS§Ý\ 5_ø¢\13·Ú«­µGòï\11\0\fÞ\96NL©ëвÒ\88\13Ç\bc@  \8fÝÇë8ÚL\1c\1d \94C\86!L\99ì\85ÔL4\87ë)éå\8eK\137\99­I"¹yV»\18ytL9ð\86r¾¿á<Îc9\14â96"\94g\9d%\18b\9e\99ulãÕ\ 6CÒW$1\ 5¢\9c\82\fÉ+\88\14   
+u\8eÀÀ\1d\8e-\9dß\82\10ÅèVF^t+33RiøÈ\80ª\10\14\94\18Î\85Ã\9e\88Æ\9f\16C!Î\87Bú{Rý\1a±@ÝÖö\92P$DÝ^\10\8aXD2ÞF\85\93.\7f\aæ!ÉBÄ'·^{ô\ 6§  vµöÅ\1cXwO»v?¹×\92aÙáú*|®ã\83û$SÒÓ\81.M K\ 3º\8c<è/Z¾R£`jwÙaÌkò\f§HÈ\94J¶oúm¸1        co\87\8b\0Ð\8c\10£*5g£xÇæ\83'æd2Mps\b.˧\89\93r\96&oói¢&Y\ 2¡À\b\94ܳ~äg{h*äA¿\84=¤5\ 4Eß4Ó¾ì\825\96Ò]\9dÌv\94zÊgÙÞ<lÑL0Y\9eÈ\12tv\8a±\97¦|lí\9c,\1f\9b¶       ¹û\ 4\1dîë¤SY\ 1\10&\a `\ 2ú\18ÌÞÇ\1f;¯«w¡\eÄ\94 ¦ñ¹ïÐÎÇ  ë8Ò_!4£\8b)whÊC\v\90U\1a\82zR°\8bZ\83¹! MÛ«a\10»ï\9eÇjx~K\ 38\1fÝÒxLo»á\ 2Ãß\a¤û\ 2\1a?î¶é6|ÝÏn«Üé\848×Å*4(Ô]\1aÌ$ó\99Ñ\80µ\9c^W_\946ÏÊ\9aEn±'4\8c\9dK\181\9604[3\9d\1dÄÕw«J)i²¥\£¹Ñ/.å\96\ 1\90çû}_É\87\8có®=.Öh\12´\97ë\87ºÈ³m\0\83L\1eMZg+ìÈù·ÙÛ\aÉ\ fÂ!ÜÔ\9fg×Ù_}ï/ù«/óç4\b}v½í\9b£
+µÅ%P}ÿÛÚCh?ïo\8c\99^$kæÙ[\11#R1¼á\8c.þ#åô\90³¹\ 4\97§\12ü\92ê4NòC        8µýJ\18Â=\99øVÙ¼pût¶¶9³v´ô:k³£µÙÿlm~´6Ï&\1d\ 4ï\7f\0±tÈú
+endstream
+endobj
+670 0 obj <<
+/Type /Page
+/Contents 671 0 R
+/Resources 669 0 R
+/MediaBox [0 0 612 792]
+/Parent 576 0 R
+>> endobj
+672 0 obj <<
+/D [670 0 R /FitH 686.127]
+>> endobj
+669 0 obj <<
+/Font << /F8 458 0 R /F78 673 0 R /F11 573 0 R /F1 667 0 R /F10 668 0 R /F14 574 0 R /F70 508 0 R /F7 674 0 R /F49 457 0 R /F77 675 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+678 0 obj <<
+/Length 372       
+/Filter /FlateDecode
+>>
+stream
+xÚ½\92=OÃ0\10\86÷ü
+\8fö\90«¿â\ f!\16\10Eb`ÊÖ2¤J["\91D¢-ôçsÎ\97\9a6\b¤"\16\9f}öÝóúµ9Ù\12N\1e£»4\9aÍ­#\1e¼\91\86¤\e\ 1g<1Î\80\90\96¤9YÐçzÏ\8c¥\193\86î\8bºb±²¸Ä(hÞ.îëêc]\85Í\1d{I\9ffóÓ¦J%\80\r\11Ù´;\16áHÄ;\11}D%ö¤(\96&\ 1©=N,&U[»\94\82\8fªÇ¤fÖs\8a·z\8b\125]ò\84+\1c\ 4Ã^\8eÞ\86`©<ë3¦·\9db¡Àk{%[_°Õ¯ÙîJ¶ý\81MbÇAù`³\0/:\YT¡¸}J!NH\92\83¶¾Ge7\b¯±º|ô Þöç\1a\11#ì"N8§éë\1aÿ\8fR\ 1X\94LZz`\82\96!§i½i÷öL:ú\196ë6Q\85Ä¡\fã
+ïäèú}7!Uh\rÒèAë¥F\a\89\e4fU>ÕÄ\83²\83µ\13÷D\86\1d¾6\9cy\8b¯Ö¼a\8cm¼L:s³ãwæJÐÂü½¹Ù±3·l\13×;k@rù\ fÎ&ÓÎöñ!\8d¾\0k\96\17\b
+endstream
+endobj
+677 0 obj <<
+/Type /Page
+/Contents 678 0 R
+/Resources 676 0 R
+/MediaBox [0 0 612 792]
+/Parent 680 0 R
+>> endobj
+679 0 obj <<
+/D [677 0 R /FitH 686.127]
+>> endobj
+676 0 obj <<
+/Font << /F78 673 0 R /F8 458 0 R /F77 675 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+683 0 obj <<
+/Length 124       
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppçr
+áÒw³P°Ô³432S\bIS043Ð333W0³0Ó342W\bIQ\88Ö¨ÈÌÔ\8c\rñÒw3GVjd`®gll
+4\a¬È/¿DÓÌ\#QÓÌL£$3?OS×Ø\1cÈÍK\ 11,4\9cóóÊRó@\12Å ³¸\f .@§]C¸\0F\11%l
+endstream
+endobj
+682 0 obj <<
+/Type /Page
+/Contents 683 0 R
+/Resources 681 0 R
+/MediaBox [0 0 612 792]
+/Parent 680 0 R
+>> endobj
+684 0 obj <<
+/D [682 0 R /FitH 686.127]
+>> endobj
+681 0 obj <<
+/Font << /F8 458 0 R /F78 673 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+688 0 obj <<
+/Length 1392      
+/Filter /FlateDecode
+>>
+stream
+xÚuVKsÛF\f¾ûWhr)5c)|?\8evl§iýhme:\9d$\875¹4w,rÕ]Ò\89óë\ 3,@IL\99\8b\ 4`\ 1,\16ø\0Ð_<-üÅû\13\9fÿÏ7'o¯â|\11Æë,Ï\82Ŧ^\ 4~ºÎÓb\91dù:N£Å¦Z|òþ\94¯ËU\94%Þ×e\14xÚTvùeóÇÛ«|Q¬\8b4LÑÐ_¬\92`\9dû      \99l\1a     &iâ=/ÃÌsö)Ú\879Ù;ös\10Å7\1f\1f6oN\91OG~\19x\e\12ÜÞñ\19éÞ_þýñÃýåűìá÷³ëëÿ 0>\f)\bÖE\92RHì,IRÖ»ûx}A\92äHBüOÊ÷\97ïînn.o/.'\167gË<òþ\1d5EWM.æ\ æÝ_\9b\ fw·g×o\96«8Ï<Õá\7fîõ\8d\82×Zb*½\A~Ê¡\95\1d&ª']a$+k\12<:5¹÷\84ªFî\8cìeE\9aÂÒa%mi\14ëWÓ«ï¯ÐðÝ\Àa\10\14\90Ð(ò>á1à%\0\15\83 Aâþý   (\9d\eQd|Lp\ 2á\97µó\17Äë"\8e§Nÿi$>$\8c\ e%¢¢!NX+M¯tg\99'µÌÛmE\89Q£Pwôß7|Xjz8§Ê\92T×ì\83þ\0\85Ú0ý¨z\vi\12-i\ 2'·õ©\vw5\17¯jw[9VBp|\91ï{¶ÑÃ\16Ã*\8aC)\90\81
+ì ø\8aÔ°Z(\95\a\8eÕÐÑ>\14K*}#z:©Ø¨Ó=\11µÞn5&ëë\1c¤!\e\16\17\9e\91ÿ\rÊì\ 3¶ëå*Í\ 2ﬣc±ÛmUé\9eñ\e\82ÃÏÇØ\e\81\ 6/J\eÒTlá2\8d\ 4<ËÊ\12\9eÁ<æ\18í\ fUD®ÓÝj\ eKP§Z\9bVuOð¼\98¼\1dyÅÿîÅHTÐ\10pSà}ö\83\18èÎ%\14-ñ6\1c$Ô7lgwô\8cR¡>½ð\14C\8a¼Ç\81]
+\97\93Wbàn«;ñ¸\95sᶲo¨\r]\85\ 3B\14ü7ÐÜ[÷
+ä 9-Q<\ 2\889\82\rVVP\858ò½óW\14\854ÿ\ 4\asì]~\13\b·SBÁQ±ìô\96\99\88+eKa°¹ã\9c\8b\16ã\101\ 6¡\90¹)\ 2\82Ú\88\16ýÇY\ 6\85\9cE>Zè¡ß\r\8eF0àÁ`Ù\970ìÉ\81\ 6$¢ïe»cC@þ<\10\9cs\1aX\83KRN}]àL\e\93\92á@Àú\ f\16   °\b¼'Ò·º\95¤UÉZ\fÛ\9e\98\97%Ld±\1d¤%¾ÆÀ\90 y\ 1\86Ò\18ÝI=°\ 2ÂÐ\15'ÄÁÔ±sDt\ e\88\9e   \1f0\ 4\131t~\f\91<®!q\96\ 4\8auÜ¥H\1cÍ\1c\9c¦\8d\14\95\94\ eG\8fGÕ&Á\1e\18Y\ f\96ÝáHÁÿJ\96\8c\8b©\0z\85ïq9\95a\9ebÁÉ\10Dn2 pz=4ȸ\ 6ñ\10Ö ·\90\eC9 \98<\8d\99r\1cö>÷¹`\ 4Ídð¸óã° u\ 6Íáü¾à\8f4ÐÃÉx\ f\9e=Bå\a\10Fn"\18¶Ä=ë\bê}=.\ 1\ 5Q¾Ò\89ü&Ë¡\97äE\18p\ 3×\ea^Iâò\87\18B\1c'1-L\8c        çÊLìn½Úî\89¢\18w\f\16\15\96\97r°"\ 6РúqR\81Ä(ûüë¥èÆsø\13\ 6P\80\9fE§D6\9c\10L\10§    Oâ\18êk\a÷q\10:4Ñ¥qèÞjIÜ
+C_`\15«±\1c_cÈ\e\9fð\1ep¢_oEÂV\9cbÇ¥®ã\88ý.\8dF\Ç\\1d\94í¡\v´\83\1fC\97\ eF\87ûF\ 1\1a?\8aêýù+\9b²\vØ\14عy\88ë}ôï>\1a\90À©;Û¿®B\ 1}TP\e5z\8bíHò\9aº\1a\88¡wIEzÒ¿¡WK\81glñUõ\rS\8d\1aW!²ÜþÁt¤NçÁLÛº\8d\96ä\18       í       SAWµ;@\ 5,+xr\12dÞáñPõ\10P\92A­Ç5\97ä¼O\81pÓ³tí#\ f\1f\96¨Oq\82Êñ3\93}/Z\ 4ãL&i~·øËû\ eñ\18æ>U>\84ïö\12g\e\12ºÃ\86DêÑ5\1c\ eã\14\16иãKýÔ©ï²\1aux      \v÷Léþ\9eiï¦ãç_\9a\1e\ 6>ßSïÏ-\8b¦\bwîÝÌ\9f\ 6i²ö³t±
+ýx\9d\849½ð\9bRj¢w¹9ù\ 1¤Ï\81\18
+endstream
+endobj
+687 0 obj <<
+/Type /Page
+/Contents 688 0 R
+/Resources 686 0 R
+/MediaBox [0 0 612 792]
+/Parent 680 0 R
+/Annots [ 685 0 R ]
+>> endobj
+685 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [131.887 489.796 159.782 498.596]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rfc2119) >>
+>> endobj
+689 0 obj <<
+/D [687 0 R /FitH 686.127]
+>> endobj
+690 0 obj <<
+/D [687 0 R /FitH 533.793]
+>> endobj
+686 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+694 0 obj <<
+/Length 112       
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppçr
+áÒw³P°Ô³432S\bIS043Ð333W0³0Ó342W\bIQ\88Ö¨È,Ó\8c\rñÒw3GVjda\ 1Tj
+4\a¬È;µRS×ØÜB£\ÓÈH#_ÓP£(ES×P£\18¤\95Ë\0j!:í\1aÂ\ 5\0\9d\14\1f\17
+endstream
+endobj
+693 0 obj <<
+/Type /Page
+/Contents 694 0 R
+/Resources 692 0 R
+/MediaBox [0 0 612 792]
+/Parent 680 0 R
+>> endobj
+695 0 obj <<
+/D [693 0 R /FitH 686.127]
+>> endobj
+692 0 obj <<
+/Font << /F8 458 0 R /F78 673 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+703 0 obj <<
+/Length 1940      
+/Filter /FlateDecode
+>>
+stream
+xÚ\8dXK\8fÛÈ\11¾ûWèH\ 1\16\87l¾ç¶vbà      61Ö\83E\82Ý=pÈ\1e\890E
\94Çþ÷ùêAJ\9aá&Á`Äêbuu½«\9aÑf¿\896\1fßDú|÷ðæîCZnL\14æ¹É6\ fO\9b8ÊÃ2¯6Y\99\84IYl\1eÚÍoÁûC}\9a¬Ûî\92"\vâí\1f\ f\7f\93miX\94ELÛ¢Í.­Â\99þÓ°Mâ`r#vÄA{n¦n\1cd[¹©Â*7¹nÊb\9c\96È®\87\83\1d]\8d-U\12t^\9e¼L\83½\1d¬«{Á\9dÎî´Ý\99"\18½}»Ý¥Q\15ôÛ\18«í.\ eü\ f!úÖµv\14°ÁÓ\94Ak\9bp»ËM\1a|\9an\ fy¬½m\ 5\84\98ü\9c\ eV\80_?'"\ 2\18â\10Kg\8c¤
+I\1fÇa\95å"ýå\14\88\ 4àDÚCHhOÌ   õ¸ÅÏ\ f\81ÿ9\18\ 1\1e¶e\12`\13ÀÃ0öã¾³^Þü\1ee\11\9d\ 4wÅ8-Ú|ÝÌÐßá·"½2e\$a\94æxÅÂ\1c¦ét\7fw÷üü\1c\8e\83     \9bñx§\9cÄñ·~¨ª0)\8ay/\8e\8da¨â"$\94\18\87z\82\1a¤7\942aj\12U?\93]l°\14vúõ3Ì\94\90\99B\0± ýxv\8d\124j\17]N#=\93\v\83\7fu§C8º½ ?\90yÆóÐÖ\1cC\8c«\87VH\9dí­ø\8eÐÝ$X\10S¬2å\8d§TÔw_þ²ë»¯dq:2J\82¾kìà­\b½Ë³D5\8fÒ îý(DǺUòz\90\9cýFlÄõMýØs@\9a8\80óÙ×ø©û\89áÝ\93³V\98ö\1dLÓÐqr,1Û;°\ 5Ý$˧ѭÉ.4\88!\93ÆÁ     >\99÷кéëîè\ 5î\14wìö\87-Ì­ËCMôßTwÂ\8c\17\84\13\f{\82\0?>M´÷\99Õp\8a\vp%\vLÞ}Ûfy\0?ÍìÁ\ 1æLã$øÇ(TÐê\884^QÌ\9fØ\86¶é~\8fâ´Qo'p\85ýÞù\8925KÙ*\8c\94üÌæüÌ\12a=  Ù#G\18KÀ.\18IdÙÆ9\ fh\8eH"\9fSwÎï·\84F:²iXy{QI\ 5øy\ e \15]~¶}=x\92ß\80û±îÄIx\92s2®jô¦µÀõ\14¾²ò\8dëN¢8Qýv\95ün¯¹ÿËÇ7rB\94Þd4\90\7f°±Ëà3«ì\88\91\17Öã\93<E}â½jî\95ª&Ú\93ë\93\ 4ÉÐ\8e§\89Ke\ 2\83»ñ(Ðt`Ã\83`\9aMø}\92WÏÝt\10H\ ftÇÎ{\1c\16.]$NÃ$Í\8d6\84$       \8d\9a1\ eQ=âØdêdô\1e\8e=\ 2´W¬µ\14\ 3ñMyÛRÒ8\87\97¯Ý@\18}áϳlÞN\82"\83ÑS\8a\12\80'[Oggý\8c®\95ðb\1faȹ\94AЮ§j èn\98·\89\ 4×í»a=\17DÝ4¿í\ii\82÷ªÃ\92öDe\87\85®\15\8cZ\1d\10X\91\15\99\19\95-\ 2\1eE[Yô£÷½Åÿ\ fYO(C~)ÑÊ\8f\ 2¸àJ\9d¤\19\eeEêÙÖ¦,5\19Iè$ºyѼTÀ\94\15I6\8c\13²ÎT\ 5\e\8b(µå+v\91\99^]ËLû_ÉLHMºqMT©\1e\96\8bÀy\94\ 5\9f\9e\ 4Y\v\91ú^\16\?ð\ e\ 2\vâ¥ÏÅÅL:ÈSO»òùõÙ\85\9eÍ\93L$)º"2\9d\9b¦¨&j9¤\10÷= \9e\ fv\10\12Ð"3-dov)p\94ó\80Á\81\1a}Q\ 4? !æ\84So'ÝÖ£î
+ÄéÀü­·7\a¬ÊZ\9f4¡jç%ùÙ\14xþ4¿\19Úî;×/\99gPÞ\ 4àòƤïÂøe\81û¯5#\9e\8b\86\99\8b\86N\80¨\16\1f\18\vØÊþÏKFñb
+-LÐ\9cÑáÅÞ\9c\1f@¡X\88
+(°^P\98ôö°\84\1e!çù\13 F\17åGv¤gí\1e»ÉÁ\ 3µS¶m\aÇz©ØL1és}Ô\1cü´L\v&C\b¹úHÉ\81þëêÉ
+\923     \18D\8a ¤\r ài;sR~î>Äñõ(\99\15!ê§N\83ÿV\8ad\93\87U\91\94DQ\84UUn\920\8fU h\85\8d       \8b*\83o.Tï\95*ºa\15\e(\17bn\13¢Ç\15Vi\18EfsEô\7fqr¯]\r꼸fÔ`àvj\14J\8c\13ùD\ 63¯Ýôá Ö;9tK¯Vn-åÐÐ-}s\17W\88ÂÒ¬\15\9ad       \9b\82ÂF\1a¨\99\ fçקº±^àZ)çì1\9a=&øb\97\8bÔ\9få\8d \90\19¯ó\ 6)\9b@\13\1e@\89¨¥¶\9fXwé#$\ fßAÐÕëYæÇÝê¨V£Jt\ 3\ 6ô$\9f«\97\97\ 5\ f\89\ 4\89mï·¸èA´{s\1f½\95\94$Ø0\9cÓ \89\ 1R6¦÷ø\83À\19Ú\ e\9b\9e\90\8béi!S\93\1e\88\90^\91ÐÖ¢\v]?+É:xR«\17¡.B\ 3/C\ 5° è\9cà®tÄ\8b~\1eðu¦â]NyÉܦ#§rb\8f\81è\7f{\fÄi\98®V:ªrU\9aB5\13Â[Ky¢«\8d¹\8c6\80çÙ\97®<­ôA\1eU°ä>E4×\11¨÷%mÅ®¯å\8a
+*°Á Ïm7C\bÈD\ f\84Ì2t\14W\1a\89øY¼+ËSõñÔÊâ(@\8dÛµö4\1d¼Ü ûÚíù#BE3\ 4O#À\96ò\0±\97Wó0&xjI\12H\83\ 6«r\1fF¥Àýʺ\81«\1e\e:\7f\10г4¹Ö"ù¼Ä      1ÒÏ\ 1¿\10îã;ý 0\9f\82\92½¥o\1a\819\12Ù¹\9fº\9d\10\v\85\9cÈ_\e²à]/ÑøU¿h\fú©áùÐ-2¿\1aëè³E=¬É¼LBtK¤*\947ÝU\8fbìÕ@È÷Ñèå]\ 6ñáô\8dòkêó|\13\95¡\17Àyè(²dq]\1dh}Â\1d\87\83\8cÞÁIÔ\ 1×ä\953û>\94\19äËM\18Ò\9dAîtÉëx$Ü\1c\8fBÚé8Ag\ fË=Dö§<®Ñú¬Ó\1a`ísË\85ã\92cq^\85I\8e\ 6e²ÐDóðpCó×\877ÿ\ 1 Ñüx
+endstream
+endobj
+702 0 obj <<
+/Type /Page
+/Contents 703 0 R
+/Resources 701 0 R
+/MediaBox [0 0 612 792]
+/Parent 680 0 R
+/Annots [ 696 0 R 697 0 R 698 0 R 699 0 R 700 0 R ]
+>> endobj
+696 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [278.919 466.211 380.288 478.167]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.on2.com/)>>
+>> endobj
+697 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [291.942 408.926 320.225 417.837]
+/Subtype /Link
+/A << /S /GoTo /D (cite.Mel04) >>
+>> endobj
+698 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [200.048 280.08 216.846 290.928]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.1) >>
+>> endobj
+699 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [308.085 200.992 322.808 211.84]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.3) >>
+>> endobj
+700 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [434.087 177.082 448.809 187.93]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.4) >>
+>> endobj
+704 0 obj <<
+/D [702 0 R /FitH 686.127]
+>> endobj
+6 0 obj <<
+/D [702 0 R /FitH 668.127]
+>> endobj
+10 0 obj <<
+/D [702 0 R /FitH 380.77]
+>> endobj
+14 0 obj <<
+/D [702 0 R /FitH 265.816]
+>> endobj
+701 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F74 666 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+711 0 obj <<
+/Length 2339      
+/Filter /FlateDecode
+>>
+stream
+xÚ\8d\18Ùn\e9òÝ_¡·i\ 1V§ïcÞ\1cçò\ 2\93\18\1em0@2ÀRÝ´DL\1fZ²åc0\1f¿uQG,/òÄb\91,\16ë.F³õ,\9a}¼x»¼xó¡\9aÕa]$Åly?\8b\8b(,\8arVTE\18'ålÙξ\ 5ÉüÏå¿Þ|(Óã\8du\1a¦Q
+ThËõ§«Ûåû»ù"MÓ \ eç\8b²¬\82\9bÏË»yR\ 5_Þýûzyóå3\92¹\88äê\1fÇ7\1f²ú\88þ".ª0­\8bÙ")\ 1\99ò5\9fÇIÿÊÜ\1cs\9d&a]îy¹\19î­þïN\ fx÷Ô=\ 3SU\1248Û¨am\865bâàÞª^ó¢U\93vÿ(dzÇÍ<\ e`%\ e\ 6Þù=\8a³®çE5´\8c|0­\1e\91\17àµ
+£¤\861\ eë<g.\1c±Ðh \99ÅY ¬f ÙM\fLãZO\emÿiÔÀ\98Õ\1c\1e\eÈ>·Ûna^\ 5£\9dtË8#\eá\18\ 3_Ök¡:\ e\vâ%:åbRfÐ\96Õr?Ú^M\bãU@ù\99ñ"\193°d`Õé\aÄi«:Þ²ÜèÑ*\86\1d
+f²Zõ\8e\11þ!!\v#­Ã*\8fAoÀF]3\e¿\1f=fÏ\f\ 3fh\80\96Ã'\12cF6´z;mä\ 6¿Wµ­\99Ì80[øêÎ/¹­"Y\13IÇËÃ(´¶\9d\1a\ 6Ý\86l9Y5\8b³0Í\8a\ 4m\a\ 4\96\16a\11gÌi\1c¦ð¾8É\83ëN9gPõ\8dÂK_\9a\1d\1cMÒ0\8e*>ê\85\94%5±\80£LWÝHÏ'QÿµXñ{q¥\e\9d{fp²jp¨$\9e6|¤Õ\8d,oPy\bí&Ó\99¿µ¿bà±b\ 6á!\a\ e\93\1aÜ\19üJ<ã{\14%/\9f\11Ga^W~OÅÔ\96d ¬4½¸¡ñF\14\1cÅa\92\95§\86öÎ8Ðã\84þ\94'ÁõèÀî\10\ 6Û\99WYpx\1a¢\80å8h\19\94(\9aò \1a\8f$v\82\9b±\17^\ 6\80\10\93G1È\9c\94\r;@Çh\0g|À\90Ørö\1e\18Ù{\0päÿ\b5¨k\ 6Ç{AíÅ/\vJÆßnß\7f\970ɪ`\91\10P\ 6\vô\8aL&\14#pï§0)R\8c\86I\84æÁÈÖG\17\ eàÃÅg\98ß\8c¨\88Gxc\84/hÍ\83AÙíÈ\ 5\0ujY(\8bH\82\r®\8e\ 60\95\83\0'Tß]/\19+OÖ`óEc$~:Þ$$!6L£ez,QÄ¡D\8fy/\98wðeG\81\ 2\15\fïFgJ1\1a%e\ 1ñmå&Åw\18Õa\98ÆM÷v\94í@ÔiÞÛ°\89 ..\91Å\92\1e\ 3\90]\89U!\8bÑ{!\928\8e¡\8e\07\9d3\12æ\84\82\\9crnp\f\7f\8fòèæ%\9a\1e\ f\ 3l\89yÆ"æe$HÁ÷ädF\ 4o\ 5\rÊä4Dvð\ 3]Xü\88+H>d,<Ïê³\ fÀãà¸ÃÈ#¤\1fó0ÏAs\9dh\92ñ\93¬\93\17 °2\8b-hÔ4\93aI2zÏ0ÀÈðÛc´¼\17çã\8e^\8c1oà\11\ 5ÂÐ\91\ fý\ìÍ$ö^9·ë·èçîõ°[îÃ.Þ\921\10\881î&U~\12CqK«\9dY\ f¼¦ð\ e|!.ì÷÷ÛN?¡\91ÕY°uÏ\9c\eÉ[\1e\8cÛ¡\9d.\14û\ eØ\1f9\ 5\1e\87Dïo²B\10¤rÆ%|\ e5xÏ%§©\8e\9dq!\97C¸ò¹\19\19ÞÛ¾äW\10_\9de@5\81È^ü\90yê8ØZᶥ\ 4QG`\11\18\8aq\8db\e\8cf\92%ö¢\81'¨Z(\ 1\80«<\8d\ 2÷<ðãí\b\11\84b®¬`Ê\95\9b&ÝøÔ\b\1c\8e¬R­¡®phzeÆ ®7\90U)¬\ 3F[;Z\87±¼(\83+\8f<\11&bȶatc§©\9e\ 3GV\8cê¡ô\90Ý\8cÀ7â¨\9a\ 6*\b.i\90Ä°\85Âë\8cßp\19·È(ö°Ég\10r8\84\97l\12V\ 3ÏH  W$.\9d\1e X\b²\9c\84\94e#A\89Åq°\e¸öâB\ e\96ÿ\ 3Õ
+å;r¸Éý\12\9e3\16Î\18ií­@$\82\18`b`\88ßéöh*Ïä\9c\13º²\92+)ýÈ!#\94\8aI¬È\8f/=Pïi±xaÞ¾è}æP\ 3lp\81\92$ì[      \84\1a¼\16óWO@Ç\89\10÷ Öp\9c6G8k XÇD\87ÇEO¸ÀbÇx\1fU\87x\9fpáw|£ÕzÁU\ab!\1a\ 2ãÖ¨Uw6\82\99ÅÜ\r0\84\81ïëÛ;\ ew\19\84ßC&BA¤Ò\ eàÖ\1f4ÊÈ\r)àaîËú\84Â3\8eài¦ÇÅ]Ï\b\14\18J\85è\82\84Ô\13®\97'ër'8à\19ö±R}Òí\eý$\95R3qQ\9dÒÙ3Ñ£<\8d\1e\13#\99¼8)Ì\81@A;È\91\13iK\86\e\87´'
+Ú728Ù9¿üh\80\0\1d\95Û( li35\ 6\88ëµïÔ\8cë½Q¨éõ\10s\1að\12\b$¤w\94%fWV\7fQ\1d\85·¤z-¼%Ð×    ?\8e:\r\7f fE#u\8aY\f6£µ\12\ 1in\86s\8a\ 1\ f\1dm«À³@\eu.b@HB  \82>3¥\90wÔ!û¡Æ!\80¸\1d3Ë{©O­¥ûC\ 4\9a)7T4\81fU¨î\ 5\qZ\9c$q×ù+Ft7¯ ÆÀâ\ 4\9eCdI\84<\1fô´¯ºFû\17\88»É4ÊMR¨äY\1e|À²ß\9fäb\ 3\80íÎ
+;\8e\8a\v@QÀ\86\11\ 3:D\96{ýÈsý¤0\1fÊ.*.\88\92\11L+\85ïÙ¾\172;['æØ,ãt\8d<dÐÞ\9b\ e\8bç,&A¢p{Yá\16\v\r/`éB\185ù£ØvKFOË\ 3\8fJFÖ
+\0¾ö%Øû¤4\94\82¤/ÏÚK\a)m·Feç\95\7f0@~Ü÷î\0\97×à5 hF)\1eð\vÄXÝ\1f\8a¿¼b}Àx\ fE\9bòKÔJàÁ½ÙÉ}\83ç@¿\92\9dö\7f\ 2l½ÿ·@Á¼\91¾\90\ 3ß\86+d¿\bh²¨\15ï\83\86\9fònqø\83@XBÏÈ3%$ø7\ 4\80\13³\9fäfÑ\ 6\1d\87\93µTÁ\ 3\17`$\ 4xáÕÖ÷\9f-&°'úË\8aA&ÑÌ®g\fÜ}¼\98}£SW'_]@õçÊßÜ\7f= Vc.[±Öù]O»­\94=Tm\ 3pkÇ\95Z\99\ e\92\16l\95¢è7\7f°ûÉß\8a_0Q\81·BWa&µÖ<3\82åN\19\0\88±[kô¤ì3# *êáH\83¶Ãs©Á¤µÅ?\vp»¯·)F°Rú"¢=ñh5þMÉEê\9c\1fÜ+CÍ\13\1eº\foÆ1÷è\887\ 3XQ\ e%3ËAÜ\ 26<Ry\84[°|SÜ°Â\8c\9a\1fXÿ\8aÎ7Ú\15¹\14Ì¿\89¾bV'\ 3¤Îà\ f³åO\93cuþ\89a%öM\14\10Fk¶TçÂ\ 4\8e\80\1c6!tßçÞuhJ.¹6}Ü\18ª\1d6\1c\ 1Åô×\14P°Ör2ò\0ŨVöøÀ\81 ÅÞ4ø$í½tÇ\98³ä*\12\0\1c¡¤YRÒ\14âÇ_k0wÍ(\ 6\7fV5ä¬iî\7fIIá\90(|«\82\8b \9eÞçfâä($gÅ!ÄâNÕ\8eRÃBÓ>öû\12V¾cÒb_\18\8c¨÷l½³TÊÑ>µ\8f,L§\90ÿ\94\17ÿÌï\97\17ÿ\ 3¢ë\14!
+endstream
+endobj
+710 0 obj <<
+/Type /Page
+/Contents 711 0 R
+/Resources 709 0 R
+/MediaBox [0 0 612 792]
+/Parent 680 0 R
+/Annots [ 707 0 R 708 0 R ]
+>> endobj
+707 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [242.97 212.835 252.435 223.684]
+/Subtype /Link
+/A << /S /GoTo /D (appendix.A) >>
+>> endobj
+708 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [393.624 141.159 421.354 151.896]
+/Subtype /Link
+/A << /S /GoTo /D (cite.vorbis) >>
+>> endobj
+712 0 obj <<
+/D [710 0 R /FitH 686.127]
+>> endobj
+18 0 obj <<
+/D [710 0 R /FitH 592.328]
+>> endobj
+22 0 obj <<
+/D [710 0 R /FitH 460.322]
+>> endobj
+26 0 obj <<
+/D [710 0 R /FitH 195.842]
+>> endobj
+709 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F48 455 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+716 0 obj <<
+/Length 1965      
+/Filter /FlateDecode
+>>
+stream
+xÚuXKsÛ6\10¾çWèVj&\92Å·Ô\9c\127îc&I§UÓδ=À$$bL\82
+HÆu~}÷\ 5J\94é\8b¸Ø\ 5\16À>¾]h³8.6\8b\1f_½Û¿º¹ËãÅn½Ë¢l±?,ÂM¶Þf»E¶ÍÖa\94/öåâï \gëå*Ï·ÁÝ2Ú\ 6\9f~ûðv¹\8d\83ýr\15ÇqpûéãÈþxû~ùïþ\97\9b»í\85Î8Þ®a\93\r+\8bq«\8d\9c\12é*ÊaAÌsJ]´Ë\15è,µ\83o\12\ 6\9dî\87\13\92QÐWªg¦r\9a\89\93Ó\1d\90a`ñ "5\96¿\9fñ¬­»7\1d\" \93`_\99\8eEEkÿÙ\84Éqpª7­eý¥ê\95h\90i¶íY¤Pý×e\9a\ 5ÊÔê¾Öx\17¸Ç*\f×»4åÃã¾h\97ϿƯ\91J\82ÇÊ\14¸²bÁÐé\8e\ 5Õ\12/Q\8e\97-\99Í;Ô\ 3O\8bAc×kU®i·0Yï\92dºå¾Ò­Sx»(hÔ\ 3îEæè\98ÕW\9a\89N5BÁÍ\97Q\1eô®å+á
\19U³¸Ô\9d9ZO\17¦#ë$a,ÖG>Ø5a»²¤Q¥(ï[:éjî¨Æ\16õ\80\13Áï|0$4;Î8\19\9f\{¯îMmzä?1³ñfªy|hÝ\95\9a\1fn÷L\90Eó@\83w34Dad\87\8eåÊ\96BÔõ\95\8e\93AÙÕ\9ck{óM\ 2%Éâà¤\1cس\a»á8!Ç#\9fÍ\r\8c{Ów½Óªa~\ 5>\84É\10\85Û8\95(D¾\91õí¡×¢¢Óâ\12rH\86\91\ 2ÃÁ\96\ ebdæ`\18ź.Qw¾Í\83\9fÑEÉ\965'x9¸\14E\84Óh5\1aÐ\84æD6m»Î`8óì\16¿ùe\16²@Yñ\ 6J\ f\8e\83        µX¿\8dfÙxk`>\9a¾j\87~rê\8cO]q>\19{ä8\874þjÚ¡«\9f8\ f\ eºç¼áÄ\88½\93\12ï_8!\8f\8d=´<E<\e\aãÙe\8a \b\8aFG\"\91ÿÞÜ%»\vð\8a \8679À\13\9c;\14<üØöúû\19\9c\ 3\9cLF\9c\93\9c¤Yùf\ 2\87ë\f4Ê´b\99\86hØgÚÂ|\1d§~\96±¦7ªG¸KwSÇDÙ& @\ 4\81²ò\85¬ì\9drO<4\92ëju@ߣg(\ 2PvRdbÆ\föÒ*Ë×\19øhâ+t#![\b
+øs\11Þq¸A°       \83\96éº%\9fâÜ\8e¿ìº0\9cú\ 5Æ\95\9fqÏ)«e\13¾rm¾\91ó\81\81'\98MJ\ e\8aøìádâaðÝ¥\ f·Þ=\94Q\1dB4Ö2AÐ8\8füb\1cÄ\c\90\89ÒWÌwúË`\1c\9d\r\84\f\9e¸\ 6%\98L(\90Û¡\8d\8ef\89\95\8aÕS¸\92¾\1a \85³\1eâÿEü¬\95;b\96\ 1\82 á\928\9bÀ\f\fÇ\Wå\98õK®\ 5 =¶\88\11\10sûJÔðuYÚ\81¹\99kdþ@9/\97\a\0ÒåkD$Ð^c^\1f«éYÔ\9c\87ÜPëU{XõlóÆkÌó Ö]Ç\14\14\16ËT\98=¼cÊ\88Ì\81U\9bFËîÑV\0\1cE\7f¡1OÕºuÇïÆÙ\aí´-4\ f\81:7\133§;´uMUðQªrOÈL\115\1c\8fºCÄ\7f¹ö~\1aÐvi\1e°\ eË\83±\80\ 2ý\88Ù׺\a\1e\19\8bn\81\86\0=Ôc\89\94U¢4\13'g\1aJa\1cÔfR\ ei¿ÃÕ\821$\9f\a\8f\a\qu¼ãªC_Ëß\ 6\ eÖU\10îo@[\ 4ü~:OÉ<\ e\88¡\e°4!Ã_\95'\95L\88«em¡¤ç\ 1ºk±lÐä¦\1d¤a\9bq\v]/ÆN¥9ÕÊøÎ\ e\10á\ 5Im\8fÆj.Á(¡o,.D\8e\e¬\97\1d\156R¢upN_ê\1c\1d\ 64$\13ØBVÙÙ\82+eÓ\9c»\8a\bÀo@\9bE\0\7f¦1=u
+"!#ÃW.\ f\7f\ 6\ 2\8bP\92ø\ar-\85
+øàF\14kwP\85¬(5!,ÆûÑ\12\89ýl²  ~je)@\87´\r\88jQ"¼\97\1a\ 6;VU\8c=*£ [È\92sÆ· Ô\ 2#q\0\f\80ÂÏÇ\83îIJ5Ý\98g0\94~7¦\10X\82Z\v\9c¦N§Ú\14ÒC\91\18ê\8f^sõK¶\98`q\92EXÿàÀq\ 4!\9c\8do\10¸r\18¥ð\ 6ÙaßÙСó4¸m¡øÃ\10\13þY\15Ý\10êo£p,ÊXL.ð\1e\88\1aNHdE\1cô b\ 3ÖõªÔd1®E\88æÒ\96\86\98(2y\8aýØns\94@ÿ\8c\8bùÚoØ\99c+\85\v\ 5¡r~îľË\9e\v;';\f\ 5z&J7W\ 5\\98òF\ 2\8aßH@\14-D|Ñ×O<¼8lÉ\1c\7f'Zeù\výa­GoË\e      øg̤\90´\18\93~g°ÝÌÉçl\81+Rx7\8c\e§ç2\89\ 3x¤t\ 6lÂ'L±ïÀ\ f\18A\949fxgFi2A{zïm\83·<ëêQ\89;3Fõ<:(h0fÛþÃ@q\1ee©Ô\9d,eX\82æß\v&\96b\16\ 13\12/Ü=Ã3\8da\85Ã
+îjD\84\8d\ 3~¹ôj¿ëh\91\99~\1aã9£W-'\ 4u}Ì\eã\1dèKC\80\89Ò\88L\14g\91\97ø@\ 4\ e`kÉ«\18\ 1²ð| \1c\18J\9b\13ø\1fnOm¥\0\97¬\82ÆÄpÐáHÍ\86\ 6\0\8c¨Å\ 2\9fnàÚ\88¥I.\8d#\12ªè©æ ==(r|f\14ÔP çÃ\1f¿ï\99òAõ¼\17\87×ý:JÆf\[x\82bCNnMà}\v(Siø1ܧÃöðñý\99_=¹\8dÆ\89P\88¿ª\1aÔ=G¤$\83&4ô;Ò[+Lý\13=»2\ 6\v\ 6\ eËvað'\86
+K\ 1S!!\1c>\ f^û&\8c\ 4¶µ+K@)}¥ß\81\83|%'\99¦)l~\92'.<Þ¨\b'òo\ 2fy!Mþhúd'ÇËéxãß\ e\17¯Oyò\97ô8Ýa(v\9aWv\0H\$ù¥\88\8fq¤Æ\10Ã\ 1à\83´°\ f\18Ðd\14|\8cÎÃÌÀ/Fùçe|\r*ÿ¼\80\8es±âÉW0\8cõðºú\9dû`)\9d­¼T/ðP\1eªÍüóòýþÕÿþY0 
+endstream
+endobj
+715 0 obj <<
+/Type /Page
+/Contents 716 0 R
+/Resources 714 0 R
+/MediaBox [0 0 612 792]
+/Parent 718 0 R
+>> endobj
+717 0 obj <<
+/D [715 0 R /FitH 686.127]
+>> endobj
+30 0 obj <<
+/D [715 0 R /FitH 406.096]
+>> endobj
+714 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+721 0 obj <<
+/Length 120       
+/Filter /FlateDecode
+>>
+stream
+xÚ]\8d»\ eÂ0\f\0÷|\85Çd¨ëÄ\95\9d\8cPúbhQåN\88\rÁÿÿ\ 1\ f1 N·\9cî\b\9e@0¸£¹ºÏP°H\12°\aD!\14Q\90,\18\93\82Ýáê\9bp³sÝ+ÿ\8b\85\91\89ß\95¯Ò\8e\87\8buk¨\98ÙG\f\95jöÓlkHÙ/§­µi\99?\19G¿õ\9e\9d¹\17\8f\7f
+endstream
+endobj
+720 0 obj <<
+/Type /Page
+/Contents 721 0 R
+/Resources 719 0 R
+/MediaBox [0 0 612 792]
+/Parent 718 0 R
+>> endobj
+722 0 obj <<
+/D [720 0 R /FitH 686.127]
+>> endobj
+719 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+727 0 obj <<
+/Length 1600      
+/Filter /FlateDecode
+>>
+stream
+xÚ­WK\8fÛ6\10¾ï¯Ð­2\10³$EJTom\90\ 4)zH\9bE\80"ÍAkk×Bdk+ÉÙl\7f}¿á\8c¼ÖÚÛ$H/âC\9c÷7áNn\12\9d¼ºÐ2þryñãK\17\12«U\9e[\9f\^'Fç*äeâ\ 3ö\82K.×Éûôù¦º\1dë~±Ì
+\9fÚÅ\87Ë_\99Ì©"\14\86Èt²ôVù"\13\82\ egMº®×Ló®Y×\1d\8eý~5îû\9aÙ\84¤Tenó\89\89S>Ï\99Éå¦îúê\87\ 1tÚ¤õn\ 5\ e6¤ëfwÃ[ÕnÍ\93u}òﶧ\9d"]-\96 \1d\84I#ãU5ÔBÛíx\f¬\8fqG
+ÙÌ)\er(\16\15úKk{ªu©2;\9d\b¾euV\v|>\8aÌîZ4k>×í \16K\97\b\95À2YZ\97©\çÉÒ\18UzÏü\86z56Ý\8e8\14\1cV}s\15\ 3»sÓ-`å\1d/*>÷iòv\9e^÷Õ¶æi³0©0j«fͳn?>Ã,\80yCd²ÝìHóQ\98°9äK|>\ eBÀÞÇoR!@\ 52CÏõ\1f7Ý@â³ì\8cO`~ÕËß®¿©vÍ?õZ\1dÐe\9cÊ\n\ 5\18®P¾d¦V\19\ 4ÕX\9f¾\\94.\9d,ôéoÕ\ 2 »§\ fì:\8b/\9b\82ùüLú¸É[4\15\14\1eÀ\98        \beoàQ\96#\9b\r\9ftËu³­w\ 3BUµLWõ Â¯{^Rð\89æ!ø eÞp§\85\19\91ø\89øwo²gç\1cº\1fbàs\1dcíË´on61VË\r\ 2\12ã\87\9f\92\ e]\8f\98#'ª±æýá~\18ë-\ 50ÏÓ»fÜð6F\93Ê\91\ e\1cÉxb\1eÇø¿æ\8dVÐF\8aö˶¾\1ey\7fÕõ;Ô\87c\85%\89\v+,0\89>\86\ 3<øFôÇ]\1e\r\18íHÂØWý=ï0\bmº­"&ïyu\808\18vý¶\1a\85Ïݦ\89\0Ûðr?\88Ô\8a\aÒxrÔ\19ï\1eÜvð\19 É>c¼\8aË°ËöDä\8a¿0çÑ=üÜßÞr¶\1e\9c\85Mq\16S_?¢\10÷\90rH\80Ò9h\882küqM¤\ 4ô\92±\ 3/\98\ 1&\11a\92¡\14þ\ 3\féçþ\96Ç£ü\8e´}-ÔC}[õdzL\9e\8a\0Ô©Ô­\16\1e\ 2bK§!¶­võp\9a\15tf&"B^   \aïD\1cbÇÕ/õcqíÌÂQW\87X\1aÇ®2ì*.ÕæX\8eVYVNrþ\94\13Y\82|/²@'
+U\96!A\91\9d|©Oµµª(=´y8ôì\9c,UfÙ$ê¹\1cÐ3QÆÂ\14åJáru*Ê)Ü&ÉÑ\19ò\8d      ±¬\9e\8a´^\19c¾$ÓÌ\84ö§BQDqúè̪Û2B\11\12ÆÄpêí8\89¸\8a·V,\gt4\99\8e\80ýÎ\18À»ÖÎb\10±ÅZ4¢^Õ\ e\1dÏVUÛJ6£º[\15¢\17fwÐ94\9bB\85"Lº¶ûmE5Ù\89¬Óh\ 5e\8bì\bÆt6Þ\80\ 4þó\90tÈ_\1f¾\17'Ai\97\1d\87ì   \80h¥KûMÂúsÂ\9c\9f    \93´\86\959_Öd.;\9f¶Äùs'Ìýlr(æ\ fUcÓǺ1s÷\99²\81@\96æ`\8e\92"á´TÄ£\væÅC\91È\88ß\82úÂ\9aW\11-(ªÕ047»x9fñú¦Í\b÷ý¶î\9b\15]Ú´õiáɺ}ýl¢c\8aAZ\9cY\99Go° \8bþª\8dv_PvꤿIxòÇ«\8bä}<Fý
+\1d\98ºîÉ ÃÆãñÅåÅßÂÎ$Ö\ 6U\0z6\ f*dÉj{ñþ\83NÖø\87ë\våªHîâÉmRÂ}\9a0Ú&o/~çæ><êf\v\ f\8e> ³
+ì¾×¸\v\9d²Z£k\8få\9ct~3¥Á\13Êxª\94ùcm\1c\92û«µAz¸¬ÀhTVΪÁ\1cعʭýº¢\92?YT\80\1d°\ 1r<\1e)\86\8f\99/JûB\9duO&-|¨
+¤íÒÀ)¹È³ÿ\93¼þ?â\82Ì(\8aò\eP2{
+Îâc¬r`iB¦¼\13\13\1e\10?!û'ä±s\ fÐq\ 2\9dø\1fàjV\9cÞ' O\96%½:Q´\8b\aÓ^Sf\19ô\]ìé1\9bÚ\19L¥Ñ\8b÷d1]L\19?(6},)\91BJ\16Íù}A\f÷WCµ½\8dÅ\8aÖWS/I\87\84\1a£\rFÚ2\8cS\8b\8fû\91KС';º`b9(´t54!.y\99òK­\8b-#¶×M/Ï9j\7f½\9bÚ_\9cÜÖ\15?ò¨×®Æi&üî\9a5wê%³ÆÖ¦\9eú~\11\88æÈ+g\1aÝ\83\8ft\81Æzò\85\ eQå">\ 5°ØTTM¯y!z\81\80\1f²S\ 4\8d±\82b:½71\9d´ÆT\1eêT¥ã;ÃÄÇ(\19\0âØSøØSÄ3|\17\13Ùtïc*¯äGfìêOü\14\912}\bò¼¾&&Ç#=Gc\876ÊjÁ²\9f\9dA:ý\vá7ÿ
+endstream
+endobj
+726 0 obj <<
+/Type /Page
+/Contents 727 0 R
+/Resources 725 0 R
+/MediaBox [0 0 612 792]
+/Parent 718 0 R
+/Annots [ 723 0 R ]
+>> endobj
+723 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [370.603 285.708 385.325 296.556]
+/Subtype /Link
+/A << /S /GoTo /D (table.2.1) >>
+>> endobj
+728 0 obj <<
+/D [726 0 R /FitH 686.127]
+>> endobj
+34 0 obj <<
+/D [726 0 R /FitH 668.127]
+>> endobj
+38 0 obj <<
+/D [726 0 R /FitH 420.801]
+>> endobj
+633 0 obj <<
+/D [726 0 R /FitH 195.496]
+>> endobj
+725 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+733 0 obj <<
+/Length 1133      
+/Filter /FlateDecode
+>>
+stream
+xÚ}VK\8fÛ6\10¾ûWèH\ 3µV|èÕ[º\8fd\8b\ 2I·N/i\ f\\99\88H¢Cɻɿï\f\87²µ­Q,`Îp\86Ãy|üVYrH²äýê\97íêæ¡Jê´.D\91l÷       /²´(ʤ¨\8a\94\8b2Ùî\92/¬Xÿ½ýõæ¡\94KG©ÒB*\88\12\n?¼û´½\7fZo¤\94L¤ëMYVìöãÝý\1dmýùxwÿ\11EÅþØ>­EÅ>ßn??ÝcäU\16³¹yPUÂU*U!ð\8eÍ|ÉF\94p±¤«D*Ö\eÎEÎ>Ùf:y\ 3\9c=\99\83u\ 3eº¬(KÀ\9cª\9aÓéwÃz#\84dfh\1cH\15Û\99\1dî\böbwÆ\91qïuoH´Ñ\7fÛ\1aç5yÚ\91ö¼ùv²\9eÎK6ÅíÆò^ð'Æд¼ÚÝÔR\ 4=ÄC­±\87\16\18¤ÕQÒP\18\14\83ùs\9eÖyNù÷è|ê&{ì\f¦QTÌíi\1dí÷É\98á',+c½þj\87\ 3Yô@+\14\83W\99\83×\1dî\94\f6Jv
+A\9fC;\8c\1cô¹£65èòu$£yÁcf íµ51þÔ\1a\12\82wë]¯ßÔPP\rÇN\ f\98¼¬©Ì \8c§çQ÷PÕ\ eÐS@\ 3>8\fò\1aúH÷y(Me%\941¬âyZâÄ\16;c¯»\ eª!èf\vD\88\82\ 3Æó\19ºÇ\80¢uÎq\\8a\v\16eø¹\8e¨B¦e%æã}\18÷\8fPçF\8a<Uª|;²ØXH«\92\0·¿2®\ 6\ 4\8d¬T\0\rn\1f½\19M\18ÆD\e½\9e\8c·8&t{mÝ8\a°½\81úÝ0\92\89\1a\bÂàâQMú\12)dÀ\99¢%\ 2å\1a¼\8eö»éFè³\14\10\1a¯\10\9c\8d-\8db ÕÆõÁ\1eN\ 4Ò\15\878Yâ\ f            OïWÉ\97à#Rþæ\89Ã\150^¥2|P\14æx~Å xzÅAnt\14.\r\ 4ÅAÿäh&Òö\801\94\ 4`oÍÉG°n\ 1\1d¿¹Vggö\10A\ 1Ì\1aç\a\ 4½\82\82±A*¼BCB\84\15Ú\9eiÌaût\8c~\8el"Ïi\83ÚG2¶   W£\e\9ckKÚ\ e\b£\99 FIJ*\88       Ð0ã(\ 4|Ã!WÒ§Îd0üg;yí\7f\90\1a\19\9aââÞ\85aÂT\11j¡;HwÑ\85H\a%;¯#­\8d#ÆÐv\98\9d\rí@\19ÝùÖ©µÃ\1cêj¾K®\95\15\81P*ö\88w*Ew*lþ,]\90\ 1æ32ÔÌ\92(-\12\1cÉ/Ì\ eM\1a\ e\87÷\ 3räv\14wzÒáæ<@ð\1a=\85\\9d\9fè\91\89\9a^\8e¨cp\14æÿ\105¾MKtGjgM<s\9a\88¦Þ\1c\84Ê\\13ºãüK\9c?*\8b²Èó2è+ݵ½>`Ѳ\fÕá\9ceÍFG[Ô\10\10f\8e\94\86q"Ãå}\81Òxw¤\ e\84aa\0G\87Î\81.s\ 1å<\17IÿB\80§÷ÎÇ{vv\ 4²'`\ 3ñ¤×²'"ÈêEجº\84EC\f1\92:8rq\90\90§-ïºxÎÆ3\94l\86\98;\83/Fó.¤ÙÀW\ 43c ;.\97cD/\17\81\87ÇxßUÆ\8c]\91,Ò·õQ\9f1'Ïp_\12á¿×ûm$Q~þ\ 6ã%|
+\95yÒô«og#þ^Û¸yìyrçV¿Ãß\1csvÙÌ\117\8b\90ÿùô\13\ 2>¶røþ\12𵤨¸Hññ«\8eÿ\8c\9c\95³ßb\ 3õ\14'OÌy®\94Db ©\96p\91q®ãÿöbÑ\93\7f\0ÂF¾[
+endstream
+endobj
+732 0 obj <<
+/Type /Page
+/Contents 733 0 R
+/Resources 731 0 R
+/MediaBox [0 0 612 792]
+/Parent 718 0 R
+/Annots [ 724 0 R ]
+>> endobj
+729 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pic-frame.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 735 0 R
+/BBox [0 0 350 285]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 736 0 R
+>>/Font << /R8 737 0 R>>
+>>
+/Length 738 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c­XKoä6\f¾ûWè\98]tTQ\12õ¸\16èãÖfw\80Ý\ 2{)²\93L\8a\99\ 2ɦèß/%[\12my\ 6McäàÉgò#MR\14¥'¡$\b\95þ¦çÝyøþ\83\17\ fß\86\8c\8a\ f?O?\9e\1f\86§\ 1ÆßÓãî,~Ø\93x\10N:0\11Åþ~\18i@è(\95EOÄÑ  \13ûópóYüz\7fÿíðònÿç %¨h\82\bR9\1d¢Ø\7f\1dn~{¼{ùûù\90^'\8e]"#îè\9d\13\ 6¤Gë3\ f\93Ûe\1eïÅ.d\8aß\99\89\1f÷Ãí`¥×V£øgÐÖÈ\18\84ö\11¥\15çú¿\8bä«\11§áã`\8c²äw\93©\0\13z"çt@E¯Ó·\9e\ 6\83\8aýȯNÃq0\1a\95´\91È\8c\93\103\e\18iCEN\fÁ uâoZ×\90H®;B¬\93q&R\88\8f\83\8eN\86\bU\8d>ØX\89\ 6\18QC\8a^Óº\82 Å\ 4c3¿4\95Ì\7fz/þj!Ï\82,\9cEó#eH\89\875g/\eé=+fïßoÅtLÕÐ'ðràûl\15rrj#¦äT    )\84T7µ\8aA\83´~,Pt(Cúà"S\0.ô_«\18AK\ 3N\0F
+Qfó(\8d\8a\1595$\80\8c\16\13R´®!\88Ò\a\10à\95tj&S\99[\19\17½VÆ\8d©"U¯j]C¦ºhö\97\96u\$YD«nªä\15_/Ûè=«VY\19¿\95*\95ÌJ
+/\87¾OXe'·¶¢:¾¦\8fª@j\9eÙ4\80Z\ 6ÎW\91j³j]CÀ\18i\fó}i+Ùw´\8c¼g\99@tÒ¬\92G *\15\95Ë@Z2iûk¦\17fjí-K-}>\95£\85Eñõn^4ѹÅ+o\13\9eÜ>Wòv1Þ}\96xÙmE\95Ý\9a¢W»c\r\8e\0\98·e\ 4êÅyX\0 ,`E\98\10zM\ f.T\90\19\93BéæL#ò\9af\f~ÚÊ,\95»O\9b[EhÈ\92*m\12i%(Zl+Ȥµ\8a8
+'jBhò¡¹íÔÙÊö'=§\9dTys-\b\92¾2Èôz¤h­"\93}\fZ¢ÓÌÇ&3-\88*Zã^\9dg!½]s¶7Ò;Ò\99¥úÛ\8a*ÕßJ\ eûØ÷ùé²\91ÜÚ\88*/\v\93¦\fÇJÞXZb\f9q)ç\9cÔ\9eKMÈ«&d:4HãI\97¦`ãò\80X\10j:^ç      ÙÓ;½\8a\8cZëH°Ò%¯°NÚs[£ýQ/M¥Þç¯)L\96\8e\e\ 1¹^\87\14­u¤Ø\aÚù¸×Mf*ç*Ú\ 2_\95[HoW\9dí\8dô\8e,ͦvº\11ÕX7}\ eûØ÷ùYf#»µ\rÕk\86\8bÚ­ ¦õÒ\1a*¦m\84¯â\1e\18\80Ò\1c\1cu(åxS,"­\97¶$´¥ZJ­-Õ%Ò\92°\82\94&P\93¹´ÕõÒV|Ëî:ï¥ÌÙÞHïHg\96õÒ·Rñ^Ú²×G¾KÎ2\15¬\91¾\89\87\9fΦp\1aå\14        ¥üa:÷>\1fØñ¬DX£÷\92\ 6\ 2\88c'ÍBÿïÖ\ 5\9c\97Ji\11d\8c\81ì²Ë\12ñéñëËqvµbèè\89z<Èù0^­üôüÇù ~9<>\1có\1dJe¦\ fóù¼êéØ\8aL¶ç\ 5\9bîlhî¢c\99·zæÅ
+s\9aÜC\9a`0\87¼2ç["#u
\ e\14\rg`\97×D;°i\8aC\12дõ'ÇHàË\8dúN}yWï\80n\87\7f\ 1¶dÇ\13
+endstream
+endobj
+735 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (pic-frame.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+736 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+737 0 obj
+<<
+/BaseFont /AHFVLI#2BTimes-Roman
+/FontDescriptor 739 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 117
+/Widths [ 250 0 0 0 0 0 0 0 333 333 0 0 250 0 0 0 500 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 556 0 722 0 0 0 0 0 0 722 556 0 0 0 0 0 0 944 722 722 0 0 0 0 0 0 0 444 0 444 500 444 333 500 500 278 0 0 0 778 0 0 0 0 333 389 278 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+738 0 obj
+1099
+endobj
+739 0 obj
+<<
+/Type /FontDescriptor
+/FontName /AHFVLI#2BTimes-Roman
+/FontBBox [ 0 -218 932 683]
+/Flags 32
+/Ascent 683
+/CapHeight 676
+/Descent -218
+/ItalicAngle 0
+/StemV 139
+/MissingWidth 500
+/XHeight 460
+/CharSet (/F/H/O/P/W/X/Y/a/c/comma/d/e/f/g/h/i/m/parenleft/parenright/r/s/space/t/u/zero)
+/FontFile3 740 0 R
+>>
+endobj
+740 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2964
+>>
+stream
+x\9cmV{TSg¶?1\92s´HoÉdHªMÒ§:U\a­ÞBíÔiQÛ\19\eE
+(\81D    $@\ 2     $\90\ 4Èæ\99@\80\90\aá\91ð\88¼T\10\15©\15,N[ÇjkuÚ©x{×\9d¹µw:Ìí\9aï0\9f÷®{°wÖýãÎZg\9duÎÙß·÷þýöÞ¿ó±\88µk\b\16\8b\15\9a$+\94¨¶'(
+³å«ïÛè\8d,zÓ\1aú\196`ùߢVö\85<CĺÙ\e \94\r¡k{6\85\16\87£[O!ï\93ÈôO\ 4\9bÅÒØúc\14Jm±,Oª\16oINHÝúòËÛþïËÎèèhñ íß-âý\12\95,O.~\89y(\95\14(\94\85\12¹z¯8\86Y]P ;)Î+Ð*¥*qvN\8e$gu[Jv\81$_|PV S*\15¥â-1[Å»"#wngn{âd\85'JTâÇ\99\8bã\14ÑâXq\82$¯¤ »øÿ[\b\82\10¤\1d->¨R¿S\92}2Gr8÷H\9eTV\98*Þ²u[$AD\13¯\11\89Äf"\89H&¶\12)Ä[Ä~â\0q\90\88$Þ&v\12ï\10¿"~MÄ\11Q\ 4\8bXG¬'6\10O\11O3ä\11k      7ë)\96\92õõ\9a\925wÙqì¹µÙkgB¢B:8\\8e\92óGr\8eÚCÙ×Ŭ»±îÓõ?]\9f¾¾{ý#º.l%\17¼+k¼¬\95Ø\95\9fñpµ\86s¥¾Û\ 4\19´ò<\1c\82\85üìkqKª)ð      Àë´\a\e\ 2\r|\ fþ@C~\çÖý\a\16!\16ÞÍÇ;qò®g-µiµ\ 2\rÒ{Èøf­\1dzÁéì\1f\9fAO -üo±8xÌ-\ 3\9d\0´\15F\99µ\16\fÖ*+¥A³\1e2¥U×\9eµ\80\93\90\9f\8f^B¿þø\9e·ã£fÁjb\9e\15\97\85~»Ì^I\MN¡áÌY]5 \ 2£¥ªZ\87\9fÇ¥|¼\ 5\15\eºÍ.p\bÀÝÕ6ÒØ\fíàh <8¨!/Öwé¿ÇÏ¢\b\9cÄÇo\91°Ûh\8c¬e\82\90»\1aõ\1dð\ 5\85RH´\ 5\95.~3à»ÌÄD\ fÀIÿÂËúâ>ÛF?Íëjjkè\0ª¿­"S\84\9bH8j2\1dª¢tÈä$ßn*wÂ<\85\91©Y\7fk\9bÅè\10\1dæN ú\9c®@°Ô+Ë\96«÷\1f\13ý\81´4¦\94äU\1eÑ\bÂè÷Á\83\16Ï¢¶    \8d'üOË\11\)­B\15<¤S\93U{µº½@á\17Q1'ÐÒê\17¢M\1c\14\ 2>\9dk'ÕÏ©CÏ\87<
+p¸w5äçæN=\1c \1e\1d !ÊP¹ÏÂÀ  zÈ7\9aõ]p\9bBrô"ù\15¸t\1d¯Qa´Àè«òÒ;¼\95¾ðË×Qô§\11Ümè·è\ 6¯\16m
+1pêë«MV¦\10\ 23\18\e\r-\14×e/)i.ÚøzBZLâÈÉ¥tÑ©Ñ2\97
+
+\ 4\99ù\8a4YA§O#,í¯î­\9c§*pd'ÇÖÞÜÈ°Ã\8dm\83®ú^3ãÀ\1cð׺7ÞýháÓYUðð\98\b\13\1f)ºuýà\17\9c\19\ eÌÌ\ fÉvõ
+Ãаq\8e\ e\1d        ïD\16üîý\bî\12²Ó)<îÍ\97\10Åi·6\99\85¦jsµÉ(IÊJ¯¨¥¸K\ 6\93Ùdy\1aê\1aê\9bê)îÍ÷ñ\15ΫCY×.MôÍ\ 5\85\95\8eÒârc \bruþß\88Ð$É]ú3çqë KÓhÜÃúë2ººÌF\12\84yL­á¶Ãq×Æ4Ç°\86¼kr\18 æ1\91¯\1a«~±Jä°\87üeke'ܢР   t\15§þ#\v\1fyÁ)d\18]g\HðÒ¯¹ô]á·î£\83\f6\17­\9aåY8\19\ 6Ç\8c\b=Ä»Hn°\9c¼^×a\84£\14®"AaÑë\rÊ\92\82ªB ròO\9f\13q]èwø%=y±®K\a\19\14n!_¿\98öÙød·ß/\9c\9a
+\89"¹±Íõ³Þ1Çå.¦\9d\8e\18ç\13\16h~_øÕ¯Ñ\96¯"¸çé¸Oxåú*\8b\ e(µ©kZ\84\18\bs\96A]_ÉX\96ç\bPÛß<\16«ö\96õöõx}ÍÖ\16«MTßfµ\83\8dò\8føÎ\òË\93\85q$ÞñnyM\96¤¤L/\83S\147-v:sqúlÏÜ¢\90Û\99Úâ.=»ñ4ôt\8cN0&üó¯yP`©.­Ré\15Õ¥@I\15§§DÍ$\;;\866LS«\19Þ¦C\ 6YýwÙôs(\92\97~ O\95\0Tä¡/\11ù\97\ fn}5ÖiÈm\17µ\96Ø\15nm\ f\b\ 6|\9eÞ«\a.¼z,­,ï\84èh¦âmx\9dÂ?ýÝ\ eÄ>\7f¦{xLèïóø\87®Q«TÏA7½>Àò?@e÷Ùè;#\ fm\9e\vé&µÖz¨\ 3\86a\9cþ\88\99½ôr©ñP¹ \82´7´\82\1d¨ñ6ã   \11\8e$%#JÇIfàÈ\1d\8cÈ=\87\7frg7ZsuÂ{á´è\10\89XkÁdª2\1a´eÅF9PQI_¢'QȥϿxÿÒñ\14Ñ*¬\9bH>\82È1\16½\rEñÒ÷eÉ\ fA\ 2d\rÊçµ\13¦`ý"\85\1695\1f\e\a\8bG
+Ç2zRá(\1c×JdÇO(÷C4\85\85·÷ òÛ;×\10qN\88ï¡m<ǽÓã\8b°\b}\8aÎÝ\14Ó¾ú1ú¿ÇX§\11\87~\ 3qØè¿V¢x8\11oÂ/à\8cí#\91WâE\v±ÿ\9aó\rPè(Ú\84Ä(ãOò¥¤\ fE±7_\1d{\99Á¾v\ 6f´cùW\8e\ro\aü\ 4\1c©<X\96Z]\^¬VK¥ïiS \ 3ÞsK\87SgNý\19\10\e\96\ 3ß\9d»@MN]ò}\0Ô\8f
+¸y\ 4e\aX\7fax½Î\8c&~\92\99Ì\ 5ÏðDO\97\16v\17u\18]@õzܽc\99\ 3\87ßMQf\14\89\8a2kò¬{©èüßã\e\1cxËP\15SËèd§\93\8cn28à\ e\85n 0òGýó\9dA³ã\8cþ}¿\8c*\10+\82[\80ÞCÓ¼\81z\97u\0îÁ\95ö©¾\ f\16á\13\9fP\ e\9e\9cÞ\1dØÎ\94ÉÅáº\18ñ«i7þ}fk\8cûL?\8aßëMº.ø\8câ\16Ð¥ký6\9b\1fm¼~ü\85\9f\1d9\8aÉ2}C£ZÈ´\v\96Ï£W¼(¢\1f\9d\9al     °\ 2\9f¢\8a»þ\0\9b>Eóy\93o\90e k*³\95ØùÊveK\11P;Þ\8c\89\8cõK>9%ÒhµåfË)ye\19\94AiGÕÙ²ý©ÊS\90K¥ÜËüöν\81ssÂ\89\bLÀõãçÞl¼V~Jcq\et\8378ê··YmÖ&ðÔwZ[a\1cÎ8\87ýÁ\80s\14faÐÒ«\1f¡°éÑÓ¼ éKó% þ-X\99\17¿/\a\87¼\12?8Ýkë<7+jA\7fä]\v\8cÎ\f\ f\94\17v\vÝÒ\8e\fÈ¡\12åÒ\8cÃÙ\1f?\\85ÅÔjã\15Ög÷Q\1c\9dè!ïÜÌ\90k\12¨Ùþ¼\ 3"|\8c\84·\8d\95ñf¦\12R'\99Ün¶ÃM
\93?d_yíH¶êp\86\10Í\93\96&YUqMb\85@Y\13RA674A\vPSö\9a,Ñ£|\12\ e\98«ãk\98ý\ 5N2¾ÕØÁìgô\9b\89ú\84\8b6,\87ß[þgFæ~@1t\16\ fÿ<)DÇ\8cYGcgC\e\bú\1eÿ5u$Ä\18\r\aW»Áè$\7fÕRÓ¾ú\9bB$\97NC¥<¥Z­PøÔ\81Á^ß`@Ý+\17\85­x\18ïÏ̱\1eÜG±«\17ÛC?Çël²78\80\1ah«H\17áV\12\92õºD+ã±ØI¦4ê\1c0I¡Q\12\1aíí6[\7fï\94k\14¨i\9f\94\90\84D\83!a5¸ÚI&4è\p\9dB-äÐTÐ=\ 3Ô¼[\19%Ây$$ÔÔÄ\9b\98E
+'YÔXØXé\86I\ 1:A¢õ9\1f¾\11\9fV\14\9f,ÔÎËüÉ\90  
+}T,u\8745¦id\86$\9d ìoû\rÞ\95\r^\16s6eN(Ç4\9cË\16·\ 1\94Pj.2*ðSø\ f|ÌGÿ^ßRí³6        ª{Ì\1ep@_oû\95Õ\13\8aWCÎ[Û«Oï\rFóÅx\14¿@\87\9aܵ\8f\8f2¾.Ûå&fI½\86¼lqjÇ·£äG§ùN\ eÚAïE»\1fí\rqr\96PW{\0±Ð\ 5Ï\9c£íýv¦0MÌô®¼àe]|ÀF\17\19Éx3½°(7cÿnéfÀë\0sÇ·~óâÙô\81\92¹ü\8enþÞß(F\95wT7\f_À÷ðCçïý×\ 3×\87Æn/Pÿë\ 4¥?`Oà\ 3¼Ï/\ e\r\8cÏÜú\97Ñï\ 1­\ 3ô\93Üï^Y>q±È\97:RUÁÿ2Ö/\rü²ï\1dÇ>Ø\fÏWF)ã\14±\85y1ñ«É\98½\15ÿ\19\8e"'#¸Y_ãgy7\82ç\17áCjV:ù\9e\96  ¹=ù½\9a±V[CC«\90\9bÕh\ 3hØho5×ä+r\93s\19\89­Ó\ f¬\84\ f°ú\1e¢Î\87ldcà$Avy®4>Q\82ÉÇxXA¼îBâxæeÕ\ 2\\86)×ØèÂ\a\13\88\ 2´\81\91èY\1c!¬+âÝ?Ïè»\ 4K2Å{ödþ\15å éyÄ~ 
++óÒ)^\94äå\f­_zbÈ\1e\1aºä\ eÝ@\10ÿ\ 3nÄ÷u
+endstream
+endobj
+724 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [275.371 569.919 290.093 580.767]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.1) >>
+>> endobj
+734 0 obj <<
+/D [732 0 R /FitH 686.127]
+>> endobj
+42 0 obj <<
+/D [732 0 R /FitH 668.127]
+>> endobj
+577 0 obj <<
+/D [732 0 R /FitH 154.45]
+>> endobj
+731 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F48 455 0 R /F70 508 0 R >>
+/XObject << /Im1 729 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+747 0 obj <<
+/Length 1406      
+/Filter /FlateDecode
+>>
+stream
+xÚ\85WKsÜ6\f¾ûWèÈ\9dñÒ|\8bjOucgÒvú\88Ýé!éA\96\12­´\95´vüï\v\10\94ö\99d<c\91 \88ç\a\80+\92§D$o/®ï/®nS\9dd<sÊ%÷\8f\89\14\8e{\97%Î;.U\9aÜ\97É\a¦¸æ\8be\9azvýÛ\1f?ÿz·Xj­ÙO¿¿¡ÅÝß\7f޼ǥ\99Îÿ½ÿåêÖï\89ÕÚsÐ#H^\8a\f\17"\1aquk|"\r×Æ)ä]Fæ¥Já¾\9eMX,¥T\96]7\1dè\92¬XÀ¿Ï\ 3¬SËò¶¤ÅÝv\13\9eöÇÜ'\96       Ð£¹±\86ôÜäÅBy¶ÂÛ\9e\15\ 5A\19Û,$kò¶¢]=\10ð}X,\81¿\84Óú¹.«2\9e·(eìH_*ö#l3.´\9f\0\ 6Z°ï\9cm
+â gÎî\91tzb\94f_hÆ\95·\13çG!Ô©4)¸rrâñ$lS\7f©\9a\ 1²kÁê\10,°;\84àst1ï+Z<õ\1d\ 6\17\8eÀK\90\ e\81\93)×B%\90\18\9eYK\82g×!\7f\9a\993Æ*˭Ͼm,xnÓ\89Å\90¬¼ïs\94ý:оÈ\9b\86L9
+±3<UÓå\ 1\8c\11\10B}3Þ\16\80àÜt1\8fj\86U\87Z_ZÚÖñ{[?m!4\88d\fªHú§\84\16ïß^$\1f\80G\ 1\ 1ÔA*\84Ú\0\8aw8\v\9e\10Îp¹Ã\19îVù@¡\96Vq«\8fC=b\8e2Íf\ 3q3Tc¤"`2rù0­pH\15\83ìSRû³Ü`¯S\9a½{$îqUÑ\82Ìï»uNû\r\1a=\90\b\82L\90ý0äë\rdé2¸!\ eí\a\10\ eHG¸a¬`ÃX7\rÑÊ© \90¾C\15\1e\9d-\ 1h\17N§ß­\81Ôì×\0J{h æ³Ói\b\11êÄøá9ÕÈ\8fP#"C\9b'[£Ñ\92\ e#\91\1e«\17\94\80±Äíqä)\95ÐÞ \9e\8eC\91\84\ føÒA\11XUѺÙ\860Ãi\b3bH;v¿\8aÇØ\83RÖmÛ2ïë\90\ 4 \86ìÃ\8dÓì\ 3\91²/üaö\83(\80ßQ,vVù\98\7fX\ 4\93ösêÈ\91M\ 4¯·¬\fr\1c\91\bmUTÃ\066¯D( §³®\ 6\9dm\ 1¹&ö\97z\Ññ¸ê\86HDo\88TMWÁºU\8f\99\94\9cÈ\ 4ÃKØd\96Õ\87\97Ü>hÏÀq\86°ÆÂCùÏÈ_\11\85\1a}Uµ´ÝA\9b\1f\94øñ÷æ>¶\a9ÏVe\ 5×Ú%Åúâ¿ù\10ÿ\9f#\½[«äMwñ\17üM2'\96å$q¹'2Ìô\ 3Ì\eÁ-\8cX%=̹\98¦Ø½\82+Ð¥~\0D\19\9c\9e\ 4%,½¡îZ\1aê\ 1\97Óç±Ï×\15\9dìª2Dè\ 4izê3ÀKH£ÚÀ=q§3ÌÎ\ 5\11<ħ\80E\a¹sÑöÓ1¥Lì9¸(\10da\10+C¸\85þ5\86\ e\89ª:"\94õG!5Ôr\8bÄ\91\88]_Vý°\7fÓDÄÃâya\1d¨©»mä(«\82\(\83O@ÙôÑ2´`à±Þ\rÏ\8c9\84\1a\95®\97Ц¤é±{h/ðUq:Ì ñ\9bt\1eí=\ e¯|\18C\87\11\0þ@@\ 3\99äNÌcö\92:r\8d½®\81~Õçc\88\11Ø\10<\85ï÷&\1a\9a\88ï°Ó\89f}
+.\85G\11È\89\19\88»j÷¢òò\b#³~
+\940\ø£Hõ4Û\96Ø\0\9fpN\1a)(U\97Ø\bqhäýX·OxBîà7$\ eY\9bnN~\15o7ÕãH\¡ÉïsGx#-`\17iÔ§\bì\84ùmT\aS é`y~ºaÌÓØ9ºqÄN\85\84è\13mhJ§\13\98¨§\8f×\83Aè©\84Úë\9aÙ\9bð\ e\8b
+Àµ×\ 31)4Û/ã\19uÛM\14µ\vZ°¢ýº\v\14/,Ûª|\8a´©-D&3\e\8aÄj,\bþ3ú\15÷Zï¡ß\98\f\9e*E\17blüyð;ø\15"æ§\\81\bðá?Üt&Ô\80úJ\r\b.33ÝÇ\1f1\99dïZÒX\10\14é\8d\ 1ÖÌ\90JÓÓ^\86\f4ðáf\1e\0\19¤L)ÀõÞL\8d\ 3_ru\ 4ëCù8Ð\8dbÿÀ䣶c©lÒP6°\9bC«üa#UîLÛUnj\87\8e\8dôf¦IÖǾèؤ¦\8f½\ 4i\93ÿ\1a\84\ fõºnòx@¿cÎ\8d¶ÿ\ 1\ 2¥\8er
+endstream
+endobj
+746 0 obj <<
+/Type /Page
+/Contents 747 0 R
+/Resources 745 0 R
+/MediaBox [0 0 612 792]
+/Parent 718 0 R
+/Annots [ 730 0 R 742 0 R ]
+>> endobj
+741 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./superblock.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 749 0 R
+/BBox [0 0 356 296]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 750 0 R
+>>/Font << /R8 751 0 R>>
+>>
+/Length 752 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c}\94ÁnÛ0\f\86ïz
+\1eS`aE\8a\12¥k\81mçµ¾-;\fiZ`kÐ5ð>þhÙ\8a­.(\f\84    ø\89üù\9bÊ\vx$ðã3ÇýÑ]ß*<þv\82ÊÂ\11þº\9a\87ÛÏ.3j*\11\88\ 3¦\ 4\94       \85Ä"ÛÏ\f§\83»s\9c\ 4)KÏô\88HÄXV\b£\97Ð3\89\15SP\b>aà|N¶\9e\15jz\16¨     º\0IVTáNµ\ f¥\97´@\8b¦3Ô4­¡IÓ\ 5\82\9a©\87¬bgÒ\ 2\9d]:3­ÐÊ¥Vç?'×.M²W\ 64h­è<[ëÖ\ê\15ÉeÙ½ß}·Æôv÷\1e\15\14Éãf½Y(µ\91c\88\163R\9a\v~\85\980\15\82\84÷o\8f\ 4\89v\86\81\95\v\96Ü\8eÌ,y\fþýò\14\83ⲯcN\8böLë\99#af¹\¨5{\1fjê£\9aܲ\82¦X¡é¾\9d\1eÝ\8b£éû\1cöG¸\19ì~f0G(X\9dáÁM÷Ö>±x3\9c\97\18\b\86£Ûì6þ\83ß]]\r?\1c\9c\148\8fë\90`¸w\9bO§ïÇCM\9a¬`É-{û' R³w\7f~\1dNpóô¼ÿ       »\8d¼ÊTh\eí\85Ú\ 6nU0\92reók®93Ñæ`(èÕkMÕ\ 2cr\14n*8\8fâ\1e\1c\a1£L\90"\13M,"\8e¤\87-\8d#\81½\9b@1\ 1Û\ ep
+u¦\99ù8¸/öü\ 3@§ø?
+endstream
+endobj
+749 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (superblock.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+750 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+751 0 obj
+<<
+/BaseFont /IBUFPP#2BTimes-Roman
+/FontDescriptor 753 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 0 333 333 0 0 250 0 250 0 500 0 0 0 500 0 0 0 500 0 0 0 0 0 0 0 0 0 667 0 0 0 556 0 0 0 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 0 0 0 0 444 0 444 0 444 0 0 0 0 0 500 278 778 0 500 500 0 333 0 0 500 0 0 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+752 0 obj
+459
+endobj
+753 0 obj
+<<
+/Type /FontDescriptor
+/FontName /IBUFPP#2BTimes-Roman
+/FontBBox [ 0 -217 775 683]
+/Flags 32
+/Ascent 683
+/CapHeight 676
+/Descent -217
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/B/F/S/a/c/comma/e/eight/four/k/l/m/o/p/parenleft/parenright/period/r/space/u/x/zero)
+/FontFile3 754 0 R
+>>
+endobj
+754 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2473
+>>
+stream
+x\9ceUyTSW\1a\7f1\90wu\90¶¼F\88h\92.îZ\91ê\19\90NÕ"êhê°/¢²H \81,l\ 1\82Ù\10\bÑ\eö-\84@@ö5 ¬¢ÒQQè>X\15m\15éØéb§­\9dÎÜǹþ1\ fÏé\99\9cwîy÷~ßïw¾å~¿Ë"\9c\96\11,\16Ë%T*\17gl\vVÊã\14Kû­´'\8b\8c\86X¾X¿¸Çy-!j`¯\84.lèâÔ´fÅ674ó
+²½\84
+^&Ø,VNE«¿2U\9d.M\92d
+7\86\ 5GlÚ²eëÿNvøúú
+ãÕ¿[\84ûÅ\19Ò$\85p=ó\93%\96)SåbE¦\9fÐ\9fñ\96ɤ§\84I2uª$C\18\97\90 NX\82\85ÇÉÄ)Â\ 3R\9945U\99%Üè¿Ièíåµc\e³ì:*\95Ç«2\84/"\17\1e
+EÂ`q\92J\16\97þÿ\16\82 V½§LM? \8aË9%\ eI\91Éw
+}6nÚú\96\17A¼A\ 4\12AD\b±\81\b'Þ#¢\88ýÄ\ 1b'!"Þ'\8e\12\\82\88åÄ
+b%ñ\12ñ
+áÎÔ\8cp":\89ßXY¬;Ëü\97\r±ÃÙ\8f\9d|\9cj\9d}\9c?ã¸p.sh\ e&\rä\14X\ 1\ e\ 31¸I\9b\\17·ÃÆ\9c\ 1úñ@N£\er~\86\8cÏv#Ò\9dJ¶-næRÖ\1crÞXk\80ûÀó@\12îÓé|L\80JÎA_\93÷álÓ@\9f£Ç>\ 6'à¨ú¢¬SÞ\9eZ{¸~ÒÒTÝÒ\ 4(Yk³u`h5rò\9eÂûø¾ø       ÷G8nth\18ø\8d\8cöS¢Õ0,+áTf\8a:>ÿÏ\10\1cÓVõ\bÐ\90\13R\93M\15UVþ(\87\92!r:ÚûOá1Û\ 4®´)¯\83öî`u~\83ê¾a£\12:\96\8bWymÁ|ìùÝzä\86Ü\9eþ\eñ\91ûö\1fð«\ 2\9d\92;\7fs\v^\8b\9dO\1eÜ\9b\90Ør1K \9c<ý78\v~¸43Ëg¸°Ü\96Û Fò¼\1eÚõ\96ÛÝy¤Zp§\8cUôZn\95¹\ 2VAÐW\91w\ð\BÂ\b\83\10Pës\91\91¤N6\90{ͺ\1aø!@;Èþä\96¼a\bÐ\8ao\91\13Z\87^\ ex²9$&=,F0G\16\16\87eIt¡¹<´y/·ëºcüÎå=\18`ö±½þÇ\83\1d]|W´\0­ô\9fì¬{óì
+z5·®¤Ê\\vAkÕé\18\ 1.!aTAÁ\11=Р\ 2+y°$×
+o\0¤"{F®´\97W\19ójøõÚ\9aB\v\ 4-V[Go\96]\1a§ÈÜ\7fLð-i,\ eW%é\ 2sx®ô\a°\11M\ f¡ªA¦£?=s§$t\ 6:ÍE\9aLRï§ÖøA\80סtNGYy;\1f­á gج±í\0­\1c\13zÃùy\a\87\9aË!ï\14Z´0\0<\ f ¡\8fA·Ç\brPo#ùn©¶\ eÞ\ 6H\81Ö\91_A\9b¦v7XjÍT°\9dÞmÓÖ¹ÍΣ\ 3óî\94\8dθÂ5rN\18\ 5è)ö&©Þ\rÆT\9b\a£\0Ö\93PiÔj\r©*\99^\ eABJß°\80²¡\a\96\9c0Õià  \80ËÈw&"¿\18¸PßÞÎ\1f\19qö!)QéÙ+vGÍÕ:&½À¼\eÁS´G\8bÛõGhãWîÔ\18\13n®VoÔ@\90YP7*@\11$\9c4vjZT\8eØÆ@\b¶í;&Ê´g\9foi²7\97\9e+;W!8[u®\12V\80ö\9eæ\8b\97Û\15aü£$~ëýÜüX±*[+\85É\80\8a\14\8dÆL\8f\ e5MNó)KDYCÖ\90g\1flªí\1fdLxû#.\94\19Ïdé3´Ê3Y\10H\94}#\82R\12Þ\1c\95£K%\81vúm+\vu¯B'¬\1c\19Ì®\97\8dâWQ¤Ç#äÒØÞUßcæY±·\86ì:[]\bµP¯W¥Ë\8c\85zµ.[k÷P\ e«û \ 5ÖY*ºÌÀ\8aOiªÈ.X¯ë>þ=~Ó\ 3s°¯<>¯ ÙÄÓ uVR©/³\94WX-vÁ\ 3ôÒ?°°´°¸\10\16ò º (ù,XªÕmÚ¹\93Õ:Ǧ_G^Üè\80¤\8c`\b¼\8e|\89È_¯Í~å°\18\12«\ 5åªJe\83º        òÚ\9a\eÏ_\ f¸ôÇc\91ÙIñ\82¨\18åAø\ eÀ«\1e¼\85Øc\17ë»\1düö\16\9b/x?G\8a\1eD:XôVäÃ\8dÞ\13«8\ 2\83al§â\86z° ÷ì4@Ó\9cü\8fó:Ó{ä\8e\13M\110
+\1eW\8b¥ÇãS÷C_\80ù·w!ò\87»7\111ÌÇ÷ÑVnÍý¾\81i8\r[\94\96\9d\fý\aZ\87ÊNã!©Ýmv\ 1i\7fq§ÖÐ!\8b>Ü,NQ¦Á\90\vó`nin% zë\12\13+S<caLn²B"SÇÁ\bè7\1a\82\9c\ 2o\8b'ã[ÅUº²,\98\ 1\ eE\9dxÏ[t\r¹Fñ39]XâÜÌ¡D\8dæÚ:«g\r´\155\160L\9aÁ\8bù\17=\11ùäÁ¯\ fC?Æ\1e³\82קâFá_ÁµáÁ\99±á\9c¤~~wJ]Z} 3(K\1d¶Ò>VÖCf\82\17Ù\\8b¹Ê\\rAoµ.Zð<\8b\91\r\93É\7fi\82uV2Û|ªXS\aûyHD"!þKIQ±©ØTbâUæ\95\14B#8s¦PÏÏÑ \85\95\13S"k\8c»\8a·¡p\8fÎöÙOfÆ;+yÖÒºb\e\ 4\95V\1c«å\8WSÄ\\97ü3Z­\9eÑ7W\ fÚ\87,*\16ë\15ùA§yò|gWÔ\r­¬\7fγ\e\99\98Ê95æZs%\ 4=ÕZFÌÒH\18¦Õ\89\8cLT\ 6+)*ÕWÃk\80þ\9eÁGä\8aó\ eäò\\17\e\99\9cÖN²\16æ\91héc7Ò¯s-%\95æ\1a\bÚªNG\v\12\87\1cÃ\91n%Ã\8b55ð\ 2@ý$,®¬®¨h=?bë\87`´Y\12 Àr\12\86\18\fÁE\8c\95\f6klp\ 6 2²k¤·a\1c\82\e\r©>\ 2\9cDÂàüü \ 2ÆIi%Ó\8aåź\ 6x\81\87âI´"áÖ»A\91iAa|õ\ri{\18\8c\81\8f\bÜ%\v\8a#s¤\86P\rïÅ\94¡\r\1f1Bê\86Æî¿;çN}GË\18\9d[G\aÅpð§Ï\83\9c\8f >ìGR¿Ì!¿g\1c|è#..à \ 2ô\94)T \ 3×v,ºv¸]¿\17p\a)?\ f½çNÍ¡\11\9aäþôAÿ0ü\f<ô¿µ\ 1³v\1fò:ܨøm;\9fz\82        _\95ìàêÍ\ f\ e"gä2÷ɯ|j\ eÎI/ã\95ß\0õ\9bÜ/"Z\92`\b8|òäá=\91S_\7fÔ<<u\89\7fy\8eë=\954\ e¯\83©±¡\ f?\e\899\10¬<\19\eM\10\16\99\0ó\12,¾igM,°Ñ\ 4s»÷EËÓ\12Oìß)Ù\0ñr\88©\81M\7f_7\14ݦ\9aL©­÷ðûPÙ\9fz7ãSÃ=ø3üÍò°}¦c¦Ëq{êw\12\14½À\1eÄ\ 1Ü;\13]m\ 3ã³_÷ÿ\fÑr\88^Müñígñ\13\11=úÓ\1e_\8aÚ%\1d{[\ eÕì\81\eà\e:\9fÔ£J\91<É?\88!))´\9fþ\97\eòºàNÅ>¯q?í\1d\9b\86·À\15É\85\93\92\8cL)\9fjJ9\9fã(¯0\9bËùTlq\ 5\84fÏÊòÂü\14ebX¢\80Á\e\98\18\99+OO\93)ZÓ;»ÛZ;»ÓÚäK\8f·¶mÑ­\8dÕò\14Y\9e²Q\ 5\93i(\8cËM\94\ 4\85\881ù"UV/^~)d æjÆ\14¼
+Gl\8eþ©k\83\b\12 8/ô\1a\9bÒ¸ócØ\19\8b±8F¸kWÌ\7fP\ 2\92\8c\82À5ÛN\87ÛQ¨\9dÓµâñ\1fº*]\\1e7¸¬$\88ÿ\ 2ϳÂ\83
+endstream
+endobj
+730 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [341.506 619.822 356.229 630.67]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.2) >>
+>> endobj
+742 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [308.795 177.902 323.517 188.75]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.3) >>
+>> endobj
+748 0 obj <<
+/D [746 0 R /FitH 686.127]
+>> endobj
+46 0 obj <<
+/D [746 0 R /FitH 668.127]
+>> endobj
+578 0 obj <<
+/D [746 0 R /FitH 230.411]
+>> endobj
+745 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F70 508 0 R /F14 574 0 R >>
+/XObject << /Im2 741 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+758 0 obj <<
+/Length 1659      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XKsÛ6\10¾ûWðHÍD\b^$ÈÜÚØiÒKZGi¦\93æ@K\94Å\89Dº$UÇýõÝÅ\ 2\14iRª_㱸\0\96\8bo÷[\0\ðà:àÁ/g?/Î^¿K\82\94¥±\8c\83Å:\101gql\828\89\99\90&X¬\82¯a2û¶øõõ;£ú\8aJ³Xi°bUÞ¾ÿé·ÅÅål®\94
+%\9bÍ\8dI·\1fÏ/Ωë\8f\ fç\17\1fQÔá§ÅåL&áç·\8bÏ\97\17\8c;4Ç\9e\17\8b3\ 1\ 2\ f\ 4à\13,\92*Ð*\ 5|I°Ü\9dýÝ\râïTÇë\ f;\15\9cWg¿Ã\9f·éUæÞâ¼gr\14\16©\fã:
+47Lj\17\96wÅõ¾Î½ËêÍl®u\14^fM\9b×Ô[Õ«¼.Êk×ZS\1c\85\18ÄQ±DI\1fÇÒ©è\9eJÂDÚ\ 5ú/Îå\84\19+y\9d\1d)\fx\95\8cÇ©W¸ÚV³9p°D"¾7\93$\ 4s©9Ó*
\8a3#\9cÓµw/æä\1e\89ëÊ        ÷LC&D2
+¿\14í¦(I#ÏìØ\86ZÍþÆêç\93ï¿ÂN\13n*lÝâOþ\8fý­ÝÈ}O¬\8d̲\82Âr\99C\9f\b\9b|\85N\82cs!X\1a\8c\85\94È0£Çûb{åÀ´Ô³Ü×4\1f5o²\16\9c/qîT\87Åv»oÚ:kÁ¸\1döæ\b`T)Íêk\97\8c\97\10ׯVG2=\b; ÁX¥"ü°\1e\80ZV[\e[\9c~\9b\95\ eÉ\8aÜFï°YVíÀ¿\98ü[V%¢o3\8bÌpk3N¡\7fw³ÍÛ\9c:\89\ 2C\14\18O\81Á\98\9að;½Q\95ôl7ºq#5=ëâz\83/´Ôl\8aUÞ` `\1fè^j²]îßêV\ 6ô\17Í\14;M\v\11¦¥³\a\ 2_ÑöÑ\14\80ý\8eºo!­Hʬ£w¤2N
+\}û\161Q\83\10\81êº&HÐGÔWûr\95ÕÎ~µÛ\15Àø\8aYxB³Të!ÆÅ,\ 15çE\97\ f.D\9b¢!É{kã\81á/\11J}à\ 4\1e\1e\89}1k»ÀØ',E\12n\8a\1fùÖuÞ\92;h¢\\91 íV\r\10' v¯ª4Ü\0Y\90n\1aÖÈÅa9Â@íV\9amT\98\89Êó\a\1dÛý.#éf&B\97\8dh.sv\15§7&\18H\1dJ\10\12R\1a,}è\1eæ\9dM\1eM¾M$\a`ò{/-w 3¦¶ó¡¡NrBM'\85\83¤!ký\ 6S\1d\8c\18gDuF\86\90Õx·;\96'_69® \19Û=ÉnI\8dÝ6 §p#K²µòý6k0
+8af£²¡\91á´}+°þ6@MN²ã\vFýÖ\ 1\9d\10\14×¥\9f\f9\1e§\8eÛGÖÕvKAí\ e³¢\\15ns}3y~À¡}8\88%\9c­ð\1fÈ\bÎO8lá\8cýú\8d\a+\18\ 4f\99J\93àÖªî\ 2\ 1_\1e\11|\81ð`\e|\82\ 3{hD£\11\1dÁa\96\9c2\ 2ê\14|²1>ÏÁD,bx&,ö\1c   ©À\1dÉ9H²\93¢N¢\r\97Ò\ 6 é§B\1a\1cá*R\80I\f1ÁG\85\80cÎ>b\17é!\ 2#\98¶o=;(Ê\18\16%æ^PLê\ 3`\92ñôZB ¹yÂô\13¼Â§\90\10êExU13\9eUÞ1(:)î$s\82Õ§\ 1\9a\80èá\9c>? \1d§½\80\98ÎycN0úèÉ'\96»\92,\85oÙç-w      \9f\9fQú¬´\888\8bRðIj¦´ÛÔ`aK\8c\9e\98çi\ 4Qá'2âiX¦3¢\ fæá9ñüht9Ñ\a \84ñY!N­óGO?A(OXÂõ\8b\10
+u\8dJ\ 5¹ \1d\91Æ=\13O¨8AèÓ°L\13Ú\aópB\9f\1f\8d\8eÐ>\0!ºe.Ò\13\84>zú1¡"\8dY¢_f\85r¬9]N*G¤ôDâùlì®}\9cÑ'\82\99\8fæÁ\8c¾@8:Fû\0\84è¾E\84>Îèã§\9f`4Ñ,I_d\89\8a$a:!\ f¸#TxBµ'4:AèÓ°L\12Ú\aóp>\9f\1f\fÏg\7f~!º\8fLHìãt>zöñ9\8c6â4zÌ9<¾\194\11\850\8a\19÷W`ïm\11&¥«\11Q\80 ÿAâ?³\bÊ\8cí\1eË\ 4l7®xZ\16ë»{o¹«$2@ÏÛMá+Ó\81ê¨\90\93]é¶ß®\9c\ eMD\r{\vÔø*~²6^ q-䡬Á\ 6V}ølýèhjì´å'
+b¿Ã:íÊ]¨`u\85CK¬\93ÜeLAzÕ¾Ák\f\1c]×ÕÎÍX:[îÖ\aEWºY Õ\91R\18\86%\ fËüG\8bW¯<B\87î¨\13o\8aì`Õ\92PçMîÄÖ\8dý\9b×NÊü\88·Ù´Yíúl8$ïբزðì¬:üP6m\9eáM\8dÖ²+)ïÁíÂÔÑä.\82t
+á_ÖyÖØk-\9dv÷WÃ\90á\b\85\f%7ËýkÕ\94Û\ 5ç.<ÿt**\88YjT\82*\86¥\90ÿ¸/D~w\1a]\9bÆL\9a`ÞÓñu4N\y\0¶à\1ec\80\85¢âÃ\r¹Óà\ 3\bBBp\98N\9dù«1\ 4Ø\ 4\rì\ 2\a\9d\11\84äH\fìüêÿæ\17\ 3\0õ±Zþ?YP\81\92
+endstream
+endobj
+757 0 obj <<
+/Type /Page
+/Contents 758 0 R
+/Resources 756 0 R
+/MediaBox [0 0 612 792]
+/Parent 718 0 R
+/Annots [ 744 0 R ]
+>> endobj
+743 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./raster-block.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 760 0 R
+/BBox [0 0 342 229]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 761 0 R
+>>/Font << /R8 762 0 R>>
+>>
+/Length 763 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c­WË\8eÔJ\fÝç+²\9c\19©\8dízo\91\10\12; %\16À\8a{\99\11\9a\1e     Xðû\9c\92ê<JjÑêEZ.\97ÏÉ\89írýì\99¤çü;?¿\9dºW\1fBÿø»ûÙq¯\9a¸?uyá¹3V«?ÃÒs÷ÔyÃdÕ÷\92\82!Ip\ fêÈY3Y\9e'\8b²0¥l)»Z\96À\9eXrä¤ÄµÏ\1cù©ûôпt\96\82Zuý\9f\81\1fÞvÖ(y\13¦Ýà%\88\97l\15ïc÷\1e\e\1e·Þa\17{Íxfóýa\8bÉ­¢?\81o ë\8ch/\81#yÛ;ï)Iyüú\1f..X2Þ´\D¬\90\86¦K^\92Ør\99¸ähÁ4¹ì»L\\1a.\85˾Ká\92\ 1#\94mpi¸\14.-\973\97\86\12(±G*4¸4\
+\97\96Ë\99KÃE5¸\9ca\8dÏ8¹ì«[\\1a/]\Z\¢m\8a2¬· òz\8bå°¾ÿ¢×v4\rJÖ»ª£\15ËÜÑ\fÊU]¬êµe)u¯Iȸ\8bº\9f"\97\8evn_Åun_óæܾ6Èî\82¬©Í°h]·
+õt\85Ö\12¼E 
+S¢K¨\8d*^±Ì\98eWÓ\12M¢X˵Ä\9a´\96\9c%ÖWZK´)çÍ¥Ö[d÷@ÖÔ.´¾U¨«´ÆQBÆÖ\98\8aóÇÖñ\8a¥Â<ïjZr\80djî\v¬Ië\94\12
+§ÎkÑh\96Bo0ÝCXóº\14úF¡®\11º\94\81ÂÅHT,s\ 3I\8c'\ e\8b¹\90Z\96R\901zò\12*\9f9ò¢\81\14×¹\81Ì\9bë\ 6R\91Ý\ 5YS\9b\ 6ò¯¡®Ñ\1aù\8aÚ\95êû\1aV!W7ëb\99¿oÙÕ²\18\92d  4       \r\ 3N\1c­2Ú°`¬\8b\8b¤Þbº\89°&u\91Ñ7\89s\8dÄ&\ 4\8aè¿Áa·Í\80¨XJ\98;<\8e|ä0\0\ 4\80 p\r\99\84\ 1TH\18\92wºma̺\11\81\80ã®K¨Id#ÎPì\8d\8dÄN2\85ĹA\a\8bq!\96\^3Ý\82X\13[\82Bå[\85ºJh\1c:6a\86\89\8a&\99KV\9d\e/1\18mò¤\a¥\1d\93\83ö\12Q@,C\f\9b\aNL>È\80\107-ùÃ{ðAd¦à\a\9fK¬Jit&\1c\86\82[L\86\ 4     ¯\84\132»"­µh½&»\ 1²¦¶\84ÍZß(TÖz¼uýz\84è2þ??¾\9dú×G\nó5\82\8c\89Ú\1f¿wã¥\17\85áQ)xE¼²ÉÏã©û|Ç÷\aë\98ïäüÔû¯Çwc\84H\11ß=\a\bL\8cq\14©aA\ 6Aÿëî\88èþø£;\bNk˸p\8a¡\ 1p^[ðPL½      \19t¨]O\a\19ÂDrl°\88Ï`<\8fkZ\16\15·C\8fÓì\90\e¬e?î\1cá#¡\ 5@ <\11£\ fä\95/w/\aùrÿ0x(º²Á)W\0²ÃËÃ9ò\9b#>òûî/Ãþ/ª
+endstream
+endobj
+760 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (raster-block.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+761 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+762 0 obj
+<<
+/BaseFont /SHCMPM#2BTimes-Roman
+/FontDescriptor 764 0 R
+/Type /Font
+/FirstChar 40
+/LastChar 110
+/Widths [ 333 333 500 0 0 564 250 0 500 500 500 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 778 500]
+/Encoding 765 0 R
+/Subtype /Type1
+>>
+endobj
+763 0 obj
+933
+endobj
+764 0 obj
+<<
+/Type /FontDescriptor
+/FontName /SHCMPM#2BTimes-Roman
+/FontBBox [ 0 -177 775 676]
+/Flags 131104
+/Ascent 676
+/CapHeight 676
+/Descent -177
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/asterisk/m/minus/n/one/parenleft/parenright/period/two/zero)
+/FontFile3 766 0 R
+>>
+endobj
+765 0 obj
+<<
+/Type /Encoding
+/BaseEncoding /WinAnsiEncoding
+/Differences [ 45/minus]
+>>
+endobj
+766 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 1221
+>>
+stream
+x\9ceSmLSW\18¾\97\vÞ\v"N\3ꤽÎMe\8aA7#L÷a@§YÃB\ 1\92b\v-½¥_\94ÒööcP´ñPi\v\14lii\81ò%+à\16?V¢\8ea6\97¸,.ê6³ Û²lQC\96,;\97\\7fìÖmÙ\8f%''ç\9c÷=Ïó¼ïs\ e\8a¤¦ (\8afV(T2}¾X­\924%÷;\98\17Qfc
+\93\8b\ 1öàJp¥0-\17\11\85°5 \13\ 3\99©\91\8d©O²al\1dô¬\85Îç\10\fE[}#Åj\8dI§h\907\93Û*ÅÇò¶oßñßÉ®¢¢"²Îôo\84,\91é\15\r\16nÑ"£Ô\1a\95¬©y\1fYÌeS\94â\14Ù@\994r=)\91JeÒäµ£\12J¦$\ f)(\85F£n!·\15ç\91»\v
+våsÓ\9eR\85ªÎ '\9f)'KÕE¤\88\14Ë\1a\f\94D÷ÿ\b\82 \19Mªmùy¯î,ص\eAÞGJ\91td\14É@V#k\91uH6²\1eYÍõ\ 3IEZÐ-¨\12¥ÑOSb)7°M\18\85Í3®,Æ\ 5\ 2Ì\86yôÁ",YÄ\82ÌK<ï¹ÞN? Æzè\13\13\ab\87µê\fACy\0¯ê¢ûÀ4\ 1\13W¢}S\80\98\e¦\8e\bY\19\ eD6óñd\924\80\9fðØûÀ\1c\ 1Møoµ\9f\1d¨¡Ìï½+ø\1ewºO\98\14\8e
+\v?k%Ì1æ^G\97\16¡(9°0GÚ\7f®;I\1aë±T\vY/\ e*­tùY\ eO\17À\8fºi?¸HÀ8\ eÜݽ>ßÈÐ¥\818 .Gå\a\85¬
+\aå\ e\878IÝ\1cÀÅ\9dô\0¸E@\ f>qi*t\15\10\v!M¡\90\8aho/srIê\0®u«Ü¶\10¸È\87u8Ì\90~þVY\95¶¬R`ZP\8cV\82Z ¶\16\8a\88{\9cÞªVN/ÍÏ\82K+/\ f¢\89%\f&V
+y\aªUÚú\9a\92×å[\ 1\9b\ eØõ3y?½òquÌp]Ù\17ÌÙ÷¥:®¹§ÿÊq\1f,\83\7f\18½5vkbú\9b\9bD\16ó\ 5ÔÜF\99I¨áÝ~Úy\ 4ÿ\a\15V/a³ìAÞÝÄDlæê\9d\1fãË\0¦\ 3ø|ýã×~¯Kh£Ç.Ø-9\ fD£ò±w\86\ fûß\ 6[Áf[¡¦T-R5\14\97q¨®g \1da\fv0\95¼N³»¥£É¦à;MgÌÀA\18\83æp$\14\8ex]ý§û\ 5¶¸s\96ë£\ f÷¹¢m\11Óh#\7f\84\1a°\87\0\119\1f\88Æh\7f­O(õ*û´ÁvOÎÜXØwÙ7ëí÷\83\11b\88\ e¶Ðf\9bZ/Щt\ 6\83Ýy&'\86\83\98\7fÒ\eî
+\ 2?\11±\ 4\8dF\9a6Ú»LÞ\16Ao£\87\ 2\1aÂ\86Ë"­ÁÆiã°½Û\ 2\88VÚbÔ\ fZ\13\19çÄ\aa\9bß\99S§³tÔ´\9dl7Û\81\8e0\9c·E\83=\9eð\80`|Êãéöõöø<ñ(\91\ 5Ï9¸\12×-óT:-Õ4¢\e\9f\8c\8d\8cOjc*!W¾5¶\92\1dC\87\1fÁþG\18ôqöT\0\89¹^^V.cñgþ Slú'å3µ×ô7Á5pi`:~s~\16\12\0®! ¤\0nb_\10¸´¼Å+l\1a+ceµä\9e\7fB)\94_\81Ø\92ðïÏqãü\1dN\80\82óÿ2GÀ\1e.H³â}\1e\7fW\97\eèêåú×C+\85O\8fã ±½ÙÒF·Y]\92äÓ\1d\ fàû;-½ A0\8fñ$Ô}fè.
+\7f\185ÌåÙ<õb[ÛIÀgÛWÁý°äç_/Þ\aßñ\97ßøvsÅ1éz\81RA+Í%\91Ó9\1f=\99¾ð5 \16\17Ä{߬ٹw·\90\96¥Ù\99\rx\96q\909:\b+\ 6WMd<\=Ñ\9d\99ù0\94¹\ 6\ 2\97e>¥
+endstream
+endobj
+744 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [373.5 361.641 388.222 372.489]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.4) >>
+>> endobj
+759 0 obj <<
+/D [757 0 R /FitH 686.127]
+>> endobj
+579 0 obj <<
+/D [757 0 R /FitH 419.202]
+>> endobj
+756 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F11 573 0 R /F14 574 0 R /F13 705 0 R /F10 668 0 R >>
+/XObject << /Im3 743 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+773 0 obj <<
+/Length 1581      
+/Filter /FlateDecode
+>>
+stream
+xÚ\85WKsÜ6\f¾ûWè¨\9dé2"EêÑ[\9c6mÚf2MÝSÚ\ 3½+{5\91Ä-%Õq\7f}ñ eÙ«´³3+\b\ 4A\10\8f\ fP\96Ü'YòÃÕõÍÕ«·e\9eÔ¢.T\91ÜÜ%2+DUÔIQ\15Bª2¹9&\9fR%´Øí˲Jß¿Þ©*}ó\11ÿ?ìöy®Óë_>¼ùù·Ý\9f7?½z[­4åy%@uÆ*j\14¸Ê¹_{~\7fs%\81È\12\99ÈB\v¥L¢ó\1a\f©\92C\7fõײ\88ÿ[\8cWïz\9d|ç®~\85\19EöQã~¥\92\1c°¶Zæ¥0²JtV
+¥Ãý߶÷³oðº9úâÛÝ^k\93þØv·»½*ÓÆOì\8aÃìÿFÏ\ 4\8f\8do\87{^tw̽í\1cìªÒ\ 3J~\1e\99ùÐN§v`Ú²ü8\9fYûn/S¿µwÓ¥É>ÏD¡kxæB\97\92opîìÐ@\fM®Ò\9b\13ÚWäiÛ\9f»ö`§Ö\r\81\81Ö\14*\9dNvbÎ\14eùä\12O.Ùj\90»ó®çeÛuLÐAaÙú°yò\8d\9d\9ac\10\8d«ü:\ fí\84\17\ 1ã÷R\8aÚ\18¶ø8G×E+À'\7fïL\ 1j[7\a¿\9d}pH3\8e\8bø85çQ\90R©E­5hV\ 2Ò\975¿î¦\93\9bïO\10Ŭ¾\f\87\96\19[\8e«£ë\9b©í)\ 6#³ì\ 1\ fÃÛ $\ 6\r¹Þ©\9ey\14÷o\80\ 6\8d´\ e<\bï\8eUÀË1\1c9÷Í\80Dz\ 3ö\8b±è\86\82\8d\rW\87Ø\fÇæ\v\8ec\f\ 6\98Õ\ 6×\86,ZåÐE¾Ðn\b2Õj\99­ÓÞ`±Ö±Zm÷`\1fÇ\8d\9a\96ÂT2JµÓxa[Lâ\ 3\1f|\8c¦\91O\ 4\15Æ%×\85B\9d{Yg"W\90¯¥È¥Z\10\aî&\95IßÛ\ 3Æ8/Mz\8d·É%Ü\ 6þ>o\98\a)¤r\91\9b<\ 4\1a·\15i\1f5\94\98\97\ f\8ec`Ûad\8eeaÅ\aH½ö\13è¯ë2zà\8f,S\97\f £\8a2*(õÞâ9\8f¬\9cÐ\0Ø\97h\0Lr"\bA4%\81        ÐÝÜ[^¥\12Û\8ca-
+Y,1\1c\8e\e¦ÕÂä:\8apr\91\ fö\9c\82¹\ 4ÿÕæy)F\139ÑTe.­F&Z­ªb±\1ai\128\ 1LX\96ax\80ÚPµ!$@æxr\18\8f\87a­ÇDÔE\90c\f÷÷\ 1é?\ 2Ì}"\19%Ì3\14\ 4k\ 5\16^\r(\87GÏá\88\90\ 3[¶o`ÏÁ¢   E\99úæì\9b1\16)°*p+EñáÔ F \10£ Rcû\85\89ɱð\84²\ fÔ\12ºØ\19\85\rè\8fJB±\9c\89Û\fGÂ2\94\12t\11ªbõ§ \87ò\98Ý»q\8d\ 5\8b¡Y1\16\ 31"fÌ\10¡ÛÑöH\9f\81î\bà\8e@¡÷À\94\9bS\e6.Ï\81\9f±\\10ð\90SÐeIó\1cÌ÷ü~yÉ\Ã\15N-'\ 5\v¹¡{d5«:|v\99\0\84\97)gLt½¡\9aE\ 66\ 1¼\fÒ\84\8e®s\9e_c\vÔ²\8a \82\e/\1a\em]ÙBRð\94é\9dó}è\96t$w\7f7Oü\1e!\ f\11\8d>"b@è! cïB\ 3¦þ\86þ;LÎ\ad½s\9eW\96>pp\1eR\92=íB¢|u¬h\83^nÏ´»sa\96àìøz\9b\8c>R\e \85LÊ(\ 5\ e°Ý\18ä\9eZ#¾\91ï\90»\85\16zÁ¡ÃÎ@¤ð\ f¼\83ÿèÐ\1az\ 6³ü%\8eéJH³@\9dà\1eÌI\8bG®»\ f¾S÷aòibh\8e\96q\99\0P\81\v\8c~\1e¹æ\8bíÛ!\94$ÄÇÆ\ 4¦\9a_e=®¾l1(C\9e@8\88uË`\8e,\ 6ógRq\94@\1a\fg0Å\11\ 1((wH!÷\14N\e?.&âA\e)xçfªM¹ôD /\13\a\98Ð\v[ÊT ç0Y\ 1iù1ö\90PË\
+\8c\17£0px\14\ 6\ 6\95}\98úpk\0²!\9eÃÏÿÃz\94Q¢¸Äú\r¤x\87­µ\80\92\ 1\87ñøªc÷\ 4\8aà\8e|\8eoa\12ã\895O\a71ÿ\19\0ÐÔ\1aù037Sؽ\8cè\9eß/Æ-Øȳµ~\9a¤'wf\ e\15"0|{\7fz\9a\ 2_\84\fÃ@Р   õÀ*\f\9ckû@­>1\8cf¬Æõ©¥\82\ar\86r\fÛÃt\bÌÐÃø%¦\82Ñ\eC>\1e1O<¹B´B2"{1æΣ5\e¦ß2FÍÃÑúG¬h\98Ìñ\93\83h\95º¾\9d¦g}\a\80ùº9X0\99¥¹\\80à#\82\86\7f\ 2Eµn\10Ò\86\11ê \1d¨Øq\9bã'\9f\1f¤-?z\1a
+º©\85(nÙ\8cc\99\96y*\v\9cß\19wé[\0xüQ u:4¡à\ 2?z\13×ÎÖO­íx%¸\16ù/\\v×-*\9dþ>tíç0\17<I­[¦ÎÿKÍÖ\15\86&ÎÜdgÈÎ|å\ fj?\vT¯§öðÙp^¾v  \8bV\1f OcüÖ·û¿Ä\&å
+endstream
+endobj
+772 0 obj <<
+/Type /Page
+/Contents 773 0 R
+/Resources 771 0 R
+/MediaBox [0 0 612 792]
+/Parent 775 0 R
+/Annots [ 767 0 R 769 0 R ]
+>> endobj
+755 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./hilbert-block.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 776 0 R
+/BBox [0 0 229 229]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 777 0 R
+>>/Font << /R8 778 0 R>>
+>>
+/Length 779 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c­XË\8eÜ6\10¼ë+tËì\ 2Ëðý¸\ 60\f\ 4¹Ø\19 \87ENN¼\8b`&\80í\83\7f\12Ù¤H\8a\88Ö\82\ 1K[ÓÝU*QÝ¢¾Ì\9c\89\99ã¿xüt\9f~þèæ\97\82Î\1fßÇ\93¯/Ó\97I¬çñðé>ÿr\85p?\vÁ\94òr¾~\9eÖ2b\96\96Icí,\rSx¼Þ§ç\v\7f\86ó\8bxøóúëd,³AÌñpýkºÈ\87ë?ÓS\ 4ø\ 2)\84x\19¤käùbb][Ö}*#\\8cð}æçK\80\0i8ãò"ø\1a¤\98GåE\9d\8b\10H\9e\80ß\0\90\ f?U\8aÅ"ùúø|\11\1a\8ar¼^³T|w\9d>\80\8b|\962ðù¾8{\9b\96?èdùï6½NVq¦%\18è$ÓÖ@¸\ 3/\8dV\84Ü\bQ\82\83Û\1e\90\945B\1c·\8c\v¨\1cà¶\99PÄäʯÓ\1f\8fó¿\93fN\82-ó÷I+ɬr\94\ 4r\ 4\94     º(ó;\\1e\9f_zÒw)[¡YÄçÇBÀYE_Aæÿ½\aÞYæD\98±\8a\99\10t>\ 4      Q^y\16¤ì )«\8b\18Çà\81ÁKXeÕTt\vb¤V\8aqoQBL\ 5ûñÞ¯¶w\946\f­\88\86\13\1c?©Ò\11\9b\8dðLq3{ç\98°\1eµTLxOÈ-#*0å\ 4 \945@´\96 \v\10ã\99te\b\15\8e6§Õ\1c#ï´à)\15mî(Ýehe\11'Ø|R¥#6+\1e\98ç\ 1ºupÌá#L\88\f\92á\ 3\84\8f  \17²\ 3Ä\9c.\128\83î'¤SL¡¨\9a\88L\8e\91!\ 4xTp-SªWL\9bhr«³ahE´\9c`òI\95Þd²³Ð»J\8f½\81\13QR¶È\9aÔ\ 3¢n¯¡³mT¦\88­Å\ 2&\17\1eó\15{\18nÊÖ\16'\95MýFACXúû\ 3e\8e\98\9bº9Ü\19è\ 6¡\98\89  É3Qr\18\ 2a3Ý\ 6H\9a%\ 2Z8ô\81"&WN316\86\14\9a'aNF\8f;bwIZi\99\16|>«Ô¡Ù\17\9b¼°F2\837\97\10\ 3\ 3AÛ¢íw\90\98ÕEÖy"\fü\12|1OrÈvö¥µ{Ï©ëê\8e³¯UÚ0´"\1aN\9c}çT:bóÒe\14¬\1d\rwTâ\1cXz/4Ã\84Ü
+Dkx    @\84²\ 6\b>{\ 1\1e\rx\7f\82ѹ\89I\95£ÏØ\90\8dv\14\8a"|\99\89\94î3´º\12'ø|V©CFk­à¹Í½\8a\0jÃPØ0ßER·ê\0\12NTÑò*"2\99"©5çܲ7w\84\14\8d\8a\8a\13M>£Î!\871 ÞÕs\97Z\8cTe\aJHîR)k\88à+\90/\e\95]Fwµ-º3\nX\86Ò¦;÷Äî\91´Ò6Ýù¬R\87¼\ eð¼8]t*B¨\17/\¦\8bP«j\11Ð,\98ÕEË«¹²×)\94úsN.\etOlMÒ\13RÓ¢×'\95z\93×Ü\efmáu\80×\1dcDÁÙ")«\87\90\85o\94RLíu|UÎ\17\9eÞ¦+¯\v±5IOHM[zý\83¥\ ey\8dw\bÞ\17ó¶hY½\\14{\1eBh_DY#\ 4×\87Ñy{USe«cà­`ê)\9b­`Oé\1eC+«Ü
+\9eTéØ0\\e?n(\1d\10Ý  Á}¶Õ¢\98\ 5-\92²úÈ:dð\aau1drL5\10Ó\97\8c<¡ÒÇ\8e4\10[±-I+¤¦]fâ9¥Þ2\16ó\87+\1a\82ôQ*!ùÃUÊ\1a"qÌä\ f`5W3\16óç»´Ê·\9fïzb÷HZi\9bOwg\95B¯a~\19µl#¹Ç\ 6\14ÇK<|ý\eB\8cÓà \1a\85\b¡\ 5>O£\10ü   Þ?\a\ 5«ÁÊ\19\ f!-\83\90¤e?$iAB\ fÛÁ\81\96AHÒ2
+\89Z\ 6!I\8bc\81\83\ 3-\83\90¤e\14\12µ\fB>Lÿ\ 1Ö¾ä\14
+endstream
+endobj
+776 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (hilbert-block.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+777 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+778 0 obj
+<<
+/BaseFont /ZVTVKO#2BTimes-Roman
+/FontDescriptor 780 0 R
+/Type /Font
+/FirstChar 48
+/LastChar 57
+/Widths [ 500 500 500 500 500 500 500 500 500 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+779 0 obj
+1222
+endobj
+780 0 obj
+<<
+/Type /FontDescriptor
+/FontName /ZVTVKO#2BTimes-Roman
+/FontBBox [ 0 -14 476 688]
+/Flags 65569
+/Ascent 688
+/CapHeight 688
+/Descent -14
+/ItalicAngle 0
+/StemV 71
+/AvgWidth 500
+/MaxWidth 500
+/MissingWidth 500
+/CharSet (/eight/five/four/nine/one/seven/six/three/two/zero)
+/FontFile3 781 0 R
+>>
+endobj
+781 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 1244
+>>
+stream
+x\9ceRiPSg\14}\8f\97å)K\95øÊ¢&¯\9b\eZ\16¥\88{\ 5Ñ"¥\12\9d\92  ò\b)     \89\84°\ 6,\81\ 1ôÓâĵ,\ 6YÄ]Q\8c!U\ 6\91¸W°¨DªU\1cµ´vo§÷e>~\948Óé\8fþ¹s÷sÎ\9dK\12\ 2/\82$I\9f\96\91ë´ÊlO\1cÂO&ù)^üT
+\95ðzw¬p*\91Ð@ù"\1f
\b\1a§\b°?´L\84\9a× |\ 2A\91d\81¥%F§/ÌQ«2sÙ\19ëä\ef\86\84Ìþ/\13\1e\1d\1dͦ\15þ[ac9\83Z\95ÍN\esò8\8dN¯å²s\17²1cÝ\1a\8dz\13«Ò\14ê3\r¬2=\9d\8c­Wj¸,6N­Qëõº<vFÌL6",,|Î\98\89LTkÓ\8c\ 6ö\15q6Q\17Í&°rNeÔ(sþ_!\bbüÜy\91ïEÍ\8f\ e\v\8f \88I\ 4C¼N\ 4\10\81D\10\11LL$ü               á=v\ eB@l'®\91ËÉvò\91W\9aW\1f\15F\15Swøj?¾ºä\14ÿâª?\f\fq\ 3\ 1\92~\98\ 3ß1WPÓÖfóuã\199\8a££äñïëó-Í\19RmC\91¥\bѹ¦\92¼L\9bñ\8ek¨µÃ!st´:ÑmÔUìÈ>\9a\7f°`\9fâ\0-yÒïh9})øáêË¡)\8a¢,\95T«7m6~T[\15Øq×~ü\ 6¢oÙ\15  *\93*'G¦ÕêL+\rô\18\ fd\85é7ùÅV\7f°?Xâ
+\90\8cð\1a(fÞá\93\14"|{4I¸\1a\85bÉo.Xø»\b¯ºÉà
+\11TÀK¡GÃi¾w\88\ 4÷\1d
+>à¿e`£¨\ eÕìøÂÒþ,Ðl1å\95Uæ¡ Ì\890\89˶mEÛÐÖ Ê\9aê]ÇÎV\94vHA\9cÑý!\9aA\87$.[\9c_d9¨\95f5åîÉCtvÉ\96\1cÎa¸ÿxàP×EY§½±\17\r¢\81\82Î\94\8b\8aóò&<¾Ñú¤\8d\17t\92'F æ9ÅËÝË\18,*K*X¾\11\13KÖ`\11ÂÁhÞ¡¹¶\94vÅ%ÃuDÃ\84á\1fA
+\93\96?ÄbE^\ 5\97 ;\ 4\0\ 2Â[i\9c\86Ï0Ã\17cðDì\95\9e¸bîº\1f ´kW\9bµVÖXwt÷Iä\81+·òwï\91ü:÷,fT$Z\83§×\97Ûú\1aö÷  Ð\8aðÇ£#Â["Èt¿ùê(mn¿6ÿË\83\81®?y0@â\ 2\e/f~é>y\ eõÑ\8fb®NÇä\82Uañ\a²ÿ
+\95J\9ea"Ú¨Y\19<kh%\bÁÇõõ\1fR\89\v¹Ô\17°ïsºðmæî\86f\15ZKǧ¦Æ/Ýè|zóà9§CzÁÅD8U\9dè2í´wÜè³)âäºT9'­¬F¨ªÚC\18Êl¼ \8d<ò=uÅÈ\80`\7fÏ\81¾\v\7f\ e^\83       \b\10\1d
+ã0\83½#¦áÉØo`\ 1\10=çê:º¥i8
+S,\9e½\99\86+àfP~\95ùs³Î\90QªBôÒOî\83woÝÕÆVY½µeïaD?µGâE2\8fâV·\7f+Ùü\12ö¿¤Àâ\9eÏ$#eQFfÒZ\ e\8b\11\1e\870y\1c\8fs¬=­è28Q\17²Õ\9f:éìi\a\1a\81/\rÊ0x\ 3\aH«73\8fíX\889Ì)ØÈHÅß\90\ e\99\86=\0¨\96ïþò\e+ êa
\8f\ 1àUaÂ\12ñ¾\9d{kjv4Xêkö ºq·)K6\9a"F\9f\95ç\16\9b\92jå6Ú\ 4\87\8b\17ïA_ÑüObϪA¾é\1e /\86)^\aS\99Ò\9d\19òRsêØ\9b\96\8b`\11Ä>\e93\88\1e\ 4ýºÀõVò\ 6ã¦\fi\96Ú\94U\14ÛX\19xöçSÇú\11ý¸W\1eµøÓw£"d8\ e'    ·ðÁb¿|+¿Þ
+ÉVÑ\91ñO¼\8fìòñyÒàãK\10ÿ\0ö\85W\1a
+endstream
+endobj
+767 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [348.723 261.533 363.445 272.382]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.5) >>
+>> endobj
+769 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [434.087 177.024 448.809 187.872]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.6) >>
+>> endobj
+774 0 obj <<
+/D [772 0 R /FitH 686.127]
+>> endobj
+580 0 obj <<
+/D [772 0 R /FitH 419.202]
+>> endobj
+50 0 obj <<
+/D [772 0 R /FitH 316.593]
+>> endobj
+771 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F48 455 0 R /F14 574 0 R >>
+/XObject << /Im4 755 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+784 0 obj <<
+/Length 344       
+/Filter /FlateDecode
+>>
+stream
+xÚ\8d\92Ír\820\14\85÷<Å]Â\82Hþ±»V°ÚM[\8dÝtºPD\9b©@\ež~Á\80£#v\9cÌ$wrNÎÜûM\ 2XC\0\8fÎ\83rzÃ\10ú¨/\88\0µ\ 2,\ 2$\84\ 4\11
+\84\89\ 4µ\84w\17\aÞ\87\r%=uR\86\ 4eUÌÁ3\18Ý¿¨xâù\94R\97 Ï\972t\aÏQ\1cÙ«·q\14?×%s§jâ\91Ð\9d\rÔl\12×ÉNдsí\8c\95\83«"\0|l\90J\89d\9fC\929?G±Þ».zã\8cCT8¯Õj3[\8bß&ú'\91\17\\b\96\10(ã¨\8f¹\9dy¨×¥IÛ\91ù\9dç3ÆÝi¹ð|"Ý¥Þë­.r;t±²¾¹=Vf\9e¥VÑyMcWX!\9b'¦)\17\9bª¨¤¤Ö¿¶7\91ê F$G\ 1¡\80¥@\94\8a\9b\89\89«ÄÚDÿ$òò'Õ\1a\ f\ 13\86\18ï$&\1ab#½±ÈR³³L\92Òìë©\eka\96©Ñùú\1cå?¨\ e¾_½ûÔù\19ömù}ð¥¦ëÝ­\7fñ\ f\95\94¹\1e
+endstream
+endobj
+783 0 obj <<
+/Type /Page
+/Contents 784 0 R
+/Resources 782 0 R
+/MediaBox [0 0 612 792]
+/Parent 775 0 R
+>> endobj
+768 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./macroblock.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 786 0 R
+/BBox [0 0 367 267]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 787 0 R
+>>/Font << /R8 788 0 R>>
+>>
+/Length 789 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c}RMoÔ@\f½Ï¯ð\8d­Äº¶çËÓc%àB\ f\94Ü(\87%ݶj7,\rBåçãI²i"\ 4\1aE\8e<ÏÏÏÏó\f\84\f\14ÛÎ\9d_g¸ÿé¾@L\98
+ÃWKߺ\82!h\84\177 áú\83ã¤Èv_\12
+\92Äcô \94\19\99¡ß»ÏÆ2\96\aÌ\12¤Ösö(~®b\9fÑs\9aãPå\891\e\93\ f8]\95\10§XFȬ\87\951°¾Ê\88\8aö\81ä\82\14ü\88þ«ý\82ÚÏ-ʪûRá©ý¬ð_î0\89\10%#¥4\99\12֦Ģ&\19<³Aó\1a\93ÃÚ8¦À¨é\95°\8e\97d=^ªLKÆ\85\a)O\92ÇÅõ÷îÙH\87ÿ)´\1d\6¶v\85\93\9d\e\9f\ 3\831
+K\ 1±    É\8ck:·¹ÙÐ[º9;k\1e]!ÔjJí¨Z ¹u\9b÷ý®Û_@ûÐ\1f»\1dü8ì¾ï+tkÎsÅn\85\b\ 1|µkûã·Ã±}\1a06e©\8a·^l\ 2Ò\ 1syºæhu!Cóñ\94\12\ 6͵³åô·Z&Ôm\fÏGÐSþ¯&oÛÊæÔVì\15å²\ 2\1f~-¡ï\1a÷ÉÎ\1f?w°Ì
+endstream
+endobj
+786 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (macroblock.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+787 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+788 0 obj
+<<
+/BaseFont /MXWNJK#2BTimes-Roman
+/FontDescriptor 790 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 0 333 333 0 0 250 0 0 0 500 0 0 0 0 0 0 0 500 0 278 0 0 0 0 0 0 0 667 0 0 0 556 0 0 0 0 0 0 889 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 444 500 444 0 444 0 0 500 0 0 500 278 778 500 500 500 0 333 0 0 500 0 0 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+789 0 obj
+388
+endobj
+790 0 obj
+<<
+/Type /FontDescriptor
+/FontName /MXWNJK#2BTimes-Roman
+/FontBBox [ 0 -217 863 683]
+/Flags 32
+/Ascent 683
+/CapHeight 662
+/Descent -217
+/ItalicAngle 0
+/StemV 129
+/MissingWidth 500
+/XHeight 460
+/CharSet (/B/F/M/a/b/c/colon/comma/e/eight/h/k/l/m/n/o/p/parenleft/parenright/r/space/u/x/zero)
+/FontFile3 791 0 R
+>>
+endobj
+791 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2673
+>>
+stream
+x\9ceViTSg\1a¾1$ߧEÚ\92¦\10\97$­ûVÑÖ\19ÐZ\17DZM©\80,\82Ê"\81D²°C \v\b\89Ñ/a    \ 1B\80\ 4d\97%\88¬âÒª(:mµX\15µ\8av\99ÖÚiǶ3ße.?æÒvÎüè9÷Üsï÷.÷}ßç=Ïs\19\84Û,\82Á`¸ï\95ÊÅékB\94ò8ÅÌûjr>\83\0\8b\ÈD\94\97©-¬\85\84¨\8e9\17¹3\91»[ý\82\17\96\e/cÇ\8b¸è%\82É`äX\9aü\95)ª4i\92$C¸<,$bŪU«ÿ\7f²ÎÏÏO\18¯ú\9fE¸C\9c.MR\b\97Ò\ fYb\992E.Vdl\12úÓÞ2\99ô\900I¦J\91¤\vã\12\12Ä   3aáq2q²p§T&MIQf \97û¯\10®÷ñY·\86¾m\b\92Êã3Ó\85¿U.\fRú       EÂ\10qR¦,.íÏ\16\82 ¼\15Û\95)i;3ãrâ\ f½/\96$ËäBß\8dËW¬ö!\88\ f\88\1e"\98\b%\96\11áÄvb\1fáOì Þ v\12ï\11"â}"\88`\10<b>1\9b\98CÌ%^&xôä\b7"\8b1\8f\91ÈønVà¬~æRæ\98[\88[7\8bÍJg\8d³ßeO\82\ 5àcp\ 3î\85Ç৳9³Cg÷\91F\ fÒ\88ìä¼\8b\8c\a\93xÇ$³\86|\9d[V\aªD°Õª\8e\12P&\80Bò5\91\1aKì ²D]\85\\10w\81\91¡\86ªN\ 4Ï6ÊÞ\13Pb\80DÚÜ}3N  v\10Uª«Bg!V\81§1\97\1d\90åî\ eäß\aEæ(\954\7fo\1eÏcj-räô\90\8f{r\1c\9e\98õ\1c\e\9eoÄÀ\8bs¸vj%\97\ 1\93\86ª|´\r\ 1h\9bVëk\84\9cÃ9øKp\ f\8d×÷t¹:\9cCh\ 4\rªNËÚä-)U»j.Øê+\1aë!GÖÔ`ïé\9b\87ÝÖ\8fRÛø~Ô×Ü\1fаÁ¥¦Ã/§·\1c\12ÍCaY       \872\92\85ï!\18¥±v\bp\9f\e]e½Åjç\ f²92\fÆ¢×o\ e\8fY# §RÐJ®oe´}\83«¿aâb2\96K½ê³\8aâSó¿[\8a=±ç³\7fa>öZû=õ\8a@«äN^YE-¤X\a\ 3·&$6\9eÎ\12(/ä}\86Æá÷g®\8dóé\\94¼6·N\85å\ 5\1d¤ÇUÏ;\93\89\17Ç`%\17r­&\v²"Øe)Ø/\98\96\0\14\91\9f¿G\ f9Ks±\ 1p\ eÖ\81­&m%º\ eñ:Ð}¸± \1fA<ç[ì\86\97à\97\ 2¾^\19\1a\93\16\16#\98\0zsX\96D»7\97\87Wnå¶_r\rß>»\85\82\143j«ÿþ\10W;ß\ 3?¡1ÞìdÜ\9ddZÈyÜêb«©
+Á&k^\8c\80*\ 6h_QÑn\1d\8d]\91\1d\ 4\16çÚÑe\883AÇÀ¹\962«¡ \92_£©ÔÛ\10l´×¶vf9¥q\8a\8c\1dQ\82o\81Á\1c\9e\99¤Ý\93Ãó ?D\ e\87­§hD\7f|îÅ\91\90é8\8f\8bÕ\19@·I¥Þ\84 µ\ 4§±[KËZøx\ 1\e³P\83ºv\1dlb\eñ"Öt+\9b3\91\ 3nëm\1a\14\0§\ 3\0òÍ×n1À\1cÜé\0ï\94hªÑ-\88\15x    ø\ 2Õª«6Â\19hFC\9cäÆZMµçø$Þ9éÅ©%ÓÏq\rì\ 3ù\95Ã\ 2ü\8cZ\ f8\9d¹à\9a±ª\0í\83\94\ e ¥A£ÉOÉ\94éä\b&$wõ\v8µø>µT\ 3F\8cÕjt\0R¥àí\91ÈÏ{zkZZø\ 3\ 3,_À\11\95\1c;çtU\9e¯¦ÛÛSp9d\94ônô¼ô\b/ÿÂ\8b3D\ 6}ÂÍÕè\fj\ 43\8aª\a\ 58\ 2 \v\866uc¦+Ö±\aÁ5Û¢D\19Îì\13\8dõÎ\86\92ã¥Ç-\82cÖãåÈ\ 2[:\1aN\9fmQ\84ñ\83\0õÆû¹\85±âÌl\8d\14\1d\86\9cHÑ`ÌØ`_ý\851>Ç\16QZ\97Õ7¿\vÕWu\9f¢MÔÚG\$3\1cÉÒ¥k\94\10\94\ 6\ 4%\0]ésá¹\833#ANòM;\ 3\9f|\15\1f°³e(»F6H½\82\1fawGK{M\87\89g§Ö«Aû±
+=Ò \9d.3MfÐëTÚl\8dÓ[Ù¯êB6Tm³´\9b \9d:¤¶\82vT£=¹ÿ)µØ\9bbS~òø\82¢ÃF\9e\1a\ 3¥®ÔVf±Û\9c\82ûøÅ¿SÂ\12½Y\8fô<¤*:zøØoàt\90/\gÜ\9cÄÙ_1ñ\9a©Í\\839N\9dR¸_ËS\14²ò@\99©\ 4Y\10<m=\12'\98®\ 1²Ç\87\1f`ïçx\16^\84_ÜòtYPpRT6?Ü­÷\8cë½s\9b)\ f\8a\19½Û/âà\89\f\ e·HV\e£i\82\8e}¸Ñ\ 1Ié!\búì~\80ÁÏ\17Ç¿pÙò\13+\ 4e\99åÊ:U=â578N\
+8óרÈì¤xÁ¾\18e z\eR¯Þ\7f\ 33\87\9ctñ[\1aéÑ\\81\1eÿ\99\8b\1cSn\ e\ 6f\f\92\99S\7f!?ãNï£÷P§}û\8f=Ü^Jïá8$iJ\1a·Ùn\97A\a\15\r¨Ôi3\95G\9aYTT\ eû¡Á¦CÛáôJ\80\16kr|õt\9cnf\7fsO \7fBr\19À%ÓgXÕì\99&nbE\a\ 6.\ 6¹\1aûr£·Ä*v£\10\14Û¦¸¬:UÔyl\fâ1váÇ\ 5mi\1d\81ú\b´\ fíW\89¥ûãSv ?HñomÀàû;W0ÑϧîáÕÜÊ{]=ch\f5*moÁßÙ|þG\8cÏ'qÐ$\13¯ÃϸýÃíµ½\b\9ekJ
+\10PQ\0\ 5\16h\83õ¿ÓyX\85¾\1cÝ\848\1aü\1a÷ÑÆ=qé\1f\1càãËÀP,Õ¥\15\86æñRf\10+1\15£R\ 4\aÊ\vc\ 5ÓÉ\0\ 5è\8f\ 4\17Òñ2;\b.+¨¢ã\7fÿª¯\9dñ\90æ\97)&×f²\9a*\10ì¬ÐF\v¦³hR3\1aýgøEk\aÙ¦Cfu5êæa\11ÀBê\83â£f£ÙXlä\95\17\14ë\91\ 1\1e9¢×ñsÔXagÇ\14Ë\1cqç©58Ü»­eü\93kÃmå<{Iµ¹\16Ár;\15«a÷\1e¯<J/sá\11\8dFG³¯\87\v\8e\9aÅ:Eap\1eO^ÈòÀ'\91\9dñ\8f\83®©\8c]iª2\95#ØQ¡¡©6\15 0\8dVd «Ê·\ 3Q\89®\ 2]\84äS:>"W\°3\97V)\aÝÓÂ\v\8c'\93X4s1\1d´4Ú\8aËg¤±Ù\9a\17- Êfr¨C\8fÓ9Òì Ü¬®D½\10w\ 3d.¯°X\9aN\fÔv#8Ø ¡Ç.\a(4??dF 3ì Ä¤®E× .\ 5í\ 3\9d\b^®Kñ\15PI´Ô\16\16\ 6\17ÑNJ;H5ËÍÚ:ÔËÃñ\0ÏI¸úNpdjp\18_uYÚ\12\86b\90Rã+\82whU\8dÌ¡UUÍóÀÅ4\f\9aÖ)\8fVÏKw\ 3ncåͽw½8\13x\80\ 4Ü\1f?ìîG7àCÿ«Ë(ÆÆw}v9\14¿®ås¾¦\b¿LYà¼\95÷\ 31\v»O|ò3\9f3\81&¤g©¹ß@Õbîç\11\8dI(\14î:xp×\96ÈÑ/ÿÖÐ?z\86\7fv\82»~4i\18]\82£C}×o\fÄì\fQ\1e\f\11ó\rF\84\8e\1a!=ô|ÌÄ&Ìdà\ 5d\fW\9e\96*S4¥µ\9dlnj;\99Ú,\17P\94Û\9fÎh\81\9aZìd\8c<aâ\91)_î¶hyjâ\81\1doI\96!j6¢8=+¾ZÒ\17Ý\9cy!¹ªÆ{ÓuewÊ\9dôOóï¢\9fЯ¶\87-×Z¯µ»n\8dÂ?\92àè'ÌST\0÷öH{sÏðø\97Ý?!<\eáW\12\7fxóyüHjCD\87.Ïû\81¨EÒºµñÝÊ-h\19Z¤õM        R\8aäIþÁt\92b½3ï\17OìÓëÅ\89}D½Æý´sh\f]\85ç$½\a\19R>§>ùD\8e«Ìb2\95ñ9±f\vB¦ùåeúÂdebXâÌ\8f\83¦yʳ\99Ñø\fÛ\9e\85ng/\8aËM\94\ 4\87\8a)ð[?\8cNjö\99Ð\9e\98óé£è<\1a¨uu\8f^<\85!Âs!\8eóÁ¯Q^|c*wr\88bQbJ\1c#Ü°!æß8\ 1K\86\89À#ÛI\86;ñ^'»}Îã\17ÚËÝÝ\1f×¹Ï%\88ÿ\ 2òJ3\12
+endstream
+endobj
+770 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./hilbert-mb.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 792 0 R
+/BBox [0 0 115 115]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 793 0 R
+>>/Font << /R8 794 0 R>>
+>>
+/Length 795 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c­TMk\ 21\14¼çW¼£
+¾æûãZ(\85Þ´\v=\94\9elU\8a\1eú÷;Y7k1[iA\ 4\13'óÞL\86\17÷$Y\91Ì\9f~]µâf\19hó):\94\96÷ýæ°\11\8eû~YµtÛ\80\1eI)6&jjÖâØF\91ö¬\9d÷¤]>
+Ô´b"§Í;Ú9Ï>)j^ÅóDMçÖI9ÑÓ\97æAô'ó\13cbrÍ]#\16\90G_å$µ\9d¥\9dè~\f\9bîk'¶ÂÈÄQ&òF¢\8b\ 3½ \ 1f¢Ò`é YbW#¥j\14I\92a+HÜ-fà\*Ë?ÍèCX\ eÚjG_¥Æ\1aÍIz\98)M\94\rJ\1eq7I\9b\11ß\95^m©v°\9eýP¿RÏ-Lþ5þ\eµ§h\12+(µ"\87ì¬\19\90Ý          \9eS\8c@\86ª\vHö,\15\10\17\19öv\95Ô)~¤íM(LX@Ú2ÙSi\ e}Äé¯
+µ­A\13\81_©Ó\7fb\8e&rÒ\9a\9c\8aì\82\ 5½ V\e¶.\80\95µ\82J#H©\1aE\`¼ek1±±\ 3Τ\86\98{f\19åv(í\87ý\18ó\88ÓJ¡6Qi"æ+uÊ1\a\ 4b0õ@ºIÁ_U~\16ýrx\ 3%\1fåk] \94.\ 1\ fÎ;\7f©Ë\ 5ÊB|\ 3æ¦\17»
+endstream
+endobj
+792 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (hilbert-mb.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+793 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+794 0 obj
+<<
+/BaseFont /GNMPFG#2BTimes-Roman
+/FontDescriptor 796 0 R
+/Type /Font
+/FirstChar 48
+/LastChar 51
+/Widths [ 500 500 500 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+795 0 obj
+416
+endobj
+796 0 obj
+<<
+/Type /FontDescriptor
+/FontName /GNMPFG#2BTimes-Roman
+/FontBBox [ 0 -14 476 676]
+/Flags 65569
+/Ascent 676
+/CapHeight 676
+/Descent -14
+/ItalicAngle 0
+/StemV 71
+/AvgWidth 500
+/MaxWidth 500
+/MissingWidth 500
+/CharSet (/one/three/two/zero)
+/FontFile3 797 0 R
+>>
+endobj
+797 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 672
+>>
+stream
+x\9ccd`ab`ddä    ÉÌM-Ö\rÊÏMÌ\ 3ñµ~H3þ\90aú!ËÜ]û£à§\ 5«,\83Ï\fÞn\1eæn\1e\96\ 5?u\85¾O\14üÞÁÿ½I\80\81\99\91±bÒ\12çü\82Ê¢Ìô\8c\12\ 5\8dРpMmm\1d\84\88¡¥¥¥BR%LFÁ%µ83=OA\rÈ(KÍÉ/ÈMÍ+±Vp\ 6ªÎÉÉLVHÏ©,È(VHLIIM\ 1i\vKÌIÍVpËÌÉ,(È/SÐpÖT0200Ô\ 5\12¦~\99¹I¥Å
+`w+øå[*ø(\ 4¥¦\97æ$\16aÊ000°\18\e\18\1a10\880\b2\b1\b\ 2ýÎÀÂÐÃð\96Ñ\82±ïG\aß\8f\8eÚõ?\9e\1d\17ú~ùVêeqá\vßu¿ß\13=Ö½¨sqÓÉÒMAÝn\1cæA^\8e\ 5å\93\16§Éåέ\9aTÕÍQRS[\96±­ôâ\8d[K·ì\92ßµeéÑîsÝûªwå­*_X1=~\1e\87ð\83\v»\96l8(uÇû°~d|Uvº\nAMa©ÿ¬v\89-Wv¬9ÕÍqfG¼OzMzQ\91|nn~\8d{1\aÈ\1dK\7f
+-e\üúû\8c×Ìß'ý´\10\réN¬JË\b\fNýÍÞý\9b³û7ã\9aß\9c»\827Äï+>Ú½¯{Û\9cõë\8e\1eÚø\9d£û;/Ç÷D\83ï\8a¿Åå:
+EïïøÍú;õwj¼\82©iü·ï)ß3v|g~(\ f´ {Ö\8f\ 33/Ígü\9eù\90ùûv \ 5¿=\fXkÙ§O\98Ößß;wÒ\9cþ©Ý\1c\v¦ÔdËÿ\89dïÎj.©nªiªíHìâ¨ù¾b\16»MOõÔîÝ\1c?Þ°\83\8cºþcÑUÆïÏ\1e2ÿÈÿ.+Z7!-¨®)®[òw3Ûw\9bï.O^lºÞ}Sò½Õ\rå\90ðÒä4¹ìÌ\9aì*\97\ 5m\12\9bß®_}¡\9bãþ\91 sÛX=s#ùßn¿\ 3\7fH±ó\95Ïÿ\116ÿ{È|¶\95\\ f¸WNæáy0\97\87\97\81\ 1\0~Ê$\14
+endstream
+endobj
+785 0 obj <<
+/D [783 0 R /FitH 686.127]
+>> endobj
+581 0 obj <<
+/D [783 0 R /FitH 357.87]
+>> endobj
+582 0 obj <<
+/D [783 0 R /FitH 156.41]
+>> endobj
+782 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/XObject << /Im5 768 0 R /Im6 770 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+803 0 obj <<
+/Length 2028      
+/Filter /FlateDecode
+>>
+stream
+xÚ­YM\93Û6\12½Ï¯à\91ªZÁÄ7\99\9b×3vÍVy\9cØÚ\\9c\1ch\89\9aa\85"\1dRò$ùõÛ\8d\ 6DP¢µå\99¹\88M°ÑÝè~\0\1e ,¹O²äÝÕ¿WW¯ÞZ\99\14¬0Â$«mÂ3ÃrS$&7\8c\v\9b¬6ÉçT0Í\16KkóôÍ\87ëÛ»w\8b¥\942}ÿáúæ\13\89¯ï®QPéÏ\1fo®o߬n?Ü-~_ýçÕÛ<2\r\8a̪\ 2\1c\9c£ÊUæCI\96\92ç,Ït²\14\16úHÒúïP·÷h[§û\87\8a\9c\f客¦m\7f\14\87ú\1fÿ¹\1cNô«¿ÊÝ×Æë\95_\16K\91§Ý\ 2~¾áOõ¯£z\1ftzß\93kjØ\95ë¾#ñK\ 3\82°éz\ 1?\7f\f8\86\15+\94\82'g\85Ö\14yÝ.\96Jð´*×èæ\81Þzçø\91^ÊvC\82\1c?Úôq ·nKOï\1cÅ\13çX\94̦+\1cè¬f\9e\7fx\8bn\N\18\86ú¾­¼wL\14\ e#\9b\ e`Û5\rEëK aL\9bz]\r?M*\17\9e7««?¯8\88\13\9eç\8c\17yb²\9cY.\93õîêóïY²\81\8fà\88IøôèTw ÊY¦\15ÈMòéê\97\13#²°\89.\fÓº¸d\ 4Ô)t²á\80\1d\83\8f\17\8ai« \9e\8cqåG(³Å\92\8b,K%aq2\ 2!\ 53\92¿\84s!\11Ùù\89s\11\9cË\19ç\16§¡~ªs®bï¹d\99\12Sï¿e\19\aÿÆ\1e%CÒY(2\83é\9f\89\97È\83\ 40\18[L#Q!\ fj&\ fR\19f¥y\11çZ°\ 2\908u®f|\9a\ 2ð(\9fàó\1cþh\ 3Â\7f\1eúsÅ\ 4¬\8bÏB¿e\99Q`Ê2[\b¿\0CÞ-ä]\Àþó]\vÅ\99ÀLÄ®µwm. ÿi®g\91?ñý\ 4ä??\v\ 1ù\93H\84öÈ\17æ\ 2ò_À¹GþÔyq\ 1ù?ìs\ 6µV0ñ2 µ\9aåÒS\91Ì#G^\0í³=\1f1\e{VÞ³½\80Ù'y\9e\87lìú        \90}v\ e\8e\88\8d\ 3\11* Ö^@ìó}\aÀN|ç\17\0û£.gVj0\91iþ#Kµ\8b[å        °?\18»\88é³\16\126\99\91>CÚ¸Ðé\e$\91\10¡²:}\8f\r"ÝT\ 3½\97\v\9e")Dùç¾\ 2¶µ¯»ö\9cK\ 3U\13\10oæYòÍ\91cJ-O¸\1fµÕ\ 3=×D 7Èýðýàù5\88][ya\8bO\ 1Á¸×aW6\r\92d\9d\ 3ê¸ú+ô\1dª=)B\a\17¡Í&¤GÇt\7f½Ð@iñg\1cý\8eÞ«á|\80&cVÈÐyÿPîÉç¦Â\10Z"¬K\ 1Û«²bÊ[\1fF\8a\9dÓ!@Á\88O\93\82\1fë\81\9e_{H;èA, Ôk\94öÄ\8e-\9c1º]P«¾ÕÝa\bípöp\14\1c^^\93ƹ\13\e9qå$³¹O|L»\r\85ïÊ 
+âÿøÜÓpÀT7\93fe\197yHT\8f     ­¶\15=[\97t¬*/Ò-\fÍ5cØç      ·\19\13F\ 5;Xn\98æCÕT\142\ 6R®×]OÕsquþùà\ 3^ÓàG\8d\9do¨ KJf\98%lî1@\bÎ\17\91\94<)b8ÙEÐ¥ó\1c\bÛCÓü\1dà\10\9c\ 6P~ÃDUý\80Ó&B³\fh\1e\8bèLEnÚ\137þ¯Ê\1d\84®3Eg,lEøõÃ~îÀTÒ\99RÃ4®\9bò\v\9e8\15$q\1c.¼rp¹À\1a Æ¼\82C\b<       « \12\ 1\r?·hwß\97¡?\84\fõQ\1cÎ\8103\1d |ï\99Y\b[¹)\8e³ð¾k6\15\1eL\11\10\ 1\rç`Ð\86        È¾\13£:I\95\9d\9fr)/\16\17\83uG+\97:&Â\8c\89@\95(\11¨\15ro}\89mȽ\9dT)h"$s\99>>TxR÷ýöôt³£ôFÊv®8Q\16e>:\a±ëéY¶ôDM\vó¿\8f4\11\ 5\85Io±j[j§XA\88b\9d\1a~D\8fåpný\18\87¦Yézp7éÀ    \18\9e\1d\81¿¸Ø»\9b\ 41\81\95ðH\1eHöç|\11V?é®Lp©â"ýTù¶·õý¡wÅ÷\9ba\7f\9f\90ðñÝUòÙ\19\10ÌNoi>\93\19~/[²U7Í\ 1æKév+÷\85n/äÙå\82_åb,È1z¼t9\fn.Kï\ 6\ 5\97<9M\9e\1cg¯Äjà¬ÚÓË\86Ö\ 42(Ó¶Û\a{áFÃß\14µáZ#2«BMÜ\fe³W\1dÑ\95Ç\91GÀB,\80\83\88B2I<b$\19ø;×ðêvg\93ë\ e¸Ä/G\9bAe\19,.#\93ç$YsXÿ\81\82\1a\ e;!§äúʺ±A\ 5\7f\82J(\9dÞ\8c×`~U\94Ó9)UT\87ïg¿êãìÏ¥\aC\ 6J\94ÃÓ\0\9bU~©pó¡£Åg²W(\9e\8f{Å@ïµ_¥¾\96ý¾^\1f\9a²§vÂ6| k½\9b\ eØß\95\8b"\ 4\10\1eíâ­\9e»'Ëü=\19t½½[}|ýý\9b»c(øÐnq\82eÔã\12[\fPø\ 2H\19·|w\1fèT\89¯ \86\v\17\ 5\aBAËEà\ 1Î\96£\17øÁ­\ 1õÂm¨Þ~T\1dÒ¥i\8cüaõP\ f³ë\9cÛ5dØL`"¶¸YbÓ4çð)\1a(~/\8f³\ 3\86\1a]\1d@ׯ\8a´\v\89\91ý\18Ø\13\17$öæã\fM\87C\8d\0\0\v\bÔò\8b×!@üóbÊ°''\83\1cw&gHsO¯ï>¼ÿ5\1a ¥\ 1\12\80CË¿[^¥\f\96\89R\ 6º[\86ª\96DØ\£ß\17\b\8f[æâ¾g\14\10Ú\\ e\95¥Eª"9ÚãAïd(\96Q43õõðézÄ\81R\84\ 3\9a\9e~Þú{o$GÛòÐø51Î\8dk\bi\bÔ\97\11\r\98\9egÀ¹\94L\99ãIÆø\93Ìõ\9b\15qx\7f¤AZnÖ5$\a^öÃÿ=±¼\9eá*XT+§Tv¨7\87²\99ù3Á2\9d\8b ë@\ f{[¹q<Pqb§ØD\85\ 1!æß\9cÏ\95\93û]\v¾\96ôzVL4Ø\91
+,\ 2»\13\17îh\ 2Ѻï}µ$\10ª\82q¨Þ¤\8aà\1d¶Ë\83;Ýá$\82ÎĤ
\8b~Ð@\10
+ª*<\a(¹Û\17Av\9c\ 24KÿÉ\9dÃ@p\8b:´ÿy(ýBøOèâçþX&?hTwû\1d®BÎfû½Ëýÿ\ 1>\9269
+endstream
+endobj
+802 0 obj <<
+/Type /Page
+/Contents 803 0 R
+/Resources 801 0 R
+/MediaBox [0 0 612 792]
+/Parent 775 0 R
+/Annots [ 798 0 R ]
+>> endobj
+799 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./reference-frames.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 805 0 R
+/BBox [0 0 263 100]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ColorSpace <<
+/R9 806 0 R
+>>/ExtGState <<
+/R7 807 0 R
+>>/Pattern <<
+/R8 808 0 R
+>>/Font << /R10 809 0 R>>
+>>
+/Length 810 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\95UKoÚ@\10¾ï¯\98#\89Äd\9f\9eÙk¥ªjo\ 1K=D9DÆPU\98
+\93ª\7f¿³\8b\ 3\vF\ 4°Äz¿y}óíÃ[Ðh@§g\18\9bN=Í\bV;õ\ 2\8e\90¢\87W\81\17*¢÷\1cà\9fÊÞ0û¦È0Zí P\85:\82e\87>¸a$è[5WF\aF\17N}èÔÇjb)tÕÇ\89\8b\ e×óh¤\0Ç¿~¥\f9ÆÊ_a¸|¼ÁIÚ\80ô¤\8c.2\86k        E¾\bÍn/êÓ\8ca×ln   ûÔ¥`!\v\13\8d¶wÓ¸%îeXïÏ}çj+\9bÁh­¡Ë»b­lå\8a\97lZ«_Ê0i\8c\16¼s\98rv\a$XFö,^\86\93ñ\12ò\11u\19        \16\13K-k\18MFNk¥ú?\1fa£<\92õ6íàC\90\89(ªg:{ÄV\1e-G     \9a«ç\93\88q\ 3ãÂçäî\10(8Ù³Tæ\1f\90B\ e\1f-
+Û1RÈ1F\821È\ò<«u\10èàz\94e@Ne¹DvTdDä\ e1ÒA\90;£È? Eë\95Pðö\ 2R´>F(bå¨äyVë(Æ\87ëQ\8c\ 19\13cLv\dDd>Ü¢r\96·rGæ÷ah:øRËé\95©Ü¯\1c      j¹\1cö\1e`=a¨,\90AbSAÝ©       ">Ô¿\87\b\83αM!Së\9d¬\92Ü\18\84Z\93\87z¡^&ß7ïýÛÃÔÈ\ fcLÓ¶ÏÓ´\99\8bé]ÖbúZÿ\10\ 1BnwJN\ 4à\yÒüíûvó\9e\98NCÄ`\ 3KGÉÒ·ËVLM\9b\ 6\1c\8b|\142ëeÿÖµR*\8a\fÓTjjd+:Y\8cÂ}²ú³^´\9b\94Í";ïX²y4d)\9b÷ÑbýZËú=«ÿ\19¶s×
+endstream
+endobj
+805 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (reference-frames.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+806 0 obj
+[/Pattern/DeviceRGB]
+endobj
+807 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+808 0 obj
+<<
+/Filter /FlateDecode
+/Type /Pattern
+/PatternType 1
+/PaintType 2
+/TilingType 2
+/BBox [ -2 -4 10 5]
+/Matrix [ 1 0 0 -1 -52.9 114.3]
+/XStep 8
+/YStep 4
+/Resources <<
+/ProcSet [/PDF]
+>>
+/Length 64
+>>
+stream
+x\9c3Ð3T0\0A(\9d\9cËUÈ¥kd  kb `\b¤-\r\14\8aR\15Â\15ò¸Ì\15Ê!2\86\ 6
+¹\\86\ 6\ 6
\ 6
+9\Á\\81\\0Ü\94\r\86
+endstream
+endobj
+809 0 obj
+<<
+/BaseFont /LQDLZE#2BTimes-Roman
+/FontDescriptor 811 0 R
+/Type /Font
+/FirstChar 46
+/LastChar 117
+/Widths [ 250 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 333 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 444 0 444 500 444 333 500 0 0 0 0 278 778 500 500 0 0 333 0 278 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+810 0 obj
+562
+endobj
+811 0 obj
+<<
+/Type /FontDescriptor
+/FontName /LQDLZE#2BTimes-Roman
+/FontBBox [ 0 -218 775 683]
+/Flags 34
+/Ascent 683
+/CapHeight 662
+/Descent -218
+/ItalicAngle 0
+/StemV 111
+/MissingWidth 500
+/XHeight 460
+/CharSet (/I/a/c/d/e/f/g/l/m/n/o/period/r/t/u)
+/FontFile3 812 0 R
+>>
+endobj
+812 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 1844
+>>
+stream
+x\9ceTkP\93W\1aþ>\ 3\9c3.bK\9a*Zó¥þ°Z/¥¶\1deëÖZQ·C¼!7Q\96\8b\84\10Ì\8dK\b               I$Dà\85pO @Â5á\8e \82\17(­"\v»mÇZ×Ví\16üÑÝVwgw;Ó9\9fóõÇ~éÎÎþØ\993gÎ9ï{Þ÷=Ïû\9c\87¦BVQ4M\87'(T²Â\9dñ\1aU¦:¸ßÁn¤ÙWV±\9b\ 4À©\9f·?ß\1fº\89\92v
+Ö@¸\0ÂCº^A\95\91äÊ\8b¤e-±¿@   hº¤±ï Fk(PÈs\8b$[\13ã\93·mß¾ã\7f'oÆÄÄH²\fÿµHbe\85
+¹Z²\85_\14Ë\94\1a­J¦.zWr\90÷V*\15ç$r¥A\9b[(ÉÌÎ\96e\a¯%e*eç%\87\15J\85V«)\96l=¸M²;:úÍ\9düôÎ1\85*KW(ù¥rÉ1M\8cD*\89\97ÉuÊÌ\82ÿ·P\14µV­)(Ò}\98y.[\96#WªvQÔqê\ 4u\8a\92¨×©\ f¨Xê\10u\98:Bý\96:J\1d£ÖR/ððP!T1u\8b~\95¶Ó?­\8a^uOðº`0\ 4\87ÈB÷\85\1a¶\85Ų\95\11l%xØ\r·èÇË$vYÐÎn\1658[j\\80\ 3ͦT\86«A\10o5§\Ä&\92ëA)u&7\8cc2\8an^ëv\8f\0\9eéU~Èp2\ 4Ò2ãé S¶\a¥Ö[Ü0\83\89\ 1ý\90~û@\9aÒ\18wDü\bÙkS\r
+kBi\14\9fÑ\16`w\aè\81ïHÛw\ 2âd3DÜËÑÛ91·ñû-$\92D>û\89\88ɺ7\9er/1e\1aÑòÂvn\13\17ú»#ïgçô^.f4s¥_À=üôÆÒ=q\ 4yÂWÿ\e\1fýÕ² \91Ý js6׸\ 1÷5\97¦3\9c\13Ái»=ÎÂWe÷ #N£\aæ1Ñ¡á©Y\7fC³Ãæ\12·\9b]\15­\80{=\1d\81\91b\9f"S]\14\9bÊü\159j\93tò²\13%Q\11dÈ6Ç\86\ f\12\awty\9dp\854±I"áÝ-\ 4\87µT;+Äö\v\15\17ì6YBÆ\99Ò\8bX¸bµWØ\1d\e ²¦ÊY\85\85w?æ> Û3\98±03Ñ;7".s\15\17\18m:\88Ê1ùÿÀ\90I$\ùgX\10\8d;ñ>ö×\1dæ¶È{Ëä0\9f¥\83-\9c\159ÂÒ¬®ë\fyÆíFÂ\11#ZªtÛà4æ,\b4\ e³ÙªÕ)-*ÀÙçG¯2Â\ eò\88ÛbF7+ÛL\90\86¹z´ïfÊýK\93í~¿xj*t/\12Jëªf}ã®\8fÚ¢\82\90y\9f\87xi\82þ% \88Ð"x¿Ì²§\12\97\90Y/\8aq\96¶Á}Ì\9e@p¿­u¹\ e{¹Ù\12´âp[á\0\8e`OØæãï°ë{#o\7fK¶~³Nx\8d\99Èh¶8L\80\8bìmÓ\fIF0ç\180õêÆ3¼'\0ï<\90*-òé{z»|ÝuÕõÕ\8dLUsu\134bÿp÷å\19¿:Q|\f\8e\1aË3d:½Y\ 1yX\98"\9dN_\9c¾Ò5·(\16¶&×w\16_Ù8
+]î±    ÞĽñ­\b\94\8e\vÅ\96B³æB1à\Íè\14S\87`áÊ8Y3ýK\85_²¡\ 3tß×\ 2v3\89\16\9d9$/\8c\a\1c\1d÷\98 \1foÝûf¼Õ\9aÓÂ4è\9a4\9d\86.\88êïööÜ>tcOj\8a^\9eÅ\9c\1c\81}\98{ùÑ."¸v¹}h\ìïõú\a\17p°KsÐή\ eÐþ'D¿, \7f³\89Èks¡íÈP]\ 5\95\80åå|³Ø?òÜ9c̵Å\19£JQSM\ 34\ 1¾ÔlËb¸h$\eÖºÎ\ 1æÐ..\94Û̽ôàm²êö\84ïÆ(\13Çw!\ 4ìv\8bÍjÐ\17ØÔ\80÷&<&kIèÌ\9f¾úxæl\12\13|Ö]¢\1e&h\9cfw\90½¢3û3Ôq\10\ f\19\ 3êyÃ\84}¤j\11\93Å°òOm\ 3\ 5êñ´®d8\rg\r2ÅÙ,m,Ä`Nüå;\ 4=}°@¨«bî!Ù!r=\1c½´\b\8bЫi}\eÿç\17½6L2\ 3ô\8füÛ\96x\8esky\8aßñ\ eMtµÙÔ\9dâö|·­\ 3p\8f·³g<½ÿøÑ$mZ>\93\9f^.¯~\17Ç\9cÿ3÷y\18|`µ\1c\f*@«\87g\91Õ\ 5\ f\9c\1e:N=OÞò\91u}$o²>@\a¾ ¥_û\ 3\ 26\8f]/\9a|\ féÁäÔ7ê\9aÖk[´õù\80w\1d8\18-õË>ËcJ\f\ 6c\85#O]¦\a=\14»-Wô±ÉÚ<ÈÁI\ fÓ\9f>xØ\7fuN<1Ô1\f\13°töê\ 1''jX\9fT[Ð\fíà\e\19ó75W7V;Á[ÕZÝ\0\97à²gÈ?\12ð\8cÁ,\f8zÌÃ\98³ÿ¼A4b\7f\1\ 3ø/#eò\93û³¹Ð·N\ eL÷4¶^\9deêÉ÷¢\85ÀØõ¡~£ª]Ü\99ëN\83l|J\9d\9bv<óÓg¼ò\f\81\87þû²Àû\ j\bsÕ¸kø^\ f·\98Ï2?ç#H4\97I\1d<\18V\ f\92ÖYZà\16f\7f@\17k\93\8d2ÛacTÄs/\ fø¦9úÉ2\91\ 6\87ÀËën«³)¨»ýÍ¥g\18®!\18Ãtª\9a\8fQàAIµ&\17Lb2\86 ¶©¥±±¯gªc\fðtwî!\86S!8eµÆ\a±/ò ø\1aS\a,aR\8f\ 6§F:¯\ 3\9eïÔîe89¯ãåå'í¼\93Æ\83òkUµe\9d0\19\10Y\9dýû÷N¦ä\9fL\14\eæ\15þDH\a\8d\14?à%;¥\84\97l\13¯\19\8f&/þC¤*ÈWªû
+\ 6\86úû\ 6\86òûUL\84ÞÇ&ùH\82/lpõʯ\ 6\9bÂÃW:Ã×PÔ¿\ 1uK{Å
+endstream
+endobj
+798 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [323.815 414.524 338.537 425.372]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.7) >>
+>> endobj
+804 0 obj <<
+/D [802 0 R /FitH 686.127]
+>> endobj
+54 0 obj <<
+/D [802 0 R /FitH 534.204]
+>> endobj
+583 0 obj <<
+/D [802 0 R /FitH 273.426]
+>> endobj
+58 0 obj <<
+/D [802 0 R /FitH 170.234]
+>> endobj
+801 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F14 574 0 R /F48 455 0 R /F70 508 0 R >>
+/XObject << /Im7 799 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+815 0 obj <<
+/Length 2097      
+/Filter /FlateDecode
+>>
+stream
+xÚ½YY\93ÛÄ\16~\9f_¡[\14\85\\155½w\8bû\94;3a©b\v\86\a\12ªPlÙ\16W\96\8c$\93L~=çô¢±Ç\8a\ 3\8cÃ\8b{U÷9ßYºû3MÖ    M>¿úßüêÓg6ÉI®¹Næ«\84iJ´6\89\9a0n\92ù2y\912>ûeþÕ§Ï\8c8\9c)$ÑBÂ2nÎõ\17O¿\9bß>\9feB\88\94\93Yf\8cM¯¿½¹½ñ]?}ysû-VeúÃüù\8cÛôÇëù\8fÏoqå+\1aÄ9\96%\8b[dÜ@§ð\eU\r~<\94ë²\9beÜÚ´Øíº\16ûÞTÛb¨ÚÆw·+,MZøæ\803^ãO\9b-«mÙô0³¨ýà\1cûïvØHKßõ%\14ÆýBã¦ê\17]9\84¡ë¶¯\9a2~ieÚ\15M¿j»-Ae@\91\8c1\92+åå\9dop*\80qs=÷\95¡ø?îWö¾Y4¾´\1ed&\ f °9¡÷\18¿¤4Xâ\10&K¬Êã\14\eÖìºÂéä\9b\ e\v(wÕ\9b²öÕ?fJ§E½\1f¥\beÕìöC\14lé+Ý\8c!,,\1döPë\9a¿ 8§\9a\1f#9b\99     &\b\87\95\8f Eu\84Vé¢õ\16{I\99^T¥w\f?t¯\1e¸¢\12¹3\83wbzèÄ°¼\11&ÊÐ\14þ\9b)\96¢c\b«ÓÖµ\96eW5ëSù\8d$\14Ü\92\1eK5lʾ<\10Ð\ 4\ 1\11À*"éeíý4ì\rÕ%Î\95\fkµ¾|å×ñ\980k\88=FÄ\aÀël\vÞ\ e\8aÿ\ 6rg\82\82á;\90ýÉ\faLWh»vë\ajøÀøx(ûÁ÷¹Í ÜÀÄj½AÏ`\ eOjÒUWþ¾/\9bÅÝÌ\8a\14 \95B#¤wþ\8b¢+C¥î[ÿA»\1aÀ ®³j\96å\eÐh"8 \98§\8cB4\1f\9dþmµÎÞ\16kXJÙ{{\9c\1aC)Â¥\8d_=ñY\a½\1aSN¿ñ\05¾»
+å³j½ï\1cªW\f¾¤I·N|åùçWÉ\v÷)'ö(GÁâä¨ãa      \91À\8e´É\9d\9bg\9c\13®\99\17oq*\7ff(¡\90a\8fð¡`\ 2EiÊBÉC)B)C©B©Ci\9c\84·ó«ß\83b,á\1aÃM'Êp"$O\16Û«\17¿Ðd    \83`\16"r\9b¼vS·p\b0h+¨×É\ f\9f\9e\12\\19"ó<QZ\12fx\94urO­\fÌ£DY}nO\9a\ 4½ßµ¥1Dp5±å\83Ì\ 3\92\991ïüç\14\89Tcв\11À\89\1c\ 6;ææ}K\8d\8e\8aØs\ 5\92ÿd­Ü\9dpQ*´'E{\9b©µÀ¡¬}ÏZ#\ 4Ü\9e±\8bbpʳ¿k\97ci¬$&ǵ ¤ÖoJ\82ü\1f\87òýíÓx\0Èxþ Ï±3º\88\9c0}\19\1f\93\9c\18\15î\eüA¨\99hf\11dg:\1ak¬ä¡"ù\19\8c\86òÇa\1f\ 5\16pJÚ\80ýGpV¨¿\ 3ýØÆÏ>\9a°\ 4f0¨\1e\9c\10#ÍE,Á!\13\89`\89\98ôl´\0\8f\160\11ø\187\82F\v°X\11g\ 4¦\16àã\97  \ 3\98guþ\81Â@G$Þ©\8bÌ5 w\11ð!Ã\93\9c\ 5ðó\bz\ 4\94Ù\bº\8c \8fX\8fèÇ!%B\1e;<\19áfC\14\84Y\96ÃUQ\86\8bÌ\19ÍàIbõe\ 2\94H\99ÿ\9b\ 1#Ïh\ 6\17É\9c>Òf\92Xx)Hcád\ e`²h\a\16\13\12\8fIKÄØ\11\8a±£â\90:'²V\0 ¸HÈH\r¯\1c\9e\7fØ\93C\9dÑE        "íeà\87\8b\115\ 1~\1eáç#Ø#ü1xd<3T\f\1e\15í Ï\¨¤\84§\a\17\97\89\ 5iH¼\97~àPÐñ¦ônÅ\ 4\877\95½\88-\84\82%£-"¼bÌVñÐ\90±¢¢½Ôh\94\18\1cúÌÅCÂÅ^Ó\v\85\ 2×\84}àH0gTa\94hy\19ô\99$\\84-ÅÔõúèÆû¾[¬\88&\91ö\9fÞ\88ǽd´ª2\8f^KÅ@ÖüÑ7u-\8e\1f\9a\19\83\ 3\92\e\8b,\b\91\91\8c\voÖÀ³ÙÏà-.UúóøJ\86n÷ê?ûF½\7f«Â!xà/9¾hà­
+÷IkÂÉÿM;\94\9f\9d\8a\ eS\14ÓQö\ 1Y.IóÈDø\86c\90$µ©#?Ú\1a飭§?\wÕ,«\ 5ò\fîËr\85\94\1eV\87v\8a\16Ð\82è|Üqå¨\80\12\7f\ 23\91\ 1Fi³ß¾r\ 3\13\14\81\ 5ï\16*.\80Â9>\85k\ eÇï\83\97\ e° V\913\83\e
+\92&È7-\1cË\88Ä\92\rÄ\92\e½§HÜw\8eáÙo\91f      ìM×û\11Ç\96Èc²\a\17@\9e$\9bbI\ 21    Ã\9e\91vÑ40NÔ\83\8f\95m¹m»8Ø­\8b¦z\e\18ÑÉéN5G\90q\15Ù\1cèÞ8\ 2î\8fÙÈ8=\10ç\95\17ÇÑ;L¤¯»j\18bcå\19\rí.V|é?k\87!ÎØ\94Î\8f\ f¦¬Úº\8eþ\83íEÛÜ\8bâu\ f¬-\8e6í1Zát\19\9cÊH\0Y
+\10÷»
+\89[a¢â\86¥]µÞ¸Õ²\rx\81#Û`8Ð\89\10=USÄo\1c  v×\ fåÖ·\ 1¦¶+ü2û\1e|w\ 2 \95£ß,\8d¾\83Õ\13ßQV¥_\17\rªvç§TÛ]]n\83\9e~\9e\1fp\86³,È\ f\1d\8eJv#Á5:\94wB\92_«&ÛÕÅ¢ü\ 4½\15|l¾)Я\rx[\ f\10)¤ý\9cá¥\11\10\81þkü°Û\ 2;'IÖÞ\8fUa²\8f~èè\8bí¤\1c£c\1a\9e¾ÚÃR\ 2C\1d[\83\13È×J_©\9a\9c\91¡\11!\84ê!e\8dmÏ^vá+ÏV¶#W½ô6ª\1aÄZ³ôf?)\19º\1eÏ\85ß\1d+§¾\81½\a¾\ 1\ex÷Àþ>¸\ 6ÖÁ\1dÂlç\0X\89\84;T\8f\1dÀ÷yúsâ\1f\ 3p±'\81Ám\1cµÊ!ob>ñ\-Çô\14ú\17\90NVûÚå\ 4hnÆø\81F\f¹\r\88%uXª\11Kh»L\8dsÐî\13Aõ./@\86´\88ÇQH9.\9e\ eXV\97ñ£\ 3\1cô÷û\ 5.³ «\84N\a(   \99Ù¿\8b2\ e\92°pþyß\97tB$ãØj\18zI\15¥\13/N8\0,\1dÿqøïé    !á\9c\1dÏk
+Ë0¿`\85ªJ\ 6`×µSOúlrzJiC¬\1a\97¸¹Æ\94*áü\83#©uçR\14w8Ý]Ã1/Æ«\ 5ñ\87ÄÓºö{ûø\80\8dÁ\9e.z&1pfñàÁíC\1avlÇÑVA\93S\ 5àeqð¯ÌÓ\19×éµ'ߧ\94è'´Pð\ 4â÷ZLÝCàöù'!$\89G
+endstream
+endobj
+814 0 obj <<
+/Type /Page
+/Contents 815 0 R
+/Resources 813 0 R
+/MediaBox [0 0 612 792]
+/Parent 775 0 R
+/Annots [ 800 0 R ]
+>> endobj
+800 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [318.143 607.41 332.866 618.258]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.8) >>
+>> endobj
+816 0 obj <<
+/D [814 0 R /FitH 686.127]
+>> endobj
+584 0 obj <<
+/D [814 0 R /FitH 394.763]
+>> endobj
+813 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+821 0 obj <<
+/Length 1780      
+/Filter /FlateDecode
+>>
+stream
+xÚ\95XY\8fÛ6\10~ß_á·ÈÀZ\15\ f\1d~l7M\82\ 2E¯E\81")\10®LÛldÉ¡äÝl~}g8C[\82\95&}1©á\\1c~\9c\19:[ì\16ÙâõMÆã\ f÷7ß½ÒÕBfiQÈ|q¿]\88¬H«b½È+\95j\r¤Íâmr·7ÇÁúåJ\95\96\7fßÿDb:-«R X¶XéuZ     M\ 2/mÝ\ 1·H6®Ý\91Ø/\8fKø¶þÑÙ'ÒP-Öéº\90\ 5Ëç"­26x¿wýr%õ:ém=¸®Å\8f*9ún)«äÑm,/\eZØ»Ý\9e\b\8d}D\16ÛÐ\ 20ÖÞ\1d£\8auÒmiaØ["ÜïmçY\r:-Q¨~Áúë®í\a\7fZ\8a¤^®D28\98u8ka\92â>Ðu!Òuή\7f\ fÛÍTòà\86Õ\ 3zò¼\82)ÒtÒ\1fAi\99ØÚ½Ë\84®\ry\85+æÈKÆ÷Dy ï\9dk[
+!ètÌý\aÇ\ 4¬ß\b°\9f-ünA\93ß_ß,Þ\ 6æ<,Ç\93\ 6ÇÒåJ+\8dû%m\8d¡#EÇHaO\v¦_M6VÐÆúÓ!\84LRÐU\búj\12o\99\9cÚ\8dõý`Z:x$QÄe\8c¸\1aE\b¨cÌ\89\80G\8cßµíû[\98\15\84ñÞC¼]½\84\98ì\89\91\0\98ØÌ\9dÇCPg\9bÀõ\94\9eÁ+tªt!\19|J¦E\94\0\8bBæ#\18Gðßu-\9eÝîäM<\82+ K\0²\14ã\8b\10öç1þ\bèá\ 4\87­u\16Àåú¡§\ 5\8c\13S'&.\8b0\86 "×Ç\93iqG\83û<b;\98Á»\1a/\aòÀ)\¤fBóæ\ 4\86ÔÁ ¬\84¸ \9f\ 5\ 4v\1fzZÝv\9e\ 5\9c¼¼»\9f\bZÐVÔÎ\92_xzJ\14ä\ 4r\19\167\ f\r+ÀMáظC¸"0}\æ Ò\9cì\9cÕ\99-\80³\r\ 3\ 6­~ »¢T\82!l\0à\88z\9d\81îíÁ¸\96Î\13>\83\vp+\86¸~\ 1äYÕÑ\1d\19C®e.\ 4\1f\8em7\90üèÐ`{#\94\ 5_#Êd\99æëê\8c²3Î^7Ý\83\1da¢JÕ:fJ\ 4\84*\93\1dëЪ\18å1Z\9b\81T9A_Á\0\94pØB\92\ e\13¼W\1d±x\8b)cCtÔg\9b\r\9e².\14$\87\10ÿ=+éçÎjë\rf\10\9dU      øaQR\16\17j\99ôîs¤\1e]=\9c<s#\9df\84h`í\10¹p\95\98Ýô|Dõp6à:^¬»\ 6Q\14,\1cM}1ñ     ²Ö\9c\9f\9d\87{\84\\95`\8byHz8P¶ó=\85\11\b\ 1í§\ 3f&ÎÙ\88¹*Ëøh¾Q\86\16\10W8n\1cå3"Ò\85ê&~\1c`Ìóä\1fØÙÌ\16F\161\89ê"äl©\93\83k1\168}\\ 6Ãc\9eÃ\86\96®\99½}tä?~Íï\19ãþjYÁ¥b!Êø0¡\88Ò|\83iB·6\98Ê\13,¨íÜ\16\ 6j\ 1Êr¶l¢ÇU¨â½%.ãäHÞ«\17¼ú^ÆY8Å°("ÉÛ\vf\1c×°gô\9eױآ\84·[ëm[³\99¡#2\15±\17ý\¥ì¼Û\85Z­°\98R\820ô      ÷\ 4+[Èj\98\9d\98d ?\7f\r\ 5\b§\14·ÿÌ&å%\9bHÎ&¿aiPbT\1a0¯ü\1cKÃ×\13J¨Î(c\1a.\9b¸\89R'X¸\90\8eA\b­`¥ia\83G£0N\ 1ª´z]¢\90z)Q(\185q\95fm\11"XBª<éBÚ\ 5®í<Ú­áä\13¶Vf£½I\99æ¥\ 2\81À\88\1e\8d½\81¦äù¸Ì¡-½\8eJ©S©Î\92·3º\8bTV:2Ô¨\86\12\rê=6¦\9dQ
+=®\80\1e\97eÞeyF<B\8c\98TZ\95\7f1\83\ 2sëRUÁµt\rUD¥\85à\0\96dZ®sèk.L·3¦&[¸c\86lbJ@+³\12©^ëØO]ÙÒi\96ÉÅ\88\aÏ-\ fyàÚ$@­Ðùÿ³éçljP;â\81`
\8b·}\ 6
+ë´¨ª/C\ 1»\82O38\80gM)¿\86\83ó\86>ºk\15°ã|\8a$8\18\9d¥k­§@~Ú»XF\15ä\1a\1d]\94*ÙB¦ðÝ\81>>[ß\11ËÀc¡Â]Á´U7§\9e\13\1a\9cr\95·Ägâ$<gð]ãÃ¥\ 5M\90ýHe¸ñKê\0\910ºÇ(dè\114\9f´Ã\8b\87ó*¦ï¼\9aÜf        q\1em\92\96\99=¤è¼LB\91Éã\v-/\93IC\86\84ÃèÉ\0\8cá\81\ 1d\16¨\12j    q\8fðó\81\169Á°\ e\10^â­\87í|Ä \18
+\ 1ô\19\9bÛ¹\8cn¸ßë÷\1d2>qr\8f\1eëFèk¿ü$\ 36ÌëW\8f\ 6o\91+,\9c\994\1aL\ 3Zo¹\89eÚ¹\84t0ã\ 6w\ f\97á66«PÐ!¥?ÇNø\b50vë\­¨\16\1d\ 3Øv\1e\8fP$ô\1a\Í9\19\81\ 6b\9añ\8aS:\13$\81ó\8d#T\10áü^\fï\ 3È\99[B5.Q­\99
+\96\85·1Í\18ý\9aÑ\ f#=ÿgìU#±B;×ßtg¼\a<pë\84ÞI\ 6¡\ 2/¸       ³\1e\826Äs@zO£ñðÌ÷`K$±\8b@yzý ß0å'Ðw}ï\06ÌL\8f\1dlu>\99ÃñL\ e»D\11ãW³\97ÎÅ?\12"\ 4`Ò×&<³àu\7fé\1f\ 3ÇäzgøtA[\83\r¸@I\v\86 ?§¯s\ e\82ù\93\eö$£$ÿ\87p>Mú\ e\958<ÑÉ\193ð_
+ÞN\91/\8a"T9¸\8b©Ìø±,Ô\84éÇû\9b\7f\ 1\81ßÔG
+endstream
+endobj
+820 0 obj <<
+/Type /Page
+/Contents 821 0 R
+/Resources 819 0 R
+/MediaBox [0 0 612 792]
+/Parent 775 0 R
+/Annots [ 817 0 R 818 0 R ]
+>> endobj
+817 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [345.229 466.937 352.203 477.785]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.5) >>
+>> endobj
+818 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [187.345 167.006 202.068 175.917]
+/Subtype /Link
+/A << /S /GoTo /D (table.3.1) >>
+>> endobj
+822 0 obj <<
+/D [820 0 R /FitH 686.127]
+>> endobj
+62 0 obj <<
+/D [820 0 R /FitH 668.127]
+>> endobj
+66 0 obj <<
+/D [820 0 R /FitH 431.238]
+>> endobj
+70 0 obj <<
+/D [820 0 R /FitH 351.986]
+>> endobj
+74 0 obj <<
+/D [820 0 R /FitH 246.223]
+>> endobj
+819 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F70 508 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+829 0 obj <<
+/Length 2852      
+/Filter /FlateDecode
+>>
+stream
+xÚ\9dYIsÛF\16¾ëWà6`\95\88 W4ææEI\9cC\9c8\9c¤¦ì\1c \12\920" \1a ­È¿~Þ\ 6\10 AÇÎ\85è½ßò½­\99F÷Q\1aýpõrqõÝ÷!Ê\93Ük\1f-î"åÓÄû,òÁ'JgÑb\15½\8f\95\9dý¹øé»ï33\éòÄf\1a\8e¡5¯~|ñËâæÝln\8c\89M2\9bgY\88_ß¼zûúÍÏ?ðèÛ\99Îâßa\8dR:þýÍÍ\1fxêU*¤\úÞ,®>^)h¦\91\8a´ÖI\9aù\bHL2\9dGËÍÕû?Óh\ 5\93?Ei\92åYôDK7°4MBn¡½\8e~»úõ\9cU­C\92:\13y\97%Úzfã×C±\9dé\10ï«Ïžª·Lù\ 2)\7fÞÍæð)gs¥Ó4þO\v\8d¸¸/\89\8bi*\9dJ<\90pB¥ÍÃ7Pé=±åm\9aè\10\98Êt6wiÈã7?/Þ½\98oj ,Ä«\92\89½]s\7f\89|<¶H\1e\1c?W*É\9d\13\85Êþ\97'Ki\7fELÛ\98\ 5ñÌ\83õþ¡l¸Ù_\97|\81søz£¿E?é%Hj\a\v]\16¹Ü&\ 66\10\a\8bY0qq».;À©\7fÏæÖZQ`v®ÀÀ
+\f±ly³]U˲\9dÄ`4ÏÓD\85<\9a\eàÇæ|ç¦\14lÀ1\ en@98\1f7å®)Ûr8µª>¤Ê\94Í`ÐÇËuѶ\88\9e¸å\81ú\8e¿m}h\96%ïÜ\14û²©\8aõ5bMÇuÃKz]à\1aÑ\ 5\8d7M±½/7ÝEC]\v¢÷\ fÅ\9e9n\ fÕ¾eÝ   <Vn\97\9d:\9b\7f        \0\9aòã¡júC[Òs¤l\92[\ 3g\83D¼8\86\9b\82\90óÀÄ~<³\1d\9d)䨩þâvÕòÊBæ\ 2û\15e\87~ŪÄzÓù\95\ fiªyÕ\10\13\ 1¬?ë\96\84Ó\8b4\8b\16Æ\94\9fßV{n\7f\9a9\17\17ëCÙ¢p\ 1>O\ fÕ\12¡ò0$NÅ\87¶\ñ) aä|®¼K\94±c\e\1ap\8bºË\f\v\15\eõa¿\9bÁA{éÞ\8dæõ4ÛZÁ\1d\7f϶³#¶MüúÕ\ 2¼­ÕvÂwá<\89\ 5\81Î\92o\84ÆV\8ca\89PµÌ±\ 1Þ«í½0­ó$\84lÌôþ¡)\119\1eà\oø\88\ 1\ 5LÐ)ð\89\12\ 1å¹I\ 2´\84ôÛ\99\83eh\f&\84NqgÜ:\93dG \14Û\15_¼ÇË\9ePqõÄE&$Áö\17µKºi-7}"õOÜ\ 4NÙõx\ 2q:\v>ãA8E\ 15-\1a\91ÏàD>\rÆ\ 1P\9e\0Å3\15»Ú¹6\1e\1c\9b>\15\9A¬Ê\12§CwïëWpP®\aD\9f\11
+Üåº\8f¹×ÈU*8&34YJ86\80ãb·[W¨X\1cDgE_b
+fé2\188W#Ï#h\a\eÒø\96õÕ\e\1aJ   \f\8cEsçA\86c×Ó\96Ë\9a´\96\1eå\ 6Í¡ÜÒ\8céMý%\11¥ £¼Wè\8b\99öñ+vb\9d\9cÀÔ¦D\95A3\e\8a
\8e¡¨ú«3\10\15\9cÑI+e×Nãëõ\916\1aéâ 4Er\99H\ ev       \0\94u\89óf\f\0\92§Wr\124D\9e~(O \fäÙÈxÑ5¼å/é\f¾=\ 6ÕQ\96­ìa+9îy\81\94}i\1f\93ú§2\85»Z¢~Y\88¯\9c\fRF×Iúcu®\v<1ë\1dW\7f7\a\96¹±\90%¹qd\111X-bÀ\ 6²\84ßr\r±      ã¨¸\1d\1eÅ´\85\98\84=\962¶XÊ×\98%\18â\96F\89?ÚFÙÜp+8VnH\84\ føe%V\92\86¨x\12\19\80v\88Ô\16\84ʤC£Ý×\r\82\vÛD¨Ïãm±?\0ì\1a\00õëf\85ÐÂ%\1fR\97\0\11Á\86ø·r\89´\91GÇd\85s­æ>âÆ;HWÞÓ.H¹FÙ\f\85\11HAù\98N¢p\13Â\9eÈ\13âÊ]Ñ@ÞÑõ&Ó\bįU¡\13¨
+\83À\82=\16¤Ê\8e@¡Þdzt\fG÷ã|\1a÷\13p±1Ð\1fô\96õ\9a\ f\ e`\9fŶDý\99<~ªörÁadz\12«OàK\90        >\16CmÛ\8aRF\1c\12F\82\e2\ 2ã¤\1e\18\1dð\ 1=\90Ê5\1a¨\15èÀ\10s\f;z\8aÏM\ 3cA\96\86\86\81\82`Â4 \ 5U]áQ\ 1N\b\ 4è\90\14æ\81xï¾s½\98!+(*F¬CÞÓî\9b²Ø`PA?ϸ-ªmË#G¶\r\94\ 2lè0\o×ÏÜ*x¦\ 5t\90«\82¡öp\8bøà\85w<Ï\1e\r\ 6$\8e\88\90'üD\8a\ 6n¾(\f\9d8ãΤÑv\9e\ 2ÌÍ\9d2Êqº·u£õ\90µÎƱ±ïVBr\vr sÃ.q\ 2Û.D \90\98v]ðoÁ\99s²ùXöãäH6»Ã\9e\82\8cV\92kQs]mË¢\11e¦*qéIÞU±òÊFd¼&c¼Ïb\b®$­\a%c²r\7fh\ 6µ\ f`¦¦\94é,÷g\1f*ЪÉDX&¸ª\96Ý«ÿ\1d\19î<³ê    \87\81\95ãÀñBRÒÔ¸õ/Äô\860\8d\9e\açøxkINë\12}µ±>ÞÖÛ¹\b\88f¡Øêân+\eH\81¶#\10\8ez@\86\ f\e¬3püSÕ\1eÀÍN8\88ö¹Ý\97\9b1ËgÕÛ\98e û3ÓÝ\8b¸l\9aº\19ÖIv\1c;¯¶ \85g¬Y±ö\0\8an%û.\ eÈ\83\16ðQ£\ 2v9âÔ;\1eY\95ã\9a\9ep\83\13¨ìõ\9e\8aA\r)=\98ûö\1e\1d#o:¾W\90\96W-/£Â`xa¿ïbD£
+&w²\ 5\1a\13¥^î\87¥\ 6¬YaÀ´[*- [m»3*YðP\16\07ÔrjÐÙÐ,×ôØì.õvʱf`\94ªO\vA<\90
+¢¼\fpHb\ 1\8e÷là\ 6ìkSíżdã\88¿Ku\ 1\94@Îöî¨\92ú¸gì\9aqC\11\ 1'¾&YR©IRóÏ\93%,Ë|ÚeKaè\ 2¡ÀÙ5PÐuuÕ¸Ä[vx\85\19\10²È\14\9f¸ÃÉî`\965\85­j\v¬m\ 6\at\13«²\7f>XÉ);¹\15\82Æe@Ub8\90Û|9¯AùBa\91¨\93Ì\86}\13%»_\7f\f@Â&ú4GJX\ 56DL¡F%\80\9bÐ!±Á0½&Q\89\ 1CRÚÅ?\1eÐ=°oÉ\ü
\86B\eE¬ÅÜ«\1f\84®'Püê\94V7\18cs¬»ÉQBñ\17R\1e\19¸r~å\82±[p#Í3¯\eRAËE\rr\fù²Ü\9c>Ná\90Äk\13\eÝ­}D\18\94ÛÉ·B~\ e±X\ 4Õü\95\8c^\1cq\803åÔOgÊà\17çÞëÁc\11.¥|2\15\97\82\ 3H\rßò\88ËÊ-w\87Á\14û\ f\854
+Þ?tÖÙô\vX[n:oµD\90zzÉãà\e¼ \b\12:\ 6µ\17\8e±ER\84\99£\143\92"&\84°\9f\9f\15.°ÍSã:+ÏãÏeSóTsØÂà\84Ä!üá  ¨mDµ\84m²Jc\8eAxð\ er=ëíaÂã\18È\ euïPn¶«ùÛ»ùKv\99ËGØê0\99oÀ:\1eËf\ 2·y\96¤Çýâ\87\1f\9dÚ³ª\r\8dÂ0\8a3=\86e÷ü\84\vVÕ§\8a}\ 6\8cb\ e\8f\83\92åÔ<\8aðÿ4ã\b\86ýû¦>ìZ^ɯ\13:V\9eÞ@´\14\ 48u¬\1f°G\9b:Z\9a¦\9c_öIm÷\ e²âø\9aË\13/|\vþPê\8b\r\ eM\19\ 3\1f\e\17\10\80S\15¿3c®fäQ        \87ûG%ì\b\95|R#      \ e\91Ò\8e    éRþ\13ÄÐÃ\80¹\0Äk\9e{z¨øµ¼{Í0^ò`¶\ 4èÞÕT\90\177\9d;"
+\a\9d¤K~*]òR(´\97*ÉÑKÈ\vÜ'O\14\17=\b¾\8dü\ 1J¦Èá\87e>öî\9abSÊKFg\17\81|1Lî\8aª\91ç\91înËÏÂ\83\eÉ\7fó\1eü}äÉêø'Á©Ìå%UKm/o°\8bî\8d÷¨_è \ 5²¸\C¬jùµuð\1a¥\87ÆrËé­PÒö\8fÑôå\84\11\1aw\rø  \9eê\1e\9e\11\aýI\99H\11ó¿jê\ f\ 2a¤3\91ÜuE ;VBJ\r\1c\81\87ê,U\9d#ø¯¬0\91\87\84Å\ 4\\91%9\847\ 3\19\96ëþ©:s'\9eþ¹\9b\ f\16M+\9d)aï|\91¤\10\92,?þ      )+Ò\11I
+ßb¡È¶Ýãó\19I@¶ñÑ`MïIG\97)h\ 6÷w\97©ÑmÍÔ+¾\81¤r°ærØÔ¹øÔÜ\1d_S¡M\80\12\13§OÊÅ#Ê #\e¢,\84Kx\97Å\84²\90     Ê`\80P6\11T\HRÛ\a\ 5\82h\82      ¤"?2Á¶±\89\1däB)É\94\8b:/0 ñÌ\9dÂTç\96\886ú{L\ e9W×\å:±öä¹à\9fÃVaÙð5°å?O!'<\96Í\13È\85ëÝW"×}\ 1¹PßD\835\17\91k²o»¬\99º,3£Ë.\ 1wê?Õ\9bÅÕÿ\ 1E'2V
+endstream
+endobj
+828 0 obj <<
+/Type /Page
+/Contents 829 0 R
+/Resources 827 0 R
+/MediaBox [0 0 612 792]
+/Parent 775 0 R
+/Annots [ 823 0 R 824 0 R 825 0 R ]
+>> endobj
+823 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [371.441 439.082 386.163 451.037]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.6) >>
+>> endobj
+824 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [206.164 297.886 228.635 306.797]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.1) >>
+>> endobj
+825 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [284.204 297.886 306.676 306.797]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.2) >>
+>> endobj
+830 0 obj <<
+/D [828 0 R /FitH 686.127]
+>> endobj
+634 0 obj <<
+/D [828 0 R /FitH 606.349]
+>> endobj
+78 0 obj <<
+/D [828 0 R /FitH 284.459]
+>> endobj
+827 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F70 508 0 R /F48 455 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+836 0 obj <<
+/Length 1887      
+/Filter /FlateDecode
+>>
+stream
+xÚ½XKsÛ6\10¾ûWèVhÆ¢ù\80ø\98\9e\12Û\89ÝI'\99ØÍ%éLa
+\968\91H\85\8f$ÎäÇw_ HYrrH{\11\81Åb±Øýö\ 1ù\93åÄ\9f¼<y~{rö"\89&\99\97Åa<¹½\9f\ 4~ì¥q6\89ÓØ\vÂdr»\98¼W\91\17zÓY\92¤êêúåÕìÕå»ËWÓY\14EêâòüõÅ%\8fß¼\9d\86\89z}~y3\rÔÍôïÛ?Î^¤\ 3ÑÀã%:\83\83Ih0G\96\13_T\99Ì¢ õR\7f>\99\85       ì\89\98ëveYú¶¶yÑȤÙNgaª\80òÁ\ ftnÚ¢*y¥ºçïª\9a\ 2Ã\17\9e´,D«¼\82}\89ZØ;Ú_ñïÇ\86ÙL-â\176ç¥\85]ÈÒVN4µ0\17\8dÍgx\91É,Ð^¦5|\ 3/\9bÏY}R\f¯\19À%ýI½\9cðà-\ø=í\8f=íé±%Þ+\8f­§Ó     \b\8dt\1c¢ý|0Q䥺÷É\14\8e
+çêªX®f¯ìçi\14\ 6­\92¹º \e\0aa\99ð¦æyn\9bf'\9c4uÂC=öx ò\a²j\16vcÛnûØÁ \ 3\\98øâºçö¾"\8bj\7f`Ñ¢\2)7hA\1d¨;ò\89]\16å)\12Beú= \81r.«\99ûO\0×_7·£­<)Ê¢-̺øFN\ 3\ 1\1fÆ\b\80Á]Ñ6mmÍ\86\8f½µ²\ 6ÎA\aÇ!`¥®­\0­*Ao8xÉKm%_\92
+\ 3\119XdÝR%\fCDA(ÍÃ\f\91\86\97»Æ6Ndme\ fksHÏ­É\11Ý\1fñǶ\rZé÷éLk­Ì\1a\0 ý\84±¬ýTÕöSWÔv\ 1¶ÕaL°Åõª\ 6ÙB»C9\ fÌÞ®\8a\869\ eÅ\18¨\1eÇ\10ãen\85ɶ¼¯Û\8a°ÁMGªÇ¬úÆÈaa\1a9\13-Q)\9c\9bV¾å\80© I[\9bÙ}m6\96\89c\v|¯j&C\10 ¡\1cí´õá\9d    Ú\ e´\ e3Ì.\94/>\17\14ñÈ\87¾=`zH\ 4uµ­\vÓ¢\97 :ä¾\89ä
+ ÔöÞÖ\96L\84S:»áñ\8anÏJ2Ŭ\ 19\8b\a\9chg\ fÔ\7f Ú¥!`0¥\9c\91ó-Vvñý\90\96"h]\95K   \81\80q\89ß\15\0YB¦Ç \8c\19Ãàa\1d§êºÜgðÕõ)Ó\bc8 S&\ 3\18Òê}ëBU\82N\8ed\ïâôé\0Ü¥cý\18\ 1\94èëÑâÎÉT,ÆN¦t:éó3¤¶P\ fÊ\8bÖ©\v6\1a?
+/$\826\88ðDB\b(}\b\ 1­ur\0@¬Ð¨2íNØçÏ«Í\ 6w$ª=^Eú­d\16Â\0ܼu¥±¡tÌe\8f8]ùÈÆÉ9\8c½$c\89רf\14î©\19\a\81ºê³Î8¹\a\90ÚçÐ*ø\ 3ÃÍ¡(\1c¾ð\1cd\vÎ\0\12\v\ fíÁà@jëDºl\8a\88Yäø\91]\18\9dd\97¹Ú"Æ*´$FqÃ62üùL@¨\ei\13´¢ã»\rþJ¬°y]\88E\18}¨\é$íz\b\94µ25\1cg¨@\ 1ö\8a¦-raä\ e\ 1Õ©\ e¡}W5 \91v\1cÐ<3T\rbå \8d\fP×°rè¹zÆ\8b\0\9díÚ¶²\ eWÎëb+\9d\10\10H\8f8vE*9â)\9Piâ>Ý\1dï{~ÔÜhhnÂc­Íql\9esH :ál(\84Ç \99%\1e\98r\bÈ0\1cG\14\11\hã¸(óuGèÀ\19\94]¡·ö«psÏÁ"\80.\9c\1fü¹ÿOk\96Ío0
+\18\92|ü¸:\10x\\v\13ô\99>PØ=,(gij\17$-\87ê¾\1a\10m¾.Ø=gëâ®6õ\83ãÀ\ 2\89,X®¨0t97;\83í\83<NMÆ!äÁ¡\e\94¥\81\1fq\82_IIaoÀT     Ç.7\86\8aº\ 3\1dõU\ 4Ç\r\81\14WMãd9é`â\85ì,÷Îy7M1\8dß\81 'õZÄ\90µ\ e)~#p´_á²i¬ú\ 2\99c%\8f²L})Ú\15¯5kh\8cå\1a8߸\ et\0\7fH6¼¸è,\ f¨L¦.l`Ð52 \80\82¯\91\1d('ÂJ?8\ 3ÚK\1e¸\1a2;t\vr¾ö}µ±\1cõ¦,\1atYÌÑ\8dK»èÆÙ(º\91@^\83oÿÎÁ    \9b\967\ f\\88\85\ 6ÏW\83æâ¿\88üh?ò]ý®\84\87â+\97§\ 1IÝri\9bÖ½º¨»ÜåT@\1d\8f\13È\8dÔC\0Ô±Ô\91¤^\98eãÜ\91¥®\92â°Ï\1aÙ(kd        Çó×Ö\96Máâ\e\99\9c9]­Ë\99»¡IÛ\ 1yë¤qø\81\rO9\93\886{\18Á3\19)±T\13\1c\fp\ 13î¿c¶\90\8e#õ©3\9cû\8ao®÷\0*\9cV\179^\0y)KáàªC\boLéD\v v¯ã\84\a \ZK]©F¯TøÕ£Ö\9f\17V2¸8¿e\16é\95±´Æy!\99\91ò,þÁ\0\ f\98\ 1n\89kXÓ×l@I7tÌ0\16äÍ?8N\8b\e\8fö\97O?éõÏ\0\9cÞíO¼ÚÇ\ fkx\14§Ñîa\1d>~Xï?Ò\17]m\7føÀfؾ\1dæä)B°Á\15ru\98\80I\1eØÎ+Û`üã\9a+"r\1a±Q5¢\8dØä#\85»\17\1a>ê÷\91è¤Ýw帤\ 3»\1f\98,uâP÷\ 3ܧûy ©\\v\ fY`ë:ªMÑö9\81ëe4x\172\13?³¼\91OÎ^$É°\85ÅÖ\1aÿ_ò=\1d\ 5¬Å\870ð÷ö\8cZ\f\1c¹4q1Ä÷ãg\86¤(zºnûÇ?\90\0ìs³|Rµ\19\1f\84ªÍ³ì\17¨Ö?\86ôÁ>üg\95\89\7f\81*ûÿ¥Ý­\ 5wl;yÅ¡_\ 3EQ\ f\89\v\86®UÇÖ«\7fä\r.çÀQ®\1f°'û\7fÍ»19Å*(À×I\94Ä\ 6/\8f¹\a\19ß!bïNzp§èÈ\9dÜ÷òöä_÷S\9e^
+endstream
+endobj
+835 0 obj <<
+/Type /Page
+/Contents 836 0 R
+/Resources 834 0 R
+/MediaBox [0 0 612 792]
+/Parent 841 0 R
+/Annots [ 826 0 R 831 0 R 832 0 R 833 0 R ]
+>> endobj
+826 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [126.352 645.213 148.823 653.859]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.4) >>
+>> endobj
+831 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [189.255 408.14 203.977 418.878]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.2) >>
+>> endobj
+832 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [189.255 321.574 203.977 332.422]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.3) >>
+>> endobj
+833 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [221.384 258.918 236.107 269.767]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.4) >>
+>> endobj
+837 0 obj <<
+/D [835 0 R /FitH 686.127]
+>> endobj
+82 0 obj <<
+/D [835 0 R /FitH 630.47]
+>> endobj
+86 0 obj <<
+/D [835 0 R /FitH 599.569]
+>> endobj
+838 0 obj <<
+/D [835 0 R /FitH 457.126]
+>> endobj
+839 0 obj <<
+/D [835 0 R /FitH 394.47]
+>> endobj
+840 0 obj <<
+/D [835 0 R /FitH 307.904]
+>> endobj
+90 0 obj <<
+/D [835 0 R /FitH 245.248]
+>> endobj
+834 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F49 457 0 R /F77 675 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+844 0 obj <<
+/Length 1949      
+/Filter /FlateDecode
+>>
+stream
+xÚ½\18ÉrÔFôî¯\98cO\15\12ZZ\e99¶!¤*@Á\84\1cB\ e²Ô\9eQY#\rÝ\12Äùú¼¥µ\199\10B¸Lw¿÷¦ß¾´¼Í~ãm\9e\9dý¸;{ü4Ýdn\16\añfw³ñcÏ\8dãd\13§±ë\aÉfWn~\17~¼ýc÷óã§I8§\8c2W&\ 1\C4\17?\9d¿Ú]½Þ:a\18\8aÐÝ:I\92\8aË«\8b\97\97Ï_<cèËm\90\88·@ãû\81xûüê7¼õ̳¢\f+°Ifl\1c_J7\82½\13$\0\f\99Û»À÷\16ÿ^j\81;\7f\90ìR\15íÖ RQ*\96ãØvUÛà^\8a\ f[@¨¢kµaä;/òª\ 6¡\9dÒLs£ó£²è¶©ï\80Äwïq_ÊÌü\9dÀw\ 3\19\7f\ 3\89¯k>\17(×­S+\16»¶nñf\17¥¡\9beãMï+&Y¸Øw³D\ e\14UsÓêc\8e\16ùg\9d|/r3ò\ 3j\95|\ 3­./ؾ\ 4N\84zçùq±u|Qm}¡pÃ~`j\10\937*/0\90\ e|\1aï,×Lõånú\16
+ù¦c\8dÎ\91ùÅB@Ö®R\93\9eJ)«4Úê$­J\89 µo¿oä\ 5\8dµë92ÿ\ 2\95Àu­Í\9b¹V÷\1d\ 5Z\ 1åä«äÛøÊ÷\1fÒì     ÄS\9cð\12Ãò=ã"\ eõ¿´âZ`¬\98°Fk\7f\95        ¿"6^QÍÑX.\98ýåç\14  ÅI«²*>_\þ£Å_\83Å\eÓé¾è¾0ØÌÿ*ÏE{B#Ü1ó\1e\987TØî'6\1dçõÊ|_\ f\ 3\ 2\13\ 4|(kè|X\82\9b½û@\87\96Ù\8c\85\a\ 2\85n\10fÌäEÛ©'\9fv\9dPº2L\aI\8a¡\85A\9cË(\12ZåZçÍ^\1d1|\12\f\1f\ 4·7¼v\aÅ\eÓ©\93á-4i\8b«,䤭)\95\19h\ 6\fëhLå dÐÌ`vÉ$¬Ð\v#kÉëZÁØ\12y\818Çf\1f\85"oxU\7fæÇS­\1eá)!Æ\84Å%\10Gulõ\9dÃþmÀl\ 6w\9d\86]^5äj¼\82²âC¥Ûæh3\84®\ 3©\1aE2yV\9aÈZ\88\98\87p\7f~K\96²'´N_w\15ÈÃ\90Sn\fO'\ 1ØB·ýþ0\1c,ÅåÅ\8e\89:üµåÌÉINüi«rM°ë\1eþ\1eB\844ûÑ9GÜÅ"¯ë¥oØ6Û4\14`ÙÔ÷ÄË\86)G\87b¼icÝ\8dª\80Ud\1aÏ=\9eë\ e\882dtÎó\\90¥\141¸N\85\13O\ fT(Da\88ÐZZp\85\12½ãE\10\ 2%ãA b\91\88X2ĨS®óNñi¯º5\11\8d\13%Z[J\91\8d\8cDo(B\0D\ e\90\94
+\16B\81&mô#\09ãÊ\ e\ 5Ì\83\ e¥{Þ÷\98Å\9a\19DÈ`. \8dz=/\9dÒ÷g\96\93\98E\10»\1c¯\18\ 6Z\ 3\1cUS`\16ÅI"v\9c\98\80Àâ\82\ 3\9e\8eÂ?A²:k\ 6\82¢\19é§\11°Òª¾³PPëÃ\96¢m9#b)í»So÷ä¹0`\ f# É»^C\88Ú{Ø3P\raúgX*jµÏkwM¬çh\9dÄ\83ü\ 3\96¹-î\b°u\8c%!È5_Ì\87\1c\17ßVzÕ §dÇ°ÊÒ7mã\fE\84\aË\ 6ÒÌÊƪµ\8eó$\96`<;qLÙLp\88\ 1\9dA
+ë`5Ì\1aÜ\85º\93¶QÊ\ 6p\ 2éf^²,î»\83j5^\1axca2|´~\89Ð/\10\ 4\16\98\9b\91D°ZÞCü è\1ak\9a%+ÉBXF©¾ \88ª
\86¶>âÚÁ\8b\14\16w\10\Ê¥¡ÈØ\1eÔ\15ò\14\16gò¤a(õ\19/ÁBOi\0 !c÷Ô¢\0·d5Ôy\8cõ8\84¦ÇD |ÔæX¯\9ceæó¥ðÎ:0ae9S\96j*72àr³\92¤$=$þ    kaÑ×¹FúÄÖxÄTØ \86h\18Ò\fà-
+yÃû\89\98
+\b\81 é\1a\9e\aðø˯o,b
+b\89!RCÚÃùã\18ë«­\ 1¦½¢2\98©\ñã$\84\88A_R!ð\90\80Óe\8cZ\84²\^6s0\19\1dPÇÊ\80ÍÆ\82\ 44P7 Q\1f\19]´Ç#¾È\19\ 5ÝÃ\16§
+Êòª\84\1f+r\80\1fM\13bAR uò\8eQ8GPÖáü\8e\80\9c\97\9aç
+ØÑx´§\8e\8f¡Ôö\16>7'\1c\8d\r\99\82zJa\1fÙN\9c¦âM?<b\91·e\0Ú®gùd\82\0þ;\9a H3vIÛ×%ãF¿á¡T\(MG!ÉÀ®å\95\91íe\15¥,Âs^\0²¯-\b\86\8a¦\1c/PZãó\ 4·\10\97+ââDã\84P½èà n1íÑX8  £¤\88\ 4-Nù\9eú'\1eíèÒRùNlP\84c   Ä\ eÀgÓ\17\85\ 4,\99pùÃËZ^á\85²\1e¦óGÉÊ8\9b¸±Ì\86\99\19\86\98ð{\8b?
\8b}±Û\86¾¸Ã©9 Ù\f@üî\83s©Ö¾º\ 4n
+Ó¼w¯\90\82÷{\9eß|L´^óî\94Û
+\89m£cXGmÇÆ\14¼\14\1c\18¨ñ"Æ\8e\93\14\91\1e´R«7q\85´Â,̲¼\1e\16\98\19\8e¹¾Å\9d\9c}uÁ\13\8dYÃh\12È\91\ 6Õp\7f\18¾ää%Í>HZ*SèÊ\ 6jÉtùð\14\82\1f®\10.§Än`\80¦é\ eL=©\94\8aõ±k¡\vNr\1e©B³^F]\11 \1f0\8bK5<Ì\0±¼\98,,Å9ö\1fĶ ­æ¿\9epºç\97¤\15\82(:êdvÚ1LÊ£\1elô`\v£4ëXþ\80.òï±5\93¼LµÖ\11¸\90-Züt­\9d\ 1¸­úb2\ 3Ð\99\ 3\17\vúV6!BQí\9b\16\12\83\9bÿØB\ 37H­MÏ˲¤¡\11*\95\ 2'ä8\12\7f)\98ä åïI xÐ|ª\r\0Ù
+°é`¾íøU\ 4P\8b­n,ò îx÷\91Âuø\13?ÄR1ÿ0\vGNý\a{þd£¦]û\92\7f+p¹Ýí¨\13 }5´ùGÖÖfaó\12ëÙ©®
+®bçâõWóÕîìoÝ]ê¨
+endstream
+endobj
+843 0 obj <<
+/Type /Page
+/Contents 844 0 R
+/Resources 842 0 R
+/MediaBox [0 0 612 792]
+/Parent 841 0 R
+>> endobj
+845 0 obj <<
+/D [843 0 R /FitH 686.127]
+>> endobj
+846 0 obj <<
+/D [843 0 R /FitH 190.636]
+>> endobj
+842 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F77 675 0 R /F70 508 0 R /F11 573 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+849 0 obj <<
+/Length 2780      
+/Filter /FlateDecode
+>>
+stream
+xÚ¥\19MsÛ¶òî_¡#5c1$A\12ä¼Sâ8\8d;IÝ\97xri{ )ÈâX&\15\92\8aëüúî\17HP¢ÒÌô"\ 2\8bÅ\ 2»Øo\ 5\8b\87E°øåâÍÝÅ«wZ-r?O£tq·Y\84Aêgi¾H³Ô\ f#½¸[/þð\94\1fùË\95Ö\99÷þæ\97÷«\ f×_®?,WJ)ïíõÕíÛk\1eÿþi\19iïöêúó2ô>/ÿºûõÕ»Ì!\r\8es8\98\88\86\1aQ.\ 2¹Ê«w°4"¯,ö*Ò\0T¼çÝ2O½¶x2pb\9cxïM±6-\8fß\9a²\81Qä­ÍéÑa\14úA\96Ú£ï¶H \b¼\8dÐ\82áVhEyî\95M\8d¬ôEUw\fé\1a\8b÷°kî\8b\1d\8f«zÓ´OE_\ 1>\9c¹XÙsVaèçI§\15÷@#ó\9aC¿\Å*õz<=VÚ+\ fmkà¤Ìë\19@×AI'1ß\11\81\7f\ 6aÜv²·ê\18(4RË\ 1Á\90ÒË\9e\ e\9aÝú\12fiä=o«\12q¶¼Ø        jY\11Z''l\88\95`ÊC¿¥\93cíÙoQË\9c\19h\v\9enàíåJ0kÚYd#à\81ß,ñnf\96ä¨}kÖUÙó\ 4\ 4\87\9e     ÷ð§\9b»ø¦m\9eà±r\85T¾UÍ¡Û½ð|M
+\ 3\e×fÍ\90Öl\f<Hixj¯\10zpÅ4RÞ\r\8eGv]\1c\1c\97È%\ eîí\13प×F\ 4\r\rW\98¹êÑ\85À¢\9e«~Ë£\1au[Å\9eéúâ~Wu[\8bâÞY)«\ e¡×ùtD\18ûy\1c£búA\94\1fÃ9µù»çѾ2%î\92\85fÃ_W¿\ 5ÀßÞ\92°ê\17å\83\ 1\11^w\84\a\19­Ù°yêÀ±Ï(Ëý$\88¬}~­æLØÏ\a\84oË$õ\8aÝÁð\9b¯T¨}\95\1eÛÝn× ¸\9fñ\87å\95\13\aJÉÍp`u0Nr\94LC/\v\88ÃîÎâ\91"Á¨©\r£ô\8d¥Õ\1a¡¶F[Rf0ë\19V5²\9aý\v«A¤fx\9d\9c\8c\ 4\10å¡\9f¨p*\80CG\Ç)s\rß\82}eWÕ\ f;àâÿ\12ǹg
\1fp\ 5µ\0¿\8eÛÀigv¦ì;\87 Âzw\ f\9eð7\ 3¾\1e
+\16Eõ]ô\b¡ SmU\9aîrb\a)_\9bä\eG\91·!÷\ 1\ 3º\97&¿\ 5³S\92\b=ö~\0ú3H\82\8a\11J\96âàµ\0'D÷\18Çà¤Ö¸¨Î]\80\1d\97ÍÎ.ìwEmü9k¾³\1eÚúïSU\88\95\1fäñ\ f5\ 10\82ðD\13Ø\7f\fM¥ý,\18bl±{.^º\99P\1cùé¨\83¬'x×ç­©\99øÚ8b\ 6uáõ·W\12¹ÐQiÏ\0o)ú\8d²²>\98¢\97"îgt?Èü$N\7fÄ1¨vâ\aI6\15¦Ã¹\ 2\1f"\8a\r#¾0\8eN/\8cÐ×\b¸â±xWºôxaT}\ 5áߺ
+àê\e9\8cVVØ­\ 3\ 4.\91xEûÂÔÄ\1f\0ü~Ç\84IE\1ey\15\8ctF'¦\98èt\80þ\97ßÕ%&\19\14\1da5\1fâZ[t=-¡ÏÁ°\85\8b®_¢9\7fĤOe\1eæè8Ã\1fj\19ú\8ehFË\90°XTË3ñ÷4l\ 4\r\86ª(\13Ï\8apP\16öMAìÇ\89:rε\ 4°á\85 ºÍ¿\90Ï7\9e¤\87 Ø(õ£L\12Ô+\9bú\91ZÄÞ\9b\1d\ 3Ê%ü<2ìf\9a¬\1d\eZêC\9c\1a\13Ä\8aÄ\ey\10o\1f\f\ f×\ 6ÜÈSU\eYrü"NùqµG®ê\91pByÒÈ
+%\12\ 1r²(gNåÒ¢\8e'\83,\98¥D¼\93\ 2ÓâcÉ\eâtØp¨Ç- ZI\90\82lgô!M|\1d\r\1e¢\&¡×à\ fäÍø\vÄtJÌÀ¬DÙiÍáûDh)ú\9aÁ\9aQb|ñºëÛCÙÛ\9b»ñ\ 3¦HKÂv\ 49~¢\92\93°\r\88¡ÈL\85j*\8a0:2£\8e\91(ÄÁâ1rÓBVB¦\96\90)
+\ 1¸à$®¸\9f39´ù0%\17\0\8e\80lýä@9¯;>\8föR®\8bb\9c1ÿ®\99&së¢/\ 4b̺ãa/\8b÷ìayÒBne\13<NC\94Í`bo_ȽÐtú\9f°\96\8fEÙâ)iè½\81»îÐ\83ã<D{   \89Á4ð>\ eå\14MÙ|\10õ\9c  ¥\19\8c\aupd­¦²\8e]Y\8fîö\85×ÎËúÈ&\98,[\92\1c=\91öÍow\9f\10!Ý°ûÐ\9bf\9a\17¸¬Á\91µsÍ5\16\81\1e«½x?4¨8¢"\85QÆb\ 5§¶
+Àq1\17÷\92Ð\8fÂäG6\17$\90\14\95-¯À4\9e\98 ¬Î\9bàÊ\92\9e°NòÊ´5Å%>,<\1c[d\96Z%ʤ\16eTG´Yzú\f\19{\ 1,\85àr¯I\0/\8cû$ú\ 4(S'ÈË®ý\ 3ʶè\18^ôBÖ\14ÌÚ|"\b\1a\bèbÕw\fØ\1d\9e
+\1e\9dø\ 2\ 4ºÌà\9c«æ\88äQ\81;°ð\11ï\7f\0È\ 2ö=t"\b¦å!ë<qxö@tÂ3\ 6ïºdÉ&DÛk\9eU\eI\17¶æE²\r\89ýEU[\80ó0\98Å\90\ 1\v^?º\ f*j\8cQu²y\89\91è\81a\8310=Ò\15\0OªÏ¹B\9a½\ e\9d\\18gîõp.º\80ÃéÍÈôbkz ²®«\1ej»­\97\08 §æ\ 3@\87«þ04JæN\9d\11\ 2Dü×@l\86\93\89D\83l*Ñ \9b      /\81Ô\8d°(Oªíö|Ðþa§\93\ 2 \90\ 34\ e\ 6\8e\96\a\ 3ðS×\9f¨\15v}wñõ\ 23µ`\11\10â4ø4\b\99~
+ùpùtñÇ_Áb\r\8bÀ\91¯òlñL¨O\vHð2\fè»Åç\8bÿsOÏõ\11q\98ù\1a\98GJPå²\10~»ýøÅÖΡ\9f\1d÷¬¬\8cDkÔ¨5?\13_\1a\920÷¾`Ç\ eêŦ\9d)C2pÛñ\90xÞ8\9d¤\ 43%ÐÚ\82¬\8f\1aA      \9b\19\r&\ 6\ e¸¢\1cUk0MF\fêTÀ\17¤\8b\140\12àÔ\8d\ 4dðµPè8a_É\95f\9a_j\8c\12\98\12\r i\94H´ò>s³p\1a'p:\95ª\e\98(\18¢s\9c/C`¥\85ú¦j\85.· p \94IL\rJlÖ\11\8b`ÿ\80Éò\8bpû¢á\85±m\ 5À£æàZ\9a t\9e\9at
+Ôh\ 2*\9b)q w\80\93\9e [\ 3vJ\8eº]nk¦\9a\91ð/\19\87\8c:\8b
+*Òb¿o\9b}[\15½aÀȲö8\9bC\96yÎ>O»\169ÈAOx˼\89¹«ì4Â)-7ç®ìL\1c\eÄ£NÄsÞ\96dï´\92Y}\0­\80\81ÙÍd\19©\82Äþ¸Î\9bÐ\ ec(­ÃÑÞ~P\10¥¹\1f§C=t\83\ 1\18Ý3\7f\8f\1döP\8eÆ:\ 2E\84Éa×Wûùj4
+}\9d«\7féy¨±G0v¿.¹¦ég;\vIä§Ù\7fë+$\13\ f\9d\a\80\90èÓÄ(\11}JNt\1a\8bÀæb\ 25\ 5%Ķ]\9c \9a£\7fëyr û\80\r\èã¨à\95³\85½eèç\99NO\99\86òa[,©¹am?ö°\80\81\ 4H|\7f,\86\98ÿ\84æ¾½ºCתmq>Võ0ég¢A®!\93\1dë\87ª\ 6ÝzYBÎ\80¾\1a²\7f\8e\98yæ6\0¹u\9fña*×gZ\b\8cľ'wß\89\1c&¸NtÝ)Xðk\8e\ 2r\95\89®p\v\eË\aLG\81M>4ÊÎ\1f\8a\ 1H½ïÕÃ
+Oú^<0\80
+SÆ\91VJÊÍ\1c=ôg£ìTß\10­\12Ú­Ù·àY%Ȭe\83dæTèðgW\ 1\9fôOF?çX¹i\8bïÌ5dM   \94N(\8btá<å\86\18$\99}ñ¸\94\1a5Æ®)/slB\80\90U\11\7f\8f\ 4\9cØ7¶\86Ý\1etlÿ\ 1Áî,\13u\89ho¶lèÌ\93Õ\8f\125\10¢£)j\10)p\95\85\94\e
+\19Ç\ e\878%\ eq0\110\83\8aÓÝ¢éé¼\1eP¦¡¹.<\96|{ vk"\15Nâ}7\g$gu
+×P*\95ì,¸3K÷amÆé4J]r\18.,erÒ÷``Ò>w. ä¨h¬y<¹Ûù|zÆä ÒlNþ\84\ 1¨UQ\1c\17ü\19þ\92\80qÝÔ+\16\ 4ÎÎö\9aÉ-\84\98\ 1ÌTܱöã±ëy]¯W·\9bÕ\9b±¤\86ô\1aârû\b&xê\88\94\9f\8cÿ¿\J\9a\1c\aòW\9ak9ò\87\1fzN\1c\90ê\a\81w\rR¼}Ãc<\8d3:2/ð§×¸\84èÎ\92üÝ\8c\8cB(ºmóÂûû-\ 6\v\åf"\9e\a\9a\8eÿ/¶ã©\93õ#ßáþÝn¿Psü\ 3ïÿ,¼
+endstream
+endobj
+848 0 obj <<
+/Type /Page
+/Contents 849 0 R
+/Resources 847 0 R
+/MediaBox [0 0 612 792]
+/Parent 841 0 R
+>> endobj
+850 0 obj <<
+/D [848 0 R /FitH 686.127]
+>> endobj
+851 0 obj <<
+/D [848 0 R /FitH 668.127]
+>> endobj
+852 0 obj <<
+/D [848 0 R /FitH 500.371]
+>> endobj
+853 0 obj <<
+/D [848 0 R /FitH 436.282]
+>> endobj
+854 0 obj <<
+/D [848 0 R /FitH 326.309]
+>> endobj
+855 0 obj <<
+/D [848 0 R /FitH 254.139]
+>> endobj
+856 0 obj <<
+/D [848 0 R /FitH 202.004]
+>> endobj
+847 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+859 0 obj <<
+/Length 2860      
+/Filter /FlateDecode
+>>
+stream
+xÚ\95ZIwÛ¶\16ÞçWxI\9dZ\f1\10 \97\f=§/9=~íâµ\vZ¢d¾H\94CRIì_ß;\81\83D¹ÉÆ\ 4\81KàNøî 'WÛ«äêí\8b_n_¼|\93]åqî´»ºÝ\)\97ÄÎù+\97¹Xi\7fu»¾ú_¤²Åß·¿¾|ãÍ\982Ícë5lC4¯Þýüñöæ÷ÅÒ\18\13\99x±ô>\8b^ß¼úðúý\7fÞòì\87\85öÑ\1f\94\8eþx\7fó'îú"\11V¦|,ÃöKíaÒð!U»Xê\G\87ºÄ\81\8av\87zËSOesàQs¬áxk\92è¿õ®ú´ÐYTòʯ\1foÞò¨¨×¼Áo0uÍsÝ}Ùȶá\9c:lY~>VM¹/kÜ­ãÉÍ¡aê²X¡d÷(\ e\88²T*ÎÓ\949¾Ûá\16Y´Â\ f?\81\1e\12\eu\a|¦Q\89LàÄת»ç©\82\aú¨\UÅ\8e\17öEÃ\924$[\1a½ß0i}¨\977\1f~        ;\7fBNʺå÷ǪÜÉ\19_\16)l¿;\96²DÜÓ\91»\1dÏ8Ë\13\87Í\9c  \1d¶â\8a\ 5*ÿJ\94[U¨\11\1fu-¯U5?Q\fc£»\ 5Z(ÈïA~\15\12l'´¨c|²\10°4\88Ê\v²ÁêØ´1q¦l\9c[\vìÙX\99\8cÙ»)HèF\97±\1e`\a<Ây2'N\17m+\9bUEW®yQ\94\8fË<1(\1fD´+qýdìúÞÇ@\19\\1f\93²\1c\14°.¿ñ\17coN\r\ª@^      W\ 5\9f\10°nj}ôf\91\81à\8d0TÕÛ]¹$Ù\97Ú¦qîÕÔ8ç6!/5&\e¹\ 4i>\aÍ\93:`\89\99å¡L\89\95³è©Ú.\9f\8aí a\8eÎ1%\1c«\9aHOÖÏijiÞ\8b7ãgx\8f\97p\85\910\1dvGîmæ\84{\\12¦h(St(\ e\90ûÅRE$Á     1J\10\88ÏM«­\8f\9dêQ\r= i»s\8bj\15\ fØwAý|ðä4°\9fËcc´\bíx\ 3\86,\aÎ>\18>w°ï\1emwWÕEW\1dj\9e\9cªDiQuîQH¸`%
\8diɬð,¶\ 5\19\ 6\88ÀÙ\89\ 6Ç\83\91\91V\8c\fódd<\8awvc5\9cÚë\92ëiϾ\80è@ÛÀ\801\1a\11¸ \98¶$³e\99a\85a\0\ 6\ 3\f\90çÂèë}%@\v¯\ e®Å¶®6\8fá\8c¢;9\rðº@¡fÝ\8cD\1c¨Ý9PkÁ\rxR¸Á\ 1\87\e$\1f\8bR\v\7fýÉA\95Úõ[\f:èu®Ï,\ 6ô'|ù^õé?`\84þBö
+2>ÄÇÔ\8f\14\ f\847À    Cp\86$\f\17ýEö\ 3\90ðk\8f  ~\ 4\1eá\bF  ? À \85a\13Ï\b1ÁýT\82  <y\13\180ãib¢×G\99¢P
+O1\a\13µ<¢\18\8f\ 3v)\18\9c¸TÊ\90\ f\v\87¹µèTv«\ f\1d\ fî\v$úÂiÅ\ \94x\86t>Ð\rQÑL\15i$\10àüBÓÍ#¿\8e\10Ø°¶/G¿[B\8d\80\v\98 äQ\81É\f\ e¶Í\ 1o\9bDµ5O\12.Q4\10ª¶kÊb\8fcÀldä\91Ç#nm\b\ 5\b<.e\95à·wxðãÉ\86§:\95ÅG\86Á^\8a\11
+\1e\9aj\8bP\87êR>Ú4\87}ÌßÝrÌRY´/\v²¯ê=\1a)I\85°Z\ eY\80\1a_5Xª\10pØe\95Ü
+ÜãØðíMÄÍÔ(¢É9\94 ÌfD\ 5ɯúè\ 2Cdz&¬x\107Q!^`R\97Bjt\1eVP-Ù\90X°.U¸ßk¶\9e:ÑmË\93bðsj¶õ¥]|ÈÍhîЬ)ÅôpOÿÄ\1c\8d¬\95åq\96eSñ×eØ\ fÒ\93kV\1dz¸²\11¤jÍ\0BÊN\92\ 4x\rØ\81CR2æ·\15\7f\0OÊÌTHQa06«\9d\88\81ïç\19\ 6øið\18;¤d§ö#\82\fô¶æܸ^Ñ\8e0\13üÙd!ºÂ$±wÜãß;¾J\rS\10Øej\1e\84å\fñU &+ñ±ëp\1eAÆø¬3<Bú\96\89zeÌbÏ çL\94\vÏÁTå\1a\11\14BüÏ\9b\8eù\a5\1f¡\ 2P,/Ñb8bÏ@Óò4W   \99\r<\ e6Eê\1a¾§³Ò\90Ngö\8c\99!5\9e\\r°~ì}Úû|u~+ ÛÎÂúuHc$\9f2ÚÄ
\9f ÉÔ\ 1Í\94\97\0§R]l\98¢d¤\ eè;q23\13!\f\96\14\eËÏå\93ÊÄöYáT\12û\ 1\1aB0Ø\ 2\1awx\139iLòX'~
+úX\ 1ZÀ§¢æ'\859\1cpö¬¼Tr/ß(5:/Óqªòp^=Ë\902}µr\ e5\8a#>>Ç\8e%Ìtü\1c\87\rå/\1a_Y@\96ôG\8co9'      ûÊqPJ\vK£DÛÆ\99±Ó\vR\97ߺ\19\9dh\1d'Æ?£\93,ε¾¨\12\9d\8fÏñí)©É\80¹åBE\93:\98H   kyøõþÐ\96²\81ø®ç>C:ö]>\88|\97\86-ï_~>bHaâ9'Ìlì¬ù\91+\ 6IÖݱ\vWLCTÒ'\9a¤|È«ÁS\97iê¸-áU_f¨¨\91zÃK\84ÂÁ¦üÚgzD\Ô3VÁ^\94\99%\8f\9d7\17Í\82[\v\1cù\84b\13LL¡\ 1\ f\1fA\ 3\90\ 5h\80\95p}¦\1eë\fÀ\95ý~]²
+m2Êw\86\96JͪfP\85ÁèB5<³e_â¶\rRB6·½?ùl\82\fZÁÜ®¢ü\e\1a\84!¥+Ó½Ú®h:r\81\1c¯U\85ؾý÷ÖVËY\94è[³¾U>ug\9c\98Æ\r\9aêë¥ä\92Î\93Xëì9\9dCQ­{£ü\ 4{Ã]P\94Ù\85B\0Îi\ frH-+Gv\84j7ã}¹\8a³¡Ä\9fu>å.Ã$\9e3)\15hF\ 2EÈ«´Oâ4\9fª\15t\8eQú{S}\8dÁ\99ú\96\10|á*®y*¤08ûP4-\ 5r¢åÇ»#¤)f\8f±\ 3Iz\aâUNW4¥\ 3R7\10ÀâÌ¡\9eC\18\a\12Ø\7f      s\10\vû\f¸^\87\93ÊÀÁN\1aBðêã$÷Ó\90þ°+¸
+O¥F\ eí  \98 T§Ñä"ÀûyUï\ 2Ö\12ù\ 4\ft:©Ít:8f*\85|\8fµL<§\89ÜÇÞ¨\1fÁZlñ\1c\85\ 1\84UF\8c$\ 5ð;éó\rXk­\85\1cW
+ËwXß¡=ñN\91M\8dÑ\83\bAøíðIZµ\8cÅ@Ö\96»rÅÝP\83\9dõQ­ªCÑØ,7M±\97\ fî\8a\92M\ 4>LH]a\90%Ï4(\98\97Lâã\81Ó        CnG\ 2X,Ò8\95°\¶(A&\1c´ew|àá=8:éÁÁmø­¨CÁªÌ¤|#ÒÉ%Ä\8d\v^Àó¾ñaf>»Ç\85Y@:\91\ eܯY@A\87wËÁÝ« í?³ºU±N{»\9fµ¢5è\8eÁS\e\8c\88%Õ¾J¡\95)5À\82\r7&J¾ñ0%7\1e¦Ø\16\ 2\17\1f
+ñ{té\8eçªý¾\ã\99;©Ä\85¯\89@\85T\a>´p¼\9fÆIiúx\7fV[x\178ÆU\89ø>:¶äa´Oø\10\rP\87Ýï\ 1¡dËöØ\97\85ÌÎ÷¸Æ¾æB\1fi[WÝq]^³\93b\9fP~uàH`ÌðkÆ®¬·\14±F¥\0\90b6 Í§V7>¶^~\15
+\f¤uô±\ 1\85®¨A{\9e7\9aØä½ÑCÑå\82Z\9d\88å{±8*\86Ê\11Ö7\98:ÊGý\ fMð6Ó±tAßnj\16\14Þ§Ã\91\80`µü\9a üMÓ\92ê\89\1cÒ)\12Q»¤ÿñ\88S9\A]ás(Í\91î\94%¤ $Õa½û\7føüØv$ãZ>(Úp\16"\ fN±÷Î\1c^¶ü\1e\8eæË\0\13uYAF\84(Ê°\12~':¹¥¡%\90 +ÀÇ~Ô¢PQX\v\88·94{î0$C?\0Æ-%ø\ 5fE5WÇJ\85ÞQ2\93\ 6¨D\9aMIÔ\14-Û_I\9få\9a;\14\9cJ+\15|\ 1£×÷ü\94\88.Ëí\9a˾*YÃïà\ euÛ5ÇK~\9aB²ÓÇï7U\rõþ#f\1aXqAÔ;r\ 2a\13i\b[H\ e\1e\ 1®ìÇ¥\ f}è£ý\81\7f¹Àõ/}Þ·êÐ¥qî¯$Mª\r\8f\8b\87\87]µ*\82k2K'*\80{\92R^\97XòcÎß\9eB¥u¡\11\8eK\98ÿÊ\87\b\ 33YfªbçúÊøó\\12\ 3\14I¯&pLG\8e\89\a\f\80&¬ÈÏÃn|EòÓ[\e\18Úíx\95\9d\7f\10$¸Â\12Ë\ e\rµÎó\19¸Í\12i\ 3ú\1cBCos\82æ\fÌI)\ 3R½~uËT\97ºV\93­ÖåD××ؾtÜxÈÈ¿û\bÛ´³Mq:\8e\9aBMQ·x·¦\1d*2=#\15þ\E0=n6=0Æ\1e\9aég¨cÅ~ǽ´>%\19\7f<êSòľÏvgXícDp]\f     ,\9c0`Ì@\14ºxÆö\8dÿ>¶4e{Üuñä¿\1cÂóæöÅ?m\82\88ä
+endstream
+endobj
+858 0 obj <<
+/Type /Page
+/Contents 859 0 R
+/Resources 857 0 R
+/MediaBox [0 0 612 792]
+/Parent 841 0 R
+>> endobj
+860 0 obj <<
+/D [858 0 R /FitH 686.127]
+>> endobj
+861 0 obj <<
+/D [858 0 R /FitH 253.546]
+>> endobj
+862 0 obj <<
+/D [858 0 R /FitH 182.141]
+>> endobj
+857 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F11 573 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+865 0 obj <<
+/Length 314       
+/Filter /FlateDecode
+>>
+stream
+xÚe\90]O\830\14\86ïù\15\8dWmb;úA[nÝ`Ó,\99Ù\88\v\84\82d\f\bàÿ·µ,j¼éùzÏy\9f4\ 45\bÁ6xÈ\82Uª8\88I,\99\ 4Y\ 5h(\89\961\90Z\12Ê\14ÈJð
+9a\ 4a¥4Ü=nwx\9f¼${\849çp\93¬\ f\9bÄçÏGÄ\14\93\13¢ð\84Þ²§Uª\7f\9d\1a¢Dl\8d¿\8fÒØI\82pAY¥vô#Æ75fÊ6¹ßÙ÷Ö\8aÁ~@\98E\1a¦M;\9b±éêÿf:$Z°\9bW\864\87v\971\ 1\8bþ:´f6®\8aàü±$£\85¶)µón\9aÇÏb6¥_¨Æüjîm.$Ì;¯>S.\9a\ e·î¦¶<w^Z\9a÷¥U û\\164\80\17\1cL)\89£ÈC\9dC*\1c¿ÿ½frQÀ|\18ÚÆY»æÜ/ÑQº©)k3ù^_ù\98·­\9f\15ÎYY\86Ò×\1eE9\14\ 5/\13ùóÝ·\98\17ã\r\80-
+endstream
+endobj
+864 0 obj <<
+/Type /Page
+/Contents 865 0 R
+/Resources 863 0 R
+/MediaBox [0 0 612 792]
+/Parent 841 0 R
+>> endobj
+866 0 obj <<
+/D [864 0 R /FitH 686.127]
+>> endobj
+867 0 obj <<
+/D [864 0 R /FitH 668.127]
+>> endobj
+863 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+870 0 obj <<
+/Length 132       
+/Filter /FlateDecode
+>>
+stream
+xÚ]\8e;\ eÂ0\10\ 5{\9fbK»ÈÆ^î]\86Ä        ¡ \b­B\81èP¸ÿ\r\b\9f\ 2Q=i4\1a=\ f\ fð0\98\9d\9aºO\90131è\ 2\81=2\vpb\f$ w¸Zòî¦\87º\97økn3n\84ÖÌÛi÷ÍIËÙU1F\eÑU"Év¥\9dºñ8|èäHì¼:!\90\9dÇryU\8dÿ^ùߢ栯m#Å
+endstream
+endobj
+869 0 obj <<
+/Type /Page
+/Contents 870 0 R
+/Resources 868 0 R
+/MediaBox [0 0 612 792]
+/Parent 841 0 R
+>> endobj
+871 0 obj <<
+/D [869 0 R /FitH 686.127]
+>> endobj
+868 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+874 0 obj <<
+/Length 2085      
+/Filter /FlateDecode
+>>
+stream
+xÚ\8dXK\8fã¸\11¾Ï¯0r\92\81±"\8a¤\1e¹m\1a³A\ 2Ìi:A6;{ %Ú&F\96\1c\9eίO½(ÛÓÚ \17\93,\16\8b¥z~t¶9n²Í_>d2þùùÃ\1f\7f6Õ&ÏÒ¢Èíæù°QY\91VE½±\95\fHíæ×äéä.³\1f·;]ÚÄl\7f\e\1f3iY\95
+\8fe\9b\9dU©±\86\ fü#´~`ö\9f·µI\86ñìæ\89\ fV\9b\8b¼\88Çtj\8cÜó|
+\13\9c2&\81A%¾\99ÃÐ3á\18^¶y\95xÚ·\89cêeôM\98<ÓZ?5c¸ÜÎ\f\a\1eç\93\88Z@;\88JD\9fOnfòóÉ\ f£cjÔ¥q;Ô\1c\95U*­­({qû\ eä\1a«é"cód\9a\871ôÇt»«²\1ceñv\14\8a,û0OóèÝ\99·ð\ e\1c\e·\88ËE\9cNN®o»ÐoUrd\82è\8fST\18y]\8ffy{P°`\ 5Ý\b\97\8dn|\ 3Î"KF?\rÝ\95­\83ëë\ 5%ÔÉ<ðZe¦²EÆNRæÎKÊ\96i])\90Or¿fYþÞ\95*\83x1\91G\84¡%r\93|¹6¨å\89/\8a_\ 1ÓW$\ f×®\8d*þû\1a\v×±Ùwª¨ Îì£õÏÃ\84
+\9c7z/S?º=Ùc¦@\ 1\12Å\0\8cè\1aw\14>ør\8c¥\91W\87Ñ\9de\ 3¢\82'×¾\19Î\10]Óä[¦´nv\1fq
+n\1e\98\84,]`\ fÌk!Òúf «Z?\92>:ùüÓ¶ÒÉ/¼\18ýáJÑ«\r¹\ 1iwg\98\10Π·\9c~Å´\b[üh>5\85ÿĽ=\7fÔ\e\99´oE*ðb\18ò©\91\89\14\vsðSJz+\93ÖÆ\80ò:µõ\92\8c¨@i@˳\v}Ëù/YUbVQ\82ÀlZ\12\15É®û&tÇ*\r×Y¶P5py\99\frP\1cÑ\84¯\992\8d\9c"j\99\90ÖÍ<ýx«hÅQÄ\ 1\12µ¿3=ç÷\9f¶»¢Ô|È\98\12<Ö¡\87q:]\CÔ
+r¨e\9aðUÉ%|÷\1dÓX\10\ 42\94:Ii ¢¾#F .¸ð\88ý'\96p\1aøcï®]       \10Jÿ
+\1cã1Ö<G\12F\1c\12Y-\98 ¬\92\82Ò\15ÇÑõ\13*'K*a8\8bßø£X'©\ fôÀ\14\91äxhýK\0\8b¬\14\12t¾x
+f\12î;\ 3%\ eCU%\1d\84\16]\99éŬ8½e=°º\89©O\7fý$%FÝW\8f¢LU­cùø'\9a\e³$Ïuò¯÷Å&¯Rk«[A²\19\1cV0*pTacíE% \9dÈ\8e Â;?e\1c\1a\1cDµMK«\1eýó²µ\ 5ÔÑ0\'É7þ$\7föB8È·Ó¦ÃzÐ\1f9\1f9Ra"\ eA\ e\96×]ãéÐ\vo8\v³ãÌÕÜ\ 1/ Ý5Ô\vÓ¥íB¸kSäÒ?\8dJ\vS²º&UÀ«r\9b\9dÐ\80¿°Gpú\ 4\ 1\0\ 5\7fÀ\8fPÊ0&Öû24÷ªÔK)Àª\9c\93\84\87Î\8dG¡ô\18¥×3\1ah¿\14XÜÀÜűÅ4× *\86\10\12Å:8\9dføz7¶\13/¯T{q\86fb\ 1Ç\0õ\85\17T\0ÀÝFÕÉ\97Ðÿ\10º·"Æý<+¸\9fg¤¹ÎlÒ\rÓôÆ\94¥â6Xá\15$ÈÌ\e\90\18¸\b¡\84yòÝ\81\8f\ 6ÚÐwo\ fr\ fþUv\ e<B \9ce60Ë\140P\ erîÒ9êY«(cï(â¾á\87\9a<ù{ß\85o\ 4\84àl.\15\18TÐüz7Ëòìç\93|\14\13H\19\18%\a8Jé\÷\83¤\8bÃ~8sǺ;)\fÿ£\9a\9d£\19»\8f\98\ul\11\0\0á\1a.\88\ 3Û
+&­oCã¨ôé\1a\1a\8cÐ{aæ®\f\93\98I4¥ bP8NÜ~ji£0J\ 4òâu\fó\fQ·¢3ç[\819M^x ä΢N\ 6@\92gh¯²O©
+£ã\ 1b\ 5Ór V\ 5½\11ücm\96|\ 6ý\14]\v\12 Ú­ÿ\1e\b×á\99\a\9dñ4òR\9e³úÀr\0àÁ9IËéDàhµ&O³w¨\eܺ\8f\r\13\17\8fM\95Ô75«\ f»®çµïoÐ\ 4\83Þ\82\958Ëq×µm@50×ð\14"\9d«t\10¨HwÔ\ e>p~\ fAïú\9b6\1a"\83%ëÄ»\89-\fÁ<\ f\1d\06p:\ 6\ 5q\98[Å4ÒODÊ+;[\98 \15\ 1wð÷iö;Ȥw\ 2Û\ 2V\8e7\ f.\88¸Ø\11Ws-¶H\r\ 5\94£Þ.ªÀô®<á2\b'#8\988\88Z\8a¦ÜÆd±\82pÇ.ÒÅè\9cñÛÊ$\92Ø\9f\19ÏÞݼ\88¸Ý»¦3?]\108\ eÜSúA\bþ»kf²5,\0Ã4h\98\13/\87\rãcêVüæ\92\9eåú\aT\19;\19ÕxI:¶½Ö\vt\15¡\86ì\1d/\16\87\ 3èý}¨ù\13\16!Se·\97RYßpL¶\ 4\ 1α\ 1­à\87¼Nm¾<?~\11\16½)ÒºÔ\15²À\e¦®6:-\94Ü\9a­ÈÉÓ\12\94ÚÝq=  Wö Jå\88\14R\13¿`¿"ˤY¦6wLÿ\9f¨ñ};®\ 1\eÝ\vZ3\rXì5à³\0©ä      \9ct×s4'yßaþö\80m\19óTyZÔf¥"\1aU,p½Â*\87\ 4Æ>ã@"\95]D\82¼       qW­\92OnÁ|Ë\ 1b\90\13\1c@3¼'&¦T»=6[än\ 3´&\8f\1d\f7\0\b\95p\17ß/½(vZ\85©\0\88\8ft¸\u­6àÔ:F\b¼\f\0sòPÀðþ=«Ó¼Z\0in-ö4\r\14b"¡.\ f\10\9b\87~\a0л\91Y\8eîÌ\16+ñÿ\8a]3\8c£\14.Üåú\7fäºJ\v2%ý\15Á^2\10¹Y¾\8ek\8c\85ÎD\98\1c¬\8a\87T\84úðº\87¶F/7d\94þ\13­\ f»®ç\9dè\ 5[ÝìÎKyWØê=z¦]Ï\82~\17\13P|b\8dÓ:þ½\93eÉyi\7f4ÁZ\91×µüë\83e]ø¸¢àäÀ#\17Å,[êrvK\ 1\9cs\ f'\94\1d:þG\ 5É\a\bZaèyd\93]A\833]J}hí\ 3º0áëÏ\1a\80Ï×1bW®h\1f\19V\v\ 4\84pzH\19$D5\8bò¦&Ì    Eã¤õè°Þ·"\8aS\98XDâ)\8c\84@
+ù×\ 2Pk Ç;w\10ar«ÿ?ÀÃ\8dPÕôð"¹á(½¼×è\8f\ 6y\94|UÚ\ûo=\ 3¶þ\ f\97ÿ\fá©VÀË\0\8aFnÓ\1c
+\1cç\87z`úôüá¿\83Ñc\14
+endstream
+endobj
+873 0 obj <<
+/Type /Page
+/Contents 874 0 R
+/Resources 872 0 R
+/MediaBox [0 0 612 792]
+/Parent 876 0 R
+>> endobj
+875 0 obj <<
+/D [873 0 R /FitH 686.127]
+>> endobj
+94 0 obj <<
+/D [873 0 R /FitH 668.127]
+>> endobj
+98 0 obj <<
+/D [873 0 R /FitH 343.658]
+>> endobj
+872 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F14 574 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+879 0 obj <<
+/Length 2660      
+/Filter /FlateDecode
+>>
+stream
+xÚíZYsÜÆ\11~ç¯ØG°â\1d\81Uy°\14JqR\89\14\89å\8a\ 1Ú\ 5ITö ÷\90¬\7f\9f¯§\81%°;{Y´\9d\85\ 4\ 6\8d\9eéî¯Ol>¸\1dä\83\97\17Ï®/\9e¼\b\83B\14N¹ÁõÍ@º\8ç\a.8!\95\1f\\8f\aï3¥.?\ÿåÉ\v¯»\94!\b­\14ØD\9aç\7fþîõõÕ\9bË¡Ö:3ârè}È~øþOW¯xéÅ¥òÙ«7\7fûî2\98ìú-1¼È\9bS<yaÂ@\1a¡\8dSÄzØò\1e*\8fý4ï`\84º\1cJ©lö|>\99/ÀÖÛìí}9ªøòù|v©eö\89þT\8be=\9f\81ÉÊÙ\98)^Ó£rQN«\15\bX¦®ð96\94"(É\e\81³Ñ*»\7fx\a÷2û|W\8fH\9c\1dWËÑ¢þx9T!kÞXñ«2\eáÈ\19\ e\86G\9fèÏæ`DE¯ø¬Z\11¯Ïñi5ã'U9¢û;¾\e±¼ÄoÉòÒj¹¨H\ 4\94¢°\96O=©\97«\8a\ 4\86¢\9a3MæÄì3\8cb\8c\96\15?'\16¸p|^Zé\8aJ÷³ª\1a·ÜVs&\9e\96÷¼\10ÏÕ\10Þ,æÓ\86ì®aZÍFó(!q\88Ê\96²¯íî¹ß5$zàDáu \12X¿\b\ 3-\9cl\88ò\ 4\1f%|a\aÃ\ eÕó\86*ï±\92°ëP
+S\18¦ú\98àeD\9e«A\87h\1f«\1e§Å.\94¼P\84é\ eMu¿\80Þ#\12
+  Û°Rã\7fÒ\9a\82o\8c«Oõ¨\1aÖ³quÏæÃ\15¿Æ\94\r\1aè²A\ 3½öüû«\94nL!\®['ý'Ü2@ÓC¥tö¯ÝSÃÝtØPÿ\98Û\\16Zâ¿\14\11jC-µ@Tè\19®ÅÓ\96£èè\19?æÒÌ\9a§åÇåjQ\8eV|7-!2þÔ£rÂÔ£\8d\9føÆOxýf=\e­\1a\8bì}Ñ9ô~7¨gqëzUM¾\0÷¹É ÿQ½¬à\ 5Î\86ƹ±\\8eFk\9c*\12Y\8e\15\ fÔñ\f´þ¹^Ýñ\83ÎötË\9e\9eÛÎé»^\9eÛ}\al\8c»¸\99/¦äa
+A²&Ph\9c\89o\17\15©\86\16\96_àÔÓ\86hÉkcRô´\9eñË\ 6x\ 6¿/LÃhÂâOërR¯:Oæ7ü`¾^ݯW¼\86\0V/Z6Q\ 3-\8fî¹\1d\9f»d)-\ 4«'åÇ        md5ô\15\81\9c\8dªå²\9eÝÒ¢\892úlþ\10ß\16\14\83dÈ®~\8e\17ÇÕ\88ß\1cW\v~+\1eíRF¼ã6ÊkÍ\ 6Lc~o#®%#0\91\86G°ZG5\11\8fØÑ\12Ú\9fÏ\b\16ºÑ¹Ö\8d!ia¾¨oë\194¿ëNH\8a\ en\9d\9f\12±ÜI\11Ë\9d\11f¾*`Éã\11Ëë\1e§\18\ÄV¢îm>\94J\v\ 3\19 7¤Íð[\ar{\8a^ì)\1a¶=µ\98¢ks¡´ìrBÄÞÝOÒ\86ú4d\9c¥\82×\89s;¡\vw\92
+z\aßÇÊ\1fÕ\81\81\95{¬¾Ý\82E\17HC\8bâÍ\91\89¬@öh\93DôPc\12q\92×Wå¿ãRC\16\86\1fk
+\0\ 6\11¢F}\85\ f8ôLÖLØÄLÓø/],ÊÙmÅÏÞ'ul\8c\90\88\ 3y+ÊP:Ïÿ\1c\v¶U\12\ 5Ó\92+k?ð>\1c\vê¡%§Ge½0ºè\aLJs\88,¡à\ 2*\84&®Ó
+\84q­0t\1f\83\11(8\18\11\86.\93Â@\10\11\8a3\85ÙàT~`Ö7±\9c\ e±4 {®\98qÿ¾ÙÒtX8àÀª\87"!oÎå;°
+¢0\ 6`/TS¼Ë\b\98«ë\8b\9f.$^Í\ar`\94\15\12ÑÔ\14\b"Z\ f\8b÷\1fòÁ\18\ f\11®\81Ë0ø\1cI§ÄÈÓk\93ÁÛ\8b\7fpÓÒÝmÃ)xaó¶iIhË!Jù\ 1mg\ fè«Ë\1a~m|qL\12ã \12ó\18\92´\9c\12\92\by]O\90\8e!\13\88W ô­Å\8e\84\81~²ég\88\80\ e°CC0ÙÝm¨s\841\bÑK¸GâØþ¼D±§\97\97¨\84Ð.{V\8dÊu,<s\9f-çÓæªçQ¸\9f\96M\9d@77ådÂW¨1\96õ¸y\87½-wÙ\1cE\83&\9e±ø \15ö\ 4ÐT?£LljÒÜw\8a\91èø2\17!\ f}\89\e§Ò\9df\8eî¸s,g³jÂ\vìó\9bzkÛÁsØÚ»_!³|]\97$\1f¥è@rUa§èø\ 6
+)Ú¦4P\1d¼\OVK¾y0(n\1a\83âêÁ ¬ÊeÕXÆ\0ü[X\8cAu¹)ÿ\12\ 2B[¹ü¯Ëæê\94lîRÙ|»ÐÓ]NM¡74Hj\7f\9fs5<\9a\94ÓûXÇ\93\92\96wóõdÌ×\9b9\aÝ\8cçÜÜ!\e®x\85KñøÒª¼\8d®$\12âh\ 3Ýà¨F\8aÜ\1f\9d\0 aKÝÓs7h\ e\95PÈPC'¬or.Ð\90È}ØÓJXÅ´#¥?¦\1cN
+\8f\ 5'¼9ßüéc¡Uo\9bÒD>-P-\ 5\9cÊùí\8c\1azT¸j\11ù\8aãÔ*\ 1\ 1¤B_ô«Úw»\19Kë\8¤\ 4\14ï S\872\16J\9a\10+ÛNÊê\1e\fÆ\17\16\9d\83Éáñ®é\ 1®6Ñr÷\84\9aý°ÿ.a¬\1czC\99A\83Àð0\8f\0\12h\1c\91J;Ò\a\86\ 6
+¯¾2×Áü®è\ 6¦\93 r^Hí\15\8aíî·\1f\ 5úL\14ôÏVÀ\99\8a@ÞDU\84'\85Á\ 5\1c-\r\15]äÂB\92CP       ±ê=\0\15x\8c²\ 3\1d¤\90\85ûEP9,\86ßkP\99\83\89±äm­72\9eÔ!<!cÐ\f:WÅ9xJ\ 6\7f-<-\92x"Eÿ>xÊ\11\1c]çh{ðäôÑÐS\b¯Âa<¡\99ÑÖ\9c\1fyì¹RìÂI\91µ2]4é\16MÀMA±\8b\86#@»Ö-\80\90<7SÒo)éÚC\8a\ fH"j+V\ e\9dÊ\9e^ÊÔÙÑÞI¶Sߥ·¸Â\r-\95\0\e¢§       ^AäA²\1eü\81êÜ\82\1a)µh\1aýo8ù\1f4C!TnRBí\93H?\9e\b\ 2\1d\9e\80!jC\98"\1a9´ež\8aÁ\9f?\18<+\81\1d.ÒÏêÀö\8cÀÌÉ#°7I\1d8£Î×ÁË$«\0\97:\9bÕ³\ 4\ 2Ik\97UO\ 5»¬\ e\8fÀ\1c\ 5¦Ô\ 4\f\9dkr\ 2\86õî\ 4L·_\84°\1eklº\98Àé×Ó\92o\9a9=^\8b\1f÷èϼá\1f»ÍÅ\9c)íCÇ\89×cA>áõÄ'©Ä¤¼\99\ 5\19\1esÅ+\1aÌÑ\7f\9egµ£s\Ìæ³á¤\9eUej
+!Q(\ 6\1d\8e\ 1D\9eßU\1d\ 6ÈY¬ö\ 1Ä'X\85­|ÛcÔ|\9a#­¬\97Õ¸¯°ñ¢fëóm9Z­y"¸ù.ý«GÉå\8b¾=øûà2NA\8aì\87K´»í¸Cº\87NMúN§\86\a±¡ã\85æqÍ\86\9fó\1dÛ\10\84íÄ\11kéñ)ÕCòk\ 6\8eà\Þ¬èk\ fí×4\8cX\8c\r£H\96bH\83>*\98\9a\11{,ÂP»hö\9aÊ
+K¬:DÉZ\fª\97'\8c]\8eí\95Srè\10ý\81>¾ªLÅ\8f«\89ÂM9h×ìNW{\87ë5\83\7fM\95\r\82~JqÂdMökÄd%\8c"ËÛcÓãs<i\90\88ûßĹd2û
+pe\90ª\83\8b?ÊðA\1fóõÝ!Á\1e«ëDZz\7f¯\9e\11;f×'\97ßqÌ\vËYèò¡\ 5Ø\87\13\84\84\1c\1dêq\9cèc8I~L\v\87FO\apb~Ánýþ@\15Ü¿«\9c$t\aû\ 3CC\93½íAËI\16À\8fQ\9dñý\96.ÑR=|By\ 4\97³§ôùö±-\97ʹV¸ÜÇ\19JqÎ7À3O~\14Ò\12-7 ­\8bã\98ö\8f\bé3>*<\ 2¤Íþ\967 ¬\84â\11 Ýrú?¤Ï\85t
+\ 4°\86\ 2\e\12\92Ý\9f\90Ðôã\84*\17.¨c\ 5ãï\9b\8fÂÁtô\9bW!\87³\8b<1»\9cZ\85ìßM\1a\r»Fw\89Á\8d²"ØôÜ&\81K'\8còç\15e'õíO¹ÄNq\94J\84âì2ïÈoz(
+\ 3R<ÑP§tóÿ\vÍZ¯\9bG·F#¾\ eÕI\13\8daÈ^>K\r\a<0ÕýÕä«æÇuô-\92û5nînË)5åñ3ð|±¨âÏ\1a xýaÂö\7f$\93ÿ\0ïà¦@
+endstream
+endobj
+878 0 obj <<
+/Type /Page
+/Contents 879 0 R
+/Resources 877 0 R
+/MediaBox [0 0 612 792]
+/Parent 876 0 R
+>> endobj
+880 0 obj <<
+/D [878 0 R /FitH 686.127]
+>> endobj
+102 0 obj <<
+/D [878 0 R /FitH 668.127]
+>> endobj
+881 0 obj <<
+/D [878 0 R /FitH 428.946]
+>> endobj
+883 0 obj <<
+/D [878 0 R /FitH 402.974]
+>> endobj
+884 0 obj <<
+/D [878 0 R /FitH 375.945]
+>> endobj
+885 0 obj <<
+/D [878 0 R /FitH 235.303]
+>> endobj
+886 0 obj <<
+/D [878 0 R /FitH 213.52]
+>> endobj
+887 0 obj <<
+/D [878 0 R /FitH 192.838]
+>> endobj
+877 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F48 455 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R /F49 457 0 R /F14 574 0 R /F7 674 0 R /F9 882 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+890 0 obj <<
+/Length 2196      
+/Filter /FlateDecode
+>>
+stream
+xÚÍYY\93Û¸\11~÷¯Ð#§ÖÂâ"\bz\93\a\8f3\9erjcoÙS©\1c\9b\aZÂÌ0+\89\13\1evv\7fýv£\ 1\8a\940\87\N9/#°Ùh4úü\9aÃ\177\v¾¸|v~õìû×\85Z\94¬4Ò,®®\17\82\efM¹0Ö0!\8bÅÕzñÏL3ÉÎ\96Ea³Wï~|÷þl©\94Ê>ütfUöòL\ 2õ\82H¯Þ½ýëÅû\ foÞ½ý@\84\97oÿ\84\v\9d\ 1¯Î^¾\7fù\97\8b+`8û×Õ\9f¿\7fm'Ç\ 23+t   Jù\ 3¥B\96g<¨¹X*n\99Õr±\94\ 5ìQÄuu[wg@Ñ٪١\1e\9fð\8f\1a\1e\81®²¾úåL\16\99ëÂã­#þ]³[nê\9d«ZRE\88©    r˸´Q\97÷\81E-\f+\ve\91¥`\ 6\94\bCL<!G²¢ÌAõ=×eR\94UêtQç      Q vn\12¢¦\86ÎY.ÅL\927Z³é«\9b`\9c\8d#;n\82q«Ý\99ÈÖ´ÞVw\81Úß\ 2\15v\88l\8b§,\96¢\94Ì\14ð+X\99ç$»oÀý\fÁÖ°V°¾¹Eù}x\85§\15t\1a>ßµ°\a\87\95[\13é#²ÿJ»½\v\91X­ú¡Ú\10±\19ú»!È[»OõÊA¸j\b»·Mïâ¾*0ô\185¨1\9fë\9a\8a!-L\861¦E\9e5»Í¯D!Y\9ev\1d).\10\82&H$M\9e£&\ 6\8c¸&\8eºï\82ÜÙqn<Ì»¬àSï[ÉTYÄ\80Ü5ý±_\85e\ 2B2°x\r½W\14ç,WåüªCçM+ÔÞ´"\9a\16\16õ\8e¬   Ë\895\8bìÜ­ª¡\vLU`¨·´øT»Ïõî\86\1e\1cÝ­n\9bÝ\96ÖA\1e\1aÓïîºa\vJ$üPïÈPÛ¦ó\86\84Ps\10$uôH\9eu=X³j×\9d·m\1e­¯³\ 6#)X´Úl\88xSm·\18¦\15=~ôÑåzäúìY]\10;:1Ü\1f¹Ñm   \1dÇ\80SÑD\1dÕ9\7f\ e\1d\ 4\v>Tm3 ûq-R\ 5G\97Ì(\1d\9d÷âØ»\90ÿfô¿ I>·àÈ\94D\993m\9e*O>\ fj\92\8eÚ\a\18Qè§ëÛzÕß\7f\9a- ÄÔ#Ç\8dõ\943\8aLYpVJ\8cÌ\1c^\aþÆ\9eÒ´tîªÚÔ\1fÛª÷\8eGÂç\1aª\ ei\16³\1fTJ8#Ü\88"\1aX¶¡¦Ä\92µIy\ 1Z\8bÂL\91\82qH%¯Ï\8fÇ\97)Y®GÛý\11\8b¡Í~æ9O:\16òVDÞ\8bdõ/¡Óh&\84~ ds\ ejM\98¾\83\84\80\93£KøD®\94P\ e¦r\7fæ"OT\r\fêBÎ\84ã]4+¢`°Gi\99\ 2~2\8c ®î¶\196\18/FÆ\94¢\87\ 1lÜ¡\8dÝ\1a½`Êè5#¼ÂÄE\9e\81ÅuëÂê®j«­ë]K\8f\ e\ 3[@Ш1´Ó·*\99\12£\87n]T\13\98õ\7f]xðÙ3UäÓY\ eUz3¸piÉ\99ÌÕ<í»;ºéªFY^Tn}ÁÂ_ßXüjMá¶\1a\83\ 2\9a\8b\12\0\8b#\86T¯Aúõ°[õãÓ]ë:\14P@\ 5\fgݺ6\88\88gAwN\15ѵ\83äùÍ\85ªC-6\1e4Ë$ò    \ 6q\88eÊÏ£H\16\fJ#ô\13\80\87ÜÌ\90Ñ, 8ÓÜî³#!   ú\910\8f\83+\8cH5GD³\0grß\11ï      ni ^-\ 5·\9a\ 6·\9ddÍT7(E\ 5\13\1c½®Y©õ\fµ\1d\Ó<ý\92÷Á>ýU.\993\v¨ïø\92åC\97\98_ò<yI+õÓ¯y\1f$-¾Ê5Áâ¹H\Sði¥RLÁ\8d\96\12|\9c\87\13&Y¬-Ý\8bÄ5rô|D\ 1èQb\84Wl6\9d\1cÚ\17Ú!\87î\v8\aÚb\fó¥Í.\83\81\99\144ðE>¶\b¨JÉ.¹|Ú8\92?i\86È\9f2\8e\9c$ê~ß\1f\8b\9aÝßÀk=\13\85n}\13\10¨\8d\1d\1d×\ 4å*"¯\9a¶u¾V¢û_\1c8dê¹e\ e½ÐÊ9ΠÑQi>)Å\93
+       t?:Z?:âã8Áøõ~\82Ñb6/ákÂQ° aÉ\v»uÛ°jh\13õ\1d ÌGÑÃ:>\eδÚ\1fF(Æ·Z­pj\82õlpBf\ f¥U8\f\17\116ÑKB¹°\1cQ>x.\98\86\e\94\99ú\92V<KÏO[hM\1eñÚ\9cvna\v)\8bí¯,³7}xÛÑ/áLX´î?CÝúf\ 5\1eÿÁâãPoÖ5N\9f7D¨ègíVáª.pÆ\1dãVðêr¦ätØumO\93
+Ü1=\ e¨h4\\102hëfè\88@w\v\ f\ 15Oø÷Ø\94O°©\08{W}¬7u_»°\17ÆÇ\84!\ 3ê\ 6<Ô׫aã£\ e\b^?Õ°Zy\88ÅÆý\93Ø~       ^Òû\99\e×\9dßx³\9fÅ\90èÝ\8c¿\ 41üÜ]\8cá£\ 1\87ï\88\81Â\aE6d&ÿÖù\89V\13\94Â_pà°rôr×Ô\9d\eÅû_\98Ø~I^·uU\17æ·ë0ðÅ\81®ÞBàCô\18[\10xB" ¢þ\1eþ\ eF\86¸5ȬÖÿ\1e:\8f\9f<C\13\11¾\acÆÁïÎ[ÀO\91\14\vÉ\9cìÜÄ\90JÓW\0ü\r\ 1øµTOè\91&}ì>Þi+\1f:ZGþ|R\òcé\ 1ªMùïÚ& Ñ\96Þt\9bHx\9e4q\9c>»03\86¯!@©û8ãÕ\9b0O\85²\ 5D>\9f4ùlNT4\88êð\1a\1eSÀÑ\ 2D0Pà5\87áÊ\9e\ eú\ e¾]\199\83\0\11\94\1cc\12l\9aº\88\1dEÉäÀÇ4"|\9cÁÆÞ#\14\84\ 2öë"ûáX\ 3\1cY÷£El\8dzÊÁ
+m÷PBê'@`p\9cÉþ\80±W \ 6æøÜ¥-¡\87\ 1ü\ 1\9d¹\9e4JA\93àwÉQ\89ñýT\ er\8bc¹h¤      K\12/*f\8bü\10\ 3×\89Ŭ\83\v\9d4MníA«ç)xQúO¼\13Å\7f\80¼\ 1Ö\89qf\82\ 1í)mN4ú±\18\94Çbì½R\bv\1aÀ0E\ 1ÑYÊ92\15÷!p     nôc7~ͶùéS·É\8aËTF\b@àö±\8c(OrÎ%\r¢\8ff\84*Ô·Ï\88ËdF\1c\80è¯\91\11òÔ\8c(N4z2#Ì\17å\83,u"\1fäýù \98À\89b\9a\ f§\8c\93ß&\1fÎ\ 1Öò,\9d\14Jɯ\9b\14p\98\92!)ì\ 3I\91\97Åÿ$)ô\13\92B\1f~
\ f\8d\83\ f$Eñ\7fÒ&ÎÓI1ù,rBZäÌêT\9bP\89\ f\18
\92üâï\17 \8d\f\13füÌð<!Ä0n'\11)TJ\86~TÄ\ 4û¤"T3ËóSd<\16\8d\ f\7f\8a\11\18Ý¢üÒo1þKë7\17©pÇÿC\8f\8aþ\rð¢Íþ\8eY¦²\7f¤D[¦Ì$ö %K%\8e?]\1cþ^\=û\1d¾U\8añ
+endstream
+endobj
+889 0 obj <<
+/Type /Page
+/Contents 890 0 R
+/Resources 888 0 R
+/MediaBox [0 0 612 792]
+/Parent 876 0 R
+>> endobj
+891 0 obj <<
+/D [889 0 R /FitH 686.127]
+>> endobj
+892 0 obj <<
+/D [889 0 R /FitH 576.526]
+>> endobj
+893 0 obj <<
+/D [889 0 R /FitH 494.769]
+>> endobj
+894 0 obj <<
+/D [889 0 R /FitH 479.825]
+>> endobj
+895 0 obj <<
+/D [889 0 R /FitH 464.881]
+>> endobj
+896 0 obj <<
+/D [889 0 R /FitH 252.946]
+>> endobj
+897 0 obj <<
+/D [889 0 R /FitH 224.961]
+>> endobj
+898 0 obj <<
+/D [889 0 R /FitH 196.976]
+>> endobj
+888 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F11 573 0 R /F13 705 0 R /F70 508 0 R /F10 668 0 R /F49 457 0 R /F1 667 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+906 0 obj <<
+/Length 3013      
+/Filter /FlateDecode
+>>
+stream
+xÚÍ\1a]sã¶ñÝ¿\82\8fôL\84#>     ¤\93\87ûî%½æj;\99|>ð$ÚbG\12\15\92\9düøîbA\8a\94p¶ì6\9d¾\88Àb±Xì\17\16\veÉM\92%oÏ^\\9d={c\13Ç\9c\11&¹ºN¸É\981yb¬a\äÉÕ"ù9\15êü׫¯\9f½Éå\18ÓZ&\85\02\1eçå_\9f\7f¸z}q>\93\8a\9dÏòܦ߿{õú[\ 2½9\17yúíÅûççV¥W\97Hð,\v\LY\98q#\99â:\99\89\1c\80\92è_-«ö|&\1cOçõæ\Øô\13þ\94M[A×Ã×Å6`\14ôY\94\9fªy9[\94\ 3îfQú\99\1d\r¯ªMY4Ô¾@îÞ¾ N»-æ%5»:|\97ç<õ0\91.¨É\81\ 3\9eVsl\95\ fìeÆ9sZ\13ËÕ&¶´tÙ°´´.}ùî5I\97ó±t3Ãrézéþ\0ò´é\8f@LÈô'Â\1fËLX¦d\8fìù\a\r\18\ e\92^\96´ä¶h\8a\81À¨_4a ó\18\81\11\ f\99#§Ë¦¦M͸Ô\8c\e7ÝÛºèªyÕ!æ\1d\82ZüVë\ 6åSm\8a®li ¾ÆoN\v! [6eI°mS­\8b¦*Û?\9a\ 5Ê7Oo`t\13ÚÅ\ 6\88-hÚÇÕ®ü£hiâ-*¬\­brG\1ci\Ø\19\r\rLçÈ´\1fA¦sdºç\18¡Èñ\84À-*\19M ê\10\92\838i^5hõh\1a í-¥\82\16Y
+èEk\1eÌ\19±á\eÙòF°®Ð.]\82­\80\18ü\9e½Þ\84¶ \ 1¿öîº\98w»Æë\15q\a\89A»í\8aÍ¢h\16-Í mm«y±ZÝ\11h\81[\ 6Ö\9aê£ßP\19\88Ð(Ø\f\b\82å\8f\80að|\8b\1etl\9a\86\19á\ emSÉ<Ø&GÏ\ 5ÿò­¦ümW\81)P\ f½\ f¿S\8fïÂà²lÃü\89ms´>¯\950» Ï®-¯wd/³À\13\10g]SlÚëºA#Á\90\82A\vÚMõ;¶Uêõ\ 5°¦Ü6dê\8bÝÜs
\8fäæ+Ò\1a\8b\88\vâin ¦é\8cÙLÐ\92o\8e¥Å3¦uÞKë«@è\0\81\9bDH\96q\15Âó`@9Ó2èÃô@Ãd\1e\18Â8Ï\12Ã\.­W\8ff\99v        wL\ 5r¿\13\96K\14s\96KDR°¦Mf\19s.\1c  Þ"Î^_\9dývÆa\95\89ä\10\84r\9eh-\98¶É|}öó¯Y²\80\83Ig\93[\8f¹N,°\89Ñj\95\\9eý\83Π  OH              )P\93\ eñÿ.ÆU¦\88)3bê\80\96â\10¼\14\bPY}ïþò    ©\9bÈþàXr óSög¬ºo\7fF1®ÅI\eäÇlEv(\15
+5·\ fí\90\83²\ 3ÒÇã\1dªÌÁ\91\9e\9f´C\9eó{v\88\944\98û\89;D¶ò\11[\a  \81\93L\82\8dÎ\1c\13½)s\b!\19DOÿ\95\ 2¾\94¡\8cx\98\ e®2\ 3u¸~\16\89O\8e\95\ 1-Þ;Ü/Y\96EDl\98\10\83SÞï\1f\a¦8^   ÙÑÉ\bé\94ÕN¶û\ 3c\85üAHð!ðo\93ç÷éRb(9Å\1d!FäúÑÞ8V  ¤)VÙ±3þ\99\1aÉ£®3Õ\b\87\÷OÐH,|hÎ4\88ý4\8dH0Ü\13\ 2ÈÃ*\89Æ\8f\89N\1cË\80\ 6hfï[O×\89yØK\8e\9dý`%\f\18#¤ÿH'\87\8b\1dèÄåL\98Ót"\98°î\94\90w\92N"B\18çLÂ_¾$@tÈ\15\90Ï#\87¼>\ e J2n1òX7ÈTg`B
+¾üxù\19D\ e\ 6GÊL(&3}\9ce8)¦\19Å$CápsÑ\ 4\bI_ìÔ\ 2\81£\18\94\889aD±Ü
+@Ë\98\11ÄnâÄ$XÖ#\88éÏ*\bN"ç¼\9föª\961ñDt\ 1±/\83£L°ÌÉi\92w\94å\rÖý&â&9ËѬx\9f\ 4î½$ÿ\9cKF4\r\97|ð5\ry\r?AË\ay£µ8UËü\11çâmÄ     ÁÌ\15\uu\963)ïuB\10\vÏï\r\8c@Ë@\1a¤3Ð_¿§{\ 3v>âë°\ e\ 1i\1cÇô!\17v"Ái\96\ 1¡\ 3\93\13Ë2Ëÿ×\87Úmd%âç´CÍ<\10\83Ê\13\18zl¢,H\vbÕ}\11Ôx§yXy*× òGd\1a·\91\bªÁ²\r®©{\15\9fê¡\1c¬,3jâ£!^ê{âe\ 6ê\9d       \88\9b<\1a0å½\ 1Ó\b9\ e\98?ÐTP÷AÙåÇ0 \94\98\ eü\14¹)J&àr\v¬ÙÞ0e\8c¥û\83\94x H\99à5%£y"@\9câ    2±\92\0ò\11¡:v\88(\1f    FH\17T\ 4pþ@\9fÔ\0\9e\0\12\1cy#¤·ý\1a|ª§\93\18]!ËÄx\85\17q\8d+ù$\8ds%ÀrÅDçÁèMoô0\8871\ 5®\ 1'\9fê·ô\ 1k\1eC\ 5æË\bïÚ0u\14Ø&"\80\98åÔ\83é\0jr"\83¿\9cÏ \81\8fRÄ£B\88Ç+îq$?§)þt\92·\11\92 ?å"$ï"$\1déñ\89¢<\8dâç$i\9eLñ$\93\7f\14ÅÈ\89~$ÆP¨\83+)\87äPaøÅ\13\1d¬Ü\0Y´òáô\80qX\9d\v\9d>ÿtnDZT«âãÊ\17zuú²^Õ\r5/±ÀÙ\1e¯\r.\bY}¦\ÿ\9cAÕK!B%^ÈP7\ 6È<\90\83fKäüø|×4á\19\ 1ë·8¼(\7fɸÚø2$t¯i\9aÄb'A>\86
+=¶aͺ)\báSµ(k¬Ãª,}]̱²¼$¬zSF\vÒXUWÂ\97S\95ÈÒvYc%\16!\epý/\90\94Ho+¬ä"ðvYQÙ\9dºUGÓª@¥)¯ËÆ\17z\11\8a¥Z\8fµ¡o·$¼,]P©u¾[\87\9dû\85dZlÂÔ\82f¬ë&Êö¢ì@S~\9d\f_v¨N;¯PlóPéÅ\11¬Ýã×ëÀ£îkçؽnê5µhc^\Ø­º\801.Bcß«\15\e\8b²©¨t½`\13\16ásY¯}\1dÛ\8c×\84,Âï\1dÁ\9bº#À\9eýë;\1a*V+\1a\ 1È´\16®ÓMIï\ em[4wøöæ\8bï\ e\8ekh{s\81IC-ݤ»MKo\e°JôU\v%çíMÙÑb \16©{ÅI\95\1f+\8ef´eC²h©_\84\8fóÈ¢«P\84Wô~\84#·Ë¢'²¬w«\ 5ACå\9d\ 6Àì\171\9eo\97e¨è\97\9bðNµ¨67\ 4òB\90
+VÞ\ f\9dóô\86 \83ÓÈÁi\86\98áW\10½w[¦Õ\10+\18\ fÑâ¢\9c3¤ªS\95gï©\85\aë\1eþîê»Ù\ 56Múâ\8a\ 1ÖÌÐÀå]Û\95kj¿\7fö÷«Ë\97~o
+rMÈ|gpÚ;Õ__¼ßaü!ºØ
+t±     tMÆg£ôurÑ\19(Zf¸\1d¿·*çúh¤\1c\b\1eMi\vÂ)Ȩ\bÚ#zéûV\1fu|»©\8bżh;BîÊUù©¢W[\1c&G\86Æ+\9cóý«@ËG\ 2@_£«í\86HâÈ\1c\10\ 3-&¢êçkp7X\ e\r\12Äÿu±-6¾mÒo F\14\ 1î\97\1d\ 5]\95~·!\8b\ 3\98·8ø¾¿ó©Ífíßj\ 1ççðl\8d·\9fæ&¡ÆÅÛ3X\17¤íìäU\e\80¿ú\b;¼öa\fïC»<\16fd7ë¢\8fß\ 6\9d½­©µ7zè\90رEá\1f\1a½å`ûý³\ fèêÏÿF]´½\17Mñ¯j\85Æ\80ÒÈUo>¸Æ&|·Û¦Þ6UÑ\85U"¯î\91XÖî¶ÛUåÍÀ\9a½\19Ø\10 \10¸÷À²!\88\8fþ\802¯×ýsyë×ÅA¿'\8f\ 5\92êi,0~˲\19B\v\ 2o\8aõº æ§s\8dâÚáK£ËDzYF¥{Yλ°\91\ 5¥RÃ+5ü\97\ 1²ê\ 3ÅúÈ@Ò\96\92d\86ß\89Ì\0\108Bä\81#êú·I\9cÒ¶»uÀ¾î\ 3ÑXcøð¸A#Ùutx@¢â0\ 3ç\90Lôï=ï6t(\92\8c¡ñÝe8\8fÛn·¨j\ 2®k\88ªµ?\9eð\0m\ 2n±øç\ e¬e\11HÔ4± î+£©\ 1§^\17&\90\8eöOß\b\8adpÂBPÜ?þ\9e\96ùÿ÷\13àÛØ%\9feÓÄÿ+ºâH©ý\9dsb(Y4;uvø÷Ë\97\91wo\96\9báÎ#¹\8c]rI\97Y¿¥ãÂ-Ü\9bl?þ9&ø\ 3L\f\ 4¤pèóøß\9cL\92Ñp7DH\8cS\83¹@b52\17À"sÁ|ko.\0îê}\16Æ1\86û\1e\18\vXl\17\80\r\83NfÙ7AÈ\8aÙü0­\88Z\90\ 4\7fh?\8e \9e\a\92&\eU\12×\80\96\9fª%8í\9fj*ùC¦r²½ÂE\9fLÅ«Ëà\;\8d9!\7fÉ\1dæ5Ô\b)\9fÿß\ ft}Ú\8a\8d\8a\90"L¨nª®XQç 3C\90ÿçP\1eþP\83\8dpzz¢ÕÍ\ 6\ eD<`áh\87l\96\129\1c¢\94í\8bðï¥>^\8eÿ«B¼CÂØç^Ðìs$ê=pÒë£\93\9e¦ùÿ¨\85D\14ÿÂd4&õMG[\82t\95î\11"d¼\91\88\89¯ùÙðW®\8bhåß(\8eÏdü\9eè\ 4Út\1a\1cm\8fõ6JÊJõxR/"¤,Ë°ØxDjlb\9a     3¥\14´H\12\99ÞÎB&\ f\1a\ 5÷±\auÐáZ\vçcÈxñ¨Î36QLÿ}}uöon\90²U
+endstream
+endobj
+905 0 obj <<
+/Type /Page
+/Contents 906 0 R
+/Resources 904 0 R
+/MediaBox [0 0 612 792]
+/Parent 876 0 R
+/Annots [ 899 0 R 900 0 R 901 0 R ]
+>> endobj
+899 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [394.994 227.028 425.214 235.828]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rec470) >>
+>> endobj
+900 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [194.541 188.671 217.012 200.627]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.2) >>
+>> endobj
+901 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [257.988 131.141 288.209 139.941]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rec601) >>
+>> endobj
+907 0 obj <<
+/D [905 0 R /FitH 686.127]
+>> endobj
+908 0 obj <<
+/D [905 0 R /FitH 550.575]
+>> endobj
+909 0 obj <<
+/D [905 0 R /FitH 506.245]
+>> endobj
+910 0 obj <<
+/D [905 0 R /FitH 464.905]
+>> endobj
+106 0 obj <<
+/D [905 0 R /FitH 398.114]
+>> endobj
+110 0 obj <<
+/D [905 0 R /FitH 284.678]
+>> endobj
+904 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F11 573 0 R /F1 667 0 R /F10 668 0 R /F9 882 0 R /F7 674 0 R /F13 705 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+919 0 obj <<
+/Length 1979      
+/Filter /FlateDecode
+>>
+stream
+xÚÕYYsÛ8\12~ϯà#Ue!¸H\10\93\9a\87Øq\12ï8GEÊLMeç\81¦h\8bµ\12©"©q¼¿~»Ñ N8q\12ÏNÍ\8bÐh4\e}áúÄ£\9b\88\9e\9cN\9f<}iTd\99Me\1aM¯#ÁS\96¥6J³\94       i¢é,ú\14k¦ØhlL\16?\1f !â_Ýïó\8bËç§\97磱R*>{wùî\ 3\91\93÷£L\81¤Ìâ³óÉè\8fé¿\9e¾Ìv¦\0\19\ 5\ 3\9cr\99 È\13îM\8aÆJd,ãI4\96\ 6¾Q$õ¡,À\ 4©x¬\r'bÖ@\9bÅeGݺé\89èVÄ/ªë;âä5µU½Z{¡\9b|¹Ì\89¼^×E_55è×\82Ç/Ñú¦¥±é¼lÚü\ 4:        \8fûy\89\±c\8cá\16­\8fÆB3«5´\82Ù$!\9b?yÇ\ 48Ö¢wH|\0\17\17Ó\8f\îûý)þ\ 3tj½±\12ÈÁ4?ÐQ\9bwÝzYÎ\9c½      \98\87\96ìÔIÜåËrød\18ʽêm\94þÍ\85.gĽ¬Ý\11=yó~zî¼ãû~       Ãß\80Hj¿ä!|mõ\91\87\18I\bïí¼*p¦9©)\16yµD\v\r\ 4¹¡¶\1d\89\18\8c\171\98\97\ftÑÓ\aKJý¬lkb¬Ú\1c\ 2U\94ômå¹\14\b`\14m\99û8B¯¹¦á·ÓÉYÈ¿®º©óEGÕ\Tm\91#©ca­fî\83\15ãZÒWS\9cL\81úUÞº¸\8b¸/Û\8ex×XPHä\8b\ 5\12\82lCNÑ,h\10xm^w ºtÆúOg%&¨Æ\f\eÊNJª\f\8c0FÝ%\80\b\97\0'¬Ùa\91¹oó¶\fTmJ~ÜT\7fbjÊ\9a\9cvóA\1c¦¸,ò+ÈÄ¢ü¤ð\85fâ0ïl\9f!dÊ\f\97°Ôa\85g\9aæ}\anª®ìiÃ\10<J\995*Ã\1dC&ÌX\ 5f2m½ôï£q*âgg$m#p$\13Êí`\8a      +Q\98'~ÿº
+èT,MT´#\14Ò\951\9e\89\99µ>:íñ~f\98Ì"     ¦\91ÄÏXd\19\94mÂEê'\16\12vS\98Ùï~Ï\8eõi¦A¡\1f\172\vèðy{¸\ e°Fø\94KÅ´I7¹w\12ç\9f\8buÛùr:\b\94\86x
+óÏ\v¾\146\14\94\129³9\9b¤þáè\83\8e\azÆiÆ\8cÑû©ø%\10®\8céTìe \18  al´#ãcÁC\1e$ ¶ñò§ce\92\99\81\rE\12Ö:(I¾Çú«ã      aCH¿Éúì+Öo¼\13"\94Ã1nAú öî¨9Ò\ 6ö\9bÍmÅ\9b%\7fØ,\194
+\92è6º}£tÈ(»-±G\8b\95Nî±Jkyd\95:Vf¡\ 6Í\81\87­
+\e\95°L\99#£ÒÐÂH\8c|ôPq\91Ýc\16?Ü]Á,\13ªøL\88Ç7+¼Vµ\86\90B\7f¥þ\1cX«        K­¦µ\9aìí4{ê`\7f\13\11z\ 6·\9dÔÀÅñX#ì·B\864\86÷®ä\91ã\91\9a\80
+ëÞ\15\ f<\ 3x0\06\93\ f5A©àÞ\8f\8b*Û/\94\87eä&hP
+§ÚÃ3¢B\1a÷3¢¹üK2"Åß\9e\11\13>\8dáÅ\8b\17\8eoÏÈUРο\7f\8d\84\8c\ 4\ fÈÿoFxæo§
+n}úh[OøÅb±^V5¼äámÒ{Ìá\9e{U\8a\91Ýl­\ fKámH\ f¬PûÝ\8bê6t<J\91þ%)T\82ÿðEõ¾$\8a\87Þ\13\15\9d¾;P\8eP\82)\rÇ¡\86ÓNz§ýKrQR\16á¹øÓ\b\ e(\8d°
\9a\99ç;\94\ 1©÷\98s÷¨v\ fêÝ)\86öéKØKé\r/Ýb¶pµÖÂ\1d|\ 6n\9f\e\18\fB&\1eÂQ6ÃyN_!i\¡m\a\1fÇ\1fhàt
+w@>Ni`r×õ%â\15n\88xy=s\15¬áQcS\87\f\1f7¨Ý$ñmÕÏ\89òs\0\ 1\91r1N¶E\9dí\9dà^±äpøª\ 1r@ÈG¥z\ 3"¤IÜ­rÄA\90;\8c®;\87\1e¤\ eßÁúu4!\10@\10^wI\1d\11\93ó³ço\88ì6\ e\83~\a\b\0s\89YY\ f0\ e\8e ®²§¸-»>\ 4°8\0Æ\ eø\f\16ÍjÚÅ\8cº_\ 6Îl\16\ 2Î@\9d\80*\1câ\a\9a®\bä".\85\ 1©ÙHÄUKåÖ/î\ 6Y\8f}\81ÀÆcì`Y\9c\9e\10}*\80P<\89_xÆ\vb¤ñ«\13Róú$äòÅ   Õò/'\ 4«¼Å4?\85Èk\8a¼\1a"\ f2Ã|H¿ðò¯|ÿõ\9e\1eh\85\17¸t
+]ÒØ}KÄîÃ\10\96\e÷\ e\92©\7f_¿mú2°Èa\11#JãW9e\17Bå«\1827,!`R=´\rBXEÕ\ få\ 6Í\9f£$\89óÅ\1añZì#\bå>\99!\ 2©Ê¶ÜìíÐ\\83
+¢úyÓ\rp\95\81Ãá\0«;\821Uf©F¡õ&\ 2\85»      CØBÆ¿ÍK?¼-|èPø\81\18
+?Û)\ 3ì¸"-=tv\90^\9c¼í\10\9d\942\9e\95\88 \96³\13Ba!`w4pë\80\e{W9Õ£Tñ\1a½\80\15\b­\và{\0\17X«¶ZæmåÀnèæ¾};Å\12\9e@9\9fÑÖ¹k\9bÏêë\ 6§¥¹Q\88à½Ö\81Ú^\13\14\12l®s\8fªz\8e[¥JÆËü?U}C<¿Ï {U\15ýÚù\ 2ü~}µ\ 3ÆËx\9e\8f\Êýâ\ 3N\81\8cy^ß`\\ 2\11¤²Ò鮧
+¢ç÷.\18@\9dÙF'r¨Ø\9cNbä\1dµäìb\81\10y&=4\vÊ>²       #       XüÍrYÖ³.d̺s\1e+\88OÑ´­\87Z¡/\1c\1e¼®úö\8e\86\11®Æ6_­Z\17çÏ`}_úA7/|T~®º\1eTâZMLÜõPly;\vMí@iXÑ|\e\bôBÃugÝî¬\11\10Ø\96¯û\8fcFÄP¾\12Ê\17Ó½)a\18;\b!þY\ 2¦\8cCv }Õ\7fK¿%5\1e\r^!,¿ÍÏ\ e>\9c\17\10)/}\8bóV#\ 4¹IhÙ´þ´\87Xîø\0gEII¬¡°nîСðîu>}ò?\133E²
+endstream
+endobj
+918 0 obj <<
+/Type /Page
+/Contents 919 0 R
+/Resources 917 0 R
+/MediaBox [0 0 612 792]
+/Parent 876 0 R
+/Annots [ 902 0 R 903 0 R 913 0 R 914 0 R 915 0 R ]
+>> endobj
+902 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [108.64 645.213 138.86 654.013]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rec709) >>
+>> endobj
+903 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [135.402 633.258 168.804 642.058]
+/Subtype /Link
+/A << /S /GoTo /D (cite.smpte170m) >>
+>> endobj
+913 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [419.852 606.323 434.575 617.171]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.2) >>
+>> endobj
+914 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [170.907 594.368 185.63 605.216]
+/Subtype /Link
+/A << /S /GoTo /D (table.4.1) >>
+>> endobj
+915 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [163.534 241.093 193.754 249.893]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rec470) >>
+>> endobj
+920 0 obj <<
+/D [918 0 R /FitH 686.127]
+>> endobj
+635 0 obj <<
+/D [918 0 R /FitH 345.12]
+>> endobj
+114 0 obj <<
+/D [918 0 R /FitH 301.502]
+>> endobj
+917 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F10 668 0 R /F9 882 0 R /F11 573 0 R /F48 455 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+930 0 obj <<
+/Length 2165      
+/Filter /FlateDecode
+>>
+stream
+xÚÕYK\93Û¸\11¾ûWèHUYX¼\88Ǻr\18{Ç^'qì\1a+©Jy÷À\918\12«$Q!)\8fçߧ\e\rJ\94\84\19Ï\8eílåÄ\ 6\b4\1aÝ_?\0ðÑbÄGo\9e½\9c>ûéµ\e\8d4£éÍH\18Î\8c±#ã\f\13Ò\8e¦óѧL\9añïÓ¿þôÚªáHç\98\92\12Ø\841¯~½ø0½¼\1aO\94R\99\89µ.û×Û_.ßS×ë±´Ùû«w\17c§³éGdø\8cG)\8eE\98\b«\98²n4\91\16:\15ñ¿*gÀT{\9e\89Ø6õXºìsÕVõ¦X­îb÷x\ 2½e³®º\96zºeIÄ®\8dD}sòç\1fÓ\8f¯\88\9a!ÏeS¯\8b®\9aU\1d¶"ãÏã<Ï\8aÕ®lQz\90S3¯5|\ 5óyNbþÆs¾¨>ã¬r\ 3;w"«ÂWf\1fËY\a\82\86\9d\vØ7\1f5\8b\11\11Wo\9e\8d>\85Á\9a)&\8e\94CL\ 5ñº­º%Q«rQÌî\88þ0v*»ø;5\8aÍ\9c\88\8f\97¯.Þ\11YþgWm× \10\88Õ\81\1asç³·Q¼é²¬\9bâyØ\12\f¨ lªb\85\16\94Ù\1agïÚ\8eZ× e\9b\95Ô\98\97³:h}^Ω§hÛݺÚ,¨Õ\8d\8cc7å-\11\a©U/5ôöR\ 3¹m*\98·\1eOàw K$[\84\81VÙ»b\92\92¹\97X\9b yÜp¹    baÏMÝ\101¯Úíªè\8d\v\1d`\18ú®ÂP¾Wp\18]~®feK\8dvYïV\91ß5a\8d\1a³:¬GÆoºr?æ°
+â-!ô@\7f\r\v\ 3\9a\ 6°r\97Õ¿qaf´MhF×\0
+\ãå\e"Ûè\ 6³
+\ 6ë ;ô\16ôY\14A«ëØ\ 4`\9b\0ìÈþ\86Ü]\88\81WJ%\99·¶ww`\9aÓ¨¡ëzf÷\ 1á/ÈLf2ÁK\18f\95ë\aþ|ÎG2köK9Ø\9c1>û5xûmÐnÔñsX\ 3PXmÈ!¥µLh\13µfhú¶)Àïf\88>À[·¬Zrǽ7S\93ºU¶Û4e±ªZ\98B!\ 5\7f.«Å\92~\7f\8a¾)È}\89\bî\vx\ 6\99\82\8c\9eºðïèu^F[!§h+$Û\ e\1c-\8aÕ-\8b®\175\89\95ú\801´a\ 3~\ 1\82Â\94\1c\18ݵ]¹FZ¢\8dѾ¡;"\16»÷\88ÅF±\8d1ôK\85¾\ eÛM\18\1e\167îÈî\13\80\v¢êÜp\b[\10ô\0\ 1Å}&R\10È\99\13ò+\10د*Q{\1cBZµ     \86\84=­ë\10\89`\13³b]6E\8cÉRçL\8aüXeÛ¦\9cÌê¦\81\0\f\80Q>\86Q­yp\bè\88ÊBr\80\vl&\9d\80t%\aJIé\ 22©sCwÈuÆSÜ,\93¹}¬.t\8e¨7&B\19elw\8bEÙv±Ulhkõ®Ûîâ\86)\80Å´å9ÓúDE=ZÈýák{pØ\87À!\80\a7ùÃQÁ1mý@\ f\12*\ 3\99Æ\84öö±aÁX\fzÊ@X\f¾\v\92Ó×RVWÇ\81\r\9b\0\80\8eé\0;B:@b\a^Ô¢;\95Ä!\0\84´¥,sÜ\1dkk\90ºz§Ã¥\95¦d\ f\9d\94U\13±Ü\fË\19i=\953HÌ)\ 5` Àæ¦î\888Dò\9b;ê)â\84jQu\98\ 4°Qnú\14\12².v¡!ñ\eÔ\81Ĭ^á\86\ 3Ój\ 1%SÈ¥Ò@q\ 6ûé\7f\r\v\82d\8d\13e×.{;ýçä\8aÈ\97Sf¸\98äÔz LÂ\1c\9f\9f\85G\9a\86\ 6Ä/Ôis@¹49ÆƦ£-i\9bÝ@]FCbt<\rVZ0ÁU\8f\91«8D\8d\f$/H90Ä2£ÅH1#¢)R. Hóà!\83Qo\92¬\9cÒ\7f\9cÕË\ 4+Ç8@ã\9cÕ\10þ\10ÙÌ1§hEÒÈIÆ\9f÷9\11¼Êùc\vö% "6f$\152ÒýÅG\1cæ5\ 1Vy5\ 4\aÀbÿ1`ñ\17\86$üSmBDBrP\82`óf·     Õ1æz\99\1f\0\89ÿz@B=\11Á\8c½W!ýÍî\87©å\9eöõ0\18¹L\80\91\\99\84U\aé¨\15Â\f|\8b\101 Î-ç_)Ú\94\15p,Á2\16r\15N\82*\15\99X\1eC\10\10\94Ä­\88;\84\9e计¯)6-\fÅCI½\89Sç%\1az\13\82\194Cè\81±_?gÀ`ÍN·\1dæ\16M\99PhDÛð\3\fuh«âz\8cg\92\a\16\85\19ç\8bfì¸C@\ eȵ\ 4\90k&\9c¤ußÃ6U[vÑmøÀmd\ eÞ¥@LÈ\1c\9aFÿ\e\10\17¯h´\1fÁF\1c¸\1aæ\178Zy\89\83yn{G8ç  þ\95«Ñ`P\8a\17ø+ä\ 4μ\8fÊiÎý\15Òº\13àÿÚ\1f¥><"
+\93\f^\f*\9b>v½8g¨\99\96û:@H\97Ê¡d·Çó\bgK2¹T\90¨ÍÞöaÄå\97Ù®i#\9cN\14¥A\9fÂþÿ)_
+\9fÒ¾g\80ÑÇjNJýÍÚ\a\1e½öOøL\8ccÖêcSü-¡.(­\8c8²@R\15\ 2ê¯Á\98¨\vþÔ\1aì°\ 3\9fÒ$ø:0É\9f"ýõù\82pV4?Fz!R6\84ª\83Y}¢ûÿAaë\ e\85mR*°b\88t(\95zèÜá\98\97îDªoW\96Îï\91Jc¸>Ñ\95J]\r\88ÃíA\94J\7f³Ti¡àl©ì\99P&å\19ùÑ\85Å÷Q\15\17î\1e±øix\ 5±l
+òN\88ï/VÚYµfÎ\9c\98ðKÂYsf¼&gÍ\8f\11;\bpp¬\1f\fz\ 1å\8e±Ù]\82#\ 4\!S\1cÓÁ+ÿÎú0)øùpãüp\0߯À\93
+ðN>ö\f«T2ø£S¹§Xd\91\14Ȩü\ fXD¥8\1e[DsùC,"ý\9fn\11Ã\93\161P\8d\8a§Xä:)\10çO÷\91\aSä÷¶\88Èÿt\8bpCå©÷Ì
+\7f\1a>sþ\8bÉï©¢¤\83£þ^ÐÇÙë6ÁÇ\80;ú'{Ðm*\17J8Áÿ\b{)¡¾¹,½ÏbâÑQ\8düøpª\vG\v¼ß\98hHm²?\19Ó¹qUöo\86òg¼¸\f7\12xF>ÜJ\84{r Ã\r{8Cwû»ïöh©Ã\8b"\ 4PضÒ\90ÚÐ\83\ 4P\12h\ eÑ0\82\a6\rL\84̳\ fÕ\972\1c¾ñâÁë,\9c³Ûó]rHâ\ 26 öGûºÁ[c\83W°[ºõ¨\9bp\ f\vGì¶\7f¥ ç(¼¯ÃÒ¨lâ;\1c\8dÚÒÚø\9fÎ÷ís¼ëVYYÌðòuIÿÂ\83%|o\97Õ°{×Ò«Ô1s\9b\97\83vwÝ\16ëí\8a\9eåòø\1a\86\ 4]9äx\9d\82¼ññ\93ÚÛU±        ÷;@7åªèªþå!L«é\ 6~?}µ;\9a\18\1el]vA]ÃG.êYÇ\a¸\94\ 5/§Ïþ\v^Û=H
+endstream
+endobj
+929 0 obj <<
+/Type /Page
+/Contents 930 0 R
+/Resources 928 0 R
+/MediaBox [0 0 612 792]
+/Parent 876 0 R
+/Annots [ 916 0 R 923 0 R 924 0 R 925 0 R 926 0 R 927 0 R ]
+>> endobj
+916 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [237.482 642.722 259.954 654.677]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.1) >>
+>> endobj
+923 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [344.378 583.5 372.8 594.237]
+/Subtype /Link
+/A << /S /GoTo /D (cite.Poyn97) >>
+>> endobj
+924 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [257.988 513.706 288.209 522.506]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rec601) >>
+>> endobj
+925 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [180.704 477.841 210.924 486.641]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rec709) >>
+>> endobj
+926 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [473.65 463.948 488.373 474.796]
+/Subtype /Link
+/A << /S /GoTo /D (section.4.2) >>
+>> endobj
+927 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [224.705 451.993 239.428 462.841]
+/Subtype /Link
+/A << /S /GoTo /D (table.4.2) >>
+>> endobj
+931 0 obj <<
+/D [929 0 R /FitH 686.127]
+>> endobj
+636 0 obj <<
+/D [929 0 R /FitH 206.548]
+>> endobj
+118 0 obj <<
+/D [929 0 R /FitH 169.953]
+>> endobj
+928 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R /F9 882 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+938 0 obj <<
+/Length 1313      
+/Filter /FlateDecode
+>>
+stream
+xÚ\95VKsÛ6\10¾ëWð\bÍ\980\ 1\82\92ÆΤÓ6©­C2N\ f\90\ 4K\9cò¡\10dmwúã»\8b\ 5õ2S§£\19a        ,öùí.¢`\13DÁûÙÛÅìò&\8b\83\82\17©L\83ÅC ¢\94çi\11¤yÊ\85Ì\82Å:¸g\8a+>\ f³,g\9f>|¾þe\1eÆqÌnæ2g\1fo\7f}3Ïc¶¸\9bÿ±øùò&?\12\ 5L<S\ 5(rBd\86,³È«\ eÂñ<\94\19Ü\89\89«1f\rò\8b\9cõ-®\19ë̪\9dË\8cý\85úLG\87\9aÎ\1e\86ª¢\8dÎض\1aú²mèd\85W¶][{Î]¥\e\8fe¿%ÊêzW\19ëo´á<\14Ì\96=Y\90\1d1ö[\83Æ\83á¡\10¼H\12\1a\12b\14\8fdÙà\1a±¶[£µ¸\85®àº\ 2ëÀ  ïI\7fzx\8b»ïßÒÇC믮Ë9Ø\84\86í\80¨4ºõ<*ðºç¡\93\awjÚiÁÞý¡`]ë8VÆÚpÊ\8d²Ù@zU,Ù;\8c\82é TbXtC\84¶v¨\rÒ)ÄC÷´\8b\91!>4ß\a\1c¿m¹itEìV÷¥ý\1a  eìÙ­ß\9e¿\r¥íû­n\1a\88Î\84u.I`"X\18       ¼Ùv¦\ 6{S\95±\ 5ÊÁírmP\19\92U\8b\96<\86;0\98v\10A\8dí»aEøÀ=´¦ê]\94\9cÔÒó\96¨Ì\8c\1f~mÚ~ʲ]§AâJW\17X\11\92-\87\9e\bíÒüL\1fv({½¬\10|±`z·ë\9c\81Oe­=\\81ÉEÙÉ d\12ó`\rf~\r9¼ ¢CÒ\10\1a l\98iÖ.2xs\14åbëTQÕ$)Óe5\99x2Kf\ 5 ³ÞAõ ,ü$HQ     ¬\b\10\99¾\0\bðR\ 3øB\1f\16ã÷L´³\1e    MËÒ\99ìjù É|\9f\84\v\ 4C\84\b\ 3Ðì\8dÀÂÀÕhÂÖ\89\aéq\ 5Æqák\19h\15\8d!(N@yδªZklO\a®ÙÀZöèh*Ùusâ(^p\91h\87jM¬\b
+GlüÝÇ®u¹\0Ör\12É®\82|¾b_Cq¬<úpï±tý\f¨#\1cÄ£?\8aÕ-\19\1ccÂjʸBL¹*×Ôô8µb\95\a¤\b3\ 6SdÎ¥:4t\ 10\122aê
+~ (KØÝ°ÜWÛ\8bv\8eÎä<\11\92D¼¡Î\v¡ÛvÆwÖU[µ\1díº\86h\89Ö\9d?·=ÔîÚoö´B\vÇÆF\1f\87.þÏ>ë$®|2\9eg«í8\ 3\9c\8dB\1cÏ\9c\85\92ãÌùâYâ åE\16çÈ\ 2æÈ\82\98§Â§%zé«äY\91À\84:0]`;M&u\8a\84ç\90b¯ò'Ï\11\9d¨\14R@ø¸*¼¸åK\9d\88!\9e![Ä\95\87·n0Z©\98Ô\8bù\14ÅkzOÔv/Õæ<\8a\92à\88\87:F5\18Òü5J"küÇM¹\19:7
+g\ 2\14GA· \88¸\85\89~\ f<\11Cd\9d\fú{\94! ®\12é;6\8a:ÌÞÔÕ\8bÛìÇÓu      ½!6\9dq\9d´§M\9a\80\ 4+\8c\99µ\83"\88ÑÔ¦a\94ñX©ÓN\ 1ã½òsPÓ\84\87*Âaoù\89¹çëõ»* \9c"\9eÉ$\90\9a\a«zöm\7f\88ÿS\e\97\1fê<x×Î~\87ß(sd  G\89á\91H÷&;\ 1c\94\ 3¦!G\85ä9TµsÇgÂy\ 1\11¿\ 2\84}Â2ñ½Ä\1c:\98÷\96*}ÊÙón\ 1\18\94<ÊR\b¥ä¢È\ f]Cî»\86¼\92ÿ£køçÝ\82\1eRçH\8ex\ e5ùCHVß- \f^\93"8âÁê\99(W¨²¼øÁrUÿQ7"9V¶ox\10\11Bf\96\1e\1a\1elú×$P[]=\10Ex\aÆ-@»íÊ¿ñ\81\bÏ#|ËàùÉ«\16¾Û£{\13aL!Y¯µ¾ü\95Ö\87ó\8b\17\ 2R\ f}-É\8e\9cÃÉ(
+H!\9a8X\1cÚY|\98ΡL
+g LÜ\83ÙMÿä0     pÛõnܤ\10xN"\9cçC\8dÂüðëè`\94¹=\v\10î-Ç\9aÆk\7fzáÚ\1eDO¡\1dJú_©¾E|
+endstream
+endobj
+937 0 obj <<
+/Type /Page
+/Contents 938 0 R
+/Resources 936 0 R
+/MediaBox [0 0 612 792]
+/Parent 940 0 R
+/Annots [ 933 0 R ]
+>> endobj
+934 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pixel444.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 941 0 R
+/BBox [0 0 336 267]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 942 0 R
+>>/Font << /R8 943 0 R>>
+>>
+/Length 944 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\8d\93MO\ 21\10\86ïý\15sS\13\19;\9dN§õ¨Q¯\8a{1à\ 1\ 1QÃú±ÄèÏwvÁD\b\10ÓÃì¶Ï|uÞ~\80G\ 2ß®\95\1d×0[¸\ 1HÂT\bîm{â
\98\ 5¾\GCÿÊ\11\11\92\9d\97\8c9r\ 6*I\91Ìj\12L\ 4ÍÔÝ:%E5?     \11}àí\10q*¨\fÙ+Æ\1d\81\ 6«:"j\88¡-\84(¡E\f\8aѬÈ\94:[bYz\ 5±\1fÑÿAdé=Óvh\95m/£\0s\80¤l\9b\9c       EÊÿ á\80\81d\ 3\92õt{!âB6\ 1°\ 6\91Ëæ\rüBÂ\8c²Î\84­H&\eIÚ@Êzª5f³³¥|\9a\99ûp´ü^\99q\rg\95\89/\83Zë9Cõè\96\9a$HÞÔç\ 3\ 4\ 4V`U»ÃËfTOOaüÔ¼Õ#x\9f\8f^§pþpT½¸\94MjÅ\94\91\91£Íµ\9aì \9b\96îQh\13
+ôÔcN6\91?üüó\97¾;há¶<{\15Ö©tõE$Óm\8fb{q©ó¼~þ\9eÎ\17\82¢Ñ\ 4ܳA\85ÈÝñðÐ\1fûáQ{~Q¹\e[?XP¿\8f
+endstream
+endobj
+941 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (pixel444.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+942 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+943 0 obj
+<<
+/BaseFont /TGKBXV#2BTimes-Roman
+/FontDescriptor 945 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 333 333 333 0 0 250 0 0 0 500 0 0 0 0 0 0 0 0 0 278 0 0 0 0 0 0 0 0 667 0 0 556 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 722 0 0 0 0 0 0 0 444 500 444 0 444 0 0 500 278 0 0 278 778 500 500 500 0 333 389 0 500 0 0 500]
+/Encoding 946 0 R
+/Subtype /Type1
+>>
+endobj
+944 0 obj
+373
+endobj
+945 0 obj
+<<
+/Type /FontDescriptor
+/FontName /TGKBXV#2BTimes-Roman
+/FontBBox [ 0 -217 775 683]
+/Flags 32
+/Ascent 683
+/CapHeight 676
+/Descent -217
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/C/F/P/Y/a/b/c/colon/comma/e/h/i/l/m/n/o/p/parenleft/parenright/quoteright/r/s/space/u/x/zero)
+/FontFile3 947 0 R
+>>
+endobj
+946 0 obj
+<<
+/Type /Encoding
+/BaseEncoding /WinAnsiEncoding
+/Differences [ 39/quoteright]
+>>
+endobj
+947 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2743
+>>
+stream
+x\9ceVyTSW\1a\7f1\90ûp¡-i
+)\9a¤ußÑj\vÚ\8eZDÇ\8a\94}W\16     \10I\bkز\ 2AàKXÂ\1e\ 2a_\ 4\89\82\82\8aÈTQ±\9d¶V«u\eÑq:­µS\8f]æ>Îó\8f\99Ós¦ç¼óÎ{÷Þï»ßïû¾ßý]\16á0\87`±Xó\83%2qæÚ@¹,.Õþ¿\86rgQ\vçP\8bØ@Ëf\9bg·9."|[Ø\v`>\eæ;´-\9cgrÁ7^Ãm¯àâW        6\8b\95kêò\96§åeH\92\92³D+B\ 2ÃV®^½æ÷\91\r^^^¢ø¼ÿÍ\88v\8a3%I©¢eÌ\87B,\95§ÉÄ©Y[EÞÌj©TrP\94$ÍKKÎ\14Å%$\88\13ìf¡qRq\8ah\97D*IK\93+D+¼W\8a6zxlX˼6ûIdñÙ\99¢\17\91\8büä^"_Q 8)[\1a\97ñÇ\19\82 ÞL\95Gx§eìÊÌ\8eË\8d?(öO\96He¢-ËW¬\ãA\10\1f\13þÄ\16b   \11@\ 4\11Ë\89`"\94ø\90\88 ¼\89\9dÄ.b\ 3±\87ø\88ØGø\11\9d         'b.±\80x\8dpgòG8\10
+â<ë]Öà\9cus\8csh¶É\81íÐí¸Þ\11\1c\1fq>ä\9cA\1e¨\ 2}F\16\90jr\84üÑi\83\93Âit®+UêL\95\82\99zó<ëî\fÞ9Ãn¦ÞæUWÔ\19ê\81ì­UF
+i\ 3\82@­*ü0©ÄÉf\14^©l\0\e\89\8f¢ñSí\r\83@\9eí\94î\11Òb\ 4¾êü\bû¢\ 43\8a¬Ò4ÀY\12ç¡Ç1\17\97æïÝ-¸\83\8a\8d\91y\12mp\ 1\9fÙQ×Kmìeõ}\8b\9b¾eã
+*\96G¿á±\9a\16Ðîß/Ã.ØåÉoX\80]×ÿ@¿.TËy3\97\8b\ 3»·'$v\8e(\84òÉ\82¯à\1aùÃ\99\ 4γ\89Ð:˶²ð\97ÏسA³«x´<\973Yn)\82\95h
+\95ôbZáF¯À\19Úf½\ 5êùÐÒT;`¬\84:¨7\90­ô`.\1a/kR=¥ß®t°\eý!\82M:\9dÇa2\17_jE\e\8dª\ 6ø\86Ä¡\b¯À\8aéGÝíç*ùγëUcÔÏ#¬^L²g        *\94W\88\15\8e
+\8e^Q É\81BPV(«#\9b#j¢Á\v<¥û\82\89×\ 1=\aÖõo>\17xù£ïÄ?\ 1v\84\9fNOß#óZvìÜ#ó\ 4¾/\ 4Yc\8f\a\9f\95~\v\98Mâ=ßc'¼tjRqpD0\90b\96·~D2Y£e\96ü\96<,Ó\r\97]nÎàì\87®Ü\92Zj\11¯Ö`\82\8f\9atÑÂçÉ\b´Z\7f=É]\96\8fK\10÷@\vÚnP×ç$Þ\80\86\ euêN\ 2\89ç~\87\1dðRüªÏ?V\ 5Åd\84Ä\bo!½1D\91¬\ eÎçãUÛyý\17l§o\9cÝF\934;r»wt ­_à\8c\1f2\9dò\81\95õÍ\fÛD½Ékª¨54\0ÙU[\10#¤+\10D\14\17ïÕ0\1dPlF»+òÍ0Eâl40:ÑS][¢«\174«êõ\8d@v\9a\83
+«$.5kg¤ð;Tb\fÍNRûç2mñ\17hÅÓ'píñÜV\97\9f\9e¹r\93©L\ÀÃÊ,¤Ù\9a§Ü
+$½\14gpz«ª{\ 4x!\87Éa»Ò²\81ìâ\94âÅ\8eÏ{9Ü[¹è\86¾Q\ 5>äs\1f\ 4\9eZõ¶\12¦\8c\83­èO\95ª&¸NâT¼\14Ý\ 3\8b²a\v\93N¾®]c¥ÖYÕí.ç®`¯¯\¹kð\97ø\vÞa¼ÐQË)++,./?\f|=è\8cÚ*\92k©ÉήLw\7f?0Ü;hàà\83(áÅCC9\96L\90òcRäá\12ic{®@ÑUØ¡\9e"\vh\8fF\8e©®ÒÈd\87ë[\vMe\1dL1,úÞ\9eÃ-î·>»øÕDæàÇ6!M|&oVvA\ f\7fäHïé©~ÉÆ\ e\81\9d\e\17\ 3­Ô\16\8bªÉåÚ\fÞ5ãʵP\99\13¼\12Î~mýi!~BoDÜÁ|t¥´A\a\11$­A /Q©´iÙR\8d\fÈ\84\94£'\85\\v¾C/S¡ñÒ&%ì'é*ôþxø×Ç\86\9b{z\ 4££\8e\9e\88ë[Y6aµÕ\9fkb²î¯\9b
+¼H¹uº\¸\8fWÜså\9e¢ü>çå«4%J ³\8a\9bÆ\848\fÁdI\9f²3Û\16Ûê\ fäÚ\1d\91¾YÖ\9c\8eÎ6k{eyU¹IXV[^\ 3&²g }älOj\88À\ fÑëöå\17Å\8a³sT\128DrÃ}Çb¦ÇN´MN\v¸\8daU-\8a\13îG¡­aè83E¯¿Ï\ 3iI¡B\93©\92\17*\80L\96\1f\1d\15V"¸tÂ\86\17\8cÙ\e\1f¬Ô;f\16\ 6ÞoæH!§Y:F¿\8eÃÝîãù­=ýÍ\ 3\ 6¾\99Þ¨DýeuzP\81F\93\9d!-ÑkòÔ9*«\9büdÞQh\84¦FS¿\81\a\95µ¨\1f\9aÕG¢\1fÓKÜh\ eí%\8b×\15\1f*å+ñR3\92\1a«MæF«ð\ e\9f´¨RoÔ\83\9e\ f\87\ f\95Ù#a¨7ïSÖÕ\19\9có\88\8d×Î~À+1Æ)Ó\8a¢ÕüÔ"Ç\ 2Tm¨\ 4\13\90\85qÂçÍHúàÐ]ìö\fÏÁ\8bñ+Û\1e\vH\8aÌ\11\84:\f\9f±MÞ\9eø\80v¦ÙQ{½Â\ ett     ìu¸N9ö±ºn±©·±\a/Ê')3\10H\8f½w1úùüµ{¶Fmb\9d°:»FÞ\92×\ 6üîöÖ\8e\v>gÞ\8b\fÏI\8a\17FÄÈwÃû$ýÆ\9du\98}j¤ù\88MÐÓɤæ\12i÷{\15§\ e`dcQk°'/j[lê^\b\84ؾԩ¼ãÅ\83eÓ$\9eæ\14ýU×\971 ³ío\v\83\b\88Î\13K¢ãÓv\82\17I\v®oÆè\87\9b\970qR@ßÆkxõ·\8f\1e\9b\86\947n"_\92¶}\ 4O\1ccHûô\19.À,W®\14\1fÀc¼î2Ky7Ü\86OêF;/\ fئás8©:\9eÖwplSïZ\86Ì\16\ e×Â0¶¨N\aÞ/\18û^\91n[ñKƾ_¡l\82¯I®\94R8ô\98L=ØýJô\92\114ÊQ\19\8cY\82\97ªåþ      ëë\19ì7ÃÆ\eð\13ÞÉÓý\96a 'º\92|\84t$\82Ý:u\80þ¥l\85Ôékà*\89£Ð¯q\9f\8fËüx¿\0\92
+\89&£(¨\80\9ff/^¥¡\ 2ª\80\1c­)\8a\15>OAà£/\f(bì¥f\14P­k`ì\9dñ\11f×yæ!+^ðÌåö³w\19\8a½íúµ>ØQ\89j\f\rÆFC-ð;_\9c\89J\ 4Þ:í.»*êÌhOUQ\9dý\10Â\88K\85c\ 5/-+K.oÏêíëhïëÍêH\15¾ðÎú×\f\9b\114^5§ÞÐ`¨\ 1r NÅ\9céé\bBTjß\12Æ\95Ö\8c|+5up\9e¤\1e£ÃÆ°|±nW>#J­Lh\8b&Y\ fg°¯ýa·2JÞXQcWòîÚ\82(!]m÷¡\f*g|d\98Q¨QY\ fÃ$\1eB`¬©3\99º:F-C@\8eµ'3Ù\93!\bÒj\ 3í\91g\99Q Ai\81+$®Bý£\83\81\9cjIó\14ÒIÌÍ ¨( \98Y$7£t£Ì¨n\81a>\8eGxnÂå?\ 5\84§\a\84\bò¦$=!\10\ 3r\95§/y\93¹\ 4\84ç2\97\0\19W0xµ\98\8d\r\98ÍÂ\v©\18\9e,#]\9aÚ\95Ñw¤»«ïHz·LHÓ\ e\7f\18cD\88ºú\v\vï\1efÿFùð¾\18<5\r\97É\89äá\ 3É\99Y\92\94\8e\[µÉ`¨\16\98\8c\0\ 6 kªõE\87äI!\89vÃÙ%VÖøC6\1e\9fõäí\88\92¥'îß¹)y9ÐN@s\8f­|´ôDTwödJC³ÛÖOåCi73¿Ð~\ 3Oá×Æ¿õ\é½Òo»~\91ü¯\13\1cõ\90}\9cöáÝ\18ïï>vúÚß\87\9e\ 2v\ 2üzâ\8fï<\8b\1fOo\ f\eÐ\14¸ÝõíIîÝÞùçúm°\1c\16«=Óüä¾²$ï\0ÆI\85ÞZð\8b\vö\18våÆÞ§ßú\7f\14\ 2nÛï@¸±F\13\ 3ÅÝ\8e$E\9ehGB\95ªºg]ºY\9dOpã\13661p\82!.?19 HL£\17xX\83´Ó\99 c1ç2/Â9\18µØ\86.\9e?\8e\vH\1cç\81ߢ]\ 5¥é¼\99S´#-¦Å1¢Í\9b\8d\13pò)Ì~(tαR¡V\1clåôÏ}0¯¿fþü\a\17\10Ä\7f\0\9don\85
+endstream
+endobj
+933 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [227.189 512.284 241.912 524.239]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.1) >>
+>> endobj
+939 0 obj <<
+/D [937 0 R /FitH 686.127]
+>> endobj
+122 0 obj <<
+/D [937 0 R /FitH 558.315]
+>> endobj
+585 0 obj <<
+/D [937 0 R /FitH 204.803]
+>> endobj
+126 0 obj <<
+/D [937 0 R /FitH 164.664]
+>> endobj
+936 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/XObject << /Im8 934 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+952 0 obj <<
+/Length 1325      
+/Filter /FlateDecode
+>>
+stream
+xÚ\8dVYoÛF\10~÷¯àã
+\biîÁ]Òon\13§)\10\85\ 2\aJ¢%"<d\1eqÝ_ß\99\9d%M\8aL[\18\90g\87ßν3\13zG/ôÞ_ý´½º¾\8b½$H´ÐÞöÑã:\f´6\9e\8e\85ñ¶\aï\v\13ñæÏí¯×wFN\91q\1cH!@\8cÅüüËíçí»û\8d/¥d*ØøÆÄì÷\ foß}"ÖÝF\18öéþãí&Vlû\80\ 2¯BgÅÜ\ 4\7f\90ì\v\ 3LIò\8b¾LA\92\88Ù¹H«\8cȯa\14\99;ÜåǾɬ`\ ebC¯9zDÜ¿¿ò¾X\8c
+ÄL3\b\ 6\19\1cÌUJ²\87¼Ì\8b´)^6±doPjºSöBòOé\ 6~¿ãO6p\8a\0ED\85nö%\82v\e\1f¡\r\1dòT7ùßu\85\80.-Ð\180Äç<H¢\88<mûóxS\89\90í\8aÚ\9e÷xç[û\ 6m\15¬©ûê\90\1d\bÒ\9f1àaÄ>¦û¦^½FÌ\14\ 2d\89Cö5äª\1a\ 4àµÖb8Û×EíTÛP\ f\1aÓê°j.¨\91Zb\brôU\vf½[\ 4\ 10\a4É°¬¥cUwta\8fQ;¥Õ1èë\84íú\8e Yjí?\11®\84\93ÏY³áÌi\9d{é¤Õ6\v]\9aW-q\¢\80J\9dê2µF¾¬yD\1a\9bÚ\16\9cTN\87!+¿µ\81½ÃU\90(\ 5\17E\90$\9c.nm\15¨Ðùã$À¹MËsa½V.\aH|GTÖtù>-\8a\17÷±È\8f6+xxλ\13QÝ Ù=\ 3Å\a\99\180H\ e\ 5\f\0P_¾5Ð\1f-\9c¸6)=Ô¨B\8c=D4#nÖØ\82\0®Ë[\87ìg[ò\0\81/\90ç\91U\13\94LÂOÎ$¨E\1dq\88\86-\ 3[>PK¯\99\»DÜ\13¦\a\89t-/}\95\88ÔP¤EÝfm\87\87y¸ñL"Á\8c\18ø·tá\84\9e\9e±OÏBÏ Ò\89lOùcGd\99RqØÃ\8ej\96\ eMöÔç\14%8uõ\9a\9dç\86jòÐïñV$X\vIM\8b\96\ eϧ|\8c\ 4\1c{«?\82Ç\91Ã\93\94\90\ 2Ê\ 5}½h\17\96çÜE\87JL^ê\94 ×yu¤Óð.Ò.¯+§ù\11ÞõZ½×å\19`»¼È;ç7vìg\94\r\1cn_\1f¼\83\85\81\88j_Ú.+[Ä\ 6³ÖzùÿÝÖµe\ eCF\ 5\91\90\9e01ü×Þ¾¼z\1a?âï\1aãúC\99xoë«ßào\909@üA¢?\11¹\98mB\8bÀ(P«t \95sÞM\r7¶Ä\röº\88}ÎÿÊ0_Èͪ½Ë§}\97\88»\117bÕÙë;\15{\14[A³,\14Ah"\ fÊ%\90Æõ       \15¨@Bĸ\88¬¬\10Ä\9a\88=ô»1\87vÞN\8d\87\9c\890\90\¿¶\1a\8bá|ê!\fïX\8e#Ù!BO\a\89\911"\fLu°*P\89ó\7f·Te \82Æ\9b`\ç¿PÆ\93 2ú¿\94ñ\99¶fM["gÚhè@H"åz%\10mWÛW\87´k\8bðd\_\a\1e5H .\1f\8c\95\9b\ 3^¾âi\9eS\13¦¾©Ñ¶¡oºp7Y[\17=>%¸\15\v\9aæ1\89YFÆD0\13Ì\10\99?\1cBÎ"\93$±'\ 3=ä3\\ 6\ 6\8a\9e?\ 1ÙÈ@[\8b\121í®2\89¦s\12Ì"ó\ 4\9ag_fFÇ1²±¤V\8bL\17\93x\88I<\99ßfh~Í(×\86(\81:\vù¼\8b\\ 6^ÄÑr\aA¦Í\ 6\12¤\19\19\89ÕÍ\ 1\ e9K׿èhg\825+ \8dÙ\91\83\873\1c0\14\10;\ 1±Ã¶H·ÖºcWS\1dÁfD;\1cü§ý\93³§>m:Úðø°\ 3ò\1f¬?\93û\17\v\ 51'»,ÿ\1f»,gØC~´Ë\86+»¬\1cwY>ßeW\9cv©1C\ 4M´^\14ÂhJ\r\0\16\ 5\0¼é.\8bçe²ÌP\10f,\b\90¹Ô:+\b\13\8dZÇ%
+rjW\99¹j;¸9[\9d{ËÅZFÑëb-a\87±\8bµJÌ°X#oá\ 32]£âÓÅÚòÝb\8d´[¬\91\1c\17kÔèÚ\13§U:ân\95^\9b/0Dÿ\ 1\98AuC
+endstream
+endobj
+951 0 obj <<
+/Type /Page
+/Contents 952 0 R
+/Resources 950 0 R
+/MediaBox [0 0 612 792]
+/Parent 940 0 R
+/Annots [ 935 0 R 949 0 R ]
+>> endobj
+948 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pixel422.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 954 0 R
+/BBox [0 0 336 267]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 955 0 R
+>>/Font << /R8 956 0 R>>
+>>
+/Length 957 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\95\93Mo\141\f\86ïù\15¾ÑJ¬\89\13;\8e9R\15®Pæ\82(\87\14ÐNK§Bðóqfwi§ÌVE9d2~òú+¾\81\88\ 4±­Ý¾êÃ\8b3\85ËÛÀ¨\89\93À¯0ÚáìM *\982$®¨R\81²b¦2îÆ\ 6Ã:¼ß3\14\15c¦y&\89\1fD\1f\17ÚC\8f*q$\14å;%64âyè¯Ò\1c$RP\92N\94Rµyè¾Ò?Pu£W ¨z\ 5ó\83¸eÂHN\98\19\8a9£ÙT(Í3\13¡\87L©â'°BHZ\ e´m\aU\12,å@K>\82ç_\8cà\93¿\87\8b`È\Û\ 3\býK\12cl\91ZQ$\17Ñâj´¿¼½u÷®\88Å\1a6     ,=Í%åb¨\19Z!¹þ¯ÇI\96OõH\1e¥ÿ¶\8a\95ó\ 1\97ÛQ\19\8d·füÞm«\1e^u>Z\15\14Ej\85îKØN\1cA\89î#&H\99PÍM}8z=,ûõKX}\1d®û%üØ,¯Öpòù¸û\1e\1a\9bOaÅÌ>\1fÝÅ\ 1zhô\82Rs(°Ð\88µ0Ýç7?÷ô\87g\rnáyî\94MÆøØÛ\92aAìU²2Þ|ûí÷zs;*[\e*O|\91}\b8\8fæó£ø<\9e\1f7ûi\17Þùú\ 3\8f/ì7
+endstream
+endobj
+954 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (pixel422.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+955 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+956 0 obj
+<<
+/BaseFont /TGKBXV#2BTimes-Roman
+/FontDescriptor 958 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 333 333 333 0 0 250 0 0 0 500 0 0 0 0 0 0 0 0 0 278 0 0 0 0 0 0 0 0 667 0 0 556 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 722 0 0 0 0 0 0 0 444 500 444 0 444 0 0 500 278 0 0 278 778 500 500 500 0 333 389 0 500 0 0 500]
+/Encoding 959 0 R
+/Subtype /Type1
+>>
+endobj
+957 0 obj
+414
+endobj
+958 0 obj
+<<
+/Type /FontDescriptor
+/FontName /TGKBXV#2BTimes-Roman
+/FontBBox [ 0 -217 775 683]
+/Flags 32
+/Ascent 683
+/CapHeight 676
+/Descent -217
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/C/F/P/Y/a/b/c/colon/comma/e/h/i/l/m/n/o/p/parenleft/parenright/quoteright/r/s/space/u/x/zero)
+/FontFile3 960 0 R
+>>
+endobj
+959 0 obj
+<<
+/Type /Encoding
+/BaseEncoding /WinAnsiEncoding
+/Differences [ 39/quoteright]
+>>
+endobj
+960 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2743
+>>
+stream
+x\9ceVyTSW\1a\7f1\90ûp¡-i
+)\9a¤ußÑj\vÚ\8eZDÇ\8a\94}W\16     \10I\bkز\ 2AàKXÂ\1e\ 2a_\ 4\89\82\82\8aÈTQ±\9d¶V«u\eÑq:­µS\8f]æ>Îó\8f\99Ós¦ç¼óÎ{÷Þï»ßïû¾ßý]\16á0\87`±Xó\83%2qæÚ@¹,.Õþ¿\86rgQ\vçP\8bØ@Ëf\9bg·9."|[Ø\v`>\eæ;´-\9cgrÁ7^Ãm¯àâW        6\8b\95kêò\96§åeH\92\92³D+B\ 2ÃV®^½æ÷\91\r^^^¢ø¼ÿÍ\88v\8a3%I©¢eÌ\87B,\95§ÉÄ©Y[EÞÌj©TrP\94$ÍKKÎ\14Å%$\88\13ìf¡qRq\8ah\97D*IK\93+D+¼W\8a6zxlX˼6ûIdñÙ\99¢\17\91\8büä^"_Q 8)[\1a\97ñÇ\19\82 ÞL\95Gx§eìÊÌ\8eË\8d?(öO\96He¢-ËW¬\ãA\10\1f\13þÄ\16b   \11@\ 4\11Ë\89`"\94ø\90\88 ¼\89\9dÄ.b\ 3±\87ø\88ØGø\11\9d         'b.±\80x\8dpgòG8\10
+â<ë]Öà\9cus\8csh¶É\81íÐí¸Þ\11\1c\1fq>ä\9cA\1e¨\ 2}F\16\90jr\84üÑi\83\93Âit®+UêL\95\82\99zó<ëî\fÞ9Ãn¦ÞæUWÔ\19ê\81ì­UF
+i\ 3\82@­*ü0©ÄÉf\14^©l\0\e\89\8f¢ñSí\r\83@\9eí\94î\11Òb\ 4¾êü\bû¢\ 43\8a¬Ò4ÀY\12ç¡Ç1\17\97æïÝ-¸\83\8a\8d\91y\12mp\ 1\9fÙQ×Kmìeõ}\8b\9b¾eã
+*\96G¿á±\9a\16Ðîß/Ã.ØåÉoX\80]×ÿ@¿.TËy3\97\8b\ 3»·'$v\8e(\84òÉ\82¯à\1aùÃ\99\ 4γ\89Ð:˶²ð\97ÏسA³«x´<\973Yn)\82\95h
+\95ôbZáF¯À\19Úf½\ 5êùÐÒT;`¬\84:¨7\90­ô`.\1a/kR=¥ß®t°\eý!\82M:\9dÇa2\17_jE\e\8dª\ 6ø\86Ä¡\b¯À\8aéGÝíç*ùγëUcÔÏ#¬^L²g        *\94W\88\15\8e
+\8e^Q É\81BPV(«#\9b#j¢Á\v<¥û\82\89×\ 1=\aÖõo>\17xù£ïÄ?\ 1v\84\9fNOß#óZvìÜ#ó\ 4¾/\ 4Yc\8f\a\9f\95~\v\98Mâ=ßc'¼tjRqpD0\90b\96·~D2Y£e\96ü\96<,Ó\r\97]nÎàì\87®Ü\92Zj\11¯Ö`\82\8f\9atÑÂçÉ\b´Z\7f=É]\96\8fK\10÷@\vÚnP×ç$Þ\80\86\ euêN\ 2\89ç~\87\1dðRüªÏ?V\ 5Åd\84Ä\bo!½1D\91¬\ eÎçãUÛyý\17l§o\9cÝF\934;r»wt ­_à\8c\1f2\9dò\81\95õÍ\fÛD½Ékª¨54\0ÙU[\10#¤+\10D\14\17ïÕ0\1dPlF»+òÍ0Eâl40:ÑS][¢«\174«êõ\8d@v\9a\83
+«$.5kg¤ð;Tb\fÍNRûç2mñ\17hÅÓ'píñÜV\97\9f\9e¹r\93©L\ÀÃÊ,¤Ù\9a§Ü
+$½\14gpz«ª{\ 4x!\87Éa»Ò²\81ìâ\94âÅ\8eÏ{9Ü[¹è\86¾Q\ 5>äs\1f\ 4\9eZõ¶\12¦\8c\83­èO\95ª&¸NâT¼\14Ý\ 3\8b²a\v\93N¾®]c¥ÖYÕí.ç®`¯¯\¹kð\97ø\vÞa¼ÐQË)++,./?\f|=è\8cÚ*\92k©ÉήLw\7f?0Ü;hàà\83(áÅCC9\96L\90òcRäá\12ic{®@ÑUØ¡\9e"\vh\8fF\8e©®ÒÈd\87ë[\vMe\1dL1,úÞ\9eÃ-î·>»øÕDæàÇ6!M|&oVvA\ f\7fäHïé©~ÉÆ\ e\81\9d\e\17\ 3­Ô\16\8bªÉåÚ\fÞ5ãʵP\99\13¼\12Î~mýi!~BoDÜÁ|t¥´A\a\11$­A /Q©´iÙR\8d\fÈ\84\94£'\85\\v¾C/S¡ñÒ&%ì'é*ôþxø×Ç\86\9b{z\ 4££\8e\9e\88ë[Y6aµÕ\9fkb²î¯\9b
+¼H¹uº\¸\8fWÜså\9e¢ü>çå«4%J ³\8a\9bÆ\848\fÁdI\9f²3Û\16Ûê\ fäÚ\1d\91¾YÖ\9c\8eÎ6k{eyU¹IXV[^\ 3&²g }älOj\88À\ fÑëöå\17Å\8a³sT\128DrÃ}Çb¦ÇN´MN\v¸\8daU-\8a\13îG¡­aè83E¯¿Ï\ 3iI¡B\93©\92\17*\80L\96\1f\1d\15V"¸tÂ\86\17\8cÙ\e\1f¬Ô;f\16\ 6ÞoæH!§Y:F¿\8eÃÝîãù­=ýÍ\ 3\ 6¾\99Þ¨DýeuzP\81F\93\9d!-ÑkòÔ9*«\9büdÞQh\84¦FS¿\81\a\95µ¨\1f\9aÕG¢\1fÓKÜh\ eí%\8b×\15\1f*å+ñR3\92\1a«MæF«ð\ e\9f´¨RoÔ\83\9e\ f\87\ f\95Ù#a¨7ïSÖÕ\19\9có\88\8d×Î~À+1Æ)Ó\8a¢ÕüÔ"Ç\ 2Tm¨\ 4\13\90\85qÂçÍHúàÐ]ìö\fÏÁ\8bñ+Û\1e\vH\8aÌ\11\84:\f\9f±MÞ\9eø\80v¦ÙQ{½Â\ ett     ìu¸N9ö±ºn±©·±\a/Ê')3\10H\8f½w1úùüµ{¶Fmb\9d°:»FÞ\92×\ 6üîöÖ\8e\v>gÞ\8b\fÏI\8a\17FÄÈwÃû$ýÆ\9du\98}j¤ù\88MÐÓɤæ\12i÷{\15§\ e`dcQk°'/j[lê^\b\84ؾԩ¼ãÅ\83eÓ$\9eæ\14ýU×\971 ³ío\v\83\b\88Î\13K¢ãÓv\82\17I\v®oÆè\87\9b\970qR@ßÆkxõ·\8f\1e\9b\86\947n"_\92¶}\ 4O\1ccHûô\19.À,W®\14\1fÀc¼î2Ky7Ü\86OêF;/\ fئás8©:\9eÖwplSïZ\86Ì\16\ e×Â0¶¨N\aÞ/\18û^\91n[ñKƾ_¡l\82¯I®\94R8ô\98L=ØýJô\92\114ÊQ\19\8cY\82\97ªåþ      ëë\19ì7ÃÆ\eð\13ÞÉÓý\96a 'º\92|\84t$\82Ý:u\80þ¥l\85Ôékà*\89£Ð¯q\9f\8fËüx¿\0\92
+\89&£(¨\80\9ff/^¥¡\ 2ª\80\1c­)\8a\15>OAà£/\f(bì¥f\14P­k`ì\9dñ\11f×yæ!+^ðÌåö³w\19\8a½íúµ>ØQ\89j\f\rÆFC-ð;_\9c\89J\ 4Þ:í.»*êÌhOUQ\9dý\10Â\88K\85c\ 5/-+K.oÏêíëhïëÍêH\15¾ðÎú×\f\9b\114^5§ÞÐ`¨\ 1r NÅ\9céé\bBTjß\12Æ\95Ö\8c|+5up\9e¤\1e£ÃÆ°|±nW>#J­Lh\8b&Y\ fg°¯ýa·2JÞXQcWòîÚ\82(!]m÷¡\f*g|d\98Q¨QY\ fÃ$\1eB`¬©3\99º:F-C@\8eµ'3Ù\93!\bÒj\ 3í\91g\99Q Ai\81+$®Bý£\83\81\9cjIó\14ÒIÌÍ ¨( \98Y$7£t£Ì¨n\81a>\8eGxnÂå?\ 5\84§\a\84\bò¦$=!\10\ 3r\95§/y\93¹\ 4\84ç2\97\0\19W0xµ\98\8d\r\98ÍÂ\v©\18\9e,#]\9aÚ\95Ñw¤»«ïHz·LHÓ\ e\7f\18cD\88ºú\v\vï\1efÿFùð¾\18<5\r\97É\89äá\ 3É\99Y\92\94\8e\[µÉ`¨\16\98\8c\0\ 6 kªõE\87äI!\89vÃÙ%VÖøC6\1e\9fõäí\88\92¥'îß¹)y9ÐN@s\8f­|´ôDTwödJC³ÛÖOåCi73¿Ð~\ 3Oá×Æ¿õ\é½Òo»~\91ü¯\13\1cõ\90}\9cöáÝ\18ïï>vúÚß\87\9e\ 2v\ 2üzâ\8fï<\8b\1fOo\ f\eÐ\14¸ÝõíIîÝÞùçúm°\1c\16«=Óüä¾²$ï\0ÆI\85ÞZð\8b\vö\18våÆÞ§ßú\7f\14\ 2nÛï@¸±F\13\ 3ÅÝ\8e$E\9ehGB\95ªºg]ºY\9dOpã\13661p\82!.?19 HL£\17xX\83´Ó\99 c1ç2/Â9\18µØ\86.\9e?\8e\vH\1cç\81ߢ]\ 5¥é¼\99S´#-¦Å1¢Í\9b\8d\13pò)Ì~(tαR¡V\1clåôÏ}0¯¿fþü\a\17\10Ä\7f\0\9don\85
+endstream
+endobj
+935 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [262.354 654.677 277.077 666.633]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.2) >>
+>> endobj
+949 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [393.475 140.605 408.197 152.56]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.3) >>
+>> endobj
+953 0 obj <<
+/D [951 0 R /FitH 686.127]
+>> endobj
+586 0 obj <<
+/D [951 0 R /FitH 258.6]
+>> endobj
+130 0 obj <<
+/D [951 0 R /FitH 213.319]
+>> endobj
+950 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F48 455 0 R /F11 573 0 R /F10 668 0 R /F13 705 0 R >>
+/XObject << /Im9 948 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+964 0 obj <<
+/Length 1276      
+/Filter /FlateDecode
+>>
+stream
+xÚ\95\16ÉnÛFô®¯à\91\ 2B\9aÃ\9d¾¹h\1c$hP7\11Ú\ 2m\ f#i$\ eÊÍÃa\1cçëû\96¡LÅÌ¡\10 Î[çío"ïìEÞ»ÍO»ÍÍ}\91xUXåqîíN\9e\88ò°Ì+//óPÄ\85·;z\7fùi\98\86Û (Jÿáý\9fo\7fÙ\ 6I\92ø÷Û¸ô\7fýôñn[&þîóö\9fÝ\87\9bûr¡
+\98Â"­à"R\12WȲ\89ÜÕ^0Ó\83¸\0\99\84¹:Ô:µø¿ß\ 6ð¯\f\WDþ±gpd°ë-\1f\ eÈZËî¬Þ\0¢\8cüýä(J2\8d¡V\1eLÏÇ}ú\88ü¯SÓÓÍVêÎÝð¤m­;>k§²ï\14\1f\1e'i,\98\ 6\1e\817\81\10a\95\81\1c9>­\ 4\8d\85ÿÌ\10\9bbúV"\9c\82\7f\03\84\ f\82Â\ fI§HÃ*M¯\15ïj¸<\8d\ 4\vÔ\ 6\16E$£GÙ\ e\rÆ\a\ 1i\1có\17dVÆê\83l\9agGì\8e|¨{£¿Í\9e\aÅ\18\85Êñ\1a:8\11ÌJÁ\18\8b\Oø§@\82¨§~â \ 4k\1e4\13º\9f\8a\15ª*¯Jð\8c²>B\ 6Ó¤Z$\ eY¿\17âs\8d\ 3Ñ
+\7fêôãäh\87¦\1fÕh\1d°\bü\8b\92p-s»Z»ÜÍ_\8b!Çt\81\94bÔ8í\ 3Ò¡»3c\ 6\14:\ 6¦Q\1dùô\84\10=[³\8e\ f\ foß½aÚÇÅ\99\92AHÀ\ 5kv \8cK\96¹´%\11Ƽ :C@wµ2Ú*¢A\ 6\f\16\ 5\12~\7fH°k\93¿cÄu¶\99½7L[\96     c\ 6\b±b¦±Ö'ËX\b#\175\ 2®C¯lÎÙf£\1e'm(\16Uæ[ì¼*÷\aÃ%\7f\9c\ e\8a)£>w²\19\99üTëKË\ 28\8d\8eé¨ÿ\8e\8c«K¦^u\14À\8b¤\80ÈÜ[Òê¾sêOýjÃ\1eú\16R¨÷ºÑTÑ®c±ÿ9q¯¯Ç:x\1e­jÇðj¨}ÿ}»Û\b8D\9eð\84\88Â"μ¸â©wh7\8f\17"þ¯!nÞ·"ò~î7¿ÁoV:ó\ 4³Ê`¡\93&úr
+ÇQ     \8d\b÷æ\82\ 6;¹|¯Ï\93q\ 5\9d\86É-¤3Íü\aýU5®òUwp©\9aë9½\8do£UooîÓÒã\88Æxe ¢8\8c\8a\1cF|\15æ"~Y")ô\84\883ÿó´_¤«p¥\8d\aî¸\ 2\8d9X¶\11\80\fi|½b0\93e\98\94έ»ÆÖýtÆ´Å©S\ 5\87\93áî\8d±Ü¾9dË#Ç24W2\ 1²cfl^\9aáV\9d\r\ 5\12×\17\14\10ú\93S\fÓËÍÍ\9eõð¾)Ü Ç)\97Ĺs\99ìdSÖj\93¯è©\123á\Ê\9cY¯¬\0\ 2Y\ 1ßaÎe\16»\9bþ\97øõ\8atzh\e\ 2q±X\ 1{\846?`\971q\11W ÎÛbÅ5õ\856G\87á\88\12XèÀ\8a\ 3a\9a\95Çв4F \92FѦ»t râ\90Æo+\8f\8aOh=~ÉO\14\1fP\96Òa'Ò2kÅr
+y¸áò\81`Ìû\97Ì\89a\14áJCeÓHU\8ar8û×\86\1dï\94#2U\1cy>ÂÀi¥¥\84G0°`'\9f&GÂ\9dÁÎpä¢h\119d¸T$é\94Úi·=\7f\17£\12A~\12 \8b\97'\ 1¢ç'ÁêÔ3F\8d\ 3××¼\82hNãì#í\ 5¥\18@^Á4õæ½ý£GÊÝÈñk\15w\8eæ6À\92{yG \83äÒè\91\8b+\81ÂTÒ\94&\ e*3¶\ 1 \17V<rX\1d\9a¦Dä¶6ªæÏü$ÀóÕ²\88f?~üR±µÄ
+ÎsV\9a\17®w\0qy] @\ 1\ 3ê¢%\0ëâ\95ÓRB\9f\a|í)~Þ\ 5Y\9aø\7fPy\91\ f\ 3ÏAÔÇ·\14×\ 6\ 3ahdGo_¾t%¡,
+\ fàá29ËÅó\8d\ 6(\97w\ 5!j\1a¦_¤®.\ 4ø\95å£ã»®\e\1cð\14    ø:q\17\82R\^m\88ÕÝê\ 2\81\1fÖ\ 5
+endstream
+endobj
+963 0 obj <<
+/Type /Page
+/Contents 964 0 R
+/Resources 962 0 R
+/MediaBox [0 0 612 792]
+/Parent 940 0 R
+>> endobj
+961 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pixel420.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 966 0 R
+/BBox [0 0 336 267]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 967 0 R
+>>/Font << /R8 968 0 R>>
+>>
+/Length 969 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c}\92Oo\141\fÅïù\14¾ÑJ¬\e'v\1cs,*\¡Ì\ 5µ\1c\96í¶\14í\14:\15\82\8f\8f3;Û?êì*\87$òo\9e3Ïï\1e"\12Ķ¦}Õ\87\93s\85\9b\87À¨\89\93Àß0Öáüc *\982$®¨R\81²b¦2îÆ\ 6Ã:|Ù1\14\15c¦y&\89_D\ f\ví \83J\1c EùI\89\r\8dx\1ezT\9a\83D
+JÒ\17J©Ú<ô\é\15t\ 1N\15#øæ®]\ 5CæÚlTRT?Ib\8cÍ"+\8aä\9d´\b\16\9aìËÅP3TïÀu\ fC\84äúV±rÞ\ 3]Lí\9fÆXcÂ\9a ø3ü>?¼\98\fÅ\ e3,®©`1¢FÝBibdbJuËóKæQh\82¶±\1an½÷\1dÏÓ¶êá´ó\18VP\14©\15ºë°M'A\89ngL\90\9a\97úpôaXöëw°ú1üê\97ð{³¼[ÃûïÇÝÏPª;m\9eØ\8a\99=KÝÕ\1ezhô\82Rk(°Ð\88µ0=ç7\7fvô×7\rnÏó1S6\19ßÇH>¶\ 5±ÿ©\95ñËO·ÿÖ\9b\87QÙZ\0}4\8bì\81á<\96/\8fâÛxyÜêg]øìë?ÓQÁk
+endstream
+endobj
+966 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (pixel420.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+967 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+968 0 obj
+<<
+/BaseFont /TGKBXV#2BTimes-Roman
+/FontDescriptor 970 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 333 333 333 0 0 250 0 0 0 500 0 0 0 0 0 0 0 0 0 278 0 0 0 0 0 0 0 0 667 0 0 556 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 722 0 0 0 0 0 0 0 444 500 444 0 444 0 0 500 278 0 0 278 778 500 500 500 0 333 389 0 500 0 0 500]
+/Encoding 971 0 R
+/Subtype /Type1
+>>
+endobj
+969 0 obj
+387
+endobj
+970 0 obj
+<<
+/Type /FontDescriptor
+/FontName /TGKBXV#2BTimes-Roman
+/FontBBox [ 0 -217 775 683]
+/Flags 32
+/Ascent 683
+/CapHeight 676
+/Descent -217
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/C/F/P/Y/a/b/c/colon/comma/e/h/i/l/m/n/o/p/parenleft/parenright/quoteright/r/s/space/u/x/zero)
+/FontFile3 972 0 R
+>>
+endobj
+971 0 obj
+<<
+/Type /Encoding
+/BaseEncoding /WinAnsiEncoding
+/Differences [ 39/quoteright]
+>>
+endobj
+972 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2743
+>>
+stream
+x\9ceVyTSW\1a\7f1\90ûp¡-i
+)\9a¤ußÑj\vÚ\8eZDÇ\8a\94}W\16     \10I\bkز\ 2AàKXÂ\1e\ 2a_\ 4\89\82\82\8aÈTQ±\9d¶V«u\eÑq:­µS\8f]æ>Îó\8f\99Ós¦ç¼óÎ{÷Þï»ßïû¾ßý]\16á0\87`±Xó\83%2qæÚ@¹,.Õþ¿\86rgQ\vçP\8bØ@Ëf\9bg·9."|[Ø\v`>\eæ;´-\9cgrÁ7^Ãm¯àâW        6\8b\95kêò\96§åeH\92\92³D+B\ 2ÃV®^½æ÷\91\r^^^¢ø¼ÿÍ\88v\8a3%I©¢eÌ\87B,\95§ÉÄ©Y[EÞÌj©TrP\94$ÍKKÎ\14Å%$\88\13ìf¡qRq\8ah\97D*IK\93+D+¼W\8a6zxlX˼6ûIdñÙ\99¢\17\91\8büä^"_Q 8)[\1a\97ñÇ\19\82 ÞL\95Gx§eìÊÌ\8eË\8d?(öO\96He¢-ËW¬\ãA\10\1f\13þÄ\16b   \11@\ 4\11Ë\89`"\94ø\90\88 ¼\89\9dÄ.b\ 3±\87ø\88ØGø\11\9d         'b.±\80x\8dpgòG8\10
+â<ë]Öà\9cus\8csh¶É\81íÐí¸Þ\11\1c\1fq>ä\9cA\1e¨\ 2}F\16\90jr\84üÑi\83\93Âit®+UêL\95\82\99zó<ëî\fÞ9Ãn¦ÞæUWÔ\19ê\81ì­UF
+i\ 3\82@­*ü0©ÄÉf\14^©l\0\e\89\8f¢ñSí\r\83@\9eí\94î\11Òb\ 4¾êü\bû¢\ 43\8a¬Ò4ÀY\12ç¡Ç1\17\97æïÝ-¸\83\8a\8d\91y\12mp\ 1\9fÙQ×Kmìeõ}\8b\9b¾eã
+*\96G¿á±\9a\16Ðîß/Ã.ØåÉoX\80]×ÿ@¿.TËy3\97\8b\ 3»·'$v\8e(\84òÉ\82¯à\1aùÃ\99\ 4γ\89Ð:˶²ð\97ÏسA³«x´<\973Yn)\82\95h
+\95ôbZáF¯À\19Úf½\ 5êùÐÒT;`¬\84:¨7\90­ô`.\1a/kR=¥ß®t°\eý!\82M:\9dÇa2\17_jE\e\8dª\ 6ø\86Ä¡\b¯À\8aéGÝíç*ùγëUcÔÏ#¬^L²g        *\94W\88\15\8e
+\8e^Q É\81BPV(«#\9b#j¢Á\v<¥û\82\89×\ 1=\aÖõo>\17xù£ïÄ?\ 1v\84\9fNOß#óZvìÜ#ó\ 4¾/\ 4Yc\8f\a\9f\95~\v\98Mâ=ßc'¼tjRqpD0\90b\96·~D2Y£e\96ü\96<,Ó\r\97]nÎàì\87®Ü\92Zj\11¯Ö`\82\8f\9atÑÂçÉ\b´Z\7f=É]\96\8fK\10÷@\vÚnP×ç$Þ\80\86\ euêN\ 2\89ç~\87\1dðRüªÏ?V\ 5Åd\84Ä\bo!½1D\91¬\ eÎçãUÛyý\17l§o\9cÝF\934;r»wt ­_à\8c\1f2\9dò\81\95õÍ\fÛD½Ékª¨54\0ÙU[\10#¤+\10D\14\17ïÕ0\1dPlF»+òÍ0Eâl40:ÑS][¢«\174«êõ\8d@v\9a\83
+«$.5kg¤ð;Tb\fÍNRûç2mñ\17hÅÓ'píñÜV\97\9f\9e¹r\93©L\ÀÃÊ,¤Ù\9a§Ü
+$½\14gpz«ª{\ 4x!\87Éa»Ò²\81ìâ\94âÅ\8eÏ{9Ü[¹è\86¾Q\ 5>äs\1f\ 4\9eZõ¶\12¦\8c\83­èO\95ª&¸NâT¼\14Ý\ 3\8b²a\v\93N¾®]c¥ÖYÕí.ç®`¯¯\¹kð\97ø\vÞa¼ÐQË)++,./?\f|=è\8cÚ*\92k©ÉήLw\7f?0Ü;hàà\83(áÅCC9\96L\90òcRäá\12ic{®@ÑUØ¡\9e"\vh\8fF\8e©®ÒÈd\87ë[\vMe\1dL1,úÞ\9eÃ-î·>»øÕDæàÇ6!M|&oVvA\ f\7fäHïé©~ÉÆ\ e\81\9d\e\17\ 3­Ô\16\8bªÉåÚ\fÞ5ãʵP\99\13¼\12Î~mýi!~BoDÜÁ|t¥´A\a\11$­A /Q©´iÙR\8d\fÈ\84\94£'\85\\v¾C/S¡ñÒ&%ì'é*ôþxø×Ç\86\9b{z\ 4££\8e\9e\88ë[Y6aµÕ\9fkb²î¯\9b
+¼H¹uº\¸\8fWÜså\9e¢ü>çå«4%J ³\8a\9bÆ\848\fÁdI\9f²3Û\16Ûê\ fäÚ\1d\91¾YÖ\9c\8eÎ6k{eyU¹IXV[^\ 3&²g }älOj\88À\ fÑëöå\17Å\8a³sT\128DrÃ}Çb¦ÇN´MN\v¸\8daU-\8a\13îG¡­aè83E¯¿Ï\ 3iI¡B\93©\92\17*\80L\96\1f\1d\15V"¸tÂ\86\17\8cÙ\e\1f¬Ô;f\16\ 6ÞoæH!§Y:F¿\8eÃÝîãù­=ýÍ\ 3\ 6¾\99Þ¨DýeuzP\81F\93\9d!-ÑkòÔ9*«\9büdÞQh\84¦FS¿\81\a\95µ¨\1f\9aÕG¢\1fÓKÜh\ eí%\8b×\15\1f*å+ñR3\92\1a«MæF«ð\ e\9f´¨RoÔ\83\9e\ f\87\ f\95Ù#a¨7ïSÖÕ\19\9có\88\8d×Î~À+1Æ)Ó\8a¢ÕüÔ"Ç\ 2Tm¨\ 4\13\90\85qÂçÍHúàÐ]ìö\fÏÁ\8bñ+Û\1e\vH\8aÌ\11\84:\f\9f±MÞ\9eø\80v¦ÙQ{½Â\ ett     ìu¸N9ö±ºn±©·±\a/Ê')3\10H\8f½w1úùüµ{¶Fmb\9d°:»FÞ\92×\ 6üîöÖ\8e\v>gÞ\8b\fÏI\8a\17FÄÈwÃû$ýÆ\9du\98}j¤ù\88MÐÓɤæ\12i÷{\15§\ e`dcQk°'/j[lê^\b\84ؾԩ¼ãÅ\83eÓ$\9eæ\14ýU×\971 ³ío\v\83\b\88Î\13K¢ãÓv\82\17I\v®oÆè\87\9b\970qR@ßÆkxõ·\8f\1e\9b\86\947n"_\92¶}\ 4O\1ccHûô\19.À,W®\14\1fÀc¼î2Ky7Ü\86OêF;/\ fئás8©:\9eÖwplSïZ\86Ì\16\ e×Â0¶¨N\aÞ/\18û^\91n[ñKƾ_¡l\82¯I®\94R8ô\98L=ØýJô\92\114ÊQ\19\8cY\82\97ªåþ      ëë\19ì7ÃÆ\eð\13ÞÉÓý\96a 'º\92|\84t$\82Ý:u\80þ¥l\85Ôékà*\89£Ð¯q\9f\8fËüx¿\0\92
+\89&£(¨\80\9ff/^¥¡\ 2ª\80\1c­)\8a\15>OAà£/\f(bì¥f\14P­k`ì\9dñ\11f×yæ!+^ðÌåö³w\19\8a½íúµ>ØQ\89j\f\rÆFC-ð;_\9c\89J\ 4Þ:í.»*êÌhOUQ\9dý\10Â\88K\85c\ 5/-+K.oÏêíëhïëÍêH\15¾ðÎú×\f\9b\114^5§ÞÐ`¨\ 1r NÅ\9céé\bBTjß\12Æ\95Ö\8c|+5up\9e¤\1e£ÃÆ°|±nW>#J­Lh\8b&Y\ fg°¯ýa·2JÞXQcWòîÚ\82(!]m÷¡\f*g|d\98Q¨QY\ fÃ$\1eB`¬©3\99º:F-C@\8eµ'3Ù\93!\bÒj\ 3í\91g\99Q Ai\81+$®Bý£\83\81\9cjIó\14ÒIÌÍ ¨( \98Y$7£t£Ì¨n\81a>\8eGxnÂå?\ 5\84§\a\84\bò¦$=!\10\ 3r\95§/y\93¹\ 4\84ç2\97\0\19W0xµ\98\8d\r\98ÍÂ\v©\18\9e,#]\9aÚ\95Ñw¤»«ïHz·LHÓ\ e\7f\18cD\88ºú\v\vï\1efÿFùð¾\18<5\r\97É\89äá\ 3É\99Y\92\94\8e\[µÉ`¨\16\98\8c\0\ 6 kªõE\87äI!\89vÃÙ%VÖøC6\1e\9fõäí\88\92¥'îß¹)y9ÐN@s\8f­|´ôDTwödJC³ÛÖOåCi73¿Ð~\ 3Oá×Æ¿õ\é½Òo»~\91ü¯\13\1cõ\90}\9cöáÝ\18ïï>vúÚß\87\9e\ 2v\ 2üzâ\8fï<\8b\1fOo\ f\eÐ\14¸ÝõíIîÝÞùçúm°\1c\16«=Óüä¾²$ï\0ÆI\85ÞZð\8b\vö\18våÆÞ§ßú\7f\14\ 2nÛï@¸±F\13\ 3ÅÝ\8e$E\9ehGB\95ªºg]ºY\9dOpã\13661p\82!.?19 HL£\17xX\83´Ó\99 c1ç2/Â9\18µØ\86.\9e?\8e\vH\1cç\81ߢ]\ 5¥é¼\99S´#-¦Å1¢Í\9b\8d\13pò)Ì~(tαR¡V\1clåôÏ}0¯¿fþü\a\17\10Ä\7f\0\9don\85
+endstream
+endobj
+965 0 obj <<
+/D [963 0 R /FitH 686.127]
+>> endobj
+587 0 obj <<
+/D [963 0 R /FitH 273.824]
+>> endobj
+134 0 obj <<
+/D [963 0 R /FitH 234.268]
+>> endobj
+962 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R >>
+/XObject << /Im10 961 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+987 0 obj <<
+/Length 1913      
+/Filter /FlateDecode
+>>
+stream
+xÚ\9d\18Ù\8eÛ6ð}¿Â\8f2\10+¢D]yK\9bÝt\v\14MS£\a\92>h%Ú\16*K®$'»ýúÎE\1d\8e6\ e
+\ 3Öp83$ç&½Õ~å­ÞÞ|·½yy\97¬R7\8dühµÝ­Tä¹Q\14¯¢$r\95\1f¯¶Åê\83\13x뿶?¾¼\8b\83)e\92¸\81ï\83\18¢ùþ\87×ﶷï×\9b \b\1cí®7q\9c8¿Ý¿¹ý\99Qwk?v~~ÿÓëu¢\9dí¯(ðÆ\93]Ì·°±\927~\fÈ\80å÷\a³Þøiêäms:\ 1\988¦`Ì©\+'_o\94Ó\9f\ 1j\85°5û²©\19>âê8Ù\11\19"\13ç\81¥0EYçÕ¹0\ 5ì\Ãv·\87\9d»\17°{/r>\1f\8cH*ÊOeQÖ{\161ìêsYô\a\ 6\9b\16\ f\a\aÛ(å¦aÈû?\98rO2{\94è9Í\8e¿$\ 1\81S\99\ fÛDZÝ>Â\ fÈø$\f\b\7fÆ¿F\10òm\1eú¬¬/¤v忲Ã/\16ìÎ\ f]v<U¨F\1cç(óÐ6Çliÿ§*«\r©\ 3´\ 32p7\81FÅ¢\9a\ f\1aÅAÛ\9cë\82\84\ 3Ýù\ 4GsI°Ònªõ\úÝ:        \9cs\vrÛcÓ\1aXF+_¶\9aÆ\ eí\93\94\1e¤\91S5´L\9eõ  \8eqY+¤\85ùè)]Óº\80oM\ 5d\9fÐü\861¤. \14á\91³k³#¬È\1eîM\1c1\80\9dÆQh=¼nz&\9a9kà§nì¥óã\90lí§lÔV\ 6lQ\f\8dÀw~'\8fBô¹£\93!8ðéWþ+\9fÁ¬.F\9cÇà®i\8fY\8fÖÐa0r\91bâQ1\88\ 3³/Xsbk8AÂaAÎÐ1bÐ\e\9b\13ý¶\91\rW;\ fÜSÎÂHtÖ\85\8bÑi\ f\ 6\r\96¥ V§r\13ç\8fÙ\86#Þp\ 3V\r:\83´:b_\86\0\19\a\0\vÂA{*(¼ÁÕî/\ 5Ìå[.Ã
+¨Ñíuê\98,GG:ðdÞ\80\ 6êù\86¾\1eC\83\9e\ 3\9a\8e\90®\10\8b\11¦(XÈF9\93ãj\1dÏâr\88d\13 4\13ýÑ\v½Î\18\1eÜ\95\fæ[\ 5\eòVí~ÅÀû·7«\ fD£]=KÈ\84Vèf,#«\97\8ec\1eiQXM¡SC\8eÙ\92'\86>\1c¨zbÈ<ææÔ\93=t¨H³\88.w<î-\87$P\9aëxÎÚ\fÝ<\ 1ÖZ(\ f\99©(ñg\9d¹\90We]¿èùb5­â%\13\0\96L\0_9\ 3AÆ2\8cÌd\ 3ø\8a\rT<±\ 1\fF\e¨\ 4Ò\elÿ\8a\19\80\fʦrÂ\vK8¢ß\bRÕýb0³\13\87éÔ\89aDN\8cØQ\8dA\14"uÍ\13\ 3\1ff̶\13¶Á­Ã\84Ý\1aqäö-ì®9\92ºy\1a\ e\8c#Lí\95A¨c|Þà ¥bÖ1\ 5æ%V1­ÜÈÖPÅKÑ\8e
+\ f¢dÜLÄ
+G\9cä\9dhÈ;x°\18ktY  \e\9f\fxZs\84\9aÈ\95c\10×ñ\1cí8³®\84\98\v\7f\10Y͢Υ
+ÇT\85\93t´w\90zWc\ e\19´\e=gi\ 5    ªfIý\81Ì\bô9ø8F\82§)x\10%%̳Á\838"\aÔ$u!\v\93Â<Å\ 5Q\fº\ 5l¶ÇÖa1\.C\84ê\7fÃ_\ e\11¬ïl1@\rRqzÇ\93b1À\8c\95\ 2\ 6¤24\82\11Þ«j£Ö2^VÛs­Åk\90­¤Â\95DzÊZF\9cZi#L×1\86T§°ºVPIm\97E\9d\84Â\ e\8fT¬¬w\ 1\0\120K\v;\9d\16\b3\91?\94$¤´%II#¦\92!.y$ý!¤\1f:Éfé(¦Î\85\89\88\9f\86\ f\8dl\93\80 7        ÔÏúTð\10)\84¡ó'\8fÇ\94Aâ:þNë\9e\17\1erÊ©yÐ\88ÜiC\81ckèos©PÚ\vüN\v\1f"Z6\85Mf;Æ\8aK\85Óæ#\9cF!Ì\u§0Y¨|äN\92+¹x±4±?@\99Í\8eÖ\80\v\19ll÷Q\94\8fUË°3Ø°UC,\ 2$\87äÁ\82\82\94äLt\9fÚ,ðXç\93\8d\1d.q®×\9c¯}o¢*µ\90{Å<£
+õ7¨P£
+\9f+Y\1a2\vwZ6h\0\98vZ\12s:\99\15©Ð·E
+       .\b\a9cÑÒÉè\93$K\96\9c5¹:ù\9aONz\8a`±7\v°'kxV²\1eA\86§Æõ¥;\v\86î,\18»³\17\Q\86Beo8\0Ì
+\95\1am\8b5u©õ\1aë\967­[±Ô-Oî9^|y_\8cÈÀWí
+\8cÔ\8d\Ö(Ø\10\1a\17fð0Ê\1fC\ 4\1c"ÀK!â\8d\89\84Gó PcPx¶\13\aà¹Æmtw¨(YÕ5¶Þ|½@\19fø¦Cÿ\9fòr;æä\16³'ZûÐ\9c«\82áñ\8d\ 1ÛèÁ\14t]E\14åÏ\bïp Rî¡d¦(1P@?unD0e{ë5´\92\áù="òí;\ 5@|«ü²\94H~B\ 3ùIB\ 6\8aÉ@8Â~\9f¾Ci¢\91D,\95\12\8fZ\13Dó.\92\84=ì     ê]V!bhU|¸e³K Õò\8aöÝ\84\b\99\9bà+\v»É\82O°y±Ûydï'\ræ½´LóZ\92¤Ó\82\9d¤|\ 5\1d\1a\9b\1aé­$xÓiÖ\84\ 1]\89p^\8eÑ>Í$/ \1eä^½\87\87ÓDáÛ'
+@KáÇ×\rî¬\ 1«åQ\8b\8cúìoûÊ\ 1\1c9?\88\0Ô¯é&Åbºó\80>d½\85\ 4eíÜñðÜQë\ 3P¶¬}öí\86b\1eBÇƺ;\v ËïíV\82O\ro\8d*\8dÜÔS«üxóÏ\8dç&¾öC"\99Â4i9\ 5ñòþ¨ÔêMsó\vüìÜÆ\8aÝLä>ûΩ¢Ðõ|%¯P\9c  \ 2)l\f^\81¿Ç©ó®|4\15#çÉ\ 6\14[`tò\9cDúx10|Ï"7 \8f\0"~EcØ6\14j\9a%\91æËçLD\ fusÁ\12\14\ 6\1c\8\1a[Pl½ñ%ð\8a\ 33\97¬;
+endstream
+endobj
+986 0 obj <<
+/Type /Page
+/Contents 987 0 R
+/Resources 985 0 R
+/MediaBox [0 0 612 792]
+/Parent 940 0 R
+/Annots [ 973 0 R 974 0 R 975 0 R 976 0 R 977 0 R 978 0 R 979 0 R 980 0 R ]
+>> endobj
+981 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pic_even.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 989 0 R
+/BBox [0 0 417 168]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 990 0 R
+>>/Font << /R8 991 0 R>>
+>>
+/Length 992 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\8dTMo\13A\f½ï¯\98c"\113öØóÑ#\12 q\82²·¦\87(\r\ 5Ô\b5\15\82\9fÏ\9bìnº   Ù´ÚÃ$;Ïöóó[?:Oì|}ús½mÞ^'wÿÔ(%Q1÷§Ùß»ë\8f\rçD>GgQɼ:\ eJ\1c3ÎDE\8bÛm\9a¯\a\90r¦RâyPJ\85²¨3óä¹\82\8cTp\8a\92?Á<'ú\1f3\14cI\81ø\ 5F\f\14ÅS\90\908"½³ \14RÙ_\86=³Q¦\ 1\14\8a§h2\ 1Ê\96+\97Ë\99zÐÅLb¦\84\11\1ce\92ó\98£D§\98X\8cJ¾Ìh\0½\8a\11fÀä'ª\r\18_
\ 4ë¾ØQ\9e)FG\89NA7p#ÅÂî\16\1e½k
+©æjZf\95ý°\85)fu%\0\86ÿI\84\14\83»¨g¯³HF\11'
+ÓÁl)\1aÈC:ö$<\18J`Å\9c\ e ³\86âlL\85G sö\15ò\9a\ e\16O!\90øàJÁû¢\97;\94\80b{Ï\e\99"(\ 6J\90]9\91¤é\ 6\11ºp±ó_\8cXôd#S©\1aE9æõ*Ð$ù*KeëSG#cÆ<°Ï]p·xv÷ÍcÃÝïþXoÝ»\16\8b*;L3&\8cµýÖt\v\8c\1dCwNÉ\ 5°\8b\9c\»mfD4o\7f6\vÆ\18\r\82waâÚ»Ñ\1dÖ\r\ 6\81~`\98\10Çwì\15\9ae·@\87Á î讲@\8b\1cÐ\ 5X,ê|\93\0*dÈ\ 6äÍl9óoür>_°¦\ 2\7f\1d^ܶ\9f \ 5v öÜ\ 2\1fg       Ð¤&\1f\0(P\aÃ¥8,¯RÍR¯?ÿø»yx\1aÊ\8fDèªêÙ\ 61iÏ°gwæÓ&2vz\88}\13\86/Ïa\9c\84>ìVÛÍ\95[\7fßýÚ®Ür¦Wr\85\9e6\1dË^Zh\91ÑM   \93A2
+\92êáP;ÏAC\1eÇ<üÞ®*ä}Û|Áó\ fBF_ì
+endstream
+endobj
+989 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115428-07'00')
+/ModDate (D:20090924115428-07'00')
+/Title (pic_even.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+990 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+991 0 obj
+<<
+/BaseFont /AXDXXM#2BTimes-Roman
+/FontDescriptor 993 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 0 333 333 0 0 250 0 250 0 500 0 500 0 500 0 0 0 0 0 278 0 0 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 444 0 444 0 444 0 0 500 278 0 0 278 778 0 500 0 0 333 389 0 500 0 0 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+992 0 obj
+609
+endobj
+993 0 obj
+<<
+/Type /FontDescriptor
+/FontName /AXDXXM#2BTimes-Roman
+/FontBBox [ 0 -177 775 683]
+/Flags 131104
+/Ascent 683
+/CapHeight 662
+/Descent -177
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/F/P/a/c/colon/comma/e/four/h/i/l/m/o/parenleft/parenright/period/r/s/space/two/u/x/zero)
+/FontFile3 994 0 R
+>>
+endobj
+994 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2332
+>>
+stream
+x\9ceUkXSG\1a>1$sl\91nISHÑ$½Xu½\14©® ¶¶ËÅv¥\94\ 4\10\14\91\8b\ 4\12IH  ×\M\82À$\Â-\84\86«DQAë¢Û\16\14ÖÖmµ­Úv¥în»mÝ®ën·sØñÇ\1eh÷Ù\1f}\9eóÌsÎ|ó½ó}ïÌû\1e\ 6\11°\82`0\18\81É2\85D½Y¬Td\17.}o¢Â\18Ôê\15Ô\1a&ı\8b\1d\8b{Xk\88øNæ*\18È\84\81\ 1Ý«WN\a£÷\1eG\9d\8f!ë/\b&\83Qæì\8fVªÊ\8beùR\8dp}\8a8uÃÆ\8d\9bþ?³5**J\98Sþ¿\880F¢\96å\17
+\9f§_J$r¥J!)Ôì\12FÓ«årÙ\11a¾¼\%U\v³ss%¹Kiû³å\92\ 2a\9cL.S©\94%ÂõÑ\e\84\11áá[7ÓÃö\ 4\99"G«\16.W.LPF       ã\85bI¾V\9e]üó\bA\10!Êâ8µ6»ì\88$Q*\93+¶    w®ß°iKx\ 4A$\12IÄ:"\99ØOü\9a8@Ä\10qÄVâuâ7Ä\eD\ 2Á%\18D\18±\92x\84XE<F<Np\88P\9a6"\80Nò3Ö0άX»â
+SÄ\1c\ e \ 3L\ 1\92Y\8dìWÙz¶\89}\96ý\1f°\a\18\81\e`RDU\aQÕæA*b\901ô%jÿ\92\89ê¨,.~2|#æã°¯\9fGÁ(øÞ¿\11\1f\85¼ð-~B`Pr\17.oÄk0ëðÞWróúN\97\b\94\97*?\84×Éoß\9a¿Î\ fBw¡\9bzÉ˸¹ÀtROqÛë\9aím\90ìo®Ì\14à:\0\ fX­û\8c¤\ eYÝ`o]\85\eÎ\90H\vF'§}\8dÍUæV~\87¾Õæ\82d\9fÛ38Vâ\95e\17jb\ e
\1cûµù\86Ä2^\10õ;Ø\85æΠæSe]Á\7f\7f\10Â\91RjTÉE:\r0î*×í\82$^\8b\8aÙ\83\r\8d>>ZÍF,Ø£ól%ûÙÕèYÖÃA6çV\19øØæÒÃXòa,\80\91\9e\f\8du\81\97ëõíð\ 6\89
+ÑZð9ôèÚv\92A\14ÏÜcôR[¼\86\9eà\8bó(êÃ\10Î&ô\at\8d{\1c­f\99Ø55ǬµµÇ!Ï\ 6Í\ eS\ 3Éñ4iµõEa»ÅiÑI£G¾H\17Ì\1e\1d/õ¨¡\9c\97Y L\93É]=eü\92þc½\86\19²\12\87»ØÎ\96z\aÍ\ e\19¶×ôÚh\0Û ïxgØ­«³\1fN«ÇÞô\v0qUÙ¡ë\87>Þé\91Áó3ò\88^þÒyÍ\8a½ÔN\8f¾=øú\ 2\8a[\báx(õ4·\8a\9daj=/@÷p\ 4à\8cU\80ùê63<@b#\80Ê*½Þ¤ÒÊ\8d
+Hæ\16\9c8+àxЧøy=¸PÝ®\83\19$n\0»/¤}tr¢ÃçãON²"\ 1'¾¾fÚëo½ØN³\9eh\9e\11ÏR¡}ÁïÞAë?\ fá\9c£\12ÞçVè\8dU:Hj¬íS\ 2\94
+४!]\9fÖ\9fÕ\95\bÉͯ\1e\8c×xK{ûº½=õµ\rµNAMsm\13t\92¾Ñ\9eÓ¿õ\15¦ð\13\0ÞòF\85%K¢-ÕËàQ\92\93\16?\9597u¦ûÒ\1c\9fãJmè,9\13v\ 2\8d\9f¢Cø\85;\(¯:VbTë\95ÇJ )U\9e\98\14Ô\ 3\8c\1f­\9a¢Oª\1a\17Ý\f4ò$Êp³å°´C>\85\9f@i¡wP`\97o¸cÔÎsã\b\1d\18®i±A=4\1aµÅò*\9b±ÜPª÷\86\96\9f\80.Øîr\ eÛI7>¢k\ 6ðÃ0rè\eü\(fã(E\8eÙz´\9a§CkÝ@ilp5:Ý.¯àSôØWXXosØ \8d\aË­Ç\8fÖ\90K\Ý XC\8cþ[Lê\19\14ÎM\8fÍW\8b!\19¾ï3\ 4þùÎõÏý.S^\8b QÛ¤ì,ï\86¼\81\9e®ÞwcßÚq0­4?Gp S¹\17î&ñ\93\9fnAÌs§;Fü|_\1f]þåeÜ\ fPá(\ 2~\ 6µ   ErÓ÷d\15î\83b\985T8S~Ê:V3G¢9¶å=óPñ¨Â\9fÑ\9d
+\ fÀCå\12Ù¡\1cU\f\8c"1ÿÆv\ 4¾ýä2"Îòñm´\89ÛzûÄÉ98\aû\94®mä\8fÂê9\8d¦OÒºÿ\0U"F\bG\8e\ e£)î@\8d§v\0Þ\86o·Lö]\19õÏÁ÷áYý)ÕÐ\91©m\83\9biÁyØ\1c\ f­*K\8b\19F/«j\87żÇú£ªv×éÚáG$GN\95\ 4ø\9cN\1f
+\9b?ôÜ/\13\ f`Pª·;4Kw\99ö\8b°·\19\1f\84\ 5\8aîqÏ\9e\1föL@rº??V\80\ f\ 2¸×l\10ÙhÏ\90ºAJ\8b­     ~@¢tð}öÛ;\13³ÕofðÑ\f¨ª\93\19\8b-I\95<\95\85U   êíu°\ 1\92\93M\96,ÁÃ\ 2\0cmÇD\16:_î\ 6¢Fs\e\9d\1f\84Fè]\1fu\8f{Ѫ\aÁ·\1fü\8aVÐ÷(zÉ÷^Hfé@\93½Íá²7C^ß²oé\0\8c6\9bâ\8eÓ\18f7x½ÁÒ²d\14\bp¨4TÂUi4Je\8ffp¨·ghPÓ[(XFg|·ÀìZdr\eÙ­ö6{\13$G[ô\87\ 4\ f\8b\0\eâ«h(\93\eÄ×\e[à;$õ\r8îH­\90\98ã*xA\8b]tik.1î. ø¥\87ÙE=ÃuÕ5Ù[!9Ð\\99\8dK\18º¤Z\1a£Ø\rö;t­p\82\0:\9aZ\9cÎþÞIÏ8$§z¤4{
+\0\93L&ñRå\1a7\10Ûu\1e8O¢\ 60<9Öy\1e\923\9dªH\ 1Î\aPl±\88¬ô"¥\e\149\14\ eC'\9cà¡\1c\80\1eɽò²(­H\94Â/\9f\91ùR`&Tê#ãÉO\80Õ\91V&3%ëxËÊCë®Ò\9e\1f\8cÎÝ~ùV\bçkJN[òZJ\94ÉÆ×\1e\8aXûР   ¼\vpþq\vízÀƯ]åb+\eYÑ=V\10ª£¹2!&²#&\ 3­¦2¹\8aâ"ya\7fñÐÈ@ÿÐHÑ\80B\80qÀÏæè\9fÌâs^Æ\85»Lta1\92ûjº¢(/#f\9bt\1dÄ+!æ\9cÜðçµgÒ\a´\97
+Ú:Bwý^9®úD}Ít\13Þ\87ß»þè\9b\1f\9c\1föß\98%\7f\ 2Aéw\99§p,÷ã\vÃ\ 3'Ï_ÿÓø}\88VBôDÞß^|\90s¡¨'uÔX\19úY¼O:øJßk­{à:ø¬!R\95 \8cWäG\8bh\90:\9b·ò_Á(|"\84\93u\a?ͽ6vn\ e^!§¥\13\87¥j\8d\8cÏé.è-ó7:íöF>'Ëá\84Ð\1eÖÔh³\14(óRòèNêLt\r\8fßÿyã4±ú\81Åà\ 1Fß=äºÇDNºÓd\98]\91'\15%I0Xn\951\86\95t2ó¢z\16^\84\93\1eÿøì;§\10    Ñ*\12e\87£§q\b¿º\88»p\ e³°\ 4K2\85Û·gþ\80r\91ô\1cbÞ]Ú\0Þ¤z?f ¯î2)%ZÃ54ä\89\rÇ\ eC\1e¶°Ñn\14ó\97¯'nÂÛ¼û;o=\9b\9cª=\92Ç/\90é
+*bº«BO\7fç\1fý\0\92\v\1d/elÙ\11!ÀqXÄ2RO\81 R/µß\8b\92½ìáG¾xt¸)0ð\8bÎÀU\ 4ñ_²`\91"
+endstream
+endobj
+973 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [459.007 570.991 473.73 582.946]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.4) >>
+>> endobj
+974 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [470.438 547.081 485.161 559.036]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.5) >>
+>> endobj
+975 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [231.587 511.215 246.31 523.171]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.6) >>
+>> endobj
+976 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [426.394 499.26 441.116 511.215]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.7) >>
+>> endobj
+977 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [395.504 463.395 410.227 475.35]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.4) >>
+>> endobj
+978 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [211.384 439.484 226.106 451.44]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.5) >>
+>> endobj
+979 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [297.797 415.574 312.52 427.529]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.6) >>
+>> endobj
+980 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [319.212 403.619 333.935 415.574]
+/Subtype /Link
+/A << /S /GoTo /D (figure.4.7) >>
+>> endobj
+988 0 obj <<
+/D [986 0 R /FitH 686.127]
+>> endobj
+588 0 obj <<
+/D [986 0 R /FitH 176.976]
+>> endobj
+985 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R >>
+/XObject << /Im11 981 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+997 0 obj <<
+/Length 352       
+/Filter /FlateDecode
+>>
+stream
+xÚ½ÒÉNÃ0\10\ 6à{\9eÂGû\10×Ëx   7\10\r*\ 2\a\80\12S"Ѥ´e\11O\8f\9b¥JE7U\bå\10{2þí|2C#ÄÐYp\92\ 4½ØH\14ÑH\v\8d\92\99¦VGH[M¹0(ÉÐ=\ 6
+\94\84ÆX<\1cÜõ/H(¥Ä1\11\16_Ý\\1e\13+qrK\1e\93ó^l;Q¾\89\1a\88üFU\88ä\8b\96\805[oz÷\93\80û\ 1C|y\16%\fåR t\1c¼\ 5\8cZ\ 1BU-Ýqõ±]Ù\14z\831\17è´\f®ýÓnÐö\84m|Øɯ@ì\8a\87¥Z\ 1\82HQ¡xý+q>z\9fº\9a\ 1¨:"!\80ÂÃü˽ÖÅ´\9cNÝlBBOT\16\99+Ò¦û3\9f¿Ô#÷A\84Á®¨g\93<\9d/#Ë\aÆåÌÍ\173ÀOEÖ\94«¸,[³b\96\7f»½t·(Kà\9eS\1f¦,w+wò\7f+sF¹ÑH2_\ 3½NY\1f¤¼Ñ\fV\94å\1eÊð'Ê\iª\ 4?L\19v+wò7Þe.<'¬½Ëæ\9f\94·Üþ½\95½î\ f\9bt\18"
+endstream
+endobj
+996 0 obj <<
+/Type /Page
+/Contents 997 0 R
+/Resources 995 0 R
+/MediaBox [0 0 612 792]
+/Parent 940 0 R
+>> endobj
+982 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pic_even_odd.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 999 0 R
+/BBox [0 0 417 168]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ColorSpace <<
+/R9 1000 0 R
+>>/ExtGState <<
+/R7 1001 0 R
+>>/Pattern <<
+/R8 1002 0 R
+>>/Font << /R10 1003 0 R>>
+>>
+/Length 1004 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\8dVMoÚ@\10½ûWì\91He²3û99Vj+õÔ&¾%9 BÓV¡U@Uûóû\16Û`\82\r\96\ f\vÞ73oÞ\ eoy5\96ØØò´ër]]ß&ó¼­<%ñ\12Ìßj·on?U\9c\13Ù\1cM\88\9e\82õ\86\9d'\8e\19k"õj6«ên\ fò\9cI5\ e\83RRÊâM\b\96,\17P /XÅ\93}\839$:ÅH\b\9e@28!\97tWÄÉq­\ eãÔR\f2\8c\89\1aHóq\9e\1d¯\ 1ÐQ¢· {¨CQÙ<B³§JÉû\DdöB\11\9a   SÌÞ¨\ 3\fß\93\byt×\ 67Q\aíY$£\88\11\ f\11Ð|\8a\ 1äA\94-        w\92\v¤Éi\ f:\96<tç\12\98\94{ S99\vY\9fö\92'çH¬3ªx¯þ|\87âP\8cý.qð\b\8a\8eR0ì9\91¤ñ\ 6\eî\11º°\86áq\91\10-\85Þ\11z\1f(ÊD^¥ãBĦ¦BV%î\88å1b\93jv³\ 5\11\99ìùÙ:¼\1d\e\97C&\88wv¶:ÐÙ)\ 5iQÑ\84\9ftf\ep\9al6Ï\a\16\ eg\Ô8\8aÝÍÈ7üôÕ,·\8d!\ßf³]þ\9a\168\ 14άӰ\1f+\13\88M\88»\8c\19¥å\14c\82Á\1c·\96aZSâ.c.Ò\1aw³ó´ÎÅ]Æ\1cì\9dqääFì}\84û>\166Qê\føÔ0ùI\81\13@wí]\ 6\157\9fÛe¹6ïk\14ÇW8rL°æ\1a9\e\88ax''(\83Î"'S¯«\19\11]Õ?«9Ã\8aK\8bM\98\98ú©·\a=a¦P\14¦\ fµz{l\vËlæ°\15\17`\90½½\1d\r\98\19\15\8bI'\ 1V( \1d ÷³\87\99}g\1f®®æì\93â\92Ø¿x¬?Ãôp±âò\9ccÀÔaòKö\ e\80
+E\13V5\82µ8~Ùþòãßêe»¯ß\93¡)ë\a[\84Ê\96!o³æ\9362þ*¸Ø¶\11à\12\ 66\1asKéãf±^Ý\98å÷ÍïõÂ<Ìü\8dÜà0\16ÛUóU7\9b\98Ñ\8fºÑ é\ 5\8a\é=;ïr?æåÏzQ \1fêê+\9eÿ¾êÜÜ
+endstream
+endobj
+999 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115428-07'00')
+/ModDate (D:20090924115428-07'00')
+/Title (pic_even_odd.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+1000 0 obj
+[/Pattern/DeviceRGB]
+endobj
+1001 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+1002 0 obj
+<<
+/Filter /FlateDecode
+/Type /Pattern
+/PatternType 1
+/PaintType 2
+/TilingType 2
+/BBox [ -2 -4 10 5]
+/Matrix [ 1 0 0 -1 -27.4 197.8]
+/XStep 8
+/YStep 4
+/Resources <<
+/ProcSet [/PDF]
+>>
+/Length 71
+>>
+stream
+x\9c3Ð3T0\0A(\9d\9cËUÈ¥kd  kb `\b¤-\r\14\8aR\15Â\15ò¸Ì\15ÊÁ2¦\ 6
+¹\\86\ 6@%\86\ 6
+9\Á\10å\860QS\88\17\0#\92\11c
+endstream
+endobj
+1003 0 obj
+<<
+/BaseFont /AXDXXM#2BTimes-Roman
+/FontDescriptor 1005 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 0 333 333 0 0 250 0 250 0 500 0 500 0 500 0 0 0 0 0 278 0 0 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 444 0 444 0 444 0 0 500 278 0 0 278 778 0 500 0 0 333 389 0 500 0 0 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+1004 0 obj
+686
+endobj
+1005 0 obj
+<<
+/Type /FontDescriptor
+/FontName /AXDXXM#2BTimes-Roman
+/FontBBox [ 0 -177 775 683]
+/Flags 131104
+/Ascent 683
+/CapHeight 662
+/Descent -177
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/F/P/a/c/colon/comma/e/four/h/i/l/m/o/parenleft/parenright/period/r/s/space/two/u/x/zero)
+/FontFile3 1006 0 R
+>>
+endobj
+1006 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2332
+>>
+stream
+x\9ceUkXSG\1a>1$sl\91nISHÑ$½Xu½\14©® ¶¶ËÅv¥\94\ 4\10\14\91\8b\ 4\12IH  ×\M\82À$\Â-\84\86«DQAë¢Û\16\14ÖÖmµ­Úv¥în»mÝ®ën·sØñÇ\1eh÷Ù\1f}\9eóÌsÎ|ó½ó}ïÌû\1e\ 6\11°\82`0\18\81É2\85D½Y¬Td\17.}o¢Â\18Ôê\15Ô\1a&ı\8b\1d\8b{Xk\88øNæ*\18È\84\81\ 1Ý«WN\a£÷\1eG\9d\8f!ë/\b&\83Qæì\8fVªÊ\8beùR\8dp}\8a8uÃÆ\8d\9bþ?³5**J\98Sþ¿\880F¢\96å\17
+\9f§_J$r¥J!)Ôì\12FÓ«årÙ\11a¾¼\%U\v³ss%¹Kiû³å\92\ 2a\9cL.S©\94%ÂõÑ\e\84\11áá[7ÓÃö\ 4\99"G«\16.W.LPF       ã\85bI¾V\9e]üó\bA\10!Êâ8µ6»ì\88$Q*\93+¶    w®ß°iKx\ 4A$\12IÄ:"\99ØOü\9a8@Ä\10qÄVâuâ7Ä\eD\ 2Á%\18D\18±\92x\84XE<F<Np\88P\9a6"\80Nò3Ö0άX»â
+SÄ\1c\ e \ 3L\ 1\92Y\8dìWÙz¶\89}\96ý\1f°\a\18\81\e`RDU\aQÕæA*b\901ô%jÿ\92\89ê¨,.~2|#æã°¯\9fGÁ(øÞ¿\11\1f\85¼ð-~B`Pr\17.oÄk0ëðÞWróúN\97\b\94\97*?\84×Éoß\9a¿Î\ fBw¡\9bzÉ˸¹ÀtROqÛë\9aím\90ìo®Ì\14à:\0\ fX­û\8c¤\ eYÝ`o]\85\eÎ\90H\vF'§}\8dÍUæV~\87¾Õæ\82d\9fÛ38Vâ\95e\17jb\ e
\1cûµù\86Ä2^\10õ;Ø\85æΠæSe]Á\7f\7f\10Â\91RjTÉE:\r0î*×í\82$^\8b\8aÙ\83\r\8d>>ZÍF,Ø£ól%ûÙÕèYÖÃA6çV\19øØæÒÃXòa,\80\91\9e\f\8du\81\97ëõíð\ 6\89
+ÑZð9ôèÚv\92A\14ÏÜcôR[¼\86\9eà\8bó(êÃ\10Î&ô\at\8d{\1c­f\99Ø55ǬµµÇ!Ï\ 6Í\ eS\ 3Éñ4iµõEa»ÅiÑI£G¾H\17Ì\1e\1d/õ¨¡\9c\97Y L\93É]=eü\92þc½\86\19²\12\87»ØÎ\96z\aÍ\ e\19¶×ôÚh\0Û ïxgØ­«³\1fN«ÇÞô\v0qUÙ¡ë\87>Þé\91Áó3ò\88^þÒyÍ\8a½ÔN\8f¾=øú\ 2\8a[\báx(õ4·\8a\9daj=/@÷p\ 4à\8cU\80ùê63<@b#\80Ê*½Þ¤ÒÊ\8d
+Hæ\16\9c8+àxЧøy=¸PÝ®\83\19$n\0»/¤}tr¢ÃçãON²"\ 1'¾¾fÚëo½ØN³\9eh\9e\11ÏR¡}ÁïÞAë?\ fá\9c£\12ÞçVè\8dU:Hj¬íS\ 2\94
+४!]\9fÖ\9fÕ\95\bÉͯ\1e\8c×xK{ûº½=õµ\rµNAMsm\13t\92¾Ñ\9eÓ¿õ\15¦ð\13\0ÞòF\85%K¢-ÕËàQ\92\93\16?\9597u¦ûÒ\1c\9fãJmè,9\13v\ 2\8d\9f¢Cø\85;\(¯:VbTë\95ÇJ )U\9e\98\14Ô\ 3\8c\1f­\9a¢Oª\1a\17Ý\f4ò$Êp³å°´C>\85\9f@i¡wP`\97o¸cÔÎsã\b\1d\18®i±A=4\1aµÅò*\9b±ÜPª÷\86\96\9f\80.Øîr\ eÛI7>¢k\ 6ðÃ0rè\eü\(fã(E\8eÙz´\9a§CkÝ@ilp5:Ý.¯àSôØWXXosØ \8d\aË­Ç\8fÖ\90K\Ý XC\8cþ[Lê\19\14ÎM\8fÍW\8b!\19¾ï3\ 4þùÎõÏý.S^\8b QÛ¤ì,ï\86¼\81\9e®ÞwcßÚq0­4?Gp S¹\17î&ñ\93\9fnAÌs§;Fü|_\1f]þåeÜ\ fPá(\ 2~\ 6µ   ErÓ÷d\15î\83b\985T8S~Ê:V3G¢9¶å=óPñ¨Â\9fÑ\9d
+\ fÀCå\12Ù¡\1cU\f\8c"1ÿÆv\ 4¾ýä2"Îòñm´\89ÛzûÄÉ98\aû\94®mä\8fÂê9\8d¦OÒºÿ\0U"F\bG\8e\ e£)î@\8d§v\0Þ\86o·Lö]\19õÏÁ÷áYý)ÕÐ\91©m\83\9biÁyØ\1c\ f­*K\8b\19F/«j\87żÇú£ªv×éÚáG$GN\95\ 4ø\9cN\1f
+\9b?ôÜ/\13\ f`Pª·;4Kw\99ö\8b°·\19\1f\84\ 5\8aîqÏ\9e\1föL@rº??V\80\ f\ 2¸×l\10ÙhÏ\90ºAJ\8b­     ~@¢tð}öÛ;\13³ÕofðÑ\f¨ª\93\19\8b-I\95<\95\85U   êíu°\ 1\92\93M\96,ÁÃ\ 2\0cmÇD\16:_î\ 6¢Fs\e\9d\1f\84Fè]\1fu\8f{Ѫ\aÁ·\1fü\8aVÐ÷(zÉ÷^Hfé@\93½Íá²7C^ß²oé\0\8c6\9bâ\8eÓ\18f7x½ÁÒ²d\14\bp¨4TÂUi4Je\8ffp¨·ghPÓ[(XFg|·ÀìZdr\eÙ­ö6{\13$G[ô\87\ 4\ f\8b\0\eâ«h(\93\eÄ×\e[à;$õ\r8îH­\90\98ã*xA\8b]tik.1î. ø¥\87ÙE=ÃuÕ5Ù[!9Ð\\99\8dK\18º¤Z\1a£Ø\rö;t­p\82\0:\9aZ\9cÎþÞIÏ8$§z¤4{
+\0\93L&ñRå\1a7\10Ûu\1e8O¢\ 60<9Öy\1e\923\9dªH\ 1Î\aPl±\88¬ô"¥\e\149\14\ eC'\9cà¡\1c\80\1eɽò²(­H\94Â/\9f\91ùR`&Tê#ãÉO\80Õ\91V&3%ëxËÊCë®Ò\9e\1f\8cÎÝ~ùV\bçkJN[òZJ\94ÉÆ×\1e\8aXûР   ¼\vpþq\vízÀƯ]åb+\eYÑ=V\10ª£¹2!&²#&\ 3­¦2¹\8aâ"ya\7fñÐÈ@ÿÐHÑ\80B\80qÀÏæè\9fÌâs^Æ\85»Lta1\92ûjº¢(/#f\9bt\1dÄ+!æ\9cÜðçµgÒ\a´\97
+Ú:Bwý^9®úD}Ít\13Þ\87ß»þè\9b\1f\9c\1föß\98%\7f\ 2Aéw\99§p,÷ã\vÃ\ 3'Ï_ÿÓø}\88VBôDÞß^|\90s¡¨'uÔX\19úY¼O:øJßk­{à:ø¬!R\95 \8cWäG\8bh\90:\9b·ò_Á(|"\84\93u\a?ͽ6vn\ e^!§¥\13\87¥j\8d\8cÏé.è-ó7:íöF>'Ëá\84Ð\1eÖÔh³\14(óRòèNêLt\r\8fßÿyã4±ú\81Åà\ 1Fß=äºÇDNºÓd\98]\91'\15%I0Xn\951\86\95t2ó¢z\16^\84\93\1eÿøì;§\10    Ñ*\12e\87£§q\b¿º\88»p\ e³°\ 4K2\85Û·gþ\80r\91ô\1cbÞ]Ú\0Þ¤z?f ¯î2)%ZÃ54ä\89\rÇ\ eC\1e¶°Ñn\14ó\97¯'nÂÛ¼û;o=\9b\9cª=\92Ç/\90é
+*bº«BO\7fç\1fý\0\92\v\1d/elÙ\11!ÀqXÄ2RO\81 R/µß\8b\92½ìáG¾xt¸)0ð\8bÎÀU\ 4ñ_²`\91"
+endstream
+endobj
+983 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pic_odd.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 1007 0 R
+/BBox [0 0 417 168]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ColorSpace <<
+/R9 1008 0 R
+>>/ExtGState <<
+/R7 1009 0 R
+>>/Pattern <<
+/R8 1010 0 R
+>>/Font << /R10 1011 0 R>>
+>>
+/Length 1012 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\8dUËnÛ@\f¼ë+xt\80\9aYr¹¯\1c\v´\ 5zj\13ß\9a\1c\fÇI[Ä-b£h?¿³\96ì(\89%\ 5:¬¤\1d\92á4ûH\8e\85\½ºuµiÎ/\13Ýï\1a㤦\81þ6û}ºüÔHNìr¤\10\8d\833\12o,1cM\¬ÐvÝ\\1dA&\99K\89§A)\15Îj\14\82c'\15\14Ø\14«\1a»\17\98§D¯1\87b¢É³L0\12 8¾\ 4\85\16ä\93D¤§à\95}*ûM¿gÖËt\0ùâ8\ 6\1d\0å\90+\97ñL\1dh4Ó7(ͱ\bÝ@ÿÛ¦°Y®\ 3\111Ý7¢Â1\e\15\ f\18\9e\93*\e\94ê\82Û¨§9\8ajF\11R\83 \102ÅÀ^3\ 5q¬r\10K!sNGÐI±$\aá"=ЩÑ(;KÇñ%ïY\9d§Rð¾Øx\87êQl?ÏÀÁ\10\14=§@b\92XÓp\83\b\84Ó_\83\86è8\84'åÍ\ 2G}ÎëM AòU\96ÊÖ¥\96F.\85åÀ>\ f±×\10\8cq÷ì»Ñ\97ä[̳Ïf\0\83a\b»        \8c\ 35=]\v\ 2\92à\rY\À(\85¶÷\r²*×Ò\83éï`!\85V»ÖXÎ/3íV¿Þ\147\8d\99¦5ØÑ\ 4­\91¸iÌ$­á¡\8eÓ\1a\8b\9bÆLÒ\1aþ\8eÆi\8dÅMc®º#\ 5D\1e\eiï»eµ¡÷\v\94Æ#Ì,&¸Úâ®iÏ&!\81íHJäÑV\94D\8bM3cæ³ÅÏf.p±Ú_\e¦´¸ííá$\81\ f\81\12üÒÇþ\9e8\83ed\9aã\a÷\ 1ÞÒÛÛÓÀ/.\1e\7f1hÌ«¿%\ 5\16\r"\1d ßf×3÷Î]\9f\9dÍÅR\81¿\1e_Ü,>Ã
+p¾á\f\9bcBÅÃ\13\ 3\0\15ª&R
+á`*Õ,ëö\97\1fÿÖ\ f»cý\9e\fmY;Ù"¬Î       ü¹]ó«62Nl\1f»6BàB0´\98;J\1f·ËÍú\82Vß·¿7Kº\9eÙ\85^`\18ËݺåÙ©\9b)fôSü`\90ö\82´º¸¯½go>÷c\1eþl\96\15òaÑ|Åõ\1f=JÂq
+endstream
+endobj
+1007 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115428-07'00')
+/ModDate (D:20090924115428-07'00')
+/Title (pic_odd.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+1008 0 obj
+[/Pattern/DeviceRGB]
+endobj
+1009 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+1010 0 obj
+<<
+/Filter /FlateDecode
+/Type /Pattern
+/PatternType 1
+/PaintType 2
+/TilingType 2
+/BBox [ -2 -4 10 5]
+/Matrix [ 1 0 0 -1 -27.4 197.8]
+/XStep 8
+/YStep 4
+/Resources <<
+/ProcSet [/PDF]
+>>
+/Length 71
+>>
+stream
+x\9c3Ð3T0\0A(\9d\9cËUÈ¥kd  kb `\b¤-\r\14\8aR\15Â\15ò¸Ì\15ÊÁ2¦\ 6
+¹\\86\ 6@%\86\ 6
+9\Á\10å\860QS\88\17\0#\92\11c
+endstream
+endobj
+1011 0 obj
+<<
+/BaseFont /AXDXXM#2BTimes-Roman
+/FontDescriptor 1013 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 0 333 333 0 0 250 0 250 0 500 0 500 0 500 0 0 0 0 0 278 0 0 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 444 0 444 0 444 0 0 500 278 0 0 278 778 0 500 0 0 333 389 0 500 0 0 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+1012 0 obj
+666
+endobj
+1013 0 obj
+<<
+/Type /FontDescriptor
+/FontName /AXDXXM#2BTimes-Roman
+/FontBBox [ 0 -177 775 683]
+/Flags 131104
+/Ascent 683
+/CapHeight 662
+/Descent -177
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/F/P/a/c/colon/comma/e/four/h/i/l/m/o/parenleft/parenright/period/r/s/space/two/u/x/zero)
+/FontFile3 1014 0 R
+>>
+endobj
+1014 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2332
+>>
+stream
+x\9ceUkXSG\1a>1$sl\91nISHÑ$½Xu½\14©® ¶¶ËÅv¥\94\ 4\10\14\91\8b\ 4\12IH  ×\M\82À$\Â-\84\86«DQAë¢Û\16\14ÖÖmµ­Úv¥în»mÝ®ën·sØñÇ\1eh÷Ù\1f}\9eóÌsÎ|ó½ó}ïÌû\1e\ 6\11°\82`0\18\81É2\85D½Y¬Td\17.}o¢Â\18Ôê\15Ô\1a&ı\8b\1d\8b{Xk\88øNæ*\18È\84\81\ 1Ý«WN\a£÷\1eG\9d\8f!ë/\b&\83Qæì\8fVªÊ\8beùR\8dp}\8a8uÃÆ\8d\9bþ?³5**J\98Sþ¿\880F¢\96å\17
+\9f§_J$r¥J!)Ôì\12FÓ«årÙ\11a¾¼\%U\v³ss%¹Kiû³å\92\ 2a\9cL.S©\94%ÂõÑ\e\84\11áá[7ÓÃö\ 4\99"G«\16.W.LPF       ã\85bI¾V\9e]üó\bA\10!Êâ8µ6»ì\88$Q*\93+¶    w®ß°iKx\ 4A$\12IÄ:"\99ØOü\9a8@Ä\10qÄVâuâ7Ä\eD\ 2Á%\18D\18±\92x\84XE<F<Np\88P\9a6"\80Nò3Ö0άX»â
+SÄ\1c\ e \ 3L\ 1\92Y\8dìWÙz¶\89}\96ý\1f°\a\18\81\e`RDU\aQÕæA*b\901ô%jÿ\92\89ê¨,.~2|#æã°¯\9fGÁ(øÞ¿\11\1f\85¼ð-~B`Pr\17.oÄk0ëðÞWróúN\97\b\94\97*?\84×Éoß\9a¿Î\ fBw¡\9bzÉ˸¹ÀtROqÛë\9aím\90ìo®Ì\14à:\0\ fX­û\8c¤\ eYÝ`o]\85\eÎ\90H\vF'§}\8dÍUæV~\87¾Õæ\82d\9fÛ38Vâ\95e\17jb\ e
\1cûµù\86Ä2^\10õ;Ø\85æΠæSe]Á\7f\7f\10Â\91RjTÉE:\r0î*×í\82$^\8b\8aÙ\83\r\8d>>ZÍF,Ø£ól%ûÙÕèYÖÃA6çV\19øØæÒÃXòa,\80\91\9e\f\8du\81\97ëõíð\ 6\89
+ÑZð9ôèÚv\92A\14ÏÜcôR[¼\86\9eà\8bó(êÃ\10Î&ô\at\8d{\1c­f\99Ø55ǬµµÇ!Ï\ 6Í\ eS\ 3Éñ4iµõEa»ÅiÑI£G¾H\17Ì\1e\1d/õ¨¡\9c\97Y L\93É]=eü\92þc½\86\19²\12\87»ØÎ\96z\aÍ\ e\19¶×ôÚh\0Û ïxgØ­«³\1fN«ÇÞô\v0qUÙ¡ë\87>Þé\91Áó3ò\88^þÒyÍ\8a½ÔN\8f¾=øú\ 2\8a[\báx(õ4·\8a\9daj=/@÷p\ 4à\8cU\80ùê63<@b#\80Ê*½Þ¤ÒÊ\8d
+Hæ\16\9c8+àxЧøy=¸PÝ®\83\19$n\0»/¤}tr¢ÃçãON²"\ 1'¾¾fÚëo½ØN³\9eh\9e\11ÏR¡}ÁïÞAë?\ fá\9c£\12ÞçVè\8dU:Hj¬íS\ 2\94
+४!]\9fÖ\9fÕ\95\bÉͯ\1e\8c×xK{ûº½=õµ\rµNAMsm\13t\92¾Ñ\9eÓ¿õ\15¦ð\13\0ÞòF\85%K¢-ÕËàQ\92\93\16?\9597u¦ûÒ\1c\9fãJmè,9\13v\ 2\8d\9f¢Cø\85;\(¯:VbTë\95ÇJ )U\9e\98\14Ô\ 3\8c\1f­\9a¢Oª\1a\17Ý\f4ò$Êp³å°´C>\85\9f@i¡wP`\97o¸cÔÎsã\b\1d\18®i±A=4\1aµÅò*\9b±ÜPª÷\86\96\9f\80.Øîr\ eÛI7>¢k\ 6ðÃ0rè\eü\(fã(E\8eÙz´\9a§CkÝ@ilp5:Ý.¯àSôØWXXosØ \8d\aË­Ç\8fÖ\90K\Ý XC\8cþ[Lê\19\14ÎM\8fÍW\8b!\19¾ï3\ 4þùÎõÏý.S^\8b QÛ¤ì,ï\86¼\81\9e®ÞwcßÚq0­4?Gp S¹\17î&ñ\93\9fnAÌs§;Fü|_\1f]þåeÜ\ fPá(\ 2~\ 6µ   ErÓ÷d\15î\83b\985T8S~Ê:V3G¢9¶å=óPñ¨Â\9fÑ\9d
+\ fÀCå\12Ù¡\1cU\f\8c"1ÿÆv\ 4¾ýä2"Îòñm´\89ÛzûÄÉ98\aû\94®mä\8fÂê9\8d¦OÒºÿ\0U"F\bG\8e\ e£)î@\8d§v\0Þ\86o·Lö]\19õÏÁ÷áYý)ÕÐ\91©m\83\9biÁyØ\1c\ f­*K\8b\19F/«j\87żÇú£ªv×éÚáG$GN\95\ 4ø\9cN\1f
+\9b?ôÜ/\13\ f`Pª·;4Kw\99ö\8b°·\19\1f\84\ 5\8aîqÏ\9e\1föL@rº??V\80\ f\ 2¸×l\10ÙhÏ\90ºAJ\8b­     ~@¢tð}öÛ;\13³ÕofðÑ\f¨ª\93\19\8b-I\95<\95\85U   êíu°\ 1\92\93M\96,ÁÃ\ 2\0cmÇD\16:_î\ 6¢Fs\e\9d\1f\84Fè]\1fu\8f{Ѫ\aÁ·\1fü\8aVÐ÷(zÉ÷^Hfé@\93½Íá²7C^ß²oé\0\8c6\9bâ\8eÓ\18f7x½ÁÒ²d\14\bp¨4TÂUi4Je\8ffp¨·ghPÓ[(XFg|·ÀìZdr\eÙ­ö6{\13$G[ô\87\ 4\ f\8b\0\eâ«h(\93\eÄ×\e[à;$õ\r8îH­\90\98ã*xA\8b]tik.1î. ø¥\87ÙE=ÃuÕ5Ù[!9Ð\\99\8dK\18º¤Z\1a£Ø\rö;t­p\82\0:\9aZ\9cÎþÞIÏ8$§z¤4{
+\0\93L&ñRå\1a7\10Ûu\1e8O¢\ 60<9Öy\1e\923\9dªH\ 1Î\aPl±\88¬ô"¥\e\149\14\ eC'\9cà¡\1c\80\1eɽò²(­H\94Â/\9f\91ùR`&Tê#ãÉO\80Õ\91V&3%ëxËÊCë®Ò\9e\1f\8cÎÝ~ùV\bçkJN[òZJ\94ÉÆ×\1e\8aXûР   ¼\vpþq\vízÀƯ]åb+\eYÑ=V\10ª£¹2!&²#&\ 3­¦2¹\8aâ"ya\7fñÐÈ@ÿÐHÑ\80B\80qÀÏæè\9fÌâs^Æ\85»Lta1\92ûjº¢(/#f\9bt\1dÄ+!æ\9cÜðçµgÒ\a´\97
+Ú:Bwý^9®úD}Ít\13Þ\87ß»þè\9b\1f\9c\1föß\98%\7f\ 2Aéw\99§p,÷ã\vÃ\ 3'Ï_ÿÓø}\88VBôDÞß^|\90s¡¨'uÔX\19úY¼O:øJßk­{à:ø¬!R\95 \8cWäG\8bh\90:\9b·ò_Á(|"\84\93u\a?ͽ6vn\ e^!§¥\13\87¥j\8d\8cÏé.è-ó7:íöF>'Ëá\84Ð\1eÖÔh³\14(óRòèNêLt\r\8fßÿyã4±ú\81Åà\ 1Fß=äºÇDNºÓd\98]\91'\15%I0Xn\951\86\95t2ó¢z\16^\84\93\1eÿøì;§\10    Ñ*\12e\87£§q\b¿º\88»p\ e³°\ 4K2\85Û·gþ\80r\91ô\1cbÞ]Ú\0Þ¤z?f ¯î2)%ZÃ54ä\89\rÇ\ eC\1e¶°Ñn\14ó\97¯'nÂÛ¼û;o=\9b\9cª=\92Ç/\90é
+*bº«BO\7fç\1fý\0\92\v\1d/elÙ\11!ÀqXÄ2RO\81 R/µß\8b\92½ìáG¾xt¸)0ð\8bÎÀU\ 4ñ_²`\91"
+endstream
+endobj
+984 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./pic_odd_even.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 1015 0 R
+/BBox [0 0 417 168]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ColorSpace <<
+/R9 1016 0 R
+>>/ExtGState <<
+/R7 1017 0 R
+>>/Pattern <<
+/R8 1018 0 R
+>>/Font << /R10 1019 0 R>>
+>>
+/Length 1020 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\9dVËn\1aA\10¼ïWô\11K¡=Ýól\1f#%\91rJì½Ù> \8c\9dD&\91AQòù©a\ 1¯1°8â0ÀTÏTÕöLí\139\16rõ³\1e§óæü2Óò       \9c5h¤?Íj\9e.?5R2»\92(¦ÀÑ\ 5\12\1fXRÁ\98Ù\82ÑbÖ\mAA
+\9b¥ý \9c\8d\8b\ 6\8aѱ\93
+\8a\1c\14£\ 6v;\98ç\85^c6\9b\89fÏ2ÀH\80â´\v\8a\1dè\1aª8\99Ð-´Þ5Æ!\94*^$èªH\85S        d\1e0üΪ\1cÀj]ÜU={&ª\85½\90\ 6\90\aé\9c"{-\14űÊ\86\98BRÉ[Ð^bR¢°I\ f´Ï\ 6e\17òÖªì=«ód\86ÿ-\1c\1e\9b­¼\8b\1c\ 3\8a\92ç\1cI\82dÖ|X`Ç=Á\17±¸ßy\8dÉq\8cäÍq\8a\8a5Cä¤'òª\8a+\11\97»\1d\8a\19Ë\86X9DLc\f\8coÑ+ûl+B^wyu\98-¯=\18\10WSË8\1aE\\84»B\8b\87F\83(f\8e,\7f\8f\13d4]vçêü²Ðrúó¤ºaÌ ­Ã\8a\8eÓ:V7\8c9ñIû\12K=¥/\16Z\9dþÞJ\eÐ\v\13vA\a\86\16AS¾õá\9cR7\8c\19¤õÖ\87sJÝ0æ¹Ýqe\b»ÿjwñ¸bêaì\97Æá¾:V7\8c\19¦uPÑ\0­#uÃ\98ô6F¿Õ­\13ê\861Wë¤\ 6\91§Fºïëa:§÷-¶ÆOäVÊ\b°ö¾é"_H\900\92ÑC\90\95$S;oFÌ|ÖþhÆ\82Àªúº2¥ö®7\87ÎCä ÷\10\8d>õçÄ\ 5te¡1®\ 1\1f\11#½¹\15\r\ùâq«\83ƸFYV`á;\96\ 3ôzt3rïÜÍÙÙXB6Déö\8fÛö3¢\ 1¯\rx5\18ã(\9a\87\19\r\0;TOÄ\8c\90÷Vs±N\7fùþwö¸Üîß³¡Û6ì\95\88Ts\ 2{»±¼\92Qð"äÓZF\8cl\84k/\95\8f\8bÉ|vAÓo\8b_ó       Ý\8cÂ\85^àaL\96³\8eçÚÝB©@\8fù\83EÚ+Ò\1aؾj/>øÒ¯yü=\9f\87¶ù\8aÏ?Ý\ 5
+.
+endstream
+endobj
+1015 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115428-07'00')
+/ModDate (D:20090924115428-07'00')
+/Title (pic_odd_even.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+1016 0 obj
+[/Pattern/DeviceRGB]
+endobj
+1017 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+1018 0 obj
+<<
+/Filter /FlateDecode
+/Type /Pattern
+/PatternType 1
+/PaintType 2
+/TilingType 2
+/BBox [ -2 -4 10 5]
+/Matrix [ 1 0 0 -1 -27.4 197.8]
+/XStep 8
+/YStep 4
+/Resources <<
+/ProcSet [/PDF]
+>>
+/Length 71
+>>
+stream
+x\9c3Ð3T0\0A(\9d\9cËUÈ¥kd  kb `\b¤-\r\14\8aR\15Â\15ò¸Ì\15ÊÁ2¦\ 6
+¹\\86\ 6@%\86\ 6
+9\Á\10å\860QS\88\17\0#\92\11c
+endstream
+endobj
+1019 0 obj
+<<
+/BaseFont /AXDXXM#2BTimes-Roman
+/FontDescriptor 1021 0 R
+/Type /Font
+/FirstChar 32
+/LastChar 120
+/Widths [ 250 0 0 0 0 0 0 0 333 333 0 0 250 0 250 0 500 0 500 0 500 0 0 0 0 0 278 0 0 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 556 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 444 0 444 0 444 0 0 500 278 0 0 278 778 0 500 0 0 333 389 0 500 0 0 500]
+/Encoding /WinAnsiEncoding
+/Subtype /Type1
+>>
+endobj
+1020 0 obj
+693
+endobj
+1021 0 obj
+<<
+/Type /FontDescriptor
+/FontName /AXDXXM#2BTimes-Roman
+/FontBBox [ 0 -177 775 683]
+/Flags 131104
+/Ascent 683
+/CapHeight 662
+/Descent -177
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/F/P/a/c/colon/comma/e/four/h/i/l/m/o/parenleft/parenright/period/r/s/space/two/u/x/zero)
+/FontFile3 1022 0 R
+>>
+endobj
+1022 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 2332
+>>
+stream
+x\9ceUkXSG\1a>1$sl\91nISHÑ$½Xu½\14©® ¶¶ËÅv¥\94\ 4\10\14\91\8b\ 4\12IH  ×\M\82À$\Â-\84\86«DQAë¢Û\16\14ÖÖmµ­Úv¥în»mÝ®ën·sØñÇ\1eh÷Ù\1f}\9eóÌsÎ|ó½ó}ïÌû\1e\ 6\11°\82`0\18\81É2\85D½Y¬Td\17.}o¢Â\18Ôê\15Ô\1a&ı\8b\1d\8b{Xk\88øNæ*\18È\84\81\ 1Ý«WN\a£÷\1eG\9d\8f!ë/\b&\83Qæì\8fVªÊ\8beùR\8dp}\8a8uÃÆ\8d\9bþ?³5**J\98Sþ¿\880F¢\96å\17
+\9f§_J$r¥J!)Ôì\12FÓ«årÙ\11a¾¼\%U\v³ss%¹Kiû³å\92\ 2a\9cL.S©\94%ÂõÑ\e\84\11áá[7ÓÃö\ 4\99"G«\16.W.LPF       ã\85bI¾V\9e]üó\bA\10!Êâ8µ6»ì\88$Q*\93+¶    w®ß°iKx\ 4A$\12IÄ:"\99ØOü\9a8@Ä\10qÄVâuâ7Ä\eD\ 2Á%\18D\18±\92x\84XE<F<Np\88P\9a6"\80Nò3Ö0άX»â
+SÄ\1c\ e \ 3L\ 1\92Y\8dìWÙz¶\89}\96ý\1f°\a\18\81\e`RDU\aQÕæA*b\901ô%jÿ\92\89ê¨,.~2|#æã°¯\9fGÁ(øÞ¿\11\1f\85¼ð-~B`Pr\17.oÄk0ëðÞWróúN\97\b\94\97*?\84×Éoß\9a¿Î\ fBw¡\9bzÉ˸¹ÀtROqÛë\9aím\90ìo®Ì\14à:\0\ fX­û\8c¤\ eYÝ`o]\85\eÎ\90H\vF'§}\8dÍUæV~\87¾Õæ\82d\9fÛ38Vâ\95e\17jb\ e
\1cûµù\86Ä2^\10õ;Ø\85æΠæSe]Á\7f\7f\10Â\91RjTÉE:\r0î*×í\82$^\8b\8aÙ\83\r\8d>>ZÍF,Ø£ól%ûÙÕèYÖÃA6çV\19øØæÒÃXòa,\80\91\9e\f\8du\81\97ëõíð\ 6\89
+ÑZð9ôèÚv\92A\14ÏÜcôR[¼\86\9eà\8bó(êÃ\10Î&ô\at\8d{\1c­f\99Ø55ǬµµÇ!Ï\ 6Í\ eS\ 3Éñ4iµõEa»ÅiÑI£G¾H\17Ì\1e\1d/õ¨¡\9c\97Y L\93É]=eü\92þc½\86\19²\12\87»ØÎ\96z\aÍ\ e\19¶×ôÚh\0Û ïxgØ­«³\1fN«ÇÞô\v0qUÙ¡ë\87>Þé\91Áó3ò\88^þÒyÍ\8a½ÔN\8f¾=øú\ 2\8a[\báx(õ4·\8a\9daj=/@÷p\ 4à\8cU\80ùê63<@b#\80Ê*½Þ¤ÒÊ\8d
+Hæ\16\9c8+àxЧøy=¸PÝ®\83\19$n\0»/¤}tr¢ÃçãON²"\ 1'¾¾fÚëo½ØN³\9eh\9e\11ÏR¡}ÁïÞAë?\ fá\9c£\12ÞçVè\8dU:Hj¬íS\ 2\94
+४!]\9fÖ\9fÕ\95\bÉͯ\1e\8c×xK{ûº½=õµ\rµNAMsm\13t\92¾Ñ\9eÓ¿õ\15¦ð\13\0ÞòF\85%K¢-ÕËàQ\92\93\16?\9597u¦ûÒ\1c\9fãJmè,9\13v\ 2\8d\9f¢Cø\85;\(¯:VbTë\95ÇJ )U\9e\98\14Ô\ 3\8c\1f­\9a¢Oª\1a\17Ý\f4ò$Êp³å°´C>\85\9f@i¡wP`\97o¸cÔÎsã\b\1d\18®i±A=4\1aµÅò*\9b±ÜPª÷\86\96\9f\80.Øîr\ eÛI7>¢k\ 6ðÃ0rè\eü\(fã(E\8eÙz´\9a§CkÝ@ilp5:Ý.¯àSôØWXXosØ \8d\aË­Ç\8fÖ\90K\Ý XC\8cþ[Lê\19\14ÎM\8fÍW\8b!\19¾ï3\ 4þùÎõÏý.S^\8b QÛ¤ì,ï\86¼\81\9e®ÞwcßÚq0­4?Gp S¹\17î&ñ\93\9fnAÌs§;Fü|_\1f]þåeÜ\ fPá(\ 2~\ 6µ   ErÓ÷d\15î\83b\985T8S~Ê:V3G¢9¶å=óPñ¨Â\9fÑ\9d
+\ fÀCå\12Ù¡\1cU\f\8c"1ÿÆv\ 4¾ýä2"Îòñm´\89ÛzûÄÉ98\aû\94®mä\8fÂê9\8d¦OÒºÿ\0U"F\bG\8e\ e£)î@\8d§v\0Þ\86o·Lö]\19õÏÁ÷áYý)ÕÐ\91©m\83\9biÁyØ\1c\ f­*K\8b\19F/«j\87żÇú£ªv×éÚáG$GN\95\ 4ø\9cN\1f
+\9b?ôÜ/\13\ f`Pª·;4Kw\99ö\8b°·\19\1f\84\ 5\8aîqÏ\9e\1föL@rº??V\80\ f\ 2¸×l\10ÙhÏ\90ºAJ\8b­     ~@¢tð}öÛ;\13³ÕofðÑ\f¨ª\93\19\8b-I\95<\95\85U   êíu°\ 1\92\93M\96,ÁÃ\ 2\0cmÇD\16:_î\ 6¢Fs\e\9d\1f\84Fè]\1fu\8f{Ѫ\aÁ·\1fü\8aVÐ÷(zÉ÷^Hfé@\93½Íá²7C^ß²oé\0\8c6\9bâ\8eÓ\18f7x½ÁÒ²d\14\bp¨4TÂUi4Je\8ffp¨·ghPÓ[(XFg|·ÀìZdr\eÙ­ö6{\13$G[ô\87\ 4\ f\8b\0\eâ«h(\93\eÄ×\e[à;$õ\r8îH­\90\98ã*xA\8b]tik.1î. ø¥\87ÙE=ÃuÕ5Ù[!9Ð\\99\8dK\18º¤Z\1a£Ø\rö;t­p\82\0:\9aZ\9cÎþÞIÏ8$§z¤4{
+\0\93L&ñRå\1a7\10Ûu\1e8O¢\ 60<9Öy\1e\923\9dªH\ 1Î\aPl±\88¬ô"¥\e\149\14\ eC'\9cà¡\1c\80\1eɽò²(­H\94Â/\9f\91ùR`&Tê#ãÉO\80Õ\91V&3%ëxËÊCë®Ò\9e\1f\8cÎÝ~ùV\bçkJN[òZJ\94ÉÆ×\1e\8aXûР   ¼\vpþq\vízÀƯ]åb+\eYÑ=V\10ª£¹2!&²#&\ 3­¦2¹\8aâ"ya\7fñÐÈ@ÿÐHÑ\80B\80qÀÏæè\9fÌâs^Æ\85»Lta1\92ûjº¢(/#f\9bt\1dÄ+!æ\9cÜðçµgÒ\a´\97
+Ú:Bwý^9®úD}Ít\13Þ\87ß»þè\9b\1f\9c\1föß\98%\7f\ 2Aéw\99§p,÷ã\vÃ\ 3'Ï_ÿÓø}\88VBôDÞß^|\90s¡¨'uÔX\19úY¼O:øJßk­{à:ø¬!R\95 \8cWäG\8bh\90:\9b·ò_Á(|"\84\93u\a?ͽ6vn\ e^!§¥\13\87¥j\8d\8cÏé.è-ó7:íöF>'Ëá\84Ð\1eÖÔh³\14(óRòèNêLt\r\8fßÿyã4±ú\81Åà\ 1Fß=äºÇDNºÓd\98]\91'\15%I0Xn\951\86\95t2ó¢z\16^\84\93\1eÿøì;§\10    Ñ*\12e\87£§q\b¿º\88»p\ e³°\ 4K2\85Û·gþ\80r\91ô\1cbÞ]Ú\0Þ¤z?f ¯î2)%ZÃ54ä\89\rÇ\ eC\1e¶°Ñn\14ó\97¯'nÂÛ¼û;o=\9b\9cª=\92Ç/\90é
+*bº«BO\7fç\1fý\0\92\v\1d/elÙ\11!ÀqXÄ2RO\81 R/µß\8b\92½ìáG¾xt¸)0ð\8bÎÀU\ 4ñ_²`\91"
+endstream
+endobj
+998 0 obj <<
+/D [996 0 R /FitH 686.127]
+>> endobj
+589 0 obj <<
+/D [996 0 R /FitH 507.206]
+>> endobj
+590 0 obj <<
+/D [996 0 R /FitH 321.901]
+>> endobj
+591 0 obj <<
+/D [996 0 R /FitH 136.596]
+>> endobj
+995 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R >>
+/XObject << /Im12 982 0 R /Im13 983 0 R /Im14 984 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1025 0 obj <<
+/Length 127       
+/Filter /FlateDecode
+>>
+stream
+xÚ]\8e;\ eÂ@\f\ 5û=\85Ko\91ÍÆ\8e\f°ËGBAÁ¢At\bî\7f\ 3¾\ 5¢zÒh4z\19î\90a\1d\16\1eÚj0¤AHÀoÐIN"
+b\92:Rð+\9c\91)^|×Vå_Ó,1Ñ3óv\96\9bñàe\8e\r3c\9fb£jxÚ®ÊôA5\92â4ïÇh=úñ\15\fùûâ\7f\8b\87\aóÈ"|
+endstream
+endobj
+1024 0 obj <<
+/Type /Page
+/Contents 1025 0 R
+/Resources 1023 0 R
+/MediaBox [0 0 612 792]
+/Parent 940 0 R
+>> endobj
+1026 0 obj <<
+/D [1024 0 R /FitH 686.127]
+>> endobj
+1023 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1029 0 obj <<
+/Length 1615      
+/Filter /FlateDecode
+>>
+stream
+xÚ\8dXK\8fÛ6\10¾çWø¶4\10«¢D½ÐS\13$E\8b¶9Ô@\ fM\81¥m®MÄ\92\\8aÚ\8dóë;\ fR+wµh/Kr43\1c\ e¿ù8Þtu\¥«\1fߤa|·}óÝGU¯²4)ˬXm\1fV2-\93ºlVE\9d%\95R«íaõ§x\7fÒ\17oÜz\93W\85\7fm\7ff3\95Tu%Ñ,]m\8a4)dÎ\ 6﬿èý:\97â\8bí\8el÷¾ïÖy&\1eQj:üë-\88¢3©\92\\95YtV'ª\ e»\17\89\o¤Ì
\89\8dÝ£5OlX¯\9a¤)³2\98ey"³`¶=\99õF¥\rNz§a.S±ï×\9b¬\12\a³çõ8\98\81µ\9c9ko\1f×Y-Ìùʲ±\e¼\e÷~tæÀúà\a\14\9eø3\1e\11V_È\ 6B\14>øÚù@æµíèø(ÛÙN»+F\8d\81J\994EÁ\81ZV6GÊ°ÊÄçT*s>\f¼ê\1fxÔng½C\1f´|²\a\7fJÀw\95\8a_ú£Ýë3\84]+ñ\16¿+a0¸J\9cXû&TÏ2\e6Ð<\80w8­ÑmøÚ\85}N\96LOK¡£\r$´È!:\83\13ÐwÖ{¸_\92ö\9dÙìÐúº\81)+ì0¬+ÏýÉ°¢éèfj¸\19Ç\9ftwàO Ó±\b\82;¼î×v\93>O\ 6Ý\9a¥ {Ç\9b\0\aÏÙ®R\b\8e)\16L0\0ï×~ð¬µ\1f\9d3|aÁ\ 5ß+Y\ e\1e\80v4üA;§»£i\83öÀÒ£ëÇK´d¡\8a\bèo¢-9Z¼\9dB\89n\ 2'¯§­r8éØYÏb\ 2\v\8cÆ\1eO!H\òV¨ú9-R>ÝÞ\e?ÀR"`\8aF\fö«7\98êh\10äþd\9dç\{\ 6?üé_¨õ\8eEg3\fKYß÷mÛwTYE!zȶé"´\7f¥ú\ 2ù`¿\99\ 1\92^§u(`Ð\98
+¸ ¤E,si\81,\94\e§\87S\89ÌÂ\ e)Ù\\9e{K\955°W¼ïÅ8á\82÷\98·T\8aV_.L`° Ü¦)\ 3\ 5\ 5g.;^¼¨0\90ÍK
+\96Ó5ÓJwìN\ 3¿D'Î\\9c\19Â\194\9f"X.\84\1a2·!*\0Å\9c\91\0ù\9bH\95´#©æ2)ÓgR}¦U\82\ 2³4\95\1dNÞ]½\19\16IV6IÙ\ 4¢ÿ Ó,\95h©@\94Ì'î3í\85`Ö3e¡\92vÌ$Ö\eâT\84\8eÊ\95ÐlyÏÕèÍ\1d«#?¡|¸vè\13H£íÇ {²xbrÚ\ 5ë    Õ{\7f÷v)]þ¤±fë\ 2<ÃÎYSÌË\ 4å;J\1eT|#>"\95"¦Q~\19]8\f=\17(B0àȬQ\97@%pM\8cÍ*`\13¿/c3l¯Ã¶áÜìȶ\97³\8dÛ¼\ 2Ò¡\ 5¶7\94ò¬¼á\ 6d«ø  æéQAáD\18\843Tê\ 1R¹á×.+'zĹf\8d\v¼\92\ f½k!MU&\81\18#S¾\8aгah\ e×\ 1@\810Ë#ã=®\vpì¬Þ!/ <\ 4À\161/ÁF\ f,æú\83ÉÃØ\1dtäW*!Ôò}Ë\9f©^qc>9U\ 5\19\r´5\e\99%e¤X&\9a\19\8a\95\18wöïÑú\80·\ 5è²Ø\87ãÃÝëð¬¡\18.}°ôÈ 25\vïùá\vðÎÉ\16å;raæhVâ\99¢9ìÍ\14÷,»¿õÞ¼åk9õ\135\9bGÜÇ8ú¢\ 2êUZqÞTZ>ó)\b_ð)|ÇçO\8aW8\15l¨0Aoðö|f\11ïÌ«\12à\80\17ß\11\8cà#àe        \1cº\vðÊeqû¾ÉyMà
+\9f\85ïa\9a\ 5Ú\ 4\11\96     ?®Õ3Ubî£\ 2´v<a¼,íaýÄ\9d\92K\1aGÍÃÑÆÃ/\15àôüÖ)"\9bº?@\ 1Õ\1c\16G\ 1Å»=Q\8b\ 5\1a\87p\9fc;õ\ ey\rg\19\ 6\90\ 4\1d¾(\12³`\96\ 2\10FWÔïÐd\82\b¯\1fè\ 5\ 6ÍÀV\15³ÕR\ 3\14
+Ã|Õ\98ÄPy\1d·\8fÿ÷ñÈÂãñǺA¢<,½\1f<ûDýÖ\7f½$? ðkqÏí\85;Üñ\9a\1f\81:\14FµÀm Dx°Z@ûÜ\90\87©ï\12ÜÊ×¢EGãÙ[J\ 1J0/ì$\b\9eo\0\vÜlÙÔÜ\ f.Aú%Mäe3ã\ 3\i\1e\9e\10¹pP^QW\0ã.¶+3Í\10;NéêP\1d\8d9UØ\7fU5\ÿèÂ\94\80P\86ß$³F\90Ü\aJE\88\16R|\88¿\12\96\9aû\19þ\14ÿ\1e¨U¨&\98Ìâ¯cÙÕjv\0¨\0\87ÄØ}Y\87´ó÷Pôô¾rRêиÂx?ØcG}\1a\9b;<R\ 3ÖÉ1ù×þ·\8a¯â\F\139µÁ2\9c\ 6FJ\91\ e?pXgF<pHúñ\813¬xn\ 5¥\8a\14A½?\1c1pØí\ f¹Ù.S\0\11ÜØdäµø=r5=^óÍ_ûÙ\ 2\11\84W\90~paáÆZ\1fì.Ö2í\9bÓË\83C¼)ÜU)~îPÎ-y,\7f3s\fÛOÿ$XɲLê
\9e¬H²Tr4y~£ôaûæ\1f­\86T\ 5
+endstream
+endobj
+1028 0 obj <<
+/Type /Page
+/Contents 1029 0 R
+/Resources 1027 0 R
+/MediaBox [0 0 612 792]
+/Parent 1031 0 R
+>> endobj
+1030 0 obj <<
+/D [1028 0 R /FitH 686.127]
+>> endobj
+138 0 obj <<
+/D [1028 0 R /FitH 668.127]
+>> endobj
+142 0 obj <<
+/D [1028 0 R /FitH 487.561]
+>> endobj
+146 0 obj <<
+/D [1028 0 R /FitH 349.981]
+>> endobj
+150 0 obj <<
+/D [1028 0 R /FitH 200.406]
+>> endobj
+1027 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1034 0 obj <<
+/Length 2408      
+/Filter /FlateDecode
+>>
+stream
+xÚµ\19Ë\92Û¸ñî¯ÐÍTeÈ%ÀwR9Ø.ïÆ\89\1f[±²9Ä©2FÄH,S¤BR\9eõ~}ú\ 5\12Ò°\9cÚC."Ðh4º\eý\84âÍa\13o~zör÷ì\87\1fËM\15U¹Î7»\87\8dÊã(Ï\8bM^æ\91ÒÅfWoþ\15$éöß»¿þðc\91ø\98I\1e%y
+d\bçÕ_^ü¼{ý÷m\98$I\90EÛ°(Êàå\9bÝÏÛ2   ^lu\19¼úÛ\9b÷?ñú«\ fï\7fyý~÷æÃ{$ü,\16\17N*¼\93B¥U\94ªr\13ê\ 2\80    \1føI«øj÷µ 8R\8e¹\97Í!´]Ý\98î\8fÛ0MÓ é\90\914x<6{äíÈ|MGËðS?N\f\1a\9bC×|\8aUº7\1db
+ø~«\8bàÛdy¶ïOvä!¢\ eãtÇtlt\88\18\9e\84:Ta|wÃòµ Ìt¨ã¨¬Ôï\17óm3M­õ$-
+\964\8bQÒ­
+öÈ6
+\9bV",,µÖ\90´0\\93\16P=iaæ¤\ 5|OÚl\96\16Pb\90U\87        I\vÜ\85JEU\963\97¦«ÿ\9fJx×üjkO\ay\1eô\1d\88ŅAÿÀ_\96\1e\ 6­\1dÇ\10\86
\1dµ\95&A?ÔvhºÃè\90ÍÄ#ÐK×Ëø~\e\82\8a\84Ìù"Ð\86\15ׯ\89\95\ 4\86÷ö\88ú\15\95+ð      \ 1\8f[Z"\ 3Ú\9bÉ\1eú¡±ã\1d\16\85\9ec\ 6ô\ 3\7fc2µ$"\ eH\9d     ©3Ï\98\8b\1dq\91+\1cô\83áñ}3\9dAK\86\v\88\8eà\18îºCÀWdɲd\r)  ¶\8cgVÀ\9e,\86L\ 2v\8c\13Ð<È        x×\8eü8\rÖ\9cxz2]s¾\84Ì¡J£*MESÂckø\1c]V\ 1ê\1e¿¤=]Åh\8e%\9aã\1d\80.\ 4\11\1e\91\82
+jZª\82\96/^\89\0-¨.ÕU°CÐ\11A\97\91·\1eÉá\85H\89÷ÏG9CàµF°Ñ\88\883F\ 2%íí Üö]ûíêîE¢úÂt\12\1eU=5§æ7d\ 4D\85ißá\r\97pýGÛ1ÚãÐÐ\92Û¶ïIáµå©Xe\91#=º\89\ 1¬e\94#:^2Bj\96\8a\16\1fxq¹+\0\ 2±\15\8dx@s\12C\873\8ev\98ý¢ã\91a¿q\81\ 2õ\fôßö\87foZPH\99\ 6(^ZÌ\97'®e\ 6¡kZâÑв,Ún\16¹\16¬N\ 6µ½]\ 2Ç[q9º@ö\8b\87\ 1½\1c½ÊñÀðßì Þ6\1dÑxúËáx\83GéO)?ýe:Êuâ¢NÇ(~TÊ¢ªtË\11/§å\86u«9¯ee\94Çè\9cU¤$×f\91\8a\12°
+¥3H[t¿Yð\81\84xr\ 2\8aZFeRñÖ\17¨\87Ò\17\ efG3òÀðç\91\1d¡\rk\8b^Û±öÊà³Ë\ 20~\92\ 5\9e\våF\10>ÅYüöã=|\14\85~}\95H\ 1¡\91C%Ê\96ì\15>\91"\18ÑöíªÑ±\v k=ñy\9c©\0½bä!Ú0;¨\8fî\ 5Òç£óÒÓ¹µ'K\ 1mb\98\ 4k{@\eAÀ×m\ 6>Ó^ä\9c?(´ä$FÝú\8\9a\9f©PX\91`U\85:\17éa\80*|Ç*D@Æ*\83\ 5#\b¬:\8dÎÍÞÝ\8fÍ$ ÈnÈWª\82\97¨DÔÆ$Û)ßkö{<o1\ 6\ 4\ e\9e.'ü\95,6\90\12\8a#9/I\98Ã$]²\19\98\82¤¯~ÅSÊ$Reõ\1dG©¢Ù\8d\1e\\ e\9b+1Ð\91d>0\8a\13Ë"Êâü;ô˨H\v·þg\10\17\82ir\1d\b"I=\88!\ 5âìD9cò¼6\8d\924\17¯-\91 Þ\80\11GZÏn«Åi_¡\96 \ 3I°'/\1ey\ 4§ÁÊÔ\v\9c\82à\9aSk\1déBùÉ\1as\96KÖp[sèÛ󼳶\1e\19\8d¨S²ö³\ 5,\98\ 1lo0\18à¾1\ 4æácSOGÞ±ø\ 2
+?\8c\f\95   #ÊUl\ 4\àÐ7Ñkæ\7fÏ2«,\80\ 3\90\ 1å\15F\ 4?\e\8a\17_¨ø\99Fr³\12\85\1c-#\¹&î§"£­\85.\9b2\f¸\1cS\98@ÀçÈ\8a\ 1ÊÇ8\e\ 5\80\14\\97®6XMñ*äÁ\15æyOYùÎ\ 3³Á\9e\aâN±ûLT¢ü   \18WŲ§³¿N<\12~yBÞMD\8c@\8c -§5\ 2\9dK-Ü~:Y(h'{S[¸\92úa²·\8ec)SbYøp³\ 2b|mú\8b×°\0\9b\-Î¥\98\8eT\95_Y`î§Ü\81\9cßizéÜ­\92ñ\14þ\1d\8e~<r!\90\9a\a\9e bØe0:\1f¥`\87ñ;
+.\18\a\1f®#[Ó\99áÛJ\ 5)l_ÙO
\86-9¥¬Ääq,"0Ê\¥Þaý\92A8jÛ\1e-\94³f-X"\ 3\8eI©8à{G\8aÜ;"l¥\9b\92SîÖìÎNû\b\ fN5h\92KmäKKZK\15\9aÏ\7f.\r\85j\ 4ÏQ¼ ó\ 6G\1ax\ 1U\85_vC\1c\1d\8d´\1aÔ°Ð\1aÇ}L´8Eýc×\1e§Á?\8f\ e¸\(]\8dceÍá\97ªNW¹çë8C60\88Ç\89KзÆDX,¡éF\a`=ãx6\ f\9cÌDÈ6t\95qAî¯Ü$ö|á\85OY¨®Iæ²\14\14à\81\94\13x¶r³\88}éØ¿©Th\ 4÷Æ\9d©«x¸éhÆþ2ì×»\9b§6¸ -TV\84@\8b\fÙ\18é\88u\96\7f\17\9bµ\1d'p»\ 5ÃS³°K\ 5:\8b$D¤/º\9cE£ý¢Ù\15®ÑÂá\14®FʵB\85Ã\ 2G\ 3*')y@óñ¾\9f¬\8b\1f\E¡«7\12\8bj\14>±OóÚ\12lÊà\17|­ê!Sʦ7·ùö\8eSçRî®Dca\94\r9\81"m±u\8epàà\8f\r¥]X\94\12YK\15\ 5\10~¢ðV\9cuàøZãØs-\91\13\97'Þ+â\ 1D¨(G_\7f/ëé*ñl1\99m\91Ò³\92È +\rɶe\8cy\eÇ\1a\cgô\96ö\97\8bÑùGhïm\89è\ e²\a¥¢\98q«¾\15Öé\91\ 2Ã%[\v¿D\14NǹËι\ 4\f\84\90\8eý\15ÉÛyáË\9c¥Yð¢s)+Ç\f\87\1eÔ¶d\9eyáê\1c\18Q\9f~E³\bZî¨òÜ\7f@Ëóï\96\1d\90\91Ïò\bCþ.ï\8dïþñqç^\1eÝ«\13>\ fA×Æ\95;Wß7ýì\9c\v\83=\97¹\10yWûÒX\1aR5\97\91\92âö#\95X\9d\1dÇÿÙ\8d\90V\95KÔa\16Ç7\ 5\ 1®^÷ñ\84/L#þä\88Ü<\98q\16\ 3øyàÝ{d\89\9c\8cKÏD+\pmÃ/\17\885J­\88ð~X»\8eKÇ8`\ 6y¡A\1c\8c   i\I\8bÈE$Î¥®\80ÑuÉ¡8ÖÝ,`\82×\12&qi\9aé^?§í%ÊòöºÙ\eé\16nù<öÜê\82(:°Æuá8ó\9aY\9c\8eÇþÒ\92ÌÊWÌ\12S\ 6¨\f'+\18f\94ÅI¾#Ã¥P¨ \16ØQ\98E`\83ù=öÇ\8a\14\1dÇ$ÜÙwßsZð»;ßo2ÔÉ`-¿&rQL\ 3¶"\?\9biÂ÷6þS"½úû"\8d
+=?»Ü+¥\9e\1aªNý\86qO½_\1e/\95\ 1N&óE\9e<yÚóWz\80ùm\1c@Ϊpü¹x.\ 5iYE:¹yÓ4ãu³é,lnE½~\a{Q©è?KÏ{%§Ê¢,\9f\9bÚOq\1c?\95³\806uî»Õs9|dêfù{ÃÖwóësá=\9aÈ?\eîÑDþûH}N£Õÿo^ï\9eý\17ÂêÌ\18
+endstream
+endobj
+1033 0 obj <<
+/Type /Page
+/Contents 1034 0 R
+/Resources 1032 0 R
+/MediaBox [0 0 612 792]
+/Parent 1031 0 R
+>> endobj
+1035 0 obj <<
+/D [1033 0 R /FitH 686.127]
+>> endobj
+154 0 obj <<
+/D [1033 0 R /FitH 507.081]
+>> endobj
+158 0 obj <<
+/D [1033 0 R /FitH 422.134]
+>> endobj
+162 0 obj <<
+/D [1033 0 R /FitH 199.094]
+>> endobj
+1032 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F77 675 0 R /F11 573 0 R /F48 455 0 R /F74 666 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1038 0 obj <<
+/Length 1459      
+/Filter /FlateDecode
+>>
+stream
+xÚ½YKoÛF\10¾ëW\10è!\14P®wö½=&µ\ 3÷\90 °.E\1a ²EÛ\ 2\95è8þ÷\9dá.%Ò\92([¢}ÚÕ>ç\9b×7Kñä&áÉçÁÇÑàäÌÊÄ3o\84IF×     pÃ\9cñ\89q\86\81°Éh\92|K5\13l\98YëÒO_ÿ<ÿòy\98I)Ó\8fç£\vê©ôüËèk\1cûgtz1ü>úëäÌ5NÅ)f\95Ç;«ó¤¦%\ 3\1e¥89S.\ 1`^kA«³zy&,\1e!×B\88a\ 6 tzZ\ÍñBH'Óâ\ 6;\16\87~\8dïîgùæÝ\1cÏsLy\11\8e\19Ýæ¸Áëôz>\9bÍ\87Â¥\8fá\f\1cÊñ\f¼!½\1fB:«\96\99ty\e\16\92²Þ¾,ÇeìίC;.Â\96\7f¹æ.»\9c\96Ø\810uIg<\95«½\8b\9cnª6]\97ù"\ eç?\87¦ùb<#\18$yÐJ\90ürZ\8c\17OÃLq\9fN\v:°ÌoòÅ2\8c\8c\17yèä\95npv\82(r\82C\9dßq\12ǦÅÕì!(\8dÖVh¨3£-6½\1a\97Óy\11\86\bUkÍýC\19;ÕÚ9É`ÓJzÅ\1dês±Þ°Eü"ÿU\ 6'AÍ\ 4¿)çaàq1­T\83Ý0¤P\97\938p»\9a)Q/UwVÁ*\10ÖMy\eÖW6h._é\18'§E¼8ZaÉ*\ 1A1¯\14z\99`VGW?]i\8fP+\88ð\95HUø]       O\9d\87b9½)òI\98m\18$Lÿ\1cj4îì!\1eó\ 3Ä\87°\92¼#x©U\r7\15Ü2\aª\ e\91K\0Î7\9dY`Tj¨\17\ 5ÿ¢ã£-æá\179"µùÊ\9bK\9a~\8a\bj_$\1ddB9æ¹\8f¶2áà <\16î\87¦\98 \ 5æ\ 5
+MÎÀÄå¿Uá|:\1aü7 Ùx\ 2      \18Á¸³\89\16\9aI\ 5ÉÕÝàÛw\9eLp\12=\83\92Çjé\1d-\ fn2K.\ 6\7f\87\9cÔÄ\fÆ1#é(\94T¸p¥Ed\ 2ÃÞÄVÇVQ+]*©å<\15±\85Øò-¢
+@ÍËJTP¢KT°(\82\96Øß%+Êh\9dO4\18æmL9\8dàGgä\1dÊ\ 2ɤ3¯U\16fʶ¶\84Qm       `C\v\r\11Xά\¹!ßØÐÚØr\rc1i\9bµoª-§g`m%~;³µ\14\ 4\1d
+âÀ\94ìÇ\9b¸f\1cl\ 3&zÏÖ\16½©S\rÈ/\9e9¤°\ eLb7&å<SV÷\81Iyɸ\11ï\84Iv`B+kÑ\v$\a\fx?fÂØD\83\99\81\98¹XÍT\92y§÷\8cíÀª1'`Ät\83uLc`ï\0+$&S%Qm\1c\v\158@4B%\98D\9do7X\88VhÞ\89y\®*²¢\ 3\9f¢Dâ{1¦æLפq¸1CÛtÆ6ÝÏò\82ê\ 2Hÿ ÂÓ\94õ\9aì\1fô\85¨\9c\97
+\93\7f\f\99OóÀâ\81Ì\1f¢\9f\87\8cuq\15\8aÆuÅAñЬnP¤X\1eÄ
+d]\1eÐd]\1e\84\1a\8d\96üÈàC\98ÛU!(L\14Â4*\ 4ØR päHÑ,\10¶±8z\vz\1c¦ÚÇÔµO\a\8dK
+hÝK\92\92\14Ñ
+^@ãØÊØ\8aØÂÊ9vÒ8\89*u'\89\ 2\89àõ~\1a\97Æ3pæ\954.\8d\90xëþÝ$Þ\1e\eÞ\81ºC\zÍî[
+<\8cv´Ò\1e\16wè>Þ\1eÈâRKfT?Τ-\13\12^\90Q:3Íñ,\8e5.3®\97,)\15>u­y'L\1d,.\85¯jÁ>0á\8b^\8a~ìô64.\81Ò\92;\8eÆ\ 1£\163\10=(¹>\90Æ%V\83o@ãÂc*ñ²\17cb©aݱ¶ÜËâõç\8bøÎ\7f_2·ÏÈü\19\81+"p\13ß÷\15\90\94xS»\87Ä\91 õÊ^\97\9c#\13ó-\99\1aÓ\89\ 5\99Æòø¥<.(¤M/iJPH×\1ez\10\8fWî°\93ÇITD´\87ƽ\12ûi\à\91ê\95$. |\8fé\83Æ\e÷¿\9eÄw¾Ô)¹ÓÃñ0\12\16øþuÚõ\83\ f½\10c³ýÉ\0öÔïÛÊ\13n*DüynÙô|\8ctïÕ\vÊ\94ê\vßA\94\8eÙ\92yÞKÆÄZ  \1fvGdÌZ\vG2z\88\18×\v\99\96º\17LoÃè`0A\19q,£W`-º\eø\83\19Ý)Ó?£\ 3r\82â¶\17\10NG\1a3Pû.J\7föÝ>ò¹xöiþ­\b\1däk\19Ýxã÷\90¹¤\18h}³\87X\9f ©Ó\17ü-IÎ\1a¦\9b\9fI#³¯þ\r«[´ùÿÂt    ²
+endstream
+endobj
+1037 0 obj <<
+/Type /Page
+/Contents 1038 0 R
+/Resources 1036 0 R
+/MediaBox [0 0 612 792]
+/Parent 1031 0 R
+>> endobj
+1039 0 obj <<
+/D [1037 0 R /FitH 686.127]
+>> endobj
+166 0 obj <<
+/D [1037 0 R /FitH 668.127]
+>> endobj
+1036 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F74 666 0 R /F14 574 0 R /F49 457 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1042 0 obj <<
+/Length 1773      
+/Filter /FlateDecode
+>>
+stream
+xÚµXKoÛ8\10¾çW\bØCe`ÅòMjom7}-\90v»F/M\81UlÅ6 K]InÚ\7f¿C\ eåÈ\89\89{1irHÎ\f\87ó}#\1a-"\1a½9{9={þÚF)I5×Ñô:b\9a\12­M¤­&\8c\9bh:\8f¾ÄBO¾Nß?\7fmD_Rh"´\84m¼Ì«·/>NÏ?M\12!D¬È$1ÆÆ/ßM?N¬\88_L¸\8d_ýõîâ\rοúpñùübúîÃ\85Ûø\8c\ 6m\9e¿f²wBÂ\19QRAëNJñ\9cßü\8aóéÙ\7fg\f\16Ñ\88E\9c)b­\8a´\94\843\13ÍÖg_¾Òh\ e\93ï#JDj£\e/ºvâ\8c¤JEEôÏÙß÷Íç\9c\13)ÜV\86X*ðH3IÀ\15*Ö¡U¡\95¡\15¡å¡e¡¥÷UeF\11Í\98W\95îW\95YÐTrè\8fèÊ,'ÊÚH\v0_ZÔõÊyúg\9b;?Ë!\r¶Î\12\9c\8fu\96Lïx\8bÂ\1e;\1axë)ݶôNËFZ\8a1Ö·0\11)\91FFIÐcÀB¶ÇB\ eæP}\1a\v¹ 6\rñ@\ fX8néc,ä{,¤\96\bÅNc¡\93\13vØBöK-\14ã\16ª\14\9e~z\9a;T)\8cÙ;wHÇ5W\82H¾Íotû¨ÇZ¿ÁN\ 2³\96PÈ_a\87K*\87b\9cé\14\1e¢\86\ ed^¦Q\968AX\98\bPY\1d\18\eq\9d\81\14v(6,d\10=\9a\f­òÉPÙ\14ò¯y\84fÎ(x8R\8f\?º\8cí\\16a"í\Vî1OC\v\e\9e Ù+¸\ 1        \99ö\81÷¼§\15v'´EÜ´u\9e­1Ì\8b¼\´Ë \8bÿ\98$Rzøp"Ý\82\ 6½\ 1i\14µæ>:4#FÛ(\91\16Æ\82\8a\8apâ0\87q\15ÿ\99Ï*Ø\87ÅóU¹\80\ ehrþ#[\7f+òû¡F=¢¦*ÄØt     JJ\96Æ×UQTN\8b\e¿\87ä4ÎÃ\1e~¾Yâl\83\7f[¿\ e\84\9a6k\83HuÝ\9f\83Î%UÔ&W«\16:\f\87ÀP\83\9eñ\9b\ 6ϸ~^:#à\88y>Ç\91\85\14ëi\1cv7ñ·:ÿ¾ª6\rþë)«ãìºÍk\1coòïNo\98`q\9d\158\7fµ*³ú'
+À)0ßæ\8b¼\ e[eu8a\9eߪô;\f    '=+6èf'á\94éë\18b»Àe³¬]U%Þ°s\8ek½ú.\12\16y\8b#ß¼lÕéQãèuU£\X â2ÿ\11V\80GÃ\\85\ 3àÅ9¾5&\81/¸D\v\84\ 4³(\97\85eþ&ÝO\85\ 3W\10\90Ý\9e\9b²Y-Ê<¬èy\a§¯ëj½c\89¸u½\9b\ f×hð\1aÝHvåÿWîæñ.ÈP\9a¤Är¯7gûX\9e\84\87¯#)ÀÛéÓÞ=\83wo`'E K\ e\90<¸mOò(C\92\a\0!BË\87hË0És\9a\9ato
+fF\13©Ù>\92\a\1cئ\91\ 4\ 2¢9\7f\v¾\ 2
+D\85z"|2\80O±«Á\1eÀ\a§
+ÈXt\fg÷²¿\9d¸`\94\81\1fÓCø\19\x,I\f\1e\ 2
+EíI¢   Ät\87\92´_
+@4Ñ\10M\ f"P\9e39>},+D\93\80/Aé¦Na\93\0Êd\18\1f\89=Á&ý`\1e\18\92<µ²\v&YCLwþ.x\8f\9b4Öî\ 1{H«\1exJè\0ìïÁ|\0w 2 eÂ\15\9aû³«\9b³b\93ߦy¿\87s\93?Á!l(Ëû\8fÆÑ¢\94woæ\8a\r¼P`P:e·ÏJ±@Ö|®\11£\bRV\90÷ëA\1cé\ 1Ó!\10\ 1\7f\ 4\1c\91\11Æ ð­y0\92\b\96\12\96\9e\80J\1aû\90ï\ 5@\11\1f\ 1%\ 2\98z\9aÚýPb¼¦\a¡D0\87·öH(\11Ô\10.ùI dG\83ñ\1aó^à\1aJ\8cØÖSÇ@\89\86G\ fUÈ!$A\ f>\ eIx
+¼ÜêSD\13O-<@1\90v\a
+\8e_     %Ü
+"\ 4;\89MV\93\94Ùa\9bØ©mÚ\ 3%Ü0"ÌiîÉ\0åÖb¸p\1c³éX,\11\8b\80\84\1e\ 3$\94>\11H¦ýª£]B\1dÕ\ 4\83j7.½CíÃ`\1aÅ\0q°¬\85Y\80\1eÌú½ÏÅ@Þ{å-¡\94{Ûµ  ø~É\19½³¤¯¿ëmÕ\7fQ´Ëj³XºbÏW8\8d+\ 5\1dbU\9b\1a{\80q\rN{[ò:HTõj\ 1eeQü\f³õªmó\12'³&´8×\80AEoçÄ\ 3§ôP\99\f\15\94\1e;]        Êñò°\0¥*nªu\8e½\80Ë®;\ 3h\ 5/º*\17\vP?\7f\8d-\1c\95ܬæí²ÁÿXй\1eVÖ(\12Bo þ^¹\e3,X_\14øo\9e_R&\ 1ñÉ$QÊÆ\17\15\8egu»r3³U\16\ 2\98Á:GJ\80CWX\ 1oÊyV¯ò¦[\99cg\9d\ 5þ\0­ç\ 20¶*±\1d©¿·\ 6ì\8d\95\ 4¯\1eH\ 5QÝgÝc\82Å\7f;\11\8aÇÎÀºqÆ(\ 1ÔDéî©Á\9cw\97êªe7°C\86`æ_ñ\fgªÒÅ\8eë¡CòY¶iòn9rI×\9fUa\vÿ=\0Ä\e\97\1aÜw\989þ¿   _<\9cð6H\aÜÔ\8b$\bÍ\12Û[êæB¡§-ܬV&~\9bÍQp\e.;ú¸\99&èâúþ=çÛ~÷``YݱcP\ 2º]DgC\9a\ e±I·\14_ÅÎ×\88:o7õV\18nCõ\12\1f¦\9fM\11(å2sÿ»\ fD\98K½çóò\ e7½CaáÖ\ 6\b\ 67PG2y\9b\v\87ò¥#!ÛÊ\98\8dЮ\ 5Ðú\1f^~A\19
+endstream
+endobj
+1041 0 obj <<
+/Type /Page
+/Contents 1042 0 R
+/Resources 1040 0 R
+/MediaBox [0 0 612 792]
+/Parent 1031 0 R
+>> endobj
+1043 0 obj <<
+/D [1041 0 R /FitH 686.127]
+>> endobj
+170 0 obj <<
+/D [1041 0 R /FitH 531.706]
+>> endobj
+1040 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F49 457 0 R /F11 573 0 R /F48 455 0 R /F74 666 0 R /F77 675 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1046 0 obj <<
+/Length 1700      
+/Filter /FlateDecode
+>>
+stream
+xÚ\85X[¯Û6\f~?¿"ou\80&\8dïöc»\9d\16gÀÖaM7ì\ 6T\89\95Ĩ#g²ÜÓö×\8f7Åv\8f³½Ä\14EQ$E~\94²Y\1c\17\9bÅ\9b»WÛ»\17¯óxQ®Ë,Ê\16ÛÃ"Üdë"+\17Y\91­Ã(_l«Å\9f\8eÖËU\9e\17Áwo¿\7føéÍr\15Çqðêaû\ e©$xøiûVx¿oïß-ÿÞþðâu1Ò
+Së<)aOÒ\17ç(r·\11+^¼N\8aE\18®Ë4\8dPzåÅWQ\ e*âÁ\88
+Ã(\rîMµj\ f«\9f\97q\18¨=þ~\ÆQ \1dX\91§Á˦>\9a³68á\9eZ³Y¬Âb\1d\17%+Þ\9eôr\95\94%\88FEðåRïU\83\8c"è;\99i\ füÝÕî\ 2û\81ØÇÚ\1cY¨îduËß\8b\ 5\83ªßËê³2¤\99Gµ©ô\85$4P0\93ÃƤiGRN¯\14Ú¯+´\9c\8c¥Ð°±~{ü\ 1õè_\18\80\ 5Q\11\ 5\8f§z\8fêN8\84ÀXÍ|}Fé\1d\ e\ 2]U \98Ø5Y\85fãHñ¢FÙ£¶Ìzb\ fq÷-¯Sµñ\82\9d³ýÞõV?\87q  ã\9e\8c<Í9 ÀØ\18d &ô}{<2á¬2Ý\85\8cl­c\1eÄ\etku\86ôË¢MpÿÙikTÓ|Y\16q\0»%\e\b£\92ݦKx¨Í\9e\1c\fÈmÚØ\e òâä\9c­WE\10\98\1fß¿Û"\15Q a×cmx¬LÅ"Ú\13­á¯ò\vd\vbò9´½©\94\ 57\92\0|K\8b2x{pÚ<G£âÀ\9d´W91\1f8C\ 2ä\98ïc«3¶z\1c\81Í\86ò\13¿¦uLPäq\82ÏQÓy\93\ 4\8eûq²È\ 4¦?~½#\1d\9a    \91'Ï#Èé\ e3±e\1alÇÄ\eoݳæ\8e|\80q\aNè«\11ôE\8fgN Q\9dcdÙ¡Ã\1cD\18\91EðU\f@\93ªpkÒ\14&ë2I¦ê~;iÜ\ f\80\f\17æ%Ö~k\15³F±¶ÌáR.¨\94;aMÂ/ÌC+\v°Òr\9f UE\18\81ÛÔã]o\14újÎàI±aÔ£h\1aÍ°¼F3,x\9f°\94ü\ 1F£:\ 6       \1a\8d\121dPïâÉo\12\8bõu"Ò<â\9c¢õÂûª%:Þ\8eª\a(²ì³Ø0s¢C\94Er\b3\ 4¹\83bHb<\174£§D\8b\0àNmßT,íNÞ*ÜÏ°\9c\96ÉQ,$\85Y\14Ê¡\12]µøöX7\rSV\ 3vIävµÁ²\9c)«Á_42\8d\16C{\ 2#\b\88-\13q\16sز\bJ\8e¿ge95-\8f/Ê!\8eñ \15fçú¿6aFAÉ\18Ç\98r'å\98\12\93\81\ 2\blQã£\17ÑLTz\94Ã3ѧ&µ\81úÙaJ1M\8b\91Ð\9fÕ\1e\ 6\8c©¿¢O\bèIÄU\8a\12h\94°¨%\ e«Ñ\8f\1a \91Z§H^\91;\8dá@©OÂÌGÃ\967º:ÊÆ05c+\ 3\16\14¹Õÿôµ¥#\86Zçb\ 3öà+dÒí\9a\7fI\ 5äôùâ\86Ül\87´`êÂ@Cù%9Ãp>.\14Ã\12\ 6\8e{ïa/\17|&EO\1a´$Y×7N2×ש\92ï\aÍ\17\9aÛ@0E¸g°g\9c":Tµ«[\83U\13\86ÁK\7fÏÀÉC\8f\19\89hÌcö5\82\b\17Aw\85k;f*h?VHÃ+¼U3{'â;F\81M\98í\9f'E   \8b:\9b\ ecNvHµ\ 1w²C~Ý\ 1ÝI\8aà½i@}Í\88Ä\v~žßÚ]MÈ\0Ú®\0\ e\93\95¯O\1eJþ¤|\8dC\ e\SÌ^¹onVÙ\\84©ör¾,à\97?¦µgE%\98\ 5g_h<EI\ 2ìip\11)\92\ 4­´\1a\12WdëÃHk6-Z\9a@\90ì¥=[1á\ 6\9eÞ<¤\ 4\9a 8\ 4\19\9eqÊ»Büq%a}§9Á$Ê\9d\95¿»\82 âÖ\19\ fþ²¤ÄF\ 1\82\14\98ãËr\1cß2\94\ 1-Ác@ÌT\8e\a\8f\f\8c\9aG\9c¤\83Zäì />y\0E¦êÄ8B\7f\7fýKäb\80\12Ó\8b\13ÎTÊ©éj¹lv]½k\béRh¦Ð\909,x¹\98q\83\e¡5\8c%¸£åäÒÖ¶Ô¢¯¼ØßõÜiͯ\90é;gC\ f\9c¿Cð\81\93Ê\ 3ç\17\88\83Ü\1eÒà\ fê<H½ªå\85óÀo\e¼»uÿûÀ¹*C\a1\ 6i!Ý\f\19;:é´\98Þ\aq\86+µãYÆyà~Z¦\19\94s/Ã\ f\9bg,@\97\8cÊ\10ùT\86ȯÍÞj|\95á.̺\91*þú\9a$\91?$o\9c¥\87h\b>a\1a\0@\90k\89¤L"Ý\10       Bp$(+\92x\98\99V\v\9e}\ e×ÛÞñ,\9bLb\9d\9bè\8cQ'\8ag\90*íl\87ån]È\v\a¾7+4æ×\94¯P\1cÒÍ¡\10\vðºï «Â\81hº½\94\89\7fl\90A²Æ^s\85\9fqøáã¥çFíæÌ\9c\1c6½á\18«ñ\r\bÏ·½¦\1dñ1ÇY@\e \1c\9c7M\84rû÷ÆF\83±ò 4̼\81ñ<9ê`3\90|MÜ\b0TñG®a@Qâ"1õ%\19zÙ°êbõ§ºí;\1eI+\ 4ª#¤G\8a\ e\18\89Û]\ f&\87ãú¯v\17\a\aU7ϧ\9d/\1eG\12\87O7ʹù\8dÿ\eñßûíÝ¿\1c\14
+endstream
+endobj
+1045 0 obj <<
+/Type /Page
+/Contents 1046 0 R
+/Resources 1044 0 R
+/MediaBox [0 0 612 792]
+/Parent 1031 0 R
+>> endobj
+1047 0 obj <<
+/D [1045 0 R /FitH 686.127]
+>> endobj
+174 0 obj <<
+/D [1045 0 R /FitH 668.127]
+>> endobj
+178 0 obj <<
+/D [1045 0 R /FitH 408.704]
+>> endobj
+1044 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1050 0 obj <<
+/Length 133       
+/Filter /FlateDecode
+>>
+stream
+xÚ]\8e;\ eÂ0\10\ 5{\9fbKo\11ÇñÂzS&\96\13\f\92\13¡\15\r¢Cpÿ\eð-\10Õ+f4z\1eîàa6£\9av\12è]Ï\81AoбwÌ\11XØu!\82^álIð¢ûv\8aôk\12;âÍ3óvÒnX5\1f±!"»uØÄ(v,º¢\90\1d0\88M\87\ fOK=åªe©¯°ñß7ÿ\9bÕ<\0+A$Î
+endstream
+endobj
+1049 0 obj <<
+/Type /Page
+/Contents 1050 0 R
+/Resources 1048 0 R
+/MediaBox [0 0 612 792]
+/Parent 1031 0 R
+>> endobj
+1051 0 obj <<
+/D [1049 0 R /FitH 686.127]
+>> endobj
+1048 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1054 0 obj <<
+/Length 1099      
+/Filter /FlateDecode
+>>
+stream
+xÚÍVßoÜ6\f~Ï_á·ù°Zµ~X¶û\96vËÖ¡\e:àP`Ø\ 6L9+9a>Û\93}-\ 2ä\8f\1f)ÊÎ]ât\ f+\86!\ fd(\92"?}¤/On\93<ùî"\8fòõöâå\95ª\12\913­E\91lo\12\9ekVé:)*É\ 4\aS\93ü\9a¾Ù\9ba²~\93ɲHõæ÷í\ f\14¦XY\95\1cÃò$+r\96+E\ 1¯Ý4NÞ\9a\ 3\85|oMcýH\81UR³Z\v=\87  \96KMa\97\9bLÕ"Ýîmï\rê2½~È\84\9bLT©½uÝH\86OnÚ\936í½µ\14´\ f÷\91y0»\r\84ü¹\11ej§\91m²Zp¼âs®\15ºb¹X!ç¬."\12ÆÛ\17\9b¬à<u\1d\ 4Ao½\87øh\83Rx\8a\89K\9dºÆv\98hr¿å\íÌäú\18AW.!\96¬»þp\88\11\94 æâ©ifÍ\83\12ãL×P\L ÓÑNÇa­fº\ f\1a/u\95^¶-¸+\8e\9d "Roÿ::?_ÑÐéMïIiì®\ f\987\96\fPçÐ:Óíì\9c±£\ 3Û5Y\7f\93\ 5\10Ë\19Ä9¦k\\0`¥<Ûíú#5n½\85û%>ëÞµ\96ÔXA\996®»%Sè\19\95u\90eÍS¬\1f=\b\95 ÎO\8dÇçU\8edôÐB¤éã"éF     ùfZ\83\1ej3×-\ 2¢\94
+\80àñ) \v\ 1ñè\14\90èù\18\ 2ù\0\81\14g\8fðlqU~Î!Yñu\ e\ 5W7\924$º¾ËnÌdZú×zßû9g,õ\ 5\81\14\88\87\a?^n*\99þBÿĹ\8c¹o»\9eÚ\b'pp7_vZ}\1cú\93æ\80¤´[êó\1d!JÆytÿð^Â\ 4\0\86o\80\88ðà×®uÓ\ 6@º{º^p\99éZA\8a\87\91ò­³¸@4\10¥#\eÍ\91\9ei\12O\aßã»}\ 4ô\80k\ryÌ-¡î¦\91\14À)\0o\\87Ã\8d\8dfóýg¯u\1c\8f¦m\11\91\1c\b\ 1ë+p2×°ý8\fö\87·t\12ð\aùóÑ\11\7f&w\b\f\93à9RÄx\f,ÞãÓpäúÇÀg\1f\9e\11b\aãÍÁN¡\eô7ÔK\ 1\9ak\91±ä\86«\f\8f¡\94\11)b\9fß"\98HKZ\1e¨tý\14-+©Á<õ$\ 3ô¨Ðüà\1a.¤Â5<ÚG)\1dð\r&9ð\aíñJ(\ e1Ó*5\ 3¼Æ@\843~\8dR¡!)ç©U\80Ì\ e)<\929\92µí\11­Olù\9eqÅ$<e$\9dT\8cë\98P3\ eÀpQ ë\ eal\97Ï\1aéß\ 4\16K\1eGt\85Ã\82   °\85to»á\18&T\9e<Ñ«5þæ¬\12\v\7f\7fê;\eª]>àÿ$_^\95ê$_Vç\f°\84b*¦8§¬9|\11\80G)¢\94k,\0çB\ 4_\14\82\84$¡H\14$4\89\92DE¢&ñ¿Ì\12&¶`B\9ewüuö/ÿÖ\bz\ f\8b|ù$a\ 5ÓÝ`£ù\1e\99\ 4ò\8f髨-\96ý\13\8b}°¬<Ø\97-¿Xʧ»û'Õø'\16sb\11ð+\13¾\95\93a\f6\0/\80fÿiÕU\r÷\87»\11qB?\e\a»s7°e\83\11«#-øÕê9dï©\81<]zy쨿`3'#}º!JΤ¨aYqVUtÝ\95»=\86]
+\9b\ eöÖ+üQr²·Àºì-ÐßãÞ>ûÝKöwa¡ß¡©\87]õ¹¥\93àVá\8a>Ó2V!ë³\98\17\7f\ 3ÉV\b|
+endstream
+endobj
+1053 0 obj <<
+/Type /Page
+/Contents 1054 0 R
+/Resources 1052 0 R
+/MediaBox [0 0 612 792]
+/Parent 1058 0 R
+>> endobj
+1055 0 obj <<
+/D [1053 0 R /FitH 686.127]
+>> endobj
+182 0 obj <<
+/D [1053 0 R /FitH 668.127]
+>> endobj
+1056 0 obj <<
+/D [1053 0 R /FitH 394.473]
+>> endobj
+186 0 obj <<
+/D [1053 0 R /FitH 330.419]
+>> endobj
+1057 0 obj <<
+/D [1053 0 R /FitH 302.192]
+>> endobj
+592 0 obj <<
+/D [1053 0 R /FitH 134.074]
+>> endobj
+1052 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F49 457 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1061 0 obj <<
+/Length 1893      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XKsÛ6\10¾ûWðVj&Bð"\0æÒq\12»qf즶êN'ÉLh\91¶ØJ¢KRI\93æÇw\17\vRÔÃvâÉE\-ÁÅ·ï\ 5xt\13ñè\97\83ç\93\83§Ç.JYj¤\89\910\9c\19c#ã\f\13ÒF\93<z\ek>z?yýôت\8d\95\82q£@\8c_óâÕá\9bÉÑùh¬\94\8a\r\e\8d­uñó\93ÉÅäüèð\94د\8e\ e_\1e\9d_ °\ 3\1e\10<=Öé@ê¸\13;\96\16\98\8a\84ÿºjoW-\bq*¾ÍêlQ´EÝ<ó\82\8e&\aÿ\1c\b\90Å#±\86¯\14s\89\89¦\8b\83·ïy\94ÃË×\11g6µÑ'¿t\11)\9d²\84§@Ï£\8b\83ßö\98"\15Ì\b\1d\19©\98²\ 1É\19ì=\1ak!x<\19I\e\7f¾\1d\ 1Ò\18xRj\1d_\8cD\~\19\8d\ 5p\0\$¸e\89\96`i\92\90\8cw<áWeÛÀSøUÊ1\a{\ e×\\947Ë"ÿ\19$IÎã\97E3­ËÛ¶¬\96dÉl\99#¡ãz\84[Á~M[\97S\ÐÜc\15\9e0gv¬¢Sw¿U6<DÂ\\94¤\9aiChɱ£ÔÄ\93\1c\fM\99\93>TN\96#éⶸ)jPÂ\82~\ eÍ\97\98ø¬òD\12Ofdå¸Å¥ÞÈ.\ e¬ê:¼êÖÌ\8a,GQH_\91;Æd}\992Ë·¬_.oÈ\86y1­¼Ü¼ÈÙÝFK¬a\8eëï\ e¥=F\ 3a      g\89  \97h¯¬.³«yÑ`lëxÕ\14ù³]ó¹\84%2íÌwV-\v\8f7\1a[\90æ\12Ð\ frE\85\b=ʦh³\19\9aVö¶Aú\96Þü\8d?EK¼+²ìM¹l\88ñ©lç޾ÊBha|ù¸Ç\7fC\89ï¸ÐÅ<o\9e |øvV\ e÷Îê\82\88`i\8b\96&àB³TëMÇd\rùåº\9aÏ+Ì­O!ûR\ 1þdÂZ(\rð\95\95`\9b\8e\13\b¨s\0\89Ò\12È\14J\147\86\94#ÖjÙøì¢\17e\1f\8d¨fM̬!/l9Q2×yá¡\90wPÆÒ~5ÔC­]|rM\bÈ´°Ï¢j\ 2(\84T¢=)tÇR       &ÌVìN3\ 2K\1f\a\85\94Ï\b|¶³2Ø\10\95²}\8a!#¼XVáã¦h\9ft_\15¡ª4muë\91b\ 2ö¢¶¿Ìè\7f\1f\aJQdÙ.²¶<\ 2%\8c\1c\v0\8e\f\8aÈ{¼&\8d\88\r=\82Ó\90\;\rÿ­\9dV7\88Xro[|\ 5ê4\ 5\91yEO\ f\1d\89Y\860?\8e¨\98\84ÕD|\1cAýÉæ«"xÞê\813%xS\8b¾\80ñ\7f­Þõ¸ä \9fèÖ<Ù#\ 6ÒXȵ\10ã\1e#d¬\84a\ÙÍÈ\0iÉc¤\19(\90É\0Òñ\1dBäw\b±òa$c\95\8bí1¶a\89\1d@\12ß(­.\9aÐ' \ f\92\8fç\9fG01\84÷!Î]\1fçIªº8÷̺È\16Dw<\f\1cªW0\ 3\18\93\ 4\9b\87®·n XÂ1o\fÔSìWHÛ\90\8eÈí\81ù\f\9ffاqD\82\92?¡pÅU\10\82I\bAÿ\7fZÕ½N\156|/´¢\97Ôý\80q\88\8b\13¿êÄ£å\9b¡1\88l\9f¿ëjQ\10ásw\ 6\14§*â}h\7f
+åáÃ\8c(\1d\7f(z^ÕSuGõ#É\87ì§Ð\9eR?Ám\94ë\97ë¦\v\8f$\ 5%)\95)£=HdgSÐ>÷½\1aÿ\82Ö{ê±\82zläã+2T\r?hà\ ee^\ 4 k\17Ñ\9bPè¨*KÇR¾Õ¸|´¤\1cg\95Á@¸\eØ0\93&v\90ÿ\8e\7fCdkÞµ\vØaZ-\16\ 2ÒA3\86\97\ 4c{dÚ\85!\94f ×\0\87x8é=\ er1jÚ\ 1\82.²º}<\94±ä)3Vo×2'\1fBäÓ·Ï\1e\9c\9d\9b0P-|P5áè@\917\9d®ê\90æKZEêà\82\1aTx\ 6¢a\94§\80°!  Ç¦~\fjK «¥¯)¦w\b,\vU¦ñcD\v\8bV·!\r\ 2ò\r\1d\ fçsX¯\a\ 3\9a\1e\ eh6¨\80\v2äu=\v9\ 4\17\880=hµ\9e\1ez\9c}\94À:\1a\14\80ð©?\94°5^#+Ìt_\87Ã\1c°Ëfýé\9e"S.˶̼N\ eö\e      ÚÛ\91\8dá\19¶´[³Â×\ 6ç\85±v¶+Å°6/\e¨\a7«²\99\15M÷ywÐY\90\98ëºZЫ\8fà©\8a\98yÖfÄÜ\88\ 6ï\91f?lP\1d¼6PV¦!á\90@cÔhd\99\86y\v¹\88\13\9f0\93\10z%ã7øùv\bzÑ~ Fª\ 2±5\91\9d×ýf½\ fl8ÊÑvxLÜ×\1eá<bÍ Ý:õP\19ùo\8f\18\18À\9dX\v9~°ñûÓª\a\8c\ fl\ 5]1qéfW\84\96\14®¡!\84ΠâÓß/&D]õ\11\87\13æͲªÃ\19\f\8bàt 4\14vÀÀq\178+\ 4á\86\90\90I|\82é©ÄV½V6\89\a\94\eX\96\17{\1a\b÷½ÉÉîXz×\1dÃÖ½\0çðM²s\1cÛ¹É\bë \890\97\9aGÞdHP_)wÿñS1+Ä=7\19\ e<©d$QÛ.ôé&Cqåð&cX\ 5¤\84\8arQ~!/§püí'\9f{o0ì\1d7\18\10h÷Ý`\14ßru!9Æ\84»ÿêb\8f\19ö^]\88\14C*\9c\97/O\ f_ï:Ù
+f\ú½7\16þH\a\15\bþÿU\85£$¥BÝô\9aÓ ³À"\18n+ê½ñ\13 l$×åéÉÙ\ f\ 5[.«p\86Û©×8]\97®ß\8038ÿòüèòGâÜ1b]|,\7f\fÔãÓç\7f|\1f\91\13f?V\81\ 5?÷W(@ú~+º\ 1\ e\88ë\9a²N\98\18\92ÈE6­«»o¬®æapñÍ¥Ù«\99ä\82©Ôî¨öê\87©&\1d\9eùË\9bY\18,ð?ê']\98'\90\11ô\93a¸Âw\8fP®¿\17è\9eP\12þ\a±ï\8dË
+endstream
+endobj
+1060 0 obj <<
+/Type /Page
+/Contents 1061 0 R
+/Resources 1059 0 R
+/MediaBox [0 0 612 792]
+/Parent 1058 0 R
+>> endobj
+1062 0 obj <<
+/D [1060 0 R /FitH 686.127]
+>> endobj
+1063 0 obj <<
+/D [1060 0 R /FitH 668.127]
+>> endobj
+1064 0 obj <<
+/D [1060 0 R /FitH 634.254]
+>> endobj
+1065 0 obj <<
+/D [1060 0 R /FitH 562.465]
+>> endobj
+1066 0 obj <<
+/D [1060 0 R /FitH 514.644]
+>> endobj
+1067 0 obj <<
+/D [1060 0 R /FitH 480.827]
+>> endobj
+190 0 obj <<
+/D [1060 0 R /FitH 320.359]
+>> endobj
+1068 0 obj <<
+/D [1060 0 R /FitH 294.498]
+>> endobj
+1069 0 obj <<
+/D [1060 0 R /FitH 266.665]
+>> endobj
+1070 0 obj <<
+/D [1060 0 R /FitH 232.736]
+>> endobj
+1059 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F74 666 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1074 0 obj <<
+/Length 1729      
+/Filter /FlateDecode
+>>
+stream
+xÚ½X[wÓ8\10~ï¯ð£r\ e\11¶$[2/{
+i!ìR É²p\80\a×q\12\9fMìb;@÷×ï\8cFÎ¥uJÃ\86}±ÆºÎ7ßh4\92ïÍ<ß{~òt|òø\K/æq$"o<õ\ 2?â&\8a½ÈD<\10Ú\e\8f\82÷úZ\e6\1c\9c]\8c\87çÃg§=£ØxØë\aìu/`\17½¾\94\8a½8;\1d\9c]¢,ÙàìÙëÁYïóøåãs³µ\ 2´q­bXßέ\ 2ìrâ;\8dÎÆ'_N\ 2\10}/Ø(\13i®Eì¥Ë\93\8f\9f}o\ 2\8d/=\9fëX{ßl×¥'\15Ì\1aàÀ\857:yKȶ\97\ 50<\90Ò\8b\85\8a\8bd\99\81¶¾4lÜ\13\9aÝ\÷úP@\9d\10J²QþO\86Úy1ê\11yý àq\18ÒØO~è_åM\r¥\85àIÃ\rXl»Ï(\9f\15Ùä7°Rl\ 26Èê´Ê¯\9b¼,ÈDI1!»UYÝTy\8a-µ5G·\19d̵¼c\ 6\15\9bûÍ\0Æî X\18\ e:8;\8c\9e\8eî2¥\ 3\1e\995Qâ'\fk²YV\81ÒÂ÷\99\14h§0b\17¥\15B6\9e£é¢\905e\93,H´ÃVKü^A\8da8\1e\eÊ)\96\8aÕ«ë\9dú«EiÿS\1cò·µ\a°\aÐýx\97\81¼5#\19qZ\81#&KtÉ\8c\13\9a\1dä}á\a\\82±v&¹ø)äQ'r\19«\16¹\8ce7rl@äØ\97\90jDª\11©m´¨bDµ\17ø´\ 2¿=\0â«#²\eË Å\88â\1a£¶\18µÅ\88\r\88\11Ëe\92Ve\a\14·\ 3o\93m     %b\15\11+\ f\85ûføì¯Ãá
+¿\13®\12\96OÀ³\9a\19\v\fk\e¨k{\çð\93¢ç5+\90*W]e3Üë?tàëü{¶¨\ fBøâh\b\ 3\8e|6·ýáßÄä P6¶\83A\80i³ªÜÏ/\84õþ0X\1a`\99=AH±÷XÀnûä\a²Î\1a÷7¥²¡^r\ 3\r\87Ü\81fvÝõÁÐô\1dh\1f\8e      íÃ\11¡\85ÿ\rÚùåÅÑ\82\v\85qØíý*i2ÒÇE\98\fjʪS-·Ø-­\ 6¿T«IV\94˼8H§7½8b§?c.¡:\15\v\8d ºHLjw\90¦\rj\9a\97T½1`\7f¿cïÃÑíÍ\ 4dp4 "\8c[ (v\0ÁêÖæýýN|\10\8cg£cmIô\90´\\94\159G}\9d¤ÙÃÝâüp5ö;ª3£=7Ëj\994?Ö£M\86_¿zzy4J1á%º0S0>\83\\99\ fþØì\0J\fU{É\84\9c8K\96\8fvs\ 2L¹] ÚäThó,-\8bÉÃÉ\7fûçé\1f\87Û=Úk÷/«d\917Øÿ\86\14\9aç4úÁ~ðûyO
+ö|ôbx>>\³°S3\1dhH\89ËU\81    ZCÿM\89eÄêy>m«Ú¾\7fã´\19&27ûy±±\102\1cß&÷\9aaʳ\9d\ 1âð\8aÚ¯\9cAPF\ 6±´\8b)?b³*¡Ø´ 'ðw\97!~Ë:Çk\11ß\7f-\12\8d\92\aß\ e;¯EB+.´Û\11ï0Î%U\9e\-2t:¸ò®êlòä.;&ä¡X³sQ\16´ý\81h\9f\87&\ 4`p\87Vî¶å\12KÍr\88h\96Ç\1cÎq\95&t3Ä\96y\96L\90ZL81·¬IL¨µ\9e\97Us»£\86<\95rTÍÊbqC\92\e1;\91\80\ve\8b\89\9b\ fÑP}C9z?P<Vj\97\88I\96.\12\9bFH\97\12¢@»\13dåC\ f\9c·\0¦¾Z\aÂÕ±ORS    \88Ë*quxéEá\1aî\ 5Ðù+X¡\9d¥IòEæ\9aó\82â\97µ\89\1dHîU¢{¡Ë5]NCêiã\82\1fÊ\94Îb\9dk\8cÙtµ°*B\1d\80£\eÈÄ.¬I¡\92úM\92&áh È\9dSÐÜM\1aön¹°½êõô¨/Ýóp\89m\9d\9d\9b%u\e¯\17p\eB"ë';\8f\ry 1\80i\1eÅÎ\8b\ 2¾Ûçc?\8400ØÀ\81\ 2Ü\970\83\90\96Ë¥Õ\14䵦 o<\ 2ÿ\92\94ôÅ»ô$/fn\12\9c\9bÉ\90;{sÍ&\94`B#^\92ìÞÇW\ e\17
+&Ô=oóN®å._£Ì¾zX(´±«\99GÂ¥\ 5%\ 3Å"\1eÜÂÊ\90\15iØpÚ\11]#Å¥Ýìv\ 5÷&\ 5Z\8c?¼éx\8f2°á\85i{W\19\ 5ê\8d\v·á\våf\8e\9c¢DàÍ\1a<ÖµmEÙÐ\12ZmG\17\15ñ\10\bt\8bøß\8d\7fW\11áóX¬Õ~DûQBàð¥¾\95¬Í3\97¬×My\8d¦P\18ïóö`Lè6½\8eå\8d;B];êh\85¦=¼º}Ú\9ebÖSn¹Z¿%Òp!\1d\91¢Ó\1d/a8\1a\ 6ߺ°\14Ìôá\ 4§ªUQÛ÷1úËw\8e4\1cQwp\eD\ 1W±h­ôîÕéË\8e'FÅ\83\8d%ïs\15°®\81ð|ÿl\1aP®¹#¢[#\ 2 \89   
+\9d¡\ 55\11)\96>\18È}?Üõù\rSm\fµ\1cÜfg\13\99ðüq/"iZV°/a«Í¨\ 6·&q¹\9e´M\9e·È¼\8f@çTò>\ 2qiç\11-\81PµE \ 2Ø!\10Gt\13\bK«-\93\ f;îCRÀ\89\1eo\13¨¢=\ 4j\88\8câ\a³Aü\80í¸M T\e;\8b\92nW©]\ 2áà\ eþ_þp˺\87èý\1cn=\98ÿ\vÉâß\19
+endstream
+endobj
+1073 0 obj <<
+/Type /Page
+/Contents 1074 0 R
+/Resources 1072 0 R
+/MediaBox [0 0 612 792]
+/Parent 1058 0 R
+/Annots [ 1071 0 R ]
+>> endobj
+1071 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [165.458 189.585 180.18 200.433]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.1) >>
+>> endobj
+1075 0 obj <<
+/D [1073 0 R /FitH 686.127]
+>> endobj
+1076 0 obj <<
+/D [1073 0 R /FitH 286.231]
+>> endobj
+1077 0 obj <<
+/D [1073 0 R /FitH 219.569]
+>> endobj
+1078 0 obj <<
+/D [1073 0 R /FitH 175.486]
+>> endobj
+1079 0 obj <<
+/D [1073 0 R /FitH 145.295]
+>> endobj
+1072 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1082 0 obj <<
+/Length 525       
+/Filter /FlateDecode
+>>
+stream
+xÚÍ\96ooÚ0\10Æßó)ün\89¦¸þ\13\9f\9d¾\v\90\94t\83±\90\9b¶IE%ëФVbTÚ\v>ü.±!\ 4\98Tmj6!ñ\\1eYw¿Ü9\89\19¹'\8c\ôúEï,5$¢\11\b ÅWÂ\81Q\0\0åB\93bA>y¡ð¿\14\97\96­\95\9c2\90\98¦^3\18ÅÓ"Éý@Jé\ 1õ\ 3­\8d×Ï\8aY\91'ñØÚ£$\1e&ù¬JÖc\8eà¹\8aÕýê\ 1W\bÊ\ 4\ 6\10\82¥`~\10EZyÜ©p*«\9a\98\9cFJí\16+Q¯­DX\91VB+Ê
+XÑV\8c\95ÈÊ\7f\99¥ºÛ@Q!Ûwü:øËß©6np¸8\r\8fý4X_\0\ 2l­Ûõ+\17í\9coGNÙ8ûÙ¡\ 3äÛÇ#\9aÕ\913ßsê»»\1eÇ\97'\91_¸Ë®x69äÉ\93ëÆR\1a÷{:îßø\81   YÇ\88`D]|\84Ï¿Üã\99f\83\eJ©[Ðé ¹ÂúX»Bh¶§\89DM\85 \Â?\99$Vÿp0I´>6\16H\1c_\9aO~׸\17\81\84\1dd=8¬\8d\ 4Í4\1dÓ°S&u\82ixÀ4\8d·\8d\92]ozÁ±bµÃâªSõÕÆ}wÐBP. \e&h¿Þ\ 63\f\e>
\98¼\e÷ó\ ey\ ezôþ*~ë\1eÈ\8dýR½I/f£,-Üå4uA^þ°Á\9fA¶N\18í\ 3\8e\8e(c\11Á\ 6Qc¸Í\97\9fVåöè"Îý \f\95\97\a_\18o½üÌxx7_/\1f\1fÜ9¦\9c\95\8d§¾ÐÞü®Zø½ú+×Ï:Þ$Eï\17»\99ñ£
+endstream
+endobj
+1081 0 obj <<
+/Type /Page
+/Contents 1082 0 R
+/Resources 1080 0 R
+/MediaBox [0 0 612 792]
+/Parent 1058 0 R
+>> endobj
+1083 0 obj <<
+/D [1081 0 R /FitH 686.127]
+>> endobj
+593 0 obj <<
+/D [1081 0 R /FitH 244.632]
+>> endobj
+1080 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1091 0 obj <<
+/Length 2662      
+/Filter /FlateDecode
+>>
+stream
+xÚ­ZK\93ÛF\ e¾Ï¯Ð\91ª²\98\9b{s23\9bÙ*;\89=\9b]\97\93\ 3G¢4¬\95(-Iù\91_¿@£\9b/÷hìl."û\85F\ 3\1fÐ\0(¶Ø-ØâïWßß_}wkä"OóLd\8bûí\82³,µY¾Èl\96ra\16÷\9bÅû$KEº\\19c\93»ë\9b×÷w·w?¼\Z\95Üß-W<ùiÉ\93×Ë\95\94*ùñæåõÍ\e|\97ÉõÍ\ f?]ß,\7f¿ÿÇw·v´\ 3\8c¥Få°¿£­$N¹b\9e£ð\¬¤à©6b±\12\ 6ÖJ?;\9dÌ^¼_iÆ\927e±\81M\81¿¢Æg\9eØÕCÕQ×¹n«]]nh ª\97Â&]¹+\e¿¢%\16\81£\91\142\9d\ 3\8f¿¾¹ù5v\904c2Ì\ 1\ 1\92»m\8c\9cMsm\9e¡fRiT\98SµÄÝ®)\8b®D){v»G:¢Mø\v$\ 2âQ"Í\84^¬8\87]4­ï\1eK\98&2\\0êArØh; w ÷C\81\92øL\8dõ\91äRTn\99I\8e§®:ÖÅ\9e\86·ÀŹ)[?ÖPo\90esjÊ®\18Ï_ã\0pº+\9dtáT\13î6G\98\ 6³Î\87Ò\93\0í(¥\91¢{\16ôØ\9eaW`¿¤æ\87¥0IÙ´°\11u\1c·øTpF< ö´'G¹\W¿1®Ö\8e)\aÝ\1c@²+\9a;lÛñb\8d¢\8añøa©³¤Ø\9fKBö1¦WÐ\19³ò[Pò\82l\ 3÷td\83B°Óé\1c\9e\9brMòÙ\14\ f{?¯X¯\8fͦªw~ý1Р  \8b\b\1eÞÌ\ f\97\95\95©â\19 \86¥R(bJ_2*%Q\eøà\997*%ÆF\ 5#S£Â\15\12©\91:\88âöÕ÷ÿ\8a\88˦BÚ\91Q)#\93{:&\10~õÏ·÷ÄÁ\ 3)\9aºÉLüæÎD\9cip\vÔ\94\9c\8f²9\ 2ÝLð@7\17\94¾\97Ô\ 4/\1f\15 q\ 3æ\ 4=Ò¡g2%èÌÉ\ 4ÚÛ¦8ø!D5>\ fź9ÒëÃÞ\9b\0
+î?mÏO\14\8aź;£e¡\9e?VÄ\ 2Ar\f&Ùo       cnKè:U\9fÊ}Ûã+¦\14\ 5"\8a(\85«Ñ,ÅR¥{\10ÿÆ\98üRs&åyO\87gsà       ¡ÀMÉ)ò²KÈË2\87<x\0òP\ 1\ fèÉ\10\80à\83F\0\84    S\0â§ÎÊ¥\19\9dõÇ\b\0u*\18\1f{uÕ\ 3\10\b{\0\ 2\a\ fdlÔ\18\0\b\0ÌÀúm\14\80Úê@\17î\8dvb»\ e\80\96{ÕÂðcYí\1eÝ\19©ít\ fÏ~Â\ 4\ eX\80W\87\ 5x\ 6øÁ+ÁÏ ü\fÁOãuþ<ü&|üu\18\84Xcð£\83^&\18\ 4g«¸þ?1(S=Ç ¹\80A\951w\17ÁC(ò~ø>\80\ f[=ø\10£\88\ 1·*~Ð\1cB\9fÞ»ý|÷CÌ\ 3
+°55\ 2 \15\ 1(H\98\0\88\aÄF}¤g\0¢\87_\9e*\f¡¦¡\81\8b \98\0\19j\16áR@\ 4ÈÕ3\1eAæ©\1düt\\eYª­\18´\ 1Ûqtè\0\8d×G\fj$sκ#n\84¢\1e\90rK=Eã'Á\996xs²<)? °K\7f\82îñxÞ=Ò¤c½ÿì)±\11%'\b#áVQ^\ e\99\875RW,KÚ3\98\¶®|,\82\9dÚÝ°n°¿\18\9fi¤¨}Ü\84ã(\ 1\9b\80g\a\9eêÑ÷\9dª5ÆNÔ ÷ÍQ­Y&\82Z\81*=3\b\8dê²ç b\8c\10jµeCB\80y<OüEÒ\95\1dµ\8b=`ó0\1c\86ç\14Vq\eâ$èy\ 4\89\96Í\v\8c\80\18\9dÕ­\ 4·\0«>Rs\8bq\9eë§Õmu8íÉ=mhàT4­ÇÚ\8cM\9cZ\ 6\81\bÇ``j\89ö\92%\82\7fB>¬\1c,\11ºF\96hgq\88[\11µBÃS>$ `\85\91k@\80åðq\1cbóÞ
+\81°·BØs°Bh8+\84á\99\15\1a°\15\13µÂ\8c?i\85\90\ fäöy\9f\98\11\a+íMP\ 3Ç÷Kà÷¸+Ás7ÄÈÇ
+ ù%#p\85å"ÿ\16\9f\85¦\9a\ 5´!åHt\95\85Ë\r¬ ­þ(©Ë]'~\88d\97óÔd|\96>Tíiï³\17øñQ2³\83©IfÀiì\¢\80ïx4w\1d1ë·\85ÎÉ\95   mwu9\a\95%oK?é¶Ú!EÄ%\ 6\ 5lÑì\16ôòÆ!\14)\8a\94Ï\80ë\ 2\93\97;H¨^Ä\fÄy;Ù{;\fñ\e\7f\856\14þàmY·\9do\fW-XÌó¦\94_0%\91S\9e,r\13òdì:×à\97\\1a\ 1\16EI\17Ä»4mbXn}üzcàñÕ\b*ÿ\8e\1a\16çã¬YI\8c¯B\92
+´É¶ð­\ f±°\81\85¼ô¡\16v\8eB-\ 38ÍfVö\84mÉÔ\1aõ×\87¼\11\1a`lD%ÆNîê\eß 52ã9\b\80a«§0àì"\ e´Ç\81\1ep G.\15[3Íë\võ\12>Öü»è\19d\9eO4\1fn@$\1cÔ®Çj×^íz¬v=Q;(\81\89?¥ö'<*ÏÌsqM®Ìeµó±Ï|Ríf\88g¿Fd!\80\82+{æ½Å\93ÞÛ@:cí·\80\v½·èK\v"ê½EðÞð\122YwËû\92\14\93)(wª\94Yª \92\10l ífµ/·\1dMX\1f\9bÚ\9d*\96_\ 4ßo&¾ße\19Á÷;\17º£Â\ f\16\97Cï³¾\1c½kÌ\97Ï,Í\80âøÌÐø¥ØE\19ªh\99D
+\1f»¨l\1c»¨\99\8bu+â±\8bLs9¤Jo^GÔ©àÊ\1cÛ\99é3M¤ëC\17``\b]ÔÈ­bc\9cÁ²4Ïy,\83ý
\88\8bR±$\15;\92J\9e\9cá&\18        &\9f\v橻Ǩ\14¢øA0×QÁh;\15\vÆö\82±cÁر`ìL06WñÚRîj9ÇÆEÎ>¸çTÖäY\82fô©Ü¬|®\8c#\8d«òâÛ\87jS\1ei^\1f ¬\1dM\96Ü¢Õã¢@Ï¥\150³-0ÞÞøÞ.\16p8\vR\ 2+\ 5\10U\14ãôÀo.X_å\84\88\v\9c\9c\81Ð\11ý\14øMH\9a\ 1xBL`wus\7fõ_oJ|!\84N58+¡-H\9c\87«÷¿³Å\ 6\ 6\81\19\17Ì~tS\ f\v\ enM \88÷\8b·W¿ÐW\88É\96H+Ó\16\94I}Y§\99Z »ñiÝ6È\a\8eãk*\rµÚ\12\8e¾Aµ3éj\1d\94Ã`BU£C¡<\85z»ê0\11       ÊÒ¦Z\88\88P%ø\18TiÓvÔ\b5\10¥¨¦«\9c\13\ 1BoÄMë*\9c9$ÄÔ{(Cé¼j\ fÔ\15H\9c\1aç/\11\1f\eêqU`Ød\9a£ºí&\bð\92©\8fõÊï\ f\8eî\b,˶ôu\1c\97ëM\1cmUW]Ee\1f\15\88Å\voñþû\f\97\97*z\92jÉ@0äpØ5*åÉq\ e\17¾zÈ'ëÉpWë¾Àðó2Ï\92\971\87(\ 1Dù(\97\9b\15\85\18KÅ<nºø\9d       \12\94\82\1eý1à}\\91¤¢\90\19*\92ü©#ØÔ\f\17¼?Âu4ÁÊ'é¨\ 6ê_\9dÂÁ¥Á\8cþVAõi\1c\18\88¿×s\ 6áì¬\9c9C\9f\ e\19\96FO\1dÆ:êhÐÄð5§\9b}<¹/\13j;ÔÛ}Ú¦]\11\ 2G\1c\12\1dg
+\1c#\9a\1d\89\1cg´3\8a´[Ä\12\\99\86û\18Fq\91\9c\Mós[­\11ñ84­øã\9c°¨ðK\90]OæH].\95Ã\8e991ª\9b¢+7ýµÃ¹¿\1cD²«úÒ\16v?P~û\94'ÇZX\7f¾\99º!uÑÌ|\85ºuj³þÊü[\84\12xt©þ\ 4:1\85¾C\ 5s\96\94\95Ç'óJ\87'aÊ\r»\98r¿ii\80\92`èFG\85jæáë\1e\8e\ 6DÚù\8f\8a \14\ 5\17_>\9d¯Í{\rÉ\9cÏ\80\bc\ 1\880VÕàü\ eÞ÷ÓÇ\1ea      LШ\8f\9d'\81öLå¾jïÃNüþã©ôß\81ʺ¿¶\eÔ5\&wu\\8dôñ\89CèÜ\86/E~³W/Ñ´ßQcøÒ\15>T\rß    üÇ&\ f\96)'Åé´¯ÖýÁ8\\1d\85\1fñ\1då'\blÜG[l\1d\9cÇ-ú2@´n\11î        ïÇ7å¶8ï½#ÿò\93©ëæȱ\ 5|ÁÃ`\v\a_¹?\10¼£Æð)\ 5\1aç¶Ü¤Ñÿ\ 4@¸ñ?ɧ\17\93
+endstream
+endobj
+1090 0 obj <<
+/Type /Page
+/Contents 1091 0 R
+/Resources 1089 0 R
+/MediaBox [0 0 612 792]
+/Parent 1058 0 R
+/Annots [ 1084 0 R 1085 0 R ]
+>> endobj
+1084 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [401.241 418.519 415.963 429.367]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.1) >>
+>> endobj
+1085 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [429.742 330.05 444.465 340.899]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.1) >>
+>> endobj
+1092 0 obj <<
+/D [1090 0 R /FitH 686.127]
+>> endobj
+1093 0 obj <<
+/D [1090 0 R /FitH 668.127]
+>> endobj
+1094 0 obj <<
+/D [1090 0 R /FitH 616.177]
+>> endobj
+1095 0 obj <<
+/D [1090 0 R /FitH 571.943]
+>> endobj
+1096 0 obj <<
+/D [1090 0 R /FitH 527.709]
+>> endobj
+1097 0 obj <<
+/D [1090 0 R /FitH 459.565]
+>> endobj
+1098 0 obj <<
+/D [1090 0 R /FitH 405.313]
+>> endobj
+1099 0 obj <<
+/D [1090 0 R /FitH 370.543]
+>> endobj
+1100 0 obj <<
+/D [1090 0 R /FitH 326.862]
+>> endobj
+1101 0 obj <<
+/D [1090 0 R /FitH 296.521]
+>> endobj
+1103 0 obj <<
+/D [1090 0 R /FitH 228.376]
+>> endobj
+1104 0 obj <<
+/D [1090 0 R /FitH 206.115]
+>> endobj
+1089 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F61 1102 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1113 0 obj <<
+/Length 2359      
+/Filter /FlateDecode
+>>
+stream
+xÚ\9d\19ÙrÛFò]_\81·\ 5«L\ 4sáØ7)+ÙÞµsHLª¶ìT-L\8eDTH\82\ 1@+ޯ߾\0\ 2$td_8=\8d9úî\9ef\1c<\ 4qðöâjqñÝM\16äQ\9eè$XÜ\a*\89£$I\83$K"¥Ó`±
+>\85ÖÎ~[üó»\9bÔ\8cVª(N\f\1cCk¾\7fwùÓâúv67Æ\84I4\9b§i\16^½_Ü-n¯/?2úÝõå?®oïð°\8bX(èÆ1\19såL\94\ 1\1ds\9d\ 2Òð\1dÊE£½Á§¹\8bãðÖ\17«Ù\'yXìxÌæ_Ê\96Áî)\1fv^\16\94»\99NÃÖ?øZv4Ì\9aÍG¬ñå\1dkw¼f$'\e%¶[\0ÜZmÂźlä\1a\19\v\1e¾Î\9c\v\8bÍÁóô¾®¶cz=\90\95\85\87­¯\8b\16\16©p\857\82\14@\ei\9e\0 ¢Ü9¾mS6È[¦Ãê\1eG\15¶kÏ\88\ 2\8fáÛÊMñeãùû²ÚT5¯höÅÒ7o`\92ëð¡ü\8a\eü\8e¿\952.f\99\ri7
+[\ 1\97qP?\ 4\fÜ\92ØqY\12\99\13m° R\10\84Ðó\9f_v+ÿ9V\16\14ð7¦å(\vä0\1e³VîVå\12D\80âË2à«h\19ê9È\98\ 3\ 6ËÝ}Uo\8b¶¬\88ò4|Dí\16²{Wµ\8c-\10\v÷&C©ÀéUw\8b ünI¨påkâ$\ fß·Sd~¼\9ce&ü7\18µNÂ/´Åó¤ÙólY"×hu¼\ 4\18¦Û\f\92¹\9f©p¿A~\89~Ä}-\v^Uìxô\7f¶¾Þ\15\e\9em}±k\902«Ã÷÷r\f\7fª}ãkÖæj\8adf\9f\18K\ 6\8a\1eÙ[À\eÆ\17\8c^ù£$\18sd\19&µ¿?4\9ea\94\1cl\91\ fk\ 1\9a¶öÅ6\9aôún¼^\ü!\96¦\ 2­]dµ\v\80\ 1\e\17\9f~\8b\83\15|\ 4¾À!Òà\91\96n\ 3\r~¨rôÔMpwñóy<ÓFE6Ö\81ËàÌT±0~E^X\18JC\0ù\9e­\v\89½#ëBR§IJáh}J\91ͳ¿@\91\85¸\99e\81K²È)Ë\14Å :\95êpà/Ñ\94\1a\95¬»õË\88ånÓX¢ëçØÅ\8d\17¡ßù%\99Õ\93\1eL{#\13©S\1f\86cÔäÝzêî«·g\97Ûð\ e,\9bÂØ\8b4\18¢A¿LCÂ4\98\9e\ 66÷4ì\ 4¥"\15CºP\90¾\94ë²\9c`¢<{\117OH-£ë´sOÛ\82Í\130­ä¯\98güTÚÕ&\ 1\18Î\ 4£PIÆ·/ÈL)^qR5\7fGß·á5e±\ 3Hy\8bR¦¬±âE\1f(9 \84É\ 1\95qjÜͳ\8e\bbÈA\92\1a\ 4¤#\95J\ 1 \92g\12¯q1Å\r\18´\85Ä\vdµ<=æ^\9c\95\94ä$÷Ò¦éÜ\v\120}YñÃ\8f\1f¯nÏӯ͢$MºExKyÿ­Ü=\1c©±yÈÉT®¦\11ª\82\86!\8cÓ`<µäÙ<\8fâüDù\rD´Ý
+ÃmæÂ[ÎJƦ?\ e\14\90\ 1¤à\a#    \18Æ\a\88\97 d¯\1dCZʧ\0\94\9c\9a\8cØLÓ(360`®\9d±I\95\ 51a \ e0(ëÐ\ûu\9fã8\9e(Hâ(vº\93\88â\8b\85_\80$/        iÌ\1aÃEÍÞ\8apí÷µ\9fw2\ 1\19\e5\8e\ 1\8d\17%âæ\9cT\b£\9aâÐ\82\1d©üe\ 6!\1a\1aý:\ 6M_qAt\98\83\9fS¥qnCÆF9\ý\82        \81ÊÓ~\11¥ë\8dpEÙ\11FHr\82©v\9boc\8e\v\9e®Åª\85\9e\e,\9dÈ\1a`ÉþÀ¢eq:\eÙ,\1f\8bó×+,\98\13-9\12ë2\93Æ`9D\ 1à\87i\e¦äîEWM\0âX|À\ 4\94\90±!dÈç
+Ø2@\9a3\8a\8b2D\1eY\85É1¯\9f\9eÖøÉÚ\87ó½       ÿëkÉü\1d¦+Þºô_´ò½+\ 4\86õ\95Ô\19¥\84-ªÕpñ²¨G\85\859\96T\87\r\1c~\12\87æ*\8dR\ 5Fªcx®tÏ\84ô¹h\95\9d\v\13~% 8\88T0\e½\12hÃt¤rðJèMòç_.?\9c[\19DQp\88ÁC!1±<\14ðà¡~ó$ìÐ\9dá9\96\ 2\8c{\906Öö _±§\f2\9e>y\1a\10c¦7J\9e±Å\8a\9eò®0˱\8c\ 3\89J\ 1È\18\8c\12±/ØCId¸\87\r\95áÇ5¾\1c\10ZVÛ=(n%\8b\f»êf*\8d#7d\b\87%½Ì\9cíkdH¹R\91\ 3²)¶\9eQ§µ¹ÊÂ\ fEÍÏ8XØ¿*\1a\9e\1fm\117¯Ë\87u·rÈ"X¾\9cE\1a\99°ö%\87pG®\91r\98dõ «Ú,¼çÐo¡R/¶û\8d\174'\ 6\a\81B\8cW\14Û\8a\12\14¡Yê5'\12×ù?OÀ\8fI}E¹+»\1dízòÁÄ\ 2B7áÐ\0ɧ¤3Çî&^öX¶ëÎñ02øÚ÷\86\ 2¾\a\1eßÂ\85Í«|,{ÆÇlN9\18\aÇ>\86àÑÇp6ò1\9b?U\r¤*r¶÷±\7fÝÌ\8c\ eßÞ½{\7f³8÷5\97\19>Êó§3\ 4\94\7fÚ¼îØ\ 4\9eúªo\ 6\88\9dÌ\8dÒRq\ eÔÁ~«\13ö[\1cÁ-ÚR\1e¨IgÙ\0\ 5\17q\eApAR5¨F*¡d\ f\84\87¦©èã²ì»\ 3´\85Õ\89\90/\96¨Çuw'Í~§ò¸e\9cD\ 4¡\8aì\9f\1eËÕ\94U\9dY\a\94¼Ä  =>ã\\1eø\80¼¯ÙC\ 1\94\16\ 6þ~é\8b\rü@]
+Ýñ\ eÀ¦häÌßÉ\v¾\rÎÂÎ\ 4\16(-Ê\r\8d\9f¿PÃ\ 4 Ì:o¦"
+u\`\ 1ɯ­êî\ 5²b4µ6\8e4$áaßW\804O¦\8b/\16J|Z\97\8cl    
+9õZS\82ó²n)\16gÂîãºÜø\13
+7\95()\932õäÚ,\8dÌkM\18"\1fV;'Å\1cW\87\96âw\1fq\18AT 0©Uü\80Zµ¹f­É1M¹[ú\93\ 3\b\89²i\ 3:§6ð6Á\98ÙN\86\95\ar6Ò§ \ 6É°\96`ÿÉØ\7f\10ÁUBÕ\88³\1dC"µY8\8eb\83£+/&:5TÃL¾`éÛíõÍ«"cþ\õ¡ùu\ 2\83\96êC\r{\94øaüNÒO¾\93T\ 4eZ§ÿ\9fn&*f\17Å£\1e¥\8d\9f\b\87:\8d\9e=+\8b´NÏ«e o`<Í\88Ãaq\ 3Sòb\8a\9d:\86Z\18|f\» \8b¦nÜ\v]1NZ\9e)\17$\88a7I]ßò\1c\0½/ÿô\e\ 6¹GH®\96\9eg*\81\ 1Æ×ô<a\19¼ø'{\9e\8eúq\1da\13Ö<êÏ\9dI\al@\89ò\e\9e\8e\1asZwq\r\8d¹×d)âîk2\95÷û¹ \86\8fǾ\1cp'/=TÑrYÕ+v\vXÞVSAUÞ!gÞÂ-Ë×8\ 3ÀÏ\94       \19uÈq0R&dCgÀÙÀ\19(¡k´`ì=âG `xL-¨zÔ\18\82\r\8a4\83\9f\98\e\84Æ=è\8eîQ#\1aWZ\11£u±$\9e¹M©_¼ã¯\r(\ 4ÿéÈ»Þ?#Y\e\b\13\ evó1\80\18iÃ3n 
+\9cb\8eÆ=í\13%éÿ­
+5©\8aË\ 6Å=\11\13à}\9cØÞã\7f¸»\9aø\17\ 4Ê(uü\9fD\9aÇ\83\7f;p:´4~Ö\9dß\95+ÈNîÅX¦º\15oäè\86£õÀ§\11Ý·ÛáÓ+ü\1a\97%\91;÷ë©>Ùõââ\7fÒ\9a¾(
+endstream
+endobj
+1112 0 obj <<
+/Type /Page
+/Contents 1113 0 R
+/Resources 1111 0 R
+/MediaBox [0 0 612 792]
+/Parent 1058 0 R
+/Annots [ 1086 0 R 1087 0 R 1088 0 R 1105 0 R 1109 0 R ]
+>> endobj
+1086 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [388.905 643.276 403.628 654.124]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.3) >>
+>> endobj
+1087 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [371.239 551.976 393.71 565.924]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.1) >>
+>> endobj
+1088 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [376.982 540.021 399.453 553.968]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.3.2) >>
+>> endobj
+1105 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [460.436 205.315 475.158 216.164]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.4) >>
+>> endobj
+1109 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [441.365 117.248 456.088 128.097]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.5) >>
+>> endobj
+1114 0 obj <<
+/D [1112 0 R /FitH 686.127]
+>> endobj
+1115 0 obj <<
+/D [1112 0 R /FitH 668.127]
+>> endobj
+637 0 obj <<
+/D [1112 0 R /FitH 480.123]
+>> endobj
+1116 0 obj <<
+/D [1112 0 R /FitH 450.093]
+>> endobj
+1117 0 obj <<
+/D [1112 0 R /FitH 382.149]
+>> endobj
+1118 0 obj <<
+/D [1112 0 R /FitH 314.205]
+>> endobj
+1119 0 obj <<
+/D [1112 0 R /FitH 234.306]
+>> endobj
+1120 0 obj <<
+/D [1112 0 R /FitH 178.317]
+>> endobj
+1121 0 obj <<
+/D [1112 0 R /FitH 134.284]
+>> endobj
+1111 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F7 674 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1124 0 obj <<
+/Length 1702      
+/Filter /FlateDecode
+>>
+stream
+xÚíXÛrÛ6\10}×Wà\91\9aF\bî\97\10§v.S»n¬ée\92\12lq"\89*I%q¾¾\v\80\94(\8bRìD\99´3\19\8fL\10\0\17»gÏ.\16 è\1a\11ô¬w4ì=<Ñ\1cYl\15Shx\85(QØ(\8b\94Q\982\8d\86cô:Q\98ãþ@k\93<ýíôôølØ\1f\93çÇO~9~Õ\7f;|ùðÄ´dÀ\18ÖÂÂ
+ák!ý\94\1e©×Üõ<\1eöþéQh\12D\11Õ\14{iJi¬\99E£Yïõ[\82Æ0ø\12\11¬­F\1fÂÔ\19bT`
\ 4MÑEï÷hS[\1dª5VD %5fBE¥þè\e\9e¤Ó¥ë\ f(#$9Ï>ºi4ëÄ\ fåÅ,­\82ÞÝzIxZq[/aÍ=ô2 \ f -\bfÆDµH\7fÀ¨f\89\1e\11¯\8e\10IJç¢n\17nTeù<(\16u*®Ql¼zÖC¯Ã$\81\ 5æ\e\98\83d\10C±ï\84\8e\ 1¥ØJ\19\97¤õ\92¯\é\8a÷}¦\13\9cÈZº±¯Ñ\8dÝY7¾Z\12þ¾fIºsÉnÿJk\80wì>¼#í\98Úô3ÁJ\83L\r\ 41"Z6\fü»\9cÖ\86(,\1eõ\aB\88äxî]°ìÓd\ 6ÔL\\91Vn\1c\9a\95UlåW\11\8cs\98Ö\10Wxâ\8aHÜòN\11×\1dy\12\ 2\9f2$!Z\8c¢{\11\10\123°q\83á\10÷-Ó\15ÃÄ")4溦øù  ØE\88\14ÉÙÅÑE\87\v\1a\ 5\ 4Å\ 62о\10ëR`\ 3zH\1f\94\82\ 2\8ca\ 3\9aÕ1æ\99Æ88Z#\8d¥f±ß3ËÿbBÛ°C·óÙÉéÑ\9fÛI\ f¢XHÖÌù        \88ËXB=Íâ\J7(\81\r5ÍäÇ\8f·Åù\16o&°\96\18Ñ\16C1Q+½Þ\10·\ 5\ 1\0V­§ì5Ñ´L|Þ\91×5\16TÞÇDû9\13Ù\96\89\90\0\94ÂVkh\bl\85ØX\8d\0&Jóy\14ä\1d\12GóÃ8Zü\87\1dÍ\ fãè\95\89\9eÀl&\ f\12õÂ\12 \90iv¯\1fQÿ#ê\7fDýwvtwÔ\vm0aâ0Q\ fDRÔ®\vHnmÂ;àå
+\93ïL C£ÛA ým,<\b\7f¾ \17îà\8f\82L\ fâîQ¬î.×%ÃJ*$8<µÝQ®Ëº\?[Î|½~    ÖÂÁ©\88\85x,Ïáx²\@¿©ûyr4ÍÃû¨\ fÿÞ\95±ó*¯¿riè\9fÄîó®º~oY\8f\ 6Ü`i\19<}Õ]§P¨|o\9d}\ 6\12λOÊ2»\9ew8ZX¬Ö\99â,Vè\9b\b1\85\rY\91/\8dú¾ïKY\1f¨ýk:\1aåÅ8\9b_Ç×*ïXÊzz®\b\ 3ç\82­\95¨ÄDÐfÆ\83Zt\19a¹ÎÞ{¼Ü<v_ú\97\9b84ô\88\ 5wí9\19
+p£º}.¼\ 5Ö\80\1a\86¥RhÀ ~\81\8f\11SþU\98\9ev\81
+Ñ£ôjN5q\9d°î\88N¡°V\1d       h#\elf u:¸\15ç­|°#Î!\90\b\8cx\90¾%\b¢\1fÎÇÜ@ÃçãúÖå\1c\122\87\ 3ýÓ|¶H«ì2\9bfU\9f3ðÛ¶ï\89Ä\94¬ö¶ø)ãÉ8Æ\90+ãë<¯b\ 3øV¸Q5½\89¯\93t>\ eá
+í«"\9d\85¦HÊìSóe5IëOÓ­\85Åj¤^|ã6Â3ÝØ$\ 4ür
+Gï*[\84%,\89!\ f\83Táþ@Q\96\f'\9e\8fËòA\a6\94ÀÙZ\8b\15ó_<íØ0`{â|\1deóq\97 hò\96\98.oqÌÖ\1e-'ùr:\8eª^F\1cãKéªh\bDjè\88\f\84F\ 3\1e4?dãjR\ 3d!Ûsz\v ¹\17Mm2qÙu°¿\8aïÙ<>\17\95>\8eak(\Y§ÇQ\95Å\8b'p\1e\ 4n=¾ÃdØÞu+k¼xúW\87Ñ\f\8cþ<v\8cÓ\96\9c¿;åHm·À£mðh\ 3\1e4\ 2xðüä\8a<^h\r\98$àk½    T ³ ÀR\97\8e]QÆ\17Ïlÿ\f\94\16\ 4Ⱥ\88ÛÊ(»º\89Ci\1c\18åS¿kø\9er\91\8e\9cç\9c\14k±ù|Z\7fP.\17\11伨êe\82g}£¾dôÍà\98®\e¸«°ï4\ 1n\10Tç\@å\ 1àÀL \97R«;â>|ɤ\8fí\19$eN\83÷µL\9e\a#·Ñ%>IÀ\16P'\87a`\9cÖ¾\91\17>Ø4l\95QXM%\18\8c\88ÅÁ¬\8c}UóeéFyà \f\86\88\f\83\85sÛß. ~ý\86«\93wa\17©V²BV\80\19õ\9e~\9dÍ»\80ñú1²ÖÕÓ *\:þ0 É\8b*N\b: \8f!XqÞ\8a\8a¸óÃ\1c VÑ0È}¬?lY\1e#¦Éu0+-²ËªH\8b\9b8uæªt\9cVéÏ{ë\83\8dÊ\89\11\ 3ÙÙ"\ 6[¬Ðj_åD\ 5ÅTÓ=×|á*\94j\10
+g7Ë×÷|\12\8a©¦\86è^\9fZ\8b\85 û*ÿÎõ7ê\11\be*\14Ô\94p\8aàju\93\ e;\99LTWåO¡Â»ËN¨¾Ù\96º\ 3\r¨6ü\15ñAÐо¼ZÝ~D4Ìÿ
+\r%±Ü\7f\ 3|w4$P\94ÑÕ©\90j"\13Úu±Àa¢à÷´b'\1cü\80p\b\83\ 5»O¤î>ãøË\16Æ\10\85ª\168·ã\8c£îrÆù¶g\9aVîú\17bu\8a·
+endstream
+endobj
+1123 0 obj <<
+/Type /Page
+/Contents 1124 0 R
+/Resources 1122 0 R
+/MediaBox [0 0 612 792]
+/Parent 1129 0 R
+/Annots [ 1106 0 R 1107 0 R 1108 0 R 1110 0 R ]
+>> endobj
+1106 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [291.566 635.706 314.037 649.653]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.4.3) >>
+>> endobj
+1107 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [291.566 611.795 314.037 625.743]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.4.2) >>
+>> endobj
+1108 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [291.566 599.84 314.037 613.788]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.4.4.1) >>
+>> endobj
+1110 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [381.202 397.652 395.924 408.5]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.6) >>
+>> endobj
+1125 0 obj <<
+/D [1123 0 R /FitH 686.127]
+>> endobj
+638 0 obj <<
+/D [1123 0 R /FitH 582.439]
+>> endobj
+639 0 obj <<
+/D [1123 0 R /FitH 444.634]
+>> endobj
+1126 0 obj <<
+/D [1123 0 R /FitH 410.548]
+>> endobj
+1127 0 obj <<
+/D [1123 0 R /FitH 394.394]
+>> endobj
+1128 0 obj <<
+/D [1123 0 R /FitH 363.111]
+>> endobj
+194 0 obj <<
+/D [1123 0 R /FitH 290.099]
+>> endobj
+640 0 obj <<
+/D [1123 0 R /FitH 132.137]
+>> endobj
+1122 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F11 573 0 R /F14 574 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1132 0 obj <<
+/Length 2014      
+/Filter /FlateDecode
+>>
+stream
+xÚµ\18]\93Û¶ñý~\ 5ßJMM\84\0\b\82t3Ó¹$çÆ\99Ôm}j_ì<àD\9c\84\86"\15\92òÅýõÝÅ\82\12)Ó7öÅ~ÐàcWûý\ 5¦Ñ6J£¿]}·¾úæE\11\95¬ÌE\1e­ï#\9e§,Ïu\94\179ãBGë*z\13gùê\97õOß¼Ðr\86ÉY\9aK ãq¾ÿñú\9fë\9b׫DJ\19çl\95h]Äß½\ß®_ß\ÿ\9d®\7f¼¹þáæõ-\12»J\83\ 4\1f[oÖW¿]qئ\11\8f\84ÔL(\11\81\14E´Ù_½ù%\8d*\0þ\14¥L\96EôàQ÷\11/S¦2üc\1dÝ^ýë\82H\86D\94b\1aTy\84\b sV*\15h|`%\91I\96\83\1c¹*\99Ì\83\91HÇ»\95ÐñûÁÒ©¶ÍvØy\85g
+ÉTÃ\1fõ\97\90Er      
+g3Yþ½~\91\14$\81m6í*\11E\Ù
+o²¸\1f:׬x¼¥#cìCù2¡\99*³'È·à4 ¡tö9NK?\16\9e\14ì\ eâÉ\82t}á¶ÇÎ\8eq'\9f¯\92,SñÏdøE\13H2Á6¸Èx\8f­\0Þ\1e\87ÅØ\8c\92\8cË(\ 1¾EF|Mwç\86Îtï\81aÊã½\1dLe\ 6C§;ÏÏÖm³íé\ 6Lî×\80ÐÛ\83é\f\86        \9eêvë6¦\ e ¡³f\8f{\11\ f;3Ðí¡kQÄw®²\81â\16Ð\ 6Û¡Ä e\12¼àe\ 3\12ÇÍp2\8bi\82ë÷f\83Dv®        \10\10¢·æÎÕn@ÀûU!c\1f\ e\11ÏX     QEdCX­wø·"\8f7í~o\eüÇ\80\17*~\9bòÌÖ\15A]O\97{k\1a´mÀ\19ZZ\83m\b÷Ø{\9f 6\92;nð\ f;º©Ý¯«3fßîmëå\ 6Ð\7fÛa \ f\ 2ÄÐÝoGçµûÕË\9fÌ\14\bviZ\9f\98Y\1e·\r® Ô.\Ô\ 6åÒÈ\rüAÀö\9e`\86\8e\16*[Vðøå@ ~×\1e½ÞÙT±ó\7fÀ°C\1d®\sßv{3¸\13ó\96\0\9dÝ[¯~ ÐÑ5ʶàÜÊõ\eÀ+˸íh\1dÌad\8dÇ;r¥ß{×ãÆþ~¨\r\ 6!\1eÀÛôGÌ\8b\12\ 2\1fXuý_\80\11\8a0Ь\e\9eÁU
+\92´     `$\ao¡Ö\8d^õ$ìïa\875ÅÛ×_ûÀÅÝ\ 6\82`A\8b\93±D\ eÉÓ¢Õ; à/|Ü7´3\84±i\8f\87:\0\1f|®vUÿ\fåÉã»ã@\0×7\7f\1a\b\7fÛúðð´Zº\9ap\14À±»`E\8aÃ\85W\9cn0G·\9d9ìØ\92
+\94\ eX`ú\1eå\ f\19áL\8d\92!\0í\8d«·/¥àTx\ 4=\80¡ì»ÕèvÀ\0Ü÷\ 4\83\f\1e       \8a\1eØ\8emÆ+\13\88X¶eÏ?LÛ\99\9c\\9dÒ\96R\12.vÖT\9e-ì}ÖÂÚ\ f`\9a\8aö&Ü\19ZNeJrH\18ð\96óz\ab>[`µn»ó\86Hî\\0mj,\ 5~Kªn\80\89\8f7!Na\9e,\95\1coÒãer@eôÜ`\9dУ\v\17VBo\8f\rU},½\ 3AD\98\9c\95\1aÛ\b\f3\19Ì\ 6Y\11A[ç\81³\fh<\9b\ e=)Ka*J&xoÓ4%Ìi£\82^,Õ8\eqâKe8\15¡è`Ý÷ÕÆ7c߬&zÙPª/µ\9c+Y»½\e@?²_\9e³\82Ï}ïãEñE\9d¡\87Jñ)*ëOÑ\18\8b©Ê\8a\87R4Ø\1eËf©C(ª\14\15Ò'\85à\\8fýZQTá:íÛ\18\f\96\ 3ØÌ 
\ 3%_ÈÁ@\ 1Ð÷½­   ¹'+É\82ñbn$ã\e¥\96TÂÆ\90Ö"D_]\13\14\9aíÞ5\90®\15h£ <¼l\b`ªÊ\85ª®©Þxt/«¾p\1e\0j×ûÂZøH\18y{­µ/xxì¡~ÕT\10ñ8¡±P\89î=iìôT%\b»©ÆëÆìÇR\ 1Å     \15\feä2WájÌU¬Un\1c¡Ìl\9cõÀà\1d}\1e,Çj\aaD5Ê\r=£@\81Ô"y\ 5\86JJ\83TQ\92ô0µ1\88\17Î\85\8a¿§\12%\83\v&\83\1cì\7f°È\12`\95\rdËI\0¢M
+\18\v\ 3Õ\97ÍÁ\17ÍÂO9`\0p_ÿ|)nSV\88S®¾\82\19\83-POF¼D(V\94!\15þq\1c>Æe>P\8fï*©9\ 3¯]̺ԧYXÂ\88«ùy\16^x¢å,ÏT$ý\ 3,LÁ¯\805\980O³xMó,t¯SÃ\83±9¾uÿ£:\v³¬Òå¼Ì¾MU\8aî\82\95{$È\92\ 2
\14çÖm\e\15g\13\8e¾è7\9d;\84°\aï\eL\9e\10      \9dÅ      {\83Àþ\11[\80¦\90F\97ÆÈ&\ f\83EcÌüBÄ rKÁø\98\ f?ß¼úÐÑ@\8aC  KÇð z±õ\rE¤©\ f[!T\ e!à7*¾\ e\ f&LE;Æö9S¦Ùðn\ 5\7f4õѲGô\159<@³Ïvþ\82¾@\fÂq,ÈÿY\95À¼s殶~öÎü\ýH\18
+\rA¬ø\17\89C\91+xxþÁ8T\9f\10\87ê+Å¡\80æ_äâ³ã°X\bC!ÑÇù)\fS0\86\86ª>\ f7\ráVÌ£-?\8f\93ø\98êú\10\ 17\83\1dÏ÷§)qá-ë#rqX\ 5\13dé¡ä6Õ\17\17E<A\94açº/%ÉÙAò       \92Ü·Çnì\8cO\15e9\14y\99Asùci     ©\9d\ 3\ 2×)S0\ ezE¯\83,§J\96]¼á¥\9c\8fd2\f$°Vöòó\89\7f\16\0\89û¶®ýW\89\87ÐòÎ\1fL\ 4Ó \ e\14\ 2VÊð\15\91³9Î\9bD\81\95\13düJAT\8bs\85=6½OöÓkjâ"Lõ !æÙ\ 5qt´\ 6Þ\92x\8b¯É\9b\7f\84·\bSõ×ä-\1e×;û\9a¼åã¼Õ"ïë\1eÉ/\fX8\f¨rlÏ\8b\1d\1c&/U\9e\9e\18\84Àù\1az5ö^:b\ fÁ\88øsØðð¨á³¡¯\84\92\7f\1a\ 6¾ýva.,\18\11£À\8e4R\14\v\14³\82éô3\bò|JQ.PTðä*\8aÇ(Â\13P1Áõ¼¼\8a\f\ f\1f]\19\1d¥²ÀW\12}\1a\fÝ2<$a¢\ eßáà¦oi¥/8¸\eq\ fµ\19ð\vVøË\ 3¾#Ü
+_Y\ 4?\ 5\918¿û\9e\8dÄìâ\97U(\82ÿ\a\8d\85\ 4Õ
+endstream
+endobj
+1131 0 obj <<
+/Type /Page
+/Contents 1132 0 R
+/Resources 1130 0 R
+/MediaBox [0 0 612 792]
+/Parent 1129 0 R
+>> endobj
+1133 0 obj <<
+/D [1131 0 R /FitH 686.127]
+>> endobj
+594 0 obj <<
+/D [1131 0 R /FitH 639.335]
+>> endobj
+198 0 obj <<
+/D [1131 0 R /FitH 452.155]
+>> endobj
+1134 0 obj <<
+/D [1131 0 R /FitH 431.386]
+>> endobj
+1135 0 obj <<
+/D [1131 0 R /FitH 405.877]
+>> endobj
+1136 0 obj <<
+/D [1131 0 R /FitH 371.949]
+>> endobj
+1137 0 obj <<
+/D [1131 0 R /FitH 312.115]
+>> endobj
+1138 0 obj <<
+/D [1131 0 R /FitH 276.25]
+>> endobj
+1139 0 obj <<
+/D [1131 0 R /FitH 166.651]
+>> endobj
+1140 0 obj <<
+/D [1131 0 R /FitH 148.718]
+>> endobj
+1141 0 obj <<
+/D [1131 0 R /FitH 130.785]
+>> endobj
+1142 0 obj <<
+/D [1131 0 R /FitH 112.853]
+>> endobj
+1143 0 obj <<
+/D [1131 0 R /FitH 94.92]
+>> endobj
+1130 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F7 674 0 R /F14 574 0 R /F48 455 0 R /F49 457 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1150 0 obj <<
+/Length 1953      
+/Filter /FlateDecode
+>>
+stream
+xÚÅXÛ\8eÛ6\10}߯У\fT\foâ%/EÚlÚ\ 4í¦Í\1a\ 1\8a$\ f^Kk\v±-W\92\9bË×w\86¤dÉÖÚÙ¸@_V´È\1dÎ\fÏ\9c9\14\8d\16\11\8d~¹úizõä\85\16\91%Vq\15Mï#F\151ÊFÊ(¸\8e¦Yô.VD\90I¢µ\89\7f~ýûï×7ÓI"\84\88\7f½~öüúÍäÃôÕ\93\17¦g\ 3æ\88\96\16vpÿ-5.¹¢aÏ\87\9e×Ó«¿¯\18\fiÄ"Î\15ÑFDJib¹\89æë«w\1fh\94Áä«\88\12aMôÉ-]\83Ç\82\18XJ£Ut{õç\81\11\8b\94h\88ò\84\11\88MÓ`Ãå¥\1f\12\97\1661`Ê\12¡|\ÿL¸\89óMVV\98\ e\19×MUl&,^¸p\aá\bA\89Tú;<\19I      ØHµ¼0%R\10É/Ê\b\1c2K\ 1(R\13JCJ6\98\92Ý\1aÿÞM\12LOÈMyï!3/×ëÜ­jê\13iz¬w#Y\ 2\13\9c_\98\bUê2ÜHï\8e\90D¥Âg©\97\84\1erNÁæÑ\8e\8c$\ 4l\19°uYF\98!\9añÿ$#\9c\13ní÷fäÑ\8e\8cd\ 4l¤L\\98\11àK\ 1epIF´t\ 5­(¼\93©Ï\b!äDô\8fÞt$z°ÁNÛ8\8c\9eö»F?\ 2f\r¡Ð,Rm iø\0^\14\8b]\95ûªWD>\9d$R¦ñÏÃ\83\86\1e\92ϲ\96$~\9báÄ\17üSî\9aѦ\11%J\11\9e²(á\9a\18é·Zçë²ú\82|cã²ZÌ6Å×YS\94\9bðæÞ?\9be\8e\ 3\13Ï'    \8bû~àì2ø\81ã¢ö\v\8b\f\97è¸)æ³\95\9fúT4K?Ù,gÍp\83·\13#`ÿ\ 4\1d\ag\93p\0ÎÅ;´)R\15¿ü\ 1\9f:\9e­V%nÿ aîfî]\1f\81\ 1\16\ 3:\8f˶³ªîVÌKÇ©Yî\7ffy½-\9aðÃE\87ÿ\91\15ï)\13yµÏ2ÌÞ\15\9dÍ1¢\8f¡¸\ eÝ\9c\97î¿Bgó±\97\9b\9aø\1e/M\0\15ÇCO¸$\96j\7f\12Æî\95\ 2\87ü2Þ\9dµ`Î\v\9dîÏ\1aÆÏs\8c\ 6æ \1aoÜö\0\85n\19"Z«/7Û\1dÚ\80üBBfë¼É«úé±ð`\148\8eËVxÜ\94\9b\9c\8cXOÚu       O\89±¡w½Þ5\ fí2¬ÂV"I\8e\9aà\88QµÕ]\ 5               K\85é*è¸r\ 4Ô\86\89$³DÒ\0ç\eØ\1aÜ°ZÅS<\82/[8v\1d#z\81<ãÛ\ 24ÆWÄ°Ë\9cs\87\ 3\8d\r\ eò=M)\1cz\rOæV  \ 3\11«¨¿æ¶XlòìG°Ä)\85\ 3©çU±õu\83\959Ûd¾,«\1cÙxî\90p"\e\94A.\8f\94\9aìñÉh6\ 6\1a\13\16ÿ30ÉÛë\9bç¯Gd&¬\11\8e\9d|4¾cÀÙ\8a\94ÆÓe \1e\ f\16J³¡V[\8c\82#\98\1d¤ó&èÞÛs^¼ôU\97/\1cÎ1¯\82ã¹AéÝ\94n\90\94²{µ¤\9dZÒN-á\ 42
+>wuû\ 68Áó
+\ 3Ðij\86îu\92j4 Î)¡\96\rÿå[\ 3\8a¹|VU\81¡\13-\8d\8c\9fM\92TêxUÔ\8d\1f\81ßÇû3\8d<Áº¢|xçD¦\84Ù6õ¡,}\ eZíè`ßï\1fÿL µ³Õ.¯q\8a<\8cO\ 1\95f5{tµ\8eã\93Q¢tððíÄ\82\vU1»[¡\17\ 22\ 3Ng'\98\83ÃåJ¨3Ì\ 1w(ÆN0\aãÐ\0\aà03 \ e¦¨Dê0\9e:L \ e\ 1\15ÿÕs\86á 8ì·P\86\1e§\f!Yz1eð\148^\9f¡\8c\914h:r$\âù\ 6Ê\98\17Çè\ 2K\8c©G\17*\87vPl²ü3\ eyhö¢U\13<\9e着§$D¼\ 3\9eq`ôr\82÷Åí   |rÉ\b?\87Ïs\98àÀÁÐ
+8SøÎGÚQ!ø±]åN0À\11Í\ f\95ØÒ±ä,\9b\97¡ê\9cp\81g\96wò#\v§]{K÷e«eB·Ü\8b5N4À<AwÚ[3#Ã5ï\92Ôu\9f\9e¸á6è\19\1c´j\bÇ\9dH\83\1c\99¯²Úÿ\9aͽª«\90ä\1da9#hÓê½±mU:¢\9dç\99\13§8\999\14\a\ 2Îü:¸Ç{²%ú \13Üæ\ eÕ.\ 6\7f\84Õ"ò\837.\1aÁ$¨ v\10$0S"\85\89_\8e\92\8e ÃW\15ðbú×\1f×Ç86\12.¶¦]]åͮڸ#\81\8dï\ 2=ã¸Yº£\83\91\8fÚtQã»vnS6~\v¸\80ô\80\ 4Å\94jÝnB?\e\b´\15Ë;·\7fp\19\ 3\9b\8a\87\1c\ eù\ f\fQ7å\96ø«ÀtÙBË\89R\13\7fìZu3\84\1eúè\90ÖÀé.Çñ+ãe\vÜ>\84Û\96°\87d{¦\1a \19*\84\9f\87¤\90á\ 2\81\83Ukß\7fíq\ e\83c~Ò}éè¯\1e|&\82ßuÛQ%6ø04ûõG§\ 5ï\16E+ÉÝÏ"<\ 1\8cÉC@=\83Rw+\13G8u\99,|ZËq¨Ê\ e{¿]ß\8c B\80|HÛ%GÙ\aå\9dÚ4ä?|\ f\11£ù\7f\ 3Å>â\ 1t%Áϸ\07\Ú1½Iüí\a"Þmj×À<`PGû;\ ev\81úÐU\95\ 2\90åÐS9êém\1eì7-8÷\9f/\ e¼\87f\r×°Öµ\87\94m
+Y\ 6ú\ e«\90Å\ 6ÖÃ-­é>¤\r>±Á²:0~\0R\937õq\19Àå\85\99axé7\14\82¥Á\11\18\8c
+X\9cp¾XÖ\8a7x3øðçÞ´Øï\e<Â>¼sØ×\1eûð³\bÏÿ       ûì<øå£À¯Fsþ¬F¤\8e8!%QJ}\83\986\8cè}©6ûû\10\b\eÔË\1d\1fWm?/Æö3\18´½ â¹\80~eÌ\90qõhÐ/ü\a\14Ôc*Î}SXú_\0ù:\9fï\9a¢½Ï      \80D§ýý\9aöö1\94\87\92÷½\e\13\86\88\1cÚUÛ}U®½=ê\1f®ü¸rúxì@4Qû\ 4\1d\1c\bë7U\83Ò¶[ù\9eR:rù\ 2ÉÝ®`¨Äñs\11Dì¸ÊI\1cl>;\8f|¨8KR\95\ e\9bm\1drôtô\ 3\1a\7f\ 1\89¦\1a?
+endstream
+endobj
+1149 0 obj <<
+/Type /Page
+/Contents 1150 0 R
+/Resources 1148 0 R
+/MediaBox [0 0 612 792]
+/Parent 1129 0 R
+/Annots [ 1144 0 R 1145 0 R 1146 0 R ]
+>> endobj
+1144 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [165.458 185.137 180.18 195.985]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.1) >>
+>> endobj
+1145 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [151.258 145.231 173.73 154.059]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.3.1) >>
+>> endobj
+1146 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [151.258 79.478 173.73 88.306]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.3.1) >>
+>> endobj
+1151 0 obj <<
+/D [1149 0 R /FitH 686.127]
+>> endobj
+595 0 obj <<
+/D [1149 0 R /FitH 590.075]
+>> endobj
+202 0 obj <<
+/D [1149 0 R /FitH 512.429]
+>> endobj
+1152 0 obj <<
+/D [1149 0 R /FitH 492.047]
+>> endobj
+1153 0 obj <<
+/D [1149 0 R /FitH 464.214]
+>> endobj
+1154 0 obj <<
+/D [1149 0 R /FitH 430.286]
+>> endobj
+1155 0 obj <<
+/D [1149 0 R /FitH 322.631]
+>> endobj
+1156 0 obj <<
+/D [1149 0 R /FitH 286.766]
+>> endobj
+1157 0 obj <<
+/D [1149 0 R /FitH 213.033]
+>> endobj
+1158 0 obj <<
+/D [1149 0 R /FitH 171.19]
+>> endobj
+1159 0 obj <<
+/D [1149 0 R /FitH 143.239]
+>> endobj
+1160 0 obj <<
+/D [1149 0 R /FitH 123.369]
+>> endobj
+1161 0 obj <<
+/D [1149 0 R /FitH 105.436]
+>> endobj
+1162 0 obj <<
+/D [1149 0 R /FitH 77.485]
+>> endobj
+1163 0 obj <<
+/D [1149 0 R /FitH 57.615]
+>> endobj
+1148 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F49 457 0 R /F70 508 0 R /F74 666 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1167 0 obj <<
+/Length 2705      
+/Filter /FlateDecode
+>>
+stream
+xÚ\95\19]sÛ¸ñ=¿Bs/¦fB\1eÁo6\93\a'v\1aw\12§cË\9d»æ2c\98\84%4\14©#©$NïÇw\17»ü\92è8}\11\80Å\12Xì÷®ÜÅzá.þþìÕêÙ¯o\92Eê¤\91\17-V÷\v\11¹N\14Å\8b(\89\1cáÅ\8bU¾øh\ 5ÉòÓê\1f¿¾\89ý      ¦pÜÈ\87c\fÎë·§ÿ\\9d_-mß÷­ÈYÚq\9cX¯.V׫«óÓ÷\ 4~{~zv~u\8d\87=s\99\82n\9c\92a\v_8i\90.l/\ 6 Owüá\86®\84\1f19añÑ\ e]×:SYµ´½ÄÊ\15Ü\16øV»1\13Ï*T¹n7\ 4¬î'\9b¾\95íëZ\95Kø®%À~)¬fi\vKÕôyVm·\88\11\13\86\e\ f\8eÙÕty¦ò}­\90¾\85\88\9dX\bx
+¼$\fé\ 5\ 5¯\82ã\80!\81¥Kb̵ÊZ]\95æY\ 2\1eå.êõ\82&Wæ\81ÄTß9z9nh"®"!\ 1ÓFB\12\91\13ºI'¤wç\97\844æµç;~\12t(Îô\ 6[\84\89\18'0\ 6\83 î\1e\13Ä\95\92ù\f)\81ï$\83ºÌS\12\eu(\89}§[âϾlôºT9s\r$DOVkU7\87\14\13DÞ1ÁÙc\ 4_+¾\86¤     74m\8d">~D\9c:ñÀ«×\1fÞ¿?¿\]\1f¿\84i`¼\8fl>îø­N\f\b\99>>"q¢°g×'&°"ú\98PÐÞ\8aT\975¸¡m£äô\9e\86_\84Ú\19[Y«Zâ\17°'\ eAî`a\ 2î\f\ 5ݳÂ\83\ 3?\9a*=\ 26 U´\bÞÜÕºQ\r-Ûî#¦B×ÀP\98< 46ÔLÐ\1a°Ô2?>v'3üì³±\90¶#3\0?\10°\15EDåMYhÂ\82Çy\1e³Ã\13 f\11ÔMKÐîhÜ\98\1eý\1c\81 G\8c¨\eB*+\ 6¬U©jY\14\ f\ 4ï\8f¯J\ 2y\aç\11¬*'è^÷N|\86;u\ 3;¹Vè.<K"#p²\95Èì\aZ4;Y2\18\17­Þ\15ü\ 5~\v\ 3Ø0âB`çâp\8eüƱ¥M¿\97¥qq¸Óq\86\8eËðâþ%\b\ 3\86Ì\10\8d6´«%xª\fyc¬Éö£ÄxL£*wFɪ}\99«\1c(\f\83\98(D¤  \11\bèÅ\13ÅGD ÌH\ 5ðH*\0¨vè#eñ\ 2\96IHÒ\83\10\b}\86ä;ã\93ÙVv5XCOÁÈûöÖ\ 4f¯ä\966ÕÈQ\83\8b½çOØS\18â`,ª5q\83?ÚîXó\93\80<)ø\8fdA$yhÕ®\89h\1d}èÒ}\88\v­\9bÆp#\ e­×Ä*_\18B\ 1ðf\99\82\ 5×[Ù\1e» |qb\fydÀ)¸Ls\1cΦ¦\f\0zYÖVuC\0YóGÀ\80}ÖB\0Ëy­·º\905>\ f\97è~\f>\r7\97\17¿Ñ\8cØúE×UÙ_5\16\aÛí\97e\18ÁeZÞ\15
+ô#r\ 5Ð+[\96g\83f\99¦\a\9a\ 2;hÕªÈ\91å        :\1f\b\ 6\ro\19O\a@9Á¤E)·\8awK\ 61ZVAÌovF9ÀBÙÕ\1f*\ fQ[ìÙ\83Ò!Fæôág^²+úÛ#iÍ$~\84\ 2²ªÄĦ\18âÃÿ\17E\\88\ 2Â\83\80õ\92Ç?\84\1f¬.VïÎ_ö*|@\Åz\vjQÕò\97\99\886\84ËÑÓ\7f\9a$1GÒÙÅÕùëÕ\87«\97\v;q7t¢ Â ã$éDU½t\90\1a.Hj8C\eÃ1\93\8d²u    ¶Ûè\96ó'Ú1"ÁÉû\9bë\15#wÚ\81\v\13y\0ýôúõ\85\ 5\19\e\89¾\fò\a\ eÎÁ$ý\1cG\1df\8aûÍsgr\96À\89áEÌ\90vSWûõfæH?q¼\9eoî·ølæ(×I=Ñá<\9f9\ 4ò£Ä\1f\ eñÏ\1e¡§OøÐgß¾<a_\9d¤\96ú\96\15{rÏ\91ðÆ\9c9¾M¸¾ãùÑp_ \9eºï§ß\1f\9e>u\94.\81Ò¦\93·Q#ß\85l\16\8a\90£°t P;H\12ëöôä¿·ÿæ§\aIÌ^\ ev\8c\eKâ!: Ð(\ e\ 4$ãú`Sý¹×ì\ 1\14V\ 3\9dCÂ=: ù1÷ ò:a:¼8\9ac\1e¸\81ø'\98\a/O\1d\bv\87
+\19Ïs1ñÅ<\17Á¿ú³\fóSϺ\95À°ï\86\1d\90À\9c\96´3äu&СÃï\ 3\9dA\18ü.,Ð\82ÿªJ¾­%\a\9föY\85Í\ 4N"ÃwUW\9cÑbô\18Sf\9cZ¹þ«\v¹\94\ f\80OËu\ 3\91·B2¾\9açå\942ÎÙ.%J\91?PêE\ 1û\1a\ 4ãáfÜn\8d´sHi´lͼ\80ù\ 3}p_M/$è\1ds\ 2\ fø±J\b¨à\ñ\84\ 1\83Ú\ 4á\8c\ 1¿ÀsAù6\1d± ¢²à9ÖGÌ^\10_\98N\9fßñ\ e\92\ 2®¡Zf70y«KóÒI\ 54H\14Y\ e|z\82·>H-\97­¤\19²1GþQ¾\f¶w\ f\17͹\18x­HÓ']\9a\18¬dÏÊXÐÉmw»2ñÙ£zc²3ä;L]sø©\ 6«ÃCMÅI\11\1cHæ§/Í
+%9!\ 4×\10öÉ\81?®¸fø7®Ò052\r\ 6\93/\96\82Q%KJ\12ÂÍê\8d\9dôÉ)µ\1d\91s\rA\9d\ 2\9a\98N\81õû\122~U§ÑA¥k}z\\82o4\93J&ÁÄQPÅë.?¬\b4ʧ\ 3ëVó«jÐ\1f\93\99ëï*?yÑ\95¨\9aÏéFÙ3#S¦ÁÒèª\9cÖµ\90\8f\97}»BgºË¯}ËTqiWµ\81\8e\99ú+±dÛ\1a÷d\16æd\141Å=\ 6nx\ 2E\97\rrüOUëÞ\9daöt?Á\8bÑÜA¯ê"ï\14Gòñ9\89O5å    SÁi¥\92\9fçrÊór]èf\83í1(\8eNwø$Ã<SJ\87ÖûS¬\1c~§ÅWÀÄ\19Y+\8e\93\12\ 6QfE@¸\9dË\17VÝu´\90ßf\8a\9fRYN½\84\19J\9b\16²+Yã\8bÃ\91ÛôC¯×\91\10\93ߦU\8c\9fB\a\89\1c\86ýag\17¡gÊ\12\14\\98Xwû\96\91\81ÐL\88Æ            utÀ y\0\94»[u9G=õ\1a ¾\0\83¦ª\ eC\1a°\9cTý¸\1d\93\ 6Nä÷\8d\9dl\19\ f\ 6Û6ÇþÈÇd6\18ò4;\10\10LGqaÊzFØ7LRO\e\e7N'ñ\98@\83o0fo¾¬Ø8|×ñâ\83l`\88\85äZdó@ÆU«\91Ú\185\99v\89dÙ©>\86ZY®÷rý\ 3w\7f\ 1\ 5Ó\17\9dCè¡.Ç-\17Ê9\94\93'\bò\a\85y7"\96Ui\8f´Ê\e§\rÞ UðÉW\rÞ£$0È®©Jìw\ 4Â\84\9aÇÝC]±í!\a#¾9\88è¥8N*K\ 4\f\95%âË\86 &\16ì·²´áò\1c\8bU\82\83R*FÝt¸²@\9c\a\ 5\0\97ê\9b=Ûü)¤.M\ 6\1e\ 4\81uz·ïzt_uQ\90\14&}\vÈs²j_\83P~\9càÔÜ^ÓlàeEëA>vç\9c2\8d\b\ f´\ 3W߸KÇ_Ý\8eÄ\ 5J\9c\9f\10x¨Õ`aD\86¾\f¬å_&î\18-\98\11\11SyýöÃÍ»3¬D\ 4øÞ¾\85\a«¦Ú\9a\9e\90 ¿ª[Z\19\1f\0£4M\ 6ü©tΠ\1a\f¼\96µ6\89\ 6\0¸¨/\8a}KÑ2é\1ar0Aù\eí\87¹¡}^>2ÃîD\0Îå7½Û8Um¢n×F\80I\ 5'Ö4%IQw5×\14:ã^\92Ѥ\95h:§E\ 1\99ÈÁyõ༠    ÀiDdm«ZÍuR@gî÷¬,­\7Ó¤n£\8a\1dÍÐ\92º\966[\1e\84\81ïÈj¸s\89Nîé´À\8d{ãt¹\8c20ã£a\ 2Þ\ 5r\93\8c\ 2\81\11\8eü\8fH¶G^¹Q×>Å\1dH\ 1\9b:\9eLôÿ\ 3\0ê\14:sÍ\8b\8el(¤Â0\9e\92\rfziÈ>rà±çà\8c\1dø+58NAæ\83£¤¡÷*\15äÎ\18¹DjAƬ·Æÿ\ 1BAÍ(\98\19\87
+ãÈÉ\89\91Åà¢ã#L\8dh\8c¥09So\8e\7f+\85\90\176Y­wì´\ 3nx\ 5&jë\9a@]\ ePR\12  \10Ð\ eTà8µ.+\82\fD\ 4aO\ 4LI\98\16I\86°ú\80é[(ºûDz\981\95¾\87\vªÖ7°Ç\19¯ìz¬T\ fbÔéÐA³\9fs\0*\8açÓÍ\92Ñ\87\ 6Vßàê\13T\9fû·CªIé\88\87;_=û\1fä(wè
+endstream
+endobj
+1166 0 obj <<
+/Type /Page
+/Contents 1167 0 R
+/Resources 1165 0 R
+/MediaBox [0 0 612 792]
+/Parent 1129 0 R
+/Annots [ 1147 0 R 1164 0 R ]
+>> endobj
+1147 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [279.002 643.276 301.473 654.041]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.3.1) >>
+>> endobj
+1164 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [423.183 336.026 450.11 344.826]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rfc2044) >>
+>> endobj
+1168 0 obj <<
+/D [1166 0 R /FitH 686.127]
+>> endobj
+1169 0 obj <<
+/D [1166 0 R /FitH 668.127]
+>> endobj
+1170 0 obj <<
+/D [1166 0 R /FitH 642.673]
+>> endobj
+1171 0 obj <<
+/D [1166 0 R /FitH 626.965]
+>> endobj
+206 0 obj <<
+/D [1166 0 R /FitH 532.59]
+>> endobj
+1172 0 obj <<
+/D [1166 0 R /FitH 154.11]
+>> endobj
+1165 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F70 508 0 R /F48 455 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1176 0 obj <<
+/Length 1787      
+/Filter /FlateDecode
+>>
+stream
+xÚµXKsâH\f¾çWp4U\83\a?°ÍÜ2À$l1!\ 5ÎTÍ>\ e\8dÝ\84ÞøÁÚí\99Éþú\95\9d\10²\9b\85V¿$µ¤O\92\19\ fî\aãÁÕÅÇøâý§Ð\eLíià\ 6\83x?pÆ\81\1d\ 5ÓA\10\ 5¶ã\86\838\1düf\ 5¶o\ fGa\18YÛE|w;\1cy\9eg]/.ç\8bÍð\8fø\97÷\9f¢'\1c\ eý)ð7wý)\1e¹\18³ÄÓq0òÜÈ\ e\83p0rCàáÑ­x\19¯\16\1f\17\95Ê\12Iß*D.í³üàgäDÀ\80î_n\86\91\a\¶13ù¤²<\17\ fC7²dEÌÊ\8a¶J}\90L&\95\14ºäýbèX"\1f\8e\1cë¿d:$ôËb³]®o@¢ë\81©\9a\9dV:\93ï`:\89¬Jæê\aí¨b_\9aÕÐèàzÓV\aÜÕò\87¦ÅTÕZ\15÷\8dª\ f0Ðî7zA­Ê¢æ«{Ú\11\86Öz\93\8dæÈêÒØ   Mí\8f]k.´DʳD]\83Íá@¢`-¥íïJ\1fh\eÔ¥%\167
+&®µÌ\8f\99Ìe\81|µÐ¤"\9eÞ^¯ïVsº ´\96ùQ£\82\ 3\a¢Æ\9d\80R\8e=\9dLH+\r\89c\1dEU£\fà«\ fª¦ÅßÇ\8e\94\96\ 5/\8a\82ÆåvM\eQ0vh)¥÷\0µGKãf.\12Ô\ f,Ê;\8aô\95èè
+\~¬$)ÏR\8aÔè:~®fR\9akOÜñ\8aÍGÝ#\9fDÊj=#ÃS¸x\91o­ØÜ,\1a\97\0\17É\aH\19\1f\ 4|\0j§æ\ 1è\8aÉ4´bc2<Õ\8e\88,{<¹\8a\ 6Ír\8c®×ü\91\9dè\ 5(Ù·È)Êb\84\1c\92v\ fÔC\83\94ÕCý&s\90\88ÙúöëfyuÝbuV\1e\87nh=¢7Ôý\ 1iM;5x¦\8b°·\81\9c-n¶\94K\9c\9eµá\e\11_Ç8\19\b·Ï\ 5\8e\95©D\16µ\ 1\1eî h«ÜX\ 1lìûþùpÇ\9bß\ 1°£W\rj8úø¦\92Æ\94GÑè\12\ 5$4E\0tg\11ä8Jûd\ 1sD¥v\r\a\95U^\13Ùá\ ehöcùp.\9aáÑ\18\10Î\98}ë8\98Np~·YѼ)0Êþj¤\89!\a\ 3\ e]_\90\81à$Å\94Ó\1a\95¼ÀZîiµ(é\98\89EÂgË}{ÙÄ)P\1dÄq\e\16Ïh\v\b­Ùì\90F=N£\1e\80Uíi4ÂpÞ\v\83\19cV\ve<\85à¦Áä\1a±Ëø\1c¼ù\1dï\9b¸@F/|ýL1\ eäÏ\ 6Ô_)V{\83\9b©bð\90\99\0)]ÔÓzÿî\1ea¾U7\94­hYÐ\0úý\ 4ºÖ\eäpuy³üõYÎ\ 1³mu\93"ÆJ\9abuÅ\87\a\9euÛì2\88bY\99¹Ë\ 6\ e;|L\ 2\17\85ú»Í\v°©ú\94Xfß\10g&iÁYU¼\9eïÉ\1e\{»<b\ 2£7\97÷¯uíl\8e\9d/7\8bY¼ÞpR\99«J&]mo3Ø\99\0ôH\95        ,L8*W\99àú¤±o.ÞTgo\8d\ 3Öó»Ù¢U涢àH\9b¤k=Úúcò¸q\8b&\85ºtû&[\9c¤¿ÙúóízÛ       þÜÔ\98\ f\81Üxá[;³ûÖe¢9\85zlÙ\93\1aÒáá'\1e\15£ý\8d¤+\14\138\80\93\1d\14¾\89õ'ø\98V\f\7f\18¡pÉû²z¤\99\16÷&¢#\8b|þø\1dô¬R³\1av·Ú8G\ 6\9850­\16mÁÀÅ\f\8a³2µ¯\rZXÍÄθUfTþÎ\ 6|L­S\0@\ 1\85EÖðÔdt\18¥h!\8f³>\83ùã°;Ã\1d\11P}G\ 4\93¾Ï
+,Ö\84Ï#¶$\9f2}\130\134Å"\ 3\99ïL\9eí\9fÃ6ãÞ\ 3^\9a£\8aM¦ÕÑ$ÍÀé\14­9aìÙà\aÞïó[ÀÝ\18ó       \89\ fÄ\1f±rÑI5ö1 "n¯\83±\ 26\16³?£0æG\7fÒ¾\bhÿ\89XØhí\83ôÍ:¦\13\9d¡pÕT\82\946\14ù½¤ÙÉ\8bá,ªIÔNt\97L( \ ee~Ö¦m·Y\15"#\0¤2S¹ìûÏ\9fÊq\8bíl³¼mS:p»\92\85¬\88µ\ f¬ë¤RG\fÐ6\9f5\90î\0\f\80\1f^iq¸Ë\9ajgÓç\9c\1f\r\1cßöüÀÅ\ fº\91oO#\17?Ôì\89×}\10\82º\8e\v&\95º9\ 2\87pb]K\91\ 2h^|\10\82\ 5\8e\çIü{î\18\89²\12D×Ì\ 6È\ 3±1t\8b=®ØnÛe\0\ 1F3¹\ 4È.6øLCÞÀÓè<\97²[¥¨$\9dòá2ÍÒMC¬±î\9dq\1e\8cÃ\89\87B\9bVÕdTRÂãÖ\ 1\88:\11\19\1fî\10ÏgZE¹´ ãFeí\12      C/þÕ\b
+\9b¾Üâ\ 1ìXjt#øáô3%xªq\14\r¼ÌËEASºK4k\11q¬ãJ\81pÄ<\14Z\ f¼Õ2\9aÏ\107\11ä\14èlÐ\9e\ 5b5\18\8f2\11M-OηM\17§O\96y\1e¿Ü\ 5\ 2¾» \0ZT\fúúHPM(ñr²(i¤h2\89jJý_`:>ÈH5ú\ 5Í\ 6u\82Ú\9b\83è?Þè$g\ 1YÐ4\17©|Î\9fê\85<òêá,º9ÛÔ\f-úrÒR\8fD¦î\vcf¬¯C.O@KQ?Òiî÷\9f@Ð0v[\b\85\1föð³\1d\ 6àÊôÕ\14¿\0Bhh´1\1cÐ+\86\b\90ñp
+!I\1d.LçXö\13\13søáH\12§Ï1\v\8b¦$pY\1c\eä\14\195\ 5¦«ªþð\12êÎx\f@÷Ûÿ~nÊâ\95¿N\16ñÅ?¤åÈ:
+endstream
+endobj
+1175 0 obj <<
+/Type /Page
+/Contents 1176 0 R
+/Resources 1174 0 R
+/MediaBox [0 0 612 792]
+/Parent 1129 0 R
+>> endobj
+1177 0 obj <<
+/D [1175 0 R /FitH 686.127]
+>> endobj
+210 0 obj <<
+/D [1175 0 R /FitH 251.681]
+>> endobj
+214 0 obj <<
+/D [1175 0 R /FitH 150.582]
+>> endobj
+1178 0 obj <<
+/D [1175 0 R /FitH 129.812]
+>> endobj
+1174 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1183 0 obj <<
+/Length 2078      
+/Filter /FlateDecode
+>>
+stream
+xÚ½YËrÛ6\14Ýû+¸¤f*\ 4o\80Ýt\1c?\9atÒ4µ4ݤYÐ\12msªW(©iûõ=x\90¢$Z\8eÂN7\16 A\17À¹ç\9e{/L\93Ç\84&?^¼\1e_¼ºµIF2Íu2~H\98¦Dk\93h«    ã&\19O\93\8f©¢\83\9f\1a±7\93\11ª\ 5Ìø9Wo.?\8c\ 6C!DªÉ`h\8cM_¿\1d\8fÆw7\97?\87á77\97×7w#gì\82Æ\1d<÷y3¾ø|ÁðH\13\96pe  \95,ÁÎHÆm2\99_|üD\93)¾ü)¡Dd6ùâ§Î\13&-¶(ñ<KF\17¿\1e\18á2ÑJ\11\83\93\9c°\81Ù\8cdJE\13G q«°\1d\vS\19\11:\9c\7f²\9cÏ\97\8bpΧ"\9f\16\95{\96éýl9\18r\93N\ 6øó\87?úÞÑ$ÕÄRý\rÛê\80\a6\94\91ýà\91\82\v\1d£\88\92!\94Fx<
+6]®\ 2B¿S&g\9b\80\91H7ùý¬\bpUÅz9ÛnJ@ù<Tçn±\ 3)\98à¼\1fPÂñ_÷B*³ÄZ\ 5S\92h%¾\1a©ç\919{O\1dÐ\bJ,\14 \17\12Ãú±\b\ 2d2\9ehΠ   Ï²\80Íz\92\a¢\9cÏ\99³wÔ\81\fl(&ú!\83ý\b\95õAFPJ2 \89¦\18\93* s9\0\ 2\1eG(=\8fÊÙ»é@\ 56Øi\e/¢¢2 ©P}Q1"\83)C\14xãQ¹¾
+04\88È\97\109\7f\88¨Lx[½\10±\f\92Àúé°K\96\1c¦\14áÂ\ 6D\16\8e'Û¹û{ïu¦ÎSË\87\0Õ}¾\8eÜ\99ç\9bª\9c\94Åú\ 4Zgï²\ 3\90ª\9f\16+\9dA$l߬¥,L\19\ eM\96\ 1­\1d\18\9f·ù¦ü'÷"ãñú\1atÎÞU\a:°A³~\15\8fR\1aB!{E\17·D\18p å¡\12, C\b9qø³\17í8<l\18©ú\1d^JÒOo¹\96D2\ 3K\960\13KbðÁ\87Ò&УÊ\17\8fQ`Ê0^T«\90Çg\ri^\94ã³÷Ú\ 1\19L\88\8cõ\83L å
+Ó/\9a\ 4
+\11\ 5\ 5¹¨Õx\1caXþáªá"¢òf\8b"GÌó6H§ÂêìíuÀ\ 4\eT\9cUäÐçZ&\8eª\e\ 5\8a¢\ 2\1fQfoËÇmUÔÍ\90ú~0\94R¥£b³\8d\9b¦E@vÚTÛÉÆÍïj\8c^ÝʬµÚ0SD\0Ñ!J=Ëcöÿe»Ym\1d\15­HWy\95Ï\vðoýý1\86u{'Q\9b[}\14\9d&3Íù\ 5JdÃXsþãV\11J)PµJa\88°Q\13Þcmð^K\9b\8e]\1cü\1d¢À\8d\19&ÓQù\8f?e\82,­µM\86ÑOþ·¿SEïËÍ\1a\9fÌO\12(\8fÑ\83¶ç\8cÊÇE1ý\ 1æ\84aé5x2dé¤*W\ 3\96îÄ9_Lc\\16k'Óî\9bõ    4X\86\8eåHgd\8b\r\9dhì9&\18³ ©%RÇ\82õÝí»·?\8fB÷ÜÆNI/£±w~\e\11\8cpç¦û¸äU\95{,ý\97FûB¶=Á\0\ e®tú~é\1f\14ªÁ¡â`\9e\1c\16³b^ÔJ¥8\8fÆ\f\8cùW\97öÝÔØ¥º®Ã½6]\87[QÃÏн½=ÍÊy\19µïÏ\ 1VÌgÛbM\9e\87Xdè*\8e\17     ×\ 11\8cA\91\15\8b\10ÿ6È4NU\ 6Õ@\bÈt».¦'È/$%\9cõã¾ÖD#3   \9e\11S_\93\ 4îc\15é¸ï fé\8eþ\\8a\1dý-G£\9eõ ¿\90L9ú;ê·y\8f%§MWô\15Ô\17\8cw4Â/2ßÐ\ eæ»\12ܲX:}.\8fY\ fK\8cé.Ö\ f\85¡4Õ\87<\1e?ŤڤÛV\r&\90j§Å_\9etÉ0ÚÞCô½»\7f\82G¸`\1d«\89¸H\M\87ÕP5§kç&<Y\1f\1endÇñð\1ekçrñ\18Þ+Èyø\ 5Ò¿\1fÙ<E\13\93m5ô[tzi\91^÷¶X\15»2\ 2Í       Ü\97;E»Çì8\11OPS©è)à\8ahLà\88\87\8cE\12\8f\9fJ\17EÔ¤«*ÜDL\8aiÈe\18\9b\16\9308-â,\7fNAmÓ\90cÌ÷\12øl_eàµu\95á¾\8c
+\82\9f\ 2]]£ë¾rñ\e\8d.ãºUùç \ 4R½¨÷:\93¾ÈÜ\97¦î\v\94ïÂë\97§Ò_Å=E
+­ÃçÔ\87Rtë´¦Wðʨ\984\97\vÁ\ fÕc\12\1eî~¼H>Æ,/       ÛKà®Bvy_¦o£{w\8b5(Æ¥òu\98ñ°\9cÍàú¥Ûá\97\98À\e{\bUW\7f\ e9\ eËb¡ÁÈÁ\9aC\ 5jßy:zÃÁ®\18Þ×r½]¬½\884gl\85\85\93\90¸G\1f;\aÆ]^\ 2}êª\83w®};@\11²\8c¥M\91O\9cý§`{\ 2)*&ÛÍÎ\97íô\11\9dp×¼§0\92£\11\9a»´Å1ÀÈzÆCµ\9c\a{4FÖ2\16câ»úà\93Ùv\1dwr\0ô\90¡¤16\9eVïä9¯µù\ 4à\914\1e¿sP÷'ÚOw\99ðY\82\9e®%¤Ë%¦\9eõ±\ 3>\80§Í)ð¬¿~\8c\13>\91\8e½@Ê\90ñ\90±8
+ú,BòÛ\ah¨Ð:½ZÎWÐåûr\86ó
+\1e*\95\ 3ÿÐpgNk\99qþfv/ZñÚÒ\b÷eÔ\b\11xÏ«hà)¯¦{áÄ\82\b»OlÐ\85 ÈüzA1â>ö$cϸ\90µ\09wV1\ 3=Fª,ÚÚ ÒËUÌð\8biù×i\85xMø±>\ 4¤mLòÜ!E\1dØÄÚ\18áNX8r\ 2ã*ýÕ¥AÁÚiШô\83\83¼©úÃص\97\18\8cO\8b\ eoº@FC\9fÕ\89ø¹æáÐ\85Ô·\1cÑ\85ï\97\8b¢\93*õ¼À\95omQСYÝ3¿¡\12\87\8by¨_[5\9a0\9aÆ\1amåë^7ÆÛý    c0.D\8f
+\rþÊ\ e+4±×\99¸D\8f\12\rz?ñ\8f¥W~<¹*îT»\82få¿éU\86èMEs\83\f¶\\8d®.ßÝ\1c»\1eå®\11ê¥~Ewõ+î\8a0\93I{\ 2Ó]\r\8bf±aq\10´\9a\16\8cï,â56-\18^{Üòp¥\92h´¡Êîo¥\1dØhÌ\90_+÷`\9aûr78    ½O\ 1íÑ\93²\b\1ep\8b¯Ã\÷£\8e¶¬Ém\1d\82Ë\89Ü\15º/§«f\9bÝÒ«hHüíÕ¯û¹J½ä*õ¿¹ªC\83¥¬]\85\a_aJiüm¾\e\88j_û+®Þqº\87½2ÄtºJ¸\8b\bõ­®êú·õ¿\v\88
+endstream
+endobj
+1182 0 obj <<
+/Type /Page
+/Contents 1183 0 R
+/Resources 1181 0 R
+/MediaBox [0 0 612 792]
+/Parent 1129 0 R
+/Annots [ 1179 0 R 1180 0 R ]
+>> endobj
+1179 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [337.228 226.028 359.699 236.876]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.1) >>
+>> endobj
+1180 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [312.017 126.409 328.815 137.257]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.2) >>
+>> endobj
+1184 0 obj <<
+/D [1182 0 R /FitH 686.127]
+>> endobj
+596 0 obj <<
+/D [1182 0 R /FitH 515.953]
+>> endobj
+1185 0 obj <<
+/D [1182 0 R /FitH 482.136]
+>> endobj
+1186 0 obj <<
+/D [1182 0 R /FitH 448.263]
+>> endobj
+1187 0 obj <<
+/D [1182 0 R /FitH 376.474]
+>> endobj
+1188 0 obj <<
+/D [1182 0 R /FitH 340.608]
+>> endobj
+1189 0 obj <<
+/D [1182 0 R /FitH 221.047]
+>> endobj
+1190 0 obj <<
+/D [1182 0 R /FitH 201.122]
+>> endobj
+1191 0 obj <<
+/D [1182 0 R /FitH 179.204]
+>> endobj
+1192 0 obj <<
+/D [1182 0 R /FitH 150.762]
+>> endobj
+218 0 obj <<
+/D [1182 0 R /FitH 113.464]
+>> endobj
+1193 0 obj <<
+/D [1182 0 R /FitH 92.695]
+>> endobj
+1194 0 obj <<
+/D [1182 0 R /FitH 67.187]
+>> endobj
+1195 0 obj <<
+/D [1182 0 R /FitH 33.258]
+>> endobj
+1181 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F70 508 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1204 0 obj <<
+/Length 1688      
+/Filter /FlateDecode
+>>
+stream
+xÚÝYKsÛ6\10¾ëWðVj\1a!x\ 3ì¥\13ÇNêÌÄMlµ\9d©ã\ 3-Ñ23zØ"\1d'ùõÝÅ\92\94hѲ\9c\87\ f=h\b\ 2 °ûáÃ\87]\88G\93\88G¯{{ÃÞóWNE       K¬´Ñð"\12Ü2o\93ÈzË\84tÑp\1c\9dÆ\96\1f8çã\93\83á_ïú\ 3¥TüÇÁ\8bý\83ãþÙðÍóW~m\ 4hcN'0~øÖ\bìÒãÕ\8c\aÃÞuO@\91Gb5\99uÌÉ$\1aÍz§g<\1a\9b\883\97¸è6t\9dEJè\ 2?\9cF'½÷dùú´Bjf\8d\8bàǤ¶4ùQ:ËÀZgy<ìK\17\7f¹ê\ fà\81uRèø$ÿ\9a¡u\91\100ºRÑ@\b\96\18C\1f\7fà\86\9fçe\ 1ÏàC¤<ó0Ùz\9f\93|2ÏÆ¿÷\aB\9a$ÞÏ\8aÑ2¿*óÅ\9c0Jçc,èx\99\15å2\1faK\11ðèÆA%`Æ\ 6\ e:ñÛq\0´;VPz\ 66T@ì½=Ù\*ka:[¯Ôá¼/}\f\93\1f\18¡e,8À%\8d\89\8f\16¡`ãá%`'}\12\87¾73\ 4õ\9c0\85\8fdÂãÅ\ 5u8O\8bªë,E׳\82\91\ 1-c\a\95      -àw°Uî÷\a\16ø¸n3.\11o\8f\94.\97)vø\12\1a\81ÒÖ\99ÖúùʯÊA\13¿è0ÒIf\85¬§^A)ô:í\rÓ¦±ï\ 3çrÓ\aà\8föu\17«\117WÙ\bܤ×Ñ\82\Jóù X=0\9a\19 E˱|>!\86\95¸ È0Â\e«¶â-\85aÎûöhGï\8f\9f\f\89ø@%6\96\1d\98zÁ4wÛ1\15\9c)ר\8d¢ÁVV\84×\80©\v\98\12pP\87À\ 5xe\ 2\93Ü\81·a·\ fìö\81ÝJ'\81ÝJûøú&%\1c¨z\99Î'YAå\8bÅ\92ú¤-|*E\9aä\9fð»lN\9e8¾æ\8a4\8c'\8d»×eÞá­fÊ6]P^6\87\11\1e\98hê>WÓ®a\ 4\ 1í\19¸\b
+       \1aÕÈ£\88A«ÈÒé\97¾×1#°lÂ@WÚ`\r\82\98GO\1d§eÅÄEQ\95¬Ú\9d\8d@ÆÃ\7f\ f\1e$¤ú\89\84´Üw\13\ 4$u;!\ 1Û5>n\ e\920.õ\ ec\88F)\14Z\94 +}\11×b\816"\1d±¥!³1LXÑF \80S®À%\96$ÎVÅY:BL.©v\8dÌØ\18ÈL-\81ËXH» ý\1frùÏù4è0éC\10ä\ f\è%ðx\93¾\96Cı:\17:ETI\10ïºËi\17PÌY¿\1d'°Ï6c\9cu\rb`\92\1dPjæ9#\ 4 haÂضB}êÃfH§7Y½\99\97Õ¹rSdãÇìâ½·\87\89\93\9f±\89ÅC»øQ\83ày_íâúlêØÂw\16¶sC\9fϺ\16\18¢¾zª_`é\9câñ\rÈE\81\e \830\14\ 2lÚÏX\b\ 2àP\0ðm%\0D\v\1cª5c%  Êúêx³x¼\85G-\ 28M\97\108\ fB\90l'¸a+~ߣ\ 3\10\18\8bä\11\f\7fÖÅðÚ\e\12\a0º%\f
+\84\ 1ú)_©\80±\86T\0\vk*p\97\9c\98'tl\vżÓ;\88\83xH\1dÜÓ«\ 3DH.þ\95\ 2%\11ò\9f\81I̺4\90\82B\86á|[>6å¢;×Ñ°¤*1\8fÎù:s\1d\95(&hþ¿û!þËÓóiP0Ð{´ä·û-\ 1\16\87}ú]Ù'ì\99D\18È\ 2\0\12@r-û\94\(Ì>=e\9fa«H©Õ*ûD=Ón\97äÓu'\9f\8aswoò©vL>\95æÌsùèä³½OëÁ$®®ÝÂ[#\98\\9d\8c­ÜS9ÎcÑ¡èÚ\8a\95Vå_Sò\15kË6¾\1aB\80|>Î>Ã\8e\ 6Ôâ\93,£~C<ÿSJ¬\ 4Ø\88¬okë4¬I\85Îr\12Qáøu/:\r`\ 2ÑZ\17\1að\rë\12ná9¼ÜQîëòã\8fA\ 2\ fæM$BBØF"\84å\84D×éBS·lì\14\88\87l\94÷Ø8ZLÃy\ 1V\MÓyÛ \81Ö\86\96\ 6+\87¨Àé\83øË\1dño¹fk×>>\91k;b}ý\rPoä+Ãú
\9b\10\8f³hôC-Ú\7f9$#F\v"$\1c£v\94gMî\f}À>\bSBü°»\99\9d!ÐCv&÷Úyçòäó7­åòç,f¥áU\ 4Ö2«Û\90£½Ãá  \9e;Ú53"º«YMçµ\1e\8e\8d¹"\95\16øÉ\ 5\951øɦã*Ë/\17õ±\92Ò\ 1\7f÷\8eãèà\1f\9cõý1^\8bÂt\ fJ\9a\8d_MÓ     2DBÄ\85·\aÒ«\8a\18ù(EKÊ\9a#\ 5uK©Ï<»¥÷"«¾¢ûGy'¦íTãæÖ\ 6\9c¹Í§Ó\8a\vÍ\15\8c\91±z^E2÷¨úñ;tUâ\8dò\ eêM®jQ»\8a¥|\ eî\8dÁÕ\12í¡¶\8c
+k<À×Êæ{}*ÃF\83\94wqU%\19ÒóÊ;ª\ f1      Ô],\173ª£T\17
+EZ7\92¸u\ 4»Aê¶\84u\10l3\ 5\89Ñ÷]å\væ\85\82'gÂËú\96       \97D[\90_ðë%\95\8bQ:­ª)Ú\81Â~Ý\162ÿ¦½\95ÖbÿeÕÐ,1½æsz\86\16\93¤E5^>»ª\a+ëè\12Ê·yyI%ÈðÖO¦µ¿<þ\ 3Æ\1d\15¡
+endstream
+endobj
+1203 0 obj <<
+/Type /Page
+/Contents 1204 0 R
+/Resources 1202 0 R
+/MediaBox [0 0 612 792]
+/Parent 1208 0 R
+/Annots [ 1200 0 R 1201 0 R ]
+>> endobj
+1200 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [302.884 312.858 317.607 325.356]
+/Subtype /Link
+/A << /S /GoTo /D (table.3.1) >>
+>> endobj
+1201 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [424.401 288.948 439.124 302.895]
+/Subtype /Link
+/A << /S /GoTo /D (table.2.1) >>
+>> endobj
+1205 0 obj <<
+/D [1203 0 R /FitH 686.127]
+>> endobj
+1206 0 obj <<
+/D [1203 0 R /FitH 405.055]
+>> endobj
+1207 0 obj <<
+/D [1203 0 R /FitH 369.19]
+>> endobj
+1202 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1211 0 obj <<
+/Length 2364      
+/Filter /FlateDecode
+>>
+stream
+xÚíYÝsÛ¸\11\7fÏ_áGjj#\ 4A\ 2à½99§w\9d&sc«÷\92ä\81\92 \893\12é\92tbß_ß]ì\82\1f\12cçnÚÞt¦/"°\0\16»?ì\17 øbw\11_üõÕ\9bå«×ïìE.r\9dè\8båöBêXhm.´ÕB&æb¹¹ø\18eÉâóòo¯ß\195\99)E¬\15°ñsÞþtýËòævq¥\94\8a´X\\19c£7?/ï\96·7×ï\89üÓÍõ\8f7·wÈìUÌ\12L·¿
+\¯\12\ 3DE¼¿,2\1d\15\87\a×.®Ò$\8b\±^$6Ú_B7µQ]9¤§Ñ¶n¨\ 1}\19ñ$\16=\1e\8b.3\91¥6\88þÏ\92æLpH\84µI\98Ñ\v\80zI\e\8e$i\8b#ïÝâ\96ëâÀ]X\91á\8a\85$aZ"\17\r/|hÝf"4hõ\ 5åuÍ\13J\ 3H$V¤\0\84\94"Ï2\96ô¡¨pRWþVte]\11¬Ý"1ÑÓý\ 20ÃÍ\94\82\r\8d­ë\ 3òÇæý¡¨@\ 1d.S\91§)î!¤æCö:©8\8eVEë[2:\16]S®\11u¤{A±Q\1c\ eÔ\98\11\a¨\13qZâDòÀ`\90\a\9a^\1eæíqÁ\86\87±\83)\8c\e/+\99wÁØ\ 4ùGØ´eµCô\95ÔQW¬\ exV©ÊQ¯\96É´\v\8eï]E­Æm]ãªu¿\19ÐV¨Ó\13µËjã\1eC\93¾m8¨\ 2a\90\ 6\b]KCõvÆÚ\12\9b\89ÜÊÞÚ\0´\ e¦§IÔ,2\84f\a(\9c\19`\96zûçEtl°(>W\9c\ e.\ 5@ÑÚ\1a\ 4\1e|¢e"\88\ 4§\9f£ÊDè\ f\8dè\ríï\87Ê\96çÖÔo\89\97[\97Û'\1aùº/Ù«ü\ 46\15\18\18\99J\1a\8e\13ÈdæHBëA\1dâ©ð\ 3Ã9àD\16gÏz)p2é\99\97\fW\ 2n®26sK\93®ÉAàÌÈ+\b\9ft
+\8b\1a`\81¡\92¿\9b`\94\9fb\99B»òº)va\5\89;\9e2ç±)º\88%\17±ä±*xlú\r\8f\9d5ùåÂ\82\ 2ÀÅG"äùeA1ÀSî\8b57Ñt\93D\93\11 aï\8a\8dk ~&©\89VeGTÐ++v-Í\ 5\91åW\1a+\88êqÃ>â\86_RÐDL\ e¸a»«iÍ*D&ì¬ëû\12qà      Û¦>Î\19\ 5ì¥l\16Ý7îKY?´\87'êo\1c\ 2O¨[\16\ 5éeÕv \ fuüyÂwEàBP þ`ËÈÄñl\7f`\8f÷p\98\87r]v°\13 
+\81CC¬¹éãñt;÷¸v÷Ý\9cÜ\ 4o\9e{\ 3\8eb\96OOH]\17\1cÅVáà=5\0\ 2m\ f\b\ 5ÑÀª<\1eݦ,:çQÀ°Ù¸5PP/\1c\a±| SÑ]y,\ fEC:\âd\88\81Ý\8cÀ3Ö\99Û3ëÌ\r¹\0|«º£91æ^©8¬\0\81à\81)¤%PVc\ 6AKl³\96¸Ó\9e\87\9d\9c1Nõ®À3g\14 ü«´îÝ\ 6\9aÞm°\99ñzÍ\96ï\a\aøpBo¾\ 3\ 2@\9d \0ðf\10¬\97{\ f\ 2°\0¦G\9cðp\18-!w1Ñ×v"§&9×õ\11¼Ñë\b±Å\81\10­#ä{Ü1\14!¨±\rZC<y,\8e÷\açÉ& ¥\82ÖØr]XKßq\18ËGa\fÚ%oCçRwû9@)vÁ\ 1¡¿Û\98ûEU¹C\8bá"\87øÖÒPÉß\r\19¸¥,\9d\18Î5H¨\9brWV\98'±÷ë/ʳ@:Qú\89¤\91\0c)qáw¤\11v\9b>_\9e\8a^r9ôó\87åíõI\19\ 4´P\9b\1ek¯ÿ&d\89¹Zèf\88áÚ\8cC\1c\ 4Ô$\8b0\13«Õv( `¨ O[þæh\90\86\8cì+þÔDàl
+s|6}ä=ª\r&Vth£)\98 9äÓÙÄàF9(\8f\1c¡\90\9fÔ\ 2!ùcøÐ\92Ë\b \9e$õGjs\8e³Ãâ3¶$[`KÍPRp!\0­¢\1døÌytW4¾<ÒÄ7ÍBé¢!á>vDò; $)DÀ\9aF»}Á£\8cÍëwR\8e\8b\ 5(©LÞ×ôÕy9\91\8b4éK.2´Ë\19FJ\89<·Ïð±"1}Ýò\1707\15G\92\84dp¡5®\98\98\80|\9a§B)\13k\91Z;\8d*td\89\f\\93\15èthI\1fÿÏîA©PCýô\8d
+˦ú¼Ââ}IÖÁ\92\9d¯«a\84Î,\89{+7ÞÊ\81\0fÃ%jI~ͼüi³¨\9e\10¬(¡z\92/EZ$ÉÔbv®\82Z¼sìê+\7fý ö¡¬\ÁÅ\14ïæB\81LÁû¥û\90Ì¢\ 3T\a\143Ö!XK®3dÊâ\ 2\ 1ÝAFçª\8dæz·4Þ-¡\17ô\93\az\1eë\10\9d642ÜE¼\1f\94\r\911\9cø´OwÑó£\ 5Ô\ 4\1cïsG\v¨d"Îì\14Íþ\88a£,¸}\16Ü\1e\1a\a·í¨å\8b'¯õÕTmZê\95\1a¯l\1f\8e4âñ\98\8c\80:ít\8c.\99Ð\18'lè\ 6·¤¤\v»\7f£\ e\9b±v-lü\92±k\99\9f\19;æ,NÊI(Z°Ñ\94 ún\1fª_(WÀ\ 6ΠÀ\99ÅfÓN\16û\84\80ðqÏ'»1ïõCÓ¸1\8b>T+,E|ù1bI1Âúø5\r§\1esÃÁÔ\84B\b\1a\ 1ó~,cÌÇ\93úú\ 1Úïÿq·¤V_ÐcGcRWÖP\1c6}\1c6ÙÀæPøb80¤æ\16\v\ 2TsE\13g\1a\15\96CB§W\85Ú¿\12´å
+ëö¹£6
+n\8eê\ fÜ\1c\9a\18.\8ej.\1eø'\15¬É:÷Í\8bä\ 2/õ'E%Þæ\8a\ 6ª\1c\b@-ßø\1af±q\13¯Ç!\9e²­Ã%¬ýaòj\ 6\87-\fH\ 6×(øòYK1\9dóñ*\83Òÿ\96®FÈ\95¶K¯ü\85\ f)\ fU[k\88\90;× ¡AVºnq\9cF?àc\1e__\ 3\14ã`\ 1ô\ 6¶º\f\aÖ¡æ+ì W\8céL\18\80ß\8b\9dÌ\8aýÎßmýzTÏà\r¹jÝú¡+é\82Ö\8b\92õ¢¨ù\97\18\99\ 2Zéï°\v¾©\0¿\985¯ù\81S]\ 6ÌÖ )KrzFR\19a¬duù1óS\9cÅ\ 5üÈ\17\ e\8b\9f
+<ì/\9f\18:DÓ\e\8fW+ÍÇzåà\12}Ír½\80(òöîíõßof_\9e >\vS?Î=ÌxÛ{\ 6E+tÖ\83øY\9c\9a®Ñ¾@\9aÀ¢þÇ\8c\97ÅNÿo¼ÿmãýñ\19Ã5Ã;ë\1f6\õ¬á\1a\90\18nJ\ fgøÉ  \ 6ÿößÃ\90ÒÛÜÈp\rT»l¸38X+bÓ+ðáÍû»s\15\94\15ÙpËéÂ?\15#kO\13=¼eúÔ\83\rÿ\9bâ\8d\9fê              \17\1d\95O\93\88\13Ñ \ fI\95¿ \99\11ÚôÇÈå\84\87"èT5\99Î\ eü\11r%ÿñ/Ø\91\95=õ8\80LdéÉ¡è?Ë-WÇ\19«ÂZ<\91/ú%:×\f´©\11ùP·\ eÐBu?ÂV\8bÌô[|\8aãxîz\v­0E¢\17ÏÅ\ 14\8a³b#\8d\ 5ÔÛ¿#\16üg \86\88\94ôH¬ÿÝ\11pNs     \97}kðÆ©\ 1\ 1®XJñ}áÏ~G²â\87ªÙ°§¡\f\8d\9aõ©$\13*ÿþ\987k\9eþbÔóø<Ç\84þHy\ 6ø\17\ 2§ND*íÔ~Ì\9f\96:»9\102\91Xõ¢å|§Ë\84ïÍòÕ¿\0ͺç\
+endstream
+endobj
+1210 0 obj <<
+/Type /Page
+/Contents 1211 0 R
+/Resources 1209 0 R
+/MediaBox [0 0 612 792]
+/Parent 1208 0 R
+>> endobj
+1212 0 obj <<
+/D [1210 0 R /FitH 686.127]
+>> endobj
+1213 0 obj <<
+/D [1210 0 R /FitH 349.887]
+>> endobj
+1214 0 obj <<
+/D [1210 0 R /FitH 329.113]
+>> endobj
+1215 0 obj <<
+/D [1210 0 R /FitH 306.136]
+>> endobj
+1216 0 obj <<
+/D [1210 0 R /FitH 287.014]
+>> endobj
+1217 0 obj <<
+/D [1210 0 R /FitH 266.794]
+>> endobj
+1218 0 obj <<
+/D [1210 0 R /FitH 243.816]
+>> endobj
+1219 0 obj <<
+/D [1210 0 R /FitH 224.694]
+>> endobj
+1220 0 obj <<
+/D [1210 0 R /FitH 192.519]
+>> endobj
+1221 0 obj <<
+/D [1210 0 R /FitH 168.988]
+>> endobj
+1222 0 obj <<
+/D [1210 0 R /FitH 150.419]
+>> endobj
+1223 0 obj <<
+/D [1210 0 R /FitH 134.055]
+>> endobj
+1209 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F11 573 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1234 0 obj <<
+/Length 1952      
+/Filter /FlateDecode
+>>
+stream
+xÚíZ[oÛF\16~ϯàK\ 1
+\89&\9cû0@\17°\e'u\81\ 4\89£m\81Mò@K´Ì­L*$å4ýõ{æBñ6\94­¬\8bmÚ}1ç¦\99sùÎmÆQ°\ e¢àå£ÓÅ£§/$\rb\14\v"\82ÅU\80#\81\94\88\ 3¡\ 4ÂD\ 6\8bUð>\14\88¡Ù\J\15¾;[üóÍlN)\r\7f<;y~v1û¸øéé\vÕÙ\ 1æ\90d1ìo~Ë©^ò(r'6ß`N#\86\ 4\15Á\9cHø-µ«?D<Jà\ fîý(x?çQ\14¾\98)\1a\16¥=>M\963¢ÂkÝcá²È«t¹«³[=\98Ú%·3ÎÃd³sÝâÊ\12+£.¿L"IXCív\93\8d\1cE´YqU\167v¿È\1e]\17¶K\9eØo\96/7»Ê\11ò¬ÏÇ\1cS\81b¢ ÁQÌì\8e\19ò1{î£\96D\88\90ò©vÄbÜã\bI\8a\9b5ÿð°\13!\8eE³ rÂ)ýÇñH\8cd3<\8eIqÿã\9c\94Ê4YYù%v\0Ï/³Ú6wy\95­óÔÍg3\1cæ3"Ã:]§NùIe¿¯Ï~Ñ3o/\ 6"\9cÇ\14Å1Öò\ 61+'g¿ Ï6Uú¤ÙV\1fl\8f5[+ØÚNÕש\1d\aP\89.¨òtx6ARHw´l\8e\9e\9c\12Ò;\fºYe¿¿§e¡I#L\9f\9fÛÁÏ\r¡\9d\94®±,¶Z\10_²|­\a°\91*\8coËô6+vÕæ\8bí¯Ò\ f\11fV¶Ð­ÒZ\93\15`\81Àæ\80f\8cbÎ-ÍÅ\95åðÓ.Éõ\91µå¿LòuZ\81;`\8c\85çy#\9dÄM/\93j\bz\8c$迧\8a\93# Ï\11\1e\90ÿ#!h\ 50ÆßÅ\9b1ôx\84@Ä}~O\8fA\9eÞ´\aº\91'Ó¸\18\1e\e!Lãþ©?\1cÀÜþ\18hY¸\19,\e´\89\86\1c\8f»Ä\121Á[uüÛë.\ 5Þ/±<\90¾á@W{zÏ\ 1L îqp¬»?°¨d³æC\14Ec\1ab$[D`\13PÌ©I¾r\8d)\ eE\ 4pm]\9e\87¿9a1`RôÍÅðÉ\0&-\9f\1eî\0¨êp¬\ 1k\89öKtÔ\85-\17×ZEzó*ݤËÚuöGj36\rm³úÛ±Yݵ6kÛ­\aÐ\86\10Û\95ê³r¥c,ãÄ\1d\0\8d*¹q­e±if·\9b$w£Ú\1eì\ f2ײXb\8a\84\97»Ú\ e\8d·m¼\93!%ê\13±g!û=©³¢q4ÆËmg\904\84\vÀ£|`\ 3Ï'-ÏyÐI\1cp$ãø. ó\98\r\80Nú@'\ 6èÔ\ 3cN!¸â\ e\8c©\8f
+\93\1a\rÍA\r¬\81í­í±g\8f¸\9b\ f´A|`R"Æw\9a\rnr´\81'VHñ=1ß\7fïÛ¥Ã\10u:°F\89§\95\ 1(\95\92|µURÙU\8aîNy\1f \9fÜa \90µ¶\ 6ú\18\90\18ã\90hq|Gµ¹\82£^\CÊb\f\ 1Nj-\16:{rn\8aJ[\ 5\15\10\85\96©MolßÚ2,±éj0\17\141*&\8cÃE2gß:zìí{d\1d\fq2°\8e3¯u\9c\0\89|Ï9w\9cÿë·\17ï<é?A¼ÅÉ{_D7ùÑALã.J>ú6\ 1Ó£ü\bOúq2\8dó°© ÀÐ\afÓç?\b¢*>\86Mÿ&¸]òq\94\8c\12\90¾Ú_\1c©v bÏ   Hãü_g\1e\89hÛiˤ?\93â\89ÄVñDv¼se'2\1fÇ\82 ¨¥ãáXþCAÀ¦A 1DFܯI^\1e      \ 2       á\8a´"9}uî\93\b\ 4¬\96Ö?¿õWMÍî\ 3\ 18L*\1e\9cãÿ\95#P\12bóÀ\11\87
+\13\12÷*S¢leJ\14\9d^ðù:[êðum'²|\95-\93ÚX\97"®0Ô­¦lÕí¤\84\0éÚ.^\99ÂÕÌÙ}òô³­L!\r\93¼\1fýL\88t7:F\9dÞphJT>*QéT\89ÊïS¢\9eLe(`\1e¸u\92\9fJ\1f$\ 5ÂrP\17ݯ¶\ 3w\14\ fKèÓ#é\83\f\8aíãÕ§    ³\93ìkÈã:ëc}ïâ¯=/\É\r\ 5¯+v³M\ 1\8aÇÝz°g\84\92¢Ö2^\9f¾zçÉ^)Ô\8còÎì\15Z½ìõ\98b\7f\1cG\1c1\19÷\91ù­¹Å;7ñ\ 3\99\18\9e\ 6²^jî\15t\ 2ëj@h5ßu\99\82G(\9bi­zÝ*ÜH
+æ»q\93\85OÔ±D$\96NÒb\b\85^VÆ ÎíÅèîVªºØ:g°hP]Õ@Ó\8dSxÕÀ`\95.\ví~ÂUr¹\19\95\97P_´\17YòPy9      sj`.\88\aÄJ\17â\1e\10\ fJ¹n9èQ\8dB\82Óv\93{¡ÜÝåMFþ¹Ò¥\9f\1a\eK\ 3\1f\ 4ê\87ï\82õ\85â\13;³ÝìªÉ\vblÊmvl)6ôçÝ{¸¯ñç\9eM\81Ûøð¦\11R­ò\1e{ÐÒs´\7fO\94\8ck0ì®×\8fªÁ\86úÆJýwùÅ\9d
+/'\1e¿º\1a\anH\88G\90\ 6\16Å\0Ñ/\1f*\ 5\80<\1cÓÿç\0ß\12ä1Ìs¬úÁòÇ#_}ØýÝ[\13Ã7iåîÁl\9e¡Ç\ 4u\89Àº°S\97öéøWçÍÝhU§[C\9fFQ\14\94ëÀ6.\f¥z¥Ü¿Ng·Ï\a¬\84C   P\8a\88¢}\8b8?B\0P±Gññ\ 2ØçZ\1328\9c\f\ f\e&C¶^Ãc.\19øñAåôÓ\91\17\vz\vöW¼T\1c^-w.\15ïaSÈçq\b\8b\90\10`W` *v¹ðÏoèlÎ\99\f\7f(n¶I\9d]f\epk\94\84_|\ 1\t¯è\r\ 6\98\14\9eç\16=ºMÊä&\ 5<U¶oÞ\9buCßp'åªA\88ö\9bz8s¿\ 3\8a\90½½nÎë¹ÈÅ(65)xÕxàæ\8a@·×î\9f)òýe\8d\19>Ùºw |\95ývÈr\19\14ËÔk¯ ^\15\88\96Ndþ\eE)Õþß\v\88\16\9c\197²ÝÕö}]ród\f\9f·Zl\14w_©`ôUR\97\96¤\81þô\e\97B4vî ßê·1ªhGÐϼÿ.s¶xô\1f\89\9a
+endstream
+endobj
+1233 0 obj <<
+/Type /Page
+/Contents 1234 0 R
+/Resources 1232 0 R
+/MediaBox [0 0 612 792]
+/Parent 1208 0 R
+/Annots [ 1224 0 R 1225 0 R ]
+>> endobj
+1224 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [347.685 256.172 383.025 268.127]
+/Subtype /Link
+/A << /S /GoTo /D (Item.70) >>
+>> endobj
+1225 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [278.697 190.979 295.496 201.827]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.3) >>
+>> endobj
+1235 0 obj <<
+/D [1233 0 R /FitH 686.127]
+>> endobj
+1236 0 obj <<
+/D [1233 0 R /FitH 668.127]
+>> endobj
+1237 0 obj <<
+/D [1233 0 R /FitH 651.689]
+>> endobj
+1238 0 obj <<
+/D [1233 0 R /FitH 638.294]
+>> endobj
+1239 0 obj <<
+/D [1233 0 R /FitH 624.347]
+>> endobj
+1240 0 obj <<
+/D [1233 0 R /FitH 598.444]
+>> endobj
+1241 0 obj <<
+/D [1233 0 R /FitH 584.496]
+>> endobj
+1242 0 obj <<
+/D [1233 0 R /FitH 570.549]
+>> endobj
+1243 0 obj <<
+/D [1233 0 R /FitH 520.735]
+>> endobj
+1244 0 obj <<
+/D [1233 0 R /FitH 482.877]
+>> endobj
+1245 0 obj <<
+/D [1233 0 R /FitH 468.376]
+>> endobj
+1246 0 obj <<
+/D [1233 0 R /FitH 454.428]
+>> endobj
+1247 0 obj <<
+/D [1233 0 R /FitH 440.481]
+>> endobj
+1248 0 obj <<
+/D [1233 0 R /FitH 415.131]
+>> endobj
+1249 0 obj <<
+/D [1233 0 R /FitH 401.184]
+>> endobj
+1250 0 obj <<
+/D [1233 0 R /FitH 387.236]
+>> endobj
+1251 0 obj <<
+/D [1233 0 R /FitH 349.378]
+>> endobj
+1252 0 obj <<
+/D [1233 0 R /FitH 322.922]
+>> endobj
+1253 0 obj <<
+/D [1233 0 R /FitH 308.974]
+>> endobj
+1254 0 obj <<
+/D [1233 0 R /FitH 295.58]
+>> endobj
+1255 0 obj <<
+/D [1233 0 R /FitH 269.123]
+>> endobj
+1256 0 obj <<
+/D [1233 0 R /FitH 255.176]
+>> endobj
+1257 0 obj <<
+/D [1233 0 R /FitH 241.781]
+>> endobj
+1258 0 obj <<
+/D [1233 0 R /FitH 215.332]
+>> endobj
+222 0 obj <<
+/D [1233 0 R /FitH 178.034]
+>> endobj
+1259 0 obj <<
+/D [1233 0 R /FitH 157.265]
+>> endobj
+1232 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F11 573 0 R /F14 574 0 R /F49 457 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1262 0 obj <<
+/Length 1556      
+/Filter /FlateDecode
+>>
+stream
+xÚÝXKsÛ6\10¾ëWðVrZ"Ä\9bÈ¥ã\87\92:S»\8dÅé¡\8e\ f´ÄÈ\9cÑË$\956ùõÝ\ 5(\8a´(ÉN\9cδ\17\11\ 4!`÷Ûýv\17\eyS/òÞ\ eN\93Á«7±g\88QLyÉG\8fª\88(¥=\15+B\99ö\92\89wãK\11Ü&ï^½Ñ¼³\92\92HqØÆ®9ûåä÷dx\1d\84\9cs_\91 Ô:öO/\92Qr=<¹tÓ¿\f\87×#Ül\10Õ\12\f\93ÁÃ\80Â0òèöt¥\89\eÏ\a\917\81\8fï¼\88h£½¿ìÒ¹Ç\ 5'\9aâ\1fgÞhð¾G\13\1d\13!¥§¤&L('åU:Ï@\16­"? \98ö?¯\82\10\1e8ǨðGù\97\f¥ó(\85Ý9÷BJ\89\81\9f?D2ºË«\12\9eÔ®â1\89\ 1£ö\9aQ>]d\93\9f\83\902iüó¬\1c\17ùªÊ\97\v\87\98¸A\91\95°Æ¯\8a< þØ\ eq´ÄÑ\ 2\ 6¥\ 5©\1f\1cn@¶\1dp\84\89\ f\83\8e\9dcO±\98\80<Nø\93\803ÿltvòëÐ\19¼\8d§RpªÜ\98ûb\11°Ø¯²iVX(¢.TiQ¤¸à³ý\18\8cèàD\15\0Ϥò¯\96v áðP*ê+\11\fa\98\f7¿Ý\11^\99¿üè¦K\8b]:sf\ 3·á2î\8aò)\80SÒÙ\1a\ 1\17\7f\\168Ðp lwæ&ÇKç\a\1f"ªÆyæ¬\80\87\97n-þ©GÍ,\1dãªû\9a\1eQ\v\88 j\ 3×C¾\v(n¤ÅfE#&q+;Ö
+\99\8c\bÕº{úùÿÚTbc*\18\19\ e4¨ì&¬½âÆ^õémíjÂÛ-\90pÖTº×T\\ 3\15ä\8b\99JI"`ÜÑìôrtÌLì<\b\15ÄÌç\99K\11¥eÇ\ñ®µv¥Ô\8c(Ê6G_5âQÑÆ\ 5\14\91z³èC\14±]\1d \ 2\8ax³D  d\91®eÔè\0ø:^:\95Ò|\11Z©C)\88\14]½òÅÔ\19ÊÚ\9asáߥeæ¦æ)ÄÉqVöãM%Ññ#j\½¿þ×\0ï£\a7Êg=\90\ 2½ \9c\1c\86\94F\847\90r·W\8bRøj\11Õ\16\15\ e:\ 3ï÷ðæè\152\ 3ñ§«\89Õs=Çß;G\1fä\860\96¡\1cXõ°N7<Æé"]L\91\8a8v<\825i\1fFÓü\13þ\ f\13\b%\89L£òCÕG/A¸jTÆ\1c¹»\ruÙ¼^³\9aõ³TGÍ6?\81\8a\90æ!Ñ®\9c²ãª\96rö9\88\85O\1c\10È\81Ý \91Üç¥ó<÷\14~ZÕ\9e¸,ë\91âO÷FpÆ\8b?\87G\1d\92\7fG\87T\90äz\1dR\10Ãù\11\87\ 4\\rÝzäî.\86DìY\9b(\8e"\99¶_£\84è\888\8d\ 5
+I Îìê_B\91V¢q]ja\8aoó°\9dm¹1~´nì¾X/ÆÁwóbý\ 4/VßÙ\8bku~[Ìl\0V.¤b$\86t)\8a²êq\,\aå6!ô\86\88ä\8d      oúP"Z\1d\ 1 \ 4Ü^\1anû6\91pÊs\88~ë \80\82\9bP©öW\14\96ÇE\9dRÖe69@àG\ 1áýõéåÅ>þª\97æ¯ù\ fðW<\85¿\8f\fÛËæ»y\9f\81\15\89£æ°\1fÀxp\e´6\83\11\8f\1c\8fqª©êìÛ\96øÎ#Ü.\9dãê`\0é¦Ni
+S\9a}lèï\8aÿ]ñá>\19\19sØ»%Ù:÷\9e\b\0\977j\9e\15\ 1ö»÷\9e°À!,À:\1e×1@*éb\0\ eZ1à±gâ\ 5·\87\13\9cÄZ>!4\1c\8b\fñKD\ 6q\1c\8d\f¶ZúÑUGÔÞÛCid;,¸ð \97`mº\9cï\v\15\1f\ 1ݺq¢\1d\1fÀ$\82ù´&zÍxe\19\ f"7\ e\9d\7fI]\13\ 1g+˸¦s\81Sùb\92ýír\ 1\15Àf\bå\1d©FY­L\82Þ\91Þ¹KXÝZ(¦\9e\e\¿\1dx7v\19'´Ó¥\81-\9e\ eA¯e\8eAÀz à\1aoz3ËSÈ^«YºÈÜl­o(aÚé\ 6\ 3§[¸\1f\85£j³oQûá+´V\8fµNîkC9Óë\96ém=Úع¿7Ä\8c\81\v\19\7fv㬧7\ 4\9bi\ e×4SW\13ëjµÆÚ\170^¥E:Ϫ¬(_\1f\10\ 5,ÀÄ·µð\80\97J\b\8fñ\98h©Û-<\86uMÒ\10Á\86m¦Û-<Ãa\9fohà1-Äá\ 6\1e^JñË\81^\1dc\940ù2­:\16¡mE]\91\\9e\ 4\ 6\11Øq9¡   ¥â«\9a?\1a¢'\14xG\9b?BÆuógÛøÁ¹Ö½\1f\1aÀçN\14kú?f\7fµ&¹r\19\1a\8aÁV}\8fÓçg\89\9bîï\ 2ÙOù¢OÝEZ­\8btæ,¸,&Yq\80K4\8e\bã/Ä%*Á\1dyÍ¥?\ 2{¥Ï1\ eca
+u<&\99×\9dØÓj\90ÿ\ 3\17\1c£\17
+endstream
+endobj
+1261 0 obj <<
+/Type /Page
+/Contents 1262 0 R
+/Resources 1260 0 R
+/MediaBox [0 0 612 792]
+/Parent 1208 0 R
+/Annots [ 1230 0 R 1231 0 R ]
+>> endobj
+1230 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [420.568 336.826 435.29 349.324]
+/Subtype /Link
+/A << /S /GoTo /D (table.3.1) >>
+>> endobj
+1231 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [391.51 312.916 406.233 325.414]
+/Subtype /Link
+/A << /S /GoTo /D (table.2.1) >>
+>> endobj
+1263 0 obj <<
+/D [1261 0 R /FitH 686.127]
+>> endobj
+1264 0 obj <<
+/D [1261 0 R /FitH 668.127]
+>> endobj
+1266 0 obj <<
+/D [1261 0 R /FitH 285.504]
+>> endobj
+1267 0 obj <<
+/D [1261 0 R /FitH 249.638]
+>> endobj
+1268 0 obj <<
+/D [1261 0 R /FitH 165.894]
+>> endobj
+1260 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F70 508 0 R /F14 574 0 R /F83 1265 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1272 0 obj <<
+/Length 1973      
+/Filter /FlateDecode
+>>
+stream
+xÚíYÝ\8f£È\11\7f\9f¿\82G,­û覿H\14Es·s\979åFÙµ#E\99Ý\aÆÆ6'\f\1eÀ;»ûקª«Á`33É%\ f9i_\fT\17ÕõÕ¿þ5\8e\82m\10\ 5?]}¿¼úîG\13\a  K´ÐÁr\13ðH3«\93@[͸0Ár\1dÜ\87\9aI6\9b\ecÃÅÍòï\7f\9bÍã8\ eÿrsýöæýìãòçï~´\ 3\v\8cLÀ¾{W)T¹\8aü\8c7Ë«Ç+\ e·QÀO\93\8cH\82Õþêþc\14¬aðç b&1Á\93\a±\ 4«\1c_,\82ÅÕ;ò|8-ç  \93F\ 5Z\19&¤¦ÉïÒ}6\9b\v#£p9\13&ürÀ§Ðɸ\f\17ù×\f½\v\12Ë\94µÁ\9cs\96(Eï~\88\90·\r\¹S\8a\90\91¡Î"ß\96ÙúÏ`N\98$|\9b5«:?´yUR\8aÒr\8d72¬³¦­ó\15\8e4.\1dÓi\88\13\8b4Èľ\9c\ 6\13M\15PX\ 6>\90\9f«ü²NJ³Ø\88®L·åLذͶY=\9bK-E¨1*¥Ã»Êݨp¹Ë(¬·?,)¬\15\ eÙ0û\10q½Ê32A:y¹Î>3\9auäßÜÏ;ÊõÃþ78\98<ëàCÚdäá>\85¼\7fþm.ýúÿæÒcý?-ãã1-qQø\8aÕi¹ÍÎÝ\9aväÝíb9³qxý~f%¬¬9\17Qäæ6\83¹ùssG6,²\rN\eÁZ,×sZ\95UÞ»\ 3òjC×v\97Mä'\8e\14\93\91ìÂ~\9cH\f8lx\9f\18\17\9d\ f\86q®}Lº\8béæî-ø\11\võl\16U\17\89¦H\8cNÂ:ßî|ß\emûp,\85ãå\89\v\aÇ\9f  'V,Rö¥pæ\1cÐA%z\\89aX<\81\9cè³R}ÿ\vD\10AM\87ÕAõ©º¦u\9d¢Ï_\9c\86Ñ.\81C\ 5{^Ðk,R\12j9Ï\8al\9f\9d
+\98\f\8c¹ÇUEéHó2/·$óÉ\0¬\ 2_Îà×g/«}6\8b´ÍÖÓké¥øßýr{\87\ 6T|VU\ eUåÓe\95\87ùy\98ï1 ã\1eeü´`r\18ú
+]\1f¦\84õ8øi\ 6vÒâ\bC\14Ô¤;iQTèÅ\13þP<Q¸©À¡XP>ÜÍêX×'8EÁ\14ÒNÆݵóâ\87ë¿Þ\80\8fJ\9aç#¿\84\ 5y67¤»Y¥\85\1f\83 5\ 6I-7½\8bÉ\84\ 3sÐÿÝf.8³<\ e¤ÆÐ|HÎC!-ä«Ë¢ë$\14\1djJÐ*[\1fk¯¶\82\9b\aÊ\1d=\1c\eL;Þµ\15]·Y\99ÕÐ]ô\94Ò¥\ 1Ó\85\17=bQ»Ò\7fõ5Ç\ 1\ fåT\ 5É\12)ÇÕ¦ÂÆ\ 6\8dƱ\ e·ù§\19yÂÃ\92DÔSv`\18õ[·p¨ó³7$[UEgîP¤e'F\8eq (\ 2ðQ\9bäE|\14,\8aL§ÑWÖ\99µ½«\9d\1d\ 6¼¿.x\ 1\88
+\8cq\1cý!­\81
+n¨\8fÖ\99ïâuæiQîyÒ"[u¶|;ÕÛ\80nÞÿt\15Ü;%$¡bÄ%a\ eZ\ 2S¹¿«\E5®ª´Å;\ 2_':ÔPQïÌqÕ\92\10!z¤å\e\1feÝêö\8f\8eØ\91m/!LBQ·¿O¼\96\82qãó±\ 4~9Ñ>¾áÝ\16\b\ 6x\14µ;L¢\92½,¥Ë\ 1AêsVÐÓ\b\83 Ç°\96*ñ4\14\86Z·S\1d\ezʽÉuþ)§\92\80ð¡\83l\9a\974p¥  ÎÚc]ú·Ûñ\18Åræ#\86\16\8dëÒ-¬\98\8bð\80@úÙ¹\8a\11p>\ 4\98¹\846\î\9c\97ü\f_ÝÛ4"°\ 6%é¸\82­IÚ\a\ 2òMu¬1\17\\93»0\fUZ¡Æ\8e4¨¿A\8e&h\7f\ 2©\v\84f\98
+\85x02\97c{8¶o\bª\9fvyo\19Æ\9c\97pM\8b\ 6§\16\ eaP°IW-\ 1¿';(\ 3Gé®Hk\87Öø\ 24pIR¿AÀ\vu»«ÊªÞ§\ 5       hµâR\83\86Àæ.§<vóÀZj;°o\81@4\0S{6^Y\0\ eÜ\18xÙ²\b\16÷2?Ó¹\9f+`}×M\ 3\87     \b\92\92i\80îè\ 5îÊá\8c    G6¯Òî\86ô\93üë\1cN\87\94ÕïLrHY\9bc\9ft\fk\87\88Ýú\19ã\11Ó\82\1aÂ0%ù\18\1d¹\1cã\91½û\1f"¡|\8c<Ð,1±¥Ã\16ÓÒ¢n"äY °}\8d\14¥á'k°²ÈÚ@G38Ev*Ü\e\193@¦T\ 2ü\95I¸8µ\7fL8\ 5ãpºEPfÜöG\87_/'\ 4§ì)Ä?y\97àè>&Ñ\18 \|\17¼{¿¸ýçÍâ²\98\12\8eÇQÜY»\9fÈ=dT÷\ 1>¶S\r\11öß7ÄÇ)#\8a©¸çý\87\88\12âÜȨ7GFúÜ\9c\19\11¶/ØG_\rþ\4\7f\9c ì\ 2{Ma¯Á"JüI¼ß®GAYØ\8b\9eã7\8cÄü'])§ºR\81\92y¦+G\rÅð<ñ­\9d~gí\ 4ÔNyèzÚe\8eîZ\ 5\b¸ßwÜ\14\9bºÚÓ@D\17Øù¦ú\89;Þq\ 1Lé\8d+Z\ f\9a£20Í\1a\8f$²t\9c\9a&q×\87þ;\e<|Íê
+÷sÀçÛ\8d×;ùM\96T¸¯H"i¿#V$\12¦\93³3TU"æ\e1Ä|Ã\87\\v\aaç¸,\94IX,ÕË{\92`Võ Á=ÝÂ\8eÊ2ÖÝn¦v\15\ 5\aXõ"Û\8e\81 ÷\rPäYãÝ,É{Úü\8cð\87\95êX®Óú\v\8dùóK{:8:Â\ 3Ê\9dÈ \99EÕÓ\ 6éY%gp¸\9bøfмA£Ú\93'a<'\10Fz6C§¼(Hz:D\ru\9bî\ 3+pÃmZ¯\8b¬i¼\95\8d·p¢CN\z}Wv\18_¡÷»ªÉÊ3z1G¬\8b\1d\ 5\89­GOñ\12\ 5q<`øi*\ e\97\13\ fzdj/×L¹/"@\¸ù¶\9bÛH¼\ 6¿öuø\95¯Â¯z\1d~ù«ð«^\87ß×зWøèÉ.`\18\19ü\8aÈâÈÒ\eñ¿Ñ\97îó"\91ÓS7êg»\11\8a¤±î®\eõïz\17ÿÖFÐ\13\83?Àþ\ 5yÊ«×
+endstream
+endobj
+1271 0 obj <<
+/Type /Page
+/Contents 1272 0 R
+/Resources 1270 0 R
+/MediaBox [0 0 612 792]
+/Parent 1208 0 R
+/Annots [ 1269 0 R ]
+>> endobj
+1269 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [242.417 438.622 264.888 449.471]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.2) >>
+>> endobj
+1273 0 obj <<
+/D [1271 0 R /FitH 686.127]
+>> endobj
+1274 0 obj <<
+/D [1271 0 R /FitH 668.127]
+>> endobj
+1275 0 obj <<
+/D [1271 0 R /FitH 378.887]
+>> endobj
+1277 0 obj <<
+/D [1271 0 R /FitH 233.875]
+>> endobj
+1278 0 obj <<
+/D [1271 0 R /FitH 172.923]
+>> endobj
+1270 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F83 1265 0 R /F14 574 0 R /F71 1276 0 R /F13 705 0 R /F7 674 0 R /F1 667 0 R /F49 457 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1282 0 obj <<
+/Length 1737      
+/Filter /FlateDecode
+>>
+stream
+xÚíYYsÛF\f~÷¯à#5\8d6{\1fî¤\1dÙVjej·¶4y¨ã\a\1d¶:lRJ\9aüúb¹<¥\15%O¦ÓN§/æ!\10\vàÃ\ 2\1fÖ8x\fpðÓÑÉäèõ[\1d\18d$\95Áä! \12#)U µD\84ª`r\1fÜ\84Bön'ï^¿U¬%I\10\96\fÔä2§ç\83_'Ãë^\9f1\16JÔë+¥Ã\93Ñd<¹\1e\ e.Üëóáàlx=¶Ê\8epaAym\9bÑ'\#­eЧ
+^2·\ 6G­O\83\9b¾À8\1cdYò¸(,Ä\r%\9c\83+²4ðn\9e8\99æ:\14\83\97¤\14Y}\8c\9d¡\9fzB\84Ñl\1d»/¸ij¥H\eQ~ru}r1\1ao+æ\12\19VIÝ\14\ 2ÍøQ¤ Î\85ÀóÊc\1caH\93JÇ­O\89@¢^åiæW"j\ fK%­8µ\94<§>%à³à\95\92\r\18ú\14k$9\aÔà\13*\8a¤ù6°~÷\82%¸ú\1f¬}`  Ø\97º\14ù®×§\94\86d\e4B\10Õ\e I/ho{\9a\85ËÔ\85;\8e¦=ªÃ\8fö\89\87Óå"\8b§ëUòɾÜB$\7f\>xü \0\8dâUù\98ú\1c!Ȩ*ë\1eÒåÜéÃnéÕ²(6ì\95»I\16ÓÙ:+,9Þp\970\85\94n{û\ 1\v\1cÁ\1fÒ\91©¹æ\93\v\1f\14\12²\1eó.\ f@@T.Þ:]EÞr\e%Yåmзñ Ìâ\ 2\89dj\ 3©SKx;2X\9a\a\8cÙöÚ
+\11#k\11\81¯FÃË3\8f2f\105ª¡\f{r7¿«ÒÎã*Ü©\86E.¦\e+I\84µÞ¶ºµc[f\9f\xv+\15\88\99\8dÍÚÂÅnVÝYö\89Dúð]v\0²9\82\84C\ràÂÞ \ 3å°¹ÿ¼(\82¯BïGQ4Qô`\ 3«ÖۤĦ½\12\ 5\ 3ñ\ 6Â\95ÈÕh<±\9b~pÝÓ<\9cìÀS@AÆâ\0@Å~@É>DUgo\80XRªþ\ 6\82·r\13Óm7Ûá»\1e\8f~\eú:\r°\1aL÷u\1a½¿Óð\7f!-hd       iízÉ+\97ß¼Ù\93y/-y»s­\e\ 4ö\1f\a¡Ùé\rAR)¸á\b\93:Ìw{[\1faáÕÅèÒÞÑ¢q\91v{\87÷\8f¶ãª0^¸Ç;ûðÅÝç5$º\9bå-îÈz\8a\83ô1p7×ùzV!\8c\1a\ eû90\8d>\ 1\8a\91Þ÷\bt÷G·<ô}\ fbv\9f\8d\99¥y¥D´¸÷±\12\83H]iö\16  ä\1deÊëprô\8M ÈAÖA\7f\17X!Mu0\9d\1fÝÜâà\1e~|\17`¤ \ 3\7fÎEç@\8d\14ÊwÌ,\18\1f]mÏhTr\90'\ 17
+1^p\99S`C\96÷|ÀDN\13\0\ 3\1eV\9e@I\93Ó\8b®8\ 1S\92¦
+e\9e\0ÖM¯;\1crK\81ð\86;ÜèNwÚÕ]qÄ 1¹Æ\88\ 1Aè"\84¼Þ/oÀa\981\81\rR"xÉ
+mb\8f\9c÷©ãv}\86±\b\89ôÀÝ/4Ú«\11¢½r«\88µ\97þÁc\eôBR\11\17g\94pF1¯Q\ 2ËPûl\ 2\ 2h\98òÛtp4ÈV4â´\8c\86$!£ÿD4ÈV4ZF9\88\19\83+¥/Ø6x×\11\a\ 5Â+À\1d\ e-]È"ÝêJU\1c`\10}ÜësÎÃ\8bd\91ÌmM[C\11\9a»°^­#g\7fò5Z%ËbJx\9fë\80º\98u\96\ 5 úPeòz\fÄ\877¨þtWA\1eù&(ª\9ag\17û\a¨øy\1dÍ2gê×8]¾r¾D\8d9çj|:øyØ5§l4\¢ìqQÕ ÎN\9d\82-K\ 4T,M\ e\9f°÷\r\18ÛÓ¬Ò@"í4+\80§Õ!½ß\15Òá,\8b\8b¹±\8e\0÷E û\84\81Ø\ 4U\95å\83\1e£aG\14\18S\87\13\8f\97G\ 1:¼%\ 3.
+\8dV\1fïiõ\9e\93\13\83p³   \fzFÂ.Ùn\16\ 2\86\98ÃDZo\9e\92Á,\98þò"I\8aãÉyôg>ß\16\8dj£VÁ\90ÂêÌúÞC\a¡jTöÍ\93\85Õ\95ëk Ø\1ec\15Ð6þ\82éÛ\7f|@4TYù²\81d÷VhwQë\8a{\13\8cw\fr\10MÌØ\v&Qî1\ 6\ 6¤z\8bï\8b3ÇFZcvÌ\fPÛd]¹\8e\8büÔ\81ëL4ïVÌv!é\8e\88µ6å\ 1\16,\ 3¬\91P\ 1Õh\ 2\ 4¤­ááò\8f\1e#\8e¥Â«ó5\10%6\8f\16\r  [þ3ÏVÀ°\9f º\94K\8c\16\15|\ 6Åþ)J£y\f],;öõ@\f-«râr¹\88\91G{¿\94³í@CÒäÒ¿¬W»Vi7ÈòÀ\9eB\83\93W2Î\90"d7±$ÒÎj" T#^\12\80KX\e\ 2J¡XLlÏûòä\88&¼ÓÌ\84ãä«Û\9a\ 4\95\90O\19É*+Q\ eò.®\82¦Ì\18êO|ÿ£u\95\98ð,ΦiòT6U\9eóô¼"¤q¶J\93©ý%ë\b\ 30\ f\ 3ñíà£Þ0´kz®\f²Í\0SàÅ?\1fÎ'¾Q\92!Ró\9cfRÙ\1aVò      ð"M£<xö\91Èp\0"0   \84\1a÷ãY</ézþ®!k\1f\97\ fîznù\87Õog¢|\rË WUÒ \bc\9e\10m\ 4>'«\8fÎ\9aõSûØ\14( ;Ï-xi\12gN <àE»£L4\81-§^\9cl\9e(\832\ 1C®¡ÎÞ÷¶ÍDiâÜ\82\9càá:\8bï\8f½\8c
+lû\vNÎ4_
+endstream
+endobj
+1281 0 obj <<
+/Type /Page
+/Contents 1282 0 R
+/Resources 1280 0 R
+/MediaBox [0 0 612 792]
+/Parent 1208 0 R
+/Annots [ 1279 0 R ]
+>> endobj
+1279 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [378.411 519.186 398.115 531.141]
+/Subtype /Link
+/A << /S /GoTo /D (table.6.18) >>
+>> endobj
+1283 0 obj <<
+/D [1281 0 R /FitH 686.127]
+>> endobj
+1284 0 obj <<
+/D [1281 0 R /FitH 668.127]
+>> endobj
+1285 0 obj <<
+/D [1281 0 R /FitH 651.689]
+>> endobj
+1286 0 obj <<
+/D [1281 0 R /FitH 631.763]
+>> endobj
+1287 0 obj <<
+/D [1281 0 R /FitH 610.399]
+>> endobj
+1288 0 obj <<
+/D [1281 0 R /FitH 533.133]
+>> endobj
+641 0 obj <<
+/D [1281 0 R /FitH 426.523]
+>> endobj
+1289 0 obj <<
+/D [1281 0 R /FitH 400.676]
+>> endobj
+1290 0 obj <<
+/D [1281 0 R /FitH 384.736]
+>> endobj
+1291 0 obj <<
+/D [1281 0 R /FitH 368.795]
+>> endobj
+226 0 obj <<
+/D [1281 0 R /FitH 318.989]
+>> endobj
+1292 0 obj <<
+/D [1281 0 R /FitH 301.098]
+>> endobj
+1293 0 obj <<
+/D [1281 0 R /FitH 273.265]
+>> endobj
+1294 0 obj <<
+/D [1281 0 R /FitH 239.337]
+>> endobj
+1295 0 obj <<
+/D [1281 0 R /FitH 167.548]
+>> endobj
+1280 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F49 457 0 R /F83 1265 0 R /F14 574 0 R /F11 573 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1299 0 obj <<
+/Length 2432      
+/Filter /FlateDecode
+>>
+stream
+xÚ½\19]\8fÛ¸ñ}\7f\85ß*\ 3±N¤¾Û\87"i6ÍÞ\15É]Ö}Ê\ 58Ú¢m"²ä\88Ònö\90\1fßù eÙk§w(Ð\17\8b\1c\ eg\86óM:\9amgÑì\9f\967?¼ÉãY\19\96\99ÌfËÍLDYXdå,+²PÈ|¶¬f\1f\83,LÂù"Ï\8bàþvùï\9fç\8b8\8e\83··/_ß~\98\7fZþøÃ\9bbB\ 1ÖÂ<)\81>íMsD¹\89\1cÇÛåÍ\97\e\ 1Ãh&\8e̲<Ìe9[ïo>~\8af\15,þ8\8b¼Ìg\8f\84º\9fÅ  P\15¸±\9eÝßüÂ\92
+\91\86y\f´Ò<\94IÆÌß©½\9e/d\92'Ár.\8bàé\0³"@X!epo~×(ݬÌÃ\b\88/\84\bË4彿Fi´2½\85¯ ¤¸\b\vÐÈ\14çÞl\e\1dÈ¥I\16¼ÖvÝ\99CoÚ\86\9a\8a\a\9d¶}gÖ¸bI\1d\97Õ\10\97t\8435$eñ'ÔàiÉ"\ 4Î,æÛWwËûùB\14B\ 4¯L\8f2%\ 1JÔÌE°\85©\8c¢ \96p\f\99fÁ»Ö\r^²ð\84¸åq»áÍ\ 3l<ð°oy  ÷ã\17u\16\92¢S\85.ßÿtû\ e¤@fw\r\9a£×[ÝÍ\17I\91\96AJLÓçÜ\81w­yüú\1fKÏó3î×NÏ\ fsبêA_ä{wÿ¯Û\97o\90q\11\8f\8ca\1axæE Î\99¿©\15\9c8\8dË ß©\9eG¦©ÌZõÚºé\ 6¿@k§\19°\1eºN3y\12C\94Q( \10N\84iZòÀJ#ç\84ô\89_"B\83NÓ(\rV\80\98\a\ 1\ 5\10\éµ#\ 1@Z­x§±\97\ e¯XCµVÎr$@\ edÂë\8e\98æIX\bù¿Å£\14@#\9e¥I
+aã<\80N\99%ÁÛá×HÄ{Õà4\ ezµªQ­¸4X]ñ\b\1d\vW\8f'v»É\rh\1fº\ 1許<W\9dð}Ûy2Æ3ñÌ­î\87\ 3éj!\92°L\92S\8dí´ªÈ1\84ä½Âï\ 5À¦íö\f\ 1Dñge\1aÕ=9l°!äˬ\10pbc\19¨\eØ»¦S\ 2º#\88\99áË\80æíô\1eméügÄBßó\ 2\°îT1EN.CÙ\r'\9b¡®¿YÔaQxJ\0VÄá\89Á\16¸ëfív°3æ\14Á¼þhê\9aa\87α\1a<¶b\14\88½\fbÏT\fµt\8a/\83wNÌ0k\82\8d<.\9cc\8c\8drf\12\v/2\8dps\1c1!v<2L\ e\9d\ 6¿J¾.6\1c\85\14pN­sød\eø6-#«=ºÓÊlQ|È\930yâ\95Ç\1dXf*¸+0Gß\844ÅÙç\92O½o°äde°o;7\9a\94\ 4\ 4\14$\f.\1cjµFßÅ1¯\95¬\ 1\1a¸HÁ\r|$\84ú­Më\0úë¡6kÓ×O\8c:\9a\82|Ð%\r\X±3\\r\ 6b\1cCm[¡\93ödݾóÆ\ 5}Áb\1aØ'v[õõ\ 5\ 2Ê`5ô¼Òè\87¹tüq\eЫib-#ìqy°½ãâ­\89\9b=\11\85Êc°÷"ºÝÃ1Ñ¡óÀñ\ 3gö!Ñ]©BÎü²\fÈÚÄ\egGO\92åè\11l/\84\80\e\1ea¡Ã5\17«\9d¡ \ 6\80q\b\8a?¾rá\12Ù\r{¨XB\91é=\94\9d\92¨\eG¤Ó\8bKbO\9c%\8e øê\96J2\f\1fM¿ã\11\e+* ôAÕuÝh²\97åUÊ4\90f|\89"`mö¦?Ù\9d\a{õÕ°jö\f°Ø&Ñ\88Ê\7fD±Ï\v\vâN\12|\9c¦Ó<\15§®e\0\fðå\96a\91\82èw=\83P\1dø\85¼³\ 2Ý=ñFÅÀ-\93óu\90\96L¥Ýª§î2®\ 3î\98b\12Ôªï1¿³\ÍâRXOò"´LÓhJ\84K\ 6´bÀ\ 1}0xÅR¯\84h.Ç\8bÓ\92í\96Å\98Q!Ø\ar2Ø¢,¯)\9ev\1az
+k\\b]ªîõ¶íÀþ{\8c\87Ù.\8e2¢C6uóÃ\18²\ f®oò.\90±-³\80;ãÖZ³¢v\v@¶WkDüÌÓ\16Ç\ fTp;°nJóG^Û\9a\87±!C\9aîk\1aÞCí\19\96\b\ 4^I%׳ç˺ߵÃ\16½¼\1ców\J®÷8 G\82µÊ ÛijÃ8'\0\90»FÀ:V\19PWBbVneÇiÈ\91å}\rÔzU;\ 4ÅZ\ 10ÕÄëÝ\83rZâ4\96gà=jM®\83\13\124O§¹\ 3MWdÞA\ 1Ç\7f)\9b\13òÄÿp\81#ùØþ\89\0\83'\97\1c<y:RPuí\8c\ 4\ 4\0\04hµ\1cÞ\7f\va\19\9f\84°\8c]êÂQ»§v\ 1\87¶Ýëo\9cûaÆòÃ\0ÄøF\99CºN
+\açþ&ã\93®^\1e»z\7fPL\11I"ø\94°~¥á­)\bâ|zú\9cN\8f\9a\86\86Ýlx\9då\83ÁAu½Y\ fµêHÃ1\16\ 5\rí\93Ãï\1d=ë.\8fk³qh\¼êÞ\1cø\86\92\1fµdy\ e\19\88\a|n¤\82\v)grø$*}[5h\9eRi\81ô¨x:\96\96¨\18KK\96G¾´\0\ 6«\81Ö¹È\0ì\84Eq¼5Y\9eï\95ï\fqÿÁ\9dVu¼j\9c`W:Q¾·Ä\19#âwl4cldÐ]¡&££B\7fpçp\8e\9aG]çy@ÅÈ5Cøe\eÁÀª\8d£Oæ\0\92ÊÚaïaì\8d´zô¡lrF\9eþ®!é^\90\1eïú\8f;CÙnÇ÷$ÝTÖÝâÏ/¢I°ª¹\v]£k}Æ\17\82\17\8c´SÓMxÑ\81sc\1cQ\85Pî¾:\8d¥ñRMq»PL{=\1f.wn£Sz\9c°¾â\93»\92{z`\81\12ðD\1f\ eö¯'/2³\85\fó,\87O\14\16qÉ,Dx\8aó\11\8as\14¼\99Ã\r\9a=\1a.4jª.¨¤\16ªUoÆÔ7½\97\8fç¤×¢<\9aÞ\13\13`\9fHÿ\´ëÍó'%|Ú)c\8f²éÚ=\13\8cN_ òÒYÁ4ëz\18ë&hþüÄ"\11aZâÕ¼\f\9329:\81ò¯=çG¿×½{öâ·\94)ßÞÛCï\ fþÒp|89Óä"
+Ó4\ 6Îi\býÎä©é\1aç;Ê\9cÉÈXºü\ e l\ 2©\95\91Øà\80§q²v\8d\15 ¬\jN9*q\8bn¶ý\ eõ$±À·\aJªÒù\94¤g!M}½t^\ 5\9b\87¦r]©(B\99¥\97\9c\87Î\14\9d\87"-ÜiËãi××Nû\ 1nß'\11$\16+ãT?4\96ÞÛ¼\91'OH\88éC\8fß{\9eI\12\8a(\7f.Hõ]µ\8fÔ\1cK\17Km£Ï<Jfa\9c\97§V5á5ºØ{pw\18Á\15\89\8a\bß<ùɧc\8cÖa\9eÞ3¸«¢\9dÜ\94P´$åI¸\14\10R\85\8f\97·à6ÏBJÆa\1c\8dQ÷ñB`rVønXÊ0ÉG\1a\9f\9cp\96\85S5øQõÄÀXbÇEÞ\85\1eÇÝS\91\85y\1e_Im£\eN\92\eºáw\9d-\ ee\91Ð\17îYÎ\b\97­ðÌÍÒ?ífô\9c\19^N¥§\12\\16áeU\9d¥\8f\832\8e\az&Ç;)]\88\93\87î\bL7¾¯ÿí¹]\920\91£åHLrrfÖúÂtìîâøº+I\19\8aBü¿]é\99ZË4\14eú<|õµð}\8f×\84Gc\9f\ 5j\1aJ`ô\a\ 2\8fó\90ß ¿F\7f¹\96ùý\ 3Kå2ÄfR-.9Iñ\87ÜôõôéSJ÷n\88\83ßP\14\1cØaµà>@BO<Xº_2*=\vÁèô¦ù\ 2ÿ\10ÁHÄÞË#sME
+¶×ô8ê\1e\85»í\8c\a\1fH(Ä\15«3Q\83SÙ'\7fõü\aÀ,¢\99
+endstream
+endobj
+1298 0 obj <<
+/Type /Page
+/Contents 1299 0 R
+/Resources 1297 0 R
+/MediaBox [0 0 612 792]
+/Parent 1313 0 R
+/Annots [ 1296 0 R ]
+>> endobj
+1296 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [441.094 117.248 453.603 128.097]
+/Subtype /Link
+/A << /S /GoTo /D (Item.90) >>
+>> endobj
+1300 0 obj <<
+/D [1298 0 R /FitH 686.127]
+>> endobj
+1301 0 obj <<
+/D [1298 0 R /FitH 668.127]
+>> endobj
+1302 0 obj <<
+/D [1298 0 R /FitH 313.558]
+>> endobj
+1303 0 obj <<
+/D [1298 0 R /FitH 290.134]
+>> endobj
+1304 0 obj <<
+/D [1298 0 R /FitH 274.072]
+>> endobj
+1305 0 obj <<
+/D [1298 0 R /FitH 249.099]
+>> endobj
+1306 0 obj <<
+/D [1298 0 R /FitH 231.1]
+>> endobj
+1307 0 obj <<
+/D [1298 0 R /FitH 213.814]
+>> endobj
+1308 0 obj <<
+/D [1298 0 R /FitH 190.618]
+>> endobj
+1309 0 obj <<
+/D [1298 0 R /FitH 174.949]
+>> endobj
+1310 0 obj <<
+/D [1298 0 R /FitH 160.664]
+>> endobj
+1311 0 obj <<
+/D [1298 0 R /FitH 143.378]
+>> endobj
+1312 0 obj <<
+/D [1298 0 R /FitH 132.137]
+>> endobj
+1297 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1318 0 obj <<
+/Length 1843      
+/Filter /FlateDecode
+>>
+stream
+xÚåY[sÛ¶\12~÷¯à[©i\85à\ eð¼t|KíNâ6¶æ<\9c$3¥$ÚáT·P\94Óô×\9f],H\892e;MÛ\99N_Ì%\b-\16ß~ûq    óä.áÉ\ fG'££\17/}\92±ÌJ\9b\8cn\13a9³Ö%Ö[&¤KFÓämjüàýèÇ\17/\9dêÌ\14\8c[\ 5\9cÓ\8bã\9fGç×\83¡R*µl0tΧ'\97£\9bÑõùñk\1a¾8?>;¿¾AgG<FÐ\»a\f\85\10Ì\9a,\19J\a\83\8aÖ(Ë\92u~\9c¼\1d\1aÎÓëb¾\1cH\9fÞã\9f\ 2Ö\92.­?\ 4æ¿ðoȸ­\96s²ÚgÅbJÆò\96®\17\1819È\9bgù´1¢C\11\1dÖË\1ew\10\1e@ø\11¸    \96\19\87\15\10\ 3\ao\17Ca\98s\1a®\8ae:\82^Þ÷îõ¬\98À²°Ï),*¥¤ÕÑ\bq¡±Þ\8c\87uU\84a\95nÖåâ®\99Z®ÉZUädRL7Uñ\1dØZ§ë:¯êv2Á\85\1eÖu±
\b\b\84'Õ]BÆu\b
\8añ^¨é^ì\92\15íÏÓþî\9f\v©\ 4È\b_0\by¥ÓÛ\81H)\9bpÓ>¦l\82AXë\1d¬_¼ÔÙ.½\8cd\1a\ 2\19JÃ|f) ÿþ¬àgÚ¦§Ëù*¯Ëq9+\aC\91Ö\ 3%ÓÏä¥S*\3otS\0£\10\ 6\17éÙé\88\8czùk ä\82n/6ï¸Pst\99Ç¡:\1fÏ\8a5Ùy\15\7fÿ!¯¦!Ç\ er\8c;â2-ã\ f Æ°\1f\802®Þ!Ù¨\81â~`L\9aÏ6Á¹B\12\ 4O\80 -\ 3Cwå}\e\1dÜ\86\15àùñj\15\96\ 60Ëß\ eg\1d§\9e\9bv\0Û'\14\96D x¨bï3
+Ò2Í\f  ¤Io\8az\ 3ë)gÒ\8b"\9f\16\15ÙDr%\90ä\ f³\aþ\84gªñw¹Xmj\98íUºÊ«|^ÔEµþO_¾8óÒ4ùºZ.\8a^n4ó:äøiS\1fZåè|tô1¢$Z\ 1Õ\1e¸î\93Éüèí{\9eLáÙ\8f   g.sɧ0s\9e\98\13ø»Yrsô¦G\8b\9dg\1a\9db:\8b²p\ 5K#H\96§#¬\91Ï1]¨@B§7åï\ 5i\10Ô\9aSªË\8fwÜðqY¯á*Â,åa«.Ù\9dsSÞ-\8aé÷\90 i2ÈÄzR\95«º\F\9eäM\91UÈ- pUB1N\82\89Ö\12­\ 5\18ëG°1\86e\99Ø\aG\ 3^\8f\82ÓÉ\13\89Ö@'\1f\83\7fõòÕåë\9b\87¹·\16ÀhS\7f¹@æ×Å\1dð\rQà]\94òªÊqB¨ù\ 4^\84Ö\99\ eD\ euÑX P0Lz\fW¸·zXÌ\8ayAîilë,Ü¢4áuFú»\Ñ-(\83\ 6Ìfð¤\95L9×\rª\ eµ\ 1¸ÏÊyYS­B\95[ªò^"K|­xßõs\8cjvzszüêü\0\8fÁ\ 4ïëLw`\12\a'cEÄ      \89²Å
+Çw°2V\ 6¬px\1dØ\95Ï\88ØÖ1eö6µ\ 5b0Ôܧ·Ë
+\r\a\v\82»S\1a\8c\9aZ\0ÖvR\16ÄS\|MsñG»Û\8c\95\13\9cõ!¶@|\a. o\11ÑÂõ±ìÑ\1cpäÚWD\ef\7fº\fgPòÝ\9d\9dý3S\ 5\~f¶t\93-0Â\9b\k\a»¦\81Øê4)\8b\ 1ôl0¸\b=\0fËõfK9Ð\vó§eË\1a¦å^\91^\9d\1c\14\9fÞT\r\8dÐÐ=ñ\88ù\15\82×$ ¼Ë¥Ï\90¤.Ý\0¢s4Æ\8dÜC\a\83¤Àu\9c¯ã/æ9¨òä\80*Äh:\1c\7fFØòl0´ÐÒ\7f­vú\87D{\18¤\93Ì
+Ù¾©Ûð\84ÞÍ'$À¸fÒ;ÎåÃ=Àë\rz\918ÅjÄÎÅ\18]\90\9d,iKy¹ ù\1d\1ax£ìuV¡-ÞiFu\84\e\87\1e\85»W\84¯Þ\ÿm\80÷U¶Êl*{ \ 5e\0%|\1cRÁ¡õj¦(òµ£\ 6x\e\10u\ 1Q -A\97á'Y+\vC\99\81tvw\12ö¹\99ãß1\95=Ö´&\82+P\83\8f\9b¼\91 \1c®òÅ]èoÁ¦ú\879y\1fFÛV·GÃ\rãY»å\8fu\9f,h¦l;%§\8f¼=7\ 2[µ6w«Y¿º8Þ"\87ß\ÐÃA\17µ¢ÍNê\18åìóÀë4¶ù6cVúý.¿\8cm=]¡©¯#\13\97ëhYõ\f6Æê\a2^þïüIBª¿\90\90\16ÞϽ\84Ô,Sê        B\ 2®\99Ø2ò¡\97\8cqùEN¬Â\90²]^c\84HD\1cF\r ¡0LØ=\1a¯¡\ 3ǯìøV\94Vm[\880ºCc|\18hLO\ 2\8bÑø7°ø§Å,\bp<?A%Æ.¸Z×=ÄÅ^ßl_\b½ò©$3ªMáÛ>\94Â)Ä£ \89\14§¼ïsb`\15ó\ 5\10½\8fßë\90"aìáN\bëøS9\9bQýF\ 5Ü~½?ÿåòæúäõåWW³}ª\9aã\84ì\1fPÍú9Õ¼\97ænmÇÍ\8eç}é¶Ìóv±o \95NfñÄÅ)NU\8dCmo\1aî¶2@ü /\9dLFiP6öÈhätiÄ\80¾b\1e\86ï<\bBö8×\rÛRý\80\1e\11\9e}\91\1e\1c\ 1\91\120Où¨\bÆ\1aR\ 44v\14a_\ eñ,£§&\14óÎ<C(\9eÒ     ÿgè\84~\1aºl«\13¡wú\96z%\11\8eh\86&3»"Abê\99rY\17\8c¯\13\8eÈî\8bÑ\93ª\11Ï0óx\18\14Î/\9b\9dâ²6=^Ða\99çÝ3\11åån\ 3\8e·¡¿\83+9§\1e\h(sPüÎ.i]#·ç¦`\7f*¡¯\fV8IħKº*I×"öõ{\ 4\82¦½9\1em*\93õþkâ|tô\7f\eW    Ã
+endstream
+endobj
+1317 0 obj <<
+/Type /Page
+/Contents 1318 0 R
+/Resources 1316 0 R
+/MediaBox [0 0 612 792]
+/Parent 1313 0 R
+/Annots [ 1314 0 R 1315 0 R ]
+>> endobj
+1314 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [494.892 629.328 507.401 640.176]
+/Subtype /Link
+/A << /S /GoTo /D (Item.90) >>
+>> endobj
+1315 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [332.496 577.529 349.294 588.378]
+/Subtype /Link
+/A << /S /GoTo /D (section.B.4) >>
+>> endobj
+1319 0 obj <<
+/D [1317 0 R /FitH 686.127]
+>> endobj
+1320 0 obj <<
+/D [1317 0 R /FitH 668.127]
+>> endobj
+1321 0 obj <<
+/D [1317 0 R /FitH 644.217]
+>> endobj
+1322 0 obj <<
+/D [1317 0 R /FitH 628.332]
+>> endobj
+1323 0 obj <<
+/D [1317 0 R /FitH 604.373]
+>> endobj
+230 0 obj <<
+/D [1317 0 R /FitH 564.585]
+>> endobj
+1324 0 obj <<
+/D [1317 0 R /FitH 543.816]
+>> endobj
+1325 0 obj <<
+/D [1317 0 R /FitH 518.307]
+>> endobj
+1326 0 obj <<
+/D [1317 0 R /FitH 484.379]
+>> endobj
+1316 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F48 455 0 R /F70 508 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1333 0 obj <<
+/Length 1071      
+/Filter /FlateDecode
+>>
+stream
+xÚ¥VÉrÛ8\10½ë+p$«\86\b\88\85\0rIy\91'N9®ÄâLUÆÉ\81\12i\99\15JTH*\99ä맱\90ÖB/3s°Ñ\ 2\1a\ f\8dׯ\e$h\89\bú}r\9aN^]H\864Ö MPz\87b\92`\95h\94¨\ 4ÇT¢4G·A\829\ e#)U0\9b¦\7f|\b#ÆXðvzr>½        ¿¤ï^]¨\1d\ 4\92kÀ·{\856.\13âO\9c¦\93o\93\18L\82â\87Ã\12\89%Õh±\9aÜ~!(\87Åw\88`©%úa]W\88q@\8dÍÆ
+Í&\1f]ä»ÇÆ\94ãDH\ 4\7f\98òÄ\1d~\9d­
+\88V&$HC*\83\9f\9b0\82ÁÌÑ\98\a³òWa¢Cq\fè\8c¡(\8e±\16ÂmþL\ 4\99\97]\vcl½\98Â
+\ eÛõ\99\95Ëu\91¿      £\98
+\1d\9c\17í¢)7]Y¯\1dGÙ:7\ 6\ f\9a¢í\9araVZËÇ8\ fLC\18G<p­\1eåa\f\84c¡Ô¿&\13R6"\ 3¢0ÕÌ]öÏP'AÖ\94Ù¼*Z¸\97âÁ¶-ò×Ç\1aP\ 2\v:Hàº^\17Ø2\18I\ 2±   àYbÍ<lz_8¶\16õjS\15]á(k\8bn»q\v÷E\96\17\8d³ËÖ-çÅ¢\86d*0rOvëÆ»ºªê\10V~@Z\82öõ\9eþPD±L$\f\90ÅØë;Æû>·\91 \ 4²9\9c\0\ 3\½»÷\ 6\ 4º2)6v\1f\9b±?\93\98\17UÞº_Ùba\ 2¨\9b0\ eòr½ô \ 6\a°MS[Q.\8a\14n1\87-\85\8d\1eô4w\9aÍ\9d{¹v\8a\85kôzõb\9f\15V_ö*N\14Í\129ãÆ^\8a\81䡪\ fî\1a@is¦\82Ë;\97Ç=\1d$\1c3+\14{\82/y\88"ýôa:\92v\8e)U½w\ 3      lÖ6;pðÜd䧳»{\9bE°ÜåÕpy3ׯ­ëÎ\1d!ù®2y\82\85\94ý!äoE\8f\ 3¡\ 4k:\84ý\9bÓ\1e\8b\13L\98Ü/rH\83¯Õ¶«7\86
+.@\91¥×Ò&[\98¸¿\9a\7f6!Ý®
+\99\8dÑ\1aÝýc²=ÐVÔg\ e¢¥>\bú¼þ\18÷\921Fåæë\8dûidWu¶@Ìb¹*MP\\ 5ßC\ 12¬¶ý~S¸ÎܶV\90Æi@\1d\84hî    ù\0\rÚ\94\80ϲün\19X;ÏÒ\8f ¸èH\8d=±OK\11è1¯Ê¡\18-\85\0\ f\87\8cê\91\ f\ 2»º¸º|?;Î>§»
+9â\1f\98\97Jîg\80=\9f\ 1.¹ã\8aK\11|Ûf.ÈòWæÚ½YÞd\r<8\90\89ÖýÞ¶\86Ê\12\884d\9b}\1eàXøf®gÙlò\88¥\1fG\99N^Ä4×\96i:Vö\9aùî\vNðDm«ÎèZ\10èò~\16ª¢±%\f\93®õ\1c¾\14\ 2lhé\9eí\93\90Ñàlvvr5Ò\1f\ 4t\13¦öÊò0¿\98ªÁáü   \1c©â\17ã\\9f\8e©\ 4\9eI&äS ã\1dc\14\8c
+Ìô3\11\91\9d\88\8cE\ 4ºe/\a\ 1\8cË¿¦cú\87ï\14Â\1ep\86O\91c@\88\e¾\95\ 6ÀÓ÷\97cx  <Öâ±z¢\84c\ 2\8e{õÄ_ÐѨö½\a\8có³Ô\84I ê¿\ e\9d\ 6æßn¡¹±U¶ö«Ù\1c\8a©rO£óè;Ù.ÚÑ«\ 2s¶¸ä\0\úñÿ·0þ_ZØÃ\93\9a\8e©\89aFâqÂw>¤ÿ\ 1\84þÐÛ
+endstream
+endobj
+1332 0 obj <<
+/Type /Page
+/Contents 1333 0 R
+/Resources 1331 0 R
+/MediaBox [0 0 612 792]
+/Parent 1313 0 R
+/Annots [ 1327 0 R 1328 0 R 1329 0 R 1330 0 R ]
+>> endobj
+1327 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [165.458 553.554 180.18 564.402]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.1) >>
+>> endobj
+1328 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [151.258 511.656 173.73 520.484]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.1) >>
+>> endobj
+1329 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [151.418 477.838 173.89 488.686]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.2) >>
+>> endobj
+1330 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [151.258 435.94 173.73 444.768]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.4) >>
+>> endobj
+1334 0 obj <<
+/D [1332 0 R /FitH 686.127]
+>> endobj
+1335 0 obj <<
+/D [1332 0 R /FitH 620.248]
+>> endobj
+1336 0 obj <<
+/D [1332 0 R /FitH 582.446]
+>> endobj
+1337 0 obj <<
+/D [1332 0 R /FitH 538.61]
+>> endobj
+1338 0 obj <<
+/D [1332 0 R /FitH 508.667]
+>> endobj
+1339 0 obj <<
+/D [1332 0 R /FitH 462.894]
+>> endobj
+1331 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1342 0 obj <<
+/Length 122       
+/Filter /FlateDecode
+>>
+stream
+xÚ]\8e»\ eÂ0\fE÷|\85Çd¨ëÔ\92\9d\8e\14$$\94zCl\bþÿ\ fx.0]éèèè\12Ü\81`\17&\ fý\`ÄQ\ 6\ 1¿A\16B\11\ 5)\82yPð+\9c£Pºø¡\9f\95\7fÌ\8c$ü̼\9dÍROn-uÌ\1c\ 5S§Zâ´÷Õ\9bÕã\a/V·ÖÖW,Ð÷Áÿ\9a\87\a}\83"\15
+endstream
+endobj
+1341 0 obj <<
+/Type /Page
+/Contents 1342 0 R
+/Resources 1340 0 R
+/MediaBox [0 0 612 792]
+/Parent 1313 0 R
+>> endobj
+1343 0 obj <<
+/D [1341 0 R /FitH 686.127]
+>> endobj
+1340 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1346 0 obj <<
+/Length 1181      
+/Filter /FlateDecode
+>>
+stream
+xÚ¥WK\8fÛ6\10¾ûWè(\ 1\15Ë\97\97"M6m
+tÓt\8d\ 2E\92\83Vâz\85\95%G\92³ØþúÎ\90\94cÙZ£\8b\9cÌÇÌh\1eß|\1cÓh\13Ñè×\15\r¿¿¬W?¾\95\94ä9Ï¢õ]ÄhNtn¢L\v"%\1cUÑÇøõ}±\em\9f¤Be±J>¯\7f÷j\92\18ªÑ(\95\86h&½ÂÛÄȸ/¶Ö«¼±e\a+\16WÖ+ëÈ\10\93ó<¨f\8ch\1a¾µ¾¯\87\ 4Nx<Ør¬»\167¨9\94IÊâ>aq}\9b¤\Ç6È\8d÷Ö/Ên»kìh½Æ®ï\9cXi«}\1f$Z[Úa(ú§ ÙMÆK/[\ 5¹Â\9f\ fu»i\9cËè%cÄdÁË;\f\8e\14"x,(\8bÑ/\15[ôsS·ài8\7f¬Ç{\Qï+.îBvàöÞ\16\95í\7fÀ\8d\8aﺦ\ 1Å.\ 1C\8f  FYy\85[Ü<y\8d\83·Ó]\13BE\99\a\7fö\89²¬Ø\fÁì¶(!\1dÇ\81ä>\90SU®t¼\9dÌ£6×\ 6\ e|!ðò«sª\1c»~ºõ&\14\9aPñCÚX/ÒøR+zTk¦r\92\ 3r¨ÿø\97ú\1c\ eà\9cäl\92ø\9ady\4û\83+E[y? >Ù\16Móä·.±¸xózí\17½\1dêj_87 f­    \ 5\Ϫ8v\ fÎÕÖ¥IÈøñ¾v\89ÀjAe\vÄ\r\83+jåw\b\eüí\ 16í0öûr\f\17®º`'Àcj\14&\89\909\ fh\17\9c\18\19Ò¯\b\ 3Ã\8cg§-ó\9b\ 3Å3í#ͼ\7f\ fäÌY|×îöè\8e\16ñ®@{иÃO\v\14\94ä\94èë®=8|l=\9däR\9e\11m\82Ûï÷ãs_Y]­W_VX@\1a±\ 3\9d\bI\89Ñ&*·«\8f\9fiTÁ%@\91(£¢G'º\ 5\11A\14CÅ&ºY}ðä4G\ 6ÚÊ#!(ÉhðäÚe\8cKeâµë\90\9dç\ 6Ä\0\13ñMý¯ï_\93Á÷Ù¼ü\9fhFoëq\80\84\84\86PóèXæ¦Þ´¶ú\19Ìe\92A%\86²¯w¾\e\1cBÚjÂ\ 2\ 2\ 4ÀPC÷:¦rBH\ 1Ï'\85\ 1\12ÌYR¤Ñ\97\932+ÐÁ\18e$3"ðïú\9f?¯Îk\ e<Ë 0:!\ 5\13\râLæ\92Ç\80EΡá®;·È\80ÚB\ 3Lt\ 5Ø\1e\8fÓ¼\b\99ð\99Y®¯?¼»y¹CüY\87Z$\9bý\16\15ÂkÐû\8bîn\81w8\85F\ 3ð^æ\1d£ä9ï,FÈ\15%\82\9f\84øÂ\b\17^\95¢ï\vOóx  \       \10\9e¡1?ÍÇ«vÁ=e\88d\a\92]Î<×\84k>ɤ¶±[ë\9d\83ÔÓìÈ\15·]Ì*|'ÿfc1©\1c$ÔIRÓÀÈB\91Üðy\ 6¦\84/7\fÏ)¡\½\98E\16\e\86\v\90\14¡aþN\f¸Ö×Åm\83c\85Ð\129¿ºÀh\9cB\96\81\17¿\8bÑ\80¸9\95\113\1a\9e\ 46g4)Î\18\8dËcF\ 3F\15êÿ0\9az\8eÑT~Êhò\98Ñ\90ÍÜ\bv\81Ã\98\86÷ZÈ\17s\98\bSX^ãÝüãý_W\88Ü\94q\98ffÔ \14\9c\9cqÕ+¼\10aîñ뺭ê²\18a\8aó{x\9fÝ\8b®xxÚálÛõv\ 1ÛBd\84f\17'\95\94É\8cdÐh³\81ê\es\ 4º\fÃÂíTEÜ\1c\r\9cÕ\ 5¼³\8c\13ðñ»1¦\91F`ÈgЭaÈF8e\871\94\18ê\8f\aà\83r\1cüÅÑP\84Ûñ\ 4\94 \ eìpj­\1eüQ\bÛ\95\0÷Ç\91ãH\97\92«-ð\8dÓì\82\ fá\18'cLÐô\9f\ 5\92\ 2Ù\16n\1eá4ôLÎf2\90Ìÿ\0\92>"¿
+endstream
+endobj
+1345 0 obj <<
+/Type /Page
+/Contents 1346 0 R
+/Resources 1344 0 R
+/MediaBox [0 0 612 792]
+/Parent 1313 0 R
+>> endobj
+1347 0 obj <<
+/D [1345 0 R /FitH 686.127]
+>> endobj
+234 0 obj <<
+/D [1345 0 R /FitH 668.127]
+>> endobj
+238 0 obj <<
+/D [1345 0 R /FitH 429.01]
+>> endobj
+1348 0 obj <<
+/D [1345 0 R /FitH 403.149]
+>> endobj
+1349 0 obj <<
+/D [1345 0 R /FitH 375.315]
+>> endobj
+1350 0 obj <<
+/D [1345 0 R /FitH 341.387]
+>> endobj
+1351 0 obj <<
+/D [1345 0 R /FitH 245.688]
+>> endobj
+1352 0 obj <<
+/D [1345 0 R /FitH 209.822]
+>> endobj
+1344 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1356 0 obj <<
+/Length 1961      
+/Filter /FlateDecode
+>>
+stream
+xÚ½XßsÛ6\f~Ï_¡Gù®æø\9bÒÞº4Ùº»­]êõn×öA\96\14GWÙJ%¹Ùú×\ f (Ų\95dÙíöbI4     |\0?\82\0\89xôãÙ\ f«³ï.\93(e©\956Z]GÂrf­\8blb\99\90.Z\15Ñ\87ØÊŧÕÏß]:u83åL¥\ eÄø9ç?½|»º¸Z,\95R±c\8b¥sI|yõò\97\v\1azuqþæÕ\ 5Ê9ãAùTór\10¸\94\ e\ 6\15\89Ív\ 5¬Ot\9c\85tq\9f\85\88;\1c4q\7fSÒ¿uÕõ4Ô\\a¬ü\10+\ak\8c\1e°~©hÎÄpÉt"\87\19_\17ÆÆY½/GEYO\9a¦·õb)\93¸¤    û®\f@\ 1\9f\7fö7UX|Ý\ 2âl±\14ñ¶\ 4Ç\98ÔÅ«\ 1øG.t\vØO1Ka\99\96ò1ÌàXøIÀw\82¥Æ\1caG\rn\ 4l\ f\ 1Û\11°\8b¯\9bvF}\9a0\a\12\83ö\fD\18\11×3~ÓÌè\11å«s\92\9e\v̳yUÂÖ%qß\91>r\10B¬i`]\83\7fhA\8e{ü¹\ 3/Y®ÀKäB\eWamÑì\ 2þ¾¡\91r×íÛ\12\17\14\93È Cw\84­\13\96ÀÁó¶-\8b*ï«f÷\ 2\aÒøî¦Ê\11á\rýï\95Á3(Ã\11\84,\ 6¾ÁÀ\97}F6Uß¼\eýì-p\13%J\1eßá\9fMû9Hʳüó\16Ì\ 4Ðy_\16Ì\83æS´\9e\182Iã\97è\89sz\9f÷&¨\92)\80nðó\ e§\97_ñµlÃ?9`ôëÇ\8dÇ\8f¢$ðn\0\8f\83û®Úmè\95\fûk\8e\91\18\e\9e8E\82\19eNN\11âáq\13àô\83\8dxj_ÐÖI'\99HÒ©3º²ö\9eÂ\b¢ýr\8c$\19=ÖõH\99$þ¼\{ÔËé(-\g]Õ±IèÁã.\1cÆ\1aÉ\9c\ eaN\1cÍù°4\9cÇWe\86\04'Åi,\96몧\91ý®«6»2ü_ÑÆ\94\9b²\ 5\ 2k«ã××´\84x\ 3S\ eÏ&|¶£lÏ9xî\9a\9e\96|+Û\ 6ɤeÜõÍ­\178\9e\bZ\80\8e\ 3; *\93×,\99\11D\ 4Gé¸Èúà²Û,¸\ 5ÙÐ\1f\f¢$\87\83¯I\94|Ä#ÒiÔ \9d\19<\82\1eÁ?\ e<\12\16\19\9d\1e\92Æ(¸s\92\815\97«?Þ^\9cRK¥l\f\ri\827P.=Ã\ 1Å\81ÞÓáv$¾ó7\83ÿëºÍ¶aV8\18È}
+       gB\1dÅÓ¢\fç¯(\8b\17¨\98ûó¬¹\8c7\15\9d¸\1d~*\1f&pxµHÀûëÚ\87¥3\ 1¨yÔn"z¹ò~Äé\8e©#÷¢aÖHÏ\e\14Dw\88\17Ý\r#%\r\f\17\87\1f\r&áø\81Iþ¯)úÃ\88c\87øè)\ 5ôøå÷w«pb(JÑ\a2qÊ\83ãçÅêìK0SDàW¦A¸\11    \93<\89òíÙ\87O<*àOÐÍ\1cÄç;?u\vÑ\ 2®e\85\ 1¥\8eÞ\9dýFÙÈ\84\1a\126DÃ\fÃ\1dsÒ<J\10\8e\1fcÏ%î\ 1¹\ 5m[Mø\80ÆÌ\83æ\18\17ô1h\9d&\8f\83\ 17\10\\89\90Ï8 µ\87Ã1\ 4
+\17¿¦ÈÛ\86\13I\e7s\ f\88é|<?\93ùóðµSL\bù\1c\9fó\872Ai-\98\91DZk\96¸\90\8eÝ3;äyê{ \99Ö3îväî\91\17\90îPJõ\18\97¢eª\98ã\1a\92\eÌD\ 5éU\8f\85fE'\ f\95\ 4·Ú\10¢áõ DÃÿ\15d\1aÁ£\9bÁ§ó1É&,\11cÀùíõ»\99Ë.ep©\ fS>ðO'\115I \89NBL\r\9f0%Dm1o\82\9aÆToóp|ß\]\0Î#ñ|ªÝÌj§{j\14qï«î>\ 4¼ )]ÙϹKBæ\95\8c!ü×Y\7f)Á «\eæø\ 4\ e\ 4\8a\13¯\19 \*¦7\91\9dÅý\ 6Âa{Wuå÷G·»e©rSË?rÃ3ø\11ÿ\ 5\93h\eþ\ 1\8dà@ºT=\87\94F)Þ\8fxË[¦\ eÍY?mÎ\7fÌ&\b±Ü\9d\ 2É\1f\ 22O¬ â\1f°
+¢þ½k\9eÃ*yâDH^5¬8Á^<\84ý!rI\10àÒ (гbÿ+«04§ÉsX%g\83\93\85\8aw        \15\9c\18\1c\eònv{ @ëûÒï9»£NÀÀ½ËU:=±î¡Xu
+\ 5Òx£õ\13\19¤\96°q#\16ªò\92\98û\92M\ e¹8\8cdT\15ª°I0r°Iðu°I\98\88\ eU[WÒ*X\13\ 4gm\18Âò¿Äò¿+[Ê\17\8b°\8el\89\96\ 6\8b\9f\93ºÕ#\94jR4HJ\ 5\95Ô1öA|ª\ fcßP|8N\90\18\ f\15\83\16CÅ \87Üá@\84
\ 2¼Üg\89Ù\1aÄúû\1dTdyÞ´\85ï¸lhÄï ,\0tþz\98I]º\90\15æ¨y\86\856\9bÙ³¥Ô,Åh\ 2\a*MC6úþ­\ 2\ 56\89Ï\9bí-,]W5l\82\92CA:¡87\8c\8f\r(j©@r\ eå}^uáãºi·¾þ\87w,\0ðÙ\ f3¯Á\84Á)<¾\ 1\ 2øc'C9\ 6Ïn¿îú¡ÔÏêú¯P'\90æI\1e] ¹ªlCy\8e\el¨"PX©\94\ræ|øÞßd»é¿`46ÌtJFàPÓV\9bj\87m\17\9a\0H\15½\ f\16\91\80¼Þ\17ؤ¯ ¿ÎZ\f\1f3;ã\91í·ø\eÊ\84\96ú\1aÞ3Â\ 2Ïý\8cÎ\17:\9eºå=giêÀosÐX      L70ý˾j\87©\9e+¸dì;Á\aU\13é   êGcñ\v)0\ 3~¨q\8c\18w
+ß³ºCî7ôå[\1eþ¥¡mȪ0Ðì`óh\ 5> ª\86\12\89*´ã6\aÇ\8cùÑ.\adÙ:9ér`q\98\88ÁÜ<Ûw\ 1¯'5¾\14¡\91ÓÑ'\1e?ê~\80Äô¸îìö·t\92\9a\16ý\f\90\8fZ\1e5ö{ ¿®g\8cH,\93&}¢á)¬\9bmx\1a\15ú®ð\ 2F\84!:6è¹P\83\1c7Y±ûfí¿ÐIò±\ fIº}cÐÈA£z¨\9d\83Ô39î\81V»IúC\1dØ­\ f\92ó¥,\94S\7f\ 3{\86\9b¡
+endstream
+endobj
+1355 0 obj <<
+/Type /Page
+/Contents 1356 0 R
+/Resources 1354 0 R
+/MediaBox [0 0 612 792]
+/Parent 1313 0 R
+/Annots [ 1353 0 R ]
+>> endobj
+1353 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [306.698 539.998 321.421 550.846]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.3) >>
+>> endobj
+1357 0 obj <<
+/D [1355 0 R /FitH 686.127]
+>> endobj
+1358 0 obj <<
+/D [1355 0 R /FitH 602.014]
+>> endobj
+1359 0 obj <<
+/D [1355 0 R /FitH 569.305]
+>> endobj
+642 0 obj <<
+/D [1355 0 R /FitH 456.829]
+>> endobj
+1360 0 obj <<
+/D [1355 0 R /FitH 430.566]
+>> endobj
+1361 0 obj <<
+/D [1355 0 R /FitH 407.321]
+>> endobj
+1362 0 obj <<
+/D [1355 0 R /FitH 387.12]
+>> endobj
+1363 0 obj <<
+/D [1355 0 R /FitH 366.365]
+>> endobj
+1364 0 obj <<
+/D [1355 0 R /FitH 345.348]
+>> endobj
+1365 0 obj <<
+/D [1355 0 R /FitH 326.503]
+>> endobj
+1366 0 obj <<
+/D [1355 0 R /FitH 310.148]
+>> endobj
+1367 0 obj <<
+/D [1355 0 R /FitH 293.793]
+>> endobj
+1368 0 obj <<
+/D [1355 0 R /FitH 275.238]
+>> endobj
+1369 0 obj <<
+/D [1355 0 R /FitH 261.083]
+>> endobj
+1370 0 obj <<
+/D [1355 0 R /FitH 245.282]
+>> endobj
+1371 0 obj <<
+/D [1355 0 R /FitH 190.183]
+>> endobj
+1354 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1375 0 obj <<
+/Length 1629      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XKsÛ6\10¾ëWðVj¦B\88\a\ 1°\97NR?êNF\99Jj/I\ e\94\ 4É\9cH\94LRqÒ_ß],(\8bÖ£õ8\17\ 3X®öùawá$ZFItÛ{7é½¹12ÊX¦\85\8e&\8b\88'\9aY\9dEÚjÆ\85\89&óècl\98\8116\1eõ\85\8dÿ\1a\ eÞ_\ fo'¿÷\aRÊøzøÛ\87«ë+<¨øÝÝ\84¨ãÉènx;î\7f\9eüñæÆ\1eh\80\8f̨\fô{ÙZ"K/   \16½¹Q6â\8a\ 5r\ f\810 Bî\rê\ f8\17i<Ú\95\83÷®\6÷ Ö¤ñu9ÛÀ\8eÇs7'Ê»¢¡Í¸©\8arY\1f[\94\80pάà$|ò\88N\82\14ÅÓøk?Mã¼*ò¦Ø\945Ñ6\vZ+н
+ºñì¼naâ9è!R^9ÚìjØ\80Utj\82ôºÙ´\fµ{Ø\81\0÷LÇ´h\ 2e±©Ðt´\96s\96¥)YÛÜ;tOÆÓ\15*·ñ\f­ÿB´\19\91B,Dü)ái\ e\1fórN\9b3"À·¯¸q+
+\99I\ eqb\ 5Ë\fo³øP\1c\87\95\v&µm9 \90:ÎW;W\ 3\94R­â       i\15ñ¶
+ZÝ|W¹`\1cF\b×¹Ûûà½\1fð,eRfGAÀø"î¦>Ý\80Ä\83\80"ÝgÂÓ·>GnV@4\94\8f\fP\8b\92Ø(\16°YlV\10\rPüè\93\89<\8d?\ 6p\90\8a\99\87\ 5\11¹Þ(Ñ¢Ê0kíÓ\1dâ\ 1´ï7år\0È=   PÚ_¹=\8e\83ð¬\8bXn\19\8b¾+·;\14ae¼Í«|í\1aWÕ¿øku=é=ô0KIÄ÷w;U\80ve¢Ùº÷ñs\12Íá#À\8a\99ÌD\8f\9eu\1dI\ 5·\8eã\ fWѸ÷'\15\8aNryʸVQ*9dY\91!CÐ\r.Ziâ  \86éûÖ§\ ehB((      Å?\94\98\ 5e\94BM¿ý\94¤ \82\1d\99¤\85+i¢C\9eq±,ÝüW\8c\vøzåêYUl1\ 3\1eа\ 1\14A()7\17ÂÀ%³éQ\18Tf/\87¡\93\89½°D0\95\86
+2\84*x¢ò)Ã\f`#i³\86!jÜÒU`µH\92Xj\f\14\\93áÆoÒpG\0i\9ew·Æ¿S\8aiE®b\9d\b°¯\ 3J7D9¸9ì|\10T¦Á¨\17Cád\f\94\81èµ¹ú°k^\86J¥ ã¼\1a\95Â#[É\94é.*\ 5B\ 6Pi\b\95Æ£Ò\8a\ 3Tf\8aqþ¬°\Deú\f\95ÂJ}\16\95ê\7f¢RÁÅæ©ý1¨T\89ö\90óv\9e\ 1¥\ 4¯u\vJªE`u\1djQ\96i\ ea\83Öußçq@ã\ 1´æOð»\84²\843\88à\8f\81\994
+\9c
+£ÉßýLûþ<]ùJo\15¶Úù\ 5\9cÉ\14¢©ì+qf\98\82Þ\ 6\8d\bhi\ag\89¶ÿQý \15$ü58ËRþ\1cgê¥ÕO
+,X/Ç\99=\95\11\8eé\r³\19\8c\86¡\9eýÈ
\0b\0À¶È\1d\ eeo\91W¬3'é=ú\81AÁàÑ5Ë\80Yü¤UÂ$OS\v\1dóº\ e³
+\f\84¨Yè\f\ 6\ 4\1c\0q×´?\9bíªÊ\91\1ao\vNK\80\8bnÎa|da¦9õyä\ 3)\8e-Æ@ry6\90íDzØ\1d\9aöã¡a\ 4\96Ö\88gcåÈW\v¨\9a0 µê±
+<\ 5M\ 5ÅÁ\ 2M\16(i\9fRi|*\8d\92\19\rµÀà¾5UN¤)$\95F\8\94Îù|"\ f´±³\91;\1c
+»S[µ+\ f£p1¾ãI\1fZÂÛQ\1fj\ 6\16²¦\83\r}ÚM¸\815Æ£É+\84%R\ 4ù\akÓ²P\ 5ØÔu\ 1å\89¾\1d<\1a\8eýÓÏger\ 6G\7fê%´,\8b¯h¦\v\1dæ÷\1dL²r\9d\87c·í\9fó\1esôáæ\ 6r̳$;\ 51qÒs¸Bñ\ 6õÕ®¡Ó¢Ú¬i7\1a÷±Y\84¨b»%vD¡JC\96\80\8018\9fÝ\83Ô\9d.]<ÃA*}]\ 5Ç\17\1f\97\11×\96%Iè\90à \7f\8e)\11\175­å\86Öm\95CE\9då+:®\8a5vJÜú·\9cB\fR\83ÄýÉb\86Ì\1e!°Î 6»Ù®)è\85EÄ䧠Ô\97rÜp¢ ð¼ ÙT,Sª\e±\19¦^Áð1m'\e<tk$R¨RÁp\ 4ò¼\83@ë¾¾ð\99\ f¸½\vò*\97¯
+ÿìù\8eùü\19¨0\ e\10¼¥¦Û\86âö¯` ¶\82}\88H3<cýàuáý\9a\9ei\0F\11|\80¡û:­\89èßmÀ\94Ó±\86¡e\15\ 4\1f\15½HÐr\1c\r\82àYî\9fãÈ´ö\ fpÜ=\16«\15É*]\9b\15\10@¤iÛÊ\91³¢Dóøa×îjðôd\1d}\8b\88Ïà¥\8830\96P\18?BÌ\rx\ 2?Ÿ\87Ñ
+>Í}[\ fêæôcï#¬cznú\8bAw¢ZF´\19Ýö¢\8f^\0¾3Eç_*ø\ 1¥Ô$\ 5Ç#Òõxï\82ä\86\80¿g\83\8f9\1d¿\94ô\b.O9\17n\81ï4¡îî+ñ:ÿV¬CJé±\8cóÏé®\ 48
+Ócks»Âýÿ\17\94Ö
+endstream
+endobj
+1374 0 obj <<
+/Type /Page
+/Contents 1375 0 R
+/Resources 1373 0 R
+/MediaBox [0 0 612 792]
+/Parent 1383 0 R
+/Annots [ 1372 0 R ]
+>> endobj
+1372 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [293.852 129.204 316.323 140.052]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.2) >>
+>> endobj
+1376 0 obj <<
+/D [1374 0 R /FitH 686.127]
+>> endobj
+242 0 obj <<
+/D [1374 0 R /FitH 668.127]
+>> endobj
+246 0 obj <<
+/D [1374 0 R /FitH 596.555]
+>> endobj
+1377 0 obj <<
+/D [1374 0 R /FitH 575.786]
+>> endobj
+1378 0 obj <<
+/D [1374 0 R /FitH 542.245]
+>> endobj
+1379 0 obj <<
+/D [1374 0 R /FitH 482.411]
+>> endobj
+1380 0 obj <<
+/D [1374 0 R /FitH 446.546]
+>> endobj
+1381 0 obj <<
+/D [1374 0 R /FitH 386.712]
+>> endobj
+1382 0 obj <<
+/D [1374 0 R /FitH 350.846]
+>> endobj
+1373 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F70 508 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1388 0 obj <<
+/Length 1758      
+/Filter /FlateDecode
+>>
+stream
+xÚÝXK\93Û6\f¾ï¯Ð­ò4fø\12)å¶Iv\9bt\92M»ë\9e\92\1cd[öjÆ\96\1cIΣ\93\1f_\90 õðÊv¶Í©\17\93\84\ 3\b\ 2 i°\ ehðÛÅóÙÅÓë8HH¢¸
+f«\80)J\94Ò\81\8a\15a\\a³eð>TròqöûÓk-ú\9c   %"Ñ Æò¼xuùÇìêv2\15B\84\9aL¦ZÇáõíåÛ+$½¼zñîå\95\91sA\9dò¡æ)Ó\11\91\91\b¦\\ 3Q ØëI,²\ 2\19\91\b\9bû\f'\1f(\93UÝà¢Ú\17OÌ,\ eS3È°Î\8bõÆqÎsÇõy\12EaºÙ;z^»ÍYºô»\8b%îoî',\ 4>\16\16È\94âðj\ fzÅ6-¦\8br2åq¸Ì\96^ÊnjL\ 3#$I¤\84\91\91$\8aÐ\86*«³b\ 2üMÚä¥\91\99¨°\áhd':¬@å¾Àù¦SÏÂ5 ±T\8b\186,3«]ÃÄð,\81\a\f\90\8c;\ 3\80¥¹O\e\9c\ 1Ø       °~ÃÕ¢ÜåY=Ô\8f>\85   z
+&à)\85\9e2\16Ñ¡-ieØ\19¸r·³(²\ 2½\0¤¦t£\15ɤ\13        \94º©àL (¤\88{G
+,Yº0\0ïqµ(\8b:[ì\9bü³!:)î|YÒ        î\1f&,­-\9dâÈ+\96Æi#F4å\1a\ 2d\89\81\99\17u\ 3A`\16N\12\10çö|3\0\8dëÊq\88pU\95[äEmÂÆ\18\18\98¥[b\95µ!À   Õ1j\9cY^\15\85e±ù\86³ìë"Û¹x\80¥=^3®pôAhæ\9b¬À00\ 2Úïîã®Ê>çåÞm¯öNÞ\17\13p©£Bt$Æ\87Ztû¶é×\131\9boÍþ½1U©pgÝQÖu>·\17\vH\1d\ 5ëÂL\t¦-ëÜ\87 òá\ 6\93#\97   ¾Àe:¸1\108\91\14áëÂË88V\85\98\17imO\ 4¢·(AQ\85\v\f\ 6¡\ 6Q\ 3Këq¡Ú³UíÙz\98\83\13\1a\ 3Ü\88ßlJ\83î\8bÛV:Mýð\8dC'\ 1NÄ)\82£\e        FúK\8da\84RdÈ<aS\16k4Â\1c[Zø°ËÝw8A\7fLÇ#ï¦l2\7f{lVà4Ì'\98Ú`:·\87\93\84¥qaý\1d\rê.\ÒK¸°À\18\ 3nL8@IWM涤}\1e\98Øx\ 5Þ6^\80fÂñ{¾:\1e}Eé,,mº\116\958«1\ 3Á¤È2\88\99'íe,\1c¹lo%~êò\19Þ÷\1aÉæØÏ]X`_\94ÛÝ&k\1c\f\97|!ZÛÔ°«\90²È\96ûj Càý\83m«ÒGLýlP\ 2¡Ø\11\råvÊ9\91\fU32dy?\8d(\r/áò­\9d\89o®n\ eRÐÀF\19Ò\ 3\11\10r\9c\82\ 2WÏù)\r¶ÒˤW\99¥\84\96@ùBÿüõì\ e\99úÕ[PÂ"æyZ\Ùv×øÛ\ fK_\a\86\92ÄL\ f!\8aQ\88¯W\a\ eÈ>íÓM=\82Y+¢\19÷xn\8e\80\8e\88î:\98'>Õ7ûÊß5¸(÷Χ>\10\96.\14|%AëFÀ0\rM\15;í@®H,<Ë¡\87\ 4\ 5F\109p\91\1cuÑm[©R\97N¦î&\bh0Ì   w\85ÏfØÌå\18é¢U\18\80§ã':©9BÍQ\97xmÞéèM¾Íp¶·ÝI\93opY\16\8e\8e\179\98´ÕÂ'Zô¼o\94jäZ»Ä[à2wãÌ4\1c\1c\19Ôæ\1chP­\ 3\9cÜZü\86M\13}h\96+\136IÀE\15\87}Ý¢\\17ùßÙrè\8fÃñjvñÉ©e\ 1g\82p\19\a\92j¢t\14\17ï?Ò` \1f¡4ØxübY·\ 1\171\ 1]4Ø\ 4w\17\7f>ìÕ9K\bçQ\0Ý!a        GP\ 3O\89ð\85\8fQp\137\87tg½qyk~g\9ehCÒÍ÷>ÉØ\84m\8d\1f·@$\8c(yh\80\93\ 6h9fAL     \17έsúðv0\ 6®\89ÚûÌL/\ 3\ 6P\a\9a¹÷\89\1c¼'Ü\9eA\8f0gç¥s'\9d\1cw0ÖÛ¢\14áÝ\8egÀ©4\ e*|6¢\ 1\Ö]o1
+\17ÞS<ÖÃ\10\9b³\1fÀ+\ fðÊ\9f\8d7z\fÞ\1f\0¬\1c\0«\9f\r8y\14àQÄ\14j\83ns6° dá#\8e\8e`\86¢Ã\99ü\97\98\99\1e\a\1d\11®â\11Ð?\82:v¨¥G\1dÿlÔB<\125;\8bZ\98xæ&\9e}|\bù³a\9b\ eôDf£\9cÄT<"7Ócÿ§@v\ 3½*àÐäD\90-±¹l\v\92û·D\ 3n)å0yË.y»Âì\1e\1a\90\9bKì>%¤k×Ëü\9f±\8fÕ¢`\1aA§)!+ò\98\88ØÿÁs²å\84Rõ n\18\9amÿíG¬\1f\92ÆX±\r­íHküЫÍæs^ \19¤Ê3µÙ°i\ 2f>(ÏæKºX\94\15vãF.<Ñ\8eTë¶'=pò°\97\18¼\fz^s\ 2û]\90\7f9\ 5Ö;\8fnÂn\rýÝõõÝéV,>ûX¸=ûZø@#jÏWvçË9\ f\7f5C\ f        ð±Óh\92q4;üÿ +\96CH¢ûGª÷ß\v¸Ë½y˱^:\8aH\14ËóÍ4O\8euÓ,ÖD$r\b\9dÑqìK\13ã\89t\98e\82\7fs\19
+\86:\10zî4Ë7W\10J7d2MÀæv×Û¿îf¸Ïý·\84\8bMV×N¬}á\e\9a¹å\86b\1f7Nר+ q@J\1cDù©\97\8e\90H\90\88\1e\18û\8f\18ºÃDü?^`½Nþ\1fÓ8\89¤
+endstream
+endobj
+1387 0 obj <<
+/Type /Page
+/Contents 1388 0 R
+/Resources 1386 0 R
+/MediaBox [0 0 612 792]
+/Parent 1383 0 R
+/Annots [ 1384 0 R 1385 0 R ]
+>> endobj
+1384 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [480.615 431.233 495.338 442.081]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.7) >>
+>> endobj
+1385 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [432.142 243.244 446.864 254.092]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.7) >>
+>> endobj
+1389 0 obj <<
+/D [1387 0 R /FitH 686.127]
+>> endobj
+1390 0 obj <<
+/D [1387 0 R /FitH 530.083]
+>> endobj
+1391 0 obj <<
+/D [1387 0 R /FitH 509.666]
+>> endobj
+1392 0 obj <<
+/D [1387 0 R /FitH 489.249]
+>> endobj
+1393 0 obj <<
+/D [1387 0 R /FitH 468.832]
+>> endobj
+1394 0 obj <<
+/D [1387 0 R /FitH 448.415]
+>> endobj
+643 0 obj <<
+/D [1387 0 R /FitH 286.519]
+>> endobj
+1395 0 obj <<
+/D [1387 0 R /FitH 260.426]
+>> endobj
+1396 0 obj <<
+/D [1387 0 R /FitH 229.991]
+>> endobj
+1397 0 obj <<
+/D [1387 0 R /FitH 207.637]
+>> endobj
+1398 0 obj <<
+/D [1387 0 R /FitH 186.666]
+>> endobj
+1399 0 obj <<
+/D [1387 0 R /FitH 166.803]
+>> endobj
+1400 0 obj <<
+/D [1387 0 R /FitH 136.368]
+>> endobj
+1386 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F74 666 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1405 0 obj <<
+/Length 1579      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XKsÛ6\10¾ûWðVj&Dð"@äÒ©c;q§c·\92ÚK\92\ 3-Q2g$Q!);éôÇw\17\vÊ\94L»õ8\17\11\ 4\96À>¾ýv!\1e-#\1e}89\9d\9e¼½°*rÌ\19i¢é"\12̸ܰÈd\86  i£é<ú\14[&Ù(±6\8bÇ#\99Å\7f^%¿\9d_}\98~\1c%J©øüêýõÙù\19¾èøôrJ³\93éøòêÃdôeúëÛ\8b¬w\ 2,2«\1d\9cï÷6)\8a\9cð Q÷\8c\12%\rKS\1d%Ò·\8a¤\ 5\17\8f>%)çñå\82\ e\1d\83^¤Gñu\97¯\1a\9aÕBº74¬\8b|N\ 29M\88ä¦li¸Û4årS\84õr\83¦¶Å²¨i9\ f»\9d^\8e\12\11O\8fôàQ"ÀF\99\ 6=Õ \9e×ímQß\97Mñ¦Û\13\8f\1cÈÐàn\94¦q¾Ú\85×Ï<å\82ü)t?dV2\91e\9dC?sÎ\1f{Ýy\1f\ 6\118
+6\13G*&"\83\8dRqd\89\1e´ä}Eþ!7\91\8a:\9e\17³j\94ÀÄ\1cæE¼¤Ù\1a<K&,êjM£¦-¶~_\ 1»ò¨^F4\18û\13ð«ôèØ\98\91U\0\9d\a³\12Ë\84K\ 1#)Ë\9c!\8dÿú]á\19)è¸Þæ-F«¼)W\10f%ãï\8f]#¸\ 6@\9aÎ9þséd<GSl\4ôº©Z\1a\10\86¤\13\88!¿RÜÓÀC   \17z\91ór\8b\16Qä7íyhy°\vx       u\ 3ï\a}\12!\98KC\18VÅfÙÞ\82]ÎÄÕ\82\9e\88kÈK\ 3fMoË\86&WåºlÃ\98\90\ 4\83uþ­\û@­ib\13^à÷Æ«ãQÞÛ{Vm\9ab¶kË;\94        Ûð\9fÂÆU\90\16ÝD[yÝù¡Ò¨ ¬\e\8eÙ\94¨Ô¡s\93\99\ fKy³*h­iÁ£ë\ 6,I¥\8a/F\99¢ýA\1c\16\9aj\93ïEïÊyQÑRSþ\8d\91ÁY¯3<\85\93| ?\14\17\90\1fª\97\1fr\b\ 4L(ÛÉ\b\9eñ°wMAQ`\97\92Á<ÓŤñæk2Ï\ 1Ó¼\93ï8\r\17U½ÎÛ\7fB\bt\mVßie[~+V}!\12 ØÂd³Ûn}Lªºm`\ 3\8a¬"<f\1e\8f(ïñè÷#á¦\18
+Aî#ý\9d\12q\v9YWàÍuC\13!ö³|×\ 4\92yÈÕUµ   Ü§\ 1Hùæ\81K\ 3wÕ!éI\11\98Ù\14ż\98wi\9a\87D÷rOã\19°Ô¾ HHL!Óxr\vv&ã\1d\1e`ÓøÔÓ1\f&míS\ 4Çg>k\94\80ô\19 \ 149cÊÑÞ\97\9bí\ e·\0\18mó:_\17\90{Í;O&çÓ\93¯\81pľÒi«\19\17"\9a­O>}áÑ\1c\16Á\8bÌ:\eÝ{Ñu¤4\94,\81\1f®¢ÉÉ\1fT6\ fÐ#R&\8c\8e´Q,\95ÁÈ+8\e\94\8d§>\b\14\ 4©¡@\ 2\80}Ä2\rÜe\ fÃ\86\\ flÒ M{!\95±\fÊq_fâ«ÕÏè\17°õ¬hfu¹mË*D*ßÌ»\9a\a\19VÎp¥yÆ\rÚ0.\1f¹A»ìy7\1cDb¿\99ÒÌ\88 ç\15\94\9b\81>@[f\ 1\1c¼\8bZ¿ÜJ¨0Ê £R\13_U~\90\ 2Éu\88\ed/0µ
+}À\rQ "·¢\99\aÞ-Ø3N\90\19s ÷K±0ì\ 4.\99\91dÞõ®}\19*\95\ 5D¿\1a\95\92eÚFÊ@ê\1d¢R"d\0\95\96Pi=*3ÙC¥ÓL\b÷
+TÊL\99'Q©ÿ'*UÊ\81\8fA¥R\18]³ï\81\86@©Àê}+pÚµ\86Mà"ç\f´~ØQÜ\ 2\95>jz\8aù\ 3ü\9eA\19vÀòG¡LÁÓAÞRï2\82Z\9c×%VLL\80LÇÀìógp\ 6A\87L\95¯Ä\99eÚd\91ÄFTº\ 3\9cq\93ý\aûA-àâ58s©8Æ\99~)ûÉ\14\b\17ã,\e\88\b\98\aá\rW'º\90 \9fýH\86\83Ê]\ 2\0;\92{\8cÀ&ÐÞ"¯ÙP[@\97\r\91Z\16Ô\12\83ZI˱­5][\v¯p{¡cgeÞâÉÒ¸ø¾Ä6\15Gm÷ÙlW×\ 5\1dãuÁ{\ 6àâ°\99\82Æ\83\85þ÷`9(L7;ùXct¤PO:rß7÷ªCÛ-ö\15ëº\9fAw\8d=[\0kZ¹?\1eYàÁi:\1c\1c40¤\81VÙC(­\ f¥õ¡ÔÊyuP øÖÖ9MÝ@P}éÂ\17j§H&ô×\83®éEÿè\ 2Yï6}/<ëßÉ\14\eï_Æ#à\f\ e²ö\0\efØLÈÀ\ 6ýÑæ5Â\12g$Ù\a϶\13é\1aÕ\86z\7f\\ 3\r\93\10¢'íÛ£. }Qu7rz,ñ\8e\ 2n\r\15æãî3\17jÝ5¬\87eÿØú\0>ÿ·ÆõÅ\ 5ÄX8î\86 &\a-\87\14\8a+<¯)Zz\vW\\18\8d'#,\16Á«XnI\1cQ¨Ó\10%\98@\1f<m}/tÃÔ\85\97@\a\95ú\ 5\f~ügË¿Â\91`\96
+endstream
+endobj
+1404 0 obj <<
+/Type /Page
+/Contents 1405 0 R
+/Resources 1403 0 R
+/MediaBox [0 0 612 792]
+/Parent 1383 0 R
+/Annots [ 1401 0 R ]
+>> endobj
+1401 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [282.046 615.38 289.02 626.229]
+/Subtype /Link
+/A << /S /GoTo /D (Item.123) >>
+>> endobj
+1406 0 obj <<
+/D [1404 0 R /FitH 686.127]
+>> endobj
+1407 0 obj <<
+/D [1404 0 R /FitH 668.127]
+>> endobj
+1408 0 obj <<
+/D [1404 0 R /FitH 652.242]
+>> endobj
+1409 0 obj <<
+/D [1404 0 R /FitH 631.763]
+>> endobj
+1410 0 obj <<
+/D [1404 0 R /FitH 602.436]
+>> endobj
+250 0 obj <<
+/D [1404 0 R /FitH 528.719]
+>> endobj
+1411 0 obj <<
+/D [1404 0 R /FitH 507.95]
+>> endobj
+1412 0 obj <<
+/D [1404 0 R /FitH 474.409]
+>> endobj
+1413 0 obj <<
+/D [1404 0 R /FitH 414.575]
+>> endobj
+1414 0 obj <<
+/D [1404 0 R /FitH 378.71]
+>> endobj
+1415 0 obj <<
+/D [1404 0 R /FitH 318.876]
+>> endobj
+1416 0 obj <<
+/D [1404 0 R /FitH 283.01]
+>> endobj
+1403 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F14 574 0 R /F49 457 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1422 0 obj <<
+/Length 1616      
+/Filter /FlateDecode
+>>
+stream
+xÚÅXKsÛ6\10¾ûWðVj\1a!X\0\ 4ÈÜ\1cÇNÒÉ£µÕ\93\93\ 3\12'\14©ð\11§ýõ]<(\89\f%9­gz!\80Åbñí\ 2û\0\fhðúìåììùU\1c$$\91L\ 6³û\0$%Rª@Æ\92\0SÁl\11Ü\86RN>Ï~{~¥ø>gB O\14\8a±<\17\7f\9f]^O¦\9cóP\91ÉT©8¼º>\7f\7féH¯./>¾º4rΨ߼¿ó\14TDDÄ\83)SHäNìl\95Õ(@Äá¦*'S\16\87s½h+íhÝ\\9d­³<­Ì@\85\88ÍJ\1f^Y¶M\9e\15záå\14\8d\9e7YYX\94\80\18iP-\ 3×¹~}\16ÜZfE\18\81\9e"\88ó\19
+\88X¨¿Ïõ¦1\93¨\8f \89\10Ø\ 2I¢È©Ó¬Ò\ 69©òèh\1c®ÓïÙz\82ðÚµ\9b)&L\85í\ 4µéÜ!t\15"/\84\95\9b/ï];/\8bZÏÛ&ûfV{iô\97ÚsU\8e\0\1d!óm\8e¶j¬â8km\85DNñÄ\ 4\97\9d½·üÎ\8cF\1fÚפ\ f\edXµ\85ëäºX6+×/´^ؽ°ÿ°Ò\9eC\17sw"\v4<\84KGM]s\975®soU0ìéÜläEZõ±u\ 6Ä\ eH¿0÷Çl\98¿Ô\8e\98\15\9dð\11\1dêvcWèÊ4Ñ@\82év¨Í¬Áe(Æ0fü¥(\rßCáÈîhÍDQúN\9açÝ\9cö;dMí¥x©©\e:(ÊC\91#P\90µÒ\ 3quºÖÄj6vÙfÖBè{ór½ÉucG"\è\9dõ\97\8eá\a\ fA\9a=\7flÓÚ-»/óÜ)\¿èßþ)#
+CÆ\14bBiâö\ 6\90iDix^×Ù²prß]~p\82\9b\ eæ·I\84\a\95·\1e'\1d\88 v\a.\99Û\81\1dÛÁ\86+\91ì\85\17!0®É.Z½|;»qLû!\b½\0"èx¶¸ô\1a]\1aÏæ/7¬\9b
+\r7Ø}ª\ 4\89Ay\88à$ðQ\88\a\ 6Ð_Û4¯G0+I\14°\ eÏ\87\ 3 #¢vaø\99\93]馭
+o_t±\95·iw\13r¯Ëî.X/Ýj7\ 2\ 6\14f\ 68n@&IÌ;\96¡\858EF\14Ù;E1j¢k\9dz8©Ã\rS\17\16\90Ò\16æ\84;¸èF\88¾ÑKã8\863õ×\16\ 1\1e¿?ѱ\9debwÆÆíkÆM\8fÞdkíz­\rØM\96»aYxº\rT\86så        oÚO\14ø:-ÜpkùÚ\8d\97>\90ûéÌ·³I\8cf¸Ëõ\91¬\84l\8aÀ )\ 1º%ïG\84Χ+<öe\91ý­\17}#\fÛËÙÙW¿%\ 4\f8a"\ eD"\b£2\98¯Ïn?Ó`\81\93\18Yí%|°¬ë\80ñ\98à\9e\83\9b³?~¬2\18$\84±(\101'\8aùT¿o\1eÄxÑ\99\aS\1f3'sc-q~m¾³\8ehï¡ï·]d± È:Ô\ 1\rTL@±¡\ 6"\89\8fj Ä\98
+\12\9d\14\ 3\8b\8eþè\13\0h\9bhëÅ\80\18\15j\0\1e\15\0{KP$Û­x\81\9cR¹F\86/Fv@­vnÇ|­&zµ\15\16k,VýÛp\a§áò\ 1\þÔpÅi¸\9d\11\ 1Þè©ñÊ\9f0ïc\0+\ f\98yÀê©\ 1w\18\1e\89x\14\1c£¶±\1f`\80\19Æ.1&/\ 6âß\82>p-"Âd<\ 2\1aN\83în\86è@GO\r\9aÓ#!\87\ 2²&?\114é¡'\1ac@\14Öz\qB#_jì²\84\7f\80\ 1 l!D?¬\8a]Xõ©ÀUÙعY\95\95O±>\92\8a^$=\94#\82©\88 fu\16\91îHäñâO²ý`.L07´´XøI\17ÔM×çN¶«\rk7î%Kæ\93%{\²\84\91dyë ÌçeåËb³{éjë½D*\aµáÀº]NÇ\92ËW\\15\16\14ÃJ¨\13¸W*ªSu\90ßÀÚæ§\8b¡kCÿxuus¼$\8aO\16í×'«öO4¢ötÅ.U3ÆÂ_M³\87\ 4ùà8\9ad\1cÍÆ¿Ù\8aE\1f\92yæl2í_+åý¶\ft\1dw\96Ã\9a6ÂK\e\8bÓE-K\ e\10\13Ñ?M ãØ\17\88\19Ë'\8fY$\91}\80\e\8a5§!ì\99Ó\fß]âUú`^ÿø@O°ÎÜ®|ÿ'ZÙ®½s\ 6q\83\×µ\17½2\97ÆÐ\8c\8b\e\8a}høýFÍ¡ð½\ 1ýðzìÕ!\ f\19%â$¢ª\7f\9c\0ÿñ5\14\ 3\91\89xÌkH\1e{\r­v¾ù¿¾\86Ì\8b\9d\ fLÄN: ¿ÏÇý¯KÇûÉ\13\98 *Þ\16\11\9f(\1d\89ýñ¶SjÄI§ÀQ\90\88\ 6ÈÇ\9fº\17¥\8bH.0µý\1f\10\ 3B\98\9fG]>ªÊug{½9\12ÆqU4ü\vGüIÅæ\7f\b\17\ 6\1d\96\r\18í\13ÄË\19a\8a\16\v[\0\16Ù|ÈÁ\9f¸\8aÂ\97¹#Ì'øùâhWyº¬]÷\95Ån\17\8cÜ
+\8c`\98\9ccæÃÀÛbÓ\9a@\8dQp\93\1a¯Z5øy²÷Òú\a\ e\b
+endstream
+endobj
+1421 0 obj <<
+/Type /Page
+/Contents 1422 0 R
+/Resources 1420 0 R
+/MediaBox [0 0 612 792]
+/Parent 1383 0 R
+/Annots [ 1402 0 R 1417 0 R 1418 0 R 1419 0 R ]
+>> endobj
+1402 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [448.683 655.231 471.154 666.079]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.1) >>
+>> endobj
+1417 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [485.671 515.955 505.375 526.803]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.11) >>
+>> endobj
+1418 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [428.066 344.567 447.77 355.415]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.11) >>
+>> endobj
+1419 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [335.844 192.125 342.818 202.973]
+/Subtype /Link
+/A << /S /GoTo /D (Item.137) >>
+>> endobj
+1423 0 obj <<
+/D [1421 0 R /FitH 686.127]
+>> endobj
+1424 0 obj <<
+/D [1421 0 R /FitH 605.556]
+>> endobj
+1425 0 obj <<
+/D [1421 0 R /FitH 587.195]
+>> endobj
+1426 0 obj <<
+/D [1421 0 R /FitH 568.833]
+>> endobj
+1427 0 obj <<
+/D [1421 0 R /FitH 550.471]
+>> endobj
+1428 0 obj <<
+/D [1421 0 R /FitH 532.109]
+>> endobj
+644 0 obj <<
+/D [1421 0 R /FitH 385.006]
+>> endobj
+1429 0 obj <<
+/D [1421 0 R /FitH 360.722]
+>> endobj
+1430 0 obj <<
+/D [1421 0 R /FitH 332.342]
+>> endobj
+1431 0 obj <<
+/D [1421 0 R /FitH 312.043]
+>> endobj
+1432 0 obj <<
+/D [1421 0 R /FitH 293.128]
+>> endobj
+1433 0 obj <<
+/D [1421 0 R /FitH 275.32]
+>> endobj
+1434 0 obj <<
+/D [1421 0 R /FitH 246.94]
+>> endobj
+1435 0 obj <<
+/D [1421 0 R /FitH 226.641]
+>> endobj
+1436 0 obj <<
+/D [1421 0 R /FitH 207.726]
+>> endobj
+254 0 obj <<
+/D [1421 0 R /FitH 178.781]
+>> endobj
+1437 0 obj <<
+/D [1421 0 R /FitH 150.131]
+>> endobj
+1420 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F74 666 0 R /F11 573 0 R /F14 574 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1440 0 obj <<
+/Length 1536      
+/Filter /FlateDecode
+>>
+stream
+xÚÍXM\8fÛ6\10½ï¯ÐQ\ 6bFü&{)v³Ù i\90¤°Q HrÐÚ\[¨?¶\92Ü4ýõ\9dáÐ^ÉV6ÙMPôbR$EÎÌ\9b÷8r\91-²"{qv1={zeeæ\997ÂdÓ\9b\8c\17\869ã3ã\fãÂfÓyö>·L²ÑØZ\97?{{ùür4\96\17¯ß>û\85ºW¯ÏGÂæ/&ôxù\1c\97\8d>N_=½r\9d½a\8eYåá丫±¸ä¬H¶<\9f\9eýyÆ¡[düÎ\fc\99\15>\9b­ÏÞ\7f,²9L¾Ê
+f½Í>Å¥ëL*Ø\95ã\8b«lrö+ùÔ=\96sÜËdF[&\94¡Ãß\94ë0\1a\8b¢pùt$\þù\16\9e\\8ecBÉ|Rý\13к\f ½ÏÆ\9c3¯5½û¡ÐÅuÕ6Ðò¸H:æ VÝ5\93j±     ó\9f\ 5\17ùehfuuÛVÛ\r\85¨ÜÌ©S\87¦­«\19Î41\1cÃa\90\9eYy\12\ 6åÝýa\80`\ f@+\1c\83£ÉΫéïï\ 6 Ò\9cqp%!õr\83!jÃ"Ô`µ-\8a\9cc\9c´ÉßlcGçÓe@\87T~SÇÈ¢om7°\8c\ eéY4NÇô¢ûfr1y\98A\80b.Å E«¼Ý¶å
+»2\8f¯íÖø{MfÕ4±½¡¶ÙÝöƯW¸\9dÍg\98ß\7f44Xm¨-#ø\\06ÅQ\8aÄ(\fºÌ]\ 1(¨#\9f\1få²\19vYú\83ËÒ}Áe\98\88.ÃÚS\17a2º\bmIknF<\a\8fFc\9e\80\1cNS\rl±Æ>\98­\83\r$¸Miúv×ÞîZpÜÉü¶Äඡn~ºÇ\14       ú\ 5aþ.á\10\ 2\88"2-43\8ew\85C\16\10¬cá°\Ý      \a/8S 6ß \1cfX9¸÷'Ê¡\1eª\1cºp\8c[õc\94CyÄ×\91\9d\17t\17\9c¤­\11¬pv(mÑá¢\1f\90óº.c\14ã¤\85í¹èEãDhÎ7\ 3¬\ 2Nq¥ög\ e²IH¦\1cß/\19\87UX\a²m4Vp³\95\aKâ#²\ 3Û\ f\ 5×å"\ 68\e+\ e\17\88ë{PmæÕ¬l«Í\ 2\10ãÒä\9f\96U¤Ò2=\13¿\1còËE~Á¨\85ãÂP<f´v\1eæ÷ÐLÁ¥Èõ\ f¢\99R¨G\89f¿\8d¼\ 1Óªòz\15\1ad\9bÊwM\98ßÃ3\ 5\97«ÖßË3Í\94Ð\99\82=\vÛç\19\84gN\88\f3pÚãoh\b%Ô,\ 1Å-q\rÔî\91t\93Î1mô\83éæ\ 6\90\91\16aöû\9c~9ÅòÊ\ 2\17zW\81\92Ú}ñ*Ð2_\85Í¢]b_\90äC[Ò\14D\88\9eÑ3Ì_ì·[\9a\9c\87q\8c\9c(<Óâ\v\88\17½5©À"{\95.L~\81ç`\f÷çxox~Ncóp\97ó\14ò&¤åh.¶\89\83l\880\93\8bw©&åx'\1eË\8dqLXq¯æ@f@Î=Bs$\93\85<hÎ`Õ\ 2¥\81SvXt¬×]ÑÁGp8ÆS\ 3\81àæ;Ji\12"\88\88í\89\8eDÍÁä]BÚÆ,n\ f½\9a¦·5½¶Ù¶C1\feÔ&H\12\ 3ºÕ-\81ð¹¯_4V5ÔÂUÜVåjõù\e´ì(M\ eø]á¾\a\f\8fÒû\ 4Có5\fÍÿ\11\1fb(±èÛnÆwØÄ¡>Ë\\82ÙîÏ\18Øò\18x¤bÕ¤*\7f\976\96Ç0Ã÷dÑ­w\87@o®«\81º\81`\1e*wAãü¾Â×{HÍþ\9bCc(Ãß)L74ÔÒ\9cÉg»º>à\85\ 3\aÇÉi>t©÷]ÿf¿\1eå\96\19vK¹\83[\8aÊ\11©|r\v\ 6únÁÀ\11Z§®\99}½r\f[\12Ûz\1eê{\8a\ eQ(¨ëÌw^ô\9c9.3\ eA±û?\17¦Ë\98T\ 6Ô¤N.\84ù®F?\8d\ 1ûÚ\94¡<\8fß\1f`\7f"FC+:õ\16>\9e\94[¸sIÛÙ¾×ÆR4p\ 15\8bê/|-¤Ñô\157ÖJ#rqÿrCüæ\8a\8e\bH\8d»      N¯?Á¾Êã\15\bcë²\8eFA\17¸I\9dë\15\16\1c{«é#\fÇgôa\16\995V\8a\93\røfjÓyôEØ=OæË-N}Âí\ 2ùT§\19x\19\ 6\8fHR\95®-I¾\8e¤\80ÒÎ\88¡èJð)é\1f®¨Ãº¤¨Ê|\87\10«®'Z\8a\94ã°|»ÿ°\83\81 0 r©\9a4\11³\1fO\8fQ4\87\8a\0=2\1ejµ@Ãø\99\1a=\82þA\10¿ªlO\88\0\88L\12ã\ 4× K¨E\15\8e\v»\18\11çRZ\b¶ÿPzÙ\92\99ä\1e´k\12 mÝ\12\16qÞÅÊ\vçaï@½vY¦wïn\ exHÙì¡\9eª"nÐ\9dïYqg\10MÜP@|Ä=¡ä\87\89It\89Àãª
+½?è:\7fÔý\vÿËãT
+endstream
+endobj
+1439 0 obj <<
+/Type /Page
+/Contents 1440 0 R
+/Resources 1438 0 R
+/MediaBox [0 0 612 792]
+/Parent 1383 0 R
+>> endobj
+1441 0 obj <<
+/D [1439 0 R /FitH 686.127]
+>> endobj
+1442 0 obj <<
+/D [1439 0 R /FitH 668.127]
+>> endobj
+1443 0 obj <<
+/D [1439 0 R /FitH 572.428]
+>> endobj
+1444 0 obj <<
+/D [1439 0 R /FitH 536.562]
+>> endobj
+1445 0 obj <<
+/D [1439 0 R /FitH 452.818]
+>> endobj
+1446 0 obj <<
+/D [1439 0 R /FitH 416.953]
+>> endobj
+1438 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1452 0 obj <<
+/Length 2204      
+/Filter /FlateDecode
+>>
+stream
+xÚÝYK\93Û¸\11¾ûWèHUYXâA\82ÌÍcÏ$NÕx]\1eå°åõ\81#Q\12k5â\84¤<ë­üøô\ 3 Å\87¤}æ\90\8b\b4\1a¯~|Ýh\85³í,\9cýýÕÍòÕwwÉ,\15i¬âÙr3\93q(âØÎâ$\16RÙÙr=û\1cÄÉüËò\9fßÝY}Ê\99\86\16\96!\9e·ÿxóqyûi¾ÐZ\a\17Ö&Áݧ7÷·Lzwûöûw·¸Î«ÐmÞßyá\17\(\vDÍËæ\87¹J\82¦¨òý·ùBA»<6u±Î±c\83f\973õ¹X5ÇÊQ«|[\94\87×Ð1i\90\7fÅ\15`\1dâkvåq»k'\7fãVV¹e\ e\8dõ\\ 6Eý¼Ïæ0ü\8dVXÃ¥L\98\ 6·\87U       LÀ\93W5^\b\90R¤QÄg¾\7f3Otð\ 3Ü;N\82\15ÎÝñ\84²Î\99Ø\94nÐ/ÄÝúÈÜÜ{Üó(Ñ~ªa÷\b®ó.?Ý\9d\18ïÿõ°äÖ&+\9aÝ\ 6\8e~Ü£¸\90Tå«ùB\ 6å\ 1¨5¶\9a
+ÇW\r\ e§Ý\96\13÷\18\1c\0å\99\86Á#ÑòUvÄÛ¨$D9\16\157W%ëË©­vÔìÀ\r\9ck\ 37\r毹µ)qºM\83ç*_\83"ËÊM,ܼÍ\11Îìô\8bÝ*{ÊQ \ 6V»ÛgÛI5 RÙlÃ\9e\81\8b4\89½Õ¢¾\89§ç\ 3\89\88\95ò,ëNàk\96\19\1d\17eûÌZ­\1a°¶\9aÇÊ\r\7f3/Þg¾rÅý¾H\99ö²+:µ§Á¾ÈÝRÞÐÉbv\8eº\ 1Õº\16Já5Ý|¡#\11\87Éàþ5{\1eLEÁimØÎ\91v(ù;P1s¡Ôy"\e,4Ù£@ä¸\9b4"5¦¿Ùrç8WåÓó>oÜ\86Ï\95[?_\1fýÞ\85;Wæ¶Û\94{8\ 50½Ô\7fëá\ 3 \81°\80E\vi\85ñ\80 E\9fçó"
+Ãàý\86ÕhÒ\13=*%âT{=Þ-\7føx;V¶Q"RÒ3ù³ý\92W%\9fîÇ0
+\v¶æ*ãA\12<Ðåð¸&\11Ê¢\16\12!\8dâ\15q~\86ÌSǾC  ãW*È3o\ 6Ø\ 3OªÙuÉö\8b¯sç90öu\1eÅA¶?RW£ÍMØ9\L¦þ^\8fÅ\84\99\87"\89[üÞTå\13¯\1eò\a1
+WÇ\v|¸yàùÒ\9c,\10\e\11\9bÖ\95~\fÃp¼\89\15Ö´§\90(\a\82e0Å\9aШØ\1e&4\ag?   -7\18\8d×\8eB!u«ºÏ\13B`û¹ \ 3ðô¨µ\90\97À®ãÄ;SÌc\8d·o\90}äd\8fÝò\90\ f\fr¡Q,Þ
+\9cÕªI«ý\1e]ó¥ðNæM\r"\13áÅ\ 5SC\14Óq\7f\8f\8b\96ö¦®QÔ´è\87\9b÷Ë\a¶îѵÀÖò       \85H\15\vÛBâ\87\ao\ f§²T©H:s\18JEFVH0È\ 5 \87\8c\92îÈ\8fç\8eü)Ï\0p\8d\ 1S?ð\97\ e¾x,\1aî¶\8dº©\8aÃ\96ÛÎWKîá\ 408c#\b7-\ fÝ\1a\e\fO\16à      m\11c>¡\941\96:D]0æ\81kÇQ\1fóêUU¸h\88\a\r5!§  Mð\90¯0&ЭÐ@ÃYµ\9d\13Ý\ f\99¬\0\ f\1d\\1cĶ\88A\13Ë\1d"\11rU9\ 4ź\8b§HãóCc_Ô\rï\8cq\a\19\8c¢?vW|?\f]\13\11\92£S\12xk\ee\1c\ 3\15ZÒÜH\83««ð¦#Éðf)ÊA\8fáíØá\1a\12O}\vºgp-\11ab¼\99Õ\93È\16\vÕ\ 1\ 3#\9b\8e\bÙp]ʾ KÈö0     m6\16\ 2m\80\9fa\12\r±M\ 34Wù\13\ 5´Ó»¡Î\b^\94Ö\90^\fb5\99²\ 6=fôõ\8e      \84\1dy\ 1\92\bµ\1f2­Ù#ѹ4P³ÃÚ-å]\1e\88~yº:\1aèÍG\ 2ÕIд\98ÿD\97%\fȪZdý2\82À0\15±´cSYÿ^|jÊ&Û»Ü\ 5¥\8a\84\8d\94\81³b\92\13|¯X7op\92rSÆ\935gÝý\92Ì¢ôºQöEÆ\eæÿ>f{w\14Ì9\86\82L\12\98?\ 1\9aù_\v\9a(MP\81\f®b§Kí\18,  7s\a\98\1e\ 2¦V\f\98ø½
+\98Èt\ e0\8d\91\ e0\91k\b\98Zy3\82A\ 6\9c\95Àwã\9eJJ\a½<_é.ygãºþB\1a\ 1f,àÉ6Ö\1el\r\8fã\v¨i\b5\r\1aH\8b\9aF»¤\10O\83È9\97\18\8eà>)4ú\R\18IÈvÕe;µ"Ôi\1f<qÁ\90?d$.Y9\a\9e©Ð\91¹
+\9e±2=ðäu;\87\ e   9#È=ýk=RAøñ\1e\89môHLW­\1cA:\ e\ 1\1aäSØÈ\9aÁ\b£·\ 2Í ½õ\86\9cÿÑå¬\14\89\94ý\8cÓ\83 v\88®M\87èø\8aj<0òØÃÍ\1d\9eï¬<d\14Ã{@ý\11T\97I,à\19Ææl;sÞ^\ 3u\95Z\ fêØd\11¤I@>z|ÂßÇ\16ª\91\83\84\ 5ß\11d#\91j\f°JV\1c¨\80\0¤Âmr
+ùgç¿Ð{Øa\94\1d\8aýO·)«:\9b²îÁ°0\0J\1fJ|%ã8Y¹k\15\8eï©Øî\bÂÎä@²{ÙN\171 a\97m\ 6ãÄ{r\1c·_É»ÉØ''\94ç÷¼¬)\9erÂÑÐãh8­9-]ý\ 3\18NòPìzhõIõ\9a¹{!\1aØX_6 Ì£\8a\93\86\97(\ 4\9f\95Û·7A¦#\ 5O`ôiy%\89\82\13/®öÙ3\12}|\80Ñ|½u-ºH\12uCô\14ãæKA5\18hí²^\9e\87lùËÜ\1f\90¦c\1cÆ\16\88\98¾\83;N\1d¹+ÀäOc't\99É ¦ìþO\9eQ\84mîþ׳\ 2ÍÏ(5Î
+\86¯OaÒ\89|´¸þtñA¸M\12G5¼\93\92Y/\85À(\­óê?Åa\9dÿìI\8f\Q\9eÈ»ÃHD±úÕå\8aaõ  ëçqhú\97\ 5`\1e\9fÁ(a"uíq\15\9aij´        :Ý\91\85á\13ðvìr&Î\93\18P\9d\1f5c¾)\91\85Â\18ý«E64\veC¡)¤i\11ú\90V\14çJ\8cT\17»\14 \12)\94Ò¿1@À\9a\ 4úðýÅ¥\9aðö¥2YäCþ¸"\13GBv\15\99?V"K~C\89\8ck\83»®\12\19µ\95Hu=         Íià:/ øüÓҠʤSYìUV\.°½ætò$\8b£hh¤³R#\r8¦¤¬
+\89Yôfç^6ÐÞy(#<\95®æB+tL-\86Jÿ&§å\ e\\7f\89ä°L?Lê\fâîXã\98»wõ\86ÿYQT¸£$X÷×\ 6\0\8aþ¬³\89\88R,\96
+\958¬±Â\80\8a\82ûlEõs\88\177èÃ\1a^,søù\89io\99´fG\aÂ=\12\14Àf=qo\b\8e
+òc%y\97÷\87ç#\8a     ð\19\92\f\88ÉM^\rþ8ðßÛå«ÿ\ 2\10`
+endstream
+endobj
+1451 0 obj <<
+/Type /Page
+/Contents 1452 0 R
+/Resources 1450 0 R
+/MediaBox [0 0 612 792]
+/Parent 1383 0 R
+/Annots [ 1447 0 R 1448 0 R 1449 0 R ]
+>> endobj
+1447 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [289.213 485.496 311.685 496.344]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.1) >>
+>> endobj
+1448 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [286.805 395.202 309.276 406.05]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.1) >>
+>> endobj
+1449 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [287.11 259.024 309.582 267.935]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.2) >>
+>> endobj
+1453 0 obj <<
+/D [1451 0 R /FitH 686.127]
+>> endobj
+1454 0 obj <<
+/D [1451 0 R /FitH 594.038]
+>> endobj
+1455 0 obj <<
+/D [1451 0 R /FitH 573.349]
+>> endobj
+1456 0 obj <<
+/D [1451 0 R /FitH 547.734]
+>> endobj
+1457 0 obj <<
+/D [1451 0 R /FitH 525.108]
+>> endobj
+1458 0 obj <<
+/D [1451 0 R /FitH 510.95]
+>> endobj
+1459 0 obj <<
+/D [1451 0 R /FitH 473.436]
+>> endobj
+1460 0 obj <<
+/D [1451 0 R /FitH 446.769]
+>> endobj
+1461 0 obj <<
+/D [1451 0 R /FitH 420.656]
+>> endobj
+1462 0 obj <<
+/D [1451 0 R /FitH 385.078]
+>> endobj
+1463 0 obj <<
+/D [1451 0 R /FitH 344.52]
+>> endobj
+1464 0 obj <<
+/D [1451 0 R /FitH 285.032]
+>> endobj
+1465 0 obj <<
+/D [1451 0 R /FitH 258.919]
+>> endobj
+1466 0 obj <<
+/D [1451 0 R /FitH 241.169]
+>> endobj
+1467 0 obj <<
+/D [1451 0 R /FitH 228.665]
+>> endobj
+1468 0 obj <<
+/D [1451 0 R /FitH 215.055]
+>> endobj
+258 0 obj <<
+/D [1451 0 R /FitH 177.791]
+>> endobj
+1469 0 obj <<
+/D [1451 0 R /FitH 149.693]
+>> endobj
+1450 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F49 457 0 R /F14 574 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1476 0 obj <<
+/Length 1606      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XIsÚH\14¾ó+t\14U¡Óû2\97)¼d\9bØÎÄÔTM%9È \83*\80<\92\88'óëç½n K \1cãäBïÝoû¾÷\ 4\8dæ\11\8d^\ fN&\83\97¯\8c\88\1cq\9aëhr\e\89Õ.ÒV\13ÆM4\99E\9fbC$\19\8e\8c±ñÅxÈm|ú\11\7f¯\86#!d|òþêô\ fì\8aøôêìíåëп¸:;¿\1e~\99¼{ùʶî\87%b¤\83×ýÍÚá\96\ 1­å9\9f\fþ\190èÒ\88=\88¢\r1ÜEÓÕàÓ\17\1aÍ`ñ]D\89q&º÷[W\91\90p+Ã\83ËèzðgЫý,ã\9c\bÁ#­\fáR\87Ç/\93U
+ÂRnâ   *ôýn8\82\ 6æ¸a2¾ÎþKQ:\10\84\11    \87F\8c\11§T8ü\99*z\93U%´Ìï\12\96Xx¬½ç:\9b¯ÓÙïÃ\11s\8eÇgi9-²»*Ë×ÁrÉz\16lU¤eUdS\)½=úí \1c1bÏ\ eÒÙÇí\0Öîñ/·`\10\11ä|5ùûÃù¾¯4'Ô\9aÆUo×h£*\9d§Åp$µä1\ 3Cq¥âËÜwt<Y¤A¡Û"\98\16\94¬Ú\96\91\8eD£ú\99\8eu//N®\8f\13\88\81@\82÷Jä\84\89«¼\1a²8Y\86\91?¹YáïM\90¬\b\vù-¶:^%Ó"\ fÎ\a«SëºâÝ,s\7fl\8a7|-\83ÒYãÖ\96\rz\15æ\10OÌìÄÓå³\14Öý.p^aÔ\16»½Úâ\ 2j\8bí¾:0éÕ\8169l\86§ªXãí\ 4øáüì\18-ñeÚ}s\\14\89\ f)¿h4Ä;ï\80\8eÕ\96¨M¢âñºGBK   \93²y³×ø\\10iY³e\94.ÓU\1ad\ 3ë\ 3\17&[Iü\10\8d\89ígÊT2÷8\8eÀK@7¶«A¶\9eeÓ¤ÊÖs \ 6\ 6Áv¿ÈÀò&^Ôã=wÀ,ø¡Hûì1\r{gé\8c\1c¦\ e\ 5ää\80Á\8e¥Ð^êP\8c\13­xxþjSÝmÀ Â\8aø.Áx¨Ò¢üí°(Ò\ 2ñHñ\93lnà®H\1aß´¹\Yþ#.×ÄAÆ{\ 2\97\9b\ 3\.Á\19ÀåÐ\8b\91Ï\81V\9eMéRS"\94ü5\94.%:Ù\ 6q/N\ e$`# ðùóÁ&:V\11O\ 5\9buz\v¶^n\17\12,aúѦ\94l£M)\81\0S\9cØ]*m á\11\8bW\rFÊ0¾Í\8bÐI\93\ 6x~Û\96ôi\97¸º\80|\ 4g\929Ȫæ×àL8A¨¬qö×Ði°A\96Ü,Q\vae¼)ÓÙ#@\13ÚB¹ð\93@\13\94P\1d\ 1¬\b\834KÅ\8f\90æ \ 5È®%\1fE\9aÞE\1agf·j\12ÇBLHÐY\1e\ f1Ûç\11\8eîm\10v}úæüâ\1cÔV\9aõTGâ`u´\rÇÀ\19>\M\1d®8Qú8[¤unÝ\ 5åÅøý\87\93ó       Z\88Ò=\f\ 3+*¹ÃpÉ\8f²æ\1e\90½´\Óx\99\95Uèa\86ãª\v'\9c\9fæ\ 5ø"\84\9e\8dü\e\90Ô\85ÙË|ó`\81*\ f\9azüYÄ\1fξÙ@î\14«dݵKSa\18Ú©0\98&Z쨹ºÉz\18/ØãتÑú\92n\96þ\8b\95Ç©ªY\9bn@ë\9a¡¶\15\92ë\86{`\14¯\\ f\87<I¥gi¤\7f½F½\95o·ðÝ:l\16Æy1K\8b#\9cw¤¦\87Af}ù\1a\14­Ë\ë,\16æ8|\b³CJN\1f\0*5Tò\90â\8b|\15\ 6\93!T:ÈÂ\9er\ 2Û\14ó(t>¾\1eD\9fü6CX÷Ó\16®}\ 178\15\97URT£>doñqë\9fC\eÒG²\rZ\91\93¥\14#\16\93:ähmùÖÎ#àÍ8©[p0øµ*\920ôeÿ\vìó8ý6ô\1f\14ßÃR\13ð\92Õ\91bb\9fa¿6ËÅW¿\7fV?P\86½\9dÈ\81qV?üöròq\\1fm|BÐ\ f
+eô\ 5\0\93PôÈ\1d¶[cB\ frc¼\14aØÈ-µ\8e\179.Ý£l\8d
+õJ\12\9a`w7æqnÚ¼qÓd?)\1cì\80¢°¥K-\84oóuZwnC\9bfóEó9\817¶Ò@Ol<\90.Z\1e"}\9e\ 5¹ÑT\8a\a\93\94øÄm\10\9fv7>ѲÎÅãå2\é?\ fa¯'\b\9cØÿNTµ¯`1     ÇÐ\99K¬¯pîn\99¬Ó²\99\ eQ\94dkïæöÑ^\85\ fqg\0Æ}æßÃÕÆ\ 3¾:(K_>4\7f>°xÑN³v\9bfwÒ°\bÚz:Lªpâqö\8e\91\a\9fCuM0F_\ePluç\9d\99\17U\12´Æy
+w\87\9a\14¶`
+Ä©u^¥õ¡²^ñ\ 2àZ\12&ºõ¬¡mÉ\1f\ eb\84-¿\87\99²Ê\v\1f\7f¦\8e?\13¼x\101X\93UE\9a¬|e\17
+dì$¡i,a\11ÖÃ\10âö\ 1Ù°#»­Û*´\v\ fm¼¡\9eX¦IYw\11     ûI\81s¨Ê¨j¸~¹Y%=ßä ;Ûþ{¸\17\17\96\87GÊÂ\17I[\85vÄ·þtü\1fÒ\83\10\8a
+endstream
+endobj
+1475 0 obj <<
+/Type /Page
+/Contents 1476 0 R
+/Resources 1474 0 R
+/MediaBox [0 0 612 792]
+/Parent 1483 0 R
+/Annots [ 1472 0 R 1473 0 R ]
+>> endobj
+1472 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [400.29 230.763 419.994 241.612]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.19) >>
+>> endobj
+1473 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [205.218 153.838 224.922 164.687]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.18) >>
+>> endobj
+1477 0 obj <<
+/D [1475 0 R /FitH 686.127]
+>> endobj
+1478 0 obj <<
+/D [1475 0 R /FitH 668.127]
+>> endobj
+1479 0 obj <<
+/D [1475 0 R /FitH 524.607]
+>> endobj
+1480 0 obj <<
+/D [1475 0 R /FitH 488.742]
+>> endobj
+1481 0 obj <<
+/D [1475 0 R /FitH 404.997]
+>> endobj
+1482 0 obj <<
+/D [1475 0 R /FitH 369.132]
+>> endobj
+1474 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1488 0 obj <<
+/Length 1859      
+/Filter /FlateDecode
+>>
+stream
+xÚ­YÉrÛ8\10½û+x¤ªF\bö%7/r\96\1aÙ\19[\99ª)'\aJ¦mÕhñ\90R\92©ùùé\ 6@\99¤©Åe\9f ¬ïá¡Ñè¦hr\9fÐäÃÑÉèèݹM\1cq\9aëdt\970M\89Ö&ÑV\13ÆM2ºMnRC{ßG\9fß\9d\eQ\1fé(\11ÎÀ2~ÌéÇã/£ÁU¯/\84H\réõ\8d±éùÕñp\10\9aÎ\ 6§\97g\ 3\88Fðmå`tôÏ\11\83\9f4a        W\94\12 E\fwÉd~tó\9d&·Ðù9¡Ä\0\83\9f\1c¸\vÂ\9d\86ß³äúè\8fç\9bãJ\13«x¢\95!\ê@üÓâ6ÿÕë3Nizºìõ¹Mo§\8bûÀz\18\erO¼\9b\98bD;Ù&&\9d}\ 1\89\12\92\12nm F\ 1\9a\19\9e~º@]\9fá\v\ e'$\8c\9f#aN\v_Ôð9qÖmG\17ÜÁYë&úÅåðO\ 4\9a\13\ 5­}Æ\88S*ô²'nWÇ~\18m\ eà\a\92g°qcÞ\82<¬$L$¿\8bº8\90\19\95Dsþ\16Ì`%ÉE\9dY\vR\ 2unß\ 2R:"\98iBþ~|=
+rXN\8cqM9äar(ǽ_x½\1c¸\92Ôv¿\1co\0\19åh@¢\1c\1eê@=,ø\1eö\16æ\81+)\16ÏêÃåïg\83\8b\ eX#\bø\877@5 ®¶MÔ§»Î¨#VDE¢\83Ô\a*¢-1êM,\ 4VRÊ\1c¦ÈëQ+Eê¨\9dzD\v1\aê\81\8f\r}\13\v\81\954¬´ÿƼ\1e²º1uÈó\1e<\81\97_¯¶¿\81
+JGÙK\1egº-\ 2áR\11­d¢8^ÿh¡£\9e\15i6\9eåU|Áìû^_J\99\ e³I±ÄV\99\9eÌÂk=A¾\7f\87\91Û_ô²3\16\ 1§ A"\93ô\ 5l\8dG\ 5Æ­\95¥\14éê![\85_\93å\ 2ÛWÙtQV-\11ä6Ô\9bóã é¢Z(\8f³°÷¡XγP\7f\9ce\8b¼ü\r*\86¦ãuD[,W[æÏÖ0³ã-öëÀ2BÑtø\15\1e\83¾\90&\1d{Fy¨Ô  c\1d×Ær\9b\8d3J¨Ð\89\ 4/B­z\8dÁ1A(W\894pѬ®ù#\8f?¯xA@)­JG\ f¨Ñºô»a E\93~\8f¥á ëSCu\91ç·e¼Ô\8a\13¡ZaÁj\19ìãI\16¨Üæ\13\88\fS\ÉDqÀÎî\96Eè.×áÈB-\v½óÊ ÛÇN<:\ 3ó\92²\89Ý4R8¥ù\93\91úzVäáG¾\98ÔÉ@˺ÜÌZ.â¨å]\1c\a½Lº
+U/Ï7Ê\ 4î)/ò`µ¡¯\f;Éçy\89R;\95^?µ\84!4ª×±\81\15\1a°\80\99ðï\85\91@,\ fuo\9fØRfóØTNç\8f³Øúq\8d\94æÙ"tM\9e\8eÍO^\86QEþXäå\8626­\1e`?q\91ys\96\1f\9eãÞÇ^®¼@\93áV§YÙ¸"Ñâî§?pJ\8e$\0\7f,+·ã\81ð\16\84\vPÜ'áÇ\158\8c\e?\12<\92k8\14X\14\85\ 4+\18ùýÃ\98\8dþ9\1e@\11Ø\83\11O|¿Þ ®ª        eý\b<¯²5¢¾o¨nöm+;.BGV\96Óû\ 5ØL\87{@\89\81LVY4¶Lj·\ fÂ\8e\9aI\84~\8a\85À\93.C\ 3\1e\ 4¸ù渰¯|\f\8c&(\81ô\9e\91G'\ 6½Á\89Á\8fñtU®\8a<\9b£ß\93*ýù0\9då]´\eâ\bÉSö\9f\ e?¼åá\ f¼\91\92¥\88÷+x6Þ¢\86~\ 4\1e\91lV.CwÍ\10°\1aü «½?[­\0\87\ 2í¼v&j\87+\9a\0ào¿]û\9bÔ}\0\98Q\9e\85\15B­îÝÐQM\8b\82\85|ͳ\162\88ê\1dQ%j¨V>Ã\ fÙØam,Ù\99§7C\0\ 1\9cá\99\16\10LK¶3\ 4à\94A<Ãv¤ÁÂ\80o\81\88\f\96ä1\oØ\9c`\fSO\9f«óX
+_2Ld|]Å\12\8c\81)\r±BÇóE!ÿw<\11\90vK£Û\9c¹sOa\vpÖÌíç¬\14a1x¬y´z\b\12\\15ßó\91áݹ¡õ¯,\10\9d:i«¯,óiG\10V\9d\0ÄnHuÇ\87\88Î\130²c;Â\12\aãøù§¾m£ ât\15-Ñ8\8bç%­\95x&Õ÷¤:r?.Ù¸\ 4\17»:wÙ²\vÞâ "6;\1c{?8omPn©\8b\bÎ÷\82ë\rø~tÚÚ*Ý"\85\8cèâ\ 5[?\0¾º\89ûJ\1eáå\8bà÷ã«Ö\8dßV²\88¯^\86¿\9f\80®¹\9a}%\12Ð/$Àö\110\11à\90r\8b/¬¼\a\97\16ò\1dý\12ÿ½3\85\ 3Ç\99pN\89²f[
\ e\86ͧ®þ °´ÜùR\81º\9cp\15²9f\´[Òz£û
+4út\17Ô\96®¾\13ÈA\9d¨ä>\1fýõeðüL$'ÊËâ\aMã{MÃ\8e¾QE§!Ø(²ÐsW@ \fíì}\93\ad8\84\e Ë\1c\91\\86åp~\86\83»8\9f£¦>\e\15¿        ¦01-óÉz\15c\9aÐø£§ 
+\9e­cuy×õêHü\90 6¯Îxú|×@Ò\89ÍÃt\aikX\90\86ÂçSP"ÿ\ e\81\14l#ìÅðä:\fbõ»!4át3è\e¥\1d\11å¿*\84\93E¡0¦c.\9dö0´FM0|\87\90ç\a\86O\90\aû,\86á1ÛJcBlØe\ 6p r#Çðdxy6¸~ÎEÃý°\9b\7fDn:\84åÄh³[VT~cLß\83ÅÄ@N6\ eOà[¶±1ÿ%\1e·ß2nÈ×$±Ò6­\8aw^\81KÀ)~N˸zeº\90oäÅnÓ\ 5ÖNT\96+\ e°Ü«<»m¤Í¢\ f\81g\fO\171Y©\82Y¼<ù}à 1\83\v~áúôã`8è\8eUÁÇý\ f.5\ eô
+endstream
+endobj
+1487 0 obj <<
+/Type /Page
+/Contents 1488 0 R
+/Resources 1486 0 R
+/MediaBox [0 0 612 792]
+/Parent 1483 0 R
+/Annots [ 1484 0 R 1485 0 R ]
+>> endobj
+1484 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [223.615 429.132 243.319 439.98]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.19) >>
+>> endobj
+1485 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [405.497 405.222 425.201 416.07]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.19) >>
+>> endobj
+1489 0 obj <<
+/D [1487 0 R /FitH 686.127]
+>> endobj
+645 0 obj <<
+/D [1487 0 R /FitH 534.618]
+>> endobj
+646 0 obj <<
+/D [1487 0 R /FitH 232.542]
+>> endobj
+1490 0 obj <<
+/D [1487 0 R /FitH 204.16]
+>> endobj
+1491 0 obj <<
+/D [1487 0 R /FitH 182.19]
+>> endobj
+1492 0 obj <<
+/D [1487 0 R /FitH 152.804]
+>> endobj
+1493 0 obj <<
+/D [1487 0 R /FitH 131.388]
+>> endobj
+1486 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F74 666 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1499 0 obj <<
+/Length 1941      
+/Filter /FlateDecode
+>>
+stream
+xÚÅXKsÓH\10¾çWèhWáAóÐÌ\88ËV\ 2a      µIv\89+\ 5\15rPl%Q\11KF\92        Pûã·{z$K²\92@AÕ^ìy©Õ\8f¯¿îQ\18Ü\ 4aðçÞÁ|ïùk#\83\98ÅZè`~\1dðP3«ã@[͸0Á|\19\L\f\8bØtf\8c\9d\1c\9fÎ\8fNO¦3)åäüðåüôÝÙôrþöùkÛ\91\ 1\9b̨\18Þ@Os<²\17úw6ÿÁL\86\11ã6\ efÂÀ³\92N\7f\f£ð
+~ú\ f\ 5\17³(\f'G×ôêã³\97o\ e\8f\ fi\92Uø¯&á\8bþ#B3i@:\8fX¬HxÆƤ¾\9eZ9)J\92\96&\8b©°\93[\9a-¦3>)ò)\9fT8J\17\9b\82û)í\7f\99FÑ$¹ÛøiÑèwúÊ+w]\16\1e\ 5ý\9b\9cå\8b»Må\85\ e\82   )À\ 2     \16X2a\7fÔ\84wi²$¹    \89\95³«¬¦\95M^e7yê÷³\1cßT§7iI'\93\8a"hÂ.\f¢\98\86p\95íF\19\95ã¦91ÐjÆ\rgÊr¯»ÇÑÁ¨îû\15êç\1d·ÿ×ßoö\ f\ eç\17cJA$ÃX?©\94mN\z\97ߦd*DKw¢\85QÚÑ[GàsÙC\rBrñ\10$OAzy\9fU)ÄS(\88'@@\88\ eD\85\10\ e¢ø\9f\175\r\8c;\rÐñ¶ã\9aS\13\a)\85¨ÌÒ\8ad\15×´Ñz\a\15     ¸a<² )gq¤IUoj\a\98U\eö¾/\16EY¦Õ\1a\ 4[\ 2ø2Ëo\9a­»Í*ï#z\8e9\92\Ý¥Î\a\1c<\10\ 6åM@\83\e\ eÕ\8cÇ\ 3/íBÃ2¡£\1d\ f/\1fòð6=\952 i^õs\12\16WÉ¢,èôÕ]á\ftÏ|¢mç    Ø[ÐÖÒ%\ 6¬\17å2õ/q\ 1¿\ 6ÊSVMÎÒE\9d\81\87\1e\e\1e\16L\rÍFsþ¥@5\ 6c "ÏDù2ýÚää\15ª÷m\ 4ñQÈ´\92-à¯Æ\10\ f|\1dòæÈ\80@f\90Æ\ 30\8fS #Vk\1d{Øxè·\11Å43¼¥\87«ñL\8cD«ºs:È'øÁ\e\0a    -­ï\92Ü/\16^\8b&\82­&\ 651£\9að\883\1d\89G}$À\8d¦õQú5«ê\8aÄW\e\ f'\8cÓLHÎB\15÷#Uß&5\89\84\9d\8eLÎ"ÛrÑÁKà\92W»o\86\0rÙ¾y\8cÔ\ 43Ú<æH\væÉ\ 1£5%\8f\ fãm\81u\ 5ÿ\91\8aá"\1eëN)\85\89\93\vÿ\8e§p\80<¥¸\98\94T_bC\\91Ò\98J\f\1cK\9a\7fú«³UJ£M\8eq«³;\9a\16¹_\87H»Ì\0²\15CwÃ\11\ 5¶½Ù|\f¹\%9Nå6]+ÚÎüú\ f\10\93\1a'&\12ãÅ\95d\15\87÷ÜäÙ÷t\89\86G\90\10ù\92\ ex¦Þ\ 5BØ×ÿø\0ËÊHW¤94;æ)(Ø'\93½\v\ 5àxÊ(\18t\8b\eL\9f¨¤ÐqYùãåý\12»\15\1dNî¡Ø¥#\ 2¥e\ÙÇäA¹\8b\19\ fe¿^eÕ ,9^ì\97\9e\83\bÙE\ 4M\97é\96ÑwJ\8e\ 2\92\8c\19\19\96s\ 2>\16á\84j°o¬p¸m¬\\8dï6Vî\81j\ 4-<\86b°åë_D\8bù\89Òp9t\8a\88\15\ 3²È²§Ýb#êr\8c\ 4¢ \7f¤ó\99graÔ\80¶+:\84)\8bÿÔèÀÀó<\ e\87\95\1a×\12ÌG\9f\98\89o\93ª8xF<"\99°ª\9f\88\ f\88\99RÑÿ\11\81ÇÛÑ\90V±ù8:\99\1f¾sq8\9cï}ö¬Æ\ 3i4Ó:P
+T36X¬ö..Ã`     {o\83\90ÉØ\ 6÷îä
+T\8b-\96ç»àlï\1fºæõnh\ 6Ú{\b¹R!\8b¡Íwê\9d\9c\1e\9fcÓ¼Ïl\0i\ 3í\90 ô5`.^§$ÈVº½\18B ¸\0º)\\934\93&\9a\9cOc\ 5W¥º(«]\97\0]Bé´P¤\9c\84#ÄD\8c<Kÿ>\8bÊ\84¦×e²BÌÁU\91°\ 6k+ÿ*\1cSßG¯"9eJ\83Må8\1c\1ft\1c\8ekÕ¸\ 4C\12hîiÄø~ØéäÌ\18\12}õ)[Sû\8c|3S\86;c¤\12Î\18©¶w­\92\96[c ñ¿\ 5ì\16øê{g\ 1ÙQúM¤8×\11ºÇ\1c\ f*\7f?\18\11Û¤\ 5õï°°ê\94J\9c\97éçMVú\87\931[Z\87DªãR\9a»¬\8d\80\8e\9bltm2îàU\16ÿý-"]d×ßh%i\9eA®Һ\95\84zû§\88\ 5"¤Øk(*ùÂO\9d\97èqº<ãâýmÖôýþÍ#V¬Ët\99-êÞ=¸OD\18' õùmZù¤[\97\9ewÒå¦L«æJ\8cÔáKSÛ"Ò\16-6\ e£«\963\1eÝS7_\11\9a[~\13ØoãÚ´\89æ¬\10M~\18fm¼ýôÂ\1fÍ1\9a¿r°\95\ 2Ëáx\8fb\99l\84\1eåë\rº        :§u\82î\ 6,U/vù¦ù\18$\80.\8c\1eò\8d\89MË7\80\10ð\87\19\87\vÅb¸\8a\b\1d3a|     >¡H[n \8d\ 3\8f|[;ï¸k0\84é,\ 3´}wß]\¸¡^i ¿^ÌÝ碬®\9aË#v"V\98 {æÌUé?Pj(ÀSÕ¢ÌÖÛø9zÀè@üáÒín{Õ#Î\0\864P6\aÞP\1dö\1dõF¿\rh\84\ 1\ 1KÝ´\8eçî»Ñn%2PÝÚËÖQï\ 3\8e\81âÌÑ2(%'\85\eD\88o\84\8c
+[\9cr.ã^f»ÝmË\94aW\7f\14꣠  í\80 ÒúÖ\1fe\8f¸F@\8d\bã\9f\ 6ʨkx¬\99âþÖzº©\7f\ e²\1cÊ\15\87\96ï\970\v\85v\91C+ \85ìb\96ëP!f-aÖzÌJÀÚw\ 2«\85û¯\89ûÝî£`Õ\ 3°JÅ£_\ 6+W\8a\7f\ fX9\94\e¬¾ß\ 5*HÂ\97=\bT\rNâ°ö\ 1ïlîã\16Î\1cZ¡}\9b¼§¿E±j>Kù/a´î¾\82Y\7fãÁ\85¶jÙnÕb#ü7ó\9aõojç\1f~»    \1f~\9f     ;\1fÌ!Àÿ\ 1Òû»U
+endstream
+endobj
+1498 0 obj <<
+/Type /Page
+/Contents 1499 0 R
+/Resources 1497 0 R
+/MediaBox [0 0 612 792]
+/Parent 1483 0 R
+/Annots [ 1494 0 R 1495 0 R 1496 0 R ]
+>> endobj
+1494 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [365.954 583.5 385.658 594.348]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.19) >>
+>> endobj
+1495 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [423.017 567.006 437.74 578.961]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.4) >>
+>> endobj
+1496 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [317.292 501.806 336.996 512.654]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.19) >>
+>> endobj
+1500 0 obj <<
+/D [1498 0 R /FitH 686.127]
+>> endobj
+1501 0 obj <<
+/D [1498 0 R /FitH 668.127]
+>> endobj
+1502 0 obj <<
+/D [1498 0 R /FitH 651.689]
+>> endobj
+1503 0 obj <<
+/D [1498 0 R /FitH 638.294]
+>> endobj
+1504 0 obj <<
+/D [1498 0 R /FitH 624.347]
+>> endobj
+1505 0 obj <<
+/D [1498 0 R /FitH 609.846]
+>> endobj
+1506 0 obj <<
+/D [1498 0 R /FitH 582.504]
+>> endobj
+1507 0 obj <<
+/D [1498 0 R /FitH 552.616]
+>> endobj
+1508 0 obj <<
+/D [1498 0 R /FitH 526.159]
+>> endobj
+1509 0 obj <<
+/D [1498 0 R /FitH 478.837]
+>> endobj
+1510 0 obj <<
+/D [1498 0 R /FitH 462.399]
+>> endobj
+262 0 obj <<
+/D [1498 0 R /FitH 423.475]
+>> endobj
+266 0 obj <<
+/D [1498 0 R /FitH 334.469]
+>> endobj
+1511 0 obj <<
+/D [1498 0 R /FitH 316.024]
+>> endobj
+1512 0 obj <<
+/D [1498 0 R /FitH 280.158]
+>> endobj
+1513 0 obj <<
+/D [1498 0 R /FitH 208.369]
+>> endobj
+1514 0 obj <<
+/D [1498 0 R /FitH 172.504]
+>> endobj
+1497 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1521 0 obj <<
+/Length 1943      
+/Filter /FlateDecode
+>>
+stream
+xÚÝYËsÛ6\13¿û¯à\91\9a©P¼\b\10¹tÒÆIÓ\19'm¬ñ´\93ö@K\94ͯ\94è\92\94óøë»\8b\ 5)R¢\1d«Íôð\9d\0,\96À>~û\80Ä£\9b\88G¯Î¾_\9c}û2\8d\1csF\9a\8e\84áÌ\18\e\99Ô0!m´XEïc+g\7f,~úö¥UCNÇ\99r\16\8eñ<?üøüçÅù»Ù\)\15[6\9b[\9bÆ/ß=¿8'Ò\8bó\1fÞ¾8ÇsÎx¸ü|qö×\99\80)\8fÄþbc\99\95.ZnÎÞÿÁ£\15\14qfá¦\ f\9eu\13\98\15øa\19]\9eý2¥\84aF'\91I,\93Ú\90\80o²M>\9bÃ5:^̤\8d?ÍD|7\9bË4\ 6²\94\97Åç\1c\ 5\8c\12뢹\10Ì% }þ;OøuÑ60
+ϤR\96\82\81\86<\97ÅÍ6_}\a
+k\91Ä/òfY\17wmQmÑ\ 4:ζpå\8aæuÞ´u±ÄÍÆ\e\18Ê1«\8e\8c¡]ú 1¦\ eÑ,IÓ\93-ªÝ\14.xʤS¤ïÕÌ\99\8bìºÌ\eÐ+Õñ®ÉWÏ\1eV(I\15s©þwÞµ\ 2Ü\93F\89U,árè]É\9d\vÞE×Ú   ×Z\96\b\19\k\9eàZsàZé$?t­\ 2×\9eä×$I\98sÉ)~} RÁ\f\1aÝëHÌ\8b«ËׯÞ\0Ì%çñëí\fÐÝæ7y\rÂY \b4Gbâ7\95\9f$ñâ\16-dlÜ\80~83qµ&JK[&ÞT¤'ÎïѶù²­jZ/«\rÅP5÷\96\13\10:æ r¶9ÉA\96úß®iÉT«|YùoWù\8a=b+i\98Sê_B&a\ 6\18´\13\f\ 6/\16©ny\lWÅ}±Úe%­÷:u\927¸!È2À\90ÑÐÛ\ 5¶î\91¯³\v\9e\91mirÝg\18àòúZÔ\97Ö»¦ØÞ\10\1fÜ\15\92\16\ 1\8f­¼eçB3§õØ´\9b¼½\r6l å\1aeI-åR@µÐµ·5, ,1@\9d\91p?KúÐ%J\99ooÚ[\9aÿ¸\83¯Õ\ 6\95Àoz?}3\9bk¡ã\9b\82ôÝ\12w\11Ø\16³\14"\ 1\ fDg\92\1fë\9b\88&ï^\9dEï=;äd5ª\ 3 \88÷?,FqIªð4n\0)>À8^ÚKÓ\10¥íØ6ÙͶhw«°DKÒ>¤Ý@[BhÄä_»÷/í­\8a\1a<X~¢\95W
\84\ 6Ì\ f ½\12\87\8b\87b\a§\84P²Ò\9f!­ê\9c\14p\93\96\1a\r´ö6kÇìímÑ\10e\995=W^ç´\9dÕ\1d\r\85\ f\10ñ;u~\aù'(\95Q\ eò\9ckÂ¥\fA\r¬äÿr7©Áç¼®PNÍã\97èSüZIá#\ 3\8e½.ÊÂßý\89È\1f
+\8f\e\98]ý¬ÐH _F\ 4²\ 5Î@u\9a n8Öy¶¢Y¾G\13î¯i$·ÂdèÖî»       ¡ý¹\90`zá\93ø-Ú\1d\12£)à\0N\fäî\13Ú­\9a|\9cÍ\95¯f\94¬Öð­7\ 3ÌI2Ø\ e\96.ê<0ÕP\85\bÊ}´Jf»\ eä<["?ØJ'r"Í\ 4:J\88\91\87\8b6ûsFù\ 3WU \16ÃÄ\8e\ 4ðfâ½ÙÐz]W\e\84\1e¤AHù\f
+&ïÊ\1eçÄ4L\95Ð}Aá\ f,J\84SÄ0\99
+f¤êX\9eaOei0ñ³ã\ 3\85b\12*~\7f\90\14uX\96\90ÿÈõ\81\ 6\81àS\1d \15®\18»÷6+×ó»âc^b{\95`¡õ±\îÀ3\bu\ 4\9evqÁÈ\ 3\aª\v\ 1ݪ/\11OÕ]$\13ºûÙ^õ£\13ÀÛP\92ÃþÔ\ 1Ø\98\8a\7f\a%R_\90Èî%\ 2\e\19h{!Ì>úP(aÚ\10Õg<\18û|  ór·ÉÂ7¥o_ýG\18^©ÀÜ )(`?ïÁ\8d«fw\rÌóP¹\8cbº/]!\18\9alsWúB\88\8eÿè3\1e\9cés`Ú%ª\14Ã\ 1O\ 5<g´F9rLÅÐ\88\r¸ª\1a\0Ñ¥õ\15\95U ÷5:\95ã\1a\9dN\ 6à\ 3iE¦¼\8f¹\1aRlKrC'\106¯©Ù\f×òØgt\18ÿÚe5|Òá\16I &`6\0V:þ\10\82N\192ÇÓ\ 1k'Ð\ 1Y(\15OÅ«M¾R´«/\89$\9f
+X\10É[Í\e°ñµÓø¾\80ò\ 4t\9bÐñ\8f\1d\ 6þY\16\8dÏ\98\ e\9a\846+Ê\86\16Ø\10è\ 4ÐTQoå\17\0¡\8eù>¤Z(t\0\92\86ö}µÅ]ª\ 58k+\1a\11@»6lõ«bð\9d/¹¸Ñ\aÆ\ 4¸®Kêe<Ç\9f¡øtÕdå\1f\19\ 1\f\15¡B]æþ\89ñH£å_á\8e\89éNË\97'5.OÏC­\ 4\14\97A\84.|\90>\f\1f/J(\9eÃ6~\V×UY\92©\9bgc1æää9Ö£4¼à\ 4;\10u\9eà\efM\b\19=F%>2z\90]\]\84_\16Æ@JRfÀÐ|Ü\1eðCQ\8cf\1a\0:\97
+dqû\17aÖ=\a\ fEz\17\1a\17\87Ï)¥x×Ú8\1föHÈhÙ\16Ôhðx\17\1a\85\926ªm û\16\159©×q£Æ[ñxÔêÂv\11è\v̼_è´\81m¢Ó¦c\1a\ 2\81õ¯¦QZ\86à© Ýú\9c¯¾9xÙfMhæ\94Úw@}ã\11è\15\8d\17W¿\1exs.R&M\ 2#<À¥\1c<¼ÿÿÍÜi>\bü¯eæß@ð$>´µÒÐe¤cHËÉðz\8bï\8a\ f\90.\ f¢Bà\9bÛ\9e\1e\14¨        é\91ÌÉ_ØEo\eÿëIÈ\ e£_%¼Æ\13!.\8cd¸}\8cÿ:Q)À°\1dÃ\11Ü\1cgNª\807õt¼í5\10§h\10ü\81¿¾\1c\88"\98àö\18÷Ë\87äx½\1e\1e6ε¢C\v\81dÂl\90\1a9\17\8f\9aM       \90¤g\99ÀØq3¢%K\9d>îEFw\8f\9a\91\93\1d\86ý\8e¶òØP«ÿ\12rV\ eÊÊo\93\1aèÔ<\ 6:Á'tÈ¿&è°A©;\1c<\ 2\f\ 1\0ð²øëÐSÑ×Õsý\14ô ¦\9c\82\80¾\94ÛÓÑ\97\9c\86¾\13}7øKâoн\16ã
+endstream
+endobj
+1520 0 obj <<
+/Type /Page
+/Contents 1521 0 R
+/Resources 1519 0 R
+/MediaBox [0 0 612 792]
+/Parent 1483 0 R
+/Annots [ 1515 0 R 1516 0 R 1517 0 R 1518 0 R ]
+>> endobj
+1515 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [482.903 476.221 502.607 487.069]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.23) >>
+>> endobj
+1516 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [293.171 357.816 315.642 366.727]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.1) >>
+>> endobj
+1517 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [475.692 294.408 495.396 306.363]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.23) >>
+>> endobj
+1518 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [475.692 264.93 495.396 276.886]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.23) >>
+>> endobj
+1522 0 obj <<
+/D [1520 0 R /FitH 686.127]
+>> endobj
+1523 0 obj <<
+/D [1520 0 R /FitH 620.248]
+>> endobj
+1524 0 obj <<
+/D [1520 0 R /FitH 584.383]
+>> endobj
+1525 0 obj <<
+/D [1520 0 R /FitH 336.569]
+>> endobj
+1526 0 obj <<
+/D [1520 0 R /FitH 312.633]
+>> endobj
+1527 0 obj <<
+/D [1520 0 R /FitH 281.219]
+>> endobj
+1528 0 obj <<
+/D [1520 0 R /FitH 248.958]
+>> endobj
+1529 0 obj <<
+/D [1520 0 R /FitH 225.022]
+>> endobj
+1530 0 obj <<
+/D [1520 0 R /FitH 205.009]
+>> endobj
+1531 0 obj <<
+/D [1520 0 R /FitH 187.487]
+>> endobj
+1532 0 obj <<
+/D [1520 0 R /FitH 169.965]
+>> endobj
+1533 0 obj <<
+/D [1520 0 R /FitH 152.443]
+>> endobj
+1534 0 obj <<
+/D [1520 0 R /FitH 134.921]
+>> endobj
+1519 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1537 0 obj <<
+/Length 220       
+/Filter /FlateDecode
+>>
+stream
+xÚU\8eËNÃ0\10E÷ù\8aY\8e\17\88_,\v\r*R\1a©µ²©º\88R\83\10ÐT!ü?\8eܪ°\99ç\9d9\97Ã\epx.V¡(k«À3o¤\81ð
+\82\eæ\8c\aã\f\13ÒB8Á\ 1\8cPk\1d6mØ´[B\95RØ­\1fC»Û\93cx)k÷çGZ2[ùDÈ×j\91\14üÊ,ëÊ\81\10Ìk-\175½É©´é\85º#%¡BH\8dM?LcbZ\8d«Ï¥\108\90\14>ò¬\19ç÷ñ\9cë\8eø
+ã0\8f\9fâ°\1cH<Åì3qîF9Pá\98r>37çËÏ\9cÔNá¥\9fú¯8Çéûá\9fù[^\87â\17lßL\r
+endstream
+endobj
+1536 0 obj <<
+/Type /Page
+/Contents 1537 0 R
+/Resources 1535 0 R
+/MediaBox [0 0 612 792]
+/Parent 1483 0 R
+>> endobj
+1538 0 obj <<
+/D [1536 0 R /FitH 686.127]
+>> endobj
+270 0 obj <<
+/D [1536 0 R /FitH 668.127]
+>> endobj
+1539 0 obj <<
+/D [1536 0 R /FitH 651.73]
+>> endobj
+1535 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1542 0 obj <<
+/Length 1353      
+/Filter /FlateDecode
+>>
+stream
+xÚµXKsÛ6\10¾ëWðH\1d\88àýè¥#ÛrÛLí¤±Æ\13O\9a\ 3-Ñ6§¢èRT\9dö×w\97 %Q\86äGâ\8b\0\12 ¸ûí÷í.E£Û\88F¿\f\8e&\83w§6rÄi®£ÉMÄ4%Z\9bH[M\187Ñd\16}\89\8d\1c~\9d¼\7fwjÄöNG\89p\ 6\8e\1cÿ:ú8\19\7f\1a&B\88Ø\90ab\8c\8dO?\8dÎÆþÖÉøøÃÉ\18Ï\19ÐöåãÉàï\ 1\83)\8dØæÅÚ\10Ã]4-\ 6_¾Òh\ 6\8bï#J\f¼é¡ÙZDB
+b\18>8\8f.\ 6\7f\ 4\9c°\8che#­\fáR{\ 3ÏÓ"\ 3S\94åñdÈmüïý0\81\ 1îqÃd|\91ÿ\97¡u\11£\9a8#£\84\94ò\ fÿI\15½Îë%\8c¬Ù%,±ð²í=\17ùí"\9bý<L\98\14&>\81\83\9cVù}\9d\ fY\.\10\a\19§\8b\99\a¤Ê\96u\95Oë¼\,\eXÂp\bG\8cx\ 4\87tö0\1cÒ=
+*àÁ-\81W{s?\9eú n\ 3g\ 4a\92w!ým\818ÕÙmV\r\13©%\8f9\80Å\95\8aÏËf¢ãÉ]潹ϿesïáMY\15iMüé=;\92öü\1e´çgG\17\ 4\16b\116E+\17×e\9dÎý´ylUàïµ\8f\17Ê\e?\16é´*}Ø\ 1hj]߶ëyÙ<6Å\13þZzWó.\92þò¦\ 2b\ 5½å\8c\13.Xÿȳ£3ÐÁ\8b<Fóhÿ\94QU¥\r\89\9b\81\0¼GFÑ¢Ò£âÑ"`¢¥Ä:ݽ3\1c        !\89Pk\99'Ù<+2oÜ0Q
+`X\9b\ 2\97\ 2\91E\93\12Å\895ºoõÔ£9Ë\17·\10F       ð·7²¥¿\ 6êøI#\9e´\81ý®Ýº\8eT\a\85\ eÅèù\818\7f\15ítX\ 1\80CK;\ 1\8bAÚá\ 2Ò\ e÷>æ\15ÜÌ\17û\89ø:®\1daÊ=ykª±çQM\12ÅÙ\9aj!ð¹ Ò²0Ó\1c³È4H¤`\8cA²9fÖd\93\8ah®vS6Sé-`«4\algù4­\eâáõÃ]Þ\91\v/wã\11\80!­ÚL×\918\9b\91ýi[Q\ 1Ad/®b\81´m"\89 Û\96î\1fVõý
+\0\11\16\92n\8a|¨³jùÓ~S$(Q\1aû}\ 5Õ(â(\8f¤\ 4D\9cê\17T*w\vªà½\82
+02Û\17\9e\9ah{Ϧ\9e*¦ \9e¶µÔ\17\15RùÌB*¹\ 4\1fSH%Ãðò6£_\8e\8f'\ 1:khB \91¡»2J\98Ö¬£î\ eËø      Ô%h\9c\9eÐäå\10¢\9fMë²ò\\85fM\e\85\ 2rÌïÀ<Åà\88«¡\95>\9b.\9b;&¬Nc\81#âiuò°:\ 5£m\1d\89\97\83±(\13¯QHkÊؾ\1f\9b\83\8f\1eùT\87¥\0'\19\96\ 1\83JÅ«@¶\ fÇ\eô\ 1.ý \ 5B\ 1\98\ e|§ÁÛ<½\9e\12\0ðj\99Í\ eHP\b(\86ú;%¨! ÀQ\9c\13a{
+äÊÚ\80\ 2ÅvKË      \95ö;ZZ.\ 5ß+Á¦\97E\8aÕ\90\9e\9fV¢ \12Z\83\97\ 6\84È\9dh\88ÛXûûèb\ 2Å\88qJ÷
+       \ e\16\93ÑFMÛbÚÞÑWÓ²½j\9b_\19ÏÓeí\81\10¥\89W\0\13\14Â\0µ\1aeÊ66ó\97ج\9e´Y=Ëæe6-»ðÕ¥\1f;?ä®\1fv¿\1f]\ eü\fN8¡û=\93Â\8f\86C\86P\17\7föô,<{ËÅ&­Pß©\vj\9b\ e\88º\8da0o\róù\859(sÌìä\97\8dÍ¡å³Ë«×Z}õ\16Vë¾ÕðÁM·{¼ \ fÅuþ8W·\8c        µ±êÐ×\13sØ)eßü´ùH\82±ök\98tAä+\14y\85Þ\1aô\167l}EIh^\15\15u( #\80HS\11²8Üx+É;\8bq\8a\16ãXû5`t\89\a=4\90WÉ<»©ý\86ùªH÷Ó¦opÿ«¯î¾x½Óû\8aÒ\1e\a\8fÐA)\e\aÍ\96\83¬sPï8(\81\838E\aq¬ý\9aÛq°ÊoïZ\166\8ba/õ[{y\8c^
+ö(\8cû½të0â´ñÒµaÄÉê¾­l]\fñæ\9bÇpýGÕÖ\1fVÿ\ 3K}\9b\84
+endstream
+endobj
+1541 0 obj <<
+/Type /Page
+/Contents 1542 0 R
+/Resources 1540 0 R
+/MediaBox [0 0 612 792]
+/Parent 1483 0 R
+>> endobj
+1543 0 obj <<
+/D [1541 0 R /FitH 686.127]
+>> endobj
+1544 0 obj <<
+/D [1541 0 R /FitH 668.127]
+>> endobj
+1545 0 obj <<
+/D [1541 0 R /FitH 488.742]
+>> endobj
+1546 0 obj <<
+/D [1541 0 R /FitH 452.876]
+>> endobj
+1547 0 obj <<
+/D [1541 0 R /FitH 369.132]
+>> endobj
+1548 0 obj <<
+/D [1541 0 R /FitH 333.266]
+>> endobj
+1540 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1551 0 obj <<
+/Length 1733      
+/Filter /FlateDecode
+>>
+stream
+xÚåYK\93Û6\f¾ï¯ÐQ\9e\89\19ñMN\ f\9d¶Ù¤I\93Ýé®\93K\9a\83\eMmÉ\91ì&é¯/@PkÉ\8f¼Ö\9d\93A\12\ 2È\ fàG\90Î\92\9b$K\1e\9dý<9»ÿÐÊÄ3o\84I&ó\84g\86\13ã\fãÂ&\93Yò2µL³ÑØZ\97\9c<¾¼\18\8d¥\94é\8bó_&\97W×£W\93\1fº\9e\r\18dVyð@_kT9Ë¢ÏóÉÙÛ3\ eb\96ð­;c\99\15>\99.Ï^¾Ê\92\19\f>I2f½MÞ\ 5Õe"\15Xåøá"¹>û\9dæÞw˹`ÞòÄhË\842äü"_\16£±ÐÎ¥\93\91\87\15´\
+}Rp\95^\97#\9eþ=\1a\81IÂ|\ 4Ë\94\9c3¯5Ùø#ÓÙërÝÂ/\ fZÒ1\aØôu®Ë\9bª\98ý\bÆ\95\14é\83¢\9d6åj]Ö\15a\95W3\12\9a¢]7å\14\0Ëa8¤gVîÁ¡¼û\ 28:[Â1ðLÓ|\0³ÐΧ\8f+\ 4c]Ü\14Íh¬¹\12©40w¡uzQ\aÁ¤\937EÐNËjV¼Gѧõ\9cºÖÝØf\15\ 1mÆMyó&X¥\91Åf\99\13¦^0Åw0}½¨ÃwSüâO¦\f`©h\1c:\96ù´©I\1cê³`x|Ðò9|`¬è-\11ÃKËäÝ2M·LMËÔÖvËD\11\97\89¿9ý\ 4§o\9az\19Û4\99ÐoqòákH¤êøziMBß®    Äá\9aîa§MgE\ 4´\9a\95Õ\r)\86,\82_4\82\1e²¡íUù¾X\10LóºYæë\83ðÄ\rñ\10\14m\96\1dÏ\80/\81Æ\10\ 4·Ð\98½¸Ò×ß2.Qù\11f­qÿ\ e.\87RÆ|ã¸Ä|ù\15·S&?\9f1\ eâb>¾\95¾Ã|y\f\8aÞ\8b¯ÄÅ|\1eÅ|O¸Ä|y\ 2\8a\13æ\vî# ×z\89<þ½ÓÌoH3Vÿ§é×|\ 5.OñX\12îÿK3\87\vA) ÊÓònu±àÌq\99\b\ae«q4\89gu,N\9dNÿÂ\ 5\15ÓuÝ´Ô\917¸z§Ò\16ú\8a\19uÂ\I(rB\97Z\1d@Nï\9cqpcÐ>\ 4\94¾"/Í\87ø\19a9\8b\8e\8a÷ÓbµÞ:¢DQÌ+µC»\17\93ó«\ 3xAÁì æ\17Ö2¸\aìâ%{\853\\12\9cÿ\bZJ0'\15X2ÌóX6?{qÀ¥ÉX&í)\\1aÉ2¡\87.\1f"\\97ϯ ÏT¦:ø¨\94åé\aêÝMkìÃ*\1a\7fóÅ\82\84\90Ë(Lë\ 5Æ\10ÅÕ"¯\8a6*6q<oÛp\8bÙù¬Å+T\b\88\86;!ìîA@\96]"\19ÕK$\f¾´\14|\188\125\ 1\99      ÑO\84Ñ`ØÞ\ 1B!\14\93p\91\15\ 6rF»ãQ\13\8a3àßS¸T\8a\86.»¨Ñ²o\93ü^`7
+       \ eÌëMCÒ0\82-u\96\116b!\10Â]*H!pq{HË\8c×ÃpP0\9dí\a\13Z`©lH¬ÑÓ»\8a\1a\943\18=KÑ\83éjà¯pi=®ÕÒ`à\ 5\1cÙ[
+\8e\96Õí\ 4\ e\9d\11}\9eVFnó\12dZ
+\bÓz¹Ú¬ÃR 5o°\12@ l¶\b­ò:Ý´\81~Ãwh3²M~³í^­\9a\94ù:\9a]×·f¾àX¿%%Á\fìú\18u'Óºùh®s\8b¯\13.\11Ü0cý]èÂj\90m°¤¶©\1e\9cÓ;\83ÑGw\9cÂ3@\9c`\16Bé¢ù`\16\8f.\9f>8¿8àÕ\ 3qdê\14^½g\99\97\aÖ\1e\8f\14<\91Û°Ý0\11\ 2&\98\19\8b¢Ó\19°UÌäm]\ 2<2Ì\82\12\93Qp°:í6ó\8czhw\bØÕ+ äÕ¢,b;ä\15(lÏIlí>`\8cmæ1qTH\1cÔ\80\90\9f\83µ\ 3\91ÃG5o\80¸2Å,Ìòë1\94\12\8e\19­\82%ØæǹRj\15øþ\ 4.5\9c\91J\ f]n¹\12W\1fë\b\ 4pXG@4Cx\84Î\18\9c\90;t\87·0³\r«ïª\19D2\846ôa\14Qo\18E\1c¡ª\ 6\86zU\r´:µ\11'SQ;ò°7ûµ\8e\91<}^í\9aßý`Ë\8e\a\18§)¦EÙM_HAü\8f¬\98ç\9bÅ\1a\e<<Gfôê
+eß\16\ 3ÆñÕõ\87ýwYÅ\94pÝx\16^3\83õí±Mí9  |ë\7fµi¨Ì­[dg\1cÃ\82\e\87\88\9c\ 3Ëö¦Ì\a7\13\10\85Pz        g°\1c\9e\ 4½"ô8Ñ^ÔUØÈ\8e\1e"\r>DR\88Pn\8ae^VT\86C³«LAÜ{m\84¾i¤\8b­~\17»¶3÷vS\86JØ «L1\ fö¿Ù®êP¹:(­\ 5Ø¡ÓK\18\13\91\ 2¡EÃë¦Kµ|Éh\e\0\1f\ýD*½j\19\9b3j\16Ñf\85·ã5É\9b6êäÔ¦   \8e1Jñ\9eÒæá(E\9dUS\8c\ f%â¬\8cU\0Ô8ÄsBÈ´\r÷/ÑáÒR«\8a½Ý\16DyPIôl\88\92\94\9cY¨¥¹\14\fèéNä\86\e\82%(\90bÚ\â\19\81þ?5\11% ¨ÏÌ    &\ 2\11dÞ«áD\8e\1d\90Êà_\16î\14n-°dDr¸þ\90£\12®\1a\90·»%|/ñ¥¡\1c\92Òv\ fñfË?ØÛ§\v\1c<ÆGX\9fjí?AHv\87\90ÐÃ\1c\13º!¹ÇËÒîÓ®Ò*\9d \a\ 4\8a\a\8d|ÑÖ4¯²\9a.6qQ6ÖÞÐM´ÐÿGª÷ÏÔ?jx\97\84
+endstream
+endobj
+1550 0 obj <<
+/Type /Page
+/Contents 1551 0 R
+/Resources 1549 0 R
+/MediaBox [0 0 612 792]
+/Parent 1553 0 R
+>> endobj
+1552 0 obj <<
+/D [1550 0 R /FitH 686.127]
+>> endobj
+1549 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1560 0 obj <<
+/Length 2173      
+/Filter /FlateDecode
+>>
+stream
+xÚí\19Érã6öî¯à\91®j!Ø\b\803'¯\99¤ÚvÆÖtMÊÝ\aY¢lÖhqHÉ\9däëç=<\80\12EÚn·Ý9¤úbayxûJóä6áÉ\8f{\87ý\1fN]\92³ÜH\93\f§\890\9c\19c\13ã\f\13Ò&ÃIr\9dZ³ÿiøó\ f§VmCæ\9c©Ü\ 2\1a\ fsô¯\83_\86'\97û\ 3¥TjÙþÀZ\97\9e^\1e\9c\9dÐÑñÉÑÅñ     âÙã\81x\9bò "\1cH\v\87\8aÐÞÌ\96û\ 3éÒñ>üù_\r¸,O?\97«;\\89t±¤\931AM\8a   ígëù\88 \b\81E\ 4\16\10¼ÃÓ<\1dÕt»º+þ \17£ª £1Á\aT"-\17\ 4ðÓ9\8a\87ü\9f\f÷~Û\13 \ 2OD¢µd*\93\89É\1cSF'ãùÞõ'\9eLàòç\ 4\ 5rÉg\ f:O$Ë]\ e«Yrµ÷ï®êµÎ\98ÒÂc\12\80ÉË\7f~qö\81èÏ£\88È\ 3(Éif¬\ 6µ      \96gYÐ\16j  \ 5R\1a\0?r¡\17û Áª\.\98\7f&4Ëux\ 4\9cùGû\ 2\r\85\9aö\8fH,\81?\a\14\8dÒL\vñ
+\89¥\11Ì\ 1;\88I\ 2\ eÈÛ%isƵy\v\92N2®²6É÷\aWC\12\98<)»2\8a      mß\80\11e À\94y^vå\14Sʽ\ 5I\88i%mWvI2¯ëà\b«\8dG ëÐú\ 1\18\ f\82ûÉ\8c\99,o»ßjYí\ f´0é´ZÎiåQiaÓÙ¨^ÑÑ|4®\96´lG7\ 1\19Ç\98Ãûí°Æý²\9a\14\15\0\bÚzkmQ1)J\80!Ü\\ 4B»ÔQ\ 6¾\13;-^ Od<O+\8c\ 5\91Þû\94P\8c\ 3¦\91böÇ>h\ 4a\ 4\aâ#Äm5ÒÅÇ«Q¹ð\1cÛ,\1dÑMT$®\83"\11/)\fÎî=éeIïËÅ-\1d{öm0\b¢»¯\8a\87r¹®û\ 4\98V£y\ 1\89×ä\1ab\1a\11\ 1\9c\97y±$Õ\16¿ßÏÊq\195\11y\82\9bÀScÀEá\159\81ìQ\13DÔä\8dç4\18uRìZh\1a1\0Ëu\80Úä\15ÖÇ÷Yð\a©ºÙ\1e\ f[$`ï\9d\ 3~!D\91ÇË\ 3ÚÎcÞÆ­N=\1fp¼\\14a1¥_Ò%,~¼x\7f|r¾õ8¤>Üûj\80h\16ËU\8bgC<\83¥ë\12\17    e¨H(\94º¬iu_\ 5Q\8a\1aÄ\1eè\f\18\9eÒÕh\11\1fÕkÈÑf\\16dw:öëõ\1c\1dí\86ü\ eŬèr\19p\84 Âe·DÂáÝ\bwdÖ\0F\86\ 3R=6h×Ï,\14½\8c´ç\17\82\80à\11w\ 5­)Gúë\8dþ°Àº\fµ¼\b\ 2
+\flN\8d\ 4$\9f­\94Ì\1d³\ÆFâ\9f\ 4Òª\8cLK\17ï9Å?bÜöZ$åu\ fç\90È\1a9êU1\9a\80\ 12(¡§ûN¡cP\ 6\13\90ÊU[\r15\81á{\Q︢\ e®øx¥Ì-ˤJ²\8c3+_Ó\e(ÎY&¤Ç\94Éì\89j!,³B¿\ 5I   \18¸j\93<Em\üç\92Än¬\ eF×ÚÆÐÒít\ 2ûP\ f¤Þ\80¬ï)ç\15U¨(Øyr(\88-\83Tåí]\13\1a:\9d\81÷Qg§t§x`\97Iѧ¨\94QþzGÐ\ 5ñ´\bpS:%çÄ\a\evZ4Õ\13d(;ø\83\8dc<Óg!pL¼\88a£©À9õ¡¾\7f\8bHA\88 \8d\87 eâªáÞ\17©U\15\ 1Gá~\14pN\973\10\ 2P}®ÿÑêÀ!
+\985ØrCWä\ 2\9f\82µa®¡\12òô ®ËÛ =ì\19\ 4qéKp<\93AcTÌ|\8f¾á\12eÍ ùÍÖ\81é'ó\ 1\8c\1a\alW,\b\ 5,À©ò0ÆÈ^Á.!? C\1c\92y*\ 6\8a\v\14º\b÷%èw\81iyUÜ\16\15\ 1\93\8a9Äâ\19\8c7\98èµJÏ\97«\82\8e©7@ÀX\19\ 1ú\ 2ïÊ\ 1*ÞTÈ\8aw\1f0ËNjÚö_\1düWÑü\83.\15Ë\81Þ\1dxè¾*~[\97UP|\88\9f\8d\eªv&E\9bEd±ÚãávµßUxàØ«;ÔHÕ«î\98\83=Æbä£ê\8e\88aQ-Ækßd5D\83¶¢Ó@\1d¢Q\94o\8f¢0\83YÝxÌü¦ìú\fp&¤\88 \9b\18â!\11,7NI\8fu¾íq0\92r\1d_\9f\9f\1d^\ 5ÇÕ­\96\9ee¶!ñ\91GïÞfï"\88@×íD¤æ~\90\12Ù\1aùÂ×£Ò\9f¦=\1cÃ\10\8dãa tv\88îyÕå\a&0áL\ 4»îQ.f\b÷¤j\85a\rÀ§v\82´\e­>6Qe9Ó@@+É´Ê_5Q\ 1\86ÌzLR?Q"a\98ÄÑå\r(Â0i´kQ\8c\15²Ï´ÂX\18c%.\18\8f%µì\r\93÷\85Ï\e2=Àú%³ôÐÿêô(ì)ñ\ 2À1þ¨M«¨b\8f\8b\97åbR\8e±©ÅSÊ_~Ùê÷\0Î\ fV}Æ\a7âªùÈÓk}\98áMãh¾O\ 4\84\81\ 3E_bÂÈè\18´\86íFºÛ¼jGÝ'ô\131«ÁÑN\15îr\9a;f¤|ÖOy\13\9f¨Ç\fjeU\8d\16·^\ fD\19+\7f ZÁÔè\13=ðâ5\84ùݹfº
+(\ eB\ 3#2¨K;iÛ\a\82\89ú0ø9iRüNg^L#ÚÆ\80=\19Ã\83xu\1a\11\9fËn7²\85§\ 1
+ÅÞgÑ\80hVLWÈ®qéá\86£\9eI`÷-\ 4\10½£h>z´w¢}¤\85¥&¶\aÇϼiht
+\v\14r§ýo\9e\a\9dö\87L\7f\1a\84çºñßCü\ 6yÜõ\fhq\85j<ãúàÓn\9b·\18üYTËÝxÆO~Ö\ 5ÞÂ÷\94\83\8e\13\\bg@ü±i\r£þ,\1c5ó8¬;ß\b\f¾\89»³\ fÿ%\14ô\11Ä\9fü
+\vð\835b¥>"c\12\8a^û#M4ÁfB\9d¬«¦Ä×ãª\fU?\98®\f\15~ÿXúñ1äÒê6¡Å¥\17\94¾üfl·H¥\1d\9bj\bDÓ²éáSMgO=6Pð\e\83\9d}89\1aö\147\r\89Þf\1d³>Õ\90¢Z»-©³L|yGê\r!ýÀÛmL¹a"ÏÛ>S>âÑ\17Àiõ¹¬\8b\18M\8f©#Ï l©/R\87~\91:úúsã\18·î\95í¹e2o{@ùð\82¨Î Û|iT\1f~\8fê¿cT\1f~}T\ 3¹Ì½MTã\0Òv\99\87§Cú\99\88v9ËÜ·PEoDì`^;pk&D»N?\94ß8¢\8f¾&¢¿\aôW\ 5´øë"úè5\11í6ÿ\92\91í\97E´cZÈ\1d\7f._\15ÓP¥aFø\ 6Êx$¦·\86\9d¯\8cé\9cYgwÒZù\92ö[  &­|aX\1f\7f\ fë¿cX\1f¿¦ýVB¾>¬ãïÉpïÿ\a°VÌ
+endstream
+endobj
+1559 0 obj <<
+/Type /Page
+/Contents 1560 0 R
+/Resources 1558 0 R
+/MediaBox [0 0 612 792]
+/Parent 1553 0 R
+/Annots [ 1554 0 R 1555 0 R 1556 0 R 1557 0 R ]
+>> endobj
+1554 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [396.068 337.48 418.54 348.328]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+1555 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [396.068 269.563 418.54 280.411]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+1556 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [396.068 201.646 418.54 212.494]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+1557 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [396.068 133.729 418.54 144.578]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+1561 0 obj <<
+/D [1559 0 R /FitH 686.127]
+>> endobj
+1562 0 obj <<
+/D [1559 0 R /FitH 520.509]
+>> endobj
+1563 0 obj <<
+/D [1559 0 R /FitH 497.922]
+>> endobj
+1564 0 obj <<
+/D [1559 0 R /FitH 466.425]
+>> endobj
+1565 0 obj <<
+/D [1559 0 R /FitH 443.74]
+>> endobj
+1566 0 obj <<
+/D [1559 0 R /FitH 425.679]
+>> endobj
+1567 0 obj <<
+/D [1559 0 R /FitH 376.377]
+>> endobj
+1568 0 obj <<
+/D [1559 0 R /FitH 361.833]
+>> endobj
+1569 0 obj <<
+/D [1559 0 R /FitH 336.441]
+>> endobj
+1570 0 obj <<
+/D [1559 0 R /FitH 321.897]
+>> endobj
+1571 0 obj <<
+/D [1559 0 R /FitH 307.906]
+>> endobj
+1572 0 obj <<
+/D [1559 0 R /FitH 293.916]
+>> endobj
+1573 0 obj <<
+/D [1559 0 R /FitH 268.524]
+>> endobj
+1574 0 obj <<
+/D [1559 0 R /FitH 253.98]
+>> endobj
+1575 0 obj <<
+/D [1559 0 R /FitH 239.99]
+>> endobj
+1576 0 obj <<
+/D [1559 0 R /FitH 225.999]
+>> endobj
+1577 0 obj <<
+/D [1559 0 R /FitH 200.607]
+>> endobj
+1578 0 obj <<
+/D [1559 0 R /FitH 186.063]
+>> endobj
+1579 0 obj <<
+/D [1559 0 R /FitH 172.073]
+>> endobj
+1580 0 obj <<
+/D [1559 0 R /FitH 158.083]
+>> endobj
+1581 0 obj <<
+/D [1559 0 R /FitH 132.69]
+>> endobj
+1558 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F11 573 0 R /F70 508 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1584 0 obj <<
+/Length 1702      
+/Filter /FlateDecode
+>>
+stream
+xÚåYKsÛ6\10¾ëWðHM-\ 4X¼ÓSâX\8e\9d¤n\eM/®\ f¶L§\9aÚR*)¯\7f\9f]\82¤H\8a¤ÄDéLÝñ\8c\ 1\81àîb\9fß\12<z\17ñètð|2x2¶2òÌ\e0Ñä.\12Ü0g|d\9ca\ 2l4¹\8d.cË4\e\8e¬uñ\9b\8bÉÙÅ/Ã\91\942þãäxrñûÛáÕäüÉØ\95hàCf\95G\ eámK[\ 6\99\8fÑ\b\9cbÜ8\9cX|W\86ݳϬ²=º\1ciÎã\8bõ_ÉòÓl\95\1c\ 5æ׫ÕìÝ<ðFV\eæ^3!tÎû\r Ù ¢òÌØb×å\8b«@\15\99ÐDÅ\1f\87ÚÄ×÷\1f\92°þ'G\19\ 2\15!Jd\8cc LNæç\ 6>L\81Ë\9fs$#j§\e\81\18\e\8d\84d^g
+oÖÁÙ]Ãy\ 1pZèú×ñ¶\fÂ1i ß1[\85#ñpP:\99z
+OSÙ\9eÖe3ÌpW\15íY£h¯\93\ 3\e\9fÐ\80ª\9bß\86É8,ß\fÑÚq\12Ö\82\96qu6¿M>\87µÙ<,M\17éÎÛ${\7f±¼M\96áÑâ®öúb\9e\11¼¹\ foM\87øïï\9c\19  Í\0ð\ 4\ 2O Ã        2#Ëøázº\\ 45\ 4
+\96\94\ 2>¾[.\1e6n±m|\81\96ã\18<\99b\8f³-<2Ì[éh\8bÅ\18BæLy\156Ýl\9bÇ2  2*í!Ý5póLZèÅlÙÄÌÊ
+³÷÷×ód\95\ 5Õ2Y½\ f\86\9a®g\1fI\99Éý\97¡\93qÝi\85Å\94 LÕ3\9e7zƳ¶@U\ 6\93\84è\19¨'Y \16\90\94\9aqn{\92\1c·Ç>9ÐHhÃPg#e\19(\b/QÔ,\17\1f
+C\95ãѧÑF¾¡\¾\e AZÁ\99ð\11\ 5§ÛC`U\büìªÁøh\b:zÙü\9f\9bÌ_uµ\9f\9a\12(Ízêðy£HÀ´\87]"¡É0\83î\90      ý\f\19:\85\13żR½ôuÜ"\1c\86î\81Ô%÷R\97*\97\9bF\v
+¥·E\1a\9cL\ 6ÿ\f(Px$"\90\18æBEZ{¦\9d\8d¦\ f\83Ë+\1eÝâÃó\883é]ô)Ýú\10\91ãjCFº\8fÞ\ e~\vžR§Q    \9e\e¤Å\19\98̵նK;\91\96\18à̹"\0@6$)Ìe\14*eço(\8a#a\14æ*t\r¥PÃy¶j\89\94s!\9eì\9eñä\ f\eOYÝøÒä \9c\a\ fÑÿr@µË¤\98%}uË\94\ 6\14\80ÿ!\ 1u\0}\1d<¢Ê2Õ"Ê\ 2\13(\95F¨ µÜ\15QB\88\8e\88Â"a0\9dkDÑ\1c\WDY¬%iD\89zD¹\96\80*¼_\8b:Nsäú2\0i\91'\8fY\ f\10©Ñx¦?\88\84*\88\84\9d Òí\ 4\91à\15\81Hð¡È§\93qX.@$­¥å\9aV\11DΦÉ*¬\12\8c¤Å2\8c¤õ\fFÒ#\82\91\15\ 2\81ìb½&¸\97ómÃ\8e\v\ 2HJÔ ç*,¦Üq\f¤q\92!LP|\v£Òã\800ó7\1a0\9f1\98\98¿\17`\1a¦8la>\84| };ä;ÊÐ\8fõ\98OjZ\b\861&>¥Án~¿\fÃÆP&\83ë4Ù\18ÊØ *\¬\18Ê\14x?\9dÞ\85­\ 5\81ª¡\8c)\fÅ\e\8cDî¹e$rÖ´Óh\ 5õ\16Q©Ø\13Óë=`¶®ª¼\1fÊÆ,"­x\14(ûtO\94-9B\12¹\13eK\81ù\15öA\ 5\8eaN\1fa\1eåÿ/\94]\87\8d\8eY$%=\96i\8c\93®"\875\f­ÑQä¸g\ e\85\97N2%³ò\ 5Û6Â\1e\11\8cj)r\95 sÌ{U­r\8d°\91pªÓi\99sÞtÃF<\84r{:\bá ò\10ÛË\1cß\89\eáp8h\1f\17\11;q\10\82\12\8d©M"8w¦ÛC0©pèð\10\r\98¸$\8e\1a£Owy\b\97öp0È\0S`«0è¸w¾tî\e¿ ´¤K\ 4äRôij/÷H\97\çùRõÊ\97î\87äËGÖegé\92p<\ 2õ\1déRIÙÕeó\b
\15\b
+«^ÏTéºS¥\93>K\95zwªô? U>Ú\8e\113%`»\ 4Öáö\9d©Ò[×\9d\13\b\18Ç\1c@\97\87\bk\ eØ1Òµ\81ÈR¥Î;Æ>-#:\ 3Wý[FYn\19ñ¯µeô{ß;\0\13êg<Äã£ÐÃ\9d\1e\95{H\aik\82ûnÒÏüIø\11:\v\9cÌ\86"κ\93ô\18\96Wº0ìÖ\8b\9ap3k8)ú\8b)v¤­\r\12\9d\86+\85ÐÚ¸M\ f\8a¤­\8dkëA\10£      +võ bWß\87ý\1d:\83 =r\94O\94:\11´\81\90µK\ f²\8f\80Ð\1e\89Íå\88¨·QM\1a\ 2\89\b#\17ø¡QEXWó\rÔ\a ì\1a\97Ëëù»ô¢'ðE)Ö\8bðky½Z§÷>"Ó[Þ\8e*\8a¯\86n\14³l|\96\12Öñy:ªøUö»Øð:\f\9bË(ü\11*,Nfí\ e TÙ×[<\80\94<\80HV.³ðw~\99EÓ»\rû\ 6\ f@}*èç\ 1ËF\ fÀ7øãð\80­î\18Á¥ðúQtÇg\9dpoëÛ-}\16¢Ï}i\14\98\9eMK]\8f\b÷\8d¨%Ûÿ&h>ï­Eºzªä\92½Û¬--¢Ù¥ªjñEO-"\10öú\e¿«´¨\91àk_\92¯zª\91\10\87ø&5\1e×Ô\98\8f\88¶¾\ 2 ¸\0\96
+endstream
+endobj
+1583 0 obj <<
+/Type /Page
+/Contents 1584 0 R
+/Resources 1582 0 R
+/MediaBox [0 0 612 792]
+/Parent 1553 0 R
+>> endobj
+1585 0 obj <<
+/D [1583 0 R /FitH 686.127]
+>> endobj
+1586 0 obj <<
+/D [1583 0 R /FitH 668.127]
+>> endobj
+1587 0 obj <<
+/D [1583 0 R /FitH 653.672]
+>> endobj
+1588 0 obj <<
+/D [1583 0 R /FitH 639.715]
+>> endobj
+1589 0 obj <<
+/D [1583 0 R /FitH 614.356]
+>> endobj
+1590 0 obj <<
+/D [1583 0 R /FitH 493.416]
+>> endobj
+1591 0 obj <<
+/D [1583 0 R /FitH 480.455]
+>> endobj
+1592 0 obj <<
+/D [1583 0 R /FitH 431.186]
+>> endobj
+1593 0 obj <<
+/D [1583 0 R /FitH 342.923]
+>> endobj
+1594 0 obj <<
+/D [1583 0 R /FitH 256.21]
+>> endobj
+1595 0 obj <<
+/D [1583 0 R /FitH 243.249]
+>> endobj
+1596 0 obj <<
+/D [1583 0 R /FitH 193.98]
+>> endobj
+1597 0 obj <<
+/D [1583 0 R /FitH 167.514]
+>> endobj
+1598 0 obj <<
+/D [1583 0 R /FitH 141.602]
+>> endobj
+1582 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F11 573 0 R /F10 668 0 R /F1 667 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1603 0 obj <<
+/Length 2651      
+/Filter /FlateDecode
+>>
+stream
+xÚí\1a]sÛ¸ñÝ¿\82\8fôL\84Ã7\88ô)\978\97tâä\9aè2½ñå\81\96h\9b\13\91RÜô×w\17\vJ$EÉnì\9bÌtú\ 4`\ 1î.\16û      \90'×     O~9ùyzòÓË,ñÌ[i\93éU",gÖºÄf\96       é\92é<¹H]vúiú÷\9f^:Õ]é9SÞ\ 1\9a°æù«g¿NÏÞ\9fN\94R©c§\13ç²ôåûgçg\ 4zqöüÝ\8b3ÄsÂ#ñ¶ís0\11R2£t2\91\ e\80\8aÐ\9f±Þ§ÉÅÄp\9e>k\9aòzEÌißA¢-ÓV·¼\9d\7f<{>ý@˺¤´gÖ\99vÕÅ«OÄj¾\9a\8f T\86YïÿK\94o"ÊõM\81\1d\9d~=56Í\17\9bb\84ÂDXË|\ 6;\17\82ycîAi»Å\8b\17\9f\ 6\12\9ad > ¸4\93ÎÒª\7f\95eyL\90\81×7Ï>L%q\eÙV\1d\ 3\1c\97\88\ 1"\ ed\$çZr_ï \16Qõ¨é!µ?¸áç\1fÿI"\10¢«\83&cf«\82\7f\e\11\12Ó2Û\9dÙï§\13i\10\1f0?ÑÚ¦Ó\9b²!"mÛeÂt\98¨®vó@\ 67
+\87dmÿ°\96Õº¬ÂÎ\f \90YZÌÖU\8dc\9bÎ\8bY\ 5ô³t~*RÀ* \13\16^ÕÕ\92z\91¸I\17y³¦^ûM\11\17/6Ë\9cð]\ 2\9a\ 5ÍÎN¥K?Ó\822\92¯\ 1EQ\a^y\9fɪ\9e\175Z¨\12 \80¢\ 6\9a ¥t\89H6H\17Gùâ\16Ç9nâ[\830\ f\14Á&Ó\82\ 6ù\9aÚE\917±[­\8a'Ð32mÊÕ,®[泺\8aßïØÍÒÏM\8f·¨¡·åú\86TnU\91À\83\0\+\0½\15\80ÚC\17\80»]àhÓD\ 5^¶b$$ü)\81_¿E\9f\85*z6=ùóD\0;<\11\896\9eq'\12\93\ 1k>\99-O.>ñd\ esÀ0x½,¹\r+\97\89\ 4\83E§°H>\9cücß\9dj+\19·\ 1\8fó´Ã·ïÎ?\ eMU:É2¥Ð\ 30\ 3ØÃBTûKÔÕ1\13z\aªRß\96M\10¸öiy5âP\9cgÊîÔÿçsðÀ#\9eÄ
+&²­\15]D_Ï;+$sv»`yYîã\0Æ3.Ú%\9fð¼m°)l-5¸¡C\ 2\17\8a\9bÆ\1a\10¯x\88Ä\81\13\ 5®\1f1       ð\7f\81\9f_Þ½yqöv\84,F;á\1e\83¬UÌâIwÉ\9e\7fÄã{B»\9f\17\13r\1cÒ@h\15\ 3/?Ûé§t\10\82¨\ 13º^\ 4\90Þº\16\84w]\v\8eÁæ\ 1°®h%úJÂ\ 2\81,tÈóù\fì\ 10\12\1a\þ¥\ 6G\12\98oêbÌgÌ\8bfV\97\97a\15\8a\9e\1f\80\13d\rÅK\92­¯\13ê¼\ f
+\8b\16ç\18\bf ÉéÐ\ e\84càÒ÷Í`v\1f3\b,\8d\9a\81íê÷_n\ 6\1d#\b,ÅÀ¢ixÌ\bx\16\12\1f#5Ë2õ #\10ÌH\150YH(¢6\8e\90\94\19sÒ<\ 6I\ 5.Nè>É\90JàÙ=\1d:<\10\94à\83\93¾;59\9c      8Î4Wwd\ 2n,\138\98 í\92¡¡\9a:\17\98îå:\7f]b5!µ\e\1f9q\9cܱÌJ1cÕ÷¥VC£Î ¸\99\9eßǪ\8drãV\9dqæµûAÁÍÇàæ]ªhx4¸9Æ\8d\ f1B¨\a\19\99ä\8cë,¤\15^\1d³kå\18\98õ#PÔ\90×+ߧ\88\9aÕF6Øz¾­Â@W\15\88S»~ð8¬fXâ\19ñ=Zv·Ùî)"TL MûzXü\ fD\17yïè¢\95f\10c\1f\1e\\10\91ÊD7Õ\19ºyá\róÂÝÇÍ¿(:)\90\96\1aS -!\ 5ÂB   2\r\91\86L\bgÚL\bûÝL\bÇ»L\bG!\13
+È0\13"Èï\940ÇL\bI´%\9dàÌ\bÛ¯G¾Ô½Ì(\bù\8e\\b\19^\97\98S=JJ¤\98\fW\ 2\9d2þÿ±æp¬\81\fRø}\e\87êÝeé\9d\86\ e\88¥\f\1f\8cXºµLkóc"\ e²\85\8e­y\8aíÁâUyͼÓ\89\82â&\83\9aêû-]yº\81CL¶U¾\83µ\94\96L\82­?\9c,\b\99Inúd±l~Bû\17O©}ý¶­¨ Ú9¡úAgúþYtÛt\ 1sgÑ/½\80<\ 5ä§3¼8û~þ%\1c@&\ 3\1e\8eý\18\15\ 6,8©öÞ1t\82\86+ãÁ\96èªhäRìßE]íi?7\8c«\11í¿>¤ø¯Ç"\9a´ÌJñ£ô<\8bzîÒUµ&\80£\ 6w\12aî ògx#h\13\ 5y\88\92òAÊ\ f\9a\80IHu$×\82À\8aû|8I\8c¬ÎØ>É\97\18ÐÞýö>j\ f
+\ 2¼Õ\8azW\18fjê\17\b»\896ÁÁ\85\8ffýËÄá\rÚÈ        \1aÍ\9cߺ¼Ñ\13\14ÁÙÄ\15m\18\8c\97~¨¨Dõw\94û4¬\ 3kñ÷N|ör\fÝFÈû\96\92\ 5\92i#ïu·¯ïRøì\98´2f\8d\1a¤p\87rØ#Å®\r¹ø÷ÆËá³\ 3ä÷,Ã\9c\1d²q«£Ãúø«Â¯\ú¼Z~É×åe¹(קJ¦ßF\8e\87«\10'"ÁßV\8b¢i(Få\8b\ 5vtzUmj\ 2Ñ\ 5.Â.\17»\9b§ \1dñ£rE-]QaÆGê\84°\81Ê\86é¼.hr§ßOâ%}ä¬\17\19\ 2\1cíQC^P¬¶_Ö45§qÑÐ0¸\1d\14\vÈ6 Ø¹SÆá!\8fäà448UÍ\84{\90C\82ÜF\83¡H(ê¼;â\900\ 1°\10È\1e\81$$\0Vö)¶þ\88\91@¦7EUç$\81º\0\91À,%åM\e\9cA[ÍÞ\11\84ÂErø¦Y×å,>\9bH\91^\86\17\a\9a\ 5¨\1eæéa\14\f\ 5\96l_Y\0Ø{e\81ñ\15u\ 4DS\ 2lV=¯\a\90ø\82\0½¡2!,oèû¶*\18<PÌ\8b«|³Àç\ 5á\83\89ò\11\ 3\ 5\7f"|v_\ 3å±\9e\ 5\84»Ý\84\a*Þ>PÁTÛΪUS6ë\82
+\1d\82ÅW\13á£\8c ó\ 5\ e#$´\ 4ÍÃÊl7¿·u\80Ýä\91\ 6ª{8<\8d©Àà\8d\8b¢L¾º\ eòt¾}ìÁ.¡w\81üײÚ44ºªóe\9c $Çmy\82^°ý\9bº
\ 2ãr\ 5\87¸Ìã\19ã\82<v¶\ fP8Xäõu±ø6v[\r^¾ªÛ w\e¢%:XPµrÙ*Tx\14B\1a\8c\8a?H\9a5F\11\19¢    %mXFZO\86\ e>¡ü\83\v=\8b\8cáD¸\ 3²\19\9f\9b2\10DhPA\ 4\1fò\bF\86Ä\10C4\87Äá\ 1öi\f\80H±ÌfG<\82\ 3DB>\ 6E\a\15=\1f\90l]\ 2íz\89\ 5p|ô\83áÞ+]\10\1c8þ(CtÂä(\ 4¤ýjð.Ò \v\1ae>\94õØîÔ\0\ 6»gÕpà\19R\9a\84¬HÀ¹P5¾øF3[ß\ 2ßåÔ´þ\v§;¨Ðþ¬\10é«àÐn\83Y\92qÖxëÅ\15à¾Îë9E:DT]\8diâMü~"½\85\8a\fà\b_\94¥\8f\8f¾\b\88\81\11@{2Ãi\8ar0\9bÏÖ\e\88«\11M7æM\14o£&¬£\10îmo_\11Åàu\17a èùè\9bl\fÝ>Û½AùÖÉ\93|\83°\ 3\1a\1f_³qEd$\8b\87Hý`\1cØ9d\1c6\vW\ f\ 2[þ°x) \ 36\ 1\13çò\88u@Í\0\9aú\18$¡fР¶\1eÉ\9du\90\bãI \83\a\1f4m\85\14e\ec&g.ó}UÚÅ\ 6\944h\1c\1e\18õ¢j@°£s\10á^JF\93Áv\96/f\9bE¾."ø&v¶'\9aù}\ 2tVÝåäªÑ²*ÒU>\92Äa\95â]z¹Y\8fY\ 4ñª@ÿÛê\16°Å»\17ü}\81\7JGH\90\ eò´      (\8d\81\1f77Õ\ 6      Ïi\18\bÅ:ÿ\1cv²¢9òÿ81Û¦\13\bo-\1fgZ73Âï²ÈÛP\8bf\1f®\16¡ÝR\f\ 3*½>\93Q¡1Ì\e\9a!_D\194þ¯\11\r·\9a§\98e\10\80\ eþj\85\ 6\8e½ð\ f\ 3v\ eþ¬\0Õ\8b\0õÅúSÙ\87Ô\9f\10N4w\ 1\93PîHÉ\vñÄrÿ\18$!\9e`ÕÖ#¹µ\98`\f
+C3¤³\83\1fm:ÿstc|(8\10D^\v{Gÿ\18\89Õ\ 3Îî<)\eýO\r\1f\1e_C°
+endstream
+endobj
+1602 0 obj <<
+/Type /Page
+/Contents 1603 0 R
+/Resources 1601 0 R
+/MediaBox [0 0 612 792]
+/Parent 1553 0 R
+/Annots [ 1599 0 R 1600 0 R ]
+>> endobj
+1599 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [297.073 540.286 319.544 549.197]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+1600 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [361.974 402.894 384.445 413.742]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+1604 0 obj <<
+/D [1602 0 R /FitH 686.127]
+>> endobj
+1605 0 obj <<
+/D [1602 0 R /FitH 668.127]
+>> endobj
+1606 0 obj <<
+/D [1602 0 R /FitH 641.397]
+>> endobj
+1607 0 obj <<
+/D [1602 0 R /FitH 627.674]
+>> endobj
+1608 0 obj <<
+/D [1602 0 R /FitH 579.469]
+>> endobj
+1609 0 obj <<
+/D [1602 0 R /FitH 538.96]
+>> endobj
+1610 0 obj <<
+/D [1602 0 R /FitH 517.55]
+>> endobj
+1611 0 obj <<
+/D [1602 0 R /FitH 503.273]
+>> endobj
+1612 0 obj <<
+/D [1602 0 R /FitH 489.55]
+>> endobj
+1613 0 obj <<
+/D [1602 0 R /FitH 474.72]
+>> endobj
+1614 0 obj <<
+/D [1602 0 R /FitH 446.167]
+>> endobj
+1615 0 obj <<
+/D [1602 0 R /FitH 427.247]
+>> endobj
+1616 0 obj <<
+/D [1602 0 R /FitH 401.569]
+>> endobj
+1617 0 obj <<
+/D [1602 0 R /FitH 387.292]
+>> endobj
+1618 0 obj <<
+/D [1602 0 R /FitH 372.462]
+>> endobj
+1619 0 obj <<
+/D [1602 0 R /FitH 343.909]
+>> endobj
+1620 0 obj <<
+/D [1602 0 R /FitH 315.524]
+>> endobj
+1621 0 obj <<
+/D [1602 0 R /FitH 285.721]
+>> endobj
+1601 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F11 573 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1624 0 obj <<
+/Length 1854      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XKsÛ6\10¾ûWðHÍT(Þ\8f^:qâvÜz\92I­é%é\81\16a\8b\13\89RH*Ióë»\v\80²(Q\8aÝä"â±XìóÛ\85\90Ñì÷\8bËÙÅÏ¿\19\919â4×Ùì>cT\13«]¦­&\8c\9blVfïrC4\99L\8d±ùåÍ\9b\97\7fNo®þ¾º\99ü3û\ 3\ eÓ½ÃÎ\11¡\80q8ôö:Q\fØk"Ì\8eäÕÕË7¯®"\99Ý£âÌ\12ÊeOf\1c\92\Ð$ôÏ¿I\9b1I\84Ô\1c©§B\bb¤Ë¦Ü\0\v±\93y2e\8c«ür¹\9eL\ 5Ëç\13øù0½ñ\9f\97é^·Ï\8bqIàöþæ\8fU$\1a\fQ{Jøyä_úDìöT\99\88q\ 2\84cÄr\16Ï\×\9bm\a\87¬È7ES¬|ç\9bö\97 åÕìâã\ 5\ 3æ4c\8fÞ`\9cP0í|uñî\1f\9a\95°ùGF\81¯É>\aÒU&$\18\81áÁev{ñ6ºvߨ\8cs"\ 4Ï4eD)\1e\ 5y\rw\83\1c\94\9b|6á6ÿw3\99Â\aÖ¸a2¿­¾\ 6¥@\10F¤Ô \ e#N©xø=Uô®êZø²@%,¨¨³}\9aÛê¡öå¯à
+ç8ت\9d7Õ¦«Ö5Ü*d^Ô%\ eDÞø¶kª9î´§í ¬$T\1eÙA:{Þ\ e\ 3\97ì\98\19N´pÉ\10\97·Çq¨ÁêÖô\8e¾®ÑB\9d\7fðÍd*\99ä¹\80\10ã\©üõ:\ft>[ 9\9dÉ»uW,ã0\1cÛ®ð÷.Z·\89\eëûø½Ã\0\85õ9\92|hãbUÇo\11í/\1c\88â\86ö¿ÇÈ!cAÇÁ]Ì\1c¸ë\12\93íÕs´Ä\9bé\90É\8b¦)B \84M£ÁÖ|àp\96,\91L¢ò\17õ\88\84\96\12&w  >j|.\88´¬'\99ú¥_ù(\eX\1f ¨ØI\12¦hLü¾§L\15\ f!\86\12á\90»\ 3\rªº¬æEWÕ\ f\88\ f\9f\17\15XÞä\8b4?r\a¬\82\1f\1a?f\8fy¤-}ùtG¼~{ýÌ`Ó\10l|<Ö wj\94þ(À`\ 3lr\fÒ\9c\1aÂ\9c:\84¸\ 1T\80°fç\9dO\13¸¬Xn}KÎd&r\ 5ì}.B\8d\84ð°ÚÆëßl»ç\81¥T\1a\0Î}\1fX\ 2àZi2À<B\8dÙ\a\9f:\ f\96\ ȩYò¹~\ 2\ 3¬äNÊ\80\95\10{y3aùw@¦ä\16ªÕ\8fALÉÐÉrWߧ\82çc¡\f\f\19Óÿ\1f\0\93\10Å8Âõ·\ 1\85\8f\ 3\8a°.\ 1\8aA@Áéhòà-ì1uÆrG\11eÕqîD@bB\81\ 5\ f`|\9dÒÕ\17=\ eál\bCgRO@Û¥¨ý1©'\8c\0\r\93\8bÿ\9e8\90¾©\8a»¥Ç²de¾m}y&÷\84´ÄQõCrO@\8aH>hT 5\13\98{&æ\9e     ¹g¹ØË=  ¡ç\9eÒ§\98ñ>\85[(\ 1\a}\8aè\93N>1é\ 4§Ä\81\9f\9f\9buvÌ#\14ÜËú¸¾\9eÝ\ 2(ph7\87\15B(Û·#{\99\92J\84Ì\97¾~è\16»ª\10u\8a[`\998GÅ°(â¸[ÇÍ\12ÀÇ#
+\85:g Î\91±\1cNb9ËòËCv\ e°0\7f\11×JÿX/ã\ 5­ï\86R¥úMF\92\8f\ e!õ®z\ eò \89Ü©\8e\rZAì\vü\978DYðÛÅ=\91Ï·MÓ[¢\87\f$\18æhÏ'vl¡÷p§º\85¤tSúfLÕ)\83NWh5<>
+8çT¶ ò\89¾\81j\94\14_-_âl\14ï k'\14^/ç\9b\ 5íÜ\11àí®\bß®¿sYµèpªÆï³Ð.\9dmM¦LQ¸O\f\r³\a³1l=\84\91¬{3ï\10¶[T\89â±w\1eÏ`.á¥!Äw¾¸àÉ\aÅ\8cCM\0\90\8a¢Î\82\bÒ¹|Ó¤àñå\16\9aË°ÖBU\9aw\89\0\8d\12¨cÖ\9dõ\88 ú±\16îyDQ\1a2\e\99ßõø\89\8b\88êq9\98
+\a¥ÿ¸-b0U_C"÷"\85Á\vÜy\99\8a\9aâäðm\98"\1dý çUª³ \17\97Áóá\eê\9dÅz\87³Ãz\aÍ»Ê_½\8c\9bçØ\15Ëe\1c\80\16q\10¤ÄA\8bUc¤\ 5\96\ 6*\8cûFTSwÜ\ 2ÿ\ 4|5`Û:]\9dDèú9Êõ  \7fÖU\19\8dÃ\15TD)\ eß 1K\9b{ßøz\8e¹!Yþ¹
+\10\r£\ e\12s\91\ 4øÝ4¾\8c\85\aç4_ùØ-\14uÕ®~Â5\9e\9e2Á¤x$\19\14Ы\8dgB:"ÿ\9eù\9e\8f}9\86ìåzUT5I\90\ 6\9aÈ!\b§\a¯\1c$>LC\9eÁ·\98w[p\10öT\ e[VТMî\vhZÆ\8d»ô\92\vGêÄ"\0òØ\ 3F\13ùøx<Õ\85i±kÔ\92¹×\91\8b¼ÄÎ\1aßw¡\ 3t'ÞKÚ\10cØÙXáÐaëS-\9f\80¦Yè\83ôØ\ 3(     ù\17³\ e³3ä\17®D|\9ajx  ÌúŽò\99èWÅ\aT\rq/LÃKpÙU\9be:²)Ú¶ßí\16Ízû°8¸)"2\8e¢ú§_¸\182GÏc\8c<\ 5\10Q&a-ÐíºÙ\11\bc\16j\96ø\86M\19UcU\ 5îð_æ~ÓÅq
+e¨,E\9b\96@\16\84\ fèV¯ë\ 3\fm\92Ä\ e±\ 6Gþº¹\9aö\1d:\rÿ\0\9e\81
+=Óªh?àDÅP\87ïq¯TÆ\8d\10xpª¬>U¥OkAlduôç\ f²|\fX¤ÅÉç\80*qá\ 1ü¸\81'0è\88\ 6\89W·(ºH\81P8âËT\86]hh|øß \eñ\8fbDðoÁ£\11c%F°\8424\15\v\10C\83³þõ\1a6£Ø\fC\11,\17$g4\828\12\14q~Àû¾Y¯âþ²èÂÿ\1c0\f\172ú¨\1e^H\ 6\7f\1a÷_(öÿ\ 1ë\9f\95ê
+endstream
+endobj
+1623 0 obj <<
+/Type /Page
+/Contents 1624 0 R
+/Resources 1622 0 R
+/MediaBox [0 0 612 792]
+/Parent 1553 0 R
+>> endobj
+1625 0 obj <<
+/D [1623 0 R /FitH 686.127]
+>> endobj
+274 0 obj <<
+/D [1623 0 R /FitH 668.127]
+>> endobj
+1627 0 obj <<
+/D [1623 0 R /FitH 645.509]
+>> endobj
+1628 0 obj <<
+/D [1623 0 R /FitH 612.433]
+>> endobj
+1629 0 obj <<
+/D [1623 0 R /FitH 492.823]
+>> endobj
+1630 0 obj <<
+/D [1623 0 R /FitH 456.958]
+>> endobj
+1631 0 obj <<
+/D [1623 0 R /FitH 385.169]
+>> endobj
+1632 0 obj <<
+/D [1623 0 R /FitH 349.303]
+>> endobj
+1622 0 obj <<
+/Font << /F73 507 0 R /F70 508 0 R /F8 458 0 R /F48 455 0 R /F89 1626 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1636 0 obj <<
+/Length 1405      
+/Filter /FlateDecode
+>>
+stream
+xÚÍXKsã6\f¾çWø(ÏT\>E±·<\9c6\9d\9bxzIö Û\8a­©-9\92¼\8fþú\ 2$%Y¶lO¦\9di/1       \81       |ø\0\86\8e\96#:úéêfzõá>\1e\19b"\1e\8d¦¯#\16Q\12Ez\14Å\11a\\8f¦\8bÑs\10Óñçé/\1fîµØ×4\94\b£Á\8cÕ¹ýùúãtò8\ e\85\10\81&ãPë8¸\7f¼þuâDw\93Ûßï&hç\8aúÍû;\87\8dÁ\90k\10
+gv\92ÌÇ<\ eVhD\ 6ÕnV¥o»4GYí\fo\93ªr_³1\vü°L«ºÌæuºpJuáäõ*u\82Ù\1a$`ÄZÿ³rÂ,o´ÀRê·LçEî­,Ëb·%½;\8c\18'Lã¡\191Ìû\8b\1dè<\87\8aÒà~\1c\8b (Á\14\13AÚÝ\vf_ÆJ\ 5É\1avÝá¶L\ 6Å«w9ÝsQl\88hü=Ë\9cB/x\8chÝj¼\96ÅÆ\99§îÇ:\ 1~_¨ò\ 1\95foµÔ\84\eÓ¬þíæÉé0¹§Ã\15èðFç\85Rz|
+C\94jÍ0Ø\8cý\80ûê\0\ 2\95-ó¡\9d%¡¼EÒ§\aPçÁÃÓ±i.\88Ñ­íç\ 1\17q¢£ø\9c\8fb\12©ÖE\9f½c,*º8ìüô¯´,\ eB\19ò\88\83\ 5D+1h\11Íð\vñ\16½x\ 3¨\0R\80«]\9d}A¡\87äþæ0\1dD\0\93pAÙ\9eÿ-\eB\81\ 2o\9a\ 3\14\b\87\ 2\ 4wᦧQ`¨lQðéa\b\ 6\82\12i¢K0À$ö*\1caðã¡+¹!ÌÄÞ\97ª1¦h\82ÚC.½v\b
+\85â\0Ð\87é\93\eÎl*§nâ\82        \ 3K\12»\rþõ
+¥û\0\9e\ e8`ÀÝF\90È\9cM9HÿÖ\11Õ®\r²=HR\ f\83\16¢7È\8awÇv\15%LðKH×ï@:|\a\97\eI\183àr +å]\9eyúË\8b<DÈ;\9c$Àzǧ\8f\f\899ÿ×RU¿+U1\8fÞvÉz(T""\82\9aó\89\ 1ôH[Ï\1f&6Ó\8c(*` \88\91\1d\18g§Àø\98&P\17¤\8cÀUî×B2\9c\9b\ 3¬EùÒ\8d3W»
+7Ã\ 5À\8eR«`Wµ:\16Â8Øb0¸\ eæ0gÁ\ 2ëCi?i;±ÒÐF\96Å\84[Z¸zZªæeæ\91\ f\aå&¶\ 5\ e8>xJçuVX*¾bp':*\97#7x´÷C%(â\f¨íðîà¸PB$¦+Ä\r*\96é\16ê­/Ê^f¯\80[®³ªv"L;üui§1í´-½¨f\93Å~ÞUé\10Xb¸ Ø#¾ãð\86\8dN\ fÜÀª\91\ 1£\8ah¡ßA¦\r\9b¯²å*-\ f\11¤\80:¹<\ 2Ðü\14\80Ú\ 2!ãý\ 2\81\ 2\81*M\81p\91Gµá\1a¡$\89äYÒ\12DvUÒU\bÜ\80\16\9cñÉ
+¡8\11qt¡O\88\807Ùù\ 2Á(D©ß(¸}-\8d
+q\8aFC.a=\9c£\17í³tÊþ1\eÉ\ 36Ê|»¹Ï\9câ\ 4sj@EGP\17\98\1f\13çQ\19gx >î32Ì\98\9b\ 2ñÜv=Ôs\1d\ ef\0k$L\1c'öWu\1fW\96kQd\8bw·Nµä\8a\12\804±=;\9a\85\19R\13Jz\8c\80(T,ê\13'$Àqü|£ÿ\1fT>2\ 4\7f\ 6IL\ 1Ò!\90Xl<üÿø(àX@¢·àÌb³E?\82WgÙ\1a<\vÇý>\94\85\8a\bÝ\ 2»kZ¡ü8s0\98#C°`\vV\93:\9b­ÑõP\83Àõi²©°½W4(òõw§^äCl\8b\ 5VwIøv¢\9bê\9aÏ.Pv·9\96Y4ß´{®£\81G\11§æ òm\9dÊ<{¡LÚG`dÜó.\8a=t@ðZ&\e?D\80¥%ÞDý
+'l\157I³Ö·\8cÅÖ}°h´\9aþÅ\bãÄ\9d¯\8ft\90»b\ eífº\80*î·úºÊ<Ùámh\9f;âêb·^¸çHV§eRû·ÉÐëî\98\87\19\85\ 6V^èÔ5<):\1eö\8f5Km`6OÝ\1d\9awë7,KéÂ6\ 114\ 1¶É®ü¢Ü¿0g.Ù`\94\94þ¼eÓ¯$ع4/Â|±÷\1c\0>`D\18ÕwF¿[w¤\ 6½Buð°\1fÆ^ÌI¬ôYèÁVz\10z`}\91"\8eòæ¿  ¯M\1fàw\95\10\rL\r\9b$i\9fú\9aßÉôêo\8bç.Ñ
+endstream
+endobj
+1635 0 obj <<
+/Type /Page
+/Contents 1636 0 R
+/Resources 1634 0 R
+/MediaBox [0 0 612 792]
+/Parent 1553 0 R
+/Annots [ 1633 0 R ]
+>> endobj
+1633 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [286.072 553.612 308.544 564.46]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.1) >>
+>> endobj
+1637 0 obj <<
+/D [1635 0 R /FitH 686.127]
+>> endobj
+1638 0 obj <<
+/D [1635 0 R /FitH 650.25]
+>> endobj
+1639 0 obj <<
+/D [1635 0 R /FitH 629.771]
+>> endobj
+1640 0 obj <<
+/D [1635 0 R /FitH 607.853]
+>> endobj
+1641 0 obj <<
+/D [1635 0 R /FitH 579.958]
+>> endobj
+1642 0 obj <<
+/D [1635 0 R /FitH 540.661]
+>> endobj
+1643 0 obj <<
+/D [1635 0 R /FitH 510.219]
+>> endobj
+1644 0 obj <<
+/D [1635 0 R /FitH 472.368]
+>> endobj
+1634 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1647 0 obj <<
+/Length 804       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\99MO\e1\10\86ïù\15\1eÖ\9d±½\1e»G ý T\b\ 2\1cø\bU% m\ 1õï×ÉnB¶lð\8cêS\12eÖó>óz<Q\fê»\ 2õq²7\9b¼û@VE\1d½ñjv«\10¼\ e>*\1f¼FCjv£Î*Ò^×\rQ¨ö\8e\8e÷¿4GÓÓéQ}1;L\ fÃÖÃ1jÛ¦\85W\ f\9d|î#\ 6Ë{mi\13r0Ý?>\98vaa+Ê`Ð`Ü:,à2d\ 2½è]¯ÓÙä×\ 4Ó[P\98\12\91\86\10\94\11£º¾\9f\9c]\80ºI_\1e\14IýY\85Þ+c¬6´Ìv§¾MNº¢lËA²\1a|«<\80vÖw¢>=\9f\ 3ÚûË\87º±ÖVû\8bº1¡º\99×\r\1a\80ê´\ e¶º¼{^\7ff\87/IGIÚèt\bî_\12\17ÃÛ$éók\946Xí(v(W\0ðÚ\84\94\8e\0×\1eô\ 1\83Å\9a>¤AÔ±õ\9bÅ0·\18\8e,\96vFLµ\85õ*ØgÄí ´)ckÖA磺I\93\8boejLÚãÖ\86^w»É\88Ù*\18\8e\12Ê\r_92ü³yå¸qîÿ\94[\89r\8evÇÑ^J½\93©Ïï\99\96§¾Ì®iEê1_{ÏR\8fejïóêýVÒ|í\89§¾LíIPûå¶Ï\17?0ä¯V*¢?\bõçË\1f\99úËÔ?Êô\8f\105mrâØÐ3i\1d¤\81þ\1d»?\ 5\12Jf\15\8c\ 3`úQEc\0\98\ 5@&\0\96\ 1À<\80\7fI;~ô\ f\ 1\f\v`×Ù/\ 60"\aÆOÿ!\80e\ 2\14rÀÊ\0\18=àx\0¥zÀ        \ 1ò\ e´L\80B\ e´\12\80]c`Hà9\ 4»ç\80\18ÁK\11ò&\10\17¡\90\v$9\89xà0\11JuB\10ºÀh\85ÈE(äB\94!0\ 6\82\ 1\1e\89`@\8a\90uÁ \17¡\8c\v\ 6\85\bù^0\86\89\17\8c\91"ä]°\\84B.XÑ\89\84\8c¹`X£¹;U\8b \88fsw\14æ\10Z.B!\17Z!\ 2£\17<\13¡T/x)BÞ\ 5â"\14r\81d\b\9c¹À\9bÎXl.\ 4)BÞ\85ÈE(äB\94\9dH\8c¹`\81\89\17,\b]È÷\82E.B\19\17º|ãÿø\e \8d>Hî.`ûbgp\87á¢và\14RÐÑô\7füÏV·\ eWwóîR\82´±ïëÆ97¼®p/×\15\8f]äíâw÷æëâéÇ¢¿ÓXÝa̯\9fºï\96\ fÝÿL\8fQµx\98?Ôéõ©Æê\91{\95ó\17Ö=å¨
+endstream
+endobj
+1646 0 obj <<
+/Type /Page
+/Contents 1647 0 R
+/Resources 1645 0 R
+/MediaBox [0 0 612 792]
+/Parent 1649 0 R
+>> endobj
+1648 0 obj <<
+/D [1646 0 R /FitH 686.127]
+>> endobj
+647 0 obj <<
+/D [1646 0 R /FitH 190.884]
+>> endobj
+1645 0 obj <<
+/Font << /F73 507 0 R /F70 508 0 R /F8 458 0 R /F74 666 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1652 0 obj <<
+/Length 120       
+/Filter /FlateDecode
+>>
+stream
+xÚ]\8d»
+Ã0\fEw\7f\85F{\88¢X Ùc\9aÈ)\85Ò\12´\95n¥ýÿ?ès(\99.\1c\ eç\12<\80`       ;\ f}+P±J\16ð;\fB(¢ EpÈ
+~\83K,9]ýÐ7å\7f³\12rÕWæãLûñ춦\8e\99£bêTKlëx´/\9am:Íöî\ 4ú\9do×<<\ 1ï \8e
+endstream
+endobj
+1651 0 obj <<
+/Type /Page
+/Contents 1652 0 R
+/Resources 1650 0 R
+/MediaBox [0 0 612 792]
+/Parent 1649 0 R
+>> endobj
+1653 0 obj <<
+/D [1651 0 R /FitH 686.127]
+>> endobj
+1650 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1659 0 obj <<
+/Length 2052      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XK\93ÛÈ\r¾ëWðHUE4ûÝÌ%e\8fg6\93T\8d+\19]Rö\1e(\89#1\96D-IÙ»þõÁ£I\91\1aÎÚãÊ\85ì\a\1a\ràC\ 3èN£m\94F¿ÌÞ-goî\9c\8a²$³ÒF˧H¤6ñ6\8b¬·\89\90.Zn¢\8f±K\2_8çã÷7ËùB)\15ß|¸½»»¿¹¿}X>Î\7f]þãÍ\9d\1fp\ 1\8aÄé\fö õ^!É,\r»¾¹Ó>\12:QÚJ¤^tä\vé\80\85ê7\9d/\84\90&lêL|SÁ_ÄŧTØuY\1cçÐi\9bçÛ§ÀI$^
+æ´Ü\15°ÎÊø·s~\9cK\17·å·bÃCÌ\e\1akà-ý\807t\807Ì©8¯\ 3\83M\11È6Ýú\15òû\83Û\87üsyÜrÛj^zÊ\9b¦hx¬ÝÕÕy»ë:\ 5
+\8e²
+\91dÆ°¬û²iç\vmL\=ñ\7f¸#öW{\1e\84\9f\9b¿À¨\aêcÁÓOUÍ\8d"_£l;îµÕg¤\a½¨[\1e7Åï]\93ÿßÊíâ[¾\r\9b×\9b¢\ 6̽H㻹×qÇ\15ŦÆû\9b)ñûmP.é\ 1\1eì~Å\ fJm}ü÷3XX\1d\0\bê¶ùj?\aH\ 1ê¸Á!ÇÖÆ9ÒpW5E }ª\81²:p'?Thkâ±+x%pÖ5Ú\ fG\85%\11R6\r­G%x\ 1o\89íýù\90OirÚç´.Ëâü¸áFÕ\8d0§¬Û\1aF\82­E\WÀ\8f\86\88C\ 3FÔp^\96\1dá[Tê\86Û\9dµPùã\9c\f b\90\ 6ô\ e\96sqñ\85¨j\9a±Á>°|S~)7\9dñ6,PÉ\ e^M©ôT\9d\11ÅTÃJ\ 4¡¨\v¦æÁ-xç   åµÆÇo·y ¬\8fè^R\8daDb½ÀMW@RÒrr©r\8d®\8eÓ$#\8e^NÌEPÒ\11¹²Ó\ 29;-4ؽ`Ý\9fÂBÀú\80\8bs\ 1\17g\ 3.0¸@\83}(\80\ 2}\ 6%0X\9d[^\aäMXÐ\14ûbÝ^sA\1d\1c(³"]X£êsó¸+Å \97\ e\90\89\8b\81ù~¾0"Þ3\86\ 4ų¸µèÖ°Ê\96Wö¸\18\88'\9dû(§&B\96ã\90\ 5sxª\95\93¼\98\87ÈJØ87Å\88Á\84Z8+,K(Ä@D©U¢d¯Õ_\ 1Q8xô³ð{¦\92P\89ôª#W\ 2}Ø«øë®Ü\a!\ 6\12\ e½\f±_Hc\13\vû\8f\àÌ\ 1UûXÉ            \95L2\18ø9\ 1µC\ 1\8d\8c\8bv\8d'\17\9cä¡j\vÞ\8eÂFÞv\9d2HÑ\80\8b£'r;LcôÆ\7f\7f\13þáP¸\90F`\ 4\8f¸£è¬´\8b˧n\ f8¢l   \ré8ÓcCpZ\82àrļ¨4ü\8f\8boE]ñhï*0\13ö#WÁC8Êp*¸\vüÉãqÁS\9d\1f\8a\84ö\86L\9dé«­\97s\0±\8fõ`(mÂ\99×\9aã\12¥+Mé\ 5÷©¸7\8e#0\80ç\12²É\7f)\0t\ 4\7f\9cر\e\80Í\ 2\1fÞ\85ÙazÑàÞàG}\96\83\9d1\ 1ì÷\81v\17Ä©\8b\ 5ÛpJ\91C\8e©°f¯$м\f'\ 5\aÂÄ¡ªÃ\bF¼K\ 2v1\1d\16XòµlwL\81\0 x*3\1c¡pp²ºà©\91\88uòqà×é\84»\801'b"\87Qi8IÃ\9fÅÕ\12pG°\aØ\ fÃ\ 4ΣØT\0Àª\9c\7f\rÔ0ûÀp\k`\r(0\83ÑÒKd§¢\aÉOu /6çN\82§N¨ë\82'D·>g+(5è\80\b\11oË/]µ\82]òN\98~\84È\Vd\83\19\9eð4ª·\117þýË,úHÄX¬\8aQ½      » iE\87\ap"©°Á\ e\ fËúS\8cb\84}\7f`¿\94ö\93×ûQÖw¡ò\ 4N\97\13\8fÆ\9aÊkW¦\93Þ\85læ»<ä]\80ópêK¦6LPÜÁ\ 6º0þ¯J]ZüB\85\8bseÃ\19q`x\1a\ eÿï\1a\ 2\89Ð\10ê¹!(âbÁOÚÊ®>w\89÷þr½\10¡Ö§£\8eµþr\9ei\8c0Xï\1fyè=\19Q¡5\ 3×l\ô\v\9f¨\8c\1fOçpÀN9Ʋ¶¨\e
+ÿ³Ûåì· \85èï;Z¤p\1f\89Ö\87ÙÇ_Óh\ 3s\0Qâ2\17}%ÊC¤ ó9J,ûèqö/¾;\8d2\89Ä+\8d\89T\96\84«Ó\ 3lM\998\ 3\8d誠â\10Ý`X
+\1d?\ 2B\1cg!\15i)Ç~ñ)5éªl\eø\93SGÊÃÅÆEC\9aÇr{,6\7f\ 3\vÊ,\ 5+5ëº<\11^\14ÓÙé\15\ 6¦­KB²yÙ\12\10g\12e®-¡3ÿç\96\18aÑór)\85\19\1fþyûð<\ 1[Èl¢OÀ÷ì\96Å\16c²±ZÆ\ 6¬\ 5u\0äaj\18>TÞ\8dî4Øå"¦ h\84ýáe­ËdY\92\9a+\v/)\91[0Ô\ 1\ 1:c,ÂÞªCÉ\86üh»ühÑ\96ùq;y\81K'J\12(b´|]E¢;r\9bLøúB*\93¤ÙUaôðîñuæ\15`^e'í+3¨\8a«\16«V  9\89\96\9dÉ@+Î&5ÓP¼É\9eÝJy2¤«I³çì\9c\97\99\8aÂ$Â\9a+°î_¥âD¾y[×9Õ\18\ 1\1ag¢!\81»¶ÇÛã\84xÎ'©îA\9a´¼\84ãì{Ø\17p¯8ô\89\9fï¹( ½\1e`\97,im\9f\16H\ 4>\8a\f\85[\9fëºg¢\9d\1eÝë¡ÛÝë¡\98æÄ\v\10\80åÄ\84·^'ø\1fÅá\81Þ\7f~\1a\vó=,Ìk°ð*1Zý4\16\1ej\9a¼\97\84º\80\ 5\1aN®¿zâ ºR¨QM\rù\94\ 1\19\81\ fJçK·\83\ 3Æûw\99ÿ#\1c?\86\86|\ f±ËùW\9e\10\91X¸x\f      ð
+!\ 5\a_\86ðrC½\97°É\84{\86\8dÐCpLâ/\8f\85\9fÒTN\ 4Å\144éùÐë\9a±Ã#\84]ªß\r\17?¡æ721Ò\8c\15\f5\91Qái\11\e\93wi\9eú2Ç\9döç¢\99~T©ù\ 5®?fÔ\e#ÉcThûáK\e>ÜÕ\8b)¶ôüÆVPß\85\7fUþtÜ7ÝÙ²!î«þq\10\9b\14\94T¸Lac\14\80pàJÑ\17ã}wÃ\1c= *Õ½4~WÕ\1e»×W\10Ó\9a\920A\eÂ\9aî¿\97pÊ×b°Dòr­$¬LÒÔ¾ºl\9c,\96\84\92\89P¡nüpn_,`»òºû\83hÿ\ 3ÁrØ3
+endstream
+endobj
+1658 0 obj <<
+/Type /Page
+/Contents 1659 0 R
+/Resources 1657 0 R
+/MediaBox [0 0 612 792]
+/Parent 1649 0 R
+/Annots [ 1654 0 R 1655 0 R 1656 0 R ]
+>> endobj
+1654 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [207.821 489.948 230.292 500.796]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.1) >>
+>> endobj
+1655 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [363.268 489.948 385.739 500.796]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.2) >>
+>> endobj
+1656 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [426.338 477.993 448.809 488.841]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.3) >>
+>> endobj
+1660 0 obj <<
+/D [1658 0 R /FitH 686.127]
+>> endobj
+278 0 obj <<
+/D [1658 0 R /FitH 668.127]
+>> endobj
+282 0 obj <<
+/D [1658 0 R /FitH 465.048]
+>> endobj
+1661 0 obj <<
+/D [1658 0 R /FitH 446.604]
+>> endobj
+1662 0 obj <<
+/D [1658 0 R /FitH 410.738]
+>> endobj
+1663 0 obj <<
+/D [1658 0 R /FitH 144.766]
+>> endobj
+1657 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F48 455 0 R /F70 508 0 R /F11 573 0 R /F49 457 0 R /F14 574 0 R /F83 1265 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1668 0 obj <<
+/Length 1956      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XKsÛ8\12¾ûWðHUE\18âA\ 2Èe+\8eå\99Lí$»±jª¶\929Ð",s#\91     %M\9cüúý\1a\0iQ¦=ëÊ\1cTx5Ðïþ\9aÊ\92u\92%?\9f\9d/Ï~º4\89\10E²¼Ix\91±¢ÐIa
\85N\96Uò!5jöÇò×\9f.µ<¦´\19\93\19Oóú\97WÿZ.ÞÏæRÊT³Ù\k\93\7fõÛ"l],^¿»XÐ;gYd¾X\9e}9ã\98f  ¿g\h¦\85MVÛ³\ f\7fdI\85Ã_\93\8cipúêI·\89T\92iN\177ÉÕÙ¿'\94Ð\12o%E®\99PE\90ïm¹u\90Dh\9b.gB§ß>Ïæ\18ü\1eWéUýÝ\91p      Ï\f³Ò&sÎ\99Íópùc\96g×õ~\87\91{*i\98\81u\8ei®êuãª\7fÌæ\«,½p»UW\7fÞ×m\13ô/\9b\8a&*íÜnßÕ+:ÙysL\9bAZ¦å\ 33(k\9e6\83²\ f\9ci\92B\18\ 6\19\82\9cË7WÁ\9bÇ\16\83¥8,\15}ù¦\99       \93îÝÚu^Ûll\8dW]W\12Á7\7f\88@)t>2\85\86iE^¤o[?ÉÓWM`9\92ÎdL\98\81çÛó ±\84dÊð\9edî6në\82l³¹²"-½$pfX¶7aÜßÎx\1aÜ9W\9c\9dzsuèºá\99ÂÚtß~¢\15öü²n*wGS\93Þ´]Øså\8aHn§ìq½!=Mê)>± Uç"C:Ù\139^¿[\^>æ\8c!±Ä\ 5$@.=Ï)\9c\15V\8d\9cÂ\v\bÉAñ\9f\99Q©ÛÅÕ´k\ 4Ó÷v\1f\ÃÕØ7æÞ}\1f³L<ÔÄ0\9e«\9e¤P`©$9\rîéý&Tð\e\9d|9\94AI$c\15ݧ\99*äXÕ\8b×K¤\92.ÒU°»û\98ñbU\ f.¥£?g\88¿rs =ií\1d)u\1e\1c©O\1cYL92ämÝ\84´ý^¯çßËuØl»Êuÿ¿£\17ïÎÿÒÍÇî\9dç\1cV\91\9e\98FEº¼E¹Ò\99F\rÙ\96uS7ë°Ü¸f\8d\98÷s²%\8dûÛXÏ\94eY.\9eÈ\0Òn\ 1\8f¼;\8f\ 5êаÇ\vS\8eÒgQ*\9e[\9f'
+\13\1eã\82\15\10Î\võûÌÂe]]^o¼×\10¥\87\9d«^>.\8b2¨kJþ\18V\14¨_*O\94ÖÌ\8c°\ 2\TÄ
+Xçs\b\ 4"u\80\vdJ®\7f\ 4-¤âù)Z( \ 5X>\v0\14F\89d{.`èl\ 20\94"'\9b\98\15ÿ}\18»x\89óI¼\0\9cfY\1f»#\bh\11\928\17r¨°4õ¹\8f±\fCHA\9dú$ýÔSÓhút¯P\eÂÕ£,\1c©1\8fâ\8d¼²\7f¦\1a\1aj<®\ 5\b6B¥\80ROd\8e\92\9c +~°³ÉY\ 1\ 2\1eôáú
\8b\1d¶Û²CI\95y0+mR\19ð\93!Ãi³\17|\17Öu\1c×õ\9f\83By°;m/g\ 6U\eYéu\vjuë$LÞÿ|\96|ðä\1a=ƨ¿\83\ 3\b\8bÛ\90Fm·/\87ò㥤Zæ\v>W\88<uâº\96Ê\81Na|\17f^bCU®¤'L\11tÒAv,\8bp^E\84Ø\r\ f\84IYU\81®lÂF\v\f\91;\17\8f{\86Ázô\8e;\ e\88*\19\8e\804¹G\9a\17h>\103®·á\ 4HïoÛÃ\1a\85ZåÆ[\97Ƶk\Wnh\ 1½öas\aÂM\15æm³ù\16f×}\r¢\ 5ÕÆpÉc\emA¦]¼s\13ß¡:ågRÄ\93H»i©Ä\0@Ð)!\89æ\86£Å¸   \ f\96\ f\88
+µÑ0û\0ÃøÝum\98y\9f`<±\15\97\11|q\ 4?G"\88ú\82fÆ«LDýɾså>ÜD\1d\8c\9bÞM\18\17>\84é>\84?4ý«Q¦ í±t=
+\9eèr\84\9f\94¹#y±\1e÷\ 1;6\8aêÓq\9cëV°L\16\89\94È\ 6\94ü'r] ÿµZ=\91ëÖ0\ 4e"EÁ\fR"tï\94\8bãºó»OOï\18Nµwq·G+è\8fÎ\81Býn\ fïï\ fñÞ?}×0\ 5\12b²`\1dCÊ_*!\ 4\0\13\99\8bñ{2CUÐ\0×\8cÐB\15)\9fjÆø \91\98r¤8!\92SD2\12\89H\14¿fQF\8f\8c\9dåL\ fÍØKB\7f\1d\86"}ù\108¸Ä·\8bìÉu,]\9c\93fUEæ227\7f7s\9e?Á=\8fÜUoéb\8a=Gdæüyü\87¶^òÈ_(DM>æ\8f2\9c«\¥\1c\17ÖFWÿ\9dê«Ìæ/ú®<6O\9bMØ8Ió\93´~<ð\85\14LA\85gdoöØ\1f*"7Ld*Á\8f  ^\1ce±GÔøw\89\94ÐW)u\9f¦KúJ;Â4\90]E\80\9fªFÉ\9c:Q\v÷Ã\rà\19ù Wñ\15ÑÆòj\ 1\81a<ê*ÃF\84RÌÚ&Þ\89Õvô\81LËUÙ\ 4$Åüzø\e\85\98l·®ªQ¾  ±hã¦ÝÀè¸úÕ+RM`|ÿí\15>^ÑØe¨ö¾Ë\82[E\8e¾Æ7_Ar:ÝÅV|U\13jÒɪÜùïYºÚ¹HíVn·óý\10íïã#înï\9a*îÝFÚ®lÖ.ìùvTØx\86\8dmyWoI¶Ãv\12I|5Å\17Aÿ\r&UD-ì\ 5¥½\a\14\97CÝy\8cQñ»\12´W.øàñÖJQ\80\bÆ'z+\85\ fÚ7h;]E)\80ü®\4NS\85°Çå6r
+09\88º\9bRÇã¦\89êK\9b¥¿\1c\0´Ô\eQ£°\rÝ\92½\aÌ\9dozd\0q\1c\7f\10þ®»ï&é\8eÿÿÄ\95QÀ.2j#mÓ¿éÿº\ 1³ør\1f\17\95æý\1f\a´Ñ\8bëîÊíç\8d\8bWÊÉÞ+\ 4³6Ñe:4I4\ e®Ã\1cÕÌ\8f1puàé\9d¦Í½0\98\97ñ\95§Þ%=|\9b\15\9e·i|\1d¹\16i½þÚ\1céï\86ç\1fUÂÚÈÌF\13`\1c\94À\9cz=\1a«ºë­¹Ú#%QQ\104\85\12Ca°±0`D2ñ\94º\85´\r\e$x\9c\8e\8b\85\1d\8a\ 5]\8b;#ɦ*\14*íÿ\0\9cb1
+endstream
+endobj
+1667 0 obj <<
+/Type /Page
+/Contents 1668 0 R
+/Resources 1666 0 R
+/MediaBox [0 0 612 792]
+/Parent 1649 0 R
+/Annots [ 1664 0 R 1665 0 R ]
+>> endobj
+1664 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [391.072 396.853 410.776 407.701]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.33) >>
+>> endobj
+1665 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [329.909 153.114 352.38 163.962]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.1) >>
+>> endobj
+1669 0 obj <<
+/D [1667 0 R /FitH 686.127]
+>> endobj
+1670 0 obj <<
+/D [1667 0 R /FitH 668.127]
+>> endobj
+1671 0 obj <<
+/D [1667 0 R /FitH 524.607]
+>> endobj
+1672 0 obj <<
+/D [1667 0 R /FitH 488.742]
+>> endobj
+648 0 obj <<
+/D [1667 0 R /FitH 216.171]
+>> endobj
+1666 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1675 0 obj <<
+/Length 1605      
+/Filter /FlateDecode
+>>
+stream
+xÚíYKsÛ6\10¾ûWèHMC\ 4\ f\ 2 {k\1c»ãv\1aw\1aµ\17;\aJ\82\12©!©$ίï\ 2\vR¤DÙq\1ev§Ó\8b\ 5,\81Åî·\ fìÂtt3¢£\9fO^MN^\9ek1JH¢¸\1aM\16#F\15\89U2R±"\8cëÑd>º
+4Ñd\1cj\1d\a¯O'ãP\b\11\9c^\9e\9d\9f_\9c^\9c½\99¼\1d¿\9büòò<îp\81\15DG        \9cáöÇÒ.9¡þÔQØ|\ f¹\86=\ 2WUu±\19\87<QAZÛ_\19ÔK\83\ 4\93Ï\91R,ü
+\9cÎ\8aUQ"e³Jó1\vü\86\86ê×ÕÅí\98ÇÀ\ 6©Y>7\1fA£Hð`\82gÈ Üæ8øíÏ·\93\17¸pYØm\1fÜÞ÷c®\ 3\17A\85\93\bt\ 2}BÆH"%ê`%·ðØó\85\88\82\81]\8b¢4Hp*Ù\15N%·t±÷eQ¦kCú\881N\98Ö\80\17#\0<\8bí­¹
+%¥ÁÅ\ 2Í\ 1èîìÁ9Q\89hÌ1¹üõìÍ¡Ñ"I\84fÍ¢¬Biè\v\14/­ªì&\1fà-)\91¢å}vùjÐ\1f`غC«éû±\94AºÚúé¾B!\93\9cH¥`\90\10å\11æ\83Z_\ 2ÏòCV\99\17È*\eBA3¢eòE(°§Ca_Á\90SF\94à=\14ij À\9f\ e\ 5q?
+>\ 4¢g\81Aü¸ï§\94\12\96D=\v]SISøÃ\86$üä>úSD\94\87Ó̧\8emnÁ5þ{\96ÛäS\9b\eÀ\85\ 5¥ßT\r\94Í\11\ f`O\89Ú¥å\83pK\ 4¨k!\96DAصzL\8féñÓ=\8e\0\ 6û\16\8e\1f8 RDï6\1f9\80ÃUÖzã\ f\90\8a9\ f"«Ë\81æ1\180\96=\ 3Êgñ­è~ßb_â\âßç\ò¿é\ñç:\97z\16ç\92ßÁ¹¢ÿ\9dë\89\9c\8b©\87½\8b5\ 5û\ 3îu(\16ØÀ\8e¾Ä­Ô¾[%\8cPžâ:dßä>Ô\ 4
+ÈÏp«ø¸[ÅDHñ\88\vq¸ú\8e      åüA\97Ò*ê!ËDðÉ\94\85Í\ 5L\1f¯¹Àp\9aÉÇp¯\väî\9b\13\9c \17ÃÀ\ 1¼]Û¿v\ 1t>%~p\8d
+ãÐt9òÜ\99IJY!af·ÜzShÚ5E¤ILÛ\b\9fþ}(!0À5½vªÚ:¦Ë¦C\82\ 6\ f\81\98\8a\b\95-ÿÉÅ\0\ 4,&ª5ôÕ\80\90\0£ºWÄ\84PÝÆí;ï\8e\15\8a¶2\95\ f\86z       }(\86EtàO4qí[70âÁP=\1fǾ\89¤20éÌö\9eK\9c\fu\1dñ¡.1ÈJ[\9f¨\a\94a\94Ä»àX\94ÅÚ¯é>\ 6pA¸Þ±É\ 6Ø0"eÜs,ª\ 2%\9cÓ²{\1a\ 5E\12Ú\1eï\1e\13Þ\ e¦\e\96°=£õ%\ 4£µÇO³!£%\1d£\rÙ]BËr/TÖ/U×î !FË¡5>Ù¬\ 4A{н@\94Æ\9aõ³tB\1eu3\81\93Û$ä\ 5ys\f4\19AÚÓß\10´Æ¯ý\v\ 6h¬Pã\ 1\11c\92ÄâÑqx \9dþ|é\ es6¸VÿÉ\0|ýq@ÃÖH?©\16G1>\92Ib¸aµè»\13c_£æwªt\ 6ø³h¿Òi\13Á5¥t\10ª]1ÄÚ"hï4W        Eö\ 6á\12ÎõO\97\7fý.Æa$YpZ¬7i\9d\15\14\16\82\awC9Q\92\19Þi\9bpäa\a&oï¾\12)s\9c\9b
+§yQã`[¹½\8dI\81Rmpå,KWHiJ\99rS\9a:\rÝsbØÈл\ 6묰w\8aöw°\8e\\9d¤±>\bW&¿©\97H\0\94q\81}Íd\81Mñ½8\8bí\8d_\91Õ\15\ e榣ÌÀuèPl°\0=\ 1CS\1d\82Æ9\½m\8e®¶\eÔ³(ëæ<2\ e¥\8a\0N÷8
+²­S«ø\1d*ÌmmÀ\99WØ×X¾ð°õ\89\ eæ[7PÁÚ&W¸\14YóÅÞ7ö7Å\9fe
+\87;ÎH\9dͲ¹A\90\91\92å~ßÒ3p/»igOû¥\87Ngmå'eV×î9Y+\7fåû\ 3\9cIópèqØ\9aÑ\19\9fGÀÖF¥µ\ f\97î\99\9e\99cÿÌÌ!\a¸Wb\ e\86·µ;nEw\84A¶Þ¬ÌÚk\98\15~Xg`mTÛNÑ+aP\9aMé \ 3LgÆ3©\87D]¤Y½\lW«»1ø\8f{*\97Ý¢$
+¦)Ö{\bK9¯\90\86\19\1cäö»j\80\ 6®¢§;û»\esW\84Â\97\ f\9e\fË\89\b\räp)²9\92²Úó4ݸZÝù\rÕ N\85o\17ÖEUc\9euOíH¬²O¦êÔ\99Ø_ø\8fi3X\18´R§ùØ\15|\11M$\8eöJbÿlºNo³üÆ\17\8emw\93\9b\19\14\8fiygÑm\12[<Bɹ\r1êþO¢;ÿ\8cáp>\ 3Ç9u\95|`®)S³\f<\ 1&.Èd0\19'QPÜZ\8aÉ\91ôÚù4\10æCw·E\vÚ\9d\ 4O¹È7[Ë dÚ¤\16%ÈSU¿Ïk~Ï&'ÿ\0\92fE¬
+endstream
+endobj
+1674 0 obj <<
+/Type /Page
+/Contents 1675 0 R
+/Resources 1673 0 R
+/MediaBox [0 0 612 792]
+/Parent 1649 0 R
+>> endobj
+1676 0 obj <<
+/D [1674 0 R /FitH 686.127]
+>> endobj
+1677 0 obj <<
+/D [1674 0 R /FitH 640.781]
+>> endobj
+1678 0 obj <<
+/D [1674 0 R /FitH 619.194]
+>> endobj
+1679 0 obj <<
+/D [1674 0 R /FitH 599.543]
+>> endobj
+1680 0 obj <<
+/D [1674 0 R /FitH 579.893]
+>> endobj
+1681 0 obj <<
+/D [1674 0 R /FitH 558.25]
+>> endobj
+1682 0 obj <<
+/D [1674 0 R /FitH 542.031]
+>> endobj
+1683 0 obj <<
+/D [1674 0 R /FitH 524.373]
+>> endobj
+1684 0 obj <<
+/D [1674 0 R /FitH 503.283]
+>> endobj
+1685 0 obj <<
+/D [1674 0 R /FitH 487.065]
+>> endobj
+1686 0 obj <<
+/D [1674 0 R /FitH 469.407]
+>> endobj
+1687 0 obj <<
+/D [1674 0 R /FitH 448.317]
+>> endobj
+1688 0 obj <<
+/D [1674 0 R /FitH 432.098]
+>> endobj
+1689 0 obj <<
+/D [1674 0 R /FitH 414.44]
+>> endobj
+1690 0 obj <<
+/D [1674 0 R /FitH 393.351]
+>> endobj
+1691 0 obj <<
+/D [1674 0 R /FitH 377.132]
+>> endobj
+1692 0 obj <<
+/D [1674 0 R /FitH 347.519]
+>> endobj
+1693 0 obj <<
+/D [1674 0 R /FitH 327.868]
+>> endobj
+1694 0 obj <<
+/D [1674 0 R /FitH 308.218]
+>> endobj
+1695 0 obj <<
+/D [1674 0 R /FitH 288.568]
+>> endobj
+1696 0 obj <<
+/D [1674 0 R /FitH 258.942]
+>> endobj
+286 0 obj <<
+/D [1674 0 R /FitH 173.942]
+>> endobj
+1697 0 obj <<
+/D [1674 0 R /FitH 155.498]
+>> endobj
+1673 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R /F83 1265 0 R /F14 574 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1700 0 obj <<
+/Length 1491      
+/Filter /FlateDecode
+>>
+stream
+xÚÅXMsÛ6\10½ëWðH\1e\88à\e`.\1dÅ\96\8dÝÚ\9aÎtâ\1ch\89VØÈ¢CQiã_ß]\80\94H\89\92£8\9d\9eð)\12ûÞbß\13i0\vhp>x3\1e¼:³AB\12Íu0¾\ f\98¦Dk\13h«     ã&\18O\83÷¡ÕÑ\87ñÛWgF´w&\94\88ÄÀcÜ\9e\93\9f\87¿\8dG×Q,\84\b\r\89bclxv=|7òS§£\93«Ó\11>g@ë\97\8fÆ\83Ï\ 3\ 6]\1a°Í\8bµ!\86'Áäaðþ\ 3\r¦°ø6 ÄÀ\9bþv[\1f\ 2!\ 51\f\7f8\ fn\ 6¿÷\ 4a\ 4<+ÐÊ\10.µ?ßeú\90ÁI¸IÂqÄMøõ1\8a¡qsL\867ùS\86\87\v\18µ$\11I\103F\12¥ü\8fo©¢wyµ\84\96¹]Â\12\vè´÷Üä³E6ý)\8a\99\914<Í\96\932\7f¬òbáãO\17SìÈ°Ì\96U\99Opeéàè\87A$Ä\88\1d\18db\ fà\93\1d2m ¹%p\ 6\7fÎñÕ/£KÏg\e\8a\ 1V5\9b\17\8b\88Û°ÊfY\19ÅJK\1e*\80\8b+\1d^\16®£ÂñGÄ\ e:Uñ   7g\v\83u\18å\8b\99\1fO³IᦦÙ\14ÒB1
+?Í\97\1el\99\10ªx\17ì\a|ÚjYy¸îÖ4Á ¯Á¬Ü»¡S¦\8bY½f|L\0H\v\0J\89\1c}\rähã\e\rÍ\ e\bL\10nE³]0â·t@\85\84\ 3\ f\9dC_¾¹9\ eS\ 6\98
\ f*\83\b\8b*\9dû®ûÙÊ¡Rc[ú\85âÞ·ws\ fð\ 4·|ZúI\a\15´é~ ïK¸\13½!r
\7f;ÄñÅQ!âkiý\84ú\ e\ eË2Å\r_Ý"T\18mTÐÞ`¶ñ\18.z\8eg\ 1\7f»~g/ò\\10iY³%ÎæÙCæÏ\16Å2áaêN\ 2\ f\11Il«\8f\11\v}\1d\88%#ë2P\1fo²*Ëõct\92´S\1f\87ùb\9aý\83]\eÞ\17¥\9fËRGËÇ\ e\1e5¢]â\ e0±U\8eN®FggûÈXg;?\85\13@\11ÞG\8aê%\85\11\9dÈNac\98¥\f\19Y\19fËzÔO\r'f\83û\9a\1a&»ÜØ\r\94òÝH,aJ6[´\84WJ\81¤\ 1=\ro\zÞpåó*õAB\15\9fÖô\19"µè\86zz2\86KatXW¤ì\962=É×\94âÒ\97\bò/\9d¯0N\1c;"\85Q\9eHó-DúÒäk\95\f\9fòYü\94ÎüdQN³²&Ú\8ag\89¾Ë\9f#yoQQÍ%Ò¾¨H¦\9aüÄ®Ëxh«f­\93Û8±\15Ón\15©/ES\937Uþ»B­\8e\f\155©?Rw\98:\1aãhEÅh\89\94#\a\90 ûåW\9a\84\80n\1ckBzÔ\17\9e¥8±¦FëjU=®ðLV\84\8f)\16à*+\97¯\ f\9c\ 4´[ióB?\ 4÷I\8a@2K¨\95\1dC\ 4\19C\ 4¢(9\7f\89!âÉ\8e!\92`\88à2\1få\89$¨¹2öÇx"a\91a~@Ú4d)ãÏI\9bzNÚÔ1Ò\ 6DQ©¾[Ú8¸\9b\96´áÐ\95HhÛÒ\ 6Þ\92É-uïÞ\7f#Û7\ 6\87¹£\v²\83\85XB\8cð\95\11\97^*qL\11¦U·ª\îÓ¸ÿ\83\15+\88\92ò»Y±,i³b\99EV¼JI¢¡Âu+¡/É\1c0\ 3°\v\7f+7Je|\81\86åbµ©×\r\1d0ÿíBõ\rt<ã8ºlüG\8e\ 3að®Ãìå'Ù¸ü=®C\11\v?:è:\18\85hLÛv\b\85\17
+2\7fÍ\9e\80lqÆ\eVÐvÄ\9eH¨ñ\8aËmIC7\12+¡¼óÀÎ\1eç¡DÇyô\80æéµjsÛÜhÛyà\1c*2¶kç\81\83¢\8cû,y£Ñý\15\97\e@\r®Ì\ fÑA\ eîAYÿÚ?¢\ 4b-óônî\8c\16мZfÓ\ 3:\b·\93pÃ^¦\83\90®\1aÊ+è\eØTÛÖAx\8d¬u\10Ø~ô$aM\0\96Bp·Ê¼äÓ\80@cõ\ 3\94\90%\ 6þ\ 2ñ£\95Ðö\b!³jcOn.Î/\ 1\f\18»Kl\1a»%\f¥!Û¶[Ch\13      \100\85i\86}0Vù$­Ü¿\7f\1c»b\86\9d%`à{N\91ÚKméq\8eÃ\80aÚ¾L½\17\87øË×û\83wCÜr\ eÑ$@m7\1a\8eÑÐ^÷\b\ 4\87\ fél\91W+T;e©;0NWÍzÇ]º\89Öáâ\ 31\1c<wMÁõ¯#¤\0+BÇñ:
+ö|0\80Ä\99g\8b\19h¼·Þ÷\9dÏ$]\84ÝÊSV\16u­0ûj%0´\95 [\ 5¨úk·`B\8e1Öÿ\81£ÿ¸ÃE\ 1\87*ý«\8fôä\8cã\aÇ£¾\f6_\1a\9bö_\ 4²\0\8d
+endstream
+endobj
+1699 0 obj <<
+/Type /Page
+/Contents 1700 0 R
+/Resources 1698 0 R
+/MediaBox [0 0 612 792]
+/Parent 1649 0 R
+>> endobj
+1701 0 obj <<
+/D [1699 0 R /FitH 686.127]
+>> endobj
+1702 0 obj <<
+/D [1699 0 R /FitH 668.127]
+>> endobj
+1703 0 obj <<
+/D [1699 0 R /FitH 464.831]
+>> endobj
+1704 0 obj <<
+/D [1699 0 R /FitH 428.966]
+>> endobj
+1705 0 obj <<
+/D [1699 0 R /FitH 261.535]
+>> endobj
+1706 0 obj <<
+/D [1699 0 R /FitH 225.67]
+>> endobj
+1698 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F11 573 0 R /F14 574 0 R /F83 1265 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1711 0 obj <<
+/Length 1824      
+/Filter /FlateDecode
+>>
+stream
+xÚÅYÝsÛ6\f\7fÏ_¡Gù®fùMªok\9aìãnémñ¶»¥}PlÅÖÕ¶2In\9aüõ\ 3 Ê\96eÙY<g{1)\12$\80\1fA\0\ 6i4\8dhôýÙûÑÙÛK#¢\84$\9aëht\17\89ÕI¤­&\8c\9bh4\89nbC\f\19\f\8d±ñ\87óÑ`(\84\88Ï?^\^þxþãÅÕèzðyôÓÛKÛÚ\ 5(\88\91    ððë­q$g4p\8d\86\82Yb©\8a\86ÜÀ\1a\81T\17éxÀm<\eÀ(\8b\8b;lëYVe¡[|q\ 4Ù²ÂïI6. g¡\13F\8ae -Jl\17E\19F\ 2\892=γ¥Û©\ eËòå\9aW ^\95e Á\81Û9.÷\12~\ 10$\97ñwN«hÈ$I¤\84\96\91D)Ô¥Z-\16\bXqTEp\8eÛ»\81E\96.óå´Âa\9cf\9bi¯§\ 1=ñóë@é8\9d¯²@\9fW8~_\ 22($,\ 48p8\ fËF\ 3+âôv\9e\19 O£r\1aaçW8\85\eOf\88°Û§s\13;ý$ì0ËJ¿\1aÆ·´K\1d¨\82Z\10½öRÒ$®²¯þpÊt\8es\93\1c \16Ù\ 6GGõàú©ûy¬p¤.\90|}¸ùS\863)NLsÜx\89\9f»çhps\eÏóªv¢\v\1dÿ1Ë\ecòr.Ã\9e\80]\8f>Å}\9d/¼ÜV\821Ý#\87ådÀâ
+\a\8b%¶xFÐɾ¥ã\1a»ól9­g\9ePàa¶        \7fX9\18\16iØ m±\8e~U¹£Ë&øåÁ\0ª2k\1dn\9fÄÙæ®$f\83\9d×\9eÇW\85³\b\9eh\10\91Æ#\1fF'\ 5¶Ë"L®\9cÊ&\9e¤¸Î\84\9b\0$½×&L9É\8b\15\80Ô\1c\82\e½óWϳ\ e\ 2Åæú\98ø\vÎçwØ\ 6Áz\94lÝot:Î"\84\8cïaÃ\957AøxÊÊ\ 2\15è߶ä\8bÑÙ_ÁðÙÚ±)#\b\93,\1a/În>Óh\ 2\93À\98\98ÄD\ f\9et\11           Þ\8b¹\85óèúì\17ô\92m÷Æ\18'V\9aHiN´²(­¿oÍA D¿û+\b7\17\90â\94Æ\17ßê2Å©÷¹s>~ôjµp\8bn\11h@\8f1-\9d!9H\18\17Dóm\Îû]\99#×ÚûÝ6õ\87¬\1a\979X8Ø°C§\1f\15©\b\8b\8a\vP\11àK\84\8d\94wþ:\84\8eÁP\19*cá\9c\92Ô1Ã`\ 1û´c\8e"Æ°&Z¼\ 3\ 4´ÁFC³\13]\98 Ü\8aupqÎ\18\9e\15e\8dà66!×6á\0L\bU\1d7m\83túÕ¤Ó\12¶6 Þ\9f;vºG¦$ÈD×2\rµÓ\8f\85E\1cN%¬\b\18\85\ 3l/A5d[,m\89ж\91ë\13¥tWvÓ\8eÚ\rCf \15`f[JÆvx¢\98\9cô]eÆ_ED~PD\11\17ñÔÏð\14\ayÊWá)\ fòT¯ÂSõòlLN¿
+O}PO\13\93ò4=w^\13-ù±þ¨Ñ!Ñ\84Ê\8eëf6è NªCrb\1d\18?¨D\12\94\90'U\ 2îk\8f÷e\10þÄËÔ\90k÷@\e\9fI\19¡¼ãhyã6ÕIÕàìÔj\b}P\8dÆ\13ëÓº9sj5´íU#x\14î"\ 4\87¸ç¢\19O\92\93¹\94äÔz({جºa\87\87Èøq\99\93»b\ e\991¤o\98\ 4OpþÖeÉ\8f=ÚsÈ7\8dVÏko»1\9c\eJ\14\13\1dI»ÁJ\ 4IG^\9cb\93`W(XGÜæO'\8a\88l    5/r\ 3k\91\15±¼\13\ 3x7ÖÉFäY\99µà­öã+\ f\bk$\91\9bTï%øZN8K:Âv\83¤
+Â^ú¿
+«²#ï\1a`³c\ fûÀ\85üÑÈ£À\85¼\9fwíÁtäÕ\8d¼á/øs\ 6ñ,¾Ú\10­Å\91Æ \19ï¸\8cn0íuYÔ\12®\8f\9d3òé»îÙZ     "µ>Ò\8b$ÿÈX\ f8\ 3«\88JÔ1XZð~ð?mûìwbz\7f\18\ 3\1d\8eÏ*¬ÛÛý\95¡ûÐ4ÇnmþíÝOÀA\1as\f\9c      ÀIÙ6\9c\82vrÕÿ3\bðÓd\87²û\ f\88\ 3fRt\9c\9e`\9dK)N~)eøÇÏO}'Å\7f~'ù\89\13w<\9aþ\1a\ f\97\8c0þ¢ÊWSI붻µ\9f\ 4â\9f\888\9c«\ 5á7\ 51_\80ö ¹Bó;WX\96=\ 5,¬á\ 2UO\15í:ÔÒÛ¥½ÍS\ 2$6ÒýSä\9c$,pÆøêê\90\82o¿\1aÀ÷æ4ì>·K­~(<\1a¸µ3W·u=|Y\80Noýù\r\8c)_à\7f\9f\7f»\1eaïêcèÜ\96\ 3W\9c\9fî\7f\9a±\91 rí«ÑÐõru\v\84Â\84\91{ß5Ü\9c\7f
+0r³1>c\98u\1dÖmäkÎ0\87Z#y\1a\16jIà6\83á\9d\1fÈ«Y±\9aOÂvȺ¯àS§ë3t5`ÿÂ\ 29}\1a
\9bÊnS-.\9a¢2H6Ëð\9de§¢\9cWo\\1d_Æi\85C\ 5¨V>äU(5ç¡\b½À'\ 6\1cÄÚvV.òPí¾]áËDØÂ\91\86·\v\18W\98\7fõ¾\13Ü\95Å\ 2m2_â*¥ât\9e\8fM>T.\1a'q\9f\ 6\94ÝÎuEzí÷í%ø\82\96o\a« .å5$á¡®ì\8aù=÷^À\85Û¤ª\18V¤¯¦\9b¸ÑÞ\røã\85\16¥\99åÙ:\95\93\88¨ë\99\8eýÌÃâf¶Ùd\ %æÈ.¼\13xÊe\vÆ*kÊ8Dt3ø§|:|J§xa\16éý½»\12þã\13Utâ\8bÕÁ®&8>Ok\7fVÐõf\ 4íu6^׳{_¶\1c\11`Hx÷i\v\980Üã!¯gØë\7fãè;.ð«\7f\ 3\88VÃg
+endstream
+endobj
+1710 0 obj <<
+/Type /Page
+/Contents 1711 0 R
+/Resources 1709 0 R
+/MediaBox [0 0 612 792]
+/Parent 1714 0 R
+/Annots [ 1707 0 R 1708 0 R ]
+>> endobj
+1707 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [399.229 643.276 418.933 654.124]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.38) >>
+>> endobj
+1708 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [332.758 116.695 355.23 128.65]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.2) >>
+>> endobj
+1712 0 obj <<
+/D [1710 0 R /FitH 686.127]
+>> endobj
+1713 0 obj <<
+/D [1710 0 R /FitH 573.54]
+>> endobj
+649 0 obj <<
+/D [1710 0 R /FitH 220.797]
+>> endobj
+1709 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F11 573 0 R /F14 574 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1717 0 obj <<
+/Length 930       
+/Filter /FlateDecode
+>>
+stream
+xÚí\99ISÛ0\14\80ïü
+\1f\9d¡\16Ú\97Þ($\94\ 3¹\ 1\a\93\98à\16âN\96v\86_ßgKqâ%a\ 2\f\9e)¾ [~yzë'acoìaïdïÓ`ï §=\83\8c¤Ò\eÜzDb$¥ò¤\96\88\rFÞ¥¯uçzð堧غ¤Á\88\19\ 5j2\99£Ï\87?\ 6ÝóNÀ\18ó\15ê\ 4Ji¿w~ø½k§\8e»Gýãnªg\ f»Å\8b+\aD`$¸ô\ 2ª`\92Yµ£h\98t\ 2ªáâC'àDúád\ 4\1a\8dñ\17³\bf0öC{?\ foîÝÌ}ú\eå'¿\82Åo;3O¬ÐCè&\1eãqð\18\8eíl<\19ÅÃhf\9f\8c§Q8\8f¦©©`f@\b2BXkæwáĺ#Y:r«\17îC;ÌÂÛÈ>p&\fÃy\9cLPÁïÌC©8\8c\ 4)n¬nR\12º\f\ 4\18szkC\ fR«PQ\8a¤aËÈ\ fú_»gVj=\9e\ ¦ÈR(\9e¹Ì|,\99"\bäY\83\9b\ 6iáò}\85\ 5\ eá\ f©³è<
+GVW<±®:ßYp\13Ïíåb2\8bÇ\93hd\9f\83\1c$p\1e\8d!¨6XÎ\98óoݳrh \ 6\ 4K\8b\ 1iÅVæÜl2çp\96.µÒçÒr\17Ù©?\1d\ 1%s¿pYIUY)J©¿o\a\92ê.Ù\ 1QÁªjÆp\93\19½\8ef~2µ
+£p\98z|gïÀ\ 4áLHo\13\97Q\85×\92\ 5½\94®ç\925ÿYM'Á\bÓ¥Àí4yp"¬X\17\9có\K\«EÁÕR"±&¥\9eÕ¨#\1c\99íê4\12$7j?\vl&Cø\9a\10\13Hȼ\10¯0ÆUE*ë\ 3'\92å\ 3º\9dr¨­\19Ô
+ñã\ eñ!ËÕVà´\0¡~·×»¨í\ 5br\13.ëB\87\94ÌÕÜÔ¸
+W*·ðú²&\87à&\13ÛR¨\90Æyì¯3¾\ 4ÔH$t\992«â\15yñ2ÿ1\9a&åv!\1aQ)ª\85:z¢_ª\91\ 4úR\9cÇhpZ\13FXLêW\8c¢u˹Ë×zµ&Ï\1a\19ÍÞغ5FÔ¡\8a(\8d81EvÒZ\8c÷ÁÉéßx\96nb\19:ë°®`7\10æYX×e¬\13\fD1ÜÙ¦_ÂuÙr½åzËõ\ 6¹N[®7ÇuÇNÖ\b×Í˹¾±0¸A\92ë¦Z¬ ¢Øb\e\80Ä\9e®¯l\9eTò      ü$Zî¾ù´Í´[3U#/12ÔT16|Nµb\93oZg\9bÊUpD\84zÊAý¿\84¿òb\81\8d\817\82.\82[ví®ê\ 1«XO\9b\ fXy\1cHÝNf\88ªö_K¾7%\1fkÉ×\bùD3ä#-ùv>µÑí§¶\96]-»Þ\17»d3ì¢ÛÙ¥Zv½ö©\8dn?µµÿ¯¶ä{'äspQÍ\90\8f½æ7\94Ð\86\9fÔ\7f;akßNÒ×à¥ï'\17§'¥\97\92˱;Øû\a\1eõÕ\18
+endstream
+endobj
+1716 0 obj <<
+/Type /Page
+/Contents 1717 0 R
+/Resources 1715 0 R
+/MediaBox [0 0 612 792]
+/Parent 1714 0 R
+>> endobj
+1718 0 obj <<
+/D [1716 0 R /FitH 686.127]
+>> endobj
+1719 0 obj <<
+/D [1716 0 R /FitH 640.367]
+>> endobj
+1720 0 obj <<
+/D [1716 0 R /FitH 618.516]
+>> endobj
+1721 0 obj <<
+/D [1716 0 R /FitH 600.153]
+>> endobj
+1722 0 obj <<
+/D [1716 0 R /FitH 584.28]
+>> endobj
+1723 0 obj <<
+/D [1716 0 R /FitH 558.943]
+>> endobj
+1724 0 obj <<
+/D [1716 0 R /FitH 538.587]
+>> endobj
+1725 0 obj <<
+/D [1716 0 R /FitH 517.291]
+>> endobj
+1726 0 obj <<
+/D [1716 0 R /FitH 500.864]
+>> endobj
+1727 0 obj <<
+/D [1716 0 R /FitH 484.992]
+>> endobj
+1728 0 obj <<
+/D [1716 0 R /FitH 459.655]
+>> endobj
+1729 0 obj <<
+/D [1716 0 R /FitH 439.299]
+>> endobj
+1730 0 obj <<
+/D [1716 0 R /FitH 418.002]
+>> endobj
+1731 0 obj <<
+/D [1716 0 R /FitH 401.576]
+>> endobj
+1732 0 obj <<
+/D [1716 0 R /FitH 385.703]
+>> endobj
+1733 0 obj <<
+/D [1716 0 R /FitH 367.838]
+>> endobj
+1734 0 obj <<
+/D [1716 0 R /FitH 346.541]
+>> endobj
+1735 0 obj <<
+/D [1716 0 R /FitH 330.115]
+>> endobj
+1736 0 obj <<
+/D [1716 0 R /FitH 314.242]
+>> endobj
+1737 0 obj <<
+/D [1716 0 R /FitH 296.377]
+>> endobj
+1738 0 obj <<
+/D [1716 0 R /FitH 275.08]
+>> endobj
+1739 0 obj <<
+/D [1716 0 R /FitH 258.654]
+>> endobj
+1740 0 obj <<
+/D [1716 0 R /FitH 242.781]
+>> endobj
+1741 0 obj <<
+/D [1716 0 R /FitH 224.916]
+>> endobj
+1742 0 obj <<
+/D [1716 0 R /FitH 203.619]
+>> endobj
+1743 0 obj <<
+/D [1716 0 R /FitH 187.193]
+>> endobj
+1744 0 obj <<
+/D [1716 0 R /FitH 171.321]
+>> endobj
+1745 0 obj <<
+/D [1716 0 R /FitH 153.455]
+>> endobj
+1746 0 obj <<
+/D [1716 0 R /FitH 132.159]
+>> endobj
+1715 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F70 508 0 R /F83 1265 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1749 0 obj <<
+/Length 731       
+/Filter /FlateDecode
+>>
+stream
+xÚí\96ËnÛ0\10E÷þ
+-e´\9a\1a²»4µ\r·¨\ 3$Ú¥Y8\8dâ
+(RÀvZ __ÊzX\8eäÄNÓ*\ fn,\81¦\86ÃËË9Ã\82\82Qï}Ü;\18\92\b,XÍu\10_\ 5È4\18m\ 3m4 § ¾\fÎB\ 2\82~DdÂ\ fGq?\12B\84\83áp|4\1eLâÓþyüñ`hjQÜ\f iÝ\1a«ï\8dͦôX±jù\f\14 ±AÄÉ}+òÙ_\98b\17î\a7>
+Î"ÅX8¾Ê×?\1d\8f\9b\fÓE>ò;\99ÿx\9b¿N\17\8btv\9d§å²¨í\ e-p\8de^«M´¤/]V¶\9auVL¨ËÄ\81´)'\¤Í\10î\8dªý\9f·\85\84*g,[B\18PÈ«\10ùÎ\96ß\92|×?ûJ\87Óï7I>.`S¬\b-\ 3\14NYÔÀ\ 4­\95ýºMÙc\17{þ+]$÷\89h5HkwÒ\90ߧ!=\r\rWß¡¬§oÀº¥X)\1ccÍàT÷xã\ 48× ¸h\9eÀå¶\138ܦ¸bÀYåÇxÜ"7\1aÐk±\1eÁ²wkµ\91Þ¦V[Ó3\8fh\86¾\93\97\87\a6̯\19X^\9a߬¥Oö\96^Z`V\96ëN¶¹]I@E¯Fþ\86×Q\80±ä^\ÕáEÑ\87]ªLzÕ²#B U­\16\1f\7f\1aLZ\v\8c êR\94\14@ùî¶\19\98ËÉ\1dá*7´k3L·\99á$\99^\1650W\1f£\8bt\99\8fÜ\gFI\8aÿÓë>7á2\99¹cÂp^\16Î5¢n\vÅ@)Ñôå\13ÀÝs)Õ«qéq×1î¤Ç\9dÇ\9dÇÝ\1a\eÜ)\8f»\97\8f;åq×1î\94Ç\9dÇÝëÅ\9d\ 1Cf\ 3wÈþ\82wÚ]­\87áN{ܽ|Üi\8f»\8eq§ïÆ\9dñ¸ë
+wäq×   î°\13ÜÑ\8bÂÝCR\99ç3Ë4>\1ff\7f\8cne\82\80\8cö CqAª\88\14\8e6,*2\8bª\1a\91²hÅÒµË*BÊVh\ØZ6»TJß\ 5´v\ 1ÅÁìÜ\v\17ø'½@û\95\97 Ûn\9ds3\99p\7f6\19\90Fýgî>ç®\0\9d^-Õwö\90®@Kã»\82\82\92¼È;i\vÌ\9dm\ 1ï²+(\9f\83¸÷\a@(vá
+endstream
+endobj
+1748 0 obj <<
+/Type /Page
+/Contents 1749 0 R
+/Resources 1747 0 R
+/MediaBox [0 0 612 792]
+/Parent 1714 0 R
+>> endobj
+1750 0 obj <<
+/D [1748 0 R /FitH 686.127]
+>> endobj
+1751 0 obj <<
+/D [1748 0 R /FitH 668.127]
+>> endobj
+1752 0 obj <<
+/D [1748 0 R /FitH 653.633]
+>> endobj
+1753 0 obj <<
+/D [1748 0 R /FitH 637.595]
+>> endobj
+1754 0 obj <<
+/D [1748 0 R /FitH 621.558]
+>> endobj
+1755 0 obj <<
+/D [1748 0 R /FitH 603.479]
+>> endobj
+1756 0 obj <<
+/D [1748 0 R /FitH 581.872]
+>> endobj
+1757 0 obj <<
+/D [1748 0 R /FitH 565.281]
+>> endobj
+1758 0 obj <<
+/D [1748 0 R /FitH 549.244]
+>> endobj
+1759 0 obj <<
+/D [1748 0 R /FitH 533.206]
+>> endobj
+1760 0 obj <<
+/D [1748 0 R /FitH 517.169]
+>> endobj
+1761 0 obj <<
+/D [1748 0 R /FitH 499.09]
+>> endobj
+1762 0 obj <<
+/D [1748 0 R /FitH 477.483]
+>> endobj
+1763 0 obj <<
+/D [1748 0 R /FitH 460.892]
+>> endobj
+1764 0 obj <<
+/D [1748 0 R /FitH 444.855]
+>> endobj
+1765 0 obj <<
+/D [1748 0 R /FitH 428.817]
+>> endobj
+1766 0 obj <<
+/D [1748 0 R /FitH 412.78]
+>> endobj
+1767 0 obj <<
+/D [1748 0 R /FitH 394.701]
+>> endobj
+1768 0 obj <<
+/D [1748 0 R /FitH 373.094]
+>> endobj
+1769 0 obj <<
+/D [1748 0 R /FitH 356.503]
+>> endobj
+1770 0 obj <<
+/D [1748 0 R /FitH 340.466]
+>> endobj
+1771 0 obj <<
+/D [1748 0 R /FitH 324.428]
+>> endobj
+1772 0 obj <<
+/D [1748 0 R /FitH 308.391]
+>> endobj
+1773 0 obj <<
+/D [1748 0 R /FitH 290.312]
+>> endobj
+1774 0 obj <<
+/D [1748 0 R /FitH 268.705]
+>> endobj
+1775 0 obj <<
+/D [1748 0 R /FitH 252.114]
+>> endobj
+1776 0 obj <<
+/D [1748 0 R /FitH 236.076]
+>> endobj
+1777 0 obj <<
+/D [1748 0 R /FitH 220.039]
+>> endobj
+1778 0 obj <<
+/D [1748 0 R /FitH 204.002]
+>> endobj
+1779 0 obj <<
+/D [1748 0 R /FitH 187.964]
+>> endobj
+1780 0 obj <<
+/D [1748 0 R /FitH 171.927]
+>> endobj
+1781 0 obj <<
+/D [1748 0 R /FitH 153.848]
+>> endobj
+1782 0 obj <<
+/D [1748 0 R /FitH 132.241]
+>> endobj
+1747 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F83 1265 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1785 0 obj <<
+/Length 689       
+/Filter /FlateDecode
+>>
+stream
+xÚíYMsÚ0\10½ó+|´§µ¢Õ·z£\89¡i'!\93øF9@1Ô3\1d:\ 3¤\9d鯯\8clc°)´\93\84BtA¶¼ì>=­Vo$ìM=ìu[ïãÖEGy\1aiA\84\17O<\10\18    !=¡\ 4\ 2"½xìõ}\8d\83Aüñ¢#iÕRcDµ4nV6\97\1fÚwqt\1f\84\94R_¢ \94\9dûöMd»®¢ËÞU\94ùiá<xÑn"\bA\0RTz!\91¦\93\9f1Ç#ó\ 3\e\1e¼~È1öï\93áØF\19f\róI8J\97¶çq¶H§³$ÿ\9eÎ\ 2¢üe2MæÖr¸°\1fnÚÙ\87.Út\ f\b°\ 1\ 2\1c)àk _v\ 1i/²`k\8fÒïÚ\97å×Ä>ü\b\87ß\1eó×Ì[\1e:\b   !þ\9b¬¡¾Î"l\81      «hÄ\1aÍx\17\9aë\89\ròpݽµ£MóÑþJæßßæ\8cYÈ«ùeº:¿ \11\11PÎo/êt\1e¬]uº\18G IaÕÏ\rª\89B\90\14e\9a\8cÒº\vó$ua0hrÁ\11§¼°X6¸P\88C  b°Á9Ë8\17\15Îó\89©±kò\19¨®ó\9bìâ·g"Ì\7f¦\8bd\1f\95Z ¦õY1¹ú\1f°*|\85´  \85\vâ0®;\97\12\923éÏ\90hZu&\9bMIÙ³ôêä\e\L\95C\8e¯\e\98\a\85\84zBâÿÌÚ6º
+k/\84®,4į\17\19S}\99q_[\ 6Ó¿g^#ÁJä·»ò\9e3\ 4\e :\17úkùn\ 2(©²\ 2\84\14\ 6k\ 5\14\1dRqÒIÃ\98¤0«¬\1cRïStÛXk¨,k{±-\80\9d\rØ\14EÍ6ÁeÙ0<x/\86ý{q\10\82?/jèzÏÚf
+#Îi½.\1c.\vè3È\ 2ñ\92²\0¨Ó\ 5ÇÕ\ 5Üé\82ÿB\17\b§\v\9c.x=º W\ 5ì\18ª\80à\93Q\ 5â_T\ 1;uU@`\9f*àN\15¸Ó\ 2§
+\9c*x^UÀ\9d*8Îi\ 1?\8a.\80óÖ\ 5üÔ/\11¨t§\ 5N\178]àn\11ÜiÁëÔ\ 5â(º\80\9c÷-\82~\1a]P´QÜú\rt\ 1Ì\f
+endstream
+endobj
+1784 0 obj <<
+/Type /Page
+/Contents 1785 0 R
+/Resources 1783 0 R
+/MediaBox [0 0 612 792]
+/Parent 1714 0 R
+>> endobj
+1786 0 obj <<
+/D [1784 0 R /FitH 686.127]
+>> endobj
+1787 0 obj <<
+/D [1784 0 R /FitH 668.127]
+>> endobj
+1788 0 obj <<
+/D [1784 0 R /FitH 653.743]
+>> endobj
+1789 0 obj <<
+/D [1784 0 R /FitH 637.928]
+>> endobj
+1790 0 obj <<
+/D [1784 0 R /FitH 622.112]
+>> endobj
+1791 0 obj <<
+/D [1784 0 R /FitH 606.296]
+>> endobj
+1792 0 obj <<
+/D [1784 0 R /FitH 590.481]
+>> endobj
+1793 0 obj <<
+/D [1784 0 R /FitH 572.672]
+>> endobj
+1794 0 obj <<
+/D [1784 0 R /FitH 551.433]
+>> endobj
+1795 0 obj <<
+/D [1784 0 R /FitH 535.064]
+>> endobj
+1796 0 obj <<
+/D [1784 0 R /FitH 519.248]
+>> endobj
+1797 0 obj <<
+/D [1784 0 R /FitH 503.432]
+>> endobj
+1798 0 obj <<
+/D [1784 0 R /FitH 487.616]
+>> endobj
+1799 0 obj <<
+/D [1784 0 R /FitH 471.801]
+>> endobj
+1800 0 obj <<
+/D [1784 0 R /FitH 455.985]
+>> endobj
+1801 0 obj <<
+/D [1784 0 R /FitH 438.177]
+>> endobj
+1802 0 obj <<
+/D [1784 0 R /FitH 416.937]
+>> endobj
+1803 0 obj <<
+/D [1784 0 R /FitH 400.568]
+>> endobj
+1804 0 obj <<
+/D [1784 0 R /FitH 384.752]
+>> endobj
+1805 0 obj <<
+/D [1784 0 R /FitH 368.936]
+>> endobj
+1806 0 obj <<
+/D [1784 0 R /FitH 353.121]
+>> endobj
+1807 0 obj <<
+/D [1784 0 R /FitH 337.305]
+>> endobj
+1808 0 obj <<
+/D [1784 0 R /FitH 321.489]
+>> endobj
+1809 0 obj <<
+/D [1784 0 R /FitH 303.681]
+>> endobj
+1810 0 obj <<
+/D [1784 0 R /FitH 282.441]
+>> endobj
+1811 0 obj <<
+/D [1784 0 R /FitH 266.072]
+>> endobj
+1812 0 obj <<
+/D [1784 0 R /FitH 250.257]
+>> endobj
+1813 0 obj <<
+/D [1784 0 R /FitH 234.441]
+>> endobj
+1814 0 obj <<
+/D [1784 0 R /FitH 218.625]
+>> endobj
+1815 0 obj <<
+/D [1784 0 R /FitH 202.809]
+>> endobj
+1816 0 obj <<
+/D [1784 0 R /FitH 186.994]
+>> endobj
+1817 0 obj <<
+/D [1784 0 R /FitH 169.186]
+>> endobj
+1818 0 obj <<
+/D [1784 0 R /FitH 147.946]
+>> endobj
+1819 0 obj <<
+/D [1784 0 R /FitH 131.577]
+>> endobj
+1783 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F83 1265 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1822 0 obj <<
+/Length 924       
+/Filter /FlateDecode
+>>
+stream
+xÚí\98KoÚ@\10Çïù\14>.j\99ìûÑ[\9aBD«\12©á\96r Á\10¢6H@Z)\9f¾³ø\81Á6\90BJH}\89×d¼;þÏë\a4\18\ 64¸8ùØ99m\1a\118p\9aë 3\b\18Õ`µ\v´ÕÀ¸      :ýà\9a\180P«\ecɧóN­.\84 ç\97\8df³uÞj´;WµnçóiÓfvA\v0Òá\19óç\1dó&'4>5¹\ 6uA%PË\83:7ø¬\88¬¿SEoñÏòCÁu]QJΦÓÑð!òáëY\8d\er\11ÝÌîÂhñ«¦\14éýx\8coýnÞÐzCÎ9yç/\82\8f\80å3ê\f\185xQ \8d\¸Ó/s§5\88N¹j]´ýJ\92Ñ4úä)\9c\8cßGË^äó\%\14%#6sÀ5Kd\9akZ ¦TÀ\ju\1d\ed£ÆÁh\9b\18Ü\8cò[àʤáè\16m¡@   \95
+¶° \18O·X\12]zÑuFô829u\1d\ 5&\¬¯Zè\e\96é{\89'L~\8f¦á&)\9d\ 6éÜVJòMJ\9aסäü9&³î[px\14M\84£4¿¹É\16^\9cø«qà\\82.ÊsÌf,ò\rµ\97\17\1fý\926}åN«@yfñ$·Ç\1c^/Ûª{\19ÙJݳ{Ì\8bL«á$ße4CÁD¾\ e\86Ï\97Þ\81\96©çí²ÄW\12\982ÿ\8dü¹\84Ç\ 3¬±¾\ 3\81V.²b\ 6¶i9£AÁ;\19\8de\96¾Òå\97F»°Ù\b\93¶íd.pña5\e(vE'#çô"\19z;&Ãnãļ¢qò\84WF&5FƹRâ\1c\18ö\9e\)Ý\94©÷-ìõãa\12\1dÆê7£YôÉã\83W6\8cÿ?zðÝs\16\ eÃIdÙ\9b.¦ý\8a#%àpûRà`±\9eåq\80\ 3£`p\15[$=±\e½õ\f\83Z\18uYÐ6\9d\0©ó¡îïN\ f\ 6ç¡>\ ezX/ç\1dê¹\ 5Ih\ 1\8e\9bg\90D.\18\rlo2\9fòáß´-êd\85\ f%øÀóø@Að|\1dì\85Þ*\84x\ e\83 \84Ü\19!\9a5+Èx>Ö,   {·þëÚ]t·ôýÙ\92q컡Y©Ð¯´GÝ\17\ 4\ 3Ça\1a\8cÁdü³(\1e\ 2{®\Ûé\18X\9bvºÙØ;äæïU°\1dÓ8\81å¦Æ¹ø²=/.M\98\87IÒòñ\80©¯\ e7\1e\96\94_\1e\ f÷E]Û.\íF\92ù\1aCCÿ3\8b\ 6G}\123p*n\1d+c×óG®ãXàº\82¬c£\ 2^AÖ\8bÈYAÖ\9b\83,QAÖk\83¬\98cpy\bÆRk\19+\ 1À
+²¶\81,^AV\ 5Yo\15²ÄZ*¨ k¯r¾<d©\7f\0Yû¥\98£a,¹\96±dÅX\ac,N\ fÂXºb¬½1\96¨\18ë8\19KU\8cµ\11
+ä®\8c%+ÆÚZÎý3VrmtNþ\0 ¬ií
+endstream
+endobj
+1821 0 obj <<
+/Type /Page
+/Contents 1822 0 R
+/Resources 1820 0 R
+/MediaBox [0 0 612 792]
+/Parent 1714 0 R
+>> endobj
+1823 0 obj <<
+/D [1821 0 R /FitH 686.127]
+>> endobj
+1824 0 obj <<
+/D [1821 0 R /FitH 668.127]
+>> endobj
+1825 0 obj <<
+/D [1821 0 R /FitH 653.814]
+>> endobj
+1826 0 obj <<
+/D [1821 0 R /FitH 638.139]
+>> endobj
+1827 0 obj <<
+/D [1821 0 R /FitH 622.465]
+>> endobj
+1828 0 obj <<
+/D [1821 0 R /FitH 606.79]
+>> endobj
+1829 0 obj <<
+/D [1821 0 R /FitH 589.123]
+>> endobj
+1830 0 obj <<
+/D [1821 0 R /FitH 568.025]
+>> endobj
+1831 0 obj <<
+/D [1821 0 R /FitH 551.797]
+>> endobj
+1832 0 obj <<
+/D [1821 0 R /FitH 536.122]
+>> endobj
+1833 0 obj <<
+/D [1821 0 R /FitH 520.447]
+>> endobj
+1834 0 obj <<
+/D [1821 0 R /FitH 504.773]
+>> endobj
+1835 0 obj <<
+/D [1821 0 R /FitH 489.098]
+>> endobj
+1836 0 obj <<
+/D [1821 0 R /FitH 471.431]
+>> endobj
+1837 0 obj <<
+/D [1821 0 R /FitH 450.333]
+>> endobj
+1838 0 obj <<
+/D [1821 0 R /FitH 424.64]
+>> endobj
+1839 0 obj <<
+/D [1821 0 R /FitH 406.475]
+>> endobj
+1840 0 obj <<
+/D [1821 0 R /FitH 390.8]
+>> endobj
+1841 0 obj <<
+/D [1821 0 R /FitH 375.126]
+>> endobj
+1842 0 obj <<
+/D [1821 0 R /FitH 359.451]
+>> endobj
+1843 0 obj <<
+/D [1821 0 R /FitH 341.784]
+>> endobj
+1844 0 obj <<
+/D [1821 0 R /FitH 320.685]
+>> endobj
+1845 0 obj <<
+/D [1821 0 R /FitH 294.993]
+>> endobj
+1846 0 obj <<
+/D [1821 0 R /FitH 276.828]
+>> endobj
+1847 0 obj <<
+/D [1821 0 R /FitH 261.153]
+>> endobj
+1848 0 obj <<
+/D [1821 0 R /FitH 245.479]
+>> endobj
+1849 0 obj <<
+/D [1821 0 R /FitH 229.804]
+>> endobj
+1850 0 obj <<
+/D [1821 0 R /FitH 212.137]
+>> endobj
+1851 0 obj <<
+/D [1821 0 R /FitH 191.038]
+>> endobj
+1852 0 obj <<
+/D [1821 0 R /FitH 165.346]
+>> endobj
+1853 0 obj <<
+/D [1821 0 R /FitH 147.181]
+>> endobj
+1854 0 obj <<
+/D [1821 0 R /FitH 131.506]
+>> endobj
+1820 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F83 1265 0 R /F14 574 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1857 0 obj <<
+/Length 1103      
+/Filter /FlateDecode
+>>
+stream
+xÚí\9aËRãF\14\86÷<\85\96­":Ó÷Kv\84±        I\ 6R\8cw\f\v3È T\82«lOR\95§\9fnµ$KVË\17ìÂ\f¥\r²¤æèô\7fn\9f\f8z\8cptqòËèäÃPG\ 6\8c¤2\1aM""1H©"©%\10ª¢ÑCt\8b\f\8dïF¿}\18*V_i00£¬\99|Íù¯g\7f\8e\ 67qÂ\18C
+âD)\8d\867g\9f\ 6þÒÇÁùõÇ\81³s\82\8b\87\97Ǧ\a\89sÁ>)¡Ê^cÞú\17,pj\7f\90\86\81è6\11\18£³ù<{|ö.rS3Å\r`ÃK\ fG\97\9fý\9aÆ~5H]®¸-î×·IAÉj\93÷YÛ\82ý¤L¹àÎovñ\94º\ f\1cý\e\v\89Æ\7f\7fKCÞi0öQ¯ë\1d¥\14\9dú\83\80¦\98¹ð\8cÚ£\0\8déRø\89\r¦F»«¯\81kQ>ûêüz0\1c\ 6ö(8\10¡6mR¿\97\10¬\8a\ 3´ÒVu\ 3Jk¿\8a\12\bI}m75û/\9b§?ù=f\93À\9e\94\ 4µÌùëß\aWm\97¸\0¦H¹(\9b{sTý¼\9a\11\18\ 31¬é\9cK\89qW6\fcÍÐtæ\fj\94\8e¿ÆT¡'\7ff\ 3!\ b\82òÐ\184-üW¸.\97\0j*½\16\7f\ 5BB\80T!\99̦ÿ\84¢Â@âJ\86E\16´¢µ¬VL½Kns\ 1sÄvÃ\rælÓ\92\95¤y\89\9dL.X\1c£qW\9dØ\ 2\10¸r¤«LlÈ\88¡\aLÄÛ\80ö\ 2\ 4\13ë¤W¶3ÈF¥\99¼ÒìB×°%\18ìR\99\80\11Â/Z\96_^\8dÿ§³i«ïh R\14}§Öðï»\92ì&\1d\94\1d{«$¹Ï\16þÊ·g'sZÜÏ\9ecªÑ"}Lg~å¸ÈõÏ\97\17W+~جªíÅ×./.'KSÞxYHn\93E\89vF\9dØ]\13Á\8f\15ö\86\89fØ;\92\9bÊFrÛùqçw½x*+\9a¯F\9b´Bm\18\16ù¡KäÕ\96ש§Q¶àå»\953·AxÍ\88d`håé\17\8cq¨\\15¯|m\ 5\83rjÇ\0oG£'­Ã\92\96ìIëÍ\92\16=
+ié0iñ\1dHë%C0N\b\9a\95\8d´s\10&\18\84`ûÌcºó<¾ùc°ï<.Ê£2W¶ÓÔ_Z\19\94_U/Tg»U¬5?è\16#«B`g1G`í\10Ø\9d\95\b\9cúÓ0ÿ\12 \84¯å_\f\98nâ_
+\9cóí\87\90ã_çR\17ÿr0ëÍi\10¤rê4W¶=³\98\1d\8dKHÞff\15\0M¹K\95¹ËßÌ\8eÇp\17¤\8dï#Ö\11\0yc\1cíñÙH\10%=ËâwkÙ+ªìea\8cV¶½ëv¢¦=À\86\89Ë%i÷\fë\ 2Xbó3ÀLëG÷ö\18\9aw«i»#h;C\85Þ\8bb¥°&L;"\8f/¡XÉuO±a\8a-§%+/´\8bCRÀ,ðz÷´s(\ 4\ 6\8aI\8f´/AZv\14¤5?\fÒÒ\97 -ûA\91\96àMLËz¦í\99ö5\98VìÉ´¬gÚ\9ei{¦Ýù»AÁÉ\11¨1\97ª9 \ 2Þ  \90\92¾ªwy\1f\92'\1c«nÝ´\ 6µ\1c\ 1ô â\15\ e';U65ÎàÄÐFlTtùÄ\ 3@s«¡\10f½^¡R~\f*ex\7f*Ýòuñ\r\rç,Ôo\98Þü\92S\fJÏÔ\ 4µÇ1%\80÷ãè£ü©ö@/\16\9fÎÜÍ\v\bþ\17Ó`tò\1dØñ±0
+endstream
+endobj
+1856 0 obj <<
+/Type /Page
+/Contents 1857 0 R
+/Resources 1855 0 R
+/MediaBox [0 0 612 792]
+/Parent 1714 0 R
+>> endobj
+1858 0 obj <<
+/D [1856 0 R /FitH 686.127]
+>> endobj
+1859 0 obj <<
+/D [1856 0 R /FitH 668.127]
+>> endobj
+1860 0 obj <<
+/D [1856 0 R /FitH 653.75]
+>> endobj
+1861 0 obj <<
+/D [1856 0 R /FitH 635.955]
+>> endobj
+1862 0 obj <<
+/D [1856 0 R /FitH 614.728]
+>> endobj
+1863 0 obj <<
+/D [1856 0 R /FitH 588.907]
+>> endobj
+1864 0 obj <<
+/D [1856 0 R /FitH 570.613]
+>> endobj
+1865 0 obj <<
+/D [1856 0 R /FitH 554.811]
+>> endobj
+1866 0 obj <<
+/D [1856 0 R /FitH 539.008]
+>> endobj
+1867 0 obj <<
+/D [1856 0 R /FitH 523.205]
+>> endobj
+1868 0 obj <<
+/D [1856 0 R /FitH 505.41]
+>> endobj
+1869 0 obj <<
+/D [1856 0 R /FitH 484.183]
+>> endobj
+1870 0 obj <<
+/D [1856 0 R /FitH 467.826]
+>> endobj
+1871 0 obj <<
+/D [1856 0 R /FitH 452.024]
+>> endobj
+1872 0 obj <<
+/D [1856 0 R /FitH 436.221]
+>> endobj
+1873 0 obj <<
+/D [1856 0 R /FitH 410.954]
+>> endobj
+1874 0 obj <<
+/D [1856 0 R /FitH 392.66]
+>> endobj
+1875 0 obj <<
+/D [1856 0 R /FitH 376.857]
+>> endobj
+1876 0 obj <<
+/D [1856 0 R /FitH 361.054]
+>> endobj
+1877 0 obj <<
+/D [1856 0 R /FitH 343.259]
+>> endobj
+1878 0 obj <<
+/D [1856 0 R /FitH 322.032]
+>> endobj
+1879 0 obj <<
+/D [1856 0 R /FitH 305.676]
+>> endobj
+1880 0 obj <<
+/D [1856 0 R /FitH 289.873]
+>> endobj
+1881 0 obj <<
+/D [1856 0 R /FitH 274.07]
+>> endobj
+1882 0 obj <<
+/D [1856 0 R /FitH 248.803]
+>> endobj
+1883 0 obj <<
+/D [1856 0 R /FitH 230.509]
+>> endobj
+1884 0 obj <<
+/D [1856 0 R /FitH 214.707]
+>> endobj
+1885 0 obj <<
+/D [1856 0 R /FitH 184.956]
+>> endobj
+1886 0 obj <<
+/D [1856 0 R /FitH 163.729]
+>> endobj
+1887 0 obj <<
+/D [1856 0 R /FitH 147.373]
+>> endobj
+1888 0 obj <<
+/D [1856 0 R /FitH 131.57]
+>> endobj
+1855 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F83 1265 0 R /F70 508 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1891 0 obj <<
+/Length 1506      
+/Filter /FlateDecode
+>>
+stream
+xÚÝYKwÚF\14Þó+´\14ÇÕdÞ\8fnzüLH\e|\1a³s¼\90\95\1ap\85\88Oóë{ç\81\10H\8a!vâÓn\90ft5s绯ï
+\1cÝF8zÛ;\1aõÞ\9c)\16\19d$\95Ñè&"X"-M$µD\84ªh4\89.c\85\14ê'JéøäxÔO\18cññùéÙÙàxp:\1c]ô¯Fïß\9céÚ* \81\14\87{ß0+ÒÃa×Õ5J\18\16\88h\13%TÁ»ÌK\7fÂ\ 2\87\14]&\ 2ãøp±Èog^\87\ f\87}ªã·vÀãò.ó³_úBÄéý2\fíj\95 ¥4>°\17\16\ 3ÚÜ\82 \82U\94\10\81\f\92ué2¸ñ[\\fÞ\ e½\12ùÂÏ|Í\8aù/þ6õ
+;\88\0\91\1aÒD#"ø
+#\ah\v\94\1c\102d%u\19\ 4ê&£HI½\12¸Î\9b\9dªlqÕ¶\84@\82\89\95DÙ²\ 4ÁHÁ]\908ðH\92+\7fÄ\0=·ÐË
+z¾²Ï\16È \1c\a\9c\837p\ 64ÁúÀ>\87]\8aÇ|\91=\85«\11H\9b\9dP¥O¡ª^\ fUpè>\89\9bÀº5\b¯-"\192´Òô\13Ƹ¹\91ªGc\87Y(§°\90n\98åö\89PlZ@`Äx¥ÑhÐ\82?øþÚg_\0þ~ÂqÈ\ 1\1c×s@\8bv\ 4aM\9f¯\9dÞG;*\8d³/\(¤R  êuÂ'au]\9d}ØåÂ\82Cúø1\18\82 MÉ\12QIÀ\1f\b2Bx¡-GÜÐ\9b
+¤ØÓf_ïø\ 2Èn;±\91H\19fs\fø²ôB ×.      %¿i9\13` x\95}Gç¿\9f\ e[\93       S\95Ъ\ 60òëvâÃ\18²\ e\ fÚ\89u\88¥]!ö1K'!ÝùD@\92ë¼ô3Ë\99õ\9f,<Ïg6¨Ëì6+¼dºX\17§m\940\12\825\ 2ýú\a\9esÚëíx×Ú¯|íg/Rû\93º2d\a\ 2¨|üãtø<
+R\87Ä®ÖäBõ\82l\97òR\15\18´\15\f\8c$6{\16è³¾æñ¼ð\bgéØ\9eùÎoQSÃ>\9c\87HS¸\16DÚ nªìQ~n­\96\98VavŞmù\83"ÎÙîE·\9c{\15íùZ\96#\1c\10àßZN#Aªý\ e\1cºÍ\1aÍ\80
+H²G\8d&\16eHL\94ón¦\ 3\ 5\9b\19ùZTgÃz\9bTçsÛé4\96ëRã+\fdk¡7\vLW([FÝ\88X\80\8cÐÝ  ËóùºÂú?Ì×­s~/eg\88Ëfr¼{>[W\90jäÿ\16Ôf*\80¾Z­iÛ3è:ð~ÁEÃûó½é:\97\88Ñ\9fÌÛ<v\ e°P :ù:Ø^JúS»        \97Æ\ f (\ 2#VÝÀiH\b\84¿\ 2Q\ fÙ\13jÓ6?oI\9f­uC\eþS; \14ÔÐ\91×\96Z\91\84P ;6¯P(\ fдW\1f\9bX\1fNEEøܤD|\fe\9a\91\18x\10\91ã<\9bõaPúG'ÙØ?\9c´\9d\15Ã.\1a±Õâ\83ÙÃÒ¾§Yü\90\16é4+³báyúé¨÷wÏæ\18\1c\91ê3\18cP¢\88\89ÆÓÞå\15\8e&ðð=°#\ 5LåÑ\89N#Æ\19¸\81}ñ>ºèýé¿©m`  \9c\841\1a1*\11f¡)\19ÂÞ \a\ 6\12;²ñýÏ\ 3D\82\8em<\80\17ùWß\86\11L\80ÐÈM+;¶\9e\97\8bU¨GL#\r\9bÕe.\1c\ 1ý\r\804\86\ 2H\8bq\91?\94ù|\16(è,\90Ó"[\94E>¶O\16ßÀ\ 1\ 3ÏaÛ0p£¿\rÃf\ 1\rkQÈù\84\86\945<jñ>è\80ñº\ 3\1eÔé3'\9cÆLÚ´\ 1\ e>tì\r\92íÈù½QÀçÊôÞߺ×\96Sû{íÁ-ü\83ù\8d¿^ßÏݼ£ª\7f-üd>ó×ÔÃÏ\f¨b6῱\8e\83Z\9c-¡`-¢¶¬ut|~rz²Ï)íÎxs\91âH\9d\9f¸\87¶-\ 5æS\17 \ 1\89\0\89\88\ f[S\16t k>Û
+>\85R¯«Z\9bd÷Ù4óº\ 1úÀÿÓJ\137´`r×\16\10\91Þ.|nâ\ 4Q¾ÅìòÙ$\1f§e>»µÁÍdüx\97\8fm\13w\17Æ\rsÀ,Ø¡È6ð\bñ3ö²\93l²»!\86\1f¾ËÙh«³\19ÐÍ~¢\83Iân¬ÛÙÉV·³\ f,R\ 6Î9MÇżۻ\9a^é[H\1f¶~¸§\a¾\e=yîwK0 \9b¦¡\97,Óëû@fjö\16XJëW        \938Ö8ÉìÙëþaçkòvè\82\r®ë\r:Oî6\85\ 3S\83ãǼ´Í£6ñòÁϸN\rÆÎ\1e0\ e\9b\16ùê\95\89ºÓ\181\ 2)M÷Nç­y\8cHhYuø\8bä|YvV\96íÿ=@µ\7f\ 1ÃYý\18
+endstream
+endobj
+1890 0 obj <<
+/Type /Page
+/Contents 1891 0 R
+/Resources 1889 0 R
+/MediaBox [0 0 612 792]
+/Parent 1910 0 R
+>> endobj
+1892 0 obj <<
+/D [1890 0 R /FitH 686.127]
+>> endobj
+1893 0 obj <<
+/D [1890 0 R /FitH 668.127]
+>> endobj
+1894 0 obj <<
+/D [1890 0 R /FitH 653.681]
+>> endobj
+1895 0 obj <<
+/D [1890 0 R /FitH 637.741]
+>> endobj
+1896 0 obj <<
+/D [1890 0 R /FitH 621.801]
+>> endobj
+1897 0 obj <<
+/D [1890 0 R /FitH 591.913]
+>> endobj
+1898 0 obj <<
+/D [1890 0 R /FitH 570.549]
+>> endobj
+1899 0 obj <<
+/D [1890 0 R /FitH 554.055]
+>> endobj
+1900 0 obj <<
+/D [1890 0 R /FitH 538.115]
+>> endobj
+1901 0 obj <<
+/D [1890 0 R /FitH 522.174]
+>> endobj
+1902 0 obj <<
+/D [1890 0 R /FitH 506.234]
+>> endobj
+1903 0 obj <<
+/D [1890 0 R /FitH 490.294]
+>> endobj
+1904 0 obj <<
+/D [1890 0 R /FitH 464.889]
+>> endobj
+1905 0 obj <<
+/D [1890 0 R /FitH 446.458]
+>> endobj
+1906 0 obj <<
+/D [1890 0 R /FitH 430.518]
+>> endobj
+290 0 obj <<
+/D [1890 0 R /FitH 390.674]
+>> endobj
+1907 0 obj <<
+/D [1890 0 R /FitH 372.783]
+>> endobj
+1908 0 obj <<
+/D [1890 0 R /FitH 336.918]
+>> endobj
+1909 0 obj <<
+/D [1890 0 R /FitH 181.443]
+>> endobj
+1889 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F83 1265 0 R /F14 574 0 R /F70 508 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1914 0 obj <<
+/Length 1615      
+/Filter /FlateDecode
+>>
+stream
+xÚÍXMsÛ6\10½ûWðHÎD\b¾\ 1öÒql9N\9aØm¬v¦\93ä@K\8cÌD\12\1d\8aJ\1aÿúî\ 2 DR´cÇ\99NO\0\17K`÷íâa\ 1\1aÍ#\1a=?x69xzb£\94¤\9aëhò!b\9a\12­M¤­&\8c\9bh2\8bÞÆ©LÞO^>=1¢­\99R"R\ 3Ó8\9d£ÓÃß'ã7ÉH\b\11\e\92\8c\8c±ñÉ\9bÃ×c/:\1e\1f\9d\1f\8fq\9e\ 3\1a\16\1fO\ e>\1f0èÒ\88í\16Ö\86\18\9eFÓåÁÛ÷4\9aÁàË\88\12\ 3+}uªËHHA\fÃ\1f\17ÑÅÁ\1f\ 3N\18K\98\14\91V\86p©½\81gÙ2\aS`îx\92p\13\7f»NFР\8c3\19_\1479Z\171&\88ä<\1a1FR¥üÏ諸\97\86\969-a\89\ 5xÚ:\17Å|\95Ï~MF\8c§4>Î×Óª¸®\8br\85\0È8[%,\9eù~\95¯ëª\98âàÚA2\f\85H\89\11{PÈÔÞ\r\85\ 2j#Í-\818\84`\9d\8fON.|PÛÀi\b:ãMHùq2Ò\10Å\17«\84Û¸Îçyå|§]l\ e«*C\85onÐ2¢SÙ\ 1\86i@\9a\81Æß\89\95\b8\8b×NbâÃ\957¢c²\15$eÛÄ:{\16\fe²¥Ã\15±ð\13mÂCù¾7\8c\827Ûy´\ 4ì\95\89³
\80\16C
+ DÇå\a?òy\93­FÎ\89\91âDqÙõ³\86\f\81ø)¡âã£\89ïLKpÄÆù;Êô´È=P8¤ã/       L\9d-6ùz\b´\ fe\95\8c¤Uq\9eMñ§+ÿu¹ð\13:Ù'/+V¾½)æ£\9blî?Êj44í,¯È\0¢\0¶"L«®òÙýÒà¶ðëÁðk¢\8d\8aÚ
+\ 6\80ÅYé:êÖ +)÷\82Þ6\8bÃÆ´¬Q\19å\8b|¹Eܲ\14\r«e\16Ãêb)%ÑÒt\8d®¯ \r\04dcé\99`\17D\83SºárÓ¬ \99\bQ\ 3¹\8b\9a\81¨\rÄ \eCrûþV\8a\92\94²\aSÝÀþ\86É8¸I\ 3aÿ\95¤\90{U\91]. ýF\ 2¶Ýf\9dÏ~¹Ã\16J        \aby\14íê\94(a"iSb\99jÓ.\17Zõi\97\9b6í¦\92X%îúz\98u¹V²Ïº\ 2X÷A\94+\r'\82>\9c\0ãJ\8dá\r\8c
+2\1aÒ_§n?\99°\9f \99$\8b\85ìo\91\89ËOÅb§»Yb*]zªÁ\9f\14\85
+Ýl[{¡£\fhëf\9aÅf\99ùÓÍ\1a\92Ú´\8bóõ"[åÄï\96A\85É\8b\v<&{Æ£¾´$½\8b\ f\8c\ 6°ø\ fð\81\81\b?L\a\92©@\ah\b¢ì\ 1\836l}\19O7\81CG\12\ 2Æd×\8dj;\17fO]~¯<dU±\9aåÿø®£\ 4\119\8a\a\16lÇç.3\98Õ\1d¦E\13y,ô`f\bÊÁÀeV¬\8aÕÜ\7f.òÕ¼ÆÅ©ð\a\1aÈêF\17\Ýúsk\16\80!Þöj³º3\19Î\7f\e\9fa\95CiÏb\r\16«`g0X\a\83aÚÆ\bãA\15}PC~{\8fà{\96\87Óu\96ÏÈ\10Ñ\9e>GE#\a¬\10ßµb\eÚÓ\rÔ\ 3\ 2O\82e\16\8c©\91:}w^\95\9bëpª\1aÚJÀ\9e9ÓËb?IÝþ\188H;áíÛÉ%mR\f»\18Nlëf¬ã\ 3
+úe\ 3\aR)\12d\ f×\85¼`q¨n¡¦¤¶·ew8\ f\97-\8au=\ 4Âp\8eü4(\14\1c\ 1
\98\83\ 2\1fc](p¤o;*\15«\ 1ßÕ°ïeµ«¡îãèÇÇ;z¸*Á\1fÇë[g±ÛP|æ?÷jC§íÛ\96\17·zú@Ïê\a\85\107\9dþá­ï\9c\1e4mÿ|©?>Ú®-àmSpû?Ä\9c\0ÓU\83\13Ü×Hj\84u%\0'PI\80"T\ eÒë½Ú·Zh¸hÚ¨¥´o»\1cÄTÂaÑ$\8aõ\17\18lëf¬\837
+N7ÈpÈn·¦G`<maw\95Ø
\19½À\1dr(q+ Ä\15\14®ç\8a\87!zþZÔWES\86y®uT
+\tÿ,ü.¼AïèNxÕÿ\ 6^)\95\83\17[\a/vüµ\ 2
+RÆþvQ\95\b2\ e8\90×Cׯ\9f\8bòý7\95ù¯\91ó{Õ{\bÈÝq¯b\16î2B<ò       IAM\bsÂí\91¦<T>W\ 5Þ¦\ 4\8b¯+\7fg\9cæ³M\95\aÙ¦v£á FQæk\9a\12Áû\12X\ 6å5ö¿&n¨7\1fÒÐ\f\82\aÓ\86µê ãõ«Oa\8d mUI½ÅñXTy(æ$IeïMc\9dc\1ct8k u/\eR³á\97\8dµWòùªÃ1ì$\15\bÜ»y\1a\1f6áÕl§\90ã=¬½\90«I\8a0¡wß\ 68\9f\800\95¾0\1eà\95×\7f^L:\15£ÿ¸qÐUå\93ÎÅOàÝåíÀF`Ô¶.\18\8a%p£l\14ÞûÉ\9aµ¥[Û¿\1eÂ\87{[Ú]\ 6D\9c\7fA\10òê[8ÿ:Çsß\12\ 1©¦ì÷L\11\8d\ 2é<¢¶\1eSÿ\ 50\15I-
+endstream
+endobj
+1913 0 obj <<
+/Type /Page
+/Contents 1914 0 R
+/Resources 1912 0 R
+/MediaBox [0 0 612 792]
+/Parent 1910 0 R
+>> endobj
+1915 0 obj <<
+/D [1913 0 R /FitH 686.127]
+>> endobj
+1916 0 obj <<
+/D [1913 0 R /FitH 668.127]
+>> endobj
+1917 0 obj <<
+/D [1913 0 R /FitH 536.562]
+>> endobj
+1918 0 obj <<
+/D [1913 0 R /FitH 500.697]
+>> endobj
+1912 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F7 674 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1923 0 obj <<
+/Length 2208      
+/Filter /FlateDecode
+>>
+stream
+xÚ½YKWã8\16Þó+¼tN\13µÞ\92k×PPE?`¦É\99\rU\v\93\18âî\10ÓN\ 2§ú×Ï\95®ìØ\8e\92Ps\98^\80\1e¹Ò}è»\ fÉ4yLhòéälròã¥\11IF2Íu2yH\18ÕÄê,ÑV\13ÆM2\99%w©!\86\8cÆÆØôãùd4\16B¤ç7\17\97\97WçW\17×\93ÛÑ×ÉÏ?^ÚÎ.@A\8cÌ\80\87_\9f)GrB\ 3×d,\98%\96ªdÌ\r¬\11Hu]­\vØÜèt=Ï×Ø{\1dq\9b\86ÙÍó\bèÓY¾%\v\9di\ 5¿\0Ý\17Êô´,\96nѺùiÓ\1dV\ f®Uiñ2\82­\8aú\e\ eï\17¸ÃÔ\91þ\89¤÷¸çCU·\p§Ò7\9brùè´JÆL\92LJh\19É\94B]ò%¬\912½¸9ÃN½    3U\8dí¬\bRÏÜF~*Çf]ýéµ^\9eº1(\¬\9eK¯³ûq\1e:\ fùtÝLå¡WúV¥å*l¸¨\8b\r\aÎ|¸}\10ÀÙÑ)@û¢o\96\8bb\ 5\e\90\9bë<×ÅKYmüt\90\10Ì·Äá«\eäaI\8e\9b:,ý»¨+ì\81\r\1c\8cX\96Næe /Ã\96³j\19èѼkw\8a\ 6\8c\rFg Èâ[\90¨\8aÉüT>\95SP\8b\0ÊÿüKàL>mA\80¦ö¢\80\92 \8c\94\1c\84ñç¹\1a¬¯\96\8e§\9f*\9fÂ\ø1 Î âFc\96vQ\at]Ô\ 1õ,às\15\93}Y9*JAñéb3+p°\9e\83Ú¡\1f\85÷ªY\84m\8e\r\9aÝõÐì®Wo`«@V\86e¯ób9ì!\8ex\96\ 5°º¥Eî]b^\84up\101\1d¼]¸a诹û÷\r'ÖÞPt\9f\8b:\12-ÜApá\ 3À©#\93é¼r\ 4èý/þ\7fí\7f\11\8d\94°®.\1eóz\86`ucçÛ\8eU+LsHî\80vøÒpH\80±Ó\9eJºõ`ÔBh\91æ³Y¹.Á\8cÕ2_àÔÞCÑ<Íý!\0Ñj].\168·*Ö8çý\ f\ 1\81âJ8\ 4\168\170\aT\9bU3õ\10\9654]lÁ|\19x\ 2\10"\a3+ÖEýT.\11ø\10·K·\9dÀX\ 3ÃÕ3j1-½^03Í=g ñ\9cEÃÙ­õ|Cä\\85É6#L}Ì\83\8dÕÝ\0ô\98µ«}{[L½W»\8cÀ@^\9aÔ\8f     v~\87Üpç\97AZ ¢\9f4îRÒ\9f`\9c0c \87PµD}Ù\80æn¬\0µ?­Våc`\7fýëÙ-\8aÖêõ2R\10%\16\9b ò\17ª(¦4È`\9dÌÈ\19¡R79íú·³\90ø\98ìf>M\94a\rÑ\17JÅnv4\84eª!\91Àn(õ\98iI,ãÐɶºñ¨n\97#p
+L*<mÜ\15G\90°VÅt³._\9a,*ûÊJ\ f//\9f¡]U¥ ÌòFÄûrW\a0>Õ-ÅC]=á~\14\eL2|\9f-¥%L\9bÖ\94QKrE\8c\92\1d\88\14\94PÞZ\9b9S\9e\86Ô×\1c9¨<¹º½\8bh   qG\1f\12­DCð5h6Ǭ \81Ò\12\93±¾¿\r \84>>8[N âê\9d¬8\8aZ¨#\8e \96\ eö }\16ò\bx`Ã\ ex`¿]ð OÕò\14ûÀ\ 3
+ÊÖ®ë2zl\86²\ 1x`?\1aT¬p¨Å\87¡í\9c{QÓWÍa,wG\1fÓð*&"T\9dÚÈ·KècìV¾Æ`ìÃîÑ*Àù\98)ÂM\16ÖF\rÿ;Ôe¸I\8e{Êñ½¯Þ`f³tçÞ  \9b¾\1cz,ê\10¹W1£+(B·*Í\e\9dL¢a^Øà²Ò¸\98Bd\16L÷ë®æ\8a@9\96thvðk\14Ñ°#\1c\ 6Ñ,Ü\10Ê\7fJMÓÅÖ[Õ<ßU\13n7V\1dR\93S\88-,\9c¥Ý"í~\1fÒZ_\92V¡/\19çKnÔõ%\9f\19ÝdÇ\97¤Õ{|I)b·é$\1a\88\ 5è0\bÄn?\8a\8dó%ÇmO V`,}$\ ekp\ 5s4\ egF÷â0²\7fh\fò:/\83Ev\85\18\büõ\v°³ó\9b\8f\17\1f#\0¥\84\89Ö$±À\ eñg\9b\14×E¨£\0wËj9\ eµ³\83í2àsO\ eÉ\14¡T}/¯â¯M¾\88á\eÂ\9b Ù¡Àd\b <üþ!\ 2Yce\1f³å¡Ü\12ÉÌ\0\bÕZ÷Ú_ó#\17|\b7LÙc\87`¿×0!¹ÉNrÛÝ\19\8a\87Ì\8a·\1ai·´\82òK³7\85¯«\87aöm2Á#Ü\8cÖEÝHÝ\94¾\ e8\83Sq¯\ 3YÖg÷Óád,Y7\19KÖ5\87ÿ1\1a+\0\8aƶ°_ÿ\11ñRð..{¡"rn\92\bi\ fæF\17\14\15ʤ\ 5T^R´\95×.´4ÖéaÝ>dI\ 5Õ1{GdŶPD     uÈT\86Xª·àÄ\82OY¢\94èG©n9Ö-\8d¢\95\9fÄG¯.\14Î\8e\96~ûªWÈ\fB¿\83\83a©5¬\ fÇF\12Í\aYþü\1dêT\97\88<Õn¦a
+r\19W\87SMæ\1f\f»\99fÇÌ\16\0*v<<îâ7 gýZ®\8a¡ÛB¡¡õ[ܶ«þçO½Ûu\83\89ð\94ãîÆy{\1f®\96Ñâ\99\11aÄÿR<O\øÈï\17Å¡\9bµ\80\9bµä\87/ÖÃöbròWØ\8f%.Uë,áÖ\15â6\99>\9dÜ}¥É\f~û9\ 1Á2\93¼zʧ\ 4\0DµËe\8bäöäß᩹\1f\f\aOæFÃ-Ní×Xjb·q\vlì¤\8dJe(Ô~r(\95\8bV\87¤²1¡T\ 6\84!\87ºZÊ0\93ÒØ\13\v\vHf½êRK¶MÓ.é`£1iï\94pܶú)ÿxep_\7fÓɸê³ÔïÌ\92IàÉ\81'\8fð\f\81\8e©\bS Ð\|\1f×\96\9c\e t\9a\8a\10_!SRÝ×\94Û÷æªEà*÷Ã\88B~\80²øíà¦Ýï)=8Qw%\84\8b\86\95 \ 4G\11\9eÚzä\a÷\14-ÓÏ\9b/\94\89§¦\9c\0\12ÊôS]m\9eW\a}\15¬h T\90Þ\98\ 39&~3\86ìÏ\ eÖÎ`|µuFW\ fqkÓð
+\v=,\86\Ͻ´¹GÛÌöj\82\83íÄ6\9aÍ£\ 1OAE²\r\89þu×Ú&¸BlÝø\99̧\16¦#\89\ 5n\8dLÊÃ\8fr\9að¬\ec òóô\87\98\89àú«ßë¦Ý»\82Æ\92\19×\99\aû\eòp\9bÊNÃÝe\9fÑ3\87E}Ìæ&ëÛ<Räì78\94èR\1d\7f\ 5Õ]\83s¾Çàà Zÿ?îüQ\83s¨/Õ ðùxèu\83»\^`\a_7 ã?É\81B9\ e\9bOHîÙ\ 3¿D-\ 6+ýk;o*4Þ~`\98ùO/\\84\aþAMÍ\ 1\8d\ eû9ö1\96\8b®\8b\1d­¨ãx@\ 3w\8aIî¯Ì!pC©)²~ä®\8biõ¸,ÿ.f§½«tçi¶ûma\80¬æ  próËÅu¼<\81Èý_»\16Eu
+endstream
+endobj
+1922 0 obj <<
+/Type /Page
+/Contents 1923 0 R
+/Resources 1921 0 R
+/MediaBox [0 0 612 792]
+/Parent 1910 0 R
+/Annots [ 1911 0 R 1919 0 R ]
+>> endobj
+1911 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [420.112 571.545 442.583 582.393]
+/Subtype /Link
+/A << /S /GoTo /D (section*.115) >>
+>> endobj
+1919 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [376.065 297.204 395.769 308.052]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.42) >>
+>> endobj
+1924 0 obj <<
+/D [1922 0 R /FitH 686.127]
+>> endobj
+1925 0 obj <<
+/D [1922 0 R /FitH 567.886]
+>> endobj
+1926 0 obj <<
+/D [1922 0 R /FitH 548.069]
+>> endobj
+1927 0 obj <<
+/D [1922 0 R /FitH 519.341]
+>> endobj
+1928 0 obj <<
+/D [1922 0 R /FitH 498.139]
+>> endobj
+1929 0 obj <<
+/D [1922 0 R /FitH 478.82]
+>> endobj
+1930 0 obj <<
+/D [1922 0 R /FitH 459.389]
+>> endobj
+1931 0 obj <<
+/D [1922 0 R /FitH 446.325]
+>> endobj
+1932 0 obj <<
+/D [1922 0 R /FitH 432.708]
+>> endobj
+1933 0 obj <<
+/D [1922 0 R /FitH 403.259]
+>> endobj
+1934 0 obj <<
+/D [1922 0 R /FitH 389.642]
+>> endobj
+1935 0 obj <<
+/D [1922 0 R /FitH 376.579]
+>> endobj
+1936 0 obj <<
+/D [1922 0 R /FitH 352.944]
+>> endobj
+1937 0 obj <<
+/D [1922 0 R /FitH 336.836]
+>> endobj
+1938 0 obj <<
+/D [1922 0 R /FitH 323.219]
+>> endobj
+1939 0 obj <<
+/D [1922 0 R /FitH 312.093]
+>> endobj
+650 0 obj <<
+/D [1922 0 R /FitH 196.237]
+>> endobj
+1940 0 obj <<
+/D [1922 0 R /FitH 169.389]
+>> endobj
+1941 0 obj <<
+/D [1922 0 R /FitH 155.218]
+>> endobj
+1942 0 obj <<
+/D [1922 0 R /FitH 141.602]
+>> endobj
+1921 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F7 674 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1949 0 obj <<
+/Length 2056      
+/Filter /FlateDecode
+>>
+stream
+xÚµYIwÛF\12¾ëWà\b¾gtÐ\v\1a\8d¹äi¡f<\13K\89É9äÙ>@D\8bÂ3IÐ\0\19Åþõ©êj\80\0   Zv\96\8bz+TWW}µQq°\fâàß\17\8b\1fnM\90±L\v\1dÌ\1f\ 3®c¦u\1a\19\17i0/\82wa¦'\1fæÿýá6\95}Ê,f2K\81\8d£¹þÏåÏóéÛI$¥\fS6\89ÒÔ\84·o/ßLiëfz}\7f3E>\17±¿¼\1d\87\12D\\b\96H\15D"\85MIì§lðið.Jâ8|ý8\89\84\10áüþ\7fÓ;\9cÊ°lhke\9b\86vvOù\86öÒW0ª$´¿oa\8b\87\ 5\11´ÇÓû+ÿEõq"Lhýþ¾)7Ë\96\17|fi¾­«\b\85
+¸b\890 8gY\92\90¼\v[ìkKß/Ëß\1c»IÄCϲôãÌ.veµqoãð²8¨\97\ 1MÞºW:±YÊøñóñ`Wy\ 1·0\9a°ÈwþÆùëÙ;o²¸o2£\98Éxk²\87\92húÚ7L'²%øð\8a\bTÖ£\0£\1c\8c~?½½\9d\9drQ        ã\87{ÆD\11,Õæ;\ 5\ 1D$\ 6P\99\fU\9do
+\82\18Øov\ 4\93\bl#\80OÄ%Ë\94¡\ fnG±t¿{²õsÙX\0\892\1e$ÀY%*ÌiXTNÏö}Ìõ¢\ 4xÀb\87GI\1f2Hé!\83S`K$\80\17ø<\r\17\88\ 3\80\a   \10â\ 1DBö^Õ\82\ 6\18Je\1c`p|\110H\84\80\11Ço\94*u\80A\82\ 1`pã\1c`4H$ÿ"`2\16KýM\88\11/!&ý\1eI"\99p\a\8eS\91"!5\13R\fU~wN¸D1\9e¤\7f#\9c\99\97É é¥Ò\82\ 2\9fÂ\80\97\ 5\91\14\0VM´)3\80\17\0}øÿMQ9TÉ4     o®iü¹¶EÙAbxg\fïäÌ\bN\9cæ\bD\19\83N\16»}¾Â¹\b\7f\9b$:ÌW{KËêÑ\93Ðàn\81í\ 5!×E°#ð#Ya½g\14¶ \9d\87      \90\7f¦ùË\90\ 5"\80ì      `áb\8cæx¼ke¯m\83B\94\ 5xO÷\88ǺZ;G\8a\8f"\ 3b@\81ã9\1d\12\89ONÚ';§^o÷Ýa'x"ý¥@b7ÝûjÈlI¬A\99N´D¶Üñ\85\8e\98öUXmV\9fi\96oAØíª¤;\14\88°N×\10ÅF\83L\ 3×*È\¿ìsÚ(¿X\1fõ.Qâ¯~\8bg EM©\vç½\ay.EY\83\99@b#CÖ\ 6¥L©¡\8côj\ 5ɯñFu\8bÂ6\8bº| »=ÁS\85\97\ 2ã\ e\8e{\80°ßé8õõק­\11\82Â`Ý~fiRÕå²Ü\0\0\^\18Ȫ{úTú+ú4Âû\ 4Põ1\ 2Ëöã¾{Àò±ªi\92Óð°"æ\v\91ö\9cýݽ\1d®ðK\84¨\9bíÚ+á\8e\11\18t7bõ¢3ç\91BC\ 2Ø5~²^\83¨\94êa¹±åò  ¯'õWµ'{~*\9dTO´\84÷AIb\89§\13\ 1wI~LIðç£ç¿¡±Î\9b\1dª\1dçUMÈGÍÏÝmûæÕ\98ôµõæ¢ü\87Xs%SéA8p\16\80Ý\9axíÚS/\8e\93\14wJO×
+\83s'Ì«ö\1cös\8fa\17¼\ e^ÐaÛK\7f\ eÔw\15êRe(j\8eé<ëà     {À\7fK30¨õ\9b\1eê\0\a\85ýä<\13Rl  Ïýâb\14\96\98Ë\96³m\99\9cAc&tx;1\107êö\13\10á\14Ý\9d¢ó¦Ú \16\80Ô¡Õ\88óî\ fg9\8aê&+\8c\9a\86\87\a\89)\96ÀÖ³\93{\82ñ\96\88     ¬0iòµ\1dË{\90²\92C\81ði$óqÁÔ!yvðö¢×v\99×\ 5\15ëx\ fØÐWzÀÁ\1c\15Õ¤En\8eü.ZyÔ­F$Ô\90@_\14ÐðìD@45Ïz¹\8d§ë\1aP\ 6\84&\8e/¦7$J\99>Jo\10e#\9deàNU3¦Y\9eÆ,\8dÕ\9f\17Ü\19\1cïη\94{H¯\1aj\99T\ eC¥OU\92\82oç´Þ\a/Q·m\82A\ 5øbà\80²ÔA¸+i\9cÅD[\81\80þ\8déj\19hd¨\9a¹vᱫg\b\85\rxÃiù\86AÇ0i2bûz\ 3\9c\10>\90\1a\80
+¡¢ù\97Ó÷t~ñÉ[\85w½-Ô\85LA{²X_¼û\10\a\ 5\1cB c)ô5Ï\8et\1d@M\f>\87\1f®\82ÙÅ/#}²áPÑ\19 ä,\8eýûîÐI"\15cbA¥}¦2\e_&¸
+gàh\14\85¸\86²Z\ fÁý>Nâ\a\88ò0ºf/\90\ 6j·4èÓÌÊåÆ\16?\82
+\ 5t,7.ín\ fÑ´ë\84j\aÔfW£/;\9b9"Øú\8aV\84dI,\8eµ¢2óu­\f,CÌ@-\80Í8óðºÂÎÿæ\14¿©d\u5ÿk
+Wvië±ÌrY×¹Ó©;4\9aé4\19è\86\v.pç\9ab(ñ.7#Ð\ 1³u7Þ]\8dÔú \ 5eºx\11Ù\95]wµnb°\8cjåpË6^)Ád¬\8e\93|é~\85È \\0\9có\9dÿ%a\98\9fáx\18Ñ\9a\81\ 6¼\1a)\82\ fò\e\eím\84\80^êH\967WoÀ\b³\7fÚ\bòÛ\8c \986]7t÷fÌ\ e\12\1a£CÚ\18Ú!E¬\ fD\89 EÓú¨\85Æz@ë¤Ó\97Ó=n¬[\ 56´ve\9dÖ:´¹·ÉÈÛ×ù¢®È\0Cc}»\11\9cÍ©êûûl\0a(\93CGР\1c\a\8a\9c HàvR\båPõòP\ eÕ\89[=XãrQÑa^nè7.H£2É\86\92\90>\95¯n´BÅb)\87[XnRfÀÔ\82;\85\8dÆP=(Ö\92\94â?\8c¾KÃ6ÏÕ
+\1a;*KgT\86ä\95îHET*ò\9e¡iIñ\91{\83ã¤3¸[ÕöÑÖ£\1c¡aòÎ÷\88      æÛM~î'\85¡ÉÅ\rè(5ÿ¨éÏ8"LOâ!W\83\12\8f    Õý~ó>\8eÅد\e      ïüY+l\1a\ 6\90\12\8d\f\95\9d\91\ f\9a\90ÄõÑ\8f0m5\8aùízN\933¿»áQ×Ì7c
+óý\9aêÛ\19V§m\9bï4`üR.£/ù\92\16U=\8aÙ¶\9d\0\17\110ökÐy\87\8f\128\b¥öáÓÇQM\8dªÎPÎÂþ\8eS\89u\18\ f\1fi¾kÏ\17ûºn5D\1dOÆâäHÉ'
+\0`S«¥Úßz|÷¤zÝÓxÝÀy ¢û\9ejêø\1f\0\7f\0¿\18       L
+endstream
+endobj
+1948 0 obj <<
+/Type /Page
+/Contents 1949 0 R
+/Resources 1947 0 R
+/MediaBox [0 0 612 792]
+/Parent 1910 0 R
+/Annots [ 1920 0 R 1944 0 R 1945 0 R 1946 0 R ]
+>> endobj
+1920 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [341.716 642.722 364.188 654.677]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.1) >>
+>> endobj
+1944 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [315.002 604.864 337.474 616.819]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.2) >>
+>> endobj
+1945 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [404.033 538.696 418.755 549.544]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.7) >>
+>> endobj
+1946 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [358.329 431.099 373.052 441.947]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.6) >>
+>> endobj
+1950 0 obj <<
+/D [1948 0 R /FitH 686.127]
+>> endobj
+1951 0 obj <<
+/D [1948 0 R /FitH 668.127]
+>> endobj
+1952 0 obj <<
+/D [1948 0 R /FitH 632.262]
+>> endobj
+294 0 obj <<
+/D [1948 0 R /FitH 578.892]
+>> endobj
+298 0 obj <<
+/D [1948 0 R /FitH 406.2]
+>> endobj
+1953 0 obj <<
+/D [1948 0 R /FitH 385.43]
+>> endobj
+1954 0 obj <<
+/D [1948 0 R /FitH 351.889]
+>> endobj
+1947 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F49 457 0 R /F48 455 0 R /F14 574 0 R /F83 1265 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1957 0 obj <<
+/Length 1840      
+/Filter /FlateDecode
+>>
+stream
+xÚåXK\93\9bF\10¾ï¯à\16Teaf\18\18È%e{m×ú°vbÅ©\94í\ 3+FZ\12        \94\ 1íÆþõéÇ\80@B¶×É-§y5=ÓÝ_¿\b½µ\17z//\9e..\1e¿Ð\91\97\ 5Y"\13o±òD\98\ 4i\92yI\9a\ 4BjoQxï}\1d¤Ál®uêÿz}ùúêúål\1eE\91\7fù\8cÇ7¿<¿¼z¶¸z}=û¸xõøE:à\aç\81V\19ÜF\9c2\8d$\17¡»ÿñ\v8:\10Ï;ê¹Ô°\19ñ7¯÷ínßÂUiäïr\9boMkló#1z¾¸øëB\0¯Ð\13\87·\ 3\974N¼åöâýÇÐ+àð\95\17\ 6:ÓÞ=\91n½HÁE\ 2?Üxo/~fE\fß-¤\fD\92x\89\8c\82\97\Ãݳ¹\8cUè/f2õ?í`\95ú¸'Uä¿-?\e|\95\97\89 ÍRo.D\90Å1\7fû!\8cÃ\9b²m`\14D\14¥A
+
+\1eÒ¼-×\95)~\ 2v*\rýKÓ,m¹k˺b=çUÁ\13k\9aÖ\96K<i¾ \860\86ñD\r
+^öE5\8cLÒ1\8b3\15¨\84\9f\f-~jëD\ 4\1aDq¦¾ªPE­Y\e\v¯\96\8b\ 4$\13°ùû\fLi\1a·ZÜ¢\ 2\95ôwÖ\14 \95)x\89ðBµÞÍâÄÏ7{Gµª-ï·Ýw˽\9d\93J\85Ì\ 2\1d\1e\1a~\b«îfS\93Í\96¸÷gp^{±\861T\ f\ 6Ñ´öâ0\88\ 5¿çÝ,\ 3ql\99ßlP\ 5Qªü}c\8a/à9\96I Cñïð,d\90*íÅ"\ 6Ât\84çPÇ'xÖB\8dð\9c%â[ð\9c\9cÁs¦\14áy6\17¾\9d  ÿ\0kõPX\ 3~\ 3ÀÍ\83a\9dNØE¥hd\aë7ð\8a\11pQ0`&D2\96þ\89µ9i\8c(\0*ZD#Ñ\ 5Æ\ 4ÀíuM\93Ø\7f2\9bÇ\91ðÕÜl̶\87d\1c\85\80\ 5ä¥\81\17
+\9c oËjÍ_Üß\96\ 4Ö[º*\91\10\8eôø1\95)×·HrCæ«-ÂJ\80\15On:³â\ 2ÁÆ3ò$\9c\17\9d\ 3²/\85ã;Ð(ä-°\9dJ\80\90NyO¯02B\8aø\ eõAÜ\88ÄH}Q2¡?\9dècýáVÞ3£å²æü¬H\87:I(T\90öt\10ÅÙø-K\ e\b\85)æµ-0X)pÐq\9cà=°\8cù\9b§õ\8aG\8aA8écPx>ú(0\84ð\ f\8c50\16þ\ f\r\9f\9dZqRß\8eïoø\11ÄÔÿ\ 4¬ú\10\97Õ!.\83Æ\95J\8e5®T<Ô8R\902`\9b\95\ 1\e÷xØ\89Ó6î´>\và|·Û|â\18\0\r\93;ÐÓî\89nȲ\87\1aD\1d\92Ä\17Azyõ\ e"\90Ör\9c\9dT\ 2Y$=F\1cç%@OÇ»à%>\11Ç¢¼+\v"q¢ãæ@tís*\83ãf¿å\ 45eÊ\eV%¤Ä\80\ e\875Ñô7\7f\9c¦_gú©ô«\ 4\bxêS$¡\ 2²\ eÙ2ccÂVÎôæñäÄC\88\ f\8b\19eAxÖÍØpäkß.ðö¦ü\ e\89å´M£\f_*|\12\1aW(´\8cRgFØØæK[óÞ±\9cx<\881ó³\12÷\18=âp*²\82Ü\9cõ\85Ó\94¤i\90ÄQG0©5\89¥s¬Æ\80ÿ?imÂ#\80»Î¾¢5\15\88ã\82ñC(ÔÃÔ\86ñã\8cÖÀû\9dwax \95\1dâE\fùae G,Ýre¹$K(Û\94çÕ\ 4\15\ 2yR&ºøAsâ\eeaïn¬N8ÙvþÇç\9cûq\9fl6\91¹¾ª\7f¬J{íN"M`u%F\ 6\98®é@ô ;­é\1eرA×\ 5\89MB\13\10KÉw.nË\86á´³N\1cSì­q1hßnÊʸ\ 4|[£¤÷®×â=×\92\90²`·c\ 6ÚÛr Sþ
+\\82Ï\15\7f\15ù\rh}cÎ6\1c¤iIÝ\9f{$ÒB¾\18Þ\86Ñ´áíe½\85\ 6\98î\83UÞðiÎËq®e¢\94\12\ e\1d#àpd`L\ 5t¬Æ $°¢l
\9cñ°XßÀñÞ4.©ª\0
+ù1LV¶ÞR-Â\90Ó]\84\ f\8f$oxóPÍÒ\12\8aQ¼1sï\83\9d\86\1c\0g\ 3×@
+r\8d\0k   Õ\99\15v7yÛR\83I\ f\0\97éú
+(¤áéÍ\14²\vü\81°\ 5ÃS\1d\fNYQõ\ 1³Þ\95`ÎÏ4\§±\86\ 4\16|ÀÕt\14  'tO0ô3Xº\1aÛU\8a\11 æ
+Bãsàz\877\99\8a©ÊÕÑgëzS\98jJ\1c\173")\+%ÃÎÜ\ 2!uWÖû\86WCRr\ 2\89ý\86\97-Ïú\8fÑ\16\8fp
+Ýz°&Ýw\91cH\86ñÒ6mÏ\8e*\1fnúÝ\8dÃW»Ô\94¯\1c\8dô©M\81±ä\98js^Ò§t=ÅËO\8e\98ß-ý¦-7\e\9e¶Ö¸p\88\ 4\r\8f®éqØ\96`"xgd\ 6\ 5¹ìZ dqëØîö\96»àº1\8e\13øÐ\84Úé÷D\1awNKý\11\15A\1c÷áäÔ5q\97\\13'\ba\1c¹\8e¤Sì\10¸\13Äyî.àçppB\8e\96÷)\97ÀØö'õ#lµáâ\12`Êgv\8f)\9b\90
+=%\86ªI\fµ\aö¹-\@ül,r\1cýzr~ª°YßoÚqX$_!\97Á\8c\81O\9d\88\91\10tm^­û<OH§\1a\7fi\9a\87JØëãÍ X^¡ÔÜy!\12$ýLq\13\14µvÓɺ\15O\86\85¨ì;=í\1a²Æi\90Â\94Æ0\85K
+S²ë÷pÂa
+gÃ\f\ eË\ 3à'ÃeN\17\88\8e\11ý¼:@\12OÆñ\ 1õ\1f\92?W£\ f1¡7-³° ¹!\aBf\86\ 1\ 5ª\10÷ã\f\96\84\97\f\83D\87±\93Ûº+rÇ\89ÿ\15à\1d´7üuÛ\8d\90Ïÿ\ 1Jh\88\14
+endstream
+endobj
+1956 0 obj <<
+/Type /Page
+/Contents 1957 0 R
+/Resources 1955 0 R
+/MediaBox [0 0 612 792]
+/Parent 1910 0 R
+>> endobj
+1958 0 obj <<
+/D [1956 0 R /FitH 686.127]
+>> endobj
+1959 0 obj <<
+/D [1956 0 R /FitH 668.127]
+>> endobj
+1960 0 obj <<
+/D [1956 0 R /FitH 634.254]
+>> endobj
+1961 0 obj <<
+/D [1956 0 R /FitH 562.465]
+>> endobj
+1962 0 obj <<
+/D [1956 0 R /FitH 526.6]
+>> endobj
+1955 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1968 0 obj <<
+/Length 1754      
+/Filter /FlateDecode
+>>
+stream
+xÚíYËVÛH\10Ýó\15Ú\8d|NÜé÷#;\b\90aN\80\fñÌ\86°0¶\fNl)\91L\92\93¯\9f*uK\96dc\9bÄ3³a\91Hên×ãVuõ­\86Fw\11\8dÞ\1c\1c\r\ e^\9eÚÈ\11§¹\8e\ 6\93\88iJ´6\91\9a0n¢Á8º\8e\9díÝ\fþxyjDs¥£D8\ 3bÊ5¯\7f?|78¹êõ\85\10±!½¾16>½:<?ñCÇ'¯/\8fOPÎ\ 1\rÊÛ\9aû\95À>70(¼Ø<\99$y\92\8e\92^\9f;\13Oòá<¼N\v|Úø¡HÆa$-\16Ép\fº¥àñÙÄ\8f¦\99\7f\16\ f£\1e7ñ½ÿº\9dá°\8daÌÆ\9füXò}Z,\8a\17`/\95ñâ>I½\ 2xóó\9fód<\1d-²¼i\0\bN\16è\16¸Ôg\8c8¥¼å\8bÌ;þ#É3Òò;b\9c0\83\8e2"ªå¬³æº¯(\8d\ f\8bbz\97\ 6ôi\ 3-)!Lº\ 2\7f~;õk\9a\80r
+\11\92Ò\v´g\9a\8e\93ïø*ãlâ\87ê¹ùp\94g~Î\ 3\12´O~z\94¥\b×b8M§é\9d\1fë\0é­\10-3\ 4\81xTv¬³\14Þ\8c«\16tp\0\e,aÎb~\90\90\8fü\89X)Âim@þ\812¹j\ 3\ 3@­k£eMüµ§T<\9c=\84Ï\121xÖóWËüÄÏÓ\9e\15±ÏQü<\vXÃë(\9b=ÌS|·µ\94AÏÊxx;KJw0T4Êï"ÿrU:\86Ëa7±Xöú,Ö\1dl¤!L³vÞ\8d²<O\8aÏeP²t\\a
+ò±tZº\86×F\13ÎdåõùÑ9ìÑ÷«àhF\98­·úõ\1a\8c91ÚnLG¦I½à¦\1dÀîódpð%ÀÁ \7f$qÔF
+ò@Ùh4?¸¾¡Ñ\18æ`Ë\11\ 3\ 5ã[¹r\1eq\ 5\81æ\18ÃYôþàÏÕâÆ\19%ÖêHiK¨\vÉôÚçï\12¨ó0\01´R²V\88\19bøô!FoÖ[­9QRuÍ\96\90ÐO7[A\18¤·\9a\1f¨¢g\17XwW-P\9aPáÊ_     xv,\10M\v\88³\9bô+G(·-ý\17\97ç\7f\83rÖë+'yÌ\96æ¼Ë\93¯Óì¡(g±.ö%l`ÉC\96êPîZö_\1dzY Êx×d9u\91¥I-§S_ùî\bÀ\81"¹Ý\a\ 2       CåwK\0ÀHC\9f\0@0_ìn>SDÂÑ»\aóA\127²2\7f\8d\ab\1f\1a\8d\83ÂâÚ\1aß\1e¾\1fxȤTf3d°Ca²\r\99Ü\1d28s\14ÛKÄA\92`n;d¿®±\82¬©\11\1e3á~\ 63µ3fÒ1¢ô>Ò\f%    \1d\82þæòíñÉŪZ\ 1nrËö VP\88\80ik]\96\81\1a4jÅ\9bl6NÒ%hN\11ae\e4½;h\104M÷\91h(IR·#h¿¬¶\ 2­©µ\82\8c\e8þv\85,Ôs³;dÚ\10­ö\92g I*±uoîAcØ\9b-\8d§Èx/ÿº
+%\8ds¶i{®§\a\12\98\95Y5m\13«¡\8fµn\1c\18\96\83¸H\81¥(l\84\ 1²\95\92b\86ÆLêWX\7fe\9bÖÈ@k\80h\ eçÈ4\93Âÿ`\82Ý\ e¾\9c\fK\86\7fïWפ      ~ày\93lð¦MÜ\ eNC\89,\ 2»<J\83\95b-¡?\9b<Þb´   ¾\ 5ÇŦ\ e\ 3SÕÔ<w\1a\9c\857}8Ëj\9a\õB³d\12f\93ñ]\18ë4L\12ÈvÙ$\8d±\ 5Åï²?}Õeé\12ÒµÙ¿`~\fëÄص\8dQ@\euÝÏÝ~\ã¥h²ùÒHÉ\947\12\ 33îgù8Éýhè\ 3ñ\15ÝÂg§ç[5\81IZÖ\9f\rHÛr«\85\ 5¿\15^°Ç\12ßÒdzw\8fq¼õ\r\ 2»u°\86$¤|Õ`\98/3ÌIbËƯQgêð\14\81\81Ë\18:V\90ô-äÊC\b\1a0Ǫi\r\8d\97ï\81ÊÉV\90»\r\84k\ 5OE\f\88Ý>\161ÈÓÕÎ\8a\83\14^7<Gxùq¼\8a\16Ä\94 ¶­±2\9b\82\ eµpÙ<ß\84\1e¿ð~\86\ 4÷\97\10Ý´Ô\82X\10ÑòsúÄÎ\9aC9ä˶ïãÚ[\b%Íÿq\vÑ\86±s\v±\rÈu·\10ð\ fÐ\ 2ÔD\85Öôñº¥xpH±Ö%\ 2\8c\97\ eÃp\98ç­R\f\9f§x-\10:Lø¬.\11àµÎå\86\94e\85\7fü\12\ 1\96cåïÜB!\97\90ë.\ f¶_\e@)¢bO×\ 6fcþ0ì¸L'¿\93/\ fÃY±F\9eÐDP»íª\aÚéå¦ën\væð`2íH\1f\17¥Iï®éM§¸@Øu\15v\18ïÞð\ 1\86LµÕ\1cmWst¶IÑ\9a\92\r\eÐ-!yrâ3l^µ\vvê*ñ×gþ%\98\94\7f\9b\16É\voØ°¶\Ö\0\89\96Ýõ¾X\7fSZ\1e\9a¬\16ãÑcÅø_0\ 1\8ek\1eßò¿ñ\9d6uªG+\8ddf{ù\83sF+·\91!qb\99h2$\14\\1e \92Ù\8a!áXà\15¶>ÕM`H8\96fygÕmYÀ³Å"\9bû\81j±    ¼ÃVkM\83©x
+\0f\9bîÅÉ:\8a%      §ú×\19\96tp\1ao<#À\10\f\vø\10à\ e\94¹¦\82\15Ëâ\96\1c.Boqh;Ë\ 2\ 2¯ÅÓX\16
+\9e\ 5"\ 4ÿ%yßG\aÇS é ZØ ^ÆS/îx ^\9erYE\94íP®\9aI!Ñ2\15Ñ\1a{e¡,\rÓñ3íz¦]Ï´ë\99\14íjüåç\1föÔ(\17
+endstream
+endobj
+1967 0 obj <<
+/Type /Page
+/Contents 1968 0 R
+/Resources 1966 0 R
+/MediaBox [0 0 612 792]
+/Parent 1910 0 R
+/Annots [ 1963 0 R 1964 0 R 1965 0 R ]
+>> endobj
+1963 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [485.671 602.221 505.375 613.069]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+1964 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [485.671 328.593 505.375 337.504]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+1965 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [485.671 131.141 505.375 140.052]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+1969 0 obj <<
+/D [1967 0 R /FitH 686.127]
+>> endobj
+1970 0 obj <<
+/D [1967 0 R /FitH 640.682]
+>> endobj
+1971 0 obj <<
+/D [1967 0 R /FitH 619.044]
+>> endobj
+651 0 obj <<
+/D [1967 0 R /FitH 445.469]
+>> endobj
+1972 0 obj <<
+/D [1967 0 R /FitH 419.847]
+>> endobj
+1973 0 obj <<
+/D [1967 0 R /FitH 398.707]
+>> endobj
+1974 0 obj <<
+/D [1967 0 R /FitH 372.974]
+>> endobj
+1975 0 obj <<
+/D [1967 0 R /FitH 352.889]
+>> endobj
+1976 0 obj <<
+/D [1967 0 R /FitH 339.607]
+>> endobj
+1977 0 obj <<
+/D [1967 0 R /FitH 313.263]
+>> endobj
+1978 0 obj <<
+/D [1967 0 R /FitH 299.428]
+>> endobj
+1979 0 obj <<
+/D [1967 0 R /FitH 285.593]
+>> endobj
+1980 0 obj <<
+/D [1967 0 R /FitH 271.758]
+>> endobj
+1981 0 obj <<
+/D [1967 0 R /FitH 254.05]
+>> endobj
+1982 0 obj <<
+/D [1967 0 R /FitH 234.35]
+>> endobj
+1983 0 obj <<
+/D [1967 0 R /FitH 203.193]
+>> endobj
+1984 0 obj <<
+/D [1967 0 R /FitH 175.522]
+>> endobj
+1985 0 obj <<
+/D [1967 0 R /FitH 155.437]
+>> endobj
+1986 0 obj <<
+/D [1967 0 R /FitH 142.155]
+>> endobj
+1966 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F83 1265 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+1992 0 obj <<
+/Length 1329      
+/Filter /FlateDecode
+>>
+stream
+xÚíXMoã6\10½çWèV\19¨¸ü\12Ií-±\93\85\8bn\12dÝö\90ÍA¶eG­#¡²³»í¯ïP¤dQ\92\14.\16ÈÅ¢¨ñðqæqæ\81Ø[zØûpv19{w%\99\17¡HPáM\16\1eÁ\ 2)\11yB D¨ô&sïÞ\97H¡A ¥ò\7f¹\1eÝ\8c¯?\f\ 2Æ\98?\1a\9açíÝåh<\9c\8c\a\ f\93\9fÞ]©\86\8e$\8f`µÒS\14i\933lׯ\9e^@\85@¡T0\90ð_f¬Ï\91cíÝ\a!Æþùz\9d.3»ô=yÐ#îo\1e\133õe\10
+?^='f\9e´|`ÄIè\ 5\84#LÌ*\17\87\18ï[§Ü´ÄÍ(R\8c"¬ª]O\7fï\ 6&BXÖai!\0t
+\11ÈB\13f\9a¦½@o\0Qñ5]'?\1a\q\r\9c×áa\ eì°\ e\ fóÿN\8a¼³z\84$\93ð\14\b\vnVÿ\8cC<\83\1fr"\b\12\ 1i\ 2\b#\91¡A N³{lWå\15õûV\1d/Ìÿ§«|\10PåÏ\ 6ðóG\ f\11 \8f\91b5\ fÒ.\ f\bA\11,f-Òµq\9cå\e³\87x\95gËÖ&ì\80ûSX\úùf\93?\99\89d¾´6ù¢e;3Hç\ 3âÃ\f\81Aù}QÄOÉûVô9°\8e\127\10\9a\0ñ.\ 2ØÃÒ³\7f \12aûÎ\ 1¡\88\vQY\18¸\1c×p\93y\90\17ó¤0³iVãÿ¦ñGf\9fðå`&\b\83\ 2â}©PH\84\1fÖÆ1ø\ 5\8f_õO\85"KÒå£\9e\98\96\85æ\1e§~\8a\12T\ e        \0Õî\81Ç*\ 2§ú C\9aCÑÜ$\ 4\7f\r±¯²³z~²Õfú¼±9Ìì×Âb(gçæ%ë\1c\19\85¨\b»§vº+i@â2\ 4pж1 à\ 5ʾ\rÂÅðft9êF*\ 4b0ZYÝ÷\84\9b")äÑõÏ\1eSÃ~^±ß\9cÏ69\ 5C
+\\98}ÚÚ\90¢\97±\128\17Öð\9fúà\ 1õC.]Zj\84Ù<ùf@¶N\18ó\9fâ\19\1cÌ\92\8dR³Q\ 2\eËϳ<Ó\89ÛÄi\96VGú k)f\88o#ýâFB%äS·U§\91ì®i!µû  \89S+á5w¿Sÿ.Y$E\92ÍìëÕ@\ 1S\r£ául#\ 5Ã\9aÜ06^\88?\19((ÖÓUÙ=Ï\b\0Á^±ôÌà®\ 4¥Í¡\r\b\17,a\88*n\ f\94Mÿ,/\8ad\9dgó:°\9b¼\87Û\12z?®\ føÇ\8b\8f@îOÝ\80
+\82\88\92G\93»\97>п(\15-z'\7f>Ç«u\8f?(M\f×9,>cÂ{\b¤\18©\8cÞwz¶D\18K'ÑÇÈ'z"ùD¿OùD_+\9fÂWË'úJùd[\81:Íî[ò)Ú]jä1ò    B)÷ª'\8a\98P\8ez\92\95z\82\9edU¶`®°ÍÛ\9aXÉTþ«0\83ÚÔÕW\8eq¾hÙn\ 5\8béü\0\9dcå6þ>±Å\11Åâ¿\90\939\v÷J-\ 6\85M9=\8d\13(ÏZN\99\90[\9cÔÝN\eéýêça\9dÅa'!9¤³xSgiÇZgÉJg\ 5\8d\8fVqÉ*# ¸\8c¼\8a8èKáv\83J\86\1dTPVagsÇ\98\18×\8dÄ=\ 25²½ú+|Ó_oúëM\7f½é¯Cú\8b\9dH\7f±ïS\7f±ÿ_\7fý\e\b\14
+\9cl] \0\7fN²xK\81\11²³ÚÀa\84R¯»\9e\1eåvÆè\ 2Ü`ÈÚ¼ßÞã\a\0É).oÖÊ!)U¢\9d-\ 5\94±Ô¸õ(.\92z\9d@\83µ¦°Hf-\1aM©\16p\84%!n¡\19\rõ]sO?\ 4eC;Íb\e«®whA*ªÕÒÏç\9f&£a×/\17(âêP)R/ª\1c\ f\ e\1aP2÷¶\13\84í^¶´ê\ f\85 \11ùr\19\190\1eU\97n\11\88u'ü˼þ\ 6\ fA­@jÚ\19f\14iÙ?Ê\99ÛÑøWmÍÚF\86>ú}Q\94*ºé§ReZË\95é¦nº«\16\7f\ 23hV²½Ws¹ÖÓ\9eÜÛQ\al}}Êý$.¥ÁcU®û\18\01gÛ;Î\1e½\vEPîÈ~õ¼\9c\9cý\ 3Ø[$\87
+endstream
+endobj
+1991 0 obj <<
+/Type /Page
+/Contents 1992 0 R
+/Resources 1990 0 R
+/MediaBox [0 0 612 792]
+/Parent 2022 0 R
+/Annots [ 1987 0 R 1988 0 R 1989 0 R ]
+>> endobj
+1987 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [431.873 494.466 451.577 503.377]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+1988 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [431.873 293.843 451.577 302.754]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+1989 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [191.441 116.695 211.145 128.65]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.47) >>
+>> endobj
+1993 0 obj <<
+/D [1991 0 R /FitH 686.127]
+>> endobj
+1994 0 obj <<
+/D [1991 0 R /FitH 668.127]
+>> endobj
+1995 0 obj <<
+/D [1991 0 R /FitH 653.619]
+>> endobj
+1996 0 obj <<
+/D [1991 0 R /FitH 639.609]
+>> endobj
+1997 0 obj <<
+/D [1991 0 R /FitH 625.599]
+>> endobj
+1998 0 obj <<
+/D [1991 0 R /FitH 607.479]
+>> endobj
+1999 0 obj <<
+/D [1991 0 R /FitH 587.305]
+>> endobj
+2000 0 obj <<
+/D [1991 0 R /FitH 565.629]
+>> endobj
+2001 0 obj <<
+/D [1991 0 R /FitH 539.547]
+>> endobj
+2002 0 obj <<
+/D [1991 0 R /FitH 518.936]
+>> endobj
+2003 0 obj <<
+/D [1991 0 R /FitH 505.48]
+>> endobj
+2004 0 obj <<
+/D [1991 0 R /FitH 478.961]
+>> endobj
+2005 0 obj <<
+/D [1991 0 R /FitH 464.951]
+>> endobj
+2006 0 obj <<
+/D [1991 0 R /FitH 450.941]
+>> endobj
+2007 0 obj <<
+/D [1991 0 R /FitH 436.932]
+>> endobj
+2008 0 obj <<
+/D [1991 0 R /FitH 418.812]
+>> endobj
+2009 0 obj <<
+/D [1991 0 R /FitH 398.638]
+>> endobj
+2010 0 obj <<
+/D [1991 0 R /FitH 366.944]
+>> endobj
+2011 0 obj <<
+/D [1991 0 R /FitH 336.987]
+>> endobj
+2012 0 obj <<
+/D [1991 0 R /FitH 318.314]
+>> endobj
+2013 0 obj <<
+/D [1991 0 R /FitH 304.857]
+>> endobj
+2014 0 obj <<
+/D [1991 0 R /FitH 278.339]
+>> endobj
+2015 0 obj <<
+/D [1991 0 R /FitH 264.329]
+>> endobj
+2016 0 obj <<
+/D [1991 0 R /FitH 250.319]
+>> endobj
+2017 0 obj <<
+/D [1991 0 R /FitH 236.309]
+>> endobj
+2018 0 obj <<
+/D [1991 0 R /FitH 218.189]
+>> endobj
+2019 0 obj <<
+/D [1991 0 R /FitH 198.015]
+>> endobj
+2020 0 obj <<
+/D [1991 0 R /FitH 165.885]
+>> endobj
+2021 0 obj <<
+/D [1991 0 R /FitH 146.147]
+>> endobj
+1990 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2025 0 obj <<
+/Length 1333      
+/Filter /FlateDecode
+>>
+stream
+xÚíYKsÛ6\10¾ëWðHMC\ 4\8b7<\93\83cÉ­3éXµ5ÍAñA±i\99\1d[J%%\99é¯ï\82 %R\ 4©ÈvëL§\a\8b \81}\7f»XÀ4\9aE4ú¹÷vÜ{}j"K¬b*\1aßF (QJGÊ(\ 2LGã\9bh\12\ 3¥ý«ñ»×§\9aW\97ZJ¸ÕÈ'_tòËñh<¼è'\9cóX\93~¢µ\89O/\8e\7f\1dúO\83áÉù`èøôh!½í9\1c÷þì\ 1\ ei\ 4¨\91"ÌÚ\bµ"\9aÙèú¡7¹¢Ñ\r\8b(ѨÁ·|éCÄ9#B\18\1cßG\97½ß\ 2ÖiE¨a\91\92\9a0¡¼â£      ½rjE\80\96\0±Rú©\8fTÒ÷ø\ 3ù<\97\84Q\16U\17\8c&ài\13F@È&õ Bn        ¥j\87\9cyr\8a\0uU¶±|\87\98od+k\ 2Ô\17[rML\9dúCIÍ1\88\9dVs"4Û¡-­¦DÀ\1e«ÑÓZï\90\17V·é½%\16\ 4\94\bë\9d´ùì¢ê4\8dS5§\rÎ~Ï1\18Æ\18ÆHó\ 6Æ\ 4jùý\183\8c0ä¡\98!\88û"\830\a\18¥1m>\85{vÌs¦Ý|\8e\92ºµå"haÚ1ßÎ\14ö0}\92¦\ 1\8dD\88\19\1c¢i\eSØÃ\94Õ\98ª°O\9f\90o5>\99õå\15D\rG@¤`eyýHË"\\ 5\e\96Ä\1c\8bù\12¦ú  +øm\ 4`òÑ\98{[\130\16\1d\9b\8ae¢5Ð¥\11ß\e\9b*\91ÓPËæ\82\uÉq\90³eæ\10ÌÃ\1eÌC0è{0ÿxmU7îá\9fÀý³û¶M[^ð\83Ú\aÇW\1d\82~øwÑ\1f®øB⦮\ ei*hkë¤\81\91àø¤Eë4î\e\1eO?ݧe_$ô\11ºS\88ø\83\9bI³Ù]\9f\99x½ró"\9eÎo\8an)û\9a­\16Ë\95\7f»],ýü°\ fñ´\9f@|í¨îüìeºö\83Å­_uüµ/U<Íî·\82\a'~j´Lo²ëµãÜÕ\89¡ÿ    \ 3ì,,QTm7×OåÞº]9I$úúxµÊfs\1f"a+^\91\14\9b&(\8348\19]\f\aÍHJ\8eÝf¹h}W(\8dfÈxzÿ¥xý+].H]x\ 2\14w[DN\ 2Âu8\eE¯Û\14=C\1f1c|×\87#\eg+ÿe¾\98'NÄ+|µ&\9e¶Y\84ÙC\98\14{MÂîF×mrR*6¹W§k@\86ÀvO˽"\80\0ØrÕO\88\vΰAòíìNB!(AðJ>ñ\80X4\1c\13\97îtt'çÃÓÓ˦xT\12ì&´\93ÑÛ3\14}\85\7fÎ÷»\81RØFJUÄ ¶\81ºÙ\1f(xt ,á
+~Ü@ÁË\ 5
\ 3Å\b\17\91Péþ8±ÿjB±\97\8b\13k\8f\13àî×Ì'\8c\86ν°'XüÊ\8f|°l=Xº+X\9a(!\7fÜ`ñ\97\v\16ïJ*Ky#©f\a\ 27ämÏó¤í´Íù\8aheC\12\0ê\8ah»YöæMS   7Ú¸<?w£ùqÈ;\8cZb$k¸ç®\vÆÎ\ 4·\89¿*\87à\87\95\97$7\9a.ÓbîþÞ\7f)ñ~TçÏ\14áÚÖÓ*#-:\ 4ÚV4ds#öGÀ»\f\9d«\83Î\15õ¦I[Ùl~k¬\fæÿ¦hv¢\94\ 5JJ@ª\10Ø·Â\8eö5X\91-ôòº¡Y<[¦Óuºô/ë»éÜ\8d¸;b¸JbD{%I\\ fînHjéöXH\a\80Ì\88Ù:ñà\9aÛè4¥ ù¾è.Ì
+\90fah\9c£~ËoÙ*Í\8b)\8b³\10Tð´À\r<\vV¬Ö{±b\99~\84+h'VX'V¤®aÅ@\ 5+¦À\8a¿¾\ 4\\8cÉV?5æ\0Ês·ãh!´~j-|\12pXÀ[Íê\86çT.w\91ó\14è\bÜÍö\96\19ó²Ð\81ÿ¡s\0t`\v\1ddi\8a;kæÛ\12©    ¸KzÜ\9cLi¤&Ø4ã\8e
+LÆgó>\aÔ\v\7fÒå:\9bÏÜÍ\8a,4ÆA~øÇgqøÏ\16óò}\81\ 3\88¯ÓÕ*`\8c»Ç1î¿\ 3¹À³ùç/î\9eÁðøót9}H1\1c«£à-ÂpÜû\eTnòN
+endstream
+endobj
+2024 0 obj <<
+/Type /Page
+/Contents 2025 0 R
+/Resources 2023 0 R
+/MediaBox [0 0 612 792]
+/Parent 2022 0 R
+>> endobj
+2026 0 obj <<
+/D [2024 0 R /FitH 686.127]
+>> endobj
+652 0 obj <<
+/D [2024 0 R /FitH 442.962]
+>> endobj
+2027 0 obj <<
+/D [2024 0 R /FitH 411.364]
+>> endobj
+2028 0 obj <<
+/D [2024 0 R /FitH 397.473]
+>> endobj
+2029 0 obj <<
+/D [2024 0 R /FitH 370.688]
+>> endobj
+2030 0 obj <<
+/D [2024 0 R /FitH 343.902]
+>> endobj
+2031 0 obj <<
+/D [2024 0 R /FitH 317.117]
+>> endobj
+2032 0 obj <<
+/D [2024 0 R /FitH 290.331]
+>> endobj
+2033 0 obj <<
+/D [2024 0 R /FitH 275.501]
+>> endobj
+2034 0 obj <<
+/D [2024 0 R /FitH 259.233]
+>> endobj
+2035 0 obj <<
+/D [2024 0 R /FitH 233.885]
+>> endobj
+2036 0 obj <<
+/D [2024 0 R /FitH 208.537]
+>> endobj
+302 0 obj <<
+/D [2024 0 R /FitH 171.719]
+>> endobj
+2037 0 obj <<
+/D [2024 0 R /FitH 151.503]
+>> endobj
+2023 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F49 457 0 R /F11 573 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2040 0 obj <<
+/Length 1528      
+/Filter /FlateDecode
+>>
+stream
+xÚµXKsÛ6\10¾ëWðHÍ\94\bÞ\0{éÄ\96\9dq¦±ÛZíL'É\81¦h\99\13=\1c\8aªÛüúî\ 2$EJ\90l7Ó\13\9e\ 4öõ}» \8dæ\11\8dÞ\8dΦ£7\97FD)I5×Ñô>bT\13«ÓH[M\187Ñt\16}\8c\r±d\9c\18cã߯'7W×ïÆ\89\10"\9e\9cûö\97ß.&WçÓ«\9bëñçéû7\97¶w\9eà\96\18mà6w\12£\f÷\8ch#ÀÅtôuÄ K#¶»[\ebx\1aåËÑÇÏ4\9aÁâû\88\12\93\9aèÉm]FBZ\92Jüp\11Ý\8e\8aôï\ 5Ùá¬H+C¸ÔþòëlY\8c\13I-\8f§cnã\7f\1eÇ    40'8\93ñmù­@á"Æ4I\85\8e\12ÆHª\94ÿø\13Uô®¬7Ð:\15"a\89\ 5\ 3õ÷Ü\96óU1ûi\9c0Ni<)6yU>Öåzåí\94­f¾S\15\eØ\13×Õ\98Åeîº%t׫\8d3NØ("%F\1c\18E¦ö´Qd\1aò.x\ 5\ 4ñR\9f\9dßL.&\87®3\820É[Ï]­Ðdu1/*§>\1d\9açmUeΦn\11\82G\e\r\ 3[s¥ãëµë¨øíÊ_9\10Ð2Â)kï¼>»=\14\8b\v"m·%)\16Ųð²\8d\13ee\9cu\92¸áúÞI\94HN\ 4\95û>e*\9boP 4.W³2Ïêr5DZ\8d\9f\1eÀ5Ð>øå»ÅÚE\8b\9bû²   Ù «
+ïßÜo\9d\153\12Ð\11\8eã\84¥jøñ\87³\ fà\86ÛÿÛ\râenàD[ѹáCÈ\ fB\12¡lØ\ f\ 6£} J¢$ÑZ\f¥\ 5ß$Z«Î^Îö8±l\r¸ñãûu\85\1d\1d\17\93¾î\r¼\97Y^­½\ 3\86Îz¹\13Îo../\9fõ\ 1\9f\800@\86¯ó\ 5#:\95CHh\10\92Á\8e\10¨¨«\e\1dó\bt\ f\80Ád\1f\19\12¸Nµ{>QÊ\ f5±DÁ7Í\16-áJÍú\90á\9a:·àô×m¶J\1aô\0_Àõ\ 3ýjàK$4¤ºó©ï4\9e,\0Y:/»xÀ¥¿Æ\10mÙb[\ 4±ã<,¤ÜyØ\8d\86\8eôsåÊ·ßÊyò-\9bûÁºJBÇÎ\8a\8a\1cçTÅ\14¡@ô¯M4AN\95\162\1d\ 4\89»÷f[?nQq+âǬ\82ÄS\17ÕæÇã¢H-\89\ 4F>)\8a \86\9dÊy,\85³x$\95\0\vôs\9eà&}&çQÐ\13ÒË\vr\9e>\92ó\8c<Èyr\90óêªÌqåD\96\93B\13)Åé,\170CØ#\1cÝkNC\e
+\ 4&Í÷C[\1c\85¶h¡m\8eBÛØç -\88\85\19h35\84¶D\16\86Â\ 2\855\ eÝ\92{tÃ
+¢Û)é`ìQn\88Üçh\ f\8fB\e\96\0Úº\81\e{0\eåÁlöèº9ø\0Ú\8azhC»\836\fÖ\95Cq"S\19O\1f
+?      µgàÌN\10ØÍ\8cSU²^Öp£ý\8bqî©\,ü7w°fâæ\80íc\98U²ºIíá(\16\86\ 1ÍêW\839\18ÅB*\ 2ÉÊßüÇ8\ 5\ 5«2»[8cCÞØn\8aÙ      b\11\9c\92\94}/±\09p\16    \ 6P\14}báÚª}bá¦O,©\ 5\fªï¨¥¹\10êt-ý\ 2^á)äOþz^±\ 1\87p\8bÞmhåç··S|\a1xV8Ö0=ÖPà9­NQ\a\ 4\8a\11ìTU\80¯\83\8e> *5\8fÅ°Ø©^\ 6Ça¾ö\8bY¹r5\15ÎÕ\ fÞ!ð¸\12j\8fè\97ë\r\1ed8\983o\ e^àY\86A
\95³~\ fê\8b+]Fÿ!\ 4\92õªðDãØ\0;ec\9e\15y\rS¡G\aû;öp£ª¸\ f\82±¨\8a\14Þ÷\98i\89'3\96b\81ªöÙ\f\1f«Í\ 3­Oò\0wàFÆ\82\15\99c\1d\ 5iá±*à\91P£!p\88\86PÆì\fá§\9d\ 2\9a<(J¾­ª\1d\8b\86\8bÖ}-t«\ 5>c¡B\vh`\82\89Çi 9pG^o³\85ï»c¸î\8b\8fÃ{|\8aV¾_·ß\81´Éq]ú\8a\ 6\a\84
+pCû\ 5xð »2\90¡=\8a\ 2\ f ¯²Ðûo\1a¯-Uø¦+þö]\97\v ­ÛµÖþÆa\b&¼ýMì\82îK{\80W\1a\1eßt\ f3}T û\9a4õRM\97ÿIU\1eTU0Ûª*\9a´\87Sµ_3ÝË\bæ\ e².Ì\ 1[$GÕì8ä0D\ 3ºjJ¨ê\1e\8e!\15-Ñ»\rAsq-\b\ 4÷0ä+(;äë\f¦Á`a{Iã<Ë\1c÷°\18#ÄH\1f!ÐÖí\16`\9c\96\pÞ\91ËQ;5¿\ f\1cGr\b¦¦âÂþ\ eDí;\17®v´\fs=\16ĽÈ\1d\ 1\92;ú¶\r\18PiÂiW+\ 6ã\8cA&\eø û!×û1÷/pWÕ°
+endstream
+endobj
+2039 0 obj <<
+/Type /Page
+/Contents 2040 0 R
+/Resources 2038 0 R
+/MediaBox [0 0 612 792]
+/Parent 2022 0 R
+>> endobj
+2041 0 obj <<
+/D [2039 0 R /FitH 686.127]
+>> endobj
+2042 0 obj <<
+/D [2039 0 R /FitH 668.127]
+>> endobj
+2043 0 obj <<
+/D [2039 0 R /FitH 500.697]
+>> endobj
+2044 0 obj <<
+/D [2039 0 R /FitH 464.831]
+>> endobj
+2045 0 obj <<
+/D [2039 0 R /FitH 357.177]
+>> endobj
+2046 0 obj <<
+/D [2039 0 R /FitH 321.311]
+>> endobj
+2038 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2051 0 obj <<
+/Length 2207      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\19M\97£¸ñÞ¿\82[ðËX+      $Á^òús3û2»\93nßzç@\83Úæ\ 5\83\ 3x{f\7f}ªT\ 2Û\98íîIr1B*Jõýe\1e¬\ 3\1eütqµºøá. R\96\83Õs 4gZ\9b@'\9a i\82U\11<\86\82ËÅ\97ÕÏ?Ü\99è\184å,J\ràq@×\7f¿ü¼º½_,£(
+\r[,\8dI»ûËO·´us{ýëÍ-â¹àþöÛÕÅ¿/\ 4,y \ e7kÃ\8cL\83|{ñø\85\a\ 5\1cþ\1cpfà¦\17\aº\r¢8bFà\87UðpñÏ\19.\8c\ 4\1c\81V\86ÉX\13}¿d[»XJ\9d¨pµ\90Iøm\aoI\88{FÄáCù\87\824a<RÁR\b\96*EßþÆ\15\7f\ e\9eÂ\ 1E    Kàªc\98\87r]Ûâo\80.\8aTxc»¼-w}ÙÔÄ~V\17´hm×·e\8e'\9d\93Ƽ\14¢\94\99èL
+q\9a¼.\ 5ÃÏ\94\99\ 4Z&\f®&:wUIÊ<\16\98RLj5¨òc\8d\ 2êíÚ¶\8be¬c\19J`K*\15þÒ¸\85\ e/\89\99¼©\9a\16\971àÍjK»e]دì\15æ¤d:\92ÿ£\8a\15Ó\0 Ò\98©D\10á«MÙ¡VE¸k\91R\13æ¶Ø·\96ö
\93'R»\83ãa¿ñ\87y³ÝU¶·Ãç\v\116\ e\9dÇÙ<Ós\ fguÑ\94õ\9aÞ=\ e\1eÞ\\ f\82\8ce)b\96Æñ©Iõ\80=\92\ 2Ì!oPÚ¿ã\ fÊ\e7\1dÆHò°iËuYg\15m#~Üý}\ 1ªÈª½íÀÍâ\98\87W6Ïö\9dÿ¦ì        \1aE\81Ï\9d\13DÓuåSe=þ\86@³¢ \8dl\82Ø\1f{\fUÖ®É9ø)\13\ e 6¡J8-\1câ8ñ\fÀ\86\17\85-èÕq\0Ï\9cdk\7fãBç¥%{££c\1aà5óÛÖ\vè\e]ðTyý.àç_\1f`SñðeSæ\bµ!\98\97²ª<Y\e[ÓÊk\7f\8e\19\10 R\99*â"Õ`Ç é|±\ 4-ÁÂâ"sRF\98\8d_x\ e\9d\eÀëó°ð\0:¬í×\9e\88è$tD"ѱ\10\aDh  5Ä\86½\17\17l9qÁó \93\19ºóf_\15tU\83Òð\82\ 2Ñ*gY/t\86*NM(ôòÉY\bñ7ø9\18\92\ 6Ï%\aB8zêp\ 3\81«²\1eÿ\93\v\9c\ 4\0\84¢\1fäYï\1cÁm\r,C\8cÛWþ\12\12&(ò\84v\1f\94Gj\84        ;\17@iÝZ\10kçí"COú@&Ù\95à¦ß\b¨ß´Ä \11 ð\ eÇ/üd(    \a\a\9c×G/\9br½qn\ 6à\18ÒiUÖ\ 3\17#¦æ/ݼÔ1^l\ f¦\v\9cj\8a\87\188ð¼ß\90\19áÚ\ 1í·øëm²e'É1\10\92 c\82¥ä\8c\ f·\8a        ÌãRq\1eÞ-\12¸¤¥Ël6ú\0\\83&eó}_\92U\10ȱ\8b\11y\94ÝOrG\f)4\8e\86\940\9b5\84b\1c\ayn\9b-!ä\9eÝ\86\8f§DC<ä,q96e"9¤ØlȯS\ 6/;4\ eÂö\8fË\87ÕÍõ#ÿ2ÈôÀ\94\1e\99\8aÃ?lÛL\84µäL)\fÃ\8a\89ô8³\7fǵâû¯\15Lps~kþ\1d·Êÿ\82Ù?¹¶ø³kG#\8a¥:2"|;\8d[¸§\9d\99¯\0pI\15À\8c))L÷É[¦\94Æc\ 1RÖsh$SÑhmíBa4îÁ\97Ï\90I4«±0mÚ¶\18l]Jè7\ 3Ý\8e¥Â\16K\aà3u*\19\9f¦jWÎÌ\10$5K\0Ö_ó4ÃU´\1a]hê\ 5Ò°(\89¼\86|<,gýû£wÐ8=¾\1dªA3\8aã
+\8bë\9b\99Â\8e3\11\89\ 1êq\8e\vf´y7\13_|\85×ù(ÖÔK4¾)o\1aªW(U\97"bÊx1^Îòv\rqt\8feW\94hoß\899±ï\ 4Ë\86Ï÷À\9d\83Ùw\14î\8fÁ©ÚKÆj\ f\ f\9b}_\95\98PP± c)§Z%V\1eìX©ùBµ]\a´¸wT"\9f\86%lê5á\99ÇÅ,áê\94é+ö\96\8b»\1cÿ\8ao£ÓΨ_\0/::t_¿ÞÞÝ=\9c+/FãzSÿÉûõï\ 2¯\942ü+=H5\18TÎÄ¡¡ëHÌ©<®gå±ÂØÓî±\98\0®\95/u\15 Ç\1c¢¨@ÅÇP/àÑ\¶Åý¡HAø¢mv;g/\ e\89/\ 4\9cEÌÔäT\eøxàt\81\15Â\19_\8a\94«\9b×´|®»\18ÚÒT½Kuòÿèº>gF\83©Å§¦\86¦xÆ+\8f\187\ 3·>HݾÉí    \95ÀGÊGn·stB\1d ôH(õSÆøÀë\96®÷2ÉXBáz\9båÔå\99³\f\85{Pú\90i\945µjfÚ6Ì%\19hÿ!\18¿W¦ì,¦Ëó\18p÷ýò\92#        XÇÇ3\12\8bXrðkR(?\8d\9b<¡Â\93\9bCá  {÷öÙ¶¶Îý\17\90ö¡pu³\11\88-\8f\93:¾Arßok\ 2¤*1X\ 2yJOæ#Î\7f3l/_\89¢8\15\8aõT\144EhÁ\93i\1eÓÔ\ 5Åw´Óf.ðÉ\98éCÚýtõ 2ß\8cûhq\\ 4¼\19ùæí\122üè>gº\86\f\9cê\89®\7fbï,éfèI\ 5S<~KñX:ËI:~áA\82      \ 6¼(Ö\12q@h\86
+I\8b\0Z*&\95\1f\f\19\96B\87+ 6º?t¢>3\9eÒ\0­\90\14,\91\ f\1d\90DBhê\10\85]\9f­­kÚ\86VXFGC\16zóý'=ü\87ÎfåÀ\13Äó"ë3ÚÚeÞ¿ÁymO§\9bìÐó\12Ô\93ópë:~x-ì¡Ôsã\12\11^VÕ\3ÚoÜ°!Å\19Ý\16¢\86ë\80cß     G¾\91\8d\8eût\ 2ðmï)CØB\8aУp<¥Ñ\ 1²¶/tò\8c®\87Í·\8cÇæûpe¶\83\970\93þÓõ\962um}ħ\81Í\1d\8dÝ:®'\ 1Ò}\93ue÷\81Ö4\9eD|\1dm\1cµ\91s\9fÃ^é!1JûY* ñs\12\12\84GîU\99\86Cf\85%ì}óW·³c\8dCM×Ñ`Æ\r\16ÉÌ\v\8eUhOçÛ¬ï}\1fM6ïðÉÁf\rD®d4v(èÈÜ?\ f\13\9cnÖÔ\ 5\96\ fåc\93¤âã& ÞÎ&R1\ 4Ö\8cÎv\v\1cô¡\P@~Z\84\a(C|>7í\16\99t\88²nX¢\92\1dXïá\ 6SF,\18%qo;\987½:MÒþ8\81\9c\88\96¼\ 5©`Ô\f­ ìqIU9mÀ\ 2­ºµ~\ f\r%÷»®\82Ú\8dâÇcÊÍj\8eËîG\1cr飴­\86©S\9bù¯\ 6é\7f@6ô\90ýUø²iªÁ\9c\96³\16R~µ8à\83¼î\90\fÃ:\94®\bÑö\92Ô\e\19F\92P\17l²êy9ýÖ\vCÁùj\0tJi    È\19;<÷äÔ@V1\ 2ÑIæ\86\8dgµHw\92\ f\8eþùø\ f\r×N\f
+endstream
+endobj
+2050 0 obj <<
+/Type /Page
+/Contents 2051 0 R
+/Resources 2049 0 R
+/MediaBox [0 0 612 792]
+/Parent 2022 0 R
+/Annots [ 2047 0 R 2048 0 R ]
+>> endobj
+2047 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [288.555 384.353 311.026 393.153]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.8.1) >>
+>> endobj
+2048 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [269.46 290.076 289.163 302.031]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+2052 0 obj <<
+/D [2050 0 R /FitH 686.127]
+>> endobj
+2053 0 obj <<
+/D [2050 0 R /FitH 516.426]
+>> endobj
+2054 0 obj <<
+/D [2050 0 R /FitH 495.253]
+>> endobj
+2055 0 obj <<
+/D [2050 0 R /FitH 479.505]
+>> endobj
+2056 0 obj <<
+/D [2050 0 R /FitH 464.309]
+>> endobj
+2057 0 obj <<
+/D [2050 0 R /FitH 449.114]
+>> endobj
+2058 0 obj <<
+/D [2050 0 R /FitH 422.835]
+>> endobj
+2059 0 obj <<
+/D [2050 0 R /FitH 406.769]
+>> endobj
+2060 0 obj <<
+/D [2050 0 R /FitH 383.729]
+>> endobj
+2061 0 obj <<
+/D [2050 0 R /FitH 367.663]
+>> endobj
+2062 0 obj <<
+/D [2050 0 R /FitH 342.687]
+>> endobj
+2063 0 obj <<
+/D [2050 0 R /FitH 328.558]
+>> endobj
+2064 0 obj <<
+/D [2050 0 R /FitH 315.536]
+>> endobj
+2065 0 obj <<
+/D [2050 0 R /FitH 289.453]
+>> endobj
+306 0 obj <<
+/D [2050 0 R /FitH 263.178]
+>> endobj
+310 0 obj <<
+/D [2050 0 R /FitH 174.492]
+>> endobj
+2049 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F49 457 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2068 0 obj <<
+/Length 1471      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XÉrÛF\10½ó+p\ 4«Ìñì\8b/)Ų\13å +\12\13\1fd\1d@\12$Q!\ 1\ 6\0#Û_\9f\1e4\ 6\ 2(X\15E:Í`\96\9eÞÞë&i´\89hôËäçùäíG#"G\9cæ:\9a¯#F5±ÚEÚj¸\89æ«è66Ä\91éÌ\18\e_\7fxÿéòf~=å6þãýüâÓåônþÛÛ\8f¶'BpK\8c6ð@s\99QáÏLhûf4\v\af\1c\ 4k\81Ç\96Åt\ 6BWéj:\13ÎÆY\8eãÅåüú\f§ûpäÍt&\99\8cï·Ù.Å­d·ÃIQoÓÒO]¼\98²x\87W\96^ß¿*\?Ví¥"\ f\935\8ep\17'»¤®Q\f,ú»÷Snâ\ 2\9c \85\8bç[\90\9cz£À \19cÄ)\85FÜo\8b]:;d_S¯\8eÖñ¡LWÙ².JüÌ*\1cA\85U»²Æ\11\9f\86ɺL\96uVäI\90\90\94µ\9f\12V\16\8dI`(~î\v\7f\1cçÿx]Ó\87÷\96Å~6¦ç\ 1Eäiî/Ô^+!P;!ãïiY¼Á¥Æ\9d÷Yã1øD-áÈ6Ù­;;a£ogO\92·\93`\86H×K\11P\87+b\9dFuæ\8dX+â\8b|*x\\97\89ÿ\94ñU'5Ø`\89°\ e/]ä\87c\8d×ÀGÉ>\85\88\1e§#£\94X.C:^\82Õc*͹\81f\9f\8eõ\8f^\99|\98\9e0\90K#ÖáF    \a¹-£å~r{G£\15l\82æÄ8\13Ý7G÷\91\90\82\18æ/î¢\9bÉï\bÂ\81ÆL\10-T¤¸#ܲVox\e¢¦\95\8cç>\19¿ù\18\9aØ;\8e\ 3\16n²ï\98\91\8cr\90Î\87ñþB\15]du\ 5#kN  \v\9a¨\7fæ&Ûäéê'\90ê\93í<­\96evhS\vB\99ä\90ô+\9c\97iU\97Y\93¦Õ\13®\0éƨSWHg\9fvÅ ,\9d0\88\8eÐm诮?\9c?\ e´\94D».Îü\1cÀ
+\8cu\81)\9enÒr\f      g%$\e\1cøÖl\ 2éiи\7fÀ\82C¸Ò\907ÍDÅg\rÖ\18l4\1a0ÙS\ 1î\ve\83
+_(åcùH\98ìØÑ¢°¤S£ùD¨³!}0\807(\92ì\8eiãu R      \1cm\87\ 6Õ\ 5B\10Y\ e\82µ\ e \fL
\ 1ÙÂ÷bÈ\93äÇA\95Ö§\97xv~\8f\ 6U*M$³¨ø\9fS\aÆ\95Y²Ø¥\15âßÓÇ\13X\93\82\13xçePãÄB4$gD\87r\87Pc\9a6P³\b5ë¡Æ¹\14\ fP\ 3W(ã^\804!Ù#¤ @Ú³`&©Ï\82g£ÌÐ\91\80\bç£+QÍÅ×\11\8c        ð¸\ eÉÛÇÖL\18Jcq\8a\16¤v*âmQfß\v¼ÐÔ6X\v\ 5\ 4¦Y¾J¿\86©\1fy[lèiv¶ä=Ð\7fÖê5\bÅâÛ«é\ fÁÀÒZÖÙ2     5/\94?Ùi/Zí\1fJå¨öã\81\14F\11
+ìñ¢|\86\0O\ 1dh\fï\95WÉ©×ÍÛëË+$|\9f]\9aÝ
\1c\8a~\96oðc_\94íåz\v% ¹W\ayKHÌ:A¡¸\ 2\f¥\1a\86ÂO`'ß8RïÇ >kÉ\8bIâ¤\1c\86,9\1cv\99'%É\1d\12\97\144¼çâªðý\9e_:\1c˶\87©Ú=O\99~gÙö4iÙÚàÚû°W&ùæä8VÑ¢ª²E\90\1e\8ft¶T\ fú\8cT\90\1e­.\1eµ\9b¾p\96Å1oyÖwVdØ\r\ 3\ 11ã{a\10\19¨\90\9d\9c¹\9d\8b?N¡         d\9e&Í#Û\90\9cmah»¶õ\bF\1cÔ\1dÚ¥þ\188|ÛÁE8±.\8b=\8a£øH¨,æMÈôåîXe\b\8cw'=>TBã\ 4x
+ÄsýÀ\8dI Æ׶\ e°c»Ê;F]`\9dáê\95¬ãÄY\b\1aS\90Ã(0\e\8dÙ\19$Ö&\1fi7%'Rñ ÍxC\ 3åÍ\88ΦÛ\11«yÿ\87ÖhH¡k¢Ý3wc2\14QB=é8¨&´ë«îN~      \9c\ 4§AüXw­\1caÂü ïÿÜünºj    õÿwþãÄÊ\9c$ÒÊWi\14\98\95\84ÒaO®\8c:m\14N{r\07\17/éÉ¥\94c=yË+ÿ­S`\1aÚ-÷J\r9S\1eqmD®¯>?«Ö*&yÌéh±\95ÌÅ÷ÙÊÿ¼\85Þ\10\89\9a\ 5\12\87\85å±,Ó®æÀÎa\97äiw¸ñ·tPIOüÝ\15ä2]§ a\19úã²\89b¿v7\95½\1aÏcè\90\98>iú®¯~}5ó\85Õñ6Í6ÛÖBa\rþ\1c°áO\ 2\98\f\17Z\1føé¨\ fôK|Ð\91Z\18!»þ\ 5ÐSy¼
+endstream
+endobj
+2067 0 obj <<
+/Type /Page
+/Contents 2068 0 R
+/Resources 2066 0 R
+/MediaBox [0 0 612 792]
+/Parent 2022 0 R
+>> endobj
+2069 0 obj <<
+/D [2067 0 R /FitH 686.127]
+>> endobj
+2070 0 obj <<
+/D [2067 0 R /FitH 601.924]
+>> endobj
+2071 0 obj <<
+/D [2067 0 R /FitH 601.924]
+>> endobj
+2072 0 obj <<
+/D [2067 0 R /FitH 574.091]
+>> endobj
+2073 0 obj <<
+/D [2067 0 R /FitH 540.163]
+>> endobj
+2074 0 obj <<
+/D [2067 0 R /FitH 468.374]
+>> endobj
+2075 0 obj <<
+/D [2067 0 R /FitH 432.508]
+>> endobj
+2076 0 obj <<
+/D [2067 0 R /FitH 314.884]
+>> endobj
+2077 0 obj <<
+/D [2067 0 R /FitH 291.029]
+>> endobj
+2078 0 obj <<
+/D [2067 0 R /FitH 272.543]
+>> endobj
+2079 0 obj <<
+/D [2067 0 R /FitH 230.748]
+>> endobj
+2080 0 obj <<
+/D [2067 0 R /FitH 230.748]
+>> endobj
+2081 0 obj <<
+/D [2067 0 R /FitH 194.883]
+>> endobj
+2066 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2084 0 obj <<
+/Length 1508      
+/Filter /FlateDecode
+>>
+stream
+xÚÅXMsÛ6\10½ëWðVj¦Bð\r²\97\8e\13ËM:\93Äu4i3I\ e´DÛ\9cÒ\92\89\9d_ß],H\916íDcO{\11@`\81žÝÅ>\88\11\8f~\9b<_L\9e\1d%QÊR+m´8\8b\84åÌZ\17ÙÄ2!]´XE\1fcÁõôóâ÷gGNõESÎTê`\1f/ôâåÁñb~2\9d)¥bǦ3ç\92øèäàõ\9c\86\ eç/Þ\1eÎq\9f        \ fÚç\8bÉ?\13\ 1]\1e\89\9d\98\93i´¼\9c|üÌ£\15\1eqæ@ÓW/z\19\98\13¸°\8cÞMþ\18³Â2«Md\8dcR[:à\9bì2\9fΤq&^Le\12ßlá+\89aLI¡ãwÅ·\1cO\17 .X*U4\13Ð\1aC\8b?qÃO\8b¦\86Vx)\95°\ 4ðé˼+Î×ùêWØUk\1d\1fæõ²*¶M±Y#\0:ÎÖ+B¢Êë¦*\968S{<ÆqP)sê\ e\ e:M\1eÆA§wÜ\99DV&\fTÓ9OæGÇäÏ>f°\97\10¶õ¦<\9cÎ,8ðÕ\1a¡jòó¼òfó!,\aU\95y,ý$Ä\8cuf\80I\ 2hHcã7\eß1ñ\ 1i\1e\9cÒ)&ÁãAõÉñK\92\11º'#\1dxT·2\9f8\97#\e     Î`b·Ñ\9fwÍT\82%<iE²îüà\994^\82¯¤\8b\9b¬X\17ësoÓ,\81(çvhvs\81\91\94\0ñ¡¦¦ÑÍ\19µ;±«ª
+"4°-³uÞ        \8f\0ë\97\9cå°v\99S\10\9dU\10ÅlÄô\99H%\13àêÁ6Ïÿú\9e£û\ e\9e\19¡e,ypUð\99\8d\17x\18\9dºøbS\15ß\82ÉY\89c`Jq\9d\974]¬Wù5u\11\ 2\ e\9fT:eÜÈáéÊ\rîô\15\7fòjV\82\12\11\9fM\ 5\82ä\1cz£Zã©ð"ÁýpÌã\82\ 3}Hûø\85d?-7>»\97(ñ÷\1e\80}x2À\9c\17²­)\96\b\17\8e\ 4¸°\eà®7\ fÚÿ\1c.ó8¸^¿ß3À,àeFá2*¹\13_Æçä%^Ô\10\9c²\93dÑDl\1f\84lh\17ÞÌi|¹¡;Y\1a\1eü³l6\15\14,-ð(EMS¾\ 5ñ¬ô\88g¨ú¦\1e\8bµ\8c2õëŦÌgÁ¿\98«_¦`[V^åûàùá©ðL¤º\15~8\12ÐL\ 2\9aþBÂqD\13Ûÿ\11\ f\9aã5S\eÃ\0³}©ÃHÉ\84½ d¦6¸øíU³½\ 2¨T¢âm\86wp\93Wõ/\ f\9c\84k\ 6ìã\91,Æ1­t¤RÍ\84Ó\ 3\16c\8dþ\1e\8b\91°»ü\11\16cïa1Ê\9a\18å¬o\9f\84ÅÀ\81À½\92Îy|2?\1cÉ\15\80=U?Êbì÷X\8c½\8fÅ \1aVÀÄ]¦\ 2ë\95Iï2\95dHT\84îR:¡Íúd\ 4>1%±ÝVùªÀ¤¢Ï.\ f({f
+\82C&C\83\9a\rùèªni\83_\r#¯Þt\1c}IɼÊ\83C\87Ù]?\90fJ\ 3\19ãO\94g\10¶L\81¤?øûi
+ÆUEvZ\82}\90n\1amX=\90h2u\9eó=ÅsA\82ë\8cìç\19hñy\ 6\97\15\14Ú.Õ¤Ôj\97j\89dÆ¥C\ f<ø^°·2Mi1\9ai rEý\1fK6iáÒ\16jïds|$Ùà¡\ 4N\ e/ÀÓë½Ê\92r\9cÇ
+p\82È\8c?LáÒDoú/_\9b\14\97wj½âª%GØ\rä\88º´\8281Wãle`Ä,\1cnX¾n\9eÖ\bu»ÀâH¯bµ&¨`\82R-­×Á\ 4\87&¸=L¨öô\83\ 4\13\ 2=íÝ^t|¨Æ\17\10\e\p\83î(=v[\e|\97\ 1:þi2£j#á±Êo\91\99öÕ¢\ 6¯\96¡\91ÂIÈ\v=L\9eêæɬ\94@\82\87\91` v\83\81Ò\91\81²%ÍØÙ½½îµqgÙxJz\96§\1ew;9Ã,\b\bc\19×!!É\85F\10O¢në6 [ý\9a\ 13uq¹-o¨¿Ül\v\7f·\1aÑ"s\9a5Å%-lÚ}»\97-¾2º×-\8aøº\ 4\12\9dh/\ efB³TëÑ8\0'y´¨\e8}A\91\875H¦)\15.\98=më o\8f\84\83\83´ÿ©¦Ñ\8e\80¦ÞÓnG@±Ü\9dõö\18JÐw ÃÅÎB\90Þ\5u±Êï\7f\97§zð.Oûügd½^Ù\9aF;ée¹©á
\ f¨àÆWpúÜÜ\16ÎWçíÔÙ­©\81Vã_\7f \18]4zÚ»\8cj(õ\8auÝäÙ
+à1Ü`\1aùÑm\95AmY¢\ 1@]@]»p·ÁUVR\ 4Áeæ\15nAw\99\93î\10*AGç<èç×[ªcø\7f\8a\1f   a£!(©~v\7f\aöþ\16ü\17\15æ\12î
+endstream
+endobj
+2083 0 obj <<
+/Type /Page
+/Contents 2084 0 R
+/Resources 2082 0 R
+/MediaBox [0 0 612 792]
+/Parent 2022 0 R
+>> endobj
+2085 0 obj <<
+/D [2083 0 R /FitH 686.127]
+>> endobj
+2086 0 obj <<
+/D [2083 0 R /FitH 440.921]
+>> endobj
+2087 0 obj <<
+/D [2083 0 R /FitH 405.055]
+>> endobj
+2088 0 obj <<
+/D [2083 0 R /FitH 333.266]
+>> endobj
+2089 0 obj <<
+/D [2083 0 R /FitH 297.401]
+>> endobj
+2082 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2092 0 obj <<
+/Length 1730      
+/Filter /FlateDecode
+>>
+stream
+xÚÕYKsÛ6\10¾ûWðHMK\ 4O\ 2ì¥\93\87ݦ3u\[m\93q| %ØâT&U\92\8e\9dL~|\17\0\9f\12$Ë®'Ó^,p     ,°ß~»Ü\85qp\1dàà§\83\83\17G\92\ 5   Jb\1a\aÓ«\80à\18©8     b\15#Be0\9d\aç¡D     \9aDRªðôðõ»ã³éé\84ªð÷×Ó·ï\8e'\17Ó_^\1c©\81
+F\15\92±\84\rìb\82\85\99s\80\9b=\83¨\9d\10QP\1c37­¸\9aD\8c$a½Ð0 8,õ\95.u>ÓN~U¦7Í\9bK³ûg'VNT\94î\91Äîy\95ÝëeådEîd:\9d\99\85\v'­²¹þ:׫I\ 42\9dϳüz<ýn¡á,\8d\ f6Àù#BP"\84;s^Ôf9u\876\83YQ\96º2J%(rJ\8d<½Ï*7j\7f«ÛË*½Y-õ¼\91çæ\97\f\82ªÜ\9c¸ÙdµLsý5ÍçíV+\8b\87Yé9䥵°(çÖ\16Æzl`\f»ÂIëÂ=Õ\8b¬\91\97ú:+r4v\1c¡\88Hã6ÐNTãݵ9ç\91À8<\9a(æ|\ 2º\ 6¸3\1e~\9a\888L\97·Ú½\ 4·[\ 2I<`P\82\11ð°%ÐåçM\8e\11\86bÊÚ\19WeqãÔa·Ik\90ü¾5s¶¼­²Oæ\1cú\875:\ 2ÓeÂ\04PO\eÐ>b\81SøC|Ö½¬ªì:÷\9c\9b'(æª=Ué?7åí\ 4Gu8\1e`"\ 6\98\98ÍÝR\9e\fµÃ9!2\9bů>x´'\88\11ÚÎøΣ#±\ 1×Løõ\ f\8f\ e\86\91\Ó0ö\8d\19ít\rF\fw3\f\86k\14\ 1 1âp¬\88\b\94ð\1eðËm\80¿õ\91\ 4\92\b¥òA°I;£¥öu©ÓÚÅ\ 2\10e\91æ;A\97\18"©£âéÉÏn\ eáÃ\93H\14cÑ[\8cñæYF°\11chCÍt+\998bÉ·áÒs\9aµîl
+ÎV¢ñ5é\9d={\9c³%ê\89½¿¯\97ºªÖ\1dýE\97E\8fý$"a6!¡×\ 5\ 4sÈt\8fØw\9b\17Ì\9e\eQ  [P²\11\ 5ómÀlMª\eÛù\93ª\80äÔ\9dôòÞk\8b¤â\99\92*E\89\92#ã2ô¸dJ\11\17=öþó2Î\9e'\9b¾÷fSÜñG6}ïͦ\9cðýóé½7\9frÌwæS%\90á\11\ 3¨\9bÏræ\aÛ\1f[\0t"w\ 2M\91Hø0¸¨P}"5\ f.¾Ìh\vÞ1Ô|Xõ\19çO_ÆI\10é\1dêÏ8
\98¯'R*w%R\86\1e\15``HÃ#H\ e·V\92\92\87è9-ÛÈ¥\10U±â\8d«eëêÇø:F\98°ý\83jïDjòè\16ü]\16eÿ>\92ýYT"ÆÄ\1aû?=\98\ e\94Hv\99ñäôð\8d¯©A\92uô=÷A;lz\1e.\8c.|:\ 4\12\9f\f.Ú²]¯×Ö\1e\e\15\ eâÓã\13\8f\91\ 4\91ø!\ewÖ·0"Éþ&\96~\131íaB\1e["\1aK$ ø\81¨D*\89ÝÔ©\85\ 1¾\91?§Ë«è$»7\9cÔ\10¾K#æáI©çÙ¬\1e´r
+1\95¸ÅoóÕmí\96¯RÓjBf«ÜGípzð÷\81¡\a\ e\1fsXL\81Ô³\9b\83ó\v\1cÌá%è\84FB\ 6wvêM\0\8c\ 6Z\99\85Ëàìà7×l\8f,%\1cA\13Ã1Яé\82\8fm\93K%ááÔvwM\7fjZR\90\9de_\\8fG0D\f\96ãNÏÖÐY]µ\ 5\14R\90\99\86sΠ\ 2ôüGÐÊ°\bßh\e·³2[Õ¦
+²½/\10É6\99®\ f¬ê\12@\83f°Ú\ e\ 6\83\1a\8fÒ\r0x¢v\831rj§L©Ûö²Ë¦j\9co\95ê\82à­ë\91õµù\14        ÂiH¡`¡\14RÇqa\aqC\rIûl^/ÜÐ^8È6zäZÃm\ 4¶áî&[Ø¡ÃÃP\94\8c`ïÒÕðÆ\ 2@lo,\\9b=h½½\94&        dI\167ªãµÂü9Ìç8\èìzÑZ\bÏ\16\ 3ømLH:\f¤\9d\ 1\82\16\ 3\9bb v¥ª1\bôÍ$\8a¥\1a\81á¹
+yY\96©»;2/¡ï\8f¥\18E\87j\0k\90\13áK_KH\81\9fä\81Þ ¸¬äà{O½å#åb£nXKÈ}\ f\98\87¦J\85³Â\19\9bf¹¹\ 22\16ERZîlº\86\vÒ-hü[9©¡\80ùí§\rÃÀ\b\1c\ 5<pZö\f¿?#ç3çüýÉî«Á\9fÈu\ e¯\16E\99}i1Z\1a\19qÜs¯³|®ïÝÐBÀIw\81æeø²0\9aîl³SFK\9b8¯ e\ 2H\12\98ç¢Ì'æ\93\ 3ÃÒ\89\8dj({\1dD\92`\83.L)í\9c\ 6\9dݲ°yßöx\7fí\1f+¾K¡'B\18Ç        Ô\13@\14]ÖÙÌ\0h$\r\80±Ä&\9eIh14OÆP3á\7f\8ca¼£\8fÛ\ 5b\f 
+?\r\ 1\90\r\1a\82lVÜ´WÄC#à\9drd|\bÈ\8f\98ð²ª]\98Ý-\8a¥\8e\1aÏ\980¼)Ì÷º-¡\rئêÙ\9fEÞ{Á§!@\85l\8eвÈH\86ö·\1f\e³ÄØnÞ×íRk'øÚ¶\17õv<Ö `\ 3\bø\13!xOÿó,¨4¤ôùs\93 \v\83\ fÏ\86\0Ux\9d\ 5²³_5,hþÏáR\89yïX\0\83ÊÂ3\8b¶#ñ$\18üµ,aܶÈ\8f(ìÛ6³ýý\aGt£\12
+endstream
+endobj
+2091 0 obj <<
+/Type /Page
+/Contents 2092 0 R
+/Resources 2090 0 R
+/MediaBox [0 0 612 792]
+/Parent 2106 0 R
+>> endobj
+2093 0 obj <<
+/D [2091 0 R /FitH 686.127]
+>> endobj
+2094 0 obj <<
+/D [2091 0 R /FitH 626.339]
+>> endobj
+2095 0 obj <<
+/D [2091 0 R /FitH 604.421]
+>> endobj
+2096 0 obj <<
+/D [2091 0 R /FitH 587.928]
+>> endobj
+2097 0 obj <<
+/D [2091 0 R /FitH 571.988]
+>> endobj
+2098 0 obj <<
+/D [2091 0 R /FitH 556.047]
+>> endobj
+2099 0 obj <<
+/D [2091 0 R /FitH 538.115]
+>> endobj
+2100 0 obj <<
+/D [2091 0 R /FitH 524.167]
+>> endobj
+2101 0 obj <<
+/D [2091 0 R /FitH 510.219]
+>> endobj
+2102 0 obj <<
+/D [2091 0 R /FitH 496.825]
+>> endobj
+2103 0 obj <<
+/D [2091 0 R /FitH 454.477]
+>> endobj
+2104 0 obj <<
+/D [2091 0 R /FitH 454.477]
+>> endobj
+2105 0 obj <<
+/D [2091 0 R /FitH 418.611]
+>> endobj
+2090 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2109 0 obj <<
+/Length 1948      
+/Filter /FlateDecode
+>>
+stream
+xÚµX[sÛÆ\ e~÷¯à#5'Úì\95Kö¥ãÖöi:\93K\13Of2i\1fh\89¶9G&U\92Jìüú\ 2\vP$eÚ\89\9b\9c\17\10>|\0\16»2º\8adôߣ_Î\8f\9e\9f¥Q&²D'Ñùe¤\12)\92ÄGI\9a\b¥}t¾\8e>ÆJ&\8b¿Î\7f\7f~æÍxi&\85É<È        \8b~ýíøÍùéÛÅÒ\18\13{±Xz\9fÆgo\8f_\9eÒÐÉ鯯ONQÎ\91ä\7f\7f~f³\91Àe/q©=\f\1a\92ûz×mw\1dÈHM¼Í\9bü¦è\8a¦ý)\b:=?úûH\81,\19©AucDê\92husôñ/\19­aò÷H
+\ f\82?\87¥7\91±Fx\85\e7Ñ»£?æÌà\8556J´\11Ƴ&¯à¿\17K\9d8\e\9f/t\1aßm¡\97Æ0f´²ñ»òK\81ZEJj\90®\ 1\8f\12\99s´ùOéäEÙµðUa\95IE
+\7f6^󮼪\8aõÏ Õ$.>)ÚUSn»²®Ð\826Ϋ5\99²)Ú®)W8Ó>b\aéD\9aܳ\83ÍÒÇí0á\84\84¥\91ˬ°   ©ùæíé   ùÃØdÖ\8a$3½7è\93Å2\ 1\axQ¡¥ºâªh\ 2j9µÊqÓäÁ\94a\12|.ñnb\92\14\8c¡]\12¿ªCÃÅÇh\8cDÁDÐ@Ù\91
+°ß¸¬WáO)õ}5\95\14
+\80Ƚx\14\96ïÕ\bÝú\92¾Û¦X\83\99ë\86º\9f\16 H¾Ù\15ÁèÑÒX\b\91t
+¨«\89¢][\10i\97a7\8c¼xµ\8f\8eU\1d\1cg]0\9f\17\e\1a\ eÿkÅÃ\9c:\9f\88TÚ'ûö\f§ ÌIá\14éý~\91\ 1¶¦Ì/6\0\ f\82Í"\84õ#aæt"´Tß\19fÀ¸u\91S\ e\16¦ã0\83¿      aæ\81\14\8f4­­\19"-ÕÂùì[\ 2ÍÏ\a\9a±j6Ðà/×Ôþ¶X\83 \12\1aBþ©±æåL¬Ù\14Iæ`»¸\9d  5#\94Úûð8Ä\96ÆK\19\e°\13xfüa\ 19\13é\f½óktI©ãëº)¿Ô´+ßà\18dÖò¶àfY­\8bÛ¾I;:Úzè©\82O\851\88%+7áäâîÇ\82\80\98ù\84ë\8b¦+W\ 1\82\19 \0i=\ 4Ã\10àK\10`\8e x\84à\9f\0¡¹UOà\ 1\83\96\87é+èo­\ 37U¶i;ê\1c2\82c\f\a\9b\f\87\9aôE8á¬Ñ\99ð²OBì3MqY4EµbS]â¡9\vTy\r±a\ f\90Þý8¤hð=Ò9Ú,â\84\88\8f7=e\ f³\aÐ\963ÀYõïA}«\7f\18jíTÜ\16«\1aÏkl\1fÒ\8bcL/6\19/5é;O¯û.z{ç¸Ó?Ð\91\a Ø\9e²\8b#{/\ e0{¢\833Kvæ\7f\8bv>\13Cµ&\1cÈø®cÉ;\91À\ 28\1d\84ê«¿\17X\14h\17×UÁ\8d`\1cH(!#ÖÝ5\ fó:rYh¬ê\9bmÈ8°³Â¤Óµ´ñÞÊiv¥±\9b\9aÏ%h\93y¹ \81\82ªº£\81\9c>\9f¯ëMAa²TVdöÀ×ûLéüPÓ<Ã\1a'\ 4ZE3¤\15Ì^ç\9bËåh˸*\82nP\ 2¾X.@Õ\ fG9\87þ×·\82ã,çªÂÞ\8d@²u\924±6CîÃA\1c\9c\v&zÛàÜ'´,Û\ 6û%ùpÍ"°ó\19\7fx\80L´÷Îl\90\ 5\93\83\9d[¼Çd& \1a+\9aôµF\9fÄñ°lé\v\15ß\rVvؾàª\12Û]³«VyWVWÜ\ f°¤\19×\95¡\8f~\81ß"\ f\8epM=v£\94Ý\b°±\98\9a±y¨ßÖ,âKÑÔÀ¨Õ2Ü\1aflLÿ®Í\10¿\9a\11\ 4=\82 \ 3\ 4\bá\ 1\85\ e(n¨\95\ fz\8c¶\65Ï£NhNe8yh\ 4EP\9aòb·/±\ eUe\112íM\96\8d\93\ 2\8e\87¤@ͼ£\15¼4\8dû\98ÊI~\18cC²\8f\10Yì,°u -%\ e<q\90N\ 20üYÃú\ 4Ä춳.\9d_\15ëg|\96\8dü\0\8f´=\81)\13\88\8bªâ
+\96\90S÷G!z[Uv¤\1d\14E\82\92f\1fàZhË%ôëj\83úg
+\1dß\ f\8e\ f\ 3m~³\r%¾ÍtoÙL±¹ 1¶lXA\96\85\99À\15ä\85\ 6\\0éâ\15\1d\v\1ey+\8c\ e\91þ`\16\1a§\1e\vY« ûa\fÊ$./é;ʮؽ\1f\ 5-MPÐø\9e÷d\bhhOyüÄ|\ 5ëâH\ 5©\b\1d\94z£D3Ãå\8c\ eà×0\1d¿\ 4Óðß:¸¾\8cÿÖÍ\86pK\v?\97\88\ f\97ü½Ë\9b\ e|\883\13\ eå«Õ\ eô¹£¥eE£Ý|F"\ e\80V<
+Ò,Þnò\8a.tì­Øè\9a"\ f^\8f+\8a\8aî\12fBæ\86Ñ6Ð\1evµ4\ 2\1a\ 2¸\16\8fo\9e!­±5Éó°v¯2\#Å콿ê¯Û`5¼m¡ù\83h¤À8;ÉõØß\82]¨uU\84\ 3\1466õ.ÜÔBM±¦Y:\9e¡A\ 1E\17È0\10jIøòÁ6.LÝølÅ0u\19¿¶8wÏÒ\f\ 1\²à«ý$éÍ\96­\94dÅäõ\vÊ\1d¨.ðµË\b\99füÔv°æ#\90-ã3\f÷þ!a\b4\94¼\8f"\9a\840¸_\bfR(¹\7f¨\9b»\8c)#\12­û\15\94\16P\9cܧ(zÖ{Öã[mvmI6ûiªñ\12n¯pd\ 2,%d\96\f\97ò¼¿\91\1f¢;n[¸\8fÏèm3\91@J\93\8fÜK\14\î¥ê\97tÃí\10\88\e¬\82\7fO{'\ f!\164MöïE¿|\98\11\9f  £ö\8fZÿ\99\91\11\82\97ï?Ìèh\12¡¬>\102%(<w>Æ\8f\14f\80\89\86\93¥\96JX\87\8f\8e\89pzdö\8b\87ÌþbÎUt*´~\8aÉK>°®BNiØ_®óêQË{\19R\16Ëxûæ·\99×<íE"Ýè5OÞ×eb8\85HÙCó\a
+ÈPÿ_\9fòß\0Ì>\15Ø!áà\ f"\83Ë    \11>züZ=\8dp/\94Vÿ\82p("ÚC¶¹ìd\ 20+Ï\93 $Ô\ 3J\7fý_õ×X ¢r\f¶ÿÂíð\1f\91ç3©
+endstream
+endobj
+2108 0 obj <<
+/Type /Page
+/Contents 2109 0 R
+/Resources 2107 0 R
+/MediaBox [0 0 612 792]
+/Parent 2106 0 R
+>> endobj
+2110 0 obj <<
+/D [2108 0 R /FitH 686.127]
+>> endobj
+2111 0 obj <<
+/D [2108 0 R /FitH 668.127]
+>> endobj
+2112 0 obj <<
+/D [2108 0 R /FitH 634.254]
+>> endobj
+2113 0 obj <<
+/D [2108 0 R /FitH 562.465]
+>> endobj
+2114 0 obj <<
+/D [2108 0 R /FitH 526.6]
+>> endobj
+2115 0 obj <<
+/D [2108 0 R /FitH 188.918]
+>> endobj
+2116 0 obj <<
+/D [2108 0 R /FitH 165.536]
+>> endobj
+2117 0 obj <<
+/D [2108 0 R /FitH 148.457]
+>> endobj
+2118 0 obj <<
+/D [2108 0 R /FitH 131.932]
+>> endobj
+2107 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2127 0 obj <<
+/Length 1927      
+/Filter /FlateDecode
+>>
+stream
+xÚåZ[WÛF\10~çWèQ>­7{ßU\1eÒõMN\ 3    ¸mRÂ\830ÂÑ©±A24ðë;£\95u±×2\ 6\9aszú\ 2º¬fw¾\99ùæ\ 24\18\ 54øykg°õêÀ\88 "\91æ:\18\\ 6\8cjbu\14h«       ã&\18\\ 4§¡!\11éõ\8d±áñþîÑáÉà¸ÇmøÛîàíÑaïlðîÕ\81m\88\10Ü\12£\rlP|̨Á5[´Üsþ;è\vJ    §&èsØ@\v·ü\v\ 2~°ÖGÁi_Q\1ançy:\9a¸-\rmì©P\12\9bo\99Ýóåc1Kl½dö5éõ\85\10á]O©0\1eß\96·¸½ûVF\8d\8f¥\ 6\95¢ùÇ;\9f=â#"\18\9f¯øÁ##*\94,\17¼ÿý³ç\8c\ 2@\97\8bBZ\8a\84\9cß{ÎA\89¨ÕD I\eÉ>\aØ\85TA\9f)\12É\1aõd\15êo/=\a\ 1\9bÕê®\ 6¼Z\92æ\ eàQ\96ij$Ã\e  V\88'\9d¸\eJ"¥ç2\8e?üâÖ0Ù>\89¦ªÖ\98Òå³\14W\95G¢¢?º}ãU\1e%%\11Ñ÷r¨ç)&Z\8a-\9a\e¼\81\b-\97Ì}   \11mÃÍl®\89bì       F\1f'y¾hñ\87$\9bÖFèõY\98öXèµ\ 5£\92D\eyÛ*kà¦\8b\01p2\16-á3Z\ 5ÍAÏ\8ap\9a9\81I<D.üê´\83Ýtc·©\ fÄH\11jm\15Âß<ª\bbxe÷ËlzåÄÑ\12©»5%zéd8¾ÍÓ;<GòzA9ËIdMK¹\94lD­\92\13©jì¿1/öʪ\97¡ÖO^j¥\o@­\9fØS©\95\85\12Ie\17µ²H\13j\18\\b\80Û\96\ 1÷G\18'\9aÉn°!Y*Ù\8c0nhM«xã\82\f¯V`®\ 1Ñ\ 6«þá#\1fÈgÆt\93\8f%:\8a\16Y\95Û.V\15\84\81~\853¡&\8dÐêPL*¢jÊìÐÌvk\86{\80$\v\96dp\1cÕÁ¯\f\96\89ÍA\0\13ë\ 3L?\91U\1fE©ëwÝ\88Rµ!\96/`r·!ï\18b\1a\9eÂÿ\ 5Ú1kYGmÂ:/PÐ=\91u\141\91*á.kö»\8dHG\bÓ\rõw$\1d»\9etì³H\87ÿ7HGw\91\ eXÜÈ\ 5\8boÂ9ðý:\93·¢ëÑ\9c\83\94\93wq\8ex\81\98^UÆ)kÛ¤s\97®¯vZ¶\84FRÖvúp¼¿çkp\ 1¼jÍ©\ fÞf\ 3¼²K«xáÌ'\ 3\9cJ¨Ç\13Ã\99C¦D¬Y\8aÂ\87A\1f\ÈZ\ 1.\ 6\9eÅl]åz \10Ä\9aJìñþÁ\a\ f\ 2\8c0ÍÖ!`ë\82Ý\97]\14\91öñ\bø3\94"\«\ 6\ 4\9cs/U3ð<ù"J\99î.\ 4\95b\9bhÅ×j5ïC\80QX+qHZ\15_oÞxC\89ëJg\9f\b\0ÅVNøº\84Í\ 6®äá\8e\92¢\b2\98*f4ÖÚz\1eÄ!Ð\19Wá^rs\vD X8K\1fâY:õE\15\85¨´ØO\17\9f¿\9d\ßÎÀK\81³¯ã,¾J \87ä®qÙ\1flÝl!~4`Õ,JDÐ\8bS\11\f¯¶NÏhp\ 1\ 5\14R\9e      þ.\96^\ 5\ 2\14­é88Ùúè\ 6[-0¸$Z\99\06Åʤ8Ç!l\rÇ0\9a\86\83\1e7áý5Ò|\88Ï8\93áIúà\82\87aC&D»\16Äà9OgùÜ: \19\ 4ë ¹æ\ 48&¹ø      \90â*\ 2¤òa\96^\17\10\9c\¸XÍ\92|\96¥C|\93wÀ 5\11\ 6       Ù°\13\86v Ì\85)0>-3ÇîÑþÁÁɲ\aÁ\86FT)\9bïõúÚX0\1fv\9a³d\ 4\99\1f\15§m`¶³,Æ\ 5\ 5ë\ 5\96\16-T\98\ 6\98\19¬ø\8c\8dt\92\17w&Üö9\ e\9e±\1cî\9cøR+æÂÆÄ\8br/WÒz\9c£%à.!¡TG-n¡]/~ßôX\b>Ý/\99\93CõÀÛ:\82«'`;\ 5^²·;À\v\15\ e§X\86\84É\17Êô0M\1cHnM\95½r\1f`\978K\90\86»Y\82ÁY\ 2Þ\9d\8f\9dÀb¾ð\17>ÃVß½{HGý\87\1eN³¾OìE\92\11\ f¢\06àe\17:\9bí\9eàáîÉîö¯ûëÜ`\95ùËr%^i~Ý0?\87ät8-.\14lÞW\9a\81UúX<$ãäªF\ f\9e;\89\ 6­\84·h%¥y\98\ fã±\8bOh6\84\8aÚǨÒ\1f¸\97¤¶\ 4\99\82\9b¡ä]w=Äý¦.èk³\99p\96»÷ø\91\aÙjæã-¥%« ºI=\9e\b\82êôZ\1dÓo*¨F\98Y0ÕÞó̤Ö\99I}\173)\8f\99äÜLpQÔ1R\1aP×=ð\87תpªFsÆk&a\88®Sã³Í¤!ëÃuë\18\9fM¨þ\88ÒD\eÕ\8a(»l)Ï$\1d'K¼fÒ÷>*\15 H=n÷S)¤¹ºnC&åÆ4\8d\8f·Ã©S)N+\16\95Pö,Äh:\19-\14­çq^VøW1fÄ$\7f<\85\1d~<~©\14\1añr\81/6D¤CîÁ\14b\v¸dmz\12¦JO kf'¸-05\ 5¦\ e8x\86À\15ðrW\r¶´(t¼½Â\9fç.v00dTæ9\e\16\85\9b\v`|\9cÅ\93\11Æ!^» \82\ f\9fQ9l\9eø;K\1aUêÞÌ|±\ 5å\]Gc\15äé\15-xbU\ 3_\8fý!jê
+\18\87\0PÈA)UUq,\84\92Ê\9dt|ß³2$\ e,\1d\11Í\17¼gðuÞá¦e\7f\eÏJO\9cæå\95\16\8f÷FpÆ·\7fî¯uHñB\14àsH\riÏë\90Pù  ±Æ!\ 1Û\86?.\vÁá\98|\84\8cª.Ó\ 2O\14¡*P^ÍÉ\ 2Ï\88î\88o*gVªhÄZ\bäPqa¥\b\19\ 5×sÝüÓ\v>m83¾,\9cÙ½)|\19/þ/¾|4\19\17<¬ç\83,\ 3\16b2Ëg¾©\1c\85¾¨Î\v^\12\15\1cÈûÑݾ\1f\9cs®o\8cW£TÏ\f\1c\ 2Ð[\11¦ô꺢\bæ¬Ì+·yrA¼ÿ\8f\0=×?VMα
+endstream
+endobj
+2126 0 obj <<
+/Type /Page
+/Contents 2127 0 R
+/Resources 2125 0 R
+/MediaBox [0 0 612 792]
+/Parent 2106 0 R
+>> endobj
+2128 0 obj <<
+/D [2126 0 R /FitH 686.127]
+>> endobj
+2129 0 obj <<
+/D [2126 0 R /FitH 668.127]
+>> endobj
+2130 0 obj <<
+/D [2126 0 R /FitH 653.681]
+>> endobj
+2131 0 obj <<
+/D [2126 0 R /FitH 637.741]
+>> endobj
+2132 0 obj <<
+/D [2126 0 R /FitH 621.801]
+>> endobj
+2133 0 obj <<
+/D [2126 0 R /FitH 603.868]
+>> endobj
+2134 0 obj <<
+/D [2126 0 R /FitH 589.92]
+>> endobj
+2135 0 obj <<
+/D [2126 0 R /FitH 564.017]
+>> endobj
+2136 0 obj <<
+/D [2126 0 R /FitH 550.623]
+>> endobj
+2137 0 obj <<
+/D [2126 0 R /FitH 536.122]
+>> endobj
+2138 0 obj <<
+/D [2126 0 R /FitH 510.219]
+>> endobj
+2139 0 obj <<
+/D [2126 0 R /FitH 496.825]
+>> endobj
+314 0 obj <<
+/D [2126 0 R /FitH 448.458]
+>> endobj
+2140 0 obj <<
+/D [2126 0 R /FitH 428.242]
+>> endobj
+2141 0 obj <<
+/D [2126 0 R /FitH 394.701]
+>> endobj
+2125 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2147 0 obj <<
+/Length 1461      
+/Filter /FlateDecode
+>>
+stream
+xÚÕXMsÛ6\10½ëWðVjZ"øþè¥ãØNÚÌ$©mMg:\8e\ f´D+\9cÊ\92MQiã_ß]\0dH\89²­\89\ fí\89 \b\ 1ûv÷í>\88\84&oG¯'£Wolâ\88Ó\'\93\9b\84iJ´6\89\9a0n\92É,¹L\19µã«É»Wo\8cè.u\94\bg`\1f¿èø×£ß'§çãL\b\91\1a\8c±é\9bó£÷§aêäôøãÉ)î3¢ñôÓÉè~Ä`H\13öídm\88á.\99Þ\8e.¯h2\83\8fï\12J\f\9cô·_z\9b\b)\88aøÃEr1:\e@a,\91J%Z\19Â¥\ e\ 6~Èo\v0Åh\9aNÆܤ_ïÆ\19<p\8e3\99^\94\ f\ 5Z\970\ 6»\v\91d\8c\11\a\9bø\1f\7f¢\8a^\97õ\1a\9e̯\12\96XðOwÍE9_\16³_Æ\19ãÊ¥'ÅzZ\95wu¹Z\ 6\aäËY\18\1aÖ¤uU\8eY:õC\1c­p´\84ÁÚ;iØ9Â\81m;Î\91Î>î\1cévbl\13Í-\ 1{\82ñgç¯ßÿv\11ÂÜu¥Öp j\82,NÆ\99\86¸þ¶\1cs\9bÖż¨¼7hß[yUå¸à«ÿ\b©¤\8dê¹Ê\81ë¹Òé\87\95\1f¨ô\bö¥6åÁ\0&;\16XI\1cXI\9b@P¾k%ìm\1c\1cØÅ\11Ê\ fÚDK4Éu°x\vW7aºþ\DNÐÎ\16\99R\84iÖ÷Æõm9p\98&\96\87ý\0\19\ 1I\9f\ 5$\89\114½YUaªÈ§\98­\9fÃÛý&\ f®÷\9eÍâ.½ãª|9ǤÖ6l\82\83<<æå\17üq\112m×| \ru®1ê¾\1e²[\11Ýú\11Szw\17\ 69ÊÚ]î\16å°«©m\96ü\14Ápp\9eÒ[h\8a\14\8c\9eÖÑúÅ×±\15)T\18`ªM?.á=SZù\90øÁ'Êdµ®\872\13y\1cÌéQB\10kÚ$ÿpv>@\ 4Á\89j\81_\ eÀæÄhû¸ïÀ\90oλ\1aÚDÁ!òi×µÞ½\82À:\9dþ\88\ f\932_\9e2åTúe\fôÊ\17\9bb\1d\9c«\81ëÆEgè\86¦E¨H\98v$\1eÕ-ñ\19\87p\ekû>\1cÄæë\84nÌêÖ\a\b\89ä)\8bD\8f\8c×\9eñ`r\9bÐåC\1ej%ÎÖ\9eqm\81Æ©r9+þ!¡BK`³â}«.\8a\bf\82Ù\91_/<?c\ 5­æI\18\9c¿\1d%\97~\99 ¬×\8c`\8bç»`02O¹\80\ f¸@@1\9d®\16\9e§ÆÀ¾ù²\b³\11o¦`:`\83\96í÷Â\93°ù÷À¾/éá°õ6ì    ò\94[:\10{n\\0\1e\16`±Å©Xl· Ç,>9\ eq\9f®B\9d\0öëiY,±jÖ\87\ fA\8b6\1dá\16\1e\9e\fðL\80\87õ;@\84\13ÖÏÇx} F\ 6\18Å\1e\90\1c\90\9b *Î\ 3*xÖÍ\92馪¢\9daâz\11pø¦ö×~èå²\17ÕY\11ÅÓª\9a\15\15Ù¯\90\1fAÕÁòq@!ÁfÌ\10
++½E\1f7õÝ\ 6P\b à]^\81\9a¬\8bjýó~S\84\83\96@ù÷)Y\b\8f\96
+ä&'\1c\9ajGÉrj\14*ÙX(}[禫d\1dö\eö\1c\87\85,wRz!\8b!örµÕ³²§gAËNñË#ÒUh PùËHW¡0ÊM\ 18;ÞMkØ\8a±Á´\1eP\ 5G=½j Ã
+Öó\b\ 3\19¬øsle\8aúÝ¿a\ f\ 3\87k\99\15\8bâ¶Ís\9cëÊFxõ²\11\9e³¢S\19
\9e\12¸ð\bµÅÔ\93ã    8\17~à]ß¡~[ÙÖá»ç  Sþâ\90×\9b*_\84\93°\ 4C>½!CÀ/
+\1f¶§Z\86Þn\19\98=\8f\90PpA´{!\12rg\88¤\91\84\7f\8cAíäU\89ý\1d=\0Ñ@ñò\b\v¹\11 j_\86\85\\83/èÿ\99\85\\82Ʀâ`\16Ú\ 1\12r\81Q\8eÿ\11\9c½?Bm2ÁÛ/\98»M¸HÇGn\89C¬Ó\ 3×D¥l\97\15ý\\87p
+®ßH8\9cÞiÄû\18×\11ÌÀT\1dîN8ð\170\8b\170|óÄÔ@°]¹\11¹¯\91\93]®Å2µléÙkcÛ7H\86\95\1e\1aXϸiyH\85Ëä~q"\98i\8a\8b\1e\96LáS\94*¸<\94\18Ý\ 2ð=[@϶®oå\81 \1e\1e^\ e\95b\11\95¢û"\83k\1aT°Ê£\82©\87r\9e=äóç Ú\83\ 3\ 5\9a¦zËX&YÊÝ·¶!zm\ 3s`].ç\8bxiiú\82\89}a\8f¢µQÑ\ e\93\9bII\80B\aTº¦¤7Ï\7f\ 1\14\ 6Ç_
+endstream
+endobj
+2146 0 obj <<
+/Type /Page
+/Contents 2147 0 R
+/Resources 2145 0 R
+/MediaBox [0 0 612 792]
+/Parent 2106 0 R
+/Annots [ 2123 0 R 2124 0 R 2144 0 R ]
+>> endobj
+2123 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [420.568 540.064 435.29 552.562]
+/Subtype /Link
+/A << /S /GoTo /D (table.3.1) >>
+>> endobj
+2124 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [391.51 516.154 406.233 528.652]
+/Subtype /Link
+/A << /S /GoTo /D (table.2.1) >>
+>> endobj
+2144 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [376.746 324.813 391.469 337.864]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.6) >>
+>> endobj
+2148 0 obj <<
+/D [2146 0 R /FitH 686.127]
+>> endobj
+2149 0 obj <<
+/D [2146 0 R /FitH 428.966]
+>> endobj
+2150 0 obj <<
+/D [2146 0 R /FitH 393.1]
+>> endobj
+2151 0 obj <<
+/D [2146 0 R /FitH 309.356]
+>> endobj
+2152 0 obj <<
+/D [2146 0 R /FitH 273.491]
+>> endobj
+2145 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F83 1265 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2158 0 obj <<
+/Length 2483      
+/Filter /FlateDecode
+>>
+stream
+xÚí\19Ë\92Û¸ñî¯Ð%UT\95Å%\0>ÀTía<\9eIM*¶Ë\1eí%¶\ f\18\12#±L\91Z\92òÚ®ýøt£\ 1\92\920\ f'¹%\17\12h4\1a\8d~\ 3\88\16\9bE´øÛ\8b\17¿\gb\91\87yÊÓÅú~Á¢4\94i¾He\1a2\9e-Öåâc\90\85y¸\e\99\f>\]¾{{»þ°ä2øír}óîíòóúï¿\Ë\19   Áe\98¥\19,`&³(G\9c\17\91]s±\12L\84\92\8bÅ\8a\ 3áT\10Úz[õË\95H£`ßµK\18
+\8aå\8a\ 5º<,YÐi\1a\1aÔ\17\Y[Ìaká¿\1fT\83\ 3CõC\97\ 4z}¹¦FAÔô§\88¥E¥\91(áÂp\92\a_\97I\12¨úàhV\rÁ\7fT\9bÕ\ fµ!`Û\95ºÃ],V,\ eó8\86?\vó$!ÞïÛ\ eñ²@ѯ¯\9aM­©}Wãú\12v\ 3\9f/\7fªûA\ed   \1c\12ƾÓeU\fUÛP\7f«z;ÕLÔÚÂ\ fMÙ6úOÕ\94Ôïôpè\1a\8bkE\91\ 5¥^\19F£c\16O$\14Ç\19î<u;Ç>î<\8eÓ Q@WÕ\ 44;GåË8¸¹'\84Zu\e\ 5mΠ  ×       ÖG^u\9a¦\97ÚÎ*\1d'(?\ fÏE«º^×ß\ 1\89\83\ 1\80¼«÷/aP0\92HÌ8È©?Ô\ 3ì\8e\ 5\e\82\94úT\1c@l4\ 4K[5\84|GæC\9d¾Ú4\15,\17{\85\X¢\86e\11\93 :l\v\10\ 4(K  rW\r=J6N\82Û\831\8f-!(\1a\7f\80\81®b\88v\87¦P\83Ù\ 2\80\87\96À\8aºÈ,\r        Xt\85\96\7f\a\ 6\1fï\9d\ 6;ìí*ÊY£\84\19°ûïÔ.«¾P] ÖM}ktÀxµÙênEnBÓ`sÔjïñ\9f\a#`À%þÀOÛ¯\8av·¯õN\93j        \ 1X9\16oêX<â/48>\7f¼¨\87m{Ø\808EÄ\81K\13Y E\91\ 5|\11¢\8a    )\11Z\a²p\18tï°íÀÌÞ\9c8\0ºSCW\15\ eù¾kw'Óöjõp èÔN\83ÿ\9bÙ)\85\1aøÛ¹IÐ\83Gï    ¶Õ\8ad    m
+/0n\82\97\82C¨Ï)ÀdÁ\17è\83ý\vf8¢=\82\17v\0\81þ»¶·­¾úF\8d\12-[À¬1>\ 2\10BNï³\97C\8f¦Å!8\1aö8\84\f\ f\15mm\ 60¢×ªÑ`ê1\8f\82\8bÆ"\e³Æ\rUÄÜ\14\96\9a\9b\85\95?Q=Ôv]«7êÀnw\84Ñ6\85ö1l¤\8dÎQ\92§\ 3Zx\9c\98\18\ fY\96AZ\8aB\96Ä6{\9dà|\%Q\14ü\86\11\9e2_\9cÏS_\1e¦¹t\99ïb)xpy{yñ\8f«ó,\99Ä¡\10#êK\ f±$äÉ\88ðú\11:\99dϦóêÍí9\r\9e\84"\7f>\8d·ï?ÜúÒ~\98\88ç\13\ 1\1a7ÿ¼òÐ\89e(#ñ\13t^½¹ñ\91IÃ\$'dä¼Ô\ 1/IÃHd'\89r¨Î\89aÁÂâÇ\88%aÆs\87°¯ý4\12>\93Ï\8aç\90\14!\99\9f\13ãq\98\8e¬ÿ^E\1ebÀy\9c\9c\10\ 3\97ÄH`ã2\97ùTJÙ\80\87°MõÕÔP\ráVö\7f«©\ 4AkG.£E·YPã\83±{DJC°ÚS\870+¶DÅ84ú%øô`\17DnLDÌD\98%ù±¸M\11\ 4^9KÈ.ÚB\ 63Ñö\e\7f\94"X\9f
\16\15ËCÎ\89&÷úìE\8fù\90h]\12y
+¼Ð\1fk\15\8fµå2\8c²±\9a½|wu}í3·$d\93\v}ô)u^\14ßy\f\ 4ZÙhB\9f?F\9f    \ 5ìn¦÷$\8c§\0ó)\8aÄ9\9d\f8\19MÃI\rÈ\9d        .\83:=ÊHt,'|á\95Ý\1aiØZc&Aaô.¨d\11Te@â§öTPL\11\1cáw¨æïÔ.»v¿§r\ 2#sãj\rè\9c\94\14c½tÄ]t¤÷ø1½\9f+6\ 6/KÓ1À¾¿ô\ 6ÆtR\1aª\84vMv\13Ïì\86\84r*â,\82 /\8e%\9cü?£ü\8fd\94ô?Ê(pþ\16âç2
+¨ÿ¡\8c\92\84I<e\94'\82\8f%eò\89\10îp)²³|\82°Y>ÁneÿOæ\13Dòæ\13³bKTÆ\1aϱa\12I*Ã\\9eäí\vdÂÆu_2\11?\9bL\9c¿¦^\7f½Æé­\8dLzªÉÏ\83\ 2\9c\7f\8c´³h.n(1£1ö\14>åÂÞ²Qeö \81!Ö¦®\96º©xI\8dª)êCou\81Yø¯'[\93\90¡Ìyd
+\98\9f¢$RðaOÅÍ#Þ\93\bj\ fî8ûñÃÇ|\ 2®2\1a/\99O\86<\96ú\9b\7fºfÉDà\82}Æm!ÑuîlÐï\8dáµ\8d=}f&÷\9c3Çrp¬)]û$+¡¸\1ay\83SI\92\8aà*Ü\84(H)&+ã°Ñ,\17Çfv¤Ü\98NS\98ìZ:Ô\1a \8aÕÃZ\1a\85SHt\8c\10g¿þêõÒtD\90Fs6s\96´4\1cº\ e;kï\ f°\ 19\89çüÙ\ 2úËl\99Ê\96e×Õ\ 6Ýÿ\11×\16P\84É#«\9a×\1d)8Y
+\r\b»"\9eLñî       SüéÒ\8dE"L\19{VíÆÿ\9bµ\9bÏk \97%\8f;\r\87 3®â«þb\b{üß)þ<ü\b\11Æ2}¶\19\9cU\8f\1c³3³JL&%\16\ f)ñ¤\86L\98QeÂ)\94AWQw¬!\13æ¯!\13\90\80?«!\91H3\e:ª!Íe\11\88\a\12ý\91G{ÊÊ\15\93!\87\13ØÙæÊç\ 4ËãÊ\ 2¼íé\12S\9e\18ß\91¦\8e\8cïiE=§D\ 5\82\84ÀMáÂ`§\12`x%\9fÈxºö\17\10|\19O\825Åð$¸i\96\ 2/K᣻Þ\ 2ñ²ý\8c­ÈÈQäî~\1fqY\1cð×ø7Á\ 44Eù\8a\bÁ ÝÚãhO\80^ïUG7\9cn\12Þ\13Bn ñÙe"\ 1Ô\1ej¥ÂØJOsÌ\ 5$s!\ 3\0ì5\ 1\1eâ ô]\1f\11ÿ1\1ck;Õô÷m·£®a\14þx)Ü\99+5è\18&\fÏ8\ 19\8bù¼J\0¨Í\18\98tb\17ÀcskÝ<\9bÆ\18í¡MeÆ)×c\98¤Kð\87¯L¯&Â,\9b\v\11\ 1©\95¡»ª\ 4\f\92aj\15r$ÃÔi1\vúBÕæ®t>uþ0\80ýÑ\99\ 1I\11è^\15\83)®Æ¥³#M?|ÁªkàÚ\15A"\916ºà\9d\88½\ 3\85\rÛ¶\ 1\15â+\a\ 2\1cÿ6ÀØKëÄU¾8Ýi\1d\15\ 6\ 5\ 3ÝÉÂ\80\fDÌn\9a ã>\88¤GA÷í\ 1Ç%³\14¥}¸À\86ñ\149³8,V¤\fn\ 6\82\eÓ\83¿êûÃÎX\8a\99­ì°¢__íªZYÚ\8e7\Ïñ6Râ¨w¼PF³óÜ¿CÍoâ,O­6±\ 1|\19¥¨®$\80Q>6Ü\r1]t\1f\8d}\95\83À\8c\97W2
+úÖá ÿØRô+«¯\15)\ 6Bòø\1c\81\90bÈ÷ôïôï\87ʼ\16\96>Q»§7éB\ 16fÎ\f]zz\83ÆüéMÆ3_\941UA#N;l©[V\1d\1dyðQ'É3\e\ 4S\9a·v\9e±-ÃDå½Y·:âY4ê\88g Îº¦\90ÑÓ\18   3\8b\LÔ\eÝÑk\96\19\9d6fº-ýÛ=m¬3I\18ÉþQá\ 6\88NÑiÕ;
+\90y\v#xo8¼¨ÑÚ#9ª§§î°íðå¥=\f®¯mc&éHÒk 6¦\8b~À1"\ 6 1\85­\ eRøø\1a!\83~[Ý\9bW³X¤Á»¦þþhÐÃ\98Ü\18·\14±a\14\8c£7O\ e¾Ë(4'a\1fר¦?Ày¥´ç+Ë\12¦ÖÊD.À´\18ãU\18\ 5¨\8cÞ[J\8bD\12oûj\16\97L-m¸«\ 6â\0j£Ð[/_­_ü\v\1c\98
+endstream
+endobj
+2157 0 obj <<
+/Type /Page
+/Contents 2158 0 R
+/Resources 2156 0 R
+/MediaBox [0 0 612 792]
+/Parent 2106 0 R
+/Annots [ 2153 0 R 2154 0 R 2155 0 R ]
+>> endobj
+2153 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [360.716 503.571 383.188 514.419]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.3) >>
+>> endobj
+2154 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [359.26 402.782 381.732 413.63]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.3) >>
+>> endobj
+2155 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [374.709 339.879 389.431 351.834]
+/Subtype /Link
+/A << /S /GoTo /D (figure.2.8) >>
+>> endobj
+2159 0 obj <<
+/D [2157 0 R /FitH 686.127]
+>> endobj
+2160 0 obj <<
+/D [2157 0 R /FitH 534.047]
+>> endobj
+2161 0 obj <<
+/D [2157 0 R /FitH 488.98]
+>> endobj
+2162 0 obj <<
+/D [2157 0 R /FitH 469.206]
+>> endobj
+2163 0 obj <<
+/D [2157 0 R /FitH 450.54]
+>> endobj
+2164 0 obj <<
+/D [2157 0 R /FitH 430.767]
+>> endobj
+2165 0 obj <<
+/D [2157 0 R /FitH 388.191]
+>> endobj
+2166 0 obj <<
+/D [2157 0 R /FitH 366.979]
+>> endobj
+2167 0 obj <<
+/D [2157 0 R /FitH 339.236]
+>> endobj
+2168 0 obj <<
+/D [2157 0 R /FitH 324.001]
+>> endobj
+2169 0 obj <<
+/D [2157 0 R /FitH 299.302]
+>> endobj
+318 0 obj <<
+/D [2157 0 R /FitH 269.58]
+>> endobj
+2156 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F83 1265 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2172 0 obj <<
+/Length 1938      
+/Filter /FlateDecode
+>>
+stream
+xÚÕX[\93ã´\12~\9f_á7\9c*b,É\96d^¨ag\16\96\1c6uêPÀ\83ÆÑ$*|      ²3;ï§[-;ÎLv¹Ô¾ð\12I­V»»õõEÉ\93]\92'_]}¹¹úìµNª¬\92\&\9bû\84É<\93R%RË\8cq\95l¶ÉO)cùê\97Í7\9f½VbÉZå\99¨\14È L¯¾¾þÏæö\87ÕZ\b\91ªlµVJ§¯\7f¸þö\96H7·¯¾¿¹E9Wyüúù§×L\95YQ\8a\15\10\ 5\89½n\9aÕºÈuêº\15×éh}k·Î\8c\96¨\ f«²LMs´\ 3­\8d\8f\e£?v5°mã²\8fû4\b¾¾s#Í\a·ë&6o\ fÞ\ e\96>eF×wD¿CÂ\13*\ fj\16YU\140²¬*KÒrë\86Úø­ëv`,\ 3\8d::\10\16{·Û[¿îýÖz¢À·\a\9a\81Ua\1c÷ÖÅÍ\11\8f¾Ã\9fþ\93ÈU÷í¡±-ê¥`?Ð^ª
+>/\84N7{\e\14ÍÏUü9gEgÀ\99B\17i\7f\1c\ fÇ1Îïi´¦FY{\\95)»!êèM7Ü÷¾¥¥\e&òìÞ°ìi440IîÅùä^\9cÏ·\15\85uñôe\8d\aÓ\ 2#WEÚ\9a®³\1eíãeú¦#âÁ\9bztµý\14\96Z¦î\9eÈ(,LÐí4{\87n\ 3÷Óª\8f\8c\86\ 6&   Û¬X`\913\99åª\98°ýs\9esâZ\ 2VgJ\8b\89\ 5Ä\ 4qÁî 3~ôجX:ºCãê\88&®à:M4á\ e\87\94\8c_s^dºTç>èïFã\82ÿ¸Ö\03oë±yZ\81ÓÐìJÑwa\8b Åµ
+W\84\94á\bW.k\17!BD¸Iâ²\ f¨\9fõO´¬MS\1f\9bIG`´\8fµ=ÄC\80í&@\e9ïðÜSô\19[¸Cp\9d±Ù\1f¯^úKeZÌûEFV\vQ\86`?³z³G\95\8f\ 1k1\16\ 1wàÑ\0½H\bÈ#?\88Ù\ f"(ºÆs`ñĺ7#mµA|sv1Ka¦iz\8aÂ@6\1d\91]\8cÂõ\19Z%é<¥\v!e\1a]\ e·Õ<\11ÅÅ\9d92`îíÎ\r\90Ð\ 6\0vYðôÍ\1cäSD\ fÄx\1c(±À´1~\17²Èò<-ɨa¼\18J\10\84kû8ÚnKÙ8D\89\10\8bP\ 5"\84§\9cÂSÄ \ 6rkbî5Á
+ØÁ|\ 4
+Þ¹Æ!¾  \11\80IºÓK  ò»>\XQM·Pè\10±H\99U(ôl\13í\84l\8eäã`·\0xQò´Ç¯=\ 4Hx\0x9_\14ð\aý
+\1d­C\ 1Û­\eQGò%R\82\a\80\aÖ,E0ÝA\8a«×ïÏíóEÀ\99}\7fl¶4\8fð¢Å\1eÄ6!ËÉ*^\17\15Ì|Y0\ 1ê9ÓS\ 4\1c»Á\8cG¿*Y\8ah\86aû2fÊ"S|®±Æ»qßZÈz\ 12\15\ 4Jp&hà\ 6ô\8fRÑvP\ 3ó_,:d\9b®2U\94çÆÅ´QªÙ6\9c϶á"Ö6\e÷\82\ 3qB\89\16&1V¦\ 2\17\ 4Ìb½¥\ 4\86éJq¸¡\ 1\81\0&G)!\eÃX7¦=P\92\89²/Ä\18\14<\88Z0/\8fèÌËho\8eEâÑQ\f´DÀT\87\1c­ëÎ7æ2\14*f\ 1^\fe-/O\81\8f\90ðò¥p\84\9e}\f!0\9e\9a\83gaGñ"@or\ e\85±\br\aK{è\11\7f¬'\94\ 1å\1d\r\1fª3pn\ 1¡Áa\ f\bc\bºIĽïÛ)\96]<9\1cèâj\87Õ¾\8e]Áûbr\13\8c+c­\87qYëËX¦pÒw!\8dá\fM\8d\95ã,ø`/\843\8e\1dµ\16(¡'}Î
+Ñ@{s&Ã\ fCü\¨Â"gY^\89E\15\96\97ª\8a\89\9cźÂ\ 5\94gyn1å\13ÎÒEë\84\18(Xúu?·]ö!\16\1c\96zð9Æ\15\9f \0gg\10Â<ôN0\9aáy¢«\81ÕÌÊoh\ 4\9f\86\1eÄ`\ f\128\16\9eF1]TË=Úæ\12\90æÌ\1cj;%:\1c)\ 6a\ 2ò@Õ\9d½àE-2}Ê:àÄü²\13g\16^\96\17Ê;tD2/'\9eÏÁ;RÑ ax!\91\89\8c\9fº#\14\19ô¤ÖG/Ò'RM4+`\82ö\81ôÒ\94Jf\ª¿\81\aÍJE¢·Ç(xì\9f¹\ e»\9b\87\8e²÷S;\ 6¯\91çÝ\18\7¼Pà>!o\87\19U3\9ca\fâ\88Pp!ß\15ZP¶DòoG\13\9b\82ߧw\ 5P­÷½\8f\akÊ¿8mͯ\11\82ô\r\92]LÈ\8c\87)\82²K\89\12\87Î\aÁ«ó\88HÅÞ\1f\91¸\a]v?Ò|À^ç\89æ§J§ò´Æ°À\M­ë\96Xb\83ÐÓÊÐ\10Aë"\ f@tgÏ$\86Öì\ 2Úcs"Na\92Ñ=ÃÅ\9e.\1a\ eÁ\15éJ.³\19¸|z¹À;ApP\ 2~ G\8a\9b7¯6ó\17u&tE\87ßÄ\9c\ 5\1c\aãáÝ\81mU@õÕíæê·+\ 6\aò\84ÍÏc¡\8a\f\8amR·W?ý\92'[Ø\ 4\99\99\82çð»ÀÚ&¢\80\ 4Äð`\93¼½ú不6D\14Ôc!!@«"öIôæÉá\95°      eå0Ç\89bEúÖýN\1e«À]\92=\7fá\959\16^\18)       
+\9diøÖ\92çmx\8d}\81o\87¢Hoì\10îÓcm9Äþ\15j\8b\99ÚDÈu£w±8½ß\e\85\ 4WêçÞ(*ýao\9c]' Ó       |?«4'u\7f|\19ß \8819\ 5ø\9bø¯À.v9Ï\90tí½9UgÅ2%Ø\99?Âó\89\ 1Ç\8fØ¿\86ô\8a«kpD    \89M¯m\13
+A;¿¢\90lf±a\89i\ 1G\ 4W\98\8c:K©2QêsåNñ\97}À·\fN\82å\7f\17i\17\12\ e°ÉEôí÷ó\7f\0\7f\11ô\1c\0«¸ø( ç%¤ò\7f3æ9|H     ñq0Ï9^²&uÿÿO1/ÿ\fóòO1\8f\8e\b\98\1d]²À;r\84®\aÈó¿Hôv\8c\7fÄ}\0Ì<¯2©øÇ\ 13\83Æ\ 6sp°é\7f«
+ÃÒ\99»ÆÆ¿¨ðÍøùÙÿ\8dÓ\bºý\ 1rçZb
+endstream
+endobj
+2171 0 obj <<
+/Type /Page
+/Contents 2172 0 R
+/Resources 2170 0 R
+/MediaBox [0 0 612 792]
+/Parent 2106 0 R
+>> endobj
+2173 0 obj <<
+/D [2171 0 R /FitH 686.127]
+>> endobj
+2174 0 obj <<
+/D [2171 0 R /FitH 410.641]
+>> endobj
+2175 0 obj <<
+/D [2171 0 R /FitH 410.641]
+>> endobj
+2176 0 obj <<
+/D [2171 0 R /FitH 374.776]
+>> endobj
+2177 0 obj <<
+/D [2171 0 R /FitH 302.987]
+>> endobj
+2178 0 obj <<
+/D [2171 0 R /FitH 267.121]
+>> endobj
+2179 0 obj <<
+/D [2171 0 R /FitH 195.332]
+>> endobj
+2170 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F11 573 0 R /F70 508 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2186 0 obj <<
+/Length 1964      
+/Filter /FlateDecode
+>>
+stream
+xÚ¥XO\93Û¶\ e¿ûSè(ÏÔ\8c(Q¤ÔK'ÝÍf¶3/\99fÝét\92\1c´\12m³O¶\1cJÞ$ýô\ 5\bRòßNß¼Ë\9a\ 4!\0\ 4\81\1f\80M¢u\94Dog?/g¯\1eT\16\95¬\94©\8c\96«\88'\92\15²\8cd!\19OU´l¢\8f±b%\9b/\94\ foîÞ¿{Z~\98§EüÛÝòñý»ùçå/¯\1e\8a#\11YZ0%\15(p\1f\91g\96x\9do\96³/3\ eË$â\93\98J˨ÞÎ>~N¢\ 6\ e\7f\89\12¦J\15}u¬Û(\13\19S\1c?l£§Ù¯dû±^ÎSV\b\15É\±THÒþ®Úêù"MT\1e/Ñèï{Ø\15\14\17ñ\93ùK£uQÉA\ e\8f\16\1c\9c¾ý\94äɳ\19zøuW\88²\82\15 ë\98çɬwºù        Ä\95BÄ÷º¯ç\v\1eÛ9\8fÍ~0Ýn¾È2\11\ 6\17Ylu?XSãIï¼rÝ\eYÉTvá\rQ\16ÿ\837\82,x\rÐLÖ.Á
+\99Èøq\87¾\18ôZ[w1\10ƹ<½ýkk+ç1Ç¡8XÄO®\9e¥pk\ e\1c\7fÌ\v\81\1eåqï(*~\r÷\ 6Åq±Ð­ÞjÒF¤j\14ë¶uG\87\95Ù\99Ý\9a\86Þ\ 4b"ËËS«ê\83µ£<ôèË<Ïãª=hÚv+ò¸®jdÚ\10µ\87WªZZ·f§\99\93¿àEÊÒäìÞ\1f\80-/Ó\13\1f-\ 4\17i¸°Â\vg±îýõ_\93ÜAo)¶:[ÙïgƱÛ\8f\9d\97\90.iúÿ\85~ÊYÁ³(\97\10¡"< \98\9d+ððvß\9a*øLä2n´\8bÒ\ e\93\06\96\18ÿóÛÓ\92Î\ f½&\12¾\84[èoU=ÐÒ\80¸ñM+\8aq¤£çñãñ\eãX^ð\8f¶½ö.\17\f\12åÔã÷w\18\97i     ¦|J¸\80|¢­qÙ\93\80\13¥÷Ù[\e\9dv@&!²ø©ÃDG¦Î3Ù\8aÒÌ\11·!èpó\1c0\07V/:\vNÐÍ\ f¤îù0ÐI\88ÃäÔ\ÈáC\8b,*\8b·(õÐûÝ$\176{\vföºýN[ýå`|8xß\81á¹Ìâ%Ý\ eXÂoE?\8dÆ°\rk\90Ep\ 2»aSy\8d­Ù\ 2@ѺG\ f\±·\9a\9e\ 1\14«ø\80\91\9b\89\82rE ÛëÎYîBÁ\9d\0vmÍ_Î\81è\95<ó^\813¸×\v\8añ·ð²*'ú;m\1akV\ 3Évo((§\1d\ 1>o\b\0é %ÕÝ\9e]³}¹Ñ\90NÀ!r\8cJL9!cOàr\ 1ðL$3e+@zC\fÕ~o;¤\7f3[\1f©È\8b÷ÆãðëlÃ\83b±w)Ñ\19w\9bÁ«¹§ß1\9e\15ų#bì\1eÛíËÎsÕ»(Î@\98\8bb\9f\17H¸Ûè\1d­V\90T\9dõ~&ÒG_+1Ùí:¢Å\87·3\90y÷ô ÔI)\ 5âg\fÿ\Ä\8f\ 3}o1ά{aØqI¿\14¦í`\0     ê1-À(_\98T\9cÊ«¡Ó4fäΦ2Ö#|\1c È=\ f¶¢jÆN,;ÿ\ 5ä;ǽ´\ 4xOsĽ/³\84IÅ¡J!ËñÚ\1d\86/=áÕã\96çÑ}\a@ø먠ð,\82øÅ\91üK¼Ì\v\96ÂY*s&\0\8eÜe\1fÌú`}\19Q\8cÿ\88¸\92»\ 2\1fJÇCë¢é+íÞÚj¿¡j³ê¬/\ 2\e/\0\83\ 6O\1eÏ@Ð\1dú ¹ðR\ 4Õ\99   \9e\82ñ¹\ 3ü\80ãY\91O5\fÖ\80~ùh
+ì×Þ\94\82\82\1a\7fÉ\12\XÈMNO¶\82EgC.à©Ã\1cø\85´ì \1e\ 6\17¸PÑ\8dgñ~A\83ÉË\10\97´pqéxÀ_ç\91\89ðV\96\ 4o7¡?\18.EìRUÅ/¦qÑ\v\14ÄA       \97ó\b\8ah/¦?Tí\949Àí.\ eG_7f,ý°ÝWvèO9È5@@×ôðv[¢Wîõñ\epSe«vq-'Z\8dz\9f
+\8f\88\97f\8b®õOkvµÕU¯}Ƭl·¥@hõÊw,Cç{A³ÞøB\80j®¹çÍ\8d.&u]\8c×Ø\13å\b\9eº\96\ 2®\19O|úÒþ´@ÒÙ×\8d¦ØO§\18\ e:R¯\ 3Ê]eÿ;I\86¯Ì°!\8eêö\e7Ý@C\ 2\17Ç)X0\9eåaHø\94$ür\92\90,w]\8fcq)¦$UG\19×ÆÖ­³\ 3Zû}{è\89ìJ楶2\87þ¨\9c´ñäR\eL bdÁèU)Ö\1f¯\ e n¨¦\92\a¤;¯\87\1fÉ(8KJ\19\84\98kJ¸\1aÏ  OAÔÓ\15Q\0\ 1\ e\ 4\1dç\9f\97\92
+@\8aqÈ¢ÐU¡ÊÀ"\14GtO(\8e\18§¡å\a\88IX
+\1aN\ 1ÿ¼b\9e´
+Ø®ã4ä\9dÇ\13x¡Re\ 5Í\e        Ë³4ÊX   Í,]ÿS\92ñËÆ\17\861\ 6ÓR\84Ý·\10Åyã\9b\1dM90x\8aô´íUG:GI
+"%håòÒW%ÄZ\ 1¦\89L\8e£\1d\ f\8dKC\8bÞìn\M\bÆe\16\89©Tü    ÑQÄ7®'Á\11eþo®W0\99\94ÿp=\90T¦Å¿¹\9ePüúõZÓ\13 Ã:ôbK\1c_\10Áþ\ 1Ó\81M1\99_\ 1uQ\94ñïÔÂP_ç\9b>\b\1d\82\95Ê\a\18ø\f"â´/Úéo\18\93R\12
+"èÒvÄ6 !î`שD\80j\89\93\94\fc\1el ôóР    \ 3Å\83\95ô%\r\15\ 1\ 4¬\9fC÷?Á¿\8c×&tÅn{\9câ\98þ\82Cé½R\0\81î}K¹uð%æ\ 6ü@(p Lðs\ 5ì@E6ý×$8Ê\97\vIS\81<*\ 2 ­5P¨v¾\98\99]\83½\1d\15ÏqF\90¡'\91Ù©\ f\85÷á1§ó¡{»\12\82©8ûwH(\ 2\ 65Ííªõþb\0\93\89×Æé\1a\1c³\rl_·:lí8TlWT$\ e~¶;¬7Dö×H¦\9e\81ÇuµÛu\ 3\91§á\v\ e¬\1e\9buÉO4×\ 6F$îüp\84£f¦\8fþé\90'd¢ë©p7Í\96b\9c-ýÔä\8a\968\1e?s²T9Ka£¿éúàS4\8cK%v-U\v\9d\ 6æ[\99Æ÷fµ¸Ú1\ 2òü\rásîT
+endstream
+endobj
+2185 0 obj <<
+/Type /Page
+/Contents 2186 0 R
+/Resources 2184 0 R
+/MediaBox [0 0 612 792]
+/Parent 2189 0 R
+/Annots [ 2180 0 R 2182 0 R 2183 0 R ]
+>> endobj
+2181 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./idct.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 2190 0 R
+/BBox [0 0 512 280]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 2191 0 R
+>>/Font << /R8 2192 0 R>>
+>>
+/Length 2193 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9cÕ]Í\8e\91¾×SÔm%\ 3ÝNþ\93W/\16\8bÔ\ 3ì\ 3ÌÂ\12\f\8d\ 1Ù\a¿¾Éøâ\8f]Y^Lû\92\r\ 1Ó\91\fFðc0\19\f\ 6\99¥ßïÇk¸\1fë?þûõÛí\8f?·û/\7f¿ý~;î±\1fÇýÛm1~»\95\10\1dA¬ßn¿Þr\ få5ßcÍqVÍ㨠\7f\13ºõEK­Ó§Þè©\1e\9eG:~½ýï\1fî\7f½å×rÿ\aá8î?ÿ÷-\86\86ê³Á>\9a\88¾Ý~\9au~y\ fé\ý\ e\84\1aûó\1fÞ7ôQM¿N,ßiÀPª\1a\90èß\84\1eNÿ\93\15J?<¯:\ 3.\8b\11\9f-Æu\97ÅÞµ\7f®koµ\8aµ>(ú\11óÄÃ̳h1OL^ÿù\13pÅèqA\877Ïâ\8byP×\9b\87Û?×µ·z¼3Ï÷\8a~È<Î:îÝÙl\7fò\0HyCôÞ.ÙÌ\92\1f¬â{¶©ÙZ\8bï-ò\1db\1f°F\8cÝ\9cÑ¢Å\19¥àçêù\13æx:ü\1c\87\ eg\14â\8b÷A]g\16iÿT×Þ*4\9bi¾[t\99'äÖî\85\10\85\9el\9c¨¼W+\97×\9a\18üÂ\13§³\ 3ýNCwsúÝ|~÷\1eñô\81:×½\eíù\9d\85»¹÷^ßÙ·{w¼«ÙZË»m¿KLí\8a÷\9f¬T\8e\ fY)\f7;\87\9b\9ec{ÛÏ\9f0GÆ6IÆÃ\1c\1dn\92\8e\87Y:¶ùöN×Þêû\99ú½¢\1f\98­Ù&k¶¹Zü»~ú@\90\8a\9f ùý4-6KËûI\9aýDÛÔl­åw\13ô»Ä\965ZQw\11BpÁ
+1\10Å\80!~d1xD\89¡\8b51°\8a\83!C\9d¢¾¨©&×\ 6\11â\88k@5ÀJcÚ'\97b\8c\8a\8a\9exV¦â\1aÇ\13\a\17-87C"òn®Z2\93\vnó]\8c¥H+q\ 4\e6*\a,*\17M1\fm\9cêh×\89Ã]'ÎÞ\ 6Ã"eÚGhHÖ\8cv²iódùîÆ°Û\10\16µ\95\fG+\9b=´×T.nú¾þûÛ/ÓÉÌ·FüÍ"ç«\14r¿\87^Ãk/÷Qîä\87æ߯³F\88¯\ 1\85m¸Êô0\95Ì*DÖ<eç_®\1f:kYÄR\ 3Ý(î¾~\17=óí¿*4rÓý07]Å®\ 4ú\8cñÆ\8ba°u±©À\19ã\r]\96\ 5v\92¹í½_\93\87\ 4\16aý§âÕQ­¿\1e\96\1e6@\89»\ 1Jf=\8b0\ 3 ¸ûú]ôÈØ\\13\9d\ e\8fÀ«2Idx\1e\18<<¹Ù²\9büð<0¦@\9bqs\19TNdå\ eÕn\bkQà5Y\7fjðõ\ 3ô¬:\93¬\81\ 2\9eE¬:POÅ«]­/x0<×E·\86\a\9bÝé}~¿\ 5Ðüçë·û\9f¾Üþøólùxí÷/\7f¾!G0\9dU\8d¯µÌ\15¯Þ¿|»ýðòã\97¿ÜþëË\Zßy2       0É_\8c\82)Îs:4\99ë\8b²·\12\fx\r\16¡\87¥KÜFÌ\19~\81Eb\15]\8br\8e\ 3\8cîEºêR¯vm\98æá\ 4gÕ%E}Ü#K½Üpá\7fÙýÜ\ 3\8b=\9dl\19\16\99v_Ò\ 3÷a\11f\8e.\ 6ÐúôPÕ\18½ï¾d\1c²`\1cÞ\14(î¾~\17=2^×D§Ã$ðªD  2H\ f\f\1e¢\9el\e\0=0ØÓµ¦¾¤åÝ\97´È>`\11æKP\1c\0=ìKÚØ}       YléaC²z\18òpõ\ 5\8fyºk¢û7=]ËO=ݬbñý¢c\83?\b\99PŸÖY
+ð#ÖßcP/À8\9a\13¡\87\84\15\18t\84?\10\91\94EWÂb!\8d\80Q\9d\88âÂÐ|\ 2\984\85\8eî¶KYcóÕ\85'¬7Þ>Åæ¶R\1a2<a½±\15dÿEtÚ-R\83ô¢\86Í"U\8d "x¨f\91Úw\8b´Ctµc³\b\18Õ\89(.7p×\86i\ 3'8³nÄtà\1eY2p5¹ÍñØ\ 6î\91Å\ 3§Û`¢Ëf\91P\12÷\82\b\18«ã*\82\87®\16 õØ,2õ\8b®\1a½E\98Q\9d\88â²\81»8L\1d\99u\9f,\ 3wÂz\93¼D±TD\r~àNX2p\92Ø :ì\16éCzÑÇf\11bPÇE\ 4\ fÙ,2ên\91ÑE×è\9bE\86\1aAD\14\97\e¸kô\81\13\9cY\93\15:p\8f,\19¸\11\\ e©m\ 3÷Èz»\8d¾\9c?1\88\9c\er\8a\92(*ZÏ3~\1d+\9f\14\1d+\88\9aË8=öa\ 2D/=_o \13uLë¯\95\86ô`\ 5RýTÞ\9d@W=\13÷\85Ñ}0ê\18Ç
+:ÒBö,ìHUó1 9Å\92ªæc(\93Gïgª\9a\8fIÅåcð@/\14HίHý\95xAÖ°C\8dåcШÖ÷©¢«Bû\95²\9b\9a\11\9a".UtÎàt(2B \9b
+\9c1ÞÐe͸v[|\ 5"-Ë\9c¥\rÞ\ 4`¬Îª\b\1eªZA\16_\15YË2ta½ÖFÀè^¤û°â3ÀÔ\ 1S\9cÕ\87\15ÏX\92ÜFìÀôðÃvÂz»å#k\84\f\9aÃÝ|D\8b\90\91\13\87\aH£Y\84\9cF1\11< ªe\1aá®\8a¬@\98óë\14!k#ë\91¡@ÄpÑÀ}\ 6\984p£Ú1é\11} ÿ\8cÅ\a\ 6\1c­s³I\85ÎYsàZ\8dv\98P-#\93[¶$\ e\8e\19\90ÄÉuX\12'×æDè\ 1\89\17¦\91\91Q\91\95«áS\ eZN´\11\13Q\\18¸O\0s\r\®Ý\9dÍd\9fkzÆzãC\1c$\94¸YÉ5=cÉÀÉÁ\91\8b\90\15ì
+\84ù|(m\16!Fu\112?t³\b\87»*²\ 2aèB\84¬\8d\80á"dÃå\ 6îÚ0mà\ 4ç\16È?cÉÀ!ZçfÃ6p\8f¬)4g­\1c\ 5\12Éiµ\9c,\11\83ó>Z9r²´MNÁ×\ f\92>\ 3Éi5\11Xù6Ò\834\9c¨§bjWê\v\1e\8c×uÑÑ0¥hç¨Ý%    Ï\19|X\8a\ È¡\ 2g\f\1e\1e9v\ 5\8dÝ\88@¤}
+Î`±\81\91.1#x\91 \9b\ e¦±\eQ\91ÑE\1760Ú\b1Ð<\8b(.\e§\8bÃÔ\ 1ÓSlÙXÙ\90\9d°ä\84\e\9b\9b\1f\13\16\87 Å\96v9\98\93U7ËÊ\9e·\85=˺.õé¡Ø².\as"PdU/Û¢^dM\97ú\8aÇ"\8fk¢Ó\80£XPQ¶pã\81ÁÁF¶\80¢l¡Æ\ 3c\ eO\8c\92Þ\ 6Ééê\1c\ fMoçÐ$½\9dCÑôv\ eÉÕ§\aJK\83ätµ\b\90'ZzØA±z*¦v¥¾àÁð\\17Ý\a·Á9äÿ'ù\9ez]Àh¤\16\99:¿b\1d\8bf\9aÁÎ\9cç\8d\88ùº5,²TÜ\9a«¿\1e2mÙA&~%Y\80Þá¥\87_mV\8fâêê\v\1eì±®\8bî\83#\92\11IÏó\12e\1d.S\97\17\15©\aS óY÷¤ÖI÷\82\99ù\9c{\16\ 5_3\90\82U\81\8e\84¦X¨w©=X\ 3\92\a¬\95\92\a\87«Ì 0
+×BôQËg\1cDÅg\86Ï\85R-\88\ 6@\1fX\1a\v§F\ ez'VªâÀ
+X8\95B\8c<\9c\b\1e\12ù\0Ð\ 5Kcq§ßÐÅ[\95âÎ˹y\11éªky©O\0ó£îªPÚ\8e\92BO\ 6)\8e\1aõ\16[µ%1\ e\9b²tï\f39v\9bà±7W\7f=`é\ 3ÉK¢\b¬µ\12×çh  \15õ(®®¾à¡±¹0º5$±w»\ 2\98Ý\ 2\7fÎxÃ\r>¬ãhN\16øsÆ\ez-\97\ f«í\ 4\ 4áZãpû0x\ 3Pñê¨Ö§\87ª\ 6\90\9d\80\b¬-\ 2éÁÎAÔ£¸ºú\82Ç\86ç\9aètx\ 4^vû\9as\ 6\ f\ f¶/ \87\1f\9e\aÆ\14hs\8e\ erå #w¨Ùõ\8cØôÖFlv\99#ÎíµÕ§\aòÆ \ewH\ 4\86è\19ÐÃ꩸ûú]ô,Ô×E÷A\87\16\e\1cÚxºèÄzhj\84iä9bé\96\1aáÛ·\94\1a\89%Yj$\96àE\82¦3@s\9eCEV\ 6\ 4º\90\1aÑF\88\8b\88âÂÐ|\ 2\984\85Jt\97\99»Ïà<cÉmf¤i¸Ù Bç¬7XA.G\83N\9bE(ËÏ\17ª\83·\b3\82\17       \9a²gºo\16¡,?t!ý¯\8d\10\ 3Íw³\88\9dR|\ 6\98:pz×¼ûS\8ag,¹l\8e£\b¦\87\1f¸\13Ö\14\9aÛª{È\94Meº¢{\19û°\90×2\9aè{\0,¯  û6f$'\82\aº        
\ 4tODèí']<-¤\11bPó"¢¸0p\9f\0æG½b®tÂû\97a\9e~Fà.[ÉZJG1øô n±\14\18Ý]¶ÂC²hJ\ e\T$I8Åg4ÚH\92\80JE\14\97\ 5\14\17\87©\91\85âÜî\84=cqtÁçEÜì\16þ\9d°8\0Ô/CÜÕ\ f\ 1K\99G|\19\82\94¤t\ f\8cî®~ðCV\8bH~QEF\17]HIj#C\8c "\8aË\ 6îâ0uà\14çvCå\19ëM¾»      ::\969}Æâ«Eò}\8eÛºÈm\9a,\97\eóv·1ËÕF­\7fèÖ\ 5¤|ÒpØÖ\ 5_úl÷\1a\8b\kÔúÁo¬.\8cN/\12       <¿±:gð%¢lw*ËvÛò\81ÁÃ#ßI¹­\8b ¤\9b»A·.Ò\1f*>ÜÖ\ 5\ fv\7fQïa\1f¶u!=c»½8äò¢Ö\ f~cuat:<\ 2Ïo¬Î\19<<ÝnNöíNå\ 3ãíÖ\ f¹°C\14_Ái\1d\17\9c¦Çh\92ßj   \97¡VYpU\83\²!\8aïÞHåu)\87¾w#÷!j×\135ǵ\ 5\ 4\rÉÅ\10Ñw\9cQ.\bµî.\ e\9d\15ó\97\9aä§\88\12\avVÌæÇ©:z\8bC~\85µ\92U\90l¾Ç(\ fN èA>H\1cðkýuô\8fï\11ëÖíõ\b\f\10P<6\14×D§ÃÂßTÊí\ 4\e\98\a\86\fÍÐAÐ\8b
\fN;ÌwCwö¡G,\9dM.\9dÉÖ\9e(ÛÛ\83±6ñ*\82\aÛÝ\87Þ°tªÈP]Ûþ\9e\19Ý\8btÕ%ù\87\8bÃü7\13\11\13Þ»\90{ýÜKÈC\9c\ 5È\14^[\18³¨\97׸ެµ« \1f< ·\9bk\7f¥+3«¸úúUæ;\93}\8a\87»
+\14Ñ\83UZÔSñðõõêâò¹×E\87\9f8\18\1a\9a,2\8f\1d^î¬6w\ f\ fÅÕ××\90\82É\1d^    ¬§\ 4\ f\ fÅÃ×\1f>pº.:5\1e/ÀD\96\1d^Ϭ¶g\ f\ fÅÕ××\ 5\9fÉ\1d^o¢§yx(\1e¾þðaÍuÑ©ñäÃEÐ!Ð\9b¬3ãЩqìsã\90É¡"v\87MèN:T$©®´Í\ f0\86\17±ï8uþ^\e\83M÷òDÆAM¶ZÈøS
+Ë+\11sy\9dî`\r.ʳ\13°k\9cLRsZ?\ 5Ö\93hª¨~*oN ùTÃ\85Ñ©ñ\90£\ 3Yvx5³Ú\9a7xT\9e\9d@Ö´ \93;¼ÚDOÛàQys\ 2ö\9d\96\18ï\9aèÄx\9c\99\ 6Ù6x¡H`Wª\87\87òì\ 4²&Ã\99Üà\852DÏððPÞ\9c\80]±dã]\14\1d\19ÏÒ  \13\aÄGdñ\11¡6¡9*/N@~Òä«ü|\fZÓúEô\14D×¢\7f\95w'Ð\9bK4]\18\1d-!ÕÜ
+hv\13¡\92ùá?èKav,skG\8e\96\19Ù\8b\98k\11\1a\8eVDR\10]p.Ú\b\18Í\8blÎï3À4sòw\9aÕy\1aUQå§*ØÕh£`d/bÎFè\1dçò*¬«m8Áh^ds\87\9f\ 1&]H\8c\1aù\83äH>E\8büñÃM4yR´È\7fÒ¾¾FþL"\9eR\81"zpý+ZäÏ\10¤¾ß\97\\18\9d\1aO>î\ 1\8d\11\13\ 54\96üóVÙ#dFõ"ö©²Ð4b&ÒTWó(\991¼Èðïâg\80\89ϨäK\9foL³?I\13\86º |\10\ 5\17\94j4\174\1f¼HT·!4\1a\15\91\14D\17\\906\ 2Fñ"ö\ 5\12}\9du}\98¸\12ÞtSÀ4"ü\9cªm
+øWÎøë\80l\9b\82ùàE²\ 6òBS£&\92T\17>/ÑF\88ѼH\8bnïò\19`\9a9ùó\94ä¢4U±¢1þ\9d¹ºá\ 4#{\11\vÔ\84Þq\16ýª \8c\r'\18Í\8bl¡äg\80Iæ<\82~\0C$oäóqèÆ\1f¿æ\a\8f4ºnüÓúxYêã\ 1þ\b$»j\11\a\97+Eýº[     \b¨¯xø3\82Ë¢SOYÌ\ 3I
+I\9cC\16\a\947ÿ\93ÅýXý¨_9\80dx,PÄù\94Í÷\14q=V¿¸\84Ø\85Ñá\1e\e¤\8b\94æb©
+\8fî³\0^,YáMÚ××O;\98Ds"PäÖOáK?Uá1\ 4©ßüýÖë¢Sãñ=I"Ë\ e\0ü<föðP\9c}ý¬÷;AîðÖ\f\80\9eæᡸùúÍß>½.:2^ÒL1\91:VÉ2ÅtE\88Ç6Y¦xÒ¾¾f\8a\99äæ\92e\8aI\ f\8fm²L1C\90ú>\8f}atj<\1eÛä2Å"ßå®\16\8fm²L1Á°ú\9a)fr\87G\83\984S¬ê\eóú>\8f}atºÚÊ7\80 \91ô\90\15\87²!üS¸Ñ/iÌè&Â\ fY\175I|\98HQ]Å/kô(P\10\15(.[v/\ e\93ÞÅ\184Èb\1a\11Ó\f\17-Èâ\9fý¥ +\86nAV\g\84*\82\aÜÕe\9a\1a5\91¡ºp\8c©\8d,\ 6C\81\88âÂKù        `ª9åú)è²á¤}(ÿVrö8\99Ñ\9dH°ßæ\10zÃIûPÖÕ<N0\18\8aát\17}?\ 1LÉu\17\10·,ÉÞ̧\18y;ÄÈ|\86¡µ5zh.x\90Ú\85O0Êv\80QøüBkû¸æz ÄT]\ f-Ä  \8blç3\8b¾\1dYt>±ÐÚ\1a+4\17*hm>¯èÛqEçÓ
+­í£\98ë\81¢%$H*\8e¨$\e">B ÷«\89¸Î\a\ e«´»<\9cþÎ\11(\8eÏ¥va\1dì\8dåpb}Êkµ\ 5\a\16\8cË\81RSqF#¸ì\84Â:\ 4×±\ 3;\18\19\v\81]&±\80iý$zÒ\ 6\8er\19Á¥2ìV\93Øì\9aèt\87!\97nAcA\97(\9b\96zþyüèÃxfd/\92\16\1a.SE\8aê*>\94gFó"-ºPå3ÀTsÊås¢9õ(*()\89ï7ⶥdFö"v®#ô\86\93\92\92üÿ'ض\95Ìh^¤©.1çÅa~ôçy×w>¯\85.\85\1dëRXª÷/ÿsû!ÿø\1f·\1fâú§Î\7ff3«°L\92ùi±Úügµ15þßí\87°Ä{}\9d!l¾ç´\94ÎÒÿ¬«8ô×2Ö¶\8dKߨôE\8aSØk\97×RÒ¸¿\ 4h~AõR_s®sÕ,R;¯âã¾0écÊåu}\ô2¨\90:5±Iw\b8õ®Hï¨\1f/±%\92ËÿB÷KÈùþ\92\9a´\9f\96\9eô-\9d÷\rÕçÒHå%£rÛ*GéòË[\83váô(ê\9b\a\99Ñ4½ê÷Óí\9fÿf5\82
+endstream
+endobj
+2190 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115428-07'00')
+/ModDate (D:20090924115428-07'00')
+/Title (idct.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+2191 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+2192 0 obj
+<<
+/BaseFont /XKVMYW#2BTimes-Roman
+/FontDescriptor 2194 0 R
+/Type /Font
+/FirstChar 45
+/LastChar 83
+/Widths [ 564 0 0 500 500 500 500 500 500 500 500 0 0 0 0 0 0 0 0 0 0 0 667 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 556]
+/Encoding 2195 0 R
+/Subtype /Type1
+>>
+endobj
+2193 0 obj
+4737
+endobj
+2194 0 obj
+<<
+/Type /FontDescriptor
+/FontName /XKVMYW#2BTimes-Roman
+/FontBBox [ 0 -14 633 688]
+/Flags 65568
+/Ascent 688
+/CapHeight 676
+/Descent -14
+/ItalicAngle 0
+/StemV 94
+/MissingWidth 500
+/CharSet (/C/S/five/four/minus/one/seven/six/three/two/zero)
+/FontFile3 2196 0 R
+>>
+endobj
+2195 0 obj
+<<
+/Type /Encoding
+/BaseEncoding /WinAnsiEncoding
+/Differences [ 45/minus]
+>>
+endobj
+2196 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 1309
+>>
+stream
+x\9ceRiPSW\14~/\8f¼<\15¨\12S@4yµµj)
+("E\1d\ 5´¢\91B\88K\9cÚ\18äe1      \89\ 4\ 2\84\ 4e©¢W\85\ 67Ö kÁ\ 5\11\84@+*\85ªu©\8aV¤¶È\8cZZ[k\9dNïË\~4éL§?úçÌÙÏw¾spÌ\8b\83á8î-Õè\19S\88Ä W¤yì`6\bggrØY\ 4°¹|\qÜY\98¸\9að\ 1Þ\ 4ðöª\9dÉ]â\a\9b§ÁÒ7`áT\8cÀñl{C¬Á\98\93®Q©3èy\e%\9bç\a\a¿ÿ\9f',**\8aNÉù7BÇ1&\8d*\8d~×­\98\19\9dÁ¨gÒ2¢éXw¶N§ÙA«t9Fµ\89V¤¦2©\9e²M
+\1d£¥×ht\1a£Ñ`¦çÅΧÃCCÃBÜ""A£OÉ4Ñÿ\0§\13\f\98\960ªL\9d"ýÿ\11\fæÄ&/Z\1c±$2$4,\1cÃÞÁ\16cÓ1\ 1ö&æ\8f\ 5`MØ4Ì\ fãcÞnF0/Ì\82\aáõø(GƹÆù\93à\12J¢Ý\8bÇ\16ûº\16ÚºÙ×\1dx3¤\b\17Æn\12\14@3×L~jÎÝ\9d\ 5
+\80õ°õ³­\95²²\8fA\14XªÛ ]½\81Y\0\10\a,h\89è\93\]÷\13ó\12@.xÙsí1\95S½*.^¿\14\ 4\8aA²c{»ôKÝ3\0  
\8fÃIpÎÀ%ó\8e\ eá)m\85¡f\1dåË^¶µe:XÔ©qøÝ\e\83¶Wþü\99l²k©ÀLîËسÇ\ 2ò\81¥ÄRFñO\97+\95eÚ í@nÙ\99¦Öå(Àf\10Ý\9d\f½\12\87\98K)\rÌ\91¼R30QkeÛbÂÅýÐW&Ì [\90\9a{\92ä\8bk\ e\1e\b:\ 6ªöÕ\14¹;YÛ;
+;\82 ïéÈë\1f¤7QÀ=ÑìAE7¸Bõ_h¿î¼\90­:+lÕ\96ïªL¤\1aH_¶ØÖÆ>¿ê\a\87F\98!\7fþ\1d\18\ 2\7f\14|\rêö×\17\Ï</\ 1k¨HɺUÆ,{½R¨¯¶Ø-\80Ê°ÚÌê®Ì»Ã#\8d\9d½¢ÞÎÆAp\eôåö¦µf\9dÌ>.¯¡øOîô6\9c»2ãñú¯\16Êä\16­J¨7Zwe~T±/ ó¾óô7\80ºé\94\8bUVUzºH¯7X?4¹\89*\ 6\ e\ 6»Üá\a\9d\8fV\fûóÇY\1dÌ\15Ìa\93ä$º=\91Ä]\ fÏ h\1eÿÕ0\8cþ\83Dko\bP\11     \8bà\v®g\87sìÀ\b\ e]w   \18Ï~/\80[ÈJPrè°½ýi@\81ÝjÎßk\ 6\81\88!\11\8eò\ fì\a\aÀþÀ½%Åe§:\8aò:\85\90§¼¼\ 1Ì£\82\13V.ϲØOê\85Úº\8c£f@¥Ùv§3½¦ïF\87\9aú.\8az\9cµ\ 3à!\18Êî\91]\94wKêÐäZ\ fj[3ëÕ\83\9f\19\87\bVâZ)@d~RvÌ\16\84­HD$@3Àâ¦E]²vù\15Óu@Á©c¿@!\9c\1eó\18ñäæ"F,j\82ÁÐ\vb0¬\91B)è¼`ìb,\9a\868©   «\17\19.ì+kvT\88j+[\8f\9c\ 5\9eq\85\ eöþ\ 3\9cÝèzO0A\92\89hnUa×·Õ'úA Ô\93hëÄ8÷&   Õ®ÙnR®Aã-\9cm\85FÁ­\89\83ñ<\ fÖF\97_#^ÿ\ 2\9exA@»û      ¥@aQª\93\92\19Ä\ 3h\12@øi4©7ù\9c¼Ï4\bú@WUÛÙÁþvH\ 1èCAE(|\vù\v\8bw  F\9d\88\8b\18ÄÈé\88\bù_0\15ª\9d\90\18\13yNXÁ^.¿çÀ¡f\8c\80Ýî\ 1hm(×Æ;^z¬¤äPµ½ªä( j\8fXµ¢      \19\ fì,ÌÈ-°\16Ø\8a\15\a(+ü¼\82·ì`îQð\ 5ÅþêÁ
+\1e²u\ fpø|\8c`\rp\96 ¯T)É+øÄ}ÅB\12.\83qOÇÏ?\ 4\8f\ 2\7fÿ`øméæÌ\1dJ¡VcÕZâj÷\ 6tüÖvê\ e F\a$\91Ë·-\88\f\17¡5(\89»\9b\9dÁóÍr°\9b\1cPê [&?\99ÒRæíý¤ÚÛ\aÃþ\ 6þÝk·
+endstream
+endobj
+2180 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [251.415 508.073 282.603 516.874]
+/Subtype /Link
+/A << /S /GoTo /D (cite.CSF77) >>
+>> endobj
+2182 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [408.69 236.8 423.412 247.648]
+/Subtype /Link
+/A << /S /GoTo /D (figure.7.1) >>
+>> endobj
+2183 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [342.829 175.526 362.533 190.013]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.65) >>
+>> endobj
+2187 0 obj <<
+/D [2185 0 R /FitH 686.127]
+>> endobj
+2188 0 obj <<
+/D [2185 0 R /FitH 668.127]
+>> endobj
+597 0 obj <<
+/D [2185 0 R /FitH 277.4]
+>> endobj
+2184 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F14 574 0 R /F11 573 0 R /F10 668 0 R /F7 674 0 R >>
+/XObject << /Im15 2181 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2200 0 obj <<
+/Length 1361      
+/Filter /FlateDecode
+>>
+stream
+xÚÕXMoã6\10½ûWè(£\15Ãï\8f\1e\16H³I\8b\ 2Ŷ±Q Èæ ÛJ¬"\96]IÞmþ}\87¤èX²²Q°\8e±{\12E\r\87|3oÞHÂÑ}\84£_F?OGgW:2ÈH*£é]D$FRªHj\89\bUÑt\11ÝÄ\84Ðñíô·³+ÅöM\rFÌ(ðã\8c.~=ÿczy=N\18c±BãD)\1d_]\9fÿ~é§Þ_^|x\7f\8cp³{{ë$8L¨\82IæÝÞeeV\8c©\8ekpcT|_\8eI\9c\8e\13\12o`°¬üì*µ&\8föFƳq\ 27\99¿YÏê4/ÒÙCæ-·U^ÀÂ{\7fW/\e³´ªÖnÙ<Oëü\93õ\96ý8N8¡ñ|½Z\8d)¬¬Ó\1a\87j÷0-\16ÞÁ"¯\12\v\ e\80%\84 #\84?\7f]æ³mð\b¦\82Ç\9br½ñG,ë\1c<f\16\8d\ 5"X¼¾ó6Û¢Jëm\99ÖÙÂO¤\16w^/WÎÚ­\9bÛ\11\ 4Z`\11O\97\8dóùúa»*ÚÎ\ü¶\ e\84\8d\r\9c¾¬ü\93uá¯6\ e=\87\7fÈî ì\1c³¸Ì6eV5\99¨ü\Zøk^äu\9e\9b\80låö\84\90åëÆÌ\9eÆ^]ÌýºÍ¶qÿþbê\as\9f\85ì#&r\9e\87ý\0¤\ 4<Ó°\12\ 6Û#\97ÆãR¸É/L\94ùý2°\bæ»pZ¶Û¢\ 3ÂåÀzÝÖpb\eq8Ì\87¢1\9f§ÍfO¼³¶\8ewaåÌÆþ±ïȳ¼NÊÌÓ£\ 4nZb2Þ\1c\ 6Ê\86%`á\873àqùèÇO\0\80ÄM\90í¼K9ca=d¸^\ 6\8a\95¨U}Ýëåtôï\88À\10G$¢P\8bÊ\90H\18\89\98âÑ|5º¹ÅÑ\ 2\1e\ 2\ 4x¤¢ÏÎt\15i\86¸\140|\88&£?\ f%\85\82\v%u$´@\1a\zµð\82\9e¡BÄ\88 '¹7hk\132l§7\93\1e\ f\ 2 ¶óðO\8f\a\85¸        Ïÿ\1akàðÃÖ1ÿ\19ô\1a\14\89\99.znôëÑK\r§oDí\82@>(ÆñD5\ 3É©R}ü¸ ÁT\ 6S,x¿)\v¦¢\19\bÎ\ré5åÁ4\f¸d¼ß48\9b\ 4÷Lr\82{MÃ\11'áÐT`Ý6\95\8di\0>   ¡\80n£Åó©\0 H`ú
+"âçz\1c\85\83`®#\80\8chè3SÇ\ 6ß&\\ 3\93â'\10\eÎc"C        òø|\ 3âmkõ¿|媮j\97Ý\ 4J¾ò¦¾3ÀÜźr³_ª½(a\1aQÌáJ\91\12M\91\90vÁF7 õ8>¯ªü¾)÷é\r¾í\bƧ±\90;Z\9f]\ 1ß÷ø\8f5\12\86\85
+øû°B\80¤\10\99æ¹sN)\8d\7fèñE)\92¯pÅo;`\12Â\r"\9aÚ¾\8f$@wv´\17²KN¹-æÐ\ f\ 1¥\96\ 18\8cêµ½*ûN`owÙ\82)\e'§À0ßRü \98Z\ 6evã\ 5\8d\97`¸K\8bðN\ 1®\96Ð?²Ò7\1d\ 2)bm:¯ËEV\ 6\95¶ýª\ 3µY±\a\94}]nÝ<T±×@¾\9fcH\8cÑ»Ä|Ä\98\1dæÆJ­\f&n£C1¥ tj\97Àwïzä\148+wz\vòÜ\85m5\8f\86\f7"Á\a\0'oL꾨Ù\f\f÷ldÜ[é\91        /\ 6\13\9e\84\97_\97÷ã\12\9e\9c\90ðj\0\ 2ð\8fX`è®}à%ÒB\1f\82o1·õfõ"si_p\bôJÍ_\13\1c83é;±Dðà°Ôt§Òè\93\89À\13ÙïÉ\ 6ù\98ÐåW@çmè]n\80\ 1dÊ´¹¡\ap\83\ràF\7f\0ðj@\80ä\11¸Á^Í\8dæÕÂ]\9e%8ç\88*ó}&¹Q>3 É|\88\0¨\13      \0ù\ 6\ 5@\9dF\0Ô[ràðÒª\7f\82\apC\fá\ 6ë\8b\ f#H³ã\16\8fø\ 6¹ÁNÃ\rv"nðð×u\0\90æÐÏ\r\8c\88ÒGm\ eâ-\9b\ 3;Ms`'\16\0: ÉjH\92Õ\89\92LÞ2Éê4I>µÊ¿ü±\7fýå\fû\17\84½hÙ®Ðq\8a;òÁ\8fÐZܾ}¼b\88\eó²N³§O.Ñó=l\7fØu¾\96Èð\ fb1ì\838üþ~\83ïb\85\14P¨õ\ fô\8b\1fÆ{¿Úÿ\aÂÐkä
+endstream
+endobj
+2199 0 obj <<
+/Type /Page
+/Contents 2200 0 R
+/Resources 2198 0 R
+/MediaBox [0 0 612 792]
+/Parent 2189 0 R
+>> endobj
+2201 0 obj <<
+/D [2199 0 R /FitH 686.127]
+>> endobj
+653 0 obj <<
+/D [2199 0 R /FitH 475.218]
+>> endobj
+2202 0 obj <<
+/D [2199 0 R /FitH 444.355]
+>> endobj
+2203 0 obj <<
+/D [2199 0 R /FitH 424.197]
+>> endobj
+2204 0 obj <<
+/D [2199 0 R /FitH 395.128]
+>> endobj
+2205 0 obj <<
+/D [2199 0 R /FitH 373.032]
+>> endobj
+2206 0 obj <<
+/D [2199 0 R /FitH 353.428]
+>> endobj
+2207 0 obj <<
+/D [2199 0 R /FitH 324.359]
+>> endobj
+2208 0 obj <<
+/D [2199 0 R /FitH 302.263]
+>> endobj
+2209 0 obj <<
+/D [2199 0 R /FitH 282.659]
+>> endobj
+2210 0 obj <<
+/D [2199 0 R /FitH 263.054]
+>> endobj
+2211 0 obj <<
+/D [2199 0 R /FitH 243.449]
+>> endobj
+2212 0 obj <<
+/D [2199 0 R /FitH 223.845]
+>> endobj
+2213 0 obj <<
+/D [2199 0 R /FitH 204.24]
+>> endobj
+2214 0 obj <<
+/D [2199 0 R /FitH 184.636]
+>> endobj
+2215 0 obj <<
+/D [2199 0 R /FitH 165.031]
+>> endobj
+2216 0 obj <<
+/D [2199 0 R /FitH 145.426]
+>> endobj
+2198 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F11 573 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2219 0 obj <<
+/Length 699       
+/Filter /FlateDecode
+>>
+stream
+xÚÝ\97M\8fÚ0\10\86ïü
+\1f\13UñÚ\1e\7f^VjÑnÕ\1ev%\9aJ\95(\a¶¤\80TÁ*°\95úïkÇ1\e\12 )\84\1eödÇ\99xfüxæ\ 5\82æ\88 \8f\83\ féàæ^\ 12ØH&Qú\13Q"±\96\ 6I-1e
+¥34\8e\1468N\94ÒÑènøøð%\1dÅLG_\87é§Ç\87x\92~¾¹×\95-\80i¬¤²\ e\8a\8f)\ 5g3 ¥Ï0¢\ 4\18ÅB1\940ë@Bi.ñ\9e9\1a'\82\90èýf³\9c¯â\ 4\0¢t,&nÆ£í"óK¿c!£é¯\97̯\ f¹\ f\8bòjj\85\e\11âúN\b4\83W\98\9a\9dIáÈoD+6\8c`®L0º½mîB5f¯\9e\1a)%T\ 16\84Û\89Á\92ÈÒLuÈ\9c·d>ªíAJ\1f%I\eX\9b\8f\81°\ eb\1a\ 5\1féXÙ(\18cÑ;?¤c99â7äf:ä&[r+ü\1eà
+\80«TI\93\87)î×\8ej#Ú\84rÀÜ\9aì\1d\96å|(è4Ö\10å/«\1fÓ­\v\10º\9dm×nTÑÔ?R\99<-·~Ée\9aÍüz\9e=çÙ&[¹2ÚN·ËõÊÛ<¹\85?Þf\96¯\9f\9f\97«¹\7f\9a®v¯T´XÎ\17Y\9e¸à\90½5\8aÚ\1a¢\14\e!|àë|\96åþ\b­ûMóö\95\9fT\0ÙR¼\1cPoe'ÿGÙ\ 5ʬCæê̲\v§\v½\94\1d©\97\1dLN\97\1dr\83Ö²#ý\94\1d´\94]8,Ñ!hrY\1f\17 ´\ e\84MNß\83.-\9eµò ýð¨\a\vê\ e\vëÃô\82CÖq\88\16Y\ 2ÒÃ\8f\8dJ»º\8c\87è&KÐG«n\ 1\ 2ì:\rKµ4,\80\ e\92Ë$sÞÝàôÖ\8dS7ÀNoÝRÐ[7?¤·nÝê­r¢êæ¯z[l\18ôÖ=\94zëeõ\98è¶*mHñdO.î\b7\95KÂí·\\87[ò­y\8b4\96\92\85÷ec\84À\85ï\83\87\ 6øDh\f´F_\§;Ê6úòíÒ\ fG«®J\9f^B?Pèç?\ 2ûçflÞ|ísrUúì\1cúÄìcàô\1cüû\82\buö¼Æ>\8cwéà/µÔâH
+endstream
+endobj
+2218 0 obj <<
+/Type /Page
+/Contents 2219 0 R
+/Resources 2217 0 R
+/MediaBox [0 0 612 792]
+/Parent 2189 0 R
+>> endobj
+2220 0 obj <<
+/D [2218 0 R /FitH 686.127]
+>> endobj
+2221 0 obj <<
+/D [2218 0 R /FitH 668.127]
+>> endobj
+2222 0 obj <<
+/D [2218 0 R /FitH 651.848]
+>> endobj
+2223 0 obj <<
+/D [2218 0 R /FitH 632.242]
+>> endobj
+2224 0 obj <<
+/D [2218 0 R /FitH 612.635]
+>> endobj
+2225 0 obj <<
+/D [2218 0 R /FitH 593.029]
+>> endobj
+2226 0 obj <<
+/D [2218 0 R /FitH 563.958]
+>> endobj
+2227 0 obj <<
+/D [2218 0 R /FitH 541.861]
+>> endobj
+2228 0 obj <<
+/D [2218 0 R /FitH 522.254]
+>> endobj
+2229 0 obj <<
+/D [2218 0 R /FitH 502.648]
+>> endobj
+2230 0 obj <<
+/D [2218 0 R /FitH 483.041]
+>> endobj
+2231 0 obj <<
+/D [2218 0 R /FitH 463.435]
+>> endobj
+2232 0 obj <<
+/D [2218 0 R /FitH 443.828]
+>> endobj
+2233 0 obj <<
+/D [2218 0 R /FitH 424.222]
+>> endobj
+2234 0 obj <<
+/D [2218 0 R /FitH 404.615]
+>> endobj
+2235 0 obj <<
+/D [2218 0 R /FitH 385.009]
+>> endobj
+2236 0 obj <<
+/D [2218 0 R /FitH 365.402]
+>> endobj
+2237 0 obj <<
+/D [2218 0 R /FitH 345.796]
+>> endobj
+2238 0 obj <<
+/D [2218 0 R /FitH 326.189]
+>> endobj
+2239 0 obj <<
+/D [2218 0 R /FitH 297.118]
+>> endobj
+2240 0 obj <<
+/D [2218 0 R /FitH 275.021]
+>> endobj
+2241 0 obj <<
+/D [2218 0 R /FitH 255.415]
+>> endobj
+2242 0 obj <<
+/D [2218 0 R /FitH 226.344]
+>> endobj
+2243 0 obj <<
+/D [2218 0 R /FitH 204.247]
+>> endobj
+2244 0 obj <<
+/D [2218 0 R /FitH 184.64]
+>> endobj
+2245 0 obj <<
+/D [2218 0 R /FitH 155.569]
+>> endobj
+2246 0 obj <<
+/D [2218 0 R /FitH 133.472]
+>> endobj
+2217 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F14 574 0 R /F11 573 0 R /F49 457 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2252 0 obj <<
+/Length 865       
+/Filter /FlateDecode
+>>
+stream
+xÚå\97MSÛ0\10\86ïù\15\a\v}Kî¥\93\92ÐÒ\99\96\12|h'p0\89\b\9e\ 1'ØN;í¯ïJr2ù \f\1dÂ\89KdI«Õjßg\1d\99¢\19¢ècïCÞ;:±(#\99æ\1aå7\88iJ´6H[M\187(\9f¢1fL&Wùç£\13#6M3JDfÀO0:þÔÿ\96\ fGI*\84À\86$©1\16\9f\8cú_\86qh0<>\e\f½\9f\1eív_µÛ!¤Ì
+Â)C)70(¢{ÉÉÖZ4N\15¥8O¬Àõ²\9a\14­KR®9\1eŦ\9dǶð\8dÀL§×eÂp\e»M9«Ü4ZÔnQ»ÆU    ·¸-Úr^Åñk?ð;ÚOëùbQVà`\16\a\8aj=Ëñm9»uu:¯§®öA"f\88ap\0ÆH¦T<ÀuÙ6;GH×vpzÞÙIñèAû\8d\8f9Ê ³\8d\8ch¹Vá{´Ø̧\ 5Aùj~,®¢\1cí­ó\ f\12ÿL\94ÆÅÝÒÅñÑn\8cÊ\12\9d\18åS1F?Ñ{·\8dØÞFâÜ\a\12Ber\93).\0»u´\97\94Òý\ 3\85§\95I>\96W{i\15\82P+»\98u\17³z+\0éW\ 5H\1e\ 4 ór\80ø¡\0\ 4Ⱦ\15\80²W\ 5H\1d\ 2 E_\ e\10;\14@úy\0)öF\0RüU\ 1Ò\a\ 1\1c z(\80Ì3\ 1\92o\ 5 õª\0\99g\ 1´³Gª\15Q\14\14á\8aجS$\ f\1e ý|à[\89O«Dpð\a?®nºÉÁq\1eRBýÝ\96\b\9bÅŧÕbÙF\8bEQ\17÷®\85%ïÂÁ\87yï¡Ç`\ 1El}'ç\86\12£5\9aÜ÷ÆW\14Ma\12|\12\ 3wð_Áô\1e  ¸=úlRt\87.zç\8fÝï5¤J!\ e>¹íîÖ_aoP\91\1a\ 5,yI\17гØ\8f\19&ñEùÇ\85ø3\90RïHzI\15õ²BË\82\91°ÄÂ^\9b6\17\81´÷à.\93\12\ f\3IR\86kÏâ"²æE(ªiL?\90ØÖåÄÏ4Od\ 3¾\b\8cÙË\86ÌìÓÙØ\125:³\88\vF\84a1ÜÁùñ>Aà\8a1½Bè4V\8a\9bu°Ó.)\1d\16ýº.bmøIÃ\88\11\fm\1aÀ\a\19XüH\0\1a×t½~\92jH¸\96©»s÷]9Ʊbí2tç7±\9dº\87e¬Ã\16T\9a\86ý´!BÙí\88<\82©\80\ 5!õþ½`°»¤LOJ¿\8dÁm\13çK¯\ 6SØ×yÑ.ëâ.öca\a\13/ùä\86l\1d|¥´\v²\ 5Õ¢`õ\fÅ\87Q(c¯/'z§º½ËîÏñq­)¤PeÿMþ#Z\ex1)"u\17ðÙ²ýg\11î~¦Bh\7f\ 1¾\ 2¢m
+endstream
+endobj
+2251 0 obj <<
+/Type /Page
+/Contents 2252 0 R
+/Resources 2250 0 R
+/MediaBox [0 0 612 792]
+/Parent 2189 0 R
+/Annots [ 2249 0 R ]
+>> endobj
+2249 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [376.746 202.877 391.469 215.929]
+/Subtype /Link
+/A << /S /GoTo /D (section.2.6) >>
+>> endobj
+2253 0 obj <<
+/D [2251 0 R /FitH 686.127]
+>> endobj
+2254 0 obj <<
+/D [2251 0 R /FitH 668.127]
+>> endobj
+2255 0 obj <<
+/D [2251 0 R /FitH 642.224]
+>> endobj
+2256 0 obj <<
+/D [2251 0 R /FitH 619.808]
+>> endobj
+2257 0 obj <<
+/D [2251 0 R /FitH 599.883]
+>> endobj
+2258 0 obj <<
+/D [2251 0 R /FitH 570.493]
+>> endobj
+2259 0 obj <<
+/D [2251 0 R /FitH 548.077]
+>> endobj
+2260 0 obj <<
+/D [2251 0 R /FitH 528.152]
+>> endobj
+2261 0 obj <<
+/D [2251 0 R /FitH 498.762]
+>> endobj
+2262 0 obj <<
+/D [2251 0 R /FitH 476.346]
+>> endobj
+2263 0 obj <<
+/D [2251 0 R /FitH 456.421]
+>> endobj
+2264 0 obj <<
+/D [2251 0 R /FitH 427.031]
+>> endobj
+2265 0 obj <<
+/D [2251 0 R /FitH 404.615]
+>> endobj
+2266 0 obj <<
+/D [2251 0 R /FitH 384.69]
+>> endobj
+2267 0 obj <<
+/D [2251 0 R /FitH 355.3]
+>> endobj
+1943 0 obj <<
+/D [2251 0 R /FitH 307.03]
+>> endobj
+2268 0 obj <<
+/D [2251 0 R /FitH 307.03]
+>> endobj
+2269 0 obj <<
+/D [2251 0 R /FitH 271.164]
+>> endobj
+2270 0 obj <<
+/D [2251 0 R /FitH 187.42]
+>> endobj
+2250 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2275 0 obj <<
+/Length 1684      
+/Filter /FlateDecode
+>>
+stream
+xÚíYÍsÓ8\14¿÷¯ðÑ\99%B\92õe\ eì°-ìÀ¡\fmv\a¦ppcÑz6±\8bí´°\7fý¾'É\89\9d¸¥¥-{ádùéùé}ÿ\9e\12\1a\9dE4úsï\8fÙÞÓW:\89R\92*®¢Ùç\88QE\8cJ#e\14a\G³<:\895IÉdªµ\89\8f^î¿=<\9e\1d\89ÿÚ\9f½~{8ù4{óô\95é\89H¸!Zi8À}Ì\98D\9e=\1aÎ|9Ûû²Ç`I#¶9Ni¢y\1aÍ\97{'\9fh\94Ãæ\9b\88\12\9dêèʱ.£D$D3üp\11\1dï½óº÷Ïe\8c\13#t¤¤&\(\7fúa¶´\93)\97ZÆ3TúÛ\ 5¼\99\18h    g">.þµ¨\1d(ÂHÊ\93hÊà)¥ÿø#\95ô´h\ex2Ç\95\18bÀ)}\9eã⬴ùï U\b\11\1fØf^\17\17mQ\95pB"â¬Ìq\91ĵmÚº\98ãNãü1î\87$%:Ùñ\83HÍÍ~\10éX\f!\10p´×óèåñn¨@\14\8b\14?\98L\15\ 4ùu\89\9e\99­\9dÕtè\95\17u\9d9WºMÃ\88JÅÀ%L\817\18p|\98\18\81®fqã(:~\ 1\89\8e\8d×\85\89\9e2©&\10¦N\99\8f\94ò]\85!ÄJt,\ 6e©8súhÐǽÎ+¯~V\94Eyæ\8fkÏ}\94§\ 2RDª¡=¹\9dW.)r\v±\82\b\8a|\95-ðÍÄ\9f«Ú\93Q\8a[ÌWumý)c\ e:]xysäø\87\\1fm\99B¥p~ç¬\1f\8d¶Ô\9c\b
+\7fORtL\91\9d.,ø>\81\1a\9b?»A\17\17\1e¦\ 2\89J\86\15Hw+\90ë~\ 5¦àAÅnS\80ê\9a\ 2LC\ 1bÂÕ\13\16ߣ\ e%§Ðþî^\87\9a\8eE\86b\98\85Ww^|¯\fûå7\15Jð8\ 1ã¸Tñaå\16àHÌD´ÆÙZ-ÀØÕ2XZ\94¹ýJü!\ 3u¦á\18ïá\10\9dúAÕ©+,Ä+ÿ²Qdëè\10¸\ fÀ&GÚÍ\18ï°çh\ 6M\92Ý¥ç\0\0Äfj\17vÙÕ­#ek±S4¨úìÉìÀ¿\17\aû3O)Ê\8b\95¯u\0ªD¦Cí.'À\9c-V¶  æ2à    §[6¼ÿ\89ö&"õöâÆÆf$÷lÆW´\19\9fh3>½ÍngÕN¯5\19Ýá¢\f¶Ë\9eíãå$ÀF\ e\8dá^Í\853bX\12      \96\10AS¯Æì¼pí-\89/êÐtm¾ª­§e\17\17\8bÂ\ 6\ 6×½qá,5\98\9fè\86KÌX[7aÓ[\8fìuV6Ðú\97á#\15ÈÅr-°
+§øÇ°ë\87<\10\ 4\9aÒ°â\\92¥\1aÐæË*ó\81\81\16\98{b@"û\9125/BÜ\9agPx eUέgs\90\84\v\9b¹ãÎý['Ú\99\8a\vã\1fX\96&¾j\9e\80¦4ôBÇ\7f\8d@½+\10:\8c\1dÃ:\83¹BAï\ 54 Æ¿¸\94êð\12 ÐsW\8b\96¸ö\ 1\räö<k»\95íä ,ÄU\9d\17eÖñ5ß\9aÖ.ý\1aQ̯\9cÊ\9b\8f\11\96\83\12#jº,\81"õ¼\90±\8dC%$ÕÅÙ¹sóô\1c\1cã¤Ã~\bDO\11`]+\ 2\fA\11 \9evÕÔ\97\8f0ãIÎ\e¾IVu\ 6N\90\8cÁ\vzy\ 5\11\19\vaºëî+pþ\12\97¥';cð\89\rÖiÁ`J©«¥'\9fzÍÛ¶#¸D\ 5\96¶ºxâæ^\10\ 4rÛ5uÈÖû\1eC\ 6\8e\9du
+AZ\8a\12ç"äÛt½1#²:`B^\\16Þ­\0Nk_ÁFS|m­-\9ftб*s7°!ßU\ 1)çè­/à\8eÃ\ 6\18o\ 3Ò\80¸¬Î\ 3\87\9f,ª¦-.'aÈw\80\bÖ:Í\8bÖÏ\89Ð1ÉàN\82s%Ó:\82\ 6J¤èZì\16ÏÉTR\1a¿\9a@­»Ô\83\ 3\87\a­\1dâ7!ð» \9cÂ\A×Ø:\86¾àD\99&\1dG\b+\88£þ\10\17%xÕÏ\86ÚM\8d\80[\17^`à\ 6¡Õf~ʺáé¡-\91\84\1aÓé9\1f·$Õâ\a,a\84'\b\88\12\10\82\85\ 2\1e\rÆ\8b¦\81éÏ\8bùp2¢¤\84ûBÊnRÒ\10%×Þþ\14\92ëÜnûÁ}7\98»a^NÍúË\83wû»²¹$J­]4¦\1fïß\94»l\18Ü\8a\18L\9d¦\7f+JvÏÑ\84¥²w+â\9cÇ¿\8d\9cÆ\80Q\9aÛ{cËç0ÄÃ~ÂCdz#úu)¶_-aP\b\18ó>ÀÏ\1a\9dÜ\98\95j\aÄ:ö%ë\80\18\89~ôêa\10\8e\8b`תqMb\0sÛØïá\15oâ¾\97AÓpw|C¸\92C4.Bö\1c[w%pFøé¥>\8büâÈ\99\83é\80¿\83$[vnw\92ipò {ÑIóǪCAd"\1e½\ eoQ\86#5\ 2WRÉ»\93G\7f\82à¼\9fß·®\91aÒÂMr\9d´£m\0\$\1f \v8úûÑ\13RÂyr\9fÒ¢ÄPæÛ7åá\a\99ÇG \aÍ\17I\98\9bvÿ\17\ 4º\16\ fX\ 2Á\90âö\99\7f[\0ú~öþ0\0Ý£¸ÌO-®\9d~    \83\vÝ\86û_¨r\13ªülPy´Òb¿P¥\v\ 3Fs\14YTBhªïÒAüøç\1e¦Ë\ f\98*YßzEäÆüçÏGâëÓ:p\88a\84zÿåü\a<qD\96
+endstream
+endobj
+2274 0 obj <<
+/Type /Page
+/Contents 2275 0 R
+/Resources 2273 0 R
+/MediaBox [0 0 612 792]
+/Parent 2189 0 R
+/Annots [ 2271 0 R 2272 0 R ]
+>> endobj
+2271 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [199.19 267.779 221.661 276.579]
+/Subtype /Link
+/A << /S /GoTo /D (section*.111) >>
+>> endobj
+2272 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [199.19 153.183 221.661 161.984]
+/Subtype /Link
+/A << /S /GoTo /D (section*.111) >>
+>> endobj
+2276 0 obj <<
+/D [2274 0 R /FitH 686.127]
+>> endobj
+2277 0 obj <<
+/D [2274 0 R /FitH 668.127]
+>> endobj
+2278 0 obj <<
+/D [2274 0 R /FitH 584.383]
+>> endobj
+2279 0 obj <<
+/D [2274 0 R /FitH 548.517]
+>> endobj
+2280 0 obj <<
+/D [2274 0 R /FitH 346.017]
+>> endobj
+2281 0 obj <<
+/D [2274 0 R /FitH 326.185]
+>> endobj
+2282 0 obj <<
+/D [2274 0 R /FitH 305.986]
+>> endobj
+2283 0 obj <<
+/D [2274 0 R /FitH 292.113]
+>> endobj
+2284 0 obj <<
+/D [2274 0 R /FitH 266.858]
+>> endobj
+2285 0 obj <<
+/D [2274 0 R /FitH 246.658]
+>> endobj
+2286 0 obj <<
+/D [2274 0 R /FitH 230.867]
+>> endobj
+2287 0 obj <<
+/D [2274 0 R /FitH 211.59]
+>> endobj
+2288 0 obj <<
+/D [2274 0 R /FitH 191.39]
+>> endobj
+2289 0 obj <<
+/D [2274 0 R /FitH 177.517]
+>> endobj
+2290 0 obj <<
+/D [2274 0 R /FitH 152.262]
+>> endobj
+2291 0 obj <<
+/D [2274 0 R /FitH 132.062]
+>> endobj
+2273 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2296 0 obj <<
+/Length 1882      
+/Filter /FlateDecode
+>>
+stream
+xÚÕXM\8fÛ6\10½ï¯Ð­2\10+¢H\91R/Eº\1fm\8a6I\13£h\91öÀµ¸6QYr)y\83ô×w\86CÚÒÆY èöÐ\8bE\rG3äÌ\9b7¤ód\93äÉw\17ß®.\9eßTI\9dÕ²\90Éê.a2ϤT\89¬dÆ
+\95¬\9aä}Ê\98\ü±úáù\8dâSÕ:Ïx­À\8eWºüþÅ\9bÕõÛÅ\92s\9eªl±TªJoÞ¾øé\9aDW×\97¯¯®ÑÎE\1e¼?¿\11õÄà2Z\\16
+\84\9c쮶\ 6\fT<eWø\14éÍ¢\96iï>,x\91j×ÐäÕå\8af\7fÏËüUß-_õn§G{\8fZ\ 6\84\f=\83×%«2^Õdûe·?\8cd`¯\9dÞ\99Ѹák¿ÆëÕÅ_\17\f\13v\8a
++3!e²Þ]¼ÿ#O\1a\98\ 4\9b\99\825\7fðª»\84\v\9e)\86\1f¶É»\8b\9fÏEXfR\94\89ÌEVWa\93¯À÷bYäªLW\8b¢J?îá­JQ¦\98HßÙ¿\8d_\7fÍÀ\ e\83MÀ³,é[Üñ­\1d\87ã&y\95UàkªóÎn:Ó|\ 3æj!Ò+3¬\17K\96:»`é~´}\87)\12©î\1aÊ\953Ãèì\1ag\86ÏG£¬T&\94z\18\rQW\8fGc\96t2V%¥\92\18-÷W\82Û4l`\b`\18Áö²Ã(\8dfcÜ1¯\93í¾pNû0úIÅ2ÅÙ,\1eL@(\18hü¶\0Ì\98!¼½\b\81¨\96¦5;CN($úhÒkôw$¶\ 1A0¼_\94eªÛ\83\19²GbVV\99\17#èLÌÀ\18/ HCÌ^\1fÆ/\ 3s\99«¬bÅ\93\80YÔ*ãEý?\ 6³P58*\9e\ 6ÌBb\96%-÷·ÿ\1cÌò³`.¥$0c\84N\80\ 4Ðø\8a\80Ƨ'R\1c¬{ÊÚï9\93KïZB\8eËj¾¸µ\rF\1f\ 3½(\ 1Vòi0/
+á)Ø{ÿ\ 5[\81vV߶¸mäÿÃ`\9aG@/ò<c¥z\12ÐC\eɤ\12ÿcÐs\ 5\ 4\ 2xýRÐWg0Ï%&¹\bM\eV!sù    ´\ 3ð\9f\fß\12\9e\ fÈ\1aE\13lã뺧Im;ÛmH6nÍçA}pnBþ\ 2©]zj§à\12ùÃRô\1a\95¶$\1d Cº¥qk;ã\v\ 2Ï\eEVäåÜ\ 3\1e\93ʺ\98Åg)\98(âf\15n\96O6KvG³#\õN»\8f\ fúÎ#\15È9\ 3س\7f\a{Uf\12\14\8a\1a\98\92M\ eg\85,Ó;<\90ùÈ7$\18\9dî\ 6\90îè\15Ë\12G\ 2:fP\88\9f\9a.PM\83A@\89\1dHµëG\12ì\0×z4ÁômH-Y!å2\1dFT\ 2÷\14u8\        1\ fº\ 6MQsò,j¿\14°t\8f?Ð*\rÍö]\9c\ 5J[Ö\85Hß8³¶qÚüu°!â°ð Ä=M,ó\93e5±<           ¾ê6¸â¸á3į[@\93à\fÌê\11G\85\8f\fJ\1c.Ãa@P:ö$Ý\1c ï\aD\99\ 5\82\88_Ãò\9c!U2T@\88é}g\a8.G8{W]t\1eLíÁ\1fÒ\8d'\1eO9gÖÜR*{@©\10\fRµÄ\10\8c\18\b\8f\ fc:\9a\99g]\88\9c¸\v§h\v\1féeÝïö­Õ±\1a\98ù§°\eÐ9R\80ƵáýCªôû\1eEä9dãÙÙPc\1e\8a9\8aEÍæ)\vá¯1\14Þî½m|
+@\82aöMÖÑ\0e:h\aã\81\85\bn\9d\8dèñ^ÉÛi\e
+\ 2\8cL\85R}6ÐÓøe\9e\18}-\b\9eÆ'Õ\98àG\8cûF\81\ 2¤°\99Æ´^\81\86\ e\83ßMCo·¸¢\8f4þÕî·Yï6_\ 5\1f@\ 1@F4\9e.j\1eçа?lmÄXQ\87B¯#\17@/\1f¨\8b\82H\1f§\10½8
+\14RO\b\0Æ¿¼á\19áóGûç"tÜ\93ÉÒ\97¢\9a\169
\94ó,L\8fó¥ÀqG¸!\bõ\1e°g\9asñÇ\9aCöõ=@Å\1e@¸øð,vã\85\ f!\8ea=]¸I\ 4£Dèý¹V²îÛî\9bß4ü\86Bk?´#u\97#ÍA\1fÏËé\85\19*÷Ô\90
+ÜV     \8bé©\10ýôÆéý\96\86\1e\81<\16;ê£\84aá¨pÇæ³bà\81\1dK\95Õ\ 5qxÞØÍÁù\1e\eº\91Û$4xûÝEòÞ먬\98ý!\0«ÇdÂ\ 1çåxtò)\9f\a0µÚmL\8b]0ôs?pf\92k\14ø\0bEE\r\8c\ 5ÿ\1e\ 3\81C\eÊ\93^).Óo?!v\9c½ºÄZYeôæ\97\8eªCx\1e\18iìsx*9ö<´Z\16\ 1ù(#ï \1aÐ\ fd\15R3Ð\94?øMU\80e\ 6ï\a\16=\90È>Ôq=\91d°±Õ'^"     aQw\eÓ \94Ë*\1c,ýªÌ¹å_â\85\1a:Ù°Ö­¡á\9d^\8f½\eèÅóNì®\ 5\90\9e' Ø2qÐFªÆÈ\92Îía\84;,¦Ë\9a\8b\89Ã\17¨$:dk7÷r4Ú{\r\95ö\83\1d\83h\0ÒÎÎm!üÑÄNÕ\ac\ f\1exúÄ\1dvø{K>Ý\104\82æ\18?oÍÝH#g g\ eñ\82ô@íÐ\85Å;oõà\8f78áÿRÀ°ã\ e#\83\84/Ï,ûÄ\15\ 1\rD6\81+ìf;ù\13#ÈEzÎ5~\1fÿCàñ\1f5Ðõ\94®¨»áeðÁ\95oÎA¡4ñ¸Z*ì\93Ñ\13   \1a{o©    á[l+8.Â?\8c\89ÌjÅ+<pÂ9\93çpv\85Sçé&ðÉ]\9a\15Ér¢â«\ e=y¤yèÞA\fÇÐ\9cý\(\ 4\95ÒöÛÑ\ 2#¯O%¡ \aÃhtC\ 6<\ 6@¨é1líÝ\18\90YQ>¸Íùrc1Ó\f¸\14\89×M¸\94M¸Ô7/\15z7άuøþ6^ Ñ\ 6\1e¼v¸\85ý\ 2\116½Î\9b`\12N\84¾nÿô\94è\r\84ðÂX7\8d?PøqpÐC6ù`Æ\19\ 5Ç'\#þ\ 1­3\89G
+endstream
+endobj
+2295 0 obj <<
+/Type /Page
+/Contents 2296 0 R
+/Resources 2294 0 R
+/MediaBox [0 0 612 792]
+/Parent 2189 0 R
+/Annots [ 2293 0 R ]
+>> endobj
+2293 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [465.995 201.085 480.717 211.933]
+/Subtype /Link
+/A << /S /GoTo /D (figure.7.2) >>
+>> endobj
+2297 0 obj <<
+/D [2295 0 R /FitH 686.127]
+>> endobj
+2298 0 obj <<
+/D [2295 0 R /FitH 649.24]
+>> endobj
+2299 0 obj <<
+/D [2295 0 R /FitH 649.24]
+>> endobj
+2300 0 obj <<
+/D [2295 0 R /FitH 615.865]
+>> endobj
+2301 0 obj <<
+/D [2295 0 R /FitH 544.076]
+>> endobj
+2302 0 obj <<
+/D [2295 0 R /FitH 508.21]
+>> endobj
+2303 0 obj <<
+/D [2295 0 R /FitH 436.421]
+>> endobj
+2304 0 obj <<
+/D [2295 0 R /FitH 400.556]
+>> endobj
+2294 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F7 674 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2307 0 obj <<
+/Length 979       
+/Filter /FlateDecode
+>>
+stream
+xÚ½WMoÛ8\10½ûWho2vÅpø)õÖMê¢{h±©
+,\90æ Ø²-¬"¥\92Ü´ÿ¾Ã\ f¹\92ã \ 2\12'\ 1Lz4\1cÎ{o8¢i°   hð~öw:;[h\1e$$QL\ 5é:\0ªH¬\92\8a\0ÓAº
+®BM\122\8f´\8eÃËwç\9f>~N/ç,\ e¿\9c§\1f>}\9c_§ÿ\9c-âA\bÎb¢\95Æ\rìb\0m|fÔïùØø.\9d\ 1Nh\0û$DL H\15,ogßf\94(\r\9c[\97áÜ>ìWzÃÙ\87[PÁE=û\17ÿû\rz\9f¨\ f\1f\râ[&\86(@J"\ 5\ 4\84iå°,\8aÍ®Éç\11ç\1cIaoæ\91\102ü\lª¬tÖEY\enîÝ·÷Mv·5S\11®ëÆÙº­\ f\0\17îÉb\1e\8b°nîͺ¬Y9ãÅyz\945\934\82gAÄ\19\ 1H\^õÚÉ Å\10\ 1\10¥X/\ 3ý±À¿#jIB1\8c÷*Ö¸½\92>I\9cT&«Ý­ù¼\99\997îAÑz\87|\93uÅwã\90ÿ\85&ÍìZí£TnÖn\8buWT\e÷-ók}D¤&Çú\92\82\86é¶\8fÛ\96Åfk¢våO\935\ 2WDÅF> \89\94>ßjÙäY\9b·F        áÒ6\93e}{·ë0±Ú*Ó\9bÊüGÑ\99 ?\9d\ry\e¯ë\9a¬j1\9f[[ï*üR\95Åÿ\16Û\81ca\89\eÜ\1dÐÃdI}~¾`PFCJ¢B0>*º\99C\88) I\87M¾)ÚÎ.7\1e\8e6´g~\85rjÁHT\9e\10\87ë+¥ì¡¦@   \8f÷Ê?\12\87àyî]þ8\12cäÀ\99Ëé¦ÏÝVÄ®ì\8a;\94Ç¥o\ f\ 6>jw_)¨e\91[\8a¼\7fW{/O\9b\ eë\ 2©X9iAkÔV\8eµÍ*¯\14§4¬Í\12O7\86\97î\94\19n)îX;§²¶\15\863[a\14|\1d£¡¨°\1eü´íMnô>\10¢ö\9bü\bW\f\18\91¿Ï\brN\1fò¥Q\96=]\8a\ 20
+Dd¬z'ì\1e ´\e\14\ eÇ$`1\1fÆôxï·ÅÒàß\ e\ 1AXfÍ\ 6\8f§e\94\ 2®Æ\8cvÛ¬r½§É¿í\8a&_\91Q\93     \10(J\81«\110õ%\f\a>W\91Ä=߶-v=\17,½¢×®kí{Û÷¹D­Ë\9d§S$£ê\8c\89Lö¸þ{\b<\1e6.\e\9c1\16þy$\16\1269\94¾>\0\13\81\14ß\ 5\8c¢ÆÜù±    \90á\94\90áå «' \v\7fÀ'@f§\84Ì^\ e²\9c¦²\98\0\99\9f\122\7f9Èb\9aÊr\ 2dqbÈGÞE\8chþ°»\8e6²³\17£ÃW\80\9a@\87<qÑ¿\ 6\1drZuè       t¨\13·½× CM«\8ex\ 2\1dúÄ/¾× CO«\8eäI:.\1fåÂÚÓÁ\9bÜ\ e¦½\1en-HbîøC\1dð6û¬Fý{óc×`NDòÄÕÎÌö\94\1fK\1a\ 4FAFG|Á3/NÖ~y\10\83\1e\9e/
+\1c\8aÂ\ eð\r~ ÿ\ 2ÜîÇñ
+endstream
+endobj
+2306 0 obj <<
+/Type /Page
+/Contents 2307 0 R
+/Resources 2305 0 R
+/MediaBox [0 0 612 792]
+/Parent 2321 0 R
+>> endobj
+2292 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./fdct.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 2322 0 R
+/BBox [0 0 512 280]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 2323 0 R
+>>/Font << /R8 2324 0 R>>
+>>
+/Length 2325 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9cÕ]Í®\1c¹­Þ÷Sô.\93\0>)ýKÛ\ 4A6ÙÌ\1c\ 3y\0\a\19ãb|\81I\16\88üH\8a:§:\80ÏlªaÀf\89?úD\95$\8a\7f½\1f/á~Ð\1fù÷Ë·Û\1f\7f\9fÿ}ûõvÜc?\8eû·\e1~¹\95\10\1dÁ¬_n_o¹\87ò\92ï±æ8Eó8*è_\94n\9dh\95:}ê\8d\9fêáylãëíï\7f¸ÿÿ-¿\94û\7f\18Çqÿ鯷\18\1aÄg\85}4U}½ý8e~~\véÜü\ e\84+ûç\1fÞVôQK_'\96ït`(Õ\1cÈô/J\ fgÿÁ\13ã
\1f\9eW\9d\ 3ÉcÌ\17\8f\89,yìMýç¶öZ«zë\83ª\1fqO<\96{\88V÷Ääí\9f?\ 1W\8c\1e\17lx÷\10\ 3\1e©ÿÜÖ^ëñÆ=ß«ú!÷8ï¸wgóýÉ\ 3 å\rÑ[¿äå\96üÎ+¾e\9b\99­¶øÖ#ß¡ö\ 1oÄØ×dD´NF)ø±zþ\841\9e\ e?ÆaÃ9\85ù:û@Ö¹Eë?µµ×
+ËË5ß­ú\ 1÷ô5U÷5Sw?\8f\9d>0¤î'¿\9eßø¥¯I¹×7^é~\12ÝÍlµåÝ#ߥö\91¡3ÜØ\19\8cí]<\7fÂ\e<¶Wx¼\e\r¡ñn\f\8dm4¼±µ×úv\1c}¯ê\aÜ\93×PÊk$\15ÿ&\9e>0¤â_ßüv\10\955\86ÊÛ!\94ý0ØÌlµå7Ãç»ÔÈ\e\f×\8a\v$Ò°\b\83Êuâc\19\fý\10f\vr)V^V±Í\bü\841\11rs½\8f',È¡'·â°\8a¼1,¥ã\b*X¤ ¢kx\fCk\89¥,gr9`q¹Zâri\1d3vK\ 2\8b\10È\ 1V\1c¾\8d\90\83S\98c\8dL±iý©¦åE.\a^\94\99!Md\8e"\ 6#[¹¶\90Ë¥nf¬\ edN]\95\18\1aË\98µ\1e\1c´\1e\1c\18+@Hî\85\0#¯rm
+?É\vÞÂj \97Ë,ÙÂjI¸Ó\9f\7fý|ë3\ 4\80A¦æë\1ar¿·\1e^z\89÷Qîô®Í\7f¾ÜZ\8aÌ£²àD\ 3\fL\ 1¢jfE\15\ e\1d\16èß)!fé\89«\13i\ 5ñ\85\86ÖÅ\10ѨmÑFm×Î\98\8a18C°¡ÜTø¤ø\95\9b\rÈ4ÛP¬µ±\ 6 ebµ\18åÁ)\ 4±\83FÇÚ©\1dÖèØ\ e±CÄj6?¢b(\18\1eë\8a\8b¢ÓnÑY³Û`\94\8e\90ù´¦5ý\ e×9ï\194;Î\r\84ÍÀDÇÆ-
+!\13Æù\è\81&(¢¾ÜÂ1"        \80q4§Â\ fd\8b¤\98\8eÜ*SIYm\115¥´\120ªS1\ÜOÏ\0\93:,\1cÝ-hÙfIjÂ\ 3\96¬P\13\9d\92*=`M¥>\97\[½\88\9e\ 1
+7¯×\0h\8d\1ehÖ%j¶¢\87\b\97\11£\r§Â\ fdkJ\81Îh\9eªÄª¶\88"[R  \18Ý«t³E\rx\ 2\98ÜqýpÁ@µ\85\87\9bpÎz\95¨!\f\17t\14S:giÇi¤ÂtÙ=R\92\82\11fpÃU\ 5\ f}y¤\1e»GjT[D9\8f\80ѽJ7[Öq×\86¹:NqV\8b>¬ãÞ³´ãJY½SÃÖqïYS©Ì\90_bO&\13VãP\ eÆÚ©!\1c`òZ\11rᶡ89y~à9\1e\8a¬
\10;\83×
+5ÏÅ\¯Ê+\1eô×uÑq7ål\81{94|#ܧ\f\89Î{ZQû0\853\86t\8fÆù \ 3Þ>\81\18ú\10èL-\1f\b#9\15<dóB\18\15o\9fª\8c®¶F÷~\0\ 3Õ\8b\8aáZýtq\98Öa\86ó°Ø]»ì\84¥[ª\11Üþ¬ùn;aI\bRÖÒ\9e\9b¼\89²êf]Ùó¶°g]×M\9e\1eÊZÖK\947Q\14\8a®êe[Ô\8b®é&¯xVäqMt\16p\94\15T\94-ÜxÇ\90`#¯\80¢l¡Æ;ÆTHyî-PÎd\96\ 6¥È\b\eÍÐqîÚ\1afîظ=(.N\9e\1f\1a;\80É!\r\12\ 5\9e\89È\8eLPb\9e\8b¹^\95W<è\9e뢣îÁÁÇÜ\85þ:;\84iùçË·û\9f>ßþø\13½\18/ýþù\9f7\9c\17\ 5\8aU^jÉ\13Ùýó·Û\ f\9f~ÿùÿn\7fù|ûqíhÇ\\ 13\ f$¢RG\v\9e"ÍPgÌu+q\ 44\ 2v ôÔÇ\92&\9al|¹1\95\80^¥éí%\ex§Õ2\97v'ÝÕÆì\88ë\81ú ÿÇAîO\13Ô#ÿ×H#p¶\94\88ÈÐó½\1eÀ3\87,%ifý¥\0÷,IK\8eèBð\88h\849Ô»\8a\ ehó´¯\ 6ç\ 3Õ£¢R9ûü\1a@>èç\92áçøÈÍ¡qv\ 4+=è\ 3Ë^íXÄ\ e\8e\10)Ùp`u«       Ë\1e\18Á«\ 4±ERH¥`ÙS\15Þm°-Ù\86h%Ø\86\1cNÅpa\ 6z\ 2\98\1f\9d\8ajä©\88²:\ f:)ÖC\97G&u¹\8b¥ÛòÈ      M\8cÚX\92-\8f±\ 4/\1ftY\ 3\9d*Ð:\88\l\86\9dnË# ¨¼âá¾¹0º¯\9cé\8d+\9fÜÝâ}Î\90Ô0ÖhT\97\8cñ\8aVK&\9bÉ´;\80Ö/¤²\83w\0\8a\83\97\ f\1aÍ\83ì»\ 3(üg;Ø\15¨y.æz»s\80íY.\8cκG\8f\ 1ºÛ³\9c3¤{°5\ 19|÷¼cL\85\1ci^år&£4(¯]UL¶Ù\8aiíÁbJN\9e\1fx6\ 6Ù¤Aª0Ô\ eÏèf\9e\8a¹^\95W<è\9eë¢ûà\84\16\13/:\13Ùÿ\9cÏôÀ\ 64r\18úÒpvC\ ey\92\7f+\85\11¼J°T\ 5hÉa\98
+e7`\vi\ f«\84\19\½ª\18®5r.\ eÓ\86\90\9d\7fu\9f\9dyÄÒ£1¤`¤Úà\aÒ Kf:=\83«.\97¯`9g/gpÛt"\8càUV:_è¾y\84óö°Õ¶)\ 5\8cê2ú\v×ê¸\8bô\8e³#Ííìá\11KO.ë\9açÖùÃ#\96Ì\81!\ f\9bfB®h\9eÌ\ 3!g\99\1f\98Z\13\8d0\92SÁð©&\94\80æ©
+¿ýlK\86\85\f®^U\f×\9a\f/\ eó7Î\8a\13ÞÃiq¬ó\17Ðr\98\12\87;\7fÁ96Î_bwç/±»ó\17<àÌDh\1c¦\98
+\1d³È\998<9Üù\8b@\11\95±\1d\13=\ 3L\1e]}\9d\ 5M-\7f\88õ*·\ 4p\16$ÕZø÷\80õ
+/Ø5\83ºr\87
+\96³\8a¸f\80t£6\ f\fj¸©à!\9bG4wh*£«-¤\e­\92¡N0\15õ:îâ0­ã\fgöYÑG¬W½Ä\11Ü\85\8eæ;î\845\95ZçC{æ\80\8eh^\93£\91Nsx£\13\8a\8eɽÉa
+3êp*x@\ 4\ 6º¡y¦2Ì\16¼k\950£{\95n¶¨\ 1O\0ó£Ób;0-ö·Ñ"Ý\89\9e³\84m-\89Ì#¼´0¦V./±ßs\17¨\19¯X\8bý\85ÒÁ\\1c½|´­%È>Õ©v(\94 v
\ 11\8fââå\8bßø^\17\1d\ f#z\94\r\14\93e\87׳\98íÙÃCqôòvÈ$ä\ e¯7µÓ<<\14\17/_ü¶ôºè¾ú\9bM©öh\97¸øh½HZ\15£b\8e ¾uÅC%U\8c!*,à    ó\ 3Op å~\90ÊÓ½!ÜÝê0£#\8e\8a»\97ïjgºðªÐø\86b=ÖÝ·ên;\9d3^åêZX·Ø\9a)\9c1^Ñd½§×W\1aI\11R~\89\15\90vÒöp15Ôäé\ 1£\ 6\1d@ù%\ßËÞ\ 1(î^¾»¹áÂè¬{\14^uI±s\86t\ fr_¨.ùîyÇ\98
+\85²p\1cÉ\83¬Ò ¼Òv3\843ày%ùR\ e^>À\ eÉL²\ 6i\90(Ìm\1aìÔ\ 4;0ÏÅT¯É+\1etÏuÑ}p!M\19iäòp{\81\11ª÷TÝ-!\eÓ\94Þ\96áÖü[ Fq·\84ð\80\9b=BãÊ\8f©Ðe ¹'[·\89\ 3\8cîU¶ËLÏ\0sÍp\8as»Ìô\88e³ÜX³\99]fzÄ\92\99No\1e÷\95\91U¬=H\e\90ÁÕ¶uu\80ÉóC5ghFÖ\96\86C\17\8cû\ 2ÅÝËw·\90_\18\9du\93«.¿|Î\90.B\1a\19äð\1dô\8e!3\1dNÇAæ}.¡cp\9e\ 3p:®S\ 3\8a\83\97\ f\rrìs   {,[¢^ÍÃ\91\87\93W<k¦»&ºß8Ó=>»çWÀ.Ø÷\95\97\86\13\11¸`\1f·õ\17\fzýL\85\1fÒZ\815Ý`*I\97`ÉPX%I\17á¥Ò}"å\19\102\9cÕ'R\1e±d\18I¶DªÝB\86\13\96ÌtöýC_YX\ 3[u6\91Ä­5¯\9a\13T\ 5\ fkBÑ,¬©4\9dQ$qk\954\9dS\96J7[Öq×\86¹:®®9nå\97\1f±´ãê\9açV~ù\11K:Î>Bq\17Ym=¥\9cª|¸\92¶E\9b\19Å]d\95\87î¶$ǾhÓ\89\blá¨Ä*\ 1£{\95í¾í3À\±\85âÜîÛ>bil\81c\e©6l±Å{\96vÜp\9bHIð­\8d\9en#%\1d´6\86\95T\15<¸½¤$øLeØfrì»ÉaN0\95\1e]êò\19\8e\en{;ö\8dï{\96vÜp[ܱo~ß³$ê\881ØÂ\1eCGódå\8d¡Ê\8aÌÔZÚ\85\11¼J\10[²¸Ç\98Ð<Uáõ\86mÉB¤\95`!:\9c\8aáZáÇÅaþÆ8dÂ{\14\88äl_¡\81\94¤KN]34üi\1d¿±9%ÍÐä\14¼°}\89\ 6R2.*O©\18|Æ×a¦[\86\ 6\95ª¼\82á\8e¹*´¯ü¹¡}\127U\òè\9c!ß'"G\ 4²\99Â\19ãU\9a,\9fF¢ùØ1\1aDÚK\8avó.\10Fð*Á6\86BcÇh*´\97\94\ f-ëæ\af\0\8a¨\18.×I×\86¹:L¿4í~/ü\88e\9d6VçØ^ø\11k*5»)ΤæÉr[7Åù\13UäÕr]7Åsu7Åù\ 1ù0\90\92'S\ 5ÊôàSW\ e\96Õ<\8aÝMqÃ\83þº.:î¦j×Õ§\8aËú\9d3^ñ±/\92{¨NCøs\86t\8f~(\×æ^\11Òv\10_\16\aï\0\86\9a<?Ts\80nîU\81výl\aÉ\05\8fâêä\15Ïê\9ek¢³îQxÙ¥*Î\19Ò=ÈH\80\1c¾{Þ1^ñ;CÁæ}¢\12\8eQòQø\18$PhÊ\9f\8dóúÙ;s¹´/éd¹~P8B1é"6ð\92«ezÉÃ\92ÎÁ¯F\97\ 3Å\1d\12l\9b\a\92Î\9c¢Á\8a5Ã&\13\v\18ÊûRHk[&$Õv_òMí4\ f\8e\1f\ 5\ 3+\18\1eóÙEÑñgÕz³ã\eÈ8¸¶VE=vùZ;rlвTÇåÙ)dKF\bɵ\99|
+b'ñ 5û\Þ\9cºiB\9fj_\17\1d>\f\e¶ð\v\1d¸¾ù¢òùe\88ú\89 SôiZåóNaT¯Rm±V\9aë\*Élá#S«\84\19ë\f\1f\9f<\ 3ÌåNùH\15tÛq\96ª¶KÝp\82Q½Jµ½ºÒ;Îbß\16\96±á\ 4cx\95\95C0w^\e&»3$û\f\96I9\8b\ fsJÖ³{ü\88\8c|fwØÙý¤½¼]\ 5\17\12³°)4µ\83Ï0Ô<\17'/\9fÜ*\7fat:/\16\9b\ e\88N\f\9d¼M;Yf\1d\93Î\1aÖ\81BE*]dÎ)Û\94SdÆ1éæ\ 2×ë\81â\e,1Ø\ 5\e"íÂL<Ö\ 5\eúñ\1f¹`\13úº`C\17\8aL>Øá·\90rçC\14ø&\rÿì\10\88y.\ 6\ 4\91W<¸Ár]tæ<¹`ÃdÙáñM\1aþ\r¦ìᡸ;ù`çiBîðø&\rÛi\1e\1e\17\ 3\82\83·®ÿ\\17\9d9OïÍ\83Æ´ª\ 6\95\1f\9eª\1e¡0ºS  +¹«4O«Ke\98­áQ\82!P b¸\96\17/\ eÓÜ©·Ù£\v\ 4\a¥ò\v_[\87\vÃ\85«ò°º\ãÏ¥ÒÌÖÖé`D\17².\Ë\9d\17\87\89ï\ 6
+Z¢ÑX*LP\98\8a/\0\10¿Æ\92Q)\18Ù«¬\bViTª*\14ªÊÏ¥a\ 2ÒJÀh^e\8b±\9f\ 1¦¹S/\15\83N\eÎ0ìÛ\9c\11=Nad¯\92í@@é\rg\18Ål\15\8fS\18Í«¬;ÖêÎ\8bÃä3\908t3\ fR÷çQÃõ¹\9fÄoæñ¾4jxOÅÕËWÛÐ\83\94\1d½*\14µ\83\¿\9açâáåí\86#\1dH\\17\9d9Oîß\11©A\82êSôÀf\11Thm(®^Þ2\7fBîð(zÀ/\1d\ 6\ f\ fÅÃË\ f\17ò\\18\9d9O®ô0Yvx\14=àg\1c³\87\87âêå-/'ä\ e\8f¢\aØi\1e\1e\8a\87\97\1f.ä¹0º5låÒZt{ù52\ e\e\1aÇ>6\ e\1d\1c¦²öòJ#©d*Él¥m|\801¼Ê\96rx\ 6\98æN½\19ô¬dj\82×8üàgÜF\8b0ªWY_6)½áä5N~Vt\e\18^eø5ú\19`.wÖ5z,{©&ª\ e\1fÍwj¥U\aÐR©+ã)ô\8e³6³µ\8d!a\f¯²®ï\98\rs\rv¹E\12]¦i­SÕÖ¯º\8d"0ªWY\99&¥÷QDû\ 3±5öÅpè(2\95-!ö\f\9dÉÝí\0\8d8k>\1c\16\9aAkH\Ñ\93\85fòã¾¢b¿ôûÅ~õW*U\15\8b!\10\9a­J\88!P b¸àÎ'\80Éç.Ç:\ e:¶ó cÅhc\1d\b\8d¾b´áO\84Æ:\12\1aþLH\15\8aÚ\91C¡Ãb4\81 §B\8a\aç.×E·\9c'\aî \83\1c\f\1dn\81\ 4ÀcGx(D] Çºó®4zÌT\92ÙJ\eJzT(8\1e2\Î\8b×\86\89«\r\96\1aeRCØ\9cª\85¼|E!Ë\15\97l!oNÙË[zTHé=Q(Aì äUó(n^¾¹\80üÂèÌyrpÍdÙáQl\8bß\16Ï\1e\1e\8a³\97Ïvà\ er\87×õ\16Lo\1e\1e\8a\9b\97oþ:ÀuÑ\99óô¿ìH.}¢\ 68\ 2\12\9ai\85ÂÈ^e¥O\94Æë\9e\ 4¶ÒÖÅÂh^eËò<\ 3ÌåκºÛ\ eÌÕDÕþ\96ÐÌ*­ÚãK%[8¥ô\8e³6³µuº0\9aWiÑE\90Ï\0ÓÎ\0õ÷IA#0Ðs0\ e\19äÿ\85\88þ M\18\87W9,\83¤4\ e\1e\98­â\ fÛ\84\91¼Êú¹V=\f¼8Ì\8f~:_ÛË\àè7þ
+_@ýs¦\e¨Ç=Õûç\7fèã\84Õ\ e\12 \92J%¡¼\94\92æ´%¥\9f^¹ø\93\96ÏÆnâý¥\8c\19Å}¢k®³\14Ò%½Ì5´ß?\95\fÙ¶ÉÎfÃÆk\83meô¨Æ\9bÇ\12\ e\ 3Ãåñxɹ\86»Ùùs:\87\9e\1e@O§Ð!\9d*\8aCM*~ê¹òR\8f\9f\ 6\17\1eTF\ 2\7f»ý\90\7fÿ»Û\ f\91þªó¯éb*,\93\14~"V\9b\7fQ7¢îÀU\97\83~\ 1&/\83³\M±\12[.j\99\95â\1foÿ\ 5Fd>Ú
+endstream
+endobj
+2322 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115428-07'00')
+/ModDate (D:20090924115428-07'00')
+/Title (fdct.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+2323 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+2324 0 obj
+<<
+/BaseFont /XKVMYW#2BTimes-Roman
+/FontDescriptor 2326 0 R
+/Type /Font
+/FirstChar 45
+/LastChar 83
+/Widths [ 564 0 0 500 500 500 500 500 500 500 500 0 0 0 0 0 0 0 0 0 0 0 667 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 556]
+/Encoding 2327 0 R
+/Subtype /Type1
+>>
+endobj
+2325 0 obj
+4757
+endobj
+2326 0 obj
+<<
+/Type /FontDescriptor
+/FontName /XKVMYW#2BTimes-Roman
+/FontBBox [ 0 -14 633 688]
+/Flags 65568
+/Ascent 688
+/CapHeight 676
+/Descent -14
+/ItalicAngle 0
+/StemV 94
+/MissingWidth 500
+/CharSet (/C/S/five/four/minus/one/seven/six/three/two/zero)
+/FontFile3 2328 0 R
+>>
+endobj
+2327 0 obj
+<<
+/Type /Encoding
+/BaseEncoding /WinAnsiEncoding
+/Differences [ 45/minus]
+>>
+endobj
+2328 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 1309
+>>
+stream
+x\9ceRiPSW\14~/\8f¼<\15¨\12S@4yµµj)
+("E\1d\ 5´¢\91B\88K\9cÚ\18äe1      \89\ 4\ 2\84\ 4e©¢W\85\ 67Ö kÁ\ 5\11\84@+*\85ªu©\8aV¤¶È\8cZZ[k\9dNïË\~4éL§?úçÌÙÏw¾spÌ\8b\83á8î-Õè\19S\88Ä W¤yì`6\bggrØY\ 4°¹|\qÜY\98¸\9að\ 1Þ\ 4ðöª\9dÉ]â\a\9b§ÁÒ7`áT\8cÀñl{C¬Á\98\93®Q©3èy\e%\9bç\a\a¿ÿ\9f',**\8aNÉù7BÇ1&\8d*\8d~×­\98\19\9dÁ¨gÒ2¢éXw¶N§ÙA«t9Fµ\89V¤¦2©\9e²M
+\1d£¥×ht\1a£Ñ`¦çÅΧÃCCÃBÜ""A£OÉ4Ñÿ\0§\13\f\98\960ªL\9d"ýÿ\11\fæÄ&/Z\1c±$2$4,\1cÃÞÁ\16cÓ1\ 1ö&æ\8f\ 5`MØ4Ì\ fãcÞnF0/Ì\82\aáõø(GƹÆù\93à\12J¢Ý\8bÇ\16ûº\16ÚºÙ×\1dx3¤\b\17Æn\12\14@3×L~jÎÝ\9d\ 5
+\80õ°õ³­\95²²\8fA\14XªÛ ]½\81Y\0\10\a,h\89è\93\]÷\13ó\12@.xÙsí1\95S½*.^¿\14\ 4\8aA²c{»ôKÝ3\0  
\8fÃIpÎÀ%ó\8e\ eá)m\85¡f\1dåË^¶µe:XÔ©qøÝ\e\83¶Wþü\99l²k©ÀLîËسÇ\ 2ò\81¥ÄRFñO\97+\95eÚ í@nÙ\99¦Öå(Àf\10Ý\9d\f½\12\87\98K)\rÌ\91¼R30QkeÛbÂÅýÐW&Ì [\90\9a{\92ä\8bk\ e\1e\b:\ 6ªöÕ\14¹;YÛ;
+;\82 ïéÈë\1f¤7QÀ=ÑìAE7¸Bõ_h¿î¼\90­:+lÕ\96ïªL¤\1aH_¶ØÖÆ>¿ê\a\87F\98!\7fþ\1d\18\ 2\7f\14|\rêö×\17\Ï</\ 1k¨HɺUÆ,{½R¨¯¶Ø-\80Ê°ÚÌê®Ì»Ã#\8d\9d½¢ÞÎÆAp\eôåö¦µf\9dÌ>.¯¡øOîô6\9c»2ãñú¯\16Êä\16­J¨7Zwe~T±/ ó¾óô7\80ºé\94\8bUVUzºH¯7X?4¹\89*\ 6\ e\ 6»Üá\a\9d\8fV\fûóÇY\1dÌ\15Ìa\93ä$º=\91Ä]\ fÏ h\1eÿÕ0\8cþ\83Dko\bP\11     \8bà\v®g\87sìÀ\b\ e]w   \18Ï~/\80[ÈJPrè°½ýi@\81ÝjÎßk\ 6\81\88!\11\8eò\ fì\a\aÀþÀ½%Åe§:\8aò:\85\90§¼¼\ 1Ì£\82\13V.ϲØOê\85Úº\8c£f@¥Ùv§3½¦ïF\87\9aú.\8az\9cµ\ 3à!\18Êî\91]\94wKêÐäZ\ fj[3ëÕ\83\9f\19\87\bVâZ)@d~RvÌ\16\84­HD$@3Àâ¦E]²vù\15Óu@Á©c¿@!\9c\1eó\18ñäæ"F,j\82ÁÐ\vb0¬\91B)è¼`ìb,\9a\868©   «\17\19.ì+kvT\88j+[\8f\9c\ 5\9eq\85\ eöþ\ 3\9cÝèzO0A\92\89hnUa×·Õ'úA Ô\93hëÄ8÷&   Õ®ÙnR®Aã-\9cm\85FÁ­\89\83ñ<\ fÖF\97_#^ÿ\ 2\9exA@»û      ¥@aQª\93\92\19Ä\ 3h\12@øi4©7ù\9c¼Ï4\bú@WUÛÙÁþvH\ 1èCAE(|\vù\v\8bw  F\9d\88\8b\18ÄÈé\88\bù_0\15ª\9d\90\18\13yNXÁ^.¿çÀ¡f\8c\80Ýî\ 1hm(×Æ;^z¬¤äPµ½ªä( j\8fXµ¢      \19\ fì,ÌÈ-°\16Ø\8a\15\a(+ü¼\82·ì`îQð\ 5ÅþêÁ
+\1e²u\ fpø|\8c`\rp\96 ¯T)É+øÄ}ÅB\12.\83qOÇÏ?\ 4\8f\ 2\7fÿ`øméæÌ\1dJ¡VcÕZâj÷\ 6tüÖvê\ e F\a$\91Ë·-\88\f\17¡5(\89»\9b\9dÁóÍr°\9b\1cPê [&?\99ÒRæíý¤ÚÛ\aÃþ\ 6þÝk·
+endstream
+endobj
+2308 0 obj <<
+/D [2306 0 R /FitH 686.127]
+>> endobj
+598 0 obj <<
+/D [2306 0 R /FitH 460.231]
+>> endobj
+2309 0 obj <<
+/D [2306 0 R /FitH 360.127]
+>> endobj
+2310 0 obj <<
+/D [2306 0 R /FitH 339.06]
+>> endobj
+2311 0 obj <<
+/D [2306 0 R /FitH 318.547]
+>> endobj
+2312 0 obj <<
+/D [2306 0 R /FitH 298.033]
+>> endobj
+2313 0 obj <<
+/D [2306 0 R /FitH 277.52]
+>> endobj
+2314 0 obj <<
+/D [2306 0 R /FitH 257.006]
+>> endobj
+2315 0 obj <<
+/D [2306 0 R /FitH 236.493]
+>> endobj
+2316 0 obj <<
+/D [2306 0 R /FitH 215.979]
+>> endobj
+2317 0 obj <<
+/D [2306 0 R /FitH 195.466]
+>> endobj
+2318 0 obj <<
+/D [2306 0 R /FitH 174.952]
+>> endobj
+2319 0 obj <<
+/D [2306 0 R /FitH 154.439]
+>> endobj
+2320 0 obj <<
+/D [2306 0 R /FitH 133.925]
+>> endobj
+2305 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R /F14 574 0 R /F11 573 0 R /F49 457 0 R >>
+/XObject << /Im16 2292 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2331 0 obj <<
+/Length 1193      
+/Filter /FlateDecode
+>>
+stream
+xÚÍYÛ\8eâF\10}ç+úÑVäÞ¾_"­"Â0IVÉ&aü\12±<\10Æ3\83ÄeÖ°\896_\9fêns1x°'\182\ f\88¶]®:uNUµ1\ 4="\82~è|\9fvÞÝ\1ad±UL¡ô\ 1QE°R\1a)£0e\1a¥÷h\18QjâQúáÝ­æû¦\96`n5øñF½\1f»¿¥ýA\9cpÎ#\8dãDk\13Ý\ eº¿ôé\9b~ï×\9b¾óÓ!EôÍw\19BB\rÇ\8cP\940\r'y\81\81ãÒ½h\98HB¢îj5}\\84\bé\90\8dÜJDë§,\9cú+\96*\1aϾdá|:¤£\90  \15û\99p\8e\85µ\9bL>\11B\82Õ>,ë±\14&.Ô\ 1\9e\84
+ð¢\18\94É\ 2¶h\0\9bÖÀ\1e\1cø \a1dm\8cA\1d\92\17Æ¡\bè«x\91Ǽ\0»Ä\88\ 3̪\ 1\86\97OD\92\9e¨\14\94bÃ÷\ 5åÇÀ5¦VîL$ \ 1\19cÑ7áËe\ 3\17¨û\14\9e\ 3i1Xm<¼\7f_ÃÍQÊ   #\ 63j\vfTa¦\e0#¯ÇÌà\85ì)\85&5gdïF\r#ò .Ìùµ,\8eU¬i Û\ 2å>n;³EÖÌ\96¢R\18i\0[\9c7[\18=_\ f\87ªÑ\83±\16\86\83\8fÛ\8e\1eªÙ¬gM¶(ý\1fõØh~r?ñ\89\b»\97\89°X\89í\1eýÇqª\ 6[±íâ!\19\ 5P\ 5:QFÇ_\9e+Z`»{\16h<pÉaiÐ\v\ f\0Ð\87²É\8bR*®Oé±/(MS_òlWò'u\0Æ\84j]\ 6uQ\19X\ 3\19ÜçNUI¡a\9f¦¯\90"\1dòÑKäQ,M-{lÇ\9e÷³ß%\e¨½*¨Â`*ù« ²ó ò2Ô#±\15Å\ 2Ê¥<ÆôEÅV\rÅ®dP\elôUÅ>`°j×R\18.¼¢\83O\963<8\bmßl\8dl\ 6\82¹h\8dЦ\ 3A·3\10ô\15\ 6\82ng \88ÿAl{Q±eS±y;b«+\88ÍÛ\11[^_lN.*6o:ýy;Ó_½ÝéÏÛ\99þòúO\b\9c^´FtÓ\1aÑíÔ\88~»5¢Û©\91\vl\1a ±qï\99¬\94Ì¿\19\80ÊÌ¿\19\84\e4¶XÄ        ¥LF©\97S˨·\9c?ϲuq4È&ËÅj\9d\7f\99¬§ËE8×\9d=.óéúi^QLîG·ÁÜØ\10á§Åó\975Üexô<ÎÇsð\9b¯¾õåÙO;\9f;\8ev\82èöå9\83G\17Ë8\9aÌ;Ã\11A÷pñ\ 3"Xﹿ½é\1cq0µLÀz\86î:¿W¼\887\1aRµÀ\9e\81æ\b8>Bè8\11
+p¤1ÓÑ×gØ\12\92dTDwÓ\7f2\a
+QÆÀ¹\81$<w;½ÿ\9c®W\e\95\10\87*f\1aíÛÜAoe÷ß\ 1\99\fzí&[MòésA\194Åxq\1f\16\ 2\9bh\9dÇ4\9aNür
+Kàø\ 4)\ 42æG¤\bkN\93R\12&8\83¢0\16KV\14@7æ,êÝõº?÷+Ú^bê]\16JÆÌDëì1Ë=\a¤à¨\18:ã<\1f;\83¯þ¢¡XY\81ö\r¨r\9b0L\8a\8fK¿\802\8a\13ÃH¤D\92Ͳy¶pº¬Ã¹\9d78\ 4v\1e¼W¥1\97\1cw5\19Ï\9c\8aÖìæÐ*\1c?,ó°è:Ï=·ÖÑÄE7Qö\90\94²Ø*MÅd\9a\85TWa¼=8y\9cPyP0\eOÜå§â\7f\1d²ß×Ô¿\96-\18û<=æÔ\ 5Ó[N·\88qE'%\9cº|U\19áÍyjÉ:µäeÔ\92%µ¤ô»\86ܨå\8e½Zná÷\15·¸éUAß\b\bR©­T\10ØòàÂ-NHD¡\97\8c¡§4J66¥B+kuôG\1c4î¿Jdz\ 5
+endstream
+endobj
+2330 0 obj <<
+/Type /Page
+/Contents 2331 0 R
+/Resources 2329 0 R
+/MediaBox [0 0 612 792]
+/Parent 2321 0 R
+>> endobj
+2332 0 obj <<
+/D [2330 0 R /FitH 686.127]
+>> endobj
+2333 0 obj <<
+/D [2330 0 R /FitH 668.127]
+>> endobj
+2334 0 obj <<
+/D [2330 0 R /FitH 651.689]
+>> endobj
+2335 0 obj <<
+/D [2330 0 R /FitH 631.763]
+>> endobj
+2336 0 obj <<
+/D [2330 0 R /FitH 611.838]
+>> endobj
+2337 0 obj <<
+/D [2330 0 R /FitH 591.913]
+>> endobj
+2338 0 obj <<
+/D [2330 0 R /FitH 571.988]
+>> endobj
+2339 0 obj <<
+/D [2330 0 R /FitH 552.062]
+>> endobj
+2340 0 obj <<
+/D [2330 0 R /FitH 532.137]
+>> endobj
+2341 0 obj <<
+/D [2330 0 R /FitH 512.212]
+>> endobj
+2342 0 obj <<
+/D [2330 0 R /FitH 492.286]
+>> endobj
+2343 0 obj <<
+/D [2330 0 R /FitH 472.361]
+>> endobj
+2344 0 obj <<
+/D [2330 0 R /FitH 452.436]
+>> endobj
+2345 0 obj <<
+/D [2330 0 R /FitH 432.511]
+>> endobj
+2346 0 obj <<
+/D [2330 0 R /FitH 412.585]
+>> endobj
+2347 0 obj <<
+/D [2330 0 R /FitH 392.66]
+>> endobj
+2348 0 obj <<
+/D [2330 0 R /FitH 372.735]
+>> endobj
+2349 0 obj <<
+/D [2330 0 R /FitH 352.809]
+>> endobj
+2350 0 obj <<
+/D [2330 0 R /FitH 332.884]
+>> endobj
+2351 0 obj <<
+/D [2330 0 R /FitH 312.959]
+>> endobj
+322 0 obj <<
+/D [2330 0 R /FitH 283.078]
+>> endobj
+2352 0 obj <<
+/D [2330 0 R /FitH 262.862]
+>> endobj
+2353 0 obj <<
+/D [2330 0 R /FitH 229.321]
+>> endobj
+2329 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F11 573 0 R /F49 457 0 R /F48 455 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2356 0 obj <<
+/Length 1595      
+/Filter /FlateDecode
+>>
+stream
+xÚÍYÛrÛ6\10}×Wð­Ô´Bp¿<ubÇI\9dIìÆV§\93&~ %Zæ\8cDÙ$\9dÔýú.\0\8a\17\v\92¬FÉô\89       \ 1»gÏ\9e]P8\9aE8z38\1a\ f^¼V,2ÈH*£ñMD°DZ\9aHj\89\bUÑx\1a}\8a\152h8RJÇ\17'Ççg\97ã\8b!Õñ\1fÇãÓó³áÕøí\8b׺³\ 4£\1a)©`\ 3÷cB\8c\9d3Àõ\9e'ãÁý\80À\10G¤ÝN*¤¨\89&\8bÁ§+\1cMáåÛ\b#eTôÕM]DLbd(\87ñ<º\1c|ð¶w÷%\8c!-H$\85B\94K¿ûY²H\87#.5\8bÇCªâÇ»á\b\8cQÂãËì\9fÔZ\17\11Jau\1d\8d\bAF\bÿãÏXàë¬*áJÜ,¦\91\ 6Pºs.³Y\9eN\7f\1d\8e\bÅ8~\95\96\93"»«²e\ e;0\16'ùÔ\ f\8a´\849q5$q\91\84ÒÁ\12\86\83\19¤Ø\1a\1cÜèípp\13
+%Ä\ 3,ðæ\1e½¿\\8f\98\16\10
+\18}5\1cI\88õin£\¥³´pÎã>8IQ$v£{     t\91\90Ñ\804\152>[º\81\88\9d{F*\8a\98i¸rÖ\98Gx\97Q\ 2áÖ¾Ï\18Ó\80\ f\88\93f\1dÉaKغµÑÝN\96ùÈY;\12\fqIû\ eUI\96\f¦2\1eW·©\1f\'¥\e\89x\91T\10¹´D\ 17ìTD\94ê¯xöáâ\87¡-×Ñ\1eIÂb\1aÀ\13\98\13ÖÖt5\85ùµ:pÚ[\80ÓÙ\f¸Õ°\ 2\b\9c?\ 1ÁAÊ\89ð\90rH:÷«\87\85MÇk\9f\8d\85\9f±¼ñ\13î\1f\92ܾ­BH\14I>³¹D5\8fo\96\85\1d\888ñ÷³ì\8b];ͽ?
+w\99¦\91ÔzåÑ}\95\ 5|æ 8Mdlê®/32@\1dÍj\9bj\95¹\9bgA\ 4\156«Õ~\ 1×\ 4±2`\15\bl\ 4\rðÆÎ\1f\87 NV`Áåñm\ 6
+\ 1îqx\95\95\1eÖz¥>!*¯+\8beéF<\96ìùÌ\ 4b\9eþu²\93\9cì;\92Ó\1a\1f$'\ 6µÒÛÉ  #Î[r®/¢\9cËÏ_C2k\10­=Q\96áöÖ\12Ò^-u]$¸U"Ù÷¾\84\1a\ 2\ 1\9f\9b/\80ÐÉÄâqë\9fz:\ 3~þ%\10\18B<KCH:B\vàIâ/Û\b-$Âr\a¡\15\ 2Òm'4%H48l&²n\89ì9       ÕÅVù~nna7áJÄçùÜ\8a\87R\r¤¸\9fI\9f1áEY\ 5\88\fvjÙ03,­\8c\1a\7f?\85¼í¶&aÌÀ\1aÉVS®B\8b\bØEì\ 1Ù\95í@xüe\bÌOæ\10üZ.!S\98|\92×\ f\8eK¶s(R\9f×\ fe:Ý'³\8fÞ\9fþ°Ä6\81Ä\86´
+&¶ÁH`º£êp\84é¶Ä\86Í©Øg\11Û
+X\8bú®\80ó®_èyk³WS¾¢æ\93 CïGU³ìõ"\14uh¸pC¿\9fJ¿\9c\8d\9f\1d1\97ݾý\0\19Q¬¿{«\19\12¦Þ?\0MVU\10\9eP_÷üЩ\84\1d$¡ mÓ\f*\11Å;ø/\10oµ3¬\19Ä !Å^¢\ 1Ò§Wú\0\ 29©S\0ú?#T_\ 3Ö¥C
+VK\87bÒ7\12\11\8b§ ØÖ=\903pBPÏÑ\90]\12¢\ f!!ÏP]Ó\91\10"hü³½°\98¸\13É\88\1a½\12\95\1aN  ­¾:°¢\üþñÏ]zÒÕ\91\91 \9cÆ\14×\8aPK\83\84ÖÆ5Ò4þ\9aM«[?´)GÁ´&å\bé"\r\872ÚÂô±\9eÂ"\89\8c\82\1eÁ\15z\ 3Ç\a\86$©­Åë¦\82¥¶{êLº\9b'yÚh0Õz]\b\18Ö\9eh\fCÉNoÒ"Í'©\7f~SÀ©²ôã,\ f\95±»ìït^î\85ño\aÃXS\11ߦÙì¶n:ì½×6± h\ eÇoÃv\ 1­\1dÐr#о)`\96\7fÀoEº`\ 3ÐÊ[!ë\f\ fZ`CÍÐ
+f H\96{êî\ fìñáÈË\14^\91×\ e\1dMàº\89¼ö\93\86\mr\OÁ=L    %`/\1cìks¯×mUîØÒ\99ÓHro»þ¹Dì³i\11Ú\14SÚÝÔ\ 5Ñ\9eºd\9d´\92Ögd\18ô£\b\9d\1e"üÉ   é@±<\\920FzIÒ¶ûdc@5"\84ï
\87\96o\89'\83\1e¡3çpñäÏ\88'ÿÆx\1e07ß\9c¿{uqòúã\81>\91¼<Ì\a)\86H[ÿ[]î\7f\90\82¢Á\ 2]ho%ã>(âmE\94ÃY×4\8cJ\8aº\8a\eà\b{úÕ£ùð¢»\1f^Ü×\15ûÌ~X´ñ«ß\8fBU©JýïlcJ¼~Ùk\98î¶Cníÿ¯%\81`8µQ_|å³\8b¯Â¸îò`0[Χ`¸\eï®\17{Óo\b\89\7f\7fã S¤¥Îñ\ 6\ ebÂwp\10àÇíçÕp1\ 4\12ÒÖÑïGB±NBìÅ\a\ eM\9bIH4ùæ\1aj÷×r­\9e\ 5H(\ fGÂæ\1f\8fÎ?\1fÿ\ 2\94@\13Â
+endstream
+endobj
+2355 0 obj <<
+/Type /Page
+/Contents 2356 0 R
+/Resources 2354 0 R
+/MediaBox [0 0 612 792]
+/Parent 2321 0 R
+>> endobj
+2357 0 obj <<
+/D [2355 0 R /FitH 686.127]
+>> endobj
+2354 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2360 0 obj <<
+/Length 1371      
+/Filter /FlateDecode
+>>
+stream
+xÚíXÉrÛ8\10½ë+x\ 4\ f\11ËiÊÖ\92¥ÆKd\95§RI\ e4E+¬\91D\87\92\93\8a¿~\1a\0µÐ\82\1e\973Us\11[`\13èî÷ºÑ\0\89&\11\89^w\8eG\9dW\ 3\1d\19l$\93Ñè:¢\92`)U$µÄ\94©h4\8e>"ÊHüyôîÕ@ñmUC07
+æqJÝ7Gç£þ0N8çHá8QJ£Áðè¤ï\87zýîY¯oçé\90fõþ¨óµCA$\11ݬ,\15VÌDù¬óñ3\89Æðò]D°\82\95¾;ÕYÄAÕ0\ 1ò4ºè¼\ f\15\96ÂD2U\98      é\r<ÍfE\9c\b©9\1aÅL¡\1f7q\ 2\ f\18ã\8c
+tQÞ\15Öº\882\ 6³ë(¡\14\9b\1f\7f")¹*\97\vxR§Å5Ö\10\9fm\9d\8br2/Æ\7fÄ     Ä\8b ^±ÈëòfYVs\1f\80l>öB],@\a\98¢2wb   b5_¸è\84£Â\rV|'*Âè\9fG\ 5\82p\1f\\1dI¦1\18â­~}ögoØ\1fÄ\9c¡îÐü\1dJ\9d\ 2\ fÄ
+dÖ\8b\13   ¸¾\9dÇL£e1)j\17\rÒ\8eÖQ]gVá\87{  T\92*m\85JCèY*Ñiå\84\14\1dù\95[æ*\8e¹b«¥\87çÝ7^\89\8a-%.1¡|¥ô\89\10\16\98\89\12L6L\85\99þÚuT\10\f\96¬t²:q¶'Fa\ ell¹·r.\91T£¼ò±ÈÊy9\9fØ1\85\96_\8aõË$\14 eá?\ 2"(\ 3Ð_Û'\83ï\80\aEã%Ý2NJ¬ÕÚËn£A"\89\8dâÚ\ 5\v`\825\80\11¢1r×EÊ0\83×[J7ÓlîY\9f\0JL«¶\99Î.à²óÇ
+\93j:\ 6Ó\9d\\17×E]Ìó"äàu\rÙ\86\ 3P$\8c\vLÕ*½\9aÜ<\1fö/\81\84\1f\1eà_úRü£)ß°æÃ\ 3üc\9cíá\1fHÀ¡ÍDaúqÃ\83ôã¿Ä>½bÑ¡\ 4Ô\948 íÓ\ 2\1d`\9fÂ\ 2
+bc[\ 3\12$Ý6û\fT"\8e%mæ'\ 1ö\11¬%ptKë>ýô.ý\ 43\9e~`\ 1º©\8boeu»ðÃO"à=¦7\ 4tUðø©,\94ûX(ÿ\8bU\90·½û×iH\98§!¡\ fÓ\90jº¯\bÒV\15¼
\10Ö×ògUð÷ áð\7f\1a¾\0\rÛÛñ\83{±xþ½øåXxz|±\8f\9cKR*\18â²aOC#\89FÖRJ¸@Ëj\99M\9d\9c"÷áíÌþ^\81¢Fv\ 6§\ 5\1eºþ[\18LRÖ6éjZ9åÜ~÷÷Â7Ò¥ë¬\ 5ÊüßC½l\98slÏ#½_qô1\9d\ 6ÝI®yÀBÍð&o\82ág\1c\8bMñK\8ai1kHk\8b\80\82\1c±\86¨Æ\90DphKD\80\81¼¤i6±¼\91ÄÆ\90¢q\99gK\971vèû\97Ò\85ùKÈá \10Y]x$rÿr\\8c\ fgÛÉñ     \0qñÜ@ðÃ\80\80/ä:¹OOBP\80\13<U\ f@!é¦\¥\1c\e!\1eèÞ\84\91\1e\11x®Âæ!0)\9a­â¸ð
+×UÐé"k\80\9fey]y@Ú(\1d\9e\13'\97ýîh/\14\9bX'Ô:Ü$î=ã\ eìÕ/c8\90\17ù²ª\17ÛÐ\ 1ß\rõ\1a¶°P\98âC¬\85­ä\14\88zá\bÜ\0\80oåov\8aÆ\137`QsÂ\1a§½ uxÚtÏú\83ÁÅó\1c\98(\96voÚ.cm\10\16Í¿ \0\86`*è\ e\ 2­N\81\81hÌn§ÐÚ"\ 5frí\89\14qb4mÀY\99
+Îa"\ 2ÇV\rø}½Í¼Ûå]1öC½îÈ\vy\15ì\ 4
+(\8e2/7t`)à
+Õ"\9bÞZ¯í\7f\a«\15\82°Ê\10¬íýê®\9c$wÙÄ\ fVõ¸¨\7fao>\f÷§VKõ{m[öÒÎ_ªèf\93\12Ü\87\vôòê¶ù\eê\84,v6ì\ e;åK'\7ft\12¾\7fûh$䪷ÝÓ\9dË\83\90PÆ]\9a® \bÚÅ4t\95<\8c\85àr\a\8b\14K\9e¶­õ\95þÕ@\91ö\81\8a\8bõ~øµ\f\1f¹6-3ä\93ôù\14\ etªÜ½æ½@ÛkZôöÙ\89Ï~+â\a\82-ae±  v(Ú\ 6k*w£m¯x\84Ï\0+´ªWÂSXxïδ¾ºßºÂÿ\aÌVÒ´
+endstream
+endobj
+2359 0 obj <<
+/Type /Page
+/Contents 2360 0 R
+/Resources 2358 0 R
+/MediaBox [0 0 612 792]
+/Parent 2321 0 R
+>> endobj
+2361 0 obj <<
+/D [2359 0 R /FitH 686.127]
+>> endobj
+2358 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F10 668 0 R /F13 705 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2367 0 obj <<
+/Length 1375      
+/Filter /FlateDecode
+>>
+stream
+xÚÍXKsÛF\f¾ëWðH\1d¸Ù÷£\97Nì$M2\13;µÕ$\9e8\aY¢mNeÉ¥è:ͯ/°»\12IimUã¶ã\8b\84\ 1¡]àÃ\87\87H³«\8cf¿\f\ eF\83\17o\8cÈ\1cq\9aëlt\99\89Õ.ÓV\13ÆM6\9af_sC\1c\19\16ÆØüäõáñÑéèdÈmþÛáèÝñÑðÛèý\8b7¶s\84à\96\18\ 2ÿcÆ\19Ú\fh¼óõhðÇ\80\81H3Ö^§\r1Üe\93\9bÁ×o4\9bÂÃ÷\19\99ìÞ\9bÞdBSâ¸\ 4y\96\9d\ e~\r¾wïeB\10«X¦\95!\êpûÑø¦\1c\16R[\91\8f\86Üä\7fÝ\ e\vø\ 2\9dàLæ§Õ\8f\12½Ë\18çpºÍ
\88S*üø\9c*zQ5Køö1dÂ\12\v tmN««y9ýyX0Niþª\Nê궩\16s¸A\88|<\9f\ 6¡.\97`\937C\96×Õ\ 4\r\96\1e\964\1cÂ\11#¶à\90Î>\b\10I\94µ{c*]\8a\ fÔ\12îD\88ùø®¹½k .@õv\\ 3ÄMY/\7fz8\1ee\ 5qV>ê\8a\14Ä0öHz\99!\16\8c \8aònz\ 5µ\1cÓkCzm"½à\8832¦Wÿ\83ôêÍô:a|z1\8b5d±Í²ìe¹Ù\9d\14qN=\9aÞ\14\1cÉÌ(\89ivÁ]¨Ï³í\8aT\82p¶.HþjXh¨åwsD¬)¯ÊÚGOûä\7fY×c\ f©\7f\bí@\eÕc¾\ 5¨¹ÒùÑÂ\v*\7f\19nîy    Éb\9e`Á½\8fgo\83\11\93Ý\8e\ 1½Æ¬\8dÎ)å\89\93\9c\8f¶=èóv\9c\92\12¡ÕÊf¼\ e\0ÈàòÉb^øP
+g\b\83 zÑ6ãj^ͯ\86\852<o®K\14\18þ&`\84I\ fâ2<Y\¶¦! ÖkE\94h¹ö6¦\84\89\fY(¬\a\ 6\18`3A4\8b\1eÐíx
+\ 6\8cÔÒ\80 \88\8aÍøv6\9e\83?\Iï\ 4~{\7fQ¨Kð\18\18x7iÊ)ªT~\89åI\12x\16\9c\ 1Ò\1e\ e@ Ã\83§2Hïb\90Þ\8fAÜt\18t\98d\10\14\94´;\18Ä(¡\82wNJS\bÇ^\82BRö)DéF;i)¤U¤\10\bk
+µôÑ:Ð'\9a¥éÓ:z\18-h\8f=0Vázè\192X]$éc\88\94h\aÍE³ÿ\8b?'Ï­\ 3=sþlµ e"\7f@Hð\a´\9e?Ñ,Á\1f\ e2ÛÅ\9f\1e\aèCÅ¿Ä\9eô$\940æ84¸}\17\83ä$\94\f\ 2TqGù4t\1að¯Æ\173ܼ\84\95ùݲ\9c>²¤\bÇ¡Ù>uIáÄB<ÂrÂV\98\85%\85+£v-)À\ 6.\9e°\83r   ,ÛØA÷ÞN\84\96D+¹÷vb\13)\11XøPX±b>Ã\1cµ°4bá\9b\85b\92å\9cnÖò\bi%\99Ëï«is\8d¢õ\94CU\13\9eÙ|rW×e8,("?£±GÕa*6Ú\94?@h¾>Àâ\ 1BÃjW^\96 \99Äç\9eÀA¬æÁâ¶ú^¤ÚU9[\92PÝÉ+O>¾\85È\80\14½¶\87Ñó\87¢\17Vç×euu½òÏ\86ÊG}³2èG\0\8a\b\ 1\8aÏ\ 5\ 2½\1a\ eo>\ 2\ 3\14´þ0\ 2Lþ®Ý¬Öc\0ÈÅ\98þ¯f\81h\exj\12\9bÀîI@;\93 1\b\ 4#\96ÚÔ \10.4u\13;>ü\97¸
+ Y\18ûT'ÒÄ­M\f\ 2Ôú&\fß­Y7\9b¨Xul»®\b\9a"\ 2´\87>\11\84ì\11\ 1\9e·Íü\ 1\8a\1f|Á{\fÝbøv}ëXßÎä×\8bºú\11\83\eÏ\82\ e\bVF±\9aOËïAôåïìjê¥y=[àI÷øQÖŬ¼lðÕ\ 5b^ÏÑ\1d|\8d\81\a¡Î\87\8e\8anè \88.f\vß²'hñûc\14?8Û\17\ 2ÃUþgð¶©&\b\0j"\0(F\0Pô~sõ,\ 1\88\96\1f>}Á?Ël³Íihs*Ùå\94°-\a\0ê&\8b\9b0(\17X"\9d¿`á±_\81Ä\ e2\9cS&ëe\13ø{\7f½\98\95ED\16ù}³h_Ô\84\14L\9aEýXz?|:Û3:Á8\9emÚô¢¦\13[[q ÷Ý\9dÅ\7f (¬\ 2x0Â\8d D'(¹+¨6e\1c¢\92Ï$gK\#§û§lý\86±ó¦ño÷S\e{
+endstream
+endobj
+2366 0 obj <<
+/Type /Page
+/Contents 2367 0 R
+/Resources 2365 0 R
+/MediaBox [0 0 612 792]
+/Parent 2321 0 R
+>> endobj
+2368 0 obj <<
+/D [2366 0 R /FitH 686.127]
+>> endobj
+2369 0 obj <<
+/D [2366 0 R /FitH 620.248]
+>> endobj
+2370 0 obj <<
+/D [2366 0 R /FitH 584.383]
+>> endobj
+2371 0 obj <<
+/D [2366 0 R /FitH 428.908]
+>> endobj
+2372 0 obj <<
+/D [2366 0 R /FitH 393.042]
+>> endobj
+2365 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2376 0 obj <<
+/Length 1909      
+/Filter /FlateDecode
+>>
+stream
+xÚµXMsÛ8\12½ûWðHU\r1ø"@îeË\eÛ³;U\99Íت­J%s )ØfE"\15\8aÊ$þõÛ\8d\ 6dR¢\93x6{\ 2Øh4Ñ\ f¯\e\rðä>áÉ/gÿX\9eý|U$%+\8d4Éò.\11\863clb
\84´Ér\95¼K\85\94\8b?\96¿þ|eÕXµäL\95\16ìx¥Wÿ<\7f³¼¼^dJ©Ô²Efm\91^]\9f¿¾$ÑÅå«\7f_\¢\9d3\1eþ~¹<ûx& Ë\13ñôgc\99\95eRoÎÞýÁ\93\15\fþ\9apfáO\7fzÕM¢´bVàÄursöû\9c\17\86\19\9d'&·LjC\vü­Ú¸E&s\9b§Ë\85,Ò/[ø*R\90))tzÓ<:\]"¸`¥TI& Ís\9aü\9eçü¶\19
+¯¥
+V\0>c\9d\9bæ¾u«¿\83U­uzávußl\87¦k\11\0\9d\8a\90èÝnè\9b\1aGv\1e\8fy\1cTɬ:ÁA\97ÅKp@[EbdÁàÏ´Ì×ÿy+\17\99ÐB¤ÿj\11\88ÁÝ»~\91åFË4\87ÕËܤ¿u¾\ 3P= @*O?¡ªë\87¦®Ö$©»\rAص\8e\f\91¼»£v\88Sw®Î\bÚR2\ 1ë\99@ÛE\þ|èÖ.Û6\9fÝ\9a\10Ût\11=\15~_\ f]ϼ©lÖÖ\9bëË\vôÍØTBÇXë}´ÁG\9c\b\98        a¦ÓÎû¾ò\94ð\1a@}cóÉÖ\16Ç°\9cã²
+\ 3\ 3>0\84\1e¡\ eó­Õ1.Þs\1e¢g²3\10;BF\9d\82\8cU\87eøO\8f#´ÛÞ­\1aô\9c>?-`!Õzïv\ 4\84ÒÌòrêÐÐ\11\9d#(ïül\90\84MQi½ïûѶéôvÝùݬQöák(__Þ\80¦\ 2\18\bäbB¤\13\90Í,È\82\99R%c\ 5aÀª\0\8d·\8bBc\\8atç%ÖÃm\95\9d\85»´\f\epKÈ\a#´­\8ah[D\e\8e\9a¶iïéw\b\96\87AKVäGþ¬\M\80­\1c\10\18Â\15\ 3»Yí1<\8c*\br\14{ȱ3\86\1cÍò)¬ß¿\ 1¿¿>_\14
+ÒX& ×|\1dý0¥z\16ý|\84þ\94ãÀ\v^¤Fg¸\15ní6O|\ 1ù\98­¼$¶\82øã¾"­æ±òá\8bÿ\83\9c®ò#\8e\8ex\9cia\b/ì¸Ê#ð\80_yzñjIâ\80¶{Ï\85©\9bÃRp¨içðl«aßS²RiׯÜWSÇÅ+4\ f)p\9a\14\ 5Hd\19\16Qw»@S\9f\1aµà@\0r\1a\b³\10ióèáZÑ\18\9aÅöÙÕ\vDî49\ 6\92U´úï§Æ\e\98\9dñBاð:xaý.Cô÷Àæ\16Î¥}=¸\90\8f\ f\99\18³/ð\ 1÷\8a\85B\80\8f\82ë\98ÆÍiü\ 5F\86\0<]\9b2\81s\81|&\80\vCM»r\9f±ë\81ò¢!\8eMr\18jLq\8a\ 6\b^]2\9eËéZÇ\11<eÉ\91\8fó`oþ\92¯rÖW\95ëè+v}8AKù\1a´7UÝw$;ö\12e°{Ùó~\1e²Ú)\99f\9c\85ª\81ç*z0çcÁÌ\93Â,^\12\8c\14p
+Nؼ]¿\10/,Iæá\92\12}^cÎ\90\12¸º®Ú \r ¢\14ADÑp\98\ 1\84\81\10õgË(\11Ïb6\13sßE\8a\1eB\ÿ(7sQD\87rAI\16EC\1cëÝ\9d\83\10¨\1d\8dßõXä>ë\12X\82òÍ\a¸6ez\e\8e?ìSLA'\86\84§\8b\1cª0\10X\88\11úÄ4=\93l#=¿\87_¹a\92\1f \98\r"aXñ\r~åL\1cóëöóËqWó\99§\94éC×7\8f±*X\93l\8b       Þ§Eü\8a¹Éw±\15\87\92á\87RêöË\8fòËJ~TÉ[ MÈô8\b\0ùL\83è\19¶ÿ\17Ï>\ e\7f!#\88c×Î\91¡ez8\85céá¥Ãô²'\vt\12|\84­\83\ 6ý\eçHu\89'c\95}ÍM\8fA¸¬õ÷ u®\7f9KÞyîÃÊ'WÜçè;{Ø\7fløËÁxæääâ´\12\ 3)?p\96\87ó\14DC\9c\ 1ÅÊ·\8eÊi\ 1ó\82\8dn~\9ckå¬kå\93kep-¦5(KÏ\91\18/uoÇ\9e¿\9fË\2.åÿöNasf@ABºË\8d¤\95,\1f\1a¨Í\94ö÷æp\ 1Ö\ 6\a\1f·a\8cê\ 2èL¯!(ÙV!ó\82Çn\bZÕPQ\8f\9e\ 3wé-\7fÓüÔtûÝúK´\8dgY\v\86©àÔ¬Ôz\8aÛ¶\ f\81ïVûÞ\97òÜøë'¶£¢\92\ 4¾´·¾´\87¯\93j\8d\9b°q&n\9c9Ôx6\r\19\a\91k\8cJ¯ð¦èï\rÜÒ\16\ 1¿É¼Mý/?ì~\9a\0\14\r1?ºbã'n\0¶pÖm¼5èï\17þ:*(yÜ\93\90V   \9dé©     \82\14ú¬|Zý       \88-ÁÂ]\10nñ8YC\1e\86¼\12Æ\ e\16ÃãÇÌ\9a\9f\9eB`\8e\12ñe\89ØÞ\1ez8ÆGwR\14{fñÒ?Ýì©ÐçX5t\9bñ´i\80ù³ húË\18\19x6\\8e\97{\85I\95îv2Ý·c¶¢dJ\ 2Ø¥L«XâÃp¼\96\a
+ìHêY"&jY´\13ê\9b\13Ó(\ 3ÌûÃ\8cm\13\15        \80hpìC,\C``      ¤C\95\ 5]ÚW/£\95X5\ 2\1cÅM\98\1düyE*><@øèú\ e\88\\18ÿÌÖ\1e\19\1asÒÒ&Ï ;Ú_mÈ;\1få+\0\18é¡Ë\18ñæ)gÀ¤ýz a½®Â3\9e\8bjÝQZè«ö>tÃ\ 1\ 59ë)\8bÉ\3È©1\8fÿ\røb,5\ 6\9aÓÚN1Y\1cn\ f\90àÃÚcbÚ\81Ïq-áò\ 6å\9e\8b£[Íñ[\96¥·,\15s\ 4\90´$3¥>\1c5\99,\ 3}°³\v\bÔ\r")¡\8e«\91õÕÎEE\bÔj \8f\8a\9acv¡lô\88´#I×b2\1dMóï\f^u&\82pÇâ\81\8cJñe\ 1\ 31\9b\14\16£7ôÿ\ 2       \81æ¶
+endstream
+endobj
+2375 0 obj <<
+/Type /Page
+/Contents 2376 0 R
+/Resources 2374 0 R
+/MediaBox [0 0 612 792]
+/Parent 2321 0 R
+/Annots [ 2364 0 R ]
+>> endobj
+2364 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [367.891 300.961 382.613 313.459]
+/Subtype /Link
+/A << /S /GoTo /D (table.3.1) >>
+>> endobj
+2377 0 obj <<
+/D [2375 0 R /FitH 686.127]
+>> endobj
+2374 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2384 0 obj <<
+/Length 2268      
+/Filter /FlateDecode
+>>
+stream
+xÚ­YKsã6\12¾ûWèHU\8d\83\0\99\9b\9f\89·6¶ck\93Myæ@I\90Å\1a\8aô\90\94'\99_¿Ýh\90\12)Ú²2{\ 2Ø\0\1a\8d¯\1fè\ 6\83ÑÓ(\18ý|r6=ùx¥Å(öcÅÕhº\1c±@ù\91\8aG*R>ãz4]\8c\1e=íÇþx¢uäÝ_\9eßÞ<LïÇ<òþs>½¾½\19\7f\9eþëãU´ÃBðÈ×JÃ\ 6v1ã\ 2ç\9c\ 4nÏѤ\990áÀX \9aö=©Ó"\1fO\84\f¼$_@GÄ^\9a\8f¹ö^p7SV\86F/Χ4Z\97I^-\8brMô´¢¶ú\92>?\8f'¸f\ 1bK%¼ë¼ªM² ñzå\18Í\v '9r¯\89ò\9cþe2bþ2\ eC/É6\ 6\85\aÁ'\8cùq\18\92°°)0\ e\92\81ò a\1e±JKG\9be\85\15c\8eä/´\0\85Äv^¬\9f7µY8jN+\8aÜ\10\ 1Ä}\ 6Ù\95
\9b¢6ÍfIÝÛ¶.7ùÜ!\87\ 3Ųa8\19\92»6åÚ,Ò\ 49
+Pgáp*-\8b\8a\88\16G\1d{Å:­­\84H$\95@\87Ð\83Χ\80É<ÉhnYl`\ 2\83}\9f\88\90:fU\96>­,,ÙßDY¤°R\98ÒXÝÖnÏ|PÜ\15²á±ðæIeP\97\82yS\14ÀÒ\90íÊ4è"Éê\ 5;ßV\ 6\ 4u\1f\r1/jêÔ\r\8b¾\86\82Ô\98¤¹Û¼ÈQvì%Ô\\9ccËa\19(\1d9hÏÀ¡Ô<m\ e5p\18\8bH\14x38Ê\82ºÖÞ£Æ"\ 1µ9\89ÓcÖ\ e1o3¶VÖRKkw5P7eÞ°]\96Åz\971v\8a\89Ü\86\vãvZ¸ñç\92\8e17\8bMéh`K\ 3Çx0sknèÒ\f\ 6\83Qù4¢Î=8÷ãDÄ\1a\ 2\86îúü£÷\ 1´Ç\84³#\98b\95\81\9d\19
+ö7õçx´\15\9cÆ\1e\8b´B&\ 5\83uAme\fuÒ¥\eX9BiÖ µvÁ>\9aäè±ÞzwEßIÙõså\82\92)\v4;μӬBvÊ\9a\91¡\1e9$öÌK\ 3/~\81õåÍ\f\15YhhÓ¨\94+\ e®°HÁ¥Q²\ e\87=[UÎVµ³Õ\ 1e¡üp@\16\ fï_\81R\ 4ç\ e@\98\85\86ýêl\1a²f\fmU§YFÝ­ñ Ö*0oË\97y\89\9b\v±¡ ­ììñ\B$jm©/ùº       \e\18\8d¥·Jð\83@F\8aðÖ\89µ]\18Kk¢äE>!\85!?&ýXÊ.ÓÓe\8d1AÚ#ÛHÌ\85\93>r¦\8ff*¥\v°0º,\93µ¡%Í\ 2\fÝ\99©\r\ 6\ 5¤\97\86â@\ ev[Yw,Ñ\1fçµ\85\ 3£¢e\1az³MM\1cf\142 Z¹]R\8a\18\93!¡ç  ÚR¤\9bUô±±A\84\82\8c\94\84\9aÒ,1¶Î\r\8dZù?`¸RÍ\8c\8c´E±_Û8\9eY\pþ\1aíiSÕô5#3 \ f¸jhE±ÕEI\94Ôͯ\vú^\99ìÙ-\ 2\83¾Õµg2\ fÐbRÖé2\99×\95O M­¢p¤i\17\ 6ì=³Á\ eµ\9f\13õp\\82IÚgA?0ù]\ 2ã>Ó\98\9b0\1f\80q)LoÎã$\f\ 2ï´ªÒ§\9cò\1f\1dì$@RúJ©&ÿù\9a\ 6û9\12Ó¾\fX3\85ü\ fäë$\1d\1f¯d¼Ë\95ûQ\1c6K~»~\18à\1aû\82µ\e?\ 6\9f{rO\18\97\11tb?l2/>xº«qD7'Êe\12ºl    r\90R\91\94v\90î\89\1e\ 6q\0P·¢ÌÒ\ 1\16´lf¸;\vØ\ 5´\89\8döðù)\b\83!4 u\fÚÕ7g\ e\rÐØv\ e\ f}µEìS\10\f("¶\19h\93ªÂfì§>f
+²U8
+a&\efa\90àìã\f\95l\13ãçl\b\95Ð\ fÄ\9e\9d`þ"\0ÃCR;6/2R\93ô\9e!ÖdIîâbïÂØ\17\87\81<ZÊ÷+É\85\83¬È\9f\9c/ÖEßÄ8W\10ÃÐÄB?Ôñ\16®Ù\ 1¸lFuö_lY\93¡qoU\94é÷&#Ë\88æ²t\9cç\80A*\ 2\83­[Ê0ÎÁªo\18ÐL9É̲&ú¼\80T©ì.\9a¹ h\13\90A¬"\9f«°\e\99\87\0\8b|\15¶úÛÃ&ô#Æö¡\99\1f\82F@Òyö'fPM\ 2\1e\8b&\ 2×\90-dDiÊ\97xk1± \8bi²^ì´ÀD[`\84Í|   \98ÝE\87\81\81\98\1aF?
+\fØ\f\e°\99ÅkÀ\/\ab\ 2\94\95\9c·îuv~{qy±/H\b\91Ið6H\ e\1c\89ï\96¯\aÏòy÷v\92m\16Ò\ f#JøÒ\1d0r\ 5Á\91·
+÷eØʽ\1e\92\8bÃÑ8;*z¬\93¹M\11ÛxѪÚ\ 5\97\18joè\83q\85\apÖ-ÄÇ[\83\86Û\91\15V\13\84Ö0\Ã\86 |.ÛËç׳_Á\12\ 6®KÅ|\16éC\96\10½ 9S~ô\8a%°í\ 5v}3½?E[þà\92\9c×\94Ì\82\0¶lUøµ\1e¾"x$ßÈ\1dè\1aÝ\ fÌ\90@0ÑGu\18Ö[¬\9e¿¥\959$p\1cú"æÿ\ayÙ^®Â\ 2`\1d÷ä}ñ\8f½q\99lá,1×\1d\140\8cÂ\8e\80RëÝ4\a?íÓ
+>\80À%KS"ï~\9b\14È\99¤ç
+\ 6ø¼&¿Ã\89pIc龦W¢\86\9fÍùe\ 4\81\93w\ 3è\14\93¯d\96\99Cé¬T}8ÈkËÒTô¶S@9Ùx.äTûÎ\829¡Úf\ 1?è-úýÞ²g pÇÊ ì*üåM¯ïn\ f^\1fªCº\96\10\9aâf\92uU¨¹1`£¥«¸y\98#úÝ=Ü ¶·©\bEÕTË
++Ç1=ÿDÛw\13\18\7fJ_lÎ\91ÓgêZ(PèMn\82\80GQ·\1azOí\ 2¶| xÁûEké t¬_\ e¸xï¦ÂÒ¤çu§þ\9by\eÔË÷\97Ww\1fèýâþî\ f°ré¹Oûàc§ÜýB\1dJФì<Âà·\ 5ν¢Hªì°}\873à4íë°w\12\b\vó\e\9eA\9e³)w\1e&)Jmk\1d9\ë0,Fä;,\8fmïo\84e\80\13\14p\9a¿] 0¨F¢á«³ß^NO¾:À\18ø^èKÈ>9H\eÅr4_\9f<~\ eF\v\18\84ÚÜ×±\1e}³S×#Ìá\15ÇM²ÑÃÉoî7A7ëc¾\0\eæB[¦;\a\aË Ä°ìRA
+ÓFc´\99ñ\ 4ò=I6\ 3\82ÅÖJðHâ\væGª/¹\8c£·%ï\16Þ\12jd\ 1\13aaØÔ÷ t$\987Xh
+?ä­n! ü\ erC*Î\ 3\15\80´\7f¢±s¦°ûËþ\89'ny'º7Û±÷n7\16Ü;?Cd\19ú×¹Ý\13|\aºÇîÉ\8fÚó\1e7RÑ?Ü\93¿\eÖ\9foÿ}A°²8æǪºÛ±÷n×ÂJáéG\8eÈ\8fÚÓÂ\1a\ 4C{\ e\e>\v%Ôáú\18\9f\rv\7fñE½ª\1fÄg\ 2\ 2<\13ý|Ã]5:ü\89\1eBw2\1c\8c\7fwø¼àj\7f÷\97Nx\ féwãrÞeóbtÙ¼\18\rÜÓpµ0¦ß\13.Å?\b\97¯FÃ\9d¨ø?.Ë\ 6h
+endstream
+endobj
+2383 0 obj <<
+/Type /Page
+/Contents 2384 0 R
+/Resources 2382 0 R
+/MediaBox [0 0 612 792]
+/Parent 2399 0 R
+/Annots [ 2373 0 R 2378 0 R 2379 0 R 2380 0 R 2381 0 R ]
+>> endobj
+2373 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [141.377 595.455 156.1 606.303]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.7) >>
+>> endobj
+2378 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [305.32 523.724 325.024 534.572]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.10) >>
+>> endobj
+2379 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [198.725 323.548 218.429 335.503]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.46) >>
+>> endobj
+2380 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [191.806 300.316 214.278 308.962]
+/Subtype /Link
+/A << /S /GoTo /D (section*.96) >>
+>> endobj
+2381 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [431.873 270.845 451.577 281.693]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.75) >>
+>> endobj
+2385 0 obj <<
+/D [2383 0 R /FitH 686.127]
+>> endobj
+2386 0 obj <<
+/D [2383 0 R /FitH 519.466]
+>> endobj
+2387 0 obj <<
+/D [2383 0 R /FitH 499.349]
+>> endobj
+2388 0 obj <<
+/D [2383 0 R /FitH 477.792]
+>> endobj
+2389 0 obj <<
+/D [2383 0 R /FitH 462.213]
+>> endobj
+2390 0 obj <<
+/D [2383 0 R /FitH 437.17]
+>> endobj
+2391 0 obj <<
+/D [2383 0 R /FitH 409.636]
+>> endobj
+2392 0 obj <<
+/D [2383 0 R /FitH 389.755]
+>> endobj
+2393 0 obj <<
+/D [2383 0 R /FitH 376.542]
+>> endobj
+2394 0 obj <<
+/D [2383 0 R /FitH 362.221]
+>> endobj
+2395 0 obj <<
+/D [2383 0 R /FitH 349.008]
+>> endobj
+2396 0 obj <<
+/D [2383 0 R /FitH 322.732]
+>> endobj
+2397 0 obj <<
+/D [2383 0 R /FitH 299.501]
+>> endobj
+2398 0 obj <<
+/D [2383 0 R /FitH 285.734]
+>> endobj
+654 0 obj <<
+/D [2383 0 R /FitH 145.668]
+>> endobj
+2382 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2409 0 obj <<
+/Length 1808      
+/Filter /FlateDecode
+>>
+stream
+xÚíZ[S\e7\14~çWìãz\9aUt×*\ f\99\ 1c7tJ\ 2ÆM\93\12\1e\f^`3Ä6¾¤¡¿¾GÒÞ-ÛËÔÓé%Oºìñѹ\9fO\ 2\1cÜ\ 58øñàhxð²\1f\a\1aiIe0¼\r\88ÄHJ\15ÈX"BU0\1c\a\97!¡¼s5üée_±*©Æ\88i\ 5|,Q÷ÍáÙ°7èD\8c±P¡N¤T\1cö\a\87§=·uÜë¾;î\19>\a8;=\1fë"D\84R\14\13\12DTÁ&sì\8fPí§Áe$0\ e\ f\17\8bônâ\ e8}ÿÁLx¸¼OÜÎ×\8e\90áèa\958é      ¯\9c"0\8a)\833\b¢Z¸3®?;B®+\84
+\11ø\9e)yú¾×\1d^8ªªÌ\#©xNu\99Y\vW((R2Π ®Óu\161\92\82å\ 4W\99Ä8\90H+\16ç\1c\14X\a\1dÕ7\9f^\b\13\19T\88>ßt"Jiø       c¶~*\91HâB=cÌOX`\8f\19ÀN8V­ì vÙAýe;Ä>;ÄÛÌ\0j\91\8c\19©Ð1\14\97~{U\v±FTR¦\10\1e\16\11&B·\8cJ\82H\1cï5*ÿvo<yôâH\81Zÿ¯¨|ò\b\ 2fÐ{\8fJ)\e\11sܦVÒç\14K\82\98RõCÆÿ\96b)Ú\14Ë\8cèsòß\rKÑ¢X\8a=\86%\96¼\1e1½6Å\92\87+\95÷p¹\97°ü\87VËä{µÜOXJ$$©\87\e\96\10\7f\94\12l\9f<®F\ f\8bb\93ºÙh2v\9f]\9fç²A÷\91¾0S\1e®\16\89#t\91\r\1f³È\8eÌé\ 1á\88\82É"B\90\16\99\ 4ØPAÃA¯\7f\ 6\8cÃÁÙ¯\9d\88ðÐ.5,ßd\1f\8e\93\8fæG9\ 1H\9aí[I\r7+iN\11\877Ó/³ÕÒ¦\17è_\13àlÐ;vY¸Z¤\93;7Í2\93\87³ù\148\0\83\9agÙz\97~íÀV\92ås:q¤\17ÉÍ2\9d\9d        \9c\82\83ù]à&\ 3kqwgÐ\884\\116|\13\11\ 1\ e4\85\9dYønÅüÑëÀw èü÷t\91\80\9eB\91pÕ!!Ø\93\84 ª \99\1efRT\98\85[gÖ6¿qÖfa±|cgØYÛl\15Ö¶NÌ\85«ØÐ9\80S]µ»[~0±Á\19v®á\ 4gõÏÌ\96S7æÞ±\vç\ f3sþ¨º,+\7fEÝÜè\1dÕð\ eÛ£w\98p\10¹ê\9d¯iº)Á<\15*F¢,eo»ïzý¾§D      \8e\88PûD\10Π\v\17®\ fÉb\91\aû(3\12}ÕÐU\19\1dE]×C¯¦¿äÎj(Ë\19¢´Ðâ°Ãhؽè\1eþÜó*ÌXAúÂÃLBi×9Áñ\16>*ÞŦ 8:õØ\9e
+¸õ\93Ö<Þ\9e\ f<L\18E\82me\ 2%\9a! ©%\13ð:ù­çëY1\8a1Ý.\14\89\v\7f\9f\ f\8eNO|l C1Ñ`S\8b+æ8çqé   ,#¯d­yÌ\1eü<\14Ö%\ fh,ÌV      O \v$iAú\98b\ f7\ e\ e!\r\1fq\92U\f\98Ì @Ö\8b\86©/\11\86\8e¨Ôy
+cjGµ»\92\18"\89 \98\9byb¸\98\9ag\b\8a\9ag7ï\13·{Üu#´×\899{\99þ1²\87Y²/£å<ýækbç§\87\9d\98\85õNÂ!dd\96¿¼í#\93\91b3>\r\84\0¤Ùx#Ø\0Æj¨eS¡ã\86\1fm\14º\98=\a\8bÁL\15ñqu\89¯<\80\13\1a\17/_òü(Ó`hY$PfTÃÎ"Ó\1fÜ@Ä\ 6\8c¦0Ü1\8aÌzýÚ\13¥1¢² \10\1e\1e\1cé2\8cwà<\86\bfmÞj\86F\8fùjr32\11Ç\94p.\86q   ù0uÓ\91\e\88\8c®Ó¥\9b\9b\90HÆn>Ofód\91¸°Ì\82Òì_\9b\8d'7\1fϧ³YÞ´!ö4çõ8uQýä¢ê>½\ 3ô\12Mçãdî\ 2\ e\ e^xÀ\10\13\8dvë¿û÷\8d\96SÃJà0\19Ý\98£îÝ
+\ 2\0¶Ëé­§Èh\868.Û©\a«\83\bªì
+·óé\17Ç\ e»Á¤6\13$T¦ú\b\9eÁæ\86\92L\9be!Ìh]\86ü7¯0±f5al)£\1c.@ºnv\9c5ú©3³\15\10Ö£JÎ\ fz\17>\88\11\e£è­FÁ\88\95]éÊÇ\ 4\10cÙp¼º`8\857\80J\81Á«\ 6³Õi½Ê)°E£Ì\ 1$K·cæ\ 6Ø¡\fávX'«\95ë\8a\82\1c\15Èö¸¡q\96\15±Z`Eå\ 1 \8e ((WüäÜ×Ò\89\ 6\14Ñ\84\8auÌY­ ç'ær\16ú8\81\11*\95t\ f ój=\9f5Ä'¯Ûùèy\98Òüé\84\94ûÂ\94l\a¦l\a\ e8X\8a½\19RÒ]<\9e\85(·³Ø\f#«(\92Å\9b1©`r[®×\12Áò\ 2Øg.ç\ 6úAßµ½\18ö\8eÏ»\19
\14ðGÜx Ùø*¡*÷^î\7f\95°÷^s¤éó;®¿Ü^\7féÎÇ\89¼­WÒ·»%}#ª\99\18\0\93
+îÕ¶é\98  Í\954{\ e\vëõ˽٫Brí\944#(\19­c\8eüµ Õµ\9fíÒ[@á³í\ 1î"\90Æ\ 5êMr0غÏ\bD\15­3J\9fÙg(â¢È\95ù'L¸7\94IIäi5vIÖô\ 4[(R÷oºU¾\88\13\9e?(q\ 3%Êç;ÎxþðÃÍË\92\99d.6;ÕW)³®¸×,Ól\ 4ø
+l®\1f\92Ín4d
+)Q\17\13t qãÁñf:\a\1c;³¡5\9d\8cËä\9aºñf\ 5ß'æ iÙ¼üØ$ñã5èü\9aËgyÄ_VL+W-.ÎE\91BÞÿ6è\r\ fþ\ 4°7°\ e
+endstream
+endobj
+2408 0 obj <<
+/Type /Page
+/Contents 2409 0 R
+/Resources 2407 0 R
+/MediaBox [0 0 612 792]
+/Parent 2399 0 R
+/Annots [ 2400 0 R 2401 0 R 2402 0 R 2403 0 R 2404 0 R 2405 0 R ]
+>> endobj
+2400 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [435.891 460.959 458.363 471.808]
+/Subtype /Link
+/A << /S /GoTo /D (section*.100) >>
+>> endobj
+2401 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [377.997 423.226 400.469 434.074]
+/Subtype /Link
+/A << /S /GoTo /D (section*.104) >>
+>> endobj
+2402 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [311.403 371.669 333.874 382.518]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.3) >>
+>> endobj
+2403 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [404.066 200.187 426.537 211.036]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.2) >>
+>> endobj
+2404 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [262.541 176.346 285.012 184.992]
+/Subtype /Link
+/A << /S /GoTo /D (section*.115) >>
+>> endobj
+2405 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [485.671 129.204 505.375 140.052]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.75) >>
+>> endobj
+2410 0 obj <<
+/D [2408 0 R /FitH 686.127]
+>> endobj
+2411 0 obj <<
+/D [2408 0 R /FitH 668.127]
+>> endobj
+2412 0 obj <<
+/D [2408 0 R /FitH 625.039]
+>> endobj
+2413 0 obj <<
+/D [2408 0 R /FitH 582.089]
+>> endobj
+2414 0 obj <<
+/D [2408 0 R /FitH 539.858]
+>> endobj
+2415 0 obj <<
+/D [2408 0 R /FitH 496.908]
+>> endobj
+2416 0 obj <<
+/D [2408 0 R /FitH 460.088]
+>> endobj
+2417 0 obj <<
+/D [2408 0 R /FitH 422.354]
+>> endobj
+2418 0 obj <<
+/D [2408 0 R /FitH 407.978]
+>> endobj
+2419 0 obj <<
+/D [2408 0 R /FitH 358.842]
+>> endobj
+2420 0 obj <<
+/D [2408 0 R /FitH 315.699]
+>> endobj
+2421 0 obj <<
+/D [2408 0 R /FitH 290.474]
+>> endobj
+2422 0 obj <<
+/D [2408 0 R /FitH 264.142]
+>> endobj
+2423 0 obj <<
+/D [2408 0 R /FitH 252.809]
+>> endobj
+2424 0 obj <<
+/D [2408 0 R /FitH 236.496]
+>> endobj
+2425 0 obj <<
+/D [2408 0 R /FitH 199.316]
+>> endobj
+2426 0 obj <<
+/D [2408 0 R /FitH 175.474]
+>> endobj
+2427 0 obj <<
+/D [2408 0 R /FitH 155.425]
+>> endobj
+2428 0 obj <<
+/D [2408 0 R /FitH 142.155]
+>> endobj
+2407 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F14 574 0 R /F49 457 0 R /F70 508 0 R /F10 668 0 R /F11 573 0 R /F83 1265 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2432 0 obj <<
+/Length 1187      
+/Filter /FlateDecode
+>>
+stream
+xÚ½WÛrÛ6\10}÷Wð\11\9a\86\97¼Õ\8d\95ºãÔª¢¶Î8y\90eJæT\12\15Rr\9b¿ï\82 i\92\82%Ûíd<c\ 2\10°8»gw±K¢ED¢÷'g\93\93Ó¡æ\91ÅV1\15\11%
+\ee#e\14¦LG\93»è\ 6iL \1eÄZ\etyu5\1aÄ\9cs4¼¸\1c\18\8e&çã\8b\ f¾L~9\1d\9a\96 Î\fÖJÃ5¥\bʤÛsBª\9bëo\143m1WÜ\rà0÷ÛÓ4Å\9dýÑM,   A?\16EºX{\0\1fþ¸v\ 3\81¶÷\89_y\18H\85¦Ë]â×IO\ 4ÁLë(¦\ 2+Zßóð\8ck>Á@Úg_ÃJ½;×\84où½H×\8b\14ñ²Ý \91]¸9Eãó\ 1EÃÑ\e\98i\89Æ£?\a \18\9fË\91@g×ÕÒ\19\80e²Þ\0&ª6L×wþ\82R\9dr\a \8a\84\14[)=ØY¶Úì¶\ e\8fUh4>\7fçG»
+­Õ\15ZXÛä\19\f\f\9a%w»¼Z[¤\ f\ 3XJÖ~\9a®ý\99\8fÉl\9bfëÒ\ e\14¬@¢|\11ùÁ¸´\88Û\f\1e\80iÏT\b<Op\86&÷iQb&]¸©³\94\15¨HW\9bå77\96\97fÙÆA©\16³¹_­ÐKø9^:ü\1aͦÛäÎ/Þ.+\95ÜÉ¿ü     ¯Cëä&O\1eÒlWÝ\9c'ó$OÖ³$\ 4o\9eOWI\8fþ\98J¬µèùHØã\87.Ȳ\1c\\8d)\94LKX÷~ÖöC\98\82~e\14
+CË \9cë ¼ý¶\1f§à\ 1\0\95Ô`³\95\17Füg\9bù¯~ã¾Æ»Ñë\90Pα ÍU·ÿ\ 4±(É\ e\81q\ 6\8e\19×XYÞµs\89\10\82\84®\80àùx\13\18\9c\1e4
\9c4;¾\84\84H,ùae\b¨+\1a\19\1e]\95CD7\87ð½\1c\12S&0È\8f©\86¤E½\8cÏD\12ðaÈÂ0¢O8\8bðÎ\ 2W´(òIK¶.\f;\vÇ\96É#Þ¢\18ï1äðW\998óÓ\86\8cÒ]^\85Ź\8bÕG¼E3y\1cËÛ\9ei\19'X\9a®i\8f¿6£Ão\8dãÆåÊ\9b *p¡\15ßÝá\18\aÿy"\12 \90¸úθ\9cïö½\9d1\8e\19a½·9LÊżC\88KÿnºÈ\13Hây\1dfÓ*\ 50)÷\12C\8bLx\C\ 1Y\9eÛ\ 3¹ÿ®§ÏÄ\b×\14~¸L\8a¢\8f\91¼
+áë«\9b\8bP¼1x\92x\13o\9be\1a RbÂl½%ùº\9b.+]¼\ 6¢Ö <)lë¨& ½ñ\92ñùO\9f\ 2\15#Ç\4Ùÿ¦¬d\84\ 6\ f\ e\80µ\10úì¨ã²GÇ=»®ã!\10\ 5\f3ñ¿¥òѾs\v¬\85xNEx\ 5Bó¿Ó")\9f[p\9c\10S\9abóHC\98)\81-\95{L\81þ´\92|\88)AE\8b©³Pm\8f¥\10]¦@æ\13L1õ¢Ôç\98¢Ö\86\99¢X\eö2ª@iG\95¯\1c¤ÁB¨nåÐ\8b«Ñ\7f(ÖZü\ 5Ê\ e\89¹\11ÇxS\9aõycÖ æx#Påf~þ$\7f\86\ 2Ê\16}ã }Öè\ e}T«0}\ 63Ë_L\9f¤aú\b6\94¾ì\r«Ú\8d\86>eÌ3è\ 3£\18gM.\14src0¾\80\131WXhùØÖ\ 2XhMÑ¥+\16(\82~!æÐ7\rÓ%¼%®ß      õ¬õ÷|Ru2´¬V\18\14#TBÕbm4[\9d|m~tÿC\v§\17+ª£wÙÉoðW\v­÷ĵȸ%³ì×;ö2®´à\11e\fSj½^ÃtQvceõ\83ù[è\9f\84\84þ©Zª\1a\9cRW\98~&T,\9b\973O\8a\8dÿy]T\16\9dÃ\13´[\97Ý\e>h\8f\96\ 5\f)ÕD
+endstream
+endobj
+2431 0 obj <<
+/Type /Page
+/Contents 2432 0 R
+/Resources 2430 0 R
+/MediaBox [0 0 612 792]
+/Parent 2399 0 R
+/Annots [ 2406 0 R ]
+>> endobj
+2429 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./lflim.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 2445 0 R
+/BBox [0 0 291 218]
+/Resources <<
+/ProcSet [ /PDF /Text ]
+/ExtGState <<
+/R7 2446 0 R
+>>/Font << /R8 2447 0 R>>
+>>
+/Length 2448 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9c\9dRMk\ 2A\f½çWä¨âN'3;_×B)\94½h\17zPO\8aÚ²[°=ôï7óa]­\85"\v;ɼ$ïñ2\a\94\82PƯ\9cë\1eîæ\ ew\9fp\0\89\8a¼Ä\1e\81
+4\b\12ÔÁ\1e\94'\125\92´\81KU\90*Ç]\89I\9a\18\97ªë\99×i\82w\ 3,ÏØÃË\ 4ßa\81\ 1\95ÃUüm \16\ 6¿\92*\89óG \9d{\99Ý\a}\9có\f3.Ù]ê»Êu®*3o'\97<·NÚ³\96ÿºIµ#TÒ\enïKFÎ2Fµ6çq®ú\9d\19ÍuÆ\95ì4ï\ f7S\83Kl©Ó\1eÝ»Ôr>÷\9csÈÂÎÝÚ\1a­
+ìùi¥Úýl4ð­©cD!îÙªä¼Ñú´\85áþóâ>vl>å¸\1cë\1eï[~ç\9e/\84Çv\vùñG!ÂÊÀ÷¤\85¶\87ÑrT©f*\97ãqû\ 6F\v\19\15T\8eÁM\ 2\9biÕdÐYAÚ\98¨+\81ݶ{í# \9d\b\86\81JÛÒÕLK\8f!áC°Ç\81\vÆ
+[EJ[Q«Ñ|¼j\9fà¡å\85Ìà\e¹5»\9b
+endstream
+endobj
+2445 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115428-07'00')
+/ModDate (D:20090924115428-07'00')
+/Title (lflim.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+2446 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+2447 0 obj
+<<
+/BaseFont /IDVWIJ#2BTimes-Roman
+/FontDescriptor 2449 0 R
+/Type /Font
+/FirstChar 40
+/LastChar 109
+/Widths [ 333 333 0 0 250 564 0 0 500 0 500 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 611 0 0 0 0 0 667 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 333 0 0 278 0 0 278 778]
+/Encoding 2450 0 R
+/Subtype /Type1
+>>
+endobj
+2448 0 obj
+358
+endobj
+2449 0 obj
+<<
+/Type /FontDescriptor
+/FontName /IDVWIJ#2BTimes-Roman
+/FontBBox [ 0 -177 775 683]
+/Flags 131104
+/Ascent 683
+/CapHeight 662
+/Descent -177
+/ItalicAngle 0
+/StemV 116
+/MissingWidth 500
+/XHeight 460
+/CharSet (/L/R/comma/f/i/l/m/minus/parenleft/parenright/two/zero)
+/FontFile3 2451 0 R
+>>
+endobj
+2450 0 obj
+<<
+/Type /Encoding
+/BaseEncoding /WinAnsiEncoding
+/Differences [ 45/minus]
+>>
+endobj
+2451 0 obj
+<<
+/Filter /FlateDecode
+/Subtype /Type1C
+/Length 1322
+>>
+stream
+x\9ce\92mLSW\18ÇïåBïE¡Nº\ 6\98B¯s\13\892QÇ,sSÇÛt©LÊ«a\b\96¶´µ\ 5\v\94RDÔyZ\ 6­@­ô\ 2Õ\ 2\15V\10\1dCÉ4q\12e\89ÄiD\9dqØmY¶8çpfç6\97\ f\96}XrrrÎy\9eó{þÿó\1c\14   \ fCP\14\8d*\90«Äº\14¡Z%ª\ eí×Ó+Pze\18\9d\80\ 1&;p*°="\ 1\11¸°h\10\85\81¨ð¾\95\11Â\18\1cÚ\96Áï \18\8a\1alg2Õ\9aº\ 3r©LO®-\14\16'¯[·þ¿\93\8dééédeÝ¿\112K¬\93K«É5ÁE­X©Ö¨ÄÕú­df0[©\94ï'¥Ê:\8dLG\8aªªÄU¡kE"¥XAæÈ\95r\8dF]K®ÍL&7¥¦nL      Ni¹rUe\8d\8e\9cÌU§\93\ 2R(\96Ö(E\aþ\1fA\10$J \11Ê\95ªµ)ÉëS7!H
+ò!²\19ù\bÙ\8dä"\91È\0²\ 4\89F\96#\1c$:ø*H8²\17\99@w \14ú0\f\84Ý
+óck0   v=<\81>Ʀ! \fãô\1fTÌï\v±\1c\rý-ÌàÖ\8b\eõÆzYUA\1d\1f\10;Y\19¦\ e\1f\8fVáàöÉ\93ßµ\13\14ã3àw[\1d\8d \9b\83sÚAv£1ã\bÁÙc }ø\14Ì\88`C?pÒIÃP4\88>\9fÇà\f]Äe\96A\825M\9d=×w²¹Ú\95xJÛÝÜ\ 3\b7år\8f\96{>Þ]¤)Óò´å-Òã[\89tÅ#f\96\ 52ÌM\99G #t8ñô6s\17\98#à,dãìÀ\ 6@ÑÏÇ\fTÌÂ\ 24A4\96s?\90DqÅm\a;«?g*aGܬÃÛ=20졾\0\97À\84iL;$¾À÷¤\0\82\19bq&\rø\K§\19d\11\8bÙ8à77íh%\fÐKáÛÚM\ ep\87\80{ñ¯­ð\10s#\ 2¦±8%\8b¥´\9f;Øe?\ f\97OW¤ì­\15I\r\89eZYëºO     6<\e´¹Ôéë\85Ñ\v1\ f\16Þ\99\8få¼\80\99t\ 5\97ÙP\10aÄí\96n«Ãr\ 2Ä\9f>ÑPÎc\8c8Èl6ç\84,5;ñ]í-\9d¡j\10çÐ%°\96«ÑëÕê~ýà\90»\7fhPï®æ½¤£Oç1*\80q;X]\96n\8b\1d\10Ã\9d\8d\9fð\16µ8(l4  \8e\ 4Qf'.ø¬©\13\%è_ñ£ÖâzqsN}<;@\ 5¥%\AýóP\10\1a\18E¿Îu´Ù-]\80ð\9ch(å1\1d!\861ÿx\90\89\17Y\8d]`\9c\80>\1c\9d\19÷D\8f\ f\10_ö˲yL°õùf³0¤\ïÄ\85\16c\ f\98!`;î\9d\18q]\ 4Ä5\97\86Ïc¤8\10¶´ä\1d\ e\9d¸Öª²\9a\`<\1eVâpIÕõmy%Ú¼Âĺkò\81BP\ eÔ\8d|\ 11\87\1f\96\18äæ\ 2c|ðÇ\ 4ÞèE§ü\18\9c
+ð¹\1f\94ª´\92²¬·eI\80\89\ 4\fg,ùÇ7/\94zj®(ºOÅmýFíÓÌéfÍ÷À3ðÂñh`fpÆ;zg\9a`Ó7 æ&J\9f\85\1aîÍEË.ü\1f*,õcç\98lîÝ)¯gìâí\1f\0\8c\ 4ðUÉo\9b\17*§´ýÅÃM\rq\ f\ 5\ 3²Á\1d§wvm\aI`µ\89¯ÉU\vTÒ̼`\97ÛZ{\eþ\8c\81©ã±\9c\8aï\99UÜÙ\91É\eà:ñ\95l|\9f\97'rú\14nÃh\87ÍbéHäTXm\0XVØ;Z[\14jI¡\84Ǧ\8f5z\ 21\1eôô\13èx\82A[Ð_\ 1\10ÕKdyùb\ 6\7fi\10\1da"/å\8f\95_ÖM\83Ë`¢gÔ7}õ\1c$\0\8c& (\15®bb\13\8fi¹ó\93L\ 4#fÄådZZù_°
+Ê&!æ\ f\15\0÷h÷]\14þìÇh5Là\9aÚ%BÓ¡} \9eiaÁ÷`ÖO¿\8cß\ 3\ fâ\9f½{\7fuAqÍ~I¢BnTÔgõ\1d\89;ÿttø\16 æ¯  ·¼_öÖ\96M<&\87É\8bh¢_ÃÙ\a{é¢^XÐËò.y¼Ôk\8f\8a\8a\8aF\90¿\ 1~\90nW
+endstream
+endobj
+2406 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [402.606 614.05 425.077 624.898]
+/Subtype /Link
+/A << /S /GoTo /D (section*.100) >>
+>> endobj
+2433 0 obj <<
+/D [2431 0 R /FitH 686.127]
+>> endobj
+2434 0 obj <<
+/D [2431 0 R /FitH 668.127]
+>> endobj
+2435 0 obj <<
+/D [2431 0 R /FitH 653.569]
+>> endobj
+2436 0 obj <<
+/D [2431 0 R /FitH 638.956]
+>> endobj
+2437 0 obj <<
+/D [2431 0 R /FitH 590.415]
+>> endobj
+2438 0 obj <<
+/D [2431 0 R /FitH 561.356]
+>> endobj
+2439 0 obj <<
+/D [2431 0 R /FitH 541.428]
+>> endobj
+2440 0 obj <<
+/D [2431 0 R /FitH 526.815]
+>> endobj
+2441 0 obj <<
+/D [2431 0 R /FitH 512.755]
+>> endobj
+2442 0 obj <<
+/D [2431 0 R /FitH 498.142]
+>> endobj
+2443 0 obj <<
+/D [2431 0 R /FitH 482.976]
+>> endobj
+2444 0 obj <<
+/D [2431 0 R /FitH 458.899]
+>> endobj
+326 0 obj <<
+/D [2431 0 R /FitH 417.111]
+>> endobj
+599 0 obj <<
+/D [2431 0 R /FitH 134.074]
+>> endobj
+2430 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R /F48 455 0 R >>
+/XObject << /Im17 2429 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2455 0 obj <<
+/Length 1842      
+/Filter /FlateDecode
+>>
+stream
+xÚíXÝsÓF\10\7f÷_¡GyZ\1f÷}'JÛ¡$!tÂG\93Ì´\1dàA±\95 ¢ÈF¶\81ò×w÷V\92%G\ e\ 4\92\87vúb\9dO{{»¿ý\16\8f."\1e=\1eýr:ºwà£\84%VÚèô<\12\963k]d½eBºèt\16½\8c\85´ãק¿Þ;pªK\9a\12\a|\ 2Ñ£Ã\87/N÷\8fÇ\13¥TìØxâ\9c\8f\ f\8e\1f>ݧ­½ýGÏ÷ö\91Ï\88×·÷¯\9e\bg\986*\9aH\a\9b\8aØ\9e¾Éà¼Tq1\1f\8fç\vü+ãW\èb\95Uô2_Ò3¥Ç2¿\\14õ¹Yv\16\8eºx:\86\9f·yy1Äaõ&]õy\9d¥ËlFËyIGªuYÖç7w]¦E\81j\81\ 2\9a%ZÃS°Ä\18\92?\9b]\80 Ò\18\10d\95MWá8þÅëÇ"&   pc>\ 6õÞ£\8c´£A¦úè\94t\9f¡<øâ¬\ 6c\8a\12\r^´¤eZÎêÅì/¸b½ÜÜÚ²\ä\1f³\82¸½\1f#i±n\8e\9f!׿\83J¼¯L\8a8Úx\95.\ 2 Y\15\ 4\82\9d*[.È<å2\ 3ÛkiÈrÒ\99\ eÐWH\89\0\11ÇW\97µ\9aë"]\11çV\18º·áx>/\8a\0×\87ñDÄ9è\18ô\ 3\92r^N\8a¼ÌÒjHþóu      \16\98\97÷ÃK+YÂE4Ñ\8a\89¢\0aM~ù\8a\e~L>/DÇG\15gÆ7\1eÿ\ 3\11è¤C \99\96\11\11t\9dÜ2\9f4¯á\12\81RûøÇúªnt9&à*%\99r      ÑûF%\ fTuhþÔì\81\ fì%7Û{ÐÂ\ 61¨Ô\17\1e¾áÅ÷¯â"\14óÊEZ2­\ 5\ 1ü!À¼Ü¿ËÆX&}\8b\7fcAݽ\883\ 1FoM 5\99à\15ç|@,Ϥ5\rµ\1cà\afJÌ\86\1dW\ 3NÑ£9\1a`2\11\3\ eë\9e·\ e\8bä\98ÓÉu\1a&Ìh×\91h\80G\12òë]h%¶|]l\19«o\vÉ\9cº^Ò\9e¶w&i¬ioy0à\ 6\10öÂ~\9b[õ$
+~¥¯É\13\13¡À\13àLÏ#\86R\92\83䥯CÙ(\88d{\15æ-\88:8ï\82Èß\18\13¢\aC¨ôxì\b\94\84\15q2\91P¿¿£Ç\90\1f\1c¿\13\97ï«Øuù£Áèíà\1cü趠ÞÍbW\Ù¯\80£ïÄÂBG'ksÙëóºø\^¿\95<`o\1f|¨m\10¬VB°Jɸ¨Kó!´G\ 3BHÈôB^\83\1aÜ`7>\12ºQÏC·é\92¸È/sêæp\13:7\e:7ú\9b½[§\ 5-WóAçÃnbc±\83£'OO®
+\0EظVÅ\97uëÏ»:0g[\9cÞåC\85\13´l)^CGh¼\8a\9f¬H¸Y\86-a\99Õª\85\ e\95£¾0KßÖ/æç´\8f\ 4\84\93×}\7fj\9aºïñ\104\93E\ 1\roE\1d¤\82\960Çæ\1d\9aÆ\83übM\16\19¡«ñ¨º\88hqüx\14½\f4\90L{\13
+°gC@\1a\98T\9cû,\90\96)Ñ·¤Ãî¼~VUZ7·(&)k66­Éën9\9bæ\b\1a)eP)B\84\v涪DÀS\e\1f/³Õz\81K\17¿ÉÒ\19và¸\ eã\ 1¾G\89p#/gÙǬÞÜtÿ[F\17V3»É*»ÍÞ\92\80E´÷\eyP\81j¹¢KÁWK\1cvVù§\14Í×\11\85\96çó\8a\8eµæ\17Î3ëåVO_¥\97\19Þ$êéF%8[\84E\ 2³O@\f\ 2;ÜÂq-ì´Ô{\8fèM=f¡wÚi\9e\95\88Äj  Îk5\8f\8fÒê"\f\8b\89ïMLáºó¡@÷Ð\89y}}¤{Û¢\ 5ªçSp[b\99\92Ê\8a\88M_epïyIÂÀ`Ý\8cW\8d£ú\88h%^ÁÃ4í\9bÎ\e\94\ 6\18\9a\ 4\fh\87ó*ÿ\ 4À+\ 1\13\ 4I\98Ô®j\83#\81gªaô¤\¬C4«x\91¢\ 5àÔ2ôõ£ýÓÑ»:ÂDû=A\83g8i¢éåèåk\1eÍà%L\ 5àº.ú\10H/#\ 5s\98\13\88NF¿\r}\9b\0ñ\9d\8f44ËRK\12ä\19Ü\rV\83ì\e\9f\ 6Ï­GS\1cÎ\85\8eOòOä<\82Ãha®tØ\86\9få«e\98Ä\90Jyæá².ÍI~Qf³\9f\81«JD¼\97-§U¾ \87EôC0A\a\16W0\85f8\8e\82\90\90`c¹\e\11å¡ã\80¾l\v\11\9døë\11é'¢À\fÆDgX3­\1dï?z1\90\8b4\13\9bÈ\94{àÔÐ\9e>!\1fÏ.²Áyùa\9b¢ð%\bl¡zt       <6T\90¯\9eÍÃÂÄ\ f\87Ê®bÜ´qpüâp¨ý\82Ìët§~Ë\ 1F       \0&6|~¿ª%ÖaÕfÜn\86\85¶o:'mÓ<|Ä       ñå\12\ 6\89c(\7fêÍ\81`Ö:\eÐ\eLÖøLñ\ 1!\80\1frÒ2£\7fÍË\96O\95M\86Ð\ 5öà+ë)U*ð¥\90Ê\86êÍD$\8aIP¬wþà\8fÏ\99¹kÞ\89\11 \8a䵡j\8bYúL£¡\0½©ÓA\80¨ ½ú+\91\ ee\9423$\89 `ý=&Ä\96NÀÂ[m^ó\81\ 6\13\87ñ1ÁEÑ\ 4Ê9,°\18p\ ePTe(O\9cª>>        >X¤mh¥\94§¡¹      /Î(]\ faÛ$Ålv\ 3<ÿ¼5<\1dÇÏj(\µ\82¤^Ð\ eº  \ 1\8aÿj@q\89*;®v\0jþ­\80\1eÝ\fO\vxºA818ºß\7f;U\8f\92oh\8béEÛ?±Ý¹\17Ê\ 5ã íM«Ñ@î\ 5fÊ@^ª?\81=_¯nV\18%\0¦Õ­ÔE    ½B¢Ý·ÔEû\ 5uÑÞm]\14^AÇs;eQ8´³þ¿.þWêâ\ e\97ÁÏÆòFAÔ\fxÍó\1fOµr¯
+endstream
+endobj
+2454 0 obj <<
+/Type /Page
+/Contents 2455 0 R
+/Resources 2453 0 R
+/MediaBox [0 0 612 792]
+/Parent 2399 0 R
+/Annots [ 2452 0 R ]
+>> endobj
+2452 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [293.973 518.244 308.695 529.092]
+/Subtype /Link
+/A << /S /GoTo /D (figure.7.3) >>
+>> endobj
+2456 0 obj <<
+/D [2454 0 R /FitH 686.127]
+>> endobj
+330 0 obj <<
+/D [2454 0 R /FitH 469.434]
+>> endobj
+2457 0 obj <<
+/D [2454 0 R /FitH 450.989]
+>> endobj
+2458 0 obj <<
+/D [2454 0 R /FitH 415.124]
+>> endobj
+2459 0 obj <<
+/D [2454 0 R /FitH 247.694]
+>> endobj
+2460 0 obj <<
+/D [2454 0 R /FitH 211.828]
+>> endobj
+2453 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F11 573 0 R /F49 457 0 R /F1 667 0 R /F14 574 0 R /F70 508 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2463 0 obj <<
+/Length 1759      
+/Filter /FlateDecode
+>>
+stream
+xÚíYÛn\e7\10}÷Wìã
\18Þ/)\90"m¢ÔA\90¸¶Ð6pü°\96Öö¢²¤®ä8É×w\86Ü«v¥8ð¥\ 5Ü\a\81\\8a;\1c\9e\999CîÐè<¢Ñë½\9fÇ{OGFD\8e8Íu4>\8b\18ÕÄj\17i«       ã&\1aO£ãØ\10FÉ`h\8c\8dß¾\7f\7f0\18
+!âÑþÛ\81\15ñøÕáþ»×\83\93ñ\9b§#Û\10$¸%F\e\8b\0Y8g\8f\16+?\1d\98=,§\ f¹\81A\11^ú}àt\9cäYr:KW°ª\95ñÕ*\9d\92^\8d÷þÞc \8cF¬V[\bb\95\8e&\97{Ç'4\9aÂ\9fo"J\8c3ѵ\9fz\19    )\88aøâ,:Úû-`ÐÔ\9c1N¬4\91æ\82\bS¨ò.¹L\aC¦©\8cÇ\ 3nã/ËÁ\10\1a\18ã\\8aø(û\9a¢V\91åD\19\17\r\19#N©ðîGªèi¶^AËü$a\89\ 5l\9bs\8e²óy:ý  6)\99\8a_¦«I\9e-×Ùb\1eÀNæSìÈ8OWë<\9bà?«\1d0P\ 5m\a\ 6éìwÀPÈRN\12©\83\96\87 \84r<Þ\9f#\ 6ëô<ÍaÄP\1a;\0\82ÁØ\87\ 1\18       \8då\9fÆ\17iP;\9d\9e§a'Ót\9d\8b<<å8\95Å\b¦\89aK)ñ\0Ñ6\80èqZ\9aÝË\8a\17AøGÊäl\9dæé4</³Ïé,èói À³fWa=\88\ 1ÚØùÆê§_ºÞ\rà1¦KçnëÅA/NÑ1`\8dw\vßQ5\14\9fpn\9a¯³I2ëè\95ͧéç0\9a\15¦__\14È\9dÎ\16Þç&(à/²ÝúJKp`w» à\8cX&"%$Qe<\8e/2\84XÉx\99\17º¤Ó«<\rcÉr9˼\r`»I\18\93Ãu²\fÝ\8bE\9e}]\ 4¤pç8VZ(¼³^\84Ñ4ñ[¼\b\12øÆuxX\9c\15k\85æ\13þUa\89#m\90¼3\r\99$NʶQÑ!I\8b\91\84\19\98ÆlA[\es\8e\87
+¬;Bo+]¸Ö¶åXáOзë_\8e\ 2\9fVÎÓç^L\10`\9frÆY¾¸\fâhX\ 4\81ÂGó¬­Ý\10HÛ8\ 1;\ 5Q\×ì\93\94Ô³¹\93\17«\15\10O\90vX\b/ý­Þ
\b¼¬\r\80È\ 1\10\1d\94o\919P°Q¥ò\87¯~9èË\ e\84ó
+\82ã\1e\99=F\1fz0²Àμ\9cñ¤\ fgìí\84\99\12\19'}j(¢Dµ\97Ñ\9f=2\80i+=OÂÿL6©\828[­ñ\91\95ÑRTôÈ\80\ 4ìtC\86èÑ\14ç<\1eÔ-¡VÖj\0Çò\98\9d<       \ 1Ï\85"RÉ*ò·âª     ¥î\e¸â\1c{\ 3\Ííp\ 5óYµ\vW8\1f\19}ï¸B\ 6\81+£"æ}n\r
++%º~ÝZ¯¥óm|Ò>\ 4\ e°s\eØ\89\93Ð\16\8f²$b@\935Q\80S¯ªl÷üy¯Çs-[$Ñ ~A)á\14\93\97\80äÕ8vÞ\84ø\ f\12¿\1fßÂò\8c\1aB\r\8c\13Zÿ(â\19\9cgTv\89\80\1dö\18Yà      ¼öä\1f\80\936¯&¼í*\81\1eÆê\98S\f\7f\eG\148I\ 3ë9¼\83(`¿\863L¶9Ã>\9eªàrw\10\1a\7fÈ3.\86K×*\8c¬/\92yè}MóÅ\ fxÂrq²ògwt£\1eï\80;\8e¤\ fà\1d\86À~wǾ­ãæ\1eyÓÕÇ\0\fvVx\87G/\r\1d\b,U\ 4V\89eÇxp\81\95Z\14Æ«m7Ýf»÷ =¿ÎV)XEP\17ggØr\1fÔ@8hKlÏó4ñ\amü/\98\13\87áØ]¼\97\ 4Bè1\ 1åD\vù\10\964\9aí\8es¡î"ÎåNK\1a"\8djZR3´d8X\18G\8cÕí«D\937Uãì\ fØnZ\173\95²\1dã¦72.~\ 6Øf$§árïî?Ó"\17³oq±¸÷L\8b\¬z¸8¤±\ 1\8bÓ\9eÛ\98\8c\ f:öpp\8f\17®c\10\88!\88Ï\eçÎê\92Þ¹ÿmÍ\9d
+|ùq\9fÖûO\95áâzóÛÒ7R® D=DÆUþ0Üɸçw\9dq1᮶g\÷\10\1fθü\ e3îÅÿ\19÷_̸ü®2®ò_½7\8d\9bÝ>ãJbÅãθü¦\19\17V³Eµ\83ûj\ f\\96\88dÊW{¬u\8d*\13÷\81¬°ô#\e\8d\8aG\99ÿRÜU\1e\ 3\98ýùòj\8dÅ"\11/\93<¹Lá­Õ\8e\92\11\87U\1dW·,\19\bdÁ5\JÞ,\19qÍÝfÉHp&ã#\0­¬\1a1\88x©ô-ÊF\8¶µlTÕYÖ9.:ñÝ\fº;\8bHÌrâÄ÷\17\916N:\850ÃÀÇv\ 5\8b\94\84Õ\1fJùËÁP\ 3c7K+=\95¡\17y\9exlCñM\13\r\9c`7ë0/ú>\9d
+BUÍ·\a¿ö\9cLÀS±\18X\9fLx\1f)\10#x-ç\8f\1eJ`@í\95\98¤R\1f|\82Ç\93²<\92ͳùy @à?\1f)\1dþ\ 3?«^ÀÒd\1cº«ð\ f\16J°MB³\9c%sÿ\8e¨þ©\84äé°\ 5mñq\1fd¯ÖùÕd]\96ÏÎ0\98HÏ®ý1\9a\8b\8d
+K\1f\8d´mÜ*\9b)\ 6ª\14e3U\9aK\87²\994ºS>±¢p\86Ý¢p\ 6\89$l\10\86p\83>¸¤\ 3óò¶v³\ 5\ eµ¸áÌ\ 3x\ 6\11\ 1Ì!!\rL\16ù\1cµÂ¾\97\amÈ:\ e\127döbh\11ÚÓ"²{<´.B¶SSÙBèý\ 3¹S`:
+endstream
+endobj
+2462 0 obj <<
+/Type /Page
+/Contents 2463 0 R
+/Resources 2461 0 R
+/MediaBox [0 0 612 792]
+/Parent 2399 0 R
+>> endobj
+2464 0 obj <<
+/D [2462 0 R /FitH 686.127]
+>> endobj
+2465 0 obj <<
+/D [2462 0 R /FitH 668.127]
+>> endobj
+2466 0 obj <<
+/D [2462 0 R /FitH 634.254]
+>> endobj
+2467 0 obj <<
+/D [2462 0 R /FitH 514.693]
+>> endobj
+2468 0 obj <<
+/D [2462 0 R /FitH 492.775]
+>> endobj
+2469 0 obj <<
+/D [2462 0 R /FitH 427.365]
+>> endobj
+2470 0 obj <<
+/D [2462 0 R /FitH 412.52]
+>> endobj
+2471 0 obj <<
+/D [2462 0 R /FitH 396.58]
+>> endobj
+2472 0 obj <<
+/D [2462 0 R /FitH 371.175]
+>> endobj
+2473 0 obj <<
+/D [2462 0 R /FitH 352.745]
+>> endobj
+2474 0 obj <<
+/D [2462 0 R /FitH 336.804]
+>> endobj
+2475 0 obj <<
+/D [2462 0 R /FitH 320.864]
+>> endobj
+2476 0 obj <<
+/D [2462 0 R /FitH 295.459]
+>> endobj
+334 0 obj <<
+/D [2462 0 R /FitH 265.08]
+>> endobj
+2477 0 obj <<
+/D [2462 0 R /FitH 247.189]
+>> endobj
+2478 0 obj <<
+/D [2462 0 R /FitH 211.324]
+>> endobj
+2461 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R /F14 574 0 R /F11 573 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2481 0 obj <<
+/Length 1765      
+/Filter /FlateDecode
+>>
+stream
+xÚåYÛnÛF\10}÷Wðq\85\84\9b½_R \85\eÛM\826q\1d¡màø\81\96h\9b¨,©\14\9d¤ùúÎpI\8a\94(:\86\9d´E\1f\f.Éáìì\999s\91Yt\19±èǽ\1fÆ{O\8e\ä©7ÂDã\8b\88\eF\8d±\91q\86ra£ñ4:%\¸ÑÙøÕ\93#+Û¢\9eQé-è)\85\9e¿Ø?\1e\1f\9e\8cb)%±t\14[ëÈÑÉþÏ\87áÑÁáó7\a\87¨g\8f\1f\8e÷þÜã°d\11_ïl,µÂG\93ë½Ó3\16Máå«\88Q\v;},E¯#©$µ\1c?\9cEo÷~é;\85¥ÜºÈhK\852ÁÀ×Éu:\8a\85\11\9e\8c\91¿\96pg  <\93\82+ò6û\9c¢u\11g\82*m¢\98sêµ\ e\1f¿g\9a\9d
+®¼\94\92\8e:ج-ó6»\9c§ÓïA«ô\9c\1c¤«I\9e-\8bl1\ f\0$ó).\14ÉG\1cwådUäÙ¤\14\80u\89L?"ÒS+·\10\r#¢ü\96c\ 1\12á(X\13,>z\17üÚÆN)Ê\1d¯½úr\8eP\15ée\9a\8f\95 \82Á\ 1\85Öäõ¢\\18\82ÓX¦È\a\94Mó"\9b$³ðd  'Ë>¥Õ]6\9f¦\9fÂrq\81WI\8a«
+tå)Ó¢\vúl\81
+?\96Z\11/\ 4.ÆŬFð\ 2\16Å(V\8c\91É"\9f£\91¸FíxEíå"i0OÀ\aÞ\93b\11^\9cÃ\19P;ÚÀ6]ÎÕ¬HótJ\ 3J\1d<cî%\15\0\9b\9fî\86§\ 1<m/\9c\180³EiÜb\19nk{B\10Ͳë¬\b/>\8cà«dv\93ÒÝ1¤\81Ï\16®weUO\f\812¸*[ÅÐ\9b\9bby\83\968I\96I\ e$\ 3\eWO\aL\91\90Z\8cz\10\82k¡©\ 1tÿÛ\ 4×ÌÁiÔÃ\10\yô´\v\16\9f\1c>?¾-$ÅÁ(6\90«Û¡ÙC\87ý<OJTË\97\10NÆê\ e\8aß*\905Ùï¡\8d\95@sUo}rü"ÈpÕ\92\11\96JÛȼgLô(Â\94È×z~Û>¥äÔ\0?+\91¤1\1f¢A@¶\b§M²y6¿,\8f\14[O\15×ÝS\87\f¢Ö\1f\94~\rËUxS&\e¸&x\91\9b%ó4ÜÕ/\e=y\1a÷¡\vê!Xn&E:\rÁt\81L\1a ´B\ 6è\a"´R\8c:S\11ú×\91\87t\92gÉù,]!¯\15¹Y¥Ó\ 1F+n¨Ö÷e4D\94Ò\91b\862Ûa4l£\90Ñ\16\9cÇɲÊØ\10c\80oCj'¨¶þK8mû9-Á÷\9b\9cVÀiز¦uÚðy\80ÌÒ9ª\8d¾3\99]\ f\97¥E'û*ÈÁ
+íE·\84H\v\ 3\18У\91w#ð\15ú¬¼«ê\b<\99^V\15e
+¹yR,òp\aç       `ÂyB¨mFå1\b\1ae\87·\94ë-÷»\95ª\8eåeh\ 1Ð\96\82\8e\92µ\8e]ï^5lç\9fzR\97¤\9c\9bÞj*\ 5ØUu'­,\14`\80Vãj\91g\9fkÚϳÚ2XVÍ\89d\ 2\96áQQ\7fz^\95â       ~üÇ\0+¥²T+w?&X¨i  \81U²"Âø*C*JC\96yeJ:½ÉÓð,Y\96I'K+\99$\T\$Ë°ìvfø¤ÝM\98²\1dÂk\9a\94
+w\93Åìæz\1eÖ\98ÈZº7À,ó'WÔ+Õ\8d .r!\1c0\1eig\10\88¸\80\ 2h#ð\18U¦:3ß\909\8d58ø\b\ 3®\8eඹ­Ø
+/Áâí\10\83\99\85³ffé\8b0\ eî\11º\96¸È\17×A\1d\v\9b\ 4¤`ÂyÚµ.\86\8aè<T\ f\ 1\7~\9d\80\92:ûl\9ed\7fµ\82Ü\13´\9dTÊëÖo}\14D\16
\81\82\18\83MO£º§,JêÖ¥³¿úKA\85h(tÚ£D\94\r\ 4Û=#@dbí©$Îúthªe\83âÑï=:\1c\91xÔç+\\rº
+ fÍiÏzZ        \88Èu£\ 3\9d\ 4ÛV\82«¦K\90=: \ 5{ÝÒ!ûÚ\9a¶Ì\0ìö6Øí ì0ºY¾\86\fè"\bï\85\1f£\10Êá7ÅÿQH\ 3BC.d²É\a;\81ÕÔ{u\v°\1d\99¯\a,N\13-\aB ¢\17Wî©°n\10\ 3N\ráêÀ\9c{Æ5ä(·\1dÖ\1dK;»Ü'\13Ü\8e\1cß\80\86Î~cèJ{J³8Qu&\ 60yû\900\ e\99\86       Ï\9eõrE¬%äFæ\97\8c\1c\82\82ÝÊÏç_\92ú\8fw¦þòù\8e<\ fE¬l\93¿z¦\7fð\94£nK9òNþE{*³fÐÓèì\1a\11;éq³\82\92$\9aO¿ë9\81¢J4hôü\94\83\15~Í:Íño£I\89\ 5to\10l\90ý\f\85\9ex\1d\f\93]Áðò\ 2\7f¦p\18\bÀ\ f\82\8d\1eÞÂðU­\8a+\98BÊw\9fÓ|ñ\18û)O\92\10B=\91\ 1C\8eü6Ì\17ëm\90b\9cï\88\f`¾¼\8døÞêaâ;}ÇÀ(\91K\ 3p@*]\91ªÆqËqкKa¶\1d7Ýå¸7 >ÿ\98­ÒÇ8%8\92]\84ñá¸\9a"Váz\99§Ih´\99¨|\89+\98MÊï\ 6\)\18\fµî\e´s\96ZÕ©\7f\86ív¥ÓÃ}\9d-[øA\92KéïXÿÀ?\1eÒ4÷=?ÏTYS·z\7f\0wÓ¿X©´ÛvoúEîÅ\9f÷v¹É\e\98îýÿ½û\v \15õ\8f\ e\eÃØñ\16Ýð7O§·ý\81ÿ\18\8b+çî-wVNM¥ÖÿLå\14ÿ\9eÊyÿaé\96z+\19$¯¯[n[ÿHü\eO¯·Ë
+endstream
+endobj
+2480 0 obj <<
+/Type /Page
+/Contents 2481 0 R
+/Resources 2479 0 R
+/MediaBox [0 0 612 792]
+/Parent 2399 0 R
+>> endobj
+2482 0 obj <<
+/D [2480 0 R /FitH 686.127]
+>> endobj
+2483 0 obj <<
+/D [2480 0 R /FitH 572.428]
+>> endobj
+2484 0 obj <<
+/D [2480 0 R /FitH 536.562]
+>> endobj
+2485 0 obj <<
+/D [2480 0 R /FitH 452.818]
+>> endobj
+2486 0 obj <<
+/D [2480 0 R /FitH 416.953]
+>> endobj
+2487 0 obj <<
+/D [2480 0 R /FitH 296.168]
+>> endobj
+2488 0 obj <<
+/D [2480 0 R /FitH 275.509]
+>> endobj
+2489 0 obj <<
+/D [2480 0 R /FitH 207.482]
+>> endobj
+2490 0 obj <<
+/D [2480 0 R /FitH 192.366]
+>> endobj
+2491 0 obj <<
+/D [2480 0 R /FitH 176.154]
+>> endobj
+2492 0 obj <<
+/D [2480 0 R /FitH 150.477]
+>> endobj
+2493 0 obj <<
+/D [2480 0 R /FitH 131.775]
+>> endobj
+2479 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2496 0 obj <<
+/Length 1610      
+/Filter /FlateDecode
+>>
+stream
+xÚÍY[SÛF\14~çWèq=­6{¿ô¥\13\f¤d(\10ðL\9b!<\b[\18M\8díH¢Ióë{vW²%[6vÈdxaµÒÑÑî÷}ç²\86\88\ e\ e\a\aoN4\8f\8a©hp\1fQ¢°Q6RFaÊt4\18E7HcJp/ÖÚ ³\8b\8bË^Ì9G'§g=ÃÑàøêôü]ïvðþÍ\89i8âÌ`­4|Æ» Ì:\9b\ 3R}¹\1e£\98Y\8b\95\14p¡áe\1eÌ?\11IÆð\87¶^\8anbI\b:½ï\81±A\97nÐ(+Ât\92\16ÕUù\90Lóoi>û\15.\8dEIQdãiX¨°Í-s\83-UõJ¯\8eû\97]ÛÁ\8c-ln:Ü°ævO>®» \1a3Åj\8b_z1¥\14±Û._Ôb\ e$ÔÎþîp¦°ÕjéÌ\ehÒ°0ØH^\eÜ}ípA° ¢¶¸­¡K\ 3rÿö¤DÉä)]\ 2\89ÛdÄLhÌÁWL%¶bIÜÃ&â.À{þ%+R \84\13\83²{72G¤\e\1c\91n\1cçiR¦y\98\ 4\15\93Ò¿·\85JF\18\96\f*µ0M*\15ÙL¥\91r+\95\1a\vE·Q     jàv\1f*ÁÀ\ 5\96À\94\87b\vKðÏ<¿.|\eüº)\80»J/°*¬Yc7Û\89]p¹\91%X\97Yîç%$\99­$\19Ìu\ 3×\98\81$\ 6øéíñf01r;Iv\19Ý;Å\9b\ 3©âC8>T\83\8fK\-ÓD\81>æ\Ä\fr\95\13\8bK\96ÆØFzæ.\9f0\89ú³Çù$-\9d\e-ÑÙ\fF\8afó0=É&.°Ö\ 1 @3ÀU{<\9dÎ\9fJx\ 5òû<É\93\97\17¿yÒ\8f\a\a\9f\ f\1cª$¢\8bj!\ 5\87\80`Ñðñàæ\96D#xø>"X[\1d}ñ¦\8f\11w&Ô½8\89®\ f>\84ÒÓ\82\871\909\8b\98Éj!çðmX\87d\1a\rzÌ ÿæ.\99#w\8fQ\81®³o©\17;¤R\0×´µîÔz\97\95E-Ø\bÀ3PÓ\9a6× Ñtô;\80',CGi1̳y\99ͦ\81\95d:
+|äiQæÙÐ=)¶à\0±¢!ë®ààÂh+\ eí\8cQ;#\ 2sQ\95à³\93³Ó?¯×E¥\18èr\91«N§\ e¤2\1d\a\92\8dÍ&y\9ex\14ýC¨ðJË\16\1aÚ\ 5     èð|æ/$z\v»\17\16)\11§\93ô1\ 5÷\1a\95áÞÒ\99\9fÎîÃ8\99y\86¼â`ú\89P1\89ý÷`©\ë\95täÓ<à;É\1e³r%\12
+Ü¡Ô\98Áû\94¯¤µ«Ë\8f\7fí\ 3N,©\80d@ªmVûUhàÂQ\b\89¾d£òÁ]
+¿3wË\85ªÿ\ 4°×H\1d\9c`e\17¹£ÊC\94G®@sãL ¯\ 1\ 1p¬hµZ²¾Tè\r\98\8câ\86Ñ|\92L«ÅÀ
+|F· \8c\1a@ÕÌç\92\82@\87 Í2\7f\1a¦£pç>¯\82\87¢l\1aÆyö5î\12F:Ù\ fë?~\1cÖ\94¡\874\e?x{7ç\ 1pÊ6\ 2N!,äK\ 1\akÂ:\ 1\87//\0\87ÔjyW\ 5ýÉ\88÷\7f\9cº\rD[¥nÃýVý­\r`\v8\ 6ÈÅGú\95   i\81M\ 1GH¿¶Zí]Gé\83jnUÔ0r\89uýs°k\85%£m\8doÿjÕ\9aäë_5\18N1QÃÆ3\fM¦`!_¹ÑÓé.Ztzö!\99\e¢ÚTÔ\14\ 3bYU#\80â}Ùüqñ£­hÅ\8f\9b»­i»\8dR)Äs\94Ò\16º]\9cÂ\96 â6\8cvâT­\9cÊ×Äéùáõþ\94rÕI)×
+\95³2\99¸K\8dükO\8fîï]h~ò`ã+.\18Üù\92«ÑÐ\15ç\7f\8að0\9b\86¾HXL$kÇS\12öê·½û\16\ fû\17GÇG/ì@Þ>×\81е\ e¤ë\ 4¡5VËÃm'ø\8cca\16Ýÿ¢}ñAÂ`h´/nêÀt#ô+2\19\17A,Ð/j¹Ò±dÓQ6LÊl:\86¼I \95>dCçÇ¥S"\80"Z·@\81\ f\98\17áQ\92§]\90\f\83õ(\1díÎÅ\87Óïn\ 5Õs­`e v#Âb*\16Ç´óÎu1\83\99áÝLpÝbÂMCí]9\ièÜ\97GòÏÙúWb
+\8cÛÅq·ÚÅwõ\92Çý\8fÏ¡Ë\8e\82žTîf½áî\0\19Ú¾åÙsÙ~QÑ<0\83V\97]Ñ'BX×\8f\11\f\vÁ\1a\9e
+! \r/úÙ¶NbJ,\1c¡Äª\82\ 3
+I6õaÁ­¬º$¸¨\1fV\94\17á®Ï]vSO½\82â\vzjeº{êªV\88ºV\88f­(\eÅ\82©®b±\97\98ú\87/U\93zNMj\1f5A\99¥z©\81þ\ 65IÊ\9fW\93´MO]j\82 Ôb'5©\9f£¦\9dºÉ»®Î\83ÃQ`µ\9btÚ¡\95\98H-&ºAL\ eÒ\97\8aéêu¥¦×*&ù\1aÄ´­\8dÕkM,(\87\93 %N+)Á\8dn)\99\95\9en©¤î_¦\\13\1fÚã\17ºÕ\7fÕü\ fW,Cé
+endstream
+endobj
+2495 0 obj <<
+/Type /Page
+/Contents 2496 0 R
+/Resources 2494 0 R
+/MediaBox [0 0 612 792]
+/Parent 2503 0 R
+>> endobj
+2497 0 obj <<
+/D [2495 0 R /FitH 686.127]
+>> endobj
+2498 0 obj <<
+/D [2495 0 R /FitH 668.127]
+>> endobj
+2499 0 obj <<
+/D [2495 0 R /FitH 653.681]
+>> endobj
+2500 0 obj <<
+/D [2495 0 R /FitH 628.276]
+>> endobj
+338 0 obj <<
+/D [2495 0 R /FitH 597.897]
+>> endobj
+2501 0 obj <<
+/D [2495 0 R /FitH 577.682]
+>> endobj
+2502 0 obj <<
+/D [2495 0 R /FitH 544.141]
+>> endobj
+2494 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R /F48 455 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2506 0 obj <<
+/Length 1374      
+/Filter /FlateDecode
+>>
+stream
+xÚí\98KsÛ6\10Çïú\14<R\a!x?zéزÜ4Ó&®£iê\89s %Úf+K*Eçõé»\v\80\12\8e\9d×äÐ\8b       \81Ëåî\1f?,\96¦ÙEF³_\ 6ûÓÁ\93C\9b9â4×Ùô<c\9a\12­M¦­&\8c\9bl:Ï^çLÐá\9bé³'\87FtM\1d\19ðã\8dÆO÷\8e¦\93ãáH\b\91\e2\1c\19cóÃã½ß'aê`2~q0A?\ 3\1aßþäPº\8eÃQëqÄ\rL\8aà÷Åu³¾nÀ\87\15ùº¨\8b«²)ëÍOÞÑd:øwÀÀ\17ÍØ.t!\88U:\9b]\r^¿¡Ù\1cn>Ë(1àø\9d7½Ê\84\14Ä0|p\91½\1cü\91\90Á0¢\9dÊ4\17D\98\18Ésx7ÄA-ϧCnó\ fëá\b.8Ç\99Ì_V\1fK\8c*cT\13g$äÃ\88S*<|J\15\9a\r\\99·\12\96X\10¸kó²ºX\96ó\9f\87 \840ùA¹\99Á0¯«!Ë×MµZ¢\902/\96ó h]n\9aº\9aá\9dÍ=rPE¬¾%\87tö~9zK\13\9cÙL9I¤\ eÑ\1eOÆ'\ 1\8b®rJ\10Ît\v\ 5?\18\8e4pðë\12\ 5\8b²öÉÓ¾8{u]xEýM@O\eÕSÆ\82Ò\éüùÊ\ f\17ÞÜ\vÒ\b@V¶¯>>:y\1a\8c\98ì\18      àÚl\8dN)å O\8eXÓñóêv\9a\12HÕ[7Å6~@Áå³Õrä3\199C\98ºABSTËjy1\1c)Ãóæ\12\16·\fcx,¨\ 4\17\937\e\9ceùê¼µ,c:¬»0\ 2\16\ 6b\8f\81Ä\ 5a"C\ 4\85õ²\10\ak-\88f1\0z;\9d\11\ 3\1cµ\84­Ç\14QqÛ¯\17Å\12BãJú ð\8aAøA]B´\80ßõ¬)ç8¥òó\1aR)®\10Ù\92$D\1dqÊ        ×®¯\ 6P4ÞÿÑ0â¦\83Ñ8\89\91"n'û\1d\181J¨à\1dOi\90°Î&@\92²\ f\12¥w\82¤UX\19\1ct)²\81"\98õ\14iÝò\96\ 6I°mFãhB{ 1Π\ 4¨\1d1\82³$I\86H\8c\14j\8c\99¤ãÿIú2\92\94\89$Anþô¹M\13\98x\9a¢i\ 2%\ ecúP\94d°ªï@\89\8a¯\8b\90\94\ eÎ\ ef\1fÝ3$\ eIp¦5\1cí1¯?\87NÃbTÅÙ¢Ü`\17#óëM9¿§\7f\91\92\13\ 5µú\8bú\17\bAK\95IÁ=8\9dþ\85+£>Õ¿\0\1a\|AÿÂ% \87ýK]}~ã"\99$\8a«G7.6Ñ·H\8a½A»{^\ 1\ e\16ÚÉ]\11ð}\160Í$Ë9½¹·§\b\98d.\7fWÍ¡\80ÂÐzøpª   ÷l>»®ë¸KÂ\9dHj4öÂ:N\18D\13\84\8dm\94w\10TéÑ\8b\8a\9dסå\84»Õ2\×Õûr±!a/÷\1d¶uðè)ÄÍ4ë\15\8dß\95\9b°:¿,«\8bË\18¾°a\8fã|Ó\1aô\12Ä\89\98 \ e\93      ªo\95àd|\ 4\v¦¨½³\9cKÜÎú[Õtîv\958UÒáóEKù\80\92N;%=QÑ\ 5#\96ÚTE\17.\9cóf[º½\\16Îpª\13òsk\13\8d\ 1Îú"
\9dYw\99q¢­¸vË1ýä\ 2÷Ö7¹\96\91þý¿Ð³v~\ 5M\87ÕÛûPÇ}èL~¹ª«\8f1\9db\11æ<7aX-çåû0ôÛÔÙö¤J\13ºX¡§wø§¬G\v_\rÎáÜhð#\16\95®\97\18\15~Т?\9có9ãDW®\846g\8b\95/²3´øç>ª÷O\1e«\84á*\7f\e\82\19ê\803Q\a\1cF\1dpèãæêGÖ!\12q\88D8\bõÎê¥\1eD\84½\97\bóÙJøZ\1f\95Ø\1d\ 4fw\10\14uYÄ©U\989\8bçlB\97SÊä¢)ër~\1f\e\87'\8fÕä{²ñ]\15\89\94ü\ 6õÅPqC\10\r\82\98¤\1eX\9e"\82«uøÙ¾(Tª\ 5þ\97Å÷\89U\13î¿\1dÂÃÅâºý\ 41´S\9aoâ]%úñp\ 6Åê}{å\84\f·Z\eøüÇ©¦½×ï3À¢¿µZ\aa%¥#Tñ~¬³`>/c7¶ªçe\9dÊ1ÍâÙß_-U®·©r\1dRÅ©"ü\¶\rI\80\ 568~¡ AÈØ`Æ\ 63FëÏËxû¯Èö
+\9dè\7f\92e&Õ
+endstream
+endobj
+2505 0 obj <<
+/Type /Page
+/Contents 2506 0 R
+/Resources 2504 0 R
+/MediaBox [0 0 612 792]
+/Parent 2503 0 R
+>> endobj
+2507 0 obj <<
+/D [2505 0 R /FitH 686.127]
+>> endobj
+2508 0 obj <<
+/D [2505 0 R /FitH 668.127]
+>> endobj
+2509 0 obj <<
+/D [2505 0 R /FitH 634.254]
+>> endobj
+2510 0 obj <<
+/D [2505 0 R /FitH 478.779]
+>> endobj
+2511 0 obj <<
+/D [2505 0 R /FitH 442.913]
+>> endobj
+2504 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2517 0 obj <<
+/Length 2022      
+/Filter /FlateDecode
+>>
+stream
+xÚ­XKsÛ6\10¾ûWðHÍD\b^\ 4È^:µc·î¸\89k«m<\8e\ f\94\bË\9cÊ¢KRI\93_ß]\0¤ø²\9c´½\88«år±øö  Ð`\1dÐàÇ£ãÅÑë3-\82\84$\8a«`q\1f0ªH¬\92\8a\83E\16Ü\86\9a0Jfs­ãðâÝ»ËÙ\\b\11\9e\9d_Ìb\11.N¯Îßþ8»[üüú,î(\12<&ZiXƪ`\82¡Ì\11õ+\9f.\8eþ:b@Ò\80í\17U\9ah\9e\ 4«Ç£Û;\1adðòç\80\12\9dèà\93\15}\f\84\14D3üp\13\\1fýêvÐ]\971Nb©\ 3\15iÂ¥r«¿M\1fÍlÎ#\1d\85\8b\19\8fÃÏOð/\ e\81'8\93áuþÅ u`\b#    \17Á\9cÁ3\8aÜÇ\1fhD\97y]ÁÓî!\101\89\ 1\9a®Ìu¾Þ\9aì{Ð*¥\fß\98jUæOu^l\11+\19¦ÛÌ\81V\9aª.ó\15¾©,\1eÓ8\88\84h1ÂA&ña\1c4\9dò$8\ 2\96vv>mò±«@\15cªñÔù\16\11ªÍÚ\94³y¤$\ f9l\8bG*|[X\ 20|@4¹\fWŦ(\91\14 9Ýzn¾ÍÌß\8e[Ü;VÝ~±+KãVp\88Ë\84Ðh\80ørSXÿ¬PîOr\0(\88K¥õ\7f\v\18ÎHÌD\10Å\8c\9d\ 5\8b\87¼\9aÍ%\8dçÒÛb²]i\90§ÃÌ| Ln\8d\17±\9bC¢(3\ 4ÍñÒº÷V\87\1fg\0]ZæÅÎ\7f綩q\9b:üÓ        \99lݨMK¯\16\17ÛÔ¦4\99\85\ 2°\92$\91²\8fÙ±Y¥»
+#ZÓФ\16º\a÷/}\ 2·¯R\1f\8eÀ@¯ØçÖô\19ÖVKàç\9fð§p\8cÆ\86Ê«\ZP
+\94ø8ó©\ 4ü\fã{\añý\11÷d6\9f\1dûÑm4ËQ\8d±\91\ f\ eéÙï`\8a\94\ f@÷¨\1c\17-Äg+V\1a\10t\8b\99̱òÇtm^Aвd/÷4c!\ 2ÉÂU^Y\1e\v\8b]ý´«½âe\9dæÛF\85µPà6'LÌ\8c/\eÛ,ß®á\ 3X\a!\95\1c\91\83u\8c£\9b0°fØ0\0æCQæ_üÖÒ\8d{kË\ 2¾t\10\965xÉ¿êà\8d\ 2.\16ð\13ô¥ñ\9fÕE³\8aéÙë«\9e\8f%¬;ÖÁX\88Üß
+ìß\18G\ f\93m.¥Ïpû¡Û\v\92MÔgNÕ\83\f8â¾(\1fýRh\14¾w[G\ e\84¥/\7fK\8c\8aÏ\8eþýR\90^K\80L$\f\92yÎ)ÔW\8f9\eÈÜÎ#JÃ\1fª
+
+®ÓsÑ,ç­\814SaºÙ\19WèdÒÉõ\ 4;YÜTº\8b³\8bó_®'ê!'\91nëáí\84\1e\ e­­Uóëù\84\ e\96\10±¯©·ôîn°\919SÌj\99\83¨\8cc'È'·{\86\8d¶ðnèä6l{        a·w -#(\94o\9d\8e\90P\92\88¶#\97³\88\85i\ 516¶\1eZ\ 6׬\91´1ðÊ)þ\94×~å\95Ïi\93ÍÛ ijÿxm&8Ô¬\16\90åD\e\8a\89\82\ 5¾\e Å¡\8cÇ`R\ f-ìÌiÓ\96\87 \9dßO9NC¿\90Í"Ç'ïÞ\9c¾\19[\12Q\ 2óÊ \0zÛé\ 5À\8b\9b¹óN©\1cFÛb;ÿbÊb¸G%\b\16õ\88DÔ·ëüPô\8f­\82À\95\11oV\9dìõ \9dÂ\84E;E×Å\8bmÙh\9d+\15bÿÎ7y|\87ÅÔõy\e{½Ê1åthîZÊC8a½Ú;Äu\15³)¶ë¶\9a\fó\86C¿N`°\9c3hì\rN\a\81²\8dõêôäò\15\96M\15^]þ\ 1ý@\84þ¯«Â(rù\93#º-ÛÕ\12ß\92×¹«Ô^gî\9f\vÌÏt¹±%Ç\ f)å:pÄ\955\aÅ4\89£AÅ\13\84Ç\83F¾*`Bª\§)|§Ù×ÕÖ/²Sè\9a\12?\95v06\82æ\83!\81sO\e\12\87Ïþ\14\96@\1aDq\0-\88Pqplg\1av(Ä¡q5\81ó\82P\ 1ÀL¢¦\83MÚË\ 5QªÍ-ô+\8eö\9c;¿r©\13ëÉñÐØ\98K\ 5¡T\1e\9a®'ÍíÙ@9¡I\12\88\84\91(ñå\88N\15\1cJº¦Þ\80\81\14Æà«Ë\e\8cAÎ0\1ao~\1aorn?ì\ 5\ 6{YýÉ1*\95¨ÿÄê\87\89\13ȯÓÏ¿Bÿ\15*\85Ì\9aÐ?\r\80.\97Äú[b\83v\ f§ýÚ\ 5gÒXÀH\ f
+¸Oý}îÙ,À\1cû\ eg\18ÀÀ¬pì\83\99\8b\85\15Ru      ÔÎ2k7­±Ð\ f&\97XÕ|Éi\ fkx,ô%û¾é¾§M÷\9dè B\10¡\87¹öl*\rý!°\16D@Dpn\8d\9bºv¸°        %Ãã÷ø\8c|]\0ÆpÒÄ\97Oùßfã^7¥^ùRßýtS´s¿)ç\88Ϧ\ 1ê~\86¨Yq¨P[Ûï\9d
+{\8cSp\8ac\13\13ýxÂ\9cê[Ðøä×·ÓaGPàtÀÝ6\ 4èm\ e¹\8f\87\81£*<¾Aó\98·ÓVûî\14\8e"\rl@6°\81\9c\85\rXþCµ\87M#l\es_;~\v\14ÐÝ\8f,b\11ÑZ\1e:÷N\85\98"ûæýÍ8I\rKõa\9aFéÜ\8f\06´p¨ó\99±.MZ7Ç\ 1\98ïýíÆÄ,\ 3'TmïQö=ú\87\17'ù³÷Ï\8eò\96\8fã\1e\98d7Ídï\b\ f;Sí\14ñ\81R:\86\ 6©\16\1a\8eSãh"\17\9aD\8c÷\11:~Ùl\8c£(yÖl\8c3\1e\8d¼\813fÒ_ëdr­ß*wÚT¬\1db\12  `YÂ-\ fêý?7Ì\80è\85\97Ã\ 3ãgÇrc\r\10£³¨âÃË\bw73¾fhÎ¥¸¦²3\89}Úë\1d \ì#\85\87OGÙ; x¾<.Bé\8bDò¸Èi[bÝa¤gÀðº\ 6y\99½\8eó³eæ¯P\84²£ios¹÷èµ±7tÏOsèV{):<y\8c¼\fÇ\1e{jéæ\~8é|8ý\8b¤Óp4Jþç¤;~?P\ 1\93\12\1clÿç\1c±©}3\99Ú1¡R\7fkj\8f2;&p\18ù\86l\13B5Ù\86¤Í6!t'Û\90íG\ 5e³Í2\¶!é·ª\86mE¨ÑÅ\9f\10Ñ>±\9eË<;ÿ³æ\8e\ e\88¥ÕQÔuñè\18\90²Í\ 6E°}÷n\a¦²\ eº/e/d\9dÞ祿\ 2hM¡É(ëðåtÖEà\87ÿ\9atüpÒuÎ*ÿ\0ÖZ÷\v
+endstream
+endobj
+2516 0 obj <<
+/Type /Page
+/Contents 2517 0 R
+/Resources 2515 0 R
+/MediaBox [0 0 612 792]
+/Parent 2503 0 R
+/Annots [ 2512 0 R 2513 0 R 2514 0 R ]
+>> endobj
+2512 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [431.873 441.914 451.577 452.762]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.85) >>
+>> endobj
+2513 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [234.756 198.013 262.209 206.813]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.1) >>
+>> endobj
+2514 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [234.756 119.186 262.209 127.986]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.2) >>
+>> endobj
+2518 0 obj <<
+/D [2516 0 R /FitH 686.127]
+>> endobj
+2519 0 obj <<
+/D [2516 0 R /FitH 526.841]
+>> endobj
+2520 0 obj <<
+/D [2516 0 R /FitH 506.799]
+>> endobj
+2521 0 obj <<
+/D [2516 0 R /FitH 485.872]
+>> endobj
+2522 0 obj <<
+/D [2516 0 R /FitH 468.041]
+>> endobj
+2523 0 obj <<
+/D [2516 0 R /FitH 454.865]
+>> endobj
+655 0 obj <<
+/D [2516 0 R /FitH 352.678]
+>> endobj
+2524 0 obj <<
+/D [2516 0 R /FitH 325.493]
+>> endobj
+2525 0 obj <<
+/D [2516 0 R /FitH 301.746]
+>> endobj
+2526 0 obj <<
+/D [2516 0 R /FitH 276.062]
+>> endobj
+2527 0 obj <<
+/D [2516 0 R /FitH 260.395]
+>> endobj
+2528 0 obj <<
+/D [2516 0 R /FitH 246.113]
+>> endobj
+2529 0 obj <<
+/D [2516 0 R /FitH 232.937]
+>> endobj
+2530 0 obj <<
+/D [2516 0 R /FitH 197.235]
+>> endobj
+2531 0 obj <<
+/D [2516 0 R /FitH 181.568]
+>> endobj
+2532 0 obj <<
+/D [2516 0 R /FitH 167.839]
+>> endobj
+2533 0 obj <<
+/D [2516 0 R /FitH 153.557]
+>> endobj
+2515 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F70 508 0 R /F49 457 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2540 0 obj <<
+/Length 2326      
+/Filter /FlateDecode
+>>
+stream
+xÚ­YKsä¶\11¾ï¯\98\92¡      \90à÷ծäÝ\94]Q)J²©µ\ fÔ\10\1aÁæ\90\13\92£µüëÓ/pÈ\11¥ÝTù"\ 2\r »Ñ\8f¯\e£hµ[E«\1fÞ\ܾùî*_\15a\91êtu{¿Ri\14¦i¶Jó4T:[ÝV«Ï\81\8aõú\97Û¿}w\95ÅÓ­E\14ÆE\ 6|hÓ»\ fo¯o/oÖ\9b8\8e\83,\o²,\ f®nÞþtɤ÷\97ïþþþ\12ù¼\89DºÿÎUب$\ e\93<Ymt\ 6Ä\98Ù?:\17Î\ e¯>oL\14\ 5\1fï\81½Î\83\9f#\13]|Zo´\8a\83¿àG\a\14¯º\9e¿µ]oTÐËlx(\e\1eÝ\ÿ\e\ 6\89\ eʦâ«&ÅÌ*EhâÜ_õ\ 2\9e÷M57Q\b¦ò»>\8bÍ¢É\ e\1dféh±»_\9f³(Â(+ü\86_¦Ê\17Á\1f¶kÿÊÃ/\ f¶³\vüñÞa\91\81í\94
+\vc^\16¤â0örP@¢\13°\87ÅA\1cl[°`\1eT¶Ú´]e;^vMe\7fç\ríýÙ\89»\9a\8fl×ðç7^,«_Ë­m\902ÈövÉ&:\ e\8d\1a\8dâ\16tÕa\9e\8dÚ¶ÍI6l\85;'E\98æñüÎ\9dÛ=\90äïçQ£ÂL¥°5\ e\8b$ç­o\17\ 3ëmß»]ñ{õ      ¿r]$<®M\1a\94õÑ2}\f>­)øà\93\9d1\8eÂD\19\91-©uñuÙÿ\81¯)^\94}\ 1ëÚ\ 4g|6\18\8aùü\9eï\16eý³wÍ\ eXEEpsùî\1a\ 3L%pc\1a\18\12\ fì\85\8céA[\7fô\84á~Âa$
+ÂÚCÛ¹?Zö{Yó"ÇG\86ñ\91a|à¾\9f#\95Ô\eò¡J@Í3\ f\ e\18w:S\185üE\ 18\18}ËS[íd\ 1Ã\12¿gÑø<æ\94F\81é«A§ÂØ\8cÉüÅ\r\ fgZ\1c:\11b«c'´ÊöÛÎÝÑU   j*\ eQ\15§¡.òù\ 5\9d\1fv;8°\17:\aó Zu»\15\ fnÈMèæ,TàÒ3\a>óz\9c\87:1s·\ 3\ 2\9d&âè%7\17\14½ ÍC'¬\12úÀ·¶\ 4\9bFyØ\ 4ÚÍõ\a\0\9b\99
+S\15\7f\13lª¯Áfþ\7fÁ樸\1a\98×aSçú\e`S\87É\14\7f\92\99É\b\9b\9d¯\82\r\ e\0D=­ã3\82¥8Ä \9d±y\96+°8ÇR¢E,U\860æõ¸Æ\ 2!;Ê;R¹EÆ\8føÇ\9eá%\84C\ eÆ\8dÿlȼøô
+8æ\7f\168\8e¡\9dd3`~\ 5,³o\ 1Ë8\1dÁ\12\86\f\96q\16\\81\97Ox       \ 4ÆKØò£lõx       CÑ9\15»w\83Û\12Z\ 2å®\ 6F#\84I\10\18\ 6L\84Å\112}¡O\ 52áL\9c\1aa\8d\83öÀ\ 3ÆH\1cQ¸Á÷¹\8c\ 5\98\8c\8aP§ñWj³Î\8b9LÎT\98Á$g\ 1\92\ 1)1\1dNhY1Ý5\82\98Z\85Æ\9c\95\84o@Ê\98\91R/"å\19>mr\r\1d¬\82\187a^\88\rÿu\1d¯7)øú]»?\94\83»sµ\eÖ±\ e\9e\16.\1feá©-¼Å+\e\b\7f\aÀ"^±F¢b¾¸ZÙ-ç75VHqûCm÷\92Ýh\b$\1e\9bÎöCç¶Ha\93°´\99Eö-\19\84Ð\8dãh;´]Ï\84;$<ñØ6uÙí8z\8dOK w M\ 3r\8e$\87H÷]¹·¼íî\b1\17\90Ã\99N\1dÈ©\16\f4e\89zFs\r\ fîw[S\a\e\86_7\b\ 1ÃR\86\8e¯ßò\8cõSEp(«\8aE\0µ³;¸-¼-\92$
+>\10h}¡K£\9d%\8d¨CÖÁ}ÛM9ÁàÐÙG×\1e{Ïê\1ejA³]ÔY, s,v\bóP\e\82\ 3:T\94Á¹\80ô±ëÐpH\91H\ 6Ñ\96        Ü+\0\17éGÚ\ 3OÇD¦\19\14)%\8a9ÔÎVp\11]\0ÓãÀÛèF¬\92°ßµue\9b¥\v\9cnG)á=
+\88è\ 6©:\9c\94^}ª1÷ \12+ÓU}ø"ÊÜ\92Iâ,     ö¶lh\88ù^\ eLdËg>Æ23µ<\90§ºávÔ\r\9d\96\0âÉë0\ 1L7\84éÂ\80]ÞI÷?Óp¼þ\7f\8f\8eÝ\82\1d\9b\0\1d6\86\1cµ8\89\82\1e2Åïéí¡ìÊÁ"8ãü\1eÎtíþ¬åÛ\97سáY·/}Ó9\96\9c\87ÉÕ:O\82c\a§º=H@?æq`\1f\11e\97Ýåî§÷ÏÓ©År\9fv0\10\87ÓxjF8Af\94ý£\81hÅÉ\81ûr;\9c\89é9,rsòB\81Ïbû´¤å¶=Öh®B\ 5\ f¥4\fÔæ"¥r\8c\14c\8f\82ÄÑ\8d8ñnô\9d\10\99+\8e\82\94\1d\8c\86
+D\92²x\ 4®ç_¢\9d\17#\1a4­È\90\8a\8aC9§\ 3i  Ý\16®1I>¸lIl R×5IÇ&ÑQA|à\ 5@ácMØ\88ÛÉÿx\fÊ5\1a´\97C\ 4\ e\8f\0³¬ÏiscËnÓ\ f\80\95[&ôÐÊY\7f´:Z\96Ä\1dÝ3ü\84\18uTö6\13\14\89³4Ø»~_\ eôÆy\0[\9aL\8f©\99\ 6\ f<ÚR·\ e\83¶¡Ö\ 3Fc\1aÐ:à¿\ 3\ 3\13\fÀ¼\94\1d\ f\9c\1c\97äL©\92M\15\15X\98:k\ 1<ä:?8Æé\86¡\ 1ÌîñÃöÖã\ 6ÄL/\90\0EµíJÞÓ\bâÓäØ8@\9a=_\89\1f¢Î\8e`$È3³X2q=.\8a\15\b®_\84\12\8e)\93\r§>ßðÑTvBÄx·\15Æ5T.ö\ 5\92\ 5&q\88ðK_\99s\19m¡¥½«\85    =w\81+&
+õH\9eî5á¬Å\91\8b5\8c`xÞ\89\8d \92zPIS\ 4\955¾\\e\9eNq%5'\IéùÔ\8c<\9f¤\8f\18õ;\95\95w\ f-\11\87\9etYÐUp¨\88X\1c\180UIðq`ZY÷-\8f|½)"_o
+i*p[Ç©à\ 6è\81àE.\eùÍ'ÇQ;ÀdÔ=/\82;°Á\17WQËZÐ\83qA·Úí\81#Vã$\8dÉ\7f      4öô\93\19|Ïü\87$¼+~O\10Ù"h!     +\ eá!\1dõà\88\93S\11\11\1e:\83Ýá\13\8f·u¹?\88\943K¦ó~0QzÞ\ f"\81s¤â      ©       _[z´Ã\19uk²[N-ü¦AtGb\146åH%¹\18±/6ç\89Âæ¼xö+\ 6Kã_\10^:©ñ'e\15\14(      \aË¿\84\9cûNàÐ\80ë)\918zÌ\18=Æ·\87Fy\9cå&8ò\86À\95\93ox©¬[îy\95?}jd\rÿ\b5ãL½\84´Ô\10\8fW\v
+û*
+\96\85\8eº¯ý^
+\0c|\879 Ç¸ÊcFâ^z^à\80\ 3\a\ 6\8c\9c\18N\0£ÔE\12OG©\9dø7Àìì¼Þ"\85ê-JF߶\8b:û'mî\9fá08\15`\9aNp\17\90LvãrGå
+&\87ºÜb'\92DZ\9ao:#_*û$ÁýF÷\1fE·²qïSR\98\97\8d\7f\ 5Á¤·\1d!àbw3yîÉ ü¡\86 ¸§î\8e_\909Öµ8I5¾\0\81I¬é§Db\ 2oO\ 5û\956ô|¬í \85èj]$>\b\9eÞ\801"æ»4Â\1f¤Â\+fú±9\1céÖq\80\1e\98vý÷\8bÿI¹¼}ó?\ 1w\95\ e
+endstream
+endobj
+2539 0 obj <<
+/Type /Page
+/Contents 2540 0 R
+/Resources 2538 0 R
+/MediaBox [0 0 612 792]
+/Parent 2503 0 R
+/Annots [ 2534 0 R 2535 0 R 2536 0 R 2537 0 R ]
+>> endobj
+2534 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [288.555 567.504 316.007 576.305]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.1) >>
+>> endobj
+2535 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [276.932 475.848 304.384 484.648]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.2) >>
+>> endobj
+2536 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [435.396 244.777 457.868 255.625]
+/Subtype /Link
+/A << /S /GoTo /D (section*.100) >>
+>> endobj
+2537 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [480.136 244.777 502.607 255.625]
+/Subtype /Link
+/A << /S /GoTo /D (section*.104) >>
+>> endobj
+2541 0 obj <<
+/D [2539 0 R /FitH 686.127]
+>> endobj
+2542 0 obj <<
+/D [2539 0 R /FitH 668.127]
+>> endobj
+2543 0 obj <<
+/D [2539 0 R /FitH 630.324]
+>> endobj
+2544 0 obj <<
+/D [2539 0 R /FitH 615.823]
+>> endobj
+2545 0 obj <<
+/D [2539 0 R /FitH 602.429]
+>> endobj
+2546 0 obj <<
+/D [2539 0 R /FitH 566.508]
+>> endobj
+2547 0 obj <<
+/D [2539 0 R /FitH 538.668]
+>> endobj
+2548 0 obj <<
+/D [2539 0 R /FitH 524.72]
+>> endobj
+2549 0 obj <<
+/D [2539 0 R /FitH 510.219]
+>> endobj
+2550 0 obj <<
+/D [2539 0 R /FitH 462.904]
+>> endobj
+342 0 obj <<
+/D [2539 0 R /FitH 182.94]
+>> endobj
+2551 0 obj <<
+/D [2539 0 R /FitH 154.289]
+>> endobj
+2538 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F70 508 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2554 0 obj <<
+/Length 1298      
+/Filter /FlateDecode
+>>
+stream
+xÚÝXË\92\9b8\14Ýû+X\8aª\81è\ 1\12¬¦Ü~$\9d\93¶§f\91Î\82ƸMÅ6\1dÀÉd¾~î\95À\8f6v5.Ïf6è-ÝsÎ\95t\ 5µ\9e-j½ïÜL;ï\86JX¡\eJ.­éÜbTº\81\f-\19H\97qeMgÖ\17¢\Æ\ÛQ* ½ûѧ»Át`;B\b2|è\8eªl\7fлï\ fì¯Ó\8fï\86ÁÞ\84\82\a®\92
+\96ÓS1!°O\87V\16\f¦\9dï\1d\ 6Yj±ÝâR¹\8a\87V¼ê|ùJ­\194~´¨«BeýÔ]W\96\90Ô\r¹\aù¥5é|6Hö×\85\85ÜÀg\96ô\95Ë=iV\1fG«Äv<\19\b2µ¹"¿^l\a\12¨\13\9cyd\92þ\93 u\16ã\1cf\ f,\ap\87¾o\ 6?R\9f>¥e\ 1)Ó½Dà\ 6@Ñ~\9fIú¼Nf¿Û\ eã\94\92~RÄyúR¦ÙÚ\90\14­g&\93'\ 5ô!¥ÍH\9eÆءд4Ó!BW\89#:¼08O\87\176  \vz\80\ 5ÆÜáèæ¯cÉ\ 2\1f¤÷kÅn×6\ fH\99<'¹íøÌã\84I`\8dû\92\8c3\9dñÉt\ 1\14rß#?ÓY¹0ÙlnÒ²n\9bç\806Z!n]#Hº6l{¡K}~Èö*\8aóÌ\90õ´Äu\ 2\12£!ß
+×X|\80ÎáÂs\99R\87s\0¼\ f\17ÃóÉ\18M=\80è)E\16Iú¼ÐcL\19qbZ\9a\ eÁ!Î\93øÒÊ%¶8½
+§B\9cª\15ÎñäfÒ\1e§à5άÒÓ`\84\9a2+£¥Éêa\9b\15~\9f´
+8\1e\e4nH\8b\8dÓ\80²Úp/Û!\rB\9aJC\84G"S\9cç°G[@¿\b¹lDÎ(\98QA\87ü    ìº\17\80?©ì\7f\81rtE\81¯\ 4óô\ 65Hk\a¿\fñða|5À¾\92fyÜ\92N\1e\95U]\85;É£3\1e\fy\e«ûW³Zrzp\94T\86K\16\92Y²ÎV©sZ\9buÔÊìOv(I÷\12ƹwÂÅ8#/éßɲÊGEu\12Ä%âH³3¶oU¹\ 4Cÿj\18¸\905\ 4Ì\1e#ÐÕ³ä\8cï J-¥èµÜç\12\0\ 4\8döã¦\8b³e\96\9bíX¼Dqóþ«¦?dsØÞ\f\8c\8aF4c\9e嫨|³\1dãûÑÍÃÕ$\95JT\9a,M\ 1¹jWAáÜa§/wICR\94y\12­~Ã\11\81>â°\12£BÜ\99\94Tñd®g¢\87ÞP$q¶\9e½Ý\15>ÿÙ½k¯\82<©Â÷M´LK\1dö\9a\8aEjF¿Y\8d?\86¶àäýäÃípÚÞ2¿9Ü\80\96h\95mÖuH\ 5å2Ã\94\91b\91ÎëªÅ\99\e\8eM~ad/ê\93Þ\93|w±)}±)\13»@\9f'l¨úWA(m\10\1cIzΣ5N°\81\93x\99\18'6'AV¤\18¸¿]лáÝí¨Õþnð¢(Ï#c=6Â+M*ßÚï ^\aç]Û      à.\91\9e\93,\93U¢Ñ\94¦n7\19\14\ 3$wÅÖöjÖê\86Ï^\f+\8f\94y˲\8eë\96é
+\1cKSóÃ\86¥£å&i\11¾vÑ«z\93^÷np)9~#9Ì\95¡wð>;~º´gG¹Â\7fõ4,âHûF\18 \ 1>\10\0Þ²Á7\1eVÍõ\19\f\99.NÞÃ<\ 6ùÕã\ 2¼rî4\81A\8eã41\88\8bíñi(O"\1dl-\fa\8aî1¦\98Ë©¬\19û\9e\1es\8a«(¯î±\95¬Q1Á\10ï+Åúÿ\aµ|ß«ÕÒRaYóëׯVÌô{M»06Û!\ 1\8däV#X8\14f
\9c\91\88\ 6\ 1\91S÷90ý¼V'^H£\vÞ\ e\8c6ß#aHÌqøê¹\80\rø"Äô)*ð\0¦\14Þ\bg\82Ô2Oã6ÇÄ\epð¾¹\98Û9ÞÞ\19Zu\b\8eýîØJ\ 5Çd¸ý±µ£\99yû¿¿|\97îì{¤\947`p=¶\9dGbè\82"ïÜ\19\8b\10:\18*\1d_¸p·½¢2J×éú\19CÒú\87\vþOÐ:pxáAȵ#{ûïmï\1fÜ¿
+ëÖi
+endstream
+endobj
+2553 0 obj <<
+/Type /Page
+/Contents 2554 0 R
+/Resources 2552 0 R
+/MediaBox [0 0 612 792]
+/Parent 2503 0 R
+>> endobj
+2555 0 obj <<
+/D [2553 0 R /FitH 686.127]
+>> endobj
+2556 0 obj <<
+/D [2553 0 R /FitH 668.127]
+>> endobj
+2552 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F70 508 0 R /F14 574 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2559 0 obj <<
+/Length 1455      
+/Filter /FlateDecode
+>>
+stream
+xÚåXYoÛF\10~ׯà[)´Üì½Ë§Â±å8A\938²Ð"uü@Ë´L@W(ÉAúë;{\90"¥Õa¤NZôE\RÃÙ9¾ùf\968\1aE8zÕy9è¼8×Q\8aRIe4¸\8f\88ÄHJ\15I-\11¡*\1aÜE×1a¼{3xóâ\±¦h\8a\11K\15è±B§\17'\97\83^¿\9b0Æb\85º\89R:>ï\9f¼í¹Gg½Ó÷g=£§\83ýî½Açs\87À\12Gd½³THÑ4\1aN:×78º\83?ßD\18)Øé\8b\15\9dD\fDSÊa=\8e®:\1f\ 2^h\85$O#)\14¢\:\ 3ße\93¼\9bp©Y<èR\15\7f\9dw\13¸À3F  \8f¯\8a¿rc]D(\ 5í:J\b\10îåOXàÛb¹\80+±RL#\rñiÊ\\15£i~÷k7!\14ãø,_\fËb¾,fS\17\80lzç\16\0\99xYvI\\fí²\80ålº°Ñ        G\85¥H±­¨ðTï\8f
+\ 4a3¹:\92T#0Ä\87åCÿÊe·\19A- ý¼Ê-=ë&\12ÒùzÚ¥:^棼´AÀí ee\99\19\81¯öO@\90\15!     \11§BÆïfv!â\13ÐKXL\9d\ 1\84·-ÀXT\16\98n[    º5I+\19æ\94­­°·Ã\993:+¦\89µ+a\1cq\0EËôb:\ 2l\0\f\96\ f\ 6$DÄö­ÕÄüÞ\82µ:\ 6\9fí\1f³{'ùy\959Í¡P\94ÙtdÒL5\8fïg¥[dæ"âQñhÞ˧¾¨pÃ#¥\91ÔuM}\ 6`l;Í¡\18d%bPµ­&I\19â\9aµm\9a\8f\8b`\b\15Ö\95¶_À5A\fBçÎçáÒ\e;þÚ\85Â1e\r53x(À7\ e«bábêÕ´á°tx\9fÌ\16vÅcÉ\90³ \ 5Ë\84BF\88Rþm_®\0Ë×\7fö\ eB\93=#4\8dñAh\ 2ñ1½\1f\9a°âk#\ 3J\94uùx\1d\92\19\83¨÷D\19x\9b[\83Fs5¸µ\99àP7T´½_\0·AÂ\18øgå\ 5Ð^64ñxpO×X¶·\16½¡0Z(\v@Hæ.û ,$Âò\0\94\15\ 2¸í\872%HÔA8
\ e\90X"%7ª|\1f®    W"~?\1d\eÚPª\8e'Þì\ 3\84\97\8be\0Å`§\96µ¡aVe\14   Vû{\1dò\16\8c>\103°F²Jä&¤DÀ.â   !»1m\91Ç\8f]\80}6ö,   5ÂäFE¯,\8a *¾\14ã±+éÛº\89ÂÍj\91ß=¥Â_¾}ýÝ
+<\r\148\94W°Àa²\11\98\1eè=\1c­EB\ 5\ e\9b\14%\92;\8bÚ®\80ó\88\93\r \9b\94U(ÝÈ?Ì&TÕjo'!\0HT§ÿ§\85Qæ²çÔ\9a2·{\v \13ÐÔÚ{Í\1c\92\1cÊ0\87¹uÌa\97\96+Ì"\våk\1fsP\89(\96û«@ ¾¦Ï0s\90\14    )\9eD\1dÀ~ºb        @õÐ×\82¢\16µ-\a¶     D
+æ      D1é\ 6    ³hPF\1d\ 4¹\9e*\ 3åÂ\90VÿY&!\82Æ?\9b\v\8b\89\9d\96\13\9aê\rn\910\7fªçá\16¯íbp\90X.V\90\196Éüx¾ÌnÇ~«æ\ 4   -,>\ 1\11ÉD¬q\92\8fóI^µJó¬)Ël{µg\b\9e",6æ¯Æ\86¢ÚpaÖ\1c|^>¸§«y¨Z\963g$£ÎBoBYTA³E© (I||\90^½ÿí¬ß;ÿø­ã¿GóÉN
\ 2z\9b\82·MU\f\ 1vª­û\97\1f/\ 2ÜÊ\80!X\80[[\9a`EÓ\86¢?¶ýäæ\b[o\96\95\1e\9f©B\f^my×8Tèæ¡Â\9e\1c$q\13Cõg\12L¢Ï\9a¡[\82\1d\87õæpB\1a\96\19Ö§uýú\14\11\16I\94*\98\0\99Âé\8f!I¼\858P\9d\18\86\12àï\86Ô|\9cMóºÅS­¶;\8bÂØÓ\17,F³ñ\1d\18n×e~\9f\97ùt\18\9e\rK8`?\19|]\98]O_þC\aÐ\93CCÀ±\bdëöÙ¿<Ý\81@(æ\ 3\b\84ðãõ\17\12Ð\14\86 X²\1f\82â\9b!(·!\88ÝáAc²\e\82¤föS/\80[\b$\94À\ 6\88§ÜÏ\1aá.£eÔ\10úa\bÔ»\11Øß\81@ñÿF {\12\0áÆ4 ãiP¥Ä¥;¥»0(\9b³Ð.\10:\fVF\ 60H\11\ 5ô5\8461¨ÛuòÝXð²ßû}O\vþaðûW´àgFß\91MX\1f×\84ÅQMøxøq\9aú\8f\91`î¼Ì\1f\8bÙjá\1e\1f        Àú;{ã{ûß®P¸·
+endstream
+endobj
+2558 0 obj <<
+/Type /Page
+/Contents 2559 0 R
+/Resources 2557 0 R
+/MediaBox [0 0 612 792]
+/Parent 2503 0 R
+>> endobj
+2560 0 obj <<
+/D [2558 0 R /FitH 686.127]
+>> endobj
+2557 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2563 0 obj <<
+/Length 958       
+/Filter /FlateDecode
+>>
+stream
+xÚí\98KSÛ0\10\80ïù\15\a\v½\1f½t  ´\f\ 5\1a2í0À!$"x\ 6\92Ô1íÐ_ßµe'Nã\0\1dÂkÊI\1a{-íãÓîZ\ 4\r\11A;\8d­ncc[sd±UL¡î\ 5¢Da£,RFaÊ4ê\ eÐI 1¥8\8c´6AóàËá^»Û\ e#Îy°ÝÙüRL[íæA«\1d\9euw7¶MeAÎ\fÖJÃvùR\94ËL¦A
+\rÚÝÆ\8f\ 6\85)At¾¹ÒX3\8bú×\8d\933\82\ 6ðr\17\11¬­F¿rÑkÄ\15Á\96 \98_¡£ÆWoIu_Ê96\92"%5fBùÝ÷{×.\8c\842<è\86L\a·\930\82\ 1\9eqFEp\14ÿv\99v\882\ 6«\e\14\81ÝVJÿñ)\91ä<N§0Ò\\8a\elÀEU\99£x8r\83\8faD\19!AËMûI<IãñÈ;©7\1aøI⦠\13¤!\r\92¸\9f        Ls·Ô»\83[¬ù\92;\845w»CغÀB<@\ 3¯îa§ý­ÓÞ\ e9\v\9a[˱3\12\18\90eèX+\8c\14 ðy\142\13¤nè\92Ü\rdÑM\9bIÒË\ 4\97\80\91ÒrÁG\ 6|Τ
+öÇùD\ 6\9b\ 5u5Ç\³rëÎaó\93\17¢¢Ê\96Â\84òRè\94\10\12%\98X]Yéû²¡\82`67´\97D¹î\91ÕàªEëJÛ"EMÐ\1f{WôâQ<\1aúgé%ÄÔÍÞGu.J\9dÿ\ e\180\84\ 5ã\8bl\ 4\1a.]a$­è\ 6g\81\1aZêÖ,$\bRØjnr_A\94\0D\b/u¾lb¶¿Q¨"4¹ê\8d\11D\89\99¿pÏ´\12ÌæZÁÄ\ 4\93Äý\8cÇ7Sÿ8q\17.q£¾«3ð"\81\83\86k\82\111.0Õº\10\18vÞ1\\v\86@áåÃ1Ô\96æ\ 1×\96­Â\10Ò\87\16÷a¸@aRC!Ã\f^?7\85õyUR\89      Wÿ\fjóª0Pç\ 4ó;\1fܤ\93\9b\14R=\14\9aI/S#uÉôÃjU\84\12X@\90×Qñ\84äà\83·\ð\ 4\9c(!øz
+\9e`Y\94\8bN¦Ón\1e¿¶\ 4C%\9f§\85ã\15   \86qvO\82±y\0ç\vÕç\17nÅK\949a´?Ê0Öç\17hÓ´\9e\b\12dÕj~±p\1c8V´X\9f,[¨±\12\ 2E\15!\9f_J\ 5r{Áç\ 2ü»¨k\96_<¨`Î4Mnú©ËÙ\15\ f®frÆØ{3õ\fULÕPF
+ÊÈjʤ\96\8fn¦ Õ\9b\9a*V*0£Ì<)dï­ÒK´JBû\8e=\eWBÆáïõa\90É\95½\92\85¿n\86*2%d^\81\122©Øú)+ÎÖÎÁ^\v\1aó÷\92ù\ 2\9c\19ê\93Y6®ü3\14sýW\95LsOÉ\84Óf2\84\96\9d=¹&^«|2\1c_\r@ñ|¾ÎÿÂ\ 2¿×z=A\1f\92ìÄ\9bNv¯ûzâi!\94Ë\10>ºâªû To\19\1f^N<\96ÁÙMxåFü\ fw\17£ä
+endstream
+endobj
+2562 0 obj <<
+/Type /Page
+/Contents 2563 0 R
+/Resources 2561 0 R
+/MediaBox [0 0 612 792]
+/Parent 2567 0 R
+>> endobj
+2564 0 obj <<
+/D [2562 0 R /FitH 686.127]
+>> endobj
+2565 0 obj <<
+/D [2562 0 R /FitH 500.697]
+>> endobj
+2566 0 obj <<
+/D [2562 0 R /FitH 464.831]
+>> endobj
+2561 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F10 668 0 R /F13 705 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2570 0 obj <<
+/Length 1533      
+/Filter /FlateDecode
+>>
+stream
+xÚÕXMsÛ6\10½ëWðH\1e\88à\e`/\1d[\96\9a\8eciÜñ$9Ð\14-sj\91\ e%'\13ÿú.\0J$%X²\934mO$È%°ûöa÷\818\98\a8øcp<\1d¼\1aë A\89¤2\98Þ\ 4Db$¥
\96\88P\15LgÁ\87\900\19}\9a¾}5V¬k\9a\12\ 5óX£áë£óéè"\8a\19c¡BQ¬\94\ eÇ\17G§#÷èd4|w22ó\fp³úh:ø< p\8b\ 3Ò®,\15R4   ²ÅàÃ'\1cÌàåÛ\0#\ 5+}µ¦\8b\80\81iB9Üß\ 5\93Á{O\14Z!É\93@
+\85(\97ÎÁ³t\91G1\97\9a\85Ó\88ªðÛ}\14Ã\ 5\9e1Jx8)\1esã]@(\85Ùu\10\13\82\12!ÜÇ\1f±À×Åj     Wb­\98F\1aðéÚL\8ay\99Ï~\8fbB1\ eOòeV\17÷«¢*\1d\0i9s7u¾\ 4\9bpUG$,2{[ÀmU.-:~TX\82\14ÛA\85'z?*\0Âvru ©Fà\88óúübty1\1a\fwQÔ\ 2(À×ù¥'Q,!¥oÊ\88êp\95ÏóÚ\ 2\81û@\1dÕuj\f¾Ù\97À"©D\ f%\r¨S!óÊÞ\88ðÈ­ÜóT1D\ 4[/}q~õÚ\19\11Þ1b\12QF×F\1f\9e\99à\ eÈÔNôçn\9cÜðx³XZÇÖõ8Q\88Á§½èÖ±Å\92è0«\1c\14iQ\16åÜ<Sáê6ß¼\8c}ø¬r÷\11P@\13\1cV7îj¾s\11\92\8e\158Ýì°&E\84\ 5\12%\8ai\v\14J\80\ 2\fIÒÌ\8fwã#\18iI\83¸cu\7f\97\96\8eí1¤\88jÕwÒxÅiâ¢áàî}\9d\7f\87¥{\ç7y\9d\97\vð¦\86}\86<\99\88\88¨õÆ\92=úE\8c\86Ãã'8(þ-\ e2E[ê\f\9fà &ì\0\a!\ 1¸-\940\93\9f\84´\r´GBö"\ eÂà\16ªÉ\vh\88©£!&OÓ\90h²)ô\8d\ 5îÑ\90P\ 2+@AâÎêÚÃCX_Ë c´MCýëh¸Åø.\r/~\94\86ò\10\råÿ\99\86ò\9f¡¡J\88M¸JèS4\94H+~\88\86=\16Ö\1e\16RDáõ¯f¡¿­s!\10¸õR­ãéê0\17tõD6Ù¹\8c\12    é+Òë;£6\98æáÃ2\9fý¶Ç\15Ì\11襽¾p\86\14!{t\97RHH\16°Äl1ÞÕ]L*bt\97vºK{t\17dFó\1f\91]\8c'ûeת.2óf\8fÐbJÚë>¡u\10\86Fg1i²K\9d\9bãéÕ¹\91Â\18\i\v\87Q\7fu\14\vÉIH¶ËÁÔ0\8e1îhä¢Xu!D¾²söþÍ\ 4¨\89\95è\15\ 6\ri3u³\86\¯ÁÂÒhâ\87\85ùàÚÍ^»\17À\7f'þq'Dª)"x#¬>\17þrßn×/\11,\96Þ=äKçt\f\9b\10a½ÕÛ\9cë\9a\8a\9dÚ*9X\91¾uz¨ÏË\9d\ 2[\1ad¸Å(Îïò\85Á¿©AîM;'\f\85?x¢\19â­òô\ 5\ fg\0\820øÑsx\17\ 4\ 2 à-\10\8eÍA   Z\f%\98=\v\87\83z\87xpØí\ f\10U+\83Ï\8e'»QQ\88»\15\ 2\16À\rxZè.xfèÀ\vb.\10f;;\9b\88t\ e¥I@\90E9+²te[\87\09òõ\16ÎE@Ç[7¼¾«,#33÷_K_¡Më\86Æ\993\9då3/ÄÍ\1e9=>\ 5\8c'ÍQí§`Ì\9e\871\9c5ð¦¿\9e\9dúP\ 6\84ò£\fM«AYY\8a&l\83²\80Ʀ·\b·FÃ"kø¼¨ì¡wf\9a\82\19ßTµ»ÉS\8bîmc\96fuåù\9f\8a},>½\1c\r§\13ÃbE;èÅDJ²öÙ\aô35þe\ 4çø<[Uõ²\9b\11`hBÚÍO`\8a«\b\9a\9f\89×\8e¼YQæw\ 1=L}êO
+\ 5D;Ô7C#\1aÌuQ5
+
+\1a\97â[¢³mR_̧¹û\17`"²\ fmnÌM\9b\eÓ\f\
+ThwÈN
+,\0d]Mm®lMåLþ\1c\9eÓgñ\A\9f\ 6-ò½\882\81»\88\9a¡·\12Ã2\98ê¶\10{+11\87ää©JÜtØïÁº;áðÝh<6tçÀ]Çae\ 1W/\ 3\9c      E¸W¼ûD6\1cqdVO\94\18Ð^Lì@ß;/P\ 1\90\88ÝóÂÖo\ 3*7Å^r@Dénñ1CÃssýü\906
+?\16\fª=Ýfúc\ e2L(\1e\9e\f§î¦©M9t\ 2\99\15\9bÔ\9bW\90\1dÑdÇ'ªM®(\b¦6WfÔ/MîYQ\9a+\r\1f\8b\98ÎÝê\9eåõ¾îp¶N&\94.ýsv\8dúïu`w\9e\ 1p²jý#\94\84[Éà\0WV=8\1a»¡ë\18ðÙ\ 6ýçµ\89Í_ßÎßß¿\ 1º9c\17
+endstream
+endobj
+2569 0 obj <<
+/Type /Page
+/Contents 2570 0 R
+/Resources 2568 0 R
+/MediaBox [0 0 612 792]
+/Parent 2567 0 R
+>> endobj
+2571 0 obj <<
+/D [2569 0 R /FitH 686.127]
+>> endobj
+2572 0 obj <<
+/D [2569 0 R /FitH 440.921]
+>> endobj
+2573 0 obj <<
+/D [2569 0 R /FitH 405.055]
+>> endobj
+2568 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2583 0 obj <<
+/Length 2102      
+/Filter /FlateDecode
+>>
+stream
+xÚ½YK\93Û6\12¾Ï¯à\91ª2\11âA\80ÜËV<\8f\8dS;cÇÒî\96ËÉ\81Cr4,k$\85¤<N~}ºÑ ERÔHöºr"\b4\e\8dïkôC
+½¥\17zÿºx½¸øáÆH/a\89\16Ú[<x<Ô,Ö\89§c͸0Þ"÷>ú\86qÎf\81\7fùööÝ¿¯\17׳@Jéß¼ÿñÖ\r¯®/ß^]Ï~[üüÃMÜS(EÌ\8c\9dUÅ¥A\99\8bÐYp½¸øý\82Ã0ôø~sm\98\11\89\97=]|ü-ôrXüÙ\v\99I\8c÷lE\9f<©$3\1c?\yó\8b_è$ý}¹\0\ 1­<\1d\19&\94¦ÝïÒ§\ 2ÌÕ\86û\8b\99\88ý?¶³\0\1e8'¸òçå\9f\ 5Zçq.X¬¸\17À¹\93\8f\7f\r£ð¾ljxr+%c\16\ 3D}\99y¹\\17ù?g\ 1\97*ö¯@1÷ë¬*·M¹Y\13Pé:§AUÔMUf¸R[L¦±\90      3ò\0\v\95Ä/c¡\92)V\81\fØ\9al}ÿîÃÿ\ eùÒ
+NÃ[ºÞ¬\11¦¦X\16Õ,\88¸\12¾\b\ 12\11iÿnc\a\91¿xDü\12ã?\97yóHÃÍ\ 3>µß<\16´\ 5\98·ßC O$í\1e\1f\9c\84ô4K\8c\8cQ°\ 4\ e(\99æ\8e¹pÂRfTì\ 5=¡í*]\17\9d\ 1HQ\90(¦b5$²±\ 6\v\r\f<\14U±Îì«ñ\1f*p\8f\9a\96Ê5ÍmË/Ūf´û\0Ó\0<\86\85¡\1cê\ 6P\7fú~ jå?\16åòq\ 6\964ôn\91\85ç1d\13¦¤>\ fÚè\ 5h\95\88\bÚh\b-YÐB\e\87æï\84öòûù«\8adë¯8DTñy\ 4\19Xãö¸t\12á\0T.ÀZ¸\96ÎØûCKc\ 6\ 6y=\19\8c\ 4\13\9b\85,\82¸ub3>Ø­:Ü-à"b"A~ ZhÞ£\11yP!y\92âpæ\19·!\10Æ}Ú@ÄÑ\86t\87C2J\17;\81Äïw?\94àíý\88ñ~(A§ÂùãLj\13\9d\89®z\81K\9ep¯'s\94K¡øy\8e£NQ©ÿN*Mx\92Êûòë\89\94z\92H\11Å`F^|Áab\8f\83SM»\96í*8\8ac\19%îWø½ñ3\8c\8c\9f(g«\84\85\91p6êáÙ²\8dMôyárï¦Ê\8b\8a\1dϺ*á@\8cþ?+\10Îb\b½J\v¦\85\ 3mñXÖh
+À]¹#\14ù®*hnW\17n5]­p \1c\ 6\9d|ìäkZÍ\8b_C®Öx,\94Áãâ³õ\ 3ú®ø\nvNo]dT\8aà×\16g+^\92g\ 4Às¢Fé2CÜ\1fÓm\83,Ê8ñ\9b\r>\11Í\ eVZH×°mNã
+\16×Pàì²\86¤S\9aÏ6OÛUѸ/\1eà\83Ê\16\87
+S\87\89ÿ¦q»¤\9fpcë⨻&5åz»s\12\9fgàHéj7rkG}ϺÜÖ|p\ 56O4¢4\ 5\83Ç"\ 5G¨_Á\9b\89h\ f\1dûÏvcd\0eh¶÷ÑÀ\e\7fÕt\9bìà8\91Òþ\8fîëÍ®\ 1Ã_M^@TÃ¥¿,?w'æÒí\a\83Ý:«6[Wªæh+7}|íù@Îî\vÛ*\19;?ÃÙúq³[9\89û®Ü\85\97V©ñ[\ 5\96X\8e\91 kÐ''l­\8a%U²:lµ=lª\82&ò²\86¨d\vë\19¸\15\94C\80[\a\0¡Ú\1d$+Ó\15Ídi]¼rXÓL\18Ü[-\8dS¼M­\13~ÂÛ^44gÏ\aϦ*R\82\0^\8a/iÖ¬þ \97UI\1e4u\8eÔ\ 5\86Ò\85(tÀ\8a¦\1eÈ!qø\Ú\82\16Fk\84\83@B\81(¦Kò\89¢g×Ü@\b`Ü@
+\86< \ÕÍG"\1f\83(\fý7\ f¤\8e8\87}jlE(T\8d\97ò´I]Äî`\89    \16Xµ°X\83×Á\9fEµùÇÈ"H=\123IÂÚ>\0û\9a´mjÆ\86]\rî¸iÍ0ª\83        \86\0Åy;ªHºwE­äÍâûkä:VþÝ/oævØöD°\ eSôá®.×K\9asÁÌÆxè\v¹\1829\8c\8btøö&­\1d&\8eì¹\v~xN\8aøÕÒ£Á{{b\14\82\8c<\ 2Â\1fQ\16ð\98        \rõ1\8f\98Týîð\18\8aÿ¡Ó(pJ\87Àa½\14ð+ûîæ¯ç\87Ù\15\8aûXuÅ=`§\12±¯<\ 6Ú°Ñëòðݤ2 \9d\11\1f)\e\84t(5ºL\82ãUY7t\b[dÁLÿ6àüð6¸\94\12I0E\8c{i\1e¥Ëzp\aÝ\r{\8d¿#\ÑJë\ 5}÷ßçMô³|\87\19Ä-\rh\97\8evu.íò$íà\1aQ|H{v\82v\99Ä/Ðn ×ê8½»\9d¢J*&#³§êP\vT-qr\9anѧ\9b«c¾\ 31"ìD\1d\1f\a
\90q9V8,        \926i\ 2\0O)ä\eò\b\ 1a±+&]¶\1ey\ e(K:ï*±¬XÒÜS«¾¦÷½ïàÛíë[0vN/Îy\14w\85\8d\83\ 5Îõ¼Æi\9cÈ\17\90úÖÐ\91\1fó!Ì\fB%ä@XüBæ\ 38j\1a¶Q\9edPQ\9bÐ*\12°Q\1au\ 3ABk\aÊ!ç<IÀ¹»\1e÷ÝÍ!á`r¨^rÂ\88\ 1~_çÉÖ&ÇÚ«É&RFÌ\84£\8aô¼x&TD\89E\886ª¸Ù\81\97
\82\v\ e\9e6®:\86OÈ+²fSÕ´\88Ð\1aëkøvûßëËÅ\9cÆ\1dªh°5câW\11)\8fç*3
+Zgçªè\8clu$l\15/\87­C2\14(0_\99T$4k\1döøB©>Ú§\7f¬\e\89\ fCQ\ 3\9aB\ 2\f\84\86}^°*\88\94ÕD\93* uÓº\8b¤¿Ot§X\8eí­\eµ\ f°MÈ¢ñ\8f¾ýÜ$¡<±ôÙ"\ 5\12\vÒN¡       ßN³üÍ\15\89>ɱ\ 6Ó\93C\8e!x\98Øÿj¢\15ÜdóUDOE\83Ä\983¢AÜ÷\16!zÞ"\8e\157\ 6¼¾\v4?-¦Í\93!\1fi\1e&'\11î\7f.\81ñÕå\ 2\9b\9f.ë`c­\ 3WÂ$\90ëL4ÌXYéz@[Úò¾§ÀÛÝåÛë\9b\9b9½¸òv4Û\95¸¼-ªù¡ëÀ\ßuh\9foÏOçU9Tc\8f\iyª¸í¸£±=4\ eºð\1e(\ 5wf\9doö¿ÐY\81«Kzn«"/ÝÏ\13øÞ>ÝOy\93Õ?~+¹\1e°FÌ\18b\ 6Öj\báÔâº\1f\9f¡}î\88àº#\82ë¶ç6\a¿Îà\\9f\88\9e*\80>\98¢ä\1c\1a\a\\12\8dÿsô:61ÙC¾\ 5ã«ç².\86-_ï\9f¶¿\0ú\82Èå
+endstream
+endobj
+2582 0 obj <<
+/Type /Page
+/Contents 2583 0 R
+/Resources 2581 0 R
+/MediaBox [0 0 612 792]
+/Parent 2567 0 R
+/Annots [ 2574 0 R 2575 0 R 2576 0 R 2577 0 R 2578 0 R 2579 0 R 2580 0 R ]
+>> endobj
+2574 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [271.474 348.2 286.197 359.049]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.1) >>
+>> endobj
+2575 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [404.974 320.9 419.697 331.748]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.3) >>
+>> endobj
+2576 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [187.567 283.582 202.289 292.382]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.4) >>
+>> endobj
+2577 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [288.632 242.389 311.104 253.238]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.1) >>
+>> endobj
+2578 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [358.98 215.089 373.702 225.937]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.6) >>
+>> endobj
+2579 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [187.567 177.771 210.038 186.571]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.3) >>
+>> endobj
+2580 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [173.176 138.516 195.648 147.162]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.8.2) >>
+>> endobj
+2584 0 obj <<
+/D [2582 0 R /FitH 686.127]
+>> endobj
+2585 0 obj <<
+/D [2582 0 R /FitH 398.062]
+>> endobj
+2586 0 obj <<
+/D [2582 0 R /FitH 374.802]
+>> endobj
+2587 0 obj <<
+/D [2582 0 R /FitH 347.502]
+>> endobj
+2588 0 obj <<
+/D [2582 0 R /FitH 320.201]
+>> endobj
+2589 0 obj <<
+/D [2582 0 R /FitH 282.883]
+>> endobj
+2590 0 obj <<
+/D [2582 0 R /FitH 241.691]
+>> endobj
+2591 0 obj <<
+/D [2582 0 R /FitH 214.391]
+>> endobj
+2592 0 obj <<
+/D [2582 0 R /FitH 177.072]
+>> endobj
+2593 0 obj <<
+/D [2582 0 R /FitH 135.824]
+>> endobj
+2581 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2599 0 obj <<
+/Length 1726      
+/Filter /FlateDecode
+>>
+stream
+xÚÕYIs\1aG\14¾ëWÌq¨ò´{_r\13\b,¹,Y\ 2b\97\80a$Q\85@\19\90\9dä×çõtÏ\ 6Í&;\87\Do¼ý}ï=\84£\87\bGïNÚÃ\93·=\1d\19d$\95Ñð>"\12#)U$µD\84ªh8\89ncÂtënøþmO±úS\83\113
+èä\8f:ç§×Ãn¿\950Æb\85Z\89R:îõO/»îè¬ÛùxÖµtN°ç¾í³;<ùó\84À\12G$¢\ 2#£t\ 4R!EM4~:¹½ÃÑ\ 4.ßG\18)\90àGþô   \84g\bk\ 3ëY48¹qÚqS\93\99
+\89\8c\90\91\14
+Q.\9dä×=§]Ý\ e\f\96B\17ºõ¯;\9fA\v\8d\8d]\9eçJ\84\85\14\ 4IÃ×\85äFï\16²Î\9aJ\82\8c\ 6\199FTk'\ 1n%\94b\11{G\10^\97\95#Âi!ëW\8c\99{ÔÐ\!bdñ¦wÙþ¼©³\10\88(Q¼   q²DÄ\ 1\8cD\8dÑù&£\84\100\17fv\ 1f\16î-ݧ";\92sHE\foJ:D\ 6X\11
+VPÿ\95\92¬\95\10\ 5J\ 6Yÿ/´Ü\12ø ¬\ 4\82Gd'Þ\8aA
+\92\14\18\vM\11gƱ\1f¶4\8bGßfi\ 10ÚüÖJ8çñçédõhOy<\9aOÜõy:}xlQ\1d¯Ü~qï\1et\1e³ÅÓÈ\9d]ÏFótéÖ÷\8bÌ=HGcûµGÿdúW:s\17½\96æñ"{\1a­vB\98\82äM\18A\9a\8a¼\ 2\8fà\ fi|5ºM\ 4Æñér9}\98;~½á\97ë®ã·zô\9a~o        \19\8ff/©;'îÔ\92\9cÎs\rÓÌë\90\8d\9eà\11\89sN$FMn   FBp\88F\81\f'\95\ e\11ìêæb°G®5v\ 4\11¬<·\8aÙø\10fÀë\16ßíf\a±´¦^\98ád\eÃ\9e\8d§ÜëRÕ½\ e;`%,+°¡å&µ\r\1fWÿp-L\rDi\1eÎ9³oÓÍ<\84X`¤xp\ f\91çèc÷±Z¸O+f ù¸F\86\94ÙwÕ\1e\ 4²\98\82²ÄÔ²\18\a\84\00Ðe¦\13k\8f7ÀX\815\v\9b\83\10m[\9cÏnCj\ 2z\11¹KM\8d¤(ÑæÎ+\a~\83\87QB!\99%åM\14\sæ?i¶Xw'`¡ä\1a¾\ 6|\8a<Z÷ùfèô¯¿ØBÍe\ 1\ 5Ô\1e\9d»K\1fK´t°Ë~\9a\8c\92\86#AÈ~\98Tz7"3\8d(«9J\10ǹ\ 4¬­"p\8a\84> æ*³»\1c1\81(&u    Þ8\a1[
+dQ¦|K\94¥Ëg(Ç:NÇ«éw\9b\eéìo\9b1\eY\a\9a^â;½Ä]\ f\ 5^âÔëï\8e Û ³Ê7¹£ì¢\8c\93¥Û»\1câXWO²\85\95î\87ÛX\98··U±°\92¸Z\95=DnÑÏe²Ïl\11Y\97Õ\92\19/²,Mró\14úÕ\82×[f1\9f\ f\16\ 1§\b\88\1dUæE¨É\ 4¬Â¼ôɺi¡ú1Î\9b\15AÛþ¾´\92lJ\0M¬4e\\9c¶ à:\83Îé\87n eà\88±\12\84ÔAT\94´ÎvЩra\e\99òAûr°I\ 2@\8d\19r0\8d«\9b~\80\b\83´a\87\13\ 1\1a\17\7ft\ 3t\0\855fGÐi_^\84È@­`b\17\19ÈC\890SÍ<,a¿a \86¸®é\96\b"<\80ç\e\1e_¶/a7ðW\97\9fº\9dáÀ_u>v{½âæ
+v\90\ 1\94^\ f\v\9eI#òo.òÈ·o¬¸\1em\81hµ?/\97\9dµ«ÎyHm¢\\9fä\95y÷ñÃY¿Ûû²©´\14HH³Û\11µ:å  å!ßÞ¤¦ ­©:Â\1fb\93l?@\96\ 1\10ï   \16\Nj×ýî§-Êr@¦}Ñ[\85¥'´CYÌk¦K(w­ò&Yëu©CtûAº|MJg6®Öê}\96\8e\17óå*{\19¯l\ 4y\84·\8bñâéy\96®üî>\83h\1c=Ù&6?ѱíqU\18_        Ìð\8c\96Fèw;\ 1K2\ 6 º'\7f\15«\13     Y\10&qM\1a\164z\9b\ 5¡o\91´N/`9\ e\83\ e¼,\13o;\f!\a|\1a¶«\8aÌ£o\97\9e¡æA_\15\8fÓÉKæÏ\1e|\95ö}ÐÔ\7f\ eÒ±5æj
+v]Ì·WCKB!\83øZyÙYï=FÉ£j\12·Ca\99¦\1fz\1f.B5Àv=JÖ\fÎ8iÂ\rÇ%ÜäW5¸qû0Ü\b(ªUâ\1c\ 6¯\96`      ¯vã=\ f   ¸Îá[k(iñ\91J\13\8f\9e\9f¡kJ¨ðγ\8bÙÂu\ fÏnû\15\13>ËG¸ü\95½\14¼z]K\9c\8eü\98g\97Óy0\85\9dL?\9d\16¼Â\8c\ 3Ó¢\ 4\80\rÜ\fç
+D\11S\aä\8aдÊ\95\9fÈ\a\1e\ fÜLGbhkwç\83ý\89\ 1F'¶/!ìx£×º4\15Ì\88\8bü7\bS\ eù\10ÁÓ¥;²\ 3\90;©ÍõÙÈ]æ\ e/Æ6\e\93\ e\98SC\13\87Õ¯¨¥\12F\ 2þúZzT\14PûË\91\b1\vÕ\1c\ 5ðQ>vS\80äõ\89.\09\80kU/øÚ\84\0ÆD\1f['¸QÛ´ÖÐå²}±O\10­\8a\89§W\8c&P\84¬b²Ù1¾~nÓ»æ¶\80U9T\7fókz\19#øk{\19Fñ6\v\v\83ûZ\19\81$o\86\15#ª>\7f\ 6:D
+ß²ÝR#Æ_\e^\90.úèð²0µUy.\8f\8d.KîÀÉ¿ö¯\9a\7f\ 1\1d¿\12¬
+endstream
+endobj
+2598 0 obj <<
+/Type /Page
+/Contents 2599 0 R
+/Resources 2597 0 R
+/MediaBox [0 0 612 792]
+/Parent 2567 0 R
+/Annots [ 2594 0 R 2595 0 R 2596 0 R ]
+>> endobj
+2594 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [456.639 436.099 476.343 446.947]
+/Subtype /Link
+/A << /S /GoTo /D (table.7.89) >>
+>> endobj
+2595 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [337.117 344.442 359.589 355.291]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.9.4) >>
+>> endobj
+2596 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [410.536 300.607 437.989 311.455]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.3) >>
+>> endobj
+2600 0 obj <<
+/D [2598 0 R /FitH 686.127]
+>> endobj
+656 0 obj <<
+/D [2598 0 R /FitH 594.394]
+>> endobj
+2601 0 obj <<
+/D [2598 0 R /FitH 560.576]
+>> endobj
+2602 0 obj <<
+/D [2598 0 R /FitH 546.13]
+>> endobj
+2603 0 obj <<
+/D [2598 0 R /FitH 530.19]
+>> endobj
+2604 0 obj <<
+/D [2598 0 R /FitH 514.25]
+>> endobj
+2605 0 obj <<
+/D [2598 0 R /FitH 486.853]
+>> endobj
+2606 0 obj <<
+/D [2598 0 R /FitH 453.035]
+>> endobj
+2607 0 obj <<
+/D [2598 0 R /FitH 421.155]
+>> endobj
+2608 0 obj <<
+/D [2598 0 R /FitH 341.454]
+>> endobj
+2609 0 obj <<
+/D [2598 0 R /FitH 297.618]
+>> endobj
+2610 0 obj <<
+/D [2598 0 R /FitH 253.782]
+>> endobj
+2597 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F49 457 0 R /F14 574 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2616 0 obj <<
+/Length 1482      
+/Filter /FlateDecode
+>>
+stream
+xÚ\95WK\8fÛ6\10¾ï¯ÐQ\ 6j®øÒ£·¤H\82´\bR\ 4\ 6Z Í\81+Ñ6±\96dHÜõn\7f}g8\94lízÑöbRÃáp\9eß\8c³d\97dɧ\9b,®ï77·\1fU\99\88\8cå¹ÐÉf\9bð,ge^%º\ 4\1a/\92M\93|Oß\1d\8f«µä©í\1a÷\ 4»B§ïV?6¿ÒeÅ\8a²àx9KÖZ°\Ñ­¯»\1dñ¾w~ô\835-ÞA&Q±²,\89ëCW\9bãøp0ÞõÝ,\94+&U.¢Ð\1cuáQ\17ÆWkÎ\85N¿>®P§áÑÙ\13],\93\8aU¹Èã5Q°¬\14tm³w#hSÊ´éWkQ¦õCk»\15l<\91G0Q\14©­Ý_\19W62û½¥\8dm\91÷.\µMãº\1dÑû\ 1W\91\ 2\e\15OkÜ\ 4\8bà\83\8c"Æ-­\9b½í\aCû£©Qê=þX\1f\9ftÝä&ÎY¥5éoP\8c\94Ñ©R¥~0]Ô¹\1f<ÑÈË,Ü\a\ fVJ\81\10\f\8f¼\8c\b<\16|\ 17\r}Æè\ 4R?8ôK\91\10å4\18\8c?ê8\10ÿ6X\rG5ù²±ÍOH¨Ò\83ë¬\89\87Þµv}gF\92\ 3\e¶Z+%ÒÏ\9eHÇ¡_\am׳º\176?º\ 6ã ²,\1d\9f»zè;÷wð(<¦x\9e\86\90<\1c¼;\1eì\13D$\92·\83iÏ_v\18P[\14ÒXok\8a\b~\9a\ e\15«ªt´ö>\ 4\14©\a ¯¯E 5Ã=j\93\1fÒ\93Ò\ 3)\8d\9d]1\10%HG\9eºoA¿6&\b&Üøâ2¤\ 3\90OôqΠ    HFO\9cð^k<\9d?\ 4\7fâî\ eù\9ei\8f²®è<'\edά`ýv\82P\95(\95\12$\9bq\ 4Jà)Ò-fx\8bv9Lvg\ 6çQígâ=9¿§\1dY\8aR­7î\10\9fÀ\8aX\9c\86ôÄÍèÁ{fhØÛ¹±ÁK\ 2\82÷§;îY?`bc\88\1d+\109!Ù\90\14³J\86\f \13¢\a\8f\13\9a\10uK+a\0°\aý\ 2eª½\92j\ f\86Ð\17íµ@L\11\14\95\0P@\ e\0a\ e\Yr\9fL»ß\0\8d\vu\81aJ²"\97p\12dì½?þ|{{:\9dØS4ú¶ßín\9b¾Æ5\16ÿÞ·\87(\9f@~    \8bB\b¦K=É\fY\1a\94¢\85\ 2d\9bé+V§ÈsÀãriÓX\ fî\18Ý+³ÿa\96æ\8cÿ7³b)ÿ«QYÅ\ 4W\93D\ 4\19\9eÅ\14\ 1ÍfçC»p\90¨#mÍaì'ó2&\8bbi^c±\11t\ 1½2\81°\1cÖo\1f1O~¡\ f©¥¤Ý÷\vã\87]´ýÛ§\e\10ôûÖfr¡=\10\7f \92\0Ù\7fìÁÝ$b.ÖìZg\0\86:4\81L\866T¤\96>^t¦\97ú\1aZN\90õ×\12óq¥¡ª\ 1ó§Ê\15\92*\13W\ 2­&Ô6R\10ðcY\ 1Î\ f\f¶½\86ö\94\84\ 1LI@\8db÷¦sc;\ 2"\v­©\9e\90ù\ºÈûq\85\ 1
+\7f\9a\ 4f]sÒu\0\90m¡°\eô\87â±\9d)H½\91VªT8é@Æcð\1d\1dL\19\80gÔ¼Tvö7ì\11\14z:\ f\8e\ 3\12Fÿ`×±\1f\96±\1f\ 2ÃèáÚÎ^ïÒ\r\81m@\88Ö\8d\7f\bôä9ûäGv\9esÂåiÎQâ<\17Á\9c3O:_>\7fù@£\94Ç\91ç9Nc×\87\1eÉrÍ/@RUYº³\10.Wã\a\8fÒ\90ìC\a\89½\9dH\ 1\94\81ÉtSw©"ð!\95|BDè\14áýEió
+öU>ÃËñxpu\b(Öôk\85\8b\92)­/
\82\96\1d16Îdu,Öp\87/\1d\1fmʪW6ñ,¶ë,"9nÈ ~Î\ 1$B\7f\98í\83#LûE7\89#\11²îí\10%]õ\82È\vV(1\99\15\92ëºý
+FÔB^Ø\9f\17\92ºp°UBë+¹^\96AhÑz²F\97\93ñ\1a»4\16ñq\82\aä\9a\8b\ e\ 4ò\ 60\93±Q\18¤'\16   \8dA(©\9f\1e¡çÊt\1e\ 2ñO\0hZ
+\82Ø+e°x\13Ë\81\9eê\f\ 2
+\16\ 3\14\81í¦Ú\90\92Î\99ª\8aÙ7ýîñµÿà\9fK%øÙ\7f4/ä\82©b\1a\1f\80¯\ f~D\f\84\12.h\18W\ 5MÕ°ÚË?!8Êj>\81I\91¶®\8d»¥{¯e¿f²ä˸{J±WªCK\15b\ e}kb½á;wSöâ\a\r|Ð}1&±\ 2r¦_vãÁnÃx.å˲1\87ÃsD¥>þw\b¦I¹\9c\ f\11ëaV\1dV\9cþÍ\8cã\14¾ \1dQöù/ƹ\9dñ\1cþ®\95àp¡\99È"øpY-¸>lnþ\ 1CÍÇd
+endstream
+endobj
+2615 0 obj <<
+/Type /Page
+/Contents 2616 0 R
+/Resources 2614 0 R
+/MediaBox [0 0 612 792]
+/Parent 2567 0 R
+/Annots [ 2611 0 R 2612 0 R 2613 0 R ]
+>> endobj
+2611 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [149.635 305.89 371.302 317.015]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.xiph.org/ogg/doc/oggstream.html)>>
+>> endobj
+2612 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [157.036 293.935 368.242 305.06]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.xiph.org/ogg/doc/framing.html)>>
+>> endobj
+2613 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 0]
+/Rect [200.663 284.194 226.87 293.105]
+/Subtype /Link
+/A << /S /GoTo /D (cite.rfc3533) >>
+>> endobj
+2617 0 obj <<
+/D [2615 0 R /FitH 686.127]
+>> endobj
+346 0 obj <<
+/D [2615 0 R /FitH 668.127]
+>> endobj
+350 0 obj <<
+/D [2615 0 R /FitH 453.419]
+>> endobj
+354 0 obj <<
+/D [2615 0 R /FitH 223.211]
+>> endobj
+2614 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2622 0 obj <<
+/Length 2287      
+/Filter /FlateDecode
+>>
+stream
+xÚ\8dXYoã8\12~ϯðÛÈÀÆ­\83º\1e3ÛI:»Ó\a&n`\80\99\ 1\96±h\9bhYòJrg²¿~ë"%;Jc^l²X,\16ëøª¨p±[\84\8bû«\9f×Wïî\8aE¹*³8[¬·\8b(\vWY\96/²"[Eq¾XW\8bß\83H\85Ë?×ÿzw\97'\13Ö\128\93\18Ä\10ÏÍ\97\9fÞ?ü¶¼N\92$¸Y-¯ALðùþ\9e       ??¬\1f׿ÞÞ|Ä©
+n?ýóæËã×_n\96\85
\ f\9f?¡ü«P´zw§\8aE¤V\89Êb<éZ\8eº\8es8=\91\ 3Wñò:\8aâ4¸=,\93(x\ 2ÉQ`ªÊ6;\18æi`\eþ×üW·;»Ñ5O\9eìÐ\ f\9dÑ\a¾ØÔ\ 4!\9c\93¬Â2âs>ï@\9cJ£ 7GÝéÁô8\r\83ao\98¾i\9b\8d9\ eLm·LÔb°pj[¥V`Wg±º]\ 2\84\7f¨\97Ê\9c^H1D\9eÑ/W«REN
+\9cÞÛ~ KãÁ¬ÀD½m§\ f²Jê\81<¸`T®2p/\18pU¦)\8b\ 2;©¸\fà\96\83Ý\9cjÝá¼\80{ÿ÷dà\8a¼Jò\91k\89\97¼\86ë/\81ç\eþ\98¡ç5ÝT¼uÓ\1e\8eµ\19dë³\1döè\13\1cÛ\ 1ö÷¸ßÔ[fÞví\81\17Q÷×æKÂrU¤îÞÇýKïMGw\92õ³+ý\rsªx\95\97¥\13û¼·t¡=\84\89*\82\83ÆÉ\vOÄÔ8É\ 3\ 3\971\1d/ M\90¦yÚ\83¹kä1è`a\f:ÞÖ\9dmkð¨Ó\ 1\7f!\96Ñ\9e²î\9c&\9a\9e]ÐËWQ8ÊïyN²Nõ`Á   \7f\99\8a\89C»3¨:f($Âzo\85»7\9bÁ¶\8dL\8e¬ÂÆþ\11\b\v\a\15\fÌTMN9T1<W\8ec1\873LÛi\1e\1fõeÀ\0\91¢"%Kàßx)\98Hþåãí@ó"BÍ\r/\1côñ(\11\9eû3ý69|ª^vi»8\9cú\86\ 2\13i\96\2´8\8b8=æ\8c
+kÇ=ÅI?ÊãóaÉI%\81=Ó*Óo:ëÌç\ f£\7f     þK[6æ¯\81¡Tü´âPF¤$¶X°+\89ViXz\8c\E\82\92\1f\8c®L×Ïâ\1d¢\81\18\85¬\9aä   èc\aËp   \93Ê°-(\1c6\9a\ 3\ 5Wö$\16Çê·¼\ e¾ákj8\9b(O.¥PîÐSþãn+\125ÿù,\821\19\13\aG½3«9óp\18ÇeD,8
+Áʨlcd\81\82\17é\ 4;\ 3À\eüò\12\ 6Í\19\8b\ f\r¤:\ fâ\ 2A^\ 3;+^ûøõqÍ£=\ 1b\9c\aßéú\17\ 2ÿ#ÎÞÙ¦ùA¶\90\7fé¸\9f¸PÂ\rR½s\8e\1føî\11V\0\ 5»c(\8bÅÄoqNáÑ"þÆyÌ@\8cÄ\ 1µ³\9dÌ\9cÏ\90\85|\96\11\89\7f\84i\bØ}0|[t</\1cÌ +=h\96£Ý9\15\9cI÷ób\19Ú\87\13\1c{dôòJO®\8c¢à,\bQ\15ÆÁF7<p\10ųþèèmcd K\87\13
+§[\18\93û{Ä6\80û\87­È\ 3Y§ý\0P\v£\98ò\15æMÛ\Ïæ]Û\1d Ü\9dS\15ØÊ\99\ f\8bÖ\ 5\9cý\83k.\1cø¼\1c\1f8\92\0à\89m6õ©âÔ\17ø\83ÿ\81±\18\9a+\98\86\87a\88í\f\8c®ºç\82ñ\8c\1e5u\rfPE&)\rtr©s'\12|òªâuò*§=\95.t+\85\f,³ðá\86DNS\95K\ eâ\88ù\8b·Pm\ 2Áå\bÁdÅĵ\11¥÷\1f\f\9d=Ë©=˱uÙ      á       ä|;c\1cðbÏt;Ó\8c}\ 6\rj\8de\1dGb\91\19UÏìC\bÂYIZâ\80M\ 2\ 3D\9d\8eú\ 4H`l¿\84Î\89\83£ó¤ûaR÷¸\19cëß2Al\1cgî®Hì nlg\9c\97{¦n1n6¨³­-¢\9e\1eDªoG0
+ç1\1e\ eà+"»=\¿\9dÍÇÚn_ø\82>°À\ 2z\ 3:õVÄÁâ\96\1a\1f\ 2\8d»õÑ\8e*¨}²\8dh(\
+ËImY·þm»ÝÔõk=\b\19\98,q\8d\fg\90-n´¢ß®\ 3ä\81eD1*E(\85¢©\9dÞ\87:¤ºò Í\8cØ6 á\7f¦kgkµ·áeÅvï\9a»e©\ 2        \1fèÔ(|þNõ\8e\8bx\8cÁ¸H\\f"]À»¸\ 4~¦a¶â¿æ}c\15\ 4Ú¤Aµ\8f`\13®}E\12\8cÅm²\1f0Õ<ó:\ 1\ 3\1fúFýf\8fÅ*h¥­\8e}¾ÄêuÓ\88D\82rZE÷è\r%eÅ[©R\10ÓÀ\ 4\11\83,\8c½\1d.3rÅc\90Àð$ÙP3\v§7Ð\rg\83r}ùÅM\ 4\19ÃÀ7«ø®û\82²ü-r¹\ 5pQÑ#ö£\e9\1d`ÈI¡Î»NÇõ#i\1e\1d\89\15­#\82ä\116W=\1a×\98%\99\180IÅc\80DZÔ\11 1\"\9b\80P"\8f\b
+f\14<K|\1e^óë\16\99¦\ f `yüðùë/ïyiO/­ït\e\91H\97\ 2\9fØâ@\9a·ø¤aJ&\r\93\98ø\´M\85à!©<¾N\89\a\92½?ؾ\97¼V¾!óÀ.*¦i m­\9fj!\7f\aälß\ 6£»%d\80¤1ô\ 6\12Õiäý\9cº6\12G£ã`rÐ\1dÇ|Åst\1e\8fHD\f\b\85ÐΠU˦K\84¢O\14]gèI\aÍDã\9fk³(N¶J¥uÅ\ 1[\1f\ e#{LW*ÛCh¹¨\ 1\82$\95éØH5S_í\93ø\ 1\91X\99Ø4QðîÈej
+J¼MË\88ÚyÛïÙj\0WKìNiHL³U\9bÃW©àÑ\88ß½?Ý\9bJ\8doß³úTA·këþG/­h\84íD`û\1e«F\12\89C\0¸\8fôeÊ9ä-\ 4\ 2¼\97øHf2\1c\9b"B=\18øØp°\97N\9eV)#^úº\86q|@\18\90<\ 5;#\16Ñ¡59ÿD\1a\7f\90Á\91x.\81@:\91´\81§ìÙdÒÿSVÌø\81J\10¾.R\0µí@Ï\ 4ò-ú|àÉe\a\8a¼ôªÃµ®%µ7¦ç§E\85^\8d¤¹EN_\85\91ݽ+G\11ð\1c´\98¨\95\10\93\1aÓæ
+\97%\1e \9f\9fùn ñ\ 3;lEù\98ä\82\15\85[ËÁÖ}ϤÞî\1ai©|ï\9d\14Ó\90óíµ´9E°\93\1eÈ/;dÎÇÓÿ}\87ÔûÇ\ f\ fwk¦à÷ÉÃì+Æ\fÜ\ 5åÎU8¨\98"n\1eEgoµ\82ÉäÅ\0\øJ|\94[àç[ü&\19.ºÝ\82\a¿Þ_-~§M\19´4Óï» \10¾ú¨¬(WVryÍ¡ä×&\9bKmƹN\94S\ 24*t%8\9atf*ò6\95\ f<g\8cÓ¸\ 6z\8b<"Ì¿lE\8c\8bd\1cK$ãp"\8aùÙ\97sZ\11üÍ\\88\ 3ÿŽ\18Ê\8c\8bj\99\ 6ã³(\8a¤'(]©\85e\89µ2\9b\8dµ2½4\15\18\10q=OET&\86ð\eIw Ë¥ç\8a¯¥gj\92ºðI3\8fïùÙ\95ÀÝi\84î¦V¦gVÍ|¾+\0\12½^Û\13¹\r¦ÓÞ\92\96¥\ 6òwS @\r²r\1c\83\1d6Jf\8a\13ª\ f\7f»¾ú?=û\92\82
+endstream
+endobj
+2621 0 obj <<
+/Type /Page
+/Contents 2622 0 R
+/Resources 2620 0 R
+/MediaBox [0 0 612 792]
+/Parent 2567 0 R
+/Annots [ 2619 0 R ]
+>> endobj
+2619 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [389.951 152.56 404.674 164.516]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.2) >>
+>> endobj
+2623 0 obj <<
+/D [2621 0 R /FitH 686.127]
+>> endobj
+358 0 obj <<
+/D [2621 0 R /FitH 668.127]
+>> endobj
+362 0 obj <<
+/D [2621 0 R /FitH 546.463]
+>> endobj
+366 0 obj <<
+/D [2621 0 R /FitH 359.803]
+>> endobj
+370 0 obj <<
+/D [2621 0 R /FitH 224.265]
+>> endobj
+2620 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F48 455 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2626 0 obj <<
+/Length 2445      
+/Filter /FlateDecode
+>>
+stream
+xÚ­YÝ\93Û6\ e\7fÏ_á·hgbEß\92\1f÷®Û47Ùk¦ë¤\9d¹»\99Ð\12mó¢\ f\9f(ïfÿûÃ\17%yWÛ¦3}2      \82 \b\ 2?\0r°:¬\82Õ»W\7fÛ¾zûc\1e¯6þ&\8b²Õv¿
+\83Ì/²Í*+2?\8còÕ¶ZýË»öcÿj\9dç\85wûéÃU\91xÛ÷\1f?ÜüvóÃÕ:\8e\13ïnûËÍõ-\8ecïöúãÇ÷ÿ|wõ\9fí?ÞþXÌ\ 4ÇQáçY\ eÇ\92È0      \91çU \9a¬Ö\8ea\1då°)\166\16\14&3I\89¿)"'ç¿ÏO\8aæç\ 4 V\12{ÿ\ eÒ@á0ò¾^E\85§¯Ö¡÷¸¿
+½^54\ 1\8eð\rr$Þ¾«ëî*ʽ\ab­XÄ\ e'\8f,cI-°\96\9fÆÅ\1f(6®óaé²(°ýt\85?ºbô\97I\8aE\92\1eJxï$\8f¼ë¾;·b\0Å?l¿Ç=\e\ e­aZ^\19\8e\9a\a\8d©ÖxÔj\1dæ©¿\89b\18\84þ&Mù\98ªF¾,ðº=þ\86²\11\bvèµj\9e\10\ f½jñÌs­OWk\18tV¸õÿκ-5ó7æpD¶\81\17wÄ*ka\14'\vÖ\89ÒÀ\ fÒø»Í\93¢}²ü%qqæÇaü½\ e\10g\7f\81´I·ü\r[<\8e\ 3\88\8fðÒâà\9b\8bÞ\ 1C\18}\7f(EÙ\86Bißõ<¡GÂÁÜ+$\94¢"zñ`P.Î\92?\13+(M¡+âi¶ãß®E?\8dbï}ëô1\96G\14»
+£øñ\89ª\8bþÄ7\v\13\11¦u.\f\ fQDé¥AKðSKÈ\10\ 6^\83øѵ\0&\1d\8e\ 6\1c´¦Tu\8dp\11\86\9e²ÌØ\83Ã\9aÞmÛ\89r8fg\87ÁÏ\87\ 3ï\ 1\137j@\17  Sow\1ex¹ìHõA\99Ö2\9f\81ÓZf6°\88*\a\97º¶ºÔÖª\9e°\vÔëø\17\9e)ÌJ£Y`-«h\ 3\ ex\17\8108õúÞtg˳§\00\89\19¶¯¬VºìÈÎ\95i\ fLRûA÷2\RÙjýÕ§\85\10Ð>I`5ò£\\92ÂÇÞ ÿÅqÁ'ÃïÎ\f#vÄ\eï\9eTì-Z\84Öc?ò\19q\ 3¯R\83bêI\95ÈÈ\17\1a,ïeÐï5³4ªÿ:f\ 1X\1d³@\x"\85ý)wþ\94£?±ç8Ýçا{sï\ 4FEàíû®Á]ÎA\81dÚJ\7fc\1a"$\92x\r\bbu¤íè0J^\ 6\9dïÀäÉܺ¸Ù\80ß)Øß;IÀªÚ'bKrá3?\1fÅTæm\8fjXz\1cc9íÃæGNú\97FJÄqâØ\81ðÁ´-¿=,\12èÇ.[\0¡\ 2\85P&ø\19\8cj\17³ÈÃ\8e\ 4¾r\7f\95¦\9eª\99Ê\12\12\7fìL\82\14wQ\96¯ÚI\9dù=2¾\87n+¸i
+ö¹;\93\1f\1c\81\1dP\86\1dÉòä¨på^j\ 6¤°Þ0øüËÍg\1e\8dÀ\81\13Ò®\b'>SI\8c\19ä+9NY¸V\15©\8b§êAäwüû%x½hýÖ\ e°\ryr9«ð¾\84¯á*Y\80\8fF\8f\ 2k%]\1f\ 6S&\ 4ÎÑ¢\10Ó\83\161ª,»^¢\13¦¬AÁ®"û*mËÞ\9c\9cî°\87Åv\97æ)\\80,h®*9\ 2êÈ\90\7fè$ü%[\81\1f6\1d\ 5\1e\90¬9´\97\ 6\ 3âdh\98Ðåç\9bí©6\ 3Ó\96k\ 6Xx8j\91\a#c\97Ô­\ 14\9fzRès¦J
+\ 4¦8É"ÌU°1N|W²B±\f¾\1cF©w{®\asªõ7²s\9e\r\8c\eu:¡9\9ee>\90\16E~\12F"î\ 4·b\e\80:I\ 2×<\9fäNýà\ 2\1fé\94:p\0>Ðõ\8aÇ\r!\93\1d.¶æ¸õ9ï\b¢vÜ\8b\16\1cÌzÉ>îbI\9ex\ f\ 6|\ 5F1¤\80\ 6<ËR8ó*\14\8eçÊtÌÈØ\8bD,\1a\91\87\83ÏØXtý\ e¡\0çïù\87r>n¸ãKk\84F\à\9cg\ 1âÒ`ClK\89äØ\9dÉ_à\19çvc
+Xl\r\ 5¤:Ùs­\ 6\87^·Ð¾Ð28ÑéhJñ\82\9cdîò}Mððh_NVΠ       Pé\90LÁu\ 2Íøn¡w\ f\18A´`\9eÉBÏ2­q\98H\f.\9cqãøDÓk`:>hÄA\80\84"ͼ\9f\87\97sÒIn±sép\r\85\9e4\10\ f\82#@o8å­ª\aÊ9=\16\1e
+ÇÈE\ f\f\18p3ô!¤\eù=â]\ 1Ýi\15S\1fø\97[;\9fø\17Ñ\80~\8f"TM¾\8f9)̽»®ÑKï,\95\a¿
+ec     \18ÊBRªaê\90@6mY\9f+Gmô \U\0î
+\8fá¸\ 4,»Ó\94\8ejg\10j.\12\95@\85\91C{b¶²±\1cfÈAz;ä\886~\9aOÐá\87\ 2\1e\7f?B\8dw      \1cv\11\ 2ê}ÞÏÅ#´\14.ªã¬põ@\8e¥\87e\12ù\1dò=\7fyZ>Q"\9eP\a\89·\9féI\1ce.Ãt\88\ 18=@Ó(Áº\1c\94c\82\8d¸3\1f]l\ 4Ë\b\91¤-Ï}/¹\93iuwÀº\9a'Ï]\ e\e\ f\e¢\14JìÎ\94\8b»&=¸¡\D»Á¸ê\ 3õ\ 2·o]Z\9a\954X¸ÉÅÛjR\1cVNGÆ       Ñ\1eöL`\8bZ¿\8c\1f[n\837\1eç3
+x\81\80\9e\17ä5¡\88su_Ésqiì}ètQÍ2\8d\9bïÂ{n|l°Æ'\9a\ ep\99\16%O5fÿ;¸¢°2\eÈí\920c\ 4\9d\19\8e\9dÕLsX\87ã§Z\12\r\8bP\1aõzÍ~\\82[0\89J\1c\1c@«%\14~îö âys\8a¥âlÙ´\92y\9f¾²8ò¹­°]\82|\84\ 5b\92x×xí\8cÃ%¿\f\97l\8eRL\98Beö\11"Ã.
+,Â\16θô\ 1\16\ 4ÆZ8ìT\87ÂÊt\17»T¾rò\88#ïî§\9f?}ø\ 1DZWuL³\1dÏmÓ¹ØÄ\ e\ f\97$W»
+\1cI\r\18¤\11÷¢\15W3Y³«\85çÞ\8c\138\ 6\93\ 1ER\7fÆ´À\b½`PñÞ\19\10^Öt°Â~\18\ 6ï\99\9cpL{µ$3b ËkaX
+>êj3iP\81GãÃål`ü~tX\8cõf\16ºSpKv\10\ 1p¸`Ê<\96¿\17ä#\ 1ùw|ç\98k¥?\81ô×NA×7âàY·%\r$Ö¸Jêë1ØÇdüÍA¡\94Õ¬\ 1öÊ\9bp\92ýEºÍ\ 5á\ e-^óä¤\ eô$جvý\92}µrn\9e\84éI¸\99W?8}0µ[\18«\9epóÄU\902+yò ö~\ 5\1f§\ 23$óXý\ 6+Z¹\ e\12Ñ      {ª\8aCÖx\11óÑkà\95æ°\83s\89ï(\99Åw\94\8a­\80:f_ ¢l\9f\ fßrm\0Ľ*±~\80,byÇ\v-"\9e½g\ eNí@\0á\8bN+ù>§«Õ\1c\14\80MM×JMÐIk\fÃ\85º\17\86\82ÂI\8f_\ 1Fè[®\14òçÐ7¶\e\8bß¡¤h\ 6E\s\95\87h5\ 6<L Sëµkà]U¥ú\1e\ 1ñ2BÝbÛ\r.ECÝ %×bR}Oµ-%´^ó\90\8bÑB:P^¤Ï$0êZ!¹\97Åñè·8\19\83\96\86C*Jg\8e\86\ähÌ/}   \8eÇï88¡ÏA/fTñ_Ì%¦¡/zS\ eÅ\ f\0\9b\98¿ÚP­l°7Jâ|Ú%îj\87y6ìL©/òsæ6ä\17ÙYRèA·º7¥¨á¾Öp9ò;\rX2EË\81"\13æ\95±£\0ü\86\85í+x8&¨\ e?x"\8f\958/©þBÊÙ¢\e#ceð\95¹9ÈA[|Uä\90WE\16j&\81į\9aP\94ò÷¯ù\9fOî÷fûêÿZ\91\18&
+endstream
+endobj
+2625 0 obj <<
+/Type /Page
+/Contents 2626 0 R
+/Resources 2624 0 R
+/MediaBox [0 0 612 792]
+/Parent 2628 0 R
+>> endobj
+2627 0 obj <<
+/D [2625 0 R /FitH 686.127]
+>> endobj
+374 0 obj <<
+/D [2625 0 R /FitH 498.005]
+>> endobj
+378 0 obj <<
+/D [2625 0 R /FitH 380.005]
+>> endobj
+382 0 obj <<
+/D [2625 0 R /FitH 237.431]
+>> endobj
+2624 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F14 574 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2631 0 obj <<
+/Length 684       
+/Filter /FlateDecode
+>>
+stream
+xÚ\85TÛnÛ0\f}ÏWøm6P»\91o\89\1fÓ--:¬\17¬.0`\e0ÕVl¡\8e\9dÉr»þýHQvb Ã\9eDñrD\1e\92Z:\95³t®\16\17ùâürídA\96\86©\93ï\1c\96.\834]9é:\rX¸ròÒùî²8ô~æ\9fÏ/WÑ\89k\ 6\9eQ\b0Ægs\7f¿½ýtýÍó£(r7\81ç\ 3\8c{wuE\8a\8bëü!ÿºÝÜà5v··\1f\ f\8f_6Þ:vóë»[Ä_,mVó\94\90\1f®@\17Ñs]+<?f±Ë\87Rv$öZ        ¾?\83\v¼Ð)Rv;ë×záÚ}³J]\vu\1aD²6.\aÏ\87CX\1cð$£,\ 5@¬\-=æþX²¸àZv-\19\ f¼\12ó÷0\ ej\82z|Æ\82,I(ï\83\92{®Þ\88\94ñmd\ 4ãP§k®­t\9a\r9õu74%\99\9f\8e\86È=4¼\10sîSb\84´á¦ì>0y±8Èâx\9eÜf§\91\96p\9dR\f
+¿\10\8aJ¶­l+Rb²xR\ 1\1fè\82\1côÀZ\98%ÇðZðrÄ4\ e(&\13\80à\ 5rZϵStÓU²à\8d\7f/cJ §òn 1\8f\ f9]fôTª\e,\91\96$ÝU\82\86à]ʸiµmSÉ5·4S\ 5\86KCKQ\fê¿|F\f\0\9b\86\ 4j\ 6\b5d\v"sy9JÆ7\9c^A'\8e\82ÉØ0Û\ e\98Es¥Æ\9fáeuĶ\19³è\14\8b+kÝ#æÐhyhÄ\1f ä\9fì\8e$Á2Ç\19ìi-\90\91dy\9cÃ8;!\1a\fÓ\1c\82,[:)+ð\9cÆýÄ(Û\ 2\94½\99,¼wÊ\8c\v\8aOvag\18Zîç{\95Rªâ÷ _¼$\ 5¢í\9aâ¤%\8cf*        \11A*\12+E\9fÁÐ\bRÐht½¤\85Æ0\pÑ\94=\96ÎÖPº´x;^ÈFj®Í(Cp/Ä3-\ 6\^k9\826r\ fx`xç\17°\e   Ý\1cà¡H(ª\1fÆJa!Jì\85ÉP÷äF\9f\ 3~PÌ\1d\97\19¨6\ 4
+­ÝgÒN³4o2\réôÁ\8eç6_ü\ 5Ù\80\95å
+endstream
+endobj
+2630 0 obj <<
+/Type /Page
+/Contents 2631 0 R
+/Resources 2629 0 R
+/MediaBox [0 0 612 792]
+/Parent 2628 0 R
+>> endobj
+2632 0 obj <<
+/D [2630 0 R /FitH 686.127]
+>> endobj
+2629 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2646 0 obj <<
+/Length 1067      
+/Filter /FlateDecode
+>>
+stream
+xÚÅWKsÛ6\10¾ëWàHv\86\bAâAöVuä4\9d6il%\87Ú9P$daÊWHȵÓ?ß\ 5\ 1\9aqM©3=\11\ 2öñíâÛÅ*D÷(D¯\17¡û.×\8bWW4AQ\889\8f\18Zo\11        9Nx\8aX\12a\16§h] [ï\87¶õ\83\98x².Ô#¬\ 4ó\96þ§õÏV\99b\91\bb\94C\14°\10\vâÔ>þ\16\1f¤\bÅ1åÑ(\95`\9e8©%&~@HÄ\ 6ùÁø\8fMÕfZmT©´\ f~\9f¬\99\ 4¥8å\11wF¢\18³\90[#ë\9dêý\80Rîõ2\as\9eVMm7JÕkw\96\95¥Y\b¯ÙÚ\r½\93v!ë¼ñ\83
+Ù9Ùº°²\85\1c\8f\80±í$Tßïe?\1aÊ´\15¯2\1fd\9f\9c\91»\90Ä2wG.\1f\ 6;!8eÌbÏ]´å\93\9fÄ\1eö\83$\16Þ*Ë\8d\9d\1dhrê\rÁÁ·\90}Þ©Í\0G\16ßÊ@k:\v\92r\ 6Â:SåTÈ\ 6l\16òQ[1\ 5\1a&A Wn\9dw\97N\903Ù;`ø\ 6ø¶k\fÎ\aU\18<q\1c{\95Ë\91K\16D5lo\ 1Ú°èäVv\90o\89\8d½\ 3\17_]        qt¿À\97\942¸d\86\19%Ö×]DÂ\13\9dcJ\f+Ø·¬Rº×\9dÌ*ët'3¸ÙÞü Þ]ÈÂ\e¸\15C\11c\8e\80R\88º{d\17ׯ\17èvÐâ\13o\ 6AÈÈ)l\9a\1eÃ&8
+\13ËM*,\94¿\9eÁLL¹\8c\98ß\14²6ÉÔ
+hCóÌrø+ü¹èqô\12ü\93´C]r\80O\ 4\16,²¨¾{iÊß6uP\19üûR«¶\94\16º)5\ 3\9bpû»U¹Þwî°W_\ 6\92ôÏ\82
\9b\08\91°x&ª\e\r\95\9cu\ 5xr\ 4Í\9bräâ@û\16¨\9a\rMCÎÀAçâØ\9b&
+Ùi:}R\11\14öEâ}o?Ã/qôËdoèF§²Â\8b&\9aÑ\98áGY\1e\T\99î\9f¥l\10¥Ð\9aÝ\9d\93\99\94½\91zßN8úBr\91\99éûÅöàÆ93\ 5Rjé\12XªJi\9b¨\a\9f\99>?4f+ø¢j¡P-\14\1e¢¹õr\11%Þï3Wï_\8ej½Íº¬\92ú\8cn\ 5\11D\97E0·¸~Ú\9b\a®Ê\1ct\9dmJy\ el:\1f6\f\1a@"Ûh\93ùïÃ\95ykM¢O\eìX43£\10\17\90çÜ\18V\8f\1a&²±­\95M}\1ft{w\15\9b± à\15Tõý¼j0áD\97\ 6\aôæízu=\b¯Ö\8bÏ\ e\1dA\84Óá9")Ø%\fåÕâöS\88
+8\84y\ 4Çi\82þ\1cD+\14á\14æÊ\10\95èfñÞη\93ÞÅ¡÷À8a,ÅÄÍ\8e¿~ü\86ËÄÌ\1fñ\7fá2\118\8d£©Ë+Söï>\Û+ÚAý\10¯(á\9eì\86}3coÿu*u\97¼)íÆ0\1cþ1·Ç   ÌÎé\10\9ccB\92óyº\9c\80\ eJù`\16ðF\r\b\8fôLU\87lTü¬þ9ø\9báSÐQbÚîgÕ+\9f\9f\b\11aJ/h:¿Ë®\81ðë{½³7·z·´¸¡nç\97èÿÑs>Ô\9d4-%×\87y¿\19ß.óú\9a\8bÍõ8Ù´YQ8VÇã\fãþ\84Ø\96õÌ£>\83Õ0\92Äÿ\9e    Dâ\14\ 6\fK\98§n\ 2!tª
+mào±Ì\8f·
+endstream
+endobj
+2645 0 obj <<
+/Type /Page
+/Contents 2646 0 R
+/Resources 2644 0 R
+/MediaBox [0 0 612 792]
+/Parent 2628 0 R
+/Annots [ 2633 0 R 2634 0 R 2635 0 R 2636 0 R 2637 0 R 2638 0 R 2639 0 R 2640 0 R 2641 0 R 2642 0 R 2643 0 R ]
+>> endobj
+2633 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [252.02 396.687 258.993 408.643]
+/Subtype /Link
+/A << /S /GoTo /D (chapter.6) >>
+>> endobj
+2634 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [284.454 373.14 299.176 385.095]
+/Subtype /Link
+/A << /S /GoTo /D (section.6.2) >>
+>> endobj
+2635 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [312.687 290.179 335.158 302.134]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.1) >>
+>> endobj
+2636 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [321.708 275.325 344.18 287.28]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.2) >>
+>> endobj
+2637 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [279.865 260.472 302.337 272.427]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.6.4.4) >>
+>> endobj
+2638 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [264.667 236.924 279.389 248.879]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.1) >>
+>> endobj
+2639 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [301.833 213.377 324.304 225.332]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.2.1) >>
+>> endobj
+2640 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [379.879 189.829 402.351 201.784]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.5.2) >>
+>> endobj
+2641 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [261.669 166.281 276.392 178.236]
+/Subtype /Link
+/A << /S /GoTo /D (section.7.6) >>
+>> endobj
+2642 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [269.814 142.733 292.285 154.688]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.7.1) >>
+>> endobj
+2643 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[1 0 0]
+/Rect [411.007 119.186 438.46 131.141]
+/Subtype /Link
+/A << /S /GoTo /D (subsection.7.10.3) >>
+>> endobj
+2647 0 obj <<
+/D [2645 0 R /FitH 686.127]
+>> endobj
+386 0 obj <<
+/D [2645 0 R /FitH 668.127]
+>> endobj
+390 0 obj <<
+/D [2645 0 R /FitH 491.97]
+>> endobj
+2644 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F77 675 0 R /F49 457 0 R /F70 508 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2650 0 obj <<
+/Length 1538      
+/Filter /FlateDecode
+>>
+stream
+xÚí[]oÛ6\14}ϯУ\fL,yù©\r{HÚdè\90\15Yk\14\e¶=(±\92\18sìÌR¶u¿~¤HÙ\96\86/S¥E\9f,ÓWçò\1e\1eKâÁ\15Mn\12\9aüpt2<zqf\92\9cä
+T2¼N\98¢D)\9d\b\ 3\9d\fGÉo)\13bðÇðÇ\17g\9a¯\84\82¤DÛ\10ê\83\8e/.Nß¼zýË ã\9c§'d\90Y\9côý\ 5\1eÑ\90ðÅ\990    \13\84\v\ 5\ e$kQ2Ð\16\99\13\ 2\83\8c1\90éùÌâ±tvo?´LÏÆ\93º\9cûãóñݸö\87ï\a9O\8bÉCYùy®VD-tN´
\foK?ÃÛb>Ê®,<\98tT\8eüàÄ\7foÒq\91þN\99\18°4ä´\ 3\93\90Ó\86þ=\90Òå´¿[D\96V~ø¡j±ÆS\7fÎû\v\eÂýq1\ fÙG¥Ã\9e¶±Eå\7f¿\9e\14ì\fþ©¾õ¥\88\16Ë\157&É8%B\1a_ÐùÙùë\9fÞ=®[HK2oWç{\1fÀÄêZ\ 3Ñ\8b\80ë\r\b$7ÐþÎi@`+\11ÍQ\eñÝc\84N\ 6\90[\10øÞ\b´\7f\ 4&±<04\ f\82\901e\88a`\ f\18É¥\fPüPBØb6\1cÍ) \19Á#0<\11\fM\ 4^àô0ipbl!\1d\e\90:\17\95MsÑD³\ 5\10Ø.\84E
+s(\ 2Û\85°\7f\15úÉ\10öçA£y8¤\8a5](\1f¨Ð|(4\1f
\a¾
+ùd\bûó Ñ<H¼.ÂõB ù\10h>zDX\ 4p4\ f\1c]\ 5ï¥\8aͺ\04\1f\80æ£G\84\9dU|ù<lÖ\ 5EóAÑÕô\88°³\8a/\9f\87\8bÏ\82ÑOPE\1f<¬Z\17\8aPcÚ\80\9bà\94¬\19K\86\13®¬2$\10`\vc\89\acéç\87b:à,­Çÿ\15õx6õFÒÅ\80CZÌ\8b»².ç\1f1\93Ì>fÒ_.\ 5èÕ\14vô~       ß1\8cDzé\8c\9f\ f~ÔùfÞ\19ò\8e\91Øì\18ñÖ1Ò[\1c#\10ÄP\9edB\11e\ 2   Ç®È\97ï^\1e\9f\9f>®Pj¨ÄÚFË\87CºI\0v\9dr!öÝ\91
+\19\ 1#Â<¸\8e\80!"`0<\ 6\18\89ÇP\aad@\rQjÍF\ 2\11aB\10\ 1#\ 2¹,ÇÏ\83\99\18\18\11j\89 z¦h<¡°\bW\ 3\16Al\8cÇÀ\88PK\ 4Ñ3\16\ 3#B-TG\10\8a\ e\9b\80T\87ø©]\b\8e\8609\1eB\1e
+±´Rá\10wºëBJ<\848\0Â*\84Û\a µ}\82¦hZ\95ÁC\b<\ 4¾\10©Ñú\90
+½¸\12/1I£éCàÿvBâ!ðú\10øK\90 h}p\83^\®ñ\102\9a>8\9eV\ ex\bü\9f\1fðB\a\83Ö\aào\ e ð\10\10M\1fÀд2üÊ0ü-\8ai<\ 4þùã°6\81.\ 4þþÂ6ùQvÕ©Ê×\r©¼£\10#       \ 5c\15\13¨\ f\11\17F
+½Ó\85aûÚ0\0\11,\ 3\1acgL¿\9c]m\7f;ã'Ø]«\88»ë(;ôg\82Á\9f   \ 6ô\86±Å\86\89±Ý\8fb\19ô\87ÑÝæã\1f\90s\8a¾;E\800ñ6P\ 6ÿh\1a\ 1B\7fæ\10°s\9b\ fÏ\1eb³>bø\16_!`ç\1e\1d\9e\16\ 3\86öè[ÄÜ`÷
+\81ìá\7f\16\10[\f\98\bÖÇW\bØ        \ 1Ï\1ebM\1f*\1a­ì+\ 4ì\84\80^ v\1a0]\81ä\82\bû<\9fqA@\a\ 3Æ·ÙP³è®©ü×Ùtâ\1aq¨N\v?P\8d§7\93Ò\1fû¾\1e³Ú×cGçÅô&\ 4\ÏæþäæÅ°âÊ\ 5ßn?W§µkàùp?È 9Ç\ 5\16Ó\91+ÂêÙoC:×½«Ù¤IÁez?)¦å7þØ\9dÓô
+Õ¾/I¦\97E\15\8eî\8az>þ×ÿܶ\1cÉt\ùÏ«Ù´ªÃÌüH};\9f=ÜÜÎ\1eê5ȦN2È\840®ÿi^6Ӥݠ     \86®¥\ 6¦Ü<\97«2ä^469PIÛ¦*Ù¼}7¯êîL\97s¿n)pS{,*\10\86\18­ZIü\1aBx¢H®¹q!\9aä¹Nìu\83u\e\aM§Ó\8cq'\9ae\90_Îb:-'>ÿìÚ\7f¾~3|{ì\17\r\14'\94ê.)wm\7f\98\r·\v}\19^6lðþ¬Ü\1a\82    kèºÆ\1a\1aìHUÚÕ     \83¾fw²\7fO±¾]\ 6oØÁ\1an\8f\17}r/C\bíPÀÀ]4\89ÈÃ,/\1fs    (\96¬Ä\ 4q®§ËÉÒ\91Ü/Ù|S2¥;ÉVø®|µ\rávÐ\13Þ\f-¹õüs B®Y\16k\847\1a\16­ÜD:)ªðjç8¼\8déÞí¬Ü_¸mº\v\92ã.óé[\7f\ 2fÍ_w\14\90|"í\12i\9bÈÇy\95¸×T'>jµ.ÒyI¶ý<\1d\1eý\ fäWx³
+endstream
+endobj
+2649 0 obj <<
+/Type /Page
+/Contents 2650 0 R
+/Resources 2648 0 R
+/MediaBox [0 0 612 792]
+/Parent 2628 0 R
+>> endobj
+2651 0 obj <<
+/D [2649 0 R /FitH 686.127]
+>> endobj
+394 0 obj <<
+/D [2649 0 R /FitH 668.127]
+>> endobj
+398 0 obj <<
+/D [2649 0 R /FitH 477.268]
+>> endobj
+2648 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F48 455 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F13 705 0 R /F10 668 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2654 0 obj <<
+/Length 1398      
+/Filter /FlateDecode
+>>
+stream
+xÚí\[s£6\14~ϯð#Ì\14E÷Ëtú°\99Ùt·ÓÝéÅíC/\ f$Æ6SÛ¤@\9aÉ¿¯°À1^\1cc\1fØ8±\9f\90ÅáÓ\91¾OÒ\91\10Æ\83É\0\ f¾¿¸\1a^\^+60ÈH*\aÃñ\80`\89´4\ 3©%"T\r\86£Á\9fÞ\15âÈ\ f\94ÒÞ\87ß®¯?½ûì\a\8c1oèkæ½»úñý¯þßÃ\1f.¯õ\1a\ e£\1a)©l)K\ 4ÂEas\81Ë\82/¯¹Y³\ e¨ÖHk:\b¸±×²ÔO\r¸\16\96\b]Á~ç\f\b¯Õ\0    "+\8b±\1f\b\8cíå\v\91á|å ,¡È\9aI\91b\95Å·\r\10\14©Õ}BÀ\b\18\8c°­\16ô9\ 4\85\14Y\19P\ e\86à\18\f!\ e\ 2\82T\ 6ò\10\88\80X!*¦l\82 #dÙ¬ô\90
\88¡`j9\18ÁÀÅ!Á´\b\rg\16ý\10pq\88\1dÄ´\17\aë­ß·F \1cܦ¼\ 3Z\14\\1c\ 6î\85<&q(0µà±\87vЦð\ 1]ÃÅ¡á\12\95´;qèCÅAvrÛZ_\f¬¯.Ft\r\8f\9d\9a4Z\8fñvc°\830jUQª3}Pð\94Ï\ 4T\1e\aM\945\ 4   \9fYt\a¡5\87Ë\83\ fÓÝðÁMoÔ´\96\87\ 2w\­àÜ28·\94t\80\81;\18\82\ eò£yÙ¢À\13¿\ 1O/\ 6<~\18øÜиúÚ\97\18ü¢ó˪Á\8diÚó \bKS\99L\1a\85èMÒj\10\ 11\ 6i¼1Æ4ì\9b\14H¤»è´\8b \b<\8cqxhiÌë\86 ;!hw\ 1\95\a\81«CBÕ!åY\1d\ 3\1eÞ\1eNíîµ~û\19Î\9cÕÑ\83:8xf\91àM±\83ªó¦Ä\ 1c¶{qHH\85àÄ\9cÅqÌâ\10gq¼\15fÏâèI\1co\81Ù³8Îâx\9d»%òå_ô\12ø\9a\89âc8eB5\18\82Ñþκ´ØÏ×\e»%G \ e\8a{;Hp\12Ìn\9c\88ÐpqÈW@m{\84\93fvã\9d7ïîE1\86Æ\f=RÛþeõI3Û\9f8ÀoGz¤¶5Âi3Û\9f84øüÐ\vQ[C8if76}º;¼È(x©ÀÁ3\13×Gp\0é\15S»qDEwp¼DôÞoi¿Ü\1e\9f:^\8cÚ-\18µí\12\89° OÛ%\81\10²Ú5©©\84J\8d8f6A\10\97ÜÙ\ f§\91\1f0,½4\9a\87ñ"^LÜÏ»0\rçQ\1e¥\99û\9dÅó»Ù£K\87\99Í$^ì\13o²(²\94\97O£¬\ 4\9a\87y\1aßFåsyR^«rîÒäÎ\ f¨ö¢Ôeü{\1f.|û;/\¶\12vMR[]¥áb\12eÈÕ©öe\920\88\191\b\18CÚ6ÔÒúóÏ¿4}ñ$\105Ï~\99d\19ç«m§qÃfQMú¤å¾T}·\89\v\80ì\vÀ·\ 1LZ\96°\81°VÄ\96\1d3Úy\1dzl\84I\83l\ 2Â\b¢\8a¬ä¶4µºùøGÓ×r\82 ¡ö\90ÎîÏÙ\ e¥\8eî¢NíKÝ×W\ fÙå\ 2Ýänç\ 4ô\8c\ f[ú1;S±\9f\v\91æ\88\18½Ù\8f®>}lèFÜ \85i\97ý\bC\87\ fÜ\eû{÷\82¯?\ f¼ª:LZF`\80¡\80BkA_~L¥Ð°ä4ê°\1aÍt1¢0ng\14÷\9d»@²\88>¹BZ\9bÕçõ6Ü%Tx\1fîÿÂ\84ÍÃ"èUÂ\eú\86{áÍÌƺ_ø\83\97a¶¦d-̦Bxãd6K\8ap÷a\19jSÁ½ÜA,oß&.\16¶¡¸ËÈÝ\83Ü\9b\86é(¸M\96¡ó(\1a¹Ì5\87ÜÓåíÌݾÏ\9c¡ðn
+ÔG\97þý'\86ü\80\13]x\95FË°\e××\8eaZº«qé\86õÑ\86ûQ\11÷\97à\95\87álö\8dM)ìî\86·EQSwï!ΧÎ:t\19Û\1cvFã$]aº\ 4£eùÉ?\ 5lT>÷\9fo×8áì¾X\14T5Ù0Ìjõ\92kõbÌ.g\924/Ú\86±§¶)òÝ2Å&æI\96»ÛY<YÄÖk~[­S\96\ 67q\9e¹T2v\86öÙ8uYëBakÕ,¼\15Äz\e\97Ϻ«x*7³«®&F\92t´\01¶lxƸ÷0\8d«¶.²-Ä£K=ÄEó\15&7\ 51^ä~\8c¢uù\14\86ã4\99¯\1evFY\94ßß¹¼i\14Ú2Qí\8f!ªëûáÅÿ¿Ù\a$
+endstream
+endobj
+2653 0 obj <<
+/Type /Page
+/Contents 2654 0 R
+/Resources 2652 0 R
+/MediaBox [0 0 612 792]
+/Parent 2628 0 R
+>> endobj
+2655 0 obj <<
+/D [2653 0 R /FitH 686.127]
+>> endobj
+402 0 obj <<
+/D [2653 0 R /FitH 230.554]
+>> endobj
+2652 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F49 457 0 R /F14 574 0 R /F11 573 0 R /F48 455 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2658 0 obj <<
+/Length 765       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\98MOÛ@\10\86ïþ\15\ fYvvöóXZhË\ 1Q5BH\94\ 3\94´\87\92¢VBýû]Ç\84bp²ï¤9%qÆ\8fßùØÉL\8cú®\8c\1cÎ\9b\83㤲ÎÁ\ 65ÿ¦(\18\1dBT!\ 5M6ªù­ºlÉ\85îj~rp\1cù\99©õFÇbb\ 6£7ggG§ï>^t3fn\ fu7+\9cöü\8cû[\eóøÀ\97¯GóæWCå­QT\1e\1eµ ªÜWÀY}]6\97WFÝ\96ïNTyV\8eêÏÊr©È;mR.ïïÔçæÓ\84\1fÑkvI\ 5\1fµua\90øáá\8b!^^ÿ\1c4¾½ïf6µ·\8bòb}lç]âöþGW®-\1eMÎûK×w\ f\8b\95\13\93b=é\90ÝK±.§íb£\e©em¸¨uFÛ\94\ 6µ7Æ\98!ì#ÇØj\8a´\8eº}4\19áfk£\19\91ÎÞ?ñ¨Ê£,àÑ\ 6\85Q\93·kb\9c\ 6\ e\81\99\8dL#Q]%        U"L®3Ã\98 8o\93Ôù\1e\8bTRØ      LÕ0$qh\v·\8e\r;`ëõoeõ\ f\1c(W\aþ«\ 2 \0ÈJ\14\ 2.SÄ\81P%\11\8b\80@RH\ 2Īݠ\91\80JÆ3MXí\ 4\91HÈq&)\13iJ^\f\ 5ú§ÅOø\1a
+P\1dÞ\95\9f¨\0Öï \16éGQ\18Ùzã42¥\80FAGê=¯×}\12\ 1\91¦é\ 5g³÷ºN\94\9c#¨¯\e\11°\9eç¼qfµ\81u\8eñ?\aìadµ\8eµ]\v+Ó¾¦ar\1eÍÚ®\9f­]{}s·\18>\9e>,û1ûf5\80/~\ f·\98­\9bÂäÆÀåé©ÈÞÇÊÀÅ\0^\18(g?8Õ/\fñÕÂÐQ;±3<ÉÝÇÒÀ.ëT®ÀK\83E\96\ 6\8b/\r\16Y\1a¦f±:\90D@@¡\95\0       PèD@@a¬\ 3ó)lã/\12\ 3}\9e'Æ:ª\13£\90H\80J\163WÞ\ 3E.(ÊçdªJN;I®\97À¶\r\ 4hó`:Ò\e\vT\83ß\ 5\vD!Éó\ 6\94Z\8f+\89\ 2\0´\0\96ä\1fhR\96$NCm/È\88@b\ 4\9d\99 ß\8e$\ 2\ 2i1\82´\10pp² n\bÊ\8a¤¸\87¿mªL6R&\90k\162\91\1awR&\0e\12¥|KLG\89w²Ä£Q\8dâ\b\0ÍÍn\9e^÷±>¬\87×=®\ f4¹>\14\ fþ\ 2
+.n¢
+endstream
+endobj
+2657 0 obj <<
+/Type /Page
+/Contents 2658 0 R
+/Resources 2656 0 R
+/MediaBox [0 0 612 792]
+/Parent 2628 0 R
+>> endobj
+2659 0 obj <<
+/D [2657 0 R /FitH 686.127]
+>> endobj
+2656 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2662 0 obj <<
+/Length 811       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\98MO\eA\f\86ïû+æ¸{\88\19Û³óq\84\8a\14¡\16µ"p¡\1cHI{()j%Ô¿ßM&\ 16Ùeì´§|0yòúµ=±±æ»±æ}u2«\8e¦\81M\82äÉ\9bÙ7\83ÖCôÉøè\ 1)\98Ù½¹©OÀA3       !ÖgWÓéÇã\8bfÂÌõ¬\89\\1f\9f|8½lngçGÓø\8aÃ\14!øÐ}Ë\9a\80.¬ÎTvóÅ»\8f§³êW\85ÝSkР\12 Cã}\80@É|]V7·ÖÜw\7f<7\16B
+æÏúèÒ`ë\81¹{ú`.«Ï9\9e×2\90ZðÞø6\09\9fµ\9c=}±ÈË»\9f9\8aw\8fÍ\84b}¿h&\98Ú\90£züÑtï-6G®WoÝ=<-Ö1\fkm\11|r»Z]\8aoj\rîµX\8c\80Øyï,P\8cYíÜZ»o/²\ 3\87´µ\976Gz¸ÉöÐ\ 4\11RÛ>ó°Èäà¡@ ¢
+(PH\1a 
+\14:\15P 0\94\81\9b\8a\9cw\16\8e¤9\ 1'~F\ e\13ó\99¾Ä5Q\106+*'3±¬\93´:\87íì1YÇ\14äÇ«"/\ 3   5       \97\94$k\14J\12c5&J\8a\9c\14m\88¢\8b\80\12\17[\1d\11%\17.kr\9d¡\92èI¯Uä\ 1\85C¸å¦ô\8azÚ`Qpϵ\87`%6x}ÖÐ\8aê\96\92ÞáõCÙäx\90\e\92æ\8d\ah.ëuZ½\ 2¥N©Tp\17\86²Ì^-H\fÕ\Ø¢¡Äª\80åܤñ \96<C
\9f¦mL@\9c\f9\ 6Ú
+»þÄ\80y\8eîMÞn5i»únþ°È//\9e\96«¡{¾\1eÇ\17¿óGè͵ap} dÁ¦$[\1f\1cØ\98Æ#b\8b`-É\17\88Ôæ°V\vDØ[ \1a¬\av\88\92\1db@p¯:(y°Áï/\11\83Õ\16\0ÛÒt\90Ïì.\11Ã]Û\95R(NÀùÐÞVbË@§\ 2
+\88c3Û\18\11Ë.\ 6\8d\8bcMÛ\17Ée\91þey*Ûh\15A\ fëëE\9cä\11\8f\rW}}\8a¤ ¨\10I\ 3\94\94\8dU\ 1QÒ}\vÑ÷\90(°rl \1c\17:\16\7fO«×dü­i²GmÕÔñ½¹ïBR»\90÷Ò¢äx\90dAËGyË¿\80\ 5\\7f\80\13\ 2lÐcËæ:¥¹e"ê\88\82\9bÅ+ò$iX\8c
+'%©AÖ\0%¿\1eI\ 5\14ÝøDZf9p¶J¦äÞw\9at#\8af\10F­PAï\90¢ÒECHþ7Êðà*Z\1d
+\93övný\8f»\ 3\ fî\ e]\ 4\7f\ 1-\ 6r\96
+endstream
+endobj
+2661 0 obj <<
+/Type /Page
+/Contents 2662 0 R
+/Resources 2660 0 R
+/MediaBox [0 0 612 792]
+/Parent 2664 0 R
+>> endobj
+2663 0 obj <<
+/D [2661 0 R /FitH 686.127]
+>> endobj
+2660 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2667 0 obj <<
+/Length 765       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\98Mo\131\10\86ïû+|Ü=Äõx¼þ8Rh\81\1eª"¢
+©ô\90ÒÀ\81\84
\88¿\8f\e74)»ñ;!¹d\93x\9f}çÃã\99\18õM\19õ¶9\9d6'çQ%\9d¼õjúU\917Úû |ô\9alPÓ{uÓ\92\8bÝíôâä<ðÖRÛ\e\1dò\12S\16½ºº:»|óþS7aæöTw\93Ìi¯¯øñÖÆ<=ðåûÙ´ùÙP¾4\8aòÃ\836^åû28©/ËææÖ¨ûüÛ\85ÊÏJAý^¯\*ê\9d61åë\85úØ|\18°#\84|ÍÊ÷A[ç\8bÄw«Ï\86x9ûQ4¾~è&6¶÷ónB)õí´\8b®}øÞÙÐÎ\9f\96\w\91ÛÙb5_\e1(¶'í\93{)Ö¥¸_lp;jY\e\8eÊ;£m\8c\9dɯâ÷\1dËØj
+´q;õO¡ÙæM6\8b&D:õý3\90Ì\185hêí\86:\ 2-k\86¡T\95jåR\ 1¨\95BëL&!\13\90éêH¿\85¤z\8c\82,FDH:Ù 3ý\91
+hõr­ Þt\80Þ±$Ø\91\1c\ f\92\fdB\14\1a\fp½Ø\13u'8©\13êH+A\12P\0E\19\v\b4\ 2\81\84ThÉÖG2\88\89\10\17Z\11\10P(Ø\95\ 4\1c\ f       ä@\83Gd]\86\80:$\88     \81'\eË\90\80Ý^D\ 4\80Q\ 2D2Qd3!¹CõÜñÛDà4cA:®\91@Ëad\86\ 3écF{VëY§\10þ³Á.-«u¬íFZîö5\95Îy§×v¥·\9eÝ-æåãåjÙåÖûnÝ\80Ï\7f\95[ÜÞIapbàüô\98e\1fcd༠\1ek`è¨\1d\98\19þÊ=ÆÐÀ.é\98¿Á\87\ 6\8b\f\r\83ýýØ\96``\97ñP£P'\ 6!\91ªD\96\10  ðb\90xq|ËZäØ´ÿv
+\80B'P¸§à[¤àÛ\81Ö£.Ñ\1a\19\91 \ 4·AN­'P/H \ 2\1d\1f·wå\8a\ 2ÿL®K\8e\aI®'\82\8db\a\13Äõ\ap\ 1l/Ç\ 25Ê˽\v\94\81}\7fi\fg\ 3À$¡\ 3\0$\8b\90@q±8\90 c\8eDÀún2õxûýsÈ\ e.áéCÈy$(¥\ 4\15gò2â\9e~\9c\81ù\9f\a\91õÄa¡á\84èt\82X\17\94¤B\81mèDL`\eòxãz\8cÉaÓ·\1eqrè\a'\87\1fÎ\84
+endstream
+endobj
+2666 0 obj <<
+/Type /Page
+/Contents 2667 0 R
+/Resources 2665 0 R
+/MediaBox [0 0 612 792]
+/Parent 2664 0 R
+>> endobj
+2668 0 obj <<
+/D [2666 0 R /FitH 686.127]
+>> endobj
+2665 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2671 0 obj <<
+/Length 740       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98Ao\1a1\10\85ïû+|d\ f8~¶wl\1fC\15\1aEmÔ*4\974\87ÐÐ\1e\1a\1aµRÔ¿ßeM6@!;CÝS\b\98\8f7\1eïøÍ\18õM\19õ¶\9a̪\93ip*éD\96Ôì«\82!\1d))\8a¤a\83\9aÝ«\9bÑD{]\8fC\88£óOÓéûÓËzì\9c\eÍêèF§\93wgWõíìâd\1a78ÎF\1d(´¿Ò\11àÓjMeÖ?¼û÷lVý¬Ð¾4
+
\1a\1e\8a(è`\93ú²¬nn\8dºo?¼PF\87\14ÔïnéR¡!í\ûòA]U\1fs<\9b2`\eM¤¨ ÚzÊZÎ\9f>\e¸åÝ\8f\1cÅ\9bÇzlãè~Q\8f\91\9a\90£zü^·ï-ÖK®WoÝ=<-º\18ökm )ù]­>ÅWµ\ 6¿)\16Q\ 3íÞ{£m\8cYíÜ\18ó÷öÂyíaûíuyÉ\16nü¼h\fèÔ4=\ f\f`\10\ 11\f\8c\ 2 \f'hg\84Èa\95ÖË\90ûw2i\97\\8fÜOÌk2\916\89à\84n\83P'\ eD¿%\95\86¥î@\19;
+©Òa¦\931\19\87S\94v\98á¬C\92up\9eHkd\1a1\9co'É78U\83D\1a9e#ñ\89¬'\aV\ 4d(d\1c\81\8c\82aøYÁÁø}t\9c$f°T\ 6¡JÖSÓÈ¡\9c\11\97;¬7\1e¡\17¬û×&iÊÖhFE¶G¡\19àx\f\98Á%1w¸öy~\81æ©D#PÉ©¥FÂ\e\ e8\1dö®\96\9cN!ü\93ÏFÒÖ%e½ÓöY×õ\a§\91\1dô\96çö+\8fíGwó\87Eþ÷òi¹²ÛóÎ\88/~å¯Ð«\rÃÞÆ¡5Ím ±Dãà\8cmÍ{ø\8f\9dC/¶@ç`\93ï\ eìnçPô\94\19VMtB\13\ 2¬Ü\1eçBôBdÙ\v1#Qä>¤m&çj\814xNy\91õ\ e\9cz*ó\92¦´É/m¬:$ʶ\8b\9cÄ@âQ8\15\ 3¥\r´Ì\8f°F\ 3\92f        \87g\ 3RÇ°\85d*\95\99Ó\8ce\9dÍ(Ü\82\fFi×Û\83Ë»Þ\17tq×»F\971§»ùCÑùÎ\9aZvl\92¡(:\83\ 3o\16#í"\8aÎ2Ëy}zñúeç·¬kD2D8®yx¶¯\ 5\9a\a\9bH\9b@%\9b\87°·yh\ 3ø\ 37ur2
+endstream
+endobj
+2670 0 obj <<
+/Type /Page
+/Contents 2671 0 R
+/Resources 2669 0 R
+/MediaBox [0 0 612 792]
+/Parent 2664 0 R
+>> endobj
+2672 0 obj <<
+/D [2670 0 R /FitH 686.127]
+>> endobj
+2669 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2675 0 obj <<
+/Length 758       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98MoÓ@\10\86ïþ\15\ fÙîÌ~\1f)´@\ fU\11V\85TzHHà@B\ 5RÄßg\13;Uܬ½3UÈ%\89³~üÎÇÎÎD\89\1fB\89÷Õe[]\\a\11etèDû]\80SÒ9/\p\12Ð\8bv)\1ej°ªylo.®½>Z\8aVI\9f\96¨nÑ\9b»»«Ûw\1f¿43­u})\9bYâÔ÷wzwk¥ú\a¾|¿j«ß\15¤\8fJ@z¸\97Ê\89t_\ 2GñmS=<*±L¿Ý\88ô¬èÅßýÊ\8d\0
+1}^\8bÏÕ§\8c\1d^K¥\83pÖK4®\93øaûU\81ÞÌ\7fu\1aß>53\fõr\95ÞL\88\ 4]?ýlÒµU¿ä~wi¾Þ®öFdÅZ\90.\9a\97bM\fÓb½É©5Jb\b\9dÚ\85Ú½:Ç\ fLÓ(ÁÃÁï\18ûØ\1c\ 3g\87E3\0\19­="B\8eè%X<\10}\1eØ­9\ 1\96y\8aÃ\83²Å 9\16\ 3P\9cè\98H(«$ÄÅ\1d!       DÃ\10\9a\a$(D\ e\90\12j`\ 1)F\83g"Ë  \ eå\ 4wGIJ\1f1Ð5\ 2­L\0\17Y6;Ð÷5\8c\ 1\87f[\96\95GÅe\12Ò\12\81¾·{è\98Ø\81G\1dË£=¶\1c
+l\99jøTB
+ 3\\84¢dyÁ*\135pD\12\14rr\14Êi\14\19\91¡TaÔ\1c\ 3×3\91@Ø>\9a^\87{f9Ë\91åK ¤\ f8\9eí\84\84T£ý):-£÷gi¦Ñh\89\ai©³\97ÐuÉ\83¾ÚìúhSÏ\17ëU÷õv»ÙµÔ\8b}³½úÓÝ\12\82ìt ÓÓC\92}\8eñ@\9b(Còÿÿ\e\ f\9eÕ\9ec>x\96{2\1f\8c¥\ 6\ eS#\9fl¹n~t\97iÂx 3Àñþd@u¯ B\91jùÔ2Ô°¡P\fÓÔ¹wÒCN\1fÐ\9aP\ e³:Ë*§*\17g\94CÊ(\97\ 1\12üh\18@ í ©A.\8b$¨t\8ch\93ò\axv\97\93G1\92\a(\91F\8e@J.\ 2\1dØÕ r\11BºÑ\1d\92\10jE\ f\90S\13,kðBÊà\95ïåË"\ 3\13\9b©²LÔÀ    \ eA!ã°\ 5ÂQ\e\19ùHÙ\84¨9ú\0\b[\ 6X\12\81\94;\bL\99\94\82\16ÊB\1d­\91GÊ_¯9\9d\94\b\ 5&\92 Ò\8fw§ç\98\ e\ eÍé\19§\83\98\9d\ e\92\ 5ÿ\0,\95
+endstream
+endobj
+2674 0 obj <<
+/Type /Page
+/Contents 2675 0 R
+/Resources 2673 0 R
+/MediaBox [0 0 612 792]
+/Parent 2664 0 R
+>> endobj
+2676 0 obj <<
+/D [2674 0 R /FitH 686.127]
+>> endobj
+2673 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2679 0 obj <<
+/Length 717       
+/Filter /FlateDecode
+>>
+stream
+xÚÍYMsÓ0\10½ûWèh\1f¢j%Y\1fÇ\86ièt \ 3SÓKé!!\81\ 3    \1d\98Éð÷±­:\13\a\aíÂ2\90\8b\13GyÞ§]­ÞS\94ø$\94xYÌ\9bâbá\8d\882:íDóQ\80r2¸(\p\12´\17ÍZ<\94sie5ó>\94×ï\16\8b×\97·ÕÌ\18S6U0ååüÕÕ]õØÜ\,Â\11\8eÑAzçÛ§ô\bPC7¦PÏ\ f>½^5Å×\ 2Ú·J\80\0PÒ{\10Îyéu\14\1fvÅã\12ëöË\eÑ~\15½øÞ\ fÝ     ¨£TÝS¶â®x\9bø\1c\87\ 1ष-\9dÚKm]
+æzÿ^\81Ù-¿$\1a/\9eª\99\ eåzÓ^b\88\89ÖÓ窽·y\1erßÝZn÷\9b\9eÄt°5H\17íi°6\86_\ 6ëíT´VI\1dB\8av¥Òëç9\ 6ã%Ôz\98c­Ó\90\11äl\184\ 3\90±®G\980\81\ 4c\aÌ0       ù<f\ 22\8f¨i\88\90¥m\80D;\ f¨-\ 5\10\89yHw\f\99\9fGC\99GÀЮI´!ÏÚ(\1ab\9e4\10H\ 3&/\86\10!  Á\11R\rg23fíI¬1\99\81\r\88òq\14HL\8c¤Ü "\ 4B\7fD­j\0|ª»5\8d@´¤\10\ 1Îí\fã\ 2\ 2: æ˲¦£æA-\19\14Q\9aÄ<¡º¥"f
+Q\9f\9e\ 2   ù´+Ê\\ 2ª_\ 6R\88\98\89\ 4"$b\15iOÉ7 rCØ\1c\8dR>\88\8d1\9e\17¦Ú\19\19½çPÑÚ\1a©\87¸îß\18   I\1e\8f\ 4µí\ 4´-\97«í&}¼Ýï:-½êUöæ[úI\9a\80³~`Ò\17èà¥S\81Ã\17èhd\1dÜ_ô\ 5\87`\19|Á!ÚS_ÀÙ\ 2\92\94U\9c\1d:Aò4è:'\8fÿH{*Þ\16\80ÓÇ\18Åí\8eõ1\8fÑ\18InÄ6âI      ï1y5É\ 1\95U\93\f¨Àl¬{T\16gíþ±\95¡IzÜ"¢\1a\ f\1eÃ\95õ2¿\7fFÁeeÜ\91\95Q¼F\18%p,·9¢¹-`q[Çò\18u.£HJ\91ý<
+p\9b\19Õ\19 
\90¼\81\ 2~!¯x\84<Ñn`\1cÌÈ\e°\1e\17þ'Ö`Ц\fÖ`\90¦\9cÖ`ú¯\82\96Á\ f\a1e\ 4
+endstream
+endobj
+2678 0 obj <<
+/Type /Page
+/Contents 2679 0 R
+/Resources 2677 0 R
+/MediaBox [0 0 612 792]
+/Parent 2664 0 R
+>> endobj
+2680 0 obj <<
+/D [2678 0 R /FitH 686.127]
+>> endobj
+2677 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2683 0 obj <<
+/Length 697       
+/Filter /FlateDecode
+>>
+stream
+xÚÕYMoÓ@\10½ûWìÑ>d;³ß{¤Ð\ 2=TAX\15Ré!!\81\ 3     \15H\11\7f\9fulWIêà\99f+ÊÉ\89³~ûff=ûÞ\ 6Ä7\ 1âmq^\17g\97AD\19\9dr¢þ*Ð\81\v\17\9cDåE½\10·%ZUÝÕWg\97\fU\16¤OC \1dôj:½¸~óþS5ÑZ\97ç²\9a$\9còfª\9bG\vè&<¼^ÔÅÏ\ 2ÓG\10\98&7Òº(Ò\83 9\8a/ëâö\ eÄ"ýx%ÒdÑ\8bßÛ¡k\816Jhæ^\89\8fÅ\87\818<HkR\1cÖKe\KñÝæ3 ^Ï~´\1c_ßW\13\15ÊÅ2]b\88e]\ 5\7f¯Ò½e7䦹5[m\96Û \86ÉZ\94.\9aC²&\86¿\92õf\88­\ 1©BhÙÎ\ 1Ú¬ïÅe\94Dmú¤Ç®.»`\93\ 4QFk{4\1c\87\ 3\ e\1c\ eòÓ^¢Õ= \9aAÄnÐcD\1c¥¨Y\14)\1c\95cq\1c&y\10v\18\87t;\90HȤç±<\12ú~2\ 3/\99¤Ø\15r\89\8ecj c¦¸     ÙT,@BÅ\91\94E\12GËáØ°$TÜÓ+ÞaRPÝ\13PÇ_uËG%,OÅÍê8Q3Nt·ö\84·]\ 5\1eKJà\9e\ 5I!ix\88\14\84\1c/\8eb\14çÈ{¹\ f\88\8ceIê\1dJ3\82&6\ f\15¹\98\84\1eÇŤlk\8e\8bI\0Õ\9c\82\12ª\ 4\84|²êNÀ\83ã*U9-£÷9$µ2Zª\9eXÒ÷\12[­¼§®M£¦M9\9b¯\96í×ëͺ\11Öó­ä^þj\1fi·á£æ`Ð$h\83Ò\80Ëa\12´ñR\aó\8c\81l\ 6\93ðÀöÿ7    ì\ e\11Nr\1d\99·º\8c\82Þí\8bï¬]¿ÓÞð\1c\82>³¶{©\82Þò\ 4½
+L\8f\90EyZ\9eòäº\8e\7f£<õ\vP\9e\0y\9c\91;DÍnb\10I\8b\16\13í4\80çÜi§\ 1L\1d\92æy\ 4ÒÉ\17\ 2éh\85\8bI
+Þ3ý\f©}jdSÍ.ÁI²\9esT\87´\ eªO7
+'8Χù\84^¨fð     ½NÍé\13\86ÿDH\11ü\ 1l.h\9e
+endstream
+endobj
+2682 0 obj <<
+/Type /Page
+/Contents 2683 0 R
+/Resources 2681 0 R
+/MediaBox [0 0 612 792]
+/Parent 2664 0 R
+>> endobj
+2684 0 obj <<
+/D [2682 0 R /FitH 686.127]
+>> endobj
+2681 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2687 0 obj <<
+/Length 717       
+/Filter /FlateDecode
+>>
+stream
+xÚÝ\98Mo\1a1\10\86ïû+|\84\ 3Î\8c?Æö1T¡QÔF­²Í%Í\ 1
+í¡Ð¨\95Pÿ~\17\f(l\96ìLd.=\ 1\8byv>¼Ãû\1aÔ\ f\ 5ê}5®«\8bI°*éD\86Tý]!\90\8e\94\14EÒh\82ªçêa0ÖN\ fG!ÄÁõ\97Éäãåípd­\1dÔÃh\a\97ã\ fWwÃÇúæb\12\9f\89:Phî²% ·\9b5\15ìnÜ~½ª«ß\156oA¡B\ 4\1d\ 2*¢ \83IêÛªzx\ 45o¾¼QÍW)¨¿Û¥+\85>iØÜe©îªÏ9\9fça \92\ e®IÇ\am\1cå`®×_\ 1íjú+§ñîi82q0_4/)¦\9cÖÓÏasm±[r¿¹4]®\17Û$º\83õ¨)¹v°.ÅW\83\r®+Z\aÚÄ\98£\9d\ 1¼,/:£Ñº}yS^q\ 4\eí×\8c\10uò~OÃ~\1cHp\f\9e\15ñ°\97\87|\1eBgùlÐèÍ\81g:\81»E/\80Ø\ fÄ~ \1d\80È\bÑXI\88ØÝåV\90^\88äÄiA\fí/§A)\14\19\ fM\90ì¢\fíß\9aÔ\ f¥c(£SV\9e?\a\e°ý%\88¢º2Æ\87\91\ 19½÷R$ã\99O¢g\9eÕ!$Q\87N´§Õu  \937>­\8cÈ\99#\18¥LÎ\86\97´(C\19õ\ 4\f¤\13!Yõ\94"9»3H\99\8cÔe}ç\8c\ f'\18Éùaï\8fÒ\v£äd.ª&c\1eÁi±jÈê\14B     em\9cÕf\1fØý'«1Kæ#\91í6¢Ú\r¦³å"\7f¼]¯6úz¶UÞ\8b?ù'y\8f\9eô\b\9d^ÁÄ         b       ¯`\92×1\11Û+\ 4\1f\84\10l\ 1¯`\92Õ>\12Ç+tí\vÞ>c\b\9eô?hñç*\aÊ+gF\19½P7\ 2\9cC\8c\ 3§ \9c\7fÑ\16µðÜ\87C Î r3¸´Ì}¥ºbWBm,\96w\10p\16_\ 6¥õ)\9c\92\0rmÞr:ŵy\89S\12êÑåo÷M¬!åD@Þ(\8dR©{\ 6ù\HëÒ±Ö\85\12\87\ 5\8cå¥ia{Çëº\13"YGdA\f-ãîè\b\8aeÏòX§N\92\ 3\11\ e\9cÖ®\ 5¬Ã^º\96´\ e¾Ó:4\19ü\ 3ß\ro\f
+endstream
+endobj
+2686 0 obj <<
+/Type /Page
+/Contents 2687 0 R
+/Resources 2685 0 R
+/MediaBox [0 0 612 792]
+/Parent 2689 0 R
+>> endobj
+2688 0 obj <<
+/D [2686 0 R /FitH 686.127]
+>> endobj
+2685 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2692 0 obj <<
+/Length 728       
+/Filter /FlateDecode
+>>
+stream
+xÚå\98OsÓ0\10Åïþ\14\87¨ÚÕÿ#\85\16è¡\13\ 6O\87\99ÒCB\ 2\a\12:0\93áë£Ä1\8d\e'Þu5Ã\81\\928òÓ\93V\92ß/J|\13J¼-.ëââ:\88(£C'ê¯\ 2\9c\92Îyá\82\93\80\vq_\825ÕC}sqíõAS´JúÔD5\8d^M§W·oÞ\7fª&ZëòRV\93¤SÞMõöÖBí;|þ~U\17?\vH\1f\95\80Ô¹\91ÖE\91nLÊQ|Y\17÷\ fJ,Ò\8f7"u\16½ø½kº\16`£TÛ¾Wâcñ¡g\1c>H\15\82pÖK4®±ønóY\81^Ï~4\1e_?V\13\fåb\99ÞPcYWA\97\8fß«tm¹or·½4[m\96»Aô\9bµ ]4ÏÍ\9a\18Î\9aõ¦ãVIkÒ¬\e%1¹Þ¹\9d«ôjæ½32í%XÝN;Ø}i\ eõ&m£      \80\8cÖ>    Â° p\ 4\81à\10Y\82Ã\ e\91ã\10ú'Ñ \ 4mZEÕ+¸os,\b\84º \e6é:\9a0h\13\986     SiXSI¨6"OqØ£V\1c\82d\r\9aà\10\14½Ö¤õ\18é\85\ 6Ò\9eöô\11\93ª\f\9a%HY7LEÒ\1e\f\MÂ\8e±\9cZ\ 3Ѩg\1a=Q¤î*BÎ*jDIf#ß,\9c83»\86í\18ä©\bÃÊ®OyøLv£<\ fë\9a\11ºÃª\9a«J8\9e\19OcÚúR,AÂé\17\18[\96d\11\1cÇ"åÑî\19\85!=\92âéÄ\8aNËèýËâu\13XÑh\89­³\94õ%4¹¹\93´Í6Y\9br6_-\9b¯·\9bõ6dÏwñ{ù«¹¥\99Ó\93 Ð\v\fÚ\804Êå\0\ 6mâ.ÆS\81Á[Ï\ 4\86¿f3\0\836^ê`\18À\80\14`@\1a0\8c^ºçx\ 1)\0\82\f^@
+\80`\1f/¨ÜI\\r\9bÔ\84Q;\1a\83 \85\97k\bå9\97UN\88BΨB%\e&\87dÍÐÙ0Ä\1d`\88ÊMJ\84º(\16\88ü\ 3°Q\99Á\ 6y\82\90\85\94ÜA<¢\ 4$ÃK\¤q[®&!usÒf£I;}Ý(]ÈÁ\1fîH\172\13Ó\930äÀ\9a#ݼè±W\85¼,NÚû\bÿ\ 5'¼ào\92± Ð&Õ\f Ð\ 6Õ\9c à{A!\8dà\ f\9dWj÷
+endstream
+endobj
+2691 0 obj <<
+/Type /Page
+/Contents 2692 0 R
+/Resources 2690 0 R
+/MediaBox [0 0 612 792]
+/Parent 2689 0 R
+>> endobj
+2693 0 obj <<
+/D [2691 0 R /FitH 686.127]
+>> endobj
+2690 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2696 0 obj <<
+/Length 720       
+/Filter /FlateDecode
+>>
+stream
+xÚå\98MoÚ@\10\86ïþ\15\ flvf?f÷\18ªÐ(j£V!¹¤9@¡=\14\1aµ\12ê߯Á\98Bbê\19ºý\90\9a\v\89Ø<~gvì}_\eõQ\19õ²\18\8e\8b³\11Y\95t
+\18Ôø\83\ 2\13t\fI\85\184 ©ñLÝ\97Cít5 \8aååíhôúüº\1aXkËq\15my>|uqS=\8c¯ÎFq\8fc1j
+T_eC\0ï×k
+³½ðÓÏ\8bqñ¥\80úW£@\ 1\18M\ 4*\ 4Ò\84I½_\16÷\ fFÍê/¯TýU"õm³t©À'mÖWY¨\9bâmSϾ\f\81\9c
+\9e4ºÐ\88¹\½3`\97\93ÏM\19/\1e«\ 1Ær6¯?\òë²\ùø©B*çÛ%wëJ'\8bÕ|SD·X__)¹§b]\8a?\15[kÛS\vA\93«\9bï\8cÆ\18\eµS³þyÞa°¤ÁcÛa\84\ 1pÐ.\1a\0èäý\1e\11\18H/DB\aÒ¡\ 6ëvsÐIÜ®yF\84^\89 \92È©Ù\88\80ý\15S\7fÅ¡å\ 1c\9fA²ÏÀi!J\80\8c\16\ 2\89\80\f\85\8e\ f\ 4sìv9Ü\16Ë\1fÄ\ 6Ù/\13\19\8d\fûÌ~¤\ 5\9c\ 1\176\138C\89$\86öß9(Û"\0àm}8\89Ëim\92\r@KîoE<Er?Ö\9f\80í§:9\95qsEé\841\1e,\18D\eÆxR\19\89\9fÕ$é%çQ\9a\ 4\ 2YÇQ\14\ 1\19w\9152bÿ@\1aþ\11\f¬\ 3ÎJ\14²\88AFd\8c¶=nU1X\9d\88~ÉWo\9d*:«±\95v÷Æjh\fó\81Åv\8d¥\9eL\17óæÏëÕ²ª\1d÷tã»ç_\9b\7fi&éhBèL
+\18I\a\13s$\ 5L^Ç\14ØI\81<5\ 1h\9d\14"')ìÄfH
+\98¬ö1t%\ 5Îq\1d\9eå~HÈdù
+\14C\81å\ 1¢(\87´\Èé-~p!«³Øq³\9eÿ-5ëño\98ö\aeHø\riùß\8c¶A\14\9f\8f¶þïF[Ê\1dm1w´\15F\ 6\93÷­\r\ 4)\13r'pÈúê\86çæ£ds8ã#ÊÞ,ÿ-{CÀ\8bZB\95\90ÛÒ\9b¼9\8bs\12¦ÿ""tÄ¢n\8b\9a!!´\ e5gBH\9d   ¡®à;U
+i©
+endstream
+endobj
+2695 0 obj <<
+/Type /Page
+/Contents 2696 0 R
+/Resources 2694 0 R
+/MediaBox [0 0 612 792]
+/Parent 2689 0 R
+>> endobj
+2697 0 obj <<
+/D [2695 0 R /FitH 686.127]
+>> endobj
+2694 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2700 0 obj <<
+/Length 743       
+/Filter /FlateDecode
+>>
+stream
+xÚÅXKoÓ@\10¾ûWìÑ>d»³ï=Rh\81\1eª ¢
+©ôÐ\90À\81\84
\88¿Ï&k\97:]Ç3éFÍÅy\8c?\7fóÌ7+Ø\ f&Øûê|V\9d]z\16x°Ò²Ùw\ 6Vpk\1d³Þr\90\8eÍ\16ì¶\ 6c\9b»ÙÕÙ¥SOL¥\11ÜE\13\91\8cÞL§\17×ï>~i&J©ú\9c7\93\88SßLÕöÖJ´\ fÜ¿^̪ß\15Ä·\82A|¸æÆ\ 6\16o\8cÈ\81}[W·w\82\8fW,>,8öwgºf`\ 2\17Ûg¯ØçêSÆ\ f\8et­q\j\9b(~Ø|\15 Ö÷¿\12Ç·\ fÍDúz±\8c\17\1dL=k¼®\1f~6ñ»ø\15Ô­ÙMãU}¿j Þ,w¾ä9\eà6è}Î:ø\83\9c\9dî\91\16Üè\18|-¸ô>\91\9e\8bøJáï9¨\1c\a£ºè«Ö¤\87\8c&\0<\18ó\1f\10F\ 1ÁP\0a\9c!8\12`\8e¡\96\1c\94î\0ó\1e·6{x\90\ra\1fÏ\91ð\10\11ôã\ eÛG@D\ 4¥"D\10""¢n$P1Ç\1d\97\8e\88   ãÉ\91\94äl!\114-\8d&&C\86\94r@T9à\1dG%\1c$ÞkT¶\ 1(\80\98A¡I\80\18DKCÄu\ e¡½[PÌ\142\94|·¨\98Ê\94ä\10ìb;NØ\1fC8??ûÀö(`Dß\azâÆÙj*ÛqHE\84D¸NP  \ 3Éßë,E\ 2Äôj !" \15\10\12\8e¬!Ê\8cB\8d(Rf\10õ\18\86¥ª´\8a\aç^&¯\93R\95ZqÙ\11\8bZ\9fCÒÌ=¥­\93²¾\9f¯\96éãõf½\15Ùó\9dü^þI·¤Ú\1c\\14²\v\83ÒÀµ°%\16\ 6e$W"\1c·0¸zÙ_\16r\9bÂ#Ù\ 2\9b\82Ò\8e\9fo
+¸º@
\ 3ý*1\8b\87ÌÈz\ 4EE¢\b\18\96\87þ¬³,\87g\80ÄÈÜ\1cæ8â¡A%\9fÉÇò+\8d(:÷\ 4J\85SæýÀ´\7fÁZ\88!H\13Ì¢\88`¶$\ 5®\v+pÊ¢y:\ 5^vyíP1mCW\9e»î)£Âm\ 6\19N Âqí)Ã\11!\86Sl9¯¡À\11§\ e½tazK\10\ 3Zø$ãµd½/.ë¥!B\169l±OT}ÙCÏ¡\92<þ\\16U<)Òy©Z`Sè\94jÉM\ 1²\9bBôà\1f\ 3Zk\b
+endstream
+endobj
+2699 0 obj <<
+/Type /Page
+/Contents 2700 0 R
+/Resources 2698 0 R
+/MediaBox [0 0 612 792]
+/Parent 2689 0 R
+>> endobj
+2701 0 obj <<
+/D [2699 0 R /FitH 686.127]
+>> endobj
+2698 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2704 0 obj <<
+/Length 729       
+/Filter /FlateDecode
+>>
+stream
+xÚ½\98OsÚ0\10Åïþ\14\a\14­þìJǤ\13\9aÉ´\99vBsIs\80B{(4ÓÎ0ýú5ØPCL½KÕ\9e\80±øù­V\92ß³Q_\94\8b«Iq1&§\92NhQM>+0¨#&\85\115XR\93¹z,¯´×Õ\88(\967\1fÆã·\97wÕÈ9WNªèÊË«7×÷ÕÓäöb\1c;\1cg£&¤ú.[\ 2\ 4Ú\8c)L{ããÏëIñ½\80ú«Q \0\8c&\ 2\85H\9alR\9fVÅã\93Qóúâ­ª/%R?·CW
+BÒfs\97¥º/Þ7õte\80\ 5\8dä\15\ 6ÒÖc#æfýÑ\80[M¿5e¼z®F6\96óEýáSØ\94åËç¯\95¥rÑ\ eyØT:]®\17Û"úÅ\86úNÉ\1f\8bõ)þQl­­£\16P\93¯'ß\emclÔÎ\8c1/ç\17\1ci\bv?¿í\90\ 3Üh7h\ 4 S\b{\1eôð¼Õàü\8e\97zqí\98#\1c°\ 4F\81\97xH´AD\ 4\86H\8bBä°JHÃHì \87[\ 3\92Öpªv ©\9aU4\89\88\f ç\ 3\91Ñj!\11Ì`cÜpc°K<%ô\90\8aüvï©ÀàƳ¸À\98Y+\9cÙ\96ÌØñp\ e\99ÁMrîð>\râåÀPj¤J\19L\121\19\9b\0\18+
+D}ç\1c'\8e\7f(\ 3g3\19ÁfbõÙ      *f\1dò\10dÄáõM\92\9a\99\87\9d\173\19s\19%Íæím+ÔÉX\92\ fc\91;sÚ¬Zt:\11ý\95³n½ªõNÛ\9d´\87wNCc\99\ fL¶oLõt¶\4?ïÖ«ªöܳ­ó^ühþÒ<9Nf\84Þ¬`#i41GV°)ê\0ð\ f³Â^l\86¬`\93Ó!"++\9c}X±\8e{#2Íy£\açpv2 Çâ\90Ð1çÙÿ(²Ì.·ev\90Á2\9f\1f\14Z\93\94õ\19µH1·E\ 2Á3\895\91\ 5¹\ 3\12@fÃÀÊp"OÃZ\90\16\85È,^¡ã5\19\v\1cdf3sºf­\1d\99\1d?\90ÄÐ-ØdIUØC\86¬!û78wÈî\903\87ì=9sÈÞq!ëë\118ýBàüè~21\9cÿþ\93\e\19Âÿ\88\f\9a!2ì,kÎÈàz#C]Á/¦\ emR
+endstream
+endobj
+2703 0 obj <<
+/Type /Page
+/Contents 2704 0 R
+/Resources 2702 0 R
+/MediaBox [0 0 612 792]
+/Parent 2689 0 R
+>> endobj
+2705 0 obj <<
+/D [2703 0 R /FitH 686.127]
+>> endobj
+2702 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2708 0 obj <<
+/Length 739       
+/Filter /FlateDecode
+>>
+stream
+xÚÍ\98OoÓ@\10Åïþ\14\ fÙÎìÿ=Rh\81\1eª ¬ªRé!!\81\ 3    \15H\11_\9f\8d\1dWqâÔ3a\11\9cÒ¦ë\9fßîLwß[\10_\ 5\88·Åe]\\\a\11etÊ\89ú\8b@\aÒ9/\p\12\95\17õB<\94hCõXß\\{½7TY\90>\r\81vЫéôêöÍûûj¢µ./e5I\9cònª·\8f\16°{ááçU]ü(0ý\b\ 2ÓË\8d´.\8aô`"Gñy]<<\82X¤?Þ\88ô²èůfèZ \8d\12¶ï^\89\8fÅ\87\81yx+M\92ë¬\97ʸVâ»Í'@½\9e}o5¾~ª&*\94\8beú0Ñ\96u\15Lùô­Jߥ¯°Ü\r»«\82.g«
+ËͲ\99Ë°f\8bÒEs¨ÙÄð¢foz¢AZ\93\16ß\80T!´¢ç\0Ю~o~FIÔ¦[ü¸«Ï>mÒ\8d\99 Êhí3\ e\87xÚK´ºã)3\bÜ\r:\ 2â¨@Ï\10\88Ã3î+DÏP\88¤Icd")\v   ãL×câxµ\15o1\91\ 4Õ|(\12\9c\83¥\80ÝyàñVµg\81\15\14»\15\90\82EV×\8e\ 3\91ó¿\7f¢\a\ e$Z\1e\91 \91G$\89ôL$¡4\91SqR±\ 3]$i\eÕÀ\ 2\12*£9@Ê®¬X@\82B¤WeÛ9\94ó7Ð÷\8c\16\r!\13I\98¸c¬$©Ø\1aYDB\7f\aiF!pÊM\9a¶r<\95ãÅ\ 6N±)=\ e§\9dªrZFïÿÌ]·FU\19-U§,Y}\89­eî\19\1aëÙ|µl\7f½Ý¬·\1e{Þ¸ïåÏö\91Öq\9eÌ        \83yA\e\94\ 6\\8e¼ Mlì;5/xë·ÓÒ]^èg\85¡ ð,6CPÐÆK\1d\f)(4\8d¡ú\8d1ܺêØØg\r\1e\b\14\85/\9dÃj\b\89\ 4&p\99Ä}\9fiB\81ºù\13<¨;âæ± Gz1·Ç§Y<¦¯mürÎs\1ahG\81ý\aîÛí»ïܹ\163\9b\93¿cè³\9e¨ÿ­Qv{F\19òº1 1Uä2ó^5ì\98\98óNä$\91ïò\1c+x(\9eÿÎ\92döí7¥Þ\81\89Ì\1e;ò^&"é\92N³"\ 2fJ\1dû\8e\9e²\8e\9e\87Dâ-ï°MÍ\90\12:\97\9a3%ØÁ\94\90\e7\94j\14
+endstream
+endobj
+2707 0 obj <<
+/Type /Page
+/Contents 2708 0 R
+/Resources 2706 0 R
+/MediaBox [0 0 612 792]
+/Parent 2689 0 R
+>> endobj
+2709 0 obj <<
+/D [2707 0 R /FitH 686.127]
+>> endobj
+2706 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2712 0 obj <<
+/Length 728       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98Ko\1a1\14\85÷ó+¼\84\ 5\8e\8fß^\86*4\8aÚ¨UH6i\16Ph\17\85\84ú÷;\83\ 11dèÜ\9b¸+\1ec¾9÷ÚØç\8c\12ß\85\12ï«ñ´º\98\ 4#\92L^{1ý& ¼\8c>     \1f½\84\ e\10\8f\83±´r8
+!\ e®ï'\93\8f\97·Ã\911f0\1dF3¸\1c\7f¸º\e>Mo.&ñ\88ct\94Á\87ú.[\ 2\jÆTjwãÓ׫iõ«BýV        \b\10 ¼\ f2è$¾®«Ç'%\16õÅ\eQ_JAüÙ\ e]\8b\9a+Us\97\95¸«>çz\8ee\0õuW\97ã\82ÔÖg1×\9b/
+f=û\99Ëx÷<\1cé8X,ë\97àB.ëùÇ°þn¹\eòÐ|5[m\96Û"ºÅ:H\9fì©X\9bâ?Å\ 6ÛRëe°µZ«¤\8e\9d+¥^ö\17VK\18»ïoÊ#Z´Ñ~Ì\b\90ɹ\ 3\ e\14¢f\12Ñ\8f\8c\d#´Sª     \12N\1f¤vkÝ\r:\vF¯`ÿ\1aÁýX×\8fõ§Xôw\ 1ü.ôkµì\16\10\94*\9eÒ~\95`©Dÿ\92\82cI¤\14íû\89\87Y\aeÕ[\86\90\89\89ì/\e\91\87$4\92E¤Ìµa\ 1)\8d\ 4k²Ai¤\ e<\95\ 4"c\8d\83²\ f\eÅ\ 2\12\16\8fæ\0)S\rú¼@Ѧ:°4Òd&.³\7f\8b4ô-\12¤\rÍ0Î\9b3\9dl+T\f\85 ø\8d@?gAÚz`9%\13&Z\e\16\90 P\9dw¨Ú\e\99Bx\9b\9dÎ\ 6U[#õ^ÙÃ'#\91}rËYÛÆIÛÁl¾Zæ\8f·\9bucªç[»½ü\9d\7f\92ÏųÁ 3 è\18¤W±D@ÐÉÉ\98ü\7f\f\b\a±\ 5\ 2\82NFºè_\ 6\ 4Ut/U¤Í\99ç7\89K\97ì\14\8aF"Êiix§eÙí\896#\96\124²N\8dì2)¥û×`Q6        \1e\81Ë\86«\ 3¸h\12ÜSËÆ«\1dµh\ eÌ̲Ñ\0\8aâqÀò8e#\16Õ.:¦\ 3EÑÔF³v\9c\88\ 5R4 ¤ßc"é\11Ud\19\9f\87b½}\v\8a"i°%´l\1a$f\ eÃ#¢l\1c$ýyX\89\15´g\1e\94üæ[L\94|v
+b/ñæ Ð\11¶º\8dj\81\9c°÷©%sBèÌ  u\ 5\7f\ 1Û_i:
+endstream
+endobj
+2711 0 obj <<
+/Type /Page
+/Contents 2712 0 R
+/Resources 2710 0 R
+/MediaBox [0 0 612 792]
+/Parent 2714 0 R
+>> endobj
+2713 0 obj <<
+/D [2711 0 R /FitH 686.127]
+>> endobj
+2710 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2717 0 obj <<
+/Length 742       
+/Filter /FlateDecode
+>>
+stream
+xÚÅ\98OsÓ0\10Åïþ\14\87¨»ú¯#\85\16è¡\13\ 6O\87\99ÒCB\ 2\a\12:0\93áë£Äq¨]'ÞMÅpJë*ÏO»ªô{\ 2ñM\80x[\ÖÅÅu\10QF§\9c¨¿
+t \9dóÂ\ 5'QyQ/Ä}\99\1eV\ fõÍŵ×O\86*\vÒ§!Ð\fz5\9d^ݾyÿ©\9ah­ËKYM\92Ny7ÕÛ¯\16°\7faÿóª.~\16\98~\ 4\81éåFZ\17EúbR\8eâ˺¸\7f\0±H\7f¼\11éeÑ\8bß»¡k\816Jؾ{%>\16\1f\ 6æá­4É®³^*ã\1a\8bï6\9f\ 1õzö£ñøú±\9a¨P.\96éÃD[ÖU0åã÷*=K\8f°Ü\ f»«\82.g«
+ËÍr7\97\16¥\8b¦ïÙÄpÒ³7\1dÓ ­IÅ7 U\b\8dé9À¾ú\9dùi/Ñê¶øØ6è©Ü¤\1d4A\94ÑÚ\83\1e\ eè\19%Q\9bV/\ eÊíÇôä\90àOY\86?ÜJ¨GÃò\88ÃÓî\9510m"¡5n\Óu4    >=Ï縢bÍ||\ 1\ 1½9¤õ£éöH]Q\86%Hò\18é\8dÞI\8eWQqª\88\94\85é#Rv\1eåx\8aã\1e\14q|§@F\19w\9d\19\9fµgôúXkº&=Ç$i\83ÔLE$h\ 6¶æÖ*e\1d)N×ÿ*\13¶6äôê <Þ1wN-\b\8cJ\8c»µ|·\84ý$r½\124-O\93r\ 6\eÞ\12 ¸ÔÈrI1Éû\ f T\12\8fóªrZFï_ÆØ\r®*£¥j­%à\97Ø\80s\a·M\83׳ùjÙüz»YoI{¾cðå¯æ+\r\86\1cM\v\83©A\e\94\ 6\\8eÔ ­\92\1aây©Á\97Ënb\18\8a\v\a³\19â\826^ê`èqAQâ\82ú/qáì\ 3û$\84+
+÷¨!`\1e\97<\85{\83\92Y\10À\9d\97@3äeú\7fÁàyÑ\91Ô\12\16C\918'°È1×éÖAðܧ\ed?Ý\80|º1Ø#s\96AÒÍ\a\85f:èAØn\r\ få([\85ÏM3Ê2i\86tÍåØ¢y.S\G\94\1ai\80ë¶I4ÙÃÒA9OXz®\9c;+!õ¾.òÝfIJ½õ\80¹\833\12¯s\ 2sþÄ+§afÍ\10\19ZdÍ\19\19â`dH3ø\ 38-mÈ
+endstream
+endobj
+2716 0 obj <<
+/Type /Page
+/Contents 2717 0 R
+/Resources 2715 0 R
+/MediaBox [0 0 612 792]
+/Parent 2714 0 R
+>> endobj
+2718 0 obj <<
+/D [2716 0 R /FitH 686.127]
+>> endobj
+2715 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2721 0 obj <<
+/Length 733       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\99OsÚ0\10Åïþ\14\a\14­þë\18\99L\9bi'N.i\ ePh\ f\85\19¦_¿Â²Óà\98\88\v\ 4\8b\9fßz%ù=G°ïL°÷ż..\16N±À\83\95\96Õß\18\b˽\rÌzËA:V¯Ùc9ç\9aW3ç|y}¿X|¼¼­fJ©²®¼*/ç\1f®îª§úæbá_q\94ôÜY\17ÏÒ\10ÀÂaL!Ú\13÷߯êâW\ 1ñ£`À\0\ 4w\ e\98µ\8e;\19Ø×]ñø$Ø:\1e¼añPpìO3tÇÀ\ 4.\ egÙ²»âsªçµ\f\80xÜÄr\8cãRÛ$æzÿE\80Ú-\7f¦2Þ=W3éËõ&¾9ãRYÏ?ªøݦ\1dòpøj¹Ýo\9a"\86Å\1aà6è¾X\1dü\7fÅ:}¤Ör§£Z-¸ô>©] !Þ^_P\8e\83\91/×·\1dr\84\9bu\83f\0<\18óÂ\83\ 1\9e\96\1c\94îxa\10×\8eéá`\\9eT\ 4\8a¦×xÕa\ 2\16#WLábÀr\1c\82a\1c\ftÅãTðd*\ 2ê¨Ðñéj(Ó\15P*5Må8Q      RïÇ\8b\ 6|Ñ0¸\98\8eq\82\82ÃÌuÂ\15\ 4Üêñ4"`¶\10Ce"\84\82Å·º\85Âx\83<©A\rt|\12Y"\141Ï    [Q³¼G5J\82FÜâ&lÃÈ\8eÓ\8aÆ´[\93ªFÝ$\1cE$fõHK#b®¤""1\eG ô\e·p\1c¥=\98~+\1a\10ÑnsÚ­J«xpî<k\9d̪Ô\8aËNÚÃ'Å!yæ#\97­\ f®Z\97ËÕv\93þ¼Ýï\ e\ 6{ÕXïÍïô\93t\8b<\19\12\ 6Ã\82ô\8e[ás\84\ 5% f\1e\8b\ e\vRIbXx\11\9b!,È ¸ñ\16\15\16&ßéQ»)É-\8b¼Ù#³\11I®!Ï\8erÌDa1ÞØö±8Ár\82`ÔÍ\94\18=:2æVà§\91ó'¼\7f\1dJ[4ä°\7fý©\ 1Y\9cjO,dõÔɨfµ.8\9b
+\92büó>â\0Ì6\bø~ãæ<É£
+\80ÜfMà|\90£&\92¼a\1e0YY\11z\83j¶$\9aýìÎ\d\8eߧ\82Øäç6§ö\893B\13.}ZJ¯qù\93\16\91³=]:?>tþ5C|èìkÎø0ü?\86XÁ_ \1c
+endstream
+endobj
+2720 0 obj <<
+/Type /Page
+/Contents 2721 0 R
+/Resources 2719 0 R
+/MediaBox [0 0 612 792]
+/Parent 2714 0 R
+>> endobj
+2722 0 obj <<
+/D [2720 0 R /FitH 686.127]
+>> endobj
+2719 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2725 0 obj <<
+/Length 753       
+/Filter /FlateDecode
+>>
+stream
+xÚ½\99OSÛ0\10Åïþ\14\87\bí®þXÇÒB[\ eL:Í0ÌP\ eФ=4)ÓÎ0ýú\95ã¸$ Ä»AS8\ 4\82üóÓj¥¼g\8cú®\8cz_\9dΪ\93óVE\1d=z5û¦À\eí}P¾õ\1a0¨Ù\ÝÔà±¹\9d]\9c\9c\aÚ\1a\8aÎè\90\86\98\9béôìòÝÇëfBDõ©n&\89S_M©»´2\9b\e>\7f=\9bU¿*H?\1a\ 5éæV;\1fUº0\91£úºªnn\8d\9a§?^¨t³\18Ô\9fõÐ\95\ 2\17µéî½T\9f«O\99y\ 4Ô­KópA£õ½Ä\ f\8f_\fÐêîg¯ñíC3Á¶\9e/ÒKp¡\9e5-Õ\ f?\9aôÞb3äª{ënù¸XO"/Ö\81öÑ>\17kc{Pl°;j\8dv6©µFcÛöjïM÷Õ\17~gj\1448\1aê\8ev³6ÛÀÉ0h\ 2 £s[D` [!\12Æ\91 B2\80$\ 1f'mQ\ 3Ù\ 1\18²¼Í\98\17¼q\81àÆ\ 5ú\ 1\b\8c\85\86 \98\90è\84È<t·\90(($l¾Ç\95¢Xiv\8dv¥¶R©ãH\18Gn­:\ 3h$\1a\19\95\84(©$§Ñ\ 5[\e8'\1a \b8^ÂÈ/!«\19Áð·6°Î
\81\v¬³Â\8a\80\9c\rhdDÖñã¥L\8eРX\9c\1e
+{>hw»È\vºè\89\9dî\18î8Ö\1e\81e|ìFñ\921Î8\12j\1d×I é\ 2\92h\ 3pj   ¢öç\1c#´ß¦¢'\1dCx\9d§î]*ZÒ8(K\ 6_Co\96wìµíì´­ïî\97\8bþ×ËÇUç¬ï×\9e{ñ»¿\84ð`:Ȧ\ 4² ­ñ%R\ 29Ôd";%Øèúiu)!pRÂ?±\ 5R\ 2Ù ©µ\99\94°¯3\90Ó¼\98±ß\8cã\10$~Ù\1cØ\ fÈ\89\1d9\91\f¢\95\10\8e\87<8
+R\ 2rR\ 2
+R\ 2\ 4f<íx\rI\ 2äH<t6ç\88\1c&\ 6)\93\11      If½\81Õ\92 Yp\1eÒ\89æ\ e%£ðÿ2ô¯\89\1cPØ/3Í­0$°¼­\17Ê\ 4(\9a×\aCg\8a\eæ-pYÇü\ 4\86"\ f\19ü\vpY+>`\v\r¶è#\11\9e\13\97¹\F[EYX(\9bæyé;¾>*\1cý\10èè¤0XÕ\ 2Iapª%\93Bþÿ\bi\ 6\7f\ 1\92-hü
+endstream
+endobj
+2724 0 obj <<
+/Type /Page
+/Contents 2725 0 R
+/Resources 2723 0 R
+/MediaBox [0 0 612 792]
+/Parent 2714 0 R
+>> endobj
+2726 0 obj <<
+/D [2724 0 R /FitH 686.127]
+>> endobj
+2723 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2729 0 obj <<
+/Length 734       
+/Filter /FlateDecode
+>>
+stream
+xÚÝ\98KOÛ@\14\85÷þ\15³´\17\19æÜy/¡"E¨E­HÙP\16PÒ.J\8aZ  õï×\89\93È\ e\ e¹\97N7]%(ÃçsçÎã\1c\eõM\19õ¶:\99UGÓhUÖ9PP³¯
+&è\14²
+)hPT³{u]\9f\9bI\8c©>û4\9d¾?¾h&ÖÚzÖ$[\1f\9f¼;½lnfçGÓÔãXJ:\86Ø>eE@°Ë1\95Y?x÷ótVý¬Ð~5
+
+0:F¨\10¢\8e\94Õ\97Eu}cÔ}ûã¹j\7fÊQý^\r](ø¬Íò)\ fê²úØÕÓ\97\ 1\82\ eÑ©à£&\17:1gO\9f\rìâöGWÆ\9bÇfB©¾\9f·\1f.ûeY®~üÞP¬çë!WËJo\1f\9eæ«"ÆÅúöIÙí\8au9½(¶ÕÖS\8b £k'ß\19M)ujï\8c1Ïç\176jxÚίí\86\fp\93Í      ³÷[\1e\18@/\ 2b\ 4èHú\rÐ\8còÖcvx`Tl\8d@ 8%\93\93\11qX#\ e\13Ã\96È\91(i3\18]\89ü®´M1\9c¥H\82ÆtÌÑÂ\87:\93T'Æ×Ð\90ê^AåpýanxÎåô\9fÄs\8b}Ku(9¼f*\ eï\0\82\0\83\9a\85T\ 6\90\87\89\büÍ\ f\16ÐI$bßn\1döÝJú¾w.\87L\922\19í\89ÂÚ\19H/é\ f8\r\12­!Æ:\87d÷p.M\90\bÈP(9ìÁ8è³`í\80se"
+ÚÌDfQÑ,&\ 5)óð>Ä~·JÁê\1cã_YëµY%g5m´]}°\1a\9dg\1e¸l×¹êÛ»\87y÷çÅÓ¢iM÷ÝÊzÏ\7fuÿbÝ\8b!a4,P\8a:\98T",PNÚ\ 3ÿ0,lÅ\16\b\v\94­ö)<\ f\v\85½3/.$\19±ÌõÙ\v %\ f\16VÁ¢øÁ
+4°PøPÙkèFÎ\14î4\96\8d\85`\ 5a\91I2\85.\90>\11E\82fßy\14\8d\85ÿ\8bñ°2ãQö\8d\a°1ØeÃà\16ËpJAä\94Ì6µ\95\r\99=rá4\bvÞpò\99@\91×\18;}CÑ´\ 5fèÈÂ9-\93\8c\ 6\94\8d×`ÞnQÊdì*\12íÖ%\93£4\8b\952®Î$\8b\97\81ã\86µ@^ØøÕ\92\8fæ\85\82?G\8b
+endstream
+endobj
+2728 0 obj <<
+/Type /Page
+/Contents 2729 0 R
+/Resources 2727 0 R
+/MediaBox [0 0 612 792]
+/Parent 2714 0 R
+>> endobj
+2730 0 obj <<
+/D [2728 0 R /FitH 686.127]
+>> endobj
+2727 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2733 0 obj <<
+/Length 747       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98OsÓ0\10Åïþ\14\87¨Z­þXG
+-ÐC§\f\9eNgJ\ f             \1cHèÀL\86¯\8f\12ÅÔvÝx7\15¹¤Iå\9fß®då=)ñ](ñ¾8o\8a³ËZ\ 4\19\9cv¢ù&À)é\9c\17®v\12´\17ÍRÜ\97àLõÐ\\9d]zì\fÕVI\1f\87¨4èÍÍÍÅõ»\8f\f\11ËsYÍ"§¼½ÁÝ¥\85:Üpø~Ñ\14¿
+\88\7f*\ 1ñæFZ\17D¼0\92\83øº)î\1f\94\7f^\89x³àÅ\9fýÐ\8d\0\e¤ÚÝ{->\17\9fFêðV\9a(×Y/µqIâ\87í\17\ 5¸\99ÿL\1aß>V3]\97ËU|3Á\96MU\9bòñG\15¿\8b_Ay\18v[ÕXÎ×\15\94ÛÕ¾\96\16¤\vf¨Ù\84ú¨foz¢\95´&6ß(©ë:\89^¨øJíï\15\88^\82Ŷûx\18ÒãÍÚA3\0\19¬}\ 2Â$\10\f\a8Æ3Z\ 2\9a\96\17Fq\871\ 3\1c\v\9cz\ 1\b\1dÔ\96\88¬§\91®\8b\ 4Ò\kfí{ì¨Üþ\14\14µX\ 2×\9dÄ%ôWëS\1a\11_Ódà\93§\9f\ 1\88Ár (\r\¥Ó:\915a\84\89B^; \13\ 4\8c§uÿT\11V\93g"    K_Óg<!  Ì\9a>;\a\9d\81W;a]Ö,"i\87vL$¡nGß¡wHBÝ\86#\92ò#\82, ¡fÆ®Iúå\ 4`\ 1§÷\1fÅXá¤ß        dÌ2Ðjæl\16\1aXU\13¶qÿ²[Õ\ eeðþu\ e;\99UmPêVY´û\12\92\99m\93Ìõ|±^¥\8f×ÛÍÎg/ö\ e|õ;]\82îhV\18Í\fh@\1aård\ 6´Z¢
+§e\ 6_®úya,,ü\13\9b!, ñ\12kó<,ä|¼Ô\91\1dJS²\87~\ e¤\10\81G\84Iâ1w¯Iùã\15qfZ\1e\10ZØ5
+Ó@¤×\v$+\ 3,ÛAÝ\9e¨@Èïਮ#°¡\90Ãù\1e\93T?°¥¦\1eä\8d\9c]2ä\f\87\1dpæpØ%ç\r\87OdÈ\91¿\87\8b"Kæ\1ch\85\1a](äöö4\9fks\egàØHÊóÊsâ\94°`xÄÌ9\8evÐfxÄÿ`ÇógÃt\\93ã< '3ïa\ríè\v_ö­\19bCk[sÆ\ 6?\1a\eb\ 5\7f\ 1¸En
+endstream
+endobj
+2732 0 obj <<
+/Type /Page
+/Contents 2733 0 R
+/Resources 2731 0 R
+/MediaBox [0 0 612 792]
+/Parent 2714 0 R
+>> endobj
+2734 0 obj <<
+/D [2732 0 R /FitH 686.127]
+>> endobj
+2731 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2737 0 obj <<
+/Length 730       
+/Filter /FlateDecode
+>>
+stream
+xÚ½XMsÚ0\10½ûWèh\1fP´+i%\1dC'4\93i3í\84ä\92æ\0\85öPh¦\9daú÷k0\10\13H¼ëª9\ 1cñôöCë÷dÔweÔûb8.ÎFÁª¤\13!©ñ7\ 5\86t¤¤(\92\ 6\fj<S÷åP;]\rB\88ååíhôñüº\1aXkËq\15my>üpqS=\8c¯ÎF±\85c1ê@¡Þe\83\0ä×k
+³ÝøùçŸøU@ýÕ(P\0F\87\0\8a\80I}]\16÷\ fFÍê\87Wª~\94\82ú³YºTà\936ë]\16ê¦øÜÄÓ¦\ 1\b\9a\82\83FG\r\99ËÕ\17\ 3v9ùÙ\84ñî±\1a`,góúÃ%¿\ eË\95\8f?*\få|»än\1déd±\9ao\828MÖ×;%÷\9c¬KñU²5·\16\1d\\9d|g4ÆØ°\9d\1ac\8eó\v6hð¸Ë/ÚfÉ\ 1Ü`·h\0 \93÷{<8\89èP\83u;Äp\12p»æ\18\10:)Z\10Q\84î ÁÉ\10»9¢\17 Bw\12Mw\12i\ f×M\ f\f\9f\1e§Æ\89_cX7\8dá´"D       É\ 6\15X=\8e½\80\19U\87\8cò\13¿ü-\Fç£éÅ\98Ób©\a2tfÂ\8b\e3J19#%HÃçä\94ºA\ fú\80ѲB\9e\9c\9e"!dw\85PT!F"%\a\15
+\ 5\95a\1dy\10\84Ì\8aÙJ\8e:+h\8c2DFÔV\12õfÄ1h&!M`Ì\f'\98ÈÀ\9c\98\93s\12\9d\f\91ÁѾ,\\91¬N!ü\93ÊÞêVtVã\8eÚÝ'«¡\91Ï\a\82Û5\ 2{2]Ì\9b\9f׫eUëïéF\85Ï\7f7\7f±ñU¿pÒ7`\f\9aLÌá\e0Eí\ 1þ£oØ\93Íà\e0Yí#½\81oÈ9ÿ\98
+E>K£z1(#ö(\8b\1d6  È¤¨é\18\8el#çÕ\91\90Ù\ 6´\91óú\80\162dU\95{`ÎÙ \1e\8dÁÐm$mdÈ|\9dÀòêáͽú\13\1c§8\92nb½Ä%b5»ûÏ{9ñÂÜëo\1fX®I¦¥yÓ\88\84\ e"\8bF\95Y\bôB\va²^æm_\9f&ë%A\83       Ù]\ 4k\9c;IÍ9%\97ù'Èîñ8Mä^Ö°\19,ÄNÂæ´\10é¤\85¨#ø\vn\v
+endstream
+endobj
+2736 0 obj <<
+/Type /Page
+/Contents 2737 0 R
+/Resources 2735 0 R
+/MediaBox [0 0 612 792]
+/Parent 2739 0 R
+>> endobj
+2738 0 obj <<
+/D [2736 0 R /FitH 686.127]
+>> endobj
+2735 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2742 0 obj <<
+/Length 754       
+/Filter /FlateDecode
+>>
+stream
+xÚÍ\98OoÚ@\10Åïþ\14{4\a63û\7f\8fM\9b´Í!¢*\8a"¥9@¡=\14\1aµ\12ê×ïÚ\ 6\1a\88ag\9c\10\91\90õÏofvÍ{\80ø.@¼¯.§ÕÅu\10QF§\9c\98~\13è@:ç\85\vN¢òbº\10\ f5:7z\9cÞ\\{ýl©² }Z\ 2Ý¢7\93ÉÕí»\8f÷£±Öº¾\94£qâÔw\13Ý\ZÁö\86ǯWÓêW\85éW\10\98nn¤uQ¤\v\139\8a¯ëêá\11Ä"ýóF¤\9bE/þ´K×\ 2m\94ÐÜ{%>W\9fzêðAB\bÂY/\95q\9dÄ\ f\9b/\80z=ûÙi|û4\1a«P/\96éEiUOGA×O?Fé½åvÉ]óÖlµY¶Eô\8bµ(]4ÇbM\fgÅzs \16¤5©ë\ 6¤Jª[µs\0èÚ~P\98ö\12­Þu\1d·K\ epãÝ¢1¢\8cÖîyØÃ3J¢6;^ìÅm×\1cá\90"P9\86\97xT²e\11ó@e8@\84l\13\89î\1f\ f)cfu\11)U£ç!       }d\f\86´w4°\80\84\9a5\aØhÌ\ f\eéÃî\90ùC\18è\87\10igFy^áy¢F\16\91pj\80U5\92v\10F\9eʦ\99\8a\16zj/\1d\8dIñå\9eÚRGd\1cD&4ðǶýÉ\92Ý@rþ\80Ù!\ 3$4\19\ 649¯Vsû@x\10\ 6¦RBñ\9c£FúÌS, ¡hÂ\19Ø\8f\9d&Ñp$\92¶P`\11    @}Úº*§eôþu>»s®Êh©vÊ\92é\97Ø\19è\ 3Ëm\1a\8bmêÙ|µìþ¼Ý¬\e·=o}øòww\89\81³\89¡79h\83Ò\80+\91\1c´URC$'\a\13mWV\93\1c<%9ìÅ\16H\ eÚx©\83!%\87áNÿôÆU\87û¬\7fãª\1e\9f\9f\a\ 6\16\90 Ðp\80\98W\88¬\921¯ð\9cßU/>\97\80dO\15çÃ\ 3\802jdL\ 6\81äx\91§\12Ë>\99)
+\81éÉ\8b¤¥çÁ\ 1¡h2n\91´\84Ãsx[GJ\ 1»aà"þ®\a\8cÅ\rú\9e\Æ »\17äâ\9e´³Ð¥sÕ)ûü\1a\9f\v\14÷ÃùÞ\ 4Ï=ôY¹÷0;\94\ eç$&²\99e¿\96øo\r¾Í\18üÁßäµþ\1e
+Ç$Ú£Ã\15Î\f]\19ý¦µ@fØyÖ\92\99\ 1{3Cªà/_»n¯
+endstream
+endobj
+2741 0 obj <<
+/Type /Page
+/Contents 2742 0 R
+/Resources 2740 0 R
+/MediaBox [0 0 612 792]
+/Parent 2739 0 R
+>> endobj
+2743 0 obj <<
+/D [2741 0 R /FitH 686.127]
+>> endobj
+2740 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2746 0 obj <<
+/Length 754       
+/Filter /FlateDecode
+>>
+stream
+xÚ­XMoÚ@\10½ûWìÑ>°\99\99]ïÇ1T¡QÔF­âä\92æ\0\85öPhÔJ¨\7f¿6\86Ä\80\89gÈ^0ÈËÛ7\1f»3o@ýT >fã*»\98x£¢\8e\8e\9cª~(\ 4§\83\8bÊ\ 5§\91¼ªæê1\1f\8b\91÷!¿¾\9fL>_Þ\16#cL^\15Áä\97ãOWwÅSus1    \1d\1cCA{çë]6\bè|³&\83íÆ\87Ï«*û\93\15\14*DÐÞ£rÎkOQ}_e\8fO æõË\eU¿\8a^ýÛ,]),£\86f\97¥ºË¾¶öti ¡vÞ*WzMÖµd®×ß\0Íjú»5ãÃs1¢\90Ï\17õÃƲ1ËæÏ¿
+òùb»ä¡±tº\/6Fô\93\9d¢=$kcx\93lÍ­Ã\16\9dö¶v¾\ 5M!´lg\0pì_´¤ÑØ\9d\7fc»b\ fm´[3BÔ±,_à°\ fÏx\8d%íð\fô\ 2n\17\1d\ 1b?Ç}LôRLdXnE\96o@Yl\89äl\9b\8fa`\1c\ 6vGÀ8ì\89ò\1cO #\19\bÎq\ 5"\ eRvgP\1eö0F1_\ 6h\10\82\ e[\1f\86­ï&Â0 
+ÜÉ\89»\11\98ÌJ$+\ 2ä :\19"ãx
+\92§¹H\18w©àÀ7\88ȹK\9d\8c%'\1d\r?{6\90\8c+\89¤\90\8csX\8a,g\ 4<HÂÃÈID    C\8eÉ\82Rtª\14ïÇÅ\vâÂsb)¢Èñ¢\91!r ­ ÒÈÊFò\12\96\8c\13\ 3\92Èpr\aN·¬ä\8c\8eÞ¿«¿Þv¬d\8d¦\1d³\87/FcÛ8ïµÚ¶m­§³å¢ýy»^\15uç=Ûôß\8b¿í_,½©\14z\15\ 3\ 5¯\1d\84\14\8aÁ\0ÖÂDZ\15\ 3\19j\85\18\ 2G1¼\90\18(\1a]\ 6ÇR\fï(îÀM4n%N«h\18­\11È*\11¤=ùÀ\12]¢û  \80c¶¬\0\ e\ ey\9d\8c\91!bÒ\9e\90W8$j\98Y7¢¨\141J:
+K:'4²¢\ e\98Z°¿\8a_H*ú^q1ñ$ \8b\9cv\14ÐAN;\vè\ 2'\1e\ 6ìA'\9d\ 6¼\ e\19\92
+÷Ý\88!Í0ë t\1c®NÈ\15\93¨Ïn\1f\9dD/u[^H,\1eX³0\91Àá\1d)Á´\ 6\917þ2²f\1f\12+EVFâé\ 66\81~Øõ¯)õ\83éÕ\ fµ\ 5ÿ\ 1Ù\8e
+endstream
+endobj
+2745 0 obj <<
+/Type /Page
+/Contents 2746 0 R
+/Resources 2744 0 R
+/MediaBox [0 0 612 792]
+/Parent 2739 0 R
+>> endobj
+2747 0 obj <<
+/D [2745 0 R /FitH 686.127]
+>> endobj
+2744 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2750 0 obj <<
+/Length 800       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\98Mo\13A\f\86ïû+æ\98\1c2\1d\8f=_G
+-ÐCUDT!\95\1eZ\1a8ÐP\81Tñ÷\99dÒ*Sv2öÂióá}öµÇvì\18õM\19õv8^\ eG§Q%\9d¼õjùU\817Úû |ô\1alPË;u5\ 3\1fç×˳£Ó\80{¦Ö\19\1d²\89)F¯..NÎß¼ÿ4_ âìXÏ\17\993»¼ÀÍ­\83Ù=ðåõd9ü\1c ¿4
+òÃQ£%\95oÌ䤾¬\87«k£îò\97g*?,\ 5õ{kºÎ¦ \9dÏ/ïÕÇáÃ\88\1f!irQy\17´%_$¾{ül\0×7?\8aÆ×\ fó\85\8d³»U¾XkfËy¤ÙÃ÷yþlµ5¡Ùåæ£\9bûÇÕÖ\89\ e´OôR,¥xPl *êI£±Ê\93Ñ6Æ¢öÖ\18SÂ^9\86I{²OQ·¸;\99}ÜâÉh\ 1 \93sÏ<èòÀ\bx0¦\8f\1c\96\1d/\8dâv6/q\f\1e\88x}\7f-ñý\ 53~"µBì+ô{@\86D/\92\b\1c\91Ä\ fcAB?\15ÁIu\ 2\87êåT\ e6LÀr¸±Ïõ\7fq\81Uêv\8ad`¥\18LC3
\8b\90\19±¶f¢jF_\804\89\rÝx8Q{\0Æá¡ðð\18é r¾ï³\11ä\0¯\14$­¦Õ½j\8dAp.ÜÖEB\95\8cô\89¢P\ 2#\96\80"\95¬\8c42$£\1c%9Îê\1d\92>ÍëüV$\913ìXÉa\ 3kÜ íAÖæk
+áߦn£\1d\ 5e       µ}Ò\96W\0\reâ®\ 6p*\ 3÷Ííýª¼=\7f\ofïÛíT¾úUn!:¸?\8cî\11H ÉxÖ\1eá\926¡í\11:ÒÉ:þ\1e\81\16V{\ 4\b\11Ïb\19\88Ø*9\90\82ÆH¼="hpÝz(F\9c=\82¬\ 6ìÍýÅ\86³FÔòZkɨ<`\0[s\7f\ 38ÞHk\97Iâr»9×~»¾L_C¡¯Ô\89\95\1e\b)ö&õbÔÀÂ\81äÄÞäÛ#C\9f\f\93ÈÀ\10\rq"º_\¾\7f~~\84Ì8Ck¦\89\86~¨[\13õa4\83\e¤\\ 6\93dLFÍ\ 5YÍqDb_äþ?\r]\89À\97Ø\9c©+ \95\ 1\19åêøçÂ)$#\10ÈëTIp&Í¿U*$
+J²½\99Ô~G\99ß\9clD\10Éäü\9eX\19\91Q1"\8d\9cß|äwbàym\83L#§j¼\bÉ\0b{\8cål\11½\99{7ÅþÏ-Â\8dn\11Ù\83?Ì©uÿ
+endstream
+endobj
+2749 0 obj <<
+/Type /Page
+/Contents 2750 0 R
+/Resources 2748 0 R
+/MediaBox [0 0 612 792]
+/Parent 2739 0 R
+>> endobj
+2751 0 obj <<
+/D [2749 0 R /FitH 686.127]
+>> endobj
+2748 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2754 0 obj <<
+/Length 743       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98MsÚ0\10\86ïþ\15\a\14­$¯¤cè\84f2m¦\9dÐ\Ò\1c Ð\1e
+Í´3Lÿ~ml\13pm¼k\94\130\16\8fßý°õ®\94ø!\94x\9fLçÉÕÌ\19\11d@\8dbþ]\80Bé1\bô(A;1_\89§t*­Ì&ÎùôöËlöñú>\9b\18cÒyæMz=ýpó\90=Ïï®fþ\88\97\ e]q\97=\ 10\94k\12U߸ýy3O~'P|U\ 2\ 4\80\92Î\81@tÒé ¾m\93§g%VÅÅ;Q\
+NüÝ/Ý
\83Tå]6â!ù\Ås,\ 34HtV`X\89¹Ý}U`¶\8b_U\18ï^²\89öéj]|Ø\90\97aÙôåg¦]º®\97<\96\91.6»õ>\88n±yq§`ÛbmðgÅ\16Ú\8eÔ\ 2Jg\8bä[%µ÷\95Ú¥Rêÿü\82q\12rÝäWûjÉ    nÒ,\9a\0È\90ç\a\1e\fò@1xÐ¥Ïj     Æ6¼Ð\89«×´q@\89\18\fG!P\826\8a\87\84Á°ípØø
+\ 4B\9ds\96D\18\ eZ\a:\11Ôp¥\15½Ò@é\1c\b)\ 4Í    \98\92B\80abSf äÐ0b.\93¨H\ f\f£u\1a*E,òÅö\14¾¥×\8fÑKz\88Ô82¡\13\ 2«\13*2%\178BqO«µr¡Ç\91     /\16\18E&$Ù±Á\ 4¨åV\8e°\9fp3@H*³\11\86·(Íy|I;³fÕ§ÌäðKÆ1U\ 2\81\99Ó7ç\9a9\9cMÏÓI(¸e%\93\0\1e\91Á¹\8b\fwmaµ5R7Ê\1e?\19      \95\93>ñÞ¶òÚ\8båf]ý¼ßm³Â\8a\86|ý§ú\8bų£Cç\b¡½\93¨|\8c\11B\a/s\807\1c!\ eb#\8c\10:\18\99{$\8d\10£MG\9f1¸À«ªz\a\88ò¢nS!¦\89©¡\10Ùr\1d°$0Òw«#pd×uL\8e»m¿\92I\8d¦Æ\91ãø¹\ e2Äõ]Çä8¾«Ý\eQ7¶º#âNð´\1eÓ¼zE\19àÏ\1f\83\r¬\ 21\86mdÌî\817»S\1eMd\rÛ\14WͲ\97´Fd\9e\b¨¸'\ 2}/\f¶[=9µ ÔÛ±\99\91\87\9e=4îÁ\1c)p`\9eYD±éø\96s\19Ñ÷Ç\1c$|¿\93\8d0H4F6æ á:\a\89"\82\7fó\10
+endstream
+endobj
+2753 0 obj <<
+/Type /Page
+/Contents 2754 0 R
+/Resources 2752 0 R
+/MediaBox [0 0 612 792]
+/Parent 2739 0 R
+>> endobj
+2755 0 obj <<
+/D [2753 0 R /FitH 686.127]
+>> endobj
+2752 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2758 0 obj <<
+/Length 743       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\98OsÚ0\10Åïþ\14\a\14­´úwlÚ¤m\ e\19:õd2\93æ\0\85öPh¦\9daúõ+l\93b0x\97êD\ 2òÏo¥µô\9e\95ø.\94x_\×ÅÕm\10QF§\9d¨¿ pJ:ç\85\vN\82ö¢^\88§\12¼ª\9e뻫[oö\86j«¤OCT;èÍtzsÿîãc51Æ\94ײ\9a$Nù05ÛK\vÕÝððó¦.~\15\90þT\ 2ÒÍQZ\17Eº0\91£øº.\9e\9e\95\1fïDºYôâO3t-ÀF©¶÷^\89Ïŧ\81\95\98ä:ë¥F×Jü°ù¢À¬g?[\8do_ª\89\ eåb\99>0Ú²®\ 2\96/?ªô]ú
+ÊnØC\15L9[UPn\96M-Ã\9a-H\17ñP3ÆpV³Ç\9eh%-¦ÉG%u\b­è¹RÝì÷êC-Áànòc·>û´ÉnÌ\ 4@Fk_q0L4^\825;¢\1eFv\83\ 6\900*\12x"\81¢RñT\ 2Af`Ê\84q\95n\¥û\87\1c\97¨\18\12\81Ð>\9eÅ\83ñu\ 1ÇX\17Ú\1c"\87\1d\ 3<â¸F\b\8cu\ 6\86ÑÞ´§Ú°\80\84\92\91\ 3¤,\vx\1e\91Ò\8d\91\89$´£¥/5  \b\8cn$µ7h\16pÛ>ã\e\85¦o\14\1d\93²ýà\ 5T
\8esÝ1\97ÐP\9a?·'ûª/Ù]2\15\84v\ 5¾àq±\86+\96 Ô3\85\12\90\8c]\19hϪå\88¤lP\86\ 5$(T§\9dªvFFïÿÏ]·FU£\91z§,Y}        ­eî\19ml\8dõl¾Z¶ÿÞoÖ[\8f=oÜ÷òw{       \86³9a0/\18\ 4\89ÊåÈ\v\ 6ccß©yÁ[¿-ËìòB?+\f\ 5\85\19\82\82A/M@RPh\1a\ec¸Óô±»Í\1a<\80¢\ f\19ú\80\86\fL$\8c"ÏíR\9aco5e\93ÒÇÖ\91tX\eÎÚtg5\85ë.âB\8eãú\98\9bù´Þ\ 3ç=U_Á\90%Ôº\ 3,ä4Y\1d\14²\1aë\ 6
+Y-f\8bÌ\9bèiAϲêÎ\13ôÜ^ÐË\9bn©Ï\91c"!ë[& \89D\1e1ÓË\f·\8f\84ì!7ç\e!Z`0¹ã(\ f\b\99ó-e\99\81\93\13\80\12@\81\13\90HUk^ô l\8eþ´UÍ\90\14vN5gR\88\83I!Uð\17\ 6JjÐ
+endstream
+endobj
+2757 0 obj <<
+/Type /Page
+/Contents 2758 0 R
+/Resources 2756 0 R
+/MediaBox [0 0 612 792]
+/Parent 2739 0 R
+>> endobj
+2759 0 obj <<
+/D [2757 0 R /FitH 686.127]
+>> endobj
+2756 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2762 0 obj <<
+/Length 737       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\99KsÚ0\14\85÷þ\15\v\14]½®´\f\99ÐL¦Í´\137\9b4\v\b´\8bB3í\fÓ¿_?\80\1a0ñ½ 6<,>\9f«kYç\80\12?\84\12\1f²q\99]MÐ\88(£×^\94ß\ 5(/\83\8fÂ\a/A£(çâ9\1fK+\8b\11bÈï¾N&\9f®\1f\8a\911&/\8b`òëñÇÛÇ⥼¿\9a\84\ eÇè Ñcu\96\86\0\bõ\98LmN|ø|[f¿3¨^*\ 1\ 2@ID\10Þ£D\1dÅë*{~Qb^\1d¼\17Õ¡\88âo3t%ÀE©ê³,Åcö¥­§+\ 3 :îªr\1cJm}+ænýM\81YM\7fµeܼ\15#\1dòù¢zB\87mYo?\8bê³ÅfÈSýÑt¹^4Eô\8bu }´\87bm\fï\8aE»§ÖK´\95Z«¤\ e¡U;SJ\1dÏ/\18\94àôn~7Cöp£í \11\80\8cÎíxÐóZ\82±[^ìÅmÆ\1cà@õ+Ü'\1a&\11\bLËfR¨î\f*\10z¤        =òÇàáfùs\ 4\ 3A°f\TÿÁ0\f\ 6>x\98
+\91K\1d\9eÚÀ\9bZ\82HǺ\b(]r¬²)\8d\ad"        u{\ e\92²L\81Ó\1a ´F\a\96Äa a,øæ&Jh6£3\r\92ÒíÀe\ e¯\eMoN³\12\87ç\12X"  \17¤á4\a\89\1c\8d$\95Úó\90\ 4¢e\11     @Ã\0\ 2Å* ãâ¡õÚ2zM\99\9c\9a)k\10XÀá\ 5¨N;Uí\8d\8c\88\97ÙêÖ¨jk¤Þ
+{úl$´~yÏaÛÚQÛ|:[.Ú·\ fëUm®g\8dí^üi¿âÔ»\ 1¡7(è\80Ò«\90"(è\18¤\ 3 \a\ 5\e][V\1d\14\90\12\14vb\13\ 4\ 5\1d\8d\1f\a\ 5\92\15ç\98\9aæ\ 1i\1d\ 3\11éxÈ´{È©­óì;Õ©}\93oæ<#Ç)\96\7fM\e\v!ij%íÀ`x.A%Ù:ºÄ46sßx¤MÂ\e&m>¹\8e¦á¦
+Ã}ä¤i¸\ 3N\1c\87»ä4yØ\1f\92\ f\19[*$N\v4s\ f>\81q¾ \80\0åÞGø\ 1«Û#JÛ1±\15çÙR\95Ú\96Rf\11\9e´,#O#¤I]¾cïUÚÔE\8a F]\9c\18úr\¿gM\10\19\965edèÿO¡ªà\1f\8a\89
+endstream
+endobj
+2761 0 obj <<
+/Type /Page
+/Contents 2762 0 R
+/Resources 2760 0 R
+/MediaBox [0 0 612 792]
+/Parent 2764 0 R
+>> endobj
+2763 0 obj <<
+/D [2761 0 R /FitH 686.127]
+>> endobj
+2760 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2767 0 obj <<
+/Length 751       
+/Filter /FlateDecode
+>>
+stream
+xÚÅYM\8fÓ0\10½çWø\98\1cêõxü\11\1f\ 5ö°*"Z­´ì¡¥\85\ 3-+\90*þ>nÒ\94¦rÛ\99`Ä)mê<?Ï8ã÷¦J|\15J¼-®\9bâê¶\16A\ 6§\9d\bpJ:ç\85«\9d\ 4íE³\10O%x]=7wW·\1e\ f\86j«¤\8fCT7èÕtzsÿæýc5AÄòZV\93\88S>Lqûh¡v\13\1e_o\9aâG\ 1ñ£\12\10'7Òº â\83\119\88ÏëâéY\89EüñNÄÉ\82\17¿Ú¡k\ 16Hµ\9d{%>\16\1f\12ëðV\9aH×Y/µq\1dÅw\9bO
+p=ûÞq|ýRMt].\96ñb\82-\9bª6åË·*Þ\8b· Ü\r{¨j,g«
+ÊͲ]K\9a³\ 5é\829ælB}\96³7\ 3ÒJZ\13\83o\94ÔuÝ\91\9e+¥ºè\ fÖ\87^\82Å>ø\1aw  :\84\9bô\83&\02X»Ç\ 3
+¢ã!\ 2\85&x6(\85+Ô#`!\85\ 44=n:\ 4»1§`IÁU\97       »\ 42\\ eE\18\13
+\0\ 2g=\ eù2g\r|d¸\98<ËM\1eaCÔlLBÆ\1cs/\10x\1a&O
+MËJ\12\81$²HRö\11\87"\81``\10¤D\90ñÒ§\8bÈ\90\9e¢Ó\ 3ZÉg\94Ñvs_DDÅB$Ä\90Q*H\95\184#)§Â8Ì\8b\85\16FíY«&UóÀ\84$äÆp IÉA\1e"!\92\86\93n\12IdmÉ\13,\87;Hsv\10\10ÎB8­[µC\19¼ÿ;­ÝÉVmPê\9eY\14þ\12:\ 1=\90ݦ\93Ù³ùjÙ}½ß¬·\8a{ÞjñåÏî\11«Ïº\86¤{@\ 3Ò(\97Ã= 52hKv\ f\1aõvYØ»\87¡sHÙ\86\f\ 1\8d\97X\eºmÐ\14Û S¶!kõk\11\98¹¸ês§\92&J\99£8Z\1eb\96\12àÎJ\19¾ö8¯eFK£\7f ehõ\8e\8cGÒF\81§d(â\b8z\90t\ 2ã\7fPG\87*!³~#õ\14xâèDÅ\19ßû \9dèH\7f\9d\81æÆyb«\reV\7fÛ\83\9e\ 2\1eß<8DÎÛ<8@\86<]%\97@\86\9f\14iÈÛ\0ú\ 3\rY[w{\J\94Ý\18\ÈÙ»ÛÁRÈZö\96ÈÛ©\ 2 ù\1cà\96\a v\aÒ*6\83\89èElN\13\91þë!®à7ù÷r\9b
+endstream
+endobj
+2766 0 obj <<
+/Type /Page
+/Contents 2767 0 R
+/Resources 2765 0 R
+/MediaBox [0 0 612 792]
+/Parent 2764 0 R
+>> endobj
+2768 0 obj <<
+/D [2766 0 R /FitH 686.127]
+>> endobj
+2765 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2771 0 obj <<
+/Length 744       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98MsÓ0\10\86ïþ\15\87¨ÚÕÇJÇ\86ièt \ 3ÓÐKé¡!\81\ 3   \1d\98Éð÷±ã$äíw\8d8%\9d¨\8f_­díûʨoʨ·ÅxZ\LȪ¤SÀ ¦_\15\98 cH*Ä \ 1IMçê¡\1ck§«\11Q,¯?M&ï/o«\91µ¶\9c\96\97ãwWwÕãôæb\12\ f8\16£¦@õS6\ 4 Û\8c)ÌöÁ§\9fWÓâg\ 1õW£@\ 1\18M\ 4*\ 4Ò\84I}Y\15\ f\8fFÍë\1foTýS"õ{3t¥À'm\9a§,Õ]ñ±\9dÏ¡\f\81\9c
+\9e4ºÐ\8a¹^\7f6`WO?Úi¼y®F\18Ëù¢þpÉ7Óråó÷
+©\l\87Ü73}Z®\17\9bIt\8bõõ\93\92;\15ëR|Ul­í@-\ 4M®.¾3\1aclÕÎ\8c1çõ\ 5K\1a<îê\8b\1dr\84\eí\ 6\8d\0tò~Ï\ 3\ eÒ\82\10 ]L\87\1a¬Û1©\13¹\1dÓ\85\84~\9dà¤:¡\99?§¨f\18\19ú5§~r8'3ª\818H3ôkF\18B\ 6F\9d!\f#Cï~\8bâýÆÝtq\90dF\99\81\ 6l\r\ 6ÖË\ 5÷×7ÈêÛ\ ft"`?Ï
+x\8cóËHp\9c­\8f^°ÚÍBs\98I°Ô\ef\7f\1d½lâ\8c}n\8dHe¿DàKd\1dJ\86¿2\9c
+&\81¼\17úó1\10e@Nï\10\1cjíqÖ_E+B2\80 \ 1rNr\14¬3ð^j\12iäL\e\83\fÉ º\97½,\ 6«\13Ñ?\19ï­\95Eg5î¤Ý\7f°\1aZG}äÁ]ë¹\9ffËEûçízUÕ\96|¶1æ\8b_í¿x÷j\84è\8c\12\18I\a\13sD     k ND\81\1d%Ðb\9b\90\9a(\119Qb/6C\94Àdµ\8f\81\15%\86÷8NÏ\14¶tÃܹl+\ 3\99»\e£\84 âAn\9bÀ´\1e\12×½aBÞÌ\b,?,9LY1FÒ\91\ 4\9f×'\84\83\1e\9c¥¿ý×\ e\9cÙÉ\80a¹#\1239Å\94\98Ö=\96\822\e²'çÍí\adÆÉ\1e\aÔ\18xñ:\fÓ\fy\83ð_t¦{¨ó\15ä½Ãq\90fÖÛLÃÐ\90÷úì\b\9dçþì\14\rY\8330\83s\90\1cç¼\8d\86ÒÝ\90=§q/^ºím\86t±s·9Ó\85ïL\17õ\fþ\0.\ 3{S
+endstream
+endobj
+2770 0 obj <<
+/Type /Page
+/Contents 2771 0 R
+/Resources 2769 0 R
+/MediaBox [0 0 612 792]
+/Parent 2764 0 R
+>> endobj
+2772 0 obj <<
+/D [2770 0 R /FitH 686.127]
+>> endobj
+2769 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2775 0 obj <<
+/Length 747       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\98OsÚ0\10Åïþ\14\a\14­V\7f¬cÓ&msȤSO&3i\ ePh\ f\85\19¦_¿\ 2áÄ&\ 6ï\82r!!âç§ÕJz\ f%~
+%>\16\97Mqq]\8b \83ÓN4?\ 48%\9dóÂÕN\82ö¢\99\8bÇ\12¼©\9e\9a\9b\8bk\8f\9d¡Ú*éã\10\95\ 6½»»»ºýðù¡\9a by)«Iä\94÷w¸ùh¡v\ fÜ\7f½j\8a?\ 5Ä_\95\80øp#­\v"~0\92\83ø¾*\1e\9f\94\98Ç\7fÞ\88ø°àÅ¿íÐ\95\0\e¤Ú<{)¾\16_\ 6æá­4Q®³^jã\92ÄOëo
+p5ý\9d\7f®&º.ç\8bøb\82-\9bª6åó¯*¾\17ß\82r7쾪±\9c.+(×\8bí\\865[\90.\98}Í&ÔG5{Ó\13­¤5±øFI]×IôLm~Rý{3D/Áb[~ívKÔ\ 5NÚA\13\0\19¬í\10a\9c\18XD\ 2Ðp\80C<£% iyÃúvcöp0^Áv\bI\1e\10\80H\0ºWàx\ 1\ 1é
+áPÛôkXÓk¸%&,¡\1d5Sj\ 2\13\9a\bN\ 1Ãx%ì)\95 ´\81f´A\97\ 1Ü       \92Ç©\86O%´n`/Û¸Rä*%èô<\9d\84\86µ¬å\a¦\ 5Ö¼\81²<\965mJ!\r\87\9f\8a3iÒñ\f\9c\85\ 1ÒVgu\ f\90\98à¸L
+´fCÇ·£f¬\10P.'Ï\ 3\12öbÍXrÒ¾á\s¤\85\ 1\16\900e<ìYµC\19¼?Ïg'˪\rJÝ*\8b¦_B2Ï=Ëm\92Å\9eÎ\96\8bôçízµqÛ³­\ f_üM\1f±îhb\18L\ eh@\1aår$\a´F\ 6mÉÉA£ÞL\vÛäÐO\rC\91áEl\86È\80ÆK¬ÍÛÈ\90Õ=\1fÞ        \9aâ\9e\8d\9f\1f;í5%|¼ÕG":\1e\11rÜë]£\98å¸ë\19\85¬'2É&h{¶M8ã\0%\19\19Ö\11OKG`Y÷\10ɶ#óöÍláH÷/*\16\91²ÜÈ#BÞH\9c|a\1e\13çúPJ\100l©[nÞ0Ü\ 1gJÃ\83è¼qø\95\f\99¾ÍpCèÌßgtÐ\99\v\19òf\87\1d7sð\ 6\95?\90Pz\179m@"\ 6\9eÝÏ\9dA\81\94!RR\1e\192Dëasf\b?\98\fþ\ 3N q£
+endstream
+endobj
+2774 0 obj <<
+/Type /Page
+/Contents 2775 0 R
+/Resources 2773 0 R
+/MediaBox [0 0 612 792]
+/Parent 2764 0 R
+>> endobj
+2776 0 obj <<
+/D [2774 0 R /FitH 686.127]
+>> endobj
+2773 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2779 0 obj <<
+/Length 801       
+/Filter /FlateDecode
+>>
+stream
+xÚ­\97ÁN\eA\f\86ïû\14\1c\9e\19ÏÌ\11*R\84\8a\94\vå\0%í¡¤¨\95P_¿»YHÙd7co+EJH\86/¿ý{\1cÛ\9a\9a·Õɲ:ZDg2d&6˯\ 6-Câl81 E³¼7×õ  x\98ÍcLõÙ§ÅâýñÅlî\9c«\97³äêã\93\97³\9båùÑ"½â8J\1096ß²!`\fí\99Ê>\7fñîóé²úYaóÒ\1al4d\b\r\869B¤l¾¬«ë\e\9b\ fÏ\8d\85\98£ù½9º6È\b\81\9b\97\ fæ²úØÅóZ\ 6R\0nH!\ 2yî´\9c=}¶èÖ·?º(Þ<Îæ\94êûUóDdÛ¨|ýø}Ö¼·Ú\1cñõUûÖíÃÓj\13ðÖ\80ÀÙïjõ9\1dÔ\1aýk±\18 XoØ[ \94:µwÖÚýô¢÷Àä_Ò\9b»\13=ÚüåÌ\1c\11r\b[\1c\ eà\\ 6ö´uË\ eò\9e\ fíðpX`\9fHQG,kt:\8d(ÐÈ:¢ \8f®Lä-\11\8b6[¹Í2W²<âÖ\14A%:\95D´å IG,»BA\13µ p\90ä6Ëê\ 6\15
+QbtR\ 1\ 59t\1a ¤pPa3\8alq¨Ó(Ê$\ 6\85×\1d\14ËÁ{eð\9bGY+«\13\80"n\9cÂ\95u$\9a\88\16\94\9dC\94t¨0Á=Ù¥à\89dɯ\9d\9d\94iYÿÊÓØ\ 2\92\ 5L¯*\f\89oQå\9b¤Æ\92\8e\ e~|\98%v\90cü§Á\e\19¢Ï\86¼\ 3z\91võÁ\ 1vSwo\b÷ÝÐ}{÷°êþ¼xZ·ó÷Ýf2_ýêþ%¤\83+Äà*A)\ 2Û$Z%B\ 6\eÇ#¢\9c  \8aw  \9fÃß]">ï\12®Ý%ÜÈ.±\15+Ø%\ 6Äöj\83²\83\90x\7f\97\18ì\f\110\14Ç\99îÐî61Üyû@Ô\0\17\ 1ºÒLØ\9dÙ\a\96%\8eÍþ#\12±¨\10\15
\1cp.ã\ e/\12;\8eXy¸8R4}\81N\1eo\vÄr\19:¥F\140ÇZý8\13%\17&è©(»\8a©Læ\ 1r¹>YéW\a\16¤\98ì¤dH\8a6O!\97S\11\ 2\11M\10\8c\92\8eJ8¡.$}pl´?,YÀe5·l\9cW\19'©]ÝE\16u\1c§rJ\12\84]ÆY\ 5\r))\92(úmv\1a Äæ¬\ 2\8aîºÓÜÈÑ\8dµïLÔ8#KeÔE. úñ9V²F\14\87în\8cý\9fkD\1e\#\9a\bþ\0\r1x\9a
+endstream
+endobj
+2778 0 obj <<
+/Type /Page
+/Contents 2779 0 R
+/Resources 2777 0 R
+/MediaBox [0 0 612 792]
+/Parent 2764 0 R
+>> endobj
+2780 0 obj <<
+/D [2778 0 R /FitH 686.127]
+>> endobj
+2777 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2783 0 obj <<
+/Length 758       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98OoÓ@\10Åïþ\14{t\ eÙî\9bý\7f¤Ð\ 2=TED\15Ré¡¥\81\ 3\r\15H\15_\9f\8d\9dÐ&qí\19czI\93¬\7f~3;ë¼\19£¾)£ÞVÇ\8bêè4©¬s  \16_\15\82Ñ!D\15RР¨\16wêªF\f³ëÅÙÑi´Ï\96\927:\96%¦]ôêââäüÍûO³¹µ¶>Ö³yáÔ\97\17v}ie67Ü\7f=YT?+\94\7f\8dB¹¹Ó>dU.,䬾¬ª«k£îÊ\97gªÜ,Gõ»YºRðY\9bõ½ïÕÇêCG\1c1i\93\92
+>jr¡\95øîñ³\81]Ýüh5¾~\98Í)ÕwËòB\96êÅ,Ùúáû¬|¶Ü,¹\\7ftsÿ¸l\82è\16ë¡Cvûb]N½b£ÛQk´w%ëÎh*ª\eµ·¦üµyß\89Ì\91\86uÛ´ÛÍÎ<ÇÍ·kæ\80ÎÞ?ñÐ\ 5´QÃÛ-\90|'q³è\90\88a\8d\11\f\95Ö\bU\ 2\832£D&\86\13\99\87%\86-\8f\112$!3ÂÍüpÑ]\89{ñZ¾>°\12\98$Àá\80\8d `0\8e\1e\86\89Ç!&\91Bpr\18\ 59\ 4§lH¢\11\9cºq\12\89\9c A""çì\81\7f\96Ñ 9'\ 6²È\e*ãqëE;ÔR99ð#Ô\82÷è0#Ñ\8cZÈò\9d\8c¡\9aÆ©\ 6ãØb\14\9a\10\87\1f\raLáñÎ_\1a'\9a\91jDq\81\fC­xÿ\18\90É(³ð²¯¥`u\8eñßLxkkÉYM[m¥#ÐhÝõ\8e\1fwkÿíê\9bÛûeûöüqµ¶â·\8dI_þj/   ¦·\9dèl+¬\83v&LÑVXït&ÿ\1fÛ\8a¿b'h+¬\8bÚ&Çk+\9aÊ \8e\99£\ e\7f=¥mè9`Ä1×\aú\9a_ãá\98a¥L\f\9e\ 4/@\87£ïë~è°µ`%4Êt2\88NDd\0\93\ 4\bÎ\8e\93\8c\11¢íÆ\8b\95)vta\ fÊ(M8¹Ö^?G\9c\9fë>2#¿q\14\99\91\r2ãÈ\fÍy\f\99S¿D\92çÀ\13\99qÖ0J3£;\11\98Äç`LëlwÐ\98´÷Ù '\997ín\1e¦\1c \18\9eë$aä\13\8f\ 3%>\96=z\9atRÄéÈ­`RÄ\99Á@4'\9a\bîd±ÛÖNÐUl]í\94]\ 5\8a\12Á\1fÊhz\97
+endstream
+endobj
+2782 0 obj <<
+/Type /Page
+/Contents 2783 0 R
+/Resources 2781 0 R
+/MediaBox [0 0 612 792]
+/Parent 2764 0 R
+>> endobj
+2784 0 obj <<
+/D [2782 0 R /FitH 686.127]
+>> endobj
+2781 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2787 0 obj <<
+/Length 742       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98ÁrÓ0\10\86ï~
+\1dãCT­$k¥cÃ4t:Ð\81©é¥ô\90\90À\81\84\ eÌtx}ìȦNãÖ»B\9c\92ØÊç_»+é_+ñM(ñ¶XÔÅÙ\12\8d\b28íDýU\80rÒ» \9cw\124\8az#îf\vie9Gô³ËOËåûóërn\8c\99Õ¥7³óÅ»\8b\9bò¾¾:[ú\ 1Çh/Ñaó\94\ 3\ 1\10Û1\85ê\1eüüó¢.~\16Ð|U\ 2\ 4\80\92\88 \9cC\89:\88/ûâî^\89MsóJ4·\ 2\8aß\87¡{\ 1U\90ª}ÊNÜ\14\1fã|\862@[©}3\9d
+¥¶.\8a¹|ü¬ÀìW?â4Þ<\94síg\9bmó¡\8d\8eÓzø^6׶Ý\90ÛöÒj÷¸=Lb\l\ 5Ò\ 5û\¬\rþU±h\87jÁI´\8d\1aÕ>ª]+u\1a^°Z\82±}xC\1cq\ 4\9b÷cæ\02TUO\83i\9cáà`T\9f\95î\81z\9cØ\r:%\ 2\ 1\89L$L#\1d\v      \93qÔÓqìJr\r\84,+zZÚ\10N\ 3-\ f\8a¥\87ð\80\9cÎ
+h\16\92R\8eýSÉHÊÌ«i¦;bR2T±2ÔiU\94\10Xn\b"yºè]\92dB\84Á%I¦\94X\95B\9eæ\1aà×D[\16\84jÓ      \8aA\114kH"\93\96\9dOD\132\88ihÊÂVII\ 4\85\14Õ\84ºSl.Á\15xö¦\84\17\f_+áèE\9eXºð\8c2 y"Nò\81°ñ\ 2\94âT/\9b\8c\f\88ÿäÌ;¯«­\91º\17vûÁH\88\96ûȤÛÖ\94ÛÙj½ÛÆ\9f×\8fûÖ\9f¯\ fÎ}û+þÅéW{\8cÑ^C{\94\1c½\86QдLî?ö\1a\7fÅfè5t0²ò\8eÒk\8cÕ\ 5Õ%çl] ¯E¦ø/Ãâ\91\8en\96\9f\8d\ e&\8b¡uC&ÍdX¦R\9aÁ0l*dí\ 6#4·ûî \99:\85\13ì\v   c[o7\ 2Î|ö\ fÉy\ fê'2äöÈCtf\93<@\13ªÃ¤¢óØÂÓú mj>E5moÃ4t&k?\8aÎlí\9fÐ\90©uwchÈkÆ\aèÜÝû\10\9d¹}\8fè¼/\ 3\89¯\17Y%A9\9f\17\89+Âó4\126xËjK\88mθ/ÎÐ\96ô¶8g[bFÛ\92f\ 6\7f\0cQ\8c\92
+endstream
+endobj
+2786 0 obj <<
+/Type /Page
+/Contents 2787 0 R
+/Resources 2785 0 R
+/MediaBox [0 0 612 792]
+/Parent 2789 0 R
+>> endobj
+2788 0 obj <<
+/D [2786 0 R /FitH 686.127]
+>> endobj
+2785 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2792 0 obj <<
+/Length 741       
+/Filter /FlateDecode
+>>
+stream
+xÚÅ\98OsÓ0\10Åïþ\14\87¨ZiõïH¡\ 5\84ÁÓa¦ô\90\90À\81\84\ eÌdøú(q\12âÄ\8ewS\r\9cÒ¦òÏO»ªô\9e\94ø&\94x[\×ÅÕm\10QF§\9d¨¿
+pJ:ç\85\vN\82ö¢\9e\89Ç\12\9e껫[o\ e\86j«¤OCT3èÕx|sÿæý§jd\8c)¯e5J\9còalÖ\8f\16jûÂãÏ\9bºøY@úQ    H/Gi]\14éÁD\8eâ˲x|Rb\96þx'ÒË¢\17¿7C\97\ 2l\94jýî\85øX|è\98\87·\12\93\g½Ôè\1a\89ïV\9f\15\98åäG£ñõs5Ò¡\9cÍÓ\aF[ÖUÀòù{\95¾K_A¹\1döP\ 5SN\16\15\94«ùf.Ý\9a-H\17ñX3ÆpV³Ç\96h%-¦â£\92:\84FôT)ÕT¿5?Ô\12\fî\8a¿\1dÑ¢\8dvcF\02Z»ÇA\17Ïx        Öìx:t\ 2·\83N\800\b\ 4Ã\0Âð\84#cÂ\14y\8a.\ f\14¥#0,Ð\1d\0      \12\91%\91ÒdË#\ ek4À!\ 2¡\8c\9eÞç5°\eyTHÇ\13I\13\8a\9c~ï±Ã\Ç-À\86Ké¾â\97\81
+ ^B¦´NëËÈÃ\9a5\D\86ÁþÙ\vÖ\ 5¡Ä\81-\97\0õL(¡¬<$A#g\ 5\90v\ 3BãÝ_ aÊ\86£\90v\98\ 4Æ&\0}ÇI\ei\98\99¬¹HB»-¯\98\84#Jqú\r\94\8d\14Y\1aIHÇD\12\96eì÷®Ú\19\19½\7f\99ßn¬«F#õN[2ÿ\12\1a\13ݲÞØXíÉt1o~½_-×®{ºñãó_Í#\ eÏ&\87Î\ 4a\10$*\97#A\18«¥Qñ²\ 4áËy;=tE\87½Ø\fÑÁ \97&àitèß\ 25eµé\13³\7fÆ«j\8a\ fì BV\1f¸\ 6frlm$\10Ë©y\93ß\82\87«ª        Uu'` H>g'ú%\ 3á\98q\97\14\192Û×Cr^ûº'g1\82ÇTB\19(\9eíxMPjàØ5È{\98S{\85¬{\8a¬÷\0ÿä\9a\82}Ísx©\90õ\9aç¿Ý)0sjf;MûçÖÌ\94\97õ¾\8c\96ÄLîàÄKbÙ\8d´"\9b^z|È\9c\16IudEä¾\8có\92lGØw ß¼fÈ\ e\9a3;ØÎì\90\a"_q\9d
+endstream
+endobj
+2791 0 obj <<
+/Type /Page
+/Contents 2792 0 R
+/Resources 2790 0 R
+/MediaBox [0 0 612 792]
+/Parent 2789 0 R
+>> endobj
+2793 0 obj <<
+/D [2791 0 R /FitH 686.127]
+>> endobj
+2790 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2796 0 obj <<
+/Length 732       
+/Filter /FlateDecode
+>>
+stream
+xÚ½\98OsÚ0\10Åïþ\14\a\14íJ^IǤ\13\9aÉ´\99vâæ\92æ\0\85öPh¦\9daúõk°\ 1\ 3NX¹Ûr\ 1\ 6ñó[ý}OF}SF½Í®ªìbì­\8a:\12\92ª¾*0¤\ 3EE\814 WÕL=æWÚébä}Èo>\8dÇï/ï\8a\91µ6¯\8a`óË«w×÷ÅSu{1\ e\1d\8eÅ =ùú)\e\ 2ø¸n\93\99öÁÇï×Uö3\83ú£Q \0\8cö\1e\14\91×\1e£ú²Ì\1e\9f\8c\9aÕ?Þªú§èÕïMÓ¥\822j³~ÊBÝg\1f\9bzº2\0A\93w\8aJ¯ÑQ#æfõÙ\80]N~4e¼y.F\18òÙ¼~s±\\97åòçï\ 5ú|Þ6yXW:Y¬æ\9b"úÅ\96õ\93¢;\16ëbxUl­­£\16H{Ww¾3\1aChÔN\8d1§ý\v\ e5X·íßØ´8 \8d¶mF\0:\96å\ e\a=8ë5\94¸\e.ÓËk\e\1dñ\80¡\ f\12ô\ 1C Æ\14\81ý
+\8fJ¶iD\86Æò<\91öD\ 60ð%r\ 6Åð\a\ 5X£lÓ\80p\9e\18\12\89\f¤KEr*/ÏCé\bZc\19Ó\12\98ïÉ\8c5\1e\a\91\81¡\19\87\91\19+\0\86\90\9f\86\91áìÔ !S\ 3\18Ý\fa\90dF7\83\1f@f`Ëd,\ 3ê\92 \8c9fùÛ6ð\16±M\99¶¼Õ\8b>\rÉ º$"cdR¶\ 1Ö\84OêFÖ¾í\13\16'°ª¶&M$g?¥DäùM        _6²HVGïÿÊu·>\16\9dÕ¸\95öðÁjhìô\81\ 1w\8dá\9eL\17óæëÝjYÔ~|ºqåó_Í_\88\ f½9\ 2\83×d\82D\8eÀ\18t        ð\ fsÄN¬@\8eÀhu\19è4G\88Z¸õ>eÚ\97èaÕ\ 1Ë\9eU{0È:¯\ eXÖxíÀ\1c\ fÃñ]t
+\96µ]{0Ã\8bÓ\80ÙÆ;*h\90ba\13³%˺\98\96
+\92¡¤a\82¨\93i&\97È\19|\88\94=\84y\8b\16\93\86\9d3C1     \b"îh\7fÝ {¥\ 4²WJ`d¯\94xþ7-NIÜ®tc\84H.éúsÃ3\81Ì\1e\94¿[\81\97vòá7@ÜÈh\85\83   ç6ò F\b\87±ÿ\97"úBh¿\8f\15\88\11[\e+\19#|o\8c¨+ø\ 350vr
+endstream
+endobj
+2795 0 obj <<
+/Type /Page
+/Contents 2796 0 R
+/Resources 2794 0 R
+/MediaBox [0 0 612 792]
+/Parent 2789 0 R
+>> endobj
+2797 0 obj <<
+/D [2795 0 R /FitH 686.127]
+>> endobj
+2794 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2800 0 obj <<
+/Length 733       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98Mo\131\10\86ïû+|Ü=Ä\9dñ·\8f\14\87*\88¨B*=$$p ¡\ 2)âïãÍnJ>¶Ý\19cNi\13ﳯÇ\1eϼ\ 6ñM\80x[]Ϊ\8bë ¢\8cN91û*Ð\81\v\17\9cDåÅl)îk\fÐ<Ìn.®½>\18ª,H\9f\86@7èÕtzuûæý§f¢µ®/e3I\9cúnªÛG+è_xúy5«~V\98þ\ 4\81éåFZ\17Ez0\91£ø²©î\1f@,Ó\8f7"½,zñ{7t#ÐF      í»×âcõa`\1e>H\bA8ë¥2®\93ønû\19Poæ?:\8d¯\1f\9b\89
+õr\95>\94Võ¬       º~üÞ¤ïVý\90»ö«ùz»ÚMbX¬Eé¢9\15kbxQ¬7GjAZ\93¢n@ª¤z§v\ 1Ð\87ýhbÚK´z\1fu\15û\959ÄMö\83&\882ZûÄC
+Ñò\88ÃL£$j³g\86Ad?f\b\89ã:Qsu"eú\1a3°8\1a\ 17\1e\ 1wBMj z1ðõ¶d\1c'û,2aé\14ä\91        \9ac\ e\99\94\16*\8f<®Y\11vÜùÞ@J\8a\98,Í$´ËD\13ÖÐf Ç3Ð3Ï ÂÂñ\12\84\0Ô\8c\9d\80ãÇ.0¦LY\18FÚRªB¤Ë#U\ 4\158ú(»\\19ú\82ì¶áx\f\19Ç\bR\82¨\19A¤ÕUd)$\85Ñ1\91\84½myó¦¬\8d\ 6ÆjS4"G#\ 5¨xÀñCÑ<ß×*§eôþß\9að®­UFKµW\96\1c\81Ä®»>êÇMÛ\7f\9bz¾X¯º\7f\9b\15\9aôÕ¯î\11\17\13\83¶B\e\94\ 6\   [¡­\91QÙÿh+\9eÄ\16°\15Úx©\83¡Û
+E©Dê¼´\95<¥H\86°xX2S\81\90V\9c<\85"uü 
+\91l£a\95J R\1d\9fJt9>\8f\8cE\eÙ\ 3\90Æ<2\16ñ|î\8cLq9\1cS}H.Ú~\1f\80)a¶Y\92)aÎH\12J\15w\19¡ D\82Õ¿ü\ 5\93Ü/æ\84\ 2\17òÐXö.ç\b\8d\ 3z4\16¹z;^@,z÷Ö3Ë:_â%Hdz7(kµ\80´W\91·¡°\90i=²\98\1a\95µý\ 4yñù¦·\80çØ÷¼%=G\1cô\1ci\ 6\7f\0ÐT\80a
+endstream
+endobj
+2799 0 obj <<
+/Type /Page
+/Contents 2800 0 R
+/Resources 2798 0 R
+/MediaBox [0 0 612 792]
+/Parent 2789 0 R
+>> endobj
+2801 0 obj <<
+/D [2799 0 R /FitH 686.127]
+>> endobj
+2798 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2804 0 obj <<
+/Length 605       
+/Filter /FlateDecode
+>>
+stream
+xÚí\99ÁnÛ0\f\86ï~
+\1díCT\91\92EéØ\fÍ\8ab+6Ôë¥ë!Y¼\1d\96¬Ø\80`¯?9\8e\83$ukJË\80\1d|rb3\9f\7fR¢À\1f\9bPâm6­²\8b\19i᥷hEõU\80²ÒY/¬³\12\90\14\ fùT\1aYL\88\~ýi6{\7fy[L´ÖyU8\9d_Nß]Ý\15\8fÕÍÅÌ\1dp4:I\96Â[¶\ 4pÐÄdj÷âÓëU\95ýÌ |T\ 2\ 4\80\92D ¬%IèÅ\97uöð¨Ä2<¼\11á\91'ñ{\eº\16Pz©\9a·¬Ä]ö±ÍçP\ 6 \91èB:%I4¶\15s½ù¬@¯ç?Ú4Þ<\15\13tù²\ e\17Ôئõô½\b÷ê]È}sk¾ÚÔÛ$úÅ\96 ­7§b\8d\8a%s¨\16¬$\13Ô\1a\15T»VíB)õ¼¾ IB\89]}Q·!G¸I\174\ 1\90¾,÷<èá\19\94 MÇëÇíbNpЫï\98g¢xÃú \867\8cC>\8e\93­\1aÆÙ=\ eXëkøë»Eò¨6\9eÚ\80\87É@id\18&§i\ 6\86f\9fFfhvÃdû\8c\f\9c\14Í\9c\ e£\98\96Ø\839e.\93$sÊ\9cÐ$ý\8a\8fKa\13JÁ©\84V    Û¢!3:\eRJ\ 1Àh@TihNA\12U3ö\ 6b4\9a\ 1-c\17\90±Û\ìnãd\1fy\1c3\88q\87%ë,ÃH$ãD\88ÛP\9c=\8aqg90¦\8f2bÅ9\alL\832äù\97\87^´Zz¢¿\9aÐw3/\1a-±ÓuÿAKhGï£aÝ4ùÉç\8bUÝ~½Ý¬\9b9}±\9dàë_íOH½ê5z=\a:\92V¹sx\ e­ X'û\ f=Ç^ì\19<\az-KgGÏ1z\8eÑs\8c\9e\1c£ç\18=Çè9FÏ1z\8eÿËstCï\19<G7ó\9eÓsôÿ¿\11\ 3¸/\87'
+endstream
+endobj
+2803 0 obj <<
+/Type /Page
+/Contents 2804 0 R
+/Resources 2802 0 R
+/MediaBox [0 0 612 792]
+/Parent 2789 0 R
+>> endobj
+2805 0 obj <<
+/D [2803 0 R /FitH 686.127]
+>> endobj
+2802 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2808 0 obj <<
+/Length 754       
+/Filter /FlateDecode
+>>
+stream
+xÚµYMsÓ0\10½ûWèh\1f¢jõ­#\85\16è¡\13\ 6O\87\99ÒCB\ 2\a\12:0\93áï£Xv\89\13'Þ5âäÄ\91\9fÞ®VÚ÷\1cÁ¾1ÁÞ\16×uquëYàÁJËê¯\f¬àÖ:f½å \1d«Wì±\ 4/«§úîêÖ©\83¡Ò\bîâ\10\91\ 6½\9aÏoîß¼ÿTÍ\94Rå5¯f\11§|\98«ý£\85h'<¾ÞÔÅÏ\ 2âGÁ N®¹±\81Å\a#r`_¶Åã\93`«øã\1d\8b\93\ 5Ç~7C·\fLàb?÷\86},>\fÄá\f×\91®5\8eKm\13Åw»Ï\ 2Ôvñ#q|ý\ͤ/WëxÑÁ\94uåuùü½\8a÷â-(Ûa\ f\95WåbSA¹[7±\fs6ÀmÐÇ\9c\179;Ý#-¸Ñ1ùZpé}"½\14B¤ì÷âS\8e\83Q]ò¡\1dÒ\83\9bu\83f\0<\18ó\82\a\ 3xZrPºÃ\v\83\98#8@ð\93\9aÀ\ f\ 4\88Q\86\8eÄ\10`\9c¢¥P\1c\18\96å2fpx\91û\88\12\1fr\83\b\88º1ø \13&\92«¥rÅ2\96b\12cD\ 1@\98\82\8cª~9\8el\a\90\11E\v\938\8f\99°~\88\14{:Ýq®\9aÌ\15³3\1c\99*¦Æ,­\12Æ\83\a\88\8a"-\11&\91\92\ 4\88È!¥æ\ 1Õ=\15aUpY4$\8e\884*ACDp¤\9cwÈDj"$\82¥£A\ 2¢9)Bkn Ç·¡'lCÜò(R\99cÖ[\9dW¯Ò*\1e\9cû7Å\9dÄ«Ô\8aË\8eY\94ÿ\1c\92\8cî\89o\9dÄöb¹Y§¯÷»í^w/\eE¾þ\95\1eqò¢w\18ô\10J\ 3×Âæð\10Êh\1e¤A{\b©ä>,Õy\88¾\7f\182\ f/d3\98\a¥\1dW^\9f\9a\87óûVb\ e@yb\1f0mI\11äyæ6wáT\91\18¿$OíC^¿\84\ 1ß\91pz\86Ò\91\1a-#²\9eP\rdÞc\14Õ\90HâCd\16\1f"¯KDY\rO\93   È®AQ    ÿA&`¶ ¦uàdY²\bö\13ØLöÂ\9eàâjÞO¡\f\98SØNÈ1.\1f$[\7f\b\9dÙ×ÿ\85Înì\ f¡3;û\ 3è¼Ö¾\ 5\86¼/\92pÅæ\88\92:ëKH@\16\0m\ecXÒ\8cÞ\99F=ýÅ!à¼\84=/f3x\89NËæô\12ÃÿCÄ\bþ\0y8u\b
+endstream
+endobj
+2807 0 obj <<
+/Type /Page
+/Contents 2808 0 R
+/Resources 2806 0 R
+/MediaBox [0 0 612 792]
+/Parent 2789 0 R
+>> endobj
+2809 0 obj <<
+/D [2807 0 R /FitH 686.127]
+>> endobj
+2806 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2812 0 obj <<
+/Length 743       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98MsÚ0\10\86ïþ\15\ 1\92VÒ1tB3\996ÓNH.i\ e¡Ð\1e
+Í´3Lÿ~m\f\89\ 1\83w]\95\v\ 4\94Çûeé}mÔweÔûb<-.&Áª¤\13!©é7\ 5\86t¤¤(\92\ 6\fj:W\8f\83±vz8
+!\ e®ï'\93\8f\97·Ã\91µv0\1dF;¸\1c\7f¸º\e>Mo.&±Á±\18u P^eC\80h«5\85Ù^øðýjZü* üh\14(\0£C\0E\14tÀ¤¾®\8aÇ'£æå\8f7ªü)\ 5õg³t¥À'mª«,Õ]ñ¹Î§\19\ 6 Ó\18Ët|Ðè¨\ eæzýÅ\80]=ÿ¬Óx÷2\1ca\1cÌ\17å\eZ¬Ózù1,¿[l\97<T_=/×\8bM\12íÁzÐ\94Üa°.ųÁ\ 6×\8c\16H\aWFëL\19u¬£\9d\99Íë¸Ä`\83\ 6\8f»\12\97ì\11G»E#\0\9d¼o"¡\ 5éP\83u;dh%n×\1c\13¡3Fô¢\18\19À(\ 1vg\9c\ 4\19CwOvKÎ\85G¯<\ e\10\ 5ù\ 2t\17\10\ 4S\ 3ÌA4Bdw["¿-À\ 2¢\bÈ\98ÃÄo4p&\a­¤\88Ð\9d1\b2n\8do\1fg$8`L\r:AÂPÕ°;H'\vò\14ôà\8eñ\82Vo©\8c\82zy¬U]\19\855ÒÂÖdÆÞ\91z\91\8fýÈ\8c\e\15zt\ f8ÃF}\1aȪ\ 6Ä>Õ`\95\ 3B/4\ 3Lb0\ 3*Ý#\18ó\10DóÀ¸\91­h\ eX\87¾\15¥Íi\ fÒi%\8bdu
\9fd÷VÈ¢³\1aw±=|²\1aj=½§À]¥¸Ýày¶\Ô\7fÞ®W\95ø\9emdùâwý/Á\9d5\10­F\ 2cÐdb\ e#a\r\94~\88þ£\91x\r6\83\91Àdµ\8fÔb$ò*LÖ)!ò%,©àeÄÌ·\98©\ f\9b¬:¸ffqdô\86Ìì\9f8§ \15\19(È«\vO6¦·,<Ù\16ù)â%>\8f#ÿIâó0\89LYVýÏ\91¿ â±v   \929(ÖÖcA\fÍ£ýé\0
+¼Í\^\ 3à\19h\12ökë)2\8bÝ\ 69³Ö}%CfGø\ 6\86Üæ­\89ÎìÞ\1aèÜö­\89Îãß\8eÐ\99\9dÅI«)~hÕ\9c\8a¼\ f­\18»N\12\19\15æ³ÎvM\9bÁRì$mNKá[-E\99Á_¤\9f
+endstream
+endobj
+2811 0 obj <<
+/Type /Page
+/Contents 2812 0 R
+/Resources 2810 0 R
+/MediaBox [0 0 612 792]
+/Parent 2814 0 R
+>> endobj
+2813 0 obj <<
+/D [2811 0 R /FitH 686.127]
+>> endobj
+2810 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2817 0 obj <<
+/Length 744       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98KsÓ0\14\85÷þ\15\8b¨÷ê­%\85\16è¢\13\86L\87\99ÒEB\ 2\v\12:0\93áï#Ûqã$n|%\94U^ò§£«kå\1c\ 3ûÁ\80½/®gÅÕ­c\9e{#\f\9b}gh\80\ec\99q\86£°l¶d\8f%:U=Íî®n­ì\r\15\1a¸\r\1dôf:½¹\7f÷ñK5\91R\96×¼\9a\ 4Nù0\95õ¥\ 5ì&<~½\99\15¿\v\fo\81a\98\qm<\v\17\ 6²gß6Åã\13°eøñ\8e\85ɼe\7f\9b¡\e\86Ús¨ç^³Ïŧ\81uXÇÁ9f´åB\99\87íW@¹\99ÿj5¾}®&Â\95ËUx\11R\94³ÊÉòùg\15¾[í\86<Ô_Í×ÛU³\88\1a¹ñêX¬òî¬X«\ eÔ\ 2×*T]\ 1\17Au£v\ 1ÐVý`]Jp\94ª+ºßíK\1f6éÆL\10¹×º£á OZ\8eZv<á\ 6\81»A'@\1c\15(b\ 4\ 6\85@\10)!Fd\ 3\1d\17jc\85\8e#Ý8Òô\918¾=6nåHØq\15\89$¨ÔQH\ 2ÐÓ\81Hj¡nR*q\#\8aq¢Ù\13Ç»GÒ\e\92r#B\ 4\ e)%\14\84õ\8a\12\ f¥\1ck\12\13°4Á.bÛ{dBCÙ$Í\94[\1eÒÈ\ 4Í>\85\8c\84?:\13×¾\1d\98P\r4);H+\87N*\aé\8fZ$¢        §-¦¡    õPñäñ\93MǶ\ 6¡\ 4±=1®RE©\1cça\f\8f°5ðºÃ\15FroíÿÙñÖà
+%¹è\84\85lÀ±õÙ\aÎ\ÕN\\95óÅzÕ~¼ßnjS¾hìúêO{\895g\83Å`À\90
\ 2\93#`H­¸\17ú\82\ 1ãEl\86\80!\95åÒ©\93\80\ 1\f\86\8fÛô@P\1f³¯u® \98C1@$ Ïy¹A$\8e#1\ 2\899rßÞl\12o~ò¹\9c×k^Àl\92üµ\8a\13\89yÃs\83lón\9eÀkNÁ\98ÙVíÁ\94\9eÒIÅÈo#ð\12\8f\0\98;Ót\Úm\81  \8dA|Ô\0iª1w\1aë¡1³-~AS\1cw\\1eë¡1s\ 4Ù£)ÍçÓTSnÃ\84ã.³\9bo\83\aR-\94rÚG÷\ 3fz\1cg\8e¨\84sÞÅV\95Ô\ 1\94\98ÔÃ\12\9fy\r»à\f!¤3Á9C\88\1d\f!a\ 5ÿ\0yb\85\8e
+endstream
+endobj
+2816 0 obj <<
+/Type /Page
+/Contents 2817 0 R
+/Resources 2815 0 R
+/MediaBox [0 0 612 792]
+/Parent 2814 0 R
+>> endobj
+2818 0 obj <<
+/D [2816 0 R /FitH 686.127]
+>> endobj
+2815 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2821 0 obj <<
+/Length 731       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\98ËnÛ0\10E÷ú
+.¥\85\19Îð½\8c\8b¸AÐ\ 6-¢f\93fa×n\17µ\e´@Ðß/-É\86\14ËÑ\90aW~ÑG\97Ôpt/\ 5ûÁ\ 4{_Ìëâba%óÜ\e4¬þÎ@\18î\8c\19\ ehY½f\ få\9c+^ͬuåõ\97Åâãåm5\93R\96uådy9ÿpuW=Ö7\17\v×ãHtÜ\1a\e®Ò\10Àéý\98Bt\17~ùzU\17¿\v\bo\ 5\ 3\ 6 ¸µÀ\8c±Ü¢gßvÅã`ëðã\r\v?yËþ6Cw\f´çb\7f\95-»+>·óéË\0T\1c]\98\8e\1c\95iÅ\?\7f\15 wË_í4Þ=U3tåz\13^Pb;­§\9fUønÓ\r¹ß\7fµÜ>o\9aI\8c\8bÕÀ\8dW/Å*ï^\15kU_-\18nUP«DPíZµ+!N\97\17\14r\90ê°¼Ý\88\ 1lv\183\ 3à^ë\ 3\r¦q\10\83#ðd\14\ f\b\13V\91ÄÀ$Pu\ 2\15ÆÁÒrÐx\Ðq½Ý \96lFÈ0M\96Óä\11Í@ÐlÒÈ\ 4Í:\85L)\v\93r\ 3\81²%\"\19&Év\9a|Z\1agVc¸Îh\93Ö\19\be\87&\rM¨;      \89èiÕRÄ£ å\8cÑTÊö\83è\96\ 1M\97#ÔE\82à\ 6\vHC\13\16\ 4u"\9a Z%¡){\10\Òm¤ìA°iª)k-\12Ñ\ 4Õ>\ 5\872\81KÀFË%0#kbú\19\82ô§\13¥õDÜ}\828\7fÞ4£\91Ü[û&\87ßyfT\92ãAÖý'É¡µî\ 3³¯öæ^\95ËÕvÓ~¼}Þí}þªI\0\9b?í_¬{5«\8cf\16t\96\eárd\16) D/ó\1f3ËQl\86Ì\82^rí\f%³¤W\99 VÙ\e¶@r "\19S\19Å£e
+\8cÙ¥D+\13a::#Cñ\e*R)IkLÃï¨\90Õ2\1f\1f{9såñ\81\97×\10\1d± òÄ(3\ 2Î\e£\ 6ä,1j\84\f\99íò\0\9d×.÷Ñ\99\0\9d'F\9dÖ\a­©¹\14Õ´ÞfÓÐ\99íò\0\9d×.÷Ð\90ùPj\80Î{*ÕGg>\96\1a ó\9e\ 3D¤Þ¼\91\84v\9a\8a\9e¶#\\9cFB\83W1\r\9eÀ\83ó¾8C,9Øâ\9c±Ä\8fÆ\920\83\7f\8b\1e\9a8
+endstream
+endobj
+2820 0 obj <<
+/Type /Page
+/Contents 2821 0 R
+/Resources 2819 0 R
+/MediaBox [0 0 612 792]
+/Parent 2814 0 R
+>> endobj
+2822 0 obj <<
+/D [2820 0 R /FitH 686.127]
+>> endobj
+2819 0 obj <<
+/Font << /F73 507 0 R /F8 458 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2825 0 obj <<
+/Length 112       
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppçr
+áÒw³P°Ô³432S\bIS043Ð333W0³0Ó342W\bIQ\88Ö0´0Ó\8c\rñÒw37FRjdj g\ eTb\0\18\10àêçâ\19¡©kll¬á¤§©\v4G#,À\18¤\95Ë\0j!:í\1aÂ\ 5\0@l\1dÊ
+endstream
+endobj
+2824 0 obj <<
+/Type /Page
+/Contents 2825 0 R
+/Resources 2823 0 R
+/MediaBox [0 0 612 792]
+/Parent 2814 0 R
+>> endobj
+2826 0 obj <<
+/D [2824 0 R /FitH 686.127]
+>> endobj
+2823 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2833 0 obj <<
+/Length 1213      
+/Filter /FlateDecode
+>>
+stream
+xÚ\8d\8eÛ6\10}÷Wè­4\101¤$ê\82>mnmÚ\ 2A±F\11 Û\a­DÛìJ¢JÉ\9bæï;álm×I\8a\ 5Öù\903\87g\86\12Ñ!\12ÑO\e\11~_í6/ßee\94\b\9eç\89\8avûH\8a\9c\97y\15©2åY\ 6ª6úÄnÆq\e§\92é¡5ÿ\80T(özûçî\17
+ÎxQ\16\12\83E\14g\15/eFa¯mgÇ£\1dȵ\8c*^åI\1e\1c\95ä¥\bû\7f8\1c`פ`f¢ß\1aC M       \9e"z\88\16é×MôÉ;|4ã\91[\17ÂÞmË\94ÙÓÐÖ³¡ãÎ%\ 6\7f}'djÝLþ³¥ßÑÙY7A©§I\ fÛ¤d³©»à§\a\94Jf÷¤{O>Ú\81\894=*N]\8cçbeRòJ\85ÊfÓëÖÔàX*¶w¶G)g\8du\80(îêêY\93õh§¹>èx®\1fÌpøq\eg2a\1fÐ\rr\e(îÖ\9e\\13ü=V \9b\8fA\ 1     ý\10t\a§aßi&\ 3\96\8bguO2ÌC\86\88E\9a²\87-\9e£GZéG,J»/øc\a<!Í Å\ 1\90Z\96±[­¿yKà\7fsï³·§\99â)UØ~u}°úÎõ\81ÇÞ:rmõ\\9bnâ¾\12\99ñ*Ë\9e\ 2î©\94\89\84í\8e\1aÀEYz¨PçÏG\ 1Ø\909\84\a­ç\90GÓjKbc}æ­n Ú\    vã¯ý\ 2\a:õ5éübï´î\82|ÚJ\ 6GBÃР       õÐ\92¡5\13Ñ$¾\96ûìÌýÉÓ\ 1b\b«%½\14\82ý.¨YJCy"\1eéÆ`M\8dGpz\81\92}>jØÅ\91£\19èwtæq«\14\ 3~x7è\82Ó}g\9a\10c\83û\85¡Wy\1dh[\0\95ë±nÌLHÀ=\ 2\90ìg\8b|úìY\14¸ôbÍW\88\\91\0V@\82lE\ 2¯£\8a\v\8cÙz0Q&<@\80î\85³\14ûK7\88õL\83ÉéI»GOæ«\rIÝR1g\ eGßÉ´ômP     6éE±8Òy \9ca\aù\1aìd¡\9cAh´\9bÍþË÷ü\eÛ\8f\9d\89¯µf=4úëL_àÃ\9eW2?§§dÁ&»÷7âñ¯\9d&\8f\86æ@\8b\97\ 1P{\84n\ 4¡Ó(õa\ 4\86\ 4\84ý\81»\81 -\85\87\16ù\85«úë¼~uû&îÌ\83g\ 1ô\ 1\f\ 2à\9b\1e&(..`\92ì\8e¾A±½)C=\91Û`gÒÃ¥ÂÙMXÍGãZ\12Ç\1a@^Üi¾ú}\96\a\92\92Æ@¦W\99\1c.\ 6ÌÃB\at\87\1e\8cb\ 1÷4N1ÿ\12\80Ï\99\ f ûn\a\ 3Òpá½Ç\1d\8d'BÉÇ.L\96,L´\0\ 5\8d´ÍÛÝ\86f¨<¿ÄI\91r%Ò¨é7\7fo\ 4OU.Ée-{ã\12\19\14/ß÷²\8cÞØÍïð·ØâeÛxµ¯ÿ\ eX¿Ï\89Hx\9e%Qªà\10Y\11RPï\84\15©\ 4`? è(R\95*\85×~ôCàÒXþÙ/\8aÕ¾\12¾4`;A\eÞ%J>ÿ6\0\ 6©B->\89\10Y\fÿ
+:m53`µ<\1cç\99ZñBTOï\97æ\89\9fâ\8aÝt\1d\ eâìÒýþeð\ 4óóÚѬj\83?ô>L­,YfnXüáÏu÷f
+\8asZWºø?¯[\HAC¢\90\92]è`\1c\99:{°\13\19=´¨\9b]Ýê¾v\ fÁp'\94¸\82n"s \84¼À\9b\14ÏáÍábÏ\1e\ 2\9f\80\9c¦|¾ñ¨ÇI\92ðª\92×çÐÿxËÙק\19Í\80ô2\ 3\9aS¿êÈ\8c-f\1aо£Éð[@\ 2\8a´¤\8fØ\92«DF \17@bú\84}\8eDÆá9\82¢.N;\9f\9eâ*U¨\97Ë÷ïÛ\95~¥þÈ\9fÖ\a\8f\11OsÜR\14\1cf"yɲxâ\ 6-þ/y¾ðà
+endstream
+endobj
+2832 0 obj <<
+/Type /Page
+/Contents 2833 0 R
+/Resources 2831 0 R
+/MediaBox [0 0 612 792]
+/Parent 2814 0 R
+/Annots [ 2827 0 R 2828 0 R 2830 0 R ]
+>> endobj
+2829 0 obj <<
+/Type /XObject
+/Subtype /Form
+/FormType 1
+/PTEX.FileName (./xifish.pdf)
+/PTEX.PageNumber 1
+/PTEX.InfoDict 2835 0 R
+/BBox [0 0 199 199]
+/Resources <<
+/ProcSet [ /PDF ]
+/ExtGState <<
+/R7 2836 0 R
+>>>>
+/Length 2837 0 R
+/Filter /FlateDecode
+>>
+stream
+x\9cÝV»rT1\fíïW¸¦X,Ù\96ä/ &û        ;\10\8a¤ \14ü>:\92ï\r\9b\85\8aL\ 6\182ìY­\1eÇzÙ_K=Q©ø·>/\8fÛû;-÷߶zb\e\7fꬵ²\ 3¡I\9dÊÓý6'\15\9aFåq\8b\ f|\7f\7fîß?¿s7c\88¸\91[Oe\11\aF<^8\ 1L\9b+[2\9dfnÒ*'\85Þ\eQX\1fq\7f¶Þ\19Àº\0º¢t\87\8d»+j·B\9d\e4i\16\1aÌ\bIÕÅc\180Ou\;p¯cW§1{qÞ¡¯C
+\91\ 4nSÊì\921G/ß·Èg¹ûðf\81Ï[È´U\94ÃóR$Ý\10K\19c"¨ñ\8e¨\96a03\9eE\82\873ÿC\ f\8bBè»\87&~rêy\16ñ3\92Õ8K÷³³Wß±x/\10÷8£±=cé\87¾!WµÎ8»ö\ 2\1205\87#¼ y\93#\812Û.Õ®\ 5y^.L\83\89Z+2\ eÝd\1eù\95\16­×½O\97\ 2ʦ5\b\ 5÷<ýçÇôb\16¬\ 3\fY'§YûÀqÑ\95SC\19'7\8f\ eX¥¨H¸ð.U\8e9¬´\9cuüL ÐH\8aqÝÑ\84\8c=\ 1Tg\b\r \1c+ÏÜ|\ 2ª²ÇmNle¹\r$\7f\82úh\9cÃõ°á\84ÁèaC\a;ÜÛtI©\92íÊá\94XçÞÞÄ-[=
+k!Gí\88Z$\99Á+)fÁëÈ\82Gf\ 2ÿk|Ï«j^ \8c»Û­\1e¨¬E\fnPÜl\17\14O\b?cè³\9bzç¥\87ªi\9bk8^ßëùy\8f\18\9c³gÔ*¯\ 4«\8e\8c²»\9a§e!ÏY"§\89\18Ø\9c\8f¾¡}jx.\16\a¬²\9fuèr\89`Öl\9d ç\fÿϦë,Ç\15\80Å        óÇ4\97Ü\93û´À(y Üi$>\99¯b\8e\ùÈÖZ\83¢\ f­ÿ=}\8aÊ@8åZ\b¿Ñ¨×\9aó\17æXTHÔ\95Ð\9f\ 5·\9a\10¾\f\14æ±àn"ݨB\18mzCÿ7Ò\97\a\889ªsÞ
+1,7´°?¯\84{»¡ÿ|Þð¾\bHJ'ßN¾ÏO]f\86\18ª .[7õ\9fi\85¦q\18\ 4\86\1f×\ 1lÃ_1Z\ e}\óá\aà²\1dþñ5\ 2/\83\83Ï\ 54\9dï÷¿\99â\97Õ\8d\98öE1a\93\93\87\10òg \96#ûPcö\ 2\¶!t"¼\95\9f\r\12\87ë\846ÜA9ô±yÂ\ f\80SÜýãk\ 6N\83\83Ïåê\8d\18;CpË\ 1¡[|gø\83\fíù\10û\86ª`;°§+\9emبc\87~)®Õê7w´e¼\ 2Ö\²oí¼¦ó
+\Û2\1e\8bo\1eø\1c;\13£ï{TxÝÈìÞÔòù\90ïÀ´ÆrÉ-»P,æºï[[·ßk»<o\1f·\1f½ásñ
+endstream
+endobj
+2835 0 obj
+<<
+/Producer (GPL Ghostscript 8.70)
+/CreationDate (D:20090924115427-07'00')
+/ModDate (D:20090924115427-07'00')
+/Title (xifish.fig)
+/Creator (fig2dev Version 3.2 Patchlevel 5)
+/Author (giles@snow \(Ralph Giles\))
+>>
+endobj
+2836 0 obj
+<<
+/Type /ExtGState
+/OPM 1
+>>
+endobj
+2837 0 obj
+884
+endobj
+2827 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [145.039 478.892 237.629 489.74]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.xiph.org)>>
+>> endobj
+2828 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [234.917 454.982 375.723 465.83]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.xiph.org/about.html)>>
+>> endobj
+2830 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [186.702 311.52 279.355 322.368]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.xiph.org)>>
+>> endobj
+2834 0 obj <<
+/D [2832 0 R /FitH 686.127]
+>> endobj
+406 0 obj <<
+/D [2832 0 R /FitH 668.127]
+>> endobj
+2831 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F77 675 0 R /F7 674 0 R >>
+/XObject << /Im18 2829 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2840 0 obj <<
+/Length 117       
+/Filter /FlateDecode
+>>
+stream
+xÚ3PHW0Ppçr
+áÒw³P°Ô³432S\bIS043Ð333W0³0Ó342W\bIQ\88Ö0´°Ð\8c\rñÒw37FRjdh¨gb\f4\ 6¬Æ1 ÀÕÏÅ3BS×ØØXÃYOS\17h\8c\86³¿\8f\7f\80\87¿\1fH;\97\ 1ÔRtÚ5\84\v\0Ìn\1f\1a
+endstream
+endobj
+2839 0 obj <<
+/Type /Page
+/Contents 2840 0 R
+/Resources 2838 0 R
+/MediaBox [0 0 612 792]
+/Parent 2814 0 R
+>> endobj
+2841 0 obj <<
+/D [2839 0 R /FitH 686.127]
+>> endobj
+2838 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2850 0 obj <<
+/Length 1718      
+/Filter /FlateDecode
+>>
+stream
+xÚÕXMsÛ6\10½çWð\bÍ\94\10>     Â7[±\137UãF\8aÓ\19'\aZ\82%L$R%)Ùnûã»  Y\94\97\1er\88\ 5\80»Àb÷áínH4\8bHôî\r   ¿gã7ý\v\91FL`\95*\1a\8dï"J\12\9c&:\92*Å4\15Ñx\1aÝ 3{»°Å¬ÌVó\1e§è±÷müën\93þE\1a\13\968}\12Å\92cAS¯ysVfZ}k)D7±$\ 4\8d&E]÷bÎ\18\ 2¡inJìÄú\17\8aìíG\89À\89\94 Øì÷é¢Ç\124\05\91"F©>éÅB
+ôÁ<º5\85î\8b²')\9aV~z\aÓFv]\19¿bsÿ\ev
+r`\bE\85\1f_æS;q\9bduÐùäf&væEq\92bAX\14S\8a5\18Ö\98õ×Ú6Ç\9a¥Éa+A\14ú­\99oÌ¢ò·Úw\92â\98$»;ýâ\14(\1aöàDgF       \83I\8f)4\87ÓS\85¨Ö
+\a\ fRP"Ñ÷h;ú\0îWboëDaÂØvëy]¯Núýûû{lM}\87\8brÖ/ï&î\9fs\1eö7¢\82`\92ªp¥Ä«Ö\ fõ\v\12'\9an\8fÁíøÆ\12ö\11"\8a\19ÅDð\80\84ÁèBu#áK/åÈäñûÊ®óY/f\82¡ÁÜäà\18\96\104À~é}V\96¶*r?\e-m=o$Àmù4,\ 6Ñ­Ê\85Û¹Ì\16\10O\96¢ïnUKtê?ÞeUíG\93b¹Zûðò\ 43ÉÛÑ­³Ú\16\0a\99¢l1+J8{é§\rÂ\98Ô¨\9e\e¿2µÕ¤4u\98M\8aÊæ&\88\94Y^\81²\vé\f^aÊÕÖ§\97ççç \95j4î)\85\1ax\81v6q¶T>p[\95\96µÎA\1c\ e\1e\14Ëå:ß"y«Ô\ ec
+hQ|\ f\88\9cs4ø8\ 4k¿\12I4ü¡'\94\10ñ\ f%\94\ 5\1a\99Um\96Ρ·Î@dJ¯GµR\87\8cc\ egy(\ 4:¹¹\1c\7fÖ²\13
+\97¹Û·6e¾ó¹¤\ 4\10²0\10¨æ`w¯p§æûç\1cÆ`\9e\ 4\80l¿úÎäfÓ\93Ò=+7g$\88\8cîmý·)\9f\8fø\ 2\10Õ\19#\85\85ÈÓ\82û3Ùý)\80\ 1¦\8d\14Í\10\5þä\86\1c\9d\8dqBh,\81²$ÓhT¯§¶ð\9fÎs¯ÜP\97uoÀé^e>êK\0\r¹· \1dñ;\90'        zkg¶v.s\13@Mâ\¶±\957\ 6Ö<\eÂ`TÃ\ 5ýîS¿"N¸\e(ÿ\96ÜÊ\17;5ñhRî.iÂ.49Ñ~tZ­\9e\PûµÆ)\99w-9xG¶èÀ P\89äô\0\83T§,À­tW0S¿n¦¶ö¡öRZvp\8fJE\aàÒ\9f\12p +Ø«\ 1\97È\1dà`\b\80\13\8aÄ\89Ë\91J\ 2\eHOá\96N a\96}\8cÀÚè±
+\89.\9cÝ\ e¡Yv\84\90\11L)?
+¡"¯
+az\14Â\ 4ó¤\833\bû\19CÈ V0ê\ e!Øö\14>IÄ6|n\báSD7|¡ä\ 1\ex\89M¶X\9bÊ\8f\9b·-\89lòP\13¿ppËÈ÷oÇ×>\17U{\14P\1d¤²UùÄFë\897έû<\v\926o¹û@g\16\f]\86´g\1e\E3wµM\96ÏÌ1~¸+òô\1e\a\ 4ûýjë\ 2\80\17\12 ³\87*q\80*F\b;DÕ6f-T\rÍ\82\88NT\ríw\87\1a\13\8a3\ 3á\85Ú\ 3*\88D\bt}ÅÝ:A·¶®êÒdK/ær{Vûq\96÷\1avuã) °É\95\9eÜ\9dæªô+\13SU¯®î8UXJÝ*ïÂcM)\ 6úm;ËW~Ëõ¢¶KpP\86'\ fýÍ\8aÇ\ e(ÁVü\83:\ fÚ\0~ø²\87Y¹«O½³Å¡³\19\15X¦ü \ 4¼º3\84\1fy;\91\1c\8dìbcáÉq%\10HÙ¯\84òç\1a\ 2\8e\13\96\1e7\ 4:A\rî²+\87ôçª1\ eÅÞÇÙÌ\7f\f96[UëÅ.A'P"\ 2\a\86°9ùë&o\96\81\10a\81\1dW\98Óä5x\1df\ eE\8f\1e¤à)þêX\v\8då\13o¼PÉ»[ÿ(\8c©ë8\9e­×\19ô4G9óÊ\19^4Ö?ÓÁ\ræY¹pü#\14E{â\9e\8f\9bÇ\92\82Ç}\11nþZ\eÿañ\18g\95\7f\S¯\v\9fªÀÌ\90°PæëÊb]ûù\f¨$û\7fßȪxÌ\9dÅ\90,úïÜq\17§\7fày½\¼äÔ\84a*\ e+\97æ¶æ¶\gåã.Å\1d×Å\90õ¸>l\91FÃ+ÝÍF£@\16\10û-\9e 3l
+?ø\1d\16\ 1Ï0¾\9aØz]:ð§i(æ`\15\92¡hezøx\9eÏ 3\ 1¨wWº
+²Ïîå\83eãó\98*2ÜúRP,dÛ\95\ 4´Îÿú\1fhF\9aR\11\9a¡mS}ê\1e\ f\9f2üÚ5Ô\9c>\8d\91\9dùZåi£ßÇ£A«µWO\85´ÛtÕ®<C3»Z¼Ü\aA\ 3¬õQý¢\8fh\r\9cÂÄ!«ýiWÏT&ðeî^ªkÈB3Z¬Cºïä6\ eýÜ\13t¯=5ÝZ÷\9f\14ÀJ\97îG¢ý¢Û\11¥xºÚñÍ4ÅûD\ 5\86¨Vvüñs\12\98\10ÕAC\ fîrÛ>\94\ eê!ÇPÅlÖß47èO\8bIÿ\85Ǥ5\86+>CP,Å
\85b\ 23BC!\90ê\96ÐùøÍ\7fß+²¸
+endstream
+endobj
+2849 0 obj <<
+/Type /Page
+/Contents 2850 0 R
+/Resources 2848 0 R
+/MediaBox [0 0 612 792]
+/Parent 2857 0 R
+/Annots [ 2842 0 R 2853 0 R 2843 0 R 2854 0 R 2844 0 R 2845 0 R 2855 0 R 2846 0 R 2856 0 R ]
+>> endobj
+2842 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [282.213 509.6 451.577 520.725]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.ietf.org/rfc/rfc2119.txt)>>
+>> endobj
+2853 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [142.126 499.859 159.81 507.367]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.ietf.org/rfc/rfc2119.txt)>>
+>> endobj
+2843 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [423.432 272.6 451.577 284.555]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.multimedia.cx/vp3-format.txt)>>
+>> endobj
+2854 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [142.126 260.921 322.448 272.046]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.multimedia.cx/vp3-format.txt)>>
+>> endobj
+2844 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [191.652 227.923 376.706 239.048]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.ietf.org/rfc/rfc3533.txt)>>
+>> endobj
+2845 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [423.432 206.602 451.577 218.558]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.poynton.com/GammaFAQ.html)>>
+>> endobj
+2855 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [142.126 194.924 306.259 206.049]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.poynton.com/GammaFAQ.html)>>
+>> endobj
+2846 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [365.899 128.65 451.577 140.605]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.xiph.org/ogg/vorbis/doc/)>>
+>> endobj
+2856 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [142.126 116.972 243.495 128.097]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.xiph.org/ogg/vorbis/doc/)>>
+>> endobj
+2851 0 obj <<
+/D [2849 0 R /FitH 686.127]
+>> endobj
+2852 0 obj <<
+/D [2849 0 R /FitH 533.513]
+>> endobj
+691 0 obj <<
+/D [2849 0 R /FitH 536.721]
+>> endobj
+2197 0 obj <<
+/D [2849 0 R /FitH 491.767]
+>> endobj
+912 0 obj <<
+/D [2849 0 R /FitH 446.813]
+>> endobj
+911 0 obj <<
+/D [2849 0 R /FitH 389.904]
+>> endobj
+921 0 obj <<
+/D [2849 0 R /FitH 344.951]
+>> endobj
+706 0 obj <<
+/D [2849 0 R /FitH 288.042]
+>> endobj
+2618 0 obj <<
+/D [2849 0 R /FitH 255.043]
+>> endobj
+932 0 obj <<
+/D [2849 0 R /FitH 222.045]
+>> endobj
+922 0 obj <<
+/D [2849 0 R /FitH 189.046]
+>> endobj
+713 0 obj <<
+/D [2849 0 R /FitH 144.092]
+>> endobj
+2848 0 obj <<
+/Font << /F48 455 0 R /F8 458 0 R /F70 508 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2860 0 obj <<
+/Length 361       
+/Filter /FlateDecode
+>>
+stream
+xÚmRËNÃ0\10¼÷+|´%ìø¹¶{£\88\94\ 2RQI\ fUÕCH\93R!\1a\94\ 6\95ÏÇÁ\r4\12\17g³;\9eÝ\995G;ÄÑt4ÉFIê\90g\1e$ ¬B\ 28\ 3°\b\1c0!-ʶh\8d\85çd\93Ý'©U\17P  \9a\ 3Ï\ fh2\9b<ÎæÓÅõÓݪC\8fø¹Gÿ\1d6¢ýu*mHªH²^\11§pÙxØ\f\9a\1aÇqÚU\9büPÔû#¡F*\1cð:àweþÉÎ3òK9Ò0\ 5¢\9fq\91\12       ø&\U\12K®õ\98PÇ=^f)\11\98º«P±\80ó\bh\eb\ 4Î\ fǪnÞóv_\1fb>þƸ®º®\88\ 4w\88
+Á¼1±Ûò°/:\86º;¶%¡ZÙ@·í\ 2À³çyÌ\b\ e\1aâì\83MpÃ,üÚ\eFÓZàyÑÖ/$x\16D\87\8cða9\1eØÙ¬N(Go¨\8f\1e\82éV_\90Ú°Õ?;^Ûöc\9c$§Ó\89í˶bu³K\9aªH¢$á\82\165\94\14ª\9dm¬ýj\aû\19\8en,3J÷]Ø¿¯á6\e}\ 3óà\96ý
+endstream
+endobj
+2859 0 obj <<
+/Type /Page
+/Contents 2860 0 R
+/Resources 2858 0 R
+/MediaBox [0 0 612 792]
+/Parent 2857 0 R
+/Annots [ 2847 0 R 2862 0 R ]
+>> endobj
+2847 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [377.854 642.999 505.375 654.124]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.ietf.org/rfc/rfc2044.txt)>>
+>> endobj
+2862 0 obj <<
+/Type /Annot
+/Border[0 0 0]/H/I/C[0 1 1]
+/Rect [195.924 633.258 255.451 641.339]
+/Subtype/Link/A<</Type/Action/S/URI/URI(http://www.ietf.org/rfc/rfc2044.txt)>>
+>> endobj
+2861 0 obj <<
+/D [2859 0 R /FitH 686.127]
+>> endobj
+1173 0 obj <<
+/D [2859 0 R /FitH 670.12]
+>> endobj
+2858 0 obj <<
+/Font << /F8 458 0 R /F73 507 0 R /F70 508 0 R /F74 666 0 R >>
+/ProcSet [ /PDF /Text ]
+>> endobj
+2863 0 obj
+[300 300 450 250 800 550 500 500 450]
+endobj
+2864 0 obj
+[368.3 368.3 544.5 309.5 955.6 661.9 603.2 603.2 544.5 500.4]
+endobj
+2865 0 obj
+[591.1 591.1 591.1 591.1 591.1 591.1 591.1 591.1 591.1 591.1 355.6 355.6 386.1 885.5 591.1 591.1 885.5 865.5 816.7 826.7 875.5 756.7 727.2 895.3 896.1 471.7 610.6 895 697.8 1072.8 896.1 855 787.2 855 859.4 650 796.1 880.8 865.5 1160 865.5 865.5 708.9 356.1 620.6 356.1 591.1 355.6 355.6 591.1 532.2 532.2 591.1 532.2 400 532.2 591.1 355.6 355.6 532.2 296.7 944.4 650 591.1 591.1 532.2 501.7 486.9 385]
+endobj
+2866 0 obj
+[985.1 844.4 808.9 1011.5 1002 479.4 665.5 1003.4 773.4 1215.1 1002 968.3 878.6 968.3 959.9]
+endobj
+2867 0 obj
+[633.3 649.4 739.7 677 684 700.6 827.6 533.6 588.2 758.1 480.3 1228 880.8 702.8 739.7 658.9 671.3 670.1 563.7 846.1 722.2 1009]
+endobj
+2868 0 obj
+[892.9 339.3 892.9 585.3 892.9 585.3 892.9 892.9 892.9 892.9 892.9 892.9 892.9 1138.9 585.3 585.3 892.9 892.9 892.9 892.9 892.9 892.9 892.9 892.9 892.9 892.9 892.9 892.9 1138.9 1138.9 892.9 892.9 1138.9 1138.9 585.3 585.3 1138.9 1138.9 1138.9 892.9 1138.9 1138.9 708.3 708.3 1138.9 1138.9 1138.9 892.9 329.4]
+endobj
+2869 0 obj <<
+/Length 163       
+/Filter /FlateDecode
+>>
+stream
+xÚ31Ô35R0P0U0V06W0¶TH1ä*ä26\ 4\8a\19(\18\9b\81%\92\9c<¹ôÃ\15\8c\r¹ô=\80¢\ú\9e¾
+%E¥©\úN\ 1Î
+@Q\17\85\96X.O\17\ 5\ 6æ\ 6\ 6\ 6ö\ 38q\ 5s\83Í\1fæ\86º\7fÌ\rÿê\9b\9bÿØ\1fnÿÁÿ¸ÿ\ 1óïý\r\fÿÿ10Øÿ``à\7f\0Á 6P\f$\aR\ 3R\vÒ\ 3Ò\v2\ 3d\16>»@nárõä
\ 2\0øED\87
+endstream
+endobj
+2870 0 obj <<
+/Length 149       
+/Filter /FlateDecode
+>>
+stream
+xÚ31Ô35R0P0\ 5Bc3\ 5cs\85\14C®B.c\ 3\ 5\1046\ 2K$çr9yré\87+\18\epé{\0E¹ô=}\15J\8aJS¹ô\9d\ 2\9c\15\f¹ô]\14¢\r\15\fb¹<]\14\18ä\1f00üÿÃÀøÿ\1f\ 3ûÿÿ\rüÿÿ\1f\90ÿÿÿ\81ýÿÿ\1f@¸þÿÿ\1f0üÿÿÿ?Ä`d=0s@f\82Ì\ 6Ù\ 1²\vd'Èn.WO®@.\0Æsud
+endstream
+endobj
+2871 0 obj <<
+/Length 169       
+/Filter /FlateDecode
+>>
+stream
+xÚ¥Ë=
+Â@\10\86á  \v       \f!u\8a\14s\ 27?n\88m\8cà\16\82V\16"\ 4ÔRPÑÞ£å(\ 1\râ:»E¬e\8a\aÞ\8fQjR\94\94\9aËg¤r*§tÌð\8a*ãX(»\1cÎXk\94[R\19Ê¥É(õ\8aî·Ç        e½\9e\93©\ríÌÏ\1euC\0 \0ZÇ0\f¯'ô\ eðAtÞ\98ÞÒ
+Gûå\120©ÏT\968b\92\90  -QÂø±¥b\82\94\11\8e7ãõc û\ 1þ\ 5\17\1a\ 1g35¹
+endstream
+endobj
+2872 0 obj <<
+/Length 420       
+/Filter /FlateDecode
+>>
+stream
+xÚµ\93ÁJÃ@\10\86wÉaa/y\83î¾\80&\8dZ#\94\ 6j\ 5s(èÉ\83\b\ 5õèAQè¡\98<Z\1e%¾AÀK\ eÒufv\13¦Þ\r¡ýv73³3óÏEv\9cÍljÏìQvbóÜÎNíÓT¿ê<\83ÝÔæçáèñE/K\9dÜÙ<ÓÉ5ìë¤\Û÷·\8fg\9d,o.íT'+{?µé\83.WVÀS8\11\9eȹ. qn\1f°rÎÕDÒµð\12*85=a\f\ faÑÀ\8fwWÑ\1aí$\9dÅh\17\91\85 \8aüHÜ\88\e²ÀÏ\8c\ fô\89¶>z\11\96ápç1\ 6ôÑ\85\17ï3
+       À\7fäo*d\87ßø§'\84Ûn\0ÑIáê\16\9c":÷\85hà|/¿[±@\84ä*Ä   \84\9dÀ\ 2ó\84|\fbUcX#æ\94\8cÁ\87Ü{¬wT\19\89¸\1dP\ 1*L6`\1f\10.\14°      ¸\ 1쨾\80\11 ù\83â\1f±\1f\ 2\1f\g;âpõÍaB>cÑ\8cÉ\13Ω$\12\10k\86\85ªÇò\11N¨¨J\0\18áë\1c\1aÐci\17Ø!hK/Æfµ\88ØÍÂÕ¬±\88¬óL\ fL%L;\QLgL}L\93L©L¿LÕLël\ 2ø\°ia3Ä&\8bÍ\e\9fB6\9bÃÄê«Rßê_c\10ßÝ
+endstream
+endobj
+675 0 obj <<
+/Type /Font
+/Subtype /Type3
+/Name /F77
+/FontMatrix [0.01204 0 0 0.01204 0 0]
+/FontBBox [ 0 -23 88 64 ]
+/Resources << /ProcSet [ /PDF /ImageB ] >>
+/FirstChar 42
+/LastChar 169
+/Widths 2873 0 R
+/Encoding 2874 0 R
+/CharProcs 2875 0 R
+>> endobj
+2873 0 obj
+[41.52 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 41.52 0 0 0 0 0 0 0 0 0 0 0 0 0 0 55.36 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 92.26 ]
+endobj
+2874 0 obj <<
+/Type /Encoding
+/Differences [42/a42 43/.notdef 136/a136 137/.notdef 151/a151 152/.notdef 169/a169]
+>> endobj
+2875 0 obj <<
+/a42 2869 0 R
+/a136 2870 0 R
+/a151 2871 0 R
+/a169 2872 0 R
+>> endobj
+2876 0 obj
+[569.5 569.5 569.5 569.5 569.5 569.5 569.5 569.5 569.5 569.5 323.4 323.4 323.4 877 538.7 538.7 877 843.3 798.6 815.5 860.1 767.9 737.1 883.9 843.3 412.7 583.3 874 706.4 1027.8 843.3 877 767.9 877 829.4 631 815.5 843.3 843.3 1150.8 843.3 843.3 692.5 323.4 569.5 323.4 569.5 323.4 323.4 569.5 631 507.9 631 507.9 354.2 569.5 631 323.4 354.2 600.2 323.4 938.5 631 569.5 631 600.2 446.4 452.6 446.4 631]
+endobj
+2877 0 obj
+[786.1 829.2 741.7 712.5 851.4 813.9 405.6 566.7 843.1 683.3 988.9 813.9 844.4 741.7 844.4 800 611.1 786.1 813.9 813.9 1105.5 813.9 813.9 669.4 319.4 552.8 319.4 552.8 319.4 319.4 613.3 580 591.1 624.4 557.8 535.6 641.1 613.3 302.2 424.4 635.6 513.3 746.7 613.3 635.6 557.8 635.6 602.2 457.8 591.1 613.3 613.3 835.6 613.3 613.3]
+endobj
+2878 0 obj
+[647.8 600.1 519.3 476.1 519.8 588.6 544.1 422.8 668.8 677.6 694.6 572.8 519.8 668 592.7 662 526.8 632.9 686.9 713.8 756 719.7 539.7 689.9 950 592.7 439.2 751.4 1138.9 1138.9 1138.9 1138.9 339.3 339.3 585.3 585.3 585.3 585.3 585.3 585.3 585.3 585.3 585.3 585.3 585.3 585.3 339.3 339.3 892.9 585.3 892.9 585.3 610.1 859.1 863.2 819.4 934.1 838.7 724.5 889.4 935.6 506.3 632 959.9 783.7 1089.4 904.9 868.9 727.3 899.7 860.6 701.5 674.8 778.2 674.6 1074.4 936.9 671.5 778.4 462.3 462.3 462.3 1138.9 1138.9 478.2 619.7 502.4 510.5 594.7 542 557.1 557.3 668.8 404.2 472.7 607.3 361.3 1013.7 706.2 563.9 588.9 523.6 530.4 539.2 431.6 675.4 571.4 826.4 647.8 579.4]
+endobj
+2879 0 obj
+[472.2 472.2 472.2 472.2 583.3 583.3 472.2 472.2 333.3 555.6 577.8 577.8 597.2 597.2 736.1 736.1 527.8 527.8 583.3 583.3 583.3 583.3 750 750 750 750 1044.4 1044.4 791.7 791.7 583.3 583.3 638.9 638.9 638.9 638.9 805.6 805.6 805.6 805.6 1277.8 1277.8 811.1 811.1 875 875 666.7 666.7 666.7 666.7 666.7 666.7 888.9 888.9 888.9 888.9 888.9 888.9 888.9 666.7 875 875 875 875 611.1 611.1 833.3 1111.1 472.2 555.6 1111.1 1511.1 1111.1 1511.1 1111.1 1511.1 1055.6 944.5 472.2 833.3 833.3 833.3 833.3 833.3 1444.5 1277.8 555.6 1111.1 1111.1 1111.1 1111.1 1111.1 944.5 1277.8 555.6 1000 1444.5 555.6 1000 1444.5 472.2 472.2 527.8 527.8]
+endobj
+2880 0 obj
+[525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525 525]
+endobj
+2881 0 obj
+[777.8 277.8 777.8 500 777.8 500 777.8 777.8 777.8 777.8 777.8 777.8 777.8 1000 500 500 777.8 777.8 777.8 777.8 777.8 777.8 777.8 777.8 777.8 777.8 777.8 777.8 1000 1000 777.8 777.8 1000 1000 500 500 1000 1000 1000 777.8 1000 1000 611.1 611.1 1000 1000 1000 777.8 275 1000 666.7 666.7 888.9 888.9 0 0 555.6 555.6 666.7 500 722.2 722.2 777.8 777.8 611.1 798.5 656.8 526.5 771.4 527.8 718.7 594.9 844.5 544.5 677.8 762 689.7 1200.9 820.5 796.1 695.6 816.7 847.5 605.6 544.6 625.8 612.8 987.8 713.3 668.3 724.7 666.7 666.7 666.7 666.7 666.7 611.1 611.1 444.4 444.4 444.4 444.4 500 500 388.9 388.9 277.8]
+endobj
+2882 0 obj
+[639.7 565.6 517.7 444.4 405.9 437.5 496.5 469.4 353.9 576.2 583.3 602.6 494 437.5 570 517 571.4 437.2 540.3 595.8 625.7 651.4 622.5 466.3 591.4 828.1 517 362.8 654.2 1000 1000 1000 1000 277.8 277.8 500 500 500 500 500 500 500 500 500 500 500 500 277.8 277.8 777.8 500 777.8 500 530.9 750 758.5 714.7 827.9 738.2 643.1 786.3 831.3 439.6 554.5 849.3 680.6 970.1 803.5 762.8 642 790.6 759.3 613.2 584.4 682.8 583.3 944.4 828.5 580.6 682.6 388.9 388.9 388.9 1000 1000 416.7 528.6 429.2 432.8 520.5 465.6 489.6 477 576.2 344.5 411.8 520.6 298.4 878 600.2 484.7 503.1 446.4 451.2 468.8 361.1 572.5 484.7 715.9 571.5 490.3]
+endobj
+2883 0 obj
+[562.2 587.8 881.7 894.4 306.7 332.2 511.1 511.1 511.1 511.1 511.1 831.3 460 536.7 715.6 715.6 511.1 882.8 985 766.7 255.6 306.7 514.4 817.8 769.1 817.8 766.7 306.7 408.9 408.9 511.1 766.7 306.7 357.8 306.7 511.1 511.1 511.1 511.1 511.1 511.1 511.1 511.1 511.1 511.1 511.1 306.7 306.7 306.7 766.7 511.1 511.1 766.7 743.3 703.9 715.6 755 678.3 652.8 773.6 743.3 385.6 525 768.9 627.2 896.7 743.3 766.7 678.3 766.7 729.4 562.2 715.6 743.3 743.3 998.9 743.3 743.3 613.3 306.7 514.4 306.7 511.1 306.7 306.7 511.1 460 460 511.1 460 306.7 460 511.1 306.7 306.7 460 255.6 817.8 562.2 511.1 511.1 460 421.7 408.9 332.2 536.7 460 664.4 463.9 485.6 408.9 511.1 1022.2]
+endobj
+2884 0 obj
+[333.3 277.8 500 500 500 500 500 500 500 500 500 500 500 277.8 277.8 277.8 777.8 472.2 472.2 777.8 750 708.3 722.2 763.9 680.6 652.8 784.7 750 361.1 513.9 777.8 625 916.7 750 777.8 680.6 777.8 736.1 555.6 722.2 750 750 1027.8 750 750]
+endobj
+2885 0 obj
+[833.3 777.8 694.4 666.7 750 722.2 777.8 722.2 777.8 722.2 583.3 555.6 555.6 833.3 833.3 277.8 305.6 500 500 500 500 500 750 444.4 500 722.2 777.8 500 902.8 1013.9 777.8 277.8 277.8 500 833.3 500 833.3 777.8 277.8 388.9 388.9 500 777.8 277.8 333.3 277.8 500 500 500 500 500 500 500 500 500 500 500 277.8 277.8 277.8 777.8 472.2 472.2 777.8 750 708.3 722.2 763.9 680.6 652.8 784.7 750 361.1 513.9 777.8 625 916.7 750 777.8 680.6 777.8 736.1 555.6 722.2 750 750 1027.8 750 750 611.1 277.8 500 277.8 500 277.8 277.8 500 555.6 444.4 555.6 444.4 305.6 500 555.6 277.8 305.6 527.8 277.8 833.3 555.6 500 555.6 527.8 391.7 394.4 388.9 555.6 527.8 722.2 527.8 527.8 444.4 500 1000]
+endobj
+2886 0 obj
+[638.9 638.9 958.3 958.3 319.4 351.4 575 575 575 575 575 869.4 511.1 597.2 830.6 894.4 575 1041.7 1169.4 894.4 319.4 350 602.8 958.3 575 958.3 894.4 319.4 447.2 447.2 575 894.4 319.4 383.3 319.4 575 575 575 575 575 575 575 575 575 575 575 319.4 319.4 350 894.4 543.1 543.1 894.4 869.4 818.1 830.6 881.9 755.6 723.6 904.2 900 436.1 594.4 901.4 691.7 1091.7 900 863.9 786.1 863.9 862.5 638.9 800 884.7 869.4 1188.9 869.4 869.4 702.8 319.4 602.8 319.4 575 319.4 319.4 559 638.9 511.1 638.9 527.1 351.4 575 638.9 319.4 351.4 606.9 319.4 958.3 638.9 575 638.9 606.9 473.6 453.6 447.2 638.9 606.9 830.6 606.9 606.9 511.1 575]
+endobj
+2887 0 obj
+[656.2 625 625 937.5 937.5 312.5 343.7 562.5 562.5 562.5 562.5 562.5 849.5 500 574.1 812.5 875 562.5 1018.5 1143.5 875 312.5 342.6 581 937.5 562.5 937.5 875 312.5 437.5 437.5 562.5 875 312.5 375 312.5 562.5 562.5 562.5 562.5 562.5 562.5 562.5 562.5 562.5 562.5 562.5 312.5 312.5 342.6 875 531.2 531.2 875 849.5 799.8 812.5 862.3 738.4 707.2 884.3 879.6 419 581 880.8 675.9 1067.1 879.6 844.9 768.5 844.9 839.1 625 782.4 864.6 849.5 1162 849.5 849.5 687.5 312.5 581 312.5 562.5 312.5 312.5 546.9 625 500 625 513.3 343.7 562.5 625 312.5 343.7 593.7 312.5 937.5 625 562.5 625 593.7 459.5 443.8 437.5 625 593.7 812.5 593.7 593.7 500]
+endobj
+2888 0 obj
+[272 326.4 272 489.6 489.6 489.6 489.6 489.6 489.6 489.6 489.6 489.6 489.6 489.6 272 272 272 761.6 462.4 462.4 761.6 734 693.4 707.2 747.8 666.2 639 768.3 734 353.2 503 761.2 611.8 897.2 734 761.6 666.2 761.6 720.6 544 707.2 734 734 1006 734 734 598.4 272 489.6 272 489.6 272 272 489.6 544 435.2 544 435.2 299.2 489.6 544 272 299.2 516.8 272 816 544 489.6 544 516.8 380.8 386.2 380.8 544]
+endobj
+2889 0 obj
+[499.3 499.3 748.9 748.9 249.6 275.8 458.6 458.6 458.6 458.6 458.6 693.3 406.4 458.6 667.6 719.8 458.6 837.2 941.7 719.8 249.6 249.6 458.6 772.1 458.6 772.1 719.8 249.6 354.1 354.1 458.6 719.8 249.6 301.9 249.6 458.6 458.6 458.6 458.6 458.6 458.6 458.6 458.6 458.6 458.6 458.6 249.6 249.6 249.6 719.8 432.5 432.5 719.8 693.3 654.3 667.6 706.6 628.2 602.1 726.3 693.3 327.6 471.5 719.4 576 850 693.3 719.8 628.2 719.8 680.5 510.9 667.6 693.3 693.3 954.5 693.3 693.3 563.1 249.6 458.6 249.6 458.6 249.6 249.6 458.6 510.9 406.4 510.9 406.4 275.8 458.6 510.9 249.6 275.8 484.7 249.6 772.1 510.9 458.6 510.9 484.7 354.1 359.4 354.1]
+endobj
+2890 0 obj <<
+/Length1 1737
+/Length2 12625
+/Length3 0
+/Length 13580     
+/Filter /FlateDecode
+>>
+stream
+xÚ­\96UX\Ý\96®q'¸\ 5+ÜÝÝÝ]\ 2\ 4+Ü5\10Ü\82»Cp\bînÁÝÝ]\83{ðSÿÞÝ;éîÛóT]¬w\ eûÆ\98s®*
+\12e5\ 6\11S{c ¤½\9d\v\ 3\v#\v/@LAT\9b\85\19ÀÂÈÌ,\8a@A!æ\ 44r±´·\137r\ 1ò\ 2XxxX\ 1\92@cÐ\ 3èËËÁÎËÌ\89@\ 1\10³wðp²4·p\ 1P\8bÑüãÄ\ 5\10±\ 5:Y\9a\18Ù\ 1\14\8c\,\80¶ \1c&F6\05{\13\8b\a#@ÄÆ\ 6 úO\843@\15è\ftr\ 3\9a2"°°\0L-M\\0Æ@sK;\ 4¦\7f4ÉØ\99Ù\ 3¸þ½lêêðß&7 \933H\14\80ú_2i\0 \91¦öv6\1e\0\19\ 2\93¢=¨\1a\10¤åÿ\87¬ÿ\9d\ÒÕÆFÑÈö\9fôÿ\9aÔÿ±\eÙZÚxü\97\87½­\83«\vР  `o
+t²ûß®ZÀ\7f\8b\13µ·ù?ed\\8cl,MDìÌm\80\0æ\7f/Y:KZ~\ 1\9a*[º\98X\0Ì\8cl\9c\81ÿZ\aÚ\99þo         ÁýK\0\93®ª\94\8c¶.Ý\7fíé¿\8cÊF\96v.ê\1e\ eÿIû\8f÷¿\98å\ f\83¦ãdù\ 5ð\89\194^\16\90#èóßOúÿ«\98\84\9d\89½©¥\9d9\80\95\83\13`äädä\81\0:= â\0|e\ 1\99\ 2¿\0\80_@\8a\99\18íì]@!\0ÐH¼\ 1föN\bÿl('\a\80\9f¥\7f\13'\80\ fq\ 1\98Äþ\107\80\ fñ\0\98$þC\Ì\0&É?Ä\ 2`\92úC¬\0&é?Ä\ 6`\92ùCì\0&Ù?\ 4Ò"÷\87@Zäÿ\10H\8bÂ\1f\ 2iQüC -Jÿ!n\90\16å?\ 4Ò¢ò\87@ZTÿ\10H\8bÚ\1f\ 2iQÿC -\1a\7f\b¤Eó\ f\81´hý!\90\16í?\ 4Ò¢ó\1fâ\ 1iÑýC 8£?\ 4\8a3þC 8\93ÿ\10\aÈfbo\ 3ºaÿ½ÂÂ\fJeú\17\82ú\ 2þñ\aéû÷aþ\8f\ 3+¨9ÐÑ4r¶ø+\bÔ¾Ù\1f\ 45lffùW\b\88ÿ \aÛ?èöW\91\7fìö®N\7få\ 3¹\98ÿ\85 \84\7fª±\83&háá`\ 1ü»        ÐÚ_\ 5\99A\ 3±þ\vA]Ûü\85 \91ØþAÐ\ 5\93\8a\ 3\14jgi\aüË\ e\9a\88ý\9fê `ûÿa\ 6©wøc\ 6%s0r\ 2ÚÙ\0Íþ\f\8d\9då¿V\9dþç,ÿ\99Ô_m³\80ºpþ£ä\1f\ 2ºýÕ&\aÈÝ\19t}ÿ\ 4\80¶çO:\ eP\15\17\v'à_\93\ 5©qq·ÿ+\0Ô\9dë_\b\1a\8cÛ_\bêÍý¯m\ 3EÿU\8c\15\94ÞãOK PO Ó¿sÿß×\94¨¨ý\97¯\fl ÓÄÀ
+R\ 1\ eàaçôþ\1f\9e&®N \99¸üëG\0t¤þ\9bÍ,AïF ð\vÐ\ 4ayÁÞ\84/È*¥1¤ÄG"\7fª\14\9a\16\Ô¼)V±®k¶\ 31p)\ eܦhDÎ\91v£Vû©,\1dãÃ\ 1ô\ 1±û\v¾sx»\97ʸä\85¿clêüÛ\81\9báAºg\v¾öuº\82Ǿ\ 3éCà    J[ãÜí)\a¸ÒÌÆhI¢NAÿ÷Ë\81\93\ejqõCØ5\12°îOnõÝ\19A\9c\92é6\1aß\82k)ÙHTQS\1dKBÙ¿­»£&ÆC­O\ 6úX}\83k¦[½²owE\7fÊ\87ËIxû\föh\ 2\13\11áü1tÑ\ 5\11\f_(À»e³\9e\8b\81\87£'d7ë°<»±¤aB\81©\12¿k_w\8bîERì\8b{˽\1eÙnk=ÑÓ®øúp\19>ÿh\97Q@ì\92À æã|çÛ(.CõnZʵé\1c\\a¬=°ð\83OâðPTPzí1\0z2\1f»|<î]U¶Âɸ\ 6R¥ÿCëTLý¸ÆÌ®åý\11ç\10½\ e6Ìöþ Ð\86PþÈ\8cÓ\80\97ÍO±Fû½fsïªóÜøPÑ(Ø·\9a[0üR\vÏ
+ÛÕ=VGE\8fÌ'\99¥Ü\ê\eÆ\bjhòv?\91«\ 3Å     aµ¾l\84SËt×f*0Æì¤\0Ûº{1¶\98`?4°h¶ð°X@2\89Û¤Y\11\ 5\94mÜPä·\8d\83±M¥F\954\94\ f!Ó.ðW$î\ 2\16î\9b\9bµ\96ù]\9eEfPx\1d(\1f\ 5òX"rC\10ê\14©[\a\8e\18V  Äö\ 1¼Ã\9bñîð1\8c¢]\ f\1d\90\ 3Ë\88Æß\8fÝ\99É?EG\87\90*§Âfjäû(êTÒfq6²gçueÔÜÝ\8a *^\f\1a\b¥2\9fÀ\19øØwR\9a\95ëòD2\SÃÐNf\8fhjò `\ 5zɦ\9dr  /9O^0\92G\88\8f`H&ü\bÐQ\98²¤SøI\8cÝ7~Z\14ß÷Aüµó\ 1
+\15\r·]MëÓ5\15Ëá\83£\a{\85£n/\9f>§GSа°äÁ8?ÂÒ\87é{MÊ\1aE¶É\15»Ú\0ý>ñ'cx£O]þÎï¸Ð\1d/#rhwÈÖs\81¯!<\8fGSä\9f$\ 5\809Wô\94CÅç4¨®nɽW,âK¿4eü­*\8cJdz\7f\90\955\ 4§A'\#p\8c[û äT\ 4«Lì\11\eÅ+ôZIÊ¢æÖȳ==C\8502\ fØà÷k\ 2ma\97ù"\91uìP³vjJë=\1e\9eòU=*ê-\8aÈ;)ç©~Þ\9dm\99ëDãG|Á\8d)h\7fFT±d\80­îlK@²\87O©çÚéÇÿfmTh\92gÎÃÚ\ 3¥Íö\94¯_K»\81\8eJÆ1k}><_½5¦b$\ 4mTÝ\fÑF\84\86v¬3袩¦bEcg\8e\134ô¸e\1dF-Ùʶ\e^)9¿.í£Y\ 2æ1â\9d\eEqcA8\85A ¹­0~\87þ\82¹\î,2\ fe\93|\1c\89Óë{\17D0G     \9fçq´;g\19\13o\0é\13°M\a\81\8fèÆ\91\\ 34P+\13=Ù«\95\17¢\9du¼BÌy$­ÔâkÃ\16\v»îÛ©ÉU\ 3k\83\8fv¿,Ã\8eC(\89y3Ü+\1e\84
+3f     MÆ|Q)ç½\92ñY¾å\8búñD¶¡¿\84õ|ý\81ðû\ e©\90|û:\98E¨Bì$\17ÁG*ø[9\r\9b\9a\1f^ª×ȯ¦\8b\ f\b¬\11\91\ 2F°¸\16\ 5\13¼ù°\8eàuù6\1at9×\ e¿vLb.Ý`\90\94¸4\10\12å#\92êOñÓ\9dýv\8b\8cá¸ió[Íñ\89B\8f+ÔÇâ\1aQVâàg\11UHfõ¥4T±\95á\13¾TN:FeªîNÞº j       'VÄ2\86YD\ 1ÐÓ\8dS0ö\96ÌC>%k\eÇ~á.R9d\8d\87Ë°ßüÙÓ5<jÕ:\8d\1f¸Ã\1cAãýãö\88;\9dxU\e3\11W0Z\19UºGx£à\18|%q\17\99È_\93F\1d\12ZÖo(6U¿p¿öV`ï\9cg¦YÔ\aü\80\880S\81\16\1f]ðÞ\ 2á«\7f\98ïãDXá\0>þ¼c{#ó¹BI\1c¹$}\80çAÒåÐ\1dgá8\8a\9cN`\8eú5ÄÚAk\1eðE 4i×Á¢Ècîi\9a}o®\96\94)@mr´Éx\17\16\9b\1cÿظøº}¶O\ 1_\99ìy­\8a¸ú´\8b\81Ï1Fä\90øù\1a\eLõ÷ó¶
+\ 3\1d\190£P\11 Z§\18t\92_^½\9f8Á7KÐú\v½¬¡©®¡¹A\1e\9bj\81_\7f\98ü\85ðw¨4¤¹­Ç
\ e\8aÏ\9bÚ\ ff\94¸É}Þ\88ðy\12`·Mø  C\ fç\f\ eW«å`2¿Q_\88­YÅ&\94\97\ e\ 6\84\97ºé÷\147¥´±\1c-\11\8ceÉêï\93̬±\9f0\89§xìÄ\vÑ1سì\89â(òõJ!òJ[\88\99(ÒÑ\7f\10\1f\97ïpsóö'§n\ 5'\ eñ=      ¹ó\99q´¬*[hîîÁ)­ÛQÌ9Cö]àqó\ fE\94\ 6÷¤ L\8e\v\14ù;[]Q±Nh#"\ 1/a¿g\rËñiB\ 6øZÚ\9fI\8fÆÕ¶Knh\99\vÖæ3Ò"£x"Ðú\fzN!¯\vð\eiúsîo\15÷xW\94¦ÔL8ÖÁ©µÁúÊ­\91\\ 1l:b\80+îRÊn\86=بã/à!\97Ϫ^\15K·t?ok(Gà\7fépCÏ\15\8eçrÔ()ANéIm­8½w:úu!¥ÿ¼u\91\97T°}ÙM\91yÈ)Æ\16#2
+\15\98Þº¤|á\9d:úá-\a­þaEË\97K§DxFÐY\82 Ù\1d\93Ychl#\9a9~°\8dý¥Ð*\9ac\97ã\f\86¯×öJR \ 3\a½"C»#ãÃõ&7kèÉ3?Ôð®ãS-8¾"°c \14(\98JjJMCPw^Lw:®\1f'ìòamLòæw\92)mú$ªbð|\88E\0K\83Ý¥Z!±RG¨Ä\1d\8dN]V|[a\1fIÀìb¶±¾ßî\ 6²|    \8e\ f\ 2Ë~½G\ 6\95,q\r\f\93Éñ÷E\1c\ f\12h\8fúv\8eZÂÈ\95ê/
+°_
+ÈåË\92.\98^Øf#È=Ä\væfN^¼Ç­«\96´,""\19ø\ 2e¡ø\ 3Í6Ó\94æ_g\ fØÍ #¡»tH\9c\eêQ\95\85Q_¨í\87IªyZÃÌ\9b:üH¼\ 3°öB\95öì®ìèmK¦O4´Ê`\96¾S£\8a¢)"\eËswe\86ô°\1ccFó¶¥\9cÞZÉ\13ä¥\ 4\91¶ c}\89çõn3ÆE4\8f'Ï\øÅ\v\15Kv©*Ù\b«7\1e:gZ.\8b-¨-\80ÑàP\e2ØS§Í>3Á9¡ñ!ü¨\89Ýâ£ê¯\rói¬!¬¦\12,3$\9dÖ\14`0v\1c²×sòÁÞGú¾\14\1a¤ð\99\16ª{\9d´-\95\10\1e¥T0\81\83±²Ú\84@Át4}nt´»µl\82ô\1f¬\ 4g\a\1d\8fI#ð
+~´ÉÚ\98;7q\16V°(\8a«\ 4â9±{ù\ f²Ò\8bI\e\85Ò*è¯ô×`Ó&Å~E\13`M³~)Ô­\1f\89Rå×6ÆÖý|\fÇzV+\9c\aP\1aÌØyÂ.LÃ\1dÜÉ\ 6ÛKFs\11\8f7\90Í\94Ï\91¸µÖ½~çûÙ\8d@<·
+ųðó 8%\85¬      AõI\eº_\10ïùv«ÌtØÜç$¡à^÷×;Z¹\80©ª×¼2\98¼o3½\88Ú¸&zK;´ã[Ì\ 5È\93-Ùç\89àKª\9f\9a\12\80\97¨\9cª\84`\17\19Ū÷\15Ä8Ê%\15&Øt_áL=è=V\87=[z\14\15æcÀæZÆDDh[ÆZ\84ç)\84)/+\87D\80÷[\8aÏüµ\15·\98\rÓÑ|Øãc|ÒA[\86\\ 2\94\89ë\9fû\1eÔ\98~õãsº\8cÁ\9a\8c\99\1f£n\17¹ìW\ró\1f_\1fÐ\88\9eõ(F\-[ Ø®ýL٨ϭ,?`»\83¥ë# C1\ 4\b\19\8c»\11\°T:_õ¾ØWõDMåbÚ\93}fÇÖ\9fûT,µwì¤`\ 1VÉX\11\95No=\1dÝZä}\ 5Eck¨\13(s\12&\e¨\1dÜ>äîø¹Î¹â*Ë;i¥£ë@³C\90à\84ª«Â\19\agúAö~\89\8cí±W©ø+øPx -¿¹Í@È%ÇCG\91ËÅõnl\12µ÷R\92t\8c±uKj\12âê<kÃ-ò\84³ÍÜjVü\etL\9dÛ \ 5î`æ¼9Ì,\ 4·Û\1e\ 2\84\0A±c\18«`\aúd>2/.ɹ\89b\10ÂV§ïÃ`ÛK\91e), ft© /8\ 5\12\87ª\90"¸T¥\9d\e\rÙ6\16ÕÈD\1c\1d\7f\8d¤\10ñÍ&8â¼\82¤q¹»)nEV=c  (Æ\8d\90Á°yòKëÊ\9dPa¨)=y8Á\9b\15\83L#Ó+å-ÇZÎ,ç1\fQ\ f\18\93\94#mï¾Så
+\ 1fल_\87g1\8aÃ*¿·\12Æ\81µø»qw\\97Æ\15sãÞ\8eþz\9c\9c\10\e¹_óè\91\\10 À\12ëÿUcY\88²ë\vËÕ\178Áï\vñ°""mÇõºt\13Ú°4¨Ã4õ\ 6\9dMj{ðRÑF\91æJtq<8\ 2Þiö¢úó\vl\99̸\pC]sõ\85ÊU\9bP\80\13ɱavê樂$á\r·\88ÉÄ\ 2¬ÎeB\92\17`\ 5\98\ 2GÌo6çæÎ.ht\12
+}? Ùá÷sm\7fàè\9b\1alEïÙ\f\80Ýt«+KwU`\f;Lº×¼{\84Ë\+7Þ}[uKýT(°LN\86p,/
+,\90\98áUWq¨¢Ô\18 ÁDÆli\99yeOÛæ\1d'\ 1k\9aCè9\89é\v$N6ly=*\ 2.\1aD/\9b®ÔO=á\1e´¤\b[³c[į¡ãµë\10Æõ\15ûa\ 4\r\ 5\;öÙ?þô¦tÁ}\99\1c\99d¼Û\89ÃW\94\8d\9d[ÒdÕ\89¸¢Õ3v+ùýj
+N\13vÈî_\1c`íð\90üi\88uiÔ\98 h++¡*ùLwß\8bLHÖþÔ(È+·)É´kfe©¿­}³Ýb9\1a\ fÅÕ9°X1º#\89¤©Ê°ð\85}º5Ñïµb6ÒU@\92\89íÝ\ 5\87òIU¥ÒzF¯\14\99\91kt\8bLë7#âH\95åC|\8c}°Æ»q½«\10¿ò¦KºËH\8f\80XGÌ8Wy?\0U6\16÷T\8b\96Y8eÄ\ 4XCåÇõQX\89Ø]=÷&ß\v\9e\a\16\ e\17Zv|´ª´Ù\9c#D\9ceÍÐï\89¥Á\rÌ\8c°\92óÓ×83ö¡cF¶\15g´w¸¢\ 1ß\8b\155ÍW\r\1f\ 4ùÐX,mt\84\ 6A9²Ó½\83fZ\92ßÐÀÐJ¾\9d%\9f\½õO®ï¶»\14|¡-Æ\9c\82\84As\95ç¸\8a\1a\9f¾=þ"\ 4þ\báß·?V\eúæd\g}Í\86\bëD\8cX/º+@Â\9cÂ\ 6G\14RW¸z,+\8f
\9fù + µkY,ÕB6Û\8d(\9f{qû£¼\b'!PKj\99ñ\vØÇÛb*@çöw\ e\rñ¼¯ê\11\99S\9fÍRÈ=±Å\8a>\aÃø»Ä\0°BÏÓâ%Þ\f¹òò5ªR4,O\90\1f»\7fj\1e\8d-T\16Ã\ 4\f@\10|ø)÷%>´pR)[FWª³J\8a
+6 À\ 5\15Ë/        qøë\r
+±F\8c},I\ 2ïRsD>Ó\1evûRÃ\99ï»D¡¾JLÞéA\95©`êb\19ñ\91\99\19ª53µUåKÕ\97h\87À%\92Ê2\98W´ÄÆýÉz\17\91M4\ 3h\7f#\83ë«×¨çv\ 15¬ÝlsÝi\ 5ç£\9bÆ6Ò\8b¾9?\ 6\13!-\88Ö-k!ðø(g\19p'\ evÌLO\1cç\96\8a.òÒ1"&f«UµÉh²\91ãǪÍåù®\1aâLE\97`NÒ%3\17UpòD/Hf;Ç\8asK\1eíwE\86\a;ð²p-\fòRÏ\15µºÈù¾·qÅ\ eÿ,\1aú8\9e¶ïà\ 5\vñ5\17áÊ\9b\95á=\ 5ôÈÎ"B'«¤\18Y\1a»×sÂ:\9fÐ&\90f\17\7f\14Ð{    óoÊCÏÿV©$#\9f\19:W\1c¯E_\97¢1Fu=ÄxUôm\1f\9c¤.\90\9f­~\96#×ë\9fQ\93\85q\8b\95B\ 6ªDÞ1f\87'ºv\bbä':bgï\1cØ),\18Ì)­eÙî¼\1ea¾þ´\ÔipÕµLþ\9d\ e¿ë\89±j\88\89v1QÒ\10~¡Y(Ð,$ÌäísÝ\vðå4"6\92ÆiéKOoÌ ÕÐ\fw÷1\88cÜM?G\8amú!"±»\96ì¬#Û~'ðX~îë\90&v\8f\fÐ&\87{x\v^\97(z\eÝÏå\87Qõ!Ü]Ò'\9e&\86\eþxâûÙß!¥!ÆF,       F³æ\ e8Å¿×k'\96\15}\7fÏÙ,«\89´)é´M;\96A"4¿Né        Ó\96>9Q|pÅêº\17&\19_ø&^¹\18\83\17\169HÏfà§\1fîÈ\0®0)\10|n\86\;k+\97\9d@\\95táøY\8fÕ,Ì0\16\87È\8d=`Ðs÷4®AÎWöQ\vA¿5Óã\8cò\14!ä]\82pÀöF\a¦H\8a\0F(8¢4X\9fr\r©êd¢Øç\9a0±üxsû\10>\8b©\85¾ö£ü~\94ðwQ\91OmioÌÙ\ f缶"BwJ\a\8c¼ôô\1dg®PNÛÁ7Q\15;~Q\983yùbºóØ>.V\9fCH»vÞN&Ur¬\ e\15ÌB"£ÈÇ\16Ïn\87\99\94\91ö\¾\98¹!+"ÒMÊlú\9a3©ÞGe(ú) 7´\ 6³        þ\94a\99ï\82pGà\7fÉÉ Á\8b\17ô³)\19@\96nþf³\15ûÁY\15ß\bi\94¿bÞ\87ñ\1c\96Q<H¸p}Ë\1cÚBp÷\9ce¿ïÑú\17<*þé\89\1\95\f  ã§\bÁS\9bp\8aò&jܼ4
\88\18ê\8cz;z»\1c\86x~»hnß!\v±k\82׫\94
+,Ô#Ïý+?\15B#B$}\83.\r­/Kµ¿dÝò\ 5\ 4ãâ²Ñ\83Ìëy1U   \11\ f!¶0âÍ\95\7f¢\97\15.lh\17´\9cÊ?TñiÕË\86C]ê\9fî°Û\85t\17\18ý¶8Ï\91¥\fJF\88&\15§\14+ü¾ÃãÇåÕ]d¸jI×ß\9dÛDV\a\0¿\93\87+ÛSC3\97Ci÷yü\99\1abìÆf¾6ÇÔr!\9eÏGù\v<\94\19b\98@\9bl\83Qöóñ1$\94^\1d©L×o:\98Á¯\97\14`±3T\1fq²Ï?KøP×L@\ e\8edVÏp«q˦qò> ^Q¢±ïõ\89k_qO\99Ð>¢\8dµt\9dI¾`ð\ 6YÝÂuIHCÝ\rIÚï\r\15Á«        ßu¦m    ¦\ fýî(>î!¬-V[S¦§*ÎAû\9dKJÄ"Íös\ 3ýa\9d\f\ 6÷ÆQ-õ*ERÂùʳL\93z\94\98z[×T¡>WBg´¿0hÑM8\94}Èz!+\8a$â·ù/\95\8e\8a\11FE\9b\9a
+Ý¢ ô(ÜÛ¶Æ\8d
+p$\19j\eIÅX(ÂZðLèuÝ\fü
+øÒ2.¬qß\1e5Ê;\87c\7f\92\85&â:÷\8e\19Å\ e-\1fI¾}¢~Î\ e)\8fÀJ\~µ\85m_\16\18\9d\85»\92\9a:æ:©KÂw»Ú\ f\ fíZ\90ÆÌç¦'!\92\96ë!\9ans=\194º!Bd\9e\14\12\8eË\13tɪP!%\17\8bÕ"\84ö\1a\19Ã\ fD\96Ê8ß%ÛX>2\8d|uÓ\89mÂv2\8b·ôã,\1eKÚÚ\1aR\ e6ëQP×CýÀå6çÙ\e§¯ÂAñ¼\16\7fHoÍ\8dz©`\9dÖ\v,\9dMM¦øñCïc"½ærÏý®ñ\95ä­°Á´\1d+ªiü\8c;\e\ 2B]\9eYiãCR6\8e¢ýõV¬qÔc{\17§|Êò\81¬µ­zQôMKA\1e\82Á\8a\ 6+`Öî\8a¹MRçìí\12\98Xõz;\1c\vqQ¾\1f\1aü\10\19\8dͶE(ä\88ÿ¥¨á\ 6Ïi©X§húêhªàN Gÿ\8cêÑ¡¼cüm­Ù\b2\9aÐð\üh
+ó=\8d,c{ÉsÙg\a\86\88­\96¸oÝ3\84¿Y\15\83É\9b¹ï\90zLm\9e\1eÒÊëìÌ{¯¦\8bÌÇ­\97\84\18>\85W\86\19\97©{ZdÂ\8a\94\9eBY:¼ ¯éG ÙTyï\14¾N{\95\ 6öH
+soRY)ï|\ 3\10\9a`ÁV?\99¶Âu'çyTô%÷R\9e\0fv~\b\ e­c\a\ fFPê³ÿ\99YIÁ¥Qåã9ør\bT¦L¢¸\(Ý\ 6lûÐÞ»\1f7\9bÎl\16à\15.êîóijG\1a¸\96\ f\94ÍS\93\89\ 4ÜGD{\92Í\82\18\93\8e\18#YË\9f'È´J¹¾°\8d§±ùÅ\­\v@\bb½ÂVvÖOgY\8fTOä\90\84ÇFÝ\1eòpæ·ø(¢t\v\88A\ 2ñg\86£<\1f\90ߣÖS\80£¾zÔð        \1fr?&¼'\90<èb\93'»S\904u       \14Ø#9ð\8fÄ[\f'aÈ\1a\1d\ 5uwZ\93|·&ÿ\18ú¶\e<Ø£\99RSF%Ojç3ÅÎ&¡þ\13­ÔÉ2\ 2,^~\99Ë/È$o#\12Gô®¤\16A^ÙÃ\93*\ fNëB¾ÖÖf\96\1eî\9dè\81¾cÕ\93\83üX1üzÇ\9d\13y{"]\Æí\86ê\8es\8b\9ebP\8a;
+öy\19ÅÍù)iV\ 4U\12J\9bô\9b Z8µà=¿ü\ 5Ìç\11\9dBnJ3íZjH¹_¯¦N\8eë².\14
+y>ÃêXOk~\8d\89ÄÕæxÒ\ 6C¾©ç®&°¥\98\ 4<lïòº\rJ`\99·çge\9a\84àun\8aü,åCÅã?I±&\1dý¦æ\1d\11\85>\80@y âè¦F\8b\ 2\96\9d\121ù¬×o!\16Vd\13º#p;o;bnÒ)áüÓZò­V\82V\1dË9741ÖJcß\®ÿM\83&\9b\99¢>      :Æs\ 5\1c®5°{Ð!|~\17¥½{Ù\93:I\8b|\10\10\9eäò¦lq\9f,h\7f¡ú¦\ fa½ÑÐsln\1d\8c\97\7fÇ\1e\96\87Z\11    n\92À\9eÊm\18Î\1fÑ\15Í}g]è!À]\84\ f\17'\16¢D\8a\8f\97ÌäØéÏQ$Ä\8a.)\10_\84\96¡"0\aæbÙÙ*J\8f\89\b\ fs+\1f\ 5ÎeÝQ\14\88\98\9c@®<`-n¨¾\1f­Ö\1aýâi\11ÚÊ%GÂF7\1d\ 6\9eÜHQ+µw\15`â£*Ï®A/%|#-~\rýy¡K\90ï\1aA9Ûëѽ\9bÄx\88#àaÒ¿uý\8eÁF\0i\f0ÌÆÅ\19ï¾ÆËJ\93í\9c¿zBáÝf»\9aZÏì\13Wg2\94mOÝÙg#\9bI\88MT£|ô¸rkd|]Vn,&W\90ý­µU"vi ì³{mNÎMM\18ùË­Þ´|\95]áʸ\90$]×Rù÷B\ 6êmn^³#´kHZ*\9dÚ_Ê>~­Äk\98Ý\97¸]4?»Q\ fO\13\e¬T³_ë\9d¥"fbÄ\rcOXK\81GÏ:;\87àÑ\1etö#04)6ÂÂ\8dÚq\14\10©a\8eç\ ey\1cÂá¿b\84\1a:\ 5\r.o\ 3à3e\87ô¥Ñ\91&c\8dÊ\r\92ùï\ 3¾pÁ\9e¸ôîá\òZ]\9cJ\10ü¸Y¥e\8f+¿oùÖ\94»\ 2\f\r\9dÇ\80\18v\\fOrO\97¢\9aqb\8b^6\88Ò$\95V5C\ 5M+uî¾\8b\8eB\83èX\7f\1cÎñ\9a5\8da¥ßÍ%¶¢êv\1dý\94pº/ëÄ\9bÏgásÕ\8f«\9c$õ\\8cj\1a\94 RÑ\ 1ÝÂ\86\93\8c\1cN¸0#ÏûÉ\18ÿ\9c{-Æ~Ô\ fÒ¡G\86V\90N¸¿s%\7f骿ñwwùO\ 2÷:ò\ì#\ 2\ 4ÜÅ\9fdq¨å\f½5»¦\vD2Mô\8c\9aÓ¡\8dr5\v\b\e±½1\1eÍ\ 4Ký¤¿¡k\8cã»HV\14î'\ 2M\ 1®1\87\ 1ºÊ\9dô¤¿s®`¼ 1÷«R®m\97\ føzð\ fâÛ\0$.\12'3É\ fc\b\ 4UÝÅù\11NdÅÁUèI&\eÀÔ\8fD|\8aßï\89\93Bæ ´O¾\9fo\9fó     \ 4ö\1a\9aWdd%nÍ"Ã\98ó\b\16®\92X!,ÆTñ\84$\8b±kR\ 57\1cß²¿_B\92fºm!(;üî\16\vÆ0\18ËÖ\82û        Û\91\89º¨\r§$CÛÈTR\8c¼Á>\v\8eÔ«ÏKnÂ\1dõòE¦}p)­¸!ÿjdÙã\94í+m\1cÖï\1cc\8aK\85\11²óý\95\81Û#-.\99n\92/\17Y\ 2Å_½e¸ÐûàUH\1eá)ÌOÞXP\19\8e\8aOs\11ÆuÕyQ¿Ú\13·\9dF\ eÏþ&H4<\aCcrYQX¬NØ\85\92
+\1d\8d¬å\8b¤ß\9b=vÄÂ%³§-\9fJ\vì^`O\85\88YgÿôµÔ¿\94\7f­FH\7fSL/r
+)@¥&\ f\9c´5\81\vYE\86¦@\8b)_s\1f*Wi¬,±&\91qI\82\9e¢Ê}A\1dR\1e\8f<²¹p\15\8b®¬\9bÒÌ¡q­w+X[\r­\1eHª[}ß`¬J\fa\1d\83³\96qùpÎÒø¨\98Å)7SSm»U\r\eq3wkÿ]2$k\11¢j¡FDÝþ
+ýH\9díxÙÜÿ 0­C{@d<p\80\8e\9a)ïQG\85'\16\ 3\9c\81$ÈN wôû
+\89\84\11"qcgµðÃ50
+\1d\ eN\93\17\95\vÊáî\fê'±\ayuÆë´\92\8b A°ôzeò·!ü\1f\84ù&x|Í©V|â\17\9f_¦FéL5oã\9f!íbÊCÆ4¾Ä\ fY\84ËÜ£ÚS\8f4\9fÄ÷ÃÂ
+\16ö1\92\8e8\f1mT2\85}k\93\fú|·t½æ<\87\93\88\85Ä,oéúà\19\Ñ"Üp\9aO2\0Í\vÃ\948/dä®á\1571\8aÂþ\85\ 6a_Ì\88ª\96 ª"ÿ1Ò 9Þ6¡Õ\91@\19\1e\16cJ1UÖg×8ÕRȯ\89ò\10\1dµØÒXì\9a¨\9fr0ò*\9cªÛ¨û¬¥P\9aP\a\80ÁØ\r§\aé.\0\9d\1d\88lJ~-"Å\1fk\86\90\12\9a5öÚ\9b\8c9?º½àóíÉÙM»&ÄÔ\85\v\f\83Õ\91\8eÕ÷hïæè\90\8d±e\9b¬YUÈO-~ÿ\83Á\8eÈ\ 25\9cÆ\95B\ 5oµ,døf;\8d\13\95=s15[6f\94_²è&\98l¤M\1d<±s\8cHÇg\19\85íºÔùK\82)Úàd]\98Ò\1eËÏ]E\96ÁÔäqâ¯R\84Ã/\1aÔ;FÇãSÉ\1de\8eè¼èTîâ\8d\e~%´Úìfb3;\97\13\19\8c£0\r¾\86Ð4~G\ f]±å\0ææ,\7f\95=d9# M{C\84ãݼ÷αnúP\86Ç|Ér?{Ô!Pxý :\9a\85êsQ\89~kØs°r\8bÄpxî\12\92ëà·\ 1\ 4]Ax¸\8d¼\ 2\13$¤H®ö×\ 2_ó;ïµ\9ej¢z=\82\ 5\9f\9aܧg\91\ 6 ßX£ö\19\e¥Gö\8aU\82kçÐûvbmÇj\12q\94ç\
+Îu.Z\86â¸Y\bË÷yéâ2á%G1¢~\ e\83\ 4\8b\b+x¡Z\82uY¿\8f«EO\8f\18ñXX¦´°§EW±hïñ\9eNn?\80Ð-\ 1:Ge\83D_f?Hke\9a³\e½BÆ\9b\15ê\9e>¦ë>9}{pëþñ^\11\17Ú{Ô\ f¹üD±¸\7f671¥>íåêJBªçVÌ%\aÙ¹ü¬\19÷N.\18¢\9dÕöön\9dª\ 6«"auLk\0ÈI\9c\15d\a\eì\82÷Ø\11ì¸\19êþÍdP2«Á\1c´\97.\84\83ÿ\18*þè¦l\ e)\8fú\ 1\9fT¦ªeA \16:\87´\9f\y©!l\9e\fJ\99æLÜþ\13¼\94\80Á\8e@\109úý'\9c´µýÁ\88ë\83ÝÉx\1a'\ e÷Ľ0jô/\94\üyZõĹ\0O,XÎF[\ 3¦ :\92(J\a\1eð¦\1fýó}Ö®\v$²Û12»îìûAÒÇ\16\10´e\17\1a\86\8a\9e\98ô¸R4á\13Ü\0¨Óß\ 3M÷c\ 4$µIº?¾)\97\9e\88>ßY\15ýô\8a\83ùlW\16}\ 2\f\14ß\14³üazuçðÌ¡R:ª¯\186Þ)¼p¥w\8b\13\9a\7fW\13¬\8e\ 6;\1a\82\19¥Ù%|ó¶
+®ý%m<\e×o`\98\0Ò_4\8d\ 3\89aürM\ 3ݳï\85ú\17XýïÍX\1a\7fyÿlè;nÖ¶§uçøÕ½\93\8f\82¤îyéa\98Ô«ÔoáJâ\ e\8b\96Ü\9cn\fýwVÀà\8e\8dXRÄ\87½ËÄT?\9d\85ün\14"¨>\1dÜZç\82죶1rv\852¤Á\17\99Y\ fiû^þ\8akg
+Ýo=]J0Ê9.\1aë[Ô~è\1dîX\eÛjà\88\8f\9e»¤x\vì\90VX;Á\9d¦ùV\1aBÃ&    ùÛo70±\8d\v8\9bz8MécÔ\8e¤6®Á¾Ão\v\95G\fBÀo4ë\81T³Ç
+\86i\81G\1c"¬¾\ 6*\13Ò\81·¹¥8Á]íÖ\17\rW¢gbp³¶>Ê\1e\ e\86SÇ«\92iÕoÙ\84IÙ­\ 1\13C80úÍ"·/\9aÅÅ\a\1cÕ/SXÂG\v\92e8\eÔ)ÃsÄ>hùX\v
+\ 1\eîÛÍ\10£RùÞ=Âò\8e ü/ÎrE=<\1e\9f0\9f\1f\rÞ¡1M\7f\1c§ûáá\18J½ú¹êÓ\ f\82k\9a'\1cÍÌ\94ò\e"Äû\83\93à\86ù_´ý\90aü)|z|\9a÷>r·6Z5\96U
+\87ËÓ.\eô!Y21
+w/ßDw³±³°¬µg1\82ytp\97\8c\1d¶fVÚ#Ý\ 1bi8y\1fÌ\9e\17]΢\96\87\9b9tQ.\r\fÊ?R\83r~Áw\ 1I7÷²ó\92ÇØäçÁ¼\10µ!Â$tø£\vqþÒ\1c|     i\99\0ý\90\84\ 2\125®®3Z\9f\f×U÷A\9d\1d\9e¶÷\bcÉlH7\8f}Ú8,\0\17ú+À\e®Ì_2ðÀ¢p\9c\8fÀ²
+öÄ´æUNý\9aÝ      ­ø*\1a\8d9Ã"|Ü\86TÓ;qð\ 1Ì\1f.S\8f¹CC\v¡,¦b\1c\83\14\r\88\1a\a\9cU\ 6\99\8a´\fRÇwi\bj%\8déäßFç#ÊM\8a\10muÐüj&!ÍÈ{%ÚMê®yø\8b\ 3\93\15\10\7f\89÷÷à¼z\18÷\13    z\1cäó&­\1c\a\8ee\ e\84\8c\10»+ìÜ¡\15o;\1c\¬êÝ\13ørÆ\8a\19x(¬¥\7f\99\951Y(d¡ñÎï^\ 5-Ë×°\17ÌÈ·+{?L\93_Öu\87\90§ã\9fç\90U\95ièBõÞå\85¬\1eu³yüøâø\86~¾¾°\89\8c\80gTFÐ餬â²`\92\r\96k\98µ§ý\86\18÷7yûêaÃÈm\1d\vÕáÁ\14\87ÈÃ=\14ݾ\1cM\9d\ f\fQÓmM\122\ f\9bÊ \8dÜв3éæ °\8füÕô\82L`s\16ØùIÑ\ 6j\81ÀL\93ß\ 4\9c7\1d\11\ 2Ã\888fºtKtà7Ã:1²\b|Yb\ fÄ\rËóWOÈOçÝ´Ì\15¦\8bËOÙ\8eÉR
+\1c\9cìò\87\8cØ­îCQMSÉAyth^¡\ 2\8fµÛI#÷½£ÓÐ\1f+p+¿*ÂcúY1\16ºÅ¨vÛ\ 5/>1\11\vx£í¶qââ\9dÖV.\89t\8bªrøô\14Ø\82õ¾Aà\91ý\88\7fÛi̬\14|BØÓâ±åDÜ\11=XÆÝw\85\12HØ­¹¹ðáF}\vîvqìµÂ\92Æ\9c\94ñÁë±R\89Ûc\9d\9aª|\85s\97\ 2ê\9e\14®Y­-r£\ï¸(Ë\vö\81\8dkv\1dá\a\ 6\10\a\9d4\91!)'áBkcÔJ\1aC"¬Ç&êPY<\87v1\b:W\88Ì.\eÊáhqOü²©~\80\ 3±¯+ÔðñÉé3\91>\8b/\9e¦\90\10Î\ 3Ô\99/ió5<\fä\vtnlF!\9féT\83Ó\8e\1aMéaþú4ì*mÝݧ/@pn]R\13\86\1fu×üÑVå\a-\90\ÜÉ\81Ä'ü\1a\ 51ä[誷ü\1f~¹ë#xTôê =ô\89ß´\9eÝ\11A\#íµÖÓ`fU#]7÷\9c+=L ðæ{k\95\87\15\1a\93\ 5¿«©%±\97\r'ù*X7\ f;\10ú},ü\8a\1fw\1aä;Ë\ræð\9d\ 5øåZ¼í\15\7fº\14í£G\1a<Üq]ôüµÙ¥õ:¿ð\b\8aóô\9aËþv]iÇ¡¦ØúËawUcµÝ\948v{\ 5 aÍä\92õDgùàGV^"\99x}ði\9f\ e4M2DGó¾<x&^5²\8f»þ\ 5g:\ 1í|\a8\ f\82,d
+NΩÌ\8dE\14\14\14ßF\9d\8eI\94\eÚ¼É\ 4CÈY@íU\84yc³\ 52±B\95F£YÜ\9dø\83\ 1ç[ ú v\84f\9dNGv?÷|¨?f\98ê\81@\91óÄiáz»Xä\14×±&[õ·hcóÌd\ 2Ý \a/\99ß`áq\14£öñWÛgöj_\90\11Þس\1a§:g±\89k\8d\95\91­\88\1fû4\11 \bø\8b}ÂÚÙÄD³Âô*]±ûmZàÁÍ\15gî[\16\86gpoÚ±äb\91Æx\9e«~\89?â-Z\b¾\18µO\12±öÁ\98\8fPJ\ 4Ò´ÆÒ.âÒ\9c\8dqHð⤩\97{\893\9b}pY\85¨\86ÆbLL\18\9eÊì\vÐ> \17M\e®Ã\ eýêõñW\8f\18 "Û¨¼eò!\91Á\8cÇ\19õÄǽ¸¾ë\16\86$cÀesÿ\89yÑð{\11Îþ]=Ø@Ü\r\94`ê9B?\16\1eاê÷Û\ 1FÈs»Ä\r´E!§®r_ÔþÈDi©\bjýA\ 1Ìxâïníïr¹n\r89\8b\8eMôF\93ªÚz^iÆãÞG\9c\98©\r0\ eE~\92ÒòpN\ 3Ò\1feDüa\ 46ëÞ$¾ý ¬»©Aèò\9e_d²Ã\1d9p\8cÿ¤ËZ8¤³\1f;\863+Íî!®USEBÃ\9e\96(à&\ f-\b\ fk\8aÚ\ 3\8dá;Ðã|7]PÉ»²±dÁÿ\8e7úëpñÉm\&\9eGW\8aÊ¥k:EùÂ\r.øg3Ø{Ð\964LfÔnåäáú\ fS\19ëÜ9\19R\e!µÜA\1e¶ûê[\92ôNH\88÷;N\92\88àô6]z]<El\8a]s\1f\7fÒ¸¼kóà\fgÓúÒûìêØlB\ 6åÇz  ¨\ 2o¶i&
+\1cÕÓ¨ Ó×/+©lÃPÓ\8dO?+\10\16Ä£`\86½\7f«:F#+ì1\9a¶üÞâ÷%\1dØ\r£Ç\8cÿ¼MÈÍÎ\99C¤_qú\16{¾+bGéð<v\17U453åtÅ µz\ 3¥)\8f÷Ør*jÓ塦Í\ 5\8e\97e¡ÇÛ.\8b¯Íñ¡\a\82\ 3:\vÛüÑÑO}\83=x»G\1dC\ fer\86\7f¬\89\97çS6ÑbÓ3«`åîGü\9f(í   %§\ 4«`ÐjQu\9c\1dÔ¿:w\9b7\ f\9aÆ\aq¾é¥Û¡yÓîèïõ~þ\18\1e¨/\12ÆX\\1d36á\15ê\81üqq\97\0åù\8c\8cb\92næ\8þFU\ 1,\b\13AÄÉws=È«á\1eá*\f\ 2â½c.ñs´Ù\9eÕ\92\94Äó\8cIK?Яq´èSdò#8ôê*\9a@£ÉÂ×Iênü.\9eËb4\ eéÝ(\17û\8b·\ 3\98vAÈ\0[uÄ,û-ë^þï1£xubZ7ù¯¸1\880{Û\e\ fþ.\13m0E\vÍ\ f.·=1÷}_kñ(\84\161\86Iiå\4.O\az\82ïF"ô­¸÷&\ fOíâ\f:\0XûðåLZ_WP\12ñV\95ÔÓ\f\9a\15j~\9e&¤[í\e\1c´]:\85n^:\15`\ e\8c\8e@¶Ø\9fâ\9aûɸænÕâimVC¥"Â×\ 10j\85°º_ï\1cùÌE+<ôíj\13H#I¯\8fp\ 5ÐY\9dбÔÑÅѨ\12Ï\7f¡÷c4)7Ù}\1c&¶§1Qp!¦w
+æ«ãüýT²ý\93\7fÁá2\1cº\83\11.ßkç\rÏ\1d\1dÌs\13cFÆýV¶\15+\90Fô¸>£\9d\8cÔ¡\8e6'±õvÓ\9d\15<B='ï5)ù\13«ÿ\f\9a\10¤\82_\80µ¯=\91±ôôB(z­ë­\8b\95i®ãâvM©4N¢t7\r\ 1\84\ 2gu]§{GpV Ïs\9a¸õ»oøZ0B/\87AÒ§\12/¶Xüê\1asn\ 3¿fD»UR§Lì`µP\98`\9fÄ»(§\ 1\ 5þâ¾ü[\1eÛ\93@=Ýß;):w'A¹\8a˯LÝS\11Ù\96+õr\r²\97#îô\85­µ¦\97\89ñ\v\95f\vb\9eô\8e\ 2\17βg\8b\97\97|Û4|\97\1fs|So\96\1d\1cÕ"K?TD\9e²×JsÚ9g_ú$ qY&\17\9e\17\ f
+#1fQ/\98m\ 6ÄÅ,=\ ej÷lgUãU³à#×~:)\10ÞoØ\1c÷c\8d1k\bWñ* *>\19õÎHm7\vpøuä=\13ÉçNñå\97\v¹øA\85#´¿ûW\9c\92¥à_W÷r©¿xʲ)®¿=\Dì\86¥ùû;\93®\86:{pµè¦\82s×G\ 2\8cV¾³\8fä¥i\16ÉmHÈ«¦\ f\9fY\88ÖÍ\ 6È\18ºè-q\87¡Ëò(      ÈÒ      \8a\r/Ä>Ï¡Ål¾Ã\12àZòí/ö²t¿oÓß_ÀY³x\1eÀ\99\1eã\7f\13u   2³J8\8e\1a\93¢?û¡ò*ì\13|\ 3\ 5\9c\ eRßb\ fí.í«)¾\ 4Ǻנ{}¥Oí\90þÐÁ)¥\9a!)\9c\ 4ã\8fî\ 4¬ÝXɹ\8eáã\9b{\1c1 *Ãy\96_;V
\18©ô(\8f&D¿ìÁ± í÷A,A\96ÐãÓþm\9a\ 4\1dÉ\9a\f\97À\Ñg¥00uá\90¸dþ\92\93Ò\eË£H½j%\a\12\8c\8eí5 \8aJ0\ 3\ f\eÆ©ý\91xóÝ2ÕÛìPÌ5¿RæJ    p\95fÁµü¢\95ÝÁn°\95\9eESQ\ 4Æ>î\90\8ck\9búXÙxPQE°Ü²I\15ùñ¨]\0°ñ3·ë\17p\9c£\1f,çûõgm>\bº\9f-\8fäI\ 3\8aC\bÝdÄ\19Cc÷¼\964\1f<×¥¸ì\18c\ 4ÖtÙ¶\9fj\9a\8a\96\ 51\8dFgV`a\Ä;QÀ
+ôÜ8F:\1e/dh/·d\8cÚ\82\95Yi\f vZm\19[\7f-±Ð\ 5Iâß4-Påë1\9fX²n®ú`«²\ 6µà\ 17SGêintûò¤¶\9e( ñgÌê³\8dÖ\13Æ\8bÎê\9c\7fpðØêë'ÑÌúÅ'\105\8cÔì\98ª\1eº\a\ f\0?Ä]\84"\ 1\8eu&ö\15.`s}¦j¿vá/\90§õº\93S5GÇðÎ\eökV\19O[\96¬\19*V®\94
+iP     ¦8cVXÎFq\8d\11ÅW/v³öã¾ÁäipEä*\9c È2^l\v\88Ð\10eÿ®$Â(û5~V\fô<,R·\12âݨRú=pÀ\19\96\16\98pÌi\8fû)þՠ    û%\8d.M\11½\87\83\8d\7f#ê`¦\f%ù-«§\88\8dµ&\13EÕºöhþQùªÌð¶ÿ=\94\9cO{?¶4y\16àªáëKÖ$W«y.á´{\7f\93\1e-ÚD¾ë\1eùËA+°õås¤$µ\eã¨%-ÿGF±'äµb^§\83ÀÇ´Lõ g\92\86À Å\8eñÈBI'õæ\88§Ô/jÈ8\1f±³\ 4§\17í\870èG\9b\9cdñ(x\v32øç\875\91ûÏ;\9bÇ\86ò\13ËáÈ(Ï÷;\1cÒ\86£x>m+´îÚÍ\7f\11KmµTÚM±ó\8a^5<Úÿª\e)Ê,»ÿ5QÈê\9b¤w\ 1t\ 1º\8bËJ\8c¦sÿ#\90óx\17\87²ÇYBÇA\92õÜ;üÐ\8a\81§î<\92ãñÔD7Ûá\971ìR§¾qc`;ÝÏ>\fÓ\17ä=\9a"ê²-\11\vÇ\ 3E\96Ö-$Ò°\99;'Z§²K"\e>häWë×¥¼\ 2\1e\8füÕ\ e\8c\85h°}\98ý½Íð\10L\8eί+ \13o\0\9dE\8b\12\87RÑa\1e\ 6ï\13\ eµ\1dÄ\86l\9e·á¡ÓÎIº­\eÞ\ 6"¯bçX\1eN\9fÌ\81\eä\15ýØéLÄÏ}Ùs\91÷\87¤ÚÒ\10\93)8\ e\9e\a&\18ÝwC\ eÖ#Á¿]\99\82\97\82wì!bÄ.Ï·:\844ÄÄS\18¿\94Oa9ÃÓ_\98\12\ fUsá\£Jå\91\93í¤©|l²\9b\8c\ 1\9fA^9«SZYS r)\97í±&\97JhÔ:9»$j`\86E}Q9v\12\9e\99ì&ô\ fÌþ-\18è\1cð
+\19\ 5\ 2ç\8a+´¹+\1däe±Q@AºÎ\81{/Z²A¦ý(æê4';ÿìÞ\1fK5îh\99¡¨¥Jñ5ç\eªõÍçwÕ±¨
+\9dÔJ,l\9e\95\f\b¤@Gúû\88ÔÒphý\14W\1c$½°bl\1f|À5½2³\80iùñGõÔÍxl\89z®37yD\ 2\92·©¶±Ùþt|
+{êD\ 3Á\ 2®8L2S\89\9ex'áÍòL>³ñòä\8f#7ª8èúH_;m?òâ"\17кP\9a\93\1f\18µ®¸ëÇ\1e\ 3jv-¼ÜR1\1a\btúmóï1\95#õ~q\    \18§\b\82þ³(;êQ\92ßv\8b¦,ãMä\9c    \80Ë\7f¤±lk;ø\1a¹á\ 4Ùɱ\ fKL§ÄQ;b¬)ýþc²®7»W[!r$±\b\1d¯\87¹ \9d\18\97ÿÉ;Õ*¾ÐÖ\1drv\99âàÙøä\ 6QõX   /oê.\1f\ eáDV\92\rÿÅ?\1a%\u\89*\90D\1dÉ\85\94\82WÔW]MÐ-\84O<dÊã\82ç\ 1«?\80UÊö\13\93'Bi\ 1\9ev^µ\9dû§}²a)ÏHÛß\8c/«ÔpÙ{\18Ýá\elÍF2³¹{L><obÏôÏnï\93\1dH¤:J÷\10Z\16Ä%Ѧpv\1e\81¬¥ã\ 5Ir\1eФ\1c¢\ 6ýYq»_³PÖ(Æ\ 3;#¶G·»°Î´}187Ä­\18\92\11©
+T¯\95\bêµÙ)\9d\8e|\8aýE¹\7fî\13­Þ'¹a<Ã1NzlF>\1d¥¡ìk°\95\ fê¥\13\0\ 53\17êP\ 5rxÞq(y\11Ñ\8aå\85\bÆ\91\9aû\8c\19`ëÐÁhÀí\1fUd\19±\10? J\ eåÖ\16¤\9b+)\8aôo$DV\15äøo\15g*s?Èô2\10\8dS`\9aåowSèÄ5\92ÍXª\87\98UÁÞKmSÂ\93\9e«äZáW¬¡LØ\96äv0\96\r÷-AæxA9\85\81£bûà\80\1fÙ\ 1\96\10\91oyÙ\811ï´}\18\ 3\82½Õ=\17\825ñ]³\84êäaý\117B0\12\87\90÷ïàÕv·    *é\9e©¬BFÝé3Ñmä\9d\11\87Åm6év©Â\8b\80ïoé?*'è\17ö\9cä-¾\89~\92>rPÏ\11/\12¥ÙÜÞl\9eJ\8ef\r¶­'Ù7MÙwï\80\8cåÍjmì\18\0Ë{\98\1e\1d<\86÷aí\9e\88\95nÇ˯\1dè´aA½&æîãÏèC\19AÈP¯Ç\89M\89ìKÆ',AL\1cû\8aëÂ\1aï¤pb3bW\97߸5íü\89\10Π1\97Gm| (ÌtF÷a¼åbG\88Zb\18ö\8eǧ\vë­xÐ>\17¹xÍ>ºebLzC\84®~\ 1,#>§ÙÏÔO³|\1f}ÃGz oä°os§-Íñ·£h\96\ e\1a.ͼ\8eþ[@ëC*ÕP\89÷\88\ f+\v\b\ 5Vz\aa»8Àú\98\84Þ9ä#ÍS\89°æ×/\ e\9e\81)z(ÝW\11\876\1d¹i\ 6ç\11ÐEJo5ÜðHa\89µ\8dSl[Ð69\ 6V\8a±ßè{¬!Ĥ/¾Áå\94ÙÅû"\98×?!\9f\ 6MðÉ\1eõóB;`ßÀ³@<òÒîHk×\88²²·®\7ff\1fõí"\10\8e½áA"T\12¿ÂW4m©\96\C=áç#´­ø\7f9?\98¦
+endstream
+endobj
+2891 0 obj <<
+/Type /FontDescriptor
+/FontName /ZRGIXZ+CMBX10
+/Flags 4
+/FontBBox [-301 -250 1164 946]
+/Ascent 694
+/CapHeight 686
+/Descent -194
+/ItalicAngle 0
+/StemV 114
+/XHeight 444
+/CharSet (/A/B/C/D/E/F/G/H/I/J/K/L/M/N/O/P/Q/R/S/T/U/V/W/X/Y/Z/a/b/c/colon/d/e/eight/endash/f/ffi/fi/five/four/g/h/hyphen/i/k/l/m/n/nine/o/one/p/parenleft/parenright/r/s/seven/six/t/three/two/u/v/w/x/y/zero)
+/FontFile 2890 0 R
+>> endobj
+2892 0 obj <<
+/Length1 1752
+/Length2 11158
+/Length3 0
+/Length 12115     
+/Filter /FlateDecode
+>>
+stream
+xÚ­\95c|\9dݶö\e\eM\9aÆÉ\8am4¶mÛ¶m\e\8dmÛn\1a;McÛ6ßõì}ÎnÏ9_ß_¾ä?ç\98ãºÆuÏû^$\ 4r\8a4üF¶\ 6Æ"¶6N4\f´\f\1c\0Ai\ 15\ 6F\0\ 3-=,      \89 \83±¾\93¹­\8d\90¾\931\a\80\81\9d\9d\ 1Àïl
+`¤\a0°r01s°0Ã\92\0\ 4míÜ\1dÌMÍ\9c\0ä\82\14ÿ\14}\ 3ð[\e;\98\eêÛ\0¤õ\9dÌ\8c­\81=\fõ­\0\8a\86æÆNî´\0~++\80Â?'\1c\ 1
\8eÆ\ e.ÆF´°\f\f\0#sC'\80\81±©¹\r,Ý?\8eÄmLl\ 1ßþ½läl÷ß[.Æ\ e\8e@S\0r I
+\0Т\91­\8d\95;ÀÈØ\ 4\96\16¨e\ftòÿÃÔÿn.âle%£oýOû\7f¥ô\7föõ­Í­Üÿ«ÂÖÚÎÙÉØ\ 1 mkdì`ó¿KU\8dÿmNÀÖêÿÈ\88;é[\99\eòÛ\98Z\19\ 3èÿ½dî(bîfl$gîdh\ 60Ñ·r4þ׺±\8dÑÿ¶\0\8cí_\ 6è\144\94Åe%¨þëyþkSNßÜÆIÉÝî?mÿ©þ\173üa`:\ eæn\0MzZzz\ 6`!ðï¿ÿÓþ_bÂ6\86¶Fæ6À\vÁÂ
+ÐwpÐw\87\ 5Þ\f ±\0<\19\0æ6FÆn\0c7 c:Z\e['à\11\00\12o\80\89­\ 3ì?\8f\93\95\ 5@ÇÿÏÒ¿\89\15@'ð\87¾\ 1è\ 4ÿ\10\e\80\ f±\ 3è\84ÿCßè\ 1t"\7f\88\ 1@'ú\87\18\ 1tb\7f\88  @'þ\87\80ê\92\7f\b¨.õ\87\80êÒ\7f\b¨.ó\87\80ê²ÿ!6 ºÜ\1f\ 2ªËÿ! ºÂ\1f\ 2ª+þ!f\0\9dÒ\1f\ 2zQþC@/*\7f\bèEõ?Ä\ eÔÓøCÀ=ý?\ 4ôið\87\80>\rÿC,À=C[+à[óß+\fôÀVF\7f!лñ\9f\87\7f_Ñ?\ 5ÀqLþ °Üä/dþ\aÍÿð?Å\7f\90\85é\1ftù«ÿ?û¶Î\ e\7fµ\a\96\98þ\85À\86fÿAf`@fîvfÆ\7fû\a®ý%H\ fÌÂò/\ 4\ e\17\ 2Ó°þË<pö?­X\80GmÌm\8cÿÚ\aNgûG\1dxØö\7fl\ 3ÝÛýÙ\ 66³Ów0¶±26ù\93\17\7f­:ü\8f\18\99\81ÁÚ\ 1?D¶\7f\0\1cÝþ/\ 4\8eþW0\fÀ9\1dÿxý\87\8c
+\82\ 5\b|cÿ£\0\9cÆÑJßÑì¯\16@Ñ?\16X\80Î\9cÌ\1c\8cÿz\1aÀ     \9c\mÿ:\0ìáü\17\ 2Ãtù\v\81y¸þõ¨\81§ÝþB`{÷¿\10\98\95Ç\1fsÀN\1eÆ\ eÿ\96ú¿\9f.\ 1\ 1[7O\1aàm¡a\ 4º\ 4\ 6Ã\ e|Oé½ÿG¡¡³\ 30U§\7fý*\0?\80ÿÍ&æÀÏ¥±±\9b±!ìÒ¼­!g\90EJsH\99\8fpÁt9\ 4%\88\80iK\9cLCï¯.¸ÀÅx\10«âQI{Êõzµç\8atTÄ}\88}|×WlÇ\88N/ù      \91\v\7fû¸Ôßïû.zûé\1emØj×éÒî{v\84\ f\81'H\1dÍs·§, ²³ëceIê\85\ 3Y\97\83'yräBJ\a\ 4\9fú4]\1aû2\82X¿©\89¤[)\87\ 6×\932\11( §Ú\97\851\87®¹"'%\80¯M\ 5úX\84B·R­\Ùv:£<\17@ç&¾ë\82\19M¨è=H\9e\7fwGØÑx\8e\e\7f@©óÓ.\8dØqÎ\95NS\8f©z5Ð\ÅÏdдº\8eÊ\98#»¡vÒJ«î¶[®\9eË.Ôx\92\85Æd.\17\r\97ø\86`\1eÑÞUH ü©.®\86Ôwªe-¿ÓLOCæ\1eo¼`\1eÇLRô£)Ì\83ól³ñ\17bL{\ f \15\9e\88\81\14ã\ 4±\86<\83\82øC\82I2x)v>Xø­ªÑ7\rÏ1®\ eñÐB¤¨&̤\17\99P\8eø÷^\b\8døzÓâéXò\92\0,+·Ya\9c½\90
+ò%×\8e\1e\8cðç\bËÞ\86ráDd\19à\ fÀ`\94\84è#Ì\82\8fÔµ'«ÿ}óM¥x\8c0+öÓ&~\8d2ÙÝθ;\ 2}\90©$\ f)\85-\ f\18\96²6±\9ajDø\ 1\r\83IÁÀ\ 2_CE\1dÙ\94\0<\83õ\93j(w®Ôå
+I      \8bSá:­,\8d¶L\f\9c ¤Ò\94/3\16ö
+\ f©k_\92\8bL\95Ú@ðmö\15´à;(RÎÆÒ§h\13\84\8c\85üR\87´N\86l\93\ 5\7fdì6\95\1dHÁ¼\8cÄáï>X»ö9ôpïj&\97óË:\ 3:èXÄ¿Z .
+Hæ|E¿\19\1de\f×!Gûk]WV=[\89\18\1eÒ\ak\9br\1dE´Äê\ 6äøæ\93V¨^zòxËxí þj9A g\19ø\12]ºôÌ,Æüå­tg5ÛJ4\9bç<ýs®\92ï\b´n¡!ÖLæ\11ë¦z\fC
+À·¤ÃFyê÷\85Cu\1fMúwgb\1c\ f{\ 6KÚ/ÑÛy\8eT¬dÈÙ\85"c\8c\88\1dÛ\a\ 1þ\13\97á\88´\ eÍö¨,Á¾xDL^Î\a\14vx\89¿»{\ráW}e\92\1d\98Na\9eÐ÷Fí¸|\12\83ÐR\11\1d\83x\aõ³6Ñ\87E9¬±©ö¾Ð\9cä\a·Åæ\8dë\18ÍVµùï\8b\a\ 5Éç\v¯Ý\97s\ 6\90\1c\88Ð×~0λ\9f\92UV\ 5\ f²Ë\14\13\9d\87qG\9a\9a};:)Ü¥*½1\16ä\88CÂí/»<\8c ¥\7fB\81Ó6ë\9e Ó»¸v¨ÕpO\88¦H\10`
+V©ÿÅ.ñ*~oÍWs,k\10\15=Y\97Aÿ<¤Ý'¡\15¨1Ï\8c5\8cÁ¦2\14ósY¸¾eÇ·q_¦\10\126Â3u\1f\9f4v\98Á\ 6\84ï>\1d\17à\8c\187VÔþí÷1:\89² z\ 4ö×Ö4þÙ3E\9aü\80¼>ÄZ·Ì±÷Ö\8c¼ÃMM\v½Jæ\9eOyåò-(\99\12ÖÑ9æ!\9c¹+S\8b\94P\ eghI\ 6Z\15£»?;®\97\99H6£ß\rXñ,\82¢ø\82Í\ 5é\82aÞqd¦CÄ*\9c÷\8e\97zXê\1eáÐ\96ÌS\1d       ù×¾\148ÌtÁ˲HÁö³\92½|K\85\98`\14\17à¹ö5ºß=¼ð;\fõ$?\1dZ!6äý5à\98C
+\8dÓç©Æ£¤\14¼Â\17­/\101B°vþâÈ\90#|\8bà¿\80\13¡A7WÎ\b×\1dM\97\vJ\r}^rO\8ewq\84¨#\87ß)º\8d\88\99!&`ÑhеÉ\16IöòðÃáX\8aÚ\ 1Yãx·~÷m%ÿaÂñ\15.1};©¯\16ÔíhMtVæNÄÂjRG]\82-\ 4ÞÏÙï\18\f\96.#\85Õíq·¯êU\12ÐD®ÄQ\97\1e\126É1#RSɲÇqé\18èÿÛ,9\92ú3U\87Óf\r;Wúö若ä\81\88\94zi¥\0\87vfG\16J\ 1\91^xQ,\1dÐ_rg\90:\12\ 6ÑÓ\\8dÕ©¯\80®î\9cmUczWéü̧y\13Ä׺I\9c9Îý¹ç\8f\1a$\1dó\105û\/¿×À\14ͳÆ,\1c\93»_+ÈÞ·°ô\9b×ÛRµá²®¬èÏ[\19R\99²Âh)d\97\11Ïmö
+¶      û\8e_\99j\93\ f¤\ 1M\9e\16o&uy×Òùc\8a]EZ¡ô1Þe\9axGÐé]ç~\86\84e\16Wu\91jã«¥lÄÞ\95Ð\95ôm§\rñ«pøki\8d8.#Ñ\84\97Ý        5\1eõh\97«\8c©¬\90¯ßm\89ÒÙ^\9a¸¾ì\a\95/\87­Ô=ó\13\9cå\82\8e©X|ÃI3\95\86:\0\8bü1^þË?N&\9fðE´\8e\93\91p±£EFZ\85@qû\13óÑ÷o\ eÂä\9e\8e\85ý}\81¼²°M\9fâÙ\7f¬í}¢n\93\9d\82\fqM\17w\87\8dEk­ÑÄ\87>\e¹×Ør¦"\19YC8ö¤8)ìñ\82´ëá+i)©Éâî\13¼TâQ\ 4\8c1÷B5k\86Öqì\97ÛSäIé\8d\19±\ e&\88Ñ\17¡\9b\9eG\ 6Î\16×\14hëKÅ\95\85å¥Ù\89gwéÒiQÓx\9e\vT\ 5ßcüÜ^u9\9eChÁ\16÷·ÔZÛBÇÍ\93Á\ egÿòÃ\18êIe°î¾ûSøÎç\ 3\1dV1Ü.3E3\94f-ýr\ 2άÏ\15jS\92sS\89½H\94\ e\ f\9dI¸ð\10á\ e×\18÷\87\
+µ*7\ 3OÂ×M>v\ 4Þ\vûÅ\15ÆoWï~ÞYy\9e!\84*SÐÝj\93\92|\9d9(\14¿µq´\10\87f\99<m't;¾\1d\19\1c\95l[K eS\80IbÇ©+Ë0 º­ÜÚ¹A\9ah(S¯xjý¤`¡úèsì!gkÅûÖ2|]Äî¹RËðåóâtVI\ 4Sv[ª\99uÓ¤*3&µO@ý\11\eýâï<\9aoÂE6\86k©mhb³p\8fãâç]Ù\e\8d¿c\bÎÊÞ\92ÀUZ¨ø\9aÄ£Fù_\\8bFÛè\9f\96\846ºÛÐ
+\19\1cçñ9è:ä^|\9eC×ð\93`³Î\91ìç~\ób\7f\80\1d\9d\85z#\10ÜC+ª=TË\15\8a×$\ 5yQÂh²Çð'\9b\9f8\16\8aî
+åüú\94\95|FF\99z\97Ĺu\91Ðè=D\16\­u»\ 1UóE,ø²Hjd¾\ eu\15\81\16\9eû\88;\10\9cú\9bèÂË#\1a¹Ì\802\1c\82 U\e«) ½\0\91ó\16!¬§\952ý;\ e\87Ûí·qìE\rÃ\99Òß\r\e\1e¯\9a&\19\ 1Cîó\17\ð<Ø\85mï¯\94±«Ò­±)\80\12)êÙ_±\b"ä´8Ä¥·\17âï]\a~\ 5ð\9cIvM\16òÇ\98GFÔ¸ðÖ\82»\8c\ 5\12\93\ 4\88®\8cAh°³\85\11ðìv+é^\18\13¼.\98\ 6\8b\93\88!\8b\ 5ÐÍÒ    W±eß`í\99®J\85x½'©y\ 3~Ó èÐ\92v:«%CÞ\8d\ eM0fÖ\1c\1d\e5\a\9fßÆ\18r뿨9÷\1eÿt\133h_\1faÍ|`B~ò*\85ø¨º\9e*\88óÞ\ 4\19KLØóõ\e&¿+·~\83îØ\ 6?´Uæâ\r\91TíòªúÖ'ú9±doÿ\9b-Èü©9ðQ\8eS\ 4  [/\8d©\85âOe\92\93\13\ 2 A\ 5âËÅÖ<¾Ç\ 6\8d%Kcû&\1cv\1d짠ªq\ 4\83ú¨êü-záÜõæd\90\97èñ6ãé\99Р\ 1\r\ 2î(\1f¤°0è\8b}|\8c¸áfE;\rZp\13,D\1e\9c7¾»\ 4O\91]5\92·\96¬\8f\9a+\936!ß\9f»^Rà{ø\18^\7f8H7îé\7fé½ù\16æ.äxiÁ÷Î*­\90ÕÖ=@éÏ\9e >¾yBi\87äJ\94pº²¤Y\97\95     Ñ\8c}»¸P*SÒøË帨ge ,0"\82s\1cm\1d\96Å`&h}\1dÍl0¬P0ç$BÃã¦\81\fÔ$\10i@[K¨)\161"Ø\eÄ\1a -\16M\1a¶Dd¦'F÷½Bà#bc}\89N|Ü\bkV#Ç\v<`¹_l\ràB\96\9cj\ 3\87{\8d\0«3\82ͼ¶ëHïj\12\12/Wn*ê\9c\17\82x¬â\9fr&aç»â\15µ½\92£>\18!²r·\7fÞÈ\12Âàø<þ\16ÅÏ\ f¿à¿Z±\97\aÇ6º\10Ñê¨t\95,\17\16\16\1eG±dO\9f\\19\81diÃFÄ-%´¾}\87®\89`¿á\9a>\17^\81Slí\95æ\1cCMq,²\0æc\8e¸ë\89\ 3Þ¨Ãå\8cn\99gP\9c[\f\ 2½J\80\1c©9¤Ô3\e-u\19bPh\Ȫ\95fúøøNQ @Ñ·a´x°¶
+¼pvkü\80uk(ÔeÛ2øQßLð'\12;{çL6+\83`\9c¯"\96äcnÉÜ\9a\>nwo\9f\83\91\91Óµ\1aæ\9cqép¥+Ù`\8e\8a]\1fo136ÎüÏ\15¤çyç\82\L2y\ 40\9bõ\9a¢?=¸\b\8f®\12y*O\85ê\r\87Aç¿TºÑóü\84/Î1ÙæË8R¿~w\91\7f9mop\0\95øüÅW@\15²«\ 2¹Øì»a\ 3\17\8e£\80\91ª1Z\97ê\1aï¹\9c\b9Déiätݦ\8dxÍB.!¼n\fAÞ`\96õ\8cõúK¥çduÀýË\ 6Å\r\1f÷Éç\8a\1dºÉCÃ\97%ùw\1ao1\8b¹¨\0\14û\83®(Ë»ò÷ïÞ¡­ÂáFóxý\14Lå/äÜKdç_\8e7`Ö\ fiÉõ¥áÁ±·ÁyGÑ4K¸A6;jP*\8fvN-êÄ\91 ]\ 4C\8a\84µ\13¸\199ûÞ)Ë\9a\f\9a%ªó\fguÉæ:[f\99\fJÅ$ÀÜÈ£Y\9d5(Ä¢PúTÃîâÔÏ
+\1aD(Ü\90\96 Å#\128«jy\13\1fº0GÅ\ 1\18\9fëc¼\ ew\11)\ fðw;üo\18º¡÷Ã\13â\92°\92ÜÕ+Vv\10¦+¹&\a{8\83ßae5¦Ã7ñMû\83\1aJW{"\85äOî¡8ëÏ\89ÅyR¦Ú\1c¯>\8a´"r\8eî\9fÐ\18\18(uÚ\ 4\82\94Üái\8e8Û§d¾\7f\906\12fú¢Æ£\90\9a\b\14\9e\8bl\aÿô\12´ëD"ή¦±Ôè­YÝûH\1d\ fÝùq\1d<4\f\12\ eUýX\17ïÎ\8f\1d\8anîÂ{ú*\9fí\86}·îä«\16ÏÚ\14Ø\93¡¡=íÓTÑ6ú\9báú\90F
+tSs    \19Ä0\95¤V\1fÑ\93°Fä\86\90­J\8eãIËmã»w\93C\10\9ed\80#B\97\vά}:\13oßoã\ 3\89O\95¥ë½'>r\11íÒ±K*\9ct\9dä\1d\159ÏJ®v~æsM;\91\94&ÛÖÙÁ/O\ 6\rÝ\9a\9fql\93°\17³\97~ß-\f\86hüèfÿ\10K¡ö®,«]Ö\1f\85þ<Ð\ 5-ñ¤'S\14bE;©×\8e[\82\87ÔdÓ¤®+\18ü\85b#\ru ¢À\82\86\ f\ e\8e÷áP\18º1)[Í\1d¬¤b\12K\9fÝéú7[äÆÀR&\98Ú\83õWX\864ç÷ù\11IE\82e¢*\87,öY(^\13\84\99w¥«Oµ\86<Ê{\15ƪqþj­\970\ 3\82Ô%ö¡úŪ}¾\ 5\11>®áþáE¾\9fȲÍjáâHW#\15\87ÒS       éN·}^W\8fj\1e°®\8e\92\19â\93T{êéP¾ê9AríNò\7f\7f¨ï{ÅyâÕש¯\bq@\98Ñ1ÿd~«¾\9f2\ 2\9dý=]öyã@\9d5­¢ÎeE\8cãÜ2\14o±ë\8c6A@}\12\ 4FÎ>\89\r\9a\ 3,=Çõ\9cºÛÊ2ôyS\8aÏ*4\84Óö[\91òn¼ðXÛe}0>\96\9fCU·\ 4Æ{·ÿ\82\10`'Ð\0yÐäEÜs$\19aç#\81~5~f\1f\83\aÑ(¾5l\92      \ 1\84D\fò\1eÓ\fß/Ê\8en\83\8fÿ6\8b \9es(Ç\81\1f\ 2ÜPuþK\7fèþêª\9f\\10\95HvGÉ\ 2\82\17\bs¸Ïü¤Ç¾ç\17ÓÑ6K\eL.£#\ f¡ÕVð\9eéØÜ=¦õG\ 1        !yïwö ò\8c\89\18³.'»%_S\1f\ 2F8ø³èM\1a\ 2¥T\92^j,ÝÀ¨\1e'ÿçü\14\18\95wg\9cô\ 2éé\88\ 2c\8e\16\97     \8a£CñÜÄ  Nr÷\19(\12¼r\8bzáò\ 51\94\91\95\v\8b\aë\868\8aP2¢.\1c\96sx\9f±â¾\9am*0Ë2}¨Ã\8duÜÓ¤ìM&-\1d\ 3Ú=\ e\17jÆm\1aÝ.³l&q¸#\92\r\87\90\92\9fuß=#ßyÞÝ
+&\b·!ë\85\8fÔ¯ÒÌÍnÈó¼Ì\a®;\1aí\91ô?Ãn\ 5¢!÷R4\9f3×8m}¹öã\99öÖ\12Wxerg¤výQÈþì\998a£.òµ=;\ 1$[T,\8d\1a\94hÜ("©\0L\93,(ÑWY\81É9s2ÝÜ[ñLÅ\99\v\au\96M\91õ3Ù½7'\91\8cì»E[(µs\8e´ÞÝÙ¨eÑRÿxÿä{˨\85ÏÅÞ\80zéÂû\99·ìð¤Û     ´\ 2Ùð\85K\99\86^,\1a\1fw\9d\91I4ïfÄ$ì\9d êóϾyGâý¶\90H\aZµÒ\96Í\8d¬\ 2Fg­\86\ 60ºÝ\10&À&õ=ê×@\8cÐU\83XÿÂ\ 3È+\96~\98\14.\8ei\93+ðEi-ôA\1dÌÕ\ 2èßtUÌÁi)\96O\99¦\9b²ã\ 3Å\97ú ã\9el\ 5í\8bv"¼µ\1c7ÈÓç\94.\95F»àä\8f\ 2ô±%;­4\ 5û¿\ 4äJ5Ñ\1c\19\9d­û®9vÆùGo\99\93_y\83ë¼{\9aK\9c\ f:Ô3¦Í\8dS¡£P-`ÙQCXà©æ+úq\ e\ 2§?\86fwe·\fÞñE\9c)ñÆ\f~dyU@Â[ÌcªL\eû\84\bÊ*££\82¾\92räl\9eù}p\12ìÃêç\9a\18>8\97\93Ü\18\1eò'Ç^ÆÈL"ö\19ç°ÐYáK,.\12\90\f\8b¨\12±\82'_\võ\88®×3í\11Þ%`>í«\83zZ\8c©ï>OF$\8dÕ\82mMÀ\19\9b\9b|\86ú²\ 2¥1ïZÕ|øZ*
+f\8f-Ñm´?©ÊyV\ f\905\9fo\9b\12ȼN±¨\8c ¼^h\92ëPàÚ@Îó\14÷:¨¡\87\89)\9còu^®½ã|r({Î\92íý\88\83_Ë      \12\82d\9aÙ,jò#i\ e\93J|-TaËϪé\94ùM|ã°®\8e\8c÷\1d\ 12Ϊ£òQ´\99Gï]c1O÷'§
+§Èg\1c°&\8a8\9c\1c\90ç{gG\92}:V0\93ü\12lyÂ×÷\1cþ©aË\ eó\ 4]yèïR×¾\94\12\95ú¼\83\85#I\ 6j^\81®\ 3\9eL¨5fþ\84 S%ºN\1cÞ\b®Ý\aä\85ö1æ^1\ eV¡Ä_ØÖ¾×¼EÌçn\17\93­ÂVà\9fd¡Näõ1Buøóë`ó7\94îð|¾i\r\13äÅ\96\88þlÆ´q\96ã¥O¶¢¹J\1cV­t\17\1c\96\88\\öbÖu\9b\8c\1f~a:.ÊÂìy×D$\1f\7f½\8f,\ föÔyfZÀö`Ó)p]íÇ¿¾\1dÀh¯H¯Þ\88\ 3
+G\89p\96#%ã\1d       mzñþ»ÛFÉÕ\9d\9b\8d\867$ß«W´Â²\16ÿÂ\8ab\12\8c1PÙÛÁê3\97\97½Þ4\15î­ã©Þ+IJ»i\87)\b\9eO\13¹à.\9f\9bð\8c¼G\8cÜ\ 5\90hc\12sò~\97\85\9bç=I+GØL¡\19îJs³L\14)·j\92ã_P3ÿ,\ 6=wï\81ßÝ\89\v8AR?Û:.\ eR4/&ù\14MP\149   ª\1d\91Vþ;jÈÜï\95YUV\8c\8fØ\r\91\91¶'AÊ\9bÅ]×\19ÜM;z\ 5Ì-aRSïw%âqEÕ\85cRVÀëiñ"2ürö=Ìúý{\1e¹SÅA³k Ôb¹£Êî+.º6TÃ!\aäò\89Ï3ßÙ\19\ faµàù9Q¶\83\8dħ¯\9aû\1f\ fl\16B¤ÅñnXcUT(°ËÆê¬?\9exn\14\87ø¶Ý\16\8f\eà\92ãäå&õ¦òrE=\83~2\9c\8aÖ<Y>¿Mà¥\8fF1á°ïÊ\ep\8d,\83}©Éî\ eϽcoó\9eñ\9a-\99¦°÷äÓÕºK,¿«n\17ÐùÍH¦\86Ç\fË=Õ¬]·cáÜrÕÛEÞ3\8e* µë\11\10\91D­/\8aáp+\90\96ú\8dA\85ÖÒ\1aeö#"ÒÉ[Ös\96\ e¤\97×eÍCî\90H6¸S[!ð\19\0\ 3®\85\1dþåmpbäÃ.a?Yyrì\99\971rÙJ¸¸ÿÄ2;Ñ\1dåev8äq\ 1¿ñ^ÜkÓ7¼\99ÂPà\8dñFÓïcFË?2?÷]úÁ\9axI\1e\14ÍHïbÕë\b3îìAEvË#§Ö&rn\9c&\ fv\ 2.\950lZ\9c²l\1eî·zÆ«BæMBæÁÌj0ئ\17\83$Ò²\14l\f\ 5\ 6ê&\9e\10fd¼¹õ+ÖæÇK ±\fSu¿\bäÞ`\ 4d=øP\ 5HTâÃé¥\ 4\95²W\ 6m\995Úþ¸\19\98)O2\8dÿu\92\9b\82X裠s\12Bù#\83\81m-ÌQ\15Q®tD©ÕAV\1eÌû\1a\ 6=ëcõD\14WÚ³'¨P]Þͯ¤\98K\88J¹¯¸Ö¦|îq>\85öµã\9bá\bï Õ¹c\11nÁà÷Ý\e;>«ô\89\86cdÜ~û\rf?ï        çYÁ\82ÍÂ\ 4ÑRú\ 2\ 3=Dd©©Ñ^VlôɯFÅx(OÚ=cZñsX<)ÂF'\96\ 2é\86j\8dsg\94Yq\10Þ'ã¡ZWJ âs¼g\ 3Ù\86à\aÂ\19\98\12«é¹Iê\99\83OáuGxݺO#G\82\8b\vÝÎô(¦ôLOæAðͺ\87ºÅ\8c \95¿\8eì¤ïa\9dßKµ\89ÉQ\15\fx\8bæÞ?j\83\1cÏí§\16T_ô\8a\ f\149(§\aÂÈþ\b\ 2{tß\15ó\82»¼ÂòpC\85æYC\r¯|\9f/(«³,Ë\8bc\14G\95Ð\94غ¡õ1!
+Cõ\17ÂS²HÞsÕº¶\91/
+[*ú~\19»¼6\1e¼¹e\92\9e\ e\ 2áS[aù¡SзPïIÍ\89÷±d\9a¿Ï\88ûU1$WPuÍæ}±ìc\ 2 8¤B]´ó®ÆdT\ 1³1u¸_6­¬\9elÅXCö\8b >ª\ 2Ú[«\19\1f\vd\1d­Ñ\14ÙC³\ 5\ e¹$\fì£må#AJØ;\95Ò<mZ\ 41JªX\ 3.ÿ\13\1d\ 2\89»/Ô\17a^÷ºRWbörÛóþ§ÑÎ!\99å \83yÜLù÷Mƪ{h\1d\8f\1a\1dÞ&ô\14©òÚ\17cN\97A\1a\16'\18\9cáõ\9c[Tc0\12Ë««ø\17pV­d\87T&Hqf    õ­xájÅf\18­\f      ½:;RjýbÔ\16\91'ëK92²\81\1e\11xán\95¤ÍMÂë|Ä\9c\8eö1ëð÷æ®ÈPF    \9b\v\95ñÔ\8aÇ¡÷[\a\92µ½IÖ§[ì`Î\0\92á7\92ý×¾Ò¼È9ZNß«:tÄxË'n\ 5åVs¥°ù\9asÝv\92\ 5þ\ e°=¯\82\1fC\96Uæw\bì^ÉK\9aõd&q\8e\13\e\91äæg
+\ eø PqÊ\1cf\9b\8d\88\19¯\88\ 5\82{\13½øýØ\85_\9f  |dÓ\83Feej~æ4(É\áòؾ\16(:\ 4\88     yæMóh×îð\1f} Ì¨Â\"x¤\8a©%9ÁsNÐÆ\15\95\ 6h9(áqkA¥ªQ°\eíÞU\8a\fXЦ¿½_,0\15\89Go-0òt0Ð\12è~¥\90=\16\84\8bIÖp\1eà8÷0Ä4Wß,\83\97åNK\ 1ó¤V\98TFÁo}ö/gÝ`\12£´ß+\90\9aOkdÌ\80X7¡\92R:åq\8cóe5]Fâ\90\96ä\99^Ø~*\b\14\8bÒÇpÙÏÞ\95¦¼\8c8rIéT\82W\8dì\7f¸i\r\9e^cïÖ\10åñ-QøüJe,Y¥\88áJ¤\8e·RkU\173Óz,õcàZWV~Ë·Ûï,·\ f=O½\8fNiqü\82      ã×\18\85\91\ 2\95Äx\97­
+q§v±m{z&X·\ 6õ÷[\r\ 2úÃ\9f\14\9bö»Ä\93z\ fñ0\13ï¼G¨³¥¦Æ\1a\81E\9fSL<\11|&\84Ð=ßÞ%Ìëû\eº®\8a\1aP\ fê®®<·Ñ¾×bEòTZÉlü\ 6\9bÚÕ1$'\84|*\Là¤AQÓ\8aµÓ½}°êÔQ{F¥\16c\9e\11¾,+ôìk¿_¡ãà¥Ç\e\8c¡<5Ö+\fÙÓ\81¾øàµÞKýpÎ\ f\93*N\9cg«!d~#\ f\80jªCiËÌonÏ^\9fÏ\95÷\15ÙæÛ\87+£À×\8dí\8aa\18\9d\1d_\10M\88ì;§'\92ðC\9dò\82\ f(\10\0õò9ïW\8bTj£%W[ÆвR\Ý
+]}ß\7f7²é\9b¶6PQÅÀ\89z¼zqµ5jÈë\86\84JQ½qâÿNXËöæ²lL\8bH\1fr:tõSçP\9c\7f|t\ 5a*yå6\93\Eý\81ÛÑm¸µqãBôæþy4\99jG\r\16$\98\ 1#\90î\11vÍcI\0WÀGT\9eá\9cx%&uØ\eæ{¹?\búèyd\889\9bq\96²B{/׺­à+iÐü\bFùæ\ 51\1aMB\ 2è¼B÷I©r;fSfa%\19÷\91ãËÛµõQè\80\16\88s[\16\ 24\86\83ëi\15\9aí×ZC\17\80=±È\93æ\10"7\97î°ó\ e:Y\ 5ÚNÞ*\96èjé®MÍ\17\vèÕv³/ç\91\9d¥m½\v\9fXå¾\8b1ÑÅH+áNGbÑ\ 487©a\88M®t\8a\8dC Q.c¯äð\r\90:\88ú2¨F))fÀÄ\8b+Ô¾\10\10æ\ 4±(Þ\92²\r~\9a\9b<øúu\7f\ 4¿Ø\8dÈì ù*¤©ß\9f\9bóÜ*ª}wèÙõºA;\13gÕOà,Ü¡u§Ì$É-v?øÚäÉó¬\14\ 2Ã5-\ e\bz\8c
+\a\88\0\90jN*Ó\8f͵\¶\93æ·ÖÝA±VÔV1§Òòøõ×\ 3-'Kb\81Ûa×óûã\86ÞH\7fâàz\1c÷[ê©8\1a\8a}Ö¨ñE£¼`NC\r\1eßñØYÐ\ eàò¹L­öWÁæ/\10ÿÆR7ñ1·G\93h(ÿT\rN±'e\967\19#\91_\8cNC¥_g\7f´}ùºîþEæ®v\ 6J\87V\83.\11LðÁeO»m¦\9etH@´\87/0@\1a¢3-=ûa\13¿5.\8a\e9'þ³uÙ\9ePm/ö'\83®:\p8\17\8cÍ&
+\a#:Ä\9e¯¿ø§âm²ÏÞõÅàuæ\7f\9f\9aÐ\1a\9f        ~£ëÈ:&Õ\82í£XÞÖ\9dLw8rù\99\13{_W\9c\ 6¡ÛC\ 3\90j\84\14\ e\13ÅGFóÍ·\96º]ÃàÝDSDëò\81\18\ e\8a­²ÿ¹©í\9aQ¯Õ}Õf\b\86ûÃÿÇ\ f°\13¤b<èϤeË\97C\10\9aØ|v\Ù:T\1fB¦C\ 5ËV:\18=    ]<el\95\17ø°±ÉÖQf(Õ¯ùáĹgè'µ£\14,U\8c;Ò·\81\0ú\r¨ã_h\81nþ¡\89\ 2\11©\8eÔµ5?lêgpÄ\98\13⻬\901\13\82\93(mj\7f/bb¾    9\10\83LÔfO¨+æÔds\8e\8eÁ¶\87\fGw6é´¹Ópìl`´ZyÙ\99Í=1[k§gMö\17ë½@iä\8c\ 54³f\8b§ð_ ¢\bÅñª°é\97ÉcEÝlÜ\ 6éTâ>ð\99ªÍÃDwòÞÑ\1egfÑî
+Tû>\e<\8fÏàG\81ï·\8a¢T\80\ 6§Æ    1ÚC$ÿ\14 ¨û¡\ 1Þ\"¤k(\8f(]ªÕ´\89µ"^9l¾P£'|4\8d\15C\1dFrF?ó\8exB¾\90\9dÙ^&ùàÚ¶ot°Á\16\82\89%kÓES\eê6F²"ä_i÷Åc½$å\1cîÜþ\r\94v¸Ádv\80\10Í\1e÷ÙRÅ~\94ÂÅçþ8]SínhG\12¦\9cQ¨H\a1»÷dmõpý\19ÿÝ\7f\ 6\99\80\8dÍ_ØDA\12ýx«Öè\19z\9aWrw{¢«ØK\16nM@×a4Þ,¯\909\G\90\9c£\97äBiô\8eÙcZ¢û¥õ\17uÁúF8=\83t·j/\f¯\916-Í\13Ú÷ ÃH|?ËX:åN\8b\8fÉ\9esý«ì>7?ðT¡Oøå߯ÂM\187ê>\1f\11üD\ 5\85¾ÍóW­\7f+\91ö:\ 4\1f2\90ø\15ÙÑÒ\1185\93V3)a\b\8d¿IMPÓ\92\ 2Ñ]£®i\a\93\8cÕ\89àæ?¡\e\85\11\8bÊ\\82ïÒ\9c\83ä[Ë\94\8dÖʪ=\15kYQ:Ögø³ãî`\9c&3ït\7f»=\9eæ2.¹\9a»|gW\8a×\8aQZÄçWS\1f\97\ 3\9f|v>T1dË\95'%,:     Æãzß#5\ 3\ 5\ 2T\ f]gÜ­\17\e3\ 3c\89\93Û\ 6sÌá»\ e¼Zz^¨\10dcº\92\8f@Îàs5ômë~½ýó\8f\93hw\9bKÍï¤\8b­8(hs§ÑÐ^\895\85(¯Í\8a\ 6\1e¹\ 3ÂU\92à³\vÁïEîà\94\8f\122ùÖv>4\15t\v\85
+ê(\8bûMÍ\8dsÝ`\0òøÆÑ\15_süU¢Æ\r\ fH\14\8f»Þ\15康\0#¿»^Xs"ë\ 3\86ý]ß¾ÇùÙ\18x\1f \84þ4ä\1a\0\12\ 5\râ}§\82²Ou\9c\9e¡\8b\9aEûÒ{ÜqÂVó¼\1e
+|\18òÎ\-L¦@x½\ 2nïÏL\139\ 3t\1aG\bÕ\8bÓÔOj\ e\89¡øñ\ 5ÎеÌ\89\b*6\8d¿\9bfmaòê\90~s¶\836\9bµ|Mð}Y}Û1\8b?Óa!7»ñ\ 3ô3:)^óè\8b~M¼nOØOXR0i\86ÈC\16Ð\v®]pÍ\1d\a»»>\9d
+\bõ®pb<V        3ßn¼\90¶§^\vÊ\84Ú\83\aÅ}«çÛ¯,ý\8d\82\82î\1dVmy\19\8c­ãÉ\85\84=Þó\82Ó\11\0\85øü˨*ïVtFEÈ\87Fv+\ fD?à\ eúbúÝ\ eµg´/-uÙÿ\99\87\89Tzj\91*ò0      \ e\1aûh-\94Ge\19yðéué¼\ 6>Wð{Ü\1a­ÛÂh\vê\99\0\92\11\ eë-¥1\17Q ö|à'\17U)Ò/~8gF3Ñ×\1c/Î;\ÏÎ\9e=Äû¢Òöz©0\12\16{ëþÉ·¤%/鸵å<\9e¦\88àtäQ÷IMLAÜ'óh\8fsý,\9dZd\19óQéq\88Ò\ 1à\ 5\\13ÅÝË \18ïäöÎ6\16]c5\ e\92\1d9\1a\\9d\95£B\934$g\10\10\ 3.½ÇP\87#wÅDG\f¿:F0'77±\84\eY·pfæ9Êî"rÆ\1a\vVaÝÖ[Z\99¤\96\ 6ÍM¦&#¼§ë<|\82¾;\19Õî@âÃ'\10o\8f¹6$ÍÞAA/1{N\14\9a@\r*==\ fø\1c\80}\81å®\17§\ eçç©-G\b\95ÚîÇ\9b%\13ÚHA$¼¡0}|m\eá z\0\91T³ßTI\vï\8c\9d¾´  \875\10Ûs\9b\84ñ\91Ê\ e ¤\92ç\80\13¹Úñ£ÊzÜ\9aS{³/ö¯y\13\9eÌ$` !^¼\1fÁ\19Ç`\82@Î!IK0g ßxÑR\12çiQðv»¹\9aéKô\86^ì0L8LÐey>\ú=P+Ý\9fôèd¶\89ã]ðƵU\16Ý%îÑçq\9b812.u\8dúÃ)\8e\ 52Cfz\11ѵ\91\9b±v^àÌ\7f=\9d7\8b\90áU\f\9d\9a jÙ\98C|ªùí*$o\80\15®J÷4\99$\11esNaM\15£\ 2SØørÑPcP\80Q=ìh  §ÕòðÂ$>mí×,\9aYZu\15ßÁïdÂ\\1cgB\0\829\8c\80Äø\ 5K~rþ6T\ 3\92Æ~j'¾g\86veRxeÈ\9e 6¿\19u\80\15õ]\8a\ 4\90ßã\86}ïÓk[%T \1eñÔ¥Jítp#ì\8b¿\94µý\ 5ñïÃÉ´ê\11³\92ð_£z`Önm«A24#ì'\ 1Ʋ´2\ 1³urC\14\81\88\18\14\84\163üÕ-sì\14!D\e\ fô³\15\1fúB\ f\\85\97\ 1pöqÕ>óØE¤¥Ô¦áR\8bßP´O©ú\82xµ¬\8eÀ¾\96Ó,¼\b1RqãÆBqNZ7\vQ*       \1f\89\94¥"ÚW\83Oì¾\ 5\18ò\19yH7>®~ÆV@\13\87(éc6@\14ÿ\81Y¦aRXg\89ñµæ3wóRj6\e¹wægîÚE\8e4ËrN²"U\v\9b\9f¶}\89»\0ì\82å,\1e\f\aÛf¶Ô«ôtu\ 6Ðè\8dd\ 6C2Ð\90\0\8b\18S?TKê
+Li§zãg\91\81ä9)EzôU\8d@\8f\8c(D\18\8fZ-\94C\17Xt&\90ÐÌ;\92\aÕû¢Ã²¾\17~îøö¢1ÎTÉ\97"\12a\80O\95Y]\ 23 F\93D\93\86]º7\bâkç\81\8fyÏ*?Ú\94`}\9dë ;g9\942]o\e\e¯\11Iî3§Ò\8f  ,ß\1fq0\96\12N¤QqF3é4£?fÝú;\12\r\ 4§,Ò©²\8dû\94Ô´,Ø,â\96C¾A\10ùïÔ\8e\86~Ì©,us!Å1\rJ\ eþ:\9b±\7f\17Ôõ
+\9c4\10Åé;\90Ò®ô¿7%n9Ñ]\8f\14\11\91g\1f 
+%¢Å\91ù&m£K%©\86§Sß\8bÉat Fß®NTdmºÙÄ×z\11ݤ\10ä\f\9fqx\96]\aM\19\11q|ªÌ\85¡W0|*YÌ\99\ 6\82=ókZC\8cúçÆ5º
\10èëZ{wöIîÞ\ eGG¤ÖR© øÓIä\1d|\83\ 2\e\17\8d  \1dÙ\1d¯\87Óª(îL#bfà±\90Åì\ 5\928¶égq\r¶$Ƥ6\8f\85\1f%a\ 4\9cë<Ä\aÅSû\8d\ 1\83O{¿\ f²U@IÂ\84àGfT\90V\1e\ 4Ç}@«\e¤`\85\88Í\87Kî«ø³Ö#¶}Ï   .GáPA\86Bt\9a\bÂmçÆ(Òzº\1ew\9f\ 5ì%\18åR¥(ª\ 2þÖs(êxæ!\16Z\88ñ\88ì&Ý­FÑ\1c\15¦ð\19¿\ e¢$8V\81\85\90Æ­Åèmd;\94§²$ºXíò\97¡\17§NõëòÞv»ìn*
+­s\7f\88\9aW\9fñ\80~£¤\8c®\81\ 6ý¥ñï}ÒëZ\9f¿\ 5b\81H¯àXÍíY\81\9c\e´\98ûÙ\99¶6\8c×\ e;\a|hgì×\ 6ºZ´°\17]ìвC\14¯ÝÇ\ eå\9a^âãWû\93QRS\9dxs"\96]#\1f¼lu=Ó
+¶:yÊV\8d×õà\19ȸç
+\81òQÃ\81ð2EÎ×\9du?[±gý\82{/P
+\89BB_VOÊ\10Ó¬baÐá\8f(üH-ù\9aÿ\88\8f÷)"\93WêÝ®} ;½Ö\8ez°ÔiKir\80²¦È÷\18Ü8©\r})Ö½hC\15¦ÈdBt\12ìg§\18²o
+\87®ôv ,4\82À4\ 6"\84etv®êEl\83\1fQb¤Ô\96Ïü\8cNÆØ\ 4Ë'\87ù m\8f\1f   Q\90Ǿ°7#¬~f\88D/.D_r®\9f¦Ð\82\ 3¬Å\1d±ª6 Å\8ax\ 43ëÍNª58êLÆö½ù»£Ìµæâo)[\12\8a'Fô\17z\92\ 4»§\8c% ¹[`Ï\19\94&¨À-iÒÊ2?ÓI~Ô}ê\r¬\1c¡¯ÿ\94\1e1\v\92]õ±~\[\1fnT\ 3\7f\8a\83Q[[¦\92OßHó5\ 2Ñ\95Y|n:#$\9cÌ\89Ö\85\84\ 2\1a\12ÀÆ\ 3\f\89y\vG|Õp/Ï0\8c\$Á¸+\81³ ¯Nïͳw÷I\8e\94;\9f\8cùñ\92·5j²Ä#\96·Çí\8dt}Ú\;ðâÅ=5ßPfkn\9fÄù¾Æ\1a`\9eè\1f­ô^5\84åÑ~¬lê:0\9d!\80´\80+´X\83Ý\86X\86\89lIáT\8fÔSÅ¥\9cÒõÐà\9f\r\aK¢?ìnÞ\94\89\99ÉBä+»k1XÏÏ\95\16\8bìF\84Ô\rò¶n\91ôÝ\84<p\1e\82"ìâ;\0\8b\13\84\10ñ\8b¦"o\9a\8a»®µ«oL¤õw¾\83\ f\88¯b\ 1ÙR ?2È@ù\84hz/È\19\8b±åTw\ 2K~¶©Éê¡,g¦Û\90¼sú\9a\92²â\8d\ f\93× \92-éBU\98"ÅA\94+\1d\9a3\99\8b­\r\91ÉÚ¾Wx\f\8b[Ìô4*U<E\1a\15$^Å¢dY\88jãì\987íÄQ»óA\98\9c\81÷\8c\87v1¹
+ZÙ\1dÂ\rT<Ä38`>\8c*)-\82´\r\94e\81íeŶ1\82\86Îû
+}㡼xvE­þj¸\17ú®È#¦£\14¦\ 1pg\ f4\91¸H¦ÅÎpº\1f¥Dÿ®»:C\18\9f¯©\v\98\~ñÓ    Ë±tNA%\e\91|\8c·\ 4´²\1f\80\9b\92QÞ²\awUð¨ÚÞÞ8p\9fB\88Ã\9b\9e¯Pé+>\11\18#\94åE\1fmEd`\1a\8d\80\9e&]Ü\8cÑ\96SùAðÝTÇläxÍ(¾\1c\15!kd\f§\rÆ \83kh\8bÑ\9d¤Îh\bÎ-:\97£`Ôüþý*Px\Ò%\9d2QÐ~\9f\Ëü\94RzÍ\97`@åwg¬\12k\13翯\90^yñ        \e­kÈìû×\8fþ\17h{N'ÿ\9f\95\14þ ;\16P\bÝ\15J:íÓàl|\88<oª\0þ\97B'\8bê\84\1fXiü¶\9d\8bFÃJ§Ëª°aqp#ý\8c\0x+Ä(E;\ 5\8cì\eé¼Ã§ºËÞ©A\9c\1cç«ç¾äK³x\81\19n\12¢¥ÃÊ|üÛ&r2;ysB[ ¾¼Á\85\8e\r>b\16ù\94KSP4òY\a\bÎ\87\88²Ã\96úxK»\1d5\17×G\82\ 6×¾v!bRm\17W\9eu\bÛb\86\9c\9dþ?"¥=\84 ÕU¯¡\99m.ö¾¿\1dl\bÞ³V\r⸶\8c´¤GºË#庠Ç\86öñ=Á*yçÝ\9bCa\1anô¡´z8ß½XÕ\1eâÀ\19Ü\17\1eã£G\92\9c\1fWV#\11ñÉ\9f       ýt\enÙb»\1d\9b\94q\96¤\96\1e\82\19{Æd¢©Íâ\v\14»t«\82\8a¥ÖNÁ\9cò(A\16pc;ÿÚ{\8aD\10\97T\9b\am\vï\98F\12µÓv      oôÁâK"$\80\11¸M×\8e\8aö}\7f\89]Ú_\9eðÓ\1cÂ:r4\8bádP\18O9Lv\10ØCâ\93}f}&\96ª\1dR%\91¢.©\83üö\94\82ê«»»Æ\1dfºÒâÖcþQk\92Ìú*9å\8c¼\1c\ 6\14á5r_s¦²¼÷³\1d¾\92\1c\82rÏÃ\8f\92\81æ3ßÀíó\ f\eûn\96\9bnu\85\9eíyþ©\ 4XyJ;A\86áÅÐ\19     Bõ-C\vÇ\ e_RA2\b"\8cqù6é\9e
+i!\ 1Rd0uD4<\19\vZ\94¸!rKt\82Õ%\8ek\8d\86\9f­%ù\8c\90\96]+ðä©\¥l\13J\1cí\8bo¸­Í\86\90Áæ3\8f«`ó¥Âû\ 4æ,\11¤ö°E-K\9fáe)\10UÕÞ­\19ê\ 6ÝK{ú\83ð\ 5&»ùLçg\93Úý\8cÆÝé5¿\16\99ÐâBÐ\97KéÝÐò¢\96ëú\82.\9dzzü?vÅ\ 1î
+endstream
+endobj
+2893 0 obj <<
+/Type /FontDescriptor
+/FontName /RZUIOJ+CMBX12
+/Flags 4
+/FontBBox [-53 -251 1139 750]
+/Ascent 694
+/CapHeight 686
+/Descent -194
+/ItalicAngle 0
+/StemV 109
+/XHeight 444
+/CharSet (/A/B/C/D/E/F/G/H/I/K/L/M/N/O/P/Q/R/S/T/U/V/W/Z/a/b/c/colon/d/e/eight/f/ff/ffi/fi/five/four/g/h/hyphen/i/k/l/m/n/nine/o/one/p/parenleft/parenright/period/q/r/s/seven/six/slash/t/three/two/u/v/w/x/y/z/zero)
+/FontFile 2892 0 R
+>> endobj
+2894 0 obj <<
+/Length1 776
+/Length2 1619
+/Length3 0
+/Length 2157      
+/Filter /FlateDecode
+>>
+stream
+xÚ­R{<\93}\1f\9eI\94\ eät\8fDZlffνs\96Ó\9c\98íÞ̳ÝãÞ\1c\16EÍ9½Q\14«       ©\87\94\1eE¥ôh**I\91S\9a¨\90\92\1eRÎzGoÏóyëß÷sÿs_ßïõû^×ïú}u\90D_#\ 2\95\1d
+:±!®\11\ 6\85±\ 4ì=ì\ 2ñ\0\ 6e\8cÐѱ\87A2\97Á\86\1cÈ\Ð\12ÀXX`\0B\14\1d01\ 60f\96X\9c¥©\ 5B\a°gGð`\ 6=\8c\vèÛ\e,\92ð\0\81\ 5Â\f
+\19\ 2<ÈÜ0\90%\99A!3\ 1_6\85\ 1ry(\80Àd\ 2>\8b'8\80\ fÈ\ 1áh\90\8aB`0\0\95\ 2¡ \9d\ 1\8b\86\!\1a\eÀ\7f+S£"¾·¢A\98#1\ 5èKL\1a\0\12\8bT6Ää\ 1T\90\86@{²%Z ÄÉÿÃÔ\8fÃ\9d¢\98LO2kqübH?µÉ,\ 6\93÷_\ 2\9b\15\11Å\ 5\83M\ 5aèGj\0øÍ\9b\1d\9bù\93\8a+\97ÌdP\b\10\9d  \ 2ÆßJ\f\8e\13#\16¤\12\19\J\18@#39àR\1d\84¨?Z\90¤¶d\0½s\aa{`Ð\96o¯¹Ô#\92\19\10×\8f\17ñ÷ÔEò\12Æü\83%ÙÀ\8cX\80d\8c26ÆH\88\92ïûßî\1f´\1c!
+\9bÊ\80\803\ 3È0Læ!${!A8 \ e\ 30 *\18\v\80±\12Ãh\14ÄæJ\8e\0\92\ 146\8cX|L3s\0í°XZBxc\0íô\ f\92ô<ÿFæ&\0Úg        ý|Y;;vl\9c\91DÒÈ\ 4'Q71·\0ð8̾ÿ!R¢`\18\84¸Kk$\89ì;¦1$\ 1\83`,HAtw°)VIá'®¦\94íw<ó伬¡´\1dýZ\96ç\95Ûm·äø]ÙÒÌs\ fÝ"\r{/\aÎ\94\v\94Ö\fÊ\ ejÆÌ©r2jã½\9b\9d>\1e\88ÌÊk_\18\8c\ e\19\14ì­Q\r\1c\17\ 6"´&ùï\15n^}61\82\93öjím*Ë    *¹'ü«á}\11QßÁohå\v¤\94\88\14]%:\99d\86\ ft\120ýS\93/ëb\91>\8ay\91ei¦©â\18Å\9c£ËÅ-üýá©«®oé\19c×F­\9b9³ªðØB°\fµyGȤÛèq\9eüë\9d3Y\8f&×U&î.Íx\1dUèe\9d%
+éÝ8\955l¥TõÛå\89\13êYrÕÄ\81m#¡.|C~\8b\83ª\8b·C`²s\9eÅ¥ó\ 62ÅÑÑ\ 3óµ\1d¾Nñ$zÀsU\18\89\95\14Éyuw*ÞìþÓûpÞIºØ\11;\15aD]sÝݺ>$Æe¶ón-«,\19ßXjÕÜ\9cªzÇîµò¸Á²|ϳG\82\19é!uþWÅ\9b\atC\89\9dõÿ^á\10¿G\1aSEÔv·h3éx?8Äj\97¹\1a\98Â\9aè¡s\83\95=Y\17\98\88\eï\8bO\r\83PúÆ}i¹G¬ÆC\95ÌÒ/\12ÎÖ\94É\8fó3´Ô\88ôkÆ4²¡ÂEåp³\88Ëç\84\9b0fñ|\Ȳ\9cò;à'þ4¿´\\ 3/\12\1c\9bì\19Óz~ÊÜþiäΦ\8fGÇ3FÞ\12óÖy?m\rVú£×\1eh%\a<%8\87\1a\1a\f\r})Ä_2-TÙ\17Pnx:Ò@J3\81¶ZÙ7\86~öKWâõØ\91Ìl\r+Í_+\f\ 4÷Bõf\85P³øÞÔËfå®'\95n\13wÂQf_
+àì¢ÂIó\ fzí)7*2\97÷É\93¬Ó0ámxwo*ò\88\7fÚhÏ4Mv\97ÿp¬zTeg\8d¨x^÷àPSÚÌ©°ôL\7fÅ[*Ô\9bÄ]åÓ§³\e×®t|Yë\96a¸ÁÀ\17x7¾÷Ä\87¤\86\81\1cn=_?èì+_\b\9bn\93uTÈÒIn´dÛ\18ï\86\ fuó3G\82¿¾9£\84\937Ò©-®:\17\17zøs\91Ú»è²ùF\8f{­©ùù\7f¸M¶ÔÏy=Éß\ 3\ 1\ 35ÎHÙºb\9fW\8fÞv\93Â}Ó¯xÕ\ fª±]\9d\8at(÷¡\90¶DôC/5ìê5%\19Î\1dØ\17"fUc \146sýX*æêq~2Å\83Rþ8\85! +dm\8fÉ       \97\16\1a7\8f\1cã\81Ù`;l\12B\12mÙ¯±\11e¾}lâMh!i¾ "*\17Ì´]ÿåsÍ2U\98;   \91\b\9fSÌÏ|Øàºu{\ 1'%\8eß²?2ãþê\88P\8c\8f\17hkk¿xï[gØÿP®¸¥ \99׶©QTí\134\97öµÿæ\14\ eÞÈBJ\81mOuù\ 3=\eÑS£þý\ f8\a\vÎöK=\82ï9¹>Ô£Õ¹V¿\9d\88\97ÓR\94Ã>´{úù\1d¯ºfµ\8a6Êè\15b>\95
+¯¨|æq(­)\85·|ªD÷ù¹]ù1µDï\92å¶\1cÃ)üÅÂÑÑ·\1d\82=w\1f\1ejöÚ`\9b·+×9W82\83êò\99;cèá¬\9b\8f;ÕôF­~Ö+D=±zú×\17.\9aÃ\99Ò6[\ 3Z/\ 6\8d|òïLZ1?×Ð\90a¾óÀ\8cå®Ì\82\88b\9f\8cûÙ\88\8am\83I¦}&ØäU·Ñqr\ f\8f\95ú­B\10YÔC\18ê§\7f\1e\14k*\127©(U\16\91ju\ 5®ý\ 3\ e\9b?S\ 3\ 5Éõ}öA\89âSxE-7\13©îà\r2\0wîRK\8d\9dÅæç\89\8d«çצ\9eß\9a\87½¾o\9dFuº\9cí\ 1V}É\84õë¤\v¾q\17\1eÔ7¸g ª R±Qê\9fs·¡*0\ 5i;_\91cYgÙ-° y\9ewGSgMw\18\88\92êÜ'z°X\81\8b¾~\8c©\9aÚ9ð´\910}\90µL´¹. ÿ`ðó\8c\84µÖ»Û\ed\7fAbo«W>ûý
+-[oA7Âôù\ 6\9c£Òzãë3\81°ÍBOïdÚða_רá\1dd{{×°º1k\948ófX²Ê\ 5ëO/\13\84\19Úý_£\8dÔ÷\1c1\18\9aí°-wÝ\83\ 5we+9k;*\92T9òo®\87LÛ$T\87\ 5o\eÒ\1eL\97÷|¼       ¤{h\K\97\86\10ßyg5JÏ8¯\1cª\9fJd¸\12\14Ô\8e:«Ï)weÉ4í\99\13.,ÌÑ\1a\86\96\87b"ñ\8aUMbµT+\99\84ÖvCí\86\8b\8f§\1e¼·}\84Ôk|gM÷óû\10 ä\98ëê\18¦\8b\ 2\eq/\12\12û\84\85'\87=òJ\84\11J\87Ç^­ ~ÍW\19WÐ>Y\99\87;¡tA'å¥\1eB3¹lY×ozü²b\13\95Awüá\17³ZÊu\80B\8b\ªM|Ëk
+WÓ{úë\8d\ 6³éGM\1aû>~DÈWÃnâûµÅ\93\85Ê(½/×\ e²\9f>[h>\17\7f#\1cÝ\ 1vr¨4æ´Yim\9e\9dc\18×ï$¦ú®v½GÃÌ\7f\0ës)\ 1
+endstream
+endobj
+2895 0 obj <<
+/Type /FontDescriptor
+/FontName /ZVAJXY+CMBX7
+/Flags 4
+/FontBBox [-55 -250 1289 751]
+/Ascent 694
+/CapHeight 686
+/Descent -194
+/ItalicAngle 0
+/StemV 127
+/XHeight 444
+/CharSet (/D/F/N/R)
+/FontFile 2894 0 R
+>> endobj
+2896 0 obj <<
+/Length1 840
+/Length2 2153
+/Length3 0
+/Length 2721      
+/Filter /FlateDecode
+>>
+stream
+xÚ­U{<Óí\en\11¢b©DÔWNIìÀ\1cF4[¼\92³Z\v\17c6fs¬H\94B\85YMI\86äPè\80"\89\9c\8a\1cB&\95\14aH$\92ûz\8f¿Þ\7f\7f\9fç\9fçºïë¾ïësÝÏçó¨)Û;icÈtOÐ\82Ncj#t\10h\0kc~ÈÙ
+\ 1\a\10:pI55,\ 3$2)t\1a\8eÈ\ 4Ñ\0ÂÈ\b\ 1`XÞ\0Â\10@\18 õôѺB\12\80¥\a\841(Þ>L`\a\aÉ\0Àø\83\f
+\89H\ 3l\88L\1fÐ_Ø\83\ 2Nt\12\ 5d\86é\0\18*\15püQ\11\ 48\82A #\18$ëH"\10\0\99Bb\ 2\9e 7\85&    û¡É\8aæE\a\fþ\b\93Y\ 1\7f¥\82AF\90P\14°C(R\13\10J$ÓiÔ0\80\fzIÂléÂY PÉÿCÔ¯Í-XTª-ÑÿGû?}ú\ f\83èO¡\86ýÉ¡û\a°\98 \ 3°¡\93A\ 6íW*\1eüC\9e9\9dú\9fAVL"\95BÂм©  \8dÐÓ\81ëý\11§\ 4YPBA²=\85\ 1¼\88Ô ðg\1c¤\91\7fÕ!tï§
+\98\ 5Æ\8e`ç õ÷b\7f¦í\89\14\1aÓ9,\0\ 4àÿð\7fbÄ?Xh\13\83\12
+¸Àuàp\84\90(<\7fÝÜ~\19·\97\93)4o\0\89Ò\a\88\f\ 61LRø\84\84\b\ 5\0
+\8d\f\86\ 2`¨P3L\87Fg
+K\0¡3Ç\0/:CòÇ^\8d\f\ 1\98ç\8fÐO\84\80£\0\18å_P\98¥þ\ 3\11H\0\16ð/¨\vÀ\ 2ÿ\ 5õ\ 1\18óo¨',\r\a\19ô\9f\81ÿ:dnN\ f\8dÐF\1a\ 1ÚH\94P/Ò@\ f0@é\1dû\1f"\89Å`\804æÏ7(ôù/ìE\11®\ 6\ 4CA\92$¿\9bN2\8eñ½Xz*ïøÞ¬¶üU\9aA\8aÜÜ\98æªØ»\c\1dÁ\eãõ\9d\8c²Vgpë\144\16êK)\90á\8c\84\91½Pýò¥\98£\r\11N°Ø\1ehÃÚ\r\9a\99iNâ\9fH\ 2×#+\e3êk¤ýÓÏ|äoû\10P¦õ©WeæmpÕª¢ý#\b\ 3\9eüøYѼ\97Ý\8bÓÇý"[úùR\97È*\83\1c\8c\8aý©àÁá·\17\9eÍ\8fYÒ³èü\9cF9×´\19Ù%¾|Íë\ e¿¾µ\£ø\f\9b\15Ö'ýõ\86\13\80\89{\1aÏ¡ª@J\1cïí@xâÔ%\1e\ 5\9dîÈÝ\94\1c<4®\12IéÙw~â\8e\ f±=\86!^¥Õ­è\8b\81-\8f\16\8d!\vCP\95Ï   à\f\87¼ùºÎ3.tç\1dã&Ã1\82ô×duÂú#¥ÇÕ¥&wÄ~¸|\1dr\95â¯;yO_\8c7³±ÿ\89;R\17JD³Ë\r­¶\14d\fÀë\9aÃ:4ÕÞ÷D\87eh\88×j²²Ù\93ß\1cLmN"?\ eâ\ 2ø\8cm\ fõ\_Ý\8d>5õùJ}7­\82¤Ômék\9fä\9d}%G-wWκèÇm       Z\ 6Ú÷ö\13¬\1a\9cJ\91Àê2¢à\82ÕÎ\16\93*_Ôó-^Ó\956\89µ>\1aÏÍ\89¹"È\18\87öÓlCK®Ücr\b\83\9b\14Ø׺!)³I\82\86\94bïí3Ç\8aèQÚ h!¸<#>QÃõ¼&®EuK\88\8d\9bî\8e;Õ¢.öÚ¸c©ù\13\99=b:º>ÿ»\18t\9dóÍ'¸\86\8fD\8eFöY\v,{ð\8d\98Àb\7f0o\19"²¹âC¼Ap£:\ f¬\a7\ 6FFê°M<\ 4\ 5*|?\97E\87}\8a¶a\15»wk\v\17
+f\8b3fgÈ\ 5®_\8a\fS\16\8d\ eÅÞ8¿O6Þä:\e­\8d\95ªÂò·EÊy*\169~\ f\1a\ 3"Ѫv¥\13aÚOå¶Wë&×pª5y}u\ f
+L¯\99%
+DÒ\eÑï\82Ñ\ 51!¾»ZçGF'\1fõ~\90\e®òÑV\89\9dR-\Ýäe/¿Éõ=ÌÉj\18/w\8c}\93ÄÁ¯F¾\ 3ÃßØ\98Í\84ëɳ©-Êëð\83\99|ÅY    #\82¹ã±õÁb¨Õª/·Ô(Ò9Éq%\8dOõDÇ\87\94¹±³p\ 5ÀSÖgÖÒrôÅ\99\vÙMS¥\9a²å\8b÷õñ{2fä\12ó\83«\8fÂJ\92¾¹§\92hI\96C\111)\92\8fjQrù³\12x;[^gu\82È°\8aYÝÁ2\e\9c¿iq~\ 5)g£   \9a\9f¼ëDuôV;\99S\87ìsî\9f°\97\1dþ\0ïzåUð<õ\81\1a<ñÕ·G©_Í\83\9eÏí9O\105¦E»-«&\97n{\1a£¤üý\v\145Í'¤b\0\8d JÕ\82\84¨··¬_hd\r\89\15\8e\ 6'\10\88õìÒP¶övåab\85áîMu\9a(îÒíTi\97\97×.\9f\8fµ=>v¤³<ï`\8b\0L\87ØO×\149j¤d\9e\1d\¹_v\1eÛ|m\ 5ÇïNýìcFµí CnZ\89|\a\vþHòlßù\8b\10\197g\96\86tî¡Ïòܾ\11q³w4\ 1ù½¤ ³°]½<Á,éÈégú-[\v\ 3ã,%û¶hú\1dîétË]\16\87,\90\91¦3\16\92VÉação­¿lÅj\90¿ø®kcóí\98\9d\1e\1cÂPW²\19ÎC\ 2\13ÅëÝ«æoïP\1d½yºÚKóvµñý5VØ[-¨Ï©åâ\ fïF\99Ô\1d£\7f»·¤\10¥`\10]¹ÉSI^­ö5úÊ\1a\ 59ò)\ 5i¿Hüµ\a\18\8fY\1e\86þ¤kcý'h^\1aCþõ\ 4DÍ8°Q\82\ 4¿\14¼\12Himós¼z  ë0×\97\7fá¾\18T2 9  É[È4oÆ?\bòE\9blb[\8b\1cH\86!F\16\8b\82dÇî¤òÙ¢«tãQ{y\v[  \8b\93\9e]#\ 3\12×8et\bzáÝ£°RØ\93\85\eZ_áë\f<>{}=ÑrÖ½ÒÚÂM\1c\9fyXÖEÿû5JlÐá\ 3##]Á\e\80«YéJO·äb\15£*£¢\9a\ eõº<¸\18&\ 6ðÊ: ;\8bÏ)U\ 6¥A\ 2ÏFÖùoªé88\f·Ýõðªg@b\82\7f\9c\128\1e©î\9d\86\16\93Öw\19@lVn§ëo\9f\88wÏRF2B\ e\8f\95¦tÚ¿¯ïêô¹«\8bÍÀMx[¸\99ñ\9d
\9ed\9aã³SßêÒûqðnÙ\83\8e«8.ç\\1fd«µ/5Ì\99^\924ä¼\vhC\94\87ûG×FD3¦\16\ 4\¾èu4\81\{\b\9b\80ÇðØI\9a\17@üH        Ä·\84\91\8e\8bñ\1cÌi{]ï6k\89\84ºsÓ÷`<ýsÛw«wyì\9dß%·ñAY|ì«©¼.\8a\ 1\1f¢u«ãåDï\10U\19jG\94\87A&Åp<\85m\8f¶I¥?\16+ts¨âÄ<sÄ@ª
+a\ 5&&ER\16Ç]/\88øXÕ\1f=\95\19¼5é\8a£ÅMH\9eß\ 6©\81úhY÷\90ñôÓFC\\a\16ß9¹-ø\fHmñk\8d_Q÷¼ZÜú\80\81\94Û\85{¢gj¾èu2\8a¡p¬³ª³ÌÜC\83ô¾\86/X\97\93b\98ê\14\87g\aP\8f\13\ fÙ/Ífû>îkê\e\1f\18\93Ó\7f¿/)¨"®Yk¶äþÕY·\87!q\r«\ f\96(¿|\ 5ÚTÛ\eȪX\93S9±+\1fz\85¥U°°(¯2s¢P:1¾ê\12M\8fwÝì\8a"~É®¶Ue¼\8c\1a@ËY\8d°¦eÍy\emS1ÉÝZ¤\93òÒ¯óö±b\9c³goQVIñ\ e\8d\15\83\ 2o÷¨¨Åܳ.²\8e\14¥5\ fg\87«0våg¾\919\8c\9bk\8b\81æ¼®ó¡Ô\98\8e9ªèsÐG\9aF=°êY
+¯=»rÔmN\86'o\1eΩÁ\9c¨ó6]\9a\9aL\9cNò3±´õj¬:aü\96óM,\89D±óãÍ\88F¯ûm\87]h\7fWH\9e       \97\90ñd%n\9f\82úyEï¯ý|\9c\1d\v±iwé¨ýÍ\89T]êΩÝÇ     \8få®U|C\1cÝmyÑj¶\Qæ2л~ã½î\81ü\1açé;iéÍßÉï¿Þ@\85Á\e%üp}­ý\91Ȧ\8b\18Æ ¨ðSÇ_®©º=öI\8aõ¾®G\ 5ÖÂVáÏ+m\96\9e\9a7NÂõ"/\1a\8fùXÒ\fѱ\1c±7û"\1eó\14E:eµ\18Ö=;Ë+ß\ 6n\90\99\15ó×Àöf\85W,á\96G\9f:W\87\ 3ëX\89\12íÎ\11­_\14çÍ\95        ª¥\86û\ 5OÍÝÚÄ\8b\r¡\96é*EzÊ\9f*\9cq®9xÂ\9e²¶£3§~\a\1d12°
+endstream
+endobj
+2897 0 obj <<
+/Type /FontDescriptor
+/FontName /FAOYOQ+CMBXTI10
+/Flags 4
+/FontBBox [-29 -250 1274 754]
+/Ascent 694
+/CapHeight 686
+/Descent -194
+/ItalicAngle -14
+/StemV 107
+/XHeight 444
+/CharSet (/b/i/l/p/q/t/zero)
+/FontFile 2896 0 R
+>> endobj
+2898 0 obj <<
+/Length1 948
+/Length2 3439
+/Length3 0
+/Length 4056      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\92g\S[³Æ\ 5Q\90¢ô^6\ 2\91")H/Ò{ïÒÁ$@ $\94ÐE\ 4é\b"-ô¢" \ 2\82¼\82\82\94\80 ] \94`¡#]±ÐÑ\e\9cãõýz\7fûËþÏ<kæY3KDÐÌRR\1d\81½\8aÔÁbp\9200L\11Ð4Ö´Ô\84A\ 1\18\18J+"¢é\8ftá°\18-7\1cR\11\80)(À\0õ@\ f\0&\ fÀä\14¥e\15¥\15hE\0M¬o¨?ÊÃ\13\a\88j\8aý\14É\ 1ê>H\7f\14Ü\r\ 3\18»á<\91\1ap74`\89\85£\90¸P0 \8eF\ 3\16?O\ 4\0\16È\0¤\7f\10\12\ 1¦\85Á\0\ 4
+\8e\ 3®"=P\18ZÈOKú\18w, ÷W\18\11èûw*\bé\1f@6\ 5\88\92M\8a\ 1d\8b\b,\ 6\1d
\90î´\10\13\17\92ìäÿÃÔ\9fÅu\ 2Ñh\137\9f\9fåÿ\1aÓ\7f Ü|PèÐÿ\95`}|\ 3qH\7fÀ\18\8b@úcþ\94Ú"ÿrg\8c\ 2}þÌêãÜÐ(¸:Æ\ 3\8d\ 4 \7f\85P\ 1\10\f\85\83{\ 2înè\0ä¯8\12\83øÓ\ 4yr¿,@\f-l¬MÍ%þÞ鯬\99\e
+\83³
+õý§îOù/\86ýËä    ù£B\0\a(\18
+\85\91\85äïï?§?ºicàX\ 4
\ 1HÉÈ\ 2nþþn¡´ä×C&\19 \1c\ 6 0\bd\b\80\f![\86\801X\1cù\b@\9eJ\ 4à\8eõ§ý¹RY9\0¢ù3ô\8bädȦÿ%y\0\ f\917\b\87`P(\0\860\0\82ü\rÉ\85Pÿ"ùò\10ÌoH\16c\7fCi\0âÿ\e\92Ï\ 6ü\86²\0\ 4÷\e\92M\ 5ý\86
+\0$ø_\94"W\ eý\85ÿ½\13\r\rlH8¹\97¤\94\fyBP99òu¡\11ÿG\a\ fô÷Gbp¿\1e<y±\7f³;\8aü\f\90È\10$\9c\964\81\85+Åxá\9fÆU^×¾÷úá)±\0ÞÜò\98\81ÖØ\86\%ðú{%f¢\7fã°\15\92ÿ3S,\93\17ª\8a1{Ó°\1a\82p\97\99åzª~­'Ü\12\12;ÅÔÃÀ*V\9agIý\11¾îèLùª¸\9bpΧ0ñ\ 3I`Ñ·Qâã´Ð·\99 ÖSµF«0¹»\\9bIT\95\93\13Ç_®{G\ eÎ\92èr\10BKÙ´NÅÍFYH\9b\95\99´þ\83\r]ì=,©ì\15\87cÞ7\96ï$.»Qï·\f¹
+ÉÅÆ'ÇsU\8eÎ@ÅBÜç\ 6i¡ëA\94\19rig\87ë\14èËÚ;K´E©LAÞ¥á\8bñ=ù\99\aÝ\13z:1/ÛÖâ[\ 6\82\89´#l\16'\9d³\16\81ÔS\89ù\9e:Éò¥&       ËI ð\1cj,/\1eUVÛ"êìÀ\96ú¨8\1dË\87¦»ÍgKêä\13©¹À,ÃYx\91\ 4¶I\9c\15\84\0¥\94-\ 6\8aô§V=4\f)µ_\93ö½\92X¥ø£)KÉA:zIâà\8c\1a\9c\16-\81#"-@X¬hõÆ\8aÙç\93\83O/dC4Ç\1f\84tih\ e®\86X¾è®Ò>v<S}Á¸61½ø\8a\0Áp¦;9\9d\89Ѻªì³\8fd÷5ß4¬\1f!+\98bÂþ\83Î\ 3z¨Úr¿ð³ÈÁjªø\1aù»\14\87\9f\16yªF9¹¢Ê¹Ô¶?Pïó;½ê3ëg\9fò\95äLµyÍJ\82\ 4\rÑYT½¹Ã¸ ,?Úüeù>]ø        \17ÆfÍ\10æ¾îM±ì]W\9fÞ«]ÇóÔ?¤.DwjÎh\r½üqºÌ\11N\ f¬Öð0ðÚ\ 4\ 4*k>§ö\98pâÑæí\96gH~Òõ6jå8©<\7f5C0.îs¡2IÄÆg<þ\9bzÉ4\ fogË\1a\18\1dáÌȾs',^\80ç9Ék\7fÅ#À\8c\83)O^`øÒºäe~ß\8cã´ÁÇCĨ[ÇE\0÷IMú\r?Y \95\8a-\11v\88¼æE¬×\13?\e\80Ã'\82\8b2%¿¥&ô}zu\9eç\8b÷n\97LÛEOE\ 3ð×þ\95+@Eµt\1c\9b½\1a+\94éya\90X¤Îû\9d¢>íì\89žª=µ;ç+½\f{\92R^û\7fo´{\90¤ÕÊ\84\80'ûd   ên)_½\9dG ¸òq©\7f¸Ä\98©Z\1em)ÞÌÄn)>\11öq6ðÖ)fõ\ 5\8a\9e\1c\84î:Å\8d6\8fÜ(Ã5ãöÝ\v¯É\13ë¬\ 3\15¼çв\9c¸×¥[ÀêJ1ì\171oßÑj¿æ\ 2áåðK7ï\12\e«\19)Úë\9dîz\ri\rm·\7WMì\ 6\eè8Þ|\ 4ZÑúÚq«"p\ 4Ê£;ÎÔ\9bnh\9eÀ÷m/lJ©ar\81ëû\8fRFú¸\97¬Øàù\84®\83¹Àæ\82\ 4:çÊ\87öâ±\9d\82´)Åj\ f1\87\8dä4­\9b]\ 2\8c-󻾤\89¾![\13zT·¡ZÂ\97Ð\11ü\83óBì4tã\93vMñÊ\144E/2Þ\8aÜ\1fX¾XBe6°\eC3Ú¶\7fØ£ÅÐbAAÙ)\82G³q0ñÉç\8fÞ°y´ÄüéÉ\ e\85\ 3\e\7fø¬A\94ç&£>\95x¬÷u6¦y)\1dýZq×HÉ\9dLïÄYí÷í\r\8b\91\92t\r\8bÞQ\8a\8b,~:O(Gyce\8bTõÅ\98\8ajópE·\9eÔ\96*ÄI\83çóãÕ|SN\9dúâh\81µþ\14\8eßÉ\96èé\8eðueÃù|l\b 6Ì1\ 2û1ý'\94äZ\eé\12m[w©ú\1a¡âÃs}\8eË\8f;\bl\8aZ\1cK\93\8c\9f\9a\19ST£j1rõWH6ºz\1d\11Ö)\8b¡ê\82\87\r\16\8b\9cR=ÎÜØ&\ f\9eÌiÁ¡7©.ð\83æ\0Ûg\94\15Û¡Ë2ò®\17\82\ 1\93ÓéI\85Ϩù\13\ 67ðÄ\88\ 4\ 1±\17Ês\17Í\eÀ÷·ñÚÖe\83\99EÞNW¾¦e\r*MÕ¹æ\eJfl\84M
+ÓXЫÝjû¶èJ\9c]-ÕÛÇÆÆ5
+8¨öáÅkÒÝm\96[*\vú¬­uýö&M=C\93½      \83+9¢z   OfÔü\8e¼:¦V¿®u\1e\953bëð0+ù¨'R\8dLbûú\f^\9e\8cA/òÚ\1eYË¿ó\1d\f­¸A\82|\9dáQ\8eÚfd§qT?\97»ù2\94æHÚ,#QÆ´½òÞ°'cÓþèÔ£®þý¡\8eÌ\13Í+w\v\947]/\87¿ÃÃ\82ú±éÔ
+ÚÚÅ«*o*éÌoj\v?ÜWØf\86­\fç
+\19\92ª,:ÄÊ\9d\9b\15n÷ò\9e\88k\1a\15\16\12­úr/Õ\80\18{D\aê/1\18Ò\1aÕÀJfî%¶\8d­\rþà\85\84GOÙÁ\1a\9f.\ 6/,\rßyÕ\r\93±ÈÊ.:Q\96\9fr\95QÊâ\fãò\\13ÈfÙ:¡\87ÚY\9dZJû¥¡ü{\9fqÅ¥»ê¹g\9d\7f<\1c¢a¹Ó(Õä¬\90`U\8e\8f\92ïè]\94h\1f^\ fêð\1ag]\88\94\81íç\92´Í׶{­\95\9fû]H\93½tZ\87\9dWÏ?fÚà\90\84ÈÌáK o\93Èpp\80¤\ 6i\17=SOµú\b\14\1a\ 6\r\ 6W\89\1e\8fÊ2mß\95ت\90ZϽþl(~L×±ü&­a\96Ò\ 4\e\19\95Ö\8c\ fyo\1f\7f\ 2«ñrv\fu8MT\7f_°&&/Ô\12\13\19b\v@\12ª¾ªÉÐh\e\9d\11\96'\8a\95É!{\vÇ£Hëµ¥\9eÇú:å\88\86e¹GkQ[ð¦tU@à2¨\89®§ðÔ¦NÜà¨[\17\81Û\8cÇl\îÝò\13:\9f§ì\9b+\ 6?\9e9á±&ÅÑ     Ia³\ 4ïÏÉÖåW\f\ 6Çó\95¹"\ 6ò¢\9eÆ\1e¸\ fIM{'
+¤ê\\1eQ\ f\98\1c«0°Ìãÿz\ e\ e\9aÝ\8b»0°øyRjõ­\9a\9eÙnô\87åÇó\95\99qç3ø©dKé+\ 3/\1d=%\18N\87\1e~Z5\18Ü\eIÑÊ\f?"\r²Ì\17Rx\9fâ#õ¤
+ï?ÌaÚªe&\9dô(\13dLe&z\9e\90ÚÙoÖ¼à9ÓJü\8f÷\fÅ\17ìÕ¦æ^6#×\8bh«®âÂ\16\82¦R\1e;þ±OúS\9fA§¢\85sf\fK·ìN                n\1dc~(©¤µù>\1f ha:\98WJÇ.*\f\8aé\8dm¹3w{E\9c}ÿö2ƨ\14º¸î ¶bÚÏ3\9d/Zµ!1SkI\97>\90,þh.Òü|\ f\9adOÄ\1eÑ\12\91*\ 3uÑÁ\9dßs\1dEz\ e¿DR²\17\88KOÉbç%à¶uø¬\ e¥\ 5Ó\9a6\ 1Ë3´\88\92¸â\86É\11\1aEs"¦I~¨n¨8k>çã\996\ eJ\9d4·Z\ ek_\8dðøФ©\99\8f    ÕÁ\167'ÑÄçD\94-\93\8bòQOä%\81Êø×Í\1ew\9aÇâè\ 3\rµ×\89\92;@dNà¨P@\92\17>lïYéc\9ec¢þò\99âäùÀ\ 6\85*Óö\djX\á;N\ 4\95±Ò«KöBXF\ 5®\ 6·F^>ßø>èþskûÛ\94Å(\949NCô\80i±t§ÆJ­Ð­PfÇÅÐ\81%1¨îJ\80ÊcZ×ø¨\17-#'\91ü7®T\18Ñ\851\98\9d\9d´\99AÔçȵ§©M¸Z:7Wé$»\17­±\8d\95,Ø÷KO\85;ºs¢å4l\9a\93
+\8fäízR¹ëY\8b\e\89\8d\89ÓÈï\8f³E@\19Ã4\11½\R\85N\8c\ao\11::=è\r¬tíáÉ"ñ\90=p\80"èþ±ø\9bGo\, º½\Q>+%\15Á\ 2<Ïx\1f=mÙJä³\85sl¸l/Ê\1a\91rÍU\83YÒ;²*/YÈ\vß\9f'¾³Ò\8d\11\9eí\94iÍÎa¹v        ·²6\ 6ÃwÜ\9d\81ɦóf\11My´x>¶\158-ë\16\88ý<ÞIÊ&õ©ºäÎ9tÍ·\94\16pí)Í\ 4Q*æ¾ñ\19kH9\9dGgõ\1d¤\8a\räS\19\82X$h³»\96}<rέ8Í\94 Ì&\96ñõò\9e<\e¶¦X1s?µØ\82U³Ë¥µuU,¿\84¿¡+ÃF@\ 39\14c¢%ãBpÚÍ:R¸ý\ 6W{jþ\.}EÀüV\89iÊXc;ÕØtEP­Fom\94tâÃþ]ã\9dëu¤\9bfpj\9a\88/ëxa^ªº\b\15é04Ñ7     FL\80<ñó Áé\8c\8ac    VìÒzcBvìÉOb6\98e\16fí¾\8d¤4P¼\9a\rÚØÏ®K|ÅUW/|áÁy\82Lc\86\ 5|ä¸\82¹þÖ\9d-\13JÚiJB\17\7fÊ\9d¹{Ð\rQ\15\9e9tÄ»:Ð\ 2O¸`¼\8båNgýÁ7![Û\18é¦Ñ\90öv\8a\19Ú\ 5\1cwtY\8bdzꮤà\10:g\8b\880Ïäbµ¤è¯,·­a\7fÅ·,y$cG¿\120ö²\8ar\15j\9dW\9bÏ*`u¦f
+\9c710\1e\99\1f\1ar|Ó\11ßÔ\8f\7fvæ&÷A\13§W¬æ!)Gt¿þÓÈ}9ï\a\84\96\ 69Öã\1f\r\9fsÞq\96ì)¹Í'\16\13\8a]×â\ eÆø­®\7fÆh8û¿
\9dt\ 2u\1f\9em\97FËMl«¡\9a¥òò]Ò3ð\9e £ä\ 50å`Z»      \88\9b\81A¥$,M NÄ\6&ê¹ôõ¬7\ 3[Iõ\94÷ù\9d\ fßóÆ\ fì¾Éòô\96kÐöiLGÀî)\9b{í},XÆ\a\ 5¼XÔg\0ßàá®þ\9e$÷rܤÜú@û&iã~Ïë\92\8c\ 2§»A9\1aü²yâàÜdu\16ä§[nÞÙVKe\8dú?¢\8c\97å\væ\9d'\ 2\93Xï4\9e½5\9e±É=wÃîàvz\ 3kEÇ\96\8bäìIºÛ\12\18¾\89\83\8bç_\96ÝÐ{Ý\1a\9bÖz$ð\ 2*1ð¡¸D¯Í×ÓÏ0\84§<n#NÃí¥\ eJaƸ\8cÏIÐõÜ»"\8dÖ\83\9a¢\8dÞÇ+ü/\1e]æ¤\17ζË~oT1:ÙËÃ6\82á<\8f \19\ 2(\9b\8e¤\1do»r¬Q\11z\97ö@¢=\97µ\11Ö\93ië5Rpº\1c6\95ÂQp·rù!./^ #·\84@\9d¿mT_·ZO,Ò\eÓ§Ô<APZ\92\81`\84®ê©¸ :Ì=\86\85M\93\99v\8f\19Ë\86Ó¬62b4\9ey\8e^±©\9e¼\9aº*\81¹\9b|ò-7Ã\18ߨÙÓy[¯ ªv\eÝàDñÈ\83\8b\í¤©\10©\1fÇB|£Ç\8b=\1e\12y@\ 5\9dV\82æAéÈF\ fýN)¯\83n¥,\bi\18u³¶Ê^F%\87pGÐèÊW\ 4\83\f½\7fe|q\ 6;Á´Âv\80)_ ÆÞa}ëíiÀ@U)]\0Ä\r\1c\15ü\90/\1f\1e\10ªiðåø­èÕ\94\13×>\1de\88×E¢£ÃÊû¤9$¦Ï\9eÊ/d\1c\18í4ÓunÈ?yUñ\7f\0é}èB
+endstream
+endobj
+2899 0 obj <<
+/Type /FontDescriptor
+/FontName /KRVUOQ+CMCSC10
+/Flags 4
+/FontBBox [14 -250 1077 750]
+/Ascent 514
+/CapHeight 683
+/Descent 0
+/ItalicAngle 0
+/StemV 72
+/XHeight 431
+/CharSet (/C/K/N/a/d/e/i/n/o/r/s/t/v/w/y)
+/FontFile 2898 0 R
+>> endobj
+2900 0 obj <<
+/Length1 1296
+/Length2 3183
+/Length3 0
+/Length 3906      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\94y<\94û\17ÇÉ>¢BÖðØ\19ë\fÆ\96-\8c¬\89²$e\9a\19\fc\861\8c-[Ù%[\88
+Ù÷²¯]K\8b\84\12\8a2(Ù%Ù\8aÄor»]uÿý½\9e\7f\9eïy\9fó9\9f×9ßç\11\13²°\92ÕEá/¡áx\1cQ\16"\aQ\aôÌ\fl!
+\0DNA\ 1$&¦G@#\88\18<N\1fAD«\ 3\1055(`ì\8d\ 5 \8a\0\14¢\ e\85ª+©\82Ä\0\87\1f\ 1ãìB\ 4$õ¤~$©\0ºîh\ 2\ 6\89À\ 1f\b¢\vÚ\9d¢\81D`\ 1+<\12\83&úÉ\ 1ºX,`ù£Â\v°D{¡       >h\94\1c\b\ 2\ 1P\18$\11¸\84vÆà@ò?,\19á\9cð\80Êßa\94·Ç?È\aMð¢\98\ 2$\7f¸\94\ 2(\1eQx\1cÖ\ f\9d@òæxJ34ÅÊÿÃÕ\9fâpo,Ö\1cáþC~oNÿá\bw\fÖïg\ 6ÞÝÃ\9b\88&\0fx\14\9a\80û3Õ\ 6ý·934
+ãíþ'5""°\18¤.Î\19\8b\ 6\14þ\ ea¼à\18_4Ê\ 2CDº\0N\b¬\17z/\8eÆ¡þ4A\99Ü\9e\ 5ù³g¬N\19ÛJÿÜé\1e´@`pÄ3~\1e¿d\7f\9d!ÿ\9e)ó!`|\ 1{\ 5Ê|!\94DÊóÏ\9bÃ\1fÍ\fpH<
+\83s\ 6 Ê0\0A  ü@\94ÛC9)\ 3\ 1\10\0\83C¡}\ 1´/ű¼\1c\ e\94\0\94¡\\ 6\9cð\ 4Ð\8f\8d \80ü%\ 2\ 2\89¦¤QÀ^\f
\19â\9d\88\970Îο\88²ê~Bü\15\87\8b»cPÿ\16ì\97"zü\eÿÙÖ\rMüCJYé7²Ï\96²Âod¿\9aâ/²wãöË)ÿ\8eöëA~Gû\ 4\91h\f\16ócý{#øET~\91¿;íC\10\ 5J\99\13\16\8f'ü(:±\8f\8bï¯\80B\7f\aûµT~¢½6ûÅ\94÷\83ßÔ\14ÿ ûä({ó@\10иÿ6RûIþ[¤J)òòvwßû\ 1¡0^\1eX\84ß\1eüïm?q\ 2ï\e \vU\ 2d¡j\94»\0Q¢lQE\ 5zù·L¤7\81Ò\87¸÷3¡|4ÿ\9c\9d0\94O\8crýÐHÐÈ+<RãªkZ]Dq\90\8b\12:0õ      çú\ 4óê¶\81Væ+Ã\89ÔØ\82n\13OðX\95íVi\ 6;ë4Ý´ i\9bÏ+¦%ðt/üS¨gBúÐδ\8fãt\86\7f#\9fíJ\86\99ß\94\87ð\97+\v\87\9aë\ 6×\16\95©O½\1c{V\9cb\97÷èöòã\85\1c\vIý33\f£BTíö>5í\99Wa*¶ð\fìÙÈð*qE!ËÃé\9eÅQJ\91dÒá\94$Zòó+A®\91\8c\rÒo?ã[¼Ù¶r\19³\93wί7t?.|PûBØgêÈn%ø\1dÏá1\ 6¼(\84?åE`Y§ÈªcT°@\ e\1f¹0)x\15j\17ñý^éxW¼\89ÎLz´ÐÐéEFç\85ný6k\9båÑD­\0\ 5ÚüÕw\8a\ 1\98È\9d\16\83Íè®Q÷¶r\9b \ 4\17C'\18³+\82%\9f(}VhW¬¹*ü`0Bín½¹)ãÊÌá÷Æ7W\r'ÖÔL§ÍËj\8dlpÑ´æ\96ó\ fìì\9f¢\8eºß\8e\93.=däd~\83?\90W\93+úa0Í\13:^äÐì8íV\99¡²@X÷\84\9fq1F\ 6\12C,,(,gj(ö=.r¡}^ÈZ\9cïz5$ÌÓ`\fb\8f\1e®\vP\14ù\82\98\10i\1625u£\97å\93\14´Ð}á\ 2É2:BwÅgøS\93]\94I.$Îþ©õÕ\95Р       ;¾¶þª<;0{ð*5\82\8a§¡\f^\81;ÙÂ$\10\15¯\1férÅb®Ü\82¸tò¤Ä±\ fe\9d×âZ®kVK²\93\87ªu+3\9c¨%y\9bT\8dÓbÓOª#·\1fÚ¾\98l\99þ~\855\88éÞÛt\7f7d=\u;K(?ÎÅð\ eo¸°µÇë[ä©2fÒzqJ·\aóÅC\9f7\83\1fk}\9f\10        U^6¾\rtò¤ß\aO8ùt^âà-ɽÑû  d4ÁÁ¯h\87^ù¦\9bn\94v³¯§«ÄAÌ\12åk:\0Ò
\11\15ÿ­\83\1eD~ÝôðÜÒR﮿aQ<fØô\8e\8d8g{\19&×ä"\vËì\92ùx\96ñ\18\v\93èðP½Ö²yy°AZ`Q¹× Ù`\8cÇ)·Aì\18M\ 4§©²m\bY\9c©\8b5µ¿4âX\92\1d1>}Ã\93ß\\94WüÎ\90ત\12\1c¥¾ùùZ\9f\91·ò\ eZ\85A3J/\1f¼\12Ùô\9a¾Ê|­\@游\13Ù¬¿½K:a\96´±"M·S·\9ctuý2[y\12w\9fU\ 5è¬\8fWiu0\13²Hõñj>< Øü\98êç0Û¸©Çn\ 6¦:ôÕE)\8bº\89Tgé£Î\12¸",\9b¿\0\8c\13$\9f®þ&¦þÓfª       "g¶Û\90\931\90l0¶Kl!4°º\e\99õ1R§qÄ\8e¾\13§^Ú\94\98vjÐþ®\a]»TÞ\83g ë­­Ï_Dì\ 6³2Þ<448&8Ë øð\85·
\9ba­z#®kQn¶á\91þ<e»\85\ 1\8d\8fÔÌæú­DÞ¢\84;s\930]ëÊ\ 2KR\85O\ 5¼yÐ\r\ 2e\15\8cï'h\19§ur¤ËëÜ«4!pK°EC±\ eCví}Ú³ñµ\ 1d\8fÙD\eÅ5;\80Á+¨öQëúè\94Hq8\9c\1c\14©ü!\99ÿ%¯ìº¨d\93LOR`\91¡§l\8bårT­ôÈ\81Í»¾·²\17\18Jíâ.ºl¿Ywhy²¡¤}\91ô´`ÓÄñØpËr·\87D\8bÃ\aþñ^>³P·ïøÐá\8fŽ\ 5Û]OØ\9bêÊìB!÷¯\87ÿ\95«×a©çrN|Ì\16u\8dºU§'\86çCýÂ\1aÓ\røáW³Í©w\ eÒ¾ì:ýÍZ!\15\19\ 5ßöldµ0>í2»\10¢[\99ú%µ#?î\99"OÄ[\82\8aCÝǸ°qß\v»î¾Ýì8\ 6\92[\ 5Ø¿d±WìdjTup¨\\19ú\8d¼xHä¼Ç|y\195\f
+sM\16ynWŤËÁÒ\96U\eµ iõÙv@\86\rýD=(BýÓýæ{|\16îSE£Lk^ï\1eÅ\1c\1cG\ 4K¯3Ý\8f+÷Üa­r­ñ\19\9a©\97\90\1dç*\8dãÉ\88jmý²\88ãM\99¸ê\12ÿ~ãÁÝ\15/\9d/c4÷\87ã\99Ûc\14ù\83Y\eFù\b´­²í°\ 1\11\93\19z³Íç¶R\ 1ùq¯¿çeæ³(*϶ÇËèï\84\95\v\835@\1aYÜ<,ØÑëPµH¥¬\ eQj\ 2\813F\13fòp.í´6D\83\14\ f\1dcÐ4Uó[=ß\94©UPmæj1\92$}UÌ\96U¾~\85ëÛæÀûo\12\81jq\8e\8cNJ \93\17²\87¹Î\r}®på°ì\86o0*gl-$²\ 5\7f\88`·­¬Ki¼Î\89Üõa_zóÍ\8bv×ò\16\95\88Ù\826\95bÚÄÍÞî*]½þµ©\ 4\9eqa\87ïïÞö1¸\1dÈ=¢æ\1a]q\90\93\ 1g\93Äk·\eêxìP\8d#V\90·nà¾ø\96\ 6MPË\99\89d\9eW\8b\1d½]\9br\8a5G*È\eù\81Ì\MøtMÉâ\92í¤R¥¡\77ÛIí\97\82N\91Yç.à\18óè\9a8\19èî.LJçæ\9c\19_7ó\99\93Ô'%¶mv\84;ª¥}45Ö\9bN:ê\92\98¢SÃÞ¾ÅÆ\81Ð\a¿æ/üüúL\91z\97$Kµ³°ÝØ;µ\vÝï#MÃ\91Y_\8bK·­OÝN\9f?\97Îæ\11êcX»0g¼Ý¹BO¥z&úB\1e\16ÝY÷\ 1!\8bçøl»b\97Ä¬ü,\ 6\90\18¸þé\rAÙÇ\a\12õyTôk¨¿ÇVvª=\86¶¶9\85Ü\90¹ûáµÃTXÙ@sÁxÔì\83>\11#£hp~\85Ã\níòG\9e·\\°¹³\99\89\1e\82>ó#¢\18\95\89Ã(\v,\98\8d)~¾À\97\82\e˪6jc0"´\12«\81\ 4nÈû\ f¸æ\18Ö<¥69w"!\97\96Ú_ôô%Cæ\ 3)\85ÜÂ\9dtGÎ74nU\ f\99¼\18ãZ\f\93`aM®þÊ\8a¸\1c\v3âûXI\9dÖ¥Ô£   ×Ò\9b\8fí¬ôYÏ\9c7\0·³\8bø²\8d\83á\85§b£ã\ 4\98ÞAI÷iᆰð<u1´RËfT\9aL\ 2/Ñ:\1f3;\9f¬Á\9cÇù\8ec·Öñqµá3\92Ar\ 4è\13Ä\9e®­á}ô!\89í\90\ 5)+×®Í:M\ e\81\1f;J¦À.ø\81:}£@\92ßÒ¤}W\7f|ܹCrp¤\ e\90¨cB¬ôde¿ù©¡\bZ÷Òr%\\ 6%¨(äïv)aG\19\16\94Bob.i3ð\1a6i\9cáÈ\99]E¯Ö·ò
+6&A7$Ð!Oÿ:(ýElcA,·\1d¤\9eä\91úY\90Ì1Â&\aÓª»²%_g\94ÉS²;\1dI?ÿÜ \15u!©DÜU§Ùõîuá\82        Â7\1aú
+¼Cå9Iãí)zø\9bË\1d\-x\ 1m½ö\8eè\aðëçÖvº\ 3§ÉùÐ0    ëøcn\e­\ eÍ\ fËú\e.¢n\ 5I0\1dëá\16\vÉÑ`¶7#   \17\92#O\ 6°&\1f¡\15\ e¿ý¸s»jé廥¯Ob\aJ\89\98¯Õ¹\ 6\98Ò\ 6ØTüÆx\ ez(ÕCW¶ìfÇÀC¾ùÆ#O®ðÖ±®A÷aaí^­k\1f¸©\1a\8bËb²]ênPñ'ø\17\18¤\1dú\16ÚB%Õ\89\ 6[<ìò[ï\91\98L\b:úJ<\8fËÜ\86ü,/\87æjË\93B¾0\ 1©\12í¢ÍW)k%m÷\9aÓ£\agȤ{ì\ e\99\17IÏgÆ3\82\1a\13\f\8bÌ\91\8b\81ÂMµ,ºO{\ 1¡.Í'öÎNümTâª\aßð\87\8d`­VZ\ 2/\ fscÎ2J`ý\9d8\94\8e^K¹"3®Qåõ~tÐ
+\94<\8blæ\\8e\ 6¹\8b\8ajf\ 5k\81ü\8fæ\84ô¾¼B2¼£aÈc\80î9ª\a><ÒùB}\8d\90\97\11\91\81|\r\9aÐ~¸\9cöåÚnÖÒù\94\9a\89\fCýV|£TýÛÆ\e\9a\19tG<?:~eMè\93ÖU9*À]\88n\9c¤y¦È\12ül©lz\8dÇ«9ÿ\9dK²4ºz\1dƱkje};N\eH?¾Z\92Y\cXÑ\91úLH£<\96\ 34¡?gTìLÎy{\90ºGV\8fý%h¹=°u\92£¹\84\9aÊ~ç\92l£¸Þ\ 5Cëð\853\13\ 2#M®/¤\12é©å\10ͳ·ú\c©\182JñÄX\89\93Ñeb9ÎÅÃ54ÝXÿ\1aª(I­×`Emç\9e\8bå\97\85Bg®Ú>\r+Ë}Þ@,\8d?ÑË}ï\91婶Þ~]w\83\90E1¶>µL\93Û^\vë¡\89c2RS\86\8fy\85"\11\18ÛDnñ®\13­Ü|+ É±/\1ffær\86·\ 6Ê/\17pj4\v\ 4ø³ññuIéÝþê1H\13w2\f¥îD°þ.ç\86\12\8c!F
+\12\9f\89ñ=éá?³~WN6S/\ 43\98'*·Ùf\8d\8bø°Ý¿¾#Ô\98%EýJ6U^<²?ÙVôpÐ;ï)Ë
+\7f­¸õezo\ 3¼/3çq{\18\f´ñòv®©V'ZFÞ[ö}Ð¥\8d\88\1eZÆC¼      \87¨Rº\83Y&¬Sÿ¸Ô\8d\8e\ f_:qß\91÷Tz@l}øEO\vºµS\ 5L\8bÌnª~\11Uã¤è¿hZ7èbD¾ä\1d\94ün©ÿéhÀ7)A´O\91¸kù£Ê\8c\ 4Éó·|²½ý\11
\96%êýCÑrî\1c4ª4
+\17øoÓ<=¸¸Ú$uDÂ&r¹\v\11üþ«bRO{\84Äîå2MjÁbvíúQe)É
+\1e3!\87-𧾻\1fU8S=]«FØP°þ´Î\8f\93\ 5\15:bÃÁÇ'ÇUþ\82_Vì¡}]®Ç&+t}è¬\14nnëÛ2ÕD¼\82B7c_\95\13\10Ô*"\9d¤Ïz¡G\96íTÏ\ e\99;óf\9b\8aû\\ 2\896HÎEpk AS¦­Õ¾íP«\KJ(xðÀ\89Jsƹ4\97Íÿ\ 1ÑÉÖ7
+endstream
+endobj
+2901 0 obj <<
+/Type /FontDescriptor
+/FontName /UTSOJX+CMEX10
+/Flags 4
+/FontBBox [-24 -2960 1454 772]
+/Ascent 40
+/CapHeight 0
+/Descent -600
+/ItalicAngle 0
+/StemV 47
+/XHeight 431
+/CharSet (/braceex/braceleftbigg/braceleftbt/braceleftmid/bracelefttp/bracketleftbt/bracketleftex/bracketlefttp/bracketrightbt/bracketrightex/bracketrighttp/ceilingleftbig/ceilingrightbig/floorleftBig/floorleftbig/floorleftbigg/floorrightBig/floorrightbig/floorrightbigg/parenleftbigg/parenrightbigg/summationdisplay)
+/FontFile 2900 0 R
+>> endobj
+2902 0 obj <<
+/Length1 1248
+/Length2 7610
+/Length3 0
+/Length 8383      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\94eX\1cÛ¶®\83»\13\82ÓX°@ãÐXp\v.Á!¤iÜ%¸»»C\bî\12ÜÝÝ\82\aww\97ÃZûì\9du÷ù{\9fúSïÐo\8e9ª¨É\15\94\19\85\f¬¾BÄ­,í\19Y\98Xx\0"²²R,Ì\80×wffdjj\11[\88¾½\89\95¥¨¾=\84\aÀ\ 2\ 2q\ 2¤\1dÌ\ 1¬l\0f.\1e\ e6\1e\ e.dj\80\88\95µ³­\89\91±=\80V\84.\80\90\ 5ÄÖ\ 4¬o  \90Õ·7\86X¼Ö\0ë\9b\ 3\94­À&\10{g&\80\90¹9@é¯\f;\80\12Ä\ e\r\84ÌÂ\ 200\ 1Û\ 3¾B\8cL,\91\81\7fi\92²4´\ 2pýËlà`ýo×7\88­Ý«(\0íß2é\0¯"\r¬,Í\9d\ 1\ 6\10Cd \9cÕk7È«\96ÿ\1f²þ»¸¸\83¹¹\9c¾Å_åÿ\9eÔÿñë[\98\98;ÿo\84\95\85µ\83\16 ke\0±µüïP5È¿ÄÉB\fL\1c,þÛ+e¯on\ 2\16²42\87\0\18\99\98Ùÿe7±\137q\82\18(\98Ø\83\8d\ 1\86úæv\90¿í\10K\83ÿVò:¿¿u\0\15Å\95U4Ä\18þ÷jÿv*è\9bXÚ«8[C\0Ì\7f¢ÿf\96?ü:$[\13'\80\163\1333Ëkàëóï7\9dÿj&f  ¶20±4\ 2°rp\ 2ômmõ\9d\91_\97è\958\0®,\0\13K\ 3\88\13\0âôª\18Èdieÿ\9a\ 2x\9d\8c;ÀÐÊ\16ù¯{åä\ 4\0\85ÿ2ý\8b¸\0@\91?\ 4\ 2\0ÅþC\Ì\0 ø\1fb\ 1\0\10\a\0øé\ f½Ö\94ù\ fq¿æ)ü!V\0\ fq\ 3\80ê\7fèµ\9fÆ\7f\bô\9a§ù\87^\95éÿ\87^\17\16¨onmüÇ\ 2z­ôõ\8fÿµËW\88ý?ܯ¥Áÿ!\8e¿ÈÊÂâ\1f\ 5Ù\ 1@\ 3\88ù?2X^\8f\ 4±¶31·²dùcd\ 3\0\8dôÿ\99ÈùÚÉè¯OõuÙþ\13Åü\9a\ f|\9d\87é\9f\8c×s\99Cììþá\7f\95\8f³½\ 6XþÑúz0ë×oÇÊà\1f\11¯jÿÑî/©\7fÊq¾ÎÆÎ\ßÎø\1fÓx­èô\ f|\8d\eÿïÞ
+\v[9¹2²±\ 2\18Y9^÷\88\99\9dûõr\99Ýÿ\9f\83­-ÄÒþï\7fÃëöÿ\9b\rM^?\18\bÄ  \ 2F\9e\9f±\ 2óú\99\ 6\14z\88e\8f\17ÁÑÙ\11'çû\r·úW'ó2\1d,óbOÛÖ\8d©@Hϱü±LM\8a1\13\8e>\95\ 2\r\f9V    j\85Üú\\95\81þsX}h¸t\99\b\ 3m]èþ\8cÞN\f\8bôà\9dy²Më:\86\93\ 5Ê«\95o­på2{,\Y\ 4G!°\85³3O\17\1ef\9e#«ó(I\ 6\94[       È:\19M2ñ\90Ï»+QC÷\87\12VÙVó¹ýï´S®p\9eç    :\7fO\9a-¡%\83B3da~%ó?"1Ó9\19®\8d ³¤\9a\91Í«\7f\aI+ó \12sN\7fþ\91\fxCÈO\9e¬.ÐPÿIö\18qc\82\ e´A\9e\8c:)åã\9e ©&¥zMT\94\89\r.$2ç\97È%\80\82Ttj¶Y\bXv\ 4nV(ú`\9bU\8c³òDZX×ÅS+}¹{¢>§
+\87½ÔyxX¾y       %h;\ 1»\92¿Á/\83VcàNýø\8d\96á\80n\98\99\0n*¨\8f\Cß8vÇ^è£ä2\8a`h¯ÅèÇ5·\86[Y\80\97\17îLA\10å<+ò\1eÏ\9d\8f\ f²\9a\f\95õ}1ÚbNo@\1aÝ\96|kY§ûÝm¡©¬ºâ"ZË_\9aUf\19úKjÚ³EqJ\ 2auúêÅų©ê\11­æ6\84ß\91\và\10ó¾Å\14ÒÞT\ 1\18GÌwL:E\1d\1a·¸asÜß\91\14óp¦O>òn\8d%¨öÕ\1dås\92xÀmù\12\99E0\1dªÐ»r\1fô~*ùâ<Î]RÕ7\80G\93h âƨ\98hV\ø©0ÀÂù\f\84\14_\ 4ª8e\81ùáÖr)Tßc\98a\e\ 5(§ýäyEO×K­7Xrf\8f\19¥ð\90õ\85ÉVãcs[§¥­åfÙ\9dë7Öfy=\ e^m£çI\81\9c\×HÏ\93³Yv\92`=d\1e\94µ¹\r\10\81µ\98K\82Ç\8bßõ\9c\84\ 3
+\96Xý°Ö¼åNQòï\81U\13Ð\86oK\ e\96\ 3%¿zé{\816\82òN\ fi\ f\84ñ\8c
+_Õë}û-æ
+{\16\91ó\ 2\e;Ưs\18\1c?3&û\9eN½áü<q~!±\v¥ôJ\få\93ÜÈ\8b±,A7-P\94í\7flj\12ô@\1eVjéE\83Ê\8aC\18\96\8f=\b½\9eö\16H-Pÿ%Ï\1d\1dÒO\ 3\90úü\v:úTÅRá±<oq\1c)\9aòêpº\98
+sQ¦\f\8bÍ%8b>ÕJ\12$8à z\e´\7f:t\80\85$\8dÓn7\ e\8f\8fhH\ f[Àð£\94c×    è/}m\ eh\7f>\vG\1f\990\0\937ð³z(Ï\85ýØ¥¾\8f\87+Rk±Éx§N^3=â\8fWcC&Eå1O¯ºl~tG[Ê\191IØÿ\ 6é[5\9a[ÂÚ(7{\ eAcA \8aðKÖýh²MÓ\9e¸ç\927BnøÒ}\9eÛ¾\16Õ×\11\8d¸{ëV\17ÒÙ/K;Kïûº¼6öZFXå3©?:\90o\811\96¯ýÅ1\95z7fìO\89¨É\95dèyx¦Ìô»\8f\9cIö~ä\84¯]¬I&ÍfúÍ\8ekSñ,\92f?\7f~ÔVZÄ\1e\ 2a|Ö\16¸WuB{û[\92     \v7=B¤7·bÅ\f*
+\10v´iJ¶\1ac5\80ÁÈß·\T\16\97Vzá\16Z\82\17À~òÒ;øÓ!\90S¢§|ì:\8bm\15ù¤xu8\14\1eÑ\fâo¿\ f0{\81Fîa\94Ú¯i\17ζÆÃW\8fj,£\86?\ f\ 69\87\a\17"\9e7\8b\90á\85\1aP\8b`gá<³ÞÃ`\19%\13\1cC\8b·Ðö\7f9¾ØÇ,$Ùe2d­]º«\8b#4\89ì÷<ë\80©@ÞÑ£\92\0ÈòÙ\1a\9cGC9¯ÍéUÜåNqb\86Û¼\19\9a\9daS¡÷ÞÅU.\84Y¼æ\8fM@\97Õ\86\89¯`â3Å\ 4´Ô#ô;\1fT6½1\95³]\8b^Vþô\86\ e¾D­mï\8e\19A\9cÊp²´n½êðm\12;\v\89½o\870¡fgϺ7ÿ¢l[\8eÓtÏä=f"éEeÂE4m\ e\8anÇøj-·×Â\1e\9b«\18{<Ê<Ã\80\ 5µ\81\8a_LP\9f\80\ 3Þ©×5µF\10\13]-áeÇ\9cE\13\12ÚSwC1N³+ì\82Z×·\ f\88°öº]\12\ 6\19\12]rVU½»\18{\11¨\16;&7,Ù¶¼e¤3!
+®ðé\f\96\1dYÄ¥­¿ÝoLÐù\v³BÇxßÕQs©áã_í\80UÆ2å5?!S9ËåDW¢\aÂÍiìÇd\1d{X¢\ 5@y¼·«\96\8cù%b\9fXÙsñ´(ß\ 1ÞI\e\8aa\90È4-Èu"jV\1døYýl\92ñy¦Þ\b\ 6<#\87\8d¶É§}I\93\1eY\ 3\0\1c@20R#ó6Ôm\82\98¢\19ZTý=\94oôâ".N\16\b\11\8dKºª\ 2ê\9cÈ+hl\86²EÌàû¡\80üñ½^[Âç4\8cD+\93\19\f_`ßa(Å"ྠ\8d\aIIcXo¬\9bþÖÐ~ôª\84k×îá=T|ðMbG VF\9a®CÙOr\1d\98¥À}hÑ< Å      QéÉ §\96ùæ\ 1^U¼\bÖo\eiÁЯÅÔ\a\87&)\ f é"rD×ñ?¥nÓ\13\«Æ\19\7fõ¢\14é{ÙYG÷èö¬è
\8fe|ÞÆ#ûì\ 5é\84±\ f\aÒí\9b(¸8À\97v\87÷\ ef\93\81\fK\ 1\ 5ºmR\86x4ÙÄ¢»\9e\82\18ç½þ\91ªd\1e:\92Ë\87\1dR\e2§P*¬Þ\83«\18ù&\1a©\1fÜ*\18P±öݽ×\ 4¹Qç\82¶K#\ f+µ?\86Ðõà/¯=\9fÿ\10Í\11(0\1fO\e\9c\152\v\938µßÒ\94\90[Bï<©¦º\91\92+|÷+««ÌBÖ^õý\¢²Ùü¶\84\1cÐQ4·\8bc`/õÃÃ÷\11¨*êùáð<þUÑÁªÔ¯£ºá\99fw÷ß\ 6\fú['¼êÖ\12\8fJ\90\8béϲ¸à\87>\ 4¡\13ö5{M¸\15`\82\7f¿¨¤\9er^Ø\f\95\9e¥nª\99¸\e±oÅÎ"<^q\13é,wÊÒc\14^ C]
\98\9d½Õ\818h¤5ÛR\95\1e\98\9b¦\fÃ|Ð\96ýFtSÚ\ 3\1dßD-\r§ªÇÌ\1d\98ô´­:\16¢\979oÂbw·Ý\88\9f7\ 6\96ó\8b\vô\1e*ß<³\82dtÑ\bËá¬C\t\84á\133ñ:\89\14\90\99du\ 4J-\86\ f\1f49ï/\1dU3A\9f®Ì¹¸¨b\7f\1c~°lVc\b[^6È\ 4îÐ1ó0Û;bÄ÷¡.¶´²Ñ(\bô+y\11K-|íqV\19\86\97PWç#&ÃÔ\f\ÿ2×ïÓ¾K¬$H\9aÁåäs\99Ü\10@ÏU\98MEûA'\8eK\81\8a~C\r¬öm\ 4 \9dGÍä3î\r\1fɬdÆØooàÝÇE*TAi\13\9b@)ÕêhË\aU\96\12\r+\90\90µv°,Qªf¿\91öaÐÀtÈ\1d\80\1cn^±M\bÿYÎKÌwÈ)ºD\18Æγ9õ0aÚ\97¡á\90ÛË/ì¾1Ó8áÀôwÔ\15ó¸N\94çÖ(\13\1aÊF6Z>+5gl\99\1a\949\f\92EW@îÏ\96ÀoU_ë:\14Gå7x#å\ 1õ¦\86×j@N\82úgc6«ûï\ 4´0\948\ f%\12ß\82\12¦C\1eÖWús\19\1e{K¡]¯\ 6kGO4xsÂS\1exôÃûíp;i9©Ò8\ 2C\ fÏÒ\9a\v\14ÎýW®Æe\8bâ£\80\1eÄk5¾æÐ\ 3®úhÉòúcúaQ×\96a\96\eó\99åj\ 2¼ÅÏ_c\8cÞ1«Wåx\aëyË]H×]Π\\a\85\91¹3\ e>ô_7.C\1cö0     7ÊM1KIú\8b\ eÞ\7fö?ÍE\12AnV\vÒ\10é´\ 1YcÔæ\94õ\982       J\1cd`í¬\ e×\88áäò\89ÚâíQð^æ³ÅeÓc\188ÁD\)":®Â\ra\7fçyO`óóg\8c\95}Øù,ë\È\9b0-._UÖ\9acÈNh-\93;F\86{\ 3éx(Ásq±ü\93r\1f\1fî\82FOjhTD`ê]\19Ïzî\84Åaêè¸Ï\11´\860ã2\r\0\1e\15\86\17vx¹*k\15¹\fi¦è*\85x´P÷;aç\19\11+\8eBàÓ%&ÚiB\ 3\7f,ìm\16\89\1dܧ#ê^¸·\aT[Oõß÷ØÞ-]\1e\91ªtñÌ4wÁ¯\8c\17̼\ fËhý¦r?\16%J3ñ\r\8dX]ÿýV\8cµ4\8e\9cwcKõ^Èl­\84\11¼,\ eÚ\96nÈ]Û\99ÄyÍ\ e'\1a
+¼)oVg!p\7f×\95ün
+*õ±5ÖT²\9aåÍ\ 5&½°«i×\91\87§ä@R3*QnvB=\84ÀwÄ/\9aAçß\9b/ü¨\ 2ã\9a8\96
+fËèÓÅ\aÝÕ\ 1\13\b\8d   2Ö·J\a=\8c\9fÝ\ 6\9fÓvH\r¬\a\8c\aLÅeJf\89\97\9bæLU;\ 2ñ\13ÊAyô׶\14òøÀªz\84S\89Íûì\8b\ 2ü/\8b³\17Í\98<\96\ 6¾s·VfWv;\8cÞhòºÇtçÁ\12®HÍø/¢Ó»\8dko\86=\9b\14\86¡8\8fi»A\17dìaé\ 6à¸\80\8cý± ·¦§\8fZâTgóeï°Éz\v\96·ÓBë¤d\81u/Y\12ù ½qqóÝV»aÜÝ\87\16kÆåÙ'\97ÙÇ\95\11\ 54\82Þ¬qòoקÄýjN6(ÝÜ·½)
+.\9b;+'4\ eP~5T\99ÈæCdÌl(P­h¶%çCa1sFcÓ\v\14©\1a9Ø_´Îü\9c`¼Õ\97qõe¸\1ap\18&D'*z)xL\ 5°&¾¸³òa\1f\ra\84°\9a Â.\9b\9fñJ·\9eu°2¼0ªJ>\v(öuw \bù\85\9cÆ\90\11¼_ÙV\17äP\971\9fÀ(\1c3Q\8dðóäܤ¡\9a@-Õ\84ÅÉá"×ff4Ö\1a\ 1ÞW\8a\8b\90\82¶u¢l\81­v\0õûe¡\9aÉï\8dbýx¶\eH\1f\81<è­\11\ eŦ®@Ôß\f\1aùú\82TØ`ú\1dXw nuãñ´iÔ·\1fy%Ç\11à\ e©nZ,ó<µ\87·\10\90¥fS\88S:v­¢Â=\1e\ 6;u;\14\1fÏ\8e ¶9\83\8c¯Ål÷¸$Å>14÷¤_\ 4LÏ0ãÜ÷Þ\83=|\99õ;&\9ewÌw'F\9f$xD\9cNÛ¹\ 3\0²U®½úÞ\88KUÜDððû\8b]ê%$T¨Áþ¾\87ê|{Ã\14.H/[ë¬LiY?\89Û)¸_ÿ±W\ 3\19D\12\92\12cLèÁ½
+\82J\1d"4Ðg\ 3\19¢©    þF°¿ÐhÆu\a\91»Så©1¤\9dÑ\92dh&q4\9anXã\8d\0\12¦\86\9dq°NE§|t;Ñ\97õ\91\13CFD}8Ûy(Ðö£ô\9c\11LC@l[?à\r\8b\9dZÅã£ö´#Ê\11Õ\ 3JF0éÕ°\80\98_\1a8\b°wÒ`_â¶L\ 2ü\1cq'6>H\94ëa\17»KØ ®À(¡OD;\1f¸\91ñ\82\9e\15ó¬\9bàÈQ\19Ã\11¢Uè\17~\9d\83PêÙ+5p\9c¹ ó\92®\8b¬\88\87vÍà¾\8dOTü6N\84Y~¹û´\9c\8eÚ\89\1f\97´­*tÜþ^\9d\ 4æé*\8e%2R¦n\11?{KG>§t2#¡8Ç}Qéæ¡ç´×+¨Eæ\0Áó\97P\945úá\bGJm|ÆÇ\81\12ø\96º;²*£\b\ 6Ö\9f[B\0{.¥z\93\95þFÔu\94Ø@È@ÑÃeûês%Õ
+\10¥ÅSz\9aá]è½
+¡:_ä%\8f-*Ýyù\80,#Æ=Ç6¸Æ{\93?\84U\10W\9f_9\ 5dü¶0,pñR7Øô\8böº\92¶ÚIéoú\87\ 4\ f\1e\84$\v\8a·\945\99¾¬O\12\ 5\f\19%w±ò«\88Î\16\ 1³ì7:¾þ\9e\aз{\vN\8aDþ furo]\1fZ[\92!Ýp\ 2Ï\94í\13|;\12ö\1f¡rÀÛ¦»Äå<À§æËï\80'\\8dù\15\7f\88#\8e
+Z\v\17ëû"LÕÇFdO;\9f¬b\17\86Y$ÑÙÎ\99¥³C\ 10B¾\b\e,ËKòé\ 2\83î{|\13\13\83á\8d\f\7f¨q\ 1\7f\9aO)"2/PËì\bY\à¥Ñ0L)Ð\98Ò×úùÃÏÔ3ó-UQ\ e\vò\83ÑÝ«3à\82ï{\9c\9dü\ f?\0ö\84\82#ü;\f\ 5FV\ eh\9aÐô*½\8e7\13l¿\16Ê\88Å\a[\15B[\92\ 2ËÞ\97\9dÎ7òi+7\85åp\f\1aá8\82}i        \89\b§ä
+\8b\97Üvºéæ\97ÁÛÊ\95µ2\87ºµú6tgÑ!V\11¶:Õ\a\18'\aÚ©
+½û\bܸ\81óÖ\0\87\12\f_\91\1f\ 5îp \95Y)-\97Ü\14S\13\82Õ³\8b\974\12qyè\ f~\ fñr\82·ËG,øqóï\92\ 2\8c\98G&ÇSKo\9e(£yª1#f´D¨wY\996@\90ø4¿\94\93Ê\13\87\b\15\19\97\®©æfĶ\9f%
+nÑÞ\12\89Ã\f\84\fJv¨\ 4\963\eIZ\15¾\8bØÓ¥yu´hJ\ 2\14\85g3SÁ«\95\17oÇdÓ\ eXª¦\1aÚ\98xãT"©¬Ì\16\12²\e\85R{@Í[ò\1e"\Øhåø@í§(ï\96\rx\1c\9c¾Í5ð#më!K\7fí\9céôÂ]û@\96 \fáË¥ÖÙ­\85\83+!\9fà\8cª³£z;Ú\rµk\8c;V2\15k\e1\88\17!oP~\r\ 5È\a2ô§ll÷k\90\17\89¤Çd\87Ù[ê.\1e`BϺ\82\82yAaI\9c\1a8L#´ÿ>Ò\7fãªèãÒ\96Ä\95sYù\8e0aÿE´ü£¡zÏ BoóÜKü
+öXq#\8dÝz <\92]\15   fHO9¨;H3\8dt¾41i3JQN*\90da-\e#¦a\90W²V\ 3+ID§Tyi\8e\825üÊ©;ó>fÝ­Ê£2\8dMDѳNWK\8d9\r( §¸\1f×¹$¬øô&áðÞ\8b°\19©GAãC/\17Õ\1a\8a\81\1cJ>@C_\8cRu\8ak\90²ÿ\90elq®0Ç@¾\90"Y\88N\8e©Ó\9d\ 2\ 3Ñm³¿ò½\fJ\95I\ ea£ÔØ\ 5\92L\14¥'BFýÀ\85ã\82\88s\aÝb¤IÂ\f\ 55îÛ}\91ß=ý1ðkâ¬ó
+\12V\1e§\ e\82F\92\ 1Æè»â\95ïp¸ô±R¶÷\86ðeÏ1*?ï\ 4+\17»\96\8a°\14\94\8fª\88:¨v®£8B\9fOªd«s\85\ 5£-¯\96r¡æ\ eK:¦3\1e±*m\92F·É'Ó;ïD\rh\e¨ N7/hMС\ 4Ks\84\1a·zø_¡\ e\12«Z_Ä+\ eÁM\15eÉP\86xK:ÍÎì\86\ 4iÒ+~×\92*©ÆÛ§\\9cAoZZý¤à\99 êPù¹1»\19éÂI9MùǦí~ÖO?èÏ\18\9aÔ\e     ÉL\9eÕË®Ô\84AC\84\99D\93È3\80\1cÃYþ\9a·cCð\13\88¼ðSeÁb\1déÆx\ 6\12áÛ\8d¿v\8cD\19\ 4{\96\8a>~¹\17\98£\98\r¾\86 \12çòïáõý|£è\9a[¯"
\8fÖ\1a
+þ¾MÛà,\ 4\ruU}g:)Ù        t¼kM.ÏtHRQ²\10´\94Ñ\14æb      V\ fyÇÜ\86§©B;g\99K Ú+Þ9u(\9fÕÔý\83µ¶6¥ö\\85<]-A\99 Ë¥yß.Ü#äêk jwBñ6\11ÔmY%:Òµ\9cy\12b\81z\85]M\87À˲Å\9a>O,èð½\14\84÷3f¡ç;Lm\8a\96m\93\18¡4\8dMÌ7\ fy\8fz3¼(Û9Þ\1c\89G¤Q\vÇ\8dm\8e­üH\8a´ÒG õâi×\19\8a¢­\98ÀQæ\ fk\12T\1f\8a1_h~Erk\83I\81\90ºzÞ\891rc[/\7f®HW\86â½\Ð_¨¡Y¯6#5ê\90[\18L£(Õm¯JÜ_:d[w6¸ÕAµK¸ \96_g\84þñrØÿ\8bqcb¯Ñ\96}>ü  \87ú\92\95½Ð\ fq3@:h×Bµ\92\8a+h§ÖÎõW\ 6â!\13ñØ>±;\98Y ×Ø\81¾å3àpBU`¶ù.\19c#\8e18í\96Íæ@ÐPèJOx<éÄùImhâçmáê§\9c\e }aÈ×Vµ    _*¢b±Ìæ\1fçU\8cö$BnÇ\16Â\9743\8aË\93$\85\ e\82Û\1a;·^4óØóçª\8b[\ 3õ_$\1c©¥gjÖ\ 6ô*À\865\95W\99atáB\8e\81Ì_4ý1V2ñ\91\8f\96ö[ø 8´@+\14Ëã½ø¸³1Ã\8fÅ\9d\89\11À½7½Yp4â\ e\8d\1f\aöwêª(yNõÙ\9câ\9a±Á>{\16,k\11¬ð=êOt±e-_¥X\84IÓ¡ülC\84f\ fào:\16è\87a\19\99c©æ·\9dfq\1e¡ký\88Ä\9eBqØe4{\vðA}(ù\f 5¬òΩSj\ e`ÆÐOÄ£9\89ÆܯLN)o\a\8a²ãÓ=\ e\8f\8eý8ötNî`²{ö"\133\88\8aú5\ 3Y>2>\87ü>\89\9dVWò#Í©$\12o\18Õ\1fp\92&\90Nµ¹\8e\9f\83rRËÛ\17£4oý¢g
+[ë]³£\ 5­\8aÊS7Ü\eÀÕz\f_\8dsà^5\18wMÐïz\8bWUúáÙ\17$y{\827Ô¿d¢\8f[ܵxTôÛô(ÌG8\13\11\1aµòÀ\8eóMg\10øÛ[-\86ÑkÁð\v)^\9epðÝ\85\99Ñî\98\89
+U¾+t\13\10u\82àÖ{)\13]K5¾/¶ª]z5¥$Ý,Pa5\9bSìñ§ow«¶\e\9eòäÓÐFoß2J\86\1e\7f+cÊL÷\81i\96 ntBíLÜ3\eLl\81fX\v\92þ
+[\e\17\83Ã/÷íº¬\16ü\87Z°ôÎ:ÑGóé%G\9dJ\a\97°¦%y®_rC°±nMï\11-\1d\9euQ£ó1ûEê¢\84»{â\8b\7f\11\1d9Ënüj*xÔ\83õ6£YA¶\ 5 ^\ 5T8«öäoL1O¢@#S\15km    n±|\17«ÎO\82\9d\97
+\ 6&M]\ e\16³\8c~À£uâ\12I4\18\0ÕÏñ\8eòÏgô}ïq3:à3Yð\8a2óç\96»Tm¢s\ fÄ\9d\89Èñή\83@»È\12ü\9a¾ÁööPá)ÕÔí\88Mv|×ÑÃ}-¯ÙTy\88ÚV»\17NÐÖ\1d7HyÅ\9a>ÕZK%\86ZÉ]ÆÝSÅ6\94­Y<\ 6ûH°9¢.-ßJ[zÀ&\vH@Äm\11õÙ\Fp\ e\9a2C\8eì- \7fÒÛð=\1e\9cþ°º¾kÑwJüî\87u\98¿½-\ e¡nã\|·§7,\10ûm\ 5\8dp\8fÖòsã@\ 2\15 \eó\86É\10\17\95Á\ 1M\9b÷Ò/¨ó­\963vylQÈ^\ 1D)^\88þ;m÷Ö}\f3Íü[Kj¡Ñ\1eµ\91dÔ´ÐÛÀ|Êd\96I'\rÄ1b/\9d̵²ÚÚÅ\1aà\18¡ãOh^DU\9e\ 6¶üH*^x`\7fo?W\8dR[\13ôdó»I\97\97\ 3(2ÚtªKÜ\1e7 O+¬\8b\b.þë\11­¶Zõñð\e\ 4\9e%\87Ù5VÌ^\86»K\97òÇï\18\ 3çWj\865¥©·~Ë    Íþ°§\15ºº¬\87\10®<\1dk`Â\87ü\ eÇÀ¶Ô=7jF\99º\91*tv\11}2,Þ<\9b\14i\ 1\8d\9f¹Ø2\19\99*6\1e(§6\91[x1âj°Ù\ 2é~úïû
+ºÏìE!êó\95\95w\94|'Â"\aú\86\85hùuW\83\ 1\9a\8dd\137aº\83û·ÖIÙ\19¼ma\90j\97\86µ\90àG#\8a\85_\983\ 3\ 6±zûN\ 6\1f;+\ 2ºj«MóÚH1\13?=·\a¾à}¦   \1föì%kñ\\88\v\9a\91¦\190ÝHMШì\80Õ4B\85m~\8eÈøò\95\9f\7f\18úÊÊcéþôy\17k\8a«\9cÇG9\1a\9fj\eú\8aÙl\13)·      ~ßò(«îW\ 1η\87 \96÷\845?\89½Ùy\12#\1eÑ°ë<\9b÷³Ø")¦íĵ×\1a\11ZjË3ºâ\87g"àR\16\90X¿âä\11p_\92ÝÕ\15|'k¬g)¶¥)4\15IgÖ\vøýEp\bfdº\89üs$½`\83Ëá\81\152u\9b½Wz_\8dYÞ-\zW\80±XþT\9b|\98ç\89\15¿\92\96È\8d\7fò°xuî\18À\13PEå\15\1e6â«\92®r\92°®Ãú\9ep8³=ã!:bå0{ïFïë\99\82Ñ\99SRÊ¥\90äí¨pÅ\a\fίö\0Kïæ+ea?ü¼\ 6\9e®é\10p\9fÛHpQe\\87\ fÞ\16¿Íò¯ó%ÊZ\ 1\12¬\0&\7fÿ\88çæÕ\97ã2\8dNÈ6ZH\9f;صO]\ 4\8d¨Æ\88^\93Lö·g\eT\11\9b/%\8cD'\83\1c\12\95fÚó\e\13\96Ñæ¨KûÔ.INc\ 3²\ræµ2h¶}eP4)2üC;wp­;ì`=ÚB·/\89NÝØÍJ1þ\80¿\82\ 2\85lL\864z\91Äv%æý&Þ­\1cw=WÞv[Vì}OÁ\89ýèÔ²ÚÂj\15\15\9c\88#\8feá¬\fÔ¡!pYÕ\ e©/±6µ:`t\ 6+ó<ó7áA\7f\96\19\19\86»\8cFppÛR\99}\9eÐ\94*\9bt\rÙûãZ\ 5\ 6r²ÝÂ\93\vH¶Èw\9d\eo\12äò\9a\95,»2\ 5u/\9a,üÀaÜ\1c\8f[ï|\eOr\19?\8b\1f^©y¿¢\14/~âm\90ÐIQ\ 4\1d\1c\19²Dr¸ú\91§ê8cùÉvK\9c¸ßåµ%\8c/\19C½Ô,æ\v1©J\11{÷¯Õû"¹uðíoú\7f\15"\eå\9dXO=\1c\80÷IÇ2\17´ç\18eÞõ\91\89\83\ 6\ 6f@ì  \ 3¤?\97ä©îä\8ei5¢Óï£\ 3:)ë\a¨VßI\9bÉË\7fx+ãGÑ-9l\8aÓ\86®\12Æ÷îÛÅpoS»èT\e\165\8cµ\ 2%·5}\8eàÇÂk\88#êý\9d!\8b\13#\ao\fòsVªògYÚÛ¨J\9bÕ    Â*4©\9d0\19µ}sl4\0çqý\9b\12f9â<ÃÈY\17MË!Ktð\19\9c\ f£².ì|oüÑLËïÃþ\1e\94ÅÖ\88\12µî²kã<\96%o\96Ò&,ÝÅHÝ\8fúH -O¨~\9dGت\9aáÉ\9d§bª'>
+º6Ü/[¾Ë=d*\v§"oÏ\1ejó¶%RlFtD\b\87TÄ~\93íÔIN~N$tù\84\ 3ó»ý  JbòqЧmË>Oeðº`\ 6É¥Ëô \881(Ôüáú\89íìj1HíØYåXßì¶\b=FÖ÷a-iWñ¸a¦\9eó\1ak3¨°µ£t¡\\14Y\1a¤¤vÃéOè\eÖºMBo\99§Õ°+Úd\93D=IÅ\87À12ñ³ò­,èüêaI1/Ãg&µ¨\97ôöæh(XKê\1ajèÛñZPùô\12\8bÄpö\a³\99ð\ 1\87-\97\86\15L~,\ e·\9fZ]Ú`u\rú\99,\17\9fÎ\8c¥4l¼î\13\ 6$§µj\8dîè\9c\bë\1c\98\ 6\86Ú&æ.Ú«$E\8bÎò\8aG:ãý\15ÐV­Àw÷\f\91¯=Ë\87ßw\1cvS\86\a©ib\82\87\90\9b\89\10\1c\7fÜtÌ¿\99iíã\eÛ\10;²e\9e1\968?$\b\98*9\eT\93P3z[<¨iäM/\83\16[ZLÇ\8d?ÌoCr\eªîо]\f\ 354·láØlÇè?\98ë
+a\979H]f\9b½îyP\99¾;zü$g\f~\92LîáµÁn«}y\84Åá#|\1cÒïy\89\98\bñ\81:ü&-       "ë8M\7f\8e\18\9d\f!ZÂ(`\ 4¯à\11ìË\a\1cM\8f*
+\1e0â6M¢ym«0öY${'údQ¤ïìf\84i\aï\17\88Î\ eM_n z®ÃUx¦Áøvòu{ue\8db1Û,Þ\94°òÿ ;Õ\94\{\8aç5xi\8ai÷×ñM
\9d\97\92\8f\11\11\11¡F\8b\b2reEÀ³TsHî/ù­@dÓg÷»z!@ù\7f\0ÝÈ\81à
+endstream
+endobj
+2903 0 obj <<
+/Type /FontDescriptor
+/FontName /QFSTYE+CMMI10
+/Flags 4
+/FontBBox [-32 -250 1048 750]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle -14
+/StemV 72
+/XHeight 431
+/CharSet (/B/C/E/F/G/K/L/P/R/X/Y/Z/a/alpha/b/beta/c/comma/delta/epsilon1/gamma/greater/i/j/less/m/n/period/r/s/slash/x/y)
+/FontFile 2902 0 R
+>> endobj
+2904 0 obj <<
+/Length1 789
+/Length2 1905
+/Length3 0
+/Length 2458      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\92y<\94k\eÇ\91\8a±$\84¢<¶\90ef0\96±\8e}0Ö±\86\8c\99Ç\98\8c\19Æ\10\95å$"»L\88Ô\899r&»æ8Ô§Ðè\90ìK¢¼)\91l¡ÕrÞ¡÷|Îûvþ}?Ï?÷ïº~÷u\7fïßý¨(¸zh¡\bÔ`Ð\96J¡kÁµáHÀ
+\83A#\0î\12\ 6\83¨¨XÑ@\1c\9dD¥Xãè \12\80\e\19é\ 3¨h"\0Ó\ 1`\86H\1d8\12Î5\ 1\888\1a\89\18J\aÔ¬ÔwL\ 6\0*\1c¤\91ð8
+\80ÁÑCÁpî\f<\8e\fxPñ$\90\1e§\r ÈdÀ}gG\14à\ eF\81´\18\90 \r\81Ã\ 1\ 2       O\a\82A"\89\ 2\81î ¡)!TÀà{\99\10\1dñW+\ 6¤Eq¡\0µ]Lu\80\vI RÈq\0\ 1\f\81@\9d©ÜÓ@.Ëÿ\ 3ëÇá¶Ñd²3.|güNPÿhãÂIä¸ÿ\18¨á\11Ñt\90\ 6\ 4\90FùÑê\r~gÃ\80\ 4Rtø\8f]4\1dG&áQ\14"\19\ 4´àzÚ0½ïuR\94-)\16\92èøP \ 4G\8e\ 2wë \85ð# 7¾]\ e¨%Æ\vëç¦ñýaw{®8\12\85\8e\8d\8b\0\ 1Øßæ]\rÿ[s#¢\91b\81\930m\18\fÎ5r¿¿V\ 1?\9ceCÁS        $
+\11ÐAè\ 38\1a\r\17\a\81qGé \10À98@¢\10ÀX\0\8cå\ 2Cµ)T:w\vÀ\r&\1e\b¡Ò ;¯jd\b@\83wJ»
+\ eÓ\ 5 Ä¿%\\ f\80ÒþK\1a\ 1Ð3»ò\9f÷µ´¤Æ\9eÓ5\0´t\10Üóuõ\8c\0\ 3\ 4\7f|øh\1a\r¤Ðwÿ(nh\7fé\10\127g\10\8c\ 5ñ\90ñQ*ÞøâéBvjU\82Myÿ¯û\9e\8cÄ3oUz1\8b¾ÕÅ覿Ìhà\1d\99°UµwHª\80³k'ZWMQÞõ¯\12ÂäRL\87¥U¾8\8d`ùXi¬\84å\97\13«í\8fá÷U¼Î{4Ñ{>\eÉ\¾Âc$xùpb©ã¬/&ÎZCó2Ñ:þ\8dm\91ÎA\9b±Ð\92¼e¥ÀÛ¢l\9e\95\92\b\1f°j\16W\1fµ{:ogMIÔ~\19ê\85ý«øJôÃí·_ó_27\r\v§{2Îæ*eãÞH)¾LZ7|Qì\14¥êÏQD\8f\7f
+¥^Z+Ø8Ç\ e\95ÈP\10Z(³EùÉútå6\1f\8b\8f\1fâ\95DH;\9dP¹~\ 2r\f\13¯m©ØØ\88AÝðPþÕ*\96¹\84VUy\93\17×éÆ\9bÆ\93\8d\17Ô\ 2\ ewäع4I~Y(\94-ÆÈÅ\8fy4DjDb¯¯\17v\82S\a\8e\93Ò\80ëel©7ã-\8a7¾^\9c½\9d:Á»¥`¿¨mï»E\90jïu÷ \13æÓ\9c2KµÄ\92§\9b\8dßü\16bç¤Ä¦dsxtxXbn\8eM\18Éî\b~)VØñä9\81àÙ\91¦k{ÝOëx:6 \9bë.8¶\1cÎ6Té½`(üp»Ï\16<f\16pf¥\0\9c\85\13\0=5ÅU\ 6í^bÔjÇ\ 3Æ¢1{k~\12è¼\93JvÑ$2
+Ææ²
+ìøË9c\91\93F®Æ\v¬ô5LæDÎD^í´¼9_P\7f`.'jºÍô\e\9f¦\8dâL^ö´«áMtN«\87H¹1dÚ°¾sqÏ&¿Æö3%Êþ\vÂ'Y¨c5²ðq$´²\83^O;µ\80¸v¯9[3]ÁFý\16~\8cñë\13!F9\vê,°\8c\10\9cQ\88\foÝ7Ó¬.k\1eàЭtàçüO\8e]|\15\7f\Ô<\90GÍßèç«\1e\16xÀÏÛ¯æÒº\12à\14Î\86[î·ëÉÕ\f\94\92~ë­/¾qü\ f\83¬uù\rWû¡¾}öW&*²×ë¬Æ\82>     GG*\90\ 6ÈÉK|Â6úeÖf)f2\82\18Íâûâ©\13\83¸\83\8d.\96íbúµ\f-\91\98Ä\81D\92ïøÖpÐÞQ\97?±g4\[K¤\91³\85|Eò>_W\11\9c¼õ\98r\19wiÌ
+®´"\ 2\91ç1©\83\13\8dÕ\0\9cãlÜ°\84ç½¹ÅÍÇ\96z\12î;º\1d¯íغ>Õ¨^+Çx$_ÁüÄH#¹^SºO\133Ä«\9f\91¯ ~=.\8a½\83\10\vöX\92äG[ú¥F¼úª!}\99\8f\99}7ÚbýþOb3ö­>ο\8cªp>nó*We£óN\1d\91e\f\8aûÐõE\17å¬â¶×:sgb\85\ 1Ø\8d\83««æÕx\7fë\96=BFË+Éå\vO\a   G\9føöÀh\99"m>êxU©tÍÓîY¢\87ª\18u5Y9\83Þ\1cÍ\14Ó\84°þjÿS.\83k\1fÆ"\b¦çeô|c\1d\91\10\ 4R\ e\99\93þpM7g²×_õóïhS\9dhyå»BóG«Î\96Yòð©4}xêdY÷Ñß\14aÀ[3.\97dÊ       ý.>ï\90zÕ»\883·¢íÅ+úË\ 6Ý\e\ 2­\{â\93\92"~\9515·Ç­òñ9õ}N      ám\9cí¤\98Q\11 ó­`ò\80q\Í=\98\1eÍnëä\99}©ô\17Õ¿\bN\ 6g\1f®í¿$$gÑ¿WÅQJ¿ä\1aì4¤\9e\16xäéåT\17\13éÊ\9a¡\fNÆE«ì\rD0B\v?Å6\e\9d«kß0¡5\ 5»U¿Ê\118ëð*£\ 4ù'ªº¬\85üâ5\1d\fS=µ\81\97\13H&#$nêݾª\9c\1f\81
+3anÈ£yë\1eϳÓ\ 4\15ç\95\8degÓ²\98göt´Îï\95\ e\99\10\90
+K\90û\10æ\9e\ 4iªaµdÊ$²\95\1fõ\92;Rð\84p<]kÿ¨íj}\12ë\916v<®õHß\8bg¢cò¹   íUZë½\1f\0\95âù­\95\1aç@B\80Å\89´\80ñY/ómÙ®ÍÊ\7f©ê\99³\88ïK\ae\94\85Þ!´TûÔÿô:ÊËß\81,ÌC·\ faî½½»u@Él\ 6\18\1e@Iø¥è\9bVkÆômÁôk\8a\97»\9d\99<ø)\99Û\8féw«¾¬×¢?Fðó\99½;\15\12)ôä¥\8c¹vp\ 1µÝjÑÞåÄ­r\1e¹Nxs¬\b²\93|©äШ>æ=´¬fÿà\80\80¾x\84\85\8f\91õ\8b#ßZ»îÜ\1d\98\81¾\9e×ñÀ\14\8c:@<µ"'Ä\14'n>ª_\1c\roÇ\QxÝR\9eEe5\8e\8e\95)Þ{Ç,tÁþ\94YV¥:\16L\13ÈêBi\8aÄ\88µUöxÆwbýë\ 5Md\ 5o\11[¬a\82)\ 2wWzÎ\ 1\87\96<@\93\93\9cüY¿Íð½Òö§Ä=k%Û&£*\ 2\9fJø¼»S=è\95¦\1c$\1cÒ5×½ù\195$Ñq-\18óþ\13/K\11m§\$5\9e\89{FÉe¶\8c/Zo@¯x\1a\16\812\93}\95MBño\94Y\90Ìá\86\92|öì:g5×{ÿ %hÅb\81\98k_Z,AÔ¾i\9d\8aä¬\ 3\83Î?®[\86V¶È\8a\13á¨qFT\1d5Ý¢³*ñ\8bsØü ÿ\9aoFãÑ\8bb7ÒkÑG\9f\7fÃ&\84>$¢\83Rc¿®Ò_vÏé|k\15¾ÚÛµÔÙ×p!`:èæ\87\9f\a\1fXgÎ~\9eëöÃâ\1a\ fB\rzÂ&Ä\9aß[\95liOÑõ\1dÞ0\a\14\15RÅêu´ô òó#Ï¢\1d$%Ç\97<¡+ªÔ&¸\84¯ÄÉ\81\1cÖÂ\95\944ÝÉÛ\1f     \ f>õõÈnÙ\9f\9b\߬\8b\95\97Ü\18x©MhðÂ\1dæ\96\ 3Và·\96\92·Ø¢ÞÓ{Ì\ eTx+L%\9dß<TdÞÆ\f}tÞ¹öá   eÛþÛÝnw\98¥ï[¬\1a\1e\9b\89\17\9cÕ\95Ò¿¤\91\9a8o\97ÂFHwò­Ôá¤Fôfþ\rËß Y
+endstream
+endobj
+2905 0 obj <<
+/Type /FontDescriptor
+/FontName /BMVTZQ+CMMI5
+/Flags 4
+/FontBBox [37 -250 1349 750]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle -14
+/StemV 90
+/XHeight 431
+/CharSet (/b/g/r/w)
+/FontFile 2904 0 R
+>> endobj
+2906 0 obj <<
+/Length1 958
+/Length2 4005
+/Length3 0
+/Length 4639      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\93y8\94mûÇm!;! Ý\91-1c,c)²\93}ßEc0\8c\991\ 6c\89ì&Ú\101JÖ¬\85ì[¶ìÙ·ìe'\95-[xÕó{\96÷yÿý\1d÷õÇõ9¿çu^ßã<¯\9bÿ²\81±¨\92\ e\\1d\8dÂ\89\8a\8b\89Ë\ 1*ººZPàt\v\ 6Óðó«`á\ e8\ 4\1a¥ê\80\83Ë\ 1â²²ÒÀ-/$\0\91\0ÀP9)\89ÓEÃ\ f¨ 1¾X\84³\v\ e\10R\11þ\95\ 4\ 5\94ÜáX\ 4Ì\ 1\ 5è:à\àî§5`\ e\18\rCÀq¾b\80\12\12        \18ý:á    \18Á=áXo¸£\18\8d¸8à\88\80á\80;pg\ 4\8a\ 6ôË\92\16Ê    \r@ÿ\b;zaþ\94¼áXÏSS\80Ðo\9bÂÀ©IG4
\v\9dh@zèÓÛà§^þ?lý»¸º\17\12©çàþ«ü¯Fý\8fìà\8e@úþ_\ 2Ú\1dã\85\83c\ 1]´#\1c\8búwª9ü\ foºpG\84\97û¿U-\9c\ 3\12\ 1SB9#á\80¨¸¤\18\8f8ÂS\1d\81\87;\1a p0\17ÀÉ\ 1é ÿ\1d\87£\1cÿíä´}¿}\80\8c¬\f¬tÌDþ\18ìoÍÀ\ 1\81Â\99øbà\0øïäß,þ7\9f\b\8bÀ\ 3Ö`10Xü4ñôûsgû¯»ÔP0´#\ 2å\f@¤¤\ 1\a,ÖÁ\97\ 6|Z
+"%\ 5ø\8b\ 3\b\94#\1c\ fÀñ§\86Ab(4îô\b\98»\80\13\1aKókªÒP\0¤ò+ô\9bdd\ 1\90å_t:4\90Ãß$\ 3\80îüEâ\90S\82ãþ\96¥N\8fÂÐîî\7fGÄÁ\12\0ÈùoüE\ eÿ\9d \ 5\80\10ÿ@i\0äú\17BNEÌ?TqI\0\84ý\a\9eÞçó\ f;`\0\84ÿ\a\8a\ 3 ßßø¿\93QVFãýÁ\80(Dê´QâPq\0*\ 5¾û_i0/,\16\8eÂý~ú§Óý\93\9d\10§\ f\ 2\ eÇÃa4\1fGÐ0ù0×Äò\88Ü@µ\8c¾¼3Â\9e\I¯ÂºëÃK\93äÅÖ¦åY\86°\15½&p\9eMæpfWD>Sºv!ÈÑIjöB¹R@\9b¿1(|\8c¹\8d\9eU8-Ù\98ê\elÍÆ\8e¬=µµ\89Ñý9aéã¥yL\85È·q¾\9d\19ïú3otVÄ¡é\17ÖïSä\8e\8e\1cm\ 5º\ 5}\98ýHûÌ\91o!\81Æ6µFç)Ülyæq×Á\17\rt\ 6úcVûy\9bä\9d\1f/4M\r¸MÒ'ÉF§ê\92\8fzËΰ@2GøäRÞ \8a\rg\ 6\15\e\12Ä
+P
+ï*\vù]¯Ãõòö³è\fkѹ´\ eå\14¤MRoòý\8bð\ 3´Ú÷Ý\83ÈIz\11z\b³\93\14ávýn\9b\17Q\8fóÌ\8a\97]Æâ
+T¥\16Ëz$W£V(\86\86º\81\1an{\89ÜJq0\16[MfÝ(ÔÔäTNvÑQV/%ùjjÖ\90¬üZ      \8a³\98K\14w\92}<wpØúÝú\1e\17\17Ä»\98éÞ\ e\99,Y\19<nëGñ\96o"ù#骹|ï¦\95ÀKZ¢\829+©
+ñ~\1aìîôô\94
+z®DcÛ\8e\8dú~á÷,P¯á\91ÈȬ\988\92ÔáqÓâ§ÌU\86\92Âu¢\91!TÍ\89\18R>\8eU¿\8c$\92\ eÿç2\96s}E\1a\ 6\95²´\e\eµÂ\93¼µ\85\ 6_Z3Z%úâü,\97-\178¬öw\9c)0\ fns\19ì>R\99)PiY\9a\8c?§Ús¬"\98|t\9d= ^\88\90a´yr\ f Ú{»¦E=L\85ϳèý©{\91ÕÒ\8f27~=\8cµf¹\ 4\85\eJEî(yW\b\a\8c3_E\18Þ3 \95\b¨6Á¯=Ó\99â%£\7fý±3\94¹Y±¶]Ég§'\92\ 1\93ÚJ=\10-\87¥þ¶+\1cÕ(Ízm\89¨\97⯸\10µ\12\16Mѯ´@xûä\96\10)ØD6â
+ë^Üpy³à«¯\82àéiW¶Ä¢\14þGg\ 4.¶JþÐI\róù`\bÓÎÖü\89ùaÙAß Ü0R\1eÓ?#=ÂveëN¥\95Å\88ÕC÷#\v\85ýWÉÊ\8fø\1e¿,\93\86ß.Ëy\9e<\90u~Vú¼\96é­:¸\ 6\15ß³\93©\b\85\9b\ 6\âh¡£\99hSƽ\11Ø3\95¾úL^Â\9eõ\98*\81»T¬í=\8bð ÂÒ²<Ëã\9b:¾Ä\871Q\89\91\1f\9aJ'»Ò\rÎ\85\8cÊì)¢_ä»\1dÔíS\14Á!ØîrnÕ}C\9b\96\95aôU\ 6¤ã,Mqßí$wqâ~Ù-^»é¯b`BbÁÈ·<HâÖ~¶ª\8b    È\8cG\ 3\e`\12fÒÙé¡kÅ÷PÄ㲡T+NqF\13ß\1fg\ 1\e"©YKe\1d]ÌDGNoÛí\r]ɨÃgNø\88J\1cMä×¥\13\ 4Ì.òOȤ5®t}rý\8eáM\7f6Ü(¡$³OÛtUzµ'6!ráÓO\90\9e\94zi©E±\10Ê\9bmýÒ¼ÐOç µ\89ì\86\99PÃiÌË7ÛrXP\8bç%xYåÞ#sÚ\ 6\ f\89Ø\93\0¤ß\ 5"Ý-1\9f/;2\eòÈcbsÕÇMTÏv\96l0`cðñ>^ù>é÷°uy\ 3\17d\8dæ\11\94\14J7Ý\e\89¢\922c4¼\12\9fuék÷YÏv±ÎZ^Õýª´
+¿ó~¬¾\&É®zæÊj¾X\93Ô\9c¼ß\17=ZùYE¡U':¯h\90\ÏAF_U>Ô¿Äo{\9a¨\10\83Ý^¹\ f¤6ÓùÓ\95½#L0UÎ\89:\872AÛÇyããJK²\86 \97;\9eøÐKÖ\b\ 1\ 2kÛSo!Q\93    \92»Ú\ 5½oªî\ fhTY\7f\18'\ 3½§ª\15(\10³Î        Ñ¹åQ¨=d\95x!~4\9cP}ѹ7\15®qï\87ßǾN\9bÍ*\8dÐêÑ`\9f):µG÷«ÀýéZ\85BF{3\8eWÒï\b\8a]\1f\95:Ú#ÃXÝPîw\9bE ñ\ 4\8d+ßVeµ \92hqÍÙbK\19~ZñÖ\98CîÁ\88u\82PvÝD5$îy\1aÕÎI\ 5ÿ¸eYe[XÖ|\9eð¸\vD?Sù£\eµÇa\8b\ 4»ÏbXå\87k9T{"¢É±Ìó½\94â\ 3\16ºW>zf^!\ªY9P"\81q\ eÊ}\9fñ*c¢Â¾\ eé*m6ã\18\97j®»É±îú\81ûþ5Æ\182hФòùh\8cÕR\8cïºÚgyÛ«\ 6½þßsÔ»îÖ°:¼Ó¨ef\vò\15\15ë\88\8e\83H@\ e©¿\9a\8eÑ}\8b\95ÊNðª;ñá³4W\16Ë\91\84u\8fØ\88\82ÅòwÞµ\95øig\80î9\99.JëC@\96_        $~S]i\83÷Á\ 1\1c\9b\v    \14\98ôÄÌ\96 \81]×±H¡ \11êÏ\8a;/\840$:·_µ³\ e^×Ò\9f\1d\f÷CCP\87£%Q\v4F
\ fLm
+WåVî\8a3µGeK\8e\85çºË\8am»i¯\18ßñäε]\96W\86bÝ       Ò\89wBÒt\14\86\13É\90\1f;\0õIÏZØ\aM­Æ\1d\19\86\9c\15.\ 6@^6S.¡£ò©~\eVµ}>T>vðS¼*\9c+\1f+\93´«7«bßÍa\ 4á\91ý\81ß6²\9f\ e¡\bO=,/cÆÈ\9dM~ãÒ\1a\ f}n3R¼!°Ü\9d¾ß³°óBAÞ+\8a÷¶ÃF\84AùPFÎei\9b>ö©4{o¥×Ó\9b\1c\12¥ë\0\7f9Üèýýj\ e\ 6\97©÷¡*jú\f«8\12\91¼d\9aà¶\16zy
+\ 5ÄÄÉÌÝ\86\9cÝA»wv\87G\86ÑZ>O×ë\19¾.J\10{\ eÚo6?ad¢¤¹Ífþ¢o\81Î2$,E¨\87uס.cÙ\95­\ e"\17x\96\86m\1cNgç×û\93wi9[%&è.ú,ÇUEç6\81\ et¹õ\87\81XH4ÏN,d\97³íÇy\ 3\vB\1aÔ98dËdh¹æñ\17\81ÛRe\12)\9eÁäÛ\ 2\f¥1=\82áîÀó\ek7\1eÊÞù®Mj\18¤X\89Ò\1a\12>H\9dxº2°Ä7Ã~2|\82;oòE²F\803~%\15à¤)|\97ÐrC\93GU\86Ã\9av\89·IÊ^'mÒF\8bõY\9a_Kì7*37¾`óÑË¥Oµ\89i\1fb\96Õ½­3âY|`ÊÏsÞ\9b«õÓÛ%¨ó6r\9e\14»\ 6Në`\15\18èg\9b¬ZÌï3/\aØ\164\abkò\9c]¡û\ fêD\16æ3\97\8fc\83õ\1fÕ\9dØ­Æh½Z,Û¢V¨-êþ\8cá3\8a.#.\97(,y¬+\9doI½PB    \16êLB\95õì÷\17\b°\81\98nI\97Úz\16Â=1\9f\97ò\94ôÙù\\85îru_`ØM=ÙþÌ\9b,¥\Æ\ä'Q|ëÚ#Á\166?håµäÍby\15\8f3QTo\1cÎHi$¾ô\19\8c4\8f)&v\XÀAH©PÅÒvÄ@5\85ì\98¤{»Ø\91®èju\ 1géàKüÙì\17'9\17XÅ» ®d{®p\92ý·êdFä\ 4$\15\8b\v\e\1c\8ab×¼\ 1^
+üºÕ:{3PÐ\é¶\85íëù*·Þ°w"È\09\11Ííy¾\8912Ò@©÷Æ\85>®p\1e\81`\9c\10VVðê\9d¸è\17Ô×U\82ÎÚÞ»Ê\8c6\\89Yh\7frN+;ÔÞ\89A\80¨q\80Ì\94\7fûÐûYQA\85\96¶dÅ\99EÞÙ!\8e\98R (@\ 2t\r\13Ä\19W¤À$2À3ÁÒç}\13ê³??Ö4æK\85\7fØ[á}äü:\by\18LÛÌG\16þ\9a|óz´5\94c¾Dâ1]\88gi°l¤ü\ 3õ«\ fÐ>O¬:#U¬¤w«s|\9b;ÒQJâ\17\efâ¡\1f2¨y\1dû\1d\eMC´Pgvª¼\ 2GK\8e_ëüx6¨\9fÈeé³O\19úª\85\95*à&ÒÈÞ\18§!EÙ\98áÞÏاÜtoT¶!ÈþpÖÝÆ\86\1e\83\9cBÐ¥¦uê`\9f\ 5¬\7fL_û6¨\95<hV¯IDsE©\1c×3\7fHþI5:ïVEÙ\81\89bù#+X}ÌúÔ¹\ 6ÕÉ+l7\ 24`\83¬8òËÍM[Þ\87æ\12\92}\9c¥CÜ´SÕççFÐ\ e\98\9d/4j\1e\9bç\14ìY\9c]\19õJ^\1eàïê3È\13¸Ù\89\81½2\9e½ë¥ÝGÃã\bì8\1f$úÖq¿|æBÁ\89©Ñ\9azw»\®ý¢¢<w1\fCKaýaî\v¿\937l¤\89Þòù\14²\r\16ËbO~:ºÔÒF\9e¿û\0\93ÛmN\8c\8a\91{âÀ%[!õ~\9flþÍ2½\83\89r\99`¯3j­*\98Úbû\91ç\99¤®ØÔtZ
+P.UÆur\83/¾*\1d\8eÖy\81ÀBÄ\94¸\14Îïf¼cuîa½\19\81\19\ e\9a(%¤Ã\18\9cä\1c%³ÈG\ eûH²VÉÕ®Ù\1e\903Ï·VtW­Ò\9e\88S=£\9c)V\9f1³Î\9eYv\84¾\18»\11-Ò:UÙe\87öz uIås§8·b0i\r¾æöì\80!^Y\ 1âÞ*¬I×pñ\e\90üâòµiÓ\bk\12v\1f\r\9a\ 4¡u\8cò\ f\893\8dÝ+1&\94\11.9/ÙöÒ²8¹
+>õR'r<_S+\8bº\18»\ 5sH97-O\1c¢$OóÎ!L\9dÍwÚLg¥vú\1côXÒÃ]70\9e³DBMbk\95ï\eÝ¥ÆòÄÒ1ëw`C\97\11ù"µ7H·~Ñiæ\8f×\8c\87+\8f\13E\ fx\7f\10ÜfÚ¸|F¹s9\a¦©4\17\1dØ£c.²\9a\188}\ 2Ì\a{=GhÞJÏQåLkH\0\a¯k\9a\ 2³»ñ\9a,Ò<\85s\9dlô¬ü\84ò­÷0\1e\97\93íOûEí|  ,g´\89ÎÕ $Rö\89iA
+øúúþ¢\1c½W\96ÂÏt¹ðë,â\1e\ 3S\9d\ fÄ\96\1f{\ f\9c[oæ\85v\85\9eþ2DÇ\ eÿcÉR\9ePè»\8ea6Úã*»·òÁj\ 5¸×à\ 6±ÙÃ\91ÎÆAû©R\1dä§T\89NƬ\8dC]Í0A_Âr:Q³(ñ8ü8²Òi4\9c\9e½{²¿\95:\v\12\17\96»\98\e®v¢&éh\9açÒÚ\8c6e\bY¹VÍÊ\10ÄsP¶\ fd\\92\93\1ab¼}ÔÊü\\9e\18¶¨td\1d×0\19\19ó\19y6³\93+);\8b¢°\97«\9eéË\1cL&\99ÇSçÃd\84à"xoK·¾þ*~"j}tíüÛ\8fÀ\9c×\9böª\84¶\ºÄ\92Í­Ë\eÜæé\9c\ fu×|L\16\96\13ä2"\f\b´&¡S\83Á
+ÌæßiÕ\8dão<\8eÍ%\fi\99ÔÁ½\19µ¢L\v·.\91\ 2ÐZ:1ç +7ðt\e#¦h(}\ 1ÎÜ\fº%![Æ\13\14C«Ñ\\9dscõõ\a\9eðQÊ\87!\14\a\9c&k_\89½E÷ßð\1eÍ\11·3\82ö)Îd\8bE!o\85ì\87â©­\1f6\ e¹\ 4\ahôt/U'\95Z\96TÑlã\92Ô¾\ e©¯\vö>ñ°à\98\ fè*~\9b\82¸ºDmH4d\84\15³°Î\9b}\85~\ 1f\1d        Á\87ÀQ    \8a`Ýh«Bo\98sWÎ\8b¿0P\9f\1f²°\88d&u\82¿¼;~Ñ×  ¸¼N£MRí=\9c¦ajÅîÔÄ,º[Qõ¸\8aôòp±\9b\85Ê\99m|UżæA67\84=s·àüçé6͹òyã,\ 3l\1cqööëí\ e¿P«GK)5´³\ 5[Wr\15c\8dïµ\92¾Ô\8fAp*ÂS \89èzk\125y==õ\93\17\A\98î\16Jó\°\82!\87\93\1d\8dÍ6+õþ<,{©åÈ÷-g@\ 6àµÕµéº¤=w\14\1e;Pè°&\10c)«æ\1cäýø\ 5G\93u®$DZ¿Ñ÷,/ÎÜ\rJ|YL\14è¢ó`Tì¬r}~\88\19\1f©i|äPîË×9Ì\93ü\14\8fÜ\ 5{ä×.½\19F»6ÚKÖ\ 6©\17\1e1o\95.Ý0³,à²Æt²Þ94ï\97¦~\97 Ð 9\e_øÔC\82Ø=-\ 6£Fy\ f\15r+\9f\fmO\91\95Åï\1eð\16W<]XéÈ2\17kèmnQ\b\92ãE$\13\8aÊEÒ\14#>\1d\97ï :adY¥µ\80Ê\1d\8d9\8eÜéüÔ*Á\87O\9c6\98\8aú\93§¶\862ðÏÌ\18êr\9e\17¼·++«Jk¡¤²8\f\7fÇ+M\89\8d;0$Æ\97¬wÆ\98Ãè\82\93zºC£,¹\95\87\84Û6Ý\10±TÃ.±Y]Ý\a×\99\1eg\15\91ó?ä\9d.·8Ì\9bn\19\19ô\8fHfæµ5\1f\bµ-%·¬\13\1c\19B1\96Å\18%\1cý\1dºó´0HD\90ûFô\7f\0\ 4\87
+endstream
+endobj
+2907 0 obj <<
+/Type /FontDescriptor
+/FontName /RZPZLV+CMMI7
+/Flags 4
+/FontBBox [0 -250 1171 750]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle -14
+/StemV 81
+/XHeight 431
+/CharSet (/C/Y/a/b/beta/comma/g/gamma/i/j/pi/r/w/x/y)
+/FontFile 2906 0 R
+>> endobj
+2908 0 obj <<
+/Length1 2146
+/Length2 15870
+/Length3 0
+/Length 17011     
+/Filter /FlateDecode
+>>
+stream
+xÚ¬·eT\1dL²¶\8d»\a\87àîîîî.A7\ e\ew\rîîî\ 4ww\b\1aÜÝ\ 2Á=¸|<3çL2çýû-X¬}UWWÝ]U½{AN¬¤J/l
+4\ 6H\0í\9cé\99\19\98y\88DåU\98\99\88\98\19\98\98DàÈÉE\1d\ 1\96@;1#g\0\ f\11377\v\91\ 4ÀøãÃÇ/\ f;\e\ f;\v\1c9\91(ÐÞÃÑÒÜÂ\99\88J\94ú\1f'N"a[\80£¥\89\91\1d\91¼\91³\ 5Àö#\86\89\91\r\91*ÐÄ\12àìÁ@$lcC¤òÏ\ e'"\15\80\13ÀÑ\15\0ÇÌLdjiâLd\f0·´\83cüG\92´\9d\19\90\88óßfS\17ûÿ]r\ 58:}\88"¢ú\97Lj¢\ f\91¦@;\e\ f"S\80\19\1c£\ 2ð#\eàCËÿ\1f²þop   \17\e\e\ 5\7fÂÿS¨ÿgÙÈÖÒÆã\7f\1c\80¶ö.Î\0G"y )ÀÑîÿºj\ 2þ­M\1e`jébû\7f\9d\8dl,M\84íÌm\0DLÿ6Y:IXº\ 3L\95,\9dM,\88Ì\8cl\9c\0ÿ²\ 3ìLÿ¯\88\8fÊýK\ 2£¤\92¢\82\86&í¿{ú¯5%#K;g5\ fûÿDýÇù_Ìü\87?ªãhéN¤ËôQ^æ\ fÇ\8f\9fÿý¤ÿ\7fr\89Û\99\0M-íÌ\89XØ9\88\8c\1c\1d\8d<à>¦ç\83Ø\89¼\98\89,íL\ 1îD\0÷\ fÁ\8c\fv@ç\8f-D\1f5ñ!2\ 3:ÂýÓP\ ev"Fá\7fLÿ&\ e"F\91?ÄIÄ(ú\87¸\88\18ÅþCÌ\1f\0°q6ú³ÌMÄ(þ\1fâd"b\94øC\1fÞ\92\7f\88\85\88\ f±\121Jÿ!6"F\99?ô!Nö\ f}\88\93ûC\1fâäÿÐ\878\85?ô¡Eñ?Äõ¡Eé\ f}hQþC\1fZTþÐ\87\16Õ?ô¡Eí\ f}hQÿC\1fZ4þÐ\87\16Í?ô¡Eë\ f}hÑþ\ fq\7fhÑùC\1fûþT\90ûc\9fñ\1fúÐiìhdb\r\ 1\989ÿ±³þÇþï»õ\9f\85\8fD&ÿ!ö\8f`&@\9b\8f;ú¿\16\7f,¶¶\7f\1223}¨1ý\v?R\ 2þDø8"à¿20³|\84\0Ø\9a\1a9YüeûÐóq\ 3þ¶qü\13ÇÁåãbÿ        ýQg³?øá`ö\17²ý\83\96\7fÅüà?ÈÎú\ fºþQÆü\8fáOpö\7fÜ\81.\8e\7feûp0ÿ\v?âÿQÇöÑH\v\ f{\v\80Ý_\1e\1f¶¿ò3}\1cÝê/üh\93õ_øQÚ¿\8föQwÛ¿\8eöQÓ?\91Ù?¶ÚYÚý¥ý\9f³\ 3ÿ\88ùØ\fü¯å\8fÃØÿYþ\bfoä\b°û¯\11`cþ\1fë\7f\ f\0ëG.{\80£   Àî/W\8e\7fÙ,\81\7fÚÌöQ\1c{\e\17§¿r~X\1cþtï\1fr\ 18ýóêü\19.\96\7f\8c@g\80©±Í\7fiaeû³ð\7fæ\91ã\7fVþÛ\9fû\7f¬ÿíÌüÏ\füÕAæ\8f\86üQÈþ±É     `kùß\ 3Íþ\8f\ fÀõ¯>²\7f\ 4qúøÞüÏQ?*âdó_ãÊü¡êOZö\8fJ:[8\ 2þ\9aú\8f\8a\ 1ÿÚð\11Ãå/üh¾ë_ø¡Ìí¯ÁýØíþ\17~\84÷ø\v?\8aèùGÜG$O\80ã¿Sý¿ï\87\88\bÐÝ\8b\9eåCáÇ\1f¦\7fî*÷GI¹}þËÓÄÅñc\f\9cÿõ<\7f\Âÿe3Ë\8fG\v\0p\a\98À­,\ 2Mx\83¬R\9bC¾ù\8a\17N\97\80\8a\98·Ä)4ôÎuÁ\a\83Ú\94\8cÉ:ÐlÖk=Ud|B:\80< t{Ás\8aèôV\9e\90¸\bp\88K[x;p5<ÈðlÃÓºÎ\90÷Ø·'¹\ f<Aîh\9e¿=e\aU\9cÝ\1cÿ\96¤]ô=ûrè$_\89JLí\17ô:1H\9f®kc_f\10\a§\96D\86\8dzhp=\ 5
+J\9a÷0¶Ð\r7\94¤\ 4\88\8d©@_«P\98VÚµ+`§\vÚS!L^â\9bÞ=F,ªI'!«Ê.\rºÊ/ÁÓ²¢P\14äº÷Á\91\1a¡L"sUG¢\ 3ÈU\18\951éÀ\9cO!5Ù\9e¸â\ 63\97X\93âaò®\17tm\9dZįä\1cú\9b%?\rXi\r,\8ad\96\8b\99.\13
+\81\95Ñ\94\8f0\9eoÇD)\ fÜ\ 5\9d²\89~dÛþ\17ÞÈ\89ÎùÑ\1azÔ:\90Ä\88mV¤X:ß32§Ñ=\99\91n³Ôq\85}áHì\ 5\93Þ½\\84\85}J\9cà,÷P\9e¬D¨_|\15\8dá\91\a\87ø\94\8er°r\9a\bäd\a\1c\19   b\84®vDb<\18j¶õt\94æ¢TPå_fåÕÀ¼{ÈÑ6P\81\10&\9bB*¥UªÍÂ\ 5¾\ 1?\ 3\92Ü\83&ÙÍð¤1\ 4ósàhB\10¼\8cÔC\1c\98ø\ fª¡Ê\90\14Ä\91° \]\ f:\1ai2È*;\ 5jǼ<yßÊ\14ϸ\7f<ÛªéÖw\ eæ|ÁL5\85®ÈNR·\99¿\84!»ÐÌ´\0i^ç©     \82\17\1cúJåÈ\11Ã+â¼\ 15ÆQ\13k"Ñ\87':ìø\83\8c\91\97\98Nv        4Ú!¿T.#é\f$±ø\19 y»í\82"Y³D\94vZ\bÚZm\81\8a\9cÆ\99²\1fp\ 5\85.­¼¥ë\ 2ÁRÀôZØä¢ÃÕô+\95¦¢\8f\14*\ f7ýå\ 1;Û¡uí6Y©ý8ëªÍ»gøG\8a\8fÄH\,\94f{\80Ï\11i\89öZ¨&º\17:\9c\14\94\13Õ¯½Ç\ 1\1fì°ú 8QPq\84íN\8cóc\90\9fQ\13&a7/¼\17Ë+\83  º\0dFU[p\r\8aºw8Ë%\96áü@[\13=¦^ë3QJ'{êýv-¦¶Ã\b\ 1\16«Ù\eEÉ&IîÆ0ò*³ôû\19¬c9\99S1¡\1eÛr\90ôÍW\16\14=\13S\ fâ¯\91×\96§#\9e´øQU6îÍûFµÐ©Ý´Ãc,\8dªB.wÒxGÚ3wì\12\ 2\ eæ9*~\8aâ@7Y\9a\87·\9bå!^ÆÈô7d§v±\86)\8c\92O\92\ 4\85Ãù\13îü\ 2\8d\842\93ûD.\99Vrbf»ËH÷Ã!ÖUPû[\10l³CÐ/_GOæ\97ã\18~¹b\rTW\8e{O\820gC¹\95Û¶l\93Ã+ÇŦXºuEEC¿vÝNk\89)øøÄ»G\1f§{wC\8aÇ1\98ãÈz\15NÀߪ½\94Àg\10   X7QÌ.4±\10ìDÏæÕ}QílÝÛF1o@\9aÝ k«µe&)å\14U\85\9c§?\1ajFO°~\15ÛB\99\11\ 3;9{\87G\97ÅÏ\9c¥wòP1~;~c\1e)%î\9f·ÊC@±Àû\96\8a\b{u¬\98¯a\9d²K\1c"#^ ³zjr\87\9f;\13è:\97\83¼±÷¬Ø¹aåe\ 6\15\91>\87ÿ[ni\8bÄx5þÇ0UøX      íg ±ú\8f\98$8:öå    \81aU
\18z&\94¸\eÜ&d¦J·ÙAñö{\16Öp!\e1S<\1eÇ~ë\89"\11%yp\e\92Âv\Ëý\aß"\10%\^\16æ\9fÀ\94J\1e\e$\19E ñv}÷\85ê6æ\8d¼=8;á\f\19\87
+,Å\10\vq\10
+{Æã;¦\9bÒÜ$b%o|\ 3Ê ¦\10\ 3ä\0æ-\b\99M\14W[Ô\b\ 3\8aìà\13$dÓEÑïï9\8a\ 5Þ\ 2\1e\88\96!q¬ÆjK{bÊ\a        Õ¤=\ 6Ï\95]7\ 2äì\99³µ¿ò,ÌÀ4"G\9cInÈBÆ\95Ül|Ë\7f]õ¸×S\8d±¨)C©ò\9bX\14¥é\19ü.\8a¸ÀÜ©pX\9a¤3\93¾\9e\92¥ò\98\7f\82 án\82x\f\9b}>ôæ\1d\ eÚ×\8dÙ\ 3â5] ¿jq\8c\89Å|Êyx#!øê\ 3\ 5\86\ 43~+Ãd\96\8b°Ð;\ 2I`\10\ 2E\ 2QÃA_\12×"צ2zë\91[¯úE²\124Þ%\19\8e\90\a\11\96\13ÔH\8a\84VM\97\0ä\e\1e÷,\1aºñoB'\v°ï¤\9dÏeI§¨\ 3ì\82\99\13\97át 'Z<òÆd\ eØé\86¦éx\ 1À\iäR.£'#ÅS¿~\1e}qfHÊfõÔ\80«\11ÈËÓÄÏ\b\86¿\90\17*Õ¯\19L<æ,\99\ 4Mò~A%p¢Fç\95è6\19\f\1dc¥v*÷M«
+áN(d~qT\949AÏâZC¢};DýöMÆ\19R\84n=\1e\7f#õTÚu×ÏÕ*G0\88Ë\eb\88Ã\ 5\16ÃW>\1e6ÿn£)£\r\16\ 3Lu:ËÚ[µÖ\98\81»H\7f¥ô\v1ûEDåïyjC±\9f/"m3\8fë\7f
+I\10ªÿø[²ûҰͲ.µ&Õ0ò¾Ð\19\9e\18×\ 2±º\ 2BÍÞ\ 6 \85¦>\96)\ 4\1d[2§âä\a
+XfcÏè|ýÝ\8föP\9d»\0\7f\9e\12øk!%\e\9b\ f2&rÕý\ eϨ2ÍÙ\9a\a\96G¨Ï·Kæ\82£\83þ     ?£?\9f\8amS\82ôÇ°õïÒ\84úú=\8b\99-6\87e¶äºxµ@\80ål!rV­\1eÒ`ú±>sÐDûálÁ\94ÿ\10{\82KC¸¬|\95_\82\12Þ·\92.b\15\8d©\öþ®y¸\99\15i\10(Öwx\83asÙî%´¤*ªwr\a¤\94\98à\817\a\bëË>\87\v©\a09ªäÜn»pë\99\9a}\ fW        Ls:GiíW³\11î\88\ e}\e°ïFifâ\9c0{¯cý.
+Y¬|¨¤Å÷\12ëºtßæ\99(8ÄË¢\9c\ 5º\1fFèóH\81-üü\13ï¡2¸ÚTB\16\e\ 4B7R\98\88\9eáBV@i\86/_l¢ä\83\vÚÊx­D!ju\9a\84!p·ÑGÄ\e©øöîõ\vèZ&Ü\87<  ¡¼=êa»ÚÍ!\97\91{`&\90O²Y\12W\92\9cà\17\92\92ó\1fðì¿&4ÁªÚ\87/W²åÙV\7f\89ìÈ\84C¼Ì,qä?NQ\84êÝ)QÃÔ\90D"'Ôy1s\83àÿ5´¬k8wÒZ$¬ß³)H½ð\94×4){¤\9e\9cLaPÖI\96ïø\\93\89;]´\83_UÑß\82+
+\e ±öz¿C\ 1\95 }"\8dP^ë£\97u"uÖý8Ó7\89á8þí
+Q\ 6\ 6S\0\8e³é6      [j4ùÁ®¶7âQÍ\ 6\87\rÁ(Lå\¥òü\9evi^8ÐbfPÉ\90Ø\9cµ80á`\93\9b\80ø\98\82À\9aK¯À\85òîwÑÂ\ eY_ãË»D`®]õ\91ed\8e5\8fX«ÂíMZù׸\1f¾\ f£¤Es3¯X¾±øÓ     çÎ\8cû æ
+]0ëÐ'\9bÏsþ\18·Uù\9f\8a\9f\v\16\95 \ 3\a׿Z/:éÂj]\ 4½O\9bð\97í\1a¬y\85Å<rçöZ>·¿\1c
+`Øi9¬\9de\14\1fI¹cÞ °EÒ\1d\9f\17JÄC        ³ÈÎL­&\94}\12Ù°Q ,\1e%
+\13
+\91uR.tz¢\8f¦Shq"\8b4ðYc#\9açSªûm\7f*+±\87B\9cò\80\94¿,|Ëûë¤\12/ §æÒ\8bLW\99\8fpá®C\9a\82çÇ~ðó|jÁ0$\ 1¹\81½ÓU1Ù¥Â;j;\14¾\16\98'\10\85W7×ò\13=M\91êÆ}·ùÍÖ\ e\bG\9cÂ<l±ðq9Ð+x\f­HhyñT£æAñÉ:ÞvÙ?°Gõ5 \16ä`g§\83Ô|\93l\1e\13Åô\1dQÒªýçwªêj/C4=;/hÉÞ\95\v\90m/\ 1\9eë\87Ø\ 1\85\ 5\15\84\933¤ T\ f}¶ñe$ÕHÇ\ 3\9aL\89êb\1a\13z)G\v4LY\8bÀ\99ðL\®÷<ò\15\86Rt!Vtx\ e\8aFûá\99dYß\98¦Í\8aï\94\9da\80\96¦ns^\99\96c%\ 4oðΧe\99¦\93"\0FC~ü-eô>\v\9d\13ÅHá\16IHÉ\93ù|±®àm|\15F\82­\e\95\89\94\9eÞ\81í}{ß\16Z]HÞTì^\a#'\15fÈöugbc²ã9¤ñ\a\9c¨\1f{R^ñ\9d\86î®Ävh\94`92¨%
+M¶Ô¦\86Í\14\ 4î'ÁNβ\9dwW\82Òg­\1akÙ%e\97\93ð$ n?~:tÊÃ\995¨/Ö®\9fa\8e\89N61²ÞÔ\99\1eWx£\91\8al\85P^\9eÐ}:,\7f`Ê]lP\e\8cú7¾®·÷z\90\93\86\98\87báü\1c Ej/{,\9c\1e«mþ Î\81ph\ f\16P?E\ 6F7Ki½ì¾ê>bÃÜ}\19\eÛ\132p\9e\15¼Wy\16SãõÖpý\v9}â\8bOû¼Ä­\98\87¿\0Z6Ò®§
+\87êCÄ\15<\19r\83\ej\93F\9b³\8eÓ6ìû±?þ\ 1\94ÆtFÊÞØQOv\97ÍRP«3-9BÑç\94#\9eô\9f~,ãàÚÉ\99²¯¼\1d\rm¹\[¸J\89_¾B×\9a\1d>\1fáÒW.\1a;ØåßH\95.çúºå\9f=ÝÝ\8a,BBRÃ2¤Àß\8c[pD@i\95+[%hSyïÞ \8c¥à¿hÙ
+AÝP9\96\vjM\11>\18\12\8f\8bº *¤\11\19¨´ùõ_1õ»<ß\18 1o~½\16\1dÁ7\8f_Û&ýqg±¶¦\80À¶tT¨¼\93ê3Áìý)©.]\87H^I\f\7f&U8E÷+fÞT\86\97\8f\8c Õ=\85Ö\e\1f£éîÚå9}\ eAZd\ f¦ò*²S\0\89ö\98Z5b]þ3Ô;ªÿzpçµÓÂ\83\ eEþE\a\81\7f\ 6ZJû\1c\88Ôö\88!ÑX¦\9f¼YD\Wô÷(û)Y½éíعh4Å:ñ«\a\120!y\1e¿\b~îK\98Hñ8h\91]qN+¢íw°l\1cTd\10ÁÃïcø»¨\9f\99T\9bz«ã\ f\8cI\1a\93\15\9aà/\8e\8d\a¦\9d¯Ë{Ô¢\83\aáéGí\9fï»éh\87ã\ 6\ 3\92;\e§6¤Owó14g_©Y1\19$uy]y\ 6"¶0!W\f,x\ 4'\84:\94¼nÉôÀÙ¶ç\98«&ý\8f\9aÔ¸\ 3\11vÏÙ\89Iy©Nâ1
+!wëNå60ì'û\1cXHÀ9Ã\8f:ÎO\8d\a\11§}\82»%TѨ¶A\107Mh{\9cò>F\97È*ãFt¢P\89Hµ/\8c\ 5\10\94¹^»¦f\9eG z¿\10~0²¦ÙÜÚ[\93ÈNIàØ9Ê\7fÀÂ\13â\4Í\12*ê>tB\_ï\1a½ÓÜT\a_1Ï\96H ¯\8f¢Ü¤ÑÇå\ 2i\90¯C9\8fËd
+ýá\8bëùoÿü\88§t\1e¢L\98'?\81ð#\97\92­Y¾º°\ø\9f89µBQW\90ã\13:R\fAw\99½´\82ôà¢A¥\92Ðu\8c¶ù\b\ f$ó        U\9b,(\ f;øýù2\13~\8b]ÓÊFÑ_#6×¼ÇÛ\8d\80×µ\15\rWl¾TÈ«»\18Ôe¸ß®\r¾óà}#\96\9eÉ·0\9bg\1aVW·C\16òõ\15cµ)³Ï2îJ\82ö\0Ó\93µ¼\86h\18\r\ f2£CõË÷ðX\ª\ 5\10)û&&H]yè\ 5\84\98´?¾\91#È        Ø)²ÈÚºª\9c\11ÂÙ?\81;ÞGbo´~>ÎP¾\ 6\ 1eÅ~Dl\12ô6¹MþE¡\14\eínéUØÏСÖ(»æ¦%8\92)\8cD;¾Àjmh \15ÊÛ\19xI\13'Ì?É\95.'6\8få\99º:.Ér\87aÊÓª%w¢§65¦\9bÓZ xâÙë¶XT\88Z\9aåÐ\ 1×6Hý£2ü÷¼)&O]÷\16Üö§Ú¯Á\82S\8a\93\16#ñþ5n-\e7h{lïÃ>S\85^B\98\89Áe\8dhxN}Ì\94\94T´79øjíï\84\16Jº3
+ÔI^°ö¹r0©y\ 6Ö1´\81\9f\8el\8cºfN
+vkJ\16ª\ e!Çæã\10«ÝxÜ\8ad\ 4äÛ#$Áç+M-;
+\ 6ÑЭâ"j À\7fDcl  ö\1cùø"\9e'\9cHàý:½+îb\ fhX\8avpºÚípµ)í?Fît·«\87\81\r£\96¯äìBå\ 5\8f-\176$Ñ0\803ôLJßÖO9|È»­ðH¿¿´0\ f\9f\8dÀ<6Í\84ì\0g\a\8cμf\8de+\94-\14TN0O}Ú\86-\82Æ\1a\884zM\ f\ f¡\1aÜ\19¾±#×\ 3N)Ù\17W`\19¤×XNxÈ®\v2\97ru¶öù\8c«ÉW)\94ýÚJï\1570é.¶Z®H\1frñ2²\1e\11\8càW\ 6?ÄÒ6©\v\8c¨\95:ñå\14À\ 1\ 6n\9eÀ*ñQ Q®\13@bÿä\9d\12
+(­yÈ<=è\99\96\v\1e\92Ê(\833\85<\0    O²«\93|!÷2
\145D{q\98)c5Ï\82î\9drdcw\82¼­e\94@\/&¾_ ÐgÌÜcätõèÚ¼ÿ¾qþüåõ®.kï \ 3>=\8f°
+s 4ª
+t0ö¤4^\97\9f\95\87\bñ\f\9c\9a\1a©c`½\971¤%\e1êjÉ,@Ñúi¾4°øx\90ø\19ÂÆ\f\9b}'kÁÃ\14uZc\8a\98­­oÐ\1a\e¶Â[{1Ç)<F]\94/\18"\e×»?\1fi{ƺY]E\1dsg÷\
\1c½Â\8e´ ôCñ³§-\87 -Õï\1c¼\10\80_¿o\bõÄ®ýiáøu\80%¨ÒÉ\13\ 5\8a^ààsãeïÎûÒ\9ds¨G\83\fÐ\89¤£\_þ¨ø{î\ 2ý
+¹~\17g\19?f\ fu&MõdjÅrphï&C¬k\ 1Ä|\9cpÀï"P¤ÀÓ[\93M꾺9Ý\85Z£Cr\87ìEgú\f \15z\87÷\8bM"6û\97\1dÂÑï\94u\ 3m7PÁ\83\87:r{\9d*ê»\1d?$}Ù\93\7f\1c\91\86Z\9eÌïË2\10A°òÑÕ\92z\15D HXðp\b\9d¤0+h;\9ao\12Aºò¬Qî!\17\82\9d:\8a\87\9dX    jãÒ!\ 5»$\1c\93keEâý0çcíÈg\8aÍq\Ç_Wâ*ADý\96
+\88ÜkZ±væ9Ŭ\80±F8Òÿ\fu[\8e\ 2'Óm\7fO½bï<ä\98Í\ 42*x\93¶Æhj\96\8amøòÂ\91g\8d×`\11l\8fÆ-» @\1eµA\93ʽÞ\17r\81Û¾Ó\9eõ~\1a©!\18\8e   ë\15\f(%­U¾Ã~\ 37\13¼kQ\93}Á{Ùë{Ö£èµajA\ 1
+\ 5$9ª%\10>$'ô\91\ 5×Ñq°àlKíÕv`Ç\89îjÍ/{\14¨2\84\(§\98Çø\8fsg\ 5\89\88©{/\89\8f\1dUjö8p$~>Ë´Q|\h\06©_8È\13\13\e¼áøïíÂ
\ 6ÃÝ´Âù\1fÀí\9eß\00X½?\11üx©âÃÇ\87Hh«¼vº\80Ó._\9añ\9büÁ-^T±\92\ 1Ø$ \v\9c¸Õ\93Mb+çºH\ 1ÿq\8dÐ\93\8eÉMùÃ×\1eÌ­\8d­½§²òQ\r:ÀoWY7÷\163\89Ün\8anýÙc«­\ 6s\ 4èë)¹p8        .Ѳ\88%J6#´oî\97a\8bº¾\99\82\12Ìwµ°¿<$¥{\f\999^\9d     º\91æ©&Å\86ßÖÛu\81\98\82*þÉ`S³\15\bÈñ&þ*\925uÚ\bÊ\84âCöê\83üÃÃMn\98´(SVFm`÷Ë$6#µ\88®xr_y\99\10®WIRU²á\84ÅÖÄ\83ÿh\e²Wà¦o±®}O-\9a\9e\12à\9d$)\1fú
+í6\0þ'l7î\92,¸k²\85\9e\f«Ì\9dÀ\ 5\9f\91ïû\ 2éH\0+;Kt\9aÿÅ\1cùOéÅ"Ö:¤{öèÁ7Æ=í¹Ù êPú\1c\97ìúG\97`þW#Æ=Q\91é\14ºy¶©X\8a\9cBEBU\8fL\\r¯t§\\9cþñi¨\14\v\aYQ\ e.ßµõ6\93!pwl\11;µ.R
+ÅBÇÊ\ 4i@<Çj\84ï×\89H\9f\10¶Xü>ØÅ+ß«\ 2ëx\9bc\1d\väWBmï\ e\ 3M&Âó'Â,\89\9aó\9c\8c/M Td3ï\963]ÊÂ\8fy_Zªôá\17òG\91'ûYÃÓ(_î¿_l,ao\ 4\80\7f\85\13nW\99ÿ~úÈòlëjóªBìbw¶Ôß­\F,\ 4&\b\ e|Êy}Ü\ 3\aͱÏ\8eD\13\1aÌÃæ\19¹-O7_¤§3\ 4îEäÉ\96\bï\ 6ÔÁ[¹\88vmkPàWôë̲0¼ïm@%·æø¨/íI\14\ 4PEf#Ó\88Ó\9fOU\80*\8fiP|\16Ï\16\84\80\91Ä+Áä¹áɼ\95. Ñ÷ðwDæ\1d|\9e\8aïr\8f~iÝÄ ¶ç      ò\12Ö\82\8ea\80W«C\17ð,z)Ä\89\87£d\86¡\9a?7ÍÆZ!»\85÷Ú\\ 5ÑM\8dÕ Ò*³\rõmJÉäZ¡Ô@\13õì¸\9e\aC\1aæg,¤éO­D{i6\9cE\96x]$¯xÕf\ 4[ÿfT\9bÙG\1a\85\13»R3ª`\9a\vYßÌ\0ïPßd\96,~\7f£Oî¤×j²¶\99ÕBîË^\95y5ú*\8e>\89\1eð¥\9e´­KA\9f\176Që\13øDðvܨ\819\85ß·P@O_ùÇì*àZnÍ\1d\8dÏ1\87£¸\84\85Ey¦\95h\e$»#eN"ã®æ\11\8fL¯¢\84¾Æ«%ä¾'æ$õâ"òTýèªÇ\12û\1e\aÇÇ5jÓ¿
+z\10\11a4\98\ fÏhspð~Ó<å\16\16\83R<!Èõ\;­gA¬\95ú\86\96ÌQ\9bÝõ5¡H\8ca8Ø1Ò©v\1fúìmYÓ,j\9b\83´\12\0­Ýÿ}ÏÞOYÆlâ+nÄh´®\1e%\89è:Æi¾êåîö\93\8bÎw৪K5BŶ\1c"és7]0\aôI\9cG8¼ÏÝ×\eoÎðrLlk4\85\b\18EG\14
\97\8b¬q÷\12\19ùf²t%ú6À¢ª.\1a\91\e\17Ã@"4k\19¦®\14 Å%Ý
++=\17!\1féáò~VhÞ\10\96É`       Ê-ʯ±e¨}
+c³F\8càz3¾\91\10\96.¶¤üÕ56ââ,öÀÆiÓ'\91Å¢lå¡s²\9auDÏ~?3²#þMBÉ>Ä\ 3wv\88^4_\13\8bÈI`\16¥|\8a\fÿEpTDþ\ eÊÌî\82äÍf\1e-\93·t\1c)[¨ÚϺ\95Û"æÆ|«gá\b¡\vR{ÓU'Ðê\80{|ùk¿i(\96\841_2\17Û­F\rj\81&â(®N¾~J\16´÷x\1d
+BÃK\1cN¡Ñ[¡\95º\18wu\17g6çJ\16;±QhýÜ     \åE¸\11+\93\91Þ\1dÌtí\89\[XÿËZ~Ds\92_üËG\ f³.Õrõv»¶µì«4&³\bE\9bN ÖÈè\15åÔ¡è\16û\aPßa\ 2\99\ 4X¨Áåi´d>ç|MÄ]Û±?{\16}U>O?ë }²\1fK\101\eéÕ¬\92×P-\84\89î \16~°fHôì\1aæ<\8c§\ ecÛñ°­Ü\80\11çû\95cFõÚw}\vd׺N^óª\8fk\8dÚ:W\bÅón\14¢¬ÌônlC§}9©ÿ\89tí£îñe;ýJZ    ï\1d\r\92dD'À\1eæ\92O5\e\1a\f\82Td9±Ûqÿ z\1exåªxº.Ö\96Ñ«u¡ \15\88TûÓ\85ã4Yt¦èЮ\ 2vF2\8c\95µ=\b¤nt\841»V\9cub\1e®\96\ 5w\ 5ý\82¤ë¬Kp\ e}P!\vJÙ8Æ\92U\95p¬>×\ 6_¾ÞûÜi×\13é{}\85_\ eX)B1YñÚ\1a\85û¶\1cçPâÛ\0´eó/\9b¡Fß±÷FEÄ{\152kÝêô\9b;%À]b¶ª\14²\85«Â~kC5\9ehE5²\ 3½\ e¬¢b¼YH8ªÛ\1aïäèÂ\19m]¥ì\9aN¦í¾Ë¼\8cØ\15X-2 \91\9c\bMª.s¾Ö¥[P[\13
+f\95xr0E²
+\97{ø¶6s\171$®\ 6UQShÍ\92qR\f¥\11¹hl\v\8dp«£¿e¹0Ëi~¬Ñ\8f\86\9f~é§ñÛ\93Ê\0\8b{J)éô\v\82×¹IÞQé#¢\9bà\1a:]|×\b\93Ú\1d&Ø»ÇM\16\ 1ø\9eâ\967\rËw°t¦>ϬÇÏSbPUï¡r    \82:ËÙ¥ô¨\1dÄýs\11\94;ÑÊY¦n\92\81\97j\9d\vÇëY\8c\8fèk{BÎöæz\18\1d`ýBVÂê\1aº
+!\88jù*æn§:¿ÙósyÕ¸&o¨zkû0A??·Bª\9b\9a\81\12y\9eÅÕ¥ÚÓ2f¥j'+=\bF\8a¾¨í0ã\9a:+pÇYv\ f0j;ßê\16ÞF5\96÷Á\14"xy\9f\9c~¥ä\82¼ø]¦d\85G\1dxCI+>\1dà+\8ckP·X\17é1\8a2fjß/5\80§îz\8a1×)\80\v\ 2u½í6l¢\11ú\rr¬'i\ 2'Â$\81      øàdªs\8e­ºS¹<\b£\98\82¾\1dö\99[§¶\b\12)î)X^ÌÓO\0F9ðÑ"OïEØÎ\87?t\97`\94þüw¼ÖæÜ»¾xC4TÝIõT;ÙϹ.Ó$AÈÖ³¤Õw\9aèp\e^u+\19m^\96@FÃÑÁm¡UÜô1[\9b\84\fþ/\13\1c\ e\9e³r\19\ 6°2\81ÊU_¯Ã\9a\96~åÎ{\95à7\8e/ÒGÏ\8b\97ÁÏ'AB&&%i/¦\ fxú~ña\8d^\11çé\8c-\b\18Z"ã{¯\99^J\99¹¸ä\92¨A0"dæ,Ý5\93\97Ê\ 2Åñ£&ç×û\ 1bÛíîtB\1c\b\88ß4à¼sÏ\19\91\1c\98ÄH°l.\91\96É.Û5ã<þY\87ÙòZ\10Á\zÞmú:ÇJåùÌ\18íÌ;î·EÃ1\8fSVýc,Ö&Í 9\ 2Ûõ«ÿóB\9b\83÷'ãéû`I?`¥\95\bh
+Lúu}D\9dýø±i¯\ e\96\8aé \9c\88A\1cÂï1G*Xë¨rR\9aZ\8bÙH!ÅG\8b5\9fÐY\8flDH\9a]¯.W¨Ynò\1f1IL\1c\831;^º>þ\1c·\8aÓ+3ªÛâMçSãÐ\aDE\8dÜ+ÆÏ\ f\93ÅÆ[\ 2\8bk\13½üÎ9\8bþ·i\8cN¨µ`*\ 6\ 6î>e\9còÛS\90Õ\82öÐÓ\85ÏÚb\97\9a]¾Î¯±k\ 4\9f\1dDѱ0óÔcíHC\93K\145ï,\18\83ä\88]s\ 6í\8dFN\8c·X=f\rÊÄúuÀ\ e\12\82$I\1d¾ñW\82\@ý
+\1e\b2CíëPÙI      T0ZZ\7f9{Ö\9c\8c­ñè\r\1f\97ã'ÕçÅÓòÉÙHPáë!\eË«£ßrjc\96uj\13ÎÀé¸\b0¤Ò#C;\97\95\1e\Ý÷:sÉR!õÅ\1aÛ\82*c\82sX@-t\88      ç\96\8f\96õßr-8TL²Ï\81\8f%¨6wìs\82íf4b\1dø\12Ô²\9a\16NF+\r^\9d\9a/\99!É2\8bUÿñ¼AI\18³=\12;øÍ\fF\1c"\82p\88h6\88fù ê­I\12TûÑæ \97\b\ 1\ 3C\89ä²²8\7f\87覺ÊÍ1£f],N\8fóë4XzÈâçk\923E8Kq!\19Ýi©¨\ 3!\10\9c\999Â'µ\97\ 1\93ús\13\9cø>Ë~jÛY\9b~9sþ>9\89i\87¹\81\8f!èX\9b\90ððîézlÞü{¦Ã>ò\1e      Õ\13¾²¤1ÐÛfX½e~3Ç\86åwe\8d\85\95.\18ëO»\ 2yag·\vxH\85Q\1aÙ\99&4\88\ 4FoyS=Å÷Î\9a\ f°rhÜÜV\býæÇb+W3Pg\ 1Áå¹\81YA8\ 5È Q\85\9e%\83¶pÊãÖ5O»Û\8c\18\rW\16hE7kr¡}y¡È3Àt\99IÚ°\97MîÈ°\8a ëz{;kzö!|¬\9aT9$\8fÌ·u\1e\10Ï\14Å\ 6\14v\84Ýú¦z$\1cåí\12Táɧw\9dÒv8k¹M×H \8d\94O ¼?\1cëÚQ\f
+\84¼^Ⱦ?/Ää±+£5YÒ^\13\9bU\19\ fe2½\ 6ElÀ\92<ÍIp      )@\10·#\9bÎ~\83 'è\11hôc\196\18\870Dk=
+¿ÀÛÖâÁõ\8cÏ\eC«]tÜ+Þ¿{\8eا²«®\9b\vv¼\¦´8=Hî\8a¬>Ã÷ÙvÃ"8m°IõD¦\9f\85þn\12ãWÀ`¥\80kçØ&E\80ËZDÏ\19Vs\ 2xÙ\éÃy}ýQN¨
+\90¨[\e¼\12/ØòrV·ðÊ@J.Na\8d´ Î/H»úx\8a\92¿ú\1dOqyÛPB\04(øhç\86h\8bE\9f®U¼Úùz       \9e¥ï`\1cId\964Ǹ\87²ânÃ\91K\12\ 5{ßgªæ\8bxÍ)´-cÿ\1eJÆ:\8b4\8diæ,|\86\13b^\v\15Ñ·O«ê\18nFÇrµéøvK\99îü|à\93g4!ê\96K\89\ 1Ï\ e\18\88òÃatAj\b&\ 5ìÏÊ
+³_ò!Y,`Úi:b\9a\ e\1d¶aÕ'eávèûPZ¯ì\1d£\8f\r\88H\88\84,\97\98É\1d\89Ë@z"?±w[o/õ­®\99³p\8f]³ÄlcÆ\97\95»ó\19\19ÏAW\9ao,ùÆ9\85Kï{y\8e\9c`Z\8b?\8a×è\95ÚÒwòx\835S5Z\9ak%à\80\e\14\8cñV'P¨¶»év}\9dì\e%xR&\87.=ùÒl§}8l
+þöãi9Ì=,³ó´ÙtÜÉT<¼ýå;aì1\1d\1d\9aÂRäÐDÐ,ä梨ۭ\9fÏS.+®òg)3¾ÊXjH;\ruß÷vnãö\94 ¢¹`§\11\14%ÑÐqåy\rÌ/zHÊh¬\1dÏ       iøAu®#\1c¢\9de¢¡3ö\90¡lc§Q\ 5_²ôìºÈ÷-÷\9c×m\997\9c\87D0\94\14\8f\18p^g*~O\87~\8dkO\11\18%]'û\ 2³}.\7f\88\14 ÷Ü\977\1fÝ\989nâñÖ\11\9f@ÏÌD÷Æ!Ï\eÆv\ ew¯Y|`¹D\92ÄsÄQØ\93!\83+é4\80r5ÚYõE\1aY4kô1îõåæg\9a\1eü'úº¶éé\83Äù\8b\97\93Ù¬Õ\92¬X\ 11\7fðr\1f+¯Í\8c\9cq@\85Ý=Ò\13\89\1f\8chv)z\9a\vÜ\8a\9fYJÄõ\80/´ébÀÈO\92o\18\97ïU[WE³éé\9b\8a¡ú\ 1\9dÇ\8b_T_ý\9aÚmt¬ ,\ 5\9a\18¢O\19Y\©
+¾flú\ 5\ e´¾"TÊÀ\1a{çsa)\96É\1aLÚ¬÷)s\19u\ fIܲÄÆ{\9d\95õ;Û\ 5cÑp#QwLìS\81Ö\15²£"¥M/\b\85qF¥S\17\vä\9e°¾ë^zÑ{\r\1fl\ 11âüËû\13HÐ>eòpÔKÖ\ eæ\85+M\v¸ïT¢kä&ºóØYg¥86·x¿{%èé\1efE\7fö¾\13    ^xf\10\9b\83Ñ<Ò\16\86\8eÍ\83x¢¡B\ e\ eZâ;é\9b\10#\1av\ 3\8ff\16Îò\8cà\ 2ý|\10VòBU-Ù_ʶ\95ò`.ã\81y¿ib¶Cê<\94§@\80d\95êOw3\94R\124lP\88AÎ<«²È÷2°òN]\12Ár¼¡ô»Lß\81´B\bµ\82\8e.[ê÷cúçCO\96¶5<yl\97³ <äq8>Í\vµOyß6Í\95Åhf\1f\92çä\9fÀ^(0}®\1f\8d\94\ f\ 1\96F¼æ[\ 6J\99 $\86S\99½ó\94óªÊ»øâ^î:c\12]»**0§V"gûF4­/\86Ë\1c°\87\8f\v¾\9bBbLÃ\14Ttà®\98\85\8f\8d\82c\90Rh¥ºR\ 5ª\8au\ fÝ\ fÒ¬\12ÎÌ\ fwD\82I×+^\96õß'g\8aàÛ\91\ 3¹%âÛä¥1²\83\9eóF¢9¶õ\91å¿£h\v:ǯÿÀ~\14\f\16EY\9fáE\fô\14\1e\8ePK\91]Z\99%\ 6¶o±\95½\96[Må
+O4\82?ÕìÏ,"Ö®\82\14ȧδþ\13L\13<æ¹ìq\11\18\11v£¯Fº>3Ù²\8cì·ü\88ý]½¿¼IL\90\ 6
+\85®\0RE\8aÁºhË0\99R\94v\98AÊ-.åÂ|î/Á$%½UÏ\96O®lR\11½¡
\9e|\94½ÅuÇßü´5ß \9d\99ú Do\14Y\833\92!\8cK\94¾KP\8cÞ\8fÑ\1d¼ºh\8bàù¶ô\bÍá\9e\93\87o!ÆïÈx }üûÿ\võkï{6\900ò»\93\9f\19~Sg\83îü\12­ó\18g\92\12²-ö\91Û´g\11ªñîõª!íÖpp¢­åQ\12¸\ 5\9aOòc6Ûï\92\88"epùxKèD\7fb,³\1a\8a\v&Ï4N8\8e\ 6Rï}³i[â\ 3\83Gý­8¤{(]wùÅ\9aInëyÕ¹\8b\84\11IJÂ\1d[\8f â\9a«ÛÀ¸\14-\89\9cºÌÕ{rTB[ÌKlf<6kqXsfí@3a<L\vîCDfÊ¢\16£\bz¤jþò\9câ\8b\8böv1W\14â\99]\r^\89\16\7f\1a{Ó'7MéKL\98&B\91F\ 1;,oX$g¬ ö\8e\1fOóÚÆ\8f1d\8a4\b \15-\v\89ãÈêNJS\88ôØ1ýêRÞN£Ë
+`v&­\ 5\11H.\13      \9f2\8eº5È\92\17pU¢C-3À\92\12¾ôh\ 2ü/&\13¼\17\bÙGÄp¯áÛò6ZÝ\87,Äi\8a\94\8d\8cÙK\9b¼\92\8bê\bÙ¶\92à\ 3Ñß5½1  \93\8cÛ0Áe¼Ák(¾õù\12þ\84&1\9c5yÜe\ 4Z\a\1f'@\8a\93\89Å\18P±ì\9câŹͻrsükÆS\1eBãö±5>ëê\11\9d ;²\9d²\8eù\179Ë7Â\a¼\12Jß    >\11ÒêT="M»Pªþ_\91q?jÔ¼]sc¾ÆàÈ\8fð1\1e»¹/¢\8fý\1eÜ\80å.C\ 3o!mbZtZ\17\18{¨ÆM+ï4­uºí\97\94Ð×l¡\88î¯BgÑÊ\99Õý\96õÄ\89|¢1\8d®GÎ`÷EK!.\ 2\ fìë\17p\87\10\89/^\ 4\90Å\10é\87Ú\ 3ìïf;Âç\96d¶QV©ì"QÝnçöÐMf\ 1e¿ÕyD\82¤\94:F    ¹\ fê¿Ú&ë»ÜñB6ø±I$¶üF)_¦dÛ/\97W>\ f\1a®);tsÑ\99\12bð°ü¦\7fd©Æ¤ /\95tÁ \15\9dÑ#\91\ f\1fIML[áÔÆ
+c@ÉÕ\8e¦;eÑæ\8b%1^Ö\ 5\ 4\12zúîè»*9\11eè·ú\10k>c5\94\8d\86Åw\ fÃ\r\9f\1f\9a\18¹÷\1a>{\89\80¡\ fåxíÓ_Í2TØ\9aèÊ»ÜáÆ@*³ª\ 5\ eÕ\9aÇ0(ß\ 3¯êV\ 4\ 55\ 6Â;\90\ 1¶j\92\11\89\ 4O\8e\ 3\19\9e,xÑPý¨\1dGÓ3~Û dv{¸ò]\9cv\f\ 6\8a¼\93'#nE®f\86sç$ð³:
\8ew\ e\ 1\14\ 38T\8aþ\93åÃÛ§ù\17\154 !\98E     ËOUÿ 8þ»×pIL\87\86ä~\85\ 4\8cK¼±\96\9fYY\ 4\0¾~6é\80\88\956~*\86Êt\ 6K#\9f¹F }ÉsGç\88õFu[Õ\ f_ñVÛk\10\83àn\1e0丫\93M`YoÆXQó\99Á\81è¥\b\aÅyZ@X:qïS¼ñ\99vç^\17\ f°8\ 1.\9f2h\1eÍAßß\8e?¾Ô ';\99\94GQÿ;R|FX\17Å\diíHZ&@\11u9\84\ fô÷\8dA¤êVMa\83\86y¿\ f       XCë¾=\v:yÍ1Uø\8a\922ît8)Ðc)×pw)¸\17"®N/$\12ã¼ ØBÍßN\v\88%¿¯Ú<ï÷\v\ 6\85\ 4¡ØB\98ýJÐs¶\8b6©[k,§\1dÄ\90^ÿP  |W±Ðå¥èÁ\88ß]­P9´%­¢Ï§VñBy\1cI¡(\87a0R.5*í¶Ä­ÜF\1e\13Õìêd\riÒÖÔ\ 1¢VAH\15Ç»n­ð{8R-A\8c\86²\88âkY\aö¨¯ÏÚ \98\81Á×í@\8ey´P®êçe(¹\9dÀ\8bQ$©5\9dÑJMbI|Ö\18cµ¯O?\19W\9f\r׶a­AãµêÉraó$ð¤tÈ\9dx^\v\9aÂu¨ÞIE¦ö\87øó!¤i`w\ 1ö?ì\84ÜË\11x[ÙÅ»åF8+\1c1T,i©34\85 \85\ª Ücµ~R\12ÂÁ4Õ{i\97\94<\1e\84²TÊU×#ÆgÝÒy]§~^\rÚÒ©\975¶R¹°\14\ 6\1eaO\1e\9d-ÞûqÊ\124        Ðùw\1f¾ÌT¯\82\81\9cj<c"\86\8c<&é÷Þ\f\86ì^\aÜ\81¦\1e$\ fh\1e|?þÍE±\15õYM¦ò\86WÔ&H£:æ+\80±@E\13õÝ\89P{¡ÂJó¡\8b$L9s¦[M\1dRPo\8f´93£:\:\98Ç\92\ 5rX·ØfÇ
+6µQ×!H¸U8®öITÚ0\17D`«\17sae\8c´£Ç°ÓMþ\15\1dx®ä\85&2po\8clD¦ð\95D\1c\8cº\9d¸&c#ýËÄ¥Íaó¼Ä\9c.A\1d\11\aUL\14²b1Ó¯\9d7ÿÀ*ñ\8bBöäç© ¢~\1d¿ìåù<$ûîþ\94\9cn\ 1÷\179\12çÆ\88µÝ\að\81Ù1\12¼Å¡0G/y>I+»$>\b»rkd°Ësæ_u\8f\14l3Eª[ÍÐr\19eùfò\992(Ç;\8aKWçØ1_s§ìNk¡`à(\11jX\9aír/ö³£o»q>'\91¨e0\1f\89Ü2¦M=ìYò<²\1aÝ\9bÂÒ\1a\8cdTȶ\90\ 2<\9c'\ 1å*AÖ«0\92\12ÒE4Ù$\ 5¾0æ±m¾§½\8b8äÒV\0vñã\ 3\94Y}\81¤×sØðÒº\1fÙ&|'5®öò\b?¨¥ùÂöl\91ãèÞG>µ
+ÛmÄã\ 3\9c\7f\11ªÛËþf\87ºÆ\ 4~\99\84VF§µ\17]û-,d\90\80`ÇU_å\f7\98%X\8a¯ö\9e\16\vb\18yÓ¶\16¼\90û\ 6Ù¦ù``d\7fPØqºX\18À È$È3-i©HTëÄÜ\19\a«Eðé`n6L\ 6Ý×]    ¤\1e\9a\87\1f\1do\931Ë/²\0\87bS^íP¡ên\81v\1a­ZDj:å]¶§ú\99V\93\88ßzMºý®F&ïNRB\11\11\86\9c9il$\9cßØtÿV\ 4Ë\1c½½ÇH\88θrkïy\88\80\81ìF\9avÀa\80i®c\1d÷\ 1¢f\96\v\93ß\1a
+xß·\rwùÍƾ\96B!ìT\9eʸ¢ñã°N\88¬r4\90Y\8eî\ e\1c¸\95\15¯$ó\ 4x\85æ^C\86kGãÜL>\ 4éUül\18[\\1aÈ\b\v\9cò^\93\95ë\v\1c\9b       cÏ\8b\18+ÖbA\0sBê\b%\ 2ôµ<'NÌe­gw:
+\18Ù,\12=ãúÞ\18´½\ 13 äK\91+ÝJ¢¡CFP\84\12:£:\80E2íUÀ\8eãÀK\9aåÙô\8d\89H´ùçË(ü\8c«\9d2*5Xp \9e0äT'\14
+6\9fw³^\91~§a\fùFD¹)Æéw.\ 40¢¹\ 4\83¢êKÝ}µ¤ð×C\ 3Æ\reª0\86à.E®\10*\94É-ß¾~Tc\fÊ\82\14f\18}µ´*íð(QE
+®c1\84È2È\ 1ÝW\1a\97\9a\9fØÙ\95rÑô²\97ùq\8f$\83\11h\97;Fm¥\8e{
+V\12\98\f\13\8f\e\89¦8\1cßô¿\96Ü+ÔwÛî\18\80\87ÅÉÕQÂ\16ó\94HD
+íæ\12dPÖ\15Õ\98±5C\8aG¡=\99\88q\9ef\89p&Ã\98\19\92\91ÜJ\18\16Fg\80\82+·îÚ\1f\81\e°t:\1c\96\130T~ãl\7fÄ\83on\89\8cHY£8\ 4óñrg\9aÕ1w÷¬`;eåó0ìÝò}¥íµj\1e\92\0¢wÍ\r(\14\15yúÊ\1e¼8ZÖ0¡$&à\ 3\ 4\8e^\90Û\85\97\85\eBåÚU\e%hÁ¼c\14\10Èó(6mM\9a  J\16[\bì3¸\9a¥A[\1f\v¬\8b8 ÑÕL{ªéë­/餤9¡3Év¬.1\17{\ 6Ë\96\19§o\97µ"¶\93^õ~\8bP¨pýâyÎ\83¸ªÆJÚX"o/\ 6¶FOÎ\b\a®Dà°\1eÐ{þ\9c q\1a\1acéu9\17c£Dâ\80Õë\93É\97Y`|Ö¾r(.$óNÀî\91Ô\ eK£p\9b·ïg\r\"\fÄ\16àzö±!þ¡Úå\ 1úõwmJléÏEµZðÅV¾\9c\1dMüM°\e¬dG\v¿Ú\90Ï$p¼'(Ý\8aÔ\13{*ï?yÆåõG\19À6{\90Ê\9ejÖµiºE\ 4×în\8d\15òBèö\95~!¢ê\1d\13´a\19íw(\1c·)¹\8c\1co\16\94\16{\94©\9dlñ©<Ñ\9aÂ"\ 5\85^ÛÕG\fFGGyÓBEYc
\99ÝÖ\80D3p\bæ »Rt\ 4àãA\1c±©\f\98¤±      ìb(C\8e¨\93n\98è27`Sø\85ܬjB\19   î³ù´V@\ f\1f?Do\81Ô8Çîí77DZ=\19\0\92"+ñ\15S\ 5<Zèd\1c\f\7fß8ê\0\8aUOOÏÒð'\8dß\13áÁsË\12#¼Ñ%_\88kÍX_\v\83
+H\ 1     ÒvÛ¨\ 3R\89\99³ätõm\ 6\8caXÈ\80Äãë\9d*Iɾ#èÍ£\ 2h\9eõ¹OA`\88\19³ëøk¨`z\86ùãbóÕyÂZ!\ f,"ÑR\9c@\93?S\97N\90](¨&Ä\17n\98®\9ax\91J\81$©Ä=ôÔ`©\88\97\9eKXwïöm/yÓ\8a\96u\94N.{6åý\86Ñ\96-\82\92\8eBº­\85ä´­üjfôéÉvØdc¿¡ÚnîáG\fóºÖYÞ/\fêi»\16\rK{q_\89?õó\17\8eàD\ 2Eæ@sØ\ eÜ\18ë\7f \93\14\b\ 3KrÚ\1a=\8cßßÐ\8aev\9a\ 3\83C\93±\88Ä\8dæ{·\ 2Tb¶Ëà\95øÄ\ 4ÎPè¸á«~0\80
+.\18ÈPÇ\ 4x\86\8e\1eÙ÷\83êÑàë¼"´j\84É\85\89q\a\19~J H\9c\99\97.*µç`çO\91Ò~  ÌÓi\ 4­«²¢\13;/óÂ9nÎzü\19wù(úÊõ\96R|N\81u7\98KR\9dë;}\14±h]\ 3\83f\ 1ã{\b¼\81ÿVI\\8dÙ¥\ 3!\9e \90KÀ??y,¼.[\0à\81ÒT½\83Ò.5,\86zíõ¶L¼3\0¾§ê<eû!ö¹G\1a©ùNb³Øø\8b|*\ eå«þ*\9e*\ e\1c\9b\17\ f\15jµç}©\98A`¨¼ç\82fr2\fÌåÊ\1diZ\9aeÖñ\87^}¹±ØÂ~\97\887\93·PÃ\1c2ÿ\1c³@¼¿g°\7fð²\ fszM5é^ZêÌ\1a¹@µ\89\86£\aGøùBÂy\12ûSé¨\83(\83\9aÜ*CÎÖÞoèÁO/×\9a\eF§2ݳ\8c\ 32\185²a \14ïî:¢\94è?\7f·\rM1-|J\85´\ 3\81Ä\e].\19\10V\8f\ 1Ë\1f®ô\98ép\86\1fÐçµ\ 6\95ë
\13W~+ßÜ9\18×\12ͮ´z\16¶~\92ñã'ISG;2\0\8eé4\ eã\eñ)ðÇ\1ffmYA7¯ìÆ;á\ 6:$\97ò©      Ì+rG`¯_\1e|³³\8d²<á\86)sÜÜ6zG\vf\8b(id\16\15lf\8aA/\12®{Ã\1c\1fµ Üs\ 5¥\8fïË¥f\1f¨\82,jÑ)¾\97\8en\8a\91)\84¿,mÈ%\8b\852®»\86\89öÝV\13¯L\r¢Ðí66ü~dS\19ÇÑóP<\1e\ 3«$\94x\97"\15ÝÖ\1cý;þÇIJµÇgÌ}m2DKÄ>\9b¡\10Ee¯pÚ\ 2¶a!¥\1cØi5n¸µ&ªxñá°`¼eÊÑI>\8f\f\93\87¨\84¯<5üø\19áY½Æ\11^-zÄx/\9fØ\e\1aSÆo%ï¿Û\98k\8eW\15hkHÓ\9cO\96ºÕD\8b\fzj*ZÔ=ÑC\aeÌ®\f|\ f\ f¯ç\r³\9bÖ®TÌ¡K)4ni\90\90ø\95\88}¯Ü#Â
+\8e¬\903õ2ËS\1fÝko \aÊu]9\18\85\8b¬ù9Ãþ     Ð.x
+ìvá\12ú}«°\9e5i¤óäû½$9ÈLû\9d°\ e£W\97Ð\17y¥E"»4\ 4\85 `\84í{tâÖvZª \88\81íÚ¼­fù®Ïµ'ºvz\16ÃÕʹ5F\12¬Ó/\86»À\8dø¦»\13/Ìm`\9e\1f\ 4Ü\825Êq\9bgú\ìÊ\14\13\8cÄ°D©\ eÄéå'Æ\1as\10\ 1ÜÐo
+ø$\1eøu¯Fg¬Àþ\fEN²äܱ'¡\1d¿«J\9a\95\80þÇ\9f¸x\ fâ_\T\87\8aJ)Íó\1e\9b®V        ¶Pë º}"¡8¾Gfü>\127H\82È@¶o@Cc\1e^âè\99ïéÑ\9b\80¢³\ f\97\1f³\rºÏª\81¦¡Bð\9bK\9f¦P¼\9dCÙåÀ ]MU¥A±Ù¢TcH~2ÑêG\93PW¹Ú$I"âÿÚþô+h\ 1Ì\96\1d\9aXëPP[Et£ÐÝ\1dZ±{æ\0\14o\95]Pm]VUì\95\94Ax®\90\9d¼\9cÞÕæóú·\96á\12°Üír\r¯;H23*¥îb\90\15­ªË!\16\17\15ì\1f\16\90\86|ÊN
+\b\ 5×R~\b\ 2\9f/EZ\ e<×¼\99\1dTñ$«\8e\90âXð0×mI\9cåx\1a8&M\85«Nî\9dæN\93\86óï^º\9c\80\90T`\19\ 3\95G$³~nÒ\81S\8a\ 2\91`Ê7Ä\16òC#ñ\ee~\1aÈ\18¨[gjÚ\ 4\88'/:á¸\9f\r¯ºû \85åg\97fØfKÜYB?c©Ü9ù\92±4³ÜCámñu­(Ouha,Eü\92*\96\15ÝÅ©{&ùn|k\9d
+XÖIc\ fÿµ]¬\1aô¾Àήö¢\19\18à2Ã
+xy\8co;d\9aö©A\12²i\99÷#\bØ\95¬¼8eg \1f:l,Ö\85­\9fA=(öDxû\ e»éW:¶©3\98ù¬\1dÐT\89<\bÅxîøÓ?±ñè\98NfÒ¸²\10ÜÞqÓ$¼\10¯Ýõ\8cù6\9b\97+kZGu\ 3\1aÂ|h\1f\8eFzl6 )³=q/\88Ý¢Yaþ0è¦å'ëïRlzð}]ÝX¦ÆúʽÕû³A\1cì\9fP\84C\ e¯\eúà*ø¿¯¤(ÄL\13g\f7Pa³´_ùÆ!c\15ÝS¶Ò\e\9fò\$¢²LT«}Íýñd6E0!èóÀÒ\9fyíCaé ÆV\90çtJ\a\92¯\ e«\ 6¹p\82\1fÀ\9e|\13D9ìJµ\16\y§Z² ß¬\13É´"\87\90ô,^-/ðqnÀ\19î`,XS\7fÒÐ<ª¡Ô\a®û\92\9b/áw\86ýtT Ù*   \85\8a¦Ý\1cðz\f\ 1YÒÜ\vH!\13ªV\81bð¹\9bÅ\8aÚÖÎY\93¿Á¸ÊV{ÚQ-^        \9fµ
\aõ\1cë\81Üd\90\19\eñ\ 3c½"¦\98Õmz7yºh\9e#£0\89>Èé\96\91fâÇüV{0\9bóÓ|Ð,°Ì%N£q\ fEf¦@\93\1eÒgÇOÉì\84\8cQnã©@\99\bfL¿\88\98ý;\9e\ 2ËN\85£%ß´i\92Q\94L\ f\ 3Ì\ 1Í%ÄWÍ8Ecõqp\1eiãÎlXø\11ãÄ\9bê®}¼Ë¥\8e£³W\ 1¦P6\16HÜnÕo\82\8f©½Ç?Iòè\83¨
\ f¼¡9ÈÒ\7fêD)KÎ;§kDòR#vkɤ\82\15qÏs8\9386ô\92ÆÀ(s0ÂW\13+^\18\8b=°ÛÓ%Z3©\87\8a    Eu\1c\7f[t2Ì«S¥fD\v\95²\ 4\85½(9U·~)ª)uBC¢Ñ³ióæ¢\99UÜK\ 4}\9b\8c­Þô\14òýQ\ 1¶ÞC\9bÆ<\0³Q`Kº\84\89\81±l<^~Ö\96ýå1> '\ 1¦¼9+\14\87¦7úC\7f¥y¥æ\8a\92\ e¯òÐT\91»ûm\vß\ 5\ 5ò3\88~m÷\ 1ö\9e§¾@g1¿a\14\17J\1fWÀ(VC\82\fë\1e±s6î§;ù%=²=\88AÚ|¢Îi\1e\11õ!\15ÀºjI\9eÀ\90U¶Õ7rvªôB\97P³à\12·øQrP
+NßRð\a\16]´M_.Gý}\94Éb$\88¢(D6\8cäZ\88óþ\¶¤|Z×îS\9ap¬uËg\16ªò\9b¢=7e\b\97Î3F\1aZ°Ctñwô­>\a3¨]\8d_´ÍÁ\16@$þ©;Ì\99D\9dh&X\83m\9dÌ\15üØÂ\86\ 4\ 2ÔvCS\14Îè»ò\83áª}\8f\12=HQLèR\aB/ÌKÆþ®ãÅxÕ\91Å\ 5L·©\8c0\986^\82¯Øé_G£\1e2\83a!Àûüñ ì¾2\84\93ÙP+\84¢X1ÿX l¶µÀâ>úi)\8c\e-Ã.³-r×{\\1céÈA §Sü@û´\1c}7r¨\9f\ fZY\9d<ÉêG1\13(º½_x¸0~\81\9eè9[#\ 5Ô\8a\vÕ\7f#\83ø\12OYº-Ý\ 5º®U ¯-çê±»¡Ù\89Úwt\98\1fï,\9bÝw\1dA\8a%ê¢-\81\16ö\12ê!L}_y«`i)ã\86í2t\8a     $÷ò³bË9\97jCUdr²
+8]\10»Pi0CWxV·\9bO\ f¬øf>m\11\9dÚÉY\1döNÕUüÎÞ³;Z?&\1eAD\95Ðæº\1f~\83_¸î\eW\92ê¢_2\e\97É]èM>\a\e&%`d\83á\8e\8f\8f6§Þ:    \f%+\'¾4²£ºÒÆûÝ·®h}\9a\1cõ½W~u~ÐAoe YrW\80Ó¿kyõ\ 4÷\8dK\13".\ eà\1dN\12lj\ 4\86
+hP§éuÈϾv2¼\85qKQVÈ[)/ùÌþY½\96òT*T\85\94ä÷7:g²\83\98\8a\8e\ 6\b¤\15\0¢\98\8a\14²Ce\11³1[`üD×E ¨Á\83\93´\e\9a#´àìÛëÃëPlÅpåYδû¼\81\b#hñ7]GWÎR\8dºì\81\96í/\ 2OJ\87e\8fÜ\89\86\ 2¯\96ÔG9\1eöÍ\82åë\82C¶Ä¿.ðù;Ä\9c/)Z.¾P\16Á5mO\1aÉ\80J\f \ 40¥FNH¡5³eá¬I¦¤3\8eÛ\1a£~\93¤´\0\1d\84ô.åRÈ\19w\88'§^ð)]VqÖÞ\9c\9d½æ\1dº tgÔ\999ºpôÁ\92\8d»d\9cFgX1®\14å¾ébkÿúÛC\eØø­\88\99\9eöñ7\95\\0\13\v)CA$ð\15jZeþ\ 6ÝßY\1a\81Óöå¶fJÝ\8c\aµÏ\9b\1ee7y[6à\a\98«'¡\9d\81"Eø`^{î«\ 1\82p.ÿu\ 1bC UµÄr7I\90É\eRD4g\ 1Y\8d½éä3a\80\836\r]°ÒeS¥)Å÷SùQ6øD²=.Ò7'4û^ýá®XÛâ\12\b»í\80Íß\9cZC{<Zâ\11\e\87x\1eg!gCóu!h\9a\1ekW\ 1­\9a\9dØ;a\11+\87ø\b\7f\\8f\91\15«\8aføï*Q\93\fq»µ\f"T5×útã\88(ã¬\ 6\8e¬-c\90è\a\1a\97å´\ 2¶­Z\85Í\1c\19\92nÆA¨¤\84\18/gòÖØ\1c÷cü\rª\839$>zFû¸#\153.9Ö4\82\89U\ 3±Õ±\80;!øÇ Â\9a!&G\ e\7f\10³t¢\8e\8a³\8ez&Ø \11ÞD12\91LõO\9eXR\ evHVàpÂrý¥¬¦Ø\1d±@rEyê´9­<'__\91tvÙX}\1e?È,\88\9f­\16T%Êì¡\84F·F\8b\1açÄ\r®k\925ðÄñ\98åÒaiú£»¿+A'\92b1Eu\7f`f9\11¾\88`ðí\eë@ÆÔ\ eVçfÉÐÆ\r\1d\95úCÕ J\92HT    |IÄ»ð-Ë.\7f]:à\19\9e@¿¦y\ e\ 3«8ª\83Ƕ¯J.ìà2wi"\r\12\1a6ÿÞ\ 5RÖý4Eå?¹[ÉÌ\ 2O\8f¶&x\ 6\85\b\8e       fÝ2X\9aáãÝ}3Øù\99í3\ 2\89\ 1\97v"Y¸\10qy3\96çæÏ÷_âyæfêâQÓÚ\89øß
+\8c¦?¹Ð]ÙnÂ\ 4\11\7f©u\9c\ e\18Ýßx\85\f\0AÒì¦[h¨±Ûª}õ¤ü\86\89\v\97zl\99«±Øê\99\96a}^¶·Ð\8etq5ØxP 9\97ùþ\ 4\82'\9dE\9a¨Ï\83É@}\9cgB$\18cÚ )W¾\ 3\18N\84\9dVlLe£!=!tJÀ\99\9b¼ÈâZ´ß\9c\85\aàbÕo\ 5µ\11¤r\19\833|éëå·\90i'\94}#Ó\8aá\95[ð¾á9ï\9f³GÖ%ÖD\175.y]\ 6ï& -Çd\ fæ\ 4Á\8cTzOèð\ f\18Ó·\ 2É\84Q\93ß\bÂÓÈ:\9dÍv*KÙû\94WiTÜ        §Eñ£\80)\183ô·K«V\13øï\85êÁ;õ÷Ïlª\10®+ä°HÌ®Sé\8bò\0m\13_ÌS|\ 4Ø_\81l0]í÷\aS$)\85ßÝEÞ×\e\13\e\1ca<øÒ\16\8d9\94ê`>¥|Ú¡\9b\18@rÕfm\8e¸+5\9c`¨ñ\87´/\8d\86\16ý\14\98\85\82ø\96+}¬Ï\9c;Kh\81§ÙÏOÁÝ\1c\ 3\18¡þÿ\ 5ï\0\10ÿ0ìn\ 4/Ûn{ÓÜô\7f$¨ÏÌ\19Ê»¹îÀ¹\9fóÕôÚôLML±ú\80O\11ckß^ø\1d}+¯{:º.þ(\ 4ÑMìÀQ\98\90\b\ 1<\94\84ò¹úvè\ f® /`8ë\7f\83¥ñ÷j_ÙÃð\95ïlQ\8cK\13XxõÓ\ 1HwÅ\16õ;â©*ù+½w&\8b\96b;T§\8cÃx¿9"\1a¬       Ý(ö¥\13Úg¨|ó\8eÉÍÍ\9e¹Çf6kfÙ:]Ð`nn÷Ä1åÂx¸\ 2\85Ýb¿dÑõ\11\ 2|d,°2m¸L[×°°ÂBþ¬00â˸Û/Ü$µ°wÀ1k»¿\11Ü\87¢DYäëøÜ'`JQ\84\1fía¿¼G¨;   Ó©\17¿\8d\0¼»
+¯Pf>
+endstream
+endobj
+2909 0 obj <<
+/Type /FontDescriptor
+/FontName /GPONVW+CMR10
+/Flags 4
+/FontBBox [-251 -250 1009 969]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle 0
+/StemV 69
+/XHeight 431
+/CharSet (/A/B/C/D/Delta/E/F/G/H/I/J/K/L/M/N/O/P/Q/R/S/T/U/V/W/X/Y/Z/a/b/bracketleft/bracketright/c/colon/comma/d/e/eight/emdash/endash/equal/f/ff/ffi/fi/five/fl/four/g/h/hyphen/i/j/k/l/m/n/nine/o/one/p/parenleft/parenright/percent/period/plus/q/question/quotedblleft/quotedblright/quoteleft/quoteright/r/s/semicolon/seven/six/slash/t/three/two/u/v/w/x/y/z/zero)
+/FontFile 2908 0 R
+>> endobj
+2910 0 obj <<
+/Length1 1075
+/Length2 4617
+/Length3 0
+/Length 5298      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\93gXSë¶\85\11\95ª4¥(Å \82\14\v\88Té½H7\84\84\ 4H\ 2!Dz\95Þ\11\90ÞA\8a\ 2"\1dA@@©Ò\8b\82\ 2"½©\80tnÜû\9e­w\9f¿÷Y\7fÖû\8d¹Æ\1cÏüæâåÖ5\10\96·ÅÙ TpX\820\ 4\b¹\rPÔÒ\87@\ 1\10 \98\86\97W\11\8f\80\11Ð8¬\12\8c\80¸\r\80HIA\0ò®v\0(\18\0\11¿-"y\e,FÃ\vPÄ9¹ãÑv(\ 2\80_QàW\91\ 4@\1e\83À£á0,@\vF@!0$\ f\11`\80\83£\11\ 4w @ÞÑ\11 ÿë\v\17\80\ 5\81'"l\814\10\bÀ\16\r'\0l\10vh,\rèW 5,\12\a\90øûØÖÕé?\12\11\81w!\85\ 2ð\93B
+\0H\11mqXGw\80-\ 2I\ 3ÒÆ\91z!HIþ?BýÛ\ÅÕÑQ\e\86ùeÿkHÿ%Ã0hG÷ÿ-Àa\9c\     \b<@\vg\8bÀcÿ]j\82ø;\9b\16Â\16í\8aù·ªF\809¢áòX;G\ 4\0ü÷\11ÚE\ 5í\86°ÕE\13à(\0\12æè\82øë\1c\81µýw\bÒÜþ\8a\0RQ6V\90×\10úû>ÿÒtah,ÁÐÝé\1f×_Å\7f1ä7\93¦\83\ 1ÌÁ@0\18B*$=ÿy³üW/e,\1cg\8bÆ\92\16BL\1c\0Ããaî4¤Í \91\18À\13\ 2@cm\11n\0\84\e)0\b\88Å\11H\9f\0H3ñ\ 6 qx\9a_×)\ 1&\85üuô\17I\8a\0@\ 6¿I\12\0ºÿ\ f\91n\ f\ 4ûM$Íæ\1f\12\15\ 5\80à8\fæ·\ e\ 1\93\8cmÿ@\b\0\84ø\aÅ \0\10\12ç\8aÿC'u¶û\ 3I\86¨?P\f\0Bÿ\81R\0\10æ7BH­°¿½I9±h,â\ f\9dÔ\e÷\a\92\9a\8e.N"ÒRâþ\b\v!uÿ#\e\84TBøíOêFxø§\1f©¡ëo?Ò`<\10ø¿õÿ^\v\ 5\ 5\9c\9b§°\88(@\18*\ 6!MQ\12 !\ 6öþ?upW<\1e\81%üõÇ\91vë?\8cD\936\11\81pCÀi&ÇppéGöOj\82\8b}\94ó\ 6\v\9eQ°«\8dÕ~Ù2ÜD\e8\11wƱ°[ÃYðSåý\83ÒÔKt\vç\17®=<bw   \7få¥×§²éï\1c\9b<z²@|°\90êQÏ~ÿ{ª\96ûW§ë?\ 3\ekF¶×ÄÎè\f}ê)N0ÍïÈØê\ÍÑåW2\¤\9câ&k5'Vµ¦=\12\97¸¯\92êh\14\12TÉ'­Ï\90ì\\1c*\1a\90!!þÜôû@\1fû\10ª:¡\8fßp¯\\99\ eò¨²\1f\9fXl/\ fÝ5gI\1f\15·Äö\8f\8e£Æ0\8e(XD¤ª\90èµÈ¼è´ú\86£\83çé ¹\ 1\91\1a¾Ødì\88lúc\98¸r\1dOüh÷ìU¯ª\f\1f`ÀÔHPO¶æC(°rái\86ËÔ\15mÓV@î\87Æ´\9fÀ[ß\8d§±ÕÚk\r÷ýÏ\94N\8aT{-åe\ f:ðë\8d«é¸Pcv¤§\90\8d{IÕ!\9f\93\14!ÞÖ°\v\93T1ÉjL8\9eé\19ðÏÊ\87Ó)ç-"\18ÓËÒS\98ÃÛguû\8en!×ãW«z©\ 5K(#gmîå\88\98\rC?\14ë\ e\9dM|*©)r\8a_É»j\1eFÄ­\95Û[PÏ}\96ì¤bÎúWxÕk      \9cR{\9b\9e¦À\ 6\13\8bU¿LxA\ 2¸â\13\v0Ü!æòÉ1\1e,9÷\9dtß¼e×V4j\94øn4V)Ñ\9fôÝÐî'}N&}\90\9bõv,*!½×ýû^\99ÉèÏ´ú\8e÷Vë\96É&õIÞiI}ï]FǬ\7f\9a\1d4"]î²5ÌÙ\9aâ\ 1ï²\ 6]Üù\88ê\8fÉ\aܪVé\ 4X#CbÆ\18(7r§_\)\víðy¿©á<\7f\99F4\91sJ\fU¤ÙÅãü4\8cü*Ãí«¢NºÇ\85k?cåì\86.q^ðº§\1ek\10\8cM\ f]°BC\eB\9e\8a\a¯T\9cy\1c¶§Å\9c\9eÌå\ 1^O\0V2V\|½óê-`{\8eøF$\rR³ÒXá¦HgOÝ(á\r\86åÒrÕ\87$Õ=ðY{\85NP^)B¾\89&ÿlº³>ì\ 6¾M)ROç&ÖRòC([\87\199ÁÂU\94>2¨õ1Q."\8eö(Ü÷¬.`Çjï\88ïîóç9Æ»ïc\8050z\9f¥\10\9eÅ>f%týö:1ÔA®ÆýôSuZM\87ÙO*Ïü\b×\rÐKÂ\8b´^\85«Iw\98Oί\95ìoômW:ë2ä\ 1\18\80¸Èî<\85\ 3F\ 3>ç¾\18?\8e\81ðËþJ\9cãpÇ-\91\9e³e#-\1faÛN\8bÚkYÛÖÂð\99دgÌM¼ãü=é\ 6ó¼G{Óä¾Ä¢\82\84¦\ 5é/Ì:\1f®QÓÉBd\8d\17\1dÑ<
+Ï+Hy¤úÀ6T\}ÅÊ6PK³ÀosB{kf\11\89Ä?®\9f\0´õ2½;L"¼v}nâï\83\13h>\9a\83's\rÜ\91 7\9c\9a(QUò¼Èsn§I\ eü2ã¡Ú˵\96gëY¥\8cf>ï\ eÁßûn,R:}:\7f?<¿mÏ\9füYç\88îQ£\ 17\15¨ay¯û\89Ì&\86\1a\9d㻫\8f\10\8e,cȤØ.9s\ 1î\90ÉsͲ]\ª©\90IFͼ\vfiô <A\8a_3E\88²}y\86ÌV*¦\87öøNÏ\v\8brxð\13î¹×\9eÊ\8eï\f7Ýï¢Z|û¿5d=\95\8ekä§çi\10|EG»Zà9.¸[À%\1cóñðå\9d\8b%\15y\19\vOJ_e\ém°\1c8\8e\95Êc¤.æúÞV\19¼Ö$yÈqmcí\85æ\1efz»u\85â³ÿ\10mûͳ[Ðá±\9cô"³«<ù*\ 1I£înMfÀ\87@co\9e)P/±\8e\8e3á.\9fáD¯È\8e|}n\1dË\98=V&Lmï\82ã<6?ñÖKÓsS\ 4\ 6\ví\94sRN\91\84+äno¾\12\98êf@mÐVAÓó]^ÈT14çq*cI\89\1f\8c9êëD¢.ë¶\0Õ\97glÇ\17©@/ïÌ\9dt\1dè\14¨\ e¦d¹\9c\v=\9c~¾<\1fy³ª\ fp\10½­Åj\ 6\8f·\8fñ\9ccýñ±à¼ú\15\882oÚ:\85^\r\1fsûtáñ­éOì\1aé1Ïæï^Ù$\8bÔPTx£\95\9a_?\14uÜïuÇMEl´\90\17ªGCßW÷lä\ 3Å\ 5E¿f\96)+]^ºªÄS Îá«¿Uôúm¿\bÄY\99±÷*Á\ar¶v_g\82X\89à a»\80«oNW\89\ fßµ\ e\9a\93\19Í,¼<\flzêN   \1a7\7f\95kX\1e¸Ï\9e â`-÷VÀ¼="dþù}¬;^\ 5K\17\ 4\9dØç\rì¥â\8dfO\88²eãÙöñ\ f_¯d¤¾ýÒLetUiUûǾ\9aY@c\ 1ö\90*´Àñ8ôZ  \X\aRÙe\15·ã¬\177@S7ãvyÁÚ\ 5Ðê6\8f\10ljMKR3{Ä\9bj\1eË\80'\8fF
+\ 6      \ 6åÕ\9etØd\8d\88è\ 6lw%g\85,\1fï'æt§¡@çA.\88Ô¬(Ï÷eê\93IõèÆÚ½&dx}à\\rB5\7f \84(q\96Fp2&»<&p±\9d\8fÚ@©é¥VØ@\8c\ 5\a\r\95Â!\98yD\b\9e\93%ýÌÃ\93so\15\14\12"²¾U×ëÏ÷¸\ 4¡.Å"\12h%\15u¦¨\82úT\ 6\13ò×eÂBùÖô2k\v«£L\9fµÿ(\9c¹/CåE~ Ì\93½x\87qÏG\8ao +\8e\1d£\92\92à\16®\ e\ 4®_ñ¾±à\878ðÙ¶ºsxS\90GûÖpÏ ®DTòÊmÛLÆ(\1eI\ 3'×®á'\18z\91þ\8f¥\vÂf/L#Ȳãñ]¥        \90YGË^a\19|k\96ªÃ\vQùìÝÎáâ²´»Áøýl\84ð9´\97ø\17ÑFûÖªN8Ï~Pvz<\bï\94ÑÐNlMü\12ϳx+\fï\1e¹Ä"7L^câ!{yÎþ-ô°k\7f\9fÅË\82Û\1f\89\8f'\8bl*­\99+àH_\11\90§á\86\Áwó>ëw\98\19Ù²æñÔ²^\81íB\947\ 5¸\ 2RS
\eªß¯Z\ 6Z\ 4)\18\fþäÕ1®À\b¤Nq{IjjTÜÓ9\ \9f44LªªåUwëþÀZ H\rïB\82rK÷SO8%¼£éZ>PÛØúF9ÖBè¬\8eÉ^%\9fÓܲ·\90Ê\91|EÇ\12á-ØÉcµ\10zvº\9dë^Òê\92\9búÍ\ 4ãÚÔ\83\1c\15é|\826kMÑ,èb~þYoNQÉ\1c\1d\b}N{\94\ 3ñÃ\97\1fg2BÇb\15\r.z\9c¼a\82ñùö¿\8c\17¡¨Ï\u¹e\ 2®\84äåÐ1Ð¥yMewç\97èK\10õ\83ÝY6(\14\ 4\ 2\9bÚUe:¿cÈS\85¤o\814<·n¸Iè\15¢¾r÷UjéÎúPDlÔÄqò¤ÊÖîèÍ70f}H+\15|¡É\98Dçû@Á\88)n\1ebÙ²×C¡+ía\90\84nü¼P¹·].\ 2I\8bD\85CÇi\ 3òcéê
+ßÇ:æ){v\99µð2²(\8f|¦¸Þ¾oÜÆ\12`³¼]\126\7fZU\ 3×J<\1d\8cÞc\87íáû;i\1d\1cÄÇòEØyδ±\9b^Û<%\1ar\93\r¤$¡müì\0oøºXÛ\17v_ϲ>ÊöC\1eð\89?R\ 1\7fJ½w©n=\11\14l\ 6ÎØ\v\9cº\8e"rzèYnnâ\9céºå\17ïdƶ5×é?\10@ß|Iq\93øÆ;\9cZm©K¥8ιÎÅ\8c\f\1daM©â\15\ 6³h~Ò\832\9cõp\1dÆ^ìI¾6úIV:Ù/äò
+à®\90þîÀ}\16\19ð\88\ 5[ê½]á\8aYý\kîn¶Iu^\9cÆ«\16\7föuµëzqá(â¸díV'øæ1\91\bÓAtնϠ\16\97äi'\1eÜda"¦Ï\1a>ÿ>rõ´ä½ìBàx8ÂK²lZÉ\9dÈðÎÎ)Äñ|ô\1eÔ%\15.náB¤\90Aë$\ 4YSú¹\94\91%³.¨¿+á\12§p5\96¨Yì\råhó\ 4J\7f¬lã\98Ç>\ e\8b\9a\8c5ÊJ* L\10\ 2\8a\99\9d\l¯±0a\1aÚµÞ
+\8d¡\ 2µ®PÔ\8fw<\1cS\8da~Ý_c\19Ü\9f!z?\85¾d\1diz¤|UsèDÁÏ\90«-,\84\81\vX\84$[ø\90ÁD\9eùú<òZnQ\14æ£Æ@yZ\84[®PõkÊÓ2\13\1d\82¥Ë\ f ²,\18\9eô £À½¿\91\8bù;ô\15Cú1gô\15ö²\1d\81EJ\ 3½ç3ÖJïUzø¿ûlQzð\80Õìi\8f\99¢\97³gÈPª¦\17P¾¯ZGU\r\9cúY|Ä\ eíü\1e\ 5ÜR-\96ò}î\ 3\8c\1dÑïg7âU°\1f3\v\16ßMüôÐÈ\91«(Å<¤Ãº\83Ñ{\13ÅÜMpp@?Ö\85V»Ur«»)}âWÈôÖ,§Ýax/û\83üH¨P§9`­Ò%<¦
+\12.s¹o\9eö\ 3G\1cdeÓsâæ\10¡sàÄ%@zi]x\ 4 ¸¸Ó\11\1a\82ô\v¥©é\83\98\8e@\1dÜ\ 3òûÓ\94óÍg±I]Ð\89%2g+\ 1:\13¡¦¶\81U\9f¼j\97ÎwÔ?B\91küwV7F9ÈÉÇû;íÓMºöí¾\ 6\9e0\1c       >&Ï¿+Ù_yF\86\7f\9e\93Çþ\16[×Ö§ÅÔYó<3xß±\8eÐ\90G×.ð´Qg\7f\87\8d1\8dC\87áb\99Y"0¢oF·Z+D³Cfu\8d«¦{ò>\86¹1Åyã\fMÖÇ\85\9d\83hÝÂ\ eáþ)n^gÜ~\8e\8aͳóÜ ëEÙ\82\90Çmá¦\1a9\8b\12±U!\ 2-¡Ã\93ñ\86\1d\e  EتÔ\93Bñ%\19£Õ\ 5¹\bò\ 5\fçä²rEPC\9d\80¤YW\ 5\17}E¡\11µ\92   oÌ\8bÙ\v×ö\8fB\86¥-\9fí­\96.í³±<ÒS@Ú\99§\94\87&\80\1e\1d®±7DÞYð\v\vìH_+\84w\1d/Xw\14\8b\v\96òÇ)1)ÚV\19ùP\8cgߣ÷ÝI\99¯\14\9fÞ9o£\89ùÁ6ôi$I&h3¹6\1f¸
\114;û@\99ò\19\96å¢i%A\14\7f\94\87\19\13é\94oí¢ä¹¼\94®\96t©TJuH«¼\10fÑ9ÜFûÔPJ%\9b\8dÛØ\98c\8dx|ë²ír\8f\ 2_&=\ e%/\9b\17©àjË\87\82¾EäίÐ\ 5q¼æ>gYnñùòr\8dOêx\7f>K+\82(prB|\82\87\9fh\ 4¢\êJeï\ 5Ð)#[_\1fa¯H^6Õ´\99±\ eé#ï\9a\94z\ 3J\b\94»ÂÅغÁþÑ_/ÚK\9d\fü\80¡Ê"Eqp.­Ä\8a\9e\91Ê*¥ip«PDM\ 4®Ñõ³\sà7\8eLS¡°Úà¼Ñ\1a\95±-î\r\8fÚË^F~ÉÜÍàÛ\vú\f#\13þ\83d\fb-õR!f_\8d\9eph}S\19ZñT«\9a     ).\83Ø\1dÑñ:\7fý¹û\1c\9e[\87Ùë`|Ï®DXì}ìÿÕW5¿D¢ÓRr8×ákæQ\11K\ 1\1a*\9eÎ\9d\9c\95\1e*\16Êol#­ý\fø3\83ÑõjÙ\93l\87¶Ôk@­p\13ÕÙ\83\10ù=±]\9aR4BâlJÚ§,ê\b\89\fàißÚ\9dþ\16×YJ~_µs·µ÷\12z\12Ç\83^\83\0\99\80æÙ\b\ e\83ië¡Eµ¼Õ0\9a\8eÀÌÚ¸}O%ã\9fÓ\83@\86>mÑòFZî\ 2zPE\85Ê\83\ fö\8cù[\b\16Vh®\93ð¡tÅ£Ú\f½\ f³\19d\8da~r[ìs¸f\1d©\18ÝÓg½1ì\ e¦Qá5g\87¨\ 2\16«² \ f¢xgÌw\e\18\1d}oZµ§\17º\82í)LTÓý¸<
+\1eÏúg\9d*?ÜÑ1\7fg\1f\17õ´ö§G\84oP¾óiU/2Ì·~*Ñ\9füâùC&\rAe3øÅܧJ\82ðÚê\12\89d°ñÌ*l©Ùª{<âL\93)\81½ÛbáxF?w+
+ïÛ{ ËÇz««H>\87¥é\9d\1faI>,°AÉzÒ¢ý\16\15Ú"\1c\95p¿w\90.0é2\98>2cØë\ 4í©óy\92\8aRLàÔéÊþ^1µ»uÓd\94ÇÇÚ\1fxõr\1f\1dÕI\13à\ 5áæ³D.ïdËsp\82Å[ú\1fÇ\96\1d"g\ 3xl\196\87ßÇn^]vª}ÀÏÒ® \9e²ìz;Gæ\89\ 6³Ú2W\84\98\94_¨¸ÑÜpp\ 3M·@        \14£ÖSz`\ 1TlBO?\9dÁ\87¥&ZÛô\907\97¼|Ö)Â9ë\91hâ=\1f\1c¦vm\1e-74mõv%÷\98í\ 3ÛÓ\1fõ
+\10Zâç6¢²>7\9d(.Þ\98)\88gäÛçJG\ 3TÔÀ\92\1aÛ°±wþ\94,m\1ekë^æVyr<\90p\83q\ 3u\9eÓÌFHêú!\ 6éÁa¢â\1d\ 5\1f¶à¦;\95±Ôá\0\85JÈì\7f\15´²ç\88åël-Lç£Î\13I6\81êyq÷6LîDv!?¶Æ\13°Q\16Ê\95÷\9ej\1a(\99\ e\9aU\95\13Ù;²\1e\9aûÓ\7fá\8aÚ\ 1^`\98ÃÞѲ»TË\eoc\vs¼A·ß¼\8cFIäÏÙ\85è¯Ñ\a\17Ý*¬·lÝ8è\16\81Ù ¦¸çÛ>_OE\99j\8bÔ-\9fã\102\85\9a\99A¥¹¬\ 4÷\f\16Óò^P`ñ\ùÔê÷
\ 5\94\Ã7\92R\13Í8j\17Æ#¿³Ôæ:&^UÊ\ e    ¶±ºn\12Âùjºªå-5\8f\97\ e\1ajétµFcþölBO\ e!\0Ⱦ~JayX¥Cg\ 5|ó®Î\98ÏÚo-]Ú}\89\vîú±\8f\90ÊÀ()´Ë{ÿó\92÷\8a\16Õ¾R\87\87\13\14Ænö\15Ò`_Ò2þÞT(Ðsu\17+'~\81Üxþ²éù\ 4ê\8bnï¿÷\8bÚtµ>Úcn¹á÷\8d­ÌZc\98ùº\89\8d÷!íµn\vÏ\11\1c\9b'K¢¬m\99uÌ)Ýz\97\93\9e»¸=\ 5U\9c\83\93uý¾a\1c\\80µÆÍ¢\9d}.\8a'a½¸£tq\9fÕ\ f\aÀ'Ft®J\9d\90ÐÝ\fO\a\8f\1c\9c*V\84\8e´²íê6\våÍ{}\98\98\vµËÞNßxlþöÝì\9d\96§PÙçÀs\9daÄy¦gÑù¹zô\11ka\125\84¥ðö\v-¦¬\97/9D4Ü\KÉô£t\19\9d%wí\9c\86\81Ù]Â¥u\94|z7cP
+à3H¹o_\b\ 5\19¥\9fE\9fXðû­ê\eB¾5«Wn "i|rÜBÿ\aT¶RÙ
+endstream
+endobj
+2911 0 obj <<
+/Type /FontDescriptor
+/FontName /FEVBAK+CMR12
+/Flags 4
+/FontBBox [-34 -251 988 750]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle 0
+/StemV 65
+/XHeight 431
+/CharSet (/F/S/X/a/b/comma/d/e/four/g/h/i/m/n/nine/o/p/period/r/t/two/u/zero)
+/FontFile 2910 0 R
+>> endobj
+2912 0 obj <<
+/Length1 912
+/Length2 2948
+/Length3 0
+/Length 3545      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\92y<Ôk\eÆm\91)K$\95Sç'\ 6Ùf\ 6Ã\18ÂØ\97\bÙ²\8f\99ÁÔ\98a\8c}©ìÙ²\96l\91u,I\1c\92ND²EemP\96B!F¼S½ç\9cÞοïç÷Ïï{ß×s=×ç¾\1f°°éy\19\14\96ä\82Ó%\11)20Y\18\12Ð26\87)\ 10Y(\b\fÖ"ãÐ\14<\89¨\8d¦à\90\0LY\19\ 6 |Ü\09(\0SDÊ#\90r
+ 0 Eò\f ãÝÜ)\80\84Öéo"%\0å\81#ã1h"`\8c¦¸ã<\18\1e\184\ 18OÂàq\94\0Y\0\0æßNx\ 3æ8o\1cÙ\17\87\95\ 5Á`\0\16\8f¡\0.87<\11\ 4ù\16È\80èJ\ 2\94~\94±>\9e\7fµ|qdoF(@\82\11ò4À\88\88%\11    \ 1\0\16ç
+\82\98\90\18\18\1f¡~5×õ!\10\1eßì¿\ré_m´\a\9e\10ð_\ 1ÉÃÓ\87\82#\ 3Æ$,\8eLüUj\8dû\91Í\18\87ÅûxüÚ5          x\f\8aèFÀ\ 1Ð\1f%¼·.Þ\1f\875ÅS0î\80+\9aà\8dû^Ç\11±¿\86`Ìí{\ 4\88\95\96\9e\95¶Ô\8f}~ï\99¢ñD\8aE\80çß®ßÄß\19ö\ f3¦CÆû\ 3vPY(\14Æ\102¾¿þ\1c~¹K\87\88!añDÆ\83\80+\ 2h2\19\1d\0\f\ 6Á\81 \18\80'bqþ\0Î\9f\11\18"K$Q\18G\0ÆLB\0W\12\19ôm\9d\by\0rþ[é\a)\0\10\8b¿\89±/\bú\1fR\ 6 \98¿      ÆH\ 3Áý\83r\0Ä\15ÿS\97aäþ\13Â\ 1ÈO]\18\14\80\10\7fB\86\15é'dxyþ\84\f+òO¨\b@(ßñß3×Ô$ù\aÉÈË\ 32rp( ¬\0\a\94\14\94CþG\87ñ!\93qDÊ÷çÌXÜ_ì\8a\19\87óÇa@c#$\8cJÄÅ\9buQÔP\9d\82þ²}\92Ì\9anõI&5\8f\ 6\1f\1c\b\1fMf&\14w\eyINÜ·Ù.Ïäç\9eÛ7÷»ß\8e\90wlK°Y¯îÇ«^I\19ûs¾Îs\99\81\8dB6k\99Æ\ 1³\9e§6Ã\17y\9aë\86>/Á\99Ï\rLôPÓ.\14>ÎYéZÌ7\95ж\98çx#ÌÔfç[Û\96\15¡¨d£\9b\8c\8e¼/&/lÎ\9báE\8dQ\88\1e÷ãMKa\e\7f\1e\1ez1z\7f\83ÔëUR\8b\ fßvÁþ¼Ô]'\ eǼ|\90À½å}ì9\85BrÕÄô\82¾\9bàÂÓ5v\95\ 1\1d¹D¤Ä\16©û\15P\941£çã\18\vó\83{ÜYYû/½\9e[~\1eq\­ªk]âܲ*F#²Édjç"\vñÆ\8daK\1f}!¦ -ÕBó\ fê^£êe5c\13ã\92×o<\8eà¾k7û&õÔ»\13{\8e`®E\ 4\91¯ðöSúVm»½\ø§¾\12£0ÿü{9%ïï\9e\12Y^/\98
+QF8\98\vèu\94\95'Öï3ð!6%~Ö©24\b¦\8aV<;3¬CJ\94\ eUL»h·j"\9b\9e\91¾ùô\9c\ 1?Ùê¡®¡HTÄ°x\8a\88>~aºx´òó4¢>\8d<@\ 5\11¨¹"iÏ\80^\ 4Ê\eª+h\aô=T\12\11oå×L\¾¨\ 6\99\8ch\7f]x¯ÒÆäýä\1fG%\ 6\e>EF mÚ³3;\f\b\8dx\99\17,ÇðA²CCà\8eôË£\9dÎ\¾S:\8fÑÂÄ\15\a\84 Y«ãpt >¿]Ve }\vöÎ\91¬`±³\e/Âs\9a_Æj y¤¹\82!S··3NíY²Ú\ e\83uoò\84\7f\18\18ä.¯þÄÊy²åP\91R\16_³º\86£\92À±"5ê\b\9a²\f¾3k\81Yò¢\ 6Ñ\1e\19)Ï]åKG\vþ       \96©£\1f\9e72êµ\8a\13õh\90Ï\90BôÎ\8bŵRêîµ]I\9e®þ\12"7B2î\17y±Ê%é§HuÞ\94|ô»7ò\10\vB®×\9dî\12StÓOkóª°ñuê£\8eÍ+LüÂCÊ~^\9b\12_sg\83wC\92S\1a¢\97bÔªMMÝÅNt2]\v
+\91\0Vp\ 2½\143¸ð\86òå\85\9aJ8y¬T,\rJãxk­)\8a\16\8cÜ\11\ fc»|\96UùeÖ\91(\99ÔÛH¥ÍD\13a
+\8d¾*w>»Þ\19\b¸µ\17µQ°HK¼\97ß\8d±0ýúa3·Ú#R]åsí1ª0)\83\17\93v½É\7f¡\18\ 6˾ÏìnP\97}}\ 3f\96µ+\94I/:\12\1ckQ\9e£\11ÏâJ\15{\9fÜ×uZ-Oßsá¡iÜHµñ\14×É\8d\ 4bT\10ïÙ\91
+é>RÌ\993\aD\9e\fa\89\15³°\13\8fÙÙ\8bÕ{<\R8'kÖ*üGt\b\91\92\84Û<7Cê\90Z(%\v6À̧6ùª\86§Lï¸á©Òí{û§ÌÓèåÇ,íÆ\99-\98\99¤¶N7Km\15\8c§úK\e\ es;otÏ\85\eP\ 5óã«"Ù8ê\vÙ\86\92ÛáSHË­f\9c\a\97âÇ1èÔ\197Vv­S\93%u\8fX]mä\1cr;\16ÚK\81ØÆ\eñ\1cûB®&ïEª%\8dôÉçg^T\e\13\97Ég¿lÏ#* ë\13ªßxëV\19\aó¶â\91\8b\ 1\89ØÌ7O\r*\10\11i=\9a¯,1ÃC×S\ el\1d·n\vG\19ÅUÀ\eÌ\98#ZnÕG¯\1fò\ 5ÀÅ\ 6@iÀÆFzѹ\85\exuú×ñ\93\a\ 6fW)¿A\9b¢\9b²Ù[WüOר\82ÂF\ eWÔ2\81S2Å\93ÆËv\14I\1d\83\rF\1dböbF\13N4t\1f|\8f]ý>&Ïv£G1áF.ÂÙ'[\14×           \ e       9\92üuMÃ\9a¥¶§ÑCh\f\18so}}«GuaRïE\14'\8f²\8cs\8cÔÛV\17¼¡Ã\8a\18ð¾·eTY\ 3®\rSsýÊ\7f8@\b\\8f\95ü$çl\1dxþqá\18ï\0\ 3ÿKò\91gÖD¹\17\e\9f¤)\1e\98®³ËX¶ôWsÚ8
+.8e\8a;è¨YaaZ´\88\9cÉ\9d¶½\16Ë{0õÁáãÊg¸s¨ÝS'\ eu§ö¨v`NØk¨²"\86Þs>\9bÈF~Ö\88\88°½þòBÒîËÉh\ e³)He\8e\8dÞ£Q\aâý'\8aº4m«\99ÞçØØ@c¥×µ\eúnTØ~Ëø\86G˼f\88Ô·W\92taÁ«      jBÍ.²/\9dÝ\87:<ÿ¨#Á#\9f\98ÔK8¬\90\1eÛ,§\ 2\18\90MÃ$i)
+¢³C©*?{i\15Rc·«o4TÌk]¶öÐV -ê =n{\18uÂýFNBÁ'\ 5Kî8\8fyÕØ4\89aÁ¨2S·;S2³ú6f(D¡H\93&'}¼\9f\99\ 6\92\8b`Z\87*î}\ 2¡ø>¿¯\e6\1däÏP\1a¼R\9f©\92#Ìí\ 1³t°+\13\83J¥>Ôtñ\f[¨v`¯Õ _\90v8\9e)y%Ô>\96¼¸\14Ä\14Ú¯\ 3Ô¢\8dÕ\17\93\13hz%n\1ak7uz@4÷ÛRVI¹|¥\91­·\14¯\98\fòÀ@¦ãWÝÙº.ÿÁÖÚ\9dÀéza®èé4)8ÒM8\94ýE98´H·i©±"[B³)qqå\909ºÀÁ\zÉ7§ï1j½\87}GnÓr*áv[L¿ø\97à\ 1>/.A\9fû@¢\f4®yÔ3VPCL,¤Ní@?\18á\14ïîé¹&\ 23\12\8e\9aãÕÐÃÌ\9búª¤íLDDá"0H\830f>í]PÑ:rUMÅã­{Jñ³\17M\1aëÄC\8añ\99l\11\94Òªb\1fº\17ê\92Õ\ 5¹n±ù¤æôÈÎ{\9b{ÒùI³'#ÕÄ\9b\0/±ý±a9&\9fÛâK½â_æ«\1cÏ\8a·\1a+·®\eÍÇ@\86\ e»8Ù\88*ÕâJ5\9cFE¬\9b\9e\füa#U\86\1dfº$nëîÖ°«^×á?LrÔa[L¤dÍ\9bqiû\1f\9f_¿ÓâÁïúE«Ù\93J\15oôóºmÖbî\©\f±¯\1dÕOêvn\15~tÂv\8cÓ­Á³µÑYÿ5¨Ó-56{_±NèÁ\12/.ïV?8,2ÓÒHÖ\7f\9bßâö;,¢Ü\95&\10£¿ÏB¥J>      ¹S\ f½\84<öª\1dì8k%¥\11\1fB3]Û:ÒYûHo´è0û\16[n%f\9dÝFY#\ e$§³(ö&È\81\vÝ\99­7(Ð\eòªG\86:f£pP,©ö®UWç\a¤     \]TÛv@Ȥéi\0\93Ô0ø´Ó\ 5\ 5I¬­ âDÕä\9dÞÞmÎ\8a\86\8dÌò\99\97\95\86tï¸ððϬBùæ+\96ª29\aG¥_¸
+s¹Ý±Õ\1cZK.îL¯12\8b]\9eá\1d¬\81Ð먺hY³7^åÉcïvº\10NH\96è\ 1ÎAG|\89QºÙ$ê\82\98\ 4ø)\97AÚâ\1eþlú¥2ÃÇø\88\ea\ 1,AÏ\13¦\v]\ 5%)\7fn(        {_\ eävõÎp\98\1e\98\8bD\ 4\14ª¾\9cC\8fж\95âJ­.\95\0\1dö5Q[\11|ÙÚ¬´      \83è6Z×Û\8f\1fûM¤Tå\ 3³ìÜ\84×hÒ3\ 6UWÌGy>éK\bÁÕè+\1cvýݳ\ eû¼V©!\80Ëx3
+QÍÆ\14\7fªzøÓo\aâ\1aé½\12GÞ)pï\11¹Ånê]Ãí\8fãî^¿nRð\81p¾°\84^õ¶í¡%³)bKýÌtßkP"ÚqÞ*\9bÿ=OKZRó\88îVaõÑ9\88\97dòjZ`{.K\87 Ð)%(\ 6\9eyFW(\96¢õÆù®µßl\17\17Ìg\ 5\ eÒ\ 5c£¢)-û\94S\14ç¤\16\ 2\91Ò\85£ïnÕ¼\1eúÓèþ\ 5\90ùøý¼Ißò3ös§EoÖH\å\87Å}\91\87×6h5ô>Ï¡N\89c\1cÜ\98h½&\ 4\90é£\\19ºK²](Ök5\8a \94\89ù\b\9c;O@\ 1\15\13auÑ/½ï7xH\88\13g{¤¼`Gìî³\83´xê~\1f\fÚbí\80\9d¾z\80=j#B dÆe\ 4ì¹¾Jã"dî\16Ó>¨N¦¯\vÒÿDC\93åÏ\91¿~ýR¹\9f\14i©öÖ'i\ 2­¬\9a\98/\8e©ß«WÆ\1c\e\15ðã(¿K        uæé²k\8f¦ôÞ;ø"áZý\90éKÀ\1e®êó ¬°Ð/óv>§k |1\95)ïÐ\9côµE¹Ä\9eT½V\8a!\86Sz;«\eÚ{\87\e\1eREPÕ¥]Ñ\ fÖUÏ\eÿX\1fv¦ä·\13e_\82¯s\14\9eU\91\9eå¬Oà_\93âÚ\83\r\ 3\9c«ü)\12È\14Ã\0ýßÛ\råô\10<Y\97¯F[\vÀo¼ñ jÿ~\16V\fÊ\8að\9a^üjõ®\8c¿1\9cï\14s\18ù,,Q3f`\r¨\9b\13G,ÒUæ´6\93Ò½z\81~\7f®ùðÅ\92¤Ü\ 1åóÕ'\99U\99\9e\1d)=>ç±¼\83_\ 4>íô\ f?u\98\89q\f|\83|s¬Ç\81e\81ãIYñj~zJÌ\8aÄÒz´ÛXY-}P®Ç­¾ãèà³*\9ecÒVSwÅy}¦\82]\9djȶò\99L\88¥.V«BÙCÇ£:â¡ÝÆr\97_q8Ú\1eù\ fæ\1dÌ9
+endstream
+endobj
+2913 0 obj <<
+/Type /FontDescriptor
+/FontName /VDCGVD+CMR17
+/Flags 4
+/FontBBox [-33 -250 945 749]
+/Ascent 694
+/CapHeight 683
+/Descent -195
+/ItalicAngle 0
+/StemV 53
+/XHeight 430
+/CharSet (/S/T/a/c/e/fi/h/i/n/o/p/r/t)
+/FontFile 2912 0 R
+>> endobj
+2914 0 obj <<
+/Length1 954
+/Length2 3046
+/Length3 0
+/Length 3673      
+/Filter /FlateDecode
+>>
+stream
+xÚ­Ry<Ôû÷\96¸\84쥬\1fÙ\89Y\f\84¬eßwcæ\83\99\98aÌ`ì;-\84p\11\11EöP\11Y\93-B\96PB\v"²dIè7ÕïÞî·ï¿ß×ç\9fÏs\9es\9eó¼Ï9b¦\16²\9a\18\82\e¨KÀ\93dar0\15@ÛÈ\1c Àä LbbÚD\10\12ðgQ$P\ 5\80)+Ã\0\a\0\87\ 20E\15ye\158\8cI\fÐ&øP\88X\ fO\12 ©-õ=           hz\83D,\1a\85\a\8cP$OÐ\9bª\81Fy\ 1\16\ 44\16$Qä\0M//Àü{\85\1f`\ eú\81D\7f\10\ 4\83\ 1\18,\9a\ 4¸\81\1eX<\13ä»\1f\ 3¼;\ 1\fcÈ>\7fSþ Ñ\8fj
+\90¤\9a\94\ 2¨\161\ 4¼\17\ 5À\80îL\10c\ 2µ\17Huò¿0õ»¸.ÙËË\18åý]\9e:£ÿbQÞX/Êÿó\ 4o\1f2  $\ 2F\ 4\fHÄÿ\9ej\ 3þ´f\ 4b°dïßY\ 3\12Ê\v\8bÖÄ{x\81\0ôg\bë§\8b\r\ 41¦X\12Ú\13pGyù\81?â \1eó»       êØ~X\80Ø\9e;«ia#óc\9b?(S\14\16O²¤øü#ú=÷\a\86ýÂÔÙ\10±\81\80\ 3T\ e
+\85Q\13©ßß\7fN¿µÒÁ£  \18,\9ez\ e
+\8a\0\8aHDQ\98¨wAE
+@0\fÀâ1` \0\ 6RýBäð\ 4\12µ\ 4 \8e$\14p'\10\99¾/SQ\ 1\80h~\ fýDH\0¢ý\ fB*\ 2\90ó¿8\18\0\ 1}ÉÔeý\1dQ\80\ 3\10w\ 2\99øO\0\ 6¥ªa\7fA\18\14\80àÿ\ 5©
+\84\7f B\99\8aðà/5\ 4\0ñ£>úW:µ=é\17M-&y\12Á\7f\15PÕI\ 1\84\7f\15\93\7fé+\ 1\90 \90ø\93ÿïõhi\11\ 2\83eáH@\16N\15\82Áàp\0©\0\rý\8fD4\99H\ 4ñ¤\1f\97O]òßØ\1dK=    \10\f\ 4ÑL\13c\ 4´j\fî¯\aq%a:\85\83¥ôÒ\87´<ê\92\8dk[\87\9b\98£ÇS\ ey\15õ\9eó\95~]c»[\96ÍÅ:G?'\14°ÇçwéQ\88Y¿î§HßäÌÑ\839\7f×¹ì \87|¶ëÙF\94÷>§¶£\97Ø\1a\1f\8c|þ¨pÈäùë§%iv·\9eä®v.Ý4\95<k9ÏðJ\98¦ÍÁÿ^Ûõ\18E¤­n¶\97U|l\8d¸¼°9{¦oI\ 2"~*\80=-\95nj :\f\17ÏX/ór\8dð\88̹[È\98\7fíÀq³¾·1oÏëñÚ\87Jø:bÉõ ô­Azuù7s­¤\ 2\96¤\91}¿·×\1c\97FXY+|Z\13\82t\ 4ùx»õ*_k¦ô½¼\8c\fúìC;6Èã\9a\89S:zR\ 5fµ[\ 2\95!        QJZQûcìÒ\v+\a¯1z6¸Ý\13B\12·¢\8e\97ô¾\80Zscß\ 5ÖÄ­\8bH®WÆ|:ñç;\8e\9c3\12¾\ 5\ 6¥m»\96
+X&É¡{¤8v×n\9a£\1a³-:\j;z\ 5çLb0Ej\8b\87\94\9eÚ§q&Å\84\1dÒºà\99\9cÎ\e:´Éä\ 2\8f\9dýb»&ÔµÊú\86°\12\82ÎJº  ¿Ü\13ÃoÓ}D÷yû^$ÂÍ \bóñ+cÁ3\ 6SÅgÅ
+y½\82É­[q\8f\e%VvuFõ·\9b\18ÎϱºáL¢;ó>¨X\88\ 4*B I\89}\11S,\ 6³Èþ\9e\86·©QopAFW\8e]O_\97h*(\88¬*\99\10\8e¨aä,à\18È[â\90kÏÖ¨mR\8f\8cÈë\94\17ë8×ÖS\9eßkÒM\93©\16\10×;õÔ\8eÛK\ 3l²{\88#UËÔdsYVñ\18À\85Yð'\ flÏñq·²\92\/>­\ eó\8cq
+VÏ7£_y\87z\8b\r\1f\88vlöÖí²\12ÑKò÷\84\93ù·&ð\8f\95\9a*lFUÍ7\11låy3:¸!Ø¡(-D\8d[9KÙ-U·¥Ie\8aC¥×Á_Ö*¦¥³ké    ñÊë\1e®q%\91\82\8eÙ\86\e&êbÖ\17¡\15;lÌSåªhÃ\91\ 6\9c\1d\91õ\16)Uq\80\8dRvË×\vÁ\96i\16Nøc¢,lü3¡-î²Ë\9f\8a\81Ó¾¥\ 1§×¶§N\9d¾°\96\9b´:PWLè\1cb\1a\16ióç2`(Cº\0\ 3ýîAwÓÞt=\15¦tHÊKõ¼S\98¿%H'=Ø\90oW»ã&\82\8a¨5Òx6.¯'\16ÐЯ'm\<#Êè\11?Ѭ$\9b^\95º¿·Äé¯0\16\91\v9bQ÷I)Ø6j+\9b;ÿþ«15\8e\86'××Ásà\98\ 3û\96\95ÒR\17£\96Å\8dk"\9av\f\1fçcM0wi\ 2\8eé\\fÌ<bÀ²u\91.£S9\16Cz\93\9c\9c\84Ù<=³²/jüÞ\96)5¨¯gbw
+W\92c8"T¸ZÎ#<,¦KFe~\9e0ccϸ\7f¿\83B\7f5\1fTSÛÛ~Åe@Û<\15\18*õð*\83ÇÈêâÓË\výC¯âè\83K²ç¹:.dN<\12¥O­Ò3[+î\ 1Σ\83=n£$\8e*\85\1c)J\88£Ý¾T\95º\85\14Ù\98í;#\9fK\7f÷ZÓê\91Ȫ\94ýaÁ\9bÛüâæÛÕP¤ *gx._\1f)\8a²%\0\8f×\ eé\1a\1f\93\1cåh\1a\96\87Òq=ð-Âaª)ö\8bFNÒó\913꽺Úz1ü"ý\8eÙS.rçüù\83¾\94\8f6\v\86\87¼\8a«½\14Ù×®ÙâCæ\8akET5\19I\16\8bîôÝÔZ?éæyª¾-ß[±ukV÷Ö|ðW\ ea?\90\81Ý2\8a\ e\ 4\1f)\1f\ 4ÝÕO\18*\9a´\9a#t~¢ïR[ì_ζNÞ\94
+ÔSâ6=à\16"¾¿q\ 5¼¨\9bX3Ò[soS¶\ fqúö\97eC«\97ú\ 6ï\v\8f¦Ú\9bC÷h)D\eér\9c[Á>}u5¯\89£\9f\ 5{\1açÇ\16cÞv9U\e²`û\1cjõá\13˽²\ 4ô×÷\89Æ|BÉ\19\ fºçµ÷\1f·z÷óÔ\ f\89\85%\96Y\e¸\94\ 5j6\83\13\90¨\ fç\8dG\8cEçNÊóüU6«è«+¼ëô$ýÂCóÄü¦A\96²\87Ó\1fÍ\96-\ e\12³\9b     U\7fÄ\16\1d\ e`q\9an\8b\14MzÄØ&3F{qtk
+Ýáð)¸n\9f\9b1o÷}µ³ñ¤"«Q\9fǨ3ö#æø\15 \2}`ór^b½Ã\1dÆ<M)ä\8e{n=b¹N\9fK\929Þ·n\84\19õøH=4\7f2a\97ÍcÌDP-§|¿\95\8eÏ\93_yAÔ¹Úä«ÆSï©Ó3;­E®îûâ\1a\a\90\85\82Ú@\ 6î\ 53L\82·\94pfÔ½ì\ ft{/Â÷ë­uÑ{èlñê'®\92öéÊýz\15л\8a¾7uº%MíFXN*¿¹\82þvÍ\86Ï@P\96Á¹#$ºÇ»|\99²1ÎR6\9c\9dOk\18B^\14\10+Ý¥{\15´AÎâ\9fÇ\94¸³Î\8d
+ü±<6º\95~                \1d\1e      xg\95f\9b%°²\80ô\e2ìËè{]Å«\16H_ÖåÚT㸹ÏÅN;[\13* pD¶>R|«¯\859h¾,§óÔC¥øi¸Àå²\8e¥8¿¥F9\ 1§\1d\16\ 5sæ*\9aoó®ø,      \9e\93¡%-Z\12t¦×\97\93\14\81Ã\83|\rÉÊí4ÆßT¬\ 3\1cýÈ\92\17\8f\10ÛN-f\9br\10T\rs²»\9f"FÍÕº­\15\18\1cå»\17Î¥ØC®\1c8¸p\¡ä8\18ß­`\ 3¿=\88\811'è\15FÝÜv4Ý\80æÊó¥*\8aD\94Ï l\98¬zTº\896·!.iB7\8e\91%\83\1em¥´â\82\9fôk\15ij-Öåæ;Ü\\99\18ïO(`\17~ÆÁv·¸±V¡Ø\86dt\86^\7fyu¼DLÿ3\7f¬\93Á×\ 6~\ 6hIuF\86¹\9f*\e\8fIr!Qé\ 5íñÅ\85JLÑ\87Âu\917ª÷\13Ô¸üzè\94\87\16\1f\9a~»ßs\80\ 4ù\ 6ôÖ£\ f²Ä\82}9¸âRâ\8a\9b\e­2¯D,\1dj7KW\9dâ"\1cÍQJ\90ð^1£Ñh\9e\eÇ\1cnz"ñ9õ\86:.¥)ÎKîò\91x\1cýÚãéâl\17d7ÉP\8cQîìZª¶ª\eÍ\9c*±Ò\99\ 21ïd\19Ì\82GEÌ\91_\f>n¾9ï©j?iáx\15\9e\9f¦þ\8d¤ÐøuX´\ 1i/\1acæÛ\9c\84\f欣©ìõ¬åu\1a\ 4Ðgøx`÷h]âï\19e\8c8X\a¥É\18b®×ßÐ,Ué\8c÷çiø£\rÑÄa\9dve6\13u\vþFF}æ\81\1e¯\fk\ 5F\ 32\8d|ÿUÂý­\®ó¡
+áND#m\1e\16\99Vͳ\ 3\92sænÃ\11\9bnð0W¯LX«Â\9aæÞ\86Ú\9dãCúÓ\8dUç«"æQcëòÂפ\r\96\83+\ 2\aipn^q\93I]]oi\0\ 1³{g¢Ç§\1c\9aB|ÛK|\8aû\8es,\9c¬eº-ubÆ»\ 4\10\17o¸L¶\17ÛÞý\f\1d\ËøÖ\9d\1a\8eXÌ8#\82\ 4\94ݪ\86\9d\9fS\84\1cÈBÒÛ´4\8b´\f»¦ìVO`©KöµÙÞ>/,ª\ 2«óZ
+æÉhÿ*z\81¦\1e\83\85\95õý\96Tù§¸\1cgnUNB­\85ÏÕ\ f\1ewâmO^(\N
+jk)Ý:|P\9d\1e¾¢írìjØ\1d\9e\85¢ÓlWiº.¨ë+d±®\14nPn7_@\17Æ\96ú©¥})¯Ì\8c\94Ü\ 3Q±fÜZ{Òû\7fzÝE}T\87ÆA\87-Ï;|©\14\8a\90þ\<òÖµÔòê\90e-Ã\ 5cF®\86\84\8a\86\87Úm2E\ 2\9bq«õ\1fSÞµÍì\88>R\1aAE^\88ê¯j\bÓé\856lÏ\1fõ¼\8få¿\ 4\9fÍ*`^ÁÚø\aßÆU_"Û¶6\90<:Õ\8d\92Í|±zç\9fÅ·]kU\r©|fÍ#\9bbnýzîlß\16»+
+>Ã䮤Ê\95â äûî«\15TM\91\95®d\9d}>ofó©\v\fáöNÒsÞ
+\97N\ 3yu+7\0Ú þ<\1f}=-#%Uï(·\8añ(MÂÃH\9c\a»«ä6D)?ê\8cúºïYMh\12-}¨\8c\86\1f÷a\93ÑÂ|í:E'%\81Þöö;8»³§\a\14ÜB\90q²kè4¦wgÊ\ 2Û(·Ë\1cË\8aæV9¡\1aXq³PçÄ\bÊá\fÇD²È¥L¾ô\ 4\15\1eaÏþ\8cgõúõé\ 1\16§´Þ[­O~åè\88¾á>P\93ñm\ 2C      wgÇ0\84ôWv¿\10Ug\rFx
+}\90Þ\fIÇ«\9c\1cä\97z\11Â\1fã9ü¡ÌWËÔ~-ë8?\96Ù\82ý\1e\8d¿á^\98g\98}\16ãr\9ff\84®<í}7\89\92å\80\904\9b\8bË\8a\fí¼Æß\1eµd$È
\8e\19×\ 4äÓs¼|s\99©¿\93Ü\14M7ÑC³b|öþ@{\7fuQ\9a\80¨Äípk\81\8eùè\b4ûr\83Q\18\12N©<¦Ù[³\e»ß<à¿C×ë1\14\1añ24qç>6\1c\(¯¯M\13ý¹®nÐ}\8csÿÎXLcêÑÅÑ\8119Pkìú\1dSÐdÞ\9fs,¨÷\14\1e\vccJï³\98Ü\ eZÞϳÅÈ\97£N\18±\9c\14K\1fÿê.ÏóÏÍ[emë"YÓ+ºÛ:\fÂÞPN\8d\87Ý¿W³ÍÈ{Wuå«\95#V«+Ï¢+|Ír?~±[úqá\9d\94é\10Óì\13J]Ò\93j\ f\1cªìÞ¦î_T\9cNl¥Íïà<Vø\7f\82\ e"\17
+endstream
+endobj
+2915 0 obj <<
+/Type /FontDescriptor
+/FontName /XKDASW+CMR7
+/Flags 4
+/FontBBox [-27 -250 1122 750]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle 0
+/StemV 79
+/XHeight 431
+/CharSet (/A/C/L/equal/four/i/n/o/one/six/t/three/two/u/zero)
+/FontFile 2914 0 R
+>> endobj
+2916 0 obj <<
+/Length1 1259
+/Length2 7345
+/Length3 0
+/Length 8108      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\95eX\˶®\91\ 4ww:hp      nÁ%¸\13\bÞ\rt\90\86ÆÝÝÝ%8$¸\a\r\10Ü\ 2Á       îî      ~z­uöfß}þÞgþ\99ï¨QãûjTÕ\9cô¯Ô4Ù$\80\103\90,ÄÎ\89\8d\8b\9dK\b ¥¬©ÄÅ àbçD£§\97\82\82L\9dÀ\10;iS'\90\10\80KP\90\v ál     à\86\8dó    ñp
+qÃ\92\0R\10{w(ØÒÊ   ðZ\8aé¯$~\80\84-\b
+67µ\ 3(\9b:Y\81la5ÌMm\0\9a\10s0ÈÉ\9d\1d ac\ 3Ðøk\86#@\ 3ä\b\82º\80\80ìh\\\0 ØÜ      `\ 6²\ 4Û¡qüåHÁÎ\ 2\ 2àÿ'\ft¶ÿ×\90\v\bê\b3\ 5x\r\ 4\80Y\ 4BìlÜ\ 1@\90\ 5\1a\87
+\ 4¦\ 5\829ùÿaê¿\8bË:Ûب\98ÚþUþï.ý\9fqS[°\8dûÿf@lí\9d\9d@P\802\ 4\b\82Úýwª.è\1fsÊ  ØÙö¿G\15\9cLmÀæ\12v\96\0\9b ;\ fß?a°£,Ø\r\ 4T\ 3;\99[\ 1,Lm\1cA\7fÇAvÀÿ6\ 2kÞß68d¥ä\94eUYþwWÿ\1eT3\ 5Û9i¹Û\83\0\9cÏÙ\7f3×3Ãz\ 4\ 5»\ 1\f8Ù99¹`\89°ç_o\86ÿ%&cg\ e\ 1\82í`Ç\82\97\ f`
+\85\9aº£ÁÎ\a\8cx\ 1\9e\\0°\1d\10ä\ 6\0¹Á\1cs°ÛA\9c`S\0°Æx\ 3, P´¿6\95\8f\17À!ñWè\1fâ\ 3pH>\13?\80\99\ 4\0\1cÒÏ$\bà\90ù7ñsÂÖúL\\0\ e¹gâ\ 6pÈ?Ó\e\0\87Â3ÁÔ\15\9f      ¦®ôL0uåg\82©«<\13L]õß$\0SW{&\98\9eÆ3Áô4\9f\89\aÀ¡õL0uíg\82©ë<\13L]÷\99`êzÏ\ 4S\7fÿo\82µ\9dã\9fãôï\b\ 2ì\ 2z\ eÀ,Y@\9c¡ÿ\ eðÀ\94­Üí­@vÏ90A;°Ýó$\1e\98
+ä?\19¦c\ f»C\10àó\1cX\19G\90Ë\7fV\81\11vrþÍ°­p²\82\82þÃ\v¬YN®\90ç²°¥y\80 ÿ\ 4þï9\96\94\84¸y²ñq\ 3ظa3¹¸¸ßÀ6\8dÓûÿI4w\86BAvN\7f\7f(`·á_l\ 1\86Ý\1f\10È\rd\8e6?\ 31\17\ eú\98Ú\18Ræ#S0Qþ\92É\91"½$h¤#¸>]\98ý`Y\18ï'´i\\vDu\8e\e\8cû\11ü\19'åH±\82\ 3hÁ»JÚ(áÕï©É\11<\87Û\8fIÀô)C\13ùÄüà\83\11Â@n_7¶mvøÎ<õ¦}\13ËÉ\ 2íÕ\8aKÇË*¥=.þ|Ò£\88\17e³3\ f\17>Ö¾£«óèi@Ú­\144ÃÜV¥d\90ÎîJÜðí¡\1c¤\02_4@ü!ã
+ÿq\9e´ûפõ\12fº`d®2âtºè=*'\93\9bÅÚ(\1aW¦5õ¼^\12SËOTº¥\97\89ôó?G\10¥/nRËrlº,-y\ fF­ô¿ÄK¢,<öGÖ\93ÝsP¼JÇi¿¤4s\7f­r\r×\98ê2DØ\16ÁÃãÅé&¢QU\8cÝ!Æ+Ƽ¡5\1eÚ çú\91¦ß¥?¯áó\87µ\e\89\93îù¡\1ehR§¸\87%5Φ\93ð\1fI\82·ªÞ\8fÛR_\85Û#[6Îßµ\8dû¢­D\16Á\99aø#\8aUF©\9c\7f[>\13úî|V×Ú\bA\15\15vÓÂkf±|Ê\v­Ò%a¡á¼9Çwð\eÒ+\99¯\1d yzÑa3A)U;d¯×ߢy=ß0³G5\þa\19÷}õVVàbEÊÌÀÀ×\1a~\95k\8d\1f\18Øb;8ÒÐÁè)]æ*6\99\12ôßH\ 4rëT\e=\9d´+\82Ý?ê\f$G5R;:¬\aU½²û¶©ú|T-¡:\8fóH\8aS\9b\rd\ e5\93^\85[å9\94~~Û\v\r\ȸÇ\7f¼Ä\83sËxk\92é*\ 3ÍkÌo\ 3\9f¤¹\19\1fW¼k½{\fÃï(\8c¤\fóL3>\84\v\87ç¯\18¹x\19hZ÷\13y\ 4¡ap·ë~RÞÎðÆôÏè\81\pÄE¨Ù_0\ 5¶Â9ño¨!§¯\18¡M9 )ÁÁ\9d¢F\eìå²·|ëî\95~HÖ\98XÊK+S\14>s¹Â\1d[\13m:¹=ò\92\18\8f\96\83»ò0þQ\9fl\92\92yիʯÀ\8fd\9e'çò[á×l\ 3\92Ó<·\96¤\8dâÉ:°cÇ\1fk\90?¨©\8bÌ\97éd\9e^nM\88ÕM=\7f\aõnºÙMí\9dôi¬N\91äâ*tòî{t\ eÐjíspt\8f\86ø\ 6&Wÿ\17ü\99ïÞ,\8d<\1d{\90¼5ì \16Ü\92ðßÌoDg~\r\93ws3\1eô"m¡\8bsVaÈoófT÷Z¥\8d\92lZ?EÂ]©|icî6û\1c\1e%ÙÂ\8e\82\81³\9c BídS>åTÂÉò4ѪS\0\99\14*þ2Å;!+¥u\18 ©¸\ 5oMÞ»Þk\8d n¼Ð«\10ÓÍ\889¶Ý­ýV
\1e\ 5VÄ´ª\13´·\ 4\1c\1aÈO3Éæ\971(è¬"\19Öø¨JJ#v½eª\83\13<¢²\18z\9fµ¿aã\97«*½\88Eg[ó'ÅE\ 3NQ¼\9cæû\81T\7fÅ\ 1Y\rIkô\8f¦\8aÀ¡\ e\9c+(\96ÊXû{ª\98Ê\14\9c\13&·úÚl¬Ý^\86Ó\92\97­JèÓ\1eæ\9c-\8d\8fÛÕ¡\9c?­\93¡Æ©ù\89\9e44\83¶û\92º\19mby¿\85\8fy\8b\11³ü\15r&ä¢\93ìæ"\ 5E¡*Ñ:\84r\13ri`\9c>*\ fÐa_\85èÙG\e\ 5\1cùßæ\14.\1a¿Ú¢\a\vïÂè\95 \1e÷ÅÅÙ\es¦Ûq\81TIOi\83ð_\0\1e[Ö?uf\eS4]Ç8\86>%)û\87\83EÏ L\1aZ'·\ 1uV2Ô»5ö×@\81\nê?à\868\f¦Ø\8e\f%\90Î\8a\\8cÿ>ö\10{dĶ¥ùo¾[Ö\8dðå\11\8aMÍJ7óòD\9féuùRìÆ\eÍý½\rKÈò8\95\125\95\ 3\8e\94»h¯QÂþdå\8a\94km\1cÖn\98¡\13<\Fë\9fêBÐ\84ñÃEgÏ|ª¸æÂg:8>»\9dm\17\17\1eÊ"|f\97O\147\1a
+\1fü\ eõÎß¼Ðþ(\9e\90êGíò\84=\93U\f\8ceòC#±\89\12¿Ô/\85ÓóÑ\9bÊ\1c\91Î&P¦ü\ü\87­Ë\98°\94Ô\8e´§WÜ\9d\b"quøÊ\92\88Ê\9bôDDÚ\9e\90oÂEÚVõ\8dÈ|\97C\8cÐ\1f¸\87]\8b\9e/\96w¥4=¨5¿½Øó#\19rõÓw\0-x\9fëè\9dI¿\8a«TkįÒ.\91­\94I     ´ñIo¸ëØ\9b\7fÇÉá²ÞCV­AÄw\87®îÛë\1aH\16¹\9cô£\194\10Ê\98¼T7\fþ\ 1O\12r3>\80\92d\91\1fèæyö1\ 1\8a\8e§à6/\1cJ\9fÄeâçS²{$\1c\8fol\1aÈNf
+N\19\e¾\17\85&XÎÖHzK&*vâ\9bOa¼ªd³u@\1f\f\ 23øÍóG85È/Ixdù\vÓXóç5S)\82\81\a¾òM¯B ßæù\î\92áÚ\14¥n\8ad2á=\99@\r\8c\ f¾¡\7fÚ¥\81Þ\1aÖ¢â\15\8e\94ÏÎ+¬\98\10=½ç\aôpÞ9c\e¥ \ 6\b\11\9aGD¼¦=å\erG\f\12Ú\9a\9f9±ÖÃ?1\11\14w\18Ìb¿\12«o\bnߥ©Æò,Q¯õ\8flõ,Lý\18øÁëå\90d6»êX>UC\87EäX÷\e\8dGr 6=RìmnåR¹H\1c\ 2ÒøOºG³Pïë(\11\10ë     \9e@£(ycmâ bìG¯\91d\7fù3\81Â\18KuíÚi\8cßË_\1d\87ôX
+åúf\182.G\88®¦NÙ«¯\90È
\1d8tñw2b
+nxÅy,2 ¢ðãèý\1a\9d²v4×\1cá_àH\18åãÜ\f\v\ 5\87Zê?\ 6\ ft:\93¦«=hkPNýÖN\ 3\\9díÇ\7f'æ×½Ü*°Y?u-\1dp¡5õö\0é[1ov±®q¯#Æ\ 5£\bµÕô\9b\85\ f\1eM;«ÊU\89d3\v)²BPSóÜBTHö\a~çÊ9ãÏ\7fu\13\1f_t2ï\13 J:Ô£¾\1eYRØ\9cÓgy\ 1ü\ 5\98\1ad÷)\93\9c3:<q!`ÌH\8a_\ 3ÿ²>\fRP»ç¨öJ\96\84¼\ eÛx\84¢ÄD®mãàíÅ\9eÂ_4ÉûÇ\ eÜ3±\15\94ç\ e~\0í\89H.\84\ fשg(\b¥g
+ÂÓáÅÒ\85ÝÐÝôF§\97\1ah³½Ë\12Í Ùñcï´)A~Ï\QF«;ÛµµcÃç\85W²à`FÍ%´XìN\86p\120Ì»®öÕ¥ìí\b
\1eÿ»Á$\9\ 2q×ùm
+ö      *DZi%,¸§Ð°§\ 6HØ"\85ïÙ\ 5Ã4ó\8fwã^\1d\85\81\8b\v?,¸\12÷\1c\1aÙu]H-#¨,Xé\1d\89¢¿Xÿ!e}\ 1\19ôu}\97ü\rñ\9c\f\9eYB\ 5\ 3Z«_À\8c3]Q{ ÿÚ\80\98rxÓj\1e\87+\ 2_´s\9fû\91²´÷\1dµ`\8d-\87ÖSÐ>\9a ö\9cÝ{Å©¨\9fÍýW2X  `ý5÷ÎÐ\98Á÷Ç\98¢A#ªÇ{Ó~´;\9dK bßÔf\1dÎñ;í\9fx\b\95\ 3èô2Iµíu\97ÈMÑ<óa©1·-,\1e»éÍ\1dÍ2.\ 5|5^D+Ì\95<\87\ 2\96\17d3\ e7ü'\a´xd\96\eË\13\ 2y\1eäþ\14\ 5\9f\95\93ºYb\16F+\90g3.©pÞÍbÁCi'¸ù\0ã\8c\ 4Ì\95X¿\e
+:% ¨\89÷Á¿*ãò\ 2jËu\84Â652=­\97ltß\8d)\16\1cm\1a\86b\15­Ï\13g\8fåXo$\8d Fîl®ÊÉ\12\14ae\ 5z\1dj8±è¼¬{?ÑÚ^|ÊYêÎ\a`\83ÜóS%II\r\a/F¤z¶ÜÙ,q¥\11.\97\13\82ßú}Y\17L»u\14ÅÿüÃ\93\83'J\0°þ\83,ùö\8d/|\95¥~öíuÁS4«Os!\91¨êh\1eã+v×#«³Æ\17\13÷\13Í\82|uçaú\8aP§*dßjU\9fø\½ôäÔ\ f¨
+òfabkkÔÔÈ\1e\12ÖúI;µ\82\9cü?\aA\9b»±\85\ fM;ÊÁµq\b$?\98\9a?\89¦É\87\83¬ÞÍq)NzdÆ)ÉT\82÷§b\aûî\99\17Búç¤ð\ 3\18æ\90\1a8\9eZ£Ø»ÛÃo\ f4\ 4\96i\14¥\9eD\92.oG{V3öú&üi«\\V\92f    Øµ'\85±\ 38\86¹\97кÞÚöÙ䬡\83ËÅÑ\15ÐÚ\ 1ý¿î¶!\b       ñ
+ú¯'Wè  á%oö}.omûW\18\87¶b Îü\12\88\1eOõ¡\8dK\8fêá\9e\81è¯ø]û\11Äò¤æ
+L\10\99\97\88®\807/\b¢èúÔæ½       \9cÚ¼9\87Ø"=uÎûÄú ´\9e²q½èFÃð\ 4Ì\96pà \86eY¡³;îþ\95\92ñ§wå\ 4\1e¨UC%\1f;\f\11ÎÑ\14&RÐ\ 6}s[qPª®ömÞ\bÔ°@qO§[s+ÛÍ»\7fS²·½\vhCäõy³­\9a\eJ\9acä*þ\90t;9\9f¿.äy\82µ¡1æ\8c\8c\88j?ÍP\ 51yTÑì\7f©\82\87÷çî\97¨®\ 6ºâ:WP     ¸n=E,\86pÙ±B\1c\94LÒ²\9cÙR²}MÊÄ\9f\11\8fñö (\9e¾\9b\0\13\b'\80\e\ 4z,3\15\aáñëUÀ­?Ê\91ÓÍ\9c$ºfdVÎY~a        áUx¥N7ªÐ{¸ÒO]¸.ȼ\13\9fböFÐNC{/\81®;ñ¸o\12\ fñöð[×ç³{a\86;ÄLßâmàh\83ÄÕ9\91\a\96¤\7fyfàl¾¬\99\Q8k\9a\8aQe\91\8e\e6cÔÞHÿäúá\99á\9bG¾¡ å\ 6\8dKr'\89&\r
+g}\85Ò¦
+\92òØ\19<\97\12û\1cý\1f\9e\8am¿ÜÒäÕ]%0ü3\12\ 5\ 2Ø®É;\96\92 Ògp\8e\ f\99Nx\8c\ 5\9a®p\18wòK\92\9dL1\8b\bº\16\ eëÜ»Uç½{\94\82ª®Ô\9dBÀP\ euöm\ 6ëík\15A)%\9b\87û%ÖÈ\9a\99\ 6~ß;ÓTà\8dP\15Ï\13\9b@G~ss0E`ë\99¦MC\1f°\emÂsÓXðÍ{\ eæï´¤rä\85¼Ú¿ÛWWx\91\94\83û¹x½¨
+o¦Q\15 ÙÌ\1fdN2äZh\96ËR\90\ e=¢-\90\ 5\aèq­\81«\ eé5ß\ f-i\9a\13¿\14¾±:ê,û\15\168¸&ÄW´-s\8b·ï:Å\16m\15û\ 5{\82s¿iVÊè"½¨1876ðãöï©/\9bQMf<\8dsaA>pl\98Hßhj\18û\]7\16õ*\19Ë~Ç ££\8f\97ß\85\91¡ªz°Á)+¤·*;µ*6\11Üf(JÒ\8ae\85\9dö\18õ#\90Àþ7Áóç\97r\82>Pí2\8bK\rºø»^d,z©÷\9aÒ\14/\1c¾\8d\ 3K¬^·\ 2?ÂþÁÓØ\85\1a\155»/;z~  )\1dè|\12\19á>稫X#D\18Ï\1c¥6P~ }EAHa­\8cúC(¦\173%Â\1d\94ÿöäâýÐiÎG¤Pÿ²îÄÂÖ&ÁÅøÜ!ItSÅGd\83.áo¬Ëâeö_&ß\16}\9d£I]\90«\b÷\1eüê\82\1f+Àêê\90,kL$,Ft×\9c \13\r¢tXÿ\93\8f¦ë\95\94adݶ\85\nDz\8e\95ÖKåÀ&\93¸Ê\ 3è·|\85Þ\81)¨IP®yÔ¹Ý#dç\16"+c\86\1cp\14r\98gXB^\90¢\8cÔ5\99ø#bM\ 6¯\9bpÝÜ\98\e\8bÎ\94³+=Ô\ 2ë\ráP¢}©æ\1a|Å5]Nd\9d¡\8a\87\ 1.3ßR·\eϸòS¹[%:áñ\98À¹WZôÆ\er\83t\96óÆ´\ 5.¶i[Ë&Ñê¼Xô\9f¿ªI\ 4\14ñÎ\82m+óH®x¨\ao9ç1/F_Rèn÷ð|R¬Ðô\rÀÐMÀ<\È\ fy8F<uÕ\95£Õ\90ü\fâ
+T      ¼\aÌ\10dOÖ=|à0     Å¿»WôwWUÐ\92G\råzÄó?±^dçf{ÀM\9eMYìb\ f¬W ×\95Ï¿¹Øå.¸4¹ÿv\b\7fÊåkg\187tBïÀÖê5»\8cÿ¹tU\ eðí\1cþuÂ\8b'½pÿ°\95þzÊ£m\86\97~\8cb¦=\r\1eØ!ô\13\98\1c\sp)\1a6Sê\8fT¯H*'¶ò]á\11&\ 5\12sp\e,·Q¾\81¼\90w¿\17p{P\a\8dÑ0ëE\88/´¥\ 4Vt»2·\16\19¶e®ß<þút¼,ú3>\ 5`z>\9d\981Vû\95v\ fü#\ 4±¼ØÝ\9c+ÐÝú*\9a\82]T\15\19õp\1dÏ\16ç2g\7f>A\93âúlKÌq\8a\93¦\ý\83>øgÐ*\90ÒÂrºSÔÍ_\13E@U\9d\eíÒ\86<°VuÕ»~µÏW;\83{\83ÍeAJ\rE\91ú½¹½^\ 1V¡<}®|y\9b\18T\97FCO-Ö·ö\ 3]}\93n`á¥\87\8bO\b)kQ´í#Â\1aÁ¹×¦Yc2i¼¡\98\1f'¾×\15v\84\15\ 6ÿ×uûD$>ú#Ùëïõ\15Ñæ\9e7\98å\943\b\16®\97\8fµ9\8cý\8c\ fê÷RûÉ\835Ô£r\13ª\8fú©<\9a¹yëßûü\aðð\9d\9b\13*ÏÔ6Y\9f² Z\16R/¹úæÇë\83\ e\ fý®8\16wê|Úo\10üÔ"1Á\1a´$)kó\83$\93gfU&y!5u\1fn>K:§\9bl`Óë\9eé×W)ÆKéQoµ¾°úƽùþ5<©¡Ú\88M)\8dø¹ó\ f[\9a¬CG©D\13·!³\96\ 3´V\ 6¬ÜR\1e¸Öz\r\8eÞ
\r\9eÝ+2\88´\91\95ú÷ëq6|Oà±×\87}+½Ì\92·-
+\94\92s\1f^Ç¿1\a2´äý>9\1eXuÿ9i\8e\8d\13¶­øUÑb$"\1dý\1d\8fÈ`p\ 20(Ãh× ííNÑÇÓtd\9b\86\9bàÝQ>Ô[bÍ\rõcõ\aòôo\7fÐ*(ÕØ*GÄê¹h3\ 1\97\91Y\røk/¶ünî;oæ4\ 1_lS¶o¾\1a'\8aP«t    ¦¼\13\84þ\16
+D\85ß\9cõ¥\19\16e\9cr\9càLü\14ú£Î½\81âìý\ 2óT%\e\8d'\8eí\92y\8d\9fÅ7\91\9bÓ\11\ e\83ûÏiZ\18\1c\14
+q¯[\aK¹\\9e\1aÅ)ûv\96\ 1«|Fô»O¨Sªª\ 3!OæömM½ä\98E|@ux½7 ®U\14³\ 2\92ØÁ!ú\ eá7÷Ùö\9d\ 6\a\11\10\17:új,B7\19zºùG&³£ôÙf\ 4æn\98\a4ÃÕ\91\ fS=ÆíÔ)\94è\14\ 2\epo¦½\8e³f95\95°ñói\81ÒLÄø\ 1\1a\1d¬Ä:Ìé]\96|TÑ\ 4\0tÉ×\ 3tJ9ê      TjØ\7f\9aJÌ:\14ó\96PHÊ|\16ì\7f\9eqO\18ì\8fÞÍa{ãá²¢\9a\91ܾ`Î"Äë¬Q9Z6!Ys\1e\94È\9cS8\16²¡\86wþª¤¤Û\12®#]üØÎ\94\ 4\7fNY\ e\8f¬Pi\93x\rÊ´uQ¢N\1e\ 2¦\9c\8a\82~í=\84\ f\0í\18D-\ 3\8aº/9\82¤Î\85\94v\10\19­.±\90\b\8f\96?´à\\84üðòê¯\1a\81mp»ÊöÄ´k¸Eæ\956\râϯ \9eY\0\99{Èý\12Ã\8fÖ\10ê¬$\1a\84kÝÏj\94\966\1aÛ'µ\18RµÖì®t/3ýõ_e\88%\1epNRÞ\13k\ eÐÈcÏ]\9bSuøYÄËP@öRH¼6ò$ÕÒ\ 3*T×\1d\8d\8d¸n\94\12\ 6¹s\86µ8ÖãÁîDg\10>nÛ\ 5³°{\[ÁEmdg\1a\97þ<\13lrÿÕ0¨\13nÿ!.~\12ä\8f\89»Ð)ÒøñN®þØ\96þö\ fÂvM\9a\8f:/\88V\10¬\89\97\1fɯü(ÊÏ/4\10µ\89*ó¬\9d\8du\99»ähÌI§·¹Ö\r\91_9ü(\ 3­3)ø\8d\15\8f\r~D&Y`@{\1d\17zoî2\ 4E_q\9bL\87,\9e@®ó&ñz@¢ZÜ\93z\99FE\r=¾:\95\8b\8e@h6\1e²L$u\92\0-ëÀYþÏ|·\9d¢C%º2\ 2ý^[¢\1cï¢OOM\87\18¢;¦­+:uA 4-\19\vKj\1câwûï\9f\95ߢX_à8ÆËt)Ç\f{Q1Ë(~\91D\rÑ¡EÀ*¶X÷ÛS_+Í\88Ò'NF¹(HÈùä\9d\97HÎ,\®Éù
+ý[·\8cÖÃÎø\ 5\a°\96ÈÆÀ\8aî=ÛÇ\ 1\14£D²Ê\97\93+xD#&^j\0#7(\83\95Vs\99Û¯Gï »'B0\(iб\ 3ú6\84¾ \83É\7f\92.ñ=Â\81·)b´\8dmü7InZT¿WtÌÑsÙ©¢Bd \ 4Ô×\ eyüc×^\1c\8b»ó¬Î\8d±\13ȲZlQ\8e1,-   ßùl¨îfý³\83\13U]\8e\94À\f¿Îí\14\1a[F\1dèêY\ 6µ\ eÏ\90\86¾«\99|¯Î\1fÍÂ#\86|ç}pa¡\99\95\97gµð\95Þ­cbø\93\9d$eþ\89\ 3Ãÿíä\\96(\1fø\12®öBè     ÞA\87Oºøe×[B\92\12ÁÒ0|\83\f\17w5ñ\8f\8fc\1e\91â»HÎ\82\13Þùã¦Î%\1c\91wÙU~ïP¦\9eèR:Þ6«zH\90\8b¸\87\90\12Xî¸\86f\80qZVÚÅH=\81Ú\rså¶A\ 1\9aôh³½2ã\1eeÎÁDuáª>*2T\88×\1fEj\ fãáӪ͠a¬qsݤw\9b
+<´\9c_cïýhG³¬¿ÄU\86~Ça\8d\0}½{\1a÷§\8cÇu&\8eå)G\ f­{ó03FpèÁ\19,x]\80\9aø«.\9b\ 6|'¥Î¤O¿êë\9d!ñ»Ï×=ª |\93¨ç±rÈÚé'\93Ú\9c`zxN§é]âT\ 3ïÇ\ 4ã¡lÉ\81¼²\83äÓ
+\ 2 &Þ\1aÇC\18æ½£ÝÒVÕ\8bý\9c\97\9fÌnß      U\f´lgLõf]2'\1f²8g$+\84Å}UßNE\8aØéÓ7)y¬\89.ôV~÷ r;´o)ýb\99LNçõÊ\12fXï\ 18\93LÊ6\ 4!Èô\9f\ 2?\13ÒV\19¯\9f\0nðJɱü\84·d\91Õ\84\ 4ÇõqNa¨çîZÒ\c\ 1\ 6\88ò\95è\1cô\ e\14Ä\99K\92\ f\962²Þ\a¿bM\7fó 4nw\1c^³YN\\84AÐÍOXä\ 1l\18\ 5\97\91Æù9ãz{(¹\92¾/.¢\8bÏÜ\97\eSSc\1eÒGé\8b\8e ü5*µM±ºÛE\92Lâh$ÔY\81\ 5µo\98\87Ï\ 4¬Cúß\12§Æl\1dgÀÇ[Þ\8aIEËuÚWíâQ^\84\v\f\87²-<\88\1csê(¶ç`J]
+áP\9a\ 4#ð¯\ 6î
+}N\15å#5¬])îy\99Z·Pð³À2ÎÎ\10\0\88þDóK©¶\8b­oCmðà\9e/ÉS\9f5t­è\91ª¼¬æ\ 3¢¿ñ        äÔ}|b÷\8eY(Á,¦\89GmÄ»®3Î\97QÞÈÊÃ\89Þç\11Í`8"Eû\8c\905PFª:q\8aKë!¸mµëu¨µ³\ eýÃ÷(\ fæ0\8a\1c\13úû§··%\82\14c\11\e\13´\15{\91Ť·i\13²d\8bóÊD        1\ 5õ\8bõ\9e\99å 3\ 3\82ê\8c\8a.箦}ÿVÂÚøÞs\14ty#|\10®¸\1f_\r\8b@g\1e\89È´6\89\92È»Ó\b#l\ 6Í'©\1cA\86\90S\ e\vM\1a÷­ Ü¬¨\87'E^þzc>\8d}\17^\82\ 6$/õ+\19­ð.\8dê\99-\9fS\ráZZìÆm°\85´úÕG\7f     3ͦº]v\eçãx\\96¢\9bûmZW\14%\8d\85FÜa¦O\18qº#­¯}ºë5òÊ\81ù®æ\a~û9ÓSqç\1aR\84\113¼È­oÙOÓ\9e:|\88w\85\ 2{\9c\96Ç6(º\9bóxø\90\83OÔÃ3´kÙ^q´²$CÛ«§¥\9eÐrîF\86hªý«8Á.\8d#~\ e\ 4Þ½X\1a\98ëÄ\97\9aH&\f\17\vÊ(I¹~Ù\96;;\8e3\83|+ß\8e\17\b._Î\8a\8bx\ 1\98 t÷ý¼)\10ä5l\94oXuÑ{\8fïÆÇÖ\98bjä\ 4\8aÀÆä\88[¿àã\ e/ÞAàôZ\9a\9d\\f\9d\8aÛ\96\ 5èÕzùæn6\9aå\10\1esÐ:ðª0ó]m¾Å·g\18\ 2\90-5ë»Ù};è\89L\9fª\88°ÐP) \ eoåæØ0-\13b\ 3£o        ô¨Tðê:"¬Þæ¢Õ91M;\9b\8b\89\v4 VÕ\1fV+M!\80\8c\865¦ÉY\8f¸k\ f¬°ºë¹?Ì\1fÅTGÕuÿ\14Ìáfjv\14\83J\94\8a\996µ|X\9d\91\9eLG¡\a\ 2\8aA\90`\r\15Z\80^¤[lήõWmï\ 6µ\93cu\9b¢~\83«Ý
+w\81ÏñK\8cÜ%s3y\87®·\19i2\8b\10e\16Ö*\96?\1d*\ 3NÙáV®ÅÉbþ¬Q4)\93ë\1f\1d\7f\9f0è~\17û­\17N\17âbî½\1eþ¨_Ç\1eeÅ8ªýA¶\1aõ\vy\94P³ÿ>C.\8fáJ.ý\8eA\14p`\17\90õg\8ceìñë\b'¯NN\8cñ{\9f\97ö\18\ eîµyyÉNáBUò^~\10Ìe\1a\8fF\16\19\17\92\97àª\eéèWQ%ßHYß\93K        oN#·^o\8d|\141¦X\r.\14Ý\16þ#´XN\87\98ê\14\ ePm$\94\19lï<b6¦ò!Úw.\r\18i[7uO<+W5Î\ 4\ e[\17¿\19ùs*$3\80]#Z\82èÎ_ãPÚ\179\18P\12Ø\12 WÂ~:óR\96ÓÙÜñááq}Vr\83\a8\9d\92fÕ½a\96\92F\90Ôg\11Å\14öò~el\8f¶ôE8ï\9fÒqæ\15ek½³«L>mÿÛ\94Íc\97°æ\86C
+\Ù²¹\89D%\923\82+wÜþ\fòÕ*n\92\8d\80Ó        È\9b4\14\e¦lÜP²\80_\10\8aíÒÛ;åÆ\90R_æ\98yZ\81\83+\8aù\9e\1e0\84¥·Pð2\9f\19\8a¦¤\b7ÅÖ\96\9cøØ7÷I<Õ=äFj5׺\13\840ìk\1c\88¤(\9c)\10á\11h\ 5\8di»ýâl­¿CÊ\9båÿ»é\93\ 2   Îk9b\8c®c,éði>øª\8a{jÞ{\15
+Óú\9aæ\129³ø\ 18^ýÂî¬Wï£\18\e¥\ 5!ìÙGþ`»³â$ÊO\15Gyz|kÑàö \14\ 1Zúu¾Ù S´bâ×\86\9e \ fäÆ\11çÞì]\1fQÑæ\9c#M6Cü\11\18Yk\80¢\8eÛå-\91a\94\17B²²3\86ÑS\12KÀÎWµ\86ÃÐwõ}ª²<×9ÆÊÖ\16"^æô6\12¬\85\9aé\Òâ\14Îf¯Hx\ 2Híw     È=:Bá\89\87\\86CÔpUô\1a3\11Ö¦ÓwÚ
+$\aÊ\80¯\e\ f\83\91èÈ\8c·»Å\1fdpD8eÜW¨\89\\92ð\85\f£ë+Ó\r\1f\ 2o\8a¬û¹L¾\\88WÊD/\8dæEr'±Læ
+\7fõò¶Õ¬õ\16X\97HHöLëæ+\97»\8a"®üÀÔo\96%2â\ 1ïGWx\ 5×\10<W]\9dªðH|F´\93dëV©\14ø´\13\93WµÇÃ\92S2\b\r1=DáÔ$\13\92UQ>\10LMgù\1f?íÎÀ
+endstream
+endobj
+2917 0 obj <<
+/Type /FontDescriptor
+/FontName /FCGMFO+CMSL10
+/Flags 4
+/FontBBox [-62 -250 1123 750]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle -9
+/StemV 79
+/XHeight 431
+/CharSet (/A/B/C/D/E/F/G/H/I/K/L/M/N/O/P/R/S/T/U/V/W/X/Y/eight/five/four/hyphen/nine/one/period/seven/six/three/two/zero)
+/FontFile 2916 0 R
+>> endobj
+2918 0 obj <<
+/Length1 1212
+/Length2 3333
+/Length3 0
+/Length 4087      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\93y<Ôû÷dz\8d\8c¥.Æ\1a}\90\10Æ\8c}¹)K\94u\8c\9404f>\18Æ\f3c_Rd\r\91¬)\84¤$\8a(kd)Úì\ 6\92-[$ÛoZn÷v¿ÿþ\1eóϼ\9f¯sÎûõ>ç|¤%PÖ\8azx²3hD&Ñ\14\91p¤6``n}\ 6\89\0\90p\ 4TZÚ\80\ 2bi\ 4\10K\ 3µ\ 1¤\96\16\12Ðóq\ 5\90j\0BC[\19¡­¦\ 1\95\ 6\fÈ^\ 1\14\82«\e\r\905\90û\16¤\ 1èy\82\14\ 2\ eK\ 2̱47Ð\93Q\ 3\87%\ 2Öd\1c\ 1¤\ 5À\ 1="\11@\7fË \ 2h\90
+R|A<\1c\8aD\ 2x\ 2\8e\ 68\83®\ 4\12\9b£\13$\172 ñ\ 3ã}¼þ\96|A
+\95a
+\90e\98\94\ 3\18\16ñd\121\0À\83.P%\v2ã.\90áäÿÃÔ\7f\8b\eù\10\89\16XÏoå¿wé\7ft¬'\81\18ð3\82ìéåC\ 3)\809\19\ fRHÿ\r=\rþ0g\ eâ        >\9eÿUOаD\ 2N\8fäJ\ 4\ 1E¤*\1c¡¢öC P\8d\bþ \1eE áÜ\0\17,\91
+~ç     ÿ_+\8cö}7¢diebtÌPþç\¿\8b(,\81D;\19à\ 5\ 2\88\7f¢¿\9f\91ÿ\9c\19\10ü\ 1{\ 4\1c\81@2\ 2\19¿¿ÿaþsÙ1\12\8e\8c'\90\\ 1e5u\0K¡`\ 3 \8c\rb\9cÔ\80 $@ áA\7f\0ôg8V\82\93È4F
+ÀhM\bàB¦@¿\8d\95ñ8%F\16Ù\ fOö#}\93~På\9f\94\bºÐþ¡\1a?)\89LaL\11\97¤òSú1÷¿±ªúOL%ûÐÜüÀ\7fg0\14*cF\ 4ª\ac\1dÜ~q$\82\91ã\8c¥ü\v0Ì8S°8ð73H\84ÊOüû\95H\ 4\ 2\81\ 4"áÛ\ 4\7fK@þ\12~OÑbp\ 2\ 5G\ 4=        $\1fê/¬ù7ö"þ\8bj1°\v\91L¦üV\Kë'ý½²2ãJ×oß1H\ 1½}\18\eÿK`\98$\82Têï\94\ 1\7f·Àx¹§\ f\91FðbLû×;\0%/Æ\9bÉx\1cHúV\17ÿKa4î\9bÕ\7fJüïZêë\93ý\83\14\95µ\0E-uÆ\9a \91ê\80\86\86ZÈo\818\1f
+\85Qúû\97ÏXî¿Ï.\ 4Æ\a\ 1\82þ \ e:ÐKÆéD¸§UFÞ\ e=vóu1\9b\12Çz[ÉÇ\ 1ö\ 6ÛªÐ,\ 2>ÄZíº\95\84+-\7f:÷CEB\93 Ç\e!\13\9cÎU>ÊCáx\8bK\8e+y|w+bs
+m/\87©ÕÃû­\ 5\ 3ÂcS¹·åe¦O4y\9fJ¿vñ\83¨v=e,3FJa`Eê\\e×uü\94¾Ýͺµ\91^NÞCèäC\92"\1a\ 3EìÃL\ 2\82\ 1Ã\93\97ªÎ¥µ\1eÆÍw\ e\9a\9d@ R\8dbeÞ¸èr:¯`Wÿ\82b\|ß¼\91·\9aÐkì\9eúà'\84ßÜky©ÞÞ\7fV,Z2Jz±ÙºÐÿsl¨hPßs/vÁ·Ñ3ñ¹\9f\83-9 õbúÏ\86_7E´~PJ\f\133Û×6¦â¶!Ò&o\91Êï\8a\18Qa.\9f¨\12~áþ\97MY)2jg\8a]¤ ôK!ÖãÚ£\141ÃÙ@ï[O\ e¯Ù\bÆ\87ÀM+ÓÏ|Ê\7fÒÄÙû\ 4\86ä;Ò=`\90¸~\83â\ 3\12«lîS±\9a\960£$8>§ÚÑûÚ8\7f,Ìs\17\97pv°\15æ\11\12\r\89o\1c\1f\89{æ¥Árò¢Õ\91«êÑâ3\eÍ\81Ê/Û«åÕä$­²k\1f%ùv\82õYkt±l;\1e\7f\8dÊ\14Ý\97G%²\9dî\1e\Ìb²×\15\94è[\1acO½¨ C¾ÌzWjO1«d~Õ©ÚµpøÜ3þsu¯\15\98%\1cΰíiðHDQg{\82Tâ8\1a1\1c\15`³{)@\99ðcê\17\ f¾º\eF¹C£\19V9\93ó3!:ÅA¡ï\ 3æÄï0\rÜ\b\ f»\95Á\97²>Ã\f\1c     >ê(ÁϾØô¼`øà¶WdzÆǨ +ÀQ¹\9a]}só)\ 2\ 6I\94ÅêÀÁÇ~®Â\17\9a¤\8dvíÕÀI&\8bS2Ë\19\81|\11Ø^EöÈ/\88#a\ 5ó\19O\94û×Ï|nAB<\96JiÅ&.;1\v\9bÃèwe]ÂK\v©ØÖÒW\9c\13ê¤ñQÌgsXJ\14\92Oüå\8dv\8f\1aA\89\ 6T\1d\P#5z¦<{ÙÒ!Jß´ù\88\ 3¼2}\10`b×@¬Ô     ÀÂ\15\ 5\87:\93ãÅìäN~M4*Â÷/ôVT@¤lö~Ýy´\82á¸lø\{qf\ fKSD\84R\9d¶B\8e ³\83\96\98\ 4*Í&(   \9e÷"Z\90âJˬw4\\7f\vá|\90·qöô\13t<¢®«Dï¾I\1d¤¼ný\15Ь°§Àülû\82Ìl\19¢+\88\85\ 6éx¹×Öî(ÿÅÖû\17E\ eWÑÛxO6§é\1fñ}÷\bZ|8\aS?Sæ\1f@   Oéï\19Vþ`Fëñ\14·    *(iÇé½v×T\118ªËf4\90\94 ¯þÐÀÄ\9c}\84VOzÔ¡§Ýn\7fµ)\17Õ¨1\99\10>åàô\ 2Õ\98ì¨ù¢WLAeb^ÁEêÅ\ 1sO
+\1fRF\b³8|ITi¹ëÎé\8dà¼7
+"`¨ÇeS"\9b\9cns\87ûÙ\85µà6\\1c\92ãñ¦¹J#,q9»Ë\12F[\8eäÖÎe]àü:ò\19z\80\8av\8b\82è|P\82³\9cböçMßlYz¼\9ag\1fr,îÚXî8\7f¹ú©i5]kAJöÐ\ 4M;pϪ®¥\84T\eD\ 4\17óôy'Z'¯³yì­7 ¨}\88¦Y;q\9bX\1e
+Û½?ÍñeO\18u¦OL\9cÑdÉõ\\95\96\9a\0\85%ßP\95\84¨\83\99Ùe{ZÓetvo-§v\eµ6\ eZªì/¨¾=\ 27\vU8¥%\16<f\fËúHÑ\1f­\8eάÖ\9a+Õý\94h\9a\0
+\86\94\9bÄ\aÞ\ 4n^ÚS\95b±çEt¾ý Ì.L÷Ê\1c L_h\9bª´º\r/\8c­Uêõ\9bâ?@\87<\19¹?O¶¹¼»\83¦Õ\80\ eê(qÊkméJ¼Ýß\1cÅÉ\9eA;î}¾h{Wâ®!Ø\9aë\\ fëj\12\97ÒÃ\8a²;¯\92\9eÎóxM\9eBô_d\1eæãkãº[\14\ 1ï\ eËÏ\e\9b\8b\e\9bÜo\92Ç»Ú6tÃàø¡¬·\94{+<9\89\986+áƬ\84Í\vüÆÒìL«ÙqÎN˱ëö×\10L6\ 6úÇGÙdNÓçð«è\98\8f=/\92«s%
+-¼
+Ëd>×M\9d\99\94\97ÖZ­\1cDû½O]öÝüX,õ\15uoõÞþñ&4\867l³Q2Åûò­ö­Æ\97z¬f\13\82\86»wÛõª,n,\98wÝÄ_Z\81Ã\e|ª{Þ5\16\10ûVLt\9aÏdæ\1f>ärMA\99\7fèPÑvhq¸\ 3Kx\9as¾ÝüðÌyKe=î\93ÇEk\8fYVº\9b\86t\ fûÕ»ù\89\14/Pùrk·Ñ\87\83\1eÏy\12\82\¹?«GNkÖ½v´Í\90VJÄdÞ}UXÞ>ÍÔ\91Ê|\82§ÀuÇ°ýãöe§ÎÃÛÍ\9b½\85GË-\rçoa[\93ó¹\8b\ e\ 6Cl+\98¬ÅÓ\ 2g4cÒ\eÀÃ\8f\87\9bªùÌ|üvÛ)N\95yÞ2X³&rÙ\99ma®Ìç¨\1c\8a\84Þ;\99ÚÙzþkHä¡4ïg\r\ 2Ý·ÚÕY[\8f\9a\7fs\15Ö\94\12\9bµ\ 3ùc]·\92Û\ 4¼Òdµ\93\12\v:>­àß[Ø\96Xàÿ0CJkhÇ[6X¨Ô\7f¹Èm\90~ë¹ÎS\8b\9cÀ{w\9b<1ܸV¬û^5½¯k:\11tßøurÕ Pbjuîèó,\99\98MSÛ§&W-­Û*lç+\r}ÇT¯=\10²\8aL\v+}|ðÂ\83ÝÌE\9c$«ÄÞ\90`r\9a\90°Ñ\f¹\9a_\14mE¦óÅ"\9e}\9a\r×d\1a\16K\8c!Ä´½Ê\8e4\83\16ÜFLi¢mÏÙuæ£î\19B­OÓc®£jüÚÇîÆ-\ e^wÛûaÎ\ e\ 6\9fæÔÜW\90)\fîowàz¦^\11e´ïJ\85É=\9e\92\13\10%Äs¡A\89@T¨[li"IÁå\94\9f®°>"\18â übhþ }\9f ¾öñ\14#«æ\8eB.·Ì\93¡z»Ó¹Ý\16\vÚ\1deGg<R\85!öûTS\ eó1ÇQX\ 3Ï5\88md\18NÈû#\89\10\0\16\8e-Ön»\9d5ºÂÃ'×põu\8aüNô\13W§{ÊR®\1a\ 1\1cêkÚC'=\85ÜżN.\ f\8c\97ÀÔ`õ[¥K»V\9f    b©ä;ÜWì;\92¬`L_#.¾\9f\9c9¶\Ï«Ëó\1cö\ 5ÿ)ú BÜ8â£E¾«ÆGQ\9e©ºh\85\96§@ác=\16i®V¢sÎb\ 1\9d\ 5R\²\19°æ:½j¸±\9dßG;À´l7rý4\8f\98\94\8c\8f=8)\87=´q`cWú]_\vÞ\9ag\956ÉE|Odk?7¡\96»\8bÓÊÓ¼\15º¼\123ø­ÜúNU½3{Â\7f-ý­<Oå\82îèÊ       \9e\86sþÓN\vã;(\8c°»7\97W\9a5ûÓ÷éivF(ëö\8bwÊ$\8fT\19C4R!%N¤\8d§í¤Ìb{.¦soÏ\86¿ØU¤ê¶åT}áxãõÃ\86ÃÂÀ1\97Id\1a\955t\92=cª,\85\8cU/EKÉ_áÞ-4̱Ëtø\83\88»t\9f¬Ð°¢ãÒ\1eEOhvÿ\1f´=ùSáw\8cïf¾¦è±'\9c\93¬v¼ã
+ÀÎÕ\9eÿ*ÕO-\82EÄ©=\95½\8d²µ\11\17«\85Ç\91\1e\8eÎn6VØ©îÖ\90\ fÕùëRñ4K\11ËÛ\1dm÷îé¾4\81\ 3\93uhx\84_\8cþ\88ó_9ç>\95ÇäZf\8fD  é\1c³ùø8j{·ñùÒÛ°«¦\v\85\1a\e\8a«^Äq>qO7ÇuöqÇÚ©r\8côÊÁqu\a­Ú¡lêKdKy\87åñÂé\ eÜàtÅ\ 3Uzé´\1aS¦!4Kn\15d\89\ f_\148\19ÃQRóç\8eË>\95¼ö\82^Þó:\8f\92½ÙVØ̽\\9b\fÍ\1f8\ÊÙFù?È÷\12\b\80ë\93Y®°éb>î.\r\8dl\14ü«S¼äì\90±ù\8a¥Û}ísµu\7fÂ\9e\ 4\ eä\8dù\ 6Ü\9fH\18S\b=ÝdUsp\96-ç*Ä»\87\ eäAÂ|²\89F¶ÑîÀ\81 Â°ÚÕÎãzÅy\89\7f\8beTU£\8f&Élö]\eá(R¨\96\rQ\99\90ÿ\8aJ\9e`[å£/¿¯ÇÌ!©
+ñm\7fr\1d"`Ê\10ÙF\16ò¤¦é\ 3E¡n\94j\b\e\1d?­¿]lÚUT}Eº\9fE´·\ 5{çø~ÑË\96I\84$ÓÚ¹vô£áGÁW1ì=Îoù-æÂ
+\8b\93è[3¶2=\15WK\ºILH\96~õ.\91x\94îýBG\8e\91¥\1dX}©\aÁ\1f£s\86\88±\ 4¯\7f\8bxdò|\16\94÷ã¬zÜ\1ei"!ã]2wÉÙ\9bCK\1dµëH\ 3%íÊØæÈ\e\86¹\18\ 1\93õ\17%!\95丮cãB\ 5ëc½\1a\8dªÆR±WPª;\81Q*\ 5;F\8b\7f\ 4Òý\fâ?\1d\f\19u     }墻P¶ÖÇ:ÔéäÍ\9a³}Cð0í˺Lëí\89û\92rªvI.²ÃýBÐôë\ 2+5uR©wÒ
+;¼Nä¢çRõ\96\1c\1f\8e÷\8d
+éli\98`\96z(KÒ\82\84\9cþ£î®\19=U?e-\ 1^O\1aúÔ¦ójk(Ìg«\13\e\85\8e?U\18Ó  Yèí\13ÍIð%8\a5\8c\95çúÚ\10Ù\9faVg½ËÖ8Zªö\1d)vþú¼F¢3\92pähѧK¦\19YØ`ôd¡Éè\9f\8fÍÕ\9bfÅôDÌÍy¢Oø}<\9e\9fÿÊ°eGÔ\85ÿJ\857\87RJÿ\96sedÑf»\99ÎR\9c\9a\8fâ\10¬F¶ø=G³^^©i\ 4¤aoÞ:,KúÐ{§\87÷=\9d\94/ÚÛ¸\1fmØKåq\8aê\9eàj\19Yp+\1cñßH\1e\94æÚu«ïÀv\12Q²îKù\9bÅ\8bS\ f»2?\17ö)\96l|*L =\É^}\eU,\7f!c\94\93\19é-ÇË[\ f\9f䧽®\99ÔRK\9b9m¥¸Ø\ e\1f©\1e"¿w\16\8cñö^ywi\97íɸ%xïÞpcsS|\99s7õÀÃ\13\91~
+)¹çE\9f?\16        ï\16\98\1cì±B<PNý@2ò\1c¿ñ\a\83»¢t9Ë\11\93å\10\ 1ï-z\96­¬\10\9b\ 2§èÊ&«\ 4%%z^!:\\ 4M_\1fºðTn~&Å\83ó|îY¨¾¿t\92È(]l6áDû'j\9f*l½±BUi3­áÿ\0)\e\15\94
+endstream
+endobj
+2919 0 obj <<
+/Type /FontDescriptor
+/FontName /OQJFED+CMSY10
+/Flags 4
+/FontBBox [-29 -960 1116 775]
+/Ascent 750
+/CapHeight 683
+/Descent -194
+/ItalicAngle -14
+/StemV 85
+/XHeight 431
+/CharSet (/arrowdown/arrowleft/arrownortheast/arrowright/arrowsouthwest/asteriskmath/bar/braceleft/braceright/ceilingleft/ceilingright/circleminus/circleplus/floorleft/floorright/greaterequal/lessequal/minus/multiply/periodcentered/plusminus)
+/FontFile 2918 0 R
+>> endobj
+2920 0 obj <<
+/Length1 763
+/Length2 673
+/Length3 0
+/Length 1198      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\92}PTU\18ÆCJaÁ\1c \ 2t\ 6\ eì\10\9fûq7\16p\19Èe\11Å\81\18\1d\97½g\97\93wï]îÞÝvÝ@\10%\165RC\1dCE0\ 5\15\89\94ÐDHÖb§Æ\ 1\994i\84\ 60\140Q Ë&²»\10ã\84ÿ6÷\9fû>ïsÞó;Ï9!A\8a,\9e\14§ò`
+E2<\8c\8fI\80,=ëíX\80ñ\85\9c\90\10\19\rU\f¢Èd\15\ 3%\0\12\ 3\16`b \8c\95\880\89XÄ \ 12Jo¡\916\9f\ 1a²p§)\16Hu\90Fj\15   ÒUL>Ô±3Ô*\ 2dQj\ 4\19\v\1fH      \ 2d:W\18@&4@Ú\ 4q>\aÃ\0\8eÔ\fÈ\83ZDr\ 4N TRC\81Ø9\197êç[&H\eX(\10ÆB\86\ 3\16\11§HÂ\ 2p¨á\bä\14»\17dIþ\ f¨\85ÃS\8c\ 4!Wé\9cã\9d!=×Vé\10aù×@éôF\ 6Ò \9dÂ!M.´n\80slé\10GFÝÂn*£"\90ZJj  \bxX4_ø\86\81\f\fq\ 5bÔù@£"\fpV\87\10\85Mo\16D°1#-;I\1e9w«³=\85
+\91L¶E\ f\81ð\99y¶Æ\9eÕlF42\83\!_(ÄX#ûÍÿ½»`¯Õ¤\9aÂ\11©\ 5"q\fPÑ´ÊÂ\11²£Db1°b\0\9184\ 3hf\81\ 5|\92bØ%\80\10h(\9aã¼T!\10è\10i48ÕY!:\ e\bô4bá\9dÊóçJJ¢ÌV\1eû\ 6y+Å\18ÀDb\11\88\8d\13\15þǨ6Ò4$\99Ù\97æ3_k\10\9b(\84f¨æôݤÔñÛß;ðeYCÑêº\9eS/       Ü\9f8\1a\96|\9ds¡èS\84\17f\89\8fd\ 4i\99ãcÇ\86Z>²ûn¾î·N\1d_åC\9f÷ß-ߥ\9c®õ9ÓRQs"çãbq\aÿV\96¯¥´bÿÒ¿#CÇRí\ 5ë\ f\18Z!é \87\ fÙ¸Q}ÓÜ­\ eÏ#ø½¤\8duí¿\ fÜôð\8eÈÜ\e\11¼<¶¯~I¿Ëk¾\96þ»½\19©\ 1\1d°a×Ñ¡æîÝôF}\98\7fj座#q\97N4s˺¦"ë\147ùµ~7¾\90\8fxwv.\93]\8b\9fYú0Ò/\17ñ¬¡í]á/OÜ~"¨ê\1fWèó\a<<\3\86ï_¸#\eñjçH\8fýá¨\8e¿²Y\1c\15-;Mi\94g\94\9eW\83\ fßÿ+gp\ 3LJÛS\1d\9a¸µvU»\95_µ¼Õv=4/·­Õ5ñ\ 5\85b\9cïÝìøeª10ù¤ÿ\86ƨo\12öXgܹë]^Í){\10Ócï'·ÔNT_]ÔµõQö\91M\87
+\ 2í\9d^#òÊ×\136}Vt4rÍðZ\8f\ 3\15Mê²\8a±\90\9f\12²}R¬¦Þ\87\82â\ 3½Û\ 3G{l\93V,-R_\15ç\97\95\186T7¦4\1f>\1e\9dp®½´¹rôGú\1dÉþî[®;Å~W8ùm\87´M:aö\9bÄ\a\1d«º>T*#îÕ\9cR¢AtmàbU¥\17-\8bë\1eÐع.¥Ë\ïúp\ 3\9bþüþpG\8el·r|[ýÚË?,\1f\88¹ ×\9aê¿B\97\9fÞ1¶OÞ\96\8a\14Ä8§ºløÛú4ojz\7fD[I2XÑX\1c½ÈÃ`_¼\97´E\84:ÒgpfòÒ\96O\1cüß\1e\t\9bÞq¾©|_ÒXÁû?¿R\1eø8x[IKܨçè\8a'Ñçj\ 6+oíK´µN\88~}qh$È´×Ô\90º\93\94\9fE\ 1nM õ¡\8e}ÅÅk\84Q\9b\845Í   \ 1X\99wP\eým%å\92i-å\1e4u\9a\ 4\8b¿³q;²\9b\8fÚMë¸\89·\89\bsécóâ\0¯\93n\9cõ\9f\9få½åòè^\8aíà?s\9e
+endstream
+endobj
+2921 0 obj <<
+/Type /FontDescriptor
+/FontName /ZQLTBN+CMSY7
+/Flags 4
+/FontBBox [-15 -951 1252 782]
+/Ascent 750
+/CapHeight 683
+/Descent -194
+/ItalicAngle -14
+/StemV 93
+/XHeight 431
+/CharSet (/minus/prime)
+/FontFile 2920 0 R
+>> endobj
+2922 0 obj <<
+/Length1 1711
+/Length2 14395
+/Length3 0
+/Length 15356     
+/Filter /FlateDecode
+>>
+stream
+xÚ­·cxeßÒî\1dÛ¶mÛ¶m­Ø¶m\e\1d³ctlÛN:¶;\1dtðfï}\9eÝÿó\9c¯ïµÖ\87õ\e£ªî»jÎ9æµÈ\89\95\85Í\1cL\0\12\ eö®ôÌ\fÌ<D¢òjÒÌLDÌ\fLL"0ää¢Î\0cW+\a{1cW\0\ f\11377\v\91\ 4ÀäëÇ×\97\87\9d\83\87\99\ 3\86\9cHÔÁÑËÙÊÂÒ\95\88J\94ú_A\9cDÂv\0g+Sc{"ycWK\80ÝW\rSc["U\aS+\80«\17\ 3\91°­-\91Ê¿2\\88T\0.\0gw\80\19\ 3\f33\91\99\95©+\91    ÀÂÊ\1e\86ñ_\9e¤íÍ\1d\888ÿ³lææø?[î\0g\97/SDTÿ¶IMôeÒÌÁÞÖ\8bÈ\f`\ eèàð¥\ 6øòòÿ\87­ÿ]\ÂÍÖVÁØî_åÿ=©ÿgßØÎÊÖëÿD8Ø9º¹\ 2\9c\89ä\1dÌ\0Îöÿ;T\13ð\1f\03+7»ÿ½+íjlke*loa\v ¢gfc`bûϺ\95\8b\84\95'ÀLÉÊÕÔ\92ÈÜØÖ\ 5ðïu\80½Ùÿvò5¿\7fû`\14\91\97\96×Q¤ý?\97öß\9bJÆVö®j^\8e\0"¦¿Ñÿfæ¿ü5$g+O"]¦¯)3\7f\ 5~}þç\97þÿ\12\13·7u0³²· baç 2vv6ö\82ùº\89¾\88\9dÈ\87\99ÈÊÞ\fàI\ 4ðürÌÈ`ïàú\95Bô5\19?"s\ag\98\7f]W\ ev"Fá\7f\878¾<ÿ%N"FÑ¿ÄEÄ(ö\97¸\89\18ÅÿK\9cLD\8c\12\7f\89\85\88Qê/±\121Jÿ¥/=Ù¿ô¥'÷\97¾ôäÿÒ\97\9eÂ_úÒSü/q}é)ý%f"Få¿ô¥®ò\97¾ÔUÿ\12\e\11£Ú_úò¢þ\97¾¼hü¥//\9aÿ¥¯\e\98Ñø/}93ùK_ÎLÿKì_{¦\ e¶_\8fÈÿ¬°±ýkÅÎîo>3Ó\97\7fà\97\7fÀß
+_>þs\7fþ7\80å«\ 4ÀÎÌØÅò\1fI_m\9aÿů\bss«\7f¤|ñ_dgý\17ºÿCä_û\ enÎÿ¨÷\15\ fü*øW\8díkR\96^\8e\96\0û\7fD|­ýC\90é˶õ?ðkb6ÿÀ¯±Øþ\ 3¿ff÷\17¿\9e\rÆ¿\95Ù¿Rí­ì\ 1ÿØÿ\1a\90Ã_3_É\ eÿ×öW3\8e\7f·¿\8c8~\1d6\ eÿ\980óWsNÿÀ¯æþÑ:óW'.\7fåÿE\0÷\7f´Êþ\15îòõ8þMø\92ø{yؿܹZ:\ 3þ1ݯ~\=\1cþ\91ðÕ\92Û?ðk\1aîÿÀ¯\86<þqé¾²ÿ!ÆòUÞë\1føÕ¬÷ßf¿*y\ 3\9cÿ#õÿ\9eB""\ e\9e>ôÌ\1c¬Dô,_¦¾\1aç âæàöû¿"MÝ\9c\9d\ 1ö®ÿ>ê¿\ e³ÿas«¯ó\ f\0ð\ 4\98¬¯8\98ò\86Zg´\86\8b\17ÏU\81S»àe\95\87\845gñ2\ìð¢,9·Íª\ 1\bî\91Ã\90­­ª\91Ò¯d¿3\9a\99³ÿÄn\15ö\1dõQe\f[C\1e\85G£.ÌV\85¼1½Ð3\0\19+\18\19@´Ë\8b:Y'<tl£½Ù }Üuï\ 1¯\93;cæ,¾\8a\ 6«\]y\7fð·      \98þ¹\ e\9biFz\94\ e£_Ð)\97\ 6Ð8ÝM\9c\94t(vX/\1dÃÔË~DýXÇ\1eØ^°Ù\82Ïâ\8e)\90\a]Îâ\7f\83f¢ö4ß\9b\86aα!\×Êç\96ú¬o>A$f\18w_QÊZS\80ç,/w\1aD·^°\ 6GåL ¾ä\10\85Ì¿ü9^­ÖìÁ ?\11<·T3ú\8b±9¥
+¬¸W\ 6w\ 5âr/\9cY¿'÷}\12\a\14ôtñ\94\89r\9aç5\ 1vɼât\ 2ÁÉlV½\89åu\89-Ø5n©pRPh\92ÐÀ\ 2\9b6\18ãÛÚ\aÓË­î-ÆcË\14*\8c,dú5\84Z\9a\bc\87zÏYïz\1e\98\84|¦÷Ð\ 2ç\0Ôk8,2\83ú\8c\ fgp±ì\0\ 3ÿ\ 1¦úzÝ]¾4\¼è\ f\ 3ÌËÓ\80\8av´°\10\f²\ 5EÎÁ\9c\97\fz×ãKÉPgï>Ø\\19\9eÅ\r<\92n+c\7f\98\8dG5\92{\9a \ 3ùiù\97·ù\88Ró¶?æøàLâòð+#Ã0Þ\n#\93Ï\97\1eV\ f4\84\82\ 1ý}Î\1d\1e©Kg\b@ìT4\98` ìö:¹ëÕk0Cl4*!\87\14É*¿Ôð:ÍT\9aò\97åYí`±\93ãsç«)¾\87\\10å3\8c*!\17\99\82óêw\82H@ûJ\11·Ü\8f\93«\9d¡Á\1eèÒ÷Ng\ 6\8f¿%!îäÃ\87\8bû:ÖÔk\¼ \92É÷\95v.©ïéÛ3\a2ã«Ì*Õ÷úÁ\ 4\98=\14\ 6\13À\u1øÔ¶H\7fà+CÅ¢sf\8dü\8cjY^1ÀS §\15\85Û%|%\9djÔOÓ\93_\vc\86q´a\81\8bs¥s NcQ{UÛ¨=FXò\88ðÃîZ\88Ïnq¯?\87
+rz\a\825ZååÓ|Rë\82¼\18ïuÃõ£e\11ÏËâ2n\eª_\8f\15¡Aî\99yrPxC\98¸\8er\16°½R=°\88sa5¥¿µ¬½ýðû£ÉÍ»QÂ]V2\98þlÄR\19\b}¾GæãwÊË{hw\1f\15\96ùi`[\96ÆL)J\93\84·m´r\88
+\9e­õªnÿÀ\94äÙâ\8bQn:;ÞsIi%Ö}N®\19u£@0½w.z½\99¦\8eú\8ba{\96»V\85\ 6\7f`KE\10ÌþRnb_3¹\rd Ò\85Q\17µeêä´µ°p3¼á\9c+R@
+÷¼E\88ôj½3õÄ\13þºÔã{\15F¾yµ_8d3´q¾×½È¬Ê1V\r|­(³¯\92ï&åy4\9aóÒé:æ1]æn½ôhô¼ºÑ\8cXqZP·\8dº2\0\1aO_\18\12\ 5¥r\99Àn\10H/\18\83DÒîG\94Dªbw\b|\1f5\8b³´\9bf°Þ\9dêó¾æ!^6\1d\1eå¤;RÏ:\16\bî¬\99\97>ÀIK\8a\89\14ÏÿT§\91\e¢/¬Á7Ñq8ÿPé\18E±X*ºÎØ\rÙè÷\f\ e\ 4ÖG¥hÆüMåO\13\9cѳ\9a\89\13þ\eAW®3âî%z\7fÔ\Qt¦:\8d\825mú¬¸\92Û°"HcK×U|#ðGglOY]ÖéYºµ[sh¡yþ     ý\v\8fLI\16QÒ­øØÎ\8f\1030>\9bããÕ\9f\9d0¼Ñ¡óKÎ!\r)Í"ÊNº5ý.\11\ 6iæD[>\fyËU\9c\9e\85\14è¬\8c»\8a¹æòs²ÍÚC\13\rM#¦µ°\9aßR\ 4gù;h7¤3\ e_VÏÃÛd\9aGñ¤\fË\8al\13¨±§,*\80Í\13v\88"?ÌöêÐ\8eq<´
+B\17\92\1ac<Û®Ýp\12ùõéPM&ÙÔ0\84\90Êq²\93¸%\17Ì9&ÕÁ\82\12RÛù²÷\99\0wï:\17\155      9Ïnüƾ\8d\bD\ f\83Yc]y«ZA«\80Âð,Ê¢,5\9b0Ö¥éFI·v¨\vñ\vûà\eê;Rçm(/Ç\1eB\15)\ fÐr# ú\10\ f\83Ä\81§iÔÖe1\9c\83_ANÊF&\10Iã³Ý"x5iWXB9¦\r¨\8fm)ËÝ\9f\90ýFr\9b\12\9f\1aýäXL0\v\ 5\ 2a9bBl»^êå9ߤ\89åcwZ\90ïÏ\97ªÍý§;ÏPÈ}ßÙ\86hº²A\98ësPvEI\1f\149PÃ\96\rÜ4Ð(½\95g}ß\8eN\96e\81oð4Ú*=B»UMµG\1er\8d\ 5{C´\14\17ç×¹ãu«T*\902¤U}nyý_\1dV\97Ø©×[§\fQ.#¨\r¤Ý§í³`\1e¥¢9×GÚO\9f\90\7fÍ¡~¶*\eD\1e\9cc,n\88·\12ß·ì\1eºLÆUùµÇ'JÿÀ_]\1aXôËÄ\1eØQ\9fxðß\13\1f\7f{\ 6\1a\13ä/Dï\r\80Ê8a\18o,#Ô]B5¤v,H°ï\90þÓ\98ö1\ 5>°û\8c·l]9áÝû\16\ 4÷É\MS@_Tß\99ÙàKå\12&Çîð\ eÚûà\ 5yìdìpü\99>~Ð\97\9cCq\1c\168\ 5Ò\84E\93\14Å©\\10\9eß0D\b!¯È\91¯\97M\99\b0ÃþaÈlZ\1e\ 2Ê.Ù\fY\88×\ 5û¹¶\17D±»ßñ>\96ï_\9d`ÌCö\9a\8di¸ ºv\8c
\ 1\9cª\9c\93\9a~ÂÍ:Æ|\9f³¿ø\8dñ\86µÝs¾ó\96²æìù©[Ð\ 5²à(\14\82\12\etCô\86Í\80&X-\15ÙÑgoÆÙ\13Ì£â\97Áyç\92N\93ÔËãóð\91p-\83¿\9e@ H\a\19¦j\8c\8fZ%ß=R        \1dDë]û\ 1R´&\ 6
+¯J}\fR\1c\88£4K\97)\9df¡êGØ\85\89Ôs\ 6O\eñ\8aí\91\\889½&¥Ùñô>\ 6¿¢Ùø\$BÓ\12×Þ¶{\ 34ìEu\8b\19\86Í\99Û7d\98ÑZé©ÔZ¶E:8e3\90- ÙÚLãô\9ex,\9cÌ.ðoV\99i¤2³KÝ\14\99Ð\90\8eL[Æ\1cÜß3\1f0Ûé\e\7f\a\ 6õîa#'¦¦*\94-JH\1cS\15cÏá\99Ð\83'\99.PåDW\17;êw;µBÑÃ*Y?Ïgν~§ß\ fføm³U'cU5\ eUûk   äB\8aþjLÌ|MÓ
+T\84\98\9f
+\ 5÷ú¬ç  ;§3ä\11\82gxÍÉT¡\e\ 4)1ÛÞ\8di"i\ 3 É\vâ\1fÊ0ß\b0\ fJ¢ò\f½\13?
+1¾\15´âàâ\89£\94\16·0¡²7ä\82^D]r­\r\16·T\97\e«`1\99Æ\82\ e\ 5Ñ\86£©î#N7r\94:{³\ 3\ 4\88Á\83z±Ç9Ô\9d0\9b\9dÈ\ 1g_\1eE£{θ1Ò«\1e\87\10\80ØZ9T0\9f{Xô±\95Ì\10ø%¥ÿzØPL+VTø\95\14qË.§\vl¡Û\18½¥W\8fµíLj\10\15\15\15ø]b^\e\13¼âM¸Òv\1cn\14<öéåXõó\1cÌB¬\7f\99zxüô\96¥ýuLÚ\94\fÓ\8btC\ 5Y'¦3\80\11Á\8b\93 ¢Â\93\98
+ç@§QZc÷úÆ%>QOïOQNÅeMv\90*ÆâmÑdêÈ]\8ef\82\14¾¹\r\82ô]^ÊòFE76aÐ\9d\10 "\94\af¡Ñz;\81îw·à@ÿ\96\bWi\8b\84à\85£³8Á­+\12\9d{ãgº\19kD½B\8a\95Ä\8cD\an|ÝÓ\80\16xK#\8fιn2Ko\88\93\90s{\94-êU²\ f\98¡,DúÆb6#åno3\8d\9bÃøí­\1eù\8c.a̬[À3_\90oY
\9d9O¸ÅÂÌü!ÎöÌ\15\80\ 2\ 3ÌW:\1aü²=3²Uí\97ijNòõ/¾\86¢\82\91ù$q)\ 4w\94_ïüó¹Ã°\1d4\81;\8aÇ\10\90õø:c\bc\83\84nÌÒéÏfó\8böJí«=ßq¿\1dI
+\e`XçÍ\90I\8c\8b¬ÈCÓµ\98ζ\f\8bºÏ}(
+,J\9e᫵\aûdÈÃ\13\1a\82XÈ'í\10\0©\93«\92«q<åÂ#_Ú3¬îåx·\88¢GlqAúß\ f楯É^Ûx\f\8cÎD!}\9b$¥A|ô\8eWeÙ©\94á \1c\ 1\9bü\94§¼\0ª'Tó-Ìú\ 6'ôìc\89\11\8e\b«Nâ·\0\8c\81ëS©]½P;¸¬ZÆW³\8c\ 3\17\8c\8f\8d\9fï"Í6\92±\ e_\98a°`¼\7f\1a\ 5\0\vû,¹/4)ª&±|\8c\17 ahë\16µ^Ã~B4ÿf¡í8\10X\8dβÌ\99*\93Å[\7f]d\9f1\ e       
+3£f|ãr>,Ùøzå4C\ 3tx,     qâ\99\90W¾ñ)(¬3"'çÒýãÃÒ4¤¢\83rôM9\81\13\7f\85\90M´ØcÚ¬\96\17£éyòl^1\ 1*\86¾¢\1aÀ]|Xí±¢l
+ù`v .³\ 5ù;(ÒgÛàrÅí#×wçORÞ#o\83é°þY»õ\1d\0Ö©\9f^r4ÌÖ\b\w)v\ fcäÅ)Bé¦y&\9f1*Í£H5\90Úó\97ÿI\16(·Õ\ 1ãÇ|Ñ[æ¹\8fhÕâdy°\1d\94ì\16(\98\88»C\ fH,Íë¯G\8f\81\aØ3.\12\87CÕ¯\8b0\92ëÝY\9dºOú+ÍÙ\ 5í¥\ 6ón\ 2{\14\0iÞ`Õ\1cR¬[»àI.6\1c\82\95¹\8eç\ 4VrXÓÀÚ\12 äðàw\rK\rtQJß\85é\v\83*̬;A\ 2\8dÈë¤ü\1a·éS\98ÉëMµCqh\88Õ\83ñé²r_ñ-«ßp/\15\852|3\8f\ fã\82õk\90j\94¦~\1cä\ë¾é¾£´kP\7f@AíÄâ2¿%³ûtñ7ZíH¶ÔíÄÒ\ fð÷\14+[ZÃú»\\8eÐWñÑNV-Úg\97\87\9a}a\82C;\bÕ`ÐÌÎ\14?\1aAOak¡²`!L\1c.â;´¡°\99Ä:D¤\1f\ 1¾ý1º\85\ 4p<­òûJf\11Yêzvö\10=´Ç\96¼=­\95÷çPJµ\ 1pͦ\9eÔ\93¯AäÚ\97\1aækÀÜåûQu¤ç«"Ò¶\95\9b\ 5³¾zîÝrÂ\195\8fhÂ<!\8cþ´\8a\11©î4rLÈð\19UF~|<J\9f\8f\9a\ 5¶,ÅSo!©ñ\81s@dó\L49^æH\1f¥eÛ\85\ e\ 1\8e\89\88YGØ\bo\803\0 þæþµðb\bÆ\16*X>\17t)\1cÈY\97\11âtÔ\ 6ßu7ñÉf\13vN¯\9c÷\1fè\01ÞÌã"à\ 1\83+ò¡\9f)ICØEð\ 3\967\8fþ\95ÖAÔ\9c|\97©0y\19Ö\1f\enyÄb.Ú[Þ
+U®éNÌ©\ fRa      åþáÅzµ~ɶ°\ 1h¶ò  úèó¬ïû?)\82l! \95Ý\7frìvÑè³\võ\0(\e¹Y\b\12i\1e@&\89×ßåK)\ré¤\ 2»Ô\14\88\9aô}ðÑh\8e¼¢iï¤äãû\81ÈtÊ\ 3ÍðÅ*\8eÛóù{°µtä\15\83wT\14\88ãàý\15\ e0\ 4VW9f\84\89\ 4¿C\ 5ß÷¨\9c»1\v\96Õ)Ùç\ f\ 6\15\rü0þݹz´\84\7f@~\r~´LÊ\ e\8a5\v\8d\1a\13úv§ÇO»~Ø}â\fç\88\97éÇé\131Åô>\89L\ eC]\1a\12ªÊL®¹\v-Y\935+\101©6Ä¥^Æâ3*C0ÂF\99`\95ÐÒ{Ê\8c:æó IÔ>^)<KÂÈ\b\120Á9ÃÂ\ 2\17é?\92Å\95¿Îtö|Ê\\fPiûQu\9d+\ 3µæiÖ7@ê¶\b\ 3)÷ùnx¬]÷³4ºÚ\82éîñ\89\15\94&ÿð Í\84\1d¨àÏÆÍ\8f·YtG¼´\18OIç\9b¼1á2©\8c]i\1dÈ\90\16£ïµ wß\ 6Õ\8fÂÆZç:\f}µ&"gÏë\9eùvt`¤0\aUÀÃ\8bØ_µ÷,]º£ï\ 3ó\13\8dÚïhñý\86àC>~)üj\88V Î[>\ e\16 3^øÖéÝ&Ã[º}\e'WýÈdî\12\8a]¾¶Snpi\ 5\9f\ e\ 5|Ñl9\8c|ê³É8l´]\ 4ëÚ}$¯:qÃ÷ª\16\8b:!OM_¥\8eÅ\ek5\83âè\94,(0ãÕè`^]sª \8eÂ\ eÝA\vô±\88Ér7\b\f|cå\12n¥3Én\82]ÒW\8d\19Kùk(\10\11%Ø'\f·6l\F NX@z#u\81å° Kϲ\9dR;ËcÆ9ê\8f\18       @ÂÞSÝB\9fðpÖ{µxH«ýÒ\82ÒJPt\9f?\97h\97\ 2]q\v\15-hÀ\ 4²ß¡Of\e÷â*»g\92\9c\82­Çïò>úÔ¿7_\v.£zkµ:t îdêÑBr4°:~²6QÊ\88©+å\16vÐSê¨\¦\8b2\85¼.À\rl/±\e_½`Æ Tõ0Ö\84¡Àв(Í\14\99 \89qñøæ\9b\ f\85¸\ 3Þ\11Ì%uµ}\9b\15ý\83\98ïl:lcR\#ö¹8\19ë+\82ºbì\98
+3òùu\93pO5Î~@èZ­\8eû½>ñEî\99¡uÙ\84\16èg\17\11\vëk½\ etk\18z¬ô¡L\r;LÇV
+¶dýÖ%â&èâ\ 18èÓ\9dãî\8f\8c5C'\83; ó\ 2ÛW¹n\9d}ÑÒ!ç\85¥3¨tß\8d÷\95ÒäÁ&\ epØàÓ\8b\12\85¶¨\96\85~àÃÛ@Â\r·*»2\bqi\ 1\15\9e\93\18\1c\97±Â\96A\vÂ\\89+s0Qâ\9b4>×8Ó\8eT`M#sÙ\86ÞÕöºÁ\1c«ÜQ\ e©¡ÁæY ¨\13?\16\9cë CáìãF\83¹\11\87\85."ºô\8c\14\82\11\0Ým\12¯ºc\18¾9P£¹cS°M¤­}\ 2ºLÛ\1a¤$l\1aÆA\fw`*Ã\11\897\10avU¯ø\802~\D"¸Ú\a_Ê=\-O\86B\84ÞÌö`þêHy´³­oÆ]B\82»SÉ-=ä\ 6®¼ìNG)ï\14ý\87®gC­\ 3ÊÙ87\96Ê\9dÐò7½\8cuKf\8e\10K¥¼\14ñ\1d$\94ú\16F2\93Gâg\ 4¢öv\84\ 5\87ü5\v\17\90w\15Ûl\99è\99k\9dÎ\81Yl¸ì\9fÌgx\9f\14§ü\85\ 2\1dMr\8dqV\86¾\eØ&º\ 4M\86R\91úE¦+o\15\9cZÈ;[î\11F\87KnVQ<Å\91èNÓss«;ˤÆ\1cÙ\901R\9b¤
+íEÿà\vËÎû^,Y®\92Ó!/?\94q\13ªÇé¨È©\88\91\14°¢W\102 5\15\f\95\80\99\8e;÷­aUJÐ\84¹¹ÌÐ`\19Ò\1e¬\ 22\a\9f#.7\fo\18t\9dx\ 2ST(\ e\88d{ÍgN3\904³k|\9cÊ÷¨Vb\9c\90\94ñÛç\99¿.ñ7¥ï\99\95\19\ f\90Ñ\83¤¯\14¬\9c Y\8c,/ÒIËv\8bCN\17M\15]/á\86¼ÀF\1f\8bü\9f0\10\98\98)ÍÊ\94c\90àH\ 2QÂb¨a[<^E\99uF\86£\8aWÎ1\17Æm!J¥ìûÁÉX)U\88¿£b2¬ô\9awݲ7\87hp\ 2
+¦H\9a\982W4\8e\9frÿDüX\97|ÙU(KÎC´\15±QÌ\84L\8e\84®$¥Wô5£[Ö(Ö«§\vd>E°\92\8bÉ4*Uà\1a]"\1dM\18êÞ%ÐÝö\9c10r\86Ò\87h\ 6w\91\10åÙ9-Ø\95ÛËÁ¸w¬¯ê÷\8d\99;_\82\834\92«ïê>²¥[?¶¨µ2\7f\99Q\83\80Á_¤8ûm\9f\8bÒ_;´úCõ \19ªõqø\96eT\8dþ\81Ê÷µ\89\r\v\ 6Å\9cÄj¯ëû\9b\vÈ\11S»âO\9b¼íT\13\18\95\r\ 4\97á\ 4ÕÒ\8dl\9f\95Í\eÙ4cÚ3xÒ½\9aÙϦ×ÊÒà\7f\8eÿy¦ÅBø\95\15t¬TB7\ 1ÂÖb^r\94=?\85â#vºç;ÝȬ·é&Áñ\aÿ³=û\9bÉáu\9a\9d1?ϲ\91\92ÿïöÄt\7f \84\82lsd:\9d¡}ì3,M\8c\[\1d\96Ã]o\1abîÛ@¡?Øk=\95ì\11a0^á\18;!Y<Xa\12©õ1Å3AP\98úuM:\ 6\au\8c³úu¸\ 1\13\ 3¡ås\8c\ 6\ 4\13"ã¶\80­©\9d·BÍ\11\9c"©ËÃ{SSæ\8e\ 1&ê FþUx\82\94v\ eÉs\1cͲ¨Ê~ÌPG\99¹\eÁæ      ª!¸ÝWn\19yx\rÉM\14,y\88Ó'î-4²\9cý\8b|Þ\£\1eJ\1a¸²\au|ºø\99äö\85H"`èóÈÉ­\ 2\96ÄÚ¸\99é0d\14(Y
+\12\13Æ0±cg\8e-\86\eñ\ 6\\15»Éf[\95XHç%RVNß\11\90\90p©A÷~®\999,OBÙžßU!Så½>\98ÑSËÕ\7fú/5?\1eL2»K4ê'CfW\ 3\8a\ 48xcÈXG\90°»L\12nw\97\8c\87ª9\81à&¨W\16UôSçÉ\1fÄÏ\ 4\135p~3V\96èZ\ 3\85\87¨M\84       \8aû­¹Ì$\97=\13ÝÅ\15v\89SÀwõ\vÁþiõi¦0Ô\ 2\11üú\0:\8f\8aDãþ\b Ta|l\88*­>Í\9a\ fØKØ\1d*\"Âa\90vá6ÍqÝ\9eû@rYdÑ\f\87'\97\8akZ¦\95\15\a{ÝE×:àA
+\80^}s\9bÁ¢Þ\1aîP\0Ã\977\9f\9a\14bm\ 5»iA\82\14\8aëc°î,\12Ït{\1cRFàÎZ\18Àpéë¢\b¤Û)\96Ã/ñ³\8afPºéE\8e±qe0\8c\19"Wój·k`o\ 1è±\ 5\902¹i\r_\96Ë»ô\81Û\8c Tm\ 3\13öXý                þF=Ùt¸W¤)æT>\ 2\89\82­K4\83ènàA~$Tí×aQàí\eÝÞK¦R\14è²EoêÕ\84@\1aT1\808ãLâ÷Sal&·¶±w
+òQ\1eY`©\9dzÓ¥\90\8cÚöº âºë"\0·£¸\8cf7a\92\r\90¿ä\18Ö<1¨âr(â\8cqÆd?\9f­èçä\ fi\9c\07eÇY÷\81<·ÆNâ{\1d\95\9d\ f!e\ 66û!\93¼\80<B\ 2¬å\8fo¬sµ6aå}J¿\f\ fÄ\95/AÔ\84)E\97\1dÝØé´^jCQ\ 6[\8a\97Ö¦UeêS    2¶ç\8a Åó¥·mobÀÚí\fÇ\8bUPÞR\ 2\82\827\ e\ 5cûI»à5R\83X5\87ì\96\99\16\ 3ê\10\85á}ªla\94\91$µ{F5í\9f¯\94\9e\878¿UU
+ hýê­ß_2q\98.Q¨ÎÀÚûIÈ2\7f\18\ 3å\80EùY\ 3í*\873l\86 µj\98ÉÃadg9£§\82\15B~®Õ=Û5fÍj\81SY9 ÒÌ-odµ\85\15\ 3ç4}¦Û\95¿¸K\9e Ô\99~Y×\r[Ã<©c\0êÒT\94¡\9bÖ\8b\11ÏC×Ò\90¦ ¤\88y\ 5ÊÍ=\a\96´@Ï\17*sN|.£çºI\85\9bºqíw210À·"ÕoVÓ))M¢8\7f²¨       f`Pt\85\8d\88\9fFMüà;£\9eÁ\81\1dZ<t'\14F\808^FßÚ¾Ê
+­Ãø8¤Õ´\7fúªú\9dÞ\90ÑÀÅh\12\96ò\1aâ)ò¸W\80Õ R\8cÚ79vþW
\aÐk"¥
+Au$K
+?!\80×a¯\8a\9b3w|\1a®%\82p\88\89¶P\í\ 3\97Dj\86½=½(\9bj}Ó\1aê¦éfõ\15'$Ýó>°WMâ\1e\10\86\81ÿ4\90$ëþ¡`'Ç\9fí@\10\fÜ\ 2á2\vë\8c\f`2t,\ 6 \a\aW[\9dü8¬ËÅîê\97*q\9eD»µ\1cõdV\fW\1f&ý®Õm\1f¯»gà&àäj\87c\98áö±\bE0ï7t'_éoª\ 3\82Ðan\14\9aø\ 3ÄËz¯.iÞÆ\1e\9eñ±-)§§\ 3Þpx\8f·\1f¡/²ç.'gi\9cº\81i\89e³Bm\9fjËÖY$wýÔ\8aùâÀ×,O\94½t¤
+U\aé@\8btÝX+\a\8d9Àl\1aQ´Í»|KíÁó\9eNî@\ 5êõóö\1a\1eÈ»pû|\eþyÅ®\%ô7y/Þ\16ð\9dGϧÜ\9fo\8eI\8fF\17Ýaú¡´\ f\16\17hH\c\13òß'ì¹RE¢¸°æ\8cç\16\990ïL'2\85Ï4`®Ìå}\9aÊÍÄ\8eÉØ\9c\ù¥:ã<\11ý\91Òá%XÞ÷u    ãûçÁIÇ\80{vÙÛg±2è#^G\8b«\9ev¢U        a\bZÇ-\8e­\90þxÂ#Ú<)ú\1f ÆßR&ï¨'!Àµz»\8fi[¯É<gÉq\ 21\ 1-öàß\r\ 5\f       6^Àý\ e¥\11ýéÍ«\81>\fviÕÇu\1d\8a¶É\82\v§­\14a\91AwÂæ(ÚëO\96ÝãZ²\14·BÅõC8\b7u°­àû\87]_;%"a        }\80\97.ðØqµ£t"ë×ÿ©uó\ 2;f¸\17^\85xv\ 3¡Më\83\97+çCÞçýg²`\93\1eÜï\80ËßENWaå{\14+õK\18ʳn\9b@]X
+\11\84*
+\1aJÏ9çt5B\81ô±\9f\91\8d\ 3é\97õÈ¡\9c³K(»ÏEq\8f¸\a¥\8fã9SËP\91>\976\8fa{\ 4îÏ¡ux}=Fe\8bÑЭä\123\9f\1dhHk;\1a13\94I\8a\15Å`1Ô\r\99+m%·Ó=\ 3½¤/d\89A\7f@AÔg=ÞÌ\ 1U\1f\e\83\ aÇø8À\89¯Ö°\9c6ª%\\8bMJ/hcv"K³­"í~ÐäUhîN¿H-{"\19î\92\1cUtº\92º¾\83Ä\9f¡\80ä\88°¨[ý &\96X%ºH¿~ù®¡M-3Ç»\10Ô\9eï%¾ï\8aîÜå\a¤F¡\ eædÇ\91\84\92\ 6\99\v\82\ 5Äzr<«°\84[Ô!\1c\ 5\15ø\96<R§\ 1u>ÔGY\r nû­¯À{²è\9bÕr§ª4£á\8dèË.\97R\e\9f\ fððõ+\14\85Þû¨·ðWábh2¥ïH+XW¢ìÚ\12G1\87(U=Óñå\ fe\86©g$\16\8fåH£<!tk \83 (\15ãÁâ)¾yØ\8bùì4\8elÁu<Èc\ 2\9b¡Ü\9cH\1a\ 1½"lc\rZ\81 ¡½\91T3Ñ\17°ä\1eZP\96³¿'LHf\9fÈÍko\89Zy\81ÓK*gGè*ª\89±»Ï\99\0Ý       PU¤\97[(gK\11\87°¤p"\83?\9fï\8b§Û´\ 6½Ér6\9dµ\82Ψµ\f\1f\13Å/¹\ 2úaào4é ÚÚ°\a\96    /ýC¡J\93ø&"úLtJ²\92©<h®¿ÛLô!ü.(\1a=r{\1cØM\ 1F"·\92ãµt®É=\96c\1e­Gb\90\86¬8\1e\ eN;\10×(í\1eú&r9»\80-ÊhÒÛf_·\9e\86¢hz3_SF¦Í÷=v\12\ 4Á\9eJÞWõ\1c\8fØ\96²Í¼\93ûëu_+9J\92lQ\ 3\9b¾Ó7¹\19\91ùÄF¢]\85ϲbDHë;Ä\ eùÓ ­\8fIx¢:\ 5MÜR\85\ 5¯\8aèûm=\7fk\1aA¼¸\80\0\fÁ\80\a6\85i\96Bb®ô@¯
+\10\9a\9c\88qN_$ï¸Øâ\1f1#v¢5\92èÙ\9b\8f±\b,þ¢5`¨\aI\95\80\14.\9a\18£o\91¨\1d\ e\818.\90@¶sHÛà\9b\96K5>eEÂ\17s\98V¡é¥ñEߨ   üè\9c\r\7f1äOFs3N>\11g\9bOKKÇxP\8foøñE+!\19x\ 4v\18±\8e£·\8f@Ûr\95G\15rèÝ\9eÖªDF,û 2Yq!É!;M¦\ 1j\97"\ 2NYÙ \1as}ÕËn÷E·¶^\17\13U\11²Ø)\12\15I\83ªî\rJ·û
\87èF?MxÁÉ[+¾\7f,\8c$(û^x\90ì*ÔÀ¯x\8eúGÒàUxú{qÛû\16&N\8b\bÞ\ 2\9aìü7qiÈéÛZRyö\11ÃÙ\9f»\fºÅ¡Tvô\1dó{0«Lb¬ÁÔD\806sddß\13o±j:7\85v\96ÅìÃïóÅ\80·&cß³'þ(æÜ\ e¶®¦;\16õõDø°\vÙ\7fFs¨$\14!ê_ÿä\ 10Já|V\9b\15ù\ÿ\9aö\anåí\89\ eÞÚ²Pwñ=\ 1mjág\8dجþÖ®ë_ \89.ª>$oÛ¬\17­\7f@\86\17a&\b1dÌ\1cpqSG9k\9ar\96iQ\f\8c\9e\95\14ÓÀ|D\ 4¶þy-\95\ 1\ 3©Õõ\9bѽ\11\ 6K°­\13\96¤#\9cî5\8cI\80Ì\93oc»T©\14J\818!\83ÍðFn\82ÛÜ\83LVã,ÉÆà:\82\87Y%\ 1{G\)\ 50+ÁÝb'½8èÁH¶üÒHçùwRåorÆ2\94eúÈÖ\88g\7f \80ëB¨¾ÝÈg0¹Çi4\OØfVv\1aä=K¥\84ºY)ð±ÑÎâås"g\9d 1.GM¢ÿF\86SjÄ\9f\10p'¿\1aGa4«\1e\12ý\15è\92½Ù 8wd\ 3]\93,ctüx\87/\ 4»\80|°S¥\83ÕGF| !o?ñ\eRº¨hT\8a\96²5\91\80Á´Ki\7få-v
+δï~¯C RÍ\aQu4³i&D©\89êêáq\81Ò
+é:\8eè½õ¶\98\8d±7O\15Y\a¸»\÷Ø\9at\81\85×3­ÊC\f£í\92    ?b\9dÿÃ\92ÿÖ\8f\1aJË<´ç§ ¬\93!ü7Q§ëÎï\99Á0å)\r¥Ï\8d"<\1d(/o÷~8o˽J¼I¨7å\87URI8Y\88\9aGäpnY\9f·\~ÞòqÒ~fcÓQ\88`\ 1R`'\ fèůÃ{8$ñ¤\ 3?H¥UÕßkÉ\ 4¡faf¶d\fz|\ 1*ÛïJ¹¬£È\95C§TãzCëô\9f\9b5\8còý}³Ñ®AÍÊ\13s\94\ 4\ e¨è\19³\80¦\8fVh[Ê@oñî\ 4;dQDÐS͸*Äþ>ñÁô.PZí­øúÄ¥\99\ 1\13»l\7f{©:.éÄù\1f©/?¥ÀÄáåHo\92Ñ\86\84#éâ\16ÔÏÛ\95<ãtw:\92¡  ½\87«\1c5\v;òå\9f'7©\17R}Ll\9f²)&\eâ\80E\ 2\82{\\88NyûÂ\òäV\19¸B\14®o\96@ º
+\89Qo-aKM%µ×p}3Á\8bëÝó'ó4¾í"û\98\1a<¹wd[\8fI\ 1¯Ë\9cRaÝ·k_~6Ò
+\16êØý\ 4z&<.\10«\1eJKÁU\16\93¥\8fp\18Acõ    \æ\85\9b\e«KºØ®$;'\0  ¢ó\ e\97\15§\88÷í\8aLåbFNvå5a»é\8e1SM\ 3\97ÿ°\1dS¨ë6Ø?Ó)í©Ãf8\8d7\91.\91Ïç\r\14    ù\84pÉ;xw\vj\ 5WU×
+2²\81ú3IÜ#ÇW\eQ\837\ 6ݲnëe\9d\9b\92iR\81\ 6Äå¸Z\18rl\93àì2m\97\8d\99a¡ÓÇ-F\9bÚ\8a´\9eTóê\8cYãø<\a\17\9c\ 2<Y{¾;¯\ e-ßÅ\ 5¥#Öpè\8fä\82\ 3r£Åþ\86\81vN&^Qö'\e\96ÏRº\89\19ï\90ü\89åÔ)´5o¯54¸iQ?x\b\ f^-IM\v|\ 5odU\93ã\932K\9fÔ\89\87>ÿÞ\90       \87ϪèTb\19¯\84hk;ÒxíÒ©ç¢ú\8eþ\ e
+zH\ e»{ÎÆ\90\94\7f\1e¼©\10éÅ6\8b\ f\11¤½>\96×ÓÖ³¢Âµazad.9dl¸.)=}qå¥S×\9cÚ6Wø¶Ã¯\98\94_\11\95,˽:²\aÿDäÄ\18{\11#\7f\14³d\1aÛæDzð)\99¶p \v"¥+¥V\8fä(ÞY¢É\bû\82+t\95\ 2>
+\ 6\9b\12;\7f\82¡[/h÷\13¼"\1fÛ\88pæÓ\1f\8e\ e7êÔÑ\96W\90\97\9cPóÁ\1egÙB¥T¹½\84Ôl³óý>j\87eYD}\7f.ýÛÀõ"¯Öv\10\83Æ¢\95\1c1ÓO¢DÈ\10Ö\8e7t¢W\82\86O\84cFYUÄ\v\9dK\1faj(¹)ÂlÑ~\ 1\1dDnòÑãwûÅÈ_Ûsä\v\96%\94\11\99¼\8c¼8+£PÔü·ÍZäõÞþ7\ 6\833,\81\1dªVDÀ\8dhâbÝ`\83\9a;C
+7€\88
+\17\ 1vX\9cßã\ 5o\ 6\18\8ey\11\10c¢_¼í×xM6\7f\fåÚ \0­\1c\11\ 5\9eªDìêÞ¹«¼_¯(\17¯\8a½ð<[+\fùǯH\80`Ê@¯\\91     (\8b\9e½- >¨¼õE?Î.é\86\95\15iær\86ñ3ÏS°_ãüx1\1d\ 5
+ÍÖU{\91\12#¼ ¸ öðUÍ\fð«\90Í8?\12\16\92^JPæD;\et\f&Ì7ï²õÕäç;\9bìî8\84\97\16Ô/jÍ.ò.&\8d\8cÍI¥×pÃ\9dàþ\8dø\9b\e%åØ\0èÕ÷½×\99o\ 1U\r(\9cP¸|\91\93V¾T\92¡4-±;#·ÓKrÊ=¦\ 2 Ü\19ù\99Ü\1e\85TTw\9e\18ùÇl\19»Èk{²×ë#è,©\8cæ\16ÜèÛÁ!,s_8Ü@\19\9dg1¨B\1eq\1a\ e:\99ì\9b7)Ké\9fª_9$öÕÔQp\98\91òL[G\81»âcwj«Y?\1cRf>     ôäIÌëýªÂ\8c-NóF÷3\90¸wb¯a\19  \87ÈumÅ=ëgô®ÈÚÓã·T]bàaïFh\13ý,IË´Ù>f\9a¹%Ö\9cµÑ\7fausz$$È(6äÜÖL
+!Þö¶\1f\ 2çÉ\82õþ\ eá¨,+V\1e·Óè8\a\97£3f\9d»\8d­V\87ü>\ f\85¹\97¤ßé:\93=3\97\87à\94\8bâ§\82\8f;\11ñû\90\14¤ôR7üáCØóè"\16Ê\95\91\802\8b\v\aõ$Â\a\1c\9e\16ªæ¢êÍx"Ñ9ó¦ãÜL8åE»éÏ0ë\8f\8b¹Ò²0Ãj\1d\13þ\99§a¢VÄ°\802ÒrªBzÎ9\9c\8dÃ\8b\8d#\9f\17\93\12\86QÇ#ñ®£J\a\ 5v1½"\91%\9cõüïßï*ñd\16\8fì>â\92\ e\9e\ 2ªl9᫬Ás£\7f8\8d\e\1e\1a\875¯í4ø¿8½\89\97À\a\13U\I®ãAài¯\8d\ 6\96ì{Â{     }?M(UÁtì$ÃÇ\90\18\f£vd¾ö±.Oa²&u.Ô\10\90¥úãÖ$qåûÒº³e\8b\97\84E%A\16ø4c,y\ 6þgëÎÁ\80@\0ì~ \10ÑD·ÍÝ°±S»úòXÜ=jqFa8bG¸Éú¹5`PÓ\90^\92;ØÐ;³1\1cà\95\83Ö.Û>8M\9d ô\ 6'Fæ·®tÇöè\17\82Düù\93P\96
+\9e\99\9c\9fg\7fqn\9cbÐÔQÆÖý\8fZZÏ\1c0Ç:åöØ böD¶¹\80\10¸\83\9f~\ 1ú½w@pö\1aà,gàqT7L,l`\91©¼\ 1\9bQ>\18Ë\11\9fÆ¡A\80üÎ=\14³\84\1dSø^\bs\8c×ÐÌa»ð\8d\83\9d\18½xÂqõ\19\ 1\ 16~"\93$Ö¾\a9et¾FÇ/Ø+\81ì'\1e\9aÆ\15\ 3\e*ùVK1Í\0\97sÀhÿäöS\15TUH\10ò\ 1£>\12\ e\81=ÞÌwÜÅAþßõ¨\ 3*\83´\89bú        ¬\93Ī\ 1\19\ f5-Ï!\94\93éZ´RãÊ?+¨`\9b\88Úqùü£º&±ë\96^Р  J\94C÷    ô¯?\ eZ\86è»~Ç \96;j\ e\7f\96(¯5²Õéa\fÊß\8b\80i\14\17n~¿¹\f\82þEw\1e\ 3ÁÇJ\8c+k\85arVäù¨(:4\97?n\9bÄ\90\86:\98¿^\9d\9bm&BßN\9f>\10¹ø0Hæ¿\ 1ß\89L#2\90Qx~4¶ríEÙ\e×鬱ô\88é\0,8\83~\8cÔ\88(Á3^Êy"Gûð&ùç-\1e\877:\14ãùB\1cta=âÅL\v\\ f\88Rf4:+\8cUs\9e¶J\11+G
+\r\12©4½v\7f¤axxYö~"y¤J/\92²bÝ\ 66#Q¦î§\97È@\9ed\93£±°§º®\14®\19\15jù<ús\8a.hG$CÉýý\8eÙl¹¦$ë\ 3×{/¨x0Ú1\9f\94YõÀ,\10\16\99\16\92\93\ 6³FB.ÿí\ 5\98bqqÈ\80ù\89^\96   »F¡½SnꢫnQ}\8a\89Ø<Ñ!©\15\8ccdÆ­ä*\91
+9\14/1¦@\17\9fÇZ<ijbeôósy¥Üõõ\13w<q4/\r×\8fiiw\10R\10ÕM\9c#\9fµ2V<è=D±¡Õ©)¤2dD[Í L\98\80UÞà#\99\\8f\0\aöò@Æt'Ñ¥ëÙî$þÛ\85 \8cï\81\15ðÉþ\8el\8fØH®Õ\88êcì͹2'©7mÌÁ\87:û}8.oÛðújÆ\1eâÆ\83ZQ\8a\15D@#\9eÁ@¥¥\ 1\12´Âì/²\9a¨\14\93\10Ý\9f=¯!éZ¶¶Uª¾ã\fS%7ìFî\96öÓ½á\võ\86\84â\©Q\ 3\81s\9cÞ%\14£b\94Å/\9dE\0»´\8dB\ eG\1a\8c\84¡¹j\86\91¶0Á\9c\8f\8c\9a)bà\88\1dâ<0-èíÊÝ*\98Àñ\84?\19aÝ&p\10\ 5·¿\90ªl3CîÇÙñR
+(r®C{_\96!Ötñµ\1dwʵ\9aýNÑíê°i\9f\17öH\1e\99ê\84{\1cèk\87õ÷:£QK8\9f¬hYY\8e
+µÕ!øãí\12È\99ü\1e\95H#\85é\831ÍÚµ\1dFq\93~\89gx\ 6úzãQ=.\8c\96íXEÃÄ\11Vk&s(QZ\86ÀüH1I\ 1Ò·\16ë§p¢\82<ëüã\87Ý\8e\r7\85_\12\8b¥ão\1céÐ\8dæk\v\83\v¿\vùn®o\990Õ[á\r|Ä;\14\9b0\9bŵ\8d\18K½éPb}oû²¨ÓÖpµÝ\1a.¬(=]¤Y\8dïá\92\94\16`UÉÖÂñÆ<¶µ[Bpºñ\13ýió\10ïý¡ß§\173rز\900\r¦¢\11_i\90SåѽÂ\ 3moÓ\95^5\1c¬\9fóÛtKuéiºlX\90\14M~ã_\86¤\ fz\ f¤\ 1\87\81È\ 3\894àmØÛëï\1a\95V>¥-\ 4Àþ\16Ï2Ìý­¦\91\19(0d\18¿\f\83 J¾tHP\18Ó\10«îÖX\8aÏ1£Wô NÊßÿÒI3§0ÏÞ­ò\96Òï\1ev\9eQ""[zeuKi£½*;Ù\9bæÃp,EiXÆöhR_\13Ec=D^-ßÏã\ 2J\17-ä_\8f¦\18$.\9ao)ù\ 4\8adéÿ2øè¤jX\ 5\80\1cl\b£4\97Åð\7f2þüÃ\867h\8a+\0Ñ>J\19Ïì\ 6\87T\93Á«Zü°\e¼bHÆ\ 5!´mk­\1fÌ*Ä\ fK\89Fy\81\8e   µC\8dÕ½pOwç(Í\86MÜÖ\82øí\97õè­±\0êöµI¦É£;\¹\98æË÷ÓÓ\9e7/wyPÝBkê\8a*\96l\bur:Ä&8¸á¼*i7\10ÛÝÃ><P;\rÄýº1hòø:\8bÊ×2ò\12\10B¡£Ý=\f\1cUn¼\12̧\99lnµâ´¶i¡¥ÝMÌ|)óÝ\89^ÜrZ°\büý½ä"´>7K©\v\ 2JyðôA\94Óæ\ 6\rm\ 4»íÇAUI33\85.l2u\bÉWÈð\91\r\8d\9a\1f¿ð\19\1aÐI&T(\8c\1c\9f\véɶ+\e\12\9cßT³>\18\18§ÌbGk@\95\93L`\91G\81»×u&\aa\18ûE©-c\12ó\18¸×¨FÚv\83
+\99Ã_\ 4 pÀgiSq(\96ÙÞ¯t­\18ª·¦ ¦½Vk>:\ eðS»îc\15\18\eÙí\12RµõÀ/ÙÁ\ 29RJF·ÍQî\9eð\88ïö\1c\ 4!õyL¥_aÎÃΰí?\1e\ ffOÒú±·ö§O6³¨ß\16¨\86ýÛ\8f\84æßúk*e\16dV\v¹ÿtû=RWJ\1a²L* ÛÔ\83áÎ\8dÊEIvÈc\8b¶UFò\87\80Êøì     \ 5ý\ 1à\97ç¿\ 4e\81ÔJs'Ó8O\8eò!ÊJYôôL\89ÏÛBmôdãüpç\b.cô¾ðq\89µ\ 6\86Ð'\8d»\10>+îÅe'¸º\1d®HÜ\93K\8bÀ   \8f\1eEþ ¢¢ð\83é\99\85;\8c=(\ 1\92\aÎ\8a¼ì%ͼ֯\8dî=T\b\bx\16\87\8e«¶úY_4¥lyGi¹\99t¸sY®·Þæm\84\e¿p¶®T®\8de]\ 1r,mH(Îé\87~Õâf¡\80s\e\91¤\80Æâ\10\14þÙ×>\81Yw&\11<:\ajhË\849×_>2\7f\90t6\809aJýÞfã\ eÉËéOù³*7\0\ eãçÇ\eOÝnuÍ\8c|dø\eõ\1a\9d:¨Ñ¬ÊE±\95À\94Rx\87¹\8bí³»Íu\bÍ\12TÒ»\82\1e-¿*\12\83¥]\89\87\96\ eä\95Bg÷ì&êtà\95ðf\8f%\82ÞO\1f·d8µ!>W\ 3\93¶S\11¨r\88×\0ð\ e\99ú!¥Jqðü\98IwCÛE5@x\99½
+¾å:\9bV\ 1Ä\0¨tmw\ e!c\a¡F7\vL"\9e\9a\1aÐ\1eíì\10ï¯hC\8b.Bpô0¸¥\ 1~h6\85}K/\94óæd©\12¡\8dl~Ðu:×Ý%\9c\93\ 5\16k\82ªv*zQ\1a\90:s\1céÕ¶\8dÄ
+\88oßF²Û\ 6@j:H=¡ó\ 6\9e½îÒg\98g/±ËKN\17Æ\18Ä·/A¿s/"á\17yh\95Ú\96¼¸\10¸²dò\ 3biÕ(:¬ð95\8còc\ 6\9fR1¯U´(m\19\«³\7f\80\17\1c¯º1üJ\1cz%zå§\9d2%KeÌZ\ f?\1c\1fé\19"!\ 2â\1fVö¶Ý8       S/yÚ\93\81<\90î\9e\b\8eö[u¼D\7f\95ôéð\94Jøýî[oÕ\90®\89 ÃRå\88¦=@Æ0\16?\8f\99\92Ö\8c¯»\14ZÂ)X7dõç;éN-\b\13½Ü¢\v¢¬Äè¹ù\ 4ìÝ]2pñüRèÌx\84oiöǾà\9aج\98\82­Û\9f¾û´Ùn\97z\KI\ 4øÔ\19#þF3ö_R±\830\9bAROì3¬ôº)\v¸õ·&ßƯ\e[,ä\ 6\a\ 2`üjĹKÕ«çZ úúsnaé    ë:øü\86Uñf Àä&ÝíA'(¥«àC°\ 2TF\92Á\ 2v¦×ÚÜÀ´£\15\b{)AÎ
+¦5\bI\9e#\12´2§¤Bó\13<       ßso\86÷\ 6­n\9d{e e\1fIÔÕ\19%?D¯JócÓDâ!ð\1aÝ\ 3ùЬÔ\95\9d:\84:\83y¹È\ 3{\ 4       ·\84\17R\9cÝ컡ÑëE    \8fçs\fÔ87í|Å $¬lá\90¢3\11gH\88QÛi\81ª0gE7\ fÔ
+¿kËÅ\90ÂâçO\99\8e,\92å\92p\9b\8a^(£[\ 3Ú\Cx\92Â:Ç#\e͹ᠠ Ò9õ\19\16¾\8d\82Ƴl
+5[ÐN):¡Ó·òíÇ£\1fàÊ¥\1d\98S\99+t22\88'1=®®îÚÖ\a\90ÛjHpYó¬`\8eÕÒ\84}\84ƵH\ f\1cd\ 5[UqUBÄçþ0pÖÜ¥\9aI\86\ 3>\87uD|ÅhTb\ 2J¬foóÎÂ\fØxW\8eë\17ë\1eÓ»\11ù\bñ@¦<\9f\7f5&4Ø\13N±Q\86Dy\ 1\89Ãç\17ÿ\bD\1f\94\9fµ¤\r]øc\136ðSÉ\95t§OpJºm\eü\ f'þóí+4AÓÆíE%\14ìÅ: \9cÒøR\8f*vFgq\89ðã2Tj\88hÇ7^*\9f÷8?%Ýgaó\9c\8a8[I8þf|^\8b\8f<F]Îñ\89YðøÛøìÞÚ\ 4q\ 4'\84b\9aTÀþÇ<¦2|
+\8c\83R\89OGÀ$­\ f\9bɾ¥ZgK\93¨\81ñ\ f"\97±I9\ 2÷gç?M¿\8fªÅ»Z\94Ã[Ñ\11 0\ 6\92â=2ò]ë\98\858æO±\7f\ f¦\ÁþÈuÚöXù5ÂØ\8aN¦Å\ 3¯É\15Õ\ræd\ 6©\eþcJ¹fÀ2,\7fŬE\9b­ \11  \1c;\ 4=ß+F(7_»IÙWRäñÓ¼\1a\ 5DFį\80\17°Ö%\r÷>rô\10mØ­r¸\agRà\93
+\9e\16®t©á¶})I³\Öèa*DÚÊßÒH$\e)\11f}|ó\94\b\8fn\8d\90³TX b\84\9a\94r\våIѬ)¯\9a¶ ìù      q[\0NöÈyK\863\8e²\8a\9a\19q\9få\9c¥}\14¤¬\16Ý Á¿qÎXÏ|\ 5¶ÊÇw$ÚÀÏ\1c\0\ fé\ 1À\17\ 2Jo§+\97\e\8bO\1fÇ\87-üÖ(R5\9a¾X¦\ 5§dH\92a\19Ãr\84æx¶cI\87\9c«7û\13D\89+\18\9d{\18\9f\8a\97\85\ 1ɽ÷Òtý="\r\98ô\9béý\19\ebBÀ\195\8e¢ ËÁÏqsV\18üò¥×\91E¨ÆX+\85<\93D\83,ÍäFÙwÖ\0j57è\90å\14]õý\8e·ïdÕ\85bêì\15ßJg}k¤a1ö\86\86ÜÃañå\r3zÁX\19ð\ fRLà¶h<D\95Ãe\9eS\1cr\13tå¤3åÎ>\1e 5I¶(\10Â\13\8b=
+}g\9b@bÄb\81\9eƤ \7fÕ\ 1·î\94\f'\1fÄ\98\89\1aÞ\b2\e¬\18eìag]\eQ\15óB\1d¨0\r+\96\84Ì\82d/±ö\18þ\1cH\8c>ýÉÔã÷T+LA"¶%&¬e¯!XCr\8cð\18\80elMëuU\89:ù³4atècWdB=\96´ù¸7U±îXBSÞ\93\87×\e\1eå§\9e\12òo\13·@´£Éɽ\8a²\ f ªuèXLP[AJ\12ÉQ\11ÚÊÄ°_Å#\8f±\9c
+KôMµ1\rÒªT\f»QÈÐ\82©dÛÕÇø\11naÅ)\9c­aÊku^\89i~u\1ez\ 5Êkþ\87µ©|\9a¥Fu\82^¯'_o\18ýG6¹Kn©ÒK0mo!£M=Ë\8eQo\15\10­æ\8bQêÅ\v\1dõj\99Ì\14 ç!\ 5×\9c\84ÃÁ\12\97\ 5uh^ÝQãN"7«Ï*×7Ø\8d\17ɨÃî¤à~¹GoÛÉ\8cf\9cìËh<\84Ùë½æZ/Bt\a{i«÷vµjCèbܬÜ\847÷Ñç&$.S­\ fxã»Òs\85¾z7ö\aF\9dÖ\83,\13Y\a\11Êaz&#ù%\ 2Byy\860`GoN\fôh±¸\f\97\+N\v\8e\v\ 4_\ 3/¹9\9e\14f¹9®t6U\15Øâ\87\13Q\88\84\9c<\f!'e\82\87      ü¤\91\9bÍÌÊ)cÌÛ\a\18\13:¶æü\8f\13\8e\95hrroFMBK|y 2\9c»O\fêÌêÒØÄË\84@¿ãh\18[¿ÌAP\9eôò\1a\1a\a+P27¨9üå<ã©=*yK\8d*»qnèYÉ«ÈÕ6¹LÞx\8d~\a,\81\1e\876\9f\99yö3ëë° «ïáÉê\8fXÙá\13\ 2\90!&x©pÙÏ\1aãH$$µ8\ 5A3\f(òsñ\81\8aaò|¦f\17Iej 5\15å\99å\85JÛÈ^Q1Cq\11HéÁ¸õÏaÝ=+K~æîuo\949\våÞ#JÉõ¶Hѽ\ 3DÛÝbî\9b(i\ 2\1f4x\8cn\9e¢\98\1e\98Y1@,æ\97H÷d'{éäì2·Ø\99©\1eZ=ãBÜ6Ù\88·eõ\ 3ôu¾kï\16jÒà@\12\8e\8f\eÊké¿Ý{b\8cß\vÛùû\fL\90L\ e°~jlë.\1c\8e²µmÞõ\ 5"\8f\1fNßf/\10\9b}£²\9bïåÓ\19\80+\93%Få6\83\16È)OâµÌO(¿¹ln¾®½h÷ëÚXL½¸ò\8f«å\13å\vB\8c\97ÏB|à¸\1aLT\83\1aì´6'\9e\9dc?,\ 6
+éIa]zG¡*n W\148\bR\ 3íðó[þI\ 2\î5Ç\8dîy\17Hæ­\14\0´ç\87s\86Ú¥\94ë\80ª\ e&Hï0&P\8fïì\97à-\8c\1fi\16¥&; Lÿt.\a\8aM\ 2[r\r\8f_"\ 6ß­ÿÁ1\18áødü^.*ùú0\9b~S_\1a\87\98ÞÛ\81\8dÃ,§ñÍÍÈ"Fb\1aκ4¥¬\94-ø¶lʾìfÓ\93÷î÷\16Ëqú¯Ñ\88Ïë³ÛÑ×ÏQ¤Õ°´¸\8dØi\ 3\9e¡h³a\ 6m½sÔò\83¤\1di¨Ø8~-z7A¡·O¥æö\r\7f\19ÜÊ\ 6|\18"\81\93¹'%\1f_d4x\8e\15}þ8$®ð#\10*Â&l\ 2¦\bwQ¾l\19_È@å?û¯#+Ö\ 51øÎ\9d\94!´£þ\9dþÄZks\95}@¯XÁþ       >קrþÒ\14«Í\v\99\8fóª\9f}L®Æh©Æ§Gùº,j\9feÀÀ/¨~H}Ú\8c\&G?-ïí\81·°Åù\17\18{çQ&\9ep\87Ëci4ÞR9ÛL5\apϬ&\19HDO\1dò\9fÇ6\97í) |Y\9aëD¨íAÍèóªÇV\ 4\85Øv\1f\8bw«ÝM ªã\956\1d7\97\bë5>D\8bµ\ 6ɪÂwì\84\ 6\7fñæ@\9eã/¤ã¼¦,¯Pyéë+µ¾;³g\ 2L\13çÏ\844¼~°Ó:ˬäFÓtLRJ\80ØùÐ\1c\98&7I\9bê\eHG\0\84\8f\88\8a\84à_G~ÊtmW\17\r¯Sü    ïå\15\ôÜ\ 5ß+r\9cm-U~³iâ·ëÂ\1aS6\1a
+joì\1cjn\95ÔG«\vÖ«\9dââ\91\18]s\b\9d
+KxB\e\166 (Õ¤ç\13±\92¬\b\0X\ eT\93\15!hÿòzÌp4Q±\ e\8e§ý¬}Ï+ð[\12ýco\85Ì\17\16\95\86\98ævŸMå÷\92o׿\1f»r\96òÿ\ 1p\1e\10¦
+endstream
+endobj
+2923 0 obj <<
+/Type /FontDescriptor
+/FontName /BMIMZO+CMTI10
+/Flags 4
+/FontBBox [-163 -250 1146 969]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle -14
+/StemV 68
+/XHeight 431
+/CharSet (/A/B/C/D/E/F/H/I/K/L/M/N/O/P/Q/R/S/T/U/V/W/a/b/c/colon/comma/d/e/eight/emdash/f/ffi/fi/five/four/g/h/hyphen/i/j/k/l/m/n/nine/o/one/p/period/q/r/s/seven/six/t/three/two/u/v/w/x/y/z/zero)
+/FontFile 2922 0 R
+>> endobj
+2924 0 obj <<
+/Length1 760
+/Length2 1284
+/Length3 0
+/Length 1817      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\92{<\94ù\1eÇ+·5\8548QËcå247\1a·AͺN\8cûê(lcæ1\1eÍ<ÏÜ0\13â\b§F«^l\84\95ûí\14-Z\13­´\96e7¹S.iÖQË\96\9cÖAå¶CÛk_Çþ{^¿\7f\9eÏ÷ûù}\7fïçóû\19\eú\ 6`)L$\1ctC`!\96\88\ 3δ@*Ñ\12 â\b(ccg>H\17B\bìB\17\82ö\0ÑÎ\8e\bP¢Y\0Ñ\16°$Ú\13¬íIV(cÀ\19á\8aù\10+R\b\989c6M6\0\85\ 3ò!\ 6\1d\ 6hta$È\91Ï`ÐÙ@\0Â\80\18\aPØlÀ\7fs\87\0ð\a\ 5 ?\ 6dâPD"À\84\18\1cdA0
+¿ID\85#\10Àæ}\99\19ÍýÐ\8a\ 1ù\ 29\14`&\87Ä\0rD&\ 2³Å\0\13\8c@á½\11ùY \9cäÿ\ 1µ}¸[4\9bíMçl\8eßJé/}:\ab\8bÿp \1c\10ä\ 34\84   òáíÖ\13à{8\1aÈ\84¢9Û»T!\9d\r1(0\8b\r\ 2\11\1cáÈû:$p\83D Ó\17\122"\81\b:[\0nÕA\98¹\9dD\9eÞ\16\aÞ×=ÀÇÅÙâ\8fkÝjúÒ!X\18\82\0áO÷\96&þ©å!ñ!\11p\8a\80#\10\88r£|}ø
+Ýv\98+Ì@\98\10Ì\ 2,IÖ\0\9dϧ\8bQ\ 4ù(K\12       \88#\ 2\10Ì\ 4E\0(\92\13ãq0"\94o\ 1äÉ$\0\11\b\1fµy«D\ 2  ÀC\9bµ÷\92h\ 5ày[ò¯ÿôé§\88(\ eke\r`-ID¹\95`\ 5Ø\90\b      ÿcdDóù ,Üz5òd>è\bH\1e&\b\8a@\ 6jt\ 4a\90S¢r\1aӪϹ\96öýK        #8\98[\99Ò}/õv.\19÷b\92¼o\88\r\ 4õ\7fÓLÕ\8c\82nìÍ\9eó¬Á3#H2ÝFJ|g\\0>õ±f§\9a\16¦8/@e\9eñ"$lWWá\ fm\1a\9c\82\8b¿\8c\1aLs¥\16ócF\8bOcî)Ýò\9a\94èÎI\14«\1f\8d¬-\9c;\93øP6ºû\1aÓèY6*´ð®×U0hæé\95\aï^º#¥Èhy×ßBò\16Ñ룺mO\ 6ÎL¨åÚ¥\17Ò\14FªþsÊýÖÕy³ê\ eúøĵöøE\7f_\85\85ñg­*õ3N\11Ò·  Oâe¯¤'E-\99¦­¤\82\1d\16\92\8e³VëCó»ô¸©uSMV\93§ñ\1aËZ¬\97Ã;\85Çÿm{\vSd²<\18y\131î¾\93<\1e'p\ e¢g¶D\9eCS?        NN&\98\ e\14ÈjÒÊçI\15ÉMIF\83_%Öþ£|ø\ e«¨\82-)\1aï"kgWù(Zß\8c\12ï\90²ZºeÊ(\ fÍ\1d\ eâµnÞ££\89XTDô¬ý\80^Ðí\87\19Ëas\8e\8bÓ_,7õßãûzð\87áqS¼~Î*\9fÝ\18Ù\15Â#\ 4\8fé.µÉ\16~6Ý[\9e\8f´Cy3ç'/¥iK1æm!Ã<Oö\8aÖ¼úký:\82ê½f\9f#'C\1d9¹&7Ú\9a\1f\8d£Í@}ç¸\15\a·±¸pÃìÓ«Ö\97\16\ 6¹´\1aûÛô¶Ë<\1d°ÕÃsé \12\905@ü    ¤g\941F\9c\8eÁ=©_ìG±\95.Ö¯OX¢ym\19±\93940tq#\812·s\9d\97\90)¹ð9RÑ;=p?)1#1K¬#Ë\9eë/mf%Y\18\1c§îU\8f¦\93\8bH\9c\82\aÍCc\r\1d×¹eÜ¿/\1a\ 5\1aêÓýoâí\8fÿbTâ°&N[õi±Ër\9f\92\11(C?>½ê\12µ±[ÅeqÌ´;6>»¦áBÿ\féÉ\83\9f\8dVübÄMÒy\bVÕ+ðóÛ=ÅäêQîûTí;é± |³²Ê\894ܼ\a\13õm°÷O\87ëÏe®\8f\9e
+\ e1|ÖªVyhH\85þÀ&nòó¦K\ 5ÚX¶Ú\8f\97\8e\9d\9f\ 5\19\86­í®\ f\91n-ì¼ÎTÂÈ»¾\86ýþFu\95\85v\9d*Yû}\ e\93ù\ 6\9c\f\90HQ\14Z[yüMgày)\1aTÖñ?´¢\87\1d\rïH\8dùÈ\83«÷Ä\iE)ÇoÙÑô\9a\86ymJP·Æþ\1f[Ûó©ßLäòÊ\15ub=ª\1ad\9e\aº¢§@-ÖÀa'ØØ¡ì×/sÑK³\8aª\ 6¶Å×.G>fÛ\ 6ú\90\v1n\8c\ 2C\85BÂóQ\95±1\7fé±äÏ\9c¾÷ò\9e½³Á~\91\8eX$e\94}\Í«\10ï^úø\80¤xÜEÂ70sü'g\¥<¬GÛ]¼Ï!\9d7xw\88T§ÖÇné+)hJqì\96\84yßÔ\bï\80ÒrV\95ëý[ÖÒÜ\8dò\e\8c\18\ eyy\91RÌ´Æ×\9d\ f\97*\8ad\ 2}'JÈ`bíÙ\8f.¿ns3}ªÝó\83Àݯ\98r´=ÁDónzîY\16öÖd\ 2WûQ/¿§zêk©9©\94Þ°âE}\95Ò\93\8a|ñÝ\85x
+âåKSG\93BTe1ý
+\ e\89íó1#ea\83ø\¼$Øv5p@õ\88«Ù\ 6\1awâØ\ 5\86\1aD¨9\14[\ f_±éÒ\7fþ}Õ\7f\9d&'ó×_\9d\88\7fýÙη­\ý\97××ÊFK\{k&\ eÔPK\8eÒ>¡FL5d\84ào'[ï¡\95¶{I\16³T\f\1a©ðiY~PØôFýræìÁðÐ\14\ 4÷r\b§Ók\86þʼÁóÍu\17ëÒF\89\16à)¹º\vü6¿·\1aúNWñJC\88\86óì7\ 57®¦\1dýííX\7fúì;Ý!ÅõáuS\ 1M\ f[':\13À1\19
+÷Pb¯c\m8\ 3Ö§\16\v<ë±]´½ 0dq\ 3÷ët#yåbZ¤\91«\89úáß\ 1½etµ
+endstream
+endobj
+2925 0 obj <<
+/Type /FontDescriptor
+/FontName /PGSODC+CMTI12
+/Flags 4
+/FontBBox [-36 -251 1103 750]
+/Ascent 694
+/CapHeight 683
+/Descent -194
+/ItalicAngle -14
+/StemV 63
+/XHeight 431
+/CharSet (/i/q)
+/FontFile 2924 0 R
+>> endobj
+2926 0 obj <<
+/Length1 787
+/Length2 1685
+/Length3 0
+/Length 2234      
+/Filter /FlateDecode
+>>
+stream
+xÚ­\92{8\94ë\1aÆ\91\8aÉ\99\94C|\88²cN\19\83É8åL,\87\8aPÓÌ7ãcÌLc\86\192R¡\10*\11©\1cCb\12¡¢-,,\87h¥"É\r¨T\ e\8bäØ\1eµºÚ»õï¾Þ\7f¾ûyî÷y\7fßý¾ºZî\9e\86V$úQÐ\8eNc\19¢à(3ÀÆÕË\11\v àH\98®®\r\13$° :m/\81\ 5\9a\ 1(SS\14`Ŧ\0(\13\0\8d2CbÍP&0]À\86Îà2!J \vØi£¿fÂ\ 2V! \13"\12h\80+\81\15\b\86\bg\10       TÀ\93N\84@\16\17\ eXQ©\80ÇÚ\8e\ 3\f\ 5\99a         \ e\0\12Dd\ 1GA
+D\83\80\1cid:\80ý^&±\19?Za 3T\b\ 5ì\14\ 3BD\12\9d\ 2$\90\fCì£\vÏ\ 2\85$ÿ\ f¨_\87Û±©Ô}\84\90µñk!ý£M\b\81¨Ü¿\rô\10\ 6\9b\ 52\ 1W:       dÒ~µ\1e\0¿³¹\82$\88\1dòk×\91E BD+\1a\85
+\ 2\86(#8Òè{\1d
\838 É\1db\11\ 3\ 12\81\1a
+~«\834Ò¯$Âð¾q Ü\ eº{99ìú~©ßzî\ 4\88Æòâ2@\0ùÓüM£~jaDL\88\ 3\1c\91H\94Ð(\?¾ü\7f\96\93 \1a\ 5@c\8c\ 1\ 2\93IàÂ\90ÂQh\f\ 6\88D\ 1\10\8d\ 4r\0\90#\ 4FÀit\96p\v \f&
+ Ó\99°µ;E!1\0\ 2Z«ý-\8d\ 1DÐO\89Ú\r \8eý\974\ 2\10Ìoò\9f?lmMçD\1a¢±\80!\1a#$@\e\9b\0X\f\7f\8cD6\93  ÒXß^\94\1f\9a\f      \93\ 6A\ eH\84õ?§\13\832ªãJx¶ù=7×ë\87ªg\16\9dî|\18[\95\89\83O¼Æ)ô2kº½@\8d\19ùXù ¨T.ý£s\19\82\bTª­\8e·Fz"bûä[¥\95ôs³<7N\12\ 2ÄÚ®·4Ê\86\=;Þ¯9¨Ù5ùRgn(ìáz¾Ë;\146Oåc\82\8bç+\7fñ\82£»\ 4ý\9b.\93tFÓaþ×\1f¸\\ 2÷¿\1dJíXü`Oϧ÷\17¶mñË\9aS\íWi\1cü3ø\95t¦iâu×u/ÂL\87\14Ð\ 5Ïu̲ùPÅoCO-\1aÒ\rÚé·\1eߨQû4ß°\7féiØÌTO}° §X÷¼é\9dÄÌ\16]ù+IG¾Fæ\88ÙCÈ¡W\88`5ß\13Ó\r£{óà\16²wVKIÕ\85\92Õ\1aª÷\bZKó3u;ºF«Òå\1c\96µ ¶\ 1ÖáÎ\88©OÏ6î´4©ð\eÅC7µÛÃ\1aó$>\97Å)u¹KÛg\ 5Èþ\19\10\12Ý|Ü\1dïÒt\96Ý\ 1KáÉ¥\83KÐD9­:Ñ\90\9eÿ\aåYýø)\99ì±ióÅ\896\8f¡mQR\83»\a\9e÷»ö\95K;\94\12O(v³óüÄWÞdz?xä\9aÍÊ\16h\86z\1du=Ï\e\ 3PI\fm,?IFsQL!:ÎÐu\ 5¶?Ü\1aS\1cÃ\7f\90\12íܱ;Fý úW\13;\ 4ùJt\86fÆ-I,.å
+\ fD*òc\18\ 4ü9Þ\16\1dß³¸áô\9c. ½FS9üÔ\99\90\9a\b¾nؼGß±cñæÝþÏ91\9c\7f×~\94³YVÛ\94ÚÏo\8cTá`-ß\ e
+F\ 5Ûä\83\92n\9fjÕZª\9d\98\97ÛZr@\86ã#Õ\87\92\ fnX)оÎ-\8c\89wkÊ\9d\96(X.\96\1a\8e.tú\17{ý¡\ 1s\8fa\1fo\85Sáh4âî\83\11\9f\ 6  ò´é\e'S/7ØfJËÌõ\aÇ\17P\8c¤\94\v\1cjGG\95ͳ½G+«jêMÞI£\ 3êP÷×/\96\9aîáÕßûà0rë\91ïö(\1d\87\eÚ\17\8bô\96\vt79YF\93vÈ^ÀßUîHÀù«ÄSã½'ô\15\ f\8c\8ctú¬{Rh|\ 33L\99/9VÑdV4\97¬úò¢º­L±qäÖa\99À=\8f?¨5pßb\aù_¥\95u\9aË{^\89\ f¦\1d¼\81\q\8cO;i±èÍðÜ<\15Èc_(\1cj«}¾\8aØC\1cS(îVú=SþHae+Ncú\99\9aéì¾ñ208ö²½\9a\95½2\19\11X{×-1­b'-_Ð[Þ\97ôÔÓô|\99ÍK\85
+»Æ\14\95\1e©\0\1a®}[Ä\84ײû|\82ürVñã´Ûö"\8a\8eâ\88\8d\81\99Ú_D7_w\bÏ({ÊqéÕ1È\12ù¬}¬\16®\17\ 6׳:¡lj\195¦þVó£A®D\1f\98Ë\ÍWyC£)\85Ï)\8fo0ð»Áy¤÷Q\ eû!7i³ûÌ®\96ó¡ëúõ½GçF)Ñ\94×lÃà¼ÃSnV¬C¾QûC\1dµc³\95\ 6\8c·æ:øÿ\11t\10o\aFÄ?±   1ÉÖ|³çÑ[ï\8f-Åç\8e/ÄØ6£.i\a¥¶>A´=®lÚÙÔ\eR!w¯2¡2\¼ú¦Î\87Å^ùK{\16®öSñùË\91¤¨íÞÛÎ9GæH¶Âbx\9d»=êÚGæß!ì_-=;ôN\14-ë´£j\ 6riM¨uÔ²Z\98®fx\eë\95¿8¹-\7fß\ e\8dU÷Ü/Þï]7¨\ 11Q×Þ}âV\97\1a\ e¦\89^Á^¶¬|\1fMo\8fQ}\9bÑÒaK'Tä\9c\9f¢Ì\8aÖøûúLæ\89,Ùî\1d2\97\1c\89Ã\14\89þµ[Â)Îñ·\86\97ÉëÇVòNîs3<Ý\84©ôp¹=%\88°\1d×6âH&ç8\97êú\93¢\8c\bI:ªú\1e\uÌìUO\ 19\8fï\8d        ãI¾I*]¬\8eůð\19"O5ÁÜ;Ös1\86É=yã%³ôøO\9f§\1d\14yÜZÒÅD´ìÜCÞÈ\ eóI4%°âò\96\82D/Xþ \99ñ°_ºÒä\9d£\1f¥_Fr\84\1c@¾«\16\10_X¤QÞWpÐK+\J1\9eÿ\85\1fÐÇC.vF\9d¹\98S\845\97ÞlÑY²K ¿ß9¤*&S|à\f7¯«KÔ|aµH*[ÕØÂò\f6\93\9a}.o\1e¾\90üÉY`dת¾Ðý,Õ\13\17Ú\9d\8e1ùÚz¨\ e\87\8a\184\94[\92J«´¬\ f\14\9bá'\9e 30y¯\1d­ v¹oü0?c\bLO\11ÈU6¬\18\H\8d¸\81z\1c5õºïZ1×ñ\1a\82\9cß\1cyÏçÀ\987í÷\8cÔ%\82Rí¤*;a˱M&¢5aY¶ÌæM\1afó.\9e\19M¬u÷g󬥶_j*iµ\8dÚ:F§â\93»]Ë'\e»¬{Wâ\92綯\947û8)´
+\fp\12\e¦ü=\8d»ÄDe\8e\10ù\92\84Ç\9f
+v\93\9e\85w\8dº2\v\9c\81\a\9eJ<°Ïe¢óê\83:¶v¡\7f¼\98}Ww³®\ enQ£SaÕ·*:½Um\95\18§^«¾ÜíS¶àÜ\90üÀ*\96í~\1f·îùÕî\97>\19/\18\ 3\9au"õ¾0\89D>þª9zÚ/\97";ò\bàÍù\96\11\9cô-Êÿ\ 3´ÆC\a
+endstream
+endobj
+2927 0 obj <<
+/Type /FontDescriptor
+/FontName /OXPTJH+CMTI7
+/Flags 4
+/FontBBox [-27 -250 1268 750]
+/Ascent 694
+/CapHeight 678
+/Descent -194
+/ItalicAngle -14
+/StemV 76
+/XHeight 431
+/CharSet (/i/j/q/r)
+/FontFile 2926 0 R
+>> endobj
+2928 0 obj <<
+/Length1 1726
+/Length2 11072
+/Length3 0
+/Length 12028     
+/Filter /FlateDecode
+>>
+stream
+xÚ­¶e\\14ì¶ÿMwK\97Cww7Ò]Ò5t\ e\9dÒ\8d4\bHIw7ÒÝÝ\12¢twû̽÷9\eÏþ¿}>Ã\8bù^«~k]1P\91©¨3\89\99;\9a\ 2¥\1d\1d\\99Ø\98Ùø\ 1\12\8a\1a\1a\06fVVq$**        \10ÐÄÕÚÑAÒÄ\15È\ f`ããc\a\889\81\0ìÜ\06V~Nvð\1f\12\15@ÂÑÉ\vdmiå
\95 ûÇ\89\a f\ f\ 4Y\9b\998\0\14M\­\80öà\1cf&v\0uG3k «\173@ÌÎ\ e öO\84\v@\rè\ 2\ 4¹\ 3Í\99\91ØØ\0æÖf®\0S ¥µ\ 3\12Ë?\9ad\1d,\1c\ 1<ÿ^6wsú_\93;\10ä\ 2\16\ 5 ý\97L:\0X¤¹£\83\9d\17À\1ch\81Ä¢ä\b®\ 6\ 4kùÿCÖ\7f'\97v³³S2±ÿ'ý¿&õÿØMì­í¼þÇÃÑÞÉÍ\15\b\ 2(:\9a\ 3A\ eÿíª\rü·8E ¹µ\9bý\7f[e]Mì¬ÍÄ\1c\80\0Ö\7f/Y»H[{\ 2ÍU¬]ͬ\0® 7à¿\96\81\ eæÿ­\ 1\7f)`ù .©ª©Äð?\9bú/£\8a\89µ\83«\86\97Ó\7f²þãý/f{cðx@Ö\9e\0=Vð|ÙÀ\8eàÏÿ~3ø¯bR\ ef\8eæÖ\ e\96\0v.n\80    \b\85\ 4>>`â\ 2ø°\ 1¬\1dÌ\81\9e\0 'X0\v³\83£+8\ 4\0\9e\89\1fÀÂ\11\84ôÏ\8ers\ 1XÄþYú7q\ 3XÄß\88\aÀ"ñF¼\0\16É7â\ 3°Hý\87xX\ 1,ÒoÄ\ 6îü\8dØ\ 1,2oÄ\ 1`\91}#N\0\8bÜ\e\81µÈ¿\11X\8bÂ\e\81µ(¾\11X\8bÒ\e\81µ(ÿ\87xÁZTÞ\b¬Eõ\8dÀZÔÞ\b¬Eý\8dÀZ4Þ\b¬Eó\8dÀZ´Þ\b¬Eû\8dÀZtÞ\b¬åã\7f\b|äYLÞ\bìiú\1fbc\a\1745\ 1½\99Á¡fÿ!.°³\99£\1dø\96ý'\80\15Ü\99ù_\bn\røæ\ f\96øï\ 3ýæ\0îÖâÍ\ 1Ü­\85µû_\11ÿ\98\1dÝ@\7f\ 5\80],ÿB°@«ÿ 'x"V^NVÀ¿\15\81׬ÿB°f»¿\10Ü\90ý\e\82o\0Ë[,\17x4\ eÖ\ eÀ¿ìà~\1cßÊ\81\83\1dÿ\8f\19,×éÍ\fn×    ü\98\r\84\13¬ÞÉÎÍåm `\1fg7GW \1dÐâm,\1c|ÿ³
+ú¿Ób\ 3wû×,ØÀ­½¥âú\87\80î\7fõÎ\ 5vw\ 1ßÑÿT\a÷ãbgâbõW
+pý·\ 2\àö\­@À¿6\0<\10W\ fÇ¿\ 2À9ÜþBð8ÝÿB°p\8f¿\8e\ f8Úó/\ 4§÷zS\ 3\ eõ\ 6\82þ\9dûÿ}\9dÄÅ\1d=}\988\ 1\1c\à+É\ 6¾4¬~ÿÇÍÌ\r\ 4\ 2:¸þëå\a¿pÿË\16Öàç\10\bô\ 4\9a!­,:\9a   \84ؤ5\85\95úKåO\97ÁÒC\8a[6Ç+ÕwÏ}G\ e^N\80´+\1a\95w¦ß¨Óy,Ïx\87\v»ûÞã\99È%ªÃWuBú,Ð9þËÂë®»ñn\86w+\91Îe\86¢×o'ò»à#ôö¦ùëc.HåÙ\8d±Òä\8f\ 5\ 3\83Gy*´\92\1a{ðëd\10=zî\r=\99!Ü<:Ò\19v\9aá¡uÔ\1cdj\18_\9cK#8Ã\7fx`$'Âü\98
+ö·     GhaX»pìpÃzÌGÈMz5\82x0\83\8b\ eb\17Ï^n\9e²\11
+Ï`"àý¡/iùð#Æ\80\10\0Q_ÔÅBe\9a\93^\15=ßæ°Ò~·Ú5½­ÞVÛã\ 51ÿü\13Ñ\94~\82`oH\81\16~\9aÏEû\ 4¾\\1aU\ræ\88_ª¹B\11ÃÖ\ 5º2X&\94\95½Xê\1a/Y$Sù\ 4È\10¬[\90FSÒ\80éý\87D~2\98´\11£)\14/uºÓ:¨Ù\ 20&¸ÕËXñC*éR²Gé\18M×W®\9f\9e\18²C\û\15«\9aãºë0\ 1á\ fæT\1a¶ââ±Ó·þ\9e_W´yGT¿¸¨\9eHq»ýiǹ²nß\8bÛú\89\1dÚ \84ü0£QO)\84.;@Ø\1efâÍ\99¡'Û·N÷ÊþDY\9aü\819\ f­Ê\ 3Ñ\12±\13\15³lV\8e\ 1§\90\ 4\84ô$\801»U\11Û\93\a\90ß\a\19B,í\94:¦{v\10ð8q®\b! H$üöêS~x¦ð\1aÃÌ!Õë,%ü\89Î)h\ eè$e\98\85y\1eG>Eí]°·8·¯£ä\95¢%\1f;<\17>8,á\8b£qè^¡ÿÔêÙã     »Æ"ç÷Tè¸X\1dætÄ­\f¹\117úT\rô³êËeÃJÐæ\9e,/\8b.ì® ¢\r¶6\90ý\1eù¾ülß:\ 3iç$´!j\8c\9c<\eÇ\94#}Dho\85ËEnuÕ\eÛ´\as^nA8_Oû÷tã3²\f\17;ùÚçç\8594\9c\876Vå\12/>æ­\8eîí"R×ú¼g~!<(ü%J©\80¡2ÔA\ 3\ 2×÷\85¯\8e1]ÆTHã4Rò]\bi£òñ_\83\v-@)áj'ò\86^ÛaÆîÊ8\86açÙ\8f9î¡\977Pþú\1ejáõh\0ë\r%Em¬½i\ e\19BõoN\fÅ\1a\8cÎpd.Ðñ¬S´Ë­\83\ 2\9a©¥\r\f\1c{+äÉr¼Î\1cÁsæQr\17Æù5ÃW<\99\ 5<\f\ eeËÚܪN\a~l/wYÉ\b
+\91Ñ`\ 5\94·\92h\8c\a¦\ 6°3\97\83¶©\90Ü\91\87×ÿxÅÑwõ_©'%~ÑW¨§¬\81\0Ñ\19õ\18\aF×p\19­+cíd~\91¡\96\82\99u>\17\8aí\9d¡O,\98\ 3p¾à®¾kq_\8e\89At \91^^úE\9cW\92\96\93      \7fÌÁ³\87Ò¾\93ïA¡\a3\94Ù¾f1IL(\16¹Ú<\99\8cRm¿:\9d\9e¸à\b¢\8b·" Æ8\15ú½æ{Ëm«°¤,&\19²>Ñ&\99ùX\99\9f\85N£­d¬Ä6¦*\80¿\13\ 1o¢ÚÛÑt =ä\8dt\\10£ãÝn\18ãN¹`Ë~\8fÜñ2ìZ¶x¨J0Rc\15v\1e3´¡\ 1±uÃ\0/#2ßvi\87£5JS÷ñ^Ê\8aÄd\9a\89¶6tä\-D1Ã(a\8a\80\f¥«\8eHsbx0Dòs¦.      e6\8e\96\19\9d\97;\1aã\10¼Á]ò\96C\ 5ãg\ f\ 4Ú`ï£Í\8bÂÃ]\17ÞQ¿ó\ 2\8fUËì\8ap[\ath\88\13Åø´]\8d\8b4\82¸e\93ãÊwQ\v\r!ß>\v>\1d\87_G|/æ;Z²l#7$Eó½YÒ\ fmØÐà\91!\82$\92×O\89\1f\vF\84ÿºÁ®ð«÷¨\1fe¶¨é\12é|\14¶%%ìHG\1c£jÎr½þ\99_GjÜ\ 3Ëþrõð\83þ\98bòá×Í£ÇZ\9er\93\ 3M½ÒA8Ã\87Ê9÷Û\13\ 5iãXw.§Öò¹ÛÄ\ 5Ø"Y\rîðrï\989/k\11çÁá\8f^¶X\aÃ\9cÛ±5Ï\10f\vPU\17·7ìJ\1dïÊE\8ex¢»2óKGs\98\ 6»\85\99È \ 6.¥(Y\ÌUò\19ÖI\13\95\88\1di\7f<óAL\9c\r%µ*U·Õ.§É¥4P\ e>,\91î\96ccwöû\aÛ\9e\r\97ñ\13ÕÄ[\8e\95o¤A.ª¸-éJtRÏÖà\b;|#·]\1fù¡ö\1c5AÉÓõhÜ\1f­\19Å\198åt\94)\83ñ#k\9dÕÎ8ø#(\81\898:aÇç©hÚETÀ\19k6¶ú|è8F÷\8c\9cüèQ§É\15tt3\19\19\1dXN\2c\9fÁä`Þw\88çM°¤\ 5Tc\83ãçýDÔw\88\93g\89\ 2¥\e$NBRec©\98\8eÈ÷\193]Ö%ÆâÏ&\1eªF±Ìð\ 5\1aùÔýy¹-\8aþScäÜÎÊo\99WQ\ 3È\99ØØ\b6Uh¹\9a4~aµ:>\ 5¦føÍ®:ÛV\9e\86\vÇS£¹¬±û?\ 2\84¦:5a\bt=\89Â\v°\0+ôÁ2NÄ\87\8eîßÎE9Ù?{\83#\83X9ðÛ\8cY±Ý\99ßi@g},ãGµUá_\90\82\853ó¹ À§\12dN\1f\9b \8bÛQ\98ÑGÏ\18\87©"\99*¬9~6xXFÅQÞ¡OÉ&¥·ÌÐ\8f\9c\9b\8b~\#Ò¶uq£RÎíÓÅ\936¶ÌÅ
+î'¶ÙàÊpd¤>Ö\1d\1fÐg+N©4`q
+¼¦@ø\ 6¿á\19úgÏA\8a\91\89ï\89ÜGÀ\væ\8fÅâÈüþ\93ÈóçÖ eçß\1eûñ¥û>^m@Îb£\99/?{´\9fèÞ\vb
+|L¸¢
+\95ÎM8fcO§ù\10µ`wH]R&á\8aÀ\89\1c)öx\9cDOÆ\95üÄ+ßP\84\13*\93õd\9dN+T®¸6©È¶o\a\ 3C+K. \ f\b¹-\12îÕ\18A\9a[\94wG\90îüÎø\ 1wYåXÛ\0ÕO\848V+\8e®\12rÃx1á&Ø®ç ñû\8d:\<\89\95\13÷W\bi×ØÛûSJhF\92<\ 3Wø®\19\9asBØ\94=ÏGÞeÙ\ 1{Íä5«ü¶\9f]\ 4û¹þO.å\8døljÖŶ\13Î\91Ô5f°Ö\1eñ=\1fX½~ª)\9b\18ó©+\vÐ~êæ
+#Ð7/ô\93\8e\9f\f\86Å\95B%j
+Ì©\19\8dËÍ®\få1\1ez0^³ãÂÕ³e8\97ò©[\97´ÒT\eÉ\93       é\1fã»î\7f¦àÇ\85©0\99\12c\19|ð-\804\ fP\98ºþÍb*¦àÉìHÇ"2EMÑ\89\97«   å\99ë¿â´\14ÏA\98\1f¾º\8c<G\9a\15¯ÐYc±@\11\ eèáã-\96N\90oó¥\8e¾ä\89ͦ\9c[ÉÕÚ;:Z(§»úð=R\ 6\7fÃgl\95¨\ 4\12/;
+¾ºa²\83\81\ 5ÿ!48ûÏb\17ª     t\eäÚÄ\98L_\98\9bQ9\89£Â\99È\ZNÄ\v¶Ïá~0nÌ®\m\81²¼bg\81@\1c\1d\8eÃ:DÍÇ;m\89Ø#\9aËj\ 4CxøQ\8bSµÊGýY\9c\¦Q\9fõÍ\17\8aÀ\94Vl~·\15\86P~ÂI\87\89æO\9c¸zQÞß·\ 2
+ìé²\1e\9e{\1dÉå\10ºly\r æ×ó\7f\8eÌ\92/µÂaxÞ\19Zâ[Ëä;\ f£@?JÇ\9e\v\0\8aÒ\ 5yÒ2\9b\ 6\83¶_Q\94\vjSõ\86\88\99ȼ\15\7f
+A\19ý\bFE\ eÖ|tú\16\17\9cG¾g\97;Ú*î®ñÅ\9f3á'IM¢\92üÐe³»Ês¶Zº\99\9fÆ
\r®ÿ¼Á£®¤éº\ 6¡\0N\90ç£E\86\ 3dòìW%\97  ÂæY»QɳX;=Ä\89/E6º\169\80\a\e=l\88\17TÍ9käÝ´\9eâä®\97÷ 4é\9f¢ù\85_¸TÃ\ 3Ä\9b\18ÓiT`c\90\ 6\8f{\1c\9dÔ\8d££\ 5ïª4\0\8anÍNk¾\82\8e§¿O`Ü9\1ah N\91\98\82T&úYÚ=¥mû\1eüÙË\ 4¬\94Ò¬ð2IÛC¸Ý=h>ª~±\93»ð,¤ÇiGíå\95¹2c\bcçY\14lû¥\13oO<\97/3\9cø¨~ïD\7f`·Å½N$ððÁ\94u\9fë,TB\94\\11\ 2n¾Þõì\99\998ãý{      ÑFc\ 6\86\89¼¢B@\15S+»$ñøFD1VÑ\15\0³G¢>r\10[\91ú§éW5ôóI\91\ f·Ý¡Üû¾)3´L\ 2ü\9eR"R\80éÉ\10Yx÷¨ãB¹T\1c˳2ö\90\1aÉ\8aå¶PèÝ\ 3e\12æ£U¾"]@yãKx\93§ö%Ü\89\84Í\1e4&b­Éã\8f@MåËiµ?\e\9ft÷wÞ%¸ºÂ\9dh¼³îm\11¦ä£Êß­ÆúH¬\8f\1fõù
+3¨Ó\e:ÅG\ 2\16Ï\ 2¢ébf\vÄ\9aú¬â2'¹¿ÓFJ\1f¹Ô\9d\¡ùa\ 2\85\84(w¢\ 3æ\92¡âdñìâç\94·dtÈÁ\ f\92\8eÊ]>¶ê\ 2\1a\11\88Ã.\ 5¿ì\1eW¹)ÑÝ\92´èAqfíõÜRÏ\85-÷e\1ca\99YÑËZѦ\0
+{¶ÑÏå\ 4©ù++Ö\ 4.Hô§!ÑRäz\19\89Í?\a¾BaVé\99\8bãà¯Ä9\9d¯±²»Ü\88\15áë6\17f÷µð~2\8e¦DMà¿I\14?ZÚU\87\9eßÍy¨Û\9d7Ø÷ÆÈ_\9e¹\9e\19\84\1aêû)f9g$t³W7ÒàV\1d@äÎx,¶²Wkª2q\²\a3BÜÏñMJÆxC~S\82t   -\9c\89ô}¯6<\88yï´\0kù(s,⨢äÞReèdP§\98é)Ê\87IAuå¸QóËÎ\91Út*JÉ\8b-\ 6Â\1f'϶|&\ 4§Ô±ó'c\9a5Þ~÷í\91\1cb\ 1Á9þ²\96»TÇ\86\1fìi\17E{q\86èUþ\9ea\1dî\9a\ei\86IrOñLf)\82\\83
+7õå\19÷}¥¾ÒCqOTS\8aé\91\94\19Ð[Á\84\89NÚÅ\9d\9fÙ1´8íZ8\98E\16ñYL£`\8eë\9f\9cÈ \1f\82a\1cXñó`ÇÕs\ 2®~\8c\ e\88:1]\ e\fëWe\11\16\99énVÈ5O\16\e+x^Ä\9bÄ\17\91ûS¾7À_\94À\90Ix¾ýÐeÑ\9d)ê¼îÂ\e>8\82"£ÑJÓJ4.7\9d\84 \ e\1du\125ÇN\82\14\186\98ú}Nâ\82¦4WU#Qóì\1c\7f\ 6)Õ1hå¶Õ^÷ã|¿c¯F³à\92n*\83±\ f¿z\9dµ3:Ý\8a]÷-\13eG      ±\94Îëݵ±+¯0\89\eËwE"\âDgN\15\14\1d\9dBø$\1c\10¿\84\1d¹\1a®í\a\8f\8de¥Q)ìý=¤\93Õ\9cê8\8fl<\ 19T\8enW\ 6(Äê\966­AÒ=Ë\ eR\ 2kÓ}\97Î
+\9b&C\96j\b\80Z\81x\vuOñêX8\87\8eõ£\9b6\ 4,;\ 5\9e$k\98RF%Ì&
+ª:[\ 2w\84/\1a}\14m5\ 5Ód¥\r¨\15\8bj¾kºì\17g×°~¦\8aÜ·\90^Ú¶\ 4ìAÙÖ\8eÙF·Û¸©µêrú¼¯;ó\1f÷¶\13lÈÙ:ÈËCiOPªðEÕÌ\ e£4\93\82Í}ó¡|\16Öbp¥f£\7fãâ¹\97Ú\bk8×\88nS\ 6^·!ùÛÂV\8d&Íÿ\81é\9f\8bÚ *òh\94£ØñH0\8bý\9d8§_3\13ï%\b]¢op\15®G6Í\8fÝ\92/öõ~Æ\b~vy§\1f˼\8b[sÝe\vs\90\84¨\ 1d?üZ\1cÄó¹¡Ü!\80\9fP\r&\81 î9\85óRÛ\8aðÒ$fÝ\83\8bÁ\1fyág7Ù\99:\bV\1a\16Ï®*2\13þÀ\11\ 1\81 \f©:\9fGHÙRÆS:
+%$\17ye2\84\86¯\96\9cß%1i\93ì×ÑÅ\17Å3\9bWÕ¼¶\15\10½Û\15\9eÍ"^æ\88\12\1c»Ò\88mß$\9d`Û     [\91)\94·P\15b\90Ú\1c£)¿{QWúû]"\ 4óÞ\8a@ÛyBxí&\9e\8aÔí{4×ë!dÍ<þ¼\8aÝ\8ep\vòá\97J\8bóo\a\8f¡è(ÎÎwÀ(}\ 6® ¿\99\1aX=þ\9bæe\1eÞ\17\1eºO\12á,­ÁZ;¼Aö¯;ì\9a\13GF\ 6$Ë%\ 3ÒÉ\98­\9aÅ©,Ë\ 4
+\8a\9f¡\19rªÎSº\9e\7fccgàxH\9aêÚèÊÖ@\ 1¶µ¾M.sz\0-WANÛå¤\7f&V½á\v\ 5\85\905R¦ç\ 4B\ 6¼´ÚÑÎ+Ûô\18\10Ü%nò\14ïÏm;\1c\9bÏ=S\vê9ú\99ìÇK5aj§·\11"\9cõø\8e3[êàVz-d¯
+±äæ²"n\91Ú\83¸yíFã»?\15H\89bnÒ`´Äº6«³.ä[Z\eï\8c­uÂå~\10¤\9a!Û¬ÅJd¼\92\88¾¦ä\8d\ 5­Úk\U#p6§Ø\13u¦Mdá0$"ºHdp",¡(i츠R«Ùúu\85WC\18\ 6lÆ"*Ky~¤bº\8eÛi§Mø\83\19æ\91\ 3\18å_ïLÎT¸û\80¦\8bi\ 1ß\91\9d¶kÏ\1f&á±+S¾T©Î\12Â\94\94ºÞ\99I´ãc=ïNH/; þëν­º¹QÉp\95"à³\9b©\98<,\92Ò²ÑÕO
+]¿ÇN©¬å\93'çaÆorÕ\1cųÕë°w\1d^
\9e8 Ýºé#¦nKç\8dÀý\9a¨\9dÌ\0½áÞ
+>\13\82P\16\95\85\12 \rÏ\fq\9a®¦\91\99ävÒ@\95äBd\1fÊIzô;(TûK`,Wû¢ú\95ÛiRç7\1cbaήtê\10å®Ø!y\1d\94Ò}7ó\9d4  (\ 3ÔÔéul³eèf\9dÀÖq¬$\8cö#\16\1e¶ \\14\835·+QÖr#
\v\871\aÓ H\82\16ÊJKVj(êÁÑ\96\ f6Øël%ñLª9dÌ4\ 5*·¯\18À\13ÉÅ$\8b¬³/8¸Õk\vÎ\9cT\8d3åÆab1\ab\ 1\9fÑåi\7f\84ê\8bÇ®+¶\akP­msí¯ ²A\7fÓ\13R\10-¯´\89?²Ü0u¨O¿hÅ8[Ùz?©\1a\90\80²\8dÀi\9d¬Uï\16       Z\18IK:mh\85hÇ2\9a\97¼Äö\Â-\96ï\17w\ e|¯ÌbzýêÕ1\93\80Ç\v×Q\8a\89,즹\11µg¼Â8ßûà\9dÞG\v\87ì\9c\15jпÖÉ\11"\17UhGõUD\9dn\98\89\807ÁkÄÜ\99°\fóè\ fãxÌwÆp~H\95\8aºüJBÒzÜ\87\90úÑ\e\15±\9dës@Z8UÜä¯\8b\ 5Ê\f'\96+¥ÃÐ\8a\1f\ 5\16»}W\15ù\ e¿\90(\8a*'à\9eî3bZ*\9eÍ>ú\feDÿ²\98\93I\1f\v_Ñé\eÚ¶?)\86\1dL#k¡ôÔ<\9fTLÞ\88¦õª\99%\ 5\9d\19ÜSý¢ÒÁ¨½óXè\r\8a©%\93ÿXäÏ\86'ɼ\e"\1c\97V\15Û«\ 3aîÉ}CÍ!\101\ 2(DD.é\88l\86>\ 3ÿzKcí-;\9d´\82oNë¯ÞO\90\17½\92hÞYe\90O]\1a_7¹\8eWYL\9eá\89/\87\1c!¾IU\85\17ÝÍFJH\95\8f»\8d!\9a\1fd\85\1c£Z\97\82¦¹§ýVo2Yx·{ e\99\15òoË\fô\82m\19\8b\129îhçÓ\90l#H÷Óo{È0\8aBpé]`:5¢,úV\17½ \13\a¹{©\8cPÂÍá}T;øPig\8f\7fÿ6(R
+\97Å\8e4\14\12\1dÅu\8aªCVR\9f oã\12¦Jì.\1aùYã£õ\95Ǿ®\88B-÷\8ffÖGÒ!©N¹\ 5L<\võ_+ô¹Á\86È~eïSOåø\ 5\89¤ò`\10\8e¿\:M3td,+Ý\97á\18\12Ö´-0}\1c\98P½Gr1¬ÿ|#\12s\9bCÖ~0o\ 1\91¸EôBz\82¢ä¶F¸¦oOæ
+'X\88ñ»óQX¬lì(4À¥GÊÈø¾\81C}×þ\87|\ 3\ 5­MGºñ´]Ëkx£\05\17\81\×»(\8b3ÖÔwbòï\92\10.\1c½N¤\830\14Uèz¤\17\83£ÊÅu̹n²*)¬&\83\1f¨h\8fR\\10»à¿\9c¸2:\12£CØÅD0\85\8eF³V{d?\8c\97%£D\98\81^íz©§\17:aGÛâ|?ê\12?\1dj\9d½ÿ\85á§3¢Ø\98
\18½<\8aEVÚ»$´\8f°\99!\14$ÿ\83\17¾1\15-xs,b¨ùÖ\94ÅXxþâ©c×c\97A@·u\18\10¶¹\86°\13Y·GY\ 2¦$\96Áíù\95ǹyÙÊùô¡Â\1fdDZ\88Ê\90§&¶X\8fô+\a\ 1\ 6O¯Àµìp\93\7f­5%ã\vÞWµ¡E|¦î²2{ã9ØųWþO\ 1\9dhB\93N×Å\96Ó?\f/¸ïT ËÐ\8e¸î=f'\f\vP7æ3ð\12\b\ e×cÇõ ,Aµ\8f\80Ø\97è\10ÛÈ_5_ø¿\vo8v\8a}KÅ=b÷MìQàû\1e\91h4\ 3OEú:K\9doÆ?8î\7fãZ-|õ"ò±\13\8a\83¢|±G\ 2qÛäú×@á6R~ÂW¾\ 3eÆÕ©9\8e\96'\82ä\83+õ|\95õ6\9cL\\ fZÇu¦Ç\1ay4½Æ$çd\9aZtÅýÚ¯\85\17\86ê»\av\9cʪñ%¾Âï\8a\11\10-\ 3~PMß÷ÓÈï[ç\a\ 6âîÐFê}¢;Ķ+0\bXÏ\&\8b\fU\r¥à;rx\91¨©\18^½@Qt*\84õ÷cC\15\16Ö<5\8b\1cø°×-ýu̾\1eE®H       E0\80:\9b\98Ne¬³\ 6^m\1d;8\8a²3\17Å\19ËFë§ï~§+*ß        üB\13\96\1f\8a\1cй@\ 2bØ®\1aóç.7ñ\bi\92v6l?\13É;\12\91â]\15y¡Ôáu\²¡5]F?qß+\8aë¾9ôMÉãVeøìæ®c\83ø\1e\0¶#hÆ´ÝÖ©¡ÊI\8b^¸Ó¶\8b+õOÿûZL5\9e\98©5Qy»2\89\r\8b¶§K\1dPµH¹Ãé9ÏÔÖÖ¬?Ú\8c\82¨A¾ÃjNhH\8d\ 4¿\95è\88¬Þ\86V\99"\ 3üu\9b\12ÜÛË%y&\7fOWâpTh7\ e6\89\ 6Mu2KÆ\8e\92\1cätòÁ\9bÚËÏò\e±kÉ÷\994~C\85E\aÉ\90æ®ñ\80\ 3\8e#D[\a踢\13\1d¾É\8e\80é\9fï\9b\ 4\15¿S®\9b\1e\1a
+\ 5MØê}Ö]w\11\9e¡¢àºµæF-\141hµ\84[\99\ 3í\19c\85%\94êÖqm{߶Ï\96U\96\14ûrªÇ
+;÷|¡Yß\93P\8c\9c\86j\1f£nS´\11¢?\99#Þñ3â\9fLè³\9bª\8eꧺ\8fü:×sDÚ8ùqã\11\ 5\rbk©úç&\8ea,¦ÅËQ\7f\1a×ê\94\95¾},Õ®\96\94õê\82ÖwÓ_ï\ 4<6[\9bûâ&-Ù?\14!÷T\ f\98\92\ 4¾üù¶\8b+Ö=\bOÞ¥§¡\984ƪ>\81\1fçÆo\12\917`îcvígÜ\r7wTõ³\87\ f\11\8aP15­\r\9b\90ÚS\88ÜL\10Ýôh±¨¨C\ 3öõ\18¶ø×È/¯Ó\9f\ 6\9fËöv\92\>\94\8eÿ\bg\9a\8a5HK¶\89\94\8a²<ÑÉÏÝ(~ÖÈ\16\ 6e&\7f   ÆÒãö.w`>°aûHÝÊ\96\81Tb¾gw\11Òâ=ÍU¯à³Ó;tà\b¡\8fo\ 6ßQÄÿ\b{\13ÁE\82î¦\ e\92P\12°ËVcÞ\88\83E§£\94\83\99Ûì\ e\8a«\92Ü\95s\80íUä±c\8cÚ\80Àø\1eÌZ_\84\ 2}OÀ\ø)F6\9cª*uE&I\82»Q»\1c\99eòêå§\ 2.ÅIÜ\v\96aV\9d\19è7\8cÜY\7f\7f\13ÚÝ=¡I\e\v²ñ\0îúð\81=lFè~âà\9fc.¥í0.|ò½Dþ¡=#\82\8d´ÈOWR\9d>ñÍ>é£\ 1º¼\vå·\835>\ 5ÏÝáßzsv\19Ca©½\8cº|Ùé\80ý:ȲMA\90\13aåæ!Îi\8f\97;®9®¢,À=Ë\9c4ýÔ\84\16ëoýØ~JcÊ\11\10-}\94Ë\1fîä*t\83x¶tÛ\88|I\19Ûç#B\10\1a¶¹;wR®|CH`JeÊæüV2ÞGܶ)\12Ô-X]ÙÀOÄ+-ë%\84\9dD\85|æUñKn4³z'J0\8bYШ`!O\8dç1Ú«ô\9a\9d\8dÂø\94\9d\9bt{H\92¶ôÚÐ\9c´\90\9eÍ\90忢ʺ(\18ú,³n\15óª¨\18\80fgÓÄǺbÅ`\e^ïô¥\85ñ\89t"\a­\17+3ADG2Ù°h@\7f2t¦-S\8dH\94\17\1d¦È;Él\87lI\89ݱÛ+ÇÞÓÀ¤¿\87\ÂV>ÈÏ\94\85(\97úkB¤g\97\952\12½\90Ù\8fô©\v\ 3÷"\94\90ÇÝ\ 4\19sM¨øb\91Å\83w\9c45\1d¡\1c*Òº;¼\13"È_ÚÅ7\19³\ f\99\ e9\ 1Ì\98\eã\b_½É       ¢-O\ 2?.\96~\94d\ 3\9c³Êµ¼(Í\10Vh\96æd¿K\86QØ¿r\ fg\8b\vf\13¥Æ?{\95¤Ë+Gû~\19í¢åÚB(\17^\9f\9dŰɤ5ÃeÐi'Øn\98ZwT-\ 3\1dN6X·q$6tÌós;,\0ã\b\90ÓhùëwÀÄ}ÜïÍ9\ fÕÞ`ï'\18\98¹¤Ód\81eµUÏ\8f¼\8d\91\1c\ f©ûD\1c\91ÎÅ\b©\8fÑK\8f\8e~\12B]ÅÏ\89\86ck¿Î¾§Aê\97p=këþÂYÑ-ä\r\88A\95¦\fVf7)ÉÎð\89o:®ýiß        \9d\9cÀh²=Òô\a¾¯ºô\19ÇO¬ÔÈ>qÝ\e56²\98Â[¤7p\9a¼\10ö¸7}\81ô\8f\ 1í÷K\¶ \ eÿ\ 6{\9dµH\1e×ø\9fFý¥*\1d\95"ïp-ª±ì¯¿\10­~E1ß\8eó\17QêØG
+G\96ÃP1Zí\15.ë2çàrÃob\ fr÷W\89ÿ\9eÊ­3\8cÔÂó;}wZ,\9ex\13\1dÆ\9eÁ«³}d8èpÍÔ\ e'q5ÀÙU\9cï\85xYÓÌ4Æ,ïý\8b\1eõöb\ 3¶ç]Á\9e\91­­De¡\1aNßYÚEµó±\1cÑÆécpFc\1e\8e\86\86Þ\96\1c\1cúv°T¥TGä
+~ÿ
+g«R-¾\1c\r\98ãµí«Y¶¡Ñ¥ÔÏ\87\83\9fUG!Òw\18\85g\82hEªÈÓîV\10ò\87zpÀ]ç\8dÄvlT´N\ 4 ÁM\r\1aâ«F+g
+\81Åw\87Ö\1e\81\92²\90ÍóÈ\ eV\90·óï­E\7f[\86ï\10\f¼\1fÏ\7f\9d/HÞyÇNº\9cÂëîÙ÷¤\15:÷´·ÐÕ@BR§üÃÇ\97¿½¦¯H\81\1c¹\97\18J1Û>ÊøÚ\99\1d23¬ÄâÖ\12à½.\9aô;\84¦Ô\ 2\89ÚçõUqE\r\vÉ¢=\9bWùÛJ\8e<\ 4\96\8e\bp°¸\97\82¦5y\93cu\92Ái\8bà0aç\11Ï þ\8b·_\9e_\1d>>t,W)q\81\ e\1cN\8d´~y\ 2KW:Ä$·u6ù\aËË\82b\12¯A\92\8b.³ï\87BñÌ\eIR²_Ó¹\eæ\b?¢{Ûzhô$ÏU¨\84\8e1\18\80Ì\b\1d÷Å\1c.>­¤û,ã¨lê[8\94ä\84\e¸xô¢^o\9cñ\fÑfñj\9aqÌu1\15|\8d¤\13øô»aK3§MÒ\1c{ç'\e¤#\94K\r³¬­Í×6¨»e8\1a\8eE&E´\98î\99¼\92ã\vcBl®\84A£lh\b\bn«`ÿ\1f7SÌ\85k¥^ø\9bf,Àà\96\ 5ª?\ 3/Ïü\ 4qÍ°\1fа\87ý
+ïBCé\1f¥\a®» î>kx\ 5¥\127ÏÙ`Öd"³\126\91\11)ÑÍ\ e¨\85ç\11ÿ\96\91e\14WÙ@ý\9aÓ Â{Å\92Dô¬\89ñK'¥% _ü»\803cg\vº\15\89\1a¥Ö^ÂñªM\87é×Þêz$\ f«$2\ 6\98hl"Ù ªEw        ö\ 2\12\8eíÛ6}rF%~Ò§].Fn}\1e\9cu6\b¹²;åÜÞ\96)bxòµÔù\rÛ³\8e\ 6_]HôrzÝ;nýÄÃVßÖ\e\8eÛy~¬Yç\ 2;M=h>NÞÏ[­\18b"=ý\1f÷ä\ e\90ÐøpM]×\1d8\a³7\8b\19\8d¨½T©\8bþ\80\ 1VZR¬ßs\8b\18B\1f\15þ¬èvO\1cÅÏ#"bc$-ì\92\1eÇ\ 5zë¬ú\8d#Z\1f,\956ÆðCÂ\ 4\v×\18d\86Ö\7fºz¥Å\8c\8eä\ f\10¨\18¦&Ön\9b0ÌG°\8d\8fH\90$ôU>ÂV#¡Ú)r\9d'ô,»!Ëì\1cD\94\17ÏñeÌQ\93ÛÑ\80ÆÃÀ1ÿ\90\99Íæ\9b\0ßrÛ ÿ{nv\ 3~ꮸ\8d­r$\18\8f*\16\8bé\1d\96×q6lâêF¦)\8a7\87Ç\98Ö°Á~¦X\16²¿é^\9d1\99ÊY\85\rÓ'ìöé/ì\12R\11ìÌNïfµb¿=\18<\8e²H\9eLÕÛÞÏeWÒ\92Ûív1\ f
+bj     \8c\9cD\ 6\82>\1eZ6«ÐÎ\1d9\1aäå\ ?¤\84\85\9a\ 2RZ$P!\ e\ 5-s¶ý\12\9a\88¦\13>e:Ù\ faÚGlx}çªÉ\ 5\90W\16¥Ó\ 4¦æ2\94fë(3ö]ÙlÞtü9·II\8dÀÍ\v®"««ëG{mÒ\99\83ÈéO\eúæäOü»S±\99\8b\96\r\ fÀÃYí)áÃÂ\8c8\91\ 2i¾0\0ï\99+\ 5\rê\8e\8e/ß|\17L\182ÙT\1f\1am\8e±\18\82÷í\94Z\9a\1c>¦£G»Z _=':w\99ïTÌ\138\7f¾%îyU¾S\9f~zÝP[morÂÍ\14\13zj\8d\18\9e5\8c\ eó\19\ 5H¨[ƪ0·µ:2ñ%0Cä\9aðÐsÂ'¼\17I*Q\\81ÚcúT¢¸\14ª\17Æ\8fg?\M\ 4T]\85gVêó\9b\1d/E¢âzÿKÃd\ 2JÃQ\ e×\1f´\17\ 6\e\ 2ÒÚÃS¢«'Qy\81\r\9b\883VÁòv&Cxxã÷I³V[aèC/\1dr\96)CD·t\81Â\16IÒÌ \88øÏ¥\99WÎ-\ 2\95ÌXçÙÀò\8c\91¤³ò¾«Ñz]ÄxA\19¬m²QÙ0\19×Þ/\8d­Ü/{|ôt\93è+\ 5s\17bHvÐÜ     ÞmÕ\ 5ñ'WÞd\17\8fb\9eWx"d\98Äñf<=ýç\99\82Aô+r+ë\bù<LZ\15\89Ƹþ\98õ3Ó¬=äO[§4(\14G\ 1
+\11Êß\ 32\95\98B\8eõR\14Ñ\8f\ 3E>[\ 2Ú\1eÅ®à/PÝÞé¤ù\v^E\ 5\e´\16U\8f\8f\93:®j\8eÖf
+\eÝÏ+\16\ 6\89£ª~j´T\ 4\9e£J½È\99Û\14\93\elsÔNu\122\ekAâvm\8e%·b\9c÷§¯\1a,9Q4\eó\ 1ó´Å\eN\ e\99\95\f\97H\4\0\8bÆ\87\85ç0t÷ÞÑýu8\9987        åSÉ,¯¨\9f7l\10n<ásÃá§pv=Ò\90F¹¸|\89\ 6ô]b([ø:s<¸z,ïÇ\95a`ÄLíûV\96S%ª\aݽ}§/;üêªs\ 2¹\82Vó­\ e´\1d50¯&o¿F\91\e\93qmêÓÙ ¢W>ªë©ÎÃ\89M\95\98ú\13\e¶ñóÈ\1c{£É\165\99\0ÍUg!Ï¢¶ã\89\9c\ 2ãøë\1a\8fö\8cÊ°\97wù³\r\15\ 5\83ù\83L\91\ 4\9e¹éÏs ñ3\r\9d\9aá\85f\19u\8e\16°\ 2÷º£ ¶\94Y)      qIã\vO;\93¯\19­ùU\10\ 2p\92Ô§V\80\81®ç\95fKÁ\93øè \19ýj*\brH÷Nî=Öj¦\80\88Í\8asØ£maDãDqî9hµ]Y\røß\13(ÓZÊBj®±ØµRR!³\18\ e\8fÑw­ZÂ\8a\e_ó81\93C\8aÛ\16K4Üu\aòß\91\83ÿ \12\85à\ 4ï誻-O\96\8aJ|(\99Ú«.Ó<3\ 1Én.áj\f\19IAÀ~³ìóÈ\ f\v\9b\\16|Íøh{8Z\86+\03!=.CBmoË\8d«¾\9ax\90±øY\ 2\81\839L\10\86®Bé]#Ç\10\95\13\91\1d"\8f\aì{\18úª\a\88Ù\ 4ox#J?Æqb(h\13Õ\9a\1e¸VÉÙ\80-+ü¨ºrÞ¡\9b\ 1Ì}ouroÄ9kºÔBÊv\11Ïp\93çß\90L\8f\9c\8a\99[Ú~xÂQÁÚ\15?Çp5Â\15ñ§Zz\10\86\19û=fN¿G+(Î\11 è¥¸ç\92Júð±\8bÀüqìiOÒ\97F\17ö<¼j \85\81µ6Û\16¶Ú÷\88\9e\9b¡\ fƽ_\84x7´£\989\\96<ÔÛ7\15è\9fúZæ\ 6JP(à\15®RYZhûð\98ÍYÁ^Òñ$Xâä\96z\8d¡îøú\1dkóã\1e\8bLßx¹R°R}»L\93G'\16\87\1a\r\99¢2ªû\17\9d\99\13&_\10j<Pÿðì°s¢ÊC\9eÿ\ee\85I\ 5\8an\84ûÉ*9\84üø
+\9b<!7fæ)]èzøç>\148þoÄGsÁ+i\86wf\ 1Çn¼]\85õ¤ÆF\8f@ùMcìüð)Øs|ä(;\ 3íÕ\19\99\8fÁ*ÃLPÚk"eΪó\ 1\1cø\9eÁ\84°~t¢Icº\18u\16T(º\ 1Ô_jªê$î> 1Éo\bgÉ£f%\æ>WÞXê\86W©l0úä\99±î\12\bDÇg7\94\b\94 \13\95.ñÝ\14\83Lã´A\12nÉ×c<ª\83\ f\8bÉ\15ó\fD*.\18xç÷ÉØ\ 4\9dçÔB÷æ/P¸c)fN#æ¹°cõ\83ïá\0\1e!¼M\r°@)!;©\ e\13\95 \87?\101м\13¸U\88~\84f_\10Ú\83VüWr%Ú\ 6´4Ùõ\f\ f\7f\bÄ¢\8bË|¥¬­6ê\1emWÔñ÷Àý\1cÉ\1eÔ\98s5ÐsèíÛ*\94\92<I\139\ 4\1fZ\cÍ\ eOår\r<\95K\0¦¦3B^Á\ 5\ eÞ\19ü\ 2\fæt\80\ 6òÐβ36úxSË
+Zx\8b\8f\1eäæc¤ÿ°ý\90\19\1864:K¢\ fy2£XO/`7KËëß\1d\11séÍ=#\bÊá\97\eoc2B<\b\1c\10U5\8fC\ 61°Ôøí6\19\84\18Ji_\9dÚ?\88#\9c£\ 3µXTQÄy~J¬n#\1eyÆñ\b\9bÀUâ<Ü&\9eüAß·Ìë½\11\18ÝÄÜ[5l²4{¿/Ãjýà>´FùÁ\ 6~6³Ê¦#÷ì%fÝ×ÿ(\85\91\aªýrIöd\8c{%ÎÀëWaøÔ/³ï\1a\9b\ 6\ 1\8cB\9a¥Ë
+;\84Áôqü\rñr      ;°\87\9d\9a8®òÝ\91¬sDp\ 3CÊ¡m\94U\93üìïW²}\11BFë\1cZ·ª\19l"9ïk\8cj}jôÍ\94! q\9b?ÍYn\93;¼n\98\8fV\92\16+\8a®¯dK¶ø\87ì¿hâò\9dæÓÚÚw\1d\ 4@\]-0xßüfK¥\84XË«`j¢É,·XS·Øï%+êdUÙ\85\eÈõM\\9e9bgo\vc|Y\12q¢mwÚ9{¨ú¨¸`hkbõþl1Å@Hoðw9      þ\\88\8aI`Ärªë\13(I\Õù[s%#\f.
+Zu-¯*\11,&!wd/\11\17\85¢«j\84\12B\88¢2è\88`\ 3\12Ca­Ð\ 6Y6Ï(ËaiÊA!qänlâ\9bµA\7f\93o­
+ñÍ\9c\92\85êu"¡õá\95S\82*MO      \ 1i©î\ 5¾µ¡zPجèÒ\92tÕäLü\1fß\90\84ê3çdw{Â¥\8dålBü¹¸¼øCär\1e]\90¬"´6&\8aµ\1af 7!âoÜê¸=ê~\8f>\88wÇ%\1a\97ßì\13æ\ 4\11Øîu]áï\14\83\92ú\9e`­£\8fï^c\vÆòñɶv\ 2oúí¦\93\14ò\92UÇë;{\99\94³\12\989\ 2r0,ae¬ú#\8cb¨µ¨\9c/³;! ¨9\16(ª²\8eÖt)wf?Y\eâ¿ÜÖà\95+ÜnN\r\99{\9dSö"Ær}\96´î!ÁQVÑfD3"ñ=:¸QH´¤\fäÉOkçr£\84Àð\89uPuà|*c\1aÙ%Q\97\19w\ f\12§nv         M3â®ætÊpþú\1dW[ÚÔv®[ª^\99èÎè\97\90ÊÐ\93\8düýÆ\1e¹DÑÌç\10©\86±÷ODø'ëÐÁ\92£[FüI\8e\90B\a!r¯&ÌHò\92\ fü\9b»\81     úcï¿M,¿[Âs3®Wç88ô>z\88·î4l ;¾ma±×Er¬½Zù\98@\96J\11Ü\9ctMA\84\8dSQ=Å0\87â\15X)dòi\v\ 28×/ê¡êºW\12{\97\b|!èþ\b1Sû©¦%:Uµ?A¹¾ç[ÔÝ:¿mxé\95yĪ¥tÊW8\ 6)C¸l3=\rÉûÀ)lj\8cs\13\9a?\892wï\8a\9f\86ÖÂ>|Vþ)\16\9aéxS¼§ÚwtENç¬e?¯\91\a'öØ\ 6å\9d}7\91ÕàâªmT\93½þÔèTÙÞ{\83ôÞ.K!8ò\f&\ 5_Pa]ÿzefiÏ\f\ 3ÊÞ\9cJln3\96\1eâFí«\9eÔ.\1e_r\1c<\97\9eyÂäÎ\18>?Ï\ 5~\eG)Ç\ 2vqìSäþ\ e\8b\88{3º\81nÑFT°Ù\9e\86÷#ãü\ 4F7i]ÁçFÂt«\13\83\ae\14áÒ¼îûz; ø\10=u%$èjF\94P_+ý°\15\1d\v°gFè\1dåùÅo©¾ý¾/\963\88¿O4AQ2G\8fõ\9bÅ\ 6'
+\87\87ÙÙP\9dN\a\83\1fgâ.Écç\9a\86\9e½/Íg|\aÑt\17¨&\\99]t¿\9e/\1f/·_\ 3¿Ó¼°û      X\15èp\1ep\13\16\87í(\94yȧU\91_t@ºë\8a²2Ûßå£\87¯Ä¤\ 3\17R
+×=C.Ì\86F\96
+CB\15\9c`\1d.äßyÆ\rÜ\99ú\r²O\86q\v4#6½?þ\94o0ÕS\19]DýP|\89ËH\17\8c\96-\81\17\8e\7f·\84\19\9few°]!Z'Cïê¿/H/]qw!%õ\8dß6a0pérB\9bP\94¦sî|s¾Èg­õr;xOû\8eZÍ?X|<­2¸?L\1fAôõC%\85¨¸Õ÷\8c/¶Äѳw\86÷ϱ\18Ý\96ÏGHï\fZ\11e£AÜÊ´\18¥\93~
+jK\83kÓ*¦\86A\99òZ\81\13b\15ï\17ðص¡²Ç¬µ\8fHݺ\16(\1f\e\1cµ'µ\88¿àR\95´\bý¢¿"\94¤\90éMØJ/TÙ\81ãmeÐÿ~\83²ñòdÏ\98A\8dÞ÷\99ÌáÎ\8dgj*?Jà+Öô1/Î\8cárã§Æqú\ fÏÞXÜά\ 2«\fõV/ZIâ\94+Vv½\ 6®&ûP\90\90û\9fYàßu²¸¡\9aïUÔÇ\85­\8dã\9f¾ty\ 4ãÂ$­ç\9dZ\ e\b:\88£\84å\15\ f8\ 5F\1db\1fK¼^ÒÇ÷öy3ÄGθÀ\8fÄúÖ.\11\98U°t2¥ûTá\vnL²f±ð\86ã\9fÆ\90D\9cúºÓ4ãË/Áþ\7fZx\9aª
+endstream
+endobj
+2929 0 obj <<
+/Type /FontDescriptor
+/FontName /GSDQUN+CMTT10
+/Flags 4
+/FontBBox [-4 -235 731 800]
+/Ascent 611
+/CapHeight 611
+/Descent -222
+/ItalicAngle 0
+/StemV 69
+/XHeight 431
+/CharSet (/A/B/C/D/E/F/G/H/I/J/K/L/M/N/O/P/Q/R/S/T/U/V/W/X/Y/a/b/bar/c/colon/d/e/eight/f/five/four/g/h/hyphen/i/l/m/n/nine/o/one/p/period/plus/quoteleft/quoteright/r/s/seven/six/slash/t/three/two/u/v/w/x/y/zero)
+/FontFile 2928 0 R
+>> endobj
+457 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /ZRGIXZ+CMBX10
+/FontDescriptor 2891 0 R
+/FirstChar 12
+/LastChar 123
+/Widths 2886 0 R
+>> endobj
+455 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /RZUIOJ+CMBX12
+/FontDescriptor 2893 0 R
+/FirstChar 11
+/LastChar 122
+/Widths 2887 0 R
+>> endobj
+1102 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /ZVAJXY+CMBX7
+/FontDescriptor 2895 0 R
+/FirstChar 68
+/LastChar 82
+/Widths 2866 0 R
+>> endobj
+1265 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /FAOYOQ+CMBXTI10
+/FontDescriptor 2897 0 R
+/FirstChar 48
+/LastChar 116
+/Widths 2865 0 R
+>> endobj
+673 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /KRVUOQ+CMCSC10
+/FontDescriptor 2899 0 R
+/FirstChar 67
+/LastChar 121
+/Widths 2877 0 R
+>> endobj
+667 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /UTSOJX+CMEX10
+/FontDescriptor 2901 0 R
+/FirstChar 4
+/LastChar 107
+/Widths 2879 0 R
+>> endobj
+573 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /QFSTYE+CMMI10
+/FontDescriptor 2903 0 R
+/FirstChar 11
+/LastChar 121
+/Widths 2882 0 R
+>> endobj
+882 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /BMVTZQ+CMMI5
+/FontDescriptor 2905 0 R
+/FirstChar 98
+/LastChar 119
+/Widths 2867 0 R
+>> endobj
+668 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /RZPZLV+CMMI7
+/FontDescriptor 2907 0 R
+/FirstChar 12
+/LastChar 121
+/Widths 2878 0 R
+>> endobj
+458 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /GPONVW+CMR10
+/FontDescriptor 2909 0 R
+/FirstChar 1
+/LastChar 124
+/Widths 2885 0 R
+>> endobj
+416 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /FEVBAK+CMR12
+/FontDescriptor 2911 0 R
+/FirstChar 44
+/LastChar 117
+/Widths 2888 0 R
+>> endobj
+415 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /VDCGVD+CMR17
+/FontDescriptor 2913 0 R
+/FirstChar 12
+/LastChar 116
+/Widths 2889 0 R
+>> endobj
+674 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /XKDASW+CMR7
+/FontDescriptor 2915 0 R
+/FirstChar 48
+/LastChar 117
+/Widths 2876 0 R
+>> endobj
+507 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /FCGMFO+CMSL10
+/FontDescriptor 2917 0 R
+/FirstChar 45
+/LastChar 89
+/Widths 2884 0 R
+>> endobj
+574 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /OQJFED+CMSY10
+/FontDescriptor 2919 0 R
+/FirstChar 0
+/LastChar 106
+/Widths 2881 0 R
+>> endobj
+705 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /ZQLTBN+CMSY7
+/FontDescriptor 2921 0 R
+/FirstChar 0
+/LastChar 48
+/Widths 2868 0 R
+>> endobj
+508 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /BMIMZO+CMTI10
+/FontDescriptor 2923 0 R
+/FirstChar 12
+/LastChar 124
+/Widths 2883 0 R
+>> endobj
+1626 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /PGSODC+CMTI12
+/FontDescriptor 2925 0 R
+/FirstChar 105
+/LastChar 113
+/Widths 2863 0 R
+>> endobj
+1276 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /OXPTJH+CMTI7
+/FontDescriptor 2927 0 R
+/FirstChar 105
+/LastChar 114
+/Widths 2864 0 R
+>> endobj
+666 0 obj <<
+/Type /Font
+/Subtype /Type1
+/BaseFont /GSDQUN+CMTT10
+/FontDescriptor 2929 0 R
+/FirstChar 39
+/LastChar 124
+/Widths 2880 0 R
+>> endobj
+417 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2930 0 R
+/Kids [410 0 R 419 0 R 453 0 R 505 0 R 538 0 R 542 0 R]
+>> endobj
+576 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2930 0 R
+/Kids [569 0 R 601 0 R 629 0 R 658 0 R 662 0 R 670 0 R]
+>> endobj
+680 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2930 0 R
+/Kids [677 0 R 682 0 R 687 0 R 693 0 R 702 0 R 710 0 R]
+>> endobj
+718 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2930 0 R
+/Kids [715 0 R 720 0 R 726 0 R 732 0 R 746 0 R 757 0 R]
+>> endobj
+775 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2930 0 R
+/Kids [772 0 R 783 0 R 802 0 R 814 0 R 820 0 R 828 0 R]
+>> endobj
+841 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2930 0 R
+/Kids [835 0 R 843 0 R 848 0 R 858 0 R 864 0 R 869 0 R]
+>> endobj
+876 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2931 0 R
+/Kids [873 0 R 878 0 R 889 0 R 905 0 R 918 0 R 929 0 R]
+>> endobj
+940 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2931 0 R
+/Kids [937 0 R 951 0 R 963 0 R 986 0 R 996 0 R 1024 0 R]
+>> endobj
+1031 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2931 0 R
+/Kids [1028 0 R 1033 0 R 1037 0 R 1041 0 R 1045 0 R 1049 0 R]
+>> endobj
+1058 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2931 0 R
+/Kids [1053 0 R 1060 0 R 1073 0 R 1081 0 R 1090 0 R 1112 0 R]
+>> endobj
+1129 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2931 0 R
+/Kids [1123 0 R 1131 0 R 1149 0 R 1166 0 R 1175 0 R 1182 0 R]
+>> endobj
+1208 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2931 0 R
+/Kids [1203 0 R 1210 0 R 1233 0 R 1261 0 R 1271 0 R 1281 0 R]
+>> endobj
+1313 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2932 0 R
+/Kids [1298 0 R 1317 0 R 1332 0 R 1341 0 R 1345 0 R 1355 0 R]
+>> endobj
+1383 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2932 0 R
+/Kids [1374 0 R 1387 0 R 1404 0 R 1421 0 R 1439 0 R 1451 0 R]
+>> endobj
+1483 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2932 0 R
+/Kids [1475 0 R 1487 0 R 1498 0 R 1520 0 R 1536 0 R 1541 0 R]
+>> endobj
+1553 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2932 0 R
+/Kids [1550 0 R 1559 0 R 1583 0 R 1602 0 R 1623 0 R 1635 0 R]
+>> endobj
+1649 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2932 0 R
+/Kids [1646 0 R 1651 0 R 1658 0 R 1667 0 R 1674 0 R 1699 0 R]
+>> endobj
+1714 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2932 0 R
+/Kids [1710 0 R 1716 0 R 1748 0 R 1784 0 R 1821 0 R 1856 0 R]
+>> endobj
+1910 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2933 0 R
+/Kids [1890 0 R 1913 0 R 1922 0 R 1948 0 R 1956 0 R 1967 0 R]
+>> endobj
+2022 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2933 0 R
+/Kids [1991 0 R 2024 0 R 2039 0 R 2050 0 R 2067 0 R 2083 0 R]
+>> endobj
+2106 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2933 0 R
+/Kids [2091 0 R 2108 0 R 2126 0 R 2146 0 R 2157 0 R 2171 0 R]
+>> endobj
+2189 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2933 0 R
+/Kids [2185 0 R 2199 0 R 2218 0 R 2251 0 R 2274 0 R 2295 0 R]
+>> endobj
+2321 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2933 0 R
+/Kids [2306 0 R 2330 0 R 2355 0 R 2359 0 R 2366 0 R 2375 0 R]
+>> endobj
+2399 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2933 0 R
+/Kids [2383 0 R 2408 0 R 2431 0 R 2454 0 R 2462 0 R 2480 0 R]
+>> endobj
+2503 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2934 0 R
+/Kids [2495 0 R 2505 0 R 2516 0 R 2539 0 R 2553 0 R 2558 0 R]
+>> endobj
+2567 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2934 0 R
+/Kids [2562 0 R 2569 0 R 2582 0 R 2598 0 R 2615 0 R 2621 0 R]
+>> endobj
+2628 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2934 0 R
+/Kids [2625 0 R 2630 0 R 2645 0 R 2649 0 R 2653 0 R 2657 0 R]
+>> endobj
+2664 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2934 0 R
+/Kids [2661 0 R 2666 0 R 2670 0 R 2674 0 R 2678 0 R 2682 0 R]
+>> endobj
+2689 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2934 0 R
+/Kids [2686 0 R 2691 0 R 2695 0 R 2699 0 R 2703 0 R 2707 0 R]
+>> endobj
+2714 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2934 0 R
+/Kids [2711 0 R 2716 0 R 2720 0 R 2724 0 R 2728 0 R 2732 0 R]
+>> endobj
+2739 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2935 0 R
+/Kids [2736 0 R 2741 0 R 2745 0 R 2749 0 R 2753 0 R 2757 0 R]
+>> endobj
+2764 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2935 0 R
+/Kids [2761 0 R 2766 0 R 2770 0 R 2774 0 R 2778 0 R 2782 0 R]
+>> endobj
+2789 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2935 0 R
+/Kids [2786 0 R 2791 0 R 2795 0 R 2799 0 R 2803 0 R 2807 0 R]
+>> endobj
+2814 0 obj <<
+/Type /Pages
+/Count 6
+/Parent 2935 0 R
+/Kids [2811 0 R 2816 0 R 2820 0 R 2824 0 R 2832 0 R 2839 0 R]
+>> endobj
+2857 0 obj <<
+/Type /Pages
+/Count 2
+/Parent 2935 0 R
+/Kids [2849 0 R 2859 0 R]
+>> endobj
+2930 0 obj <<
+/Type /Pages
+/Count 36
+/Parent 2936 0 R
+/Kids [417 0 R 576 0 R 680 0 R 718 0 R 775 0 R 841 0 R]
+>> endobj
+2931 0 obj <<
+/Type /Pages
+/Count 36
+/Parent 2936 0 R
+/Kids [876 0 R 940 0 R 1031 0 R 1058 0 R 1129 0 R 1208 0 R]
+>> endobj
+2932 0 obj <<
+/Type /Pages
+/Count 36
+/Parent 2936 0 R
+/Kids [1313 0 R 1383 0 R 1483 0 R 1553 0 R 1649 0 R 1714 0 R]
+>> endobj
+2933 0 obj <<
+/Type /Pages
+/Count 36
+/Parent 2936 0 R
+/Kids [1910 0 R 2022 0 R 2106 0 R 2189 0 R 2321 0 R 2399 0 R]
+>> endobj
+2934 0 obj <<
+/Type /Pages
+/Count 36
+/Parent 2936 0 R
+/Kids [2503 0 R 2567 0 R 2628 0 R 2664 0 R 2689 0 R 2714 0 R]
+>> endobj
+2935 0 obj <<
+/Type /Pages
+/Count 26
+/Parent 2936 0 R
+/Kids [2739 0 R 2764 0 R 2789 0 R 2814 0 R 2857 0 R]
+>> endobj
+2936 0 obj <<
+/Type /Pages
+/Count 206
+/Kids [2930 0 R 2931 0 R 2932 0 R 2933 0 R 2934 0 R 2935 0 R]
+>> endobj
+2937 0 obj <<
+/Type /Outlines
+/First 7 0 R
+/Last 407 0 R
+/Count 10
+>> endobj
+407 0 obj <<
+/Title 408 0 R
+/A 405 0 R
+/Parent 2937 0 R
+/Prev 387 0 R
+>> endobj
+403 0 obj <<
+/Title 404 0 R
+/A 401 0 R
+/Parent 387 0 R
+/Prev 399 0 R
+>> endobj
+399 0 obj <<
+/Title 400 0 R
+/A 397 0 R
+/Parent 387 0 R
+/Prev 395 0 R
+/Next 403 0 R
+>> endobj
+395 0 obj <<
+/Title 396 0 R
+/A 393 0 R
+/Parent 387 0 R
+/Prev 391 0 R
+/Next 399 0 R
+>> endobj
+391 0 obj <<
+/Title 392 0 R
+/A 389 0 R
+/Parent 387 0 R
+/Next 395 0 R
+>> endobj
+387 0 obj <<
+/Title 388 0 R
+/A 385 0 R
+/Parent 2937 0 R
+/Prev 347 0 R
+/Next 407 0 R
+/First 391 0 R
+/Last 403 0 R
+/Count -4
+>> endobj
+383 0 obj <<
+/Title 384 0 R
+/A 381 0 R
+/Parent 375 0 R
+/Prev 379 0 R
+>> endobj
+379 0 obj <<
+/Title 380 0 R
+/A 377 0 R
+/Parent 375 0 R
+/Next 383 0 R
+>> endobj
+375 0 obj <<
+/Title 376 0 R
+/A 373 0 R
+/Parent 347 0 R
+/Prev 359 0 R
+/First 379 0 R
+/Last 383 0 R
+/Count -2
+>> endobj
+371 0 obj <<
+/Title 372 0 R
+/A 369 0 R
+/Parent 359 0 R
+/Prev 367 0 R
+>> endobj
+367 0 obj <<
+/Title 368 0 R
+/A 365 0 R
+/Parent 359 0 R
+/Prev 363 0 R
+/Next 371 0 R
+>> endobj
+363 0 obj <<
+/Title 364 0 R
+/A 361 0 R
+/Parent 359 0 R
+/Next 367 0 R
+>> endobj
+359 0 obj <<
+/Title 360 0 R
+/A 357 0 R
+/Parent 347 0 R
+/Prev 351 0 R
+/Next 375 0 R
+/First 363 0 R
+/Last 371 0 R
+/Count -3
+>> endobj
+355 0 obj <<
+/Title 356 0 R
+/A 353 0 R
+/Parent 351 0 R
+>> endobj
+351 0 obj <<
+/Title 352 0 R
+/A 349 0 R
+/Parent 347 0 R
+/Next 359 0 R
+/First 355 0 R
+/Last 355 0 R
+/Count -1
+>> endobj
+347 0 obj <<
+/Title 348 0 R
+/A 345 0 R
+/Parent 2937 0 R
+/Prev 235 0 R
+/Next 387 0 R
+/First 351 0 R
+/Last 375 0 R
+/Count -3
+>> endobj
+343 0 obj <<
+/Title 344 0 R
+/A 341 0 R
+/Parent 235 0 R
+/Prev 327 0 R
+>> endobj
+339 0 obj <<
+/Title 340 0 R
+/A 337 0 R
+/Parent 327 0 R
+/Prev 335 0 R
+>> endobj
+335 0 obj <<
+/Title 336 0 R
+/A 333 0 R
+/Parent 327 0 R
+/Prev 331 0 R
+/Next 339 0 R
+>> endobj
+331 0 obj <<
+/Title 332 0 R
+/A 329 0 R
+/Parent 327 0 R
+/Next 335 0 R
+>> endobj
+327 0 obj <<
+/Title 328 0 R
+/A 325 0 R
+/Parent 235 0 R
+/Prev 307 0 R
+/Next 343 0 R
+/First 331 0 R
+/Last 339 0 R
+/Count -3
+>> endobj
+323 0 obj <<
+/Title 324 0 R
+/A 321 0 R
+/Parent 307 0 R
+/Prev 319 0 R
+>> endobj
+319 0 obj <<
+/Title 320 0 R
+/A 317 0 R
+/Parent 307 0 R
+/Prev 315 0 R
+/Next 323 0 R
+>> endobj
+315 0 obj <<
+/Title 316 0 R
+/A 313 0 R
+/Parent 307 0 R
+/Prev 311 0 R
+/Next 319 0 R
+>> endobj
+311 0 obj <<
+/Title 312 0 R
+/A 309 0 R
+/Parent 307 0 R
+/Next 315 0 R
+>> endobj
+307 0 obj <<
+/Title 308 0 R
+/A 305 0 R
+/Parent 235 0 R
+/Prev 295 0 R
+/Next 327 0 R
+/First 311 0 R
+/Last 323 0 R
+/Count -4
+>> endobj
+303 0 obj <<
+/Title 304 0 R
+/A 301 0 R
+/Parent 295 0 R
+/Prev 299 0 R
+>> endobj
+299 0 obj <<
+/Title 300 0 R
+/A 297 0 R
+/Parent 295 0 R
+/Next 303 0 R
+>> endobj
+295 0 obj <<
+/Title 296 0 R
+/A 293 0 R
+/Parent 235 0 R
+/Prev 279 0 R
+/Next 307 0 R
+/First 299 0 R
+/Last 303 0 R
+/Count -2
+>> endobj
+291 0 obj <<
+/Title 292 0 R
+/A 289 0 R
+/Parent 279 0 R
+/Prev 287 0 R
+>> endobj
+287 0 obj <<
+/Title 288 0 R
+/A 285 0 R
+/Parent 279 0 R
+/Prev 283 0 R
+/Next 291 0 R
+>> endobj
+283 0 obj <<
+/Title 284 0 R
+/A 281 0 R
+/Parent 279 0 R
+/Next 287 0 R
+>> endobj
+279 0 obj <<
+/Title 280 0 R
+/A 277 0 R
+/Parent 235 0 R
+/Prev 275 0 R
+/Next 295 0 R
+/First 283 0 R
+/Last 291 0 R
+/Count -3
+>> endobj
+275 0 obj <<
+/Title 276 0 R
+/A 273 0 R
+/Parent 235 0 R
+/Prev 263 0 R
+/Next 279 0 R
+>> endobj
+271 0 obj <<
+/Title 272 0 R
+/A 269 0 R
+/Parent 263 0 R
+/Prev 267 0 R
+>> endobj
+267 0 obj <<
+/Title 268 0 R
+/A 265 0 R
+/Parent 263 0 R
+/Next 271 0 R
+>> endobj
+263 0 obj <<
+/Title 264 0 R
+/A 261 0 R
+/Parent 235 0 R
+/Prev 259 0 R
+/Next 275 0 R
+/First 267 0 R
+/Last 271 0 R
+/Count -2
+>> endobj
+259 0 obj <<
+/Title 260 0 R
+/A 257 0 R
+/Parent 235 0 R
+/Prev 255 0 R
+/Next 263 0 R
+>> endobj
+255 0 obj <<
+/Title 256 0 R
+/A 253 0 R
+/Parent 235 0 R
+/Prev 243 0 R
+/Next 259 0 R
+>> endobj
+251 0 obj <<
+/Title 252 0 R
+/A 249 0 R
+/Parent 243 0 R
+/Prev 247 0 R
+>> endobj
+247 0 obj <<
+/Title 248 0 R
+/A 245 0 R
+/Parent 243 0 R
+/Next 251 0 R
+>> endobj
+243 0 obj <<
+/Title 244 0 R
+/A 241 0 R
+/Parent 235 0 R
+/Prev 239 0 R
+/Next 255 0 R
+/First 247 0 R
+/Last 251 0 R
+/Count -2
+>> endobj
+239 0 obj <<
+/Title 240 0 R
+/A 237 0 R
+/Parent 235 0 R
+/Next 243 0 R
+>> endobj
+235 0 obj <<
+/Title 236 0 R
+/A 233 0 R
+/Parent 2937 0 R
+/Prev 183 0 R
+/Next 347 0 R
+/First 239 0 R
+/Last 343 0 R
+/Count -11
+>> endobj
+231 0 obj <<
+/Title 232 0 R
+/A 229 0 R
+/Parent 211 0 R
+/Prev 227 0 R
+>> endobj
+227 0 obj <<
+/Title 228 0 R
+/A 225 0 R
+/Parent 211 0 R
+/Prev 223 0 R
+/Next 231 0 R
+>> endobj
+223 0 obj <<
+/Title 224 0 R
+/A 221 0 R
+/Parent 211 0 R
+/Prev 219 0 R
+/Next 227 0 R
+>> endobj
+219 0 obj <<
+/Title 220 0 R
+/A 217 0 R
+/Parent 211 0 R
+/Prev 215 0 R
+/Next 223 0 R
+>> endobj
+215 0 obj <<
+/Title 216 0 R
+/A 213 0 R
+/Parent 211 0 R
+/Next 219 0 R
+>> endobj
+211 0 obj <<
+/Title 212 0 R
+/A 209 0 R
+/Parent 183 0 R
+/Prev 195 0 R
+/First 215 0 R
+/Last 231 0 R
+/Count -5
+>> endobj
+207 0 obj <<
+/Title 208 0 R
+/A 205 0 R
+/Parent 195 0 R
+/Prev 203 0 R
+>> endobj
+203 0 obj <<
+/Title 204 0 R
+/A 201 0 R
+/Parent 195 0 R
+/Prev 199 0 R
+/Next 207 0 R
+>> endobj
+199 0 obj <<
+/Title 200 0 R
+/A 197 0 R
+/Parent 195 0 R
+/Next 203 0 R
+>> endobj
+195 0 obj <<
+/Title 196 0 R
+/A 193 0 R
+/Parent 183 0 R
+/Prev 191 0 R
+/Next 211 0 R
+/First 199 0 R
+/Last 207 0 R
+/Count -3
+>> endobj
+191 0 obj <<
+/Title 192 0 R
+/A 189 0 R
+/Parent 183 0 R
+/Prev 187 0 R
+/Next 195 0 R
+>> endobj
+187 0 obj <<
+/Title 188 0 R
+/A 185 0 R
+/Parent 183 0 R
+/Next 191 0 R
+>> endobj
+183 0 obj <<
+/Title 184 0 R
+/A 181 0 R
+/Parent 2937 0 R
+/Prev 139 0 R
+/Next 235 0 R
+/First 187 0 R
+/Last 211 0 R
+/Count -4
+>> endobj
+179 0 obj <<
+/Title 180 0 R
+/A 177 0 R
+/Parent 159 0 R
+/Prev 175 0 R
+>> endobj
+175 0 obj <<
+/Title 176 0 R
+/A 173 0 R
+/Parent 159 0 R
+/Prev 171 0 R
+/Next 179 0 R
+>> endobj
+171 0 obj <<
+/Title 172 0 R
+/A 169 0 R
+/Parent 159 0 R
+/Prev 167 0 R
+/Next 175 0 R
+>> endobj
+167 0 obj <<
+/Title 168 0 R
+/A 165 0 R
+/Parent 159 0 R
+/Prev 163 0 R
+/Next 171 0 R
+>> endobj
+163 0 obj <<
+/Title 164 0 R
+/A 161 0 R
+/Parent 159 0 R
+/Next 167 0 R
+>> endobj
+159 0 obj <<
+/Title 160 0 R
+/A 157 0 R
+/Parent 139 0 R
+/Prev 143 0 R
+/First 163 0 R
+/Last 179 0 R
+/Count -5
+>> endobj
+155 0 obj <<
+/Title 156 0 R
+/A 153 0 R
+/Parent 143 0 R
+/Prev 151 0 R
+>> endobj
+151 0 obj <<
+/Title 152 0 R
+/A 149 0 R
+/Parent 143 0 R
+/Prev 147 0 R
+/Next 155 0 R
+>> endobj
+147 0 obj <<
+/Title 148 0 R
+/A 145 0 R
+/Parent 143 0 R
+/Next 151 0 R
+>> endobj
+143 0 obj <<
+/Title 144 0 R
+/A 141 0 R
+/Parent 139 0 R
+/Next 159 0 R
+/First 147 0 R
+/Last 155 0 R
+/Count -3
+>> endobj
+139 0 obj <<
+/Title 140 0 R
+/A 137 0 R
+/Parent 2937 0 R
+/Prev 95 0 R
+/Next 183 0 R
+/First 143 0 R
+/Last 159 0 R
+/Count -2
+>> endobj
+135 0 obj <<
+/Title 136 0 R
+/A 133 0 R
+/Parent 119 0 R
+/Prev 131 0 R
+>> endobj
+131 0 obj <<
+/Title 132 0 R
+/A 129 0 R
+/Parent 119 0 R
+/Prev 127 0 R
+/Next 135 0 R
+>> endobj
+127 0 obj <<
+/Title 128 0 R
+/A 125 0 R
+/Parent 119 0 R
+/Prev 123 0 R
+/Next 131 0 R
+>> endobj
+123 0 obj <<
+/Title 124 0 R
+/A 121 0 R
+/Parent 119 0 R
+/Next 127 0 R
+>> endobj
+119 0 obj <<
+/Title 120 0 R
+/A 117 0 R
+/Parent 95 0 R
+/Prev 107 0 R
+/First 123 0 R
+/Last 135 0 R
+/Count -4
+>> endobj
+115 0 obj <<
+/Title 116 0 R
+/A 113 0 R
+/Parent 107 0 R
+/Prev 111 0 R
+>> endobj
+111 0 obj <<
+/Title 112 0 R
+/A 109 0 R
+/Parent 107 0 R
+/Next 115 0 R
+>> endobj
+107 0 obj <<
+/Title 108 0 R
+/A 105 0 R
+/Parent 95 0 R
+/Prev 103 0 R
+/Next 119 0 R
+/First 111 0 R
+/Last 115 0 R
+/Count -2
+>> endobj
+103 0 obj <<
+/Title 104 0 R
+/A 101 0 R
+/Parent 95 0 R
+/Prev 99 0 R
+/Next 107 0 R
+>> endobj
+99 0 obj <<
+/Title 100 0 R
+/A 97 0 R
+/Parent 95 0 R
+/Next 103 0 R
+>> endobj
+95 0 obj <<
+/Title 96 0 R
+/A 93 0 R
+/Parent 2937 0 R
+/Prev 63 0 R
+/Next 139 0 R
+/First 99 0 R
+/Last 119 0 R
+/Count -4
+>> endobj
+91 0 obj <<
+/Title 92 0 R
+/A 89 0 R
+/Parent 83 0 R
+/Prev 87 0 R
+>> endobj
+87 0 obj <<
+/Title 88 0 R
+/A 85 0 R
+/Parent 83 0 R
+/Next 91 0 R
+>> endobj
+83 0 obj <<
+/Title 84 0 R
+/A 81 0 R
+/Parent 63 0 R
+/Prev 67 0 R
+/First 87 0 R
+/Last 91 0 R
+/Count -2
+>> endobj
+79 0 obj <<
+/Title 80 0 R
+/A 77 0 R
+/Parent 67 0 R
+/Prev 75 0 R
+>> endobj
+75 0 obj <<
+/Title 76 0 R
+/A 73 0 R
+/Parent 67 0 R
+/Prev 71 0 R
+/Next 79 0 R
+>> endobj
+71 0 obj <<
+/Title 72 0 R
+/A 69 0 R
+/Parent 67 0 R
+/Next 75 0 R
+>> endobj
+67 0 obj <<
+/Title 68 0 R
+/A 65 0 R
+/Parent 63 0 R
+/Next 83 0 R
+/First 71 0 R
+/Last 79 0 R
+/Count -3
+>> endobj
+63 0 obj <<
+/Title 64 0 R
+/A 61 0 R
+/Parent 2937 0 R
+/Prev 35 0 R
+/Next 95 0 R
+/First 67 0 R
+/Last 83 0 R
+/Count -2
+>> endobj
+59 0 obj <<
+/Title 60 0 R
+/A 57 0 R
+/Parent 35 0 R
+/Prev 55 0 R
+>> endobj
+55 0 obj <<
+/Title 56 0 R
+/A 53 0 R
+/Parent 35 0 R
+/Prev 51 0 R
+/Next 59 0 R
+>> endobj
+51 0 obj <<
+/Title 52 0 R
+/A 49 0 R
+/Parent 35 0 R
+/Prev 47 0 R
+/Next 55 0 R
+>> endobj
+47 0 obj <<
+/Title 48 0 R
+/A 45 0 R
+/Parent 35 0 R
+/Prev 43 0 R
+/Next 51 0 R
+>> endobj
+43 0 obj <<
+/Title 44 0 R
+/A 41 0 R
+/Parent 35 0 R
+/Prev 39 0 R
+/Next 47 0 R
+>> endobj
+39 0 obj <<
+/Title 40 0 R
+/A 37 0 R
+/Parent 35 0 R
+/Next 43 0 R
+>> endobj
+35 0 obj <<
+/Title 36 0 R
+/A 33 0 R
+/Parent 2937 0 R
+/Prev 7 0 R
+/Next 63 0 R
+/First 39 0 R
+/Last 59 0 R
+/Count -6
+>> endobj
+31 0 obj <<
+/Title 32 0 R
+/A 29 0 R
+/Parent 7 0 R
+/Prev 27 0 R
+>> endobj
+27 0 obj <<
+/Title 28 0 R
+/A 25 0 R
+/Parent 7 0 R
+/Prev 23 0 R
+/Next 31 0 R
+>> endobj
+23 0 obj <<
+/Title 24 0 R
+/A 21 0 R
+/Parent 7 0 R
+/Prev 19 0 R
+/Next 27 0 R
+>> endobj
+19 0 obj <<
+/Title 20 0 R
+/A 17 0 R
+/Parent 7 0 R
+/Prev 15 0 R
+/Next 23 0 R
+>> endobj
+15 0 obj <<
+/Title 16 0 R
+/A 13 0 R
+/Parent 7 0 R
+/Prev 11 0 R
+/Next 19 0 R
+>> endobj
+11 0 obj <<
+/Title 12 0 R
+/A 9 0 R
+/Parent 7 0 R
+/Next 15 0 R
+>> endobj
+7 0 obj <<
+/Title 8 0 R
+/A 5 0 R
+/Parent 2937 0 R
+/Next 35 0 R
+/First 11 0 R
+/Last 31 0 R
+/Count -6
+>> endobj
+2938 0 obj <<
+/Names [(Doc-Start) 414 0 R (Item.1) 1066 0 R (Item.10) 1097 0 R (Item.100) 1321 0 R (Item.101) 1322 0 R (Item.102) 1336 0 R]
+/Limits [(Doc-Start) (Item.102)]
+>> endobj
+2939 0 obj <<
+/Names [(Item.103) 1337 0 R (Item.104) 1338 0 R (Item.105) 1339 0 R (Item.106) 1358 0 R (Item.107) 1359 0 R (Item.108) 1360 0 R]
+/Limits [(Item.103) (Item.108)]
+>> endobj
+2940 0 obj <<
+/Names [(Item.109) 1361 0 R (Item.11) 1098 0 R (Item.110) 1362 0 R (Item.111) 1363 0 R (Item.112) 1364 0 R (Item.113) 1365 0 R]
+/Limits [(Item.109) (Item.113)]
+>> endobj
+2941 0 obj <<
+/Names [(Item.114) 1366 0 R (Item.115) 1367 0 R (Item.116) 1368 0 R (Item.117) 1369 0 R (Item.118) 1370 0 R (Item.119) 1390 0 R]
+/Limits [(Item.114) (Item.119)]
+>> endobj
+2942 0 obj <<
+/Names [(Item.12) 1099 0 R (Item.120) 1391 0 R (Item.121) 1392 0 R (Item.122) 1393 0 R (Item.123) 1394 0 R (Item.124) 1395 0 R]
+/Limits [(Item.12) (Item.124)]
+>> endobj
+2943 0 obj <<
+/Names [(Item.125) 1396 0 R (Item.126) 1397 0 R (Item.127) 1398 0 R (Item.128) 1399 0 R (Item.129) 1400 0 R (Item.13) 1100 0 R]
+/Limits [(Item.125) (Item.13)]
+>> endobj
+2944 0 obj <<
+/Names [(Item.130) 1407 0 R (Item.131) 1408 0 R (Item.132) 1409 0 R (Item.133) 1424 0 R (Item.134) 1425 0 R (Item.135) 1426 0 R]
+/Limits [(Item.130) (Item.135)]
+>> endobj
+2945 0 obj <<
+/Names [(Item.136) 1427 0 R (Item.137) 1428 0 R (Item.138) 1429 0 R (Item.139) 1430 0 R (Item.14) 1101 0 R (Item.140) 1431 0 R]
+/Limits [(Item.136) (Item.140)]
+>> endobj
+2946 0 obj <<
+/Names [(Item.141) 1432 0 R (Item.142) 1433 0 R (Item.143) 1434 0 R (Item.144) 1435 0 R (Item.145) 1436 0 R (Item.146) 1454 0 R]
+/Limits [(Item.141) (Item.146)]
+>> endobj
+2947 0 obj <<
+/Names [(Item.147) 1455 0 R (Item.148) 1456 0 R (Item.149) 1457 0 R (Item.15) 1103 0 R (Item.150) 1458 0 R (Item.151) 1459 0 R]
+/Limits [(Item.147) (Item.151)]
+>> endobj
+2948 0 obj <<
+/Names [(Item.152) 1460 0 R (Item.153) 1461 0 R (Item.154) 1462 0 R (Item.155) 1463 0 R (Item.156) 1464 0 R (Item.157) 1465 0 R]
+/Limits [(Item.152) (Item.157)]
+>> endobj
+2949 0 obj <<
+/Names [(Item.158) 1466 0 R (Item.159) 1467 0 R (Item.16) 1104 0 R (Item.160) 1468 0 R (Item.161) 1490 0 R (Item.162) 1491 0 R]
+/Limits [(Item.158) (Item.162)]
+>> endobj
+2950 0 obj <<
+/Names [(Item.163) 1492 0 R (Item.164) 1493 0 R (Item.165) 1501 0 R (Item.166) 1502 0 R (Item.167) 1503 0 R (Item.168) 1504 0 R]
+/Limits [(Item.163) (Item.168)]
+>> endobj
+2951 0 obj <<
+/Names [(Item.169) 1505 0 R (Item.17) 1115 0 R (Item.170) 1506 0 R (Item.171) 1507 0 R (Item.172) 1508 0 R (Item.173) 1509 0 R]
+/Limits [(Item.169) (Item.173)]
+>> endobj
+2952 0 obj <<
+/Names [(Item.174) 1510 0 R (Item.175) 1525 0 R (Item.176) 1526 0 R (Item.177) 1527 0 R (Item.178) 1528 0 R (Item.179) 1529 0 R]
+/Limits [(Item.174) (Item.179)]
+>> endobj
+2953 0 obj <<
+/Names [(Item.18) 1116 0 R (Item.180) 1530 0 R (Item.181) 1531 0 R (Item.182) 1532 0 R (Item.183) 1533 0 R (Item.184) 1534 0 R]
+/Limits [(Item.18) (Item.184)]
+>> endobj
+2954 0 obj <<
+/Names [(Item.185) 1562 0 R (Item.186) 1563 0 R (Item.187) 1564 0 R (Item.188) 1565 0 R (Item.189) 1566 0 R (Item.19) 1117 0 R]
+/Limits [(Item.185) (Item.19)]
+>> endobj
+2955 0 obj <<
+/Names [(Item.190) 1567 0 R (Item.191) 1568 0 R (Item.192) 1569 0 R (Item.193) 1570 0 R (Item.194) 1571 0 R (Item.195) 1572 0 R]
+/Limits [(Item.190) (Item.195)]
+>> endobj
+2956 0 obj <<
+/Names [(Item.196) 1573 0 R (Item.197) 1574 0 R (Item.198) 1575 0 R (Item.199) 1576 0 R (Item.2) 1067 0 R (Item.20) 1118 0 R]
+/Limits [(Item.196) (Item.20)]
+>> endobj
+2957 0 obj <<
+/Names [(Item.200) 1577 0 R (Item.201) 1578 0 R (Item.202) 1579 0 R (Item.203) 1580 0 R (Item.204) 1581 0 R (Item.205) 1586 0 R]
+/Limits [(Item.200) (Item.205)]
+>> endobj
+2958 0 obj <<
+/Names [(Item.206) 1587 0 R (Item.207) 1588 0 R (Item.208) 1589 0 R (Item.209) 1590 0 R (Item.21) 1119 0 R (Item.210) 1591 0 R]
+/Limits [(Item.206) (Item.210)]
+>> endobj
+2959 0 obj <<
+/Names [(Item.211) 1592 0 R (Item.212) 1593 0 R (Item.213) 1594 0 R (Item.214) 1595 0 R (Item.215) 1596 0 R (Item.216) 1597 0 R]
+/Limits [(Item.211) (Item.216)]
+>> endobj
+2960 0 obj <<
+/Names [(Item.217) 1598 0 R (Item.218) 1605 0 R (Item.219) 1606 0 R (Item.22) 1120 0 R (Item.220) 1607 0 R (Item.221) 1608 0 R]
+/Limits [(Item.217) (Item.221)]
+>> endobj
+2961 0 obj <<
+/Names [(Item.222) 1609 0 R (Item.223) 1610 0 R (Item.224) 1611 0 R (Item.225) 1612 0 R (Item.226) 1613 0 R (Item.227) 1614 0 R]
+/Limits [(Item.222) (Item.227)]
+>> endobj
+2962 0 obj <<
+/Names [(Item.228) 1615 0 R (Item.229) 1616 0 R (Item.23) 1121 0 R (Item.230) 1617 0 R (Item.231) 1618 0 R (Item.232) 1619 0 R]
+/Limits [(Item.228) (Item.232)]
+>> endobj
+2963 0 obj <<
+/Names [(Item.233) 1620 0 R (Item.234) 1638 0 R (Item.235) 1639 0 R (Item.236) 1640 0 R (Item.237) 1641 0 R (Item.238) 1642 0 R]
+/Limits [(Item.233) (Item.238)]
+>> endobj
+2964 0 obj <<
+/Names [(Item.239) 1643 0 R (Item.24) 1126 0 R (Item.240) 1677 0 R (Item.241) 1678 0 R (Item.242) 1679 0 R (Item.243) 1680 0 R]
+/Limits [(Item.239) (Item.243)]
+>> endobj
+2965 0 obj <<
+/Names [(Item.244) 1681 0 R (Item.245) 1682 0 R (Item.246) 1683 0 R (Item.247) 1684 0 R (Item.248) 1685 0 R (Item.249) 1686 0 R]
+/Limits [(Item.244) (Item.249)]
+>> endobj
+2966 0 obj <<
+/Names [(Item.25) 1127 0 R (Item.250) 1687 0 R (Item.251) 1688 0 R (Item.252) 1689 0 R (Item.253) 1690 0 R (Item.254) 1691 0 R]
+/Limits [(Item.25) (Item.254)]
+>> endobj
+2967 0 obj <<
+/Names [(Item.255) 1692 0 R (Item.256) 1693 0 R (Item.257) 1694 0 R (Item.258) 1695 0 R (Item.259) 1719 0 R (Item.26) 1139 0 R]
+/Limits [(Item.255) (Item.26)]
+>> endobj
+2968 0 obj <<
+/Names [(Item.260) 1720 0 R (Item.261) 1721 0 R (Item.262) 1722 0 R (Item.263) 1723 0 R (Item.264) 1724 0 R (Item.265) 1725 0 R]
+/Limits [(Item.260) (Item.265)]
+>> endobj
+2969 0 obj <<
+/Names [(Item.266) 1726 0 R (Item.267) 1727 0 R (Item.268) 1728 0 R (Item.269) 1729 0 R (Item.27) 1140 0 R (Item.270) 1730 0 R]
+/Limits [(Item.266) (Item.270)]
+>> endobj
+2970 0 obj <<
+/Names [(Item.271) 1731 0 R (Item.272) 1732 0 R (Item.273) 1733 0 R (Item.274) 1734 0 R (Item.275) 1735 0 R (Item.276) 1736 0 R]
+/Limits [(Item.271) (Item.276)]
+>> endobj
+2971 0 obj <<
+/Names [(Item.277) 1737 0 R (Item.278) 1738 0 R (Item.279) 1739 0 R (Item.28) 1141 0 R (Item.280) 1740 0 R (Item.281) 1741 0 R]
+/Limits [(Item.277) (Item.281)]
+>> endobj
+2972 0 obj <<
+/Names [(Item.282) 1742 0 R (Item.283) 1743 0 R (Item.284) 1744 0 R (Item.285) 1745 0 R (Item.286) 1746 0 R (Item.287) 1751 0 R]
+/Limits [(Item.282) (Item.287)]
+>> endobj
+2973 0 obj <<
+/Names [(Item.288) 1752 0 R (Item.289) 1753 0 R (Item.29) 1142 0 R (Item.290) 1754 0 R (Item.291) 1755 0 R (Item.292) 1756 0 R]
+/Limits [(Item.288) (Item.292)]
+>> endobj
+2974 0 obj <<
+/Names [(Item.293) 1757 0 R (Item.294) 1758 0 R (Item.295) 1759 0 R (Item.296) 1760 0 R (Item.297) 1761 0 R (Item.298) 1762 0 R]
+/Limits [(Item.293) (Item.298)]
+>> endobj
+2975 0 obj <<
+/Names [(Item.299) 1763 0 R (Item.3) 1077 0 R (Item.30) 1143 0 R (Item.300) 1764 0 R (Item.301) 1765 0 R (Item.302) 1766 0 R]
+/Limits [(Item.299) (Item.302)]
+>> endobj
+2976 0 obj <<
+/Names [(Item.303) 1767 0 R (Item.304) 1768 0 R (Item.305) 1769 0 R (Item.306) 1770 0 R (Item.307) 1771 0 R (Item.308) 1772 0 R]
+/Limits [(Item.303) (Item.308)]
+>> endobj
+2977 0 obj <<
+/Names [(Item.309) 1773 0 R (Item.31) 1157 0 R (Item.310) 1774 0 R (Item.311) 1775 0 R (Item.312) 1776 0 R (Item.313) 1777 0 R]
+/Limits [(Item.309) (Item.313)]
+>> endobj
+2978 0 obj <<
+/Names [(Item.314) 1778 0 R (Item.315) 1779 0 R (Item.316) 1780 0 R (Item.317) 1781 0 R (Item.318) 1782 0 R (Item.319) 1787 0 R]
+/Limits [(Item.314) (Item.319)]
+>> endobj
+2979 0 obj <<
+/Names [(Item.32) 1158 0 R (Item.320) 1788 0 R (Item.321) 1789 0 R (Item.322) 1790 0 R (Item.323) 1791 0 R (Item.324) 1792 0 R]
+/Limits [(Item.32) (Item.324)]
+>> endobj
+2980 0 obj <<
+/Names [(Item.325) 1793 0 R (Item.326) 1794 0 R (Item.327) 1795 0 R (Item.328) 1796 0 R (Item.329) 1797 0 R (Item.33) 1159 0 R]
+/Limits [(Item.325) (Item.33)]
+>> endobj
+2981 0 obj <<
+/Names [(Item.330) 1798 0 R (Item.331) 1799 0 R (Item.332) 1800 0 R (Item.333) 1801 0 R (Item.334) 1802 0 R (Item.335) 1803 0 R]
+/Limits [(Item.330) (Item.335)]
+>> endobj
+2982 0 obj <<
+/Names [(Item.336) 1804 0 R (Item.337) 1805 0 R (Item.338) 1806 0 R (Item.339) 1807 0 R (Item.34) 1160 0 R (Item.340) 1808 0 R]
+/Limits [(Item.336) (Item.340)]
+>> endobj
+2983 0 obj <<
+/Names [(Item.341) 1809 0 R (Item.342) 1810 0 R (Item.343) 1811 0 R (Item.344) 1812 0 R (Item.345) 1813 0 R (Item.346) 1814 0 R]
+/Limits [(Item.341) (Item.346)]
+>> endobj
+2984 0 obj <<
+/Names [(Item.347) 1815 0 R (Item.348) 1816 0 R (Item.349) 1817 0 R (Item.35) 1161 0 R (Item.350) 1818 0 R (Item.351) 1819 0 R]
+/Limits [(Item.347) (Item.351)]
+>> endobj
+2985 0 obj <<
+/Names [(Item.352) 1824 0 R (Item.353) 1825 0 R (Item.354) 1826 0 R (Item.355) 1827 0 R (Item.356) 1828 0 R (Item.357) 1829 0 R]
+/Limits [(Item.352) (Item.357)]
+>> endobj
+2986 0 obj <<
+/Names [(Item.358) 1830 0 R (Item.359) 1831 0 R (Item.36) 1162 0 R (Item.360) 1832 0 R (Item.361) 1833 0 R (Item.362) 1834 0 R]
+/Limits [(Item.358) (Item.362)]
+>> endobj
+2987 0 obj <<
+/Names [(Item.363) 1835 0 R (Item.364) 1836 0 R (Item.365) 1837 0 R (Item.366) 1838 0 R (Item.367) 1839 0 R (Item.368) 1840 0 R]
+/Limits [(Item.363) (Item.368)]
+>> endobj
+2988 0 obj <<
+/Names [(Item.369) 1841 0 R (Item.37) 1163 0 R (Item.370) 1842 0 R (Item.371) 1843 0 R (Item.372) 1844 0 R (Item.373) 1845 0 R]
+/Limits [(Item.369) (Item.373)]
+>> endobj
+2989 0 obj <<
+/Names [(Item.374) 1846 0 R (Item.375) 1847 0 R (Item.376) 1848 0 R (Item.377) 1849 0 R (Item.378) 1850 0 R (Item.379) 1851 0 R]
+/Limits [(Item.374) (Item.379)]
+>> endobj
+2990 0 obj <<
+/Names [(Item.38) 1169 0 R (Item.380) 1852 0 R (Item.381) 1853 0 R (Item.382) 1854 0 R (Item.383) 1859 0 R (Item.384) 1860 0 R]
+/Limits [(Item.38) (Item.384)]
+>> endobj
+2991 0 obj <<
+/Names [(Item.385) 1861 0 R (Item.386) 1862 0 R (Item.387) 1863 0 R (Item.388) 1864 0 R (Item.389) 1865 0 R (Item.39) 1170 0 R]
+/Limits [(Item.385) (Item.39)]
+>> endobj
+2992 0 obj <<
+/Names [(Item.390) 1866 0 R (Item.391) 1867 0 R (Item.392) 1868 0 R (Item.393) 1869 0 R (Item.394) 1870 0 R (Item.395) 1871 0 R]
+/Limits [(Item.390) (Item.395)]
+>> endobj
+2993 0 obj <<
+/Names [(Item.396) 1872 0 R (Item.397) 1873 0 R (Item.398) 1874 0 R (Item.399) 1875 0 R (Item.4) 1078 0 R (Item.40) 1171 0 R]
+/Limits [(Item.396) (Item.40)]
+>> endobj
+2994 0 obj <<
+/Names [(Item.400) 1876 0 R (Item.401) 1877 0 R (Item.402) 1878 0 R (Item.403) 1879 0 R (Item.404) 1880 0 R (Item.405) 1881 0 R]
+/Limits [(Item.400) (Item.405)]
+>> endobj
+2995 0 obj <<
+/Names [(Item.406) 1882 0 R (Item.407) 1883 0 R (Item.408) 1884 0 R (Item.409) 1885 0 R (Item.41) 1189 0 R (Item.410) 1886 0 R]
+/Limits [(Item.406) (Item.410)]
+>> endobj
+2996 0 obj <<
+/Names [(Item.411) 1887 0 R (Item.412) 1888 0 R (Item.413) 1893 0 R (Item.414) 1894 0 R (Item.415) 1895 0 R (Item.416) 1896 0 R]
+/Limits [(Item.411) (Item.416)]
+>> endobj
+2997 0 obj <<
+/Names [(Item.417) 1897 0 R (Item.418) 1898 0 R (Item.419) 1899 0 R (Item.42) 1190 0 R (Item.420) 1900 0 R (Item.421) 1901 0 R]
+/Limits [(Item.417) (Item.421)]
+>> endobj
+2998 0 obj <<
+/Names [(Item.422) 1902 0 R (Item.423) 1903 0 R (Item.424) 1904 0 R (Item.425) 1905 0 R (Item.426) 1906 0 R (Item.427) 1925 0 R]
+/Limits [(Item.422) (Item.427)]
+>> endobj
+2999 0 obj <<
+/Names [(Item.428) 1926 0 R (Item.429) 1927 0 R (Item.43) 1191 0 R (Item.430) 1928 0 R (Item.431) 1929 0 R (Item.432) 1930 0 R]
+/Limits [(Item.428) (Item.432)]
+>> endobj
+3000 0 obj <<
+/Names [(Item.433) 1931 0 R (Item.434) 1932 0 R (Item.435) 1933 0 R (Item.436) 1934 0 R (Item.437) 1935 0 R (Item.438) 1936 0 R]
+/Limits [(Item.433) (Item.438)]
+>> endobj
+3001 0 obj <<
+/Names [(Item.439) 1937 0 R (Item.44) 1213 0 R (Item.440) 1938 0 R (Item.441) 1939 0 R (Item.442) 1940 0 R (Item.443) 1941 0 R]
+/Limits [(Item.439) (Item.443)]
+>> endobj
+3002 0 obj <<
+/Names [(Item.444) 1942 0 R (Item.445) 1951 0 R (Item.446) 1952 0 R (Item.447) 1970 0 R (Item.448) 1971 0 R (Item.449) 1972 0 R]
+/Limits [(Item.444) (Item.449)]
+>> endobj
+3003 0 obj <<
+/Names [(Item.45) 1214 0 R (Item.450) 1973 0 R (Item.451) 1974 0 R (Item.452) 1975 0 R (Item.453) 1976 0 R (Item.454) 1977 0 R]
+/Limits [(Item.45) (Item.454)]
+>> endobj
+3004 0 obj <<
+/Names [(Item.455) 1978 0 R (Item.456) 1979 0 R (Item.457) 1980 0 R (Item.458) 1981 0 R (Item.459) 1982 0 R (Item.46) 1215 0 R]
+/Limits [(Item.455) (Item.46)]
+>> endobj
+3005 0 obj <<
+/Names [(Item.460) 1983 0 R (Item.461) 1984 0 R (Item.462) 1985 0 R (Item.463) 1986 0 R (Item.464) 1994 0 R (Item.465) 1995 0 R]
+/Limits [(Item.460) (Item.465)]
+>> endobj
+3006 0 obj <<
+/Names [(Item.466) 1996 0 R (Item.467) 1997 0 R (Item.468) 1998 0 R (Item.469) 1999 0 R (Item.47) 1216 0 R (Item.470) 2000 0 R]
+/Limits [(Item.466) (Item.470)]
+>> endobj
+3007 0 obj <<
+/Names [(Item.471) 2001 0 R (Item.472) 2002 0 R (Item.473) 2003 0 R (Item.474) 2004 0 R (Item.475) 2005 0 R (Item.476) 2006 0 R]
+/Limits [(Item.471) (Item.476)]
+>> endobj
+3008 0 obj <<
+/Names [(Item.477) 2007 0 R (Item.478) 2008 0 R (Item.479) 2009 0 R (Item.48) 1217 0 R (Item.480) 2010 0 R (Item.481) 2011 0 R]
+/Limits [(Item.477) (Item.481)]
+>> endobj
+3009 0 obj <<
+/Names [(Item.482) 2012 0 R (Item.483) 2013 0 R (Item.484) 2014 0 R (Item.485) 2015 0 R (Item.486) 2016 0 R (Item.487) 2017 0 R]
+/Limits [(Item.482) (Item.487)]
+>> endobj
+3010 0 obj <<
+/Names [(Item.488) 2018 0 R (Item.489) 2019 0 R (Item.49) 1218 0 R (Item.490) 2020 0 R (Item.491) 2021 0 R (Item.492) 2027 0 R]
+/Limits [(Item.488) (Item.492)]
+>> endobj
+3011 0 obj <<
+/Names [(Item.493) 2028 0 R (Item.494) 2029 0 R (Item.495) 2030 0 R (Item.496) 2031 0 R (Item.497) 2032 0 R (Item.498) 2033 0 R]
+/Limits [(Item.493) (Item.498)]
+>> endobj
+3012 0 obj <<
+/Names [(Item.499) 2034 0 R (Item.5) 1079 0 R (Item.50) 1219 0 R (Item.500) 2035 0 R (Item.501) 2036 0 R (Item.502) 2053 0 R]
+/Limits [(Item.499) (Item.502)]
+>> endobj
+3013 0 obj <<
+/Names [(Item.503) 2054 0 R (Item.504) 2055 0 R (Item.505) 2056 0 R (Item.506) 2057 0 R (Item.507) 2058 0 R (Item.508) 2059 0 R]
+/Limits [(Item.503) (Item.508)]
+>> endobj
+3014 0 obj <<
+/Names [(Item.509) 2060 0 R (Item.51) 1220 0 R (Item.510) 2061 0 R (Item.511) 2062 0 R (Item.512) 2063 0 R (Item.513) 2064 0 R]
+/Limits [(Item.509) (Item.513)]
+>> endobj
+3015 0 obj <<
+/Names [(Item.514) 2065 0 R (Item.515) 2076 0 R (Item.516) 2077 0 R (Item.517) 2078 0 R (Item.518) 2094 0 R (Item.519) 2095 0 R]
+/Limits [(Item.514) (Item.519)]
+>> endobj
+3016 0 obj <<
+/Names [(Item.52) 1221 0 R (Item.520) 2096 0 R (Item.521) 2097 0 R (Item.522) 2098 0 R (Item.523) 2099 0 R (Item.524) 2100 0 R]
+/Limits [(Item.52) (Item.524)]
+>> endobj
+3017 0 obj <<
+/Names [(Item.525) 2101 0 R (Item.526) 2102 0 R (Item.527) 2115 0 R (Item.528) 2116 0 R (Item.529) 2117 0 R (Item.53) 1222 0 R]
+/Limits [(Item.525) (Item.53)]
+>> endobj
+3018 0 obj <<
+/Names [(Item.530) 2118 0 R (Item.531) 2129 0 R (Item.532) 2130 0 R (Item.533) 2131 0 R (Item.534) 2132 0 R (Item.535) 2133 0 R]
+/Limits [(Item.530) (Item.535)]
+>> endobj
+3019 0 obj <<
+/Names [(Item.536) 2134 0 R (Item.537) 2135 0 R (Item.538) 2136 0 R (Item.539) 2137 0 R (Item.54) 1223 0 R (Item.540) 2138 0 R]
+/Limits [(Item.536) (Item.540)]
+>> endobj
+3020 0 obj <<
+/Names [(Item.541) 2139 0 R (Item.542) 2160 0 R (Item.543) 2161 0 R (Item.544) 2162 0 R (Item.545) 2163 0 R (Item.546) 2164 0 R]
+/Limits [(Item.541) (Item.546)]
+>> endobj
+3021 0 obj <<
+/Names [(Item.547) 2165 0 R (Item.548) 2166 0 R (Item.549) 2167 0 R (Item.55) 1236 0 R (Item.550) 2168 0 R (Item.551) 2169 0 R]
+/Limits [(Item.547) (Item.551)]
+>> endobj
+3022 0 obj <<
+/Names [(Item.552) 2202 0 R (Item.553) 2203 0 R (Item.554) 2204 0 R (Item.555) 2205 0 R (Item.556) 2206 0 R (Item.557) 2207 0 R]
+/Limits [(Item.552) (Item.557)]
+>> endobj
+3023 0 obj <<
+/Names [(Item.558) 2208 0 R (Item.559) 2209 0 R (Item.56) 1237 0 R (Item.560) 2210 0 R (Item.561) 2211 0 R (Item.562) 2212 0 R]
+/Limits [(Item.558) (Item.562)]
+>> endobj
+3024 0 obj <<
+/Names [(Item.563) 2213 0 R (Item.564) 2214 0 R (Item.565) 2215 0 R (Item.566) 2216 0 R (Item.567) 2221 0 R (Item.568) 2222 0 R]
+/Limits [(Item.563) (Item.568)]
+>> endobj
+3025 0 obj <<
+/Names [(Item.569) 2223 0 R (Item.57) 1238 0 R (Item.570) 2224 0 R (Item.571) 2225 0 R (Item.572) 2226 0 R (Item.573) 2227 0 R]
+/Limits [(Item.569) (Item.573)]
+>> endobj
+3026 0 obj <<
+/Names [(Item.574) 2228 0 R (Item.575) 2229 0 R (Item.576) 2230 0 R (Item.577) 2231 0 R (Item.578) 2232 0 R (Item.579) 2233 0 R]
+/Limits [(Item.574) (Item.579)]
+>> endobj
+3027 0 obj <<
+/Names [(Item.58) 1239 0 R (Item.580) 2234 0 R (Item.581) 2235 0 R (Item.582) 2236 0 R (Item.583) 2237 0 R (Item.584) 2238 0 R]
+/Limits [(Item.58) (Item.584)]
+>> endobj
+3028 0 obj <<
+/Names [(Item.585) 2239 0 R (Item.586) 2240 0 R (Item.587) 2241 0 R (Item.588) 2242 0 R (Item.589) 2243 0 R (Item.59) 1240 0 R]
+/Limits [(Item.585) (Item.59)]
+>> endobj
+3029 0 obj <<
+/Names [(Item.590) 2244 0 R (Item.591) 2245 0 R (Item.592) 2246 0 R (Item.593) 2254 0 R (Item.594) 2255 0 R (Item.595) 2256 0 R]
+/Limits [(Item.590) (Item.595)]
+>> endobj
+3030 0 obj <<
+/Names [(Item.596) 2257 0 R (Item.597) 2258 0 R (Item.598) 2259 0 R (Item.599) 2260 0 R (Item.6) 1093 0 R (Item.60) 1241 0 R]
+/Limits [(Item.596) (Item.60)]
+>> endobj
+3031 0 obj <<
+/Names [(Item.600) 2261 0 R (Item.601) 2262 0 R (Item.602) 2263 0 R (Item.603) 2264 0 R (Item.604) 2265 0 R (Item.605) 2266 0 R]
+/Limits [(Item.600) (Item.605)]
+>> endobj
+3032 0 obj <<
+/Names [(Item.606) 2267 0 R (Item.607) 2280 0 R (Item.608) 2281 0 R (Item.609) 2282 0 R (Item.61) 1242 0 R (Item.610) 2283 0 R]
+/Limits [(Item.606) (Item.610)]
+>> endobj
+3033 0 obj <<
+/Names [(Item.611) 2284 0 R (Item.612) 2285 0 R (Item.613) 2286 0 R (Item.614) 2287 0 R (Item.615) 2288 0 R (Item.616) 2289 0 R]
+/Limits [(Item.611) (Item.616)]
+>> endobj
+3034 0 obj <<
+/Names [(Item.617) 2290 0 R (Item.618) 2291 0 R (Item.619) 2309 0 R (Item.62) 1243 0 R (Item.620) 2310 0 R (Item.621) 2311 0 R]
+/Limits [(Item.617) (Item.621)]
+>> endobj
+3035 0 obj <<
+/Names [(Item.622) 2312 0 R (Item.623) 2313 0 R (Item.624) 2314 0 R (Item.625) 2315 0 R (Item.626) 2316 0 R (Item.627) 2317 0 R]
+/Limits [(Item.622) (Item.627)]
+>> endobj
+3036 0 obj <<
+/Names [(Item.628) 2318 0 R (Item.629) 2319 0 R (Item.63) 1244 0 R (Item.630) 2320 0 R (Item.631) 2333 0 R (Item.632) 2334 0 R]
+/Limits [(Item.628) (Item.632)]
+>> endobj
+3037 0 obj <<
+/Names [(Item.633) 2335 0 R (Item.634) 2336 0 R (Item.635) 2337 0 R (Item.636) 2338 0 R (Item.637) 2339 0 R (Item.638) 2340 0 R]
+/Limits [(Item.633) (Item.638)]
+>> endobj
+3038 0 obj <<
+/Names [(Item.639) 2341 0 R (Item.64) 1245 0 R (Item.640) 2342 0 R (Item.641) 2343 0 R (Item.642) 2344 0 R (Item.643) 2345 0 R]
+/Limits [(Item.639) (Item.643)]
+>> endobj
+3039 0 obj <<
+/Names [(Item.644) 2346 0 R (Item.645) 2347 0 R (Item.646) 2348 0 R (Item.647) 2349 0 R (Item.648) 2350 0 R (Item.649) 2351 0 R]
+/Limits [(Item.644) (Item.649)]
+>> endobj
+3040 0 obj <<
+/Names [(Item.65) 1246 0 R (Item.650) 2386 0 R (Item.651) 2387 0 R (Item.652) 2388 0 R (Item.653) 2389 0 R (Item.654) 2390 0 R]
+/Limits [(Item.65) (Item.654)]
+>> endobj
+3041 0 obj <<
+/Names [(Item.655) 2391 0 R (Item.656) 2392 0 R (Item.657) 2393 0 R (Item.658) 2394 0 R (Item.659) 2395 0 R (Item.66) 1247 0 R]
+/Limits [(Item.655) (Item.66)]
+>> endobj
+3042 0 obj <<
+/Names [(Item.660) 2396 0 R (Item.661) 2397 0 R (Item.662) 2398 0 R (Item.663) 2411 0 R (Item.664) 2412 0 R (Item.665) 2413 0 R]
+/Limits [(Item.660) (Item.665)]
+>> endobj
+3043 0 obj <<
+/Names [(Item.666) 2414 0 R (Item.667) 2415 0 R (Item.668) 2416 0 R (Item.669) 2417 0 R (Item.67) 1248 0 R (Item.670) 2418 0 R]
+/Limits [(Item.666) (Item.670)]
+>> endobj
+3044 0 obj <<
+/Names [(Item.671) 2419 0 R (Item.672) 2420 0 R (Item.673) 2421 0 R (Item.674) 2422 0 R (Item.675) 2423 0 R (Item.676) 2424 0 R]
+/Limits [(Item.671) (Item.676)]
+>> endobj
+3045 0 obj <<
+/Names [(Item.677) 2425 0 R (Item.678) 2426 0 R (Item.679) 2427 0 R (Item.68) 1249 0 R (Item.680) 2428 0 R (Item.681) 2434 0 R]
+/Limits [(Item.677) (Item.681)]
+>> endobj
+3046 0 obj <<
+/Names [(Item.682) 2435 0 R (Item.683) 2436 0 R (Item.684) 2437 0 R (Item.685) 2438 0 R (Item.686) 2439 0 R (Item.687) 2440 0 R]
+/Limits [(Item.682) (Item.687)]
+>> endobj
+3047 0 obj <<
+/Names [(Item.688) 2441 0 R (Item.689) 2442 0 R (Item.69) 1250 0 R (Item.690) 2443 0 R (Item.691) 2444 0 R (Item.692) 2467 0 R]
+/Limits [(Item.688) (Item.692)]
+>> endobj
+3048 0 obj <<
+/Names [(Item.693) 2468 0 R (Item.694) 2469 0 R (Item.695) 2470 0 R (Item.696) 2471 0 R (Item.697) 2472 0 R (Item.698) 2473 0 R]
+/Limits [(Item.693) (Item.698)]
+>> endobj
+3049 0 obj <<
+/Names [(Item.699) 2474 0 R (Item.7) 1094 0 R (Item.70) 1251 0 R (Item.700) 2475 0 R (Item.701) 2476 0 R (Item.702) 2487 0 R]
+/Limits [(Item.699) (Item.702)]
+>> endobj
+3050 0 obj <<
+/Names [(Item.703) 2488 0 R (Item.704) 2489 0 R (Item.705) 2490 0 R (Item.706) 2491 0 R (Item.707) 2492 0 R (Item.708) 2493 0 R]
+/Limits [(Item.703) (Item.708)]
+>> endobj
+3051 0 obj <<
+/Names [(Item.709) 2498 0 R (Item.71) 1252 0 R (Item.710) 2499 0 R (Item.711) 2500 0 R (Item.712) 2519 0 R (Item.713) 2520 0 R]
+/Limits [(Item.709) (Item.713)]
+>> endobj
+3052 0 obj <<
+/Names [(Item.714) 2521 0 R (Item.715) 2522 0 R (Item.716) 2523 0 R (Item.717) 2524 0 R (Item.718) 2525 0 R (Item.719) 2526 0 R]
+/Limits [(Item.714) (Item.719)]
+>> endobj
+3053 0 obj <<
+/Names [(Item.72) 1253 0 R (Item.720) 2527 0 R (Item.721) 2528 0 R (Item.722) 2529 0 R (Item.723) 2530 0 R (Item.724) 2531 0 R]
+/Limits [(Item.72) (Item.724)]
+>> endobj
+3054 0 obj <<
+/Names [(Item.725) 2532 0 R (Item.726) 2533 0 R (Item.727) 2542 0 R (Item.728) 2543 0 R (Item.729) 2544 0 R (Item.73) 1254 0 R]
+/Limits [(Item.725) (Item.73)]
+>> endobj
+3055 0 obj <<
+/Names [(Item.730) 2545 0 R (Item.731) 2546 0 R (Item.732) 2547 0 R (Item.733) 2548 0 R (Item.734) 2549 0 R (Item.735) 2585 0 R]
+/Limits [(Item.730) (Item.735)]
+>> endobj
+3056 0 obj <<
+/Names [(Item.736) 2586 0 R (Item.737) 2587 0 R (Item.738) 2588 0 R (Item.739) 2589 0 R (Item.74) 1255 0 R (Item.740) 2590 0 R]
+/Limits [(Item.736) (Item.740)]
+>> endobj
+3057 0 obj <<
+/Names [(Item.741) 2591 0 R (Item.742) 2592 0 R (Item.743) 2593 0 R (Item.744) 2601 0 R (Item.745) 2602 0 R (Item.746) 2603 0 R]
+/Limits [(Item.741) (Item.746)]
+>> endobj
+3058 0 obj <<
+/Names [(Item.747) 2604 0 R (Item.748) 2605 0 R (Item.749) 2606 0 R (Item.75) 1256 0 R (Item.750) 2607 0 R (Item.751) 2608 0 R]
+/Limits [(Item.747) (Item.751)]
+>> endobj
+3059 0 obj <<
+/Names [(Item.752) 2609 0 R (Item.753) 2610 0 R (Item.76) 1257 0 R (Item.77) 1275 0 R (Item.78) 1277 0 R (Item.79) 1278 0 R]
+/Limits [(Item.752) (Item.79)]
+>> endobj
+3060 0 obj <<
+/Names [(Item.8) 1095 0 R (Item.80) 1284 0 R (Item.81) 1285 0 R (Item.82) 1286 0 R (Item.83) 1287 0 R (Item.84) 1288 0 R]
+/Limits [(Item.8) (Item.84)]
+>> endobj
+3061 0 obj <<
+/Names [(Item.85) 1289 0 R (Item.86) 1290 0 R (Item.87) 1291 0 R (Item.88) 1302 0 R (Item.89) 1303 0 R (Item.9) 1096 0 R]
+/Limits [(Item.85) (Item.9)]
+>> endobj
+3062 0 obj <<
+/Names [(Item.90) 1304 0 R (Item.91) 1305 0 R (Item.92) 1306 0 R (Item.93) 1307 0 R (Item.94) 1308 0 R (Item.95) 1309 0 R]
+/Limits [(Item.90) (Item.95)]
+>> endobj
+3063 0 obj <<
+/Names [(Item.96) 1310 0 R (Item.97) 1311 0 R (Item.98) 1312 0 R (Item.99) 1320 0 R (appendix*.139) 2852 0 R (appendix.A) 346 0 R]
+/Limits [(Item.96) (appendix.A)]
+>> endobj
+3064 0 obj <<
+/Names [(appendix.B) 386 0 R (appendix.C) 406 0 R (chapter*.1) 456 0 R (chapter*.2) 572 0 R (chapter*.3) 632 0 R (chapter*.4) 665 0 R]
+/Limits [(appendix.B) (chapter*.4)]
+>> endobj
+3065 0 obj <<
+/Names [(chapter*.5) 690 0 R (chapter.1) 6 0 R (chapter.2) 34 0 R (chapter.3) 62 0 R (chapter.4) 94 0 R (chapter.5) 138 0 R]
+/Limits [(chapter*.5) (chapter.5)]
+>> endobj
+3066 0 obj <<
+/Names [(chapter.6) 182 0 R (chapter.7) 234 0 R (cite.CSF77) 2197 0 R (cite.Mel04) 706 0 R (cite.Poyn97) 932 0 R (cite.rec470) 911 0 R]
+/Limits [(chapter.6) (cite.rec470)]
+>> endobj
+3067 0 obj <<
+/Names [(cite.rec601) 912 0 R (cite.rec709) 921 0 R (cite.rfc2044) 1173 0 R (cite.rfc2119) 691 0 R (cite.rfc3533) 2618 0 R (cite.smpte170m) 922 0 R]
+/Limits [(cite.rec601) (cite.smpte170m)]
+>> endobj
+3068 0 obj <<
+/Names [(cite.vorbis) 713 0 R (equation.4.1) 881 0 R (equation.4.10) 895 0 R (equation.4.11) 896 0 R (equation.4.12) 897 0 R (equation.4.13) 898 0 R]
+/Limits [(cite.vorbis) (equation.4.13)]
+>> endobj
+3069 0 obj <<
+/Names [(equation.4.14) 908 0 R (equation.4.15) 909 0 R (equation.4.16) 910 0 R (equation.4.2) 883 0 R (equation.4.3) 884 0 R (equation.4.4) 885 0 R]
+/Limits [(equation.4.14) (equation.4.4)]
+>> endobj
+3070 0 obj <<
+/Names [(equation.4.5) 886 0 R (equation.4.6) 887 0 R (equation.4.7) 892 0 R (equation.4.8) 893 0 R (equation.4.9) 894 0 R (figure.2.1) 577 0 R]
+/Limits [(equation.4.5) (figure.2.1)]
+>> endobj
+3071 0 obj <<
+/Names [(figure.2.2) 578 0 R (figure.2.3) 579 0 R (figure.2.4) 580 0 R (figure.2.5) 581 0 R (figure.2.6) 582 0 R (figure.2.7) 583 0 R]
+/Limits [(figure.2.2) (figure.2.7)]
+>> endobj
+3072 0 obj <<
+/Names [(figure.2.8) 584 0 R (figure.4.1) 585 0 R (figure.4.2) 586 0 R (figure.4.3) 587 0 R (figure.4.4) 588 0 R (figure.4.5) 589 0 R]
+/Limits [(figure.2.8) (figure.4.5)]
+>> endobj
+3073 0 obj <<
+/Names [(figure.4.6) 590 0 R (figure.4.7) 591 0 R (figure.6.1) 592 0 R (figure.6.2) 593 0 R (figure.6.3) 594 0 R (figure.6.4) 595 0 R]
+/Limits [(figure.4.6) (figure.6.4)]
+>> endobj
+3074 0 obj <<
+/Names [(figure.6.5) 596 0 R (figure.7.1) 597 0 R (figure.7.2) 598 0 R (figure.7.3) 599 0 R (page.1) 704 0 R (page.10) 785 0 R]
+/Limits [(figure.6.5) (page.10)]
+>> endobj
+3075 0 obj <<
+/Names [(page.100) 2026 0 R (page.101) 2041 0 R (page.102) 2052 0 R (page.103) 2069 0 R (page.104) 2085 0 R (page.105) 2093 0 R]
+/Limits [(page.100) (page.105)]
+>> endobj
+3076 0 obj <<
+/Names [(page.106) 2110 0 R (page.107) 2128 0 R (page.108) 2148 0 R (page.109) 2159 0 R (page.11) 804 0 R (page.110) 2173 0 R]
+/Limits [(page.106) (page.110)]
+>> endobj
+3077 0 obj <<
+/Names [(page.111) 2187 0 R (page.112) 2201 0 R (page.113) 2220 0 R (page.114) 2253 0 R (page.115) 2276 0 R (page.116) 2297 0 R]
+/Limits [(page.111) (page.116)]
+>> endobj
+3078 0 obj <<
+/Names [(page.117) 2308 0 R (page.118) 2332 0 R (page.119) 2357 0 R (page.12) 816 0 R (page.120) 2361 0 R (page.121) 2368 0 R]
+/Limits [(page.117) (page.121)]
+>> endobj
+3079 0 obj <<
+/Names [(page.122) 2377 0 R (page.123) 2385 0 R (page.124) 2410 0 R (page.125) 2433 0 R (page.126) 2456 0 R (page.127) 2464 0 R]
+/Limits [(page.122) (page.127)]
+>> endobj
+3080 0 obj <<
+/Names [(page.128) 2482 0 R (page.129) 2497 0 R (page.13) 822 0 R (page.130) 2507 0 R (page.131) 2518 0 R (page.132) 2541 0 R]
+/Limits [(page.128) (page.132)]
+>> endobj
+3081 0 obj <<
+/Names [(page.133) 2555 0 R (page.134) 2560 0 R (page.135) 2564 0 R (page.136) 2571 0 R (page.137) 2584 0 R (page.138) 2600 0 R]
+/Limits [(page.133) (page.138)]
+>> endobj
+3082 0 obj <<
+/Names [(page.139) 2617 0 R (page.14) 830 0 R (page.140) 2623 0 R (page.141) 2627 0 R (page.142) 2632 0 R (page.143) 2647 0 R]
+/Limits [(page.139) (page.143)]
+>> endobj
+3083 0 obj <<
+/Names [(page.144) 2651 0 R (page.145) 2655 0 R (page.146) 2659 0 R (page.147) 2663 0 R (page.148) 2668 0 R (page.149) 2672 0 R]
+/Limits [(page.144) (page.149)]
+>> endobj
+3084 0 obj <<
+/Names [(page.15) 837 0 R (page.150) 2676 0 R (page.151) 2680 0 R (page.152) 2684 0 R (page.153) 2688 0 R (page.154) 2693 0 R]
+/Limits [(page.15) (page.154)]
+>> endobj
+3085 0 obj <<
+/Names [(page.155) 2697 0 R (page.156) 2701 0 R (page.157) 2705 0 R (page.158) 2709 0 R (page.159) 2713 0 R (page.16) 845 0 R]
+/Limits [(page.155) (page.16)]
+>> endobj
+3086 0 obj <<
+/Names [(page.160) 2718 0 R (page.161) 2722 0 R (page.162) 2726 0 R (page.163) 2730 0 R (page.164) 2734 0 R (page.165) 2738 0 R]
+/Limits [(page.160) (page.165)]
+>> endobj
+3087 0 obj <<
+/Names [(page.166) 2743 0 R (page.167) 2747 0 R (page.168) 2751 0 R (page.169) 2755 0 R (page.17) 850 0 R (page.170) 2759 0 R]
+/Limits [(page.166) (page.170)]
+>> endobj
+3088 0 obj <<
+/Names [(page.171) 2763 0 R (page.172) 2768 0 R (page.173) 2772 0 R (page.174) 2776 0 R (page.175) 2780 0 R (page.176) 2784 0 R]
+/Limits [(page.171) (page.176)]
+>> endobj
+3089 0 obj <<
+/Names [(page.177) 2788 0 R (page.178) 2793 0 R (page.179) 2797 0 R (page.18) 860 0 R (page.180) 2801 0 R (page.181) 2805 0 R]
+/Limits [(page.177) (page.181)]
+>> endobj
+3090 0 obj <<
+/Names [(page.182) 2809 0 R (page.183) 2813 0 R (page.184) 2818 0 R (page.185) 2822 0 R (page.186) 2826 0 R (page.187) 2834 0 R]
+/Limits [(page.182) (page.187)]
+>> endobj
+3091 0 obj <<
+/Names [(page.188) 2841 0 R (page.189) 2851 0 R (page.19) 866 0 R (page.190) 2861 0 R (page.2) 712 0 R (page.20) 871 0 R]
+/Limits [(page.188) (page.20)]
+>> endobj
+3092 0 obj <<
+/Names [(page.21) 875 0 R (page.22) 880 0 R (page.23) 891 0 R (page.24) 907 0 R (page.25) 920 0 R (page.26) 931 0 R]
+/Limits [(page.21) (page.26)]
+>> endobj
+3093 0 obj <<
+/Names [(page.27) 939 0 R (page.28) 953 0 R (page.29) 965 0 R (page.3) 717 0 R (page.30) 988 0 R (page.31) 998 0 R]
+/Limits [(page.27) (page.31)]
+>> endobj
+3094 0 obj <<
+/Names [(page.32) 1026 0 R (page.33) 1030 0 R (page.34) 1035 0 R (page.35) 1039 0 R (page.36) 1043 0 R (page.37) 1047 0 R]
+/Limits [(page.32) (page.37)]
+>> endobj
+3095 0 obj <<
+/Names [(page.38) 1051 0 R (page.39) 1055 0 R (page.4) 722 0 R (page.40) 1062 0 R (page.41) 1075 0 R (page.42) 1083 0 R]
+/Limits [(page.38) (page.42)]
+>> endobj
+3096 0 obj <<
+/Names [(page.43) 1092 0 R (page.44) 1114 0 R (page.45) 1125 0 R (page.46) 1133 0 R (page.47) 1151 0 R (page.48) 1168 0 R]
+/Limits [(page.43) (page.48)]
+>> endobj
+3097 0 obj <<
+/Names [(page.49) 1177 0 R (page.5) 728 0 R (page.50) 1184 0 R (page.51) 1205 0 R (page.52) 1212 0 R (page.53) 1235 0 R]
+/Limits [(page.49) (page.53)]
+>> endobj
+3098 0 obj <<
+/Names [(page.54) 1263 0 R (page.55) 1273 0 R (page.56) 1283 0 R (page.57) 1300 0 R (page.58) 1319 0 R (page.59) 1334 0 R]
+/Limits [(page.54) (page.59)]
+>> endobj
+3099 0 obj <<
+/Names [(page.6) 734 0 R (page.60) 1343 0 R (page.61) 1347 0 R (page.62) 1357 0 R (page.63) 1376 0 R (page.64) 1389 0 R]
+/Limits [(page.6) (page.64)]
+>> endobj
+3100 0 obj <<
+/Names [(page.65) 1406 0 R (page.66) 1423 0 R (page.67) 1441 0 R (page.68) 1453 0 R (page.69) 1477 0 R (page.7) 748 0 R]
+/Limits [(page.65) (page.7)]
+>> endobj
+3101 0 obj <<
+/Names [(page.70) 1489 0 R (page.71) 1500 0 R (page.72) 1522 0 R (page.73) 1538 0 R (page.74) 1543 0 R (page.75) 1552 0 R]
+/Limits [(page.70) (page.75)]
+>> endobj
+3102 0 obj <<
+/Names [(page.76) 1561 0 R (page.77) 1585 0 R (page.78) 1604 0 R (page.79) 1625 0 R (page.8) 759 0 R (page.80) 1637 0 R]
+/Limits [(page.76) (page.80)]
+>> endobj
+3103 0 obj <<
+/Names [(page.81) 1648 0 R (page.82) 1653 0 R (page.83) 1660 0 R (page.84) 1669 0 R (page.85) 1676 0 R (page.86) 1701 0 R]
+/Limits [(page.81) (page.86)]
+>> endobj
+3104 0 obj <<
+/Names [(page.87) 1712 0 R (page.88) 1718 0 R (page.89) 1750 0 R (page.9) 774 0 R (page.90) 1786 0 R (page.91) 1823 0 R]
+/Limits [(page.87) (page.91)]
+>> endobj
+3105 0 obj <<
+/Names [(page.92) 1858 0 R (page.93) 1892 0 R (page.94) 1915 0 R (page.95) 1924 0 R (page.96) 1950 0 R (page.97) 1958 0 R]
+/Limits [(page.92) (page.97)]
+>> endobj
+3106 0 obj <<
+/Names [(page.98) 1969 0 R (page.99) 1993 0 R (page.i) 413 0 R (page.ii) 421 0 R (page.iii) 540 0 R (page.iv) 544 0 R]
+/Limits [(page.98) (page.iv)]
+>> endobj
+3107 0 obj <<
+/Names [(page.ix) 664 0 R (page.v) 571 0 R (page.vi) 603 0 R (page.vii) 631 0 R (page.viii) 660 0 R (page.x) 672 0 R]
+/Limits [(page.ix) (page.x)]
+>> endobj
+3108 0 obj <<
+/Names [(page.xi) 679 0 R (page.xii) 684 0 R (page.xiii) 689 0 R (page.xiv) 695 0 R (section*.10) 851 0 R (section*.100) 2079 0 R]
+/Limits [(page.xi) (section*.100)]
+>> endobj
+3109 0 obj <<
+/Names [(section*.101) 2080 0 R (section*.102) 2086 0 R (section*.103) 2088 0 R (section*.104) 2103 0 R (section*.105) 2104 0 R (section*.106) 2111 0 R]
+/Limits [(section*.101) (section*.106)]
+>> endobj
+3110 0 obj <<
+/Names [(section*.107) 2113 0 R (section*.108) 2140 0 R (section*.109) 2149 0 R (section*.11) 852 0 R (section*.110) 2151 0 R (section*.111) 2174 0 R]
+/Limits [(section*.107) (section*.111)]
+>> endobj
+3111 0 obj <<
+/Names [(section*.112) 2175 0 R (section*.113) 2177 0 R (section*.114) 2179 0 R (section*.115) 1943 0 R (section*.116) 2268 0 R (section*.117) 2270 0 R]
+/Limits [(section*.112) (section*.117)]
+>> endobj
+3112 0 obj <<
+/Names [(section*.118) 2278 0 R (section*.119) 2298 0 R (section*.12) 853 0 R (section*.120) 2299 0 R (section*.121) 2301 0 R (section*.122) 2303 0 R]
+/Limits [(section*.118) (section*.122)]
+>> endobj
+3113 0 obj <<
+/Names [(section*.123) 2352 0 R (section*.124) 2369 0 R (section*.125) 2371 0 R (section*.126) 2457 0 R (section*.127) 2459 0 R (section*.128) 2465 0 R]
+/Limits [(section*.123) (section*.128)]
+>> endobj
+3114 0 obj <<
+/Names [(section*.129) 2477 0 R (section*.13) 854 0 R (section*.130) 2483 0 R (section*.131) 2485 0 R (section*.132) 2501 0 R (section*.133) 2508 0 R]
+/Limits [(section*.129) (section*.133)]
+>> endobj
+3115 0 obj <<
+/Names [(section*.134) 2510 0 R (section*.135) 2550 0 R (section*.136) 2551 0 R (section*.137) 2565 0 R (section*.138) 2572 0 R (section*.14) 855 0 R]
+/Limits [(section*.134) (section*.14)]
+>> endobj
+3116 0 obj <<
+/Names [(section*.15) 856 0 R (section*.16) 861 0 R (section*.17) 862 0 R (section*.18) 867 0 R (section*.19) 1056 0 R (section*.20) 1057 0 R]
+/Limits [(section*.15) (section*.20)]
+>> endobj
+3117 0 obj <<
+/Names [(section*.21) 1063 0 R (section*.22) 1065 0 R (section*.23) 1068 0 R (section*.24) 1069 0 R (section*.25) 1076 0 R (section*.26) 1128 0 R]
+/Limits [(section*.21) (section*.26)]
+>> endobj
+3118 0 obj <<
+/Names [(section*.27) 1134 0 R (section*.28) 1135 0 R (section*.29) 1137 0 R (section*.30) 1152 0 R (section*.31) 1153 0 R (section*.32) 1155 0 R]
+/Limits [(section*.27) (section*.32)]
+>> endobj
+3119 0 obj <<
+/Names [(section*.33) 1172 0 R (section*.34) 1178 0 R (section*.35) 1185 0 R (section*.36) 1187 0 R (section*.37) 1192 0 R (section*.38) 1193 0 R]
+/Limits [(section*.33) (section*.38)]
+>> endobj
+3120 0 obj <<
+/Names [(section*.39) 1194 0 R (section*.40) 1206 0 R (section*.41) 1258 0 R (section*.42) 1259 0 R (section*.43) 1266 0 R (section*.44) 1268 0 R]
+/Limits [(section*.39) (section*.44)]
+>> endobj
+3121 0 obj <<
+/Names [(section*.45) 1292 0 R (section*.46) 1293 0 R (section*.47) 1295 0 R (section*.48) 1323 0 R (section*.49) 1324 0 R (section*.50) 1325 0 R]
+/Limits [(section*.45) (section*.50)]
+>> endobj
+3122 0 obj <<
+/Names [(section*.51) 1335 0 R (section*.52) 1348 0 R (section*.53) 1349 0 R (section*.54) 1351 0 R (section*.55) 1371 0 R (section*.56) 1377 0 R]
+/Limits [(section*.51) (section*.56)]
+>> endobj
+3123 0 obj <<
+/Names [(section*.57) 1379 0 R (section*.58) 1381 0 R (section*.59) 1410 0 R (section*.6) 838 0 R (section*.60) 1411 0 R (section*.61) 1413 0 R]
+/Limits [(section*.57) (section*.61)]
+>> endobj
+3124 0 obj <<
+/Names [(section*.62) 1415 0 R (section*.63) 1437 0 R (section*.64) 1443 0 R (section*.65) 1445 0 R (section*.66) 1469 0 R (section*.67) 1479 0 R]
+/Limits [(section*.62) (section*.67)]
+>> endobj
+3125 0 obj <<
+/Names [(section*.68) 1481 0 R (section*.69) 1511 0 R (section*.7) 839 0 R (section*.70) 1513 0 R (section*.71) 1523 0 R (section*.72) 1539 0 R]
+/Limits [(section*.68) (section*.72)]
+>> endobj
+3126 0 obj <<
+/Names [(section*.73) 1545 0 R (section*.74) 1547 0 R (section*.75) 1621 0 R (section*.76) 1627 0 R (section*.77) 1629 0 R (section*.78) 1631 0 R]
+/Limits [(section*.73) (section*.78)]
+>> endobj
+3127 0 obj <<
+/Names [(section*.79) 1644 0 R (section*.8) 840 0 R (section*.80) 1661 0 R (section*.81) 1663 0 R (section*.82) 1671 0 R (section*.83) 1696 0 R]
+/Limits [(section*.79) (section*.83)]
+>> endobj
+3128 0 obj <<
+/Names [(section*.84) 1697 0 R (section*.85) 1703 0 R (section*.86) 1705 0 R (section*.87) 1907 0 R (section*.88) 1909 0 R (section*.89) 1917 0 R]
+/Limits [(section*.84) (section*.89)]
+>> endobj
+3129 0 obj <<
+/Names [(section*.9) 846 0 R (section*.90) 1953 0 R (section*.91) 1959 0 R (section*.92) 1961 0 R (section*.93) 2037 0 R (section*.94) 2043 0 R]
+/Limits [(section*.9) (section*.94)]
+>> endobj
+3130 0 obj <<
+/Names [(section*.95) 2045 0 R (section*.96) 2070 0 R (section*.97) 2071 0 R (section*.98) 2072 0 R (section*.99) 2074 0 R (section.1.1) 10 0 R]
+/Limits [(section*.95) (section.1.1)]
+>> endobj
+3131 0 obj <<
+/Names [(section.1.2) 14 0 R (section.1.3) 18 0 R (section.1.4) 22 0 R (section.1.5) 26 0 R (section.1.6) 30 0 R (section.2.1) 38 0 R]
+/Limits [(section.1.2) (section.2.1)]
+>> endobj
+3132 0 obj <<
+/Names [(section.2.2) 42 0 R (section.2.3) 46 0 R (section.2.4) 50 0 R (section.2.5) 54 0 R (section.2.6) 58 0 R (section.3.1) 66 0 R]
+/Limits [(section.2.2) (section.3.1)]
+>> endobj
+3133 0 obj <<
+/Names [(section.3.2) 82 0 R (section.4.1) 98 0 R (section.4.2) 102 0 R (section.4.3) 106 0 R (section.4.4) 118 0 R (section.5.1) 142 0 R]
+/Limits [(section.3.2) (section.5.1)]
+>> endobj
+3134 0 obj <<
+/Names [(section.5.2) 158 0 R (section.6.1) 186 0 R (section.6.2) 190 0 R (section.6.3) 194 0 R (section.6.4) 210 0 R (section.7.1) 238 0 R]
+/Limits [(section.5.2) (section.7.1)]
+>> endobj
+3135 0 obj <<
+/Names [(section.7.10) 326 0 R (section.7.11) 342 0 R (section.7.2) 242 0 R (section.7.3) 254 0 R (section.7.4) 258 0 R (section.7.5) 262 0 R]
+/Limits [(section.7.10) (section.7.5)]
+>> endobj
+3136 0 obj <<
+/Names [(section.7.6) 274 0 R (section.7.7) 278 0 R (section.7.8) 294 0 R (section.7.9) 306 0 R (section.A.1) 350 0 R (section.A.2) 358 0 R]
+/Limits [(section.7.6) (section.A.2)]
+>> endobj
+3137 0 obj <<
+/Names [(section.A.3) 374 0 R (section.B.1) 390 0 R (section.B.2) 394 0 R (section.B.3) 398 0 R (section.B.4) 402 0 R (subsection.3.1.1) 70 0 R]
+/Limits [(section.A.3) (subsection.3.1.1)]
+>> endobj
+3138 0 obj <<
+/Names [(subsection.3.1.2) 74 0 R (subsection.3.1.3) 78 0 R (subsection.3.2.1) 86 0 R (subsection.3.2.2) 90 0 R (subsection.4.3.1) 110 0 R (subsection.4.3.2) 114 0 R]
+/Limits [(subsection.3.1.2) (subsection.4.3.2)]
+>> endobj
+3139 0 obj <<
+/Names [(subsection.4.4.1) 122 0 R (subsection.4.4.2) 126 0 R (subsection.4.4.3) 130 0 R (subsection.4.4.4) 134 0 R (subsection.5.1.1) 146 0 R (subsection.5.1.2) 150 0 R]
+/Limits [(subsection.4.4.1) (subsection.5.1.2)]
+>> endobj
+3140 0 obj <<
+/Names [(subsection.5.1.3) 154 0 R (subsection.5.2.1) 162 0 R (subsection.5.2.2) 166 0 R (subsection.5.2.3) 170 0 R (subsection.5.2.4) 174 0 R (subsection.5.2.5) 178 0 R]
+/Limits [(subsection.5.1.3) (subsection.5.2.5)]
+>> endobj
+3141 0 obj <<
+/Names [(subsection.6.3.1) 198 0 R (subsection.6.3.2) 202 0 R (subsection.6.3.3) 206 0 R (subsection.6.4.1) 214 0 R (subsection.6.4.2) 218 0 R (subsection.6.4.3) 222 0 R]
+/Limits [(subsection.6.3.1) (subsection.6.4.3)]
+>> endobj
+3142 0 obj <<
+/Names [(subsection.6.4.4) 226 0 R (subsection.6.4.5) 230 0 R (subsection.7.10.1) 330 0 R (subsection.7.10.2) 334 0 R (subsection.7.10.3) 338 0 R (subsection.7.2.1) 246 0 R]
+/Limits [(subsection.6.4.4) (subsection.7.2.1)]
+>> endobj
+3143 0 obj <<
+/Names [(subsection.7.2.2) 250 0 R (subsection.7.5.1) 266 0 R (subsection.7.5.2) 270 0 R (subsection.7.7.1) 282 0 R (subsection.7.7.2) 286 0 R (subsection.7.7.3) 290 0 R]
+/Limits [(subsection.7.2.2) (subsection.7.7.3)]
+>> endobj
+3144 0 obj <<
+/Names [(subsection.7.8.1) 298 0 R (subsection.7.8.2) 302 0 R (subsection.7.9.1) 310 0 R (subsection.7.9.2) 314 0 R (subsection.7.9.3) 318 0 R (subsection.7.9.4) 322 0 R]
+/Limits [(subsection.7.8.1) (subsection.7.9.4)]
+>> endobj
+3145 0 obj <<
+/Names [(subsection.A.1.1) 354 0 R (subsection.A.2.1) 362 0 R (subsection.A.2.2) 366 0 R (subsection.A.2.3) 370 0 R (subsection.A.3.1) 378 0 R (subsection.A.3.2) 382 0 R]
+/Limits [(subsection.A.1.1) (subsection.A.3.2)]
+>> endobj
+3146 0 obj <<
+/Names [(table.2.1) 633 0 R (table.3.1) 634 0 R (table.4.1) 635 0 R (table.4.2) 636 0 R (table.6.1) 1064 0 R (table.6.10) 1156 0 R]
+/Limits [(table.2.1) (table.6.10)]
+>> endobj
+3147 0 obj <<
+/Names [(table.6.11) 1186 0 R (table.6.12) 1188 0 R (table.6.13) 1195 0 R (table.6.14) 1207 0 R (table.6.15) 1264 0 R (table.6.16) 1267 0 R]
+/Limits [(table.6.11) (table.6.16)]
+>> endobj
+3148 0 obj <<
+/Names [(table.6.17) 1274 0 R (table.6.18) 641 0 R (table.6.19) 1294 0 R (table.6.2) 1070 0 R (table.6.20) 1301 0 R (table.6.21) 1326 0 R]
+/Limits [(table.6.17) (table.6.21)]
+>> endobj
+3149 0 obj <<
+/Names [(table.6.3) 637 0 R (table.6.4) 638 0 R (table.6.5) 639 0 R (table.6.6) 640 0 R (table.6.7) 1136 0 R (table.6.8) 1138 0 R]
+/Limits [(table.6.3) (table.6.8)]
+>> endobj
+3150 0 obj <<
+/Names [(table.6.9) 1154 0 R (table.7.1) 1350 0 R (table.7.10) 1416 0 R (table.7.11) 644 0 R (table.7.12) 1442 0 R (table.7.13) 1444 0 R]
+/Limits [(table.6.9) (table.7.13)]
+>> endobj
+3151 0 obj <<
+/Names [(table.7.14) 1446 0 R (table.7.15) 1478 0 R (table.7.16) 1480 0 R (table.7.17) 1482 0 R (table.7.18) 645 0 R (table.7.19) 646 0 R]
+/Limits [(table.7.14) (table.7.19)]
+>> endobj
+3152 0 obj <<
+/Names [(table.7.2) 1352 0 R (table.7.20) 1512 0 R (table.7.21) 1514 0 R (table.7.22) 1524 0 R (table.7.23) 647 0 R (table.7.24) 1544 0 R]
+/Limits [(table.7.2) (table.7.24)]
+>> endobj
+3153 0 obj <<
+/Names [(table.7.25) 1546 0 R (table.7.26) 1548 0 R (table.7.27) 1628 0 R (table.7.28) 1630 0 R (table.7.29) 1632 0 R (table.7.3) 642 0 R]
+/Limits [(table.7.25) (table.7.3)]
+>> endobj
+3154 0 obj <<
+/Names [(table.7.30) 1662 0 R (table.7.31) 1670 0 R (table.7.32) 1672 0 R (table.7.33) 648 0 R (table.7.34) 1702 0 R (table.7.35) 1704 0 R]
+/Limits [(table.7.30) (table.7.35)]
+>> endobj
+3155 0 obj <<
+/Names [(table.7.36) 1706 0 R (table.7.37) 1713 0 R (table.7.38) 649 0 R (table.7.39) 1908 0 R (table.7.4) 1378 0 R (table.7.40) 1916 0 R]
+/Limits [(table.7.36) (table.7.40)]
+>> endobj
+3156 0 obj <<
+/Names [(table.7.41) 1918 0 R (table.7.42) 650 0 R (table.7.43) 1954 0 R (table.7.44) 1960 0 R (table.7.45) 1962 0 R (table.7.46) 651 0 R]
+/Limits [(table.7.41) (table.7.46)]
+>> endobj
+3157 0 obj <<
+/Names [(table.7.47) 652 0 R (table.7.48) 2042 0 R (table.7.49) 2044 0 R (table.7.5) 1380 0 R (table.7.50) 2046 0 R (table.7.51) 2073 0 R]
+/Limits [(table.7.47) (table.7.51)]
+>> endobj
+3158 0 obj <<
+/Names [(table.7.52) 2075 0 R (table.7.53) 2081 0 R (table.7.54) 2087 0 R (table.7.55) 2089 0 R (table.7.56) 2105 0 R (table.7.57) 2112 0 R]
+/Limits [(table.7.52) (table.7.57)]
+>> endobj
+3159 0 obj <<
+/Names [(table.7.58) 2114 0 R (table.7.59) 2141 0 R (table.7.6) 1382 0 R (table.7.60) 2150 0 R (table.7.61) 2152 0 R (table.7.62) 2176 0 R]
+/Limits [(table.7.58) (table.7.62)]
+>> endobj
+3160 0 obj <<
+/Names [(table.7.63) 2178 0 R (table.7.64) 2188 0 R (table.7.65) 653 0 R (table.7.66) 2269 0 R (table.7.67) 2277 0 R (table.7.68) 2279 0 R]
+/Limits [(table.7.63) (table.7.68)]
+>> endobj
+3161 0 obj <<
+/Names [(table.7.69) 2300 0 R (table.7.7) 643 0 R (table.7.70) 2302 0 R (table.7.71) 2304 0 R (table.7.72) 2353 0 R (table.7.73) 2370 0 R]
+/Limits [(table.7.69) (table.7.73)]
+>> endobj
+3162 0 obj <<
+/Names [(table.7.74) 2372 0 R (table.7.75) 654 0 R (table.7.76) 2458 0 R (table.7.77) 2460 0 R (table.7.78) 2466 0 R (table.7.79) 2478 0 R]
+/Limits [(table.7.74) (table.7.79)]
+>> endobj
+3163 0 obj <<
+/Names [(table.7.8) 1412 0 R (table.7.80) 2484 0 R (table.7.81) 2486 0 R (table.7.82) 2502 0 R (table.7.83) 2509 0 R (table.7.84) 2511 0 R]
+/Limits [(table.7.8) (table.7.84)]
+>> endobj
+3164 0 obj <<
+/Names [(table.7.85) 655 0 R (table.7.86) 2556 0 R (table.7.87) 2566 0 R (table.7.88) 2573 0 R (table.7.89) 656 0 R (table.7.9) 1414 0 R]
+/Limits [(table.7.85) (table.7.9)]
+>> endobj
+3165 0 obj <<
+/Kids [2938 0 R 2939 0 R 2940 0 R 2941 0 R 2942 0 R 2943 0 R]
+/Limits [(Doc-Start) (Item.13)]
+>> endobj
+3166 0 obj <<
+/Kids [2944 0 R 2945 0 R 2946 0 R 2947 0 R 2948 0 R 2949 0 R]
+/Limits [(Item.130) (Item.162)]
+>> endobj
+3167 0 obj <<
+/Kids [2950 0 R 2951 0 R 2952 0 R 2953 0 R 2954 0 R 2955 0 R]
+/Limits [(Item.163) (Item.195)]
+>> endobj
+3168 0 obj <<
+/Kids [2956 0 R 2957 0 R 2958 0 R 2959 0 R 2960 0 R 2961 0 R]
+/Limits [(Item.196) (Item.227)]
+>> endobj
+3169 0 obj <<
+/Kids [2962 0 R 2963 0 R 2964 0 R 2965 0 R 2966 0 R 2967 0 R]
+/Limits [(Item.228) (Item.26)]
+>> endobj
+3170 0 obj <<
+/Kids [2968 0 R 2969 0 R 2970 0 R 2971 0 R 2972 0 R 2973 0 R]
+/Limits [(Item.260) (Item.292)]
+>> endobj
+3171 0 obj <<
+/Kids [2974 0 R 2975 0 R 2976 0 R 2977 0 R 2978 0 R 2979 0 R]
+/Limits [(Item.293) (Item.324)]
+>> endobj
+3172 0 obj <<
+/Kids [2980 0 R 2981 0 R 2982 0 R 2983 0 R 2984 0 R 2985 0 R]
+/Limits [(Item.325) (Item.357)]
+>> endobj
+3173 0 obj <<
+/Kids [2986 0 R 2987 0 R 2988 0 R 2989 0 R 2990 0 R 2991 0 R]
+/Limits [(Item.358) (Item.39)]
+>> endobj
+3174 0 obj <<
+/Kids [2992 0 R 2993 0 R 2994 0 R 2995 0 R 2996 0 R 2997 0 R]
+/Limits [(Item.390) (Item.421)]
+>> endobj
+3175 0 obj <<
+/Kids [2998 0 R 2999 0 R 3000 0 R 3001 0 R 3002 0 R 3003 0 R]
+/Limits [(Item.422) (Item.454)]
+>> endobj
+3176 0 obj <<
+/Kids [3004 0 R 3005 0 R 3006 0 R 3007 0 R 3008 0 R 3009 0 R]
+/Limits [(Item.455) (Item.487)]
+>> endobj
+3177 0 obj <<
+/Kids [3010 0 R 3011 0 R 3012 0 R 3013 0 R 3014 0 R 3015 0 R]
+/Limits [(Item.488) (Item.519)]
+>> endobj
+3178 0 obj <<
+/Kids [3016 0 R 3017 0 R 3018 0 R 3019 0 R 3020 0 R 3021 0 R]
+/Limits [(Item.52) (Item.551)]
+>> endobj
+3179 0 obj <<
+/Kids [3022 0 R 3023 0 R 3024 0 R 3025 0 R 3026 0 R 3027 0 R]
+/Limits [(Item.552) (Item.584)]
+>> endobj
+3180 0 obj <<
+/Kids [3028 0 R 3029 0 R 3030 0 R 3031 0 R 3032 0 R 3033 0 R]
+/Limits [(Item.585) (Item.616)]
+>> endobj
+3181 0 obj <<
+/Kids [3034 0 R 3035 0 R 3036 0 R 3037 0 R 3038 0 R 3039 0 R]
+/Limits [(Item.617) (Item.649)]
+>> endobj
+3182 0 obj <<
+/Kids [3040 0 R 3041 0 R 3042 0 R 3043 0 R 3044 0 R 3045 0 R]
+/Limits [(Item.65) (Item.681)]
+>> endobj
+3183 0 obj <<
+/Kids [3046 0 R 3047 0 R 3048 0 R 3049 0 R 3050 0 R 3051 0 R]
+/Limits [(Item.682) (Item.713)]
+>> endobj
+3184 0 obj <<
+/Kids [3052 0 R 3053 0 R 3054 0 R 3055 0 R 3056 0 R 3057 0 R]
+/Limits [(Item.714) (Item.746)]
+>> endobj
+3185 0 obj <<
+/Kids [3058 0 R 3059 0 R 3060 0 R 3061 0 R 3062 0 R 3063 0 R]
+/Limits [(Item.747) (appendix.A)]
+>> endobj
+3186 0 obj <<
+/Kids [3064 0 R 3065 0 R 3066 0 R 3067 0 R 3068 0 R 3069 0 R]
+/Limits [(appendix.B) (equation.4.4)]
+>> endobj
+3187 0 obj <<
+/Kids [3070 0 R 3071 0 R 3072 0 R 3073 0 R 3074 0 R 3075 0 R]
+/Limits [(equation.4.5) (page.105)]
+>> endobj
+3188 0 obj <<
+/Kids [3076 0 R 3077 0 R 3078 0 R 3079 0 R 3080 0 R 3081 0 R]
+/Limits [(page.106) (page.138)]
+>> endobj
+3189 0 obj <<
+/Kids [3082 0 R 3083 0 R 3084 0 R 3085 0 R 3086 0 R 3087 0 R]
+/Limits [(page.139) (page.170)]
+>> endobj
+3190 0 obj <<
+/Kids [3088 0 R 3089 0 R 3090 0 R 3091 0 R 3092 0 R 3093 0 R]
+/Limits [(page.171) (page.31)]
+>> endobj
+3191 0 obj <<
+/Kids [3094 0 R 3095 0 R 3096 0 R 3097 0 R 3098 0 R 3099 0 R]
+/Limits [(page.32) (page.64)]
+>> endobj
+3192 0 obj <<
+/Kids [3100 0 R 3101 0 R 3102 0 R 3103 0 R 3104 0 R 3105 0 R]
+/Limits [(page.65) (page.97)]
+>> endobj
+3193 0 obj <<
+/Kids [3106 0 R 3107 0 R 3108 0 R 3109 0 R 3110 0 R 3111 0 R]
+/Limits [(page.98) (section*.117)]
+>> endobj
+3194 0 obj <<
+/Kids [3112 0 R 3113 0 R 3114 0 R 3115 0 R 3116 0 R 3117 0 R]
+/Limits [(section*.118) (section*.26)]
+>> endobj
+3195 0 obj <<
+/Kids [3118 0 R 3119 0 R 3120 0 R 3121 0 R 3122 0 R 3123 0 R]
+/Limits [(section*.27) (section*.61)]
+>> endobj
+3196 0 obj <<
+/Kids [3124 0 R 3125 0 R 3126 0 R 3127 0 R 3128 0 R 3129 0 R]
+/Limits [(section*.62) (section*.94)]
+>> endobj
+3197 0 obj <<
+/Kids [3130 0 R 3131 0 R 3132 0 R 3133 0 R 3134 0 R 3135 0 R]
+/Limits [(section*.95) (section.7.5)]
+>> endobj
+3198 0 obj <<
+/Kids [3136 0 R 3137 0 R 3138 0 R 3139 0 R 3140 0 R 3141 0 R]
+/Limits [(section.7.6) (subsection.6.4.3)]
+>> endobj
+3199 0 obj <<
+/Kids [3142 0 R 3143 0 R 3144 0 R 3145 0 R 3146 0 R 3147 0 R]
+/Limits [(subsection.6.4.4) (table.6.16)]
+>> endobj
+3200 0 obj <<
+/Kids [3148 0 R 3149 0 R 3150 0 R 3151 0 R 3152 0 R 3153 0 R]
+/Limits [(table.6.17) (table.7.3)]
+>> endobj
+3201 0 obj <<
+/Kids [3154 0 R 3155 0 R 3156 0 R 3157 0 R 3158 0 R 3159 0 R]
+/Limits [(table.7.30) (table.7.62)]
+>> endobj
+3202 0 obj <<
+/Kids [3160 0 R 3161 0 R 3162 0 R 3163 0 R 3164 0 R]
+/Limits [(table.7.63) (table.7.9)]
+>> endobj
+3203 0 obj <<
+/Kids [3165 0 R 3166 0 R 3167 0 R 3168 0 R 3169 0 R 3170 0 R]
+/Limits [(Doc-Start) (Item.292)]
+>> endobj
+3204 0 obj <<
+/Kids [3171 0 R 3172 0 R 3173 0 R 3174 0 R 3175 0 R 3176 0 R]
+/Limits [(Item.293) (Item.487)]
+>> endobj
+3205 0 obj <<
+/Kids [3177 0 R 3178 0 R 3179 0 R 3180 0 R 3181 0 R 3182 0 R]
+/Limits [(Item.488) (Item.681)]
+>> endobj
+3206 0 obj <<
+/Kids [3183 0 R 3184 0 R 3185 0 R 3186 0 R 3187 0 R 3188 0 R]
+/Limits [(Item.682) (page.138)]
+>> endobj
+3207 0 obj <<
+/Kids [3189 0 R 3190 0 R 3191 0 R 3192 0 R 3193 0 R 3194 0 R]
+/Limits [(page.139) (section*.26)]
+>> endobj
+3208 0 obj <<
+/Kids [3195 0 R 3196 0 R 3197 0 R 3198 0 R 3199 0 R 3200 0 R]
+/Limits [(section*.27) (table.7.3)]
+>> endobj
+3209 0 obj <<
+/Kids [3201 0 R 3202 0 R]
+/Limits [(table.7.30) (table.7.9)]
+>> endobj
+3210 0 obj <<
+/Kids [3203 0 R 3204 0 R 3205 0 R 3206 0 R 3207 0 R 3208 0 R]
+/Limits [(Doc-Start) (table.7.3)]
+>> endobj
+3211 0 obj <<
+/Kids [3209 0 R]
+/Limits [(table.7.30) (table.7.9)]
+>> endobj
+3212 0 obj <<
+/Kids [3210 0 R 3211 0 R]
+/Limits [(Doc-Start) (table.7.9)]
+>> endobj
+3213 0 obj <<
+/Dests 3212 0 R
+>> endobj
+3214 0 obj <<
+/Type /Catalog
+/Pages 2936 0 R
+/Outlines 2937 0 R
+/Names 3213 0 R
+/PageMode/None/PageLabels << /Nums [0 << /S /r >> 2 << /S /r >> 16 << /S /D >> ] >>
+/OpenAction 409 0 R
+>> endobj
+3215 0 obj <<
+/Author()/Title()/Subject()/Creator(LaTeX with hyperref package)/Producer(pdfTeX-1.40.3)/Keywords()
+/CreationDate (D:20090924115430-07'00')
+/ModDate (D:20090924115430-07'00')
+/Trapped /False
+/PTEX.Fullbanner (This is pdfTeX using libpoppler, Version 3.141592-1.40.3-2.2 (Web2C 7.5.6) kpathsea version 3.5.6)
+>> endobj
+xref
+0 3216
+0000000001 65535 f 
+0000000002 00000 f 
+0000000003 00000 f 
+0000000004 00000 f 
+0000001196 00000 f 
+0000000015 00000 n 
+0000055298 00000 n 
+0000733811 00000 n 
+0000000060 00000 n 
+0000000090 00000 n 
+0000055346 00000 n 
+0000733739 00000 n 
+0000000137 00000 n 
+0000000170 00000 n 
+0000055394 00000 n 
+0000733653 00000 n 
+0000000218 00000 n 
+0000000250 00000 n 
+0000058495 00000 n 
+0000733567 00000 n 
+0000000298 00000 n 
+0000000331 00000 n 
+0000058544 00000 n 
+0000733481 00000 n 
+0000000379 00000 n 
+0000000409 00000 n 
+0000058593 00000 n 
+0000733395 00000 n 
+0000000457 00000 n 
+0000000509 00000 n 
+0000060973 00000 n 
+0000733322 00000 n 
+0000000557 00000 n 
+0000000594 00000 n 
+0000063607 00000 n 
+0000733197 00000 n 
+0000000640 00000 n 
+0000000680 00000 n 
+0000063656 00000 n 
+0000733123 00000 n 
+0000000728 00000 n 
+0000000759 00000 n 
+0000070936 00000 n 
+0000733036 00000 n 
+0000000807 00000 n 
+0000000840 00000 n 
+0000077512 00000 n 
+0000732949 00000 n 
+0000000888 00000 n 
+0000000930 00000 n 
+0000089546 00000 n 
+0000732862 00000 n 
+0000000978 00000 n 
+0000001009 00000 n 
+0000103888 00000 n 
+0000732775 00000 n 
+0000001057 00000 n 
+0000001103 00000 n 
+0000103987 00000 n 
+0000732701 00000 n 
+0000001151 00000 n 
+0000001186 00000 n 
+0000109240 00000 n 
+0000732575 00000 n 
+0000001232 00000 n 
+0000001268 00000 n 
+0000109289 00000 n 
+0000732464 00000 n 
+0000001316 00000 n 
+0000001356 00000 n 
+0000109338 00000 n 
+0000732390 00000 n 
+0000001409 00000 n 
+0000001448 00000 n 
+0000109387 00000 n 
+0000732303 00000 n 
+0000001501 00000 n 
+0000001541 00000 n 
+0000113225 00000 n 
+0000732229 00000 n 
+0000001594 00000 n 
+0000001630 00000 n 
+0000116230 00000 n 
+0000732118 00000 n 
+0000001678 00000 n 
+0000001722 00000 n 
+0000116278 00000 n 
+0000732044 00000 n 
+0000001775 00000 n 
+0000001807 00000 n 
+0000116476 00000 n 
+0000731970 00000 n 
+0000001860 00000 n 
+0000001895 00000 n 
+0000129276 00000 n 
+0000731842 00000 n 
+0000001941 00000 n 
+0000001973 00000 n 
+0000129325 00000 n 
+0000731766 00000 n 
+0000002021 00000 n 
+0000002064 00000 n 
+0000132413 00000 n 
+0000731675 00000 n 
+0000002113 00000 n 
+0000002171 00000 n 
+0000139820 00000 n 
+0000731544 00000 n 
+0000002220 00000 n 
+0000002262 00000 n 
+0000139870 00000 n 
+0000731465 00000 n 
+0000002316 00000 n 
+0000002408 00000 n 
+0000143183 00000 n 
+0000731386 00000 n 
+0000002462 00000 n 
+0000002557 00000 n 
+0000146821 00000 n 
+0000731269 00000 n 
+0000002606 00000 n 
+0000002639 00000 n 
+0000153395 00000 n 
+0000731190 00000 n 
+0000002693 00000 n 
+0000002730 00000 n 
+0000153495 00000 n 
+0000731097 00000 n 
+0000002784 00000 n 
+0000002821 00000 n 
+0000160346 00000 n 
+0000731004 00000 n 
+0000002875 00000 n 
+0000002912 00000 n 
+0000166790 00000 n 
+0000730925 00000 n 
+0000002966 00000 n 
+0000003020 00000 n 
+0000192772 00000 n 
+0000730793 00000 n 
+0000003067 00000 n 
+0000003108 00000 n 
+0000192823 00000 n 
+0000730675 00000 n 
+0000003157 00000 n 
+0000003185 00000 n 
+0000192874 00000 n 
+0000730596 00000 n 
+0000003239 00000 n 
+0000003275 00000 n 
+0000192925 00000 n 
+0000730503 00000 n 
+0000003329 00000 n 
+0000003369 00000 n 
+0000195719 00000 n 
+0000730424 00000 n 
+0000003423 00000 n 
+0000003452 00000 n 
+0000195770 00000 n 
+0000730306 00000 n 
+0000003501 00000 n 
+0000003543 00000 n 
+0000195821 00000 n 
+0000730227 00000 n 
+0000003597 00000 n 
+0000003627 00000 n 
+0000197731 00000 n 
+0000730134 00000 n 
+0000003681 00000 n 
+0000003717 00000 n 
+0000199955 00000 n 
+0000730041 00000 n 
+0000003771 00000 n 
+0000003807 00000 n 
+0000202119 00000 n 
+0000729948 00000 n 
+0000003861 00000 n 
+0000003904 00000 n 
+0000202170 00000 n 
+0000729869 00000 n 
+0000003958 00000 n 
+0000004003 00000 n 
+0000204136 00000 n 
+0000729736 00000 n 
+0000004050 00000 n 
+0000004087 00000 n 
+0000204239 00000 n 
+0000729657 00000 n 
+0000004136 00000 n 
+0000004176 00000 n 
+0000206907 00000 n 
+0000729564 00000 n 
+0000004225 00000 n 
+0000004273 00000 n 
+0000221451 00000 n 
+0000729432 00000 n 
+0000004322 00000 n 
+0000004356 00000 n 
+0000224005 00000 n 
+0000729353 00000 n 
+0000004410 00000 n 
+0000004451 00000 n 
+0000227485 00000 n 
+0000729260 00000 n 
+0000004505 00000 n 
+0000004546 00000 n 
+0000231763 00000 n 
+0000729181 00000 n 
+0000004600 00000 n 
+0000004639 00000 n 
+0000234038 00000 n 
+0000729063 00000 n 
+0000004688 00000 n 
+0000004720 00000 n 
+0000234089 00000 n 
+0000728984 00000 n 
+0000004774 00000 n 
+0000004824 00000 n 
+0000237443 00000 n 
+0000728891 00000 n 
+0000004878 00000 n 
+0000004928 00000 n 
+0000247328 00000 n 
+0000728798 00000 n 
+0000004982 00000 n 
+0000005033 00000 n 
+0000255510 00000 n 
+0000728705 00000 n 
+0000005087 00000 n 
+0000005131 00000 n 
+0000262170 00000 n 
+0000728626 00000 n 
+0000005185 00000 n 
+0000005224 00000 n 
+0000266771 00000 n 
+0000728492 00000 n 
+0000005271 00000 n 
+0000005303 00000 n 
+0000266822 00000 n 
+0000728413 00000 n 
+0000005352 00000 n 
+0000005391 00000 n 
+0000272577 00000 n 
+0000728281 00000 n 
+0000005440 00000 n 
+0000005490 00000 n 
+0000272628 00000 n 
+0000728202 00000 n 
+0000005544 00000 n 
+0000005590 00000 n 
+0000278414 00000 n 
+0000728123 00000 n 
+0000005644 00000 n 
+0000005691 00000 n 
+0000282156 00000 n 
+0000728030 00000 n 
+0000005740 00000 n 
+0000005784 00000 n 
+0000288315 00000 n 
+0000727937 00000 n 
+0000005833 00000 n 
+0000005877 00000 n 
+0000297219 00000 n 
+0000727805 00000 n 
+0000005926 00000 n 
+0000005960 00000 n 
+0000297270 00000 n 
+0000727726 00000 n 
+0000006014 00000 n 
+0000006054 00000 n 
+0000301733 00000 n 
+0000727647 00000 n 
+0000006108 00000 n 
+0000006160 00000 n 
+0000319414 00000 n 
+0000727554 00000 n 
+0000006209 00000 n 
+0000006250 00000 n 
+0000326742 00000 n 
+0000727422 00000 n 
+0000006299 00000 n 
+0000006335 00000 n 
+0000326793 00000 n 
+0000727343 00000 n 
+0000006389 00000 n 
+0000006425 00000 n 
+0000332950 00000 n 
+0000727250 00000 n 
+0000006479 00000 n 
+0000006523 00000 n 
+0000354767 00000 n 
+0000727171 00000 n 
+0000006577 00000 n 
+0000006619 00000 n 
+0000364303 00000 n 
+0000727039 00000 n 
+0000006668 00000 n 
+0000006709 00000 n 
+0000364354 00000 n 
+0000726960 00000 n 
+0000006763 00000 n 
+0000006809 00000 n 
+0000376426 00000 n 
+0000726881 00000 n 
+0000006863 00000 n 
+0000006918 00000 n 
+0000382304 00000 n 
+0000726749 00000 n 
+0000006967 00000 n 
+0000007001 00000 n 
+0000382355 00000 n 
+0000726670 00000 n 
+0000007055 00000 n 
+0000007085 00000 n 
+0000395301 00000 n 
+0000726577 00000 n 
+0000007139 00000 n 
+0000007173 00000 n 
+0000401921 00000 n 
+0000726484 00000 n 
+0000007227 00000 n 
+0000007262 00000 n 
+0000440342 00000 n 
+0000726405 00000 n 
+0000007316 00000 n 
+0000007373 00000 n 
+0000462540 00000 n 
+0000726273 00000 n 
+0000007423 00000 n 
+0000007457 00000 n 
+0000465063 00000 n 
+0000726194 00000 n 
+0000007512 00000 n 
+0000007549 00000 n 
+0000468115 00000 n 
+0000726101 00000 n 
+0000007604 00000 n 
+0000007639 00000 n 
+0000473159 00000 n 
+0000726022 00000 n 
+0000007694 00000 n 
+0000007734 00000 n 
+0000482952 00000 n 
+0000725943 00000 n 
+0000007784 00000 n 
+0000007825 00000 n 
+0000499908 00000 n 
+0000725810 00000 n 
+0000007873 00000 n 
+0000007920 00000 n 
+0000499959 00000 n 
+0000725692 00000 n 
+0000007969 00000 n 
+0000007997 00000 n 
+0000500010 00000 n 
+0000725627 00000 n 
+0000008051 00000 n 
+0000008080 00000 n 
+0000502871 00000 n 
+0000725495 00000 n 
+0000008129 00000 n 
+0000008181 00000 n 
+0000502922 00000 n 
+0000725416 00000 n 
+0000008235 00000 n 
+0000008262 00000 n 
+0000502973 00000 n 
+0000725323 00000 n 
+0000008316 00000 n 
+0000008346 00000 n 
+0000503024 00000 n 
+0000725244 00000 n 
+0000008400 00000 n 
+0000008436 00000 n 
+0000505881 00000 n 
+0000725126 00000 n 
+0000008485 00000 n 
+0000008531 00000 n 
+0000505932 00000 n 
+0000725047 00000 n 
+0000008585 00000 n 
+0000008620 00000 n 
+0000505983 00000 n 
+0000724968 00000 n 
+0000008674 00000 n 
+0000008709 00000 n 
+0000510326 00000 n 
+0000724835 00000 n 
+0000008757 00000 n 
+0000008780 00000 n 
+0000510377 00000 n 
+0000724756 00000 n 
+0000008829 00000 n 
+0000008866 00000 n 
+0000512339 00000 n 
+0000724663 00000 n 
+0000008915 00000 n 
+0000008959 00000 n 
+0000512390 00000 n 
+0000724570 00000 n 
+0000009008 00000 n 
+0000009051 00000 n 
+0000514252 00000 n 
+0000724491 00000 n 
+0000009100 00000 n 
+0000009134 00000 n 
+0000561939 00000 n 
+0000724411 00000 n 
+0000009182 00000 n 
+0000009210 00000 n 
+0000009527 00000 n 
+0000009739 00000 n 
+0000009263 00000 n 
+0000009639 00000 n 
+0000009689 00000 n 
+0000717892 00000 n 
+0000717747 00000 n 
+0000719201 00000 n 
+0000010086 00000 n 
+0000009924 00000 n 
+0000009824 00000 n 
+0000010036 00000 n 
+0000011787 00000 n 
+0000011939 00000 n 
+0000012093 00000 n 
+0000012247 00000 n 
+0000012401 00000 n 
+0000012555 00000 n 
+0000012709 00000 n 
+0000012863 00000 n 
+0000013015 00000 n 
+0000013169 00000 n 
+0000013323 00000 n 
+0000013477 00000 n 
+0000013631 00000 n 
+0000013784 00000 n 
+0000013938 00000 n 
+0000014089 00000 n 
+0000014242 00000 n 
+0000014400 00000 n 
+0000014557 00000 n 
+0000014716 00000 n 
+0000014870 00000 n 
+0000015028 00000 n 
+0000015187 00000 n 
+0000015338 00000 n 
+0000015492 00000 n 
+0000015645 00000 n 
+0000015798 00000 n 
+0000016116 00000 n 
+0000016432 00000 n 
+0000018690 00000 n 
+0000016635 00000 n 
+0000011415 00000 n 
+0000010127 00000 n 
+0000716435 00000 n 
+0000016585 00000 n 
+0000716289 00000 n 
+0000717603 00000 n 
+0000015957 00000 n 
+0000016274 00000 n 
+0000018849 00000 n 
+0000019007 00000 n 
+0000019166 00000 n 
+0000019325 00000 n 
+0000019477 00000 n 
+0000019628 00000 n 
+0000019786 00000 n 
+0000019945 00000 n 
+0000020104 00000 n 
+0000020258 00000 n 
+0000020417 00000 n 
+0000020576 00000 n 
+0000020735 00000 n 
+0000020894 00000 n 
+0000021053 00000 n 
+0000021205 00000 n 
+0000021359 00000 n 
+0000021513 00000 n 
+0000021666 00000 n 
+0000021825 00000 n 
+0000021984 00000 n 
+0000022142 00000 n 
+0000022295 00000 n 
+0000022453 00000 n 
+0000022611 00000 n 
+0000022768 00000 n 
+0000022927 00000 n 
+0000023086 00000 n 
+0000023236 00000 n 
+0000023389 00000 n 
+0000023542 00000 n 
+0000023700 00000 n 
+0000023859 00000 n 
+0000024013 00000 n 
+0000024167 00000 n 
+0000024321 00000 n 
+0000024480 00000 n 
+0000024639 00000 n 
+0000024793 00000 n 
+0000024946 00000 n 
+0000025105 00000 n 
+0000025263 00000 n 
+0000027059 00000 n 
+0000025422 00000 n 
+0000018222 00000 n 
+0000016732 00000 n 
+0000718181 00000 n 
+0000718614 00000 n 
+0000027213 00000 n 
+0000027372 00000 n 
+0000027531 00000 n 
+0000027685 00000 n 
+0000027844 00000 n 
+0000028003 00000 n 
+0000028162 00000 n 
+0000028321 00000 n 
+0000028475 00000 n 
+0000028635 00000 n 
+0000028795 00000 n 
+0000028951 00000 n 
+0000029105 00000 n 
+0000029258 00000 n 
+0000029412 00000 n 
+0000029571 00000 n 
+0000029725 00000 n 
+0000029883 00000 n 
+0000030042 00000 n 
+0000030200 00000 n 
+0000030354 00000 n 
+0000030513 00000 n 
+0000030672 00000 n 
+0000030825 00000 n 
+0000030978 00000 n 
+0000031132 00000 n 
+0000031286 00000 n 
+0000031440 00000 n 
+0000031643 00000 n 
+0000026703 00000 n 
+0000025532 00000 n 
+0000031593 00000 n 
+0000032079 00000 n 
+0000031917 00000 n 
+0000031740 00000 n 
+0000032029 00000 n 
+0000033677 00000 n 
+0000033829 00000 n 
+0000033982 00000 n 
+0000034135 00000 n 
+0000034288 00000 n 
+0000034441 00000 n 
+0000034593 00000 n 
+0000034745 00000 n 
+0000034898 00000 n 
+0000035051 00000 n 
+0000035204 00000 n 
+0000035357 00000 n 
+0000035662 00000 n 
+0000035814 00000 n 
+0000035967 00000 n 
+0000036119 00000 n 
+0000036272 00000 n 
+0000036425 00000 n 
+0000036578 00000 n 
+0000036731 00000 n 
+0000036884 00000 n 
+0000037036 00000 n 
+0000037188 00000 n 
+0000037441 00000 n 
+0000033361 00000 n 
+0000032163 00000 n 
+0000037341 00000 n 
+0000037391 00000 n 
+0000717167 00000 n 
+0000718326 00000 n 
+0000035509 00000 n 
+0000719319 00000 n 
+0000070985 00000 n 
+0000077561 00000 n 
+0000083426 00000 n 
+0000089496 00000 n 
+0000097082 00000 n 
+0000097131 00000 n 
+0000103937 00000 n 
+0000106699 00000 n 
+0000153445 00000 n 
+0000160298 00000 n 
+0000166740 00000 n 
+0000174790 00000 n 
+0000190155 00000 n 
+0000190205 00000 n 
+0000190255 00000 n 
+0000204342 00000 n 
+0000210486 00000 n 
+0000223954 00000 n 
+0000227434 00000 n 
+0000236976 00000 n 
+0000414928 00000 n 
+0000437072 00000 n 
+0000462591 00000 n 
+0000037904 00000 n 
+0000037742 00000 n 
+0000037551 00000 n 
+0000037854 00000 n 
+0000039522 00000 n 
+0000039673 00000 n 
+0000039825 00000 n 
+0000039977 00000 n 
+0000040129 00000 n 
+0000040281 00000 n 
+0000040433 00000 n 
+0000040585 00000 n 
+0000040737 00000 n 
+0000040889 00000 n 
+0000041041 00000 n 
+0000041193 00000 n 
+0000041346 00000 n 
+0000041499 00000 n 
+0000041652 00000 n 
+0000041805 00000 n 
+0000041958 00000 n 
+0000042110 00000 n 
+0000042263 00000 n 
+0000042416 00000 n 
+0000042569 00000 n 
+0000042721 00000 n 
+0000042873 00000 n 
+0000043026 00000 n 
+0000043278 00000 n 
+0000039206 00000 n 
+0000037988 00000 n 
+0000043178 00000 n 
+0000043228 00000 n 
+0000063705 00000 n 
+0000113175 00000 n 
+0000143134 00000 n 
+0000146771 00000 n 
+0000218077 00000 n 
+0000221193 00000 n 
+0000221244 00000 n 
+0000221502 00000 n 
+0000255303 00000 n 
+0000269732 00000 n 
+0000275719 00000 n 
+0000281691 00000 n 
+0000293564 00000 n 
+0000293615 00000 n 
+0000323291 00000 n 
+0000329869 00000 n 
+0000337822 00000 n 
+0000360859 00000 n 
+0000369673 00000 n 
+0000375855 00000 n 
+0000416754 00000 n 
+0000452900 00000 n 
+0000478532 00000 n 
+0000496912 00000 n 
+0000043732 00000 n 
+0000043570 00000 n 
+0000043375 00000 n 
+0000043682 00000 n 
+0000045928 00000 n 
+0000045716 00000 n 
+0000043816 00000 n 
+0000045828 00000 n 
+0000045878 00000 n 
+0000719055 00000 n 
+0000717022 00000 n 
+0000717458 00000 n 
+0000048539 00000 n 
+0000048377 00000 n 
+0000046089 00000 n 
+0000048489 00000 n 
+0000716875 00000 n 
+0000718037 00000 n 
+0000570518 00000 n 
+0000049340 00000 n 
+0000049178 00000 n 
+0000048725 00000 n 
+0000049290 00000 n 
+0000719437 00000 n 
+0000049817 00000 n 
+0000049655 00000 n 
+0000049450 00000 n 
+0000049767 00000 n 
+0000051506 00000 n 
+0000051761 00000 n 
+0000051374 00000 n 
+0000049901 00000 n 
+0000051661 00000 n 
+0000051711 00000 n 
+0000566355 00000 n 
+0000052200 00000 n 
+0000052038 00000 n 
+0000051845 00000 n 
+0000052150 00000 n 
+0000054469 00000 n 
+0000054636 00000 n 
+0000054789 00000 n 
+0000054942 00000 n 
+0000055095 00000 n 
+0000055443 00000 n 
+0000054305 00000 n 
+0000052284 00000 n 
+0000055248 00000 n 
+0000718471 00000 n 
+0000566611 00000 n 
+0000058139 00000 n 
+0000058291 00000 n 
+0000058642 00000 n 
+0000057999 00000 n 
+0000055579 00000 n 
+0000058445 00000 n 
+0000566816 00000 n 
+0000061022 00000 n 
+0000060811 00000 n 
+0000058765 00000 n 
+0000060923 00000 n 
+0000719555 00000 n 
+0000061508 00000 n 
+0000061346 00000 n 
+0000061145 00000 n 
+0000061458 00000 n 
+0000063405 00000 n 
+0000070733 00000 n 
+0000063755 00000 n 
+0000063273 00000 n 
+0000061592 00000 n 
+0000063557 00000 n 
+0000065250 00000 n 
+0000077158 00000 n 
+0000071034 00000 n 
+0000065118 00000 n 
+0000063904 00000 n 
+0000070886 00000 n 
+0000066656 00000 n 
+0000066891 00000 n 
+0000066938 00000 n 
+0000067333 00000 n 
+0000067355 00000 n 
+0000067677 00000 n 
+0000072799 00000 n 
+0000077310 00000 n 
+0000079634 00000 n 
+0000083225 00000 n 
+0000077611 00000 n 
+0000072659 00000 n 
+0000071172 00000 n 
+0000077462 00000 n 
+0000073566 00000 n 
+0000073802 00000 n 
+0000073849 00000 n 
+0000074244 00000 n 
+0000074265 00000 n 
+0000074593 00000 n 
+0000085442 00000 n 
+0000083476 00000 n 
+0000079502 00000 n 
+0000077762 00000 n 
+0000083376 00000 n 
+0000080877 00000 n 
+0000081115 00000 n 
+0000081162 00000 n 
+0000081488 00000 n 
+0000081509 00000 n 
+0000081817 00000 n 
+0000081912 00000 n 
+0000089140 00000 n 
+0000090283 00000 n 
+0000089293 00000 n 
+0000094775 00000 n 
+0000089595 00000 n 
+0000085302 00000 n 
+0000083640 00000 n 
+0000089446 00000 n 
+0000719673 00000 n 
+0000086975 00000 n 
+0000087214 00000 n 
+0000087261 00000 n 
+0000087473 00000 n 
+0000087495 00000 n 
+0000087804 00000 n 
+0000097180 00000 n 
+0000090171 00000 n 
+0000089746 00000 n 
+0000097032 00000 n 
+0000090979 00000 n 
+0000091215 00000 n 
+0000091262 00000 n 
+0000091661 00000 n 
+0000091682 00000 n 
+0000092010 00000 n 
+0000095499 00000 n 
+0000095735 00000 n 
+0000095782 00000 n 
+0000095970 00000 n 
+0000095991 00000 n 
+0000096269 00000 n 
+0000103685 00000 n 
+0000099546 00000 n 
+0000106497 00000 n 
+0000104036 00000 n 
+0000099414 00000 n 
+0000097305 00000 n 
+0000103838 00000 n 
+0000100478 00000 n 
+0000100720 00000 n 
+0000100758 00000 n 
+0000100805 00000 n 
+0000101102 00000 n 
+0000101449 00000 n 
+0000101470 00000 n 
+0000101749 00000 n 
+0000106749 00000 n 
+0000106365 00000 n 
+0000104187 00000 n 
+0000106649 00000 n 
+0000108886 00000 n 
+0000109038 00000 n 
+0000109436 00000 n 
+0000108746 00000 n 
+0000106885 00000 n 
+0000109190 00000 n 
+0000112653 00000 n 
+0000112807 00000 n 
+0000112966 00000 n 
+0000115560 00000 n 
+0000113274 00000 n 
+0000112505 00000 n 
+0000109572 00000 n 
+0000113125 00000 n 
+0000115719 00000 n 
+0000115872 00000 n 
+0000116026 00000 n 
+0000116525 00000 n 
+0000115404 00000 n 
+0000113436 00000 n 
+0000116180 00000 n 
+0000116327 00000 n 
+0000116377 00000 n 
+0000116426 00000 n 
+0000719791 00000 n 
+0000118890 00000 n 
+0000118678 00000 n 
+0000116648 00000 n 
+0000118790 00000 n 
+0000118840 00000 n 
+0000122349 00000 n 
+0000121887 00000 n 
+0000119026 00000 n 
+0000121999 00000 n 
+0000122049 00000 n 
+0000122099 00000 n 
+0000122149 00000 n 
+0000122199 00000 n 
+0000122249 00000 n 
+0000122299 00000 n 
+0000125662 00000 n 
+0000125400 00000 n 
+0000122459 00000 n 
+0000125512 00000 n 
+0000125562 00000 n 
+0000125612 00000 n 
+0000126392 00000 n 
+0000126180 00000 n 
+0000125785 00000 n 
+0000126292 00000 n 
+0000126342 00000 n 
+0000126864 00000 n 
+0000126702 00000 n 
+0000126489 00000 n 
+0000126814 00000 n 
+0000129374 00000 n 
+0000129114 00000 n 
+0000126948 00000 n 
+0000129226 00000 n 
+0000719909 00000 n 
+0000132762 00000 n 
+0000132251 00000 n 
+0000129510 00000 n 
+0000132363 00000 n 
+0000132463 00000 n 
+0000717313 00000 n 
+0000132513 00000 n 
+0000132563 00000 n 
+0000132613 00000 n 
+0000132663 00000 n 
+0000132712 00000 n 
+0000135737 00000 n 
+0000135225 00000 n 
+0000132948 00000 n 
+0000135337 00000 n 
+0000135387 00000 n 
+0000135437 00000 n 
+0000135487 00000 n 
+0000135537 00000 n 
+0000135587 00000 n 
+0000135637 00000 n 
+0000135687 00000 n 
+0000139153 00000 n 
+0000139307 00000 n 
+0000139466 00000 n 
+0000142316 00000 n 
+0000142468 00000 n 
+0000139920 00000 n 
+0000139005 00000 n 
+0000135911 00000 n 
+0000139620 00000 n 
+0000139670 00000 n 
+0000139720 00000 n 
+0000139770 00000 n 
+0000566509 00000 n 
+0000566458 00000 n 
+0000142625 00000 n 
+0000142779 00000 n 
+0000142930 00000 n 
+0000145799 00000 n 
+0000143233 00000 n 
+0000142152 00000 n 
+0000140092 00000 n 
+0000143084 00000 n 
+0000566560 00000 n 
+0000566765 00000 n 
+0000145958 00000 n 
+0000146108 00000 n 
+0000146262 00000 n 
+0000146416 00000 n 
+0000146569 00000 n 
+0000146871 00000 n 
+0000145627 00000 n 
+0000143381 00000 n 
+0000146721 00000 n 
+0000566714 00000 n 
+0000153192 00000 n 
+0000148545 00000 n 
+0000159943 00000 n 
+0000153545 00000 n 
+0000148413 00000 n 
+0000147019 00000 n 
+0000153345 00000 n 
+0000720027 00000 n 
+0000149224 00000 n 
+0000149458 00000 n 
+0000149505 00000 n 
+0000149899 00000 n 
+0000149920 00000 n 
+0000150257 00000 n 
+0000150357 00000 n 
+0000155255 00000 n 
+0000160096 00000 n 
+0000160396 00000 n 
+0000155115 00000 n 
+0000153709 00000 n 
+0000160248 00000 n 
+0000155975 00000 n 
+0000156209 00000 n 
+0000156256 00000 n 
+0000156650 00000 n 
+0000156671 00000 n 
+0000157008 00000 n 
+0000157108 00000 n 
+0000162029 00000 n 
+0000166840 00000 n 
+0000161917 00000 n 
+0000160560 00000 n 
+0000166690 00000 n 
+0000162722 00000 n 
+0000162956 00000 n 
+0000163003 00000 n 
+0000163397 00000 n 
+0000163418 00000 n 
+0000163755 00000 n 
+0000163855 00000 n 
+0000173522 00000 n 
+0000173674 00000 n 
+0000173827 00000 n 
+0000173979 00000 n 
+0000174131 00000 n 
+0000174283 00000 n 
+0000174435 00000 n 
+0000174587 00000 n 
+0000169148 00000 n 
+0000175511 00000 n 
+0000180382 00000 n 
+0000185225 00000 n 
+0000174840 00000 n 
+0000168960 00000 n 
+0000166966 00000 n 
+0000174740 00000 n 
+0000170063 00000 n 
+0000170297 00000 n 
+0000170344 00000 n 
+0000170741 00000 n 
+0000170762 00000 n 
+0000171098 00000 n 
+0000190305 00000 n 
+0000175399 00000 n 
+0000174966 00000 n 
+0000190105 00000 n 
+0000176568 00000 n 
+0000176806 00000 n 
+0000176845 00000 n 
+0000176893 00000 n 
+0000177198 00000 n 
+0000177597 00000 n 
+0000177619 00000 n 
+0000177957 00000 n 
+0000181415 00000 n 
+0000181649 00000 n 
+0000181688 00000 n 
+0000181736 00000 n 
+0000182041 00000 n 
+0000182440 00000 n 
+0000182462 00000 n 
+0000182800 00000 n 
+0000186290 00000 n 
+0000186529 00000 n 
+0000186568 00000 n 
+0000186616 00000 n 
+0000186921 00000 n 
+0000187320 00000 n 
+0000187342 00000 n 
+0000187680 00000 n 
+0000190822 00000 n 
+0000190655 00000 n 
+0000190446 00000 n 
+0000190770 00000 n 
+0000192976 00000 n 
+0000192604 00000 n 
+0000190907 00000 n 
+0000192720 00000 n 
+0000720146 00000 n 
+0000195872 00000 n 
+0000195551 00000 n 
+0000193061 00000 n 
+0000195667 00000 n 
+0000197782 00000 n 
+0000197563 00000 n 
+0000196022 00000 n 
+0000197679 00000 n 
+0000200006 00000 n 
+0000199787 00000 n 
+0000197932 00000 n 
+0000199903 00000 n 
+0000202221 00000 n 
+0000201951 00000 n 
+0000200169 00000 n 
+0000202067 00000 n 
+0000202702 00000 n 
+0000202534 00000 n 
+0000202319 00000 n 
+0000202650 00000 n 
+0000204393 00000 n 
+0000203968 00000 n 
+0000202787 00000 n 
+0000204084 00000 n 
+0000204187 00000 n 
+0000204290 00000 n 
+0000720271 00000 n 
+0000207114 00000 n 
+0000206479 00000 n 
+0000204504 00000 n 
+0000206595 00000 n 
+0000206647 00000 n 
+0000206699 00000 n 
+0000206751 00000 n 
+0000206803 00000 n 
+0000206855 00000 n 
+0000206958 00000 n 
+0000207010 00000 n 
+0000207062 00000 n 
+0000209186 00000 n 
+0000209600 00000 n 
+0000209049 00000 n 
+0000207238 00000 n 
+0000209340 00000 n 
+0000209392 00000 n 
+0000209444 00000 n 
+0000209496 00000 n 
+0000209548 00000 n 
+0000210537 00000 n 
+0000210318 00000 n 
+0000209711 00000 n 
+0000210434 00000 n 
+0000213525 00000 n 
+0000213679 00000 n 
+0000217195 00000 n 
+0000217348 00000 n 
+0000217507 00000 n 
+0000214456 00000 n 
+0000213379 00000 n 
+0000210635 00000 n 
+0000213832 00000 n 
+0000213884 00000 n 
+0000213936 00000 n 
+0000213988 00000 n 
+0000214040 00000 n 
+0000214092 00000 n 
+0000214144 00000 n 
+0000214196 00000 n 
+0000214248 00000 n 
+0000214300 00000 n 
+0000716581 00000 n 
+0000214352 00000 n 
+0000214404 00000 n 
+0000217667 00000 n 
+0000220511 00000 n 
+0000220671 00000 n 
+0000220831 00000 n 
+0000217820 00000 n 
+0000220990 00000 n 
+0000218440 00000 n 
+0000217022 00000 n 
+0000214581 00000 n 
+0000217973 00000 n 
+0000218025 00000 n 
+0000218128 00000 n 
+0000218180 00000 n 
+0000218232 00000 n 
+0000218284 00000 n 
+0000218336 00000 n 
+0000218388 00000 n 
+0000221553 00000 n 
+0000220347 00000 n 
+0000218563 00000 n 
+0000221141 00000 n 
+0000221295 00000 n 
+0000221347 00000 n 
+0000221399 00000 n 
+0000720396 00000 n 
+0000224573 00000 n 
+0000223786 00000 n 
+0000221690 00000 n 
+0000223902 00000 n 
+0000224056 00000 n 
+0000224108 00000 n 
+0000224160 00000 n 
+0000224212 00000 n 
+0000224264 00000 n 
+0000224315 00000 n 
+0000224367 00000 n 
+0000224419 00000 n 
+0000224471 00000 n 
+0000224523 00000 n 
+0000226912 00000 n 
+0000227066 00000 n 
+0000227225 00000 n 
+0000231240 00000 n 
+0000228157 00000 n 
+0000226757 00000 n 
+0000224722 00000 n 
+0000227382 00000 n 
+0000227536 00000 n 
+0000227588 00000 n 
+0000227640 00000 n 
+0000227692 00000 n 
+0000227744 00000 n 
+0000227796 00000 n 
+0000227848 00000 n 
+0000227899 00000 n 
+0000227951 00000 n 
+0000228003 00000 n 
+0000228055 00000 n 
+0000228106 00000 n 
+0000231400 00000 n 
+0000231864 00000 n 
+0000231094 00000 n 
+0000228307 00000 n 
+0000231555 00000 n 
+0000231607 00000 n 
+0000231659 00000 n 
+0000231711 00000 n 
+0000231813 00000 n 
+0000567987 00000 n 
+0000234192 00000 n 
+0000233870 00000 n 
+0000232001 00000 n 
+0000233986 00000 n 
+0000234140 00000 n 
+0000236609 00000 n 
+0000236769 00000 n 
+0000237647 00000 n 
+0000236463 00000 n 
+0000234303 00000 n 
+0000236924 00000 n 
+0000237027 00000 n 
+0000237079 00000 n 
+0000237131 00000 n 
+0000237183 00000 n 
+0000237235 00000 n 
+0000237287 00000 n 
+0000237339 00000 n 
+0000237391 00000 n 
+0000237494 00000 n 
+0000237545 00000 n 
+0000237596 00000 n 
+0000001197 00000 f 
+0000001198 00000 f 
+0000001199 00000 f 
+0000001226 00000 f 
+0000239687 00000 n 
+0000239840 00000 n 
+0000240148 00000 n 
+0000239541 00000 n 
+0000237771 00000 n 
+0000239993 00000 n 
+0000240045 00000 n 
+0000240097 00000 n 
+0000720521 00000 n 
+0000243458 00000 n 
+0000242718 00000 n 
+0000240272 00000 n 
+0000242834 00000 n 
+0000242886 00000 n 
+0000242938 00000 n 
+0000242990 00000 n 
+0000243042 00000 n 
+0000243094 00000 n 
+0000243146 00000 n 
+0000243198 00000 n 
+0000243250 00000 n 
+0000243302 00000 n 
+0000243354 00000 n 
+0000243406 00000 n 
+0000245775 00000 n 
+0000245926 00000 n 
+0000001227 00000 f 
+0000001228 00000 f 
+0000001229 00000 f 
+0000001470 00000 f 
+0000249365 00000 n 
+0000249517 00000 n 
+0000247431 00000 n 
+0000245629 00000 n 
+0000243595 00000 n 
+0000246081 00000 n 
+0000246133 00000 n 
+0000246185 00000 n 
+0000246237 00000 n 
+0000246289 00000 n 
+0000246341 00000 n 
+0000246393 00000 n 
+0000246445 00000 n 
+0000246497 00000 n 
+0000246549 00000 n 
+0000246601 00000 n 
+0000246653 00000 n 
+0000246705 00000 n 
+0000246757 00000 n 
+0000246809 00000 n 
+0000246861 00000 n 
+0000246913 00000 n 
+0000246965 00000 n 
+0000247017 00000 n 
+0000247069 00000 n 
+0000247120 00000 n 
+0000247172 00000 n 
+0000247224 00000 n 
+0000247276 00000 n 
+0000247379 00000 n 
+0000249929 00000 n 
+0000249219 00000 n 
+0000247581 00000 n 
+0000249669 00000 n 
+0000249721 00000 n 
+0000716726 00000 n 
+0000249773 00000 n 
+0000249825 00000 n 
+0000249877 00000 n 
+0000252259 00000 n 
+0000252679 00000 n 
+0000252122 00000 n 
+0000250067 00000 n 
+0000252419 00000 n 
+0000252471 00000 n 
+0000252523 00000 n 
+0000718908 00000 n 
+0000252575 00000 n 
+0000252627 00000 n 
+0000254837 00000 n 
+0000255769 00000 n 
+0000254700 00000 n 
+0000252881 00000 n 
+0000254991 00000 n 
+0000255043 00000 n 
+0000255095 00000 n 
+0000255147 00000 n 
+0000255199 00000 n 
+0000255251 00000 n 
+0000255354 00000 n 
+0000255406 00000 n 
+0000255458 00000 n 
+0000255561 00000 n 
+0000255613 00000 n 
+0000255665 00000 n 
+0000255717 00000 n 
+0000258584 00000 n 
+0000259409 00000 n 
+0000258447 00000 n 
+0000255933 00000 n 
+0000258735 00000 n 
+0000258787 00000 n 
+0000258839 00000 n 
+0000258891 00000 n 
+0000258943 00000 n 
+0000258995 00000 n 
+0000259047 00000 n 
+0000259097 00000 n 
+0000259149 00000 n 
+0000259201 00000 n 
+0000259253 00000 n 
+0000259305 00000 n 
+0000259357 00000 n 
+0000720646 00000 n 
+0000261604 00000 n 
+0000261755 00000 n 
+0000262377 00000 n 
+0000261458 00000 n 
+0000259533 00000 n 
+0000261910 00000 n 
+0000261962 00000 n 
+0000262014 00000 n 
+0000262066 00000 n 
+0000262118 00000 n 
+0000262221 00000 n 
+0000262273 00000 n 
+0000262325 00000 n 
+0000263831 00000 n 
+0000263985 00000 n 
+0000264144 00000 n 
+0000264303 00000 n 
+0000264772 00000 n 
+0000263667 00000 n 
+0000262514 00000 n 
+0000264461 00000 n 
+0000264513 00000 n 
+0000264565 00000 n 
+0000264617 00000 n 
+0000264668 00000 n 
+0000264720 00000 n 
+0000265255 00000 n 
+0000265087 00000 n 
+0000264883 00000 n 
+0000265203 00000 n 
+0000267132 00000 n 
+0000266603 00000 n 
+0000265340 00000 n 
+0000266719 00000 n 
+0000266872 00000 n 
+0000266924 00000 n 
+0000266976 00000 n 
+0000267028 00000 n 
+0000267080 00000 n 
+0000269423 00000 n 
+0000270406 00000 n 
+0000269286 00000 n 
+0000267243 00000 n 
+0000269576 00000 n 
+0000269628 00000 n 
+0000269680 00000 n 
+0000269783 00000 n 
+0000269835 00000 n 
+0000269887 00000 n 
+0000269938 00000 n 
+0000269990 00000 n 
+0000270042 00000 n 
+0000270094 00000 n 
+0000270146 00000 n 
+0000270198 00000 n 
+0000270250 00000 n 
+0000270302 00000 n 
+0000270354 00000 n 
+0000272365 00000 n 
+0000272991 00000 n 
+0000272228 00000 n 
+0000270517 00000 n 
+0000272525 00000 n 
+0000272679 00000 n 
+0000272731 00000 n 
+0000272783 00000 n 
+0000272835 00000 n 
+0000272887 00000 n 
+0000272939 00000 n 
+0000720771 00000 n 
+0000275101 00000 n 
+0000275254 00000 n 
+0000276082 00000 n 
+0000274955 00000 n 
+0000273115 00000 n 
+0000275407 00000 n 
+0000275459 00000 n 
+0000275511 00000 n 
+0000275563 00000 n 
+0000275615 00000 n 
+0000275667 00000 n 
+0000275770 00000 n 
+0000275822 00000 n 
+0000275874 00000 n 
+0000275926 00000 n 
+0000275978 00000 n 
+0000276030 00000 n 
+0000278004 00000 n 
+0000280760 00000 n 
+0000278774 00000 n 
+0000277867 00000 n 
+0000276206 00000 n 
+0000278154 00000 n 
+0000278206 00000 n 
+0000278258 00000 n 
+0000278310 00000 n 
+0000278362 00000 n 
+0000278465 00000 n 
+0000278516 00000 n 
+0000278568 00000 n 
+0000278620 00000 n 
+0000278671 00000 n 
+0000278723 00000 n 
+0000280920 00000 n 
+0000281074 00000 n 
+0000281227 00000 n 
+0000282259 00000 n 
+0000280596 00000 n 
+0000278898 00000 n 
+0000281379 00000 n 
+0000281431 00000 n 
+0000281483 00000 n 
+0000281535 00000 n 
+0000281587 00000 n 
+0000281639 00000 n 
+0000281742 00000 n 
+0000281794 00000 n 
+0000281846 00000 n 
+0000281898 00000 n 
+0000281950 00000 n 
+0000282001 00000 n 
+0000282052 00000 n 
+0000282104 00000 n 
+0000282207 00000 n 
+0000284455 00000 n 
+0000284027 00000 n 
+0000282409 00000 n 
+0000284143 00000 n 
+0000284195 00000 n 
+0000284247 00000 n 
+0000284299 00000 n 
+0000284351 00000 n 
+0000284403 00000 n 
+0000287007 00000 n 
+0000287167 00000 n 
+0000287326 00000 n 
+0000288418 00000 n 
+0000286852 00000 n 
+0000284566 00000 n 
+0000287485 00000 n 
+0000287537 00000 n 
+0000287589 00000 n 
+0000287641 00000 n 
+0000287693 00000 n 
+0000287745 00000 n 
+0000287796 00000 n 
+0000287848 00000 n 
+0000287900 00000 n 
+0000287952 00000 n 
+0000288004 00000 n 
+0000288055 00000 n 
+0000288107 00000 n 
+0000288159 00000 n 
+0000288211 00000 n 
+0000288263 00000 n 
+0000288366 00000 n 
+0000001471 00000 f 
+0000002119 00000 f 
+0000290389 00000 n 
+0000290542 00000 n 
+0000291008 00000 n 
+0000290243 00000 n 
+0000288555 00000 n 
+0000290696 00000 n 
+0000290748 00000 n 
+0000290800 00000 n 
+0000290852 00000 n 
+0000290904 00000 n 
+0000290956 00000 n 
+0000720896 00000 n 
+0000293206 00000 n 
+0000293359 00000 n 
+0000293872 00000 n 
+0000293060 00000 n 
+0000291119 00000 n 
+0000293512 00000 n 
+0000293666 00000 n 
+0000293717 00000 n 
+0000293768 00000 n 
+0000293820 00000 n 
+0000296187 00000 n 
+0000296339 00000 n 
+0000296493 00000 n 
+0000297529 00000 n 
+0000296032 00000 n 
+0000294009 00000 n 
+0000296647 00000 n 
+0000296699 00000 n 
+0000296751 00000 n 
+0000296803 00000 n 
+0000296855 00000 n 
+0000296907 00000 n 
+0000296959 00000 n 
+0000297011 00000 n 
+0000297063 00000 n 
+0000297115 00000 n 
+0000297167 00000 n 
+0000297321 00000 n 
+0000297373 00000 n 
+0000297425 00000 n 
+0000297477 00000 n 
+0000299842 00000 n 
+0000299996 00000 n 
+0000300156 00000 n 
+0000300310 00000 n 
+0000301139 00000 n 
+0000299678 00000 n 
+0000297653 00000 n 
+0000300463 00000 n 
+0000300515 00000 n 
+0000300567 00000 n 
+0000300619 00000 n 
+0000300671 00000 n 
+0000300723 00000 n 
+0000300775 00000 n 
+0000300827 00000 n 
+0000300879 00000 n 
+0000300931 00000 n 
+0000300983 00000 n 
+0000301035 00000 n 
+0000301087 00000 n 
+0000301835 00000 n 
+0000301565 00000 n 
+0000301263 00000 n 
+0000301681 00000 n 
+0000301784 00000 n 
+0000303809 00000 n 
+0000303381 00000 n 
+0000301946 00000 n 
+0000303497 00000 n 
+0000303549 00000 n 
+0000303601 00000 n 
+0000303653 00000 n 
+0000303705 00000 n 
+0000303757 00000 n 
+0000305903 00000 n 
+0000305735 00000 n 
+0000303920 00000 n 
+0000305851 00000 n 
+0000721021 00000 n 
+0000308420 00000 n 
+0000308578 00000 n 
+0000308737 00000 n 
+0000308896 00000 n 
+0000310143 00000 n 
+0000308256 00000 n 
+0000306001 00000 n 
+0000309055 00000 n 
+0000309107 00000 n 
+0000309159 00000 n 
+0000309211 00000 n 
+0000309263 00000 n 
+0000309314 00000 n 
+0000309366 00000 n 
+0000309418 00000 n 
+0000309470 00000 n 
+0000309522 00000 n 
+0000309574 00000 n 
+0000309626 00000 n 
+0000309678 00000 n 
+0000309730 00000 n 
+0000309781 00000 n 
+0000309832 00000 n 
+0000309884 00000 n 
+0000309936 00000 n 
+0000309988 00000 n 
+0000310040 00000 n 
+0000310092 00000 n 
+0000312906 00000 n 
+0000312064 00000 n 
+0000310280 00000 n 
+0000312180 00000 n 
+0000312232 00000 n 
+0000312284 00000 n 
+0000312336 00000 n 
+0000312388 00000 n 
+0000312440 00000 n 
+0000312492 00000 n 
+0000312544 00000 n 
+0000312596 00000 n 
+0000312648 00000 n 
+0000312699 00000 n 
+0000312751 00000 n 
+0000312802 00000 n 
+0000312854 00000 n 
+0000315934 00000 n 
+0000316094 00000 n 
+0000317186 00000 n 
+0000315788 00000 n 
+0000313055 00000 n 
+0000316254 00000 n 
+0000316306 00000 n 
+0000316358 00000 n 
+0000316410 00000 n 
+0000316462 00000 n 
+0000316514 00000 n 
+0000316565 00000 n 
+0000316616 00000 n 
+0000316668 00000 n 
+0000316719 00000 n 
+0000316770 00000 n 
+0000316822 00000 n 
+0000316874 00000 n 
+0000316926 00000 n 
+0000316978 00000 n 
+0000317030 00000 n 
+0000317082 00000 n 
+0000317134 00000 n 
+0000319777 00000 n 
+0000319246 00000 n 
+0000317310 00000 n 
+0000319362 00000 n 
+0000718760 00000 n 
+0000319465 00000 n 
+0000319517 00000 n 
+0000319569 00000 n 
+0000319621 00000 n 
+0000319673 00000 n 
+0000319725 00000 n 
+0000321539 00000 n 
+0000322113 00000 n 
+0000321402 00000 n 
+0000319915 00000 n 
+0000321698 00000 n 
+0000321750 00000 n 
+0000321801 00000 n 
+0000321853 00000 n 
+0000321905 00000 n 
+0000321957 00000 n 
+0000322009 00000 n 
+0000322061 00000 n 
+0000323342 00000 n 
+0000323123 00000 n 
+0000322237 00000 n 
+0000323239 00000 n 
+0000721146 00000 n 
+0000323836 00000 n 
+0000323668 00000 n 
+0000323466 00000 n 
+0000323784 00000 n 
+0000326210 00000 n 
+0000326370 00000 n 
+0000326530 00000 n 
+0000327000 00000 n 
+0000326055 00000 n 
+0000323921 00000 n 
+0000326690 00000 n 
+0000326844 00000 n 
+0000326896 00000 n 
+0000326948 00000 n 
+0000329348 00000 n 
+0000329502 00000 n 
+0000329920 00000 n 
+0000329202 00000 n 
+0000327164 00000 n 
+0000329661 00000 n 
+0000329713 00000 n 
+0000329765 00000 n 
+0000329817 00000 n 
+0000333053 00000 n 
+0000331744 00000 n 
+0000330057 00000 n 
+0000331860 00000 n 
+0000331912 00000 n 
+0000331964 00000 n 
+0000332016 00000 n 
+0000332068 00000 n 
+0000332120 00000 n 
+0000332171 00000 n 
+0000332223 00000 n 
+0000332275 00000 n 
+0000332327 00000 n 
+0000332379 00000 n 
+0000332431 00000 n 
+0000332483 00000 n 
+0000332535 00000 n 
+0000332586 00000 n 
+0000332638 00000 n 
+0000332690 00000 n 
+0000332742 00000 n 
+0000332794 00000 n 
+0000332846 00000 n 
+0000332898 00000 n 
+0000333001 00000 n 
+0000335204 00000 n 
+0000334777 00000 n 
+0000333204 00000 n 
+0000334893 00000 n 
+0000334945 00000 n 
+0000334997 00000 n 
+0000335049 00000 n 
+0000335101 00000 n 
+0000335153 00000 n 
+0000337407 00000 n 
+0000337561 00000 n 
+0000337873 00000 n 
+0000337261 00000 n 
+0000335355 00000 n 
+0000337719 00000 n 
+0000337771 00000 n 
+0000721271 00000 n 
+0000340631 00000 n 
+0000339009 00000 n 
+0000337997 00000 n 
+0000339125 00000 n 
+0000339177 00000 n 
+0000339229 00000 n 
+0000339281 00000 n 
+0000339333 00000 n 
+0000339384 00000 n 
+0000339436 00000 n 
+0000339488 00000 n 
+0000339540 00000 n 
+0000339592 00000 n 
+0000339644 00000 n 
+0000339696 00000 n 
+0000339748 00000 n 
+0000339800 00000 n 
+0000339852 00000 n 
+0000339904 00000 n 
+0000339956 00000 n 
+0000340008 00000 n 
+0000340060 00000 n 
+0000340112 00000 n 
+0000340164 00000 n 
+0000340215 00000 n 
+0000340267 00000 n 
+0000340319 00000 n 
+0000340371 00000 n 
+0000340423 00000 n 
+0000340475 00000 n 
+0000340527 00000 n 
+0000340579 00000 n 
+0000343412 00000 n 
+0000341582 00000 n 
+0000340769 00000 n 
+0000341698 00000 n 
+0000341750 00000 n 
+0000341802 00000 n 
+0000341854 00000 n 
+0000341906 00000 n 
+0000341958 00000 n 
+0000342010 00000 n 
+0000342062 00000 n 
+0000342114 00000 n 
+0000342166 00000 n 
+0000342218 00000 n 
+0000342270 00000 n 
+0000342321 00000 n 
+0000342373 00000 n 
+0000342425 00000 n 
+0000342477 00000 n 
+0000342529 00000 n 
+0000342580 00000 n 
+0000342632 00000 n 
+0000342684 00000 n 
+0000342736 00000 n 
+0000342788 00000 n 
+0000342840 00000 n 
+0000342892 00000 n 
+0000342944 00000 n 
+0000342996 00000 n 
+0000343048 00000 n 
+0000343100 00000 n 
+0000343152 00000 n 
+0000343204 00000 n 
+0000343256 00000 n 
+0000343308 00000 n 
+0000343360 00000 n 
+0000346192 00000 n 
+0000344308 00000 n 
+0000343537 00000 n 
+0000344424 00000 n 
+0000344476 00000 n 
+0000344528 00000 n 
+0000344580 00000 n 
+0000344632 00000 n 
+0000344684 00000 n 
+0000344736 00000 n 
+0000344788 00000 n 
+0000344840 00000 n 
+0000344892 00000 n 
+0000344944 00000 n 
+0000344996 00000 n 
+0000345048 00000 n 
+0000345100 00000 n 
+0000345152 00000 n 
+0000345204 00000 n 
+0000345256 00000 n 
+0000345308 00000 n 
+0000345360 00000 n 
+0000345412 00000 n 
+0000345464 00000 n 
+0000345516 00000 n 
+0000345568 00000 n 
+0000345620 00000 n 
+0000345672 00000 n 
+0000345724 00000 n 
+0000345776 00000 n 
+0000345828 00000 n 
+0000345880 00000 n 
+0000345932 00000 n 
+0000345984 00000 n 
+0000346036 00000 n 
+0000346088 00000 n 
+0000346140 00000 n 
+0000349099 00000 n 
+0000347323 00000 n 
+0000346317 00000 n 
+0000347439 00000 n 
+0000347491 00000 n 
+0000347543 00000 n 
+0000347595 00000 n 
+0000347647 00000 n 
+0000347699 00000 n 
+0000347750 00000 n 
+0000347802 00000 n 
+0000347854 00000 n 
+0000347906 00000 n 
+0000347958 00000 n 
+0000348010 00000 n 
+0000348062 00000 n 
+0000348114 00000 n 
+0000348166 00000 n 
+0000348218 00000 n 
+0000348269 00000 n 
+0000348321 00000 n 
+0000348371 00000 n 
+0000348423 00000 n 
+0000348475 00000 n 
+0000348527 00000 n 
+0000348579 00000 n 
+0000348631 00000 n 
+0000348683 00000 n 
+0000348735 00000 n 
+0000348787 00000 n 
+0000348839 00000 n 
+0000348891 00000 n 
+0000348943 00000 n 
+0000348995 00000 n 
+0000349047 00000 n 
+0000352145 00000 n 
+0000350422 00000 n 
+0000349237 00000 n 
+0000350538 00000 n 
+0000350590 00000 n 
+0000350642 00000 n 
+0000350693 00000 n 
+0000350745 00000 n 
+0000350797 00000 n 
+0000350849 00000 n 
+0000350901 00000 n 
+0000350953 00000 n 
+0000351005 00000 n 
+0000351057 00000 n 
+0000351108 00000 n 
+0000351160 00000 n 
+0000351212 00000 n 
+0000351264 00000 n 
+0000351316 00000 n 
+0000351368 00000 n 
+0000351419 00000 n 
+0000351471 00000 n 
+0000351523 00000 n 
+0000351575 00000 n 
+0000351627 00000 n 
+0000351679 00000 n 
+0000351731 00000 n 
+0000351782 00000 n 
+0000351834 00000 n 
+0000351886 00000 n 
+0000351938 00000 n 
+0000351990 00000 n 
+0000352042 00000 n 
+0000352094 00000 n 
+0000354974 00000 n 
+0000353871 00000 n 
+0000352283 00000 n 
+0000353987 00000 n 
+0000354039 00000 n 
+0000354091 00000 n 
+0000354143 00000 n 
+0000354195 00000 n 
+0000354247 00000 n 
+0000354299 00000 n 
+0000354351 00000 n 
+0000354403 00000 n 
+0000354455 00000 n 
+0000354507 00000 n 
+0000354559 00000 n 
+0000354611 00000 n 
+0000354663 00000 n 
+0000354715 00000 n 
+0000354818 00000 n 
+0000354870 00000 n 
+0000354922 00000 n 
+0000721396 00000 n 
+0000359718 00000 n 
+0000357146 00000 n 
+0000356822 00000 n 
+0000355125 00000 n 
+0000356938 00000 n 
+0000356990 00000 n 
+0000357042 00000 n 
+0000357094 00000 n 
+0000359874 00000 n 
+0000363517 00000 n 
+0000361066 00000 n 
+0000359572 00000 n 
+0000357282 00000 n 
+0000360028 00000 n 
+0000360080 00000 n 
+0000360132 00000 n 
+0000360184 00000 n 
+0000360236 00000 n 
+0000360288 00000 n 
+0000360339 00000 n 
+0000360391 00000 n 
+0000360443 00000 n 
+0000360495 00000 n 
+0000360547 00000 n 
+0000360599 00000 n 
+0000360651 00000 n 
+0000360703 00000 n 
+0000360755 00000 n 
+0000360807 00000 n 
+0000360910 00000 n 
+0000360962 00000 n 
+0000361014 00000 n 
+0000422148 00000 n 
+0000363677 00000 n 
+0000363837 00000 n 
+0000363992 00000 n 
+0000364506 00000 n 
+0000363353 00000 n 
+0000361215 00000 n 
+0000364147 00000 n 
+0000364199 00000 n 
+0000364251 00000 n 
+0000364403 00000 n 
+0000364454 00000 n 
+0000366953 00000 n 
+0000366579 00000 n 
+0000364657 00000 n 
+0000366695 00000 n 
+0000366747 00000 n 
+0000366799 00000 n 
+0000366851 00000 n 
+0000366903 00000 n 
+0000369055 00000 n 
+0000369209 00000 n 
+0000369363 00000 n 
+0000370502 00000 n 
+0000368900 00000 n 
+0000367064 00000 n 
+0000369517 00000 n 
+0000369569 00000 n 
+0000369621 00000 n 
+0000369724 00000 n 
+0000369776 00000 n 
+0000369828 00000 n 
+0000369880 00000 n 
+0000369932 00000 n 
+0000369984 00000 n 
+0000370036 00000 n 
+0000370088 00000 n 
+0000370140 00000 n 
+0000370192 00000 n 
+0000370243 00000 n 
+0000370294 00000 n 
+0000370346 00000 n 
+0000370398 00000 n 
+0000370450 00000 n 
+0000372193 00000 n 
+0000372347 00000 n 
+0000372501 00000 n 
+0000374161 00000 n 
+0000372038 00000 n 
+0000370627 00000 n 
+0000372654 00000 n 
+0000372706 00000 n 
+0000372758 00000 n 
+0000372810 00000 n 
+0000372862 00000 n 
+0000372914 00000 n 
+0000372966 00000 n 
+0000373018 00000 n 
+0000373070 00000 n 
+0000373122 00000 n 
+0000373174 00000 n 
+0000373225 00000 n 
+0000373277 00000 n 
+0000373329 00000 n 
+0000373381 00000 n 
+0000373433 00000 n 
+0000373485 00000 n 
+0000373537 00000 n 
+0000373589 00000 n 
+0000373641 00000 n 
+0000373693 00000 n 
+0000373745 00000 n 
+0000373797 00000 n 
+0000373849 00000 n 
+0000373901 00000 n 
+0000373953 00000 n 
+0000374005 00000 n 
+0000374057 00000 n 
+0000374109 00000 n 
+0000721521 00000 n 
+0000376529 00000 n 
+0000375687 00000 n 
+0000374272 00000 n 
+0000375803 00000 n 
+0000375906 00000 n 
+0000375958 00000 n 
+0000376010 00000 n 
+0000376062 00000 n 
+0000376114 00000 n 
+0000376166 00000 n 
+0000376218 00000 n 
+0000376270 00000 n 
+0000376322 00000 n 
+0000376374 00000 n 
+0000376477 00000 n 
+0000378704 00000 n 
+0000378276 00000 n 
+0000376666 00000 n 
+0000378392 00000 n 
+0000378444 00000 n 
+0000378496 00000 n 
+0000378548 00000 n 
+0000378600 00000 n 
+0000378652 00000 n 
+0000381263 00000 n 
+0000381423 00000 n 
+0000382406 00000 n 
+0000381117 00000 n 
+0000378828 00000 n 
+0000381576 00000 n 
+0000381628 00000 n 
+0000381680 00000 n 
+0000381732 00000 n 
+0000381784 00000 n 
+0000381836 00000 n 
+0000381888 00000 n 
+0000381940 00000 n 
+0000381992 00000 n 
+0000382044 00000 n 
+0000382096 00000 n 
+0000382148 00000 n 
+0000382200 00000 n 
+0000382252 00000 n 
+0000384875 00000 n 
+0000384083 00000 n 
+0000382530 00000 n 
+0000384199 00000 n 
+0000384251 00000 n 
+0000384303 00000 n 
+0000384355 00000 n 
+0000384407 00000 n 
+0000384459 00000 n 
+0000384511 00000 n 
+0000384563 00000 n 
+0000384615 00000 n 
+0000384667 00000 n 
+0000384719 00000 n 
+0000384771 00000 n 
+0000384823 00000 n 
+0000386965 00000 n 
+0000386589 00000 n 
+0000384999 00000 n 
+0000386705 00000 n 
+0000386757 00000 n 
+0000386809 00000 n 
+0000386861 00000 n 
+0000386913 00000 n 
+0000389693 00000 n 
+0000388901 00000 n 
+0000387089 00000 n 
+0000389017 00000 n 
+0000389069 00000 n 
+0000389121 00000 n 
+0000389173 00000 n 
+0000389225 00000 n 
+0000389277 00000 n 
+0000389329 00000 n 
+0000389381 00000 n 
+0000389433 00000 n 
+0000389485 00000 n 
+0000389537 00000 n 
+0000389589 00000 n 
+0000389641 00000 n 
+0000721646 00000 n 
+0000392429 00000 n 
+0000391847 00000 n 
+0000389817 00000 n 
+0000391963 00000 n 
+0000392015 00000 n 
+0000392067 00000 n 
+0000392119 00000 n 
+0000392171 00000 n 
+0000392221 00000 n 
+0000392273 00000 n 
+0000392325 00000 n 
+0000392377 00000 n 
+0000002120 00000 f 
+0000002121 00000 f 
+0000002122 00000 f 
+0000002142 00000 f 
+0000397304 00000 n 
+0000397456 00000 n 
+0000395456 00000 n 
+0000394562 00000 n 
+0000392553 00000 n 
+0000394678 00000 n 
+0000394730 00000 n 
+0000394782 00000 n 
+0000394834 00000 n 
+0000394886 00000 n 
+0000394938 00000 n 
+0000394990 00000 n 
+0000395041 00000 n 
+0000395093 00000 n 
+0000395145 00000 n 
+0000395197 00000 n 
+0000395249 00000 n 
+0000395352 00000 n 
+0000395404 00000 n 
+0000002143 00000 f 
+0000002247 00000 f 
+0000397608 00000 n 
+0000398021 00000 n 
+0000397149 00000 n 
+0000395606 00000 n 
+0000397763 00000 n 
+0000397815 00000 n 
+0000397867 00000 n 
+0000397917 00000 n 
+0000397969 00000 n 
+0000400879 00000 n 
+0000401039 00000 n 
+0000401197 00000 n 
+0000401971 00000 n 
+0000400724 00000 n 
+0000398159 00000 n 
+0000401351 00000 n 
+0000401403 00000 n 
+0000401455 00000 n 
+0000401506 00000 n 
+0000401558 00000 n 
+0000401609 00000 n 
+0000401661 00000 n 
+0000401713 00000 n 
+0000401765 00000 n 
+0000401817 00000 n 
+0000401869 00000 n 
+0000404635 00000 n 
+0000404155 00000 n 
+0000402135 00000 n 
+0000404271 00000 n 
+0000404323 00000 n 
+0000404375 00000 n 
+0000404427 00000 n 
+0000404479 00000 n 
+0000404531 00000 n 
+0000404583 00000 n 
+0000414365 00000 n 
+0000406973 00000 n 
+0000414519 00000 n 
+0000414670 00000 n 
+0000414977 00000 n 
+0000406818 00000 n 
+0000404772 00000 n 
+0000414824 00000 n 
+0000414876 00000 n 
+0000721771 00000 n 
+0000412017 00000 n 
+0000412248 00000 n 
+0000412296 00000 n 
+0000412562 00000 n 
+0000412585 00000 n 
+0000412867 00000 n 
+0000412963 00000 n 
+0000566406 00000 n 
+0000417584 00000 n 
+0000416586 00000 n 
+0000415143 00000 n 
+0000416702 00000 n 
+0000416805 00000 n 
+0000416857 00000 n 
+0000416909 00000 n 
+0000416961 00000 n 
+0000417013 00000 n 
+0000417065 00000 n 
+0000417117 00000 n 
+0000417169 00000 n 
+0000417221 00000 n 
+0000417273 00000 n 
+0000417325 00000 n 
+0000417377 00000 n 
+0000417428 00000 n 
+0000417480 00000 n 
+0000417532 00000 n 
+0000420008 00000 n 
+0000418489 00000 n 
+0000417708 00000 n 
+0000418605 00000 n 
+0000418657 00000 n 
+0000418709 00000 n 
+0000418761 00000 n 
+0000418813 00000 n 
+0000418865 00000 n 
+0000418917 00000 n 
+0000418969 00000 n 
+0000419021 00000 n 
+0000419073 00000 n 
+0000419125 00000 n 
+0000419177 00000 n 
+0000419229 00000 n 
+0000419281 00000 n 
+0000419333 00000 n 
+0000419385 00000 n 
+0000419437 00000 n 
+0000419489 00000 n 
+0000419541 00000 n 
+0000419593 00000 n 
+0000419645 00000 n 
+0000419697 00000 n 
+0000419749 00000 n 
+0000419801 00000 n 
+0000419853 00000 n 
+0000419904 00000 n 
+0000419956 00000 n 
+0000002248 00000 f 
+0000002362 00000 f 
+0000421216 00000 n 
+0000422353 00000 n 
+0000421079 00000 n 
+0000420132 00000 n 
+0000421371 00000 n 
+0000421423 00000 n 
+0000421475 00000 n 
+0000421527 00000 n 
+0000421579 00000 n 
+0000421631 00000 n 
+0000421683 00000 n 
+0000421735 00000 n 
+0000421787 00000 n 
+0000421839 00000 n 
+0000421891 00000 n 
+0000421943 00000 n 
+0000421995 00000 n 
+0000422047 00000 n 
+0000422098 00000 n 
+0000422199 00000 n 
+0000422250 00000 n 
+0000422302 00000 n 
+0000424376 00000 n 
+0000424531 00000 n 
+0000425516 00000 n 
+0000424230 00000 n 
+0000422464 00000 n 
+0000424686 00000 n 
+0000424738 00000 n 
+0000424790 00000 n 
+0000424842 00000 n 
+0000424894 00000 n 
+0000424946 00000 n 
+0000424998 00000 n 
+0000425050 00000 n 
+0000425102 00000 n 
+0000425154 00000 n 
+0000425206 00000 n 
+0000425258 00000 n 
+0000425309 00000 n 
+0000425360 00000 n 
+0000425412 00000 n 
+0000425464 00000 n 
+0000429608 00000 n 
+0000427754 00000 n 
+0000428321 00000 n 
+0000427617 00000 n 
+0000425653 00000 n 
+0000427908 00000 n 
+0000427960 00000 n 
+0000428011 00000 n 
+0000428062 00000 n 
+0000428114 00000 n 
+0000428166 00000 n 
+0000428217 00000 n 
+0000428269 00000 n 
+0000437745 00000 n 
+0000429492 00000 n 
+0000428431 00000 n 
+0000437020 00000 n 
+0000437123 00000 n 
+0000437175 00000 n 
+0000437226 00000 n 
+0000437278 00000 n 
+0000437330 00000 n 
+0000437381 00000 n 
+0000437433 00000 n 
+0000437485 00000 n 
+0000437537 00000 n 
+0000437589 00000 n 
+0000437641 00000 n 
+0000437693 00000 n 
+0000721896 00000 n 
+0000434672 00000 n 
+0000434903 00000 n 
+0000434951 00000 n 
+0000435217 00000 n 
+0000435240 00000 n 
+0000435522 00000 n 
+0000435618 00000 n 
+0000440497 00000 n 
+0000439187 00000 n 
+0000437912 00000 n 
+0000439303 00000 n 
+0000439355 00000 n 
+0000439407 00000 n 
+0000439459 00000 n 
+0000439511 00000 n 
+0000439563 00000 n 
+0000439615 00000 n 
+0000439667 00000 n 
+0000439719 00000 n 
+0000439771 00000 n 
+0000439823 00000 n 
+0000439875 00000 n 
+0000439927 00000 n 
+0000439979 00000 n 
+0000440031 00000 n 
+0000440083 00000 n 
+0000440134 00000 n 
+0000440186 00000 n 
+0000440238 00000 n 
+0000440290 00000 n 
+0000440393 00000 n 
+0000440445 00000 n 
+0000442492 00000 n 
+0000442324 00000 n 
+0000440647 00000 n 
+0000442440 00000 n 
+0000444276 00000 n 
+0000444108 00000 n 
+0000442655 00000 n 
+0000444224 00000 n 
+0000002363 00000 f 
+0000000000 00000 f 
+0000448550 00000 n 
+0000446272 00000 n 
+0000445896 00000 n 
+0000444439 00000 n 
+0000446012 00000 n 
+0000446064 00000 n 
+0000446116 00000 n 
+0000446168 00000 n 
+0000446220 00000 n 
+0000451402 00000 n 
+0000448755 00000 n 
+0000448413 00000 n 
+0000446422 00000 n 
+0000448703 00000 n 
+0000451555 00000 n 
+0000451710 00000 n 
+0000451864 00000 n 
+0000452019 00000 n 
+0000452951 00000 n 
+0000451229 00000 n 
+0000448879 00000 n 
+0000452173 00000 n 
+0000452225 00000 n 
+0000452277 00000 n 
+0000452329 00000 n 
+0000452381 00000 n 
+0000452433 00000 n 
+0000452484 00000 n 
+0000452536 00000 n 
+0000452588 00000 n 
+0000452640 00000 n 
+0000452692 00000 n 
+0000452744 00000 n 
+0000452796 00000 n 
+0000452848 00000 n 
+0000722021 00000 n 
+0000455147 00000 n 
+0000455303 00000 n 
+0000455459 00000 n 
+0000455619 00000 n 
+0000455779 00000 n 
+0000455935 00000 n 
+0000461761 00000 n 
+0000457077 00000 n 
+0000454965 00000 n 
+0000453075 00000 n 
+0000456089 00000 n 
+0000456141 00000 n 
+0000456193 00000 n 
+0000456245 00000 n 
+0000456297 00000 n 
+0000456349 00000 n 
+0000456401 00000 n 
+0000456453 00000 n 
+0000456505 00000 n 
+0000456557 00000 n 
+0000456609 00000 n 
+0000456661 00000 n 
+0000456713 00000 n 
+0000456765 00000 n 
+0000456817 00000 n 
+0000456869 00000 n 
+0000456921 00000 n 
+0000456973 00000 n 
+0000457025 00000 n 
+0000458647 00000 n 
+0000462642 00000 n 
+0000458510 00000 n 
+0000457241 00000 n 
+0000461916 00000 n 
+0000461968 00000 n 
+0000462020 00000 n 
+0000462072 00000 n 
+0000462124 00000 n 
+0000462176 00000 n 
+0000462228 00000 n 
+0000462280 00000 n 
+0000462332 00000 n 
+0000462384 00000 n 
+0000462436 00000 n 
+0000462488 00000 n 
+0000459313 00000 n 
+0000459545 00000 n 
+0000459593 00000 n 
+0000459924 00000 n 
+0000459946 00000 n 
+0000460250 00000 n 
+0000460346 00000 n 
+0000464857 00000 n 
+0000465322 00000 n 
+0000464720 00000 n 
+0000462796 00000 n 
+0000465011 00000 n 
+0000465114 00000 n 
+0000465166 00000 n 
+0000465218 00000 n 
+0000465270 00000 n 
+0000468269 00000 n 
+0000467325 00000 n 
+0000465484 00000 n 
+0000467441 00000 n 
+0000467493 00000 n 
+0000467545 00000 n 
+0000467597 00000 n 
+0000467649 00000 n 
+0000467701 00000 n 
+0000467753 00000 n 
+0000467804 00000 n 
+0000467855 00000 n 
+0000467907 00000 n 
+0000467959 00000 n 
+0000468011 00000 n 
+0000468063 00000 n 
+0000468165 00000 n 
+0000468217 00000 n 
+0000471006 00000 n 
+0000470266 00000 n 
+0000468419 00000 n 
+0000470382 00000 n 
+0000470434 00000 n 
+0000470486 00000 n 
+0000470538 00000 n 
+0000470590 00000 n 
+0000470642 00000 n 
+0000470694 00000 n 
+0000470746 00000 n 
+0000470798 00000 n 
+0000470850 00000 n 
+0000470902 00000 n 
+0000470954 00000 n 
+0000473314 00000 n 
+0000472835 00000 n 
+0000471143 00000 n 
+0000472951 00000 n 
+0000473003 00000 n 
+0000473055 00000 n 
+0000473107 00000 n 
+0000473210 00000 n 
+0000473262 00000 n 
+0000722146 00000 n 
+0000475322 00000 n 
+0000474946 00000 n 
+0000473490 00000 n 
+0000475062 00000 n 
+0000475114 00000 n 
+0000475166 00000 n 
+0000475218 00000 n 
+0000475270 00000 n 
+0000477744 00000 n 
+0000477898 00000 n 
+0000478059 00000 n 
+0000479103 00000 n 
+0000477589 00000 n 
+0000475485 00000 n 
+0000478220 00000 n 
+0000478272 00000 n 
+0000478324 00000 n 
+0000478376 00000 n 
+0000478428 00000 n 
+0000478480 00000 n 
+0000478583 00000 n 
+0000478635 00000 n 
+0000478687 00000 n 
+0000478739 00000 n 
+0000478791 00000 n 
+0000478843 00000 n 
+0000478895 00000 n 
+0000478947 00000 n 
+0000478999 00000 n 
+0000479051 00000 n 
+0000481799 00000 n 
+0000481960 00000 n 
+0000482121 00000 n 
+0000482277 00000 n 
+0000483054 00000 n 
+0000481635 00000 n 
+0000479227 00000 n 
+0000482433 00000 n 
+0000482485 00000 n 
+0000482537 00000 n 
+0000482589 00000 n 
+0000482641 00000 n 
+0000482693 00000 n 
+0000482745 00000 n 
+0000482797 00000 n 
+0000482848 00000 n 
+0000482900 00000 n 
+0000483002 00000 n 
+0000484778 00000 n 
+0000484558 00000 n 
+0000483178 00000 n 
+0000484674 00000 n 
+0000484726 00000 n 
+0000486607 00000 n 
+0000486439 00000 n 
+0000484902 00000 n 
+0000486555 00000 n 
+0000488082 00000 n 
+0000487810 00000 n 
+0000486770 00000 n 
+0000487926 00000 n 
+0000487978 00000 n 
+0000488030 00000 n 
+0000722271 00000 n 
+0000490119 00000 n 
+0000489847 00000 n 
+0000488232 00000 n 
+0000489963 00000 n 
+0000490015 00000 n 
+0000490067 00000 n 
+0000492657 00000 n 
+0000492810 00000 n 
+0000492963 00000 n 
+0000493118 00000 n 
+0000493278 00000 n 
+0000493432 00000 n 
+0000493592 00000 n 
+0000494272 00000 n 
+0000492466 00000 n 
+0000490282 00000 n 
+0000493752 00000 n 
+0000493804 00000 n 
+0000493856 00000 n 
+0000493908 00000 n 
+0000493960 00000 n 
+0000494012 00000 n 
+0000494064 00000 n 
+0000494116 00000 n 
+0000494168 00000 n 
+0000494220 00000 n 
+0000496385 00000 n 
+0000496539 00000 n 
+0000496699 00000 n 
+0000497480 00000 n 
+0000496230 00000 n 
+0000494422 00000 n 
+0000496860 00000 n 
+0000496963 00000 n 
+0000497015 00000 n 
+0000497066 00000 n 
+0000497117 00000 n 
+0000497168 00000 n 
+0000497220 00000 n 
+0000497272 00000 n 
+0000497324 00000 n 
+0000497376 00000 n 
+0000497428 00000 n 
+0000499323 00000 n 
+0000499513 00000 n 
+0000499701 00000 n 
+0000500061 00000 n 
+0000499168 00000 n 
+0000497604 00000 n 
+0000499856 00000 n 
+0000566662 00000 n 
+0000502665 00000 n 
+0000503075 00000 n 
+0000502528 00000 n 
+0000500159 00000 n 
+0000502819 00000 n 
+0000506034 00000 n 
+0000505713 00000 n 
+0000503186 00000 n 
+0000505829 00000 n 
+0000722396 00000 n 
+0000507079 00000 n 
+0000506911 00000 n 
+0000506145 00000 n 
+0000507027 00000 n 
+0000508540 00000 n 
+0000508692 00000 n 
+0000508846 00000 n 
+0000509006 00000 n 
+0000509164 00000 n 
+0000509324 00000 n 
+0000509479 00000 n 
+0000509639 00000 n 
+0000509799 00000 n 
+0000509954 00000 n 
+0000510114 00000 n 
+0000510427 00000 n 
+0000508313 00000 n 
+0000507164 00000 n 
+0000510274 00000 n 
+0000512441 00000 n 
+0000512171 00000 n 
+0000510551 00000 n 
+0000512287 00000 n 
+0000514303 00000 n 
+0000514084 00000 n 
+0000512604 00000 n 
+0000514200 00000 n 
+0000515455 00000 n 
+0000515287 00000 n 
+0000514440 00000 n 
+0000515403 00000 n 
+0000516614 00000 n 
+0000516446 00000 n 
+0000515553 00000 n 
+0000516562 00000 n 
+0000722521 00000 n 
+0000517727 00000 n 
+0000517559 00000 n 
+0000516712 00000 n 
+0000517675 00000 n 
+0000518815 00000 n 
+0000518647 00000 n 
+0000517825 00000 n 
+0000518763 00000 n 
+0000519921 00000 n 
+0000519753 00000 n 
+0000518913 00000 n 
+0000519869 00000 n 
+0000520986 00000 n 
+0000520818 00000 n 
+0000520019 00000 n 
+0000520934 00000 n 
+0000522031 00000 n 
+0000521863 00000 n 
+0000521084 00000 n 
+0000521979 00000 n 
+0000523096 00000 n 
+0000522928 00000 n 
+0000522129 00000 n 
+0000523044 00000 n 
+0000722646 00000 n 
+0000524172 00000 n 
+0000524004 00000 n 
+0000523194 00000 n 
+0000524120 00000 n 
+0000525240 00000 n 
+0000525072 00000 n 
+0000524270 00000 n 
+0000525188 00000 n 
+0000526331 00000 n 
+0000526163 00000 n 
+0000525338 00000 n 
+0000526279 00000 n 
+0000527408 00000 n 
+0000527240 00000 n 
+0000526429 00000 n 
+0000527356 00000 n 
+0000528495 00000 n 
+0000528327 00000 n 
+0000527506 00000 n 
+0000528443 00000 n 
+0000529571 00000 n 
+0000529403 00000 n 
+0000528593 00000 n 
+0000529519 00000 n 
+0000722771 00000 n 
+0000530661 00000 n 
+0000530493 00000 n 
+0000529669 00000 n 
+0000530609 00000 n 
+0000531742 00000 n 
+0000531574 00000 n 
+0000530759 00000 n 
+0000531690 00000 n 
+0000532843 00000 n 
+0000532675 00000 n 
+0000531840 00000 n 
+0000532791 00000 n 
+0000533925 00000 n 
+0000533757 00000 n 
+0000532941 00000 n 
+0000533873 00000 n 
+0000535019 00000 n 
+0000534851 00000 n 
+0000534023 00000 n 
+0000534967 00000 n 
+0000536097 00000 n 
+0000535929 00000 n 
+0000535117 00000 n 
+0000536045 00000 n 
+0000722896 00000 n 
+0000537199 00000 n 
+0000537031 00000 n 
+0000536195 00000 n 
+0000537147 00000 n 
+0000538301 00000 n 
+0000538133 00000 n 
+0000537297 00000 n 
+0000538249 00000 n 
+0000539449 00000 n 
+0000539281 00000 n 
+0000538399 00000 n 
+0000539397 00000 n 
+0000540540 00000 n 
+0000540372 00000 n 
+0000539547 00000 n 
+0000540488 00000 n 
+0000541631 00000 n 
+0000541463 00000 n 
+0000540638 00000 n 
+0000541579 00000 n 
+0000542716 00000 n 
+0000542548 00000 n 
+0000541729 00000 n 
+0000542664 00000 n 
+0000723021 00000 n 
+0000543815 00000 n 
+0000543647 00000 n 
+0000542814 00000 n 
+0000543763 00000 n 
+0000544907 00000 n 
+0000544739 00000 n 
+0000543913 00000 n 
+0000544855 00000 n 
+0000546002 00000 n 
+0000545834 00000 n 
+0000545005 00000 n 
+0000545950 00000 n 
+0000547151 00000 n 
+0000546983 00000 n 
+0000546100 00000 n 
+0000547099 00000 n 
+0000548257 00000 n 
+0000548089 00000 n 
+0000547249 00000 n 
+0000548205 00000 n 
+0000549347 00000 n 
+0000549179 00000 n 
+0000548355 00000 n 
+0000549295 00000 n 
+0000723146 00000 n 
+0000550436 00000 n 
+0000550268 00000 n 
+0000549445 00000 n 
+0000550384 00000 n 
+0000551516 00000 n 
+0000551348 00000 n 
+0000550534 00000 n 
+0000551464 00000 n 
+0000552597 00000 n 
+0000552429 00000 n 
+0000551614 00000 n 
+0000552545 00000 n 
+0000553550 00000 n 
+0000553382 00000 n 
+0000552695 00000 n 
+0000553498 00000 n 
+0000554652 00000 n 
+0000554484 00000 n 
+0000553648 00000 n 
+0000554600 00000 n 
+0000555743 00000 n 
+0000555575 00000 n 
+0000554750 00000 n 
+0000555691 00000 n 
+0000723271 00000 n 
+0000556835 00000 n 
+0000556667 00000 n 
+0000555841 00000 n 
+0000556783 00000 n 
+0000557914 00000 n 
+0000557746 00000 n 
+0000556933 00000 n 
+0000557862 00000 n 
+0000558374 00000 n 
+0000558206 00000 n 
+0000558012 00000 n 
+0000558322 00000 n 
+0000561375 00000 n 
+0000561542 00000 n 
+0000559909 00000 n 
+0000561720 00000 n 
+0000561990 00000 n 
+0000559754 00000 n 
+0000558459 00000 n 
+0000561887 00000 n 
+0000561072 00000 n 
+0000561305 00000 n 
+0000561353 00000 n 
+0000562497 00000 n 
+0000562329 00000 n 
+0000562130 00000 n 
+0000562445 00000 n 
+0000564591 00000 n 
+0000564956 00000 n 
+0000565330 00000 n 
+0000565514 00000 n 
+0000565884 00000 n 
+0000567567 00000 n 
+0000566867 00000 n 
+0000564382 00000 n 
+0000562582 00000 n 
+0000566251 00000 n 
+0000566303 00000 n 
+0000564773 00000 n 
+0000565142 00000 n 
+0000565699 00000 n 
+0000566067 00000 n 
+0000723396 00000 n 
+0000568038 00000 n 
+0000567421 00000 n 
+0000566978 00000 n 
+0000567935 00000 n 
+0000567751 00000 n 
+0000568149 00000 n 
+0000568205 00000 n 
+0000568285 00000 n 
+0000568705 00000 n 
+0000568816 00000 n 
+0000568962 00000 n 
+0000569289 00000 n 
+0000569534 00000 n 
+0000569765 00000 n 
+0000570016 00000 n 
+0000570771 00000 n 
+0000571064 00000 n 
+0000571188 00000 n 
+0000571271 00000 n 
+0000571689 00000 n 
+0000572036 00000 n 
+0000572713 00000 n 
+0000573357 00000 n 
+0000573721 00000 n 
+0000574340 00000 n 
+0000574976 00000 n 
+0000575653 00000 n 
+0000575906 00000 n 
+0000576597 00000 n 
+0000577235 00000 n 
+0000577883 00000 n 
+0000578290 00000 n 
+0000578936 00000 n 
+0000592638 00000 n 
+0000593056 00000 n 
+0000605293 00000 n 
+0000605717 00000 n 
+0000607994 00000 n 
+0000608222 00000 n 
+0000611063 00000 n 
+0000611305 00000 n 
+0000615481 00000 n 
+0000615728 00000 n 
+0000619755 00000 n 
+0000620279 00000 n 
+0000628783 00000 n 
+0000629115 00000 n 
+0000631693 00000 n 
+0000631921 00000 n 
+0000636680 00000 n 
+0000636941 00000 n 
+0000654074 00000 n 
+0000654645 00000 n 
+0000660064 00000 n 
+0000660348 00000 n 
+0000664013 00000 n 
+0000664258 00000 n 
+0000668051 00000 n 
+0000668319 00000 n 
+0000676548 00000 n 
+0000676879 00000 n 
+0000681087 00000 n 
+0000681540 00000 n 
+0000682857 00000 n 
+0000683090 00000 n 
+0000698568 00000 n 
+0000698975 00000 n 
+0000700912 00000 n 
+0000701138 00000 n 
+0000703492 00000 n 
+0000703721 00000 n 
+0000715871 00000 n 
+0000723485 00000 n 
+0000723605 00000 n 
+0000723729 00000 n 
+0000723855 00000 n 
+0000723981 00000 n 
+0000724107 00000 n 
+0000724224 00000 n 
+0000724334 00000 n 
+0000733921 00000 n 
+0000734104 00000 n 
+0000734289 00000 n 
+0000734473 00000 n 
+0000734658 00000 n 
+0000734841 00000 n 
+0000735024 00000 n 
+0000735209 00000 n 
+0000735393 00000 n 
+0000735578 00000 n 
+0000735762 00000 n 
+0000735947 00000 n 
+0000736131 00000 n 
+0000736316 00000 n 
+0000736500 00000 n 
+0000736685 00000 n 
+0000736868 00000 n 
+0000737051 00000 n 
+0000737236 00000 n 
+0000737417 00000 n 
+0000737602 00000 n 
+0000737786 00000 n 
+0000737971 00000 n 
+0000738155 00000 n 
+0000738340 00000 n 
+0000738524 00000 n 
+0000738709 00000 n 
+0000738893 00000 n 
+0000739078 00000 n 
+0000739261 00000 n 
+0000739444 00000 n 
+0000739629 00000 n 
+0000739813 00000 n 
+0000739998 00000 n 
+0000740182 00000 n 
+0000740367 00000 n 
+0000740551 00000 n 
+0000740736 00000 n 
+0000740918 00000 n 
+0000741103 00000 n 
+0000741287 00000 n 
+0000741472 00000 n 
+0000741655 00000 n 
+0000741838 00000 n 
+0000742023 00000 n 
+0000742207 00000 n 
+0000742392 00000 n 
+0000742576 00000 n 
+0000742761 00000 n 
+0000742945 00000 n 
+0000743130 00000 n 
+0000743314 00000 n 
+0000743499 00000 n 
+0000743682 00000 n 
+0000743865 00000 n 
+0000744050 00000 n 
+0000744231 00000 n 
+0000744416 00000 n 
+0000744600 00000 n 
+0000744785 00000 n 
+0000744969 00000 n 
+0000745154 00000 n 
+0000745338 00000 n 
+0000745523 00000 n 
+0000745707 00000 n 
+0000745892 00000 n 
+0000746075 00000 n 
+0000746258 00000 n 
+0000746443 00000 n 
+0000746627 00000 n 
+0000746812 00000 n 
+0000746996 00000 n 
+0000747181 00000 n 
+0000747365 00000 n 
+0000747550 00000 n 
+0000747732 00000 n 
+0000747917 00000 n 
+0000748101 00000 n 
+0000748286 00000 n 
+0000748469 00000 n 
+0000748652 00000 n 
+0000748837 00000 n 
+0000749021 00000 n 
+0000749206 00000 n 
+0000749390 00000 n 
+0000749575 00000 n 
+0000749759 00000 n 
+0000749944 00000 n 
+0000750128 00000 n 
+0000750313 00000 n 
+0000750496 00000 n 
+0000750679 00000 n 
+0000750864 00000 n 
+0000751045 00000 n 
+0000751230 00000 n 
+0000751414 00000 n 
+0000751599 00000 n 
+0000751783 00000 n 
+0000751968 00000 n 
+0000752152 00000 n 
+0000752337 00000 n 
+0000752521 00000 n 
+0000752706 00000 n 
+0000752889 00000 n 
+0000753072 00000 n 
+0000753257 00000 n 
+0000753441 00000 n 
+0000753626 00000 n 
+0000753810 00000 n 
+0000753995 00000 n 
+0000754179 00000 n 
+0000754364 00000 n 
+0000754546 00000 n 
+0000754731 00000 n 
+0000754915 00000 n 
+0000755100 00000 n 
+0000755283 00000 n 
+0000755466 00000 n 
+0000755651 00000 n 
+0000755835 00000 n 
+0000756020 00000 n 
+0000756204 00000 n 
+0000756384 00000 n 
+0000756559 00000 n 
+0000756734 00000 n 
+0000756911 00000 n 
+0000757099 00000 n 
+0000757294 00000 n 
+0000757478 00000 n 
+0000757674 00000 n 
+0000757888 00000 n 
+0000758102 00000 n 
+0000758317 00000 n 
+0000758524 00000 n 
+0000758719 00000 n 
+0000758914 00000 n 
+0000759109 00000 n 
+0000759294 00000 n 
+0000759479 00000 n 
+0000759662 00000 n 
+0000759847 00000 n 
+0000760030 00000 n 
+0000760215 00000 n 
+0000760398 00000 n 
+0000760583 00000 n 
+0000760766 00000 n 
+0000760951 00000 n 
+0000761133 00000 n 
+0000761315 00000 n 
+0000761500 00000 n 
+0000761683 00000 n 
+0000761868 00000 n 
+0000762051 00000 n 
+0000762236 00000 n 
+0000762413 00000 n 
+0000762584 00000 n 
+0000762754 00000 n 
+0000762931 00000 n 
+0000763106 00000 n 
+0000763283 00000 n 
+0000763458 00000 n 
+0000763635 00000 n 
+0000763809 00000 n 
+0000763983 00000 n 
+0000764160 00000 n 
+0000764335 00000 n 
+0000764512 00000 n 
+0000764687 00000 n 
+0000764864 00000 n 
+0000765037 00000 n 
+0000765208 00000 n 
+0000765398 00000 n 
+0000765615 00000 n 
+0000765830 00000 n 
+0000766047 00000 n 
+0000766262 00000 n 
+0000766479 00000 n 
+0000766694 00000 n 
+0000766908 00000 n 
+0000767113 00000 n 
+0000767322 00000 n 
+0000767531 00000 n 
+0000767740 00000 n 
+0000767949 00000 n 
+0000768158 00000 n 
+0000768367 00000 n 
+0000768574 00000 n 
+0000768783 00000 n 
+0000768990 00000 n 
+0000769199 00000 n 
+0000769406 00000 n 
+0000769615 00000 n 
+0000769821 00000 n 
+0000770028 00000 n 
+0000770225 00000 n 
+0000770422 00000 n 
+0000770623 00000 n 
+0000770826 00000 n 
+0000771032 00000 n 
+0000771235 00000 n 
+0000771447 00000 n 
+0000771686 00000 n 
+0000771929 00000 n 
+0000772172 00000 n 
+0000772415 00000 n 
+0000772661 00000 n 
+0000772904 00000 n 
+0000773147 00000 n 
+0000773390 00000 n 
+0000773581 00000 n 
+0000773782 00000 n 
+0000773981 00000 n 
+0000774170 00000 n 
+0000774367 00000 n 
+0000774566 00000 n 
+0000774764 00000 n 
+0000774962 00000 n 
+0000775162 00000 n 
+0000775361 00000 n 
+0000775560 00000 n 
+0000775759 00000 n 
+0000775960 00000 n 
+0000776160 00000 n 
+0000776360 00000 n 
+0000776559 00000 n 
+0000776759 00000 n 
+0000776958 00000 n 
+0000777155 00000 n 
+0000777273 00000 n 
+0000777391 00000 n 
+0000777509 00000 n 
+0000777627 00000 n 
+0000777744 00000 n 
+0000777862 00000 n 
+0000777980 00000 n 
+0000778098 00000 n 
+0000778215 00000 n 
+0000778333 00000 n 
+0000778451 00000 n 
+0000778569 00000 n 
+0000778687 00000 n 
+0000778804 00000 n 
+0000778922 00000 n 
+0000779040 00000 n 
+0000779158 00000 n 
+0000779275 00000 n 
+0000779393 00000 n 
+0000779511 00000 n 
+0000779631 00000 n 
+0000779755 00000 n 
+0000779877 00000 n 
+0000779995 00000 n 
+0000780113 00000 n 
+0000780230 00000 n 
+0000780346 00000 n 
+0000780462 00000 n 
+0000780583 00000 n 
+0000780708 00000 n 
+0000780832 00000 n 
+0000780956 00000 n 
+0000781080 00000 n 
+0000781209 00000 n 
+0000781337 00000 n 
+0000781458 00000 n 
+0000781580 00000 n 
+0000781692 00000 n 
+0000781811 00000 n 
+0000781929 00000 n 
+0000782047 00000 n 
+0000782165 00000 n 
+0000782286 00000 n 
+0000782408 00000 n 
+0000782493 00000 n 
+0000782613 00000 n 
+0000782689 00000 n 
+0000782773 00000 n 
+0000782813 00000 n 
+0000783007 00000 n 
+trailer
+<< /Size 3216
+/Root 3214 0 R
+/Info 3215 0 R
+/ID [<200D38A9CFCF7E0C179520B7E57747C4> <200D38A9CFCF7E0C179520B7E57747C4>] >>
+startxref
+783339
+%%EOF
diff --git a/doc/spec/fdct.fig b/doc/spec/fdct.fig
new file mode 100644 (file)
index 0000000..e35c758
--- /dev/null
@@ -0,0 +1,371 @@
+#FIG 3.2
+Landscape
+Center
+Inches
+Letter  
+100.00
+Single
+-2
+1200 2
+6 1350 4650 1650 4950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 1500 4800 75 75 1500 4800 1500 4725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1450 4800 1550 4800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1500 4850 1500 4750
+-6
+6 1350 450 1650 750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 1500 600 75 75 1500 600 1500 525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1450 600 1550 600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1500 650 1500 550
+-6
+6 1950 1050 2250 1350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 1200 75 75 2100 1200 2100 1125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 1200 2150 1200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 1250 2100 1150
+-6
+6 3150 2850 3450 3150
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3300 3000 75 75 3300 3000 3300 2925
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3250 3000 3350 3000
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3300 3050 3300 2950
+-6
+6 3150 2250 3450 2550
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3300 2400 75 75 3300 2400 3300 2325
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3250 2400 3350 2400
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3300 2450 3300 2350
+-6
+6 2550 3450 2850 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2700 3600 75 75 2700 3600 2700 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2650 3600 2750 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2700 3650 2700 3550
+-6
+6 2550 1650 2850 1950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2700 1800 75 75 2700 1800 2700 1725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2650 1800 2750 1800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2700 1850 2700 1750
+-6
+6 1950 4050 2250 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 4200 75 75 2100 4200 2100 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 4200 2150 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 4250 2100 4150
+-6
+6 2250 3600 2550 3900
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2400 3750 75 75 2400 3750 2400 3675
+4 1 0 40 -1 0 12 0.0000 4 15 60 2400 3800 -\001
+-6
+6 1650 4200 1950 4500
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 1800 4350 75 75 1800 4350 1800 4275
+4 1 0 40 -1 0 12 0.0000 4 15 60 1800 4400 -\001
+-6
+6 1050 4800 1350 5100
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 1200 4950 75 75 1200 4950 1200 4875
+4 1 0 40 -1 0 12 0.0000 4 15 60 1200 5000 -\001
+-6
+6 2850 3000 3150 3300
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3000 3150 75 75 3000 3150 3000 3075
+4 1 0 40 -1 0 12 0.0000 4 15 60 3000 3200 -\001
+-6
+6 4350 4050 4650 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4500 4200 75 75 4500 4200 4500 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4450 4200 4550 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4500 4250 4500 4150
+-6
+6 4350 3450 4650 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4500 3600 75 75 4500 3600 4500 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4450 3600 4550 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4500 3650 4500 3550
+-6
+6 4050 3300 4350 3600
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4200 3450 75 75 4200 3450 4200 3375
+4 1 0 40 -1 0 12 0.0000 4 15 60 4200 3500 -\001
+-6
+6 4350 2250 4650 2550
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4500 2400 75 75 4500 2400 4500 2325
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4450 2400 4550 2400
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4500 2450 4500 2350
+-6
+6 4350 450 4650 750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4500 600 75 75 4500 600 4500 525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4450 600 4550 600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4500 650 4500 550
+-6
+6 4050 2400 4350 2700
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4200 2550 75 75 4200 2550 4200 2475
+4 1 0 40 -1 0 12 0.0000 4 15 60 4200 2600 -\001
+-6
+6 4950 1050 5250 1350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 5100 1200 75 75 5100 1200 5100 1125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5050 1200 5150 1200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5100 1250 5100 1150
+-6
+6 4950 1650 5250 1950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 5100 1800 75 75 5100 1800 5100 1725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5050 1800 5150 1800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5100 1850 5100 1750
+-6
+6 4650 1800 4950 2100
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4800 1950 75 75 4800 1950 4800 1875
+4 1 0 40 -1 0 12 0.0000 4 15 60 4800 2000 -\001
+-6
+6 4725 3525 4875 4275
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4800 4200 25 25 4800 4200 4800 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4800 3600 25 25 4800 3600 4800 3575
+-6
+6 6150 4650 6450 4950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 4800 75 75 6300 4800 6300 4725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 4800 6350 4800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 4850 6300 4750
+-6
+6 6150 4050 6450 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 4200 75 75 6300 4200 6300 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 4200 6350 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 4250 6300 4150
+-6
+6 5850 3900 6150 4200
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6000 4050 75 75 6000 4050 6000 3975
+4 1 0 40 -1 0 12 0.0000 4 15 60 6000 4100 -\001
+-6
+6 6150 2850 6450 3150
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 3000 75 75 6300 3000 6300 2925
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 3000 6350 3000
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 3050 6300 2950
+-6
+6 6150 3450 6450 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 3600 75 75 6300 3600 6300 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 3600 6350 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 3650 6300 3550
+-6
+6 5850 3600 6150 3900
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6000 3750 75 75 6000 3750 6000 3675
+4 1 0 40 -1 0 12 0.0000 4 15 60 6000 3800 -\001
+-6
+6 6150 1050 6450 1350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 1200 75 75 6300 1200 6300 1125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 1200 6350 1200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 1250 6300 1150
+-6
+6 6150 450 6450 750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 600 75 75 6300 600 6300 525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 600 6350 600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 650 6300 550
+-6
+6 6150 2250 6450 2550
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 2400 75 75 6300 2400 6300 2325
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 2400 6350 2400
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 2450 6300 2350
+-6
+6 6150 1650 6450 1950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 1800 75 75 6300 1800 6300 1725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 1800 6350 1800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 1850 6300 1750
+-6
+6 5850 1200 6150 1500
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6000 1350 75 75 6000 1350 6000 1275
+4 1 0 40 -1 0 12 0.0000 4 15 60 6000 1400 -\001
+-6
+6 7350 4650 7650 4950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 7500 4800 75 75 7500 4800 7500 4725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7450 4800 7550 4800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7500 4850 7500 4750
+-6
+6 7350 2850 7650 3150
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 7500 3000 75 75 7500 3000 7500 2925
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7450 3000 7550 3000
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7500 3050 7500 2950
+-6
+6 7950 4050 8250 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 8100 4200 75 75 8100 4200 8100 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8050 4200 8150 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8100 4250 8100 4150
+-6
+6 7950 3450 8250 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 8100 3600 75 75 8100 3600 8100 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8050 3600 8150 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8100 3650 8100 3550
+-6
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 900 4800 25 25 900 4800 900 4775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 900 600 25 25 900 600 900 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1500 1200 25 25 1500 1200 1500 1175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2700 3000 25 25 2700 3000 2700 2975
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2700 2400 25 25 2700 2400 2700 2375
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2100 3600 25 25 2100 3600 2100 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1500 4200 25 25 1500 4200 1500 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3900 4200 25 25 3900 4200 3900 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3900 3600 25 25 3900 3600 3900 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3900 2400 25 25 3900 2400 3900 2375
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3900 600 25 25 3900 600 3900 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4500 1200 25 25 4500 1200 4500 1175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4500 1800 25 25 4500 1800 4500 1775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 4800 25 25 5700 4800 5700 4775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 4200 25 25 5700 4200 5700 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 3600 25 25 5700 3600 5700 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 3000 25 25 5700 3000 5700 2975
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 1200 25 25 5700 1200 5700 1175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 600 25 25 5700 600 5700 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 2400 25 25 5700 2400 5700 2375
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5725 1800 25 25 5725 1800 5725 1775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 6900 4800 25 25 6900 4800 6900 4775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 6900 3000 25 25 6900 3000 6900 2975
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 7500 4200 25 25 7500 4200 7500 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 7500 3600 25 25 7500 3600 7500 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 7500 1200 25 25 7500 1200 7500 1175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 7500 600 25 25 7500 600 7500 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2100 1800 25 25 2100 1800 2100 1775
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 600 8400 600
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 2400 8400 2400
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 3000 8400 3000
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 4800 8400 4800
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 1200 8400 1200
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 3600 8400 3600
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 1800 8400 1800
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 4200 8400 4200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        900 4800 1500 600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        900 600 1500 4800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        1500 1200 2100 4275
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        1500 4200 2100 1200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2100 3600 2700 1800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2700 2400 3300 3000
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2100 1800 2700 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2700 3000 3300 2400
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        3900 3600 4500 4200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        3900 4200 4500 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        3900 600 4500 2400
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        3900 2400 4500 600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        4500 1800 5100 1200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        4500 1200 5100 1800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        5700 4200 6300 4800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        5700 3600 6300 3000
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        5700 3000 6300 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        5700 4800 6300 4200
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        5700 1200 6300 600
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        5700 600 6300 1200
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        5700 1800 6300 2400
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        5700 2400 6300 1800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        6900 3000 7500 4800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        6900 4800 7500 3000
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        7500 4200 8100 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        7500 3600 8100 4200
+4 1 0 40 -1 0 12 0.0000 4 135 210 4800 4125 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 4800 3525 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 6000 2350 C6\001
+4 1 0 40 -1 0 12 0.0000 4 135 255 6300 2275 -S6\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 6000 1750 C6\001
+4 1 0 40 -1 0 12 0.0000 4 135 195 6300 2050 S6\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 7200 2950 C7\001
+4 1 0 40 -1 0 12 0.0000 4 135 195 7500 3375 S7\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 7200 4750 C7\001
+4 1 0 40 -1 0 12 0.0000 4 135 255 7500 4575 -S7\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 7800 4150 C3\001
+4 1 0 40 -1 0 12 0.0000 4 135 255 8100 4075 -S3\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 7800 3550 C3\001
+4 1 0 40 -1 0 12 0.0000 4 135 195 8100 3850 S3\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 7500 1125 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 7500 525 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 675 0\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 1275 4\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 1875 2\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 2475 6\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 3675 5\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 4275 3\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 4875 7\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 3075 1\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 675 0\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 1275 1\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 1875 2\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 2475 3\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 3075 4\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 3675 5\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 4275 6\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 4875 7\001
diff --git a/doc/spec/hilbert-block.fig b/doc/spec/hilbert-block.fig
new file mode 100644 (file)
index 0000000..8316c5d
--- /dev/null
@@ -0,0 +1,104 @@
+#FIG 3.2  Produced by xfig version 3.2.5-alpha4
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 675 645 3825 3795
+4 1 0 50 0 1 12 0.0000 0 150 105 900 3660 0\001
+4 1 0 50 0 1 12 0.0000 0 150 105 1800 3660 1\001
+4 1 0 50 0 1 12 0.0000 0 150 105 1800 2760 2\001
+4 1 0 50 0 1 12 0.0000 0 150 105 900 2760 3\001
+4 1 0 50 0 1 12 0.0000 0 150 105 900 1860 4\001
+4 1 0 50 0 1 12 0.0000 0 150 105 900 960 5\001
+4 1 0 50 0 1 12 0.0000 0 150 105 1800 960 6\001
+4 1 0 50 0 1 12 0.0000 0 150 105 1800 1860 7\001
+4 1 0 50 0 1 12 0.0000 0 150 105 2700 1860 8\001
+4 1 0 50 0 1 12 0.0000 0 150 105 2700 960 9\001
+4 1 0 50 0 1 12 0.0000 0 150 210 3600 960 10\001
+4 1 0 50 0 1 12 0.0000 0 150 210 3600 1860 11\001
+4 1 0 50 0 1 12 0.0000 0 150 210 3600 2760 12\001
+4 1 0 50 0 1 12 0.0000 0 150 210 2700 2760 13\001
+4 1 0 50 0 1 12 0.0000 0 150 210 2700 3660 14\001
+4 1 0 50 0 1 12 0.0000 0 150 210 3600 3660 15\001
+-6
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1125 3600 1575 3600
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1800 3375 1800 2925
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1575 2700 1125 2700
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        900 2475 900 2025
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        900 1575 900 1125
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1125 900 1575 900
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1800 1125 1800 1575
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        2025 1800 2475 1800
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        2700 1575 2700 1125
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        2925 900 3375 900
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        3600 1125 3600 1575
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        3600 2025 3600 2475
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        3375 2700 2925 2700
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        2700 2925 2700 3375
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        2925 3600 3375 3600
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 450 1350 450 1350 1350 450 1350 450 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 450 2250 450 2250 1350 1350 1350 1350 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 450 3150 450 3150 1350 2250 1350 2250 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 450 4050 450 4050 1350 3150 1350 3150 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 1350 1350 1350 1350 2250 450 2250 450 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 1350 2250 1350 2250 2250 1350 2250 1350 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 1350 3150 1350 3150 2250 2250 2250 2250 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 1350 4050 1350 4050 2250 3150 2250 3150 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 2250 1350 2250 1350 3150 450 3150 450 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 2250 2250 2250 2250 3150 1350 3150 1350 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 2250 3150 2250 3150 3150 2250 3150 2250 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 2250 4050 2250 4050 3150 3150 3150 3150 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 3150 1350 3150 1350 4050 450 4050 450 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 3150 2250 3150 2250 4050 1350 4050 1350 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 3150 3150 3150 3150 4050 2250 4050 2250 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 3150 4050 3150 4050 4050 3150 4050 3150 3150
diff --git a/doc/spec/hilbert-mb.fig b/doc/spec/hilbert-mb.fig
new file mode 100644 (file)
index 0000000..0ed12a7
--- /dev/null
@@ -0,0 +1,32 @@
+#FIG 3.2  Produced by xfig version 3.2.5-alpha4
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 810 810 1890 1890
+4 1 0 50 0 1 12 0.0000 0 150 105 900 1860 0\001
+4 1 0 50 0 1 12 0.0000 0 150 105 900 960 1\001
+4 1 0 50 0 1 12 0.0000 0 150 105 1800 960 2\001
+4 1 0 50 0 1 12 0.0000 0 150 105 1800 1860 3\001
+-6
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        900 1575 900 1125
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1125 900 1575 900
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1800 1125 1800 1575
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 450 1350 450 1350 1350 450 1350 450 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 450 2250 450 2250 1350 1350 1350 1350 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 1350 1350 1350 1350 2250 450 2250 450 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 1350 2250 1350 2250 2250 1350 2250 1350 1350
diff --git a/doc/spec/idct.fig b/doc/spec/idct.fig
new file mode 100644 (file)
index 0000000..2d4388c
--- /dev/null
@@ -0,0 +1,369 @@
+#FIG 3.2
+Landscape
+Center
+Inches
+Letter  
+100.00
+Single
+-2
+1200 2
+6 3150 4650 3450 4950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3300 4800 75 75 3300 4800 3300 4725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3250 4800 3350 4800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3300 4850 3300 4750
+-6
+6 3150 4050 3450 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3300 4200 75 75 3300 4200 3300 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3250 4200 3350 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3300 4250 3300 4150
+-6
+6 2850 3900 3150 4200
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3000 4050 75 75 3000 4050 3000 3975
+4 1 0 40 -1 0 12 0.0000 4 15 60 3000 4100 -\001
+-6
+6 3150 2850 3450 3150
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3300 3000 75 75 3300 3000 3300 2925
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3250 3000 3350 3000
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3300 3050 3300 2950
+-6
+6 3150 3450 3450 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3300 3600 75 75 3300 3600 3300 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3250 3600 3350 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        3300 3650 3300 3550
+-6
+6 2850 3600 3150 3900
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 3000 3750 75 75 3000 3750 3000 3675
+4 1 0 40 -1 0 12 0.0000 4 15 60 3000 3800 -\001
+-6
+6 1950 1050 2250 1350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 1200 75 75 2100 1200 2100 1125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 1200 2150 1200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 1250 2100 1150
+-6
+6 1950 450 2250 750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 600 75 75 2100 600 2100 525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 600 2150 600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 650 2100 550
+-6
+6 1950 2250 2250 2550
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 2400 75 75 2100 2400 2100 2325
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 2400 2150 2400
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 2450 2100 2350
+-6
+6 1950 1650 2250 1950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 1800 75 75 2100 1800 2100 1725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 1800 2150 1800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 1850 2100 1750
+-6
+6 1650 1200 1950 1500
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 1800 1350 75 75 1800 1350 1800 1275
+4 1 0 40 -1 0 12 0.0000 4 15 60 1800 1400 -\001
+-6
+6 6150 4650 6450 4950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 4800 75 75 6300 4800 6300 4725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 4800 6350 4800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 4850 6300 4750
+-6
+6 6150 450 6450 750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6300 600 75 75 6300 600 6300 525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6250 600 6350 600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6300 650 6300 550
+-6
+6 6750 1050 7050 1350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6900 1200 75 75 6900 1200 6900 1125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6850 1200 6950 1200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6900 1250 6900 1150
+-6
+6 7950 2850 8250 3150
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 8100 3000 75 75 8100 3000 8100 2925
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8050 3000 8150 3000
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8100 3050 8100 2950
+-6
+6 7950 2250 8250 2550
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 8100 2400 75 75 8100 2400 8100 2325
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8050 2400 8150 2400
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        8100 2450 8100 2350
+-6
+6 7350 3450 7650 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 7500 3600 75 75 7500 3600 7500 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7450 3600 7550 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7500 3650 7500 3550
+-6
+6 7350 1650 7650 1950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 7500 1800 75 75 7500 1800 7500 1725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7450 1800 7550 1800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        7500 1850 7500 1750
+-6
+6 6750 4050 7050 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6900 4200 75 75 6900 4200 6900 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6850 4200 6950 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        6900 4250 6900 4150
+-6
+6 7050 3600 7350 3900
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 7200 3750 75 75 7200 3750 7200 3675
+4 1 0 40 -1 0 12 0.0000 4 15 60 7200 3800 -\001
+-6
+6 6450 4200 6750 4500
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6600 4350 75 75 6600 4350 6600 4275
+4 1 0 40 -1 0 12 0.0000 4 15 60 6600 4400 -\001
+-6
+6 5850 4800 6150 5100
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 6000 4950 75 75 6000 4950 6000 4875
+4 1 0 40 -1 0 12 0.0000 4 15 60 6000 5000 -\001
+-6
+6 7650 3000 7950 3300
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 7800 3150 75 75 7800 3150 7800 3075
+4 1 0 40 -1 0 12 0.0000 4 15 60 7800 3200 -\001
+-6
+6 4950 4050 5250 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 5100 4200 75 75 5100 4200 5100 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5050 4200 5150 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5100 4250 5100 4150
+-6
+6 4950 3450 5250 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 5100 3600 75 75 5100 3600 5100 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5050 3600 5150 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5100 3650 5100 3550
+-6
+6 4650 3300 4950 3600
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4800 3450 75 75 4800 3450 4800 3375
+4 1 0 40 -1 0 12 0.0000 4 15 60 4800 3500 -\001
+-6
+6 4350 2250 4650 2550
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4500 2400 75 75 4500 2400 4500 2325
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4450 2400 4550 2400
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4500 2450 4500 2350
+-6
+6 4350 450 4650 750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4500 600 75 75 4500 600 4500 525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4450 600 4550 600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        4500 650 4500 550
+-6
+6 4050 2400 4350 2700
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4200 2550 75 75 4200 2550 4200 2475
+4 1 0 40 -1 0 12 0.0000 4 15 60 4200 2600 -\001
+-6
+6 4950 1050 5250 1350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 5100 1200 75 75 5100 1200 5100 1125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5050 1200 5150 1200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5100 1250 5100 1150
+-6
+6 4950 1650 5250 1950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 5100 1800 75 75 5100 1800 5100 1725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5050 1800 5150 1800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        5100 1850 5100 1750
+-6
+6 1950 4050 2250 4350
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 4200 75 75 2100 4200 2100 4125
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 4200 2150 4200
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 4250 2100 4150
+-6
+6 1950 3450 2250 3750
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 2100 3600 75 75 2100 3600 2100 3525
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2050 3600 2150 3600
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        2100 3650 2100 3550
+-6
+6 1350 4650 1650 4950
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 1500 4800 75 75 1500 4800 1500 4725
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1450 4800 1550 4800
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1500 4850 1500 4750
+-6
+6 1350 2850 1650 3150
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 1500 3000 75 75 1500 3000 1500 2925
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1450 3000 1550 3000
+2 1 0 1 0 7 40 -1 20 4.000 0 0 7 0 0 2
+        1500 3050 1500 2950
+-6
+6 4650 1800 4950 2100
+1 3 0 1 0 7 40 -1 20 4.000 1 0.0000 4800 1950 75 75 4800 1950 4800 1875
+4 1 0 40 -1 0 12 0.0000 4 15 60 4800 2000 -\001
+-6
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2700 4800 25 25 2700 4800 2700 4775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2700 4200 25 25 2700 4200 2700 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2700 3600 25 25 2700 3600 2700 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 2700 3000 25 25 2700 3000 2700 2975
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1500 1200 25 25 1500 1200 1500 1175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1500 600 25 25 1500 600 1500 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1500 2400 25 25 1500 2400 1500 2375
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1525 1800 25 25 1525 1800 1525 1775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3000 1200 25 25 3000 1200 3000 1175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3000 600 25 25 3000 600 3000 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 4800 25 25 5700 4800 5700 4775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 5700 600 25 25 5700 600 5700 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 6300 1200 25 25 6300 1200 6300 1175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 7500 3000 25 25 7500 3000 7500 2975
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 7500 2400 25 25 7500 2400 7500 2375
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 6900 3600 25 25 6900 3600 6900 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 6300 4200 25 25 6300 4200 6300 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4500 4200 25 25 4500 4200 4500 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4500 3600 25 25 4500 3600 4500 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4200 4200 25 25 4200 4200 4200 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4200 3600 25 25 4200 3600 4200 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 6900 1800 25 25 6900 1800 6900 1775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3900 2400 25 25 3900 2400 3900 2375
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 3900 600 25 25 3900 600 3900 575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1500 4200 25 25 1500 4200 1500 4175
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 1500 3600 25 25 1500 3600 1500 3575
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 900 4800 25 25 900 4800 900 4775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 900 3000 25 25 900 3000 900 2975
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4500 1800 25 25 4500 1800 4500 1775
+1 3 0 1 0 0 40 -1 20 4.000 1 0.0000 4500 1200 25 25 4500 1200 4500 1175
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 600 8400 600
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 2400 8400 2400
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 3000 8400 3000
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 4800 8400 4800
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 1200 8400 1200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2700 4200 3300 4800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2700 3600 3300 3000
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2700 3000 3300 3600
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 3600 8400 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        2700 4800 3300 4200
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 1800 8400 1800
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 4200 8400 4200
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        1500 1200 2100 600
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        1500 600 2100 1200
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        1500 1800 2100 2400
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 2
+        1500 2400 2100 1800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        5700 4800 6300 600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        5700 600 6300 4800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        6300 1200 6900 4275
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        6300 4200 6900 1200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        6900 3600 7500 1800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        7500 2400 8100 3000
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        6900 1800 7500 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        7500 3000 8100 2400
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        4500 3600 5100 4200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        4500 4200 5100 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        3900 2400 4500 600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        3900 600 4500 2400
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        4500 1800 5100 1200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        4500 1200 5100 1800
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        1500 4200 2100 3600
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        1500 3600 2100 4200
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        900 4800 1500 3000
+2 1 0 1 0 7 50 -1 -1 4.000 0 0 -1 0 0 2
+        900 3000 1500 4800
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 675 0\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 1275 4\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 1875 2\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 2475 6\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 3675 5\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 4275 3\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 4875 7\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 300 3075 1\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 1800 2350 C6\001
+4 1 0 40 -1 0 12 0.0000 4 135 195 2100 2275 S6\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 1800 1750 C6\001
+4 1 0 40 -1 0 12 0.0000 4 135 255 2100 2050 -S6\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 3000 1125 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 3000 525 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 675 0\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 1275 1\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 1875 2\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 2475 3\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 3075 4\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 3675 5\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 4275 6\001
+4 1 0 40 -1 0 12 0.0000 4 135 90 8700 4875 7\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 4200 4125 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 4200 3525 C4\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 1800 4150 C3\001
+4 1 0 40 -1 0 12 0.0000 4 135 195 2100 4075 S3\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 1800 3550 C3\001
+4 1 0 40 -1 0 12 0.0000 4 135 255 2100 3850 -S3\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 1200 2950 C7\001
+4 1 0 40 -1 0 12 0.0000 4 135 255 1500 3375 -S7\001
+4 1 0 40 -1 0 12 0.0000 4 135 210 1200 4750 C7\001
+4 1 0 40 -1 0 12 0.0000 4 135 195 1500 4575 S7\001
diff --git a/doc/spec/lflim.fig b/doc/spec/lflim.fig
new file mode 100644 (file)
index 0000000..c71dc7f
--- /dev/null
@@ -0,0 +1,23 @@
+#FIG 3.2  Produced by xfig version 3.2.5
+Landscape
+Center
+Inches
+Letter  
+100.00
+Single
+-2
+1200 2
+2 1 2 1 0 7 50 -1 -1 3.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        600 2400 5400 2400
+2 1 2 1 0 7 50 -1 -1 3.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        3000 4200 3000 600
+2 1 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 6
+        600 2400 1200 2400 2100 3300 3900 1500 4800 2400 5400 2400
+4 1 0 50 -1 1 12 0.0000 0 195 615 1200 2325 (-2L,0)\001
+4 1 0 50 -1 1 12 0.0000 0 195 600 2100 3525 (-L,-L)\001
+4 0 0 50 -1 1 12 0.0000 0 150 360 3075 825 lflim\001
+4 1 0 50 -1 1 12 0.0000 0 195 480 3900 1425 (L,L)\001
+4 1 0 50 -1 1 12 0.0000 0 195 555 4800 2625 (2L,0)\001
+4 0 0 50 -1 1 12 0.0000 0 150 135 5250 2625 R\001
diff --git a/doc/spec/ltablex.sty b/doc/spec/ltablex.sty
new file mode 100644 (file)
index 0000000..31a0847
--- /dev/null
@@ -0,0 +1,237 @@
+%%
+%% This is file ltablex.sty  (v1.0, November 1995)
+%%
+%%
+%% Author: Anil K. Goel (akgoel@uwaterloo.ca)
+%%
+%%
+%% Copyright (C) QNX Software Systems Ltd. 1995
+%%               All rights reserved. 
+%% Please send any comments/suggetions to:   latex@qnx.com
+%%
+%% This system is distributed in the hope that it will be useful
+%% to others,  but WITHOUT ANY WARRANTY; without even the implied
+%% warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 
+%%
+%%
+%% The file modifies the tabularx environment to
+%% combine the features of the tabularx package
+%% (auto-sized columns in a fixed width table) 
+%% with those of the longtable package 
+%% (multi-page tables).
+%% 
+%% The tables are typeset using the tabularx environment
+%% and the longtable environment is used internally to
+%% handle multi-page tables. The \setlongtables feature
+%% is used, and, therefore, the document should be
+%% run through latex twice.
+%% 
+%% Another feature that has been added is to treat the X 
+%% columns like 'l' columns if the table contents would allow
+%% that to happen without exceeding the specified width of
+%% the table. In other words, the specified width is 
+%% treated as the maximum allowed and not the exact width 
+%% of the table. This feature is the default but can be 
+%% disabled (or enabled) with \keepXColumns (or \convertXColumns).
+%%
+%% Caveats:
+%%   . The document needs to be latexed a couple times in general.
+%%   . In general, it is necessary to remove the .aux file before
+%%     the first latex run on the document.
+%%   . The table should not be larger than TeX's memory capacity
+%%
+%%
+%% Here is a a simple usage example:
+%%
+%%
+%% \documentclass{article}
+%% 
+%% \usepackage{ltablex}
+%% 
+%% \textheight=4in
+%% 
+%% \begin{document}
+%% 
+%% % we want a table that is \textwidth long, has 4 columns, columns 1
+%% % and 3 are auto sized with the 3rd columns being 3 times wider than
+%% % the first column.
+%% %
+%% 
+%% 
+%% \begin{tabularx}{\linewidth}%
+%%  {|>{\setlength{\hsize}{.5\hsize}\raggedright\arraybackslash}X| % col 1; auto-sized ragged right
+%%     c|                                                        % col 2; default    centered
+%%     >{\setlength{\hsize}{1.5\hsize}\raggedleft\arraybackslash}X|% col 3; auto-sized ragged left
+%%     l|}                                                       % col 4; default    left-justified
+%% 
+%% \caption*{The Table Caption}\\
+%% \hline
+%% F-Head1 & F-Head2 & F-Head3 & F-Head4\\
+%% \hline
+%% \hline
+%% \endfirsthead
+%% \hline
+%% Head1 & Head2 & Head3 & Head4\\
+%% \hline
+%% \hline
+%% \endhead
+%% 
+%% \hline
+%% \hline
+%% Foot1 & Foot2 & Foot3 & Foot4\\
+%% \hline
+%% \endfoot
+%% 
+%% 
+%% \hline
+%% \hline
+%% L-Foot1 & L-Foot2 & L-Foot3 & L-Foot4\\
+%% \hline
+%% \endlastfoot
+%% 
+%% This is a very long sentence not likely to fit&
+%% not too long&
+%% This is another  very long sentence not likely to fit&
+%% not long\\
+%% 
+%% \hline
+%% filler & filler & filler & filler\\
+%% 
+%% \hline
+%% This is a very long sentence not likely to fit&
+%% not too long&
+%% This is another  very long sentence not likely to fit&
+%% not long\\
+%% 
+%% \hline
+%% This is a very long sentence not likely to fit&
+%% not too long&
+%% This is another  very long sentence not likely to fit&
+%% not long\\
+%% 
+%% \hline
+%% This is a very long sentence not likely to fit&
+%% not too long&
+%% This is another  very long sentence not likely to fit&
+%% not long\\
+%% 
+%% \end{tabularx}
+%% 
+%% \begin{tabularx}{\linewidth}{|c|X|c|}
+%% \hline
+%% a &convert X to l & b\\
+%% \hline
+%% \end{tabularx}
+%% 
+%% \keepXColumns
+%% \begin{tabularx}{\linewidth}{|c|X|c|}
+%% \hline
+%% a &retain X & b\\
+%% \hline
+%% \end{tabularx}
+%% 
+%% \convertXColumns
+%% \begin{tabularx}{\linewidth}{|c|X|c|}
+%% \hline
+%% a &convert X to l & b\\
+%% \hline
+%% \end{tabularx}
+%% 
+%% 
+%% \end{document}
+
+\NeedsTeXFormat{LaTeX2e}
+\ProvidesPackage{ltablex}[1995/11/06 v1.0 Modified tabularx]
+
+\RequirePackage{longtable}[1994/12/08]
+\RequirePackage{tabularx}[1994/02/03]
+
+\newif\ifTX@convertX@
+\TX@convertX@true
+
+\newcommand\keepXColumns{
+  \TX@convertX@false
+}
+
+\newcommand\convertXColumns{
+  \TX@convertX@true
+}
+
+\renewcommand\TX@endtabularx{%
+  \expandafter\TX@newcol\expandafter{\tabularxcolumn{\TX@col@width}}%
+  \let\verb\TX@verb
+  \def\@elt##1{\global\value{##1}\the\value{##1}\relax}%
+  \edef\TX@ckpt{\cl@@ckpt}%
+  \let\@elt\relax
+  \TX@old@table=\maxdimen
+  \TX@col@width=\TX@target
+  \global\TX@cols=\@ne
+  \TX@typeout@
+    {\@spaces Table Width\@spaces Column Width\@spaces X Columns}%
+   
+  %
+  % define \endhead, etc. to be \\ so that in this part
+  % of the process they are just rows
+  %
+  \let\savecaption\caption
+  \def\caption{\\}
+  \let\saveendhead\endhead
+  \def\endhead{\\}
+  \let\saveendfirsthead\endfirsthead
+  \def\endfirsthead{\\}
+  \let\saveendfoot\endfoot
+  \def\endfoot{\\}
+  \let\saveendlastfoot\endlastfoot
+  \def\endlastfoot{\\}
+  %
+  %
+  \ifTX@convertX@
+    \TX@trial{\def\NC@rewrite@X{\NC@find l}}
+    \ifdim\wd\@tempboxa<\TX@target
+      \TX@newcol{l}
+    \else
+      \TX@convertX@false
+    \fi
+  \fi
+
+  \ifTX@convertX@
+    \relax
+  \else
+    \TX@trial{\def\NC@rewrite@X{%
+        \global\advance\TX@cols\@ne\NC@find p{\TX@col@width}}}%
+    \loop
+      \TX@arith
+      \ifTX@
+      \TX@trial{}%
+    \repeat
+  \fi
+  {\let\@footnotetext\TX@ftntext\let\@xfootnotenext\TX@xftntext
+    % we may as well set \LTchunksize to be \maxdimen as the whole
+    % thing is already in memory anyway so we may as well do it in one
+    % chunk. if it is too big for one chunk we are already dead.. 
+    \LTchunksize\maxdimen
+    % 
+    % restore \endhead, etc.
+    %
+    \let\caption\savecaption
+    \let\endhead\saveendhead
+    \let\endfirsthead\saveendfirsthead
+    \let\endfoot\saveendfoot
+    \let\endlastfoot\saveendlastfoot
+    %
+    \expandafter\longtable
+      \the\toks@
+    \endlongtable
+    }%
+  \global\TX@ftn\expandafter{\expandafter}\the\TX@ftn
+  \ifnum0=`{\fi}%
+   \end{tabularx}
+}
+
+
+%
+% activate column width reading from the .aux file
+%
+
+
+\setlongtables
diff --git a/doc/spec/macroblock.fig b/doc/spec/macroblock.fig
new file mode 100644 (file)
index 0000000..3e20d93
--- /dev/null
@@ -0,0 +1,37 @@
+#FIG 3.2  Produced by xfig version 3.2.5-alpha4
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        702 1540 4867 1540 4867 4828 702 4828 702 1540
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4828 928 4828 928 4610 710 4610 710 4828
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        914 4610 1133 4610 1133 4391 914 4391 914 4610
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        723 4385 1133 4385 1133 4828 723 4828 723 4385
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4610 928 4610 928 4391 710 4391 710 4610
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        914 4828 1133 4828 1133 4610 914 4610 914 4828
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2068 857 6233 857 6233 4145 2068 4145 2068 857
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        1385 1198 5550 1198 5550 4487 1385 4487 1385 1198
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2089 3702 2499 3702 2499 4145 2089 4145 2089 3702
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1406 4043 1816 4043 1816 4487 1406 4487 1406 4043
+4 0 0 50 -1 0 5 0.0000 4 79 182 613 4943 (0,0)\001
+4 0 0 50 -1 0 5 0.0000 4 80 785 2055 833 Frame: chroma plane\001
+4 0 0 50 -1 0 5 0.0000 4 57 467 894 4009 Macroblock\001
+4 0 0 50 -1 0 5 0.0000 4 57 228 450 4521 Block\001
+4 0 0 50 -1 0 5 0.0000 4 57 228 450 4760 Block\001
+4 0 0 50 -1 0 5 0.0000 4 57 148 450 4863 8x8\001
+4 0 0 50 -1 0 5 0.0000 4 80 785 1235 1175 Frame: chroma plane\001
+4 0 0 50 -1 0 5 0.0000 4 80 694 621 1516 Frame: luma plane\001
diff --git a/doc/spec/pic-frame.fig b/doc/spec/pic-frame.fig
new file mode 100644 (file)
index 0000000..d99ec7e
--- /dev/null
@@ -0,0 +1,75 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+0 32 #7f7f7f
+6 250 236 5737 4724
+6 659 4520 1068 4724
+4 1 0 50 0 0 7 0.0000 0 75 450 864 4724 X Offset\001
+4 1 0 50 0 0 7 0.0000 0 90 375 864 4596 Picture\001
+-6
+6 250 3880 454 4290
+4 1 0 50 0 0 7 1.5708 0 90 375 327 4086 Picture\001
+4 1 0 50 0 0 7 1.5708 0 75 450 454 4086 Y Offset\001
+-6
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        608 301 608 454
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        5466 301 5466 454
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 1 2
+       1 1 1.00 34.09 68.18
+       1 1 1.00 34.09 68.18
+        608 378 5466 378
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        608 4392 608 4546
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        1119 4392 1119 4546
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 1 2
+       1 1 1.00 34.09 68.18
+       1 1 1.00 34.09 68.18
+        608 4468 1119 4468
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 1 2
+       1 1 1.00 34.09 68.18
+       1 1 1.00 34.09 68.18
+        1119 4468 5211 4468
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        5211 4392 5211 4546
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        404 4340 557 4340
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        404 3830 557 3830
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        404 761 557 761
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 1 2
+       1 1 1.00 34.09 68.18
+       1 1 1.00 34.09 68.18
+        480 3830 480 761
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        5517 4340 5671 4340
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 0 0 2
+        5517 506 5671 506
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 1 2
+       1 1 1.00 34.09 68.18
+       1 1 1.00 34.09 68.18
+        5594 4340 5594 506
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 1 2
+       1 1 1.00 34.09 68.18
+       1 1 1.00 34.09 68.18
+        480 4340 480 3830
+2 2 0 1 0 7 50 0 -1 0.000 0 0 7 0 0 5
+        608 506 5466 506 5466 4340 608 4340 608 506
+2 2 0 1 0 7 50 0 -1 0.000 0 0 7 0 0 5
+        1119 761 5211 761 5211 3830 1119 3830 1119 761
+4 1 0 50 0 0 7 0.0000 0 90 720 3165 4596 Picture Width\001
+4 1 0 50 0 0 7 1.5708 0 105 690 5722 1912 Frame Height\001
+4 1 0 50 0 0 7 0.0000 0 90 660 2782 326 Frame Width\001
+4 1 0 50 0 0 7 1.5708 0 105 750 454 2295 Picture Height\001
+4 1 0 50 0 0 7 0.0000 0 75 315 2782 685 Frame\001
+4 1 0 50 0 0 7 0.0000 0 90 375 3165 2295 Picture\001
+4 0 0 50 0 0 7 0.0000 0 105 240 659 4290 (0,0)\001
+-6
diff --git a/doc/spec/pic_even.fig b/doc/spec/pic_even.fig
new file mode 100644 (file)
index 0000000..041a43a
--- /dev/null
@@ -0,0 +1,102 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 724 2025 945 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2244 945 2244 945 2025 732 2025 732 2244
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2475 945 2475 945 2256 732 2256 732 2475
+-6
+6 1665 2070 1888 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2267 1888 2267 1888 2070 1673 2070 1673 2267
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2475 1888 2475 1888 2278 1673 2278 1673 2475
+-6
+6 724 900 945 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 1119 945 1119 945 900 732 900 732 1119
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 1350 945 1350 945 1131 732 1131 732 1350
+-6
+6 6300 2070 6795 2520
+6 6300 2070 6570 2295
+6 6300 2070 6570 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6335 2295 6553 2295 6553 2076 6335 2076 6335 2295
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6335 2520 6553 2520 6553 2301 6335 2301 6335 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2295 6778 2295 6778 2076 6560 2076 6560 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2520 6778 2520 6778 2301 6560 2301 6560 2520
+-6
+6 4455 2070 4950 2520
+6 4455 2070 4725 2295
+6 4455 2070 4725 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2295 4708 2295 4708 2076 4490 2076 4490 2295
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2520 4708 2520 4708 2301 4490 2301 4490 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4715 2295 4933 2295 4933 2076 4715 2076 4715 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4715 2520 4933 2520 4933 2301 4715 2301 4715 2520
+-6
+6 4455 945 4950 1395
+6 4455 945 4725 1170
+6 4455 945 4725 1170
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 1170 4708 1170 4708 951 4490 951 4490 1170
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 1395 4708 1395 4708 1176 4490 1176 4490 1395
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4715 1170 4933 1170 4933 951 4715 951 4715 1170
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4715 1395 4933 1395 4933 1176 4715 1176 4715 1395
+-6
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2249 1800 3736 1800 3736 2947 2249 2947 2249 1800
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2385 1935 3600 1935 3600 2745 2385 2745 2385 1935
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2745 2610 2745 2610 2526 2397 2526 2397 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3375 2745 3590 2745 3590 2548 3375 2548 3375 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        724 900 1888 900 1888 2475 724 2475 724 900
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        473 675 2003 675 2003 2925 473 2925 473 675
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2154 2610 2154 2610 1935 2397 1935 2397 2154
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        4005 720 7020 720 7020 2970 4005 2970 4005 720
+4 0 0 50 -1 0 24 0.0000 4 30 270 2835 2655 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 1080 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 765 1665 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 2430 2385 ...\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 450 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 2205 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 3943 3098 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 75 285 4545 2655 Pixels\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 5220 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 4680 1755 ...\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 2205 1665 Frame: chroma (4:2:0 case)\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 450 585 Frame: chroma (4:2:2 case)\001
+4 0 0 50 -1 0 9 0.0000 4 75 615 4005 630 Frame: luma\001
diff --git a/doc/spec/pic_even_odd.fig b/doc/spec/pic_even_odd.fig
new file mode 100644 (file)
index 0000000..4b513b7
--- /dev/null
@@ -0,0 +1,88 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 724 2025 945 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2244 945 2244 945 2025 732 2025 732 2244
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2475 945 2475 945 2256 732 2256 732 2475
+-6
+6 1665 2070 1888 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2267 1888 2267 1888 2070 1673 2070 1673 2267
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2475 1888 2475 1888 2278 1673 2278 1673 2475
+-6
+6 4455 2070 4950 2520
+6 4455 2070 4725 2295
+6 4455 2070 4725 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2295 4708 2295 4708 2076 4490 2076 4490 2295
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2520 4708 2520 4708 2301 4490 2301 4490 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4715 2295 4933 2295 4933 2076 4715 2076 4715 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4715 2520 4933 2520 4933 2301 4715 2301 4715 2520
+-6
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2249 1800 3736 1800 3736 2947 2249 2947 2249 1800
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2385 1935 3600 1935 3600 2745 2385 2745 2385 1935
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2745 2610 2745 2610 2526 2397 2526 2397 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3375 2745 3590 2745 3590 2548 3375 2548 3375 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        724 900 1888 900 1888 2475 724 2475 724 900
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        473 675 2003 675 2003 2925 473 2925 473 675
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2154 2610 2154 2610 1935 2397 1935 2397 2154
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        4005 720 7020 720 7020 2970 4005 2970 4005 720
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 1170 4708 1170 4708 951 4490 951 4490 1170
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4715 1170 4933 1170 4933 951 4715 951 4715 1170
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2520 6778 2520 6778 2301 6560 2301 6560 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2295 6778 2295 6778 2076 6560 2076 6560 2295
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4715 945 4933 945 4933 726 4715 726 4715 945
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4490 945 4708 945 4708 726 4490 726 4490 945
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        6785 2295 7003 2295 7003 2076 6785 2076 6785 2295
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        6785 2520 7003 2520 7003 2301 6785 2301 6785 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 1125 945 1125 945 906 732 906 732 1125
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        732 894 945 894 945 675 732 675 732 894
+4 0 0 50 -1 0 24 0.0000 4 30 270 2835 2655 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 1080 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 765 1665 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 2430 2385 ...\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 450 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 2205 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 3943 3098 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 75 285 4545 2655 Pixels\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 5220 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 4680 1755 ...\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 2205 1665 Frame: chroma (4:2:0 case)\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 450 585 Frame: chroma (4:2:2 case)\001
+4 0 0 50 -1 0 9 0.0000 4 75 615 4005 630 Frame: luma\001
diff --git a/doc/spec/pic_odd.fig b/doc/spec/pic_odd.fig
new file mode 100644 (file)
index 0000000..da12601
--- /dev/null
@@ -0,0 +1,90 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 724 2025 945 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2244 945 2244 945 2025 732 2025 732 2244
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2475 945 2475 945 2256 732 2256 732 2475
+-6
+6 1665 2070 1888 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2267 1888 2267 1888 2070 1673 2070 1673 2267
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2475 1888 2475 1888 2278 1673 2278 1673 2475
+-6
+6 724 900 945 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 1119 945 1119 945 900 732 900 732 1119
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 1350 945 1350 945 1131 732 1131 732 1350
+-6
+6 6300 2070 6795 2520
+6 6300 2070 6570 2295
+6 6300 2070 6570 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6335 2295 6553 2295 6553 2076 6335 2076 6335 2295
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6335 2520 6553 2520 6553 2301 6335 2301 6335 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2295 6778 2295 6778 2076 6560 2076 6560 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2520 6778 2520 6778 2301 6560 2301 6560 2520
+-6
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2249 1800 3736 1800 3736 2947 2249 2947 2249 1800
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2385 1935 3600 1935 3600 2745 2385 2745 2385 1935
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2745 2610 2745 2610 2526 2397 2526 2397 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3375 2745 3590 2745 3590 2548 3375 2548 3375 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        724 900 1888 900 1888 2475 724 2475 724 900
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        473 675 2003 675 2003 2925 473 2925 473 675
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2154 2610 2154 2610 1935 2397 1935 2397 2154
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        4005 720 7020 720 7020 2970 4005 2970 4005 720
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2295 4708 2295 4708 2076 4490 2076 4490 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2520 4708 2520 4708 2301 4490 2301 4490 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 1170 4708 1170 4708 951 4490 951 4490 1170
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 1395 4708 1395 4708 1176 4490 1176 4490 1395
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 1170 4483 1170 4483 951 4265 951 4265 1170
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 1395 4483 1395 4483 1176 4265 1176 4265 1395
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 2295 4483 2295 4483 2076 4265 2076 4265 2295
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 2520 4483 2520 4483 2301 4265 2301 4265 2520
+4 0 0 50 -1 0 24 0.0000 4 30 270 2835 2655 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 1080 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 765 1665 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 2430 2385 ...\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 450 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 2205 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 3943 3098 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 75 285 4545 2655 Pixels\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 5220 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 4680 1755 ...\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 2205 1665 Frame: chroma (4:2:0 case)\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 450 585 Frame: chroma (4:2:2 case)\001
+4 0 0 50 -1 0 9 0.0000 4 75 615 4005 630 Frame: luma\001
diff --git a/doc/spec/pic_odd_even.fig b/doc/spec/pic_odd_even.fig
new file mode 100644 (file)
index 0000000..f131295
--- /dev/null
@@ -0,0 +1,84 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 724 2025 945 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2244 945 2244 945 2025 732 2025 732 2244
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 2475 945 2475 945 2256 732 2256 732 2475
+-6
+6 1665 2070 1888 2475
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2267 1888 2267 1888 2070 1673 2070 1673 2267
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1673 2475 1888 2475 1888 2278 1673 2278 1673 2475
+-6
+6 724 900 945 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 1119 945 1119 945 900 732 900 732 1119
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        732 1350 945 1350 945 1131 732 1131 732 1350
+-6
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2249 1800 3736 1800 3736 2947 2249 2947 2249 1800
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2385 1935 3600 1935 3600 2745 2385 2745 2385 1935
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2745 2610 2745 2610 2526 2397 2526 2397 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3375 2745 3590 2745 3590 2548 3375 2548 3375 2745
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        724 900 1888 900 1888 2475 724 2475 724 900
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        473 675 2003 675 2003 2925 473 2925 473 675
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2397 2154 2610 2154 2610 1935 2397 1935 2397 2154
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        4005 720 7020 720 7020 2970 4005 2970 4005 720
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2295 4708 2295 4708 2076 4490 2076 4490 2295
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 2520 4708 2520 4708 2301 4490 2301 4490 2520
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 2295 4483 2295 4483 2076 4265 2076 4265 2295
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 2520 4483 2520 4483 2301 4265 2301 4265 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4500 945 6795 945 6795 2520 4500 2520 4500 945
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2520 6778 2520 6778 2301 6560 2301 6560 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        6560 2295 6778 2295 6778 2076 6560 2076 6560 2295
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        6785 2295 7003 2295 7003 2076 6785 2076 6785 2295
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        6785 2520 7003 2520 7003 2301 6785 2301 6785 2520
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4490 1170 4708 1170 4708 951 4490 951 4490 1170
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 945 4483 945 4483 726 4265 726 4265 945
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4265 1170 4483 1170 4483 951 4265 951 4265 1170
+2 2 0 1 0 11 50 -1 43 0.000 0 0 -1 0 0 5
+        4490 945 4708 945 4708 726 4490 726 4490 945
+4 0 0 50 -1 0 24 0.0000 4 30 270 2835 2655 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 1080 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 765 1665 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 2430 2385 ...\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 450 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 2205 3060 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 3943 3098 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 75 285 4545 2655 Pixels\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 5220 2295 ...\001
+4 0 0 50 -1 0 24 0.0000 4 30 270 4680 1755 ...\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 2205 1665 Frame: chroma (4:2:0 case)\001
+4 0 0 50 -1 0 9 0.0000 4 105 1335 450 585 Frame: chroma (4:2:2 case)\001
+4 0 0 50 -1 0 9 0.0000 4 75 615 4005 630 Frame: luma\001
diff --git a/doc/spec/pixel420.fig b/doc/spec/pixel420.fig
new file mode 100644 (file)
index 0000000..56e9191
--- /dev/null
@@ -0,0 +1,56 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 675 4365 1170 4815
+6 675 4365 945 4590
+6 675 4365 945 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4590 928 4590 928 4371 710 4371 710 4590
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4815 928 4815 928 4596 710 4596 710 4815
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        935 4590 1153 4590 1153 4371 935 4371 935 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        935 4815 1153 4815 1153 4596 935 4596 935 4815
+-6
+6 1125 4365 1646 4815
+6 1125 4365 1420 4590
+6 1125 4365 1420 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1163 4590 1401 4590 1401 4371 1163 4371 1163 4590
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1163 4815 1401 4815 1401 4596 1163 4596 1163 4815
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1409 4590 1646 4590 1646 4371 1409 4371 1409 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1409 4815 1646 4815 1646 4596 1409 4596 1409 4815
+-6
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        1665 1350 4788 1350 4788 4153 1665 4153 1665 1350
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2700 900 5823 900 5823 3703 2700 3703 2700 900
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        702 2025 3825 2025 3825 4828 702 4828 702 2025
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1800 4005 2018 4005 2018 3786 1800 3786 1800 4005
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2160 4005 2378 4005 2378 3786 2160 3786 2160 4005
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2835 3555 3053 3555 3053 3336 2835 3336 2835 3555
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3195 3555 3413 3555 3413 3336 3195 3336 3195 3555
+4 0 0 50 -1 0 8 0.0000 4 105 1215 1485 1305 Frame: chroma plane Cb\001
+4 0 0 50 -1 0 8 0.0000 4 105 1200 2565 855 Frame: chroma plane Cr\001
+4 0 0 50 -1 0 8 0.0000 4 105 1035 540 1980 Frame: luma planeY'\001
+4 0 0 50 -1 0 7 0.0000 4 75 285 765 4320 Pixels\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 613 4943 (0,0)\001
diff --git a/doc/spec/pixel422.fig b/doc/spec/pixel422.fig
new file mode 100644 (file)
index 0000000..dbe008a
--- /dev/null
@@ -0,0 +1,70 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 675 4365 1170 4815
+6 675 4365 945 4590
+6 675 4365 945 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4590 928 4590 928 4371 710 4371 710 4590
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4815 928 4815 928 4596 710 4596 710 4815
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        935 4590 1153 4590 1153 4371 935 4371 935 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        935 4815 1153 4815 1153 4596 935 4596 935 4815
+-6
+6 1125 4365 1646 4815
+6 1125 4365 1420 4590
+6 1125 4365 1420 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1163 4590 1401 4590 1401 4371 1163 4371 1163 4590
+-6
+-6
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1163 4815 1401 4815 1401 4596 1163 4596 1163 4815
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1409 4590 1646 4590 1646 4371 1409 4371 1409 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1409 4815 1646 4815 1646 4596 1409 4596 1409 4815
+-6
+6 1800 3690 2025 4140
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1807 3909 2025 3909 2025 3690 1807 3690 1807 3909
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1807 4140 2025 4140 2025 3921 1807 3921 1807 4140
+-6
+6 2160 3690 2385 4140
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2167 3909 2385 3909 2385 3690 2167 3690 2167 3909
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2167 4140 2385 4140 2385 3921 2167 3921 2167 4140
+-6
+6 3195 3240 3420 3690
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3202 3459 3420 3459 3420 3240 3202 3240 3202 3459
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3202 3690 3420 3690 3420 3471 3202 3471 3202 3690
+-6
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        1665 1350 4788 1350 4788 4153 1665 4153 1665 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2842 3459 3060 3459 3060 3240 2842 3240 2842 3459
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2700 900 5823 900 5823 3703 2700 3703 2700 900
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2842 3690 3060 3690 3060 3471 2842 3471 2842 3690
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        702 2025 3825 2025 3825 4828 702 4828 702 2025
+4 0 0 50 -1 0 8 0.0000 4 105 1215 1485 1305 Frame: chroma plane Cb\001
+4 0 0 50 -1 0 8 0.0000 4 105 1200 2565 855 Frame: chroma plane Cr\001
+4 0 0 50 -1 0 8 0.0000 4 105 1035 540 1980 Frame: luma planeY'\001
+4 0 0 50 -1 0 7 0.0000 4 75 285 765 4320 Pixels\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 613 4943 (0,0)\001
diff --git a/doc/spec/pixel444.fig b/doc/spec/pixel444.fig
new file mode 100644 (file)
index 0000000..75655e8
--- /dev/null
@@ -0,0 +1,44 @@
+#FIG 3.2
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        702 2025 3825 2025 3825 4828 702 4828 702 2025
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        1665 1350 4788 1350 4788 4153 1665 4153 1665 1350
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        2700 900 5823 900 5823 3703 2700 3703 2700 900
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4590 928 4590 928 4371 710 4371 710 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        935 4590 1153 4590 1153 4371 935 4371 935 4590
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        935 4815 1153 4815 1153 4596 935 4596 935 4815
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        710 4815 928 4815 928 4596 710 4596 710 4815
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1700 3915 1918 3915 1918 3696 1700 3696 1700 3915
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1925 3915 2143 3915 2143 3696 1925 3696 1925 3915
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1925 4140 2143 4140 2143 3921 1925 3921 1925 4140
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1700 4140 1918 4140 1918 3921 1700 3921 1700 4140
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2735 3465 2953 3465 2953 3246 2735 3246 2735 3465
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2960 3465 3178 3465 3178 3246 2960 3246 2960 3465
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2960 3690 3178 3690 3178 3471 2960 3471 2960 3690
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2735 3690 2953 3690 2953 3471 2735 3471 2735 3690
+4 0 0 50 -1 0 8 0.0000 4 105 1215 1485 1305 Frame: chroma plane Cb\001
+4 0 0 50 -1 0 8 0.0000 4 105 1200 2565 855 Frame: chroma plane Cr\001
+4 0 0 50 -1 0 8 0.0000 4 105 1035 540 1980 Frame: luma planeY'\001
+4 0 0 50 -1 0 7 0.0000 4 75 285 765 4320 Pixels\001
+4 0 0 50 -1 0 7 0.0000 4 90 210 613 4943 (0,0)\001
diff --git a/doc/spec/raster-block.fig b/doc/spec/raster-block.fig
new file mode 100644 (file)
index 0000000..cebaf02
--- /dev/null
@@ -0,0 +1,91 @@
+#FIG 3.2  Produced by xfig version 3.2.5-alpha4
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1125 900 1575 900
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 450 1350 450 1350 1350 450 1350 450 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 450 2250 450 2250 1350 1350 1350 1350 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 450 3150 450 3150 1350 2250 1350 2250 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 450 4050 450 4050 1350 3150 1350 3150 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 1350 1350 1350 1350 2250 450 2250 450 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 1350 2250 1350 2250 2250 1350 2250 1350 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 1350 3150 1350 3150 2250 2250 2250 2250 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 1350 4050 1350 4050 2250 3150 2250 3150 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 2250 1350 2250 1350 3150 450 3150 450 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 2250 2250 2250 2250 3150 1350 3150 1350 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 2250 3150 2250 3150 3150 2250 3150 2250 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 2250 4050 2250 4050 3150 3150 3150 3150 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        450 3150 1350 3150 1350 4050 450 4050 450 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1350 3150 2250 3150 2250 4050 1350 4050 1350 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2250 3150 3150 3150 3150 4050 2250 4050 2250 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        3150 3150 4050 3150 4050 4050 3150 4050 3150 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4050 450 4950 450 4950 1350 4050 1350 4050 450
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4050 1350 4950 1350 4950 2250 4050 2250 4050 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4050 2250 4950 2250 4950 3150 4050 3150 4050 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4050 3150 4950 3150 4950 4050 4050 4050 4050 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4950 3150 5850 3150 5850 4050 4950 4050 4950 3150
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4950 2250 5850 2250 5850 3150 4950 3150 4950 2250
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4950 1350 5850 1350 5850 2250 4950 2250 4950 1350
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        4950 450 5850 450 5850 1350 4950 1350 4950 450
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1125 3600 1575 3600
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        2925 3600 3375 3600
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        2025 3600 2475 3600
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        1125 2655 1575 2655
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        4770 3600 5220 3600
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        5445 3510 900 2880
+2 1 0 1 0 7 50 0 -1 0.000 0 0 -1 1 0 2
+       1 1 1.00 60.00 120.00
+        5400 1800 855 1170
+4 1 0 50 0 1 12 0.0000 0 150 105 900 3660 0\001
+4 1 0 50 0 1 12 0.0000 0 150 105 1800 3660 1\001
+4 1 0 50 0 1 12 0.0000 0 150 105 2700 3660 2\001
+4 0 0 50 -1 0 20 0.0000 4 30 225 3555 3645 ...\001
+4 0 0 50 -1 0 20 0.0000 4 30 225 945 1845 ...\001
+4 0 0 50 -1 0 12 0.0000 4 150 330 5310 3645 m-1\001
+4 0 0 50 -1 0 12 0.0000 4 150 435 5175 2655 2m-1\001
+4 1 0 50 0 1 12 0.0000 0 105 165 900 2760 m\001
+4 1 0 50 0 1 12 0.0000 0 195 690 855 1035 (n-1)*m\001
+4 0 0 50 -1 0 12 0.0000 4 150 540 5085 900 n*m-1\001
diff --git a/doc/spec/reference-frames.fig b/doc/spec/reference-frames.fig
new file mode 100644 (file)
index 0000000..8026e56
--- /dev/null
@@ -0,0 +1,46 @@
+#FIG 3.2  Produced by xfig version 3.2.5-alpha4
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+2 2 1 2 0 7 50 -1 -1 4.000 0 0 -1 0 0 5
+        1980 450 2430 450 2430 900 1980 900 1980 450
+2 2 1 2 0 7 50 -1 -1 4.000 0 0 -1 0 0 5
+        2520 450 2970 450 2970 900 2520 900 2520 450
+2 2 1 2 0 7 50 -1 -1 4.000 0 0 -1 0 0 5
+        4140 450 4590 450 4590 900 4140 900 4140 450
+2 2 1 2 0 7 50 -1 -1 4.000 0 0 -1 0 0 5
+        1440 450 1890 450 1890 900 1440 900 1440 450
+2 2 1 2 0 7 50 -1 15 4.000 0 0 -1 0 0 5
+        3600 450 4050 450 4050 900 3600 900 3600 450
+2 2 1 2 0 7 50 -1 41 4.000 0 0 -1 0 0 5
+        3060 450 3510 450 3510 900 3060 900 3060 450
+2 2 0 2 0 7 50 -1 41 0.000 0 0 -1 0 0 5
+        900 450 1350 450 1350 900 900 900 900 450
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 1 2
+       0 0 1.00 60.00 120.00
+        3780 990 3780 1395
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 1 2
+       0 0 1.00 60.00 120.00
+        3240 990 3240 1395
+2 1 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 1 2
+       0 0 1.00 60.00 120.00
+        1125 990 1125 1395
+4 0 0 50 -1 0 20 0.0000 4 30 225 4770 675 ...\001
+4 0 0 50 -1 0 12 0.0000 4 150 420 900 405 Intra\001
+4 0 0 50 -1 0 12 0.0000 4 150 420 1440 405 Inter\001
+4 0 0 50 -1 0 12 0.0000 4 150 420 1980 405 Inter\001
+4 0 0 50 -1 0 12 0.0000 4 150 420 2520 405 Inter\001
+4 0 0 50 -1 0 12 0.0000 4 150 420 3060 405 Inter\001
+4 0 0 50 -1 0 12 0.0000 4 150 420 3600 405 Inter\001
+4 0 0 50 -1 0 12 0.0000 4 150 420 4140 405 Inter\001
+4 0 0 50 -1 0 12 0.0000 4 120 630 3690 1575 current\001
+4 0 0 50 -1 0 12 0.0000 4 150 840 2745 1575 reference\001
+4 0 0 50 -1 0 12 0.0000 4 150 510 2925 1755 frame\001
+4 0 0 50 -1 0 12 0.0000 4 150 510 3690 1755 frame\001
+4 0 0 50 -1 0 12 0.0000 4 195 570 855 1575 golden\001
+4 0 0 50 -1 0 12 0.0000 4 150 510 900 1800 frame\001
diff --git a/doc/spec/spec.bib b/doc/spec/spec.bib
new file mode 100644 (file)
index 0000000..a1cad1a
--- /dev/null
@@ -0,0 +1,120 @@
+@MANUAL{rfc2044,
+  author="Francois Yergeau",
+  title="{RFC} 2044: {UTF}-8, a transformation format of Unicode and {ISO}
+   10646",
+  month=oct,
+  year=1996,
+  note="\url{http://www.ietf.org/rfc/rfc2044.txt}"
+}
+
+@ARTICLE{CSF77,
+  author="Wen-Hsiung Chen and C. Harrison Smith and S. C. Fralick",
+  title="A Fast Computational Algorithm for the Discrete Cosine Transform",
+  journal="{IEEE} Transactions on Communications",
+  volume="COM-25",
+  number=9,
+  pages="1004--1011",
+  month=sep,
+  year=1977
+}
+
+@MISC{Mel04,
+  author="Mike Melanson",
+  title="{VP3} Bitstream Format and Decoding Process",
+  howpublished="\url{http://www.multimedia.cx/vp3-format.txt}",
+  month=mar,
+  year=2004
+}
+
+@MISC{Poyn97,
+  author="Charles Poynton",
+  title="Frequently-Asked Questions about Gamma",
+  howpublished="\url{http://www.poynton.com/GammaFAQ.html}",
+  month=feb,
+  year=1997
+}
+
+@MANUAL{rec470,
+  key="ITU470",
+  title="Reccomendation {ITU-R} {BT}.470-6: Conventional Television Systems",
+  edition="1970, revised",
+  organization="International Telecommunications Union",
+  address="1211 Geneva 20, Switzerland",
+  year=1998
+}
+
+@MANUAL{rec601,
+  key="ITU601",
+  title="Reccomendation {ITU-R} {BT}.601-5: Studio Encoding Parameters of
+   Digital Television for Standard 4:3 and Wide-Screen 16:9 Aspect Ratios",
+  edition="1982, revised",
+  organization="International Telecommunications Union",
+  address="1211 Geneva 20, Switzerland",
+  year=1995
+}
+
+@MANUAL{rec709,
+  key="ITU709",
+  title="Recommendation {ITU-R} {BT}.709-5: Parameter values for the {HDTV}
+   standards for production and international programme exchange",
+  edition="1990, revised",
+  organization="International Telecommunications Union",
+  address="1211 Geneva 20, Switzerland",
+  year=2002
+}
+
+@MANUAL{smpte170m,
+  key="SMPTE170M",
+  title="{SMPTE-170M}: Television --- Composite Analog Video Signal --- {NTSC}
+   for Studio Applications",
+  organization="Society of Motion Pciture and Television Engineers",
+  year=1994
+}
+
+@MANUAL{smpte240m,
+  key="SMPTE240M",
+  title="{SMPTE-240M}: Television --- Signal Parameters --- 1125-Line
+   High-Definition Production",
+  organization="Society of Motion Pciture and Television Engineers",
+  year=1999
+}
+
+@MANUAL{vorbis,
+  title="{Vorbis~I} specification",
+  organization="{Xiph.org Foundation}",
+  year=2002,
+  note="\url{http://www.xiph.org/ogg/vorbis/doc/}"
+}
+
+@MANUAL{rfc2119,
+  author="Scott Bradner",
+  title="{RFC} 2119: Key words for use in {RFC}s to Indicate Requirement
+   Levels",
+  month=mar,
+  year=1997,
+  note="\url{http://www.ietf.org/rfc/rfc2119.txt}"
+}
+
+@MANUAL{rfc3533,
+  author="Silvia Pfeiffer",
+  title="{RFC} 3533: The {Ogg} Encapsulation Format Version 0",
+  month=may,
+  year=2003,
+  note="\url{http://www.ietf.org/rfc/rfc3533.txt}"
+}
+
+@MANUAL{rfc3534,
+  author="Linus Walleij",
+  title="{RFC} 3534: The {application/ogg} Media Type",
+  month=may,
+  year=2003,
+  note="\url{http://www.ietf.org/rfc/rfc3534.txt}"
+}
+
+@MANUAL{rfc3550,
+  author="H. Schulzrinne, S. Casner, R. Frederick, V. Jacobson",
+  title="RTP: A Transport Protocol for Real-Time Applications",
+  month=jul,
+  year=2003,
+  note="\url{http://www.ietf.org/rfc/rfc3550.txt}"
+}
diff --git a/doc/spec/spec.tex b/doc/spec/spec.tex
new file mode 100644 (file)
index 0000000..b29d4ef
--- /dev/null
@@ -0,0 +1,8171 @@
+\documentclass[9pt,letterpaper]{book}
+
+\usepackage{latexsym}
+\usepackage{amssymb}
+\usepackage{amsmath}
+\usepackage{bm}
+\usepackage{textcomp}
+\usepackage{graphicx}
+\usepackage{booktabs}
+\usepackage{tabularx}
+\usepackage{longtable}
+\usepackage{ltablex}
+\usepackage{wrapfig}
+\usepackage[pdfpagemode=None,pdfstartview=FitH,pdfview=FitH,colorlinks=true]%
+ {hyperref}
+
+\newtheorem{theorem}{Theorem}[section]
+\newcommand{\idx}[1]{{\ensuremath{\mathit{#1}}}}
+\newcommand{\qti}{\idx{qti}}
+\newcommand{\qtj}{\idx{qtj}}
+\newcommand{\pli}{\idx{pli}}
+\newcommand{\plj}{\idx{plj}}
+\newcommand{\qi}{\idx{qi}}
+\newcommand{\ci}{\idx{ci}}
+\newcommand{\bmi}{\idx{bmi}}
+\newcommand{\bmj}{\idx{bmj}}
+\newcommand{\qri}{\idx{qri}}
+\newcommand{\qrj}{\idx{qrj}}
+\newcommand{\hti}{\idx{hti}}
+\newcommand{\sbi}{\idx{sbi}}
+\newcommand{\bi}{\idx{bi}}
+\newcommand{\bj}{\idx{bj}}
+\newcommand{\mbi}{\idx{mbi}}
+\newcommand{\mbj}{\idx{mbj}}
+\newcommand{\mi}{\idx{mi}}
+\newcommand{\cbi}{\idx{cbi}}
+\newcommand{\qii}{\idx{qii}}
+\newcommand{\ti}{\idx{ti}}
+\newcommand{\tj}{\idx{tj}}
+\newcommand{\rfi}{\idx{rfi}}
+\newcommand{\zzi}{\idx{zzi}}
+\newcommand{\ri}{\idx{ri}}
+%This somewhat odd construct ensures that \bitvar{\qi}, etc., will set the
+% qi in bold face, even though it is in a \mathit font, yet \bitvar{VAR} will
+% set VAR in a bold, roman font.
+\newcommand{\bitvar}[1]{\ensuremath{\mathbf{\bm{#1}}}}
+\newcommand{\locvar}[1]{\ensuremath{\mathrm{#1}}}
+\newcommand{\term}[1]{{\em #1}}
+\newcommand{\bin}[1]{\ensuremath{\mathtt{b#1}}}
+\newcommand{\hex}[1]{\ensuremath{\mathtt{0x#1}}}
+\newcommand{\ilog}{\ensuremath{\mathop{\mathrm{ilog}}\nolimits}}
+\newcommand{\round}{\ensuremath{\mathop{\mathrm{round}}\nolimits}}
+\newcommand{\sign}{\ensuremath{\mathop{\mathrm{sign}}\nolimits}}
+\newcommand{\lflim}{\ensuremath{\mathop{\mathrm{lflim}}\nolimits}}
+
+%Section-based table, figure, and equation numbering.
+\numberwithin{equation}{chapter}
+\numberwithin{figure}{chapter}
+\numberwithin{table}{chapter}
+
+\keepXColumns
+
+\pagestyle{headings}
+\bibliographystyle{alpha}
+
+\title{Theora Specification}
+\author{Xiph.org Foundation}
+\date{\today}
+
+
+\begin{document}
+
+\frontmatter
+
+\begin{titlepage}
+\maketitle
+\end{titlepage}
+\thispagestyle{empty}
+\cleardoublepage
+
+\pagenumbering{roman}
+
+\thispagestyle{plain}
+\tableofcontents
+\cleardoublepage
+
+\thispagestyle{plain}
+\listoffigures
+\cleardoublepage
+
+\thispagestyle{plain}
+\listoftables
+\cleardoublepage
+
+\thispagestyle{plain}
+\markboth{{\sc Notation and Conventions}}{{\sc Notation and Conventions}}
+\chapter*{Notation and Conventions}
+
+All parameters either passed in or out of a decoding procedure are given in
+ \bitvar{bold\ face}.
+
+The prefix \bin{} indicates that the following value is to be interpreted as a
+ binary number (base 2).
+\begin{verse}
+{\bf Example:} The value \bin{1110100} is equal to the decimal value 116.
+\end{verse}
+
+The prefix \hex{} indicates the the following value is to be interpreted as a
+ hexadecimal number (base 16).
+\begin{verse}
+{\bf Example:} The value \hex{74} is equal to the decimal value 116.
+\end{verse}
+
+All arithmetic defined by this specification is exact.
+However, any real numbers that do arise will always be converted back to
+ integers again in short order.
+The entire specification can be implemented using only normal integer
+ operations.
+All operations are to be implemented with sufficiently large integers so that
+ overflow cannot occur.
+Where the result of a computation is to be truncated to a fixed-sized binary
+ representation, this will be explicitly noted.
+The size given for all variables is the maximum number of bits needed to store
+ any value in that variable.
+Intermediate computations involving that variable may require more bits.
+
+The following operators are defined:
+
+\begin{description}
+\item[$|a|$]
+The absolute value of a number $a$.
+\begin{align*}
+|a| & = \left\{\begin{array}{ll}
+-a, & a < 0 \\
+a, & a \ge 0
+\end{array}\right.
+\end{align*}
+
+\item[$a*b$]
+Multiplication of a number $a$ by a number $b$.
+\item[$\frac{a}{b}$]
+Exact division of a number $a$ by a number $b$, producing a potentially
+ non-integer result.
+
+\item[$\left\lfloor a\right\rfloor$] 
+The largest integer less than or equal to a real number $a$.
+
+\item[$\left\lceil a\right\rceil$]
+The smallest integer greater than or equal to a real number $a$.
+
+\item[$a//b$]
+Integer division of $a$ by $b$.
+\begin{align*}
+a//b & = \left\{\begin{array}{ll}
+\left\lceil\frac{a}{b}\right\rceil, & a < 0 \\
+\left\lfloor\frac{a}{b}\right\rfloor, & a \ge 0
+\end{array}\right.
+\end{align*}
+
+\item[$a\%b$]
+The remainder from the integer division of $a$ by $b$.
+\begin{align*}
+a\%b & = a-|b|*\left\lfloor\frac{a}{|b|}\right\rfloor
+\end{align*}
+Note that with this definition, the result is always non-negative and less than
+ $|b|$.
+
+\item[$a<<b$]
+The value obtained by left-shifting the two's complement integer $a$ by $b$
+ bits.
+For purposes of this specification, overflow is ignored, and so this is
+ equivalent to integer multiplication of $a$ by $2^b$.
+
+\item[$a>>b$]
+The value obtained by right-shifting the two's complement integer $a$ by $b$
+ bits, filling in the leftmost bits of the new value with $0$ if $a$ is
+ non-negative and $1$ if $a$ is negative.
+This is {\em not} equivalent to integer division of $a$ by $2^b$.
+Instead,
+\begin{align*}
+a>>b & = \left\lfloor\frac{a}{2^b}\right\rfloor.
+\end{align*}
+
+\item[$\round(a)$]
+Rounds a number $a$ to the nearest integer, with ties rounded away from $0$.
+\begin{align*}
+\round(a) = \left\{\begin{array}{ll}
+\lceil a-\frac{1}{2}\rceil   & a \le 0 \\
+\lfloor a+\frac{1}{2}\rfloor & a > 0
+\end{array}\right.
+\end{align*}
+
+\item[$\sign(a)$]
+Returns the sign of a given number.
+\begin{align*}
+\sign(a) = \left\{\begin{array}{ll}
+-1 & a < 0 \\
+0  & a = 0 \\
+1  & a > 0
+\end{array}\right.
+\end{align*}
+
+\item[$\ilog(a)$]
+The minimum number of bits required to store a positive integer $a$ in
+ two's complement notation, or $0$ for a non-positive integer $a$.
+\begin{align*}
+\ilog(a) = \left\{\begin{array}{ll}
+0, & a \le 0 \\
+\left\lfloor\log_2{a}\right\rfloor+1, & a > 0
+\end{array}\right.
+\end{align*}
+
+\begin{verse}
+{\bf Examples:}
+\begin{itemize}
+\item $\ilog(-1)=0$
+\item $\ilog(0)=0$
+\item $\ilog(1)=1$
+\item $\ilog(2)=2$
+\item $\ilog(3)=2$
+\item $\ilog(4)=3$
+\item $\ilog(7)=3$
+\end{itemize}
+\end{verse}
+
+\item[$\min(a,b)$]
+The minimum of two numbers $a$ and $b$.
+
+\item[$\max(a,b)$]
+The maximum of two numbers $a$ and $b$.
+
+\end{description}
+\cleardoublepage
+
+
+\thispagestyle{plain}
+\markboth{{\sc Key words}}{{\sc Key words}}
+\chapter*{Key words}
+
+%We can't rewrite this, because this is text required by RFC 2119, so we use
+% some emergency stretching to get it typeset properly.
+\setlength{\emergencystretch}{2em}
+The key words ``MUST'', ``MUST NOT'', ``REQUIRED'', ``SHALL'', ``SHALL NOT'',
+ ``SHOULD'', ``SHOULD NOT'', ``RECOMMENDED'', ``MAY'', and ``OPTIONAL'' in this
+ document are to be intrepreted as described in RFC 2119 \cite{rfc2119}.\par
+\setlength{\emergencystretch}{0em}
+
+Where such assertions are placed on the contents of a Theora bitstream itself,
+ implementations should be prepared to encounter bitstreams that do not follow
+ these requirements.
+An application's behavior in the presecence of such non-conforming bitstreams
+ is not defined by this specification, but any reasonable method of handling 
+ them MAY be used.
+By way of example, applications MAY discard the current frame, retain the
+ current output thus far, or attempt to continue on by assuming some default
+ values for the erroneous bits.
+When such an error occurs in the bitstream headers, an application MAY refuse
+ to decode the entire stream.
+An application SHOULD NOT allow such non-conformant bitstreams to overflow
+ buffers and potentially execute arbitrary code, as this represents a serious
+ security risk.
+
+An application MUST, however, ensure any bits marked as reserved have the value
+ zero, and refuse to decode the stream if they do not.
+These are used as place holders for future bitstream features with which the
+ current bitstream is forward-compatible.
+Such features may not increment the bitstream version number, and can only be
+ recognized by checking the value of these reserved bits.
+
+\cleardoublepage
+
+
+
+\mainmatter
+
+\pagenumbering{arabic}
+\setcounter{page}{1}
+
+\chapter{Introduction}
+
+Theora is a general purpose, lossy video codec.
+It is based on the VP3 video codec produced by On2 Technologies
+ (\url{http://www.on2.com/}).
+On2 donated the VP3.1 source code to the Xiph.org Foundation and released it
+ under a BSD-like license.
+On2 also made an irrevocable, royalty-free license grant for any patent claims
+ it might have over the software and any derivatives.
+No formal specification exists for the VP3 format beyond this source code,
+ however Mike Melanson maintains a detailed description \cite{Mel04}.
+Portions of this specification were adopted from that text with permission.
+
+\section{VP3 and Theora}
+
+Theora contains a superset of the features that were available in the original
+ VP3 codec.
+Content encoded with VP3.1 can be losslessly transcoded into the Theora format.
+Theora content cannot, in general, be losslessly transcoded into the VP3
+ format.
+If a feature is not available in the original VP3 format, this is mentioned
+ when that feature is defined.
+A complete list of these features appears in Appendix~\ref{app:vp3-compat}.
+%TODO: VP3 - theora comparison in appendix
+
+\section{Video Formats}
+
+Theora currently supports progressive video data of arbitrary dimensions at a
+ constant frame rate in one of several $Y'C_bC_r$ color spaces.
+The precise definition the supported color spaces appears in
+ Section~\ref{sec:colorspaces}.
+Three different chroma subsampling formats are supported: 4:2:0, 4:2:2,
+ and 4:4:4.
+The precise details of each of these formats and their sampling locations are
+ described in Section~\ref{sec:pixfmts}.
+
+The Theora format does not support interlaced material, variable frame rates,
+ bit-depths larger than 8 bits per component, nor alternate color spaces such
+ as RGB or arbitrary multi-channel spaces.
+Black and white content can be efficiently encoded, however, because the
+ uniform chroma planes compress well.
+Support for interlaced material is planned for a future version.
+\begin{verse}
+{\bf Note:} Infrequently changing frame rates---as when film and video
+ sequences are cut together---can be supported in the Ogg container format by
+ chaining several Theora streams together.
+\end{verse}
+Support for increased bit depths or additional color spaces is not planned.
+
+\section{Classification}
+
+Theora is a block-based lossy transform codec that utilizes an
+ $8\times 8$ Type-II Discrete Cosine Transform and block-based motion
+ compensation.
+This places it in the same class of codecs as MPEG-1, -2, -4, and H.263.
+The details of how individual blocks are organized and how DCT coefficients are
+ stored in the bitstream differ substantially from these codecs, however.
+Theora supports only intra frames (I frames in MPEG) and inter frames (P frames
+ in MPEG).
+There is no equivalent to the bi-predictive frames (B frames) found in MPEG
+ codecs.
+
+\section{Assumptions}
+
+The Theora codec design assumes a complex, psychovisually-aware encoder and a
+ simple, low-complexity decoder.
+%TODO: Talk more about implementation complexity.
+
+Theora provides none of its own framing, synchronization, or protection against
+ transmission errors. 
+An encoder is solely a method of accepting input video frames and
+ compressing these frames into raw, unformatted `packets'.
+The decoder then accepts these raw packets in sequence, decodes them, and
+ synthesizes a fascimile of the original video frames.
+Theora is a free-form variable bit rate (VBR) codec, and packets have no
+ minimum size, maximum size, or fixed/expected size.
+
+Theora packets are thus intended to be used with a transport mechanism that
+ provides free-form framing, synchronization, positioning, and error correction
+ in accordance with these design assumptions, such as Ogg (for file transport)
+ or RTP (for network multicast).
+For the purposes of a few examples in this document, we will assume that Theora
+ is embedded in an Ogg stream specifically, although this is by no means a
+ requirement or fundamental assumption in the Theora design.
+
+The specification for embedding Theora into an Ogg transport stream is given in
+ Appendix~\ref{app:oggencapsulation}.
+
+\section{Codec Setup and Probability Model}
+
+Theora's heritage is the proprietary commerical codec VP3, and it retains a
+ fair amount of inflexibility when compared to Vorbis \cite{vorbis}, the first
+ Xiph.org codec, which began as a research codec.
+However, to provide additional scope for encoder improvement, Theora adopts
+ some of the configurable aspects of decoder setup that are present in Vorbis.
+This configuration data is not available in VP3, which uses hardcoded values
+ instead.
+
+Theora makes the same controversial design decision that Vorbis made to include
+ the entire probability model for the DCT coefficients and all the quantization
+ parameters in the bitstream headers.
+This is often several hundred fields.
+It is therefore impossible to decode any frame in the stream without
+ having previously fetched the codec info and codec setup headers.
+
+\begin{verse}
+{\bf Note:} Theora {\em can} initiate decode at an arbitrary intra-frame packet
+ within a bitstream so long as the codec has been initialized with the setup
+ headers.
+\end{verse}
+
+Thus, Theora headers are both required for decode to begin and relatively large
+ as bitstream headers go.
+The header size is unbounded, although as a rule-of-thumb less than 16kB is
+ recommended, and Xiph.org's reference encoder follows this suggestion.
+%TODO: Is 8kB enough? My setup header is 7.4kB, that doesn't leave much room
+% for comments.
+%RG: the lesson from vorbis is that as small as possible is really
+% important in some applications. Practically, what's acceptable
+% depends a great deal on the target bitrate. I'd leave 16 kB in the
+% spec for now. fwiw more than 1k of comments is quite unusual.
+
+Our own design work indicates that the primary liability of the required header
+ is in mindshare; it is an unusual design and thus causes some amount of
+ complaint among engineers as this runs against current design trends and
+ points out limitations in some existing software/interface designs.
+However, we find that it does not fundamentally limit Theora's suitable
+ application space.
+
+%silvia: renamed
+%\subsection{Format Specification}
+\section{Format Conformance}
+
+The Theora format is well-defined by its decode specification; any encoder that
+ produces packets that are correctly decoded by an implementation following
+ this specification may be considered a proper Theora encoder.
+A decoder must faithfully and completely implement the specification defined
+ herein %, except where noted,
+ to be considered a conformant Theora decoder.
+A decoder need not be implemented strictly as described, but the
+ actual decoder process MUST be {\em entirely mathematically equivalent}
+ to the described process.
+Where appropriate, a non-normative description of encoder processes is
+ included.
+These sections will be marked as such, and a proper Theora encoder is not
+ bound to follow them.
+
+%TODO: \subsection{Hardware Profile}
+
+
+\chapter{Coded Video Structure}
+
+Theora's encoding and decoding process is based on $8\times 8$ blocks of
+ pixels.
+This sections describes how a video frame is laid out, divided into
+ blocks, and how those blocks are organized.
+
+\section{Frame Layout}
+
+A video frame in Theora is a two-dimensional array of pixels.
+Theora, like VP3, uses a right-handed coordinate system, with the origin in the
+ lower-left corner of the frame.
+This is contrary to many video formats which use a left-handed coordinate
+ system with the origin in the upper-left corner of the frame.
+%INT: This means that for interlaced material, the definition of `even fields'
+%INT:  and `odd fields' may be reversed between Theora and other video codecs.
+%INT: This document will always refer to them as `top fields' and `bottom
+%INT:  fields'.
+
+Theora divides the pixel array up into three separate \term{color planes}, one
+ for each of the $Y'$, $C_b$, and $C_r$ components of the pixel.
+The $Y'$ plane is also called the \term{luma plane}, and the $C_b$ and $C_r$
+ planes are also called the \term{chroma planes}.
+Each plane is assigned a numerical value, as shown in
+ Table~\ref{tab:color-planes}.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{cl}\toprule
+Index & Color Plane \\\midrule
+$0$   & $Y'$        \\
+$1$   & $C_b$       \\
+$2$   & $C_r$       \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Color Plane Indices}
+\label{tab:color-planes}
+\end{table}
+
+In some pixel formats, the chroma planes are subsampled by a factor of two
+ in one or both directions.
+This means that the width or height of the chroma planes may be half that of
+ the total frame width and height.
+The luma plane is never subsampled.
+
+\section{Picture Region}
+
+An encoded video frame in Theora is required to have a width and height that
+ are multiples of sixteen, making an integral number of blocks even when the
+ chroma planes are subsampled.
+However, inside a frame a smaller \term{picture region} may be defined
+ to present material whose dimensions are not a multiple of sixteen pixels, as
+ shown in Figure~\ref{fig:pic-frame}.
+The picture region can be offset from the lower-left corner of the frame by up
+ to 255 pixels in each direction, and may have an arbitrary width and height,
+ provided that it is contained entirely within the coded frame.
+It is this picture region that contains the actual video data.
+The portions of the frame which lie outside the picture region may contain
+ arbitrary image data, so the frame must be cropped to the picture region
+ before display.
+The picture region plays no other role in the decode process, which operates on
+ the entire video frame.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{pic-frame}
+\end{center}
+\caption{Location of frame and picture regions}
+\label{fig:pic-frame}
+\end{figure}
+
+\section{Blocks and Super Blocks}
+\label{sec:blocks-and-sbs}
+
+Each color plane is subdivided into \term{blocks} of $8\times 8$ pixels.
+Blocks are grouped into $4\times 4$ arrays called \term{super blocks} as
+ shown in Figure~\ref{fig:superblock}.
+Each color plane has its own set of blocks and super blocks.
+If the chroma planes are subsampled, they are still divided into $8\times 8$
+ blocks of pixels; there are just fewer blocks than in the luma plane.
+The boundaries of blocks and super blocks in the luma plane do not necessarily
+ coincide with those of the chroma planes, if the chroma planes have been
+ subsampled.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{superblock}
+\end{center}
+\caption{Subdivision of a frame into blocks and super blocks}
+\label{fig:superblock}
+\end{figure}
+
+Blocks are accessed in two different orders in the various decoder processes.
+The first is \term{raster order}, illustrated in Figure~\ref{fig:raster-block}.
+This accesses each block in row-major order, starting in the lower left of the
+ frame and continuing along the bottom row of the entire frame, followed by the
+ next row up, starting on the left edge of the frame, etc.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{raster-block}
+\end{center}
+\caption{Raster ordering of $n\times m$ blocks}
+\label{fig:raster-block}
+\end{figure}
+
+The second is \term{coded order}.
+In coded order, blocks are accessed by super block.
+Within each frame, super blocks are traversed in raster order,
+ similar to raster order for blocks.
+Within each super block, however, blocks are accessed in a Hilbert curve
+ pattern, illustrated in Figure~\ref{fig:hilbert-block}.
+If a color plane does not contain a complete super block on the top or right
+ sides, the same ordering is still used, simply with any blocks outside the
+ frame boundary ommitted.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{hilbert-block}
+\end{center}
+\caption{Hilbert curve ordering of blocks within a super block}
+\label{fig:hilbert-block}
+\end{figure}
+
+To illustrate this ordering, consider a frame that is 240 pixels wide and
+ 48 pixels high.
+Each row of the luma plane has 30 blocks and 8 super blocks, and there are 6
+ rows of blocks and two rows of super blocks.
+
+%When accessed in raster order, each block in the luma plane is assigned the
+% following indices:
+
+%\vspace{\baselineskip}
+%\begin{center}
+%\begin{tabular}{|ccccccc|}\hline
+%150 & 151 & 152 & 153 & $\ldots$ & 178 & 179 \\
+%120 & 121 & 122 & 123 & $\ldots$ & 148 & 149 \\\hline
+% 90 &  91 &  92 &  93 & $\ldots$ & 118 & 119 \\
+% 60 &  61 &  62 &  63 & $\ldots$ &  88 &  89 \\
+% 30 &  31 &  32 &  33 & $\ldots$ &  58 &  59 \\
+%  0 &   1 &   2 &   3 & $\ldots$ &  28 &  29 \\\hline
+%\end{tabular}
+%\end{center}
+%\vspace{\baselineskip}
+
+When accessed in coded order, each block in the luma plane is assigned the
+ following indices:
+
+\vspace{\baselineskip}
+\begin{center}
+\begin{tabular}{|cccc|c|cc|}\hline
+123 & 122 & 125 & 124 & $\ldots$ & 179 & 178 \\
+120 & 121 & 126 & 127 & $\ldots$ & 176 & 177 \\\hline
+  5 &   6 &   9 &  10 & $\ldots$ & 117 & 118 \\
+  4 &   7 &   8 &  11 & $\ldots$ & 116 & 119 \\
+  3 &   2 &  13 &  12 & $\ldots$ & 115 & 114 \\
+  0 &   1 &  14 &  15 & $\ldots$ & 112 & 113 \\\hline
+\end{tabular}
+\end{center}
+\vspace{\baselineskip}
+
+Here the index values specify the order in which the blocks would be accessed.
+The indices of the blocks are numbered continuously from one color plane to the
+ next.
+They do not reset to zero at the start of each plane.
+Instead, the numbering increases continuously from the $Y'$ plane to the $C_b$
+ plane to the $C_r$ plane.
+The implication is that the blocks from all planes are treated as a unit during
+ the various processing steps.
+
+Although blocks are sometimes accessed in raster order, in this document the
+ index associated with a block is {\em always} its index in coded order.
+
+\section{Macro Blocks}
+\label{sec:mbs}
+
+A macro block contains a $2\times 2$ array of blocks in the luma plane
+ {\em and} the co-located blocks in the chroma planes, as shown in
+ Figure~\ref{fig:macroblock}.
+Thus macro blocks can represent anywhere from six to twelve blocks, depending
+ on how the chroma planes are subsampled.
+This is in contrast to super blocks, which only contain blocks from a single
+ color plane.
+% the whole super vs. macro blocks thing is a little confusing, and it can be
+% hard to remember which is what initially. A figure would/will help here,
+% but I tried to add some text emphasizing the difference in terms of
+% functionality.
+%TBT: At this point we haven't described any functionality yet.
+%TBT: As far as the reader knows, the only purpose of the blocks, macro blocks
+%TBT:  and super blocks is for data organization---and for blocks and super
+%TBT:  blocks, this is essentially true.
+%TBT: So lets restrict the differences we emphasize to those of data
+%TBT:  organization, which the sentence I just added above does.
+Macro blocks contain information about coding mode and motion vectors for the
+ corresponding blocks in all color planes.
+
+\begin{figure}[htbp]
+ \begin{center}
+ \includegraphics{macroblock}
+ \end{center}
+ \caption{Subdivision of a frame into macro blocks}
+ \label{fig:macroblock}
+\end{figure}
+
+Macro blocks are also accessed in a \term{coded order}.
+This coded order proceeds by examining each super block in the luma plane in
+ raster order, and traversing the four macro blocks inside using a smaller
+ Hilbert curve, as shown in Figure~\ref{fig:hilbert-mb}.
+%r: I rearranged the wording to make a more formal idiom here
+If the luma plane does not contain a complete super block on the top or right
+ sides, the same ordering is still used, with any macro blocks outside
+ the frame boundary simply omitted.
+Because the frame size is constrained to be a multiple of 16, there are never
+ any partial macro blocks.
+Unlike blocks, macro blocks need never be accessed in a pure raster order.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{hilbert-mb}
+\end{center}
+\caption{Hilbert curve ordering of macro blocks within a super block}
+\label{fig:hilbert-mb}
+\end{figure}
+
+Using the same frame size as the example above, there are 15 macro blocks in
+ each row and 3 rows of macro blocks.
+The macro blocks are assigned the following indices:
+
+\vspace{\baselineskip}
+\begin{center}
+\begin{tabular}{|cc|cc|c|cc|c|}\hline
+30 & 31 & 32 & 33 & $\cdots$ & 42 & 43 & 44 \\\hline
+ 1 &  2 &  5 &  6 & $\cdots$ & 25 & 26 & 29 \\
+ 0 &  3 &  4 &  7 & $\cdots$ & 24 & 27 & 28 \\\hline
+\end{tabular}
+\end{center}
+\vspace{\baselineskip}
+
+\section{Coding Modes and Prediction}
+
+Each block is coded using one of a small, fixed set of \term{coding modes} that
+ define how the block is predicted from previous frames.
+A block is predicted using one of two \term{reference frames}, selected
+ according to the coding mode.
+A reference frame is the fully decoded version of a previous frame in the
+ stream.
+The first available reference frame is the previous intra frame, called the
+ \term{golden frame}.
+The second available reference frame is the previous frame, whether it was an
+ intra frame or an inter frame.
+If the previous frame was an intra frame, then both reference frames are the
+ same.
+See Figure~\ref{fig:reference-frames} for an illustration of the reference
+ frames used for an intra frame that does not follow an intra frame.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{reference-frames}
+\end{center}
+\caption{Example of reference frames for an inter frame}
+\label{fig:reference-frames}
+\end{figure}
+
+Two coding modes in particular are worth mentioning here.
+The INTRA mode is used for blocks that are not predicted from either reference
+ frame.
+This is the only coding mode allowed in intra frames.
+The INTER\_NOMV coding mode uses the co-located contents of the block in the
+ previous frame as the predictor.
+This is the default coding mode.
+
+\section{DCT Coefficients}
+\label{sec:dct-coeffs}
+
+A \term{residual} is added to the predicted contents of a block to form the
+ final reconstruction.
+The residual is stored as a set of quantized coefficients from an integer
+ approximation of a two-dimensional Type II Discrete Cosine Transform.
+The DCT takes an $8\times 8$ array of pixel values as input and returns an
+ $8\times 8$ array of coefficient values.
+The \term{natural ordering} of these coefficients is defined to be row-major
+ order, from lowest to highest frequency.
+They are also often indexed in \term{zig-zag order}, as shown in
+ Figure~\ref{tab:zig-zag}.
+
+\begin{figure}[htbp]
+\begin{center}
+\begin{tabular}[c]{rr|c@{}c@{}c@{}c@{}c@{}c@{}c@{}c@{}c@{}c@{}c@{}c@{}c@{}c@{}c}
+ &\multicolumn{1}{r}{} & && &&&&&$c$&&& && &&  \\
+ &\multicolumn{1}{r}{} &0&&1&&2&&3&&4&&5&&6&&7 \\\cline{3-17}
+ &0 &  0 &$\rightarrow$&  1 &&  5 &$\rightarrow$&  6 && 14 &$\rightarrow$& 15 && 27 &$\rightarrow$& 28            \\[-0.5\defaultaddspace]
+ &  &    &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&                  \\
+ &1 &  2 &             &  4 &&  7 &             & 13 && 16 &             & 26 && 29 &             & 42            \\[-0.5\defaultaddspace]
+ &  &$\downarrow$&$\nearrow$&&$\swarrow$&&$\nearrow$&&$\swarrow$&&$\nearrow$&&$\swarrow$&&$\nearrow$&$\downarrow$ \\
+ &2 &  3 &             &  8 && 12 &             & 17 && 25 &             & 30 && 41 &             & 43            \\[-0.5\defaultaddspace]
+ &  &    &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&                  \\
+ &3 &  9 &             & 11 && 18 &             & 24 && 31 &             & 40 && 44 &             & 53            \\[-0.5\defaultaddspace]
+$r$&&$\downarrow$&$\nearrow$&&$\swarrow$&&$\nearrow$&&$\swarrow$&&$\nearrow$&&$\swarrow$&&$\nearrow$&$\downarrow$ \\
+ &4 & 10 &             & 19 && 23 &             & 32 && 39 &             & 45 && 52 &             & 54            \\[-0.5\defaultaddspace]
+ &  &    &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&                  \\
+ &5 & 20 &             & 22 && 33 &             & 38 && 46 &             & 51 && 55 &             & 60            \\[-0.5\defaultaddspace]
+ &  &$\downarrow$&$\nearrow$&&$\swarrow$&&$\nearrow$&&$\swarrow$&&$\nearrow$&&$\swarrow$&&$\nearrow$&$\downarrow$ \\
+ &6 & 21 &             & 34 && 37 &             & 47 && 50 &             & 56 && 59 &             & 61            \\[-0.5\defaultaddspace]
+ &  &    &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&&$\nearrow$& &$\swarrow$&                  \\
+ &7 & 35 &$\rightarrow$& 36 && 48 &$\rightarrow$& 49 && 57 &$\rightarrow$& 58 && 62 &$\rightarrow$& 63
+\end{tabular}
+\end{center}
+\caption{Zig-zag order}
+\label{tab:zig-zag}
+\end{figure}
+
+\begin{verse}
+{\bf Note:} the row and column indices refer to {\em frequency number} and not
+ pixel locations.
+The frequency numbers are defined independently of the memory organization of
+ the pixels.
+They have been written from top to bottom here to follow conventional notation,
+ despite the right-handed coordinate system Theora uses for pixel locations.
+%RG: I'd rather we were internally consistent and put dc at the lower left.
+Many implementations of the DCT operate `in-place'.
+That is, they return DCT coefficients in the same memory buffer that the
+ initial pixel values were stored in.
+Due to the right-handed coordinate system used for pixel locations in Theora,
+ one must note carefully how both pixel values and DCT coefficients are
+ organized in memory in such a system.
+\end{verse}
+
+DCT coefficient $(0,0)$ is called the \term{DC coefficient}.
+All the other coefficients are called \term{AC coefficients}.
+
+
+\chapter{Decoding Overview}
+
+This section provides a high level description of the Theora codec's
+ construction.
+A bit-by-bit specification appears beginning in Section~\ref{sec:bitpacking}.
+The later sections assume a high-level understanding of the Theora decode
+ process, which is provided below.
+
+\section{Decoder Configuration}
+
+Decoder setup consists of configuration of the quantization matrices and the
+ Huffman codebooks for the DCT coefficients, and a table of limit values for
+ the deblocking filter.
+The remainder of the decoding pipeline is not configurable.
+
+\subsection{Global Configuration}
+
+The global codec configuration consists of a few video related fields, such as
+ frame rate, frame size, picture size and offset, aspect ratio, color space,
+ pixel format, and a version number.
+The version number is divided into a major version, a minor version, amd a
+ minor revision number.
+%r: afaik the released vp3 codec called itself 3.1 and is compatible w/ theora
+%r: even though we received the in-progress 3.2 codebase
+For the format defined in this specification, these are `3', `2', and
+ `1', respectively, in reference to Theora's origin as a successor to 
+ the VP3.1 format.
+
+\subsection{Quantization Matrices}
+
+Theora allows up to 384 different quantization matrices to be defined, one for
+ each \term{quantization type}, \term{color plane} ($Y'$, $C_b$, or $C_r$), and
+ \term{quantization index}, \qi, which ranges from zero to 63, inclusive.
+There are currently two quantization types defined, which depend on the coding
+ mode of the block being dequantized, as shown in Table~\ref{tab:quant-types}.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{cl}\toprule
+Quantization Type & Usage                     \\\midrule
+$0$               & INTRA-mode blocks         \\
+$1$               & Blocks in any other mode. \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Quantization Type Indices}
+\label{tab:quant-types}
+\end{table}
+
+%r: I think 'nominally' is more specific than 'generally' here
+The quantization index, on the other hand, nominally represents a progressive
+ range of quality levels, from low quality near zero to high quality near 63.
+However, the interpretation is arbitrary, and it is possible, for example, to
+ partition the scale into two completely separate ranges with 32 levels each
+ that are meant to represent different classes of source material, or any
+ other arrangement that suits the encoder's requirements.
+
+Each quantization matrix is an $8\times 8$ matrix of 16-bit values, which is
+ used to quantize the output of the $8\times 8$ DCT\@.
+Quantization matrices are specified using three components: a
+ \term{base matrix} and two \term{scale values}.
+The first scale value is the \term{DC scale}, which is applied to the DC
+ component of the base matrix.
+The second scale value is the \term{AC scale}, which is applied to all the
+ other components of the base matrix.
+There are 64 DC scale values and 64 AC scale values, one for each \qi\ value.
+
+There are 64 elements in each base matrix, one for each DCT coefficient.
+They are stored in natural order (cf. Section~\ref{sec:dct-coeffs}).
+There is a separate set of base matrices for each quantization type and each
+ color plane, with up to 64 possible base matrices in each set, one for each
+ \qi\ value.
+%r: we will mention that the given matricies must bound the \qi range
+%r: in the detailed section. it's not important at this level.
+Typically the bitstream contains matrices for only a sparse subset of the
+ possible \qi\ values.
+The base matrices for the remainder of the \qi\ values are computed using
+ linear interpolation.
+This configuration allows the encoder to adjust the quantization matrices to
+ approximate the complex, non-linear response of the human visual system to
+ different quantization errors.
+
+Finally, because the in-loop deblocking filter strength depends on the strength
+ of the quantization matrices defined in this header, a table of 64 \term{loop
+ filter limit values} is defined, one for each \qi\ value.
+
+The precise specification of how all of this information is decoded appears in
+ Section~\ref{sub:loop-filter-limits} and Section~\ref{sub:quant-params}.
+
+\subsection{Huffman Codebooks}
+
+Theora uses 80 configurable binary Huffman codes to represent the 32 tokens
+ used to encode DCT coefficients.
+Each of the 32 token values has a different semantic meaning and is used to
+ represent single coefficient values, zero runs, combinations of the two, and
+ \term{End-Of-Block markers}.
+
+The 80 codes are divided up into five groups of 16, with each group
+ corresponding to a set of DCT coefficient indices.
+The first group corresponds to the DC coefficient, while the remaining four
+ groups correspond to different subsets of the AC coefficients.
+Within each frame, two pairs of 4-bit codebook indices are stored.
+The first pair selects which codebooks to use from the DC coefficient group for
+ the $Y'$ coefficients and the $C_b$ and $C_r$ coefficients.
+The second pair selects which codebooks to use from {\em all four} of the AC
+ coefficient groups for the $Y'$ coefficients and the $C_b$ and $C_r$
+ coefficients.
+
+The precise specification of how the codebooks are decoded appears in
+ Section~\ref{sub:huffman-tables}.
+
+\section{High-Level Decode Process}
+
+\subsection{Decoder Setup}
+
+Before decoding can begin, a decoder MUST be initialized using the bitstream
+ headers corresponding to the stream to be decoded.
+Theora uses three header packets; all are required, in order, by this
+ specification.
+Once set up, decode may begin at any intra-frame packet---or even inter-frame
+ packets, provided the appropriate decoded reference frames have already been
+ decoded and cached---belonging to the Theora stream.
+In Theora I, all packets after the three initial headers are intra-frame or
+ inter-frame packets.
+
+The header packets are, in order, the identification header, the comment
+ header, and the setup header.
+
+\paragraph{Identification Header}
+
+The identification header identifies the stream as Theora, provides a version
+ number, and defines the characteristics of the video stream such as frame
+ size.
+A complete description of the identification header appears in
+ Section~\ref{sec:idheader}.
+
+\paragraph{Comment Header}
+
+The comment header includes user text comments (`tags') and a vendor string
+ for the application/library that produced the stream.
+The format of the comment header is the same as that used in the Vorbis I and
+ Speex codecs, with slight modifications due to the use of a different bit
+ packing mechanism.
+A complete description of how the comment header is coded appears in
+ Section~\ref{sec:commentheader}, along with a suggested set of tags.
+
+\paragraph{Setup Header}
+
+The setup header includes extensive codec setup information, including the
+ complete set of quantization matrices and Huffman codebooks needed to decode
+ the DCT coefficients.
+A complete description of the setup header appears in
+ Section~\ref{sec:setupheader}.
+
+\subsection{Decode Procedure}
+
+The decoding and synthesis procedure for all video packets is fundamentally the
+ same, with some steps omitted for intra frames.
+\begin{itemize}
+\item
+Decode packet type flag.
+\item
+Decode frame header.
+\item
+Decode coded block information (inter frames only).
+\item
+Decode macro block mode information (inter frames only).
+\item
+Decode motion vectors (inter frames only).
+\item
+Decode block-level \qi\ information.
+\item
+Decode DC coefficient for each coded block.
+\item
+Decode 1st AC coefficient for each coded block.
+\item
+Decode 2nd AC coefficient for each coded block.
+\item
+$\ldots$
+\item
+Decode 63rd AC coefficient for each coded block.
+\item Perform DC coefficient prediction.
+\item Reconstruct coded blocks.
+\item Copy uncoded bocks.
+\item Perform loop filtering.
+\end{itemize}
+
+\begin{verse}
+{\bf Note:} clever rearrangement of the steps in this process is possible.
+As an example, in a memory-constrained environment, one can make multiple
+ passes through the DCT coefficients to avoid buffering them all in memory.
+On the first pass, the starting location of each coefficient is identified, and
+ then 64 separate get pointers are used to read in the 64 DCT coefficients
+ required to reconstruct each coded block in sequence.
+This operation produces entirely equivalent output and is naturally perfectly
+ legal.
+It may even be a benefit in non-memory-constrained environments due to a
+ reduced cache footprint.
+\end{verse}
+
+Theora makes equivalence easy to check by defining all decoding operations in
+ terms of exact integer operations.
+No floating-point math is required, and in particular, the implementation of
+ the iDCT transform MUST be followed precisely.
+This prevents the decoder mismatch problem commonly associated with codecs that
+ provide a less rigorous transform specification.
+Such a mismatch problem would be devastating to Theora, since a single rounding
+ error in one frame could propagate throughout the entire succeeding frame due
+ to DC prediction.
+
+\paragraph{Packet Type Decode}
+
+Theora uses four packet types.
+The first three packet types mark each of the three Theora headers described
+ above.
+The fourth packet type marks a video packet.
+All other packet types are reserved; packets marked with a reserved type should
+ be ignored.
+
+Additionally, zero-length packets are treated as if they were an inter 
+frame with no blocks coded. That is, as a duplicate frame.
+
+\paragraph{Frame Header Decode}
+
+The frame header contains some global information about the current frame.
+The first is the frame type field, which specifies if this is an intra frame or
+ an inter frame.
+Inter frames predict their contents from previously decoded reference frames.
+Intra frames can be independently decoded with no established reference frames.
+
+The next piece of information in the frame header is the list of \qi\ values
+ allowed in the frame.
+Theora allows from one to three different \qi\ values to be used in a single
+ frame, each of which selects a set of six quantization matrices, one for each
+ quantization type (inter or intra), and one for each color plane.
+The first \qi\ value is {\em always} used when dequantizing DC coefficients.
+The \qi\ value used when dequantizing AC coefficients, however, can vary from
+ block to block.
+VP3, in contrast, only allows a single \qi\ value per frame for both the DC and
+ AC coefficients.
+
+\paragraph{Coded Block Information}
+
+This stage determines which blocks in the frame are coded and which are
+ uncoded.
+A \term{coded block list} is constructed which lists all the coded blocks in
+ coded order.
+For intra frames, every block is coded, and so no data needs to be read from
+ the packet.
+
+\paragraph{Macro Block Mode Information}
+
+For intra frames, every block is coded in INTRA mode, and this stage is
+ skipped.
+In inter frames a \term{coded macro block list} is constructed from the coded
+ block list.
+Any macro block which has at least one of its luma blocks coded is considered
+ coded; all other macro blocks are uncoded, even if they contain coded chroma
+ blocks.
+A coding mode is decoded for each coded macro block, and assigned to all its
+ constituent coded blocks.
+All coded chroma blocks in uncoded macro blocks are assigned the INTER\_NOMV
+ coding mode.
+
+\paragraph{Motion Vectors}
+
+Intra frames are coded entirely in INTRA mode, and so this stage is skipped.
+Some inter coding modes, however, require one or more motion vectors to be
+ specified for each macro block.
+These are decoded in this stage, and an appropriate motion vector is assigned
+ to each coded block in the macro block.
+
+\paragraph{Block-Level \qi\ Information}
+
+If a frame allows multiple \qi\ values, the \qi\ value assigned to each block
+ is decoded here.
+Frames that use only a single \qi\ value have nothing to decode.
+
+\paragraph{DCT Coefficients}
+
+Finally, the quantized DCT coefficients are decoded.
+A list of DCT coefficients in zig-zag order for a single block is represented
+ by a list of tokens.
+A token can take on one of 32 different values, each with a different semantic
+ meaning.
+A single token can represent a single DCT coefficient, a run of zero
+ coefficients within a single block, a combination of a run of zero
+ coefficients followed by a single non-zero coefficient, an
+ \term{End-Of-Block marker}, or a run of EOB markers.
+EOB markers signify that the remainder of the block is one long zero run.
+Unlike JPEG and MPEG, there is no requirement for each block to end with 
+ a special marker.
+If non-EOB tokens yield values for all 64 of the coefficients in a block, then
+ no EOB marker occurs.
+
+Each token is associated with a specific \term{token index} in a block.
+For single-coefficient tokens, this index is the zig-zag index of the token in
+ the block.
+For zero-run tokens, this index is the zig-zag index of the {\em first}
+ coefficient in the run.
+For combination tokens, the index is again the zig-zag index of the first
+ coefficient in the zero run.
+For EOB markers, which signify that the remainder of the block is one long zero
+ run, the index is the zig-zag index of the first zero coefficient in that run.
+For EOB runs, the token index is that of the first EOB marker in the run.
+Due to zero runs and EOB markers, a block does not have to have a token for
+ every zig-zag index.
+
+Tokens are grouped in the stream by token index, not by the block they
+ originate from.
+This means that for each zig-zag index in turn, the tokens with that index from
+ {\em all} the coded blocks are coded in coded block order.
+When decoding, a current token index is maintained for each coded block.
+This index is advanced by the number of coefficients that are added to the
+ block as each token is decoded.
+After fully decoding all the tokens with token index \ti, the current token
+ index of every coded block will be \ti\ or greater.
+
+If an EOB run of $n$ blocks is decoded at token index \ti, then it ends the
+ next $n$ blocks in coded block order whose current token index is equal to
+ \ti, but not greater.
+If there are fewer than $n$ blocks with a current token index of \ti, then the
+ decoder goes through the coded block list again from the start, ending blocks
+ with a current token index of $\ti+1$, and so on, until $n$ blocks have been
+ ended.
+
+Tokens are read by parsing a Huffman code that depends on \ti\ and the color
+ plane of the next coded block whose current token index is equal to \ti, but
+ not greater.
+The Huffman codebooks are selected on a per-frame basis from the 80 codebooks
+ defined in the setup header.
+Many tokens have a fixed number of \term{extra bits} associated with them.
+These bits are read from the packet immediately after the token is decoded.
+These are used to define things such as coefficient magnitude, sign, and the
+ length of runs.
+
+\paragraph{DC Prediction}
+
+After the coefficients for each block are decoded, the quantized DC value of
+ each block is adjusted based on the DC values of its neighbors.
+This adjustment is performed by scanning the blocks in raster order, not coded
+ block order.
+
+\paragraph{Reconstruction}
+
+Finally, using the coding mode, motion vector (if applicable), quantized
+ coefficient list, and \qi\ value defined for each block, all the coded blocks
+ are reconstructed.
+The DCT coefficients are dequantized, an inverse DCT transform is applied, and
+ the predictor is formed from the coding mode and motion vector and added to
+ the result.
+
+\paragraph{Loop Filtering}
+
+To complete the reconstructed frame, an ``in-loop'' deblocking filter is
+ applied to the edges of all coded blocks.
+
+
+\chapter{Video Formats}
+
+This section gives a precise description of the video formats that Theora is
+ capable of storing.
+The Theora bitstream is capable of handling video at any arbitrary resolution
+ up to $1048560\times 1048560$.
+Such video would require almost three terabytes of storage per frame for
+ uncompressed data, so compliant decoders MAY refuse to decode images with
+ sizes beyond their capabilities.
+%TODO: What MUST a "compliant" decoder accept?
+%TODO: What SHOULD a decoder use for an upper bound? (derive from total amount
+%TODO:  of memory and memory bandwidth)
+%TODO: Any lower limits?
+%TODO: We really need hardware device profiles, but such things should be
+%TODO:  developed with input from the hardware community.
+%TODO: And even then sometimes they're useless
+
+The remainder of this section talks about two specific aspects of the video
+ format: the color space and the pixel format.
+The first describes how color is represented and how to transform that color
+ representation into a device independent color space such as CIE $XYZ$ (1931).
+The second describes the various schemes for sampling the color values in time
+ and space.
+
+\section{Color Space Conventions}
+
+There are a large number of different color standards used in digital video.
+Since Theora is a lossy codec, it restricts itself to only a few of them to
+ simplify playback.
+Unlike the alternate method of describing all the parameters of the color
+ model, this allows a few dedicated routines for color conversion to be written
+ and heavily optimized in a decoder.
+More flexible conversion functions should instead be specified in an encoder,
+ where additional computational complexity is more easily tolerated.
+The color spaces were selected to give a fair representation of color standards
+ in use around the world today.
+Most of the standards that do not exactly match one of these can be converted
+ to one fairly easily.
+
+All Theora color spaces are $Y'C_bC_r$ color spaces with one luma channel and
+ two chroma channels.
+Each channel contains 8-bit discrete values in the range $0\ldots255$, which
+ represent non-linear gamma pre-corrected signals.
+The Theora identification header contains an 8-bit value that describes the
+ color space.
+This merely selects one of the color spaces available from an enumerated list.
+Currently, only two color spaces are defined, with a third possibility that
+ indicates the color space is ``unknown".
+
+\section{Color Space Conversions and Parameters}
+\label{sec:color-xforms}
+
+The parameters which describe the conversions between each color space are
+ listed below.
+These are the parameters needed to map colors from the encoded $Y'C_bC_r$
+ representation to the device-independent color space CIE $XYZ$ (1931).
+These parameters define abstract mathematical conversion functions which are
+ infinitely precise.
+The accuracy and precision with which the conversions are performed in a real
+ system is determined by the quality of output desired and the available
+ processing power.
+Exact decoder output is defined by this specification only in the original
+ $Y'C_bC_r$ space.
+
+\begin{description}
+\item[$Y'C_bC_r$ to $Y'P_bP_r$:]
+\vspace{\baselineskip}\hfill
+
+This conversion takes 8-bit discrete values in the range $[0\ldots255]$ and
+ maps them to real values in the range $[0\ldots1]$ for Y and
+ $[-\frac{1}{2}\ldots\frac{1}{2}]$ for $P_b$ and $P_r$.
+Because some values may fall outside the offset and excursion defined for each
+ channel in the $Y'C_bC_r$ space, the results may fall outside these ranges in
+ $Y'P_bP_r$ space.
+No clamping should be done at this stage.
+
+\begin{align}
+Y'_\mathrm{out} & =
+ \frac{Y'_\mathrm{in}-\mathrm{Offset}_Y}{\mathrm{Excursion}_Y} \\
+P_b             & =
+ \frac{C_b-\mathrm{Offset}_{C_b}}{\mathrm{Excursion}_{C_b}} \\
+P_r             & =
+ \frac{C_r-\mathrm{Offset}_{C_r}}{\mathrm{Excursion}_{C_r}}
+\end{align}
+
+Parameters: $\mathrm{Offset}_{Y,C_b,C_r}$, $\mathrm{Excursion}_{Y,C_b,C_r}$.
+
+\item[$Y'P_bP_r$ to $R'G'B'$:]
+\vspace{\baselineskip}\hfill
+
+This conversion takes the one luma and two chroma channel representation and
+ maps it to the non-linear $R'G'B'$ space used to drive actual output devices.
+Values should be clamped into the range $[0\ldots1]$ after this stage.
+
+\begin{align}
+R' & = Y'+2(1-K_r)P_r \\
+G' & = Y'-2\frac{(1-K_b)K_b}{1-K_b-K_r}P_b-2\frac{(1-K_r)K_r}{1-K_b-K_r}P_r\\
+B' & = Y'+2(1-K_b)P_b
+\end{align}
+
+Parameters: $K_b,K_r$.
+
+\item[$R'G'B'$ to $RGB$ (Output device gamma correction):]
+\vspace{\baselineskip}\hfill
+
+This conversion takes the non-linear $R'G'B'$ voltage levels and maps them to
+ linear light levels produced by the actual output device.
+Note that this conversion is only that of the output device, and its inverse is
+ {\em not} that used by the input device.
+Because a dim viewing environment is assumed in most television standards, the
+ overall gamma between the input and output devices is usually around $1.1$ to
+ $1.2$, and not a strict $1.0$.
+
+For calibration with actual output devices, the model
+\begin{align}
+L & =(E'+\Delta)^\gamma
+\end{align}
+ should be used, with $\Delta$ the free parameter and $\gamma$ held fixed to
+ the value specified in this document.
+The conversion function presented here is an idealized version with $\Delta=0$.
+
+\begin{align}
+R & = R'^\gamma \\
+G & = G'^\gamma \\
+B & = B'^\gamma
+\end{align}
+
+Parameters: $\gamma$.
+
+\item[$RGB$ to $R'G'B'$ (Input device gamma correction):]
+\vspace{\baselineskip}\hfill
+
+%TODO: Tag section as non-normative
+
+This conversion takes linear light levels and maps them to the non-linear
+ voltage levels produced in the actual input device.
+This information is merely informative.
+It is not required for building a decoder or for converting between the various
+ formats and the actual output capabilities of a particular device.
+
+A linear segment is introduced on the low end to reduce noise in dark areas of
+ the image.
+The rest of the scale is adjusted so that the power segment of the curve
+ intersects the linear segment with the proper slope, and so that it still maps
+ 0 to 0 and 1 to 1.
+
+\begin{align}
+R' & = \left\{
+\begin{array}{ll}
+\alpha R,                     & 0\le R<\delta   \\
+(1+\epsilon)R^\beta-\epsilon, & \delta\le R\le1
+\end{array}\right. \\
+G' & = \left\{
+\begin{array}{ll}
+\alpha G,                     & 0\le G<\delta   \\
+(1+\epsilon)G^\beta-\epsilon, & \delta\le G\le1
+\end{array}\right. \\
+B' & = \left\{
+\begin{array}{ll}
+\alpha B,                     & 0\le B<\delta   \\
+(1+\epsilon)B^\beta-\epsilon, & \delta\le B\le1
+\end{array}\right.
+\end{align}
+
+Parameters: $\beta$, $\alpha$, $\delta$, $\epsilon$.
+
+\item[$RGB$ to CIE $XYZ$ (1931):]
+\vspace{\baselineskip}\hfill
+
+This conversion maps a device-dependent linear RGB space to the
+ device-independent linear CIE $XYZ$ space.
+The parameters are the CIE chromaticity coordinates of the three
+ primaries---red, green, and blue---as well as the chromaticity coordinates
+ of the white point of the device.
+This is how hardware manufacturers and standards typically describe a
+ particular $RGB$ space.
+The math required to convert these parameters into a useful transformation
+ matrix is reproduced below.
+
+\begin{align}
+F                  & =
+\left[\begin{array}{ccc}
+\frac{x_r}{y_r}       & \frac{x_g}{y_g}       & \frac{x_b}{y_b}       \\
+1                     & 1                     & 1                     \\
+\frac{1-x_r-y_r}{y_r} & \frac{1-x_g-y_g}{y_g} & \frac{1-x_b-y_b}{y_b}
+\end{array}\right] \\
+\left[\begin{array}{c}
+s_r \\
+s_g \\
+s_b
+\end{array}\right] & =
+F^{-1}\left[\begin{array}{c}
+\frac{x_w}{y_w} \\
+1 \\
+\frac{1-x_w-y_w}{y_w}
+\end{array}\right] \\
+\left[\begin{array}{c}
+X \\
+Y \\
+Z
+\end{array}\right] & =
+F\left[\begin{array}{c}
+s_rR \\
+s_gG \\
+s_bB
+\end{array}\right]
+\end{align}
+Parameters: $x_r,x_g,x_b,x_w, y_r,y_g,y_b,y_w$.
+
+\end{description}
+
+\section{Available Color Spaces}
+\label{sec:colorspaces}
+
+These are the color spaces currently defined for use by Theora video.
+Each one has a short name, with which it is referred to in this document, and
+ a more detailed specification of the standards from which its parameters are
+ derived.
+Some standards do not specify all the parameters necessary.
+For these unspecified parameters, this document serves as the definition of
+ what should be used when encoding or decoding Theora video.
+
+\subsection{Rec.~470M (Rec.~ITU-R~BT.470-6 System M/NTSC with
+ Rec.~ITU-R~BT.601-5)}
+\label{sec:470m}
+
+This color space is used by broadcast television and DVDs in much of the
+ Americas, Japan, Korea, and the Union of Myanmar \cite{rec470}.
+This color space may also be used for System M/PAL (Brazil), with an
+ appropriate conversion supplied by the encoder to compensate for the
+ different gamma value.
+See Section~\ref{sec:470bg} for an appropriate gamma value to assume for M/PAL
+ input.
+
+In the US, studio monitors are adjusted to a D65 white point
+ ($x_w,y_w=0.313,0.329$).
+In Japan, studio monitors are adjusted to a D white of 9300K
+ ($x_w,y_w=0.285,0.293$).
+
+Rec.~470 does not specify a digital encoding of the color signals.
+For Theora, Rec.~ITU-R~BT.601-5 \cite{rec601} is used, starting from the
+ $R'G'B'$ signals specified by Rec.~470.
+
+Rec.~470 does not specify an input gamma function.
+For Theora, the Rec.~709 \cite{rec709} input function is assumed.
+This is the same as that specified by SMPTE 170M \cite{smpte170m}, which claims
+ to reflect modern practice in the creation of NTSC signals circa 1994.
+
+The parameters for all the color transformations defined in
+ Section~\ref{sec:color-xforms} are given in Table~\ref{tab:470m}.
+
+\begin{table}[htb]
+\begin{align*}
+\mathrm{Offset}_{Y,C_b,C_r}    & = (16, 128, 128)  \\
+\mathrm{Excursion}_{Y,C_b,C_r} & = (219, 224, 224) \\
+K_r                            & = 0.299           \\
+K_b                            & = 0.114           \\
+\gamma                         & = 2.2             \\
+\beta                          & = 0.45            \\
+\alpha                         & = 4.5             \\
+\delta                         & = 0.018           \\
+\epsilon                       & = 0.099           \\
+x_r,y_r                        & = 0.67, 0.33      \\
+x_g,y_g                        & = 0.21, 0.71      \\
+x_b,y_b                        & = 0.14, 0.08      \\
+\text{(Illuminant C) } x_w,y_w & = 0.310, 0.316    \\
+\end{align*}
+\caption{Rec.~470M Parameters}
+\label{tab:470m}
+\end{table}
+
+\subsection{Rec.~470BG (Rec.~ITU-R~BT.470-6 Systems B and G with
+ Rec.~ITU-R~BT.601-5)}
+\label{sec:470bg}
+
+This color space is used by the PAL and SECAM systems in much of the rest of
+ the world \cite{rec470}
+This can be used directly by systems (B, B1, D, D1, G, H, I, K, N)/PAL and (B,
+ D, G, H, K, K1, L)/SECAM\@.
+
+\begin{verse}
+{\bf Note:} the Rec.~470BG chromaticity values are different from those
+ specified in Rec.~470M\@.
+When PAL and SECAM systems were first designed, they were based upon the same
+ primaries as NTSC\@.
+However, as methods of making color picture tubes have changed, the primaries
+ used have changed as well.
+The U.S. recommends using correction circuitry to approximate the existing,
+ standard NTSC primaries.
+Current PAL and SECAM systems have standardized on primaries in accord with
+ more recent technology.
+\end{verse}
+
+Rec.~470 provisionally permits the use of the NTSC chromaticity values (given
+ in Section~\ref{sec:470m}) with legacy PAL and SECAM equipment.
+In Theora, material must be decoded assuming the new PAL and SECAM primaries.
+Material intended for display on old legacy devices should be converted by the
+ decoder.
+
+The official Rec.~470BG specifies a gamma value of $\gamma=2.8$.
+However, in practice this value is unrealistically high \cite{Poyn97}.
+Rec.~470BG states that the overall system gamma should be approximately
+ $\gamma\beta=1.2$.
+Since most cameras pre-correct with a gamma value of $\beta=0.45$,
+ this suggests an output device gamma of approximately $\gamma=2.67$.
+This is the value recommended for use with PAL systems in Theora.
+
+Rec.~470 does not specify a digital encoding of the color signals.
+For Theora, Rec.~ITU-R~BT.601-5 \cite{rec601} is used, starting from the
+ $R'G'B'$ signals specified by Rec.~470.
+
+Rec.~470 does not specify an input gamma function.
+For Theora, the Rec 709 \cite{rec709} input function is assumed.
+
+The parameters for all the color transformations defined in
+ Section~\ref{sec:color-xforms} are given in Table~\ref{tab:470bg}.
+
+\begin{table}[htb]
+\begin{align*}
+\mathrm{Offset}_{Y,C_b,C_r}    & = (16, 128, 128)  \\
+\mathrm{Excursion}_{Y,C_b,C_r} & = (219, 224, 224) \\
+K_r                            & = 0.299           \\
+K_b                            & = 0.114           \\
+\gamma                         & = 2.67            \\
+\beta                          & = 0.45            \\
+\alpha                         & = 4.5             \\
+\delta                         & = 0.018           \\
+\epsilon                       & = 0.099           \\
+x_r,y_r                        & = 0.64, 0.33      \\
+x_g,y_g                        & = 0.29, 0.60      \\
+x_b,y_b                        & = 0.15, 0.06      \\
+\text{(D65) } x_w,y_w          & = 0.313, 0.329    \\
+\end{align*}
+\caption{Rec.~470BG Parameters}
+\label{tab:470bg}
+\end{table}
+
+\section{Pixel Formats}
+\label{sec:pixfmts}
+
+Theora supports several different pixel formats, each of which uses different
+ subsampling for the chroma planes relative to the luma plane.
+A decoder may need to recover a full resolution chroma plane with samples
+ co-sited with the luma plane in order to convert to RGB for display or perform
+ other processing.
+Decoders can assume that the chroma signal satisfies the Nyquist-Shannon
+ sampling theorem.
+The ideal low-pass reconstruction filter this implies is not practical, but any
+ suitable approximation can be used, depending on the available computing
+ power.
+Decoders MAY simply use a box filter, assigning to each luma sample the chroma
+ sample closest to it.
+Encoders would not go wrong in assuming that this will be the most common
+ approach.
+
+\subsection{4:4:4 Subsampling}
+\label{sec:444}
+
+All three color planes are stored at full resolution---each pixel has a $Y'$,
+ a $C_b$ and a $C_r$ value (see Figure~\ref{fig:pixel444}).
+The samples in the different planes are all at co-located sites.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{pixel444}
+\end{center}
+\caption{Pixels encoded 4:4:4}
+\label{fig:pixel444}
+\end{figure}
+
+% Figure.
+%YRB         YRB
+%
+%
+%
+%YRB         YRB
+%
+%
+%
+
+
+\subsection{4:2:2 Subsampling}
+\label{sec:422}
+
+The $C_b$ and $C_r$ planes are stored with half the horizontal resolution of
+ the $Y'$ plane.
+Thus, each of these planes has half the number of horizontal blocks as the luma
+ plane (see Figure~\ref{fig:pixel422}).
+Similarly, they have half the number of horizontal super blocks, rounded up.
+Macro blocks are defined across color planes, and so their number does not
+ change, but each macro block contains half as many chroma blocks.
+
+The chroma samples are vertically aligned with the luma samples, but
+ horizontally centered between two luma samples.
+Thus, each luma sample has a unique closest chroma sample.
+A horizontal phase shift may be required to produce signals which use different
+ horizontal chroma sampling locations for compatibility with different systems.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{pixel422}
+\end{center}
+\caption{Pixels encoded 4:2:2}
+\label{fig:pixel422}
+\end{figure}
+
+% Figure.
+%Y     RB    Y           Y     RB    Y
+%
+%
+%
+%Y     RB    Y           Y     RB    Y
+%
+%
+%
+
+\subsection{4:2:0 Subsampling}
+\label{sec:420}
+
+The $C_b$ and $C_r$ planes are stored with half the horizontal and half the
+ vertical resolution of the $Y'$ plane.
+Thus, each of these planes has half the number of horizontal blocks and half
+ the number of vertical blocks as the luma plane, for a total of one quarter
+ the number of blocks (see Figure~\ref{fig:pixel420}).
+Similarly, they have half the number of horizontal super blocks and half the
+ number of vertical super blocks, rounded up.
+Macro blocks are defined across color planes, and so their number does not
+ change, but each macro block contains within it one quarter as many 
+ chroma blocks.
+
+The chroma samples are vertically and horizontally centered between four luma
+ samples.
+Thus, each luma sample has a unique closest chroma sample.
+This is the same sub-sampling pattern used with JPEG, MJPEG, and MPEG-1, and
+ was inherited from VP3.
+A horizontal or vertical phase shift may be required to produce signals which
+ use different chroma sampling locations for compatibility with different
+ systems.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{pixel420}
+\end{center}
+\caption{Pixels encoded 4:2:0}
+\label{fig:pixel420}
+\end{figure}
+
+% Figure.
+%Y           Y           Y           Y
+%
+%      RB                      RB
+%
+%Y           Y           Y           Y
+%
+%
+%
+%Y           Y           Y           Y
+%
+%      RB                      RB
+%
+%Y           Y           Y           Y
+%
+%
+%
+
+\subsection{Subsampling and the Picture Region}
+
+Although the frame size must be an integral number of macro blocks, and thus
+ both the number of pixels and the number of blocks in each direction must be
+ even, no such requirement is made of the picture region.
+Thus, when using subsampled pixel formats, careful attention must be paid to
+ which chroma samples correspond to which luma samples.
+
+As mentioned above, for each pixel format, there is a unique chroma sample that
+ is the closest to each luma sample.
+When cropping the chroma planes to the picture region, all the chroma samples
+ corresponding to a luma sample in the cropped picture region must be included.
+Thus, when dividing the width or height of the picture region by two to obtain
+ the size of the subsampled chroma planes, they must be rounded up.
+
+Furthermore, the sampling locations are defined relative to the frame,
+ {\em not} the picture region.
+When using the 4:2:2 and 4:2:0 formats, the locations of chroma samples
+ relative to the luma samples depends on whether or not the X offset of the
+ picture region is odd.
+If the offset is even, each column of chroma samples corresponds to two columns
+ of luma samples (see Figure~\ref{fig:pic_even} for an example).
+The only exception is if the width is odd, in which case the last column
+ corresponds to only one column of luma samples (see Figure~\ref{fig:pic_even_odd}).
+If the offset is odd, then the first column of chroma samples corresponds to
+ only one column of luma samples, while the remaining columns each correspond
+ to two (see Figure~\ref{fig:pic_odd}).
+In this case, if the width is even, the last column again corresponds to only
+ one column of luma samples (see Figure~\ref{fig:pic_odd_even}).
+
+A similar process is followed with the rows of a picture region of odd height
+ encoded in the 4:2:0 format.
+If the Y offset is even, each row of chroma samples corresponds to two rows of
+ luma samples (see Figure~\ref{fig:pic_even}), except with an odd height, where
+ the last row corresponds to one row of chroma luna samples only (see 
+ Figure~\ref{fig:pic_even_odd}).
+If the offset is odd, then it is the first row of chroma samples which
+ corresponds to only one row of luma samples, while the remaining rows each
+ correspond to two (Figure~\ref{fig:pic_odd}), except with an even height, 
+ where the last row also corresponds to one (Figure~\ref{fig:pic_odd_even}).
+
+Encoders should be aware of these differences in the subsampling when using an
+ even or odd offset.
+In the typical case, with an even width and height, where one expects two rows
+ or columns of luma samples for every row or column of chroma samples, the
+ encoder must take care to ensure that the offsets used are both even.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics[width=\textwidth]{pic_even}
+\end{center}
+\caption{Pixel correspondence between color planes with even picture 
+ offset and even picture size}
+\label{fig:pic_even}
+\end{figure}
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics[width=\textwidth]{pic_even_odd}
+\end{center}
+\caption{Pixel correspondence with even picture offset and 
+ odd picture size}
+\label{fig:pic_even_odd}
+\end{figure}
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics[width=\textwidth]{pic_odd}
+\end{center}
+\caption{Pixel correspondence with odd picture offset and 
+ odd picture size}
+\label{fig:pic_odd}
+\end{figure}
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics[width=\textwidth]{pic_odd_even}
+\end{center}
+\caption{Pixel correspondence with odd picture offset and 
+ even picture size}
+\label{fig:pic_odd_even}
+\end{figure}
+
+
+\chapter{Bitpacking Convention}
+\label{sec:bitpacking}
+
+\section{Overview}
+
+The Theora codec uses relatively unstructured raw packets containing
+ binary integer fields of arbitrary width.
+Logically, each packet is a bitstream in which bits are written one-by-one by
+ the encoder and then read one-by-one in the same order by the decoder.
+Most current binary storage arrangements group bits into a native storage unit
+ of eight bits (octets), sixteen bits, thirty-two bits, or less commonly other
+ fixed sizes.
+The Theora bitpacking convention specifies the correct mapping of the logical
+ packet bitstream into an actual representation in fixed-width units.
+
+\subsection{Octets and Bytes}
+
+In most contemporary architectures, a `byte' is synonymous with an `octect',
+ that is, eight bits.
+For purposes of the bitpacking convention, a byte implies the smallest native
+ integer storage representation offered by a platform.
+Modern file systems invariably offer bytes as the fundamental atom of storage.
+
+The most ubiquitous architectures today consider a `byte' to be an octet.
+Note, however, that the Theora bitpacking convention is still well defined for
+ any native byte size; an implementation can use the native bit-width of a
+ given storage system.
+This document assumes that a byte is one octet for purposes of example only.
+
+\subsection{Words and Byte Order}
+
+A `word' is an integer size that is a grouped multiple of the byte size.
+Most architectures consider a word to be a group of two, four, or eight bytes.
+Each byte in the word can be ranked by order of `significance', e.g.\ the
+ significance of the bits in each byte when storing a binary integer in the
+ word.
+Several byte orderings are possible in a word.
+The common ones are
+\begin{itemize}
+\item{Big-endian:}
+in which the most significant byte comes first, e.g.\ 3-2-1-0,
+\item{Little-endian:}
+in which the least significant byte comes first, e.g.\ 0-1-2-3, and
+\item{Mixed-endian:}
+one of the less-common orderings that cannot be put into the above two
+ categories, e.g.\ 3-1-2-0 or 0-2-1-3.
+\end{itemize}
+
+The Theora bitpacking convention specifies storage and bitstream manipulation
+ at the byte, not word, level.
+Thus host word ordering is of a concern only during optimization, when writing
+ code that operates on a word of storage at a time rather than a byte.
+Logically, bytes are always encoded and decoded in order from byte zero through
+ byte $n$.
+
+\subsection{Bit Order}
+
+A byte has a well-defined `least significant' bit (LSb), which is the only bit
+ set when the byte is storing the two's complement integer value $+1$.
+A byte's `most significant' bit (MSb) is at the opposite end.
+Bits in a byte are numbered from zero at the LSb to $n$ for the MSb, where
+ $n=7$ in an octet.
+
+\section{Coding Bits into Bytes}
+
+The Theora codec needs to encode arbitrary bit-width integers from zero to 32
+ bits wide into packets.
+These integer fields are not aligned to the boundaries of the byte
+ representation; the next field is read at the bit position immediately
+ after the end of the previous field.
+
+The decoder logically unpacks integers by first reading the MSb of a binary
+ integer from the logical bitstream, followed by the next most significant
+ bit, etc., until the required number of bits have been read.
+When unpacking the bytes into bits, the decoder begins by reading the MSb of
+ the integer to be read from the most significant unread bit position of the
+ source byte, followed by the next-most significant bit position of the
+ destination integer, and so on up to the requested number of bits.
+Note that this differs from the Vorbis I codec, which
+ begins decoding with the LSb of the source integer, reading it from the
+ LSb of the source byte.
+When all the bits of the current source byte are read, decoding continues with
+ the MSb of the next byte.
+Any unfilled bits in the last byte of the packet MUST be cleared to zero by the
+ encoder.
+
+\subsection{Signedness}
+
+The binary integers decoded by the above process may be either signed or
+ unsigned.
+This varies from integer to integer, and this specification
+ indicates how each value should be interpreted as it is read.
+That is, depending on context, the three bit binary pattern \bin{111} can be
+ taken to represent either `$7$' as an unsigned integer or `$-1$' as a signed,
+ two's complement integer.
+
+\subsection{Encoding Example}
+
+The following example shows the state of an (8-bit) byte stream after several
+ binary integers are encoded, including the location of the put pointer for the
+ next bit to write to and the total length of the stream in bytes.
+
+Encode the 4 bit unsigned integer value `12' (\bin{1100}) into an empty byte
+ stream.
+
+\begin{tabular}{r|ccccccccl}
+\multicolumn{1}{r}{}& &&&&$\downarrow$&&&& \\
+         & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 & \\\cline{1-9}
+byte 0   & \textbf{1} & \textbf{1} & \textbf{0} & \textbf{0} &
+                           0 & 0 & 0 & 0 & $\leftarrow$     \\
+byte 1   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                  \\
+byte 2   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                  \\
+byte 3   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                  \\
+\multicolumn{1}{c|}{$\vdots$}&\multicolumn{8}{c}{$\vdots$}& \\
+byte $n$ & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &
+byte stream length: 1 byte
+\end{tabular}
+\vspace{\baselineskip}
+
+Continue by encoding the 3 bit signed integer value `-1' (\bin{111}).
+
+\begin{tabular}{r|ccccccccl}
+\multicolumn{1}{r}{} &&&&&&&&$\downarrow$& \\
+         & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 & \\\cline{1-9}
+byte 0   & \textbf{1} & \textbf{1} & \textbf{0} & \textbf{0} &
+           \textbf{1} & \textbf{1} & \textbf{1} & 0 & $\leftarrow$ \\
+byte 1   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                         \\
+byte 2   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                         \\
+byte 3   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                         \\
+\multicolumn{1}{c|}{$\vdots$}&\multicolumn{8}{c}{$\vdots$}&        \\
+byte $n$ & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &
+byte stream length: 1 byte
+\end{tabular}
+\vspace{\baselineskip}
+
+Continue by encoding the 7 bit integer value `17' (\bin{0010001}).
+
+\begin{tabular}{r|ccccccccl}
+\multicolumn{1}{r}{} &&&&&&&$\downarrow$&& \\
+         & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 & \\\cline{1-9}
+byte 0   & \textbf{1} & \textbf{1} & \textbf{0} & \textbf{0} &
+           \textbf{1} & \textbf{1} & \textbf{1} & \textbf{0} & \\
+byte 1   & \textbf{0} & \textbf{1} & \textbf{0} & \textbf{0} &
+           \textbf{0} & \textbf{1} & 0 & 0 & $\leftarrow$      \\
+byte 2   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                     \\
+byte 3   & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &                     \\
+\multicolumn{1}{c|}{$\vdots$}&\multicolumn{8}{c}{$\vdots$}&    \\
+byte $n$ & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &
+byte stream length: 2 bytes
+\end{tabular}
+\vspace{\baselineskip}
+
+Continue by encoding the 13 bit integer value `6969' (\bin{11011\ 00111001}).
+
+\begin{tabular}{r|ccccccccl}
+\multicolumn{1}{r}{} &&&&$\downarrow$&&&&& \\
+         & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 &            \\\cline{1-9}
+byte 0   & \textbf{1} & \textbf{1} & \textbf{0} & \textbf{0} &
+           \textbf{1} & \textbf{1} & \textbf{1} & \textbf{0} & \\
+byte 1   & \textbf{0} & \textbf{1} & \textbf{0} & \textbf{0} &
+           \textbf{0} & \textbf{1} & \textbf{1} & \textbf{1} & \\
+byte 2   & \textbf{0} & \textbf{1} & \textbf{1} & \textbf{0} &
+           \textbf{0} & \textbf{1} & \textbf{1} & \textbf{1} & \\
+byte 3   & \textbf{0} & \textbf{0} & \textbf{1} &
+                       0 & 0 & 0 & 0 & 0 & $\leftarrow$        \\
+\multicolumn{1}{c|}{$\vdots$}&\multicolumn{8}{c}{$\vdots$}&    \\
+byte $n$ & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 &
+byte stream length: 4 bytes
+\end{tabular}
+\vspace{\baselineskip}
+
+\subsection{Decoding Example}
+
+The following example shows the state of the (8-bit) byte stream encoded in the
+ previous example after several binary integers are decoded, including the
+ location of the get pointer for the next bit to read.
+
+Read a two bit unsigned integer from the example encoded above.
+
+\begin{tabular}{r|ccccccccl}
+\multicolumn{1}{r}{} &&&$\downarrow$&&&&&&              \\
+         & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 &              \\\cline{1-9}
+byte 0   & \textbf{1} & \textbf{1} & 0 & 0 & 1 & 1 & 1 & 0 & $\leftarrow$ \\
+byte 1   & 0 & 1 & 0 & 0 & 0 & 1 & 1 & 1 &              \\
+byte 2   & 0 & 1 & 1 & 0 & 0 & 1 & 1 & 1 &              \\
+byte 3   & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 &
+byte stream length: 4 bytes
+\end{tabular}
+\vspace{\baselineskip}
+
+Value read: 3 (\bin{11}).
+
+Read another two bit unsigned integer from the example encoded above.
+
+\begin{tabular}{r|ccccccccl}
+\multicolumn{1}{r}{} &&&&&$\downarrow$&&&&              \\
+         & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 &              \\\cline{1-9}
+byte 0   & \textbf{1} & \textbf{1} & \textbf{0} & \textbf{0} &
+                           1 & 1 & 1 & 0 & $\leftarrow$ \\
+byte 1   & 0 & 1 & 0 & 0 & 0 & 1 & 1 & 1 &              \\
+byte 2   & 0 & 1 & 1 & 0 & 0 & 1 & 1 & 1 &              \\
+byte 3   & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 &
+byte stream length: 4 bytes
+\end{tabular}
+\vspace{\baselineskip}
+
+Value read: 0 (\bin{00}).
+
+Two things are worth noting here.
+\begin{itemize}
+\item
+Although these four bits were originally written as a single four-bit integer,
+ reading some other combination of bit-widths from the bitstream is well
+ defined.
+No artificial alignment boundaries are maintained in the bitstream.
+\item
+The first value is the integer `$3$' only because the context stated we were
+ reading an unsigned integer.
+Had the context stated we were reading a signed integer, the returned value
+ would have been the integer `$-1$'.
+\end{itemize}
+
+\subsection{End-of-Packet Alignment}
+
+The typical use of bitpacking is to produce many independent byte-aligned
+ packets which are embedded into a larger byte-aligned container structure,
+ such as an Ogg transport bitstream.
+Externally, each bitstream encoded as a byte stream MUST begin and end on a
+ byte boundary.
+Often, the encoded packet bitstream is not an integer number of bytes, and so
+ there is unused space in the last byte of a packet.
+
+%r: I think the generality here is necessary to be consistent with our assertions
+%r: elsewhere about being independent of transport and byte width
+When a Theora encoder produces packets for embedding in a byte-aligned
+ container, unused space in the last byte of a packet is always zeroed during
+ the encoding process.
+Thus, should this unused space be read, it will return binary zeroes.
+There is no marker pattern or stuffing bits that will allow the decoder to
+ obtain the exact size, in bits, of the original bitstream.
+This knowledge is not required for decoding.
+
+Attempting to read past the end of an encoded packet results in an
+ `end-of-packet' condition.
+Any further read operations after an `end-of-packet' condition shall also
+ return `end-of-packet'.
+Unlike Vorbis, Theora does not use truncated packets as a normal mode of
+ operation.
+Therefore if a decoder encounters the `end-of-packet' condition during normal
+ decoding, it may attempt to use the bits that were read to recover as much of
+ encoded data as possible, signal a warning or error, or both.
+
+\subsection{Reading Zero Bit Integers}
+
+Reading a zero bit integer returns the value `$0$' and does not increment
+ the stream pointer.
+Reading to the end of the packet, but not past the end, so that an
+ `end-of-packet' condition is not triggered, and then reading a zero bit
+ integer shall succeed, returning `$0$', and not trigger an `end-of-packet'
+ condition.
+Reading a zero bit integer after a previous read sets the `end-of-packet'
+ condition shall fail, also returning `end-of-packet'.
+
+\chapter{Bitstream Headers}
+\label{sec:headers}
+
+A Theora bitstream begins with three header packets.
+The header packets are, in order, the identification header, the comment
+ header, and the setup header.
+All are required for decode compliance.
+An end-of-packet condition encountered while decoding the identification or
+ setup header packets renders the stream undecodable.
+An end-of-packet condition encountered while decode the comment header is a
+ non-fatal error condition, and MAY be ignored by a decoder.
+
+\paragraph{VP3 Compatibility}
+
+VP3 relies on the headers provided by its container, usually either AVI or
+ Quicktime.
+As such, several parameters available in these headers are not available to VP3
+ streams.
+These are indicated as they appear in the sections below.
+
+\section{Common Header Decode}
+\label{sub:common-header}
+
+\begin{figure}[Htbp]
+\begin{center}
+\begin{verbatim}
+  0                   1                   2                   3   
+  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |  header type  |      `t'      |      `h'      |      `e'      |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |      `o'      |      `r'      |      `a'      |     data...   |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |                 ... header-specific data ...                  |
+ |                              ...                              |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+\end{verbatim}
+\end{center}
+\caption{Common Header Packet Layout}
+\label{fig:commonheader}
+\end{figure}
+
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{HEADERTYPE} & Integer & 8 & No & The type of the header being
+ decoded. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:} None.
+\medskip
+
+Each header packet begins with the same header fields, which are decoded as
+ follows:
+
+\begin{enumerate}
+\item
+Read an 8-bit unsigned integer as \bitvar{HEADERTYPE}.
+If the most significant bit of this integer is not set, then stop.
+This is not a header packet.
+\item
+Read 6 8-bit unsigned integers.
+If these do not have the values \hex{74}, \hex{68}, \hex{65}, \hex{6F},
+ \hex{72}, and \hex{61}, respectively, then stop.
+This stream is not decodable by this specification.
+These values correspond to the ASCII values of the characters `t', `h', `e',
+ `o', `r', and `a'.
+\end{enumerate}
+
+Decode continues according to \bitvar{HEADERTYPE}.
+The identification header is type \hex{80}, the comment header is type
+ \hex{81}, and the setup header is type \hex{82}.
+These packets must occur in the order: identification, comment, setup.
+%r: I clarified the initial-bit scheme here
+%TBT: Dashes let the reader know they'll have to pick up the rest of the
+%TBT:  sentence after the explanatory phrase.
+%TBT: Otherwise it just sounds like the bit must exist.
+All header packets have the most significant bit of the type
+ field---which is the initial bit in the packet---set.
+This distinguishes them from video data packets in which the first bit
+ is unset.
+% extra header packets are a feature Dan argued for way back when for 
+% backward-compatible extensions (and icc colourspace for example)
+% I think it's reasonable
+%TBT: You can always just stick more stuff in the setup header.
+Packets with other header types (\hex{83}--\hex{FF}) are reserved and MUST be
+ ignored.
+
+\section{Identification Header Decode}
+\label{sec:idheader}
+
+\begin{figure}[Htbp]
+\begin{center}
+\begin{verbatim}
+  0                   1                   2                   3   
+  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |      0x80     |      `t'      |      `h'      |      `e'      |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |      `o'      |      `r'      |      `a'      |     VMAJ      |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |     VMIN      |     VREV      |           FMBW                |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |             FMBH              |           PICW...             |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |   ...PICW     |                 PICH                          |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |     PICX      |     PICY      |            FRN...             |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |           ...FRN              |            FRD...             |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |           ...FRD              |            PARN...            |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |    ...PARN    |                   PARD                        |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |      CS       |                  NOMBR                        |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+ |    QUAL   | KFGSHIFT| PF| Res |
+ +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+\end{verbatim}
+\end{center}
+\caption{Identification Header Packet}
+\label{fig:idheader}
+\end{figure}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{VMAJ}     & Integer &  8 & No & The major version number. \\
+\bitvar{VMIN}     & Integer &  8 & No & The minor version number. \\
+\bitvar{VREV}     & Integer &  8 & No & The version revision number. \\
+\bitvar{FMBW}     & Integer & 16 & No & The width of the frame in macro
+ blocks. \\
+\bitvar{FMBH}     & Integer & 16 & No & The height of the frame in macro
+ blocks. \\
+\bitvar{NSBS}     & Integer & 32 & No & The total number of super blocks in a
+ frame. \\
+\bitvar{NBS}      & Integer & 36 & No & The total number of blocks in a
+ frame. \\
+\bitvar{NMBS}     & Integer & 32 & No & The total number of macro blocks in a
+ frame. \\
+\bitvar{PICW}     & Integer & 20 & No & The width of the picture region in
+ pixels. \\
+\bitvar{PICH}     & Integer & 20 & No & The height of the picture region in
+ pixels. \\
+\bitvar{PICX}     & Integer &  8 & No & The X offset of the picture region in
+ pixels. \\
+\bitvar{PICY}     & Integer &  8 & No & The Y offset of the picture region in
+ pixels. \\
+\bitvar{FRN}      & Integer & 32 & No & The frame-rate numerator. \\
+\bitvar{FRD}      & Integer & 32 & No & The frame-rate denominator. \\
+\bitvar{PARN}     & Integer & 24 & No & The pixel aspect-ratio numerator. \\
+\bitvar{PARD}     & Integer & 24 & No & The pixel aspect-ratio denominator. \\
+\bitvar{CS}       & Integer &  8 & No & The color space. \\
+\bitvar{PF}       & Integer &  2 & No & The pixel format. \\
+\bitvar{NOMBR}    & Integer & 24 & No & The nominal bitrate of the stream, in
+ bits per second. \\
+\bitvar{QUAL}     & Integer &  6 & No & The quality hint. \\
+\bitvar{KFGSHIFT} & Integer &  5 & No & The amount to shift the key frame
+ number by in the granule position. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:} None.
+\medskip
+
+The identification header is a short header with only a few fields used to
+ declare the stream definitively as Theora and provide detailed information
+ about the format of the fully decoded video data.
+The identification header is decoded as follows:
+
+\begin{enumerate}
+\item
+Decode the common header fields according to the procedure described in
+ Section~\ref{sub:common-header}.
+If \bitvar{HEADERTYPE} returned by this procedure is not \hex{80}, then stop.
+This packet is not the identification header.
+\item
+Read an 8-bit unsigned integer as \bitvar{VMAJ}.
+If \bitvar{VMAJ} is not $3$, then stop.
+This stream is not decodable according to this specification.
+\item
+Read an 8-bit unsigned integer as \bitvar{VMIN}.
+If \bitvar{VMIN} is not $2$, then stop.
+This stream is not decodable according to this specification.
+\item
+Read an 8-bit unsigned integer as \bitvar{VREV}.
+If \bitvar{VREV} is greater than $1$, then this stream
+may contain optional features or interpretational changes 
+documented in a future version of this specification.
+Regardless of the value of \bitvar{VREV}, the stream is decodable 
+according to this specification.
+\item
+Read a 16-bit unsigned integer as \bitvar{FMBW}.
+This MUST be greater than zero.
+This specifies the width of the coded frame in macro blocks.
+The actual width of the frame in pixels is $\bitvar{FMBW}*16$.
+\item
+Read a 16-bit unsigned integer as \bitvar{FMBH}.
+This MUST be greater than zero.
+This specifies the height of the coded frame in macro blocks.
+The actual height of the frame in pixels is $\bitvar{FMBH}*16$.
+\item
+Read a 24-bit unsigned integer as \bitvar{PICW}.
+This MUST be no greater than $(\bitvar{FMBW}*16)$.
+Note that 24 bits are read, even though only 20 bits are sufficient to specify
+ any value of the picture width.
+This is done to preserve octet alignment in this header, to allow for a
+ simplified parser implementation.
+\item
+Read a 24-bit unsigned integer as \bitvar{PICH}.
+This MUST be no greater than $(\bitvar{FMBH}*16)$.
+Together with \bitvar{PICW}, this specifies the size of the displayable picture
+ region within the coded frame.
+See Figure~\ref{fig:pic-frame}.
+Again, 24 bits are read instead of 20.
+\item
+Read an 8-bit unsigned integer as \bitvar{PICX}.
+This MUST be no greater than $(\bitvar{FMBW}*16-\bitvar{PICX})$.
+\item
+Read an 8-bit unsigned integer as \bitvar{PICY}.
+This MUST be no greater than $(\bitvar{FMBH}*16-\bitvar{PICY})$.
+Together with \bitvar{PICX}, this specifies the location of the lower-left
+ corner of the displayable picture region.
+See Figure~\ref{fig:pic-frame}.
+\item
+Read a 32-bit unsigned integer as \bitvar{FRN}.
+This MUST be greater than zero.
+\item
+Read a 32-bit unsigned integer as \bitvar{FRD}.
+This MUST be greater than zero.
+Theora is a fixed-frame rate video codec.
+Frames are sampled at the constant rate of $\frac{\bitvar{FRN}}{\bitvar{FRD}}$
+ frames per second.
+The presentation time of the first frame is at zero seconds.
+No mechanism is provided to specify a non-zero offset for the initial
+ frame.
+\item
+Read a 24-bit unsigned integer as \bitvar{PARN}.
+\item
+Read a 24-bit unsigned integer as \bitvar{PARD}.
+Together with \bitvar{PARN}, these specify the aspect ratio of the pixels
+ within a frame, defined as the ratio of the physical width of a pixel to its
+ physical height.
+This is given by the ratio $\bitvar{PARN}:\bitvar{PARD}$.
+If either of these fields are zero, this indicates that pixel aspect ratio
+ information was not available to the encoder.
+In this case it MAY be specified by the application via an external means, or
+ a default value of $1:1$ MAY be used.
+\item
+Read an 8-bit unsigned integer as \bitvar{CS}.
+This is a value from an enumerated list of the available color spaces, given in
+ Table~\ref{tab:colorspaces}.
+The `Undefined' value indicates that color space information was not available
+ to the encoder.
+It MAY be specified by the application via an external means.
+If a reserved value is given, a decoder MAY refuse to decode the stream.
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular*}{215pt}{cl@{\extracolsep{\fill}}c}\toprule
+Value    & Color Space                               \\\midrule
+$0$      & Undefined.                                \\
+$1$      & Rec.~470M (see Section~\ref{sec:470m}).   \\
+$2$      & Rec.~470BG (see Section~\ref{sec:470bg}). \\
+$3$      & Reserved.                                 \\
+$\vdots$ &                                           \\
+$255$    &                                           \\
+\bottomrule\end{tabular*}
+\end{center}
+\caption{Enumerated List of Color Spaces}
+\label{tab:colorspaces}
+\end{table}
+\item
+Read a 24-bit unsigned integer as \bitvar{NOMBR} signifying a rate in bits
+per second. Rates equal to or greater than $2^{24}-1$ bits per second are
+represented as $2^{24}-1$. 
+The \bitvar{NOMBR} field is used only as a hint.
+For pure VBR streams, this value may be considerably off.
+The field MAY be set to zero to indicate that the encoder did not care to
+speculate. 
+\item
+Read a 6-bit unsigned integer as \bitvar{QUAL}.
+This value is used to provide a hint as to the relative quality of the stream
+ when compared to others produced by the same encoder.
+Larger values indicate higher quality.
+This can be used, for example, to select among several streams containing the
+ same material encoded with different settings.
+\item
+Read a 5-bit unsigned integer as \bitvar{KFGSHIFT}.
+The \bitvar{KFGSHIFT} is used to partition the granule position associated with
+ each packet into two different parts.
+The frame number of the last key frame, starting from zero, is stored in the
+ upper $64-\bitvar{KFGSHIFT}$ bits, while the lower \bitvar{KFGSHIFT} bits
+ contain the number of frames since the last keyframe.
+Complete details on the granule position mapping are specified in Section~REF.
+\item
+Read a 2-bit unsigned integer as \bitvar{PF}.
+The \bitvar{PF} field contains a value from an enumerated list of the available
+ pixel formats, given in Table~\ref{tab:pixel-formats}.
+If the reserved value $1$ is given, stop.
+This stream is not decodable according to this specification.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular*}{215pt}{cl@{\extracolsep{\fill}}c}\toprule
+Value & Pixel Format             \\\midrule
+$0$   & 4:2:0 (see Section~\ref{sec:420}). \\
+$1$   & Reserved.                \\
+$2$   & 4:2:2 (see Section~\ref{sec:422}). \\
+$3$   & 4:4:4 (see Section~\ref{sec:444}). \\
+\bottomrule\end{tabular*}
+\end{center}
+\caption{Enumerated List of Pixel Formats}
+\label{tab:pixel-formats}
+\end{table}
+
+\item
+Read a 3-bit unsigned integer.
+These bits are reserved.
+If this value is not zero, then stop.
+This stream is not decodable according to this specification.
+\item
+Assign \bitvar{NSBS} a value according to \bitvar{PF}, as given by
+ Table~\ref{tab:nsbs-for-pf}.
+
+\begin{table}[bt]
+\begin{center}
+\begin{tabular}{cc}\toprule
+\bitvar{PF} & \bitvar{NSBS}                                     \\\midrule
+$0$         & $\begin{aligned}
+&((\bitvar{FMBW}+1)//2)*((\bitvar{FMBH}+1)//2)\\
+& +2*((\bitvar{FMBW}+3)//4)*((\bitvar{FMBH}+3)//4)
+\end{aligned}$                                                  \\\midrule
+$2$         & $\begin{aligned}
+&((\bitvar{FMBW}+1)//2)*((\bitvar{FMBH}+1)//2)\\
+& +2*((\bitvar{FMBW}+3)//4)*((\bitvar{FMBH}+1)//2)
+\end{aligned}$                                                  \\\midrule
+$3$         & $3*((\bitvar{FMBW}+1)//2)*((\bitvar{FMBH}+1)//2)$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Number of Super Blocks for each Pixel Format}
+\label{tab:nsbs-for-pf}
+\end{table}
+
+\item
+Assign \bitvar{NBS} a value according to \bitvar{PF}, as given by
+ Table~\ref{tab:nbs-for-pf}.
+
+\begin{table}[tb]
+\begin{center}
+\begin{tabular}{cc}\toprule
+\bitvar{PF} & \bitvar{NBS}                     \\\midrule
+$0$         & $6*\bitvar{FMBW}*\bitvar{FMBH}$  \\\midrule
+$2$         & $8*\bitvar{FMBW}*\bitvar{FMBH}$  \\\midrule
+$3$         & $12*\bitvar{FMBW}*\bitvar{FMBH}$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Number of Blocks for each Pixel Format}
+\label{tab:nbs-for-pf}
+\end{table}
+
+\item
+Assign \bitvar{NMBS} the value $(\bitvar{FMBW}*\bitvar{FMBH})$.
+
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+VP3 does not correctly handle frame sizes that are not a multiple of 16.
+Thus, \bitvar{PICW} and \bitvar{PICH} should be set to the frame width and
+ height in pixels, respectively, and \bitvar{PICX} and \bitvar{PICY} should be
+ set to zero.
+VP3 headers do not specify a color space.
+VP3 only supports the 4:2:0 pixel format.
+
+\section{Comment Header}
+\label{sec:commentheader}
+
+The Theora comment header is the second of three header packets that begin a
+ Theora stream.
+It is meant for short text comments, not aribtrary metadata; arbitrary metadata
+ belongs in a separate logical stream that provides greater structure and
+ machine parseability.
+
+%r: I tried to morph this a little more in the direction of our 
+%   application space 
+The comment field is meant to be used much like someone jotting a quick note on
+ the label of a video.
+It should be a little information to remember the disc or tape by and explain it to
+ others; a short, to-the-point text note that can be more than a couple words,
+ but isn't going to be more than a short paragraph.
+The essentials, in other words, whatever they turn out to be, e.g.:
+
+%TODO: Example
+
+The comment header is stored as a logical list of eight-bit clean vectors; the
+ number of vectors is bounded at $2^{32}-1$ and the length of each vector is
+ limited to $2^{32}-1$ bytes.
+The vector length is encoded; the vector contents themselves are not null
+ terminated.
+In addition to the vector list, there is a single vector for a vendor name,
+ also eight-bit clean with a length encoded in 32 bits.
+%TODO: The 1.0 release of libtheora sets the vendor string to ...
+
+\subsection{Comment Length Decode}
+\label{sub:comment-len}
+
+\begin{figure}
+\begin{center}
+\begin{tabular}{ | c | c | }
+ \hline
+ 4 byte length &
+ UTF-8 encoded string ...\\
+ \hline
+\end{tabular}
+\end{center}
+\caption{Length encoded string layout}
+\label{fig:comment-len}
+\end{figure}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{LEN}  & Integer & 32 & No & A single 32-bit length value. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{LEN0} & Integer &  8 & No & The first octet of the string length. \\
+\locvar{LEN1} & Integer &  8 & No & The second octet of the string length. \\
+\locvar{LEN2} & Integer &  8 & No & The third octet of the string length. \\
+\locvar{LEN3} & Integer &  8 & No & The fourth octet of the string
+ length. \\
+\bottomrule\end{tabularx}
+\medskip
+
+A single comment vector is decoded as follows:
+
+\begin{enumerate}
+\item
+Read an 8-bit unsigned integer as \locvar{LEN0}.
+\item
+Read an 8-bit unsigned integer as \locvar{LEN1}.
+\item
+Read an 8-bit unsigned integer as \locvar{LEN2}.
+\item
+Read an 8-bit unsigned integer as \locvar{LEN3}.
+\item
+Assign \bitvar{LEN} the value $(\locvar{LEN0}+(\locvar{LEN1}<<8)+
+ (\locvar{LEN2}<<16)+(\locvar{LEN3}<<24))$.
+This construction is used so that on platforms with 8-bit bytes, the memory
+ organization of the comment header is identical with that of Vorbis I,
+ allowing for common parsing code despite the different bit packing
+ conventions.
+\end{enumerate}
+
+\subsection{Comment Header Decode}
+
+\begin{figure}
+\begin{center}
+\begin{tabular}{ | c | }
+  \hline
+  vendor string \\ \hline
+  number of comments \\ \hline
+  comment string \\ \hline
+  comment string \\ \hline
+  ... \\
+  \hline
+\end{tabular}
+\end{center}
+\caption{Comment Header Layout}
+\label{fig:commentheader}
+\end{figure}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{VENDOR}    & \multicolumn{3}{l}{String}       & The vendor string. \\
+\bitvar{NCOMMENTS} & Integer                & 32 & No & The number of user
+ comments. \\
+\bitvar{COMMENTS}  & \multicolumn{3}{l}{String Array} & A list of
+ \bitvar{NCOMMENTS} user comment values. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\ci} & Integer & 32 & No & The index of the current user
+ comment. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The complete comment header is decoded as follows:
+
+\begin{enumerate}
+\item
+Decode the common header fields according to the procedure described in
+ Section~\ref{sub:common-header}.
+If \bitvar{HEADERTYPE} returned by this procedure is not \hex{81}, then stop.
+This packet is not the comment header.
+\item
+Decode the length of the vendor string using the procedure given in
+ Section~\ref{sub:comment-len} into \bitvar{LEN}.
+\item
+Read \bitvar{LEN} 8-bit unsigned integers.
+\item
+Set the string \bitvar{VENDOR} to the contents of these octets.
+\item
+Decode the number of user comments using the procedure given in
+ Section~\ref{sub:comment-len} into \bitvar{LEN}.
+\item
+Assign \bitvar{NCOMMENTS} the value stored in \bitvar{LEN}.
+\item
+For each consecutive value of \locvar{\ci} from $0$ to
+ $(\bitvar{NCOMMENTS}-1)$, inclusive:
+\begin{enumerate}
+\item
+Decode the length of the current user comment using the procedure given in
+ Section~\ref{sub:comment-len} into \bitvar{LEN}.
+\item
+Read \bitvar{LEN} 8-bit unsigned integers.
+\item
+Set the string $\bitvar{COMMENTS}[\locvar{\ci}]$ to the contents of these
+ octets.
+\end{enumerate}
+\end{enumerate}
+
+The comment header comprises the entirety of the second header packet.
+Unlike the first header packet, it is not generally the only packet on the
+ second page and may span multiple pages.
+The length of the comment header packet is (practically) unbounded.
+The comment header packet is not optional; it must be present in the stream
+ even if it is logically empty.
+
+%TODO: \paragraph{VP3 Compatibility}
+
+\subsection{User Comment Format}
+
+The user comment vectors are structured similarly to a UNIX environment
+ variable.
+That is, comment fields consist of a field name and a corresponding value and
+ look like:
+\begin{center}
+\begin{tabular}{rcl}
+$\bitvar{COMMENTS}[0]$ & = & ``TITLE=the look of Theora" \\
+$\bitvar{COMMENTS}[1]$ & = & ``DIRECTOR=me"
+\end{tabular}
+\end{center}
+
+The field name is case-insensitive and MUST consist of ASCII characters
+ \hex{20} through \hex{7D}, \hex{3D} (`=') excluded.
+ASCII \hex{41} through \hex{5A} inclusive (characters `A'--`Z') are to be
+ considered equivalent to ASCII \hex{61} through \hex{7A} inclusive
+ (characters `a'--`z').
+An entirely empty field name---one that is zero characters long---is not
+ disallowed.
+
+The field name is immediately followed by ASCII \hex{3D} (`='); this equals
+ sign is used to terminate the field name.
+
+The data immediately after \hex{3D} until the end of the vector is the eight-bit
+ clean value of the field contents encoded as a UTF-8 string~\cite{rfc2044}.
+
+Field names MUST NOT be `internationalized'; this is a concession to
+ simplicity, not an attempt to exclude the majority of the world that doesn't
+ speak English.
+Applications MAY wish to present internationalized versions of the standard
+ field names listed below to the user, but they are not to be stored in the
+ bitstream.
+Field {\em contents}, however, use the UTF-8 character encoding to allow easy
+ representation of any language.
+
+Individual `vendors' MAY use non-standard field names within reason.
+The proper use of comment fields as human-readable notes has already been
+ explained.
+Abuse will be discouraged.
+
+There is no vendor-specific prefix to `non-standard' field names.
+Vendors SHOULD make some effort to avoid arbitrarily polluting the common
+ namespace.
+%"and other bodies"?
+%If you're going to be that vague, you might as well not say anything at all.
+Xiph.org and other bodies will generally collect and rationalize the more 
+ useful tags to help with standardization.
+
+Field names are not restricted to occur only once within a comment header.
+%TODO: Example
+
+\paragraph{Field Names}
+
+%r should this be an appendix?
+
+Below is a proposed, minimal list of standard field names with a description of
+ their intended use.
+No field names are mandatory; a comment header may contain one or more, all, or
+ none of the names in this list.
+
+\begin{description}
+\item{TITLE:} Video name.
+\item{ARTIST:} Filmmaker or other creator name.
+\item{VERSION:} Subtitle, remix info, or other text distinguishing
+ versions of a video.
+\item{DATE:} Date associated with the video. Implementations SHOULD attempt
+ to parse this field as an ISO 8601 date for machine interpretation and 
+ conversion.
+\item{LOCATION:} Location associated with the video. This is usually the
+ filming location for non-fiction works.
+\item{COPYRIGHT:} Copyright statement.
+\item{LICENSE:} Copyright and other licensing information. 
+ Implementations wishing to do automatic parsing of e.g
+ of distribution terms SHOULD look here for a URL uniquely defining
+ the license. If no instance of this field is present, or if no 
+ instance contains a parseable URL, and implementation MAY look
+ in the COPYRIGHT field for such a URL.
+\item{ORGANIZATION:} Studio name, Publisher, or other organization
+ involved in the creation of the video.
+
+\item{DIRECTOR:} Director or Filmmaker credit, similar to ARTIST.
+\item{PRODUCER:} Producer credit for the video.
+\item{COMPOSER:} Music credit for the video.
+\item{ACTOR:} Acting credit for the video.
+
+\item{TAG:} subject or category tag, keyword, or other content
+ classification labels. The value of each instance of this
+ field SHOULD be treated as a single label, with multiple
+ instances of the field for multiple tags. The value of
+ a single field SHOULD NOT be parsed into multiple tags
+ based on some internal delimeter.
+\item{DESCRIPTION:} General description, summary, or blurb.
+\end{description}
+
+\section{Setup Header}
+\label{sec:setupheader}
+
+The Theora setup header contains the limit values used to drive the loop
+ filter, the base matrices and scale values used to build the dequantization
+ tables, and the Huffman tables used to unpack the DCT tokens.
+Because the contents of this header are specific to Theora, no concessions have
+ been made to keep the fields octet-aligned for easy parsing.
+
+\begin{figure}
+\begin{center}
+\begin{tabular}{ | c | }
+ \hline
+ common header block \\ \hline
+ loop filter table resolution \\ \hline
+ loop filter table \\ \hline
+ scale table resolution \\ \hline
+ AC scale table \\ \hline
+ DC scale table \\ \hline
+ number of base matricies \\ \hline
+ base quatization matricies \\ \hline
+ ... \\ \hline
+ quant range interpolation table \\ \hline
+ DCT token Huffman tables \\
+ \hline
+\end{tabular}
+\end{center}
+\caption{Setup Header structure}
+\label{fig:setupheader}
+\end{figure}
+
+\subsection{Loop Filter Limit Table Decode}
+\label{sub:loop-filter-limits}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{LFLIMS}    & \multicolumn{1}{p{40pt}}{Integer array} &
+                              7 & No & A 64-element array of loop filter limit
+ values. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\qi}    & Integer &  6 & No & The quantization index. \\
+\locvar{NBITS}  & Integer &  3 & No & The size of values being read in the
+ current table. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure decodes the table of loop filter limit values used to drive the
+ loop filter, which is described in Section~\ref{sub:loop-filter-limits}.
+It is decoded as follows:
+
+\begin{enumerate}
+\item
+Read a 3-bit unsigned integer as \locvar{NBITS}.
+\item
+For each consecutive value of \locvar{\qi} from $0$ to $63$, inclusive:
+\begin{enumerate}
+\item
+Read an \locvar{NBITS}-bit unsigned integer as $\bitvar{LFLIMS}[\locvar{\qi}]$.
+\end{enumerate}
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+The loop filter limit values are hardcoded in VP3.
+The values used are given in Appendix~\ref{app:vp3-loop-filter-limits}.
+
+\subsection{Quantization Parameters Decode}
+\label{sub:quant-params}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{ACSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No & A 64-element array of scale values for
+ AC coefficients for each \qi\ value. \\
+\bitvar{DCSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No & A 64-element array of scale values for
+ the DC coefficient for each \qi\ value. \\
+\bitvar{NBMS}    & Integer & 10 & No & The number of base matrices. \\
+\bitvar{BMS}     & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              8 & No & A $\bitvar{NBMS}\times 64$ array
+ containing the base matrices. \\
+\bitvar{NQRS}    & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              6 & No & A $2\times 3$ array containing the
+ number of quant ranges for a given \qti\ and \pli, respectively.
+This is at most $63$. \\
+\bitvar{QRSIZES} & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              6 & No & A $2\times 3\times 63$ array of the
+ sizes of each quant range for a given \qti\ and \pli, respectively.
+Only the first $\bitvar{NQRS}[\qti][\pli]$ values are used. \\
+\bitvar{QRBMIS}  & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              9 & No & A $2\times 3\times 64$ array of the
+ \bmi's used for each quant range for a given \qti\ and \pli, respectively.
+Only the first $(\bitvar{NQRS}[\qti][\pli]+1)$ values are used. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\qti}    & Integer &  1 & No & A quantization type index.
+See Table~\ref{tab:quant-types}.\\
+\locvar{\qtj}    & Integer &  1 & No & A quantization type index. \\
+\locvar{\pli}    & Integer &  2 & No & A color plane index.
+See Table~\ref{tab:color-planes}.\\
+\locvar{\plj}    & Integer &  2 & No & A color plane index. \\
+\locvar{\qi}     & Integer &  6 & No & The quantization index. \\
+\locvar{\ci}     & Integer &  6 & No & The DCT coefficient index. \\
+\locvar{\bmi}    & Integer &  9 & No & The base matrix index. \\
+\locvar{\qri}    & Integer &  6 & No & The quant range index. \\
+\locvar{NBITS}   & Integer &  5 & No & The size of fields to read. \\
+\locvar{NEWQR}   & Integer &  1 & No & Flag that indicates a new set of quant
+ ranges will be defined. \\
+\locvar{RPQR}    & Integer &  1 & No & Flag that indicates the quant ranges to
+ copy will come from the same color plane. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The AC scale and DC scale values are defined in two simple tables with 64
+ values each, one for each \qi\ value.
+The same scale values are used for every quantization type and color plane.
+
+The base matrices for all quantization types and color planes are stored in a
+ single table.
+These are then referenced by index in several sets of \term{quant ranges}.
+The purpose of the quant ranges is to specify which base matrices are used for
+ which \qi\ values.
+
+A set of quant ranges is defined for each quantization type and color plane.
+To save space in the header, bit flags allow a set of quant ranges to be copied
+ from a previously defined set instead of being specified explicitly.
+Every set except the first one can be copied from the immediately preceding
+ set.
+Similarly, if the quantization type is not $0$, the set can be copied from the
+ set defined for the same color plane for the preceding quantization type.
+This formulation allows compact representation of, for example, the same 
+ set of quant ranges in both chroma channels, as is done in the original VP3,
+ or the same set of quant ranges in INTRA and INTER modes.
+
+Each quant range is defined by a size and two base matrix indices, one for each
+ end of the range.
+The base matrix for the end of one range is used as the start of the next
+ range, so that for $n$ ranges, $n+1$ base matrices are specified.
+The base matrices for the \qi\ values between the two endpoints of the range
+ are generated by linear interpolation.
+
+%TODO: figure
+
+The location of the endpoints of each range is encoded by their size.
+The \qi\ value for the left end-point is the sum of the sizes of all preceding
+ ranges, and the \qi\ value for the right end-point adds the size of the
+ current range.
+Thus the sum of the sizes of all the ranges MUST be 63, so that the last range
+ falls on the last possible \qi\ value.
+
+The complete set of quantization parameters are decoded as follows:
+
+\begin{enumerate}
+\item
+Read a 4-bit unsigned integer.
+Assign \locvar{NBITS} the value read, plus one.
+\item
+For each consecutive value of \locvar{\qi} from $0$ to $63$, inclusive:
+\begin{enumerate}
+\item
+Read an \locvar{NBITS}-bit unsigned integer as
+ $\bitvar{ACSCALE}[\locvar{\qi}]$.
+\end{enumerate}
+\item
+Read a 4-bit unsigned integer.
+Assign \locvar{NBITS} the value read, plus one.
+\item
+For each consecutive value of \locvar{\qi} from $0$ to $63$, inclusive:
+\begin{enumerate}
+\item
+Read an \locvar{NBITS}-bit unsigned integer as
+ $\bitvar{DCSCALE}[\locvar{\qi}]$.
+\end{enumerate}
+\item
+Read a 9-bit unsigned integer.
+Assign \bitvar{NBMS} the value decoded, plus one.
+\bitvar{NBMS} MUST be no greater than 384.
+\item
+For each consecutive value of \locvar{\bmi} from $0$ to $(\bitvar{NBMS}-1)$,
+ inclusive:
+\begin{enumerate}
+\item
+For each consecutive value of \locvar{\ci} from $0$ to $63$, inclusive:
+\begin{enumerate}
+\item
+Read an 8-bit unsigned integer as $\bitvar{BMS}[\locvar{\bmi}][\locvar{\ci}]$.
+\end{enumerate}
+\end{enumerate}
+\item
+For each consecutive value of \locvar{\qti} from $0$ to $1$, inclusive:
+\begin{enumerate}
+\item
+For each consecutive value of \locvar{\pli} from $0$ to $2$, inclusive:
+\begin{enumerate}
+\item
+If $\locvar{\qti}>0$ or $\locvar{\pli}>0$, read a 1-bit unsigned integer as
+ \locvar{NEWQR}.
+\item
+Else, assign \locvar{NEWQR} the value one.
+\item
+If \locvar{NEWQR} is zero, then we are copying a previously defined set of
+ quant ranges.
+In that case:
+\begin{enumerate}
+\item
+If $\locvar{\qti}>0$, read a 1-bit unsigned integer as \locvar{RPQR}.
+\item
+Else, assign \locvar{RPQR} the value zero.
+\item
+If \locvar{RPQR} is one, assign \locvar{\qtj} the value $(\locvar{\qti}-1)$
+ and assign \locvar{\plj} the value \locvar{\pli}.
+This selects the set of quant ranges defined for the same color plane as this
+ one, but for the previous quantization type.
+\item
+Else assign \locvar{\qtj} the value $(3*\locvar{\qti}+\locvar{\pli}-1)//3$ and
+ assign \locvar{\plj} the value $(\locvar{\pli}+2)\%3$.
+This selects the most recent set of quant ranges defined.
+\item
+Assign $\bitvar{NQRS}[\locvar{\qti}][\locvar{\pli}]$ the value
+ $\bitvar{NQRS}[\locvar{\qtj}][\locvar{\plj}]$.
+\item
+Assign $\bitvar{QRSIZES}[\locvar{\qti}][\locvar{\pli}]$ the values in 
+ $\bitvar{QRSIZES}[\locvar{\qtj}][\locvar{\plj}]$.
+\item
+Assign $\bitvar{QRBMIS}[\locvar{\qti}][\locvar{\pli}]$ the values in
+ $\bitvar{QRBMIS}[\locvar{\qtj}][\locvar{\plj}]$.
+\end{enumerate}
+\item
+Else, \locvar{NEWQR} is one, which indicates that we are defining a new set of
+ quant ranges.
+In that case:
+\begin{enumerate}
+\item
+Assign $\locvar{\qri}$ the value zero.
+\item
+Assign $\locvar{\qi}$ the value zero.
+\item
+Read an $\ilog(\bitvar{NBMS}-1)$-bit unsigned integer as\\
+ $\bitvar{QRBMIS}[\locvar{\qti}][\locvar{\pli}][\locvar{\qri}]$.
+If this is greater than or equal to \bitvar{NBMS}, stop.
+The stream is undecodable.
+\item
+\label{step:qr-loop}
+Read an $\ilog(62-\locvar{\qi})$-bit unsigned integer.
+Assign\\ $\bitvar{QRSIZES}[\locvar{\qti}][\locvar{\pli}][\locvar{\qri}]$ the value
+ read, plus one.
+\item
+Assign \locvar{\qi} the value $\locvar{\qi}+
+ \bitvar{QRSIZES}[\locvar{\qti}][\locvar{\pli}][\locvar{\qri}]$.
+\item
+Assign \locvar{\qri} the value $\locvar{\qri}+1$.
+\item
+Read an $\ilog(\bitvar{NBMS}-1)$-bit unsigned integer as\\
+ $\bitvar{QRBMIS}[\locvar{\qti}][\locvar{\pli}][\locvar{\qri}]$.
+\item
+If \locvar{\qi} is less than 63, go back to step~\ref{step:qr-loop}.
+\item
+If \locvar{\qi} is greater than 63, stop.
+The stream is undecodable.
+\item
+Assign $\bitvar{NQRS}[\locvar{\qti}][\locvar{\pli}]$ the value \locvar{\qri}.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+The quantization parameters are hardcoded in VP3.
+The values used are given in Appendix~\ref{app:vp3-quant-params}.
+
+\subsection{Computing a Quantization Matrix}
+\label{sub:quant-mat}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{ACSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No & A 64-element array of scale values for
+ AC coefficients for each \qi\ value. \\
+\bitvar{DCSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No & A 64-element array of scale values for
+ the DC coefficient for each \qi\ value. \\
+\bitvar{BMS}     & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              8 & No & A $\bitvar{NBMS}\times 64$ array
+ containing the base matrices. \\
+\bitvar{NQRS}    & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              6 & No & A $2\times 3$ array containing the
+ number of quant ranges for a given \qti\ and \pli, respectively.
+This is at most $63$. \\
+\bitvar{QRSIZES} & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              6 & No & A $2\times 3\times 63$ array of the
+ sizes of each quant range for a given \qti\ and \pli, respectively.
+Only the first $\bitvar{NQRS}[\qti][\pli]$ values are used. \\
+\bitvar{QRBMIS}  & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              9 & No & A $2\times 3\times 64$ array of the
+ \bmi's used for each quant range for a given \qti\ and \pli, respectively.
+Only the first $(\bitvar{NQRS}[\qti][\pli]+1)$ values are used. \\
+\bitvar{\qti}    & Integer &  1 & No & A quantization type index.
+See Table~\ref{tab:quant-types}.\\
+\bitvar{\pli}    & Integer &  2 & No & A color plane index.
+See Table~\ref{tab:color-planes}.\\
+\bitvar{\qi}     & Integer &  6 & No & The quantization index. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{QMAT} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No & A 64-element array of quantization
+ values for each DCT coefficient in natural order. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\ci}     & Integer &  6 & No & The DCT coefficient index. \\
+\locvar{\bmi}    & Integer &  9 & No & The base matrix index. \\
+\locvar{\bmj}    & Integer &  9 & No & The base matrix index. \\
+\locvar{\qri}    & Integer &  6 & No & The quant range index. \\
+\locvar{QISTART} & Integer &  6 & No & The left end-point of the \qi\ range. \\
+\locvar{QIEND  } & Integer &  6 & No & The right end-point of the \qi\ range. \\
+\locvar{BM}      & \multicolumn{1}{p{40pt}}{Integer array} &
+                              8 & No & A 64-element array containing the
+ interpolated base matrix. \\
+\locvar{QMIN}    & Integer & 16 & No & The minimum quantization value allowed
+ for the current coefficient. \\
+\locvar{QSCALE}  & Integer & 16 & No & The current scale value. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The following procedure can be used to generate a single quantization matrix
+ for a given quantization type, color plane, and \qi\ value, given the
+ quantization parameters decoded in Section~\ref{sub:quant-params}.
+
+Note that the product of the scale value and the base matrix value is in units
+ of $100$ths of a pixel value, and thus is divided by $100$ to return it to
+ units of a single pixel value.
+This value is then scaled by four, to match the scaling of the DCT output,
+ which is also a factor of four larger than the orthonormal version of the
+ transform.
+
+\begin{enumerate}
+\item
+Assign \locvar{\qri} the index of a quant range such that
+\begin{displaymath}
+\bitvar{\qi} \ge \sum_{\qrj=0}^{\locvar{\qri}-1}
+ \bitvar{QRSIZES}[\bitvar{\qti}][\bitvar{\pli}][\qrj],
+\end{displaymath}
+ and
+\begin{displaymath}
+\bitvar{\qi} \le \sum_{\qrj=0}^{\locvar{\qri}}
+ \bitvar{QRSIZES}[\bitvar{\qti}][\bitvar{\pli}][\qrj],
+\end{displaymath}
+ where summation from $0$ to $-1$ is defined to be zero.
+If there is more than one such value of $\locvar{\qri}$, i.e., if \bitvar{\qi}
+ lies on the boundary between two quant ranges, then the output will be the
+ same regardless of which one is chosen.
+\item
+Assign \locvar{QISTART} the value
+\begin{displaymath}
+\sum_{\qrj=0}^{\qri-1} \bitvar{QRSIZES}[\bitvar{\qti}][\bitvar{\pli}][\qrj].
+\end{displaymath}
+\item
+Assign \locvar{QIEND} the value
+\begin{displaymath}
+\sum_{\qrj=0}^{\qri} \bitvar{QRSIZES}[\bitvar{\qti}][\bitvar{\pli}][\qrj].
+\end{displaymath}
+\item
+Assign \locvar{\bmi} the value
+ $\bitvar{QRBMIS}[\bitvar{\qti}][\bitvar{\pli}][\qri]$.
+\item
+Assign \locvar{\bmj} the value
+ $\bitvar{QRBMIS}[\bitvar{\qti}][\bitvar{\pli}][\qri+1]$.
+\item
+For each consecutive value of \locvar{\ci} from $0$ to $63$, inclusive:
+\begin{enumerate}
+\item
+Assign $\locvar{BM}[\locvar{\ci}]$ the value
+\begin{displaymath}
+\begin{split}
+(&2*(\locvar{QIEND}-\bitvar{\qi})*\bitvar{BMS}[\locvar{\bmi}][\locvar{\ci}]\\
+ &+2*(\bitvar{\qi}-
+   \locvar{QISTART})*\bitvar{BMS}[\locvar{\bmj}][\locvar{\ci}]\\
+ &+\bitvar{QRSIZES}[\bitvar{\qti}][\bitvar{\pli}][\locvar{\qri}])//
+ (2*\bitvar{QRSIZES}[\bitvar{\qti}][\bitvar{\pli}][\locvar{\qri}])
+\end{split}
+\end{displaymath}
+\item
+Assign \locvar{QMIN} the value given by Table~\ref{tab:qmin} according to
+ \bitvar{\qti} and \locvar{\ci}.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{clr}\toprule
+Coefficient      & \multicolumn{1}{c}{\bitvar{\qti}}
+                               & \locvar{QMIN} \\\midrule
+$\locvar{\ci}=0$ & $0$ (Intra) & $16$          \\
+$\locvar{\ci}>0$ & $0$ (Intra) & $8$           \\
+$\locvar{\ci}=0$ & $1$ (Inter) & $32$          \\
+$\locvar{\ci}>0$ & $1$ (Inter) & $16$          \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Minimum Quantization Values}
+\label{tab:qmin}
+\end{table}
+
+\item
+If \locvar{\ci} equals zero, assign $\locvar{QSCALE}$ the value
+ $\bitvar{DCSCALE}[\bitvar{\qi}]$.
+\item
+Else, assign $\locvar{QSCALE}$ the value
+ $\bitvar{ACSCALE}[\bitvar{\qi}]$.
+\item
+Assign $\bitvar{QMAT}[\locvar{\ci}]$ the value
+\begin{displaymath}
+\max(\locvar{QMIN},
+ \min((\locvar{QSCALE}*\locvar{BM}[\locvar{\ci}]//100)*4,4096)).
+\end{displaymath}
+\end{enumerate}
+\end{enumerate}
+
+\subsection{DCT Token Huffman Tables}
+\label{sub:huffman-tables}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{HTS} & \multicolumn{3}{l}{Huffman table array}
+                                     & An 80-element array of Huffman tables
+ with up to 32 entries each. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{HBITS}   & Bit string & 32 & No & A string of up to 32 bits. \\
+\locvar{TOKEN}   & Integer    &  5 & No & A single DCT token value. \\
+\locvar{ISLEAF}  & Integer    &  1 & No & Flag that indicates if the current
+ node of the tree being decoded is a leaf node. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The Huffman tables used to decode DCT tokens are stored in the setup header in
+ the form of a binary tree.
+This enforces the requirements that the code be full---so that any sequence of
+ bits will produce a valid sequence of tokens---and that the code be
+ prefix-free so that there is no ambiguity when decoding.
+
+One more restriction is placed on the tables that is not explicitly enforced by
+ the bitstream syntax, but nevertheless must be obeyed by compliant encoders.
+There must be no more than 32 entries in a single table.
+Note that this restriction along with the fullness requirement limit the
+ maximum size of a single Huffman code to 32 bits.
+It is probably a good idea to enforce this latter consequence explicitly when
+ implementing the decoding procedure as a recursive algorithm, so as to prevent
+ a possible stack overflow given an invalid bitstream.
+
+Although there are 32 different DCT tokens, and thus a normal table will have
+ exactly 32 entries, this is not explicitly required.
+It is allowable to use a Huffman code that omits some---but not all---of the
+ possible token values.
+It is also allowable, if not particularly useful, to specify multiple codes for
+ the same token value in a single table.
+Note also that token values may appear in the tree in any order.
+In particular, it is not safe to assume that token value zero (which ends a
+ single block), has a Huffman code of all zeros.
+
+The tree is decoded as follows:
+
+\begin{enumerate}
+\item
+For each consecutive value of \locvar{\hti} from $0$ to $79$, inclusive:
+\begin{enumerate}
+\item
+Set \locvar{HBITS} to the empty string.
+\item
+\label{step:huff-tree-loop}
+If \locvar{HBITS} is longer than 32 bits in length, stop.
+The stream is undecodable.
+\item
+Read a 1-bit unsigned integer as \locvar{ISLEAF}.
+\item
+If \locvar{ISLEAF} is one:
+\begin{enumerate}
+\item
+If the number of entries in table $\bitvar{HTS}[\locvar{\hti}]$ is already 32,
+ stop.
+The stream is undecodable.
+\item
+Read a 5-bit unsigned integer as \locvar{TOKEN}.
+\item
+Add the pair $(\locvar{HBITS},\locvar{TOKEN})$ to Huffman table
+ $\bitvar{HTS}[\locvar{\hti}]$.
+\end{enumerate}
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Add a `0' to the end of \locvar{HBITS}.
+\item
+Decode the `0' sub-tree using this procedure, starting from
+ step~\ref{step:huff-tree-loop}.
+\item
+Remove the `0' from the end of \locvar{HBITS} and add a `1' to the end of
+ \locvar{HBITS}.
+\item
+Decode the `1' sub-tree using this procedure, starting from
+ step~\ref{step:huff-tree-loop}.
+\item
+Remove the `1' from the end of \locvar{HBITS}.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+The DCT token Huffman tables are hardcoded in VP3.
+The values used are given in Appendix~\ref{app:vp3-huffman-tables}.
+
+\subsection{Setup Header Decode}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{LFLIMS}  & \multicolumn{1}{p{40pt}}{Integer array} &
+                              7 & No & A 64-element array of loop filter limit
+ values. \\
+\bitvar{ACSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No & A 64-element array of scale values for
+ AC coefficients for each \qi\ value. \\
+\bitvar{DCSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No & A 64-element array of scale values for
+ the DC coefficient for each \qi\ value. \\
+\bitvar{NBMS}    & Integer & 10 & No & The number of base matrices. \\
+\bitvar{BMS}     & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              8 & No & A $\bitvar{NBMS}\times 64$ array
+ containing the base matrices. \\
+\bitvar{NQRS}    & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              6 & No & A $2\times 3$ array containing the
+ number of quant ranges for a given \qti\ and \pli, respectively.
+This is at most $63$. \\
+\bitvar{QRSIZES} & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              6 & No & A $2\times 3\times 63$ array of the
+ sizes of each quant range for a given \qti\ and \pli, respectively.
+Only the first $\bitvar{NQRS}[\qti][\pli]$ values will be used. \\
+\bitvar{QRBMIS}  & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              9 & No & A $2\times 3\times 64$ array of the
+ \bmi's used for each quant range for a given \qti\ and \pli, respectively.
+Only the first $(\bitvar{NQRS}[\qti][\pli]+1)$ values will be used. \\
+\bitvar{HTS} & \multicolumn{3}{l}{Huffman table array}
+                                     & An 80-element array of Huffman tables
+ with up to 32 entries each. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:} None.
+\medskip
+
+The complete setup header is decoded as follows:
+
+\begin{enumerate}
+\item
+Decode the common header fields according to the procedure described in
+ Section~\ref{sub:common-header}.
+If \bitvar{HEADERTYPE} returned by this procedure is not \hex{82}, then stop.
+This packet is not the setup header.
+\item
+Decode the loop filter limit value table using the procedure given in
+ Section~\ref{sub:loop-filter-limits} into \bitvar{LFLIMS}.
+\item
+Decode the quantization parameters using the procedure given in
+ Section~\ref{sub:quant-params}.
+The results are stored in \bitvar{ACSCALE}, \bitvar{DCSCALE}, \bitvar{NBMS},
+ \bitvar{BMS}, \bitvar{NQRS}, \bitvar{QRSIZES}, and \bitvar{QRBMIS}.
+\item
+Decode the DCT token Huffman tables using the procedure given in
+ Section~\ref{sub:huffman-tables} into \bitvar{HTS}.
+\end{enumerate}
+
+\chapter{Frame Decode}
+
+This section describes the complete procedure necessary to decode a single
+ frame.
+This begins with the frame header, followed by coded block flags, macro block
+ modes, motion vectors, block-level \qi\ values, and finally the DCT residual
+ tokens, which are used to reconstruct the frame.
+
+\section{Frame Header Decode}
+\label{sub:frame-header}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{FTYPE}   & Integer &  1 & No & The frame type. \\
+\bitvar{NQIS}    & Integer &  2 & No & The number of \qi\ values. \\
+\bitvar{QIS}     & \multicolumn{1}{p{40pt}}{Integer array} &
+                             6 & No & An \bitvar{NQIS}-element array of
+ \qi\ values. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{MOREQIS} & Integer &  1 & No & A flag indicating there are more
+ \qi\ values to be decoded. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The frame header selects which type of frame is being decoded, intra or inter,
+ and contains the list of \qi\ values that will be used in this frame.
+The first \qi\ value will be used for {\em all} DC coefficients in all blocks.
+This is done to ensure that DC prediction, which is done in the quantized
+ domain, works as expected.
+The AC coefficients, however, can be dequantized using any \qi\ value on the
+ list, selected on a block-by-block basis.
+
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer.
+If the value read is not zero, stop.
+This is not a data packet.
+\item
+Read a 1-bit unsigned integer as \bitvar{FTYPE}.
+This is the type of frame being decoded, as given in
+ Table~\ref{tab:frame-type}.
+If this is the first frame being decoded, this MUST be zero.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{cl}\toprule
+\bitvar{FTYPE} & Frame Type  \\\midrule
+$0$            & Intra frame \\
+$1$            & Inter frame \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Frame Type Values}
+\label{tab:frame-type}
+\end{table}
+
+\item
+Read in a 6-bit unsigned integer as $\bitvar{QIS}[0]$.
+\item
+Read a 1-bit unsigned integer as \locvar{MOREQIS}.
+\item
+If \locvar{MOREQIS} is zero, set \bitvar{NQIS} to 1.
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Read in a 6-bit unsigned integer as $\bitvar{QIS}[1]$.
+\item
+Read a 1-bit unsigned integer as \locvar{MOREQIS}.
+\item
+If \locvar{MOREQIS} is zero, set \bitvar{NQIS} to 2.
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Read in a 6-bit unsigned integer as $\bitvar{QIS}[2]$.
+\item
+Set \bitvar{NQIS} to 3.
+\end{enumerate}
+\end{enumerate}
+\item
+If \bitvar{FTYPE} is 0, read a 3-bit unsigned integer.
+These bits are reserved.
+If this value is not zero, stop.
+This frame is not decodable according to this specification.
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+The precise format of the frame header is substantially different in Theora
+ than in VP3.
+The original VP3 format includes a larger number of unused, reserved bits that
+ are required to be zero.
+The original VP3 frame header also can contain only a single \qi\ value,
+ because VP3 does not support block-level \qi\ values and uses the same
+ \qi\ value for all the coefficients in a frame.
+
+\section{Run-Length Encoded Bit Strings}
+
+Two variations of run-length encoding are used to store sequences of bits for
+ the block coded flags and the block-level \qi\ values.
+The procedures to decode these bit sequences are specified in the following two
+ sections.
+
+\subsection{Long-Run Bit String Decode}
+\label{sub:long-run}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{NBITS}   & Integer & 36 & No & The number of bits to decode. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{BITS}    & Bit string &    &    & The decoded bits. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{LEN}    & Integer & 36 & No & The number of bits decoded so far. \\
+\locvar{BIT}    & Integer &  1 & No & The value associated with the current
+ run. \\
+\locvar{RLEN}   & Integer & 13 & No & The length of the current run. \\
+\locvar{RBITS}  & Integer &  4 & No & The number of extra bits needed to
+ decode the run length. \\
+\locvar{RSTART} & Integer &  6 & No & The start of the possible run-length
+ values for a given Huffman code. \\
+\locvar{ROFFS}  & Integer & 12 & No & The offset from \locvar{RSTART} of the
+ run-length. \\
+\bottomrule\end{tabularx}
+\medskip
+
+There is no practical limit to the number of consecutive 0's and 1's that can
+ be decoded with this procedure.
+In reality, the run length is limited by the number of blocks in a single
+ frame, because more will never be requested.
+A separate procedure described in Section~\ref{sub:short-run} is used when
+ there is a known limit on the maximum size of the runs.
+
+For the first run, a single bit value is read, and then a Huffman-coded
+ representation of a run length is decoded, and that many copies of the bit
+ value are appended to the bit string.
+For each consecutive run, the value of the bit is toggled instead of being read
+ from the bitstream.
+
+The only exception is if the length of the previous run was 4129, the maximum
+ possible length encodable by the Huffman-coded representation.
+In this case another bit value is read from the stream, to allow for
+ consecutive runs of 0's or 1's longer than this maximum.
+
+Note that in both cases---for the first run and after a run of length 4129---if
+ no more bits are needed, then no bit value is read.
+
+The complete decoding procedure is as follows:
+
+\begin{enumerate}
+\item
+Assign \locvar{LEN} the value 0.
+\item
+Assign \bitvar{BITS} the empty string.
+\item
+If \locvar{LEN} equals \bitvar{NBITS}, return the completely decoded string
+ \bitvar{BITS}.
+\item
+Read a 1-bit unsigned integer as \locvar{BIT}.
+\item
+\label{step:long-run-loop}
+Read a bit at a time until one of the Huffman codes given in
+ Table~\ref{tab:long-run} is recognized.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{lrrl}\toprule
+Huffman Code & \locvar{RSTART} & \locvar{RBITS} & Run Lengths     \\\midrule
+\bin{0}      & $1$             & $0$            & $1$             \\
+\bin{10}     & $2$             & $1$            & $2\ldots 3$     \\
+\bin{110}    & $4$             & $1$            & $4\ldots 5$     \\
+\bin{1110}   & $6$             & $2$            & $6\ldots 9$     \\
+\bin{11110}  & $10$            & $3$            & $10\ldots 17$   \\
+\bin{111110} & $18$            & $4$            & $18\ldots 33$   \\
+\bin{111111} & $34$            & $12$           & $34\ldots 4129$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Huffman Codes for Long Run Lengths}
+\label{tab:long-run}
+\end{table}
+
+\item
+Assign \locvar{RSTART} and \locvar{RBITS} the values given in
+ Table~\ref{tab:long-run} according to the Huffman code read.
+\item
+Read an \locvar{RBITS}-bit unsigned integer as \locvar{ROFFS}.
+\item
+Assign \locvar{RLEN} the value $(\locvar{RSTART}+\locvar{ROFFS})$.
+\item
+Append \locvar{RLEN} copies of \locvar{BIT} to \bitvar{BITS}.
+\item
+Add \locvar{RLEN} to the value \locvar{LEN}.
+\locvar{LEN} MUST be less than or equal to \bitvar{NBITS}.
+\item
+If \locvar{LEN} equals \bitvar{NBITS}, return the completely decoded string
+ \bitvar{BITS}.
+\item
+If \locvar{RLEN} equals 4129, read a 1-bit unsigned integer as \locvar{BIT}.
+\item
+Otherwise, assign \locvar{BIT} the value $(1-\locvar{BIT})$.
+\item
+Continue decoding runs from step~\ref{step:long-run-loop}.
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+VP3 does not read a new bit value after decoding a run length of 4129.
+This limits the maximum number of consecutive 0's or 1's to 4129 in
+ VP3-compatible streams.
+For reasonable video sizes of $1920\times 1080$ or less in 4:2:0 format---the
+ only pixel format VP3 supports---this does not pose any problems because runs
+ longer than 4129 are not needed.
+
+\subsection{Short-Run Bit String Decode}
+\label{sub:short-run}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{NBITS}   & Integer & 36 & No & The number of bits to decode. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{BITS}    & Bit string &    &    & The decoded bits. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{LEN}    & Integer & 36 & No & The number of bits decoded so far. \\
+\locvar{BIT}    & Integer &  1 & No & The value associated with the current
+ run. \\
+\locvar{RLEN}   & Integer & 13 & No & The length of the current run. \\
+\locvar{RBITS}  & Integer &  4 & No & The number of extra bits needed to
+ decode the run length. \\
+\locvar{RSTART} & Integer &  6 & No & The start of the possible run-length
+ values for a given Huffman code. \\
+\locvar{ROFFS}  & Integer & 12 & No & The offset from \locvar{RSTART} of the
+ run-length. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure is similar to the procedure outlined in
+ Section~\ref{sub:long-run}, except that the maximum number of consecutive 0's
+ or 1's is limited to 30.
+This is the maximum run length needed when encoding a bit for each of the 16
+ blocks in a super block when it is known that not all the bits in a super
+ block are the same.
+
+The complete decoding procedure is as follows:
+
+\begin{enumerate}
+\item
+Assign \locvar{LEN} the value 0.
+\item
+Assign \bitvar{BITS} the empty string.
+\item
+If \locvar{LEN} equals \bitvar{NBITS}, return the completely decoded string
+ \bitvar{BITS}.
+\item
+Read a 1-bit unsigned integer as \locvar{BIT}.
+\item
+\label{step:short-run-loop}
+Read a bit at a time until one of the Huffman codes given in
+ Table~\ref{tab:short-run} is recognized.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{lrrl}\toprule
+Huffman Code & \locvar{RSTART} & \locvar{RBITS} & Run Lengths   \\\midrule
+\bin{0}      & $1$             & $1$            & $1\ldots 2$   \\
+\bin{10}     & $3$             & $1$            & $3\ldots 4$   \\
+\bin{110}    & $5$             & $1$            & $5\ldots 6$   \\
+\bin{1110}   & $7$             & $2$            & $7\ldots 10$  \\
+\bin{11110}  & $11$            & $2$            & $11\ldots 14$ \\
+\bin{11111}  & $15$            & $4$            & $15\ldots 30$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Huffman Codes for Short Run Lengths}
+\label{tab:short-run}
+\end{table}
+
+\item
+Assign \locvar{RSTART} and \locvar{RBITS} the values given in
+ Table~\ref{tab:short-run} according to the Huffman code read.
+\item
+Read an \locvar{RBITS}-bit unsigned integer as \locvar{ROFFS}.
+\item
+Assign \locvar{RLEN} the value $(\locvar{RSTART}+\locvar{ROFFS})$.
+\item
+Append \locvar{RLEN} copies of \locvar{BIT} to \bitvar{BITS}.
+\item
+Add \locvar{RLEN} to the value \locvar{LEN}.
+\locvar{LEN} MUST be less than or equal to \bitvar{NBITS}.
+\item
+If \locvar{LEN} equals \bitvar{NBITS}, return the completely decoded string
+ \bitvar{BITS}.
+\item
+Assign \locvar{BIT} the value $(1-\locvar{BIT})$.
+\item
+Continue decoding runs from step~\ref{step:short-run-loop}.
+\end{enumerate}
+
+\section{Coded Block Flags Decode}
+\label{sub:coded-blocks}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{FTYPE}   & Integer &  1 & No & The frame type. \\
+\bitvar{NSBS}    & Integer & 32 & No & The total number of super blocks in a
+ frame. \\
+\bitvar{NBS}     & Integer & 36 & No & The total number of blocks in a
+ frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{BCODED}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{NBITS}    & Integer & 36 & No & The length of a bit string to decode. \\
+\locvar{BITS}     & Bit string & &    & A decoded set of flags. \\
+\locvar{SBPCODED} & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No & An \bitvar{NSBS}-element array of flags
+ indicating whether or not each super block is partially coded. \\
+\locvar{SBFCODED} & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No & An \bitvar{NSBS}-element array of flags
+ indicating whether or not each non-partially coded super block is fully
+ coded. \\
+\locvar{\sbi}     & Integer & 32 & No & The index of the current super
+ block. \\
+\locvar{\bi}      & Integer & 36 & No & The index of the current block in coded
+ order. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure determines which blocks are coded in a given frame.
+In an intra frame, it marks all blocks coded.
+In an inter frame, however, any or all of the blocks may remain uncoded.
+The output is a list of bit flags, one for each block, marking it coded or not
+ coded.
+
+It is important to note that flags are still decoded for any blocks which lie
+ entirely outside the picture region, even though they are not displayed.
+Encoders MAY choose to code such blocks.
+Decoders MUST faithfully reconstruct such blocks, because their contents can be
+ used for predictors in future frames.
+Flags are \textit{not} decoded for portions of a super block which lie outside
+ the full frame, as there are no blocks in those regions.
+
+The complete procedure is as follows:
+
+\begin{enumerate}
+\item
+If \bitvar{FTYPE} is zero (intra frame):
+\begin{enumerate}
+\item
+For each consecutive value of \locvar{\bi} from 0 to $(\locvar{NBS}-1)$, assign
+ $\bitvar{BCODED}[\locvar{\bi}]$ the value one.
+\end{enumerate}
+\item
+Otherwise (inter frame):
+\begin{enumerate}
+\item
+Assign \locvar{NBITS} the value \bitvar{NSBS}.
+\item
+Read an \locvar{NBITS}-bit bit string into \locvar{BITS}, using the procedure
+ described in Section~\ref{sub:long-run}.
+This represents the list of partially coded super blocks.
+\item
+For each consecutive value of \locvar{\sbi} from 0 to $(\locvar{NSBS}-1)$,
+ remove the bit at the head of the string \locvar{BITS} and assign it to
+ $\locvar{SBPCODED}[\locvar{\sbi}]$.
+\item
+Assign \locvar{NBITS} the total number of super blocks such that \\
+ $\locvar{SBPCODED}[\locvar{\sbi}]$ equals zero.
+\item
+Read an \locvar{NBITS}-bit bit string into \locvar{BITS}, using the procedure
+ described in Section~\ref{sub:long-run}.
+This represents the list of fully coded super blocks.
+\item
+For each consecutive value of \locvar{\sbi} from 0 to $(\locvar{NSBS}-1)$ such
+ that $\locvar{SBPCODED}[\locvar{\sbi}]$ equals zero, remove the bit at the
+ head of the string \locvar{BITS} and assign it to
+ $\locvar{SBFCODED}[\locvar{\sbi}]$.
+\item
+Assign \locvar{NBITS} the number of blocks contained in super blocks where
+ $\locvar{SBPCODED}[\locvar{\sbi}]$ equals one.
+Note that this might {\em not} be equal to 16 times the number of partially
+ coded super blocks, since super blocks which overlap the edge of the frame
+ will have fewer than 16 blocks in them.
+\item
+Read an \locvar{NBITS}-bit bit string into \locvar{BITS}, using the procedure
+ described in Section~\ref{sub:short-run}.
+\item
+For each block in coded order---indexed by \locvar{\bi}:
+\begin{enumerate}
+\item
+Assign \locvar{\sbi} the index of the super block containing block
+ \locvar{\bi}.
+\item
+If $\locvar{SBPCODED}[\locvar{\sbi}]$ is zero, assign
+ $\bitvar{BCODED}[\locvar{\bi}]$ the value $\locvar{SBFCODED}[\locvar{\sbi}]$.
+\item
+Otherwise, remove the bit at the head of the string \locvar{BITS} and assign it
+ to $\bitvar{BCODED}[\locvar{\bi}]$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\section{Macro Block Coding Modes}
+\label{sub:mb-modes}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{FTYPE}    & Integer &  1 & No & The frame type. \\
+\bitvar{NMBS}     & Integer & 32 & No & The total number of macro blocks in a
+ frame. \\
+\bitvar{NBS}      & Integer & 36 & No & The total number of blocks in a
+ frame. \\
+\bitvar{BCODED}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              1 & No & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{MBMODES} & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              3 & No & An \bitvar{NMBS}-element array of coding
+ modes for each macro block. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{MSCHEME}   & Integer &  3 & No & The mode coding scheme. \\
+\locvar{MALPHABET} & \multicolumn{1}{p{40pt}}{Integer array}
+                             &  3 & No & The list of modes corresponding to each
+ Huffman code. \\
+\locvar{\mbi}      & Integer & 32 & No & The index of the current macro
+ block. \\
+\locvar{\bi}       & Integer & 36 & No & The index of the current block in
+ coded order. \\
+\locvar{\mi}       & Integer &  3 & No & The index of a Huffman code from
+ Table~\ref{tab:mode-codes}, starting from $0$. \\
+\bottomrule\end{tabularx}
+\medskip
+
+In an intra frame, every macro block marked as coded in INTRA mode.
+In an inter frame, however, a macro block can be coded in one of eight coding
+ modes, given in Table~\ref{tab:coding-modes}.
+All of the blocks in all color planes contained in a macro block will be
+ assigned the coding mode of that macro block.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{cl}\toprule
+Index & Coding Mode \\\midrule
+$0$   & INTER\_NOMV         \\
+$1$   & INTRA               \\
+$2$   & INTER\_MV           \\
+$3$   & INTER\_MV\_LAST     \\
+$4$   & INTER\_MV\_LAST2    \\
+$5$   & INTER\_GOLDEN\_NOMV \\
+$6$   & INTER\_GOLDEN\_MV   \\
+$7$   & INTER\_MV\_FOUR     \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Macro Block Coding Modes}
+\label{tab:coding-modes}
+\end{table}
+
+An important thing to note is that a coding mode is only stored in the
+ bitstream for a macro block if it has at least one {\em luma} block coded.
+A macro block that contains coded blocks in the chroma planes, but not in the
+ luma plane, MUST be coded in INTER\_NOMV mode.
+Thus, no coding mode needs to be decoded for such a macro block.
+
+Coding modes are encoded using one of eight different schemes.
+Schemes 0 through 6 use the same simple Huffman code to represent the mode
+ numbers, as given in Table~\ref{tab:mode-codes}.
+The difference in the schemes is the mode number assigned to each code.
+Scheme 0 uses an assignment specified in the bitstream, while schemes 1--6 use
+ a fixed assignment, also given in Table~\ref{tab:mode-codes}.
+Scheme 7 simply codes each mode directly in the bitstream using three bits.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{lccccccc}\toprule
+Scheme        & $1$ & $2$ & $3$ & $4$ & $5$ & $6$ & $7$ \\\cmidrule{2-7}
+Huffman Code  & \multicolumn{6}{c}{Coding Mode}   & \locvar{\mi} \\\midrule
+\bin{0}       & $3$ & $3$ & $3$ & $3$ & $0$ & $0$ & $0$ \\
+\bin{10}      & $4$ & $4$ & $2$ & $2$ & $3$ & $5$ & $1$ \\
+\bin{110}     & $2$ & $0$ & $4$ & $0$ & $4$ & $3$ & $2$ \\
+\bin{1110}    & $0$ & $2$ & $0$ & $4$ & $2$ & $4$ & $3$ \\
+\bin{11110}   & $1$ & $1$ & $1$ & $1$ & $1$ & $2$ & $4$ \\
+\bin{111110}  & $5$ & $5$ & $5$ & $5$ & $5$ & $1$ & $5$ \\
+\bin{1111110} & $6$ & $6$ & $6$ & $6$ & $6$ & $6$ & $6$ \\
+\bin{1111111} & $7$ & $7$ & $7$ & $7$ & $7$ & $7$ & $7$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Macro Block Mode Schemes}
+\label{tab:mode-codes}
+\end{table}
+
+\begin{enumerate}
+\item
+If \bitvar{FTYPE} is 0 (intra frame):
+\begin{enumerate}
+\item
+For each consecutive value of \locvar{\mbi} from 0 to $(\bitvar{NMBS}-1)$,
+ inclusive, assign $\bitvar{MBMODES}[\mbi]$ the value 1 (INTRA).
+\end{enumerate}
+\item
+Otherwise (inter frame):
+\begin{enumerate}
+\item
+Read a 3-bit unsigned integer as \locvar{MSCHEME}.
+\item
+If \locvar{MSCHEME} is 0:
+\begin{enumerate}
+\item
+For each consecutive value of \locvar{MODE} from 0 to 7, inclusive:
+\begin{enumerate}
+\item
+Read a 3-bit unsigned integer as \locvar{\mi}.
+\item
+Assign $\locvar{MALPHABET}[\mi]$ the value \locvar{MODE}.
+\end{enumerate}
+\end{enumerate}
+\item
+Otherwise, if \locvar{MSCHEME} is not 7, assign the entries of
+ \locvar{MALPHABET} the values in the corresponding column of
+ Table~\ref{tab:mode-codes}.
+\item
+For each consecutive macro block in coded order (cf.
+ Section~\ref{sec:mbs})---indexed by \locvar{\mbi}:
+\begin{enumerate}
+\item
+If a block \locvar{\bi} in the luma plane of macro block \locvar{\mbi} exists
+ such that $\bitvar{BCODED}[\locvar{\bi}]$ is 1:
+\begin{enumerate}
+\item
+If \locvar{MSCHEME} is not 7, read one bit at a time until one of the Huffman
+ codes in Table~\ref{tab:mode-codes} is recognized, and assign
+ $\bitvar{MBMODES}[\locvar{\mbi}]$ the value
+ $\locvar{MALPHABET}[\locvar{\mi}]$, where \locvar{\mi} is the index of the
+ Huffman code decoded.
+\item
+Otherwise, read a 3-bit unsigned integer as $\bitvar{MBMODES}[\locvar{\mbi}]$.
+\end{enumerate}
+\item
+Otherwise, if no luma-plane blocks in the macro block are coded, assign
+ $\bitvar{MBMODES}[\locvar{\mbi}]$ the value 0 (INTER\_NOMV).
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\section{Motion Vectors}
+
+In an intra frame, no motion vectors are used, and so motion vector decoding is
+ skipped.
+In an inter frame, however, many of the inter coding modes require a motion
+ vector in order to specify an offset into the reference frame from which to
+ predict a block.
+These procedures assigns such a motion vector to every block.
+
+\subsection{Motion Vector Decode}
+\label{sub:mv-decode}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{MVMODE}   & Integer &  1 & No & The motion vector decoding method. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{MVX}      & Integer &  6 & Yes & The X component of the motion
+ vector. \\
+\bitvar{MVY}      & Integer &  6 & Yes & The Y component of the motion
+ vector. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{MVSIGN}   & Integer &  1 & No & The sign of the motion vector component
+ just decoded. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The individual components of a motion vector can be coded using one of two
+ methods.
+The first uses a variable length Huffman code, given in
+ Table~\ref{tab:mv-huff-codes}.
+The second encodes the magnitude of the component directly in 5 bits, and the
+ sign in one bit.
+Note that in this case there are two representations for the value zero.
+For compatibility with VP3, a sign bit is read even if the magnitude read is
+ zero.
+One scheme is chosen and used for the entire frame.
+
+Each component can take on integer values from $-31\ldots 31$, inclusive, at
+ half-pixel resolution, i.e. $-15.5\ldots 15.5$ pixels in the luma plane.
+For each subsampled axis in the chroma planes, the corresponding motion vector
+ component is interpreted as being at quarter-pixel resolution, i.e.
+ $-7.75\ldots 7.75$ pixels.
+The precise details of how these vectors are used to compute predictors for
+ each block are described in Section~\ref{sec:predictors}.
+
+\begin{table}[ht]
+\begin{center}
+\begin{tabular}{lrlr}\toprule
+Huffman Code   & Value & Huffman Code   & Value \\\midrule
+\bin{000}      & $0$   \\
+\bin{001}      & $1$   & \bin{010}      & $-1$  \\
+\bin{0110}     & $2$   & \bin{0111}     & $-2$  \\
+\bin{1000}     & $3$   & \bin{1001}     & $-3$  \\
+\bin{101000}   & $4$   & \bin{101001}   & $-4$  \\
+\bin{101010}   & $5$   & \bin{101011}   & $-5$  \\
+\bin{101100}   & $6$   & \bin{101101}   & $-6$  \\
+\bin{101110}   & $7$   & \bin{101111}   & $-7$  \\
+\bin{1100000}  & $8$   & \bin{1100001}  & $-8$  \\
+\bin{1100010}  & $9$   & \bin{1100011}  & $-9$  \\
+\bin{1100100}  & $10$  & \bin{1100101}  & $-10$ \\
+\bin{1100110}  & $11$  & \bin{1100111}  & $-11$ \\
+\bin{1101000}  & $12$  & \bin{1101001}  & $-12$ \\
+\bin{1101010}  & $13$  & \bin{1101011}  & $-13$ \\
+\bin{1101100}  & $14$  & \bin{1101101}  & $-14$ \\
+\bin{1101110}  & $15$  & \bin{1101111}  & $-15$ \\
+\bin{11100000} & $16$  & \bin{11100001} & $-16$ \\
+\bin{11100010} & $17$  & \bin{11100011} & $-17$ \\
+\bin{11100100} & $18$  & \bin{11100101} & $-18$ \\
+\bin{11100110} & $19$  & \bin{11100111} & $-19$ \\
+\bin{11101000} & $20$  & \bin{11101001} & $-20$ \\
+\bin{11101010} & $21$  & \bin{11101011} & $-21$ \\
+\bin{11101100} & $22$  & \bin{11101101} & $-22$ \\
+\bin{11101110} & $23$  & \bin{11101111} & $-23$ \\
+\bin{11110000} & $24$  & \bin{11110001} & $-24$ \\
+\bin{11110010} & $25$  & \bin{11110011} & $-25$ \\
+\bin{11110100} & $26$  & \bin{11110101} & $-26$ \\
+\bin{11110110} & $27$  & \bin{11110111} & $-27$ \\
+\bin{11111000} & $28$  & \bin{11111001} & $-28$ \\
+\bin{11111010} & $29$  & \bin{11111011} & $-29$ \\
+\bin{11111100} & $30$  & \bin{11111101} & $-30$ \\
+\bin{11111110} & $31$  & \bin{11111111} & $-31$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Huffman Codes for Motion Vector Components}
+\label{tab:mv-huff-codes}
+\end{table}
+
+A single motion vector is decoded is follows:
+
+\begin{enumerate}
+\item
+If \bitvar{MVMODE} is 0:
+\begin{enumerate}
+\item
+Read 1 bit at a time until one of the Huffman codes in
+ Table~\ref{tab:mv-huff-codes} is recognized, and assign the value to
+ \locvar{MVX}.
+\item
+Read 1 bit at a time until one of the Huffman codes in
+ Table~\ref{tab:mv-huff-codes} is recognized, and assign the value to
+ \locvar{MVY}.
+\end{enumerate}
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Read a 5-bit unsigned integer as \bitvar{MVX}.
+\item
+Read a 1-bit unsigned integer as \locvar{MVSIGN}.
+\item
+If \locvar{MVSIGN} is 1, assign \bitvar{MVX} the value $-\bitvar{MVX}$.
+\item
+Read a 5-bit unsigned integer as \bitvar{MVY}.
+\item
+Read a 1-bit unsigned integer as \locvar{MVSIGN}.
+\item
+If \locvar{MVSIGN} is 1, assign \bitvar{MVY} the value $-\bitvar{MVY}$.
+\end{enumerate}
+\end{enumerate}
+
+\subsection{Macro Block Motion Vector Decode}
+\label{sub:mb-mv-decode}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{PF}      & Integer &  2 & No & The pixel format. \\
+\bitvar{NMBS}    & Integer & 32 & No & The total number of macro blocks in a
+ frame. \\
+\bitvar{MBMODES} & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              3 & No & An \bitvar{NMBS}-element array of coding
+ modes for each macro block. \\
+\bitvar{NBS}      & Integer & 36 & No & The total number of blocks in a
+ frame. \\
+\bitvar{BCODED}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              1 & No & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{MVECTS}   & \multicolumn{1}{p{50pt}}{Array of 2D Integer Vectors} &
+                               6 & Yes & An \bitvar{NBS}-element array of
+ motion vectors for each block. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{LAST1}    & \multicolumn{1}{p{50pt}}{2D Integer Vector} &
+                               6 & Yes & The last motion vector. \\
+\locvar{LAST2}    & \multicolumn{1}{p{50pt}}{2D Integer Vector} &
+                               6 & Yes & The second to last motion vector. \\
+\locvar{MVX}      & Integer &  6 & Yes & The X component of a motion vector. \\
+\locvar{MVY}      & Integer &  6 & Yes & The Y component of a motion vector. \\
+\locvar{\mbi}     & Integer & 32 &  No & The index of the current macro
+ block. \\
+\locvar{A}        & Integer & 36 &  No & The index of the lower-left luma block
+ in the macro block. \\
+\locvar{B}        & Integer & 36 &  No & The index of the lower-right luma
+ block in the macro block. \\
+\locvar{C}        & Integer & 36 &  No & The index of the upper-left luma block
+ in the macro block. \\
+\locvar{D}        & Integer & 36 &  No & The index of the upper-right luma
+ block in the macro block. \\
+\locvar{E}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\locvar{F}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\locvar{G}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\locvar{H}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\locvar{I}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\locvar{J}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\locvar{K}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\locvar{L}        & Integer & 36 &  No & The index of a chroma block in the
+ macro block, depending on the pixel format. \\
+\bottomrule\end{tabularx}
+\medskip
+
+Motion vectors are stored for each macro block.
+In every mode except for INTER\_MV\_FOUR, every block in all the color planes
+ are assigned the same motion vector.
+In INTER\_MV\_FOUR mode, all four blocks in the luma plane are assigned their
+ own motion vector, and motion vectors for blocks in the chroma planes are
+ computed from these, using averaging appropriate to the pixel format.
+
+For INTER\_MV and INTER\_GOLDEN\_MV modes, a single motion vector is decoded
+ and applied to each block.
+For INTER\_MV\_FOUR macro blocks, a motion vector is decoded for each coded
+ luma block.
+Uncoded luma blocks receive the default $(0,0)$ vector for the purposes of
+ computing the chroma motion vectors.
+
+None of the remaining macro block coding modes require decoding motion vectors
+ from the stream.
+INTRA mode does not use a motion-compensated predictor, and so requires no
+ motion vector, and INTER\_NOMV and INTER\_GOLDEN\_NOMV modes use the default
+ vector $(0,0)$ for each block.
+This also includes all macro blocks with no coded luma blocks, as they are
+ coded in INTER\_NOMV mode by definition.
+
+The modes INTER\_MV\_LAST and INTER\_MV\_LAST2 use the motion vector from the
+ last macro block (in coded order) and the second to last macro block,
+ respectively, that contained a motion vector pointing to the previous frame.
+Thus no explicit motion vector needs to be decoded for these modes.
+Macro blocks coded in INTRA mode or one of the GOLDEN modes are not considered
+ in this process.
+If an insufficient number of macro blocks have been coded in one of the INTER
+ modes, then the $(0,0)$ vector is used instead.
+For macro blocks coded in INTER\_MV\_FOUR mode, the vector from the upper-right
+ luma block is used, even if the upper-right block is not coded.
+
+The motion vectors are decoded from the stream as follows:
+
+\begin{enumerate}
+\item
+Assign \locvar{LAST1} and \locvar{LAST2} both the value $(0,0)$.
+\item
+Read a 1-bit unsigned integer as \locvar{MVMODE}.
+Note that this value is read even if no macro blocks require a motion vector to
+ be decoded.
+\item
+For each consecutive value of \locvar{\mbi} from 0 to $(\bitvar{NMBS}-1)$:
+\begin{enumerate}
+\item
+If $\bitvar{MBMODES}[\locvar{\mbi}]$ is 7 (INTER\_MV\_FOUR):
+\begin{enumerate}
+\item
+Let \locvar{A}, \locvar{B}, \locvar{C}, and \locvar{D} be the indices in coded
+ order \locvar{\bi} of the luma blocks in macro block \locvar{\mbi}, arranged
+ into raster order.
+Thus, \locvar{A} is the index in coded order of the block in the lower left,
+ \locvar{B} the lower right, \locvar{C} the upper left, and \locvar{D} the
+ upper right. % TODO: as shown in Figure~REF.
+\item If $\bitvar{BCODED}[\locvar{A}]$ is non-zero:
+\begin{enumerate}
+\item Decode a single motion vector into \locvar{MVX} and \locvar{MVY} using
+ the procedure described in Section~\ref{sub:mv-decode}.
+\item Assign $\bitvar{MVECTS}[\locvar{A}]$ the value
+ $(\locvar{MVX},\locvar{MVY})$.
+\end{enumerate}
+\item Otherwise, assign $\bitvar{MVECTS}[\locvar{A}]$ the value $(0,0)$.
+\item If $\bitvar{BCODED}[\locvar{B}]$ is non-zero:
+\begin{enumerate}
+\item Decode a single motion vector into \locvar{MVX} and \locvar{MVY} using
+ the procedure described in Section~\ref{sub:mv-decode}.
+\item Assign $\bitvar{MVECTS}[\locvar{B}]$ the value
+ $(\locvar{MVX},\locvar{MVY})$.
+\end{enumerate}
+\item
+Otherwise assign $\bitvar{MVECTS}[\locvar{B}]$ the value $(0,0)$.
+\item If $\bitvar{BCODED}[\locvar{C}]$ is non-zero:
+\begin{enumerate}
+\item Decode a single motion vector into \locvar{MVX} and \locvar{MVY} using
+ the procedure described in Section~\ref{sub:mv-decode}.
+\item Assign $\bitvar{MVECTS}[\locvar{C}]$ the value
+ $(\locvar{MVX},\locvar{MVY})$.
+\end{enumerate}
+\item Otherwise assign $\bitvar{MVECTS}[\locvar{C}]$ the value $(0,0)$.
+\item If $\bitvar{BCODED}[\locvar{D}]$ is non-zero:
+\begin{enumerate}
+\item Decode a single motion vector into \locvar{MVX} and \locvar{MVY} using
+ the procedure described in Section~\ref{sub:mv-decode}.
+\item Assign $\bitvar{MVECTS}[\locvar{D}]$ the value
+ $(\locvar{MVX},\locvar{MVY})$.
+\end{enumerate}
+\item
+Otherwise, assign $\bitvar{MVECTS}[\locvar{D}]$ the value $(0,0)$.
+\item
+If \bitvar{PF} is 0 (4:2:0):
+\begin{enumerate}
+\item
+Let \locvar{E} and \locvar{F} be the index in coded order of the one block in
+ the macro block from the $C_b$ and $C_r$ planes, respectively.
+\item
+Assign $\bitvar{MVECTS}[\locvar{E}]$ and $\bitvar{MVECTS}[\locvar{F}]$ the
+ value
+\begin{multline*}
+(\round\biggl(\frac{\begin{aligned}
+ \bitvar{MVECTS}[\locvar{A}]_x+\bitvar{MVECTS}[\locvar{B}]_x+\\
+ \bitvar{MVECTS}[\locvar{C}]_x+\bitvar{MVECTS}[\locvar{D}]_x
+ \end{aligned}}{4}\biggr), \\
+ \round\biggl(\frac{\begin{aligned}
+ \bitvar{MVECTS}[\locvar{A}]_y+\bitvar{MVECTS}[\locvar{B}]_y+\\
+ \bitvar{MVECTS}[\locvar{C}]_y+\bitvar{MVECTS}[\locvar{D}]_y
+ \end{aligned}}{4}\biggr))
+\end{multline*}
+\end{enumerate}
+\item
+If \bitvar{PF} is 2 (4:2:2):
+\begin{enumerate}
+\item
+Let \locvar{E} and \locvar{F} be the indices in coded order of the bottom and
+ top blocks in the macro block from the $C_b$ plane, respectively, and
+ \locvar{G} and \locvar{H} be the indices in coded order of the bottom and top
+ blocks in the $C_r$ plane, respectively. %TODO: as shown in Figure~REF.
+\item
+Assign $\bitvar{MVECTS}[\locvar{E}]$ and $\bitvar{MVECTS}[\locvar{G}]$ the
+ value
+\begin{multline*}
+(\round\left(\frac{
+ \bitvar{MVECTS}[\locvar{A}]_x+\bitvar{MVECTS}[\locvar{B}]_x}{2}\right), \\
+ \round\left(\frac{
+ \bitvar{MVECTS}[\locvar{A}]_y+\bitvar{MVECTS}[\locvar{B}]_y}{2}\right))
+\end{multline*}
+\item
+Assign $\bitvar{MVECTS}[\locvar{F}]$ and $\bitvar{MVECTS}[\locvar{H}]$ the
+ value
+\begin{multline*}
+(\round\left(\frac{
+ \bitvar{MVECTS}[\locvar{C}]_x+\bitvar{MVECTS}[\locvar{D}]_x}{2}\right), \\
+ \round\left(\frac{
+ \bitvar{MVECTS}[\locvar{C}]_y+\bitvar{MVECTS}[\locvar{D}]_y}{2}\right))
+\end{multline*}
+\end{enumerate}
+\item
+If \bitvar{PF} is 3 (4:4:4):
+\begin{enumerate}
+\item
+Let \locvar{E}, \locvar{F}, \locvar{G}, and \locvar{H} be the indices
+ \locvar{\bi} in coded order of the $C_b$ plane blocks in macro block
+ \locvar{\mbi}, arranged into raster order, and \locvar{I}, \locvar{J},
+ \locvar{K}, and \locvar{L} be the indices \locvar{\bi} in coded order of the
+ $C_r$ plane blocks in macro block \locvar{\mbi}, arranged into raster order.
+ %TODO: as shown in Figure~REF.
+\item
+Assign $\bitvar{MVECTS}[\locvar{E}]$ and $\bitvar{MVECTS}[\locvar{I}]$ the
+ value \\ $\bitvar{MVECTS}[\locvar{A}]$.
+\item
+Assign $\bitvar{MVECTS}[\locvar{F}]$ and $\bitvar{MVECTS}[\locvar{J}]$ the
+ value \\ $\bitvar{MVECTS}[\locvar{B}]$.
+\item
+Assign $\bitvar{MVECTS}[\locvar{G}]$ and $\bitvar{MVECTS}[\locvar{K}]$ the
+ value \\ $\bitvar{MVECTS}[\locvar{C}]$.
+\item
+Assign $\bitvar{MVECTS}[\locvar{H}]$ and $\bitvar{MVECTS}[\locvar{L}]$ the
+ value \\ $\bitvar{MVECTS}[\locvar{D}]$.
+\end{enumerate}
+\item
+Assign \locvar{LAST2} the value \locvar{LAST1}.
+\item
+Assign \locvar{LAST1} the value $(\locvar{MVX},\locvar{MVY})$.
+This is the value of the motion vector decoded from the last coded luma block
+ in raster order.
+There must always be at least one, since macro blocks with no coded luma blocks
+ must use mode 0:~INTER\_NOMV.
+\end{enumerate}
+\item
+Otherwise, if $\bitvar{MBMODES}[\locvar{\mbi}]$ is 6 (INTER\_GOLDEN\_MV),
+ decode a single motion vector into \locvar{MVX} and \locvar{MVY} using the
+ procedure described in Section~\ref{sub:mv-decode}.
+\item
+Otherwise, if $\bitvar{MBMODES}[\locvar{\mbi}]$ is 4 (INTER\_MV\_LAST2):
+\begin{enumerate}
+\item
+Assign $(\locvar{MVX},\locvar{MVY})$ the value \locvar{LAST2}.
+\item
+Assign \locvar{LAST2} the value \locvar{LAST1}.
+\item
+Assign \locvar{LAST1} the value $(\locvar{MVX},\locvar{MVY})$.
+\end{enumerate}
+\item
+Otherwise, if $\bitvar{MBMODES}[\locvar{\mbi}]$ is 3 (INTER\_MV\_LAST), assign
+ $(\locvar{MVX},\locvar{MVY})$ the value \locvar{LAST1}.
+\item
+Otherwise, if $\bitvar{MBMODES}[\locvar{\mbi}]$ is 2 (INTER\_MV):
+\begin{enumerate}
+\item
+Decode a single motion vector into \locvar{MVX} and \locvar{MVY} using the
+ procedure described in Section~\ref{sub:mv-decode}.
+\item
+Assign \locvar{LAST2} the value \locvar{LAST1}.
+\item
+Assign \locvar{LAST1} the value $(\locvar{MVX},\locvar{MVY})$.
+\end{enumerate}
+\item
+Otherwise ($\bitvar{MBMODES}[\locvar{\mbi}]$ is 5:~INTER\_GOLDEN\_NOMV,
+ 1:~INTRA, or 0:~INTER\_NOMV), assign \locvar{MVX} and \locvar{MVY} the value
+ zero.
+\item
+If $\bitvar{MBMODES}[\locvar{\mbi}]$ is not 7 (not INTER\_MV\_FOUR), then for
+ each coded block \locvar{\bi} in macro block \locvar{\mbi}:
+\begin{enumerate}
+\item
+Assign $\bitvar{MVECTS}[\locvar{\bi}]$ the value $(\locvar{MVX},\locvar{MVY})$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+Unless all four luma blocks in the macro block are coded, the VP3 encoder does
+ not select mode INTER\_MV\_FOUR.
+Theora removes this restriction by treating the motion vector for an uncoded
+ luma block as the default $(0,0)$ vector.
+This is consistent with the premise that the block has not changed since the
+ previous frame and that chroma information can be largely ignored when
+ estimating motion.
+
+No modification is required for INTER\_MV\_FOUR macro blocks in VP3 streams to
+ be decoded correctly by a Theora decoder.
+However, regardless of how many of the luma blocks are actually coded, the VP3
+ decoder always reads four motion vectors from the stream for INTER\_MV\_FOUR
+ mode.
+The motion vectors read are used to calculate the motion vectors for the chroma
+ blocks, but are otherwise ignored.
+Thus, care should be taken when creating Theora streams meant to be backwards
+ compatible with VP3 to only use INTER\_MV\_FOUR mode when all four luma
+ blocks are coded.
+
+\section{Block-Level \qi\ Decode}
+\label{sub:block-qis}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{NBS}      & Integer & 36 & No & The total number of blocks in a
+ frame. \\
+\bitvar{BCODED}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\bitvar{NQIS}     & Integer &  2 & No & The number of \qi\ values. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{QIIS}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               2 & No & An \bitvar{NBS}-element array of
+ \locvar{\qii} values for each block. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{NBITS}    & Integer & 36 & No & The length of a bit string to decode. \\
+\locvar{BITS}     & Bit string & &    & A decoded set of flags. \\
+\locvar{\bi}      & Integer & 36 & No & The index of the current block in
+ coded order. \\
+\locvar{\qii}     & Integer &  2 & No & The index of \qi\ value in the list of
+ \qi\ values defined for this frame. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure selects the \qi\ value to be used for dequantizing the AC
+ coefficients of each block.
+DC coefficients all use the same \qi\ value, so as to avoid interference with
+ the DC prediction mechanism, which occurs in the quantized domain.
+
+The value is actually represented by an index \locvar{\qii} into the list of
+ \qi\ values defined for the frame.
+The decoder makes multiple passes through the list of coded blocks, one for
+ each \qi\ value except the last one.
+In each pass, an RLE-coded bitmask is decoded to divide the blocks into two
+ groups: those that use the current \qi\ value in the list, and those that use
+ a value from later in the list.
+Each subsequent pass is restricted to the blocks in the second group.
+
+\begin{enumerate}
+\item
+For each value of \locvar{\bi} from 0 to $(\bitvar{NBS}-1)$, assign
+ $\bitvar{QIIS}[\locvar{\bi}]$ the value zero.
+\item
+For each consecutive value of \locvar{\qii} from 0 to $(\bitvar{NQIS}-2)$:
+\begin{enumerate}
+\item
+Assign \locvar{NBITS} be the number of blocks \locvar{\bi} such that
+ $\bitvar{BCODED}[\locvar{\bi}]$ is non-zero and $\bitvar{QIIS}[\locvar{\bi}]$
+ equals $\locvar{\qii}$.
+\item
+Read an \locvar{NBITS}-bit bit string into \locvar{BITS}, using the procedure
+ described in Section~\ref{sub:long-run}.
+This represents the list of blocks that use \qi\ value \locvar{\qii} or higher.
+\item
+For each consecutive value of \locvar{\bi} from 0 to $(\bitvar{NBS}-1)$ such
+ that $\bitvar{BCODED}[\locvar{\bi}]$ is non-zero and
+ $\bitvar{QIIS}[\locvar{\bi}]$ equals $\locvar{\qii}$:
+\begin{enumerate}
+\item
+Remove the bit at the head of the string \locvar{BITS} and add its value to
+ $\bitvar{QIIS}[\locvar{\bi}]$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+For VP3 compatible streams, only one \qi\ value can be specified in the frame
+ header, so the main loop of the above procedure, which would iterate from $0$
+ to $-1$, is never executed.
+Thus, no bits are read, and each block uses the one \qi\ value defined for the
+ frame.
+
+\cleardoublepage
+
+\section{DCT Coefficients}
+\label{sec:dct-decode}
+
+The quantized DCT coefficients are decoded by making 64 passes through the list
+ of coded blocks, one for each token index in zig-zag order.
+For the DC tokens, two Huffman tables are chosen from among the first 16, one
+ for the luma plane and one for the chroma planes.
+The AC tokens, however, are divided into four different groups.
+Again, two 4-bit indices are decoded, one for the luma plane, and one for the
+ chroma planes, but these select the codebooks for {\em all four} groups.
+AC coefficients in group one use codebooks $16\ldots 31$, while group two uses
+ $32\ldots 47$, etc.
+Note that this second set of indices is decoded even if there are no non-zero
+ AC coefficients in the frame.
+
+Tokens are divided into two major types: EOB tokens, which fill the remainder
+ of one or more blocks with zeros, and coefficient tokens, which fill in one or
+ more coefficients within a single block.
+A decoding procedure for the first is given in Section~\ref{sub:eob-token}, and
+ for the second in Section~\ref{sub:coeff-token}.
+The decoding procedure for the complete set of quantized coefficients is given
+ in Section~\ref{sub:dct-coeffs}.
+
+\subsection{EOB Token Decode}
+\label{sub:eob-token}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{TOKEN}    & Integer &  5 & No  & The token being decoded.
+This must be in the range $0\ldots 6$. \\
+\bitvar{NBS}      & Integer & 36 & No  & The total number of blocks in a
+ frame. \\
+\bitvar{TIS}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No  & An \bitvar{NBS}-element array of the
+ current token index for each block. \\
+\bitvar{NCOEFFS}  & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No  & An \bitvar{NBS}-element array of the
+ coefficient count for each block. \\
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bitvar{\bi}      & Integer & 36 & No  & The index of the current block in
+ coded order. \\
+\bitvar{\ti}      & Integer &  6 & No  & The current token index. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{TIS}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No  & An \bitvar{NBS}-element array of the
+ current token index for each block. \\
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bitvar{EOBS}     & Integer & 36 & No  & The remaining length of the current
+ EOB run. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\bj}      & Integer & 36 & No & Another index of a block in coded
+ order. \\
+\locvar{\tj}      & Integer &  6 & No & Another token index. \\
+\bottomrule\end{tabularx}
+\medskip
+
+A summary of the EOB tokens is given in Table~\ref{tab:eob-tokens}.
+An important thing to note is that token 6 does not add an offset to the
+ decoded run value, even though in general it should only be used for runs of
+ size 32 or longer.
+If a value of zero is decoded for this run, it is treated as an EOB run the
+ size of the remaining coded blocks.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{ccl}\toprule
+Token Value  & Extra Bits & EOB Run Lengths                         \\\midrule
+$0$          & $0$        & $1$                                     \\
+$1$          & $0$        & $2$                                     \\
+$2$          & $0$        & $3$                                     \\
+$3$          & $2$        & $4\ldots 7$                             \\
+$4$          & $3$        & $8\ldots 15$                            \\
+$5$          & $4$        & $16\ldots 31$                           \\
+$6$          & $12$       & $1\ldots 4095$, or all remaining blocks \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{EOB Token Summary}
+\label{tab:eob-tokens}
+\end{table}
+
+There is no restriction that one EOB token cannot be immediately followed by
+ another, so no special cases are necessary to extend the range of the maximum
+ run length as were required in Section~\ref{sub:long-run}.
+Indeed, depending on the lengths of the Huffman codes, it may even cheaper to
+ encode, by way of example, an EOB run of length 31 followed by an EOB run of
+ length 1 than to encode an EOB run of length 32 directly.
+There is also no restriction that an EOB run stop at the end of a color plane
+ or a token index.
+The run MUST, however, end at or before the end of the frame.
+
+\begin{enumerate}
+\item
+If \bitvar{TOKEN} is 0, assign \bitvar{EOBS} the value 1.
+\item
+Otherwise, if \bitvar{TOKEN} is 1, assign \bitvar{EOBS} the value 2.
+\item
+Otherwise, if \bitvar{TOKEN} is 2, assign \bitvar{EOBS} the value 3.
+\item
+Otherwise, if \bitvar{TOKEN} is 3:
+\begin{enumerate}
+\item
+Read a 2-bit unsigned integer as \bitvar{EOBS}.
+\item
+Assign \bitvar{EOBS} the value $(\bitvar{EOBS}+4)$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 4:
+\begin{enumerate}
+\item
+Read a 3-bit unsigned integer as \bitvar{EOBS}.
+\item
+Assign \bitvar{EOBS} the value $(\bitvar{EOBS}+8)$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 5:
+\begin{enumerate}
+\item
+Read a 4-bit unsigned integer as \bitvar{EOBS}.
+\item
+Assign \bitvar{EOBS} the value $(\bitvar{EOBS}+16)$.
+\end{enumerate}
+\item
+Otherwise, \bitvar{TOKEN} is 6:
+\begin{enumerate}
+\item
+Read a 12-bit unsigned integer as \bitvar{EOBS}.
+\item
+If \bitvar{EOBS} is zero, assign \bitvar{EOBS} to be the number of coded blocks
+ \locvar{\bj} such that $\bitvar{TIS}[\locvar{\bj}]$ is less than 64.
+\end{enumerate}
+\item
+For each value of \locvar{\tj} from $\bitvar{\ti}$ to 63, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value 64.
+\item
+Assign \bitvar{EOBS} the value $(\bitvar{EOBS}-1)$.
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+The VP3 encoder does not use the special interpretation of a zero-length EOB
+ run, though its decoder {\em does} support it.
+That may be due more to a happy accident in the way the decoder was written
+ than intentional design, however, and other VP3 implementations might not
+ reproduce it faithfully.
+For backwards compatibility, it may be wise to avoid it, especially as for most
+ frame sizes there are fewer than 4095 blocks, making it unnecessary.
+
+\subsection{Coefficient Token Decode}
+\label{sub:coeff-token}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{TOKEN}    & Integer &  5 & No  & The token being decoded.
+This must be in the range $7\ldots 31$. \\
+\bitvar{NBS}      & Integer & 36 & No  & The total number of blocks in a
+ frame. \\
+\bitvar{TIS}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No  & An \bitvar{NBS}-element array of the
+ current token index for each block. \\
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bitvar{\bi}      & Integer & 36 & No  & The index of the current block in
+ coded order. \\
+\bitvar{\ti}      & Integer &  6 & No  & The current token index. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{TIS}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No  & An \bitvar{NBS}-element array of the
+ current token index for each block. \\
+\bitvar{NCOEFFS}  & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No  & An \bitvar{NBS}-element array of the
+ coefficient count for each block. \\
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{SIGN}     & Integer &  1 & No & A flag indicating the sign of the
+ current coefficient. \\
+\locvar{MAG}      & Integer & 10 & No & The magnitude of the current
+ coefficient. \\
+\locvar{RLEN}     & Integer &  6 & No & The length of the current zero run. \\
+\locvar{\tj}      & Integer &  6 & No & Another token index. \\
+\bottomrule\end{tabularx}
+\medskip
+
+Each of these tokens decodes one or more coefficients in the current block.
+A summary of the meanings of the token values is presented in
+ Table~\ref{tab:coeff-tokens}.
+There are often several different ways to tokenize a given coefficient list.
+Which one is optimal depends on the exact lengths of the Huffman codes used to
+ represent each token.
+Note that we do not update the coefficient count for the block if we decode a
+ pure zero run.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabularx}{\textwidth}{cclX}\toprule
+Token Value  & Extra Bits & \multicolumn{1}{p{55pt}}{Number of Coefficients}
+                                    & Description                    \\\midrule
+$7$          & $3$  & $1\ldots 8$   & Short zero run.                \\
+$8$          & $6$  & $1\ldots 64$  & Zero run.                      \\
+$9$          & $0$  & $1$           & $1$.                           \\
+$10$         & $0$  & $1$           & $-1$.                          \\
+$11$         & $0$  & $1$           & $2$.                           \\
+$12$         & $0$  & $1$           & $-2$.                          \\
+$13$         & $1$  & $1$           & $\pm 3$.                       \\
+$14$         & $1$  & $1$           & $\pm 4$.                       \\
+$15$         & $1$  & $1$           & $\pm 5$.                       \\
+$16$         & $1$  & $1$           & $\pm 6$.                       \\
+$17$         & $2$  & $1$           & $\pm 7\ldots 8$.               \\
+$18$         & $3$  & $1$           & $\pm 9\ldots 12$.              \\
+$19$         & $4$  & $1$           & $\pm 13\ldots 20$.             \\
+$20$         & $5$  & $1$           & $\pm 21\ldots 36$.             \\
+$21$         & $6$  & $1$           & $\pm 37\ldots 68$.             \\
+$22$         & $10$ & $1$           & $\pm 69\ldots 580$.            \\
+$23$         & $1$  & $2$           & One zero followed by $\pm 1$.  \\
+$24$         & $1$  & $3$           & Two zeros followed by $\pm 1$. \\
+$25$         & $1$  & $4$           & Three zeros followed by
+ $\pm 1$. \\
+$26$         & $1$  & $5$           & Four zeros followed by
+ $\pm 1$. \\
+$27$         & $1$  & $6$           & Five zeros followed by
+ $\pm 1$. \\
+$28$         & $3$  & $7\ldots 10$  & $6\ldots 9$ zeros followed by
+ $\pm 1$.  \\
+$29$         & $4$  & $11\ldots 18$ & $10\ldots 17$ zeros followed by
+ $\pm 1$.\\
+$30$         & $2$  & $2$           & One zero followed by
+ $\pm 2\ldots 3$. \\
+$31$         & $3$  & $3\ldots 4$   & $2\ldots 3$ zeros followed by
+ $\pm 2\ldots 3$. \\
+\bottomrule\end{tabularx}
+\end{center}
+\caption{Coefficient Token Summary}
+\label{tab:coeff-tokens}
+\end{table}
+
+For tokens which represent more than one coefficient, they MUST NOT bring the
+ total number of coefficients in the block to more than 64.
+Care should be taken in a decoder to check for this, as otherwise it may permit
+ buffer overflows from invalidly formed packets.
+\begin{verse}
+{\bf Note:} One way to achieve this efficiently is to combine the inverse
+ zig-zag mapping (described later in Section~\ref{sub:dequant}) with
+ coefficient decode, and use a table look-up to map zig-zag indices greater
+ than 63 to a safe location.
+\end{verse}
+
+\begin{enumerate}
+\item
+If \bitvar{TOKEN} is 7:
+\begin{enumerate}
+\item
+Read in a 3-bit unsigned integer as \locvar{RLEN}.
+\item
+Assign \locvar{RLEN} the value $(\locvar{RLEN}+1)$.
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to
+ $(\bitvar{\ti}+\locvar{RLEN}-1)$, assign
+  $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value
+ $\bitvar{TIS}[\bitvar{\bi}]+\locvar{RLEN}$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 8:
+\begin{enumerate}
+\item
+Read in a 6-bit unsigned integer as \locvar{RLEN}.
+\item
+Assign \locvar{RLEN} the value $(\locvar{RLEN}+1)$.
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to
+ $(\bitvar{\ti}+\locvar{RLEN}-1)$, assign
+  $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value
+ $\bitvar{TIS}[\bitvar{\bi}]+\locvar{RLEN}$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 9:
+\begin{enumerate}
+\item
+Assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 10:
+\begin{enumerate}
+\item
+Assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 11:
+\begin{enumerate}
+\item
+Assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $2$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 12:
+\begin{enumerate}
+\item
+Assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $-2$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 13:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $3$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $-3$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 14:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $4$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $-4$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 15:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $5$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $-5$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 16:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $6$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value $-6$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 17:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 1-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+7)$.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value
+ $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 18:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 2-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+9)$.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value
+ $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 19:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 3-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+13)$.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value
+ $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 20:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 4-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+21)$.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value
+ $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 21:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 5-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+37)$.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value
+ $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 22:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 9-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+69)$.
+\item
+If \locvar{SIGN} is zero, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$
+ the value $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value
+ $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 23:
+\begin{enumerate}
+\item
+Assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}]$ the value zero.
+\item
+Read a 1-bit unsigned integer as SIGN.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+1]$ the value $1$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+1]$ the value
+ $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+2$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 24:
+\begin{enumerate}
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to $(\bitvar{\ti}+1)$, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Read a 1-bit unsigned integer as SIGN.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+2]$ the value $1$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+2]$ the value
+ $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+3$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 25:
+\begin{enumerate}
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to $(\bitvar{\ti}+2)$, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Read a 1-bit unsigned integer as SIGN.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+3]$ the value $1$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+3]$ the value
+ $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+4$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 26:
+\begin{enumerate}
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to $(\bitvar{\ti}+3)$, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Read a 1-bit unsigned integer as SIGN.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+4]$ the value $1$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+4]$ the value
+ $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+5$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 27:
+\begin{enumerate}
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to $(\bitvar{\ti}+4)$, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Read a 1-bit unsigned integer as SIGN.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+5]$ the value $1$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+5]$ the value
+ $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+6$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 28:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 2-bit unsigned integer as \locvar{RLEN}.
+\item
+Assign \locvar{RLEN} the value $(\locvar{RLEN}+6)$.
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to
+ $(\bitvar{\ti}+\locvar{RLEN}-1)$, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+\locvar{RLEN}]$ the value $1$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+\locvar{RLEN}]$
+ the value $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value
+ $\bitvar{TIS}[\bitvar{\bi}]+\locvar{RLEN}+1$.
+\item
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 29:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 3-bit unsigned integer as \locvar{RLEN}.
+\item
+Assign \locvar{RLEN} the value $(\locvar{RLEN}+10)$.
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to
+ $(\bitvar{\ti}+\locvar{RLEN}-1)$, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+\locvar{RLEN}]$ the value $1$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+\locvar{RLEN}]$
+ the value $-1$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value
+ $\bitvar{TIS}[\bitvar{\bi}]+\locvar{RLEN}+1$.
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 30:
+\begin{enumerate}
+\item
+Assign $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\ti}]$ the value zero.
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 1-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+2)$.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+1]$ the value $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+1]$ the value
+ $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]+2$.
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\item
+Otherwise, if \bitvar{TOKEN} is 31:
+\begin{enumerate}
+\item
+Read a 1-bit unsigned integer as \locvar{SIGN}.
+\item
+Read a 1-bit unsigned integer as \locvar{MAG}.
+\item
+Assign \locvar{MAG} the value $(\locvar{MAG}+2)$.
+\item
+Read a 1-bit unsigned integer as \locvar{RLEN}.
+\item
+Assign \locvar{RLEN} the value $(\locvar{RLEN}+2)$.
+\item
+For each value of \locvar{\tj} from \bitvar{\ti} to
+ $(\bitvar{\ti}+\locvar{RLEN}-1)$, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+If \locvar{SIGN} is zero, assign
+ $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+\locvar{RLEN}]$ the value
+ $\locvar{MAG}$.
+\item
+Otherwise, assign $\bitvar{COEFFS}[\bitvar{\bi}][\bitvar{\ti}+\locvar{RLEN}]$
+ the value $-\locvar{MAG}$.
+\item
+Assign $\bitvar{TIS}[\bitvar{\bi}]$ the value
+ $\bitvar{TIS}[\bitvar{\bi}]+\locvar{RLEN}+1$.
+Assign $\bitvar{NCOEFFS}[\bitvar{\bi}]$ the value $\bitvar{TIS}[\bitvar{\bi}]$.
+\end{enumerate}
+\end{enumerate}
+
+\subsection{DCT Coefficient Decode}
+\label{sub:dct-coeffs}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{NBS}      & Integer & 36 & No  & The total number of blocks in a
+ frame. \\
+\bitvar{BCODED}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\bitvar{NMBS}     & Integer & 32 & No & The total number of macro blocks in a
+ frame. \\
+\bitvar{HTS} & \multicolumn{3}{l}{Huffman table array}
+                                     & An 80-element array of Huffman tables
+ with up to 32 entries each. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bitvar{NCOEFFS}  & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No  & An \bitvar{NBS}-element array of the
+ coefficient count for each block. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{NLBS}     & Integer & 34 & No & The number of blocks in the luma
+ plane. \\
+\locvar{TIS}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & No & An \bitvar{NBS}-element array of the
+ current token index for each block. \\
+\locvar{EOBS}     & Integer & 36 & No & The remaining length of the current
+ EOB run. \\
+\locvar{TOKEN}    & Integer &  5 & No & The current token being decoded. \\
+\locvar{HG}       & Integer &  3 & No & The current Huffman table group. \\
+\locvar{\cbi}     & Integer & 36 & No & The index of the current block in the
+ coded block list. \\
+\locvar{\bi}      & Integer & 36 & No & The index of the current block in
+ coded order. \\
+\locvar{\bj}      & Integer & 36 & No & Another index of a block in coded
+ order. \\
+\locvar{\ti}      & Integer &  6 & No & The current token index. \\
+\locvar{\tj}      & Integer &  6 & No & Another token index. \\
+\locvar{\hti_L}   & Integer &  4 & No & The index of the current Huffman table
+ to use for the luma plane within a group. \\
+\locvar{\hti_C}   & Integer &  4 & No & The index of the current Huffman table
+ to use for the chroma planes within a group. \\
+\locvar{\hti}     & Integer &  7 & No & The index of the current Huffman table
+ to use. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure puts the above two procedures to work to decode the entire set
+ of DCT coefficients for the frame.
+At the end of this procedure, \locvar{EOBS} MUST be zero, and
+ $\locvar{TIS}[\locvar{\bi}]$ MUST be 64 for every coded \locvar{\bi}.
+
+Note that we update the coefficient count of every block before continuing an
+ EOB run or decoding a token, despite the fact that it is already up to date
+ unless the previous token was a pure zero run.
+This is done intentionally to mimic the VP3 accounting rules.
+Thus the only time the coefficient count does not include the coefficients in a
+ pure zero run is when when that run reaches all the way to coefficient 63.
+Note, however, that regardless of the coefficient count, any additional
+ coefficients are still set to zero.
+The only use of the count is in determining if a special case of the inverse
+ DCT can be used in Section~\ref{sub:2d-idct}.
+
+\begin{enumerate}
+\item
+Assign \locvar{NLBS} the value $(\bitvar{NMBS}*4)$.
+\item
+For each consecutive value of \locvar{\bi} from 0 to $(\bitvar{NBS}-1)$,
+ assign $\locvar{TIS}[\locvar{\bi}]$ the value zero.
+\item
+Assign \locvar{EOBS} the value 0.
+\item
+For each consecutive value of \locvar{\ti} from 0 to 63:
+\begin{enumerate}
+\item
+If \locvar{\ti} is $0$ or $1$:
+\begin{enumerate}
+\item
+Read a 4-bit unsigned integer as \locvar{\hti_L}.
+\item
+Read a 4-bit unsigned integer as \locvar{\hti_C}.
+\end{enumerate}
+\item
+For each consecutive value of \locvar{\bi} from 0 to $(\bitvar{NBS}-1)$ for
+ which $\bitvar{BCODED}[\locvar{\bi}]$ is non-zero and
+ $\locvar{TIS}[\locvar{\bi}]$ equals \locvar{\ti}:
+\begin{enumerate}
+\item
+Assign $\bitvar{NCOEFFS}[\locvar{\bi}]$ the value \locvar{\ti}.
+\item
+If \locvar{EOBS} is greater than zero:
+\begin{enumerate}
+\item
+For each value of \locvar{\tj} from $\locvar{\ti}$ to 63, assign
+ $\bitvar{COEFFS}[\locvar{\bi}][\locvar{\tj}]$ the value zero.
+\item
+Assign $\locvar{TIS}[\locvar{\bi}]$ the value 64.
+\item
+Assign \locvar{EOBS} the value $(\locvar{EOBS}-1)$.
+\end{enumerate}
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Assign \locvar{HG} a value based on \locvar{\ti} from
+ Table~\ref{tab:huff-groups}.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{lc}\toprule
+\locvar{\ti}  & \locvar{HG} \\\midrule
+$0$           & $0$ \\
+$1\ldots 5$   & $1$ \\
+$6\ldots 14$  & $2$ \\
+$15\ldots 27$ & $3$ \\
+$28\ldots 63$ & $4$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Huffman Table Groups}
+\label{tab:huff-groups}
+\end{table}
+
+\item
+If \locvar{\bi} is less than \locvar{NLBS}, assign \locvar{\hti} the value
+ $(16*\locvar{HG}+\locvar{\hti_L})$.
+\item
+Otherwise, assign \locvar{\hti} the value
+ $(16*\locvar{HG}+\locvar{\hti_C})$.
+\item
+Read one bit at a time until one of the codes in $\bitvar{HTS}[\locvar{\hti}]$
+ is recognized, and assign the value to \locvar{TOKEN}.
+\item
+If \locvar{TOKEN} is less than 7, expand an EOB token using the procedure given
+ in Section~\ref{sub:eob-token} to update $\locvar{TIS}[\locvar{\bi}]$,
+ $\bitvar{COEFFS}[\locvar{\bi}]$, and \locvar{EOBS}.
+\item
+Otherwise, expand a coefficient token using the procedure given in
+ Section~\ref{sub:coeff-token} to update $\locvar{TIS}[\locvar{\bi}]$,
+ $\bitvar{COEFFS}[\locvar{\bi}]$, and $\bitvar{NCOEFFS}[\locvar{\bi}]$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\section{Undoing DC Prediction}
+
+The actual value of a DC coefficient decoded by Section~\ref{sec:dct-decode} is
+ the residual from a predicted value computed by the encoder.
+This prediction is only applied to DC coefficients.
+Quantized AC coefficients are encoded directly.
+
+This section describes how to undo this prediction to recover the original
+ DC coefficients.
+The predicted DC value for a block is computed from the DC values of its
+ immediate neighbors which precede the block in raster order.
+Thus, reversing this prediction must procede in raster order, instead of coded
+ order.
+
+Note that this step comes before dequantizing the coefficients.
+For this reason, DC coefficients are all quantized with the same \qi\ value,
+ regardless of the block-level \qi\ values decoded in
+ Section~\ref{sub:block-qis}.
+Those \qi\ values are applied only to the AC coefficients.
+
+\subsection{Computing the DC Predictor}
+\label{sub:dc-pred}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{BCODED}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No  & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\bitvar{MBMODES}  & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               3 & No  & An \bitvar{NMBS}-element array of
+ coding modes for each macro block. \\
+\bitvar{LASTDC}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              16 & Yes & A 3-element array containing the
+ most recently decoded DC value, one for inter mode and for each reference
+ frame. \\
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bitvar{\bi}      & Integer & 36 & No  & The index of the current block in
+ coded order. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{DCPRED} & Integer & 16 & Yes & The predicted DC value for the current
+ block. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{P}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No  & A 4-element array indicating which
+ neighbors can be used for DC prediction. \\
+\locvar{PBI}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              36 & No  & A 4-element array containing the
+ coded-order block index of the current block's neighbors. \\
+\locvar{W}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               7 & Yes & A 4-element array of the weights to
+ apply to each neighboring DC value. \\
+\locvar{PDIV}     & Integer &  8 & No  & The valud to divide the weighted sum
+ by. \\
+\locvar{\bj}      & Integer & 36 & No  & The index of a neighboring block in
+ coded order. \\
+\locvar{\mbi}     & Integer & 32 & No  & The index of the macro block
+ containing block \locvar{\bi}. \\
+\locvar{\mbi}     & Integer & 32 & No  & The index of the macro block
+ containing block \locvar{\bj}. \\
+\locvar{\rfi}     & Integer &  2 & No  & The index of the reference frame
+ indicated by the coding mode for macro block \locvar{\mbi}. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure outlines how a predictor is formed for a single block.
+
+The predictor is computed as a weighted sum of the neighboring DC values from
+ coded blocks which use the same reference frame.
+This latter condition is determined only by checking the coding mode for the
+ block.
+Even if the golden frame and the previous frame are in fact the same, e.g. for
+ the first inter frame after an intra frame, they are still treated as being
+ different for the purposes of DC prediction.
+The weighted sum is divided by a power of two, with truncation towards zero,
+ and the result is checked for outranging if necessary.
+
+If there are no neighboring coded blocks which use the same reference frame as
+ the current block, then the most recent DC value of any block that used that
+ reference frame is used instead.
+If no such block exists, then the predictor is set to zero.
+
+\begin{enumerate}
+\item
+Assign \locvar{\mbi} the index of the macro block containing block
+ \bitvar{\bi}.
+\item
+Assign \locvar{\rfi} the value of the Reference Frame Index column of
+ Table~\ref{tab:cm-refs} corresponding to $\bitvar{MBMODES}[\locvar{\mbi}]$.
+
+\begin{table}[htpb]
+\begin{center}
+\begin{tabular}{ll}\toprule
+Coding Mode               & Reference Frame Index \\\midrule
+$0$ (INTER\_NOMV)         & $1$ (Previous)        \\
+$1$ (INTRA)               & $0$ (None)            \\
+$2$ (INTER\_MV)           & $1$ (Previous)        \\
+$3$ (INTER\_MV\_LAST)     & $1$ (Previous)        \\
+$4$ (INTER\_MV\_LAST2)    & $1$ (Previous)        \\
+$5$ (INTER\_GOLDEN\_NOMV) & $2$ (Golden)          \\
+$6$ (INTER\_GOLDEN\_MV)   & $2$ (Golden)          \\
+$7$ (INTER\_MV\_FOUR)     & $1$ (Previous)        \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Reference Frames for Each Coding Mode}
+\label{tab:cm-refs}
+\end{table}
+
+\item
+If block \locvar{\bi} is not along the left edge of the coded frame:
+\begin{enumerate}
+\item
+Assign \locvar{\bj} the coded-order index of block \locvar{\bi}'s left
+ neighbor, i.e., in the same row but one column to the left.
+\item
+If $\bitvar{BCODED}[\bj]$ is not zero:
+\begin{enumerate}
+\item
+Assign \locvar{\mbj} the index of the macro block containing block
+ \locvar{\bj}.
+\item
+If the value of the Reference Frame Index column of Table~\ref{tab:cm-refs}
+ corresonding to $\bitvar{MBMODES}[\locvar{\mbj}]$ equals \locvar{\rfi}:
+\begin{enumerate}
+\item
+Assign $\locvar{P}[0]$ the value $1$.
+\item
+Assign $\locvar{PBI}[0]$ the value \locvar{\bj}.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[0]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[0]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[0]$ the value zero.
+
+\item
+If block \locvar{\bi} is not along the left edge nor the bottom edge of the
+ coded frame:
+\begin{enumerate}
+\item
+Assign \locvar{\bj} the coded-order index of block \locvar{\bi}'s lower-left
+ neighbor, i.e., one row down and one column to the left.
+\item
+If $\bitvar{BCODED}[\bj]$ is not zero:
+\begin{enumerate}
+\item
+Assign \locvar{\mbj} the index of the macro block containing block
+ \locvar{\bj}.
+\item
+If the value of the Reference Frame Index column of Table~\ref{tab:cm-refs}
+ corresonding to $\bitvar{MBMODES}[\locvar{\mbj}]$ equals \locvar{\rfi}:
+\begin{enumerate}
+\item
+Assign $\locvar{P}[1]$ the value $1$.
+\item
+Assign $\locvar{PBI}[1]$ the value \locvar{\bj}.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[1]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[1]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[1]$ the value zero.
+
+\item
+If block \locvar{\bi} is not along the the bottom edge of the coded frame:
+\begin{enumerate}
+\item
+Assign \locvar{\bj} the coded-order index of block \locvar{\bi}'s lower
+ neighbor, i.e., in the same column but one row down.
+\item
+If $\bitvar{BCODED}[\bj]$ is not zero:
+\begin{enumerate}
+\item
+Assign \locvar{\mbj} the index of the macro block containing block
+ \locvar{\bj}.
+\item
+If the value of the Reference Frame Index column of Table~\ref{tab:cm-refs}
+ corresonding to $\bitvar{MBMODES}[\locvar{\mbj}]$ equals \locvar{\rfi}:
+\begin{enumerate}
+\item
+Assign $\locvar{P}[2]$ the value $1$.
+\item
+Assign $\locvar{PBI}[2]$ the value \locvar{\bj}.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[2]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[2]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[2]$ the value zero.
+
+\item
+If block \locvar{\bi} is not along the right edge nor the bottom edge of the
+ coded frame:
+\begin{enumerate}
+\item
+Assign \locvar{\bj} the coded-order index of block \locvar{\bi}'s lower-right
+ neighbor, i.e., one row down and one column to the right.
+\item
+If $\bitvar{BCODED}[\bj]$ is not zero:
+\begin{enumerate}
+\item
+Assign \locvar{\mbj} the index of the macro block containing block
+ \locvar{\bj}.
+\item
+If the value of the Reference Frame Index column of Table~\ref{tab:cm-refs}
+ corresonding to $\bitvar{MBMODES}[\locvar{\mbj}]$ equals \locvar{\rfi}:
+\begin{enumerate}
+\item
+Assign $\locvar{P}[3]$ the value $1$.
+\item
+Assign $\locvar{PBI}[3]$ the value \locvar{\bj}.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[3]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[3]$ the value zero.
+\end{enumerate}
+\item
+Otherwise, assign $\locvar{P}[3]$ the value zero.
+
+\item
+If none of the values $\locvar{P}[0]$, $\locvar{P}[1]$, $\locvar{P}[2]$, nor
+ $\locvar{P}[3]$ are non-zero, then assign \bitvar{DCPRED} the value
+ $\bitvar{LASTDC}[\locvar{\rfi}]$.
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Assign the array \locvar{W} and the variable \locvar{PDIV} the values from the
+ row of Table~\ref{tab:dc-weights} corresonding to the values of each
+ $\locvar{P}[\idx{i}]$.
+
+\begin{table}[htb]
+\begin{center}
+\begin{tabular}{ccccrrrrr}\toprule
+\multicolumn{1}{p{25pt}}{\centering$\locvar{P}[0]$ (L)} &
+\multicolumn{1}{p{25pt}}{\centering$\locvar{P}[1]$ (DL)} &
+\multicolumn{1}{p{25pt}}{\centering$\locvar{P}[2]$ (D)} &
+\multicolumn{1}{p{25pt}}{\centering$\locvar{P}[3]$ (DR)} &
+\multicolumn{1}{p{25pt}}{\centering$\locvar{W}[3]$ (L)} &
+\multicolumn{1}{p{25pt}}{\centering$\locvar{W}[1]$ (DL)} &
+\multicolumn{1}{p{25pt}}{\centering$\locvar{W}[2]$ (D)} &
+\multicolumn{1}{p{25pt}}{\centering$\locvar{W}[3]$ (DR)} &
+\locvar{PDIV} \\\midrule
+$1$ & $0$ & $0$ & $0$ &  $1$ &   $0$ &  $0$ &  $0$ &   $1$ \\
+$0$ & $1$ & $0$ & $0$ &  $0$ &   $1$ &  $0$ &  $0$ &   $1$ \\
+$1$ & $1$ & $0$ & $0$ &  $1$ &   $0$ &  $0$ &  $0$ &   $1$ \\
+$0$ & $0$ & $1$ & $0$ &  $0$ &   $0$ &  $1$ &  $0$ &   $1$ \\
+$1$ & $0$ & $1$ & $0$ &  $1$ &   $0$ &  $1$ &  $0$ &   $2$ \\
+$0$ & $1$ & $1$ & $0$ &  $0$ &   $0$ &  $1$ &  $0$ &   $1$ \\
+$1$ & $1$ & $1$ & $0$ & $29$ & $-26$ & $29$ &  $0$ &  $32$ \\
+$0$ & $0$ & $0$ & $1$ &  $0$ &   $0$ &  $0$ &  $1$ &   $1$ \\
+$1$ & $0$ & $0$ & $1$ & $75$ &   $0$ &  $0$ & $53$ & $128$ \\
+$0$ & $1$ & $0$ & $1$ &  $0$ &   $1$ &  $0$ &  $1$ &   $2$ \\
+$1$ & $1$ & $0$ & $1$ & $75$ &   $0$ &  $0$ & $53$ & $128$ \\
+$0$ & $0$ & $1$ & $1$ &  $0$ &   $0$ &  $1$ &  $0$ &   $1$ \\
+$1$ & $0$ & $1$ & $1$ & $75$ &   $0$ &  $0$ & $53$ & $128$ \\
+$0$ & $1$ & $1$ & $1$ &  $0$ &   $3$ & $10$ &  $3$ &  $16$ \\
+$1$ & $1$ & $1$ & $1$ & $29$ & $-26$ & $29$ &  $0$ &  $32$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Weights and Divisors for Each Set of Available DC Predictors}
+\label{tab:dc-weights}
+\end{table}
+
+\item
+Assign \bitvar{DCPRED} the value zero.
+\item
+If $\locvar{P}[0]$ is non-zero, assign \bitvar{DCPRED} the value
+ $(\bitvar{DCPRED}+\locvar{W}[0]*\bitvar{COEFFS}[\locvar{PBI}[0]][0])$.
+\item
+If $\locvar{P}[1]$ is non-zero, assign \bitvar{DCPRED} the value
+ $(\bitvar{DCPRED}+\locvar{W}[1]*\bitvar{COEFFS}[\locvar{PBI}[1]][0])$.
+\item
+If $\locvar{P}[2]$ is non-zero, assign \bitvar{DCPRED} the value
+ $(\bitvar{DCPRED}+\locvar{W}[2]*\bitvar{COEFFS}[\locvar{PBI}[2]][0])$.
+\item
+If $\locvar{P}[3]$ is non-zero, assign \bitvar{DCPRED} the value
+ $(\bitvar{DCPRED}+\locvar{W}[3]*\bitvar{COEFFS}[\locvar{PBI}[3]][0])$.
+\item
+Assign \bitvar{DCPRED} the value $(\bitvar{DCPRED}//\locvar{PDIV})$.
+\item
+If $\locvar{P}[0]$, $\locvar{P}[1]$, and $\locvar{P}[2]$ are all non-zero:
+\begin{enumerate}
+\item
+If $|\bitvar{DCPRED}-\bitvar{COEFFS}[\locvar{PBI}[2]][0]|$ is greater than
+ $128$, assign \bitvar{DCPRED} the value $\bitvar{COEFFS}[\locvar{PBI}[2]][0]$.
+\item
+Otherwise, if $|\bitvar{DCPRED}-\bitvar{COEFFS}[\locvar{PBI}[0]][0]|$ is
+ greater than $128$, assign \bitvar{DCPRED} the value
+ $\bitvar{COEFFS}[\locvar{PBI}[0]][0]$.
+\item
+Otherwise, if $|\bitvar{DCPRED}-\bitvar{COEFFS}[\locvar{PBI}[1]][0]|$ is
+ greater than $128$, assign \bitvar{DCPRED} the value
+ $\bitvar{COEFFS}[\locvar{PBI}[1]][0]$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\subsection{Inverting the DC Prediction Process}
+\label{sub:dc-pred-undo}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{BCODED}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               1 & No  & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\bitvar{MBMODES}  & \multicolumn{1}{p{40pt}}{Integer Array} &
+                               3 & No  & An \bitvar{NMBS}-element array of
+ coding modes for each macro block. \\
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. The DC 
+ value of each block will be updated. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{LASTDC}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              16 & Yes & A 3-element array containing the
+ most recently decoded DC value, one for inter mode and for each reference
+ frame. \\
+\locvar{DCPRED}   & Integer & 11 & Yes & The predicted DC value for the current
+ block. \\
+\locvar{DC}       & Integer & 17 & Yes & The actual DC value for the current
+ block. \\
+\locvar{\bi}      & Integer & 36 & No  & The index of the current block in
+ coded order. \\
+\locvar{\mbi}     & Integer & 32 & No  & The index of the macro block
+ containing block \locvar{\bi}. \\
+\locvar{\rfi}     & Integer &  2 & No  & The index of the reference frame
+ indicated by the coding mode for macro block \locvar{\mbi}. \\
+\locvar{\pli}     & Integer &  2 & No  & A color plane index. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure describes the complete process of undoing the DC prediction to
+ recover the original DC values.
+Because it is possible to add a value as large as $580$ to the predicted DC
+ coefficient value at every block, which will then be used to increase the
+ predictor for the next block, the reconstructed DC value could overflow a
+ 16-bit integer.
+This is handled by truncating the result to a 16-bit signed representation,
+ simply throwing away any higher bits in the two's complement representation of
+ the number.
+
+\begin{enumerate}
+\item
+For each consecutive value of \locvar{\pli} from $0$ to $2$:
+\begin{enumerate}
+\item
+Assign $\locvar{LASTDC}[0]$ the value zero.
+\item
+Assign $\locvar{LASTDC}[1]$ the value zero.
+\item
+Assign $\locvar{LASTDC}[2]$ the value zero.
+\item
+For each block of color plane \locvar{\pli} in {\em raster} order, with
+ coded-order index \locvar{\bi}:
+\begin{enumerate}
+\item
+If $\bitvar{BCODED}[\locvar{\bi}]$ is non-zero:
+\begin{enumerate}
+\item
+Compute the value \locvar{DCPRED} using the procedure outlined in
+ Section~\ref{sub:dc-pred}.
+\item
+Assign \locvar{DC} the value
+ $(\bitvar{COEFFS}[\locvar{\bi}][0]+\locvar{DCPRED})$.
+\item
+Truncate \locvar{DC} to a 16-bit representation by dropping any higher-order
+ bits.
+\item
+Assign $\bitvar{COEFFS}[\locvar{\bi}][0]$ the value \locvar{DC}.
+\item
+Assign \locvar{\mbi} the index of the macro block containing block
+ \locvar{\bi}.
+\item
+Assign \locvar{\rfi} the value of the Reference Frame Index column of
+ Table~\ref{tab:cm-refs} corresponding to $\bitvar{MBMODES}[\locvar{\mbi}]$.
+\item
+Assign $\locvar{LASTDC}[\rfi]$ the value $\locvar{DC}$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\section{Reconstruction}
+
+At this stage, the complete contents of the data packet have been decoded.
+All that remains is to reconstruct the contents of the new frame.
+This is applied on a block by block basis, and as each block is independent,
+ the order they are processed in does not matter.
+
+\subsection{Predictors}
+\label{sec:predictors}
+
+For each block, a predictor is formed based on its coding mode and motion
+ vector.
+There are three basic types of predictors: the intra predictor, the whole-pixel
+ predictor, and the half-pixel predictor.
+The former is used for all blocks coded in INTRA mode, while all other blocks
+ use one of the latter two.
+The whole-pixel predictor is used if the fractional part of both motion vector
+ components is zero, otherwise the half-pixel predictor is used.
+
+\subsubsection{The Intra Predictor}
+\label{sub:predintra}
+
+\paragraph{Input parameters:} None.
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{PRED}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & An $8\times 8$ array of predictor
+ values to use for INTRA coded blocks. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\idx{bx}}  & Integer &  3 & No  & The horizontal pixel index in the
+ block. \\
+\locvar{\idx{by}}  & Integer &  3 & No  & The vertical pixel index in the
+ block. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The intra predictor is nothing more than the constant value $128$.
+This is applied for the sole purpose of centering the range of possible DC
+ values for INTRA blocks around zero.
+
+\begin{enumerate}
+\item
+For each value of \locvar{\idx{by}} from $0$ to $7$, inclusive:
+\begin{enumerate}
+\item
+For each value of \locvar{\idx{bx}} from $0$ to $7$, inclusive:
+\begin{enumerate}
+\item
+Assign $\bitvar{PRED}[\locvar{\idx{by}}][\locvar{\idx{bx}}]$ the value $128$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\subsubsection{The Whole-Pixel Predictor}
+\label{sub:predfullpel}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RPW}   & Integer   & 20 & No  & The width of the current plane of the
+ reference frame in pixels. \\
+\bitvar{RPH}   & Integer   & 20 & No  & The height of the current plane of the
+ reference frame in pixels. \\
+\bitvar{REFP}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of the current plane of the reference frame. \\
+\bitvar{BX}    & Integer   & 20 & No  & The horizontal pixel index of the
+ lower-left corner of the current block. \\
+\bitvar{BY}    & Integer   & 20 & No  & The vertical pixel index of the
+ lower-left corner of the current block. \\
+\bitvar{MVX}   & Integer   &  5 & No  & The horizontal component of the block
+ motion vector.
+This is always a whole-pixel value. \\
+\bitvar{MVY}   & Integer   &  5 & No  & The vertical component of the block
+ motion vector.
+This is always a whole-pixel value. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{PRED}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & An $8\times 8$ array of predictor
+ values to use for INTER coded blocks. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\idx{bx}} & Integer &  3 & Yes & The horizontal pixel index in the
+ block. \\
+\locvar{\idx{by}} & Integer &  3 & Yes & The vertical pixel index in the
+ block. \\
+\locvar{\idx{rx}} & Integer & 20 & No  & The horizontal pixel index in the
+ reference frame. \\
+\locvar{\idx{ry}} & Integer & 20 & No  & The vertical pixel index in the
+ reference frame. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The whole pixel predictor simply copies verbatim the contents of the reference
+ frame pointed to by the block's motion vector.
+If the vector points outside the reference frame, then the closest value on the
+ edge of the reference frame is used instead.
+In practice, this is usually implemented by expanding the size of the reference
+ frame by $8$ or $16$ pixels on each side---depending on whether or not the
+ corresponding axis is subsampled in the current plane---and copying the border
+ pixels into this region.
+
+\begin{enumerate}
+\item
+For each value of \locvar{\idx{by}} from $0$ to $7$, inclusive:
+\begin{enumerate}
+\item
+Assign \locvar{\idx{ry}} the value
+ $(\bitvar{BY}+\bitvar{MVY}+\locvar{\idx{by}})$.
+\item
+If \locvar{\idx{ry}} is greater than $(\bitvar{RPH}-1)$, assign
+ \locvar{\idx{ry}} the value $(\bitvar{RPH}-1)$.
+\item
+If \locvar{\idx{ry}} is less than zero, assign \locvar{\idx{ry}} the value
+ zero.
+\item
+For each value of \locvar{\idx{bx}} from $0$ to $7$, inclusive:
+\begin{enumerate}
+\item
+Assign \locvar{\idx{rx}} the value
+ $(\bitvar{BX}+\bitvar{MVX}+\locvar{\idx{bx}})$.
+\item
+If \locvar{\idx{rx}} is greater than $(\bitvar{RPW}-1)$, assign
+ \locvar{\idx{rx}} the value $(\bitvar{RPW}-1)$.
+\item
+If \locvar{\idx{rx}} is less than zero, assign \locvar{\idx{rx}} the value
+ zero.
+\item
+Assign $\bitvar{PRED}[\locvar{\idx{by}}][\locvar{\idx{bx}}]$ the value
+ $\bitvar{REFP}[\locvar{\idx{ry}}][\locvar{\idx{rx}}]$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\subsubsection{The Half-Pixel Predictor}
+\label{sub:predhalfpel}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RPW}   & Integer   & 20 & No  & The width of the current plane of the
+ reference frame in pixels. \\
+\bitvar{RPH}   & Integer   & 20 & No  & The height of the current plane of the
+ reference frame in pixels. \\
+\bitvar{REFP}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of the current plane of the reference frame. \\
+\bitvar{BX}    & Integer   & 20 & No  & The horizontal pixel index of the
+ lower-left corner of the current block. \\
+\bitvar{BY}    & Integer   & 20 & No  & The vertical pixel index of the
+ lower-left corner of the current block. \\
+\bitvar{MVX}   & Integer   &  5 & No  & The horizontal component of the first
+ whole-pixel motion vector. \\
+\bitvar{MVY}   & Integer   &  5 & No  & The vertical component of the first
+ whole-pixel motion vector. \\
+\bitvar{MVX2}  & Integer   &  5 & No  & The horizontal component of the second
+ whole-pixel motion vector. \\
+\bitvar{MVY2}  & Integer   &  5 & No  & The vertical component of the second
+ whole-pixel motion vector. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{PRED}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & An $8\times 8$ array of predictor
+ values to use for INTER coded blocks. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\idx{bx}} & Integer &  3 & Yes & The horizontal pixel index in the
+ block. \\
+\locvar{\idx{by}} & Integer &  3 & Yes & The vertical pixel index in the
+ block. \\
+\locvar{\idx{rx1}} & Integer & 20 & No  & The first horizontal pixel index in
+ the reference frame. \\
+\locvar{\idx{ry1}} & Integer & 20 & No  & The first vertical pixel index in the
+ reference frame. \\
+\locvar{\idx{rx2}} & Integer & 20 & No  & The second horizontal pixel index in
+ the reference frame. \\
+\locvar{\idx{ry2}} & Integer & 20 & No  & The second vertical pixel index in
+ the reference frame. \\
+\bottomrule\end{tabularx}
+\medskip
+
+If one or both of the components of the block motion vector is not a
+ whole-pixel value, then the half-pixel predictor is used.
+The half-pixel predictor converts the fractional motion vector into two
+ whole-pixel motion vectors.
+The first is formed by truncating the values of each component towards zero,
+ and the second is formed by truncating them away from zero.
+The contributions from the reference frame at the locations pointed to by each
+ vector are averaged, truncating towards negative infinity.
+
+Only two samples from the reference frame contribute to each predictor value,
+ even if both components of the motion vector have non-zero fractional
+ components.
+Motion vector components with quarter-pixel accuracy in the chroma planes are
+ treated exactly the same as those with half-pixel accuracy.
+Any non-zero fractional part gets rounded one way in the first vector, and the
+ other way in the second.
+
+\begin{enumerate}
+\item
+For each value of \locvar{\idx{by}} from $0$ to $7$, inclusive:
+\begin{enumerate}
+\item
+Assign \locvar{\idx{ry1}} the value
+ $(\bitvar{BY}+\bitvar{MVY1}+\locvar{\idx{by}})$.
+\item
+If \locvar{\idx{ry1}} is greater than $(\bitvar{RPH}-1)$, assign
+ \locvar{\idx{ry1}} the value $(\bitvar{RPH}-1)$.
+\item
+If \locvar{\idx{ry1}} is less than zero, assign \locvar{\idx{ry1}} the value
+ zero.
+\item
+Assign \locvar{\idx{ry2}} the value
+ $(\bitvar{BY}+\bitvar{MVY2}+\locvar{\idx{by}})$.
+\item
+If \locvar{\idx{ry2}} is greater than $(\bitvar{RPH}-1)$, assign
+ \locvar{\idx{ry2}} the value $(\bitvar{RPH}-1)$.
+\item
+If \locvar{\idx{ry2}} is less than zero, assign \locvar{\idx{ry2}} the value
+ zero.
+\item
+For each value of \locvar{\idx{bx}} from $0$ to $7$, inclusive:
+\begin{enumerate}
+\item
+Assign \locvar{\idx{rx1}} the value
+ $(\bitvar{BX}+\bitvar{MVX1}+\locvar{\idx{bx}})$.
+\item
+If \locvar{\idx{rx1}} is greater than $(\bitvar{RPW}-1)$, assign
+ \locvar{\idx{rx1}} the value $(\bitvar{RPW}-1)$.
+\item
+If \locvar{\idx{rx1}} is less than zero, assign \locvar{\idx{rx1}} the value
+ zero.
+\item
+Assign \locvar{\idx{rx2}} the value
+ $(\bitvar{BX}+\bitvar{MVX2}+\locvar{\idx{bx}})$.
+\item
+If \locvar{\idx{rx2}} is greater than $(\bitvar{RPW}-1)$, assign
+ \locvar{\idx{rx2}} the value $(\bitvar{RPW}-1)$.
+\item
+If \locvar{\idx{rx2}} is less than zero, assign \locvar{\idx{rx2}} the value
+ zero.
+\item
+Assign $\bitvar{PRED}[\locvar{\idx{by}}][\locvar{\idx{bx}}]$ the value
+\begin{equation*}
+ (\bitvar{REFP}[\locvar{\idx{ry1}}][\locvar{\idx{rx1}}]+
+ \bitvar{REFP}[\locvar{\idx{ry2}}][\locvar{\idx{rx2}}])>>1.
+\end{equation*}
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\subsection{Dequantization}
+\label{sub:dequant}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{COEFFS}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                             16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bitvar{ACSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No  & A 64-element array of scale values for
+ AC coefficients for each \qi\ value. \\
+\bitvar{DCSCALE} & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No  & A 64-element array of scale values for
+ the DC coefficient for each \qi\ value. \\
+\bitvar{BMS}     & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              8 & No  & A $\bitvar{NBMS}\times 64$ array
+ containing the base matrices. \\
+\bitvar{NQRS}    & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                              6 & No  & A $2\times 3$ array containing the
+ number of quant ranges for a given \qti\ and \pli, respectively.
+This is at most $63$. \\
+\bitvar{QRSIZES} & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              6 & No  & A $2\times 3\times 63$ array of the
+ sizes of each quant range for a given \qti\ and \pli, respectively.
+Only the first $\bitvar{NQRS}[\qti][\pli]$ values are used. \\
+\bitvar{QRBMIS}  & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                              9 & No  & A $2\times 3\times 64$ array of the
+ \bmi's used for each quant range for a given \qti\ and \pli, respectively.
+Only the first $(\bitvar{NQRS}[\qti][\pli]+1)$ values are used. \\
+\bitvar{\qti}    & Integer &  1 & No  & A quantization type index.
+See Table~\ref{tab:quant-types}.\\
+\bitvar{\pli}    & Integer &  2 & No  & A color plane index.
+See Table~\ref{tab:color-planes}.\\
+\bitvar{\idx{qi0}} & Integer &  6 & No  & The quantization index of the DC
+ coefficient. \\
+\bitvar{\qi}     & Integer &  6 & No  & The quantization index of the AC
+ coefficients. \\
+\bitvar{\bi}     & Integer & 36 & No  & The index of the current block in
+ coded order. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{DQC}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              14 & Yes & A $64$-element array of dequantized
+ DCT coefficients in natural order (cf. Section~\ref{sec:dct-coeffs}). \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{QMAT}    & \multicolumn{1}{p{40pt}}{Integer array} &
+                             16 & No  & A 64-element array of quantization
+ values for each DCT coefficient in natural order. \\
+\locvar{\ci}     & Integer &  6 & No  & The DCT coefficient index in natural
+ order. \\
+\locvar{\zzi}    & Integer &  6 & No  & The DCT coefficient index in zig-zag
+ order. \\
+\locvar{C}       & Integer & 29 & Yes & A single dequantized coefficient. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure takes the quantized DCT coefficient values in zig-zag order for
+ a single block---after DC prediction has been undone---and returns the
+ dequantized values in natural order.
+If large coefficient values are decoded for coarsely quantized coefficients,
+ the resulting dequantized value can be significantly larger than 16 bits.
+Such a coefficient is truncated to a signed 16-bit representation by discarding
+ the higher-order bits of its twos-complement representation.
+
+Although this procedure recomputes the quantization matrices from the
+ parameters in the setup header for each block, there are at most six different
+ ones used for each color plane.
+An efficient implementation could compute them once in advance.
+
+\begin{enumerate}
+\item
+Using \bitvar{ACSCALE}, \bitvar{DCSCALE}, \bitvar{BMS}, \bitvar{NQRS},
+ \bitvar{QRSIZES}, \bitvar{QRBMIS}, \bitvar{\qti}, \bitvar{\pli}, and
+ \bitvar{\idx{qi0}}, use the procedure given in Section~\ref{sub:quant-mat} to
+ compute the DC quantization matrix \locvar{QMAT}.
+\item
+Assign \locvar{C} the value
+ $\bitvar{COEFFS}[\bitvar{\bi}][0]*\locvar{QMAT}[0]$.
+\item
+Truncate \locvar{C} to a 16-bit representation by dropping any higher-order
+ bits.
+\item
+Assign $\bitvar{DQC}[0]$ the value \locvar{C}.
+\item
+Using \bitvar{ACSCALE}, \bitvar{DCSCALE}, \bitvar{BMS}, \bitvar{NQRS},
+ \bitvar{QRSIZES}, \bitvar{QRBMIS}, \bitvar{\qti}, \bitvar{\pli}, and
+ \bitvar{\qi}, use the procedure given in Section~\ref{sub:quant-mat} to
+ compute the AC quantization matrix \locvar{QMAT}.
+\item
+For each value of \locvar{\ci} from 1 to 63, inclusive:
+\begin{enumerate}
+\item
+Assign \locvar{\zzi} the index in zig-zag order corresponding to \locvar{\ci}.
+E.g., the value at row $(\locvar{\ci}//8)$ and column $(\locvar{\ci}\%8)$ in
+ Figure~\ref{tab:zig-zag}
+\item
+Assign \locvar{C} the value
+ $\bitvar{COEFFS}[\bitvar{\bi}][\locvar{\zzi}]*\locvar{QMAT}[\locvar{\ci}]$.
+\item
+Truncate \locvar{C} to a 16-bit representation by dropping any higher-order
+ bits.
+\item
+Assign $\bitvar{DQC}[\locvar{\ci}]$ the value \locvar{C}.
+\end{enumerate}
+\end{enumerate}
+
+\subsection{The Inverse DCT}
+
+The 2D inverse DCT is separated into two applications of the 1D inverse DCT.
+The transform is first applied to each row, and then applied to each column of
+ the result.
+
+Each application of the 1D inverse DCT scales the values by a factor of two
+ relative to the orthonormal version of the transform, for a total scale factor
+ of four for the 2D transform.
+It is assumed that a similar scale factor is applied during the forward DCT
+ used in the encoder, so that a division by 16 is required after the transform
+ has been applied in both directions.
+The inclusion of this scale factor allows the integerized transform to operate
+ with increased precision.
+All divisions throughout the transform are implemented with right shifts.
+Only the final division by $16$ is rounded, with ties rounded towards positive
+ infinity.
+
+All intermediate values are truncated to a 32-bit signed representation by
+ discarding any higher-order bits in their two's complement representation.
+The final output of each 1D transform is truncated to a 16-bit signed value in
+ the same manner.
+In practice, if the high word of a $16\times 16$ bit multiplication can be
+ obtained directly, 16 bits is sufficient for every calculation except scaling
+ by $C4$.
+Thus we truncate to 16 bits before that multiplication to allow an
+ implementation entirely in 16-bit registers.
+Implementations using larger registers must sign-extend the 16-bit value to
+ maintain compatibility.
+
+Note that if 16-bit register are used, overflow in the additions and
+ subtractions should be handled using \textit{unsaturated} arithmetic.
+That is, the high-order bits should be discarded and the low-order bits
+ retained, instead of clamping the result to the maximum or minimum value.
+This allows the maximum flexibility in re-ordering these instructions without
+ deviating from this specification.
+
+The 1D transform can only overflow if input coefficients larger than $\pm 6201$
+ are present.
+However, the result of applying the 2D forward transform on pixel values in the
+ range $-255\ldots 255$ can be as large as $\pm 8157$ due to the scale factor
+ of four that is applied, and quantization errors could make this even larger.
+Therefore, the coefficients cannot simply be clamped into a valid range before
+ the transform.
+
+\subsubsection{The 1D Inverse DCT}
+\label{sub:1d-idct}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{Y}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              16 & Yes & An 8-element array of DCT
+ coefficients. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{X}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              16 & Yes & An 8-element array of output values. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{T}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              32 & Yes & An 8-element array containing the
+ current value of each signal line. \\
+\locvar{R}        & Integer & 32 & Yes & A temporary value. \\
+\bottomrule\end{tabularx}
+\medskip
+
+A compliant decoder MUST use the exact implementation of the inverse DCT
+ defined in this specification.
+Some operations may be re-ordered, but the result must be precisely equivalent.
+This is a design decision that limits some avenues of decoder optimization, but
+ prevents any drift in the prediction loop.
+Theora uses a 16-bit integerized approximation of of the 8-point 1D inverse DCT
+ based on the Chen factorization \cite{CSF77}.
+It requires 16 multiplications and 26 additions and subtractions.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics[width=\textwidth]{idct}
+\end{center}
+\caption{Signal Flow Graph for the 1D Inverse DCT}
+\label{fig:idct}
+\end{figure}
+
+A signal flow graph of the transformation is presented in
+ Figure~\ref{fig:idct}.
+This graph provides a good visualization of which parts of the transform are
+ parallelizable.
+Time increases from left to right.
+
+Each signal line is involved in an operation where the line is marked with a
+ dot $\cdot$ or a circled plus sign $\oplus$.
+The constants $\locvar{C}i$ and $\locvar{S}j$ are the 16-bit integer
+ approximations of $\cos(\frac{i\pi}{16})$ and $\sin(\frac{j\pi}{16})$ listed
+ in Table~\ref{tab:dct-consts}.
+When they appear next to a signal line, the value on that line is scaled by the
+ given constant.
+A circled minus sign $\ominus$ next to a signal line indicates that the value
+ on that line is negated.
+
+Operations on a single signal path through the graph cannot be reordered, but
+ operations on different paths may be, or may be executed in parallel.
+Different graphs may be obtainable using the associative, commutative, and
+ distributive properties of unsaturated arithmetic.
+The column of numbers on the left represents an initial permutation of the
+ input DCT coefficients.
+The column on the right represents the unpermuted output.
+One can be obtained by bit-reversing the 3-bit binary representation of the
+ other.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{llr}\toprule
+$\locvar{C}i$  & $\locvar{S}j$ & Value   \\\midrule
+$\locvar{C1}$  & $\locvar{S7}$ & $64277$ \\
+$\locvar{C2}$  & $\locvar{S6}$ & $60547$ \\
+$\locvar{C3}$  & $\locvar{S5}$ & $54491$ \\
+$\locvar{C4}$  & $\locvar{S4}$ & $46341$ \\
+$\locvar{C5}$  & $\locvar{S3}$ & $36410$ \\
+$\locvar{C6}$  & $\locvar{S2}$ & $25080$ \\
+$\locvar{C7}$  & $\locvar{S1}$ & $12785$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{16-bit Approximations of Sines and Cosines}
+\label{tab:dct-consts}
+\end{table}
+
+\begin{enumerate}
+\item
+Assign $\locvar{T}[0]$ the value $\bitvar{Y}[0]+\bitvar{Y}[4]$.
+\item
+Truncate $\locvar{T}[0]$ to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\locvar{T}[0]$ the value
+ $\locvar{C4}*\locvar{T}[0]>>16$.
+\item
+Assign $\locvar{T}[1]$ the value $\bitvar{Y}[0]-\bitvar{Y}[4]$.
+\item
+Truncate $\locvar{T}[1]$ to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\locvar{T}[1]$ the value $\locvar{C4}*\locvar{T}[1]>>16$.
+\item
+Assign $\locvar{T}[2]$ the value $(\locvar{C6}*\bitvar{Y}[2]>>16)-
+ (\locvar{S6}*\bitvar{Y}[6]>>16)$.
+\item
+Assign $\locvar{T}[3]$ the value $(\locvar{S6}*\bitvar{Y}[2]>>16)+
+ (\locvar{C6}*\bitvar{Y}[6]>>16)$.
+\item
+Assign $\locvar{T}[4]$ the value $(\locvar{C7}*\bitvar{Y}[1]>>16)-
+ (\locvar{S7}*\bitvar{Y}[7]>>16)$.
+\item
+Assign $\locvar{T}[5]$ the value $(\locvar{C3}*\bitvar{Y}[5]>>16)-
+ (\locvar{S3}*\bitvar{Y}[3]>>16)$.
+\item
+Assign $\locvar{T}[6]$ the value $(\locvar{S3}*\bitvar{Y}[5]>>16)+
+ (\locvar{C3}*\bitvar{Y}[3]>>16)$.
+\item
+Assign $\locvar{T}[7]$ the value $(\locvar{S7}*\bitvar{Y}[1]>>16)+
+ (\locvar{C7}*\bitvar{Y}[7]>>16)$.
+\item
+Assign \locvar{R} the value $\locvar{T}[4]+\locvar{T}[5]$.
+\item
+Assign $\locvar{T}[5]$ the value $\locvar{T}[4]-\locvar{T}[5]$.
+\item
+Truncate $\locvar{T}[5]$ to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\locvar{T}[5]$ the value $\locvar{C4}*\locvar{T}[5]>>16$.
+\item
+Assign $\locvar{T}[4]$ the value $\locvar{R}$.
+\item
+Assign \locvar{R} the value $\locvar{T}[7]+\locvar{T}[6]$.
+\item
+Assign $\locvar{T}[6]$ the value $\locvar{T}[7]-\locvar{T}[6]$.
+\item
+Truncate $\locvar{T}[6]$ to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\locvar{T}[6]$ the value $\locvar{C4}*\locvar{T}[6]>>16$.
+\item
+Assign $\locvar{T}[7]$ the value $\locvar{R}$.
+\item
+Assign \locvar{R} the value $\locvar{T}[0]+\locvar{T}[3]$.
+\item
+Assign $\locvar{T}[3]$ the value $\locvar{T}[0]-\locvar{T}[3]$.
+\item
+Assign $\locvar{T}[0]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[1]+\locvar{T}[2]$
+\item
+Assign $\locvar{T}[2]$ the value $\locvar{T}[1]-\locvar{T}[2]$
+\item
+Assign $\locvar{T}[1]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[6]+\locvar{T}[5]$.
+\item
+Assign $\locvar{T}[5]$ the value $\locvar{T}[6]-\locvar{T}[5]$.
+\item
+Assign $\locvar{T}[6]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[0]+\locvar{T}[7]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[0]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[1]+\locvar{T}[6]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[1]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[2]+\locvar{T}[5]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[2]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[3]+\locvar{T}[4]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[3]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[3]-\locvar{T}[4]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[4]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[2]-\locvar{T}[5]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[5]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[1]-\locvar{T}[6]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[6]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[0]-\locvar{T}[7]$.
+\item
+Truncate \locvar{R} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+Assign $\bitvar{X}[7]$ the value \locvar{R}.
+\end{enumerate}
+
+\subsubsection{The 2D Inverse DCT}
+\label{sub:2d-idct}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{DQC}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              14 & Yes & A $64$-element array of dequantized
+ DCT coefficients in natural order (cf. Section~\ref{sec:dct-coeffs}). \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RES}   & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                              16 & Yes & An $8\times 8$ array containing the
+ decoded residual for the current block. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{\ci}     & Integer &  3 & No  & The column index. \\
+\locvar{\ri}     & Integer &  3 & No  & The row index. \\
+\locvar{Y}       & \multicolumn{1}{p{40pt}}{Integer Array} &
+                             16 & Yes & An 8-element array of 1D iDCT input
+ values. \\
+\locvar{X}       & \multicolumn{1}{p{40pt}}{Integer Array} &
+                             16 & Yes & An 8-element array of 1D iDCT output
+ values. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure applies the 1D inverse DCT transform 16 times to a block of
+ dequantized coefficients: once for each of the 8 rows, and once for each of
+ the 8 columns of the result.
+Note that the coordinate system used for the columns is the same right-handed
+ coordinate system used by the rest of Theora.
+Thus, the column is indexed from bottom to top, not top to bottom.
+The final values are divided by sixteen, rounding with ties rounded towards
+ postive infinity.
+
+\begin{enumerate}
+\item
+For each value of \locvar{\ri} from 0 to 7:
+\begin{enumerate}
+\item
+For each value of \locvar{\ci} from 0 to 7:
+\begin{enumerate}
+\item
+Assign $\locvar{Y}[\locvar{\ci}]$ the value
+ $\bitvar{DQC}[\locvar{\ri}*8+\locvar{\ci}]$.
+\end{enumerate}
+\item
+Compute \locvar{X}, the 1D inverse DCT of \locvar{Y} using the procedure
+ described in Section~\ref{sub:1d-idct}.
+\item
+For each value of $\locvar{\ci}$ from 0 to 7:
+\begin{enumerate}
+\item
+Assign $\bitvar{RES}[\locvar{\ri}][\locvar{\ci}]$ the value
+ $\locvar{X}[\locvar{\ci}]$.
+\end{enumerate}
+\end{enumerate}
+\item
+For each value of \locvar{\ci} from 0 to 7:
+\begin{enumerate}
+\item
+For each value of \locvar{\ri} from 0 to 7:
+\begin{enumerate}
+\item
+Assign $\locvar{Y}[\locvar{\ri}]$ the value
+ $\bitvar{RES}[\locvar{\ri}][\locvar{\ci}]$.
+\end{enumerate}
+\item
+Compute \locvar{X}, the 1D inverse DCT of \locvar{Y} using the procedure
+ described in Section~\ref{sub:1d-idct}.
+\item
+For each value of \locvar{\ri} from 0 to 7:
+\begin{enumerate}
+\item
+Assign $\bitvar{RES}[\locvar{\ri}][\locvar{\ci}]$ the value
+ $(\locvar{X}[\locvar{\ri}]+8)>>4$.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\subsubsection{The 1D Forward DCT (Non-Normative)}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{X}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              14 & Yes & An 8-element array of input values. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{Y}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              16 & Yes & An 8-element array of DCT
+ coefficients. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{T}        & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              16 & Yes & An 8-element array containing the
+ current value of each signal line. \\
+\locvar{R}        & Integer & 16 & Yes & A temporary value. \\
+\bottomrule\end{tabularx}
+\medskip
+
+The forward transform used in the encoder is not mandated by this standard as
+ the inverse one is.
+Precise equivalence in the inverse transform alone is all that is required to
+ guarantee that there is no mismatch in the prediction loop between encoder and
+ any compliant decoder implementation.
+However, a forward transform is provided here as a convenience for implementing
+ an encoder.
+This is the version of the transform used by Xiph.org's Theora encoder, which
+ is the same as that used by VP3.
+Like the inverse DCT, it is first applied to each row, and then applied to each
+ column of the result.
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics[width=\textwidth]{fdct}
+\end{center}
+\caption{Signal Flow Graph for the 1D Forward DCT}
+\label{fig:fdct}
+\end{figure}
+
+The signal flow graph for the forward transform is given in
+ Figure~\ref{fig:fdct}.
+It is largely the reverse of the flow graph given for the inverse DCT.
+It is important to note that the signs on the constants in the rotations have
+ changed, and the \locvar{C4} scale factors on one of the lower butterflies now
+ appear on the opposite side.
+The column of numbers on the left represents the unpermuted input, and the
+ column on the right the permuted output DCT coefficients.
+
+A proper division by $2^{16}$ is done after the multiplications instead of a
+ shift in the forward transform.
+This can be implemented quickly by adding an offset of $\hex{FFFF}$ if the
+ number is negative, and then shifting as before.
+This slightly increases the computational complexity of the transform.
+Unlike the inverse DCT, 16-bit registers and a $16\times16\rightarrow32$ bit
+ multiply are sufficient to avoid any overflow, so long as the input is in the
+ range $-6270\ldots 6270$, which is larger than required.
+
+\begin{enumerate}
+\item
+Assign $\locvar{T}[0]$ the value $\bitvar{X}[0]+\bitvar{X}[7]$.
+\item
+Assign $\locvar{T}[1]$ the value $\bitvar{X}[1]+\bitvar{X}[6]$.
+\item
+Assign $\locvar{T}[2]$ the value $\bitvar{X}[2]+\bitvar{X}[5]$.
+\item
+Assign $\locvar{T}[3]$ the value $\bitvar{X}[3]+\bitvar{X}[4]$.
+\item
+Assign $\locvar{T}[4]$ the value $\bitvar{X}[3]-\bitvar{X}[4]$.
+\item
+Assign $\locvar{T}[5]$ the value $\bitvar{X}[2]-\bitvar{X}[5]$.
+\item
+Assign $\locvar{T}[6]$ the value $\bitvar{X}[1]-\bitvar{X}[6]$.
+\item
+Assign $\locvar{T}[7]$ the value $\bitvar{X}[0]-\bitvar{X}[7]$.
+\item
+Assign \locvar{R} the value $\locvar{T}[0]+\locvar{T}[3]$.
+\item
+Assign $\locvar{T}[3]$ the value $\locvar{T}[0]-\locvar{T}[3]$.
+\item
+Assign $\locvar{T}[0]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[1]+\locvar{T}[2]$.
+\item
+Assign $\locvar{T}[2]$ the value $\locvar{T}[1]-\locvar{T}[2]$.
+\item
+Assign $\locvar{T}[1]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[6]-\locvar{T}[5]$.
+\item
+Assign $\locvar{T}[6]$ the value
+ $(\locvar{C4}*(\locvar{T}[6]+\locvar{T}[5]))//16$.
+\item
+Assign $\locvar{T}[5]$ the value $(\locvar{C4}*\locvar{R})//16$.
+\item
+Assign \locvar{R} the value $\locvar{T}[4]+\locvar{T}[5]$.
+\item
+Assign $\locvar{T}[5]$ the value $\locvar{T}[4]-\locvar{T}[5]$.
+\item
+Assign $\locvar{T}[4]$ the value \locvar{R}.
+\item
+Assign \locvar{R} the value $\locvar{T}[7]+\locvar{T}[6]$.
+\item
+Assign $\locvar{T}[6]$ the value $\locvar{T}[7]-\locvar{T}[6]$.
+\item
+Assign $\locvar{T}[7]$ the value \locvar{R}.
+\item
+Assign $\bitvar{Y}[0]$ the value
+ $(\locvar{C4}*(\locvar{T}[0]+\locvar{T}[1]))//16$.
+\item
+Assign $\bitvar{Y}[4]$ the value
+ $(\locvar{C4}*(\locvar{T}[0]-\locvar{T}[1]))//16$.
+\item
+Assign $\bitvar{Y}[2]$ the value
+ $((\locvar{S6}*\locvar{T}[3])//16)+
+ ((\locvar{C6}*\locvar{T}[2])//16)$.
+\item
+Assign $\bitvar{Y}[6]$ the value
+ $((\locvar{C6}*\locvar{T}[3])//16)-
+ ((\locvar{S6}*\locvar{T}[2])//16)$.
+\item
+Assign $\bitvar{Y}[1]$ the value
+ $((\locvar{S7}*\locvar{T}[7])//16)+
+ ((\locvar{C7}*\locvar{T}[4])//16)$.
+\item
+Assign $\bitvar{Y}[5]$ the value
+ $((\locvar{S3}*\locvar{T}[6])//16)+
+ ((\locvar{C3}*\locvar{T}[5])//16)$.
+\item
+Assign $\bitvar{Y}[3]$ the value
+ $((\locvar{C3}*\locvar{T}[6])//16)-
+ ((\locvar{S3}*\locvar{T}[5])//16)$.
+\item
+Assign $\bitvar{Y}[7]$ the value
+ $((\locvar{C7}*\locvar{T}[7])//16)-
+ ((\locvar{S7}*\locvar{T}[4])//16)$.
+\end{enumerate}
+
+\subsection{The Complete Reconstruction Algorithm}
+\label{sub:recon}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{ACSCALE}   & \multicolumn{1}{p{40pt}}{Integer array} &
+                               16 & No  & A 64-element array of scale values
+ for AC coefficients for each \qi\ value. \\
+\bitvar{DCSCALE}   & \multicolumn{1}{p{40pt}}{Integer array} &
+                               16 & No  & A 64-element array of scale values
+ for the DC coefficient for each \qi\ value. \\
+\bitvar{BMS}       & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                                8 & No  & A $\bitvar{NBMS}\times 64$ array
+ containing the base matrices. \\
+\bitvar{NQRS}      & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                                6 & No  & A $2\times 3$ array containing the
+ number of quant ranges for a given \qti\ and \pli, respectively.
+This is at most $63$. \\
+\bitvar{QRSIZES}   & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                                6 & No  & A $2\times 3\times 63$ array of the
+ sizes of each quant range for a given \qti\ and \pli, respectively.
+Only the first $\bitvar{NQRS}[\qti][\pli]$ values are used. \\
+\bitvar{QRBMIS}    & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                                9 & No  & A $2\times 3\times 64$ array of the
+ \bmi's used for each quant range for a given \qti\ and \pli, respectively.
+Only the first $(\bitvar{NQRS}[\qti][\pli]+1)$ values are used. \\
+\bitvar{RPYW}      & Integer & 20 & No  & The width of the $Y'$ plane of the
+ reference frames in pixels. \\
+\bitvar{RPYH}      & Integer & 20 & No  & The height of the $Y'$ plane of the
+ reference frames in pixels. \\
+\bitvar{RPCW}      & Integer & 20 & No  & The width of the $C_b$ and $C_r$
+ planes of the reference frames in pixels. \\
+\bitvar{RPCH}      & Integer & 20 & No  & The height of the $C_b$ and $C_r$
+ planes of the reference frames in pixels. \\
+\bitvar{GOLDREFY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the golden reference
+ frame. \\
+\bitvar{GOLDREFCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the golden reference
+ frame. \\
+\bitvar{GOLDREFCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the golden reference
+ frame. \\
+\bitvar{PREVREFY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the previous reference
+ frame. \\
+\bitvar{PREVREFCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the previous reference
+ frame. \\
+\bitvar{PREVREFCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the previous reference
+ frame. \\
+\bitvar{NBS}       & Integer & 36 & No  & The total number of blocks in a
+ frame. \\
+\bitvar{BCODED}    & \multicolumn{1}{p{40pt}}{Integer Array} &
+                                1 & No  & An \bitvar{NBS}-element array of
+ flags indicating which blocks are coded. \\
+\bitvar{MBMODES}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                                3 & No  & An \bitvar{NMBS}-element array of
+ coding modes for each macro block. \\
+\bitvar{MVECTS}    & \multicolumn{1}{p{50pt}}{Array of 2D Integer Vectors} &
+                                6 & Yes & An \bitvar{NBS}-element array of
+ motion vectors for each block. \\
+\bitvar{COEFFS}    & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\bitvar{NCOEFFS}   & \multicolumn{1}{p{40pt}}{Integer Array} &
+                                7 & No  & An \bitvar{NBS}-element array of the
+ coefficient count for each block. \\
+\bitvar{QIS}       & \multicolumn{1}{p{40pt}}{Integer array} &
+                                6 & No  & An \bitvar{NQIS}-element array of
+ \qi\ values. \\
+\bitvar{QIIS}      & \multicolumn{1}{p{40pt}}{Integer Array} &
+                                2 & No  & An \bitvar{NBS}-element array of
+ \locvar{\qii} values for each block. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RECY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the reconstructed frame. \\
+\bitvar{RECCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the reconstructed frame. \\
+\bitvar{RECCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the reconstructed frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{RPW}       & Integer & 20 & No  & The width of the current plane of the
+ current reference frame in pixels. \\
+\locvar{RPH}       & Integer & 20 & No  & The height of the current plane of
+ the current reference frame in pixels. \\
+\locvar{REFP}      & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of the current plane of the current reference
+ frame. \\
+\locvar{BX}        & Integer & 20 & No  & The horizontal pixel index of the
+ lower-left corner of the current block. \\
+\locvar{BY}        & Integer & 20 & No  & The vertical pixel index of the
+ lower-left corner of the current block. \\
+\locvar{MVX}       & Integer &  5 & No  & The horizontal component of the first
+ whole-pixel motion vector. \\
+\locvar{MVY}       & Integer &  5 & No  & The vertical component of the first
+ whole-pixel motion vector. \\
+\locvar{MVX2}      & Integer &  5 & No  & The horizontal component of the second
+ whole-pixel motion vector. \\
+\locvar{MVY2}      & Integer &  5 & No  & The vertical component of the second
+ whole-pixel motion vector. \\
+\locvar{PRED}      & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & An $8\times 8$ array of predictor
+ values to use for the current block. \\
+\locvar{RES}       & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               16 & Yes & An $8\times 8$ array containing the
+ decoded residual for the current block. \\
+\locvar{QMAT}      & \multicolumn{1}{p{40pt}}{Integer array} &
+                               16 & No  & A 64-element array of quantization
+ values for each DCT coefficient in natural order. \\
+\locvar{DC}        & Integer & 29 & Yes & The dequantized DC coefficient of a
+ block. \\
+\locvar{P}         & Integer & 17 & Yes & A reconstructed pixel value. \\
+\locvar{\bi}       & Integer & 36 & No  & The index of the current block in
+ coded order. \\
+\locvar{\mbi}      & Integer & 32 & No  & The index of the macro block
+ containing block \locvar{\bi}. \\
+\locvar{\pli}      & Integer &  2 & No  & The color plane index of the current
+ block. \\
+\locvar{\rfi}      & Integer &  2 & No  & The index of the reference frame
+ indicated by the coding mode for macro block \locvar{\mbi}. \\
+\locvar{\idx{bx}}  & Integer &  3 & No  & The horizontal pixel index in the
+ block. \\
+\locvar{\idx{by}}  & Integer &  3 & No  & The vertical pixel index in the
+ block. \\
+\locvar{\qti}      & Integer &  1 & No  & A quantization type index.
+See Table~\ref{tab:quant-types}.\\
+\locvar{\idx{qi0}} & Integer &  6 & No  & The quantization index of the DC
+ coefficient. \\
+\locvar{\qi}       & Integer &  6 & No  & The quantization index of the AC
+ coefficients. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This section takes the decoded packet data and uses the previously defined
+ procedures to reconstruct each block of the current frame.
+For coded blocks, a predictor is formed using the coding mode and, if
+ applicable, the motion vector, and then the residual is computed from the
+ quantized DCT coefficients.
+For uncoded blocks, the contents of the co-located block are copied from the
+ previous frame and the residual is cleared to zero.
+Then the predictor and residual are added, and the result clamped to the range
+ $0\ldots 255$ and stored in the current frame.
+
+In the special case that a block contains only a DC coefficient, the
+ dequantization and inverse DCT transform is skipped.
+Instead the constant pixel value for the entire block is computed in one step.
+Note that the truncation of intermediate operations is omitted and the final
+ rounding is slightly different in this case.
+The check for whether or not the block contains only a DC coefficient is based
+ on the coefficient count returned from the token decode procedure of
+ Section~\ref{sec:dct-decode}, and not by checking to see if the remaining
+ coefficient values are zero.
+Also note that even when the coefficient count indicates the block contains
+ zero coefficients, the DC coefficient is still processed, as undoing DC
+ prediction might have made it non-zero.
+
+After this procedure, the frame is completely reconstructed, but before it can
+ be used as a reference frame, a loop filter must be run over it to help reduce
+ blocking artifacts.
+This is detailed in Section~\ref{sec:loopfilter}.
+
+\begin{enumerate}
+\item
+Assign \locvar{\idx{qi0}} the value $\bitvar{QIS}[0]$.
+\item
+For each value of \locvar{\bi} from 0 to $(\bitvar{NBS}-1)$:
+\begin{enumerate}
+\item
+Assign \locvar{\pli} the index of the color plane block \locvar{\bi} belongs
+ to.
+\item
+Assign \locvar{BX} the horizontal pixel index of the lower-left corner of block
+ \locvar{\bi}.
+\item
+Assign \locvar{BY} the vertical pixel index of the lower-left corner of block
+ \locvar{\bi}.
+\item
+If $\bitvar{BCODED}[\locvar{\bi}]$ is non-zero:
+\begin{enumerate}
+\item
+Assign \locvar{\mbi} the index of the macro block containing block
+ \locvar{\bi}.
+\item
+If $\bitvar{MBMODES}[\locvar{\mbi}]$ is 1 (INTRA), assign \locvar{\qti} the
+ value $0$.
+\item
+Otherwise, assign \locvar{\qti} the value $1$.
+\item
+Assign \locvar{\rfi} the value of the Reference Frame Index column of
+ Table~\ref{tab:cm-refs} corresponding to $\bitvar{MBMODES}[\locvar{\mbi}]$.
+\item
+If \locvar{\rfi} is zero, compute \locvar{PRED} using the procedure given in
+ Section~\ref{sub:predintra}.
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Assign \locvar{REFP}, \locvar{RPW}, and \locvar{RPH} the values given in
+ Table~\ref{tab:refp} corresponding to current value of \locvar{\rfi} and
+ \locvar{\pli}.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{cclll}\toprule
+\locvar{\rfi} & \locvar{\pli} &
+\locvar{REFP} & \locvar{RPW} & \locvar{RPH} \\\midrule
+$1$ & $0$ & \bitvar{PREVREFY}  & \bitvar{RPYW} & \bitvar{RPYH} \\
+$1$ & $1$ & \bitvar{PREVREFCB} & \bitvar{RPCW} & \bitvar{RPCH} \\
+$1$ & $2$ & \bitvar{PREVREFCR} & \bitvar{RPCW} & \bitvar{RPCH} \\
+$2$ & $0$ & \bitvar{GOLDREFY}  & \bitvar{RPYW} & \bitvar{RPYH} \\
+$2$ & $1$ & \bitvar{GOLDREFCB} & \bitvar{RPCW} & \bitvar{RPCH} \\
+$2$ & $2$ & \bitvar{GOLDREFCR} & \bitvar{RPCW} & \bitvar{RPCH} \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Reference Planes and Sizes for Each \locvar{\rfi} and \locvar{\pli}}
+\label{tab:refp}
+\end{table}
+
+\item
+Assign \locvar{MVX} the value
+\begin{equation*}
+ \left\lfloor\lvert\bitvar{MVECTS}[\locvar{\bi}]_x\rvert\right\rfloor*
+ \sign(\bitvar{MVECTS}[\locvar{\bi}]_x).
+\end{equation*}
+\item
+Assign \locvar{MVY} the value
+\begin{equation*}
+ \left\lfloor\lvert\bitvar{MVECTS}[\locvar{\bi}]_y\rvert\right\rfloor*
+ \sign(\bitvar{MVECTS}[\locvar{\bi}]_y).
+\end{equation*}
+\item
+Assign \locvar{MVX2} the value
+\begin{equation*}
+ \left\lceil\lvert\bitvar{MVECTS}[\locvar{\bi}]_x\rvert\right\rceil*
+ \sign(\bitvar{MVECTS}[\locvar{\bi}]_x).
+\end{equation*}
+\item
+Assign \locvar{MVY2} the value
+\begin{equation*}
+ \left\lceil\lvert\bitvar{MVECTS}[\locvar{\bi}]_y\rvert\right\rceil*
+ \sign(\bitvar{MVECTS}[\locvar{\bi}]_y).
+\end{equation*}
+\item
+If \locvar{MVX} equals \locvar{MVX2} and \locvar{MVY} equals \locvar{MVY2},
+ use the values \locvar{REFP}, \locvar{RPW}, \locvar{RPH}, \locvar{BX},
+ \locvar{BY}, \locvar{MVX}, and \locvar{MVY}, compute \locvar{PRED} using the
+ procedure given in Section~\ref{sub:predfullpel}.
+\item
+Otherwise, use the values \locvar{REFP}, \locvar{RPW}, \locvar{RPH},
+ \locvar{BX}, \locvar{BY}, \locvar{MVX}, \locvar{MVY}, \locvar{MVX2}, and
+ \locvar{MVY2} to compute \locvar{PRED} using the procedure given in
+ Section~\ref{sub:predhalfpel}.
+\end{enumerate}
+\item
+If $\bitvar{NCOEFFS}[\locvar{\bi}]$ is less than 2:
+\begin{enumerate}
+\item
+Using \bitvar{ACSCALE}, \bitvar{DCSCALE}, \bitvar{BMS}, \bitvar{NQRS}, \\
+ \bitvar{QRSIZES}, \bitvar{QRBMIS}, \locvar{\qti}, \locvar{\pli}, and
+ \locvar{\idx{qi0}}, use the procedure given in Section~\ref{sub:quant-mat} to
+ compute the DC quantization matrix \locvar{QMAT}.
+\item
+Assign \locvar{DC} the value
+\begin{equation*}
+ (\bitvar{COEFFS}[\bitvar{\bi}][0]*\locvar{QMAT}[0]+15)>>5.
+\end{equation*}
+\item
+Truncate \locvar{DC} to a 16-bit signed representation by dropping any
+ higher-order bits.
+\item
+For each value of \locvar{\idx{by}} from 0 to 7, and each value of
+ \locvar{\idx{bx}} from 0 to 7, assign
+ $\locvar{RES}[\locvar{\idx{by}}][\locvar{\idx{bx}}]$ the value \locvar{DC}.
+\end{enumerate}
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Assign \locvar{\qi} the value $\bitvar{QIS}[\bitvar{QIIS}[\locvar{\bi}]]$.
+\item
+Using \bitvar{ACSCALE}, \bitvar{DCSCALE}, \bitvar{BMS}, \bitvar{NQRS}, \\
+ \bitvar{QRSIZES}, \bitvar{QRBMIS}, \locvar{\qti}, \locvar{\pli},
+ \locvar{\idx{qi0}}, and \locvar{\qi}, compute \locvar{DQC} using the procedure
+ given in Section~\ref{sub:dequant}.
+\item
+Using \locvar{DQC}, compute \locvar{RES} using the procedure given in
+ Section~\ref{sub:2d-idct}.
+\end{enumerate}
+\end{enumerate}
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Assign \locvar{\rfi} the value 1.
+\item
+Assign \locvar{REFP}, \locvar{RPW}, and \locvar{RPH} the values given in
+ Table~\ref{tab:refp} corresponding to current value of \locvar{\rfi} and
+ \locvar{\pli}.
+\item
+Assign \locvar{MVX} the value 0.
+\item
+Assign \locvar{MVY} the value 0.
+\item
+Using the values \locvar{REFP}, \locvar{RPW}, \locvar{RPH}, \locvar{BX},
+ \locvar{BY}, \locvar{MVX}, and \locvar{MVY}, compute \locvar{PRED} using the
+ procedure given in Section~\ref{sub:predfullpel}.
+This is simply a copy of the co-located block in the previous reference frame.
+\item
+For each value of \locvar{\idx{by}} from 0 to 7, and each value of
+ \locvar{\idx{bx}} from 0 to 7, assign
+ $\locvar{RES}[\locvar{\idx{by}}][\locvar{\idx{bx}}]$ the value 0.
+\end{enumerate}
+\item
+For each value of \locvar{\idx{by}} from 0 to 7, and each value of
+ \locvar{\idx{bx}} from 0 to 7:
+\begin{enumerate}
+\item
+Assign \locvar{P} the value
+ $(\locvar{PRED}[\locvar{\idx{by}}][\locvar{\idx{bx}}]+
+ \locvar{RES}[\locvar{\idx{by}}][\locvar{\idx{bx}}])$.
+\item
+If \locvar{P} is greater than $255$, assign \locvar{P} the value $255$.
+\item
+If \locvar{P} is less than $0$, assign \locvar{P} the value $0$.
+\item
+If \locvar{\pli} equals 0, assign
+ $\bitvar{RECY}[\locvar{BY}+\locvar{\idx{by}}][\locvar{BX}+\locvar{\idx{bx}}]$
+ the value \locvar{P}.
+\item
+Otherwise, if \locvar{\pli} equals 1, assign
+ $\bitvar{RECB}[\locvar{BY}+\locvar{\idx{by}}][\locvar{BX}+\locvar{\idx{bx}}]$
+ the value \locvar{P}.
+\item
+Otherwise, \locvar{\pli} equals 2, so assign
+ $\bitvar{RECR}[\locvar{BY}+\locvar{\idx{by}}][\locvar{BX}+\locvar{\idx{bx}}]$
+ the value \locvar{P}.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\section{Loop Filtering}
+\label{sec:loopfilter}
+
+\begin{figure}[htbp]
+\begin{center}
+\includegraphics{lflim}
+\end{center}
+\caption{The loop filter response function.}
+\label{fig:lflim}
+\end{figure}
+
+The loop filter is a simple deblocking filter that is based on running a small
+ edge detecting filter over the coded block edges and adjusting the pixel
+ values by a tapered response.
+The filter response is modulated by the following non-linear function:
+\begin{align*}
+\lflim(\locvar{R},\bitvar{L})&=\left\{\begin{array}{ll}
+0,                        & \locvar{R}\le-2*\bitvar{L} \\
+-\locvar{R}-2*\bitvar{L}, & -2*\bitvar{L}<\locvar{R}\le-\bitvar{L} \\
+\locvar{R},               & -\bitvar{L}<\locvar{R}<\bitvar{L} \\
+-\locvar{R}+2*\bitvar{L}, & \bitvar{L}\le\locvar{R}<2*\bitvar{L} \\
+0,                        & 2*\bitvar{L}\le\locvar{R}
+\end{array}\right.
+\end{align*}
+Here \bitvar{L} is a limiting value equal to $\bitvar{LFLIMS}[\idx{qi0}]$.
+It defines the peaks of the function, illustrated in Figure~\ref{fig:lflim}.
+\bitvar{LFLIMS} is an array of values specified in the setup header and is
+ indexed by \idx{qi0}, the first quantization index for the frame, the one used
+ for all the DC coefficients.
+Larger values of \bitvar{L} indicate a stronger filter.
+
+\subsection{Horizontal Filter}
+\label{sub:filth}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RECP}      & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                   8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of a plane of the reconstructed frame. \\
+\bitvar{FX}        & Integer   & 20 & No  & The horizontal pixel index of the
+ lower-left corner of the area to be filtered. \\
+\bitvar{FY}        & Integer   & 20 & No  & The vertical pixel index of the
+ lower-left corner of the area to be filtered. \\
+\bitvar{L}         & Integer   &  7 & No  & The loop filter limit value. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RECP}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of a plane of the reconstructed frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{R}         & Integer &  9 & Yes & The edge detector response. \\
+\locvar{P}         & Integer &  9 & Yes & A filtered pixel value. \\
+\locvar{\idx{by}}  & Integer & 20 & No  & The vertical pixel index in the
+ block. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure applies a $4$-tap horizontal filter to each row of a vertical
+ block edge.
+
+\begin{enumerate}
+\item
+For each value of \locvar{\idx{by}} from $0$ to $7$:
+\begin{enumerate}
+\item
+Assign \locvar{R} the value
+\begin{multline*}
+(\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}]-
+ 3*\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+1]+\\
+ 3*\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+2]-
+ \bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+3]+4)>>3
+\end{multline*}
+\item
+Assign \locvar{P} the value
+ $(\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+1]+
+ \lflim(\locvar{R},\bitvar{L}))$.
+\item
+If \locvar{P} is less than zero, assign
+ $\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+1]$ the value zero.
+\item
+Otherwise, if \locvar{P} is greater than $255$, assign
+ $\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+1]$ the value $255$.
+\item
+Otherwise, assign
+ $\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+1]$ the value
+ \locvar{P}.
+\item
+Assign \locvar{P} the value
+ $(\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+2]-
+ \lflim(\locvar{R},\bitvar{L}))$.
+\item
+If \locvar{P} is less than zero, assign
+ $\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+2]$ the value zero.
+\item
+Otherwise, if \locvar{P} is greater than $255$, assign
+ $\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+2]$ the value $255$.
+\item
+Otherwise, assign
+ $\bitvar{RECP}[\bitvar{FY}+\locvar{\idx{by}}][\bitvar{FX}+2]$ the value
+ \locvar{P}.
+\end{enumerate}
+\end{enumerate}
+
+\subsection{Vertical Filter}
+\label{sub:filtv}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RECP}      & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                   8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of a plane of the reconstructed frame. \\
+\bitvar{FX}        & Integer   & 20 & No  & The horizontal pixel index of the
+ lower-left corner of the area to be filtered. \\
+\bitvar{FY}        & Integer   & 20 & No  & The vertical pixel index of the
+ lower-left corner of the area to be filtered. \\
+\bitvar{L}         & Integer   &  7 & No  & The loop filter limit value. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RECP}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of a plane of the reconstructed frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{R}         & Integer &  9 & Yes & The edge detector response. \\
+\locvar{P}         & Integer &  9 & Yes & A filtered pixel value. \\
+\locvar{\idx{bx}}  & Integer & 20 & No  & The horizontal pixel index in the
+ block. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure applies a $4$-tap vertical filter to each column of a horizontal
+ block edge.
+
+\begin{enumerate}
+\item
+For each value of \locvar{\idx{bx}} from $0$ to $7$:
+\begin{enumerate}
+\item
+Assign \locvar{R} the value
+\begin{multline*}
+(\bitvar{RECP}[\bitvar{FY}][\bitvar{FX}+\locvar{\idx{bx}}]-
+ 3*\bitvar{RECP}[\bitvar{FY}+1][\bitvar{FX}+\locvar{\idx{bx}}]+\\
+ 3*\bitvar{RECP}[\bitvar{FY}+2][\bitvar{FX}+\locvar{\idx{bx}}]-
+ \bitvar{RECP}[\bitvar{FY}+3][\bitvar{FX}+\locvar{\idx{bx}}]+4)>>3
+\end{multline*}
+\item
+Assign \locvar{P} the value
+ $(\bitvar{RECP}[\bitvar{FY}+1][\bitvar{FX}+\locvar{\idx{bx}}]+
+ \lflim(\locvar{R},\bitvar{L}))$.
+\item
+If \locvar{P} is less than zero, assign
+ $\bitvar{RECP}[\bitvar{FY}+1][\bitvar{FX}+\locvar{\idx{bx}}]$ the value zero.
+\item
+Otherwise, if \locvar{P} is greater than $255$, assign
+ $\bitvar{RECP}[\bitvar{FY}+1][\bitvar{FX}+\locvar{\idx{bx}}]$ the value $255$.
+\item
+Otherwise, assign
+ $\bitvar{RECP}[\bitvar{FY}+1][\bitvar{FX}+\locvar{\idx{bx}}]$ the value
+ \locvar{P}.
+\item
+Assign \locvar{P} the value
+ $(\bitvar{RECP}[\bitvar{FY}+2][\bitvar{FX}+\locvar{\idx{bx}}]-
+ \lflim(\locvar{R},\bitvar{L}))$.
+\item
+If \locvar{P} is less than zero, assign
+ $\bitvar{RECP}[\bitvar{FY}+2][\bitvar{FX}+\locvar{\idx{bx}}]$ the value zero.
+\item
+Otherwise, if \locvar{P} is greater than $255$, assign
+ $\bitvar{RECP}[\bitvar{FY}+2][\bitvar{FX}+\locvar{\idx{bx}}]$ the value $255$.
+\item
+Otherwise, assign
+ $\bitvar{RECP}[\bitvar{FY}+2][\bitvar{FX}+\locvar{\idx{bx}}]$ the value
+ \locvar{P}.
+\end{enumerate}
+\end{enumerate}
+
+\subsection{Complete Loop Filter}
+\label{sub:loop-filt}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{LFLIMS}    & \multicolumn{1}{p{40pt}}{Integer array} &
+                              7 & No & A 64-element array of loop filter limit
+ values. \\
+\bitvar{RPYW}      & Integer & 20 & No  & The width of the $Y'$ plane of the
+ reconstruced frame in pixels. \\
+\bitvar{RPYH}      & Integer & 20 & No  & The height of the $Y'$ plane of the
+ reconstruced frame in pixels. \\
+\bitvar{RPCW}      & Integer & 20 & No  & The width of the $C_b$ and $C_r$
+ planes of the reconstruced frame in pixels. \\
+\bitvar{RPCH}      & Integer & 20 & No  & The height of the $C_b$ and $C_r$
+ planes of the reconstruced frame in pixels. \\
+\bitvar{NBS}       & Integer & 36 & No  & The total number of blocks in a
+ frame. \\
+\bitvar{BCODED}    & \multicolumn{1}{p{40pt}}{Integer Array} &
+                                1 & No  & An \bitvar{NBS}-element array of
+ flags indicating which blocks are coded. \\
+\bitvar{QIS}       & \multicolumn{1}{p{40pt}}{Integer array} &
+                                6 & No  & An \bitvar{NQIS}-element array of
+ \qi\ values. \\
+\bitvar{RECY}      & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the reconstructed frame. \\
+\bitvar{RECCB}     & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the reconstructed frame. \\
+\bitvar{RECCR}     & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the reconstructed frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RECY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the reconstructed frame. \\
+\bitvar{RECCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the reconstructed frame. \\
+\bitvar{RECCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                               8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the reconstructed frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{RPW}       & Integer & 20 & No  & The width of the current plane of the
+ reconstructed frame in pixels. \\
+\locvar{RPH}       & Integer & 20 & No  & The height of the current plane of
+ the reconstructed frame in pixels. \\
+\locvar{RECP}      & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPH}\times\bitvar{RPW}$
+ array containing the contents of the current plane of the reconstruced
+ frame. \\
+\locvar{BX}        & Integer & 20 & No  & The horizontal pixel index of the
+ lower-left corner of the current block. \\
+\locvar{BY}        & Integer & 20 & No  & The vertical pixel index of the
+ lower-left corner of the current block. \\
+\locvar{FX}        & Integer & 20 & No  & The horizontal pixel index of the
+ lower-left corner of the area to be filtered. \\
+\locvar{FY}        & Integer & 20 & No  & The vertical pixel index of the
+ lower-left corner of the area to be filtered. \\
+\locvar{L}         & Integer &  7 & No  & The loop filter limit value. \\
+\locvar{\bi}       & Integer & 36 & No  & The index of the current block in
+ coded order. \\
+\locvar{\bj}       & Integer & 36 & No  & The index of a neighboring block in
+ coded order. \\
+\locvar{\pli}      & Integer &  2 & No  & The color plane index of the current
+ block. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure defines the order that the various block edges are filtered.
+Because each application of one of the two filters above destructively modifies
+ the contents of the reconstructed image, the precise output obtained differs
+ depending on the order that horizontal and vertical filters are applied to the
+ edges of a single block.
+The order defined here conforms to that used by VP3.
+
+\begin{enumerate}
+\item
+Assign \locvar{L} the value $\bitvar{LFLIMS}[\bitvar{QIS}[0]]$.
+\item
+For each block in {\em raster} order, with coded-order index \locvar{\bi}:
+\begin{enumerate}
+\item
+If $\bitvar{BCODED}[\locvar{\bi}]$ is non-zero:
+\begin{enumerate}
+\item
+Assign \locvar{\pli} the index of the color plane block \locvar{\bi} belongs
+ to.
+\item
+Assign \locvar{RECP}, \locvar{RPW}, and \locvar{RPH} the values given in
+ Table~\ref{tab:recp} corresponding to the value of \locvar{\pli}.
+
+\begin{table}[htbp]
+\begin{center}
+\begin{tabular}{clll}\toprule
+\locvar{\pli} & \locvar{RECP}  & \locvar{RPW}  & \locvar{RPH}  \\\midrule
+$0$           & \bitvar{RECY}  & \bitvar{RPYW} & \bitvar{RPYH} \\
+$1$           & \bitvar{RECCB} & \bitvar{RPCW} & \bitvar{RPCH} \\
+$2$           & \bitvar{RECCR} & \bitvar{RPCW} & \bitvar{RPCH} \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Reconstructed Planes and Sizes for Each \locvar{\pli}}
+\label{tab:recp}
+\end{table}
+
+\item
+Assign \locvar{BX} the horizontal pixel index of the lower-left corner of the
+ block \locvar{\bi}.
+\item
+Assign \locvar{BY} the vertical pixel index of the lower-left corner of the
+ block \locvar{\bi}.
+\item
+If \locvar{BX} is greater than zero:
+\begin{enumerate}
+\item
+Assign \locvar{FX} the value $(\locvar{BX}-2)$.
+\item
+Assign \locvar{FY} the value \locvar{BY}.
+\item
+Using \locvar{RECP}, \locvar{FX}, \locvar{FY}, and \locvar{L}, apply the
+ horizontal block filter to the left edge of block \locvar{\bi} with the
+ procedure described in Section~\ref{sub:filth}.
+\end{enumerate}
+\item
+If \locvar{BY} is greater than zero:
+\begin{enumerate}
+\item
+Assign \locvar{FX} the value \locvar{BX}.
+\item
+Assign \locvar{FY} the value $(\locvar{BY}-2)$
+\item
+Using \locvar{RECP}, \locvar{FX}, \locvar{FY}, and \locvar{L}, apply the
+ vertical block filter to the bottom edge of block \locvar{\bi} with the
+ procedure described in Section~\ref{sub:filtv}.
+\end{enumerate}
+\item
+If $(\locvar{BX}+8)$ is less than \locvar{RPW} and
+ $\bitvar{BCODED}[\locvar{\bj}]$ is zero, where \locvar{\bj} is the coded-order
+ index of the block adjacent to \locvar{\bi} on the right:
+\begin{enumerate}
+\item
+Assign \locvar{FX} the value $(\locvar{BX}+6)$.
+\item
+Assign \locvar{FY} the value \locvar{BY}.
+\item
+Using \locvar{RECP}, \locvar{FX}, \locvar{FY}, and \locvar{L}, apply the
+ horizontal block filter to the right edge of block \locvar{\bi} with the
+ procedure described in Section~\ref{sub:filth}.
+\end{enumerate}
+\item
+If $(\locvar{BY}+8)$ is less than \locvar{RPH} and
+ $\bitvar{BCODED}[\locvar{\bj}]$ is zero, where \locvar{\bj} is the coded-order
+ index of the block adjacent to \locvar{\bi} above:
+\begin{enumerate}
+\item
+Assign \locvar{FX} the value \locvar{BX}.
+\item
+Assign \locvar{FY} the value $(\locvar{BY}+6)$
+\item
+Using \locvar{RECP}, \locvar{FX}, \locvar{FY}, and \locvar{L}, apply the
+ vertical block filter to the top edge of block \locvar{\bi} with the
+ procedure described in Section~\ref{sub:filtv}.
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+\end{enumerate}
+
+\paragraph{VP3 Compatibility}
+
+The original VP3 decoder implemented unrestricted motion vectors by enlarging
+ the reconstructed frame buffers and repeating the pixels on its edges into the
+ padding region.
+However, for the previous reference frame this padding ocurred before the loop
+ filter was applied, but for the golden reference frame it occurred afterwards.
+
+This means that for the previous reference frame, the padding values were
+ required to be stored separately from the main image values.
+Furthermore, even if the previous and golden reference frames were in fact the
+ same frame, they could have different padding values.
+Finally, the encoder did not apply the loop filter at all, which resulted in
+ artifacts, particularly in near-static scenes, due to prediction-loop
+ mismatch.
+This last can only be considered a bug in the VP3 encoder.
+
+Given all these things, Theora now uniformly applies the loop filter before
+ the reference frames are padded.
+This means it is possible to use the same buffer for the previous and golden
+ reference frames when they do indeed refer to the same frame.
+It also means that on architectures where memory bandwidth is limited, it is
+ possible to avoid storing padding values, and simply clamp the motion vectors
+ applied to each pixel as described in Sections~\ref{sub:predfullpel}
+ and~\ref{sub:predhalfpel}.
+This means that the predicted pixel values along the edges of the frame might
+ differ slightly between VP3 and Theora, but since the VP3 encoder did not
+ apply the loop filter in the first place, this is not likely to impose any
+ serious compatibility issues.
+
+\section{Complete Frame Decode}
+
+\paragraph{Input parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{FMBW}      & Integer & 16 & No  & The width of the frame in macro
+ blocks. \\
+\bitvar{FMBH}      & Integer & 16 & No  & The height of the frame in macro
+ blocks. \\
+\bitvar{NSBS}      & Integer & 32 & No  & The total number of super blocks in a
+ frame. \\
+\bitvar{NBS}       & Integer & 36 & No  & The total number of blocks in a
+ frame. \\
+\bitvar{NMBS}      & Integer & 32 & No  & The total number of macro blocks in a
+ frame. \\
+\bitvar{FRN}       & Integer & 32 & No  & The frame-rate numerator. \\
+\bitvar{FRD}       & Integer & 32 & No  & The frame-rate denominator. \\
+\bitvar{PARN}      & Integer & 24 & No  & The pixel aspect-ratio numerator. \\
+\bitvar{PARD}      & Integer & 24 & No  & The pixel aspect-ratio
+ denominator. \\
+\bitvar{CS}        & Integer &  8 & No  & The color space. \\
+\bitvar{PF}        & Integer &  2 & No  & The pixel format. \\
+\bitvar{NOMBR}     & Integer & 24 & No  & The nominal bitrate of the stream, in
+ bits per second. \\
+\bitvar{QUAL}      & Integer &  6 & No  & The quality hint. \\
+\bitvar{KFGSHIFT}  & Integer &  5 & No  & The amount to shift the key frame
+ number by in the granule position. \\
+\bitvar{LFLIMS}    & \multicolumn{1}{p{40pt}}{Integer array} &
+                                7 & No  & A 64-element array of loop filter
+ limit values. \\
+\bitvar{ACSCALE}   & \multicolumn{1}{p{40pt}}{Integer array} &
+                               16 & No  & A 64-element array of scale values
+ for AC coefficients for each \qi\ value. \\
+\bitvar{DCSCALE}   & \multicolumn{1}{p{40pt}}{Integer array} &
+                               16 & No  & A 64-element array of scale values
+ for the DC coefficient for each \qi\ value. \\
+\bitvar{NBMS}      & Integer & 10 & No  & The number of base matrices. \\
+\bitvar{BMS}       & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                                8 & No  & A $\bitvar{NBMS}\times 64$ array
+ containing the base matrices. \\
+\bitvar{NQRS}      & \multicolumn{1}{p{50pt}}{2D Integer array} &
+                                6 & No  & A $2\times 3$ array containing the
+ number of quant ranges for a given \qti\ and \pli, respectively.
+This is at most $63$. \\
+\bitvar{QRSIZES}   & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                                6 & No  & A $2\times 3\times 63$ array of the
+ sizes of each quant range for a given \qti\ and \pli, respectively.
+Only the first $\bitvar{NQRS}[\qti][\pli]$ values will be used. \\
+\bitvar{QRBMIS}    & \multicolumn{1}{p{50pt}}{3D Integer array} &
+                                9 & No  & A $2\times 3\times 64$ array of the
+ \bmi's used for each quant range for a given \qti\ and \pli, respectively.
+Only the first $(\bitvar{NQRS}[\qti][\pli]+1)$ values will be used. \\
+\bitvar{HTS}       & \multicolumn{3}{l}{Huffman table array}
+                                        & An 80-element array of Huffman tables
+ with up to 32 entries each. \\
+\bitvar{GOLDREFY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the golden reference
+ frame. \\
+\bitvar{GOLDREFCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the golden reference
+ frame. \\
+\bitvar{GOLDREFCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the golden reference
+ frame. \\
+\bitvar{PREVREFY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the previous reference
+ frame. \\
+\bitvar{PREVREFCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the previous reference
+ frame. \\
+\bitvar{PREVREFCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the previous reference
+ frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Output parameters:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\bitvar{RECY}      & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the reconstructed frame. \\
+\bitvar{RECCB}     & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the reconstructed
+ frame. \\
+\bitvar{RECCR}     & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the reconstructed
+ frame. \\
+\bitvar{GOLDREFY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the golden reference
+ frame. \\
+\bitvar{GOLDREFCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the golden reference
+ frame. \\
+\bitvar{GOLDREFCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the golden reference
+ frame. \\
+\bitvar{PREVREFY}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPYH}\times\bitvar{RPYW}$
+ array containing the contents of the $Y'$ plane of the previous reference
+ frame. \\
+\bitvar{PREVREFCB} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_b$ plane of the previous reference
+ frame. \\
+\bitvar{PREVREFCR} & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                                8 & No  & A $\bitvar{RPCH}\times\bitvar{RPCW}$
+ array containing the contents of the $C_r$ plane of the previous reference
+ frame. \\
+\bottomrule\end{tabularx}
+
+\paragraph{Variables used:}\hfill\\*
+\begin{tabularx}{\textwidth}{@{}llrcX@{}}\toprule
+\multicolumn{1}{c}{Name} &
+\multicolumn{1}{c}{Type} &
+\multicolumn{1}{p{30pt}}{\centering Size (bits)} &
+\multicolumn{1}{c}{Signed?} &
+\multicolumn{1}{c}{Description and restrictions} \\\midrule\endhead
+\locvar{FTYPE}   & Integer &  1 & No  & The frame type. \\
+\locvar{NQIS}    & Integer &  2 & No  & The number of \qi\ values. \\
+\locvar{QIS}     & \multicolumn{1}{p{40pt}}{Integer array} &
+                              6 & No  & An \locvar{NQIS}-element array of
+ \qi\ values. \\
+\locvar{BCODED}  & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              1 & No  & An \bitvar{NBS}-element array of flags
+ indicating which blocks are coded. \\
+\locvar{MBMODES} & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              3 & No  & An \bitvar{NMBS}-element array of
+ coding modes for each macro block. \\
+\locvar{MVECTS}  & \multicolumn{1}{p{50pt}}{Array of 2D Integer Vectors} &
+                              6 & Yes & An \bitvar{NBS}-element array of motion
+ vectors for each block. \\
+\locvar{QIIS}    & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              2 & No  & An \bitvar{NBS}-element array of
+ \locvar{\qii} values for each block. \\
+\locvar{COEFFS}  & \multicolumn{1}{p{50pt}}{2D Integer Array} &
+                             16 & Yes & An $\bitvar{NBS}\times 64$ array of
+ quantized DCT coefficient values for each block in zig-zag order. \\
+\locvar{NCOEFFS} & \multicolumn{1}{p{40pt}}{Integer Array} &
+                              7 & No  & An \bitvar{NBS}-element array of the
+ coefficient count for each block. \\
+\bitvar{RPYW}    & Integer & 20 & No  & The width of the $Y'$ plane of the
+ reference frames in pixels. \\
+\bitvar{RPYH}    & Integer & 20 & No  & The height of the $Y'$ plane of the
+ reference frames in pixels. \\
+\bitvar{RPCW}    & Integer & 20 & No  & The width of the $C_b$ and $C_r$
+ planes of the reference frames in pixels. \\
+\bitvar{RPCH}    & Integer & 20 & No  & The height of the $C_b$ and $C_r$
+ planes of the reference frames in pixels. \\
+\locvar{\bi}     & Integer & 36 & No  & The index of the current block in coded
+ order. \\
+\bottomrule\end{tabularx}
+\medskip
+
+This procedure uses all the procedures defined in the previous section of this
+ chapter to decode and reconstruct a complete frame.
+It takes as input values decoded from the headers, as well as the current
+ reference frames.
+As output, it gives the uncropped, reconstructed frame.
+This should be cropped to picture region before display.
+As a special case, a 0-byte packet is treated exactly like an inter frame with
+ no coded blocks.
+
+\begin{enumerate}
+\item
+If the size of the data packet is non-zero:
+\begin{enumerate}
+\item
+Decode the frame header values \locvar{FTYPE}, \locvar{NQIS}, and \locvar{QIS}
+ using the procedure given in Section~\ref{sub:frame-header}.
+\item
+Using \locvar{FTYPE}, \bitvar{NSBS}, and \bitvar{NBS}, decode the list of coded
+ block flags into \locvar{BCODED} using the procedure given in
+ Section~\ref{sub:coded-blocks}.
+\item
+Using \locvar{FTYPE}, \bitvar{NMBS}, \bitvar{NBS}, and \bitvar{BCODED}, decode
+ the macro block coding modes into \locvar{MBMODES} using the procedure given
+ in Section~\ref{sub:mb-modes}.
+\item
+If \locvar{FTYPE} is non-zero (inter frame), using \bitvar{PF}, \bitvar{NMBS},
+ \locvar{MBMODES}, \bitvar{NBS}, and \locvar{BCODED}, decode the motion vectors
+ into \locvar{MVECTS} using the procedure given in Section~\ref{sub:mv-decode}.
+\item
+Using \bitvar{NBS}, \locvar{BCODED}, and \locvar{NQIS}, decode the block-level
+ \qi\ values into \locvar{QIIS} using the procedure given in
+ Section~\ref{sub:block-qis}.
+\item
+Using \bitvar{NBS}, \bitvar{NMBS}, \locvar{BCODED}, and \bitvar{HTS}, decode
+ the DCT coefficients into \locvar{NCOEFFS} and \locvar{NCOEFFS} using the
+ procedure given in Section~\ref{sub:dct-coeffs}.
+\item
+Using \locvar{BCODED} and \locvar{MBMODES}, undo the DC prediction on the DC
+ coefficients stored in \locvar{COEFFS} using the procedure given in
+ Section~\ref{sub:dc-pred-undo}.
+\end{enumerate}
+\item
+Otherwise:
+\begin{enumerate}
+\item
+Assign \locvar{FTYPE} the value 1 (inter frame).
+\item
+Assign \locvar{NQIS} the value 1.
+\item
+Assign $\locvar{QIS}[0]$ the value 63.
+\item
+For each value of \locvar{\bi} from 0 to $(\bitvar{NBS}-1)$, assign
+ $\locvar{BCODED}[\locvar{\bi}]$ the value zero.
+\end{enumerate}
+\item
+Assign \locvar{RPYW} and \locvar{RPYH} the values $(16*\bitvar{FMBW})$ and
+ $(16*\bitvar{FMBH})$, respectively.
+\item
+Assign \locvar{RPCW} and \locvar{RPCH} the values from the row of
+ Table~\ref{tab:rpcwh-for-pf} corresponding to \bitvar{PF}.
+
+\begin{table}[tb]
+\begin{center}
+\begin{tabular}{crr}\toprule
+\bitvar{PF} & \multicolumn{1}{c}{\locvar{RPCW}}
+                                 & \multicolumn{1}{c}{\locvar{RPCH}} \\\midrule
+$0$         &  $8*\bitvar{FMBW}$ &  $8*\bitvar{FMBH}$ \\
+$2$         &  $8*\bitvar{FMBW}$ & $16*\bitvar{FMBH}$ \\
+$3$         & $16*\bitvar{FMBW}$ & $16*\bitvar{FMBH}$ \\
+\bottomrule\end{tabular}
+\end{center}
+\caption{Width and Height of Chroma Planes for each Pixel Format}
+\label{tab:rpcwh-for-pf}
+\end{table}
+
+\item
+Using \bitvar{ACSCALE}, \bitvar{DCSCALE}, \bitvar{BMS}, \bitvar{NQRS},
+ \bitvar{QRSIZES}, \bitvar{QRBMIS}, \bitvar{NBS}, \locvar{BCODED},
+ \locvar{MBMODES}, \locvar{MVECTS}, \locvar{COEFFS}, \locvar{NCOEFFS},
+ \locvar{QIS}, \locvar{QIIS}, \locvar{RPYW}, \locvar{RPYH}, \locvar{RPCW},
+ \locvar{RPCH}, \bitvar{GOLDREFY}, \bitvar{GOLDREFCB}, \bitvar{GOLDREFCR},
+ \bitvar{PREVREFY}, \bitvar{PREVREFCB}, and \bitvar{PREVREFCR}, reconstruct the
+ complete frame into \bitvar{RECY}, \bitvar{RECCB}, and \bitvar{RECCR} using
+ the procedure given in Section~\ref{sub:recon}.
+\item
+Using \bitvar{LFLIMS}, \locvar{RPYW}, \locvar{RPYH}, \locvar{RPCW},
+ \locvar{RPCH}, \bitvar{NBS}, \locvar{BCODED}, and \locvar{QIS}, apply the loop
+ filter to the reconstructed frame in \bitvar{RECY}, \bitvar{RECCB}, and
+ \bitvar{RECCR} using the procedure given in Section~\ref{sub:loop-filt}.
+\item
+If \locvar{FTYPE} is zero (intra frame), assign \bitvar{GOLDREFY},
+ \bitvar{GOLDREFCB}, and \bitvar{GOLDREFCR} the values \bitvar{RECY},
+ \bitvar{RECCB}, and \bitvar{RECCR}, respectively.
+\item
+Assign \bitvar{PREVREFY}, \bitvar{PREVREFCB}, and \bitvar{PREVREFCR} the values
+ \bitvar{RECY}, \bitvar{RECCB}, and \bitvar{RECCR}, respectively.
+\end{enumerate}
+
+%\backmatter
+\appendix
+
+\chapter{Ogg Bitstream Encapsulation}
+\label{app:oggencapsulation}
+
+\section{Overview}
+
+This document specifies the embedding or encapsulation of Theora packets
+ in an Ogg transport stream.
+
+Ogg is a stream oriented wrapper for coded, linear time-based data.
+It provides syncronization, multiplexing, framing, error detection and
+ seeking landmarks for the decoder and complements the raw packet format
+ used by the Theora codec.
+
+This document assumes familiarity with the details of the Ogg standard.
+The Xiph.org documentation provides an overview of the Ogg transport stream
+ format at \url{http://www.xiph.org/ogg/doc/oggstream.html} and a detailed
+ description at \url{http://www.xiph.org/ogg/doc/framing.html}.
+The format is also defined in RFC~3533 \cite{rfc3533}.
+While Theora packets can be embedded in a wide variety of media
+ containers and streaming mechanisms, the Xiph.org Foundation
+ recommends Ogg as the native format for Theora video in file-oriented
+ storage and transmission contexts.
+
+\subsection{MIME type}
+
+The generic MIME type of any Ogg file is {\tt application/ogg}.
+The specific MIME type for the Ogg Theora profile documented here
+is {\tt video/ogg}. This is the MIME type recommended for files
+conforming to this appendix. The recommended filename extension
+is {\tt .ogv}.
+
+Outside of an encapsulation, the mime type {\tt video/theora} may
+ be used to refer specifically to the Theora compressed video stream.
+
+\section{Embedding in a logical bitstream}
+
+Ogg separates the concept of a {\em logical bitstream} consisting of the 
+ framing of a particular sequence of packets and complete within itself 
+ from the {\em physical bitstream} which may consist either of a single
+ logical bitstream or a number of logical bitstreams multiplexed
+ together.
+This section specifies the embedding of Theora packets in a logical Ogg
+ bitstream.
+The mapping of Ogg Theora logical bitstreams into a multiplexed physical Ogg
+ stream is described in the next section.
+
+\subsection{Headers}
+
+The initial identification header packet appears by itself in a 
+ single Ogg page.
+This page defines the start of the logical stream and MUST have
+ the `beginning of stream' flag set.
+
+The second and third header packets (comment metadata and decoder
+ setup data) can together span one or more Ogg pages.
+If there are additional non-normative header packets, they MUST be
+ included in this sequence of pages as well.
+The comment header packet MUST begin the second Ogg page in the logical
+ bitstream, and there MUST be a page break between the last header
+ packet and the first frame data packet.
+
+These two page break requirements facilitate stream identification and
+ simplify header acquisition for seeking and live streaming applications.
+
+All header pages MUST have their granule position field set to zero.
+
+\subsection{Frame data}
+
+The first frame data packet in a logical bitstream MUST begin a new Ogg 
+ page.
+All other data packets are placed one at a time into Ogg pages
+ until the end of the stream.
+Packets can span pages and multiple packets can be placed within any
+ one page.
+The last page in the logical bitstream SHOULD have its 
+ 'end of stream' flag set to indicate complete transmission
+ of the available video.
+
+Frame data pages MUST be marked with a granule position corresponding to
+ the end of the display interval of the last frame/packet that finishes 
+ in that page. See the next section for details.
+
+\subsection{Granule position}
+
+Data packets are marked by a granulepos derived from the count of decodable
+frames after that packet is processed. The field itself is divided into two
+sections, the width of the less significant section being given by the KFGSHIFT
+parameter decoded from the identification header 
+(Section~\ref{sec:idheader}).
+The more significant portion of the field gives the count of coded 
+frames after the coding of the last keyframe in stream, and the less 
+significant portion gives the count of frames since the last keyframe.
+Thus a stream would begin with a split granulepos of $1|0$ (a keyframe),
+followed by $1|1$, $1|2$, $1|3$, etc. Around a  keyframe in the 
+middle of the stream the granulepos sequence might be $1234|35$, 
+$1234|36$, $1234|37$, $1271|0$ (for the keyframe), $1271|1$, and so
+on. In this way the granulepos field increased monotonically as required 
+by the Ogg format, but contains information necessary to efficiently 
+find the previous keyframe to continue decoding after a seek.
+
+Prior to bitstream version 3.2.1, data packets were marked by a 
+granulepos derived from the index of the frame being decoded,
+rather than the count. That is they marked the beginning of the
+display interval of a frame rather than the end. Such streams
+have the VREV field of the identification header set to `0' 
+instead of `1'. They can be interpreted according to the description
+above by adding 1 to the more signification field of the split 
+granulepos when VREV is less than 1.
+
+\section{Multiplexed stream mapping}
+
+Applications supporting Ogg Theora must support Theora bitstreams
+ multiplexed with compressed audio data in the Vorbis I and Speex
+ formats, and should support Ogg-encapsulated MNG graphics for overlays.
+
+Multiple audio and video bitstreams may be multiplexed together.
+How playback of multiple/alternate streams is handled is up to the
+ application.
+Some conventions based on included metadata aide interoperability
+ in this respect.
+%TODO: describe multiple vs. alternate streams, language mapping
+% and reference metadata descriptions.
+
+\subsection{Chained streams}
+
+Ogg Theora decoders and playback applications MUST support both grouped
+ streams (multiplexed concurrent logical streams) and chained streams
+ (sequential concatenation of independent physical bitstreams).
+
+The number and codec data types of multiplexed streams and the decoder
+ parameters for those stream types that re-occur can all change at a
+ chaining boundary.
+A playback application MUST be prepared to handle such changes and
+ SHOULD do so smoothly with the minimum possible visible disruption.
+The specification of grouped streams below applies independently to each
+ segment of a chained bitstream.
+
+\subsection{Grouped streams}
+
+At the beginning of a multiplexed stream, the `beginning of stream'
+ pages for each logical bitstream will be grouped together.
+Within these, the first page to occur MUST be the Theora page.
+This facilitates identification of Ogg Theora files among other
+ Ogg-encapsulated content.
+A playback application must nevertheless handle streams where this
+ arrangement is not correct.
+%TBT: Then what's the point of requiring it in the spec?
+
+If there is more than one Theora logical stream, the first page should
+ be from the primary stream.
+That is, the best choice for the stream a generic player should begin
+ displaying without special user direction.
+If there is more than one audio stream, or of any other stream
+ type, the identification page of the primary stream of that type
+ should be placed before the others.
+%TBT: That's all pretty vague.
+
+After the `beginning of stream' pages, the header pages of each of
+ the logical streams MUST be grouped together before any data pages
+ occur.
+
+After all the header pages have been placed,
+ the data pages are multiplexed together.
+They should be placed in the stream in increasing order by the 
+ time equivalents of their granule position fields.
+This facilitates seeking while limiting the buffering requirements of the
+ playback demultiplexer.
+%TODO: A lot of this language is encoder-oriented.
+%TODO: We define a decoder-oriented specification.
+%TODO: The language should be changed to match.
+
+\cleardoublepage
+\chapter{VP3}
+
+\section{VP3 Compatibility}
+\label{app:vp3-compat}
+This section lists all of the encoder and decoder issues that may affect VP3
+ compatibly.
+Each is described in more detail in the text itself.
+This list is provided merely for reference.
+
+\begin{itemize}
+\item
+Bitstream headers (Section~\ref{sec:headers}).
+\begin{itemize}
+\item
+Identification header (Section~\ref{sec:idheader}).
+\begin{itemize}
+\item
+Non-multiple of 16 picture sizes.
+\item
+Standardized color spaces.
+\item
+Support for $4:4:4$ and $4:2:2$ pixel formats.
+\end{itemize}
+\item
+Setup header
+\begin{itemize}
+\item
+Loop filter limit values (Section~\ref{sub:loop-filter-limits}).
+\item
+Quantization parameters (Section~\ref{sub:quant-params}).
+\item
+Huffman tables (Section~\ref{sub:huffman-tables}).
+\end{itemize}
+\end{itemize}
+\item
+Frame header format (Section~\ref{sub:frame-header}).
+\item
+Extended long-run bit strings (Section~\ref{sub:long-run}).
+\item
+INTER\_MV\_FOUR handling of uncoded blocks (Section~\ref{sub:mb-mv-decode}).
+\item
+Block-level \qi\ values (Section~\ref{sub:block-qis}).
+\item
+Zero-length EOB runs (Section~\ref{sub:eob-token}).
+\item
+Unrestricted motion vector padding and the loop filter
+ (Section~\ref{sub:loop-filt}).
+\end{itemize}
+
+\section{Loop Filter Limit Values}
+\label{app:vp3-loop-filter-limits}
+
+The hard-coded loop filter limit values used in VP3 are defined as follows:
+\begin{align*}
+\bitvar{LFLIMS} = & \begin{array}[t]{r@{}rrrrrrrr@{}l}
+\{ & 30, & 25, & 20, & 20, & 15, & 15, & 14, & 14,   &      \\
+   & 13, & 13, & 12, & 12, & 11, & 11, & 10, & 10,   &      \\
+   &  9, &  9, &  8, &  8, &  7, &  7, &  7, &  7,   &      \\
+   &  6, &  6, &  6, &  6, &  5, &  5, &  5, &  5,   &      \\
+   &  4, &  4, &  4, &  4, &  3, &  3, &  3, &  3,   &      \\
+   &  2, &  2, &  2, &  2, &  2, &  2, &  2, &  2,   &      \\
+   &  0, &  0, &  0, &  0, &  0, &  0, &  0, &  0,   &      \\
+   &  0, &  0, &  0, &  0, &  0, &  0, &  0, &  0\;\ & \!\} \\
+\end{array}
+\end{align*}
+
+\section{Quantization Parameters}
+\label{app:vp3-quant-params}
+
+The hard-coded quantization parameters used by VP3 are defined as follows:
+
+\begin{align*}
+\bitvar{ACSCALE} = & \begin{array}[t]{r@{}rrrrrrrr@{}l}
+\{ & 500, & 450, & 400, & 370, & 340, & 310, & 285, & 265,   &      \\
+   & 245, & 225, & 210, & 195, & 185, & 180, & 170, & 160,   &      \\
+   & 150, & 145, & 135, & 130, & 125, & 115, & 110, & 107,   &      \\
+   & 100, &  96, &  93, &  89, &  85, &  82, &  75, &  74,   &      \\
+   &  70, &  68, &  64, &  60, &  57, &  56, &  52, &  50,   &      \\
+   &  49, &  45, &  44, &  43, &  40, &  38, &  37, &  35,   &      \\
+   &  33, &  32, &  30, &  29, &  28, &  25, &  24, &  22,   &      \\
+   &  21, &  19, &  18, &  17, &  15, &  13, &  12, &  10\;\ & \!\} \\
+\end{array} \\
+\bitvar{DCSCALE} = & \begin{array}[t]{r@{}rrrrrrrr@{}l}
+\{ & 220, & 200, & 190, & 180, & 170, & 170, & 160, & 160,   &      \\
+   & 150, & 150, & 140, & 140, & 130, & 130, & 120, & 120,   &      \\
+   & 110, & 110, & 100, & 100, &  90, &  90, &  90, &  80,   &      \\
+   &  80, &  80, &  70, &  70, &  70, &  60, &  60, &  60,   &      \\
+   &  60, &  50, &  50, &  50, &  50, &  40, &  40, &  40,   &      \\
+   &  40, &  40, &  30, &  30, &  30, &  30, &  30, &  30,   &      \\
+   &  30, &  20, &  20, &  20, &  20, &  20, &  20, &  20,   &      \\
+   &  20, &  10, &  10, &  10, &  10, &  10, &  10, &  10\;\ & \!\} \\
+\end{array}
+\end{align*}
+
+VP3 defines only a single quantization range for each quantization type and
+ color plane, and the base matrix used is constant throughout the range.
+There are three base matrices defined.
+The first is used for the $Y'$ channel of INTRA mode blocks, and the second for
+ both the $C_b$ and $C_r$ channels of INTRA mode blocks.
+The last is used for INTER mode blocks of all channels.
+
+\begin{align*}
+\bitvar{BMS} = \{ & \begin{array}[t]{r@{}rrrrrrrr@{}l}
+\{ & 16, & 11, & 10, & 16, &  24, &  40, &  51, &  61,   &       \\
+   & 12, & 12, & 14, & 19, &  26, &  58, &  60, &  55,   &       \\
+   & 14, & 13, & 16, & 24, &  40, &  57, &  69, &  56,   &       \\
+   & 14, & 17, & 22, & 29, &  51, &  87, &  80, &  62,   &       \\
+   & 18, & 22, & 37, & 58, &  68, & 109, & 103, &  77,   &       \\
+   & 24, & 35, & 55, & 64, &  81, & 104, & 113, &  92,   &       \\
+   & 49, & 64, & 78, & 87, & 103, & 121, & 120, & 101,   &       \\
+   & 72, & 92, & 95, & 98, & 112, & 100, & 103, &  99\;\ & \!\}, \\
+%\end{array} \\
+%& \begin{array}[t]{r@{}rrrrrrrr@{}l}
+\{ & 17, & 18, & 24, & 47, & 99, & 99, & 99, & 99,   &       \\
+   & 18, & 21, & 26, & 66, & 99, & 99, & 99, & 99,   &       \\
+   & 24, & 26, & 56, & 99, & 99, & 99, & 99, & 99,   &       \\
+   & 47, & 66, & 99, & 99, & 99, & 99, & 99, & 99,   &       \\
+   & 99, & 99, & 99, & 99, & 99, & 99, & 99, & 99,   &       \\
+   & 99, & 99, & 99, & 99, & 99, & 99, & 99, & 99,   &       \\
+   & 99, & 99, & 99, & 99, & 99, & 99, & 99, & 99,   &       \\
+   & 99, & 99, & 99, & 99, & 99, & 99, & 99, & 99\;\ & \!\}, \\
+%\end{array} \\
+%& \begin{array}[t]{r@{}rrrrrrrr@{}l}
+\{ & 16, & 16, & 16, & 20, & 24, & 28, &  32, &  40,   &            \\
+   & 16, & 16, & 20, & 24, & 28, & 32, &  40, &  48,   &            \\
+   & 16, & 20, & 24, & 28, & 32, & 40, &  48, &  64,   &            \\
+   & 20, & 24, & 28, & 32, & 40, & 48, &  64, &  64,   &            \\
+   & 24, & 28, & 32, & 40, & 48, & 64, &  64, &  64,   &            \\
+   & 28, & 32, & 40, & 48, & 64, & 64, &  64, &  96,   &            \\
+   & 32, & 40, & 48, & 64, & 64, & 64, &  96, & 128,   &            \\
+   & 40, & 48, & 64, & 64, & 64, & 96, & 128, & 128\;\ & \!\}\;\;\} \\
+\end{array}
+\end{align*}
+
+The remaining parameters simply assign these matrices to the proper quant
+ ranges.
+
+\begin{align*}
+\bitvar{NQRS}    = & \{ \{1, 1, 1\}, \{1, 1, 1\} \} \\
+\bitvar{QRSIZES} = &
+ \{ \{ \{1\}, \{1\}, \{1\} \}, \{ \{1\}, \{1\}, \{1\} \} \} \\
+\bitvar{QRBMIS}  = &
+ \{ \{ \{0, 0\}, \{1, 1\}, \{1, 1\} \}, \{ \{2, 2\}, \{2, 2\}, \{2, 2\} \} \} \\
+\end{align*}
+
+\section{Huffman Tables}
+\label{app:vp3-huffman-tables}
+
+The following tables contain the hard-coded Huffman codes used by VP3.
+There are 80 tables in all, each with a Huffman code for all 32 token values.
+The tokens are sorted by the most significant bits of their Huffman code.
+This is the same order in which they will be decoded from the setup header.
+
+\include{vp3huff}
+
+\cleardoublepage
+\chapter{Colophon}
+
+Ogg is a \href{http://www.xiph.org}{Xiph.org Foundation} effort to protect
+ essential tenets of Internet multimedia from corporate hostage-taking; Open
+ Source is the net's greatest tool to keep everyone honest.
+See \href{http://www.xiph.org/about.html}{About the Xiph.org Foundation} for
+ details.
+
+Ogg Theora is the first Ogg video codec.
+Anyone may freely use and distribute the Ogg and Theora specifications, whether
+ in private, public, or corporate capacity.
+However, the Xiph.org Foundation and the Ogg project reserve the right to set
+ the Ogg Theora specification and certify specification compliance.
+
+Xiph.org's Theora software codec implementation is distributed under a BSD-like
+ license.
+This does not restrict third parties from distributing independent
+ implementations of Theora software under other licenses.
+
+\begin{wrapfigure}{l}{0pt}
+\includegraphics[width=2.5cm]{xifish}
+\end{wrapfigure}
+
+These pages are Copyright \textcopyright{} 2004-2007 Xiph.org Foundation.
+All rights reserved.
+Ogg, Theora, Vorbis, Xiph.org Foundation and their logos are trademarks
+ (\texttrademark) of the \href{http://www.xiph.org}{Xiph.org Foundation}.
+
+This document is set in \LaTeX.
+
+
+
+\cleardoublepage
+\bibliography{spec}
+
+\end{document}
diff --git a/doc/spec/superblock.fig b/doc/spec/superblock.fig
new file mode 100644 (file)
index 0000000..082c31f
--- /dev/null
@@ -0,0 +1,72 @@
+#FIG 3.2  Produced by xfig version 3.2.5-alpha4
+Landscape
+Center
+Metric
+A4      
+100.00
+Single
+-2
+1200 2
+6 270 180 5905 4860
+6 387 3531 1542 4687
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        387 4687 675 4687 675 4397 387 4397 387 4687
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        675 4687 963 4687 963 4397 675 4397 675 4687
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        963 4687 1252 4687 1252 4397 963 4397 963 4687
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1252 4397 1542 4397 1542 4109 1252 4109 1252 4397
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        387 4397 675 4397 675 4109 387 4109 387 4397
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        387 4109 675 4109 675 3820 387 3820 387 4109
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        963 4109 1252 4109 1252 3820 963 3820 963 4109
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1252 4109 1542 4109 1542 3820 1252 3820 1252 4109
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1252 3820 1542 3820 1542 3531 1252 3531 1252 3820
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        675 3820 963 3820 963 3531 675 3531 675 3820
+-6
+6 387 3531 1542 4687
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1252 4687 1542 4687 1542 4397 1252 4397 1252 4687
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        963 4397 1252 4397 1252 4109 963 4109 963 4397
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        963 3820 1252 3820 1252 3531 963 3531 963 3820
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        387 3820 675 3820 675 3531 387 3531 387 3820
+-6
+6 357 3502 1570 4715
+6 675 3820 963 4397
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        675 4397 963 4397 963 4109 675 4109 675 4397
+2 2 0 1 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        675 4109 963 4109 963 3820 675 3820 675 4109
+-6
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        387 3531 1542 3531 1542 4687 387 4687 387 3531
+-6
+2 2 1 2 0 7 50 -1 -1 6.000 0 0 -1 0 0 5
+        387 353 5876 353 5876 4687 387 4687 387 353
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1542 3531 2697 3531 2697 4687 1542 4687 1542 3531
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        2697 3531 3854 3531 3854 4687 2697 4687 2697 3531
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        387 2375 1542 2375 1542 3531 387 3531 387 2375
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        1542 2375 2697 2375 2697 3531 1542 3531 1542 2375
+2 2 0 2 0 7 50 -1 -1 0.000 0 0 -1 0 0 5
+        387 1220 1542 1220 1542 2375 387 2375 387 1220
+4 0 0 50 -1 0 7 0.0000 4 125 270 270 4831 (0,0)\001
+4 0 0 50 -1 0 7 0.0000 4 96 367 473 297 Frame\001
+4 0 0 50 -1 0 7 0.0000 4 125 1002 501 3474 Super Block (4x4)\001
+4 0 0 50 -1 0 7 0.0000 4 96 203 415 4657 8x8\001
+4 0 0 50 -1 0 7 0.0000 4 96 318 357 4513 Block\001
+4 0 0 50 -1 0 13 0.0000 4 20 145 4085 4081 ...\001
+4 0 0 50 -1 0 13 4.7124 4 20 145 848 815 ...\001
+-6
diff --git a/doc/spec/vp3huff.c b/doc/spec/vp3huff.c
new file mode 100644 (file)
index 0000000..b425205
--- /dev/null
@@ -0,0 +1,918 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2007                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+    function: dump the VP3.1 huffman tables in a form suitable for
+       inclusion in the spec.
+    last mod: $Id: vp3huff.c 14078 2007-10-31 21:24:44Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+
+
+
+typedef struct{
+  unsigned long pattern;
+  int           nbits;
+}theora_huff_code;
+
+
+
+/*The default Huffman codes used for VP3.1.
+  These tables were generated by /experimental/derf/theora-exp/tools/huffgen.c
+   using the same algorithm and sampled frequency counts used by VP3.*/
+const theora_huff_code TH_VP31_HUFF_CODES[80][32]={
+  {
+    {0x002D, 6},{0x0026, 7},{0x0166, 9},{0x004E, 8},
+    {0x02CE,10},{0x059E,11},{0x027D,11},{0x0008, 5},
+    {0x04F9,12},{0x000F, 4},{0x000E, 4},{0x001B, 5},
+    {0x0006, 4},{0x0008, 4},{0x0005, 4},{0x001A, 5},
+    {0x0015, 5},{0x0007, 4},{0x000C, 4},{0x0001, 3},
+    {0x0000, 3},{0x0009, 4},{0x0017, 5},{0x0029, 6},
+    {0x0028, 6},{0x00B2, 8},{0x04F8,12},{0x059F,11},
+    {0x009E, 9},{0x013F,10},{0x0012, 6},{0x0058, 7}
+  },
+  {
+    {0x0010, 5},{0x0047, 7},{0x01FF, 9},{0x008C, 8},
+    {0x03FC,10},{0x046A,11},{0x0469,11},{0x0022, 6},
+    {0x11A1,13},{0x000E, 4},{0x000D, 4},{0x0004, 4},
+    {0x0005, 4},{0x0009, 4},{0x0006, 4},{0x001E, 5},
+    {0x0016, 5},{0x0007, 4},{0x000C, 4},{0x0001, 3},
+    {0x0000, 3},{0x000A, 4},{0x0017, 5},{0x007D, 7},
+    {0x007E, 7},{0x011B, 9},{0x08D1,12},{0x03FD,10},
+    {0x046B,11},{0x11A0,13},{0x007C, 7},{0x00FE, 8}
+  },
+  {
+    {0x0016, 5},{0x0020, 6},{0x0086, 8},{0x0087, 8},
+    {0x0367,10},{0x06CC,11},{0x06CB,11},{0x006E, 7},
+    {0x366D,14},{0x000F, 4},{0x000E, 4},{0x0004, 4},
+    {0x0005, 4},{0x000A, 4},{0x0006, 4},{0x001A, 5},
+    {0x0011, 5},{0x0007, 4},{0x000C, 4},{0x0001, 3},
+    {0x0000, 3},{0x0009, 4},{0x0017, 5},{0x006F, 7},
+    {0x006D, 7},{0x0364,10},{0x0D9A,12},{0x06CA,11},
+    {0x1B37,13},{0x366C,14},{0x0042, 7},{0x00D8, 8}
+  },
+  {
+    {0x0000, 4},{0x002D, 6},{0x00F7, 8},{0x0058, 7},
+    {0x0167, 9},{0x02CB,10},{0x02CA,10},{0x000E, 6},
+    {0x1661,13},{0x0003, 3},{0x0002, 3},{0x0008, 4},
+    {0x0009, 4},{0x000D, 4},{0x0002, 4},{0x001F, 5},
+    {0x0017, 5},{0x0001, 4},{0x000C, 4},{0x000E, 4},
+    {0x000A, 4},{0x0006, 5},{0x0078, 7},{0x000F, 6},
+    {0x007A, 7},{0x0164, 9},{0x0599,11},{0x02CD,10},
+    {0x0B31,12},{0x1660,13},{0x0079, 7},{0x00F6, 8}
+  },
+  {
+    {0x0003, 4},{0x003C, 6},{0x000F, 7},{0x007A, 7},
+    {0x001D, 8},{0x0020, 9},{0x0072,10},{0x0006, 6},
+    {0x0399,13},{0x0004, 3},{0x0005, 3},{0x0005, 4},
+    {0x0006, 4},{0x000E, 4},{0x0004, 4},{0x0000, 4},
+    {0x0019, 5},{0x0002, 4},{0x000D, 4},{0x0007, 4},
+    {0x001F, 5},{0x0030, 6},{0x0011, 8},{0x0031, 6},
+    {0x0005, 6},{0x0021, 9},{0x00E7,11},{0x0038, 9},
+    {0x01CD,12},{0x0398,13},{0x007B, 7},{0x0009, 7}
+  },
+  {
+    {0x0009, 4},{0x0002, 5},{0x0074, 7},{0x0007, 6},
+    {0x00EC, 8},{0x00D1, 9},{0x01A6,10},{0x0006, 6},
+    {0x0D21,13},{0x0005, 3},{0x0006, 3},{0x0008, 4},
+    {0x0007, 4},{0x000F, 4},{0x0004, 4},{0x0000, 4},
+    {0x001C, 5},{0x0002, 4},{0x0005, 4},{0x0003, 4},
+    {0x000C, 5},{0x0035, 7},{0x01A7,10},{0x001B, 6},
+    {0x0077, 7},{0x01A5,10},{0x0349,11},{0x00D0, 9},
+    {0x0691,12},{0x0D20,13},{0x0075, 7},{0x00ED, 8}
+  },
+  {
+    {0x000A, 4},{0x000C, 5},{0x0012, 6},{0x001B, 6},
+    {0x00B7, 8},{0x016C, 9},{0x0099, 9},{0x005A, 7},
+    {0x16D8,13},{0x0007, 3},{0x0006, 3},{0x0009, 4},
+    {0x0008, 4},{0x0000, 3},{0x0005, 4},{0x0017, 5},
+    {0x000E, 5},{0x0002, 4},{0x0003, 4},{0x000F, 5},
+    {0x001A, 6},{0x004D, 8},{0x2DB3,14},{0x002C, 6},
+    {0x0011, 6},{0x02DA,10},{0x05B7,11},{0x0098, 9},
+    {0x0B6D,12},{0x2DB2,14},{0x0010, 6},{0x0027, 7}
+  },
+  {
+    {0x000D, 4},{0x000F, 5},{0x001D, 6},{0x0008, 5},
+    {0x0051, 7},{0x0056, 8},{0x00AF, 9},{0x002A, 7},
+    {0x148A,13},{0x0007, 3},{0x0000, 2},{0x0008, 4},
+    {0x0009, 4},{0x000C, 4},{0x0006, 4},{0x0017, 5},
+    {0x000B, 5},{0x0016, 5},{0x0015, 5},{0x0009, 5},
+    {0x0050, 7},{0x00AE, 9},{0x2917,14},{0x001C, 6},
+    {0x0014, 6},{0x0290,10},{0x0523,11},{0x0149, 9},
+    {0x0A44,12},{0x2916,14},{0x0053, 7},{0x00A5, 8}
+  },
+  {
+    {0x0001, 4},{0x001D, 6},{0x00F5, 8},{0x00F4, 8},
+    {0x024D,10},{0x0499,11},{0x0498,11},{0x0001, 5},
+    {0x0021, 6},{0x0006, 3},{0x0005, 3},{0x0006, 4},
+    {0x0005, 4},{0x0002, 4},{0x0007, 5},{0x0025, 6},
+    {0x007B, 7},{0x001C, 6},{0x0020, 6},{0x000D, 6},
+    {0x0048, 7},{0x0092, 8},{0x0127, 9},{0x000E, 4},
+    {0x0004, 4},{0x0011, 5},{0x000C, 6},{0x003C, 6},
+    {0x000F, 5},{0x0000, 5},{0x001F, 5},{0x0013, 5}
+  },
+  {
+    {0x0005, 4},{0x003C, 6},{0x0040, 7},{0x000D, 7},
+    {0x0031, 9},{0x0061,10},{0x0060,10},{0x0002, 5},
+    {0x00F5, 8},{0x0006, 3},{0x0005, 3},{0x0007, 4},
+    {0x0006, 4},{0x0002, 4},{0x0009, 5},{0x0025, 6},
+    {0x0007, 6},{0x0021, 6},{0x0024, 6},{0x0010, 6},
+    {0x0041, 7},{0x00F4, 8},{0x0019, 8},{0x000E, 4},
+    {0x0003, 4},{0x0011, 5},{0x0011, 6},{0x003F, 6},
+    {0x003E, 6},{0x007B, 7},{0x0000, 4},{0x0013, 5}
+  },
+  {
+    {0x000A, 4},{0x0007, 5},{0x0001, 6},{0x0009, 6},
+    {0x0131, 9},{0x0261,10},{0x0260,10},{0x0015, 6},
+    {0x0001, 7},{0x0007, 3},{0x0006, 3},{0x0008, 4},
+    {0x0007, 4},{0x0006, 4},{0x0012, 5},{0x002F, 6},
+    {0x0014, 6},{0x0027, 6},{0x002D, 6},{0x0016, 6},
+    {0x004D, 7},{0x0099, 8},{0x0000, 7},{0x0004, 4},
+    {0x0001, 4},{0x0005, 5},{0x0017, 6},{0x002E, 6},
+    {0x002C, 6},{0x0008, 6},{0x0006, 5},{0x0001, 5}
+  },
+  {
+    {0x0000, 3},{0x000E, 5},{0x0017, 6},{0x002A, 6},
+    {0x0010, 7},{0x00F9,10},{0x00F8,10},{0x001E, 7},
+    {0x003F, 8},{0x0007, 3},{0x0006, 3},{0x0009, 4},
+    {0x0008, 4},{0x0006, 4},{0x000F, 5},{0x0005, 5},
+    {0x0016, 6},{0x0029, 6},{0x002B, 6},{0x0015, 6},
+    {0x0050, 7},{0x0011, 7},{0x007D, 9},{0x0004, 4},
+    {0x0017, 5},{0x0006, 5},{0x0014, 6},{0x002C, 6},
+    {0x002D, 6},{0x000E, 6},{0x0009, 6},{0x0051, 7}
+  },
+  {
+    {0x0002, 3},{0x0018, 5},{0x002F, 6},{0x000D, 5},
+    {0x0053, 7},{0x0295,10},{0x0294,10},{0x00A4, 8},
+    {0x007C, 8},{0x0000, 2},{0x0007, 3},{0x0009, 4},
+    {0x0008, 4},{0x001B, 5},{0x000C, 5},{0x0028, 6},
+    {0x006A, 7},{0x001E, 6},{0x001D, 6},{0x0069, 7},
+    {0x00D7, 8},{0x007D, 8},{0x014B, 9},{0x0019, 5},
+    {0x0016, 5},{0x002E, 6},{0x001C, 6},{0x002B, 6},
+    {0x002A, 6},{0x0068, 7},{0x003F, 7},{0x00D6, 8}
+  },
+  {
+    {0x0002, 3},{0x001B, 5},{0x000C, 5},{0x0018, 5},
+    {0x0029, 6},{0x007F, 8},{0x02F0,10},{0x0198, 9},
+    {0x0179, 9},{0x0000, 2},{0x0007, 3},{0x0009, 4},
+    {0x0008, 4},{0x001A, 5},{0x000D, 5},{0x002A, 6},
+    {0x0064, 7},{0x001E, 6},{0x0067, 7},{0x005F, 7},
+    {0x00CD, 8},{0x007E, 8},{0x02F1,10},{0x0016, 5},
+    {0x000E, 5},{0x002E, 6},{0x0065, 7},{0x002B, 6},
+    {0x0028, 6},{0x003E, 7},{0x00BD, 8},{0x0199, 9}
+  },
+  {
+    {0x0002, 3},{0x0007, 4},{0x0016, 5},{0x0006, 4},
+    {0x0036, 6},{0x005C, 7},{0x015D, 9},{0x015C, 9},
+    {0x02BF,10},{0x0000, 2},{0x0007, 3},{0x0009, 4},
+    {0x0008, 4},{0x0018, 5},{0x0034, 6},{0x002A, 6},
+    {0x005E, 7},{0x006A, 7},{0x0064, 7},{0x005D, 7},
+    {0x00CB, 8},{0x00AD, 8},{0x02BE,10},{0x0014, 5},
+    {0x0033, 6},{0x006E, 7},{0x005F, 7},{0x006F, 7},
+    {0x006B, 7},{0x00CA, 8},{0x00AC, 8},{0x015E, 9}
+  },
+  {
+    {0x000F, 4},{0x001D, 5},{0x0018, 5},{0x000B, 4},
+    {0x0019, 5},{0x0029, 6},{0x00D6, 8},{0x0551,11},
+    {0x0AA1,12},{0x0001, 2},{0x0000, 2},{0x0009, 4},
+    {0x0008, 4},{0x001B, 5},{0x0038, 6},{0x0028, 6},
+    {0x0057, 7},{0x006A, 7},{0x0068, 7},{0x0056, 7},
+    {0x00E5, 8},{0x0155, 9},{0x0AA0,12},{0x0073, 7},
+    {0x0069, 7},{0x00D7, 8},{0x00AB, 8},{0x00E4, 8},
+    {0x00A9, 8},{0x0151, 9},{0x0150, 9},{0x02A9,10}
+  },
+  {
+    {0x0008, 5},{0x0025, 7},{0x017A, 9},{0x02F7,10},
+    {0x0BDB,12},{0x17B4,13},{0x2F6B,14},{0x001D, 5},
+    {0x2F6A,14},{0x0008, 4},{0x0007, 4},{0x0001, 4},
+    {0x0002, 4},{0x000A, 4},{0x0006, 4},{0x0000, 4},
+    {0x001C, 5},{0x0009, 4},{0x000D, 4},{0x000F, 4},
+    {0x000C, 4},{0x0003, 4},{0x000A, 5},{0x0016, 5},
+    {0x0013, 6},{0x005D, 7},{0x0024, 7},{0x00BC, 8},
+    {0x005C, 7},{0x05EC,11},{0x000B, 5},{0x005F, 7}
+  },
+  {
+    {0x000F, 5},{0x0010, 6},{0x004B, 8},{0x00C6, 8},
+    {0x031D,10},{0x0C71,12},{0x0C70,12},{0x0001, 4},
+    {0x0C73,12},{0x0008, 4},{0x0009, 4},{0x0002, 4},
+    {0x0003, 4},{0x000B, 4},{0x0006, 4},{0x0000, 4},
+    {0x001C, 5},{0x0005, 4},{0x000D, 4},{0x000F, 4},
+    {0x000A, 4},{0x0019, 5},{0x0013, 6},{0x001D, 5},
+    {0x0030, 6},{0x0062, 7},{0x0024, 7},{0x004A, 8},
+    {0x018F, 9},{0x0C72,12},{0x000E, 5},{0x0011, 6}
+  },
+  {
+    {0x001B, 5},{0x0003, 6},{0x008D, 8},{0x0040, 7},
+    {0x0239,10},{0x0471,11},{0x08E0,12},{0x0003, 4},
+    {0x11C3,13},{0x000A, 4},{0x0009, 4},{0x0004, 4},
+    {0x0005, 4},{0x000E, 4},{0x0007, 4},{0x0001, 4},
+    {0x001E, 5},{0x0006, 4},{0x000C, 4},{0x000B, 4},
+    {0x0002, 4},{0x0000, 5},{0x0041, 7},{0x001F, 5},
+    {0x0022, 6},{0x0002, 6},{0x008F, 8},{0x008C, 8},
+    {0x011D, 9},{0x11C2,13},{0x001A, 5},{0x0021, 6}
+  },
+  {
+    {0x001F, 5},{0x0003, 6},{0x0003, 7},{0x0043, 7},
+    {0x000B, 9},{0x0015,10},{0x0051,12},{0x0003, 4},
+    {0x0050,12},{0x000D, 4},{0x000C, 4},{0x0004, 4},
+    {0x0006, 4},{0x000E, 4},{0x000A, 4},{0x0001, 4},
+    {0x001E, 5},{0x0005, 4},{0x0009, 4},{0x0007, 4},
+    {0x0011, 5},{0x0002, 6},{0x0004, 8},{0x0002, 4},
+    {0x002D, 6},{0x0020, 6},{0x0042, 7},{0x0001, 7},
+    {0x0000, 7},{0x0029,11},{0x0017, 5},{0x002C, 6}
+  },
+  {
+    {0x0003, 4},{0x001F, 6},{0x003A, 7},{0x005D, 7},
+    {0x0173, 9},{0x02E4,10},{0x172D,13},{0x0004, 4},
+    {0x172C,13},{0x000F, 4},{0x000E, 4},{0x0009, 4},
+    {0x0008, 4},{0x000C, 4},{0x000A, 4},{0x0001, 4},
+    {0x0016, 5},{0x0002, 4},{0x0005, 4},{0x001A, 5},
+    {0x002F, 6},{0x0038, 7},{0x05CA,11},{0x0006, 4},
+    {0x0037, 6},{0x001E, 6},{0x003B, 7},{0x0039, 7},
+    {0x00B8, 8},{0x0B97,12},{0x0000, 4},{0x0036, 6}
+  },
+  {
+    {0x0006, 4},{0x0037, 6},{0x005D, 7},{0x000C, 6},
+    {0x00B9, 8},{0x02E3,10},{0x05C4,11},{0x0004, 4},
+    {0x1715,13},{0x0000, 3},{0x000F, 4},{0x0008, 4},
+    {0x0007, 4},{0x000C, 4},{0x0009, 4},{0x001D, 5},
+    {0x0016, 5},{0x001C, 5},{0x001A, 5},{0x000B, 5},
+    {0x005E, 7},{0x0170, 9},{0x1714,13},{0x000A, 4},
+    {0x000A, 5},{0x0036, 6},{0x005F, 7},{0x001B, 7},
+    {0x001A, 7},{0x0B8B,12},{0x0002, 4},{0x0007, 5}
+  },
+  {
+    {0x000C, 4},{0x000B, 5},{0x0079, 7},{0x0022, 6},
+    {0x00F0, 8},{0x0119, 9},{0x0230,10},{0x001D, 5},
+    {0x08C4,12},{0x0001, 3},{0x0000, 3},{0x000A, 4},
+    {0x0009, 4},{0x000B, 4},{0x0007, 4},{0x001C, 5},
+    {0x003D, 6},{0x000D, 5},{0x0008, 5},{0x0015, 6},
+    {0x008D, 8},{0x118B,13},{0x118A,13},{0x000D, 4},
+    {0x0010, 5},{0x0009, 5},{0x0014, 6},{0x0047, 7},
+    {0x00F1, 8},{0x0463,11},{0x001F, 5},{0x000C, 5}
+  },
+  {
+    {0x0000, 3},{0x001A, 5},{0x0033, 6},{0x000C, 5},
+    {0x0046, 7},{0x01E3, 9},{0x03C5,10},{0x0017, 5},
+    {0x1E21,13},{0x0002, 3},{0x0001, 3},{0x0009, 4},
+    {0x000A, 4},{0x0007, 4},{0x001B, 5},{0x003D, 6},
+    {0x001B, 6},{0x0022, 6},{0x0079, 7},{0x00F0, 8},
+    {0x1E20,13},{0x1E23,13},{0x1E22,13},{0x000E, 4},
+    {0x0016, 5},{0x0018, 5},{0x0032, 6},{0x001A, 6},
+    {0x0047, 7},{0x0789,11},{0x001F, 5},{0x0010, 5}
+  },
+  {
+    {0x001D, 5},{0x0061, 7},{0x004E, 8},{0x009E, 9},
+    {0x027C,11},{0x09F5,13},{0x09F4,13},{0x0003, 4},
+    {0x0060, 7},{0x0000, 3},{0x000F, 4},{0x000B, 4},
+    {0x000A, 4},{0x0009, 4},{0x0005, 4},{0x000D, 5},
+    {0x0031, 6},{0x0008, 5},{0x0038, 6},{0x0012, 6},
+    {0x0026, 7},{0x013F,10},{0x04FB,12},{0x000D, 4},
+    {0x0002, 4},{0x000C, 5},{0x0039, 6},{0x001C, 6},
+    {0x000F, 5},{0x001D, 6},{0x0008, 4},{0x0019, 5}
+  },
+  {
+    {0x0007, 4},{0x0019, 6},{0x00AB, 8},{0x00AA, 8},
+    {0x0119,10},{0x0461,12},{0x0460,12},{0x001B, 5},
+    {0x0047, 8},{0x0001, 3},{0x0000, 3},{0x000C, 4},
+    {0x000B, 4},{0x0009, 4},{0x0005, 4},{0x000D, 5},
+    {0x0035, 6},{0x003D, 6},{0x003C, 6},{0x0018, 6},
+    {0x0022, 7},{0x008D, 9},{0x0231,11},{0x000E, 4},
+    {0x001F, 5},{0x0009, 5},{0x002B, 6},{0x0010, 6},
+    {0x0034, 6},{0x0054, 7},{0x0008, 4},{0x0014, 5}
+  },
+  {
+    {0x000C, 4},{0x0005, 5},{0x0008, 6},{0x005B, 7},
+    {0x004D, 9},{0x0131,11},{0x0261,12},{0x001A, 5},
+    {0x0012, 7},{0x0000, 3},{0x000F, 4},{0x000A, 4},
+    {0x0009, 4},{0x0006, 4},{0x001B, 5},{0x0006, 5},
+    {0x001C, 6},{0x002C, 6},{0x0015, 6},{0x005A, 7},
+    {0x0027, 8},{0x0099,10},{0x0260,12},{0x000E, 4},
+    {0x0004, 4},{0x000F, 5},{0x0007, 5},{0x001D, 6},
+    {0x000B, 5},{0x0014, 6},{0x0008, 4},{0x0017, 5}
+  },
+  {
+    {0x000F, 4},{0x0013, 5},{0x0075, 7},{0x0024, 6},
+    {0x0095, 8},{0x0251,10},{0x04A0,11},{0x0010, 5},
+    {0x00C8, 8},{0x0002, 3},{0x0001, 3},{0x0001, 4},
+    {0x0000, 4},{0x001A, 5},{0x0011, 5},{0x002C, 6},
+    {0x0065, 7},{0x0074, 7},{0x004B, 7},{0x00C9, 8},
+    {0x0129, 9},{0x0943,12},{0x0942,12},{0x0003, 3},
+    {0x000A, 4},{0x001C, 5},{0x0018, 5},{0x0033, 6},
+    {0x0017, 5},{0x002D, 6},{0x001B, 5},{0x003B, 6}
+  },
+  {
+    {0x0003, 3},{0x001A, 5},{0x002D, 6},{0x0038, 6},
+    {0x0028, 7},{0x0395,10},{0x0E51,12},{0x0037, 6},
+    {0x00E4, 8},{0x0001, 3},{0x0000, 3},{0x001F, 5},
+    {0x001E, 5},{0x0017, 5},{0x003A, 6},{0x0073, 7},
+    {0x002A, 7},{0x002B, 7},{0x0029, 7},{0x01CB, 9},
+    {0x0729,11},{0x1CA1,13},{0x1CA0,13},{0x0004, 3},
+    {0x000A, 4},{0x0004, 4},{0x0018, 5},{0x0036, 6},
+    {0x000B, 5},{0x002C, 6},{0x0019, 5},{0x003B, 6}
+  },
+  {
+    {0x0004, 3},{0x0004, 4},{0x003F, 6},{0x0017, 5},
+    {0x0075, 7},{0x01F5, 9},{0x07D1,11},{0x0017, 6},
+    {0x01F6, 9},{0x0001, 3},{0x0000, 3},{0x001B, 5},
+    {0x001A, 5},{0x000A, 5},{0x0032, 6},{0x0074, 7},
+    {0x00F8, 8},{0x00F9, 8},{0x01F7, 9},{0x03E9,10},
+    {0x0FA0,12},{0x1F43,13},{0x1F42,13},{0x0003, 3},
+    {0x000A, 4},{0x001E, 5},{0x001C, 5},{0x003B, 6},
+    {0x0018, 5},{0x0016, 6},{0x0016, 5},{0x0033, 6}
+  },
+  {
+    {0x0004, 3},{0x0007, 4},{0x0018, 5},{0x001E, 5},
+    {0x0036, 6},{0x0031, 7},{0x0177, 9},{0x0077, 7},
+    {0x0176, 9},{0x0001, 3},{0x0000, 3},{0x001A, 5},
+    {0x0019, 5},{0x003A, 6},{0x0019, 6},{0x005C, 7},
+    {0x00BA, 8},{0x0061, 8},{0x00C1, 9},{0x0180,10},
+    {0x0302,11},{0x0607,12},{0x0606,12},{0x0002, 3},
+    {0x000A, 4},{0x001F, 5},{0x001C, 5},{0x0037, 6},
+    {0x0016, 5},{0x0076, 7},{0x000D, 5},{0x002F, 6}
+  },
+  {
+    {0x0000, 3},{0x000A, 4},{0x001A, 5},{0x000C, 4},
+    {0x001D, 5},{0x0039, 6},{0x0078, 7},{0x005E, 7},
+    {0x0393,11},{0x0002, 3},{0x0001, 3},{0x0016, 5},
+    {0x000F, 5},{0x002E, 6},{0x005F, 7},{0x0073, 8},
+    {0x00E5, 9},{0x01C8,10},{0x0E4A,13},{0x1C97,14},
+    {0x1C96,14},{0x0E49,13},{0x0E48,13},{0x0004, 3},
+    {0x0006, 4},{0x001F, 5},{0x001B, 5},{0x001D, 6},
+    {0x0038, 6},{0x0038, 7},{0x003D, 6},{0x0079, 7}
+  },
+  {
+    {0x000B, 5},{0x002B, 7},{0x0054, 8},{0x01B7, 9},
+    {0x06D9,11},{0x0DB1,12},{0x0DB0,12},{0x0002, 4},
+    {0x00AB, 9},{0x0009, 4},{0x000A, 4},{0x0007, 4},
+    {0x0008, 4},{0x000F, 4},{0x000C, 4},{0x0003, 4},
+    {0x001D, 5},{0x0004, 4},{0x000B, 4},{0x0006, 4},
+    {0x001A, 5},{0x0003, 6},{0x00AA, 9},{0x0001, 4},
+    {0x0000, 5},{0x0014, 6},{0x006C, 7},{0x00DA, 8},
+    {0x0002, 6},{0x036D,10},{0x001C, 5},{0x0037, 6}
+  },
+  {
+    {0x001D, 5},{0x0004, 6},{0x00B6, 8},{0x006A, 8},
+    {0x05B9,11},{0x16E1,13},{0x16E0,13},{0x0007, 4},
+    {0x016F, 9},{0x000C, 4},{0x000D, 4},{0x0009, 4},
+    {0x0008, 4},{0x000F, 4},{0x000A, 4},{0x0003, 4},
+    {0x0017, 5},{0x0002, 4},{0x0004, 4},{0x001C, 5},
+    {0x002C, 6},{0x006B, 8},{0x0B71,12},{0x0005, 4},
+    {0x0003, 5},{0x001B, 6},{0x005A, 7},{0x0034, 7},
+    {0x0005, 6},{0x02DD,10},{0x0000, 4},{0x000C, 5}
+  },
+  {
+    {0x0003, 4},{0x007F, 7},{0x00A1, 8},{0x00A0, 8},
+    {0x020C,10},{0x0834,12},{0x106B,13},{0x0007, 4},
+    {0x0082, 8},{0x000E, 4},{0x000D, 4},{0x000B, 4},
+    {0x000C, 4},{0x0000, 3},{0x0009, 4},{0x0002, 4},
+    {0x0011, 5},{0x001E, 5},{0x0015, 5},{0x003E, 6},
+    {0x0040, 7},{0x041B,11},{0x106A,13},{0x0006, 4},
+    {0x000A, 5},{0x0029, 6},{0x007E, 7},{0x0051, 7},
+    {0x0021, 6},{0x0107, 9},{0x0004, 4},{0x000B, 5}
+  },
+  {
+    {0x0007, 4},{0x001B, 6},{0x00F6, 8},{0x00E9, 8},
+    {0x03A1,10},{0x0740,11},{0x0E82,12},{0x001F, 5},
+    {0x01EF, 9},{0x0001, 3},{0x0002, 3},{0x000B, 4},
+    {0x000C, 4},{0x000D, 4},{0x0008, 4},{0x001C, 5},
+    {0x0003, 5},{0x0012, 5},{0x0002, 5},{0x0075, 7},
+    {0x01D1, 9},{0x1D07,13},{0x1D06,13},{0x000A, 4},
+    {0x0013, 5},{0x003B, 6},{0x001A, 6},{0x007A, 7},
+    {0x003C, 6},{0x01EE, 9},{0x0000, 4},{0x000C, 5}
+  },
+  {
+    {0x000D, 4},{0x003D, 6},{0x0042, 7},{0x0037, 7},
+    {0x00D9, 9},{0x0362,11},{0x06C6,12},{0x001F, 5},
+    {0x0086, 8},{0x0001, 3},{0x0002, 3},{0x000C, 4},
+    {0x000B, 4},{0x000A, 4},{0x0001, 4},{0x000F, 5},
+    {0x0025, 6},{0x003C, 6},{0x001A, 6},{0x0087, 8},
+    {0x01B0,10},{0x0D8F,13},{0x0D8E,13},{0x000E, 4},
+    {0x0013, 5},{0x000C, 5},{0x0024, 6},{0x0020, 6},
+    {0x0011, 5},{0x006D, 8},{0x0000, 4},{0x000E, 5}
+  },
+  {
+    {0x0000, 3},{0x0012, 5},{0x0076, 7},{0x0077, 7},
+    {0x014D, 9},{0x0533,11},{0x14C9,13},{0x0013, 5},
+    {0x00A5, 8},{0x0002, 3},{0x0003, 3},{0x000B, 4},
+    {0x000C, 4},{0x0008, 4},{0x001A, 5},{0x002B, 6},
+    {0x0075, 7},{0x0074, 7},{0x00A7, 8},{0x0298,10},
+    {0x14C8,13},{0x14CB,13},{0x14CA,13},{0x000F, 4},
+    {0x001C, 5},{0x0007, 5},{0x002A, 6},{0x0028, 6},
+    {0x001B, 5},{0x00A4, 8},{0x0002, 4},{0x0006, 5}
+  },
+  {
+    {0x0002, 3},{0x001A, 5},{0x002B, 6},{0x003A, 6},
+    {0x00ED, 8},{0x0283,10},{0x0A0A,12},{0x0004, 5},
+    {0x00A1, 8},{0x0004, 3},{0x0003, 3},{0x000B, 4},
+    {0x000C, 4},{0x001F, 5},{0x0006, 5},{0x0077, 7},
+    {0x00A3, 8},{0x00A2, 8},{0x0140, 9},{0x1417,13},
+    {0x1416,13},{0x0A09,12},{0x0A08,12},{0x0000, 3},
+    {0x001E, 5},{0x0007, 5},{0x002A, 6},{0x0029, 6},
+    {0x001C, 5},{0x00EC, 8},{0x001B, 5},{0x0005, 5}
+  },
+  {
+    {0x0002, 3},{0x0002, 4},{0x0018, 5},{0x001D, 5},
+    {0x0035, 6},{0x00E4, 8},{0x01CF,11},{0x001D, 7},
+    {0x0072, 9},{0x0004, 3},{0x0005, 3},{0x0006, 4},
+    {0x0007, 4},{0x0006, 5},{0x0073, 7},{0x0038, 8},
+    {0x01CE,11},{0x039B,12},{0x0398,12},{0x0733,13},
+    {0x0732,13},{0x0735,13},{0x0734,13},{0x0000, 3},
+    {0x001F, 5},{0x001B, 5},{0x0034, 6},{0x000F, 6},
+    {0x001E, 5},{0x00E5, 8},{0x0019, 5},{0x0038, 6}
+  },
+  {
+    {0x0016, 5},{0x0050, 7},{0x0172, 9},{0x02E7,10},
+    {0x1732,13},{0x2E67,14},{0x2E66,14},{0x0006, 4},
+    {0x0051, 7},{0x0001, 3},{0x0000, 3},{0x000D, 4},
+    {0x000C, 4},{0x0009, 4},{0x001C, 5},{0x0009, 5},
+    {0x001C, 6},{0x001D, 6},{0x005D, 7},{0x00B8, 8},
+    {0x05CD,11},{0x1731,13},{0x1730,13},{0x000F, 4},
+    {0x0005, 4},{0x000F, 5},{0x0008, 5},{0x0029, 6},
+    {0x001D, 5},{0x002F, 6},{0x0008, 4},{0x0015, 5}
+  },
+  {
+    {0x0009, 4},{0x0021, 6},{0x0040, 7},{0x00AD, 8},
+    {0x02B0,10},{0x1589,13},{0x1588,13},{0x001C, 5},
+    {0x005F, 7},{0x0000, 3},{0x000F, 4},{0x000D, 4},
+    {0x000C, 4},{0x0006, 4},{0x0011, 5},{0x002A, 6},
+    {0x0057, 7},{0x005E, 7},{0x0041, 7},{0x0159, 9},
+    {0x0563,11},{0x158B,13},{0x158A,13},{0x0001, 3},
+    {0x0005, 4},{0x0014, 5},{0x003B, 6},{0x002E, 6},
+    {0x0004, 4},{0x003A, 6},{0x0007, 4},{0x0016, 5}
+  },
+  {
+    {0x000E, 4},{0x0007, 5},{0x0046, 7},{0x0045, 7},
+    {0x0064, 9},{0x032A,12},{0x0657,13},{0x0018, 5},
+    {0x000D, 6},{0x0000, 3},{0x000F, 4},{0x000A, 4},
+    {0x000B, 4},{0x001A, 5},{0x0036, 6},{0x0047, 7},
+    {0x0044, 7},{0x0018, 7},{0x0033, 8},{0x00CB,10},
+    {0x0656,13},{0x0329,12},{0x0328,12},{0x0002, 3},
+    {0x0006, 4},{0x0019, 5},{0x000E, 5},{0x0037, 6},
+    {0x0009, 4},{0x000F, 5},{0x0002, 4},{0x0010, 5}
+  },
+  {
+    {0x0003, 3},{0x0018, 5},{0x0023, 6},{0x0077, 7},
+    {0x0194, 9},{0x1956,13},{0x32AF,14},{0x003A, 6},
+    {0x0076, 7},{0x0002, 3},{0x0001, 3},{0x001F, 5},
+    {0x001E, 5},{0x0014, 5},{0x0022, 6},{0x0064, 7},
+    {0x0197, 9},{0x0196, 9},{0x032B,10},{0x0654,11},
+    {0x32AE,14},{0x1955,13},{0x1954,13},{0x0000, 3},
+    {0x0009, 4},{0x001C, 5},{0x0015, 5},{0x0010, 5},
+    {0x000D, 4},{0x0017, 5},{0x0016, 5},{0x0033, 6}
+  },
+  {
+    {0x0005, 3},{0x0006, 4},{0x003E, 6},{0x0010, 5},
+    {0x0048, 7},{0x093F,12},{0x24FA,14},{0x0032, 6},
+    {0x0067, 7},{0x0002, 3},{0x0001, 3},{0x001B, 5},
+    {0x001E, 5},{0x0034, 6},{0x0066, 7},{0x0092, 8},
+    {0x0126, 9},{0x024E,10},{0x049E,11},{0x49F7,15},
+    {0x49F6,15},{0x24F9,14},{0x24F8,14},{0x0000, 3},
+    {0x0007, 4},{0x0018, 5},{0x0011, 5},{0x003F, 6},
+    {0x000E, 4},{0x0013, 5},{0x0035, 6},{0x0025, 6}
+  },
+  {
+    {0x0005, 3},{0x0008, 4},{0x0012, 5},{0x001C, 5},
+    {0x001C, 6},{0x00EA, 9},{0x1D75,14},{0x001E, 6},
+    {0x0066, 7},{0x0001, 3},{0x0002, 3},{0x001B, 5},
+    {0x001A, 5},{0x001F, 6},{0x003B, 7},{0x0074, 8},
+    {0x01D6,10},{0x03AF,11},{0x1D74,14},{0x1D77,14},
+    {0x1D76,14},{0x0EB9,13},{0x0EB8,13},{0x000F, 4},
+    {0x0006, 4},{0x0013, 5},{0x003B, 6},{0x003A, 6},
+    {0x0000, 3},{0x0018, 5},{0x0032, 6},{0x0067, 7}
+  },
+  {
+    {0x0004, 3},{0x000A, 4},{0x001B, 5},{0x000C, 4},
+    {0x000D, 5},{0x00E6, 8},{0x0684,11},{0x0072, 7},
+    {0x00E7, 8},{0x0002, 3},{0x0001, 3},{0x0017, 5},
+    {0x0016, 5},{0x0018, 6},{0x00D1, 8},{0x01A0, 9},
+    {0x0686,11},{0x0D0F,12},{0x0D0A,12},{0x1A17,13},
+    {0x1A16,13},{0x1A1D,13},{0x1A1C,13},{0x000F, 4},
+    {0x001D, 5},{0x000E, 5},{0x0035, 6},{0x0038, 6},
+    {0x0000, 3},{0x000F, 5},{0x0019, 6},{0x0069, 7}
+  },
+  {
+    {0x0003, 3},{0x000C, 4},{0x001B, 5},{0x0000, 3},
+    {0x0003, 4},{0x002E, 6},{0x0051, 9},{0x00BC, 8},
+    {0x0053, 9},{0x0004, 3},{0x0002, 3},{0x0016, 5},
+    {0x0015, 5},{0x0015, 7},{0x0050, 9},{0x00A4,10},
+    {0x0294,12},{0x052B,13},{0x052A,13},{0x052D,13},
+    {0x052C,13},{0x052F,13},{0x052E,13},{0x000E, 4},
+    {0x001A, 5},{0x0004, 5},{0x0028, 6},{0x0029, 6},
+    {0x000F, 4},{0x000B, 6},{0x005F, 7},{0x00BD, 8}
+  },
+  {
+    {0x0003, 4},{0x0009, 6},{0x00D0, 8},{0x01A3, 9},
+    {0x0344,10},{0x0D14,12},{0x1A2B,13},{0x0004, 4},
+    {0x0015, 7},{0x0000, 3},{0x000F, 4},{0x000B, 4},
+    {0x000C, 4},{0x000E, 4},{0x0009, 4},{0x001B, 5},
+    {0x000A, 5},{0x0014, 5},{0x000D, 5},{0x002A, 6},
+    {0x0014, 7},{0x068B,11},{0x1A2A,13},{0x0008, 4},
+    {0x000B, 5},{0x002B, 6},{0x000B, 6},{0x0069, 7},
+    {0x0035, 6},{0x0008, 6},{0x0007, 4},{0x000C, 5}
+  },
+  {
+    {0x000A, 4},{0x003C, 6},{0x0032, 7},{0x0030, 7},
+    {0x00C5, 9},{0x0621,12},{0x0620,12},{0x001F, 5},
+    {0x0033, 7},{0x0001, 3},{0x0000, 3},{0x000E, 4},
+    {0x000D, 4},{0x000C, 4},{0x0004, 4},{0x000D, 5},
+    {0x0026, 6},{0x0027, 6},{0x0014, 6},{0x0063, 8},
+    {0x0189,10},{0x0623,12},{0x0622,12},{0x000B, 4},
+    {0x0012, 5},{0x003D, 6},{0x0022, 6},{0x0015, 6},
+    {0x000B, 5},{0x0023, 6},{0x0007, 4},{0x0010, 5}
+  },
+  {
+    {0x000F, 4},{0x000C, 5},{0x0043, 7},{0x0010, 6},
+    {0x0044, 8},{0x0114,10},{0x0455,12},{0x0018, 5},
+    {0x0023, 7},{0x0001, 3},{0x0000, 3},{0x000E, 4},
+    {0x000D, 4},{0x0009, 4},{0x0019, 5},{0x0009, 5},
+    {0x0017, 6},{0x0016, 6},{0x0042, 7},{0x008B, 9},
+    {0x0454,12},{0x0457,12},{0x0456,12},{0x000B, 4},
+    {0x0015, 5},{0x000A, 5},{0x0029, 6},{0x0020, 6},
+    {0x000D, 5},{0x0028, 6},{0x0007, 4},{0x0011, 5}
+  },
+  {
+    {0x0001, 3},{0x001A, 5},{0x0029, 6},{0x002A, 6},
+    {0x00A0, 8},{0x0285,10},{0x1425,13},{0x0002, 5},
+    {0x0000, 7},{0x0002, 3},{0x0003, 3},{0x000C, 4},
+    {0x000B, 4},{0x0008, 4},{0x0012, 5},{0x0001, 6},
+    {0x0051, 7},{0x0001, 7},{0x0143, 9},{0x0508,11},
+    {0x1424,13},{0x1427,13},{0x1426,13},{0x000F, 4},
+    {0x001C, 5},{0x0003, 5},{0x0037, 6},{0x002B, 6},
+    {0x0013, 5},{0x0036, 6},{0x001D, 5},{0x0001, 5}
+  },
+  {
+    {0x0004, 3},{0x001F, 5},{0x003D, 6},{0x0006, 5},
+    {0x0016, 7},{0x0053, 9},{0x014A,11},{0x0034, 6},
+    {0x002A, 8},{0x0002, 3},{0x0003, 3},{0x000B, 4},
+    {0x000C, 4},{0x001C, 5},{0x0037, 6},{0x0017, 7},
+    {0x002B, 8},{0x0028, 8},{0x00A4,10},{0x052D,13},
+    {0x052C,13},{0x052F,13},{0x052E,13},{0x0000, 3},
+    {0x001D, 5},{0x0007, 5},{0x0004, 5},{0x0035, 6},
+    {0x0014, 5},{0x0036, 6},{0x0015, 5},{0x003C, 6}
+  },
+  {
+    {0x0004, 3},{0x000A, 4},{0x0007, 5},{0x001D, 5},
+    {0x0009, 6},{0x01F3, 9},{0x07C7,11},{0x0008, 6},
+    {0x01F0, 9},{0x0003, 3},{0x0002, 3},{0x000D, 4},
+    {0x000C, 4},{0x0017, 5},{0x007D, 7},{0x01F2, 9},
+    {0x07C6,11},{0x07C5,11},{0x1F12,13},{0x3E27,14},
+    {0x3E26,14},{0x1F11,13},{0x1F10,13},{0x0000, 3},
+    {0x001E, 5},{0x0006, 5},{0x0039, 6},{0x0038, 6},
+    {0x003F, 6},{0x002C, 6},{0x0005, 5},{0x002D, 6}
+  },
+  {
+    {0x0002, 3},{0x0007, 4},{0x0018, 5},{0x0003, 4},
+    {0x0005, 5},{0x0035, 7},{0x004F, 9},{0x0012, 7},
+    {0x04E5,13},{0x0005, 3},{0x0004, 3},{0x000D, 4},
+    {0x000E, 4},{0x0033, 6},{0x0026, 8},{0x009D,10},
+    {0x04E4,13},{0x04E7,13},{0x04E6,13},{0x04E1,13},
+    {0x04E0,13},{0x04E3,13},{0x04E2,13},{0x0000, 3},
+    {0x001F, 5},{0x000C, 5},{0x003D, 6},{0x003C, 6},
+    {0x0032, 6},{0x0034, 7},{0x001B, 6},{0x0008, 6}
+  },
+  {
+    {0x0000, 3},{0x0004, 4},{0x001C, 5},{0x000F, 4},
+    {0x0002, 4},{0x0007, 5},{0x0075, 7},{0x00E8, 8},
+    {0x1D2A,13},{0x0005, 3},{0x0004, 3},{0x000D, 4},
+    {0x000C, 4},{0x0077, 7},{0x0E96,12},{0x3A57,14},
+    {0x3A56,14},{0x3A5D,14},{0x3A5C,14},{0x3A5F,14},
+    {0x3A5E,14},{0x1D29,13},{0x1D28,13},{0x0003, 3},
+    {0x0006, 5},{0x000A, 5},{0x002C, 7},{0x0017, 6},
+    {0x0076, 7},{0x01D3, 9},{0x03A4,10},{0x002D, 7}
+  },
+  {
+    {0x000A, 4},{0x0024, 6},{0x00BF, 8},{0x0085, 8},
+    {0x0211,10},{0x0842,12},{0x1087,13},{0x0018, 5},
+    {0x0020, 6},{0x0001, 3},{0x0002, 3},{0x000E, 4},
+    {0x000D, 4},{0x0007, 4},{0x0013, 5},{0x0025, 6},
+    {0x005E, 7},{0x0043, 7},{0x00BE, 8},{0x0109, 9},
+    {0x1086,13},{0x0841,12},{0x0840,12},{0x000F, 4},
+    {0x0001, 4},{0x0011, 5},{0x0000, 5},{0x002E, 6},
+    {0x0019, 5},{0x0001, 5},{0x0006, 4},{0x0016, 5}
+  },
+  {
+    {0x0002, 3},{0x000F, 5},{0x006F, 7},{0x0061, 7},
+    {0x0374,10},{0x1BA8,13},{0x3753,14},{0x0012, 5},
+    {0x0036, 6},{0x0000, 3},{0x0001, 3},{0x000A, 4},
+    {0x000B, 4},{0x001A, 5},{0x0031, 6},{0x0060, 7},
+    {0x00DC, 8},{0x01BB, 9},{0x06EB,11},{0x1BAB,13},
+    {0x3752,14},{0x3755,14},{0x3754,14},{0x000E, 4},
+    {0x0006, 4},{0x0013, 5},{0x000E, 5},{0x003E, 6},
+    {0x0008, 4},{0x001E, 5},{0x0019, 5},{0x003F, 6}
+  },
+  {
+    {0x0003, 3},{0x001C, 5},{0x0025, 6},{0x0024, 6},
+    {0x01DA, 9},{0x1DBD,13},{0x3B7C,14},{0x003C, 6},
+    {0x003D, 6},{0x0000, 3},{0x0001, 3},{0x000B, 4},
+    {0x000A, 4},{0x000B, 5},{0x0077, 7},{0x00EC, 8},
+    {0x03B6,10},{0x076E,11},{0x1DBF,13},{0x76FB,15},
+    {0x76FA,15},{0x3B79,14},{0x3B78,14},{0x000D, 4},
+    {0x001F, 5},{0x0013, 5},{0x000A, 5},{0x0008, 5},
+    {0x000C, 4},{0x0008, 4},{0x0009, 5},{0x003A, 6}
+  },
+  {
+    {0x0005, 3},{0x0003, 4},{0x0004, 5},{0x0010, 5},
+    {0x008F, 8},{0x0475,11},{0x11D1,13},{0x0079, 7},
+    {0x0027, 6},{0x0002, 3},{0x0003, 3},{0x0001, 4},
+    {0x0000, 4},{0x0026, 6},{0x0046, 7},{0x011C, 9},
+    {0x0477,11},{0x08ED,12},{0x11D0,13},{0x11D3,13},
+    {0x11D2,13},{0x11D9,13},{0x11D8,13},{0x000D, 4},
+    {0x001F, 5},{0x0012, 5},{0x0005, 5},{0x003D, 6},
+    {0x000C, 4},{0x000E, 4},{0x0022, 6},{0x0078, 7}
+  },
+  {
+    {0x0005, 3},{0x000C, 4},{0x001B, 5},{0x0000, 4},
+    {0x0006, 6},{0x03E2,10},{0x3E3D,14},{0x000F, 7},
+    {0x0034, 6},{0x0003, 3},{0x0002, 3},{0x001E, 5},
+    {0x001D, 5},{0x007D, 7},{0x01F0, 9},{0x07C6,11},
+    {0x3E3C,14},{0x3E3F,14},{0x3E3E,14},{0x3E39,14},
+    {0x3E38,14},{0x3E3B,14},{0x3E3A,14},{0x0008, 4},
+    {0x001C, 5},{0x0002, 5},{0x003F, 6},{0x0035, 6},
+    {0x0009, 4},{0x0001, 3},{0x000E, 7},{0x00F9, 8}
+  },
+  {
+    {0x0004, 3},{0x000B, 4},{0x0001, 4},{0x000A, 4},
+    {0x001E, 6},{0x00E0, 9},{0x0E1E,13},{0x0071, 8},
+    {0x0039, 7},{0x0007, 3},{0x0006, 3},{0x000D, 5},
+    {0x000C, 5},{0x0020, 7},{0x01C2,10},{0x1C3F,14},
+    {0x1C3E,14},{0x0E19,13},{0x0E18,13},{0x0E1B,13},
+    {0x0E1A,13},{0x0E1D,13},{0x0E1C,13},{0x0000, 4},
+    {0x0009, 5},{0x001D, 6},{0x001F, 6},{0x0011, 6},
+    {0x0005, 4},{0x0001, 3},{0x0043, 8},{0x0042, 8}
+  },
+  {
+    {0x0004, 3},{0x000D, 4},{0x0007, 4},{0x0002, 3},
+    {0x0014, 5},{0x016C, 9},{0x16D1,13},{0x02DF,10},
+    {0x016E, 9},{0x0000, 2},{0x0007, 3},{0x002C, 6},
+    {0x002B, 6},{0x02DE,10},{0x16D0,13},{0x16D3,13},
+    {0x16D2,13},{0x2DB5,14},{0x2DB4,14},{0x2DB7,14},
+    {0x2DB6,14},{0x16D9,13},{0x16D8,13},{0x000C, 5},
+    {0x002A, 6},{0x005A, 7},{0x001B, 6},{0x001A, 6},
+    {0x0017, 5},{0x000C, 4},{0x05B7,11},{0x05B5,11}
+  },
+  {
+    {0x0002, 2},{0x000F, 4},{0x001C, 5},{0x000C, 4},
+    {0x003B, 6},{0x01AC, 9},{0x1AD8,13},{0x35B3,14},
+    {0x35B2,14},{0x0001, 2},{0x0000, 2},{0x0069, 7},
+    {0x0068, 7},{0x35BD,14},{0x35BC,14},{0x35BF,14},
+    {0x35BE,14},{0x35B9,14},{0x35B8,14},{0x35BB,14},
+    {0x35BA,14},{0x35B5,14},{0x35B4,14},{0x01A9, 9},
+    {0x01A8, 9},{0x035A,10},{0x00D7, 8},{0x00D5, 8},
+    {0x003A, 6},{0x001B, 5},{0x35B7,14},{0x35B6,14}
+  },
+  {
+    {0x0000, 3},{0x0010, 5},{0x0072, 7},{0x0071, 7},
+    {0x0154, 9},{0x0AAB,12},{0x0AA8,12},{0x0014, 5},
+    {0x0070, 7},{0x0002, 3},{0x0003, 3},{0x000C, 4},
+    {0x000B, 4},{0x0003, 4},{0x0011, 5},{0x0073, 7},
+    {0x0054, 7},{0x00AB, 8},{0x02AB,10},{0x1553,13},
+    {0x1552,13},{0x1555,13},{0x1554,13},{0x000D, 4},
+    {0x001E, 5},{0x0012, 5},{0x003E, 6},{0x002B, 6},
+    {0x0002, 4},{0x003F, 6},{0x001D, 5},{0x0013, 5}
+  },
+  {
+    {0x0003, 3},{0x001F, 5},{0x0029, 6},{0x003D, 6},
+    {0x000C, 7},{0x0069,10},{0x0345,13},{0x0002, 5},
+    {0x0028, 6},{0x0002, 3},{0x0001, 3},{0x000E, 4},
+    {0x000C, 4},{0x0015, 5},{0x0007, 6},{0x001B, 8},
+    {0x006B,10},{0x006A,10},{0x0344,13},{0x0347,13},
+    {0x0346,13},{0x01A1,12},{0x01A0,12},{0x000B, 4},
+    {0x001A, 5},{0x0012, 5},{0x0000, 5},{0x003C, 6},
+    {0x0008, 4},{0x001B, 5},{0x0013, 5},{0x0001, 5}
+  },
+  {
+    {0x0004, 3},{0x0004, 4},{0x003F, 6},{0x0014, 5},
+    {0x0056, 7},{0x015C, 9},{0x15D5,13},{0x003C, 6},
+    {0x002A, 6},{0x0000, 3},{0x0001, 3},{0x000E, 4},
+    {0x000D, 4},{0x000C, 5},{0x00AF, 8},{0x02BB,10},
+    {0x15D4,13},{0x15D7,13},{0x15D6,13},{0x15D1,13},
+    {0x15D0,13},{0x15D3,13},{0x15D2,13},{0x000B, 4},
+    {0x0019, 5},{0x000D, 5},{0x003E, 6},{0x0031, 6},
+    {0x0007, 4},{0x0005, 4},{0x003D, 6},{0x0030, 6}
+  },
+  {
+    {0x0005, 3},{0x0008, 4},{0x001A, 5},{0x0000, 4},
+    {0x0036, 6},{0x0011, 8},{0x0106,12},{0x000A, 7},
+    {0x006E, 7},{0x0002, 3},{0x0003, 3},{0x0003, 4},
+    {0x0002, 4},{0x006F, 7},{0x0021, 9},{0x020F,13},
+    {0x020E,13},{0x0101,12},{0x0100,12},{0x0103,12},
+    {0x0102,12},{0x0105,12},{0x0104,12},{0x000C, 4},
+    {0x001E, 5},{0x0003, 5},{0x003E, 6},{0x003F, 6},
+    {0x0009, 4},{0x000E, 4},{0x000B, 7},{0x0009, 7}
+  },
+  {
+    {0x0002, 3},{0x000E, 4},{0x001E, 5},{0x000C, 4},
+    {0x001F, 5},{0x006E, 7},{0x00AD,10},{0x00AF,10},
+    {0x0014, 7},{0x0004, 3},{0x0003, 3},{0x001A, 5},
+    {0x0017, 5},{0x002A, 8},{0x0576,13},{0x0AEF,14},
+    {0x0AEE,14},{0x0571,13},{0x0570,13},{0x0573,13},
+    {0x0572,13},{0x0575,13},{0x0574,13},{0x0003, 4},
+    {0x0016, 5},{0x0004, 5},{0x0036, 6},{0x000B, 6},
+    {0x000A, 4},{0x0000, 3},{0x006F, 7},{0x00AC,10}
+  },
+  {
+    {0x0004, 3},{0x0005, 4},{0x0003, 3},{0x0001, 3},
+    {0x0004, 4},{0x002F, 6},{0x0526,11},{0x1495,13},
+    {0x00A6, 8},{0x0007, 3},{0x0006, 3},{0x002D, 6},
+    {0x002C, 6},{0x1494,13},{0x1497,13},{0x1496,13},
+    {0x1491,13},{0x1490,13},{0x1493,13},{0x1492,13},
+    {0x293D,14},{0x293C,14},{0x293F,14},{0x0000, 3},
+    {0x0028, 6},{0x00A5, 8},{0x0148, 9},{0x00A7, 8},
+    {0x002E, 6},{0x0015, 5},{0x0A4E,12},{0x293E,14}
+  },
+  {
+    {0x0004, 3},{0x0005, 4},{0x0003, 3},{0x0001, 3},
+    {0x0004, 4},{0x002F, 6},{0x0526,11},{0x1495,13},
+    {0x00A6, 8},{0x0007, 3},{0x0006, 3},{0x002D, 6},
+    {0x002C, 6},{0x1494,13},{0x1497,13},{0x1496,13},
+    {0x1491,13},{0x1490,13},{0x1493,13},{0x1492,13},
+    {0x293D,14},{0x293C,14},{0x293F,14},{0x0000, 3},
+    {0x0028, 6},{0x00A5, 8},{0x0148, 9},{0x00A7, 8},
+    {0x002E, 6},{0x0015, 5},{0x0A4E,12},{0x293E,14}
+  },
+  {
+    {0x0004, 3},{0x0005, 4},{0x0003, 3},{0x0001, 3},
+    {0x0004, 4},{0x002F, 6},{0x0526,11},{0x1495,13},
+    {0x00A6, 8},{0x0007, 3},{0x0006, 3},{0x002D, 6},
+    {0x002C, 6},{0x1494,13},{0x1497,13},{0x1496,13},
+    {0x1491,13},{0x1490,13},{0x1493,13},{0x1492,13},
+    {0x293D,14},{0x293C,14},{0x293F,14},{0x0000, 3},
+    {0x0028, 6},{0x00A5, 8},{0x0148, 9},{0x00A7, 8},
+    {0x002E, 6},{0x0015, 5},{0x0A4E,12},{0x293E,14}
+  },
+  {
+    {0x0003, 3},{0x0011, 5},{0x0020, 6},{0x0074, 7},
+    {0x010D, 9},{0x0863,12},{0x0860,12},{0x000A, 5},
+    {0x0075, 7},{0x0001, 3},{0x0000, 3},{0x000B, 4},
+    {0x000A, 4},{0x0018, 5},{0x0038, 6},{0x0042, 7},
+    {0x010F, 9},{0x010E, 9},{0x0219,10},{0x10C3,13},
+    {0x10C2,13},{0x10C5,13},{0x10C4,13},{0x000F, 4},
+    {0x0004, 4},{0x0019, 5},{0x000B, 5},{0x0039, 6},
+    {0x0009, 4},{0x001B, 5},{0x001A, 5},{0x003B, 6}
+  },
+  {
+    {0x0005, 3},{0x0001, 4},{0x003E, 6},{0x0001, 5},
+    {0x00E2, 8},{0x1C6F,13},{0x38D9,14},{0x0039, 6},
+    {0x001F, 6},{0x0002, 3},{0x0001, 3},{0x0009, 4},
+    {0x0008, 4},{0x0000, 5},{0x0070, 7},{0x01C7, 9},
+    {0x038C,10},{0x071A,11},{0x38D8,14},{0x38DB,14},
+    {0x38DA,14},{0x38DD,14},{0x38DC,14},{0x000D, 4},
+    {0x001D, 5},{0x000E, 5},{0x003F, 6},{0x003C, 6},
+    {0x000C, 4},{0x0006, 4},{0x003D, 6},{0x001E, 6}
+  },
+  {
+    {0x0006, 3},{0x000B, 4},{0x0011, 5},{0x001E, 5},
+    {0x0074, 7},{0x03AA,10},{0x1D5C,13},{0x0001, 6},
+    {0x0021, 6},{0x0001, 3},{0x0002, 3},{0x0007, 4},
+    {0x0006, 4},{0x003E, 6},{0x00EB, 8},{0x01D4, 9},
+    {0x0EAF,12},{0x3ABB,14},{0x3ABA,14},{0x1D59,13},
+    {0x1D58,13},{0x1D5B,13},{0x1D5A,13},{0x000A, 4},
+    {0x001C, 5},{0x0001, 5},{0x003F, 6},{0x003B, 6},
+    {0x0001, 4},{0x0009, 4},{0x0020, 6},{0x0000, 6}
+  },
+  {
+    {0x0004, 3},{0x000A, 4},{0x0017, 5},{0x0004, 4},
+    {0x0016, 6},{0x016A, 9},{0x16B1,13},{0x0017, 7},
+    {0x005B, 7},{0x0006, 3},{0x0007, 3},{0x0001, 4},
+    {0x0000, 4},{0x000A, 6},{0x02D7,10},{0x0B5A,12},
+    {0x16B0,13},{0x16B3,13},{0x16B2,13},{0x2D6D,14},
+    {0x2D6C,14},{0x2D6F,14},{0x2D6E,14},{0x0006, 4},
+    {0x000A, 5},{0x0004, 5},{0x002C, 6},{0x0017, 6},
+    {0x0003, 4},{0x0007, 4},{0x0016, 7},{0x00B4, 8}
+  },
+  {
+    {0x0005, 3},{0x000D, 4},{0x0005, 4},{0x0009, 4},
+    {0x0033, 6},{0x0193, 9},{0x192C,13},{0x0061, 8},
+    {0x0031, 7},{0x0000, 2},{0x0007, 3},{0x0010, 5},
+    {0x0011, 5},{0x00C8, 8},{0x192F,13},{0x325B,14},
+    {0x325A,14},{0x1929,13},{0x1928,13},{0x192B,13},
+    {0x192A,13},{0x325D,14},{0x325C,14},{0x0018, 5},
+    {0x001A, 6},{0x001B, 6},{0x0065, 7},{0x0019, 6},
+    {0x0004, 4},{0x0007, 4},{0x0060, 8},{0x0324,10}
+  },
+  {
+    {0x0006, 3},{0x0000, 3},{0x0002, 4},{0x000F, 4},
+    {0x0039, 6},{0x01D9, 9},{0x1D82,13},{0x0761,11},
+    {0x03BE,10},{0x0001, 2},{0x0002, 2},{0x000F, 6},
+    {0x000E, 6},{0x0762,11},{0x3B07,14},{0x3B06,14},
+    {0x3B1D,14},{0x3B1C,14},{0x3B1F,14},{0x3B1E,14},
+    {0x3B19,14},{0x3B18,14},{0x3B1B,14},{0x0038, 6},
+    {0x01DE, 9},{0x00ED, 8},{0x03BF,10},{0x00EE, 8},
+    {0x003A, 6},{0x0006, 5},{0x0EC0,12},{0x3B1A,14}
+  },
+  {
+    {0x0000, 2},{0x0002, 3},{0x000F, 5},{0x0006, 4},
+    {0x001C, 6},{0x01D0,10},{0x0E8C,13},{0x1D1B,14},
+    {0x1D1A,14},{0x0003, 2},{0x0002, 2},{0x00EA, 9},
+    {0x00E9, 9},{0x0E89,13},{0x0E88,13},{0x0E8B,13},
+    {0x0E8A,13},{0x1D65,14},{0x1D64,14},{0x1D67,14},
+    {0x1D66,14},{0x1D61,14},{0x1D60,14},{0x03AD,11},
+    {0x1D63,14},{0x1D62,14},{0x1D1D,14},{0x1D1C,14},
+    {0x003B, 7},{0x01D7,10},{0x1D1F,14},{0x1D1E,14}
+  },
+  {
+    {0x0002, 2},{0x000F, 4},{0x001C, 5},{0x000C, 4},
+    {0x003B, 6},{0x01AC, 9},{0x1AD8,13},{0x35B3,14},
+    {0x35B2,14},{0x0001, 2},{0x0000, 2},{0x0069, 7},
+    {0x0068, 7},{0x35BD,14},{0x35BC,14},{0x35BF,14},
+    {0x35BE,14},{0x35B9,14},{0x35B8,14},{0x35BB,14},
+    {0x35BA,14},{0x35B5,14},{0x35B4,14},{0x01A9, 9},
+    {0x01A8, 9},{0x035A,10},{0x00D7, 8},{0x00D5, 8},
+    {0x003A, 6},{0x001B, 5},{0x35B7,14},{0x35B6,14}
+  }
+};
+
+
+
+/*A description of a Huffman code value used when encoding the tree.*/
+typedef struct{
+  /*The bit pattern, left-shifted so that the MSB of all patterns is
+     aligned.*/
+  unsigned long pattern;
+  /*The amount the bit pattern was shifted.*/
+  int           shift;
+  /*The token this bit pattern represents.*/
+  int           token;
+}th_huff_entry;
+
+
+
+/*Compares two th_huff_entry structures by their bit patterns.
+  _c1: The first entry to compare.
+  _c2: The second entry to compare.
+  Return: <0 if _c1<_c2, >0 if _c1>_c2.*/
+static int huff_entry_cmp(const void *_c1,const void *_c2){
+  unsigned long b1;
+  unsigned long b2;
+  b1=((const th_huff_entry *)_c1)->pattern;
+  b2=((const th_huff_entry *)_c2)->pattern;
+  return b1<b2?-1:b1>b2?1:0;
+}
+
+int th_huff_codes2latex(const theora_huff_code _codes[80][32]){
+  int i;
+  printf("\\twocolumn\n");
+  for(i=0;i<80;i++){
+    th_huff_entry entries[32];
+    int           maxlen;
+    int           mask;
+    int           j;
+    /*First, find the maximum code length so we can align all the bit
+       patterns.*/
+    maxlen=_codes[i][0].nbits;
+    for(j=1;j<32;j++)if(maxlen<_codes[i][j].nbits)maxlen=_codes[i][j].nbits;
+    mask=(1<<maxlen)-1;
+    /*Copy over the codes into our temporary workspace.
+      The bit patterns are aligned, and the original entry each code is from
+       is stored as well.*/
+    for(j=0;j<32;j++){
+      entries[j].shift=maxlen-_codes[i][j].nbits;
+      entries[j].pattern=_codes[i][j].pattern<<entries[j].shift&mask;
+      entries[j].token=j;
+    }
+    /*Sort the codes into ascending order.
+      This is the order they will be presented in.*/
+    qsort(entries,32,sizeof(entries[0]),huff_entry_cmp);
+    printf("\\begin{center}\n");
+    printf("\\begin{tabular}{lr}\\toprule\n");
+    printf("\\multicolumn{1}{c}{Huffman Code} & Token Value \\\\\\midrule\n");
+    for(j=0;j<32;j++){
+      int k;
+      printf("\\bin{");
+      for(k=maxlen;k-->entries[j].shift;){
+        printf("%c",(int)(entries[j].pattern>>k&1)+'0');
+      }
+      printf("}");
+      for(;k>=0;k--)printf(" ");
+      printf(" & ");
+      if(entries[j].token<10)printf(" ");
+      printf("$%i$ \\\\\n",entries[j].token);
+    }
+    printf("\\bottomrule\n");
+    printf("\\\\\n");
+    printf("\\multicolumn{2}{c}{VP3.1 Huffman Table Number $%i$}\n",i);
+    printf("\\end{tabular}\n");
+    printf("\\end{center}\n");
+    printf("\\vfill\n");
+    printf("\n");
+  }
+  printf("\\onecolumn\n");
+  return 0;
+}
+
+int main(int _argc,char **_argv){
+  th_huff_codes2latex(TH_VP31_HUFF_CODES);
+  return 0;
+}
diff --git a/doc/spec/xifish.fig b/doc/spec/xifish.fig
new file mode 100644 (file)
index 0000000..f044a2b
--- /dev/null
@@ -0,0 +1,85 @@
+#FIG 3.2
+Landscape
+Center
+Inches
+Letter  
+100.00
+Single
+-2
+1200 2
+0 32 #496d9e
+0 33 #304d71
+0 34 #8eb2cf
+1 4 0 6 0 7 1 0 20 0.000 1 0.0000 1470 3255 270 270 1200 3255 1740 3255
+1 3 0 0 0 0 0 0 20 0.000 1 0.0000 1485 3255 75 75 1485 3255 1560 3255
+2 1 0 7 0 3 8 0 20 0.000 0 0 -1 0 0 6
+        2445 4140 2505 4350 2385 4425 2145 4425 2025 4380 1890 4320
+2 1 0 7 0 3 8 0 20 0.000 0 0 -1 0 0 20
+        2445 3480 2775 3450 2955 3390 3090 3315 3285 3285 3555 3285
+        3615 3390 3540 3675 3465 3720 3315 3765 3105 3810 3330 3765
+        3420 3825 3540 3900 3480 4260 3330 4320 3165 4305 2910 4260
+        2715 4185 2520 4185
+2 1 0 7 0 3 11 0 20 0.000 0 0 -1 0 0 9
+        1575 3150 1755 2985 2040 2820 2355 2760 2670 2850 2850 2985
+        3165 3270 3435 3420 2835 3780
+2 1 0 7 0 6 6 0 20 0.000 0 0 -1 0 0 15
+        900 3570 1020 3450 1095 3360 1395 3150 1545 3090 1725 3075
+        2025 3090 2205 3150 2295 3225 2385 3300 2445 3375 2550 3465
+        2655 3540 2775 3600 2865 3600
+2 1 0 7 0 3 4 0 20 0.000 0 0 -1 0 0 7
+        1515 4080 1770 4080 1875 3945 1965 3870 2025 3780 1995 3780
+        1665 3780
+2 1 0 0 -1 6 7 0 20 0.000 0 0 -1 0 0 11
+        2865 3615 2850 3735 2775 3945 2685 4080 2595 4155 2010 4185
+        1185 4170 1035 3990 1035 3870 975 3540 1155 3435
+2 1 0 0 0 3 5 0 20 0.000 0 0 -1 0 0 7
+        1035 3885 1005 4020 1095 4065 1245 4065 1245 3870 1050 3870
+        1065 3870
+2 1 0 7 0 3 0 0 20 0.000 0 0 -1 0 0 11
+        1245 3915 1245 3840 1170 3750 1005 3585 930 3510 750 3510
+        630 3600 645 3690 765 3780 885 3825 1035 3975
+2 1 0 7 0 3 0 0 20 0.000 0 0 -1 0 0 8
+        1095 3990 945 3990 855 4050 795 4140 885 4200 1095 4200
+        1155 4140 1245 4050
+2 1 0 7 0 6 6 0 20 0.000 0 0 -1 0 0 8
+        2685 4185 2400 4185 2220 4215 1920 4305 1695 4335 1485 4320
+        1245 4215 1155 4125
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2250 3900 2250 3825 2175 3825 2175 3900 2250 3900
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2250 3750 2250 3675 2175 3675 2175 3750 2250 3750
+2 1 0 0 -1 3 5 0 20 0.000 0 0 -1 0 0 9
+        1650 3780 1590 3975 1485 4035 1530 4080 1770 4065 1845 3960
+        1920 3900 1965 3795 1695 3780
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        1950 3450 1950 3375 1875 3375 1875 3450 1950 3450
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2400 3900 2400 3825 2325 3825 2325 3900 2400 3900
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2550 3975 2550 3900 2475 3900 2475 3975 2550 3975
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2700 3900 2700 3825 2625 3825 2625 3900 2700 3900
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2700 3750 2700 3675 2625 3675 2625 3750 2700 3750
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2550 3675 2550 3600 2475 3600 2475 3675 2550 3675
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2400 3750 2400 3675 2325 3675 2325 3750 2400 3750
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2400 3600 2400 3525 2325 3525 2325 3600 2400 3600
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2250 3600 2250 3525 2175 3525 2175 3600 2250 3600
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2250 3450 2250 3375 2175 3375 2175 3450 2250 3450
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2100 3525 2100 3450 2025 3450 2025 3525 2100 3525
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2100 3375 2100 3300 2025 3300 2025 3375 2100 3375
+2 2 0 0 0 0 3 0 20 0.000 0 0 0 0 0 5
+        2550 3825 2550 3750 2475 3750 2475 3825 2550 3825
+2 3 0 0 -1 32 13 0 20 0.000 0 0 7 0 0 5
+        2160 2055 3810 3705 2160 5355 510 3705 2160 2055
+2 1 0 0 32 34 12 0 20 0.000 0 0 -1 0 0 3
+        2160 2055 2160 3705 510 3705
+2 1 0 0 32 33 12 0 20 0.000 0 0 -1 0 0 3
+        3810 3705 2160 3705 2160 5355
diff --git a/doc/vp3-format.txt b/doc/vp3-format.txt
new file mode 100644 (file)
index 0000000..990f417
--- /dev/null
@@ -0,0 +1,1305 @@
+VP3 Bitstream Format and Decoding Process
+by Mike Melanson (mike at multimedia.cx)
+v0.5: December 8, 2004
+
+
+[December 8, 2004: Note that this document is not complete and likely
+will never be completed. However, it helped form the basis of Theora I 
+specification available at
+  http://www.theora.org/doc/Theora_I_spec.pdf ]
+
+
+Contents
+--------
+ * Introduction
+ * Underlying Coding Concepts
+ * VP3 Coding Overview
+ * VP3 Chunk Format
+ * Decoding The Frame Header
+ * Initializing The Quantization Matrices
+ * Hilbert Coding Pattern
+ * Unpacking The Block Coding Information
+ * Unpacking The Macroblock Coding Mode Information
+ * Unpacking The Macroblock Motion Vectors
+ * Unpacking The DCT Coefficients
+ * Reversing The DC Prediction
+ * Reconstructing The Frame
+ * Theora Specification
+ * Appendix A: Quantization Matrices And Scale Factors
+ * Appendix B: Macroblock Coding Mode Alphabets
+ * Appendix C: DCT Coefficient VLC Tables
+ * Appendix D: The VP3 IDCT
+ * Acknowledgements
+ * References
+ * Changelog
+
+
+Introduction
+------------
+A company named On2 (http://www.on2.com) created a video codec named
+VP3. Eventually, they decided to open source it. Like any body of code
+that was produced on a deadline, the source code was not particularly
+clean or well-documented. This makes it difficult to understand the
+fundamental operation of the codec.
+
+This document describes the VP3 bitstream format and decoding process at
+a higher level than source code.
+
+
+Underlying Coding Concepts
+-------------------------- 
+In order to understand the VP3 coding method it is necessary to
+understand the individual steps in the process. Like many multimedia
+compression algorithms VP3 does not consist of a single coding method.
+Rather, it uses a chain of methods to achieve compression.
+
+If you are acquainted with the MPEG video clique then many of VP3's
+coding concepts should look familiar as well. What follows is a list of
+the coding methods used in VP3 and a brief description of each.
+
+* Discrete Cosine Transform (DCT): This is a magical mathematical
+function that takes a group of numbers and turns it into another group
+of numbers. The transformed group of numbers exhibits some curious
+properties. Notably, larger numbers are concentrated in certain areas of
+the transformed group. 
+
+A video codec like VP3 often operates on 8x8 blocks of numbers. When
+these 8x8 blocks are transformed using a DCT the larger numbers occur
+mostly in the up and left areas of the block with the largest number
+occurring as the first in the block (up-left corner). This number is
+called the DC coefficient. The other 63 numbers are called the AC
+coefficients.
+
+The DCT and its opposite operation, the inverse DCT, require a lot of
+multiplications. Much research and experimentation is focused of
+optimizing this phase of the coding/decoding process.
+
+* Quantization: This coding step tosses out information by essentially
+dividing a number to be coded by a factor and throwing away the
+remainder. The inverse process (dequantization) involves multiplying by
+the same factor to obtain a number that is close enough to the original.
+
+* Run Length Encoding (RLE): The concept behind RLE is to shorten runs
+of numbers that are the same. For example, the string "88888" is encoded
+as (5, 8), indicating a run of 5 '8' numbers. In VP3 (and MPEG/JPEG),
+RLE is used to record the number of zero-value coefficients that occur
+before a non-zero coefficient. For example:
+
+  0 0 0 0 5 0 2 0 0 0 9
+
+is encoded as:
+
+  (4, 5), (1, 2), (3, 9)
+
+This indicates that a run of 4 zeroes is followed by a coefficient of 5;
+then a run of 1 zero is followed by 2; then a run of 3 zeroes is
+followed by 9.
+
+* Zigzag Ordering: After transforming and quantizing a block of samples,
+the samples are not in an optimal order for run length encoding. Zigzag
+ordering rearranges the samples to put more zeros between non-zero
+samples.
+
+* Differential (or Delta) Pulse Code Modulation (DPCM): 1 + 1 = 2. Got
+that? Seriously, that is what DPCM means. Rather than encoding absolute
+values, encode the differences between successive values. For example:
+
+  82 84 81 80 86 88 85
+
+Can be delta-encoded as:
+
+  82 +2 -3 -1 +6 +2 -3
+
+Most of the numbers turn into smaller numbers which require less
+information to encode.
+
+* Motion Compensation: Simply, this coding method specifies that a block
+from a certain position in the previous frame is to be copied into a new
+position in the current frame. This technique is often combined with DCT
+and DPCM coding, as well as fractional pixel motion.
+
+* Entropy Coding (a.k.a. Huffman Coding): This is the process of coding
+frequently occurring symbols with fewer bits than symbols that are not
+likely to occur as frequently.
+
+* Variable Length Run Length Booleans: An initial Boolean bit is
+extracted from the bitstream. A variable length code (VLC) is extracted
+from the bitstream and converted to a count. This count indicates that
+the next (count) elements are to be set to the Boolean value.
+Afterwards, the Boolean value is toggled, the next VLC is extracted and
+converted to a count, and the process continues until all elements are
+set to either 0 or 1.
+
+* YUV Colorspace: Like many modern video codecs, VP3 operates on a YUV
+colorspace rather than a RGB colorspace. Specifically, VP3 uses YUV
+4:2:0, alias YUV420P, YV12. Note: Throughout the course of this
+document, the U and V planes (a.k.a., Cb and Cr planes) will be
+collectively referred to as C planes (color or chrominance planes).
+
+* Frame Types: VP3 has intra-coded frames, a.k.a. intraframes, I-frames,
+or keyframes. VP3 happens to call these golden frames. VP3 has
+interframes, a.k.a. predicted frames or P-frames. These frames can use
+information from either the previous interframe or from the previous
+golden frame.
+
+
+VP3 Overview
+------------
+The first thing to understand about the VP3 coding method is that it
+encodes all 3 planes upside down. That is, the data is encoded from
+bottom-to-top rather than top-to-bottom as is done with many video
+codecs.
+
+VP3 codes a video frame by first breaking each of the 3 planes (Y, U,
+and V) into a series of 8x8 blocks called fragments. VP3 also has a
+notion of superblocks. Superblocks encapsulate 16 fragments arranged in
+a 4x4 matrix. Each plane has its own set of superblocks. Further, VP3
+also uses the notion of macroblocks which is the same as that found in
+JPEG/MPEG. One macroblock encompasses 4 blocks from the Y plane arranged
+in a 2x2 matrix, 1 block from the U plane, and 1 block from the V plane.
+While a fragment or a superblock applies to 1 and only 1 plane, a
+macroblock extends over all 3 planes.
+
+VP3 compresses golden frames by transforming each fragment with a
+discrete cosine transform. Each transformed sample is then quantized and
+the DC coefficient is reduced via DPCM using a combination of DC
+coefficients from surrounding fragments as predictors. Then, each
+fragment's DC coefficient is entropy-coded in the output bitstream,
+followed by each fragment's first AC coefficient, then each second AC
+coefficient, and so on.
+
+An interframe, naturally, is more complicated. While there is only one
+coding mode available for a golden frame (intra coding), there are 8
+coding modes that the VP3 coder can choose from for interframe
+macroblocks. Intra coding as seen in the keyframe is still available.
+The rest of the modes involve encoding a fragment diff, either from the
+previous frame or the golden frame, from the same coordinate or from the
+same coordinate plus a motion vector. All of the macroblock coding modes
+and motion vectors are encoded in an interframe bitstream.
+
+
+VP3 Chunk Format
+----------------
+The high-level format of a compressed VP3 frame is laid out as:
+
+ * chunk header
+ * block coding information
+ * macroblock coding mode information
+ * motion vectors
+ * DC coefficients
+ * 1st AC coefficients
+ * 2nd AC coefficients
+ * ...
+ * 63rd AC coefficients
+
+
+Decoding The Frame Header
+-------------------------
+The chunk header always contains at least 1 byte which has the following
+format:
+
+  bit 7: 0 = golden frame, 1 = interframe
+  bit 6: unused
+  bits 5-0: Quality index (0..63)
+
+Further, if the frame is a golden frame, there are 2 more bytes in the
+header:
+
+  byte 0: version byte 0
+  byte 1:
+    bits 7-3: VP3 version number (stored)
+    bit 2:    key frame coding method (0 = DCT key frame, only type
+              supported)
+    bits 1-0: unused, spare bits
+
+All frame headers are encoded with a quality index. This 6-bit value is
+used to index into 2 dequantizer scaling tables, 1 for DC values and 1
+for AC values. Each of the 3 dequantization tables is modified per these
+scaling values.
+
+
+Initializing The Quantization Matrices
+--------------------------------------
+VP3 has three static matrices for quantizing and dequantizing fragments.
+One matrix is for quantizing golden frame Y fragments, one matrix is for 
+quantizing golden frame C fragments, and one matrix is for quantizing both
+golden frame and interframe Y or C fragments. While these matrices are
+static, they are adjusted according to quality index coded in the header.
+
+The quality index is an index into 2 64-element tables:
+dc_scale_factor[] and ac_scale_factor[]. Each quantization factor from
+each of the three quantization matrices is adjusted by the appropriate
+scale factor according to this formula:
+
+                base quantizer * scale factor
+  quantizer  =  -----------------------------
+                            100
+     
+    where scale factor =
+        dc_scale_factor[quality_index] for DC dequantizer
+        ac_scale_factor[quality_index] for AC dequantizer
+
+The quantization matrices need to be recalculated at the beginning of a
+frame decode if the current frame's quality index is different from the
+previous frame's quality index.
+
+See Appendix A for the complete VP3 quantization matrices and scale factor
+tables.
+
+As an example, this is the base quantization matrix for golden frame Y
+fragments:
+
+    16  11  10  16  24  40  51  61
+    12  12  14  19  26  58  60  55
+    14  13  16  24  40  57  69  56
+    14  17  22  29  51  87  80  62
+    18  22  37  58  68 109 103  77
+    24  35  55  64  81 104 113  92
+    49  64  78  87 103 121 120 101
+    72  92  95  98 112 100 103  99
+
+If a particular coded frame specifies a quality index of 54. Element 54
+of the dc_scale_factor table is 20, thus:
+
+                               16 * 20
+  DC coefficient quantizer  =  -------  =  3
+                                 100
+
+Element 54 of the ac_scale_factor table is 24. The AC coefficient
+quantizers are each scaled using this factor, e.g.:
+
+    11 * 24
+    -------   =  2
+      100
+
+    100 * 24
+    --------  =  24
+      100
+
+[not complete; still need to explain how these quantizers are saturated
+and scaled with respect to the DCT process]
+
+
+Hilbert Coding Pattern
+----------------------
+VP3 uses a Hilbert pattern to code fragments within a superblock. A
+Hilbert pattern is a recursive pattern that can grow quite complicated.
+The coding pattern that VP3 uses is restricted to this pattern subset,
+where each fragment in a superblock is represented by a 'X':
+
+      X -> X    X -> X
+           |    ^
+           v    |
+      X <- X    X <- X
+      |              ^
+      v              |
+      X    X -> X    X
+      |    ^    |    ^
+      v    |    v    |
+      X -> X    X -> X
+
+As an example of this pattern, consider a plane that is 256 samples wide
+and 64 samples high. Each fragment row will be 32 fragments wide. The
+first superblock in the plane will be comprised of these 16 fragments:
+
+   0   1   2   3  ...  31
+  32  33  34  35  ...  63
+  64  65  66  67  ...  95
+  96  97  98  99  ... 127
+
+The order in which these 16 fragments are coded is:
+
+   0 |  0  1  14 15
+  32 |  3  2  13 12
+  64 |  4  7   8 11
+  96 |  5  6   9 10
+
+All of the image coding information, including the block coding status
+and modes, the motion vectors, and the DCT coefficients, are all coded
+and decoded using this pattern. Thus, it is rather critical to have the
+pattern and all of its corner cases handled correctly. In the above
+example, if the bottom row and left column were not present due to the
+superblock being in a corner, the pattern proceeds as if the missing
+fragments were present, but the missing fragments are omitted in the
+final coding list. The coding order would be:
+
+  0, 1, 2, 3, 4, 7, 8, 13, 14
+
+
+Unpacking The Block Coding Information
+--------------------------------------
+After unpacking the frame header, the decoder unpacks the block coding
+information. The only information determined in this phase is whether a
+particular superblock and its fragments are coded in the current frame
+or unchanged from the previous frame. The actual coding method is
+determined in the next phase.
+
+If the frame is a golden frame then every superblock, macroblock, and
+fragment is marked as coded.
+
+If the frame is an interframe, then the block coding information must be
+decoded. This is the phase where a decoder will build a list of coded
+fragments for which coding mode, motion vector, and DCT coefficient data
+must be decoded.
+
+First, a list of partially-coded superblocks is unpacked from the
+stream. This list is coded as a series of variable-length run length
+codes (VLRLC). First, the code is initialized by reading the next bit in
+the stream. Then, while there are still superblocks remaining in the
+list, fetch a VLC from the stream according to this table:
+
+  Codeword                Run Length
+  0                       1
+  10x                     2-3
+  110x                    4-5
+  1110xx                  6-9
+  11110xxx                10-17
+  111110xxxx              18-33
+  111111xxxxxxxxxxxx      34-4129
+
+For example, a VLC of 1101 represents a run length of 5. If the VLRLC
+was initialized to 1, then the next 5 superblocks would be set to 1,
+indicating that they are partially coded in the current frame. Then the
+bit value is toggled to 0, another VLC is fetched from the stream and
+the process continues until each superblock has been marked either
+partially coded (1) or not (0).
+
+If any of the superblocks were marked as not partially coded in the
+previous step, then a list of fully-coded superblocks is unpacked next
+using the same VLRLC as the list of partially-coded superblocks.
+Initialize the VLRLC with the next bit in the stream. For each
+superblock that was not marked as partially coded, mark it with either a
+0 or 1 according to the current VLRLC. By the end of this step, each
+superblock will be marked as either not coded, partially coded, or fully
+coded.
+
+Let's work through an example with an image frame that is 256x64 pixels.
+This means that the Y plane contains 4x2 superblocks and each of the C
+planes contains 2 superblocks each. The superblocks are numbered as
+follows:
+
+   Y:  0  1  2  3     U:  8  9
+       4  5  6  7     V: 10 11
+
+This is the state of the bitstream:
+
+  1100011001101
+
+Which is interpreted as:
+
+ initial   2 1's   1 0   4 1's  5 0's
+    1       100     0     1100   1101
+
+Superblocks 0-1 and 3-6 are marked as partially coded. Since there were
+blocks that were not marked, proceed to unpack the list of fully-coded
+superblocks. This is the state of the bitstream:
+
+  1101101
+
+Which is interpreted as:
+
+ initial  3 1's  3 0's
+    1      101    100
+
+Superblocks 2, 7, and 8 are marked as fully coded while superblocks 9,
+10, and 11 are marked as not coded. 
+
+If any of the superblocks were marked as partially coded, the next data
+in the bitstream will define which fragments inside each partially-coded
+superblock are coded. This is the first place where the Hilbert pattern
+comes into play.
+
+For each partially-coded superblock, iterate through each fragment
+according to the Hilbert pattern. Use the VLRLC method, only with a
+different table, to determine which fragments are coded. The VLRLC table
+for fragment coding runs is:
+
+  Codeword                Run Length
+  0x                      1-2
+  10x                     3-4
+  110x                    5-6
+  1110xx                  7-10
+  11110xx                 11-14
+  11111xxxx               15-30
+
+Continuing with the contrived example, superblocks 0 and 1 are both
+partially coded. This is the state of the bitstream:
+
+  0011001111010001111010...(not complete)
+
+Which is interpreted as:
+ initial  2 0's  3 1's  13 0's   1 1   13 0's
+    0      01     100   1111010   00   1111010 ...
+
+This indicates that fragments 2-4 in superblock 0 are coded, while
+fragments 0, 1, and 5-15 are not. Note that the run of 12 0's cascades
+over into the next fragment, indicating that fragment 0 of superblock 1
+is not coded. Fragment 1 of superblock 1 is coded, while the rest of the
+superblock's fragments are not coded. The example ends there (a real
+bitstream should have enough data to describe all of the partially-coded
+superblocks). Superblock 2 is fully coded which means all 16 fragments
+are coded. Thus, superblocks 0-2 have the following coded fragments:
+
+  0 |  x  x  x  x    x  x  x  x    0  1 14 15
+ 32 |  3  2  x  x    x  2  x  x    3  2 13 12
+ 64 |  4  x  x  x    x  x  x  x    4  7  8 11
+ 96 |  x  x  x  x    x  x  x  x    5  6  9 10
+
+This is a good place to generate the list of coded fragment numbers for
+this frame. In this case, the list will begin as:
+
+  33 32 64 37 8 9 41 40 72 104 105 73 ...
+
+and so on through the remaining 8 fragments of superblock 2 and onto the
+fragments for the remaining superblocks that are either fully or
+partially coded.
+
+
+Unpacking The Macroblock Coding Mode Information
+------------------------------------------------
+After unpacking the block coding information, the decoder unpacks the
+macroblock coding mode information. This process is simple when
+decoding a golden frame-- since the only possible decoding mode is INTRA,
+no macroblock coding mode information is transmitted. However, in an
+interframe, each coded macroblock is encoded with one of 8 methods:
+
+0, INTER_NO_MV: 
+  current fragment = 
+    (fragment from previous frame @ same coordinates) +
+    (DCT-encoded residual)
+
+1, INTRA: 
+  current fragment = DCT-encoded block, just like in a golden frame
+
+2, INTER_PLUS_MV:
+  current fragment =
+    (fragment from previous frame @ (same coords + motion vector)) +
+    (DCT-encoded residual)
+
+3, INTER_LAST_MV:
+  same as INTER_PLUS_MV but using the last motion vector decoded from
+  the bitstream
+
+4, INTER_PRIOR_LAST;
+  same as INTER_PLUS_MV but using the second-to-last motion vector
+  decoded from the bitstream
+
+5, USING_GOLDEN:
+  same as INTER_NO_MV but referencing the golden frame instead of
+  previous interframe
+
+6, GOLDEN_MV:
+  same as INTER_PLUS_MV but referencing the golden frame instead of
+  previous interframe
+
+7, INTER_FOURMV:
+  same as INTER_PLUS_MV except that each of the 4 Y fragments gets its
+  own motion vector, and the U and V fragments share the same motion
+  vector which is the average of the 4 Y fragment vectors
+
+The MB coding mode information is encoded using one of 8 alphabets. The
+first 3 bits of the MB coding mode stream indicate which of the 8
+alphabets, 0..7, to use to decode the MB coding information in this frame.
+The reason for the different alphabets is to minimize the number of bits
+needed to encode this section of information. Each alphabet arranges the
+coding modes in a different order, indexing the 8 modes into 8 index
+slots. Index 0 is encoded with 1 bit (0), index 1 is encoded with 2 bits
+(10), index 2 is encoded with 3 bits (110), and so on up to indices 6 and
+7 which are encoded with 6 bits each (1111110 and 1111111, respectively):
+
+  index   encoding
+  -----   --------
+    0      0
+    1      10
+    2      110
+    3      1110
+    4      11110
+    5      111110
+    6      1111110
+    7      1111111
+
+For example, the coding modes are arranged in alphabet 1 as follows:
+
+  index   coding mode
+  -----   -----------
+    0     MODE_INTER_LAST_MV
+    1     MODE_INTER_PRIOR_LAST
+    2     MODE_INTER_PLUS_MV
+    3     MODE_INTER_NO_MV
+    4     MODE_INTRA   
+    5     MODE_USING_GOLDEN,      
+    6     MODE_GOLDEN_MV   
+    7     MODE_INTER_FOURMV
+
+This alphabet arrangement is designed for frames in which motion vectors
+based off of the previous interframe dominate.
+
+When unpacking MB coding mode information for a frame, the decoder first
+reads 3 bits from the stream to determine the alphabet. In this example,
+the 3 bits would be 001 to indicate alphabet 1. Consider this contrived
+bitstream following the alphabet number:
+
+  1010000011000011111110...
+  
+The bits are read as follows:
+
+         10 10 0 0 0 0 110 0 0 0 1111111 0
+  index:  1  1 0 0 0 0   2 0 0 0       7 0
+
+This arrangement of indices translates to this series of coding modes:
+
+  index   coding mode
+  -----   -----------
+    1     MODE_INTER_PRIOR_LAST
+    1     MODE_INTER_PRIOR_LAST
+    0     MODE_INTER_LAST_MV
+    0     MODE_INTER_LAST_MV
+    0     MODE_INTER_LAST_MV
+    0     MODE_INTER_LAST_MV
+    2     MODE_INTER_PLUS_MV
+    0     MODE_INTER_LAST_MV
+    0     MODE_INTER_LAST_MV
+    0     MODE_INTER_LAST_MV
+    7     MODE_INTER_FOURMV
+    0     MODE_INTER_LAST_MV
+  
+There are 6 pre-defined alphabets. Consult Appendix B for the complete
+alphabets. What happens if none of the 6 pre-defined alphabets fit? The
+VP3 encoder can choose to use alphabet 0 which indicates a custom
+alphabet. The 3-bit coding mode numbers for each index, 0..7, are stored
+after the alphabet number in the bitstream. For example, the sequence:
+
+  000 111 110 101 100 011 010 001 000
+
+would indicate coding alphabet 0 (custom alphabet), index 0 corresponds to
+coding mode 7 (INTER_FOURMV), index 1 corresponds to coding mode 6
+(GOLDEN_MV), and so on down to index 7 which would correspond to coding
+mode 0 (INTER_NO_MV).
+
+There is one more possible alphabet: Alphabet 7. This alphabet is
+reserved for when there is such a mixture of coding modes used in a frame
+that using any variable-length coding mode would result in more bits than
+a fixed-length representation. When alphabet 7 is specified, the decoder
+reads 3 bits at a time from the bitstream, and uses those directly as the
+macroblock coding modes.
+
+To recap, this is the general algorithm for decoding macroblock coding
+mode information:
+
+  if (golden frame)
+    all frames are intracoded, there is no MB coding mode information
+  else
+    read 3 bits from bitstream to determine alphabet
+    if alphabet = 0
+      this is a custom alphabet, populate index table with 8 3-bit coding
+        modes read from bitstream
+    foreach coded macroblock, unpack a coding mode:
+      if alphabet = 7
+        read 3 bits from the bitstream as the coding mode for the
+          macroblock
+      else
+        read a VLC from the bitstream
+        use the decoded VLC value to index into the coding mode alphabet
+          selected for this frame and assign the indexed coding mode to
+          this macroblock
+  
+
+Unpacking The Macroblock Motion Vectors
+---------------------------------------
+After unpacking the macroblock coding mode information, the decoder
+unpacks the macroblock motion vectors. This phase essentially assigns a
+motion vector to each of the 6 constituent fragments of any coded
+macroblock that requires motion vectors.
+
+If the frame is a golden frame then there is no motion compensation and
+no motion vectors are encoded in the bitstream.
+
+If the frame is an interframe, the next bit is read from the bitstream
+to determine the vector entropy coding method used. If the coding method
+is zero then all of the vectors will be unpacked using a VLC method. If
+the coding method is 1 then all of the vectors will be unpacked using a
+fixed length method.
+
+The VLC unpacking method reads 3 bits from the bitstream. These 3 bits
+comprise a number ranging from 0..7 which indicate the next action:
+
+0, MV component = 0
+1, MV component = 1
+2, MV component = -1
+3, MV component = 2, read next bit for sign
+4, MV component = 3, read next bit for sign
+5, MV component = 4 + (read next 2 bits), read next bit for sign
+   range: (4..7, -4..-7)
+6, MV component = 8 + (read next 3 bits), read next bit for sign
+   range: (8..15, -8..-15)
+7, MV component = 16 + (read next 4 bits), read next bit for sign
+   range: (16..31, -16..-31)
+
+The fixed length vector unpacking method simply reads the next 5 bits
+from the bitstream, reads the next bit for sign, and calls the whole
+thing a motion vector component. This gives a range of (-31..31), which
+is the same range as the VLC method.
+
+For example, consider the following contrived motion vector bitstream:
+
+  000001011011111000...
+
+The stream is read as:
+
+  0  (000  010)  (110 111 1  100 0)
+
+The first bit indicates the entropy method which, in this example, is
+variable length as opposed to fixed length. The next 3 bits are 0 which
+indicate a X MV component of 0. The next 3 bits are 2 which indicate a Y
+MV component of -1. The first motion vector encoded in this stream is
+(0, -1). The next 3 bits are 6 which indicate 8 + next 3 bits (7) with
+another bit indicating sign (1 in this case, which is negative). Thus,
+the X MV component is -15. The next 3 bits are 4 which indicate a Y MV
+component of 3 with one more bit for the sign (0 is positive). So the
+second motion vector encoded in this stream is (-15, 3).
+
+As an example of the fixed-length entropy method, consider the following
+contrived bitstream:
+
+  1010101101010...
+
+The stream is read as:
+
+  1  01010 1  10101 0
+
+The first bit indicates the fixed length entropy method. The first 5 bits
+are 10 followed by a negative sign bit. The next 5 bits are 21 followed by
+a positive sign bit. The first motion vector in this stream is (-10, 21).
+
+During this phase of the decoding process, it is traditional to assign all
+motion vectors for all coded macroblocks that require them, whether they
+are unpacked from the motion vector bitstream or copied from previous
+coded macroblocks. It is necessary to track the motion vectors for both
+the previous macroblock as well as the next-to-last (prior) macroblock.
+The general algorithm for this phase is as follows:
+
+  foreach coded macroblock
+    last MV = 0
+    prior last MV = 0
+    if coding mode = MODE_INTER_PLUS_MV or MODE_GOLDEN_MV
+      read current MV pair from the bitstream and set all fragment motion
+        vectors to that pair
+      prior last MV = last MV
+      last MV = current MV
+    
+    if coding mode = MODE_INTER_FOURMV
+      read MV for first Y fragment in macroblock
+      read MV for second Y fragment in macroblock
+      read MV for third Y fragment in macroblock
+      read MV for fourth Y fragment in macroblock
+      set U & V fragment motion vectors to average of 4 Y vectors,
+        calculated as follows:
+        if sum of all 4 X motion components is positive, the X
+        motion component for the U & V fragments is (sum + 2) / 4,
+        otherwise, it is (sum - 2) / 4; repeat the same process for the
+        Y components
+      prior last MV = last MV
+      last MV = MV for fourth Y fragment from this macroblock
+      
+    if coding mode = MODE_INTER_LAST_MV
+      motion vectors for this macroblock are the same as last MV; note
+        that in this case, the last MV remains the last MV and the prior
+        last MV remains the prior last MV
+      
+    if coding mode = MODE_INTER_PRIOR_LAST
+      motion vectors for this macroblock are the same as prior last MV
+      prior last MV = last MV
+      last MV = current MV (effectively, swap last and prior last vectors)
+
+
+Unpacking The DCT Coefficients
+------------------------------
+After unpacking the macroblock motion vectors, the decoder unpacks the
+fragment DCT coefficient data. Each coded fragment has 64 DCT 
+coefficients. Some of the coefficients will be non-zero. Many of the 
+coefficients will, or should be 0 as this is where the coding method
+derives much of its compression.
+
+During this phase, the decoder will be unpacking DCT coefficients, zero
+runs, and end-of-block (EOB) codes. The decoder unpacks the the DC 
+coefficients for all fragments, then all of the first AC coefficients, 
+and so on until all of the 64 DCT coefficients are unpacked from the
+bitstream.
+
+To obtain the DCT coefficients, the decoder unpacks a series of VLCs
+from the bitstream which turn into a series of tokens ranging from
+0..31. Each of these tokens specifies which action to take next. VP3
+defines 80 different 32-element histograms for VLC decoding:
+
+  16 histograms for DC token decoding
+  16 histograms for group 1 AC token decoding
+  16 histograms for group 2 AC token decoding
+  16 histograms for group 3 AC token decoding
+  16 histograms for group 4 AC token decoding
+
+The decoder fetches 4 bits from the bitstream that will be used to
+select a DC histogram and 4 bits that will be used to select 4 AC
+histograms, one for each AC group.
+
+The meaning of each of the 32 possible tokens follows. 'EB' stands for
+extra bits read from bitstream directly after the VLC token:
+
+0, DCT_EOB_TOKEN
+set the current block to EOB, meaning that the block is marked as being
+fully unpacked
+
+1, DCT_EOB_PAIR_TOKEN
+set the next 2 blocks to EOB
+
+2. DCT_EOB_TRIPLE_TOKEN
+set the next 3 blocks to EOB
+
+3, DCT_REPEAT_RUN_TOKEN
+set the next (2 EBs + 4) blocks to EOB
+
+4, DCT_REPEAT_RUN2_TOKEN
+set the next (3 EBs + 8) blocks to EOB
+
+5, DCT_REPEAT_RUN3_TOKEN
+set the next (4 EBs + 16) blocks to EOB
+
+6, DCT_REPEAT_RUN4_TOKEN
+set the next (12 EBs) blocks to EOB
+
+7, DCT_SHORT_ZRL_TOKEN
+skip (3 EBs + 1) positions in the output matrix
+
+8, DCT_ZRL_TOKEN
+skip (6 EBs + 1) positions in the output matrix
+
+9, ONE_TOKEN
+output 1 as coefficient
+
+10, MINUS_ONE_TOKEN
+output -1 as coefficient
+
+11, TWO_TOKEN
+output 2 as coefficient
+
+12, MINUS_TWO_TOKEN
+output -2 as coefficient
+
+13, 14, 15, 16, LOW_VAL_TOKENS
+next EB determines coefficient sign; coeff = DCT_VAL_CAT2_MIN (3) +
+(token - 13) (this gives a range of +/- 3..6)
+
+17, DCT_VAL_CATEGORY3
+next EB determines coefficient sign; coeff = DCT_VAL_CAT3_MIN (7) + next
+EB (this gives a range of +/- 7..8)
+
+18, DCT_VAL_CATEGORY4
+next EB determines coefficient sign; coeff = DCT_VAL_CAT4_MIN (9) + next
+2 EBs (this gives a range of +/- 9..12)
+
+19, DCT_VAL_CATEGORY5
+next EB determines coefficient sign; coeff = DCT_VAL_CAT5_MIN (13) +
+next 3 EBs (this gives a range of +/- 13..20)
+
+20, DCT_VAL_CATEGORY6
+next EB determines coefficient sign; coeff = DCT_VAL_CAT6_MIN (21) +
+next 4 EBs (this gives a range of +/- 21..36)
+
+21, DCT_VAL_CATEGORY7
+next EB determines coefficient sign; coeff = DCT_VAL_CAT7_MIN (37) +
+next 5 EBs (this gives a range of +/- 37..68)
+
+22, DCT_VAL_CATEGORY8
+next EB determines coefficient sign; coeff = DCT_VAL_CAT8_MIN (69) +
+next 9 EBs (this gives a range of +/- 69..580)
+
+23, 24, 25, 26, 27, DCT_RUN_CATEGORY1
+coefficient of +/- 1 preceded by a number of 0s; next EB determines sign
+of coefficient; skip (token - 22) 0s in the output matrix before
+placing the final coefficient (this gives a range of 1..5 0s)
+
+28, DCT_RUN_CATEGORY1B
+coefficient of +/- 1 preceded by a number of 0s; next EB determines sign
+of coefficient; skip (next 2 EBs + 6) 0s in the output matrix before
+placing the final coefficient (this gives a range of 6..9 0s)
+
+29, DCT_RUN_CATEGORY1C
+coefficient of +/- 1 preceded by a number of 0s; next EB determines sign
+of coefficient; skip (next 3 EBs + 10) 0s in the output matrix before
+placing the final coefficient (this gives a range of 10..17 0s)
+
+30, DCT_RUN_CATEGORY2
+coefficient of +/- 2..3 preceded by a single zero; next EB determines
+sign of coefficient; coefficient = (next EB + 2)
+
+31, DCT_RUN_CATEGORY2B (not specifically named in VP3 source)
+coefficient of +/- 2..3 preceded by 2 or 3 0s; next EB determines
+sign of coefficient; coefficient = (next EB + 2); skip (next EB + 2) 0s
+before placing coefficient in output matrix
+
+Note: EOB runs can, and often do, cross threshold stages and plane
+boundaries. For example, a decoder may have decoded all of the AC #2
+coefficients for all fragments and still have an EOB run of 2. That
+means that during the AC #3 decode process, the first 2 coded fragments
+that are not already EOB will be set to EOB.
+
+Let's work through a highly contrived example to illustrate the
+coefficient decoding process.
+
+
+
+[not finished]
+
+
+
+
+When the decoder is finished unpacking the DCT coefficients, the entire
+encoded VP3 frame bitstream should be consumed.
+
+
+Reversing The DC Prediction
+---------------------------
+Now that all of the DCT coefficient data has been unpacked, the DC
+coefficients need to be fully reconstructed before the IDCT can be
+performed.
+
+VP3 uses a somewhat involved process for DC prediction which uses up to
+four DC coefficients from surrounding fragments. For each fragment to be
+transformed with the IDCT, the DC coefficient is predicted from weighted
+sum of the DC coefficients in the left (l), up-left (ul), up (u), and
+up-right (ur) fragments, if they are coded (not unchanged from the
+previous frame) in a compatible frame (current, previous, or golden).
+
+In a golden frame, the prediction is quite straightforward since all
+fragments will be coded. A fragment's DC prediction will fall into 1 of
+5 groups:
+
+     abbbbbbbbb
+     cdddddddde
+     cdddddddde
+     cdddddddde
+     cdddddddde
+
+* Group a is the top left corner fragment. There is nothing to predict
+from. This DC coefficient has a lot of energy and requires many bits to
+code.
+
+* Group b is the remainder of the top row of fragments. These fragments
+can only predict from the left fragment.
+
+* Group c is the left column of fragments, not including the top left
+fragment. These fragments have the top and top-right fragments from
+which to predict.
+
+* Group d is the main body of fragments. These fragments have access to
+all 4 predictors.
+
+* Group e is the right column of fragments, not including the top right
+fragment. These fragments can predict from the left, up-left and up
+fragments.
+
+The process of reversing prediction for interframes grows more complex.
+First, the decoder must evaluate which candidate fragments (l, ul, u, or
+ur) are available for as predictors. Then, it can only use fragments
+that are coded within the same frame (current, previous, or golden).
+Further, there are auxiliary predictors for each frame type that are
+initialized to 0 at the start of each video frame decode operation. The
+decoder falls back on these auxiliary predictors when it can not find
+any valid candidate predictors for the current fragment.
+
+To work through some examples, consider the following notation, e.g.:
+
+  ul-C = up-left fragment, coded in the current frame
+   u-P = up fragment, coded as a motion residual from the previous frame
+  ur-C = up-right fragment, coded in the current frame
+   l-G = left fragment, coded as a motion residual from the golden frame   
+   x-P = current fragment where DC prediction is being performed, coded
+         as a motion residual from the previous frame
+
+This is a simple case:
+
+   ul-C   u-C  ur-C
+    l-C   x-C
+
+The current fragment predicts from all four of the candidate fragments
+since they are coded in the same frame. 
+
+   ul-P   u-C  ur-C
+    l-P   x-P
+
+The current fragment predicts from the left and up-left fragments.
+
+   ul-C   u-P  ur-G
+    l-P   x-G
+
+The current fragment predicts from the up-right fragment.
+
+   ul-C   u-C  ur-C
+    l-C   x-G
+
+The current fragment does not predict from any of the candidate
+fragments since the current fragment is a motion residual from the
+golden frame. Rather, add the auxiliary golden frame predictor to the
+current fragment's DC coefficient. Save the new DC coefficient as the
+new golden frame auxiliary DC predictor.
+
+If the decoder only finds one valid candidate predictor, then it is used
+by itself. When the decoder finds multiple valid candidate fragments
+from which to predict DC, it applies a weighting function to the
+surrounding fragments' DC coefficients. The following table presents all 
+16 possible combinations of available/not available predictors and what 
+to do in each case:
+
+    ul   u  ur   l
+    --  --  --  --
+     0   0   0   0    no predictors available:
+                        use the last predictor saved for the frame type
+                        (either intra, inter, or golden)
+
+     0   0   0   1    left predictor available:
+                        pred = l.dc
+
+     0   0   1   0    up-right predictor available:
+                        pred = ur.dc
+
+     0   0   1   1    up-right, left predictors available:
+                        pred = (53 * ur.dc) + (75 * l.dc)
+                               --------------------------
+                                         128
+
+     0   1   0   0    up predictor available:
+                        pred = u.dc
+
+     0   1   0   1    up, left predictors available:
+                        pred = (u.dc + l.dc)
+                               -------------
+                                     2
+
+     0   1   1   0    up, up-right predictors available:
+                        discard up-right predictor
+                        pred = u.dc
+
+     0   1   1   1    up, up-right, left predictors available:
+                        discard up predictor
+                        pred = (53 * ur.dc) + (75 * l.dc)
+                               --------------------------
+                                         128
+
+     1   0   0   0    up-left predictor available:
+                        pred = ul.dc
+
+     1   0   0   1    up-left, left predictors available:
+                        discard up-left predictor
+                        pred = l.dc
+
+     1   0   1   0    up-left, up-right predictors available:
+                        pred = (ul.dc + ur.dc)
+                               ---------------
+                                      2
+
+     1   0   1   1    up-left, up-right, left predictors available:
+                        discard up-left predictor
+                        pred = (53 * ur.dc) + (75 * l.dc)
+                               --------------------------
+                                         128
+
+     1   1   0   0    up-left, up predictors available:
+                        discard up-left
+                        pred = u.dc
+
+     1   1   0   1    up-left, up, left predictors available:
+                        pred = (-26 * ul.dc + 29 * u.dc + 29 * l.dc)
+                               -------------------------------------
+                                                 32
+
+     1   1   1   0    up-left, up, up-right predictors available:
+                        pred = (3 * ul.dc + 10 * u.dc + 3 * ur.dc)
+                               -----------------------------------
+                                                16
+
+     1   1   1   1    all 4 predictors available:
+                        discard up-right predictor
+                        pred = (-26 * ul.dc + 29 * u.dc + 29 * l.dc)
+                               -------------------------------------
+                                                 32
+
+Note that this final prediction case ([ul u l]) risks outranging. The
+difference of the predicted DC is checked against u.dc, l.dc, and ul.dc,
+in that order, and if the difference is greater than 128 in any case,
+the predictor is assigned as that DC coefficient. In pseudocode:
+
+  if (ABSOLUTE_VALUE(pred - u.dc) > 128)
+    pref = u.dc
+  else if (ABSOLUTE_VALUE(pred - l.dc) > 128)
+    pref = l.dc
+  else if (ABSOLUTE_VALUE(pred - ul.dc) > 128)
+    pref = ul.dc
+
+The predicted value is, at long last, added to the fragment's decoded DC
+coefficient. Finally, the new DC coefficient is saved as the frame
+type's auxiliary predictor. For example, if this fragment is coded as a
+motion residual from the previous frame, save the fragment's DC
+coefficient as the previous frame auxiliary predictor.
+
+
+[still need to mention precise rounding considerations, a.k.a, the
+HIGHTBITDUPPED() macro]
+
+
+
+Reconstructing The Frame
+------------------------
+rough outline:
+  - foreach fragment:
+    - if motion vector
+      - copy motion fragment from appropriate frame into current frame
+        (don't forget to account for unrestricted motion vectors)
+    - dequantize fragment coefficients
+    - run coefficients through inverse DCT
+    - if INTRA coded fragment
+      - output transformed coefficients
+    - else
+      - apply transformed residual to motion fragment
+    
+[not finished]
+
+
+Theora Specification
+--------------------
+The Theora project leverages the VP3 codec into a new video coding
+system. The algorithm and bitstream format are the same as VP3 with a
+few minor differences:
+
+1) The frame orientation is reversed-- VP3 is coded from bottom to top
+while Theora video is coded from top to bottom.
+[nope-- only true in the first few alpha releases; final Theora spec will
+be upside-down, the same as VP3]
+
+2) Variable histograms-- VP3 uses a hardcoded set of histograms for DCT
+coefficient coding (described in section "Unpacking The DCT
+Coefficients"). Theora packs the histogram information in the header of
+the transport format (which is meant to be Ogg, but can probably be
+coerced into a variety of other multimedia container formats).
+
+3) Variable quantization-- As with the histograms, Theora codes the
+quantization tables and quality thresholds (described in section
+"Initializing The Quantization Matrices") into the header.
+
+4) [special VLRLC case for encoding unusually large runs of blocks;
+necessary for HD resolutions]
+
+[still need coding format of histogram and quantizer information]
+
+
+Appendix A: VP31 Quantization Matrices And Scale Factors
+--------------------------------------------------------
+The following quantization matrices and scale factor tables are hardcoded
+into the VP31 coding standard. These tables can vary according to the
+setup information transported along with a Theora file.
+
+Base quantization matrix for golden frame Y fragments (note that this 
+is the same as JPEG):
+
+    16  11  10  16  24  40  51  61
+    12  12  14  19  26  58  60  55
+    14  13  16  24  40  57  69  56
+    14  17  22  29  51  87  80  62
+    18  22  37  58  68 109 103  77
+    24  35  55  64  81 104 113  92
+    49  64  78  87 103 121 120 101
+    72  92  95  98 112 100 103  99
+
+
+Base quantization matrix for golden frame C fragments (note that this 
+is the same as JPEG):
+    
+    17  18  24  47  99  99  99  99
+    18  21  26  66  99  99  99  99
+    24  26  56  99  99  99  99  99
+    47  66  99  99  99  99  99  99
+    99  99  99  99  99  99  99  99
+    99  99  99  99  99  99  99  99
+    99  99  99  99  99  99  99  99
+    99  99  99  99  99  99  99  99
+
+
+Base quantization matrix for interframe Y and C fragments:
+
+    16  16  16  20  24  28  32  40
+    16  16  20  24  28  32  40  48
+    16  20  24  28  32  40  48  64
+    20  24  28  32  40  48  64  64
+    24  28  32  40  48  64  64  64
+    28  32  40  48  64  64  64  96
+    32  40  48  64  64  64  96 128
+    40  48  64  64  64  96 128 128
+
+
+DC coefficient scale factor table:
+
+   220 200 190 180 170 170 160 160
+   150 150 140 140 130 130 120 120
+   110 110 100 100  90  90  90  80
+    80  80  70  70  70  60  60  60
+    60  50  50  50  50  40  40  40
+    40  40  30  30  30  30  30  30
+    30  20  20  20  20  20  20  20
+    20  10  10  10  10  10  10  10
+
+
+AC coefficient scale factor table:
+
+   500 450 400 370 340 310 285 265
+   245 225 210 195 185 180 170 160
+   150 145 135 130 125 115 110 107
+   100  96  93  89  85  82  75  74
+    70  68  64  60  57  56  52  50
+    49  45  44  43  40  38  37  35
+    33  32  30  29  28  25  24  22
+    21  19  18  17  15  13  12  10
+
+
+Appendix B: Macroblock Coding Mode Alphabets
+--------------------------------------------
+These are the 6 pre-defined alphabets used to decode macroblock coding
+mode information:
+
+Alphabet 1:
+  index   coding mode
+  -----   -----------
+    0     MODE_INTER_LAST_MV
+    1     MODE_INTER_PRIOR_LAST
+    2     MODE_INTER_PLUS_MV
+    3     MODE_INTER_NO_MV
+    4     MODE_INTRA   
+    5     MODE_USING_GOLDEN,      
+    6     MODE_GOLDEN_MV   
+    7     MODE_INTER_FOURMV
+
+Alphabet 2:
+  index   coding mode
+  -----   -----------
+    0     MODE_INTER_LAST_MV
+    1     MODE_INTER_PRIOR_LAST
+    2     MODE_INTER_NO_MV
+    3     MODE_INTER_PLUS_MV
+    4     MODE_INTRA
+    5     MODE_USING_GOLDEN
+    6     MODE_GOLDEN_MV
+    7     MODE_INTER_FOURMV
+
+Alphabet 3:
+  index   coding mode
+  -----   -----------
+    0     MODE_INTER_LAST_MV
+    1     MODE_INTER_PLUS_MV
+    2     MODE_INTER_PRIOR_LAST
+    3     MODE_INTER_NO_MV
+    4     MODE_INTRA
+    5     MODE_USING_GOLDEN
+    6     MODE_GOLDEN_MV
+    7     MODE_INTER_FOURMV
+    
+Alphabet 4:
+  index   coding mode
+  -----   -----------
+    0     MODE_INTER_LAST_MV
+    1     MODE_INTER_PLUS_MV
+    2     MODE_INTER_NO_MV
+    3     MODE_INTER_PRIOR_LAST
+    4     MODE_INTRA
+    5     MODE_USING_GOLDEN
+    6     MODE_GOLDEN_MV
+    7     MODE_INTER_FOURMV
+
+Alphabet 5:
+  index   coding mode
+  -----   -----------
+    0     MODE_INTER_NO_MV
+    1     MODE_INTER_LAST_MV
+    2     MODE_INTER_PRIOR_LAST
+    3     MODE_INTER_PLUS_MV
+    4     MODE_INTRA
+    5     MODE_USING_GOLDEN
+    6     MODE_GOLDEN_MV
+    7     MODE_INTER_FOURMV
+    
+Alphabet 6:
+  index   coding mode
+  -----   -----------
+    0     MODE_INTER_NO_MV
+    1     MODE_USING_GOLDEN
+    2     MODE_INTER_LAST_MV
+    3     MODE_INTER_PRIOR_LAST
+    4     MODE_INTER_PLUS_MV
+    5     MODE_INTRA
+    6     MODE_GOLDEN_MV
+    7     MODE_INTER_FOURMV
+
+
+Appendix C: DCT Coefficient VLC Tables
+--------------------------------------
+- VP31 tables are hardcoded
+- Theora tables are transported with video stream
+
+[not finished]
+
+
+Appendix D: The VP3 IDCT
+------------------------
+
+[not finished]
+
+
+Acknowledgements
+----------------
+Thanks to Michael Niedermayer (michaelni at gmx dot at) for peer review,
+corrections, and recommendations for improvement.
+
+Dan Miller (dan at on2 dot com) for clarifications on pieces of the
+format.
+
+Timothy B. Terriberry (tterribe at vt dot edu) for clarification about the
+differences between VP3 and Theora, detailed explanation of motion 
+vector mechanics.
+
+
+References
+----------
+Tables necessary for decoding VP3:
+http://mplayerhq.hu/cgi-bin/cvsweb.cgi/~checkout~/ffmpeg/libavcodec/vp3data.h?content-type=text/x-cvsweb-markup&cvsroot=FFMpeg
+
+Official VP3 site:
+http://www.vp3.com/
+
+Theora, based on VP3:
+http://www.theora.org/
+
+On2, creators of the VP3 format:
+http://www.on2.com/
+
+
+ChangeLog
+---------
+v0.5: December 8, 2004
+- reworked section "Reversing The DC Prediction" to include a tabular 
+representation of all 16 prediction modes
+
+v0.4: March 2, 2004
+- renamed and expanded section "Initializing The Quantization Matrices"
+- outlined section "Reconstructing The Frame"
+- moved Theora Differences Appendix to its own section entitled "Theora
+Specification"
+- added Appendix: Quantization Matrices And Scale Factors
+- added Appendix: DCT Coefficient VLC Tables
+
+v0.3: February 29, 2004
+- expanded section "Unpacking The Macroblock Coding Mode Information"
+- expanded section "Unpacking The Macroblock Motion Vectors"
+- added Appendix: Macroblock Coding Mode Alphabets
+
+v0.2: October 9, 2003
+- expanded section "Reversing the DC Prediction"
+- added Appendix: Theora Differences
+
+v0.1: June 17, 2003
+- initial release, nowhere near complete
diff --git a/examples/Makefile.am b/examples/Makefile.am
new file mode 100644 (file)
index 0000000..45cb515
--- /dev/null
@@ -0,0 +1,38 @@
+## Process this file with automake to produce Makefile.in
+
+INCLUDES = -I$(top_srcdir)/include 
+
+noinst_PROGRAMS = dump_video dump_psnr $(BUILDABLE_EXAMPLES)
+
+# possible contents of BUILDABLE_EXAMPLES:
+EXTRA_PROGRAMS = player_example encoder_example png2theora
+
+AM_CFLAGS = $(OGG_CFLAGS)
+LDADD = ../lib/libtheora.la $(OGG_LIBS)
+LDADDDEC = ../lib/libtheoradec.la $(OGG_LIBS)
+LDADDENC = ../lib/libtheoraenc.la ../lib/libtheoradec.la $(OGG_LIBS)
+
+dump_video_SOURCES = dump_video.c
+dump_video_LDADD = $(GETOPT_OBJS) $(LDADDDEC)
+
+dump_psnr_SOURCES = dump_psnr.c
+dump_psnr_LDADD = $(GETOPT_OBJS) $(LDADDDEC) -lm
+
+player_example_SOURCES = player_example.c
+player_example_CFLAGS = $(SDL_CFLAGS) $(OGG_CFLAGS) $(VORBIS_CFLAGS)
+player_example_LDADD = $(LDADDDEC) $(SDL_LIBS) $(VORBIS_LIBS) $(OSS_LIBS)
+
+encoder_example_SOURCES = encoder_example.c
+encoder_example_CFLAGS = $(OGG_CFLAGS) $(VORBIS_CFLAGS)
+encoder_example_LDADD = $(GETOPT_OBJS) $(LDADDENC) $(VORBIS_LIBS) $(VORBISENC_LIBS) -lm
+
+png2theora_SOURCES = png2theora.c
+png2theora_CFLAGS = $(OGG_CFLAGS) $(PNG_CFLAGS)
+png2theora_LDADD = $(GETOPT_OBJS) $(LDADDENC) $(PNG_LIBS) -lm
+
+debug:
+       $(MAKE) all CFLAGS="@DEBUG@"
+
+profile:
+       $(MAKE) all CFLAGS="@PROFILE@"
+
diff --git a/examples/Makefile.in b/examples/Makefile.in
new file mode 100644 (file)
index 0000000..64e6741
--- /dev/null
@@ -0,0 +1,580 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+
+INCLUDES = -I$(top_srcdir)/include 
+
+noinst_PROGRAMS = dump_video dump_psnr $(BUILDABLE_EXAMPLES)
+
+# possible contents of BUILDABLE_EXAMPLES:
+EXTRA_PROGRAMS = player_example encoder_example png2theora
+
+AM_CFLAGS = $(OGG_CFLAGS)
+LDADD = ../lib/libtheora.la $(OGG_LIBS)
+LDADDDEC = ../lib/libtheoradec.la $(OGG_LIBS)
+LDADDENC = ../lib/libtheoraenc.la ../lib/libtheoradec.la $(OGG_LIBS)
+
+dump_video_SOURCES = dump_video.c
+EXTRA_dump_video_SOURCES = getopt.c getopt1.c getopt.h
+dump_video_LDADD = $(GETOPT_OBJS) $(LDADDDEC)
+
+dump_psnr_SOURCES = dump_psnr.c
+EXTRA_dump_psnr_SOURCES = getopt.c getopt1.c getopt.h
+dump_psnr_LDADD = $(GETOPT_OBJS) $(LDADDDEC) -lm
+
+player_example_SOURCES = player_example.c
+player_example_CFLAGS = $(SDL_CFLAGS) $(OGG_CFLAGS) $(VORBIS_CFLAGS)
+player_example_LDADD = $(LDADDDEC) $(SDL_LIBS) $(VORBIS_LIBS) $(OSS_LIBS)
+
+encoder_example_SOURCES = encoder_example.c
+EXTRA_encoder_example_SOURCES = getopt.c getopt1.c getopt.h
+encoder_example_CFLAGS = $(OGG_CFLAGS) $(VORBIS_CFLAGS)
+encoder_example_LDADD = $(GETOPT_OBJS) $(LDADDENC) $(VORBIS_LIBS) $(VORBISENC_LIBS) -lm
+
+png2theora_SOURCES = png2theora.c
+png2theora_CFLAGS = $(OGG_CFLAGS) $(PNG_CFLAGS)
+png2theora_LDADD = $(GETOPT_OBJS) $(LDADDENC) $(PNG_LIBS) -lm
+subdir = examples
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES =
+EXTRA_PROGRAMS = player_example$(EXEEXT) encoder_example$(EXEEXT) \
+       png2theora$(EXEEXT)
+noinst_PROGRAMS = dump_video$(EXEEXT) dump_psnr$(EXEEXT) \
+       @BUILDABLE_EXAMPLES@
+PROGRAMS = $(noinst_PROGRAMS)
+
+am_dump_psnr_OBJECTS = dump_psnr.$(OBJEXT)
+dump_psnr_OBJECTS = $(am_dump_psnr_OBJECTS)
+dump_psnr_DEPENDENCIES = ../lib/libtheoradec.la
+dump_psnr_LDFLAGS =
+am_dump_video_OBJECTS = dump_video.$(OBJEXT)
+dump_video_OBJECTS = $(am_dump_video_OBJECTS)
+dump_video_DEPENDENCIES = ../lib/libtheoradec.la
+dump_video_LDFLAGS =
+am_encoder_example_OBJECTS = encoder_example-encoder_example.$(OBJEXT)
+encoder_example_OBJECTS = $(am_encoder_example_OBJECTS)
+encoder_example_DEPENDENCIES = ../lib/libtheoraenc.la \
+       ../lib/libtheoradec.la
+encoder_example_LDFLAGS =
+am_player_example_OBJECTS = player_example-player_example.$(OBJEXT)
+player_example_OBJECTS = $(am_player_example_OBJECTS)
+player_example_DEPENDENCIES = ../lib/libtheoradec.la
+player_example_LDFLAGS =
+am_png2theora_OBJECTS = png2theora-png2theora.$(OBJEXT)
+png2theora_OBJECTS = $(am_png2theora_OBJECTS)
+png2theora_DEPENDENCIES = ../lib/libtheoraenc.la ../lib/libtheoradec.la
+png2theora_LDFLAGS =
+
+DEFS = @DEFS@
+DEFAULT_INCLUDES =  -I. -I$(srcdir) -I$(top_builddir)
+CPPFLAGS = @CPPFLAGS@
+LDFLAGS = @LDFLAGS@
+LIBS = @LIBS@
+depcomp = $(SHELL) $(top_srcdir)/depcomp
+am__depfiles_maybe = depfiles
+@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/dump_psnr.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/dump_video.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/encoder_example-encoder_example.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/encoder_example-getopt.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/encoder_example-getopt1.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/getopt.Po ./$(DEPDIR)/getopt1.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/player_example-player_example.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/png2theora-png2theora.Po
+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
+       $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) \
+       $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+CCLD = $(CC)
+LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+       $(AM_LDFLAGS) $(LDFLAGS) -o $@
+CFLAGS = @CFLAGS@
+DIST_SOURCES = $(dump_psnr_SOURCES) $(EXTRA_dump_psnr_SOURCES) \
+       $(dump_video_SOURCES) $(EXTRA_dump_video_SOURCES) \
+       $(encoder_example_SOURCES) $(EXTRA_encoder_example_SOURCES) \
+       $(player_example_SOURCES) $(png2theora_SOURCES)
+DIST_COMMON = Makefile.am Makefile.in
+SOURCES = $(dump_psnr_SOURCES) $(EXTRA_dump_psnr_SOURCES) $(dump_video_SOURCES) $(EXTRA_dump_video_SOURCES) $(encoder_example_SOURCES) $(EXTRA_encoder_example_SOURCES) $(player_example_SOURCES) $(png2theora_SOURCES)
+
+all: all-am
+
+.SUFFIXES:
+.SUFFIXES: .c .lo .o .obj
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  examples/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+
+clean-noinstPROGRAMS:
+       @list='$(noinst_PROGRAMS)'; for p in $$list; do \
+         f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \
+         echo " rm -f $$p $$f"; \
+         rm -f $$p $$f ; \
+       done
+dump_psnr$(EXEEXT): $(dump_psnr_OBJECTS) $(dump_psnr_DEPENDENCIES) 
+       @rm -f dump_psnr$(EXEEXT)
+       $(LINK) $(dump_psnr_LDFLAGS) $(dump_psnr_OBJECTS) $(dump_psnr_LDADD) $(LIBS)
+dump_video$(EXEEXT): $(dump_video_OBJECTS) $(dump_video_DEPENDENCIES) 
+       @rm -f dump_video$(EXEEXT)
+       $(LINK) $(dump_video_LDFLAGS) $(dump_video_OBJECTS) $(dump_video_LDADD) $(LIBS)
+encoder_example-encoder_example.$(OBJEXT): encoder_example.c
+encoder_example-getopt.$(OBJEXT): getopt.c
+encoder_example-getopt1.$(OBJEXT): getopt1.c
+encoder_example$(EXEEXT): $(encoder_example_OBJECTS) $(encoder_example_DEPENDENCIES) 
+       @rm -f encoder_example$(EXEEXT)
+       $(LINK) $(encoder_example_LDFLAGS) $(encoder_example_OBJECTS) $(encoder_example_LDADD) $(LIBS)
+player_example-player_example.$(OBJEXT): player_example.c
+player_example$(EXEEXT): $(player_example_OBJECTS) $(player_example_DEPENDENCIES) 
+       @rm -f player_example$(EXEEXT)
+       $(LINK) $(player_example_LDFLAGS) $(player_example_OBJECTS) $(player_example_LDADD) $(LIBS)
+png2theora-png2theora.$(OBJEXT): png2theora.c
+png2theora$(EXEEXT): $(png2theora_OBJECTS) $(png2theora_DEPENDENCIES) 
+       @rm -f png2theora$(EXEEXT)
+       $(LINK) $(png2theora_LDFLAGS) $(png2theora_OBJECTS) $(png2theora_LDADD) $(LIBS)
+
+mostlyclean-compile:
+       -rm -f *.$(OBJEXT) core *.core
+
+distclean-compile:
+       -rm -f *.tab.c
+
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dump_psnr.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dump_video.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encoder_example-encoder_example.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encoder_example-getopt.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encoder_example-getopt1.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/getopt.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/getopt1.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/player_example-player_example.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/png2theora-png2theora.Po@am__quote@
+
+distclean-depend:
+       -rm -rf ./$(DEPDIR)
+
+.c.o:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `test -f '$<' || echo '$(srcdir)/'`$<
+
+.c.obj:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `cygpath -w $<`
+
+.c.lo:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LTCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$<
+
+encoder_example-encoder_example.o: encoder_example.c
+@AMDEP_TRUE@   source='encoder_example.c' object='encoder_example-encoder_example.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-encoder_example.Po' tmpdepfile='$(DEPDIR)/encoder_example-encoder_example.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-encoder_example.o `test -f 'encoder_example.c' || echo '$(srcdir)/'`encoder_example.c
+
+encoder_example-encoder_example.obj: encoder_example.c
+@AMDEP_TRUE@   source='encoder_example.c' object='encoder_example-encoder_example.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-encoder_example.Po' tmpdepfile='$(DEPDIR)/encoder_example-encoder_example.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-encoder_example.obj `cygpath -w encoder_example.c`
+
+encoder_example-encoder_example.lo: encoder_example.c
+@AMDEP_TRUE@   source='encoder_example.c' object='encoder_example-encoder_example.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-encoder_example.Plo' tmpdepfile='$(DEPDIR)/encoder_example-encoder_example.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-encoder_example.lo `test -f 'encoder_example.c' || echo '$(srcdir)/'`encoder_example.c
+
+encoder_example-getopt.o: getopt.c
+@AMDEP_TRUE@   source='getopt.c' object='encoder_example-getopt.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-getopt.Po' tmpdepfile='$(DEPDIR)/encoder_example-getopt.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-getopt.o `test -f 'getopt.c' || echo '$(srcdir)/'`getopt.c
+
+encoder_example-getopt.obj: getopt.c
+@AMDEP_TRUE@   source='getopt.c' object='encoder_example-getopt.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-getopt.Po' tmpdepfile='$(DEPDIR)/encoder_example-getopt.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-getopt.obj `cygpath -w getopt.c`
+
+encoder_example-getopt.lo: getopt.c
+@AMDEP_TRUE@   source='getopt.c' object='encoder_example-getopt.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-getopt.Plo' tmpdepfile='$(DEPDIR)/encoder_example-getopt.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-getopt.lo `test -f 'getopt.c' || echo '$(srcdir)/'`getopt.c
+
+encoder_example-getopt1.o: getopt1.c
+@AMDEP_TRUE@   source='getopt1.c' object='encoder_example-getopt1.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-getopt1.Po' tmpdepfile='$(DEPDIR)/encoder_example-getopt1.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-getopt1.o `test -f 'getopt1.c' || echo '$(srcdir)/'`getopt1.c
+
+encoder_example-getopt1.obj: getopt1.c
+@AMDEP_TRUE@   source='getopt1.c' object='encoder_example-getopt1.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-getopt1.Po' tmpdepfile='$(DEPDIR)/encoder_example-getopt1.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-getopt1.obj `cygpath -w getopt1.c`
+
+encoder_example-getopt1.lo: getopt1.c
+@AMDEP_TRUE@   source='getopt1.c' object='encoder_example-getopt1.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/encoder_example-getopt1.Plo' tmpdepfile='$(DEPDIR)/encoder_example-getopt1.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(encoder_example_CFLAGS) $(CFLAGS) -c -o encoder_example-getopt1.lo `test -f 'getopt1.c' || echo '$(srcdir)/'`getopt1.c
+
+player_example-player_example.o: player_example.c
+@AMDEP_TRUE@   source='player_example.c' object='player_example-player_example.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/player_example-player_example.Po' tmpdepfile='$(DEPDIR)/player_example-player_example.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(player_example_CFLAGS) $(CFLAGS) -c -o player_example-player_example.o `test -f 'player_example.c' || echo '$(srcdir)/'`player_example.c
+
+player_example-player_example.obj: player_example.c
+@AMDEP_TRUE@   source='player_example.c' object='player_example-player_example.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/player_example-player_example.Po' tmpdepfile='$(DEPDIR)/player_example-player_example.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(player_example_CFLAGS) $(CFLAGS) -c -o player_example-player_example.obj `cygpath -w player_example.c`
+
+player_example-player_example.lo: player_example.c
+@AMDEP_TRUE@   source='player_example.c' object='player_example-player_example.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/player_example-player_example.Plo' tmpdepfile='$(DEPDIR)/player_example-player_example.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(player_example_CFLAGS) $(CFLAGS) -c -o player_example-player_example.lo `test -f 'player_example.c' || echo '$(srcdir)/'`player_example.c
+
+png2theora-png2theora.o: png2theora.c
+@AMDEP_TRUE@   source='png2theora.c' object='png2theora-png2theora.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/png2theora-png2theora.Po' tmpdepfile='$(DEPDIR)/png2theora-png2theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(png2theora_CFLAGS) $(CFLAGS) -c -o png2theora-png2theora.o `test -f 'png2theora.c' || echo '$(srcdir)/'`png2theora.c
+
+png2theora-png2theora.obj: png2theora.c
+@AMDEP_TRUE@   source='png2theora.c' object='png2theora-png2theora.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/png2theora-png2theora.Po' tmpdepfile='$(DEPDIR)/png2theora-png2theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(png2theora_CFLAGS) $(CFLAGS) -c -o png2theora-png2theora.obj `cygpath -w png2theora.c`
+
+png2theora-png2theora.lo: png2theora.c
+@AMDEP_TRUE@   source='png2theora.c' object='png2theora-png2theora.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/png2theora-png2theora.Plo' tmpdepfile='$(DEPDIR)/png2theora-png2theora.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(png2theora_CFLAGS) $(CFLAGS) -c -o png2theora-png2theora.lo `test -f 'png2theora.c' || echo '$(srcdir)/'`png2theora.c
+CCDEPMODE = @CCDEPMODE@
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+check-am: all-am
+check: check-am
+all-am: Makefile $(PROGRAMS)
+
+installdirs:
+
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-generic clean-libtool clean-noinstPROGRAMS \
+       mostlyclean-am
+
+distclean: distclean-am
+
+distclean-am: clean-am distclean-compile distclean-depend \
+       distclean-generic distclean-libtool distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+info: info-am
+
+info-am:
+
+install-data-am:
+
+install-exec-am:
+
+install-info: install-info-am
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-compile mostlyclean-generic \
+       mostlyclean-libtool
+
+uninstall-am: uninstall-info-am
+
+.PHONY: GTAGS all all-am check check-am clean clean-generic \
+       clean-libtool clean-noinstPROGRAMS distclean distclean-compile \
+       distclean-depend distclean-generic distclean-libtool \
+       distclean-tags distdir dvi dvi-am info info-am install \
+       install-am install-data install-data-am install-exec \
+       install-exec-am install-info install-info-am install-man \
+       install-strip installcheck installcheck-am installdirs \
+       maintainer-clean maintainer-clean-generic mostlyclean \
+       mostlyclean-compile mostlyclean-generic mostlyclean-libtool \
+       tags uninstall uninstall-am uninstall-info-am
+
+
+debug:
+       $(MAKE) all CFLAGS="@DEBUG@"
+
+profile:
+       $(MAKE) all CFLAGS="@PROFILE@"
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/examples/dump_psnr.c b/examples/dump_psnr.c
new file mode 100644 (file)
index 0000000..7340cad
--- /dev/null
@@ -0,0 +1,1201 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function: example dumpvid application; dumps  Theora streams
+  last mod: $Id: dump_video.c 15675 2009-02-06 09:43:27Z tterribe $
+
+ ********************************************************************/
+
+#if !defined(_GNU_SOURCE)
+#define _GNU_SOURCE
+#endif
+#if !defined(_LARGEFILE_SOURCE)
+#define _LARGEFILE_SOURCE
+#endif
+#if !defined(_LARGEFILE64_SOURCE)
+#define _LARGEFILE64_SOURCE
+#endif
+#if !defined(_FILE_OFFSET_BITS)
+#define _FILE_OFFSET_BITS 64
+#endif
+
+#include <stdio.h>
+#if !defined(_WIN32)
+#include <getopt.h>
+#include <unistd.h>
+#else
+#include "getopt.h"
+#endif
+#include <stdlib.h>
+#include <string.h>
+#include <sys/timeb.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+/*Yes, yes, we're going to hell.*/
+#if defined(_WIN32)
+#include <io.h>
+#endif
+#include <fcntl.h>
+#include <math.h>
+#include <signal.h>
+#include "theora/theoradec.h"
+
+const char *optstring = "fsy";
+struct option options [] = {
+  {"frame-type",no_argument,NULL,'f'},
+  {"summary",no_argument,NULL,'s'},
+  {"luma-only",no_argument,NULL,'y'},
+  {NULL,0,NULL,0}
+};
+
+static int show_frame_type;
+static int summary_only;
+static int luma_only;
+
+typedef struct y4m_input y4m_input;
+
+/*The function used to perform chroma conversion.*/
+typedef void (*y4m_convert_func)(y4m_input *_y4m,
+ unsigned char *_dst,unsigned char *_aux);
+
+struct y4m_input{
+  int               frame_w;
+  int               frame_h;
+  int               pic_w;
+  int               pic_h;
+  int               pic_x;
+  int               pic_y;
+  int               fps_n;
+  int               fps_d;
+  int               par_n;
+  int               par_d;
+  char              interlace;
+  int               src_c_dec_h;
+  int               src_c_dec_v;
+  int               dst_c_dec_h;
+  int               dst_c_dec_v;
+  char              chroma_type[16];
+  /*The size of each converted frame buffer.*/
+  size_t            dst_buf_sz;
+  /*The amount to read directly into the converted frame buffer.*/
+  size_t            dst_buf_read_sz;
+  /*The size of the auxilliary buffer.*/
+  size_t            aux_buf_sz;
+  /*The amount to read into the auxilliary buffer.*/
+  size_t            aux_buf_read_sz;
+  y4m_convert_func  convert;
+  unsigned char    *dst_buf;
+  unsigned char    *aux_buf;
+};
+
+
+static int y4m_parse_tags(y4m_input *_y4m,char *_tags){
+  int   got_w;
+  int   got_h;
+  int   got_fps;
+  int   got_interlace;
+  int   got_par;
+  int   got_chroma;
+  char *p;
+  char *q;
+  got_w=got_h=got_fps=got_interlace=got_par=got_chroma=0;
+  for(p=_tags;;p=q){
+    /*Skip any leading spaces.*/
+    while(*p==' ')p++;
+    /*If that's all we have, stop.*/
+    if(p[0]=='\0')break;
+    /*Find the end of this tag.*/
+    for(q=p+1;*q!='\0'&&*q!=' ';q++);
+    /*Process the tag.*/
+    switch(p[0]){
+      case 'W':{
+        if(sscanf(p+1,"%d",&_y4m->pic_w)!=1)return -1;
+        got_w=1;
+      }break;
+      case 'H':{
+        if(sscanf(p+1,"%d",&_y4m->pic_h)!=1)return -1;
+        got_h=1;
+      }break;
+      case 'F':{
+        if(sscanf(p+1,"%d:%d",&_y4m->fps_n,&_y4m->fps_d)!=2){
+          return -1;
+        }
+        got_fps=1;
+      }break;
+      case 'I':{
+        _y4m->interlace=p[1];
+        got_interlace=1;
+      }break;
+      case 'A':{
+        if(sscanf(p+1,"%d:%d",&_y4m->par_n,&_y4m->par_d)!=2){
+          return -1;
+        }
+        got_par=1;
+      }break;
+      case 'C':{
+        if(q-p>16)return -1;
+        memcpy(_y4m->chroma_type,p+1,q-p-1);
+        _y4m->chroma_type[q-p-1]='\0';
+        got_chroma=1;
+      }break;
+      /*Ignore unknown tags.*/
+    }
+  }
+  if(!got_w||!got_h||!got_fps||!got_interlace||!got_par)return -1;
+  /*Chroma-type is not specified in older files, e.g., those generated by
+     mplayer.*/
+  if(!got_chroma)strcpy(_y4m->chroma_type,"420");
+  return 0;
+}
+
+/*All anti-aliasing filters in the following conversion functions are based on
+   one of two window functions:
+  The 6-tap Lanczos window (for down-sampling and shifts):
+   sinc(\pi*t)*sinc(\pi*t/3), |t|<3  (sinc(t)==sin(t)/t)
+   0,                         |t|>=3
+  The 4-tap Mitchell window (for up-sampling):
+   7|t|^3-12|t|^2+16/3,             |t|<1
+   -(7/3)|x|^3+12|x|^2-20|x|+32/3,  |t|<2
+   0,                               |t|>=2
+  The number of taps is intentionally kept small to reduce computational
+   overhead and limit ringing.
+
+  The taps from these filters are scaled so that their sum is 1, and the result
+   is scaled by 128 and rounded to integers to create a filter whose
+   intermediate values fit inside 16 bits.
+  Coefficients are rounded in such a way as to ensure their sum is still 128,
+   which is usually equivalent to normal rounding.*/
+
+#define OC_MINI(_a,_b)      ((_a)>(_b)?(_b):(_a))
+#define OC_MAXI(_a,_b)      ((_a)<(_b)?(_b):(_a))
+#define OC_CLAMPI(_a,_b,_c) (OC_MAXI(_a,OC_MINI(_b,_c)))
+
+/*420jpeg chroma samples are sited like:
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  420mpeg2 chroma samples are sited like:
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  BR      |       BR      |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  BR      |       BR      |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  We use a resampling filter to shift the site locations one quarter pixel (at
+   the chroma plane's resolution) to the right.
+  The 4:2:2 modes look exactly the same, except there are twice as many chroma
+   lines, and they are vertically co-sited with the luma samples in both the
+   mpeg2 and jpeg cases (thus requiring no vertical resampling).*/
+static void y4m_convert_42xmpeg2_42xjpeg(y4m_input *_y4m,unsigned char *_dst,
+ unsigned char *_aux){
+  int c_w;
+  int c_h;
+  int pli;
+  int y;
+  int x;
+  /*Skip past the luma data.*/
+  _dst+=_y4m->pic_w*_y4m->pic_h;
+  /*Compute the size of each chroma plane.*/
+  c_w=(_y4m->pic_w+_y4m->dst_c_dec_h-1)/_y4m->dst_c_dec_h;
+  c_h=(_y4m->pic_h+_y4m->dst_c_dec_v-1)/_y4m->dst_c_dec_v;
+  for(pli=1;pli<3;pli++){
+    for(y=0;y<c_h;y++){
+      /*Filter: [4 -17 114 35 -9 1]/128, derived from a 6-tap Lanczos
+         window.*/
+      for(x=0;x<OC_MINI(c_w,2);x++){
+        _dst[x]=(unsigned char)OC_CLAMPI(0,4*_aux[0]-17*_aux[OC_MAXI(x-1,0)]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[OC_MINI(x+3,c_w-1)]+64>>7,255);
+      }
+      for(;x<c_w-3;x++){
+        _dst[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[x+1]-9*_aux[x+2]+_aux[x+3]+64>>7,255);
+      }
+      for(;x<c_w;x++){
+        _dst[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[c_w-1]+64>>7,255);
+      }
+      _dst+=c_w;
+      _aux+=c_w;
+    }
+  }
+}
+
+/*This format is only used for interlaced content, but is included for
+   completeness.
+
+  420jpeg chroma samples are sited like:
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  420paldv chroma samples are sited like:
+  YR------Y-------YR------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YB------Y-------YB------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YR------Y-------YR------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YB------Y-------YB------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  We use a resampling filter to shift the site locations one quarter pixel (at
+   the chroma plane's resolution) to the right.
+  Then we use another filter to move the C_r location down one quarter pixel,
+   and the C_b location up one quarter pixel.*/
+static void y4m_convert_42xpaldv_42xjpeg(y4m_input *_y4m,unsigned char *_dst,
+ unsigned char *_aux){
+  unsigned char *tmp;
+  int            c_w;
+  int            c_h;
+  int            c_sz;
+  int            pli;
+  int            y;
+  int            x;
+  /*Skip past the luma data.*/
+  _dst+=_y4m->pic_w*_y4m->pic_h;
+  /*Compute the size of each chroma plane.*/
+  c_w=(_y4m->pic_w+1)/2;
+  c_h=(_y4m->pic_h+_y4m->dst_c_dec_h-1)/_y4m->dst_c_dec_h;
+  c_sz=c_w*c_h;
+  /*First do the horizontal re-sampling.
+    This is the same as the mpeg2 case, except that after the horizontal case,
+     we need to apply a second vertical filter.*/
+  tmp=_aux+2*c_sz;
+  for(pli=1;pli<3;pli++){
+    for(y=0;y<c_h;y++){
+      /*Filter: [4 -17 114 35 -9 1]/128, derived from a 6-tap Lanczos
+         window.*/
+      for(x=0;x<OC_MINI(c_w,2);x++){
+        tmp[x]=(unsigned char)OC_CLAMPI(0,4*_aux[0]-17*_aux[OC_MAXI(x-1,0)]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[OC_MINI(x+3,c_w-1)]+64>>7,255);
+      }
+      for(;x<c_w-3;x++){
+        tmp[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[x+1]-9*_aux[x+2]+_aux[x+3]+64>>7,255);
+      }
+      for(;x<c_w;x++){
+        tmp[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[c_w-1]+64>>7,255);
+      }
+      tmp+=c_w;
+      _aux+=c_w;
+    }
+    switch(pli){
+      case 1:{
+        tmp-=c_sz;
+        /*Slide C_b up a quarter-pel.
+          This is the same filter used above, but in the other order.*/
+        for(x=0;x<c_w;x++){
+          for(y=0;y<OC_MINI(c_h,3);y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,tmp[0]-
+             9*tmp[OC_MAXI(y-2,0)*c_w]+35*tmp[OC_MAXI(y-1,0)*c_w]+
+             114*tmp[y*c_w]-17*tmp[OC_MINI(y+1,c_h-1)*c_w]+
+             4*tmp[OC_MINI(y+2,c_h-1)*c_w]+64>>7,255);
+          }
+          for(;y<c_h-2;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,tmp[(y-3)*c_w]-
+             9*tmp[(y-2)*c_w]+35*tmp[(y-1)*c_w]+114*tmp[y*c_w]-
+             17*tmp[(y+1)*c_w]+4*tmp[(y+2)*c_w]+64>>7,255);
+          }
+          for(;y<c_h;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,tmp[(y-3)*c_w]-
+             9*tmp[(y-2)*c_w]+35*tmp[(y-1)*c_w]+114*tmp[y*c_w]-
+             17*tmp[OC_MINI(y+1,c_h-1)*c_w]+4*tmp[(c_h-1)*c_w]+64>>7,255);
+          }
+          _dst++;
+          tmp++;
+        }
+        _dst+=c_sz-c_w;
+        tmp-=c_w;
+      }break;
+      case 2:{
+        tmp-=c_sz;
+        /*Slide C_r down a quarter-pel.
+          This is the same as the horizontal filter.*/
+        for(x=0;x<c_w;x++){
+          for(y=0;y<OC_MINI(c_h,2);y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,4*tmp[0]-
+             17*tmp[OC_MAXI(y-1,0)*c_w]+114*tmp[y*c_w]+
+             35*tmp[OC_MINI(y+1,c_h-1)*c_w]-9*tmp[OC_MINI(y+2,c_h-1)*c_w]+
+             tmp[OC_MINI(y+3,c_h-1)*c_w]+64>>7,255);
+          }
+          for(;y<c_h-3;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,4*tmp[(y-2)*c_w]-
+             17*tmp[(y-1)*c_w]+114*tmp[y*c_w]+35*tmp[(y+1)*c_w]-
+             9*tmp[(y+2)*c_w]+tmp[(y+3)*c_w]+64>>7,255);
+          }
+          for(;y<c_h;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,4*tmp[(y-2)*c_w]-
+             17*tmp[(y-1)*c_w]+114*tmp[y*c_w]+35*tmp[OC_MINI(y+1,c_h-1)*c_w]-
+             9*tmp[OC_MINI(y+2,c_h-1)*c_w]+tmp[(c_h-1)*c_w]+64>>7,255);
+          }
+          _dst++;
+          tmp++;
+        }
+      }break;
+    }
+    /*For actual interlaced material, this would have to be done separately on
+       each field, and the shift amounts would be different.
+      C_r moves down 1/8, C_b up 3/8 in the top field, and C_r moves down 3/8,
+       C_b up 1/8 in the bottom field.
+      The corresponding filters would be:
+       Down 1/8 (reverse order for up): [3 -11 125 15 -4 0]/128
+       Down 3/8 (reverse order for up): [4 -19 98 56 -13 2]/128*/
+  }
+}
+
+/*422jpeg chroma samples are sited like:
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  411 chroma samples are sited like:
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  We use a filter to resample at site locations one eighth pixel (at the source
+   chroma plane's horizontal resolution) and five eighths of a pixel to the
+   right.*/
+static void y4m_convert_411_422jpeg(y4m_input *_y4m,unsigned char *_dst,
+ unsigned char *_aux){
+  int c_w;
+  int dst_c_w;
+  int c_h;
+  int pli;
+  int y;
+  int x;
+  /*Skip past the luma data.*/
+  _dst+=_y4m->pic_w*_y4m->pic_h;
+  /*Compute the size of each chroma plane.*/
+  c_w=(_y4m->pic_w+_y4m->src_c_dec_h-1)/_y4m->src_c_dec_h;
+  dst_c_w=(_y4m->pic_w+_y4m->dst_c_dec_h-1)/_y4m->dst_c_dec_h;
+  c_h=(_y4m->pic_h+_y4m->dst_c_dec_v-1)/_y4m->dst_c_dec_v;
+  for(pli=1;pli<3;pli++){
+    for(y=0;y<c_h;y++){
+      /*Filters: [1 110 18 -1]/128 and [-3 50 86 -5]/128, both derived from a
+         4-tap Mitchell window.*/
+      for(x=0;x<OC_MINI(c_w,1);x++){
+        _dst[x<<1]=(unsigned char)OC_CLAMPI(0,111*_aux[0]+
+         18*_aux[OC_MINI(1,c_w-1)]-_aux[OC_MINI(2,c_w-1)]+64>>7,255);
+        _dst[x<<1|1]=(unsigned char)OC_CLAMPI(0,47*_aux[0]+
+         86*_aux[OC_MINI(1,c_w-1)]-5*_aux[OC_MINI(2,c_w-1)]+64>>7,255);
+      }
+      for(;x<c_w-2;x++){
+        _dst[x<<1]=(unsigned char)OC_CLAMPI(0,_aux[x-1]+110*_aux[x]+
+         18*_aux[x+1]-_aux[x+2]+64>>7,255);
+        _dst[x<<1|1]=(unsigned char)OC_CLAMPI(0,-3*_aux[x-1]+50*_aux[x]+
+         86*_aux[x+1]-5*_aux[x+2]+64>>7,255);
+      }
+      for(;x<c_w;x++){
+        _dst[x<<1]=(unsigned char)OC_CLAMPI(0,_aux[x-1]+110*_aux[x]+
+         18*_aux[OC_MINI(x+1,c_w-1)]-_aux[c_w-1]+64>>7,255);
+        if((x<<1|1)<dst_c_w){
+          _dst[x<<1|1]=(unsigned char)OC_CLAMPI(0,-3*_aux[x-1]+50*_aux[x]+
+           86*_aux[OC_MINI(x+1,c_w-1)]-5*_aux[c_w-1]+64>>7,255);
+        }
+      }
+      _dst+=dst_c_w;
+      _aux+=c_w;
+    }
+  }
+}
+
+/*The image is padded with empty chroma components at 4:2:0.
+  This costs about 17 bits a frame to code.*/
+static void y4m_convert_mono_420jpeg(y4m_input *_y4m,unsigned char *_dst,
+ unsigned char *_aux){
+  int c_sz;
+  _dst+=_y4m->pic_w*_y4m->pic_h;
+  c_sz=((_y4m->pic_w+_y4m->dst_c_dec_h-1)/_y4m->dst_c_dec_h)*
+   ((_y4m->pic_h+_y4m->dst_c_dec_v-1)/_y4m->dst_c_dec_v);
+  memset(_dst,128,c_sz*2);
+}
+
+#if 0
+/*Right now just 444 to 420.
+  Not too hard to generalize.*/
+static void y4m_convert_4xxjpeg_42xjpeg(y4m_input *_y4m,unsigned char *_dst,
+ unsigned char *_aux){
+  unsigned char *tmp;
+  int            c_w;
+  int            c_h;
+  int            pic_sz;
+  int            tmp_sz;
+  int            c_sz;
+  int            pli;
+  int            y;
+  int            x;
+  /*Compute the size of each chroma plane.*/
+  c_w=(_y4m->pic_w+_y4m->dst_c_dec_h-1)/_y4m->dst_c_dec_h;
+  c_h=(_y4m->pic_h+_y4m->dst_c_dec_v-1)/_y4m->dst_c_dec_v;
+  pic_sz=_y4m->pic_w*_y4m->pic_h;
+  tmp_sz=c_w*_y4m->pic_h;
+  c_sz=c_w*c_h;
+  _dst+=pic_sz;
+  for(pli=1;pli<3;pli++){
+    tmp=_aux+pic_sz;
+    /*In reality, the horizontal and vertical steps could be pipelined, for
+       less memory consumption and better cache performance, but we do them
+       separately for simplicity.*/
+    /*First do horizontal filtering (convert to 4:2:2)*/
+    /*Filter: [3 -17 78 78 -17 3]/128, derived from a 6-tap Lanczos window.*/
+    for(y=0;y<_y4m->pic_h;y++){
+      for(x=0;x<OC_MINI(_y4m->pic_w,2);x+=2){
+        tmp[x>>1]=OC_CLAMPI(0,64*_aux[0]+78*_aux[OC_MINI(1,_y4m->pic_w-1)]
+         -17*_aux[OC_MINI(2,_y4m->pic_w-1)]
+         +3*_aux[OC_MINI(3,_y4m->pic_w-1)]+64>>7,255);
+      }
+      for(;x<_y4m->pic_w-3;x+=2){
+        tmp[x>>1]=OC_CLAMPI(0,3*(_aux[x-2]+_aux[x+3])-17*(_aux[x-1]+_aux[x+2])+
+         78*(_aux[x]+_aux[x+1])+64>>7,255);
+      }
+      for(;x<_y4m->pic_w;x+=2){
+        tmp[x>>1]=OC_CLAMPI(0,3*(_aux[x-2]+_aux[_y4m->pic_w-1])-
+         17*(_aux[x-1]+_aux[OC_MINI(x+2,_y4m->pic_w-1)])+
+         78*(_aux[x]+_aux[OC_MINI(x+1,_y4m->pic_w-1)])+64>>7,255);
+      }
+      tmp+=c_w;
+      _aux+=_y4m->pic_w;
+    }
+    _aux-=pic_sz;
+    tmp-=tmp_sz;
+    /*Now do the vertical filtering.*/
+    for(x=0;x<c_w;x++){
+      for(y=0;y<OC_MINI(_y4m->pic_h,2);y+=2){
+        _dst[(y>>1)*c_w]=OC_CLAMPI(0,64*tmp[0]
+         +78*tmp[OC_MINI(1,_y4m->pic_h-1)*c_w]
+         -17*tmp[OC_MINI(2,_y4m->pic_h-1)*c_w]
+         +3*tmp[OC_MINI(3,_y4m->pic_h-1)*c_w]+64>>7,255);
+      }
+      for(;y<_y4m->pic_h-3;y+=2){
+        _dst[(y>>1)*c_w]=OC_CLAMPI(0,3*(tmp[(y-2)*c_w]+tmp[(y+3)*c_w])-
+         17*(tmp[(y-1)*c_w]+tmp[(y+2)*c_w])+78*(tmp[y*c_w]+tmp[(y+1)*c_w])+
+         64>>7,255);
+      }
+      for(;y<_y4m->pic_h;y+=2){
+        _dst[(y>>1)*c_w]=OC_CLAMPI(0,3*(tmp[(y-2)*c_w]
+         +tmp[(_y4m->pic_h-1)*c_w])-17*(tmp[(y-1)*c_w]
+         +tmp[OC_MINI(y+2,_y4m->pic_h-1)*c_w])
+         +78*(tmp[y*c_w]+tmp[OC_MINI(y+1,_y4m->pic_h-1)*c_w])+64>>7,255);
+      }
+      tmp++;
+      _dst++;
+    }
+    _dst-=c_w;
+  }
+}
+#endif
+
+/*No conversion function needed.*/
+static void y4m_convert_null(y4m_input *_y4m,unsigned char *_dst,
+ unsigned char *_aux){
+}
+
+static int y4m_input_open(y4m_input *_y4m,FILE *_fin,char *_skip,int _nskip){
+  char buffer[80];
+  int  ret;
+  int  i;
+  /*Read until newline, or 80 cols, whichever happens first.*/
+  for(i=0;i<79;i++){
+    if(_nskip>0){
+      buffer[i]=*_skip++;
+      _nskip--;
+    }
+    else{
+      ret=fread(buffer+i,1,1,_fin);
+      if(ret<1)return -1;
+    }
+    if(buffer[i]=='\n')break;
+  }
+  /*We skipped too much header data.*/
+  if(_nskip>0)return -1;
+  if(i==79){
+    fprintf(stderr,"Error parsing header; not a YUV2MPEG2 file?\n");
+    return -1;
+  }
+  buffer[i]='\0';
+  if(memcmp(buffer,"YUV4MPEG",8)){
+    fprintf(stderr,"Incomplete magic for YUV4MPEG file.\n");
+    return -1;
+  }
+  if(buffer[8]!='2'){
+    fprintf(stderr,"Incorrect YUV input file version; YUV4MPEG2 required.\n");
+  }
+  ret=y4m_parse_tags(_y4m,buffer+5);
+  if(ret<0){
+    fprintf(stderr,"Error parsing YUV4MPEG2 header.\n");
+    return ret;
+  }
+  if(_y4m->interlace!='p'){
+    fprintf(stderr,"Input video is interlaced; "
+     "Theora only handles progressive scan.\n");
+    return -1;
+  }
+  if(strcmp(_y4m->chroma_type,"420")==0||
+   strcmp(_y4m->chroma_type,"420jpeg")==0){
+    _y4m->src_c_dec_h=_y4m->dst_c_dec_h=_y4m->src_c_dec_v=_y4m->dst_c_dec_v=2;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h
+     +2*((_y4m->pic_w+1)/2)*((_y4m->pic_h+1)/2);
+    /*Natively supported: no conversion required.*/
+    _y4m->aux_buf_sz=_y4m->aux_buf_read_sz=0;
+    _y4m->convert=y4m_convert_null;
+  }
+  else if(strcmp(_y4m->chroma_type,"420mpeg2")==0){
+    _y4m->src_c_dec_h=_y4m->dst_c_dec_h=_y4m->src_c_dec_v=_y4m->dst_c_dec_v=2;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h;
+    /*Chroma filter required: read into the aux buf first.*/
+    _y4m->aux_buf_sz=_y4m->aux_buf_read_sz=
+     2*((_y4m->pic_w+1)/2)*((_y4m->pic_h+1)/2);
+    _y4m->convert=y4m_convert_42xmpeg2_42xjpeg;
+  }
+  else if(strcmp(_y4m->chroma_type,"420paldv")==0){
+    _y4m->src_c_dec_h=_y4m->dst_c_dec_h=_y4m->src_c_dec_v=_y4m->dst_c_dec_v=2;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h;
+    /*Chroma filter required: read into the aux buf first.
+      We need to make two filter passes, so we need some extra space in the
+       aux buffer.*/
+    _y4m->aux_buf_sz=3*((_y4m->pic_w+1)/2)*((_y4m->pic_h+1)/2);
+    _y4m->aux_buf_read_sz=2*((_y4m->pic_w+1)/2)*((_y4m->pic_h+1)/2);
+    _y4m->convert=y4m_convert_42xpaldv_42xjpeg;
+  }
+  else if(strcmp(_y4m->chroma_type,"422")==0){
+    _y4m->src_c_dec_h=_y4m->dst_c_dec_h=2;
+    _y4m->src_c_dec_v=_y4m->dst_c_dec_v=1;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h;
+    /*Chroma filter required: read into the aux buf first.*/
+    _y4m->aux_buf_sz=_y4m->aux_buf_read_sz=2*((_y4m->pic_w+1)/2)*_y4m->pic_h;
+    _y4m->convert=y4m_convert_42xmpeg2_42xjpeg;
+  }
+  else if(strcmp(_y4m->chroma_type,"411")==0){
+    _y4m->src_c_dec_h=4;
+    /*We don't want to introduce any additional sub-sampling, so we
+       promote 4:1:1 material to 4:2:2, as the closest format Theora can
+       handle.*/
+    _y4m->dst_c_dec_h=2;
+    _y4m->src_c_dec_v=_y4m->dst_c_dec_v=1;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h;
+    /*Chroma filter required: read into the aux buf first.*/
+    _y4m->aux_buf_sz=_y4m->aux_buf_read_sz=2*((_y4m->pic_w+3)/4)*_y4m->pic_h;
+    _y4m->convert=y4m_convert_411_422jpeg;
+  }
+  else if(strcmp(_y4m->chroma_type,"444")==0){
+    _y4m->src_c_dec_h=_y4m->dst_c_dec_h=_y4m->src_c_dec_v=_y4m->dst_c_dec_v=1;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h*3;
+    /*Natively supported: no conversion required.*/
+    _y4m->aux_buf_sz=_y4m->aux_buf_read_sz=0;
+    _y4m->convert=y4m_convert_null;
+  }
+  else if(strcmp(_y4m->chroma_type,"444alpha")==0){
+    _y4m->src_c_dec_h=_y4m->dst_c_dec_h=_y4m->src_c_dec_v=_y4m->dst_c_dec_v=1;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h*3;
+    /*Read the extra alpha plane into the aux buf.
+      It will be discarded.*/
+    _y4m->aux_buf_sz=_y4m->aux_buf_read_sz=_y4m->pic_w*_y4m->pic_h;
+    _y4m->convert=y4m_convert_null;
+  }
+  else if(strcmp(_y4m->chroma_type,"mono")==0){
+    _y4m->src_c_dec_h=_y4m->src_c_dec_v=0;
+    _y4m->dst_c_dec_h=_y4m->dst_c_dec_v=2;
+    _y4m->dst_buf_read_sz=_y4m->pic_w*_y4m->pic_h;
+    /*No extra space required, but we need to clear the chroma planes.*/
+    _y4m->aux_buf_sz=_y4m->aux_buf_read_sz=0;
+    _y4m->convert=y4m_convert_mono_420jpeg;
+  }
+  else{
+    fprintf(stderr,"Unknown chroma sampling type: %s\n",_y4m->chroma_type);
+    return -1;
+  }
+  /*The size of the final frame buffers is always computed from the
+     destination chroma decimation type.*/
+  _y4m->dst_buf_sz=_y4m->pic_w*_y4m->pic_h
+   +2*((_y4m->pic_w+_y4m->dst_c_dec_h-1)/_y4m->dst_c_dec_h)*
+   ((_y4m->pic_h+_y4m->dst_c_dec_v-1)/_y4m->dst_c_dec_v);
+  /*Scale the picture size up to a multiple of 16.*/
+  _y4m->frame_w=_y4m->pic_w+15&~0xF;
+  _y4m->frame_h=_y4m->pic_h+15&~0xF;
+  /*Force the offsets to be even so that chroma samples line up like we
+     expect.*/
+  _y4m->pic_x=_y4m->frame_w-_y4m->pic_w>>1&~1;
+  _y4m->pic_y=_y4m->frame_h-_y4m->pic_h>>1&~1;
+  _y4m->dst_buf=(unsigned char *)malloc(_y4m->dst_buf_sz);
+  _y4m->aux_buf=(unsigned char *)malloc(_y4m->aux_buf_sz);
+  return 0;
+}
+
+static void y4m_input_get_info(y4m_input *_y4m,th_info *_ti){
+  _ti->frame_width=_y4m->frame_w;
+  _ti->frame_height=_y4m->frame_h;
+  _ti->pic_width=_y4m->pic_w;
+  _ti->pic_height=_y4m->pic_h;
+  _ti->pic_x=_y4m->pic_x;
+  _ti->pic_y=_y4m->pic_y;
+  _ti->fps_numerator=_y4m->fps_n;
+  _ti->fps_denominator=_y4m->fps_d;
+  _ti->aspect_numerator=_y4m->par_n;
+  _ti->aspect_denominator=_y4m->par_d;
+  _ti->pixel_fmt=_y4m->dst_c_dec_h==2?
+   (_y4m->dst_c_dec_v==2?TH_PF_420:TH_PF_422):TH_PF_444;
+}
+
+static int y4m_input_fetch_frame(y4m_input *_y4m,FILE *_fin,
+ th_ycbcr_buffer _ycbcr){
+  char frame[6];
+  int  pic_sz;
+  int  frame_c_w;
+  int  frame_c_h;
+  int  c_w;
+  int  c_h;
+  int  c_sz;
+  int  ret;
+  pic_sz=_y4m->pic_w*_y4m->pic_h;
+  frame_c_w=_y4m->frame_w/_y4m->dst_c_dec_h;
+  frame_c_h=_y4m->frame_h/_y4m->dst_c_dec_v;
+  c_w=(_y4m->pic_w+_y4m->dst_c_dec_h-1)/_y4m->dst_c_dec_h;
+  c_h=(_y4m->pic_h+_y4m->dst_c_dec_v-1)/_y4m->dst_c_dec_v;
+  c_sz=c_w*c_h;
+  /*Read and skip the frame header.*/
+  ret=fread(frame,1,6,_fin);
+  if(ret<6)return 0;
+  if(memcmp(frame,"FRAME",5)){
+    fprintf(stderr,"Loss of framing in YUV input data\n");
+    exit(1);
+  }
+  if(frame[5]!='\n'){
+    char c;
+    int  j;
+    for(j=0;j<79&&fread(&c,1,1,_fin)&&c!='\n';j++);
+    if(j==79){
+      fprintf(stderr,"Error parsing YUV frame header\n");
+      return -1;
+    }
+  }
+  /*Read the frame data that needs no conversion.*/
+  if(fread(_y4m->dst_buf,1,_y4m->dst_buf_read_sz,_fin)!=_y4m->dst_buf_read_sz){
+    fprintf(stderr,"Error reading YUV frame data.\n");
+    return -1;
+  }
+  /*Read the frame data that does need conversion.*/
+  if(fread(_y4m->aux_buf,1,_y4m->aux_buf_read_sz,_fin)!=_y4m->aux_buf_read_sz){
+    fprintf(stderr,"Error reading YUV frame data.\n");
+    return -1;
+  }
+  /*Now convert the just read frame.*/
+  (*_y4m->convert)(_y4m,_y4m->dst_buf,_y4m->aux_buf);
+  /*Fill in the frame buffer pointers.*/
+  _ycbcr[0].width=_y4m->frame_w;
+  _ycbcr[0].height=_y4m->frame_h;
+  _ycbcr[0].stride=_y4m->pic_w;
+  _ycbcr[0].data=_y4m->dst_buf-_y4m->pic_x-_y4m->pic_y*_y4m->pic_w;
+  _ycbcr[1].width=frame_c_w;
+  _ycbcr[1].height=frame_c_h;
+  _ycbcr[1].stride=c_w;
+  _ycbcr[1].data=_y4m->dst_buf+pic_sz-(_y4m->pic_x/_y4m->dst_c_dec_h)-
+   (_y4m->pic_y/_y4m->dst_c_dec_v)*c_w;
+  _ycbcr[2].width=frame_c_w;
+  _ycbcr[2].height=frame_c_h;
+  _ycbcr[2].stride=c_w;
+  _ycbcr[2].data=_ycbcr[1].data+c_sz;
+  return 1;
+}
+
+static void y4m_input_close(y4m_input *_y4m){
+  free(_y4m->dst_buf);
+  free(_y4m->aux_buf);
+}
+
+
+
+typedef struct th_input th_input;
+
+struct th_input{
+  ogg_sync_state    oy;
+  int               theora_p;
+  ogg_stream_state  to;
+  th_info           ti;
+  th_comment        tc;
+  th_dec_ctx       *td;
+};
+
+
+
+/*Grab some more compressed bitstream and sync it for page extraction.*/
+static int th_input_buffer_data(th_input *_th,FILE *_fin){
+  char *buffer;
+  int bytes;
+  buffer=ogg_sync_buffer(&_th->oy,4096);
+  bytes=fread(buffer,1,4096,_fin);
+  ogg_sync_wrote(&_th->oy,bytes);
+  return bytes;
+}
+
+/*Push a page into the appropriate steam.
+  This can be done blindly; a stream won't accept a page that doesn't belong to
+   it.*/
+static void th_input_queue_page(th_input *_th,ogg_page *_og){
+  if(_th->theora_p)ogg_stream_pagein(&_th->to,_og);
+}
+
+static int th_input_open_impl(th_input *_th,th_setup_info **_ts,FILE *_fin,
+ char *_sig,int _nsig){
+  ogg_packet op;
+  ogg_page   og;
+  int        nheaders_left;
+  int        done_headers;
+  ogg_sync_init(&_th->oy);
+  th_info_init(&_th->ti);
+  th_comment_init(&_th->tc);
+  *_ts=NULL;
+  /*Buffer any initial data read for file ID.*/
+  if(_nsig>0){
+    char *buffer;
+    buffer=ogg_sync_buffer(&_th->oy,_nsig);
+    memcpy(buffer,_sig,_nsig);
+    ogg_sync_wrote(&_th->oy,_nsig);
+  }
+  _th->theora_p=0;
+  nheaders_left=0;
+  for(done_headers=0;!done_headers;){
+    if(th_input_buffer_data(_th,_fin)==0)break;
+    while(ogg_sync_pageout(&_th->oy,&og)>0){
+      ogg_stream_state test;
+      /*Is this a mandated initial header?
+        If not, stop parsing.*/
+      if(!ogg_page_bos(&og)){
+        /*Don't leak the page; get it into the appropriate stream.*/
+        th_input_queue_page(_th,&og);
+        done_headers=1;
+        break;
+      }
+      ogg_stream_init(&test,ogg_page_serialno(&og));
+      ogg_stream_pagein(&test,&og);
+      ogg_stream_packetpeek(&test,&op);
+      /*Identify the codec: try Theora.*/
+      if(!_th->theora_p){
+        nheaders_left=th_decode_headerin(&_th->ti,&_th->tc,_ts,&op);
+        if(nheaders_left>=0){
+          /*It is Theora.*/
+          memcpy(&_th->to,&test,sizeof(test));
+          _th->theora_p=1;
+          /*Advance past the successfully processed header.*/
+          if(nheaders_left>0)ogg_stream_packetout(&_th->to,NULL);
+          continue;
+        }
+      }
+      /*Whatever it is, we don't care about it.*/
+      ogg_stream_clear(&test);
+    }
+  }
+  /*We're expecting more header packets.*/
+  while(_th->theora_p&&nheaders_left>0){
+    int ret;
+    while(nheaders_left>0){
+      ret=ogg_stream_packetpeek(&_th->to,&op);
+      if(ret==0)break;
+      if(ret<0)continue;
+      nheaders_left=th_decode_headerin(&_th->ti,&_th->tc,_ts,&op);
+      if(nheaders_left<0){
+        fprintf(stderr,"Error parsing Theora stream headers; "
+         "corrupt stream?\n");
+        return -1;
+      }
+      /*Advance past the successfully processed header.*/
+      else if(nheaders_left>0)ogg_stream_packetout(&_th->to,NULL);
+      _th->theora_p++;
+    }
+    /*Stop now so we don't fail if there aren't enough pages in a short
+       stream.*/
+    if(!(_th->theora_p&&nheaders_left>0))break;
+    /*The header pages/packets will arrive before anything else we care
+       about, or the stream is not obeying spec.*/
+    if(ogg_sync_pageout(&_th->oy,&og)>0)th_input_queue_page(_th,&og);
+    /*We need more data.*/
+    else if(th_input_buffer_data(_th,_fin)==0){
+      fprintf(stderr,"End of file while searching for codec headers.\n");
+      return -1;
+    }
+  }
+  /*And now we have it all.
+    Initialize the decoder.*/
+  if(_th->theora_p){
+    _th->td=th_decode_alloc(&_th->ti,*_ts);
+    if(_th->td!=NULL){
+      fprintf(stderr,"Ogg logical stream %lx is Theora %ix%i %.02f fps video.\n"
+       "Encoded frame content is %ix%i with %ix%i offset.\n",
+       _th->to.serialno,_th->ti.frame_width,_th->ti.frame_height,
+       (double)_th->ti.fps_numerator/_th->ti.fps_denominator,
+       _th->ti.pic_width,_th->ti.pic_height,_th->ti.pic_x,_th->ti.pic_y);
+      return 1;
+    }
+  }
+  return -1;
+}
+
+static void th_input_close(th_input *_th){
+  if(_th->theora_p){
+    ogg_stream_clear(&_th->to);
+    th_decode_free(_th->td);
+  }
+  th_comment_clear(&_th->tc);
+  th_info_clear(&_th->ti);
+  ogg_sync_clear(&_th->oy);
+}
+
+static int th_input_open(th_input *_th,FILE *_fin,char *_sig,int _nsig){
+  th_input       th;
+  th_setup_info *ts;
+  int            ret;
+  ret=th_input_open_impl(&th,&ts,_fin,_sig,_nsig);
+  th_setup_free(ts);
+  /*Clean up on failure.*/
+  if(ret<0)th_input_close(&th);
+  else memcpy(_th,&th,sizeof(th));
+  return ret;
+}
+
+static void th_input_get_info(th_input *_th,th_info *_ti){
+  memcpy(_ti,&_th->ti,sizeof(*_ti));
+}
+
+static int th_input_fetch_frame(th_input *_th,FILE *_fin,
+ th_ycbcr_buffer _ycbcr){
+  for(;;){
+    ogg_page   og;
+    ogg_packet op;
+    if(ogg_stream_packetout(&_th->to,&op)>0){
+      if(th_decode_packetin(_th->td,&op,NULL)>=0){
+        th_decode_ycbcr_out(_th->td,_ycbcr);
+        if(!summary_only&&show_frame_type){
+          printf("%c",th_packet_iskeyframe(&op)?'K':'D');
+          if(op.bytes>0)printf("%02i ",op.packet[0]&0x3F);
+          else printf("-- ");
+        }
+        return 1;
+      }
+      else return -1;
+    }
+    while(ogg_sync_pageout(&_th->oy,&og)<=0){
+      if(th_input_buffer_data(_th,_fin)==0)return feof(_fin)?0:-1;
+    }
+    th_input_queue_page(_th,&og);
+  }
+}
+
+
+
+typedef struct video_input video_input;
+typedef void (*video_input_get_info_func)(void *_ctx,th_info *_ti);
+typedef int (*video_input_fetch_frame_func)(void *_ctx,FILE *_fin,
+ th_ycbcr_buffer _ycbcr);
+typedef void (*video_input_close_func)(void *_ctx);
+
+struct video_input{
+  FILE                         *fin;
+  video_input_get_info_func     get_info;
+  video_input_fetch_frame_func  fetch_frame;
+  video_input_close_func        close;
+  union{
+    y4m_input y4m;
+    th_input  th;
+  }ctx;
+};
+
+static int video_input_open(video_input *_vid,FILE *_fin){
+  char buffer[4];
+  int  ret;
+  /* look for magic */
+  ret=fread(buffer,1,4,_fin);
+  if(ret<4)fprintf(stderr,"EOF determining file type of file.\n");
+  else{
+    if(!memcmp(buffer,"YUV4",4)){
+      if(y4m_input_open(&_vid->ctx.y4m,_fin,buffer,4)>=0){
+        /*fprintf(stderr,"Original %s is %dx%d %.02f fps %s video.\n",
+         f,_y4m->pic_w,_y4m->pic_h,(double)_y4m->fps_n/_y4m->fps_d,_y4m->chroma_type);*/
+        _vid->fin=_fin;
+        _vid->get_info=(video_input_get_info_func)y4m_input_get_info;
+        _vid->fetch_frame=(video_input_fetch_frame_func)y4m_input_fetch_frame;
+        _vid->close=(video_input_close_func)y4m_input_close;
+        return 0;
+      }
+    }
+    else if(!memcmp(buffer,"OggS",4)){
+      if(th_input_open(&_vid->ctx.th,_fin,buffer,4)>=0){
+        _vid->fin=_fin;
+        _vid->get_info=(video_input_get_info_func)th_input_get_info;
+        _vid->fetch_frame=(video_input_fetch_frame_func)th_input_fetch_frame;
+        _vid->close=(video_input_close_func)th_input_close;
+        return 0;
+      }
+    }
+    else fprintf(stderr,"Unknown file type.\n");
+  }
+  return -1;
+}
+
+static void video_input_get_info(video_input *_vid,th_info *_ti){
+  (*_vid->get_info)(&_vid->ctx,_ti);
+}
+
+static int video_input_fetch_frame(video_input *_vid,th_ycbcr_buffer _ycbcr){
+  return (*_vid->fetch_frame)(&_vid->ctx,_vid->fin,_ycbcr);
+}
+
+static void video_input_close(video_input *_vid){
+  (*_vid->close)(&_vid->ctx);
+  fclose(_vid->fin);
+}
+
+
+
+static void usage(char *_argv[]){
+  fprintf(stderr,"Usage: %s [options] <video1> <video2>\n"
+   "    <video1> and <video1> may be either YUV4MPEG or Ogg Theora files.\n\n"
+   "    Options:\n\n"
+   "      -f --frame-type Show frame type and QI value for each Theora frame.\n"
+   "      -s --summary    Only output the summary line.\n"
+   "      -y --luma-only  Only output values for the luma channel.\n",_argv[0]);
+}
+
+int main(int _argc,char *_argv[]){
+  video_input  vid1;
+  th_info      ti1;
+  video_input  vid2;
+  th_info      ti2;
+  ogg_int64_t  gsqerr;
+  ogg_int64_t  gnpixels;
+  ogg_int64_t  gplsqerr[3];
+  ogg_int64_t  gplnpixels[3];
+  int          frameno;
+  FILE        *fin;
+  int          long_option_index;
+  int          c;
+#ifdef _WIN32
+  /*We need to set stdin/stdout to binary mode on windows.
+    Beware the evil ifdef.
+    We avoid these where we can, but this one we cannot.
+    Don't add any more, you'll probably go to hell if you do.*/
+  _setmode(_fileno(stdin),_O_BINARY);
+#endif
+  /*Process option arguments.*/
+  while((c=getopt_long(_argc,_argv,optstring,options,&long_option_index))!=EOF){
+    switch(c){
+      case 'f':show_frame_type=1;break;
+      case 's':summary_only=1;break;
+      case 'y':luma_only=1;break;
+      default:usage(_argv);break;
+    }
+  }
+  if(optind+2!=_argc){
+    usage(_argv);
+    exit(1);
+  }
+  fin=strcmp(_argv[optind],"-")==0?stdin:fopen(_argv[optind],"rb");
+  if(fin==NULL){
+    fprintf(stderr,"Unable to open '%s' for extraction.\n",_argv[optind]);
+    exit(1);
+  }
+  fprintf(stderr,"Opening %s...\n",_argv[optind]);
+  if(video_input_open(&vid1,fin)<0)exit(1);
+  video_input_get_info(&vid1,&ti1);
+  fin=strcmp(_argv[optind+1],"-")==0?stdin:fopen(_argv[optind+1],"rb");
+  if(fin==NULL){
+    fprintf(stderr,"Unable to open '%s' for extraction.\n",_argv[optind+1]);
+    exit(1);
+  }
+  fprintf(stderr,"Opening %s...\n",_argv[optind+1]);
+  if(video_input_open(&vid2,fin)<0)exit(1);
+  video_input_get_info(&vid2,&ti2);
+  /*Check to make sure these videos are compatible.*/
+  if(ti1.pic_width!=ti2.pic_width||ti1.pic_height!=ti2.pic_height){
+    fprintf(stderr,"Video resolution does not match.\n");
+    exit(1);
+  }
+  if(ti1.pixel_fmt!=ti2.pixel_fmt){
+    fprintf(stderr,"Pixel formats do not match.\n");
+    exit(1);
+  }
+  if((ti1.pic_x&!(ti1.pixel_fmt&1))!=(ti2.pic_x&!(ti2.pixel_fmt&1))||
+   (ti1.pic_y&!(ti1.pixel_fmt&2))!=(ti2.pic_y&!(ti2.pixel_fmt&2))){
+    fprintf(stderr,"Chroma subsampling offsets do not match.\n");
+    exit(1);
+  }
+  if(ti1.fps_numerator*(ogg_int64_t)ti2.fps_denominator!=
+   ti2.fps_numerator*(ogg_int64_t)ti1.fps_denominator){
+    fprintf(stderr,"Warning: framerates do not match.\n");
+  }
+  if(ti1.aspect_numerator*(ogg_int64_t)ti2.aspect_denominator!=
+   ti2.aspect_numerator*(ogg_int64_t)ti1.aspect_denominator){
+    fprintf(stderr,"Warning: aspect ratios do not match.\n");
+  }
+  gsqerr=gplsqerr[0]=gplsqerr[1]=gplsqerr[2]=0;
+  gnpixels=gplnpixels[0]=gplnpixels[1]=gplnpixels[2]=0;
+  for(frameno=0;;frameno++){
+    th_ycbcr_buffer f1;
+    th_ycbcr_buffer f2;
+    ogg_int64_t     plsqerr[3];
+    long            plnpixels[3];
+    ogg_int64_t     sqerr;
+    long            npixels;
+    int             ret1;
+    int             ret2;
+    int             pli;
+    ret1=video_input_fetch_frame(&vid1,f1);
+    ret2=video_input_fetch_frame(&vid2,f2);
+    if(ret1==0&&ret2==0)break;
+    else if(ret1<0||ret2<0)break;
+    else if(ret1==0){
+      fprintf(stderr,"%s ended before %s.\n",
+       _argv[optind],_argv[optind+1]);
+      break;
+    }
+    else if(ret2==0){
+      fprintf(stderr,"%s ended before %s.\n",
+       _argv[optind+1],_argv[optind]);
+      break;
+    }
+    /*Okay, we got one frame from each.*/
+    sqerr=0;
+    npixels=0;
+    for(pli=0;pli<3;pli++){
+      int xdec;
+      int ydec;
+      int y1;
+      int y2;
+      xdec=pli&&!(ti1.pixel_fmt&1);
+      ydec=pli&&!(ti1.pixel_fmt&2);
+      plsqerr[pli]=0;
+      plnpixels[pli]=0;
+      for(y1=ti1.pic_y>>ydec,y2=ti2.pic_y>>ydec;
+       y1<ti1.pic_y+ti1.pic_height+ydec>>ydec;y1++,y2++){
+        int x1;
+        int x2;
+        for(x1=ti1.pic_x>>xdec,x2=ti2.pic_x>>xdec;
+         x1<ti1.pic_x+ti1.pic_width+xdec>>xdec;x1++,x2++){
+          int d;
+          d=*(f1[pli].data+y1*f1[pli].stride+x1)-
+           *(f2[pli].data+y2*f2[pli].stride+x2);
+          plsqerr[pli]+=d*d;
+          plnpixels[pli]++;
+        }
+      }
+      sqerr+=plsqerr[pli];
+      gplsqerr[pli]+=plsqerr[pli];
+      npixels+=plnpixels[pli];
+      gplnpixels[pli]+=plnpixels[pli];
+    }
+    if(!summary_only){
+      if(!luma_only){
+        printf("%08i: %-7lG  (Y': %-7lG  Cb: %-7lG  Cr: %-7lG)\n",frameno,
+         10*(log10(255*255)+log10(npixels)-log10(sqerr)),
+         10*(log10(255*255)+log10(plnpixels[0])-log10(plsqerr[0])),
+         10*(log10(255*255)+log10(plnpixels[1])-log10(plsqerr[1])),
+         10*(log10(255*255)+log10(plnpixels[2])-log10(plsqerr[2])));
+      }
+      else{
+        printf("%08i: %-7lG\n",frameno,
+         10*(log10(255*255)+log10(plnpixels[0])-log10(plsqerr[0])));
+      }
+    }
+    gsqerr+=sqerr;
+    gnpixels+=npixels;
+  }
+  if(!luma_only){
+    printf("Total: %-7lG  (Y': %-7lG  Cb: %-7lG  Cr: %-7lG)\n",
+     10*(log10(255*255)+log10(gnpixels)-log10(gsqerr)),
+     10*(log10(255*255)+log10(gplnpixels[0])-log10(gplsqerr[0])),
+     10*(log10(255*255)+log10(gplnpixels[1])-log10(gplsqerr[1])),
+     10*(log10(255*255)+log10(gplnpixels[2])-log10(gplsqerr[2])));
+  }
+  else{
+    printf("Total: %-7lG\n",
+     10*(log10(255*255)+log10(gplnpixels[0])-log10(gplsqerr[0])));
+  }
+  video_input_close(&vid1);
+  video_input_close(&vid2);
+  return 0;
+}
diff --git a/examples/dump_video.c b/examples/dump_video.c
new file mode 100644 (file)
index 0000000..c4ad468
--- /dev/null
@@ -0,0 +1,496 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: example dumpvid application; dumps  Theora streams
+  last mod: $Id: dump_video.c,v 1.2 2004/03/24 19:12:42 derf Exp $
+
+ ********************************************************************/
+
+/* By Mauricio Piacentini (mauricio at xiph.org) */
+/*  simply dump decoded YUV data, for verification of theora bitstream */
+
+#if !defined(_REENTRANT)
+#define _REENTRANT
+#endif
+#if !defined(_GNU_SOURCE)
+#define _GNU_SOURCE
+#endif
+#if !defined(_LARGEFILE_SOURCE)
+#define _LARGEFILE_SOURCE
+#endif
+#if !defined(_LARGEFILE64_SOURCE)
+#define _LARGEFILE64_SOURCE
+#endif
+#if !defined(_FILE_OFFSET_BITS)
+#define _FILE_OFFSET_BITS 64
+#endif
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/timeb.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+/*Yes, yes, we're going to hell.*/
+#if defined(_WIN32)
+#include <io.h>
+#endif
+#include <fcntl.h>
+#include <limits.h>
+#include <math.h>
+#include <signal.h>
+#include "getopt.h"
+#include "theora/theoradec.h"
+
+const char *optstring = "o:rf";
+struct option options [] = {
+  {"output",required_argument,NULL,'o'},
+  {"raw",no_argument, NULL,'r'}, /*Disable YUV4MPEG2 headers:*/
+  {"fps-only",no_argument, NULL, 'f'}, /* Only interested in fps of decode loop */
+  {NULL,0,NULL,0}
+};
+
+/* Helper; just grab some more compressed bitstream and sync it for
+   page extraction */
+int buffer_data(FILE *in,ogg_sync_state *oy){
+  char *buffer=ogg_sync_buffer(oy,4096);
+  int bytes=fread(buffer,1,4096,in);
+  ogg_sync_wrote(oy,bytes);
+  return(bytes);
+}
+
+/* never forget that globals are a one-way ticket to Hell */
+/* Ogg and codec state for demux/decode */
+ogg_sync_state    oy;
+ogg_page          og;
+ogg_stream_state  vo;
+ogg_stream_state  to;
+th_info           ti;
+th_comment        tc;
+th_setup_info    *ts;
+th_dec_ctx       *td;
+
+int              theora_p=0;
+int              theora_processing_headers;
+int              stateflag=0;
+
+/* single frame video buffering */
+int          videobuf_ready=0;
+ogg_int64_t  videobuf_granulepos=-1;
+double       videobuf_time=0;
+int          raw=0;
+
+FILE* outfile = NULL;
+
+int got_sigint=0;
+static void sigint_handler (int signal) {
+  got_sigint = 1;
+}
+
+static th_ycbcr_buffer ycbcr;
+
+static void stripe_decoded(th_ycbcr_buffer _dst,th_ycbcr_buffer _src,
+ int _fragy0,int _fragy_end){
+  int pli;
+  for(pli=0;pli<3;pli++){
+    int yshift;
+    int y_end;
+    int y;
+    yshift=pli!=0&&!(ti.pixel_fmt&2);
+    y_end=_fragy_end<<3-yshift;
+    /*An implemention intending to display this data would need to check the
+       crop rectangle before proceeding.*/
+    for(y=_fragy0<<3-yshift;y<y_end;y++){
+      memcpy(_dst[pli].data+y*_dst[pli].stride,
+       _src[pli].data+y*_src[pli].stride,_src[pli].width);
+    }
+  }
+}
+
+static void open_video(void){
+  th_stripe_callback cb;
+  int                pli;
+  /*Here we allocate a buffer so we can use the striped decode feature.
+    There's no real reason to do this in this application, because we want to
+     write to the file top-down, but the frame gets decoded bottom up, so we
+     have to buffer it all anyway.
+    But this illustrates how the API works.*/
+  for(pli=0;pli<3;pli++){
+    int xshift;
+    int yshift;
+    xshift=pli!=0&&!(ti.pixel_fmt&1);
+    yshift=pli!=0&&!(ti.pixel_fmt&2);
+    ycbcr[pli].data=(unsigned char *)malloc(
+     (ti.frame_width>>xshift)*(ti.frame_height>>yshift)*sizeof(char));
+    ycbcr[pli].stride=ti.frame_width>>xshift;
+    ycbcr[pli].width=ti.frame_width>>xshift;
+    ycbcr[pli].height=ti.frame_height>>yshift;
+  }
+  /*Similarly, since ycbcr is a global, there's no real reason to pass it as
+     the context.
+    In a more object-oriented decoder, we could pass the "this" pointer
+     instead (though in C++, platform-dependent calling convention differences
+     prevent us from using a real member function pointer).*/
+  cb.ctx=ycbcr;
+  cb.stripe_decoded=(th_stripe_decoded_func)stripe_decoded;
+  th_decode_ctl(td,TH_DECCTL_SET_STRIPE_CB,&cb,sizeof(cb));
+}
+
+/*Write out the planar YUV frame, uncropped.*/
+static void video_write(void){
+  int pli;
+  int i;
+  /*Uncomment the following to do normal, non-striped decoding.
+  th_ycbcr_buffer ycbcr;
+  th_decode_ycbcr_out(td,ycbcr);*/
+  if(outfile){
+    if(!raw)fprintf(outfile, "FRAME\n");
+    for(pli=0;pli<3;pli++){
+      for(i=0;i<ycbcr[pli].height;i++){
+        fwrite(ycbcr[pli].data+ycbcr[pli].stride*i, 1,
+         ycbcr[pli].width, outfile);
+      }
+    }
+  }
+}
+
+/* dump the theora comment header */
+static int dump_comments(th_comment *_tc){
+  int   i;
+  int   len;
+  FILE *out;
+  out=stderr;
+  fprintf(out,"Encoded by %s\n",_tc->vendor);
+  if(_tc->comments){
+    fprintf(out,"theora comment header:\n");
+    for(i=0;i<_tc->comments;i++){
+      if(_tc->user_comments[i]){
+        len=_tc->comment_lengths[i]<INT_MAX?_tc->comment_lengths[i]:INT_MAX;
+        fprintf(out,"\t%.*s\n",len,_tc->user_comments[i]);
+      }
+    }
+  }
+  return 0;
+}
+
+/* helper: push a page into the appropriate steam */
+/* this can be done blindly; a stream won't accept a page
+                that doesn't belong to it */
+static int queue_page(ogg_page *page){
+  if(theora_p)ogg_stream_pagein(&to,page);
+  return 0;
+}
+
+static void usage(void){
+  fprintf(stderr,
+          "Usage: dumpvid <file.ogv> > outfile\n"
+          "input is read from stdin if no file is passed on the command line\n"
+          "\n"
+  );
+}
+
+int main(int argc,char *argv[]){
+
+  ogg_packet op;
+
+  int long_option_index;
+  int c;
+
+  struct timeb start;
+  struct timeb after;
+  struct timeb last;
+  int fps_only=0;
+  int frames = 0;
+
+  FILE *infile = stdin;
+  outfile = stdout;
+
+#ifdef _WIN32 /* We need to set stdin/stdout to binary mode on windows. */
+  /* Beware the evil ifdef. We avoid these where we can, but this one we
+     cannot. Don't add any more, you'll probably go to hell if you do. */
+  _setmode( _fileno( stdin ), _O_BINARY );
+  _setmode( _fileno( stdout ), _O_BINARY );
+#endif
+
+  /* Process option arguments. */
+  while((c=getopt_long(argc,argv,optstring,options,&long_option_index))!=EOF){
+    switch(c){
+    case 'o':
+      if(strcmp(optarg,"-")!=0){
+        outfile=fopen(optarg,"wb");
+        if(outfile==NULL){
+          fprintf(stderr,"Unable to open output file '%s'\n", optarg);
+          exit(1);
+        }
+      }else{
+        outfile=stdout;
+      }
+      break;
+
+    case 'r':
+      raw=1;
+      break;
+
+    case 'f':
+      fps_only = 1;
+      outfile = NULL;
+      break;
+
+    default:
+      usage();
+    }
+  }
+  if(optind<argc){
+    infile=fopen(argv[optind],"rb");
+    if(infile==NULL){
+      fprintf(stderr,"Unable to open '%s' for extraction.\n", argv[optind]);
+      exit(1);
+    }
+    if(++optind<argc){
+      usage();
+      exit(1);
+    }
+  }
+  /*Ok, Ogg parsing.
+    The idea here is we have a bitstream that is made up of Ogg pages.
+    The libogg sync layer will find them for us.
+    There may be pages from several logical streams interleaved; we find the
+     first theora stream and ignore any others.
+    Then we pass the pages for our stream to the libogg stream layer which
+     assembles our original set of packets out of them.
+    It's the packets that libtheora actually knows how to handle.*/
+
+  /* start up Ogg stream synchronization layer */
+  ogg_sync_init(&oy);
+
+  /* init supporting Theora structures needed in header parsing */
+  th_comment_init(&tc);
+  th_info_init(&ti);
+
+  /*Ogg file open; parse the headers.
+    Theora (like Vorbis) depends on some initial header packets for decoder
+     setup and initialization.
+    We retrieve these first before entering the main decode loop.*/
+
+  /* Only interested in Theora streams */
+  while(!stateflag){
+    int ret=buffer_data(infile,&oy);
+    if(ret==0)break;
+    while(ogg_sync_pageout(&oy,&og)>0){
+      int got_packet;
+      ogg_stream_state test;
+
+      /* is this a mandated initial header? If not, stop parsing */
+      if(!ogg_page_bos(&og)){
+        /* don't leak the page; get it into the appropriate stream */
+        queue_page(&og);
+        stateflag=1;
+        break;
+      }
+
+      ogg_stream_init(&test,ogg_page_serialno(&og));
+      ogg_stream_pagein(&test,&og);
+      got_packet = ogg_stream_packetpeek(&test,&op);
+
+      /* identify the codec: try theora */
+      if((got_packet==1) && !theora_p && (theora_processing_headers=
+       th_decode_headerin(&ti,&tc,&ts,&op))>=0){
+        /* it is theora -- save this stream state */
+        memcpy(&to,&test,sizeof(test));
+        theora_p=1;
+        /*Advance past the successfully processed header.*/
+        if(theora_processing_headers)ogg_stream_packetout(&to,NULL);
+      }else{
+        /* whatever it is, we don't care about it */
+        ogg_stream_clear(&test);
+      }
+    }
+    /* fall through to non-bos page parsing */
+  }
+
+  /* we're expecting more header packets. */
+  while(theora_p && theora_processing_headers){
+    int ret;
+
+    /* look for further theora headers */
+    while(theora_processing_headers&&(ret=ogg_stream_packetpeek(&to,&op))){
+      if(ret<0)continue;
+      theora_processing_headers=th_decode_headerin(&ti,&tc,&ts,&op);
+      if(theora_processing_headers<0){
+        fprintf(stderr,"Error parsing Theora stream headers; "
+         "corrupt stream?\n");
+        exit(1);
+      }
+      else if(theora_processing_headers>0){
+        /*Advance past the successfully processed header.*/
+        ogg_stream_packetout(&to,NULL);
+      }
+      theora_p++;
+    }
+
+    /*Stop now so we don't fail if there aren't enough pages in a short
+       stream.*/
+    if(!(theora_p && theora_processing_headers))break;
+
+    /* The header pages/packets will arrive before anything else we
+       care about, or the stream is not obeying spec */
+
+    if(ogg_sync_pageout(&oy,&og)>0){
+      queue_page(&og); /* demux into the appropriate stream */
+    }else{
+      int ret=buffer_data(infile,&oy); /* someone needs more data */
+      if(ret==0){
+        fprintf(stderr,"End of file while searching for codec headers.\n");
+        exit(1);
+      }
+    }
+  }
+
+  /* and now we have it all.  initialize decoders */
+  if(theora_p){
+    dump_comments(&tc);
+    td=th_decode_alloc(&ti,ts);
+    fprintf(stderr,"Ogg logical stream %lx is Theora %dx%d %.02f fps video\n"
+     "Encoded frame content is %dx%d with %dx%d offset\n",
+     to.serialno,ti.frame_width,ti.frame_height,
+     (double)ti.fps_numerator/ti.fps_denominator,
+     ti.pic_width,ti.pic_height,ti.pic_x,ti.pic_y);
+  }else{
+    /* tear down the partial theora setup */
+    th_info_clear(&ti);
+    th_comment_clear(&tc);
+  }
+  /*Either way, we're done with the codec setup data.*/
+  th_setup_free(ts);
+
+  /* open video */
+  if(theora_p)open_video();
+
+  if(!raw && outfile){
+    static const char *CHROMA_TYPES[4]={"420jpeg",NULL,"422","444"};
+    if(ti.pixel_fmt>=4||ti.pixel_fmt==TH_PF_RSVD){
+      fprintf(stderr,"Unknown pixel format: %i\n",ti.pixel_fmt);
+      exit(1);
+    }
+    fprintf(outfile,"YUV4MPEG2 C%s W%d H%d F%d:%d I%c A%d:%d\n",
+     CHROMA_TYPES[ti.pixel_fmt],ti.frame_width,ti.frame_height,
+     ti.fps_numerator,ti.fps_denominator,'p',
+     ti.aspect_numerator,ti.aspect_denominator);
+  }
+
+  /* install signal handler */
+  signal (SIGINT, sigint_handler);
+
+  /*Finally the main decode loop.
+
+    It's one Theora packet per frame, so this is pretty straightforward if
+     we're not trying to maintain sync with other multiplexed streams.
+
+    The videobuf_ready flag is used to maintain the input buffer in the libogg
+     stream state.
+    If there's no output frame available at the end of the decode step, we must
+     need more input data.
+    We could simplify this by just using the return code on
+     ogg_page_packetout(), but the flag system extends easily to the case where
+     you care about more than one multiplexed stream (like with audio
+     playback).
+    In that case, just maintain a flag for each decoder you care about, and
+     pull data when any one of them stalls.
+
+    videobuf_time holds the presentation time of the currently buffered video
+     frame.
+    We ignore this value.*/
+
+  stateflag=0; /* playback has not begun */
+  /* queue any remaining pages from data we buffered but that did not
+      contain headers */
+  while(ogg_sync_pageout(&oy,&og)>0){
+    queue_page(&og);
+  }
+
+  if(fps_only){
+    ftime(&start);
+    ftime(&last);
+  }
+
+  while(!got_sigint){
+
+    while(theora_p && !videobuf_ready){
+      /* theora is one in, one out... */
+      if(ogg_stream_packetout(&to,&op)>0){
+
+        if(th_decode_packetin(td,&op,&videobuf_granulepos)>=0){
+          videobuf_time=th_granule_time(td,videobuf_granulepos);
+          videobuf_ready=1;
+          frames++;
+          if(fps_only)
+            ftime(&after);
+        }
+
+      }else
+        break;
+    }
+
+    if(fps_only && (videobuf_ready || fps_only==2)){
+      long ms =
+        after.time*1000.+after.millitm-
+        (last.time*1000.+last.millitm);
+
+      if(ms>500 || fps_only==1 ||
+         (feof(infile) && !videobuf_ready)){
+        float file_fps = (float)ti.fps_numerator/ti.fps_denominator;
+        fps_only=2;
+
+        ms = after.time*1000.+after.millitm-
+          (start.time*1000.+start.millitm);
+
+        fprintf(stderr,"\rframe:%d rate:%.2fx           ",
+                frames,
+                frames*1000./(ms*file_fps));
+        memcpy(&last,&after,sizeof(last));
+      }
+    }
+
+    if(!videobuf_ready && feof(infile))break;
+
+    if(!videobuf_ready){
+      /* no data yet for somebody.  Grab another page */
+      buffer_data(infile,&oy);
+      while(ogg_sync_pageout(&oy,&og)>0){
+        queue_page(&og);
+      }
+    }
+    /* dumpvideo frame, and get new one */
+    else if(outfile)video_write();
+
+    videobuf_ready=0;
+  }
+
+  /* end of decoder loop -- close everything */
+
+  if(theora_p){
+    ogg_stream_clear(&to);
+    th_decode_free(td);
+    th_comment_clear(&tc);
+    th_info_clear(&ti);
+  }
+  ogg_sync_clear(&oy);
+
+  if(infile && infile!=stdin)fclose(infile);
+  if(outfile && outfile!=stdout)fclose(outfile);
+
+  fprintf(stderr, "\n\n%d frames\n", frames);
+  fprintf(stderr, "\nDone.\n");
+
+  return(0);
+
+}
diff --git a/examples/encoder_example.c b/examples/encoder_example.c
new file mode 100644 (file)
index 0000000..4b73b64
--- /dev/null
@@ -0,0 +1,1826 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function: example encoder application; makes an Ogg Theora/Vorbis
+            file from YUV4MPEG2 and WAV input
+  last mod: $Id: encoder_example.c 16517 2009-08-25 19:48:57Z giles $
+
+ ********************************************************************/
+
+#if !defined(_REENTRANT)
+#define _REENTRANT
+#endif
+#if !defined(_GNU_SOURCE)
+#define _GNU_SOURCE
+#endif
+#if !defined(_LARGEFILE_SOURCE)
+#define _LARGEFILE_SOURCE
+#endif
+#if !defined(_LARGEFILE64_SOURCE)
+#define _LARGEFILE64_SOURCE
+#endif
+#if !defined(_FILE_OFFSET_BITS)
+#define _FILE_OFFSET_BITS 64
+#endif
+
+#include <stdio.h>
+#if !defined(_WIN32)
+#include <getopt.h>
+#include <unistd.h>
+#else
+#include "getopt.h"
+#endif
+#include <stdlib.h>
+#include <string.h>
+#include <time.h>
+#include <math.h>
+#include "theora/theoraenc.h"
+#include "vorbis/codec.h"
+#include "vorbis/vorbisenc.h"
+
+#ifdef _WIN32
+/*supply missing headers and functions to Win32. going to hell, I know*/
+#include <fcntl.h>
+#include <io.h>
+
+static double rint(double x)
+{
+  if (x < 0.0)
+    return (double)(int)(x - 0.5);
+  else
+    return (double)(int)(x + 0.5);
+}
+#endif
+
+const char *optstring = "b:e:o:a:A:v:V:s:S:f:F:ck:d:z:\1\2\3\4";
+struct option options [] = {
+  {"begin-time",required_argument,NULL,'b'},
+  {"end-time",required_argument,NULL,'e'},
+  {"output",required_argument,NULL,'o'},
+  {"audio-rate-target",required_argument,NULL,'A'},
+  {"video-rate-target",required_argument,NULL,'V'},
+  {"audio-quality",required_argument,NULL,'a'},
+  {"video-quality",required_argument,NULL,'v'},
+  {"aspect-numerator",required_argument,NULL,'s'},
+  {"aspect-denominator",required_argument,NULL,'S'},
+  {"framerate-numerator",required_argument,NULL,'f'},
+  {"framerate-denominator",required_argument,NULL,'F'},
+  {"vp3-compatible",no_argument,NULL,'c'},
+  {"speed",required_argument,NULL,'z'},
+  {"soft-target",no_argument,NULL,'\1'},
+  {"keyframe-freq",required_argument,NULL,'k'},
+  {"buf-delay",required_argument,NULL,'d'},
+  {"two-pass",no_argument,NULL,'\2'},
+  {"first-pass",required_argument,NULL,'\3'},
+  {"second-pass",required_argument,NULL,'\4'},
+  {NULL,0,NULL,0}
+};
+
+/* You'll go to Hell for using globals. */
+
+FILE *audio=NULL;
+FILE *video=NULL;
+
+int audio_ch=0;
+int audio_hz=0;
+
+float audio_q=.1f;
+int audio_r=-1;
+int vp3_compatible=0;
+
+int frame_w=0;
+int frame_h=0;
+int pic_w=0;
+int pic_h=0;
+int pic_x=0;
+int pic_y=0;
+int video_fps_n=-1;
+int video_fps_d=-1;
+int video_par_n=-1;
+int video_par_d=-1;
+char interlace;
+int src_c_dec_h=2;
+int src_c_dec_v=2;
+int dst_c_dec_h=2;
+int dst_c_dec_v=2;
+char chroma_type[16];
+
+/*The size of each converted frame buffer.*/
+size_t y4m_dst_buf_sz;
+/*The amount to read directly into the converted frame buffer.*/
+size_t y4m_dst_buf_read_sz;
+/*The size of the auxilliary buffer.*/
+size_t y4m_aux_buf_sz;
+/*The amount to read into the auxilliary buffer.*/
+size_t y4m_aux_buf_read_sz;
+
+/*The function used to perform chroma conversion.*/
+typedef void (*y4m_convert_func)(unsigned char *_dst,unsigned char *_aux);
+
+y4m_convert_func y4m_convert=NULL;
+
+int video_r=-1;
+int video_q=-1;
+ogg_uint32_t keyframe_frequency=0;
+int buf_delay=-1;
+
+long begin_sec=-1;
+long begin_usec=0;
+long end_sec=-1;
+long end_usec=0;
+
+static void usage(void){
+  fprintf(stderr,
+          "Usage: encoder_example [options] [audio_file] video_file\n\n"
+          "Options: \n\n"
+          "  -o --output <filename.ogv>      file name for encoded output;\n"
+          "                                  If this option is not given, the\n"
+          "                                  compressed data is sent to stdout.\n\n"
+          "  -A --audio-rate-target <n>      bitrate target for Vorbis audio;\n"
+          "                                  use -a and not -A if at all possible,\n"
+          "                                  as -a gives higher quality for a given\n"
+          "                                  bitrate.\n\n"
+          "  -V --video-rate-target <n>      bitrate target for Theora video\n\n"
+          "     --soft-target                Use a large reservoir and treat the rate\n"
+          "                                  as a soft target; rate control is less\n"
+          "                                  strict but resulting quality is usually\n"
+          "                                  higher/smoother overall. Soft target also\n"
+          "                                  allows an optional -v setting to specify\n"
+          "                                  a minimum allowed quality.\n\n"
+          "     --two-pass                   Compress input using two-pass rate control\n"
+          "                                  This option requires that the input to the\n"
+          "                                  to the encoder is seekable and performs\n"
+          "                                  both passes automatically.\n\n"
+          "     --first-pass <filename>      Perform first-pass of a two-pass rate\n"
+          "                                  controlled encoding, saving pass data to\n"
+          "                                  <filename> for a later second pass\n\n"
+          "     --second-pass <filename>     Perform second-pass of a two-pass rate\n"
+          "                                  controlled encoding, reading first-pass\n"
+          "                                  data from <filename>.  The first pass\n"
+          "                                  data must come from a first encoding pass\n"
+          "                                  using identical input video to work\n"
+          "                                  properly.\n\n"
+          "  -a --audio-quality <n>          Vorbis quality selector from -1 to 10\n"
+          "                                  (-1 yields smallest files but lowest\n"
+          "                                  fidelity; 10 yields highest fidelity\n"
+          "                                  but large files. '2' is a reasonable\n"
+          "                                  default).\n\n"
+          "   -v --video-quality <n>         Theora quality selector from 0 to 10\n"
+          "                                  (0 yields smallest files but lowest\n"
+          "                                  video quality. 10 yields highest\n"
+          "                                  fidelity but large files).\n\n"
+          "   -s --aspect-numerator <n>      Aspect ratio numerator, default is 0\n"
+          "                                  or extracted from YUV input file\n"
+          "   -S --aspect-denominator <n>    Aspect ratio denominator, default is 0\n"
+          "                                  or extracted from YUV input file\n"
+          "   -f --framerate-numerator <n>   Frame rate numerator, can be extracted\n"
+          "                                  from YUV input file. ex: 30000000\n"
+          "   -F --framerate-denominator <n> Frame rate denominator, can be extracted\n"
+          "                                  from YUV input file. ex: 1000000\n"
+          "                                  The frame rate nominator divided by this\n"
+          "                                  determinates the frame rate in units per tick\n"
+          "   -k --keyframe-freq <n>         Keyframe frequency\n"
+          "   -z --speed <n>                 Sets the encoder speed level. Higher speed\n"
+          "                                  levels favor quicker encoding over better\n"
+          "                                  quality per bit. Depending on the encoding\n"
+          "                                  mode, and the internal algorithms used,\n"
+          "                                  quality may actually improve with higher\n"
+          "                                  speeds, but in this case bitrate will also\n"
+          "                                  likely increase. The maximum value, and the\n"
+          "                                  meaning of each value, are implementation-\n"
+          "                                  specific and may change depending on the\n"
+          "                                  current encoding mode (rate constrained,\n"
+          "                                  two-pass, etc.).\n"
+          "   -d --buf-delay <n>             Buffer delay (in frames). Longer delays\n"
+          "                                  allow smoother rate adaptation and provide\n"
+          "                                  better overall quality, but require more\n"
+          "                                  client side buffering and add latency. The\n"
+          "                                  default value is the keyframe interval for\n"
+          "                                  one-pass encoding (or somewhat larger if\n"
+          "                                  --soft-target is used) and infinite for\n"
+          "                                  two-pass encoding.\n"
+          "   -b --begin-time <h:m:s.d>      Begin encoding at offset into input\n"
+          "   -e --end-time <h:m:s.d>        End encoding at offset into input\n"
+          "encoder_example accepts only uncompressed RIFF WAV format audio and\n"
+          "YUV4MPEG2 uncompressed video.\n\n");
+  exit(1);
+}
+
+static int y4m_parse_tags(char *_tags){
+  int   got_w;
+  int   got_h;
+  int   got_fps;
+  int   got_interlace;
+  int   got_par;
+  int   got_chroma;
+  int   tmp_video_fps_n;
+  int   tmp_video_fps_d;
+  int   tmp_video_par_n;
+  int   tmp_video_par_d;
+  char *p;
+  char *q;
+  got_w=got_h=got_fps=got_interlace=got_par=got_chroma=0;
+  for(p=_tags;;p=q){
+    /*Skip any leading spaces.*/
+    while(*p==' ')p++;
+    /*If that's all we have, stop.*/
+    if(p[0]=='\0')break;
+    /*Find the end of this tag.*/
+    for(q=p+1;*q!='\0'&&*q!=' ';q++);
+    /*Process the tag.*/
+    switch(p[0]){
+      case 'W':{
+        if(sscanf(p+1,"%d",&pic_w)!=1)return -1;
+        got_w=1;
+      }break;
+      case 'H':{
+        if(sscanf(p+1,"%d",&pic_h)!=1)return -1;
+        got_h=1;
+      }break;
+      case 'F':{
+        if(sscanf(p+1,"%d:%d",&tmp_video_fps_n,&tmp_video_fps_d)!=2)return -1;
+        got_fps=1;
+      }break;
+      case 'I':{
+        interlace=p[1];
+        got_interlace=1;
+      }break;
+      case 'A':{
+        if(sscanf(p+1,"%d:%d",&tmp_video_par_n,&tmp_video_par_d)!=2)return -1;
+        got_par=1;
+      }break;
+      case 'C':{
+        if(q-p>16)return -1;
+        memcpy(chroma_type,p+1,q-p-1);
+        chroma_type[q-p-1]='\0';
+        got_chroma=1;
+      }break;
+      /*Ignore unknown tags.*/
+    }
+  }
+  if(!got_w||!got_h||!got_fps||!got_interlace||!got_par)return -1;
+  /*Chroma-type is not specified in older files, e.g., those generated by
+     mplayer.*/
+  if(!got_chroma)strcpy(chroma_type,"420");
+  /*Update fps and aspect ratio globals if not specified in the command line.*/
+  if(video_fps_n==-1)video_fps_n=tmp_video_fps_n;
+  if(video_fps_d==-1)video_fps_d=tmp_video_fps_d;
+  if(video_par_n==-1)video_par_n=tmp_video_par_n;
+  if(video_par_d==-1)video_par_d=tmp_video_par_d;
+  return 0;
+}
+
+/*All anti-aliasing filters in the following conversion functions are based on
+   one of two window functions:
+  The 6-tap Lanczos window (for down-sampling and shifts):
+   sinc(\pi*t)*sinc(\pi*t/3), |t|<3  (sinc(t)==sin(t)/t)
+   0,                         |t|>=3
+  The 4-tap Mitchell window (for up-sampling):
+   7|t|^3-12|t|^2+16/3,             |t|<1
+   -(7/3)|x|^3+12|x|^2-20|x|+32/3,  |t|<2
+   0,                               |t|>=2
+  The number of taps is intentionally kept small to reduce computational
+   overhead and limit ringing.
+
+  The taps from these filters are scaled so that their sum is 1, and the result
+   is scaled by 128 and rounded to integers to create a filter whose
+   intermediate values fit inside 16 bits.
+  Coefficients are rounded in such a way as to ensure their sum is still 128,
+   which is usually equivalent to normal rounding.*/
+
+#define OC_MINI(_a,_b)      ((_a)>(_b)?(_b):(_a))
+#define OC_MAXI(_a,_b)      ((_a)<(_b)?(_b):(_a))
+#define OC_CLAMPI(_a,_b,_c) (OC_MAXI(_a,OC_MINI(_b,_c)))
+
+/*420jpeg chroma samples are sited like:
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  420mpeg2 chroma samples are sited like:
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  BR      |       BR      |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  BR      |       BR      |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  We use a resampling filter to shift the site locations one quarter pixel (at
+   the chroma plane's resolution) to the right.
+  The 4:2:2 modes look exactly the same, except there are twice as many chroma
+   lines, and they are vertically co-sited with the luma samples in both the
+   mpeg2 and jpeg cases (thus requiring no vertical resampling).*/
+static void y4m_convert_42xmpeg2_42xjpeg(unsigned char *_dst,
+ unsigned char *_aux){
+  int c_w;
+  int c_h;
+  int pli;
+  int y;
+  int x;
+  /*Skip past the luma data.*/
+  _dst+=pic_w*pic_h;
+  /*Compute the size of each chroma plane.*/
+  c_w=(pic_w+dst_c_dec_h-1)/dst_c_dec_h;
+  c_h=(pic_h+dst_c_dec_v-1)/dst_c_dec_v;
+  for(pli=1;pli<3;pli++){
+    for(y=0;y<c_h;y++){
+      /*Filter: [4 -17 114 35 -9 1]/128, derived from a 6-tap Lanczos
+         window.*/
+      for(x=0;x<OC_MINI(c_w,2);x++){
+        _dst[x]=(unsigned char)OC_CLAMPI(0,4*_aux[0]-17*_aux[OC_MAXI(x-1,0)]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[OC_MINI(x+3,c_w-1)]+64>>7,255);
+      }
+      for(;x<c_w-3;x++){
+        _dst[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[x+1]-9*_aux[x+2]+_aux[x+3]+64>>7,255);
+      }
+      for(;x<c_w;x++){
+        _dst[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[c_w-1]+64>>7,255);
+      }
+      _dst+=c_w;
+      _aux+=c_w;
+    }
+  }
+}
+
+/*This format is only used for interlaced content, but is included for
+   completeness.
+
+  420jpeg chroma samples are sited like:
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |   BR  |       |   BR  |
+  |       |       |       |
+  Y-------Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  420paldv chroma samples are sited like:
+  YR------Y-------YR------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YB------Y-------YB------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YR------Y-------YR------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YB------Y-------YB------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  We use a resampling filter to shift the site locations one quarter pixel (at
+   the chroma plane's resolution) to the right.
+  Then we use another filter to move the C_r location down one quarter pixel,
+   and the C_b location up one quarter pixel.*/
+static void y4m_convert_42xpaldv_42xjpeg(unsigned char *_dst,
+ unsigned char *_aux){
+  unsigned char *tmp;
+  int            c_w;
+  int            c_h;
+  int            c_sz;
+  int            pli;
+  int            y;
+  int            x;
+  /*Skip past the luma data.*/
+  _dst+=pic_w*pic_h;
+  /*Compute the size of each chroma plane.*/
+  c_w=(pic_w+1)/2;
+  c_h=(pic_h+dst_c_dec_h-1)/dst_c_dec_h;
+  c_sz=c_w*c_h;
+  /*First do the horizontal re-sampling.
+    This is the same as the mpeg2 case, except that after the horizontal case,
+     we need to apply a second vertical filter.*/
+  tmp=_aux+2*c_sz;
+  for(pli=1;pli<3;pli++){
+    for(y=0;y<c_h;y++){
+      /*Filter: [4 -17 114 35 -9 1]/128, derived from a 6-tap Lanczos
+         window.*/
+      for(x=0;x<OC_MINI(c_w,2);x++){
+        tmp[x]=(unsigned char)OC_CLAMPI(0,4*_aux[0]-17*_aux[OC_MAXI(x-1,0)]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[OC_MINI(x+3,c_w-1)]+64>>7,255);
+      }
+      for(;x<c_w-3;x++){
+        tmp[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[x+1]-9*_aux[x+2]+_aux[x+3]+64>>7,255);
+      }
+      for(;x<c_w;x++){
+        tmp[x]=(unsigned char)OC_CLAMPI(0,4*_aux[x-2]-17*_aux[x-1]+
+         114*_aux[x]+35*_aux[OC_MINI(x+1,c_w-1)]-9*_aux[OC_MINI(x+2,c_w-1)]+
+         _aux[c_w-1]+64>>7,255);
+      }
+      tmp+=c_w;
+      _aux+=c_w;
+    }
+    switch(pli){
+      case 1:{
+        tmp-=c_sz;
+        /*Slide C_b up a quarter-pel.
+          This is the same filter used above, but in the other order.*/
+        for(x=0;x<c_w;x++){
+          for(y=0;y<OC_MINI(c_h,3);y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,tmp[0]-
+             9*tmp[OC_MAXI(y-2,0)*c_w]+35*tmp[OC_MAXI(y-1,0)*c_w]+
+             114*tmp[y*c_w]-17*tmp[OC_MINI(y+1,c_h-1)*c_w]+
+             4*tmp[OC_MINI(y+2,c_h-1)*c_w]+64>>7,255);
+          }
+          for(;y<c_h-2;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,tmp[(y-3)*c_w]-
+             9*tmp[(y-2)*c_w]+35*tmp[(y-1)*c_w]+114*tmp[y*c_w]-
+             17*tmp[(y+1)*c_w]+4*tmp[(y+2)*c_w]+64>>7,255);
+          }
+          for(;y<c_h;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,tmp[(y-3)*c_w]-
+             9*tmp[(y-2)*c_w]+35*tmp[(y-1)*c_w]+114*tmp[y*c_w]-
+             17*tmp[OC_MINI(y+1,c_h-1)*c_w]+4*tmp[(c_h-1)*c_w]+64>>7,255);
+          }
+          _dst++;
+          tmp++;
+        }
+        _dst+=c_sz-c_w;
+        tmp-=c_w;
+      }break;
+      case 2:{
+        tmp-=c_sz;
+        /*Slide C_r down a quarter-pel.
+          This is the same as the horizontal filter.*/
+        for(x=0;x<c_w;x++){
+          for(y=0;y<OC_MINI(c_h,2);y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,4*tmp[0]-
+             17*tmp[OC_MAXI(y-1,0)*c_w]+114*tmp[y*c_w]+
+             35*tmp[OC_MINI(y+1,c_h-1)*c_w]-9*tmp[OC_MINI(y+2,c_h-1)*c_w]+
+             tmp[OC_MINI(y+3,c_h-1)*c_w]+64>>7,255);
+          }
+          for(;y<c_h-3;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,4*tmp[(y-2)*c_w]-
+             17*tmp[(y-1)*c_w]+114*tmp[y*c_w]+35*tmp[(y+1)*c_w]-
+             9*tmp[(y+2)*c_w]+tmp[(y+3)*c_w]+64>>7,255);
+          }
+          for(;y<c_h;y++){
+            _dst[y*c_w]=(unsigned char)OC_CLAMPI(0,4*tmp[(y-2)*c_w]-
+             17*tmp[(y-1)*c_w]+114*tmp[y*c_w]+35*tmp[OC_MINI(y+1,c_h-1)*c_w]-
+             9*tmp[OC_MINI(y+2,c_h-1)*c_w]+tmp[(c_h-1)*c_w]+64>>7,255);
+          }
+          _dst++;
+          tmp++;
+        }
+      }break;
+    }
+    /*For actual interlaced material, this would have to be done separately on
+       each field, and the shift amounts would be different.
+      C_r moves down 1/8, C_b up 3/8 in the top field, and C_r moves down 3/8,
+       C_b up 1/8 in the bottom field.
+      The corresponding filters would be:
+       Down 1/8 (reverse order for up): [3 -11 125 15 -4 0]/128
+       Down 3/8 (reverse order for up): [4 -19 98 56 -13 2]/128*/
+  }
+}
+
+/*422jpeg chroma samples are sited like:
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  Y---BR--Y-------Y---BR--Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  411 chroma samples are sited like:
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+  YBR-----Y-------Y-------Y-------
+  |       |       |       |
+  |       |       |       |
+  |       |       |       |
+
+  We use a filter to resample at site locations one eighth pixel (at the source
+   chroma plane's horizontal resolution) and five eighths of a pixel to the
+   right.*/
+static void y4m_convert_411_422jpeg(unsigned char *_dst,
+ unsigned char *_aux){
+  int c_w;
+  int dst_c_w;
+  int c_h;
+  int pli;
+  int y;
+  int x;
+  /*Skip past the luma data.*/
+  _dst+=pic_w*pic_h;
+  /*Compute the size of each chroma plane.*/
+  c_w=(pic_w+src_c_dec_h-1)/src_c_dec_h;
+  dst_c_w=(pic_w+dst_c_dec_h-1)/dst_c_dec_h;
+  c_h=(pic_h+dst_c_dec_v-1)/dst_c_dec_v;
+  for(pli=1;pli<3;pli++){
+    for(y=0;y<c_h;y++){
+      /*Filters: [1 110 18 -1]/128 and [-3 50 86 -5]/128, both derived from a
+         4-tap Mitchell window.*/
+      for(x=0;x<OC_MINI(c_w,1);x++){
+        _dst[x<<1]=(unsigned char)OC_CLAMPI(0,111*_aux[0]+
+         18*_aux[OC_MINI(1,c_w-1)]-_aux[OC_MINI(2,c_w-1)]+64>>7,255);
+        _dst[x<<1|1]=(unsigned char)OC_CLAMPI(0,47*_aux[0]+
+         86*_aux[OC_MINI(1,c_w-1)]-5*_aux[OC_MINI(2,c_w-1)]+64>>7,255);
+      }
+      for(;x<c_w-2;x++){
+        _dst[x<<1]=(unsigned char)OC_CLAMPI(0,_aux[x-1]+110*_aux[x]+
+         18*_aux[x+1]-_aux[x+2]+64>>7,255);
+        _dst[x<<1|1]=(unsigned char)OC_CLAMPI(0,-3*_aux[x-1]+50*_aux[x]+
+         86*_aux[x+1]-5*_aux[x+2]+64>>7,255);
+      }
+      for(;x<c_w;x++){
+        _dst[x<<1]=(unsigned char)OC_CLAMPI(0,_aux[x-1]+110*_aux[x]+
+         18*_aux[OC_MINI(x+1,c_w-1)]-_aux[c_w-1]+64>>7,255);
+        if((x<<1|1)<dst_c_w){
+          _dst[x<<1|1]=(unsigned char)OC_CLAMPI(0,-3*_aux[x-1]+50*_aux[x]+
+           86*_aux[OC_MINI(x+1,c_w-1)]-5*_aux[c_w-1]+64>>7,255);
+        }
+      }
+      _dst+=dst_c_w;
+      _aux+=c_w;
+    }
+  }
+}
+
+/*The image is padded with empty chroma components at 4:2:0.
+  This costs about 17 bits a frame to code.*/
+static void y4m_convert_mono_420jpeg(unsigned char *_dst,
+ unsigned char *_aux){
+  int c_sz;
+  _dst+=pic_w*pic_h;
+  c_sz=((pic_w+dst_c_dec_h-1)/dst_c_dec_h)*((pic_h+dst_c_dec_v-1)/dst_c_dec_v);
+  memset(_dst,128,c_sz*2);
+}
+
+#if 0
+/*Right now just 444 to 420.
+  Not too hard to generalize.*/
+static void y4m_convert_4xxjpeg_42xjpeg(unsigned char *_dst,
+ unsigned char *_aux){
+  unsigned char *tmp;
+  int            c_w;
+  int            c_h;
+  int            pic_sz;
+  int            tmp_sz;
+  int            c_sz;
+  int            pli;
+  int            y;
+  int            x;
+  /*Compute the size of each chroma plane.*/
+  c_w=(pic_w+dst_c_dec_h-1)/dst_c_dec_h;
+  c_h=(pic_h+dst_c_dec_v-1)/dst_c_dec_v;
+  pic_sz=pic_w*pic_h;
+  tmp_sz=c_w*pic_h;
+  c_sz=c_w*c_h;
+  _dst+=pic_sz;
+  for(pli=1;pli<3;pli++){
+    tmp=_aux+pic_sz;
+    /*In reality, the horizontal and vertical steps could be pipelined, for
+       less memory consumption and better cache performance, but we do them
+       separately for simplicity.*/
+    /*First do horizontal filtering (convert to 4:2:2)*/
+    /*Filter: [3 -17 78 78 -17 3]/128, derived from a 6-tap Lanczos window.*/
+    for(y=0;y<pic_h;y++){
+      for(x=0;x<OC_MINI(pic_w,2);x+=2){
+        tmp[x>>1]=OC_CLAMPI(0,64*_aux[0]+78*_aux[OC_MINI(1,pic_w-1)]-
+         17*_aux[OC_MINI(2,pic_w-1)]+3*_aux[OC_MINI(3,pic_w-1)]+64>>7,255);
+      }
+      for(;x<pic_w-3;x+=2){
+        tmp[x>>1]=OC_CLAMPI(0,3*(_aux[x-2]+_aux[x+3])-17*(_aux[x-1]+_aux[x+2])+
+         78*(_aux[x]+_aux[x+1])+64>>7,255);
+      }
+      for(;x<pic_w;x+=2){
+        tmp[x>>1]=OC_CLAMPI(0,3*(_aux[x-2]+_aux[pic_w-1])-
+         17*(_aux[x-1]+_aux[OC_MINI(x+2,pic_w-1)])+
+         78*(_aux[x]+_aux[OC_MINI(x+1,pic_w-1)])+64>>7,255);
+      }
+      tmp+=c_w;
+      _aux+=pic_w;
+    }
+    _aux-=pic_sz;
+    tmp-=tmp_sz;
+    /*Now do the vertical filtering.*/
+    for(x=0;x<c_w;x++){
+      for(y=0;y<OC_MINI(pic_h,2);y+=2){
+        _dst[(y>>1)*c_w]=OC_CLAMPI(0,64*tmp[0]+78*tmp[OC_MINI(1,pic_h-1)*c_w]-
+         17*tmp[OC_MINI(2,pic_h-1)*c_w]+3*tmp[OC_MINI(3,pic_h-1)*c_w]+
+         64>>7,255);
+      }
+      for(;y<pic_h-3;y+=2){
+        _dst[(y>>1)*c_w]=OC_CLAMPI(0,3*(tmp[(y-2)*c_w]+tmp[(y+3)*c_w])-
+         17*(tmp[(y-1)*c_w]+tmp[(y+2)*c_w])+78*(tmp[y*c_w]+tmp[(y+1)*c_w])+
+         64>>7,255);
+      }
+      for(;y<pic_h;y+=2){
+        _dst[(y>>1)*c_w]=OC_CLAMPI(0,3*(tmp[(y-2)*c_w]+tmp[(pic_h-1)*c_w])-
+         17*(tmp[(y-1)*c_w]+tmp[OC_MINI(y+2,pic_h-1)*c_w])+
+         78*(tmp[y*c_w]+tmp[OC_MINI(y+1,pic_h-1)*c_w])+64>>7,255);
+      }
+      tmp++;
+      _dst++;
+    }
+    _dst-=c_w;
+  }
+}
+#endif
+
+
+/*No conversion function needed.*/
+static void y4m_convert_null(unsigned char *_dst,
+ unsigned char *_aux){
+}
+
+static void id_file(char *f){
+  FILE *test;
+  unsigned char buffer[80];
+  int ret;
+
+  /* open it, look for magic */
+
+  if(!strcmp(f,"-")){
+    /* stdin */
+    test=stdin;
+  }else{
+    test=fopen(f,"rb");
+    if(!test){
+      fprintf(stderr,"Unable to open file %s.\n",f);
+      exit(1);
+    }
+  }
+
+  ret=fread(buffer,1,4,test);
+  if(ret<4){
+    fprintf(stderr,"EOF determining file type of file %s.\n",f);
+    exit(1);
+  }
+
+  if(!memcmp(buffer,"RIFF",4)){
+    /* possible WAV file */
+
+    if(audio){
+      /* umm, we already have one */
+      fprintf(stderr,"Multiple RIFF WAVE files specified on command line.\n");
+      exit(1);
+    }
+
+    /* Parse the rest of the header */
+
+    ret=fread(buffer,1,8,test);
+    if(ret<8)goto riff_err;
+    if(!memcmp(buffer+4,"WAVE",4)){
+
+      while(!feof(test)){
+        ret=fread(buffer,1,4,test);
+        if(ret<4)goto riff_err;
+        if(!memcmp("fmt",buffer,3)){
+
+          /* OK, this is our audio specs chunk.  Slurp it up. */
+
+          ret=fread(buffer,1,20,test);
+          if(ret<20)goto riff_err;
+
+          if(memcmp(buffer+4,"\001\000",2)){
+            fprintf(stderr,"The WAV file %s is in a compressed format; "
+                    "can't read it.\n",f);
+            exit(1);
+          }
+
+          audio=test;
+          audio_ch=buffer[6]+(buffer[7]<<8);
+          audio_hz=buffer[8]+(buffer[9]<<8)+
+            (buffer[10]<<16)+(buffer[11]<<24);
+
+          if(buffer[18]+(buffer[19]<<8)!=16){
+            fprintf(stderr,"Can only read 16 bit WAV files for now.\n");
+            exit(1);
+          }
+
+          /* Now, align things to the beginning of the data */
+          /* Look for 'dataxxxx' */
+          while(!feof(test)){
+            ret=fread(buffer,1,4,test);
+            if(ret<4)goto riff_err;
+            if(!memcmp("data",buffer,4)){
+              /* We're there.  Ignore the declared size for now. */
+              ret=fread(buffer,1,4,test);
+              if(ret<4)goto riff_err;
+
+              fprintf(stderr,"File %s is 16 bit %d channel %d Hz RIFF WAV audio.\n",
+                      f,audio_ch,audio_hz);
+
+              return;
+            }
+          }
+        }
+      }
+    }
+
+    fprintf(stderr,"Couldn't find WAVE data in RIFF file %s.\n",f);
+    exit(1);
+
+  }
+  if(!memcmp(buffer,"YUV4",4)){
+    /* possible YUV2MPEG2 format file */
+    /* read until newline, or 80 cols, whichever happens first */
+    int i;
+    for(i=0;i<79;i++){
+      ret=fread(buffer+i,1,1,test);
+      if(ret<1)goto yuv_err;
+      if(buffer[i]=='\n')break;
+    }
+    if(i==79){
+      fprintf(stderr,"Error parsing %s header; not a YUV2MPEG2 file?\n",f);
+    }
+    buffer[i]='\0';
+
+    if(!memcmp(buffer,"MPEG",4)){
+
+      if(video){
+        /* umm, we already have one */
+        fprintf(stderr,"Multiple video files specified on command line.\n");
+        exit(1);
+      }
+
+      if(buffer[4]!='2'){
+        fprintf(stderr,"Incorrect YUV input file version; YUV4MPEG2 required.\n");
+      }
+
+      ret=y4m_parse_tags((char *)buffer+5);
+      if(ret<0){
+        fprintf(stderr,"Error parsing YUV4MPEG2 header in file %s.\n",f);
+        exit(1);
+      }
+
+      if(interlace!='p'){
+        fprintf(stderr,"Input video is interlaced; Theora handles only progressive scan\n");
+        exit(1);
+      }
+
+      if(strcmp(chroma_type,"420")==0||strcmp(chroma_type,"420jpeg")==0){
+        src_c_dec_h=dst_c_dec_h=src_c_dec_v=dst_c_dec_v=2;
+        y4m_dst_buf_read_sz=pic_w*pic_h+2*((pic_w+1)/2)*((pic_h+1)/2);
+        y4m_aux_buf_sz=y4m_aux_buf_read_sz=0;
+        y4m_convert=y4m_convert_null;
+      }
+      else if(strcmp(chroma_type,"420mpeg2")==0){
+        src_c_dec_h=dst_c_dec_h=src_c_dec_v=dst_c_dec_v=2;
+        y4m_dst_buf_read_sz=pic_w*pic_h;
+        /*Chroma filter required: read into the aux buf first.*/
+        y4m_aux_buf_sz=y4m_aux_buf_read_sz=2*((pic_w+1)/2)*((pic_h+1)/2);
+        y4m_convert=y4m_convert_42xmpeg2_42xjpeg;
+      }
+      else if(strcmp(chroma_type,"420paldv")==0){
+        src_c_dec_h=dst_c_dec_h=src_c_dec_v=dst_c_dec_v=2;
+        y4m_dst_buf_read_sz=pic_w*pic_h;
+        /*Chroma filter required: read into the aux buf first.
+          We need to make two filter passes, so we need some extra space in the
+           aux buffer.*/
+        y4m_aux_buf_sz=3*((pic_w+1)/2)*((pic_h+1)/2);
+        y4m_aux_buf_read_sz=2*((pic_w+1)/2)*((pic_h+1)/2);
+        y4m_convert=y4m_convert_42xpaldv_42xjpeg;
+      }
+      else if(strcmp(chroma_type,"422")==0){
+        src_c_dec_h=dst_c_dec_h=2;
+        src_c_dec_v=dst_c_dec_v=1;
+        y4m_dst_buf_read_sz=pic_w*pic_h;
+        /*Chroma filter required: read into the aux buf first.*/
+        y4m_aux_buf_sz=y4m_aux_buf_read_sz=2*((pic_w+1)/2)*pic_h;
+        y4m_convert=y4m_convert_42xmpeg2_42xjpeg;
+      }
+      else if(strcmp(chroma_type,"411")==0){
+        src_c_dec_h=4;
+        /*We don't want to introduce any additional sub-sampling, so we
+           promote 4:1:1 material to 4:2:2, as the closest format Theora can
+           handle.*/
+        dst_c_dec_h=2;
+        src_c_dec_v=dst_c_dec_v=1;
+        y4m_dst_buf_read_sz=pic_w*pic_h;
+        /*Chroma filter required: read into the aux buf first.*/
+        y4m_aux_buf_sz=y4m_aux_buf_read_sz=2*((pic_w+3)/4)*pic_h;
+        y4m_convert=y4m_convert_411_422jpeg;
+      }
+      else if(strcmp(chroma_type,"444")==0){
+        src_c_dec_h=dst_c_dec_h=src_c_dec_v=dst_c_dec_v=1;
+        y4m_dst_buf_read_sz=pic_w*pic_h*3;
+        y4m_aux_buf_sz=y4m_aux_buf_read_sz=0;
+        y4m_convert=y4m_convert_null;
+      }
+      else if(strcmp(chroma_type,"444alpha")==0){
+        src_c_dec_h=dst_c_dec_h=src_c_dec_v=dst_c_dec_v=1;
+        y4m_dst_buf_read_sz=pic_w*pic_h*3;
+        /*Read the extra alpha plane into the aux buf.
+          It will be discarded.*/
+        y4m_aux_buf_sz=y4m_aux_buf_read_sz=pic_w*pic_h;
+        y4m_convert=y4m_convert_null;
+      }
+      else if(strcmp(chroma_type,"mono")==0){
+        src_c_dec_h=src_c_dec_v=0;
+        dst_c_dec_h=dst_c_dec_v=2;
+        y4m_dst_buf_read_sz=pic_w*pic_h;
+        y4m_aux_buf_sz=y4m_aux_buf_read_sz=0;
+        y4m_convert=y4m_convert_mono_420jpeg;
+      }
+      else{
+        fprintf(stderr,"Unknown chroma sampling type: %s\n",chroma_type);
+        exit(1);
+      }
+      /*The size of the final frame buffers is always computed from the
+         destination chroma decimation type.*/
+      y4m_dst_buf_sz=pic_w*pic_h+2*((pic_w+dst_c_dec_h-1)/dst_c_dec_h)*
+       ((pic_h+dst_c_dec_v-1)/dst_c_dec_v);
+
+      video=test;
+
+      fprintf(stderr,"File %s is %dx%d %.02f fps %s video.\n",
+              f,pic_w,pic_h,(double)video_fps_n/video_fps_d,chroma_type);
+
+      return;
+    }
+  }
+  fprintf(stderr,"Input file %s is neither a WAV nor YUV4MPEG2 file.\n",f);
+  exit(1);
+
+ riff_err:
+  fprintf(stderr,"EOF parsing RIFF file %s.\n",f);
+  exit(1);
+ yuv_err:
+  fprintf(stderr,"EOF parsing YUV4MPEG2 file %s.\n",f);
+  exit(1);
+
+}
+
+int spinner=0;
+char *spinascii="|/-\\";
+void spinnit(void){
+  spinner++;
+  if(spinner==4)spinner=0;
+  fprintf(stderr,"\r%c",spinascii[spinner]);
+}
+
+int fetch_and_process_audio(FILE *audio,ogg_page *audiopage,
+                            ogg_stream_state *vo,
+                            vorbis_dsp_state *vd,
+                            vorbis_block *vb,
+                            int audioflag){
+  static ogg_int64_t samples_sofar=0;
+  ogg_packet op;
+  int i,j;
+  ogg_int64_t beginsample = audio_hz*begin_sec + audio_hz*begin_usec*.000001;
+  ogg_int64_t endsample = audio_hz*end_sec + audio_hz*end_usec*.000001;
+
+  while(audio && !audioflag){
+    /* process any audio already buffered */
+    spinnit();
+    if(ogg_stream_pageout(vo,audiopage)>0) return 1;
+    if(ogg_stream_eos(vo))return 0;
+
+    {
+      /* read and process more audio */
+      signed char readbuffer[4096];
+      signed char *readptr=readbuffer;
+      int toread=4096/2/audio_ch;
+      int bytesread=fread(readbuffer,1,toread*2*audio_ch,audio);
+      int sampread=bytesread/2/audio_ch;
+      float **vorbis_buffer;
+      int count=0;
+
+      if(bytesread<=0 ||
+         (samples_sofar>=endsample && endsample>0)){
+        /* end of file.  this can be done implicitly, but it's
+           easier to see here in non-clever fashion.  Tell the
+           library we're at end of stream so that it can handle the
+           last frame and mark end of stream in the output properly */
+        vorbis_analysis_wrote(vd,0);
+      }else{
+        if(samples_sofar < beginsample){
+          if(samples_sofar+sampread > beginsample){
+            readptr += (beginsample-samples_sofar)*2*audio_ch;
+            sampread += samples_sofar-beginsample;
+            samples_sofar = sampread+beginsample;
+          }else{
+            samples_sofar += sampread;
+            sampread = 0;
+          }
+        }else{
+          samples_sofar += sampread;
+        }
+
+        if(samples_sofar > endsample && endsample > 0)
+          sampread-= (samples_sofar - endsample);
+
+        if(sampread>0){
+
+          vorbis_buffer=vorbis_analysis_buffer(vd,sampread);
+          /* uninterleave samples */
+          for(i=0;i<sampread;i++){
+            for(j=0;j<audio_ch;j++){
+              vorbis_buffer[j][i]=((readptr[count+1]<<8)|
+                                   (0x00ff&(int)readptr[count]))/32768.f;
+              count+=2;
+            }
+          }
+
+          vorbis_analysis_wrote(vd,sampread);
+        }
+      }
+
+      while(vorbis_analysis_blockout(vd,vb)==1){
+
+        /* analysis, assume we want to use bitrate management */
+        vorbis_analysis(vb,NULL);
+        vorbis_bitrate_addblock(vb);
+
+        /* weld packets into the bitstream */
+        while(vorbis_bitrate_flushpacket(vd,&op))
+          ogg_stream_packetin(vo,&op);
+
+      }
+    }
+  }
+
+  return audioflag;
+}
+
+static int                 frame_state=-1;
+static ogg_int64_t         frames=0;
+static unsigned char      *yuvframe[3];
+static th_ycbcr_buffer     ycbcr;
+
+int fetch_and_process_video_packet(FILE *video,FILE *twopass_file,int passno,
+ th_enc_ctx *td,ogg_packet *op){
+  int                        ret;
+  int                        pic_sz;
+  int                        frame_c_w;
+  int                        frame_c_h;
+  int                        c_w;
+  int                        c_h;
+  int                        c_sz;
+  ogg_int64_t                beginframe;
+  ogg_int64_t                endframe;
+  spinnit();
+  beginframe=(video_fps_n*begin_sec+video_fps_n*begin_usec*.000001)/video_fps_d;
+  endframe=(video_fps_n*end_sec+video_fps_n*end_usec*.000001)/video_fps_d;
+  if(frame_state==-1){
+    /* initialize the double frame buffer */
+    yuvframe[0]=(unsigned char *)malloc(y4m_dst_buf_sz);
+    yuvframe[1]=(unsigned char *)malloc(y4m_dst_buf_sz);
+    yuvframe[2]=(unsigned char *)malloc(y4m_aux_buf_sz);
+    frame_state=0;
+  }
+  pic_sz=pic_w*pic_h;
+  frame_c_w=frame_w/dst_c_dec_h;
+  frame_c_h=frame_h/dst_c_dec_v;
+  c_w=(pic_w+dst_c_dec_h-1)/dst_c_dec_h;
+  c_h=(pic_h+dst_c_dec_v-1)/dst_c_dec_v;
+  c_sz=c_w*c_h;
+  /* read and process more video */
+  /* video strategy reads one frame ahead so we know when we're
+     at end of stream and can mark last video frame as such
+     (vorbis audio has to flush one frame past last video frame
+     due to overlap and thus doesn't need this extra work */
+
+  /* have two frame buffers full (if possible) before
+     proceeding.  after first pass and until eos, one will
+     always be full when we get here */
+  for(;frame_state<2 && (frames<endframe || endframe<0);){
+    char c,frame[6];
+    int ret=fread(frame,1,6,video);
+    /* match and skip the frame header */
+    if(ret<6)break;
+    if(memcmp(frame,"FRAME",5)){
+      fprintf(stderr,"Loss of framing in YUV input data\n");
+      exit(1);
+    }
+    if(frame[5]!='\n'){
+      int j;
+      for(j=0;j<79;j++)
+        if(fread(&c,1,1,video)&&c=='\n')break;
+      if(j==79){
+        fprintf(stderr,"Error parsing YUV frame header\n");
+        exit(1);
+      }
+    }
+    /*Read the frame data that needs no conversion.*/
+    if(fread(yuvframe[frame_state],1,y4m_dst_buf_read_sz,video)!=
+     y4m_dst_buf_read_sz){
+      fprintf(stderr,"Error reading YUV frame data.\n");
+      exit(1);
+    }
+    /*Read the frame data that does need conversion.*/
+    if(fread(yuvframe[2],1,y4m_aux_buf_read_sz,video)!=y4m_aux_buf_read_sz){
+      fprintf(stderr,"Error reading YUV frame data.\n");
+      exit(1);
+    }
+    /*Now convert the just read frame.*/
+    (*y4m_convert)(yuvframe[frame_state],yuvframe[2]);
+    frames++;
+    if(frames>=beginframe)
+    frame_state++;
+  }
+  /* check to see if there are dupes to flush */
+  if(th_encode_packetout(td,frame_state<1,op)>0)return 1;
+  if(frame_state<1){
+    /* can't get here unless YUV4MPEG stream has no video */
+    fprintf(stderr,"Video input contains no frames.\n");
+    exit(1);
+  }
+  /* Theora is a one-frame-in,one-frame-out system; submit a frame
+     for compression and pull out the packet */
+  /* in two-pass mode's second pass, we need to submit first-pass data */
+  if(passno==2){
+    for(;;){
+      static unsigned char buffer[80];
+      static int buf_pos;
+      int bytes;
+      /*Ask the encoder how many bytes it would like.*/
+      bytes=th_encode_ctl(td,TH_ENCCTL_2PASS_IN,NULL,0);
+      if(bytes<0){
+        fprintf(stderr,"Error submitting pass data in second pass.\n");
+        exit(1);
+      }
+      /*If it's got enough, stop.*/
+      if(bytes==0)break;
+      /*Read in some more bytes, if necessary.*/
+      if(bytes>80-buf_pos)bytes=80-buf_pos;
+      if(bytes>0&&fread(buffer+buf_pos,1,bytes,twopass_file)<bytes){
+        fprintf(stderr,"Could not read frame data from two-pass data file!\n");
+        exit(1);
+      }
+      /*And pass them off.*/
+      ret=th_encode_ctl(td,TH_ENCCTL_2PASS_IN,buffer,bytes);
+      if(ret<0){
+        fprintf(stderr,"Error submitting pass data in second pass.\n");
+        exit(1);
+      }
+      /*If the encoder consumed the whole buffer, reset it.*/
+      if(ret>=bytes)buf_pos=0;
+      /*Otherwise remember how much it used.*/
+      else buf_pos+=ret;
+    }
+  }
+  /*We submit the buffer to the library as if it were padded, but we do not
+     actually allocate space for the padding.
+    This is okay, because with the 1.0 API the library will never read data from the padded
+     region.*/
+  ycbcr[0].width=frame_w;
+  ycbcr[0].height=frame_h;
+  ycbcr[0].stride=pic_w;
+  ycbcr[0].data=yuvframe[0]-pic_x-pic_y*pic_w;
+  ycbcr[1].width=frame_c_w;
+  ycbcr[1].height=frame_c_h;
+  ycbcr[1].stride=c_w;
+  ycbcr[1].data=yuvframe[0]+pic_sz-(pic_x/dst_c_dec_h)-(pic_y/dst_c_dec_v)*c_w;
+  ycbcr[2].width=frame_c_w;
+  ycbcr[2].height=frame_c_h;
+  ycbcr[2].stride=c_w;
+  ycbcr[2].data=ycbcr[1].data+c_sz;
+  th_encode_ycbcr_in(td,ycbcr);
+  {
+    unsigned char *temp=yuvframe[0];
+    yuvframe[0]=yuvframe[1];
+    yuvframe[1]=temp;
+    frame_state--;
+  }
+  /* in two-pass mode's first pass we need to extract and save the pass data */
+  if(passno==1){
+    unsigned char *buffer;
+    int bytes = th_encode_ctl(td, TH_ENCCTL_2PASS_OUT, &buffer, sizeof(buffer));
+    if(bytes<0){
+      fprintf(stderr,"Could not read two-pass data from encoder.\n");
+      exit(1);
+    }
+    if(fwrite(buffer,1,bytes,twopass_file)<bytes){
+      fprintf(stderr,"Unable to write to two-pass data file.\n");
+      exit(1);
+    }
+    fflush(twopass_file);
+  }
+  /* if there was only one frame, it's the last in the stream */
+  ret = th_encode_packetout(td,frame_state<1,op);
+  if(passno==1 && frame_state<1){
+    /* need to read the final (summary) packet */
+    unsigned char *buffer;
+    int bytes = th_encode_ctl(td, TH_ENCCTL_2PASS_OUT, &buffer, sizeof(buffer));
+    if(bytes<0){
+      fprintf(stderr,"Could not read two-pass summary data from encoder.\n");
+      exit(1);
+    }
+    if(fseek(twopass_file,0,SEEK_SET)<0){
+      fprintf(stderr,"Unable to seek in two-pass data file.\n");
+      exit(1);
+    }
+    if(fwrite(buffer,1,bytes,twopass_file)<bytes){
+      fprintf(stderr,"Unable to write to two-pass data file.\n");
+      exit(1);
+    }
+    fflush(twopass_file);
+  }
+  return ret;
+}
+
+
+int fetch_and_process_video(FILE *video,ogg_page *videopage,
+ ogg_stream_state *to,th_enc_ctx *td,FILE *twopass_file,int passno,
+ int videoflag){
+  ogg_packet op;
+  int ret;
+  /* is there a video page flushed?  If not, work until there is. */
+  while(!videoflag){
+    if(ogg_stream_pageout(to,videopage)>0) return 1;
+    if(ogg_stream_eos(to)) return 0;
+    ret=fetch_and_process_video_packet(video,twopass_file,passno,td,&op);
+    if(ret<=0)return 0;
+    ogg_stream_packetin(to,&op);
+  }
+  return videoflag;
+}
+
+static int ilog(unsigned _v){
+  int ret;
+  for(ret=0;_v;ret++)_v>>=1;
+  return ret;
+}
+
+int main(int argc,char *argv[]){
+  int c,long_option_index,ret;
+
+  ogg_stream_state to; /* take physical pages, weld into a logical
+                           stream of packets */
+  ogg_stream_state vo; /* take physical pages, weld into a logical
+                           stream of packets */
+  ogg_page         og; /* one Ogg bitstream page.  Vorbis packets are inside */
+  ogg_packet       op; /* one raw packet of data for decode */
+
+  th_enc_ctx      *td;
+  th_info          ti;
+  th_comment       tc;
+
+  vorbis_info      vi; /* struct that stores all the static vorbis bitstream
+                          settings */
+  vorbis_comment   vc; /* struct that stores all the user comments */
+
+  vorbis_dsp_state vd; /* central working state for the packet->PCM decoder */
+  vorbis_block     vb; /* local working space for packet->PCM decode */
+
+  int speed=-1;
+  int audioflag=0;
+  int videoflag=0;
+  int akbps=0;
+  int vkbps=0;
+  int soft_target=0;
+
+  ogg_int64_t audio_bytesout=0;
+  ogg_int64_t video_bytesout=0;
+  double timebase;
+
+  FILE *outfile = stdout;
+
+  FILE *twopass_file = NULL;
+  fpos_t video_rewind_pos;
+  int twopass=0;
+  int passno;
+
+#ifdef _WIN32 /* We need to set stdin/stdout to binary mode. Damn windows. */
+  /* if we were reading/writing a file, it would also need to in
+     binary mode, eg, fopen("file.wav","wb"); */
+  /* Beware the evil ifdef. We avoid these where we can, but this one we
+     cannot. Don't add any more, you'll probably go to hell if you do. */
+  _setmode( _fileno( stdin ), _O_BINARY );
+  _setmode( _fileno( stdout ), _O_BINARY );
+#endif
+
+  while((c=getopt_long(argc,argv,optstring,options,&long_option_index))!=EOF){
+    switch(c){
+    case 'o':
+      outfile=fopen(optarg,"wb");
+      if(outfile==NULL){
+        fprintf(stderr,"Unable to open output file '%s'\n", optarg);
+        exit(1);
+      }
+      break;;
+
+    case 'a':
+      audio_q=(float)(atof(optarg)*.099);
+      if(audio_q<-.1 || audio_q>1){
+        fprintf(stderr,"Illegal audio quality (choose -1 through 10)\n");
+        exit(1);
+      }
+      audio_r=-1;
+      break;
+
+    case 'v':
+      video_q=(int)rint(6.3*atof(optarg));
+      if(video_q<0 || video_q>63){
+        fprintf(stderr,"Illegal video quality (choose 0 through 10)\n");
+        exit(1);
+      }
+      break;
+
+    case 'A':
+      audio_r=(int)(atof(optarg)*1000);
+      if(audio_q<0){
+        fprintf(stderr,"Illegal audio quality (choose > 0 please)\n");
+        exit(1);
+      }
+      audio_q=-99;
+      break;
+
+    case 'V':
+      video_r=(int)rint(atof(optarg)*1000);
+      if(video_r<1){
+        fprintf(stderr,"Illegal video bitrate (choose > 0 please)\n");
+        exit(1);
+      }
+     break;
+
+    case '\1':
+      soft_target=1;
+      break;
+
+    case 's':
+      video_par_n=(int)rint(atof(optarg));
+      break;
+
+    case 'S':
+      video_par_d=(int)rint(atof(optarg));
+      break;
+
+    case 'f':
+      video_fps_n=(int)rint(atof(optarg));
+      break;
+
+    case 'F':
+      video_fps_d=(int)rint(atof(optarg));
+      break;
+
+    case 'c':
+      vp3_compatible=1;
+      break;
+
+    case 'k':
+      keyframe_frequency=rint(atof(optarg));
+      if(keyframe_frequency<1 || keyframe_frequency>2147483647){
+        fprintf(stderr,"Illegal keyframe frequency\n");
+        exit(1);
+      }
+      break;
+
+    case 'd':
+      buf_delay=atoi(optarg);
+      if(buf_delay<=0){
+        fprintf(stderr,"Illegal buffer delay\n");
+        exit(1);
+      }
+      break;
+
+    case 'z':
+      speed=atoi(optarg);
+      if(speed<0){
+        fprintf(stderr,"Illegal speed level\n");
+        exit(1);
+      }
+      break;
+
+    case 'b':
+      {
+        char *pos=strchr(optarg,':');
+        begin_sec=atol(optarg);
+        if(pos){
+          char *pos2=strchr(++pos,':');
+          begin_sec*=60;
+          begin_sec+=atol(pos);
+          if(pos2){
+            pos2++;
+            begin_sec*=60;
+            begin_sec+=atol(pos2);
+            pos=pos2;
+          }
+        }else
+          pos=optarg;
+        pos=strchr(pos,'.');
+        if(pos){
+          int digits = strlen(++pos);
+          begin_usec=atol(pos);
+          while(digits++ < 6)
+            begin_usec*=10;
+        }
+      }
+      break;
+    case 'e':
+      {
+        char *pos=strchr(optarg,':');
+        end_sec=atol(optarg);
+        if(pos){
+          char *pos2=strchr(++pos,':');
+          end_sec*=60;
+          end_sec+=atol(pos);
+          if(pos2){
+            pos2++;
+            end_sec*=60;
+            end_sec+=atol(pos2);
+            pos=pos2;
+          }
+        }else
+          pos=optarg;
+        pos=strchr(pos,'.');
+        if(pos){
+          int digits = strlen(++pos);
+          end_usec=atol(pos);
+          while(digits++ < 6)
+            end_usec*=10;
+        }
+      }
+      break;
+    case '\2':
+      twopass=3; /* perform both passes */
+      twopass_file=tmpfile();
+      if(!twopass_file){
+        fprintf(stderr,"Unable to open temporary file for twopass data\n");
+        exit(1);
+      }
+      break;
+    case '\3':
+      twopass=1; /* perform first pass */
+      twopass_file=fopen(optarg,"wb");
+      if(!twopass_file){
+        fprintf(stderr,"Unable to open \'%s\' for twopass data\n",optarg);
+        exit(1);
+      }
+      break;
+    case '\4':
+      twopass=2; /* perform second pass */
+      twopass_file=fopen(optarg,"rb");
+      if(!twopass_file){
+        fprintf(stderr,"Unable to open twopass data file \'%s\'",optarg);
+        exit(1);
+      }
+      break;
+
+    default:
+      usage();
+    }
+  }
+
+  if(soft_target){
+    if(video_r<=0){
+      fprintf(stderr,"Soft rate target (--soft-target) requested without a bitrate (-V).\n");
+      exit(1);
+    }
+    if(video_q==-1)
+      video_q=0;
+  }else{
+    if(video_q==-1){
+      if(video_r>0)
+        video_q=0;
+      else
+        video_q=48;
+    }
+  }
+
+  if(keyframe_frequency<=0){
+    /*Use a default keyframe frequency of 64 for 1-pass (streaming) mode, and
+       256 for two-pass mode.*/
+    keyframe_frequency=twopass?256:64;
+  }
+
+  while(optind<argc){
+    /* assume that anything following the options must be a filename */
+    id_file(argv[optind]);
+    optind++;
+  }
+
+  if(twopass==3){
+    /* verify that the input is seekable! */
+    if(video){
+      if(fseek(video,0,SEEK_CUR)){
+        fprintf(stderr,"--two-pass (automatic two-pass) requires the video input\n"
+                "to be seekable.  For non-seekable input, encoder_example\n"
+                "must be run twice, first with the --first-pass option, then\n"
+                "with the --second-pass option.\n\n");
+        exit(1);
+      }
+      if(fgetpos(video,&video_rewind_pos)<0){
+        fprintf(stderr,"Unable to determine start position of video data.\n");
+        exit(1);
+      }
+    }
+  }
+
+  /* Set up Ogg output stream */
+  srand(time(NULL));
+  ogg_stream_init(&to,rand()); /* oops, add one ot the above */
+
+  /* initialize Vorbis assuming we have audio to compress. */
+  if(audio && twopass!=1){
+    ogg_stream_init(&vo,rand());
+    vorbis_info_init(&vi);
+    if(audio_q>-99)
+      ret = vorbis_encode_init_vbr(&vi,audio_ch,audio_hz,audio_q);
+    else
+      ret = vorbis_encode_init(&vi,audio_ch,audio_hz,-1,
+                               (int)(64870*(ogg_int64_t)audio_r>>16),-1);
+    if(ret){
+      fprintf(stderr,"The Vorbis encoder could not set up a mode according to\n"
+              "the requested quality or bitrate.\n\n");
+      exit(1);
+    }
+
+    vorbis_comment_init(&vc);
+    vorbis_analysis_init(&vd,&vi);
+    vorbis_block_init(&vd,&vb);
+  }
+
+  for(passno=(twopass==3?1:twopass);passno<=(twopass==3?2:twopass);passno++){
+    /* Set up Theora encoder */
+    if(!video){
+      fprintf(stderr,"No video files submitted for compression?\n");
+      exit(1);
+    }
+    /* Theora has a divisible-by-sixteen restriction for the encoded frame size */
+    /* scale the picture size up to the nearest /16 and calculate offsets */
+    frame_w=pic_w+15&~0xF;
+    frame_h=pic_h+15&~0xF;
+    /*Force the offsets to be even so that chroma samples line up like we
+       expect.*/
+    pic_x=frame_w-pic_w>>1&~1;
+    pic_y=frame_h-pic_h>>1&~1;
+    th_info_init(&ti);
+    ti.frame_width=frame_w;
+    ti.frame_height=frame_h;
+    ti.pic_width=pic_w;
+    ti.pic_height=pic_h;
+    ti.pic_x=pic_x;
+    ti.pic_y=pic_y;
+    ti.fps_numerator=video_fps_n;
+    ti.fps_denominator=video_fps_d;
+    ti.aspect_numerator=video_par_n;
+    ti.aspect_denominator=video_par_d;
+    ti.colorspace=TH_CS_UNSPECIFIED;
+    /*Account for the Ogg page overhead.
+      This is 1 byte per 255 for lacing values, plus 26 bytes per 4096 bytes for
+       the page header, plus approximately 1/2 byte per packet (not accounted for
+       here).*/
+    ti.target_bitrate=(int)(64870*(ogg_int64_t)video_r>>16);
+    ti.quality=video_q;
+    ti.keyframe_granule_shift=ilog(keyframe_frequency-1);
+    if(dst_c_dec_h==2){
+      if(dst_c_dec_v==2)ti.pixel_fmt=TH_PF_420;
+      else ti.pixel_fmt=TH_PF_422;
+    }
+    else ti.pixel_fmt=TH_PF_444;
+    td=th_encode_alloc(&ti);
+    th_info_clear(&ti);
+    /* setting just the granule shift only allows power-of-two keyframe
+       spacing.  Set the actual requested spacing. */
+    ret=th_encode_ctl(td,TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE,
+     &keyframe_frequency,sizeof(keyframe_frequency-1));
+    if(ret<0){
+      fprintf(stderr,"Could not set keyframe interval to %d.\n",(int)keyframe_frequency);
+    }
+    if(vp3_compatible){
+      ret=th_encode_ctl(td,TH_ENCCTL_SET_VP3_COMPATIBLE,&vp3_compatible,
+       sizeof(vp3_compatible));
+      if(ret<0||!vp3_compatible){
+        fprintf(stderr,"Could not enable strict VP3 compatibility.\n");
+        if(ret>=0){
+          fprintf(stderr,"Ensure your source format is supported by VP3.\n");
+          fprintf(stderr,
+           "(4:2:0 pixel format, width and height multiples of 16).\n");
+        }
+      }
+    }
+    if(soft_target){
+      /* reverse the rate control flags to favor a 'long time' strategy */
+      int arg = TH_RATECTL_CAP_UNDERFLOW;
+      ret=th_encode_ctl(td,TH_ENCCTL_SET_RATE_FLAGS,&arg,sizeof(arg));
+      if(ret<0)
+        fprintf(stderr,"Could not set encoder flags for --soft-target\n");
+      /* Default buffer control is overridden on two-pass */
+      if(!twopass&&buf_delay<0){
+        if((keyframe_frequency*7>>1) > 5*video_fps_n/video_fps_d)
+          arg=keyframe_frequency*7>>1;
+        else
+          arg=5*video_fps_n/video_fps_d;
+        ret=th_encode_ctl(td,TH_ENCCTL_SET_RATE_BUFFER,&arg,sizeof(arg));
+        if(ret<0)
+          fprintf(stderr,"Could not set rate control buffer for --soft-target\n");
+      }
+    }
+    /* set up two-pass if needed */
+    if(passno==1){
+      unsigned char *buffer;
+      int bytes;
+      bytes=th_encode_ctl(td,TH_ENCCTL_2PASS_OUT,&buffer,sizeof(buffer));
+      if(bytes<0){
+        fprintf(stderr,"Could not set up the first pass of two-pass mode.\n");
+        fprintf(stderr,"Did you remember to specify an estimated bitrate?\n");
+        exit(1);
+      }
+      /*Perform a seek test to ensure we can overwrite this placeholder data at
+         the end; this is better than letting the user sit through a whole
+         encode only to find out their pass 1 file is useless at the end.*/
+      if(fseek(twopass_file,0,SEEK_SET)<0){
+        fprintf(stderr,"Unable to seek in two-pass data file.\n");
+        exit(1);
+      }
+      if(fwrite(buffer,1,bytes,twopass_file)<bytes){
+        fprintf(stderr,"Unable to write to two-pass data file.\n");
+        exit(1);
+      }
+      fflush(twopass_file);
+    }
+    if(passno==2){
+      /*Enable the second pass here.
+        We make this call just to set the encoder into 2-pass mode, because
+         by default enabling two-pass sets the buffer delay to the whole file
+         (because there's no way to explicitly request that behavior).
+        If we waited until we were actually encoding, it would overwite our
+         settings.*/
+      if(th_encode_ctl(td,TH_ENCCTL_2PASS_IN,NULL,0)<0){
+        fprintf(stderr,"Could not set up the second pass of two-pass mode.\n");
+        exit(1);
+      }
+      if(twopass==3){
+        /* 'automatic' second pass */
+        if(fsetpos(video,&video_rewind_pos)<0){
+          fprintf(stderr,"Could not rewind video input file for second pass!\n");
+          exit(1);
+        }
+        if(fseek(twopass_file,0,SEEK_SET)<0){
+          fprintf(stderr,"Unable to seek in two-pass data file.\n");
+          exit(1);
+        }
+        frame_state=0;
+        frames=0;
+      }
+    }
+    /*Now we can set the buffer delay if the user requested a non-default one
+       (this has to be done after two-pass is enabled).*/
+    if(passno!=1&&buf_delay>=0){
+      ret=th_encode_ctl(td,TH_ENCCTL_SET_RATE_BUFFER,
+       &buf_delay,sizeof(buf_delay));
+      if(ret<0){
+        fprintf(stderr,"Warning: could not set desired buffer delay.\n");
+      }
+    }
+    /*Speed should also be set after the current encoder mode is established,
+       since the available speed levels may change depending.*/
+    if(speed>=0){
+      int speed_max;
+      int ret;
+      ret=th_encode_ctl(td,TH_ENCCTL_GET_SPLEVEL_MAX,
+       &speed_max,sizeof(speed_max));
+      if(ret<0){
+        fprintf(stderr,"Warning: could not determine maximum speed level.\n");
+        speed_max=0;
+      }
+      ret=th_encode_ctl(td,TH_ENCCTL_SET_SPLEVEL,&speed,sizeof(speed));
+      if(ret<0){
+        fprintf(stderr,"Warning: could not set speed level to %i of %i\n",
+         speed,speed_max);
+        if(speed>speed_max){
+          fprintf(stderr,"Setting it to %i instead\n",speed_max);
+        }
+        ret=th_encode_ctl(td,TH_ENCCTL_SET_SPLEVEL,
+         &speed_max,sizeof(speed_max));
+        if(ret<0){
+          fprintf(stderr,"Warning: could not set speed level to %i of %i\n",
+           speed_max,speed_max);
+        }
+      }
+    }
+    /* write the bitstream header packets with proper page interleave */
+    th_comment_init(&tc);
+    /* first packet will get its own page automatically */
+    if(th_encode_flushheader(td,&tc,&op)<=0){
+      fprintf(stderr,"Internal Theora library error.\n");
+      exit(1);
+    }
+    if(passno!=1){
+      ogg_stream_packetin(&to,&op);
+      if(ogg_stream_pageout(&to,&og)!=1){
+        fprintf(stderr,"Internal Ogg library error.\n");
+        exit(1);
+      }
+      fwrite(og.header,1,og.header_len,outfile);
+      fwrite(og.body,1,og.body_len,outfile);
+    }
+    /* create the remaining theora headers */
+    for(;;){
+      ret=th_encode_flushheader(td,&tc,&op);
+      if(ret<0){
+        fprintf(stderr,"Internal Theora library error.\n");
+        exit(1);
+      }
+      else if(!ret)break;
+      if(passno!=1)ogg_stream_packetin(&to,&op);
+    }
+    if(audio && passno!=1){
+      ogg_packet header;
+      ogg_packet header_comm;
+      ogg_packet header_code;
+      vorbis_analysis_headerout(&vd,&vc,&header,&header_comm,&header_code);
+      ogg_stream_packetin(&vo,&header); /* automatically placed in its own
+                                           page */
+      if(ogg_stream_pageout(&vo,&og)!=1){
+        fprintf(stderr,"Internal Ogg library error.\n");
+        exit(1);
+      }
+      fwrite(og.header,1,og.header_len,outfile);
+      fwrite(og.body,1,og.body_len,outfile);
+      /* remaining vorbis header packets */
+      ogg_stream_packetin(&vo,&header_comm);
+      ogg_stream_packetin(&vo,&header_code);
+    }
+    /* Flush the rest of our headers. This ensures
+       the actual data in each stream will start
+       on a new page, as per spec. */
+    if(passno!=1){
+      for(;;){
+        int result = ogg_stream_flush(&to,&og);
+        if(result<0){
+          /* can't get here */
+          fprintf(stderr,"Internal Ogg library error.\n");
+          exit(1);
+        }
+        if(result==0)break;
+        fwrite(og.header,1,og.header_len,outfile);
+        fwrite(og.body,1,og.body_len,outfile);
+      }
+    }
+    if(audio && passno!=1){
+      for(;;){
+        int result=ogg_stream_flush(&vo,&og);
+        if(result<0){
+          /* can't get here */
+          fprintf(stderr,"Internal Ogg library error.\n");
+          exit(1);
+        }
+        if(result==0)break;
+        fwrite(og.header,1,og.header_len,outfile);
+        fwrite(og.body,1,og.body_len,outfile);
+      }
+    }
+    /* setup complete.  Raw processing loop */
+      switch(passno){
+      case 0: case 2:
+        fprintf(stderr,"\rCompressing....                                          \n");
+        break;
+      case 1:
+        fprintf(stderr,"\rScanning first pass....                                  \n");
+        break;
+      }
+    for(;;){
+      int audio_or_video=-1;
+      if(passno==1){
+        ogg_packet op;
+        int ret=fetch_and_process_video_packet(video,twopass_file,passno,td,&op);
+        if(ret<0)break;
+        if(op.e_o_s)break; /* end of stream */
+        timebase=th_granule_time(td,op.granulepos);
+        audio_or_video=1;
+      }else{
+        double audiotime;
+        double videotime;
+        ogg_page audiopage;
+        ogg_page videopage;
+        /* is there an audio page flushed?  If not, fetch one if possible */
+        audioflag=fetch_and_process_audio(audio,&audiopage,&vo,&vd,&vb,audioflag);
+        /* is there a video page flushed?  If not, fetch one if possible */
+        videoflag=fetch_and_process_video(video,&videopage,&to,td,twopass_file,passno,videoflag);
+        /* no pages of either?  Must be end of stream. */
+        if(!audioflag && !videoflag)break;
+        /* which is earlier; the end of the audio page or the end of the
+           video page? Flush the earlier to stream */
+        audiotime=
+        audioflag?vorbis_granule_time(&vd,ogg_page_granulepos(&audiopage)):-1;
+        videotime=
+        videoflag?th_granule_time(td,ogg_page_granulepos(&videopage)):-1;
+        if(!audioflag){
+          audio_or_video=1;
+        } else if(!videoflag) {
+          audio_or_video=0;
+        } else {
+          if(audiotime<videotime)
+            audio_or_video=0;
+          else
+            audio_or_video=1;
+        }
+        if(audio_or_video==1){
+          /* flush a video page */
+          video_bytesout+=fwrite(videopage.header,1,videopage.header_len,outfile);
+          video_bytesout+=fwrite(videopage.body,1,videopage.body_len,outfile);
+          videoflag=0;
+          timebase=videotime;
+        }else{
+          /* flush an audio page */
+          audio_bytesout+=fwrite(audiopage.header,1,audiopage.header_len,outfile);
+          audio_bytesout+=fwrite(audiopage.body,1,audiopage.body_len,outfile);
+          audioflag=0;
+          timebase=audiotime;
+        }
+      }
+      if(timebase > 0){
+        int hundredths=(int)(timebase*100-(long)timebase*100);
+        int seconds=(long)timebase%60;
+        int minutes=((long)timebase/60)%60;
+        int hours=(long)timebase/3600;
+        if(audio_or_video)vkbps=(int)rint(video_bytesout*8./timebase*.001);
+        else akbps=(int)rint(audio_bytesout*8./timebase*.001);
+        fprintf(stderr,
+                "\r      %d:%02d:%02d.%02d audio: %dkbps video: %dkbps                 ",
+                hours,minutes,seconds,hundredths,akbps,vkbps);
+      }
+    }
+    if(video)th_encode_free(td);
+  }
+
+  /* clear out state */
+  if(audio && twopass!=1){
+    ogg_stream_clear(&vo);
+    vorbis_block_clear(&vb);
+    vorbis_dsp_clear(&vd);
+    vorbis_comment_clear(&vc);
+    vorbis_info_clear(&vi);
+    if(audio!=stdin)fclose(audio);
+  }
+  if(video){
+    ogg_stream_clear(&to);
+    th_comment_clear(&tc);
+    if(video!=stdin)fclose(video);
+  }
+
+  if(outfile && outfile!=stdout)fclose(outfile);
+  if(twopass_file)fclose(twopass_file);
+
+  fprintf(stderr,"\r   \ndone.\n\n");
+
+  return(0);
+
+}
diff --git a/examples/player_example.c b/examples/player_example.c
new file mode 100644 (file)
index 0000000..dcc02bc
--- /dev/null
@@ -0,0 +1,857 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function: example SDL player application; plays Ogg Theora files (with
+            optional Vorbis audio second stream)
+  last mod: $Id: player_example.c 16551 2009-09-09 17:53:13Z gmaxwell $
+
+ ********************************************************************/
+
+/* far more complex than most Ogg 'example' programs.  The complexity
+   of maintaining A/V sync is pretty much unavoidable.  It's necessary
+   to actually have audio/video playback to make the hard audio clock
+   sync actually work.  If there's audio playback, there might as well
+   be simple video playback as well...
+
+   A simple 'demux and write back streams' would have been easier,
+   it's true. */
+
+#if !defined(_GNU_SOURCE)
+#define _GNU_SOURCE
+#endif
+#if !defined(_LARGEFILE_SOURCE)
+#define _LARGEFILE_SOURCE
+#endif
+#if !defined(_LARGEFILE64_SOURCE)
+#define _LARGEFILE64_SOURCE
+#endif
+#if !defined(_FILE_OFFSET_BITS)
+#define _FILE_OFFSET_BITS 64
+#endif
+
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
+#ifndef _REENTRANT
+# define _REENTRANT
+#endif
+
+#include <stdio.h>
+#include <unistd.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/time.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <math.h>
+#include <signal.h>
+#include "theora/theoradec.h"
+#include "vorbis/codec.h"
+#include <SDL.h>
+
+/* yes, this makes us OSS-specific for now. None of SDL, libao, libao2
+   give us any way to determine hardware timing, and since the
+   hard/kernel buffer is going to be most of or > a second, that's
+   just a little bit important */
+#if defined(__FreeBSD__)
+#include <machine/soundcard.h>
+#define AUDIO_DEVICE "/dev/audio"
+#elif defined(__NetBSD__) || defined(__OpenBSD__)
+#include <soundcard.h>
+#define AUDIO_DEVICE "/dev/audio"
+#else
+#include <sys/soundcard.h>
+#define AUDIO_DEVICE "/dev/dsp"
+#endif
+#include <sys/ioctl.h>
+
+/* Helper; just grab some more compressed bitstream and sync it for
+   page extraction */
+int buffer_data(FILE *in,ogg_sync_state *oy){
+  char *buffer=ogg_sync_buffer(oy,4096);
+  int bytes=fread(buffer,1,4096,in);
+  ogg_sync_wrote(oy,bytes);
+  return(bytes);
+}
+
+/* never forget that globals are a one-way ticket to Hell */
+/* Ogg and codec state for demux/decode */
+ogg_sync_state   oy;
+ogg_page         og;
+ogg_stream_state vo;
+ogg_stream_state to;
+th_info      ti;
+th_comment   tc;
+th_dec_ctx       *td;
+th_setup_info    *ts;
+vorbis_info      vi;
+vorbis_dsp_state vd;
+vorbis_block     vb;
+vorbis_comment   vc;
+th_pixel_fmt     px_fmt;
+
+int              theora_p=0;
+int              vorbis_p=0;
+int              stateflag=0;
+
+/* SDL Video playback structures */
+SDL_Surface *screen;
+SDL_Overlay *yuv_overlay;
+SDL_Rect rect;
+
+/* single frame video buffering */
+int          videobuf_ready=0;
+ogg_int64_t  videobuf_granulepos=-1;
+double       videobuf_time=0;
+
+/* single audio fragment audio buffering */
+int          audiobuf_fill=0;
+int          audiobuf_ready=0;
+ogg_int16_t *audiobuf;
+ogg_int64_t  audiobuf_granulepos=0; /* time position of last sample */
+
+/* audio / video synchronization tracking:
+
+Since this will make it to Google at some point and lots of people
+search for how to do this, a quick rundown of a practical A/V sync
+strategy under Linux [the UNIX where Everything Is Hard].  Naturally,
+this works on other platforms using OSS for sound as well.
+
+In OSS, we don't have reliable access to any precise information on
+the exact current playback position (that, of course would have been
+too easy; the kernel folks like to keep us app people working hard
+doing simple things that should have been solved once and abstracted
+long ago).  Hopefully ALSA solves this a little better; we'll probably
+use that once ALSA is the standard in the stable kernel.
+
+We can't use the system clock for a/v sync because audio is hard
+synced to its own clock, and both the system and audio clocks suffer
+from wobble, drift, and a lack of accuracy that can be guaranteed to
+add a reliable percent or so of error.  After ten seconds, that's
+100ms.  We can't drift by half a second every minute.
+
+Although OSS can't generally tell us where the audio playback pointer
+is, we do know that if we work in complete audio fragments and keep
+the kernel buffer full, a blocking select on the audio buffer will
+give us a writable fragment immediately after playback finishes with
+it.  We assume at that point that we know the exact number of bytes in
+the kernel buffer that have not been played (total fragments minus
+one) and calculate clock drift between audio and system then (and only
+then).  Damp the sync correction fraction, apply, and walla: A
+reliable A/V clock that even works if it's interrupted. */
+
+long         audiofd_totalsize=-1;
+int          audiofd_fragsize;      /* read and write only complete fragments
+                                       so that SNDCTL_DSP_GETOSPACE is
+                                       accurate immediately after a bank
+                                       switch */
+int          audiofd=-1;
+ogg_int64_t  audiofd_timer_calibrate=-1;
+
+static void open_audio(){
+  audio_buf_info info;
+  int format=AFMT_S16_NE; /* host endian */
+  int channels=vi.channels;
+  int rate=vi.rate;
+  int ret;
+
+  audiofd=open(AUDIO_DEVICE,O_RDWR);
+  if(audiofd<0){
+    fprintf(stderr,"Could not open audio device " AUDIO_DEVICE ".\n");
+    exit(1);
+  }
+
+  ret=ioctl(audiofd,SNDCTL_DSP_SETFMT,&format);
+  if(ret){
+    fprintf(stderr,"Could not set 16 bit host-endian playback\n");
+    exit(1);
+  }
+
+  ret=ioctl(audiofd,SNDCTL_DSP_CHANNELS,&channels);
+  if(ret){
+    fprintf(stderr,"Could not set %d channel playback\n",channels);
+    exit(1);
+  }
+
+  ret=ioctl(audiofd,SNDCTL_DSP_SPEED,&rate);
+  if(ret){
+    fprintf(stderr,"Could not set %d Hz playback\n",rate);
+    exit(1);
+  }
+
+  ioctl(audiofd,SNDCTL_DSP_GETOSPACE,&info);
+  audiofd_fragsize=info.fragsize;
+  audiofd_totalsize=info.fragstotal*info.fragsize;
+
+  audiobuf=malloc(audiofd_fragsize);
+}
+
+static void audio_close(void){
+  if(audiofd>-1){
+    ioctl(audiofd,SNDCTL_DSP_RESET,NULL);
+    close(audiofd);
+    free(audiobuf);
+  }
+}
+
+/* call this only immediately after unblocking from a full kernel
+   having a newly empty fragment or at the point of DMA restart */
+void audio_calibrate_timer(int restart){
+  struct timeval tv;
+  ogg_int64_t current_sample;
+  ogg_int64_t new_time;
+
+  gettimeofday(&tv,0);
+  new_time=tv.tv_sec*1000+tv.tv_usec/1000;
+
+  if(restart){
+    current_sample=audiobuf_granulepos-audiobuf_fill/2/vi.channels;
+  }else
+    current_sample=audiobuf_granulepos-
+      (audiobuf_fill+audiofd_totalsize-audiofd_fragsize)/2/vi.channels;
+
+  new_time-=1000*current_sample/vi.rate;
+
+  audiofd_timer_calibrate=new_time;
+}
+
+/* get relative time since beginning playback, compensating for A/V
+   drift */
+double get_time(){
+  static ogg_int64_t last=0;
+  static ogg_int64_t up=0;
+  ogg_int64_t now;
+  struct timeval tv;
+
+  gettimeofday(&tv,0);
+  now=tv.tv_sec*1000+tv.tv_usec/1000;
+
+  if(audiofd_timer_calibrate==-1)audiofd_timer_calibrate=last=now;
+
+  if(audiofd<0){
+    /* no audio timer to worry about, we can just use the system clock */
+    /* only one complication: If the process is suspended, we should
+       reset timing to account for the gap in play time.  Do it the
+       easy/hack way */
+    if(now-last>1000)audiofd_timer_calibrate+=(now-last);
+    last=now;
+  }
+
+  if(now-up>200){
+    double timebase=(now-audiofd_timer_calibrate)*.001;
+    int hundredths=timebase*100-(long)timebase*100;
+    int seconds=(long)timebase%60;
+    int minutes=((long)timebase/60)%60;
+    int hours=(long)timebase/3600;
+
+    fprintf(stderr,"   Playing: %d:%02d:%02d.%02d                       \r",
+            hours,minutes,seconds,hundredths);
+    up=now;
+  }
+
+  return (now-audiofd_timer_calibrate)*.001;
+
+}
+
+/* write a fragment to the OSS kernel audio API, but only if we can
+   stuff in a whole fragment without blocking */
+void audio_write_nonblocking(void){
+
+  if(audiobuf_ready){
+    audio_buf_info info;
+    long bytes;
+
+    ioctl(audiofd,SNDCTL_DSP_GETOSPACE,&info);
+    bytes=info.bytes;
+    if(bytes>=audiofd_fragsize){
+      if(bytes==audiofd_totalsize)audio_calibrate_timer(1);
+
+      while(1){
+        bytes=write(audiofd,audiobuf+(audiofd_fragsize-audiobuf_fill),
+                    audiofd_fragsize);
+
+        if(bytes>0){
+
+          if(bytes!=audiobuf_fill){
+            /* shouldn't actually be possible... but eh */
+            audiobuf_fill-=bytes;
+          }else
+            break;
+        }
+      }
+
+      audiobuf_fill=0;
+      audiobuf_ready=0;
+
+    }
+  }
+}
+
+/* clean quit on Ctrl-C for SDL and thread shutdown as per SDL example
+   (we don't use any threads, but libSDL does) */
+int got_sigint=0;
+static void sigint_handler (int signal) {
+  got_sigint = 1;
+}
+
+static void open_video(void){
+  int w;
+  int h;
+  w=(ti.pic_x+ti.frame_width+1&~1)-(ti.pic_x&~1);
+  h=(ti.pic_y+ti.frame_height+1&~1)-(ti.pic_y&~1);
+  if ( SDL_Init(SDL_INIT_VIDEO) < 0 ) {
+    fprintf(stderr, "Unable to init SDL: %s\n", SDL_GetError());
+    exit(1);
+  }
+
+  screen = SDL_SetVideoMode(w, h, 0, SDL_SWSURFACE);
+  if ( screen == NULL ) {
+    fprintf(stderr, "Unable to set %dx%d video: %s\n",
+            w,h,SDL_GetError());
+    exit(1);
+  }
+
+  if (px_fmt==TH_PF_422)
+    yuv_overlay = SDL_CreateYUVOverlay(w, h,
+                                     SDL_YUY2_OVERLAY,
+                                     screen);
+  else
+    yuv_overlay = SDL_CreateYUVOverlay(w, h,
+                                     SDL_YV12_OVERLAY,
+                                     screen);
+  
+  if ( yuv_overlay == NULL ) {
+    fprintf(stderr, "SDL: Couldn't create SDL_yuv_overlay: %s\n",
+            SDL_GetError());
+    exit(1);
+  }
+  rect.x = 0;
+  rect.y = 0;
+  rect.w = w;
+  rect.h = h;
+
+  SDL_DisplayYUVOverlay(yuv_overlay, &rect);
+}
+
+static void video_write(void){
+  int i;
+  th_ycbcr_buffer yuv;
+  int y_offset, uv_offset;
+  th_decode_ycbcr_out(td,yuv);
+  /* Lock SDL_yuv_overlay */
+  if ( SDL_MUSTLOCK(screen) ) {
+    if ( SDL_LockSurface(screen) < 0 ) return;
+  }
+  if (SDL_LockYUVOverlay(yuv_overlay) < 0) return;
+
+  /* let's draw the data on a SDL screen (*screen) */
+  /* deal with border stride */
+  /* reverse u and v for SDL */
+  /* and crop input properly, respecting the encoded frame rect */
+  /* problems may exist for odd frame rect for some encodings */
+
+  y_offset=(ti.pic_x&~1)+yuv[0].stride*(ti.pic_y&~1);
+
+  if (px_fmt==TH_PF_422) {
+    uv_offset=(ti.pic_x/2)+(yuv[1].stride)*(ti.pic_y);
+    /* SDL doesn't have a planar 4:2:2 */ 
+    for(i=0;i<yuv_overlay->h;i++) {
+      int j;
+      char *in_y  = (char *)yuv[0].data+y_offset+yuv[0].stride*i;
+      char *out = (char *)(yuv_overlay->pixels[0]+yuv_overlay->pitches[0]*i);
+      for (j=0;j<yuv_overlay->w;j++)
+        out[j*2] = in_y[j];
+      char *in_u  = (char *)yuv[1].data+uv_offset+yuv[1].stride*i;
+      char *in_v  = (char *)yuv[2].data+uv_offset+yuv[2].stride*i;
+      for (j=0;j<yuv_overlay->w>>1;j++) {
+        out[j*4+1] = in_u[j];
+        out[j*4+3] = in_v[j];
+      }
+    }
+  } else {
+    uv_offset=(ti.pic_x/2)+(yuv[1].stride)*(ti.pic_y/2);
+    for(i=0;i<yuv_overlay->h;i++)
+      memcpy(yuv_overlay->pixels[0]+yuv_overlay->pitches[0]*i,
+           yuv[0].data+y_offset+yuv[0].stride*i,
+           yuv_overlay->w);
+    for(i=0;i<yuv_overlay->h/2;i++){
+      memcpy(yuv_overlay->pixels[1]+yuv_overlay->pitches[1]*i,
+           yuv[2].data+uv_offset+yuv[2].stride*i,
+           yuv_overlay->w/2);
+      memcpy(yuv_overlay->pixels[2]+yuv_overlay->pitches[2]*i,
+           yuv[1].data+uv_offset+yuv[1].stride*i,
+           yuv_overlay->w/2);
+    }
+  }
+
+  /* Unlock SDL_yuv_overlay */
+  if ( SDL_MUSTLOCK(screen) ) {
+    SDL_UnlockSurface(screen);
+  }
+  SDL_UnlockYUVOverlay(yuv_overlay);
+
+
+  /* Show, baby, show! */
+  SDL_DisplayYUVOverlay(yuv_overlay, &rect);
+
+}
+/* dump the theora (or vorbis) comment header */
+static int dump_comments(th_comment *tc){
+  int i, len;
+  char *value;
+  FILE *out=stdout;
+
+  fprintf(out,"Encoded by %s\n",tc->vendor);
+  if(tc->comments){
+    fprintf(out, "theora comment header:\n");
+    for(i=0;i<tc->comments;i++){
+      if(tc->user_comments[i]){
+        len=tc->comment_lengths[i];
+        value=malloc(len+1);
+        memcpy(value,tc->user_comments[i],len);
+        value[len]='\0';
+        fprintf(out, "\t%s\n", value);
+        free(value);
+      }
+    }
+  }
+  return(0);
+}
+
+/* Report the encoder-specified colorspace for the video, if any.
+   We don't actually make use of the information in this example;
+   a real player should attempt to perform color correction for
+   whatever display device it supports. */
+static void report_colorspace(th_info *ti)
+{
+    switch(ti->colorspace){
+      case TH_CS_UNSPECIFIED:
+        /* nothing to report */
+        break;;
+      case TH_CS_ITU_REC_470M:
+        fprintf(stderr,"  encoder specified ITU Rec 470M (NTSC) color.\n");
+        break;;
+      case TH_CS_ITU_REC_470BG:
+        fprintf(stderr,"  encoder specified ITU Rec 470BG (PAL) color.\n");
+        break;;
+      default:
+        fprintf(stderr,"warning: encoder specified unknown colorspace (%d).\n",
+            ti->colorspace);
+        break;;
+    }
+}
+
+/* helper: push a page into the appropriate steam */
+/* this can be done blindly; a stream won't accept a page
+                that doesn't belong to it */
+static int queue_page(ogg_page *page){
+  if(theora_p)ogg_stream_pagein(&to,page);
+  if(vorbis_p)ogg_stream_pagein(&vo,page);
+  return 0;
+}
+
+static void usage(void){
+  fprintf(stderr,
+          "Usage: player_example <file.ogv>\n"
+          "input is read from stdin if no file is passed on the command line\n"
+          "\n"
+  );
+}
+
+int main(int argc,char *const *argv){
+
+  int pp_level_max;
+  int pp_level;
+  int pp_inc;
+  int i,j;
+  ogg_packet op;
+
+  FILE *infile = stdin;
+
+  int frames = 0;
+  int dropped = 0;
+
+#ifdef _WIN32 /* We need to set stdin/stdout to binary mode. Damn windows. */
+  /* Beware the evil ifdef. We avoid these where we can, but this one we
+     cannot. Don't add any more, you'll probably go to hell if you do. */
+  _setmode( _fileno( stdin ), _O_BINARY );
+#endif
+
+  /* open the input file if any */
+  if(argc==2){
+    infile=fopen(argv[1],"rb");
+    if(infile==NULL){
+      fprintf(stderr,"Unable to open '%s' for playback.\n", argv[1]);
+      exit(1);
+    }
+  }
+  if(argc>2){
+      usage();
+      exit(1);
+  }
+
+  /* start up Ogg stream synchronization layer */
+  ogg_sync_init(&oy);
+
+  /* init supporting Vorbis structures needed in header parsing */
+  vorbis_info_init(&vi);
+  vorbis_comment_init(&vc);
+
+  /* init supporting Theora structures needed in header parsing */
+  th_comment_init(&tc);
+  th_info_init(&ti);
+
+  /* Ogg file open; parse the headers */
+  /* Only interested in Vorbis/Theora streams */
+  while(!stateflag){
+    int ret=buffer_data(infile,&oy);
+    if(ret==0)break;
+    while(ogg_sync_pageout(&oy,&og)>0){
+      ogg_stream_state test;
+
+      /* is this a mandated initial header? If not, stop parsing */
+      if(!ogg_page_bos(&og)){
+        /* don't leak the page; get it into the appropriate stream */
+        queue_page(&og);
+        stateflag=1;
+        break;
+      }
+
+      ogg_stream_init(&test,ogg_page_serialno(&og));
+      ogg_stream_pagein(&test,&og);
+      ogg_stream_packetout(&test,&op);
+
+
+      /* identify the codec: try theora */
+      if(!theora_p && th_decode_headerin(&ti,&tc,&ts,&op)>=0){
+        /* it is theora */
+        memcpy(&to,&test,sizeof(test));
+        theora_p=1;
+      }else if(!vorbis_p && vorbis_synthesis_headerin(&vi,&vc,&op)>=0){
+        /* it is vorbis */
+        memcpy(&vo,&test,sizeof(test));
+        vorbis_p=1;
+      }else{
+        /* whatever it is, we don't care about it */
+        ogg_stream_clear(&test);
+      }
+    }
+    /* fall through to non-bos page parsing */
+  }
+
+  /* we're expecting more header packets. */
+  while((theora_p && theora_p<3) || (vorbis_p && vorbis_p<3)){
+    int ret;
+
+    /* look for further theora headers */
+    while(theora_p && (theora_p<3) && (ret=ogg_stream_packetout(&to,&op))){
+      if(ret<0){
+        fprintf(stderr,"Error parsing Theora stream headers; "
+         "corrupt stream?\n");
+        exit(1);
+      }
+      if(!th_decode_headerin(&ti,&tc,&ts,&op)){
+        fprintf(stderr,"Error parsing Theora stream headers; "
+         "corrupt stream?\n");
+        exit(1);
+      }
+      theora_p++;
+    }
+
+    /* look for more vorbis header packets */
+    while(vorbis_p && (vorbis_p<3) && (ret=ogg_stream_packetout(&vo,&op))){
+      if(ret<0){
+        fprintf(stderr,"Error parsing Vorbis stream headers; corrupt stream?\n");
+        exit(1);
+      }
+      if(vorbis_synthesis_headerin(&vi,&vc,&op)){
+        fprintf(stderr,"Error parsing Vorbis stream headers; corrupt stream?\n");
+        exit(1);
+      }
+      vorbis_p++;
+      if(vorbis_p==3)break;
+    }
+
+    /* The header pages/packets will arrive before anything else we
+       care about, or the stream is not obeying spec */
+
+    if(ogg_sync_pageout(&oy,&og)>0){
+      queue_page(&og); /* demux into the appropriate stream */
+    }else{
+      int ret=buffer_data(infile,&oy); /* someone needs more data */
+      if(ret==0){
+        fprintf(stderr,"End of file while searching for codec headers.\n");
+        exit(1);
+      }
+    }
+  }
+
+  /* and now we have it all.  initialize decoders */
+  if(theora_p){
+    td=th_decode_alloc(&ti,ts);
+    printf("Ogg logical stream %lx is Theora %dx%d %.02f fps",
+           to.serialno,ti.pic_width,ti.pic_height,
+           (double)ti.fps_numerator/ti.fps_denominator);
+    px_fmt=ti.pixel_fmt;
+    switch(ti.pixel_fmt){
+      case TH_PF_420: printf(" 4:2:0 video\n"); break;
+      case TH_PF_422: printf(" 4:2:2 video\n"); break;
+      case TH_PF_444: printf(" 4:4:4 video\n"); break;
+      case TH_PF_RSVD:
+      default:
+       printf(" video\n  (UNKNOWN Chroma sampling!)\n");
+       break;
+    }
+    if(ti.pic_width!=ti.frame_width || ti.pic_height!=ti.frame_height)
+      printf("  Frame content is %dx%d with offset (%d,%d).\n",
+           ti.frame_width, ti.frame_height, ti.pic_x, ti.pic_y);
+    report_colorspace(&ti);
+    dump_comments(&tc);
+    th_decode_ctl(td,TH_DECCTL_GET_PPLEVEL_MAX,&pp_level_max,
+     sizeof(pp_level_max));
+    pp_level=pp_level_max;
+    th_decode_ctl(td,TH_DECCTL_SET_PPLEVEL,&pp_level,sizeof(pp_level));
+    pp_inc=0;
+
+    /*{
+      int arg = 0xffff;
+      th_decode_ctl(td,TH_DECCTL_SET_TELEMETRY_MBMODE,&arg,sizeof(arg));
+      th_decode_ctl(td,TH_DECCTL_SET_TELEMETRY_MV,&arg,sizeof(arg));
+      th_decode_ctl(td,TH_DECCTL_SET_TELEMETRY_QI,&arg,sizeof(arg));
+      arg=10;
+      th_decode_ctl(td,TH_DECCTL_SET_TELEMETRY_BITS,&arg,sizeof(arg));
+    }*/
+  }else{
+    /* tear down the partial theora setup */
+    th_info_clear(&ti);
+    th_comment_clear(&tc);
+  }
+  
+  th_setup_free(ts);
+  
+  if(vorbis_p){
+    vorbis_synthesis_init(&vd,&vi);
+    vorbis_block_init(&vd,&vb);
+    fprintf(stderr,"Ogg logical stream %lx is Vorbis %d channel %ld Hz audio.\n",
+            vo.serialno,vi.channels,vi.rate);
+  }else{
+    /* tear down the partial vorbis setup */
+    vorbis_info_clear(&vi);
+    vorbis_comment_clear(&vc);
+  }
+
+  /* open audio */
+  if(vorbis_p)open_audio();
+
+  /* open video */
+  if(theora_p)open_video();
+
+  /* install signal handler as SDL clobbered the default */
+  signal (SIGINT, sigint_handler);
+
+  /* on to the main decode loop.  We assume in this example that audio
+     and video start roughly together, and don't begin playback until
+     we have a start frame for both.  This is not necessarily a valid
+     assumption in Ogg A/V streams! It will always be true of the
+     example_encoder (and most streams) though. */
+
+  stateflag=0; /* playback has not begun */
+  while(!got_sigint){
+
+    /* we want a video and audio frame ready to go at all times.  If
+       we have to buffer incoming, buffer the compressed data (ie, let
+       ogg do the buffering) */
+    while(vorbis_p && !audiobuf_ready){
+      int ret;
+      float **pcm;
+
+      /* if there's pending, decoded audio, grab it */
+      if((ret=vorbis_synthesis_pcmout(&vd,&pcm))>0){
+        int count=audiobuf_fill/2;
+        int maxsamples=(audiofd_fragsize-audiobuf_fill)/2/vi.channels;
+        for(i=0;i<ret && i<maxsamples;i++)
+          for(j=0;j<vi.channels;j++){
+            int val=rint(pcm[j][i]*32767.f);
+            if(val>32767)val=32767;
+            if(val<-32768)val=-32768;
+            audiobuf[count++]=val;
+          }
+        vorbis_synthesis_read(&vd,i);
+        audiobuf_fill+=i*vi.channels*2;
+        if(audiobuf_fill==audiofd_fragsize)audiobuf_ready=1;
+        if(vd.granulepos>=0)
+          audiobuf_granulepos=vd.granulepos-ret+i;
+        else
+          audiobuf_granulepos+=i;
+
+      }else{
+
+        /* no pending audio; is there a pending packet to decode? */
+        if(ogg_stream_packetout(&vo,&op)>0){
+          if(vorbis_synthesis(&vb,&op)==0) /* test for success! */
+            vorbis_synthesis_blockin(&vd,&vb);
+        }else   /* we need more data; break out to suck in another page */
+          break;
+      }
+    }
+
+    while(theora_p && !videobuf_ready){
+      /* theora is one in, one out... */
+      if(ogg_stream_packetout(&to,&op)>0){
+
+        if(pp_inc){
+          pp_level+=pp_inc;
+          th_decode_ctl(td,TH_DECCTL_SET_PPLEVEL,&pp_level,
+           sizeof(pp_level));
+          pp_inc=0;
+        }
+        /*HACK: This should be set after a seek or a gap, but we might not have
+           a granulepos for the first packet (we only have them for the last
+           packet on a page), so we just set it as often as we get it.
+          To do this right, we should back-track from the last packet on the
+           page and compute the correct granulepos for the first packet after
+           a seek or a gap.*/
+        if(op.granulepos>=0){
+          th_decode_ctl(td,TH_DECCTL_SET_GRANPOS,&op.granulepos,
+           sizeof(op.granulepos));
+        }
+        if(th_decode_packetin(td,&op,&videobuf_granulepos)==0){
+          videobuf_time=th_granule_time(td,videobuf_granulepos);
+          frames++;
+
+          /* is it already too old to be useful?  This is only actually
+             useful cosmetically after a SIGSTOP.  Note that we have to
+             decode the frame even if we don't show it (for now) due to
+             keyframing.  Soon enough libtheora will be able to deal
+             with non-keyframe seeks.  */
+
+          if(videobuf_time>=get_time())
+            videobuf_ready=1;
+          else{
+            /*If we are too slow, reduce the pp level.*/
+            pp_inc=pp_level>0?-1:0;
+            dropped++;
+          }
+        }
+
+      }else
+        break;
+    }
+
+    if(!videobuf_ready && !audiobuf_ready && feof(infile))break;
+
+    if(!videobuf_ready || !audiobuf_ready){
+      /* no data yet for somebody.  Grab another page */
+      buffer_data(infile,&oy);
+      while(ogg_sync_pageout(&oy,&og)>0){
+        queue_page(&og);
+      }
+    }
+
+    /* If playback has begun, top audio buffer off immediately. */
+    if(stateflag) audio_write_nonblocking();
+
+    /* are we at or past time for this video frame? */
+    if(stateflag && videobuf_ready && videobuf_time<=get_time()){
+      video_write();
+      videobuf_ready=0;
+    }
+
+    if(stateflag &&
+       (audiobuf_ready || !vorbis_p) &&
+       (videobuf_ready || !theora_p) &&
+       !got_sigint){
+      /* we have an audio frame ready (which means the audio buffer is
+         full), it's not time to play video, so wait until one of the
+         audio buffer is ready or it's near time to play video */
+
+      /* set up select wait on the audiobuffer and a timeout for video */
+      struct timeval timeout;
+      fd_set writefs;
+      fd_set empty;
+      int n=0;
+
+      FD_ZERO(&writefs);
+      FD_ZERO(&empty);
+      if(audiofd>=0){
+        FD_SET(audiofd,&writefs);
+        n=audiofd+1;
+      }
+
+      if(theora_p){
+        double tdiff;
+        long milliseconds;
+        tdiff=videobuf_time-get_time();
+        /*If we have lots of extra time, increase the post-processing level.*/
+        if(tdiff>ti.fps_denominator*0.25/ti.fps_numerator){
+          pp_inc=pp_level<pp_level_max?1:0;
+        }
+        else if(tdiff<ti.fps_denominator*0.05/ti.fps_numerator){
+          pp_inc=pp_level>0?-1:0;
+        }
+        milliseconds=tdiff*1000-5;
+        if(milliseconds>500)milliseconds=500;
+        if(milliseconds>0){
+          timeout.tv_sec=milliseconds/1000;
+          timeout.tv_usec=(milliseconds%1000)*1000;
+
+          n=select(n,&empty,&writefs,&empty,&timeout);
+          if(n)audio_calibrate_timer(0);
+        }
+      }else{
+        select(n,&empty,&writefs,&empty,NULL);
+      }
+    }
+
+    /* if our buffers either don't exist or are ready to go,
+       we can begin playback */
+    if((!theora_p || videobuf_ready) &&
+       (!vorbis_p || audiobuf_ready))stateflag=1;
+    /* same if we've run out of input */
+    if(feof(infile))stateflag=1;
+
+  }
+
+  /* tear it all down */
+
+  audio_close();
+  SDL_Quit();
+
+  if(vorbis_p){
+    ogg_stream_clear(&vo);
+    vorbis_block_clear(&vb);
+    vorbis_dsp_clear(&vd);
+    vorbis_comment_clear(&vc);
+    vorbis_info_clear(&vi);
+  }
+  if(theora_p){
+    ogg_stream_clear(&to);
+    th_decode_free(td);
+    th_comment_clear(&tc);
+    th_info_clear(&ti);
+  }
+  ogg_sync_clear(&oy);
+
+  if(infile && infile!=stdin)fclose(infile);
+
+  fprintf(stderr,
+          "\r                                                             \r");
+  fprintf(stderr, "%d frames", frames);
+  if (dropped) fprintf(stderr, " (%d dropped)", dropped);
+  fprintf(stderr, "\n");
+  fprintf(stderr, "\nDone.\n");
+
+  return(0);
+
+}
diff --git a/examples/png2theora.c b/examples/png2theora.c
new file mode 100644 (file)
index 0000000..71a0d0f
--- /dev/null
@@ -0,0 +1,912 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009,2009           *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function: example encoder application; makes an Ogg Theora
+            file from a sequence of png images
+  last mod: $Id: png2theora.c 16503 2009-08-22 18:14:02Z giles $
+             based on code from Vegard Nossum
+
+ ********************************************************************/
+
+#define _FILE_OFFSET_BITS 64
+
+#include <errno.h>
+#include <getopt.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <time.h>
+#include <math.h>
+#include <libgen.h>
+#include <sys/types.h>
+#include <dirent.h>
+
+#ifdef HAVE_CONFIG_H
+# include <config.h>
+#endif
+
+#include <png.h>
+#include <ogg/ogg.h>
+#include "theora/theoraenc.h"
+
+#define PROGRAM_NAME  "png2theora"
+#define PROGRAM_VERSION  "1.1"
+
+static const char *option_output = NULL;
+static int video_fps_numerator = 24;
+static int video_fps_denominator = 1;
+static int video_aspect_numerator = 0;
+static int video_aspect_denominator = 0;
+static int video_rate = -1;
+static int video_quality = -1;
+ogg_uint32_t keyframe_frequency=0;
+int buf_delay=-1;
+int vp3_compatible=0;
+static int chroma_format = TH_PF_420;
+
+static FILE *twopass_file = NULL;
+static  int twopass=0;
+static  int passno;
+
+static FILE *ogg_fp = NULL;
+static ogg_stream_state ogg_os;
+static ogg_packet op;   
+static ogg_page og;
+    
+static th_enc_ctx      *td;
+static th_info          ti;
+
+static char *input_filter;
+
+const char *optstring = "o:hv:\4:\2:V:s:S:f:F:ck:d:\1\2\3\4\5\6";
+struct option options [] = {
+ {"output",required_argument,NULL,'o'},
+ {"help",no_argument,NULL,'h'},
+ {"chroma-444",no_argument,NULL,'\5'},
+ {"chroma-422",no_argument,NULL,'\6'},
+ {"video-rate-target",required_argument,NULL,'V'},
+ {"video-quality",required_argument,NULL,'v'},
+ {"aspect-numerator",required_argument,NULL,'s'},
+ {"aspect-denominator",required_argument,NULL,'S'},
+ {"framerate-numerator",required_argument,NULL,'f'},
+ {"framerate-denominator",required_argument,NULL,'F'},
+ {"vp3-compatible",no_argument,NULL,'c'},
+ {"soft-target",no_argument,NULL,'\1'},
+ {"keyframe-freq",required_argument,NULL,'k'},
+ {"buf-delay",required_argument,NULL,'d'},
+ {"two-pass",no_argument,NULL,'\2'},
+ {"first-pass",required_argument,NULL,'\3'}, 
+ {"second-pass",required_argument,NULL,'\4'},  
+ {NULL,0,NULL,0}
+};
+
+static void usage(void){
+  fprintf(stderr,
+          "%s %s\n"
+          "Usage: %s [options] <input>\n\n"
+          "The input argument uses C printf format to represent a list of files,\n"
+          "  i.e. file-%%06d.png to look for files file000001.png to file9999999.png \n\n"
+          "Options: \n\n"
+          "  -o --output <filename.ogv>      file name for encoded output (required);\n"
+          "  -v --video-quality <n>          Theora quality selector fro 0 to 10\n"
+          "                                  (0 yields smallest files but lowest\n"
+          "                                  video quality. 10 yields highest\n"
+          "                                  fidelity but large files)\n\n"
+          "  -V --video-rate-target <n>      bitrate target for Theora video\n\n"
+          "     --soft-target                Use a large reservoir and treat the rate\n"
+          "                                  as a soft target; rate control is less\n"
+          "                                  strict but resulting quality is usually\n"
+          "                                  higher/smoother overall. Soft target also\n"
+          "                                  allows an optional -v setting to specify\n"
+          "                                  a minimum allowed quality.\n\n"
+          "     --two-pass                   Compress input using two-pass rate control\n"
+          "                                  This option performs both passes automatically.\n\n"
+          "     --first-pass <filename>      Perform first-pass of a two-pass rate\n"
+          "                                  controlled encoding, saving pass data to\n"
+          "                                  <filename> for a later second pass\n\n"
+          "     --second-pass <filename>     Perform second-pass of a two-pass rate\n"
+          "                                  controlled encoding, reading first-pass\n"
+          "                                  data from <filename>.  The first pass\n"
+          "                                  data must come from a first encoding pass\n"
+          "                                  using identical input video to work\n"
+          "                                  properly.\n\n"
+          "   -k --keyframe-freq <n>         Keyframe frequency\n"
+          "   -d --buf-delay <n>             Buffer delay (in frames). Longer delays\n"
+          "                                  allow smoother rate adaptation and provide\n"
+          "                                  better overall quality, but require more\n"
+          "                                  client side buffering and add latency. The\n"
+          "                                  default value is the keyframe interval for\n"
+          "                                  one-pass encoding (or somewhat larger if\n"
+          "                                  --soft-target is used) and infinite for\n"
+          "                                  two-pass encoding.\n"
+          "  --chroma-444                    Use 4:4:4 chroma subsampling\n"
+          "  --chroma-422                    Use 4:2:2 chroma subsampling\n"
+          "                                  (4:2:0 is default)\n\n" 
+          "  -s --aspect-numerator <n>       Aspect ratio numerator, default is 0\n"
+          "  -S --aspect-denominator <n>     Aspect ratio denominator, default is 0\n"
+          "  -f --framerate-numerator <n>    Frame rate numerator\n"
+          "  -F --framerate-denominator <n>  Frame rate denominator\n"
+          "                                  The frame rate nominator divided by this\n"
+          "                                  determines the frame rate in units per tick\n"
+          ,PROGRAM_NAME, PROGRAM_VERSION, PROGRAM_NAME
+  );
+  exit(0);
+}
+
+#ifdef WIN32
+int
+alphasort (const void *a, const void *b)
+{
+  return strcoll ((*(const struct dirent **) a)->d_name,
+                  (*(const struct dirent **) b)->d_name);
+}
+
+int
+scandir (const char *dir, struct dirent ***namelist,
+         int (*select)(const struct dirent *), int (*compar)(const void *, const void *))
+{
+  DIR *d;
+  struct dirent *entry;
+  register int i=0;
+  size_t entrysize;
+
+  if ((d=opendir(dir)) == NULL)
+    return(-1);
+
+  *namelist=NULL;
+  while ((entry=readdir(d)) != NULL)
+  {
+    if (select == NULL || (select != NULL && (*select)(entry)))
+    {
+      *namelist=(struct dirent **)realloc((void *)(*namelist),
+                 (size_t)((i+1)*sizeof(struct dirent *)));
+      if (*namelist == NULL) return(-1);
+      entrysize=sizeof(struct dirent)-sizeof(entry->d_name)+strlen(entry->d_name)+1;
+      (*namelist)[i]=(struct dirent *)malloc(entrysize);
+      if ((*namelist)[i] == NULL) return(-1);
+        memcpy((*namelist)[i], entry, entrysize);
+      i++;
+    }
+  }
+  if (closedir(d)) return(-1);
+  if (i == 0) return(-1);
+  if (compar != NULL)
+    qsort((void *)(*namelist), (size_t)i, sizeof(struct dirent *), compar);
+    
+  return(i);
+}
+#endif
+
+static int
+theora_write_frame(unsigned long w, unsigned long h, unsigned char *yuv, int last)
+{
+  th_ycbcr_buffer ycbcr;
+  ogg_packet op;
+  ogg_page og;
+
+  unsigned long yuv_w;
+  unsigned long yuv_h;
+
+  unsigned char *yuv_y;
+  unsigned char *yuv_u;
+  unsigned char *yuv_v;
+
+  unsigned int x;
+  unsigned int y;
+
+  /* Must hold: yuv_w >= w */
+  yuv_w = (w + 15) & ~15;
+
+  /* Must hold: yuv_h >= h */
+  yuv_h = (h + 15) & ~15;
+
+  ycbcr[0].width = yuv_w;
+  ycbcr[0].height = yuv_h;
+  ycbcr[0].stride = yuv_w;
+  ycbcr[1].width = (chroma_format == TH_PF_444) ? yuv_w : (yuv_w >> 1);
+  ycbcr[1].stride = ycbcr[1].width;
+  ycbcr[1].height = (chroma_format == TH_PF_420) ? (yuv_h >> 1) : yuv_h;
+  ycbcr[2].width = ycbcr[1].width;
+  ycbcr[2].stride = ycbcr[1].stride;
+  ycbcr[2].height = ycbcr[1].height;
+
+  ycbcr[0].data = yuv_y = malloc(ycbcr[0].stride * ycbcr[0].height);
+  ycbcr[1].data = yuv_u = malloc(ycbcr[1].stride * ycbcr[1].height);
+  ycbcr[2].data = yuv_v = malloc(ycbcr[2].stride * ycbcr[2].height);
+
+  for(y = 0; y < h; y++) {
+    for(x = 0; x < w; x++) {
+      yuv_y[x + y * yuv_w] = yuv[3 * (x + y * w) + 0];
+    }
+  }
+
+  if (chroma_format == TH_PF_420) {
+    for(y = 0; y < h; y += 2) {
+      for(x = 0; x < w; x += 2) {
+        yuv_u[(x >> 1) + (y >> 1) * (yuv_w >> 1)] =
+          yuv[3 * (x + y * w) + 1];
+        yuv_v[(x >> 1) + (y >> 1) * (yuv_w >> 1)] =
+          yuv[3 * (x + y * w) + 2];
+      }
+    }
+  } else if (chroma_format == TH_PF_444) {
+    for(y = 0; y < h; y++) {
+      for(x = 0; x < w; x++) {
+        yuv_u[x + y * ycbcr[1].stride] = yuv[3 * (x + y * w) + 1];
+        yuv_v[x + y * ycbcr[2].stride] = yuv[3 * (x + y * w) + 2];
+      }
+    }
+  } else {  /* TH_PF_422 */
+    for(y = 0; y < h; y += 1) {
+      for(x = 0; x < w; x += 2) {
+        yuv_u[(x >> 1) + y * ycbcr[1].stride] =
+          yuv[3 * (x + y * w) + 1];
+        yuv_v[(x >> 1) + y * ycbcr[2].stride] =
+          yuv[3 * (x + y * w) + 2];
+      }
+    }    
+  }
+
+  /* Theora is a one-frame-in,one-frame-out system; submit a frame
+     for compression and pull out the packet */
+  /* in two-pass mode's second pass, we need to submit first-pass data */
+  if(passno==2){
+    int ret;
+    for(;;){
+      static unsigned char buffer[80];
+      static int buf_pos;
+      int bytes;
+      /*Ask the encoder how many bytes it would like.*/
+      bytes=th_encode_ctl(td,TH_ENCCTL_2PASS_IN,NULL,0);
+      if(bytes<0){
+        fprintf(stderr,"Error submitting pass data in second pass.\n");
+        exit(1);
+      }
+      /*If it's got enough, stop.*/
+      if(bytes==0)break;
+      /*Read in some more bytes, if necessary.*/
+      if(bytes>80-buf_pos)bytes=80-buf_pos;
+      if(bytes>0&&fread(buffer+buf_pos,1,bytes,twopass_file)<bytes){
+        fprintf(stderr,"Could not read frame data from two-pass data file!\n");
+        exit(1);
+      }
+      /*And pass them off.*/
+      ret=th_encode_ctl(td,TH_ENCCTL_2PASS_IN,buffer,bytes);
+      if(ret<0){
+        fprintf(stderr,"Error submitting pass data in second pass.\n");
+        exit(1);
+      }
+      /*If the encoder consumed the whole buffer, reset it.*/
+      if(ret>=bytes)buf_pos=0;
+      /*Otherwise remember how much it used.*/
+      else buf_pos+=ret;
+    }
+  }
+
+  if(th_encode_ycbcr_in(td, ycbcr)) {
+    fprintf(stderr, "%s: error: could not encode frame\n",
+      option_output);
+    return 1;
+  }
+
+  /* in two-pass mode's first pass we need to extract and save the pass data */
+  if(passno==1){
+    unsigned char *buffer;
+    int bytes = th_encode_ctl(td, TH_ENCCTL_2PASS_OUT, &buffer, sizeof(buffer));
+    if(bytes<0){
+      fprintf(stderr,"Could not read two-pass data from encoder.\n");
+      exit(1);
+    }
+    if(fwrite(buffer,1,bytes,twopass_file)<bytes){
+      fprintf(stderr,"Unable to write to two-pass data file.\n");
+      exit(1);
+    }
+    fflush(twopass_file);
+  }
+
+  if(!th_encode_packetout(td, last, &op)) {
+    fprintf(stderr, "%s: error: could not read packets\n",
+      option_output);
+    return 1;
+  }
+
+  if (passno!=1) { 
+    ogg_stream_packetin(&ogg_os, &op);
+    while(ogg_stream_pageout(&ogg_os, &og)) {
+      fwrite(og.header, og.header_len, 1, ogg_fp);
+      fwrite(og.body, og.body_len, 1, ogg_fp);
+    }
+  }  
+
+  free(yuv_y);
+  free(yuv_u);
+  free(yuv_v);
+
+  return 0;
+}
+
+static unsigned char
+clamp(double d)
+{
+  if(d < 0)
+    return 0;
+
+  if(d > 255)
+    return 255;
+
+  return d;
+}
+
+static void
+rgb_to_yuv(png_bytep *png,
+           unsigned char *yuv,
+           unsigned int w, unsigned int h)
+{
+  unsigned int x;
+  unsigned int y;
+
+  for(y = 0; y < h; y++) {
+    for(x = 0; x < w; x++) {
+      png_byte r;
+      png_byte g;
+      png_byte b;
+
+      r = png[y][3 * x + 0];
+      g = png[y][3 * x + 1];
+      b = png[y][3 * x + 2];
+
+      /* XXX: Cringe. */
+      yuv[3 * (x + w * y) + 0] = clamp(
+        0.299 * r
+        + 0.587 * g
+        + 0.114 * b);
+      yuv[3 * (x + w * y) + 1] = clamp((0.436 * 255
+        - 0.14713 * r
+        - 0.28886 * g
+        + 0.436 * b) / 0.872);
+      yuv[3 * (x + w * y) + 2] = clamp((0.615 * 255
+        + 0.615 * r
+        - 0.51499 * g
+        - 0.10001 * b) / 1.230);
+    }
+  }
+}
+
+static int
+png_read(const char *pathname, unsigned int *w, unsigned int *h, unsigned char **yuv)
+{
+  FILE *fp;
+  unsigned char header[8];
+  png_structp png_ptr;
+  png_infop info_ptr;
+  png_infop end_ptr;
+  png_bytep row_data;
+  png_bytep *row_pointers;
+  png_color_16p bkgd;
+  png_uint_32 width;
+  png_uint_32 height;
+  int bit_depth;
+  int color_type;
+  int interlace_type;
+  int compression_type;
+  int filter_method;
+  png_uint_32 y;
+
+  fp = fopen(pathname, "rb");
+  if(!fp) {
+    fprintf(stderr, "%s: error: %s\n",
+      pathname, strerror(errno));
+    return 1;
+  }
+
+  fread(header, 1, 8, fp);
+  if(png_sig_cmp(header, 0, 8)) {
+    fprintf(stderr, "%s: error: %s\n",
+      pathname, "not a PNG");
+    fclose(fp);
+    return 1;
+  }
+
+  png_ptr = png_create_read_struct(PNG_LIBPNG_VER_STRING,
+    NULL, NULL, NULL);
+  if(!png_ptr) {
+    fprintf(stderr, "%s: error: %s\n",
+      pathname, "couldn't create png read structure");
+    fclose(fp);
+    return 1;
+  }
+
+  info_ptr = png_create_info_struct(png_ptr);
+  if(!info_ptr) {
+    fprintf(stderr, "%s: error: %s\n",
+      pathname, "couldn't create png info structure");
+    png_destroy_read_struct(&png_ptr, NULL, NULL);
+    fclose(fp);
+    return 1;
+  }
+
+  end_ptr = png_create_info_struct(png_ptr);
+  if(!end_ptr) {
+    fprintf(stderr, "%s: error: %s\n",
+      pathname, "couldn't create png info structure");
+    png_destroy_read_struct(&png_ptr, &info_ptr, NULL);
+    fclose(fp);
+    return 1;
+  }
+
+  png_init_io(png_ptr, fp);
+  png_set_sig_bytes(png_ptr, 8);
+  png_read_info(png_ptr, info_ptr);
+  png_get_IHDR(png_ptr, info_ptr, &width, &height, &bit_depth, &color_type,
+   &interlace_type, &compression_type, &filter_method);
+  png_set_expand(png_ptr);
+  if(bit_depth<8)png_set_packing(png_ptr);
+  if(bit_depth==16)png_set_strip_16(png_ptr);
+  if(!(color_type&PNG_COLOR_MASK_COLOR))png_set_gray_to_rgb(png_ptr);
+  if(png_get_bKGD(png_ptr, info_ptr, &bkgd)){
+    png_set_background(png_ptr, bkgd, PNG_BACKGROUND_GAMMA_FILE, 1, 1.0);
+  }
+  /*Note that color_type 2 and 3 can also have alpha, despite not setting the
+     PNG_COLOR_MASK_ALPHA bit.
+    We always strip it to prevent libpng from overrunning our buffer.*/
+  png_set_strip_alpha(png_ptr);
+
+  row_data = (png_bytep)png_malloc(png_ptr,
+    3*height*width*png_sizeof(*row_data));
+  row_pointers = (png_bytep *)png_malloc(png_ptr,
+    height*png_sizeof(*row_pointers));
+  for(y = 0; y < height; y++) {
+    row_pointers[y] = row_data + y*(3*width);
+  }
+  png_read_image(png_ptr, row_pointers);
+  png_read_end(png_ptr, end_ptr);
+
+  *w = width;
+  *h = height;
+  *yuv = malloc(*w * *h * 3);
+  rgb_to_yuv(row_pointers, *yuv, *w, *h);
+
+  png_free(png_ptr, row_pointers);
+  png_free(png_ptr, row_data);
+  png_destroy_read_struct(&png_ptr, &info_ptr, &end_ptr);
+
+  fclose(fp);
+  return 0;
+}
+
+static int include_files (const struct dirent *de)
+{
+  char name[1024];
+  int number = -1;
+  sscanf(de->d_name, input_filter, &number);
+  sprintf(name, input_filter, number);
+  return !strcmp(name, de->d_name);
+}
+
+static int ilog(unsigned _v){
+  int ret;
+  for(ret=0;_v;ret++)_v>>=1;
+  return ret;
+}
+      
+int
+main(int argc, char *argv[])
+{
+  int c,long_option_index;
+  int i, n;
+  char *input_mask;
+  char *input_directory;
+  char *scratch;
+  th_comment       tc;
+  struct dirent **png_files;
+  int soft_target=0;
+  int ret;
+      
+  while(1) {
+
+    c=getopt_long(argc,argv,optstring,options,&long_option_index);
+    if(c == EOF)
+      break;
+
+    switch(c) {
+      case 'h':
+        usage();
+        break;
+      case 'o':
+        option_output = optarg;
+        break;;
+      case 'v':
+        video_quality=rint(atof(optarg)*6.3);
+        if(video_quality<0 || video_quality>63){
+          fprintf(stderr,"Illegal video quality (choose 0 through 10)\n");
+          exit(1);
+        }
+        video_rate=0;
+        break;
+      case 'V':
+        video_rate=rint(atof(optarg)*1000);
+        if(video_rate<1){
+          fprintf(stderr,"Illegal video bitrate (choose > 0 please)\n");
+          exit(1);
+        }
+        video_quality=0;
+       break;
+    case '\1':
+      soft_target=1;
+      break;
+    case 'c':
+      vp3_compatible=1;
+      break;
+    case 'k':
+      keyframe_frequency=rint(atof(optarg));
+      if(keyframe_frequency<1 || keyframe_frequency>2147483647){
+        fprintf(stderr,"Illegal keyframe frequency\n");
+        exit(1);
+      }
+      break;
+
+    case 'd':
+      buf_delay=atoi(optarg);
+      if(buf_delay<=0){
+        fprintf(stderr,"Illegal buffer delay\n");
+        exit(1);
+      }
+      break;
+     case 's':
+       video_aspect_numerator=rint(atof(optarg));
+       break;
+     case 'S':
+       video_aspect_denominator=rint(atof(optarg));
+       break;
+     case 'f':
+       video_fps_numerator=rint(atof(optarg));
+       break;
+     case 'F':
+       video_fps_denominator=rint(atof(optarg));
+       break;
+     case '\5':
+       chroma_format=TH_PF_444;
+       break;
+     case '\6':
+       chroma_format=TH_PF_422;
+       break;
+    case '\2':
+      twopass=3; /* perform both passes */
+      twopass_file=tmpfile();
+      if(!twopass_file){
+        fprintf(stderr,"Unable to open temporary file for twopass data\n");
+        exit(1);
+      }
+      break;
+    case '\3':
+      twopass=1; /* perform first pass */
+      twopass_file=fopen(optarg,"wb");
+      if(!twopass_file){
+        fprintf(stderr,"Unable to open \'%s\' for twopass data\n",optarg);
+        exit(1);
+      }
+      break;
+    case '\4':
+      twopass=2; /* perform second pass */
+      twopass_file=fopen(optarg,"rb");
+      if(!twopass_file){
+        fprintf(stderr,"Unable to open twopass data file \'%s\'",optarg);
+        exit(1);
+      }
+      break;
+     default:
+        usage();
+        break;
+      }
+  }
+
+  if(argc < 3) {
+    usage();
+  }
+
+  if(soft_target){
+    if(video_rate<=0){
+      fprintf(stderr,"Soft rate target (--soft-target) requested without a bitrate (-V).\n");
+      exit(1);
+    }
+    if(video_quality==-1)
+      video_quality=0;
+  }else{
+    if(video_rate>0)
+      video_quality=0;
+    if(video_quality==-1)
+      video_quality=48;
+  }
+
+  if(keyframe_frequency<=0){
+    /*Use a default keyframe frequency of 64 for 1-pass (streaming) mode, and
+       256 for two-pass mode.*/
+    keyframe_frequency=twopass?256:64;
+  }
+
+  input_mask = argv[optind];
+  if (!input_mask) {
+    fprintf(stderr, "no input files specified; run with -h for help.\n");
+    exit(1);
+  }
+  /* dirname and basename must operate on scratch strings */
+  scratch = strdup(input_mask);
+  input_directory = strdup(dirname(scratch));
+  free(scratch);
+  scratch = strdup(input_mask);
+  input_filter = strdup(basename(scratch));
+  free(scratch);
+
+#ifdef DEBUG
+  fprintf(stderr, "scanning %s with filter '%s'\n",
+  input_directory, input_filter);
+#endif
+  n = scandir (input_directory, &png_files, include_files, alphasort);
+
+  if (!n) {
+    fprintf(stderr, "no input files found; run with -h for help.\n");
+    exit(1);
+  }
+
+  ogg_fp = fopen(option_output, "wb");
+  if(!ogg_fp) {
+    fprintf(stderr, "%s: error: %s\n",
+      option_output, "couldn't open output file");
+    return 1;
+  }
+
+  srand(time(NULL));
+  if(ogg_stream_init(&ogg_os, rand())) {
+    fprintf(stderr, "%s: error: %s\n",
+      option_output, "couldn't create ogg stream state");
+    return 1;
+  }
+
+  for(passno=(twopass==3?1:twopass);passno<=(twopass==3?2:twopass);passno++){
+    unsigned int w;
+    unsigned int h;
+    unsigned char *yuv;
+    char input_png[1024];
+    int last = 0;
+
+    snprintf(input_png, 1023,"%s/%s", input_directory, png_files[0]->d_name);
+    if(png_read(input_png, &w, &h, &yuv)) {
+      fprintf(stderr, "could not read %s\n", input_png);
+      exit(1);
+    }
+
+    if (passno!=2) fprintf(stderr,"%d frames, %dx%d\n",n,w,h);    
+
+    /* setup complete.  Raw processing loop */
+    switch(passno){
+    case 0: case 2:
+      fprintf(stderr,"\rCompressing....                                          \n");
+      break;
+    case 1:
+      fprintf(stderr,"\rScanning first pass....                                  \n");
+      break;
+    }
+
+    fprintf(stderr, "%s\n", input_png); 
+
+    th_info_init(&ti);    
+    ti.frame_width = ((w + 15) >>4)<<4;
+    ti.frame_height = ((h + 15)>>4)<<4;
+    ti.pic_width = w;
+    ti.pic_height = h;
+    ti.pic_x = 0;
+    ti.pic_y = 0;
+    ti.fps_numerator = video_fps_numerator;
+    ti.fps_denominator = video_fps_denominator;
+    ti.aspect_numerator = video_aspect_numerator;
+    ti.aspect_denominator = video_aspect_denominator;
+    ti.colorspace = TH_CS_UNSPECIFIED;
+    ti.pixel_fmt = chroma_format;
+    ti.target_bitrate = video_rate;
+    ti.quality = video_quality;
+    ti.keyframe_granule_shift=ilog(keyframe_frequency-1);
+
+    td=th_encode_alloc(&ti);  
+    th_info_clear(&ti);
+    /* setting just the granule shift only allows power-of-two keyframe
+       spacing.  Set the actual requested spacing. */
+    ret=th_encode_ctl(td,TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE,
+     &keyframe_frequency,sizeof(keyframe_frequency-1));
+    if(ret<0){
+      fprintf(stderr,"Could not set keyframe interval to %d.\n",(int)keyframe_frequency);
+    }
+    if(vp3_compatible){
+      ret=th_encode_ctl(td,TH_ENCCTL_SET_VP3_COMPATIBLE,&vp3_compatible,
+       sizeof(vp3_compatible));
+      if(ret<0||!vp3_compatible){
+        fprintf(stderr,"Could not enable strict VP3 compatibility.\n");
+        if(ret>=0){
+          fprintf(stderr,"Ensure your source format is supported by VP3.\n");
+          fprintf(stderr,
+           "(4:2:0 pixel format, width and height multiples of 16).\n");
+        }
+      }
+    }
+    if(soft_target){
+      /* reverse the rate control flags to favor a 'long time' strategy */
+      int arg = TH_RATECTL_CAP_UNDERFLOW;
+      ret=th_encode_ctl(td,TH_ENCCTL_SET_RATE_FLAGS,&arg,sizeof(arg));
+      if(ret<0)
+        fprintf(stderr,"Could not set encoder flags for --soft-target\n");
+      /* Default buffer control is overridden on two-pass */
+      if(!twopass&&buf_delay<0){
+        if((keyframe_frequency*7>>1) > 5*video_fps_numerator/video_fps_denominator)
+          arg=keyframe_frequency*7>>1;
+        else
+          arg=5*video_fps_numerator/video_fps_denominator;
+        ret=th_encode_ctl(td,TH_ENCCTL_SET_RATE_BUFFER,&arg,sizeof(arg));
+        if(ret<0)
+          fprintf(stderr,"Could not set rate control buffer for --soft-target\n");
+      }
+    }
+    /* set up two-pass if needed */
+    if(passno==1){
+      unsigned char *buffer;
+      int bytes;
+      bytes=th_encode_ctl(td,TH_ENCCTL_2PASS_OUT,&buffer,sizeof(buffer));
+      if(bytes<0){
+        fprintf(stderr,"Could not set up the first pass of two-pass mode.\n");
+        fprintf(stderr,"Did you remember to specify an estimated bitrate?\n");
+        exit(1);
+      }
+      /*Perform a seek test to ensure we can overwrite this placeholder data at
+         the end; this is better than letting the user sit through a whole
+         encode only to find out their pass 1 file is useless at the end.*/
+      if(fseek(twopass_file,0,SEEK_SET)<0){
+        fprintf(stderr,"Unable to seek in two-pass data file.\n");
+        exit(1);
+      }
+      if(fwrite(buffer,1,bytes,twopass_file)<bytes){
+        fprintf(stderr,"Unable to write to two-pass data file.\n");
+        exit(1);
+      }
+      fflush(twopass_file);
+    }
+    if(passno==2){
+      /*Enable the second pass here.
+        We make this call just to set the encoder into 2-pass mode, because
+         by default enabling two-pass sets the buffer delay to the whole file
+         (because there's no way to explicitly request that behavior).
+        If we waited until we were actually encoding, it would overwite our
+         settings.*/
+      if(th_encode_ctl(td,TH_ENCCTL_2PASS_IN,NULL,0)<0){
+        fprintf(stderr,"Could not set up the second pass of two-pass mode.\n");
+        exit(1);
+      }
+      if(twopass==3){
+        if(fseek(twopass_file,0,SEEK_SET)<0){
+          fprintf(stderr,"Unable to seek in two-pass data file.\n");
+          exit(1);
+        }
+      }
+    }
+    /*Now we can set the buffer delay if the user requested a non-default one
+       (this has to be done after two-pass is enabled).*/
+    if(passno!=1&&buf_delay>=0){
+      ret=th_encode_ctl(td,TH_ENCCTL_SET_RATE_BUFFER,
+       &buf_delay,sizeof(buf_delay));
+      if(ret<0){
+        fprintf(stderr,"Warning: could not set desired buffer delay.\n");
+      }
+    }
+    /* write the bitstream header packets with proper page interleave */
+    th_comment_init(&tc);
+    /* first packet will get its own page automatically */
+    if(th_encode_flushheader(td,&tc,&op)<=0){
+      fprintf(stderr,"Internal Theora library error.\n");
+      exit(1); 
+    }
+    th_comment_clear(&tc);
+    if(passno!=1){
+      ogg_stream_packetin(&ogg_os,&op);
+      if(ogg_stream_pageout(&ogg_os,&og)!=1){
+        fprintf(stderr,"Internal Ogg library error.\n");
+        exit(1);
+      }
+      fwrite(og.header,1,og.header_len,ogg_fp);
+      fwrite(og.body,1,og.body_len,ogg_fp);
+    }
+    /* create the remaining theora headers */
+    for(;;){
+      ret=th_encode_flushheader(td,&tc,&op);
+      if(ret<0){
+        fprintf(stderr,"Internal Theora library error.\n");
+        exit(1);
+      }
+      else if(!ret)break;
+      if(passno!=1)ogg_stream_packetin(&ogg_os,&op);
+    }
+    /* Flush the rest of our headers. This ensures
+       the actual data in each stream will start
+       on a new page, as per spec. */
+    if(passno!=1){
+      for(;;){
+        int result = ogg_stream_flush(&ogg_os,&og);
+        if(result<0){
+          /* can't get here */
+          fprintf(stderr,"Internal Ogg library error.\n");
+          exit(1);
+        }
+        if(result==0)break;
+        fwrite(og.header,1,og.header_len,ogg_fp);
+        fwrite(og.body,1,og.body_len,ogg_fp);
+      }
+    }
+
+    i=0; last=0;
+    do {
+      if(i >= n-1) last = 1;
+      if(theora_write_frame(w, h, yuv, last)) {
+          fprintf(stderr,"Encoding error.\n");
+        exit(1);
+      }
+      free(yuv);    
+      i++;
+      if (!last) {
+        snprintf(input_png, 1023,"%s/%s", input_directory, png_files[i]->d_name);
+        if(png_read(input_png, &w, &h, &yuv)) {
+          fprintf(stderr, "could not read %s\n", input_png);
+          exit(1);
+        }
+       fprintf(stderr, "%s\n", input_png);
+      }      
+    } while (!last);
+
+    if(passno==1){
+      /* need to read the final (summary) packet */
+      unsigned char *buffer;
+      int bytes = th_encode_ctl(td, TH_ENCCTL_2PASS_OUT, &buffer, sizeof(buffer));
+      if(bytes<0){
+        fprintf(stderr,"Could not read two-pass summary data from encoder.\n");
+        exit(1);
+      }
+      if(fseek(twopass_file,0,SEEK_SET)<0){
+        fprintf(stderr,"Unable to seek in two-pass data file.\n");
+        exit(1);
+      }
+      if(fwrite(buffer,1,bytes,twopass_file)<bytes){
+        fprintf(stderr,"Unable to write to two-pass data file.\n");
+        exit(1);
+      }
+      fflush(twopass_file);
+    }
+    th_encode_free(td);
+  }
+
+  if(ogg_stream_flush(&ogg_os, &og)) {
+    fwrite(og.header, og.header_len, 1, ogg_fp);
+    fwrite(og.body, og.body_len, 1, ogg_fp);
+  }            
+
+  free(input_directory);
+  free(input_filter);
+
+  while (n--) free(png_files[n]);
+  free(png_files);  
+
+  if(ogg_fp){
+    fflush(ogg_fp);
+    if(ogg_fp!=stdout)fclose(ogg_fp);
+  }
+
+  ogg_stream_clear(&ogg_os);
+  if(twopass_file)fclose(twopass_file);
+  fprintf(stderr,"\r   \ndone.\n\n");
+
+  return 0;
+}
diff --git a/include/Makefile.am b/include/Makefile.am
new file mode 100644 (file)
index 0000000..d5db4b4
--- /dev/null
@@ -0,0 +1,3 @@
+## Process this file with automake to produce Makefile.in
+
+SUBDIRS = theora
diff --git a/include/Makefile.in b/include/Makefile.in
new file mode 100644 (file)
index 0000000..805e6c2
--- /dev/null
@@ -0,0 +1,414 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+
+SUBDIRS = theora
+subdir = include
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES =
+DIST_SOURCES =
+
+RECURSIVE_TARGETS = info-recursive dvi-recursive install-info-recursive \
+       uninstall-info-recursive all-recursive install-data-recursive \
+       install-exec-recursive installdirs-recursive install-recursive \
+       uninstall-recursive check-recursive installcheck-recursive
+DIST_COMMON = Makefile.am Makefile.in
+DIST_SUBDIRS = $(SUBDIRS)
+all: all-recursive
+
+.SUFFIXES:
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  include/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+
+# This directory's subdirectories are mostly independent; you can cd
+# into them and run `make' without going through this Makefile.
+# To change the values of `make' variables: instead of editing Makefiles,
+# (1) if the variable is set in `config.status', edit `config.status'
+#     (which will cause the Makefiles to be regenerated when you run `make');
+# (2) otherwise, pass the desired values on the `make' command line.
+$(RECURSIVE_TARGETS):
+       @set fnord $$MAKEFLAGS; amf=$$2; \
+       dot_seen=no; \
+       target=`echo $@ | sed s/-recursive//`; \
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         echo "Making $$target in $$subdir"; \
+         if test "$$subdir" = "."; then \
+           dot_seen=yes; \
+           local_target="$$target-am"; \
+         else \
+           local_target="$$target"; \
+         fi; \
+         (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+          || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
+       done; \
+       if test "$$dot_seen" = "no"; then \
+         $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
+       fi; test -z "$$fail"
+
+mostlyclean-recursive clean-recursive distclean-recursive \
+maintainer-clean-recursive:
+       @set fnord $$MAKEFLAGS; amf=$$2; \
+       dot_seen=no; \
+       case "$@" in \
+         distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
+         *) list='$(SUBDIRS)' ;; \
+       esac; \
+       rev=''; for subdir in $$list; do \
+         if test "$$subdir" = "."; then :; else \
+           rev="$$subdir $$rev"; \
+         fi; \
+       done; \
+       rev="$$rev ."; \
+       target=`echo $@ | sed s/-recursive//`; \
+       for subdir in $$rev; do \
+         echo "Making $$target in $$subdir"; \
+         if test "$$subdir" = "."; then \
+           local_target="$$target-am"; \
+         else \
+           local_target="$$target"; \
+         fi; \
+         (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+          || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
+       done && test -z "$$fail"
+tags-recursive:
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \
+       done
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS: tags-recursive $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         if test "$$subdir" = .; then :; else \
+           test -f $$subdir/TAGS && tags="$$tags -i $$here/$$subdir/TAGS"; \
+         fi; \
+       done; \
+       list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+       list='$(SUBDIRS)'; for subdir in $$list; do \
+         if test "$$subdir" = .; then :; else \
+           test -d $(distdir)/$$subdir \
+           || mkdir $(distdir)/$$subdir \
+           || exit 1; \
+           (cd $$subdir && \
+             $(MAKE) $(AM_MAKEFLAGS) \
+               top_distdir="$(top_distdir)" \
+               distdir=../$(distdir)/$$subdir \
+               distdir) \
+             || exit 1; \
+         fi; \
+       done
+check-am: all-am
+check: check-recursive
+all-am: Makefile
+installdirs: installdirs-recursive
+installdirs-am:
+
+install: install-recursive
+install-exec: install-exec-recursive
+install-data: install-data-recursive
+uninstall: uninstall-recursive
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-recursive
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-recursive
+
+clean-am: clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-recursive
+
+distclean-am: clean-am distclean-generic distclean-libtool \
+       distclean-tags
+
+dvi: dvi-recursive
+
+dvi-am:
+
+info: info-recursive
+
+info-am:
+
+install-data-am:
+
+install-exec-am:
+
+install-info: install-info-recursive
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-recursive
+
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-recursive
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+uninstall-am: uninstall-info-am
+
+uninstall-info: uninstall-info-recursive
+
+.PHONY: $(RECURSIVE_TARGETS) GTAGS all all-am check check-am clean \
+       clean-generic clean-libtool clean-recursive distclean \
+       distclean-generic distclean-libtool distclean-recursive \
+       distclean-tags distdir dvi dvi-am dvi-recursive info info-am \
+       info-recursive install install-am install-data install-data-am \
+       install-data-recursive install-exec install-exec-am \
+       install-exec-recursive install-info install-info-am \
+       install-info-recursive install-man install-recursive \
+       install-strip installcheck installcheck-am installdirs \
+       installdirs-am installdirs-recursive maintainer-clean \
+       maintainer-clean-generic maintainer-clean-recursive mostlyclean \
+       mostlyclean-generic mostlyclean-libtool mostlyclean-recursive \
+       tags tags-recursive uninstall uninstall-am uninstall-info-am \
+       uninstall-info-recursive uninstall-recursive
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/include/theora/Makefile.am b/include/theora/Makefile.am
new file mode 100644 (file)
index 0000000..5479e82
--- /dev/null
@@ -0,0 +1,7 @@
+## Process this file with automake to produce Makefile.in
+
+theoraincludedir = $(includedir)/theora
+
+theorainclude_HEADERS = theora.h theoradec.h theoraenc.h codec.h
+
+noinst_HEADERS = codec.h theoradec.h
diff --git a/include/theora/Makefile.in b/include/theora/Makefile.in
new file mode 100644 (file)
index 0000000..d20e60a
--- /dev/null
@@ -0,0 +1,355 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ../..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+
+theoraincludedir = $(includedir)/theora
+
+theorainclude_HEADERS = theora.h theoradec.h theoraenc.h codec.h
+
+noinst_HEADERS = codec.h theoradec.h
+subdir = include/theora
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES =
+DIST_SOURCES =
+HEADERS = $(noinst_HEADERS) $(theorainclude_HEADERS)
+
+DIST_COMMON = $(noinst_HEADERS) $(theorainclude_HEADERS) Makefile.am \
+       Makefile.in
+all: all-am
+
+.SUFFIXES:
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  include/theora/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+theoraincludeHEADERS_INSTALL = $(INSTALL_HEADER)
+install-theoraincludeHEADERS: $(theorainclude_HEADERS)
+       @$(NORMAL_INSTALL)
+       $(mkinstalldirs) $(DESTDIR)$(theoraincludedir)
+       @list='$(theorainclude_HEADERS)'; for p in $$list; do \
+         if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " $(theoraincludeHEADERS_INSTALL) $$d$$p $(DESTDIR)$(theoraincludedir)/$$f"; \
+         $(theoraincludeHEADERS_INSTALL) $$d$$p $(DESTDIR)$(theoraincludedir)/$$f; \
+       done
+
+uninstall-theoraincludeHEADERS:
+       @$(NORMAL_UNINSTALL)
+       @list='$(theorainclude_HEADERS)'; for p in $$list; do \
+         f="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " rm -f $(DESTDIR)$(theoraincludedir)/$$f"; \
+         rm -f $(DESTDIR)$(theoraincludedir)/$$f; \
+       done
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ../..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+check-am: all-am
+check: check-am
+all-am: Makefile $(HEADERS)
+
+installdirs:
+       $(mkinstalldirs) $(DESTDIR)$(theoraincludedir)
+
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-am
+
+distclean-am: clean-am distclean-generic distclean-libtool \
+       distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+info: info-am
+
+info-am:
+
+install-data-am: install-theoraincludeHEADERS
+
+install-exec-am:
+
+install-info: install-info-am
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+uninstall-am: uninstall-info-am uninstall-theoraincludeHEADERS
+
+.PHONY: GTAGS all all-am check check-am clean clean-generic \
+       clean-libtool distclean distclean-generic distclean-libtool \
+       distclean-tags distdir dvi dvi-am info info-am install \
+       install-am install-data install-data-am install-exec \
+       install-exec-am install-info install-info-am install-man \
+       install-strip install-theoraincludeHEADERS installcheck \
+       installcheck-am installdirs maintainer-clean \
+       maintainer-clean-generic mostlyclean mostlyclean-generic \
+       mostlyclean-libtool tags uninstall uninstall-am \
+       uninstall-info-am uninstall-theoraincludeHEADERS
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/include/theora/codec.h b/include/theora/codec.h
new file mode 100644 (file)
index 0000000..5c26696
--- /dev/null
@@ -0,0 +1,591 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: theora.h,v 1.8 2004/03/15 22:17:32 derf Exp $
+
+ ********************************************************************/
+
+/**\mainpage
+ * 
+ * \section intro Introduction
+ *
+ * This is the documentation for <tt>libtheora</tt> C API.
+ * The current reference
+ * implementation for <a href="http://www.theora.org/">Theora</a>, a free,
+ * patent-unencumbered video codec.
+ * Theora is derived from On2's VP3 codec with additional features and
+ *  integration with Ogg multimedia formats by
+ *  <a href="http://www.xiph.org/">the Xiph.Org Foundation</a>.
+ * Complete documentation of the format itself is available in
+ * <a href="http://www.theora.org/doc/Theora.pdf">the Theora
+ *  specification</a>.
+ *
+ * \subsection Organization
+ *
+ * The functions documented here are actually subdivided into three 
+ * separate libraries:
+ * - <tt>libtheoraenc</tt> contains the encoder interface,
+ *   described in \ref encfuncs.
+ * - <tt>libtheoradec</tt> contains the decoder interface and
+ *   routines shared with the encoder.
+ *   You must also link to this if you link to <tt>libtheoraenc</tt>.
+ *   The routines in this library are described in \ref decfuncs and 
+ *   \ref basefuncs.
+ * - <tt>libtheora</tt> contains the \ref oldfuncs.
+ *
+ * New code should link to <tt>libtheoradec</tt> and, if using encoder
+ * features, <tt>libtheoraenc</tt>. Together these two export both
+ * the standard and the legacy API, so this is all that is needed by
+ * any code. The older <tt>libtheora</tt> library is provided just for
+ * compatibility with older build configurations.
+ *
+ * In general the recommended 1.x API symbols can be distinguished
+ * by their <tt>th_</tt> or <tt>TH_</tt> namespace prefix.
+ * The older, legacy API uses <tt>theora_</tt> or <tt>OC_</tt>
+ * prefixes instead.
+ */
+
+/**\file
+ * The shared <tt>libtheoradec</tt> and <tt>libtheoraenc</tt> C API.
+ * You don't need to include this directly.*/
+
+#if !defined(_O_THEORA_CODEC_H_)
+# define _O_THEORA_CODEC_H_ (1)
+# include <ogg/ogg.h>
+
+#if defined(__cplusplus)
+extern "C" {
+#endif
+
+
+
+/**\name Return codes*/
+/*@{*/
+/**An invalid pointer was provided.*/
+#define TH_EFAULT     (-1)
+/**An invalid argument was provided.*/
+#define TH_EINVAL     (-10)
+/**The contents of the header were incomplete, invalid, or unexpected.*/
+#define TH_EBADHEADER (-20)
+/**The header does not belong to a Theora stream.*/
+#define TH_ENOTFORMAT (-21)
+/**The bitstream version is too high.*/
+#define TH_EVERSION   (-22)
+/**The specified function is not implemented.*/
+#define TH_EIMPL      (-23)
+/**There were errors in the video data packet.*/
+#define TH_EBADPACKET (-24)
+/**The decoded packet represented a dropped frame.
+   The player can continue to display the current frame, as the contents of the
+    decoded frame buffer have not changed.*/
+#define TH_DUPFRAME   (1)
+/*@}*/
+
+/**The currently defined color space tags.
+ * See <a href="http://www.theora.org/doc/Theora.pdf">the Theora
+ *  specification</a>, Chapter 4, for exact details on the meaning
+ *  of each of these color spaces.*/
+typedef enum{
+  /**The color space was not specified at the encoder.
+      It may be conveyed by an external means.*/
+  TH_CS_UNSPECIFIED,
+  /**A color space designed for NTSC content.*/
+  TH_CS_ITU_REC_470M,
+  /**A color space designed for PAL/SECAM content.*/
+  TH_CS_ITU_REC_470BG,
+  /**The total number of currently defined color spaces.*/
+  TH_CS_NSPACES
+}th_colorspace;
+
+/**The currently defined pixel format tags.
+ * See <a href="http://www.theora.org/doc/Theora.pdf">the Theora
+ *  specification</a>, Section 4.4, for details on the precise sample
+ *  locations.*/
+typedef enum{
+  /**Chroma decimation by 2 in both the X and Y directions (4:2:0).
+     The Cb and Cr chroma planes are half the width and half the
+      height of the luma plane.*/
+  TH_PF_420,
+  /**Currently reserved.*/
+  TH_PF_RSVD,
+  /**Chroma decimation by 2 in the X direction (4:2:2).
+     The Cb and Cr chroma planes are half the width of the luma plane, but full
+      height.*/
+  TH_PF_422,
+  /**No chroma decimation (4:4:4).
+     The Cb and Cr chroma planes are full width and full height.*/
+  TH_PF_444,
+  /**The total number of currently defined pixel formats.*/
+  TH_PF_NFORMATS
+}th_pixel_fmt;
+
+
+
+/**A buffer for a single color plane in an uncompressed image.
+ * This contains the image data in a left-to-right, top-down format.
+ * Each row of pixels is stored contiguously in memory, but successive
+ *  rows need not be.
+ * Use \a stride to compute the offset of the next row.
+ * The encoder accepts both positive \a stride values (top-down in memory)
+ *  and negative (bottom-up in memory).
+ * The decoder currently always generates images with positive strides.*/
+typedef struct{
+  /**The width of this plane.*/
+  int            width;
+  /**The height of this plane.*/
+  int            height;
+  /**The offset in bytes between successive rows.*/
+  int            stride;
+  /**A pointer to the beginning of the first row.*/
+  unsigned char *data;
+}th_img_plane;
+
+/**A complete image buffer for an uncompressed frame.
+ * The chroma planes may be decimated by a factor of two in either
+ *  direction, as indicated by th_info#pixel_fmt.
+ * The width and height of the Y' plane must be multiples of 16.
+ * They may need to be cropped for display, using the rectangle
+ *  specified by th_info#pic_x, th_info#pic_y, th_info#pic_width,
+ *  and th_info#pic_height.
+ * All samples are 8 bits.
+ * \note The term YUV often used to describe a colorspace is ambiguous.
+ * The exact parameters of the RGB to YUV conversion process aside, in
+ *  many contexts the U and V channels actually have opposite meanings.
+ * To avoid this confusion, we are explicit: the name of the color
+ *  channels are Y'CbCr, and they appear in that order, always.
+ * The prime symbol denotes that the Y channel is non-linear.
+ * Cb and Cr stand for "Chroma blue" and "Chroma red", respectively.*/
+typedef th_img_plane th_ycbcr_buffer[3];
+
+/**Theora bitstream information.
+ * This contains the basic playback parameters for a stream, and corresponds to 
+ *  the initial 'info' header packet.
+ * To initialize an encoder, the application fills in this structure and
+ *  passes it to th_encode_alloc().
+ * A default encoding mode is chosen based on the values of the #quality and
+ *  #target_bitrate fields.
+ * On decode, it is filled in by th_decode_headerin(), and then passed to
+ *  th_decode_alloc().
+ *
+ * Encoded Theora frames must be a multiple of 16 in size;
+ *  this is what the #frame_width and #frame_height members represent.
+ * To handle arbitrary picture sizes, a crop rectangle is specified in the
+ *  #pic_x, #pic_y, #pic_width and #pic_height members.
+ *
+ * All frame buffers contain pointers to the full, padded frame.
+ * However, the current encoder <em>will not</em> reference pixels outside of
+ *  the cropped picture region, and the application does not need to fill them
+ *  in.
+ * The decoder <em>will</em> allocate storage for a full frame, but the
+ *  application <em>should not</em> rely on the padding containing sensible
+ *  data.
+ *
+ * It is also generally recommended that the offsets and sizes should still be
+ *  multiples of 2 to avoid chroma sampling shifts when chroma is sub-sampled.
+ * See <a href="http://www.theora.org/doc/Theora.pdf">the Theora
+ *  specification</a>, Section 4.4, for more details.
+ *
+ * Frame rate, in frames per second, is stored as a rational fraction, as is
+ *  the pixel aspect ratio.
+ * Note that this refers to the aspect ratio of the individual pixels, not of
+ *  the overall frame itself.
+ * The frame aspect ratio can be computed from pixel aspect ratio using the
+ *  image dimensions.*/
+typedef struct{
+  /**\name Theora version
+   * Bitstream version information.*/
+  /*@{*/
+  unsigned char version_major;
+  unsigned char version_minor;
+  unsigned char version_subminor;
+  /*@}*/
+  /**The encoded frame width.
+   * This must be a multiple of 16, and less than 1048576.*/
+  ogg_uint32_t  frame_width;
+  /**The encoded frame height.
+   * This must be a multiple of 16, and less than 1048576.*/
+  ogg_uint32_t  frame_height;
+  /**The displayed picture width.
+   * This must be no larger than width.*/
+  ogg_uint32_t  pic_width;
+  /**The displayed picture height.
+   * This must be no larger than height.*/
+  ogg_uint32_t  pic_height;
+  /**The X offset of the displayed picture.
+   * This must be no larger than #frame_width-#pic_width or 255, whichever is
+   *  smaller.*/
+  ogg_uint32_t  pic_x;
+  /**The Y offset of the displayed picture.
+   * This must be no larger than #frame_height-#pic_height, and
+   *  #frame_height-#pic_height-#pic_y must be no larger than 255.
+   * This slightly funny restriction is due to the fact that the offset is
+   *  specified from the top of the image for consistency with the standard
+   *  graphics left-handed coordinate system used throughout this API, while
+   *  it is stored in the encoded stream as an offset from the bottom.*/
+  ogg_uint32_t  pic_y;
+  /**\name Frame rate
+   * The frame rate, as a fraction.
+   * If either is 0, the frame rate is undefined.*/
+  /*@{*/
+  ogg_uint32_t  fps_numerator;
+  ogg_uint32_t  fps_denominator;
+  /*@}*/
+  /**\name Aspect ratio
+   * The aspect ratio of the pixels.
+   * If either value is zero, the aspect ratio is undefined.
+   * If not specified by any external means, 1:1 should be assumed.
+   * The aspect ratio of the full picture can be computed as
+   * \code
+   *  aspect_numerator*pic_width/(aspect_denominator*pic_height).
+   * \endcode */
+  /*@{*/
+  ogg_uint32_t  aspect_numerator;
+  ogg_uint32_t  aspect_denominator;
+  /*@}*/
+  /**The color space.*/
+  th_colorspace colorspace;
+  /**The pixel format.*/
+  th_pixel_fmt  pixel_fmt;
+  /**The target bit-rate in bits per second.
+     If initializing an encoder with this struct, set this field to a non-zero
+      value to activate CBR encoding by default.*/
+  int           target_bitrate;
+  /**The target quality level.
+     Valid values range from 0 to 63, inclusive, with higher values giving
+      higher quality.
+     If initializing an encoder with this struct, and #target_bitrate is set
+      to zero, VBR encoding at this quality will be activated by default.*/
+  /*Currently this is set so that a qi of 0 corresponds to distortions of 24
+     times the JND, and each increase by 16 halves that value.
+    This gives us fine discrimination at low qualities, yet effective rate
+     control at high qualities.
+    The qi value 63 is special, however.
+    For this, the highest quality, we use one half of a JND for our threshold.
+    Due to the lower bounds placed on allowable quantizers in Theora, we will
+     not actually be able to achieve quality this good, but this should
+     provide as close to visually lossless quality as Theora is capable of.
+    We could lift the quantizer restrictions without breaking VP3.1
+     compatibility, but this would result in quantized coefficients that are
+     too large for the current bitstream to be able to store.
+    We'd have to redesign the token syntax to store these large coefficients,
+     which would make transcoding complex.*/
+  int           quality;
+  /**The amount to shift to extract the last keyframe number from the granule
+   *  position.
+   * This can be at most 31.
+   * th_info_init() will set this to a default value (currently <tt>6</tt>,
+   *  which is good for streaming applications), but you can set it to 0 to
+   *  make every frame a keyframe.
+   * The maximum distance between key frames is
+   *  <tt>1<<#keyframe_granule_shift</tt>.
+   * The keyframe frequency can be more finely controlled with
+   *  #TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE, which can also be adjusted
+   *  during encoding (for example, to force the next frame to be a keyframe),
+   *  but it cannot be set larger than the amount permitted by this field after
+   *  the headers have been output.*/
+  int           keyframe_granule_shift;
+}th_info;
+
+/**The comment information.
+ *
+ * This structure holds the in-stream metadata corresponding to
+ *  the 'comment' header packet.
+ * The comment header is meant to be used much like someone jotting a quick
+ *  note on the label of a video.
+ * It should be a short, to the point text note that can be more than a couple
+ *  words, but not more than a short paragraph.
+ *
+ * The metadata is stored as a series of (tag, value) pairs, in
+ *  length-encoded string vectors.
+ * The first occurrence of the '=' character delimits the tag and value.
+ * A particular tag may occur more than once, and order is significant.
+ * The character set encoding for the strings is always UTF-8, but the tag
+ *  names are limited to ASCII, and treated as case-insensitive.
+ * See <a href="http://www.theora.org/doc/Theora.pdf">the Theora
+ *  specification</a>, Section 6.3.3 for details.
+ *
+ * In filling in this structure, th_decode_headerin() will null-terminate
+ *  the user_comment strings for safety.
+ * However, the bitstream format itself treats them as 8-bit clean vectors,
+ *  possibly containing null characters, and so the length array should be
+ *  treated as their authoritative length.
+ */
+typedef struct th_comment{
+  /**The array of comment string vectors.*/
+  char **user_comments;
+  /**An array of the corresponding length of each vector, in bytes.*/
+  int   *comment_lengths;
+  /**The total number of comment strings.*/
+  int    comments;
+  /**The null-terminated vendor string.
+     This identifies the software used to encode the stream.*/
+  char  *vendor;
+}th_comment;
+
+
+
+/**A single base matrix.*/
+typedef unsigned char th_quant_base[64];
+
+/**A set of \a qi ranges.*/
+typedef struct{
+  /**The number of ranges in the set.*/
+  int                  nranges;
+  /**The size of each of the #nranges ranges.
+     These must sum to 63.*/
+  const int           *sizes;
+  /**#nranges <tt>+1</tt> base matrices.
+     Matrices \a i and <tt>i+1</tt> form the endpoints of range \a i.*/
+  const th_quant_base *base_matrices;
+}th_quant_ranges;
+
+/**A complete set of quantization parameters.
+   The quantizer for each coefficient is calculated as:
+   \code
+    Q=MAX(MIN(qmin[qti][ci!=0],scale[ci!=0][qi]*base[qti][pli][qi][ci]/100),
+     1024).
+   \endcode
+
+   \a qti is the quantization type index: 0 for intra, 1 for inter.
+   <tt>ci!=0</tt> is 0 for the DC coefficient and 1 for AC coefficients.
+   \a qi is the quality index, ranging between 0 (low quality) and 63 (high
+    quality).
+   \a pli is the color plane index: 0 for Y', 1 for Cb, 2 for Cr.
+   \a ci is the DCT coefficient index.
+   Coefficient indices correspond to the normal 2D DCT block
+    ordering--row-major with low frequencies first--\em not zig-zag order.
+
+   Minimum quantizers are constant, and are given by:
+   \code
+   qmin[2][2]={{4,2},{8,4}}.
+   \endcode
+
+   Parameters that can be stored in the bitstream are as follows:
+    - The two scale matrices ac_scale and dc_scale.
+      \code
+      scale[2][64]={dc_scale,ac_scale}.
+      \endcode
+    - The base matrices for each \a qi, \a qti and \a pli (up to 384 in all).
+      In order to avoid storing a full 384 base matrices, only a sparse set of
+       matrices are stored, and the rest are linearly interpolated.
+      This is done as follows.
+      For each \a qti and \a pli, a series of \a n \a qi ranges is defined.
+      The size of each \a qi range can vary arbitrarily, but they must sum to
+       63.
+      Then, <tt>n+1</tt> matrices are specified, one for each endpoint of the
+       ranges.
+      For interpolation purposes, each range's endpoints are the first \a qi
+       value it contains and one past the last \a qi value it contains.
+      Fractional values are rounded to the nearest integer, with ties rounded
+       away from zero.
+
+      Base matrices are stored by reference, so if the same matrices are used
+       multiple times, they will only appear once in the bitstream.
+      The bitstream is also capable of omitting an entire set of ranges and
+       its associated matrices if they are the same as either the previous
+       set (indexed in row-major order) or if the inter set is the same as the
+       intra set.
+
+    - Loop filter limit values.
+      The same limits are used for the loop filter in all color planes, despite
+       potentially differing levels of quantization in each.
+
+   For the current encoder, <tt>scale[ci!=0][qi]</tt> must be no greater
+    than <tt>scale[ci!=0][qi-1]</tt> and <tt>base[qti][pli][qi][ci]</tt> must
+    be no greater than <tt>base[qti][pli][qi-1][ci]</tt>.
+   These two conditions ensure that the actual quantizer for a given \a qti,
+    \a pli, and \a ci does not increase as \a qi increases.
+   This is not required by the decoder.*/
+typedef struct{
+  /**The DC scaling factors.*/
+  ogg_uint16_t    dc_scale[64];
+  /**The AC scaling factors.*/
+  ogg_uint16_t    ac_scale[64];
+  /**The loop filter limit values.*/
+  unsigned char   loop_filter_limits[64];
+  /**The \a qi ranges for each \a ci and \a pli.*/
+  th_quant_ranges qi_ranges[2][3];
+}th_quant_info;
+
+
+
+/**The number of Huffman tables used by Theora.*/
+#define TH_NHUFFMAN_TABLES (80)
+/**The number of DCT token values in each table.*/
+#define TH_NDCT_TOKENS     (32)
+
+/**A Huffman code for a Theora DCT token.
+ * Each set of Huffman codes in a given table must form a complete, prefix-free
+ *  code.
+ * There is no requirement that all the tokens in a table have a valid code,
+ *  but the current encoder is not optimized to take advantage of this.
+ * If each of the five grouops of 16 tables does not contain at least one table
+ *  with a code for every token, then the encoder may fail to encode certain
+ *  frames.
+ * The complete table in the first group of 16 does not have to be in the same
+ *  place as the complete table in the other groups, but the complete tables in
+ *  the remaining four groups must all be in the same place.*/
+typedef struct{
+  /**The bit pattern for the code, with the LSbit of the pattern aligned in
+   *   the LSbit of the word.*/
+  ogg_uint32_t pattern;
+  /**The number of bits in the code.
+   * This must be between 0 and 32, inclusive.*/
+  int          nbits;
+}th_huff_code;
+
+
+
+/**\defgroup basefuncs Functions Shared by Encode and Decode*/
+/*@{*/
+/**\name Basic shared functions*/
+/*@{*/
+/**Retrieves a human-readable string to identify the library vendor and
+ *  version.
+ * \return the version string.*/
+extern const char *th_version_string(void);
+/**Retrieves the library version number.
+ * This is the highest bitstream version that the encoder library will produce,
+ *  or that the decoder library can decode.
+ * This number is composed of a 16-bit major version, 8-bit minor version
+ * and 8 bit sub-version, composed as follows:
+ * \code
+ * (VERSION_MAJOR<<16)+(VERSION_MINOR<<8)+(VERSION_SUBMINOR)
+ * \endcode
+ * \return the version number.*/
+extern ogg_uint32_t th_version_number(void);
+/**Converts a granule position to an absolute frame index, starting at
+ *  <tt>0</tt>.
+ * The granule position is interpreted in the context of a given
+ *  #th_enc_ctx or #th_dec_ctx handle (either will suffice).
+ * \param _encdec  A previously allocated #th_enc_ctx or #th_dec_ctx
+ *                  handle.
+ * \param _granpos The granule position to convert.
+ * \returns The absolute frame index corresponding to \a _granpos.
+ * \retval -1 The given granule position was invalid (i.e. negative).*/
+extern ogg_int64_t th_granule_frame(void *_encdec,ogg_int64_t _granpos);
+/**Converts a granule position to an absolute time in seconds.
+ * The granule position is interpreted in the context of a given
+ *  #th_enc_ctx or #th_dec_ctx handle (either will suffice).
+ * \param _encdec  A previously allocated #th_enc_ctx or #th_dec_ctx
+ *                  handle.
+ * \param _granpos The granule position to convert.
+ * \return The absolute time in seconds corresponding to \a _granpos.
+ *         This is the "end time" for the frame, or the latest time it should
+ *          be displayed.
+ *         It is not the presentation time.
+ * \retval -1 The given granule position was invalid (i.e. negative).*/
+extern double th_granule_time(void *_encdec,ogg_int64_t _granpos);
+/**Determines whether a Theora packet is a header or not.
+ * This function does no verification beyond checking the packet type bit, so
+ *  it should not be used for bitstream identification; use
+ *  th_decode_headerin() for that.
+ * As per the Theora specification, an empty (0-byte) packet is treated as a
+ *  data packet (a delta frame with no coded blocks).
+ * \param _op An <tt>ogg_packet</tt> containing encoded Theora data.
+ * \retval 1 The packet is a header packet
+ * \retval 0 The packet is a video data packet.*/
+extern int th_packet_isheader(ogg_packet *_op);
+/**Determines whether a theora packet is a key frame or not.
+ * This function does no verification beyond checking the packet type and
+ *  key frame bits, so it should not be used for bitstream identification; use
+ *  th_decode_headerin() for that.
+ * As per the Theora specification, an empty (0-byte) packet is treated as a
+ *  delta frame (with no coded blocks).
+ * \param _op An <tt>ogg_packet</tt> containing encoded Theora data.
+ * \retval 1  The packet contains a key frame.
+ * \retval 0  The packet contains a delta frame.
+ * \retval -1 The packet is not a video data packet.*/
+extern int th_packet_iskeyframe(ogg_packet *_op);
+/*@}*/
+
+
+/**\name Functions for manipulating header data*/
+/*@{*/
+/**Initializes a th_info structure.
+ * This should be called on a freshly allocated #th_info structure before
+ *  attempting to use it.
+ * \param _info The #th_info struct to initialize.*/
+extern void th_info_init(th_info *_info);
+/**Clears a #th_info structure.
+ * This should be called on a #th_info structure after it is no longer
+ *  needed.
+ * \param _info The #th_info struct to clear.*/
+extern void th_info_clear(th_info *_info);
+
+/**Initialize a #th_comment structure.
+ * This should be called on a freshly allocated #th_comment structure
+ *  before attempting to use it.
+ * \param _tc The #th_comment struct to initialize.*/
+extern void th_comment_init(th_comment *_tc);
+/**Add a comment to an initialized #th_comment structure.
+ * \note Neither th_comment_add() nor th_comment_add_tag() support
+ *  comments containing null values, although the bitstream format does
+ *  support them.
+ * To add such comments you will need to manipulate the #th_comment
+ *  structure directly.
+ * \param _tc      The #th_comment struct to add the comment to.
+ * \param _comment Must be a null-terminated UTF-8 string containing the
+ *                  comment in "TAG=the value" form.*/
+extern void th_comment_add(th_comment *_tc, char *_comment);
+/**Add a comment to an initialized #th_comment structure.
+ * \note Neither th_comment_add() nor th_comment_add_tag() support
+ *  comments containing null values, although the bitstream format does
+ *  support them.
+ * To add such comments you will need to manipulate the #th_comment
+ *  structure directly.
+ * \param _tc  The #th_comment struct to add the comment to.
+ * \param _tag A null-terminated string containing the tag  associated with
+ *              the comment.
+ * \param _val The corresponding value as a null-terminated string.*/
+extern void th_comment_add_tag(th_comment *_tc,char *_tag,char *_val);
+/**Look up a comment value by its tag.
+ * \param _tc    An initialized #th_comment structure.
+ * \param _tag   The tag to look up.
+ * \param _count The instance of the tag.
+ *               The same tag can appear multiple times, each with a distinct
+ *                value, so an index is required to retrieve them all.
+ *               The order in which these values appear is significant and
+ *                should be preserved.
+ *               Use th_comment_query_count() to get the legal range for
+ *                the \a _count parameter.
+ * \return A pointer to the queried tag's value.
+ *         This points directly to data in the #th_comment structure.
+ *         It should not be modified or freed by the application, and
+ *          modifications to the structure may invalidate the pointer.
+ * \retval NULL If no matching tag is found.*/
+extern char *th_comment_query(th_comment *_tc,char *_tag,int _count);
+/**Look up the number of instances of a tag.
+ * Call this first when querying for a specific tag and then iterate over the
+ *  number of instances with separate calls to th_comment_query() to
+ *  retrieve all the values for that tag in order.
+ * \param _tc    An initialized #th_comment structure.
+ * \param _tag   The tag to look up.
+ * \return The number on instances of this particular tag.*/
+extern int th_comment_query_count(th_comment *_tc,char *_tag);
+/**Clears a #th_comment structure.
+ * This should be called on a #th_comment structure after it is no longer
+ *  needed.
+ * It will free all memory used by the structure members.
+ * \param _tc The #th_comment struct to clear.*/
+extern void th_comment_clear(th_comment *_tc);
+/*@}*/
+/*@}*/
+
+
+
+#if defined(__cplusplus)
+}
+#endif
+
+#endif
diff --git a/include/theora/theora.h b/include/theora/theora.h
new file mode 100644 (file)
index 0000000..af6eb6f
--- /dev/null
@@ -0,0 +1,784 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: theora.h,v 1.17 2003/12/06 18:06:19 arc Exp $
+
+ ********************************************************************/
+
+#ifndef _O_THEORA_H_
+#define _O_THEORA_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif /* __cplusplus */
+
+#include <stddef.h>    /* for size_t */
+
+#include <ogg/ogg.h>
+
+/** \file
+ * The libtheora pre-1.0 legacy C API.
+ *
+ * \ingroup oldfuncs
+ *
+ * \section intro Introduction
+ *
+ * This is the documentation for the libtheora legacy C API, declared in 
+ * the theora.h header, which describes the old interface used before
+ * the 1.0 release. This API was widely deployed for several years and
+ * remains supported, but for new code we recommend the cleaner API 
+ * declared in theoradec.h and theoraenc.h.
+ *
+ * libtheora is the reference implementation for
+ * <a href="http://www.theora.org/">Theora</a>, a free video codec.
+ * Theora is derived from On2's VP3 codec with improved integration with
+ * Ogg multimedia formats by <a href="http://www.xiph.org/">Xiph.Org</a>.
+ * 
+ * \section overview Overview
+ *
+ * This library will both decode and encode theora packets to/from raw YUV 
+ * frames.  In either case, the packets will most likely either come from or
+ * need to be embedded in an Ogg stream.  Use 
+ * <a href="http://xiph.org/ogg/">libogg</a> or 
+ * <a href="http://www.annodex.net/software/liboggz/index.html">liboggz</a>
+ * to extract/package these packets.
+ *
+ * \section decoding Decoding Process
+ *
+ * Decoding can be separated into the following steps:
+ * -# initialise theora_info and theora_comment structures using 
+ *    theora_info_init() and theora_comment_init():
+ \verbatim
+ theora_info     info;
+ theora_comment  comment;
+   
+ theora_info_init(&info);
+ theora_comment_init(&comment);
+ \endverbatim
+ * -# retrieve header packets from Ogg stream (there should be 3) and decode 
+ *    into theora_info and theora_comment structures using 
+ *    theora_decode_header().  See \ref identification for more information on 
+ *    identifying which packets are theora packets.
+ \verbatim
+ int i;
+ for (i = 0; i < 3; i++)
+ {
+   (get a theora packet "op" from the Ogg stream)
+   theora_decode_header(&info, &comment, op);
+ }
+ \endverbatim
+ * -# initialise the decoder based on the information retrieved into the
+ *    theora_info struct by theora_decode_header().  You will need a 
+ *    theora_state struct.
+ \verbatim
+ theora_state state;
+ theora_decode_init(&state, &info);
+ \endverbatim
+ * -# pass in packets and retrieve decoded frames!  See the yuv_buffer 
+ *    documentation for information on how to retrieve raw YUV data.
+ \verbatim
+ yuf_buffer buffer;
+ while (last packet was not e_o_s) {
+   (get a theora packet "op" from the Ogg stream)
+   theora_decode_packetin(&state, op);
+   theora_decode_YUVout(&state, &buffer);
+ }
+ \endverbatim
+ *  
+ *
+ * \subsection identification Identifying Theora Packets
+ *
+ * All streams inside an Ogg file have a unique serial_no attached to the 
+ * stream.  Typically, you will want to 
+ *  - retrieve the serial_no for each b_o_s (beginning of stream) page 
+ *    encountered within the Ogg file; 
+ *  - test the first (only) packet on that page to determine if it is a theora 
+ *    packet;
+ *  - once you have found a theora b_o_s page then use the retrieved serial_no 
+ *    to identify future packets belonging to the same theora stream.
+ * 
+ * Note that you \e cannot use theora_packet_isheader() to determine if a 
+ * packet is a theora packet or not, as this function does not perform any
+ * checking beyond whether a header bit is present.  Instead, use the
+ * theora_decode_header() function and check the return value; or examine the
+ * header bytes at the beginning of the Ogg page.
+ */
+
+
+/** \defgroup oldfuncs Legacy pre-1.0 C API */
+/*  @{ */
+
+/**
+ * A YUV buffer for passing uncompressed frames to and from the codec.
+ * This holds a Y'CbCr frame in planar format. The CbCr planes can be
+ * subsampled and have their own separate dimensions and row stride
+ * offsets. Note that the strides may be negative in some 
+ * configurations. For theora the width and height of the largest plane
+ * must be a multiple of 16. The actual meaningful picture size and 
+ * offset are stored in the theora_info structure; frames returned by
+ * the decoder may need to be cropped for display.
+ *
+ * All samples are 8 bits. Within each plane samples are ordered by
+ * row from the top of the frame to the bottom. Within each row samples
+ * are ordered from left to right.
+ *
+ * During decode, the yuv_buffer struct is allocated by the user, but all
+ * fields (including luma and chroma pointers) are filled by the library.  
+ * These pointers address library-internal memory and their contents should 
+ * not be modified.
+ *
+ * Conversely, during encode the user allocates the struct and fills out all
+ * fields.  The user also manages the data addressed by the luma and chroma
+ * pointers.  See the encoder_example.c and dump_video.c example files in
+ * theora/examples/ for more information.
+ */
+typedef struct {
+    int   y_width;      /**< Width of the Y' luminance plane */
+    int   y_height;     /**< Height of the luminance plane */
+    int   y_stride;     /**< Offset in bytes between successive rows */
+
+    int   uv_width;     /**< Width of the Cb and Cr chroma planes */
+    int   uv_height;    /**< Height of the chroma planes */
+    int   uv_stride;    /**< Offset between successive chroma rows */
+    unsigned char *y;   /**< Pointer to start of luminance data */
+    unsigned char *u;   /**< Pointer to start of Cb data */
+    unsigned char *v;   /**< Pointer to start of Cr data */
+
+} yuv_buffer;
+
+/**
+ * A Colorspace.
+ */
+typedef enum {
+  OC_CS_UNSPECIFIED,    /**< The colorspace is unknown or unspecified */
+  OC_CS_ITU_REC_470M,   /**< This is the best option for 'NTSC' content */
+  OC_CS_ITU_REC_470BG,  /**< This is the best option for 'PAL' content */
+  OC_CS_NSPACES         /**< This marks the end of the defined colorspaces */
+} theora_colorspace;
+
+/**
+ * A Chroma subsampling
+ *
+ * These enumerate the available chroma subsampling options supported
+ * by the theora format. See Section 4.4 of the specification for
+ * exact definitions.
+ */
+typedef enum {
+  OC_PF_420,    /**< Chroma subsampling by 2 in each direction (4:2:0) */
+  OC_PF_RSVD,   /**< Reserved value */
+  OC_PF_422,    /**< Horizonatal chroma subsampling by 2 (4:2:2) */
+  OC_PF_444,    /**< No chroma subsampling at all (4:4:4) */
+} theora_pixelformat;
+
+/**
+ * Theora bitstream info.
+ * Contains the basic playback parameters for a stream,
+ * corresponding to the initial 'info' header packet.
+ * 
+ * Encoded theora frames must be a multiple of 16 in width and height.
+ * To handle other frame sizes, a crop rectangle is specified in
+ * frame_height and frame_width, offset_x and * offset_y. The offset
+ * and size should still be a multiple of 2 to avoid chroma sampling
+ * shifts. Offset values in this structure are measured from the
+ * upper left of the image.
+ *
+ * Frame rate, in frames per second, is stored as a rational
+ * fraction. Aspect ratio is also stored as a rational fraction, and
+ * refers to the aspect ratio of the frame pixels, not of the
+ * overall frame itself.
+ * 
+ * See <a href="http://svn.xiph.org/trunk/theora/examples/encoder_example.c">
+ * examples/encoder_example.c</a> for usage examples of the
+ * other paramters and good default settings for the encoder parameters.
+ */
+typedef struct {
+  ogg_uint32_t  width;         /**< encoded frame width  */
+  ogg_uint32_t  height;                /**< encoded frame height */
+  ogg_uint32_t  frame_width;   /**< display frame width  */
+  ogg_uint32_t  frame_height;  /**< display frame height */
+  ogg_uint32_t  offset_x;      /**< horizontal offset of the displayed frame */
+  ogg_uint32_t  offset_y;      /**< vertical offset of the displayed frame */
+  ogg_uint32_t  fps_numerator;     /**< frame rate numerator **/
+  ogg_uint32_t  fps_denominator;    /**< frame rate denominator **/
+  ogg_uint32_t  aspect_numerator;   /**< pixel aspect ratio numerator */
+  ogg_uint32_t  aspect_denominator; /**< pixel aspect ratio denominator */
+  theora_colorspace colorspace;            /**< colorspace */
+  int           target_bitrate;            /**< nominal bitrate in bits per second */
+  int           quality;  /**< Nominal quality setting, 0-63 */
+  int           quick_p;  /**< Quick encode/decode */
+
+  /* decode only */
+  unsigned char version_major;
+  unsigned char version_minor;
+  unsigned char version_subminor;
+
+  void *codec_setup;
+
+  /* encode only */
+  int           dropframes_p;
+  int           keyframe_auto_p;
+  ogg_uint32_t  keyframe_frequency;
+  ogg_uint32_t  keyframe_frequency_force;  /* also used for decode init to
+                                              get granpos shift correct */
+  ogg_uint32_t  keyframe_data_target_bitrate;
+  ogg_int32_t   keyframe_auto_threshold;
+  ogg_uint32_t  keyframe_mindistance;
+  ogg_int32_t   noise_sensitivity;
+  ogg_int32_t   sharpness;
+
+  theora_pixelformat pixelformat;      /**< chroma subsampling mode to expect */
+
+} theora_info;
+
+/** Codec internal state and context.
+ */
+typedef struct{
+  theora_info *i;
+  ogg_int64_t granulepos;
+
+  void *internal_encode;
+  void *internal_decode;
+
+} theora_state;
+
+/** 
+ * Comment header metadata.
+ *
+ * This structure holds the in-stream metadata corresponding to
+ * the 'comment' header packet.
+ *
+ * Meta data is stored as a series of (tag, value) pairs, in
+ * length-encoded string vectors. The first occurence of the 
+ * '=' character delimits the tag and value. A particular tag
+ * may occur more than once. The character set encoding for
+ * the strings is always UTF-8, but the tag names are limited
+ * to case-insensitive ASCII. See the spec for details.
+ *
+ * In filling in this structure, theora_decode_header() will
+ * null-terminate the user_comment strings for safety. However,
+ * the bitstream format itself treats them as 8-bit clean,
+ * and so the length array should be treated as authoritative
+ * for their length.
+ */
+typedef struct theora_comment{
+  char **user_comments;         /**< An array of comment string vectors */
+  int   *comment_lengths;       /**< An array of corresponding string vector lengths in bytes */
+  int    comments;              /**< The total number of comment string vectors */
+  char  *vendor;                /**< The vendor string identifying the encoder, null terminated */
+
+} theora_comment;
+
+
+/**\name theora_control() codes */
+/* \anchor decctlcodes_old
+ * These are the available request codes for theora_control()
+ * when called with a decoder instance.
+ * By convention decoder control codes are odd, to distinguish 
+ * them from \ref encctlcodes_old "encoder control codes" which
+ * are even.
+ *
+ * Note that since the 1.0 release, both the legacy and the final
+ * implementation accept all the same control codes, but only the
+ * final API declares the newer codes.
+ *
+ * Keep any experimental or vendor-specific values above \c 0x8000.*/
+
+/*@{*/
+
+/**Get the maximum post-processing level.
+ * The decoder supports a post-processing filter that can improve
+ * the appearance of the decoded images. This returns the highest
+ * level setting for this post-processor, corresponding to maximum
+ * improvement and computational expense.
+ */
+#define TH_DECCTL_GET_PPLEVEL_MAX (1)
+
+/**Set the post-processing level.
+ * Sets the level of post-processing to use when decoding the 
+ * compressed stream. This must be a value between zero (off)
+ * and the maximum returned by TH_DECCTL_GET_PPLEVEL_MAX.
+ */
+#define TH_DECCTL_SET_PPLEVEL (3)
+
+/**Sets the maximum distance between key frames.
+ * This can be changed during an encode, but will be bounded by
+ *  <tt>1<<th_info#keyframe_granule_shift</tt>.
+ * If it is set before encoding begins, th_info#keyframe_granule_shift will
+ *  be enlarged appropriately.
+ *
+ * \param[in]  buf <tt>ogg_uint32_t</tt>: The maximum distance between key
+ *                   frames.
+ * \param[out] buf <tt>ogg_uint32_t</tt>: The actual maximum distance set.
+ * \retval OC_FAULT  \a theora_state or \a buf is <tt>NULL</tt>.
+ * \retval OC_EINVAL \a buf_sz is not <tt>sizeof(ogg_uint32_t)</tt>.
+ * \retval OC_IMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE (4)
+
+/**Set the granule position.
+ * Call this after a seek, to update the internal granulepos
+ * in the decoder, to insure that subsequent frames are marked
+ * properly. If you track timestamps yourself and do not use
+ * the granule postion returned by the decoder, then you do
+ * not need to use this control.
+ */
+#define TH_DECCTL_SET_GRANPOS (5)
+
+/**\anchor encctlcodes_old */
+
+/**Sets the quantization parameters to use.
+ * The parameters are copied, not stored by reference, so they can be freed
+ *  after this call.
+ * <tt>NULL</tt> may be specified to revert to the default parameters.
+ *
+ * \param[in] buf #th_quant_info
+ * \retval OC_FAULT  \a theora_state is <tt>NULL</tt>.
+ * \retval OC_EINVAL Encoding has already begun, the quantization parameters
+ *                    are not acceptable to this version of the encoder, 
+ *                    \a buf is <tt>NULL</tt> and \a buf_sz is not zero, 
+ *                    or \a buf is non-<tt>NULL</tt> and \a buf_sz is 
+ *                    not <tt>sizeof(#th_quant_info)</tt>.
+ * \retval OC_IMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_SET_QUANT_PARAMS (2)
+
+/**Disables any encoder features that would prevent lossless transcoding back
+ *  to VP3.
+ * This primarily means disabling block-level QI values and not using 4MV mode
+ *  when any of the luma blocks in a macro block are not coded.
+ * It also includes using the VP3 quantization tables and Huffman codes; if you
+ *  set them explicitly after calling this function, the resulting stream will
+ *  not be VP3-compatible.
+ * If you enable VP3-compatibility when encoding 4:2:2 or 4:4:4 source
+ *  material, or when using a picture region smaller than the full frame (e.g.
+ *  a non-multiple-of-16 width or height), then non-VP3 bitstream features will
+ *  still be disabled, but the stream will still not be VP3-compatible, as VP3
+ *  was not capable of encoding such formats.
+ * If you call this after encoding has already begun, then the quantization
+ *  tables and codebooks cannot be changed, but the frame-level features will
+ *  be enabled or disabled as requested.
+ *
+ * \param[in]  buf <tt>int</tt>: a non-zero value to enable VP3 compatibility,
+ *                   or 0 to disable it (the default).
+ * \param[out] buf <tt>int</tt>: 1 if all bitstream features required for
+ *                   VP3-compatibility could be set, and 0 otherwise.
+ *                  The latter will be returned if the pixel format is not
+ *                   4:2:0, the picture region is smaller than the full frame,
+ *                   or if encoding has begun, preventing the quantization
+ *                   tables and codebooks from being set.
+ * \retval OC_FAULT  \a theora_state or \a buf is <tt>NULL</tt>.
+ * \retval OC_EINVAL \a buf_sz is not <tt>sizeof(int)</tt>.
+ * \retval OC_IMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_SET_VP3_COMPATIBLE (10)
+
+/**Gets the maximum speed level.
+ * Higher speed levels favor quicker encoding over better quality per bit.
+ * Depending on the encoding mode, and the internal algorithms used, quality
+ *  may actually improve, but in this case bitrate will also likely increase.
+ * In any case, overall rate/distortion performance will probably decrease.
+ * The maximum value, and the meaning of each value, may change depending on
+ *  the current encoding mode (VBR vs. CQI, etc.).
+ *
+ * \param[out] buf int: The maximum encoding speed level.
+ * \retval OC_FAULT  \a theora_state or \a buf is <tt>NULL</tt>.
+ * \retval OC_EINVAL \a buf_sz is not <tt>sizeof(int)</tt>.
+ * \retval OC_IMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_GET_SPLEVEL_MAX (12)
+
+/**Sets the speed level.
+ * By default a speed value of 1 is used.
+ *
+ * \param[in] buf int: The new encoding speed level.
+ *                      0 is slowest, larger values use less CPU.
+ * \retval OC_FAULT  \a theora_state or \a buf is <tt>NULL</tt>.
+ * \retval OC_EINVAL \a buf_sz is not <tt>sizeof(int)</tt>, or the
+ *                    encoding speed level is out of bounds.
+ *                   The maximum encoding speed level may be
+ *                    implementation- and encoding mode-specific, and can be
+ *                    obtained via #TH_ENCCTL_GET_SPLEVEL_MAX.
+ * \retval OC_IMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_SET_SPLEVEL (14)
+
+/*@}*/
+
+#define OC_FAULT       -1       /**< General failure */
+#define OC_EINVAL      -10      /**< Library encountered invalid internal data */
+#define OC_DISABLED    -11      /**< Requested action is disabled */
+#define OC_BADHEADER   -20      /**< Header packet was corrupt/invalid */
+#define OC_NOTFORMAT   -21      /**< Packet is not a theora packet */
+#define OC_VERSION     -22      /**< Bitstream version is not handled */
+#define OC_IMPL        -23      /**< Feature or action not implemented */
+#define OC_BADPACKET   -24      /**< Packet is corrupt */
+#define OC_NEWPACKET   -25      /**< Packet is an (ignorable) unhandled extension */
+#define OC_DUPFRAME    1        /**< Packet is a dropped frame */
+
+/** 
+ * Retrieve a human-readable string to identify the encoder vendor and version.
+ * \returns A version string.
+ */
+extern const char *theora_version_string(void);
+
+/**
+ * Retrieve a 32-bit version number.
+ * This number is composed of a 16-bit major version, 8-bit minor version
+ * and 8 bit sub-version, composed as follows:
+<pre>
+   (VERSION_MAJOR<<16) + (VERSION_MINOR<<8) + (VERSION_SUB)
+</pre>
+* \returns The version number.
+*/
+extern ogg_uint32_t theora_version_number(void);
+
+/**
+ * Initialize the theora encoder.
+ * \param th The theora_state handle to initialize for encoding.
+ * \param ti A theora_info struct filled with the desired encoding parameters.
+ * \retval 0 Success
+ */
+extern int theora_encode_init(theora_state *th, theora_info *ti);
+
+/**
+ * Submit a YUV buffer to the theora encoder.
+ * \param t A theora_state handle previously initialized for encoding.
+ * \param yuv A buffer of YUV data to encode.  Note that both the yuv_buffer
+ *            struct and the luma/chroma buffers within should be allocated by
+ *            the user.
+ * \retval OC_EINVAL Encoder is not ready, or is finished.
+ * \retval -1 The size of the given frame differs from those previously input
+ * \retval 0 Success
+ */
+extern int theora_encode_YUVin(theora_state *t, yuv_buffer *yuv);
+
+/**
+ * Request the next packet of encoded video. 
+ * The encoded data is placed in a user-provided ogg_packet structure.
+ * \param t A theora_state handle previously initialized for encoding.
+ * \param last_p whether this is the last packet the encoder should produce.
+ * \param op An ogg_packet structure to fill. libtheora will set all
+ *           elements of this structure, including a pointer to encoded
+ *           data. The memory for the encoded data is owned by libtheora.
+ * \retval 0 No internal storage exists OR no packet is ready
+ * \retval -1 The encoding process has completed
+ * \retval 1 Success
+ */
+extern int theora_encode_packetout( theora_state *t, int last_p,
+                                    ogg_packet *op);
+
+/**
+ * Request a packet containing the initial header.
+ * A pointer to the header data is placed in a user-provided ogg_packet
+ * structure.
+ * \param t A theora_state handle previously initialized for encoding.
+ * \param op An ogg_packet structure to fill. libtheora will set all
+ *           elements of this structure, including a pointer to the header
+ *           data. The memory for the header data is owned by libtheora.
+ * \retval 0 Success
+ */
+extern int theora_encode_header(theora_state *t, ogg_packet *op);
+
+/**
+ * Request a comment header packet from provided metadata.
+ * A pointer to the comment data is placed in a user-provided ogg_packet
+ * structure.
+ * \param tc A theora_comment structure filled with the desired metadata
+ * \param op An ogg_packet structure to fill. libtheora will set all
+ *           elements of this structure, including a pointer to the encoded
+ *           comment data. The memory for the comment data is owned by
+ *           libtheora.
+ * \retval 0 Success
+ */
+extern int theora_encode_comment(theora_comment *tc, ogg_packet *op);
+
+/**
+ * Request a packet containing the codebook tables for the stream.
+ * A pointer to the codebook data is placed in a user-provided ogg_packet
+ * structure.
+ * \param t A theora_state handle previously initialized for encoding.
+ * \param op An ogg_packet structure to fill. libtheora will set all
+ *           elements of this structure, including a pointer to the codebook
+ *           data. The memory for the header data is owned by libtheora.
+ * \retval 0 Success
+ */
+extern int theora_encode_tables(theora_state *t, ogg_packet *op);
+
+/**
+ * Decode an Ogg packet, with the expectation that the packet contains
+ * an initial header, comment data or codebook tables.
+ *
+ * \param ci A theora_info structure to fill. This must have been previously
+ *           initialized with theora_info_init(). If \a op contains an initial
+ *           header, theora_decode_header() will fill \a ci with the
+ *           parsed header values. If \a op contains codebook tables,
+ *           theora_decode_header() will parse these and attach an internal
+ *           representation to \a ci->codec_setup.
+ * \param cc A theora_comment structure to fill. If \a op contains comment
+ *           data, theora_decode_header() will fill \a cc with the parsed
+ *           comments.
+ * \param op An ogg_packet structure which you expect contains an initial
+ *           header, comment data or codebook tables.
+ *
+ * \retval OC_BADHEADER \a op is NULL; OR the first byte of \a op->packet
+ *                      has the signature of an initial packet, but op is
+ *                      not a b_o_s packet; OR this packet has the signature
+ *                      of an initial header packet, but an initial header
+ *                      packet has already been seen; OR this packet has the
+ *                      signature of a comment packet, but the initial header
+ *                      has not yet been seen; OR this packet has the signature
+ *                      of a comment packet, but contains invalid data; OR
+ *                      this packet has the signature of codebook tables,
+ *                      but the initial header or comments have not yet
+ *                      been seen; OR this packet has the signature of codebook
+ *                      tables, but contains invalid data;
+ *                      OR the stream being decoded has a compatible version
+ *                      but this packet does not have the signature of a
+ *                      theora initial header, comments, or codebook packet
+ * \retval OC_VERSION   The packet data of \a op is an initial header with
+ *                      a version which is incompatible with this version of
+ *                      libtheora.
+ * \retval OC_NEWPACKET the stream being decoded has an incompatible (future)
+ *                      version and contains an unknown signature.
+ * \retval 0            Success
+ *
+ * \note The normal usage is that theora_decode_header() be called on the
+ *       first three packets of a theora logical bitstream in succession.
+ */
+extern int theora_decode_header(theora_info *ci, theora_comment *cc,
+                                ogg_packet *op);
+
+/**
+ * Initialize a theora_state handle for decoding.
+ * \param th The theora_state handle to initialize.
+ * \param c  A theora_info struct filled with the desired decoding parameters.
+ *           This is of course usually obtained from a previous call to
+ *           theora_decode_header().
+ * \retval 0 Success
+ */
+extern int theora_decode_init(theora_state *th, theora_info *c);
+
+/**
+ * Input a packet containing encoded data into the theora decoder.
+ * \param th A theora_state handle previously initialized for decoding.
+ * \param op An ogg_packet containing encoded theora data.
+ * \retval 0 Success
+ * \retval OC_BADPACKET \a op does not contain encoded video data
+ */
+extern int theora_decode_packetin(theora_state *th,ogg_packet *op);
+
+/**
+ * Output the next available frame of decoded YUV data.
+ * \param th A theora_state handle previously initialized for decoding.
+ * \param yuv A yuv_buffer in which libtheora should place the decoded data.
+ *            Note that the buffer struct itself is allocated by the user, but
+ *            that the luma and chroma pointers will be filled in by the 
+ *            library.  Also note that these luma and chroma regions should be 
+ *            considered read-only by the user.
+ * \retval 0 Success
+ */
+extern int theora_decode_YUVout(theora_state *th,yuv_buffer *yuv);
+
+/**
+ * Report whether a theora packet is a header or not
+ * This function does no verification beyond checking the header
+ * flag bit so it should not be used for bitstream identification;
+ * use theora_decode_header() for that.
+ *
+ * \param op An ogg_packet containing encoded theora data.
+ * \retval 1 The packet is a header packet
+ * \retval 0 The packet is not a header packet (and so contains frame data)
+ *
+ * Thus function was added in the 1.0alpha4 release.
+ */
+extern int theora_packet_isheader(ogg_packet *op);
+
+/**
+ * Report whether a theora packet is a keyframe or not
+ *
+ * \param op An ogg_packet containing encoded theora data.
+ * \retval 1 The packet contains a keyframe image
+ * \retval 0 The packet is contains an interframe delta
+ * \retval -1 The packet is not an image data packet at all
+ *
+ * Thus function was added in the 1.0alpha4 release.
+ */
+extern int theora_packet_iskeyframe(ogg_packet *op);
+
+/**
+ * Report the granulepos shift radix
+ *
+ * When embedded in Ogg, Theora uses a two-part granulepos, 
+ * splitting the 64-bit field into two pieces. The more-significant
+ * section represents the frame count at the last keyframe,
+ * and the less-significant section represents the count of
+ * frames since the last keyframe. In this way the overall
+ * field is still non-decreasing with time, but usefully encodes
+ * a pointer to the last keyframe, which is necessary for
+ * correctly restarting decode after a seek. 
+ *
+ * This function reports the number of bits used to represent
+ * the distance to the last keyframe, and thus how the granulepos
+ * field must be shifted or masked to obtain the two parts.
+ * 
+ * Since libtheora returns compressed data in an ogg_packet
+ * structure, this may be generally useful even if the Theora
+ * packets are not being used in an Ogg container. 
+ *
+ * \param ti A previously initialized theora_info struct
+ * \returns The bit shift dividing the two granulepos fields
+ *
+ * This function was added in the 1.0alpha5 release.
+ */
+int theora_granule_shift(theora_info *ti);
+
+/**
+ * Convert a granulepos to an absolute frame index, starting at 0.
+ * The granulepos is interpreted in the context of a given theora_state handle.
+ * 
+ * Note that while the granulepos encodes the frame count (i.e. starting
+ * from 1) this call returns the frame index, starting from zero. Thus
+ * One can calculate the presentation time by multiplying the index by
+ * the rate.
+ *
+ * \param th A previously initialized theora_state handle (encode or decode)
+ * \param granulepos The granulepos to convert.
+ * \returns The frame index corresponding to \a granulepos.
+ * \retval -1 The given granulepos is undefined (i.e. negative)
+ *
+ * Thus function was added in the 1.0alpha4 release.
+ */
+extern ogg_int64_t theora_granule_frame(theora_state *th,ogg_int64_t granulepos);
+
+/**
+ * Convert a granulepos to absolute time in seconds. The granulepos is
+ * interpreted in the context of a given theora_state handle, and gives
+ * the end time of a frame's presentation as used in Ogg mux ordering.
+ *
+ * \param th A previously initialized theora_state handle (encode or decode)
+ * \param granulepos The granulepos to convert.
+ * \returns The absolute time in seconds corresponding to \a granulepos.
+ *          This is the "end time" for the frame, or the latest time it should
+ *           be displayed.
+ *          It is not the presentation time.
+ * \retval -1. The given granulepos is undefined (i.e. negative), or
+ * \retval -1. The function has been disabled because floating 
+ *              point support is not available.
+ */
+extern double theora_granule_time(theora_state *th,ogg_int64_t granulepos);
+
+/**
+ * Initialize a theora_info structure. All values within the given theora_info
+ * structure are initialized, and space is allocated within libtheora for
+ * internal codec setup data.
+ * \param c A theora_info struct to initialize.
+ */
+extern void theora_info_init(theora_info *c);
+
+/**
+ * Clear a theora_info structure. All values within the given theora_info
+ * structure are cleared, and associated internal codec setup data is freed.
+ * \param c A theora_info struct to initialize.
+ */
+extern void theora_info_clear(theora_info *c);
+
+/**
+ * Free all internal data associated with a theora_state handle.
+ * \param t A theora_state handle.
+ */
+extern void theora_clear(theora_state *t);
+
+/**
+ * Initialize an allocated theora_comment structure
+ * \param tc An allocated theora_comment structure 
+ **/
+extern void theora_comment_init(theora_comment *tc);
+
+/**
+ * Add a comment to an initialized theora_comment structure
+ * \param tc A previously initialized theora comment structure
+ * \param comment A null-terminated string encoding the comment in the form
+ *                "TAG=the value"
+ *
+ * Neither theora_comment_add() nor theora_comment_add_tag() support
+ * comments containing null values, although the bitstream format
+ * supports this. To add such comments you will need to manipulate
+ * the theora_comment structure directly.
+ **/
+
+extern void theora_comment_add(theora_comment *tc, char *comment);
+
+/**
+ * Add a comment to an initialized theora_comment structure.
+ * \param tc A previously initialized theora comment structure
+ * \param tag A null-terminated string containing the tag 
+ *            associated with the comment.
+ * \param value The corresponding value as a null-terminated string
+ *
+ * Neither theora_comment_add() nor theora_comment_add_tag() support
+ * comments containing null values, although the bitstream format
+ * supports this. To add such comments you will need to manipulate
+ * the theora_comment structure directly.
+ **/
+extern void theora_comment_add_tag(theora_comment *tc,
+                                       char *tag, char *value);
+
+/**
+ * Look up a comment value by tag.
+ * \param tc Tn initialized theora_comment structure
+ * \param tag The tag to look up
+ * \param count The instance of the tag. The same tag can appear multiple
+ *              times, each with a distinct and ordered value, so an index
+ *              is required to retrieve them all.
+ * \returns A pointer to the queried tag's value
+ * \retval NULL No matching tag is found
+ *
+ * \note Use theora_comment_query_count() to get the legal range for the
+ * count parameter.
+ **/
+
+extern char *theora_comment_query(theora_comment *tc, char *tag, int count);
+
+/** Look up the number of instances of a tag.
+ *  \param tc An initialized theora_comment structure
+ *  \param tag The tag to look up
+ *  \returns The number on instances of a particular tag.
+ * 
+ *  Call this first when querying for a specific tag and then interate
+ *  over the number of instances with separate calls to 
+ *  theora_comment_query() to retrieve all instances in order.
+ **/
+extern int   theora_comment_query_count(theora_comment *tc, char *tag);
+
+/**
+ * Clear an allocated theora_comment struct so that it can be freed.
+ * \param tc An allocated theora_comment structure.
+ **/
+extern void  theora_comment_clear(theora_comment *tc);
+
+/**Encoder control function.
+ * This is used to provide advanced control the encoding process.
+ * \param th     A #theora_state handle.
+ * \param req    The control code to process.
+ *                See \ref encctlcodes_old "the list of available 
+ *                     control codes" for details.
+ * \param buf    The parameters for this control code.
+ * \param buf_sz The size of the parameter buffer.*/
+extern int theora_control(theora_state *th,int req,void *buf,size_t buf_sz);
+
+/* @} */ /* end oldfuncs doxygen group */
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif /* _O_THEORA_H_ */
diff --git a/include/theora/theoradec.h b/include/theora/theoradec.h
new file mode 100644 (file)
index 0000000..b20f0e3
--- /dev/null
@@ -0,0 +1,325 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: theora.h,v 1.8 2004/03/15 22:17:32 derf Exp $
+
+ ********************************************************************/
+
+/**\file
+ * The <tt>libtheoradec</tt> C decoding API.*/
+
+#if !defined(_O_THEORA_THEORADEC_H_)
+# define _O_THEORA_THEORADEC_H_ (1)
+# include <stddef.h>
+# include <ogg/ogg.h>
+# include "codec.h"
+
+#if defined(__cplusplus)
+extern "C" {
+#endif
+
+
+
+/**\name th_decode_ctl() codes
+ * \anchor decctlcodes
+ * These are the available request codes for th_decode_ctl().
+ * By convention, these are odd, to distinguish them from the
+ *  \ref encctlcodes "encoder control codes".
+ * Keep any experimental or vendor-specific values above \c 0x8000.*/
+/*@{*/
+/**Gets the maximum post-processing level.
+ * The decoder supports a post-processing filter that can improve
+ * the appearance of the decoded images. This returns the highest
+ * level setting for this post-processor, corresponding to maximum
+ * improvement and computational expense.
+ *
+ * \param[out] _buf int: The maximum post-processing level.
+ * \retval TH_EFAULT  \a _dec_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL  \a _buf_sz is not <tt>sizeof(int)</tt>.
+ * \retval TH_EIMPL   Not supported by this implementation.*/
+#define TH_DECCTL_GET_PPLEVEL_MAX (1)
+/**Sets the post-processing level.
+ * By default, post-processing is disabled.
+ *
+ * Sets the level of post-processing to use when decoding the
+ * compressed stream. This must be a value between zero (off)
+ * and the maximum returned by TH_DECCTL_GET_PPLEVEL_MAX.
+ *
+ * \param[in] _buf int: The new post-processing level.
+ *                      0 to disable; larger values use more CPU.
+ * \retval TH_EFAULT  \a _dec_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL  \a _buf_sz is not <tt>sizeof(int)</tt>, or the
+ *                     post-processing level is out of bounds.
+ *                    The maximum post-processing level may be
+ *                     implementation-specific, and can be obtained via
+ *                     #TH_DECCTL_GET_PPLEVEL_MAX.
+ * \retval TH_EIMPL   Not supported by this implementation.*/
+#define TH_DECCTL_SET_PPLEVEL (3)
+/**Sets the granule position.
+ * Call this after a seek, before decoding the first frame, to ensure that the
+ *  proper granule position is returned for all subsequent frames.
+ * If you track timestamps yourself and do not use the granule position
+ *  returned by the decoder, then you need not call this function.
+ *
+ * \param[in] _buf <tt>ogg_int64_t</tt>: The granule position of the next
+ *                  frame.
+ * \retval TH_EFAULT  \a _dec_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL  \a _buf_sz is not <tt>sizeof(ogg_int64_t)</tt>, or the
+ *                     granule position is negative.*/
+#define TH_DECCTL_SET_GRANPOS (5)
+/**Sets the striped decode callback function.
+ * If set, this function will be called as each piece of a frame is fully
+ *  decoded in th_decode_packetin().
+ * You can pass in a #th_stripe_callback with
+ *  th_stripe_callback#stripe_decoded set to <tt>NULL</tt> to disable the
+ *  callbacks at any point.
+ * Enabling striped decode does not prevent you from calling
+ *  th_decode_ycbcr_out() after the frame is fully decoded.
+ *
+ * \param[in]  _buf #th_stripe_callback: The callback parameters.
+ * \retval TH_EFAULT  \a _dec_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL  \a _buf_sz is not
+ *                     <tt>sizeof(th_stripe_callback)</tt>.*/
+#define TH_DECCTL_SET_STRIPE_CB (7)
+
+/**Enables telemetry and sets the macroblock display mode */
+#define TH_DECCTL_SET_TELEMETRY_MBMODE (9)
+/**Enables telemetry and sets the motion vector display mode */
+#define TH_DECCTL_SET_TELEMETRY_MV (11)
+/**Enables telemetry and sets the adaptive quantization display mode */
+#define TH_DECCTL_SET_TELEMETRY_QI (13)
+/**Enables telemetry and sets the bitstream breakdown visualization mode */
+#define TH_DECCTL_SET_TELEMETRY_BITS (15)
+/*@}*/
+
+
+
+/**A callback function for striped decode.
+ * This is a function pointer to an application-provided function that will be
+ *  called each time a section of the image is fully decoded in
+ *  th_decode_packetin().
+ * This allows the application to process the section immediately, while it is
+ *  still in cache.
+ * Note that the frame is decoded bottom to top, so \a _yfrag0 will steadily
+ *  decrease with each call until it reaches 0, at which point the full frame
+ *  is decoded.
+ * The number of fragment rows made available in each call depends on the pixel
+ *  format and the number of post-processing filters enabled, and may not even
+ *  be constant for the entire frame.
+ * If a non-<tt>NULL</tt> \a _granpos pointer is passed to
+ *  th_decode_packetin(), the granule position for the frame will be stored
+ *  in it before the first callback is made.
+ * If an entire frame is dropped (a 0-byte packet), then no callbacks will be
+ *  made at all for that frame.
+ * \param _ctx       An application-provided context pointer.
+ * \param _buf       The image buffer for the decoded frame.
+ * \param _yfrag0    The Y coordinate of the first row of 8x8 fragments
+ *                    decoded.
+ *                   Multiply this by 8 to obtain the pixel row number in the
+ *                    luma plane.
+ *                   If the chroma planes are subsampled in the Y direction,
+ *                    this will always be divisible by two.
+ * \param _yfrag_end The Y coordinate of the first row of 8x8 fragments past
+ *                    the newly decoded section.
+ *                   If the chroma planes are subsampled in the Y direction,
+ *                    this will always be divisible by two.
+ *                   I.e., this section contains fragment rows
+ *                    <tt>\a _yfrag0 ...\a _yfrag_end -1</tt>.*/
+typedef void (*th_stripe_decoded_func)(void *_ctx,th_ycbcr_buffer _buf,
+ int _yfrag0,int _yfrag_end);
+
+/**The striped decode callback data to pass to #TH_DECCTL_SET_STRIPE_CB.*/
+typedef struct{
+  /**An application-provided context pointer.
+   * This will be passed back verbatim to the application.*/
+  void                   *ctx;
+  /**The callback function pointer.*/
+  th_stripe_decoded_func  stripe_decoded;
+}th_stripe_callback;
+
+
+
+/**\name Decoder state
+   The following data structures are opaque, and their contents are not
+    publicly defined by this API.
+   Referring to their internals directly is unsupported, and may break without
+    warning.*/
+/*@{*/
+/**The decoder context.*/
+typedef struct th_dec_ctx    th_dec_ctx;
+/**Setup information.
+   This contains auxiliary information (Huffman tables and quantization
+    parameters) decoded from the setup header by th_decode_headerin() to be
+    passed to th_decode_alloc().
+   It can be re-used to initialize any number of decoders, and can be freed
+    via th_setup_free() at any time.*/
+typedef struct th_setup_info th_setup_info;
+/*@}*/
+
+
+
+/**\defgroup decfuncs Functions for Decoding*/
+/*@{*/
+/**\name Functions for decoding
+ * You must link to <tt>libtheoradec</tt> if you use any of the 
+ * functions in this section.
+ *
+ * The functions are listed in the order they are used in a typical decode.
+ * The basic steps are:
+ * - Parse the header packets by repeatedly calling th_decode_headerin().
+ * - Allocate a #th_dec_ctx handle with th_decode_alloc().
+ * - Call th_setup_free() to free any memory used for codec setup
+ *    information.
+ * - Perform any additional decoder configuration with th_decode_ctl().
+ * - For each video data packet:
+ *   - Submit the packet to the decoder via th_decode_packetin().
+ *   - Retrieve the uncompressed video data via th_decode_ycbcr_out().
+ * - Call th_decode_free() to release all decoder memory.*/
+/*@{*/
+/**Decodes the header packets of a Theora stream.
+ * This should be called on the initial packets of the stream, in succession,
+ *  until it returns <tt>0</tt>, indicating that all headers have been
+ *  processed, or an error is encountered.
+ * At least three header packets are required, and additional optional header
+ *  packets may follow.
+ * This can be used on the first packet of any logical stream to determine if
+ *  that stream is a Theora stream.
+ * \param _info  A #th_info structure to fill in.
+ *               This must have been previously initialized with
+ *                th_info_init().
+ *               The application may immediately begin using the contents of
+ *                this structure after the first header is decoded, though it
+ *                must continue to be passed in on all subsequent calls.
+ * \param _tc    A #th_comment structure to fill in.
+ *               The application may immediately begin using the contents of
+ *                this structure after the second header is decoded, though it
+ *                must continue to be passed in on all subsequent calls.
+ * \param _setup Returns a pointer to additional, private setup information
+ *                needed by the decoder.
+ *               The contents of this pointer must be initialized to
+ *                <tt>NULL</tt> on the first call, and the returned value must
+ *                continue to be passed in on all subsequent calls.
+ * \param _op    An <tt>ogg_packet</tt> structure which contains one of the
+ *                initial packets of an Ogg logical stream.
+ * \return A positive value indicates that a Theora header was successfully
+ *          processed.
+ * \retval 0             The first video data packet was encountered after all
+ *                        required header packets were parsed.
+ *                       The packet just passed in on this call should be saved
+ *                        and fed to th_decode_packetin() to begin decoding
+ *                        video data.
+ * \retval TH_EFAULT     One of \a _info, \a _tc, or \a _setup was
+ *                        <tt>NULL</tt>.
+ * \retval TH_EBADHEADER \a _op was <tt>NULL</tt>, the packet was not the next
+ *                        header packet in the expected sequence, or the format
+ *                        of the header data was invalid.
+ * \retval TH_EVERSION   The packet data was a Theora info header, but for a
+ *                        bitstream version not decodable with this version of
+ *                        <tt>libtheoradec</tt>.
+ * \retval TH_ENOTFORMAT The packet was not a Theora header.
+ */
+extern int th_decode_headerin(th_info *_info,th_comment *_tc,
+ th_setup_info **_setup,ogg_packet *_op);
+/**Allocates a decoder instance.
+ *
+ * <b>Security Warning:</b> The Theora format supports very large frame sizes,
+ *  potentially even larger than the address space of a 32-bit machine, and
+ *  creating a decoder context allocates the space for several frames of data.
+ * If the allocation fails here, your program will crash, possibly at some
+ *  future point because the OS kernel returned a valid memory range and will
+ *  only fail when it tries to map the pages in it the first time they are
+ *  used.
+ * Even if it succeeds, you may experience a denial of service if the frame
+ *  size is large enough to cause excessive paging.
+ * If you are integrating libtheora in a larger application where such things
+ *  are undesirable, it is highly recommended that you check the frame size in
+ *  \a _info before calling this function and refuse to decode streams where it
+ *  is larger than some reasonable maximum.
+ * libtheora will not check this for you, because there may be machines that
+ *  can handle such streams and applications that wish to.
+ * \param _info  A #th_info struct filled via th_decode_headerin().
+ * \param _setup A #th_setup_info handle returned via
+ *                th_decode_headerin().
+ * \return The initialized #th_dec_ctx handle.
+ * \retval NULL If the decoding parameters were invalid.*/
+extern th_dec_ctx *th_decode_alloc(const th_info *_info,
+ const th_setup_info *_setup);
+/**Releases all storage used for the decoder setup information.
+ * This should be called after you no longer want to create any decoders for
+ *  a stream whose headers you have parsed with th_decode_headerin().
+ * \param _setup The setup information to free.
+ *               This can safely be <tt>NULL</tt>.*/
+extern void th_setup_free(th_setup_info *_setup);
+/**Decoder control function.
+ * This is used to provide advanced control of the decoding process.
+ * \param _dec    A #th_dec_ctx handle.
+ * \param _req    The control code to process.
+ *                See \ref decctlcodes "the list of available control codes"
+ *                 for details.
+ * \param _buf    The parameters for this control code.
+ * \param _buf_sz The size of the parameter buffer.*/
+extern int th_decode_ctl(th_dec_ctx *_dec,int _req,void *_buf,
+ size_t _buf_sz);
+/**Submits a packet containing encoded video data to the decoder.
+ * \param _dec     A #th_dec_ctx handle.
+ * \param _op      An <tt>ogg_packet</tt> containing encoded video data.
+ * \param _granpos Returns the granule position of the decoded packet.
+ *                 If non-<tt>NULL</tt>, the granule position for this specific
+ *                  packet is stored in this location.
+ *                 This is computed incrementally from previously decoded
+ *                  packets.
+ *                 After a seek, the correct granule position must be set via
+ *                  #TH_DECCTL_SET_GRANPOS for this to work properly.
+ * \retval 0             Success.
+ *                       A new decoded frame can be retrieved by calling
+ *                        th_decode_ycbcr_out().
+ * \retval TH_DUPFRAME   The packet represented a dropped (0-byte) frame.
+ *                       The player can skip the call to th_decode_ycbcr_out(),
+ *                        as the contents of the decoded frame buffer have not
+ *                        changed.
+ * \retval TH_EFAULT     \a _dec or \a _op was <tt>NULL</tt>.
+ * \retval TH_EBADPACKET \a _op does not contain encoded video data.
+ * \retval TH_EIMPL      The video data uses bitstream features which this
+ *                        library does not support.*/
+extern int th_decode_packetin(th_dec_ctx *_dec,const ogg_packet *_op,
+ ogg_int64_t *_granpos);
+/**Outputs the next available frame of decoded Y'CbCr data.
+ * If a striped decode callback has been set with #TH_DECCTL_SET_STRIPE_CB,
+ *  then the application does not need to call this function.
+ * \param _dec   A #th_dec_ctx handle.
+ * \param _ycbcr A video buffer structure to fill in.
+ *               <tt>libtheoradec</tt> will fill in all the members of this
+ *                structure, including the pointers to the uncompressed video
+ *                data.
+ *               The memory for this video data is owned by
+ *                <tt>libtheoradec</tt>.
+ *               It may be freed or overwritten without notification when
+ *                subsequent frames are decoded.
+ * \retval 0 Success
+ * \retval TH_EFAULT     \a _dec or \a _ycbcr was <tt>NULL</tt>.
+ */
+extern int th_decode_ycbcr_out(th_dec_ctx *_dec,
+ th_ycbcr_buffer _ycbcr);
+/**Frees an allocated decoder instance.
+ * \param _dec A #th_dec_ctx handle.*/
+extern void th_decode_free(th_dec_ctx *_dec);
+/*@}*/
+/*@}*/
+
+
+
+#if defined(__cplusplus)
+}
+#endif
+
+#endif
diff --git a/include/theora/theoraenc.h b/include/theora/theoraenc.h
new file mode 100644 (file)
index 0000000..fdf2ab2
--- /dev/null
@@ -0,0 +1,486 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: theora.h,v 1.8 2004/03/15 22:17:32 derf Exp $
+
+ ********************************************************************/
+
+/**\file
+ * The <tt>libtheoraenc</tt> C encoding API.*/
+
+#if !defined(_O_THEORA_THEORAENC_H_)
+# define _O_THEORA_THEORAENC_H_ (1)
+# include <stddef.h>
+# include <ogg/ogg.h>
+# include "codec.h"
+
+#if defined(__cplusplus)
+extern "C" {
+#endif
+
+
+
+/**\name th_encode_ctl() codes
+ * \anchor encctlcodes
+ * These are the available request codes for th_encode_ctl().
+ * By convention, these are even, to distinguish them from the
+ *  \ref decctlcodes "decoder control codes".
+ * Keep any experimental or vendor-specific values above \c 0x8000.*/
+/*@{*/
+/**Sets the Huffman tables to use.
+ * The tables are copied, not stored by reference, so they can be freed after
+ *  this call.
+ * <tt>NULL</tt> may be specified to revert to the default tables.
+ *
+ * \param[in] _buf <tt>#th_huff_code[#TH_NHUFFMAN_TABLES][#TH_NDCT_TOKENS]</tt>
+ * \retval TH_EFAULT \a _enc_ctx is <tt>NULL</tt>.
+ * \retval TH_EINVAL Encoding has already begun or one or more of the given
+ *                     tables is not full or prefix-free, \a _buf is
+ *                     <tt>NULL</tt> and \a _buf_sz is not zero, or \a _buf is
+ *                     non-<tt>NULL</tt> and \a _buf_sz is not
+ *                     <tt>sizeof(#th_huff_code)*#TH_NHUFFMAN_TABLES*#TH_NDCT_TOKENS</tt>.
+ * \retval TH_EIMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_SET_HUFFMAN_CODES (0)
+/**Sets the quantization parameters to use.
+ * The parameters are copied, not stored by reference, so they can be freed
+ *  after this call.
+ * <tt>NULL</tt> may be specified to revert to the default parameters.
+ *
+ * \param[in] _buf #th_quant_info
+ * \retval TH_EFAULT \a _enc_ctx is <tt>NULL</tt>.
+ * \retval TH_EINVAL Encoding has already begun, \a _buf is 
+ *                    <tt>NULL</tt> and \a _buf_sz is not zero,
+ *                    or \a _buf is non-<tt>NULL</tt> and
+ *                    \a _buf_sz is not <tt>sizeof(#th_quant_info)</tt>.
+ * \retval TH_EIMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_SET_QUANT_PARAMS (2)
+/**Sets the maximum distance between key frames.
+ * This can be changed during an encode, but will be bounded by
+ *  <tt>1<<th_info#keyframe_granule_shift</tt>.
+ * If it is set before encoding begins, th_info#keyframe_granule_shift will
+ *  be enlarged appropriately.
+ *
+ * \param[in]  _buf <tt>ogg_uint32_t</tt>: The maximum distance between key
+ *                   frames.
+ * \param[out] _buf <tt>ogg_uint32_t</tt>: The actual maximum distance set.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(ogg_uint32_t)</tt>.
+ * \retval TH_EIMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE (4)
+/**Disables any encoder features that would prevent lossless transcoding back
+ *  to VP3.
+ * This primarily means disabling block-adaptive quantization and always coding
+ *  all four luma blocks in a macro block when 4MV is used.
+ * It also includes using the VP3 quantization tables and Huffman codes; if you
+ *  set them explicitly after calling this function, the resulting stream will
+ *  not be VP3-compatible.
+ * If you enable VP3-compatibility when encoding 4:2:2 or 4:4:4 source
+ *  material, or when using a picture region smaller than the full frame (e.g.
+ *  a non-multiple-of-16 width or height), then non-VP3 bitstream features will
+ *  still be disabled, but the stream will still not be VP3-compatible, as VP3
+ *  was not capable of encoding such formats.
+ * If you call this after encoding has already begun, then the quantization
+ *  tables and codebooks cannot be changed, but the frame-level features will
+ *  be enabled or disabled as requested.
+ *
+ * \param[in]  _buf <tt>int</tt>: a non-zero value to enable VP3 compatibility,
+ *                   or 0 to disable it (the default).
+ * \param[out] _buf <tt>int</tt>: 1 if all bitstream features required for
+ *                   VP3-compatibility could be set, and 0 otherwise.
+ *                  The latter will be returned if the pixel format is not
+ *                   4:2:0, the picture region is smaller than the full frame,
+ *                   or if encoding has begun, preventing the quantization
+ *                   tables and codebooks from being set.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(int)</tt>.
+ * \retval TH_EIMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_SET_VP3_COMPATIBLE (10)
+/**Gets the maximum speed level.
+ * Higher speed levels favor quicker encoding over better quality per bit.
+ * Depending on the encoding mode, and the internal algorithms used, quality
+ *  may actually improve, but in this case bitrate will also likely increase.
+ * In any case, overall rate/distortion performance will probably decrease.
+ * The maximum value, and the meaning of each value, may change depending on
+ *  the current encoding mode (VBR vs. constant quality, etc.).
+ *
+ * \param[out] _buf <tt>int</tt>: The maximum encoding speed level.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(int)</tt>.
+ * \retval TH_EIMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_GET_SPLEVEL_MAX (12)
+/**Sets the speed level.
+ * The current speed level may be retrieved using #TH_ENCCTL_GET_SPLEVEL.
+ *
+ * \param[in] _buf <tt>int</tt>: The new encoding speed level.
+ *                 0 is slowest, larger values use less CPU.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(int)</tt>, or the
+ *                    encoding speed level is out of bounds.
+ *                   The maximum encoding speed level may be
+ *                    implementation- and encoding mode-specific, and can be
+ *                    obtained via #TH_ENCCTL_GET_SPLEVEL_MAX.
+ * \retval TH_EIMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_SET_SPLEVEL (14)
+/**Gets the current speed level.
+ * The default speed level may vary according to encoder implementation, but if
+ *  this control code is not supported (it returns #TH_EIMPL), the default may
+ *  be assumed to be the slowest available speed (0).
+ * The maximum encoding speed level may be implementation- and encoding
+ *  mode-specific, and can be obtained via #TH_ENCCTL_GET_SPLEVEL_MAX.
+ *
+ * \param[out] _buf <tt>int</tt>: The current encoding speed level.
+ *                  0 is slowest, larger values use less CPU.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(int)</tt>.
+ * \retval TH_EIMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_GET_SPLEVEL (16)
+/**Sets the number of duplicates of the next frame to produce.
+ * Although libtheora can encode duplicate frames very cheaply, it costs some
+ *  amount of CPU to detect them, and a run of duplicates cannot span a
+ *  keyframe boundary.
+ * This control code tells the encoder to produce the specified number of extra
+ *  duplicates of the next frame.
+ * This allows the encoder to make smarter keyframe placement decisions and
+ *  rate control decisions, and reduces CPU usage as well, when compared to
+ *  just submitting the same frame for encoding multiple times.
+ * This setting only applies to the next frame submitted for encoding.
+ * You MUST call th_encode_packetout() repeatedly until it returns 0, or the
+ *  extra duplicate frames will be lost.
+ *
+ * \param[in] _buf <tt>int</tt>: The number of duplicates to produce.
+ *                 If this is negative or zero, no duplicates will be produced.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(int)</tt>, or the
+ *                    number of duplicates is greater than or equal to the
+ *                    maximum keyframe interval.
+ *                   In the latter case, NO duplicate frames will be produced.
+ *                   You must ensure that the maximum keyframe interval is set
+ *                    larger than the maximum number of duplicates you will
+ *                    ever wish to insert prior to encoding.
+ * \retval TH_EIMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_SET_DUP_COUNT (18)
+/**Modifies the default bitrate management behavior.
+ * Use to allow or disallow frame dropping, and to enable or disable capping
+ *  bit reservoir overflows and underflows.
+ * See \ref encctlcodes "the list of available flags".
+ * The flags are set by default to
+ *  <tt>#TH_RATECTL_DROP_FRAMES|#TH_RATECTL_CAP_OVERFLOW</tt>.
+ *
+ * \param[in] _buf <tt>int</tt>: Any combination of
+ *                  \ref ratectlflags "the available flags":
+ *                 - #TH_RATECTL_DROP_FRAMES: Enable frame dropping.
+ *                 - #TH_RATECTL_CAP_OVERFLOW: Don't bank excess bits for later
+ *                    use.
+ *                 - #TH_RATECTL_CAP_UNDERFLOW: Don't try to make up shortfalls
+ *                    later.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(int)</tt> or rate control
+ *                    is not enabled.
+ * \retval TH_EIMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_SET_RATE_FLAGS (20)
+/**Sets the size of the bitrate management bit reservoir as a function
+ *  of number of frames.
+ * The reservoir size affects how quickly bitrate management reacts to
+ *  instantaneous changes in the video complexity.
+ * Larger reservoirs react more slowly, and provide better overall quality, but
+ *  require more buffering by a client, adding more latency to live streams.
+ * By default, libtheora sets the reservoir to the maximum distance between
+ *  keyframes, subject to a minimum and maximum limit.
+ * This call may be used to increase or decrease the reservoir, increasing or
+ *  decreasing the allowed temporary variance in bitrate.
+ * An implementation may impose some limits on the size of a reservoir it can
+ *  handle, in which case the actual reservoir size may not be exactly what was
+ *  requested.
+ * The actual value set will be returned.
+ *
+ * \param[in]  _buf <tt>int</tt>: Requested size of the reservoir measured in
+ *                   frames.
+ * \param[out] _buf <tt>int</tt>: The actual size of the reservoir set.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(int)</tt>, or rate control
+ *                    is not enabled.  The buffer has an implementation
+ *                    defined minimum and maximum size and the value in _buf
+ *                    will be adjusted to match the actual value set.
+ * \retval TH_EIMPL   Not supported by this implementation in the current
+ *                    encoding mode.*/
+#define TH_ENCCTL_SET_RATE_BUFFER (22)
+/**Enable pass 1 of two-pass encoding mode and retrieve the first pass metrics.
+ * Pass 1 mode must be enabled before the first frame is encoded, and a target
+ *  bitrate must have already been specified to the encoder.
+ * Although this does not have to be the exact rate that will be used in the
+ *  second pass, closer values may produce better results.
+ * The first call returns the size of the two-pass header data, along with some
+ *  placeholder content, and sets the encoder into pass 1 mode implicitly.
+ * This call sets the encoder to pass 1 mode implicitly.
+ * Then, a subsequent call must be made after each call to
+ *  th_encode_ycbcr_in() to retrieve the metrics for that frame.
+ * An additional, final call must be made to retrieve the summary data,
+ *  containing such information as the total number of frames, etc.
+ * This must be stored in place of the placeholder data that was returned
+ *  in the first call, before the frame metrics data.
+ * All of this data must be presented back to the encoder during pass 2 using
+ *  #TH_ENCCTL_2PASS_IN.
+ *
+ * \param[out] <tt>char *</tt>_buf: Returns a pointer to internal storage
+ *              containing the two pass metrics data.
+ *             This storage is only valid until the next call, or until the
+ *              encoder context is freed, and must be copied by the
+ *              application.
+ * \retval >=0       The number of bytes of metric data available in the
+ *                    returned buffer.
+ * \retval TH_EFAULT \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL \a _buf_sz is not <tt>sizeof(char *)</tt>, no target
+ *                    bitrate has been set, or the first call was made after
+ *                    the first frame was submitted for encoding.
+ * \retval TH_EIMPL   Not supported by this implementation.*/
+#define TH_ENCCTL_2PASS_OUT (24)
+/**Submits two-pass encoding metric data collected the first encoding pass to
+ *  the second pass.
+ * The first call must be made before the first frame is encoded, and a target
+ *  bitrate must have already been specified to the encoder.
+ * It sets the encoder to pass 2 mode implicitly; this cannot be disabled.
+ * The encoder may require reading data from some or all of the frames in
+ *  advance, depending on, e.g., the reservoir size used in the second pass.
+ * You must call this function repeatedly before each frame to provide data
+ *  until either a) it fails to consume all of the data presented or b) all of
+ *  the pass 1 data has been consumed.
+ * In the first case, you must save the remaining data to be presented after
+ *  the next frame.
+ * You can call this function with a NULL argument to get an upper bound on
+ *  the number of bytes that will be required before the next frame.
+ *
+ * When pass 2 is first enabled, the default bit reservoir is set to the entire
+ *  file; this gives maximum flexibility but can lead to very high peak rates.
+ * You can subsequently set it to another value with #TH_ENCCTL_SET_RATE_BUFFER
+ *  (e.g., to set it to the keyframe interval for non-live streaming), however,
+ *  you may then need to provide more data before the next frame.
+ *
+ * \param[in] _buf <tt>char[]</tt>: A buffer containing the data returned by
+ *                  #TH_ENCCTL_2PASS_OUT in pass 1.
+ *                 You may pass <tt>NULL</tt> for \a _buf to return an upper
+ *                  bound on the number of additional bytes needed before the
+ *                  next frame.
+ *                 The summary data returned at the end of pass 1 must be at
+ *                  the head of the buffer on the first call with a
+ *                  non-<tt>NULL</tt> \a _buf, and the placeholder data
+ *                  returned at the start of pass 1 should be omitted.
+ *                 After each call you should advance this buffer by the number
+ *                  of bytes consumed.
+ * \retval >0            The number of bytes of metric data required/consumed.
+ * \retval 0             No more data is required before the next frame.
+ * \retval TH_EFAULT     \a _enc_ctx is <tt>NULL</tt>.
+ * \retval TH_EINVAL     No target bitrate has been set, or the first call was
+ *                        made after the first frame was submitted for
+ *                        encoding.
+ * \retval TH_ENOTFORMAT The data did not appear to be pass 1 from a compatible
+ *                        implementation of this library.
+ * \retval TH_EBADHEADER The data was invalid; this may be returned when
+ *                        attempting to read an aborted pass 1 file that still
+ *                        has the placeholder data in place of the summary
+ *                        data.
+ * \retval TH_EIMPL       Not supported by this implementation.*/
+#define TH_ENCCTL_2PASS_IN (26)
+/**Sets the current encoding quality.
+ * This is only valid so long as no bitrate has been specified, either through
+ *  the #th_info struct used to initialize the encoder or through
+ *  #TH_ENCCTL_SET_BITRATE (this restriction may be relaxed in a future
+ *  version).
+ * If it is set before the headers are emitted, the target quality encoded in
+ *  them will be updated.
+ *
+ * \param[in] _buf <tt>int</tt>: The new target quality, in the range 0...63,
+ *                  inclusive.
+ * \retval 0             Success.
+ * \retval TH_EFAULT     \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL     A target bitrate has already been specified, or the
+ *                        quality index was not in the range 0...63.
+ * \retval TH_EIMPL       Not supported by this implementation.*/
+#define TH_ENCCTL_SET_QUALITY (28)
+/**Sets the current encoding bitrate.
+ * Once a bitrate is set, the encoder must use a rate-controlled mode for all
+ *  future frames (this restriction may be relaxed in a future version).
+ * If it is set before the headers are emitted, the target bitrate encoded in
+ *  them will be updated.
+ * Due to the buffer delay, the exact bitrate of each section of the encode is
+ *  not guaranteed.
+ * The encoder may have already used more bits than allowed for the frames it
+ *  has encoded, expecting to make them up in future frames, or it may have
+ *  used fewer, holding the excess in reserve.
+ * The exact transition between the two bitrates is not well-defined by this
+ *  API, but may be affected by flags set with #TH_ENCCTL_SET_RATE_FLAGS.
+ * After a number of frames equal to the buffer delay, one may expect further
+ *  output to average at the target bitrate.
+ *
+ * \param[in] _buf <tt>long</tt>: The new target bitrate, in bits per second.
+ * \retval 0             Success.
+ * \retval TH_EFAULT     \a _enc_ctx or \a _buf is <tt>NULL</tt>.
+ * \retval TH_EINVAL     The target bitrate was not positive.
+ * \retval TH_EIMPL       Not supported by this implementation.*/
+#define TH_ENCCTL_SET_BITRATE (30)
+
+/*@}*/
+
+
+/**\name TH_ENCCTL_SET_RATE_FLAGS flags
+ * \anchor ratectlflags
+ * These are the flags available for use with #TH_ENCCTL_SET_RATE_FLAGS.*/
+/*@{*/
+/**Drop frames to keep within bitrate buffer constraints.
+ * This can have a severe impact on quality, but is the only way to ensure that
+ *  bitrate targets are met at low rates during sudden bursts of activity.*/
+#define TH_RATECTL_DROP_FRAMES   (0x1)
+/**Ignore bitrate buffer overflows.
+ * If the encoder uses so few bits that the reservoir of available bits
+ *  overflows, ignore the excess.
+ * The encoder will not try to use these extra bits in future frames.
+ * At high rates this may cause the result to be undersized, but allows a
+ *  client to play the stream using a finite buffer; it should normally be
+ *  enabled.*/
+#define TH_RATECTL_CAP_OVERFLOW  (0x2)
+/**Ignore bitrate buffer underflows.
+ * If the encoder uses so many bits that the reservoir of available bits
+ *  underflows, ignore the deficit.
+ * The encoder will not try to make up these extra bits in future frames.
+ * At low rates this may cause the result to be oversized; it should normally
+ *  be disabled.*/
+#define TH_RATECTL_CAP_UNDERFLOW (0x4)
+/*@}*/
+
+
+
+/**The quantization parameters used by VP3.*/
+extern const th_quant_info TH_VP31_QUANT_INFO;
+
+/**The Huffman tables used by VP3.*/
+extern const th_huff_code
+ TH_VP31_HUFF_CODES[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS];
+
+
+
+/**\name Encoder state
+   The following data structure is opaque, and its contents are not publicly
+    defined by this API.
+   Referring to its internals directly is unsupported, and may break without
+    warning.*/
+/*@{*/
+/**The encoder context.*/
+typedef struct th_enc_ctx    th_enc_ctx;
+/*@}*/
+
+
+
+/**\defgroup encfuncs Functions for Encoding*/
+/*@{*/
+/**\name Functions for encoding
+ * You must link to <tt>libtheoraenc</tt> and <tt>libtheoradec</tt>
+ *  if you use any of the functions in this section.
+ *
+ * The functions are listed in the order they are used in a typical encode.
+ * The basic steps are:
+ * - Fill in a #th_info structure with details on the format of the video you
+ *    wish to encode.
+ * - Allocate a #th_enc_ctx handle with th_encode_alloc().
+ * - Perform any additional encoder configuration required with
+ *    th_encode_ctl().
+ * - Repeatedly call th_encode_flushheader() to retrieve all the header
+ *    packets.
+ * - For each uncompressed frame:
+ *   - Submit the uncompressed frame via th_encode_ycbcr_in()
+ *   - Repeatedly call th_encode_packetout() to retrieve any video data packets
+ *      that are ready.
+ * - Call th_encode_free() to release all encoder memory.*/
+/*@{*/
+/**Allocates an encoder instance.
+ * \param _info A #th_info struct filled with the desired encoding parameters.
+ * \return The initialized #th_enc_ctx handle.
+ * \retval NULL If the encoding parameters were invalid.*/
+extern th_enc_ctx *th_encode_alloc(const th_info *_info);
+/**Encoder control function.
+ * This is used to provide advanced control the encoding process.
+ * \param _enc    A #th_enc_ctx handle.
+ * \param _req    The control code to process.
+ *                See \ref encctlcodes "the list of available control codes"
+ *                 for details.
+ * \param _buf    The parameters for this control code.
+ * \param _buf_sz The size of the parameter buffer.*/
+extern int th_encode_ctl(th_enc_ctx *_enc,int _req,void *_buf,size_t _buf_sz);
+/**Outputs the next header packet.
+ * This should be called repeatedly after encoder initialization until it
+ *  returns 0 in order to get all of the header packets, in order, before
+ *  encoding actual video data.
+ * \param _enc      A #th_enc_ctx handle.
+ * \param _comments The metadata to place in the comment header, when it is
+ *                   encoded.
+ * \param _op       An <tt>ogg_packet</tt> structure to fill.
+ *                  All of the elements of this structure will be set,
+ *                   including a pointer to the header data.
+ *                  The memory for the header data is owned by
+ *                   <tt>libtheoraenc</tt>, and may be invalidated when the
+ *                   next encoder function is called.
+ * \return A positive value indicates that a header packet was successfully
+ *          produced.
+ * \retval 0         No packet was produced, and no more header packets remain.
+ * \retval TH_EFAULT \a _enc, \a _comments, or \a _op was <tt>NULL</tt>.*/
+extern int th_encode_flushheader(th_enc_ctx *_enc,
+ th_comment *_comments,ogg_packet *_op);
+/**Submits an uncompressed frame to the encoder.
+ * \param _enc   A #th_enc_ctx handle.
+ * \param _ycbcr A buffer of Y'CbCr data to encode.
+ * \retval 0         Success.
+ * \retval TH_EFAULT \a _enc or \a _ycbcr is <tt>NULL</tt>.
+ * \retval TH_EINVAL The buffer size does not match the frame size the encoder
+ *                    was initialized with, or encoding has already
+ *                    completed.*/
+extern int th_encode_ycbcr_in(th_enc_ctx *_enc,th_ycbcr_buffer _ycbcr);
+/**Retrieves encoded video data packets.
+ * This should be called repeatedly after each frame is submitted to flush any
+ *  encoded packets, until it returns 0.
+ * The encoder will not buffer these packets as subsequent frames are
+ *  compressed, so a failure to do so will result in lost video data.
+ * \note Currently the encoder operates in a one-frame-in, one-packet-out
+ *        manner.
+ *       However, this may be changed in the future.
+ * \param _enc  A #th_enc_ctx handle.
+ * \param _last Set this flag to a non-zero value if no more uncompressed
+ *               frames will be submitted.
+ *              This ensures that a proper EOS flag is set on the last packet.
+ * \param _op   An <tt>ogg_packet</tt> structure to fill.
+ *              All of the elements of this structure will be set, including a
+ *               pointer to the video data.
+ *              The memory for the video data is owned by
+ *               <tt>libtheoraenc</tt>, and may be invalidated when the next
+ *               encoder function is called.
+ * \return A positive value indicates that a video data packet was successfully
+ *          produced.
+ * \retval 0         No packet was produced, and no more encoded video data
+ *                    remains.
+ * \retval TH_EFAULT \a _enc or \a _op was <tt>NULL</tt>.*/
+extern int th_encode_packetout(th_enc_ctx *_enc,int _last,ogg_packet *_op);
+/**Frees an allocated encoder instance.
+ * \param _enc A #th_enc_ctx handle.*/
+extern void th_encode_free(th_enc_ctx *_enc);
+/*@}*/
+/*@}*/
+
+
+
+#if defined(__cplusplus)
+}
+#endif
+
+#endif
diff --git a/install-sh b/install-sh
new file mode 100755 (executable)
index 0000000..11870f1
--- /dev/null
@@ -0,0 +1,251 @@
+#!/bin/sh
+#
+# install - install a program, script, or datafile
+# This comes from X11R5 (mit/util/scripts/install.sh).
+#
+# Copyright 1991 by the Massachusetts Institute of Technology
+#
+# Permission to use, copy, modify, distribute, and sell this software and its
+# documentation for any purpose is hereby granted without fee, provided that
+# the above copyright notice appear in all copies and that both that
+# copyright notice and this permission notice appear in supporting
+# documentation, and that the name of M.I.T. not be used in advertising or
+# publicity pertaining to distribution of the software without specific,
+# written prior permission.  M.I.T. makes no representations about the
+# suitability of this software for any purpose.  It is provided "as is"
+# without express or implied warranty.
+#
+# Calling this script install-sh is preferred over install.sh, to prevent
+# `make' implicit rules from creating a file called install from it
+# when there is no Makefile.
+#
+# This script is compatible with the BSD install script, but was written
+# from scratch.  It can only install one file at a time, a restriction
+# shared with many OS's install programs.
+
+
+# set DOITPROG to echo to test this script
+
+# Don't use :- since 4.3BSD and earlier shells don't like it.
+doit="${DOITPROG-}"
+
+
+# put in absolute paths if you don't have them in your path; or use env. vars.
+
+mvprog="${MVPROG-mv}"
+cpprog="${CPPROG-cp}"
+chmodprog="${CHMODPROG-chmod}"
+chownprog="${CHOWNPROG-chown}"
+chgrpprog="${CHGRPPROG-chgrp}"
+stripprog="${STRIPPROG-strip}"
+rmprog="${RMPROG-rm}"
+mkdirprog="${MKDIRPROG-mkdir}"
+
+transformbasename=""
+transform_arg=""
+instcmd="$mvprog"
+chmodcmd="$chmodprog 0755"
+chowncmd=""
+chgrpcmd=""
+stripcmd=""
+rmcmd="$rmprog -f"
+mvcmd="$mvprog"
+src=""
+dst=""
+dir_arg=""
+
+while [ x"$1" != x ]; do
+    case $1 in
+       -c) instcmd="$cpprog"
+           shift
+           continue;;
+
+       -d) dir_arg=true
+           shift
+           continue;;
+
+       -m) chmodcmd="$chmodprog $2"
+           shift
+           shift
+           continue;;
+
+       -o) chowncmd="$chownprog $2"
+           shift
+           shift
+           continue;;
+
+       -g) chgrpcmd="$chgrpprog $2"
+           shift
+           shift
+           continue;;
+
+       -s) stripcmd="$stripprog"
+           shift
+           continue;;
+
+       -t=*) transformarg=`echo $1 | sed 's/-t=//'`
+           shift
+           continue;;
+
+       -b=*) transformbasename=`echo $1 | sed 's/-b=//'`
+           shift
+           continue;;
+
+       *)  if [ x"$src" = x ]
+           then
+               src=$1
+           else
+               # this colon is to work around a 386BSD /bin/sh bug
+               :
+               dst=$1
+           fi
+           shift
+           continue;;
+    esac
+done
+
+if [ x"$src" = x ]
+then
+       echo "install:  no input file specified"
+       exit 1
+else
+       :
+fi
+
+if [ x"$dir_arg" != x ]; then
+       dst=$src
+       src=""
+       
+       if [ -d $dst ]; then
+               instcmd=:
+               chmodcmd=""
+       else
+               instcmd=$mkdirprog
+       fi
+else
+
+# Waiting for this to be detected by the "$instcmd $src $dsttmp" command
+# might cause directories to be created, which would be especially bad 
+# if $src (and thus $dsttmp) contains '*'.
+
+       if [ -f "$src" ] || [ -d "$src" ]
+       then
+               :
+       else
+               echo "install:  $src does not exist"
+               exit 1
+       fi
+       
+       if [ x"$dst" = x ]
+       then
+               echo "install:  no destination specified"
+               exit 1
+       else
+               :
+       fi
+
+# If destination is a directory, append the input filename; if your system
+# does not like double slashes in filenames, you may need to add some logic
+
+       if [ -d $dst ]
+       then
+               dst="$dst"/`basename $src`
+       else
+               :
+       fi
+fi
+
+## this sed command emulates the dirname command
+dstdir=`echo $dst | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'`
+
+# Make sure that the destination directory exists.
+#  this part is taken from Noah Friedman's mkinstalldirs script
+
+# Skip lots of stat calls in the usual case.
+if [ ! -d "$dstdir" ]; then
+defaultIFS='
+       '
+IFS="${IFS-${defaultIFS}}"
+
+oIFS="${IFS}"
+# Some sh's can't handle IFS=/ for some reason.
+IFS='%'
+set - `echo ${dstdir} | sed -e 's@/@%@g' -e 's@^%@/@'`
+IFS="${oIFS}"
+
+pathcomp=''
+
+while [ $# -ne 0 ] ; do
+       pathcomp="${pathcomp}${1}"
+       shift
+
+       if [ ! -d "${pathcomp}" ] ;
+        then
+               $mkdirprog "${pathcomp}"
+       else
+               :
+       fi
+
+       pathcomp="${pathcomp}/"
+done
+fi
+
+if [ x"$dir_arg" != x ]
+then
+       $doit $instcmd $dst &&
+
+       if [ x"$chowncmd" != x ]; then $doit $chowncmd $dst; else : ; fi &&
+       if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dst; else : ; fi &&
+       if [ x"$stripcmd" != x ]; then $doit $stripcmd $dst; else : ; fi &&
+       if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dst; else : ; fi
+else
+
+# If we're going to rename the final executable, determine the name now.
+
+       if [ x"$transformarg" = x ] 
+       then
+               dstfile=`basename $dst`
+       else
+               dstfile=`basename $dst $transformbasename | 
+                       sed $transformarg`$transformbasename
+       fi
+
+# don't allow the sed command to completely eliminate the filename
+
+       if [ x"$dstfile" = x ] 
+       then
+               dstfile=`basename $dst`
+       else
+               :
+       fi
+
+# Make a temp file name in the proper directory.
+
+       dsttmp=$dstdir/#inst.$$#
+
+# Move or copy the file name to the temp name
+
+       $doit $instcmd $src $dsttmp &&
+
+       trap "rm -f ${dsttmp}" 0 &&
+
+# and set any options; do chmod last to preserve setuid bits
+
+# If any of these fail, we abort the whole thing.  If we want to
+# ignore errors from any of these, just make sure not to ignore
+# errors from the above "$doit $instcmd $src $dsttmp" command.
+
+       if [ x"$chowncmd" != x ]; then $doit $chowncmd $dsttmp; else :;fi &&
+       if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dsttmp; else :;fi &&
+       if [ x"$stripcmd" != x ]; then $doit $stripcmd $dsttmp; else :;fi &&
+       if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dsttmp; else :;fi &&
+
+# Now rename the file to the real destination.
+
+       $doit $rmcmd -f $dstdir/$dstfile &&
+       $doit $mvcmd $dsttmp $dstdir/$dstfile 
+
+fi &&
+
+
+exit 0
diff --git a/lib/Makefile.am b/lib/Makefile.am
new file mode 100644 (file)
index 0000000..89ce261
--- /dev/null
@@ -0,0 +1,173 @@
+INCLUDES = -I$(top_srcdir)/include
+AM_CFLAGS = $(OGG_CFLAGS) $(CAIRO_CFLAGS)
+
+EXTRA_DIST = \
+       cpu.c \
+       encoder_disabled.c \
+       x86/mmxencfrag.c \
+       x86/mmxfdct.c \
+       x86/sse2fdct.c \
+       x86/x86enc.c \
+       x86/x86enc.h \
+       x86/mmxfrag.c \
+       x86/mmxfrag.h \
+       x86/mmxidct.c \
+       x86/mmxloop.h \
+       x86/mmxstate.c \
+       x86/x86int.h \
+       x86/x86state.c \
+       x86_vc
+
+lib_LTLIBRARIES = libtheoradec.la libtheoraenc.la libtheora.la
+
+if THEORA_DISABLE_ENCODE
+encoder_uniq_sources = \
+       encoder_disabled.c
+
+encoder_sources = \
+       $(encoder_uniq_sources)
+else
+encoder_uniq_x86_sources = \
+       x86/mmxencfrag.c \
+       x86/mmxfdct.c \
+       x86/x86enc.c
+
+encoder_uniq_x86_64_sources = \
+       x86/sse2fdct.c
+
+encoder_shared_x86_sources = \
+       x86/mmxfrag.c \
+       x86/mmxidct.c \
+       x86/mmxstate.c \
+       x86/x86state.c
+
+encoder_shared_x86_64_sources =
+
+if CPU_x86_64
+encoder_uniq_arch_sources = \
+ $(encoder_uniq_x86_sources) \
+ $(encoder_uniq_x86_64_sources)
+encoder_shared_arch_sources = \
+ $(encoder_shared_x86_sources) \
+ $(encoder_shared_x86_64_sources)
+else
+if CPU_x86_32
+encoder_uniq_arch_sources = $(encoder_uniq_x86_sources)
+encoder_shared_arch_sources = $(encoder_shared_x86_sources)
+else
+encoder_uniq_arch_sources =
+encoder_shared_arch_sources =
+endif
+endif
+
+encoder_uniq_sources = \
+       analyze.c \
+       fdct.c \
+       encfrag.c \
+       encapiwrapper.c \
+       encinfo.c \
+       encode.c \
+       enquant.c \
+       huffenc.c \
+       mathops.c \
+       mcenc.c \
+       rate.c \
+       tokenize.c \
+       $(encoder_uniq_arch_sources)
+
+encoder_sources = \
+       apiwrapper.c \
+       fragment.c \
+       idct.c \
+       internal.c \
+       state.c \
+       quant.c \
+       $(encoder_shared_arch_sources) \
+       $(encoder_uniq_sources)
+
+endif
+
+decoder_x86_sources = \
+       x86/mmxidct.c \
+       x86/mmxfrag.c \
+       x86/mmxstate.c \
+       x86/x86state.c
+if CPU_x86_64
+decoder_arch_sources = $(decoder_x86_sources)
+else
+if CPU_x86_32
+decoder_arch_sources = $(decoder_x86_sources)
+else
+decoder_arch_sources =
+endif
+endif
+
+decoder_sources = \
+       apiwrapper.c \
+       bitpack.c \
+       decapiwrapper.c \
+       decinfo.c \
+       decode.c \
+       dequant.c \
+       fragment.c \
+       huffdec.c \
+       idct.c \
+       info.c \
+       internal.c \
+       quant.c \
+       state.c \
+       $(decoder_arch_sources)
+
+noinst_HEADERS = \
+       cpu.h \
+       internal.h \
+       encint.h \
+       enquant.h \
+       huffenc.h \
+       mathops.h \
+       modedec.h \
+       x86/x86enc.h \
+       apiwrapper.h \
+       bitpack.h \
+       dct.h \
+       decint.h \
+       dequant.h \
+       huffdec.h \
+       huffman.h \
+       ocintrin.h \
+       quant.h \
+       x86/mmxfrag.h \
+       x86/mmxloop.h \
+       x86/x86int.h
+
+libtheoradec_la_SOURCES = \
+       $(decoder_sources) \
+       Version_script-dec theoradec.exp
+libtheoradec_la_LDFLAGS = \
+  -version-info @THDEC_LIB_CURRENT@:@THDEC_LIB_REVISION@:@THDEC_LIB_AGE@ \
+  @THEORADEC_LDFLAGS@ @CAIRO_LIBS@
+
+libtheoraenc_la_SOURCES = \
+       $(encoder_sources) \
+       Version_script-enc theoraenc.exp
+libtheoraenc_la_LDFLAGS = \
+  -version-info @THENC_LIB_CURRENT@:@THENC_LIB_REVISION@:@THENC_LIB_AGE@ \
+  @THEORAENC_LDFLAGS@ $(OGG_LIBS)
+
+libtheora_la_SOURCES = \
+       $(decoder_sources) \
+       $(encoder_uniq_sources) \
+       Version_script theora.exp
+libtheora_la_LDFLAGS = \
+  -version-info @TH_LIB_CURRENT@:@TH_LIB_REVISION@:@TH_LIB_AGE@ \
+  @THEORA_LDFLAGS@ @CAIRO_LIBS@ $(OGG_LIBS)
+
+debug:
+       $(MAKE) all CFLAGS="@DEBUG@" 
+
+profile:
+       $(MAKE) all CFLAGS="@PROFILE@"
+
+# contstruct various symbol export list files
+.def.exp : defexp.awk
+       awk -f defexp.awk $< > $@
diff --git a/lib/Makefile.in b/lib/Makefile.in
new file mode 100644 (file)
index 0000000..f26ccdc
--- /dev/null
@@ -0,0 +1,845 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+INCLUDES = -I$(top_srcdir)/include
+AM_CFLAGS = $(OGG_CFLAGS) $(CAIRO_CFLAGS)
+
+EXTRA_DIST = \
+       cpu.c \
+       encoder_disabled.c \
+       x86/mmxencfrag.c \
+       x86/mmxfdct.c \
+       x86/sse2fdct.c \
+       x86/x86enc.c \
+       x86/x86enc.h \
+       x86/mmxfrag.c \
+       x86/mmxfrag.h \
+       x86/mmxidct.c \
+       x86/mmxloop.h \
+       x86/mmxstate.c \
+       x86/x86int.h \
+       x86/x86state.c \
+       x86_vc
+
+
+lib_LTLIBRARIES = libtheoradec.la libtheoraenc.la libtheora.la
+
+@THEORA_DISABLE_ENCODE_TRUE@encoder_uniq_sources = \
+@THEORA_DISABLE_ENCODE_TRUE@   encoder_disabled.c
+
+@THEORA_DISABLE_ENCODE_FALSE@encoder_uniq_sources = \
+@THEORA_DISABLE_ENCODE_FALSE@  analyze.c \
+@THEORA_DISABLE_ENCODE_FALSE@  fdct.c \
+@THEORA_DISABLE_ENCODE_FALSE@  encfrag.c \
+@THEORA_DISABLE_ENCODE_FALSE@  encapiwrapper.c \
+@THEORA_DISABLE_ENCODE_FALSE@  encinfo.c \
+@THEORA_DISABLE_ENCODE_FALSE@  encode.c \
+@THEORA_DISABLE_ENCODE_FALSE@  enquant.c \
+@THEORA_DISABLE_ENCODE_FALSE@  huffenc.c \
+@THEORA_DISABLE_ENCODE_FALSE@  mathops.c \
+@THEORA_DISABLE_ENCODE_FALSE@  mcenc.c \
+@THEORA_DISABLE_ENCODE_FALSE@  rate.c \
+@THEORA_DISABLE_ENCODE_FALSE@  tokenize.c \
+@THEORA_DISABLE_ENCODE_FALSE@  $(encoder_uniq_arch_sources)
+
+
+@THEORA_DISABLE_ENCODE_TRUE@encoder_sources = \
+@THEORA_DISABLE_ENCODE_TRUE@   $(encoder_uniq_sources)
+
+@THEORA_DISABLE_ENCODE_FALSE@encoder_sources = \
+@THEORA_DISABLE_ENCODE_FALSE@  apiwrapper.c \
+@THEORA_DISABLE_ENCODE_FALSE@  fragment.c \
+@THEORA_DISABLE_ENCODE_FALSE@  idct.c \
+@THEORA_DISABLE_ENCODE_FALSE@  internal.c \
+@THEORA_DISABLE_ENCODE_FALSE@  state.c \
+@THEORA_DISABLE_ENCODE_FALSE@  quant.c \
+@THEORA_DISABLE_ENCODE_FALSE@  $(encoder_shared_arch_sources) \
+@THEORA_DISABLE_ENCODE_FALSE@  $(encoder_uniq_sources)
+
+@THEORA_DISABLE_ENCODE_FALSE@encoder_uniq_x86_sources = \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/mmxencfrag.c \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/mmxfdct.c \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/x86enc.c
+
+
+@THEORA_DISABLE_ENCODE_FALSE@encoder_uniq_x86_64_sources = \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/sse2fdct.c
+
+
+@THEORA_DISABLE_ENCODE_FALSE@encoder_shared_x86_sources = \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/mmxfrag.c \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/mmxidct.c \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/mmxstate.c \
+@THEORA_DISABLE_ENCODE_FALSE@  x86/x86state.c
+
+
+@THEORA_DISABLE_ENCODE_FALSE@encoder_shared_x86_64_sources = 
+
+@CPU_x86_32_FALSE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@encoder_uniq_arch_sources = 
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@encoder_uniq_arch_sources = $(encoder_uniq_x86_sources)
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@encoder_uniq_arch_sources = \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(encoder_uniq_x86_sources) \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(encoder_uniq_x86_64_sources)
+
+@CPU_x86_32_FALSE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@encoder_shared_arch_sources = 
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@encoder_shared_arch_sources = $(encoder_shared_x86_sources)
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@encoder_shared_arch_sources = \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(encoder_shared_x86_sources) \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(encoder_shared_x86_64_sources)
+
+
+decoder_x86_sources = \
+       x86/mmxidct.c \
+       x86/mmxfrag.c \
+       x86/mmxstate.c \
+       x86/x86state.c
+
+@CPU_x86_32_FALSE@@CPU_x86_64_FALSE@decoder_arch_sources = 
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@decoder_arch_sources = $(decoder_x86_sources)
+@CPU_x86_64_TRUE@decoder_arch_sources = $(decoder_x86_sources)
+
+decoder_sources = \
+       apiwrapper.c \
+       bitpack.c \
+       decapiwrapper.c \
+       decinfo.c \
+       decode.c \
+       dequant.c \
+       fragment.c \
+       huffdec.c \
+       idct.c \
+       info.c \
+       internal.c \
+       quant.c \
+       state.c \
+       $(decoder_arch_sources)
+
+
+noinst_HEADERS = \
+       cpu.h \
+       internal.h \
+       encint.h \
+       enquant.h \
+       huffenc.h \
+       mathops.h \
+       modedec.h \
+       x86/x86enc.h \
+       apiwrapper.h \
+       bitpack.h \
+       dct.h \
+       decint.h \
+       dequant.h \
+       huffdec.h \
+       huffman.h \
+       ocintrin.h \
+       quant.h \
+       x86/mmxfrag.h \
+       x86/mmxloop.h \
+       x86/x86int.h
+
+
+libtheoradec_la_SOURCES = \
+       $(decoder_sources) \
+       Version_script-dec theoradec.exp
+
+libtheoradec_la_LDFLAGS = \
+  -version-info @THDEC_LIB_CURRENT@:@THDEC_LIB_REVISION@:@THDEC_LIB_AGE@ \
+  @THEORADEC_LDFLAGS@ @CAIRO_LIBS@
+
+
+libtheoraenc_la_SOURCES = \
+       $(encoder_sources) \
+       Version_script-enc theoraenc.exp
+
+libtheoraenc_la_LDFLAGS = \
+  -version-info @THENC_LIB_CURRENT@:@THENC_LIB_REVISION@:@THENC_LIB_AGE@ \
+  @THEORAENC_LDFLAGS@ $(OGG_LIBS)
+
+
+libtheora_la_SOURCES = \
+       $(decoder_sources) \
+       $(encoder_uniq_sources) \
+       Version_script theora.exp
+
+libtheora_la_LDFLAGS = \
+  -version-info @TH_LIB_CURRENT@:@TH_LIB_REVISION@:@TH_LIB_AGE@ \
+  @THEORA_LDFLAGS@ @CAIRO_LIBS@ $(OGG_LIBS)
+
+subdir = lib
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES =
+LTLIBRARIES = $(lib_LTLIBRARIES)
+
+libtheora_la_LIBADD =
+am__objects_1 = mmxidct.lo mmxfrag.lo mmxstate.lo x86state.lo
+@CPU_x86_32_FALSE@@CPU_x86_64_FALSE@am__objects_2 =
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@am__objects_2 = $(am__objects_1)
+@CPU_x86_64_TRUE@am__objects_2 = $(am__objects_1)
+am__objects_3 = apiwrapper.lo bitpack.lo decapiwrapper.lo decinfo.lo \
+       decode.lo dequant.lo fragment.lo huffdec.lo idct.lo info.lo \
+       internal.lo quant.lo state.lo $(am__objects_2)
+@THEORA_DISABLE_ENCODE_FALSE@am__objects_4 = mmxencfrag.lo mmxfdct.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  x86enc.lo
+@THEORA_DISABLE_ENCODE_FALSE@am__objects_5 = sse2fdct.lo
+@CPU_x86_32_FALSE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@am__objects_6 =
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@am__objects_6 = \
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@       $(am__objects_4)
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@am__objects_6 = \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(am__objects_4) \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(am__objects_5)
+@THEORA_DISABLE_ENCODE_TRUE@am__objects_7 = encoder_disabled.lo
+@THEORA_DISABLE_ENCODE_FALSE@am__objects_7 = analyze.lo fdct.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  encfrag.lo encapiwrapper.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  encinfo.lo encode.lo enquant.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  huffenc.lo mathops.lo mcenc.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  rate.lo tokenize.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  $(am__objects_6)
+am_libtheora_la_OBJECTS = $(am__objects_3) $(am__objects_7)
+libtheora_la_OBJECTS = $(am_libtheora_la_OBJECTS)
+libtheoradec_la_LIBADD =
+am_libtheoradec_la_OBJECTS = $(am__objects_3)
+libtheoradec_la_OBJECTS = $(am_libtheoradec_la_OBJECTS)
+libtheoraenc_la_LIBADD =
+@THEORA_DISABLE_ENCODE_FALSE@am__objects_8 = mmxfrag.lo mmxidct.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  mmxstate.lo x86state.lo
+@THEORA_DISABLE_ENCODE_FALSE@am__objects_9 =
+@CPU_x86_32_FALSE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@am__objects_10 =
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@am__objects_10 = \
+@CPU_x86_32_TRUE@@CPU_x86_64_FALSE@@THEORA_DISABLE_ENCODE_FALSE@       $(am__objects_8)
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@am__objects_10 = \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(am__objects_8) \
+@CPU_x86_64_TRUE@@THEORA_DISABLE_ENCODE_FALSE@ $(am__objects_9)
+@THEORA_DISABLE_ENCODE_TRUE@am__objects_11 = $(am__objects_7)
+@THEORA_DISABLE_ENCODE_FALSE@am__objects_11 = apiwrapper.lo fragment.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  idct.lo internal.lo state.lo \
+@THEORA_DISABLE_ENCODE_FALSE@  quant.lo $(am__objects_10) \
+@THEORA_DISABLE_ENCODE_FALSE@  $(am__objects_7)
+am_libtheoraenc_la_OBJECTS = $(am__objects_11)
+libtheoraenc_la_OBJECTS = $(am_libtheoraenc_la_OBJECTS)
+
+DEFS = @DEFS@
+DEFAULT_INCLUDES =  -I. -I$(srcdir) -I$(top_builddir)
+CPPFLAGS = @CPPFLAGS@
+LDFLAGS = @LDFLAGS@
+LIBS = @LIBS@
+depcomp = $(SHELL) $(top_srcdir)/depcomp
+am__depfiles_maybe = depfiles
+@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/analyze.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/apiwrapper.Plo ./$(DEPDIR)/bitpack.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/decapiwrapper.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/decinfo.Plo ./$(DEPDIR)/decode.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/dequant.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/encapiwrapper.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/encfrag.Plo ./$(DEPDIR)/encinfo.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/encode.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/encoder_disabled.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/enquant.Plo ./$(DEPDIR)/fdct.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/fragment.Plo ./$(DEPDIR)/huffdec.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/huffenc.Plo ./$(DEPDIR)/idct.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/info.Plo ./$(DEPDIR)/internal.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/mathops.Plo ./$(DEPDIR)/mcenc.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/mmxencfrag.Plo ./$(DEPDIR)/mmxfdct.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/mmxfrag.Plo ./$(DEPDIR)/mmxidct.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/mmxstate.Plo ./$(DEPDIR)/quant.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/rate.Plo ./$(DEPDIR)/sse2fdct.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/state.Plo ./$(DEPDIR)/tokenize.Plo \
+@AMDEP_TRUE@   ./$(DEPDIR)/x86enc.Plo ./$(DEPDIR)/x86state.Plo
+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
+       $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) \
+       $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+CCLD = $(CC)
+LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+       $(AM_LDFLAGS) $(LDFLAGS) -o $@
+CFLAGS = @CFLAGS@
+DIST_SOURCES = $(libtheora_la_SOURCES) $(libtheoradec_la_SOURCES) \
+       $(libtheoraenc_la_SOURCES)
+HEADERS = $(noinst_HEADERS)
+
+DIST_COMMON = $(noinst_HEADERS) Makefile.am Makefile.in
+SOURCES = $(libtheora_la_SOURCES) $(libtheoradec_la_SOURCES) $(libtheoraenc_la_SOURCES)
+
+all: all-am
+
+.SUFFIXES:
+.SUFFIXES: .c .def .exp .lo .o .obj
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  lib/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+libLTLIBRARIES_INSTALL = $(INSTALL)
+install-libLTLIBRARIES: $(lib_LTLIBRARIES)
+       @$(NORMAL_INSTALL)
+       $(mkinstalldirs) $(DESTDIR)$(libdir)
+       @list='$(lib_LTLIBRARIES)'; for p in $$list; do \
+         if test -f $$p; then \
+           f="`echo $$p | sed -e 's|^.*/||'`"; \
+           echo " $(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(libdir)/$$f"; \
+           $(LIBTOOL) --mode=install $(libLTLIBRARIES_INSTALL) $(INSTALL_STRIP_FLAG) $$p $(DESTDIR)$(libdir)/$$f; \
+         else :; fi; \
+       done
+
+uninstall-libLTLIBRARIES:
+       @$(NORMAL_UNINSTALL)
+       @list='$(lib_LTLIBRARIES)'; for p in $$list; do \
+           p="`echo $$p | sed -e 's|^.*/||'`"; \
+         echo " $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p"; \
+         $(LIBTOOL) --mode=uninstall rm -f $(DESTDIR)$(libdir)/$$p; \
+       done
+
+clean-libLTLIBRARIES:
+       -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
+       @list='$(lib_LTLIBRARIES)'; for p in $$list; do \
+         dir="`echo $$p | sed -e 's|/[^/]*$$||'`"; \
+         test -z "$dir" && dir=.; \
+         echo "rm -f \"$${dir}/so_locations\""; \
+         rm -f "$${dir}/so_locations"; \
+       done
+mmxidct.lo: x86/mmxidct.c
+mmxfrag.lo: x86/mmxfrag.c
+mmxstate.lo: x86/mmxstate.c
+x86state.lo: x86/x86state.c
+mmxencfrag.lo: x86/mmxencfrag.c
+mmxfdct.lo: x86/mmxfdct.c
+x86enc.lo: x86/x86enc.c
+sse2fdct.lo: x86/sse2fdct.c
+libtheora.la: $(libtheora_la_OBJECTS) $(libtheora_la_DEPENDENCIES) 
+       $(LINK) -rpath $(libdir) $(libtheora_la_LDFLAGS) $(libtheora_la_OBJECTS) $(libtheora_la_LIBADD) $(LIBS)
+libtheoradec.la: $(libtheoradec_la_OBJECTS) $(libtheoradec_la_DEPENDENCIES) 
+       $(LINK) -rpath $(libdir) $(libtheoradec_la_LDFLAGS) $(libtheoradec_la_OBJECTS) $(libtheoradec_la_LIBADD) $(LIBS)
+libtheoraenc.la: $(libtheoraenc_la_OBJECTS) $(libtheoraenc_la_DEPENDENCIES) 
+       $(LINK) -rpath $(libdir) $(libtheoraenc_la_LDFLAGS) $(libtheoraenc_la_OBJECTS) $(libtheoraenc_la_LIBADD) $(LIBS)
+
+mostlyclean-compile:
+       -rm -f *.$(OBJEXT) core *.core
+
+distclean-compile:
+       -rm -f *.tab.c
+
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/analyze.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/apiwrapper.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bitpack.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/decapiwrapper.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/decinfo.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/decode.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/dequant.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encapiwrapper.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encfrag.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encinfo.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encode.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/encoder_disabled.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/enquant.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fdct.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fragment.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/huffdec.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/huffenc.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/idct.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/info.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/internal.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mathops.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mcenc.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mmxencfrag.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mmxfdct.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mmxfrag.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mmxidct.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mmxstate.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/quant.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rate.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/sse2fdct.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/state.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tokenize.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/x86enc.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/x86state.Plo@am__quote@
+
+distclean-depend:
+       -rm -rf ./$(DEPDIR)
+
+.c.o:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `test -f '$<' || echo '$(srcdir)/'`$<
+
+.c.obj:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `cygpath -w $<`
+
+.c.lo:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LTCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$<
+
+mmxidct.o: x86/mmxidct.c
+@AMDEP_TRUE@   source='x86/mmxidct.c' object='mmxidct.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxidct.Po' tmpdepfile='$(DEPDIR)/mmxidct.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxidct.o `test -f 'x86/mmxidct.c' || echo '$(srcdir)/'`x86/mmxidct.c
+
+mmxidct.obj: x86/mmxidct.c
+@AMDEP_TRUE@   source='x86/mmxidct.c' object='mmxidct.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxidct.Po' tmpdepfile='$(DEPDIR)/mmxidct.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxidct.obj `cygpath -w x86/mmxidct.c`
+
+mmxidct.lo: x86/mmxidct.c
+@AMDEP_TRUE@   source='x86/mmxidct.c' object='mmxidct.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxidct.Plo' tmpdepfile='$(DEPDIR)/mmxidct.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxidct.lo `test -f 'x86/mmxidct.c' || echo '$(srcdir)/'`x86/mmxidct.c
+
+mmxfrag.o: x86/mmxfrag.c
+@AMDEP_TRUE@   source='x86/mmxfrag.c' object='mmxfrag.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxfrag.Po' tmpdepfile='$(DEPDIR)/mmxfrag.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxfrag.o `test -f 'x86/mmxfrag.c' || echo '$(srcdir)/'`x86/mmxfrag.c
+
+mmxfrag.obj: x86/mmxfrag.c
+@AMDEP_TRUE@   source='x86/mmxfrag.c' object='mmxfrag.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxfrag.Po' tmpdepfile='$(DEPDIR)/mmxfrag.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxfrag.obj `cygpath -w x86/mmxfrag.c`
+
+mmxfrag.lo: x86/mmxfrag.c
+@AMDEP_TRUE@   source='x86/mmxfrag.c' object='mmxfrag.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxfrag.Plo' tmpdepfile='$(DEPDIR)/mmxfrag.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxfrag.lo `test -f 'x86/mmxfrag.c' || echo '$(srcdir)/'`x86/mmxfrag.c
+
+mmxstate.o: x86/mmxstate.c
+@AMDEP_TRUE@   source='x86/mmxstate.c' object='mmxstate.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxstate.Po' tmpdepfile='$(DEPDIR)/mmxstate.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxstate.o `test -f 'x86/mmxstate.c' || echo '$(srcdir)/'`x86/mmxstate.c
+
+mmxstate.obj: x86/mmxstate.c
+@AMDEP_TRUE@   source='x86/mmxstate.c' object='mmxstate.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxstate.Po' tmpdepfile='$(DEPDIR)/mmxstate.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxstate.obj `cygpath -w x86/mmxstate.c`
+
+mmxstate.lo: x86/mmxstate.c
+@AMDEP_TRUE@   source='x86/mmxstate.c' object='mmxstate.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxstate.Plo' tmpdepfile='$(DEPDIR)/mmxstate.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxstate.lo `test -f 'x86/mmxstate.c' || echo '$(srcdir)/'`x86/mmxstate.c
+
+x86state.o: x86/x86state.c
+@AMDEP_TRUE@   source='x86/x86state.c' object='x86state.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/x86state.Po' tmpdepfile='$(DEPDIR)/x86state.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o x86state.o `test -f 'x86/x86state.c' || echo '$(srcdir)/'`x86/x86state.c
+
+x86state.obj: x86/x86state.c
+@AMDEP_TRUE@   source='x86/x86state.c' object='x86state.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/x86state.Po' tmpdepfile='$(DEPDIR)/x86state.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o x86state.obj `cygpath -w x86/x86state.c`
+
+x86state.lo: x86/x86state.c
+@AMDEP_TRUE@   source='x86/x86state.c' object='x86state.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/x86state.Plo' tmpdepfile='$(DEPDIR)/x86state.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o x86state.lo `test -f 'x86/x86state.c' || echo '$(srcdir)/'`x86/x86state.c
+
+mmxencfrag.o: x86/mmxencfrag.c
+@AMDEP_TRUE@   source='x86/mmxencfrag.c' object='mmxencfrag.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxencfrag.Po' tmpdepfile='$(DEPDIR)/mmxencfrag.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxencfrag.o `test -f 'x86/mmxencfrag.c' || echo '$(srcdir)/'`x86/mmxencfrag.c
+
+mmxencfrag.obj: x86/mmxencfrag.c
+@AMDEP_TRUE@   source='x86/mmxencfrag.c' object='mmxencfrag.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxencfrag.Po' tmpdepfile='$(DEPDIR)/mmxencfrag.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxencfrag.obj `cygpath -w x86/mmxencfrag.c`
+
+mmxencfrag.lo: x86/mmxencfrag.c
+@AMDEP_TRUE@   source='x86/mmxencfrag.c' object='mmxencfrag.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxencfrag.Plo' tmpdepfile='$(DEPDIR)/mmxencfrag.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxencfrag.lo `test -f 'x86/mmxencfrag.c' || echo '$(srcdir)/'`x86/mmxencfrag.c
+
+mmxfdct.o: x86/mmxfdct.c
+@AMDEP_TRUE@   source='x86/mmxfdct.c' object='mmxfdct.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxfdct.Po' tmpdepfile='$(DEPDIR)/mmxfdct.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxfdct.o `test -f 'x86/mmxfdct.c' || echo '$(srcdir)/'`x86/mmxfdct.c
+
+mmxfdct.obj: x86/mmxfdct.c
+@AMDEP_TRUE@   source='x86/mmxfdct.c' object='mmxfdct.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxfdct.Po' tmpdepfile='$(DEPDIR)/mmxfdct.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxfdct.obj `cygpath -w x86/mmxfdct.c`
+
+mmxfdct.lo: x86/mmxfdct.c
+@AMDEP_TRUE@   source='x86/mmxfdct.c' object='mmxfdct.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/mmxfdct.Plo' tmpdepfile='$(DEPDIR)/mmxfdct.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o mmxfdct.lo `test -f 'x86/mmxfdct.c' || echo '$(srcdir)/'`x86/mmxfdct.c
+
+x86enc.o: x86/x86enc.c
+@AMDEP_TRUE@   source='x86/x86enc.c' object='x86enc.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/x86enc.Po' tmpdepfile='$(DEPDIR)/x86enc.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o x86enc.o `test -f 'x86/x86enc.c' || echo '$(srcdir)/'`x86/x86enc.c
+
+x86enc.obj: x86/x86enc.c
+@AMDEP_TRUE@   source='x86/x86enc.c' object='x86enc.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/x86enc.Po' tmpdepfile='$(DEPDIR)/x86enc.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o x86enc.obj `cygpath -w x86/x86enc.c`
+
+x86enc.lo: x86/x86enc.c
+@AMDEP_TRUE@   source='x86/x86enc.c' object='x86enc.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/x86enc.Plo' tmpdepfile='$(DEPDIR)/x86enc.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o x86enc.lo `test -f 'x86/x86enc.c' || echo '$(srcdir)/'`x86/x86enc.c
+
+sse2fdct.o: x86/sse2fdct.c
+@AMDEP_TRUE@   source='x86/sse2fdct.c' object='sse2fdct.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/sse2fdct.Po' tmpdepfile='$(DEPDIR)/sse2fdct.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o sse2fdct.o `test -f 'x86/sse2fdct.c' || echo '$(srcdir)/'`x86/sse2fdct.c
+
+sse2fdct.obj: x86/sse2fdct.c
+@AMDEP_TRUE@   source='x86/sse2fdct.c' object='sse2fdct.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/sse2fdct.Po' tmpdepfile='$(DEPDIR)/sse2fdct.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o sse2fdct.obj `cygpath -w x86/sse2fdct.c`
+
+sse2fdct.lo: x86/sse2fdct.c
+@AMDEP_TRUE@   source='x86/sse2fdct.c' object='sse2fdct.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/sse2fdct.Plo' tmpdepfile='$(DEPDIR)/sse2fdct.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o sse2fdct.lo `test -f 'x86/sse2fdct.c' || echo '$(srcdir)/'`x86/sse2fdct.c
+CCDEPMODE = @CCDEPMODE@
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       $(mkinstalldirs) $(distdir)/x86
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+check-am: all-am
+check: check-am
+all-am: Makefile $(LTLIBRARIES) $(HEADERS)
+
+installdirs:
+       $(mkinstalldirs) $(DESTDIR)$(libdir)
+
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \
+       mostlyclean-am
+
+distclean: distclean-am
+
+distclean-am: clean-am distclean-compile distclean-depend \
+       distclean-generic distclean-libtool distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+info: info-am
+
+info-am:
+
+install-data-am:
+
+install-exec-am: install-libLTLIBRARIES
+
+install-info: install-info-am
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-compile mostlyclean-generic \
+       mostlyclean-libtool
+
+uninstall-am: uninstall-info-am uninstall-libLTLIBRARIES
+
+.PHONY: GTAGS all all-am check check-am clean clean-generic \
+       clean-libLTLIBRARIES clean-libtool distclean distclean-compile \
+       distclean-depend distclean-generic distclean-libtool \
+       distclean-tags distdir dvi dvi-am info info-am install \
+       install-am install-data install-data-am install-exec \
+       install-exec-am install-info install-info-am \
+       install-libLTLIBRARIES install-man install-strip installcheck \
+       installcheck-am installdirs maintainer-clean \
+       maintainer-clean-generic mostlyclean mostlyclean-compile \
+       mostlyclean-generic mostlyclean-libtool tags uninstall \
+       uninstall-am uninstall-info-am uninstall-libLTLIBRARIES
+
+
+debug:
+       $(MAKE) all CFLAGS="@DEBUG@" 
+
+profile:
+       $(MAKE) all CFLAGS="@PROFILE@"
+
+# contstruct various symbol export list files
+.def.exp : defexp.awk
+       awk -f defexp.awk $< > $@
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/lib/Version_script b/lib/Version_script
new file mode 100644 (file)
index 0000000..2ecb5e4
--- /dev/null
@@ -0,0 +1,53 @@
+#
+# Export file for libtheora
+#
+# Only the symbols listed in the global section will be callable from
+# applications linking to the libraries.
+#
+
+# We use something that looks like a versioned so filename here 
+# to define the old API because of a historical confusion. This
+# label must be kept to maintain ABI compatibility.
+
+libtheora.so.1.0
+{
+       global:
+               theora_version_string;
+               theora_version_number;
+
+               theora_encode_init;
+               theora_encode_YUVin;
+               theora_encode_packetout;
+               theora_encode_header;
+               theora_encode_comment;
+               theora_encode_tables;
+
+               theora_decode_header;
+               theora_decode_init;
+               theora_decode_packetin;
+               theora_decode_YUVout;
+
+               theora_control;
+
+               theora_packet_isheader;
+               theora_packet_iskeyframe;
+
+               theora_granule_shift;
+               theora_granule_frame;
+               theora_granule_time;
+
+               theora_info_init;
+               theora_info_clear;
+
+               theora_clear;
+
+               theora_comment_init;
+               theora_comment_add;
+               theora_comment_add_tag;
+               theora_comment_query;
+               theora_comment_query_count;
+               theora_comment_clear;
+
+       local:
+               *;
+};
diff --git a/lib/Version_script-dec b/lib/Version_script-dec
new file mode 100644 (file)
index 0000000..cab3683
--- /dev/null
@@ -0,0 +1,82 @@
+#
+# Export file for libtheoradec
+#
+# Only the symbols listed in the global section will be callable from
+# applications linking to the libraries.
+#
+
+# The 1.x API
+libtheoradec_1.0
+{
+       global:
+               th_version_string;
+               th_version_number;
+
+               th_decode_headerin;
+               th_decode_alloc;
+               th_setup_free;
+               th_decode_ctl;
+               th_decode_packetin;
+               th_decode_ycbcr_out;
+               th_decode_free;
+
+               th_packet_isheader;
+               th_packet_iskeyframe;
+
+               th_granule_frame;
+               th_granule_time;
+
+               th_info_init;
+               th_info_clear;
+
+               th_comment_init;
+               th_comment_add;
+               th_comment_add_tag;
+               th_comment_query;
+               th_comment_query_count;
+               th_comment_clear;
+
+       local:
+               *;
+};
+
+# The deprecated legacy api from the libtheora alpha releases.
+# We use something that looks like a versioned so filename here 
+# to define the old API because of a historical confusion. This
+# label must be kept to maintain ABI compatibility.
+
+libtheora.so.1.0
+{
+       global:
+               theora_version_string;
+               theora_version_number;
+
+               theora_decode_header;
+               theora_decode_init;
+               theora_decode_packetin;
+               theora_decode_YUVout;
+
+               theora_control;
+
+               theora_packet_isheader;
+               theora_packet_iskeyframe;
+
+               theora_granule_shift;
+               theora_granule_frame;
+               theora_granule_time;
+
+               theora_info_init;
+               theora_info_clear;
+
+               theora_clear;
+
+               theora_comment_init;
+               theora_comment_add;
+               theora_comment_add_tag;
+               theora_comment_query;
+               theora_comment_query_count;
+               theora_comment_clear;
+
+       local:
+               *;
+};
diff --git a/lib/Version_script-enc b/lib/Version_script-enc
new file mode 100644 (file)
index 0000000..37699ed
--- /dev/null
@@ -0,0 +1,43 @@
+#
+# Export file for libtheora
+#
+# Only the symbols listed in the global section will be callable from
+# applications linking to the libraries.
+#
+
+# The 1.x encoder API
+libtheoraenc_1.0
+{
+       global:
+               th_encode_alloc;
+               th_encode_ctl;
+               th_encode_flushheader;
+               th_encode_ycbcr_in;
+               th_encode_packetout;
+               th_encode_free;
+
+               TH_VP31_QUANT_INFO;
+               TH_VP31_HUFF_CODES;
+
+       local:
+               *;
+};
+
+# The encoder portion of the deprecated alpha release api.
+# We use something that looks like a versioned so filename here 
+# to define the old API because of a historical confusion. This
+# label must be kept to maintain ABI compatibility.
+
+libtheora.so.1.0
+{
+       global:
+               theora_encode_init;
+               theora_encode_YUVin;
+               theora_encode_packetout;
+               theora_encode_header;
+               theora_encode_comment;
+               theora_encode_tables;
+
+       local:
+               *;
+};
diff --git a/lib/analyze.c b/lib/analyze.c
new file mode 100644 (file)
index 0000000..af01b60
--- /dev/null
@@ -0,0 +1,2709 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: mode selection code
+  last mod: $Id$
+
+ ********************************************************************/
+#include <limits.h>
+#include <string.h>
+#include "encint.h"
+#include "modedec.h"
+
+
+
+typedef struct oc_fr_state           oc_fr_state;
+typedef struct oc_qii_state          oc_qii_state;
+typedef struct oc_enc_pipeline_state oc_enc_pipeline_state;
+typedef struct oc_rd_metric          oc_rd_metric;
+typedef struct oc_mode_choice        oc_mode_choice;
+
+
+
+/*There are 8 possible schemes used to encode macro block modes.
+  Schemes 0-6 use a maximally-skewed Huffman code to code each of the modes.
+  The same set of Huffman codes is used for each of these 7 schemes, but the
+   mode assigned to each codeword varies.
+  Scheme 0 writes a custom mapping from codeword to MB mode to the bitstream,
+   while schemes 1-6 have a fixed mapping.
+  Scheme 7 just encodes each mode directly in 3 bits.*/
+
+/*The mode orderings for the various mode coding schemes.
+  Scheme 0 uses a custom alphabet, which is not stored in this table.
+  This is the inverse of the equivalent table OC_MODE_ALPHABETS in the
+   decoder.*/
+static const unsigned char OC_MODE_RANKS[7][OC_NMODES]={
+  /*Last MV dominates.*/ 
+  /*L P M N I G GM 4*/
+  {3,4,2,0,1,5,6,7},
+  /*L P N M I G GM 4*/
+  {2,4,3,0,1,5,6,7},
+  /*L M P N I G GM 4*/
+  {3,4,1,0,2,5,6,7},
+  /*L M N P I G GM 4*/
+  {2,4,1,0,3,5,6,7},
+  /*No MV dominates.*/
+  /*N L P M I G GM 4*/
+  {0,4,3,1,2,5,6,7},
+  /*N G L P M I GM 4*/
+  {0,5,4,2,3,1,6,7},
+  /*Default ordering.*/
+  /*N I M L P G GM 4*/
+  {0,1,2,3,4,5,6,7}
+};
+
+
+
+/*Initialize the mode scheme chooser.
+  This need only be called once per encoder.*/
+void oc_mode_scheme_chooser_init(oc_mode_scheme_chooser *_chooser){
+  int si;
+  _chooser->mode_ranks[0]=_chooser->scheme0_ranks;
+  for(si=1;si<8;si++)_chooser->mode_ranks[si]=OC_MODE_RANKS[si-1];
+}
+
+/*Reset the mode scheme chooser.
+  This needs to be called once for each frame, including the first.*/
+static void oc_mode_scheme_chooser_reset(oc_mode_scheme_chooser *_chooser){
+  int si;
+  memset(_chooser->mode_counts,0,OC_NMODES*sizeof(*_chooser->mode_counts));
+  /*Scheme 0 starts with 24 bits to store the mode list in.*/
+  _chooser->scheme_bits[0]=24;
+  memset(_chooser->scheme_bits+1,0,7*sizeof(*_chooser->scheme_bits));
+  for(si=0;si<8;si++){
+    /*Scheme 7 should always start first, and scheme 0 should always start
+       last.*/
+    _chooser->scheme_list[si]=7-si;
+    _chooser->scheme0_list[si]=_chooser->scheme0_ranks[si]=si;
+  }
+}
+
+
+/*This is the real purpose of this data structure: not actually selecting a
+   mode scheme, but estimating the cost of coding a given mode given all the
+   modes selected so far.
+  This is done via opportunity cost: the cost is defined as the number of bits
+   required to encode all the modes selected so far including the current one
+   using the best possible scheme, minus the number of bits required to encode
+   all the modes selected so far not including the current one using the best
+   possible scheme.
+  The computational expense of doing this probably makes it overkill.
+  Just be happy we take a greedy approach instead of trying to solve the
+   global mode-selection problem (which is NP-hard).
+  _mb_mode: The mode to determine the cost of.
+  Return: The number of bits required to code this mode.*/
+static int oc_mode_scheme_chooser_cost(oc_mode_scheme_chooser *_chooser,
+ int _mb_mode){
+  int scheme0;
+  int scheme1;
+  int best_bits;
+  int mode_bits;
+  int si;
+  int scheme_bits;
+  scheme0=_chooser->scheme_list[0];
+  scheme1=_chooser->scheme_list[1];
+  best_bits=_chooser->scheme_bits[scheme0];
+  mode_bits=OC_MODE_BITS[scheme0+1>>3][_chooser->mode_ranks[scheme0][_mb_mode]];
+  /*Typical case: If the difference between the best scheme and the next best
+     is greater than 6 bits, then adding just one mode cannot change which
+     scheme we use.*/
+  if(_chooser->scheme_bits[scheme1]-best_bits>6)return mode_bits;
+  /*Otherwise, check to see if adding this mode selects a different scheme as
+     the best.*/
+  si=1;
+  best_bits+=mode_bits;
+  do{
+    /*For any scheme except 0, we can just use the bit cost of the mode's rank
+       in that scheme.*/
+    if(scheme1!=0){
+      scheme_bits=_chooser->scheme_bits[scheme1]+
+       OC_MODE_BITS[scheme1+1>>3][_chooser->mode_ranks[scheme1][_mb_mode]];
+    }
+    else{
+      int ri;
+      /*For scheme 0, incrementing the mode count could potentially change the
+         mode's rank.
+        Find the index where the mode would be moved to in the optimal list,
+         and use its bit cost instead of the one for the mode's current
+         position in the list.*/
+      /*We don't recompute scheme bits; this is computing opportunity cost, not
+         an update.*/
+      for(ri=_chooser->scheme0_ranks[_mb_mode];ri>0&&
+       _chooser->mode_counts[_mb_mode]>=
+       _chooser->mode_counts[_chooser->scheme0_list[ri-1]];ri--);
+      scheme_bits=_chooser->scheme_bits[0]+OC_MODE_BITS[0][ri];
+    }
+    if(scheme_bits<best_bits)best_bits=scheme_bits;
+    if(++si>=8)break;
+    scheme1=_chooser->scheme_list[si];
+  }
+  while(_chooser->scheme_bits[scheme1]-_chooser->scheme_bits[scheme0]<=6);
+  return best_bits-_chooser->scheme_bits[scheme0];
+}
+
+/*Incrementally update the mode counts and per-scheme bit counts and re-order
+   the scheme lists once a mode has been selected.
+  _mb_mode: The mode that was chosen.*/
+static void oc_mode_scheme_chooser_update(oc_mode_scheme_chooser *_chooser,
+ int _mb_mode){
+  int ri;
+  int si;
+  _chooser->mode_counts[_mb_mode]++;
+  /*Re-order the scheme0 mode list if necessary.*/
+  for(ri=_chooser->scheme0_ranks[_mb_mode];ri>0;ri--){
+    int pmode;
+    pmode=_chooser->scheme0_list[ri-1];
+    if(_chooser->mode_counts[pmode]>=_chooser->mode_counts[_mb_mode])break;
+    /*Reorder the mode ranking.*/
+    _chooser->scheme0_ranks[pmode]++;
+    _chooser->scheme0_list[ri]=pmode;
+  }
+  _chooser->scheme0_ranks[_mb_mode]=ri;
+  _chooser->scheme0_list[ri]=_mb_mode;
+  /*Now add the bit cost for the mode to each scheme.*/
+  for(si=0;si<8;si++){
+    _chooser->scheme_bits[si]+=
+     OC_MODE_BITS[si+1>>3][_chooser->mode_ranks[si][_mb_mode]];
+  }
+  /*Finally, re-order the list of schemes.*/
+  for(si=1;si<8;si++){
+    int sj;
+    int scheme0;
+    int bits0;
+    sj=si;
+    scheme0=_chooser->scheme_list[si];
+    bits0=_chooser->scheme_bits[scheme0];
+    do{
+      int scheme1;
+      scheme1=_chooser->scheme_list[sj-1];
+      if(bits0>=_chooser->scheme_bits[scheme1])break;
+      _chooser->scheme_list[sj]=scheme1;
+    }
+    while(--sj>0);
+    _chooser->scheme_list[sj]=scheme0;
+  }
+}
+
+
+
+/*The number of bits required to encode a super block run.
+  _run_count: The desired run count; must be positive and less than 4130.*/
+static int oc_sb_run_bits(int _run_count){
+  int i;
+  for(i=0;_run_count>=OC_SB_RUN_VAL_MIN[i+1];i++);
+  return OC_SB_RUN_CODE_NBITS[i];
+}
+
+/*The number of bits required to encode a block run.
+  _run_count: The desired run count; must be positive and less than 30.*/
+static int oc_block_run_bits(int _run_count){
+  return OC_BLOCK_RUN_CODE_NBITS[_run_count-1];
+}
+
+
+
+/*State to track coded block flags and their bit cost.*/
+struct oc_fr_state{
+  ptrdiff_t  bits;
+  unsigned   sb_partial_count:16;
+  unsigned   sb_full_count:16;
+  unsigned   b_coded_count_prev:8;
+  unsigned   b_coded_count:8;
+  unsigned   b_count:8;
+  signed int sb_partial:2;
+  signed int sb_full:2;
+  signed int b_coded_prev:2;
+  signed int b_coded:2;
+};
+
+
+
+static void oc_fr_state_init(oc_fr_state *_fr){
+  _fr->bits=0;
+  _fr->sb_partial_count=0;
+  _fr->sb_full_count=0;
+  _fr->b_coded_count_prev=0;
+  _fr->b_coded_count=0;
+  _fr->b_count=0;
+  _fr->sb_partial=-1;
+  _fr->sb_full=-1;
+  _fr->b_coded_prev=-1;
+  _fr->b_coded=-1;
+}
+
+
+static void oc_fr_state_advance_sb(oc_fr_state *_fr,
+ int _sb_partial,int _sb_full){
+  ptrdiff_t bits;
+  int       sb_partial_count;
+  int       sb_full_count;
+  bits=_fr->bits;
+  /*Extend the sb_partial run, or start a new one.*/
+  sb_partial_count=_fr->sb_partial;
+  if(_fr->sb_partial==_sb_partial){
+    if(sb_partial_count>=4129){
+      bits++;
+      sb_partial_count=0;
+    }
+    else bits-=oc_sb_run_bits(sb_partial_count);
+  }
+  else sb_partial_count=0;
+  sb_partial_count++;
+  bits+=oc_sb_run_bits(sb_partial_count);
+  if(!_sb_partial){
+    /*Extend the sb_full run, or start a new one.*/
+    sb_full_count=_fr->sb_full_count;
+    if(_fr->sb_full==_sb_full){
+      if(sb_full_count>=4129){
+        bits++;
+        sb_full_count=0;
+      }
+      else bits-=oc_sb_run_bits(sb_full_count);
+    }
+    else sb_full_count=0;
+    sb_full_count++;
+    bits+=oc_sb_run_bits(sb_full_count);
+    _fr->sb_full=_sb_full;
+    _fr->sb_full_count=sb_full_count;
+  }
+  _fr->bits=bits;
+  _fr->sb_partial=_sb_partial;
+  _fr->sb_partial_count=sb_partial_count;
+}
+
+/*Flush any outstanding block flags for a SB (e.g., one with fewer than 16
+   blocks).*/
+static void oc_fr_state_flush_sb(oc_fr_state *_fr){
+  ptrdiff_t bits;
+  int       sb_partial;
+  int       sb_full=sb_full;
+  int       b_coded_count;
+  int       b_coded;
+  int       b_count;
+  b_count=_fr->b_count;
+  if(b_count>0){
+    bits=_fr->bits;
+    b_coded=_fr->b_coded;
+    b_coded_count=_fr->b_coded_count;
+    if(b_coded_count>=b_count){
+      /*This SB was fully coded/uncoded; roll back the partial block flags.*/
+      bits-=oc_block_run_bits(b_coded_count);
+      if(b_coded_count>b_count)bits+=oc_block_run_bits(b_coded_count-b_count);
+      sb_partial=0;
+      sb_full=b_coded;
+      b_coded=_fr->b_coded_prev;
+      b_coded_count=_fr->b_coded_count_prev;
+    }
+    else{
+      /*It was partially coded.*/
+      sb_partial=1;
+      /*sb_full is unused.*/
+    }
+    _fr->bits=bits;
+    _fr->b_coded_count=b_coded_count;
+    _fr->b_coded_count_prev=b_coded_count;
+    _fr->b_count=0;
+    _fr->b_coded=b_coded;
+    _fr->b_coded_prev=b_coded;
+    oc_fr_state_advance_sb(_fr,sb_partial,sb_full);
+  }
+}
+
+static void oc_fr_state_advance_block(oc_fr_state *_fr,int _b_coded){
+  ptrdiff_t bits;
+  int       b_coded_count;
+  int       b_count;
+  int       sb_partial;
+  int       sb_full=sb_full;
+  bits=_fr->bits;
+  /*Extend the b_coded run, or start a new one.*/
+  b_coded_count=_fr->b_coded_count;
+  if(_fr->b_coded==_b_coded)bits-=oc_block_run_bits(b_coded_count);
+  else b_coded_count=0;
+  b_coded_count++;
+  b_count=_fr->b_count+1;
+  if(b_count>=16){
+    /*We finished a superblock.*/
+    if(b_coded_count>=16){
+      /*It was fully coded/uncoded; roll back the partial block flags.*/
+      if(b_coded_count>16)bits+=oc_block_run_bits(b_coded_count-16);
+      sb_partial=0;
+      sb_full=_b_coded;
+      _b_coded=_fr->b_coded_prev;
+      b_coded_count=_fr->b_coded_count_prev;
+    }
+    else{
+      bits+=oc_block_run_bits(b_coded_count);
+      /*It was partially coded.*/
+      sb_partial=1;
+      /*sb_full is unused.*/
+    }
+    _fr->bits=bits;
+    _fr->b_coded_count=b_coded_count;
+    _fr->b_coded_count_prev=b_coded_count;
+    _fr->b_count=0;
+    _fr->b_coded=_b_coded;
+    _fr->b_coded_prev=_b_coded;
+    oc_fr_state_advance_sb(_fr,sb_partial,sb_full);
+  }
+  else{
+    bits+=oc_block_run_bits(b_coded_count);
+    _fr->bits=bits;
+    _fr->b_coded_count=b_coded_count;
+    _fr->b_count=b_count;
+    _fr->b_coded=_b_coded;
+  }
+}
+
+static void oc_fr_skip_block(oc_fr_state *_fr){
+  oc_fr_state_advance_block(_fr,0);
+}
+
+static void oc_fr_code_block(oc_fr_state *_fr){
+  oc_fr_state_advance_block(_fr,1);
+}
+
+static int oc_fr_cost1(const oc_fr_state *_fr){
+  oc_fr_state tmp;
+  ptrdiff_t   bits;
+  *&tmp=*_fr;
+  oc_fr_skip_block(&tmp);
+  bits=tmp.bits;
+  *&tmp=*_fr;
+  oc_fr_code_block(&tmp);
+  return (int)(tmp.bits-bits);
+}
+
+static int oc_fr_cost4(const oc_fr_state *_pre,const oc_fr_state *_post){
+  oc_fr_state tmp;
+  *&tmp=*_pre;
+  oc_fr_skip_block(&tmp);
+  oc_fr_skip_block(&tmp);
+  oc_fr_skip_block(&tmp);
+  oc_fr_skip_block(&tmp);
+  return (int)(_post->bits-tmp.bits);
+}
+
+
+
+struct oc_qii_state{
+  ptrdiff_t  bits;
+  unsigned   qi01_count:14;
+  signed int qi01:2;
+  unsigned   qi12_count:14;
+  signed int qi12:2;
+};
+
+
+
+static void oc_qii_state_init(oc_qii_state *_qs){
+  _qs->bits=0;
+  _qs->qi01_count=0;
+  _qs->qi01=-1;
+  _qs->qi12_count=0;
+  _qs->qi12=-1;
+}
+
+
+static void oc_qii_state_advance(oc_qii_state *_qd,
+ const oc_qii_state *_qs,int _qii){
+  ptrdiff_t bits;
+  int       qi01;
+  int       qi01_count;
+  int       qi12;
+  int       qi12_count;
+  bits=_qs->bits;
+  qi01=_qii+1>>1;
+  qi01_count=_qs->qi01_count;
+  if(qi01==_qs->qi01){
+    if(qi01_count>=4129){
+      bits++;
+      qi01_count=0;
+    }
+    else bits-=oc_sb_run_bits(qi01_count);
+  }
+  else qi01_count=0;
+  qi01_count++;
+  bits+=oc_sb_run_bits(qi01_count);
+  qi12_count=_qs->qi12_count;
+  if(_qii){
+    qi12=_qii>>1;
+    if(qi12==_qs->qi12){
+      if(qi12_count>=4129){
+        bits++;
+        qi12_count=0;
+      }
+      else bits-=oc_sb_run_bits(qi12_count);
+    }
+    else qi12_count=0;
+    qi12_count++;
+    bits+=oc_sb_run_bits(qi12_count);
+  }
+  else qi12=_qs->qi12;
+  _qd->bits=bits;
+  _qd->qi01=qi01;
+  _qd->qi01_count=qi01_count;
+  _qd->qi12=qi12;
+  _qd->qi12_count=qi12_count;
+}
+
+
+
+/*Temporary encoder state for the analysis pipeline.*/
+struct oc_enc_pipeline_state{
+  int                 bounding_values[256];
+  oc_fr_state         fr[3];
+  oc_qii_state        qs[3];
+  /*Condensed dequantization tables.*/
+  const ogg_uint16_t *dequant[3][3][2];
+  /*Condensed quantization tables.*/
+  const oc_iquant    *enquant[3][3][2];
+  /*Skip SSD storage for the current MCU in each plane.*/
+  unsigned           *skip_ssd[3];
+  /*Coded/uncoded fragment lists for each plane for the current MCU.*/
+  ptrdiff_t          *coded_fragis[3];
+  ptrdiff_t          *uncoded_fragis[3];
+  ptrdiff_t           ncoded_fragis[3];
+  ptrdiff_t           nuncoded_fragis[3];
+  /*The starting fragment for the current MCU in each plane.*/
+  ptrdiff_t           froffset[3];
+  /*The starting row for the current MCU in each plane.*/
+  int                 fragy0[3];
+  /*The ending row for the current MCU in each plane.*/
+  int                 fragy_end[3];
+  /*The starting superblock for the current MCU in each plane.*/
+  unsigned            sbi0[3];
+  /*The ending superblock for the current MCU in each plane.*/
+  unsigned            sbi_end[3];
+  /*The number of tokens for zzi=1 for each color plane.*/
+  int                 ndct_tokens1[3];
+  /*The outstanding eob_run count for zzi=1 for each color plane.*/
+  int                 eob_run1[3];
+  /*Whether or not the loop filter is enabled.*/
+  int                 loop_filter;
+};
+
+
+static void oc_enc_pipeline_init(oc_enc_ctx *_enc,oc_enc_pipeline_state *_pipe){
+  ptrdiff_t *coded_fragis;
+  unsigned   mcu_nvsbs;
+  ptrdiff_t  mcu_nfrags;
+  int        hdec;
+  int        vdec;
+  int        pli;
+  int        qii;
+  int        qti;
+  /*Initialize the per-plane coded block flag trackers.
+    These are used for bit-estimation purposes only; the real flag bits span
+     all three planes, so we can't compute them in parallel.*/
+  for(pli=0;pli<3;pli++)oc_fr_state_init(_pipe->fr+pli);
+  for(pli=0;pli<3;pli++)oc_qii_state_init(_pipe->qs+pli);
+  /*Set up the per-plane skip SSD storage pointers.*/
+  mcu_nvsbs=_enc->mcu_nvsbs;
+  mcu_nfrags=mcu_nvsbs*_enc->state.fplanes[0].nhsbs*16;
+  hdec=!(_enc->state.info.pixel_fmt&1);
+  vdec=!(_enc->state.info.pixel_fmt&2);
+  _pipe->skip_ssd[0]=_enc->mcu_skip_ssd;
+  _pipe->skip_ssd[1]=_pipe->skip_ssd[0]+mcu_nfrags;
+  _pipe->skip_ssd[2]=_pipe->skip_ssd[1]+(mcu_nfrags>>hdec+vdec);
+  /*Set up per-plane pointers to the coded and uncoded fragments lists.
+    Unlike the decoder, each planes' coded and uncoded fragment list is kept
+     separate during the analysis stage; we only make the coded list for all
+     three planes contiguous right before the final packet is output
+     (destroying the uncoded lists, which are no longer needed).*/
+  coded_fragis=_enc->state.coded_fragis;
+  for(pli=0;pli<3;pli++){
+    _pipe->coded_fragis[pli]=coded_fragis;
+    coded_fragis+=_enc->state.fplanes[pli].nfrags;
+    _pipe->uncoded_fragis[pli]=coded_fragis;
+  }
+  memset(_pipe->ncoded_fragis,0,sizeof(_pipe->ncoded_fragis));
+  memset(_pipe->nuncoded_fragis,0,sizeof(_pipe->nuncoded_fragis));
+  /*Set up condensed quantizer tables.*/
+  for(pli=0;pli<3;pli++){
+    for(qii=0;qii<_enc->state.nqis;qii++){
+      int qi;
+      qi=_enc->state.qis[qii];
+      for(qti=0;qti<2;qti++){
+        _pipe->dequant[pli][qii][qti]=_enc->state.dequant_tables[qi][pli][qti];
+        _pipe->enquant[pli][qii][qti]=_enc->enquant_tables[qi][pli][qti];
+      }
+    }
+  }
+  /*Initialize the tokenization state.*/
+  for(pli=0;pli<3;pli++){
+    _pipe->ndct_tokens1[pli]=0;
+    _pipe->eob_run1[pli]=0;
+  }
+  /*Initialize the bounding value array for the loop filter.*/
+  _pipe->loop_filter=!oc_state_loop_filter_init(&_enc->state,
+   _pipe->bounding_values);
+}
+
+/*Sets the current MCU stripe to super block row _sby.
+  Return: A non-zero value if this was the last MCU.*/
+static int oc_enc_pipeline_set_stripe(oc_enc_ctx *_enc,
+ oc_enc_pipeline_state *_pipe,int _sby){
+  const oc_fragment_plane *fplane;
+  unsigned                 mcu_nvsbs;
+  int                      sby_end;
+  int                      notdone;
+  int                      vdec;
+  int                      pli;
+  mcu_nvsbs=_enc->mcu_nvsbs;
+  sby_end=_enc->state.fplanes[0].nvsbs;
+  notdone=_sby+mcu_nvsbs<sby_end;
+  if(notdone)sby_end=_sby+mcu_nvsbs;
+  vdec=0;
+  for(pli=0;pli<3;pli++){
+    fplane=_enc->state.fplanes+pli;
+    _pipe->sbi0[pli]=fplane->sboffset+(_sby>>vdec)*fplane->nhsbs;
+    _pipe->fragy0[pli]=_sby<<2-vdec;
+    _pipe->froffset[pli]=fplane->froffset
+     +_pipe->fragy0[pli]*(ptrdiff_t)fplane->nhfrags;
+    if(notdone){
+      _pipe->sbi_end[pli]=fplane->sboffset+(sby_end>>vdec)*fplane->nhsbs;
+      _pipe->fragy_end[pli]=sby_end<<2-vdec;
+    }
+    else{
+      _pipe->sbi_end[pli]=fplane->sboffset+fplane->nsbs;
+      _pipe->fragy_end[pli]=fplane->nvfrags;
+    }
+    vdec=!(_enc->state.info.pixel_fmt&2);
+  }
+  return notdone;
+}
+
+static void oc_enc_pipeline_finish_mcu_plane(oc_enc_ctx *_enc,
+ oc_enc_pipeline_state *_pipe,int _pli,int _sdelay,int _edelay){
+  int refi;
+  /*Copy over all the uncoded fragments from this plane and advance the uncoded
+     fragment list.*/
+  _pipe->uncoded_fragis[_pli]-=_pipe->nuncoded_fragis[_pli];
+  oc_state_frag_copy_list(&_enc->state,_pipe->uncoded_fragis[_pli],
+   _pipe->nuncoded_fragis[_pli],OC_FRAME_SELF,OC_FRAME_PREV,_pli);
+  _pipe->nuncoded_fragis[_pli]=0;
+  /*Perform DC prediction.*/
+  oc_enc_pred_dc_frag_rows(_enc,_pli,
+   _pipe->fragy0[_pli],_pipe->fragy_end[_pli]);
+  /*Finish DC tokenization.*/
+  oc_enc_tokenize_dc_frag_list(_enc,_pli,
+   _pipe->coded_fragis[_pli],_pipe->ncoded_fragis[_pli],
+   _pipe->ndct_tokens1[_pli],_pipe->eob_run1[_pli]);
+  _pipe->ndct_tokens1[_pli]=_enc->ndct_tokens[_pli][1];
+  _pipe->eob_run1[_pli]=_enc->eob_run[_pli][1];
+  /*And advance the coded fragment list.*/
+  _enc->state.ncoded_fragis[_pli]+=_pipe->ncoded_fragis[_pli];
+  _pipe->coded_fragis[_pli]+=_pipe->ncoded_fragis[_pli];
+  _pipe->ncoded_fragis[_pli]=0;
+  /*Apply the loop filter if necessary.*/
+  refi=_enc->state.ref_frame_idx[OC_FRAME_SELF];
+  if(_pipe->loop_filter){
+    oc_state_loop_filter_frag_rows(&_enc->state,_pipe->bounding_values,
+     refi,_pli,_pipe->fragy0[_pli]-_sdelay,_pipe->fragy_end[_pli]-_edelay);
+  }
+  else _sdelay=_edelay=0;
+  /*To fill borders, we have an additional two pixel delay, since a fragment
+     in the next row could filter its top edge, using two pixels from a
+     fragment in this row.
+    But there's no reason to delay a full fragment between the two.*/
+  oc_state_borders_fill_rows(&_enc->state,refi,_pli,
+   (_pipe->fragy0[_pli]-_sdelay<<3)-(_sdelay<<1),
+   (_pipe->fragy_end[_pli]-_edelay<<3)-(_edelay<<1));
+}
+
+
+
+/*Cost information about the coded blocks in a MB.*/
+struct oc_rd_metric{
+  int uncoded_ac_ssd;
+  int coded_ac_ssd;
+  int ac_bits;
+  int dc_flag;
+};
+
+
+
+static int oc_enc_block_transform_quantize(oc_enc_ctx *_enc,
+ oc_enc_pipeline_state *_pipe,int _pli,ptrdiff_t _fragi,int _overhead_bits,
+ oc_rd_metric *_mo,oc_token_checkpoint **_stack){
+  OC_ALIGN16(ogg_int16_t  dct[64]);
+  OC_ALIGN16(ogg_int16_t  data[64]);
+  ogg_uint16_t            dc_dequant;
+  const ogg_uint16_t     *dequant;
+  const oc_iquant        *enquant;
+  ptrdiff_t               frag_offs;
+  int                     ystride;
+  const unsigned char    *src;
+  const unsigned char    *ref;
+  unsigned char          *dst;
+  int                     frame_type;
+  int                     nonzero;
+  unsigned                uncoded_ssd;
+  unsigned                coded_ssd;
+  int                     coded_dc;
+  oc_token_checkpoint    *checkpoint;
+  oc_fragment            *frags;
+  int                     mb_mode;
+  int                     mv_offs[2];
+  int                     nmv_offs;
+  int                     ac_bits;
+  int                     borderi;
+  int                     qti;
+  int                     qii;
+  int                     pi;
+  int                     zzi;
+  int                     v;
+  int                     val;
+  int                     d;
+  int                     s;
+  int                     dc;
+  frags=_enc->state.frags;
+  frag_offs=_enc->state.frag_buf_offs[_fragi];
+  ystride=_enc->state.ref_ystride[_pli];
+  src=_enc->state.ref_frame_data[OC_FRAME_IO]+frag_offs;
+  borderi=frags[_fragi].borderi;
+  qii=frags[_fragi].qii;
+  if(qii&~3){
+#if !defined(OC_COLLECT_METRICS)
+    if(_enc->sp_level>=OC_SP_LEVEL_EARLY_SKIP){
+      /*Enable early skip detection.*/
+      frags[_fragi].coded=0;
+      return 0;
+    }
+#endif
+    /*Try and code this block anyway.*/
+    qii&=3;
+    frags[_fragi].qii=qii;
+  }
+  mb_mode=frags[_fragi].mb_mode;
+  ref=_enc->state.ref_frame_data[
+   _enc->state.ref_frame_idx[OC_FRAME_FOR_MODE(mb_mode)]]+frag_offs;
+  dst=_enc->state.ref_frame_data[_enc->state.ref_frame_idx[OC_FRAME_SELF]]
+   +frag_offs;
+  /*Motion compensation:*/
+  switch(mb_mode){
+    case OC_MODE_INTRA:{
+      nmv_offs=0;
+      oc_enc_frag_sub_128(_enc,data,src,ystride);
+    }break;
+    case OC_MODE_GOLDEN_NOMV:
+    case OC_MODE_INTER_NOMV:{
+      nmv_offs=1;
+      mv_offs[0]=0;
+      oc_enc_frag_sub(_enc,data,src,ref,ystride);
+    }break;
+    default:{
+      const oc_mv *frag_mvs;
+      frag_mvs=(const oc_mv *)_enc->state.frag_mvs;
+      nmv_offs=oc_state_get_mv_offsets(&_enc->state,mv_offs,_pli,
+       frag_mvs[_fragi][0],frag_mvs[_fragi][1]);
+      if(nmv_offs>1){
+        oc_enc_frag_copy2(_enc,dst,
+         ref+mv_offs[0],ref+mv_offs[1],ystride);
+        oc_enc_frag_sub(_enc,data,src,dst,ystride);
+      }
+      else oc_enc_frag_sub(_enc,data,src,ref+mv_offs[0],ystride);
+    }break;
+  }
+#if defined(OC_COLLECT_METRICS)
+  {
+    unsigned satd;
+    switch(nmv_offs){
+      case 0:satd=oc_enc_frag_intra_satd(_enc,src,ystride);break;
+      case 1:{
+        satd=oc_enc_frag_satd_thresh(_enc,src,ref+mv_offs[0],ystride,UINT_MAX);
+      }break;
+      default:{
+        satd=oc_enc_frag_satd_thresh(_enc,src,dst,ystride,UINT_MAX);
+      }
+    }
+    _enc->frag_satd[_fragi]=satd;
+  }
+#endif
+  /*Transform:*/
+  oc_enc_fdct8x8(_enc,dct,data);
+  /*Quantize the DC coefficient:*/
+  qti=mb_mode!=OC_MODE_INTRA;
+  enquant=_pipe->enquant[_pli][0][qti];
+  dc_dequant=_pipe->dequant[_pli][0][qti][0];
+  v=dct[0];
+  val=v<<1;
+  s=OC_SIGNMASK(val);
+  val+=dc_dequant+s^s;
+  val=((enquant[0].m*(ogg_int32_t)val>>16)+val>>enquant[0].l)-s;
+  dc=OC_CLAMPI(-580,val,580);
+  nonzero=0;
+  /*Quantize the AC coefficients:*/
+  dequant=_pipe->dequant[_pli][qii][qti];
+  enquant=_pipe->enquant[_pli][qii][qti];
+  for(zzi=1;zzi<64;zzi++){
+    v=dct[OC_FZIG_ZAG[zzi]];
+    d=dequant[zzi];
+    val=v<<1;
+    v=abs(val);
+    if(v>=d){
+      s=OC_SIGNMASK(val);
+      /*The bias added here rounds ties away from zero, since token
+         optimization can only decrease the magnitude of the quantized
+         value.*/
+      val+=d+s^s;
+      /*Note the arithmetic right shift is not guaranteed by ANSI C.
+        Hopefully no one still uses ones-complement architectures.*/
+      val=((enquant[zzi].m*(ogg_int32_t)val>>16)+val>>enquant[zzi].l)-s;
+      data[zzi]=OC_CLAMPI(-580,val,580);
+      nonzero=zzi;
+    }
+    else data[zzi]=0;
+  }
+  /*Tokenize.*/
+  checkpoint=*_stack;
+  ac_bits=oc_enc_tokenize_ac(_enc,_pli,_fragi,data,dequant,dct,nonzero+1,
+   _stack,qti?0:3);
+  /*Reconstruct.
+    TODO: nonzero may need to be adjusted after tokenization.*/
+  if(nonzero==0){
+    ogg_int16_t p;
+    int         ci;
+    /*We round this dequant product (and not any of the others) because there's
+       no iDCT rounding.*/
+    p=(ogg_int16_t)(dc*(ogg_int32_t)dc_dequant+15>>5);
+    /*LOOP VECTORIZES.*/
+    for(ci=0;ci<64;ci++)data[ci]=p;
+  }
+  else{
+    data[0]=dc*dc_dequant;
+    oc_idct8x8(&_enc->state,data,nonzero+1);
+  }
+  if(!qti)oc_enc_frag_recon_intra(_enc,dst,ystride,data);
+  else{
+    oc_enc_frag_recon_inter(_enc,dst,
+     nmv_offs==1?ref+mv_offs[0]:dst,ystride,data);
+  }
+  frame_type=_enc->state.frame_type;
+#if !defined(OC_COLLECT_METRICS)
+  if(frame_type!=OC_INTRA_FRAME)
+#endif
+  {
+    /*In retrospect, should we have skipped this block?*/
+    oc_enc_frag_sub(_enc,data,src,dst,ystride);
+    coded_ssd=coded_dc=0;
+    if(borderi<0){
+      for(pi=0;pi<64;pi++){
+        coded_ssd+=data[pi]*data[pi];
+        coded_dc+=data[pi];
+      }
+    }
+    else{
+      ogg_int64_t mask;
+      mask=_enc->state.borders[borderi].mask;
+      for(pi=0;pi<64;pi++,mask>>=1)if(mask&1){
+        coded_ssd+=data[pi]*data[pi];
+        coded_dc+=data[pi];
+      }
+    }
+    /*Scale to match DCT domain.*/
+    coded_ssd<<=4;
+    /*We actually only want the AC contribution to the SSD.*/
+    coded_ssd-=coded_dc*coded_dc>>2;
+#if defined(OC_COLLECT_METRICS)
+    _enc->frag_ssd[_fragi]=coded_ssd;
+  }
+  if(frame_type!=OC_INTRA_FRAME){
+#endif
+    uncoded_ssd=_pipe->skip_ssd[_pli][_fragi-_pipe->froffset[_pli]];
+    if(uncoded_ssd<UINT_MAX){
+      /*Although the fragment coding overhead determination is accurate, it is
+         greedy, using very coarse-grained local information.
+        Allowing it to mildly discourage coding turns out to be beneficial, but
+         it's not clear that allowing it to encourage coding through negative
+         coding overhead deltas is useful.
+        For that reason, we disallow negative coding_overheads.*/
+      if(_overhead_bits<0)_overhead_bits=0;
+      if(uncoded_ssd<=coded_ssd+(_overhead_bits+ac_bits)*_enc->lambda&&
+       /*Don't allow luma blocks to be skipped in 4MV mode when VP3
+          compatibility is enabled.*/
+       (!_enc->vp3_compatible||mb_mode!=OC_MODE_INTER_MV_FOUR||_pli)){
+        /*Hm, not worth it; roll back.*/
+        oc_enc_tokenlog_rollback(_enc,checkpoint,(*_stack)-checkpoint);
+        *_stack=checkpoint;
+        frags[_fragi].coded=0;
+        return 0;
+      }
+    }
+    else _mo->dc_flag=1;
+    _mo->uncoded_ac_ssd+=uncoded_ssd;
+    _mo->coded_ac_ssd+=coded_ssd;
+    _mo->ac_bits+=ac_bits;
+  }
+  oc_qii_state_advance(_pipe->qs+_pli,_pipe->qs+_pli,qii);
+  frags[_fragi].dc=dc;
+  frags[_fragi].coded=1;
+  return 1;
+}
+
+static int oc_enc_mb_transform_quantize_luma(oc_enc_ctx *_enc,
+ oc_enc_pipeline_state *_pipe,unsigned _mbi,int _mode_overhead){
+  /*Worst case token stack usage for 4 fragments.*/
+  oc_token_checkpoint  stack[64*4];
+  oc_token_checkpoint *stackptr;
+  const oc_sb_map     *sb_maps;
+  signed char         *mb_modes;
+  oc_fragment         *frags;
+  ptrdiff_t           *coded_fragis;
+  ptrdiff_t            ncoded_fragis;
+  ptrdiff_t           *uncoded_fragis;
+  ptrdiff_t            nuncoded_fragis;
+  oc_rd_metric         mo;
+  oc_fr_state          fr_checkpoint;
+  oc_qii_state         qs_checkpoint;
+  int                  mb_mode;
+  int                  ncoded;
+  ptrdiff_t            fragi;
+  int                  bi;
+  *&fr_checkpoint=*(_pipe->fr+0);
+  *&qs_checkpoint=*(_pipe->qs+0);
+  sb_maps=(const oc_sb_map *)_enc->state.sb_maps;
+  mb_modes=_enc->state.mb_modes;
+  frags=_enc->state.frags;
+  coded_fragis=_pipe->coded_fragis[0];
+  ncoded_fragis=_pipe->ncoded_fragis[0];
+  uncoded_fragis=_pipe->uncoded_fragis[0];
+  nuncoded_fragis=_pipe->nuncoded_fragis[0];
+  mb_mode=mb_modes[_mbi];
+  ncoded=0;
+  stackptr=stack;
+  memset(&mo,0,sizeof(mo));
+  for(bi=0;bi<4;bi++){
+    fragi=sb_maps[_mbi>>2][_mbi&3][bi];
+    frags[fragi].mb_mode=mb_mode;
+    if(oc_enc_block_transform_quantize(_enc,
+     _pipe,0,fragi,oc_fr_cost1(_pipe->fr+0),&mo,&stackptr)){
+      oc_fr_code_block(_pipe->fr+0);
+      coded_fragis[ncoded_fragis++]=fragi;
+      ncoded++;
+    }
+    else{
+      *(uncoded_fragis-++nuncoded_fragis)=fragi;
+      oc_fr_skip_block(_pipe->fr+0);
+    }
+  }
+  if(_enc->state.frame_type!=OC_INTRA_FRAME){
+    if(ncoded>0&&!mo.dc_flag){
+      int cost;
+      /*Some individual blocks were worth coding.
+        See if that's still true when accounting for mode and MV overhead.*/
+      cost=mo.coded_ac_ssd+_enc->lambda*(mo.ac_bits
+       +oc_fr_cost4(&fr_checkpoint,_pipe->fr+0)+_mode_overhead);
+      if(mo.uncoded_ac_ssd<=cost){
+        /*Taking macroblock overhead into account, it is not worth coding this
+           MB.*/
+        oc_enc_tokenlog_rollback(_enc,stack,stackptr-stack);
+        *(_pipe->fr+0)=*&fr_checkpoint;
+        *(_pipe->qs+0)=*&qs_checkpoint;
+        for(bi=0;bi<4;bi++){
+          fragi=sb_maps[_mbi>>2][_mbi&3][bi];
+          if(frags[fragi].coded){
+            *(uncoded_fragis-++nuncoded_fragis)=fragi;
+            frags[fragi].coded=0;
+          }
+          oc_fr_skip_block(_pipe->fr+0);
+        }
+        ncoded_fragis-=ncoded;
+        ncoded=0;
+      }
+    }
+    /*If no luma blocks coded, the mode is forced.*/
+    if(ncoded==0)mb_modes[_mbi]=OC_MODE_INTER_NOMV;
+    /*Assume that a 1MV with a single coded block is always cheaper than a 4MV
+       with a single coded block.
+      This may not be strictly true: a 4MV computes chroma MVs using (0,0) for
+       skipped blocks, while a 1MV does not.*/
+    else if(ncoded==1&&mb_mode==OC_MODE_INTER_MV_FOUR){
+      mb_modes[_mbi]=OC_MODE_INTER_MV;
+    }
+  }
+  _pipe->ncoded_fragis[0]=ncoded_fragis;
+  _pipe->nuncoded_fragis[0]=nuncoded_fragis;
+  return ncoded;
+}
+
+static void oc_enc_sb_transform_quantize_chroma(oc_enc_ctx *_enc,
+ oc_enc_pipeline_state *_pipe,int _pli,int _sbi_start,int _sbi_end){
+  const oc_sb_map *sb_maps;
+  oc_sb_flags     *sb_flags;
+  ptrdiff_t       *coded_fragis;
+  ptrdiff_t        ncoded_fragis;
+  ptrdiff_t       *uncoded_fragis;
+  ptrdiff_t        nuncoded_fragis;
+  int              sbi;
+  sb_maps=(const oc_sb_map *)_enc->state.sb_maps;
+  sb_flags=_enc->state.sb_flags;
+  coded_fragis=_pipe->coded_fragis[_pli];
+  ncoded_fragis=_pipe->ncoded_fragis[_pli];
+  uncoded_fragis=_pipe->uncoded_fragis[_pli];
+  nuncoded_fragis=_pipe->nuncoded_fragis[_pli];
+  for(sbi=_sbi_start;sbi<_sbi_end;sbi++){
+    /*Worst case token stack usage for 1 fragment.*/
+    oc_token_checkpoint stack[64];
+    oc_rd_metric        mo;
+    int                 quadi;
+    int                 bi;
+    memset(&mo,0,sizeof(mo));
+    for(quadi=0;quadi<4;quadi++)for(bi=0;bi<4;bi++){
+      ptrdiff_t fragi;
+      fragi=sb_maps[sbi][quadi][bi];
+      if(fragi>=0){
+        oc_token_checkpoint *stackptr;
+        stackptr=stack;
+        if(oc_enc_block_transform_quantize(_enc,
+         _pipe,_pli,fragi,oc_fr_cost1(_pipe->fr+_pli),&mo,&stackptr)){
+          coded_fragis[ncoded_fragis++]=fragi;
+          oc_fr_code_block(_pipe->fr+_pli);
+        }
+        else{
+          *(uncoded_fragis-++nuncoded_fragis)=fragi;
+          oc_fr_skip_block(_pipe->fr+_pli);
+        }
+      }
+    }
+    oc_fr_state_flush_sb(_pipe->fr+_pli);
+    sb_flags[sbi].coded_fully=_pipe->fr[_pli].sb_full;
+    sb_flags[sbi].coded_partially=_pipe->fr[_pli].sb_partial;
+  }
+  _pipe->ncoded_fragis[_pli]=ncoded_fragis;
+  _pipe->nuncoded_fragis[_pli]=nuncoded_fragis;
+}
+
+/*Mode decision is done by exhaustively examining all potential choices.
+  Obviously, doing the motion compensation, fDCT, tokenization, and then
+   counting the bits each token uses is computationally expensive.
+  Theora's EOB runs can also split the cost of these tokens across multiple
+   fragments, and naturally we don't know what the optimal choice of Huffman
+   codes will be until we know all the tokens we're going to encode in all the
+   fragments.
+  So we use a simple approach to estimating the bit cost and distortion of each
+   mode based upon the SATD value of the residual before coding.
+  The mathematics behind the technique are outlined by Kim \cite{Kim03}, but
+   the process (modified somewhat from that of the paper) is very simple.
+  We build a non-linear regression of the mappings from
+   (pre-transform+quantization) SATD to (post-transform+quantization) bits and
+   SSD for each qi.
+  A separate set of mappings is kept for each quantization type and color
+   plane.
+  The mappings are constructed by partitioning the SATD values into a small
+   number of bins (currently 24) and using a linear regression in each bin
+   (as opposed to the 0th-order regression used by Kim).
+  The bit counts and SSD measurements are obtained by examining actual encoded
+   frames, with appropriate lambda values and optimal Huffman codes selected.
+  EOB bits are assigned to the fragment that started the EOB run (as opposed to
+   dividing them among all the blocks in the run; though the latter approach
+   seems more theoretically correct, Monty's testing showed a small improvement
+   with the former, though that may have been merely statistical noise).
+
+  @ARTICLE{Kim03,
+    author="Hyun Mun Kim",
+    title="Adaptive Rate Control Using Nonlinear Regression",
+    journal="IEEE Transactions on Circuits and Systems for Video Technology",
+    volume=13,
+    number=5,
+    pages="432--439",
+    month=May,
+    year=2003
+  }*/
+
+/*Computes (_ssd+_lambda*_rate)/(1<<OC_BIT_SCALE) with rounding, avoiding
+   overflow for large lambda values.*/
+#define OC_MODE_RD_COST(_ssd,_rate,_lambda) \
+ ((_ssd)>>OC_BIT_SCALE)+((_rate)>>OC_BIT_SCALE)*(_lambda) \
+ +(((_ssd)&(1<<OC_BIT_SCALE)-1)+((_rate)&(1<<OC_BIT_SCALE)-1)*(_lambda) \
+ +((1<<OC_BIT_SCALE)>>1)>>OC_BIT_SCALE)
+
+/*Estimate the R-D cost of the DCT coefficients given the SATD of a block after
+   prediction.*/
+static unsigned oc_dct_cost2(unsigned *_ssd,
+ int _qi,int _pli,int _qti,int _satd){
+  unsigned rmse;
+  int      bin;
+  int      dx;
+  int      y0;
+  int      z0;
+  int      dy;
+  int      dz;
+  /*SATD metrics for chroma planes vary much less than luma, so we scale them
+     by 4 to distribute them into the mode decision bins more evenly.*/
+  _satd<<=_pli+1&2;
+  bin=OC_MINI(_satd>>OC_SAD_SHIFT,OC_SAD_BINS-2);
+  dx=_satd-(bin<<OC_SAD_SHIFT);
+  y0=OC_MODE_RD[_qi][_pli][_qti][bin].rate;
+  z0=OC_MODE_RD[_qi][_pli][_qti][bin].rmse;
+  dy=OC_MODE_RD[_qi][_pli][_qti][bin+1].rate-y0;
+  dz=OC_MODE_RD[_qi][_pli][_qti][bin+1].rmse-z0;
+  rmse=OC_MAXI(z0+(dz*dx>>OC_SAD_SHIFT),0);
+  *_ssd=rmse*rmse>>2*OC_RMSE_SCALE-OC_BIT_SCALE;
+  return OC_MAXI(y0+(dy*dx>>OC_SAD_SHIFT),0);
+}
+
+/*Select luma block-level quantizers for a MB in an INTRA frame.*/
+static unsigned oc_analyze_intra_mb_luma(oc_enc_ctx *_enc,
+ const oc_qii_state *_qs,unsigned _mbi){
+  const unsigned char *src;
+  const ptrdiff_t     *frag_buf_offs;
+  const oc_sb_map     *sb_maps;
+  oc_fragment         *frags;
+  ptrdiff_t            frag_offs;
+  ptrdiff_t            fragi;
+  oc_qii_state         qs[4][3];
+  unsigned             cost[4][3];
+  unsigned             ssd[4][3];
+  unsigned             rate[4][3];
+  int                  prev[3][3];
+  unsigned             satd;
+  unsigned             best_cost;
+  unsigned             best_ssd;
+  unsigned             best_rate;
+  int                  best_qii;
+  int                  qii;
+  int                  lambda;
+  int                  ystride;
+  int                  nqis;
+  int                  bi;
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  sb_maps=(const oc_sb_map *)_enc->state.sb_maps;
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ystride=_enc->state.ref_ystride[0];
+  fragi=sb_maps[_mbi>>2][_mbi&3][0];
+  frag_offs=frag_buf_offs[fragi];
+  satd=oc_enc_frag_intra_satd(_enc,src+frag_offs,ystride);
+  nqis=_enc->state.nqis;
+  lambda=_enc->lambda;
+  for(qii=0;qii<nqis;qii++){
+    oc_qii_state_advance(qs[0]+qii,_qs,qii);
+    rate[0][qii]=oc_dct_cost2(ssd[0]+qii,_enc->state.qis[qii],0,0,satd)
+     +(qs[0][qii].bits-_qs->bits<<OC_BIT_SCALE);
+    cost[0][qii]=OC_MODE_RD_COST(ssd[0][qii],rate[0][qii],lambda);
+  }
+  for(bi=1;bi<4;bi++){
+    fragi=sb_maps[_mbi>>2][_mbi&3][bi];
+    frag_offs=frag_buf_offs[fragi];
+    satd=oc_enc_frag_intra_satd(_enc,src+frag_offs,ystride);
+    for(qii=0;qii<nqis;qii++){
+      oc_qii_state qt[3];
+      unsigned     cur_ssd;
+      unsigned     cur_rate;
+      int          best_qij;
+      int          qij;
+      oc_qii_state_advance(qt+0,qs[bi-1]+0,qii);
+      cur_rate=oc_dct_cost2(&cur_ssd,_enc->state.qis[qii],0,0,satd);
+      best_ssd=ssd[bi-1][0]+cur_ssd;
+      best_rate=rate[bi-1][0]+cur_rate
+       +(qt[0].bits-qs[bi-1][0].bits<<OC_BIT_SCALE);
+      best_cost=OC_MODE_RD_COST(best_ssd,best_rate,lambda);
+      best_qij=0;
+      for(qij=1;qij<nqis;qij++){
+        unsigned chain_ssd;
+        unsigned chain_rate;
+        unsigned chain_cost;
+        oc_qii_state_advance(qt+qij,qs[bi-1]+qij,qii);
+        chain_ssd=ssd[bi-1][qij]+cur_ssd;
+        chain_rate=rate[bi-1][qij]+cur_rate
+         +(qt[qij].bits-qs[bi-1][qij].bits<<OC_BIT_SCALE);
+        chain_cost=OC_MODE_RD_COST(chain_ssd,chain_rate,lambda);
+        if(chain_cost<best_cost){
+          best_cost=chain_cost;
+          best_ssd=chain_ssd;
+          best_rate=chain_rate;
+          best_qij=qij;
+        }
+      }
+      *(qs[bi]+qii)=*(qt+best_qij);
+      cost[bi][qii]=best_cost;
+      ssd[bi][qii]=best_ssd;
+      rate[bi][qii]=best_rate;
+      prev[bi-1][qii]=best_qij;
+    }
+  }
+  best_qii=0;
+  best_cost=cost[3][0];
+  for(qii=1;qii<nqis;qii++){
+    if(cost[3][qii]<best_cost){
+      best_cost=cost[3][qii];
+      best_qii=qii;
+    }
+  }
+  frags=_enc->state.frags;
+  for(bi=3;;){
+    fragi=sb_maps[_mbi>>2][_mbi&3][bi];
+    frags[fragi].qii=best_qii;
+    if(bi--<=0)break;
+    best_qii=prev[bi][best_qii];
+  }
+  return best_cost;
+}
+
+/*Select a block-level quantizer for a single chroma block in an INTRA frame.*/
+static unsigned oc_analyze_intra_chroma_block(oc_enc_ctx *_enc,
+ const oc_qii_state *_qs,int _pli,ptrdiff_t _fragi){
+  const unsigned char *src;
+  oc_fragment         *frags;
+  ptrdiff_t            frag_offs;
+  oc_qii_state         qt[3];
+  unsigned             cost[3];
+  unsigned             satd;
+  unsigned             best_cost;
+  int                  best_qii;
+  int                  qii;
+  int                  lambda;
+  int                  ystride;
+  int                  nqis;
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ystride=_enc->state.ref_ystride[_pli];
+  frag_offs=_enc->state.frag_buf_offs[_fragi];
+  satd=oc_enc_frag_intra_satd(_enc,src+frag_offs,ystride);
+  nqis=_enc->state.nqis;
+  lambda=_enc->lambda;
+  best_qii=0;
+  for(qii=0;qii<nqis;qii++){
+    unsigned cur_rate;
+    unsigned cur_ssd;
+    oc_qii_state_advance(qt+qii,_qs,qii);
+    cur_rate=oc_dct_cost2(&cur_ssd,_enc->state.qis[qii],_pli,0,satd)
+     +(qt[qii].bits-_qs->bits<<OC_BIT_SCALE);
+    cost[qii]=OC_MODE_RD_COST(cur_ssd,cur_rate,lambda);
+  }
+  best_cost=cost[0];
+  for(qii=1;qii<nqis;qii++){
+    if(cost[qii]<best_cost){
+      best_cost=cost[qii];
+      best_qii=qii;
+    }
+  }
+  frags=_enc->state.frags;
+  frags[_fragi].qii=best_qii;
+  return best_cost;
+}
+
+static void oc_enc_sb_transform_quantize_intra_chroma(oc_enc_ctx *_enc,
+ oc_enc_pipeline_state *_pipe,int _pli,int _sbi_start,int _sbi_end){
+  const oc_sb_map *sb_maps;
+  oc_sb_flags     *sb_flags;
+  ptrdiff_t       *coded_fragis;
+  ptrdiff_t        ncoded_fragis;
+  int              sbi;
+  sb_maps=(const oc_sb_map *)_enc->state.sb_maps;
+  sb_flags=_enc->state.sb_flags;
+  coded_fragis=_pipe->coded_fragis[_pli];
+  ncoded_fragis=_pipe->ncoded_fragis[_pli];
+  for(sbi=_sbi_start;sbi<_sbi_end;sbi++){
+    /*Worst case token stack usage for 1 fragment.*/
+    oc_token_checkpoint stack[64];
+    int                 quadi;
+    int                 bi;
+    for(quadi=0;quadi<4;quadi++)for(bi=0;bi<4;bi++){
+      ptrdiff_t fragi;
+      fragi=sb_maps[sbi][quadi][bi];
+      if(fragi>=0){
+        oc_token_checkpoint *stackptr;
+        oc_analyze_intra_chroma_block(_enc,_pipe->qs+_pli,_pli,fragi);
+        stackptr=stack;
+        oc_enc_block_transform_quantize(_enc,
+         _pipe,_pli,fragi,0,NULL,&stackptr);
+        coded_fragis[ncoded_fragis++]=fragi;
+      }
+    }
+  }
+  _pipe->ncoded_fragis[_pli]=ncoded_fragis;
+}
+
+/*Analysis stage for an INTRA frame.*/
+void oc_enc_analyze_intra(oc_enc_ctx *_enc,int _recode){
+  oc_enc_pipeline_state   pipe;
+  const unsigned char    *map_idxs;
+  int                     nmap_idxs;
+  oc_sb_flags            *sb_flags;
+  signed char            *mb_modes;
+  const oc_mb_map        *mb_maps;
+  oc_mb_enc_info         *embs;
+  oc_fragment            *frags;
+  unsigned                stripe_sby;
+  unsigned                mcu_nvsbs;
+  int                     notstart;
+  int                     notdone;
+  int                     refi;
+  int                     pli;
+  _enc->state.frame_type=OC_INTRA_FRAME;
+  oc_enc_tokenize_start(_enc);
+  oc_enc_pipeline_init(_enc,&pipe);
+  /*Choose MVs and MB modes and quantize and code luma.
+    Must be done in Hilbert order.*/
+  map_idxs=OC_MB_MAP_IDXS[_enc->state.info.pixel_fmt];
+  nmap_idxs=OC_MB_MAP_NIDXS[_enc->state.info.pixel_fmt];
+  _enc->state.ncoded_fragis[0]=0;
+  _enc->state.ncoded_fragis[1]=0;
+  _enc->state.ncoded_fragis[2]=0;
+  sb_flags=_enc->state.sb_flags;
+  mb_modes=_enc->state.mb_modes;
+  mb_maps=(const oc_mb_map *)_enc->state.mb_maps;
+  embs=_enc->mb_info;
+  frags=_enc->state.frags;
+  notstart=0;
+  notdone=1;
+  mcu_nvsbs=_enc->mcu_nvsbs;
+  for(stripe_sby=0;notdone;stripe_sby+=mcu_nvsbs){
+    unsigned sbi;
+    unsigned sbi_end;
+    notdone=oc_enc_pipeline_set_stripe(_enc,&pipe,stripe_sby);
+    sbi_end=pipe.sbi_end[0];
+    for(sbi=pipe.sbi0[0];sbi<sbi_end;sbi++){
+      int quadi;
+      /*Mode addressing is through Y plane, always 4 MB per SB.*/
+      for(quadi=0;quadi<4;quadi++)if(sb_flags[sbi].quad_valid&1<<quadi){
+        unsigned  mbi;
+        int       mapii;
+        int       mapi;
+        int       bi;
+        ptrdiff_t fragi;
+        mbi=sbi<<2|quadi;
+        /*Motion estimation:
+          We always do a basic 1MV search for all macroblocks, coded or not,
+           keyframe or not.*/
+        if(!_recode&&_enc->state.curframe_num>0)oc_mcenc_search(_enc,mbi);
+        oc_analyze_intra_mb_luma(_enc,pipe.qs+0,mbi);
+        mb_modes[mbi]=OC_MODE_INTRA;
+        oc_enc_mb_transform_quantize_luma(_enc,&pipe,mbi,0);
+        /*Propagate final MB mode and MVs to the chroma blocks.*/
+        for(mapii=4;mapii<nmap_idxs;mapii++){
+          mapi=map_idxs[mapii];
+          pli=mapi>>2;
+          bi=mapi&3;
+          fragi=mb_maps[mbi][pli][bi];
+          frags[fragi].mb_mode=OC_MODE_INTRA;
+        }
+      }
+    }
+    oc_enc_pipeline_finish_mcu_plane(_enc,&pipe,0,notstart,notdone);
+    /*Code chroma planes.*/
+    for(pli=1;pli<3;pli++){
+      oc_enc_sb_transform_quantize_intra_chroma(_enc,&pipe,
+       pli,pipe.sbi0[pli],pipe.sbi_end[pli]);
+      oc_enc_pipeline_finish_mcu_plane(_enc,&pipe,pli,notstart,notdone);
+    }
+    notstart=1;
+  }
+  /*Finish filling in the reference frame borders.*/
+  refi=_enc->state.ref_frame_idx[OC_FRAME_SELF];
+  for(pli=0;pli<3;pli++)oc_state_borders_fill_caps(&_enc->state,refi,pli);
+  _enc->state.ntotal_coded_fragis=_enc->state.nfrags;
+}
+
+
+
+/*Cost information about a MB mode.*/
+struct oc_mode_choice{
+  unsigned      cost;
+  unsigned      ssd;
+  unsigned      rate;
+  unsigned      overhead;
+  unsigned char qii[12];
+};
+
+
+
+static void oc_mode_set_cost(oc_mode_choice *_modec,int _lambda){
+  _modec->cost=OC_MODE_RD_COST(_modec->ssd,
+   _modec->rate+_modec->overhead,_lambda);
+}
+
+/*A set of skip SSD's to use to disable early skipping.*/
+static const unsigned OC_NOSKIP[12]={
+  UINT_MAX,UINT_MAX,UINT_MAX,UINT_MAX,
+  UINT_MAX,UINT_MAX,UINT_MAX,UINT_MAX,
+  UINT_MAX,UINT_MAX,UINT_MAX,UINT_MAX
+};
+
+/*The estimated number of bits used by a coded chroma block to specify the AC
+   quantizer.
+  TODO: Currently this is just 0.5*log2(3) (estimating about 50% compression);
+   measurements suggest this is in the right ballpark, but it varies somewhat
+   with lambda.*/
+#define OC_CHROMA_QII_RATE ((0xCAE00D1DU>>31-OC_BIT_SCALE)+1>>1)
+
+static void oc_analyze_mb_mode_luma(oc_enc_ctx *_enc,
+ oc_mode_choice *_modec,const oc_fr_state *_fr,const oc_qii_state *_qs,
+ const unsigned _frag_satd[12],const unsigned _skip_ssd[12],int _qti){
+  oc_fr_state  fr;
+  oc_qii_state qs;
+  unsigned     ssd;
+  unsigned     rate;
+  int          overhead;
+  unsigned     satd;
+  unsigned     best_ssd;
+  unsigned     best_rate;
+  int          best_overhead;
+  int          best_fri;
+  int          best_qii;
+  unsigned     cur_cost;
+  unsigned     cur_ssd;
+  unsigned     cur_rate;
+  int          cur_overhead;
+  int          lambda;
+  int          nqis;
+  int          nskipped;
+  int          bi;
+  int          qii;
+  lambda=_enc->lambda;
+  nqis=_enc->state.nqis;
+  /*We could do a trellis optimization here, but we don't make final skip
+     decisions until after transform+quantization, so the result wouldn't be
+     optimal anyway.
+    Instead we just use a greedy approach; for most SATD values, the
+     differences between the qiis are large enough to drown out the cost to
+     code the flags, anyway.*/
+  *&fr=*_fr;
+  *&qs=*_qs;
+  ssd=rate=overhead=nskipped=0;
+  for(bi=0;bi<4;bi++){
+    oc_fr_state  ft[2];
+    oc_qii_state qt[3];
+    unsigned     best_cost;
+    satd=_frag_satd[bi];
+    *(ft+0)=*&fr;
+    oc_fr_code_block(ft+0);
+    oc_qii_state_advance(qt+0,&qs,0);
+    best_overhead=(ft[0].bits-fr.bits<<OC_BIT_SCALE);
+    best_rate=oc_dct_cost2(&best_ssd,_enc->state.qis[0],0,_qti,satd)
+     +(qt[0].bits-qs.bits<<OC_BIT_SCALE);
+    best_cost=OC_MODE_RD_COST(ssd+best_ssd,rate+best_rate+best_overhead,lambda);
+    best_fri=0;
+    best_qii=0;
+    for(qii=1;qii<nqis;qii++){
+      oc_qii_state_advance(qt+qii,&qs,qii);
+      cur_rate=oc_dct_cost2(&cur_ssd,_enc->state.qis[qii],0,_qti,satd)
+       +(qt[qii].bits-qs.bits<<OC_BIT_SCALE);
+      cur_cost=OC_MODE_RD_COST(ssd+cur_ssd,rate+cur_rate+best_overhead,lambda);
+      if(cur_cost<best_cost){
+        best_cost=cur_cost;
+        best_ssd=cur_ssd;
+        best_rate=cur_rate;
+        best_qii=qii;
+      }
+    }
+    if(_skip_ssd[bi]<UINT_MAX&&nskipped<3){
+      *(ft+1)=*&fr;
+      oc_fr_skip_block(ft+1);
+      cur_overhead=ft[1].bits-fr.bits<<OC_BIT_SCALE;
+      cur_ssd=_skip_ssd[bi]<<OC_BIT_SCALE;
+      cur_cost=OC_MODE_RD_COST(ssd+cur_ssd,rate+cur_overhead,lambda);
+      if(cur_cost<=best_cost){
+        best_ssd=cur_ssd;
+        best_rate=0;
+        best_overhead=cur_overhead;
+        best_fri=1;
+        best_qii+=4;
+      }
+    }
+    rate+=best_rate;
+    ssd+=best_ssd;
+    overhead+=best_overhead;
+    *&fr=*(ft+best_fri);
+    if(best_fri==0)*&qs=*(qt+best_qii);
+    else nskipped++;
+    _modec->qii[bi]=best_qii;
+  }
+  _modec->ssd=ssd;
+  _modec->rate=rate;
+  _modec->overhead=OC_MAXI(overhead,0);
+}
+
+static void oc_analyze_mb_mode_chroma(oc_enc_ctx *_enc,
+ oc_mode_choice *_modec,const oc_fr_state *_fr,const oc_qii_state *_qs,
+ const unsigned _frag_satd[12],const unsigned _skip_ssd[12],int _qti){
+  unsigned ssd;
+  unsigned rate;
+  unsigned satd;
+  unsigned best_ssd;
+  unsigned best_rate;
+  int      best_qii;
+  unsigned cur_cost;
+  unsigned cur_ssd;
+  unsigned cur_rate;
+  int      lambda;
+  int      nblocks;
+  int      nqis;
+  int      pli;
+  int      bi;
+  int      qii;
+  lambda=_enc->lambda;
+  nqis=_enc->state.nqis;
+  ssd=_modec->ssd;
+  rate=_modec->rate;
+  /*Because (except in 4:4:4 mode) we aren't considering chroma blocks in coded
+     order, we assume a constant overhead for coded block and qii flags.*/
+  nblocks=OC_MB_MAP_NIDXS[_enc->state.info.pixel_fmt];
+  nblocks=(nblocks-4>>1)+4;
+  bi=4;
+  for(pli=1;pli<3;pli++){
+    for(;bi<nblocks;bi++){
+      unsigned best_cost;
+      satd=_frag_satd[bi];
+      best_rate=oc_dct_cost2(&best_ssd,_enc->state.qis[0],pli,_qti,satd)
+       +OC_CHROMA_QII_RATE;
+      best_cost=OC_MODE_RD_COST(ssd+best_ssd,rate+best_rate,lambda);
+      best_qii=0;
+      for(qii=1;qii<nqis;qii++){
+        cur_rate=oc_dct_cost2(&cur_ssd,_enc->state.qis[qii],0,_qti,satd)
+         +OC_CHROMA_QII_RATE;
+        cur_cost=OC_MODE_RD_COST(ssd+cur_ssd,rate+cur_rate,lambda);
+        if(cur_cost<best_cost){
+          best_cost=cur_cost;
+          best_ssd=cur_ssd;
+          best_rate=cur_rate;
+          best_qii=qii;
+        }
+      }
+      if(_skip_ssd[bi]<UINT_MAX){
+        cur_ssd=_skip_ssd[bi]<<OC_BIT_SCALE;
+        cur_cost=OC_MODE_RD_COST(ssd+cur_ssd,rate,lambda);
+        if(cur_cost<=best_cost){
+          best_ssd=cur_ssd;
+          best_rate=0;
+          best_qii+=4;
+        }
+      }
+      rate+=best_rate;
+      ssd+=best_ssd;
+      _modec->qii[bi]=best_qii;
+    }
+    nblocks=(nblocks-4<<1)+4;
+  }
+  _modec->ssd=ssd;
+  _modec->rate=rate;
+}
+
+static void oc_skip_cost(oc_enc_ctx *_enc,oc_enc_pipeline_state *_pipe,
+ unsigned _mbi,unsigned _ssd[12]){
+  OC_ALIGN16(ogg_int16_t  buffer[64]);
+  const unsigned char    *src;
+  const unsigned char    *ref;
+  int                     ystride;
+  const oc_fragment      *frags;
+  const ptrdiff_t        *frag_buf_offs;
+  const ptrdiff_t        *sb_map;
+  const oc_mb_map_plane  *mb_map;
+  const unsigned char    *map_idxs;
+  int                     map_nidxs;
+  ogg_int64_t             mask;
+  unsigned                uncoded_ssd;
+  int                     uncoded_dc;
+  unsigned                dc_dequant;
+  int                     dc_flag;
+  int                     mapii;
+  int                     mapi;
+  int                     pli;
+  int                     bi;
+  ptrdiff_t               fragi;
+  ptrdiff_t               frag_offs;
+  int                     borderi;
+  int                     pi;
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ref=_enc->state.ref_frame_data[_enc->state.ref_frame_idx[OC_FRAME_PREV]];
+  ystride=_enc->state.ref_ystride[0];
+  frags=_enc->state.frags;
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  sb_map=_enc->state.sb_maps[_mbi>>2][_mbi&3];
+  dc_dequant=_enc->state.dequant_tables[_enc->state.qis[0]][0][1][0];
+  for(bi=0;bi<4;bi++){
+    fragi=sb_map[bi];
+    frag_offs=frag_buf_offs[fragi];
+    oc_enc_frag_sub(_enc,buffer,src+frag_offs,ref+frag_offs,ystride);
+    borderi=frags[fragi].borderi;
+    uncoded_ssd=uncoded_dc=0;
+    if(borderi<0){
+      for(pi=0;pi<64;pi++){
+        uncoded_ssd+=buffer[pi]*buffer[pi];
+        uncoded_dc+=buffer[pi];
+      }
+    }
+    else{
+      ogg_int64_t mask;
+      mask=_enc->state.borders[borderi].mask;
+      for(pi=0;pi<64;pi++,mask>>=1)if(mask&1){
+        uncoded_ssd+=buffer[pi]*buffer[pi];
+        uncoded_dc+=buffer[pi];
+      }
+    }
+    /*Scale to match DCT domain.*/
+    uncoded_ssd<<=4;
+    /*We actually only want the AC contribution to the SSD.*/
+    uncoded_ssd-=uncoded_dc*uncoded_dc>>2;
+    /*DC is a special case; if there's more than a full-quantizer improvement
+       in the effective DC component, always force-code the block.*/
+    dc_flag=abs(uncoded_dc)>dc_dequant<<1;
+    uncoded_ssd|=-dc_flag;
+    _pipe->skip_ssd[0][fragi-_pipe->froffset[0]]=_ssd[bi]=uncoded_ssd;
+  }
+  mb_map=(const oc_mb_map_plane *)_enc->state.mb_maps[_mbi];
+  map_nidxs=OC_MB_MAP_NIDXS[_enc->state.info.pixel_fmt];
+  map_idxs=OC_MB_MAP_IDXS[_enc->state.info.pixel_fmt];
+  map_nidxs=(map_nidxs-4>>1)+4;
+  mapii=4;
+  for(pli=1;pli<3;pli++){
+    ystride=_enc->state.ref_ystride[pli];
+    dc_dequant=_enc->state.dequant_tables[_enc->state.qis[0]][pli][1][0];
+    for(;mapii<map_nidxs;mapii++){
+      mapi=map_idxs[mapii];
+      bi=mapi&3;
+      fragi=mb_map[pli][bi];
+      frag_offs=frag_buf_offs[fragi];
+      oc_enc_frag_sub(_enc,buffer,src+frag_offs,ref+frag_offs,ystride);
+      borderi=frags[fragi].borderi;
+      uncoded_ssd=uncoded_dc=0;
+      if(borderi<0){
+        for(pi=0;pi<64;pi++){
+          uncoded_ssd+=buffer[pi]*buffer[pi];
+          uncoded_dc+=buffer[pi];
+        }
+      }
+      else{
+        mask=_enc->state.borders[borderi].mask;
+        for(pi=0;pi<64;pi++,mask>>=1)if(mask&1){
+          uncoded_ssd+=buffer[pi]*buffer[pi];
+          uncoded_dc+=buffer[pi];
+        }
+      }
+      /*Scale to match DCT domain.*/
+      uncoded_ssd<<=4;
+      /*We actually only want the AC contribution to the SSD.*/
+      uncoded_ssd-=uncoded_dc*uncoded_dc>>2;
+      /*DC is a special case; if there's more than a full-quantizer improvement
+         in the effective DC component, always force-code the block.*/
+      dc_flag=abs(uncoded_dc)>dc_dequant<<1;
+      uncoded_ssd|=-dc_flag;
+      _pipe->skip_ssd[pli][fragi-_pipe->froffset[pli]]=_ssd[mapii]=uncoded_ssd;
+    }
+    map_nidxs=(map_nidxs-4<<1)+4;
+  }
+}
+
+static void oc_mb_intra_satd(oc_enc_ctx *_enc,unsigned _mbi,
+ unsigned _frag_satd[12]){
+  const unsigned char   *src;
+  const ptrdiff_t       *frag_buf_offs;
+  const ptrdiff_t       *sb_map;
+  const oc_mb_map_plane *mb_map;
+  const unsigned char   *map_idxs;
+  int                    map_nidxs;
+  int                    mapii;
+  int                    mapi;
+  int                    ystride;
+  int                    pli;
+  int                    bi;
+  ptrdiff_t              fragi;
+  ptrdiff_t              frag_offs;
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  sb_map=_enc->state.sb_maps[_mbi>>2][_mbi&3];
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ystride=_enc->state.ref_ystride[0];
+  for(bi=0;bi<4;bi++){
+    fragi=sb_map[bi];
+    frag_offs=frag_buf_offs[fragi];
+    _frag_satd[bi]=oc_enc_frag_intra_satd(_enc,src+frag_offs,ystride);
+  }
+  mb_map=(const oc_mb_map_plane *)_enc->state.mb_maps[_mbi];
+  map_idxs=OC_MB_MAP_IDXS[_enc->state.info.pixel_fmt];
+  map_nidxs=OC_MB_MAP_NIDXS[_enc->state.info.pixel_fmt];
+  /*Note: This assumes ref_ystride[1]==ref_ystride[2].*/
+  ystride=_enc->state.ref_ystride[1];
+  for(mapii=4;mapii<map_nidxs;mapii++){
+    mapi=map_idxs[mapii];
+    pli=mapi>>2;
+    bi=mapi&3;
+    fragi=mb_map[pli][bi];
+    frag_offs=frag_buf_offs[fragi];
+    _frag_satd[mapii]=oc_enc_frag_intra_satd(_enc,src+frag_offs,ystride);
+  }
+}
+
+static void oc_cost_intra(oc_enc_ctx *_enc,oc_mode_choice *_modec,
+ unsigned _mbi,const oc_fr_state *_fr,const oc_qii_state *_qs,
+ const unsigned _frag_satd[12],const unsigned _skip_ssd[12]){
+  oc_analyze_mb_mode_luma(_enc,_modec,_fr,_qs,_frag_satd,_skip_ssd,0);
+  oc_analyze_mb_mode_chroma(_enc,_modec,_fr,_qs,_frag_satd,_skip_ssd,0);
+  _modec->overhead+=
+   oc_mode_scheme_chooser_cost(&_enc->chooser,OC_MODE_INTRA)<<OC_BIT_SCALE;
+  oc_mode_set_cost(_modec,_enc->lambda);
+}
+
+static void oc_cost_inter(oc_enc_ctx *_enc,oc_mode_choice *_modec,
+ unsigned _mbi,int _mb_mode,const signed char *_mv,
+ const oc_fr_state *_fr,const oc_qii_state *_qs,const unsigned _skip_ssd[12]){
+  unsigned               frag_satd[12];
+  const unsigned char   *src;
+  const unsigned char   *ref;
+  int                    ystride;
+  const ptrdiff_t       *frag_buf_offs;
+  const ptrdiff_t       *sb_map;
+  const oc_mb_map_plane *mb_map;
+  const unsigned char   *map_idxs;
+  int                    map_nidxs;
+  int                    mapii;
+  int                    mapi;
+  int                    mv_offs[2];
+  int                    dx;
+  int                    dy;
+  int                    pli;
+  int                    bi;
+  ptrdiff_t              fragi;
+  ptrdiff_t              frag_offs;
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ref=_enc->state.ref_frame_data[
+   _enc->state.ref_frame_idx[OC_FRAME_FOR_MODE(_mb_mode)]];
+  ystride=_enc->state.ref_ystride[0];
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  sb_map=_enc->state.sb_maps[_mbi>>2][_mbi&3];
+  dx=_mv[0];
+  dy=_mv[1];
+  _modec->rate=_modec->ssd=0;
+  if(oc_state_get_mv_offsets(&_enc->state,mv_offs,0,dx,dy)>1){
+    for(bi=0;bi<4;bi++){
+      fragi=sb_map[bi];
+      frag_offs=frag_buf_offs[fragi];
+      frag_satd[bi]=oc_enc_frag_satd2_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ref+frag_offs+mv_offs[1],ystride,UINT_MAX);
+    }
+  }
+  else{
+    for(bi=0;bi<4;bi++){
+      fragi=sb_map[bi];
+      frag_offs=frag_buf_offs[fragi];
+      frag_satd[bi]=oc_enc_frag_satd_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ystride,UINT_MAX);
+    }
+  }
+  mb_map=(const oc_mb_map_plane *)_enc->state.mb_maps[_mbi];
+  map_idxs=OC_MB_MAP_IDXS[_enc->state.info.pixel_fmt];
+  map_nidxs=OC_MB_MAP_NIDXS[_enc->state.info.pixel_fmt];
+  /*Note: This assumes ref_ystride[1]==ref_ystride[2].*/
+  ystride=_enc->state.ref_ystride[1];
+  if(oc_state_get_mv_offsets(&_enc->state,mv_offs,1,dx,dy)>1){
+    for(mapii=4;mapii<map_nidxs;mapii++){
+      mapi=map_idxs[mapii];
+      pli=mapi>>2;
+      bi=mapi&3;
+      fragi=mb_map[pli][bi];
+      frag_offs=frag_buf_offs[fragi];
+      frag_satd[mapii]=oc_enc_frag_satd2_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ref+frag_offs+mv_offs[1],ystride,UINT_MAX);
+    }
+  }
+  else{
+    for(mapii=4;mapii<map_nidxs;mapii++){
+      mapi=map_idxs[mapii];
+      pli=mapi>>2;
+      bi=mapi&3;
+      fragi=mb_map[pli][bi];
+      frag_offs=frag_buf_offs[fragi];
+      frag_satd[mapii]=oc_enc_frag_satd_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ystride,UINT_MAX);
+    }
+  }
+  oc_analyze_mb_mode_luma(_enc,_modec,_fr,_qs,frag_satd,_skip_ssd,1);
+  oc_analyze_mb_mode_chroma(_enc,_modec,_fr,_qs,frag_satd,_skip_ssd,1);
+  _modec->overhead+=
+   oc_mode_scheme_chooser_cost(&_enc->chooser,_mb_mode)<<OC_BIT_SCALE;
+  oc_mode_set_cost(_modec,_enc->lambda);
+}
+
+static void oc_cost_inter_nomv(oc_enc_ctx *_enc,oc_mode_choice *_modec,
+ unsigned _mbi,int _mb_mode,const oc_fr_state *_fr,const oc_qii_state *_qs,
+ const unsigned _skip_ssd[12]){
+  static const oc_mv OC_MV_ZERO;
+  oc_cost_inter(_enc,_modec,_mbi,_mb_mode,OC_MV_ZERO,_fr,_qs,_skip_ssd);
+}
+
+static int oc_cost_inter1mv(oc_enc_ctx *_enc,oc_mode_choice *_modec,
+ unsigned _mbi,int _mb_mode,const signed char *_mv,
+ const oc_fr_state *_fr,const oc_qii_state *_qs,const unsigned _skip_ssd[12]){
+  int bits0;
+  oc_cost_inter(_enc,_modec,_mbi,_mb_mode,_mv,_fr,_qs,_skip_ssd);
+  bits0=OC_MV_BITS[0][_mv[0]+31]+OC_MV_BITS[0][_mv[1]+31];
+  _modec->overhead+=OC_MINI(_enc->mv_bits[0]+bits0,_enc->mv_bits[1]+12)
+   -OC_MINI(_enc->mv_bits[0],_enc->mv_bits[1])<<OC_BIT_SCALE;
+  oc_mode_set_cost(_modec,_enc->lambda);
+  return bits0;
+}
+
+/*A mapping from oc_mb_map (raster) ordering to oc_sb_map (Hilbert) ordering.*/
+static const unsigned char OC_MB_PHASE[4][4]={
+  {0,1,3,2},{0,3,1,2},{0,3,1,2},{2,3,1,0}
+};
+
+static void oc_cost_inter4mv(oc_enc_ctx *_enc,oc_mode_choice *_modec,
+ unsigned _mbi,oc_mv _mv[4],const oc_fr_state *_fr,const oc_qii_state *_qs,
+ const unsigned _skip_ssd[12]){
+  unsigned               frag_satd[12];
+  oc_mv                  lbmvs[4];
+  oc_mv                  cbmvs[4];
+  const unsigned char   *src;
+  const unsigned char   *ref;
+  int                    ystride;
+  const ptrdiff_t       *frag_buf_offs;
+  oc_mv                 *frag_mvs;
+  const oc_mb_map_plane *mb_map;
+  const unsigned char   *map_idxs;
+  int                    map_nidxs;
+  int                    nqis;
+  int                    mapii;
+  int                    mapi;
+  int                    mv_offs[2];
+  int                    dx;
+  int                    dy;
+  int                    pli;
+  int                    bi;
+  ptrdiff_t              fragi;
+  ptrdiff_t              frag_offs;
+  int                    bits0;
+  int                    bits1;
+  unsigned               satd;
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ref=_enc->state.ref_frame_data[_enc->state.ref_frame_idx[OC_FRAME_PREV]];
+  ystride=_enc->state.ref_ystride[0];
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  frag_mvs=_enc->state.frag_mvs;
+  mb_map=(const oc_mb_map_plane *)_enc->state.mb_maps[_mbi];
+  _modec->rate=_modec->ssd=0;
+  for(bi=0;bi<4;bi++){
+    fragi=mb_map[0][bi];
+    dx=_mv[bi][0];
+    dy=_mv[bi][1];
+    /*Save the block MVs as the current ones while we're here; we'll replace
+       them if we don't ultimately choose 4MV mode.*/
+    frag_mvs[fragi][0]=(signed char)dx;
+    frag_mvs[fragi][1]=(signed char)dy;
+    frag_offs=frag_buf_offs[fragi];
+    if(oc_state_get_mv_offsets(&_enc->state,mv_offs,0,dx,dy)>1){
+      satd=oc_enc_frag_satd2_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ref+frag_offs+mv_offs[1],ystride,UINT_MAX);
+    }
+    else{
+      satd=oc_enc_frag_satd_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ystride,UINT_MAX);
+    }
+    frag_satd[OC_MB_PHASE[_mbi&3][bi]]=satd;
+  }
+  oc_analyze_mb_mode_luma(_enc,_modec,_fr,_qs,frag_satd,
+   _enc->vp3_compatible?OC_NOSKIP:_skip_ssd,1);
+  /*Figure out which blocks are being skipped and give them (0,0) MVs.*/
+  bits0=0;
+  bits1=0;
+  nqis=_enc->state.nqis;
+  for(bi=0;bi<4;bi++){
+    if(_modec->qii[OC_MB_PHASE[_mbi&3][bi]]>=nqis){
+      memset(lbmvs+bi,0,sizeof(*lbmvs));
+    }
+    else{
+      memcpy(lbmvs+bi,_mv+bi,sizeof(*lbmvs));
+      bits0+=OC_MV_BITS[0][_mv[bi][0]+31]+OC_MV_BITS[0][_mv[bi][1]+31];
+      bits1+=12;
+    }
+  }
+  (*OC_SET_CHROMA_MVS_TABLE[_enc->state.info.pixel_fmt])(cbmvs,
+   (const oc_mv *)lbmvs);
+  map_idxs=OC_MB_MAP_IDXS[_enc->state.info.pixel_fmt];
+  map_nidxs=OC_MB_MAP_NIDXS[_enc->state.info.pixel_fmt];
+  /*Note: This assumes ref_ystride[1]==ref_ystride[2].*/
+  ystride=_enc->state.ref_ystride[1];
+  for(mapii=4;mapii<map_nidxs;mapii++){
+    mapi=map_idxs[mapii];
+    pli=mapi>>2;
+    bi=mapi&3;
+    fragi=mb_map[pli][bi];
+    dx=cbmvs[bi][0];
+    dy=cbmvs[bi][1];
+    frag_offs=frag_buf_offs[fragi];
+    /*TODO: We could save half these calls by re-using the results for the Cb
+       and Cr planes; is it worth it?*/
+    if(oc_state_get_mv_offsets(&_enc->state,mv_offs,pli,dx,dy)>1){
+      satd=oc_enc_frag_satd2_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ref+frag_offs+mv_offs[1],ystride,UINT_MAX);
+    }
+    else{
+      satd=oc_enc_frag_satd_thresh(_enc,src+frag_offs,
+       ref+frag_offs+mv_offs[0],ystride,UINT_MAX);
+    }
+    frag_satd[mapii]=satd;
+  }
+  oc_analyze_mb_mode_chroma(_enc,_modec,_fr,_qs,frag_satd,_skip_ssd,1);
+  _modec->overhead+=
+   oc_mode_scheme_chooser_cost(&_enc->chooser,OC_MODE_INTER_MV_FOUR)
+   +OC_MINI(_enc->mv_bits[0]+bits0,_enc->mv_bits[1]+bits1)
+   -OC_MINI(_enc->mv_bits[0],_enc->mv_bits[1])<<OC_BIT_SCALE;
+  oc_mode_set_cost(_modec,_enc->lambda);
+}
+
+int oc_enc_analyze_inter(oc_enc_ctx *_enc,int _allow_keyframe,int _recode){
+  oc_set_chroma_mvs_func  set_chroma_mvs;
+  oc_enc_pipeline_state   pipe;
+  oc_qii_state            intra_luma_qs;
+  oc_mv                   last_mv;
+  oc_mv                   prior_mv;
+  ogg_int64_t             interbits;
+  ogg_int64_t             intrabits;
+  const unsigned char    *map_idxs;
+  int                     nmap_idxs;
+  unsigned               *coded_mbis;
+  unsigned               *uncoded_mbis;
+  size_t                  ncoded_mbis;
+  size_t                  nuncoded_mbis;
+  oc_sb_flags            *sb_flags;
+  signed char            *mb_modes;
+  const oc_sb_map        *sb_maps;
+  const oc_mb_map        *mb_maps;
+  oc_mb_enc_info         *embs;
+  oc_fragment            *frags;
+  oc_mv                  *frag_mvs;
+  int                     qi;
+  unsigned                stripe_sby;
+  unsigned                mcu_nvsbs;
+  int                     notstart;
+  int                     notdone;
+  int                     vdec;
+  unsigned                sbi;
+  unsigned                sbi_end;
+  int                     refi;
+  int                     pli;
+  set_chroma_mvs=OC_SET_CHROMA_MVS_TABLE[_enc->state.info.pixel_fmt];
+  _enc->state.frame_type=OC_INTER_FRAME;
+  oc_mode_scheme_chooser_reset(&_enc->chooser);
+  oc_enc_tokenize_start(_enc);
+  oc_enc_pipeline_init(_enc,&pipe);
+  if(_allow_keyframe)oc_qii_state_init(&intra_luma_qs);
+  _enc->mv_bits[0]=_enc->mv_bits[1]=0;
+  interbits=intrabits=0;
+  last_mv[0]=last_mv[1]=prior_mv[0]=prior_mv[1]=0;
+  /*Choose MVs and MB modes and quantize and code luma.
+    Must be done in Hilbert order.*/
+  map_idxs=OC_MB_MAP_IDXS[_enc->state.info.pixel_fmt];
+  nmap_idxs=OC_MB_MAP_NIDXS[_enc->state.info.pixel_fmt];
+  qi=_enc->state.qis[0];
+  coded_mbis=_enc->coded_mbis;
+  uncoded_mbis=coded_mbis+_enc->state.nmbs;
+  ncoded_mbis=0;
+  nuncoded_mbis=0;
+  _enc->state.ncoded_fragis[0]=0;
+  _enc->state.ncoded_fragis[1]=0;
+  _enc->state.ncoded_fragis[2]=0;
+  sb_flags=_enc->state.sb_flags;
+  mb_modes=_enc->state.mb_modes;
+  sb_maps=(const oc_sb_map *)_enc->state.sb_maps;
+  mb_maps=(const oc_mb_map *)_enc->state.mb_maps;
+  embs=_enc->mb_info;
+  frags=_enc->state.frags;
+  frag_mvs=_enc->state.frag_mvs;
+  vdec=!(_enc->state.info.pixel_fmt&2);
+  notstart=0;
+  notdone=1;
+  mcu_nvsbs=_enc->mcu_nvsbs;
+  for(stripe_sby=0;notdone;stripe_sby+=mcu_nvsbs){
+    notdone=oc_enc_pipeline_set_stripe(_enc,&pipe,stripe_sby);
+    sbi_end=pipe.sbi_end[0];
+    for(sbi=pipe.sbi0[0];sbi<sbi_end;sbi++){
+      int quadi;
+      /*Mode addressing is through Y plane, always 4 MB per SB.*/
+      for(quadi=0;quadi<4;quadi++)if(sb_flags[sbi].quad_valid&1<<quadi){
+        oc_mode_choice modes[8];
+        unsigned       skip_ssd[12];
+        unsigned       intra_satd[12];
+        int            mb_mv_bits_0;
+        int            mb_gmv_bits_0;
+        int            inter_mv_pref;
+        int            mb_mode;
+        int            dx;
+        int            dy;
+        unsigned       mbi;
+        int            mapii;
+        int            mapi;
+        int            bi;
+        ptrdiff_t      fragi;
+        mbi=sbi<<2|quadi;
+        /*Motion estimation:
+          We always do a basic 1MV search for all macroblocks, coded or not,
+           keyframe or not.*/
+        if(!_recode&&_enc->sp_level<OC_SP_LEVEL_NOMC)oc_mcenc_search(_enc,mbi);
+        dx=dy=0;
+        /*Find the block choice with the lowest estimated coding cost.
+          If a Cb or Cr block is coded but no Y' block from a macro block then
+           the mode MUST be OC_MODE_INTER_NOMV.
+          This is the default state to which the mode data structure is
+           initialised in encoder and decoder at the start of each frame.*/
+        /*Block coding cost is estimated from correlated SATD metrics.*/
+        /*At this point, all blocks that are in frame are still marked coded.*/
+        if(!_recode){
+          memcpy(embs[mbi].unref_mv,
+           embs[mbi].analysis_mv[0],sizeof(embs[mbi].unref_mv));
+          embs[mbi].refined=0;
+        }
+        oc_mb_intra_satd(_enc,mbi,intra_satd);
+        /*Estimate the cost of coding this MB in a keyframe.*/
+        if(_allow_keyframe){
+          oc_cost_intra(_enc,modes+OC_MODE_INTRA,mbi,
+           pipe.fr+0,&intra_luma_qs,intra_satd,OC_NOSKIP);
+          intrabits+=modes[OC_MODE_INTRA].rate;
+          for(bi=0;bi<4;bi++){
+            oc_qii_state_advance(&intra_luma_qs,&intra_luma_qs,
+             modes[OC_MODE_INTRA].qii[bi]);
+          }
+        }
+        /*Estimate the cost in a delta frame for various modes.*/
+        oc_skip_cost(_enc,&pipe,mbi,skip_ssd);
+        oc_cost_inter_nomv(_enc,modes+OC_MODE_INTER_NOMV,mbi,
+         OC_MODE_INTER_NOMV,pipe.fr+0,pipe.qs+0,skip_ssd);
+        if(_enc->sp_level<OC_SP_LEVEL_NOMC){
+          oc_cost_intra(_enc,modes+OC_MODE_INTRA,mbi,
+           pipe.fr+0,pipe.qs+0,intra_satd,skip_ssd);
+          mb_mv_bits_0=oc_cost_inter1mv(_enc,modes+OC_MODE_INTER_MV,mbi,
+           OC_MODE_INTER_MV,embs[mbi].unref_mv[OC_FRAME_PREV],
+           pipe.fr+0,pipe.qs+0,skip_ssd);
+          oc_cost_inter(_enc,modes+OC_MODE_INTER_MV_LAST,mbi,
+           OC_MODE_INTER_MV_LAST,last_mv,pipe.fr+0,pipe.qs+0,skip_ssd);
+          oc_cost_inter(_enc,modes+OC_MODE_INTER_MV_LAST2,mbi,
+           OC_MODE_INTER_MV_LAST2,prior_mv,pipe.fr+0,pipe.qs+0,skip_ssd);
+          oc_cost_inter4mv(_enc,modes+OC_MODE_INTER_MV_FOUR,mbi,
+           embs[mbi].block_mv,pipe.fr+0,pipe.qs+0,skip_ssd);
+          oc_cost_inter_nomv(_enc,modes+OC_MODE_GOLDEN_NOMV,mbi,
+           OC_MODE_GOLDEN_NOMV,pipe.fr+0,pipe.qs+0,skip_ssd);
+          mb_gmv_bits_0=oc_cost_inter1mv(_enc,modes+OC_MODE_GOLDEN_MV,mbi,
+           OC_MODE_GOLDEN_MV,embs[mbi].unref_mv[OC_FRAME_GOLD],
+           pipe.fr+0,pipe.qs+0,skip_ssd);
+          /*The explicit MV modes (2,6,7) have not yet gone through halfpel
+             refinement.
+            We choose the explicit MV mode that's already furthest ahead on
+             R-D cost and refine only that one.
+            We have to be careful to remember which ones we've refined so that
+             we don't refine it again if we re-encode this frame.*/
+          inter_mv_pref=_enc->lambda*3;
+          if(modes[OC_MODE_INTER_MV_FOUR].cost<modes[OC_MODE_INTER_MV].cost&&
+           modes[OC_MODE_INTER_MV_FOUR].cost<modes[OC_MODE_GOLDEN_MV].cost){
+            if(!(embs[mbi].refined&0x80)){
+              oc_mcenc_refine4mv(_enc,mbi);
+              embs[mbi].refined|=0x80;
+            }
+            oc_cost_inter4mv(_enc,modes+OC_MODE_INTER_MV_FOUR,mbi,
+             embs[mbi].ref_mv,pipe.fr+0,pipe.qs+0,skip_ssd);
+          }
+          else if(modes[OC_MODE_GOLDEN_MV].cost+inter_mv_pref<
+           modes[OC_MODE_INTER_MV].cost){
+            if(!(embs[mbi].refined&0x40)){
+              oc_mcenc_refine1mv(_enc,mbi,OC_FRAME_GOLD);
+              embs[mbi].refined|=0x40;
+            }
+            mb_gmv_bits_0=oc_cost_inter1mv(_enc,modes+OC_MODE_GOLDEN_MV,mbi,
+             OC_MODE_GOLDEN_MV,embs[mbi].analysis_mv[0][OC_FRAME_GOLD],
+             pipe.fr+0,pipe.qs+0,skip_ssd);
+          }
+          if(!(embs[mbi].refined&0x04)){
+            oc_mcenc_refine1mv(_enc,mbi,OC_FRAME_PREV);
+            embs[mbi].refined|=0x04;
+          }
+          mb_mv_bits_0=oc_cost_inter1mv(_enc,modes+OC_MODE_INTER_MV,mbi,
+           OC_MODE_INTER_MV,embs[mbi].analysis_mv[0][OC_FRAME_PREV],
+           pipe.fr+0,pipe.qs+0,skip_ssd);
+          /*Finally, pick the mode with the cheapest estimated R-D cost.*/
+          mb_mode=OC_MODE_INTER_NOMV;
+          if(modes[OC_MODE_INTRA].cost<modes[OC_MODE_INTER_NOMV].cost){
+            mb_mode=OC_MODE_INTRA;
+          }
+          if(modes[OC_MODE_INTER_MV_LAST].cost<modes[mb_mode].cost){
+            mb_mode=OC_MODE_INTER_MV_LAST;
+          }
+          if(modes[OC_MODE_INTER_MV_LAST2].cost<modes[mb_mode].cost){
+            mb_mode=OC_MODE_INTER_MV_LAST2;
+          }
+          if(modes[OC_MODE_GOLDEN_NOMV].cost<modes[mb_mode].cost){
+            mb_mode=OC_MODE_GOLDEN_NOMV;
+          }
+          if(modes[OC_MODE_GOLDEN_MV].cost<modes[mb_mode].cost){
+            mb_mode=OC_MODE_GOLDEN_MV;
+          }
+          if(modes[OC_MODE_INTER_MV_FOUR].cost<modes[mb_mode].cost){
+            mb_mode=OC_MODE_INTER_MV_FOUR;
+          }
+          /*We prefer OC_MODE_INTER_MV, but not over LAST and LAST2.*/
+          if(mb_mode==OC_MODE_INTER_MV_LAST||mb_mode==OC_MODE_INTER_MV_LAST2){
+            inter_mv_pref=0;
+          }
+          if(modes[OC_MODE_INTER_MV].cost<modes[mb_mode].cost+inter_mv_pref){
+            mb_mode=OC_MODE_INTER_MV;
+          }
+        }
+        else{
+          oc_cost_inter_nomv(_enc,modes+OC_MODE_GOLDEN_NOMV,mbi,
+           OC_MODE_GOLDEN_NOMV,pipe.fr+0,pipe.qs+0,skip_ssd);
+          mb_mode=OC_MODE_INTER_NOMV;
+          if(modes[OC_MODE_INTRA].cost<modes[OC_MODE_INTER_NOMV].cost){
+            mb_mode=OC_MODE_INTRA;
+          }
+          if(modes[OC_MODE_GOLDEN_NOMV].cost<modes[mb_mode].cost){
+            mb_mode=OC_MODE_GOLDEN_NOMV;
+          }
+          mb_mv_bits_0=mb_gmv_bits_0=0;
+        }
+        mb_modes[mbi]=mb_mode;
+        /*Propagate the MVs to the luma blocks.*/
+        if(mb_mode!=OC_MODE_INTER_MV_FOUR){
+          switch(mb_mode){
+            case OC_MODE_INTER_MV:{
+              dx=embs[mbi].analysis_mv[0][OC_FRAME_PREV][0];
+              dy=embs[mbi].analysis_mv[0][OC_FRAME_PREV][1];
+            }break;
+            case OC_MODE_INTER_MV_LAST:{
+              dx=last_mv[0];
+              dy=last_mv[1];
+            }break;
+            case OC_MODE_INTER_MV_LAST2:{
+              dx=prior_mv[0];
+              dy=prior_mv[1];
+            }break;
+            case OC_MODE_GOLDEN_MV:{
+              dx=embs[mbi].analysis_mv[0][OC_FRAME_GOLD][0];
+              dy=embs[mbi].analysis_mv[0][OC_FRAME_GOLD][1];
+            }break;
+          }
+          for(bi=0;bi<4;bi++){
+            fragi=mb_maps[mbi][0][bi];
+            frag_mvs[fragi][0]=(signed char)dx;
+            frag_mvs[fragi][1]=(signed char)dy;
+          }
+        }
+        for(bi=0;bi<4;bi++){
+          fragi=sb_maps[mbi>>2][mbi&3][bi];
+          frags[fragi].qii=modes[mb_mode].qii[bi];
+        }
+        if(oc_enc_mb_transform_quantize_luma(_enc,&pipe,mbi,
+         modes[mb_mode].overhead>>OC_BIT_SCALE)>0){
+          int orig_mb_mode;
+          orig_mb_mode=mb_mode;
+          mb_mode=mb_modes[mbi];
+          switch(mb_mode){
+            case OC_MODE_INTER_MV:{
+              memcpy(prior_mv,last_mv,sizeof(prior_mv));
+              /*If we're backing out from 4MV, find the MV we're actually
+                 using.*/
+              if(orig_mb_mode==OC_MODE_INTER_MV_FOUR){
+                for(bi=0;;bi++){
+                  fragi=mb_maps[mbi][0][bi];
+                  if(frags[fragi].coded){
+                    memcpy(last_mv,frag_mvs[fragi],sizeof(last_mv));
+                    dx=frag_mvs[fragi][0];
+                    dy=frag_mvs[fragi][1];
+                    break;
+                  }
+                }
+                mb_mv_bits_0=OC_MV_BITS[0][dx+31]+OC_MV_BITS[0][dy+31];
+              }
+              /*Otherwise we used the original analysis MV.*/
+              else{
+                memcpy(last_mv,
+                 embs[mbi].analysis_mv[0][OC_FRAME_PREV],sizeof(last_mv));
+              }
+              _enc->mv_bits[0]+=mb_mv_bits_0;
+              _enc->mv_bits[1]+=12;
+            }break;
+            case OC_MODE_INTER_MV_LAST2:{
+              oc_mv tmp_mv;
+              memcpy(tmp_mv,prior_mv,sizeof(tmp_mv));
+              memcpy(prior_mv,last_mv,sizeof(prior_mv));
+              memcpy(last_mv,tmp_mv,sizeof(last_mv));
+            }break;
+            case OC_MODE_GOLDEN_MV:{
+              _enc->mv_bits[0]+=mb_gmv_bits_0;
+              _enc->mv_bits[1]+=12;
+            }break;
+            case OC_MODE_INTER_MV_FOUR:{
+              oc_mv lbmvs[4];
+              oc_mv cbmvs[4];
+              memcpy(prior_mv,last_mv,sizeof(prior_mv));
+              for(bi=0;bi<4;bi++){
+                fragi=mb_maps[mbi][0][bi];
+                if(frags[fragi].coded){
+                  memcpy(last_mv,frag_mvs[fragi],sizeof(last_mv));
+                  memcpy(lbmvs[bi],frag_mvs[fragi],sizeof(lbmvs[bi]));
+                  _enc->mv_bits[0]+=OC_MV_BITS[0][frag_mvs[fragi][0]+31]
+                   +OC_MV_BITS[0][frag_mvs[fragi][1]+31];
+                  _enc->mv_bits[1]+=12;
+                }
+                /*Replace the block MVs for not-coded blocks with (0,0).*/
+                else memset(lbmvs[bi],0,sizeof(lbmvs[bi]));
+              }
+              (*set_chroma_mvs)(cbmvs,(const oc_mv *)lbmvs);
+              for(mapii=4;mapii<nmap_idxs;mapii++){
+                mapi=map_idxs[mapii];
+                pli=mapi>>2;
+                bi=mapi&3;
+                fragi=mb_maps[mbi][pli][bi];
+                frags[fragi].mb_mode=mb_mode;
+                frags[fragi].qii=modes[OC_MODE_INTER_MV_FOUR].qii[mapii];
+                memcpy(frag_mvs[fragi],cbmvs[bi],sizeof(frag_mvs[fragi]));
+              }
+            }break;
+          }
+          coded_mbis[ncoded_mbis++]=mbi;
+          oc_mode_scheme_chooser_update(&_enc->chooser,mb_mode);
+          interbits+=modes[mb_mode].rate+modes[mb_mode].overhead;
+        }
+        else{
+          *(uncoded_mbis-++nuncoded_mbis)=mbi;
+          mb_mode=OC_MODE_INTER_NOMV;
+          dx=dy=0;
+        }
+        /*Propagate final MB mode and MVs to the chroma blocks.
+          This has already been done for 4MV mode, since it requires individual
+           block motion vectors.*/
+        if(mb_mode!=OC_MODE_INTER_MV_FOUR){
+          for(mapii=4;mapii<nmap_idxs;mapii++){
+            mapi=map_idxs[mapii];
+            pli=mapi>>2;
+            bi=mapi&3;
+            fragi=mb_maps[mbi][pli][bi];
+            frags[fragi].mb_mode=mb_mode;
+            /*If we switched from 4MV mode to INTER_MV mode, then the qii
+               values won't have been chosen with the right MV, but it's
+               probaby not worth re-estimating them.*/
+            frags[fragi].qii=modes[mb_mode].qii[mapii];
+            frag_mvs[fragi][0]=(signed char)dx;
+            frag_mvs[fragi][1]=(signed char)dy;
+          }
+        }
+      }
+      oc_fr_state_flush_sb(pipe.fr+0);
+      sb_flags[sbi].coded_fully=pipe.fr[0].sb_full;
+      sb_flags[sbi].coded_partially=pipe.fr[0].sb_partial;
+    }
+    oc_enc_pipeline_finish_mcu_plane(_enc,&pipe,0,notstart,notdone);
+    /*Code chroma planes.*/
+    for(pli=1;pli<3;pli++){
+      oc_enc_sb_transform_quantize_chroma(_enc,&pipe,
+       pli,pipe.sbi0[pli],pipe.sbi_end[pli]);
+      oc_enc_pipeline_finish_mcu_plane(_enc,&pipe,pli,notstart,notdone);
+    }
+    notstart=1;
+  }
+  /*Finish filling in the reference frame borders.*/
+  refi=_enc->state.ref_frame_idx[OC_FRAME_SELF];
+  for(pli=0;pli<3;pli++)oc_state_borders_fill_caps(&_enc->state,refi,pli);
+  /*Finish adding flagging overhead costs to inter bit counts to determine if
+     we should have coded a key frame instead.*/
+  if(_allow_keyframe){
+    if(interbits>intrabits)return 1;
+    /*Technically the chroma plane counts are over-estimations, because they
+       don't account for continuing runs from the luma planes, but the
+       inaccuracy is small.*/
+    for(pli=0;pli<3;pli++)interbits+=pipe.fr[pli].bits<<OC_BIT_SCALE;
+    interbits+=OC_MINI(_enc->mv_bits[0],_enc->mv_bits[1])<<OC_BIT_SCALE;
+    interbits+=
+     _enc->chooser.scheme_bits[_enc->chooser.scheme_list[0]]<<OC_BIT_SCALE;
+    if(interbits>intrabits)return 1;
+  }
+  _enc->ncoded_mbis=ncoded_mbis;
+  /*Compact the coded fragment list.*/
+  {
+    ptrdiff_t ncoded_fragis;
+    ncoded_fragis=_enc->state.ncoded_fragis[0];
+    for(pli=1;pli<3;pli++){
+      memmove(_enc->state.coded_fragis+ncoded_fragis,
+       _enc->state.coded_fragis+_enc->state.fplanes[pli].froffset,
+       _enc->state.ncoded_fragis[pli]*sizeof(*_enc->state.coded_fragis));
+      ncoded_fragis+=_enc->state.ncoded_fragis[pli];
+    }
+    _enc->state.ntotal_coded_fragis=ncoded_fragis;
+  }
+  return 0;
+}
+
+#if defined(OC_COLLECT_METRICS)
+# include <stdio.h>
+# include <math.h>
+
+/*TODO: It may be helpful (for block-level quantizers especially) to separate
+   out the contributions from AC and DC into separate tables.*/
+
+# define OC_ZWEIGHT   (0.25)
+
+static void oc_mode_metrics_add(oc_mode_metrics *_metrics,
+ double _w,int _satd,int _rate,double _rmse){
+  double rate;
+  /*Accumulate statistics without the scaling; this lets us change the scale
+     factor yet still use old data.*/
+  rate=ldexp(_rate,-OC_BIT_SCALE);
+  if(_metrics->fragw>0){
+    double dsatd;
+    double drate;
+    double drmse;
+    double w;
+    dsatd=_satd-_metrics->satd/_metrics->fragw;
+    drate=rate-_metrics->rate/_metrics->fragw;
+    drmse=_rmse-_metrics->rmse/_metrics->fragw;
+    w=_metrics->fragw*_w/(_metrics->fragw+_w);
+    _metrics->satd2+=dsatd*dsatd*w;
+    _metrics->satdrate+=dsatd*drate*w;
+    _metrics->rate2+=drate*drate*w;
+    _metrics->satdrmse+=dsatd*drmse*w;
+    _metrics->rmse2+=drmse*drmse*w;
+  }
+  _metrics->fragw+=_w;
+  _metrics->satd+=_satd*_w;
+  _metrics->rate+=rate*_w;
+  _metrics->rmse+=_rmse*_w;
+}
+
+static void oc_mode_metrics_merge(oc_mode_metrics *_dst,
+ const oc_mode_metrics *_src,int _n){
+  int i;
+  /*Find a non-empty set of metrics.*/
+  for(i=0;i<_n&&_src[i].fragw<=0;i++);
+  if(i>=_n){
+    memset(_dst,0,sizeof(*_dst));
+    return;
+  }
+  memcpy(_dst,_src+i,sizeof(*_dst));
+  /*And iterate over the remaining non-empty sets of metrics.*/
+  for(i++;i<_n;i++)if(_src[i].fragw>0){
+    double wa;
+    double wb;
+    double dsatd;
+    double drate;
+    double drmse;
+    double w;
+    wa=_dst->fragw;
+    wb=_src[i].fragw;
+    dsatd=_src[i].satd/wb-_dst->satd/wa;
+    drate=_src[i].rate/wb-_dst->rate/wa;
+    drmse=_src[i].rmse/wb-_dst->rmse/wa;
+    w=wa*wb/(wa+wb);
+    _dst->fragw+=_src[i].fragw;
+    _dst->satd+=_src[i].satd;
+    _dst->rate+=_src[i].rate;
+    _dst->rmse+=_src[i].rmse;
+    _dst->satd2+=_src[i].satd2+dsatd*dsatd*w;
+    _dst->satdrate+=_src[i].satdrate+dsatd*drate*w;
+    _dst->rate2+=_src[i].rate2+drate*drate*w;
+    _dst->satdrmse+=_src[i].satdrmse+dsatd*drmse*w;
+    _dst->rmse2+=_src[i].rmse2+drmse*drmse*w;
+  }
+}
+
+/*Compile collected SATD/rate/RMSE metrics into a form that's immediately
+   useful for mode decision.*/
+static void oc_enc_mode_metrics_update(oc_enc_ctx *_enc,int _qi){
+  int pli;
+  int qti;
+  oc_restore_fpu(&_enc->state);
+  /*Convert raw collected data into cleaned up sample points.*/
+  for(pli=0;pli<3;pli++){
+    for(qti=0;qti<2;qti++){
+      double fragw;
+      int    bin0;
+      int    bin1;
+      int    bin;
+      fragw=0;
+      bin0=bin1=0;
+      for(bin=0;bin<OC_SAD_BINS;bin++){
+        oc_mode_metrics metrics;
+        OC_MODE_RD[_qi][pli][qti][bin].rate=0;
+        OC_MODE_RD[_qi][pli][qti][bin].rmse=0;
+        /*Find some points on either side of the current bin.*/
+        while((bin1<bin+1||fragw<OC_ZWEIGHT)&&bin1<OC_SAD_BINS-1){
+          fragw+=OC_MODE_METRICS[_qi][pli][qti][bin1++].fragw;
+        }
+        while(bin0+1<bin&&bin0+1<bin1&&
+         fragw-OC_MODE_METRICS[_qi][pli][qti][bin0].fragw>=OC_ZWEIGHT){
+          fragw-=OC_MODE_METRICS[_qi][pli][qti][bin0++].fragw;
+        }
+        /*Merge statistics and fit lines.*/
+        oc_mode_metrics_merge(&metrics,
+         OC_MODE_METRICS[_qi][pli][qti]+bin0,bin1-bin0);
+        if(metrics.fragw>0&&metrics.satd2>0){
+          double a;
+          double b;
+          double msatd;
+          double mrate;
+          double mrmse;
+          double rate;
+          double rmse;
+          msatd=metrics.satd/metrics.fragw;
+          mrate=metrics.rate/metrics.fragw;
+          mrmse=metrics.rmse/metrics.fragw;
+          /*Compute the points on these lines corresponding to the actual bin
+             value.*/
+          b=metrics.satdrate/metrics.satd2;
+          a=mrate-b*msatd;
+          rate=ldexp(a+b*(bin<<OC_SAD_SHIFT),OC_BIT_SCALE);
+          OC_MODE_RD[_qi][pli][qti][bin].rate=
+           (ogg_int16_t)OC_CLAMPI(-32768,(int)(rate+0.5),32767);
+          b=metrics.satdrmse/metrics.satd2;
+          a=mrmse-b*msatd;
+          rmse=ldexp(a+b*(bin<<OC_SAD_SHIFT),OC_RMSE_SCALE);
+          OC_MODE_RD[_qi][pli][qti][bin].rmse=
+           (ogg_int16_t)OC_CLAMPI(-32768,(int)(rmse+0.5),32767);
+        }
+      }
+    }
+  }
+}
+
+
+
+/*The following token skipping code used to also be used in the decoder (and
+   even at one point other places in the encoder).
+  However, it was obsoleted by other optimizations, and is now only used here.
+  It has been moved here to avoid generating the code when it's not needed.*/
+
+/*Determines the number of blocks or coefficients to be skipped for a given
+   token value.
+  _token:      The token value to skip.
+  _extra_bits: The extra bits attached to this token.
+  Return: A positive value indicates that number of coefficients are to be
+           skipped in the current block.
+          Otherwise, the negative of the return value indicates that number of
+           blocks are to be ended.*/
+typedef ptrdiff_t (*oc_token_skip_func)(int _token,int _extra_bits);
+
+/*Handles the simple end of block tokens.*/
+static ptrdiff_t oc_token_skip_eob(int _token,int _extra_bits){
+  int nblocks_adjust;
+  nblocks_adjust=OC_UNIBBLE_TABLE32(0,1,2,3,7,15,0,0,_token)+1;
+  return -_extra_bits-nblocks_adjust;
+}
+
+/*The last EOB token has a special case, where an EOB run of size zero ends all
+   the remaining blocks in the frame.*/
+static ptrdiff_t oc_token_skip_eob6(int _token,int _extra_bits){
+  /*Note: We want to return -PTRDIFF_MAX, but that requires C99, which is not
+     yet available everywhere; this should be equivalent.*/
+  if(!_extra_bits)return -(~(size_t)0>>1);
+  return -_extra_bits;
+}
+
+/*Handles the pure zero run tokens.*/
+static ptrdiff_t oc_token_skip_zrl(int _token,int _extra_bits){
+  return _extra_bits+1;
+}
+
+/*Handles a normal coefficient value token.*/
+static ptrdiff_t oc_token_skip_val(void){
+  return 1;
+}
+
+/*Handles a category 1A zero run/coefficient value combo token.*/
+static ptrdiff_t oc_token_skip_run_cat1a(int _token){
+  return _token-OC_DCT_RUN_CAT1A+2;
+}
+
+/*Handles category 1b, 1c, 2a, and 2b zero run/coefficient value combo tokens.*/
+static ptrdiff_t oc_token_skip_run(int _token,int _extra_bits){
+  int run_cati;
+  int ncoeffs_mask;
+  int ncoeffs_adjust;
+  run_cati=_token-OC_DCT_RUN_CAT1B;
+  ncoeffs_mask=OC_BYTE_TABLE32(3,7,0,1,run_cati);
+  ncoeffs_adjust=OC_BYTE_TABLE32(7,11,2,3,run_cati);
+  return (_extra_bits&ncoeffs_mask)+ncoeffs_adjust;
+}
+
+/*A jump table for computing the number of coefficients or blocks to skip for
+   a given token value.
+  This reduces all the conditional branches, etc., needed to parse these token
+   values down to one indirect jump.*/
+static const oc_token_skip_func OC_TOKEN_SKIP_TABLE[TH_NDCT_TOKENS]={
+  oc_token_skip_eob,
+  oc_token_skip_eob,
+  oc_token_skip_eob,
+  oc_token_skip_eob,
+  oc_token_skip_eob,
+  oc_token_skip_eob,
+  oc_token_skip_eob6,
+  oc_token_skip_zrl,
+  oc_token_skip_zrl,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_val,
+  (oc_token_skip_func)oc_token_skip_run_cat1a,
+  (oc_token_skip_func)oc_token_skip_run_cat1a,
+  (oc_token_skip_func)oc_token_skip_run_cat1a,
+  (oc_token_skip_func)oc_token_skip_run_cat1a,
+  (oc_token_skip_func)oc_token_skip_run_cat1a,
+  oc_token_skip_run,
+  oc_token_skip_run,
+  oc_token_skip_run,
+  oc_token_skip_run
+};
+
+/*Determines the number of blocks or coefficients to be skipped for a given
+   token value.
+  _token:      The token value to skip.
+  _extra_bits: The extra bits attached to this token.
+  Return: A positive value indicates that number of coefficients are to be
+           skipped in the current block.
+          Otherwise, the negative of the return value indicates that number of
+           blocks are to be ended.
+          0 will never be returned, so that at least one coefficient in one
+           block will always be decoded for every token.*/
+static ptrdiff_t oc_dct_token_skip(int _token,int _extra_bits){
+  return (*OC_TOKEN_SKIP_TABLE[_token])(_token,_extra_bits);
+}
+
+
+
+void oc_enc_mode_metrics_collect(oc_enc_ctx *_enc){
+  static const unsigned char OC_ZZI_HUFF_OFFSET[64]={
+     0,16,16,16,16,16,32,32,
+    32,32,32,32,32,32,32,48,
+    48,48,48,48,48,48,48,48,
+    48,48,48,48,64,64,64,64,
+    64,64,64,64,64,64,64,64,
+    64,64,64,64,64,64,64,64,
+    64,64,64,64,64,64,64,64
+  };
+  const oc_fragment *frags;
+  const unsigned    *frag_satd;
+  const unsigned    *frag_ssd;
+  const ptrdiff_t   *coded_fragis;
+  ptrdiff_t          ncoded_fragis;
+  ptrdiff_t          fragii;
+  double             fragw;
+  int                qti;
+  int                qii;
+  int                qi;
+  int                pli;
+  int                zzi;
+  int                token;
+  int                eb;
+  oc_restore_fpu(&_enc->state);
+  /*Load any existing mode metrics if we haven't already.*/
+  if(!oc_has_mode_metrics){
+    FILE *fmetrics;
+    memset(OC_MODE_METRICS,0,sizeof(OC_MODE_METRICS));
+    fmetrics=fopen("modedec.stats","rb");
+    if(fmetrics!=NULL){
+      fread(OC_MODE_METRICS,sizeof(OC_MODE_METRICS),1,fmetrics);
+      fclose(fmetrics);
+    }
+    for(qi=0;qi<64;qi++)oc_enc_mode_metrics_update(_enc,qi);
+    oc_has_mode_metrics=1;
+  }
+  qti=_enc->state.frame_type;
+  frags=_enc->state.frags;
+  frag_satd=_enc->frag_satd;
+  frag_ssd=_enc->frag_ssd;
+  coded_fragis=_enc->state.coded_fragis;
+  ncoded_fragis=fragii=0;
+  /*Weight the fragments by the inverse frame size; this prevents HD content
+     from dominating the statistics.*/
+  fragw=1.0/_enc->state.nfrags;
+  for(pli=0;pli<3;pli++){
+    ptrdiff_t ti[64];
+    int       eob_token[64];
+    int       eob_run[64];
+    /*Set up token indices and eob run counts.
+      We don't bother trying to figure out the real cost of the runs that span
+       coefficients; instead we use the costs that were available when R-D
+       token optimization was done.*/
+    for(zzi=0;zzi<64;zzi++){
+      ti[zzi]=_enc->dct_token_offs[pli][zzi];
+      if(ti[zzi]>0){
+        token=_enc->dct_tokens[pli][zzi][0];
+        eb=_enc->extra_bits[pli][zzi][0];
+        eob_token[zzi]=token;
+        eob_run[zzi]=-oc_dct_token_skip(token,eb);
+      }
+      else{
+        eob_token[zzi]=OC_NDCT_EOB_TOKEN_MAX;
+        eob_run[zzi]=0;
+      }
+    }
+    /*Scan the list of coded fragments for this plane.*/
+    ncoded_fragis+=_enc->state.ncoded_fragis[pli];
+    for(;fragii<ncoded_fragis;fragii++){
+      ptrdiff_t    fragi;
+      ogg_uint32_t frag_bits;
+      int          huffi;
+      int          skip;
+      int          mb_mode;
+      unsigned     satd;
+      int          bin;
+      fragi=coded_fragis[fragii];
+      frag_bits=0;
+      for(zzi=0;zzi<64;){
+        if(eob_run[zzi]>0){
+          /*We've reached the end of the block.*/
+          eob_run[zzi]--;
+          break;
+        }
+        huffi=_enc->huff_idxs[qti][zzi>0][pli+1>>1]
+         +OC_ZZI_HUFF_OFFSET[zzi];
+        if(eob_token[zzi]<OC_NDCT_EOB_TOKEN_MAX){
+          /*This token caused an EOB run to be flushed.
+            Therefore it gets the bits associated with it.*/
+          frag_bits+=_enc->huff_codes[huffi][eob_token[zzi]].nbits
+           +OC_DCT_TOKEN_EXTRA_BITS[eob_token[zzi]];
+          eob_token[zzi]=OC_NDCT_EOB_TOKEN_MAX;
+        }
+        token=_enc->dct_tokens[pli][zzi][ti[zzi]];
+        eb=_enc->extra_bits[pli][zzi][ti[zzi]];
+        ti[zzi]++;
+        skip=oc_dct_token_skip(token,eb);
+        if(skip<0){
+          eob_token[zzi]=token;
+          eob_run[zzi]=-skip;
+        }
+        else{
+          /*A regular DCT value token; accumulate the bits for it.*/
+          frag_bits+=_enc->huff_codes[huffi][token].nbits
+           +OC_DCT_TOKEN_EXTRA_BITS[token];
+          zzi+=skip;
+        }
+      }
+      mb_mode=frags[fragi].mb_mode;
+      qi=_enc->state.qis[frags[fragi].qii];
+      satd=frag_satd[fragi]<<(pli+1&2);
+      bin=OC_MINI(satd>>OC_SAD_SHIFT,OC_SAD_BINS-1);
+      oc_mode_metrics_add(OC_MODE_METRICS[qi][pli][mb_mode!=OC_MODE_INTRA]+bin,
+       fragw,satd,frag_bits<<OC_BIT_SCALE,sqrt(frag_ssd[fragi]));
+    }
+  }
+  /*Update global SATD/rate/RMSE estimation matrix.*/
+  for(qii=0;qii<_enc->state.nqis;qii++){
+    oc_enc_mode_metrics_update(_enc,_enc->state.qis[qii]);
+  }
+}
+
+void oc_enc_mode_metrics_dump(oc_enc_ctx *_enc){
+  FILE *fmetrics;
+  int   qi;
+  /*Generate sample points for complete list of QI values.*/
+  for(qi=0;qi<64;qi++)oc_enc_mode_metrics_update(_enc,qi);
+  fmetrics=fopen("modedec.stats","wb");
+  if(fmetrics!=NULL){
+    fwrite(OC_MODE_METRICS,sizeof(OC_MODE_METRICS),1,fmetrics);
+    fclose(fmetrics);
+  }
+  fprintf(stdout,
+   "/*File generated by libtheora with OC_COLLECT_METRICS"
+   " defined at compile time.*/\n"
+   "#if !defined(_modedec_H)\n"
+   "# define _modedec_H (1)\n"
+   "\n"
+   "\n"
+   "\n"
+   "# if defined(OC_COLLECT_METRICS)\n"
+   "typedef struct oc_mode_metrics oc_mode_metrics;\n"
+   "# endif\n"
+   "typedef struct oc_mode_rd      oc_mode_rd;\n"
+   "\n"
+   "\n"
+   "\n"
+   "/*The number of extra bits of precision at which to store rate"
+   " metrics.*/\n"
+   "# define OC_BIT_SCALE  (%i)\n"
+   "/*The number of extra bits of precision at which to store RMSE metrics.\n"
+   "  This must be at least half OC_BIT_SCALE (rounded up).*/\n"
+   "# define OC_RMSE_SCALE (%i)\n"
+   "/*The number of bins to partition statistics into.*/\n"
+   "# define OC_SAD_BINS   (%i)\n"
+   "/*The number of bits of precision to drop"
+   " from SAD scores to assign them to a\n"
+   "   bin.*/\n"
+   "# define OC_SAD_SHIFT  (%i)\n"
+   "\n"
+   "\n"
+   "\n"
+   "# if defined(OC_COLLECT_METRICS)\n"
+   "struct oc_mode_metrics{\n"
+   "  double fragw;\n"
+   "  double satd;\n"
+   "  double rate;\n"
+   "  double rmse;\n"
+   "  double satd2;\n"
+   "  double satdrate;\n"
+   "  double rate2;\n"
+   "  double satdrmse;\n"
+   "  double rmse2;\n"
+   "};\n"
+   "\n"
+   "\n"
+   "int             oc_has_mode_metrics;\n"
+   "oc_mode_metrics OC_MODE_METRICS[64][3][2][OC_SAD_BINS];\n"
+   "# endif\n"
+   "\n"
+   "\n"
+   "\n"
+   "struct oc_mode_rd{\n"
+   "  ogg_int16_t rate;\n"
+   "  ogg_int16_t rmse;\n"
+   "};\n"
+   "\n"
+   "\n"
+   "# if !defined(OC_COLLECT_METRICS)\n"
+   "static const\n"
+   "# endif\n"
+   "oc_mode_rd OC_MODE_RD[64][3][2][OC_SAD_BINS]={\n",
+   OC_BIT_SCALE,OC_RMSE_SCALE,OC_SAD_BINS,OC_SAD_SHIFT);
+  for(qi=0;qi<64;qi++){
+    int pli;
+    fprintf(stdout,"  {\n");
+    for(pli=0;pli<3;pli++){
+      int qti;
+      fprintf(stdout,"    {\n");
+      for(qti=0;qti<2;qti++){
+        int bin;
+        static const char *pl_names[3]={"Y'","Cb","Cr"};
+        static const char *qti_names[2]={"INTRA","INTER"};
+        fprintf(stdout,"      /*%s  qi=%i  %s*/\n",
+         pl_names[pli],qi,qti_names[qti]);
+        fprintf(stdout,"      {\n");
+        fprintf(stdout,"        ");
+        for(bin=0;bin<OC_SAD_BINS;bin++){
+          if(bin&&!(bin&0x3))fprintf(stdout,"\n        ");
+          fprintf(stdout,"{%5i,%5i}",
+           OC_MODE_RD[qi][pli][qti][bin].rate,
+           OC_MODE_RD[qi][pli][qti][bin].rmse);
+          if(bin+1<OC_SAD_BINS)fprintf(stdout,",");
+        }
+        fprintf(stdout,"\n      }");
+        if(qti<1)fprintf(stdout,",");
+        fprintf(stdout,"\n");
+      }
+      fprintf(stdout,"    }");
+      if(pli<2)fprintf(stdout,",");
+      fprintf(stdout,"\n");
+    }
+    fprintf(stdout,"  }");
+    if(qi<63)fprintf(stdout,",");
+    fprintf(stdout,"\n");
+  }
+  fprintf(stdout,
+   "};\n"
+   "\n"
+   "#endif\n");
+}
+#endif
diff --git a/lib/apiwrapper.c b/lib/apiwrapper.c
new file mode 100644 (file)
index 0000000..dc959b8
--- /dev/null
@@ -0,0 +1,166 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: apiwrapper.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include <limits.h>
+#include "apiwrapper.h"
+
+
+
+const char *theora_version_string(void){
+  return th_version_string();
+}
+
+ogg_uint32_t theora_version_number(void){
+  return th_version_number();
+}
+
+void theora_info_init(theora_info *_ci){
+  memset(_ci,0,sizeof(*_ci));
+}
+
+void theora_info_clear(theora_info *_ci){
+  th_api_wrapper *api;
+  api=(th_api_wrapper *)_ci->codec_setup;
+  memset(_ci,0,sizeof(*_ci));
+  if(api!=NULL){
+    if(api->clear!=NULL)(*api->clear)(api);
+    _ogg_free(api);
+  }
+}
+
+void theora_clear(theora_state *_th){
+  /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
+  if(_th->internal_decode!=NULL){
+    (*((oc_state_dispatch_vtable *)_th->internal_decode)->clear)(_th);
+  }
+  if(_th->internal_encode!=NULL){
+    (*((oc_state_dispatch_vtable *)_th->internal_encode)->clear)(_th);
+  }
+  if(_th->i!=NULL)theora_info_clear(_th->i);
+  memset(_th,0,sizeof(*_th));
+}
+
+int theora_control(theora_state *_th,int _req,void *_buf,size_t _buf_sz){
+  /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
+  if(_th->internal_decode!=NULL){
+    return (*((oc_state_dispatch_vtable *)_th->internal_decode)->control)(_th,
+     _req,_buf,_buf_sz);
+  }
+  else if(_th->internal_encode!=NULL){
+    return (*((oc_state_dispatch_vtable *)_th->internal_encode)->control)(_th,
+     _req,_buf,_buf_sz);
+  }
+  else return TH_EINVAL;
+}
+
+ogg_int64_t theora_granule_frame(theora_state *_th,ogg_int64_t _gp){
+  /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
+  if(_th->internal_decode!=NULL){
+    return (*((oc_state_dispatch_vtable *)_th->internal_decode)->granule_frame)(
+     _th,_gp);
+  }
+  else if(_th->internal_encode!=NULL){
+    return (*((oc_state_dispatch_vtable *)_th->internal_encode)->granule_frame)(
+     _th,_gp);
+  }
+  else return -1;
+}
+
+double theora_granule_time(theora_state *_th, ogg_int64_t _gp){
+  /*Provide compatibility with mixed encoder and decoder shared lib versions.*/
+  if(_th->internal_decode!=NULL){
+    return (*((oc_state_dispatch_vtable *)_th->internal_decode)->granule_time)(
+     _th,_gp);
+  }
+  else if(_th->internal_encode!=NULL){
+    return (*((oc_state_dispatch_vtable *)_th->internal_encode)->granule_time)(
+     _th,_gp);
+  }
+  else return -1;
+}
+
+void oc_theora_info2th_info(th_info *_info,const theora_info *_ci){
+  _info->version_major=_ci->version_major;
+  _info->version_minor=_ci->version_minor;
+  _info->version_subminor=_ci->version_subminor;
+  _info->frame_width=_ci->width;
+  _info->frame_height=_ci->height;
+  _info->pic_width=_ci->frame_width;
+  _info->pic_height=_ci->frame_height;
+  _info->pic_x=_ci->offset_x;
+  _info->pic_y=_ci->offset_y;
+  _info->fps_numerator=_ci->fps_numerator;
+  _info->fps_denominator=_ci->fps_denominator;
+  _info->aspect_numerator=_ci->aspect_numerator;
+  _info->aspect_denominator=_ci->aspect_denominator;
+  switch(_ci->colorspace){
+    case OC_CS_ITU_REC_470M:_info->colorspace=TH_CS_ITU_REC_470M;break;
+    case OC_CS_ITU_REC_470BG:_info->colorspace=TH_CS_ITU_REC_470BG;break;
+    default:_info->colorspace=TH_CS_UNSPECIFIED;break;
+  }
+  switch(_ci->pixelformat){
+    case OC_PF_420:_info->pixel_fmt=TH_PF_420;break;
+    case OC_PF_422:_info->pixel_fmt=TH_PF_422;break;
+    case OC_PF_444:_info->pixel_fmt=TH_PF_444;break;
+    default:_info->pixel_fmt=TH_PF_RSVD;
+  }
+  _info->target_bitrate=_ci->target_bitrate;
+  _info->quality=_ci->quality;
+  _info->keyframe_granule_shift=_ci->keyframe_frequency_force>0?
+   OC_MINI(31,oc_ilog(_ci->keyframe_frequency_force-1)):0;
+}
+
+int theora_packet_isheader(ogg_packet *_op){
+  return th_packet_isheader(_op);
+}
+
+int theora_packet_iskeyframe(ogg_packet *_op){
+  return th_packet_iskeyframe(_op);
+}
+
+int theora_granule_shift(theora_info *_ci){
+  /*This breaks when keyframe_frequency_force is not positive or is larger than
+     2**31 (if your int is more than 32 bits), but that's what the original
+     function does.*/
+  return oc_ilog(_ci->keyframe_frequency_force-1);
+}
+
+void theora_comment_init(theora_comment *_tc){
+  th_comment_init((th_comment *)_tc);
+}
+
+char *theora_comment_query(theora_comment *_tc,char *_tag,int _count){
+  return th_comment_query((th_comment *)_tc,_tag,_count);
+}
+
+int theora_comment_query_count(theora_comment *_tc,char *_tag){
+  return th_comment_query_count((th_comment *)_tc,_tag);
+}
+
+void theora_comment_clear(theora_comment *_tc){
+  th_comment_clear((th_comment *)_tc);
+}
+
+void theora_comment_add(theora_comment *_tc,char *_comment){
+  th_comment_add((th_comment *)_tc,_comment);
+}
+
+void theora_comment_add_tag(theora_comment *_tc, char *_tag, char *_value){
+  th_comment_add_tag((th_comment *)_tc,_tag,_value);
+}
diff --git a/lib/apiwrapper.h b/lib/apiwrapper.h
new file mode 100644 (file)
index 0000000..93454d7
--- /dev/null
@@ -0,0 +1,54 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: apiwrapper.h 13596 2007-08-23 20:05:38Z tterribe $
+
+ ********************************************************************/
+
+#if !defined(_apiwrapper_H)
+# define _apiwrapper_H (1)
+# include <ogg/ogg.h>
+# include <theora/theora.h>
+# include "theora/theoradec.h"
+# include "theora/theoraenc.h"
+# include "internal.h"
+
+typedef struct th_api_wrapper th_api_wrapper;
+typedef struct th_api_info    th_api_info;
+
+/*Provide an entry point for the codec setup to clear itself in case we ever
+   want to break pieces off into a common base library shared by encoder and
+   decoder.
+  In addition, this makes several other pieces of the API wrapper cleaner.*/
+typedef void (*oc_setup_clear_func)(void *_ts);
+
+/*Generally only one of these pointers will be non-NULL in any given instance.
+  Technically we do not even really need this struct, since we should be able
+   to figure out which one from "context", but doing it this way makes sure we
+   don't flub it up.*/
+struct th_api_wrapper{
+  oc_setup_clear_func  clear;
+  th_setup_info       *setup;
+  th_dec_ctx          *decode;
+  th_enc_ctx          *encode;
+};
+
+struct th_api_info{
+  th_api_wrapper api;
+  theora_info    info;
+};
+
+
+void oc_theora_info2th_info(th_info *_info,const theora_info *_ci);
+
+#endif
diff --git a/lib/bitpack.c b/lib/bitpack.c
new file mode 100644 (file)
index 0000000..8195003
--- /dev/null
@@ -0,0 +1,111 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE OggTheora SOURCE CODE IS (C) COPYRIGHT 1994-2009             *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function: packing variable sized words into an octet stream
+  last mod: $Id: bitpack.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include <string.h>
+#include <stdlib.h>
+#include "bitpack.h"
+
+/*We're 'MSb' endian; if we write a word but read individual bits,
+   then we'll read the MSb first.*/
+
+void oc_pack_readinit(oc_pack_buf *_b,unsigned char *_buf,long _bytes){
+  memset(_b,0,sizeof(*_b));
+  _b->ptr=_buf;
+  _b->stop=_buf+_bytes;
+}
+
+static oc_pb_window oc_pack_refill(oc_pack_buf *_b,int _bits){
+  const unsigned char *ptr;
+  const unsigned char *stop;
+  oc_pb_window         window;
+  int                  available;
+  window=_b->window;
+  available=_b->bits;
+  ptr=_b->ptr;
+  stop=_b->stop;
+  while(available<=OC_PB_WINDOW_SIZE-8&&ptr<stop){
+    available+=8;
+    window|=(oc_pb_window)*ptr++<<OC_PB_WINDOW_SIZE-available;
+  }
+  _b->ptr=ptr;
+  if(_bits>available){
+    if(ptr>=stop){
+      _b->eof=1;
+      available=OC_LOTS_OF_BITS;
+    }
+    else window|=*ptr>>(available&7);
+  }
+  _b->bits=available;
+  return window;
+}
+
+int oc_pack_look1(oc_pack_buf *_b){
+  oc_pb_window window;
+  int          available;
+  window=_b->window;
+  available=_b->bits;
+  if(available<1)_b->window=window=oc_pack_refill(_b,1);
+  return window>>OC_PB_WINDOW_SIZE-1;
+}
+
+void oc_pack_adv1(oc_pack_buf *_b){
+  _b->window<<=1;
+  _b->bits--;
+}
+
+/*Here we assume that 0<=_bits&&_bits<=32.*/
+long oc_pack_read(oc_pack_buf *_b,int _bits){
+  oc_pb_window window;
+  int          available;
+  long         result;
+  window=_b->window;
+  available=_b->bits;
+  if(_bits==0)return 0;
+  if(available<_bits){
+    window=oc_pack_refill(_b,_bits);
+    available=_b->bits;
+  }
+  result=window>>OC_PB_WINDOW_SIZE-_bits;
+  available-=_bits;
+  window<<=1;
+  window<<=_bits-1;
+  _b->bits=available;
+  _b->window=window;
+  return result;
+}
+
+int oc_pack_read1(oc_pack_buf *_b){
+  oc_pb_window window;
+  int          available;
+  int          result;
+  window=_b->window;
+  available=_b->bits;
+  if(available<1){
+    window=oc_pack_refill(_b,1);
+    available=_b->bits;
+  }
+  result=window>>OC_PB_WINDOW_SIZE-1;
+  available--;
+  window<<=1;
+  _b->bits=available;
+  _b->window=window;
+  return result;
+}
+
+long oc_pack_bytes_left(oc_pack_buf *_b){
+  if(_b->eof)return -1;
+  return _b->stop-_b->ptr+(_b->bits>>3);
+}
diff --git a/lib/bitpack.h b/lib/bitpack.h
new file mode 100644 (file)
index 0000000..a020a29
--- /dev/null
@@ -0,0 +1,59 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE OggTheora SOURCE CODE IS (C) COPYRIGHT 1994-2009             *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function: packing variable sized words into an octet stream
+  last mod: $Id: bitwise.c 7675 2004-09-01 00:34:39Z xiphmont $
+
+ ********************************************************************/
+#if !defined(_bitpack_H)
+# define _bitpack_H (1)
+# include <limits.h>
+
+
+
+typedef unsigned long      oc_pb_window;
+typedef struct oc_pack_buf oc_pack_buf;
+
+
+
+# define OC_PB_WINDOW_SIZE ((int)sizeof(oc_pb_window)*CHAR_BIT)
+/*This is meant to be a large, positive constant that can still be efficiently
+   loaded as an immediate (on platforms like ARM, for example).
+  Even relatively modest values like 100 would work fine.*/
+# define OC_LOTS_OF_BITS (0x40000000)
+
+
+
+struct oc_pack_buf{
+  oc_pb_window         window;
+  const unsigned char *ptr;
+  const unsigned char *stop;
+  int                  bits;
+  int                  eof;
+};
+
+void oc_pack_readinit(oc_pack_buf *_b,unsigned char *_buf,long _bytes);
+int oc_pack_look1(oc_pack_buf *_b);
+void oc_pack_adv1(oc_pack_buf *_b);
+/*Here we assume 0<=_bits&&_bits<=32.*/
+long oc_pack_read(oc_pack_buf *_b,int _bits);
+int oc_pack_read1(oc_pack_buf *_b);
+/* returns -1 for read beyond EOF, or the number of whole bytes available */
+long oc_pack_bytes_left(oc_pack_buf *_b);
+
+/*These two functions are implemented locally in huffdec.c*/
+/*Read in bits without advancing the bitptr.
+  Here we assume 0<=_bits&&_bits<=32.*/
+/*static int oc_pack_look(oc_pack_buf *_b,int _bits);*/
+/*static void oc_pack_adv(oc_pack_buf *_b,int _bits);*/
+
+#endif
diff --git a/lib/cpu.c b/lib/cpu.c
new file mode 100644 (file)
index 0000000..a863aad
--- /dev/null
+++ b/lib/cpu.c
@@ -0,0 +1,226 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+ CPU capability detection for x86 processors.
+  Originally written by Rudolf Marek.
+
+ function:
+  last mod: $Id: cpu.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include "cpu.h"
+
+#if !defined(OC_X86_ASM)
+static ogg_uint32_t oc_cpu_flags_get(void){
+  return 0;
+}
+#else
+# if !defined(_MSC_VER)
+#  if defined(__amd64__)||defined(__x86_64__)
+/*On x86-64, gcc seems to be able to figure out how to save %rbx for us when
+   compiling with -fPIC.*/
+#   define cpuid(_op,_eax,_ebx,_ecx,_edx) \
+  __asm__ __volatile__( \
+   "cpuid\n\t" \
+   :[eax]"=a"(_eax),[ebx]"=b"(_ebx),[ecx]"=c"(_ecx),[edx]"=d"(_edx) \
+   :"a"(_op) \
+   :"cc" \
+  )
+#  else
+/*On x86-32, not so much.*/
+#   define cpuid(_op,_eax,_ebx,_ecx,_edx) \
+  __asm__ __volatile__( \
+   "xchgl %%ebx,%[ebx]\n\t" \
+   "cpuid\n\t" \
+   "xchgl %%ebx,%[ebx]\n\t" \
+   :[eax]"=a"(_eax),[ebx]"=r"(_ebx),[ecx]"=c"(_ecx),[edx]"=d"(_edx) \
+   :"a"(_op) \
+   :"cc" \
+  )
+#  endif
+# else
+/*Why does MSVC need this complicated rigamarole?
+  At this point I honestly do not care.*/
+
+/*Visual C cpuid helper function.
+  For VS2005 we could as well use the _cpuid builtin, but that wouldn't work
+   for VS2003 users, so we do it in inline assembler.*/
+static void oc_cpuid_helper(ogg_uint32_t _cpu_info[4],ogg_uint32_t _op){
+  _asm{
+    mov eax,[_op]
+    mov esi,_cpu_info
+    cpuid
+    mov [esi+0],eax
+    mov [esi+4],ebx
+    mov [esi+8],ecx
+    mov [esi+12],edx
+  }
+}
+
+#  define cpuid(_op,_eax,_ebx,_ecx,_edx) \
+  do{ \
+    ogg_uint32_t cpu_info[4]; \
+    oc_cpuid_helper(cpu_info,_op); \
+    (_eax)=cpu_info[0]; \
+    (_ebx)=cpu_info[1]; \
+    (_ecx)=cpu_info[2]; \
+    (_edx)=cpu_info[3]; \
+  }while(0)
+
+static void oc_detect_cpuid_helper(ogg_uint32_t *_eax,ogg_uint32_t *_ebx){
+  _asm{
+    pushfd
+    pushfd
+    pop eax
+    mov ebx,eax
+    xor eax,200000h
+    push eax
+    popfd
+    pushfd
+    pop eax
+    popfd
+    mov ecx,_eax
+    mov [ecx],eax
+    mov ecx,_ebx
+    mov [ecx],ebx
+  }
+}
+# endif
+
+static ogg_uint32_t oc_parse_intel_flags(ogg_uint32_t _edx,ogg_uint32_t _ecx){
+  ogg_uint32_t flags;
+  /*If there isn't even MMX, give up.*/
+  if(!(_edx&0x00800000))return 0;
+  flags=OC_CPU_X86_MMX;
+  if(_edx&0x02000000)flags|=OC_CPU_X86_MMXEXT|OC_CPU_X86_SSE;
+  if(_edx&0x04000000)flags|=OC_CPU_X86_SSE2;
+  if(_ecx&0x00000001)flags|=OC_CPU_X86_PNI;
+  if(_ecx&0x00000100)flags|=OC_CPU_X86_SSSE3;
+  if(_ecx&0x00080000)flags|=OC_CPU_X86_SSE4_1;
+  if(_ecx&0x00100000)flags|=OC_CPU_X86_SSE4_2;
+  return flags;
+}
+
+static ogg_uint32_t oc_parse_amd_flags(ogg_uint32_t _edx,ogg_uint32_t _ecx){
+  ogg_uint32_t flags;
+  /*If there isn't even MMX, give up.*/
+  if(!(_edx&0x00800000))return 0;
+  flags=OC_CPU_X86_MMX;
+  if(_edx&0x00400000)flags|=OC_CPU_X86_MMXEXT;
+  if(_edx&0x80000000)flags|=OC_CPU_X86_3DNOW;
+  if(_edx&0x40000000)flags|=OC_CPU_X86_3DNOWEXT;
+  if(_ecx&0x00000040)flags|=OC_CPU_X86_SSE4A;
+  if(_ecx&0x00000800)flags|=OC_CPU_X86_SSE5;
+  return flags;
+}
+
+static ogg_uint32_t oc_cpu_flags_get(void){
+  ogg_uint32_t flags;
+  ogg_uint32_t eax;
+  ogg_uint32_t ebx;
+  ogg_uint32_t ecx;
+  ogg_uint32_t edx;
+# if !defined(__amd64__)&&!defined(__x86_64__)
+  /*Not all x86-32 chips support cpuid, so we have to check.*/
+#  if !defined(_MSC_VER)
+  __asm__ __volatile__(
+   "pushfl\n\t"
+   "pushfl\n\t"
+   "popl %[a]\n\t"
+   "movl %[a],%[b]\n\t"
+   "xorl $0x200000,%[a]\n\t"
+   "pushl %[a]\n\t"
+   "popfl\n\t"
+   "pushfl\n\t"
+   "popl %[a]\n\t"
+   "popfl\n\t"
+   :[a]"=r"(eax),[b]"=r"(ebx)
+   :
+   :"cc"
+  );
+#  else
+  oc_detect_cpuid_helper(&eax,&ebx);
+#  endif
+  /*No cpuid.*/
+  if(eax==ebx)return 0;
+# endif
+  cpuid(0,eax,ebx,ecx,edx);
+  /*         l e t n          I e n i          u n e G*/
+  if(ecx==0x6C65746E&&edx==0x49656E69&&ebx==0x756E6547||
+   /*      6 8 x M          T e n i          u n e G*/
+   ecx==0x3638784D&&edx==0x54656E69&&ebx==0x756E6547){
+    /*Intel, Transmeta (tested with Crusoe TM5800):*/
+    cpuid(1,eax,ebx,ecx,edx);
+    flags=oc_parse_intel_flags(edx,ecx);
+  }
+  /*              D M A c          i t n e          h t u A*/
+  else if(ecx==0x444D4163&&edx==0x69746E65&&ebx==0x68747541||
+   /*      C S N            y b   e          d o e G*/
+   ecx==0x43534e20&&edx==0x79622065&&ebx==0x646f6547){
+    /*AMD, Geode:*/
+    cpuid(0x80000000,eax,ebx,ecx,edx);
+    if(eax<0x80000001)flags=0;
+    else{
+      cpuid(0x80000001,eax,ebx,ecx,edx);
+      flags=oc_parse_amd_flags(edx,ecx);
+    }
+    /*Also check for SSE.*/
+    cpuid(1,eax,ebx,ecx,edx);
+    flags|=oc_parse_intel_flags(edx,ecx);
+  }
+  /*Technically some VIA chips can be configured in the BIOS to return any
+     string here the user wants.
+    There is a special detection method that can be used to identify such
+     processors, but in my opinion, if the user really wants to change it, they
+     deserve what they get.*/
+  /*              s l u a          H r u a          t n e C*/
+  else if(ecx==0x736C7561&&edx==0x48727561&&ebx==0x746E6543){
+    /*VIA:*/
+    /*I only have documentation for the C7 (Esther) and Isaiah (forthcoming)
+       chips (thanks to the engineers from Centaur Technology who provided it).
+      These chips support Intel-like cpuid info.
+      The C3-2 (Nehemiah) cores appear to, as well.*/
+    cpuid(1,eax,ebx,ecx,edx);
+    flags=oc_parse_intel_flags(edx,ecx);
+    if(eax>=0x80000001){
+      /*The (non-Nehemiah) C3 processors support AMD-like cpuid info.
+        We need to check this even if the Intel test succeeds to pick up 3DNow!
+         support on these processors.
+        Unlike actual AMD processors, we cannot _rely_ on this info, since
+         some cores (e.g., the 693 stepping of the Nehemiah) claim to support
+         this function, yet return edx=0, despite the Intel test indicating
+         MMX support.
+        Therefore the features detected here are strictly added to those
+         detected by the Intel test.*/
+      /*TODO: How about earlier chips?*/
+      cpuid(0x80000001,eax,ebx,ecx,edx);
+      /*Note: As of the C7, this function returns Intel-style extended feature
+         flags, not AMD-style.
+        Currently, this only defines bits 11, 20, and 29 (0x20100800), which
+         do not conflict with any of the AMD flags we inspect.
+        For the remaining bits, Intel tells us, "Do not count on their value",
+         but VIA assures us that they will all be zero (at least on the C7 and
+         Isaiah chips).
+        In the (unlikely) event a future processor uses bits 18, 19, 30, or 31
+         (0xC0C00000) for something else, we will have to add code to detect
+         the model to decide when it is appropriate to inspect them.*/
+      flags|=oc_parse_amd_flags(edx,ecx);
+    }
+  }
+  else{
+    /*Implement me.*/
+    flags=0;
+  }
+  return flags;
+}
+#endif
diff --git a/lib/cpu.h b/lib/cpu.h
new file mode 100644 (file)
index 0000000..a43c957
--- /dev/null
+++ b/lib/cpu.h
@@ -0,0 +1,34 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+ function:
+    last mod: $Id: cpu.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#if !defined(_x86_cpu_H)
+# define _x86_cpu_H (1)
+#include "internal.h"
+
+#define OC_CPU_X86_MMX      (1<<0)
+#define OC_CPU_X86_3DNOW    (1<<1)
+#define OC_CPU_X86_3DNOWEXT (1<<2)
+#define OC_CPU_X86_MMXEXT   (1<<3)
+#define OC_CPU_X86_SSE      (1<<4)
+#define OC_CPU_X86_SSE2     (1<<5)
+#define OC_CPU_X86_PNI      (1<<6)
+#define OC_CPU_X86_SSSE3    (1<<7)
+#define OC_CPU_X86_SSE4_1   (1<<8)
+#define OC_CPU_X86_SSE4_2   (1<<9)
+#define OC_CPU_X86_SSE4A    (1<<10)
+#define OC_CPU_X86_SSE5     (1<<11)
+
+#endif
diff --git a/lib/dct.h b/lib/dct.h
new file mode 100644 (file)
index 0000000..24ba6f1
--- /dev/null
+++ b/lib/dct.h
@@ -0,0 +1,31 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: dct.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+/*Definitions shared by the forward and inverse DCT transforms.*/
+#if !defined(_dct_H)
+# define _dct_H (1)
+
+/*cos(n*pi/16) (resp. sin(m*pi/16)) scaled by 65536.*/
+#define OC_C1S7 ((ogg_int32_t)64277)
+#define OC_C2S6 ((ogg_int32_t)60547)
+#define OC_C3S5 ((ogg_int32_t)54491)
+#define OC_C4S4 ((ogg_int32_t)46341)
+#define OC_C5S3 ((ogg_int32_t)36410)
+#define OC_C6S2 ((ogg_int32_t)25080)
+#define OC_C7S1 ((ogg_int32_t)12785)
+
+#endif
diff --git a/lib/decapiwrapper.c b/lib/decapiwrapper.c
new file mode 100644 (file)
index 0000000..12ea475
--- /dev/null
@@ -0,0 +1,193 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: decapiwrapper.c 13596 2007-08-23 20:05:38Z tterribe $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include <limits.h>
+#include "apiwrapper.h"
+#include "decint.h"
+#include "theora/theoradec.h"
+
+static void th_dec_api_clear(th_api_wrapper *_api){
+  if(_api->setup)th_setup_free(_api->setup);
+  if(_api->decode)th_decode_free(_api->decode);
+  memset(_api,0,sizeof(*_api));
+}
+
+static void theora_decode_clear(theora_state *_td){
+  if(_td->i!=NULL)theora_info_clear(_td->i);
+  memset(_td,0,sizeof(*_td));
+}
+
+static int theora_decode_control(theora_state *_td,int _req,
+ void *_buf,size_t _buf_sz){
+  return th_decode_ctl(((th_api_wrapper *)_td->i->codec_setup)->decode,
+   _req,_buf,_buf_sz);
+}
+
+static ogg_int64_t theora_decode_granule_frame(theora_state *_td,
+ ogg_int64_t _gp){
+  return th_granule_frame(((th_api_wrapper *)_td->i->codec_setup)->decode,_gp);
+}
+
+static double theora_decode_granule_time(theora_state *_td,ogg_int64_t _gp){
+  return th_granule_time(((th_api_wrapper *)_td->i->codec_setup)->decode,_gp);
+}
+
+static const oc_state_dispatch_vtable OC_DEC_DISPATCH_VTBL={
+  (oc_state_clear_func)theora_decode_clear,
+  (oc_state_control_func)theora_decode_control,
+  (oc_state_granule_frame_func)theora_decode_granule_frame,
+  (oc_state_granule_time_func)theora_decode_granule_time,
+};
+
+static void th_info2theora_info(theora_info *_ci,const th_info *_info){
+  _ci->version_major=_info->version_major;
+  _ci->version_minor=_info->version_minor;
+  _ci->version_subminor=_info->version_subminor;
+  _ci->width=_info->frame_width;
+  _ci->height=_info->frame_height;
+  _ci->frame_width=_info->pic_width;
+  _ci->frame_height=_info->pic_height;
+  _ci->offset_x=_info->pic_x;
+  _ci->offset_y=_info->pic_y;
+  _ci->fps_numerator=_info->fps_numerator;
+  _ci->fps_denominator=_info->fps_denominator;
+  _ci->aspect_numerator=_info->aspect_numerator;
+  _ci->aspect_denominator=_info->aspect_denominator;
+  switch(_info->colorspace){
+    case TH_CS_ITU_REC_470M:_ci->colorspace=OC_CS_ITU_REC_470M;break;
+    case TH_CS_ITU_REC_470BG:_ci->colorspace=OC_CS_ITU_REC_470BG;break;
+    default:_ci->colorspace=OC_CS_UNSPECIFIED;break;
+  }
+  switch(_info->pixel_fmt){
+    case TH_PF_420:_ci->pixelformat=OC_PF_420;break;
+    case TH_PF_422:_ci->pixelformat=OC_PF_422;break;
+    case TH_PF_444:_ci->pixelformat=OC_PF_444;break;
+    default:_ci->pixelformat=OC_PF_RSVD;
+  }
+  _ci->target_bitrate=_info->target_bitrate;
+  _ci->quality=_info->quality;
+  _ci->keyframe_frequency_force=1<<_info->keyframe_granule_shift;
+}
+
+int theora_decode_init(theora_state *_td,theora_info *_ci){
+  th_api_info    *apiinfo;
+  th_api_wrapper *api;
+  th_info         info;
+  api=(th_api_wrapper *)_ci->codec_setup;
+  /*Allocate our own combined API wrapper/theora_info struct.
+    We put them both in one malloc'd block so that when the API wrapper is
+     freed, the info struct goes with it.
+    This avoids having to figure out whether or not we need to free the info
+     struct in either theora_info_clear() or theora_clear().*/
+  apiinfo=(th_api_info *)_ogg_calloc(1,sizeof(*apiinfo));
+  if(apiinfo==NULL)return OC_FAULT;
+  /*Make our own copy of the info struct, since its lifetime should be
+     independent of the one we were passed in.*/
+  *&apiinfo->info=*_ci;
+  /*Convert the info struct now instead of saving the the one we decoded with
+     theora_decode_header(), since the user might have modified values (i.e.,
+     color space, aspect ratio, etc. can be specified from a higher level).
+    The user also might be doing something "clever" with the header packets if
+     they are not using an Ogg encapsulation.*/
+  oc_theora_info2th_info(&info,_ci);
+  /*Don't bother to copy the setup info; th_decode_alloc() makes its own copy
+     of the stuff it needs.*/
+  apiinfo->api.decode=th_decode_alloc(&info,api->setup);
+  if(apiinfo->api.decode==NULL){
+    _ogg_free(apiinfo);
+    return OC_EINVAL;
+  }
+  apiinfo->api.clear=(oc_setup_clear_func)th_dec_api_clear;
+  _td->internal_encode=NULL;
+  /*Provide entry points for ABI compatibility with old decoder shared libs.*/
+  _td->internal_decode=(void *)&OC_DEC_DISPATCH_VTBL;
+  _td->granulepos=0;
+  _td->i=&apiinfo->info;
+  _td->i->codec_setup=&apiinfo->api;
+  return 0;
+}
+
+int theora_decode_header(theora_info *_ci,theora_comment *_cc,ogg_packet *_op){
+  th_api_wrapper *api;
+  th_info         info;
+  int             ret;
+  api=(th_api_wrapper *)_ci->codec_setup;
+  /*Allocate an API wrapper struct on demand, since it will not also include a
+     theora_info struct like the ones that are used in a theora_state struct.*/
+  if(api==NULL){
+    _ci->codec_setup=_ogg_calloc(1,sizeof(*api));
+    if(_ci->codec_setup==NULL)return OC_FAULT;
+    api=(th_api_wrapper *)_ci->codec_setup;
+    api->clear=(oc_setup_clear_func)th_dec_api_clear;
+  }
+  /*Convert from the theora_info struct instead of saving our own th_info
+     struct between calls.
+    The user might be doing something "clever" with the header packets if they
+     are not using an Ogg encapsulation, and we don't want to break this.*/
+  oc_theora_info2th_info(&info,_ci);
+  /*We rely on the fact that theora_comment and th_comment structures are
+     actually identical.
+    Take care not to change this fact unless you change the code here as
+     well!*/
+  ret=th_decode_headerin(&info,(th_comment *)_cc,&api->setup,_op);
+  /*We also rely on the fact that the error return code values are the same,
+    and that the implementations of these two functions return the same set of
+    them.
+   Note that theora_decode_header() really can return OC_NOTFORMAT, even
+    though it is not currently documented to do so.*/
+  if(ret<0)return ret;
+  th_info2theora_info(_ci,&info);
+  return 0;
+}
+
+int theora_decode_packetin(theora_state *_td,ogg_packet *_op){
+  th_api_wrapper *api;
+  ogg_int64_t     gp;
+  int             ret;
+  if(!_td||!_td->i||!_td->i->codec_setup)return OC_FAULT;
+  api=(th_api_wrapper *)_td->i->codec_setup;
+  ret=th_decode_packetin(api->decode,_op,&gp);
+  if(ret<0)return OC_BADPACKET;
+  _td->granulepos=gp;
+  return 0;
+}
+
+int theora_decode_YUVout(theora_state *_td,yuv_buffer *_yuv){
+  th_api_wrapper  *api;
+  th_dec_ctx      *decode;
+  th_ycbcr_buffer  buf;
+  int              ret;
+  if(!_td||!_td->i||!_td->i->codec_setup)return OC_FAULT;
+  api=(th_api_wrapper *)_td->i->codec_setup;
+  decode=(th_dec_ctx *)api->decode;
+  if(!decode)return OC_FAULT;
+  ret=th_decode_ycbcr_out(decode,buf);
+  if(ret>=0){
+    _yuv->y_width=buf[0].width;
+    _yuv->y_height=buf[0].height;
+    _yuv->y_stride=buf[0].stride;
+    _yuv->uv_width=buf[1].width;
+    _yuv->uv_height=buf[1].height;
+    _yuv->uv_stride=buf[1].stride;
+    _yuv->y=buf[0].data;
+    _yuv->u=buf[1].data;
+    _yuv->v=buf[2].data;
+  }
+  return ret;
+}
diff --git a/lib/decinfo.c b/lib/decinfo.c
new file mode 100644 (file)
index 0000000..845eb13
--- /dev/null
@@ -0,0 +1,246 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: decinfo.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include <limits.h>
+#include "decint.h"
+
+
+
+/*Unpacks a series of octets from a given byte array into the pack buffer.
+  No checking is done to ensure the buffer contains enough data.
+  _opb: The pack buffer to read the octets from.
+  _buf: The byte array to store the unpacked bytes in.
+  _len: The number of octets to unpack.*/
+static void oc_unpack_octets(oc_pack_buf *_opb,char *_buf,size_t _len){
+  while(_len-->0){
+    long val;
+    val=oc_pack_read(_opb,8);
+    *_buf++=(char)val;
+  }
+}
+
+/*Unpacks a 32-bit integer encoded by octets in little-endian form.*/
+static long oc_unpack_length(oc_pack_buf *_opb){
+  long ret[4];
+  int  i;
+  for(i=0;i<4;i++)ret[i]=oc_pack_read(_opb,8);
+  return ret[0]|ret[1]<<8|ret[2]<<16|ret[3]<<24;
+}
+
+static int oc_info_unpack(oc_pack_buf *_opb,th_info *_info){
+  long val;
+  /*Check the codec bitstream version.*/
+  val=oc_pack_read(_opb,8);
+  _info->version_major=(unsigned char)val;
+  val=oc_pack_read(_opb,8);
+  _info->version_minor=(unsigned char)val;
+  val=oc_pack_read(_opb,8);
+  _info->version_subminor=(unsigned char)val;
+  /*verify we can parse this bitstream version.
+     We accept earlier minors and all subminors, by spec*/
+  if(_info->version_major>TH_VERSION_MAJOR||
+   _info->version_major==TH_VERSION_MAJOR&&
+   _info->version_minor>TH_VERSION_MINOR){
+    return TH_EVERSION;
+  }
+  /*Read the encoded frame description.*/
+  val=oc_pack_read(_opb,16);
+  _info->frame_width=(ogg_uint32_t)val<<4;
+  val=oc_pack_read(_opb,16);
+  _info->frame_height=(ogg_uint32_t)val<<4;
+  val=oc_pack_read(_opb,24);
+  _info->pic_width=(ogg_uint32_t)val;
+  val=oc_pack_read(_opb,24);
+  _info->pic_height=(ogg_uint32_t)val;
+  val=oc_pack_read(_opb,8);
+  _info->pic_x=(ogg_uint32_t)val;
+  val=oc_pack_read(_opb,8);
+  _info->pic_y=(ogg_uint32_t)val;
+  val=oc_pack_read(_opb,32);
+  _info->fps_numerator=(ogg_uint32_t)val;
+  val=oc_pack_read(_opb,32);
+  _info->fps_denominator=(ogg_uint32_t)val;
+  if(_info->frame_width==0||_info->frame_height==0||
+   _info->pic_width+_info->pic_x>_info->frame_width||
+   _info->pic_height+_info->pic_y>_info->frame_height||
+   _info->fps_numerator==0||_info->fps_denominator==0){
+    return TH_EBADHEADER;
+  }
+  /*Note: The sense of pic_y is inverted in what we pass back to the
+     application compared to how it is stored in the bitstream.
+    This is because the bitstream uses a right-handed coordinate system, while
+     applications expect a left-handed one.*/
+  _info->pic_y=_info->frame_height-_info->pic_height-_info->pic_y;
+  val=oc_pack_read(_opb,24);
+  _info->aspect_numerator=(ogg_uint32_t)val;
+  val=oc_pack_read(_opb,24);
+  _info->aspect_denominator=(ogg_uint32_t)val;
+  val=oc_pack_read(_opb,8);
+  _info->colorspace=(th_colorspace)val;
+  val=oc_pack_read(_opb,24);
+  _info->target_bitrate=(int)val;
+  val=oc_pack_read(_opb,6);
+  _info->quality=(int)val;
+  val=oc_pack_read(_opb,5);
+  _info->keyframe_granule_shift=(int)val;
+  val=oc_pack_read(_opb,2);
+  _info->pixel_fmt=(th_pixel_fmt)val;
+  if(_info->pixel_fmt==TH_PF_RSVD)return TH_EBADHEADER;
+  val=oc_pack_read(_opb,3);
+  if(val!=0||oc_pack_bytes_left(_opb)<0)return TH_EBADHEADER;
+  return 0;
+}
+
+static int oc_comment_unpack(oc_pack_buf *_opb,th_comment *_tc){
+  long len;
+  int  i;
+  /*Read the vendor string.*/
+  len=oc_unpack_length(_opb);
+  if(len<0||len>oc_pack_bytes_left(_opb))return TH_EBADHEADER;
+  _tc->vendor=_ogg_malloc((size_t)len+1);
+  if(_tc->vendor==NULL)return TH_EFAULT;
+  oc_unpack_octets(_opb,_tc->vendor,len);
+  _tc->vendor[len]='\0';
+  /*Read the user comments.*/
+  _tc->comments=(int)oc_unpack_length(_opb);
+  len=_tc->comments;
+  if(len<0||len>(LONG_MAX>>2)||len<<2>oc_pack_bytes_left(_opb)){
+    _tc->comments=0;
+    return TH_EBADHEADER;
+  }
+  _tc->comment_lengths=(int *)_ogg_malloc(
+   _tc->comments*sizeof(_tc->comment_lengths[0]));
+  _tc->user_comments=(char **)_ogg_malloc(
+   _tc->comments*sizeof(_tc->user_comments[0]));
+  for(i=0;i<_tc->comments;i++){
+    len=oc_unpack_length(_opb);
+    if(len<0||len>oc_pack_bytes_left(_opb)){
+      _tc->comments=i;
+      return TH_EBADHEADER;
+    }
+    _tc->comment_lengths[i]=len;
+    _tc->user_comments[i]=_ogg_malloc((size_t)len+1);
+    if(_tc->user_comments[i]==NULL){
+      _tc->comments=i;
+      return TH_EFAULT;
+    }
+    oc_unpack_octets(_opb,_tc->user_comments[i],len);
+    _tc->user_comments[i][len]='\0';
+  }
+  return oc_pack_bytes_left(_opb)<0?TH_EBADHEADER:0;
+}
+
+static int oc_setup_unpack(oc_pack_buf *_opb,th_setup_info *_setup){
+  int ret;
+  /*Read the quantizer tables.*/
+  ret=oc_quant_params_unpack(_opb,&_setup->qinfo);
+  if(ret<0)return ret;
+  /*Read the Huffman trees.*/
+  return oc_huff_trees_unpack(_opb,_setup->huff_tables);
+}
+
+static void oc_setup_clear(th_setup_info *_setup){
+  oc_quant_params_clear(&_setup->qinfo);
+  oc_huff_trees_clear(_setup->huff_tables);
+}
+
+static int oc_dec_headerin(oc_pack_buf *_opb,th_info *_info,
+ th_comment *_tc,th_setup_info **_setup,ogg_packet *_op){
+  char buffer[6];
+  long val;
+  int  packtype;
+  int  ret;
+  val=oc_pack_read(_opb,8);
+  packtype=(int)val;
+  /*If we're at a data packet and we have received all three headers, we're
+     done.*/
+  if(!(packtype&0x80)&&_info->frame_width>0&&_tc->vendor!=NULL&&*_setup!=NULL){
+    return 0;
+  }
+  /*Check the codec string.*/
+  oc_unpack_octets(_opb,buffer,6);
+  if(memcmp(buffer,"theora",6)!=0)return TH_ENOTFORMAT;
+  switch(packtype){
+    /*Codec info header.*/
+    case 0x80:{
+      /*This should be the first packet, and we should not already be
+         initialized.*/
+      if(!_op->b_o_s||_info->frame_width>0)return TH_EBADHEADER;
+      ret=oc_info_unpack(_opb,_info);
+      if(ret<0)th_info_clear(_info);
+      else ret=3;
+    }break;
+    /*Comment header.*/
+    case 0x81:{
+      if(_tc==NULL)return TH_EFAULT;
+      /*We shoud have already decoded the info header, and should not yet have
+         decoded the comment header.*/
+      if(_info->frame_width==0||_tc->vendor!=NULL)return TH_EBADHEADER;
+      ret=oc_comment_unpack(_opb,_tc);
+      if(ret<0)th_comment_clear(_tc);
+      else ret=2;
+    }break;
+    /*Codec setup header.*/
+    case 0x82:{
+      oc_setup_info *setup;
+      if(_tc==NULL||_setup==NULL)return TH_EFAULT;
+      /*We should have already decoded the info header and the comment header,
+         and should not yet have decoded the setup header.*/
+      if(_info->frame_width==0||_tc->vendor==NULL||*_setup!=NULL){
+        return TH_EBADHEADER;
+      }
+      setup=(oc_setup_info *)_ogg_calloc(1,sizeof(*setup));
+      if(setup==NULL)return TH_EFAULT;
+      ret=oc_setup_unpack(_opb,setup);
+      if(ret<0){
+        oc_setup_clear(setup);
+        _ogg_free(setup);
+      }
+      else{
+        *_setup=setup;
+        ret=1;
+      }
+    }break;
+    default:{
+      /*We don't know what this header is.*/
+      return TH_EBADHEADER;
+    }break;
+  }
+  return ret;
+}
+
+
+/*Decodes one header packet.
+  This should be called repeatedly with the packets at the beginning of the
+   stream until it returns 0.*/
+int th_decode_headerin(th_info *_info,th_comment *_tc,
+ th_setup_info **_setup,ogg_packet *_op){
+  oc_pack_buf opb;
+  if(_op==NULL)return TH_EBADHEADER;
+  if(_info==NULL)return TH_EFAULT;
+  oc_pack_readinit(&opb,_op->packet,_op->bytes);
+  return oc_dec_headerin(&opb,_info,_tc,_setup,_op);
+}
+
+void th_setup_free(th_setup_info *_setup){
+  if(_setup!=NULL){
+    oc_setup_clear(_setup);
+    _ogg_free(_setup);
+  }
+}
diff --git a/lib/decint.h b/lib/decint.h
new file mode 100644 (file)
index 0000000..261b676
--- /dev/null
@@ -0,0 +1,107 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: decint.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <limits.h>
+#if !defined(_decint_H)
+# define _decint_H (1)
+# include "theora/theoradec.h"
+# include "internal.h"
+# include "bitpack.h"
+
+typedef struct th_setup_info oc_setup_info;
+typedef struct th_dec_ctx    oc_dec_ctx;
+
+# include "huffdec.h"
+# include "dequant.h"
+
+/*Constants for the packet-in state machine specific to the decoder.*/
+
+/*Next packet to read: Data packet.*/
+#define OC_PACKET_DATA (0)
+
+
+
+struct th_setup_info{
+  /*The Huffman codes.*/
+  oc_huff_node      *huff_tables[TH_NHUFFMAN_TABLES];
+  /*The quantization parameters.*/
+  th_quant_info  qinfo;
+};
+
+
+
+struct th_dec_ctx{
+  /*Shared encoder/decoder state.*/
+  oc_theora_state      state;
+  /*Whether or not packets are ready to be emitted.
+    This takes on negative values while there are remaining header packets to
+     be emitted, reaches 0 when the codec is ready for input, and goes to 1
+     when a frame has been processed and a data packet is ready.*/
+  int                  packet_state;
+  /*Buffer in which to assemble packets.*/
+  oc_pack_buf          opb;
+  /*Huffman decode trees.*/
+  oc_huff_node        *huff_tables[TH_NHUFFMAN_TABLES];
+  /*The index of the first token in each plane for each coefficient.*/
+  ptrdiff_t            ti0[3][64];
+  /*The number of outstanding EOB runs at the start of each coefficient in each
+     plane.*/
+  ptrdiff_t            eob_runs[3][64];
+  /*The DCT token lists.*/
+  unsigned char       *dct_tokens;
+  /*The extra bits associated with DCT tokens.*/
+  unsigned char       *extra_bits;
+  /*The number of dct tokens unpacked so far.*/
+  int                  dct_tokens_count;
+  /*The out-of-loop post-processing level.*/
+  int                  pp_level;
+  /*The DC scale used for out-of-loop deblocking.*/
+  int                  pp_dc_scale[64];
+  /*The sharpen modifier used for out-of-loop deringing.*/
+  int                  pp_sharp_mod[64];
+  /*The DC quantization index of each block.*/
+  unsigned char       *dc_qis;
+  /*The variance of each block.*/
+  int                 *variances;
+  /*The storage for the post-processed frame buffer.*/
+  unsigned char       *pp_frame_data;
+  /*Whether or not the post-processsed frame buffer has space for chroma.*/
+  int                  pp_frame_state;
+  /*The buffer used for the post-processed frame.
+    Note that this is _not_ guaranteed to have the same strides and offsets as
+     the reference frame buffers.*/
+  th_ycbcr_buffer      pp_frame_buf;
+  /*The striped decode callback function.*/
+  th_stripe_callback   stripe_cb;
+# if defined(HAVE_CAIRO)
+  /*Output metrics for debugging.*/
+  int                  telemetry;
+  int                  telemetry_mbmode;
+  int                  telemetry_mv;
+  int                  telemetry_qi;
+  int                  telemetry_bits;
+  int                  telemetry_frame_bytes;
+  int                  telemetry_coding_bytes;
+  int                  telemetry_mode_bytes;
+  int                  telemetry_mv_bytes;
+  int                  telemetry_qi_bytes;
+  int                  telemetry_dc_bytes;
+  unsigned char       *telemetry_frame_data;
+# endif
+};
+
+#endif
diff --git a/lib/decode.c b/lib/decode.c
new file mode 100644 (file)
index 0000000..7be6646
--- /dev/null
@@ -0,0 +1,2943 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: decode.c 16581 2009-09-25 22:56:16Z gmaxwell $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+#include "decint.h"
+#if defined(OC_DUMP_IMAGES)
+# include <stdio.h>
+# include "png.h"
+#endif
+#if defined(HAVE_CAIRO)
+# include <cairo.h>
+#endif
+
+
+/*No post-processing.*/
+#define OC_PP_LEVEL_DISABLED  (0)
+/*Keep track of DC qi for each block only.*/
+#define OC_PP_LEVEL_TRACKDCQI (1)
+/*Deblock the luma plane.*/
+#define OC_PP_LEVEL_DEBLOCKY  (2)
+/*Dering the luma plane.*/
+#define OC_PP_LEVEL_DERINGY   (3)
+/*Stronger luma plane deringing.*/
+#define OC_PP_LEVEL_SDERINGY  (4)
+/*Deblock the chroma planes.*/
+#define OC_PP_LEVEL_DEBLOCKC  (5)
+/*Dering the chroma planes.*/
+#define OC_PP_LEVEL_DERINGC   (6)
+/*Stronger chroma plane deringing.*/
+#define OC_PP_LEVEL_SDERINGC  (7)
+/*Maximum valid post-processing level.*/
+#define OC_PP_LEVEL_MAX       (7)
+
+
+
+/*The mode alphabets for the various mode coding schemes.
+  Scheme 0 uses a custom alphabet, which is not stored in this table.*/
+static const unsigned char OC_MODE_ALPHABETS[7][OC_NMODES]={
+  /*Last MV dominates */
+  {
+    OC_MODE_INTER_MV_LAST,OC_MODE_INTER_MV_LAST2,OC_MODE_INTER_MV,
+    OC_MODE_INTER_NOMV,OC_MODE_INTRA,OC_MODE_GOLDEN_NOMV,OC_MODE_GOLDEN_MV,
+    OC_MODE_INTER_MV_FOUR
+  },
+  {
+    OC_MODE_INTER_MV_LAST,OC_MODE_INTER_MV_LAST2,OC_MODE_INTER_NOMV,
+    OC_MODE_INTER_MV,OC_MODE_INTRA,OC_MODE_GOLDEN_NOMV,OC_MODE_GOLDEN_MV,
+    OC_MODE_INTER_MV_FOUR
+  },
+  {
+    OC_MODE_INTER_MV_LAST,OC_MODE_INTER_MV,OC_MODE_INTER_MV_LAST2,
+    OC_MODE_INTER_NOMV,OC_MODE_INTRA,OC_MODE_GOLDEN_NOMV,OC_MODE_GOLDEN_MV,
+    OC_MODE_INTER_MV_FOUR
+  },
+  {
+    OC_MODE_INTER_MV_LAST,OC_MODE_INTER_MV,OC_MODE_INTER_NOMV,
+    OC_MODE_INTER_MV_LAST2,OC_MODE_INTRA,OC_MODE_GOLDEN_NOMV,
+    OC_MODE_GOLDEN_MV,OC_MODE_INTER_MV_FOUR
+  },
+  /*No MV dominates.*/
+  {
+    OC_MODE_INTER_NOMV,OC_MODE_INTER_MV_LAST,OC_MODE_INTER_MV_LAST2,
+    OC_MODE_INTER_MV,OC_MODE_INTRA,OC_MODE_GOLDEN_NOMV,OC_MODE_GOLDEN_MV,
+    OC_MODE_INTER_MV_FOUR
+  },
+  {
+    OC_MODE_INTER_NOMV,OC_MODE_GOLDEN_NOMV,OC_MODE_INTER_MV_LAST,
+    OC_MODE_INTER_MV_LAST2,OC_MODE_INTER_MV,OC_MODE_INTRA,OC_MODE_GOLDEN_MV,
+    OC_MODE_INTER_MV_FOUR
+  },
+  /*Default ordering.*/
+  {
+    OC_MODE_INTER_NOMV,OC_MODE_INTRA,OC_MODE_INTER_MV,OC_MODE_INTER_MV_LAST,
+    OC_MODE_INTER_MV_LAST2,OC_MODE_GOLDEN_NOMV,OC_MODE_GOLDEN_MV,
+    OC_MODE_INTER_MV_FOUR
+  }
+};
+
+
+/*The original DCT tokens are extended and reordered during the construction of
+   the Huffman tables.
+  The extension means more bits can be read with fewer calls to the bitpacker
+   during the Huffman decoding process (at the cost of larger Huffman tables),
+   and fewer tokens require additional extra bits (reducing the average storage
+   per decoded token).
+  The revised ordering reveals essential information in the token value
+   itself; specifically, whether or not there are additional extra bits to read
+   and the parameter to which those extra bits are applied.
+  The token is used to fetch a code word from the OC_DCT_CODE_WORD table below.
+  The extra bits are added into code word at the bit position inferred from the
+   token value, giving the final code word from which all required parameters
+   are derived.
+  The number of EOBs and the leading zero run length can be extracted directly.
+  The coefficient magnitude is optionally negated before extraction, according
+   to a 'flip' bit.*/
+
+/*The number of additional extra bits that are decoded with each of the
+   internal DCT tokens.*/
+static const unsigned char OC_INTERNAL_DCT_TOKEN_EXTRA_BITS[15]={
+  12,4,3,3,4,4,5,5,8,8,8,8,3,3,6
+};
+
+/*Whether or not an internal token needs any additional extra bits.*/
+#define OC_DCT_TOKEN_NEEDS_MORE(token) \
+ (token<(sizeof(OC_INTERNAL_DCT_TOKEN_EXTRA_BITS)/ \
+  sizeof(*OC_INTERNAL_DCT_TOKEN_EXTRA_BITS)))
+
+/*This token (OC_DCT_REPEAT_RUN3_TOKEN) requires more than 8 extra bits.*/
+#define OC_DCT_TOKEN_FAT_EOB (0)
+
+/*The number of EOBs to use for an end-of-frame token.
+  Note: We want to set eobs to PTRDIFF_MAX here, but that requires C99, which
+   is not yet available everywhere; this should be equivalent.*/
+#define OC_DCT_EOB_FINISH (~(size_t)0>>1)
+
+/*The location of the (6) run legth bits in the code word.
+  These are placed at index 0 and given 8 bits (even though 6 would suffice)
+   because it may be faster to extract the lower byte on some platforms.*/
+#define OC_DCT_CW_RLEN_SHIFT (0)
+/*The location of the (12) EOB bits in the code word.*/
+#define OC_DCT_CW_EOB_SHIFT  (8)
+/*The location of the (1) flip bit in the code word.
+  This must be right under the magnitude bits.*/
+#define OC_DCT_CW_FLIP_BIT   (20)
+/*The location of the (11) token magnitude bits in the code word.
+  These must be last, and rely on a sign-extending right shift.*/
+#define OC_DCT_CW_MAG_SHIFT  (21)
+
+/*Pack the given fields into a code word.*/
+#define OC_DCT_CW_PACK(_eobs,_rlen,_mag,_flip) \
+ ((_eobs)<<OC_DCT_CW_EOB_SHIFT| \
+ (_rlen)<<OC_DCT_CW_RLEN_SHIFT| \
+ (_flip)<<OC_DCT_CW_FLIP_BIT| \
+ (_mag)-(_flip)<<OC_DCT_CW_MAG_SHIFT)
+
+/*A special code word value that signals the end of the frame (a long EOB run
+   of zero).*/
+#define OC_DCT_CW_FINISH (0)
+
+/*The position at which to insert the extra bits in the code word.
+  We use this formulation because Intel has no useful cmov.
+  A real architecture would probably do better with two of those.
+  This translates to 11 instructions(!), and is _still_ faster than either a
+   table lookup (just barely) or the naive double-ternary implementation (which
+   gcc translates to a jump and a cmov).
+  This assumes OC_DCT_CW_RLEN_SHIFT is zero, but could easily be reworked if
+   you want to make one of the other shifts zero.*/
+#define OC_DCT_TOKEN_EB_POS(_token) \
+ ((OC_DCT_CW_EOB_SHIFT-OC_DCT_CW_MAG_SHIFT&-((_token)<2)) \
+ +(OC_DCT_CW_MAG_SHIFT&-((_token)<12)))
+
+/*The code words for each internal token.
+  See the notes at OC_DCT_TOKEN_MAP for the reasons why things are out of
+   order.*/
+static const ogg_int32_t OC_DCT_CODE_WORD[92]={
+  /*These tokens require additional extra bits for the EOB count.*/
+  /*OC_DCT_REPEAT_RUN3_TOKEN (12 extra bits)*/
+  OC_DCT_CW_FINISH,
+  /*OC_DCT_REPEAT_RUN2_TOKEN (4 extra bits)*/
+  OC_DCT_CW_PACK(16, 0,  0,0),
+  /*These tokens require additional extra bits for the magnitude.*/
+  /*OC_DCT_VAL_CAT5 (4 extra bits-1 already read)*/
+  OC_DCT_CW_PACK( 0, 0, 13,0),
+  OC_DCT_CW_PACK( 0, 0, 13,1),
+  /*OC_DCT_VAL_CAT6 (5 extra bits-1 already read)*/
+  OC_DCT_CW_PACK( 0, 0, 21,0),
+  OC_DCT_CW_PACK( 0, 0, 21,1),
+  /*OC_DCT_VAL_CAT7 (6 extra bits-1 already read)*/
+  OC_DCT_CW_PACK( 0, 0, 37,0),
+  OC_DCT_CW_PACK( 0, 0, 37,1),
+  /*OC_DCT_VAL_CAT8 (10 extra bits-2 already read)*/
+  OC_DCT_CW_PACK( 0, 0, 69,0),
+  OC_DCT_CW_PACK( 0, 0,325,0),
+  OC_DCT_CW_PACK( 0, 0, 69,1),
+  OC_DCT_CW_PACK( 0, 0,325,1),
+  /*These tokens require additional extra bits for the run length.*/
+  /*OC_DCT_RUN_CAT1C (4 extra bits-1 already read)*/
+  OC_DCT_CW_PACK( 0,10, +1,0),
+  OC_DCT_CW_PACK( 0,10, -1,0),
+  /*OC_DCT_ZRL_TOKEN (6 extra bits)
+    Flip is set to distinguish this from OC_DCT_CW_FINISH.*/
+  OC_DCT_CW_PACK( 0, 0,  0,1),
+  /*The remaining tokens require no additional extra bits.*/
+  /*OC_DCT_EOB1_TOKEN (0 extra bits)*/
+  OC_DCT_CW_PACK( 1, 0,  0,0),
+  /*OC_DCT_EOB2_TOKEN (0 extra bits)*/
+  OC_DCT_CW_PACK( 2, 0,  0,0),
+  /*OC_DCT_EOB3_TOKEN (0 extra bits)*/
+  OC_DCT_CW_PACK( 3, 0,  0,0),
+  /*OC_DCT_RUN_CAT1A (1 extra bit-1 already read)x5*/
+  OC_DCT_CW_PACK( 0, 1, +1,0),
+  OC_DCT_CW_PACK( 0, 1, -1,0),
+  OC_DCT_CW_PACK( 0, 2, +1,0),
+  OC_DCT_CW_PACK( 0, 2, -1,0),
+  OC_DCT_CW_PACK( 0, 3, +1,0),
+  OC_DCT_CW_PACK( 0, 3, -1,0),
+  OC_DCT_CW_PACK( 0, 4, +1,0),
+  OC_DCT_CW_PACK( 0, 4, -1,0),
+  OC_DCT_CW_PACK( 0, 5, +1,0),
+  OC_DCT_CW_PACK( 0, 5, -1,0),
+  /*OC_DCT_RUN_CAT2A (2 extra bits-2 already read)*/
+  OC_DCT_CW_PACK( 0, 1, +2,0),
+  OC_DCT_CW_PACK( 0, 1, +3,0),
+  OC_DCT_CW_PACK( 0, 1, -2,0),
+  OC_DCT_CW_PACK( 0, 1, -3,0),
+  /*OC_DCT_RUN_CAT1B (3 extra bits-3 already read)*/
+  OC_DCT_CW_PACK( 0, 6, +1,0),
+  OC_DCT_CW_PACK( 0, 7, +1,0),
+  OC_DCT_CW_PACK( 0, 8, +1,0),
+  OC_DCT_CW_PACK( 0, 9, +1,0),
+  OC_DCT_CW_PACK( 0, 6, -1,0),
+  OC_DCT_CW_PACK( 0, 7, -1,0),
+  OC_DCT_CW_PACK( 0, 8, -1,0),
+  OC_DCT_CW_PACK( 0, 9, -1,0),
+  /*OC_DCT_RUN_CAT2B (3 extra bits-3 already read)*/
+  OC_DCT_CW_PACK( 0, 2, +2,0),
+  OC_DCT_CW_PACK( 0, 3, +2,0),
+  OC_DCT_CW_PACK( 0, 2, +3,0),
+  OC_DCT_CW_PACK( 0, 3, +3,0),
+  OC_DCT_CW_PACK( 0, 2, -2,0),
+  OC_DCT_CW_PACK( 0, 3, -2,0),
+  OC_DCT_CW_PACK( 0, 2, -3,0),
+  OC_DCT_CW_PACK( 0, 3, -3,0),
+  /*OC_DCT_SHORT_ZRL_TOKEN (3 extra bits-3 already read)
+    Flip is set on the first one to distinguish it from OC_DCT_CW_FINISH.*/
+  OC_DCT_CW_PACK( 0, 0,  0,1),
+  OC_DCT_CW_PACK( 0, 1,  0,0),
+  OC_DCT_CW_PACK( 0, 2,  0,0),
+  OC_DCT_CW_PACK( 0, 3,  0,0),
+  OC_DCT_CW_PACK( 0, 4,  0,0),
+  OC_DCT_CW_PACK( 0, 5,  0,0),
+  OC_DCT_CW_PACK( 0, 6,  0,0),
+  OC_DCT_CW_PACK( 0, 7,  0,0),
+  /*OC_ONE_TOKEN (0 extra bits)*/
+  OC_DCT_CW_PACK( 0, 0, +1,0),
+  /*OC_MINUS_ONE_TOKEN (0 extra bits)*/
+  OC_DCT_CW_PACK( 0, 0, -1,0),
+  /*OC_TWO_TOKEN (0 extra bits)*/
+  OC_DCT_CW_PACK( 0, 0, +2,0),
+  /*OC_MINUS_TWO_TOKEN (0 extra bits)*/
+  OC_DCT_CW_PACK( 0, 0, -2,0),
+  /*OC_DCT_VAL_CAT2 (1 extra bit-1 already read)x4*/
+  OC_DCT_CW_PACK( 0, 0, +3,0),
+  OC_DCT_CW_PACK( 0, 0, -3,0),
+  OC_DCT_CW_PACK( 0, 0, +4,0),
+  OC_DCT_CW_PACK( 0, 0, -4,0),
+  OC_DCT_CW_PACK( 0, 0, +5,0),
+  OC_DCT_CW_PACK( 0, 0, -5,0),
+  OC_DCT_CW_PACK( 0, 0, +6,0),
+  OC_DCT_CW_PACK( 0, 0, -6,0),
+  /*OC_DCT_VAL_CAT3 (2 extra bits-2 already read)*/
+  OC_DCT_CW_PACK( 0, 0, +7,0),
+  OC_DCT_CW_PACK( 0, 0, +8,0),
+  OC_DCT_CW_PACK( 0, 0, -7,0),
+  OC_DCT_CW_PACK( 0, 0, -8,0),
+  /*OC_DCT_VAL_CAT4 (3 extra bits-3 already read)*/
+  OC_DCT_CW_PACK( 0, 0, +9,0),
+  OC_DCT_CW_PACK( 0, 0,+10,0),
+  OC_DCT_CW_PACK( 0, 0,+11,0),
+  OC_DCT_CW_PACK( 0, 0,+12,0),
+  OC_DCT_CW_PACK( 0, 0, -9,0),
+  OC_DCT_CW_PACK( 0, 0,-10,0),
+  OC_DCT_CW_PACK( 0, 0,-11,0),
+  OC_DCT_CW_PACK( 0, 0,-12,0),
+  /*OC_DCT_REPEAT_RUN1_TOKEN (3 extra bits-3 already read)*/
+  OC_DCT_CW_PACK( 8, 0,  0,0),
+  OC_DCT_CW_PACK( 9, 0,  0,0),
+  OC_DCT_CW_PACK(10, 0,  0,0),
+  OC_DCT_CW_PACK(11, 0,  0,0),
+  OC_DCT_CW_PACK(12, 0,  0,0),
+  OC_DCT_CW_PACK(13, 0,  0,0),
+  OC_DCT_CW_PACK(14, 0,  0,0),
+  OC_DCT_CW_PACK(15, 0,  0,0),
+  /*OC_DCT_REPEAT_RUN0_TOKEN (2 extra bits-2 already read)*/
+  OC_DCT_CW_PACK( 4, 0,  0,0),
+  OC_DCT_CW_PACK( 5, 0,  0,0),
+  OC_DCT_CW_PACK( 6, 0,  0,0),
+  OC_DCT_CW_PACK( 7, 0,  0,0),
+};
+
+
+
+static int oc_sb_run_unpack(oc_pack_buf *_opb){
+  long bits;
+  int ret;
+  /*Coding scheme:
+       Codeword            Run Length
+     0                       1
+     10x                     2-3
+     110x                    4-5
+     1110xx                  6-9
+     11110xxx                10-17
+     111110xxxx              18-33
+     111111xxxxxxxxxxxx      34-4129*/
+  bits=oc_pack_read1(_opb);
+  if(bits==0)return 1;
+  bits=oc_pack_read(_opb,2);
+  if((bits&2)==0)return 2+(int)bits;
+  else if((bits&1)==0){
+    bits=oc_pack_read1(_opb);
+    return 4+(int)bits;
+  }
+  bits=oc_pack_read(_opb,3);
+  if((bits&4)==0)return 6+(int)bits;
+  else if((bits&2)==0){
+    ret=10+((bits&1)<<2);
+    bits=oc_pack_read(_opb,2);
+    return ret+(int)bits;
+  }
+  else if((bits&1)==0){
+    bits=oc_pack_read(_opb,4);
+    return 18+(int)bits;
+  }
+  bits=oc_pack_read(_opb,12);
+  return 34+(int)bits;
+}
+
+static int oc_block_run_unpack(oc_pack_buf *_opb){
+  long bits;
+  long bits2;
+  /*Coding scheme:
+     Codeword             Run Length
+     0x                      1-2
+     10x                     3-4
+     110x                    5-6
+     1110xx                  7-10
+     11110xx                 11-14
+     11111xxxx               15-30*/
+  bits=oc_pack_read(_opb,2);
+  if((bits&2)==0)return 1+(int)bits;
+  else if((bits&1)==0){
+    bits=oc_pack_read1(_opb);
+    return 3+(int)bits;
+  }
+  bits=oc_pack_read(_opb,2);
+  if((bits&2)==0)return 5+(int)bits;
+  else if((bits&1)==0){
+    bits=oc_pack_read(_opb,2);
+    return 7+(int)bits;
+  }
+  bits=oc_pack_read(_opb,3);
+  if((bits&4)==0)return 11+bits;
+  bits2=oc_pack_read(_opb,2);
+  return 15+((bits&3)<<2)+bits2;
+}
+
+
+
+static int oc_dec_init(oc_dec_ctx *_dec,const th_info *_info,
+ const th_setup_info *_setup){
+  int qti;
+  int pli;
+  int qi;
+  int ret;
+  ret=oc_state_init(&_dec->state,_info,3);
+  if(ret<0)return ret;
+  ret=oc_huff_trees_copy(_dec->huff_tables,
+   (const oc_huff_node *const *)_setup->huff_tables);
+  if(ret<0){
+    oc_state_clear(&_dec->state);
+    return ret;
+  }
+  /*For each fragment, allocate one byte for every DCT coefficient token, plus
+     one byte for extra-bits for each token, plus one more byte for the long
+     EOB run, just in case it's the very last token and has a run length of
+     one.*/
+  _dec->dct_tokens=(unsigned char *)_ogg_malloc((64+64+1)*
+   _dec->state.nfrags*sizeof(_dec->dct_tokens[0]));
+  if(_dec->dct_tokens==NULL){
+    oc_huff_trees_clear(_dec->huff_tables);
+    oc_state_clear(&_dec->state);
+    return TH_EFAULT;
+  }
+  for(qi=0;qi<64;qi++)for(pli=0;pli<3;pli++)for(qti=0;qti<2;qti++){
+    _dec->state.dequant_tables[qi][pli][qti]=
+     _dec->state.dequant_table_data[qi][pli][qti];
+  }
+  oc_dequant_tables_init(_dec->state.dequant_tables,_dec->pp_dc_scale,
+   &_setup->qinfo);
+  for(qi=0;qi<64;qi++){
+    int qsum;
+    qsum=0;
+    for(qti=0;qti<2;qti++)for(pli=0;pli<3;pli++){
+      qsum+=_dec->state.dequant_tables[qti][pli][qi][12]+
+       _dec->state.dequant_tables[qti][pli][qi][17]+
+       _dec->state.dequant_tables[qti][pli][qi][18]+
+       _dec->state.dequant_tables[qti][pli][qi][24]<<(pli==0);
+    }
+    _dec->pp_sharp_mod[qi]=-(qsum>>11);
+  }
+  memcpy(_dec->state.loop_filter_limits,_setup->qinfo.loop_filter_limits,
+   sizeof(_dec->state.loop_filter_limits));
+  _dec->pp_level=OC_PP_LEVEL_DISABLED;
+  _dec->dc_qis=NULL;
+  _dec->variances=NULL;
+  _dec->pp_frame_data=NULL;
+  _dec->stripe_cb.ctx=NULL;
+  _dec->stripe_cb.stripe_decoded=NULL;
+#if defined(HAVE_CAIRO)
+  _dec->telemetry=0;
+  _dec->telemetry_bits=0;
+  _dec->telemetry_qi=0;
+  _dec->telemetry_mbmode=0;
+  _dec->telemetry_mv=0;
+  _dec->telemetry_frame_data=NULL;
+#endif
+  return 0;
+}
+
+static void oc_dec_clear(oc_dec_ctx *_dec){
+#if defined(HAVE_CAIRO)
+  _ogg_free(_dec->telemetry_frame_data);
+#endif
+  _ogg_free(_dec->pp_frame_data);
+  _ogg_free(_dec->variances);
+  _ogg_free(_dec->dc_qis);
+  _ogg_free(_dec->dct_tokens);
+  oc_huff_trees_clear(_dec->huff_tables);
+  oc_state_clear(&_dec->state);
+}
+
+
+static int oc_dec_frame_header_unpack(oc_dec_ctx *_dec){
+  long val;
+  /*Check to make sure this is a data packet.*/
+  val=oc_pack_read1(&_dec->opb);
+  if(val!=0)return TH_EBADPACKET;
+  /*Read in the frame type (I or P).*/
+  val=oc_pack_read1(&_dec->opb);
+  _dec->state.frame_type=(int)val;
+  /*Read in the qi list.*/
+  val=oc_pack_read(&_dec->opb,6);
+  _dec->state.qis[0]=(unsigned char)val;
+  val=oc_pack_read1(&_dec->opb);
+  if(!val)_dec->state.nqis=1;
+  else{
+    val=oc_pack_read(&_dec->opb,6);
+    _dec->state.qis[1]=(unsigned char)val;
+    val=oc_pack_read1(&_dec->opb);
+    if(!val)_dec->state.nqis=2;
+    else{
+      val=oc_pack_read(&_dec->opb,6);
+      _dec->state.qis[2]=(unsigned char)val;
+      _dec->state.nqis=3;
+    }
+  }
+  if(_dec->state.frame_type==OC_INTRA_FRAME){
+    /*Keyframes have 3 unused configuration bits, holdovers from VP3 days.
+      Most of the other unused bits in the VP3 headers were eliminated.
+      I don't know why these remain.*/
+    /*I wanted to eliminate wasted bits, but not all config wiggle room
+       --Monty.*/
+    val=oc_pack_read(&_dec->opb,3);
+    if(val!=0)return TH_EIMPL;
+  }
+  return 0;
+}
+
+/*Mark all fragments as coded and in OC_MODE_INTRA.
+  This also builds up the coded fragment list (in coded order), and clears the
+   uncoded fragment list.
+  It does not update the coded macro block list nor the super block flags, as
+   those are not used when decoding INTRA frames.*/
+static void oc_dec_mark_all_intra(oc_dec_ctx *_dec){
+  const oc_sb_map   *sb_maps;
+  const oc_sb_flags *sb_flags;
+  oc_fragment       *frags;
+  ptrdiff_t         *coded_fragis;
+  ptrdiff_t          ncoded_fragis;
+  ptrdiff_t          prev_ncoded_fragis;
+  unsigned           nsbs;
+  unsigned           sbi;
+  int                pli;
+  coded_fragis=_dec->state.coded_fragis;
+  prev_ncoded_fragis=ncoded_fragis=0;
+  sb_maps=(const oc_sb_map *)_dec->state.sb_maps;
+  sb_flags=_dec->state.sb_flags;
+  frags=_dec->state.frags;
+  sbi=nsbs=0;
+  for(pli=0;pli<3;pli++){
+    nsbs+=_dec->state.fplanes[pli].nsbs;
+    for(;sbi<nsbs;sbi++){
+      int quadi;
+      for(quadi=0;quadi<4;quadi++)if(sb_flags[sbi].quad_valid&1<<quadi){
+        int bi;
+        for(bi=0;bi<4;bi++){
+          ptrdiff_t fragi;
+          fragi=sb_maps[sbi][quadi][bi];
+          if(fragi>=0){
+            frags[fragi].coded=1;
+            frags[fragi].mb_mode=OC_MODE_INTRA;
+            coded_fragis[ncoded_fragis++]=fragi;
+          }
+        }
+      }
+    }
+    _dec->state.ncoded_fragis[pli]=ncoded_fragis-prev_ncoded_fragis;
+    prev_ncoded_fragis=ncoded_fragis;
+  }
+  _dec->state.ntotal_coded_fragis=ncoded_fragis;
+}
+
+/*Decodes the bit flags indicating whether each super block is partially coded
+   or not.
+  Return: The number of partially coded super blocks.*/
+static unsigned oc_dec_partial_sb_flags_unpack(oc_dec_ctx *_dec){
+  oc_sb_flags *sb_flags;
+  unsigned     nsbs;
+  unsigned     sbi;
+  unsigned     npartial;
+  unsigned     run_count;
+  long         val;
+  int          flag;
+  val=oc_pack_read1(&_dec->opb);
+  flag=(int)val;
+  sb_flags=_dec->state.sb_flags;
+  nsbs=_dec->state.nsbs;
+  sbi=npartial=0;
+  while(sbi<nsbs){
+    int full_run;
+    run_count=oc_sb_run_unpack(&_dec->opb);
+    full_run=run_count>=4129;
+    do{
+      sb_flags[sbi].coded_partially=flag;
+      sb_flags[sbi].coded_fully=0;
+      npartial+=flag;
+      sbi++;
+    }
+    while(--run_count>0&&sbi<nsbs);
+    if(full_run&&sbi<nsbs){
+      val=oc_pack_read1(&_dec->opb);
+      flag=(int)val;
+    }
+    else flag=!flag;
+  }
+  /*TODO: run_count should be 0 here.
+    If it's not, we should issue a warning of some kind.*/
+  return npartial;
+}
+
+/*Decodes the bit flags for whether or not each non-partially-coded super
+   block is fully coded or not.
+  This function should only be called if there is at least one
+   non-partially-coded super block.
+  Return: The number of partially coded super blocks.*/
+static void oc_dec_coded_sb_flags_unpack(oc_dec_ctx *_dec){
+  oc_sb_flags *sb_flags;
+  unsigned     nsbs;
+  unsigned     sbi;
+  unsigned     run_count;
+  long         val;
+  int          flag;
+  sb_flags=_dec->state.sb_flags;
+  nsbs=_dec->state.nsbs;
+  /*Skip partially coded super blocks.*/
+  for(sbi=0;sb_flags[sbi].coded_partially;sbi++);
+  val=oc_pack_read1(&_dec->opb);
+  flag=(int)val;
+  do{
+    int full_run;
+    run_count=oc_sb_run_unpack(&_dec->opb);
+    full_run=run_count>=4129;
+    for(;sbi<nsbs;sbi++){
+      if(sb_flags[sbi].coded_partially)continue;
+      if(run_count--<=0)break;
+      sb_flags[sbi].coded_fully=flag;
+    }
+    if(full_run&&sbi<nsbs){
+      val=oc_pack_read1(&_dec->opb);
+      flag=(int)val;
+    }
+    else flag=!flag;
+  }
+  while(sbi<nsbs);
+  /*TODO: run_count should be 0 here.
+    If it's not, we should issue a warning of some kind.*/
+}
+
+static void oc_dec_coded_flags_unpack(oc_dec_ctx *_dec){
+  const oc_sb_map   *sb_maps;
+  const oc_sb_flags *sb_flags;
+  oc_fragment       *frags;
+  unsigned           nsbs;
+  unsigned           sbi;
+  unsigned           npartial;
+  long               val;
+  int                pli;
+  int                flag;
+  int                run_count;
+  ptrdiff_t         *coded_fragis;
+  ptrdiff_t         *uncoded_fragis;
+  ptrdiff_t          ncoded_fragis;
+  ptrdiff_t          nuncoded_fragis;
+  ptrdiff_t          prev_ncoded_fragis;
+  npartial=oc_dec_partial_sb_flags_unpack(_dec);
+  if(npartial<_dec->state.nsbs)oc_dec_coded_sb_flags_unpack(_dec);
+  if(npartial>0){
+    val=oc_pack_read1(&_dec->opb);
+    flag=!(int)val;
+  }
+  else flag=0;
+  sb_maps=(const oc_sb_map *)_dec->state.sb_maps;
+  sb_flags=_dec->state.sb_flags;
+  frags=_dec->state.frags;
+  sbi=nsbs=run_count=0;
+  coded_fragis=_dec->state.coded_fragis;
+  uncoded_fragis=coded_fragis+_dec->state.nfrags;
+  prev_ncoded_fragis=ncoded_fragis=nuncoded_fragis=0;
+  for(pli=0;pli<3;pli++){
+    nsbs+=_dec->state.fplanes[pli].nsbs;
+    for(;sbi<nsbs;sbi++){
+      int quadi;
+      for(quadi=0;quadi<4;quadi++)if(sb_flags[sbi].quad_valid&1<<quadi){
+        int bi;
+        for(bi=0;bi<4;bi++){
+          ptrdiff_t fragi;
+          fragi=sb_maps[sbi][quadi][bi];
+          if(fragi>=0){
+            int coded;
+            if(sb_flags[sbi].coded_fully)coded=1;
+            else if(!sb_flags[sbi].coded_partially)coded=0;
+            else{
+              if(run_count<=0){
+                run_count=oc_block_run_unpack(&_dec->opb);
+                flag=!flag;
+              }
+              run_count--;
+              coded=flag;
+            }
+            if(coded)coded_fragis[ncoded_fragis++]=fragi;
+            else *(uncoded_fragis-++nuncoded_fragis)=fragi;
+            frags[fragi].coded=coded;
+          }
+        }
+      }
+    }
+    _dec->state.ncoded_fragis[pli]=ncoded_fragis-prev_ncoded_fragis;
+    prev_ncoded_fragis=ncoded_fragis;
+  }
+  _dec->state.ntotal_coded_fragis=ncoded_fragis;
+  /*TODO: run_count should be 0 here.
+    If it's not, we should issue a warning of some kind.*/
+}
+
+
+
+typedef int (*oc_mode_unpack_func)(oc_pack_buf *_opb);
+
+static int oc_vlc_mode_unpack(oc_pack_buf *_opb){
+  long val;
+  int  i;
+  for(i=0;i<7;i++){
+    val=oc_pack_read1(_opb);
+    if(!val)break;
+  }
+  return i;
+}
+
+static int oc_clc_mode_unpack(oc_pack_buf *_opb){
+  long val;
+  val=oc_pack_read(_opb,3);
+  return (int)val;
+}
+
+/*Unpacks the list of macro block modes for INTER frames.*/
+static void oc_dec_mb_modes_unpack(oc_dec_ctx *_dec){
+  const oc_mb_map     *mb_maps;
+  signed char         *mb_modes;
+  const oc_fragment   *frags;
+  const unsigned char *alphabet;
+  unsigned char        scheme0_alphabet[8];
+  oc_mode_unpack_func  mode_unpack;
+  size_t               nmbs;
+  size_t               mbi;
+  long                 val;
+  int                  mode_scheme;
+  val=oc_pack_read(&_dec->opb,3);
+  mode_scheme=(int)val;
+  if(mode_scheme==0){
+    int mi;
+    /*Just in case, initialize the modes to something.
+      If the bitstream doesn't contain each index exactly once, it's likely
+       corrupt and the rest of the packet is garbage anyway, but this way we
+       won't crash, and we'll decode SOMETHING.*/
+    /*LOOP VECTORIZES*/
+    for(mi=0;mi<OC_NMODES;mi++)scheme0_alphabet[mi]=OC_MODE_INTER_NOMV;
+    for(mi=0;mi<OC_NMODES;mi++){
+      val=oc_pack_read(&_dec->opb,3);
+      scheme0_alphabet[val]=OC_MODE_ALPHABETS[6][mi];
+    }
+    alphabet=scheme0_alphabet;
+  }
+  else alphabet=OC_MODE_ALPHABETS[mode_scheme-1];
+  if(mode_scheme==7)mode_unpack=oc_clc_mode_unpack;
+  else mode_unpack=oc_vlc_mode_unpack;
+  mb_modes=_dec->state.mb_modes;
+  mb_maps=(const oc_mb_map *)_dec->state.mb_maps;
+  nmbs=_dec->state.nmbs;
+  frags=_dec->state.frags;
+  for(mbi=0;mbi<nmbs;mbi++){
+    if(mb_modes[mbi]!=OC_MODE_INVALID){
+      int bi;
+      /*Check for a coded luma block in this macro block.*/
+      for(bi=0;bi<4&&!frags[mb_maps[mbi][0][bi]].coded;bi++);
+      /*We found one, decode a mode.*/
+      if(bi<4)mb_modes[mbi]=alphabet[(*mode_unpack)(&_dec->opb)];
+      /*There were none: INTER_NOMV is forced.*/
+      else mb_modes[mbi]=OC_MODE_INTER_NOMV;
+    }
+  }
+}
+
+
+
+typedef int (*oc_mv_comp_unpack_func)(oc_pack_buf *_opb);
+
+static int oc_vlc_mv_comp_unpack(oc_pack_buf *_opb){
+  long bits;
+  int  mask;
+  int  mv;
+  bits=oc_pack_read(_opb,3);
+  switch(bits){
+    case  0:return 0;
+    case  1:return 1;
+    case  2:return -1;
+    case  3:
+    case  4:{
+      mv=(int)(bits-1);
+      bits=oc_pack_read1(_opb);
+    }break;
+    /*case  5:
+    case  6:
+    case  7:*/
+    default:{
+      mv=1<<bits-3;
+      bits=oc_pack_read(_opb,bits-2);
+      mv+=(int)(bits>>1);
+      bits&=1;
+    }break;
+  }
+  mask=-(int)bits;
+  return mv+mask^mask;
+}
+
+static int oc_clc_mv_comp_unpack(oc_pack_buf *_opb){
+  long bits;
+  int  mask;
+  int  mv;
+  bits=oc_pack_read(_opb,6);
+  mv=(int)bits>>1;
+  mask=-((int)bits&1);
+  return mv+mask^mask;
+}
+
+/*Unpacks the list of motion vectors for INTER frames, and propagtes the macro
+   block modes and motion vectors to the individual fragments.*/
+static void oc_dec_mv_unpack_and_frag_modes_fill(oc_dec_ctx *_dec){
+  const oc_mb_map        *mb_maps;
+  const signed char      *mb_modes;
+  oc_set_chroma_mvs_func  set_chroma_mvs;
+  oc_mv_comp_unpack_func  mv_comp_unpack;
+  oc_fragment            *frags;
+  oc_mv                  *frag_mvs;
+  const unsigned char    *map_idxs;
+  int                     map_nidxs;
+  oc_mv                   last_mv[2];
+  oc_mv                   cbmvs[4];
+  size_t                  nmbs;
+  size_t                  mbi;
+  long                    val;
+  set_chroma_mvs=OC_SET_CHROMA_MVS_TABLE[_dec->state.info.pixel_fmt];
+  val=oc_pack_read1(&_dec->opb);
+  mv_comp_unpack=val?oc_clc_mv_comp_unpack:oc_vlc_mv_comp_unpack;
+  map_idxs=OC_MB_MAP_IDXS[_dec->state.info.pixel_fmt];
+  map_nidxs=OC_MB_MAP_NIDXS[_dec->state.info.pixel_fmt];
+  memset(last_mv,0,sizeof(last_mv));
+  frags=_dec->state.frags;
+  frag_mvs=_dec->state.frag_mvs;
+  mb_maps=(const oc_mb_map *)_dec->state.mb_maps;
+  mb_modes=_dec->state.mb_modes;
+  nmbs=_dec->state.nmbs;
+  for(mbi=0;mbi<nmbs;mbi++){
+    int          mb_mode;
+    mb_mode=mb_modes[mbi];
+    if(mb_mode!=OC_MODE_INVALID){
+      oc_mv        mbmv;
+      ptrdiff_t    fragi;
+      int          coded[13];
+      int          codedi;
+      int          ncoded;
+      int          mapi;
+      int          mapii;
+      /*Search for at least one coded fragment.*/
+      ncoded=mapii=0;
+      do{
+        mapi=map_idxs[mapii];
+        fragi=mb_maps[mbi][mapi>>2][mapi&3];
+        if(frags[fragi].coded)coded[ncoded++]=mapi;
+      }
+      while(++mapii<map_nidxs);
+      if(ncoded<=0)continue;
+      switch(mb_mode){
+        case OC_MODE_INTER_MV_FOUR:{
+          oc_mv       lbmvs[4];
+          int         bi;
+          /*Mark the tail of the list, so we don't accidentally go past it.*/
+          coded[ncoded]=-1;
+          for(bi=codedi=0;bi<4;bi++){
+            if(coded[codedi]==bi){
+              codedi++;
+              fragi=mb_maps[mbi][0][bi];
+              frags[fragi].mb_mode=mb_mode;
+              lbmvs[bi][0]=(signed char)(*mv_comp_unpack)(&_dec->opb);
+              lbmvs[bi][1]=(signed char)(*mv_comp_unpack)(&_dec->opb);
+              memcpy(frag_mvs[fragi],lbmvs[bi],sizeof(lbmvs[bi]));
+            }
+            else lbmvs[bi][0]=lbmvs[bi][1]=0;
+          }
+          if(codedi>0){
+            memcpy(last_mv[1],last_mv[0],sizeof(last_mv[1]));
+            memcpy(last_mv[0],lbmvs[coded[codedi-1]],sizeof(last_mv[0]));
+          }
+          if(codedi<ncoded){
+            (*set_chroma_mvs)(cbmvs,(const oc_mv *)lbmvs);
+            for(;codedi<ncoded;codedi++){
+              mapi=coded[codedi];
+              bi=mapi&3;
+              fragi=mb_maps[mbi][mapi>>2][bi];
+              frags[fragi].mb_mode=mb_mode;
+              memcpy(frag_mvs[fragi],cbmvs[bi],sizeof(cbmvs[bi]));
+            }
+          }
+        }break;
+        case OC_MODE_INTER_MV:{
+          memcpy(last_mv[1],last_mv[0],sizeof(last_mv[1]));
+          mbmv[0]=last_mv[0][0]=(signed char)(*mv_comp_unpack)(&_dec->opb);
+          mbmv[1]=last_mv[0][1]=(signed char)(*mv_comp_unpack)(&_dec->opb);
+        }break;
+        case OC_MODE_INTER_MV_LAST:memcpy(mbmv,last_mv[0],sizeof(mbmv));break;
+        case OC_MODE_INTER_MV_LAST2:{
+          memcpy(mbmv,last_mv[1],sizeof(mbmv));
+          memcpy(last_mv[1],last_mv[0],sizeof(last_mv[1]));
+          memcpy(last_mv[0],mbmv,sizeof(last_mv[0]));
+        }break;
+        case OC_MODE_GOLDEN_MV:{
+          mbmv[0]=(signed char)(*mv_comp_unpack)(&_dec->opb);
+          mbmv[1]=(signed char)(*mv_comp_unpack)(&_dec->opb);
+        }break;
+        default:memset(mbmv,0,sizeof(mbmv));break;
+      }
+      /*4MV mode fills in the fragments itself.
+        For all other modes we can use this common code.*/
+      if(mb_mode!=OC_MODE_INTER_MV_FOUR){
+        for(codedi=0;codedi<ncoded;codedi++){
+          mapi=coded[codedi];
+          fragi=mb_maps[mbi][mapi>>2][mapi&3];
+          frags[fragi].mb_mode=mb_mode;
+          memcpy(frag_mvs[fragi],mbmv,sizeof(mbmv));
+        }
+      }
+    }
+  }
+}
+
+static void oc_dec_block_qis_unpack(oc_dec_ctx *_dec){
+  oc_fragment     *frags;
+  const ptrdiff_t *coded_fragis;
+  ptrdiff_t        ncoded_fragis;
+  ptrdiff_t        fragii;
+  ptrdiff_t        fragi;
+  ncoded_fragis=_dec->state.ntotal_coded_fragis;
+  if(ncoded_fragis<=0)return;
+  frags=_dec->state.frags;
+  coded_fragis=_dec->state.coded_fragis;
+  if(_dec->state.nqis==1){
+    /*If this frame has only a single qi value, then just use it for all coded
+       fragments.*/
+    for(fragii=0;fragii<ncoded_fragis;fragii++){
+      frags[coded_fragis[fragii]].qii=0;
+    }
+  }
+  else{
+    long val;
+    int  flag;
+    int  nqi1;
+    int  run_count;
+    /*Otherwise, we decode a qi index for each fragment, using two passes of
+      the same binary RLE scheme used for super-block coded bits.
+     The first pass marks each fragment as having a qii of 0 or greater than
+      0, and the second pass (if necessary), distinguishes between a qii of
+      1 and 2.
+     At first we just store the qii in the fragment.
+     After all the qii's are decoded, we make a final pass to replace them
+      with the corresponding qi's for this frame.*/
+    val=oc_pack_read1(&_dec->opb);
+    flag=(int)val;
+    nqi1=0;
+    fragii=0;
+    while(fragii<ncoded_fragis){
+      int full_run;
+      run_count=oc_sb_run_unpack(&_dec->opb);
+      full_run=run_count>=4129;
+      do{
+        frags[coded_fragis[fragii++]].qii=flag;
+        nqi1+=flag;
+      }
+      while(--run_count>0&&fragii<ncoded_fragis);
+      if(full_run&&fragii<ncoded_fragis){
+        val=oc_pack_read1(&_dec->opb);
+        flag=(int)val;
+      }
+      else flag=!flag;
+    }
+    /*TODO: run_count should be 0 here.
+      If it's not, we should issue a warning of some kind.*/
+    /*If we have 3 different qi's for this frame, and there was at least one
+       fragment with a non-zero qi, make the second pass.*/
+    if(_dec->state.nqis==3&&nqi1>0){
+      /*Skip qii==0 fragments.*/
+      for(fragii=0;frags[coded_fragis[fragii]].qii==0;fragii++);
+      val=oc_pack_read1(&_dec->opb);
+      flag=(int)val;
+      do{
+        int full_run;
+        run_count=oc_sb_run_unpack(&_dec->opb);
+        full_run=run_count>=4129;
+        for(;fragii<ncoded_fragis;fragii++){
+          fragi=coded_fragis[fragii];
+          if(frags[fragi].qii==0)continue;
+          if(run_count--<=0)break;
+          frags[fragi].qii+=flag;
+        }
+        if(full_run&&fragii<ncoded_fragis){
+          val=oc_pack_read1(&_dec->opb);
+          flag=(int)val;
+        }
+        else flag=!flag;
+      }
+      while(fragii<ncoded_fragis);
+      /*TODO: run_count should be 0 here.
+        If it's not, we should issue a warning of some kind.*/
+    }
+  }
+}
+
+
+
+/*Unpacks the DC coefficient tokens.
+  Unlike when unpacking the AC coefficient tokens, we actually need to decode
+   the DC coefficient values now so that we can do DC prediction.
+  _huff_idx:   The index of the Huffman table to use for each color plane.
+  _ntoks_left: The number of tokens left to be decoded in each color plane for
+                each coefficient.
+               This is updated as EOB tokens and zero run tokens are decoded.
+  Return: The length of any outstanding EOB run.*/
+static ptrdiff_t oc_dec_dc_coeff_unpack(oc_dec_ctx *_dec,int _huff_idxs[2],
+ ptrdiff_t _ntoks_left[3][64]){
+  unsigned char   *dct_tokens;
+  oc_fragment     *frags;
+  const ptrdiff_t *coded_fragis;
+  ptrdiff_t        ncoded_fragis;
+  ptrdiff_t        fragii;
+  ptrdiff_t        eobs;
+  ptrdiff_t        ti;
+  int              pli;
+  dct_tokens=_dec->dct_tokens;
+  frags=_dec->state.frags;
+  coded_fragis=_dec->state.coded_fragis;
+  ncoded_fragis=fragii=eobs=ti=0;
+  for(pli=0;pli<3;pli++){
+    ptrdiff_t run_counts[64];
+    ptrdiff_t eob_count;
+    ptrdiff_t eobi;
+    int       rli;
+    ncoded_fragis+=_dec->state.ncoded_fragis[pli];
+    memset(run_counts,0,sizeof(run_counts));
+    _dec->eob_runs[pli][0]=eobs;
+    _dec->ti0[pli][0]=ti;
+    /*Continue any previous EOB run, if there was one.*/
+    eobi=eobs;
+    if(ncoded_fragis-fragii<eobi)eobi=ncoded_fragis-fragii;
+    eob_count=eobi;
+    eobs-=eobi;
+    while(eobi-->0)frags[coded_fragis[fragii++]].dc=0;
+    while(fragii<ncoded_fragis){
+      int token;
+      int cw;
+      int eb;
+      int skip;
+      token=oc_huff_token_decode(&_dec->opb,
+       _dec->huff_tables[_huff_idxs[pli+1>>1]]);
+      dct_tokens[ti++]=(unsigned char)token;
+      if(OC_DCT_TOKEN_NEEDS_MORE(token)){
+        eb=(int)oc_pack_read(&_dec->opb,
+         OC_INTERNAL_DCT_TOKEN_EXTRA_BITS[token]);
+        dct_tokens[ti++]=(unsigned char)eb;
+        if(token==OC_DCT_TOKEN_FAT_EOB)dct_tokens[ti++]=(unsigned char)(eb>>8);
+        eb<<=OC_DCT_TOKEN_EB_POS(token);
+      }
+      else eb=0;
+      cw=OC_DCT_CODE_WORD[token]+eb;
+      eobs=cw>>OC_DCT_CW_EOB_SHIFT&0xFFF;
+      if(cw==OC_DCT_CW_FINISH)eobs=OC_DCT_EOB_FINISH;
+      if(eobs){
+        eobi=OC_MINI(eobs,ncoded_fragis-fragii);
+        eob_count+=eobi;
+        eobs-=eobi;
+        while(eobi-->0)frags[coded_fragis[fragii++]].dc=0;
+      }
+      else{
+        int coeff;
+        skip=(unsigned char)(cw>>OC_DCT_CW_RLEN_SHIFT);
+        cw^=-(cw&1<<OC_DCT_CW_FLIP_BIT);
+        coeff=cw>>OC_DCT_CW_MAG_SHIFT;
+        if(skip)coeff=0;
+        run_counts[skip]++;
+        frags[coded_fragis[fragii++]].dc=coeff;
+      }
+    }
+    /*Add the total EOB count to the longest run length.*/
+    run_counts[63]+=eob_count;
+    /*And convert the run_counts array to a moment table.*/
+    for(rli=63;rli-->0;)run_counts[rli]+=run_counts[rli+1];
+    /*Finally, subtract off the number of coefficients that have been
+       accounted for by runs started in this coefficient.*/
+    for(rli=64;rli-->0;)_ntoks_left[pli][rli]-=run_counts[rli];
+  }
+  _dec->dct_tokens_count=ti;
+  return eobs;
+}
+
+/*Unpacks the AC coefficient tokens.
+  This can completely discard coefficient values while unpacking, and so is
+   somewhat simpler than unpacking the DC coefficient tokens.
+  _huff_idx:   The index of the Huffman table to use for each color plane.
+  _ntoks_left: The number of tokens left to be decoded in each color plane for
+                each coefficient.
+               This is updated as EOB tokens and zero run tokens are decoded.
+  _eobs:       The length of any outstanding EOB run from previous
+                coefficients.
+  Return: The length of any outstanding EOB run.*/
+static int oc_dec_ac_coeff_unpack(oc_dec_ctx *_dec,int _zzi,int _huff_idxs[2],
+ ptrdiff_t _ntoks_left[3][64],ptrdiff_t _eobs){
+  unsigned char *dct_tokens;
+  ptrdiff_t      ti;
+  int            pli;
+  dct_tokens=_dec->dct_tokens;
+  ti=_dec->dct_tokens_count;
+  for(pli=0;pli<3;pli++){
+    ptrdiff_t run_counts[64];
+    ptrdiff_t eob_count;
+    size_t    ntoks_left;
+    size_t    ntoks;
+    int       rli;
+    _dec->eob_runs[pli][_zzi]=_eobs;
+    _dec->ti0[pli][_zzi]=ti;
+    ntoks_left=_ntoks_left[pli][_zzi];
+    memset(run_counts,0,sizeof(run_counts));
+    eob_count=0;
+    ntoks=0;
+    while(ntoks+_eobs<ntoks_left){
+      int token;
+      int cw;
+      int eb;
+      int skip;
+      ntoks+=_eobs;
+      eob_count+=_eobs;
+      token=oc_huff_token_decode(&_dec->opb,
+       _dec->huff_tables[_huff_idxs[pli+1>>1]]);
+      dct_tokens[ti++]=(unsigned char)token;
+      if(OC_DCT_TOKEN_NEEDS_MORE(token)){
+        eb=(int)oc_pack_read(&_dec->opb,
+         OC_INTERNAL_DCT_TOKEN_EXTRA_BITS[token]);
+        dct_tokens[ti++]=(unsigned char)eb;
+        if(token==OC_DCT_TOKEN_FAT_EOB)dct_tokens[ti++]=(unsigned char)(eb>>8);
+        eb<<=OC_DCT_TOKEN_EB_POS(token);
+      }
+      else eb=0;
+      cw=OC_DCT_CODE_WORD[token]+eb;
+      skip=(unsigned char)(cw>>OC_DCT_CW_RLEN_SHIFT);
+      _eobs=cw>>OC_DCT_CW_EOB_SHIFT&0xFFF;
+      if(cw==OC_DCT_CW_FINISH)_eobs=OC_DCT_EOB_FINISH;
+      if(_eobs==0){
+        run_counts[skip]++;
+        ntoks++;
+      }
+    }
+    /*Add the portion of the last EOB run actually used by this coefficient.*/
+    eob_count+=ntoks_left-ntoks;
+    /*And remove it from the remaining EOB count.*/
+    _eobs-=ntoks_left-ntoks;
+    /*Add the total EOB count to the longest run length.*/
+    run_counts[63]+=eob_count;
+    /*And convert the run_counts array to a moment table.*/
+    for(rli=63;rli-->0;)run_counts[rli]+=run_counts[rli+1];
+    /*Finally, subtract off the number of coefficients that have been
+       accounted for by runs started in this coefficient.*/
+    for(rli=64-_zzi;rli-->0;)_ntoks_left[pli][_zzi+rli]-=run_counts[rli];
+  }
+  _dec->dct_tokens_count=ti;
+  return _eobs;
+}
+
+/*Tokens describing the DCT coefficients that belong to each fragment are
+   stored in the bitstream grouped by coefficient, not by fragment.
+
+  This means that we either decode all the tokens in order, building up a
+   separate coefficient list for each fragment as we go, and then go back and
+   do the iDCT on each fragment, or we have to create separate lists of tokens
+   for each coefficient, so that we can pull the next token required off the
+   head of the appropriate list when decoding a specific fragment.
+
+  The former was VP3's choice, and it meant 2*w*h extra storage for all the
+   decoded coefficient values.
+
+  We take the second option, which lets us store just one to three bytes per
+   token (generally far fewer than the number of coefficients, due to EOB
+   tokens and zero runs), and which requires us to only maintain a counter for
+   each of the 64 coefficients, instead of a counter for every fragment to
+   determine where the next token goes.
+
+  We actually use 3 counters per coefficient, one for each color plane, so we
+   can decode all color planes simultaneously.
+  This lets color conversion, etc., be done as soon as a full MCU (one or
+   two super block rows) is decoded, while the image data is still in cache.*/
+
+static void oc_dec_residual_tokens_unpack(oc_dec_ctx *_dec){
+  static const unsigned char OC_HUFF_LIST_MAX[5]={1,6,15,28,64};
+  ptrdiff_t  ntoks_left[3][64];
+  int        huff_idxs[2];
+  ptrdiff_t  eobs;
+  long       val;
+  int        pli;
+  int        zzi;
+  int        hgi;
+  for(pli=0;pli<3;pli++)for(zzi=0;zzi<64;zzi++){
+    ntoks_left[pli][zzi]=_dec->state.ncoded_fragis[pli];
+  }
+  val=oc_pack_read(&_dec->opb,4);
+  huff_idxs[0]=(int)val;
+  val=oc_pack_read(&_dec->opb,4);
+  huff_idxs[1]=(int)val;
+  _dec->eob_runs[0][0]=0;
+  eobs=oc_dec_dc_coeff_unpack(_dec,huff_idxs,ntoks_left);
+#if defined(HAVE_CAIRO)
+  _dec->telemetry_dc_bytes=oc_pack_bytes_left(&_dec->opb);
+#endif
+  val=oc_pack_read(&_dec->opb,4);
+  huff_idxs[0]=(int)val;
+  val=oc_pack_read(&_dec->opb,4);
+  huff_idxs[1]=(int)val;
+  zzi=1;
+  for(hgi=1;hgi<5;hgi++){
+    huff_idxs[0]+=16;
+    huff_idxs[1]+=16;
+    for(;zzi<OC_HUFF_LIST_MAX[hgi];zzi++){
+      eobs=oc_dec_ac_coeff_unpack(_dec,zzi,huff_idxs,ntoks_left,eobs);
+    }
+  }
+  /*TODO: eobs should be exactly zero, or 4096 or greater.
+    The second case occurs when an EOB run of size zero is encountered, which
+     gets treated as an infinite EOB run (where infinity is PTRDIFF_MAX).
+    If neither of these conditions holds, then a warning should be issued.*/
+}
+
+
+static int oc_dec_postprocess_init(oc_dec_ctx *_dec){
+  /*pp_level 0: disabled; free any memory used and return*/
+  if(_dec->pp_level<=OC_PP_LEVEL_DISABLED){
+    if(_dec->dc_qis!=NULL){
+      _ogg_free(_dec->dc_qis);
+      _dec->dc_qis=NULL;
+      _ogg_free(_dec->variances);
+      _dec->variances=NULL;
+      _ogg_free(_dec->pp_frame_data);
+      _dec->pp_frame_data=NULL;
+    }
+    return 1;
+  }
+  if(_dec->dc_qis==NULL){
+    /*If we haven't been tracking DC quantization indices, there's no point in
+       starting now.*/
+    if(_dec->state.frame_type!=OC_INTRA_FRAME)return 1;
+    _dec->dc_qis=(unsigned char *)_ogg_malloc(
+     _dec->state.nfrags*sizeof(_dec->dc_qis[0]));
+    if(_dec->dc_qis==NULL)return 1;
+    memset(_dec->dc_qis,_dec->state.qis[0],_dec->state.nfrags);
+  }
+  else{
+    unsigned char   *dc_qis;
+    const ptrdiff_t *coded_fragis;
+    ptrdiff_t        ncoded_fragis;
+    ptrdiff_t        fragii;
+    unsigned char    qi0;
+    /*Update the DC quantization index of each coded block.*/
+    dc_qis=_dec->dc_qis;
+    coded_fragis=_dec->state.coded_fragis;
+    ncoded_fragis=_dec->state.ncoded_fragis[0]+
+     _dec->state.ncoded_fragis[1]+_dec->state.ncoded_fragis[2];
+    qi0=(unsigned char)_dec->state.qis[0];
+    for(fragii=0;fragii<ncoded_fragis;fragii++){
+      dc_qis[coded_fragis[fragii]]=qi0;
+    }
+  }
+  /*pp_level 1: Stop after updating DC quantization indices.*/
+  if(_dec->pp_level<=OC_PP_LEVEL_TRACKDCQI){
+    if(_dec->variances!=NULL){
+      _ogg_free(_dec->variances);
+      _dec->variances=NULL;
+      _ogg_free(_dec->pp_frame_data);
+      _dec->pp_frame_data=NULL;
+    }
+    return 1;
+  }
+  if(_dec->variances==NULL){
+    size_t frame_sz;
+    size_t c_sz;
+    int    c_w;
+    int    c_h;
+    frame_sz=_dec->state.info.frame_width*(size_t)_dec->state.info.frame_height;
+    c_w=_dec->state.info.frame_width>>!(_dec->state.info.pixel_fmt&1);
+    c_h=_dec->state.info.frame_height>>!(_dec->state.info.pixel_fmt&2);
+    c_sz=c_w*(size_t)c_h;
+    /*Allocate space for the chroma planes, even if we're not going to use
+       them; this simplifies allocation state management, though it may waste
+       memory on the few systems that don't overcommit pages.*/
+    frame_sz+=c_sz<<1;
+    _dec->pp_frame_data=(unsigned char *)_ogg_malloc(
+     frame_sz*sizeof(_dec->pp_frame_data[0]));
+    _dec->variances=(int *)_ogg_malloc(
+     _dec->state.nfrags*sizeof(_dec->variances[0]));
+    if(_dec->variances==NULL||_dec->pp_frame_data==NULL){
+      _ogg_free(_dec->pp_frame_data);
+      _dec->pp_frame_data=NULL;
+      _ogg_free(_dec->variances);
+      _dec->variances=NULL;
+      return 1;
+    }
+    /*Force an update of the PP buffer pointers.*/
+    _dec->pp_frame_state=0;
+  }
+  /*Update the PP buffer pointers if necessary.*/
+  if(_dec->pp_frame_state!=1+(_dec->pp_level>=OC_PP_LEVEL_DEBLOCKC)){
+    if(_dec->pp_level<OC_PP_LEVEL_DEBLOCKC){
+      /*If chroma processing is disabled, just use the PP luma plane.*/
+      _dec->pp_frame_buf[0].width=_dec->state.info.frame_width;
+      _dec->pp_frame_buf[0].height=_dec->state.info.frame_height;
+      _dec->pp_frame_buf[0].stride=-_dec->pp_frame_buf[0].width;
+      _dec->pp_frame_buf[0].data=_dec->pp_frame_data+
+       (1-_dec->pp_frame_buf[0].height)*(ptrdiff_t)_dec->pp_frame_buf[0].stride;
+    }
+    else{
+      size_t y_sz;
+      size_t c_sz;
+      int    c_w;
+      int    c_h;
+      /*Otherwise, set up pointers to all three PP planes.*/
+      y_sz=_dec->state.info.frame_width*(size_t)_dec->state.info.frame_height;
+      c_w=_dec->state.info.frame_width>>!(_dec->state.info.pixel_fmt&1);
+      c_h=_dec->state.info.frame_height>>!(_dec->state.info.pixel_fmt&2);
+      c_sz=c_w*(size_t)c_h;
+      _dec->pp_frame_buf[0].width=_dec->state.info.frame_width;
+      _dec->pp_frame_buf[0].height=_dec->state.info.frame_height;
+      _dec->pp_frame_buf[0].stride=_dec->pp_frame_buf[0].width;
+      _dec->pp_frame_buf[0].data=_dec->pp_frame_data;
+      _dec->pp_frame_buf[1].width=c_w;
+      _dec->pp_frame_buf[1].height=c_h;
+      _dec->pp_frame_buf[1].stride=_dec->pp_frame_buf[1].width;
+      _dec->pp_frame_buf[1].data=_dec->pp_frame_buf[0].data+y_sz;
+      _dec->pp_frame_buf[2].width=c_w;
+      _dec->pp_frame_buf[2].height=c_h;
+      _dec->pp_frame_buf[2].stride=_dec->pp_frame_buf[2].width;
+      _dec->pp_frame_buf[2].data=_dec->pp_frame_buf[1].data+c_sz;
+      oc_ycbcr_buffer_flip(_dec->pp_frame_buf,_dec->pp_frame_buf);
+    }
+    _dec->pp_frame_state=1+(_dec->pp_level>=OC_PP_LEVEL_DEBLOCKC);
+  }
+  /*If we're not processing chroma, copy the reference frame's chroma planes.*/
+  if(_dec->pp_level<OC_PP_LEVEL_DEBLOCKC){
+    memcpy(_dec->pp_frame_buf+1,
+     _dec->state.ref_frame_bufs[_dec->state.ref_frame_idx[OC_FRAME_SELF]]+1,
+     sizeof(_dec->pp_frame_buf[1])*2);
+  }
+  return 0;
+}
+
+
+
+typedef struct{
+  int                 bounding_values[256];
+  ptrdiff_t           ti[3][64];
+  ptrdiff_t           eob_runs[3][64];
+  const ptrdiff_t    *coded_fragis[3];
+  const ptrdiff_t    *uncoded_fragis[3];
+  ptrdiff_t           ncoded_fragis[3];
+  ptrdiff_t           nuncoded_fragis[3];
+  const ogg_uint16_t *dequant[3][3][2];
+  int                 fragy0[3];
+  int                 fragy_end[3];
+  int                 pred_last[3][3];
+  int                 mcu_nvfrags;
+  int                 loop_filter;
+  int                 pp_level;
+}oc_dec_pipeline_state;
+
+
+
+/*Initialize the main decoding pipeline.*/
+static void oc_dec_pipeline_init(oc_dec_ctx *_dec,
+ oc_dec_pipeline_state *_pipe){
+  const ptrdiff_t *coded_fragis;
+  const ptrdiff_t *uncoded_fragis;
+  int              pli;
+  int              qii;
+  int              qti;
+  /*If chroma is sub-sampled in the vertical direction, we have to decode two
+     super block rows of Y' for each super block row of Cb and Cr.*/
+  _pipe->mcu_nvfrags=4<<!(_dec->state.info.pixel_fmt&2);
+  /*Initialize the token and extra bits indices for each plane and
+     coefficient.*/
+  memcpy(_pipe->ti,_dec->ti0,sizeof(_pipe->ti));
+  /*Also copy over the initial the EOB run counts.*/
+  memcpy(_pipe->eob_runs,_dec->eob_runs,sizeof(_pipe->eob_runs));
+  /*Set up per-plane pointers to the coded and uncoded fragments lists.*/
+  coded_fragis=_dec->state.coded_fragis;
+  uncoded_fragis=coded_fragis+_dec->state.nfrags;
+  for(pli=0;pli<3;pli++){
+    ptrdiff_t ncoded_fragis;
+    _pipe->coded_fragis[pli]=coded_fragis;
+    _pipe->uncoded_fragis[pli]=uncoded_fragis;
+    ncoded_fragis=_dec->state.ncoded_fragis[pli];
+    coded_fragis+=ncoded_fragis;
+    uncoded_fragis+=ncoded_fragis-_dec->state.fplanes[pli].nfrags;
+  }
+  /*Set up condensed quantizer tables.*/
+  for(pli=0;pli<3;pli++){
+    for(qii=0;qii<_dec->state.nqis;qii++){
+      for(qti=0;qti<2;qti++){
+        _pipe->dequant[pli][qii][qti]=
+         _dec->state.dequant_tables[_dec->state.qis[qii]][pli][qti];
+      }
+    }
+  }
+  /*Set the previous DC predictor to 0 for all color planes and frame types.*/
+  memset(_pipe->pred_last,0,sizeof(_pipe->pred_last));
+  /*Initialize the bounding value array for the loop filter.*/
+  _pipe->loop_filter=!oc_state_loop_filter_init(&_dec->state,
+   _pipe->bounding_values);
+  /*Initialize any buffers needed for post-processing.
+    We also save the current post-processing level, to guard against the user
+     changing it from a callback.*/
+  if(!oc_dec_postprocess_init(_dec))_pipe->pp_level=_dec->pp_level;
+  /*If we don't have enough information to post-process, disable it, regardless
+     of the user-requested level.*/
+  else{
+    _pipe->pp_level=OC_PP_LEVEL_DISABLED;
+    memcpy(_dec->pp_frame_buf,
+     _dec->state.ref_frame_bufs[_dec->state.ref_frame_idx[OC_FRAME_SELF]],
+     sizeof(_dec->pp_frame_buf[0])*3);
+  }
+}
+
+/*Undo the DC prediction in a single plane of an MCU (one or two super block
+   rows).
+  As a side effect, the number of coded and uncoded fragments in this plane of
+   the MCU is also computed.*/
+static void oc_dec_dc_unpredict_mcu_plane(oc_dec_ctx *_dec,
+ oc_dec_pipeline_state *_pipe,int _pli){
+  const oc_fragment_plane *fplane;
+  oc_fragment             *frags;
+  int                     *pred_last;
+  ptrdiff_t                ncoded_fragis;
+  ptrdiff_t                fragi;
+  int                      fragx;
+  int                      fragy;
+  int                      fragy0;
+  int                      fragy_end;
+  int                      nhfrags;
+  /*Compute the first and last fragment row of the current MCU for this
+     plane.*/
+  fplane=_dec->state.fplanes+_pli;
+  fragy0=_pipe->fragy0[_pli];
+  fragy_end=_pipe->fragy_end[_pli];
+  nhfrags=fplane->nhfrags;
+  pred_last=_pipe->pred_last[_pli];
+  frags=_dec->state.frags;
+  ncoded_fragis=0;
+  fragi=fplane->froffset+fragy0*(ptrdiff_t)nhfrags;
+  for(fragy=fragy0;fragy<fragy_end;fragy++){
+    if(fragy==0){
+      /*For the first row, all of the cases reduce to just using the previous
+         predictor for the same reference frame.*/
+      for(fragx=0;fragx<nhfrags;fragx++,fragi++){
+        if(frags[fragi].coded){
+          int ref;
+          ref=OC_FRAME_FOR_MODE(frags[fragi].mb_mode);
+          pred_last[ref]=frags[fragi].dc+=pred_last[ref];
+          ncoded_fragis++;
+        }
+      }
+    }
+    else{
+      oc_fragment *u_frags;
+      int          l_ref;
+      int          ul_ref;
+      int          u_ref;
+      u_frags=frags-nhfrags;
+      l_ref=-1;
+      ul_ref=-1;
+      u_ref=u_frags[fragi].coded?OC_FRAME_FOR_MODE(u_frags[fragi].mb_mode):-1;
+      for(fragx=0;fragx<nhfrags;fragx++,fragi++){
+        int ur_ref;
+        if(fragx+1>=nhfrags)ur_ref=-1;
+        else{
+          ur_ref=u_frags[fragi+1].coded?
+           OC_FRAME_FOR_MODE(u_frags[fragi+1].mb_mode):-1;
+        }
+        if(frags[fragi].coded){
+          int pred;
+          int ref;
+          ref=OC_FRAME_FOR_MODE(frags[fragi].mb_mode);
+          /*We break out a separate case based on which of our neighbors use
+             the same reference frames.
+            This is somewhat faster than trying to make a generic case which
+             handles all of them, since it reduces lots of poorly predicted
+             jumps to one switch statement, and also lets a number of the
+             multiplications be optimized out by strength reduction.*/
+          switch((l_ref==ref)|(ul_ref==ref)<<1|
+           (u_ref==ref)<<2|(ur_ref==ref)<<3){
+            default:pred=pred_last[ref];break;
+            case  1:
+            case  3:pred=frags[fragi-1].dc;break;
+            case  2:pred=u_frags[fragi-1].dc;break;
+            case  4:
+            case  6:
+            case 12:pred=u_frags[fragi].dc;break;
+            case  5:pred=(frags[fragi-1].dc+u_frags[fragi].dc)/2;break;
+            case  8:pred=u_frags[fragi+1].dc;break;
+            case  9:
+            case 11:
+            case 13:{
+              pred=(75*frags[fragi-1].dc+53*u_frags[fragi+1].dc)/128;
+            }break;
+            case 10:pred=(u_frags[fragi-1].dc+u_frags[fragi+1].dc)/2;break;
+            case 14:{
+              pred=(3*(u_frags[fragi-1].dc+u_frags[fragi+1].dc)
+               +10*u_frags[fragi].dc)/16;
+            }break;
+            case  7:
+            case 15:{
+              int p0;
+              int p1;
+              int p2;
+              p0=frags[fragi-1].dc;
+              p1=u_frags[fragi-1].dc;
+              p2=u_frags[fragi].dc;
+              pred=(29*(p0+p2)-26*p1)/32;
+              if(abs(pred-p2)>128)pred=p2;
+              else if(abs(pred-p0)>128)pred=p0;
+              else if(abs(pred-p1)>128)pred=p1;
+            }break;
+          }
+          pred_last[ref]=frags[fragi].dc+=pred;
+          ncoded_fragis++;
+          l_ref=ref;
+        }
+        else l_ref=-1;
+        ul_ref=u_ref;
+        u_ref=ur_ref;
+      }
+    }
+  }
+  _pipe->ncoded_fragis[_pli]=ncoded_fragis;
+  /*Also save the number of uncoded fragments so we know how many to copy.*/
+  _pipe->nuncoded_fragis[_pli]=
+   (fragy_end-fragy0)*(ptrdiff_t)nhfrags-ncoded_fragis;
+}
+
+/*Reconstructs all coded fragments in a single MCU (one or two super block
+   rows).
+  This requires that each coded fragment have a proper macro block mode and
+   motion vector (if not in INTRA mode), and have it's DC value decoded, with
+   the DC prediction process reversed, and the number of coded and uncoded
+   fragments in this plane of the MCU be counted.
+  The token lists for each color plane and coefficient should also be filled
+   in, along with initial token offsets, extra bits offsets, and EOB run
+   counts.*/
+static void oc_dec_frags_recon_mcu_plane(oc_dec_ctx *_dec,
+ oc_dec_pipeline_state *_pipe,int _pli){
+  unsigned char       *dct_tokens;
+  const unsigned char *dct_fzig_zag;
+  ogg_uint16_t         dc_quant[2];
+  const oc_fragment   *frags;
+  const ptrdiff_t     *coded_fragis;
+  ptrdiff_t            ncoded_fragis;
+  ptrdiff_t            fragii;
+  ptrdiff_t           *ti;
+  ptrdiff_t           *eob_runs;
+  int                  qti;
+  dct_tokens=_dec->dct_tokens;
+  dct_fzig_zag=_dec->state.opt_data.dct_fzig_zag;
+  frags=_dec->state.frags;
+  coded_fragis=_pipe->coded_fragis[_pli];
+  ncoded_fragis=_pipe->ncoded_fragis[_pli];
+  ti=_pipe->ti[_pli];
+  eob_runs=_pipe->eob_runs[_pli];
+  for(qti=0;qti<2;qti++)dc_quant[qti]=_pipe->dequant[_pli][0][qti][0];
+  for(fragii=0;fragii<ncoded_fragis;fragii++){
+    /*This array is made one element larger because the zig-zag index array
+       uses the final element as a dumping ground for out-of-range indices
+       to protect us from buffer overflow.*/
+    OC_ALIGN8(ogg_int16_t dct_coeffs[65]);
+    const ogg_uint16_t *ac_quant;
+    ptrdiff_t           fragi;
+    int                 last_zzi;
+    int                 zzi;
+    fragi=coded_fragis[fragii];
+    for(zzi=0;zzi<64;zzi++)dct_coeffs[zzi]=0;
+    qti=frags[fragi].mb_mode!=OC_MODE_INTRA;
+    ac_quant=_pipe->dequant[_pli][frags[fragi].qii][qti];
+    /*Decode the AC coefficients.*/
+    for(zzi=0;zzi<64;){
+      int token;
+      last_zzi=zzi;
+      if(eob_runs[zzi]){
+        eob_runs[zzi]--;
+        break;
+      }
+      else{
+        ptrdiff_t eob;
+        int       cw;
+        int       rlen;
+        int       coeff;
+        int       lti;
+        lti=ti[zzi];
+        token=dct_tokens[lti++];
+        cw=OC_DCT_CODE_WORD[token];
+        /*These parts could be done branchless, but the branches are fairly
+           predictable and the C code translates into more than a few
+           instructions, so it's worth it to avoid them.*/
+        if(OC_DCT_TOKEN_NEEDS_MORE(token)){
+          cw+=dct_tokens[lti++]<<OC_DCT_TOKEN_EB_POS(token);
+        }
+        eob=cw>>OC_DCT_CW_EOB_SHIFT&0xFFF;
+        if(token==OC_DCT_TOKEN_FAT_EOB){
+          eob+=dct_tokens[lti++]<<8;
+          if(eob==0)eob=OC_DCT_EOB_FINISH;
+        }
+        rlen=(unsigned char)(cw>>OC_DCT_CW_RLEN_SHIFT);
+        cw^=-(cw&1<<OC_DCT_CW_FLIP_BIT);
+        coeff=cw>>OC_DCT_CW_MAG_SHIFT;
+        eob_runs[zzi]=eob;
+        ti[zzi]=lti;
+        zzi+=rlen;
+        dct_coeffs[dct_fzig_zag[zzi]]=(ogg_int16_t)(coeff*(int)ac_quant[zzi]);
+        zzi+=!eob;
+      }
+    }
+    /*TODO: zzi should be exactly 64 here.
+      If it's not, we should report some kind of warning.*/
+    zzi=OC_MINI(zzi,64);
+    dct_coeffs[0]=(ogg_int16_t)frags[fragi].dc;
+    /*last_zzi is always initialized.
+      If your compiler thinks otherwise, it is dumb.*/
+    oc_state_frag_recon(&_dec->state,fragi,_pli,
+     dct_coeffs,last_zzi,dc_quant[qti]);
+  }
+  _pipe->coded_fragis[_pli]+=ncoded_fragis;
+  /*Right now the reconstructed MCU has only the coded blocks in it.*/
+  /*TODO: We make the decision here to always copy the uncoded blocks into it
+     from the reference frame.
+    We could also copy the coded blocks back over the reference frame, if we
+     wait for an additional MCU to be decoded, which might be faster if only a
+     small number of blocks are coded.
+    However, this introduces more latency, creating a larger cache footprint.
+    It's unknown which decision is better, but this one results in simpler
+     code, and the hard case (high bitrate, high resolution) is handled
+     correctly.*/
+  /*Copy the uncoded blocks from the previous reference frame.*/
+  _pipe->uncoded_fragis[_pli]-=_pipe->nuncoded_fragis[_pli];
+  oc_state_frag_copy_list(&_dec->state,_pipe->uncoded_fragis[_pli],
+   _pipe->nuncoded_fragis[_pli],OC_FRAME_SELF,OC_FRAME_PREV,_pli);
+}
+
+/*Filter a horizontal block edge.*/
+static void oc_filter_hedge(unsigned char *_dst,int _dst_ystride,
+ const unsigned char *_src,int _src_ystride,int _qstep,int _flimit,
+ int *_variance0,int *_variance1){
+  unsigned char       *rdst;
+  const unsigned char *rsrc;
+  unsigned char       *cdst;
+  const unsigned char *csrc;
+  int                  r[10];
+  int                  sum0;
+  int                  sum1;
+  int                  bx;
+  int                  by;
+  rdst=_dst;
+  rsrc=_src;
+  for(bx=0;bx<8;bx++){
+    cdst=rdst;
+    csrc=rsrc;
+    for(by=0;by<10;by++){
+      r[by]=*csrc;
+      csrc+=_src_ystride;
+    }
+    sum0=sum1=0;
+    for(by=0;by<4;by++){
+      sum0+=abs(r[by+1]-r[by]);
+      sum1+=abs(r[by+5]-r[by+6]);
+    }
+    *_variance0+=OC_MINI(255,sum0);
+    *_variance1+=OC_MINI(255,sum1);
+    if(sum0<_flimit&&sum1<_flimit&&r[5]-r[4]<_qstep&&r[4]-r[5]<_qstep){
+      *cdst=(unsigned char)(r[0]*3+r[1]*2+r[2]+r[3]+r[4]+4>>3);
+      cdst+=_dst_ystride;
+      *cdst=(unsigned char)(r[0]*2+r[1]+r[2]*2+r[3]+r[4]+r[5]+4>>3);
+      cdst+=_dst_ystride;
+      for(by=0;by<4;by++){
+        *cdst=(unsigned char)(r[by]+r[by+1]+r[by+2]+r[by+3]*2+
+         r[by+4]+r[by+5]+r[by+6]+4>>3);
+        cdst+=_dst_ystride;
+      }
+      *cdst=(unsigned char)(r[4]+r[5]+r[6]+r[7]*2+r[8]+r[9]*2+4>>3);
+      cdst+=_dst_ystride;
+      *cdst=(unsigned char)(r[5]+r[6]+r[7]+r[8]*2+r[9]*3+4>>3);
+    }
+    else{
+      for(by=1;by<=8;by++){
+        *cdst=(unsigned char)r[by];
+        cdst+=_dst_ystride;
+      }
+    }
+    rdst++;
+    rsrc++;
+  }
+}
+
+/*Filter a vertical block edge.*/
+static void oc_filter_vedge(unsigned char *_dst,int _dst_ystride,
+ int _qstep,int _flimit,int *_variances){
+  unsigned char       *rdst;
+  const unsigned char *rsrc;
+  unsigned char       *cdst;
+  int                  r[10];
+  int                  sum0;
+  int                  sum1;
+  int                  bx;
+  int                  by;
+  cdst=_dst;
+  for(by=0;by<8;by++){
+    rsrc=cdst-1;
+    rdst=cdst;
+    for(bx=0;bx<10;bx++)r[bx]=*rsrc++;
+    sum0=sum1=0;
+    for(bx=0;bx<4;bx++){
+      sum0+=abs(r[bx+1]-r[bx]);
+      sum1+=abs(r[bx+5]-r[bx+6]);
+    }
+    _variances[0]+=OC_MINI(255,sum0);
+    _variances[1]+=OC_MINI(255,sum1);
+    if(sum0<_flimit&&sum1<_flimit&&r[5]-r[4]<_qstep&&r[4]-r[5]<_qstep){
+      *rdst++=(unsigned char)(r[0]*3+r[1]*2+r[2]+r[3]+r[4]+4>>3);
+      *rdst++=(unsigned char)(r[0]*2+r[1]+r[2]*2+r[3]+r[4]+r[5]+4>>3);
+      for(bx=0;bx<4;bx++){
+        *rdst++=(unsigned char)(r[bx]+r[bx+1]+r[bx+2]+r[bx+3]*2+
+         r[bx+4]+r[bx+5]+r[bx+6]+4>>3);
+      }
+      *rdst++=(unsigned char)(r[4]+r[5]+r[6]+r[7]*2+r[8]+r[9]*2+4>>3);
+      *rdst=(unsigned char)(r[5]+r[6]+r[7]+r[8]*2+r[9]*3+4>>3);
+    }
+    cdst+=_dst_ystride;
+  }
+}
+
+static void oc_dec_deblock_frag_rows(oc_dec_ctx *_dec,
+ th_img_plane *_dst,th_img_plane *_src,int _pli,int _fragy0,
+ int _fragy_end){
+  oc_fragment_plane   *fplane;
+  int                 *variance;
+  unsigned char       *dc_qi;
+  unsigned char       *dst;
+  const unsigned char *src;
+  ptrdiff_t            froffset;
+  int                  dst_ystride;
+  int                  src_ystride;
+  int                  nhfrags;
+  int                  width;
+  int                  notstart;
+  int                  notdone;
+  int                  flimit;
+  int                  qstep;
+  int                  y_end;
+  int                  y;
+  int                  x;
+  _dst+=_pli;
+  _src+=_pli;
+  fplane=_dec->state.fplanes+_pli;
+  nhfrags=fplane->nhfrags;
+  froffset=fplane->froffset+_fragy0*(ptrdiff_t)nhfrags;
+  variance=_dec->variances+froffset;
+  dc_qi=_dec->dc_qis+froffset;
+  notstart=_fragy0>0;
+  notdone=_fragy_end<fplane->nvfrags;
+  /*We want to clear an extra row of variances, except at the end.*/
+  memset(variance+(nhfrags&-notstart),0,
+   (_fragy_end+notdone-_fragy0-notstart)*(nhfrags*sizeof(variance[0])));
+  /*Except for the first time, we want to point to the middle of the row.*/
+  y=(_fragy0<<3)+(notstart<<2);
+  dst_ystride=_dst->stride;
+  src_ystride=_src->stride;
+  dst=_dst->data+y*(ptrdiff_t)dst_ystride;
+  src=_src->data+y*(ptrdiff_t)src_ystride;
+  width=_dst->width;
+  for(;y<4;y++){
+    memcpy(dst,src,width*sizeof(dst[0]));
+    dst+=dst_ystride;
+    src+=src_ystride;
+  }
+  /*We also want to skip the last row in the frame for this loop.*/
+  y_end=_fragy_end-!notdone<<3;
+  for(;y<y_end;y+=8){
+    qstep=_dec->pp_dc_scale[*dc_qi];
+    flimit=(qstep*3)>>2;
+    oc_filter_hedge(dst,dst_ystride,src-src_ystride,src_ystride,
+     qstep,flimit,variance,variance+nhfrags);
+    variance++;
+    dc_qi++;
+    for(x=8;x<width;x+=8){
+      qstep=_dec->pp_dc_scale[*dc_qi];
+      flimit=(qstep*3)>>2;
+      oc_filter_hedge(dst+x,dst_ystride,src+x-src_ystride,src_ystride,
+       qstep,flimit,variance,variance+nhfrags);
+      oc_filter_vedge(dst+x-(dst_ystride<<2)-4,dst_ystride,
+       qstep,flimit,variance-1);
+      variance++;
+      dc_qi++;
+    }
+    dst+=dst_ystride<<3;
+    src+=src_ystride<<3;
+  }
+  /*And finally, handle the last row in the frame, if it's in the range.*/
+  if(!notdone){
+    int height;
+    height=_dst->height;
+    for(;y<height;y++){
+      memcpy(dst,src,width*sizeof(dst[0]));
+      dst+=dst_ystride;
+      src+=src_ystride;
+    }
+    /*Filter the last row of vertical block edges.*/
+    dc_qi++;
+    for(x=8;x<width;x+=8){
+      qstep=_dec->pp_dc_scale[*dc_qi++];
+      flimit=(qstep*3)>>2;
+      oc_filter_vedge(dst+x-(dst_ystride<<3)-4,dst_ystride,
+       qstep,flimit,variance++);
+    }
+  }
+}
+
+static void oc_dering_block(unsigned char *_idata,int _ystride,int _b,
+ int _dc_scale,int _sharp_mod,int _strong){
+  static const unsigned char OC_MOD_MAX[2]={24,32};
+  static const unsigned char OC_MOD_SHIFT[2]={1,0};
+  const unsigned char *psrc;
+  const unsigned char *src;
+  const unsigned char *nsrc;
+  unsigned char       *dst;
+  int                  vmod[72];
+  int                  hmod[72];
+  int                  mod_hi;
+  int                  by;
+  int                  bx;
+  mod_hi=OC_MINI(3*_dc_scale,OC_MOD_MAX[_strong]);
+  dst=_idata;
+  src=dst;
+  psrc=src-(_ystride&-!(_b&4));
+  for(by=0;by<9;by++){
+    for(bx=0;bx<8;bx++){
+      int mod;
+      mod=32+_dc_scale-(abs(src[bx]-psrc[bx])<<OC_MOD_SHIFT[_strong]);
+      vmod[(by<<3)+bx]=mod<-64?_sharp_mod:OC_CLAMPI(0,mod,mod_hi);
+    }
+    psrc=src;
+    src+=_ystride&-(!(_b&8)|by<7);
+  }
+  nsrc=dst;
+  psrc=dst-!(_b&1);
+  for(bx=0;bx<9;bx++){
+    src=nsrc;
+    for(by=0;by<8;by++){
+      int mod;
+      mod=32+_dc_scale-(abs(*src-*psrc)<<OC_MOD_SHIFT[_strong]);
+      hmod[(bx<<3)+by]=mod<-64?_sharp_mod:OC_CLAMPI(0,mod,mod_hi);
+      psrc+=_ystride;
+      src+=_ystride;
+    }
+    psrc=nsrc;
+    nsrc+=!(_b&2)|bx<7;
+  }
+  src=dst;
+  psrc=src-(_ystride&-!(_b&4));
+  nsrc=src+_ystride;
+  for(by=0;by<8;by++){
+    int a;
+    int b;
+    int w;
+    a=128;
+    b=64;
+    w=hmod[by];
+    a-=w;
+    b+=w**(src-!(_b&1));
+    w=vmod[by<<3];
+    a-=w;
+    b+=w*psrc[0];
+    w=vmod[by+1<<3];
+    a-=w;
+    b+=w*nsrc[0];
+    w=hmod[(1<<3)+by];
+    a-=w;
+    b+=w*src[1];
+    dst[0]=OC_CLAMP255(a*src[0]+b>>7);
+    for(bx=1;bx<7;bx++){
+      a=128;
+      b=64;
+      w=hmod[(bx<<3)+by];
+      a-=w;
+      b+=w*src[bx-1];
+      w=vmod[(by<<3)+bx];
+      a-=w;
+      b+=w*psrc[bx];
+      w=vmod[(by+1<<3)+bx];
+      a-=w;
+      b+=w*nsrc[bx];
+      w=hmod[(bx+1<<3)+by];
+      a-=w;
+      b+=w*src[bx+1];
+      dst[bx]=OC_CLAMP255(a*src[bx]+b>>7);
+    }
+    a=128;
+    b=64;
+    w=hmod[(7<<3)+by];
+    a-=w;
+    b+=w*src[6];
+    w=vmod[(by<<3)+7];
+    a-=w;
+    b+=w*psrc[7];
+    w=vmod[(by+1<<3)+7];
+    a-=w;
+    b+=w*nsrc[7];
+    w=hmod[(8<<3)+by];
+    a-=w;
+    b+=w*src[7+!(_b&2)];
+    dst[7]=OC_CLAMP255(a*src[7]+b>>7);
+    dst+=_ystride;
+    psrc=src;
+    src=nsrc;
+    nsrc+=_ystride&-(!(_b&8)|by<6);
+  }
+}
+
+#define OC_DERING_THRESH1 (384)
+#define OC_DERING_THRESH2 (4*OC_DERING_THRESH1)
+#define OC_DERING_THRESH3 (5*OC_DERING_THRESH1)
+#define OC_DERING_THRESH4 (10*OC_DERING_THRESH1)
+
+static void oc_dec_dering_frag_rows(oc_dec_ctx *_dec,th_img_plane *_img,
+ int _pli,int _fragy0,int _fragy_end){
+  th_img_plane      *iplane;
+  oc_fragment_plane *fplane;
+  oc_fragment       *frag;
+  int               *variance;
+  unsigned char     *idata;
+  ptrdiff_t          froffset;
+  int                ystride;
+  int                nhfrags;
+  int                sthresh;
+  int                strong;
+  int                y_end;
+  int                width;
+  int                height;
+  int                y;
+  int                x;
+  iplane=_img+_pli;
+  fplane=_dec->state.fplanes+_pli;
+  nhfrags=fplane->nhfrags;
+  froffset=fplane->froffset+_fragy0*(ptrdiff_t)nhfrags;
+  variance=_dec->variances+froffset;
+  frag=_dec->state.frags+froffset;
+  strong=_dec->pp_level>=(_pli?OC_PP_LEVEL_SDERINGC:OC_PP_LEVEL_SDERINGY);
+  sthresh=_pli?OC_DERING_THRESH4:OC_DERING_THRESH3;
+  y=_fragy0<<3;
+  ystride=iplane->stride;
+  idata=iplane->data+y*(ptrdiff_t)ystride;
+  y_end=_fragy_end<<3;
+  width=iplane->width;
+  height=iplane->height;
+  for(;y<y_end;y+=8){
+    for(x=0;x<width;x+=8){
+      int b;
+      int qi;
+      int var;
+      qi=_dec->state.qis[frag->qii];
+      var=*variance;
+      b=(x<=0)|(x+8>=width)<<1|(y<=0)<<2|(y+8>=height)<<3;
+      if(strong&&var>sthresh){
+        oc_dering_block(idata+x,ystride,b,
+         _dec->pp_dc_scale[qi],_dec->pp_sharp_mod[qi],1);
+        if(_pli||!(b&1)&&*(variance-1)>OC_DERING_THRESH4||
+         !(b&2)&&variance[1]>OC_DERING_THRESH4||
+         !(b&4)&&*(variance-nhfrags)>OC_DERING_THRESH4||
+         !(b&8)&&variance[nhfrags]>OC_DERING_THRESH4){
+          oc_dering_block(idata+x,ystride,b,
+           _dec->pp_dc_scale[qi],_dec->pp_sharp_mod[qi],1);
+          oc_dering_block(idata+x,ystride,b,
+           _dec->pp_dc_scale[qi],_dec->pp_sharp_mod[qi],1);
+        }
+      }
+      else if(var>OC_DERING_THRESH2){
+        oc_dering_block(idata+x,ystride,b,
+         _dec->pp_dc_scale[qi],_dec->pp_sharp_mod[qi],1);
+      }
+      else if(var>OC_DERING_THRESH1){
+        oc_dering_block(idata+x,ystride,b,
+         _dec->pp_dc_scale[qi],_dec->pp_sharp_mod[qi],0);
+      }
+      frag++;
+      variance++;
+    }
+    idata+=ystride<<3;
+  }
+}
+
+
+
+th_dec_ctx *th_decode_alloc(const th_info *_info,const th_setup_info *_setup){
+  oc_dec_ctx *dec;
+  if(_info==NULL||_setup==NULL)return NULL;
+  dec=_ogg_malloc(sizeof(*dec));
+  if(dec==NULL||oc_dec_init(dec,_info,_setup)<0){
+    _ogg_free(dec);
+    return NULL;
+  }
+  dec->state.curframe_num=0;
+  return dec;
+}
+
+void th_decode_free(th_dec_ctx *_dec){
+  if(_dec!=NULL){
+    oc_dec_clear(_dec);
+    _ogg_free(_dec);
+  }
+}
+
+int th_decode_ctl(th_dec_ctx *_dec,int _req,void *_buf,
+ size_t _buf_sz){
+  switch(_req){
+  case TH_DECCTL_GET_PPLEVEL_MAX:{
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(int))return TH_EINVAL;
+    (*(int *)_buf)=OC_PP_LEVEL_MAX;
+    return 0;
+  }break;
+  case TH_DECCTL_SET_PPLEVEL:{
+    int pp_level;
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(int))return TH_EINVAL;
+    pp_level=*(int *)_buf;
+    if(pp_level<0||pp_level>OC_PP_LEVEL_MAX)return TH_EINVAL;
+    _dec->pp_level=pp_level;
+    return 0;
+  }break;
+  case TH_DECCTL_SET_GRANPOS:{
+    ogg_int64_t granpos;
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(ogg_int64_t))return TH_EINVAL;
+    granpos=*(ogg_int64_t *)_buf;
+    if(granpos<0)return TH_EINVAL;
+    _dec->state.granpos=granpos;
+    _dec->state.keyframe_num=(granpos>>_dec->state.info.keyframe_granule_shift)
+     -_dec->state.granpos_bias;
+    _dec->state.curframe_num=_dec->state.keyframe_num
+     +(granpos&(1<<_dec->state.info.keyframe_granule_shift)-1);
+    return 0;
+  }break;
+  case TH_DECCTL_SET_STRIPE_CB:{
+    th_stripe_callback *cb;
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(th_stripe_callback))return TH_EINVAL;
+    cb=(th_stripe_callback *)_buf;
+    _dec->stripe_cb.ctx=cb->ctx;
+    _dec->stripe_cb.stripe_decoded=cb->stripe_decoded;
+    return 0;
+  }break;
+#ifdef HAVE_CAIRO
+  case TH_DECCTL_SET_TELEMETRY_MBMODE:{
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(int))return TH_EINVAL;
+    _dec->telemetry=1;
+    _dec->telemetry_mbmode=*(int *)_buf;
+    return 0;
+  }break;
+  case TH_DECCTL_SET_TELEMETRY_MV:{
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(int))return TH_EINVAL;
+    _dec->telemetry=1;
+    _dec->telemetry_mv=*(int *)_buf;
+    return 0;
+  }break;
+  case TH_DECCTL_SET_TELEMETRY_QI:{
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(int))return TH_EINVAL;
+    _dec->telemetry=1;
+    _dec->telemetry_qi=*(int *)_buf;
+    return 0;
+  }break;
+  case TH_DECCTL_SET_TELEMETRY_BITS:{
+    if(_dec==NULL||_buf==NULL)return TH_EFAULT;
+    if(_buf_sz!=sizeof(int))return TH_EINVAL;
+    _dec->telemetry=1;
+    _dec->telemetry_bits=*(int *)_buf;
+    return 0;
+  }break;
+#endif
+  default:return TH_EIMPL;
+  }
+}
+
+/*We're decoding an INTER frame, but have no initialized reference
+   buffers (i.e., decoding did not start on a key frame).
+  We initialize them to a solid gray here.*/
+static void oc_dec_init_dummy_frame(th_dec_ctx *_dec){
+  th_info *info;
+  size_t   yplane_sz;
+  size_t   cplane_sz;
+  int      yhstride;
+  int      yheight;
+  int      chstride;
+  int      cheight;
+  _dec->state.ref_frame_idx[OC_FRAME_GOLD]=0;
+  _dec->state.ref_frame_idx[OC_FRAME_PREV]=0;
+  _dec->state.ref_frame_idx[OC_FRAME_SELF]=1;
+  info=&_dec->state.info;
+  yhstride=info->frame_width+2*OC_UMV_PADDING;
+  yheight=info->frame_height+2*OC_UMV_PADDING;
+  chstride=yhstride>>!(info->pixel_fmt&1);
+  cheight=yheight>>!(info->pixel_fmt&2);
+  yplane_sz=yhstride*(size_t)yheight;
+  cplane_sz=chstride*(size_t)cheight;
+  memset(_dec->state.ref_frame_data[0],0x80,yplane_sz+2*cplane_sz);
+}
+
+int th_decode_packetin(th_dec_ctx *_dec,const ogg_packet *_op,
+ ogg_int64_t *_granpos){
+  int ret;
+  if(_dec==NULL||_op==NULL)return TH_EFAULT;
+  /*A completely empty packet indicates a dropped frame and is treated exactly
+     like an inter frame with no coded blocks.
+    Only proceed if we have a non-empty packet.*/
+  if(_op->bytes!=0){
+    oc_dec_pipeline_state pipe;
+    th_ycbcr_buffer       stripe_buf;
+    int                   stripe_fragy;
+    int                   refi;
+    int                   pli;
+    int                   notstart;
+    int                   notdone;
+    oc_pack_readinit(&_dec->opb,_op->packet,_op->bytes);
+#if defined(HAVE_CAIRO)
+    _dec->telemetry_frame_bytes=_op->bytes;
+#endif
+    ret=oc_dec_frame_header_unpack(_dec);
+    if(ret<0)return ret;
+    /*Select a free buffer to use for the reconstructed version of this
+       frame.*/
+    if(_dec->state.frame_type!=OC_INTRA_FRAME&&
+     (_dec->state.ref_frame_idx[OC_FRAME_GOLD]<0||
+     _dec->state.ref_frame_idx[OC_FRAME_PREV]<0)){
+      /*No reference frames yet!*/
+      oc_dec_init_dummy_frame(_dec);
+      refi=_dec->state.ref_frame_idx[OC_FRAME_SELF];
+    }
+    else{
+      for(refi=0;refi==_dec->state.ref_frame_idx[OC_FRAME_GOLD]||
+       refi==_dec->state.ref_frame_idx[OC_FRAME_PREV];refi++);
+      _dec->state.ref_frame_idx[OC_FRAME_SELF]=refi;
+    }
+    if(_dec->state.frame_type==OC_INTRA_FRAME){
+      oc_dec_mark_all_intra(_dec);
+      _dec->state.keyframe_num=_dec->state.curframe_num;
+#if defined(HAVE_CAIRO)
+      _dec->telemetry_coding_bytes=
+       _dec->telemetry_mode_bytes=
+       _dec->telemetry_mv_bytes=oc_pack_bytes_left(&_dec->opb);
+#endif
+    }
+    else{
+      oc_dec_coded_flags_unpack(_dec);
+#if defined(HAVE_CAIRO)
+      _dec->telemetry_coding_bytes=oc_pack_bytes_left(&_dec->opb);
+#endif
+      oc_dec_mb_modes_unpack(_dec);
+#if defined(HAVE_CAIRO)
+      _dec->telemetry_mode_bytes=oc_pack_bytes_left(&_dec->opb);
+#endif
+      oc_dec_mv_unpack_and_frag_modes_fill(_dec);
+#if defined(HAVE_CAIRO)
+      _dec->telemetry_mv_bytes=oc_pack_bytes_left(&_dec->opb);
+#endif
+    }
+    oc_dec_block_qis_unpack(_dec);
+#if defined(HAVE_CAIRO)
+    _dec->telemetry_qi_bytes=oc_pack_bytes_left(&_dec->opb);
+#endif
+    oc_dec_residual_tokens_unpack(_dec);
+    /*Update granule position.
+      This must be done before the striped decode callbacks so that the
+       application knows what to do with the frame data.*/
+    _dec->state.granpos=(_dec->state.keyframe_num+_dec->state.granpos_bias<<
+     _dec->state.info.keyframe_granule_shift)
+     +(_dec->state.curframe_num-_dec->state.keyframe_num);
+    _dec->state.curframe_num++;
+    if(_granpos!=NULL)*_granpos=_dec->state.granpos;
+    /*All of the rest of the operations -- DC prediction reversal,
+       reconstructing coded fragments, copying uncoded fragments, loop
+       filtering, extending borders, and out-of-loop post-processing -- should
+       be pipelined.
+      I.e., DC prediction reversal, reconstruction, and uncoded fragment
+       copying are done for one or two super block rows, then loop filtering is
+       run as far as it can, then bordering copying, then post-processing.
+      For 4:2:0 video a Minimum Codable Unit or MCU contains two luma super
+       block rows, and one chroma.
+      Otherwise, an MCU consists of one super block row from each plane.
+      Inside each MCU, we perform all of the steps on one color plane before
+       moving on to the next.
+      After reconstruction, the additional filtering stages introduce a delay
+       since they need some pixels from the next fragment row.
+      Thus the actual number of decoded rows available is slightly smaller for
+       the first MCU, and slightly larger for the last.
+
+      This entire process allows us to operate on the data while it is still in
+       cache, resulting in big performance improvements.
+      An application callback allows further application processing (blitting
+       to video memory, color conversion, etc.) to also use the data while it's
+       in cache.*/
+    oc_dec_pipeline_init(_dec,&pipe);
+    oc_ycbcr_buffer_flip(stripe_buf,_dec->pp_frame_buf);
+    notstart=0;
+    notdone=1;
+    for(stripe_fragy=0;notdone;stripe_fragy+=pipe.mcu_nvfrags){
+      int avail_fragy0;
+      int avail_fragy_end;
+      avail_fragy0=avail_fragy_end=_dec->state.fplanes[0].nvfrags;
+      notdone=stripe_fragy+pipe.mcu_nvfrags<avail_fragy_end;
+      for(pli=0;pli<3;pli++){
+        oc_fragment_plane *fplane;
+        int                frag_shift;
+        int                pp_offset;
+        int                sdelay;
+        int                edelay;
+        fplane=_dec->state.fplanes+pli;
+        /*Compute the first and last fragment row of the current MCU for this
+           plane.*/
+        frag_shift=pli!=0&&!(_dec->state.info.pixel_fmt&2);
+        pipe.fragy0[pli]=stripe_fragy>>frag_shift;
+        pipe.fragy_end[pli]=OC_MINI(fplane->nvfrags,
+         pipe.fragy0[pli]+(pipe.mcu_nvfrags>>frag_shift));
+        oc_dec_dc_unpredict_mcu_plane(_dec,&pipe,pli);
+        oc_dec_frags_recon_mcu_plane(_dec,&pipe,pli);
+        sdelay=edelay=0;
+        if(pipe.loop_filter){
+          sdelay+=notstart;
+          edelay+=notdone;
+          oc_state_loop_filter_frag_rows(&_dec->state,pipe.bounding_values,
+           refi,pli,pipe.fragy0[pli]-sdelay,pipe.fragy_end[pli]-edelay);
+        }
+        /*To fill the borders, we have an additional two pixel delay, since a
+           fragment in the next row could filter its top edge, using two pixels
+           from a fragment in this row.
+          But there's no reason to delay a full fragment between the two.*/
+        oc_state_borders_fill_rows(&_dec->state,refi,pli,
+         (pipe.fragy0[pli]-sdelay<<3)-(sdelay<<1),
+         (pipe.fragy_end[pli]-edelay<<3)-(edelay<<1));
+        /*Out-of-loop post-processing.*/
+        pp_offset=3*(pli!=0);
+        if(pipe.pp_level>=OC_PP_LEVEL_DEBLOCKY+pp_offset){
+          /*Perform de-blocking in one plane.*/
+          sdelay+=notstart;
+          edelay+=notdone;
+          oc_dec_deblock_frag_rows(_dec,_dec->pp_frame_buf,
+           _dec->state.ref_frame_bufs[refi],pli,
+           pipe.fragy0[pli]-sdelay,pipe.fragy_end[pli]-edelay);
+          if(pipe.pp_level>=OC_PP_LEVEL_DERINGY+pp_offset){
+            /*Perform de-ringing in one plane.*/
+            sdelay+=notstart;
+            edelay+=notdone;
+            oc_dec_dering_frag_rows(_dec,_dec->pp_frame_buf,pli,
+             pipe.fragy0[pli]-sdelay,pipe.fragy_end[pli]-edelay);
+          }
+        }
+        /*If no post-processing is done, we still need to delay a row for the
+           loop filter, thanks to the strange filtering order VP3 chose.*/
+        else if(pipe.loop_filter){
+          sdelay+=notstart;
+          edelay+=notdone;
+        }
+        /*Compute the intersection of the available rows in all planes.
+          If chroma is sub-sampled, the effect of each of its delays is
+           doubled, but luma might have more post-processing filters enabled
+           than chroma, so we don't know up front which one is the limiting
+           factor.*/
+        avail_fragy0=OC_MINI(avail_fragy0,pipe.fragy0[pli]-sdelay<<frag_shift);
+        avail_fragy_end=OC_MINI(avail_fragy_end,
+         pipe.fragy_end[pli]-edelay<<frag_shift);
+      }
+      if(_dec->stripe_cb.stripe_decoded!=NULL){
+        /*The callback might want to use the FPU, so let's make sure they can.
+          We violate all kinds of ABI restrictions by not doing this until
+           now, but none of them actually matter since we don't use floating
+           point ourselves.*/
+        oc_restore_fpu(&_dec->state);
+        /*Make the callback, ensuring we flip the sense of the "start" and
+           "end" of the available region upside down.*/
+        (*_dec->stripe_cb.stripe_decoded)(_dec->stripe_cb.ctx,stripe_buf,
+         _dec->state.fplanes[0].nvfrags-avail_fragy_end,
+         _dec->state.fplanes[0].nvfrags-avail_fragy0);
+      }
+      notstart=1;
+    }
+    /*Finish filling in the reference frame borders.*/
+    for(pli=0;pli<3;pli++)oc_state_borders_fill_caps(&_dec->state,refi,pli);
+    /*Update the reference frame indices.*/
+    if(_dec->state.frame_type==OC_INTRA_FRAME){
+      /*The new frame becomes both the previous and gold reference frames.*/
+      _dec->state.ref_frame_idx[OC_FRAME_GOLD]=
+       _dec->state.ref_frame_idx[OC_FRAME_PREV]=
+       _dec->state.ref_frame_idx[OC_FRAME_SELF];
+    }
+    else{
+      /*Otherwise, just replace the previous reference frame.*/
+      _dec->state.ref_frame_idx[OC_FRAME_PREV]=
+       _dec->state.ref_frame_idx[OC_FRAME_SELF];
+    }
+    /*Restore the FPU before dump_frame, since that _does_ use the FPU (for PNG
+       gamma values, if nothing else).*/
+    oc_restore_fpu(&_dec->state);
+#if defined(OC_DUMP_IMAGES)
+    /*Don't dump images for dropped frames.*/
+    oc_state_dump_frame(&_dec->state,OC_FRAME_SELF,"dec");
+#endif
+    return 0;
+  }
+  else{
+    if(_dec->state.ref_frame_idx[OC_FRAME_GOLD]<0||
+     _dec->state.ref_frame_idx[OC_FRAME_PREV]<0){
+      int refi;
+      /*No reference frames yet!*/
+      oc_dec_init_dummy_frame(_dec);
+      refi=_dec->state.ref_frame_idx[OC_FRAME_PREV];
+      _dec->state.ref_frame_idx[OC_FRAME_SELF]=refi;
+      memcpy(_dec->pp_frame_buf,_dec->state.ref_frame_bufs[refi],
+       sizeof(_dec->pp_frame_buf[0])*3);
+    }
+    /*Just update the granule position and return.*/
+    _dec->state.granpos=(_dec->state.keyframe_num+_dec->state.granpos_bias<<
+     _dec->state.info.keyframe_granule_shift)
+     +(_dec->state.curframe_num-_dec->state.keyframe_num);
+    _dec->state.curframe_num++;
+    if(_granpos!=NULL)*_granpos=_dec->state.granpos;
+    return TH_DUPFRAME;
+  }
+}
+
+int th_decode_ycbcr_out(th_dec_ctx *_dec,th_ycbcr_buffer _ycbcr){
+  if(_dec==NULL||_ycbcr==NULL)return TH_EFAULT;
+  oc_ycbcr_buffer_flip(_ycbcr,_dec->pp_frame_buf);
+#if defined(HAVE_CAIRO)
+  /*If telemetry ioctls are active, we need to draw to the output buffer.
+    Stuff the plane into cairo.*/
+  if(_dec->telemetry){
+    cairo_surface_t *cs;
+    unsigned char   *data;
+    unsigned char   *y_row;
+    unsigned char   *u_row;
+    unsigned char   *v_row;
+    unsigned char   *rgb_row;
+    int              cstride;
+    int              w;
+    int              h;
+    int              x;
+    int              y;
+    int              hdec;
+    int              vdec;
+    w=_ycbcr[0].width;
+    h=_ycbcr[0].height;
+    hdec=!(_dec->state.info.pixel_fmt&1);
+    vdec=!(_dec->state.info.pixel_fmt&2);
+    /*Lazy data buffer init.
+      We could try to re-use the post-processing buffer, which would save
+       memory, but complicate the allocation logic there.
+      I don't think anyone cares about memory usage when using telemetry; it is
+       not meant for embedded devices.*/
+    if(_dec->telemetry_frame_data==NULL){
+      _dec->telemetry_frame_data=_ogg_malloc(
+       (w*h+2*(w>>hdec)*(h>>vdec))*sizeof(*_dec->telemetry_frame_data));
+      if(_dec->telemetry_frame_data==NULL)return 0;
+    }
+    cs=cairo_image_surface_create(CAIRO_FORMAT_RGB24,w,h);
+    /*Sadly, no YUV support in Cairo (yet); convert into the RGB buffer.*/
+    data=cairo_image_surface_get_data(cs);
+    if(data==NULL){
+      cairo_surface_destroy(cs);
+      return 0;
+    }
+    cstride=cairo_image_surface_get_stride(cs);
+    y_row=_ycbcr[0].data;
+    u_row=_ycbcr[1].data;
+    v_row=_ycbcr[2].data;
+    rgb_row=data;
+    for(y=0;y<h;y++){
+      for(x=0;x<w;x++){
+        int r;
+        int g;
+        int b;
+        r=(1904000*y_row[x]+2609823*v_row[x>>hdec]-363703744)/1635200;
+        g=(3827562*y_row[x]-1287801*u_row[x>>hdec]
+         -2672387*v_row[x>>hdec]+447306710)/3287200;
+        b=(952000*y_row[x]+1649289*u_row[x>>hdec]-225932192)/817600;
+        rgb_row[4*x+0]=OC_CLAMP255(b);
+        rgb_row[4*x+1]=OC_CLAMP255(g);
+        rgb_row[4*x+2]=OC_CLAMP255(r);
+      }
+      y_row+=_ycbcr[0].stride;
+      u_row+=_ycbcr[1].stride&-((y&1)|!vdec);
+      v_row+=_ycbcr[2].stride&-((y&1)|!vdec);
+      rgb_row+=cstride;
+    }
+    /*Draw coded identifier for each macroblock (stored in Hilbert order).*/
+    {
+      cairo_t           *c;
+      const oc_fragment *frags;
+      oc_mv             *frag_mvs;
+      const signed char *mb_modes;
+      oc_mb_map         *mb_maps;
+      size_t             nmbs;
+      size_t             mbi;
+      int                row2;
+      int                col2;
+      int                qim[3]={0,0,0};
+      if(_dec->state.nqis==2){
+        int bqi;
+        bqi=_dec->state.qis[0];
+        if(_dec->state.qis[1]>bqi)qim[1]=1;
+        if(_dec->state.qis[1]<bqi)qim[1]=-1;
+      }
+      if(_dec->state.nqis==3){
+        int bqi;
+        int cqi;
+        int dqi;
+        bqi=_dec->state.qis[0];
+        cqi=_dec->state.qis[1];
+        dqi=_dec->state.qis[2];
+        if(cqi>bqi&&dqi>bqi){
+          if(dqi>cqi){
+            qim[1]=1;
+            qim[2]=2;
+          }
+          else{
+            qim[1]=2;
+            qim[2]=1;
+          }
+        }
+        else if(cqi<bqi&&dqi<bqi){
+          if(dqi<cqi){
+            qim[1]=-1;
+            qim[2]=-2;
+          }
+          else{
+            qim[1]=-2;
+            qim[2]=-1;
+          }
+        }
+        else{
+          if(cqi<bqi)qim[1]=-1;
+          else qim[1]=1;
+          if(dqi<bqi)qim[2]=-1;
+          else qim[2]=1;
+        }
+      }
+      c=cairo_create(cs);
+      frags=_dec->state.frags;
+      frag_mvs=_dec->state.frag_mvs;
+      mb_modes=_dec->state.mb_modes;
+      mb_maps=_dec->state.mb_maps;
+      nmbs=_dec->state.nmbs;
+      row2=0;
+      col2=0;
+      for(mbi=0;mbi<nmbs;mbi++){
+        float x;
+        float y;
+        int   bi;
+        y=h-(row2+((col2+1>>1)&1))*16-16;
+        x=(col2>>1)*16;
+        cairo_set_line_width(c,1.);
+        /*Keyframe (all intra) red box.*/
+        if(_dec->state.frame_type==OC_INTRA_FRAME){
+          if(_dec->telemetry_mbmode&0x02){
+            cairo_set_source_rgba(c,1.,0,0,.5);
+            cairo_rectangle(c,x+2.5,y+2.5,11,11);
+            cairo_stroke_preserve(c);
+            cairo_set_source_rgba(c,1.,0,0,.25);
+            cairo_fill(c);
+          }
+        }
+        else{
+          const signed char *frag_mv;
+          ptrdiff_t          fragi;
+          for(bi=0;bi<4;bi++){
+            fragi=mb_maps[mbi][0][bi];
+            if(fragi>=0&&frags[fragi].coded){
+              frag_mv=frag_mvs[fragi];
+              break;
+            }
+          }
+          if(bi<4){
+            switch(mb_modes[mbi]){
+              case OC_MODE_INTRA:{
+                if(_dec->telemetry_mbmode&0x02){
+                  cairo_set_source_rgba(c,1.,0,0,.5);
+                  cairo_rectangle(c,x+2.5,y+2.5,11,11);
+                  cairo_stroke_preserve(c);
+                  cairo_set_source_rgba(c,1.,0,0,.25);
+                  cairo_fill(c);
+                }
+              }break;
+              case OC_MODE_INTER_NOMV:{
+                if(_dec->telemetry_mbmode&0x01){
+                  cairo_set_source_rgba(c,0,0,1.,.5);
+                  cairo_rectangle(c,x+2.5,y+2.5,11,11);
+                  cairo_stroke_preserve(c);
+                  cairo_set_source_rgba(c,0,0,1.,.25);
+                  cairo_fill(c);
+                }
+              }break;
+              case OC_MODE_INTER_MV:{
+                if(_dec->telemetry_mbmode&0x04){
+                  cairo_rectangle(c,x+2.5,y+2.5,11,11);
+                  cairo_set_source_rgba(c,0,1.,0,.5);
+                  cairo_stroke(c);
+                }
+                if(_dec->telemetry_mv&0x04){
+                  cairo_move_to(c,x+8+frag_mv[0],y+8-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.66,y+8-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.33,y+8-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+8,y+8);
+                  cairo_stroke(c);
+                }
+              }break;
+              case OC_MODE_INTER_MV_LAST:{
+                if(_dec->telemetry_mbmode&0x08){
+                  cairo_rectangle(c,x+2.5,y+2.5,11,11);
+                  cairo_set_source_rgba(c,0,1.,0,.5);
+                  cairo_move_to(c,x+13.5,y+2.5);
+                  cairo_line_to(c,x+2.5,y+8);
+                  cairo_line_to(c,x+13.5,y+13.5);
+                  cairo_stroke(c);
+                }
+                if(_dec->telemetry_mv&0x08){
+                  cairo_move_to(c,x+8+frag_mv[0],y+8-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.66,y+8-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.33,y+8-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+8,y+8);
+                  cairo_stroke(c);
+                }
+              }break;
+              case OC_MODE_INTER_MV_LAST2:{
+                if(_dec->telemetry_mbmode&0x10){
+                  cairo_rectangle(c,x+2.5,y+2.5,11,11);
+                  cairo_set_source_rgba(c,0,1.,0,.5);
+                  cairo_move_to(c,x+8,y+2.5);
+                  cairo_line_to(c,x+2.5,y+8);
+                  cairo_line_to(c,x+8,y+13.5);
+                  cairo_move_to(c,x+13.5,y+2.5);
+                  cairo_line_to(c,x+8,y+8);
+                  cairo_line_to(c,x+13.5,y+13.5);
+                  cairo_stroke(c);
+                }
+                if(_dec->telemetry_mv&0x10){
+                  cairo_move_to(c,x+8+frag_mv[0],y+8-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.66,y+8-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.33,y+8-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+8,y+8);
+                  cairo_stroke(c);
+                }
+              }break;
+              case OC_MODE_GOLDEN_NOMV:{
+                if(_dec->telemetry_mbmode&0x20){
+                  cairo_set_source_rgba(c,1.,1.,0,.5);
+                  cairo_rectangle(c,x+2.5,y+2.5,11,11);
+                  cairo_stroke_preserve(c);
+                  cairo_set_source_rgba(c,1.,1.,0,.25);
+                  cairo_fill(c);
+                }
+              }break;
+              case OC_MODE_GOLDEN_MV:{
+                if(_dec->telemetry_mbmode&0x40){
+                  cairo_rectangle(c,x+2.5,y+2.5,11,11);
+                  cairo_set_source_rgba(c,1.,1.,0,.5);
+                  cairo_stroke(c);
+                }
+                if(_dec->telemetry_mv&0x40){
+                  cairo_move_to(c,x+8+frag_mv[0],y+8-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.66,y+8-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+8+frag_mv[0]*.33,y+8-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+8,y+8);
+                  cairo_stroke(c);
+                }
+              }break;
+              case OC_MODE_INTER_MV_FOUR:{
+                if(_dec->telemetry_mbmode&0x80){
+                  cairo_rectangle(c,x+2.5,y+2.5,4,4);
+                  cairo_rectangle(c,x+9.5,y+2.5,4,4);
+                  cairo_rectangle(c,x+2.5,y+9.5,4,4);
+                  cairo_rectangle(c,x+9.5,y+9.5,4,4);
+                  cairo_set_source_rgba(c,0,1.,0,.5);
+                  cairo_stroke(c);
+                }
+                /*4mv is odd, coded in raster order.*/
+                fragi=mb_maps[mbi][0][0];
+                if(frags[fragi].coded&&_dec->telemetry_mv&0x80){
+                  frag_mv=frag_mvs[fragi];
+                  cairo_move_to(c,x+4+frag_mv[0],y+12-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+4+frag_mv[0]*.66,y+12-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+4+frag_mv[0]*.33,y+12-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+4,y+12);
+                  cairo_stroke(c);
+                }
+                fragi=mb_maps[mbi][0][1];
+                if(frags[fragi].coded&&_dec->telemetry_mv&0x80){
+                  frag_mv=frag_mvs[fragi];
+                  cairo_move_to(c,x+12+frag_mv[0],y+12-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+12+frag_mv[0]*.66,y+12-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+12+frag_mv[0]*.33,y+12-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+12,y+12);
+                  cairo_stroke(c);
+                }
+                fragi=mb_maps[mbi][0][2];
+                if(frags[fragi].coded&&_dec->telemetry_mv&0x80){
+                  frag_mv=frag_mvs[fragi];
+                  cairo_move_to(c,x+4+frag_mv[0],y+4-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+4+frag_mv[0]*.66,y+4-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+4+frag_mv[0]*.33,y+4-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+4,y+4);
+                  cairo_stroke(c);
+                }
+                fragi=mb_maps[mbi][0][3];
+                if(frags[fragi].coded&&_dec->telemetry_mv&0x80){
+                  frag_mv=frag_mvs[fragi];
+                  cairo_move_to(c,x+12+frag_mv[0],y+4-frag_mv[1]);
+                  cairo_set_source_rgba(c,1.,1.,1.,.9);
+                  cairo_set_line_width(c,3.);
+                  cairo_line_to(c,x+12+frag_mv[0]*.66,y+4-frag_mv[1]*.66);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,2.);
+                  cairo_line_to(c,x+12+frag_mv[0]*.33,y+4-frag_mv[1]*.33);
+                  cairo_stroke_preserve(c);
+                  cairo_set_line_width(c,1.);
+                  cairo_line_to(c,x+12,y+4);
+                  cairo_stroke(c);
+                }
+              }break;
+            }
+          }
+        }
+        /*qii illustration.*/
+        if(_dec->telemetry_qi&0x2){
+          cairo_set_line_cap(c,CAIRO_LINE_CAP_SQUARE);
+          for(bi=0;bi<4;bi++){
+            ptrdiff_t fragi;
+            int       qiv;
+            int       xp;
+            int       yp;
+            xp=x+(bi&1)*8;
+            yp=y+8-(bi&2)*4;
+            fragi=mb_maps[mbi][0][bi];
+            if(fragi>=0&&frags[fragi].coded){
+              qiv=qim[frags[fragi].qii];
+              cairo_set_line_width(c,3.);
+              cairo_set_source_rgba(c,0.,0.,0.,.5);
+              switch(qiv){
+                /*Double plus:*/
+                case 2:{
+                  if((bi&1)^((bi&2)>>1)){
+                    cairo_move_to(c,xp+2.5,yp+1.5);
+                    cairo_line_to(c,xp+2.5,yp+3.5);
+                    cairo_move_to(c,xp+1.5,yp+2.5);
+                    cairo_line_to(c,xp+3.5,yp+2.5);
+                    cairo_move_to(c,xp+5.5,yp+4.5);
+                    cairo_line_to(c,xp+5.5,yp+6.5);
+                    cairo_move_to(c,xp+4.5,yp+5.5);
+                    cairo_line_to(c,xp+6.5,yp+5.5);
+                    cairo_stroke_preserve(c);
+                    cairo_set_source_rgba(c,0.,1.,1.,1.);
+                  }
+                  else{
+                    cairo_move_to(c,xp+5.5,yp+1.5);
+                    cairo_line_to(c,xp+5.5,yp+3.5);
+                    cairo_move_to(c,xp+4.5,yp+2.5);
+                    cairo_line_to(c,xp+6.5,yp+2.5);
+                    cairo_move_to(c,xp+2.5,yp+4.5);
+                    cairo_line_to(c,xp+2.5,yp+6.5);
+                    cairo_move_to(c,xp+1.5,yp+5.5);
+                    cairo_line_to(c,xp+3.5,yp+5.5);
+                    cairo_stroke_preserve(c);
+                    cairo_set_source_rgba(c,0.,1.,1.,1.);
+                  }
+                }break;
+                /*Double minus:*/
+                case -2:{
+                  cairo_move_to(c,xp+2.5,yp+2.5);
+                  cairo_line_to(c,xp+5.5,yp+2.5);
+                  cairo_move_to(c,xp+2.5,yp+5.5);
+                  cairo_line_to(c,xp+5.5,yp+5.5);
+                  cairo_stroke_preserve(c);
+                  cairo_set_source_rgba(c,1.,1.,1.,1.);
+                }break;
+                /*Plus:*/
+                case 1:{
+                  if(bi&2==0)yp-=2;
+                  if(bi&1==0)xp-=2;
+                  cairo_move_to(c,xp+4.5,yp+2.5);
+                  cairo_line_to(c,xp+4.5,yp+6.5);
+                  cairo_move_to(c,xp+2.5,yp+4.5);
+                  cairo_line_to(c,xp+6.5,yp+4.5);
+                  cairo_stroke_preserve(c);
+                  cairo_set_source_rgba(c,.1,1.,.3,1.);
+                  break;
+                }
+                /*Fall through.*/
+                /*Minus:*/
+                case -1:{
+                  cairo_move_to(c,xp+2.5,yp+4.5);
+                  cairo_line_to(c,xp+6.5,yp+4.5);
+                  cairo_stroke_preserve(c);
+                  cairo_set_source_rgba(c,1.,.3,.1,1.);
+                }break;
+                default:continue;
+              }
+              cairo_set_line_width(c,1.);
+              cairo_stroke(c);
+            }
+          }
+        }
+        col2++;
+        if((col2>>1)>=_dec->state.nhmbs){
+          col2=0;
+          row2+=2;
+        }
+      }
+      /*Bit usage indicator[s]:*/
+      if(_dec->telemetry_bits){
+        int widths[6];
+        int fpsn;
+        int fpsd;
+        int mult;
+        int fullw;
+        int padw;
+        int i;
+        fpsn=_dec->state.info.fps_numerator;
+        fpsd=_dec->state.info.fps_denominator;
+        mult=(_dec->telemetry_bits>=0xFF?1:_dec->telemetry_bits);
+        fullw=250.f*h*fpsd*mult/fpsn;
+        padw=w-24;
+        /*Header and coded block bits.*/
+        if(_dec->telemetry_frame_bytes<0||
+         _dec->telemetry_frame_bytes==OC_LOTS_OF_BITS){
+          _dec->telemetry_frame_bytes=0;
+        }
+        if(_dec->telemetry_coding_bytes<0||
+         _dec->telemetry_coding_bytes>_dec->telemetry_frame_bytes){
+          _dec->telemetry_coding_bytes=0;
+        }
+        if(_dec->telemetry_mode_bytes<0||
+         _dec->telemetry_mode_bytes>_dec->telemetry_frame_bytes){
+          _dec->telemetry_mode_bytes=0;
+        }
+        if(_dec->telemetry_mv_bytes<0||
+         _dec->telemetry_mv_bytes>_dec->telemetry_frame_bytes){
+          _dec->telemetry_mv_bytes=0;
+        }
+        if(_dec->telemetry_qi_bytes<0||
+         _dec->telemetry_qi_bytes>_dec->telemetry_frame_bytes){
+          _dec->telemetry_qi_bytes=0;
+        }
+        if(_dec->telemetry_dc_bytes<0||
+         _dec->telemetry_dc_bytes>_dec->telemetry_frame_bytes){
+          _dec->telemetry_dc_bytes=0;
+        }
+        widths[0]=padw*(_dec->telemetry_frame_bytes-_dec->telemetry_coding_bytes)/fullw;
+        widths[1]=padw*(_dec->telemetry_coding_bytes-_dec->telemetry_mode_bytes)/fullw;
+        widths[2]=padw*(_dec->telemetry_mode_bytes-_dec->telemetry_mv_bytes)/fullw;
+        widths[3]=padw*(_dec->telemetry_mv_bytes-_dec->telemetry_qi_bytes)/fullw;
+        widths[4]=padw*(_dec->telemetry_qi_bytes-_dec->telemetry_dc_bytes)/fullw;
+        widths[5]=padw*(_dec->telemetry_dc_bytes)/fullw;
+        for(i=0;i<6;i++)if(widths[i]>w)widths[i]=w;
+        cairo_set_source_rgba(c,.0,.0,.0,.6);
+        cairo_rectangle(c,10,h-33,widths[0]+1,5);
+        cairo_rectangle(c,10,h-29,widths[1]+1,5);
+        cairo_rectangle(c,10,h-25,widths[2]+1,5);
+        cairo_rectangle(c,10,h-21,widths[3]+1,5);
+        cairo_rectangle(c,10,h-17,widths[4]+1,5);
+        cairo_rectangle(c,10,h-13,widths[5]+1,5);
+        cairo_fill(c);
+        cairo_set_source_rgb(c,1,0,0);
+        cairo_rectangle(c,10.5,h-32.5,widths[0],4);
+        cairo_fill(c);
+        cairo_set_source_rgb(c,0,1,0);
+        cairo_rectangle(c,10.5,h-28.5,widths[1],4);
+        cairo_fill(c);
+        cairo_set_source_rgb(c,0,0,1);
+        cairo_rectangle(c,10.5,h-24.5,widths[2],4);
+        cairo_fill(c);
+        cairo_set_source_rgb(c,.6,.4,.0);
+        cairo_rectangle(c,10.5,h-20.5,widths[3],4);
+        cairo_fill(c);
+        cairo_set_source_rgb(c,.3,.3,.3);
+        cairo_rectangle(c,10.5,h-16.5,widths[4],4);
+        cairo_fill(c);
+        cairo_set_source_rgb(c,.5,.5,.8);
+        cairo_rectangle(c,10.5,h-12.5,widths[5],4);
+        cairo_fill(c);
+      }
+      /*Master qi indicator[s]:*/
+      if(_dec->telemetry_qi&0x1){
+        cairo_text_extents_t extents;
+        char                 buffer[10];
+        int                  p;
+        int                  y;
+        p=0;
+        y=h-7.5;
+        if(_dec->state.qis[0]>=10)buffer[p++]=48+_dec->state.qis[0]/10;
+        buffer[p++]=48+_dec->state.qis[0]%10;
+        if(_dec->state.nqis>=2){
+          buffer[p++]=' ';
+          if(_dec->state.qis[1]>=10)buffer[p++]=48+_dec->state.qis[1]/10;
+          buffer[p++]=48+_dec->state.qis[1]%10;
+        }
+        if(_dec->state.nqis==3){
+          buffer[p++]=' ';
+          if(_dec->state.qis[2]>=10)buffer[p++]=48+_dec->state.qis[2]/10;
+          buffer[p++]=48+_dec->state.qis[2]%10;
+        }
+        buffer[p++]='\0';
+        cairo_select_font_face(c,"sans",
+         CAIRO_FONT_SLANT_NORMAL,CAIRO_FONT_WEIGHT_BOLD);
+        cairo_set_font_size(c,18);
+        cairo_text_extents(c,buffer,&extents);
+        cairo_set_source_rgb(c,1,1,1);
+        cairo_move_to(c,w-extents.x_advance-10,y);
+        cairo_show_text(c,buffer);
+        cairo_set_source_rgb(c,0,0,0);
+        cairo_move_to(c,w-extents.x_advance-10,y);
+        cairo_text_path(c,buffer);
+        cairo_set_line_width(c,.8);
+        cairo_set_line_join(c,CAIRO_LINE_JOIN_ROUND);
+        cairo_stroke(c);
+      }
+      cairo_destroy(c);
+    }
+    /*Out of the Cairo plane into the telemetry YUV buffer.*/
+    _ycbcr[0].data=_dec->telemetry_frame_data;
+    _ycbcr[0].stride=_ycbcr[0].width;
+    _ycbcr[1].data=_ycbcr[0].data+h*_ycbcr[0].stride;
+    _ycbcr[1].stride=_ycbcr[1].width;
+    _ycbcr[2].data=_ycbcr[1].data+(h>>vdec)*_ycbcr[1].stride;
+    _ycbcr[2].stride=_ycbcr[2].width;
+    y_row=_ycbcr[0].data;
+    u_row=_ycbcr[1].data;
+    v_row=_ycbcr[2].data;
+    rgb_row=data;
+    /*This is one of the few places it's worth handling chroma on a
+       case-by-case basis.*/
+    switch(_dec->state.info.pixel_fmt){
+      case TH_PF_420:{
+        for(y=0;y<h;y+=2){
+          unsigned char *y_row2;
+          unsigned char *rgb_row2;
+          y_row2=y_row+_ycbcr[0].stride;
+          rgb_row2=rgb_row+cstride;
+          for(x=0;x<w;x+=2){
+            int y;
+            int u;
+            int v;
+            y=(65481*rgb_row[4*x+2]+128553*rgb_row[4*x+1]
+             +24966*rgb_row[4*x+0]+4207500)/255000;
+            y_row[x]=OC_CLAMP255(y);
+            y=(65481*rgb_row[4*x+6]+128553*rgb_row[4*x+5]
+             +24966*rgb_row[4*x+4]+4207500)/255000;
+            y_row[x+1]=OC_CLAMP255(y);
+            y=(65481*rgb_row2[4*x+2]+128553*rgb_row2[4*x+1]
+             +24966*rgb_row2[4*x+0]+4207500)/255000;
+            y_row2[x]=OC_CLAMP255(y);
+            y=(65481*rgb_row2[4*x+6]+128553*rgb_row2[4*x+5]
+             +24966*rgb_row2[4*x+4]+4207500)/255000;
+            y_row2[x+1]=OC_CLAMP255(y);
+            u=(-8372*(rgb_row[4*x+2]+rgb_row[4*x+6]
+             +rgb_row2[4*x+2]+rgb_row2[4*x+6])
+             -16436*(rgb_row[4*x+1]+rgb_row[4*x+5]
+             +rgb_row2[4*x+1]+rgb_row2[4*x+5])
+             +24808*(rgb_row[4*x+0]+rgb_row[4*x+4]
+             +rgb_row2[4*x+0]+rgb_row2[4*x+4])+29032005)/225930;
+            v=(39256*(rgb_row[4*x+2]+rgb_row[4*x+6]
+             +rgb_row2[4*x+2]+rgb_row2[4*x+6])
+             -32872*(rgb_row[4*x+1]+rgb_row[4*x+5]
+              +rgb_row2[4*x+1]+rgb_row2[4*x+5])
+             -6384*(rgb_row[4*x+0]+rgb_row[4*x+4]
+              +rgb_row2[4*x+0]+rgb_row2[4*x+4])+45940035)/357510;
+            u_row[x>>1]=OC_CLAMP255(u);
+            v_row[x>>1]=OC_CLAMP255(v);
+          }
+          y_row+=_ycbcr[0].stride<<1;
+          u_row+=_ycbcr[1].stride;
+          v_row+=_ycbcr[2].stride;
+          rgb_row+=cstride<<1;
+        }
+      }break;
+      case TH_PF_422:{
+        for(y=0;y<h;y++){
+          for(x=0;x<w;x+=2){
+            int y;
+            int u;
+            int v;
+            y=(65481*rgb_row[4*x+2]+128553*rgb_row[4*x+1]
+             +24966*rgb_row[4*x+0]+4207500)/255000;
+            y_row[x]=OC_CLAMP255(y);
+            y=(65481*rgb_row[4*x+6]+128553*rgb_row[4*x+5]
+             +24966*rgb_row[4*x+4]+4207500)/255000;
+            y_row[x+1]=OC_CLAMP255(y);
+            u=(-16744*(rgb_row[4*x+2]+rgb_row[4*x+6])
+             -32872*(rgb_row[4*x+1]+rgb_row[4*x+5])
+             +49616*(rgb_row[4*x+0]+rgb_row[4*x+4])+29032005)/225930;
+            v=(78512*(rgb_row[4*x+2]+rgb_row[4*x+6])
+             -65744*(rgb_row[4*x+1]+rgb_row[4*x+5])
+             -12768*(rgb_row[4*x+0]+rgb_row[4*x+4])+45940035)/357510;
+            u_row[x>>1]=OC_CLAMP255(u);
+            v_row[x>>1]=OC_CLAMP255(v);
+          }
+          y_row+=_ycbcr[0].stride;
+          u_row+=_ycbcr[1].stride;
+          v_row+=_ycbcr[2].stride;
+          rgb_row+=cstride;
+        }
+      }break;
+      /*case TH_PF_444:*/
+      default:{
+        for(y=0;y<h;y++){
+          for(x=0;x<w;x++){
+            int y;
+            int u;
+            int v;
+            y=(65481*rgb_row[4*x+2]+128553*rgb_row[4*x+1]
+             +24966*rgb_row[4*x+0]+4207500)/255000;
+            u=(-33488*rgb_row[4*x+2]-65744*rgb_row[4*x+1]
+             +99232*rgb_row[4*x+0]+29032005)/225930;
+            v=(157024*rgb_row[4*x+2]-131488*rgb_row[4*x+1]
+             -25536*rgb_row[4*x+0]+45940035)/357510;
+            y_row[x]=OC_CLAMP255(y);
+            u_row[x]=OC_CLAMP255(u);
+            v_row[x]=OC_CLAMP255(v);
+          }
+          y_row+=_ycbcr[0].stride;
+          u_row+=_ycbcr[1].stride;
+          v_row+=_ycbcr[2].stride;
+          rgb_row+=cstride;
+        }
+      }break;
+    }
+    /*Finished.
+      Destroy the surface.*/
+    cairo_surface_destroy(cs);
+  }
+#endif
+  return 0;
+}
diff --git a/lib/dequant.c b/lib/dequant.c
new file mode 100644 (file)
index 0000000..e554872
--- /dev/null
@@ -0,0 +1,182 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: dequant.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+#include "dequant.h"
+#include "decint.h"
+
+int oc_quant_params_unpack(oc_pack_buf *_opb,th_quant_info *_qinfo){
+  th_quant_base *base_mats;
+  long           val;
+  int            nbase_mats;
+  int            sizes[64];
+  int            indices[64];
+  int            nbits;
+  int            bmi;
+  int            ci;
+  int            qti;
+  int            pli;
+  int            qri;
+  int            qi;
+  int            i;
+  val=oc_pack_read(_opb,3);
+  nbits=(int)val;
+  for(qi=0;qi<64;qi++){
+    val=oc_pack_read(_opb,nbits);
+    _qinfo->loop_filter_limits[qi]=(unsigned char)val;
+  }
+  val=oc_pack_read(_opb,4);
+  nbits=(int)val+1;
+  for(qi=0;qi<64;qi++){
+    val=oc_pack_read(_opb,nbits);
+    _qinfo->ac_scale[qi]=(ogg_uint16_t)val;
+  }
+  val=oc_pack_read(_opb,4);
+  nbits=(int)val+1;
+  for(qi=0;qi<64;qi++){
+    val=oc_pack_read(_opb,nbits);
+    _qinfo->dc_scale[qi]=(ogg_uint16_t)val;
+  }
+  val=oc_pack_read(_opb,9);
+  nbase_mats=(int)val+1;
+  base_mats=_ogg_malloc(nbase_mats*sizeof(base_mats[0]));
+  if(base_mats==NULL)return TH_EFAULT;
+  for(bmi=0;bmi<nbase_mats;bmi++){
+    for(ci=0;ci<64;ci++){
+      val=oc_pack_read(_opb,8);
+      base_mats[bmi][ci]=(unsigned char)val;
+    }
+  }
+  nbits=oc_ilog(nbase_mats-1);
+  for(i=0;i<6;i++){
+    th_quant_ranges *qranges;
+    th_quant_base   *qrbms;
+    int             *qrsizes;
+    qti=i/3;
+    pli=i%3;
+    qranges=_qinfo->qi_ranges[qti]+pli;
+    if(i>0){
+      val=oc_pack_read1(_opb);
+      if(!val){
+        int qtj;
+        int plj;
+        if(qti>0){
+          val=oc_pack_read1(_opb);
+          if(val){
+            qtj=qti-1;
+            plj=pli;
+          }
+          else{
+            qtj=(i-1)/3;
+            plj=(i-1)%3;
+          }
+        }
+        else{
+          qtj=(i-1)/3;
+          plj=(i-1)%3;
+        }
+        *qranges=*(_qinfo->qi_ranges[qtj]+plj);
+        continue;
+      }
+    }
+    val=oc_pack_read(_opb,nbits);
+    indices[0]=(int)val;
+    for(qi=qri=0;qi<63;){
+      val=oc_pack_read(_opb,oc_ilog(62-qi));
+      sizes[qri]=(int)val+1;
+      qi+=(int)val+1;
+      val=oc_pack_read(_opb,nbits);
+      indices[++qri]=(int)val;
+    }
+    /*Note: The caller is responsible for cleaning up any partially
+       constructed qinfo.*/
+    if(qi>63){
+      _ogg_free(base_mats);
+      return TH_EBADHEADER;
+    }
+    qranges->nranges=qri;
+    qranges->sizes=qrsizes=(int *)_ogg_malloc(qri*sizeof(qrsizes[0]));
+    if(qranges->sizes==NULL){
+      /*Note: The caller is responsible for cleaning up any partially
+         constructed qinfo.*/
+      _ogg_free(base_mats);
+      return TH_EFAULT;
+    }
+    memcpy(qrsizes,sizes,qri*sizeof(qrsizes[0]));
+    qrbms=(th_quant_base *)_ogg_malloc((qri+1)*sizeof(qrbms[0]));
+    if(qrbms==NULL){
+      /*Note: The caller is responsible for cleaning up any partially
+         constructed qinfo.*/
+      _ogg_free(base_mats);
+      return TH_EFAULT;
+    }
+    qranges->base_matrices=(const th_quant_base *)qrbms;
+    do{
+      bmi=indices[qri];
+      /*Note: The caller is responsible for cleaning up any partially
+         constructed qinfo.*/
+      if(bmi>=nbase_mats){
+        _ogg_free(base_mats);
+        return TH_EBADHEADER;
+      }
+      memcpy(qrbms[qri],base_mats[bmi],sizeof(qrbms[qri]));
+    }
+    while(qri-->0);
+  }
+  _ogg_free(base_mats);
+  return 0;
+}
+
+void oc_quant_params_clear(th_quant_info *_qinfo){
+  int i;
+  for(i=6;i-->0;){
+    int qti;
+    int pli;
+    qti=i/3;
+    pli=i%3;
+    /*Clear any duplicate pointer references.*/
+    if(i>0){
+      int qtj;
+      int plj;
+      qtj=(i-1)/3;
+      plj=(i-1)%3;
+      if(_qinfo->qi_ranges[qti][pli].sizes==
+       _qinfo->qi_ranges[qtj][plj].sizes){
+        _qinfo->qi_ranges[qti][pli].sizes=NULL;
+      }
+      if(_qinfo->qi_ranges[qti][pli].base_matrices==
+       _qinfo->qi_ranges[qtj][plj].base_matrices){
+        _qinfo->qi_ranges[qti][pli].base_matrices=NULL;
+      }
+    }
+    if(qti>0){
+      if(_qinfo->qi_ranges[1][pli].sizes==
+       _qinfo->qi_ranges[0][pli].sizes){
+        _qinfo->qi_ranges[1][pli].sizes=NULL;
+      }
+      if(_qinfo->qi_ranges[1][pli].base_matrices==
+       _qinfo->qi_ranges[0][pli].base_matrices){
+        _qinfo->qi_ranges[1][pli].base_matrices=NULL;
+      }
+    }
+    /*Now free all the non-duplicate storage.*/
+    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].sizes);
+    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].base_matrices);
+  }
+}
diff --git a/lib/dequant.h b/lib/dequant.h
new file mode 100644 (file)
index 0000000..ef25838
--- /dev/null
@@ -0,0 +1,27 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: dequant.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#if !defined(_dequant_H)
+# define _dequant_H (1)
+# include "quant.h"
+# include "bitpack.h"
+
+int oc_quant_params_unpack(oc_pack_buf *_opb,
+ th_quant_info *_qinfo);
+void oc_quant_params_clear(th_quant_info *_qinfo);
+
+#endif
diff --git a/lib/encapiwrapper.c b/lib/encapiwrapper.c
new file mode 100644 (file)
index 0000000..874f124
--- /dev/null
@@ -0,0 +1,168 @@
+#include <stdlib.h>
+#include <string.h>
+#include <limits.h>
+#include "apiwrapper.h"
+#include "encint.h"
+#include "theora/theoraenc.h"
+
+
+
+static void th_enc_api_clear(th_api_wrapper *_api){
+  if(_api->encode)th_encode_free(_api->encode);
+  memset(_api,0,sizeof(*_api));
+}
+
+static void theora_encode_clear(theora_state *_te){
+  if(_te->i!=NULL)theora_info_clear(_te->i);
+  memset(_te,0,sizeof(*_te));
+}
+
+static int theora_encode_control(theora_state *_te,int _req,
+ void *_buf,size_t _buf_sz){
+  return th_encode_ctl(((th_api_wrapper *)_te->i->codec_setup)->encode,
+   _req,_buf,_buf_sz);
+}
+
+static ogg_int64_t theora_encode_granule_frame(theora_state *_te,
+ ogg_int64_t _gp){
+  return th_granule_frame(((th_api_wrapper *)_te->i->codec_setup)->encode,_gp);
+}
+
+static double theora_encode_granule_time(theora_state *_te,ogg_int64_t _gp){
+  return th_granule_time(((th_api_wrapper *)_te->i->codec_setup)->encode,_gp);
+}
+
+static const oc_state_dispatch_vtable OC_ENC_DISPATCH_VTBL={
+  (oc_state_clear_func)theora_encode_clear,
+  (oc_state_control_func)theora_encode_control,
+  (oc_state_granule_frame_func)theora_encode_granule_frame,
+  (oc_state_granule_time_func)theora_encode_granule_time,
+};
+
+int theora_encode_init(theora_state *_te,theora_info *_ci){
+  th_api_info *apiinfo;
+  th_info      info;
+  ogg_uint32_t keyframe_frequency_force;
+  /*Allocate our own combined API wrapper/theora_info struct.
+    We put them both in one malloc'd block so that when the API wrapper is
+     freed, the info struct goes with it.
+    This avoids having to figure out whether or not we need to free the info
+     struct in either theora_info_clear() or theora_clear().*/
+  apiinfo=(th_api_info *)_ogg_malloc(sizeof(*apiinfo));
+  if(apiinfo==NULL)return TH_EFAULT;
+  /*Make our own copy of the info struct, since its lifetime should be
+     independent of the one we were passed in.*/
+  *&apiinfo->info=*_ci;
+  oc_theora_info2th_info(&info,_ci);
+  apiinfo->api.encode=th_encode_alloc(&info);
+  if(apiinfo->api.encode==NULL){
+    _ogg_free(apiinfo);
+    return OC_EINVAL;
+  }
+  apiinfo->api.clear=(oc_setup_clear_func)th_enc_api_clear;
+  /*Provide entry points for ABI compatibility with old decoder shared libs.*/
+  _te->internal_encode=(void *)&OC_ENC_DISPATCH_VTBL;
+  _te->internal_decode=NULL;
+  _te->granulepos=0;
+  _te->i=&apiinfo->info;
+  _te->i->codec_setup=&apiinfo->api;
+  /*Set the precise requested keyframe frequency.*/
+  keyframe_frequency_force=_ci->keyframe_auto_p?
+   _ci->keyframe_frequency_force:_ci->keyframe_frequency;
+  th_encode_ctl(apiinfo->api.encode,
+   TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE,
+   &keyframe_frequency_force,sizeof(keyframe_frequency_force));
+  /*TODO: Additional codec setup using the extra fields in theora_info.*/
+  return 0;
+}
+
+int theora_encode_YUVin(theora_state *_te,yuv_buffer *_yuv){
+  th_api_wrapper  *api;
+  th_ycbcr_buffer  buf;
+  int              ret;
+  api=(th_api_wrapper *)_te->i->codec_setup;
+  buf[0].width=_yuv->y_width;
+  buf[0].height=_yuv->y_height;
+  buf[0].stride=_yuv->y_stride;
+  buf[0].data=_yuv->y;
+  buf[1].width=_yuv->uv_width;
+  buf[1].height=_yuv->uv_height;
+  buf[1].stride=_yuv->uv_stride;
+  buf[1].data=_yuv->u;
+  buf[2].width=_yuv->uv_width;
+  buf[2].height=_yuv->uv_height;
+  buf[2].stride=_yuv->uv_stride;
+  buf[2].data=_yuv->v;
+  ret=th_encode_ycbcr_in(api->encode,buf);
+  if(ret<0)return ret;
+  _te->granulepos=api->encode->state.granpos;
+  return ret;
+}
+
+int theora_encode_packetout(theora_state *_te,int _last_p,ogg_packet *_op){
+  th_api_wrapper *api;
+  api=(th_api_wrapper *)_te->i->codec_setup;
+  return th_encode_packetout(api->encode,_last_p,_op);
+}
+
+int theora_encode_header(theora_state *_te,ogg_packet *_op){
+  oc_enc_ctx     *enc;
+  th_api_wrapper *api;
+  int             ret;
+  api=(th_api_wrapper *)_te->i->codec_setup;
+  enc=api->encode;
+  /*If we've already started encoding, fail.*/
+  if(enc->packet_state>OC_PACKET_EMPTY||enc->state.granpos!=0){
+    return TH_EINVAL;
+  }
+  /*Reset the state to make sure we output an info packet.*/
+  enc->packet_state=OC_PACKET_INFO_HDR;
+  ret=th_encode_flushheader(api->encode,NULL,_op);
+  return ret>=0?0:ret;
+}
+
+int theora_encode_comment(theora_comment *_tc,ogg_packet *_op){
+  oggpack_buffer  opb;
+  void           *buf;
+  int             packet_state;
+  int             ret;
+  packet_state=OC_PACKET_COMMENT_HDR;
+  oggpackB_writeinit(&opb);
+  ret=oc_state_flushheader(NULL,&packet_state,&opb,NULL,NULL,
+   th_version_string(),(th_comment *)_tc,_op);
+  if(ret>=0){
+    /*The oggpack_buffer's lifetime ends with this function, so we have to
+       copy out the packet contents.
+      Presumably the application knows it is supposed to free this.
+      This part works nothing like the Vorbis API, and the documentation on it
+       has been wrong for some time, claiming libtheora owned the memory.*/
+    buf=_ogg_malloc(_op->bytes);
+    if(buf==NULL){
+      _op->packet=NULL;
+      ret=TH_EFAULT;
+    }
+    else{
+      memcpy(buf,_op->packet,_op->bytes);
+      _op->packet=buf;
+      ret=0;
+    }
+  }
+  oggpack_writeclear(&opb);
+  return ret;
+}
+
+int theora_encode_tables(theora_state *_te,ogg_packet *_op){
+  oc_enc_ctx     *enc;
+  th_api_wrapper *api;
+  int             ret;
+  api=(th_api_wrapper *)_te->i->codec_setup;
+  enc=api->encode;
+  /*If we've already started encoding, fail.*/
+  if(enc->packet_state>OC_PACKET_EMPTY||enc->state.granpos!=0){
+    return TH_EINVAL;
+  }
+  /*Reset the state to make sure we output a setup packet.*/
+  enc->packet_state=OC_PACKET_SETUP_HDR;
+  ret=th_encode_flushheader(api->encode,NULL,_op);
+  return ret>=0?0:ret;
+}
diff --git a/lib/encfrag.c b/lib/encfrag.c
new file mode 100644 (file)
index 0000000..bb814c8
--- /dev/null
@@ -0,0 +1,388 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: encfrag.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include <stdlib.h>
+#include <string.h>
+#include "encint.h"
+
+
+void oc_enc_frag_sub(const oc_enc_ctx *_enc,ogg_int16_t _diff[64],
+ const unsigned char *_src,const unsigned char *_ref,int _ystride){
+  (*_enc->opt_vtable.frag_sub)(_diff,_src,_ref,_ystride);
+}
+
+void oc_enc_frag_sub_c(ogg_int16_t _diff[64],const unsigned char *_src,
+ const unsigned char *_ref,int _ystride){
+  int i;
+  for(i=0;i<8;i++){
+    int j;
+    for(j=0;j<8;j++)_diff[i*8+j]=(ogg_int16_t)(_src[j]-_ref[j]);
+    _src+=_ystride;
+    _ref+=_ystride;
+  }
+}
+
+void oc_enc_frag_sub_128(const oc_enc_ctx *_enc,ogg_int16_t _diff[64],
+ const unsigned char *_src,int _ystride){
+  (*_enc->opt_vtable.frag_sub_128)(_diff,_src,_ystride);
+}
+
+void oc_enc_frag_sub_128_c(ogg_int16_t *_diff,
+ const unsigned char *_src,int _ystride){
+  int i;
+  for(i=0;i<8;i++){
+    int j;
+    for(j=0;j<8;j++)_diff[i*8+j]=(ogg_int16_t)(_src[j]-128);
+    _src+=_ystride;
+  }
+}
+
+unsigned oc_enc_frag_sad(const oc_enc_ctx *_enc,const unsigned char *_x,
+ const unsigned char *_y,int _ystride){
+  return (*_enc->opt_vtable.frag_sad)(_x,_y,_ystride);
+}
+
+unsigned oc_enc_frag_sad_c(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride){
+  unsigned sad;
+  int      i;
+  sad=0;
+  for(i=8;i-->0;){
+    int j;
+    for(j=0;j<8;j++)sad+=abs(_src[j]-_ref[j]);
+    _src+=_ystride;
+    _ref+=_ystride;
+  }
+  return sad;
+}
+
+unsigned oc_enc_frag_sad_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref,int _ystride,
+ unsigned _thresh){
+  return (*_enc->opt_vtable.frag_sad_thresh)(_src,_ref,_ystride,_thresh);
+}
+
+unsigned oc_enc_frag_sad_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh){
+  unsigned sad;
+  int      i;
+  sad=0;
+  for(i=8;i-->0;){
+    int j;
+    for(j=0;j<8;j++)sad+=abs(_src[j]-_ref[j]);
+    if(sad>_thresh)break;
+    _src+=_ystride;
+    _ref+=_ystride;
+  }
+  return sad;
+}
+
+unsigned oc_enc_frag_sad2_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref1,
+ const unsigned char *_ref2,int _ystride,unsigned _thresh){
+  return (*_enc->opt_vtable.frag_sad2_thresh)(_src,_ref1,_ref2,_ystride,
+   _thresh);
+}
+
+unsigned oc_enc_frag_sad2_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh){
+  unsigned sad;
+  int      i;
+  sad=0;
+  for(i=8;i-->0;){
+    int j;
+    for(j=0;j<8;j++)sad+=abs(_src[j]-(_ref1[j]+_ref2[j]>>1));
+    if(sad>_thresh)break;
+    _src+=_ystride;
+    _ref1+=_ystride;
+    _ref2+=_ystride;
+  }
+  return sad;
+}
+
+static void oc_diff_hadamard(ogg_int16_t _buf[64],const unsigned char *_src,
+ const unsigned char *_ref,int _ystride){
+  int i;
+  for(i=0;i<8;i++){
+    int t0;
+    int t1;
+    int t2;
+    int t3;
+    int t4;
+    int t5;
+    int t6;
+    int t7;
+    int r;
+    /*Hadamard stage 1:*/
+    t0=_src[0]-_ref[0]+_src[4]-_ref[4];
+    t4=_src[0]-_ref[0]-_src[4]+_ref[4];
+    t1=_src[1]-_ref[1]+_src[5]-_ref[5];
+    t5=_src[1]-_ref[1]-_src[5]+_ref[5];
+    t2=_src[2]-_ref[2]+_src[6]-_ref[6];
+    t6=_src[2]-_ref[2]-_src[6]+_ref[6];
+    t3=_src[3]-_ref[3]+_src[7]-_ref[7];
+    t7=_src[3]-_ref[3]-_src[7]+_ref[7];
+    /*Hadamard stage 2:*/
+    r=t0;
+    t0+=t2;
+    t2=r-t2;
+    r=t1;
+    t1+=t3;
+    t3=r-t3;
+    r=t4;
+    t4+=t6;
+    t6=r-t6;
+    r=t5;
+    t5+=t7;
+    t7=r-t7;
+    /*Hadamard stage 3:*/
+    _buf[0*8+i]=(ogg_int16_t)(t0+t1);
+    _buf[1*8+i]=(ogg_int16_t)(t0-t1);
+    _buf[2*8+i]=(ogg_int16_t)(t2+t3);
+    _buf[3*8+i]=(ogg_int16_t)(t2-t3);
+    _buf[4*8+i]=(ogg_int16_t)(t4+t5);
+    _buf[5*8+i]=(ogg_int16_t)(t4-t5);
+    _buf[6*8+i]=(ogg_int16_t)(t6+t7);
+    _buf[7*8+i]=(ogg_int16_t)(t6-t7);
+    _src+=_ystride;
+    _ref+=_ystride;
+  }
+}
+
+static void oc_diff_hadamard2(ogg_int16_t _buf[64],const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride){
+  int i;
+  for(i=0;i<8;i++){
+    int t0;
+    int t1;
+    int t2;
+    int t3;
+    int t4;
+    int t5;
+    int t6;
+    int t7;
+    int r;
+    /*Hadamard stage 1:*/
+    r=_ref1[0]+_ref2[0]>>1;
+    t4=_ref1[4]+_ref2[4]>>1;
+    t0=_src[0]-r+_src[4]-t4;
+    t4=_src[0]-r-_src[4]+t4;
+    r=_ref1[1]+_ref2[1]>>1;
+    t5=_ref1[5]+_ref2[5]>>1;
+    t1=_src[1]-r+_src[5]-t5;
+    t5=_src[1]-r-_src[5]+t5;
+    r=_ref1[2]+_ref2[2]>>1;
+    t6=_ref1[6]+_ref2[6]>>1;
+    t2=_src[2]-r+_src[6]-t6;
+    t6=_src[2]-r-_src[6]+t6;
+    r=_ref1[3]+_ref2[3]>>1;
+    t7=_ref1[7]+_ref2[7]>>1;
+    t3=_src[3]-r+_src[7]-t7;
+    t7=_src[3]-r-_src[7]+t7;
+    /*Hadamard stage 2:*/
+    r=t0;
+    t0+=t2;
+    t2=r-t2;
+    r=t1;
+    t1+=t3;
+    t3=r-t3;
+    r=t4;
+    t4+=t6;
+    t6=r-t6;
+    r=t5;
+    t5+=t7;
+    t7=r-t7;
+    /*Hadamard stage 3:*/
+    _buf[0*8+i]=(ogg_int16_t)(t0+t1);
+    _buf[1*8+i]=(ogg_int16_t)(t0-t1);
+    _buf[2*8+i]=(ogg_int16_t)(t2+t3);
+    _buf[3*8+i]=(ogg_int16_t)(t2-t3);
+    _buf[4*8+i]=(ogg_int16_t)(t4+t5);
+    _buf[5*8+i]=(ogg_int16_t)(t4-t5);
+    _buf[6*8+i]=(ogg_int16_t)(t6+t7);
+    _buf[7*8+i]=(ogg_int16_t)(t6-t7);
+    _src+=_ystride;
+    _ref1+=_ystride;
+    _ref2+=_ystride;
+  }
+}
+
+static void oc_intra_hadamard(ogg_int16_t _buf[64],const unsigned char *_src,
+ int _ystride){
+  int i;
+  for(i=0;i<8;i++){
+    int t0;
+    int t1;
+    int t2;
+    int t3;
+    int t4;
+    int t5;
+    int t6;
+    int t7;
+    int r;
+    /*Hadamard stage 1:*/
+    t0=_src[0]+_src[4];
+    t4=_src[0]-_src[4];
+    t1=_src[1]+_src[5];
+    t5=_src[1]-_src[5];
+    t2=_src[2]+_src[6];
+    t6=_src[2]-_src[6];
+    t3=_src[3]+_src[7];
+    t7=_src[3]-_src[7];
+    /*Hadamard stage 2:*/
+    r=t0;
+    t0+=t2;
+    t2=r-t2;
+    r=t1;
+    t1+=t3;
+    t3=r-t3;
+    r=t4;
+    t4+=t6;
+    t6=r-t6;
+    r=t5;
+    t5+=t7;
+    t7=r-t7;
+    /*Hadamard stage 3:*/
+    _buf[0*8+i]=(ogg_int16_t)(t0+t1);
+    _buf[1*8+i]=(ogg_int16_t)(t0-t1);
+    _buf[2*8+i]=(ogg_int16_t)(t2+t3);
+    _buf[3*8+i]=(ogg_int16_t)(t2-t3);
+    _buf[4*8+i]=(ogg_int16_t)(t4+t5);
+    _buf[5*8+i]=(ogg_int16_t)(t4-t5);
+    _buf[6*8+i]=(ogg_int16_t)(t6+t7);
+    _buf[7*8+i]=(ogg_int16_t)(t6-t7);
+    _src+=_ystride;
+  }
+}
+
+unsigned oc_hadamard_sad_thresh(const ogg_int16_t _buf[64],unsigned _thresh){
+  unsigned    sad;
+  int         t0;
+  int         t1;
+  int         t2;
+  int         t3;
+  int         t4;
+  int         t5;
+  int         t6;
+  int         t7;
+  int         r;
+  int         i;
+  sad=0;
+  for(i=0;i<8;i++){
+    /*Hadamard stage 1:*/
+    t0=_buf[i*8+0]+_buf[i*8+4];
+    t4=_buf[i*8+0]-_buf[i*8+4];
+    t1=_buf[i*8+1]+_buf[i*8+5];
+    t5=_buf[i*8+1]-_buf[i*8+5];
+    t2=_buf[i*8+2]+_buf[i*8+6];
+    t6=_buf[i*8+2]-_buf[i*8+6];
+    t3=_buf[i*8+3]+_buf[i*8+7];
+    t7=_buf[i*8+3]-_buf[i*8+7];
+    /*Hadamard stage 2:*/
+    r=t0;
+    t0+=t2;
+    t2=r-t2;
+    r=t1;
+    t1+=t3;
+    t3=r-t3;
+    r=t4;
+    t4+=t6;
+    t6=r-t6;
+    r=t5;
+    t5+=t7;
+    t7=r-t7;
+    /*Hadamard stage 3:*/
+    r=abs(t0+t1);
+    r+=abs(t0-t1);
+    r+=abs(t2+t3);
+    r+=abs(t2-t3);
+    r+=abs(t4+t5);
+    r+=abs(t4-t5);
+    r+=abs(t6+t7);
+    r+=abs(t6-t7);
+    sad+=r;
+    if(sad>_thresh)break;
+  }
+  return sad;
+}
+
+unsigned oc_enc_frag_satd_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref,int _ystride,
+ unsigned _thresh){
+  return (*_enc->opt_vtable.frag_satd_thresh)(_src,_ref,_ystride,_thresh);
+}
+
+unsigned oc_enc_frag_satd_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh){
+  ogg_int16_t buf[64];
+  oc_diff_hadamard(buf,_src,_ref,_ystride);
+  return oc_hadamard_sad_thresh(buf,_thresh);
+}
+
+unsigned oc_enc_frag_satd2_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref1,
+ const unsigned char *_ref2,int _ystride,unsigned _thresh){
+  return (*_enc->opt_vtable.frag_satd2_thresh)(_src,_ref1,_ref2,_ystride,
+   _thresh);
+}
+
+unsigned oc_enc_frag_satd2_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh){
+  ogg_int16_t buf[64];
+  oc_diff_hadamard2(buf,_src,_ref1,_ref2,_ystride);
+  return oc_hadamard_sad_thresh(buf,_thresh);
+}
+
+unsigned oc_enc_frag_intra_satd(const oc_enc_ctx *_enc,
+ const unsigned char *_src,int _ystride){
+  return (*_enc->opt_vtable.frag_intra_satd)(_src,_ystride);
+}
+
+unsigned oc_enc_frag_intra_satd_c(const unsigned char *_src,int _ystride){
+  ogg_int16_t buf[64];
+  oc_intra_hadamard(buf,_src,_ystride);
+  return oc_hadamard_sad_thresh(buf,UINT_MAX)
+   -abs(buf[0]+buf[1]+buf[2]+buf[3]+buf[4]+buf[5]+buf[6]+buf[7]);
+}
+
+void oc_enc_frag_copy2(const oc_enc_ctx *_enc,unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride){
+  (*_enc->opt_vtable.frag_copy2)(_dst,_src1,_src2,_ystride);
+}
+
+void oc_enc_frag_copy2_c(unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride){
+  int i;
+  int j;
+  for(i=8;i-->0;){
+    for(j=0;j<8;j++)_dst[j]=_src1[j]+_src2[j]>>1;
+    _dst+=_ystride;
+    _src1+=_ystride;
+    _src2+=_ystride;
+  }
+}
+
+void oc_enc_frag_recon_intra(const oc_enc_ctx *_enc,
+ unsigned char *_dst,int _ystride,const ogg_int16_t _residue[64]){
+  (*_enc->opt_vtable.frag_recon_intra)(_dst,_ystride,_residue);
+}
+
+void oc_enc_frag_recon_inter(const oc_enc_ctx *_enc,unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]){
+  (*_enc->opt_vtable.frag_recon_inter)(_dst,_src,_ystride,_residue);
+}
diff --git a/lib/encinfo.c b/lib/encinfo.c
new file mode 100644 (file)
index 0000000..83be1da
--- /dev/null
@@ -0,0 +1,121 @@
+#include <stdlib.h>
+#include <string.h>
+#include "internal.h"
+#include "enquant.h"
+#include "huffenc.h"
+
+
+
+/*Packs a series of octets from a given byte array into the pack buffer.
+  _opb: The pack buffer to store the octets in.
+  _buf: The byte array containing the bytes to pack.
+  _len: The number of octets to pack.*/
+static void oc_pack_octets(oggpack_buffer *_opb,const char *_buf,int _len){
+  int i;
+  for(i=0;i<_len;i++)oggpackB_write(_opb,_buf[i],8);
+}
+
+
+
+int oc_state_flushheader(oc_theora_state *_state,int *_packet_state,
+ oggpack_buffer *_opb,const th_quant_info *_qinfo,
+ const th_huff_code _codes[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS],
+ const char *_vendor,th_comment *_tc,ogg_packet *_op){
+  unsigned char *packet;
+  int            b_o_s;
+  if(_op==NULL)return TH_EFAULT;
+  switch(*_packet_state){
+    /*Codec info header.*/
+    case OC_PACKET_INFO_HDR:{
+      if(_state==NULL)return TH_EFAULT;
+      oggpackB_reset(_opb);
+      /*Mark this packet as the info header.*/
+      oggpackB_write(_opb,0x80,8);
+      /*Write the codec string.*/
+      oc_pack_octets(_opb,"theora",6);
+      /*Write the codec bitstream version.*/
+      oggpackB_write(_opb,TH_VERSION_MAJOR,8);
+      oggpackB_write(_opb,TH_VERSION_MINOR,8);
+      oggpackB_write(_opb,TH_VERSION_SUB,8);
+      /*Describe the encoded frame.*/
+      oggpackB_write(_opb,_state->info.frame_width>>4,16);
+      oggpackB_write(_opb,_state->info.frame_height>>4,16);
+      oggpackB_write(_opb,_state->info.pic_width,24);
+      oggpackB_write(_opb,_state->info.pic_height,24);
+      oggpackB_write(_opb,_state->info.pic_x,8);
+      oggpackB_write(_opb,_state->info.pic_y,8);
+      oggpackB_write(_opb,_state->info.fps_numerator,32);
+      oggpackB_write(_opb,_state->info.fps_denominator,32);
+      oggpackB_write(_opb,_state->info.aspect_numerator,24);
+      oggpackB_write(_opb,_state->info.aspect_denominator,24);
+      oggpackB_write(_opb,_state->info.colorspace,8);
+      oggpackB_write(_opb,_state->info.target_bitrate,24);
+      oggpackB_write(_opb,_state->info.quality,6);
+      oggpackB_write(_opb,_state->info.keyframe_granule_shift,5);
+      oggpackB_write(_opb,_state->info.pixel_fmt,2);
+      /*Spare configuration bits.*/
+      oggpackB_write(_opb,0,3);
+      b_o_s=1;
+    }break;
+    /*Comment header.*/
+    case OC_PACKET_COMMENT_HDR:{
+      int vendor_len;
+      int i;
+      if(_tc==NULL)return TH_EFAULT;
+      vendor_len=strlen(_vendor);
+      oggpackB_reset(_opb);
+      /*Mark this packet as the comment header.*/
+      oggpackB_write(_opb,0x81,8);
+      /*Write the codec string.*/
+      oc_pack_octets(_opb,"theora",6);
+      /*Write the vendor string.*/
+      oggpack_write(_opb,vendor_len,32);
+      oc_pack_octets(_opb,_vendor,vendor_len);
+      oggpack_write(_opb,_tc->comments,32);
+      for(i=0;i<_tc->comments;i++){
+        if(_tc->user_comments[i]!=NULL){
+          oggpack_write(_opb,_tc->comment_lengths[i],32);
+          oc_pack_octets(_opb,_tc->user_comments[i],_tc->comment_lengths[i]);
+        }
+        else oggpack_write(_opb,0,32);
+      }
+      b_o_s=0;
+    }break;
+    /*Codec setup header.*/
+    case OC_PACKET_SETUP_HDR:{
+      int ret;
+      oggpackB_reset(_opb);
+      /*Mark this packet as the setup header.*/
+      oggpackB_write(_opb,0x82,8);
+      /*Write the codec string.*/
+      oc_pack_octets(_opb,"theora",6);
+      /*Write the quantizer tables.*/
+      oc_quant_params_pack(_opb,_qinfo);
+      /*Write the huffman codes.*/
+      ret=oc_huff_codes_pack(_opb,_codes);
+      /*This should never happen, because we validate the tables when they
+         are set.
+        If you see, it's a good chance memory is being corrupted.*/
+      if(ret<0)return ret;
+      b_o_s=0;
+    }break;
+    /*No more headers to emit.*/
+    default:return 0;
+  }
+  /*This is kind of fugly: we hand the user a buffer which they do not own.
+    We will overwrite it when the next packet is output, so the user better be
+     done with it by then.
+    Vorbis is little better: it hands back buffers that it will free the next
+     time the headers are requested, or when the encoder is cleared.
+    Hopefully libogg2 will make this much cleaner.*/
+  packet=oggpackB_get_buffer(_opb);
+  /*If there's no packet, malloc failed while writing.*/
+  if(packet==NULL)return TH_EFAULT;
+  _op->packet=packet;
+  _op->bytes=oggpackB_bytes(_opb);
+  _op->b_o_s=b_o_s;
+  _op->e_o_s=0;
+  _op->granulepos=0;
+  _op->packetno=*_packet_state+3;
+  return ++(*_packet_state)+3;
+}
diff --git a/lib/encint.h b/lib/encint.h
new file mode 100644 (file)
index 0000000..97897d5
--- /dev/null
@@ -0,0 +1,493 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: encint.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#if !defined(_encint_H)
+# define _encint_H (1)
+# if defined(HAVE_CONFIG_H)
+#  include "config.h"
+# endif
+# include "theora/theoraenc.h"
+# include "internal.h"
+# include "ocintrin.h"
+# include "mathops.h"
+# include "enquant.h"
+# include "huffenc.h"
+/*# define OC_COLLECT_METRICS*/
+
+
+
+typedef oc_mv                         oc_mv2[2];
+
+typedef struct oc_enc_opt_vtable      oc_enc_opt_vtable;
+typedef struct oc_mb_enc_info         oc_mb_enc_info;
+typedef struct oc_mode_scheme_chooser oc_mode_scheme_chooser;
+typedef struct oc_iir_filter          oc_iir_filter;
+typedef struct oc_frame_metrics       oc_frame_metrics;
+typedef struct oc_rc_state            oc_rc_state;
+typedef struct th_enc_ctx             oc_enc_ctx;
+typedef struct oc_token_checkpoint    oc_token_checkpoint;
+
+
+
+/*Constants for the packet-out state machine specific to the encoder.*/
+
+/*Next packet to emit: Data packet, but none are ready yet.*/
+#define OC_PACKET_EMPTY (0)
+/*Next packet to emit: Data packet, and one is ready.*/
+#define OC_PACKET_READY (1)
+
+/*All features enabled.*/
+#define OC_SP_LEVEL_SLOW       (0)
+/*Enable early skip.*/
+#define OC_SP_LEVEL_EARLY_SKIP (1)
+/*Disable motion compensation.*/
+#define OC_SP_LEVEL_NOMC       (2)
+/*Maximum valid speed level.*/
+#define OC_SP_LEVEL_MAX        (2)
+
+
+/*The bits used for each of the MB mode codebooks.*/
+extern const unsigned char OC_MODE_BITS[2][OC_NMODES];
+
+/*The bits used for each of the MV codebooks.*/
+extern const unsigned char OC_MV_BITS[2][64];
+
+/*The minimum value that can be stored in a SB run for each codeword.
+  The last entry is the upper bound on the length of a single SB run.*/
+extern const ogg_uint16_t  OC_SB_RUN_VAL_MIN[8];
+/*The bits used for each SB run codeword.*/
+extern const unsigned char OC_SB_RUN_CODE_NBITS[7];
+
+/*The bits used for each block run length (starting with 1).*/
+extern const unsigned char OC_BLOCK_RUN_CODE_NBITS[30];
+
+
+
+/*Encoder specific functions with accelerated variants.*/
+struct oc_enc_opt_vtable{
+  unsigned (*frag_sad)(const unsigned char *_src,
+   const unsigned char *_ref,int _ystride);
+  unsigned (*frag_sad_thresh)(const unsigned char *_src,
+   const unsigned char *_ref,int _ystride,unsigned _thresh);
+  unsigned (*frag_sad2_thresh)(const unsigned char *_src,
+   const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+   unsigned _thresh);
+  unsigned (*frag_satd_thresh)(const unsigned char *_src,
+   const unsigned char *_ref,int _ystride,unsigned _thresh);
+  unsigned (*frag_satd2_thresh)(const unsigned char *_src,
+   const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+   unsigned _thresh);
+  unsigned (*frag_intra_satd)(const unsigned char *_src,int _ystride);
+  void     (*frag_sub)(ogg_int16_t _diff[64],const unsigned char *_src,
+   const unsigned char *_ref,int _ystride);
+  void     (*frag_sub_128)(ogg_int16_t _diff[64],
+   const unsigned char *_src,int _ystride);
+  void     (*frag_copy2)(unsigned char *_dst,
+   const unsigned char *_src1,const unsigned char *_src2,int _ystride);
+  void     (*frag_recon_intra)(unsigned char *_dst,int _ystride,
+   const ogg_int16_t _residue[64]);
+  void     (*frag_recon_inter)(unsigned char *_dst,
+   const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]);
+  void     (*fdct8x8)(ogg_int16_t _y[64],const ogg_int16_t _x[64]);
+};
+
+
+void oc_enc_vtable_init(oc_enc_ctx *_enc);
+
+
+
+/*Encoder-specific macroblock information.*/
+struct oc_mb_enc_info{
+  /*Neighboring macro blocks that have MVs available from the current frame.*/
+  unsigned      cneighbors[4];
+  /*Neighboring macro blocks to use for MVs from the previous frame.*/
+  unsigned      pneighbors[4];
+  /*The number of current-frame neighbors.*/
+  unsigned char ncneighbors;
+  /*The number of previous-frame neighbors.*/
+  unsigned char npneighbors;
+  /*Flags indicating which MB modes have been refined.*/
+  unsigned char refined;
+  /*Motion vectors for a macro block for the current frame and the
+     previous two frames.
+    Each is a set of 2 vectors against OC_FRAME_GOLD and OC_FRAME_PREV, which
+     can be used to estimate constant velocity and constant acceleration
+     predictors.
+    Uninitialized MVs are (0,0).*/
+  oc_mv2        analysis_mv[3];
+  /*Current unrefined analysis MVs.*/
+  oc_mv         unref_mv[2];
+  /*Unrefined block MVs.*/
+  oc_mv         block_mv[4];
+  /*Refined block MVs.*/
+  oc_mv         ref_mv[4];
+  /*Minimum motion estimation error from the analysis stage.*/
+  ogg_uint16_t  error[2];
+  /*MB error for half-pel refinement for each frame type.*/
+  unsigned      satd[2];
+  /*Block error for half-pel refinement.*/
+  unsigned      block_satd[4];
+};
+
+
+
+/*State machine to estimate the opportunity cost of coding a MB mode.*/
+struct oc_mode_scheme_chooser{
+  /*Pointers to the a list containing the index of each mode in the mode
+     alphabet used by each scheme.
+    The first entry points to the dynamic scheme0_ranks, while the remaining 7
+     point to the constant entries stored in OC_MODE_SCHEMES.*/
+  const unsigned char *mode_ranks[8];
+  /*The ranks for each mode when coded with scheme 0.
+    These are optimized so that the more frequent modes have lower ranks.*/
+  unsigned char        scheme0_ranks[OC_NMODES];
+  /*The list of modes, sorted in descending order of frequency, that
+    corresponds to the ranks above.*/
+  unsigned char        scheme0_list[OC_NMODES];
+  /*The number of times each mode has been chosen so far.*/
+  int                  mode_counts[OC_NMODES];
+  /*The list of mode coding schemes, sorted in ascending order of bit cost.*/
+  unsigned char        scheme_list[8];
+  /*The number of bits used by each mode coding scheme.*/
+  ptrdiff_t            scheme_bits[8];
+};
+
+
+void oc_mode_scheme_chooser_init(oc_mode_scheme_chooser *_chooser);
+
+
+
+/*A 2nd order low-pass Bessel follower.
+  We use this for rate control because it has fast reaction time, but is
+   critically damped.*/
+struct oc_iir_filter{
+  ogg_int32_t c[2];
+  ogg_int64_t g;
+  ogg_int32_t x[2];
+  ogg_int32_t y[2];
+};
+
+
+
+/*The 2-pass metrics associated with a single frame.*/
+struct oc_frame_metrics{
+  /*The log base 2 of the scale factor for this frame in Q24 format.*/
+  ogg_int32_t   log_scale;
+  /*The number of application-requested duplicates of this frame.*/
+  unsigned      dup_count:31;
+  /*The frame type from pass 1.*/
+  unsigned      frame_type:1;
+};
+
+
+
+/*Rate control state information.*/
+struct oc_rc_state{
+  /*The target average bits per frame.*/
+  ogg_int64_t        bits_per_frame;
+  /*The current buffer fullness (bits available to be used).*/
+  ogg_int64_t        fullness;
+  /*The target buffer fullness.
+    This is where we'd like to be by the last keyframe the appears in the next
+     buf_delay frames.*/
+  ogg_int64_t        target;
+  /*The maximum buffer fullness (total size of the buffer).*/
+  ogg_int64_t        max;
+  /*The log of the number of pixels in a frame in Q57 format.*/
+  ogg_int64_t        log_npixels;
+  /*The exponent used in the rate model in Q8 format.*/
+  unsigned           exp[2];
+  /*The number of frames to distribute the buffer usage over.*/
+  int                buf_delay;
+  /*The total drop count from the previous frame.
+    This includes duplicates explicitly requested via the
+     TH_ENCCTL_SET_DUP_COUNT API as well as frames we chose to drop ourselves.*/
+  ogg_uint32_t       prev_drop_count;
+  /*The log of an estimated scale factor used to obtain the real framerate, for
+     VFR sources or, e.g., 12 fps content doubled to 24 fps, etc.*/
+  ogg_int64_t        log_drop_scale;
+  /*The log of estimated scale factor for the rate model in Q57 format.*/
+  ogg_int64_t        log_scale[2];
+  /*The log of the target quantizer level in Q57 format.*/
+  ogg_int64_t        log_qtarget;
+  /*Will we drop frames to meet bitrate target?*/
+  unsigned char      drop_frames;
+  /*Do we respect the maximum buffer fullness?*/
+  unsigned char      cap_overflow;
+  /*Can the reservoir go negative?*/
+  unsigned char      cap_underflow;
+  /*Second-order lowpass filters to track scale and VFR.*/
+  oc_iir_filter      scalefilter[2];
+  int                inter_count;
+  int                inter_delay;
+  int                inter_delay_target;
+  oc_iir_filter      vfrfilter;
+  /*Two-pass mode state.
+    0 => 1-pass encoding.
+    1 => 1st pass of 2-pass encoding.
+    2 => 2nd pass of 2-pass encoding.*/
+  int                twopass;
+  /*Buffer for current frame metrics.*/
+  unsigned char      twopass_buffer[48];
+  /*The number of bytes in the frame metrics buffer.
+    When 2-pass encoding is enabled, this is set to 0 after each frame is
+     submitted, and must be non-zero before the next frame will be accepted.*/
+  int                twopass_buffer_bytes;
+  int                twopass_buffer_fill;
+  /*Whether or not to force the next frame to be a keyframe.*/
+  unsigned char      twopass_force_kf;
+  /*The metrics for the previous frame.*/
+  oc_frame_metrics   prev_metrics;
+  /*The metrics for the current frame.*/
+  oc_frame_metrics   cur_metrics;
+  /*The buffered metrics for future frames.*/
+  oc_frame_metrics  *frame_metrics;
+  int                nframe_metrics;
+  int                cframe_metrics;
+  /*The index of the current frame in the circular metric buffer.*/
+  int                frame_metrics_head;
+  /*The frame count of each type (keyframes, delta frames, and dup frames);
+     32 bits limits us to 2.268 years at 60 fps.*/
+  ogg_uint32_t       frames_total[3];
+  /*The number of frames of each type yet to be processed.*/
+  ogg_uint32_t       frames_left[3];
+  /*The sum of the scale values for each frame type.*/
+  ogg_int64_t        scale_sum[2];
+  /*The start of the window over which the current scale sums are taken.*/
+  int                scale_window0;
+  /*The end of the window over which the current scale sums are taken.*/
+  int                scale_window_end;
+  /*The frame count of each type in the current 2-pass window; this does not
+     include dup frames.*/
+  int                nframes[3];
+  /*The total accumulated estimation bias.*/
+  ogg_int64_t        rate_bias;
+};
+
+
+void oc_rc_state_init(oc_rc_state *_rc,oc_enc_ctx *_enc);
+void oc_rc_state_clear(oc_rc_state *_rc);
+
+void oc_enc_rc_resize(oc_enc_ctx *_enc);
+int oc_enc_select_qi(oc_enc_ctx *_enc,int _qti,int _clamp);
+void oc_enc_calc_lambda(oc_enc_ctx *_enc,int _frame_type);
+int oc_enc_update_rc_state(oc_enc_ctx *_enc,
+ long _bits,int _qti,int _qi,int _trial,int _droppable);
+int oc_enc_rc_2pass_out(oc_enc_ctx *_enc,unsigned char **_buf);
+int oc_enc_rc_2pass_in(oc_enc_ctx *_enc,unsigned char *_buf,size_t _bytes);
+
+
+
+/*The internal encoder state.*/
+struct th_enc_ctx{
+  /*Shared encoder/decoder state.*/
+  oc_theora_state          state;
+  /*Buffer in which to assemble packets.*/
+  oggpack_buffer           opb;
+  /*Encoder-specific macroblock information.*/
+  oc_mb_enc_info          *mb_info;
+  /*DC coefficients after prediction.*/
+  ogg_int16_t             *frag_dc;
+  /*The list of coded macro blocks, in coded order.*/
+  unsigned                *coded_mbis;
+  /*The number of coded macro blocks.*/
+  size_t                   ncoded_mbis;
+  /*Whether or not packets are ready to be emitted.
+    This takes on negative values while there are remaining header packets to
+     be emitted, reaches 0 when the codec is ready for input, and becomes
+     positive when a frame has been processed and data packets are ready.*/
+  int                      packet_state;
+  /*The maximum distance between keyframes.*/
+  ogg_uint32_t             keyframe_frequency_force;
+  /*The number of duplicates to produce for the next frame.*/
+  ogg_uint32_t             dup_count;
+  /*The number of duplicates remaining to be emitted for the current frame.*/
+  ogg_uint32_t             nqueued_dups;
+  /*The number of duplicates emitted for the last frame.*/
+  ogg_uint32_t             prev_dup_count;
+  /*The current speed level.*/
+  int                      sp_level;
+  /*Whether or not VP3 compatibility mode has been enabled.*/
+  unsigned char            vp3_compatible;
+  /*Whether or not any INTER frames have been coded.*/
+  unsigned char            coded_inter_frame;
+  /*Whether or not previous frame was dropped.*/
+  unsigned char            prevframe_dropped;
+  /*Stores most recently chosen Huffman tables for each frame type, DC and AC
+     coefficients, and luma and chroma tokens.
+    The actual Huffman table used for a given coefficient depends not only on
+     the choice made here, but also its index in the zig-zag ordering.*/
+  unsigned char            huff_idxs[2][2][2];
+  /*Current count of bits used by each MV coding mode.*/
+  size_t                   mv_bits[2];
+  /*The mode scheme chooser for estimating mode coding costs.*/
+  oc_mode_scheme_chooser   chooser;
+  /*The number of vertical super blocks in an MCU.*/
+  int                      mcu_nvsbs;
+  /*The SSD error for skipping each fragment in the current MCU.*/
+  unsigned                *mcu_skip_ssd;
+  /*The DCT token lists for each coefficient and each plane.*/
+  unsigned char          **dct_tokens[3];
+  /*The extra bits associated with each DCT token.*/
+  ogg_uint16_t           **extra_bits[3];
+  /*The number of DCT tokens for each coefficient for each plane.*/
+  ptrdiff_t                ndct_tokens[3][64];
+  /*Pending EOB runs for each coefficient for each plane.*/
+  ogg_uint16_t             eob_run[3][64];
+  /*The offset of the first DCT token for each coefficient for each plane.*/
+  unsigned char            dct_token_offs[3][64];
+  /*The last DC coefficient for each plane and reference frame.*/
+  int                      dc_pred_last[3][3];
+#if defined(OC_COLLECT_METRICS)
+  /*Fragment SATD statistics for MB mode estimation metrics.*/
+  unsigned                *frag_satd;
+  /*Fragment SSD statistics for MB mode estimation metrics.*/
+  unsigned                *frag_ssd;
+#endif
+  /*The R-D optimization parameter.*/
+  int                      lambda;
+  /*The huffman tables in use.*/
+  th_huff_code             huff_codes[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS];
+  /*The quantization parameters in use.*/
+  th_quant_info            qinfo;
+  oc_iquant               *enquant_tables[64][3][2];
+  oc_iquant_table          enquant_table_data[64][3][2];
+  /*An "average" quantizer for each quantizer type (INTRA or INTER) and qi
+     value.
+    This is used to paramterize the rate control decisions.
+    They are kept in the log domain to simplify later processing.
+    Keep in mind these are DCT domain quantizers, and so are scaled by an
+     additional factor of 4 from the pixel domain.*/
+  ogg_int64_t              log_qavg[2][64];
+  /*The buffer state used to drive rate control.*/
+  oc_rc_state              rc;
+  /*Table for encoder acceleration functions.*/
+  oc_enc_opt_vtable        opt_vtable;
+};
+
+
+void oc_enc_analyze_intra(oc_enc_ctx *_enc,int _recode);
+int oc_enc_analyze_inter(oc_enc_ctx *_enc,int _allow_keyframe,int _recode);
+#if defined(OC_COLLECT_METRICS)
+void oc_enc_mode_metrics_collect(oc_enc_ctx *_enc);
+void oc_enc_mode_metrics_dump(oc_enc_ctx *_enc);
+#endif
+
+
+
+/*Perform fullpel motion search for a single MB against both reference frames.*/
+void oc_mcenc_search(oc_enc_ctx *_enc,int _mbi);
+/*Refine a MB MV for one frame.*/
+void oc_mcenc_refine1mv(oc_enc_ctx *_enc,int _mbi,int _frame);
+/*Refine the block MVs.*/
+void oc_mcenc_refine4mv(oc_enc_ctx *_enc,int _mbi);
+
+
+
+/*Used to rollback a tokenlog transaction when we retroactively decide to skip
+   a fragment.
+  A checkpoint is taken right before each token is added.*/
+struct oc_token_checkpoint{
+  /*The color plane the token was added to.*/
+  unsigned char pli;
+  /*The zig-zag index the token was added to.*/
+  unsigned char zzi;
+  /*The outstanding EOB run count before the token was added.*/
+  ogg_uint16_t  eob_run;
+  /*The token count before the token was added.*/
+  ptrdiff_t     ndct_tokens;
+};
+
+
+
+void oc_enc_tokenize_start(oc_enc_ctx *_enc);
+int oc_enc_tokenize_ac(oc_enc_ctx *_enc,int _pli,ptrdiff_t _fragi,
+ ogg_int16_t *_qdct,const ogg_uint16_t *_dequant,const ogg_int16_t *_dct,
+ int _zzi,oc_token_checkpoint **_stack,int _acmin);
+void oc_enc_tokenlog_rollback(oc_enc_ctx *_enc,
+ const oc_token_checkpoint *_stack,int _n);
+void oc_enc_pred_dc_frag_rows(oc_enc_ctx *_enc,
+ int _pli,int _fragy0,int _frag_yend);
+void oc_enc_tokenize_dc_frag_list(oc_enc_ctx *_enc,int _pli,
+ const ptrdiff_t *_coded_fragis,ptrdiff_t _ncoded_fragis,
+ int _prev_ndct_tokens1,int _prev_eob_run1);
+void oc_enc_tokenize_finish(oc_enc_ctx *_enc);
+
+
+
+/*Utility routine to encode one of the header packets.*/
+int oc_state_flushheader(oc_theora_state *_state,int *_packet_state,
+ oggpack_buffer *_opb,const th_quant_info *_qinfo,
+ const th_huff_code _codes[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS],
+ const char *_vendor,th_comment *_tc,ogg_packet *_op);
+
+
+
+/*Encoder-specific accelerated functions.*/
+void oc_enc_frag_sub(const oc_enc_ctx *_enc,ogg_int16_t _diff[64],
+ const unsigned char *_src,const unsigned char *_ref,int _ystride);
+void oc_enc_frag_sub_128(const oc_enc_ctx *_enc,ogg_int16_t _diff[64],
+ const unsigned char *_src,int _ystride);
+unsigned oc_enc_frag_sad(const oc_enc_ctx *_enc,const unsigned char *_src,
+ const unsigned char *_ref,int _ystride);
+unsigned oc_enc_frag_sad_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_sad2_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref1,
+ const unsigned char *_ref2,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_satd_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_satd2_thresh(const oc_enc_ctx *_enc,
+ const unsigned char *_src,const unsigned char *_ref1,
+ const unsigned char *_ref2,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_intra_satd(const oc_enc_ctx *_enc,
+ const unsigned char *_src,int _ystride);
+void oc_enc_frag_copy2(const oc_enc_ctx *_enc,unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride);
+void oc_enc_frag_recon_intra(const oc_enc_ctx *_enc,
+ unsigned char *_dst,int _ystride,const ogg_int16_t _residue[64]);
+void oc_enc_frag_recon_inter(const oc_enc_ctx *_enc,unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]);
+void oc_enc_fdct8x8(const oc_enc_ctx *_enc,ogg_int16_t _y[64],
+ const ogg_int16_t _x[64]);
+
+/*Default pure-C implementations.*/
+void oc_enc_vtable_init_c(oc_enc_ctx *_enc);
+
+void oc_enc_frag_sub_c(ogg_int16_t _diff[64],
+ const unsigned char *_src,const unsigned char *_ref,int _ystride);
+void oc_enc_frag_sub_128_c(ogg_int16_t _diff[64],
+ const unsigned char *_src,int _ystride);
+void oc_enc_frag_copy2_c(unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride);
+unsigned oc_enc_frag_sad_c(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride);
+unsigned oc_enc_frag_sad_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_sad2_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_satd_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_satd2_thresh_c(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_intra_satd_c(const unsigned char *_src,int _ystride);
+void oc_enc_fdct8x8_c(ogg_int16_t _y[64],const ogg_int16_t _x[64]);
+
+#endif
diff --git a/lib/encode.c b/lib/encode.c
new file mode 100644 (file)
index 0000000..0c5ea6a
--- /dev/null
@@ -0,0 +1,1615 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: encode.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include <stdlib.h>
+#include <string.h>
+#include "encint.h"
+#if defined(OC_X86_ASM)
+# include "x86/x86enc.h"
+#endif
+
+
+
+/*The default quantization parameters used by VP3.1.*/
+static const int OC_VP31_RANGE_SIZES[1]={63};
+static const th_quant_base OC_VP31_BASES_INTRA_Y[2]={
+  {
+     16, 11, 10, 16, 24, 40, 51, 61,
+     12, 12, 14, 19, 26, 58, 60, 55,
+     14, 13, 16, 24, 40, 57, 69, 56,
+     14, 17, 22, 29, 51, 87, 80, 62,
+     18, 22, 37, 58, 68,109,103, 77,
+     24, 35, 55, 64, 81,104,113, 92,
+     49, 64, 78, 87,103,121,120,101,
+     72, 92, 95, 98,112,100,103, 99
+  },
+  {
+     16, 11, 10, 16, 24, 40, 51, 61,
+     12, 12, 14, 19, 26, 58, 60, 55,
+     14, 13, 16, 24, 40, 57, 69, 56,
+     14, 17, 22, 29, 51, 87, 80, 62,
+     18, 22, 37, 58, 68,109,103, 77,
+     24, 35, 55, 64, 81,104,113, 92,
+     49, 64, 78, 87,103,121,120,101,
+     72, 92, 95, 98,112,100,103, 99
+  }
+};
+static const th_quant_base OC_VP31_BASES_INTRA_C[2]={
+  {
+     17, 18, 24, 47, 99, 99, 99, 99,
+     18, 21, 26, 66, 99, 99, 99, 99,
+     24, 26, 56, 99, 99, 99, 99, 99,
+     47, 66, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99
+  },
+  {
+     17, 18, 24, 47, 99, 99, 99, 99,
+     18, 21, 26, 66, 99, 99, 99, 99,
+     24, 26, 56, 99, 99, 99, 99, 99,
+     47, 66, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99
+  }
+};
+static const th_quant_base OC_VP31_BASES_INTER[2]={
+  {
+     16, 16, 16, 20, 24, 28, 32, 40,
+     16, 16, 20, 24, 28, 32, 40, 48,
+     16, 20, 24, 28, 32, 40, 48, 64,
+     20, 24, 28, 32, 40, 48, 64, 64,
+     24, 28, 32, 40, 48, 64, 64, 64,
+     28, 32, 40, 48, 64, 64, 64, 96,
+     32, 40, 48, 64, 64, 64, 96,128,
+     40, 48, 64, 64, 64, 96,128,128
+  },
+  {
+     16, 16, 16, 20, 24, 28, 32, 40,
+     16, 16, 20, 24, 28, 32, 40, 48,
+     16, 20, 24, 28, 32, 40, 48, 64,
+     20, 24, 28, 32, 40, 48, 64, 64,
+     24, 28, 32, 40, 48, 64, 64, 64,
+     28, 32, 40, 48, 64, 64, 64, 96,
+     32, 40, 48, 64, 64, 64, 96,128,
+     40, 48, 64, 64, 64, 96,128,128
+  }
+};
+
+const th_quant_info TH_VP31_QUANT_INFO={
+  {
+    220,200,190,180,170,170,160,160,
+    150,150,140,140,130,130,120,120,
+    110,110,100,100, 90, 90, 90, 80,
+     80, 80, 70, 70, 70, 60, 60, 60,
+     60, 50, 50, 50, 50, 40, 40, 40,
+     40, 40, 30, 30, 30, 30, 30, 30,
+     30, 20, 20, 20, 20, 20, 20, 20,
+     20, 10, 10, 10, 10, 10, 10, 10
+  },
+  {
+    500,450,400,370,340,310,285,265,
+    245,225,210,195,185,180,170,160,
+    150,145,135,130,125,115,110,107,
+    100, 96, 93, 89, 85, 82, 75, 74,
+     70, 68, 64, 60, 57, 56, 52, 50,
+     49, 45, 44, 43, 40, 38, 37, 35,
+     33, 32, 30, 29, 28, 25, 24, 22,
+     21, 19, 18, 17, 15, 13, 12, 10
+  },
+  {
+    30,25,20,20,15,15,14,14,
+    13,13,12,12,11,11,10,10,
+     9, 9, 8, 8, 7, 7, 7, 7,
+     6, 6, 6, 6, 5, 5, 5, 5,
+     4, 4, 4, 4, 3, 3, 3, 3,
+     2, 2, 2, 2, 2, 2, 2, 2,
+     0, 0, 0, 0, 0, 0, 0, 0,
+     0, 0, 0, 0, 0, 0, 0, 0
+  },
+  {
+    {
+      {1,OC_VP31_RANGE_SIZES,OC_VP31_BASES_INTRA_Y},
+      {1,OC_VP31_RANGE_SIZES,OC_VP31_BASES_INTRA_C},
+      {1,OC_VP31_RANGE_SIZES,OC_VP31_BASES_INTRA_C}
+    },
+    {
+      {1,OC_VP31_RANGE_SIZES,OC_VP31_BASES_INTER},
+      {1,OC_VP31_RANGE_SIZES,OC_VP31_BASES_INTER},
+      {1,OC_VP31_RANGE_SIZES,OC_VP31_BASES_INTER}
+    }
+  }
+};
+
+/*The current default quantization parameters.*/
+static const int OC_DEF_QRANGE_SIZES[3]={32,16,15};
+static const th_quant_base OC_DEF_BASES_INTRA_Y[4]={
+  {
+     15, 15, 15, 15, 15, 15, 15, 15,
+     15, 15, 15, 15, 15, 15, 15, 15,
+     15, 15, 15, 15, 15, 15, 15, 15,
+     15, 15, 15, 15, 15, 15, 15, 15,
+     15, 15, 15, 15, 15, 15, 15, 15,
+     15, 15, 15, 15, 15, 15, 15, 15,
+     15, 15, 15, 15, 15, 15, 15, 15,
+     15, 15, 15, 15, 15, 15, 15, 15,
+  },
+  {
+     15, 12, 12, 15, 18, 20, 20, 21,
+     13, 13, 14, 17, 18, 21, 21, 20,
+     14, 14, 15, 18, 20, 21, 21, 21,
+     14, 16, 17, 19, 20, 21, 21, 21,
+     16, 17, 20, 21, 21, 21, 21, 21,
+     18, 19, 20, 21, 21, 21, 21, 21,
+     20, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21
+  },
+  {
+     16, 12, 11, 16, 20, 25, 27, 28,
+     13, 13, 14, 18, 21, 28, 28, 27,
+     14, 13, 16, 20, 25, 28, 28, 28,
+     14, 16, 19, 22, 27, 29, 29, 28,
+     17, 19, 25, 28, 28, 30, 30, 29,
+     20, 24, 27, 28, 29, 30, 30, 29,
+     27, 28, 29, 29, 30, 30, 30, 30,
+     29, 29, 29, 29, 30, 30, 30, 29
+  },
+  {
+     16, 11, 10, 16, 24, 40, 51, 61,
+     12, 12, 14, 19, 26, 58, 60, 55,
+     14, 13, 16, 24, 40, 57, 69, 56,
+     14, 17, 22, 29, 51, 87, 80, 62,
+     18, 22, 37, 58, 68,109,103, 77,
+     24, 35, 55, 64, 81,104,113, 92,
+     49, 64, 78, 87,103,121,120,101,
+     72, 92, 95, 98,112,100,103, 99
+  }
+};
+static const th_quant_base OC_DEF_BASES_INTRA_C[4]={
+  {
+     19, 19, 19, 19, 19, 19, 19, 19,
+     19, 19, 19, 19, 19, 19, 19, 19,
+     19, 19, 19, 19, 19, 19, 19, 19,
+     19, 19, 19, 19, 19, 19, 19, 19,
+     19, 19, 19, 19, 19, 19, 19, 19,
+     19, 19, 19, 19, 19, 19, 19, 19,
+     19, 19, 19, 19, 19, 19, 19, 19,
+     19, 19, 19, 19, 19, 19, 19, 19
+  },
+  {
+     18, 18, 21, 25, 26, 26, 26, 26,
+     18, 20, 22, 26, 26, 26, 26, 26,
+     21, 22, 25, 26, 26, 26, 26, 26,
+     25, 26, 26, 26, 26, 26, 26, 26,
+     26, 26, 26, 26, 26, 26, 26, 26,
+     26, 26, 26, 26, 26, 26, 26, 26,
+     26, 26, 26, 26, 26, 26, 26, 26,
+     26, 26, 26, 26, 26, 26, 26, 26
+  },
+  {
+     17, 18, 22, 31, 36, 36, 36, 36,
+     18, 20, 24, 34, 36, 36, 36, 36,
+     22, 24, 33, 36, 36, 36, 36, 36,
+     31, 34, 36, 36, 36, 36, 36, 36,
+     36, 36, 36, 36, 36, 36, 36, 36,
+     36, 36, 36, 36, 36, 36, 36, 36,
+     36, 36, 36, 36, 36, 36, 36, 36,
+     36, 36, 36, 36, 36, 36, 36, 36
+  },
+  {
+     17, 18, 24, 47, 99, 99, 99, 99,
+     18, 21, 26, 66, 99, 99, 99, 99,
+     24, 26, 56, 99, 99, 99, 99, 99,
+     47, 66, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99,
+     99, 99, 99, 99, 99, 99, 99, 99
+  }
+};
+static const th_quant_base OC_DEF_BASES_INTER[4]={
+  {
+     21, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21,
+     21, 21, 21, 21, 21, 21, 21, 21
+  },
+  {
+     18, 18, 18, 21, 23, 24, 25, 27,
+     18, 18, 21, 23, 24, 25, 27, 28,
+     18, 21, 23, 24, 25, 27, 28, 29,
+     21, 23, 24, 25, 27, 28, 29, 29,
+     23, 24, 25, 27, 28, 29, 29, 29,
+     24, 25, 27, 28, 29, 29, 29, 30,
+     25, 27, 28, 29, 29, 29, 30, 30,
+     27, 28, 29, 29, 29, 30, 30, 30
+  },
+  {
+     17, 17, 17, 20, 23, 26, 28, 32,
+     17, 17, 20, 23, 26, 28, 32, 34,
+     17, 20, 23, 26, 28, 32, 34, 37,
+     20, 23, 26, 28, 32, 34, 37, 37,
+     23, 26, 28, 32, 34, 37, 37, 37,
+     26, 28, 32, 34, 37, 37, 37, 41,
+     28, 32, 34, 37, 37, 37, 41, 42,
+     32, 34, 37, 37, 37, 41, 42, 42
+  },
+  {
+     16, 16, 16, 20, 24, 28, 32, 40,
+     16, 16, 20, 24, 28, 32, 40, 48,
+     16, 20, 24, 28, 32, 40, 48, 64,
+     20, 24, 28, 32, 40, 48, 64, 64,
+     24, 28, 32, 40, 48, 64, 64, 64,
+     28, 32, 40, 48, 64, 64, 64, 96,
+     32, 40, 48, 64, 64, 64, 96,128,
+     40, 48, 64, 64, 64, 96,128,128
+  }
+};
+
+const th_quant_info TH_DEF_QUANT_INFO={
+  {
+    365,348,333,316,300,287,277,265,
+    252,240,229,219,206,197,189,180,
+    171,168,160,153,146,139,132,127,
+    121,115,110,107,101, 97, 94, 89,
+     85, 83, 78, 73, 72, 67, 66, 62,
+     60, 59, 56, 53, 52, 48, 47, 43,
+     42, 40, 36, 35, 34, 33, 31, 30,
+     28, 25, 24, 22, 20, 17, 14, 10
+  },
+  {
+    365,348,333,316,300,287,277,265,
+    252,240,229,219,206,197,189,180,
+    171,168,160,153,146,139,132,127,
+    121,115,110,107,101, 97, 94, 89,
+     85, 83, 78, 73, 72, 67, 66, 62,
+     60, 59, 56, 53, 52, 48, 47, 43,
+     42, 40, 36, 35, 34, 33, 31, 30,
+     28, 25, 24, 22, 20, 17, 14, 10
+  },
+  {
+    30,25,20,20,15,15,14,14,
+    13,13,12,12,11,11,10,10,
+     9, 9, 8, 8, 7, 7, 7, 7,
+     6, 6, 6, 6, 5, 5, 5, 5,
+     4, 4, 4, 4, 3, 3, 3, 3,
+     2, 2, 2, 2, 2, 2, 2, 2,
+     0, 0, 0, 0, 0, 0, 0, 0,
+     0, 0, 0, 0, 0, 0, 0, 0
+  },
+  {
+    {
+      {3,OC_DEF_QRANGE_SIZES,OC_DEF_BASES_INTRA_Y},
+      {3,OC_DEF_QRANGE_SIZES,OC_DEF_BASES_INTRA_C},
+      {3,OC_DEF_QRANGE_SIZES,OC_DEF_BASES_INTRA_C}
+    },
+    {
+      {3,OC_DEF_QRANGE_SIZES,OC_DEF_BASES_INTER},
+      {3,OC_DEF_QRANGE_SIZES,OC_DEF_BASES_INTER},
+      {3,OC_DEF_QRANGE_SIZES,OC_DEF_BASES_INTER}
+    }
+  }
+};
+
+
+
+/*The Huffman codes used for macro block modes.*/
+
+const unsigned char OC_MODE_BITS[2][OC_NMODES]={
+  /*Codebook 0: a maximally skewed prefix code.*/
+  {1,2,3,4,5,6,7,7},
+  /*Codebook 1: a fixed-length code.*/
+  {3,3,3,3,3,3,3,3}
+};
+
+static const unsigned char OC_MODE_CODES[2][OC_NMODES]={
+  /*Codebook 0: a maximally skewed prefix code.*/
+  {0x00,0x02,0x06,0x0E,0x1E,0x3E,0x7E,0x7F},
+  /*Codebook 1: a fixed-length code.*/
+  {0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07}
+};
+
+
+/*The Huffman codes used for motion vectors.*/
+
+const unsigned char OC_MV_BITS[2][64]={
+  /*Codebook 0: VLC code.*/
+  {
+      8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,
+    8,7,7,7,7,7,7,7,7,6,6,6,6,4,4,3,
+    3,
+    3,4,4,6,6,6,6,7,7,7,7,7,7,7,7,8,
+    8,8,8,8,8,8,8,8,8,8,8,8,8,8,8
+  },
+  /*Codebook 1: (5 bit magnitude, 1 bit sign).
+    This wastes a code word (0x01, negative zero), or a bit (0x00, positive
+     zero, requires only 5 bits to uniquely decode), but is hopefully not used
+     very often.*/
+  {
+      6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,
+    6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,
+    6,
+    6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,
+    6,6,6,6,6,6,6,6,6,6,6,6,6,6,6
+  }
+};
+
+static const unsigned char OC_MV_CODES[2][64]={
+  /*Codebook 0: VLC code.*/
+  {
+         0xFF,0xFD,0xFB,0xF9,0xF7,0xF5,0xF3,
+    0xF1,0xEF,0xED,0xEB,0xE9,0xE7,0xE5,0xE3,
+    0xE1,0x6F,0x6D,0x6B,0x69,0x67,0x65,0x63,
+    0x61,0x2F,0x2D,0x2B,0x29,0x09,0x07,0x02,
+    0x00,
+    0x01,0x06,0x08,0x28,0x2A,0x2C,0x2E,0x60,
+    0x62,0x64,0x66,0x68,0x6A,0x6C,0x6E,0xE0,
+    0xE2,0xE4,0xE6,0xE8,0xEA,0xEC,0xEE,0xF0,
+    0xF2,0xF4,0xF6,0xF8,0xFA,0xFC,0xFE
+  },
+  /*Codebook 1: (5 bit magnitude, 1 bit sign).*/
+  {
+         0x3F,0x3D,0x3B,0x39,0x37,0x35,0x33,
+    0x31,0x2F,0x2D,0x2B,0x29,0x27,0x25,0x23,
+    0x21,0x1F,0x1D,0x1B,0x19,0x17,0x15,0x13,
+    0x11,0x0F,0x0D,0x0B,0x09,0x07,0x05,0x03,
+    0x00,
+    0x02,0x04,0x06,0x08,0x0A,0x0C,0x0E,0x10,
+    0x12,0x14,0x16,0x18,0x1A,0x1C,0x1E,0x20,
+    0x22,0x24,0x26,0x28,0x2A,0x2C,0x2E,0x30,
+    0x32,0x34,0x36,0x38,0x3A,0x3C,0x3E
+  }
+};
+
+
+
+/*Super block run coding scheme:
+   Codeword             Run Length
+   0                       1
+   10x                     2-3
+   110x                    4-5
+   1110xx                  6-9
+   11110xxx                10-17
+   111110xxxx              18-33
+   111111xxxxxxxxxxxx      34-4129*/
+const ogg_uint16_t    OC_SB_RUN_VAL_MIN[8]={1,2,4,6,10,18,34,4130};
+static const unsigned OC_SB_RUN_CODE_PREFIX[7]={
+  0,4,0xC,0x38,0xF0,0x3E0,0x3F000
+};
+const unsigned char   OC_SB_RUN_CODE_NBITS[7]={1,3,4,6,8,10,18};
+
+
+/*Writes the bit pattern for the run length of a super block run to the given
+   oggpack_buffer.
+  _opb:       The buffer to write to.
+  _run_count: The length of the run, which must be positive.
+  _flag:      The current flag.
+  _done:      Whether or not more flags are to be encoded.*/
+static void oc_sb_run_pack(oggpack_buffer *_opb,ptrdiff_t _run_count,
+ int _flag,int _done){
+  int i;
+  if(_run_count>=4129){
+    do{
+      oggpackB_write(_opb,0x3FFFF,18);
+      _run_count-=4129;
+      if(_run_count>0)oggpackB_write(_opb,_flag,1);
+      else if(!_done)oggpackB_write(_opb,!_flag,1);
+    }
+    while(_run_count>=4129);
+    if(_run_count<=0)return;
+  }
+  for(i=0;_run_count>=OC_SB_RUN_VAL_MIN[i+1];i++);
+  oggpackB_write(_opb,OC_SB_RUN_CODE_PREFIX[i]+_run_count-OC_SB_RUN_VAL_MIN[i],
+   OC_SB_RUN_CODE_NBITS[i]);
+}
+
+
+
+/*Block run coding scheme:
+   Codeword             Run Length
+   0x                      1-2
+   10x                     3-4
+   110x                    5-6
+   1110xx                  7-10
+   11110xx                 11-14
+   11111xxxx               15-30*/
+const unsigned char OC_BLOCK_RUN_CODE_NBITS[30]={
+  2,2,3,3,4,4,6,6,6,6,7,7,7,7,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9
+};
+static const ogg_uint16_t  OC_BLOCK_RUN_CODE_PATTERN[30]={
+        0x000,0x001,0x004,0x005,0x00C,0x00D,0x038,
+  0x039,0x03A,0x03B,0x078,0x079,0x07A,0x07B,0x1F0,
+  0x1F1,0x1F2,0x1F3,0x1F4,0x1F5,0x1F6,0x1F7,0x1F8,
+  0x1F9,0x1FA,0x1FB,0x1FC,0x1FD,0x1FE,0x1FF
+};
+
+
+/*Writes the bit pattern for the run length of a block run to the given
+   oggpack_buffer.
+  _opb:       The buffer to write to.
+  _run_count: The length of the run.
+              This must be positive, and no more than 30.*/
+static void oc_block_run_pack(oggpack_buffer *_opb,int _run_count){
+  oggpackB_write(_opb,OC_BLOCK_RUN_CODE_PATTERN[_run_count-1],
+   OC_BLOCK_RUN_CODE_NBITS[_run_count-1]);
+}
+
+
+
+static void oc_enc_frame_header_pack(oc_enc_ctx *_enc){
+  /*Mark this as a data packet.*/
+  oggpackB_write(&_enc->opb,0,1);
+  /*Output the frame type (key frame or delta frame).*/
+  oggpackB_write(&_enc->opb,_enc->state.frame_type,1);
+  /*Write out the current qi list.*/
+  oggpackB_write(&_enc->opb,_enc->state.qis[0],6);
+  if(_enc->state.nqis>1){
+    oggpackB_write(&_enc->opb,1,1);
+    oggpackB_write(&_enc->opb,_enc->state.qis[1],6);
+    if(_enc->state.nqis>2){
+      oggpackB_write(&_enc->opb,1,1);
+      oggpackB_write(&_enc->opb,_enc->state.qis[2],6);
+    }
+    else oggpackB_write(&_enc->opb,0,1);
+  }
+  else oggpackB_write(&_enc->opb,0,1);
+  if(_enc->state.frame_type==OC_INTRA_FRAME){
+    /*Key frames have 3 unused configuration bits, holdovers from the VP3 days.
+      Most of the other unused bits in the VP3 headers were eliminated.
+      Monty kept these to leave us some wiggle room for future expansion,
+       though a single bit in all frames would have been far more useful.*/
+    oggpackB_write(&_enc->opb,0,3);
+  }
+}
+
+/*Writes the bit flags for whether or not each super block is partially coded
+   or not.
+  These flags are run-length encoded, with the flag value alternating between
+   each run.
+  Return: The number partially coded SBs.*/
+static unsigned oc_enc_partial_sb_flags_pack(oc_enc_ctx *_enc){
+  const oc_sb_flags *sb_flags;
+  unsigned           nsbs;
+  unsigned           sbi;
+  unsigned           npartial;
+  int                flag;
+  sb_flags=_enc->state.sb_flags;
+  nsbs=_enc->state.nsbs;
+  flag=sb_flags[0].coded_partially;
+  oggpackB_write(&_enc->opb,flag,1);
+  sbi=npartial=0;
+  do{
+    unsigned run_count;
+    for(run_count=0;sbi<nsbs;sbi++){
+      if(sb_flags[sbi].coded_partially!=flag)break;
+      run_count++;
+      npartial+=flag;
+    }
+    oc_sb_run_pack(&_enc->opb,run_count,flag,sbi>=nsbs);
+    flag=!flag;
+  }
+  while(sbi<nsbs);
+  return npartial;
+}
+
+/*Writes the coded/not coded flags for each super block that is not partially
+   coded.
+  These flags are run-length encoded, with the flag value altenating between
+   each run.*/
+static void oc_enc_coded_sb_flags_pack(oc_enc_ctx *_enc){
+  const oc_sb_flags *sb_flags;
+  unsigned           nsbs;
+  unsigned           sbi;
+  int                flag;
+  sb_flags=_enc->state.sb_flags;
+  nsbs=_enc->state.nsbs;
+  /*Skip partially coded super blocks; their flags have already been coded.*/
+  for(sbi=0;sb_flags[sbi].coded_partially;sbi++);
+  flag=sb_flags[sbi].coded_fully;
+  oggpackB_write(&_enc->opb,flag,1);
+  do{
+    unsigned run_count;
+    for(run_count=0;sbi<nsbs;sbi++){
+      if(sb_flags[sbi].coded_partially)continue;
+      if(sb_flags[sbi].coded_fully!=flag)break;
+      run_count++;
+    }
+    oc_sb_run_pack(&_enc->opb,run_count,flag,sbi>=nsbs);
+    flag=!flag;
+  }
+  while(sbi<nsbs);
+}
+
+static void oc_enc_coded_flags_pack(oc_enc_ctx *_enc){
+  const oc_sb_map   *sb_maps;
+  const oc_sb_flags *sb_flags;
+  unsigned           nsbs;
+  const oc_fragment *frags;
+  unsigned           npartial;
+  int                run_count;
+  int                flag;
+  int                pli;
+  unsigned           sbi;
+  npartial=oc_enc_partial_sb_flags_pack(_enc);
+  if(npartial<_enc->state.nsbs)oc_enc_coded_sb_flags_pack(_enc);
+  sb_maps=(const oc_sb_map *)_enc->state.sb_maps;
+  sb_flags=_enc->state.sb_flags;
+  nsbs=_enc->state.nsbs;
+  frags=_enc->state.frags;
+  for(sbi=0;sbi<nsbs&&!sb_flags[sbi].coded_partially;sbi++);
+  /*If there's at least one partial SB, store individual coded block flags.*/
+  if(sbi<nsbs){
+    flag=frags[sb_maps[sbi][0][0]].coded;
+    oggpackB_write(&_enc->opb,flag,1);
+    run_count=0;
+    nsbs=sbi=0;
+    for(pli=0;pli<3;pli++){
+      nsbs+=_enc->state.fplanes[pli].nsbs;
+      for(;sbi<nsbs;sbi++){
+        int       quadi;
+        int       bi;
+        ptrdiff_t fragi;
+        if(sb_flags[sbi].coded_partially){
+          for(quadi=0;quadi<4;quadi++){
+            for(bi=0;bi<4;bi++){
+              fragi=sb_maps[sbi][quadi][bi];
+              if(fragi>=0){
+                if(frags[fragi].coded!=flag){
+                  oc_block_run_pack(&_enc->opb,run_count);
+                  flag=!flag;
+                  run_count=1;
+                }
+                else run_count++;
+              }
+            }
+          }
+        }
+      }
+    }
+    /*Flush any trailing block coded run.*/
+    if(run_count>0)oc_block_run_pack(&_enc->opb,run_count);
+  }
+}
+
+static void oc_enc_mb_modes_pack(oc_enc_ctx *_enc){
+  const unsigned char *mode_codes;
+  const unsigned char *mode_bits;
+  const unsigned char *mode_ranks;
+  unsigned            *coded_mbis;
+  size_t               ncoded_mbis;
+  const signed char   *mb_modes;
+  unsigned             mbii;
+  int                  scheme;
+  int                  mb_mode;
+  scheme=_enc->chooser.scheme_list[0];
+  /*Encode the best scheme.*/
+  oggpackB_write(&_enc->opb,scheme,3);
+  /*If the chosen scheme is scheme 0, send the mode frequency ordering.*/
+  if(scheme==0){
+    for(mb_mode=0;mb_mode<OC_NMODES;mb_mode++){
+      oggpackB_write(&_enc->opb,_enc->chooser.scheme0_ranks[mb_mode],3);
+    }
+  }
+  mode_ranks=_enc->chooser.mode_ranks[scheme];
+  mode_bits=OC_MODE_BITS[scheme+1>>3];
+  mode_codes=OC_MODE_CODES[scheme+1>>3];
+  coded_mbis=_enc->coded_mbis;
+  ncoded_mbis=_enc->ncoded_mbis;
+  mb_modes=_enc->state.mb_modes;
+  for(mbii=0;mbii<ncoded_mbis;mbii++){
+    int rank;
+    rank=mode_ranks[mb_modes[coded_mbis[mbii]]];
+    oggpackB_write(&_enc->opb,mode_codes[rank],mode_bits[rank]);
+  }
+}
+
+static void oc_enc_mv_pack(oc_enc_ctx *_enc,int _mv_scheme,int _dx,int _dy){
+  oggpackB_write(&_enc->opb,
+   OC_MV_CODES[_mv_scheme][_dx+31],OC_MV_BITS[_mv_scheme][_dx+31]);
+  oggpackB_write(&_enc->opb,
+   OC_MV_CODES[_mv_scheme][_dy+31],OC_MV_BITS[_mv_scheme][_dy+31]);
+}
+
+static void oc_enc_mvs_pack(oc_enc_ctx *_enc){
+  const unsigned     *coded_mbis;
+  size_t              ncoded_mbis;
+  const oc_mb_map    *mb_maps;
+  const signed char  *mb_modes;
+  const oc_fragment  *frags;
+  const oc_mv        *frag_mvs;
+  unsigned            mbii;
+  int                 mv_scheme;
+  /*Choose the coding scheme.*/
+  mv_scheme=_enc->mv_bits[1]<_enc->mv_bits[0];
+  oggpackB_write(&_enc->opb,mv_scheme,1);
+  /*Encode the motion vectors.
+    Macro blocks are iterated in Hilbert scan order, but the MVs within the
+     macro block are coded in raster order.*/
+  coded_mbis=_enc->coded_mbis;
+  ncoded_mbis=_enc->ncoded_mbis;
+  mb_modes=_enc->state.mb_modes;
+  mb_maps=(const oc_mb_map *)_enc->state.mb_maps;
+  frags=_enc->state.frags;
+  frag_mvs=(const oc_mv *)_enc->state.frag_mvs;
+  for(mbii=0;mbii<ncoded_mbis;mbii++){
+    ptrdiff_t fragi;
+    unsigned  mbi;
+    int       bi;
+    mbi=coded_mbis[mbii];
+    switch(mb_modes[mbi]){
+      case OC_MODE_INTER_MV:
+      case OC_MODE_GOLDEN_MV:{
+        for(bi=0;;bi++){
+          fragi=mb_maps[mbi][0][bi];
+          if(frags[fragi].coded){
+            oc_enc_mv_pack(_enc,mv_scheme,
+             frag_mvs[fragi][0],frag_mvs[fragi][1]);
+            /*Only code a single MV for this macro block.*/
+            break;
+          }
+        }
+      }break;
+      case OC_MODE_INTER_MV_FOUR:{
+        for(bi=0;bi<4;bi++){
+          fragi=mb_maps[mbi][0][bi];
+          if(frags[fragi].coded){
+            oc_enc_mv_pack(_enc,mv_scheme,
+             frag_mvs[fragi][0],frag_mvs[fragi][1]);
+            /*Keep coding all the MVs for this macro block.*/
+          }
+        }
+      }break;
+    }
+  }
+}
+
+static void oc_enc_block_qis_pack(oc_enc_ctx *_enc){
+  const oc_fragment *frags;
+  ptrdiff_t         *coded_fragis;
+  ptrdiff_t          ncoded_fragis;
+  ptrdiff_t          fragii;
+  ptrdiff_t          run_count;
+  ptrdiff_t          nqi0;
+  int                flag;
+  if(_enc->state.nqis<=1)return;
+  ncoded_fragis=_enc->state.ntotal_coded_fragis;
+  if(ncoded_fragis<=0)return;
+  coded_fragis=_enc->state.coded_fragis;
+  frags=_enc->state.frags;
+  flag=!!frags[coded_fragis[0]].qii;
+  oggpackB_write(&_enc->opb,flag,1);
+  nqi0=0;
+  for(fragii=0;fragii<ncoded_fragis;){
+    for(run_count=0;fragii<ncoded_fragis;fragii++){
+      if(!!frags[coded_fragis[fragii]].qii!=flag)break;
+      run_count++;
+      nqi0+=!flag;
+    }
+    oc_sb_run_pack(&_enc->opb,run_count,flag,fragii>=ncoded_fragis);
+    flag=!flag;
+  }
+  if(_enc->state.nqis<3||nqi0>=ncoded_fragis)return;
+  for(fragii=0;!frags[coded_fragis[fragii]].qii;fragii++);
+  flag=frags[coded_fragis[fragii]].qii-1;
+  oggpackB_write(&_enc->opb,flag,1);
+  while(fragii<ncoded_fragis){
+    for(run_count=0;fragii<ncoded_fragis;fragii++){
+      int qii;
+      qii=frags[coded_fragis[fragii]].qii;
+      if(!qii)continue;
+      if(qii-1!=flag)break;
+      run_count++;
+    }
+    oc_sb_run_pack(&_enc->opb,run_count,flag,fragii>=ncoded_fragis);
+    flag=!flag;
+  }
+}
+
+/*Counts the tokens of each type used for the given range of coefficient
+   indices in zig-zag order.
+  _zzi_start:      The first zig-zag index to include.
+  _zzi_end:        The first zig-zag index to not include.
+  _token_counts_y: Returns the token counts for the Y' plane.
+  _token_counts_c: Returns the token counts for the Cb and Cr planes.*/
+static void oc_enc_count_tokens(oc_enc_ctx *_enc,int _zzi_start,int _zzi_end,
+ ptrdiff_t _token_counts_y[32],ptrdiff_t _token_counts_c[32]){
+  const unsigned char *dct_tokens;
+  ptrdiff_t            ndct_tokens;
+  int                  pli;
+  int                  zzi;
+  ptrdiff_t            ti;
+  memset(_token_counts_y,0,32*sizeof(*_token_counts_y));
+  memset(_token_counts_c,0,32*sizeof(*_token_counts_c));
+  for(zzi=_zzi_start;zzi<_zzi_end;zzi++){
+    dct_tokens=_enc->dct_tokens[0][zzi];
+    ndct_tokens=_enc->ndct_tokens[0][zzi];
+    for(ti=_enc->dct_token_offs[0][zzi];ti<ndct_tokens;ti++){
+      _token_counts_y[dct_tokens[ti]]++;
+    }
+  }
+  for(pli=1;pli<3;pli++){
+    for(zzi=_zzi_start;zzi<_zzi_end;zzi++){
+      dct_tokens=_enc->dct_tokens[pli][zzi];
+      ndct_tokens=_enc->ndct_tokens[pli][zzi];
+      for(ti=_enc->dct_token_offs[pli][zzi];ti<ndct_tokens;ti++){
+        _token_counts_c[dct_tokens[ti]]++;
+      }
+    }
+  }
+}
+
+/*Computes the number of bits used for each of the potential Huffman code for
+   the given list of token counts.
+  The bits are added to whatever the current bit counts are.*/
+static void oc_enc_count_bits(oc_enc_ctx *_enc,int _hgi,
+ const ptrdiff_t _token_counts[32],size_t _bit_counts[16]){
+  int huffi;
+  int huff_offs;
+  int token;
+  huff_offs=_hgi<<4;
+  for(huffi=0;huffi<16;huffi++){
+    for(token=0;token<32;token++){
+      _bit_counts[huffi]+=
+       _token_counts[token]*_enc->huff_codes[huffi+huff_offs][token].nbits;
+    }
+  }
+}
+
+/*Returns the Huffman index using the fewest number of bits.*/
+static int oc_select_huff_idx(size_t _bit_counts[16]){
+  int best_huffi;
+  int huffi;
+  best_huffi=0;
+  for(huffi=1;huffi<16;huffi++)if(_bit_counts[huffi]<_bit_counts[best_huffi]){
+    best_huffi=huffi;
+  }
+  return best_huffi;
+}
+
+static void oc_enc_huff_group_pack(oc_enc_ctx *_enc,
+ int _zzi_start,int _zzi_end,const int _huff_idxs[2]){
+  int zzi;
+  for(zzi=_zzi_start;zzi<_zzi_end;zzi++){
+    int pli;
+    for(pli=0;pli<3;pli++){
+      const unsigned char *dct_tokens;
+      const ogg_uint16_t  *extra_bits;
+      ptrdiff_t            ndct_tokens;
+      const th_huff_code  *huff_codes;
+      ptrdiff_t            ti;
+      dct_tokens=_enc->dct_tokens[pli][zzi];
+      extra_bits=_enc->extra_bits[pli][zzi];
+      ndct_tokens=_enc->ndct_tokens[pli][zzi];
+      huff_codes=_enc->huff_codes[_huff_idxs[pli+1>>1]];
+      for(ti=_enc->dct_token_offs[pli][zzi];ti<ndct_tokens;ti++){
+        int token;
+        int neb;
+        token=dct_tokens[ti];
+        oggpackB_write(&_enc->opb,huff_codes[token].pattern,
+         huff_codes[token].nbits);
+        neb=OC_DCT_TOKEN_EXTRA_BITS[token];
+        if(neb)oggpackB_write(&_enc->opb,extra_bits[ti],neb);
+      }
+    }
+  }
+}
+
+static void oc_enc_residual_tokens_pack(oc_enc_ctx *_enc){
+  static const unsigned char  OC_HUFF_GROUP_MIN[6]={0,1,6,15,28,64};
+  static const unsigned char *OC_HUFF_GROUP_MAX=OC_HUFF_GROUP_MIN+1;
+  ptrdiff_t token_counts_y[32];
+  ptrdiff_t token_counts_c[32];
+  size_t    bits_y[16];
+  size_t    bits_c[16];
+  int       huff_idxs[2];
+  int       frame_type;
+  int       hgi;
+  frame_type=_enc->state.frame_type;
+  /*Choose which Huffman tables to use for the DC token list.*/
+  oc_enc_count_tokens(_enc,0,1,token_counts_y,token_counts_c);
+  memset(bits_y,0,sizeof(bits_y));
+  memset(bits_c,0,sizeof(bits_c));
+  oc_enc_count_bits(_enc,0,token_counts_y,bits_y);
+  oc_enc_count_bits(_enc,0,token_counts_c,bits_c);
+  huff_idxs[0]=oc_select_huff_idx(bits_y);
+  huff_idxs[1]=oc_select_huff_idx(bits_c);
+  /*Write the DC token list with the chosen tables.*/
+  oggpackB_write(&_enc->opb,huff_idxs[0],4);
+  oggpackB_write(&_enc->opb,huff_idxs[1],4);
+  _enc->huff_idxs[frame_type][0][0]=(unsigned char)huff_idxs[0];
+  _enc->huff_idxs[frame_type][0][1]=(unsigned char)huff_idxs[1];
+  oc_enc_huff_group_pack(_enc,0,1,huff_idxs);
+  /*Choose which Huffman tables to use for the AC token lists.*/
+  memset(bits_y,0,sizeof(bits_y));
+  memset(bits_c,0,sizeof(bits_c));
+  for(hgi=1;hgi<5;hgi++){
+    oc_enc_count_tokens(_enc,OC_HUFF_GROUP_MIN[hgi],OC_HUFF_GROUP_MAX[hgi],
+     token_counts_y,token_counts_c);
+    oc_enc_count_bits(_enc,hgi,token_counts_y,bits_y);
+    oc_enc_count_bits(_enc,hgi,token_counts_c,bits_c);
+  }
+  huff_idxs[0]=oc_select_huff_idx(bits_y);
+  huff_idxs[1]=oc_select_huff_idx(bits_c);
+  /*Write the AC token lists using the chosen tables.*/
+  oggpackB_write(&_enc->opb,huff_idxs[0],4);
+  oggpackB_write(&_enc->opb,huff_idxs[1],4);
+  _enc->huff_idxs[frame_type][1][0]=(unsigned char)huff_idxs[0];
+  _enc->huff_idxs[frame_type][1][1]=(unsigned char)huff_idxs[1];
+  for(hgi=1;hgi<5;hgi++){
+    huff_idxs[0]+=16;
+    huff_idxs[1]+=16;
+    oc_enc_huff_group_pack(_enc,
+     OC_HUFF_GROUP_MIN[hgi],OC_HUFF_GROUP_MAX[hgi],huff_idxs);
+  }
+}
+
+static void oc_enc_frame_pack(oc_enc_ctx *_enc){
+  oggpackB_reset(&_enc->opb);
+  /*Only proceed if we have some coded blocks.
+    If there are no coded blocks, we can drop this frame simply by emitting a
+     0 byte packet.*/
+  if(_enc->state.ntotal_coded_fragis>0){
+    oc_enc_frame_header_pack(_enc);
+    if(_enc->state.frame_type==OC_INTER_FRAME){
+      /*Coded block flags, MB modes, and MVs are only needed for delta frames.*/
+      oc_enc_coded_flags_pack(_enc);
+      oc_enc_mb_modes_pack(_enc);
+      oc_enc_mvs_pack(_enc);
+    }
+    oc_enc_block_qis_pack(_enc);
+    oc_enc_tokenize_finish(_enc);
+    oc_enc_residual_tokens_pack(_enc);
+  }
+  /*Success: Mark the packet as ready to be flushed.*/
+  _enc->packet_state=OC_PACKET_READY;
+#if defined(OC_COLLECT_METRICS)
+  oc_enc_mode_metrics_collect(_enc);
+#endif
+}
+
+
+void oc_enc_vtable_init_c(oc_enc_ctx *_enc){
+  /*The implementations prefixed with oc_enc_ are encoder-specific.
+    The rest we re-use from the decoder.*/
+  _enc->opt_vtable.frag_sad=oc_enc_frag_sad_c;
+  _enc->opt_vtable.frag_sad_thresh=oc_enc_frag_sad_thresh_c;
+  _enc->opt_vtable.frag_sad2_thresh=oc_enc_frag_sad2_thresh_c;
+  _enc->opt_vtable.frag_satd_thresh=oc_enc_frag_satd_thresh_c;
+  _enc->opt_vtable.frag_satd2_thresh=oc_enc_frag_satd2_thresh_c;
+  _enc->opt_vtable.frag_intra_satd=oc_enc_frag_intra_satd_c;
+  _enc->opt_vtable.frag_sub=oc_enc_frag_sub_c;
+  _enc->opt_vtable.frag_sub_128=oc_enc_frag_sub_128_c;
+  _enc->opt_vtable.frag_copy2=oc_enc_frag_copy2_c;
+  _enc->opt_vtable.frag_recon_intra=oc_frag_recon_intra_c;
+  _enc->opt_vtable.frag_recon_inter=oc_frag_recon_inter_c;
+  _enc->opt_vtable.fdct8x8=oc_enc_fdct8x8_c;
+}
+
+/*Initialize the macro block neighbor lists for MC analysis.
+  This assumes that the entire mb_info memory region has been initialized with
+   zeros.*/
+static void oc_enc_mb_info_init(oc_enc_ctx *_enc){
+  oc_mb_enc_info    *embs;
+  const signed char *mb_modes;
+  unsigned           nhsbs;
+  unsigned           nvsbs;
+  unsigned           nhmbs;
+  unsigned           nvmbs;
+  unsigned           sby;
+  mb_modes=_enc->state.mb_modes;
+  embs=_enc->mb_info;
+  nhsbs=_enc->state.fplanes[0].nhsbs;
+  nvsbs=_enc->state.fplanes[0].nvsbs;
+  nhmbs=_enc->state.nhmbs;
+  nvmbs=_enc->state.nvmbs;
+  for(sby=0;sby<nvsbs;sby++){
+    unsigned sbx;
+    for(sbx=0;sbx<nhsbs;sbx++){
+      int quadi;
+      for(quadi=0;quadi<4;quadi++){
+        /*Because of the Hilbert curve ordering the macro blocks are
+           visited in, the available neighbors change depending on where in
+           a super block the macro block is located.
+          Only the first three vectors are used in the median calculation
+           for the optimal predictor, and so the most important should be
+           listed first.
+          Additional vectors are used, so there will always be at least 3,
+           except for in the upper-left most macro block.*/
+        /*The number of current neighbors for each macro block position.*/
+        static const unsigned char NCNEIGHBORS[4]={4,3,2,4};
+        /*The offset of each current neighbor in the X direction.*/
+        static const signed char   CDX[4][4]={
+          {-1,0,1,-1},
+          {-1,0,-1,},
+          {-1,-1},
+          {-1,0,0,1}
+        };
+        /*The offset of each current neighbor in the Y direction.*/
+        static const signed char   CDY[4][4]={
+          {0,-1,-1,-1},
+          {0,-1,-1},
+          {0,-1},
+          {0,-1,1,-1}
+        };
+        /*The offset of each previous neighbor in the X direction.*/
+        static const signed char   PDX[4]={-1,0,1,0};
+        /*The offset of each previous neighbor in the Y direction.*/
+        static const signed char   PDY[4]={0,-1,0,1};
+        unsigned mbi;
+        int      mbx;
+        int      mby;
+        unsigned nmbi;
+        int      nmbx;
+        int      nmby;
+        int      ni;
+        mbi=(sby*nhsbs+sbx<<2)+quadi;
+        if(mb_modes[mbi]==OC_MODE_INVALID)continue;
+        mbx=2*sbx+(quadi>>1);
+        mby=2*sby+(quadi+1>>1&1);
+        /*Fill in the neighbors with current motion vectors available.*/
+        for(ni=0;ni<NCNEIGHBORS[quadi];ni++){
+          nmbx=mbx+CDX[quadi][ni];
+          nmby=mby+CDY[quadi][ni];
+          if(nmbx<0||nmbx>=nhmbs||nmby<0||nmby>=nvmbs)continue;
+          nmbi=(nmby&~1)*nhmbs+((nmbx&~1)<<1)+OC_MB_MAP[nmby&1][nmbx&1];
+          if(mb_modes[nmbi]==OC_MODE_INVALID)continue;
+          embs[mbi].cneighbors[embs[mbi].ncneighbors++]=nmbi;
+        }
+        /*Fill in the neighbors with previous motion vectors available.*/
+        for(ni=0;ni<4;ni++){
+          nmbx=mbx+PDX[ni];
+          nmby=mby+PDY[ni];
+          if(nmbx<0||nmbx>=nhmbs||nmby<0||nmby>=nvmbs)continue;
+          nmbi=(nmby&~1)*nhmbs+((nmbx&~1)<<1)+OC_MB_MAP[nmby&1][nmbx&1];
+          if(mb_modes[nmbi]==OC_MODE_INVALID)continue;
+          embs[mbi].pneighbors[embs[mbi].npneighbors++]=nmbi;
+        }
+      }
+    }
+  }
+}
+
+static int oc_enc_set_huffman_codes(oc_enc_ctx *_enc,
+ const th_huff_code _codes[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS]){
+  int ret;
+  if(_enc==NULL)return TH_EFAULT;
+  if(_enc->packet_state>OC_PACKET_SETUP_HDR)return TH_EINVAL;
+  if(_codes==NULL)_codes=TH_VP31_HUFF_CODES;
+  /*Validate the codes.*/
+  oggpackB_reset(&_enc->opb);
+  ret=oc_huff_codes_pack(&_enc->opb,_codes);
+  if(ret<0)return ret;
+  memcpy(_enc->huff_codes,_codes,sizeof(_enc->huff_codes));
+  return 0;
+}
+
+/*Sets the quantization parameters to use.
+  This may only be called before the setup header is written.
+  If it is called multiple times, only the last call has any effect.
+  _qinfo: The quantization parameters.
+          These are described in more detail in theoraenc.h.
+          This can be NULL, in which case the default quantization parameters
+           will be used.*/
+static int oc_enc_set_quant_params(oc_enc_ctx *_enc,
+ const th_quant_info *_qinfo){
+  int qi;
+  int pli;
+  int qti;
+  if(_enc==NULL)return TH_EFAULT;
+  if(_enc->packet_state>OC_PACKET_SETUP_HDR)return TH_EINVAL;
+  if(_qinfo==NULL)_qinfo=&TH_DEF_QUANT_INFO;
+  /*TODO: Analyze for packing purposes instead of just doing a shallow copy.*/
+  memcpy(&_enc->qinfo,_qinfo,sizeof(_enc->qinfo));
+  for(qi=0;qi<64;qi++)for(pli=0;pli<3;pli++)for(qti=0;qti<2;qti++){
+    _enc->state.dequant_tables[qi][pli][qti]=
+     _enc->state.dequant_table_data[qi][pli][qti];
+    _enc->enquant_tables[qi][pli][qti]=_enc->enquant_table_data[qi][pli][qti];
+  }
+  oc_enquant_tables_init(_enc->state.dequant_tables,
+   _enc->enquant_tables,_qinfo);
+  memcpy(_enc->state.loop_filter_limits,_qinfo->loop_filter_limits,
+   sizeof(_enc->state.loop_filter_limits));
+  oc_enquant_qavg_init(_enc->log_qavg,_enc->state.dequant_tables,
+   _enc->state.info.pixel_fmt);
+  return 0;
+}
+
+static void oc_enc_clear(oc_enc_ctx *_enc);
+
+static int oc_enc_init(oc_enc_ctx *_enc,const th_info *_info){
+  th_info   info;
+  size_t    mcu_nmbs;
+  ptrdiff_t mcu_nfrags;
+  int       hdec;
+  int       vdec;
+  int       ret;
+  int       pli;
+  /*Clean up the requested settings.*/
+  memcpy(&info,_info,sizeof(info));
+  info.version_major=TH_VERSION_MAJOR;
+  info.version_minor=TH_VERSION_MINOR;
+  info.version_subminor=TH_VERSION_SUB;
+  if(info.quality>63)info.quality=63;
+  if(info.quality<0)info.quality=32;
+  if(info.target_bitrate<0)info.target_bitrate=0;
+  /*Initialize the shared encoder/decoder state.*/
+  ret=oc_state_init(&_enc->state,&info,4);
+  if(ret<0)return ret;
+  _enc->mb_info=_ogg_calloc(_enc->state.nmbs,sizeof(*_enc->mb_info));
+  _enc->frag_dc=_ogg_calloc(_enc->state.nfrags,sizeof(*_enc->frag_dc));
+  _enc->coded_mbis=
+   (unsigned *)_ogg_malloc(_enc->state.nmbs*sizeof(*_enc->coded_mbis));
+  hdec=!(_enc->state.info.pixel_fmt&1);
+  vdec=!(_enc->state.info.pixel_fmt&2);
+  /*If chroma is sub-sampled in the vertical direction, we have to encode two
+     super block rows of Y' for each super block row of Cb and Cr.*/
+  _enc->mcu_nvsbs=1<<vdec;
+  mcu_nmbs=_enc->mcu_nvsbs*_enc->state.fplanes[0].nhsbs*(size_t)4;
+  mcu_nfrags=4*mcu_nmbs+(8*mcu_nmbs>>hdec+vdec);
+  _enc->mcu_skip_ssd=(unsigned *)_ogg_malloc(
+   mcu_nfrags*sizeof(*_enc->mcu_skip_ssd));
+  for(pli=0;pli<3;pli++){
+    _enc->dct_tokens[pli]=(unsigned char **)oc_malloc_2d(64,
+     _enc->state.fplanes[pli].nfrags,sizeof(**_enc->dct_tokens));
+    _enc->extra_bits[pli]=(ogg_uint16_t **)oc_malloc_2d(64,
+     _enc->state.fplanes[pli].nfrags,sizeof(**_enc->extra_bits));
+  }
+#if defined(OC_COLLECT_METRICS)
+  _enc->frag_satd=_ogg_calloc(_enc->state.nfrags,sizeof(*_enc->frag_satd));
+  _enc->frag_ssd=_ogg_calloc(_enc->state.nfrags,sizeof(*_enc->frag_ssd));
+#endif
+#if defined(OC_X86_ASM)
+  oc_enc_vtable_init_x86(_enc);
+#else
+  oc_enc_vtable_init_c(_enc);
+#endif
+  _enc->keyframe_frequency_force=1<<_enc->state.info.keyframe_granule_shift;
+  _enc->state.qis[0]=_enc->state.info.quality;
+  _enc->state.nqis=1;
+  oc_rc_state_init(&_enc->rc,_enc);
+  oggpackB_writeinit(&_enc->opb);
+  if(_enc->mb_info==NULL||_enc->frag_dc==NULL||_enc->coded_mbis==NULL||
+   _enc->mcu_skip_ssd==NULL||_enc->dct_tokens[0]==NULL||
+   _enc->dct_tokens[1]==NULL||_enc->dct_tokens[2]==NULL||
+   _enc->extra_bits[0]==NULL||_enc->extra_bits[1]==NULL||
+   _enc->extra_bits[2]==NULL
+#if defined(OC_COLLECT_METRICS)
+   ||_enc->frag_satd==NULL||_enc->frag_ssd==NULL
+#endif
+   ){
+    oc_enc_clear(_enc);
+    return TH_EFAULT;
+  }
+  oc_mode_scheme_chooser_init(&_enc->chooser);
+  oc_enc_mb_info_init(_enc);
+  memset(_enc->huff_idxs,0,sizeof(_enc->huff_idxs));
+  /*Reset the packet-out state machine.*/
+  _enc->packet_state=OC_PACKET_INFO_HDR;
+  _enc->dup_count=0;
+  _enc->nqueued_dups=0;
+  _enc->prev_dup_count=0;
+  /*Enable speed optimizations up through early skip by default.*/
+  _enc->sp_level=OC_SP_LEVEL_EARLY_SKIP;
+  /*Disable VP3 compatibility by default.*/
+  _enc->vp3_compatible=0;
+  /*No INTER frames coded yet.*/
+  _enc->coded_inter_frame=0;
+  memcpy(_enc->huff_codes,TH_VP31_HUFF_CODES,sizeof(_enc->huff_codes));
+  oc_enc_set_quant_params(_enc,NULL);
+  return 0;
+}
+
+static void oc_enc_clear(oc_enc_ctx *_enc){
+  int pli;
+  oc_rc_state_clear(&_enc->rc);
+#if defined(OC_COLLECT_METRICS)
+  oc_enc_mode_metrics_dump(_enc);
+#endif
+  oggpackB_writeclear(&_enc->opb);
+#if defined(OC_COLLECT_METRICS)
+  _ogg_free(_enc->frag_ssd);
+  _ogg_free(_enc->frag_satd);
+#endif
+  for(pli=3;pli-->0;){
+    oc_free_2d(_enc->extra_bits[pli]);
+    oc_free_2d(_enc->dct_tokens[pli]);
+  }
+  _ogg_free(_enc->mcu_skip_ssd);
+  _ogg_free(_enc->coded_mbis);
+  _ogg_free(_enc->frag_dc);
+  _ogg_free(_enc->mb_info);
+  oc_state_clear(&_enc->state);
+}
+
+static void oc_enc_drop_frame(th_enc_ctx *_enc){
+  /*Use the previous frame's reconstruction.*/
+  _enc->state.ref_frame_idx[OC_FRAME_SELF]=
+   _enc->state.ref_frame_idx[OC_FRAME_PREV];
+  /*Flag motion vector analysis about the frame drop.*/
+  _enc->prevframe_dropped=1;
+  /*Zero the packet.*/
+  oggpackB_reset(&_enc->opb);
+}
+
+static void oc_enc_compress_keyframe(oc_enc_ctx *_enc,int _recode){
+  if(_enc->state.info.target_bitrate>0){
+    _enc->state.qis[0]=oc_enc_select_qi(_enc,OC_INTRA_FRAME,
+     _enc->state.curframe_num>0);
+    _enc->state.nqis=1;
+  }
+  oc_enc_calc_lambda(_enc,OC_INTRA_FRAME);
+  oc_enc_analyze_intra(_enc,_recode);
+  oc_enc_frame_pack(_enc);
+  /*On the first frame, the previous call was an initial dry-run to prime
+     feed-forward statistics.*/
+  if(!_recode&&_enc->state.curframe_num==0){
+    if(_enc->state.info.target_bitrate>0){
+      oc_enc_update_rc_state(_enc,oggpackB_bytes(&_enc->opb)<<3,
+                             OC_INTRA_FRAME,_enc->state.qis[0],1,0);
+    }
+    oc_enc_compress_keyframe(_enc,1);
+  }
+}
+
+static void oc_enc_compress_frame(oc_enc_ctx *_enc,int _recode){
+  if(_enc->state.info.target_bitrate>0){
+    _enc->state.qis[0]=oc_enc_select_qi(_enc,OC_INTER_FRAME,1);
+    _enc->state.nqis=1;
+  }
+  oc_enc_calc_lambda(_enc,OC_INTER_FRAME);
+  if(oc_enc_analyze_inter(_enc,_enc->rc.twopass!=2,_recode)){
+    /*Mode analysis thinks this should have been a keyframe; start over.*/
+    oc_enc_compress_keyframe(_enc,1);
+  }
+  else{
+    oc_enc_frame_pack(_enc);
+    if(!_enc->coded_inter_frame){
+      /*On the first INTER frame, the previous call was an initial dry-run to
+         prime feed-forward statistics.*/
+      _enc->coded_inter_frame=1;
+      if(_enc->state.info.target_bitrate>0){
+        /*Rate control also needs to prime.*/
+        oc_enc_update_rc_state(_enc,oggpackB_bytes(&_enc->opb)<<3,
+         OC_INTER_FRAME,_enc->state.qis[0],1,0);
+      }
+      oc_enc_compress_frame(_enc,1);
+    }
+  }
+}
+
+/*Set the granule position for the next packet to output based on the current
+   internal state.*/
+static void oc_enc_set_granpos(oc_enc_ctx *_enc){
+  unsigned dup_offs;
+  /*Add an offset for the number of duplicate frames we've emitted so far.*/
+  dup_offs=_enc->prev_dup_count-_enc->nqueued_dups;
+  /*If the current frame was a keyframe, use it for the high part.*/
+  if(_enc->state.frame_type==OC_INTRA_FRAME){
+    _enc->state.granpos=(_enc->state.curframe_num+_enc->state.granpos_bias<<
+     _enc->state.info.keyframe_granule_shift)+dup_offs;
+  }
+  /*Otherwise use the last keyframe in the high part and put the current frame
+     in the low part.*/
+  else{
+    _enc->state.granpos=
+     (_enc->state.keyframe_num+_enc->state.granpos_bias<<
+     _enc->state.info.keyframe_granule_shift)
+     +_enc->state.curframe_num-_enc->state.keyframe_num+dup_offs;
+  }
+}
+
+
+th_enc_ctx *th_encode_alloc(const th_info *_info){
+  oc_enc_ctx *enc;
+  if(_info==NULL)return NULL;
+  enc=_ogg_malloc(sizeof(*enc));
+  if(enc==NULL||oc_enc_init(enc,_info)<0){
+    _ogg_free(enc);
+    return NULL;
+  }
+  return enc;
+}
+
+void th_encode_free(th_enc_ctx *_enc){
+  if(_enc!=NULL){
+    oc_enc_clear(_enc);
+    _ogg_free(_enc);
+  }
+}
+
+int th_encode_ctl(th_enc_ctx *_enc,int _req,void *_buf,size_t _buf_sz){
+  switch(_req){
+    case TH_ENCCTL_SET_HUFFMAN_CODES:{
+      if(_buf==NULL&&_buf_sz!=0||
+       _buf!=NULL&&_buf_sz!=sizeof(th_huff_table)*TH_NHUFFMAN_TABLES){
+        return TH_EINVAL;
+      }
+      return oc_enc_set_huffman_codes(_enc,(const th_huff_table *)_buf);
+    }break;
+    case TH_ENCCTL_SET_QUANT_PARAMS:{
+      if(_buf==NULL&&_buf_sz!=0||
+       _buf!=NULL&&_buf_sz!=sizeof(th_quant_info)){
+        return TH_EINVAL;
+      }
+      return oc_enc_set_quant_params(_enc,(th_quant_info *)_buf);
+    }break;
+    case TH_ENCCTL_SET_KEYFRAME_FREQUENCY_FORCE:{
+      ogg_uint32_t keyframe_frequency_force;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(keyframe_frequency_force))return TH_EINVAL;
+      keyframe_frequency_force=*(ogg_uint32_t *)_buf;
+      if(keyframe_frequency_force<=0)keyframe_frequency_force=1;
+      if(_enc->packet_state==OC_PACKET_INFO_HDR){
+        /*It's still early enough to enlarge keyframe_granule_shift.*/
+        _enc->state.info.keyframe_granule_shift=OC_CLAMPI(
+         _enc->state.info.keyframe_granule_shift,
+         OC_ILOG_32(keyframe_frequency_force-1),31);
+      }
+      _enc->keyframe_frequency_force=OC_MINI(keyframe_frequency_force,
+       (ogg_uint32_t)1U<<_enc->state.info.keyframe_granule_shift);
+      *(ogg_uint32_t *)_buf=_enc->keyframe_frequency_force;
+      return 0;
+    }break;
+    case TH_ENCCTL_SET_VP3_COMPATIBLE:{
+      int vp3_compatible;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(vp3_compatible))return TH_EINVAL;
+      vp3_compatible=*(int *)_buf;
+      _enc->vp3_compatible=vp3_compatible;
+      if(oc_enc_set_huffman_codes(_enc,TH_VP31_HUFF_CODES)<0)vp3_compatible=0;
+      if(oc_enc_set_quant_params(_enc,&TH_VP31_QUANT_INFO)<0)vp3_compatible=0;
+      if(_enc->state.info.pixel_fmt!=TH_PF_420||
+       _enc->state.info.pic_width<_enc->state.info.frame_width||
+       _enc->state.info.pic_height<_enc->state.info.frame_height||
+      /*If we have more than 4095 super blocks, VP3's RLE coding might
+         overflow.
+        We could overcome this by ensuring we flip the coded/not-coded flags on
+         at least one super block in the frame, but we pick the simple solution
+         of just telling the user the stream will be incompatible instead.
+        It's unlikely the old VP3 codec would be able to decode streams at this
+         resolution in real time in the first place.*/
+       _enc->state.nsbs>4095){
+        vp3_compatible=0;
+      }
+      *(int *)_buf=vp3_compatible;
+      return 0;
+    }break;
+    case TH_ENCCTL_GET_SPLEVEL_MAX:{
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(int))return TH_EINVAL;
+      *(int *)_buf=OC_SP_LEVEL_MAX;
+      return 0;
+    }break;
+    case TH_ENCCTL_SET_SPLEVEL:{
+      int speed;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(speed))return TH_EINVAL;
+      speed=*(int *)_buf;
+      if(speed<0||speed>OC_SP_LEVEL_MAX)return TH_EINVAL;
+      _enc->sp_level=speed;
+      return 0;
+    }break;
+    case TH_ENCCTL_GET_SPLEVEL:{
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(int))return TH_EINVAL;
+      *(int *)_buf=_enc->sp_level;
+      return 0;
+    }
+    case TH_ENCCTL_SET_DUP_COUNT:{
+      int dup_count;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(dup_count))return TH_EINVAL;
+      dup_count=*(int *)_buf;
+      if(dup_count>=_enc->keyframe_frequency_force)return TH_EINVAL;
+      _enc->dup_count=OC_MAXI(dup_count,0);
+      return 0;
+    }break;
+    case TH_ENCCTL_SET_QUALITY:{
+      int qi;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_enc->state.info.target_bitrate>0)return TH_EINVAL;
+      qi=*(int *)_buf;
+      if(qi<0||qi>63)return TH_EINVAL;
+      _enc->state.info.quality=qi;
+      _enc->state.qis[0]=(unsigned char)qi;
+      _enc->state.nqis=1;
+      return 0;
+    }break;
+    case TH_ENCCTL_SET_BITRATE:{
+      long bitrate;
+      int  reset;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      bitrate=*(long *)_buf;
+      if(bitrate<=0)return TH_EINVAL;
+      reset=_enc->state.info.target_bitrate<=0;
+      _enc->state.info.target_bitrate=bitrate>INT_MAX?INT_MAX:bitrate;
+      if(reset)oc_rc_state_init(&_enc->rc,_enc);
+      else oc_enc_rc_resize(_enc);
+      return 0;
+    }break;
+    case TH_ENCCTL_SET_RATE_FLAGS:{
+      int set;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(set))return TH_EINVAL;
+      if(_enc->state.info.target_bitrate<=0)return TH_EINVAL;
+      set=*(int *)_buf;
+      _enc->rc.drop_frames=set&TH_RATECTL_DROP_FRAMES;
+      _enc->rc.cap_overflow=set&TH_RATECTL_CAP_OVERFLOW;
+      _enc->rc.cap_underflow=set&TH_RATECTL_CAP_UNDERFLOW;
+      return 0;
+    }break;
+    case TH_ENCCTL_SET_RATE_BUFFER:{
+      int set;
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_buf_sz!=sizeof(set))return TH_EINVAL;
+      if(_enc->state.info.target_bitrate<=0)return TH_EINVAL;
+      set=*(int *)_buf;
+      _enc->rc.buf_delay=set;
+      oc_enc_rc_resize(_enc);
+      *(int *)_buf=_enc->rc.buf_delay;
+      return 0;
+    }break;
+    case TH_ENCCTL_2PASS_OUT:{
+      if(_enc==NULL||_buf==NULL)return TH_EFAULT;
+      if(_enc->state.info.target_bitrate<=0||
+       _enc->state.curframe_num>=0&&_enc->rc.twopass!=1||
+       _buf_sz!=sizeof(unsigned char *)){
+        return TH_EINVAL;
+      }
+      return oc_enc_rc_2pass_out(_enc,(unsigned char **)_buf);
+    }break;
+    case TH_ENCCTL_2PASS_IN:{
+      if(_enc==NULL)return TH_EFAULT;
+      if(_enc->state.info.target_bitrate<=0||
+       _enc->state.curframe_num>=0&&_enc->rc.twopass!=2){
+        return TH_EINVAL;
+      }
+      return oc_enc_rc_2pass_in(_enc,_buf,_buf_sz);
+    }break;
+    default:return TH_EIMPL;
+  }
+}
+
+int th_encode_flushheader(th_enc_ctx *_enc,th_comment *_tc,ogg_packet *_op){
+  if(_enc==NULL)return TH_EFAULT;
+  return oc_state_flushheader(&_enc->state,&_enc->packet_state,&_enc->opb,
+   &_enc->qinfo,(const th_huff_table *)_enc->huff_codes,th_version_string(),
+   _tc,_op);
+}
+
+static void oc_img_plane_copy_pad(th_img_plane *_dst,th_img_plane *_src,
+ ogg_int32_t _pic_x,ogg_int32_t _pic_y,
+ ogg_int32_t _pic_width,ogg_int32_t _pic_height){
+  unsigned char *dst;
+  int            dstride;
+  ogg_uint32_t   frame_width;
+  ogg_uint32_t   frame_height;
+  ogg_uint32_t   y;
+  frame_width=_dst->width;
+  frame_height=_dst->height;
+  /*If we have _no_ data, just encode a dull green.*/
+  if(_pic_width==0||_pic_height==0){
+    dst=_dst->data;
+    dstride=_dst->stride;
+    for(y=0;y<frame_height;y++){
+      memset(dst,0,frame_width*sizeof(*dst));
+      dst+=dstride;
+    }
+  }
+  /*Otherwise, copy what we do have, and add our own padding.*/
+  else{
+    unsigned char *dst_data;
+    unsigned char *src_data;
+    unsigned char *src;
+    int            sstride;
+    ogg_uint32_t   x;
+    /*Step 1: Copy the data we do have.*/
+    dstride=_dst->stride;
+    sstride=_src->stride;
+    dst_data=_dst->data;
+    src_data=_src->data;
+    dst=dst_data+_pic_y*(ptrdiff_t)dstride+_pic_x;
+    src=src_data+_pic_y*(ptrdiff_t)sstride+_pic_x;
+    for(y=0;y<_pic_height;y++){
+      memcpy(dst,src,_pic_width);
+      dst+=dstride;
+      src+=sstride;
+    }
+    /*Step 2: Perform a low-pass extension into the padding region.*/
+    /*Left side.*/
+    for(x=_pic_x;x-->0;){
+      dst=dst_data+_pic_y*(ptrdiff_t)dstride+x;
+      for(y=0;y<_pic_height;y++){
+        dst[0]=(dst[1]<<1)+(dst-(dstride&-(y>0)))[1]
+         +(dst+(dstride&-(y+1<_pic_height)))[1]+2>>2;
+        dst+=dstride;
+      }
+    }
+    /*Right side.*/
+    for(x=_pic_x+_pic_width;x<frame_width;x++){
+      dst=dst_data+_pic_y*(ptrdiff_t)dstride+x-1;
+      for(y=0;y<_pic_height;y++){
+        dst[1]=(dst[0]<<1)+(dst-(dstride&-(y>0)))[0]
+         +(dst+(dstride&-(y+1<_pic_height)))[0]+2>>2;
+        dst+=dstride;
+      }
+    }
+    /*Top.*/
+    dst=dst_data+_pic_y*(ptrdiff_t)dstride;
+    for(y=_pic_y;y-->0;){
+      for(x=0;x<frame_width;x++){
+        (dst-dstride)[x]=(dst[x]<<1)+dst[x-(x>0)]
+         +dst[x+(x+1<frame_width)]+2>>2;
+      }
+      dst-=dstride;
+    }
+    /*Bottom.*/
+    dst=dst_data+(_pic_y+_pic_height)*(ptrdiff_t)dstride;
+    for(y=_pic_y+_pic_height;y<frame_height;y++){
+      for(x=0;x<frame_width;x++){
+        dst[x]=((dst-dstride)[x]<<1)+(dst-dstride)[x-(x>0)]
+         +(dst-dstride)[x+(x+1<frame_width)]+2>>2;
+      }
+      dst+=dstride;
+    }
+  }
+}
+
+int th_encode_ycbcr_in(th_enc_ctx *_enc,th_ycbcr_buffer _img){
+  th_ycbcr_buffer img;
+  int             cframe_width;
+  int             cframe_height;
+  int             cpic_width;
+  int             cpic_height;
+  int             cpic_x;
+  int             cpic_y;
+  int             hdec;
+  int             vdec;
+  int             pli;
+  int             refi;
+  int             drop;
+  /*Step 1: validate parameters.*/
+  if(_enc==NULL||_img==NULL)return TH_EFAULT;
+  if(_enc->packet_state==OC_PACKET_DONE)return TH_EINVAL;
+  if(_enc->rc.twopass&&_enc->rc.twopass_buffer_bytes==0)return TH_EINVAL;
+  if((ogg_uint32_t)_img[0].width!=_enc->state.info.frame_width||
+   (ogg_uint32_t)_img[0].height!=_enc->state.info.frame_height){
+    return TH_EINVAL;
+  }
+  hdec=!(_enc->state.info.pixel_fmt&1);
+  vdec=!(_enc->state.info.pixel_fmt&2);
+  cframe_width=_enc->state.info.frame_width>>hdec;
+  cframe_height=_enc->state.info.frame_height>>vdec;
+  if(_img[1].width!=cframe_width||_img[2].width!=cframe_width||
+   _img[1].height!=cframe_height||_img[2].height!=cframe_height){
+    return TH_EINVAL;
+  }
+  /*Step 2: Copy the input to our internal buffer.
+    This lets us add padding, if necessary, so we don't have to worry about
+     dereferencing possibly invalid addresses, and allows us to use the same
+     strides and fragment offsets for both the input frame and the reference
+     frames.*/
+  /*Flip the input buffer upside down.*/
+  oc_ycbcr_buffer_flip(img,_img);
+  oc_img_plane_copy_pad(_enc->state.ref_frame_bufs[OC_FRAME_IO]+0,img+0,
+   _enc->state.info.pic_x,_enc->state.info.pic_y,
+   _enc->state.info.pic_width,_enc->state.info.pic_height);
+  cpic_x=_enc->state.info.pic_x>>hdec;
+  cpic_y=_enc->state.info.pic_y>>vdec;
+  cpic_width=(_enc->state.info.pic_x+_enc->state.info.pic_width+hdec>>hdec)
+   -cpic_x;
+  cpic_height=(_enc->state.info.pic_y+_enc->state.info.pic_height+vdec>>vdec)
+   -cpic_y;
+  for(pli=1;pli<3;pli++){
+    oc_img_plane_copy_pad(_enc->state.ref_frame_bufs[OC_FRAME_IO]+pli,img+pli,
+     cpic_x,cpic_y,cpic_width,cpic_height);
+  }
+  /*Step 3: Update the buffer state.*/
+  if(_enc->state.ref_frame_idx[OC_FRAME_SELF]>=0){
+    _enc->state.ref_frame_idx[OC_FRAME_PREV]=
+     _enc->state.ref_frame_idx[OC_FRAME_SELF];
+    if(_enc->state.frame_type==OC_INTRA_FRAME){
+      /*The new frame becomes both the previous and gold reference frames.*/
+      _enc->state.keyframe_num=_enc->state.curframe_num;
+      _enc->state.ref_frame_idx[OC_FRAME_GOLD]=
+       _enc->state.ref_frame_idx[OC_FRAME_SELF];
+    }
+  }
+  /*Select a free buffer to use for the reconstructed version of this frame.*/
+  for(refi=0;refi==_enc->state.ref_frame_idx[OC_FRAME_GOLD]||
+   refi==_enc->state.ref_frame_idx[OC_FRAME_PREV];refi++);
+  _enc->state.ref_frame_idx[OC_FRAME_SELF]=refi;
+  _enc->state.curframe_num+=_enc->prev_dup_count+1;
+  /*Step 4: Compress the frame.*/
+  /*Start with a keyframe, and don't allow the generation of invalid files that
+     overflow the keyframe_granule_shift.*/
+  if(_enc->rc.twopass_force_kf||_enc->state.curframe_num==0||
+   _enc->state.curframe_num-_enc->state.keyframe_num+_enc->dup_count>=
+   _enc->keyframe_frequency_force){
+    oc_enc_compress_keyframe(_enc,0);
+    drop=0;
+  }
+  else{
+    oc_enc_compress_frame(_enc,0);
+    drop=1;
+  }
+  oc_restore_fpu(&_enc->state);
+  /*drop currently indicates if the frame is droppable.*/
+  if(_enc->state.info.target_bitrate>0){
+    drop=oc_enc_update_rc_state(_enc,oggpackB_bytes(&_enc->opb)<<3,
+     _enc->state.frame_type,_enc->state.qis[0],0,drop);
+  }
+  else drop=0;
+  /*drop now indicates if the frame was dropped.*/
+  if(drop)oc_enc_drop_frame(_enc);
+  else _enc->prevframe_dropped=0;
+  _enc->packet_state=OC_PACKET_READY;
+  _enc->prev_dup_count=_enc->nqueued_dups=_enc->dup_count;
+  _enc->dup_count=0;
+#if defined(OC_DUMP_IMAGES)
+  oc_enc_set_granpos(_enc);
+  oc_state_dump_frame(&_enc->state,OC_FRAME_IO,"src");
+  oc_state_dump_frame(&_enc->state,OC_FRAME_SELF,"rec");
+#endif
+  return 0;
+}
+
+int th_encode_packetout(th_enc_ctx *_enc,int _last_p,ogg_packet *_op){
+  if(_enc==NULL||_op==NULL)return TH_EFAULT;
+  if(_enc->packet_state==OC_PACKET_READY){
+    _enc->packet_state=OC_PACKET_EMPTY;
+    if(_enc->rc.twopass!=1){
+      unsigned char *packet;
+      packet=oggpackB_get_buffer(&_enc->opb);
+      /*If there's no packet, malloc failed while writing; it's lost forever.*/
+      if(packet==NULL)return TH_EFAULT;
+      _op->packet=packet;
+      _op->bytes=oggpackB_bytes(&_enc->opb);
+    }
+    /*For the first pass in 2-pass mode, don't emit any packet data.*/
+    else{
+      _op->packet=NULL;
+      _op->bytes=0;
+    }
+  }
+  else if(_enc->packet_state==OC_PACKET_EMPTY){
+    if(_enc->nqueued_dups>0){
+      _enc->nqueued_dups--;
+      _op->packet=NULL;
+      _op->bytes=0;
+    }
+    else{
+      if(_last_p)_enc->packet_state=OC_PACKET_DONE;
+      return 0;
+    }
+  }
+  else return 0;
+  _last_p=_last_p&&_enc->nqueued_dups<=0;
+  _op->b_o_s=0;
+  _op->e_o_s=_last_p;
+  oc_enc_set_granpos(_enc);
+  _op->packetno=th_granule_frame(_enc,_enc->state.granpos)+3;
+  _op->granulepos=_enc->state.granpos;
+  if(_last_p)_enc->packet_state=OC_PACKET_DONE;
+  return 1+_enc->nqueued_dups;
+}
diff --git a/lib/encoder_disabled.c b/lib/encoder_disabled.c
new file mode 100644 (file)
index 0000000..0cbf664
--- /dev/null
@@ -0,0 +1,67 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: encoder_disabled.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include "apiwrapper.h"
+#include "encint.h"
+
+th_enc_ctx *th_encode_alloc(const th_info *_info){
+  return NULL;
+}
+
+void th_encode_free(th_enc_ctx *_enc){}
+
+
+int th_encode_ctl(th_enc_ctx *_enc,int _req,void *_buf,size_t _buf_sz){
+  return OC_DISABLED;
+}
+
+int th_encode_flushheader(th_enc_ctx *_enc,th_comment *_tc,ogg_packet *_op){
+  return OC_DISABLED;
+}
+
+int th_encode_ycbcr_in(th_enc_ctx *_enc,th_ycbcr_buffer _img){
+  return OC_DISABLED;
+}
+
+int th_encode_packetout(th_enc_ctx *_enc,int _last_p,ogg_packet *_op){
+  return OC_DISABLED;
+}
+
+
+
+int theora_encode_init(theora_state *_te,theora_info *_ci){
+  return OC_DISABLED;
+}
+
+int theora_encode_YUVin(theora_state *_te,yuv_buffer *_yuv){
+  return OC_DISABLED;
+}
+
+int theora_encode_packetout(theora_state *_te,int _last_p,ogg_packet *_op){
+  return OC_DISABLED;
+}
+
+int theora_encode_header(theora_state *_te,ogg_packet *_op){
+  return OC_DISABLED;
+}
+
+int theora_encode_comment(theora_comment *_tc,ogg_packet *_op){
+  return OC_DISABLED;
+}
+
+int theora_encode_tables(theora_state *_te,ogg_packet *_op){
+  return OC_DISABLED;
+}
diff --git a/lib/enquant.c b/lib/enquant.c
new file mode 100644 (file)
index 0000000..3372fed
--- /dev/null
@@ -0,0 +1,274 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: enquant.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include <stdlib.h>
+#include <string.h>
+#include "encint.h"
+
+
+
+void oc_quant_params_pack(oggpack_buffer *_opb,const th_quant_info *_qinfo){
+  const th_quant_ranges *qranges;
+  const th_quant_base   *base_mats[2*3*64];
+  int                    indices[2][3][64];
+  int                    nbase_mats;
+  int                    nbits;
+  int                    ci;
+  int                    qi;
+  int                    qri;
+  int                    qti;
+  int                    pli;
+  int                    qtj;
+  int                    plj;
+  int                    bmi;
+  int                    i;
+  i=_qinfo->loop_filter_limits[0];
+  for(qi=1;qi<64;qi++)i=OC_MAXI(i,_qinfo->loop_filter_limits[qi]);
+  nbits=OC_ILOG_32(i);
+  oggpackB_write(_opb,nbits,3);
+  for(qi=0;qi<64;qi++){
+    oggpackB_write(_opb,_qinfo->loop_filter_limits[qi],nbits);
+  }
+  /*580 bits for VP3.*/
+  i=1;
+  for(qi=0;qi<64;qi++)i=OC_MAXI(_qinfo->ac_scale[qi],i);
+  nbits=OC_ILOGNZ_32(i);
+  oggpackB_write(_opb,nbits-1,4);
+  for(qi=0;qi<64;qi++)oggpackB_write(_opb,_qinfo->ac_scale[qi],nbits);
+  /*516 bits for VP3.*/
+  i=1;
+  for(qi=0;qi<64;qi++)i=OC_MAXI(_qinfo->dc_scale[qi],i);
+  nbits=OC_ILOGNZ_32(i);
+  oggpackB_write(_opb,nbits-1,4);
+  for(qi=0;qi<64;qi++)oggpackB_write(_opb,_qinfo->dc_scale[qi],nbits);
+  /*Consolidate any duplicate base matrices.*/
+  nbase_mats=0;
+  for(qti=0;qti<2;qti++)for(pli=0;pli<3;pli++){
+    qranges=_qinfo->qi_ranges[qti]+pli;
+    for(qri=0;qri<=qranges->nranges;qri++){
+      for(bmi=0;;bmi++){
+        if(bmi>=nbase_mats){
+          base_mats[bmi]=qranges->base_matrices+qri;
+          indices[qti][pli][qri]=nbase_mats++;
+          break;
+        }
+        else if(memcmp(base_mats[bmi][0],qranges->base_matrices[qri],
+         sizeof(base_mats[bmi][0]))==0){
+          indices[qti][pli][qri]=bmi;
+          break;
+        }
+      }
+    }
+  }
+  /*Write out the list of unique base matrices.
+    1545 bits for VP3 matrices.*/
+  oggpackB_write(_opb,nbase_mats-1,9);
+  for(bmi=0;bmi<nbase_mats;bmi++){
+    for(ci=0;ci<64;ci++)oggpackB_write(_opb,base_mats[bmi][0][ci],8);
+  }
+  /*Now store quant ranges and their associated indices into the base matrix
+     list.
+    46 bits for VP3 matrices.*/
+  nbits=OC_ILOG_32(nbase_mats-1);
+  for(i=0;i<6;i++){
+    qti=i/3;
+    pli=i%3;
+    qranges=_qinfo->qi_ranges[qti]+pli;
+    if(i>0){
+      if(qti>0){
+        if(qranges->nranges==_qinfo->qi_ranges[qti-1][pli].nranges&&
+         memcmp(qranges->sizes,_qinfo->qi_ranges[qti-1][pli].sizes,
+         qranges->nranges*sizeof(qranges->sizes[0]))==0&&
+         memcmp(indices[qti][pli],indices[qti-1][pli],
+         (qranges->nranges+1)*sizeof(indices[qti][pli][0]))==0){
+          oggpackB_write(_opb,1,2);
+          continue;
+        }
+      }
+      qtj=(i-1)/3;
+      plj=(i-1)%3;
+      if(qranges->nranges==_qinfo->qi_ranges[qtj][plj].nranges&&
+       memcmp(qranges->sizes,_qinfo->qi_ranges[qtj][plj].sizes,
+       qranges->nranges*sizeof(qranges->sizes[0]))==0&&
+       memcmp(indices[qti][pli],indices[qtj][plj],
+       (qranges->nranges+1)*sizeof(indices[qti][pli][0]))==0){
+        oggpackB_write(_opb,0,1+(qti>0));
+        continue;
+      }
+      oggpackB_write(_opb,1,1);
+    }
+    oggpackB_write(_opb,indices[qti][pli][0],nbits);
+    for(qi=qri=0;qi<63;qri++){
+      oggpackB_write(_opb,qranges->sizes[qri]-1,OC_ILOG_32(62-qi));
+      qi+=qranges->sizes[qri];
+      oggpackB_write(_opb,indices[qti][pli][qri+1],nbits);
+    }
+  }
+}
+
+static void oc_iquant_init(oc_iquant *_this,ogg_uint16_t _d){
+  ogg_uint32_t t;
+  int          l;
+  _d<<=1;
+  l=OC_ILOGNZ_32(_d)-1;
+  t=1+((ogg_uint32_t)1<<16+l)/_d;
+  _this->m=(ogg_int16_t)(t-0x10000);
+  _this->l=l;
+}
+
+/*See comments at oc_dequant_tables_init() for how the quantization tables'
+   storage should be initialized.*/
+void oc_enquant_tables_init(ogg_uint16_t *_dequant[64][3][2],
+ oc_iquant *_enquant[64][3][2],const th_quant_info *_qinfo){
+  int qi;
+  int pli;
+  int qti;
+  /*Initialize the dequantization tables first.*/
+  oc_dequant_tables_init(_dequant,NULL,_qinfo);
+  /*Derive the quantization tables directly from the dequantization tables.*/
+  for(qi=0;qi<64;qi++)for(qti=0;qti<2;qti++)for(pli=0;pli<3;pli++){
+    int zzi;
+    int plj;
+    int qtj;
+    int dupe;
+    dupe=0;
+    for(qtj=0;qtj<=qti;qtj++){
+      for(plj=0;plj<(qtj<qti?3:pli);plj++){
+        if(_dequant[qi][pli][qti]==_dequant[qi][plj][qtj]){
+          dupe=1;
+          break;
+        }
+      }
+      if(dupe)break;
+    }
+    if(dupe){
+      _enquant[qi][pli][qti]=_enquant[qi][plj][qtj];
+      continue;
+    }
+    /*In the original VP3.2 code, the rounding offset and the size of the
+       dead zone around 0 were controlled by a "sharpness" parameter.
+      We now R-D optimize the tokens for each block after quantization,
+       so the rounding offset should always be 1/2, and an explicit dead
+       zone is unnecessary.
+      Hence, all of that VP3.2 code is gone from here, and the remaining
+       floating point code has been implemented as equivalent integer
+       code with exact precision.*/
+    for(zzi=0;zzi<64;zzi++){
+      oc_iquant_init(_enquant[qi][pli][qti]+zzi,
+       _dequant[qi][pli][qti][zzi]);
+    }
+  }
+}
+
+
+
+/*This table gives the square root of the fraction of the squared magnitude of
+   each DCT coefficient relative to the total, scaled by 2**16, for both INTRA
+   and INTER modes.
+  These values were measured after motion-compensated prediction, before
+   quantization, over a large set of test video (from QCIF to 1080p) encoded at
+   all possible rates.
+  The DC coefficient takes into account the DPCM prediction (using the
+   quantized values from neighboring blocks, as the encoder does, but still
+   before quantization of the coefficient in the current block).
+  The results differ significantly from the expected variance (e.g., using an
+   AR(1) model of the signal with rho=0.95, as is frequently done to compute
+   the coding gain of the DCT).
+  We use them to estimate an "average" quantizer for a given quantizer matrix,
+   as this is used to parameterize a number of the rate control decisions.
+  These values are themselves probably quantizer-matrix dependent, since the
+   shape of the matrix affects the noise distribution in the reference frames,
+   but they should at least give us _some_ amount of adaptivity to different
+   matrices, as opposed to hard-coding a table of average Q values for the
+   current set.
+  The main features they capture are that a) only a few of the quantizers in
+   the upper-left corner contribute anything significant at all (though INTER
+   mode is significantly flatter) and b) the DPCM prediction of the DC
+   coefficient gives a very minor improvement in the INTRA case and a quite
+   significant one in the INTER case (over the expected variance).*/
+static const ogg_uint16_t OC_RPSD[2][64]={
+  {
+    52725,17370,10399, 6867, 5115, 3798, 2942, 2076,
+    17370, 9900, 6948, 4994, 3836, 2869, 2229, 1619,
+    10399, 6948, 5516, 4202, 3376, 2573, 2015, 1461,
+     6867, 4994, 4202, 3377, 2800, 2164, 1718, 1243,
+     5115, 3836, 3376, 2800, 2391, 1884, 1530, 1091,
+     3798, 2869, 2573, 2164, 1884, 1495, 1212,  873,
+     2942, 2229, 2015, 1718, 1530, 1212, 1001,  704,
+     2076, 1619, 1461, 1243, 1091,  873,  704,  474
+  },
+  {
+    23411,15604,13529,11601,10683, 8958, 7840, 6142,
+    15604,11901,10718, 9108, 8290, 6961, 6023, 4487,
+    13529,10718, 9961, 8527, 7945, 6689, 5742, 4333,
+    11601, 9108, 8527, 7414, 7084, 5923, 5175, 3743,
+    10683, 8290, 7945, 7084, 6771, 5754, 4793, 3504,
+     8958, 6961, 6689, 5923, 5754, 4679, 3936, 2989,
+     7840, 6023, 5742, 5175, 4793, 3936, 3522, 2558,
+     6142, 4487, 4333, 3743, 3504, 2989, 2558, 1829
+  }
+};
+
+/*The fraction of the squared magnitude of the residuals in each color channel
+   relative to the total, scaled by 2**16, for each pixel format.
+  These values were measured after motion-compensated prediction, before
+   quantization, over a large set of test video encoded at all possible rates.
+  TODO: These values are only from INTER frames; it should be re-measured for
+   INTRA frames.*/
+static const ogg_uint16_t OC_PCD[4][3]={
+  {59926, 3038, 2572},
+  {55201, 5597, 4738},
+  {55201, 5597, 4738},
+  {47682, 9669, 8185}
+};
+
+
+/*Compute an "average" quantizer for each qi level.
+  We do one for INTER and one for INTRA, since their behavior is very
+   different, but average across chroma channels.
+  The basic approach is to compute a harmonic average of the squared quantizer,
+   weighted by the expected squared magnitude of the DCT coefficients.
+  Under the (not quite true) assumption that DCT coefficients are
+   Laplacian-distributed, this preserves the product Q*lambda, where
+   lambda=sqrt(2/sigma**2) is the Laplacian distribution parameter (not to be
+   confused with the lambda used in R-D optimization throughout most of the
+   rest of the code).
+  The value Q*lambda completely determines the entropy of the coefficients.*/
+void oc_enquant_qavg_init(ogg_int64_t _log_qavg[2][64],
+ ogg_uint16_t *_dequant[64][3][2],int _pixel_fmt){
+  int qi;
+  int pli;
+  int qti;
+  int ci;
+  for(qti=0;qti<2;qti++)for(qi=0;qi<64;qi++){
+    ogg_int64_t q2;
+    q2=0;
+    for(pli=0;pli<3;pli++){
+      ogg_uint32_t qp;
+      qp=0;
+      for(ci=0;ci<64;ci++){
+        unsigned rq;
+        unsigned qd;
+        qd=_dequant[qi][pli][qti][OC_IZIG_ZAG[ci]];
+        rq=(OC_RPSD[qti][ci]+(qd>>1))/qd;
+        qp+=rq*(ogg_uint32_t)rq;
+      }
+      q2+=OC_PCD[_pixel_fmt][pli]*(ogg_int64_t)qp;
+    }
+    /*qavg=1.0/sqrt(q2).*/
+    _log_qavg[qti][qi]=OC_Q57(48)-oc_blog64(q2)>>1;
+  }
+}
diff --git a/lib/enquant.h b/lib/enquant.h
new file mode 100644 (file)
index 0000000..d62df10
--- /dev/null
@@ -0,0 +1,27 @@
+#if !defined(_enquant_H)
+# define _enquant_H (1)
+# include "quant.h"
+
+typedef struct oc_iquant oc_iquant;
+
+#define OC_QUANT_MAX_LOG (OC_Q57(OC_STATIC_ILOG_32(OC_QUANT_MAX)-1))
+
+/*Used to compute x/d via ((x*m>>16)+x>>l)+(x<0))
+   (i.e., one 16x16->16 mul, 2 shifts, and 2 adds).
+  This is not an approximation; for 16-bit x and d, it is exact.*/
+struct oc_iquant{
+  ogg_int16_t m;
+  ogg_int16_t l;
+};
+
+typedef oc_iquant        oc_iquant_table[64];
+
+
+
+void oc_quant_params_pack(oggpack_buffer *_opb,const th_quant_info *_qinfo);
+void oc_enquant_tables_init(ogg_uint16_t *_dequant[64][3][2],
+ oc_iquant *_enquant[64][3][2],const th_quant_info *_qinfo);
+void oc_enquant_qavg_init(ogg_int64_t _log_qavg[2][64],
+ ogg_uint16_t *_dequant[64][3][2],int _pixel_fmt);
+
+#endif
diff --git a/lib/fdct.c b/lib/fdct.c
new file mode 100644 (file)
index 0000000..dc3a66f
--- /dev/null
@@ -0,0 +1,422 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: fdct.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include "encint.h"
+#include "dct.h"
+
+
+
+/*Performs a forward 8 point Type-II DCT transform.
+  The output is scaled by a factor of 2 from the orthonormal version of the
+   transform.
+  _y: The buffer to store the result in.
+      Data will be placed the first 8 entries (e.g., in a row of an 8x8 block).
+  _x: The input coefficients.
+      Every 8th entry is used (e.g., from a column of an 8x8 block).*/
+static void oc_fdct8(ogg_int16_t _y[8],const ogg_int16_t *_x){
+  int t0;
+  int t1;
+  int t2;
+  int t3;
+  int t4;
+  int t5;
+  int t6;
+  int t7;
+  int r;
+  int s;
+  int u;
+  int v;
+  /*Stage 1:*/
+  /*0-7 butterfly.*/
+  t0=_x[0<<3]+(int)_x[7<<3];
+  t7=_x[0<<3]-(int)_x[7<<3];
+  /*1-6 butterfly.*/
+  t1=_x[1<<3]+(int)_x[6<<3];
+  t6=_x[1<<3]-(int)_x[6<<3];
+  /*2-5 butterfly.*/
+  t2=_x[2<<3]+(int)_x[5<<3];
+  t5=_x[2<<3]-(int)_x[5<<3];
+  /*3-4 butterfly.*/
+  t3=_x[3<<3]+(int)_x[4<<3];
+  t4=_x[3<<3]-(int)_x[4<<3];
+  /*Stage 2:*/
+  /*0-3 butterfly.*/
+  r=t0+t3;
+  t3=t0-t3;
+  t0=r;
+  /*1-2 butterfly.*/
+  r=t1+t2;
+  t2=t1-t2;
+  t1=r;
+  /*6-5 butterfly.*/
+  r=t6+t5;
+  t5=t6-t5;
+  t6=r;
+  /*Stages 3 and 4 are where all the approximation occurs.
+    These are chosen to be as close to an exact inverse of the approximations
+     made in the iDCT as possible, while still using mostly 16-bit arithmetic.
+    We use some 16x16->32 signed MACs, but those still commonly execute in 1
+     cycle on a 16-bit DSP.
+    For example, s=(27146*t5+0x4000>>16)+t5+(t5!=0) is an exact inverse of
+     t5=(OC_C4S4*s>>16).
+    That is, applying the latter to the output of the former will recover t5
+     exactly (over the valid input range of t5, -23171...23169).
+    We increase the rounding bias to 0xB500 in this particular case so that
+     errors inverting the subsequent butterfly are not one-sided (e.g., the
+     mean error is very close to zero).
+    The (t5!=0) term could be replaced simply by 1, but we want to send 0 to 0.
+    The fDCT of an all-zeros block will still not be zero, because of the
+     biases we added at the very beginning of the process, but it will be close
+     enough that it is guaranteed to round to zero.*/
+  /*Stage 3:*/
+  /*4-5 butterfly.*/
+  s=(27146*t5+0xB500>>16)+t5+(t5!=0)>>1;
+  r=t4+s;
+  t5=t4-s;
+  t4=r;
+  /*7-6 butterfly.*/
+  s=(27146*t6+0xB500>>16)+t6+(t6!=0)>>1;
+  r=t7+s;
+  t6=t7-s;
+  t7=r;
+  /*Stage 4:*/
+  /*0-1 butterfly.*/
+  r=(27146*t0+0x4000>>16)+t0+(t0!=0);
+  s=(27146*t1+0xB500>>16)+t1+(t1!=0);
+  u=r+s>>1;
+  v=r-u;
+  _y[0]=u;
+  _y[4]=v;
+  /*3-2 rotation by 6pi/16*/
+  u=(OC_C6S2*t2+OC_C2S6*t3+0x6CB7>>16)+(t3!=0);
+  s=(OC_C6S2*u>>16)-t2;
+  v=(s*21600+0x2800>>18)+s+(s!=0);
+  _y[2]=u;
+  _y[6]=v;
+  /*6-5 rotation by 3pi/16*/
+  u=(OC_C5S3*t6+OC_C3S5*t5+0x0E3D>>16)+(t5!=0);
+  s=t6-(OC_C5S3*u>>16);
+  v=(s*26568+0x3400>>17)+s+(s!=0);
+  _y[5]=u;
+  _y[3]=v;
+  /*7-4 rotation by 7pi/16*/
+  u=(OC_C7S1*t4+OC_C1S7*t7+0x7B1B>>16)+(t7!=0);
+  s=(OC_C7S1*u>>16)-t4;
+  v=(s*20539+0x3000>>20)+s+(s!=0);
+  _y[1]=u;
+  _y[7]=v;
+}
+
+void oc_enc_fdct8x8(const oc_enc_ctx *_enc,ogg_int16_t _y[64],
+ const ogg_int16_t _x[64]){
+  (*_enc->opt_vtable.fdct8x8)(_y,_x);
+}
+
+/*Performs a forward 8x8 Type-II DCT transform.
+  The output is scaled by a factor of 4 relative to the orthonormal version
+   of the transform.
+  _y: The buffer to store the result in.
+      This may be the same as _x.
+  _x: The input coefficients. */
+void oc_enc_fdct8x8_c(ogg_int16_t _y[64],const ogg_int16_t _x[64]){
+  const ogg_int16_t *in;
+  ogg_int16_t       *end;
+  ogg_int16_t       *out;
+  ogg_int16_t        w[64];
+  int                i;
+  /*Add two extra bits of working precision to improve accuracy; any more and
+     we could overflow.*/
+  for(i=0;i<64;i++)w[i]=_x[i]<<2;
+  /*These biases correct for some systematic error that remains in the full
+     fDCT->iDCT round trip.*/
+  w[0]+=(w[0]!=0)+1;
+  w[1]++;
+  w[8]--;
+  /*Transform columns of w into rows of _y.*/
+  for(in=w,out=_y,end=out+64;out<end;in++,out+=8)oc_fdct8(out,in);
+  /*Transform columns of _y into rows of w.*/
+  for(in=_y,out=w,end=out+64;out<end;in++,out+=8)oc_fdct8(out,in);
+  /*Round the result back to the external working precision (which is still
+     scaled by four relative to the orthogonal result).
+    TODO: We should just update the external working precision.*/
+  for(i=0;i<64;i++)_y[i]=w[i]+2>>2;
+}
+
+
+
+/*This does not seem to outperform simple LFE border padding before MC.
+  It yields higher PSNR, but much higher bitrate usage.*/
+#if 0
+typedef struct oc_extension_info oc_extension_info;
+
+
+
+/*Information needed to pad boundary blocks.
+  We multiply each row/column by an extension matrix that fills in the padding
+   values as a linear combination of the active values, so that an equivalent
+   number of coefficients are forced to zero.
+  This costs at most 16 multiplies, the same as a 1-D fDCT itself, and as
+   little as 7 multiplies.
+  We compute the extension matrices for every possible shape in advance, as
+   there are only 35.
+  The coefficients for all matrices are stored in a single array to take
+   advantage of the overlap and repetitiveness of many of the shapes.
+  A similar technique is applied to the offsets into this array.
+  This reduces the required table storage by about 48%.
+  See tools/extgen.c for details.
+  We could conceivably do the same for all 256 possible shapes.*/
+struct oc_extension_info{
+  /*The mask of the active pixels in the shape.*/
+  short                     mask;
+  /*The number of active pixels in the shape.*/
+  short                     na;
+  /*The extension matrix.
+    This is (8-na)xna*/
+  const ogg_int16_t *const *ext;
+  /*The pixel indices: na active pixels followed by 8-na padding pixels.*/
+  unsigned char             pi[8];
+  /*The coefficient indices: na unconstrained coefficients followed by 8-na
+     coefficients to be forced to zero.*/
+  unsigned char             ci[8];
+};
+
+
+/*The number of shapes we need.*/
+#define OC_NSHAPES   (35)
+
+static const ogg_int16_t OC_EXT_COEFFS[229]={
+  0x7FFF,0xE1F8,0x6903,0xAA79,0x5587,0x7FFF,0x1E08,0x7FFF,
+  0x5587,0xAA79,0x6903,0xE1F8,0x7FFF,0x0000,0x0000,0x0000,
+  0x7FFF,0x0000,0x0000,0x7FFF,0x8000,0x7FFF,0x0000,0x0000,
+  0x7FFF,0xE1F8,0x1E08,0xB0A7,0xAA1D,0x337C,0x7FFF,0x4345,
+  0x2267,0x4345,0x7FFF,0x337C,0xAA1D,0xB0A7,0x8A8C,0x4F59,
+  0x03B4,0xE2D6,0x7FFF,0x2CF3,0x7FFF,0xE2D6,0x03B4,0x4F59,
+  0x8A8C,0x1103,0x7AEF,0x5225,0xDF60,0xC288,0xDF60,0x5225,
+  0x7AEF,0x1103,0x668A,0xD6EE,0x3A16,0x0E6C,0xFA07,0x0E6C,
+  0x3A16,0xD6EE,0x668A,0x2A79,0x2402,0x980F,0x50F5,0x4882,
+  0x50F5,0x980F,0x2402,0x2A79,0xF976,0x2768,0x5F22,0x2768,
+  0xF976,0x1F91,0x76C1,0xE9AE,0x76C1,0x1F91,0x7FFF,0xD185,
+  0x0FC8,0xD185,0x7FFF,0x4F59,0x4345,0xED62,0x4345,0x4F59,
+  0xF574,0x5D99,0x2CF3,0x5D99,0xF574,0x5587,0x3505,0x30FC,
+  0xF482,0x953C,0xEAC4,0x7FFF,0x4F04,0x7FFF,0xEAC4,0x953C,
+  0xF482,0x30FC,0x4F04,0x273D,0xD8C3,0x273D,0x1E09,0x61F7,
+  0x1E09,0x273D,0xD8C3,0x273D,0x4F04,0x30FC,0xA57E,0x153C,
+  0x6AC4,0x3C7A,0x1E08,0x3C7A,0x6AC4,0x153C,0xA57E,0x7FFF,
+  0xA57E,0x5A82,0x6AC4,0x153C,0xC386,0xE1F8,0xC386,0x153C,
+  0x6AC4,0x5A82,0xD8C3,0x273D,0x7FFF,0xE1F7,0x7FFF,0x273D,
+  0xD8C3,0x4F04,0x30FC,0xD8C3,0x273D,0xD8C3,0x30FC,0x4F04,
+  0x1FC8,0x67AD,0x1853,0xE038,0x1853,0x67AD,0x1FC8,0x4546,
+  0xE038,0x1FC8,0x3ABA,0x1FC8,0xE038,0x4546,0x3505,0x5587,
+  0xF574,0xBC11,0x78F4,0x4AFB,0xE6F3,0x4E12,0x3C11,0xF8F4,
+  0x4AFB,0x3C7A,0xF88B,0x3C11,0x78F4,0xCAFB,0x7FFF,0x08CC,
+  0x070C,0x236D,0x5587,0x236D,0x070C,0xF88B,0x3C7A,0x4AFB,
+  0xF8F4,0x3C11,0x7FFF,0x153C,0xCAFB,0x153C,0x7FFF,0x1E08,
+  0xE1F8,0x7FFF,0x08CC,0x7FFF,0xCAFB,0x78F4,0x3C11,0x4E12,
+  0xE6F3,0x4AFB,0x78F4,0xBC11,0xFE3D,0x7FFF,0xFE3D,0x2F3A,
+  0x7FFF,0x2F3A,0x89BC,0x7FFF,0x89BC
+};
+
+static const ogg_int16_t *const OC_EXT_ROWS[96]={
+  OC_EXT_COEFFS+   0,OC_EXT_COEFFS+   0,OC_EXT_COEFFS+   0,OC_EXT_COEFFS+   0,
+  OC_EXT_COEFFS+   0,OC_EXT_COEFFS+   0,OC_EXT_COEFFS+   0,OC_EXT_COEFFS+   6,
+  OC_EXT_COEFFS+  27,OC_EXT_COEFFS+  38,OC_EXT_COEFFS+  43,OC_EXT_COEFFS+  32,
+  OC_EXT_COEFFS+  49,OC_EXT_COEFFS+  58,OC_EXT_COEFFS+  67,OC_EXT_COEFFS+  71,
+  OC_EXT_COEFFS+  62,OC_EXT_COEFFS+  53,OC_EXT_COEFFS+  12,OC_EXT_COEFFS+  15,
+  OC_EXT_COEFFS+  14,OC_EXT_COEFFS+  13,OC_EXT_COEFFS+  76,OC_EXT_COEFFS+  81,
+  OC_EXT_COEFFS+  86,OC_EXT_COEFFS+  91,OC_EXT_COEFFS+  96,OC_EXT_COEFFS+  98,
+  OC_EXT_COEFFS+  93,OC_EXT_COEFFS+  88,OC_EXT_COEFFS+  83,OC_EXT_COEFFS+  78,
+  OC_EXT_COEFFS+  12,OC_EXT_COEFFS+  15,OC_EXT_COEFFS+  15,OC_EXT_COEFFS+  12,
+  OC_EXT_COEFFS+  12,OC_EXT_COEFFS+  15,OC_EXT_COEFFS+  12,OC_EXT_COEFFS+  15,
+  OC_EXT_COEFFS+  15,OC_EXT_COEFFS+  12,OC_EXT_COEFFS+ 103,OC_EXT_COEFFS+ 108,
+  OC_EXT_COEFFS+ 126,OC_EXT_COEFFS+  16,OC_EXT_COEFFS+ 137,OC_EXT_COEFFS+ 141,
+  OC_EXT_COEFFS+  20,OC_EXT_COEFFS+ 130,OC_EXT_COEFFS+ 113,OC_EXT_COEFFS+ 116,
+  OC_EXT_COEFFS+ 146,OC_EXT_COEFFS+ 153,OC_EXT_COEFFS+ 160,OC_EXT_COEFFS+ 167,
+  OC_EXT_COEFFS+ 170,OC_EXT_COEFFS+ 163,OC_EXT_COEFFS+ 156,OC_EXT_COEFFS+ 149,
+  OC_EXT_COEFFS+ 119,OC_EXT_COEFFS+ 122,OC_EXT_COEFFS+ 174,OC_EXT_COEFFS+ 177,
+  OC_EXT_COEFFS+ 182,OC_EXT_COEFFS+ 187,OC_EXT_COEFFS+ 192,OC_EXT_COEFFS+ 197,
+  OC_EXT_COEFFS+ 202,OC_EXT_COEFFS+ 207,OC_EXT_COEFFS+ 210,OC_EXT_COEFFS+ 215,
+  OC_EXT_COEFFS+ 179,OC_EXT_COEFFS+ 189,OC_EXT_COEFFS+  24,OC_EXT_COEFFS+ 204,
+  OC_EXT_COEFFS+ 184,OC_EXT_COEFFS+ 194,OC_EXT_COEFFS+ 212,OC_EXT_COEFFS+ 199,
+  OC_EXT_COEFFS+ 217,OC_EXT_COEFFS+ 100,OC_EXT_COEFFS+ 134,OC_EXT_COEFFS+ 135,
+  OC_EXT_COEFFS+ 135,OC_EXT_COEFFS+  12,OC_EXT_COEFFS+  15,OC_EXT_COEFFS+ 134,
+  OC_EXT_COEFFS+ 134,OC_EXT_COEFFS+ 135,OC_EXT_COEFFS+ 220,OC_EXT_COEFFS+ 223,
+  OC_EXT_COEFFS+ 226,OC_EXT_COEFFS+ 227,OC_EXT_COEFFS+ 224,OC_EXT_COEFFS+ 221
+};
+
+static const oc_extension_info OC_EXTENSION_INFO[OC_NSHAPES]={
+  {0x7F,7,OC_EXT_ROWS+  0,{0,1,2,3,4,5,6,7},{0,1,2,4,5,6,7,3}},
+  {0xFE,7,OC_EXT_ROWS+  7,{1,2,3,4,5,6,7,0},{0,1,2,4,5,6,7,3}},
+  {0x3F,6,OC_EXT_ROWS+  8,{0,1,2,3,4,5,7,6},{0,1,3,4,6,7,5,2}},
+  {0xFC,6,OC_EXT_ROWS+ 10,{2,3,4,5,6,7,1,0},{0,1,3,4,6,7,5,2}},
+  {0x1F,5,OC_EXT_ROWS+ 12,{0,1,2,3,4,7,6,5},{0,2,3,5,7,6,4,1}},
+  {0xF8,5,OC_EXT_ROWS+ 15,{3,4,5,6,7,2,1,0},{0,2,3,5,7,6,4,1}},
+  {0x0F,4,OC_EXT_ROWS+ 18,{0,1,2,3,7,6,5,4},{0,2,4,6,7,5,3,1}},
+  {0xF0,4,OC_EXT_ROWS+ 18,{4,5,6,7,3,2,1,0},{0,2,4,6,7,5,3,1}},
+  {0x07,3,OC_EXT_ROWS+ 22,{0,1,2,7,6,5,4,3},{0,3,6,7,5,4,2,1}},
+  {0xE0,3,OC_EXT_ROWS+ 27,{5,6,7,4,3,2,1,0},{0,3,6,7,5,4,2,1}},
+  {0x03,2,OC_EXT_ROWS+ 32,{0,1,7,6,5,4,3,2},{0,4,7,6,5,3,2,1}},
+  {0xC0,2,OC_EXT_ROWS+ 32,{6,7,5,4,3,2,1,0},{0,4,7,6,5,3,2,1}},
+  {0x01,1,OC_EXT_ROWS+  0,{0,7,6,5,4,3,2,1},{0,7,6,5,4,3,2,1}},
+  {0x80,1,OC_EXT_ROWS+  0,{7,6,5,4,3,2,1,0},{0,7,6,5,4,3,2,1}},
+  {0x7E,6,OC_EXT_ROWS+ 42,{1,2,3,4,5,6,7,0},{0,1,2,5,6,7,4,3}},
+  {0x7C,5,OC_EXT_ROWS+ 44,{2,3,4,5,6,7,1,0},{0,1,4,5,7,6,3,2}},
+  {0x3E,5,OC_EXT_ROWS+ 47,{1,2,3,4,5,7,6,0},{0,1,4,5,7,6,3,2}},
+  {0x78,4,OC_EXT_ROWS+ 50,{3,4,5,6,7,2,1,0},{0,4,5,7,6,3,2,1}},
+  {0x3C,4,OC_EXT_ROWS+ 54,{2,3,4,5,7,6,1,0},{0,3,4,7,6,5,2,1}},
+  {0x1E,4,OC_EXT_ROWS+ 58,{1,2,3,4,7,6,5,0},{0,4,5,7,6,3,2,1}},
+  {0x70,3,OC_EXT_ROWS+ 62,{4,5,6,7,3,2,1,0},{0,5,7,6,4,3,2,1}},
+  {0x38,3,OC_EXT_ROWS+ 67,{3,4,5,7,6,2,1,0},{0,5,6,7,4,3,2,1}},
+  {0x1C,3,OC_EXT_ROWS+ 72,{2,3,4,7,6,5,1,0},{0,5,6,7,4,3,2,1}},
+  {0x0E,3,OC_EXT_ROWS+ 77,{1,2,3,7,6,5,4,0},{0,5,7,6,4,3,2,1}},
+  {0x60,2,OC_EXT_ROWS+ 82,{5,6,7,4,3,2,1,0},{0,2,7,6,5,4,3,1}},
+  {0x30,2,OC_EXT_ROWS+ 36,{4,5,7,6,3,2,1,0},{0,4,7,6,5,3,2,1}},
+  {0x18,2,OC_EXT_ROWS+ 90,{3,4,7,6,5,2,1,0},{0,1,7,6,5,4,3,2}},
+  {0x0C,2,OC_EXT_ROWS+ 34,{2,3,7,6,5,4,1,0},{0,4,7,6,5,3,2,1}},
+  {0x06,2,OC_EXT_ROWS+ 84,{1,2,7,6,5,4,3,0},{0,2,7,6,5,4,3,1}},
+  {0x40,1,OC_EXT_ROWS+  0,{6,7,5,4,3,2,1,0},{0,7,6,5,4,3,2,1}},
+  {0x20,1,OC_EXT_ROWS+  0,{5,7,6,4,3,2,1,0},{0,7,6,5,4,3,2,1}},
+  {0x10,1,OC_EXT_ROWS+  0,{4,7,6,5,3,2,1,0},{0,7,6,5,4,3,2,1}},
+  {0x08,1,OC_EXT_ROWS+  0,{3,7,6,5,4,2,1,0},{0,7,6,5,4,3,2,1}},
+  {0x04,1,OC_EXT_ROWS+  0,{2,7,6,5,4,3,1,0},{0,7,6,5,4,3,2,1}},
+  {0x02,1,OC_EXT_ROWS+  0,{1,7,6,5,4,3,2,0},{0,7,6,5,4,3,2,1}}
+};
+
+
+
+/*Pads a single column of a partial block and then performs a forward Type-II
+   DCT on the result.
+  The input is scaled by a factor of 4 and biased appropriately for the current
+   fDCT implementation.
+  The output is scaled by an additional factor of 2 from the orthonormal
+   version of the transform.
+  _y: The buffer to store the result in.
+      Data will be placed the first 8 entries (e.g., in a row of an 8x8 block).
+  _x: The input coefficients.
+      Every 8th entry is used (e.g., from a column of an 8x8 block).
+  _e: The extension information for the shape.*/
+static void oc_fdct8_ext(ogg_int16_t _y[8],ogg_int16_t *_x,
+ const oc_extension_info *_e){
+  const unsigned char *pi;
+  int                  na;
+  na=_e->na;
+  pi=_e->pi;
+  if(na==1){
+    int ci;
+    /*While the branch below is still correct for shapes with na==1, we can
+       perform the entire transform with just 1 multiply in this case instead
+       of 23.*/
+    _y[0]=(ogg_int16_t)(OC_DIV2_16(OC_C4S4*(_x[pi[0]])));
+    for(ci=1;ci<8;ci++)_y[ci]=0;
+  }
+  else{
+    const ogg_int16_t *const *ext;
+    int                       zpi;
+    int                       api;
+    int                       nz;
+    /*First multiply by the extension matrix to compute the padding values.*/
+    nz=8-na;
+    ext=_e->ext;
+    for(zpi=0;zpi<nz;zpi++){
+      ogg_int32_t v;
+      v=0;
+      for(api=0;api<na;api++){
+        v+=ext[zpi][api]*(ogg_int32_t)(_x[pi[api]<<3]<<1);
+      }
+      _x[pi[na+zpi]<<3]=(ogg_int16_t)(v+0x8000>>16)+1>>1;
+    }
+    oc_fdct8(_y,_x);
+  }
+}
+
+/*Performs a forward 8x8 Type-II DCT transform on blocks which overlap the
+   border of the picture region.
+  This method ONLY works with rectangular regions.
+  _border: A description of which pixels are inside the border.
+  _y:      The buffer to store the result in.
+           This may be the same as _x.
+  _x:      The input pixel values.
+           Pixel values outside the border will be ignored.*/
+void oc_fdct8x8_border(const oc_border_info *_border,
+ ogg_int16_t _y[64],const ogg_int16_t _x[64]){
+  ogg_int16_t             *in;
+  ogg_int16_t             *out;
+  ogg_int16_t              w[64];
+  ogg_int64_t              mask;
+  const oc_extension_info *cext;
+  const oc_extension_info *rext;
+  int                      cmask;
+  int                      rmask;
+  int                      ri;
+  int                      ci;
+  /*Identify the shapes of the non-zero rows and columns.*/
+  rmask=cmask=0;
+  mask=_border->mask;
+  for(ri=0;ri<8;ri++){
+    /*This aggregation is _only_ correct for rectangular masks.*/
+    cmask|=((mask&0xFF)!=0)<<ri;
+    rmask|=mask&0xFF;
+    mask>>=8;
+  }
+  /*Find the associated extension info for these shapes.*/
+  if(cmask==0xFF)cext=NULL;
+  else for(cext=OC_EXTENSION_INFO;cext->mask!=cmask;){
+    /*If we somehow can't find the shape, then just do an unpadded fDCT.
+      It won't be efficient, but it should still be correct.*/
+    if(++cext>=OC_EXTENSION_INFO+OC_NSHAPES){
+      oc_enc_fdct8x8_c(_y,_x);
+      return;
+    }
+  }
+  if(rmask==0xFF)rext=NULL;
+  else for(rext=OC_EXTENSION_INFO;rext->mask!=rmask;){
+    /*If we somehow can't find the shape, then just do an unpadded fDCT.
+      It won't be efficient, but it should still be correct.*/
+    if(++rext>=OC_EXTENSION_INFO+OC_NSHAPES){
+      oc_enc_fdct8x8_c(_y,_x);
+      return;
+    }
+  }
+  /*Add two extra bits of working precision to improve accuracy; any more and
+     we could overflow.*/
+  for(ci=0;ci<64;ci++)w[ci]=_x[ci]<<2;
+  /*These biases correct for some systematic error that remains in the full
+     fDCT->iDCT round trip.
+    We can safely add them before padding, since if these pixel values are
+     overwritten, we didn't care what they were anyway (and the unbiased values
+     will usually yield smaller DCT coefficient magnitudes).*/
+  w[0]+=(w[0]!=0)+1;
+  w[1]++;
+  w[8]--;
+  /*Transform the columns.
+    We can ignore zero columns without a problem.*/
+  in=w;
+  out=_y;
+  if(cext==NULL)for(ci=0;ci<8;ci++)oc_fdct8(out+(ci<<3),in+ci);
+  else for(ci=0;ci<8;ci++)if(rmask&(1<<ci))oc_fdct8_ext(out+(ci<<3),in+ci,cext);
+  /*Transform the rows.
+    We transform even rows that are supposedly zero, because rounding errors
+     may make them slightly non-zero, and this will give a more precise
+     reconstruction with very small quantizers.*/
+  in=_y;
+  out=w;
+  if(rext==NULL)for(ri=0;ri<8;ri++)oc_fdct8(out+(ri<<3),in+ri);
+  else for(ri=0;ri<8;ri++)oc_fdct8_ext(out+(ri<<3),in+ri,rext);
+  /*Round the result back to the external working precision (which is still
+     scaled by four relative to the orthogonal result).
+    TODO: We should just update the external working precision.*/
+  for(ci=0;ci<64;ci++)_y[ci]=w[ci]+2>>2;
+}
+#endif
diff --git a/lib/fragment.c b/lib/fragment.c
new file mode 100644 (file)
index 0000000..15372e9
--- /dev/null
@@ -0,0 +1,87 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: fragment.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include <string.h>
+#include "internal.h"
+
+void oc_frag_copy(const oc_theora_state *_state,unsigned char *_dst,
+ const unsigned char *_src,int _ystride){
+  (*_state->opt_vtable.frag_copy)(_dst,_src,_ystride);
+}
+
+void oc_frag_copy_c(unsigned char *_dst,const unsigned char *_src,int _ystride){
+  int i;
+  for(i=8;i-->0;){
+    memcpy(_dst,_src,8*sizeof(*_dst));
+    _dst+=_ystride;
+    _src+=_ystride;
+  }
+}
+
+void oc_frag_recon_intra(const oc_theora_state *_state,unsigned char *_dst,
+ int _ystride,const ogg_int16_t _residue[64]){
+  _state->opt_vtable.frag_recon_intra(_dst,_ystride,_residue);
+}
+
+void oc_frag_recon_intra_c(unsigned char *_dst,int _ystride,
+ const ogg_int16_t _residue[64]){
+  int i;
+  for(i=0;i<8;i++){
+    int j;
+    for(j=0;j<8;j++)_dst[j]=OC_CLAMP255(_residue[i*8+j]+128);
+    _dst+=_ystride;
+  }
+}
+
+void oc_frag_recon_inter(const oc_theora_state *_state,unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]){
+  _state->opt_vtable.frag_recon_inter(_dst,_src,_ystride,_residue);
+}
+
+void oc_frag_recon_inter_c(unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]){
+  int i;
+  for(i=0;i<8;i++){
+    int j;
+    for(j=0;j<8;j++)_dst[j]=OC_CLAMP255(_residue[i*8+j]+_src[j]);
+    _dst+=_ystride;
+    _src+=_ystride;
+  }
+}
+
+void oc_frag_recon_inter2(const oc_theora_state *_state,unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride,
+ const ogg_int16_t _residue[64]){
+  _state->opt_vtable.frag_recon_inter2(_dst,_src1,_src2,_ystride,_residue);
+}
+
+void oc_frag_recon_inter2_c(unsigned char *_dst,const unsigned char *_src1,
+ const unsigned char *_src2,int _ystride,const ogg_int16_t _residue[64]){
+  int i;
+  for(i=0;i<8;i++){
+    int j;
+    for(j=0;j<8;j++)_dst[j]=OC_CLAMP255(_residue[i*8+j]+(_src1[j]+_src2[j]>>1));
+    _dst+=_ystride;
+    _src1+=_ystride;
+    _src2+=_ystride;
+  }
+}
+
+void oc_restore_fpu(const oc_theora_state *_state){
+  _state->opt_vtable.restore_fpu();
+}
+
+void oc_restore_fpu_c(void){}
diff --git a/lib/huffdec.c b/lib/huffdec.c
new file mode 100644 (file)
index 0000000..8cf27f0
--- /dev/null
@@ -0,0 +1,489 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: huffdec.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+#include "huffdec.h"
+#include "decint.h"
+
+
+/*The ANSI offsetof macro is broken on some platforms (e.g., older DECs).*/
+#define _ogg_offsetof(_type,_field)\
+ ((size_t)((char *)&((_type *)0)->_field-(char *)0))
+
+/*The number of internal tokens associated with each of the spec tokens.*/
+static const unsigned char OC_DCT_TOKEN_MAP_ENTRIES[TH_NDCT_TOKENS]={
+  1,1,1,4,8,1,1,8,1,1,1,1,1,2,2,2,2,4,8,2,2,2,4,2,2,2,2,2,8,2,4,8
+};
+
+/*The map from external spec-defined tokens to internal tokens.
+  This is constructed so that any extra bits read with the original token value
+   can be masked off the least significant bits of its internal token index.
+  In addition, all of the tokens which require additional extra bits are placed
+   at the start of the list, and grouped by type.
+  OC_DCT_REPEAT_RUN3_TOKEN is placed first, as it is an extra-special case, so
+   giving it index 0 may simplify comparisons on some architectures.
+  These requirements require some substantial reordering.*/
+static const unsigned char OC_DCT_TOKEN_MAP[TH_NDCT_TOKENS]={
+  /*OC_DCT_EOB1_TOKEN (0 extra bits)*/
+  15,
+  /*OC_DCT_EOB2_TOKEN (0 extra bits)*/
+  16,
+  /*OC_DCT_EOB3_TOKEN (0 extra bits)*/
+  17,
+  /*OC_DCT_REPEAT_RUN0_TOKEN (2 extra bits)*/
+  88,
+  /*OC_DCT_REPEAT_RUN1_TOKEN (3 extra bits)*/
+  80,
+  /*OC_DCT_REPEAT_RUN2_TOKEN (4 extra bits)*/
+   1,
+  /*OC_DCT_REPEAT_RUN3_TOKEN (12 extra bits)*/
+   0,
+  /*OC_DCT_SHORT_ZRL_TOKEN (3 extra bits)*/
+  48,
+  /*OC_DCT_ZRL_TOKEN (6 extra bits)*/
+  14,
+  /*OC_ONE_TOKEN (0 extra bits)*/
+  56,
+  /*OC_MINUS_ONE_TOKEN (0 extra bits)*/
+  57,
+  /*OC_TWO_TOKEN (0 extra bits)*/
+  58,
+  /*OC_MINUS_TWO_TOKEN (0 extra bits)*/
+  59,
+  /*OC_DCT_VAL_CAT2 (1 extra bit)*/
+  60,
+  62,
+  64,
+  66,
+  /*OC_DCT_VAL_CAT3 (2 extra bits)*/
+  68,
+  /*OC_DCT_VAL_CAT4 (3 extra bits)*/
+  72,
+  /*OC_DCT_VAL_CAT5 (4 extra bits)*/
+   2,
+  /*OC_DCT_VAL_CAT6 (5 extra bits)*/
+   4,
+  /*OC_DCT_VAL_CAT7 (6 extra bits)*/
+   6,
+  /*OC_DCT_VAL_CAT8 (10 extra bits)*/
+   8,
+  /*OC_DCT_RUN_CAT1A (1 extra bit)*/
+  18,
+  20,
+  22,
+  24,
+  26,
+  /*OC_DCT_RUN_CAT1B (3 extra bits)*/
+  32,
+  /*OC_DCT_RUN_CAT1C (4 extra bits)*/
+  12,
+  /*OC_DCT_RUN_CAT2A (2 extra bits)*/
+  28,
+  /*OC_DCT_RUN_CAT2B (3 extra bits)*/
+  40
+};
+
+/*These three functions are really part of the bitpack.c module, but
+   they are only used here.
+  Declaring local static versions so they can be inlined saves considerable
+   function call overhead.*/
+
+static oc_pb_window oc_pack_refill(oc_pack_buf *_b,int _bits){
+  const unsigned char *ptr;
+  const unsigned char *stop;
+  oc_pb_window         window;
+  int                  available;
+  window=_b->window;
+  available=_b->bits;
+  ptr=_b->ptr;
+  stop=_b->stop;
+  /*This version of _refill() doesn't bother setting eof because we won't
+     check for it after we've started decoding DCT tokens.*/
+  if(ptr>=stop)available=OC_LOTS_OF_BITS;
+  while(available<=OC_PB_WINDOW_SIZE-8){
+    available+=8;
+    window|=(oc_pb_window)*ptr++<<OC_PB_WINDOW_SIZE-available;
+    if(ptr>=stop)available=OC_LOTS_OF_BITS;
+  }
+  _b->ptr=ptr;
+  if(_bits>available)window|=*ptr>>(available&7);
+  _b->bits=available;
+  return window;
+}
+
+
+/*Read in bits without advancing the bit pointer.
+  Here we assume 0<=_bits&&_bits<=32.*/
+static long oc_pack_look(oc_pack_buf *_b,int _bits){
+  oc_pb_window window;
+  int          available;
+  long         result;
+  window=_b->window;
+  available=_b->bits;
+  if(_bits==0)return 0;
+  if(_bits>available)_b->window=window=oc_pack_refill(_b,_bits);
+  result=window>>OC_PB_WINDOW_SIZE-_bits;
+  return result;
+}
+
+/*Advance the bit pointer.*/
+static void oc_pack_adv(oc_pack_buf *_b,int _bits){
+  /*We ignore the special cases for _bits==0 and _bits==32 here, since they are
+     never used actually used.
+    OC_HUFF_SLUSH (defined below) would have to be at least 27 to actually read
+     32 bits in a single go, and would require a 32 GB lookup table (assuming
+     8 byte pointers, since 4 byte pointers couldn't fit such a table).*/
+  _b->window<<=_bits;
+  _b->bits-=_bits;
+}
+
+
+/*The log_2 of the size of a lookup table is allowed to grow to relative to
+   the number of unique nodes it contains.
+  E.g., if OC_HUFF_SLUSH is 2, then at most 75% of the space in the tree is
+   wasted (each node will have an amortized cost of at most 20 bytes when using
+   4-byte pointers).
+  Larger numbers can decode tokens with fewer read operations, while smaller
+   numbers may save more space (requiring as little as 8 bytes amortized per
+   node, though there will be more nodes).
+  With a sample file:
+  32233473 read calls are required when no tree collapsing is done (100.0%).
+  19269269 read calls are required when OC_HUFF_SLUSH is 0 (59.8%).
+  11144969 read calls are required when OC_HUFF_SLUSH is 1 (34.6%).
+  10538563 read calls are required when OC_HUFF_SLUSH is 2 (32.7%).
+  10192578 read calls are required when OC_HUFF_SLUSH is 3 (31.6%).
+  Since a value of 1 gets us the vast majority of the speed-up with only a
+   small amount of wasted memory, this is what we use.*/
+#define OC_HUFF_SLUSH (1)
+
+
+/*Determines the size in bytes of a Huffman tree node that represents a
+   subtree of depth _nbits.
+  _nbits: The depth of the subtree.
+          If this is 0, the node is a leaf node.
+          Otherwise 1<<_nbits pointers are allocated for children.
+  Return: The number of bytes required to store the node.*/
+static size_t oc_huff_node_size(int _nbits){
+  size_t size;
+  size=_ogg_offsetof(oc_huff_node,nodes);
+  if(_nbits>0)size+=sizeof(oc_huff_node *)*(1<<_nbits);
+  return size;
+}
+
+static oc_huff_node *oc_huff_node_init(char **_storage,size_t _size,int _nbits){
+  oc_huff_node *ret;
+  ret=(oc_huff_node *)*_storage;
+  ret->nbits=(unsigned char)_nbits;
+  (*_storage)+=_size;
+  return ret;
+}
+
+
+/*Determines the size in bytes of a Huffman tree.
+  _nbits: The depth of the subtree.
+          If this is 0, the node is a leaf node.
+          Otherwise storage for 1<<_nbits pointers are added for children.
+  Return: The number of bytes required to store the tree.*/
+static size_t oc_huff_tree_size(const oc_huff_node *_node){
+  size_t size;
+  size=oc_huff_node_size(_node->nbits);
+  if(_node->nbits){
+    int nchildren;
+    int i;
+    nchildren=1<<_node->nbits;
+    for(i=0;i<nchildren;i+=1<<_node->nbits-_node->nodes[i]->depth){
+      size+=oc_huff_tree_size(_node->nodes[i]);
+    }
+  }
+  return size;
+}
+
+
+/*Unpacks a sub-tree from the given buffer.
+  _opb:      The buffer to unpack from.
+  _binodes:  The nodes to store the sub-tree in.
+  _nbinodes: The number of nodes available for the sub-tree.
+  Return: 0 on success, or a negative value on error.*/
+static int oc_huff_tree_unpack(oc_pack_buf *_opb,
+ oc_huff_node *_binodes,int _nbinodes){
+  oc_huff_node *binode;
+  long          bits;
+  int           nused;
+  if(_nbinodes<1)return TH_EBADHEADER;
+  binode=_binodes;
+  nused=0;
+  bits=oc_pack_read1(_opb);
+  if(oc_pack_bytes_left(_opb)<0)return TH_EBADHEADER;
+  /*Read an internal node:*/
+  if(!bits){
+    int ret;
+    nused++;
+    binode->nbits=1;
+    binode->depth=1;
+    binode->nodes[0]=_binodes+nused;
+    ret=oc_huff_tree_unpack(_opb,_binodes+nused,_nbinodes-nused);
+    if(ret>=0){
+      nused+=ret;
+      binode->nodes[1]=_binodes+nused;
+      ret=oc_huff_tree_unpack(_opb,_binodes+nused,_nbinodes-nused);
+    }
+    if(ret<0)return ret;
+    nused+=ret;
+  }
+  /*Read a leaf node:*/
+  else{
+    int ntokens;
+    int token;
+    int i;
+    bits=oc_pack_read(_opb,OC_NDCT_TOKEN_BITS);
+    if(oc_pack_bytes_left(_opb)<0)return TH_EBADHEADER;
+    /*Find out how many internal tokens we translate this external token into.*/
+    ntokens=OC_DCT_TOKEN_MAP_ENTRIES[bits];
+    if(_nbinodes<2*ntokens-1)return TH_EBADHEADER;
+    /*Fill in a complete binary tree pointing to the internal tokens.*/
+    for(i=1;i<ntokens;i<<=1){
+      int j;
+      binode=_binodes+nused;
+      nused+=i;
+      for(j=0;j<i;j++){
+        binode[j].nbits=1;
+        binode[j].depth=1;
+        binode[j].nodes[0]=_binodes+nused+2*j;
+        binode[j].nodes[1]=_binodes+nused+2*j+1;
+      }
+    }
+    /*And now the leaf nodes with those tokens.*/
+    token=OC_DCT_TOKEN_MAP[bits];
+    for(i=0;i<ntokens;i++){
+      binode=_binodes+nused++;
+      binode->nbits=0;
+      binode->depth=1;
+      binode->token=token+i;
+    }
+  }
+  return nused;
+}
+
+/*Finds the depth of shortest branch of the given sub-tree.
+  The tree must be binary.
+  _binode: The root of the given sub-tree.
+           _binode->nbits must be 0 or 1.
+  Return: The smallest depth of a leaf node in this sub-tree.
+          0 indicates this sub-tree is a leaf node.*/
+static int oc_huff_tree_mindepth(oc_huff_node *_binode){
+  int depth0;
+  int depth1;
+  if(_binode->nbits==0)return 0;
+  depth0=oc_huff_tree_mindepth(_binode->nodes[0]);
+  depth1=oc_huff_tree_mindepth(_binode->nodes[1]);
+  return OC_MINI(depth0,depth1)+1;
+}
+
+/*Finds the number of internal nodes at a given depth, plus the number of
+   leaves at that depth or shallower.
+  The tree must be binary.
+  _binode: The root of the given sub-tree.
+           _binode->nbits must be 0 or 1.
+  Return: The number of entries that would be contained in a jump table of the
+           given depth.*/
+static int oc_huff_tree_occupancy(oc_huff_node *_binode,int _depth){
+  if(_binode->nbits==0||_depth<=0)return 1;
+  else{
+    return oc_huff_tree_occupancy(_binode->nodes[0],_depth-1)+
+     oc_huff_tree_occupancy(_binode->nodes[1],_depth-1);
+  }
+}
+
+/*Makes a copy of the given Huffman tree.
+  _node: The Huffman tree to copy.
+  Return: The copy of the Huffman tree.*/
+static oc_huff_node *oc_huff_tree_copy(const oc_huff_node *_node,
+ char **_storage){
+  oc_huff_node *ret;
+  ret=oc_huff_node_init(_storage,oc_huff_node_size(_node->nbits),_node->nbits);
+  ret->depth=_node->depth;
+  if(_node->nbits){
+    int nchildren;
+    int i;
+    int inext;
+    nchildren=1<<_node->nbits;
+    for(i=0;i<nchildren;){
+      ret->nodes[i]=oc_huff_tree_copy(_node->nodes[i],_storage);
+      inext=i+(1<<_node->nbits-ret->nodes[i]->depth);
+      while(++i<inext)ret->nodes[i]=ret->nodes[i-1];
+    }
+  }
+  else ret->token=_node->token;
+  return ret;
+}
+
+static size_t oc_huff_tree_collapse_size(oc_huff_node *_binode,int _depth){
+  size_t size;
+  int    mindepth;
+  int    depth;
+  int    loccupancy;
+  int    occupancy;
+  if(_binode->nbits!=0&&_depth>0){
+    return oc_huff_tree_collapse_size(_binode->nodes[0],_depth-1)+
+     oc_huff_tree_collapse_size(_binode->nodes[1],_depth-1);
+  }
+  depth=mindepth=oc_huff_tree_mindepth(_binode);
+  occupancy=1<<mindepth;
+  do{
+    loccupancy=occupancy;
+    occupancy=oc_huff_tree_occupancy(_binode,++depth);
+  }
+  while(occupancy>loccupancy&&occupancy>=1<<OC_MAXI(depth-OC_HUFF_SLUSH,0));
+  depth--;
+  size=oc_huff_node_size(depth);
+  if(depth>0){
+    size+=oc_huff_tree_collapse_size(_binode->nodes[0],depth-1);
+    size+=oc_huff_tree_collapse_size(_binode->nodes[1],depth-1);
+  }
+  return size;
+}
+
+static oc_huff_node *oc_huff_tree_collapse(oc_huff_node *_binode,
+ char **_storage);
+
+/*Fills the given nodes table with all the children in the sub-tree at the
+   given depth.
+  The nodes in the sub-tree with a depth less than that stored in the table
+   are freed.
+  The sub-tree must be binary and complete up until the given depth.
+  _nodes:  The nodes table to fill.
+  _binode: The root of the sub-tree to fill it with.
+           _binode->nbits must be 0 or 1.
+  _level:  The current level in the table.
+           0 indicates that the current node should be stored, regardless of
+            whether it is a leaf node or an internal node.
+  _depth:  The depth of the nodes to fill the table with, relative to their
+            parent.*/
+static void oc_huff_node_fill(oc_huff_node **_nodes,
+ oc_huff_node *_binode,int _level,int _depth,char **_storage){
+  if(_level<=0||_binode->nbits==0){
+    int i;
+    _binode->depth=(unsigned char)(_depth-_level);
+    _nodes[0]=oc_huff_tree_collapse(_binode,_storage);
+    for(i=1;i<1<<_level;i++)_nodes[i]=_nodes[0];
+  }
+  else{
+    _level--;
+    oc_huff_node_fill(_nodes,_binode->nodes[0],_level,_depth,_storage);
+    _nodes+=1<<_level;
+    oc_huff_node_fill(_nodes,_binode->nodes[1],_level,_depth,_storage);
+  }
+}
+
+/*Finds the largest complete sub-tree rooted at the current node and collapses
+   it into a single node.
+  This procedure is then applied recursively to all the children of that node.
+  _binode: The root of the sub-tree to collapse.
+           _binode->nbits must be 0 or 1.
+  Return: The new root of the collapsed sub-tree.*/
+static oc_huff_node *oc_huff_tree_collapse(oc_huff_node *_binode,
+ char **_storage){
+  oc_huff_node *root;
+  size_t        size;
+  int           mindepth;
+  int           depth;
+  int           loccupancy;
+  int           occupancy;
+  depth=mindepth=oc_huff_tree_mindepth(_binode);
+  occupancy=1<<mindepth;
+  do{
+    loccupancy=occupancy;
+    occupancy=oc_huff_tree_occupancy(_binode,++depth);
+  }
+  while(occupancy>loccupancy&&occupancy>=1<<OC_MAXI(depth-OC_HUFF_SLUSH,0));
+  depth--;
+  if(depth<=1)return oc_huff_tree_copy(_binode,_storage);
+  size=oc_huff_node_size(depth);
+  root=oc_huff_node_init(_storage,size,depth);
+  root->depth=_binode->depth;
+  oc_huff_node_fill(root->nodes,_binode,depth,depth,_storage);
+  return root;
+}
+
+/*Unpacks a set of Huffman trees, and reduces them to a collapsed
+   representation.
+  _opb:   The buffer to unpack the trees from.
+  _nodes: The table to fill with the Huffman trees.
+  Return: 0 on success, or a negative value on error.*/
+int oc_huff_trees_unpack(oc_pack_buf *_opb,
+ oc_huff_node *_nodes[TH_NHUFFMAN_TABLES]){
+  int i;
+  for(i=0;i<TH_NHUFFMAN_TABLES;i++){
+    oc_huff_node  nodes[511];
+    char         *storage;
+    size_t        size;
+    int           ret;
+    /*Unpack the full tree into a temporary buffer.*/
+    ret=oc_huff_tree_unpack(_opb,nodes,sizeof(nodes)/sizeof(*nodes));
+    if(ret<0)return ret;
+    /*Figure out how big the collapsed tree will be.*/
+    size=oc_huff_tree_collapse_size(nodes,0);
+    storage=(char *)_ogg_calloc(1,size);
+    if(storage==NULL)return TH_EFAULT;
+    /*And collapse it.*/
+    _nodes[i]=oc_huff_tree_collapse(nodes,&storage);
+  }
+  return 0;
+}
+
+/*Makes a copy of the given set of Huffman trees.
+  _dst: The array to store the copy in.
+  _src: The array of trees to copy.*/
+int oc_huff_trees_copy(oc_huff_node *_dst[TH_NHUFFMAN_TABLES],
+ const oc_huff_node *const _src[TH_NHUFFMAN_TABLES]){
+  int i;
+  for(i=0;i<TH_NHUFFMAN_TABLES;i++){
+    size_t  size;
+    char   *storage;
+    size=oc_huff_tree_size(_src[i]);
+    storage=(char *)_ogg_calloc(1,size);
+    if(storage==NULL){
+      while(i-->0)_ogg_free(_dst[i]);
+      return TH_EFAULT;
+    }
+    _dst[i]=oc_huff_tree_copy(_src[i],&storage);
+  }
+  return 0;
+}
+
+/*Frees the memory used by a set of Huffman trees.
+  _nodes: The array of trees to free.*/
+void oc_huff_trees_clear(oc_huff_node *_nodes[TH_NHUFFMAN_TABLES]){
+  int i;
+  for(i=0;i<TH_NHUFFMAN_TABLES;i++)_ogg_free(_nodes[i]);
+}
+
+/*Unpacks a single token using the given Huffman tree.
+  _opb:  The buffer to unpack the token from.
+  _node: The tree to unpack the token with.
+  Return: The token value.*/
+int oc_huff_token_decode(oc_pack_buf *_opb,const oc_huff_node *_node){
+  long bits;
+  while(_node->nbits!=0){
+    bits=oc_pack_look(_opb,_node->nbits);
+    _node=_node->nodes[bits];
+    oc_pack_adv(_opb,_node->depth);
+  }
+  return _node->token;
+}
diff --git a/lib/huffdec.h b/lib/huffdec.h
new file mode 100644 (file)
index 0000000..d7ffa0e
--- /dev/null
@@ -0,0 +1,92 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: huffdec.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#if !defined(_huffdec_H)
+# define _huffdec_H (1)
+# include "huffman.h"
+# include "bitpack.h"
+
+
+
+typedef struct oc_huff_node oc_huff_node;
+
+/*A node in the Huffman tree.
+  Instead of storing every branching in the tree, subtrees can be collapsed
+   into one node, with a table of size 1<<nbits pointing directly to its
+   descedents nbits levels down.
+  This allows more than one bit to be read at a time, and avoids following all
+   the intermediate branches with next to no increased code complexity once
+   the collapsed tree has been built.
+  We do _not_ require that a subtree be complete to be collapsed, but instead
+   store duplicate pointers in the table, and record the actual depth of the
+   node below its parent.
+  This tells us the number of bits to advance the stream after reaching it.
+
+  This turns out to be equivalent to the method described in \cite{Hash95},
+   without the requirement that codewords be sorted by length.
+  If the codewords were sorted by length (so-called ``canonical-codes''), they
+   could be decoded much faster via either Lindell and Moffat's approach or
+   Hashemian's Condensed Huffman Code approach, the latter of which has an
+   extremely small memory footprint.
+  We can't use Choueka et al.'s finite state machine approach, which is
+   extremely fast, because we can't allow multiple symbols to be output at a
+   time; the codebook can and does change between symbols.
+  It also has very large memory requirements, which impairs cache coherency.
+
+  @ARTICLE{Hash95,
+    author="Reza Hashemian",
+    title="Memory Efficient and High-Speed Search {Huffman} Coding",
+    journal="{IEEE} Transactions on Communications",
+    volume=43,
+    number=10,
+    pages="2576--2581",
+    month=Oct,
+    year=1995
+  }*/
+struct oc_huff_node{
+  /*The number of bits of the code needed to descend through this node.
+    0 indicates a leaf node.
+    Otherwise there are 1<<nbits nodes in the nodes table, which can be
+     indexed by reading nbits bits from the stream.*/
+  unsigned char  nbits;
+  /*The value of a token stored in a leaf node.
+    The value in non-leaf nodes is undefined.*/
+  unsigned char  token;
+  /*The depth of the current node, relative to its parent in the collapsed
+     tree.
+    This can be less than its parent's nbits value, in which case there are
+     1<<nbits-depth copies of this node in the table, and the bitstream should
+     only be advanced depth bits after reaching this node.*/
+  unsigned char  depth;
+  /*The table of child nodes.
+    The ACTUAL size of this array is 1<<nbits, despite what the declaration
+     below claims.
+    The exception is that for leaf nodes the size is 0.*/
+  oc_huff_node  *nodes[2];
+};
+
+
+
+int oc_huff_trees_unpack(oc_pack_buf *_opb,
+ oc_huff_node *_nodes[TH_NHUFFMAN_TABLES]);
+int oc_huff_trees_copy(oc_huff_node *_dst[TH_NHUFFMAN_TABLES],
+ const oc_huff_node *const _src[TH_NHUFFMAN_TABLES]);
+void oc_huff_trees_clear(oc_huff_node *_nodes[TH_NHUFFMAN_TABLES]);
+int oc_huff_token_decode(oc_pack_buf *_opb,const oc_huff_node *_node);
+
+
+#endif
diff --git a/lib/huffenc.c b/lib/huffenc.c
new file mode 100644 (file)
index 0000000..bf624e0
--- /dev/null
@@ -0,0 +1,910 @@
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+#include "huffenc.h"
+
+
+
+/*The default Huffman codes used for VP3.1.*/
+const th_huff_code TH_VP31_HUFF_CODES[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS]={
+  {
+    {0x002D, 6},{0x0026, 7},{0x0166, 9},{0x004E, 8},
+    {0x02CE,10},{0x059E,11},{0x027D,11},{0x0008, 5},
+    {0x04F9,12},{0x000F, 4},{0x000E, 4},{0x001B, 5},
+    {0x0006, 4},{0x0008, 4},{0x0005, 4},{0x001A, 5},
+    {0x0015, 5},{0x0007, 4},{0x000C, 4},{0x0001, 3},
+    {0x0000, 3},{0x0009, 4},{0x0017, 5},{0x0029, 6},
+    {0x0028, 6},{0x00B2, 8},{0x04F8,12},{0x059F,11},
+    {0x009E, 9},{0x013F,10},{0x0012, 6},{0x0058, 7}
+  },
+  {
+    {0x0010, 5},{0x0047, 7},{0x01FF, 9},{0x008C, 8},
+    {0x03FC,10},{0x046A,11},{0x0469,11},{0x0022, 6},
+    {0x11A1,13},{0x000E, 4},{0x000D, 4},{0x0004, 4},
+    {0x0005, 4},{0x0009, 4},{0x0006, 4},{0x001E, 5},
+    {0x0016, 5},{0x0007, 4},{0x000C, 4},{0x0001, 3},
+    {0x0000, 3},{0x000A, 4},{0x0017, 5},{0x007D, 7},
+    {0x007E, 7},{0x011B, 9},{0x08D1,12},{0x03FD,10},
+    {0x046B,11},{0x11A0,13},{0x007C, 7},{0x00FE, 8}
+  },
+  {
+    {0x0016, 5},{0x0020, 6},{0x0086, 8},{0x0087, 8},
+    {0x0367,10},{0x06CC,11},{0x06CB,11},{0x006E, 7},
+    {0x366D,14},{0x000F, 4},{0x000E, 4},{0x0004, 4},
+    {0x0005, 4},{0x000A, 4},{0x0006, 4},{0x001A, 5},
+    {0x0011, 5},{0x0007, 4},{0x000C, 4},{0x0001, 3},
+    {0x0000, 3},{0x0009, 4},{0x0017, 5},{0x006F, 7},
+    {0x006D, 7},{0x0364,10},{0x0D9A,12},{0x06CA,11},
+    {0x1B37,13},{0x366C,14},{0x0042, 7},{0x00D8, 8}
+  },
+  {
+    {0x0000, 4},{0x002D, 6},{0x00F7, 8},{0x0058, 7},
+    {0x0167, 9},{0x02CB,10},{0x02CA,10},{0x000E, 6},
+    {0x1661,13},{0x0003, 3},{0x0002, 3},{0x0008, 4},
+    {0x0009, 4},{0x000D, 4},{0x0002, 4},{0x001F, 5},
+    {0x0017, 5},{0x0001, 4},{0x000C, 4},{0x000E, 4},
+    {0x000A, 4},{0x0006, 5},{0x0078, 7},{0x000F, 6},
+    {0x007A, 7},{0x0164, 9},{0x0599,11},{0x02CD,10},
+    {0x0B31,12},{0x1660,13},{0x0079, 7},{0x00F6, 8}
+  },
+  {
+    {0x0003, 4},{0x003C, 6},{0x000F, 7},{0x007A, 7},
+    {0x001D, 8},{0x0020, 9},{0x0072,10},{0x0006, 6},
+    {0x0399,13},{0x0004, 3},{0x0005, 3},{0x0005, 4},
+    {0x0006, 4},{0x000E, 4},{0x0004, 4},{0x0000, 4},
+    {0x0019, 5},{0x0002, 4},{0x000D, 4},{0x0007, 4},
+    {0x001F, 5},{0x0030, 6},{0x0011, 8},{0x0031, 6},
+    {0x0005, 6},{0x0021, 9},{0x00E7,11},{0x0038, 9},
+    {0x01CD,12},{0x0398,13},{0x007B, 7},{0x0009, 7}
+  },
+  {
+    {0x0009, 4},{0x0002, 5},{0x0074, 7},{0x0007, 6},
+    {0x00EC, 8},{0x00D1, 9},{0x01A6,10},{0x0006, 6},
+    {0x0D21,13},{0x0005, 3},{0x0006, 3},{0x0008, 4},
+    {0x0007, 4},{0x000F, 4},{0x0004, 4},{0x0000, 4},
+    {0x001C, 5},{0x0002, 4},{0x0005, 4},{0x0003, 4},
+    {0x000C, 5},{0x0035, 7},{0x01A7,10},{0x001B, 6},
+    {0x0077, 7},{0x01A5,10},{0x0349,11},{0x00D0, 9},
+    {0x0691,12},{0x0D20,13},{0x0075, 7},{0x00ED, 8}
+  },
+  {
+    {0x000A, 4},{0x000C, 5},{0x0012, 6},{0x001B, 6},
+    {0x00B7, 8},{0x016C, 9},{0x0099, 9},{0x005A, 7},
+    {0x16D8,13},{0x0007, 3},{0x0006, 3},{0x0009, 4},
+    {0x0008, 4},{0x0000, 3},{0x0005, 4},{0x0017, 5},
+    {0x000E, 5},{0x0002, 4},{0x0003, 4},{0x000F, 5},
+    {0x001A, 6},{0x004D, 8},{0x2DB3,14},{0x002C, 6},
+    {0x0011, 6},{0x02DA,10},{0x05B7,11},{0x0098, 9},
+    {0x0B6D,12},{0x2DB2,14},{0x0010, 6},{0x0027, 7}
+  },
+  {
+    {0x000D, 4},{0x000F, 5},{0x001D, 6},{0x0008, 5},
+    {0x0051, 7},{0x0056, 8},{0x00AF, 9},{0x002A, 7},
+    {0x148A,13},{0x0007, 3},{0x0000, 2},{0x0008, 4},
+    {0x0009, 4},{0x000C, 4},{0x0006, 4},{0x0017, 5},
+    {0x000B, 5},{0x0016, 5},{0x0015, 5},{0x0009, 5},
+    {0x0050, 7},{0x00AE, 9},{0x2917,14},{0x001C, 6},
+    {0x0014, 6},{0x0290,10},{0x0523,11},{0x0149, 9},
+    {0x0A44,12},{0x2916,14},{0x0053, 7},{0x00A5, 8}
+  },
+  {
+    {0x0001, 4},{0x001D, 6},{0x00F5, 8},{0x00F4, 8},
+    {0x024D,10},{0x0499,11},{0x0498,11},{0x0001, 5},
+    {0x0021, 6},{0x0006, 3},{0x0005, 3},{0x0006, 4},
+    {0x0005, 4},{0x0002, 4},{0x0007, 5},{0x0025, 6},
+    {0x007B, 7},{0x001C, 6},{0x0020, 6},{0x000D, 6},
+    {0x0048, 7},{0x0092, 8},{0x0127, 9},{0x000E, 4},
+    {0x0004, 4},{0x0011, 5},{0x000C, 6},{0x003C, 6},
+    {0x000F, 5},{0x0000, 5},{0x001F, 5},{0x0013, 5}
+  },
+  {
+    {0x0005, 4},{0x003C, 6},{0x0040, 7},{0x000D, 7},
+    {0x0031, 9},{0x0061,10},{0x0060,10},{0x0002, 5},
+    {0x00F5, 8},{0x0006, 3},{0x0005, 3},{0x0007, 4},
+    {0x0006, 4},{0x0002, 4},{0x0009, 5},{0x0025, 6},
+    {0x0007, 6},{0x0021, 6},{0x0024, 6},{0x0010, 6},
+    {0x0041, 7},{0x00F4, 8},{0x0019, 8},{0x000E, 4},
+    {0x0003, 4},{0x0011, 5},{0x0011, 6},{0x003F, 6},
+    {0x003E, 6},{0x007B, 7},{0x0000, 4},{0x0013, 5}
+  },
+  {
+    {0x000A, 4},{0x0007, 5},{0x0001, 6},{0x0009, 6},
+    {0x0131, 9},{0x0261,10},{0x0260,10},{0x0015, 6},
+    {0x0001, 7},{0x0007, 3},{0x0006, 3},{0x0008, 4},
+    {0x0007, 4},{0x0006, 4},{0x0012, 5},{0x002F, 6},
+    {0x0014, 6},{0x0027, 6},{0x002D, 6},{0x0016, 6},
+    {0x004D, 7},{0x0099, 8},{0x0000, 7},{0x0004, 4},
+    {0x0001, 4},{0x0005, 5},{0x0017, 6},{0x002E, 6},
+    {0x002C, 6},{0x0008, 6},{0x0006, 5},{0x0001, 5}
+  },
+  {
+    {0x0000, 3},{0x000E, 5},{0x0017, 6},{0x002A, 6},
+    {0x0010, 7},{0x00F9,10},{0x00F8,10},{0x001E, 7},
+    {0x003F, 8},{0x0007, 3},{0x0006, 3},{0x0009, 4},
+    {0x0008, 4},{0x0006, 4},{0x000F, 5},{0x0005, 5},
+    {0x0016, 6},{0x0029, 6},{0x002B, 6},{0x0015, 6},
+    {0x0050, 7},{0x0011, 7},{0x007D, 9},{0x0004, 4},
+    {0x0017, 5},{0x0006, 5},{0x0014, 6},{0x002C, 6},
+    {0x002D, 6},{0x000E, 6},{0x0009, 6},{0x0051, 7}
+  },
+  {
+    {0x0002, 3},{0x0018, 5},{0x002F, 6},{0x000D, 5},
+    {0x0053, 7},{0x0295,10},{0x0294,10},{0x00A4, 8},
+    {0x007C, 8},{0x0000, 2},{0x0007, 3},{0x0009, 4},
+    {0x0008, 4},{0x001B, 5},{0x000C, 5},{0x0028, 6},
+    {0x006A, 7},{0x001E, 6},{0x001D, 6},{0x0069, 7},
+    {0x00D7, 8},{0x007D, 8},{0x014B, 9},{0x0019, 5},
+    {0x0016, 5},{0x002E, 6},{0x001C, 6},{0x002B, 6},
+    {0x002A, 6},{0x0068, 7},{0x003F, 7},{0x00D6, 8}
+  },
+  {
+    {0x0002, 3},{0x001B, 5},{0x000C, 5},{0x0018, 5},
+    {0x0029, 6},{0x007F, 8},{0x02F0,10},{0x0198, 9},
+    {0x0179, 9},{0x0000, 2},{0x0007, 3},{0x0009, 4},
+    {0x0008, 4},{0x001A, 5},{0x000D, 5},{0x002A, 6},
+    {0x0064, 7},{0x001E, 6},{0x0067, 7},{0x005F, 7},
+    {0x00CD, 8},{0x007E, 8},{0x02F1,10},{0x0016, 5},
+    {0x000E, 5},{0x002E, 6},{0x0065, 7},{0x002B, 6},
+    {0x0028, 6},{0x003E, 7},{0x00BD, 8},{0x0199, 9}
+  },
+  {
+    {0x0002, 3},{0x0007, 4},{0x0016, 5},{0x0006, 4},
+    {0x0036, 6},{0x005C, 7},{0x015D, 9},{0x015C, 9},
+    {0x02BF,10},{0x0000, 2},{0x0007, 3},{0x0009, 4},
+    {0x0008, 4},{0x0018, 5},{0x0034, 6},{0x002A, 6},
+    {0x005E, 7},{0x006A, 7},{0x0064, 7},{0x005D, 7},
+    {0x00CB, 8},{0x00AD, 8},{0x02BE,10},{0x0014, 5},
+    {0x0033, 6},{0x006E, 7},{0x005F, 7},{0x006F, 7},
+    {0x006B, 7},{0x00CA, 8},{0x00AC, 8},{0x015E, 9}
+  },
+  {
+    {0x000F, 4},{0x001D, 5},{0x0018, 5},{0x000B, 4},
+    {0x0019, 5},{0x0029, 6},{0x00D6, 8},{0x0551,11},
+    {0x0AA1,12},{0x0001, 2},{0x0000, 2},{0x0009, 4},
+    {0x0008, 4},{0x001B, 5},{0x0038, 6},{0x0028, 6},
+    {0x0057, 7},{0x006A, 7},{0x0068, 7},{0x0056, 7},
+    {0x00E5, 8},{0x0155, 9},{0x0AA0,12},{0x0073, 7},
+    {0x0069, 7},{0x00D7, 8},{0x00AB, 8},{0x00E4, 8},
+    {0x00A9, 8},{0x0151, 9},{0x0150, 9},{0x02A9,10}
+  },
+  {
+    {0x0008, 5},{0x0025, 7},{0x017A, 9},{0x02F7,10},
+    {0x0BDB,12},{0x17B4,13},{0x2F6B,14},{0x001D, 5},
+    {0x2F6A,14},{0x0008, 4},{0x0007, 4},{0x0001, 4},
+    {0x0002, 4},{0x000A, 4},{0x0006, 4},{0x0000, 4},
+    {0x001C, 5},{0x0009, 4},{0x000D, 4},{0x000F, 4},
+    {0x000C, 4},{0x0003, 4},{0x000A, 5},{0x0016, 5},
+    {0x0013, 6},{0x005D, 7},{0x0024, 7},{0x00BC, 8},
+    {0x005C, 7},{0x05EC,11},{0x000B, 5},{0x005F, 7}
+  },
+  {
+    {0x000F, 5},{0x0010, 6},{0x004B, 8},{0x00C6, 8},
+    {0x031D,10},{0x0C71,12},{0x0C70,12},{0x0001, 4},
+    {0x0C73,12},{0x0008, 4},{0x0009, 4},{0x0002, 4},
+    {0x0003, 4},{0x000B, 4},{0x0006, 4},{0x0000, 4},
+    {0x001C, 5},{0x0005, 4},{0x000D, 4},{0x000F, 4},
+    {0x000A, 4},{0x0019, 5},{0x0013, 6},{0x001D, 5},
+    {0x0030, 6},{0x0062, 7},{0x0024, 7},{0x004A, 8},
+    {0x018F, 9},{0x0C72,12},{0x000E, 5},{0x0011, 6}
+  },
+  {
+    {0x001B, 5},{0x0003, 6},{0x008D, 8},{0x0040, 7},
+    {0x0239,10},{0x0471,11},{0x08E0,12},{0x0003, 4},
+    {0x11C3,13},{0x000A, 4},{0x0009, 4},{0x0004, 4},
+    {0x0005, 4},{0x000E, 4},{0x0007, 4},{0x0001, 4},
+    {0x001E, 5},{0x0006, 4},{0x000C, 4},{0x000B, 4},
+    {0x0002, 4},{0x0000, 5},{0x0041, 7},{0x001F, 5},
+    {0x0022, 6},{0x0002, 6},{0x008F, 8},{0x008C, 8},
+    {0x011D, 9},{0x11C2,13},{0x001A, 5},{0x0021, 6}
+  },
+  {
+    {0x001F, 5},{0x0003, 6},{0x0003, 7},{0x0043, 7},
+    {0x000B, 9},{0x0015,10},{0x0051,12},{0x0003, 4},
+    {0x0050,12},{0x000D, 4},{0x000C, 4},{0x0004, 4},
+    {0x0006, 4},{0x000E, 4},{0x000A, 4},{0x0001, 4},
+    {0x001E, 5},{0x0005, 4},{0x0009, 4},{0x0007, 4},
+    {0x0011, 5},{0x0002, 6},{0x0004, 8},{0x0002, 4},
+    {0x002D, 6},{0x0020, 6},{0x0042, 7},{0x0001, 7},
+    {0x0000, 7},{0x0029,11},{0x0017, 5},{0x002C, 6}
+  },
+  {
+    {0x0003, 4},{0x001F, 6},{0x003A, 7},{0x005D, 7},
+    {0x0173, 9},{0x02E4,10},{0x172D,13},{0x0004, 4},
+    {0x172C,13},{0x000F, 4},{0x000E, 4},{0x0009, 4},
+    {0x0008, 4},{0x000C, 4},{0x000A, 4},{0x0001, 4},
+    {0x0016, 5},{0x0002, 4},{0x0005, 4},{0x001A, 5},
+    {0x002F, 6},{0x0038, 7},{0x05CA,11},{0x0006, 4},
+    {0x0037, 6},{0x001E, 6},{0x003B, 7},{0x0039, 7},
+    {0x00B8, 8},{0x0B97,12},{0x0000, 4},{0x0036, 6}
+  },
+  {
+    {0x0006, 4},{0x0037, 6},{0x005D, 7},{0x000C, 6},
+    {0x00B9, 8},{0x02E3,10},{0x05C4,11},{0x0004, 4},
+    {0x1715,13},{0x0000, 3},{0x000F, 4},{0x0008, 4},
+    {0x0007, 4},{0x000C, 4},{0x0009, 4},{0x001D, 5},
+    {0x0016, 5},{0x001C, 5},{0x001A, 5},{0x000B, 5},
+    {0x005E, 7},{0x0170, 9},{0x1714,13},{0x000A, 4},
+    {0x000A, 5},{0x0036, 6},{0x005F, 7},{0x001B, 7},
+    {0x001A, 7},{0x0B8B,12},{0x0002, 4},{0x0007, 5}
+  },
+  {
+    {0x000C, 4},{0x000B, 5},{0x0079, 7},{0x0022, 6},
+    {0x00F0, 8},{0x0119, 9},{0x0230,10},{0x001D, 5},
+    {0x08C4,12},{0x0001, 3},{0x0000, 3},{0x000A, 4},
+    {0x0009, 4},{0x000B, 4},{0x0007, 4},{0x001C, 5},
+    {0x003D, 6},{0x000D, 5},{0x0008, 5},{0x0015, 6},
+    {0x008D, 8},{0x118B,13},{0x118A,13},{0x000D, 4},
+    {0x0010, 5},{0x0009, 5},{0x0014, 6},{0x0047, 7},
+    {0x00F1, 8},{0x0463,11},{0x001F, 5},{0x000C, 5}
+  },
+  {
+    {0x0000, 3},{0x001A, 5},{0x0033, 6},{0x000C, 5},
+    {0x0046, 7},{0x01E3, 9},{0x03C5,10},{0x0017, 5},
+    {0x1E21,13},{0x0002, 3},{0x0001, 3},{0x0009, 4},
+    {0x000A, 4},{0x0007, 4},{0x001B, 5},{0x003D, 6},
+    {0x001B, 6},{0x0022, 6},{0x0079, 7},{0x00F0, 8},
+    {0x1E20,13},{0x1E23,13},{0x1E22,13},{0x000E, 4},
+    {0x0016, 5},{0x0018, 5},{0x0032, 6},{0x001A, 6},
+    {0x0047, 7},{0x0789,11},{0x001F, 5},{0x0010, 5}
+  },
+  {
+    {0x001D, 5},{0x0061, 7},{0x004E, 8},{0x009E, 9},
+    {0x027C,11},{0x09F5,13},{0x09F4,13},{0x0003, 4},
+    {0x0060, 7},{0x0000, 3},{0x000F, 4},{0x000B, 4},
+    {0x000A, 4},{0x0009, 4},{0x0005, 4},{0x000D, 5},
+    {0x0031, 6},{0x0008, 5},{0x0038, 6},{0x0012, 6},
+    {0x0026, 7},{0x013F,10},{0x04FB,12},{0x000D, 4},
+    {0x0002, 4},{0x000C, 5},{0x0039, 6},{0x001C, 6},
+    {0x000F, 5},{0x001D, 6},{0x0008, 4},{0x0019, 5}
+  },
+  {
+    {0x0007, 4},{0x0019, 6},{0x00AB, 8},{0x00AA, 8},
+    {0x0119,10},{0x0461,12},{0x0460,12},{0x001B, 5},
+    {0x0047, 8},{0x0001, 3},{0x0000, 3},{0x000C, 4},
+    {0x000B, 4},{0x0009, 4},{0x0005, 4},{0x000D, 5},
+    {0x0035, 6},{0x003D, 6},{0x003C, 6},{0x0018, 6},
+    {0x0022, 7},{0x008D, 9},{0x0231,11},{0x000E, 4},
+    {0x001F, 5},{0x0009, 5},{0x002B, 6},{0x0010, 6},
+    {0x0034, 6},{0x0054, 7},{0x0008, 4},{0x0014, 5}
+  },
+  {
+    {0x000C, 4},{0x0005, 5},{0x0008, 6},{0x005B, 7},
+    {0x004D, 9},{0x0131,11},{0x0261,12},{0x001A, 5},
+    {0x0012, 7},{0x0000, 3},{0x000F, 4},{0x000A, 4},
+    {0x0009, 4},{0x0006, 4},{0x001B, 5},{0x0006, 5},
+    {0x001C, 6},{0x002C, 6},{0x0015, 6},{0x005A, 7},
+    {0x0027, 8},{0x0099,10},{0x0260,12},{0x000E, 4},
+    {0x0004, 4},{0x000F, 5},{0x0007, 5},{0x001D, 6},
+    {0x000B, 5},{0x0014, 6},{0x0008, 4},{0x0017, 5}
+  },
+  {
+    {0x000F, 4},{0x0013, 5},{0x0075, 7},{0x0024, 6},
+    {0x0095, 8},{0x0251,10},{0x04A0,11},{0x0010, 5},
+    {0x00C8, 8},{0x0002, 3},{0x0001, 3},{0x0001, 4},
+    {0x0000, 4},{0x001A, 5},{0x0011, 5},{0x002C, 6},
+    {0x0065, 7},{0x0074, 7},{0x004B, 7},{0x00C9, 8},
+    {0x0129, 9},{0x0943,12},{0x0942,12},{0x0003, 3},
+    {0x000A, 4},{0x001C, 5},{0x0018, 5},{0x0033, 6},
+    {0x0017, 5},{0x002D, 6},{0x001B, 5},{0x003B, 6}
+  },
+  {
+    {0x0003, 3},{0x001A, 5},{0x002D, 6},{0x0038, 6},
+    {0x0028, 7},{0x0395,10},{0x0E51,12},{0x0037, 6},
+    {0x00E4, 8},{0x0001, 3},{0x0000, 3},{0x001F, 5},
+    {0x001E, 5},{0x0017, 5},{0x003A, 6},{0x0073, 7},
+    {0x002A, 7},{0x002B, 7},{0x0029, 7},{0x01CB, 9},
+    {0x0729,11},{0x1CA1,13},{0x1CA0,13},{0x0004, 3},
+    {0x000A, 4},{0x0004, 4},{0x0018, 5},{0x0036, 6},
+    {0x000B, 5},{0x002C, 6},{0x0019, 5},{0x003B, 6}
+  },
+  {
+    {0x0004, 3},{0x0004, 4},{0x003F, 6},{0x0017, 5},
+    {0x0075, 7},{0x01F5, 9},{0x07D1,11},{0x0017, 6},
+    {0x01F6, 9},{0x0001, 3},{0x0000, 3},{0x001B, 5},
+    {0x001A, 5},{0x000A, 5},{0x0032, 6},{0x0074, 7},
+    {0x00F8, 8},{0x00F9, 8},{0x01F7, 9},{0x03E9,10},
+    {0x0FA0,12},{0x1F43,13},{0x1F42,13},{0x0003, 3},
+    {0x000A, 4},{0x001E, 5},{0x001C, 5},{0x003B, 6},
+    {0x0018, 5},{0x0016, 6},{0x0016, 5},{0x0033, 6}
+  },
+  {
+    {0x0004, 3},{0x0007, 4},{0x0018, 5},{0x001E, 5},
+    {0x0036, 6},{0x0031, 7},{0x0177, 9},{0x0077, 7},
+    {0x0176, 9},{0x0001, 3},{0x0000, 3},{0x001A, 5},
+    {0x0019, 5},{0x003A, 6},{0x0019, 6},{0x005C, 7},
+    {0x00BA, 8},{0x0061, 8},{0x00C1, 9},{0x0180,10},
+    {0x0302,11},{0x0607,12},{0x0606,12},{0x0002, 3},
+    {0x000A, 4},{0x001F, 5},{0x001C, 5},{0x0037, 6},
+    {0x0016, 5},{0x0076, 7},{0x000D, 5},{0x002F, 6}
+  },
+  {
+    {0x0000, 3},{0x000A, 4},{0x001A, 5},{0x000C, 4},
+    {0x001D, 5},{0x0039, 6},{0x0078, 7},{0x005E, 7},
+    {0x0393,11},{0x0002, 3},{0x0001, 3},{0x0016, 5},
+    {0x000F, 5},{0x002E, 6},{0x005F, 7},{0x0073, 8},
+    {0x00E5, 9},{0x01C8,10},{0x0E4A,13},{0x1C97,14},
+    {0x1C96,14},{0x0E49,13},{0x0E48,13},{0x0004, 3},
+    {0x0006, 4},{0x001F, 5},{0x001B, 5},{0x001D, 6},
+    {0x0038, 6},{0x0038, 7},{0x003D, 6},{0x0079, 7}
+  },
+  {
+    {0x000B, 5},{0x002B, 7},{0x0054, 8},{0x01B7, 9},
+    {0x06D9,11},{0x0DB1,12},{0x0DB0,12},{0x0002, 4},
+    {0x00AB, 9},{0x0009, 4},{0x000A, 4},{0x0007, 4},
+    {0x0008, 4},{0x000F, 4},{0x000C, 4},{0x0003, 4},
+    {0x001D, 5},{0x0004, 4},{0x000B, 4},{0x0006, 4},
+    {0x001A, 5},{0x0003, 6},{0x00AA, 9},{0x0001, 4},
+    {0x0000, 5},{0x0014, 6},{0x006C, 7},{0x00DA, 8},
+    {0x0002, 6},{0x036D,10},{0x001C, 5},{0x0037, 6}
+  },
+  {
+    {0x001D, 5},{0x0004, 6},{0x00B6, 8},{0x006A, 8},
+    {0x05B9,11},{0x16E1,13},{0x16E0,13},{0x0007, 4},
+    {0x016F, 9},{0x000C, 4},{0x000D, 4},{0x0009, 4},
+    {0x0008, 4},{0x000F, 4},{0x000A, 4},{0x0003, 4},
+    {0x0017, 5},{0x0002, 4},{0x0004, 4},{0x001C, 5},
+    {0x002C, 6},{0x006B, 8},{0x0B71,12},{0x0005, 4},
+    {0x0003, 5},{0x001B, 6},{0x005A, 7},{0x0034, 7},
+    {0x0005, 6},{0x02DD,10},{0x0000, 4},{0x000C, 5}
+  },
+  {
+    {0x0003, 4},{0x007F, 7},{0x00A1, 8},{0x00A0, 8},
+    {0x020C,10},{0x0834,12},{0x106B,13},{0x0007, 4},
+    {0x0082, 8},{0x000E, 4},{0x000D, 4},{0x000B, 4},
+    {0x000C, 4},{0x0000, 3},{0x0009, 4},{0x0002, 4},
+    {0x0011, 5},{0x001E, 5},{0x0015, 5},{0x003E, 6},
+    {0x0040, 7},{0x041B,11},{0x106A,13},{0x0006, 4},
+    {0x000A, 5},{0x0029, 6},{0x007E, 7},{0x0051, 7},
+    {0x0021, 6},{0x0107, 9},{0x0004, 4},{0x000B, 5}
+  },
+  {
+    {0x0007, 4},{0x001B, 6},{0x00F6, 8},{0x00E9, 8},
+    {0x03A1,10},{0x0740,11},{0x0E82,12},{0x001F, 5},
+    {0x01EF, 9},{0x0001, 3},{0x0002, 3},{0x000B, 4},
+    {0x000C, 4},{0x000D, 4},{0x0008, 4},{0x001C, 5},
+    {0x0003, 5},{0x0012, 5},{0x0002, 5},{0x0075, 7},
+    {0x01D1, 9},{0x1D07,13},{0x1D06,13},{0x000A, 4},
+    {0x0013, 5},{0x003B, 6},{0x001A, 6},{0x007A, 7},
+    {0x003C, 6},{0x01EE, 9},{0x0000, 4},{0x000C, 5}
+  },
+  {
+    {0x000D, 4},{0x003D, 6},{0x0042, 7},{0x0037, 7},
+    {0x00D9, 9},{0x0362,11},{0x06C6,12},{0x001F, 5},
+    {0x0086, 8},{0x0001, 3},{0x0002, 3},{0x000C, 4},
+    {0x000B, 4},{0x000A, 4},{0x0001, 4},{0x000F, 5},
+    {0x0025, 6},{0x003C, 6},{0x001A, 6},{0x0087, 8},
+    {0x01B0,10},{0x0D8F,13},{0x0D8E,13},{0x000E, 4},
+    {0x0013, 5},{0x000C, 5},{0x0024, 6},{0x0020, 6},
+    {0x0011, 5},{0x006D, 8},{0x0000, 4},{0x000E, 5}
+  },
+  {
+    {0x0000, 3},{0x0012, 5},{0x0076, 7},{0x0077, 7},
+    {0x014D, 9},{0x0533,11},{0x14C9,13},{0x0013, 5},
+    {0x00A5, 8},{0x0002, 3},{0x0003, 3},{0x000B, 4},
+    {0x000C, 4},{0x0008, 4},{0x001A, 5},{0x002B, 6},
+    {0x0075, 7},{0x0074, 7},{0x00A7, 8},{0x0298,10},
+    {0x14C8,13},{0x14CB,13},{0x14CA,13},{0x000F, 4},
+    {0x001C, 5},{0x0007, 5},{0x002A, 6},{0x0028, 6},
+    {0x001B, 5},{0x00A4, 8},{0x0002, 4},{0x0006, 5}
+  },
+  {
+    {0x0002, 3},{0x001A, 5},{0x002B, 6},{0x003A, 6},
+    {0x00ED, 8},{0x0283,10},{0x0A0A,12},{0x0004, 5},
+    {0x00A1, 8},{0x0004, 3},{0x0003, 3},{0x000B, 4},
+    {0x000C, 4},{0x001F, 5},{0x0006, 5},{0x0077, 7},
+    {0x00A3, 8},{0x00A2, 8},{0x0140, 9},{0x1417,13},
+    {0x1416,13},{0x0A09,12},{0x0A08,12},{0x0000, 3},
+    {0x001E, 5},{0x0007, 5},{0x002A, 6},{0x0029, 6},
+    {0x001C, 5},{0x00EC, 8},{0x001B, 5},{0x0005, 5}
+  },
+  {
+    {0x0002, 3},{0x0002, 4},{0x0018, 5},{0x001D, 5},
+    {0x0035, 6},{0x00E4, 8},{0x01CF,11},{0x001D, 7},
+    {0x0072, 9},{0x0004, 3},{0x0005, 3},{0x0006, 4},
+    {0x0007, 4},{0x0006, 5},{0x0073, 7},{0x0038, 8},
+    {0x01CE,11},{0x039B,12},{0x0398,12},{0x0733,13},
+    {0x0732,13},{0x0735,13},{0x0734,13},{0x0000, 3},
+    {0x001F, 5},{0x001B, 5},{0x0034, 6},{0x000F, 6},
+    {0x001E, 5},{0x00E5, 8},{0x0019, 5},{0x0038, 6}
+  },
+  {
+    {0x0016, 5},{0x0050, 7},{0x0172, 9},{0x02E7,10},
+    {0x1732,13},{0x2E67,14},{0x2E66,14},{0x0006, 4},
+    {0x0051, 7},{0x0001, 3},{0x0000, 3},{0x000D, 4},
+    {0x000C, 4},{0x0009, 4},{0x001C, 5},{0x0009, 5},
+    {0x001C, 6},{0x001D, 6},{0x005D, 7},{0x00B8, 8},
+    {0x05CD,11},{0x1731,13},{0x1730,13},{0x000F, 4},
+    {0x0005, 4},{0x000F, 5},{0x0008, 5},{0x0029, 6},
+    {0x001D, 5},{0x002F, 6},{0x0008, 4},{0x0015, 5}
+  },
+  {
+    {0x0009, 4},{0x0021, 6},{0x0040, 7},{0x00AD, 8},
+    {0x02B0,10},{0x1589,13},{0x1588,13},{0x001C, 5},
+    {0x005F, 7},{0x0000, 3},{0x000F, 4},{0x000D, 4},
+    {0x000C, 4},{0x0006, 4},{0x0011, 5},{0x002A, 6},
+    {0x0057, 7},{0x005E, 7},{0x0041, 7},{0x0159, 9},
+    {0x0563,11},{0x158B,13},{0x158A,13},{0x0001, 3},
+    {0x0005, 4},{0x0014, 5},{0x003B, 6},{0x002E, 6},
+    {0x0004, 4},{0x003A, 6},{0x0007, 4},{0x0016, 5}
+  },
+  {
+    {0x000E, 4},{0x0007, 5},{0x0046, 7},{0x0045, 7},
+    {0x0064, 9},{0x032A,12},{0x0657,13},{0x0018, 5},
+    {0x000D, 6},{0x0000, 3},{0x000F, 4},{0x000A, 4},
+    {0x000B, 4},{0x001A, 5},{0x0036, 6},{0x0047, 7},
+    {0x0044, 7},{0x0018, 7},{0x0033, 8},{0x00CB,10},
+    {0x0656,13},{0x0329,12},{0x0328,12},{0x0002, 3},
+    {0x0006, 4},{0x0019, 5},{0x000E, 5},{0x0037, 6},
+    {0x0009, 4},{0x000F, 5},{0x0002, 4},{0x0010, 5}
+  },
+  {
+    {0x0003, 3},{0x0018, 5},{0x0023, 6},{0x0077, 7},
+    {0x0194, 9},{0x1956,13},{0x32AF,14},{0x003A, 6},
+    {0x0076, 7},{0x0002, 3},{0x0001, 3},{0x001F, 5},
+    {0x001E, 5},{0x0014, 5},{0x0022, 6},{0x0064, 7},
+    {0x0197, 9},{0x0196, 9},{0x032B,10},{0x0654,11},
+    {0x32AE,14},{0x1955,13},{0x1954,13},{0x0000, 3},
+    {0x0009, 4},{0x001C, 5},{0x0015, 5},{0x0010, 5},
+    {0x000D, 4},{0x0017, 5},{0x0016, 5},{0x0033, 6}
+  },
+  {
+    {0x0005, 3},{0x0006, 4},{0x003E, 6},{0x0010, 5},
+    {0x0048, 7},{0x093F,12},{0x24FA,14},{0x0032, 6},
+    {0x0067, 7},{0x0002, 3},{0x0001, 3},{0x001B, 5},
+    {0x001E, 5},{0x0034, 6},{0x0066, 7},{0x0092, 8},
+    {0x0126, 9},{0x024E,10},{0x049E,11},{0x49F7,15},
+    {0x49F6,15},{0x24F9,14},{0x24F8,14},{0x0000, 3},
+    {0x0007, 4},{0x0018, 5},{0x0011, 5},{0x003F, 6},
+    {0x000E, 4},{0x0013, 5},{0x0035, 6},{0x0025, 6}
+  },
+  {
+    {0x0005, 3},{0x0008, 4},{0x0012, 5},{0x001C, 5},
+    {0x001C, 6},{0x00EA, 9},{0x1D75,14},{0x001E, 6},
+    {0x0066, 7},{0x0001, 3},{0x0002, 3},{0x001B, 5},
+    {0x001A, 5},{0x001F, 6},{0x003B, 7},{0x0074, 8},
+    {0x01D6,10},{0x03AF,11},{0x1D74,14},{0x1D77,14},
+    {0x1D76,14},{0x0EB9,13},{0x0EB8,13},{0x000F, 4},
+    {0x0006, 4},{0x0013, 5},{0x003B, 6},{0x003A, 6},
+    {0x0000, 3},{0x0018, 5},{0x0032, 6},{0x0067, 7}
+  },
+  {
+    {0x0004, 3},{0x000A, 4},{0x001B, 5},{0x000C, 4},
+    {0x000D, 5},{0x00E6, 8},{0x0684,11},{0x0072, 7},
+    {0x00E7, 8},{0x0002, 3},{0x0001, 3},{0x0017, 5},
+    {0x0016, 5},{0x0018, 6},{0x00D1, 8},{0x01A0, 9},
+    {0x0686,11},{0x0D0F,12},{0x0D0A,12},{0x1A17,13},
+    {0x1A16,13},{0x1A1D,13},{0x1A1C,13},{0x000F, 4},
+    {0x001D, 5},{0x000E, 5},{0x0035, 6},{0x0038, 6},
+    {0x0000, 3},{0x000F, 5},{0x0019, 6},{0x0069, 7}
+  },
+  {
+    {0x0003, 3},{0x000C, 4},{0x001B, 5},{0x0000, 3},
+    {0x0003, 4},{0x002E, 6},{0x0051, 9},{0x00BC, 8},
+    {0x0053, 9},{0x0004, 3},{0x0002, 3},{0x0016, 5},
+    {0x0015, 5},{0x0015, 7},{0x0050, 9},{0x00A4,10},
+    {0x0294,12},{0x052B,13},{0x052A,13},{0x052D,13},
+    {0x052C,13},{0x052F,13},{0x052E,13},{0x000E, 4},
+    {0x001A, 5},{0x0004, 5},{0x0028, 6},{0x0029, 6},
+    {0x000F, 4},{0x000B, 6},{0x005F, 7},{0x00BD, 8}
+  },
+  {
+    {0x0003, 4},{0x0009, 6},{0x00D0, 8},{0x01A3, 9},
+    {0x0344,10},{0x0D14,12},{0x1A2B,13},{0x0004, 4},
+    {0x0015, 7},{0x0000, 3},{0x000F, 4},{0x000B, 4},
+    {0x000C, 4},{0x000E, 4},{0x0009, 4},{0x001B, 5},
+    {0x000A, 5},{0x0014, 5},{0x000D, 5},{0x002A, 6},
+    {0x0014, 7},{0x068B,11},{0x1A2A,13},{0x0008, 4},
+    {0x000B, 5},{0x002B, 6},{0x000B, 6},{0x0069, 7},
+    {0x0035, 6},{0x0008, 6},{0x0007, 4},{0x000C, 5}
+  },
+  {
+    {0x000A, 4},{0x003C, 6},{0x0032, 7},{0x0030, 7},
+    {0x00C5, 9},{0x0621,12},{0x0620,12},{0x001F, 5},
+    {0x0033, 7},{0x0001, 3},{0x0000, 3},{0x000E, 4},
+    {0x000D, 4},{0x000C, 4},{0x0004, 4},{0x000D, 5},
+    {0x0026, 6},{0x0027, 6},{0x0014, 6},{0x0063, 8},
+    {0x0189,10},{0x0623,12},{0x0622,12},{0x000B, 4},
+    {0x0012, 5},{0x003D, 6},{0x0022, 6},{0x0015, 6},
+    {0x000B, 5},{0x0023, 6},{0x0007, 4},{0x0010, 5}
+  },
+  {
+    {0x000F, 4},{0x000C, 5},{0x0043, 7},{0x0010, 6},
+    {0x0044, 8},{0x0114,10},{0x0455,12},{0x0018, 5},
+    {0x0023, 7},{0x0001, 3},{0x0000, 3},{0x000E, 4},
+    {0x000D, 4},{0x0009, 4},{0x0019, 5},{0x0009, 5},
+    {0x0017, 6},{0x0016, 6},{0x0042, 7},{0x008B, 9},
+    {0x0454,12},{0x0457,12},{0x0456,12},{0x000B, 4},
+    {0x0015, 5},{0x000A, 5},{0x0029, 6},{0x0020, 6},
+    {0x000D, 5},{0x0028, 6},{0x0007, 4},{0x0011, 5}
+  },
+  {
+    {0x0001, 3},{0x001A, 5},{0x0029, 6},{0x002A, 6},
+    {0x00A0, 8},{0x0285,10},{0x1425,13},{0x0002, 5},
+    {0x0000, 7},{0x0002, 3},{0x0003, 3},{0x000C, 4},
+    {0x000B, 4},{0x0008, 4},{0x0012, 5},{0x0001, 6},
+    {0x0051, 7},{0x0001, 7},{0x0143, 9},{0x0508,11},
+    {0x1424,13},{0x1427,13},{0x1426,13},{0x000F, 4},
+    {0x001C, 5},{0x0003, 5},{0x0037, 6},{0x002B, 6},
+    {0x0013, 5},{0x0036, 6},{0x001D, 5},{0x0001, 5}
+  },
+  {
+    {0x0004, 3},{0x001F, 5},{0x003D, 6},{0x0006, 5},
+    {0x0016, 7},{0x0053, 9},{0x014A,11},{0x0034, 6},
+    {0x002A, 8},{0x0002, 3},{0x0003, 3},{0x000B, 4},
+    {0x000C, 4},{0x001C, 5},{0x0037, 6},{0x0017, 7},
+    {0x002B, 8},{0x0028, 8},{0x00A4,10},{0x052D,13},
+    {0x052C,13},{0x052F,13},{0x052E,13},{0x0000, 3},
+    {0x001D, 5},{0x0007, 5},{0x0004, 5},{0x0035, 6},
+    {0x0014, 5},{0x0036, 6},{0x0015, 5},{0x003C, 6}
+  },
+  {
+    {0x0004, 3},{0x000A, 4},{0x0007, 5},{0x001D, 5},
+    {0x0009, 6},{0x01F3, 9},{0x07C7,11},{0x0008, 6},
+    {0x01F0, 9},{0x0003, 3},{0x0002, 3},{0x000D, 4},
+    {0x000C, 4},{0x0017, 5},{0x007D, 7},{0x01F2, 9},
+    {0x07C6,11},{0x07C5,11},{0x1F12,13},{0x3E27,14},
+    {0x3E26,14},{0x1F11,13},{0x1F10,13},{0x0000, 3},
+    {0x001E, 5},{0x0006, 5},{0x0039, 6},{0x0038, 6},
+    {0x003F, 6},{0x002C, 6},{0x0005, 5},{0x002D, 6}
+  },
+  {
+    {0x0002, 3},{0x0007, 4},{0x0018, 5},{0x0003, 4},
+    {0x0005, 5},{0x0035, 7},{0x004F, 9},{0x0012, 7},
+    {0x04E5,13},{0x0005, 3},{0x0004, 3},{0x000D, 4},
+    {0x000E, 4},{0x0033, 6},{0x0026, 8},{0x009D,10},
+    {0x04E4,13},{0x04E7,13},{0x04E6,13},{0x04E1,13},
+    {0x04E0,13},{0x04E3,13},{0x04E2,13},{0x0000, 3},
+    {0x001F, 5},{0x000C, 5},{0x003D, 6},{0x003C, 6},
+    {0x0032, 6},{0x0034, 7},{0x001B, 6},{0x0008, 6}
+  },
+  {
+    {0x0000, 3},{0x0004, 4},{0x001C, 5},{0x000F, 4},
+    {0x0002, 4},{0x0007, 5},{0x0075, 7},{0x00E8, 8},
+    {0x1D2A,13},{0x0005, 3},{0x0004, 3},{0x000D, 4},
+    {0x000C, 4},{0x0077, 7},{0x0E96,12},{0x3A57,14},
+    {0x3A56,14},{0x3A5D,14},{0x3A5C,14},{0x3A5F,14},
+    {0x3A5E,14},{0x1D29,13},{0x1D28,13},{0x0003, 3},
+    {0x0006, 5},{0x000A, 5},{0x002C, 7},{0x0017, 6},
+    {0x0076, 7},{0x01D3, 9},{0x03A4,10},{0x002D, 7}
+  },
+  {
+    {0x000A, 4},{0x0024, 6},{0x00BF, 8},{0x0085, 8},
+    {0x0211,10},{0x0842,12},{0x1087,13},{0x0018, 5},
+    {0x0020, 6},{0x0001, 3},{0x0002, 3},{0x000E, 4},
+    {0x000D, 4},{0x0007, 4},{0x0013, 5},{0x0025, 6},
+    {0x005E, 7},{0x0043, 7},{0x00BE, 8},{0x0109, 9},
+    {0x1086,13},{0x0841,12},{0x0840,12},{0x000F, 4},
+    {0x0001, 4},{0x0011, 5},{0x0000, 5},{0x002E, 6},
+    {0x0019, 5},{0x0001, 5},{0x0006, 4},{0x0016, 5}
+  },
+  {
+    {0x0002, 3},{0x000F, 5},{0x006F, 7},{0x0061, 7},
+    {0x0374,10},{0x1BA8,13},{0x3753,14},{0x0012, 5},
+    {0x0036, 6},{0x0000, 3},{0x0001, 3},{0x000A, 4},
+    {0x000B, 4},{0x001A, 5},{0x0031, 6},{0x0060, 7},
+    {0x00DC, 8},{0x01BB, 9},{0x06EB,11},{0x1BAB,13},
+    {0x3752,14},{0x3755,14},{0x3754,14},{0x000E, 4},
+    {0x0006, 4},{0x0013, 5},{0x000E, 5},{0x003E, 6},
+    {0x0008, 4},{0x001E, 5},{0x0019, 5},{0x003F, 6}
+  },
+  {
+    {0x0003, 3},{0x001C, 5},{0x0025, 6},{0x0024, 6},
+    {0x01DA, 9},{0x1DBD,13},{0x3B7C,14},{0x003C, 6},
+    {0x003D, 6},{0x0000, 3},{0x0001, 3},{0x000B, 4},
+    {0x000A, 4},{0x000B, 5},{0x0077, 7},{0x00EC, 8},
+    {0x03B6,10},{0x076E,11},{0x1DBF,13},{0x76FB,15},
+    {0x76FA,15},{0x3B79,14},{0x3B78,14},{0x000D, 4},
+    {0x001F, 5},{0x0013, 5},{0x000A, 5},{0x0008, 5},
+    {0x000C, 4},{0x0008, 4},{0x0009, 5},{0x003A, 6}
+  },
+  {
+    {0x0005, 3},{0x0003, 4},{0x0004, 5},{0x0010, 5},
+    {0x008F, 8},{0x0475,11},{0x11D1,13},{0x0079, 7},
+    {0x0027, 6},{0x0002, 3},{0x0003, 3},{0x0001, 4},
+    {0x0000, 4},{0x0026, 6},{0x0046, 7},{0x011C, 9},
+    {0x0477,11},{0x08ED,12},{0x11D0,13},{0x11D3,13},
+    {0x11D2,13},{0x11D9,13},{0x11D8,13},{0x000D, 4},
+    {0x001F, 5},{0x0012, 5},{0x0005, 5},{0x003D, 6},
+    {0x000C, 4},{0x000E, 4},{0x0022, 6},{0x0078, 7}
+  },
+  {
+    {0x0005, 3},{0x000C, 4},{0x001B, 5},{0x0000, 4},
+    {0x0006, 6},{0x03E2,10},{0x3E3D,14},{0x000F, 7},
+    {0x0034, 6},{0x0003, 3},{0x0002, 3},{0x001E, 5},
+    {0x001D, 5},{0x007D, 7},{0x01F0, 9},{0x07C6,11},
+    {0x3E3C,14},{0x3E3F,14},{0x3E3E,14},{0x3E39,14},
+    {0x3E38,14},{0x3E3B,14},{0x3E3A,14},{0x0008, 4},
+    {0x001C, 5},{0x0002, 5},{0x003F, 6},{0x0035, 6},
+    {0x0009, 4},{0x0001, 3},{0x000E, 7},{0x00F9, 8}
+  },
+  {
+    {0x0004, 3},{0x000B, 4},{0x0001, 4},{0x000A, 4},
+    {0x001E, 6},{0x00E0, 9},{0x0E1E,13},{0x0071, 8},
+    {0x0039, 7},{0x0007, 3},{0x0006, 3},{0x000D, 5},
+    {0x000C, 5},{0x0020, 7},{0x01C2,10},{0x1C3F,14},
+    {0x1C3E,14},{0x0E19,13},{0x0E18,13},{0x0E1B,13},
+    {0x0E1A,13},{0x0E1D,13},{0x0E1C,13},{0x0000, 4},
+    {0x0009, 5},{0x001D, 6},{0x001F, 6},{0x0011, 6},
+    {0x0005, 4},{0x0001, 3},{0x0043, 8},{0x0042, 8}
+  },
+  {
+    {0x0004, 3},{0x000D, 4},{0x0007, 4},{0x0002, 3},
+    {0x0014, 5},{0x016C, 9},{0x16D1,13},{0x02DF,10},
+    {0x016E, 9},{0x0000, 2},{0x0007, 3},{0x002C, 6},
+    {0x002B, 6},{0x02DE,10},{0x16D0,13},{0x16D3,13},
+    {0x16D2,13},{0x2DB5,14},{0x2DB4,14},{0x2DB7,14},
+    {0x2DB6,14},{0x16D9,13},{0x16D8,13},{0x000C, 5},
+    {0x002A, 6},{0x005A, 7},{0x001B, 6},{0x001A, 6},
+    {0x0017, 5},{0x000C, 4},{0x05B7,11},{0x05B5,11}
+  },
+  {
+    {0x0002, 2},{0x000F, 4},{0x001C, 5},{0x000C, 4},
+    {0x003B, 6},{0x01AC, 9},{0x1AD8,13},{0x35B3,14},
+    {0x35B2,14},{0x0001, 2},{0x0000, 2},{0x0069, 7},
+    {0x0068, 7},{0x35BD,14},{0x35BC,14},{0x35BF,14},
+    {0x35BE,14},{0x35B9,14},{0x35B8,14},{0x35BB,14},
+    {0x35BA,14},{0x35B5,14},{0x35B4,14},{0x01A9, 9},
+    {0x01A8, 9},{0x035A,10},{0x00D7, 8},{0x00D5, 8},
+    {0x003A, 6},{0x001B, 5},{0x35B7,14},{0x35B6,14}
+  },
+  {
+    {0x0000, 3},{0x0010, 5},{0x0072, 7},{0x0071, 7},
+    {0x0154, 9},{0x0AAB,12},{0x0AA8,12},{0x0014, 5},
+    {0x0070, 7},{0x0002, 3},{0x0003, 3},{0x000C, 4},
+    {0x000B, 4},{0x0003, 4},{0x0011, 5},{0x0073, 7},
+    {0x0054, 7},{0x00AB, 8},{0x02AB,10},{0x1553,13},
+    {0x1552,13},{0x1555,13},{0x1554,13},{0x000D, 4},
+    {0x001E, 5},{0x0012, 5},{0x003E, 6},{0x002B, 6},
+    {0x0002, 4},{0x003F, 6},{0x001D, 5},{0x0013, 5}
+  },
+  {
+    {0x0003, 3},{0x001F, 5},{0x0029, 6},{0x003D, 6},
+    {0x000C, 7},{0x0069,10},{0x0345,13},{0x0002, 5},
+    {0x0028, 6},{0x0002, 3},{0x0001, 3},{0x000E, 4},
+    {0x000C, 4},{0x0015, 5},{0x0007, 6},{0x001B, 8},
+    {0x006B,10},{0x006A,10},{0x0344,13},{0x0347,13},
+    {0x0346,13},{0x01A1,12},{0x01A0,12},{0x000B, 4},
+    {0x001A, 5},{0x0012, 5},{0x0000, 5},{0x003C, 6},
+    {0x0008, 4},{0x001B, 5},{0x0013, 5},{0x0001, 5}
+  },
+  {
+    {0x0004, 3},{0x0004, 4},{0x003F, 6},{0x0014, 5},
+    {0x0056, 7},{0x015C, 9},{0x15D5,13},{0x003C, 6},
+    {0x002A, 6},{0x0000, 3},{0x0001, 3},{0x000E, 4},
+    {0x000D, 4},{0x000C, 5},{0x00AF, 8},{0x02BB,10},
+    {0x15D4,13},{0x15D7,13},{0x15D6,13},{0x15D1,13},
+    {0x15D0,13},{0x15D3,13},{0x15D2,13},{0x000B, 4},
+    {0x0019, 5},{0x000D, 5},{0x003E, 6},{0x0031, 6},
+    {0x0007, 4},{0x0005, 4},{0x003D, 6},{0x0030, 6}
+  },
+  {
+    {0x0005, 3},{0x0008, 4},{0x001A, 5},{0x0000, 4},
+    {0x0036, 6},{0x0011, 8},{0x0106,12},{0x000A, 7},
+    {0x006E, 7},{0x0002, 3},{0x0003, 3},{0x0003, 4},
+    {0x0002, 4},{0x006F, 7},{0x0021, 9},{0x020F,13},
+    {0x020E,13},{0x0101,12},{0x0100,12},{0x0103,12},
+    {0x0102,12},{0x0105,12},{0x0104,12},{0x000C, 4},
+    {0x001E, 5},{0x0003, 5},{0x003E, 6},{0x003F, 6},
+    {0x0009, 4},{0x000E, 4},{0x000B, 7},{0x0009, 7}
+  },
+  {
+    {0x0002, 3},{0x000E, 4},{0x001E, 5},{0x000C, 4},
+    {0x001F, 5},{0x006E, 7},{0x00AD,10},{0x00AF,10},
+    {0x0014, 7},{0x0004, 3},{0x0003, 3},{0x001A, 5},
+    {0x0017, 5},{0x002A, 8},{0x0576,13},{0x0AEF,14},
+    {0x0AEE,14},{0x0571,13},{0x0570,13},{0x0573,13},
+    {0x0572,13},{0x0575,13},{0x0574,13},{0x0003, 4},
+    {0x0016, 5},{0x0004, 5},{0x0036, 6},{0x000B, 6},
+    {0x000A, 4},{0x0000, 3},{0x006F, 7},{0x00AC,10}
+  },
+  {
+    {0x0004, 3},{0x0005, 4},{0x0003, 3},{0x0001, 3},
+    {0x0004, 4},{0x002F, 6},{0x0526,11},{0x1495,13},
+    {0x00A6, 8},{0x0007, 3},{0x0006, 3},{0x002D, 6},
+    {0x002C, 6},{0x1494,13},{0x1497,13},{0x1496,13},
+    {0x1491,13},{0x1490,13},{0x1493,13},{0x1492,13},
+    {0x293D,14},{0x293C,14},{0x293F,14},{0x0000, 3},
+    {0x0028, 6},{0x00A5, 8},{0x0148, 9},{0x00A7, 8},
+    {0x002E, 6},{0x0015, 5},{0x0A4E,12},{0x293E,14}
+  },
+  {
+    {0x0004, 3},{0x0005, 4},{0x0003, 3},{0x0001, 3},
+    {0x0004, 4},{0x002F, 6},{0x0526,11},{0x1495,13},
+    {0x00A6, 8},{0x0007, 3},{0x0006, 3},{0x002D, 6},
+    {0x002C, 6},{0x1494,13},{0x1497,13},{0x1496,13},
+    {0x1491,13},{0x1490,13},{0x1493,13},{0x1492,13},
+    {0x293D,14},{0x293C,14},{0x293F,14},{0x0000, 3},
+    {0x0028, 6},{0x00A5, 8},{0x0148, 9},{0x00A7, 8},
+    {0x002E, 6},{0x0015, 5},{0x0A4E,12},{0x293E,14}
+  },
+  {
+    {0x0004, 3},{0x0005, 4},{0x0003, 3},{0x0001, 3},
+    {0x0004, 4},{0x002F, 6},{0x0526,11},{0x1495,13},
+    {0x00A6, 8},{0x0007, 3},{0x0006, 3},{0x002D, 6},
+    {0x002C, 6},{0x1494,13},{0x1497,13},{0x1496,13},
+    {0x1491,13},{0x1490,13},{0x1493,13},{0x1492,13},
+    {0x293D,14},{0x293C,14},{0x293F,14},{0x0000, 3},
+    {0x0028, 6},{0x00A5, 8},{0x0148, 9},{0x00A7, 8},
+    {0x002E, 6},{0x0015, 5},{0x0A4E,12},{0x293E,14}
+  },
+  {
+    {0x0003, 3},{0x0011, 5},{0x0020, 6},{0x0074, 7},
+    {0x010D, 9},{0x0863,12},{0x0860,12},{0x000A, 5},
+    {0x0075, 7},{0x0001, 3},{0x0000, 3},{0x000B, 4},
+    {0x000A, 4},{0x0018, 5},{0x0038, 6},{0x0042, 7},
+    {0x010F, 9},{0x010E, 9},{0x0219,10},{0x10C3,13},
+    {0x10C2,13},{0x10C5,13},{0x10C4,13},{0x000F, 4},
+    {0x0004, 4},{0x0019, 5},{0x000B, 5},{0x0039, 6},
+    {0x0009, 4},{0x001B, 5},{0x001A, 5},{0x003B, 6}
+  },
+  {
+    {0x0005, 3},{0x0001, 4},{0x003E, 6},{0x0001, 5},
+    {0x00E2, 8},{0x1C6F,13},{0x38D9,14},{0x0039, 6},
+    {0x001F, 6},{0x0002, 3},{0x0001, 3},{0x0009, 4},
+    {0x0008, 4},{0x0000, 5},{0x0070, 7},{0x01C7, 9},
+    {0x038C,10},{0x071A,11},{0x38D8,14},{0x38DB,14},
+    {0x38DA,14},{0x38DD,14},{0x38DC,14},{0x000D, 4},
+    {0x001D, 5},{0x000E, 5},{0x003F, 6},{0x003C, 6},
+    {0x000C, 4},{0x0006, 4},{0x003D, 6},{0x001E, 6}
+  },
+  {
+    {0x0006, 3},{0x000B, 4},{0x0011, 5},{0x001E, 5},
+    {0x0074, 7},{0x03AA,10},{0x1D5C,13},{0x0001, 6},
+    {0x0021, 6},{0x0001, 3},{0x0002, 3},{0x0007, 4},
+    {0x0006, 4},{0x003E, 6},{0x00EB, 8},{0x01D4, 9},
+    {0x0EAF,12},{0x3ABB,14},{0x3ABA,14},{0x1D59,13},
+    {0x1D58,13},{0x1D5B,13},{0x1D5A,13},{0x000A, 4},
+    {0x001C, 5},{0x0001, 5},{0x003F, 6},{0x003B, 6},
+    {0x0001, 4},{0x0009, 4},{0x0020, 6},{0x0000, 6}
+  },
+  {
+    {0x0004, 3},{0x000A, 4},{0x0017, 5},{0x0004, 4},
+    {0x0016, 6},{0x016A, 9},{0x16B1,13},{0x0017, 7},
+    {0x005B, 7},{0x0006, 3},{0x0007, 3},{0x0001, 4},
+    {0x0000, 4},{0x000A, 6},{0x02D7,10},{0x0B5A,12},
+    {0x16B0,13},{0x16B3,13},{0x16B2,13},{0x2D6D,14},
+    {0x2D6C,14},{0x2D6F,14},{0x2D6E,14},{0x0006, 4},
+    {0x000A, 5},{0x0004, 5},{0x002C, 6},{0x0017, 6},
+    {0x0003, 4},{0x0007, 4},{0x0016, 7},{0x00B4, 8}
+  },
+  {
+    {0x0005, 3},{0x000D, 4},{0x0005, 4},{0x0009, 4},
+    {0x0033, 6},{0x0193, 9},{0x192C,13},{0x0061, 8},
+    {0x0031, 7},{0x0000, 2},{0x0007, 3},{0x0010, 5},
+    {0x0011, 5},{0x00C8, 8},{0x192F,13},{0x325B,14},
+    {0x325A,14},{0x1929,13},{0x1928,13},{0x192B,13},
+    {0x192A,13},{0x325D,14},{0x325C,14},{0x0018, 5},
+    {0x001A, 6},{0x001B, 6},{0x0065, 7},{0x0019, 6},
+    {0x0004, 4},{0x0007, 4},{0x0060, 8},{0x0324,10}
+  },
+  {
+    {0x0006, 3},{0x0000, 3},{0x0002, 4},{0x000F, 4},
+    {0x0039, 6},{0x01D9, 9},{0x1D82,13},{0x0761,11},
+    {0x03BE,10},{0x0001, 2},{0x0002, 2},{0x000F, 6},
+    {0x000E, 6},{0x0762,11},{0x3B07,14},{0x3B06,14},
+    {0x3B1D,14},{0x3B1C,14},{0x3B1F,14},{0x3B1E,14},
+    {0x3B19,14},{0x3B18,14},{0x3B1B,14},{0x0038, 6},
+    {0x01DE, 9},{0x00ED, 8},{0x03BF,10},{0x00EE, 8},
+    {0x003A, 6},{0x0006, 5},{0x0EC0,12},{0x3B1A,14}
+  },
+  {
+    {0x0000, 2},{0x0002, 3},{0x000F, 5},{0x0006, 4},
+    {0x001C, 6},{0x01D0,10},{0x0E8C,13},{0x1D1B,14},
+    {0x1D1A,14},{0x0003, 2},{0x0002, 2},{0x00EA, 9},
+    {0x00E9, 9},{0x0E89,13},{0x0E88,13},{0x0E8B,13},
+    {0x0E8A,13},{0x1D65,14},{0x1D64,14},{0x1D67,14},
+    {0x1D66,14},{0x1D61,14},{0x1D60,14},{0x03AD,11},
+    {0x1D63,14},{0x1D62,14},{0x1D1D,14},{0x1D1C,14},
+    {0x003B, 7},{0x01D7,10},{0x1D1F,14},{0x1D1E,14}
+  },
+  {
+    {0x0002, 2},{0x000F, 4},{0x001C, 5},{0x000C, 4},
+    {0x003B, 6},{0x01AC, 9},{0x1AD8,13},{0x35B3,14},
+    {0x35B2,14},{0x0001, 2},{0x0000, 2},{0x0069, 7},
+    {0x0068, 7},{0x35BD,14},{0x35BC,14},{0x35BF,14},
+    {0x35BE,14},{0x35B9,14},{0x35B8,14},{0x35BB,14},
+    {0x35BA,14},{0x35B5,14},{0x35B4,14},{0x01A9, 9},
+    {0x01A8, 9},{0x035A,10},{0x00D7, 8},{0x00D5, 8},
+    {0x003A, 6},{0x001B, 5},{0x35B7,14},{0x35B6,14}
+  }
+};
+
+
+
+/*A description of a Huffman code value used when encoding the tree.*/
+typedef struct{
+  /*The bit pattern, left-shifted so that the MSB of all patterns is
+     aligned.*/
+  ogg_uint32_t pattern;
+  /*The amount the bit pattern was shifted.*/
+  int          shift;
+  /*The token this bit pattern represents.*/
+  int          token;
+}oc_huff_entry;
+
+
+
+/*Compares two oc_huff_entry structures by their bit patterns.
+  _c1: The first entry to compare.
+  _c2: The second entry to compare.
+  Return: <0 if _c1<_c2, >0 if _c1>_c2.*/
+static int huff_entry_cmp(const void *_c1,const void *_c2){
+  ogg_uint32_t b1;
+  ogg_uint32_t b2;
+  b1=((const oc_huff_entry *)_c1)->pattern;
+  b2=((const oc_huff_entry *)_c2)->pattern;
+  return b1<b2?-1:b1>b2?1:0;
+}
+
+/*Encodes a description of the given Huffman tables.
+  Although the codes are stored in the encoder as flat arrays, in the bit
+   stream and in the decoder they are structured as a tree.
+  This function recovers the tree structure from the flat array and then
+   writes it out.
+  Note that the codes MUST form a Huffman code, and not merely a prefix-free
+   code, since the binary tree is assumed to be full.
+  _opb:   The buffer to store the tree in.
+  _codes: The Huffman tables to pack.
+  Return: 0 on success, or a negative value if one of the given Huffman tables
+   does not form a full, prefix-free code.*/
+int oc_huff_codes_pack(oggpack_buffer *_opb,
+ const th_huff_code _codes[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS]){
+  int i;
+  for(i=0;i<TH_NHUFFMAN_TABLES;i++){
+    oc_huff_entry entries[TH_NDCT_TOKENS];
+    int           bpos;
+    int           maxlen;
+    int           mask;
+    int           j;
+    /*First, find the maximum code length so we can align all the bit
+       patterns.*/
+    maxlen=_codes[i][0].nbits;
+    for(j=1;j<TH_NDCT_TOKENS;j++){
+      maxlen=OC_MAXI(_codes[i][j].nbits,maxlen);
+    }
+    mask=(1<<(maxlen>>1)<<(maxlen+1>>1))-1;
+    /*Copy over the codes into our temporary workspace.
+      The bit patterns are aligned, and the original entry each code is from
+       is stored as well.*/
+    for(j=0;j<TH_NDCT_TOKENS;j++){
+      entries[j].shift=maxlen-_codes[i][j].nbits;
+      entries[j].pattern=_codes[i][j].pattern<<entries[j].shift&mask;
+      entries[j].token=j;
+    }
+    /*Sort the codes into ascending order.
+      This is the order the leaves of the tree will be traversed.*/
+    qsort(entries,TH_NDCT_TOKENS,sizeof(entries[0]),huff_entry_cmp);
+    /*For each leaf of the tree:*/
+    bpos=maxlen;
+    for(j=0;j<TH_NDCT_TOKENS;j++){
+      int bit;
+      /*If this code has any bits at all.*/
+      if(entries[j].shift<maxlen){
+        /*Descend into the tree, writing a bit for each branch.*/
+        for(;bpos>entries[j].shift;bpos--)oggpackB_write(_opb,0,1);
+        /*Mark this as a leaf node, and write its value.*/
+        oggpackB_write(_opb,1,1);
+        oggpackB_write(_opb,entries[j].token,5);
+        /*For each 1 branch we've descended, back up the tree until we reach a
+           0 branch.*/
+        bit=1<<bpos;
+        for(;entries[j].pattern&bit;bpos++)bit<<=1;
+        /*Validate the code.*/
+        if(j+1<TH_NDCT_TOKENS){
+          mask=~(bit-1)<<1;
+          /*The next entry should have a 1 bit where we had a 0, and should
+             match our code above that bit.
+            This verifies both fullness and prefix-freeness simultaneously.*/
+          if(!(entries[j+1].pattern&bit)||
+           (entries[j].pattern&mask)!=(entries[j+1].pattern&mask)){
+            return TH_EINVAL;
+          }
+        }
+        /*If there are no more codes, we should have ascended back to the top
+           of the tree.*/
+        else if(bpos<maxlen)return TH_EINVAL;
+      }
+    }
+  }
+  return 0;
+}
diff --git a/lib/huffenc.h b/lib/huffenc.h
new file mode 100644 (file)
index 0000000..c5a3956
--- /dev/null
@@ -0,0 +1,19 @@
+#if !defined(_huffenc_H)
+# define _huffenc_H (1)
+# include "huffman.h"
+
+
+
+typedef th_huff_code                  th_huff_table[TH_NDCT_TOKENS];
+
+
+
+extern const th_huff_code
+ TH_VP31_HUFF_CODES[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS];
+
+
+
+int oc_huff_codes_pack(oggpack_buffer *_opb,
+ const th_huff_code _codes[TH_NHUFFMAN_TABLES][TH_NDCT_TOKENS]);
+
+#endif
diff --git a/lib/huffman.h b/lib/huffman.h
new file mode 100644 (file)
index 0000000..36cf757
--- /dev/null
@@ -0,0 +1,70 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: huffman.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#if !defined(_huffman_H)
+# define _hufffman_H (1)
+# include "theora/codec.h"
+# include "ocintrin.h"
+
+/*The range of valid quantized DCT coefficient values.
+  VP3 used 511 in the encoder, but the bitstream is capable of 580.*/
+#define OC_DCT_VAL_RANGE         (580)
+
+#define OC_NDCT_TOKEN_BITS       (5)
+
+#define OC_DCT_EOB1_TOKEN        (0)
+#define OC_DCT_EOB2_TOKEN        (1)
+#define OC_DCT_EOB3_TOKEN        (2)
+#define OC_DCT_REPEAT_RUN0_TOKEN (3)
+#define OC_DCT_REPEAT_RUN1_TOKEN (4)
+#define OC_DCT_REPEAT_RUN2_TOKEN (5)
+#define OC_DCT_REPEAT_RUN3_TOKEN (6)
+
+#define OC_DCT_SHORT_ZRL_TOKEN   (7)
+#define OC_DCT_ZRL_TOKEN         (8)
+
+#define OC_ONE_TOKEN             (9)
+#define OC_MINUS_ONE_TOKEN       (10)
+#define OC_TWO_TOKEN             (11)
+#define OC_MINUS_TWO_TOKEN       (12)
+
+#define OC_DCT_VAL_CAT2          (13)
+#define OC_DCT_VAL_CAT3          (17)
+#define OC_DCT_VAL_CAT4          (18)
+#define OC_DCT_VAL_CAT5          (19)
+#define OC_DCT_VAL_CAT6          (20)
+#define OC_DCT_VAL_CAT7          (21)
+#define OC_DCT_VAL_CAT8          (22)
+
+#define OC_DCT_RUN_CAT1A         (23)
+#define OC_DCT_RUN_CAT1B         (28)
+#define OC_DCT_RUN_CAT1C         (29)
+#define OC_DCT_RUN_CAT2A         (30)
+#define OC_DCT_RUN_CAT2B         (31)
+
+#define OC_NDCT_EOB_TOKEN_MAX    (7)
+#define OC_NDCT_ZRL_TOKEN_MAX    (9)
+#define OC_NDCT_VAL_MAX          (23)
+#define OC_NDCT_VAL_CAT1_MAX     (13)
+#define OC_NDCT_VAL_CAT2_MAX     (17)
+#define OC_NDCT_VAL_CAT2_SIZE    (OC_NDCT_VAL_CAT2_MAX-OC_DCT_VAL_CAT2)
+#define OC_NDCT_RUN_MAX          (32)
+#define OC_NDCT_RUN_CAT1A_MAX    (28)
+
+extern const unsigned char OC_DCT_TOKEN_EXTRA_BITS[TH_NDCT_TOKENS];
+
+#endif
diff --git a/lib/idct.c b/lib/idct.c
new file mode 100644 (file)
index 0000000..0e68ac7
--- /dev/null
@@ -0,0 +1,335 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: idct.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <string.h>
+#include "internal.h"
+#include "dct.h"
+
+/*Performs an inverse 8 point Type-II DCT transform.
+  The output is scaled by a factor of 2 relative to the orthonormal version of
+   the transform.
+  _y: The buffer to store the result in.
+      Data will be placed in every 8th entry (e.g., in a column of an 8x8
+       block).
+  _x: The input coefficients.
+      The first 8 entries are used (e.g., from a row of an 8x8 block).*/
+static void idct8(ogg_int16_t *_y,const ogg_int16_t _x[8]){
+  ogg_int32_t t[8];
+  ogg_int32_t r;
+  /*Stage 1:*/
+  /*0-1 butterfly.*/
+  t[0]=OC_C4S4*(ogg_int16_t)(_x[0]+_x[4])>>16;
+  t[1]=OC_C4S4*(ogg_int16_t)(_x[0]-_x[4])>>16;
+  /*2-3 rotation by 6pi/16.*/
+  t[2]=(OC_C6S2*_x[2]>>16)-(OC_C2S6*_x[6]>>16);
+  t[3]=(OC_C2S6*_x[2]>>16)+(OC_C6S2*_x[6]>>16);
+  /*4-7 rotation by 7pi/16.*/
+  t[4]=(OC_C7S1*_x[1]>>16)-(OC_C1S7*_x[7]>>16);
+  /*5-6 rotation by 3pi/16.*/
+  t[5]=(OC_C3S5*_x[5]>>16)-(OC_C5S3*_x[3]>>16);
+  t[6]=(OC_C5S3*_x[5]>>16)+(OC_C3S5*_x[3]>>16);
+  t[7]=(OC_C1S7*_x[1]>>16)+(OC_C7S1*_x[7]>>16);
+  /*Stage 2:*/
+  /*4-5 butterfly.*/
+  r=t[4]+t[5];
+  t[5]=OC_C4S4*(ogg_int16_t)(t[4]-t[5])>>16;
+  t[4]=r;
+  /*7-6 butterfly.*/
+  r=t[7]+t[6];
+  t[6]=OC_C4S4*(ogg_int16_t)(t[7]-t[6])>>16;
+  t[7]=r;
+  /*Stage 3:*/
+  /*0-3 butterfly.*/
+  r=t[0]+t[3];
+  t[3]=t[0]-t[3];
+  t[0]=r;
+  /*1-2 butterfly.*/
+  r=t[1]+t[2];
+  t[2]=t[1]-t[2];
+  t[1]=r;
+  /*6-5 butterfly.*/
+  r=t[6]+t[5];
+  t[5]=t[6]-t[5];
+  t[6]=r;
+  /*Stage 4:*/
+  /*0-7 butterfly.*/
+  _y[0<<3]=(ogg_int16_t)(t[0]+t[7]);
+  /*1-6 butterfly.*/
+  _y[1<<3]=(ogg_int16_t)(t[1]+t[6]);
+  /*2-5 butterfly.*/
+  _y[2<<3]=(ogg_int16_t)(t[2]+t[5]);
+  /*3-4 butterfly.*/
+  _y[3<<3]=(ogg_int16_t)(t[3]+t[4]);
+  _y[4<<3]=(ogg_int16_t)(t[3]-t[4]);
+  _y[5<<3]=(ogg_int16_t)(t[2]-t[5]);
+  _y[6<<3]=(ogg_int16_t)(t[1]-t[6]);
+  _y[7<<3]=(ogg_int16_t)(t[0]-t[7]);
+}
+
+/*Performs an inverse 8 point Type-II DCT transform.
+  The output is scaled by a factor of 2 relative to the orthonormal version of
+   the transform.
+  _y: The buffer to store the result in.
+      Data will be placed in every 8th entry (e.g., in a column of an 8x8
+       block).
+  _x: The input coefficients.
+      Only the first 4 entries are used.
+      The other 4 are assumed to be 0.*/
+static void idct8_4(ogg_int16_t *_y,const ogg_int16_t _x[8]){
+  ogg_int32_t t[8];
+  ogg_int32_t r;
+  /*Stage 1:*/
+  t[0]=OC_C4S4*_x[0]>>16;
+  t[2]=OC_C6S2*_x[2]>>16;
+  t[3]=OC_C2S6*_x[2]>>16;
+  t[4]=OC_C7S1*_x[1]>>16;
+  t[5]=-(OC_C5S3*_x[3]>>16);
+  t[6]=OC_C3S5*_x[3]>>16;
+  t[7]=OC_C1S7*_x[1]>>16;
+  /*Stage 2:*/
+  r=t[4]+t[5];
+  t[5]=OC_C4S4*(ogg_int16_t)(t[4]-t[5])>>16;
+  t[4]=r;
+  r=t[7]+t[6];
+  t[6]=OC_C4S4*(ogg_int16_t)(t[7]-t[6])>>16;
+  t[7]=r;
+  /*Stage 3:*/
+  t[1]=t[0]+t[2];
+  t[2]=t[0]-t[2];
+  r=t[0]+t[3];
+  t[3]=t[0]-t[3];
+  t[0]=r;
+  r=t[6]+t[5];
+  t[5]=t[6]-t[5];
+  t[6]=r;
+  /*Stage 4:*/
+  _y[0<<3]=(ogg_int16_t)(t[0]+t[7]);
+  _y[1<<3]=(ogg_int16_t)(t[1]+t[6]);
+  _y[2<<3]=(ogg_int16_t)(t[2]+t[5]);
+  _y[3<<3]=(ogg_int16_t)(t[3]+t[4]);
+  _y[4<<3]=(ogg_int16_t)(t[3]-t[4]);
+  _y[5<<3]=(ogg_int16_t)(t[2]-t[5]);
+  _y[6<<3]=(ogg_int16_t)(t[1]-t[6]);
+  _y[7<<3]=(ogg_int16_t)(t[0]-t[7]);
+}
+
+/*Performs an inverse 8 point Type-II DCT transform.
+  The output is scaled by a factor of 2 relative to the orthonormal version of
+   the transform.
+  _y: The buffer to store the result in.
+      Data will be placed in every 8th entry (e.g., in a column of an 8x8
+       block).
+  _x: The input coefficients.
+      Only the first 3 entries are used.
+      The other 5 are assumed to be 0.*/
+static void idct8_3(ogg_int16_t *_y,const ogg_int16_t _x[8]){
+  ogg_int32_t t[8];
+  ogg_int32_t r;
+  /*Stage 1:*/
+  t[0]=OC_C4S4*_x[0]>>16;
+  t[2]=OC_C6S2*_x[2]>>16;
+  t[3]=OC_C2S6*_x[2]>>16;
+  t[4]=OC_C7S1*_x[1]>>16;
+  t[7]=OC_C1S7*_x[1]>>16;
+  /*Stage 2:*/
+  t[5]=OC_C4S4*t[4]>>16;
+  t[6]=OC_C4S4*t[7]>>16;
+  /*Stage 3:*/
+  t[1]=t[0]+t[2];
+  t[2]=t[0]-t[2];
+  r=t[0]+t[3];
+  t[3]=t[0]-t[3];
+  t[0]=r;
+  r=t[6]+t[5];
+  t[5]=t[6]-t[5];
+  t[6]=r;
+  /*Stage 4:*/
+  _y[0<<3]=(ogg_int16_t)(t[0]+t[7]);
+  _y[1<<3]=(ogg_int16_t)(t[1]+t[6]);
+  _y[2<<3]=(ogg_int16_t)(t[2]+t[5]);
+  _y[3<<3]=(ogg_int16_t)(t[3]+t[4]);
+  _y[4<<3]=(ogg_int16_t)(t[3]-t[4]);
+  _y[5<<3]=(ogg_int16_t)(t[2]-t[5]);
+  _y[6<<3]=(ogg_int16_t)(t[1]-t[6]);
+  _y[7<<3]=(ogg_int16_t)(t[0]-t[7]);
+}
+
+/*Performs an inverse 8 point Type-II DCT transform.
+  The output is scaled by a factor of 2 relative to the orthonormal version of
+   the transform.
+  _y: The buffer to store the result in.
+      Data will be placed in every 8th entry (e.g., in a column of an 8x8
+       block).
+  _x: The input coefficients.
+      Only the first 2 entries are used.
+      The other 6 are assumed to be 0.*/
+static void idct8_2(ogg_int16_t *_y,const ogg_int16_t _x[8]){
+  ogg_int32_t t[8];
+  ogg_int32_t r;
+  /*Stage 1:*/
+  t[0]=OC_C4S4*_x[0]>>16;
+  t[4]=OC_C7S1*_x[1]>>16;
+  t[7]=OC_C1S7*_x[1]>>16;
+  /*Stage 2:*/
+  t[5]=OC_C4S4*t[4]>>16;
+  t[6]=OC_C4S4*t[7]>>16;
+  /*Stage 3:*/
+  r=t[6]+t[5];
+  t[5]=t[6]-t[5];
+  t[6]=r;
+  /*Stage 4:*/
+  _y[0<<3]=(ogg_int16_t)(t[0]+t[7]);
+  _y[1<<3]=(ogg_int16_t)(t[0]+t[6]);
+  _y[2<<3]=(ogg_int16_t)(t[0]+t[5]);
+  _y[3<<3]=(ogg_int16_t)(t[0]+t[4]);
+  _y[4<<3]=(ogg_int16_t)(t[0]-t[4]);
+  _y[5<<3]=(ogg_int16_t)(t[0]-t[5]);
+  _y[6<<3]=(ogg_int16_t)(t[0]-t[6]);
+  _y[7<<3]=(ogg_int16_t)(t[0]-t[7]);
+}
+
+/*Performs an inverse 8 point Type-II DCT transform.
+  The output is scaled by a factor of 2 relative to the orthonormal version of
+   the transform.
+  _y: The buffer to store the result in.
+      Data will be placed in every 8th entry (e.g., in a column of an 8x8
+       block).
+  _x: The input coefficients.
+      Only the first entry is used.
+      The other 7 are assumed to be 0.*/
+static void idct8_1(ogg_int16_t *_y,const ogg_int16_t _x[1]){
+  _y[0<<3]=_y[1<<3]=_y[2<<3]=_y[3<<3]=
+   _y[4<<3]=_y[5<<3]=_y[6<<3]=_y[7<<3]=(ogg_int16_t)(OC_C4S4*_x[0]>>16);
+}
+
+/*Performs an inverse 8x8 Type-II DCT transform.
+  The input is assumed to be scaled by a factor of 4 relative to orthonormal
+   version of the transform.
+  All coefficients but the first 3 in zig-zag scan order are assumed to be 0:
+   x  x  0  0  0  0  0  0
+   x  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+  _y: The buffer to store the result in.
+      This may be the same as _x.
+  _x: The input coefficients.*/
+static void oc_idct8x8_3(ogg_int16_t _y[64],const ogg_int16_t _x[64]){
+  const ogg_int16_t *in;
+  ogg_int16_t       *end;
+  ogg_int16_t       *out;
+  ogg_int16_t        w[64];
+  /*Transform rows of x into columns of w.*/
+  idct8_2(w,_x);
+  idct8_1(w+1,_x+8);
+  /*Transform rows of w into columns of y.*/
+  for(in=w,out=_y,end=out+8;out<end;in+=8,out++)idct8_2(out,in);
+  /*Adjust for the scale factor.*/
+  for(out=_y,end=out+64;out<end;out++)*out=(ogg_int16_t)(*out+8>>4);
+}
+
+/*Performs an inverse 8x8 Type-II DCT transform.
+  The input is assumed to be scaled by a factor of 4 relative to orthonormal
+   version of the transform.
+  All coefficients but the first 10 in zig-zag scan order are assumed to be 0:
+   x  x  x  x  0  0  0  0
+   x  x  x  0  0  0  0  0
+   x  x  0  0  0  0  0  0
+   x  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+   0  0  0  0  0  0  0  0
+  _y: The buffer to store the result in.
+      This may be the same as _x.
+  _x: The input coefficients.*/
+static void oc_idct8x8_10(ogg_int16_t _y[64],const ogg_int16_t _x[64]){
+  const ogg_int16_t *in;
+  ogg_int16_t       *end;
+  ogg_int16_t       *out;
+  ogg_int16_t        w[64];
+  /*Transform rows of x into columns of w.*/
+  idct8_4(w,_x);
+  idct8_3(w+1,_x+8);
+  idct8_2(w+2,_x+16);
+  idct8_1(w+3,_x+24);
+  /*Transform rows of w into columns of y.*/
+  for(in=w,out=_y,end=out+8;out<end;in+=8,out++)idct8_4(out,in);
+  /*Adjust for the scale factor.*/
+  for(out=_y,end=out+64;out<end;out++)*out=(ogg_int16_t)(*out+8>>4);
+}
+
+/*Performs an inverse 8x8 Type-II DCT transform.
+  The input is assumed to be scaled by a factor of 4 relative to orthonormal
+   version of the transform.
+  _y: The buffer to store the result in.
+      This may be the same as _x.
+  _x: The input coefficients.*/
+static void oc_idct8x8_slow(ogg_int16_t _y[64],const ogg_int16_t _x[64]){
+  const ogg_int16_t *in;
+  ogg_int16_t       *end;
+  ogg_int16_t       *out;
+  ogg_int16_t        w[64];
+  /*Transform rows of x into columns of w.*/
+  for(in=_x,out=w,end=out+8;out<end;in+=8,out++)idct8(out,in);
+  /*Transform rows of w into columns of y.*/
+  for(in=w,out=_y,end=out+8;out<end;in+=8,out++)idct8(out,in);
+  /*Adjust for the scale factor.*/
+  for(out=_y,end=out+64;out<end;out++)*out=(ogg_int16_t)(*out+8>>4);
+}
+
+void oc_idct8x8(const oc_theora_state *_state,ogg_int16_t _y[64],
+ int _last_zzi){
+  (*_state->opt_vtable.idct8x8)(_y,_last_zzi);
+}
+
+/*Performs an inverse 8x8 Type-II DCT transform.
+  The input is assumed to be scaled by a factor of 4 relative to orthonormal
+   version of the transform.*/
+void oc_idct8x8_c(ogg_int16_t _y[64],int _last_zzi){
+  /*_last_zzi is subtly different from an actual count of the number of
+     coefficients we decoded for this block.
+    It contains the value of zzi BEFORE the final token in the block was
+     decoded.
+    In most cases this is an EOB token (the continuation of an EOB run from a
+     previous block counts), and so this is the same as the coefficient count.
+    However, in the case that the last token was NOT an EOB token, but filled
+     the block up with exactly 64 coefficients, _last_zzi will be less than 64.
+    Provided the last token was not a pure zero run, the minimum value it can
+     be is 46, and so that doesn't affect any of the cases in this routine.
+    However, if the last token WAS a pure zero run of length 63, then _last_zzi
+     will be 1 while the number of coefficients decoded is 64.
+    Thus, we will trigger the following special case, where the real
+     coefficient count would not.
+    Note also that a zero run of length 64 will give _last_zzi a value of 0,
+     but we still process the DC coefficient, which might have a non-zero value
+     due to DC prediction.
+    Although convoluted, this is arguably the correct behavior: it allows us to
+     use a smaller transform when the block ends with a long zero run instead
+     of a normal EOB token.
+    It could be smarter... multiple separate zero runs at the end of a block
+     will fool it, but an encoder that generates these really deserves what it
+     gets.
+    Needless to say we inherited this approach from VP3.*/
+  /*Then perform the iDCT.*/
+  if(_last_zzi<3)oc_idct8x8_3(_y,_y);
+  else if(_last_zzi<10)oc_idct8x8_10(_y,_y);
+  else oc_idct8x8_slow(_y,_y);
+}
diff --git a/lib/info.c b/lib/info.c
new file mode 100644 (file)
index 0000000..6b97629
--- /dev/null
@@ -0,0 +1,131 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: info.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <ctype.h>
+#include <string.h>
+#include "internal.h"
+
+
+
+/*This is more or less the same as strncasecmp, but that doesn't exist
+   everywhere, and this is a fairly trivial function, so we include it.
+  Note: We take advantage of the fact that we know _n is less than or equal to
+   the length of at least one of the strings.*/
+static int oc_tagcompare(const char *_s1,const char *_s2,int _n){
+  int c;
+  for(c=0;c<_n;c++){
+    if(toupper(_s1[c])!=toupper(_s2[c]))return !0;
+  }
+  return _s1[c]!='=';
+}
+
+
+
+void th_info_init(th_info *_info){
+  memset(_info,0,sizeof(*_info));
+  _info->version_major=TH_VERSION_MAJOR;
+  _info->version_minor=TH_VERSION_MINOR;
+  _info->version_subminor=TH_VERSION_SUB;
+  _info->keyframe_granule_shift=6;
+}
+
+void th_info_clear(th_info *_info){
+  memset(_info,0,sizeof(*_info));
+}
+
+
+
+void th_comment_init(th_comment *_tc){
+  memset(_tc,0,sizeof(*_tc));
+}
+
+void th_comment_add(th_comment *_tc,char *_comment){
+  char **user_comments;
+  int   *comment_lengths;
+  int    comment_len;
+  user_comments=_ogg_realloc(_tc->user_comments,
+   (_tc->comments+2)*sizeof(*_tc->user_comments));
+  if(user_comments==NULL)return;
+  _tc->user_comments=user_comments;
+  comment_lengths=_ogg_realloc(_tc->comment_lengths,
+   (_tc->comments+2)*sizeof(*_tc->comment_lengths));
+  if(comment_lengths==NULL)return;
+  _tc->comment_lengths=comment_lengths;
+  comment_len=strlen(_comment);
+  comment_lengths[_tc->comments]=comment_len;
+  user_comments[_tc->comments]=_ogg_malloc(comment_len+1);
+  if(user_comments[_tc->comments]==NULL)return;
+  memcpy(_tc->user_comments[_tc->comments],_comment,comment_len+1);
+  _tc->comments++;
+  _tc->user_comments[_tc->comments]=NULL;
+}
+
+void th_comment_add_tag(th_comment *_tc,char *_tag,char *_val){
+  char *comment;
+  int   tag_len;
+  int   val_len;
+  tag_len=strlen(_tag);
+  val_len=strlen(_val);
+  /*+2 for '=' and '\0'.*/
+  comment=_ogg_malloc(tag_len+val_len+2);
+  if(comment==NULL)return;
+  memcpy(comment,_tag,tag_len);
+  comment[tag_len]='=';
+  memcpy(comment+tag_len+1,_val,val_len+1);
+  th_comment_add(_tc,comment);
+  _ogg_free(comment);
+}
+
+char *th_comment_query(th_comment *_tc,char *_tag,int _count){
+  long i;
+  int  found;
+  int  tag_len;
+  tag_len=strlen(_tag);
+  found=0;
+  for(i=0;i<_tc->comments;i++){
+    if(!oc_tagcompare(_tc->user_comments[i],_tag,tag_len)){
+      /*We return a pointer to the data, not a copy.*/
+      if(_count==found++)return _tc->user_comments[i]+tag_len+1;
+    }
+  }
+  /*Didn't find anything.*/
+  return NULL;
+}
+
+int th_comment_query_count(th_comment *_tc,char *_tag){
+  long i;
+  int  tag_len;
+  int  count;
+  tag_len=strlen(_tag);
+  count=0;
+  for(i=0;i<_tc->comments;i++){
+    if(!oc_tagcompare(_tc->user_comments[i],_tag,tag_len))count++;
+  }
+  return count;
+}
+
+void th_comment_clear(th_comment *_tc){
+  if(_tc!=NULL){
+    long i;
+    for(i=0;i<_tc->comments;i++)_ogg_free(_tc->user_comments[i]);
+    _ogg_free(_tc->user_comments);
+    _ogg_free(_tc->comment_lengths);
+    _ogg_free(_tc->vendor);
+    memset(_tc,0,sizeof(*_tc));
+  }
+}
diff --git a/lib/internal.c b/lib/internal.c
new file mode 100644 (file)
index 0000000..0fe4f63
--- /dev/null
@@ -0,0 +1,262 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: internal.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <limits.h>
+#include <string.h>
+#include "internal.h"
+
+
+
+/*A map from the index in the zig zag scan to the coefficient number in a
+   block.
+  All zig zag indices beyond 63 are sent to coefficient 64, so that zero runs
+   past the end of a block in bogus streams get mapped to a known location.*/
+const unsigned char OC_FZIG_ZAG[128]={
+   0, 1, 8,16, 9, 2, 3,10,
+  17,24,32,25,18,11, 4, 5,
+  12,19,26,33,40,48,41,34,
+  27,20,13, 6, 7,14,21,28,
+  35,42,49,56,57,50,43,36,
+  29,22,15,23,30,37,44,51,
+  58,59,52,45,38,31,39,46,
+  53,60,61,54,47,55,62,63,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64
+};
+
+/*A map from the coefficient number in a block to its index in the zig zag
+   scan.*/
+const unsigned char OC_IZIG_ZAG[64]={
+   0, 1, 5, 6,14,15,27,28,
+   2, 4, 7,13,16,26,29,42,
+   3, 8,12,17,25,30,41,43,
+   9,11,18,24,31,40,44,53,
+  10,19,23,32,39,45,52,54,
+  20,22,33,38,46,51,55,60,
+  21,34,37,47,50,56,59,61,
+  35,36,48,49,57,58,62,63
+};
+
+/*A map from physical macro block ordering to bitstream macro block
+   ordering within a super block.*/
+const unsigned char OC_MB_MAP[2][2]={{0,3},{1,2}};
+
+/*A list of the indices in the oc_mb.map array that can be valid for each of
+   the various chroma decimation types.*/
+const unsigned char OC_MB_MAP_IDXS[TH_PF_NFORMATS][12]={
+  {0,1,2,3,4,8},
+  {0,1,2,3,4,5,8,9},
+  {0,1,2,3,4,6,8,10},
+  {0,1,2,3,4,5,6,7,8,9,10,11}
+};
+
+/*The number of indices in the oc_mb.map array that can be valid for each of
+   the various chroma decimation types.*/
+const unsigned char OC_MB_MAP_NIDXS[TH_PF_NFORMATS]={6,8,8,12};
+
+/*The number of extra bits that are coded with each of the DCT tokens.
+  Each DCT token has some fixed number of additional bits (possibly 0) stored
+   after the token itself, containing, for example, coefficient magnitude,
+   sign bits, etc.*/
+const unsigned char OC_DCT_TOKEN_EXTRA_BITS[TH_NDCT_TOKENS]={
+  0,0,0,2,3,4,12,3,6,
+  0,0,0,0,
+  1,1,1,1,2,3,4,5,6,10,
+  1,1,1,1,1,3,4,
+  2,3
+};
+
+
+
+int oc_ilog(unsigned _v){
+  int ret;
+  for(ret=0;_v;ret++)_v>>=1;
+  return ret;
+}
+
+
+
+/*The function used to fill in the chroma plane motion vectors for a macro
+   block when 4 different motion vectors are specified in the luma plane.
+  This version is for use with chroma decimated in the X and Y directions
+   (4:2:0).
+  _cbmvs: The chroma block-level motion vectors to fill in.
+  _lbmvs: The luma block-level motion vectors.*/
+static void oc_set_chroma_mvs00(oc_mv _cbmvs[4],const oc_mv _lbmvs[4]){
+  int dx;
+  int dy;
+  dx=_lbmvs[0][0]+_lbmvs[1][0]+_lbmvs[2][0]+_lbmvs[3][0];
+  dy=_lbmvs[0][1]+_lbmvs[1][1]+_lbmvs[2][1]+_lbmvs[3][1];
+  _cbmvs[0][0]=(signed char)OC_DIV_ROUND_POW2(dx,2,2);
+  _cbmvs[0][1]=(signed char)OC_DIV_ROUND_POW2(dy,2,2);
+}
+
+/*The function used to fill in the chroma plane motion vectors for a macro
+   block when 4 different motion vectors are specified in the luma plane.
+  This version is for use with chroma decimated in the Y direction.
+  _cbmvs: The chroma block-level motion vectors to fill in.
+  _lbmvs: The luma block-level motion vectors.*/
+static void oc_set_chroma_mvs01(oc_mv _cbmvs[4],const oc_mv _lbmvs[4]){
+  int dx;
+  int dy;
+  dx=_lbmvs[0][0]+_lbmvs[2][0];
+  dy=_lbmvs[0][1]+_lbmvs[2][1];
+  _cbmvs[0][0]=(signed char)OC_DIV_ROUND_POW2(dx,1,1);
+  _cbmvs[0][1]=(signed char)OC_DIV_ROUND_POW2(dy,1,1);
+  dx=_lbmvs[1][0]+_lbmvs[3][0];
+  dy=_lbmvs[1][1]+_lbmvs[3][1];
+  _cbmvs[1][0]=(signed char)OC_DIV_ROUND_POW2(dx,1,1);
+  _cbmvs[1][1]=(signed char)OC_DIV_ROUND_POW2(dy,1,1);
+}
+
+/*The function used to fill in the chroma plane motion vectors for a macro
+   block when 4 different motion vectors are specified in the luma plane.
+  This version is for use with chroma decimated in the X direction (4:2:2).
+  _cbmvs: The chroma block-level motion vectors to fill in.
+  _lbmvs: The luma block-level motion vectors.*/
+static void oc_set_chroma_mvs10(oc_mv _cbmvs[4],const oc_mv _lbmvs[4]){
+  int dx;
+  int dy;
+  dx=_lbmvs[0][0]+_lbmvs[1][0];
+  dy=_lbmvs[0][1]+_lbmvs[1][1];
+  _cbmvs[0][0]=(signed char)OC_DIV_ROUND_POW2(dx,1,1);
+  _cbmvs[0][1]=(signed char)OC_DIV_ROUND_POW2(dy,1,1);
+  dx=_lbmvs[2][0]+_lbmvs[3][0];
+  dy=_lbmvs[2][1]+_lbmvs[3][1];
+  _cbmvs[2][0]=(signed char)OC_DIV_ROUND_POW2(dx,1,1);
+  _cbmvs[2][1]=(signed char)OC_DIV_ROUND_POW2(dy,1,1);
+}
+
+/*The function used to fill in the chroma plane motion vectors for a macro
+   block when 4 different motion vectors are specified in the luma plane.
+  This version is for use with no chroma decimation (4:4:4).
+  _cbmvs: The chroma block-level motion vectors to fill in.
+  _lmbmv: The luma macro-block level motion vector to fill in for use in
+           prediction.
+  _lbmvs: The luma block-level motion vectors.*/
+static void oc_set_chroma_mvs11(oc_mv _cbmvs[4],const oc_mv _lbmvs[4]){
+  memcpy(_cbmvs,_lbmvs,4*sizeof(_lbmvs[0]));
+}
+
+/*A table of functions used to fill in the chroma plane motion vectors for a
+   macro block when 4 different motion vectors are specified in the luma
+   plane.*/
+const oc_set_chroma_mvs_func OC_SET_CHROMA_MVS_TABLE[TH_PF_NFORMATS]={
+  (oc_set_chroma_mvs_func)oc_set_chroma_mvs00,
+  (oc_set_chroma_mvs_func)oc_set_chroma_mvs01,
+  (oc_set_chroma_mvs_func)oc_set_chroma_mvs10,
+  (oc_set_chroma_mvs_func)oc_set_chroma_mvs11
+};
+
+
+
+void **oc_malloc_2d(size_t _height,size_t _width,size_t _sz){
+  size_t  rowsz;
+  size_t  colsz;
+  size_t  datsz;
+  char   *ret;
+  colsz=_height*sizeof(void *);
+  rowsz=_sz*_width;
+  datsz=rowsz*_height;
+  /*Alloc array and row pointers.*/
+  ret=(char *)_ogg_malloc(datsz+colsz);
+  if(ret==NULL)return NULL;
+  /*Initialize the array.*/
+  if(ret!=NULL){
+    size_t   i;
+    void   **p;
+    char    *datptr;
+    p=(void **)ret;
+    i=_height;
+    for(datptr=ret+colsz;i-->0;p++,datptr+=rowsz)*p=(void *)datptr;
+  }
+  return (void **)ret;
+}
+
+void **oc_calloc_2d(size_t _height,size_t _width,size_t _sz){
+  size_t  colsz;
+  size_t  rowsz;
+  size_t  datsz;
+  char   *ret;
+  colsz=_height*sizeof(void *);
+  rowsz=_sz*_width;
+  datsz=rowsz*_height;
+  /*Alloc array and row pointers.*/
+  ret=(char *)_ogg_calloc(datsz+colsz,1);
+  if(ret==NULL)return NULL;
+  /*Initialize the array.*/
+  if(ret!=NULL){
+    size_t   i;
+    void   **p;
+    char    *datptr;
+    p=(void **)ret;
+    i=_height;
+    for(datptr=ret+colsz;i-->0;p++,datptr+=rowsz)*p=(void *)datptr;
+  }
+  return (void **)ret;
+}
+
+void oc_free_2d(void *_ptr){
+  _ogg_free(_ptr);
+}
+
+/*Fills in a Y'CbCr buffer with a pointer to the image data in the first
+   buffer, but with the opposite vertical orientation.
+  _dst: The destination buffer.
+        This can be the same as _src.
+  _src: The source buffer.*/
+void oc_ycbcr_buffer_flip(th_ycbcr_buffer _dst,
+ const th_ycbcr_buffer _src){
+  int pli;
+  for(pli=0;pli<3;pli++){
+    _dst[pli].width=_src[pli].width;
+    _dst[pli].height=_src[pli].height;
+    _dst[pli].stride=-_src[pli].stride;
+    _dst[pli].data=_src[pli].data
+     +(1-_dst[pli].height)*(ptrdiff_t)_dst[pli].stride;
+  }
+}
+
+const char *th_version_string(void){
+  return OC_VENDOR_STRING;
+}
+
+ogg_uint32_t th_version_number(void){
+  return (TH_VERSION_MAJOR<<16)+(TH_VERSION_MINOR<<8)+TH_VERSION_SUB;
+}
+
+/*Determines the packet type.
+  Note that this correctly interprets a 0-byte packet as a video data packet.
+  Return: 1 for a header packet, 0 for a data packet.*/
+int th_packet_isheader(ogg_packet *_op){
+  return _op->bytes>0?_op->packet[0]>>7:0;
+}
+
+/*Determines the frame type of a video data packet.
+  Note that this correctly interprets a 0-byte packet as a delta frame.
+  Return: 1 for a key frame, 0 for a delta frame, and -1 for a header
+           packet.*/
+int th_packet_iskeyframe(ogg_packet *_op){
+  return _op->bytes<=0?0:_op->packet[0]&0x80?-1:!(_op->packet[0]&0x40);
+}
diff --git a/lib/internal.h b/lib/internal.h
new file mode 100644 (file)
index 0000000..d81263e
--- /dev/null
@@ -0,0 +1,509 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: internal.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#if !defined(_internal_H)
+# define _internal_H (1)
+# include <stdlib.h>
+# include <limits.h>
+# if defined(HAVE_CONFIG_H)
+#  include <config.h>
+# endif
+# include "theora/codec.h"
+# include "theora/theora.h"
+
+# if defined(_MSC_VER)
+/*Disable missing EMMS warnings.*/
+#  pragma warning(disable:4799)
+/*Thank you Microsoft, I know the order of operations.*/
+#  pragma warning(disable:4554)
+# endif
+/*You, too, gcc.*/
+# if defined(__GNUC_PREREQ)
+#  if __GNUC_PREREQ(4,2)
+#   pragma GCC diagnostic ignored "-Wparentheses"
+#  endif
+# endif
+
+# include "ocintrin.h"
+# include "huffman.h"
+# include "quant.h"
+
+/*Some assembly constructs require aligned operands.*/
+# if defined(OC_X86_ASM)
+#  if defined(__GNUC__)
+#   define OC_ALIGN8(expr) expr __attribute__((aligned(8)))
+#   define OC_ALIGN16(expr) expr __attribute__((aligned(16)))
+#  elif defined(_MSC_VER)
+#   define OC_ALIGN8(expr) __declspec (align(8)) expr
+#   define OC_ALIGN16(expr) __declspec (align(16)) expr
+#  endif
+# endif
+# if !defined(OC_ALIGN8)
+#  define OC_ALIGN8(expr) expr
+# endif
+# if !defined(OC_ALIGN16)
+#  define OC_ALIGN16(expr) expr
+# endif
+
+
+
+typedef struct oc_sb_flags              oc_sb_flags;
+typedef struct oc_border_info           oc_border_info;
+typedef struct oc_fragment              oc_fragment;
+typedef struct oc_fragment_plane        oc_fragment_plane;
+typedef struct oc_base_opt_vtable       oc_base_opt_vtable;
+typedef struct oc_base_opt_data         oc_base_opt_data;
+typedef struct oc_state_dispatch_vtable oc_state_dispatch_vtable;
+typedef struct oc_theora_state          oc_theora_state;
+
+
+
+/*This library's version.*/
+# define OC_VENDOR_STRING "Xiph.Org libtheora 1.1 20090822 (Thusnelda)"
+
+/*Theora bitstream version.*/
+# define TH_VERSION_MAJOR (3)
+# define TH_VERSION_MINOR (2)
+# define TH_VERSION_SUB   (1)
+# define TH_VERSION_CHECK(_info,_maj,_min,_sub) \
+ ((_info)->version_major>(_maj)||(_info)->version_major==(_maj)&& \
+ ((_info)->version_minor>(_min)||(_info)->version_minor==(_min)&& \
+ (_info)->version_subminor>=(_sub)))
+
+/*A keyframe.*/
+#define OC_INTRA_FRAME (0)
+/*A predicted frame.*/
+#define OC_INTER_FRAME (1)
+/*A frame of unknown type (frame type decision has not yet been made).*/
+#define OC_UNKWN_FRAME (-1)
+
+/*The amount of padding to add to the reconstructed frame buffers on all
+   sides.
+  This is used to allow unrestricted motion vectors without special casing.
+  This must be a multiple of 2.*/
+#define OC_UMV_PADDING (16)
+
+/*Frame classification indices.*/
+/*The previous golden frame.*/
+#define OC_FRAME_GOLD (0)
+/*The previous frame.*/
+#define OC_FRAME_PREV (1)
+/*The current frame.*/
+#define OC_FRAME_SELF (2)
+
+/*The input or output buffer.*/
+#define OC_FRAME_IO   (3)
+
+/*Macroblock modes.*/
+/*Macro block is invalid: It is never coded.*/
+#define OC_MODE_INVALID        (-1)
+/*Encoded difference from the same macro block in the previous frame.*/
+#define OC_MODE_INTER_NOMV     (0)
+/*Encoded with no motion compensated prediction.*/
+#define OC_MODE_INTRA          (1)
+/*Encoded difference from the previous frame offset by the given motion 
+  vector.*/
+#define OC_MODE_INTER_MV       (2)
+/*Encoded difference from the previous frame offset by the last coded motion 
+  vector.*/
+#define OC_MODE_INTER_MV_LAST  (3)
+/*Encoded difference from the previous frame offset by the second to last 
+  coded motion vector.*/
+#define OC_MODE_INTER_MV_LAST2 (4)
+/*Encoded difference from the same macro block in the previous golden 
+  frame.*/
+#define OC_MODE_GOLDEN_NOMV    (5)
+/*Encoded difference from the previous golden frame offset by the given motion 
+  vector.*/
+#define OC_MODE_GOLDEN_MV      (6)
+/*Encoded difference from the previous frame offset by the individual motion 
+  vectors given for each block.*/
+#define OC_MODE_INTER_MV_FOUR  (7)
+/*The number of (coded) modes.*/
+#define OC_NMODES              (8)
+
+/*Determines the reference frame used for a given MB mode.*/
+#define OC_FRAME_FOR_MODE(_x) \
+ OC_UNIBBLE_TABLE32(OC_FRAME_PREV,OC_FRAME_SELF,OC_FRAME_PREV,OC_FRAME_PREV, \
+  OC_FRAME_PREV,OC_FRAME_GOLD,OC_FRAME_GOLD,OC_FRAME_PREV,(_x))
+
+/*Constants for the packet state machine common between encoder and decoder.*/
+
+/*Next packet to emit/read: Codec info header.*/
+#define OC_PACKET_INFO_HDR    (-3)
+/*Next packet to emit/read: Comment header.*/
+#define OC_PACKET_COMMENT_HDR (-2)
+/*Next packet to emit/read: Codec setup header.*/
+#define OC_PACKET_SETUP_HDR   (-1)
+/*No more packets to emit/read.*/
+#define OC_PACKET_DONE        (INT_MAX)
+
+
+
+/*Super blocks are 32x32 segments of pixels in a single color plane indexed
+   in image order.
+  Internally, super blocks are broken up into four quadrants, each of which
+   contains a 2x2 pattern of blocks, each of which is an 8x8 block of pixels.
+  Quadrants, and the blocks within them, are indexed in a special order called
+   a "Hilbert curve" within the super block.
+
+  In order to differentiate between the Hilbert-curve indexing strategy and
+   the regular image order indexing strategy, blocks indexed in image order
+   are called "fragments".
+  Fragments are indexed in image order, left to right, then bottom to top,
+   from Y' plane to Cb plane to Cr plane.
+
+  The co-located fragments in all image planes corresponding to the location
+   of a single quadrant of a luma plane super block form a macro block.
+  Thus there is only a single set of macro blocks for all planes, each of which
+   contains between 6 and 12 fragments, depending on the pixel format.
+  Therefore macro block information is kept in a separate set of arrays from
+   super blocks to avoid unused space in the other planes.
+  The lists are indexed in super block order.
+  That is, the macro block corresponding to the macro block mbi in (luma plane)
+   super block sbi is at index (sbi<<2|mbi).
+  Thus the number of macro blocks in each dimension is always twice the number
+   of super blocks, even when only an odd number fall inside the coded frame.
+  These "extra" macro blocks are just an artifact of our internal data layout,
+   and not part of the coded stream; they are flagged with a negative MB mode.*/
+
+
+
+/*A single quadrant of the map from a super block to fragment numbers.*/
+typedef ptrdiff_t       oc_sb_map_quad[4];
+/*A map from a super block to fragment numbers.*/
+typedef oc_sb_map_quad  oc_sb_map[4];
+/*A single plane of the map from a macro block to fragment numbers.*/
+typedef ptrdiff_t       oc_mb_map_plane[4];
+/*A map from a macro block to fragment numbers.*/
+typedef oc_mb_map_plane oc_mb_map[3];
+/*A motion vector.*/
+typedef signed char     oc_mv[2];
+
+
+
+/*Super block information.*/
+struct oc_sb_flags{
+  unsigned char coded_fully:1;
+  unsigned char coded_partially:1;
+  unsigned char quad_valid:4;
+};
+
+
+
+/*Information about a fragment which intersects the border of the displayable
+   region.
+  This marks which pixels belong to the displayable region.*/
+struct oc_border_info{
+  /*A bit mask marking which pixels are in the displayable region.
+    Pixel (x,y) corresponds to bit (y<<3|x).*/
+  ogg_int64_t mask;
+  /*The number of pixels in the displayable region.
+    This is always positive, and always less than 64.*/
+  int         npixels;
+};
+
+
+
+/*Fragment information.*/
+struct oc_fragment{
+  /*A flag indicating whether or not this fragment is coded.*/
+  unsigned   coded:1;
+  /*A flag indicating that this entire fragment lies outside the displayable
+     region of the frame.
+    Note the contrast with an invalid macro block, which is outside the coded
+     frame, not just the displayable one.
+    There are no fragments outside the coded frame by construction.*/
+  unsigned   invalid:1;
+  /*The index of the quality index used for this fragment's AC coefficients.*/
+  unsigned   qii:6;
+  /*The mode of the macroblock this fragment belongs to.*/
+  unsigned   mb_mode:3;
+  /*The index of the associated border information for fragments which lie
+     partially outside the displayable region.
+    For fragments completely inside or outside this region, this is -1.
+    Note that the C standard requires an explicit signed keyword for bitfield
+     types, since some compilers may treat them as unsigned without it.*/
+  signed int borderi:5;
+  /*The prediction-corrected DC component.
+    Note that the C standard requires an explicit signed keyword for bitfield
+     types, since some compilers may treat them as unsigned without it.*/
+  signed int dc:16;
+};
+
+
+
+/*A description of each fragment plane.*/
+struct oc_fragment_plane{
+  /*The number of fragments in the horizontal direction.*/
+  int       nhfrags;
+  /*The number of fragments in the vertical direction.*/
+  int       nvfrags;
+  /*The offset of the first fragment in the plane.*/
+  ptrdiff_t froffset;
+  /*The total number of fragments in the plane.*/
+  ptrdiff_t nfrags;
+  /*The number of super blocks in the horizontal direction.*/
+  unsigned  nhsbs;
+  /*The number of super blocks in the vertical direction.*/
+  unsigned  nvsbs;
+  /*The offset of the first super block in the plane.*/
+  unsigned  sboffset;
+  /*The total number of super blocks in the plane.*/
+  unsigned  nsbs;
+};
+
+
+
+/*The shared (encoder and decoder) functions that have accelerated variants.*/
+struct oc_base_opt_vtable{
+  void (*frag_copy)(unsigned char *_dst,
+   const unsigned char *_src,int _ystride);
+  void (*frag_recon_intra)(unsigned char *_dst,int _ystride,
+   const ogg_int16_t _residue[64]);
+  void (*frag_recon_inter)(unsigned char *_dst,
+   const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]);
+  void (*frag_recon_inter2)(unsigned char *_dst,const unsigned char *_src1,
+   const unsigned char *_src2,int _ystride,const ogg_int16_t _residue[64]);
+  void (*idct8x8)(ogg_int16_t _y[64],int _last_zzi);
+  void (*state_frag_recon)(const oc_theora_state *_state,ptrdiff_t _fragi,
+   int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant);
+  void (*state_frag_copy_list)(const oc_theora_state *_state,
+   const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+   int _dst_frame,int _src_frame,int _pli);
+  void (*state_loop_filter_frag_rows)(const oc_theora_state *_state,
+   int _bv[256],int _refi,int _pli,int _fragy0,int _fragy_end);  
+  void (*restore_fpu)(void);
+};
+
+/*The shared (encoder and decoder) tables that vary according to which variants
+   of the above functions are used.*/
+struct oc_base_opt_data{
+  const unsigned char *dct_fzig_zag;
+};
+
+
+/*State information common to both the encoder and decoder.*/
+struct oc_theora_state{
+  /*The stream information.*/
+  th_info             info;
+  /*Table for shared accelerated functions.*/
+  oc_base_opt_vtable  opt_vtable;
+  /*Table for shared data used by accelerated functions.*/
+  oc_base_opt_data    opt_data;
+  /*CPU flags to detect the presence of extended instruction sets.*/
+  ogg_uint32_t        cpu_flags;
+  /*The fragment plane descriptions.*/
+  oc_fragment_plane   fplanes[3];
+  /*The list of fragments, indexed in image order.*/
+  oc_fragment        *frags;
+  /*The the offset into the reference frame buffer to the upper-left pixel of
+     each fragment.*/
+  ptrdiff_t          *frag_buf_offs;
+  /*The motion vector for each fragment.*/
+  oc_mv              *frag_mvs;
+  /*The total number of fragments in a single frame.*/
+  ptrdiff_t           nfrags;
+  /*The list of super block maps, indexed in image order.*/
+  oc_sb_map          *sb_maps;
+  /*The list of super block flags, indexed in image order.*/
+  oc_sb_flags        *sb_flags;
+  /*The total number of super blocks in a single frame.*/
+  unsigned            nsbs;
+  /*The fragments from each color plane that belong to each macro block.
+    Fragments are stored in image order (left to right then top to bottom).
+    When chroma components are decimated, the extra fragments have an index of
+     -1.*/
+  oc_mb_map          *mb_maps;
+  /*The list of macro block modes.
+    A negative number indicates the macro block lies entirely outside the
+     coded frame.*/
+  signed char        *mb_modes;
+  /*The number of macro blocks in the X direction.*/
+  unsigned            nhmbs;
+  /*The number of macro blocks in the Y direction.*/
+  unsigned            nvmbs;
+  /*The total number of macro blocks.*/
+  size_t              nmbs;
+  /*The list of coded fragments, in coded order.
+    Uncoded fragments are stored in reverse order from the end of the list.*/
+  ptrdiff_t          *coded_fragis;
+  /*The number of coded fragments in each plane.*/
+  ptrdiff_t           ncoded_fragis[3];
+  /*The total number of coded fragments.*/
+  ptrdiff_t           ntotal_coded_fragis;
+  /*The index of the buffers being used for each OC_FRAME_* reference frame.*/
+  int                 ref_frame_idx[4];
+  /*The actual buffers used for the previously decoded frames.*/
+  th_ycbcr_buffer     ref_frame_bufs[4];
+  /*The storage for the reference frame buffers.*/
+  unsigned char      *ref_frame_data[4];
+  /*The strides for each plane in the reference frames.*/
+  int                 ref_ystride[3];
+  /*The number of unique border patterns.*/
+  int                 nborders;
+  /*The unique border patterns for all border fragments.
+    The borderi field of fragments which straddle the border indexes this
+     list.*/
+  oc_border_info      borders[16];
+  /*The frame number of the last keyframe.*/
+  ogg_int64_t         keyframe_num;
+  /*The frame number of the current frame.*/
+  ogg_int64_t         curframe_num;
+  /*The granpos of the current frame.*/
+  ogg_int64_t         granpos;
+  /*The type of the current frame.*/
+  unsigned char       frame_type;
+  /*The bias to add to the frame count when computing granule positions.*/
+  unsigned char       granpos_bias;
+  /*The number of quality indices used in the current frame.*/
+  unsigned char       nqis;
+  /*The quality indices of the current frame.*/
+  unsigned char       qis[3];
+  /*The dequantization tables, stored in zig-zag order, and indexed by
+     qi, pli, qti, and zzi.*/
+  ogg_uint16_t       *dequant_tables[64][3][2];
+  OC_ALIGN16(oc_quant_table      dequant_table_data[64][3][2]);
+  /*Loop filter strength parameters.*/
+  unsigned char       loop_filter_limits[64];
+};
+
+
+
+/*The function type used to fill in the chroma plane motion vectors for a
+   macro block when 4 different motion vectors are specified in the luma
+   plane.
+  _cbmvs: The chroma block-level motion vectors to fill in.
+  _lmbmv: The luma macro-block level motion vector to fill in for use in
+           prediction.
+  _lbmvs: The luma block-level motion vectors.*/
+typedef void (*oc_set_chroma_mvs_func)(oc_mv _cbmvs[4],const oc_mv _lbmvs[4]);
+
+
+
+/*A map from the index in the zig zag scan to the coefficient number in a
+   block.*/
+extern const unsigned char OC_FZIG_ZAG[128];
+/*A map from the coefficient number in a block to its index in the zig zag
+   scan.*/
+extern const unsigned char OC_IZIG_ZAG[64];
+/*A map from physical macro block ordering to bitstream macro block
+   ordering within a super block.*/
+extern const unsigned char OC_MB_MAP[2][2];
+/*A list of the indices in the oc_mb_map array that can be valid for each of
+   the various chroma decimation types.*/
+extern const unsigned char OC_MB_MAP_IDXS[TH_PF_NFORMATS][12];
+/*The number of indices in the oc_mb_map array that can be valid for each of
+   the various chroma decimation types.*/
+extern const unsigned char OC_MB_MAP_NIDXS[TH_PF_NFORMATS];
+/*A table of functions used to fill in the Cb,Cr plane motion vectors for a
+   macro block when 4 different motion vectors are specified in the luma
+   plane.*/
+extern const oc_set_chroma_mvs_func OC_SET_CHROMA_MVS_TABLE[TH_PF_NFORMATS];
+
+
+
+int oc_ilog(unsigned _v);
+void **oc_malloc_2d(size_t _height,size_t _width,size_t _sz);
+void **oc_calloc_2d(size_t _height,size_t _width,size_t _sz);
+void oc_free_2d(void *_ptr);
+
+void oc_ycbcr_buffer_flip(th_ycbcr_buffer _dst,
+ const th_ycbcr_buffer _src);
+
+int oc_state_init(oc_theora_state *_state,const th_info *_info,int _nrefs);
+void oc_state_clear(oc_theora_state *_state);
+void oc_state_vtable_init_c(oc_theora_state *_state);
+void oc_state_borders_fill_rows(oc_theora_state *_state,int _refi,int _pli,
+ int _y0,int _yend);
+void oc_state_borders_fill_caps(oc_theora_state *_state,int _refi,int _pli);
+void oc_state_borders_fill(oc_theora_state *_state,int _refi);
+void oc_state_fill_buffer_ptrs(oc_theora_state *_state,int _buf_idx,
+ th_ycbcr_buffer _img);
+int oc_state_mbi_for_pos(oc_theora_state *_state,int _mbx,int _mby);
+int oc_state_get_mv_offsets(const oc_theora_state *_state,int _offsets[2],
+ int _pli,int _dx,int _dy);
+
+int oc_state_loop_filter_init(oc_theora_state *_state,int *_bv);
+void oc_state_loop_filter(oc_theora_state *_state,int _frame);
+#if defined(OC_DUMP_IMAGES)
+int oc_state_dump_frame(const oc_theora_state *_state,int _frame,
+ const char *_suf);
+#endif
+
+/*Shared accelerated functions.*/
+void oc_frag_copy(const oc_theora_state *_state,unsigned char *_dst,
+ const unsigned char *_src,int _ystride);
+void oc_frag_recon_intra(const oc_theora_state *_state,
+ unsigned char *_dst,int _dst_ystride,const ogg_int16_t _residue[64]);
+void oc_frag_recon_inter(const oc_theora_state *_state,unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]);
+void oc_frag_recon_inter2(const oc_theora_state *_state,
+ unsigned char *_dst,const unsigned char *_src1,const unsigned char *_src2,
+ int _ystride,const ogg_int16_t _residue[64]);
+void oc_idct8x8(const oc_theora_state *_state,ogg_int16_t _y[64],int _last_zzi);
+void oc_state_frag_recon(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant);
+void oc_state_frag_copy_list(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli);
+void oc_state_loop_filter_frag_rows(const oc_theora_state *_state,
+ int _bv[256],int _refi,int _pli,int _fragy0,int _fragy_end);
+void oc_restore_fpu(const oc_theora_state *_state);
+
+/*Default pure-C implementations.*/
+void oc_frag_copy_c(unsigned char *_dst,
+ const unsigned char *_src,int _src_ystride);
+void oc_frag_recon_intra_c(unsigned char *_dst,int _dst_ystride,
+ const ogg_int16_t _residue[64]);
+void oc_frag_recon_inter_c(unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t _residue[64]);
+void oc_frag_recon_inter2_c(unsigned char *_dst,const unsigned char *_src1,
+ const unsigned char *_src2,int _ystride,const ogg_int16_t _residue[64]);
+void oc_idct8x8_c(ogg_int16_t _y[64],int _last_zzi);
+void oc_state_frag_recon_c(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant);
+void oc_state_frag_copy_list_c(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli);
+void oc_state_loop_filter_frag_rows_c(const oc_theora_state *_state,
+ int _bv[256],int _refi,int _pli,int _fragy0,int _fragy_end);
+void oc_restore_fpu_c(void);
+
+/*We need a way to call a few encoder functions without introducing a link-time
+   dependency into the decoder, while still allowing the old alpha API which
+   does not distinguish between encoder and decoder objects to be used.
+  We do this by placing a function table at the start of the encoder object
+   which can dispatch into the encoder library.
+  We do a similar thing for the decoder in case we ever decide to split off a
+   common base library.*/
+typedef void (*oc_state_clear_func)(theora_state *_th);
+typedef int (*oc_state_control_func)(theora_state *th,int _req,
+ void *_buf,size_t _buf_sz);
+typedef ogg_int64_t (*oc_state_granule_frame_func)(theora_state *_th,
+ ogg_int64_t _granulepos);
+typedef double (*oc_state_granule_time_func)(theora_state *_th,
+ ogg_int64_t _granulepos);
+
+
+struct oc_state_dispatch_vtable{
+  oc_state_clear_func         clear;
+  oc_state_control_func       control;
+  oc_state_granule_frame_func granule_frame;
+  oc_state_granule_time_func  granule_time;
+};
+
+#endif
diff --git a/lib/mathops.c b/lib/mathops.c
new file mode 100644 (file)
index 0000000..d3fb909
--- /dev/null
@@ -0,0 +1,296 @@
+#include "mathops.h"
+#include <limits.h>
+
+/*The fastest fallback strategy for platforms with fast multiplication appears
+   to be based on de Bruijn sequences~\cite{LP98}.
+  Tests confirmed this to be true even on an ARM11, where it is actually faster
+   than using the native clz instruction.
+  Define OC_ILOG_NODEBRUIJN to use a simpler fallback on platforms where
+   multiplication or table lookups are too expensive.
+
+  @UNPUBLISHED{LP98,
+    author="Charles E. Leiserson and Harald Prokop",
+    title="Using de {Bruijn} Sequences to Index a 1 in a Computer Word",
+    month=Jun,
+    year=1998,
+    note="\url{http://supertech.csail.mit.edu/papers/debruijn.pdf}"
+  }*/
+#if !defined(OC_ILOG_NODEBRUIJN)&& \
+ !defined(OC_CLZ32)||!defined(OC_CLZ64)&&LONG_MAX<9223372036854775807LL
+static const unsigned char OC_DEBRUIJN_IDX32[32]={
+   0, 1,28, 2,29,14,24, 3,30,22,20,15,25,17, 4, 8,
+  31,27,13,23,21,19,16, 7,26,12,18, 6,11, 5,10, 9
+};
+#endif
+
+int oc_ilog32(ogg_uint32_t _v){
+#if defined(OC_CLZ32)
+  return (OC_CLZ32_OFFS-OC_CLZ32(_v))&-!!_v;
+#else
+/*On a Pentium M, this branchless version tested as the fastest version without
+   multiplications on 1,000,000,000 random 32-bit integers, edging out a
+   similar version with branches, and a 256-entry LUT version.*/
+# if defined(OC_ILOG_NODEBRUIJN)
+  int ret;
+  int m;
+  ret=_v>0;
+  m=(_v>0xFFFFU)<<4;
+  _v>>=m;
+  ret|=m;
+  m=(_v>0xFFU)<<3;
+  _v>>=m;
+  ret|=m;
+  m=(_v>0xFU)<<2;
+  _v>>=m;
+  ret|=m;
+  m=(_v>3)<<1;
+  _v>>=m;
+  ret|=m;
+  ret+=_v>1;
+  return ret;
+/*This de Bruijn sequence version is faster if you have a fast multiplier.*/
+# else
+  int ret;
+  ret=_v>0;
+  _v|=_v>>1;
+  _v|=_v>>2;
+  _v|=_v>>4;
+  _v|=_v>>8;
+  _v|=_v>>16;
+  _v=(_v>>1)+1;
+  ret+=OC_DEBRUIJN_IDX32[_v*0x77CB531U>>27&0x1F];
+  return ret;
+# endif
+#endif
+}
+
+int oc_ilog64(ogg_int64_t _v){
+#if defined(OC_CLZ64)
+  return (OC_CLZ64_OFFS-OC_CLZ64(_v))&-!!_v;
+#else
+# if defined(OC_ILOG_NODEBRUIJN)
+  ogg_uint32_t v;
+  int          ret;
+  int          m;
+  ret=_v>0;
+  m=(_v>0xFFFFFFFFU)<<5;
+  v=(ogg_uint32_t)(_v>>m);
+  ret|=m;
+  m=(v>0xFFFFU)<<4;
+  v>>=m;
+  ret|=m;
+  m=(v>0xFFU)<<3;
+  v>>=m;
+  ret|=m;
+  m=(v>0xFU)<<2;
+  v>>=m;
+  ret|=m;
+  m=(v>3)<<1;
+  v>>=m;
+  ret|=m;
+  ret+=v>1;
+  return ret;
+# else
+/*If we don't have a 64-bit word, split it into two 32-bit halves.*/
+#  if LONG_MAX<9223372036854775807LL
+  ogg_uint32_t v;
+  int          ret;
+  int          m;
+  ret=_v>0;
+  m=(_v>0xFFFFFFFFU)<<5;
+  v=(ogg_uint32_t)(_v>>m);
+  ret|=m;
+  v|=v>>1;
+  v|=v>>2;
+  v|=v>>4;
+  v|=v>>8;
+  v|=v>>16;
+  v=(v>>1)+1;
+  ret+=OC_DEBRUIJN_IDX32[v*0x77CB531U>>27&0x1F];
+  return ret;
+/*Otherwise do it in one 64-bit operation.*/
+#  else
+  static const unsigned char OC_DEBRUIJN_IDX64[64]={
+     0, 1, 2, 7, 3,13, 8,19, 4,25,14,28, 9,34,20,40,
+     5,17,26,38,15,46,29,48,10,31,35,54,21,50,41,57,
+    63, 6,12,18,24,27,33,39,16,37,45,47,30,53,49,56,
+    62,11,23,32,36,44,52,55,61,22,43,51,60,42,59,58
+  };
+  int ret;
+  ret=_v>0;
+  _v|=_v>>1;
+  _v|=_v>>2;
+  _v|=_v>>4;
+  _v|=_v>>8;
+  _v|=_v>>16;
+  _v|=_v>>32;
+  _v=(_v>>1)+1;
+  ret+=OC_DEBRUIJN_IDX64[_v*0x218A392CD3D5DBF>>58&0x3F];
+  return ret;
+#  endif
+# endif
+#endif
+}
+
+/*round(2**(62+i)*atanh(2**(-(i+1)))/log(2))*/
+static const ogg_int64_t OC_ATANH_LOG2[32]={
+  0x32B803473F7AD0F4LL,0x2F2A71BD4E25E916LL,0x2E68B244BB93BA06LL,
+  0x2E39FB9198CE62E4LL,0x2E2E683F68565C8FLL,0x2E2B850BE2077FC1LL,
+  0x2E2ACC58FE7B78DBLL,0x2E2A9E2DE52FD5F2LL,0x2E2A92A338D53EECLL,
+  0x2E2A8FC08F5E19B6LL,0x2E2A8F07E51A485ELL,0x2E2A8ED9BA8AF388LL,
+  0x2E2A8ECE2FE7384ALL,0x2E2A8ECB4D3E4B1ALL,0x2E2A8ECA94940FE8LL,
+  0x2E2A8ECA6669811DLL,0x2E2A8ECA5ADEDD6ALL,0x2E2A8ECA57FC347ELL,
+  0x2E2A8ECA57438A43LL,0x2E2A8ECA57155FB4LL,0x2E2A8ECA5709D510LL,
+  0x2E2A8ECA5706F267LL,0x2E2A8ECA570639BDLL,0x2E2A8ECA57060B92LL,
+  0x2E2A8ECA57060008LL,0x2E2A8ECA5705FD25LL,0x2E2A8ECA5705FC6CLL,
+  0x2E2A8ECA5705FC3ELL,0x2E2A8ECA5705FC33LL,0x2E2A8ECA5705FC30LL,
+  0x2E2A8ECA5705FC2FLL,0x2E2A8ECA5705FC2FLL
+};
+
+/*Computes the binary exponential of _z, a log base 2 in Q57 format.*/
+ogg_int64_t oc_bexp64(ogg_int64_t _z){
+  ogg_int64_t w;
+  ogg_int64_t z;
+  int         ipart;
+  ipart=(int)(_z>>57);
+  if(ipart<0)return 0;
+  if(ipart>=63)return 0x7FFFFFFFFFFFFFFFLL;
+  z=_z-OC_Q57(ipart);
+  if(z){
+    ogg_int64_t mask;
+    long        wlo;
+    int         i;
+    /*C doesn't give us 64x64->128 muls, so we use CORDIC.
+      This is not particularly fast, but it's not being used in time-critical
+       code; it is very accurate.*/
+    /*z is the fractional part of the log in Q62 format.
+      We need 1 bit of headroom since the magnitude can get larger than 1
+       during the iteration, and a sign bit.*/
+    z<<=5;
+    /*w is the exponential in Q61 format (since it also needs headroom and can
+       get as large as 2.0); we could get another bit if we dropped the sign,
+       but we'll recover that bit later anyway.
+      Ideally this should start out as
+        \lim_{n->\infty} 2^{61}/\product_{i=1}^n \sqrt{1-2^{-2i}}
+       but in order to guarantee convergence we have to repeat iterations 4,
+        13 (=3*4+1), and 40 (=3*13+1, etc.), so it winds up somewhat larger.*/
+    w=0x26A3D0E401DD846DLL;
+    for(i=0;;i++){
+      mask=-(z<0);
+      w+=(w>>i+1)+mask^mask;
+      z-=OC_ATANH_LOG2[i]+mask^mask;
+      /*Repeat iteration 4.*/
+      if(i>=3)break;
+      z<<=1;
+    }
+    for(;;i++){
+      mask=-(z<0);
+      w+=(w>>i+1)+mask^mask;
+      z-=OC_ATANH_LOG2[i]+mask^mask;
+      /*Repeat iteration 13.*/
+      if(i>=12)break;
+      z<<=1;
+    }
+    for(;i<32;i++){
+      mask=-(z<0);
+      w+=(w>>i+1)+mask^mask;
+      z=z-(OC_ATANH_LOG2[i]+mask^mask)<<1;
+    }
+    wlo=0;
+    /*Skip the remaining iterations unless we really require that much
+       precision.
+      We could have bailed out earlier for smaller iparts, but that would
+       require initializing w from a table, as the limit doesn't converge to
+       61-bit precision until n=30.*/
+    if(ipart>30){
+      /*For these iterations, we just update the low bits, as the high bits
+         can't possibly be affected.
+        OC_ATANH_LOG2 has also converged (it actually did so one iteration
+         earlier, but that's no reason for an extra special case).*/
+      for(;;i++){
+        mask=-(z<0);
+        wlo+=(w>>i)+mask^mask;
+        z-=OC_ATANH_LOG2[31]+mask^mask;
+        /*Repeat iteration 40.*/
+        if(i>=39)break;
+        z<<=1;
+      }
+      for(;i<61;i++){
+        mask=-(z<0);
+        wlo+=(w>>i)+mask^mask;
+        z=z-(OC_ATANH_LOG2[31]+mask^mask)<<1;
+      }
+    }
+    w=(w<<1)+wlo;
+  }
+  else w=(ogg_int64_t)1<<62;
+  if(ipart<62)w=(w>>61-ipart)+1>>1;
+  return w;
+}
+
+/*Computes the binary logarithm of _w, returned in Q57 format.*/
+ogg_int64_t oc_blog64(ogg_int64_t _w){
+  ogg_int64_t z;
+  int         ipart;
+  if(_w<=0)return -1;
+  ipart=OC_ILOGNZ_64(_w)-1;
+  if(ipart>61)_w>>=ipart-61;
+  else _w<<=61-ipart;
+  z=0;
+  if(_w&_w-1){
+    ogg_int64_t x;
+    ogg_int64_t y;
+    ogg_int64_t u;
+    ogg_int64_t mask;
+    int         i;
+    /*C doesn't give us 64x64->128 muls, so we use CORDIC.
+      This is not particularly fast, but it's not being used in time-critical
+       code; it is very accurate.*/
+    /*z is the fractional part of the log in Q61 format.*/
+    /*x and y are the cosh() and sinh(), respectively, in Q61 format.
+      We are computing z=2*atanh(y/x)=2*atanh((_w-1)/(_w+1)).*/
+    x=_w+((ogg_int64_t)1<<61);
+    y=_w-((ogg_int64_t)1<<61);
+    for(i=0;i<4;i++){
+      mask=-(y<0);
+      z+=(OC_ATANH_LOG2[i]>>i)+mask^mask;
+      u=x>>i+1;
+      x-=(y>>i+1)+mask^mask;
+      y-=u+mask^mask;
+    }
+    /*Repeat iteration 4.*/
+    for(i--;i<13;i++){
+      mask=-(y<0);
+      z+=(OC_ATANH_LOG2[i]>>i)+mask^mask;
+      u=x>>i+1;
+      x-=(y>>i+1)+mask^mask;
+      y-=u+mask^mask;
+    }
+    /*Repeat iteration 13.*/
+    for(i--;i<32;i++){
+      mask=-(y<0);
+      z+=(OC_ATANH_LOG2[i]>>i)+mask^mask;
+      u=x>>i+1;
+      x-=(y>>i+1)+mask^mask;
+      y-=u+mask^mask;
+    }
+    /*OC_ATANH_LOG2 has converged.*/
+    for(;i<40;i++){
+      mask=-(y<0);
+      z+=(OC_ATANH_LOG2[31]>>i)+mask^mask;
+      u=x>>i+1;
+      x-=(y>>i+1)+mask^mask;
+      y-=u+mask^mask;
+    }
+    /*Repeat iteration 40.*/
+    for(i--;i<62;i++){
+      mask=-(y<0);
+      z+=(OC_ATANH_LOG2[31]>>i)+mask^mask;
+      u=x>>i+1;
+      x-=(y>>i+1)+mask^mask;
+      y-=u+mask^mask;
+    }
+    z=z+8>>4;
+  }
+  return OC_Q57(ipart)+z;
+}
diff --git a/lib/mathops.h b/lib/mathops.h
new file mode 100644 (file)
index 0000000..efbc537
--- /dev/null
@@ -0,0 +1,141 @@
+#if !defined(_mathops_H)
+# define _mathops_H (1)
+# include <ogg/ogg.h>
+
+# ifdef __GNUC_PREREQ
+#  if __GNUC_PREREQ(3,4)
+#   include <limits.h>
+/*Note the casts to (int) below: this prevents OC_CLZ{32|64}_OFFS from
+   "upgrading" the type of an entire expression to an (unsigned) size_t.*/
+#   if INT_MAX>=2147483647
+#    define OC_CLZ32_OFFS ((int)sizeof(unsigned)*CHAR_BIT)
+#    define OC_CLZ32(_x) (__builtin_clz(_x))
+#   elif LONG_MAX>=2147483647L
+#    define OC_CLZ32_OFFS ((int)sizeof(unsigned long)*CHAR_BIT)
+#    define OC_CLZ32(_x) (__builtin_clzl(_x))
+#   endif
+#   if INT_MAX>=9223372036854775807LL
+#    define OC_CLZ64_OFFS ((int)sizeof(unsigned)*CHAR_BIT)
+#    define OC_CLZ64(_x) (__builtin_clz(_x))
+#   elif LONG_MAX>=9223372036854775807LL
+#    define OC_CLZ64_OFFS ((int)sizeof(unsigned long)*CHAR_BIT)
+#    define OC_CLZ64(_x) (__builtin_clzl(_x))
+#   elif LLONG_MAX>=9223372036854775807LL|| \
+     __LONG_LONG_MAX__>=9223372036854775807LL
+#    define OC_CLZ64_OFFS ((int)sizeof(unsigned long long)*CHAR_BIT)
+#    define OC_CLZ64(_x) (__builtin_clzll(_x))
+#   endif
+#  endif
+# endif
+
+
+
+/**
+ * oc_ilog32 - Integer binary logarithm of a 32-bit value.
+ * @_v: A 32-bit value.
+ * Returns floor(log2(_v))+1, or 0 if _v==0.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ * The OC_ILOG_32() or OC_ILOGNZ_32() macros may be able to use a builtin
+ *  function instead, which should be faster.
+ */
+int oc_ilog32(ogg_uint32_t _v);
+/**
+ * oc_ilog64 - Integer binary logarithm of a 64-bit value.
+ * @_v: A 64-bit value.
+ * Returns floor(log2(_v))+1, or 0 if _v==0.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ * The OC_ILOG_64() or OC_ILOGNZ_64() macros may be able to use a builtin
+ *  function instead, which should be faster.
+ */
+int oc_ilog64(ogg_int64_t _v);
+
+
+# if defined(OC_CLZ32)
+/**
+ * OC_ILOGNZ_32 - Integer binary logarithm of a non-zero 32-bit value.
+ * @_v: A non-zero 32-bit value.
+ * Returns floor(log2(_v))+1.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ * If _v is zero, the return value is undefined; use OC_ILOG_32() instead.
+ */
+#  define OC_ILOGNZ_32(_v) (OC_CLZ32_OFFS-OC_CLZ32(_v))
+/**
+ * OC_ILOG_32 - Integer binary logarithm of a 32-bit value.
+ * @_v: A 32-bit value.
+ * Returns floor(log2(_v))+1, or 0 if _v==0.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ */
+#  define OC_ILOG_32(_v)   (OC_ILOGNZ_32(_v)&-!!(_v))
+# else
+#  define OC_ILOGNZ_32(_v) (oc_ilog32(_v))
+#  define OC_ILOG_32(_v)   (oc_ilog32(_v))
+# endif
+
+# if defined(CLZ64)
+/**
+ * OC_ILOGNZ_64 - Integer binary logarithm of a non-zero 64-bit value.
+ * @_v: A non-zero 64-bit value.
+ * Returns floor(log2(_v))+1.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ * If _v is zero, the return value is undefined; use OC_ILOG_64() instead.
+ */
+#  define OC_ILOGNZ_64(_v) (CLZ64_OFFS-CLZ64(_v))
+/**
+ * OC_ILOG_64 - Integer binary logarithm of a 64-bit value.
+ * @_v: A 64-bit value.
+ * Returns floor(log2(_v))+1, or 0 if _v==0.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ */
+#  define OC_ILOG_64(_v)   (OC_ILOGNZ_64(_v)&-!!(_v))
+# else
+#  define OC_ILOGNZ_64(_v) (oc_ilog64(_v))
+#  define OC_ILOG_64(_v)   (oc_ilog64(_v))
+# endif
+
+# define OC_STATIC_ILOG0(_v) (!!(_v))
+# define OC_STATIC_ILOG1(_v) (((_v)&0x2)?2:OC_STATIC_ILOG0(_v))
+# define OC_STATIC_ILOG2(_v) \
+ (((_v)&0xC)?2+OC_STATIC_ILOG1((_v)>>2):OC_STATIC_ILOG1(_v))
+# define OC_STATIC_ILOG3(_v) \
+ (((_v)&0xF0)?4+OC_STATIC_ILOG2((_v)>>4):OC_STATIC_ILOG2(_v))
+# define OC_STATIC_ILOG4(_v) \
+ (((_v)&0xFF00)?8+OC_STATIC_ILOG3((_v)>>8):OC_STATIC_ILOG3(_v))
+# define OC_STATIC_ILOG5(_v) \
+ (((_v)&0xFFFF0000)?16+OC_STATIC_ILOG4((_v)>>16):OC_STATIC_ILOG4(_v))
+# define OC_STATIC_ILOG6(_v) \
+ (((_v)&0xFFFFFFFF00000000ULL)?32+OC_STATIC_ILOG5((_v)>>32):OC_STATIC_ILOG5(_v))
+/**
+ * OC_STATIC_ILOG_32 - The integer logarithm of an (unsigned, 32-bit) constant.
+ * @_v: A non-negative 32-bit constant.
+ * Returns floor(log2(_v))+1, or 0 if _v==0.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ * This macro is suitable for evaluation at compile time, but it should not be
+ *  used on values that can change at runtime, as it operates via exhaustive
+ *  search.
+ */
+# define OC_STATIC_ILOG_32(_v) (OC_STATIC_ILOG5((ogg_uint32_t)(_v)))
+/**
+ * OC_STATIC_ILOG_64 - The integer logarithm of an (unsigned, 64-bit) constant.
+ * @_v: A non-negative 64-bit constant.
+ * Returns floor(log2(_v))+1, or 0 if _v==0.
+ * This is the number of bits that would be required to represent _v in two's
+ *  complement notation with all of the leading zeros stripped.
+ * This macro is suitable for evaluation at compile time, but it should not be
+ *  used on values that can change at runtime, as it operates via exhaustive
+ *  search.
+ */
+# define OC_STATIC_ILOG_64(_v) (OC_STATIC_ILOG6((ogg_int64_t)(_v)))
+
+#define OC_Q57(_v) ((ogg_int64_t)(_v)<<57)
+
+ogg_int64_t oc_bexp64(ogg_int64_t _z);
+ogg_int64_t oc_blog64(ogg_int64_t _w);
+
+#endif
diff --git a/lib/mcenc.c b/lib/mcenc.c
new file mode 100644 (file)
index 0000000..797e81f
--- /dev/null
@@ -0,0 +1,767 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id$
+
+ ********************************************************************/
+#include <stdlib.h>
+#include <limits.h>
+#include <string.h>
+#include "encint.h"
+
+
+
+typedef struct oc_mcenc_ctx           oc_mcenc_ctx;
+
+
+
+/*Temporary state used for motion estimation.*/
+struct oc_mcenc_ctx{
+  /*The candidate motion vectors.*/
+  int                candidates[13][2];
+  /*The start of the Set B candidates.*/
+  int                setb0;
+  /*The total number of candidates.*/
+  int                ncandidates;
+};
+
+
+
+/*The maximum Y plane SAD value for accepting the median predictor.*/
+#define OC_YSAD_THRESH1            (256)
+/*The amount to right shift the minimum error by when inflating it for
+   computing the second maximum Y plane SAD threshold.*/
+#define OC_YSAD_THRESH2_SCALE_BITS (4)
+/*The amount to add to the second maximum Y plane threshold when inflating
+   it.*/
+#define OC_YSAD_THRESH2_OFFSET     (64)
+
+/*The vector offsets in the X direction for each search site in the square
+   pattern.*/
+static const int OC_SQUARE_DX[9]={-1,0,1,-1,0,1,-1,0,1};
+/*The vector offsets in the Y direction for each search site in the square
+   pattern.*/
+static const int OC_SQUARE_DY[9]={-1,-1,-1,0,0,0,1,1,1};
+/*The number of sites to search for each boundary condition in the square
+   pattern.
+  Bit flags for the boundary conditions are as follows:
+  1: -16==dx
+  2:      dx==15(.5)
+  4: -16==dy
+  8:      dy==15(.5)*/
+static const int OC_SQUARE_NSITES[11]={8,5,5,0,5,3,3,0,5,3,3};
+/*The list of sites to search for each boundary condition in the square
+   pattern.*/
+static const int OC_SQUARE_SITES[11][8]={
+  /* -15.5<dx<31,       -15.5<dy<15(.5)*/
+  {0,1,2,3,5,6,7,8},
+  /*-15.5==dx,          -15.5<dy<15(.5)*/
+  {1,2,5,7,8},
+  /*     dx==15(.5),    -15.5<dy<15(.5)*/
+  {0,1,3,6,7},
+  /*-15.5==dx==15(.5),  -15.5<dy<15(.5)*/
+  {-1},
+  /* -15.5<dx<15(.5),  -15.5==dy*/
+  {3,5,6,7,8},
+  /*-15.5==dx,         -15.5==dy*/
+  {5,7,8},
+  /*     dx==15(.5),   -15.5==dy*/
+  {3,6,7},
+  /*-15.5==dx==15(.5), -15.5==dy*/
+  {-1},
+  /*-15.5dx<15(.5),           dy==15(.5)*/
+  {0,1,2,3,5},
+  /*-15.5==dx,                dy==15(.5)*/
+  {1,2,5},
+  /*       dx==15(.5),        dy==15(.5)*/
+  {0,1,3}
+};
+
+
+static void oc_mcenc_find_candidates(oc_enc_ctx *_enc,oc_mcenc_ctx *_mcenc,
+ int _accum[2],int _mbi,int _frame){
+  oc_mb_enc_info *embs;
+  int             a[3][2];
+  int             ncandidates;
+  unsigned        nmbi;
+  int             i;
+  embs=_enc->mb_info;
+  /*Skip a position to store the median predictor in.*/
+  ncandidates=1;
+  if(embs[_mbi].ncneighbors>0){
+    /*Fill in the first part of set A: the vectors from adjacent blocks.*/
+    for(i=0;i<embs[_mbi].ncneighbors;i++){
+      nmbi=embs[_mbi].cneighbors[i];
+      _mcenc->candidates[ncandidates][0]=embs[nmbi].analysis_mv[0][_frame][0];
+      _mcenc->candidates[ncandidates][1]=embs[nmbi].analysis_mv[0][_frame][1];
+      ncandidates++;
+    }
+  }
+  /*Add a few additional vectors to set A: the vectors used in the previous
+     frames and the (0,0) vector.*/
+  _mcenc->candidates[ncandidates][0]=OC_CLAMPI(-31,_accum[0],31);
+  _mcenc->candidates[ncandidates][1]=OC_CLAMPI(-31,_accum[1],31);
+  ncandidates++;
+  _mcenc->candidates[ncandidates][0]=OC_CLAMPI(-31,
+   embs[_mbi].analysis_mv[1][_frame][0]+_accum[0],31);
+  _mcenc->candidates[ncandidates][1]=OC_CLAMPI(-31,
+   embs[_mbi].analysis_mv[1][_frame][1]+_accum[1],31);
+  ncandidates++;
+  _mcenc->candidates[ncandidates][0]=0;
+  _mcenc->candidates[ncandidates][1]=0;
+  ncandidates++;
+  /*Use the first three vectors of set A to find our best predictor: their
+     median.*/
+  memcpy(a,_mcenc->candidates+1,sizeof(a));
+  OC_SORT2I(a[0][0],a[1][0]);
+  OC_SORT2I(a[0][1],a[1][1]);
+  OC_SORT2I(a[1][0],a[2][0]);
+  OC_SORT2I(a[1][1],a[2][1]);
+  OC_SORT2I(a[0][0],a[1][0]);
+  OC_SORT2I(a[0][1],a[1][1]);
+  _mcenc->candidates[0][0]=a[1][0];
+  _mcenc->candidates[0][1]=a[1][1];
+  /*Fill in set B: accelerated predictors for this and adjacent macro blocks.*/
+  _mcenc->setb0=ncandidates;
+  /*The first time through the loop use the current macro block.*/
+  nmbi=_mbi;
+  for(i=0;;i++){
+    _mcenc->candidates[ncandidates][0]=OC_CLAMPI(-31,
+     2*embs[_mbi].analysis_mv[1][_frame][0]
+     -embs[_mbi].analysis_mv[2][_frame][0]+_accum[0],31);
+    _mcenc->candidates[ncandidates][1]=OC_CLAMPI(-31,
+     2*embs[_mbi].analysis_mv[1][_frame][1]
+     -embs[_mbi].analysis_mv[2][_frame][1]+_accum[1],31);
+    ncandidates++;
+    if(i>=embs[_mbi].npneighbors)break;
+    nmbi=embs[_mbi].pneighbors[i];
+  }
+  /*Truncate to full-pel positions.*/
+  for(i=0;i<ncandidates;i++){
+    _mcenc->candidates[i][0]=OC_DIV2(_mcenc->candidates[i][0]);
+    _mcenc->candidates[i][1]=OC_DIV2(_mcenc->candidates[i][1]);
+  }
+  _mcenc->ncandidates=ncandidates;
+}
+
+#if 0
+static unsigned oc_sad16_halfpel(const oc_enc_ctx *_enc,
+ const ptrdiff_t *_frag_buf_offs,const ptrdiff_t _fragis[4],
+ int _mvoffset0,int _mvoffset1,const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _best_err){
+  unsigned err;
+  int      bi;
+  err=0;
+  for(bi=0;bi<4;bi++){
+    ptrdiff_t frag_offs;
+    frag_offs=_frag_buf_offs[_fragis[bi]];
+    err+=oc_enc_frag_sad2_thresh(_enc,_src+frag_offs,_ref+frag_offs+_mvoffset0,
+     _ref+frag_offs+_mvoffset1,_ystride,_best_err-err);
+  }
+  return err;
+}
+#endif
+
+static unsigned oc_satd16_halfpel(const oc_enc_ctx *_enc,
+ const ptrdiff_t *_frag_buf_offs,const ptrdiff_t _fragis[4],
+ int _mvoffset0,int _mvoffset1,const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _best_err){
+  unsigned err;
+  int      bi;
+  err=0;
+  for(bi=0;bi<4;bi++){
+    ptrdiff_t frag_offs;
+    frag_offs=_frag_buf_offs[_fragis[bi]];
+    err+=oc_enc_frag_satd2_thresh(_enc,_src+frag_offs,_ref+frag_offs+_mvoffset0,
+     _ref+frag_offs+_mvoffset1,_ystride,_best_err-err);
+  }
+  return err;
+}
+
+static unsigned oc_mcenc_ysad_check_mbcandidate_fullpel(const oc_enc_ctx *_enc,
+ const ptrdiff_t *_frag_buf_offs,const ptrdiff_t _fragis[4],int _dx,int _dy,
+ const unsigned char *_src,const unsigned char *_ref,int _ystride,
+ unsigned _block_err[4]){
+  unsigned err;
+  int      mvoffset;
+  int      bi;
+  mvoffset=_dx+_dy*_ystride;
+  err=0;
+  for(bi=0;bi<4;bi++){
+    ptrdiff_t frag_offs;
+    unsigned  block_err;
+    frag_offs=_frag_buf_offs[_fragis[bi]];
+    block_err=oc_enc_frag_sad(_enc,
+     _src+frag_offs,_ref+frag_offs+mvoffset,_ystride);
+    _block_err[bi]=block_err;
+    err+=block_err;
+  }
+  return err;
+}
+
+static int oc_mcenc_ysatd_check_mbcandidate_fullpel(const oc_enc_ctx *_enc,
+ const ptrdiff_t *_frag_buf_offs,const ptrdiff_t _fragis[4],int _dx,int _dy,
+ const unsigned char *_src,const unsigned char *_ref,int _ystride){
+  int mvoffset;
+  int err;
+  int bi;
+  mvoffset=_dx+_dy*_ystride;
+  err=0;
+  for(bi=0;bi<4;bi++){
+    ptrdiff_t frag_offs;
+    frag_offs=_frag_buf_offs[_fragis[bi]];
+    err+=oc_enc_frag_satd_thresh(_enc,
+     _src+frag_offs,_ref+frag_offs+mvoffset,_ystride,UINT_MAX);
+  }
+  return err;
+}
+
+static unsigned oc_mcenc_ysatd_check_bcandidate_fullpel(const oc_enc_ctx *_enc,
+ ptrdiff_t _frag_offs,int _dx,int _dy,
+ const unsigned char *_src,const unsigned char *_ref,int _ystride){
+  return oc_enc_frag_satd_thresh(_enc,
+   _src+_frag_offs,_ref+_frag_offs+_dx+_dy*_ystride,_ystride,UINT_MAX);
+}
+
+/*Perform a motion vector search for this macro block against a single
+   reference frame.
+  As a bonus, individual block motion vectors are computed as well, as much of
+   the work can be shared.
+  The actual motion vector is stored in the appropriate place in the
+   oc_mb_enc_info structure.
+  _mcenc:    The motion compensation context.
+  _accum:    Drop frame/golden MV accumulators.
+  _mbi:      The macro block index.
+  _frame:    The frame to search, either OC_FRAME_PREV or OC_FRAME_GOLD.*/
+void oc_mcenc_search_frame(oc_enc_ctx *_enc,int _accum[2],int _mbi,int _frame){
+  /*Note: Traditionally this search is done using a rate-distortion objective
+     function of the form D+lambda*R.
+    However, xiphmont tested this and found it produced a small degredation,
+     while requiring extra computation.
+    This is most likely due to Theora's peculiar MV encoding scheme: MVs are
+     not coded relative to a predictor, and the only truly cheap way to use a
+     MV is in the LAST or LAST2 MB modes, which are not being considered here.
+    Therefore if we use the MV found here, it's only because both LAST and
+     LAST2 performed poorly, and therefore the MB is not likely to be uniform
+     or suffer from the aperture problem.
+    Furthermore we would like to re-use the MV found here for as many MBs as
+     possible, so picking a slightly sub-optimal vector to save a bit or two
+     may cause increased degredation in many blocks to come.
+    We could artificially reduce lambda to compensate, but it's faster to just
+     disable it entirely, and use D (the distortion) as the sole criterion.*/
+  oc_mcenc_ctx         mcenc;
+  const ptrdiff_t     *frag_buf_offs;
+  const ptrdiff_t     *fragis;
+  const unsigned char *src;
+  const unsigned char *ref;
+  int                  ystride;
+  oc_mb_enc_info      *embs;
+  ogg_int32_t          hit_cache[31];
+  ogg_int32_t          hitbit;
+  unsigned             best_block_err[4];
+  unsigned             block_err[4];
+  unsigned             best_err;
+  int                  best_vec[2];
+  int                  best_block_vec[4][2];
+  int                  candx;
+  int                  candy;
+  int                  bi;
+  embs=_enc->mb_info;
+  /*Find some candidate motion vectors.*/
+  oc_mcenc_find_candidates(_enc,&mcenc,_accum,_mbi,_frame);
+  /*Clear the cache of locations we've examined.*/
+  memset(hit_cache,0,sizeof(hit_cache));
+  /*Start with the median predictor.*/
+  candx=mcenc.candidates[0][0];
+  candy=mcenc.candidates[0][1];
+  hit_cache[candy+15]|=(ogg_int32_t)1<<candx+15;
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  fragis=_enc->state.mb_maps[_mbi][0];
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ref=_enc->state.ref_frame_data[_enc->state.ref_frame_idx[_frame]];
+  ystride=_enc->state.ref_ystride[0];
+  /*TODO: customize error function for speed/(quality+size) tradeoff.*/
+  best_err=oc_mcenc_ysad_check_mbcandidate_fullpel(_enc,
+   frag_buf_offs,fragis,candx,candy,src,ref,ystride,block_err);
+  best_vec[0]=candx;
+  best_vec[1]=candy;
+  if(_frame==OC_FRAME_PREV){
+    for(bi=0;bi<4;bi++){
+      best_block_err[bi]=block_err[bi];
+      best_block_vec[bi][0]=candx;
+      best_block_vec[bi][1]=candy;
+    }
+  }
+  /*If this predictor fails, move on to set A.*/
+  if(best_err>OC_YSAD_THRESH1){
+    unsigned err;
+    unsigned t2;
+    int      ncs;
+    int      ci;
+    /*Compute the early termination threshold for set A.*/
+    t2=embs[_mbi].error[_frame];
+    ncs=OC_MINI(3,embs[_mbi].ncneighbors);
+    for(ci=0;ci<ncs;ci++){
+      t2=OC_MAXI(t2,embs[embs[_mbi].cneighbors[ci]].error[_frame]);
+    }
+    t2+=(t2>>OC_YSAD_THRESH2_SCALE_BITS)+OC_YSAD_THRESH2_OFFSET;
+    /*Examine the candidates in set A.*/
+    for(ci=1;ci<mcenc.setb0;ci++){
+      candx=mcenc.candidates[ci][0];
+      candy=mcenc.candidates[ci][1];
+      /*If we've already examined this vector, then we would be using it if it
+         was better than what we are using.*/
+      hitbit=(ogg_int32_t)1<<candx+15;
+      if(hit_cache[candy+15]&hitbit)continue;
+      hit_cache[candy+15]|=hitbit;
+      err=oc_mcenc_ysad_check_mbcandidate_fullpel(_enc,
+       frag_buf_offs,fragis,candx,candy,src,ref,ystride,block_err);
+      if(err<best_err){
+        best_err=err;
+        best_vec[0]=candx;
+        best_vec[1]=candy;
+      }
+      if(_frame==OC_FRAME_PREV){
+        for(bi=0;bi<4;bi++)if(block_err[bi]<best_block_err[bi]){
+          best_block_err[bi]=block_err[bi];
+          best_block_vec[bi][0]=candx;
+          best_block_vec[bi][1]=candy;
+        }
+      }
+    }
+    if(best_err>t2){
+      /*Examine the candidates in set B.*/
+      for(;ci<mcenc.ncandidates;ci++){
+        candx=mcenc.candidates[ci][0];
+        candy=mcenc.candidates[ci][1];
+        hitbit=(ogg_int32_t)1<<candx+15;
+        if(hit_cache[candy+15]&hitbit)continue;
+        hit_cache[candy+15]|=hitbit;
+        err=oc_mcenc_ysad_check_mbcandidate_fullpel(_enc,
+         frag_buf_offs,fragis,candx,candy,src,ref,ystride,block_err);
+        if(err<best_err){
+          best_err=err;
+          best_vec[0]=candx;
+          best_vec[1]=candy;
+        }
+        if(_frame==OC_FRAME_PREV){
+          for(bi=0;bi<4;bi++)if(block_err[bi]<best_block_err[bi]){
+            best_block_err[bi]=block_err[bi];
+            best_block_vec[bi][0]=candx;
+            best_block_vec[bi][1]=candy;
+          }
+        }
+      }
+      /*Use the same threshold for set B as in set A.*/
+      if(best_err>t2){
+        int best_site;
+        int nsites;
+        int sitei;
+        int site;
+        int b;
+        /*Square pattern search.*/
+        for(;;){
+          best_site=4;
+          /*Compose the bit flags for boundary conditions.*/
+          b=OC_DIV16(-best_vec[0]+1)|OC_DIV16(best_vec[0]+1)<<1|
+           OC_DIV16(-best_vec[1]+1)<<2|OC_DIV16(best_vec[1]+1)<<3;
+          nsites=OC_SQUARE_NSITES[b];
+          for(sitei=0;sitei<nsites;sitei++){
+            site=OC_SQUARE_SITES[b][sitei];
+            candx=best_vec[0]+OC_SQUARE_DX[site];
+            candy=best_vec[1]+OC_SQUARE_DY[site];
+            hitbit=(ogg_int32_t)1<<candx+15;
+            if(hit_cache[candy+15]&hitbit)continue;
+            hit_cache[candy+15]|=hitbit;
+            err=oc_mcenc_ysad_check_mbcandidate_fullpel(_enc,
+             frag_buf_offs,fragis,candx,candy,src,ref,ystride,block_err);
+            if(err<best_err){
+              best_err=err;
+              best_site=site;
+            }
+            if(_frame==OC_FRAME_PREV){
+              for(bi=0;bi<4;bi++)if(block_err[bi]<best_block_err[bi]){
+                best_block_err[bi]=block_err[bi];
+                best_block_vec[bi][0]=candx;
+                best_block_vec[bi][1]=candy;
+              }
+            }
+          }
+          if(best_site==4)break;
+          best_vec[0]+=OC_SQUARE_DX[best_site];
+          best_vec[1]+=OC_SQUARE_DY[best_site];
+        }
+        /*Final 4-MV search.*/
+        /*Simply use 1/4 of the macro block set A and B threshold as the
+           individual block threshold.*/
+        if(_frame==OC_FRAME_PREV){
+          t2>>=2;
+          for(bi=0;bi<4;bi++){
+            if(best_block_err[bi]>t2){
+              /*Square pattern search.
+                We do this in a slightly interesting manner.
+                We continue to check the SAD of all four blocks in the
+                 macro block.
+                This gives us two things:
+                 1) We can continue to use the hit_cache to avoid duplicate
+                     checks.
+                    Otherwise we could continue to read it, but not write to it
+                     without saving and restoring it for each block.
+                    Note that we could still eliminate a large number of
+                     duplicate checks by taking into account the site we came
+                     from when choosing the site list.
+                    We can still do that to avoid extra hit_cache queries, and
+                     it might even be a speed win.
+                 2) It gives us a slightly better chance of escaping local
+                     minima.
+                    We would not be here if we weren't doing a fairly bad job
+                     in finding a good vector, and checking these vectors can
+                     save us from 100 to several thousand points off our SAD 1
+                     in 15 times.
+                TODO: Is this a good idea?
+                Who knows.
+                It needs more testing.*/
+              for(;;){
+                int bestx;
+                int besty;
+                int bj;
+                bestx=best_block_vec[bi][0];
+                besty=best_block_vec[bi][1];
+                /*Compose the bit flags for boundary conditions.*/
+                b=OC_DIV16(-bestx+1)|OC_DIV16(bestx+1)<<1|
+                 OC_DIV16(-besty+1)<<2|OC_DIV16(besty+1)<<3;
+                nsites=OC_SQUARE_NSITES[b];
+                for(sitei=0;sitei<nsites;sitei++){
+                  site=OC_SQUARE_SITES[b][sitei];
+                  candx=bestx+OC_SQUARE_DX[site];
+                  candy=besty+OC_SQUARE_DY[site];
+                  hitbit=(ogg_int32_t)1<<candx+15;
+                  if(hit_cache[candy+15]&hitbit)continue;
+                  hit_cache[candy+15]|=hitbit;
+                  err=oc_mcenc_ysad_check_mbcandidate_fullpel(_enc,
+                   frag_buf_offs,fragis,candx,candy,src,ref,ystride,block_err);
+                  if(err<best_err){
+                    best_err=err;
+                    best_vec[0]=candx;
+                    best_vec[1]=candy;
+                  }
+                  for(bj=0;bj<4;bj++)if(block_err[bj]<best_block_err[bj]){
+                    best_block_err[bj]=block_err[bj];
+                    best_block_vec[bj][0]=candx;
+                    best_block_vec[bj][1]=candy;
+                  }
+                }
+                if(best_block_vec[bi][0]==bestx&&best_block_vec[bi][1]==besty){
+                  break;
+                }
+              }
+            }
+          }
+        }
+      }
+    }
+  }
+  embs[_mbi].error[_frame]=(ogg_uint16_t)best_err;
+  candx=best_vec[0];
+  candy=best_vec[1];
+  embs[_mbi].satd[_frame]=oc_mcenc_ysatd_check_mbcandidate_fullpel(_enc,
+   frag_buf_offs,fragis,candx,candy,src,ref,ystride);
+  embs[_mbi].analysis_mv[0][_frame][0]=(signed char)(candx<<1);
+  embs[_mbi].analysis_mv[0][_frame][1]=(signed char)(candy<<1);
+  if(_frame==OC_FRAME_PREV){
+    for(bi=0;bi<4;bi++){
+      candx=best_block_vec[bi][0];
+      candy=best_block_vec[bi][1];
+      embs[_mbi].block_satd[bi]=oc_mcenc_ysatd_check_bcandidate_fullpel(_enc,
+       frag_buf_offs[fragis[bi]],candx,candy,src,ref,ystride);
+      embs[_mbi].block_mv[bi][0]=(signed char)(candx<<1);
+      embs[_mbi].block_mv[bi][1]=(signed char)(candy<<1);
+    }
+  }
+}
+
+void oc_mcenc_search(oc_enc_ctx *_enc,int _mbi){
+  oc_mv2         *mvs;
+  int             accum_p[2];
+  int             accum_g[2];
+  mvs=_enc->mb_info[_mbi].analysis_mv;
+  if(_enc->prevframe_dropped){
+    accum_p[0]=mvs[0][OC_FRAME_PREV][0];
+    accum_p[1]=mvs[0][OC_FRAME_PREV][1];
+  }
+  else accum_p[1]=accum_p[0]=0;
+  accum_g[0]=mvs[2][OC_FRAME_GOLD][0];
+  accum_g[1]=mvs[2][OC_FRAME_GOLD][1];
+  mvs[0][OC_FRAME_PREV][0]-=mvs[2][OC_FRAME_PREV][0];
+  mvs[0][OC_FRAME_PREV][1]-=mvs[2][OC_FRAME_PREV][1];
+  /*Move the motion vector predictors back a frame.*/
+  memmove(mvs+1,mvs,2*sizeof(*mvs));
+  /*Search the last frame.*/
+  oc_mcenc_search_frame(_enc,accum_p,_mbi,OC_FRAME_PREV);
+  mvs[2][OC_FRAME_PREV][0]=accum_p[0];
+  mvs[2][OC_FRAME_PREV][1]=accum_p[1];
+  /*GOLDEN MVs are different from PREV MVs in that they're each absolute
+     offsets from some frame in the past rather than relative offsets from the
+     frame before.
+    For predictor calculation to make sense, we need them to be in the same
+     form as PREV MVs.*/
+  mvs[1][OC_FRAME_GOLD][0]-=mvs[2][OC_FRAME_GOLD][0];
+  mvs[1][OC_FRAME_GOLD][1]-=mvs[2][OC_FRAME_GOLD][1];
+  mvs[2][OC_FRAME_GOLD][0]-=accum_g[0];
+  mvs[2][OC_FRAME_GOLD][1]-=accum_g[1];
+  /*Search the golden frame.*/
+  oc_mcenc_search_frame(_enc,accum_g,_mbi,OC_FRAME_GOLD);
+  /*Put GOLDEN MVs back into absolute offset form.
+    The newest MV is already an absolute offset.*/
+  mvs[2][OC_FRAME_GOLD][0]+=accum_g[0];
+  mvs[2][OC_FRAME_GOLD][1]+=accum_g[1];
+  mvs[1][OC_FRAME_GOLD][0]+=mvs[2][OC_FRAME_GOLD][0];
+  mvs[1][OC_FRAME_GOLD][1]+=mvs[2][OC_FRAME_GOLD][1];
+}
+
+#if 0
+static int oc_mcenc_ysad_halfpel_mbrefine(const oc_enc_ctx *_enc,int _mbi,
+ int _vec[2],int _best_err,int _frame){
+  const unsigned char *src;
+  const unsigned char *ref;
+  const ptrdiff_t     *frag_buf_offs;
+  const ptrdiff_t     *fragis;
+  int                  offset_y[9];
+  int                  ystride;
+  int                  mvoffset_base;
+  int                  best_site;
+  int                  sitei;
+  int                  err;
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ref=_enc->state.ref_frame_data[_enc->state.ref_frame_idx[_framei]];
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  fragis=_enc->state.mb_maps[_mbi][0];
+  ystride=_enc->state.ref_ystride[0];
+  mvoffset_base=_vec[0]+_vec[1]*ystride;
+  offset_y[0]=offset_y[1]=offset_y[2]=-ystride;
+  offset_y[3]=offset_y[5]=0;
+  offset_y[6]=offset_y[7]=offset_y[8]=ystride;
+  best_site=4;
+  for(sitei=0;sitei<8;sitei++){
+    int site;
+    int xmask;
+    int ymask;
+    int dx;
+    int dy;
+    int mvoffset0;
+    int mvoffset1;
+    site=OC_SQUARE_SITES[0][sitei];
+    dx=OC_SQUARE_DX[site];
+    dy=OC_SQUARE_DY[site];
+    /*The following code SHOULD be equivalent to
+        oc_state_get_mv_offsets(&_mcenc->enc.state,&mvoffset0,&mvoffset1,
+         (_vec[0]<<1)+dx,(_vec[1]<<1)+dy,ref_ystride,0);
+      However, it should also be much faster, as it involves no multiplies and
+       doesn't have to handle chroma vectors.*/
+    xmask=OC_SIGNMASK(((_vec[0]<<1)+dx)^dx);
+    ymask=OC_SIGNMASK(((_vec[1]<<1)+dy)^dy);
+    mvoffset0=mvoffset_base+(dx&xmask)+(offset_y[site]&ymask);
+    mvoffset1=mvoffset_base+(dx&~xmask)+(offset_y[site]&~ymask);
+    err=oc_sad16_halfpel(_enc,frag_buf_offs,fragis,
+     mvoffset0,mvoffset1,src,ref,ystride,_best_err);
+    if(err<_best_err){
+      _best_err=err;
+      best_site=site;
+    }
+  }
+  _vec[0]=(_vec[0]<<1)+OC_SQUARE_DX[best_site];
+  _vec[1]=(_vec[1]<<1)+OC_SQUARE_DY[best_site];
+  return _best_err;
+}
+#endif
+
+static unsigned oc_mcenc_ysatd_halfpel_mbrefine(const oc_enc_ctx *_enc,
+ int _mbi,int _vec[2],unsigned _best_err,int _frame){
+  const unsigned char *src;
+  const unsigned char *ref;
+  const ptrdiff_t     *frag_buf_offs;
+  const ptrdiff_t     *fragis;
+  int                  offset_y[9];
+  int                  ystride;
+  int                  mvoffset_base;
+  int                  best_site;
+  int                  sitei;
+  int                  err;
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ref=_enc->state.ref_frame_data[_enc->state.ref_frame_idx[_frame]];
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  fragis=_enc->state.mb_maps[_mbi][0];
+  ystride=_enc->state.ref_ystride[0];
+  mvoffset_base=_vec[0]+_vec[1]*ystride;
+  offset_y[0]=offset_y[1]=offset_y[2]=-ystride;
+  offset_y[3]=offset_y[5]=0;
+  offset_y[6]=offset_y[7]=offset_y[8]=ystride;
+  best_site=4;
+  for(sitei=0;sitei<8;sitei++){
+    int site;
+    int xmask;
+    int ymask;
+    int dx;
+    int dy;
+    int mvoffset0;
+    int mvoffset1;
+    site=OC_SQUARE_SITES[0][sitei];
+    dx=OC_SQUARE_DX[site];
+    dy=OC_SQUARE_DY[site];
+    /*The following code SHOULD be equivalent to
+        oc_state_get_mv_offsets(&_mcenc->enc.state,&mvoffset0,&mvoffset1,
+         (_vec[0]<<1)+dx,(_vec[1]<<1)+dy,ref_ystride,0);
+      However, it should also be much faster, as it involves no multiplies and
+       doesn't have to handle chroma vectors.*/
+    xmask=OC_SIGNMASK(((_vec[0]<<1)+dx)^dx);
+    ymask=OC_SIGNMASK(((_vec[1]<<1)+dy)^dy);
+    mvoffset0=mvoffset_base+(dx&xmask)+(offset_y[site]&ymask);
+    mvoffset1=mvoffset_base+(dx&~xmask)+(offset_y[site]&~ymask);
+    err=oc_satd16_halfpel(_enc,frag_buf_offs,fragis,
+     mvoffset0,mvoffset1,src,ref,ystride,_best_err);
+    if(err<_best_err){
+      _best_err=err;
+      best_site=site;
+    }
+  }
+  _vec[0]=(_vec[0]<<1)+OC_SQUARE_DX[best_site];
+  _vec[1]=(_vec[1]<<1)+OC_SQUARE_DY[best_site];
+  return _best_err;
+}
+
+void oc_mcenc_refine1mv(oc_enc_ctx *_enc,int _mbi,int _frame){
+  oc_mb_enc_info *embs;
+  int             vec[2];
+  embs=_enc->mb_info;
+  vec[0]=OC_DIV2(embs[_mbi].analysis_mv[0][_frame][0]);
+  vec[1]=OC_DIV2(embs[_mbi].analysis_mv[0][_frame][1]);
+  embs[_mbi].satd[_frame]=oc_mcenc_ysatd_halfpel_mbrefine(_enc,
+   _mbi,vec,embs[_mbi].satd[_frame],_frame);
+  embs[_mbi].analysis_mv[0][_frame][0]=(signed char)vec[0];
+  embs[_mbi].analysis_mv[0][_frame][1]=(signed char)vec[1];
+}
+
+#if 0
+static int oc_mcenc_ysad_halfpel_brefine(const oc_enc_ctx *_enc,
+ int _vec[2],const unsigned char *_src,const unsigned char *_ref,int _ystride,
+ int _offset_y[9],unsigned _best_err){
+  int mvoffset_base;
+  int best_site;
+  int sitei;
+  mvoffset_base=_vec[0]+_vec[1]*_ystride;
+  best_site=4;
+  for(sitei=0;sitei<8;sitei++){
+    unsigned err;
+    int      site;
+    int      xmask;
+    int      ymask;
+    int      dx;
+    int      dy;
+    int      mvoffset0;
+    int      mvoffset1;
+    site=OC_SQUARE_SITES[0][sitei];
+    dx=OC_SQUARE_DX[site];
+    dy=OC_SQUARE_DY[site];
+    /*The following code SHOULD be equivalent to
+        oc_state_get_mv_offsets(&_mcenc->enc.state,&mvoffset0,&mvoffset1,
+         (_vec[0]<<1)+dx,(_vec[1]<<1)+dy,ref_ystride,0);
+      However, it should also be much faster, as it involves no multiplies and
+       doesn't have to handle chroma vectors.*/
+    xmask=OC_SIGNMASK(((_vec[0]<<1)+dx)^dx);
+    ymask=OC_SIGNMASK(((_vec[1]<<1)+dy)^dy);
+    mvoffset0=mvoffset_base+(dx&xmask)+(_offset_y[site]&ymask);
+    mvoffset1=mvoffset_base+(dx&~xmask)+(_offset_y[site]&~ymask);
+    err=oc_enc_frag_sad2_thresh(_enc,_src,
+     _ref+mvoffset0,_ref+mvoffset1,ystride,_best_err);
+    if(err<_best_err){
+      _best_err=err;
+      best_site=site;
+    }
+  }
+  _vec[0]=(_vec[0]<<1)+OC_SQUARE_DX[best_site];
+  _vec[1]=(_vec[1]<<1)+OC_SQUARE_DY[best_site];
+  return _best_err;
+}
+#endif
+
+static unsigned oc_mcenc_ysatd_halfpel_brefine(const oc_enc_ctx *_enc,
+ int _vec[2],const unsigned char *_src,const unsigned char *_ref,int _ystride,
+ int _offset_y[9],unsigned _best_err){
+  int mvoffset_base;
+  int best_site;
+  int sitei;
+  mvoffset_base=_vec[0]+_vec[1]*_ystride;
+  best_site=4;
+  for(sitei=0;sitei<8;sitei++){
+    unsigned err;
+    int      site;
+    int      xmask;
+    int      ymask;
+    int      dx;
+    int      dy;
+    int      mvoffset0;
+    int      mvoffset1;
+    site=OC_SQUARE_SITES[0][sitei];
+    dx=OC_SQUARE_DX[site];
+    dy=OC_SQUARE_DY[site];
+    /*The following code SHOULD be equivalent to
+        oc_state_get_mv_offsets(&_enc->state,&mvoffsets,0,
+         (_vec[0]<<1)+dx,(_vec[1]<<1)+dy);
+      However, it should also be much faster, as it involves no multiplies and
+       doesn't have to handle chroma vectors.*/
+    xmask=OC_SIGNMASK(((_vec[0]<<1)+dx)^dx);
+    ymask=OC_SIGNMASK(((_vec[1]<<1)+dy)^dy);
+    mvoffset0=mvoffset_base+(dx&xmask)+(_offset_y[site]&ymask);
+    mvoffset1=mvoffset_base+(dx&~xmask)+(_offset_y[site]&~ymask);
+    err=oc_enc_frag_satd2_thresh(_enc,_src,
+     _ref+mvoffset0,_ref+mvoffset1,_ystride,_best_err);
+    if(err<_best_err){
+      _best_err=err;
+      best_site=site;
+    }
+  }
+  _vec[0]=(_vec[0]<<1)+OC_SQUARE_DX[best_site];
+  _vec[1]=(_vec[1]<<1)+OC_SQUARE_DY[best_site];
+  return _best_err;
+}
+
+void oc_mcenc_refine4mv(oc_enc_ctx *_enc,int _mbi){
+  oc_mb_enc_info      *embs;
+  const ptrdiff_t     *frag_buf_offs;
+  const ptrdiff_t     *fragis;
+  const unsigned char *src;
+  const unsigned char *ref;
+  int                  offset_y[9];
+  int                  ystride;
+  int                  bi;
+  ystride=_enc->state.ref_ystride[0];
+  frag_buf_offs=_enc->state.frag_buf_offs;
+  fragis=_enc->state.mb_maps[_mbi][0];
+  src=_enc->state.ref_frame_data[OC_FRAME_IO];
+  ref=_enc->state.ref_frame_data[_enc->state.ref_frame_idx[OC_FRAME_PREV]];
+  offset_y[0]=offset_y[1]=offset_y[2]=-ystride;
+  offset_y[3]=offset_y[5]=0;
+  offset_y[6]=offset_y[7]=offset_y[8]=ystride;
+  embs=_enc->mb_info;
+  for(bi=0;bi<4;bi++){
+    ptrdiff_t frag_offs;
+    int       vec[2];
+    frag_offs=frag_buf_offs[fragis[bi]];
+    vec[0]=OC_DIV2(embs[_mbi].block_mv[bi][0]);
+    vec[1]=OC_DIV2(embs[_mbi].block_mv[bi][1]);
+    embs[_mbi].block_satd[bi]=oc_mcenc_ysatd_halfpel_brefine(_enc,vec,
+     src+frag_offs,ref+frag_offs,ystride,offset_y,embs[_mbi].block_satd[bi]);
+    embs[_mbi].ref_mv[bi][0]=(signed char)vec[0];
+    embs[_mbi].ref_mv[bi][1]=(signed char)vec[1];
+  }
+}
diff --git a/lib/modedec.h b/lib/modedec.h
new file mode 100644 (file)
index 0000000..ea12c64
--- /dev/null
@@ -0,0 +1,4027 @@
+/*File generated by libtheora with OC_COLLECT_METRICS defined at compile time.*/
+#if !defined(_modedec_H)
+# define _modedec_H (1)
+
+
+
+# if defined(OC_COLLECT_METRICS)
+typedef struct oc_mode_metrics oc_mode_metrics;
+# endif
+typedef struct oc_mode_rd      oc_mode_rd;
+
+
+
+/*The number of extra bits of precision at which to store rate metrics.*/
+# define OC_BIT_SCALE  (6)
+/*The number of extra bits of precision at which to store RMSE metrics.
+  This must be at least half OC_BIT_SCALE (rounded up).*/
+# define OC_RMSE_SCALE (5)
+/*The number of bins to partition statistics into.*/
+# define OC_SAD_BINS   (24)
+/*The number of bits of precision to drop from SAD scores to assign them to a
+   bin.*/
+# define OC_SAD_SHIFT  (9)
+
+
+
+# if defined(OC_COLLECT_METRICS)
+struct oc_mode_metrics{
+  double fragw;
+  double satd;
+  double rate;
+  double rmse;
+  double satd2;
+  double satdrate;
+  double rate2;
+  double satdrmse;
+  double rmse2;
+};
+
+
+int             oc_has_mode_metrics;
+oc_mode_metrics OC_MODE_METRICS[64][3][2][OC_SAD_BINS];
+# endif
+
+
+
+struct oc_mode_rd{
+  ogg_int16_t rate;
+  ogg_int16_t rmse;
+};
+
+
+# if !defined(OC_COLLECT_METRICS)
+static const
+# endif
+oc_mode_rd OC_MODE_RD[64][3][2][OC_SAD_BINS]={
+  {
+    {
+      /*Y'  qi=0  INTRA*/
+      {
+        {   87,  -66},{  132, 1611},{  197, 3474},{  285, 5130},
+        {  376, 6419},{  450, 7545},{  521, 8587},{  600, 9587},
+        {  689,10498},{  790,11348},{  899,12158},{ 1030,12855},
+        { 1166,13459},{ 1276,14052},{ 1353,14732},{ 1444,15425},
+        { 1535,16101},{ 1609,16856},{ 1697,17532},{ 1823,17995},
+        { 1962,18426},{ 2085,18919},{ 2201,19503},{ 2304,20307}
+      },
+      /*Y'  qi=0  INTER*/
+      {
+        {   32, -105},{   40, 1268},{   54, 2919},{   91, 4559},
+        {  118, 6244},{  132, 7932},{  142, 9514},{  149,10989},
+        {  155,12375},{  161,13679},{  168,14958},{  176,16215},
+        {  187,17431},{  196,18623},{  207,19790},{  218,20941},
+        {  230,22083},{  246,23213},{  265,24333},{  292,25439},
+        {  328,26512},{  372,27538},{  427,28522},{  494,29479}
+      }
+    },
+    {
+      /*Cb  qi=0  INTRA*/
+      {
+        {    1,    6},{   27,  368},{   52,  738},{   67, 1171},
+        {   80, 1642},{   99, 2134},{  110, 2642},{  112, 3144},
+        {  126, 3578},{  154, 3967},{  167, 4387},{  172, 4839},
+        {  191, 5278},{  208, 5666},{  220, 6036},{  223, 6398},
+        {  227, 6814},{  253, 7157},{  284, 7403},{  292, 7699},
+        {  314, 7983},{  339, 8203},{  363, 8460},{  399, 8919}
+      },
+      /*Cb  qi=0  INTER*/
+      {
+        {   68,  -55},{   63,  275},{   58,  602},{   53,  936},
+        {   50, 1290},{   54, 1691},{   58, 2116},{   62, 2553},
+        {   67, 2992},{   72, 3422},{   78, 3843},{   84, 4253},
+        {   89, 4658},{   94, 5062},{   98, 5455},{  100, 5848},
+        {  102, 6231},{  104, 6604},{  104, 6982},{  105, 7359},
+        {  105, 7733},{  104, 8104},{  105, 8465},{  111, 8828}
+      }
+    },
+    {
+      /*Cr  qi=0  INTRA*/
+      {
+        {    1,    8},{   23,  375},{   47,  759},{   63, 1220},
+        {   71, 1693},{   82, 2171},{   94, 2652},{  109, 3103},
+        {  125, 3567},{  133, 3995},{  151, 4375},{  168, 4819},
+        {  174, 5244},{  190, 5635},{  215, 6005},{  242, 6347},
+        {  257, 6758},{  280, 7068},{  311, 7336},{  326, 7652},
+        {  346, 7968},{  372, 8213},{  388, 8515},{  408, 9060}
+      },
+      /*Cr  qi=0  INTER*/
+      {
+        {   69,    0},{   60,  314},{   49,  624},{   45,  943},
+        {   45, 1285},{   49, 1691},{   55, 2130},{   62, 2560},
+        {   71, 2973},{   79, 3385},{   85, 3800},{   89, 4207},
+        {   92, 4620},{   95, 5037},{   96, 5436},{   97, 5839},
+        {   98, 6252},{   99, 6653},{   99, 7038},{  103, 7426},
+        {  107, 7810},{  108, 8178},{  107, 8539},{  106, 8937}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=1  INTRA*/
+      {
+        {   81,  -71},{  133, 1610},{  203, 3460},{  296, 5083},
+        {  392, 6342},{  467, 7454},{  541, 8486},{  625, 9466},
+        {  716,10352},{  823,11181},{  940,11961},{ 1074,12643},
+        { 1211,13233},{ 1324,13807},{ 1408,14489},{ 1504,15167},
+        { 1598,15824},{ 1679,16544},{ 1788,17161},{ 1928,17579},
+        { 2070,17991},{ 2202,18456},{ 2324,19021},{ 2425,19894}
+      },
+      /*Y'  qi=1  INTER*/
+      {
+        {   34,    4},{   40, 1307},{   55, 2914},{   93, 4555},
+        {  120, 6243},{  134, 7912},{  144, 9468},{  152,10918},
+        {  158,12275},{  164,13569},{  171,14846},{  180,16098},
+        {  191,17310},{  204,18484},{  216,19636},{  228,20779},
+        {  242,21912},{  261,23036},{  286,24146},{  320,25221},
+        {  363,26265},{  418,27261},{  485,28203},{  551,29148}
+      }
+    },
+    {
+      /*Cb  qi=1  INTRA*/
+      {
+        {    1,    6},{   28,  367},{   52,  738},{   68, 1172},
+        {   86, 1644},{  106, 2135},{  115, 2642},{  119, 3141},
+        {  132, 3569},{  157, 3951},{  172, 4366},{  177, 4819},
+        {  194, 5258},{  211, 5638},{  224, 6006},{  233, 6367},
+        {  236, 6784},{  258, 7121},{  299, 7357},{  319, 7637},
+        {  337, 7921},{  358, 8141},{  381, 8367},{  401, 8768}
+      },
+      /*Cb  qi=1  INTER*/
+      {
+        {   95,  -31},{   81,  295},{   67,  614},{   53,  953},
+        {   48, 1305},{   51, 1700},{   56, 2125},{   61, 2563},
+        {   67, 3008},{   73, 3435},{   79, 3844},{   85, 4251},
+        {   90, 4663},{   95, 5073},{   98, 5458},{  100, 5844},
+        {  101, 6231},{  102, 6606},{  102, 6980},{  103, 7347},
+        {  104, 7726},{  105, 8096},{  105, 8453},{  105, 8789}
+      }
+    },
+    {
+      /*Cr  qi=1  INTRA*/
+      {
+        {    1,    8},{   25,  375},{   50,  759},{   65, 1221},
+        {   74, 1695},{   86, 2172},{  101, 2651},{  117, 3101},
+        {  129, 3561},{  135, 3985},{  153, 4368},{  171, 4807},
+        {  182, 5223},{  202, 5608},{  225, 5964},{  251, 6300},
+        {  271, 6697},{  295, 6978},{  324, 7235},{  348, 7558},
+        {  367, 7877},{  394, 8101},{  413, 8386},{  409, 8945}
+      },
+      /*Cr  qi=1  INTER*/
+      {
+        {   66,   11},{   59,  323},{   51,  631},{   44,  949},
+        {   44, 1292},{   49, 1703},{   56, 2140},{   62, 2566},
+        {   69, 2991},{   77, 3397},{   84, 3799},{   89, 4211},
+        {   93, 4634},{   94, 5049},{   95, 5444},{   96, 5854},
+        {   94, 6260},{   95, 6640},{   96, 7032},{  101, 7423},
+        {  104, 7790},{  105, 8158},{  109, 8527},{  108, 8872}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=2  INTRA*/
+      {
+        {   87,  -72},{  139, 1607},{  213, 3426},{  315, 4992},
+        {  416, 6217},{  495, 7315},{  574, 8317},{  666, 9265},
+        {  763,10124},{  875,10906},{ 1001,11654},{ 1147,12305},
+        { 1289,12865},{ 1407,13424},{ 1503,14076},{ 1610,14724},
+        { 1720,15342},{ 1815,16020},{ 1937,16579},{ 2084,16981},
+        { 2236,17371},{ 2385,17779},{ 2536,18250},{ 2689,18931}
+      },
+      /*Y'  qi=2  INTER*/
+      {
+        {   30,   -2},{   40, 1308},{   57, 2921},{   96, 4567},
+        {  122, 6260},{  136, 7902},{  148, 9418},{  156,10826},
+        {  162,12157},{  169,13448},{  177,14709},{  188,15938},
+        {  200,17133},{  213,18295},{  228,19433},{  245,20564},
+        {  264,21685},{  289,22790},{  323,23876},{  368,24916},
+        {  427,25906},{  499,26837},{  585,27700},{  680,28514}
+      }
+    },
+    {
+      /*Cb  qi=2  INTRA*/
+      {
+        {    1,    6},{   30,  367},{   58,  738},{   77, 1172},
+        {   93, 1645},{  111, 2137},{  123, 2642},{  126, 3133},
+        {  136, 3553},{  162, 3934},{  178, 4352},{  183, 4803},
+        {  199, 5231},{  220, 5596},{  235, 5957},{  245, 6314},
+        {  256, 6718},{  286, 7048},{  320, 7285},{  336, 7568},
+        {  366, 7829},{  387, 8045},{  405, 8261},{  445, 8550}
+      },
+      /*Cb  qi=2  INTER*/
+      {
+        {  115,  -61},{   93,  277},{   71,  609},{   54,  963},
+        {   49, 1329},{   53, 1715},{   58, 2138},{   63, 2583},
+        {   69, 3017},{   75, 3442},{   81, 3857},{   88, 4263},
+        {   93, 4667},{   96, 5065},{  101, 5451},{  101, 5832},
+        {  102, 6213},{  103, 6593},{  103, 6968},{  104, 7336},
+        {  104, 7710},{  105, 8076},{  106, 8440},{  106, 8822}
+      }
+    },
+    {
+      /*Cr  qi=2  INTRA*/
+      {
+        {    1,    8},{   27,  375},{   54,  759},{   70, 1222},
+        {   79, 1696},{   89, 2173},{  106, 2652},{  123, 3098},
+        {  135, 3553},{  143, 3972},{  161, 4348},{  181, 4782},
+        {  194, 5189},{  213, 5565},{  235, 5907},{  266, 6229},
+        {  286, 6618},{  311, 6897},{  339, 7152},{  362, 7454},
+        {  392, 7721},{  416, 7946},{  429, 8227},{  458, 8540}
+      },
+      /*Cr  qi=2  INTER*/
+      {
+        {   74,   20},{   63,  330},{   51,  635},{   44,  942},
+        {   47, 1287},{   54, 1710},{   59, 2147},{   65, 2571},
+        {   72, 2996},{   79, 3413},{   86, 3820},{   91, 4230},
+        {   93, 4642},{   95, 5046},{   95, 5442},{   95, 5839},
+        {   96, 6243},{   97, 6641},{   99, 7021},{  101, 7396},
+        {  103, 7764},{  106, 8138},{  109, 8507},{  114, 8851}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=3  INTRA*/
+      {
+        {   91,  -67},{  141, 1606},{  219, 3405},{  328, 4929},
+        {  433, 6122},{  515, 7209},{  598, 8204},{  693, 9145},
+        {  796, 9986},{  912,10756},{ 1045,11471},{ 1200,12079},
+        { 1345,12640},{ 1471,13179},{ 1571,13809},{ 1678,14450},
+        { 1798,15047},{ 1905,15701},{ 2043,16205},{ 2202,16569},
+        { 2351,16971},{ 2501,17393},{ 2660,17851},{ 2825,18455}
+      },
+      /*Y'  qi=3  INTER*/
+      {
+        {   53, -164},{   38, 1314},{   59, 2917},{   99, 4563},
+        {  124, 6253},{  139, 7882},{  150, 9375},{  159,10749},
+        {  166,12059},{  173,13349},{  183,14608},{  194,15826},
+        {  208,17003},{  223,18150},{  240,19287},{  259,20411},
+        {  284,21508},{  317,22593},{  359,23656},{  414,24671},
+        {  483,25634},{  569,26519},{  670,27332},{  786,28072}
+      }
+    },
+    {
+      /*Cb  qi=3  INTRA*/
+      {
+        {    1,    5},{   31,  367},{   58,  739},{   78, 1173},
+        {   96, 1645},{  113, 2134},{  125, 2638},{  133, 3127},
+        {  148, 3542},{  171, 3915},{  184, 4328},{  192, 4776},
+        {  209, 5197},{  230, 5556},{  245, 5909},{  252, 6261},
+        {  272, 6641},{  304, 6942},{  330, 7184},{  342, 7477},
+        {  380, 7736},{  404, 7962},{  428, 8151},{  469, 8430}
+      },
+      /*Cb  qi=3  INTER*/
+      {
+        {   86,  -29},{   72,  296},{   58,  618},{   46,  964},
+        {   47, 1338},{   51, 1743},{   56, 2158},{   63, 2594},
+        {   69, 3035},{   77, 3455},{   84, 3859},{   89, 4266},
+        {   94, 4673},{   98, 5074},{  101, 5460},{  101, 5842},
+        {  101, 6217},{  101, 6593},{  102, 6964},{  104, 7325},
+        {  103, 7696},{  103, 8056},{  104, 8430},{  103, 8792}
+      }
+    },
+    {
+      /*Cr  qi=3  INTRA*/
+      {
+        {    1,    8},{   27,  374},{   56,  759},{   74, 1221},
+        {   83, 1696},{   96, 2173},{  113, 2650},{  127, 3091},
+        {  140, 3542},{  151, 3960},{  164, 4334},{  188, 4764},
+        {  208, 5144},{  224, 5493},{  250, 5841},{  278, 6162},
+        {  298, 6548},{  334, 6816},{  365, 7045},{  388, 7343},
+        {  419, 7613},{  443, 7836},{  455, 8105},{  484, 8445}
+      },
+      /*Cr  qi=3  INTER*/
+      {
+        {   76,   26},{   65,  332},{   53,  638},{   45,  945},
+        {   45, 1304},{   53, 1725},{   60, 2153},{   68, 2584},
+        {   74, 3007},{   81, 3425},{   87, 3844},{   91, 4253},
+        {   94, 4657},{   95, 5061},{   94, 5462},{   94, 5856},
+        {   95, 6250},{   96, 6635},{   97, 7014},{  101, 7393},
+        {  104, 7761},{  106, 8137},{  109, 8506},{  111, 8823}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=4  INTRA*/
+      {
+        {   80,  -67},{  143, 1603},{  227, 3378},{  344, 4861},
+        {  454, 6026},{  537, 7104},{  626, 8089},{  725, 9006},
+        {  830, 9827},{  950,10581},{ 1089,11270},{ 1257,11826},
+        { 1409,12366},{ 1535,12912},{ 1640,13528},{ 1753,14173},
+        { 1884,14756},{ 2007,15368},{ 2148,15852},{ 2307,16212},
+        { 2464,16591},{ 2614,17019},{ 2785,17455},{ 2970,17963}
+      },
+      /*Y'  qi=4  INTER*/
+      {
+        {   50, -145},{   38, 1324},{   61, 2921},{  102, 4566},
+        {  127, 6248},{  142, 7845},{  154, 9300},{  163,10656},
+        {  169,11965},{  177,13246},{  188,14495},{  202,15702},
+        {  218,16864},{  236,18003},{  256,19124},{  278,20233},
+        {  307,21330},{  347,22398},{  398,23437},{  463,24429},
+        {  546,25343},{  649,26170},{  767,26935},{  888,27674}
+      }
+    },
+    {
+      /*Cb  qi=4  INTRA*/
+      {
+        {    1,    5},{   33,  367},{   61,  739},{   80, 1173},
+        {   98, 1646},{  114, 2136},{  126, 2639},{  137, 3124},
+        {  152, 3535},{  176, 3903},{  194, 4307},{  206, 4753},
+        {  222, 5165},{  242, 5508},{  260, 5857},{  272, 6205},
+        {  294, 6559},{  332, 6848},{  356, 7104},{  364, 7389},
+        {  396, 7637},{  415, 7878},{  446, 8064},{  506, 8294}
+      },
+      /*Cb  qi=4  INTER*/
+      {
+        {   86,  -15},{   73,  308},{   60,  627},{   46,  967},
+        {   47, 1343},{   51, 1754},{   56, 2183},{   63, 2615},
+        {   70, 3044},{   79, 3459},{   85, 3866},{   90, 4276},
+        {   94, 4686},{   97, 5088},{  100, 5467},{  102, 5837},
+        {  102, 6205},{  101, 6569},{  103, 6939},{  104, 7317},
+        {  105, 7690},{  107, 8043},{  107, 8394},{  111, 8736}
+      }
+    },
+    {
+      /*Cr  qi=4  INTRA*/
+      {
+        {    1,    7},{   28,  375},{   57,  759},{   79, 1221},
+        {   92, 1697},{  105, 2174},{  122, 2648},{  135, 3085},
+        {  146, 3530},{  157, 3947},{  171, 4316},{  195, 4737},
+        {  218, 5117},{  239, 5445},{  268, 5767},{  295, 6074},
+        {  315, 6460},{  355, 6735},{  392, 6933},{  418, 7218},
+        {  448, 7495},{  471, 7688},{  481, 7954},{  504, 8313}
+      },
+      /*Cr  qi=4  INTER*/
+      {
+        {   68,   28},{   57,  334},{   47,  639},{   43,  953},
+        {   48, 1314},{   54, 1736},{   59, 2169},{   69, 2592},
+        {   78, 3017},{   84, 3434},{   88, 3850},{   92, 4260},
+        {   95, 4663},{   96, 5068},{   95, 5455},{   95, 5839},
+        {   96, 6243},{   97, 6626},{   98, 7006},{  101, 7390},
+        {  104, 7755},{  108, 8115},{  111, 8471},{  110, 8825}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=5  INTRA*/
+      {
+        {   84,  -69},{  147, 1599},{  237, 3350},{  360, 4796},
+        {  475, 5934},{  562, 6992},{  657, 7953},{  765, 8837},
+        {  874, 9641},{  998,10384},{ 1146,11047},{ 1322,11572},
+        { 1484,12076},{ 1617,12609},{ 1731,13203},{ 1856,13806},
+        { 1995,14367},{ 2132,14936},{ 2289,15386},{ 2460,15721},
+        { 2635,16066},{ 2802,16442},{ 2980,16805},{ 3177,17272}
+      },
+      /*Y'  qi=5  INTER*/
+      {
+        {   38,  -86},{   37, 1349},{   64, 2920},{  105, 4563},
+        {  129, 6236},{  145, 7809},{  158, 9236},{  167,10572},
+        {  174,11871},{  182,13141},{  195,14368},{  212,15558},
+        {  230,16706},{  250,17828},{  274,18944},{  303,20041},
+        {  342,21116},{  394,22152},{  460,23144},{  543,24073},
+        {  648,24919},{  773,25673},{  922,26323},{ 1084,26924}
+      }
+    },
+    {
+      /*Cb  qi=5  INTRA*/
+      {
+        {    1,    5},{   34,  367},{   63,  739},{   82, 1174},
+        {  102, 1647},{  119, 2137},{  134, 2639},{  145, 3121},
+        {  161, 3529},{  189, 3891},{  207, 4290},{  216, 4721},
+        {  232, 5113},{  258, 5455},{  277, 5798},{  294, 6124},
+        {  322, 6427},{  352, 6697},{  370, 6982},{  384, 7283},
+        {  423, 7529},{  448, 7766},{  478, 7943},{  527, 8151}
+      },
+      /*Cb  qi=5  INTER*/
+      {
+        {   83,  -49},{   69,  284},{   55,  611},{   48,  961},
+        {   49, 1355},{   52, 1769},{   58, 2191},{   65, 2616},
+        {   73, 3041},{   80, 3460},{   87, 3868},{   92, 4276},
+        {   95, 4682},{   98, 5077},{  100, 5459},{  102, 5827},
+        {  102, 6200},{  102, 6568},{  103, 6930},{  103, 7303},
+        {  104, 7672},{  106, 8032},{  106, 8391},{  106, 8727}
+      }
+    },
+    {
+      /*Cr  qi=5  INTRA*/
+      {
+        {    1,    8},{   28,  375},{   57,  760},{   81, 1222},
+        {   99, 1696},{  111, 2175},{  125, 2648},{  140, 3079},
+        {  152, 3520},{  162, 3927},{  179, 4294},{  203, 4714},
+        {  225, 5080},{  254, 5389},{  286, 5703},{  318, 5997},
+        {  342, 6364},{  380, 6640},{  416, 6837},{  445, 7103},
+        {  473, 7370},{  497, 7562},{  514, 7811},{  549, 8148}
+      },
+      /*Cr  qi=5  INTER*/
+      {
+        {   60,    6},{   54,  323},{   46,  638},{   43,  958},
+        {   45, 1329},{   54, 1749},{   61, 2175},{   70, 2600},
+        {   79, 3021},{   85, 3437},{   89, 3847},{   93, 4254},
+        {   95, 4660},{   96, 5065},{   95, 5456},{   95, 5849},
+        {   96, 6243},{   96, 6621},{   97, 6996},{  101, 7366},
+        {  104, 7722},{  107, 8088},{  111, 8448},{  119, 8816}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=6  INTRA*/
+      {
+        {   88,  -69},{  151, 1593},{  251, 3294},{  387, 4681},
+        {  507, 5790},{  601, 6837},{  702, 7787},{  813, 8648},
+        {  927, 9427},{ 1059,10152},{ 1213,10787},{ 1399,11284},
+        { 1568,11781},{ 1705,12312},{ 1823,12890},{ 1957,13482},
+        { 2106,14036},{ 2249,14600},{ 2411,15042},{ 2588,15359},
+        { 2772,15699},{ 2947,16062},{ 3127,16429},{ 3320,16849}
+      },
+      /*Y'  qi=6  INTER*/
+      {
+        {   44,  -80},{   36, 1346},{   69, 2919},{  111, 4563},
+        {  136, 6216},{  154, 7746},{  168, 9139},{  178,10461},
+        {  185,11747},{  195,13007},{  211,14229},{  230,15408},
+        {  250,16547},{  274,17663},{  302,18769},{  339,19851},
+        {  386,20907},{  446,21933},{  527,22884},{  631,23746},
+        {  760,24512},{  914,25178},{ 1087,25758},{ 1278,26262}
+      }
+    },
+    {
+      /*Cb  qi=6  INTRA*/
+      {
+        {    1,    4},{   36,  367},{   66,  739},{   84, 1174},
+        {  105, 1648},{  126, 2139},{  140, 2639},{  149, 3116},
+        {  164, 3523},{  194, 3880},{  217, 4271},{  226, 4694},
+        {  243, 5077},{  270, 5407},{  291, 5742},{  310, 6061},
+        {  340, 6340},{  373, 6609},{  394, 6890},{  409, 7189},
+        {  444, 7434},{  469, 7652},{  499, 7853},{  559, 8135}
+      },
+      /*Cb  qi=6  INTER*/
+      {
+        {   68,  -46},{   60,  291},{   50,  623},{   49,  971},
+        {   50, 1357},{   55, 1781},{   61, 2211},{   69, 2634},
+        {   78, 3052},{   86, 3466},{   91, 3882},{   95, 4292},
+        {   98, 4691},{  101, 5080},{  102, 5458},{  103, 5830},
+        {  103, 6192},{  104, 6554},{  104, 6916},{  106, 7278},
+        {  108, 7641},{  110, 8004},{  112, 8371},{  112, 8758}
+      }
+    },
+    {
+      /*Cr  qi=6  INTRA*/
+      {
+        {    1,    8},{   29,  375},{   59,  760},{   84, 1223},
+        {   99, 1698},{  112, 2176},{  129, 2647},{  143, 3076},
+        {  156, 3510},{  168, 3906},{  189, 4269},{  220, 4682},
+        {  241, 5047},{  266, 5342},{  299, 5649},{  331, 5954},
+        {  357, 6309},{  393, 6579},{  431, 6765},{  467, 6997},
+        {  501, 7276},{  520, 7488},{  525, 7749},{  548, 8146}
+      },
+      /*Cr  qi=6  INTER*/
+      {
+        {   94,   31},{   69,  335},{   47,  641},{   43,  967},
+        {   50, 1350},{   57, 1772},{   65, 2197},{   74, 2625},
+        {   83, 3043},{   90, 3454},{   94, 3867},{   97, 4273},
+        {   98, 4671},{   99, 5068},{   99, 5461},{   98, 5857},
+        {   98, 6245},{   99, 6610},{  103, 6975},{  105, 7345},
+        {  108, 7712},{  111, 8073},{  113, 8415},{  119, 8768}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=7  INTRA*/
+      {
+        {   92,  -70},{  156, 1590},{  261, 3267},{  403, 4618},
+        {  529, 5704},{  628, 6730},{  736, 7657},{  856, 8491},
+        {  978, 9246},{ 1118, 9943},{ 1281,10550},{ 1472,11028},
+        { 1645,11507},{ 1793,12008},{ 1924,12565},{ 2067,13130},
+        { 2229,13638},{ 2388,14160},{ 2558,14584},{ 2744,14886},
+        { 2932,15194},{ 3116,15531},{ 3311,15858},{ 3538,16197}
+      },
+      /*Y'  qi=7  INTER*/
+      {
+        {   43,   -8},{   36, 1351},{   71, 2923},{  112, 4568},
+        {  138, 6201},{  157, 7705},{  171, 9083},{  181,10390},
+        {  189,11664},{  202,12910},{  220,14121},{  241,15281},
+        {  266,16401},{  295,17507},{  328,18608},{  371,19677},
+        {  430,20701},{  508,21676},{  604,22588},{  727,23397},
+        {  878,24093},{ 1055,24690},{ 1263,25151},{ 1496,25504}
+      }
+    },
+    {
+      /*Cb  qi=7  INTRA*/
+      {
+        {    1,    5},{   40,  367},{   72,  740},{   89, 1175},
+        {  108, 1649},{  129, 2140},{  143, 2637},{  154, 3110},
+        {  169, 3507},{  198, 3860},{  224, 4237},{  235, 4652},
+        {  253, 5037},{  282, 5358},{  307, 5674},{  329, 5986},
+        {  361, 6273},{  393, 6527},{  419, 6777},{  435, 7078},
+        {  467, 7342},{  495, 7554},{  529, 7757},{  591, 8053}
+      },
+      /*Cb  qi=7  INTER*/
+      {
+        {   79,  -33},{   68,  299},{   56,  627},{   50,  978},
+        {   51, 1366},{   55, 1786},{   61, 2213},{   70, 2642},
+        {   80, 3062},{   87, 3474},{   92, 3886},{   96, 4292},
+        {   99, 4684},{  102, 5072},{  103, 5450},{  104, 5814},
+        {  104, 6176},{  104, 6538},{  107, 6905},{  110, 7270},
+        {  110, 7625},{  110, 7978},{  111, 8340},{  117, 8674}
+      }
+    },
+    {
+      /*Cr  qi=7  INTRA*/
+      {
+        {    2,    7},{   31,  375},{   62,  760},{   87, 1223},
+        {  103, 1698},{  115, 2175},{  131, 2644},{  147, 3066},
+        {  161, 3494},{  175, 3889},{  199, 4250},{  229, 4653},
+        {  250, 5001},{  279, 5275},{  311, 5577},{  343, 5889},
+        {  376, 6227},{  417, 6486},{  457, 6689},{  484, 6925},
+        {  518, 7174},{  544, 7393},{  549, 7662},{  577, 8050}
+      },
+      /*Cr  qi=7  INTER*/
+      {
+        {   89,   22},{   62,  332},{   45,  641},{   47,  976},
+        {   52, 1363},{   59, 1779},{   67, 2203},{   76, 2628},
+        {   84, 3046},{   90, 3460},{   94, 3875},{   98, 4272},
+        {   99, 4666},{   98, 5063},{   98, 5459},{   98, 5849},
+        {   99, 6226},{  101, 6594},{  104, 6957},{  109, 7324},
+        {  109, 7686},{  111, 8042},{  115, 8379},{  119, 8699}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=8  INTRA*/
+      {
+        {   91,  -69},{  160, 1585},{  274, 3226},{  423, 4538},
+        {  557, 5596},{  664, 6595},{  778, 7506},{  905, 8319},
+        { 1038, 9035},{ 1186, 9701},{ 1355,10292},{ 1554,10754},
+        { 1739,11196},{ 1904,11639},{ 2047,12184},{ 2194,12763},
+        { 2361,13256},{ 2529,13753},{ 2709,14155},{ 2902,14433},
+        { 3100,14723},{ 3292,15026},{ 3489,15327},{ 3714,15705}
+      },
+      /*Y'  qi=8  INTER*/
+      {
+        {   32, -157},{   33, 1346},{   74, 2914},{  116, 4554},
+        {  142, 6172},{  162, 7648},{  177, 9004},{  186,10300},
+        {  196,11570},{  210,12808},{  231,14001},{  256,15150},
+        {  285,16259},{  319,17352},{  359,18435},{  415,19475},
+        {  489,20470},{  584,21400},{  703,22246},{  852,22968},
+        { 1038,23556},{ 1253,24032},{ 1503,24367},{ 1778,24628}
+      }
+    },
+    {
+      /*Cb  qi=8  INTRA*/
+      {
+        {    1,    4},{   42,  367},{   75,  740},{   93, 1176},
+        {  111, 1649},{  128, 2139},{  144, 2635},{  157, 3103},
+        {  174, 3494},{  206, 3844},{  233, 4207},{  251, 4605},
+        {  277, 4980},{  304, 5284},{  335, 5584},{  359, 5888},
+        {  393, 6152},{  432, 6398},{  455, 6656},{  471, 6956},
+        {  502, 7193},{  528, 7405},{  562, 7630},{  603, 7922}
+      },
+      /*Cb  qi=8  INTER*/
+      {
+        {   77,  -37},{   68,  299},{   58,  632},{   50,  991},
+        {   50, 1382},{   55, 1799},{   62, 2226},{   73, 2647},
+        {   82, 3066},{   90, 3480},{   94, 3891},{   96, 4296},
+        {   98, 4687},{  101, 5073},{  103, 5456},{  104, 5817},
+        {  105, 6170},{  106, 6523},{  107, 6886},{  108, 7250},
+        {  109, 7600},{  110, 7955},{  111, 8305},{  112, 8641}
+      }
+    },
+    {
+      /*Cr  qi=8  INTRA*/
+      {
+        {    2,    7},{   33,  375},{   64,  760},{   92, 1224},
+        {  111, 1700},{  122, 2173},{  137, 2637},{  156, 3055},
+        {  172, 3476},{  186, 3856},{  211, 4211},{  242, 4597},
+        {  263, 4939},{  292, 5214},{  335, 5489},{  376, 5772},
+        {  406, 6099},{  440, 6378},{  483, 6578},{  517, 6797},
+        {  550, 7049},{  571, 7283},{  583, 7560},{  618, 7967}
+      },
+      /*Cr  qi=8  INTER*/
+      {
+        {   74,   25},{   58,  328},{   43,  637},{   45,  980},
+        {   51, 1371},{   59, 1788},{   69, 2207},{   79, 2630},
+        {   86, 3051},{   91, 3470},{   95, 3880},{   97, 4280},
+        {   98, 4680},{   97, 5074},{   96, 5456},{   97, 5839},
+        {   99, 6219},{  101, 6583},{  103, 6945},{  106, 7312},
+        {  110, 7671},{  114, 8009},{  115, 8345},{  117, 8686}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=9  INTRA*/
+      {
+        {  104,  -68},{  164, 1580},{  288, 3173},{  448, 4439},
+        {  587, 5485},{  702, 6465},{  824, 7351},{  958, 8148},
+        { 1096, 8845},{ 1253, 9480},{ 1432,10047},{ 1640,10494},
+        { 1835,10926},{ 2015,11350},{ 2166,11871},{ 2321,12428},
+        { 2508,12876},{ 2684,13345},{ 2866,13741},{ 3069,13991},
+        { 3281,14243},{ 3487,14518},{ 3689,14813},{ 3911,15175}
+      },
+      /*Y'  qi=9  INTER*/
+      {
+        {   47, -140},{   34, 1348},{   77, 2915},{  119, 4552},
+        {  145, 6150},{  166, 7600},{  182, 8936},{  192,10221},
+        {  203,11482},{  220,12711},{  244,13886},{  274,15012},
+        {  308,16111},{  349,17190},{  401,18244},{  470,19257},
+        {  561,20209},{  680,21069},{  830,21822},{ 1010,22463},
+        { 1227,22971},{ 1482,23328},{ 1769,23544},{ 2077,23655}
+      }
+    },
+    {
+      /*Cb  qi=9  INTRA*/
+      {
+        {    1,    5},{   43,  367},{   76,  740},{   95, 1176},
+        {  114, 1649},{  135, 2138},{  153, 2629},{  165, 3091},
+        {  184, 3481},{  217, 3831},{  244, 4187},{  260, 4572},
+        {  290, 4930},{  320, 5231},{  351, 5521},{  379, 5812},
+        {  414, 6055},{  452, 6307},{  483, 6564},{  502, 6848},
+        {  525, 7115},{  554, 7321},{  589, 7533},{  626, 7833}
+      },
+      /*Cb  qi=9  INTER*/
+      {
+        {  101,  -43},{   81,  298},{   62,  637},{   49,  989},
+        {   51, 1381},{   56, 1806},{   65, 2231},{   74, 2653},
+        {   84, 3071},{   91, 3482},{   95, 3892},{   97, 4293},
+        {   99, 4684},{  101, 5066},{  103, 5437},{  103, 5793},
+        {  103, 6148},{  104, 6511},{  105, 6867},{  107, 7221},
+        {  110, 7572},{  111, 7926},{  112, 8283},{  116, 8625}
+      }
+    },
+    {
+      /*Cr  qi=9  INTRA*/
+      {
+        {    2,    7},{   35,  375},{   66,  761},{   93, 1224},
+        {  112, 1700},{  126, 2173},{  144, 2633},{  165, 3047},
+        {  183, 3458},{  199, 3835},{  224, 4191},{  257, 4558},
+        {  283, 4887},{  309, 5176},{  351, 5446},{  397, 5713},
+        {  433, 6017},{  469, 6283},{  508, 6480},{  546, 6687},
+        {  579, 6945},{  600, 7182},{  610, 7434},{  623, 7793}
+      },
+      /*Cr  qi=9  INTER*/
+      {
+        {   77,   15},{   57,  330},{   45,  640},{   48,  980},
+        {   54, 1380},{   61, 1802},{   70, 2220},{   80, 2639},
+        {   87, 3057},{   92, 3474},{   94, 3882},{   98, 4282},
+        {   98, 4675},{   97, 5062},{   97, 5450},{   98, 5829},
+        {  100, 6197},{  101, 6561},{  104, 6927},{  107, 7289},
+        {  113, 7638},{  117, 7978},{  119, 8311},{  117, 8629}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=10  INTRA*/
+      {
+        {  101,  -69},{  168, 1574},{  299, 3143},{  465, 4386},
+        {  610, 5410},{  736, 6353},{  866, 7207},{ 1006, 7982},
+        { 1153, 8655},{ 1319, 9261},{ 1504, 9812},{ 1719,10248},
+        { 1928,10653},{ 2116,11056},{ 2282,11550},{ 2458,12070},
+        { 2654,12492},{ 2846,12923},{ 3043,13291},{ 3249,13537},
+        { 3466,13764},{ 3682,13999},{ 3896,14268},{ 4145,14548}
+      },
+      /*Y'  qi=10  INTER*/
+      {
+        {   48,  -94},{   34, 1355},{   81, 2920},{  124, 4545},
+        {  151, 6113},{  174, 7532},{  190, 8850},{  201,10125},
+        {  214,11379},{  235,12591},{  264,13745},{  299,14859},
+        {  338,15948},{  388,17008},{  456,18029},{  546,18988},
+        {  661,19877},{  808,20666},{  993,21321},{ 1218,21835},
+        { 1481,22203},{ 1783,22420},{ 2117,22504},{ 2469,22481}
+      }
+    },
+    {
+      /*Cb  qi=10  INTRA*/
+      {
+        {    2,    4},{   44,  367},{   79,  740},{   99, 1178},
+        {  117, 1652},{  137, 2141},{  156, 2630},{  170, 3089},
+        {  192, 3474},{  227, 3813},{  259, 4157},{  282, 4526},
+        {  310, 4860},{  342, 5140},{  377, 5425},{  400, 5714},
+        {  436, 5952},{  475, 6194},{  496, 6468},{  522, 6748},
+        {  559, 6996},{  587, 7216},{  617, 7433},{  673, 7678}
+      },
+      /*Cb  qi=10  INTER*/
+      {
+        {   87,  -37},{   72,  301},{   58,  636},{   49,  995},
+        {   51, 1394},{   57, 1819},{   66, 2241},{   78, 2660},
+        {   87, 3074},{   93, 3482},{   97, 3891},{   99, 4294},
+        {  101, 4678},{  103, 5050},{  105, 5414},{  106, 5773},
+        {  107, 6134},{  108, 6485},{  110, 6832},{  113, 7187},
+        {  113, 7547},{  114, 7887},{  117, 8230},{  112, 8590}
+      }
+    },
+    {
+      /*Cr  qi=10  INTRA*/
+      {
+        {    2,    7},{   38,  375},{   69,  761},{   96, 1224},
+        {  116, 1701},{  131, 2175},{  148, 2634},{  168, 3041},
+        {  190, 3439},{  211, 3802},{  238, 4151},{  271, 4506},
+        {  297, 4824},{  331, 5103},{  373, 5360},{  415, 5632},
+        {  459, 5928},{  500, 6176},{  535, 6386},{  573, 6586},
+        {  608, 6834},{  629, 7079},{  642, 7337},{  686, 7680}
+      },
+      /*Cr  qi=10  INTER*/
+      {
+        {   81,   34},{   63,  333},{   50,  633},{   48,  987},
+        {   53, 1397},{   61, 1820},{   71, 2237},{   83, 2651},
+        {   91, 3065},{   95, 3479},{   98, 3882},{  100, 4279},
+        {  101, 4673},{  101, 5054},{  100, 5429},{  101, 5801},
+        {  102, 6173},{  104, 6541},{  108, 6904},{  110, 7264},
+        {  114, 7609},{  119, 7945},{  123, 8275},{  128, 8615}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=11  INTRA*/
+      {
+        {  110,  -66},{  176, 1564},{  316, 3087},{  492, 4296},
+        {  645, 5299},{  781, 6217},{  924, 7039},{ 1075, 7776},
+        { 1232, 8421},{ 1410, 9005},{ 1607, 9532},{ 1834, 9929},
+        { 2053,10300},{ 2249,10697},{ 2427,11184},{ 2619,11682},
+        { 2826,12083},{ 3019,12508},{ 3225,12869},{ 3452,13064},
+        { 3670,13280},{ 3890,13519},{ 4123,13750},{ 4367,14059}
+      },
+      /*Y'  qi=11  INTER*/
+      {
+        {   72, -115},{   32, 1354},{   83, 2911},{  126, 4534},
+        {  154, 6080},{  178, 7475},{  194, 8779},{  205,10047},
+        {  222,11290},{  246,12488},{  281,13621},{  322,14714},
+        {  372,15786},{  436,16821},{  519,17813},{  628,18728},
+        {  770,19549},{  950,20254},{ 1175,20800},{ 1443,21197},
+        { 1752,21446},{ 2095,21555},{ 2457,21553},{ 2808,21544}
+      }
+    },
+    {
+      /*Cb  qi=11  INTRA*/
+      {
+        {    2,    4},{   45,  367},{   81,  740},{  101, 1177},
+        {  121, 1650},{  142, 2136},{  159, 2621},{  174, 3075},
+        {  199, 3451},{  234, 3778},{  265, 4117},{  297, 4473},
+        {  333, 4789},{  367, 5054},{  402, 5319},{  427, 5613},
+        {  462, 5871},{  503, 6107},{  532, 6336},{  560, 6584},
+        {  601, 6842},{  631, 7092},{  662, 7292},{  721, 7497}
+      },
+      /*Cb  qi=11  INTER*/
+      {
+        {  117,  -24},{   93,  308},{   69,  638},{   52,  993},
+        {   52, 1395},{   58, 1822},{   68, 2246},{   80, 2665},
+        {   89, 3082},{   94, 3492},{   96, 3900},{   98, 4299},
+        {  101, 4679},{  103, 5047},{  104, 5405},{  106, 5763},
+        {  106, 6120},{  107, 6474},{  109, 6823},{  112, 7163},
+        {  115, 7516},{  117, 7868},{  118, 8213},{  119, 8561}
+      }
+    },
+    {
+      /*Cr  qi=11  INTRA*/
+      {
+        {    2,    7},{   40,  375},{   75,  761},{  100, 1224},
+        {  119, 1700},{  137, 2169},{  154, 2622},{  178, 3025},
+        {  198, 3416},{  220, 3770},{  255, 4114},{  294, 4459},
+        {  323, 4756},{  359, 5028},{  399, 5292},{  438, 5556},
+        {  483, 5827},{  518, 6073},{  551, 6298},{  598, 6501},
+        {  634, 6754},{  652, 6997},{  670, 7211},{  689, 7560}
+      },
+      /*Cr  qi=11  INTER*/
+      {
+        {   75,   30},{   61,  334},{   51,  639},{   49,  995},
+        {   53, 1403},{   62, 1821},{   73, 2237},{   84, 2654},
+        {   91, 3070},{   95, 3485},{   96, 3890},{   98, 4287},
+        {   98, 4672},{   99, 5050},{   99, 5427},{  100, 5798},
+        {  103, 6169},{  105, 6528},{  107, 6881},{  113, 7233},
+        {  118, 7580},{  121, 7916},{  125, 8240},{  130, 8551}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=12  INTRA*/
+      {
+        {  104,  -69},{  182, 1557},{  335, 3040},{  521, 4205},
+        {  684, 5178},{  831, 6068},{  986, 6854},{ 1151, 7559},
+        { 1323, 8169},{ 1523, 8704},{ 1736, 9192},{ 1978, 9558},
+        { 2213, 9908},{ 2421,10298},{ 2613,10757},{ 2822,11208},
+        { 3042,11585},{ 3250,11991},{ 3474,12308},{ 3710,12480},
+        { 3939,12687},{ 4174,12902},{ 4416,13102},{ 4672,13369}
+      },
+      /*Y'  qi=12  INTER*/
+      {
+        {   52,  -91},{   34, 1355},{   86, 2911},{  129, 4518},
+        {  159, 6037},{  184, 7405},{  200, 8694},{  213, 9955},
+        {  232,11185},{  263,12360},{  304,13479},{  354,14555},
+        {  415,15601},{  495,16608},{  601,17549},{  738,18400},
+        {  915,19136},{ 1139,19724},{ 1414,20150},{ 1731,20412},
+        { 2090,20520},{ 2473,20509},{ 2851,20442},{ 3227,20328}
+      }
+    },
+    {
+      /*Cb  qi=12  INTRA*/
+      {
+        {    1,    4},{   46,  367},{   85,  740},{  109, 1178},
+        {  126, 1650},{  145, 2134},{  165, 2617},{  182, 3061},
+        {  209, 3428},{  245, 3749},{  281, 4077},{  316, 4417},
+        {  354, 4718},{  392, 4970},{  430, 5217},{  456, 5501},
+        {  490, 5771},{  534, 5996},{  571, 6207},{  600, 6458},
+        {  644, 6697},{  675, 6942},{  707, 7151},{  766, 7342}
+      },
+      /*Cb  qi=12  INTER*/
+      {
+        {   84,  -24},{   73,  311},{   60,  644},{   52,  998},
+        {   53, 1398},{   60, 1825},{   71, 2249},{   83, 2665},
+        {   90, 3081},{   94, 3490},{   97, 3893},{   99, 4286},
+        {  102, 4663},{  104, 5032},{  105, 5393},{  106, 5751},
+        {  107, 6102},{  108, 6445},{  111, 6788},{  113, 7136},
+        {  114, 7483},{  117, 7828},{  121, 8163},{  122, 8496}
+      }
+    },
+    {
+      /*Cr  qi=12  INTRA*/
+      {
+        {    3,    7},{   41,  375},{   78,  761},{  106, 1225},
+        {  124, 1700},{  140, 2167},{  163, 2616},{  188, 3010},
+        {  213, 3385},{  240, 3718},{  271, 4062},{  309, 4406},
+        {  345, 4691},{  387, 4956},{  430, 5212},{  469, 5467},
+        {  513, 5729},{  554, 5970},{  587, 6176},{  633, 6395},
+        {  673, 6659},{  692, 6868},{  712, 7061},{  758, 7259}
+      },
+      /*Cr  qi=12  INTER*/
+      {
+        {   73,   31},{   59,  335},{   48,  638},{   50,  998},
+        {   56, 1410},{   65, 1827},{   75, 2240},{   85, 2657},
+        {   92, 3073},{   95, 3485},{   97, 3888},{   99, 4279},
+        {   98, 4663},{   99, 5042},{  101, 5412},{  102, 5779},
+        {  105, 6142},{  107, 6498},{  108, 6848},{  113, 7198},
+        {  118, 7540},{  121, 7867},{  127, 8188},{  132, 8508}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=13  INTRA*/
+      {
+        {  109,  -68},{  187, 1551},{  347, 3010},{  541, 4153},
+        {  709, 5107},{  864, 5975},{ 1026, 6745},{ 1194, 7433},
+        { 1375, 8021},{ 1581, 8550},{ 1803, 9026},{ 2054, 9371},
+        { 2301, 9713},{ 2522,10082},{ 2728,10515},{ 2949,10956},
+        { 3184,11297},{ 3408,11653},{ 3643,11946},{ 3886,12100},
+        { 4124,12277},{ 4377,12459},{ 4632,12635},{ 4898,12861}
+      },
+      /*Y'  qi=13  INTER*/
+      {
+        {   48,  -78},{   35, 1357},{   89, 2914},{  133, 4512},
+        {  164, 6004},{  190, 7348},{  207, 8627},{  222, 9881},
+        {  247,11096},{  284,12251},{  333,13350},{  392,14407},
+        {  466,15426},{  565,16391},{  696,17279},{  865,18058},
+        { 1085,18689},{ 1358,19156},{ 1684,19456},{ 2050,19605},
+        { 2447,19614},{ 2855,19524},{ 3243,19398},{ 3611,19201}
+      }
+    },
+    {
+      /*Cb  qi=13  INTRA*/
+      {
+        {    2,    4},{   47,  367},{   86,  741},{  108, 1179},
+        {  127, 1651},{  150, 2133},{  173, 2611},{  194, 3050},
+        {  222, 3417},{  262, 3733},{  303, 4048},{  337, 4375},
+        {  378, 4657},{  420, 4897},{  456, 5148},{  486, 5422},
+        {  518, 5682},{  558, 5903},{  592, 6113},{  623, 6372},
+        {  662, 6628},{  700, 6833},{  751, 6989},{  805, 7147}
+      },
+      /*Cb  qi=13  INTER*/
+      {
+        {   94,  -34},{   78,  303},{   60,  638},{   51,  994},
+        {   54, 1406},{   61, 1836},{   73, 2253},{   84, 2668},
+        {   92, 3082},{   96, 3492},{   99, 3894},{  101, 4284},
+        {  103, 4659},{  105, 5023},{  106, 5376},{  108, 5726},
+        {  109, 6070},{  110, 6418},{  113, 6765},{  117, 7105},
+        {  119, 7448},{  122, 7784},{  126, 8119},{  131, 8463}
+      }
+    },
+    {
+      /*Cr  qi=13  INTRA*/
+      {
+        {    3,    7},{   43,  375},{   80,  762},{  110, 1226},
+        {  131, 1701},{  149, 2166},{  172, 2610},{  196, 2999},
+        {  221, 3359},{  254, 3679},{  292, 4005},{  332, 4329},
+        {  369, 4612},{  408, 4880},{  456, 5139},{  500, 5388},
+        {  544, 5631},{  581, 5877},{  615, 6101},{  660, 6316},
+        {  692, 6594},{  714, 6795},{  736, 6997},{  789, 7290}
+      },
+      /*Cr  qi=13  INTER*/
+      {
+        {   73,   28},{   61,  336},{   46,  642},{   50, 1003},
+        {   58, 1414},{   67, 1832},{   79, 2245},{   87, 2660},
+        {   93, 3075},{   97, 3484},{   99, 3888},{  100, 4277},
+        {  100, 4651},{  100, 5027},{  101, 5403},{  102, 5765},
+        {  105, 6116},{  109, 6470},{  113, 6825},{  119, 7163},
+        {  124, 7497},{  127, 7827},{  131, 8137},{  135, 8437}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=14  INTRA*/
+      {
+        {  113,  -68},{  191, 1545},{  358, 2981},{  559, 4104},
+        {  733, 5044},{  896, 5890},{ 1066, 6636},{ 1241, 7304},
+        { 1428, 7886},{ 1642, 8402},{ 1872, 8871},{ 2128, 9219},
+        { 2380, 9547},{ 2609, 9908},{ 2825,10321},{ 3055,10728},
+        { 3294,11076},{ 3523,11425},{ 3766,11689},{ 4013,11845},
+        { 4254,12022},{ 4506,12209},{ 4759,12383},{ 5013,12637}
+      },
+      /*Y'  qi=14  INTER*/
+      {
+        {   58,  -82},{   38, 1362},{   93, 2914},{  138, 4492},
+        {  171, 5962},{  198, 7289},{  216, 8559},{  234, 9804},
+        {  263,11005},{  306,12143},{  363,13222},{  434,14259},
+        {  523,15255},{  639,16188},{  794,17021},{ 1000,17717},
+        { 1262,18260},{ 1575,18645},{ 1943,18841},{ 2356,18872},
+        { 2782,18802},{ 3194,18682},{ 3576,18559},{ 3923,18447}
+      }
+    },
+    {
+      /*Cb  qi=14  INTRA*/
+      {
+        {    2,    3},{   50,  367},{   91,  741},{  114, 1180},
+        {  134, 1651},{  157, 2131},{  181, 2601},{  208, 3028},
+        {  239, 3391},{  279, 3706},{  322, 4000},{  361, 4309},
+        {  406, 4587},{  445, 4822},{  482, 5067},{  515, 5344},
+        {  546, 5612},{  589, 5821},{  626, 6020},{  655, 6276},
+        {  701, 6523},{  748, 6717},{  796, 6876},{  815, 7151}
+      },
+      /*Cb  qi=14  INTER*/
+      {
+        {   80,  -43},{   68,  301},{   56,  644},{   50, 1004},
+        {   54, 1412},{   63, 1836},{   75, 2253},{   87, 2670},
+        {   94, 3083},{   98, 3487},{  101, 3885},{  103, 4271},
+        {  106, 4645},{  107, 5004},{  108, 5358},{  109, 5705},
+        {  112, 6047},{  115, 6388},{  118, 6731},{  121, 7081},
+        {  126, 7421},{  129, 7747},{  132, 8076},{  137, 8419}
+      }
+    },
+    {
+      /*Cr  qi=14  INTRA*/
+      {
+        {    3,    6},{   45,  375},{   85,  762},{  116, 1226},
+        {  138, 1700},{  158, 2163},{  180, 2602},{  206, 2985},
+        {  236, 3333},{  270, 3639},{  310, 3956},{  359, 4258},
+        {  397, 4524},{  430, 4802},{  478, 5068},{  527, 5316},
+        {  572, 5560},{  613, 5802},{  654, 6012},{  699, 6216},
+        {  734, 6489},{  755, 6707},{  775, 6898},{  841, 7111}
+      },
+      /*Cr  qi=14  INTER*/
+      {
+        {   78,    0},{   59,  322},{   46,  649},{   51, 1016},
+        {   58, 1422},{   68, 1839},{   81, 2253},{   90, 2666},
+        {   95, 3080},{   98, 3486},{  101, 3881},{  102, 4268},
+        {  102, 4644},{  103, 5017},{  105, 5382},{  106, 5743},
+        {  108, 6093},{  112, 6442},{  118, 6791},{  124, 7130},
+        {  127, 7463},{  133, 7784},{  138, 8085},{  142, 8395}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=15  INTRA*/
+      {
+        {  111,  -66},{  197, 1538},{  370, 2949},{  579, 4050},
+        {  762, 4968},{  933, 5798},{ 1112, 6520},{ 1299, 7161},
+        { 1497, 7725},{ 1723, 8219},{ 1967, 8654},{ 2234, 8990},
+        { 2499, 9302},{ 2740, 9637},{ 2968,10039},{ 3215,10414},
+        { 3473,10709},{ 3721,11015},{ 3971,11270},{ 4228,11402},
+        { 4487,11543},{ 4752,11707},{ 5011,11871},{ 5290,12099}
+      },
+      /*Y'  qi=15  INTER*/
+      {
+        {   59, -113},{   37, 1349},{   95, 2904},{  139, 4478},
+        {  174, 5929},{  201, 7244},{  220, 8505},{  241, 9736},
+        {  275,10922},{  327,12040},{  395,13097},{  477,14114},
+        {  585,15071},{  730,15947},{  917,16714},{ 1162,17326},
+        { 1468,17770},{ 1833,18029},{ 2251,18111},{ 2694,18068},
+        { 3125,17968},{ 3529,17845},{ 3908,17713},{ 4260,17587}
+      }
+    },
+    {
+      /*Cb  qi=15  INTRA*/
+      {
+        {    2,    3},{   51,  367},{   94,  741},{  120, 1180},
+        {  140, 1651},{  160, 2129},{  184, 2591},{  213, 3010},
+        {  246, 3371},{  289, 3680},{  335, 3969},{  374, 4274},
+        {  418, 4546},{  460, 4783},{  498, 5019},{  532, 5280},
+        {  565, 5553},{  608, 5765},{  647, 5958},{  683, 6193},
+        {  732, 6433},{  782, 6620},{  832, 6769},{  848, 7027}
+      },
+      /*Cb  qi=15  INTER*/
+      {
+        {   71,  -52},{   63,  296},{   54,  644},{   50, 1010},
+        {   53, 1417},{   64, 1837},{   77, 2253},{   88, 2666},
+        {   95, 3079},{   98, 3487},{  100, 3882},{  103, 4264},
+        {  106, 4633},{  108, 4991},{  109, 5343},{  109, 5693},
+        {  112, 6038},{  114, 6371},{  119, 6709},{  123, 7051},
+        {  125, 7385},{  130, 7716},{  135, 8050},{  140, 8374}
+      }
+    },
+    {
+      /*Cr  qi=15  INTRA*/
+      {
+        {    2,    6},{   47,  375},{   87,  763},{  119, 1225},
+        {  143, 1699},{  162, 2158},{  185, 2595},{  213, 2971},
+        {  246, 3315},{  279, 3618},{  320, 3920},{  372, 4210},
+        {  409, 4480},{  446, 4756},{  496, 5017},{  542, 5263},
+        {  590, 5487},{  639, 5721},{  687, 5923},{  724, 6132},
+        {  753, 6417},{  781, 6622},{  805, 6806},{  856, 6977}
+      },
+      /*Cr  qi=15  INTER*/
+      {
+        {   71,    3},{   61,  326},{   52,  651},{   50, 1017},
+        {   58, 1422},{   69, 1837},{   82, 2251},{   90, 2668},
+        {   95, 3080},{   98, 3484},{  101, 3877},{  102, 4257},
+        {  102, 4632},{  101, 5005},{  103, 5370},{  106, 5733},
+        {  110, 6082},{  116, 6424},{  120, 6774},{  124, 7106},
+        {  130, 7427},{  135, 7748},{  141, 8052},{  147, 8333}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=16  INTRA*/
+      {
+        {  114,  -63},{  206, 1525},{  396, 2887},{  618, 3945},
+        {  816, 4832},{ 1002, 5626},{ 1196, 6319},{ 1401, 6923},
+        { 1616, 7458},{ 1857, 7928},{ 2121, 8334},{ 2405, 8645},
+        { 2685, 8934},{ 2938, 9255},{ 3175, 9638},{ 3433, 9990},
+        { 3707,10263},{ 3958,10577},{ 4218,10807},{ 4488,10906},
+        { 4760,11028},{ 5037,11148},{ 5306,11286},{ 5625,11463}
+      },
+      /*Y'  qi=16  INTER*/
+      {
+        {   69, -153},{   39, 1348},{   98, 2894},{  144, 4448},
+        {  181, 5872},{  209, 7167},{  228, 8422},{  254, 9644},
+        {  297,10810},{  359,11908},{  438,12944},{  539,13930},
+        {  672,14842},{  850,15650},{ 1085,16318},{ 1391,16793},
+        { 1769,17082},{ 2200,17198},{ 2659,17174},{ 3116,17072},
+        { 3547,16948},{ 3943,16819},{ 4299,16701},{ 4611,16644}
+      }
+    },
+    {
+      /*Cb  qi=16  INTRA*/
+      {
+        {    3,    4},{   54,  367},{   97,  742},{  122, 1181},
+        {  143, 1651},{  168, 2123},{  197, 2575},{  226, 2985},
+        {  263, 3338},{  314, 3631},{  367, 3903},{  409, 4200},
+        {  453, 4468},{  491, 4703},{  528, 4932},{  566, 5188},
+        {  601, 5459},{  647, 5672},{  693, 5844},{  734, 6058},
+        {  784, 6305},{  836, 6460},{  882, 6602},{  905, 6891}
+      },
+      /*Cb  qi=16  INTER*/
+      {
+        {   75,  -64},{   67,  292},{   56,  645},{   51, 1016},
+        {   54, 1421},{   66, 1842},{   79, 2257},{   89, 2670},
+        {   95, 3082},{   98, 3488},{  101, 3879},{  104, 4258},
+        {  106, 4623},{  108, 4974},{  109, 5321},{  113, 5664},
+        {  116, 6001},{  117, 6341},{  123, 6677},{  128, 7004},
+        {  130, 7336},{  136, 7671},{  143, 7996},{  148, 8310}
+      }
+    },
+    {
+      /*Cr  qi=16  INTRA*/
+      {
+        {    4,    7},{   50,  375},{   90,  763},{  124, 1225},
+        {  148, 1698},{  168, 2154},{  195, 2582},{  227, 2948},
+        {  263, 3279},{  302, 3575},{  343, 3865},{  394, 4137},
+        {  439, 4402},{  482, 4672},{  533, 4925},{  579, 5165},
+        {  626, 5382},{  675, 5616},{  725, 5812},{  769, 5991},
+        {  810, 6242},{  848, 6430},{  868, 6615},{  944, 6732}
+      },
+      /*Cr  qi=16  INTER*/
+      {
+        {   78,   11},{   62,  327},{   49,  650},{   50, 1025},
+        {   59, 1431},{   72, 1841},{   83, 2253},{   90, 2671},
+        {   95, 3084},{   98, 3487},{  100, 3879},{  101, 4254},
+        {  102, 4625},{  103, 4994},{  106, 5355},{  108, 5708},
+        {  111, 6058},{  115, 6400},{  121, 6733},{  128, 7058},
+        {  134, 7374},{  140, 7691},{  146, 7993},{  146, 8317}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=17  INTRA*/
+      {
+        {  112,  -59},{  210, 1515},{  409, 2850},{  640, 3882},
+        {  844, 4748},{ 1038, 5529},{ 1240, 6206},{ 1452, 6803},
+        { 1676, 7330},{ 1925, 7792},{ 2194, 8201},{ 2483, 8512},
+        { 2766, 8801},{ 3027, 9121},{ 3279, 9482},{ 3548, 9810},
+        { 3825,10069},{ 4088,10345},{ 4362,10544},{ 4638,10644},
+        { 4915,10744},{ 5196,10850},{ 5471,10981},{ 5802,11136}
+      },
+      /*Y'  qi=17  INTER*/
+      {
+        {   70, -147},{   45, 1349},{  106, 2894},{  155, 4425},
+        {  195, 5818},{  225, 7099},{  247, 8348},{  278, 9565},
+        {  328,10717},{  399,11794},{  491,12807},{  609,13760},
+        {  766,14623},{  984,15349},{ 1274,15902},{ 1642,16256},
+        { 2082,16411},{ 2563,16409},{ 3048,16315},{ 3508,16194},
+        { 3924,16064},{ 4306,15938},{ 4656,15828},{ 4966,15733}
+      }
+    },
+    {
+      /*Cb  qi=17  INTRA*/
+      {
+        {    3,    4},{   57,  367},{  101,  742},{  126, 1182},
+        {  148, 1650},{  175, 2118},{  207, 2565},{  241, 2966},
+        {  279, 3307},{  331, 3588},{  389, 3845},{  435, 4132},
+        {  474, 4408},{  517, 4641},{  560, 4869},{  602, 5122},
+        {  638, 5389},{  672, 5610},{  716, 5787},{  758, 6002},
+        {  817, 6226},{  869, 6393},{  916, 6530},{  950, 6799}
+      },
+      /*Cb  qi=17  INTER*/
+      {
+        {  105,  -65},{   86,  288},{   66,  638},{   54, 1014},
+        {   59, 1427},{   71, 1844},{   86, 2257},{   95, 2668},
+        {  100, 3075},{  103, 3476},{  106, 3867},{  110, 4241},
+        {  112, 4598},{  114, 4948},{  117, 5294},{  121, 5633},
+        {  123, 5968},{  126, 6301},{  131, 6637},{  136, 6968},
+        {  144, 7287},{  152, 7606},{  158, 7931},{  162, 8262}
+      }
+    },
+    {
+      /*Cr  qi=17  INTRA*/
+      {
+        {    4,    6},{   55,  376},{   97,  765},{  128, 1226},
+        {  152, 1696},{  175, 2144},{  204, 2568},{  241, 2928},
+        {  282, 3250},{  323, 3530},{  368, 3811},{  420, 4089},
+        {  463, 4347},{  505, 4609},{  562, 4860},{  609, 5094},
+        {  655, 5303},{  709, 5535},{  759, 5740},{  803, 5913},
+        {  844, 6153},{  879, 6350},{  905, 6527},{  972, 6637}
+      },
+      /*Cr  qi=17  INTER*/
+      {
+        {   88,    8},{   68,  330},{   51,  653},{   54, 1028},
+        {   65, 1433},{   77, 1845},{   89, 2257},{   96, 2669},
+        {  100, 3081},{  102, 3481},{  105, 3867},{  106, 4245},
+        {  108, 4613},{  110, 4971},{  112, 5328},{  115, 5679},
+        {  120, 6019},{  127, 6355},{  133, 6686},{  140, 7007},
+        {  149, 7316},{  158, 7618},{  166, 7924},{  170, 8232}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=18  INTRA*/
+      {
+        {  122,  -58},{  216, 1506},{  425, 2815},{  665, 3822},
+        {  882, 4666},{ 1088, 5425},{ 1301, 6084},{ 1529, 6653},
+        { 1766, 7162},{ 2026, 7611},{ 2312, 7987},{ 2612, 8278},
+        { 2913, 8551},{ 3196, 8840},{ 3454, 9184},{ 3734, 9490},
+        { 4030, 9725},{ 4305, 9973},{ 4585,10162},{ 4864,10251},
+        { 5150,10324},{ 5443,10420},{ 5727,10536},{ 6053,10682}
+      },
+      /*Y'  qi=18  INTER*/
+      {
+        {   66, -143},{   47, 1351},{  108, 2886},{  158, 4401},
+        {  200, 5775},{  232, 7044},{  256, 8288},{  292, 9493},
+        {  351,10625},{  434,11679},{  541,12665},{  681,13578},
+        {  875,14379},{ 1136,15025},{ 1483,15475},{ 1914,15709},
+        { 2399,15767},{ 2907,15699},{ 3400,15579},{ 3852,15453},
+        { 4259,15332},{ 4630,15221},{ 4976,15121},{ 5294,15061}
+      }
+    },
+    {
+      /*Cb  qi=18  INTRA*/
+      {
+        {    2,    3},{   61,  367},{  107,  743},{  131, 1182},
+        {  155, 1648},{  183, 2110},{  220, 2542},{  260, 2927},
+        {  303, 3265},{  359, 3540},{  416, 3785},{  462, 4063},
+        {  506, 4334},{  553, 4567},{  595, 4797},{  636, 5049},
+        {  676, 5304},{  717, 5516},{  759, 5698},{  801, 5904},
+        {  861, 6133},{  911, 6311},{  962, 6443},{ 1021, 6645}
+      },
+      /*Cb  qi=18  INTER*/
+      {
+        {  126,    5},{   95,  326},{   66,  643},{   55, 1015},
+        {   60, 1427},{   73, 1843},{   87, 2256},{   96, 2667},
+        {  101, 3073},{  104, 3470},{  108, 3853},{  111, 4226},
+        {  114, 4584},{  117, 4928},{  119, 5274},{  122, 5612},
+        {  126, 5942},{  130, 6271},{  136, 6606},{  141, 6931},
+        {  148, 7247},{  156, 7568},{  164, 7891},{  173, 8211}
+      }
+    },
+    {
+      /*Cr  qi=18  INTRA*/
+      {
+        {    4,    6},{   59,  376},{  104,  765},{  133, 1226},
+        {  156, 1692},{  184, 2136},{  218, 2548},{  260, 2893},
+        {  308, 3204},{  348, 3481},{  397, 3751},{  448, 4024},
+        {  490, 4281},{  541, 4523},{  593, 4776},{  634, 5022},
+        {  685, 5236},{  748, 5455},{  812, 5638},{  856, 5818},
+        {  891, 6048},{  928, 6230},{  961, 6405},{ 1055, 6449}
+      },
+      /*Cr  qi=18  INTER*/
+      {
+        {   81,   34},{   68,  342},{   57,  652},{   59, 1027},
+        {   67, 1439},{   80, 1848},{   91, 2257},{   97, 2670},
+        {  100, 3076},{  103, 3473},{  106, 3857},{  108, 4231},
+        {  109, 4599},{  110, 4958},{  113, 5307},{  119, 5650},
+        {  125, 5991},{  130, 6325},{  138, 6651},{  147, 6971},
+        {  153, 7278},{  162, 7578},{  172, 7874},{  177, 8156}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=19  INTRA*/
+      {
+        {  128,  -55},{  228, 1495},{  448, 2775},{  699, 3758},
+        {  931, 4571},{ 1154, 5296},{ 1386, 5914},{ 1636, 6450},
+        { 1894, 6930},{ 2177, 7342},{ 2479, 7698},{ 2792, 7976},
+        { 3099, 8235},{ 3392, 8517},{ 3658, 8853},{ 3938, 9155},
+        { 4242, 9371},{ 4527, 9605},{ 4810, 9781},{ 5089, 9853},
+        { 5378, 9920},{ 5674,10009},{ 5972,10110},{ 6336,10196}
+      },
+      /*Y'  qi=19  INTER*/
+      {
+        {   69, -147},{   49, 1353},{  111, 2883},{  162, 4381},
+        {  205, 5737},{  237, 6996},{  264, 8232},{  307, 9421},
+        {  376,10534},{  472,11567},{  596,12525},{  761,13395},
+        {  990,14130},{ 1298,14694},{ 1695,15053},{ 2172,15195},
+        { 2696,15173},{ 3213,15075},{ 3696,14948},{ 4141,14829},
+        { 4541,14721},{ 4910,14609},{ 5245,14506},{ 5536,14399}
+      }
+    },
+    {
+      /*Cb  qi=19  INTRA*/
+      {
+        {    3,    3},{   61,  367},{  109,  743},{  135, 1182},
+        {  161, 1646},{  191, 2101},{  229, 2524},{  273, 2898},
+        {  318, 3221},{  376, 3490},{  436, 3731},{  487, 3994},
+        {  539, 4251},{  584, 4485},{  621, 4721},{  664, 4967},
+        {  709, 5225},{  752, 5431},{  801, 5595},{  846, 5796},
+        {  912, 6011},{  959, 6193},{ 1015, 6321},{ 1121, 6504}
+      },
+      /*Cb  qi=19  INTER*/
+      {
+        {  126,    4},{   97,  329},{   69,  649},{   56, 1017},
+        {   61, 1432},{   74, 1846},{   88, 2255},{   98, 2663},
+        {  103, 3065},{  106, 3460},{  110, 3844},{  114, 4211},
+        {  117, 4564},{  120, 4911},{  122, 5253},{  125, 5588},
+        {  129, 5916},{  135, 6241},{  142, 6567},{  149, 6885},
+        {  155, 7206},{  163, 7527},{  174, 7843},{  188, 8145}
+      }
+    },
+    {
+      /*Cr  qi=19  INTRA*/
+      {
+        {    5,    6},{   61,  376},{  106,  765},{  135, 1225},
+        {  160, 1689},{  192, 2126},{  229, 2531},{  271, 2869},
+        {  321, 3168},{  370, 3433},{  421, 3704},{  476, 3965},
+        {  520, 4212},{  572, 4452},{  629, 4691},{  671, 4939},
+        {  724, 5152},{  792, 5347},{  858, 5510},{  895, 5696},
+        {  939, 5905},{  991, 6056},{ 1027, 6244},{ 1127, 6333}
+      },
+      /*Cr  qi=19  INTER*/
+      {
+        {   80,   45},{   66,  344},{   55,  654},{   56, 1030},
+        {   66, 1440},{   80, 1850},{   91, 2259},{   98, 2668},
+        {  102, 3072},{  104, 3466},{  107, 3845},{  109, 4215},
+        {  110, 4578},{  112, 4933},{  116, 5283},{  122, 5625},
+        {  129, 5963},{  136, 6287},{  143, 6611},{  151, 6927},
+        {  160, 7229},{  170, 7528},{  181, 7818},{  191, 8092}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=20  INTRA*/
+      {
+        {  129,  -50},{  238, 1481},{  469, 2728},{  730, 3684},
+        {  974, 4473},{ 1213, 5171},{ 1463, 5763},{ 1729, 6281},
+        { 2002, 6744},{ 2299, 7146},{ 2613, 7492},{ 2940, 7746},
+        { 3265, 7978},{ 3571, 8228},{ 3853, 8543},{ 4156, 8815},
+        { 4476, 9001},{ 4775, 9218},{ 5070, 9373},{ 5352, 9446},
+        { 5649, 9510},{ 5956, 9580},{ 6268, 9660},{ 6647, 9705}
+      },
+      /*Y'  qi=20  INTER*/
+      {
+        {   64,  -93},{   52, 1340},{  116, 2862},{  170, 4344},
+        {  216, 5678},{  249, 6928},{  281, 8155},{  333, 9326},
+        {  418,10410},{  533,11411},{  683,12329},{  890,13127},
+        { 1183,13750},{ 1579,14162},{ 2066,14357},{ 2611,14370},
+        { 3159,14284},{ 3675,14167},{ 4142,14053},{ 4568,13953},
+        { 4961,13852},{ 5320,13755},{ 5649,13675},{ 5933,13610}
+      }
+    },
+    {
+      /*Cb  qi=20  INTRA*/
+      {
+        {    3,    3},{   62,  367},{  112,  743},{  140, 1183},
+        {  165, 1646},{  196, 2099},{  235, 2517},{  284, 2883},
+        {  334, 3198},{  393, 3460},{  457, 3690},{  509, 3945},
+        {  560, 4198},{  605, 4435},{  647, 4658},{  699, 4888},
+        {  742, 5155},{  788, 5350},{  835, 5517},{  880, 5730},
+        {  956, 5914},{ 1007, 6060},{ 1053, 6199},{ 1158, 6358}
+      },
+      /*Cb  qi=20  INTER*/
+      {
+        {  128,   -6},{   96,  322},{   66,  653},{   54, 1025},
+        {   63, 1431},{   79, 1844},{   91, 2256},{   99, 2665},
+        {  104, 3065},{  107, 3455},{  111, 3831},{  115, 4189},
+        {  120, 4539},{  123, 4885},{  126, 5219},{  130, 5548},
+        {  135, 5876},{  141, 6199},{  149, 6519},{  156, 6837},
+        {  166, 7153},{  179, 7468},{  189, 7784},{  194, 8102}
+      }
+    },
+    {
+      /*Cr  qi=20  INTRA*/
+      {
+        {    4,    6},{   63,  376},{  109,  765},{  139, 1225},
+        {  165, 1689},{  199, 2124},{  239, 2523},{  285, 2852},
+        {  340, 3140},{  388, 3398},{  438, 3662},{  499, 3914},
+        {  547, 4155},{  596, 4392},{  652, 4634},{  699, 4877},
+        {  759, 5074},{  824, 5257},{  883, 5428},{  936, 5589},
+        {  986, 5790},{ 1030, 5960},{ 1074, 6119},{ 1172, 6191}
+      },
+      /*Cr  qi=20  INTER*/
+      {
+        {   92,   40},{   70,  345},{   55,  658},{   57, 1034},
+        {   69, 1441},{   84, 1852},{   94, 2261},{   98, 2669},
+        {  102, 3074},{  105, 3465},{  107, 3841},{  110, 4206},
+        {  112, 4562},{  116, 4915},{  121, 5260},{  127, 5591},
+        {  134, 5920},{  142, 6246},{  153, 6562},{  163, 6870},
+        {  173, 7170},{  186, 7463},{  198, 7746},{  199, 8030}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=21  INTRA*/
+      {
+        {  130,  -51},{  244, 1476},{  483, 2705},{  756, 3635},
+        { 1013, 4396},{ 1266, 5070},{ 1530, 5647},{ 1806, 6153},
+        { 2093, 6600},{ 2411, 6976},{ 2739, 7299},{ 3079, 7534},
+        { 3422, 7744},{ 3738, 7987},{ 4032, 8274},{ 4348, 8533},
+        { 4675, 8721},{ 4989, 8909},{ 5291, 9051},{ 5577, 9111},
+        { 5879, 9163},{ 6190, 9228},{ 6506, 9286},{ 6899, 9295}
+      },
+      /*Y'  qi=21  INTER*/
+      {
+        {   64,  -56},{   55, 1341},{  119, 2859},{  174, 4324},
+        {  223, 5640},{  258, 6880},{  295, 8096},{  359, 9246},
+        {  460,10302},{  595,11268},{  778,12131},{ 1032,12857},
+        { 1387,13385},{ 1850,13683},{ 2399,13774},{ 2976,13729},
+        { 3527,13619},{ 4034,13504},{ 4492,13401},{ 4912,13291},
+        { 5298,13209},{ 5648,13137},{ 5974,13046},{ 6308,12977}
+      }
+    },
+    {
+      /*Cb  qi=21  INTRA*/
+      {
+        {    4,    3},{   64,  367},{  114,  743},{  141, 1183},
+        {  166, 1645},{  201, 2092},{  247, 2502},{  299, 2856},
+        {  352, 3158},{  413, 3412},{  480, 3642},{  536, 3893},
+        {  588, 4137},{  637, 4367},{  678, 4598},{  725, 4834},
+        {  774, 5083},{  827, 5269},{  883, 5420},{  930, 5633},
+        {  999, 5829},{ 1057, 5959},{ 1113, 6082},{ 1200, 6265}
+      },
+      /*Cb  qi=21  INTER*/
+      {
+        {  109,   -8},{   84,  321},{   62,  654},{   54, 1028},
+        {   64, 1434},{   80, 1847},{   92, 2259},{  100, 2664},
+        {  105, 3060},{  109, 3445},{  114, 3815},{  118, 4172},
+        {  122, 4519},{  126, 4861},{  128, 5194},{  133, 5520},
+        {  139, 5847},{  146, 6169},{  155, 6487},{  166, 6801},
+        {  177, 7114},{  189, 7423},{  201, 7729},{  208, 8035}
+      }
+    },
+    {
+      /*Cr  qi=21  INTRA*/
+      {
+        {    4,    6},{   64,  377},{  111,  766},{  144, 1225},
+        {  174, 1683},{  206, 2114},{  248, 2506},{  302, 2824},
+        {  357, 3099},{  404, 3357},{  455, 3622},{  519, 3867},
+        {  573, 4098},{  625, 4331},{  683, 4571},{  733, 4802},
+        {  793, 4994},{  863, 5173},{  926, 5337},{  978, 5492},
+        { 1030, 5685},{ 1079, 5856},{ 1126, 6027},{ 1217, 6159}
+      },
+      /*Cr  qi=21  INTER*/
+      {
+        {   82,   29},{   67,  341},{   55,  660},{   58, 1038},
+        {   71, 1443},{   85, 1851},{   95, 2258},{   99, 2666},
+        {  103, 3069},{  107, 3456},{  110, 3826},{  112, 4188},
+        {  114, 4544},{  118, 4891},{  124, 5231},{  132, 5567},
+        {  139, 5894},{  148, 6210},{  159, 6520},{  171, 6822},
+        {  185, 7111},{  196, 7403},{  209, 7691},{  225, 7945}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=22  INTRA*/
+      {
+        {  128,  -45},{  254, 1463},{  507, 2662},{  794, 3562},
+        { 1070, 4292},{ 1340, 4941},{ 1622, 5492},{ 1920, 5968},
+        { 2229, 6387},{ 2565, 6742},{ 2911, 7047},{ 3263, 7264},
+        { 3615, 7464},{ 3944, 7689},{ 4258, 7950},{ 4591, 8183},
+        { 4934, 8347},{ 5259, 8517},{ 5573, 8634},{ 5870, 8683},
+        { 6186, 8723},{ 6508, 8762},{ 6831, 8801},{ 7232, 8830}
+      },
+      /*Y'  qi=22  INTER*/
+      {
+        {   77,  -48},{   57, 1343},{  122, 2853},{  180, 4299},
+        {  231, 5597},{  269, 6826},{  314, 8025},{  393, 9150},
+        {  512,10179},{  673,11103},{  894,11908},{ 1207,12542},
+        { 1635,12956},{ 2166,13148},{ 2755,13167},{ 3345,13088},
+        { 3895,12966},{ 4386,12848},{ 4832,12746},{ 5252,12647},
+        { 5634,12563},{ 5978,12497},{ 6299,12412},{ 6633,12338}
+      }
+    },
+    {
+      /*Cb  qi=22  INTRA*/
+      {
+        {    4,    3},{   66,  367},{  122,  744},{  153, 1182},
+        {  177, 1640},{  213, 2080},{  263, 2475},{  323, 2811},
+        {  382, 3103},{  451, 3346},{  522, 3568},{  581, 3814},
+        {  633, 4054},{  674, 4288},{  719, 4523},{  768, 4756},
+        {  823, 4979},{  883, 5162},{  937, 5325},{  996, 5510},
+        { 1070, 5687},{ 1129, 5807},{ 1193, 5929},{ 1311, 6099}
+      },
+      /*Cb  qi=22  INTER*/
+      {
+        {  107,   -5},{   83,  322},{   61,  653},{   55, 1030},
+        {   66, 1436},{   81, 1845},{   94, 2253},{  102, 2656},
+        {  107, 3050},{  111, 3435},{  115, 3804},{  119, 4158},
+        {  124, 4501},{  128, 4835},{  132, 5164},{  138, 5490},
+        {  146, 5812},{  154, 6128},{  163, 6442},{  174, 6754},
+        {  188, 7060},{  205, 7361},{  219, 7662},{  233, 7953}
+      }
+    },
+    {
+      /*Cr  qi=22  INTRA*/
+      {
+        {    4,    6},{   67,  378},{  118,  767},{  151, 1222},
+        {  182, 1675},{  221, 2097},{  269, 2476},{  329, 2774},
+        {  389, 3039},{  444, 3292},{  500, 3545},{  560, 3788},
+        {  615, 4020},{  671, 4251},{  734, 4484},{  781, 4712},
+        {  850, 4887},{  925, 5060},{  981, 5229},{ 1031, 5369},
+        { 1092, 5549},{ 1148, 5715},{ 1200, 5861},{ 1291, 5943}
+      },
+      /*Cr  qi=22  INTER*/
+      {
+        {   88,   34},{   69,  340},{   57,  657},{   60, 1039},
+        {   73, 1445},{   87, 1851},{   96, 2257},{  100, 2662},
+        {  103, 3058},{  107, 3442},{  111, 3812},{  115, 4172},
+        {  118, 4524},{  123, 4864},{  129, 5199},{  136, 5531},
+        {  145, 5855},{  156, 6168},{  170, 6468},{  184, 6765},
+        {  193, 7066},{  207, 7353},{  222, 7628},{  230, 7900}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=23  INTRA*/
+      {
+        {  126,  -40},{  257, 1458},{  521, 2636},{  825, 3501},
+        { 1111, 4207},{ 1391, 4842},{ 1684, 5385},{ 1992, 5858},
+        { 2311, 6277},{ 2653, 6626},{ 3005, 6929},{ 3366, 7134},
+        { 3729, 7311},{ 4071, 7526},{ 4396, 7770},{ 4734, 7986},
+        { 5086, 8131},{ 5421, 8286},{ 5735, 8404},{ 6033, 8456},
+        { 6357, 8486},{ 6682, 8525},{ 7003, 8573},{ 7387, 8604}
+      },
+      /*Y'  qi=23  INTER*/
+      {
+        {   64,  -57},{   60, 1345},{  124, 2853},{  185, 4284},
+        {  239, 5565},{  282, 6783},{  336, 7967},{  429, 9069},
+        {  568,10063},{  758,10943},{ 1028,11679},{ 1407,12216},
+        { 1909,12520},{ 2502,12616},{ 3126,12573},{ 3722,12461},
+        { 4258,12344},{ 4742,12236},{ 5185,12136},{ 5590,12052},
+        { 5970,11980},{ 6315,11901},{ 6631,11826},{ 6954,11769}
+      }
+    },
+    {
+      /*Cb  qi=23  INTRA*/
+      {
+        {    3,    3},{   70,  367},{  124,  744},{  151, 1182},
+        {  181, 1637},{  222, 2071},{  276, 2460},{  343, 2785},
+        {  403, 3072},{  468, 3317},{  542, 3534},{  605, 3773},
+        {  659, 4009},{  703, 4243},{  747, 4479},{  795, 4707},
+        {  852, 4923},{  908, 5105},{  972, 5254},{ 1043, 5423},
+        { 1118, 5594},{ 1172, 5731},{ 1240, 5853},{ 1365, 6005}
+      },
+      /*Cb  qi=23  INTER*/
+      {
+        {  109,  -10},{   87,  325},{   63,  650},{   57, 1031},
+        {   67, 1439},{   83, 1847},{   96, 2253},{  103, 2652},
+        {  109, 3041},{  114, 3421},{  117, 3789},{  122, 4141},
+        {  128, 4480},{  134, 4811},{  139, 5138},{  144, 5463},
+        {  152, 5781},{  161, 6096},{  174, 6404},{  185, 6714},
+        {  198, 7023},{  216, 7320},{  233, 7621},{  245, 7935}
+      }
+    },
+    {
+      /*Cr  qi=23  INTRA*/
+      {
+        {    5,    6},{   70,  379},{  122,  768},{  155, 1222},
+        {  187, 1671},{  231, 2088},{  283, 2459},{  346, 2750},
+        {  411, 3009},{  465, 3261},{  523, 3509},{  585, 3746},
+        {  639, 3980},{  695, 4219},{  754, 4449},{  803, 4671},
+        {  873, 4840},{  953, 5001},{ 1015, 5156},{ 1071, 5286},
+        { 1137, 5464},{ 1191, 5629},{ 1249, 5782},{ 1359, 5885}
+      },
+      /*Cr  qi=23  INTER*/
+      {
+        {   84,   29},{   69,  343},{   58,  660},{   62, 1041},
+        {   75, 1448},{   88, 1853},{   97, 2258},{  102, 2659},
+        {  105, 3050},{  108, 3430},{  113, 3799},{  116, 4155},
+        {  121, 4505},{  126, 4845},{  132, 5176},{  142, 5504},
+        {  153, 5826},{  165, 6133},{  180, 6432},{  197, 6722},
+        {  212, 7005},{  226, 7287},{  244, 7555},{  258, 7828}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=24  INTRA*/
+      {
+        {  125,  -34},{  268, 1444},{  547, 2590},{  866, 3422},
+        { 1172, 4098},{ 1476, 4702},{ 1790, 5222},{ 2117, 5678},
+        { 2453, 6080},{ 2811, 6418},{ 3178, 6700},{ 3552, 6895},
+        { 3928, 7055},{ 4286, 7243},{ 4627, 7477},{ 4981, 7674},
+        { 5344, 7802},{ 5683, 7944},{ 6009, 8043},{ 6313, 8082},
+        { 6633, 8111},{ 6959, 8151},{ 7280, 8197},{ 7660, 8221}
+      },
+      /*Y'  qi=24  INTER*/
+      {
+        {   62,  -63},{   68, 1345},{  134, 2840},{  199, 4245},
+        {  256, 5508},{  304, 6715},{  371, 7880},{  484, 8950},
+        {  652, 9899},{  892,10709},{ 1238,11334},{ 1722,11722},
+        { 2326,11875},{ 2983,11864},{ 3616,11783},{ 4189,11678},
+        { 4707,11570},{ 5178,11476},{ 5617,11395},{ 6017,11319},
+        { 6380,11252},{ 6720,11185},{ 7044,11126},{ 7377,11118}
+      }
+    },
+    {
+      /*Cb  qi=24  INTRA*/
+      {
+        {    4,    3},{   75,  367},{  132,  745},{  159, 1182},
+        {  187, 1634},{  230, 2061},{  289, 2439},{  361, 2753},
+        {  425, 3034},{  492, 3278},{  566, 3490},{  630, 3720},
+        {  686, 3956},{  732, 4190},{  777, 4420},{  829, 4637},
+        {  894, 4840},{  958, 5012},{ 1023, 5155},{ 1090, 5326},
+        { 1165, 5502},{ 1226, 5622},{ 1299, 5717},{ 1408, 5887}
+      },
+      /*Cb  qi=24  INTER*/
+      {
+        {  110,   35},{   92,  337},{   70,  651},{   63, 1033},
+        {   74, 1440},{   91, 1846},{  102, 2248},{  109, 2644},
+        {  114, 3031},{  120, 3404},{  127, 3762},{  133, 4109},
+        {  138, 4445},{  144, 4772},{  151, 5094},{  159, 5411},
+        {  168, 5728},{  180, 6037},{  195, 6338},{  210, 6640},
+        {  227, 6944},{  249, 7236},{  272, 7528},{  299, 7809}
+      }
+    },
+    {
+      /*Cr  qi=24  INTRA*/
+      {
+        {    5,    6},{   72,  380},{  124,  770},{  158, 1222},
+        {  195, 1668},{  240, 2079},{  297, 2438},{  367, 2715},
+        {  433, 2966},{  488, 3218},{  549, 3467},{  609, 3701},
+        {  664, 3935},{  728, 4165},{  792, 4379},{  845, 4586},
+        {  917, 4744},{  995, 4898},{ 1063, 5049},{ 1120, 5187},
+        { 1190, 5359},{ 1249, 5522},{ 1304, 5672},{ 1397, 5806}
+      },
+      /*Cr  qi=24  INTER*/
+      {
+        {   91,   56},{   73,  353},{   61,  664},{   66, 1045},
+        {   80, 1449},{   95, 1851},{  103, 2250},{  107, 2648},
+        {  111, 3038},{  116, 3413},{  120, 3774},{  124, 4128},
+        {  130, 4471},{  138, 4802},{  145, 5130},{  156, 5453},
+        {  171, 5764},{  187, 6061},{  204, 6355},{  220, 6643},
+        {  238, 6923},{  254, 7204},{  275, 7475},{  289, 7752}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=25  INTRA*/
+      {
+        {  125,  -28},{  285, 1426},{  582, 2540},{  917, 3351},
+        { 1244, 3997},{ 1569, 4570},{ 1903, 5071},{ 2258, 5498},
+        { 2626, 5866},{ 3002, 6182},{ 3382, 6448},{ 3770, 6623},
+        { 4162, 6760},{ 4528, 6934},{ 4882, 7144},{ 5249, 7328},
+        { 5610, 7453},{ 5958, 7578},{ 6291, 7672},{ 6597, 7708},
+        { 6928, 7715},{ 7258, 7737},{ 7575, 7781},{ 7950, 7829}
+      },
+      /*Y'  qi=25  INTER*/
+      {
+        {   64,  -16},{   72, 1348},{  139, 2832},{  206, 4218},
+        {  268, 5465},{  322, 6659},{  403, 7803},{  540, 8838},
+        {  747, 9734},{ 1044,10465},{ 1473,10981},{ 2048,11249},
+        { 2717,11311},{ 3397,11257},{ 4025,11161},{ 4589,11052},
+        { 5099,10947},{ 5560,10859},{ 5989,10786},{ 6389,10717},
+        { 6753,10652},{ 7078,10592},{ 7389,10535},{ 7697,10460}
+      }
+    },
+    {
+      /*Cb  qi=25  INTRA*/
+      {
+        {    3,    3},{   78,  368},{  133,  745},{  159, 1180},
+        {  193, 1627},{  242, 2046},{  304, 2411},{  381, 2714},
+        {  456, 2983},{  527, 3224},{  598, 3437},{  667, 3655},
+        {  726, 3888},{  776, 4117},{  826, 4333},{  883, 4543},
+        {  954, 4727},{ 1019, 4878},{ 1095, 5014},{ 1171, 5187},
+        { 1255, 5342},{ 1319, 5458},{ 1396, 5546},{ 1536, 5678}
+      },
+      /*Cb  qi=25  INTER*/
+      {
+        {  117,   32},{   89,  342},{   67,  660},{   64, 1037},
+        {   77, 1441},{   93, 1845},{  105, 2243},{  113, 2633},
+        {  120, 3016},{  125, 3387},{  131, 3739},{  137, 4080},
+        {  144, 4416},{  152, 4741},{  160, 5057},{  169, 5369},
+        {  180, 5680},{  193, 5990},{  209, 6294},{  227, 6594},
+        {  249, 6888},{  269, 7180},{  294, 7467},{  317, 7768}
+      }
+    },
+    {
+      /*Cr  qi=25  INTRA*/
+      {
+        {    6,    6},{   74,  380},{  129,  770},{  165, 1220},
+        {  201, 1658},{  253, 2061},{  315, 2410},{  388, 2676},
+        {  462, 2920},{  523, 3166},{  584, 3404},{  647, 3637},
+        {  701, 3870},{  769, 4086},{  838, 4296},{  898, 4491},
+        {  980, 4627},{ 1065, 4759},{ 1126, 4920},{ 1187, 5058},
+        { 1283, 5180},{ 1347, 5332},{ 1404, 5475},{ 1527, 5534}
+      },
+      /*Cr  qi=25  INTER*/
+      {
+        {   92,   41},{   75,  347},{   64,  664},{   70, 1045},
+        {   85, 1448},{   98, 1849},{  105, 2245},{  110, 2637},
+        {  115, 3023},{  120, 3395},{  126, 3753},{  131, 4102},
+        {  136, 4439},{  145, 4768},{  156, 5094},{  168, 5410},
+        {  184, 5717},{  203, 6010},{  221, 6300},{  239, 6577},
+        {  262, 6847},{  282, 7123},{  303, 7390},{  322, 7665}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=26  INTRA*/
+      {
+        {  130,  -24},{  292, 1423},{  594, 2525},{  943, 3307},
+        { 1289, 3921},{ 1633, 4467},{ 1991, 4943},{ 2368, 5348},
+        { 2753, 5696},{ 3148, 5991},{ 3545, 6247},{ 3942, 6415},
+        { 4342, 6535},{ 4726, 6690},{ 5093, 6883},{ 5466, 7047},
+        { 5840, 7159},{ 6202, 7274},{ 6545, 7351},{ 6855, 7375},
+        { 7186, 7384},{ 7517, 7416},{ 7840, 7447},{ 8238, 7450}
+      },
+      /*Y'  qi=26  INTER*/
+      {
+        {   52,   16},{   75, 1336},{  143, 2815},{  213, 4191},
+        {  278, 5427},{  339, 6611},{  436, 7734},{  600, 8732},
+        {  843, 9579},{ 1195,10243},{ 1702,10660},{ 2355,10825},
+        { 3070,10820},{ 3755,10743},{ 4372,10643},{ 4925,10538},
+        { 5426,10440},{ 5882,10354},{ 6296,10290},{ 6686,10224},
+        { 7049,10163},{ 7380,10113},{ 7672,10062},{ 7937,10021}
+      }
+    },
+    {
+      /*Cb  qi=26  INTRA*/
+      {
+        {    4,    3},{   79,  368},{  138,  745},{  167, 1180},
+        {  200, 1623},{  252, 2034},{  322, 2389},{  403, 2682},
+        {  480, 2941},{  558, 3176},{  631, 3393},{  700, 3608},
+        {  766, 3825},{  819, 4046},{  868, 4265},{  926, 4472},
+        { 1002, 4645},{ 1070, 4800},{ 1151, 4924},{ 1242, 5063},
+        { 1325, 5221},{ 1393, 5338},{ 1464, 5431},{ 1595, 5559}
+      },
+      /*Cb  qi=26  INTER*/
+      {
+        {   98,   33},{   83,  343},{   65,  662},{   65, 1037},
+        {   80, 1437},{   96, 1839},{  107, 2238},{  115, 2628},
+        {  122, 3007},{  128, 3373},{  134, 3722},{  142, 4060},
+        {  149, 4390},{  158, 4713},{  167, 5029},{  178, 5341},
+        {  191, 5647},{  208, 5948},{  227, 6244},{  247, 6539},
+        {  269, 6833},{  295, 7114},{  328, 7388},{  369, 7658}
+      }
+    },
+    {
+      /*Cr  qi=26  INTRA*/
+      {
+        {    5,    6},{   75,  380},{  133,  769},{  172, 1217},
+        {  212, 1652},{  266, 2048},{  333, 2384},{  412, 2643},
+        {  490, 2880},{  552, 3124},{  616, 3365},{  681, 3594},
+        {  739, 3816},{  810, 4024},{  880, 4224},{  945, 4405},
+        { 1029, 4538},{ 1114, 4674},{ 1183, 4822},{ 1254, 4946},
+        { 1346, 5063},{ 1417, 5201},{ 1478, 5345},{ 1597, 5411}
+      },
+      /*Cr  qi=26  INTER*/
+      {
+        {   97,   29},{   75,  342},{   62,  667},{   70, 1047},
+        {   87, 1447},{  100, 1846},{  107, 2242},{  113, 2633},
+        {  118, 3016},{  123, 3382},{  128, 3737},{  135, 4082},
+        {  142, 4417},{  151, 4746},{  162, 5066},{  176, 5377},
+        {  194, 5679},{  217, 5963},{  239, 6244},{  260, 6522},
+        {  284, 6789},{  309, 7052},{  335, 7313},{  355, 7582}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=27  INTRA*/
+      {
+        {  118,  -10},{  308, 1404},{  630, 2473},{  997, 3227},
+        { 1360, 3819},{ 1719, 4354},{ 2086, 4829},{ 2470, 5233},
+        { 2863, 5576},{ 3267, 5870},{ 3677, 6117},{ 4085, 6268},
+        { 4499, 6376},{ 4888, 6521},{ 5257, 6705},{ 5638, 6865},
+        { 6020, 6962},{ 6394, 7056},{ 6744, 7130},{ 7051, 7158},
+        { 7386, 7164},{ 7717, 7185},{ 8042, 7209},{ 8444, 7206}
+      },
+      /*Y'  qi=27  INTER*/
+      {
+        {   54,   19},{   77, 1333},{  147, 2806},{  221, 4166},
+        {  290, 5390},{  360, 6564},{  474, 7665},{  664, 8630},
+        {  949, 9423},{ 1370,10002},{ 1958,10323},{ 2670,10414},
+        { 3406,10375},{ 4086,10285},{ 4691,10182},{ 5233,10085},
+        { 5724, 9994},{ 6169, 9918},{ 6582, 9863},{ 6962, 9813},
+        { 7316, 9759},{ 7645, 9707},{ 7948, 9660},{ 8262, 9623}
+      }
+    },
+    {
+      /*Cb  qi=27  INTRA*/
+      {
+        {    4,    3},{   79,  368},{  137,  745},{  166, 1180},
+        {  200, 1622},{  253, 2030},{  324, 2381},{  407, 2671},
+        {  487, 2925},{  567, 3156},{  640, 3372},{  712, 3580},
+        {  782, 3792},{  833, 4015},{  887, 4227},{  954, 4422},
+        { 1031, 4592},{ 1103, 4738},{ 1187, 4856},{ 1280, 4990},
+        { 1371, 5135},{ 1442, 5244},{ 1520, 5321},{ 1684, 5398}
+      },
+      /*Cb  qi=27  INTER*/
+      {
+        {  113,   20},{   90,  338},{   66,  661},{   67, 1034},
+        {   82, 1438},{   97, 1842},{  108, 2238},{  115, 2624},
+        {  123, 3000},{  130, 3361},{  138, 3708},{  146, 4040},
+        {  155, 4367},{  164, 4688},{  174, 4999},{  186, 5306},
+        {  203, 5609},{  222, 5908},{  243, 6202},{  268, 6494},
+        {  295, 6781},{  326, 7058},{  367, 7319},{  420, 7551}
+      }
+    },
+    {
+      /*Cr  qi=27  INTRA*/
+      {
+        {    5,    6},{   75,  380},{  133,  770},{  173, 1217},
+        {  214, 1650},{  268, 2040},{  337, 2375},{  418, 2631},
+        {  496, 2862},{  558, 3104},{  625, 3346},{  692, 3571},
+        {  753, 3786},{  825, 3989},{  896, 4182},{  969, 4352},
+        { 1059, 4479},{ 1144, 4614},{ 1212, 4757},{ 1284, 4871},
+        { 1380, 4982},{ 1457, 5125},{ 1528, 5267},{ 1651, 5346}
+      },
+      /*Cr  qi=27  INTER*/
+      {
+        {   92,   24},{   74,  341},{   61,  669},{   71, 1049},
+        {   88, 1448},{  100, 1849},{  107, 2243},{  113, 2631},
+        {  119, 3010},{  125, 3373},{  131, 3723},{  137, 4064},
+        {  146, 4396},{  159, 4720},{  172, 5033},{  189, 5340},
+        {  210, 5636},{  233, 5920},{  256, 6197},{  282, 6465},
+        {  310, 6730},{  332, 7000},{  359, 7259},{  385, 7515}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=28  INTRA*/
+      {
+        {  116,   -8},{  314, 1400},{  640, 2458},{ 1013, 3197},
+        { 1386, 3768},{ 1762, 4279},{ 2151, 4733},{ 2558, 5117},
+        { 2970, 5442},{ 3393, 5714},{ 3820, 5935},{ 4243, 6069},
+        { 4671, 6161},{ 5074, 6289},{ 5456, 6457},{ 5849, 6598},
+        { 6244, 6689},{ 6632, 6777},{ 6984, 6833},{ 7294, 6855},
+        { 7625, 6862},{ 7961, 6875},{ 8302, 6890},{ 8720, 6883}
+      },
+      /*Y'  qi=28  INTER*/
+      {
+        {   54,    8},{   81, 1333},{  154, 2793},{  231, 4138},
+        {  304, 5352},{  384, 6512},{  519, 7585},{  743, 8508},
+        { 1082, 9236},{ 1587, 9717},{ 2267, 9928},{ 3034, 9944},
+        { 3775, 9878},{ 4438, 9786},{ 5031, 9686},{ 5563, 9601},
+        { 6042, 9523},{ 6481, 9456},{ 6890, 9405},{ 7266, 9356},
+        { 7614, 9313},{ 7933, 9265},{ 8238, 9220},{ 8545, 9193}
+      }
+    },
+    {
+      /*Cb  qi=28  INTRA*/
+      {
+        {    3,    3},{   80,  368},{  138,  746},{  168, 1179},
+        {  208, 1615},{  268, 2014},{  345, 2354},{  432, 2637},
+        {  515, 2884},{  595, 3108},{  669, 3323},{  745, 3533},
+        {  818, 3740},{  876, 3953},{  932, 4160},{ 1003, 4349},
+        { 1088, 4501},{ 1154, 4648},{ 1241, 4768},{ 1349, 4889},
+        { 1441, 5023},{ 1524, 5113},{ 1611, 5187},{ 1783, 5283}
+      },
+      /*Cb  qi=28  INTER*/
+      {
+        {  117,   29},{   91,  341},{   65,  663},{   68, 1038},
+        {   85, 1440},{  100, 1841},{  110, 2234},{  119, 2616},
+        {  127, 2985},{  135, 3342},{  142, 3685},{  151, 4015},
+        {  162, 4337},{  174, 4652},{  186, 4960},{  201, 5264},
+        {  218, 5567},{  239, 5863},{  266, 6149},{  295, 6434},
+        {  328, 6715},{  371, 6976},{  409, 7239},{  460, 7477}
+      }
+    },
+    {
+      /*Cr  qi=28  INTRA*/
+      {
+        {    6,    7},{   79,  381},{  138,  771},{  178, 1215},
+        {  222, 1644},{  285, 2026},{  359, 2347},{  441, 2597},
+        {  521, 2827},{  588, 3066},{  655, 3303},{  725, 3523},
+        {  791, 3728},{  870, 3920},{  950, 4103},{ 1030, 4265},
+        { 1121, 4388},{ 1198, 4520},{ 1266, 4659},{ 1356, 4759},
+        { 1461, 4865},{ 1540, 4993},{ 1619, 5115},{ 1786, 5160}
+      },
+      /*Cr  qi=28  INTER*/
+      {
+        {   96,   18},{   78,  340},{   66,  672},{   74, 1051},
+        {   90, 1450},{  103, 1845},{  110, 2235},{  116, 2619},
+        {  122, 2995},{  129, 3356},{  137, 3702},{  146, 4038},
+        {  156, 4365},{  168, 4684},{  182, 4995},{  203, 5297},
+        {  227, 5588},{  253, 5866},{  282, 6131},{  311, 6394},
+        {  339, 6664},{  366, 6918},{  400, 7171},{  424, 7450}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=29  INTRA*/
+      {
+        {  112,    7},{  334, 1382},{  681, 2410},{ 1081, 3112},
+        { 1484, 3650},{ 1894, 4128},{ 2316, 4547},{ 2749, 4905},
+        { 3188, 5208},{ 3634, 5458},{ 4079, 5666},{ 4517, 5791},
+        { 4952, 5870},{ 5359, 5983},{ 5754, 6137},{ 6165, 6268},
+        { 6568, 6351},{ 6958, 6423},{ 7320, 6471},{ 7638, 6490},
+        { 7979, 6490},{ 8313, 6499},{ 8651, 6517},{ 9085, 6499}
+      },
+      /*Y'  qi=29  INTER*/
+      {
+        {   55,   15},{   85, 1336},{  160, 2780},{  242, 4104},
+        {  323, 5302},{  418, 6443},{  586, 7480},{  859, 8342},
+        { 1278, 8982},{ 1888, 9347},{ 2658, 9457},{ 3457, 9425},
+        { 4192, 9343},{ 4842, 9247},{ 5417, 9162},{ 5935, 9086},
+        { 6404, 9011},{ 6841, 8952},{ 7241, 8907},{ 7609, 8867},
+        { 7953, 8832},{ 8267, 8792},{ 8562, 8740},{ 8836, 8701}
+      }
+    },
+    {
+      /*Cb  qi=29  INTRA*/
+      {
+        {    5,    3},{   84,  368},{  144,  746},{  176, 1175},
+        {  219, 1604},{  285, 1991},{  372, 2318},{  462, 2591},
+        {  546, 2833},{  628, 3058},{  704, 3274},{  788, 3473},
+        {  870, 3664},{  935, 3865},{  995, 4059},{ 1072, 4239},
+        { 1167, 4388},{ 1248, 4518},{ 1334, 4634},{ 1429, 4765},
+        { 1536, 4884},{ 1628, 4964},{ 1716, 5038},{ 1885, 5128}
+      },
+      /*Cb  qi=29  INTER*/
+      {
+        {  126,   25},{   95,  340},{   69,  662},{   71, 1039},
+        {   88, 1440},{  102, 1839},{  113, 2227},{  122, 2604},
+        {  132, 2969},{  141, 3320},{  151, 3659},{  161, 3985},
+        {  172, 4301},{  186, 4612},{  200, 4917},{  219, 5213},
+        {  241, 5509},{  265, 5800},{  296, 6081},{  329, 6360},
+        {  369, 6633},{  414, 6899},{  465, 7148},{  520, 7387}
+      }
+    },
+    {
+      /*Cr  qi=29  INTRA*/
+      {
+        {    6,    7},{   82,  382},{  142,  772},{  185, 1211},
+        {  233, 1632},{  303, 2000},{  388, 2306},{  475, 2550},
+        {  556, 2779},{  627, 3007},{  707, 3237},{  778, 3459},
+        {  843, 3654},{  927, 3834},{ 1012, 4012},{ 1101, 4152},
+        { 1197, 4262},{ 1275, 4399},{ 1359, 4511},{ 1455, 4596},
+        { 1562, 4708},{ 1644, 4833},{ 1719, 4954},{ 1888, 4988}
+      },
+      /*Cr  qi=29  INTER*/
+      {
+        {  101,   28},{   81,  343},{   67,  673},{   75, 1053},
+        {   93, 1450},{  106, 1844},{  113, 2230},{  119, 2610},
+        {  127, 2980},{  135, 3334},{  143, 3676},{  153, 4007},
+        {  165, 4330},{  180, 4645},{  201, 4951},{  224, 5243},
+        {  253, 5522},{  284, 5794},{  314, 6060},{  345, 6322},
+        {  381, 6578},{  419, 6828},{  455, 7073},{  495, 7316}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=30  INTRA*/
+      {
+        {  112,    8},{  335, 1380},{  682, 2401},{ 1083, 3093},
+        { 1489, 3619},{ 1902, 4092},{ 2332, 4511},{ 2777, 4865},
+        { 3231, 5156},{ 3693, 5394},{ 4153, 5585},{ 4605, 5689},
+        { 5049, 5764},{ 5468, 5871},{ 5875, 6004},{ 6295, 6120},
+        { 6706, 6201},{ 7099, 6273},{ 7461, 6311},{ 7785, 6320},
+        { 8128, 6322},{ 8469, 6331},{ 8806, 6342},{ 9220, 6338}
+      },
+      /*Y'  qi=30  INTER*/
+      {
+        {   58,    8},{   90, 1340},{  169, 2771},{  257, 4079},
+        {  345, 5266},{  459, 6387},{  660, 7383},{  990, 8180},
+        { 1496, 8726},{ 2203, 8992},{ 3029, 9038},{ 3833, 8984},
+        { 4549, 8900},{ 5183, 8813},{ 5745, 8735},{ 6250, 8674},
+        { 6715, 8619},{ 7138, 8565},{ 7529, 8528},{ 7899, 8495},
+        { 8234, 8465},{ 8550, 8429},{ 8856, 8395},{ 9160, 8374}
+      }
+    },
+    {
+      /*Cb  qi=30  INTRA*/
+      {
+        {    7,    3},{   88,  369},{  149,  747},{  185, 1175},
+        {  232, 1599},{  304, 1976},{  392, 2293},{  486, 2557},
+        {  573, 2797},{  656, 3027},{  735, 3243},{  819, 3442},
+        {  903, 3629},{  966, 3828},{ 1025, 4027},{ 1105, 4204},
+        { 1201, 4343},{ 1282, 4469},{ 1379, 4575},{ 1486, 4689},
+        { 1588, 4813},{ 1678, 4900},{ 1767, 4969},{ 1911, 5080}
+      },
+      /*Cb  qi=30  INTER*/
+      {
+        {  120,   23},{   96,  336},{   72,  661},{   75, 1043},
+        {   91, 1441},{  105, 1837},{  117, 2221},{  127, 2592},
+        {  137, 2953},{  148, 3301},{  159, 3635},{  170, 3959},
+        {  184, 4271},{  199, 4578},{  216, 4879},{  238, 5175},
+        {  262, 5466},{  294, 5750},{  332, 6027},{  373, 6298},
+        {  421, 6559},{  473, 6805},{  526, 7053},{  587, 7298}
+      }
+    },
+    {
+      /*Cr  qi=30  INTRA*/
+      {
+        {   10,    7},{   89,  384},{  147,  773},{  192, 1211},
+        {  245, 1627},{  322, 1984},{  412, 2280},{  501, 2520},
+        {  583, 2750},{  654, 2982},{  736, 3207},{  810, 3419},
+        {  873, 3614},{  957, 3794},{ 1048, 3965},{ 1139, 4102},
+        { 1237, 4208},{ 1327, 4328},{ 1408, 4448},{ 1496, 4545},
+        { 1604, 4652},{ 1699, 4760},{ 1780, 4877},{ 1937, 4942}
+      },
+      /*Cr  qi=30  INTER*/
+      {
+        {  115,   26},{   89,  342},{   70,  672},{   79, 1055},
+        {   96, 1451},{  108, 1841},{  116, 2222},{  124, 2599},
+        {  132, 2965},{  141, 3316},{  151, 3655},{  163, 3984},
+        {  178, 4301},{  197, 4609},{  219, 4909},{  247, 5195},
+        {  280, 5469},{  317, 5734},{  351, 5991},{  383, 6248},
+        {  423, 6500},{  467, 6744},{  502, 6995},{  558, 7226}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=31  INTRA*/
+      {
+        {  116,   20},{  359, 1361},{  732, 2350},{ 1162, 3010},
+        { 1597, 3507},{ 2042, 3950},{ 2503, 4339},{ 2974, 4670},
+        { 3446, 4951},{ 3922, 5179},{ 4394, 5357},{ 4858, 5454},
+        { 5313, 5519},{ 5734, 5626},{ 6154, 5755},{ 6585, 5859},
+        { 7004, 5928},{ 7408, 5998},{ 7775, 6039},{ 8102, 6048},
+        { 8442, 6051},{ 8790, 6054},{ 9136, 6057},{ 9554, 6041}
+      },
+      /*Y'  qi=31  INTER*/
+      {
+        {   53,   12},{   90, 1340},{  169, 2765},{  259, 4062},
+        {  353, 5236},{  483, 6340},{  713, 7305},{ 1086, 8059},
+        { 1651, 8548},{ 2423, 8751},{ 3288, 8754},{ 4106, 8674},
+        { 4827, 8572},{ 5451, 8482},{ 6007, 8407},{ 6514, 8344},
+        { 6970, 8282},{ 7397, 8225},{ 7795, 8193},{ 8159, 8161},
+        { 8498, 8120},{ 8814, 8093},{ 9127, 8066},{ 9432, 8040}
+      }
+    },
+    {
+      /*Cb  qi=31  INTRA*/
+      {
+        {    7,    3},{   88,  369},{  149,  746},{  185, 1173},
+        {  234, 1595},{  308, 1967},{  399, 2278},{  494, 2537},
+        {  583, 2774},{  669, 2997},{  755, 3204},{  847, 3390},
+        {  936, 3569},{ 1008, 3759},{ 1078, 3942},{ 1162, 4104},
+        { 1262, 4238},{ 1352, 4364},{ 1442, 4470},{ 1557, 4567},
+        { 1676, 4674},{ 1759, 4781},{ 1850, 4853},{ 2043, 4897}
+      },
+      /*Cb  qi=31  INTER*/
+      {
+        {  121,   23},{   96,  335},{   72,  660},{   74, 1043},
+        {   90, 1440},{  105, 1834},{  116, 2217},{  127, 2586},
+        {  138, 2945},{  148, 3293},{  159, 3626},{  172, 3945},
+        {  185, 4256},{  202, 4559},{  223, 4856},{  245, 5150},
+        {  272, 5440},{  306, 5719},{  346, 5989},{  391, 6253},
+        {  443, 6511},{  510, 6743},{  583, 6965},{  651, 7182}
+      }
+    },
+    {
+      /*Cr  qi=31  INTRA*/
+      {
+        {   10,    7},{   88,  384},{  147,  773},{  192, 1209},
+        {  247, 1622},{  326, 1974},{  417, 2262},{  509, 2500},
+        {  596, 2726},{  670, 2949},{  754, 3170},{  836, 3370},
+        {  912, 3548},{  999, 3724},{ 1093, 3888},{ 1198, 4000},
+        { 1304, 4095},{ 1384, 4230},{ 1470, 4347},{ 1577, 4422},
+        { 1696, 4513},{ 1798, 4620},{ 1869, 4746},{ 1991, 4798}
+      },
+      /*Cr  qi=31  INTER*/
+      {
+        {  113,   32},{   88,  345},{   69,  674},{   79, 1055},
+        {   96, 1451},{  108, 1839},{  115, 2218},{  123, 2592},
+        {  132, 2957},{  141, 3308},{  151, 3643},{  163, 3968},
+        {  179, 4285},{  200, 4590},{  225, 4886},{  254, 5169},
+        {  291, 5436},{  330, 5696},{  368, 5951},{  409, 6200},
+        {  452, 6448},{  493, 6695},{  536, 6940},{  571, 7204}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=32  INTRA*/
+      {
+        {  123,   26},{  370, 1356},{  756, 2321},{ 1211, 2944},
+        { 1674, 3408},{ 2148, 3826},{ 2639, 4193},{ 3138, 4504},
+        { 3634, 4765},{ 4133, 4973},{ 4625, 5137},{ 5101, 5225},
+        { 5567, 5274},{ 6002, 5363},{ 6437, 5482},{ 6885, 5566},
+        { 7312, 5625},{ 7723, 5686},{ 8101, 5721},{ 8429, 5732},
+        { 8769, 5728},{ 9120, 5726},{ 9472, 5723},{ 9918, 5700}
+      },
+      /*Y'  qi=32  INTER*/
+      {
+        {   54,   -3},{   95, 1343},{  179, 2750},{  276, 4027},
+        {  382, 5185},{  543, 6256},{  830, 7161},{ 1301, 7815},
+        { 2003, 8172},{ 2883, 8266},{ 3779, 8217},{ 4578, 8127},
+        { 5274, 8035},{ 5886, 7952},{ 6430, 7887},{ 6929, 7835},
+        { 7380, 7779},{ 7796, 7737},{ 8190, 7705},{ 8552, 7672},
+        { 8896, 7640},{ 9210, 7612},{ 9510, 7589},{ 9746, 7552}
+      }
+    },
+    {
+      /*Cb  qi=32  INTRA*/
+      {
+        {    6,    3},{   89,  369},{  153,  746},{  193, 1167},
+        {  247, 1577},{  330, 1935},{  429, 2236},{  528, 2494},
+        {  620, 2732},{  712, 2948},{  801, 3146},{  898, 3325},
+        {  999, 3489},{ 1078, 3664},{ 1155, 3832},{ 1251, 3985},
+        { 1360, 4115},{ 1451, 4236},{ 1549, 4338},{ 1667, 4433},
+        { 1797, 4522},{ 1891, 4613},{ 1989, 4687},{ 2162, 4776}
+      },
+      /*Cb  qi=32  INTER*/
+      {
+        {  116,   -1},{   98,  321},{   80,  656},{   80, 1042},
+        {   96, 1438},{  110, 1827},{  122, 2205},{  133, 2570},
+        {  144, 2925},{  157, 3268},{  170, 3597},{  185, 3911},
+        {  202, 4216},{  221, 4516},{  244, 4809},{  273, 5096},
+        {  308, 5376},{  350, 5644},{  401, 5907},{  459, 6160},
+        {  520, 6401},{  592, 6630},{  676, 6837},{  758, 7050}
+      }
+    },
+    {
+      /*Cr  qi=32  INTRA*/
+      {
+        {   12,    7},{   91,  386},{  152,  773},{  201, 1202},
+        {  261, 1603},{  347, 1942},{  447, 2223},{  540, 2460},
+        {  626, 2684},{  711, 2901},{  801, 3115},{  887, 3312},
+        {  969, 3480},{ 1068, 3633},{ 1176, 3779},{ 1283, 3885},
+        { 1392, 3969},{ 1485, 4090},{ 1573, 4206},{ 1686, 4274},
+        { 1813, 4354},{ 1911, 4459},{ 2004, 4563},{ 2162, 4590}
+      },
+      /*Cr  qi=32  INTER*/
+      {
+        {  129,    5},{   98,  334},{   75,  673},{   84, 1055},
+        {  101, 1448},{  113, 1832},{  121, 2206},{  129, 2577},
+        {  140, 2937},{  151, 3282},{  163, 3614},{  179, 3932},
+        {  198, 4240},{  221, 4542},{  252, 4830},{  290, 5102},
+        {  329, 5364},{  373, 5618},{  420, 5864},{  468, 6105},
+        {  513, 6351},{  564, 6587},{  624, 6810},{  697, 7017}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=33  INTRA*/
+      {
+        {  115,   36},{  388, 1338},{  791, 2289},{ 1258, 2899},
+        { 1732, 3352},{ 2220, 3760},{ 2730, 4117},{ 3244, 4415},
+        { 3751, 4662},{ 4261, 4858},{ 4766, 5012},{ 5249, 5094},
+        { 5719, 5141},{ 6159, 5225},{ 6597, 5333},{ 7044, 5416},
+        { 7474, 5472},{ 7893, 5531},{ 8268, 5570},{ 8591, 5580},
+        { 8931, 5578},{ 9283, 5579},{ 9634, 5582},{10067, 5560}
+      },
+      /*Y'  qi=33  INTER*/
+      {
+        {   65,  -14},{  102, 1345},{  190, 2736},{  294, 3999},
+        {  411, 5146},{  597, 6192},{  934, 7045},{ 1488, 7622},
+        { 2281, 7895},{ 3213, 7937},{ 4108, 7871},{ 4883, 7784},
+        { 5556, 7709},{ 6150, 7643},{ 6685, 7585},{ 7176, 7539},
+        { 7620, 7502},{ 8034, 7466},{ 8427, 7435},{ 8793, 7409},
+        { 9136, 7386},{ 9446, 7364},{ 9743, 7339},{10025, 7303}
+      }
+    },
+    {
+      /*Cb  qi=33  INTRA*/
+      {
+        {    5,    3},{   92,  369},{  159,  746},{  203, 1163},
+        {  263, 1564},{  353, 1911},{  458, 2204},{  557, 2460},
+        {  650, 2697},{  744, 2913},{  836, 3110},{  934, 3292},
+        { 1036, 3454},{ 1125, 3616},{ 1204, 3781},{ 1298, 3932},
+        { 1410, 4058},{ 1507, 4170},{ 1606, 4265},{ 1725, 4358},
+        { 1853, 4445},{ 1955, 4535},{ 2067, 4597},{ 2258, 4663}
+      },
+      /*Cb  qi=33  INTER*/
+      {
+        {  109,   37},{   94,  343},{   81,  662},{   85, 1042},
+        {  102, 1436},{  116, 1823},{  128, 2195},{  141, 2554},
+        {  154, 2906},{  167, 3246},{  183, 3570},{  202, 3881},
+        {  220, 4185},{  241, 4482},{  268, 4772},{  302, 5053},
+        {  341, 5328},{  388, 5592},{  446, 5846},{  507, 6096},
+        {  581, 6328},{  670, 6534},{  762, 6731},{  842, 6922}
+      }
+    },
+    {
+      /*Cr  qi=33  INTRA*/
+      {
+        {   11,    7},{   93,  387},{  158,  774},{  211, 1197},
+        {  278, 1589},{  372, 1917},{  475, 2191},{  569, 2429},
+        {  658, 2655},{  744, 2868},{  835, 3083},{  926, 3271},
+        { 1010, 3430},{ 1110, 3586},{ 1224, 3724},{ 1336, 3826},
+        { 1449, 3908},{ 1547, 4021},{ 1636, 4136},{ 1751, 4200},
+        { 1886, 4277},{ 1977, 4384},{ 2070, 4474},{ 2232, 4510}
+      },
+      /*Cr  qi=33  INTER*/
+      {
+        {   77,    9},{   90,  347},{   80,  674},{   91, 1053},
+        {  107, 1444},{  119, 1825},{  127, 2196},{  137, 2563},
+        {  149, 2919},{  161, 3259},{  176, 3588},{  194, 3905},
+        {  217, 4209},{  246, 4504},{  280, 4786},{  320, 5055},
+        {  364, 5316},{  409, 5565},{  460, 5804},{  517, 6039},
+        {  578, 6264},{  640, 6489},{  701, 6721},{  772, 6948}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=34  INTRA*/
+      {
+        {  124,   40},{  401, 1333},{  823, 2262},{ 1318, 2842},
+        { 1823, 3265},{ 2339, 3650},{ 2872, 3991},{ 3405, 4274},
+        { 3926, 4513},{ 4448, 4704},{ 4961, 4845},{ 5450, 4921},
+        { 5925, 4971},{ 6372, 5053},{ 6813, 5160},{ 7264, 5242},
+        { 7704, 5291},{ 8124, 5346},{ 8500, 5382},{ 8831, 5384},
+        { 9178, 5380},{ 9525, 5387},{ 9869, 5389},{10310, 5356}
+      },
+      /*Y'  qi=34  INTER*/
+      {
+        {   64,  -17},{  101, 1344},{  190, 2730},{  299, 3981},
+        {  430, 5110},{  648, 6127},{ 1036, 6933},{ 1664, 7445},
+        { 2535, 7652},{ 3504, 7653},{ 4402, 7572},{ 5173, 7479},
+        { 5843, 7400},{ 6441, 7334},{ 6976, 7280},{ 7464, 7231},
+        { 7910, 7189},{ 8332, 7157},{ 8730, 7125},{ 9091, 7103},
+        { 9422, 7086},{ 9753, 7061},{10067, 7036},{10316, 7029}
+      }
+    },
+    {
+      /*Cb  qi=34  INTRA*/
+      {
+        {    5,    3},{   91,  369},{  158,  746},{  204, 1162},
+        {  266, 1561},{  358, 1903},{  466, 2189},{  570, 2439},
+        {  665, 2671},{  765, 2880},{  864, 3069},{  970, 3238},
+        { 1079, 3392},{ 1174, 3545},{ 1265, 3693},{ 1360, 3841},
+        { 1471, 3968},{ 1572, 4083},{ 1675, 4181},{ 1804, 4255},
+        { 1939, 4332},{ 2048, 4411},{ 2155, 4484},{ 2339, 4584}
+      },
+      /*Cb  qi=34  INTER*/
+      {
+        {   99,   44},{   92,  345},{   82,  661},{   86, 1043},
+        {  101, 1436},{  116, 1821},{  128, 2191},{  140, 2549},
+        {  154, 2898},{  168, 3235},{  185, 3556},{  203, 3865},
+        {  224, 4166},{  248, 4457},{  278, 4741},{  315, 5021},
+        {  361, 5289},{  416, 5546},{  483, 5792},{  559, 6025},
+        {  651, 6237},{  752, 6432},{  849, 6626},{  967, 6790}
+      }
+    },
+    {
+      /*Cr  qi=34  INTRA*/
+      {
+        {   11,    7},{   93,  387},{  158,  773},{  212, 1195},
+        {  282, 1584},{  378, 1909},{  483, 2179},{  578, 2414},
+        {  671, 2633},{  766, 2837},{  866, 3038},{  960, 3223},
+        { 1049, 3376},{ 1158, 3520},{ 1285, 3644},{ 1400, 3740},
+        { 1505, 3828},{ 1616, 3928},{ 1713, 4030},{ 1820, 4104},
+        { 1957, 4185},{ 2063, 4280},{ 2160, 4355},{ 2320, 4341}
+      },
+      /*Cr  qi=34  INTER*/
+      {
+        {   78,   11},{   89,  347},{   79,  674},{   90, 1053},
+        {  106, 1444},{  117, 1823},{  127, 2192},{  137, 2558},
+        {  149, 2912},{  163, 3249},{  178, 3574},{  197, 3888},
+        {  222, 4189},{  252, 4481},{  293, 4755},{  341, 5013},
+        {  386, 5268},{  436, 5512},{  498, 5743},{  563, 5970},
+        {  622, 6200},{  694, 6415},{  776, 6622},{  871, 6818}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=35  INTRA*/
+      {
+        {  116,   51},{  433, 1312},{  881, 2221},{ 1406, 2771},
+        { 1948, 3156},{ 2511, 3501},{ 3085, 3811},{ 3654, 4066},
+        { 4212, 4273},{ 4763, 4444},{ 5298, 4572},{ 5799, 4638},
+        { 6285, 4678},{ 6747, 4746},{ 7203, 4838},{ 7673, 4905},
+        { 8124, 4950},{ 8552, 5003},{ 8938, 5027},{ 9275, 5026},
+        { 9628, 5019},{ 9981, 5024},{10331, 5030},{10795, 5000}
+      },
+      /*Y'  qi=35  INTER*/
+      {
+        {   71,  -10},{  108, 1348},{  203, 2710},{  325, 3938},
+        {  485, 5040},{  766, 6000},{ 1267, 6706},{ 2048, 7089},
+        { 3037, 7191},{ 4032, 7146},{ 4903, 7061},{ 5648, 6977},
+        { 6301, 6912},{ 6884, 6857},{ 7413, 6812},{ 7898, 6775},
+        { 8342, 6739},{ 8764, 6710},{ 9160, 6688},{ 9519, 6668},
+        { 9859, 6646},{10190, 6625},{10492, 6612},{10755, 6595}
+      }
+    },
+    {
+      /*Cb  qi=35  INTRA*/
+      {
+        {    6,    3},{   95,  369},{  164,  746},{  214, 1156},
+        {  287, 1542},{  390, 1869},{  504, 2143},{  611, 2388},
+        {  712, 2613},{  822, 2811},{  937, 2987},{ 1055, 3147},
+        { 1174, 3285},{ 1286, 3420},{ 1386, 3560},{ 1488, 3698},
+        { 1604, 3814},{ 1714, 3916},{ 1825, 4008},{ 1958, 4088},
+        { 2101, 4159},{ 2224, 4226},{ 2339, 4292},{ 2538, 4383}
+      },
+      /*Cb  qi=35  INTER*/
+      {
+        {   98,   41},{   90,  348},{   86,  665},{   92, 1042},
+        {  108, 1432},{  122, 1812},{  136, 2175},{  151, 2528},
+        {  165, 2872},{  182, 3202},{  202, 3516},{  225, 3819},
+        {  251, 4112},{  281, 4398},{  320, 4675},{  367, 4944},
+        {  421, 5204},{  493, 5450},{  579, 5679},{  672, 5892},
+        {  785, 6082},{  906, 6258},{ 1026, 6432},{ 1153, 6592}
+      }
+    },
+    {
+      /*Cr  qi=35  INTRA*/
+      {
+        {   12,    7},{   98,  388},{  166,  773},{  226, 1187},
+        {  306, 1563},{  411, 1874},{  524, 2134},{  622, 2365},
+        {  721, 2577},{  826, 2768},{  947, 2946},{ 1066, 3106},
+        { 1163, 3250},{ 1274, 3395},{ 1417, 3508},{ 1539, 3590},
+        { 1639, 3671},{ 1754, 3765},{ 1865, 3855},{ 1979, 3921},
+        { 2127, 3998},{ 2249, 4085},{ 2346, 4172},{ 2473, 4210}
+      },
+      /*Cr  qi=35  INTER*/
+      {
+        {   86,   12},{   94,  354},{   85,  677},{   96, 1052},
+        {  113, 1439},{  125, 1811},{  135, 2177},{  147, 2537},
+        {  160, 2884},{  177, 3215},{  195, 3535},{  219, 3842},
+        {  252, 4133},{  292, 4413},{  339, 4680},{  396, 4928},
+        {  455, 5169},{  514, 5408},{  588, 5626},{  672, 5835},
+        {  750, 6051},{  837, 6257},{  943, 6442},{ 1073, 6595}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=36  INTRA*/
+      {
+        {  116,   52},{  432, 1312},{  881, 2215},{ 1407, 2759},
+        { 1948, 3140},{ 2511, 3484},{ 3090, 3789},{ 3672, 4036},
+        { 4243, 4236},{ 4803, 4397},{ 5346, 4517},{ 5856, 4581},
+        { 6350, 4614},{ 6821, 4675},{ 7286, 4763},{ 7754, 4832},
+        { 8201, 4875},{ 8631, 4922},{ 9015, 4948},{ 9351, 4945},
+        { 9706, 4941},{10061, 4948},{10408, 4949},{10878, 4923}
+      },
+      /*Y'  qi=36  INTER*/
+      {
+        {   63,  -16},{  114, 1332},{  216, 2690},{  343, 3914},
+        {  515, 5009},{  829, 5939},{ 1399, 6586},{ 2263, 6901},
+        { 3290, 6967},{ 4272, 6920},{ 5115, 6847},{ 5839, 6779},
+        { 6478, 6726},{ 7051, 6685},{ 7571, 6649},{ 8050, 6614},
+        { 8495, 6587},{ 8908, 6567},{ 9298, 6550},{ 9673, 6530},
+        {10005, 6512},{10324, 6499},{10640, 6483},{10936, 6487}
+      }
+    },
+    {
+      /*Cb  qi=36  INTRA*/
+      {
+        {    6,    3},{   98,  370},{  170,  746},{  225, 1150},
+        {  306, 1527},{  416, 1845},{  534, 2116},{  642, 2363},
+        {  743, 2591},{  851, 2794},{  964, 2972},{ 1081, 3133},
+        { 1198, 3275},{ 1311, 3410},{ 1411, 3547},{ 1519, 3680},
+        { 1642, 3789},{ 1750, 3892},{ 1860, 3982},{ 1998, 4054},
+        { 2141, 4129},{ 2256, 4204},{ 2372, 4278},{ 2567, 4356}
+      },
+      /*Cb  qi=36  INTER*/
+      {
+        {  107,   30},{   96,  346},{   88,  667},{  100, 1039},
+        {  115, 1426},{  128, 1804},{  142, 2164},{  158, 2512},
+        {  176, 2851},{  195, 3178},{  218, 3491},{  243, 3791},
+        {  270, 4084},{  307, 4365},{  348, 4638},{  397, 4908},
+        {  464, 5157},{  545, 5392},{  635, 5620},{  734, 5831},
+        {  854, 6015},{  993, 6170},{ 1124, 6327},{ 1234, 6502}
+      }
+    },
+    {
+      /*Cr  qi=36  INTRA*/
+      {
+        {   12,    7},{  102,  388},{  172,  773},{  239, 1182},
+        {  328, 1546},{  439, 1848},{  554, 2106},{  651, 2341},
+        {  747, 2561},{  850, 2757},{  972, 2934},{ 1086, 3097},
+        { 1182, 3245},{ 1302, 3382},{ 1447, 3491},{ 1572, 3567},
+        { 1677, 3641},{ 1793, 3733},{ 1899, 3828},{ 2013, 3894},
+        { 2163, 3967},{ 2283, 4059},{ 2387, 4142},{ 2559, 4145}
+      },
+      /*Cr  qi=36  INTER*/
+      {
+        {   98,  -10},{   96,  347},{   89,  676},{  102, 1048},
+        {  118, 1433},{  130, 1804},{  141, 2167},{  154, 2523},
+        {  171, 2866},{  190, 3194},{  212, 3508},{  240, 3809},
+        {  276, 4099},{  320, 4377},{  372, 4638},{  428, 4887},
+        {  492, 5122},{  560, 5353},{  638, 5572},{  725, 5779},
+        {  814, 5985},{  902, 6192},{ 1013, 6377},{ 1155, 6527}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=37  INTRA*/
+      {
+        {  109,   58},{  445, 1302},{  927, 2177},{ 1489, 2689},
+        { 2053, 3052},{ 2632, 3387},{ 3230, 3683},{ 3830, 3922},
+        { 4417, 4114},{ 4992, 4266},{ 5546, 4375},{ 6067, 4430},
+        { 6571, 4459},{ 7046, 4516},{ 7513, 4599},{ 7991, 4663},
+        { 8445, 4706},{ 8883, 4749},{ 9273, 4771},{ 9612, 4770},
+        { 9970, 4765},{10325, 4773},{10672, 4778},{11106, 4758}
+      },
+      /*Y'  qi=37  INTER*/
+      {
+        {   56,  -14},{  114, 1333},{  218, 2683},{  354, 3894},
+        {  550, 4966},{  916, 5854},{ 1569, 6437},{ 2520, 6685},
+        { 3596, 6704},{ 4585, 6635},{ 5424, 6556},{ 6147, 6489},
+        { 6787, 6437},{ 7358, 6395},{ 7876, 6358},{ 8361, 6325},
+        { 8807, 6294},{ 9229, 6271},{ 9631, 6253},{10002, 6238},
+        {10356, 6228},{10678, 6212},{10975, 6197},{11274, 6185}
+      }
+    },
+    {
+      /*Cb  qi=37  INTRA*/
+      {
+        {    6,    3},{   99,  370},{  171,  746},{  227, 1149},
+        {  309, 1522},{  421, 1836},{  541, 2104},{  652, 2347},
+        {  757, 2572},{  871, 2768},{  989, 2936},{ 1111, 3087},
+        { 1238, 3223},{ 1357, 3352},{ 1465, 3486},{ 1576, 3612},
+        { 1709, 3705},{ 1828, 3801},{ 1937, 3895},{ 2076, 3967},
+        { 2220, 4035},{ 2345, 4104},{ 2466, 4173},{ 2680, 4265}
+      },
+      /*Cb  qi=37  INTER*/
+      {
+        {  111,   27},{   97,  344},{   87,  667},{   99, 1038},
+        {  115, 1425},{  128, 1802},{  143, 2160},{  159, 2506},
+        {  176, 2843},{  198, 3167},{  220, 3477},{  247, 3774},
+        {  280, 4061},{  321, 4338},{  368, 4608},{  427, 4867},
+        {  501, 5109},{  595, 5332},{  701, 5544},{  818, 5738},
+        {  956, 5905},{ 1105, 6066},{ 1248, 6217},{ 1381, 6353}
+      }
+    },
+    {
+      /*Cr  qi=37  INTRA*/
+      {
+        {   12,    7},{  102,  388},{  173,  773},{  242, 1180},
+        {  331, 1541},{  444, 1839},{  562, 2095},{  662, 2326},
+        {  763, 2540},{  871, 2728},{ 1003, 2892},{ 1130, 3045},
+        { 1230, 3188},{ 1350, 3321},{ 1503, 3418},{ 1634, 3492},
+        { 1737, 3568},{ 1856, 3653},{ 1970, 3744},{ 2091, 3802},
+        { 2247, 3871},{ 2371, 3962},{ 2477, 4041},{ 2655, 4052}
+      },
+      /*Cr  qi=37  INTER*/
+      {
+        {   89,   -9},{   97,  347},{   88,  677},{  102, 1048},
+        {  118, 1432},{  130, 1802},{  141, 2163},{  154, 2517},
+        {  172, 2857},{  192, 3181},{  216, 3494},{  246, 3793},
+        {  286, 4074},{  337, 4343},{  395, 4600},{  464, 4837},
+        {  534, 5066},{  608, 5289},{  694, 5501},{  788, 5704},
+        {  893, 5901},{ 1010, 6088},{ 1151, 6249},{ 1331, 6374}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=38  INTRA*/
+      {
+        {  107,   65},{  476, 1286},{  968, 2148},{ 1548, 2641},
+        { 2141, 2979},{ 2757, 3289},{ 3390, 3564},{ 4020, 3784},
+        { 4632, 3957},{ 5224, 4097},{ 5794, 4201},{ 6326, 4250},
+        { 6828, 4274},{ 7309, 4322},{ 7790, 4401},{ 8271, 4463},
+        { 8729, 4498},{ 9165, 4540},{ 9552, 4566},{ 9901, 4560},
+        {10266, 4552},{10617, 4563},{10964, 4572},{11393, 4567}
+      },
+      /*Y'  qi=38  INTER*/
+      {
+        {   57,  -13},{  118, 1332},{  233, 2665},{  386, 3856},
+        {  620, 4899},{ 1070, 5722},{ 1849, 6211},{ 2898, 6384},
+        { 3989, 6376},{ 4947, 6311},{ 5754, 6249},{ 6454, 6199},
+        { 7077, 6161},{ 7640, 6132},{ 8159, 6101},{ 8639, 6076},
+        { 9081, 6054},{ 9502, 6037},{ 9900, 6027},{10274, 6012},
+        {10621, 5999},{10938, 5991},{11237, 5977},{11557, 5966}
+      }
+    },
+    {
+      /*Cb  qi=38  INTRA*/
+      {
+        {    8,    3},{  104,  370},{  179,  744},{  243, 1139},
+        {  338, 1498},{  458, 1801},{  584, 2060},{  700, 2297},
+        {  812, 2514},{  935, 2699},{ 1061, 2858},{ 1189, 3007},
+        { 1321, 3141},{ 1446, 3266},{ 1563, 3388},{ 1684, 3512},
+        { 1816, 3614},{ 1942, 3702},{ 2055, 3793},{ 2201, 3857},
+        { 2357, 3923},{ 2477, 3994},{ 2593, 4061},{ 2768, 4178}
+      },
+      /*Cb  qi=38  INTER*/
+      {
+        {  118,   24},{  102,  342},{   91,  663},{  101, 1040},
+        {  116, 1427},{  131, 1799},{  147, 2152},{  168, 2491},
+        {  191, 2822},{  215, 3139},{  244, 3441},{  276, 3731},
+        {  316, 4013},{  363, 4286},{  423, 4546},{  495, 4795},
+        {  584, 5028},{  691, 5242},{  814, 5439},{  959, 5608},
+        { 1119, 5759},{ 1277, 5906},{ 1449, 6035},{ 1655, 6144}
+      }
+    },
+    {
+      /*Cr  qi=38  INTRA*/
+      {
+        {   12,    6},{  106,  387},{  182,  771},{  261, 1168},
+        {  364, 1514},{  483, 1802},{  603, 2053},{  707, 2282},
+        {  817, 2489},{  933, 2670},{ 1074, 2825},{ 1210, 2967},
+        { 1320, 3104},{ 1444, 3229},{ 1599, 3324},{ 1735, 3396},
+        { 1846, 3464},{ 1971, 3547},{ 2086, 3646},{ 2206, 3711},
+        { 2366, 3773},{ 2499, 3859},{ 2603, 3945},{ 2766, 3952}
+      },
+      /*Cr  qi=38  INTER*/
+      {
+        {   86,   -9},{   91,  352},{   85,  680},{  102, 1053},
+        {  119, 1435},{  132, 1799},{  146, 2153},{  162, 2501},
+        {  183, 2835},{  209, 3154},{  240, 3458},{  278, 3751},
+        {  327, 4025},{  388, 4284},{  455, 4532},{  529, 4766},
+        {  616, 4980},{  711, 5188},{  815, 5386},{  920, 5583},
+        { 1042, 5770},{ 1186, 5936},{ 1348, 6080},{ 1542, 6196}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=39  INTRA*/
+      {
+        {  103,   66},{  479, 1283},{  998, 2125},{ 1610, 2591},
+        { 2223, 2913},{ 2855, 3214},{ 3501, 3482},{ 4146, 3698},
+        { 4772, 3868},{ 5376, 3999},{ 5956, 4095},{ 6496, 4140},
+        { 7008, 4162},{ 7499, 4209},{ 7987, 4282},{ 8478, 4338},
+        { 8947, 4374},{ 9385, 4417},{ 9783, 4437},{10143, 4433},
+        {10504, 4424},{10866, 4435},{11225, 4444},{11665, 4430}
+      },
+      /*Y'  qi=39  INTER*/
+      {
+        {   56,    2},{  118, 1332},{  235, 2660},{  395, 3843},
+        {  653, 4867},{ 1153, 5652},{ 2003, 6089},{ 3113, 6214},
+        { 4228, 6178},{ 5189, 6102},{ 6002, 6031},{ 6707, 5976},
+        { 7336, 5936},{ 7901, 5900},{ 8424, 5870},{ 8915, 5844},
+        { 9361, 5822},{ 9784, 5807},{10187, 5794},{10571, 5778},
+        {10931, 5763},{11264, 5751},{11582, 5742},{11916, 5730}
+      }
+    },
+    {
+      /*Cb  qi=39  INTRA*/
+      {
+        {    8,    3},{  104,  370},{  179,  744},{  244, 1138},
+        {  340, 1496},{  461, 1796},{  588, 2053},{  705, 2288},
+        {  820, 2503},{  945, 2684},{ 1073, 2840},{ 1210, 2981},
+        { 1352, 3106},{ 1480, 3225},{ 1603, 3342},{ 1728, 3464},
+        { 1865, 3559},{ 1990, 3645},{ 2106, 3734},{ 2258, 3796},
+        { 2413, 3856},{ 2540, 3920},{ 2667, 3986},{ 2887, 4060}
+      },
+      /*Cb  qi=39  INTER*/
+      {
+        {  119,   19},{  103,  340},{   90,  664},{  100, 1040},
+        {  115, 1426},{  131, 1797},{  148, 2148},{  169, 2486},
+        {  192, 2816},{  217, 3131},{  247, 3432},{  282, 3721},
+        {  324, 3999},{  374, 4268},{  435, 4526},{  520, 4766},
+        {  621, 4990},{  738, 5194},{  878, 5376},{ 1035, 5543},
+        { 1202, 5686},{ 1374, 5819},{ 1545, 5950},{ 1729, 6064}
+      }
+    },
+    {
+      /*Cr  qi=39  INTRA*/
+      {
+        {   12,    6},{  106,  387},{  182,  771},{  262, 1167},
+        {  365, 1512},{  486, 1798},{  608, 2047},{  713, 2274},
+        {  824, 2479},{  945, 2655},{ 1091, 2804},{ 1231, 2941},
+        { 1346, 3073},{ 1475, 3194},{ 1633, 3282},{ 1778, 3345},
+        { 1891, 3414},{ 2013, 3501},{ 2138, 3584},{ 2266, 3640},
+        { 2428, 3701},{ 2568, 3782},{ 2674, 3863},{ 2816, 3894}
+      },
+      /*Cr  qi=39  INTER*/
+      {
+        {   88,   -7},{   92,  352},{   85,  680},{  102, 1053},
+        {  119, 1434},{  132, 1797},{  146, 2151},{  163, 2498},
+        {  185, 2830},{  211, 3147},{  243, 3451},{  285, 3735},
+        {  337, 4005},{  401, 4260},{  477, 4499},{  565, 4721},
+        {  655, 4937},{  749, 5148},{  858, 5344},{  979, 5529},
+        { 1110, 5710},{ 1264, 5871},{ 1460, 5990},{ 1677, 6086}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=40  INTRA*/
+      {
+        {   98,   71},{  491, 1274},{ 1023, 2103},{ 1641, 2559},
+        { 2257, 2877},{ 2898, 3171},{ 3566, 3429},{ 4233, 3629},
+        { 4881, 3784},{ 5499, 3906},{ 6088, 3997},{ 6631, 4040},
+        { 7145, 4060},{ 7640, 4107},{ 8128, 4178},{ 8618, 4233},
+        { 9077, 4267},{ 9514, 4304},{ 9919, 4324},{10277, 4317},
+        {10635, 4312},{10985, 4324},{11338, 4331},{11792, 4334}
+      },
+      /*Y'  qi=40  INTER*/
+      {
+        {   63,  -26},{  125, 1331},{  256, 2640},{  439, 3801},
+        {  757, 4782},{ 1391, 5474},{ 2399, 5805},{ 3582, 5870},
+        { 4678, 5824},{ 5600, 5763},{ 6386, 5710},{ 7076, 5667},
+        { 7693, 5637},{ 8252, 5610},{ 8775, 5586},{ 9255, 5571},
+        { 9694, 5556},{10115, 5541},{10530, 5530},{10903, 5522},
+        {11242, 5515},{11596, 5501},{11904, 5482},{12205, 5475}
+      }
+    },
+    {
+      /*Cb  qi=40  INTRA*/
+      {
+        {    8,    3},{  108,  371},{  189,  743},{  265, 1128},
+        {  371, 1475},{  499, 1767},{  628, 2022},{  746, 2256},
+        {  864, 2467},{  991, 2647},{ 1124, 2801},{ 1270, 2933},
+        { 1412, 3054},{ 1547, 3165},{ 1677, 3277},{ 1804, 3393},
+        { 1946, 3483},{ 2078, 3569},{ 2201, 3651},{ 2352, 3711},
+        { 2513, 3766},{ 2643, 3826},{ 2775, 3880},{ 3025, 3919}
+      },
+      /*Cb  qi=40  INTER*/
+      {
+        {  114,   35},{  104,  349},{   96,  667},{  106, 1040},
+        {  121, 1423},{  138, 1789},{  158, 2132},{  184, 2464},
+        {  212, 2787},{  242, 3095},{  279, 3389},{  321, 3671},
+        {  374, 3941},{  438, 4199},{  517, 4446},{  617, 4673},
+        {  740, 4881},{  891, 5064},{ 1058, 5225},{ 1239, 5372},
+        { 1441, 5499},{ 1638, 5610},{ 1840, 5719},{ 2076, 5814}
+      }
+    },
+    {
+      /*Cr  qi=40  INTRA*/
+      {
+        {   14,    7},{  114,  389},{  193,  771},{  283, 1156},
+        {  399, 1488},{  523, 1768},{  643, 2018},{  752, 2245},
+        {  865, 2450},{  984, 2626},{ 1139, 2763},{ 1290, 2887},
+        { 1413, 3014},{ 1550, 3128},{ 1711, 3211},{ 1865, 3268},
+        { 1981, 3334},{ 2103, 3415},{ 2237, 3486},{ 2365, 3543},
+        { 2529, 3610},{ 2666, 3700},{ 2775, 3779},{ 2929, 3803}
+      },
+      /*Cr  qi=40  INTER*/
+      {
+        {   89,   -8},{   95,  353},{   90,  681},{  107, 1053},
+        {  124, 1430},{  139, 1787},{  156, 2136},{  177, 2477},
+        {  203, 2803},{  237, 3112},{  276, 3406},{  329, 3683},
+        {  395, 3942},{  475, 4182},{  567, 4407},{  665, 4624},
+        {  767, 4834},{  879, 5032},{ 1011, 5213},{ 1169, 5375},
+        { 1348, 5525},{ 1547, 5654},{ 1785, 5743},{ 2066, 5787}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=41  INTRA*/
+      {
+        {   98,   71},{  495, 1272},{ 1040, 2090},{ 1675, 2533},
+        { 2302, 2842},{ 2953, 3132},{ 3631, 3381},{ 4309, 3574},
+        { 4966, 3726},{ 5593, 3846},{ 6189, 3934},{ 6738, 3972},
+        { 7256, 3991},{ 7754, 4036},{ 8250, 4099},{ 8747, 4150},
+        { 9207, 4185},{ 9650, 4222},{10057, 4242},{10411, 4237},
+        {10771, 4230},{11127, 4244},{11486, 4254},{11933, 4252}
+      },
+      /*Y'  qi=41  INTER*/
+      {
+        {   65,  -25},{  125, 1331},{  260, 2633},{  457, 3782},
+        {  807, 4740},{ 1499, 5397},{ 2562, 5693},{ 3766, 5743},
+        { 4859, 5695},{ 5776, 5638},{ 6556, 5590},{ 7243, 5554},
+        { 7859, 5529},{ 8417, 5506},{ 8935, 5486},{ 9419, 5473},
+        { 9869, 5460},{10296, 5446},{10711, 5436},{11089, 5430},
+        {11445, 5421},{11802, 5412},{12129, 5404},{12465, 5393}
+      }
+    },
+    {
+      /*Cb  qi=41  INTRA*/
+      {
+        {    8,    3},{  108,  371},{  189,  743},{  267, 1126},
+        {  374, 1471},{  504, 1760},{  635, 2011},{  758, 2241},
+        {  881, 2447},{ 1013, 2621},{ 1147, 2773},{ 1293, 2906},
+        { 1441, 3023},{ 1580, 3131},{ 1712, 3243},{ 1844, 3360},
+        { 1985, 3451},{ 2114, 3532},{ 2240, 3613},{ 2390, 3680},
+        { 2550, 3740},{ 2687, 3800},{ 2825, 3862},{ 3052, 3944}
+      },
+      /*Cb  qi=41  INTER*/
+      {
+        {  104,   39},{  100,  350},{   95,  667},{  105, 1040},
+        {  121, 1422},{  137, 1787},{  159, 2129},{  185, 2459},
+        {  216, 2778},{  249, 3083},{  287, 3374},{  335, 3653},
+        {  393, 3920},{  462, 4175},{  549, 4414},{  660, 4636},
+        {  791, 4839},{  952, 5014},{ 1135, 5166},{ 1337, 5297},
+        { 1552, 5411},{ 1752, 5530},{ 1972, 5634},{ 2224, 5724}
+      }
+    },
+    {
+      /*Cr  qi=41  INTRA*/
+      {
+        {   15,    7},{  115,  389},{  193,  770},{  284, 1154},
+        {  401, 1484},{  528, 1761},{  652, 2005},{  764, 2228},
+        {  882, 2427},{ 1008, 2599},{ 1167, 2734},{ 1320, 2859},
+        { 1443, 2990},{ 1580, 3103},{ 1743, 3181},{ 1894, 3241},
+        { 2012, 3309},{ 2141, 3385},{ 2272, 3459},{ 2398, 3519},
+        { 2566, 3584},{ 2707, 3680},{ 2816, 3762},{ 2991, 3770}
+      },
+      /*Cr  qi=41  INTER*/
+      {
+        {   92,   -9},{   98,  354},{   90,  682},{  107, 1052},
+        {  124, 1429},{  139, 1786},{  156, 2132},{  178, 2471},
+        {  207, 2794},{  241, 3100},{  285, 3391},{  345, 3662},
+        {  417, 3915},{  503, 4151},{  600, 4375},{  703, 4589},
+        {  815, 4791},{  942, 4981},{ 1088, 5155},{ 1250, 5316},
+        { 1432, 5462},{ 1653, 5575},{ 1930, 5639},{ 2250, 5655}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=42  INTRA*/
+      {
+        {  109,   75},{  534, 1257},{ 1114, 2047},{ 1793, 2456},
+        { 2461, 2735},{ 3157, 2994},{ 3879, 3221},{ 4595, 3396},
+        { 5282, 3531},{ 5931, 3638},{ 6546, 3714},{ 7105, 3749},
+        { 7633, 3766},{ 8147, 3803},{ 8652, 3865},{ 9148, 3915},
+        { 9613, 3946},{10075, 3976},{10489, 3997},{10835, 3994},
+        {11195, 3985},{11553, 3997},{11909, 4004},{12369, 3990}
+      },
+      /*Y'  qi=42  INTER*/
+      {
+        {   69,  -23},{  134, 1332},{  287, 2611},{  521, 3730},
+        {  970, 4624},{ 1827, 5176},{ 3028, 5382},{ 4262, 5389},
+        { 5325, 5338},{ 6214, 5291},{ 6976, 5255},{ 7651, 5228},
+        { 8260, 5206},{ 8821, 5190},{ 9343, 5177},{ 9823, 5165},
+        {10273, 5152},{10709, 5143},{11121, 5136},{11502, 5129},
+        {11857, 5125},{12193, 5115},{12520, 5107},{12802, 5097}
+      }
+    },
+    {
+      /*Cb  qi=42  INTRA*/
+      {
+        {    9,    3},{  113,  371},{  199,  743},{  279, 1123},
+        {  390, 1462},{  525, 1743},{  662, 1986},{  789, 2208},
+        {  916, 2406},{ 1057, 2571},{ 1204, 2712},{ 1362, 2835},
+        { 1524, 2943},{ 1676, 3040},{ 1815, 3145},{ 1959, 3249},
+        { 2117, 3325},{ 2249, 3406},{ 2377, 3488},{ 2537, 3547},
+        { 2706, 3597},{ 2854, 3646},{ 2999, 3705},{ 3236, 3759}
+      },
+      /*Cb  qi=42  INTER*/
+      {
+        {  114,   44},{  107,  353},{  101,  670},{  111, 1041},
+        {  129, 1418},{  148, 1775},{  174, 2110},{  208, 2432},
+        {  244, 2746},{  283, 3046},{  330, 3330},{  388, 3602},
+        {  460, 3858},{  546, 4101},{  655, 4326},{  793, 4530},
+        {  966, 4703},{ 1165, 4851},{ 1388, 4980},{ 1630, 5088},
+        { 1869, 5189},{ 2122, 5268},{ 2403, 5328},{ 2667, 5417}
+      }
+    },
+    {
+      /*Cr  qi=42  INTRA*/
+      {
+        {   15,    7},{  120,  390},{  202,  771},{  298, 1150},
+        {  421, 1473},{  553, 1743},{  681, 1982},{  796, 2199},
+        {  923, 2388},{ 1062, 2547},{ 1225, 2678},{ 1392, 2792},
+        { 1531, 2907},{ 1682, 3007},{ 1856, 3074},{ 2009, 3134},
+        { 2138, 3192},{ 2274, 3257},{ 2407, 3333},{ 2536, 3393},
+        { 2711, 3455},{ 2875, 3531},{ 3000, 3598},{ 3186, 3599}
+      },
+      /*Cr  qi=42  INTER*/
+      {
+        {   87,   -4},{   95,  358},{   97,  683},{  113, 1052},
+        {  131, 1423},{  148, 1774},{  170, 2116},{  198, 2448},
+        {  234, 2762},{  276, 3062},{  331, 3343},{  404, 3603},
+        {  494, 3844},{  598, 4067},{  715, 4276},{  842, 4471},
+        {  977, 4661},{ 1128, 4840},{ 1311, 4991},{ 1516, 5127},
+        { 1759, 5233},{ 2050, 5300},{ 2377, 5323},{ 2710, 5304}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=43  INTRA*/
+      {
+        {   99,   79},{  557, 1244},{ 1175, 2016},{ 1882, 2408},
+        { 2570, 2677},{ 3288, 2926},{ 4030, 3141},{ 4760, 3307},
+        { 5458, 3435},{ 6115, 3537},{ 6743, 3608},{ 7312, 3636},
+        { 7841, 3652},{ 8357, 3687},{ 8870, 3742},{ 9376, 3788},
+        { 9850, 3821},{10315, 3853},{10734, 3873},{11084, 3870},
+        {11442, 3862},{11800, 3874},{12160, 3879},{12618, 3876}
+      },
+      /*Y'  qi=43  INTER*/
+      {
+        {   69,  -22},{  134, 1331},{  294, 2601},{  551, 3703},
+        { 1056, 4563},{ 2003, 5061},{ 3276, 5215},{ 4534, 5194},
+        { 5599, 5133},{ 6488, 5083},{ 7257, 5044},{ 7938, 5014},
+        { 8556, 4992},{ 9124, 4975},{ 9648, 4960},{10138, 4948},
+        {10594, 4939},{11039, 4926},{11462, 4919},{11847, 4912},
+        {12216, 4904},{12570, 4896},{12883, 4889},{13189, 4879}
+      }
+    },
+    {
+      /*Cb  qi=43  INTRA*/
+      {
+        {    9,    3},{  114,  371},{  202,  740},{  294, 1110},
+        {  417, 1440},{  558, 1716},{  700, 1956},{  833, 2172},
+        {  966, 2365},{ 1116, 2524},{ 1269, 2661},{ 1431, 2781},
+        { 1599, 2885},{ 1756, 2980},{ 1902, 3082},{ 2051, 3185},
+        { 2209, 3261},{ 2337, 3342},{ 2464, 3420},{ 2633, 3475},
+        { 2809, 3525},{ 2948, 3579},{ 3094, 3633},{ 3347, 3678}
+      },
+      /*Cb  qi=43  INTER*/
+      {
+        {  111,   44},{  106,  353},{  102,  670},{  112, 1040},
+        {  128, 1416},{  148, 1771},{  176, 2104},{  211, 2424},
+        {  250, 2734},{  293, 3030},{  347, 3309},{  411, 3575},
+        {  490, 3828},{  589, 4064},{  716, 4278},{  869, 4472},
+        { 1050, 4640},{ 1264, 4781},{ 1512, 4895},{ 1775, 4991},
+        { 2042, 5069},{ 2310, 5141},{ 2593, 5207},{ 2912, 5239}
+      }
+    },
+    {
+      /*Cr  qi=43  INTRA*/
+      {
+        {   15,    7},{  121,  390},{  208,  767},{  315, 1135},
+        {  449, 1449},{  586, 1715},{  718, 1950},{  843, 2158},
+        {  977, 2342},{ 1120, 2501},{ 1290, 2632},{ 1466, 2739},
+        { 1613, 2845},{ 1763, 2945},{ 1937, 3015},{ 2093, 3070},
+        { 2225, 3126},{ 2366, 3194},{ 2501, 3267},{ 2634, 3324},
+        { 2815, 3385},{ 2964, 3466},{ 3087, 3538},{ 3263, 3555}
+      },
+      /*Cr  qi=43  INTER*/
+      {
+        {   84,   -4},{   93,  358},{   95,  683},{  113, 1052},
+        {  131, 1421},{  148, 1770},{  171, 2110},{  201, 2439},
+        {  240, 2750},{  287, 3046},{  348, 3322},{  429, 3576},
+        {  527, 3811},{  641, 4029},{  767, 4230},{  904, 4422},
+        { 1053, 4603},{ 1225, 4765},{ 1433, 4903},{ 1661, 5030},
+        { 1928, 5121},{ 2252, 5160},{ 2604, 5164},{ 2979, 5125}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=44  INTRA*/
+      {
+        {  103,   80},{  560, 1244},{ 1183, 2009},{ 1891, 2391},
+        { 2586, 2649},{ 3324, 2884},{ 4093, 3089},{ 4850, 3243},
+        { 5575, 3358},{ 6252, 3452},{ 6886, 3518},{ 7459, 3546},
+        { 7993, 3562},{ 8515, 3594},{ 9030, 3645},{ 9534, 3691},
+        {10004, 3723},{10469, 3750},{10887, 3765},{11236, 3766},
+        {11596, 3762},{11960, 3775},{12317, 3784},{12766, 3789}
+      },
+      /*Y'  qi=44  INTER*/
+      {
+        {   77,  -24},{  145, 1332},{  332, 2580},{  642, 3649},
+        { 1270, 4438},{ 2360, 4860},{ 3685, 4982},{ 4910, 4966},
+        { 5929, 4928},{ 6785, 4900},{ 7529, 4880},{ 8198, 4863},
+        { 8804, 4850},{ 9361, 4842},{ 9882, 4836},{10371, 4830},
+        {10827, 4822},{11262, 4816},{11672, 4811},{12052, 4807},
+        {12431, 4806},{12780, 4798},{13095, 4792},{13401, 4791}
+      }
+    },
+    {
+      /*Cb  qi=44  INTRA*/
+      {
+        {    9,    2},{  122,  371},{  214,  741},{  307, 1109},
+        {  433, 1432},{  576, 1704},{  718, 1939},{  855, 2152},
+        {  991, 2340},{ 1141, 2497},{ 1298, 2632},{ 1463, 2749},
+        { 1636, 2851},{ 1796, 2944},{ 1947, 3041},{ 2101, 3140},
+        { 2260, 3219},{ 2392, 3297},{ 2527, 3366},{ 2693, 3424},
+        { 2872, 3477},{ 3025, 3525},{ 3175, 3584},{ 3451, 3626}
+      },
+      /*Cb  qi=44  INTER*/
+      {
+        {  111,   14},{  110,  339},{  109,  671},{  120, 1040},
+        {  139, 1410},{  162, 1758},{  197, 2084},{  243, 2397},
+        {  291, 2702},{  342, 2992},{  405, 3265},{  484, 3521},
+        {  584, 3760},{  705, 3983},{  855, 4185},{ 1048, 4356},
+        { 1274, 4500},{ 1531, 4617},{ 1816, 4707},{ 2111, 4783},
+        { 2409, 4846},{ 2720, 4901},{ 3044, 4957},{ 3391, 4985}
+      }
+    },
+    {
+      /*Cr  qi=44  INTRA*/
+      {
+        {   17,    7},{  128,  392},{  219,  770},{  329, 1135},
+        {  465, 1442},{  601, 1703},{  734, 1935},{  862, 2142},
+        {  998, 2325},{ 1147, 2482},{ 1321, 2606},{ 1496, 2710},
+        { 1649, 2813},{ 1809, 2908},{ 1984, 2977},{ 2143, 3032},
+        { 2279, 3087},{ 2423, 3152},{ 2559, 3225},{ 2684, 3288},
+        { 2866, 3351},{ 3025, 3426},{ 3161, 3492},{ 3372, 3500}
+      },
+      /*Cr  qi=44  INTER*/
+      {
+        {   89,    0},{  101,  352},{  104,  683},{  121, 1051},
+        {  141, 1414},{  163, 1757},{  192, 2092},{  231, 2415},
+        {  278, 2720},{  336, 3007},{  412, 3273},{  510, 3516},
+        {  633, 3733},{  769, 3936},{  914, 4130},{ 1076, 4307},
+        { 1256, 4472},{ 1469, 4617},{ 1723, 4732},{ 2012, 4822},
+        { 2347, 4871},{ 2716, 4875},{ 3082, 4866},{ 3422, 4826}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=45  INTRA*/
+      {
+        {  119,   78},{  610, 1226},{ 1271, 1965},{ 2026, 2319},
+        { 2768, 2550},{ 3556, 2757},{ 4369, 2938},{ 5157, 3076},
+        { 5901, 3182},{ 6598, 3268},{ 7253, 3326},{ 7844, 3343},
+        { 8392, 3356},{ 8922, 3386},{ 9453, 3433},{ 9973, 3474},
+        {10457, 3503},{10929, 3530},{11351, 3543},{11709, 3541},
+        {12068, 3537},{12434, 3547},{12805, 3555},{13268, 3563}
+      },
+      /*Y'  qi=45  INTER*/
+      {
+        {   77,  -20},{  146, 1330},{  342, 2566},{  699, 3604},
+        { 1439, 4332},{ 2669, 4672},{ 4075, 4727},{ 5318, 4679},
+        { 6345, 4630},{ 7209, 4595},{ 7963, 4570},{ 8644, 4551},
+        { 9262, 4535},{ 9831, 4525},{10370, 4515},{10872, 4506},
+        {11334, 4500},{11783, 4492},{12219, 4489},{12617, 4483},
+        {12995, 4477},{13350, 4472},{13674, 4466},{13968, 4468}
+      }
+    },
+    {
+      /*Cb  qi=45  INTRA*/
+      {
+        {    9,    2},{  122,  370},{  219,  735},{  324, 1096},
+        {  465, 1414},{  619, 1679},{  771, 1905},{  920, 2103},
+        { 1070, 2276},{ 1236, 2419},{ 1410, 2539},{ 1595, 2644},
+        { 1784, 2736},{ 1949, 2831},{ 2104, 2931},{ 2275, 3021},
+        { 2443, 3092},{ 2586, 3166},{ 2735, 3234},{ 2904, 3288},
+        { 3093, 3338},{ 3262, 3382},{ 3419, 3427},{ 3708, 3456}
+      },
+      /*Cb  qi=45  INTER*/
+      {
+        {  103,    0},{  109,  339},{  109,  670},{  119, 1039},
+        {  137, 1408},{  162, 1754},{  199, 2076},{  248, 2386},
+        {  301, 2684},{  360, 2967},{  433, 3234},{  525, 3481},
+        {  640, 3713},{  780, 3924},{  956, 4110},{ 1176, 4266},
+        { 1438, 4390},{ 1736, 4481},{ 2057, 4553},{ 2385, 4613},
+        { 2718, 4656},{ 3056, 4698},{ 3416, 4733},{ 3799, 4755}
+      }
+    },
+    {
+      /*Cr  qi=45  INTRA*/
+      {
+        {   16,    7},{  128,  391},{  225,  763},{  350, 1120},
+        {  500, 1420},{  649, 1673},{  792, 1893},{  929, 2089},
+        { 1084, 2257},{ 1250, 2401},{ 1440, 2518},{ 1633, 2614},
+        { 1799, 2708},{ 1968, 2798},{ 2151, 2863},{ 2314, 2914},
+        { 2453, 2968},{ 2611, 3025},{ 2759, 3095},{ 2887, 3160},
+        { 3082, 3210},{ 3259, 3278},{ 3403, 3342},{ 3593, 3354}
+      },
+      /*Cr  qi=45  INTER*/
+      {
+        {   92,    0},{  101,  352},{  103,  682},{  120, 1049},
+        {  140, 1412},{  163, 1752},{  193, 2083},{  234, 2402},
+        {  287, 2702},{  353, 2983},{  442, 3240},{  557, 3471},
+        {  694, 3680},{  846, 3873},{ 1014, 4056},{ 1200, 4224},
+        { 1414, 4369},{ 1664, 4495},{ 1946, 4595},{ 2278, 4654},
+        { 2654, 4673},{ 3047, 4658},{ 3438, 4627},{ 3825, 4585}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=46  INTRA*/
+      {
+        {  119,   78},{  610, 1227},{ 1277, 1960},{ 2043, 2309},
+        { 2805, 2529},{ 3618, 2719},{ 4452, 2887},{ 5257, 3016},
+        { 6017, 3115},{ 6727, 3195},{ 7392, 3248},{ 7984, 3267},
+        { 8528, 3281},{ 9059, 3310},{ 9593, 3354},{10119, 3395},
+        {10599, 3425},{11064, 3450},{11493, 3464},{11850, 3466},
+        {12207, 3462},{12578, 3471},{12948, 3480},{13407, 3487}
+      },
+      /*Y'  qi=46  INTER*/
+      {
+        {   74,  -14},{  149, 1326},{  382, 2538},{  807, 3541},
+        { 1670, 4211},{ 3000, 4499},{ 4416, 4533},{ 5628, 4490},
+        { 6628, 4453},{ 7479, 4425},{ 8228, 4406},{ 8902, 4393},
+        { 9521, 4380},{10090, 4371},{10623, 4364},{11124, 4356},
+        {11586, 4351},{12043, 4344},{12476, 4341},{12863, 4340},
+        {13244, 4337},{13610, 4329},{13936, 4324},{14246, 4329}
+      }
+    },
+    {
+      /*Cb  qi=46  INTRA*/
+      {
+        {   11,    2},{  132,  371},{  234,  737},{  340, 1094},
+        {  481, 1405},{  637, 1667},{  791, 1891},{  944, 2084},
+        { 1099, 2253},{ 1268, 2392},{ 1444, 2507},{ 1633, 2610},
+        { 1825, 2700},{ 1990, 2794},{ 2147, 2895},{ 2321, 2984},
+        { 2493, 3053},{ 2640, 3126},{ 2787, 3198},{ 2954, 3253},
+        { 3146, 3297},{ 3313, 3344},{ 3473, 3393},{ 3757, 3434}
+      },
+      /*Cb  qi=46  INTER*/
+      {
+        {   97,    0},{  109,  339},{  108,  669},{  120, 1035},
+        {  142, 1398},{  173, 1737},{  221, 2052},{  281, 2353},
+        {  345, 2646},{  415, 2924},{  504, 3183},{  616, 3421},
+        {  749, 3643},{  914, 3842},{ 1123, 4012},{ 1379, 4150},
+        { 1685, 4250},{ 2014, 4327},{ 2366, 4382},{ 2731, 4426},
+        { 3083, 4470},{ 3445, 4490},{ 3805, 4511},{ 4146, 4539}
+      }
+    },
+    {
+      /*Cr  qi=46  INTRA*/
+      {
+        {   19,    7},{  137,  393},{  237,  765},{  364, 1116},
+        {  516, 1411},{  665, 1662},{  809, 1880},{  951, 2072},
+        { 1109, 2236},{ 1278, 2378},{ 1474, 2491},{ 1669, 2584},
+        { 1835, 2678},{ 2014, 2766},{ 2203, 2828},{ 2366, 2880},
+        { 2506, 2933},{ 2661, 2988},{ 2810, 3053},{ 2941, 3116},
+        { 3131, 3175},{ 3310, 3243},{ 3461, 3303},{ 3656, 3321}
+      },
+      /*Cr  qi=46  INTER*/
+      {
+        {   91,    1},{  103,  351},{  104,  681},{  121, 1046},
+        {  144, 1401},{  173, 1736},{  213, 2060},{  265, 2373},
+        {  330, 2666},{  410, 2938},{  517, 3185},{  655, 3404},
+        {  815, 3601},{  989, 3784},{ 1183, 3951},{ 1400, 4104},
+        { 1649, 4241},{ 1933, 4352},{ 2261, 4427},{ 2646, 4458},
+        { 3057, 4446},{ 3453, 4418},{ 3820, 4385},{ 4171, 4352}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=47  INTRA*/
+      {
+        {  117,   83},{  670, 1205},{ 1408, 1904},{ 2239, 2219},
+        { 3049, 2414},{ 3905, 2584},{ 4775, 2734},{ 5610, 2852},
+        { 6393, 2944},{ 7121, 3017},{ 7804, 3066},{ 8407, 3081},
+        { 8957, 3093},{ 9498, 3119},{10043, 3160},{10582, 3199},
+        {11083, 3226},{11561, 3250},{11993, 3263},{12352, 3264},
+        {12711, 3259},{13092, 3266},{13463, 3271},{13918, 3275}
+      },
+      /*Y'  qi=47  INTER*/
+      {
+        {   74,  -11},{  148, 1325},{  404, 2518},{  910, 3478},
+        { 1916, 4080},{ 3369, 4298},{ 4823, 4292},{ 6035, 4238},
+        { 7037, 4197},{ 7894, 4168},{ 8650, 4146},{ 9337, 4129},
+        { 9968, 4116},{10549, 4105},{11096, 4096},{11605, 4089},
+        {12081, 4083},{12547, 4076},{12990, 4070},{13399, 4070},
+        {13776, 4065},{14133, 4059},{14486, 4057},{14842, 4053}
+      }
+    },
+    {
+      /*Cb  qi=47  INTRA*/
+      {
+        {   11,    2},{  133,  370},{  242,  731},{  367, 1077},
+        {  524, 1378},{  692, 1630},{  860, 1844},{ 1028, 2024},
+        { 1203, 2178},{ 1393, 2305},{ 1582, 2413},{ 1787, 2507},
+        { 1992, 2590},{ 2175, 2676},{ 2351, 2767},{ 2534, 2851},
+        { 2707, 2923},{ 2862, 2994},{ 3021, 3060},{ 3193, 3111},
+        { 3396, 3147},{ 3573, 3184},{ 3752, 3220},{ 4038, 3255}
+      },
+      /*Cb  qi=47  INTER*/
+      {
+        {  101,    0},{  107,  339},{  108,  667},{  120, 1033},
+        {  142, 1394},{  175, 1729},{  227, 2040},{  295, 2335},
+        {  369, 2619},{  452, 2888},{  556, 3138},{  686, 3368},
+        {  850, 3574},{ 1050, 3758},{ 1299, 3910},{ 1605, 4024},
+        { 1950, 4104},{ 2317, 4163},{ 2689, 4210},{ 3077, 4239},
+        { 3466, 4258},{ 3840, 4278},{ 4205, 4298},{ 4515, 4340}
+      }
+    },
+    {
+      /*Cr  qi=47  INTRA*/
+      {
+        {   19,    7},{  138,  392},{  248,  758},{  396, 1094},
+        {  563, 1378},{  723, 1621},{  881, 1829},{ 1037, 2011},
+        { 1214, 2165},{ 1410, 2290},{ 1623, 2393},{ 1834, 2480},
+        { 2016, 2564},{ 2203, 2647},{ 2405, 2707},{ 2569, 2757},
+        { 2709, 2810},{ 2871, 2860},{ 3027, 2924},{ 3178, 2980},
+        { 3375, 3034},{ 3563, 3097},{ 3724, 3151},{ 3952, 3153}
+      },
+      /*Cr  qi=47  INTER*/
+      {
+        {   91,    1},{  100,  351},{  102,  681},{  120, 1043},
+        {  144, 1397},{  175, 1729},{  219, 2049},{  277, 2356},
+        {  353, 2640},{  451, 2902},{  579, 3136},{  739, 3342},
+        {  926, 3525},{ 1125, 3698},{ 1343, 3859},{ 1595, 3998},
+        { 1881, 4113},{ 2208, 4205},{ 2589, 4253},{ 3014, 4250},
+        { 3444, 4220},{ 3838, 4183},{ 4196, 4147},{ 4521, 4116}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=48  INTRA*/
+      {
+        {  107,   87},{  681, 1200},{ 1456, 1883},{ 2306, 2193},
+        { 3122, 2386},{ 3984, 2548},{ 4862, 2693},{ 5704, 2808},
+        { 6495, 2899},{ 7232, 2970},{ 7915, 3018},{ 8524, 3034},
+        { 9085, 3043},{ 9635, 3068},{10192, 3108},{10735, 3145},
+        {11237, 3171},{11719, 3194},{12153, 3207},{12516, 3206},
+        {12888, 3202},{13266, 3210},{13637, 3218},{14101, 3219}
+      },
+      /*Y'  qi=48  INTER*/
+      {
+        {   83,  -18},{  147, 1328},{  398, 2519},{  923, 3468},
+        { 1979, 4047},{ 3472, 4246},{ 4936, 4232},{ 6148, 4178},
+        { 7150, 4139},{ 8007, 4111},{ 8765, 4091},{ 9458, 4076},
+        {10090, 4063},{10676, 4054},{11226, 4045},{11742, 4038},
+        {12223, 4033},{12686, 4029},{13127, 4022},{13527, 4015},
+        {13915, 4012},{14277, 4007},{14619, 4004},{14966, 4001}
+      }
+    },
+    {
+      /*Cb  qi=48  INTRA*/
+      {
+        {   11,    2},{  134,  369},{  245,  730},{  373, 1075},
+        {  531, 1374},{  698, 1625},{  865, 1839},{ 1033, 2019},
+        { 1207, 2173},{ 1397, 2300},{ 1588, 2408},{ 1795, 2501},
+        { 2003, 2581},{ 2187, 2666},{ 2362, 2757},{ 2548, 2841},
+        { 2719, 2912},{ 2876, 2983},{ 3034, 3047},{ 3209, 3097},
+        { 3409, 3137},{ 3589, 3178},{ 3762, 3216},{ 4004, 3252}
+      },
+      /*Cb  qi=48  INTER*/
+      {
+        {  113,   26},{  112,  344},{  111,  668},{  120, 1032},
+        {  141, 1392},{  173, 1727},{  224, 2036},{  290, 2330},
+        {  363, 2612},{  447, 2880},{  551, 3130},{  685, 3358},
+        {  852, 3563},{ 1061, 3742},{ 1332, 3884},{ 1654, 3993},
+        { 2011, 4068},{ 2394, 4120},{ 2782, 4160},{ 3172, 4186},
+        { 3557, 4209},{ 3932, 4228},{ 4306, 4237},{ 4675, 4236}
+      }
+    },
+    {
+      /*Cr  qi=48  INTRA*/
+      {
+        {   18,    7},{  139,  389},{  252,  755},{  404, 1090},
+        {  573, 1372},{  732, 1615},{  889, 1823},{ 1045, 2005},
+        { 1222, 2159},{ 1417, 2285},{ 1631, 2387},{ 1843, 2474},
+        { 2027, 2558},{ 2212, 2639},{ 2413, 2697},{ 2578, 2746},
+        { 2720, 2798},{ 2887, 2852},{ 3040, 2913},{ 3181, 2970},
+        { 3381, 3024},{ 3581, 3081},{ 3743, 3130},{ 3948, 3133}
+      },
+      /*Cr  qi=48  INTER*/
+      {
+        {   89,    0},{  106,  352},{  105,  682},{  120, 1044},
+        {  144, 1395},{  174, 1724},{  215, 2044},{  270, 2350},
+        {  343, 2635},{  441, 2895},{  571, 3129},{  735, 3334},
+        {  926, 3518},{ 1139, 3684},{ 1371, 3836},{ 1628, 3977},
+        { 1933, 4089},{ 2279, 4164},{ 2672, 4204},{ 3105, 4205},
+        { 3533, 4176},{ 3931, 4135},{ 4290, 4089},{ 4624, 4057}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=49  INTRA*/
+      {
+        {  120,   85},{  706, 1194},{ 1485, 1875},{ 2348, 2187},
+        { 3190, 2372},{ 4076, 2521},{ 4967, 2658},{ 5819, 2771},
+        { 6611, 2861},{ 7345, 2936},{ 8026, 2990},{ 8626, 3013},
+        { 9182, 3030},{ 9723, 3059},{10266, 3100},{10802, 3143},
+        {11293, 3179},{11768, 3206},{12201, 3221},{12556, 3225},
+        {12914, 3226},{13281, 3237},{13639, 3247},{14089, 3257}
+      },
+      /*Y'  qi=49  INTER*/
+      {
+        {   72,  -11},{  155, 1320},{  458, 2485},{ 1090, 3386},
+        { 2284, 3907},{ 3835, 4075},{ 5272, 4064},{ 6449, 4026},
+        { 7426, 4003},{ 8267, 3987},{ 9017, 3976},{ 9698, 3967},
+        {10328, 3962},{10913, 3959},{11452, 3954},{11961, 3950},
+        {12442, 3947},{12904, 3946},{13347, 3945},{13749, 3943},
+        {14123, 3941},{14490, 3941},{14826, 3939},{15153, 3937}
+      }
+    },
+    {
+      /*Cb  qi=49  INTRA*/
+      {
+        {   11,    2},{  145,  369},{  262,  729},{  393, 1070},
+        {  557, 1363},{  731, 1607},{  907, 1811},{ 1085, 1983},
+        { 1268, 2130},{ 1465, 2251},{ 1658, 2359},{ 1868, 2454},
+        { 2079, 2534},{ 2264, 2621},{ 2440, 2717},{ 2625, 2802},
+        { 2792, 2878},{ 2945, 2954},{ 3106, 3021},{ 3277, 3075},
+        { 3466, 3119},{ 3638, 3170},{ 3824, 3213},{ 4100, 3243}
+      },
+      /*Cb  qi=49  INTER*/
+      {
+        {   98,   -6},{  113,  343},{  110,  669},{  122, 1029},
+        {  149, 1380},{  192, 1706},{  258, 2007},{  340, 2293},
+        {  426, 2569},{  525, 2831},{  653, 3071},{  814, 3287},
+        { 1013, 3478},{ 1262, 3637},{ 1575, 3761},{ 1936, 3851},
+        { 2328, 3910},{ 2741, 3949},{ 3163, 3970},{ 3559, 3994},
+        { 3936, 4025},{ 4300, 4050},{ 4655, 4060},{ 4962, 4062}
+      }
+    },
+    {
+      /*Cr  qi=49  INTRA*/
+      {
+        {   19,    7},{  151,  389},{  270,  753},{  427, 1084},
+        {  602, 1360},{  767, 1595},{  933, 1794},{ 1098, 1968},
+        { 1285, 2115},{ 1489, 2237},{ 1699, 2342},{ 1912, 2435},
+        { 2101, 2519},{ 2288, 2601},{ 2486, 2663},{ 2651, 2715},
+        { 2799, 2769},{ 2958, 2825},{ 3106, 2890},{ 3257, 2948},
+        { 3452, 3007},{ 3634, 3075},{ 3786, 3136},{ 3959, 3164}
+      },
+      /*Cr  qi=49  INTER*/
+      {
+        {   85,    1},{  103,  352},{  104,  681},{  121, 1039},
+        {  152, 1382},{  195, 1702},{  248, 2015},{  316, 2316},
+        {  403, 2595},{  520, 2847},{  676, 3068},{  870, 3258},
+        { 1091, 3429},{ 1329, 3585},{ 1597, 3725},{ 1894, 3849},
+        { 2242, 3940},{ 2656, 3984},{ 3098, 3992},{ 3531, 3981},
+        { 3936, 3950},{ 4304, 3915},{ 4646, 3879},{ 4915, 3861}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=50  INTRA*/
+      {
+        {  122,   89},{  798, 1170},{ 1682, 1812},{ 2613, 2096},
+        { 3501, 2260},{ 4430, 2388},{ 5352, 2510},{ 6228, 2613},
+        { 7043, 2698},{ 7793, 2770},{ 8486, 2823},{ 9092, 2846},
+        { 9652, 2865},{10210, 2895},{10773, 2936},{11315, 2979},
+        {11817, 3014},{12297, 3041},{12734, 3057},{13097, 3064},
+        {13443, 3067},{13813, 3078},{14190, 3088},{14646, 3103}
+      },
+      /*Y'  qi=50  INTER*/
+      {
+        {   73,  -11},{  154, 1318},{  501, 2457},{ 1281, 3291},
+        { 2685, 3719},{ 4356, 3810},{ 5811, 3769},{ 6988, 3726},
+        { 7976, 3700},{ 8835, 3682},{ 9606, 3669},{10307, 3659},
+        {10953, 3652},{11556, 3645},{12115, 3643},{12641, 3640},
+        {13138, 3636},{13613, 3634},{14068, 3629},{14488, 3627},
+        {14876, 3625},{15237, 3621},{15585, 3623},{15922, 3629}
+      }
+    },
+    {
+      /*Cb  qi=50  INTRA*/
+      {
+        {   11,    2},{  148,  368},{  278,  724},{  431, 1052},
+        {  613, 1334},{  806, 1567},{ 1004, 1756},{ 1203, 1915},
+        { 1405, 2051},{ 1621, 2163},{ 1833, 2262},{ 2059, 2347},
+        { 2280, 2424},{ 2476, 2512},{ 2670, 2598},{ 2864, 2679},
+        { 3037, 2754},{ 3201, 2826},{ 3376, 2887},{ 3562, 2936},
+        { 3756, 2976},{ 3932, 3022},{ 4117, 3065},{ 4385, 3094}
+      },
+      /*Cb  qi=50  INTER*/
+      {
+        {   92,   -3},{  112,  343},{  109,  669},{  121, 1027},
+        {  149, 1375},{  196, 1697},{  270, 1992},{  366, 2267},
+        {  471, 2532},{  594, 2782},{  747, 3011},{  942, 3212},
+        { 1189, 3384},{ 1497, 3521},{ 1875, 3613},{ 2297, 3673},
+        { 2739, 3710},{ 3195, 3725},{ 3644, 3737},{ 4057, 3751},
+        { 4445, 3763},{ 4841, 3769},{ 5211, 3779},{ 5568, 3769}
+      }
+    },
+    {
+      /*Cr  qi=50  INTRA*/
+      {
+        {   19,    7},{  155,  388},{  290,  744},{  474, 1060},
+        {  666, 1324},{  847, 1549},{ 1033, 1737},{ 1219, 1898},
+        { 1428, 2034},{ 1653, 2147},{ 1885, 2245},{ 2115, 2329},
+        { 2316, 2410},{ 2517, 2486},{ 2730, 2539},{ 2901, 2586},
+        { 3042, 2638},{ 3199, 2693},{ 3366, 2755},{ 3534, 2805},
+        { 3738, 2858},{ 3934, 2916},{ 4079, 2975},{ 4257, 2992}
+      },
+      /*Cr  qi=50  INTER*/
+      {
+        {   87,    1},{  102,  353},{  103,  680},{  121, 1036},
+        {  153, 1377},{  199, 1694},{  260, 1999},{  339, 2291},
+        {  446, 2559},{  590, 2797},{  780, 3003},{ 1010, 3176},
+        { 1267, 3331},{ 1547, 3474},{ 1874, 3594},{ 2245, 3688},
+        { 2666, 3742},{ 3130, 3758},{ 3594, 3748},{ 4028, 3711},
+        { 4415, 3674},{ 4771, 3641},{ 5122, 3605},{ 5482, 3569}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=51  INTRA*/
+      {
+        {  115,   93},{  819, 1164},{ 1739, 1806},{ 2695, 2101},
+        { 3612, 2257},{ 4552, 2374},{ 5479, 2490},{ 6352, 2593},
+        { 7158, 2683},{ 7898, 2761},{ 8580, 2823},{ 9177, 2854},
+        { 9728, 2880},{10268, 2917},{10816, 2966},{11350, 3016},
+        {11834, 3058},{12311, 3089},{12741, 3109},{13092, 3119},
+        {13434, 3126},{13791, 3142},{14156, 3155},{14590, 3171}
+      },
+      /*Y'  qi=51  INTER*/
+      {
+        {   58,    0},{  171, 1307},{  610, 2407},{ 1563, 3175},
+        { 3116, 3545},{ 4789, 3624},{ 6185, 3602},{ 7320, 3583},
+        { 8282, 3574},{ 9124, 3569},{ 9878, 3567},{10569, 3565},
+        {11207, 3563},{11801, 3564},{12359, 3566},{12884, 3567},
+        {13373, 3568},{13841, 3567},{14289, 3566},{14699, 3568},
+        {15086, 3568},{15446, 3566},{15788, 3564},{16103, 3568}
+      }
+    },
+    {
+      /*Cb  qi=51  INTRA*/
+      {
+        {   14,    3},{  161,  369},{  297,  722},{  454, 1047},
+        {  639, 1325},{  833, 1554},{ 1033, 1742},{ 1236, 1897},
+        { 1440, 2032},{ 1653, 2148},{ 1860, 2253},{ 2077, 2347},
+        { 2288, 2432},{ 2476, 2525},{ 2661, 2621},{ 2841, 2714},
+        { 3010, 2797},{ 3170, 2876},{ 3333, 2945},{ 3510, 3000},
+        { 3696, 3054},{ 3865, 3114},{ 4046, 3164},{ 4317, 3200}
+      },
+      /*Cb  qi=51  INTER*/
+      {
+        {   88,  -11},{  109,  341},{  109,  668},{  126, 1019},
+        {  168, 1358},{  233, 1670},{  329, 1955},{  451, 2219},
+        {  584, 2472},{  736, 2711},{  931, 2923},{ 1179, 3104},
+        { 1480, 3254},{ 1846, 3368},{ 2265, 3448},{ 2714, 3501},
+        { 3180, 3524},{ 3638, 3529},{ 4074, 3543},{ 4485, 3560},
+        { 4868, 3571},{ 5238, 3581},{ 5597, 3594},{ 5953, 3591}
+      }
+    },
+    {
+      /*Cr  qi=51  INTRA*/
+      {
+        {   24,    7},{  168,  388},{  309,  742},{  496, 1054},
+        {  688, 1316},{  873, 1538},{ 1063, 1723},{ 1252, 1882},
+        { 1460, 2018},{ 1682, 2134},{ 1907, 2238},{ 2125, 2332},
+        { 2317, 2422},{ 2507, 2510},{ 2705, 2575},{ 2869, 2630},
+        { 3015, 2684},{ 3178, 2744},{ 3329, 2815},{ 3477, 2878},
+        { 3667, 2945},{ 3848, 3016},{ 3997, 3082},{ 4174, 3121}
+      },
+      /*Cr  qi=51  INTER*/
+      {
+        {   83,   -2},{  102,  351},{  102,  680},{  126, 1029},
+        {  172, 1359},{  238, 1665},{  321, 1962},{  422, 2246},
+        {  552, 2505},{  733, 2728},{  970, 2912},{ 1247, 3069},
+        { 1552, 3209},{ 1876, 3338},{ 2251, 3440},{ 2692, 3502},
+        { 3161, 3529},{ 3637, 3525},{ 4084, 3509},{ 4487, 3479},
+        { 4850, 3444},{ 5181, 3419},{ 5507, 3406},{ 5786, 3398}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=52  INTRA*/
+      {
+        {  117,   93},{  814, 1168},{ 1729, 1822},{ 2706, 2119},
+        { 3655, 2262},{ 4604, 2374},{ 5528, 2490},{ 6394, 2596},
+        { 7189, 2691},{ 7921, 2777},{ 8596, 2846},{ 9184, 2885},
+        { 9728, 2918},{10260, 2961},{10796, 3014},{11316, 3069},
+        {11793, 3115},{12267, 3150},{12692, 3172},{13037, 3185},
+        {13367, 3196},{13717, 3214},{14087, 3227},{14521, 3249}
+      },
+      /*Y'  qi=52  INTER*/
+      {
+        {   52,    0},{  169, 1308},{  668, 2382},{ 1735, 3112},
+        { 3384, 3451},{ 5077, 3519},{ 6461, 3506},{ 7587, 3496},
+        { 8545, 3494},{ 9384, 3494},{10142, 3498},{10838, 3501},
+        {11475, 3503},{12078, 3508},{12640, 3511},{13162, 3513},
+        {13654, 3517},{14130, 3521},{14576, 3522},{14980, 3523},
+        {15369, 3523},{15737, 3522},{16071, 3521},{16382, 3516}
+      }
+    },
+    {
+      /*Cb  qi=52  INTRA*/
+      {
+        {   14,    3},{  163,  369},{  299,  722},{  457, 1044},
+        {  645, 1319},{  843, 1545},{ 1050, 1728},{ 1261, 1879},
+        { 1468, 2013},{ 1678, 2132},{ 1883, 2240},{ 2093, 2338},
+        { 2301, 2428},{ 2488, 2523},{ 2667, 2619},{ 2843, 2718},
+        { 3010, 2805},{ 3163, 2887},{ 3323, 2963},{ 3490, 3028},
+        { 3665, 3087},{ 3841, 3145},{ 4011, 3197},{ 4289, 3230}
+      },
+      /*Cb  qi=52  INTER*/
+      {
+        {   98,   -7},{  109,  342},{  109,  668},{  126, 1018},
+        {  170, 1355},{  242, 1663},{  352, 1941},{  490, 2195},
+        {  642, 2439},{  823, 2666},{ 1052, 2868},{ 1333, 3039},
+        { 1670, 3178},{ 2074, 3280},{ 2524, 3348},{ 2996, 3390},
+        { 3469, 3410},{ 3923, 3420},{ 4355, 3434},{ 4771, 3451},
+        { 5166, 3468},{ 5532, 3483},{ 5885, 3499},{ 6263, 3501}
+      }
+    },
+    {
+      /*Cr  qi=52  INTRA*/
+      {
+        {   25,    7},{  170,  388},{  312,  741},{  500, 1051},
+        {  694, 1310},{  883, 1529},{ 1082, 1709},{ 1280, 1864},
+        { 1491, 1998},{ 1710, 2117},{ 1932, 2225},{ 2143, 2324},
+        { 2328, 2418},{ 2516, 2506},{ 2708, 2578},{ 2870, 2637},
+        { 3017, 2693},{ 3170, 2758},{ 3312, 2835},{ 3455, 2901},
+        { 3644, 2972},{ 3827, 3049},{ 3968, 3121},{ 4115, 3166}
+      },
+      /*Cr  qi=52  INTER*/
+      {
+        {   86,   -2},{  101,  352},{  100,  680},{  126, 1028},
+        {  175, 1356},{  247, 1657},{  341, 1948},{  458, 2224},
+        {  615, 2471},{  828, 2681},{ 1091, 2857},{ 1395, 3008},
+        { 1732, 3140},{ 2095, 3257},{ 2502, 3348},{ 2968, 3402},
+        { 3457, 3420},{ 3926, 3413},{ 4360, 3388},{ 4759, 3357},
+        { 5128, 3329},{ 5449, 3306},{ 5741, 3295},{ 6071, 3296}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=53  INTRA*/
+      {
+        {  138,   93},{  850, 1161},{ 1773, 1810},{ 2763, 2103},
+        { 3722, 2245},{ 4675, 2360},{ 5600, 2483},{ 6464, 2597},
+        { 7255, 2700},{ 7982, 2792},{ 8652, 2867},{ 9237, 2913},
+        { 9775, 2950},{10302, 2998},{10834, 3058},{11347, 3121},
+        {11826, 3169},{12299, 3207},{12713, 3235},{13054, 3250},
+        {13387, 3265},{13744, 3286},{14110, 3302},{14515, 3323}
+      },
+      /*Y'  qi=53  INTER*/
+      {
+        {   52,    2},{  169, 1308},{  680, 2377},{ 1763, 3103},
+        { 3410, 3450},{ 5094, 3531},{ 6469, 3526},{ 7590, 3525},
+        { 8547, 3530},{ 9385, 3534},{10139, 3540},{10835, 3548},
+        {11479, 3553},{12075, 3559},{12634, 3565},{13159, 3570},
+        {13650, 3573},{14124, 3576},{14575, 3580},{14993, 3583},
+        {15375, 3584},{15744, 3584},{16091, 3583},{16421, 3586}
+      }
+    },
+    {
+      /*Cb  qi=53  INTRA*/
+      {
+        {   14,    3},{  167,  367},{  317,  717},{  492, 1033},
+        {  687, 1306},{  887, 1531},{ 1095, 1715},{ 1309, 1866},
+        { 1517, 2000},{ 1729, 2119},{ 1932, 2227},{ 2146, 2325},
+        { 2358, 2414},{ 2544, 2511},{ 2724, 2611},{ 2902, 2711},
+        { 3070, 2800},{ 3227, 2878},{ 3381, 2954},{ 3548, 3021},
+        { 3724, 3077},{ 3888, 3140},{ 4065, 3196},{ 4359, 3225}
+      },
+      /*Cb  qi=53  INTER*/
+      {
+        {   93,   -8},{  110,  342},{  108,  668},{  125, 1018},
+        {  170, 1355},{  242, 1663},{  353, 1939},{  494, 2192},
+        {  651, 2433},{  838, 2658},{ 1076, 2856},{ 1368, 3022},
+        { 1716, 3158},{ 2123, 3260},{ 2575, 3330},{ 3042, 3373},
+        { 3507, 3396},{ 3962, 3413},{ 4394, 3430},{ 4797, 3452},
+        { 5169, 3476},{ 5547, 3496},{ 5914, 3510},{ 6235, 3525}
+      }
+    },
+    {
+      /*Cr  qi=53  INTRA*/
+      {
+        {   25,    7},{  175,  386},{  335,  734},{  541, 1037},
+        {  737, 1296},{  926, 1516},{ 1125, 1696},{ 1324, 1851},
+        { 1540, 1984},{ 1763, 2102},{ 1989, 2210},{ 2202, 2310},
+        { 2386, 2404},{ 2572, 2495},{ 2768, 2569},{ 2929, 2627},
+        { 3071, 2684},{ 3231, 2749},{ 3374, 2825},{ 3514, 2894},
+        { 3703, 2963},{ 3882, 3040},{ 4024, 3111},{ 4190, 3150}
+      },
+      /*Cr  qi=53  INTER*/
+      {
+        {   87,   -1},{   99,  352},{  100,  680},{  125, 1027},
+        {  175, 1355},{  249, 1657},{  343, 1946},{  462, 2220},
+        {  624, 2465},{  844, 2671},{ 1122, 2841},{ 1435, 2989},
+        { 1768, 3125},{ 2134, 3243},{ 2545, 3334},{ 3002, 3393},
+        { 3490, 3412},{ 3965, 3405},{ 4401, 3384},{ 4797, 3359},
+        { 5156, 3328},{ 5482, 3297},{ 5800, 3292},{ 6135, 3293}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=54  INTRA*/
+      {
+        {  184,   94},{  902, 1151},{ 1876, 1776},{ 2881, 2057},
+        { 3832, 2200},{ 4785, 2315},{ 5709, 2442},{ 6570, 2562},
+        { 7362, 2672},{ 8092, 2771},{ 8760, 2852},{ 9337, 2901},
+        { 9874, 2943},{10402, 2995},{10928, 3059},{11443, 3126},
+        {11926, 3178},{12396, 3220},{12805, 3251},{13139, 3266},
+        {13466, 3280},{13822, 3304},{14184, 3322},{14585, 3342}
+      },
+      /*Y'  qi=54  INTER*/
+      {
+        {   60,    5},{  169, 1308},{  683, 2375},{ 1791, 3090},
+        { 3478, 3412},{ 5184, 3470},{ 6568, 3455},{ 7697, 3446},
+        { 8659, 3446},{ 9503, 3447},{10266, 3450},{10971, 3454},
+        {11619, 3458},{12223, 3462},{12789, 3467},{13315, 3471},
+        {13811, 3475},{14291, 3479},{14743, 3479},{15148, 3481},
+        {15535, 3483},{15913, 3481},{16252, 3479},{16569, 3472}
+      }
+    },
+    {
+      /*Cb  qi=54  INTRA*/
+      {
+        {   13,    2},{  165,  367},{  318,  715},{  498, 1030},
+        {  698, 1301},{  906, 1523},{ 1121, 1703},{ 1336, 1853},
+        { 1549, 1984},{ 1765, 2100},{ 1974, 2207},{ 2192, 2306},
+        { 2402, 2396},{ 2587, 2493},{ 2773, 2591},{ 2953, 2691},
+        { 3119, 2778},{ 3277, 2858},{ 3430, 2940},{ 3603, 3004},
+        { 3788, 3059},{ 3950, 3121},{ 4128, 3173},{ 4398, 3215}
+      },
+      /*Cb  qi=54  INTER*/
+      {
+        {  100,   -3},{  109,  343},{  107,  668},{  125, 1018},
+        {  169, 1354},{  241, 1662},{  353, 1938},{  496, 2190},
+        {  655, 2431},{  843, 2655},{ 1082, 2851},{ 1381, 3015},
+        { 1739, 3146},{ 2154, 3243},{ 2610, 3310},{ 3094, 3344},
+        { 3581, 3358},{ 4034, 3371},{ 4457, 3384},{ 4867, 3399},
+        { 5255, 3413},{ 5630, 3425},{ 6003, 3440},{ 6346, 3440}
+      }
+    },
+    {
+      /*Cr  qi=54  INTRA*/
+      {
+        {   23,    7},{  174,  386},{  338,  732},{  549, 1034},
+        {  751, 1289},{  947, 1506},{ 1150, 1685},{ 1353, 1837},
+        { 1572, 1969},{ 1800, 2087},{ 2031, 2192},{ 2248, 2291},
+        { 2434, 2387},{ 2622, 2477},{ 2815, 2549},{ 2976, 2607},
+        { 3126, 2663},{ 3286, 2727},{ 3427, 2807},{ 3569, 2877},
+        { 3761, 2941},{ 3942, 3016},{ 4084, 3093},{ 4226, 3131}
+      },
+      /*Cr  qi=54  INTER*/
+      {
+        {   88,   -2},{   99,  351},{  100,  680},{  125, 1027},
+        {  175, 1354},{  248, 1656},{  343, 1945},{  463, 2219},
+        {  626, 2463},{  850, 2668},{ 1128, 2837},{ 1445, 2983},
+        { 1791, 3111},{ 2168, 3224},{ 2597, 3309},{ 3075, 3351},
+        { 3560, 3364},{ 4029, 3356},{ 4464, 3335},{ 4858, 3307},
+        { 5218, 3275},{ 5547, 3256},{ 5850, 3247},{ 6171, 3214}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=55  INTRA*/
+      {
+        {  178,   95},{  968, 1137},{ 2000, 1747},{ 3013, 2027},
+        { 3966, 2173},{ 4920, 2294},{ 5842, 2427},{ 6702, 2553},
+        { 7489, 2668},{ 8213, 2773},{ 8875, 2858},{ 9452, 2913},
+        { 9986, 2959},{10504, 3016},{11023, 3085},{11530, 3157},
+        {12011, 3213},{12480, 3257},{12882, 3291},{13214, 3310},
+        {13542, 3325},{13890, 3350},{14248, 3371},{14671, 3398}
+      },
+      /*Y'  qi=55  INTER*/
+      {
+        {   59,    5},{  170, 1307},{  725, 2358},{ 1886, 3058},
+        { 3589, 3385},{ 5284, 3459},{ 6654, 3458},{ 7771, 3461},
+        { 8727, 3470},{ 9564, 3478},{10322, 3488},{11019, 3497},
+        {11658, 3505},{12258, 3513},{12819, 3520},{13344, 3527},
+        {13840, 3533},{14314, 3537},{14755, 3541},{15161, 3544},
+        {15552, 3548},{15916, 3548},{16257, 3548},{16576, 3540}
+      }
+    },
+    {
+      /*Cb  qi=55  INTRA*/
+      {
+        {   13,    2},{  167,  366},{  322,  714},{  508, 1026},
+        {  716, 1292},{  930, 1511},{ 1148, 1690},{ 1366, 1839},
+        { 1578, 1972},{ 1793, 2090},{ 2001, 2199},{ 2217, 2300},
+        { 2427, 2393},{ 2609, 2495},{ 2784, 2600},{ 2961, 2704},
+        { 3121, 2797},{ 3268, 2884},{ 3423, 2965},{ 3590, 3032},
+        { 3764, 3096},{ 3926, 3165},{ 4101, 3223},{ 4405, 3258}
+      },
+      /*Cb  qi=55  INTER*/
+      {
+        {   90,   -4},{  109,  344},{  107,  668},{  126, 1017},
+        {  172, 1351},{  249, 1657},{  370, 1928},{  527, 2174},
+        {  702, 2407},{  909, 2624},{ 1170, 2814},{ 1493, 2970},
+        { 1869, 3097},{ 2292, 3192},{ 2752, 3258},{ 3232, 3295},
+        { 3709, 3314},{ 4156, 3335},{ 4592, 3355},{ 5004, 3373},
+        { 5377, 3389},{ 5737, 3411},{ 6092, 3432},{ 6473, 3423}
+      }
+    },
+    {
+      /*Cr  qi=55  INTRA*/
+      {
+        {   23,    7},{  175,  385},{  342,  730},{  561, 1028},
+        {  771, 1279},{  973, 1493},{ 1181, 1669},{ 1384, 1822},
+        { 1602, 1956},{ 1830, 2076},{ 2057, 2184},{ 2270, 2288},
+        { 2452, 2389},{ 2637, 2484},{ 2823, 2559},{ 2983, 2621},
+        { 3129, 2682},{ 3280, 2753},{ 3417, 2833},{ 3554, 2904},
+        { 3743, 2977},{ 3921, 3060},{ 4055, 3137},{ 4185, 3186}
+      },
+      /*Cr  qi=55  INTER*/
+      {
+        {   85,    0},{   99,  352},{  100,  679},{  126, 1025},
+        {  178, 1351},{  256, 1650},{  359, 1935},{  493, 2202},
+        {  675, 2439},{  921, 2636},{ 1220, 2799},{ 1552, 2941},
+        { 1910, 3068},{ 2303, 3177},{ 2735, 3262},{ 3206, 3311},
+        { 3689, 3333},{ 4152, 3327},{ 4588, 3299},{ 4978, 3272},
+        { 5325, 3243},{ 5651, 3221},{ 5969, 3210},{ 6218, 3185}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=56  INTRA*/
+      {
+        {  137,  104},{ 1048, 1128},{ 2147, 1760},{ 3261, 2029},
+        { 4319, 2131},{ 5310, 2234},{ 6245, 2351},{ 7101, 2464},
+        { 7886, 2572},{ 8610, 2675},{ 9270, 2762},{ 9840, 2818},
+        {10365, 2869},{10875, 2928},{11393, 2997},{11900, 3071},
+        {12371, 3128},{12834, 3172},{13233, 3208},{13562, 3228},
+        {13878, 3245},{14221, 3271},{14584, 3292},{15008, 3320}
+      },
+      /*Y'  qi=56  INTER*/
+      {
+        {   19,   21},{  207, 1292},{ 1031, 2252},{ 2553, 2846},
+        { 4463, 3085},{ 6137, 3131},{ 7441, 3151},{ 8526, 3172},
+        { 9468, 3193},{10301, 3209},{11059, 3224},{11760, 3237},
+        {12405, 3249},{13008, 3261},{13570, 3270},{14100, 3278},
+        {14597, 3284},{15074, 3289},{15524, 3297},{15929, 3302},
+        {16314, 3306},{16675, 3307},{17004, 3305},{17288, 3301}
+      }
+    },
+    {
+      /*Cb  qi=56  INTRA*/
+      {
+        {   16,    3},{  188,  367},{  353,  712},{  546, 1017},
+        {  765, 1275},{  989, 1484},{ 1221, 1653},{ 1459, 1791},
+        { 1681, 1920},{ 1893, 2046},{ 2102, 2160},{ 2323, 2257},
+        { 2534, 2347},{ 2720, 2447},{ 2902, 2549},{ 3075, 2654},
+        { 3239, 2749},{ 3392, 2835},{ 3544, 2920},{ 3712, 2988},
+        { 3882, 3052},{ 4052, 3123},{ 4227, 3181},{ 4483, 3213}
+      },
+      /*Cb  qi=56  INTER*/
+      {
+        {   92,   -1},{  111,  343},{  114,  665},{  148, 1003},
+        {  224, 1321},{  345, 1609},{  526, 1858},{  754, 2077},
+        { 1009, 2281},{ 1319, 2464},{ 1702, 2614},{ 2145, 2732},
+        { 2625, 2824},{ 3123, 2890},{ 3634, 2933},{ 4137, 2954},
+        { 4614, 2965},{ 5052, 2988},{ 5468, 3015},{ 5852, 3035},
+        { 6213, 3060},{ 6557, 3081},{ 6906, 3094},{ 7243, 3112}
+      }
+    },
+    {
+      /*Cr  qi=56  INTRA*/
+      {
+        {   28,    8},{  195,  385},{  373,  727},{  598, 1019},
+        {  816, 1263},{ 1033, 1465},{ 1260, 1630},{ 1482, 1773},
+        { 1717, 1900},{ 1949, 2018},{ 2178, 2128},{ 2393, 2233},
+        { 2570, 2338},{ 2749, 2435},{ 2937, 2514},{ 3097, 2577},
+        { 3240, 2638},{ 3398, 2709},{ 3540, 2791},{ 3673, 2865},
+        { 3869, 2938},{ 4049, 3019},{ 4179, 3095},{ 4330, 3137}
+      },
+      /*Cr  qi=56  INTER*/
+      {
+        {   83,    0},{   99,  353},{  103,  676},{  146, 1010},
+        {  232, 1320},{  355, 1601},{  512, 1866},{  713, 2109},
+        {  988, 2312},{ 1344, 2471},{ 1750, 2602},{ 2180, 2719},
+        { 2642, 2819},{ 3141, 2892},{ 3653, 2939},{ 4159, 2961},
+        { 4636, 2961},{ 5072, 2945},{ 5464, 2917},{ 5813, 2895},
+        { 6134, 2890},{ 6458, 2883},{ 6735, 2881},{ 6953, 2902}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=57  INTRA*/
+      {
+        {  170,  106},{ 1106, 1120},{ 2246, 1740},{ 3399, 1993},
+        { 4482, 2077},{ 5492, 2167},{ 6446, 2273},{ 7324, 2379},
+        { 8130, 2482},{ 8866, 2578},{ 9537, 2661},{10119, 2715},
+        {10646, 2762},{11161, 2820},{11694, 2886},{12214, 2957},
+        {12693, 3013},{13166, 3053},{13569, 3087},{13897, 3106},
+        {14224, 3122},{14568, 3148},{14931, 3167},{15390, 3192}
+      },
+      /*Y'  qi=57  INTER*/
+      {
+        {   19,   20},{  205, 1292},{ 1096, 2229},{ 2775, 2766},
+        { 4811, 2943},{ 6512, 2964},{ 7832, 2976},{ 8940, 2990},
+        { 9903, 3004},{10755, 3017},{11532, 3029},{12243, 3039},
+        {12891, 3047},{13502, 3058},{14073, 3065},{14603, 3071},
+        {15097, 3078},{15581, 3083},{16036, 3086},{16452, 3090},
+        {16855, 3093},{17222, 3094},{17552, 3092},{17851, 3098}
+      }
+    },
+    {
+      /*Cb  qi=57  INTRA*/
+      {
+        {   16,    3},{  197,  365},{  384,  704},{  603, 1001},
+        {  837, 1252},{ 1077, 1455},{ 1326, 1618},{ 1581, 1748},
+        { 1819, 1871},{ 2042, 1993},{ 2264, 2104},{ 2500, 2196},
+        { 2722, 2280},{ 2916, 2375},{ 3103, 2473},{ 3290, 2575},
+        { 3456, 2667},{ 3612, 2748},{ 3775, 2829},{ 3958, 2896},
+        { 4145, 2947},{ 4307, 3012},{ 4476, 3070},{ 4733, 3110}
+      },
+      /*Cb  qi=57  INTER*/
+      {
+        {   94,   -1},{  111,  344},{  112,  665},{  147, 1002},
+        {  227, 1319},{  353, 1604},{  543, 1849},{  785, 2062},
+        { 1066, 2257},{ 1408, 2430},{ 1827, 2568},{ 2320, 2670},
+        { 2848, 2743},{ 3386, 2791},{ 3934, 2812},{ 4453, 2820},
+        { 4929, 2830},{ 5368, 2842},{ 5787, 2856},{ 6190, 2875},
+        { 6554, 2896},{ 6895, 2913},{ 7229, 2927},{ 7572, 2932}
+      }
+    },
+    {
+      /*Cr  qi=57  INTRA*/
+      {
+        {   28,    8},{  207,  383},{  413,  716},{  661,  999},
+        {  889, 1237},{ 1123, 1433},{ 1365, 1592},{ 1603, 1731},
+        { 1853, 1852},{ 2103, 1965},{ 2345, 2072},{ 2571, 2173},
+        { 2763, 2271},{ 2949, 2364},{ 3146, 2438},{ 3315, 2497},
+        { 3459, 2552},{ 3618, 2616},{ 3767, 2697},{ 3906, 2773},
+        { 4099, 2841},{ 4281, 2916},{ 4429, 2987},{ 4569, 3030}
+      },
+      /*Cr  qi=57  INTER*/
+      {
+        {   85,    0},{   99,  352},{  102,  675},{  147, 1008},
+        {  235, 1317},{  363, 1597},{  529, 1858},{  748, 2094},
+        { 1050, 2287},{ 1439, 2436},{ 1877, 2557},{ 2352, 2660},
+        { 2869, 2740},{ 3413, 2791},{ 3962, 2815},{ 4485, 2819},
+        { 4955, 2816},{ 5382, 2800},{ 5769, 2772},{ 6107, 2748},
+        { 6443, 2740},{ 6754, 2739},{ 7029, 2737},{ 7284, 2745}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=58  INTRA*/
+      {
+        {  164,  109},{ 1198, 1111},{ 2396, 1737},{ 3606, 1978},
+        { 4727, 2048},{ 5749, 2138},{ 6708, 2243},{ 7584, 2347},
+        { 8388, 2449},{ 9122, 2549},{ 9784, 2635},{10354, 2691},
+        {10876, 2740},{11385, 2800},{11912, 2869},{12429, 2941},
+        {12902, 2997},{13375, 3040},{13779, 3075},{14103, 3096},
+        {14435, 3112},{14783, 3140},{15141, 3160},{15599, 3186}
+      },
+      /*Y'  qi=58  INTER*/
+      {
+        {   14,   23},{  210, 1290},{ 1277, 2178},{ 3118, 2677},
+        { 5207, 2834},{ 6902, 2857},{ 8218, 2878},{ 9323, 2900},
+        {10285, 2919},{11132, 2934},{11899, 2949},{12599, 2961},
+        {13235, 2971},{13835, 2982},{14394, 2991},{14917, 2997},
+        {15412, 3005},{15882, 3009},{16325, 3013},{16735, 3016},
+        {17131, 3018},{17501, 3021},{17824, 3021},{18125, 3016}
+      }
+    },
+    {
+      /*Cb  qi=58  INTRA*/
+      {
+        {   17,    3},{  200,  365},{  389,  703},{  613,  996},
+        {  853, 1243},{ 1095, 1445},{ 1349, 1604},{ 1613, 1731},
+        { 1853, 1853},{ 2074, 1978},{ 2292, 2091},{ 2526, 2184},
+        { 2750, 2266},{ 2945, 2360},{ 3134, 2458},{ 3320, 2561},
+        { 3482, 2654},{ 3641, 2737},{ 3804, 2818},{ 3985, 2881},
+        { 4168, 2935},{ 4331, 3003},{ 4499, 3060},{ 4751, 3100}
+      },
+      /*Cb  qi=58  INTER*/
+      {
+        {   94,   -1},{  112,  345},{  112,  665},{  152,  998},
+        {  247, 1307},{  406, 1580},{  644, 1810},{  938, 2007},
+        { 1271, 2189},{ 1668, 2348},{ 2151, 2470},{ 2691, 2558},
+        { 3249, 2619},{ 3798, 2659},{ 4334, 2682},{ 4849, 2692},
+        { 5314, 2700},{ 5747, 2721},{ 6167, 2742},{ 6547, 2765},
+        { 6902, 2790},{ 7251, 2804},{ 7583, 2819},{ 7924, 2833}
+      }
+    },
+    {
+      /*Cr  qi=58  INTRA*/
+      {
+        {   29,    8},{  210,  382},{  419,  714},{  671,  993},
+        {  903, 1229},{ 1141, 1422},{ 1390, 1578},{ 1635, 1713},
+        { 1889, 1833},{ 2140, 1946},{ 2379, 2055},{ 2604, 2157},
+        { 2794, 2256},{ 2977, 2349},{ 3174, 2422},{ 3339, 2482},
+        { 3483, 2537},{ 3643, 2604},{ 3790, 2684},{ 3927, 2757},
+        { 4112, 2826},{ 4294, 2900},{ 4451, 2975},{ 4600, 3011}
+      },
+      /*Cr  qi=58  INTER*/
+      {
+        {   86,    0},{   99,  352},{  103,  675},{  151, 1004},
+        {  256, 1306},{  417, 1573},{  628, 1819},{  901, 2040},
+        { 1262, 2217},{ 1705, 2353},{ 2191, 2466},{ 2713, 2556},
+        { 3268, 2622},{ 3831, 2664},{ 4374, 2682},{ 4881, 2686},
+        { 5339, 2685},{ 5747, 2668},{ 6123, 2646},{ 6465, 2630},
+        { 6783, 2618},{ 7082, 2623},{ 7366, 2632},{ 7673, 2654}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=59  INTRA*/
+      {
+        {  142,  112},{ 1259, 1100},{ 2552, 1711},{ 3815, 1933},
+        { 4955, 1987},{ 5983, 2068},{ 6949, 2165},{ 7832, 2263},
+        { 8645, 2359},{ 9392, 2454},{10066, 2536},{10643, 2589},
+        {11174, 2636},{11696, 2693},{12230, 2758},{12752, 2826},
+        {13239, 2883},{13721, 2926},{14139, 2959},{14479, 2978},
+        {14811, 2993},{15166, 3020},{15532, 3039},{16000, 3062}
+      },
+      /*Y'  qi=59  INTER*/
+      {
+        {    8,   25},{  211, 1289},{ 1394, 2144},{ 3421, 2580},
+        { 5611, 2689},{ 7316, 2701},{ 8643, 2717},{ 9762, 2734},
+        {10735, 2750},{11587, 2763},{12353, 2775},{13056, 2785},
+        {13693, 2793},{14288, 2805},{14843, 2814},{15361, 2821},
+        {15857, 2827},{16328, 2831},{16763, 2834},{17171, 2838},
+        {17568, 2840},{17941, 2842},{18285, 2843},{18586, 2839}
+      }
+    },
+    {
+      /*Cb  qi=59  INTRA*/
+      {
+        {   17,    3},{  224,  363},{  441,  696},{  689,  982},
+        {  945, 1222},{ 1204, 1416},{ 1474, 1571},{ 1751, 1695},
+        { 2001, 1816},{ 2228, 1941},{ 2453, 2055},{ 2693, 2147},
+        { 2924, 2227},{ 3125, 2321},{ 3321, 2416},{ 3510, 2520},
+        { 3676, 2616},{ 3839, 2699},{ 4008, 2778},{ 4193, 2842},
+        { 4371, 2898},{ 4535, 2965},{ 4710, 3023},{ 4921, 3068}
+      },
+      /*Cb  qi=59  INTER*/
+      {
+        {   95,   -5},{  111,  343},{  112,  664},{  157,  995},
+        {  258, 1302},{  429, 1569},{  691, 1790},{ 1017, 1977},
+        { 1387, 2148},{ 1832, 2294},{ 2368, 2401},{ 2961, 2472},
+        { 3553, 2518},{ 4133, 2545},{ 4688, 2557},{ 5198, 2563},
+        { 5663, 2574},{ 6100, 2590},{ 6511, 2608},{ 6898, 2621},
+        { 7274, 2634},{ 7631, 2655},{ 7984, 2669},{ 8361, 2669}
+      }
+    },
+    {
+      /*Cr  qi=59  INTRA*/
+      {
+        {   31,    8},{  240,  379},{  480,  706},{  748,  978},
+        {  993, 1208},{ 1250, 1394},{ 1519, 1543},{ 1779, 1674},
+        { 2047, 1792},{ 2307, 1904},{ 2552, 2013},{ 2780, 2116},
+        { 2973, 2216},{ 3165, 2309},{ 3362, 2383},{ 3528, 2444},
+        { 3677, 2499},{ 3841, 2566},{ 3995, 2646},{ 4139, 2720},
+        { 4324, 2793},{ 4504, 2867},{ 4658, 2939},{ 4806, 2975}
+      },
+      /*Cr  qi=59  INTER*/
+      {
+        {   89,   -3},{   98,  352},{  103,  674},{  156, 1002},
+        {  268, 1300},{  441, 1562},{  673, 1801},{  980, 2010},
+        { 1385, 2175},{ 1868, 2301},{ 2401, 2402},{ 2984, 2474},
+        { 3591, 2520},{ 4179, 2545},{ 4729, 2555},{ 5232, 2553},
+        { 5679, 2545},{ 6081, 2530},{ 6447, 2510},{ 6791, 2496},
+        { 7101, 2487},{ 7393, 2489},{ 7684, 2499},{ 7950, 2501}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=60  INTRA*/
+      {
+        {   92,  116},{ 1361, 1085},{ 2746, 1686},{ 4050, 1895},
+        { 5209, 1939},{ 6244, 2012},{ 7213, 2103},{ 8105, 2197},
+        { 8928, 2290},{ 9685, 2381},{10371, 2460},{10952, 2511},
+        {11487, 2556},{12026, 2611},{12574, 2674},{13102, 2739},
+        {13597, 2793},{14092, 2831},{14523, 2862},{14862, 2881},
+        {15198, 2897},{15568, 2923},{15949, 2941},{16416, 2964}
+      },
+      /*Y'  qi=60  INTER*/
+      {
+        {    4,   30},{  215, 1287},{ 1547, 2104},{ 3729, 2491},
+        { 5973, 2568},{ 7672, 2577},{ 9001, 2591},{10123, 2606},
+        {11094, 2620},{11943, 2632},{12709, 2643},{13409, 2652},
+        {14044, 2660},{14641, 2669},{15193, 2677},{15709, 2684},
+        {16201, 2689},{16675, 2693},{17118, 2696},{17522, 2701},
+        {17920, 2704},{18293, 2706},{18620, 2702},{18923, 2700}
+      }
+    },
+    {
+      /*Cb  qi=60  INTRA*/
+      {
+        {   18,    3},{  227,  362},{  447,  694},{  708,  974},
+        {  981, 1207},{ 1252, 1397},{ 1532, 1547},{ 1822, 1663},
+        { 2082, 1780},{ 2316, 1903},{ 2548, 2013},{ 2794, 2101},
+        { 3029, 2178},{ 3242, 2266},{ 3445, 2360},{ 3638, 2459},
+        { 3816, 2547},{ 3980, 2628},{ 4146, 2708},{ 4344, 2766},
+        { 4546, 2812},{ 4725, 2872},{ 4880, 2930},{ 5054, 2966}
+      },
+      /*Cb  qi=60  INTER*/
+      {
+        {   97,   -4},{  112,  343},{  114,  664},{  162,  993},
+        {  273, 1294},{  472, 1553},{  774, 1762},{ 1138, 1939},
+        { 1543, 2102},{ 2034, 2236},{ 2620, 2329},{ 3244, 2389},
+        { 3860, 2423},{ 4443, 2440},{ 4997, 2449},{ 5502, 2455},
+        { 5962, 2458},{ 6413, 2466},{ 6836, 2485},{ 7217, 2506},
+        { 7592, 2518},{ 7957, 2533},{ 8291, 2543},{ 8574, 2545}
+      }
+    },
+    {
+      /*Cr  qi=60  INTRA*/
+      {
+        {   32,    8},{  243,  379},{  488,  702},{  771,  968},
+        { 1030, 1192},{ 1300, 1373},{ 1581, 1517},{ 1854, 1643},
+        { 2127, 1757},{ 2393, 1864},{ 2645, 1968},{ 2879, 2068},
+        { 3078, 2166},{ 3277, 2256},{ 3484, 2325},{ 3660, 2381},
+        { 3808, 2433},{ 3970, 2496},{ 4138, 2571},{ 4288, 2643},
+        { 4475, 2710},{ 4655, 2778},{ 4810, 2843},{ 4959, 2879}
+      },
+      /*Cr  qi=60  INTER*/
+      {
+        {   86,   -2},{   99,  352},{  103,  673},{  160,  998},
+        {  284, 1292},{  484, 1546},{  753, 1774},{ 1100, 1973},
+        { 1546, 2129},{ 2072, 2246},{ 2652, 2334},{ 3279, 2392},
+        { 3911, 2425},{ 4504, 2440},{ 5044, 2443},{ 5536, 2440},
+        { 5979, 2430},{ 6381, 2413},{ 6735, 2397},{ 7062, 2382},
+        { 7383, 2376},{ 7680, 2375},{ 7962, 2373},{ 8203, 2379}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=61  INTRA*/
+      {
+        {   54,  121},{ 1477, 1069},{ 3061, 1638},{ 4465, 1808},
+        { 5649, 1827},{ 6710, 1884},{ 7716, 1958},{ 8648, 2037},
+        { 9514, 2116},{10311, 2192},{11033, 2261},{11641, 2305},
+        {12202, 2342},{12771, 2387},{13356, 2440},{13924, 2493},
+        {14444, 2541},{14951, 2576},{15409, 2600},{15779, 2615},
+        {16131, 2626},{16521, 2648},{16921, 2663},{17409, 2694}
+      },
+      /*Y'  qi=61  INTER*/
+      {
+        {   -1,   32},{  216, 1286},{ 1806, 2036},{ 4279, 2327},
+        { 6629, 2352},{ 8347, 2352},{ 9707, 2357},{10860, 2364},
+        {11857, 2372},{12726, 2377},{13508, 2382},{14225, 2387},
+        {14877, 2392},{15484, 2398},{16048, 2401},{16581, 2405},
+        {17092, 2409},{17573, 2409},{18016, 2410},{18427, 2413},
+        {18829, 2415},{19221, 2415},{19578, 2415},{19980, 2413}
+      }
+    },
+    {
+      /*Cb  qi=61  INTRA*/
+      {
+        {   19,    3},{  231,  362},{  456,  693},{  733,  965},
+        { 1032, 1188},{ 1330, 1369},{ 1637, 1508},{ 1956, 1612},
+        { 2241, 1718},{ 2496, 1832},{ 2750, 1932},{ 3019, 2007},
+        { 3274, 2074},{ 3505, 2154},{ 3725, 2236},{ 3943, 2323},
+        { 4138, 2403},{ 4323, 2476},{ 4505, 2543},{ 4706, 2592},
+        { 4909, 2630},{ 5109, 2675},{ 5292, 2724},{ 5495, 2768}
+      },
+      /*Cb  qi=61  INTER*/
+      {
+        {   91,   -2},{  111,  344},{  114,  663},{  166,  989},
+        {  291, 1285},{  522, 1534},{  875, 1729},{ 1302, 1889},
+        { 1786, 2031},{ 2368, 2141},{ 3042, 2207},{ 3734, 2243},
+        { 4388, 2259},{ 4982, 2264},{ 5533, 2265},{ 6043, 2262},
+        { 6524, 2264},{ 6982, 2274},{ 7422, 2283},{ 7831, 2295},
+        { 8198, 2308},{ 8593, 2319},{ 8965, 2329},{ 9258, 2340}
+      }
+    },
+    {
+      /*Cr  qi=61  INTRA*/
+      {
+        {   33,    9},{  245,  378},{  497,  699},{  801,  958},
+        { 1087, 1171},{ 1384, 1342},{ 1692, 1474},{ 1992, 1589},
+        { 2290, 1692},{ 2576, 1789},{ 2852, 1884},{ 3109, 1973},
+        { 3324, 2061},{ 3544, 2142},{ 3763, 2199},{ 3945, 2244},
+        { 4103, 2292},{ 4283, 2349},{ 4469, 2413},{ 4635, 2476},
+        { 4836, 2534},{ 5038, 2592},{ 5210, 2649},{ 5358, 2682}
+      },
+      /*Cr  qi=61  INTER*/
+      {
+        {   82,    0},{   97,  353},{  104,  672},{  165,  995},
+        {  303, 1284},{  532, 1529},{  852, 1742},{ 1273, 1921},
+        { 1798, 2057},{ 2409, 2154},{ 3090, 2212},{ 3794, 2240},
+        { 4460, 2251},{ 5057, 2249},{ 5596, 2249},{ 6085, 2245},
+        { 6519, 2234},{ 6908, 2220},{ 7269, 2203},{ 7618, 2196},
+        { 7949, 2198},{ 8269, 2195},{ 8554, 2196},{ 8928, 2217}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=62  INTRA*/
+      {
+        {   29,  124},{ 1527, 1067},{ 3221, 1618},{ 4703, 1751},
+        { 5909, 1744},{ 7001, 1779},{ 8057, 1829},{ 9049, 1885},
+        { 9968, 1943},{10813, 1999},{11572, 2050},{12206, 2082},
+        {12801, 2107},{13402, 2140},{14020, 2180},{14625, 2223},
+        {15179, 2260},{15718, 2288},{16196, 2305},{16581, 2313},
+        {16963, 2324},{17382, 2341},{17800, 2351},{18318, 2376}
+      },
+      /*Y'  qi=62  INTER*/
+      {
+        {   -8,   36},{  218, 1284},{ 2073, 1965},{ 4814, 2159},
+        { 7237, 2138},{ 8979, 2124},{10378, 2115},{11570, 2109},
+        {12601, 2106},{13503, 2103},{14320, 2103},{15064, 2103},
+        {15746, 2103},{16384, 2104},{16975, 2105},{17534, 2105},
+        {18062, 2106},{18564, 2107},{19035, 2106},{19471, 2107},
+        {19890, 2107},{20288, 2107},{20651, 2107},{21012, 2108}
+      }
+    },
+    {
+      /*Cb  qi=62  INTRA*/
+      {
+        {   21,    3},{  283,  360},{  565,  683},{  907,  938},
+        { 1269, 1143},{ 1611, 1311},{ 1949, 1441},{ 2290, 1535},
+        { 2596, 1632},{ 2877, 1738},{ 3162, 1828},{ 3458, 1893},
+        { 3745, 1948},{ 4011, 2016},{ 4253, 2089},{ 4506, 2164},
+        { 4734, 2233},{ 4943, 2294},{ 5162, 2353},{ 5381, 2393},
+        { 5593, 2420},{ 5807, 2454},{ 6003, 2496},{ 6210, 2543}
+      },
+      /*Cb  qi=62  INTER*/
+      {
+        {   91,   -1},{  110,  344},{  113,  663},{  169,  987},
+        {  306, 1279},{  562, 1519},{  961, 1701},{ 1450, 1845},
+        { 2013, 1967},{ 2686, 2053},{ 3437, 2095},{ 4171, 2109},
+        { 4841, 2109},{ 5441, 2105},{ 6002, 2097},{ 6542, 2089},
+        { 7028, 2087},{ 7491, 2088},{ 7949, 2090},{ 8377, 2089},
+        { 8789, 2095},{ 9195, 2103},{ 9569, 2104},{ 9937, 2102}
+      }
+    },
+    {
+      /*Cr  qi=62  INTRA*/
+      {
+        {   38,    8},{  308,  374},{  619,  685},{  984,  925},
+        { 1326, 1126},{ 1662, 1285},{ 1999, 1407},{ 2328, 1512},
+        { 2659, 1604},{ 2976, 1691},{ 3285, 1774},{ 3570, 1853},
+        { 3815, 1931},{ 4068, 1998},{ 4304, 2044},{ 4491, 2082},
+        { 4666, 2124},{ 4870, 2174},{ 5078, 2231},{ 5262, 2285},
+        { 5480, 2335},{ 5703, 2378},{ 5905, 2423},{ 6075, 2454}
+      },
+      /*Cr  qi=62  INTER*/
+      {
+        {   79,    1},{   95,  353},{  102,  671},{  169,  992},
+        {  318, 1277},{  569, 1515},{  936, 1716},{ 1428, 1876},
+        { 2034, 1993},{ 2738, 2067},{ 3511, 2095},{ 4268, 2094},
+        { 4943, 2087},{ 5543, 2079},{ 6074, 2074},{ 6552, 2069},
+        { 6985, 2057},{ 7366, 2043},{ 7728, 2030},{ 8086, 2021},
+        { 8423, 2017},{ 8752, 2016},{ 9057, 2014},{ 9376, 2008}
+      }
+    }
+  },
+  {
+    {
+      /*Y'  qi=63  INTRA*/
+      {
+        {  -59,  134},{ 1734, 1036},{ 3743, 1521},{ 5309, 1618},
+        { 6520, 1597},{ 7664, 1609},{ 8809, 1630},{ 9894, 1657},
+        {10907, 1687},{11838, 1717},{12673, 1744},{13379, 1758},
+        {14038, 1767},{14698, 1784},{15379, 1806},{16062, 1831},
+        {16694, 1852},{17300, 1867},{17827, 1878},{18250, 1881},
+        {18702, 1884},{19199, 1892},{19665, 1896},{20273, 1908}
+      },
+      /*Y'  qi=63  INTER*/
+      {
+        {   -7,   33},{  209, 1285},{ 2309, 1904},{ 5274, 2025},
+        { 7801, 1966},{ 9637, 1924},{11126, 1892},{12403, 1868},
+        {13515, 1849},{14491, 1834},{15380, 1822},{16197, 1814},
+        {16944, 1806},{17645, 1799},{18303, 1794},{18916, 1789},
+        {19494, 1785},{20056, 1782},{20568, 1779},{21047, 1776},
+        {21508, 1775},{21925, 1772},{22327, 1770},{22678, 1771}
+      }
+    },
+    {
+      /*Cb  qi=63  INTRA*/
+      {
+        {   20,    3},{  294,  357},{  608,  673},{ 1047,  908},
+        { 1501, 1090},{ 1898, 1240},{ 2275, 1353},{ 2654, 1427},
+        { 3014, 1502},{ 3366, 1579},{ 3726, 1637},{ 4084, 1674},
+        { 4425, 1703},{ 4752, 1743},{ 5058, 1791},{ 5377, 1838},
+        { 5676, 1877},{ 5946, 1912},{ 6213, 1945},{ 6458, 1969},
+        { 6704, 1982},{ 6969, 1997},{ 7210, 2017},{ 7439, 2037}
+      },
+      /*Cb  qi=63  INTER*/
+      {
+        {   86,    1},{  108,  345},{  111,  663},{  168,  985},
+        {  307, 1276},{  577, 1513},{ 1007, 1688},{ 1550, 1819},
+        { 2189, 1921},{ 2938, 1981},{ 3744, 2002},{ 4512, 2002},
+        { 5199, 1996},{ 5824, 1986},{ 6419, 1971},{ 6978, 1954},
+        { 7507, 1940},{ 8015, 1932},{ 8502, 1928},{ 8978, 1920},
+        { 9410, 1915},{ 9842, 1910},{10262, 1901},{10634, 1896}
+      }
+    },
+    {
+      /*Cr  qi=63  INTRA*/
+      {
+        {   38,    7},{  324,  367},{  677,  670},{ 1136,  892},
+        { 1562, 1070},{ 1951, 1209},{ 2326, 1313},{ 2694, 1399},
+        { 3074, 1471},{ 3460, 1531},{ 3850, 1575},{ 4214, 1622},
+        { 4522, 1679},{ 4819, 1723},{ 5089, 1749},{ 5315, 1769},
+        { 5530, 1792},{ 5756, 1825},{ 6006, 1860},{ 6244, 1889},
+        { 6514, 1924},{ 6792, 1946},{ 7026, 1962},{ 7191, 1971}
+      },
+      /*Cr  qi=63  INTER*/
+      {
+        {   80,    2},{   95,  354},{  101,  671},{  167,  990},
+        {  321, 1274},{  585, 1509},{  984, 1702},{ 1534, 1849},
+        { 2217, 1947},{ 3005, 1995},{ 3839, 1999},{ 4619, 1986},
+        { 5310, 1973},{ 5933, 1961},{ 6486, 1952},{ 6988, 1942},
+        { 7435, 1927},{ 7817, 1911},{ 8198, 1900},{ 8552, 1895},
+        { 8881, 1890},{ 9253, 1883},{ 9598, 1876},{ 9923, 1859}
+      }
+    }
+  }
+};
+
+#endif
diff --git a/lib/ocintrin.h b/lib/ocintrin.h
new file mode 100644 (file)
index 0000000..d49ebb2
--- /dev/null
@@ -0,0 +1,128 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: ocintrin.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+/*Some common macros for potential platform-specific optimization.*/
+#include <math.h>
+#if !defined(_ocintrin_H)
+# define _ocintrin_H (1)
+
+/*Some specific platforms may have optimized intrinsic or inline assembly
+   versions of these functions which can substantially improve performance.
+  We define macros for them to allow easy incorporation of these non-ANSI
+   features.*/
+
+/*Note that we do not provide a macro for abs(), because it is provided as a
+   library function, which we assume is translated into an intrinsic to avoid
+   the function call overhead and then implemented in the smartest way for the
+   target platform.
+  With modern gcc (4.x), this is true: it uses cmov instructions if the
+   architecture supports it and branchless bit-twiddling if it does not (the
+   speed difference between the two approaches is not measurable).
+  Interestingly, the bit-twiddling method was patented in 2000 (US 6,073,150)
+   by Sun Microsystems, despite prior art dating back to at least 1996:
+   http://web.archive.org/web/19961201174141/www.x86.org/ftp/articles/pentopt/PENTOPT.TXT
+  On gcc 3.x, however, our assumption is not true, as abs() is translated to a
+   conditional jump, which is horrible on deeply piplined architectures (e.g.,
+   all consumer architectures for the past decade or more).
+  Also be warned that -C*abs(x) where C is a constant is mis-optimized as
+   abs(C*x) on every gcc release before 4.2.3.
+  See bug http://gcc.gnu.org/bugzilla/show_bug.cgi?id=34130 */
+
+/*Modern gcc (4.x) can compile the naive versions of min and max with cmov if
+   given an appropriate architecture, but the branchless bit-twiddling versions
+   are just as fast, and do not require any special target architecture.
+  Earlier gcc versions (3.x) compiled both code to the same assembly
+   instructions, because of the way they represented ((_b)>(_a)) internally.*/
+#define OC_MAXI(_a,_b)      ((_a)-((_a)-(_b)&-((_b)>(_a))))
+#define OC_MINI(_a,_b)      ((_a)+((_b)-(_a)&-((_b)<(_a))))
+/*Clamps an integer into the given range.
+  If _a>_c, then the lower bound _a is respected over the upper bound _c (this
+   behavior is required to meet our documented API behavior).
+  _a: The lower bound.
+  _b: The value to clamp.
+  _c: The upper boud.*/
+#define OC_CLAMPI(_a,_b,_c) (OC_MAXI(_a,OC_MINI(_b,_c)))
+#define OC_CLAMP255(_x)     ((unsigned char)((((_x)<0)-1)&((_x)|-((_x)>255))))
+/*This has a chance of compiling branchless, and is just as fast as the
+   bit-twiddling method, which is slightly less portable, since it relies on a
+   sign-extended rightshift, which is not guaranteed by ANSI (but present on
+   every relevant platform).*/
+#define OC_SIGNI(_a)        (((_a)>0)-((_a)<0))
+/*Slightly more portable than relying on a sign-extended right-shift (which is
+   not guaranteed by ANSI), and just as fast, since gcc (3.x and 4.x both)
+   compile it into the right-shift anyway.*/
+#define OC_SIGNMASK(_a)     (-((_a)<0))
+/*Divides an integer by a power of two, truncating towards 0.
+  _dividend: The integer to divide.
+  _shift:    The non-negative power of two to divide by.
+  _rmask:    (1<<_shift)-1*/
+#define OC_DIV_POW2(_dividend,_shift,_rmask)\
+  ((_dividend)+(OC_SIGNMASK(_dividend)&(_rmask))>>(_shift))
+/*Divides _x by 65536, truncating towards 0.*/
+#define OC_DIV2_16(_x) OC_DIV_POW2(_x,16,0xFFFF)
+/*Divides _x by 2, truncating towards 0.*/
+#define OC_DIV2(_x) OC_DIV_POW2(_x,1,0x1)
+/*Divides _x by 8, truncating towards 0.*/
+#define OC_DIV8(_x) OC_DIV_POW2(_x,3,0x7)
+/*Divides _x by 16, truncating towards 0.*/
+#define OC_DIV16(_x) OC_DIV_POW2(_x,4,0xF)
+/*Right shifts _dividend by _shift, adding _rval, and subtracting one for
+   negative dividends first.
+  When _rval is (1<<_shift-1), this is equivalent to division with rounding
+   ties away from zero.*/
+#define OC_DIV_ROUND_POW2(_dividend,_shift,_rval)\
+  ((_dividend)+OC_SIGNMASK(_dividend)+(_rval)>>(_shift))
+/*Divides a _x by 2, rounding towards even numbers.*/
+#define OC_DIV2_RE(_x) ((_x)+((_x)>>1&1)>>1)
+/*Divides a _x by (1<<(_shift)), rounding towards even numbers.*/
+#define OC_DIV_POW2_RE(_x,_shift) \
+  ((_x)+((_x)>>(_shift)&1)+((1<<(_shift))-1>>1)>>(_shift))
+/*Swaps two integers _a and _b if _a>_b.*/
+#define OC_SORT2I(_a,_b) \
+  do{ \
+    int t__; \
+    t__=((_a)^(_b))&-((_b)<(_a)); \
+    (_a)^=t__; \
+    (_b)^=t__; \
+  } \
+  while(0)
+
+/*Accesses one of four (signed) bytes given an index.
+  This can be used to avoid small lookup tables.*/
+#define OC_BYTE_TABLE32(_a,_b,_c,_d,_i) \
+  ((signed char) \
+   (((_a)&0xFF|((_b)&0xFF)<<8|((_c)&0xFF)<<16|((_d)&0xFF)<<24)>>(_i)*8))
+/*Accesses one of eight (unsigned) nibbles given an index.
+  This can be used to avoid small lookup tables.*/
+#define OC_UNIBBLE_TABLE32(_a,_b,_c,_d,_e,_f,_g,_h,_i) \
+  ((((_a)&0xF|((_b)&0xF)<<4|((_c)&0xF)<<8|((_d)&0xF)<<12| \
+   ((_e)&0xF)<<16|((_f)&0xF)<<20|((_g)&0xF)<<24|((_h)&0xF)<<28)>>(_i)*4)&0xF)
+
+
+
+/*All of these macros should expect floats as arguments.*/
+#define OC_MAXF(_a,_b)      ((_a)<(_b)?(_b):(_a))
+#define OC_MINF(_a,_b)      ((_a)>(_b)?(_b):(_a))
+#define OC_CLAMPF(_a,_b,_c) (OC_MINF(_a,OC_MAXF(_b,_c)))
+#define OC_FABSF(_f)        ((float)fabs(_f))
+#define OC_SQRTF(_f)        ((float)sqrt(_f))
+#define OC_POWF(_b,_e)      ((float)pow(_b,_e))
+#define OC_LOGF(_f)         ((float)log(_f))
+#define OC_IFLOORF(_f)      ((int)floor(_f))
+#define OC_ICEILF(_f)       ((int)ceil(_f))
+
+#endif
diff --git a/lib/quant.c b/lib/quant.c
new file mode 100644 (file)
index 0000000..8359f5a
--- /dev/null
@@ -0,0 +1,119 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: quant.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+#include "quant.h"
+#include "decint.h"
+
+static const unsigned OC_DC_QUANT_MIN[2]={4<<2,8<<2};
+static const unsigned OC_AC_QUANT_MIN[2]={2<<2,4<<2};
+
+/*Initializes the dequantization tables from a set of quantizer info.
+  Currently the dequantizer (and elsewhere enquantizer) tables are expected to
+   be initialized as pointing to the storage reserved for them in the
+   oc_theora_state (resp. oc_enc_ctx) structure.
+  If some tables are duplicates of others, the pointers will be adjusted to
+   point to a single copy of the tables, but the storage for them will not be
+   freed.
+  If you're concerned about the memory footprint, the obvious thing to do is
+   to move the storage out of its fixed place in the structures and allocate
+   it on demand.
+  However, a much, much better option is to only store the quantization
+   matrices being used for the current frame, and to recalculate these as the
+   qi values change between frames (this is what VP3 did).*/
+void oc_dequant_tables_init(ogg_uint16_t *_dequant[64][3][2],
+ int _pp_dc_scale[64],const th_quant_info *_qinfo){
+  /*Coding mode: intra or inter.*/
+  int          qti;
+  /*Y', C_b, C_r*/
+  int          pli;
+  for(qti=0;qti<2;qti++)for(pli=0;pli<3;pli++){
+    /*Quality index.*/
+    int qi;
+    /*Range iterator.*/
+    int qri;
+    for(qi=0,qri=0;qri<=_qinfo->qi_ranges[qti][pli].nranges;qri++){
+      th_quant_base base;
+      ogg_uint32_t  q;
+      int           qi_start;
+      int           qi_end;
+      memcpy(base,_qinfo->qi_ranges[qti][pli].base_matrices[qri],
+       sizeof(base));
+      qi_start=qi;
+      if(qri==_qinfo->qi_ranges[qti][pli].nranges)qi_end=qi+1;
+      else qi_end=qi+_qinfo->qi_ranges[qti][pli].sizes[qri];
+      /*Iterate over quality indicies in this range.*/
+      for(;;){
+        ogg_uint32_t qfac;
+        int          zzi;
+        int          ci;
+        /*In the original VP3.2 code, the rounding offset and the size of the
+           dead zone around 0 were controlled by a "sharpness" parameter.
+          The size of our dead zone is now controlled by the per-coefficient
+           quality thresholds returned by our HVS module.
+          We round down from a more accurate value when the quality of the
+           reconstruction does not fall below our threshold and it saves bits.
+          Hence, all of that VP3.2 code is gone from here, and the remaining
+           floating point code has been implemented as equivalent integer code
+           with exact precision.*/
+        qfac=(ogg_uint32_t)_qinfo->dc_scale[qi]*base[0];
+        /*For postprocessing, not dequantization.*/
+        if(_pp_dc_scale!=NULL)_pp_dc_scale[qi]=(int)(qfac/160);
+        /*Scale DC the coefficient from the proper table.*/
+        q=(qfac/100)<<2;
+        q=OC_CLAMPI(OC_DC_QUANT_MIN[qti],q,OC_QUANT_MAX);
+        _dequant[qi][pli][qti][0]=(ogg_uint16_t)q;
+        /*Now scale AC coefficients from the proper table.*/
+        for(zzi=1;zzi<64;zzi++){
+          q=((ogg_uint32_t)_qinfo->ac_scale[qi]*base[OC_FZIG_ZAG[zzi]]/100)<<2;
+          q=OC_CLAMPI(OC_AC_QUANT_MIN[qti],q,OC_QUANT_MAX);
+          _dequant[qi][pli][qti][zzi]=(ogg_uint16_t)q;
+        }
+        /*If this is a duplicate of a previous matrix, use that instead.
+          This simple check helps us improve cache coherency later.*/
+        {
+          int dupe;
+          int qtj;
+          int plj;
+          dupe=0;
+          for(qtj=0;qtj<=qti;qtj++){
+            for(plj=0;plj<(qtj<qti?3:pli);plj++){
+              if(!memcmp(_dequant[qi][pli][qti],_dequant[qi][plj][qtj],
+               sizeof(oc_quant_table))){
+                dupe=1;
+                break;
+              }
+            }
+            if(dupe)break;
+          }
+          if(dupe)_dequant[qi][pli][qti]=_dequant[qi][plj][qtj];
+        }
+        if(++qi>=qi_end)break;
+        /*Interpolate the next base matrix.*/
+        for(ci=0;ci<64;ci++){
+          base[ci]=(unsigned char)(
+           (2*((qi_end-qi)*_qinfo->qi_ranges[qti][pli].base_matrices[qri][ci]+
+           (qi-qi_start)*_qinfo->qi_ranges[qti][pli].base_matrices[qri+1][ci])
+           +_qinfo->qi_ranges[qti][pli].sizes[qri])/
+           (2*_qinfo->qi_ranges[qti][pli].sizes[qri]));
+        }
+      }
+    }
+  }
+}
diff --git a/lib/quant.h b/lib/quant.h
new file mode 100644 (file)
index 0000000..49ce13a
--- /dev/null
@@ -0,0 +1,33 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: quant.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#if !defined(_quant_H)
+# define _quant_H (1)
+# include "theora/codec.h"
+# include "ocintrin.h"
+
+typedef ogg_uint16_t   oc_quant_table[64];
+
+
+/*Maximum scaled quantizer value.*/
+#define OC_QUANT_MAX          (1024<<2)
+
+
+void oc_dequant_tables_init(ogg_uint16_t *_dequant[64][3][2],
+ int _pp_dc_scale[64],const th_quant_info *_qinfo);
+
+#endif
diff --git a/lib/rate.c b/lib/rate.c
new file mode 100644 (file)
index 0000000..4f43bb2
--- /dev/null
@@ -0,0 +1,1137 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: rate.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include <stdlib.h>
+#include <string.h>
+#include "encint.h"
+
+/*A rough lookup table for tan(x), 0<=x<pi/2.
+  The values are Q12 fixed-point and spaced at 5 degree intervals.
+  These decisions are somewhat arbitrary, but sufficient for the 2nd order
+   Bessel follower below.
+  Values of x larger than 85 degrees are extrapolated from the last inteval,
+   which is way off, but "good enough".*/
+static unsigned short OC_ROUGH_TAN_LOOKUP[18]={
+      0,  358,  722, 1098, 1491, 1910,
+   2365, 2868, 3437, 4096, 4881, 5850,
+   7094, 8784,11254,15286,23230,46817
+};
+
+/*_alpha is Q24 in the range [0,0.5).
+  The return values is 5.12.*/
+static int oc_warp_alpha(int _alpha){
+  int i;
+  int d;
+  int t0;
+  int t1;
+  i=_alpha*36>>24;
+  if(i>=17)i=16;
+  t0=OC_ROUGH_TAN_LOOKUP[i];
+  t1=OC_ROUGH_TAN_LOOKUP[i+1];
+  d=_alpha*36-(i<<24);
+  return (int)(((ogg_int64_t)t0<<32)+(t1-t0<<8)*(ogg_int64_t)d>>32);
+}
+
+/*Re-initialize the Bessel filter coefficients with the specified delay.
+  This does not alter the x/y state, but changes the reaction time of the
+   filter.
+  Altering the time constant of a reactive filter without alterning internal
+   state is something that has to be done carefuly, but our design operates at
+   high enough delays and with small enough time constant changes to make it
+   safe.*/
+static void oc_iir_filter_reinit(oc_iir_filter *_f,int _delay){
+  int         alpha;
+  ogg_int64_t one48;
+  ogg_int64_t warp;
+  ogg_int64_t k1;
+  ogg_int64_t k2;
+  ogg_int64_t d;
+  ogg_int64_t a;
+  ogg_int64_t ik2;
+  ogg_int64_t b1;
+  ogg_int64_t b2;
+  /*This borrows some code from an unreleased version of Postfish.
+    See the recipe at http://unicorn.us.com/alex/2polefilters.html for details
+     on deriving the filter coefficients.*/
+  /*alpha is Q24*/
+  alpha=(1<<24)/_delay;
+  one48=(ogg_int64_t)1<<48;
+  /*warp is 7.12*/
+  warp=OC_MAXI(oc_warp_alpha(alpha),1);
+  /*k1 is 9.12*/
+  k1=3*warp;
+  /*k2 is 16.24.*/
+  k2=k1*warp;
+  /*d is 16.15.*/
+  d=((1<<12)+k1<<12)+k2+256>>9;
+  /*a is 0.32, since d is larger than both 1.0 and k2.*/
+  a=(k2<<23)/d;
+  /*ik2 is 25.24.*/
+  ik2=one48/k2;
+  /*b1 is Q56; in practice, the integer ranges between -2 and 2.*/
+  b1=2*a*(ik2-(1<<24));
+  /*b2 is Q56; in practice, the integer ranges between -2 and 2.*/
+  b2=(one48<<8)-(4*a<<24)-b1;
+  /*All of the filter parameters are Q24.*/
+  _f->c[0]=(ogg_int32_t)(b1+((ogg_int64_t)1<<31)>>32);
+  _f->c[1]=(ogg_int32_t)(b2+((ogg_int64_t)1<<31)>>32);
+  _f->g=(ogg_int32_t)(a+128>>8);
+}
+
+/*Initialize a 2nd order low-pass Bessel filter with the corresponding delay
+   and initial value.
+  _value is Q24.*/
+static void oc_iir_filter_init(oc_iir_filter *_f,int _delay,ogg_int32_t _value){
+  oc_iir_filter_reinit(_f,_delay);
+  _f->y[1]=_f->y[0]=_f->x[1]=_f->x[0]=_value;
+}
+
+static ogg_int64_t oc_iir_filter_update(oc_iir_filter *_f,ogg_int32_t _x){
+  ogg_int64_t c0;
+  ogg_int64_t c1;
+  ogg_int64_t g;
+  ogg_int64_t x0;
+  ogg_int64_t x1;
+  ogg_int64_t y0;
+  ogg_int64_t y1;
+  ogg_int64_t ya;
+  c0=_f->c[0];
+  c1=_f->c[1];
+  g=_f->g;
+  x0=_f->x[0];
+  x1=_f->x[1];
+  y0=_f->y[0];
+  y1=_f->y[1];
+  ya=(_x+x0*2+x1)*g+y0*c0+y1*c1+(1<<23)>>24;
+  _f->x[1]=(ogg_int32_t)x0;
+  _f->x[0]=_x;
+  _f->y[1]=(ogg_int32_t)y0;
+  _f->y[0]=(ogg_int32_t)ya;
+  return ya;
+}
+
+
+
+/*Search for the quantizer that matches the target most closely.
+  We don't assume a linear ordering, but when there are ties we pick the
+   quantizer closest to the old one.*/
+static int oc_enc_find_qi_for_target(oc_enc_ctx *_enc,int _qti,int _qi_old,
+ int _qi_min,ogg_int64_t _log_qtarget){
+  ogg_int64_t best_qdiff;
+  int         best_qi;
+  int         qi;
+  best_qi=_qi_min;
+  best_qdiff=_enc->log_qavg[_qti][best_qi]-_log_qtarget;
+  best_qdiff=best_qdiff+OC_SIGNMASK(best_qdiff)^OC_SIGNMASK(best_qdiff);
+  for(qi=_qi_min+1;qi<64;qi++){
+    ogg_int64_t qdiff;
+    qdiff=_enc->log_qavg[_qti][qi]-_log_qtarget;
+    qdiff=qdiff+OC_SIGNMASK(qdiff)^OC_SIGNMASK(qdiff);
+    if(qdiff<best_qdiff||
+     qdiff==best_qdiff&&abs(qi-_qi_old)<abs(best_qi-_qi_old)){
+      best_qi=qi;
+      best_qdiff=qdiff;
+    }
+  }
+  return best_qi;
+}
+
+void oc_enc_calc_lambda(oc_enc_ctx *_enc,int _qti){
+  ogg_int64_t lq;
+  int         qi;
+  int         qi1;
+  int         nqis;
+  /*For now, lambda is fixed depending on the qi value and frame type:
+      lambda=qscale*(qavg[qti][qi]**2),
+     where qscale=0.2125.
+    This was derived by exhaustively searching for the optimal quantizer for
+     the AC coefficients in each block from a number of test sequences for a
+     number of fixed lambda values and fitting the peaks of the resulting
+     histograms (on the log(qavg) scale).
+    The same model applies to both inter and intra frames.
+    A more adaptive scheme might perform better.*/
+  qi=_enc->state.qis[0];
+  /*If rate control is active, use the lambda for the _target_ quantizer.
+    This allows us to scale to rates slightly lower than we'd normally be able
+     to reach, and give the rate control a semblance of "fractional qi"
+     precision.
+    TODO: Add API for changing QI, and allow extra precision.*/
+  if(_enc->state.info.target_bitrate>0)lq=_enc->rc.log_qtarget;
+  else lq=_enc->log_qavg[_qti][qi];
+  /*The resulting lambda value is less than 0x500000.*/
+  _enc->lambda=(int)oc_bexp64(2*lq-0x4780BD468D6B62BLL);
+  /*Select additional quantizers.
+    The R-D optimal block AC quantizer statistics suggest that the distribution
+     is roughly Gaussian-like with a slight positive skew.
+    K-means clustering on log_qavg to select 3 quantizers produces cluster
+     centers of {log_qavg-0.6,log_qavg,log_qavg+0.7}.
+    Experiments confirm these are relatively good choices.
+
+    Although we do greedy R-D optimization of the qii flags to avoid switching
+     too frequently, this becomes ineffective at low rates, either because we
+     do a poor job of predicting the actual R-D cost, or the greedy
+     optimization is not sufficient.
+    Therefore adaptive quantization is disabled above an (experimentally
+     suggested) threshold of log_qavg=7.00 (e.g., below INTRA qi=12 or
+     INTER qi=20 with current matrices).
+    This may need to be revised if the R-D cost estimation or qii flag
+     optimization strategies change.*/
+  nqis=1;
+  if(lq<(OC_Q57(56)>>3)&&!_enc->vp3_compatible){
+    qi1=oc_enc_find_qi_for_target(_enc,_qti,OC_MAXI(qi-1,0),0,
+     lq+(OC_Q57(7)+5)/10);
+    if(qi1!=qi)_enc->state.qis[nqis++]=qi1;
+    qi1=oc_enc_find_qi_for_target(_enc,_qti,OC_MINI(qi+1,63),0,
+     lq-(OC_Q57(6)+5)/10);
+    if(qi1!=qi&&qi1!=_enc->state.qis[nqis-1])_enc->state.qis[nqis++]=qi1;
+  }
+  _enc->state.nqis=nqis;
+}
+
+/*Binary exponential of _log_scale with 24-bit fractional precision and
+   saturation.
+  _log_scale: A binary logarithm in Q24 format.
+  Return: The binary exponential in Q24 format, saturated to 2**47-1 if
+   _log_scale was too large.*/
+static ogg_int64_t oc_bexp_q24(ogg_int32_t _log_scale){
+  if(_log_scale<(ogg_int32_t)23<<24){
+    ogg_int64_t ret;
+    ret=oc_bexp64(((ogg_int64_t)_log_scale<<33)+OC_Q57(24));
+    return ret<0x7FFFFFFFFFFFLL?ret:0x7FFFFFFFFFFFLL;
+  }
+  return 0x7FFFFFFFFFFFLL;
+}
+
+/*Convenience function converts Q57 value to a clamped 32-bit Q24 value
+  _in: input in Q57 format.
+  Return: same number in Q24 */
+static ogg_int32_t oc_q57_to_q24(ogg_int64_t _in){
+  ogg_int64_t ret;
+  ret=_in+((ogg_int64_t)1<<32)>>33;
+  /*0x80000000 is automatically converted to unsigned on 32-bit systems.
+    -0x7FFFFFFF-1 is needed to avoid "promoting" the whole expression to
+    unsigned.*/
+  return (ogg_int32_t)OC_CLAMPI(-0x7FFFFFFF-1,ret,0x7FFFFFFF);
+}
+
+/*Binary exponential of _log_scale with 24-bit fractional precision and
+   saturation.
+  _log_scale: A binary logarithm in Q57 format.
+  Return: The binary exponential in Q24 format, saturated to 2**31-1 if
+   _log_scale was too large.*/
+static ogg_int32_t oc_bexp64_q24(ogg_int64_t _log_scale){
+  if(_log_scale<OC_Q57(8)){
+    ogg_int64_t ret;
+    ret=oc_bexp64(_log_scale+OC_Q57(24));
+    return ret<0x7FFFFFFF?(ogg_int32_t)ret:0x7FFFFFFF;
+  }
+  return 0x7FFFFFFF;
+}
+
+
+static void oc_enc_rc_reset(oc_enc_ctx *_enc){
+  ogg_int64_t npixels;
+  ogg_int64_t ibpp;
+  int         inter_delay;
+  /*TODO: These parameters should be exposed in a th_encode_ctl() API.*/
+  _enc->rc.bits_per_frame=(_enc->state.info.target_bitrate*
+   (ogg_int64_t)_enc->state.info.fps_denominator)/
+   _enc->state.info.fps_numerator;
+  /*Insane framerates or frame sizes mean insane bitrates.
+    Let's not get carried away.*/
+  if(_enc->rc.bits_per_frame>0x400000000000LL){
+    _enc->rc.bits_per_frame=(ogg_int64_t)0x400000000000LL;
+  }
+  else if(_enc->rc.bits_per_frame<32)_enc->rc.bits_per_frame=32;
+  _enc->rc.buf_delay=OC_MAXI(_enc->rc.buf_delay,12);
+  _enc->rc.max=_enc->rc.bits_per_frame*_enc->rc.buf_delay;
+  /*Start with a buffer fullness of 50% plus 25% of the amount we plan to spend
+     on a single keyframe interval.
+    We can require fully half the bits in an interval for a keyframe, so this
+     initial level gives us maximum flexibility for over/under-shooting in
+     subsequent frames.*/
+  _enc->rc.target=(_enc->rc.max+1>>1)+(_enc->rc.bits_per_frame+2>>2)*
+   OC_MINI(_enc->keyframe_frequency_force,_enc->rc.buf_delay);
+  _enc->rc.fullness=_enc->rc.target;
+  /*Pick exponents and initial scales for quantizer selection.*/
+  npixels=_enc->state.info.frame_width*
+   (ogg_int64_t)_enc->state.info.frame_height;
+  _enc->rc.log_npixels=oc_blog64(npixels);
+  ibpp=npixels/_enc->rc.bits_per_frame;
+  if(ibpp<1){
+    _enc->rc.exp[0]=59;
+    _enc->rc.log_scale[0]=oc_blog64(1997)-OC_Q57(8);
+  }
+  else if(ibpp<2){
+    _enc->rc.exp[0]=55;
+    _enc->rc.log_scale[0]=oc_blog64(1604)-OC_Q57(8);
+  }
+  else{
+    _enc->rc.exp[0]=48;
+    _enc->rc.log_scale[0]=oc_blog64(834)-OC_Q57(8);
+  }
+  if(ibpp<4){
+    _enc->rc.exp[1]=100;
+    _enc->rc.log_scale[1]=oc_blog64(2249)-OC_Q57(8);
+  }
+  else if(ibpp<8){
+    _enc->rc.exp[1]=95;
+    _enc->rc.log_scale[1]=oc_blog64(1751)-OC_Q57(8);
+  }
+  else{
+    _enc->rc.exp[1]=73;
+    _enc->rc.log_scale[1]=oc_blog64(1260)-OC_Q57(8);
+  }
+  _enc->rc.prev_drop_count=0;
+  _enc->rc.log_drop_scale=OC_Q57(0);
+  /*Set up second order followers, initialized according to corresponding
+     time constants.*/
+  oc_iir_filter_init(&_enc->rc.scalefilter[0],4,
+   oc_q57_to_q24(_enc->rc.log_scale[0]));
+  inter_delay=(_enc->rc.twopass?
+   OC_MAXI(_enc->keyframe_frequency_force,12):_enc->rc.buf_delay)>>1;
+  _enc->rc.inter_count=0;
+  /*We clamp the actual inter_delay to a minimum of 10 to work within the range
+     of values where later incrementing the delay works as designed.
+    10 is not an exact choice, but rather a good working trade-off.*/
+  _enc->rc.inter_delay=10;
+  _enc->rc.inter_delay_target=inter_delay;
+  oc_iir_filter_init(&_enc->rc.scalefilter[1],_enc->rc.inter_delay,
+   oc_q57_to_q24(_enc->rc.log_scale[1]));
+  oc_iir_filter_init(&_enc->rc.vfrfilter,4,
+   oc_bexp64_q24(_enc->rc.log_drop_scale));
+}
+
+void oc_rc_state_init(oc_rc_state *_rc,oc_enc_ctx *_enc){
+  _rc->twopass=0;
+  _rc->twopass_buffer_bytes=0;
+  _rc->twopass_force_kf=0;
+  _rc->frame_metrics=NULL;
+  _rc->rate_bias=0;
+  if(_enc->state.info.target_bitrate>0){
+    /*The buffer size is set equal to the keyframe interval, clamped to the
+       range [12,256] frames.
+      The 12 frame minimum gives us some chance to distribute bit estimation
+       errors.
+      The 256 frame maximum means we'll require 8-10 seconds of pre-buffering
+       at 24-30 fps, which is not unreasonable.*/
+    _rc->buf_delay=_enc->keyframe_frequency_force>256?
+     256:_enc->keyframe_frequency_force;
+    /*By default, enforce all buffer constraints.*/
+    _rc->drop_frames=1;
+    _rc->cap_overflow=1;
+    _rc->cap_underflow=0;
+    oc_enc_rc_reset(_enc);
+  }
+}
+
+void oc_rc_state_clear(oc_rc_state *_rc){
+  _ogg_free(_rc->frame_metrics);
+}
+
+void oc_enc_rc_resize(oc_enc_ctx *_enc){
+  /*If encoding has not yet begun, reset the buffer state.*/
+  if(_enc->state.curframe_num<0)oc_enc_rc_reset(_enc);
+  else{
+    int idt;
+    /*Otherwise, update the bounds on the buffer, but not the current
+       fullness.*/
+    _enc->rc.bits_per_frame=(_enc->state.info.target_bitrate*
+     (ogg_int64_t)_enc->state.info.fps_denominator)/
+     _enc->state.info.fps_numerator;
+    /*Insane framerates or frame sizes mean insane bitrates.
+      Let's not get carried away.*/
+    if(_enc->rc.bits_per_frame>0x400000000000LL){
+      _enc->rc.bits_per_frame=(ogg_int64_t)0x400000000000LL;
+    }
+    else if(_enc->rc.bits_per_frame<32)_enc->rc.bits_per_frame=32;
+    _enc->rc.buf_delay=OC_MAXI(_enc->rc.buf_delay,12);
+    _enc->rc.max=_enc->rc.bits_per_frame*_enc->rc.buf_delay;
+    _enc->rc.target=(_enc->rc.max+1>>1)+(_enc->rc.bits_per_frame+2>>2)*
+     OC_MINI(_enc->keyframe_frequency_force,_enc->rc.buf_delay);
+    /*Update the INTER-frame scale filter delay.
+      We jump to it immediately if we've already seen enough frames; otherwise
+       it is simply set as the new target.*/
+    _enc->rc.inter_delay_target=idt=OC_MAXI(_enc->rc.buf_delay>>1,10);
+    if(idt<OC_MINI(_enc->rc.inter_delay,_enc->rc.inter_count)){
+      oc_iir_filter_init(&_enc->rc.scalefilter[1],idt,
+       _enc->rc.scalefilter[1].y[0]);
+      _enc->rc.inter_delay=idt;
+    }
+  }
+  /*If we're in pass-2 mode, make sure the frame metrics array is big enough
+     to hold frame statistics for the full buffer.*/
+  if(_enc->rc.twopass==2){
+    int cfm;
+    int buf_delay;
+    int reset_window;
+    buf_delay=_enc->rc.buf_delay;
+    reset_window=_enc->rc.frame_metrics==NULL&&(_enc->rc.frames_total[0]==0||
+     buf_delay<_enc->rc.frames_total[0]+_enc->rc.frames_total[1]
+     +_enc->rc.frames_total[2]);
+    cfm=_enc->rc.cframe_metrics;
+    /*Only try to resize the frame metrics buffer if a) it's too small and
+       b) we were using a finite buffer, or are about to start.*/
+    if(cfm<buf_delay&&(_enc->rc.frame_metrics!=NULL||reset_window)){
+      oc_frame_metrics *fm;
+      int               nfm;
+      int               fmh;
+      fm=(oc_frame_metrics *)_ogg_realloc(_enc->rc.frame_metrics,
+       buf_delay*sizeof(*_enc->rc.frame_metrics));
+      if(fm==NULL){
+        /*We failed to allocate a finite buffer.*/
+        /*If we don't have a valid 2-pass header yet, just return; we'll reset
+           the buffer size when we read the header.*/
+        if(_enc->rc.frames_total[0]==0)return;
+        /*Otherwise revert to the largest finite buffer previously set, or to
+           whole-file buffering if we were still using that.*/
+        _enc->rc.buf_delay=_enc->rc.frame_metrics!=NULL?
+         cfm:_enc->rc.frames_total[0]+_enc->rc.frames_total[1]
+         +_enc->rc.frames_total[2];
+        oc_enc_rc_resize(_enc);
+        return;
+      }
+      _enc->rc.frame_metrics=fm;
+      _enc->rc.cframe_metrics=buf_delay;
+      /*Re-organize the circular buffer.*/
+      fmh=_enc->rc.frame_metrics_head;
+      nfm=_enc->rc.nframe_metrics;
+      if(fmh+nfm>cfm){
+        int shift;
+        shift=OC_MINI(fmh+nfm-cfm,buf_delay-cfm);
+        memcpy(fm+cfm,fm,OC_MINI(fmh+nfm-cfm,buf_delay-cfm)*sizeof(*fm));
+        if(fmh+nfm>buf_delay)memmove(fm,fm+shift,fmh+nfm-buf_delay);
+      }
+    }
+    /*We were using whole-file buffering; now we're not.*/
+    if(reset_window){
+      _enc->rc.nframes[0]=_enc->rc.nframes[1]=_enc->rc.nframes[2]=0;
+      _enc->rc.scale_sum[0]=_enc->rc.scale_sum[1]=0;
+      _enc->rc.scale_window_end=_enc->rc.scale_window0=
+       _enc->state.curframe_num+_enc->prev_dup_count+1;
+      if(_enc->rc.twopass_buffer_bytes){
+        int qti;
+        /*We already read the metrics for the first frame in the window.*/
+        *(_enc->rc.frame_metrics)=*&_enc->rc.cur_metrics;
+        _enc->rc.nframe_metrics++;
+        qti=_enc->rc.cur_metrics.frame_type;
+        _enc->rc.nframes[qti]++;
+        _enc->rc.nframes[2]+=_enc->rc.cur_metrics.dup_count;
+        _enc->rc.scale_sum[qti]+=oc_bexp_q24(_enc->rc.cur_metrics.log_scale);
+        _enc->rc.scale_window_end+=_enc->rc.cur_metrics.dup_count+1;
+        if(_enc->rc.scale_window_end-_enc->rc.scale_window0<buf_delay){
+          /*We need more frame data.*/
+          _enc->rc.twopass_buffer_bytes=0;
+        }
+      }
+    }
+    /*Otherwise, we could shrink the size of the current window, if necessary,
+       but leaving it like it is lets us adapt to the new buffer size more
+       gracefully.*/
+  }
+}
+
+/*Scale the number of frames by the number of expected drops/duplicates.*/
+static int oc_rc_scale_drop(oc_rc_state *_rc,int _nframes){
+  if(_rc->prev_drop_count>0||_rc->log_drop_scale>OC_Q57(0)){
+    ogg_int64_t dup_scale;
+    dup_scale=oc_bexp64((_rc->log_drop_scale
+     +oc_blog64(_rc->prev_drop_count+1)>>1)+OC_Q57(8));
+    if(dup_scale<_nframes<<8){
+      int dup_scalei;
+      dup_scalei=(int)dup_scale;
+      if(dup_scalei>0)_nframes=((_nframes<<8)+dup_scalei-1)/dup_scalei;
+    }
+    else _nframes=!!_nframes;
+  }
+  return _nframes;
+}
+
+int oc_enc_select_qi(oc_enc_ctx *_enc,int _qti,int _clamp){
+  ogg_int64_t  rate_total;
+  ogg_int64_t  rate_bias;
+  int          nframes[2];
+  int          buf_delay;
+  int          buf_pad;
+  ogg_int64_t  log_qtarget;
+  ogg_int64_t  log_scale0;
+  ogg_int64_t  log_cur_scale;
+  ogg_int64_t  log_qexp;
+  int          exp0;
+  int          old_qi;
+  int          qi;
+  /*Figure out how to re-distribute bits so that we hit our fullness target
+     before the last keyframe in our current buffer window (after the current
+     frame), or the end of the buffer window, whichever comes first.*/
+  log_cur_scale=(ogg_int64_t)_enc->rc.scalefilter[_qti].y[0]<<33;
+  buf_pad=0;
+  switch(_enc->rc.twopass){
+    default:{
+      ogg_uint32_t next_key_frame;
+      /*Single pass mode: assume only forced keyframes and attempt to estimate
+         the drop count for VFR content.*/
+      next_key_frame=_qti?_enc->keyframe_frequency_force
+       -(_enc->state.curframe_num-_enc->state.keyframe_num):0;
+      nframes[0]=(_enc->rc.buf_delay-OC_MINI(next_key_frame,_enc->rc.buf_delay)
+       +_enc->keyframe_frequency_force-1)/_enc->keyframe_frequency_force;
+      if(nframes[0]+_qti>1){
+        nframes[0]--;
+        buf_delay=next_key_frame+nframes[0]*_enc->keyframe_frequency_force;
+      }
+      else buf_delay=_enc->rc.buf_delay;
+      nframes[1]=buf_delay-nframes[0];
+      /*Downgrade the delta frame rate to correspond to the recent drop count
+         history.*/
+      nframes[1]=oc_rc_scale_drop(&_enc->rc,nframes[1]);
+    }break;
+    case 1:{
+      /*Pass 1 mode: use a fixed qi value.*/
+      qi=_enc->state.qis[0];
+      _enc->rc.log_qtarget=_enc->log_qavg[_qti][qi];
+      return qi;
+    }break;
+    case 2:{
+      ogg_int64_t scale_sum[2];
+      int         qti;
+      /*Pass 2 mode: we know exactly how much of each frame type there is in
+         the current buffer window, and have estimates for the scales.*/
+      nframes[0]=_enc->rc.nframes[0];
+      nframes[1]=_enc->rc.nframes[1];
+      scale_sum[0]=_enc->rc.scale_sum[0];
+      scale_sum[1]=_enc->rc.scale_sum[1];
+      /*The window size can be slightly larger than the buffer window for VFR
+         content; clamp it down, if appropriate (the excess will all be dup
+         frames).*/
+      buf_delay=OC_MINI(_enc->rc.scale_window_end-_enc->rc.scale_window0,
+       _enc->rc.buf_delay);
+      /*If we're approaching the end of the file, add some slack to keep us
+         from slamming into a rail.
+        Our rate accuracy goes down, but it keeps the result sensible.
+        We position the target where the first forced keyframe beyond the end
+         of the file would be (for consistency with 1-pass mode).*/
+      buf_pad=OC_MINI(_enc->rc.buf_delay,_enc->state.keyframe_num
+       +_enc->keyframe_frequency_force-_enc->rc.scale_window0);
+      if(buf_delay<buf_pad)buf_pad-=buf_delay;
+      else{
+        /*Otherwise, search for the last keyframe in the buffer window and
+           target that.*/
+        buf_pad=0;
+        /*TODO: Currently we only do this when using a finite buffer; we could
+           save the position of the last keyframe in the summary data and do it
+           with a whole-file buffer as well, but it isn't likely to make a
+           difference.*/
+        if(_enc->rc.frame_metrics!=NULL){
+          int fmi;
+          int fm_tail;
+          fm_tail=_enc->rc.frame_metrics_head+_enc->rc.nframe_metrics;
+          if(fm_tail>=_enc->rc.cframe_metrics)fm_tail-=_enc->rc.cframe_metrics;
+          for(fmi=fm_tail;;){
+            oc_frame_metrics *m;
+            fmi--;
+            if(fmi<0)fmi+=_enc->rc.cframe_metrics;
+            /*Stop before we remove the first frame.*/
+            if(fmi==_enc->rc.frame_metrics_head)break;
+            m=_enc->rc.frame_metrics+fmi;
+            /*If we find a keyframe, remove it and everything past it.*/
+            if(m->frame_type==OC_INTRA_FRAME){
+              do{
+                qti=m->frame_type;
+                nframes[qti]--;
+                scale_sum[qti]-=oc_bexp_q24(m->log_scale);
+                buf_delay-=m->dup_count+1;
+                fmi++;
+                if(fmi>=_enc->rc.cframe_metrics)fmi=0;
+                m=_enc->rc.frame_metrics+fmi;
+              }
+              while(fmi!=fm_tail);
+              /*And stop scanning backwards.*/
+              break;
+            }
+          }
+        }
+      }
+      /*If we're not using the same frame type as in pass 1 (because someone
+         changed the keyframe interval), remove that scale estimate.
+        We'll add in a replacement for the correct frame type below.*/
+      qti=_enc->rc.cur_metrics.frame_type;
+      if(qti!=_qti){
+        nframes[qti]--;
+        scale_sum[qti]-=oc_bexp_q24(_enc->rc.cur_metrics.log_scale);
+      }
+      /*Compute log_scale estimates for each frame type from the pass-1 scales
+         we measured in the current window.*/
+      for(qti=0;qti<2;qti++){
+        _enc->rc.log_scale[qti]=nframes[qti]>0?
+         oc_blog64(scale_sum[qti])-oc_blog64(nframes[qti])-OC_Q57(24):
+         -_enc->rc.log_npixels;
+      }
+      /*If we're not using the same frame type as in pass 1, add a scale
+         estimate for the corresponding frame using the current low-pass
+         filter value.
+        This is mostly to ensure we have a valid estimate even when pass 1 had
+         no frames of this type in the buffer window.
+        TODO: We could also plan ahead and figure out how many keyframes we'll
+         be forced to add in the current buffer window.*/
+      qti=_enc->rc.cur_metrics.frame_type;
+      if(qti!=_qti){
+        ogg_int64_t scale;
+        scale=_enc->rc.log_scale[_qti]<OC_Q57(23)?
+         oc_bexp64(_enc->rc.log_scale[_qti]+OC_Q57(24)):0x7FFFFFFFFFFFLL;
+        scale*=nframes[_qti];
+        nframes[_qti]++;
+        scale+=oc_bexp_q24(log_cur_scale>>33);
+        _enc->rc.log_scale[_qti]=oc_blog64(scale)
+         -oc_blog64(nframes[qti])-OC_Q57(24);
+      }
+      else log_cur_scale=(ogg_int64_t)_enc->rc.cur_metrics.log_scale<<33;
+      /*Add the padding from above.
+        This basically reverts to 1-pass estimations in the last keyframe
+         interval.*/
+      if(buf_pad>0){
+        ogg_int64_t scale;
+        int         nextra_frames;
+        /*Extend the buffer.*/
+        buf_delay+=buf_pad;
+        /*Add virtual delta frames according to the estimated drop count.*/
+        nextra_frames=oc_rc_scale_drop(&_enc->rc,buf_pad);
+        /*And blend in the low-pass filtered scale according to how many frames
+           we added.*/
+        scale=
+         oc_bexp64(_enc->rc.log_scale[1]+OC_Q57(24))*(ogg_int64_t)nframes[1]
+         +oc_bexp_q24(_enc->rc.scalefilter[1].y[0])*(ogg_int64_t)nextra_frames;
+        nframes[1]+=nextra_frames;
+        _enc->rc.log_scale[1]=oc_blog64(scale)-oc_blog64(nframes[1])-OC_Q57(24);
+      }
+    }break;
+  }
+  /*If we've been missing our target, add a penalty term.*/
+  rate_bias=(_enc->rc.rate_bias/(_enc->state.curframe_num+1000))*
+   (buf_delay-buf_pad);
+  /*rate_total is the total bits available over the next buf_delay frames.*/
+  rate_total=_enc->rc.fullness-_enc->rc.target+rate_bias
+   +buf_delay*_enc->rc.bits_per_frame;
+  log_scale0=_enc->rc.log_scale[_qti]+_enc->rc.log_npixels;
+  /*If there aren't enough bits to achieve our desired fullness level, use the
+     minimum quality permitted.*/
+  if(rate_total<=buf_delay)log_qtarget=OC_QUANT_MAX_LOG;
+  else{
+    static const ogg_int64_t LOG_KEY_RATIO=0x0137222BB70747BALL;
+    ogg_int64_t log_scale1;
+    ogg_int64_t rlo;
+    ogg_int64_t rhi;
+    log_scale1=_enc->rc.log_scale[1-_qti]+_enc->rc.log_npixels;
+    rlo=0;
+    rhi=(rate_total+nframes[_qti]-1)/nframes[_qti];
+    while(rlo<rhi){
+      ogg_int64_t curr;
+      ogg_int64_t rdiff;
+      ogg_int64_t log_rpow;
+      ogg_int64_t rscale;
+      curr=rlo+rhi>>1;
+      log_rpow=oc_blog64(curr)-log_scale0;
+      log_rpow=(log_rpow+(_enc->rc.exp[_qti]>>1))/_enc->rc.exp[_qti];
+      if(_qti)log_rpow+=LOG_KEY_RATIO>>6;
+      else log_rpow-=LOG_KEY_RATIO>>6;
+      log_rpow*=_enc->rc.exp[1-_qti];
+      rscale=nframes[1-_qti]*oc_bexp64(log_scale1+log_rpow);
+      rdiff=nframes[_qti]*curr+rscale-rate_total;
+      if(rdiff<0)rlo=curr+1;
+      else if(rdiff>0)rhi=curr-1;
+      else break;
+    }
+    log_qtarget=OC_Q57(2)-((oc_blog64(rlo)-log_scale0+(_enc->rc.exp[_qti]>>1))/
+     _enc->rc.exp[_qti]<<6);
+    log_qtarget=OC_MINI(log_qtarget,OC_QUANT_MAX_LOG);
+  }
+  /*The above allocation looks only at the total rate we'll accumulate in the
+     next buf_delay frames.
+    However, we could overflow the buffer on the very next frame, so check for
+     that here, if we're not using a soft target.*/
+  exp0=_enc->rc.exp[_qti];
+  if(_enc->rc.cap_overflow){
+    ogg_int64_t margin;
+    ogg_int64_t soft_limit;
+    ogg_int64_t log_soft_limit;
+    /*Allow 3% of the buffer for prediction error.
+      This should be plenty, and we don't mind if we go a bit over; we only
+       want to keep these bits from being completely wasted.*/
+    margin=_enc->rc.max+31>>5;
+    /*We want to use at least this many bits next frame.*/
+    soft_limit=_enc->rc.fullness+_enc->rc.bits_per_frame-(_enc->rc.max-margin);
+    log_soft_limit=oc_blog64(soft_limit);
+    /*If we're predicting we won't use that many...*/
+    log_qexp=(log_qtarget-OC_Q57(2)>>6)*exp0;
+    if(log_scale0-log_qexp<log_soft_limit){
+      /*Scale the adjustment based on how far into the margin we are.*/
+      log_qexp+=(log_scale0-log_soft_limit-log_qexp>>32)*
+       ((OC_MINI(margin,soft_limit)<<32)/margin);
+      log_qtarget=((log_qexp+(exp0>>1))/exp0<<6)+OC_Q57(2);
+    }
+  }
+  /*If this was not one of the initial frames, limit the change in quality.*/
+  old_qi=_enc->state.qis[0];
+  if(_clamp){
+    ogg_int64_t log_qmin;
+    ogg_int64_t log_qmax;
+    /*Clamp the target quantizer to within [0.8*Q,1.2*Q], where Q is the
+       current quantizer.
+      TODO: With user-specified quant matrices, we need to enlarge these limits
+       if they don't actually let us change qi values.*/
+    log_qmin=_enc->log_qavg[_qti][old_qi]-0x00A4D3C25E68DC58LL;
+    log_qmax=_enc->log_qavg[_qti][old_qi]+0x00A4D3C25E68DC58LL;
+    log_qtarget=OC_CLAMPI(log_qmin,log_qtarget,log_qmax);
+  }
+  /*The above allocation looks only at the total rate we'll accumulate in the
+     next buf_delay frames.
+    However, we could bust the budget on the very next frame, so check for that
+     here, if we're not using a soft target.*/
+  /* Disabled when our minimum qi > 0; if we saturate log_qtarget to
+     to the maximum possible size when we have a minimum qi, the
+     resulting lambda will interact very strangely with SKIP.  The
+     resulting artifacts look like waterfalls. */
+  if(_enc->state.info.quality==0){
+    ogg_int64_t log_hard_limit;
+    /*Compute the maximum number of bits we can use in the next frame.
+      Allow 50% of the rate for a single frame for prediction error.
+      This may not be enough for keyframes or sudden changes in complexity.*/
+    log_hard_limit=oc_blog64(_enc->rc.fullness+(_enc->rc.bits_per_frame>>1));
+    /*If we're predicting we'll use more than this...*/
+    log_qexp=(log_qtarget-OC_Q57(2)>>6)*exp0;
+    if(log_scale0-log_qexp>log_hard_limit){
+      /*Force the target to hit our limit exactly.*/
+      log_qexp=log_scale0-log_hard_limit;
+      log_qtarget=((log_qexp+(exp0>>1))/exp0<<6)+OC_Q57(2);
+      /*If that target is unreasonable, oh well; we'll have to drop.*/
+      log_qtarget=OC_MINI(log_qtarget,OC_QUANT_MAX_LOG);
+    }
+  }
+  /*Compute a final estimate of the number of bits we plan to use.*/
+  log_qexp=(log_qtarget-OC_Q57(2)>>6)*_enc->rc.exp[_qti];
+  _enc->rc.rate_bias+=oc_bexp64(log_cur_scale+_enc->rc.log_npixels-log_qexp);
+  qi=oc_enc_find_qi_for_target(_enc,_qti,old_qi,
+   _enc->state.info.quality,log_qtarget);
+  /*Save the quantizer target for lambda calculations.*/
+  _enc->rc.log_qtarget=log_qtarget;
+  return qi;
+}
+
+int oc_enc_update_rc_state(oc_enc_ctx *_enc,
+ long _bits,int _qti,int _qi,int _trial,int _droppable){
+  ogg_int64_t buf_delta;
+  ogg_int64_t log_scale;
+  int         dropped;
+  dropped=0;
+  /* Drop frames also disabled for now in the case of infinite-buffer
+     two-pass mode */
+  if(!_enc->rc.drop_frames||_enc->rc.twopass&&_enc->rc.frame_metrics==NULL){
+    _droppable=0;
+  }
+  buf_delta=_enc->rc.bits_per_frame*(1+_enc->dup_count);
+  if(_bits<=0){
+    /*We didn't code any blocks in this frame.*/
+    log_scale=OC_Q57(-64);
+    _bits=0;
+  }
+  else{
+    ogg_int64_t log_bits;
+    ogg_int64_t log_qexp;
+    /*Compute the estimated scale factor for this frame type.*/
+    log_bits=oc_blog64(_bits);
+    log_qexp=_enc->rc.log_qtarget-OC_Q57(2);
+    log_qexp=(log_qexp>>6)*(_enc->rc.exp[_qti]);
+    log_scale=OC_MINI(log_bits-_enc->rc.log_npixels+log_qexp,OC_Q57(16));
+  }
+  /*Special two-pass processing.*/
+  switch(_enc->rc.twopass){
+    case 1:{
+      /*Pass 1 mode: save the metrics for this frame.*/
+      _enc->rc.cur_metrics.log_scale=oc_q57_to_q24(log_scale);
+      _enc->rc.cur_metrics.dup_count=_enc->dup_count;
+      _enc->rc.cur_metrics.frame_type=_enc->state.frame_type;
+      _enc->rc.twopass_buffer_bytes=0;
+    }break;
+    case 2:{
+      /*Pass 2 mode:*/
+      if(!_trial){
+        ogg_int64_t next_frame_num;
+        int         qti;
+        /*Move the current metrics back one frame.*/
+        *&_enc->rc.prev_metrics=*&_enc->rc.cur_metrics;
+        next_frame_num=_enc->state.curframe_num+_enc->dup_count+1;
+        /*Back out the last frame's statistics from the sliding window.*/
+        qti=_enc->rc.prev_metrics.frame_type;
+        _enc->rc.frames_left[qti]--;
+        _enc->rc.frames_left[2]-=_enc->rc.prev_metrics.dup_count;
+        _enc->rc.nframes[qti]--;
+        _enc->rc.nframes[2]-=_enc->rc.prev_metrics.dup_count;
+        _enc->rc.scale_sum[qti]-=oc_bexp_q24(_enc->rc.prev_metrics.log_scale);
+        _enc->rc.scale_window0=(int)next_frame_num;
+        /*Free the corresponding entry in the circular buffer.*/
+        if(_enc->rc.frame_metrics!=NULL){
+          _enc->rc.nframe_metrics--;
+          _enc->rc.frame_metrics_head++;
+          if(_enc->rc.frame_metrics_head>=_enc->rc.cframe_metrics){
+            _enc->rc.frame_metrics_head=0;
+          }
+        }
+        /*Mark us ready for the next 2-pass packet.*/
+        _enc->rc.twopass_buffer_bytes=0;
+        /*Update state, so the user doesn't have to keep calling 2pass_in after
+           they've fed in all the data when we're using a finite buffer.*/
+        _enc->prev_dup_count=_enc->dup_count;
+        oc_enc_rc_2pass_in(_enc,NULL,0);
+      }
+    }break;
+  }
+  /*Common to all passes:*/
+  if(_bits>0){
+    if(_trial){
+      oc_iir_filter *f;
+      /*Use the estimated scale factor directly if this was a trial.*/
+      f=_enc->rc.scalefilter+_qti;
+      f->y[1]=f->y[0]=f->x[1]=f->x[0]=oc_q57_to_q24(log_scale);
+      _enc->rc.log_scale[_qti]=log_scale;
+    }
+    else{
+      /*Lengthen the time constant for the INTER filter as we collect more
+         frame statistics, until we reach our target.*/
+      if(_enc->rc.inter_delay<_enc->rc.inter_delay_target&&
+       _enc->rc.inter_count>=_enc->rc.inter_delay&&_qti==OC_INTER_FRAME){
+        oc_iir_filter_reinit(&_enc->rc.scalefilter[1],++_enc->rc.inter_delay);
+      }
+      /*Otherwise update the low-pass scale filter for this frame type,
+         regardless of whether or not we dropped this frame.*/
+      _enc->rc.log_scale[_qti]=oc_iir_filter_update(
+       _enc->rc.scalefilter+_qti,oc_q57_to_q24(log_scale))<<33;
+      /*If this frame busts our budget, it must be dropped.*/
+      if(_droppable&&_enc->rc.fullness+buf_delta<_bits){
+        _enc->rc.prev_drop_count+=1+_enc->dup_count;
+        _bits=0;
+        dropped=1;
+      }
+      else{
+        ogg_uint32_t drop_count;
+        /*Update a low-pass filter to estimate the "real" frame rate taking
+           drops and duplicates into account.
+          This is only done if the frame is coded, as it needs the final
+           count of dropped frames.*/
+        drop_count=_enc->rc.prev_drop_count+1;
+        if(drop_count>0x7F)drop_count=0x7FFFFFFF;
+        else drop_count<<=24;
+        _enc->rc.log_drop_scale=oc_blog64(oc_iir_filter_update(
+         &_enc->rc.vfrfilter,drop_count))-OC_Q57(24);
+        /*Initialize the drop count for this frame to the user-requested dup
+           count.
+          It will be increased if we drop more frames.*/
+        _enc->rc.prev_drop_count=_enc->dup_count;
+      }
+    }
+    /*Increment the INTER frame count, for filter adaptation purposes.*/
+    if(_enc->rc.inter_count<INT_MAX)_enc->rc.inter_count+=_qti;
+  }
+  /*Increase the drop count.*/
+  else _enc->rc.prev_drop_count+=1+_enc->dup_count;
+  /*And update the buffer fullness level.*/
+  if(!_trial){
+    _enc->rc.fullness+=buf_delta-_bits;
+    /*If we're too quick filling the buffer and overflow is capped,
+      that rate is lost forever.*/
+    if(_enc->rc.cap_overflow&&_enc->rc.fullness>_enc->rc.max){
+      _enc->rc.fullness=_enc->rc.max;
+    }
+    /*If we're too quick draining the buffer and underflow is capped,
+      don't try to make up that rate later.*/
+    if(_enc->rc.cap_underflow&&_enc->rc.fullness<0){
+      _enc->rc.fullness=0;
+    }
+    /*Adjust the bias for the real bits we've used.*/
+    _enc->rc.rate_bias-=_bits;
+  }
+  return dropped;
+}
+
+#define OC_RC_2PASS_VERSION   (1)
+#define OC_RC_2PASS_HDR_SZ    (38)
+#define OC_RC_2PASS_PACKET_SZ (8)
+
+static void oc_rc_buffer_val(oc_rc_state *_rc,ogg_int64_t _val,int _bytes){
+  while(_bytes-->0){
+    _rc->twopass_buffer[_rc->twopass_buffer_bytes++]=(unsigned char)(_val&0xFF);
+    _val>>=8;
+  }
+}
+
+int oc_enc_rc_2pass_out(oc_enc_ctx *_enc,unsigned char **_buf){
+  if(_enc->rc.twopass_buffer_bytes==0){
+    if(_enc->rc.twopass==0){
+      int qi;
+      /*Pick first-pass qi for scale calculations.*/
+      qi=oc_enc_select_qi(_enc,0,0);
+      _enc->state.nqis=1;
+      _enc->state.qis[0]=qi;
+      _enc->rc.twopass=1;
+      _enc->rc.frames_total[0]=_enc->rc.frames_total[1]=
+       _enc->rc.frames_total[2]=0;
+      _enc->rc.scale_sum[0]=_enc->rc.scale_sum[1]=0;
+      /*Fill in dummy summary values.*/
+      oc_rc_buffer_val(&_enc->rc,0x5032544F,4);
+      oc_rc_buffer_val(&_enc->rc,OC_RC_2PASS_VERSION,4);
+      oc_rc_buffer_val(&_enc->rc,0,OC_RC_2PASS_HDR_SZ-8);
+    }
+    else{
+      int qti;
+      qti=_enc->rc.cur_metrics.frame_type;
+      _enc->rc.scale_sum[qti]+=oc_bexp_q24(_enc->rc.cur_metrics.log_scale);
+      _enc->rc.frames_total[qti]++;
+      _enc->rc.frames_total[2]+=_enc->rc.cur_metrics.dup_count;
+      oc_rc_buffer_val(&_enc->rc,
+       _enc->rc.cur_metrics.dup_count|_enc->rc.cur_metrics.frame_type<<31,4);
+      oc_rc_buffer_val(&_enc->rc,_enc->rc.cur_metrics.log_scale,4);
+    }
+  }
+  else if(_enc->packet_state==OC_PACKET_DONE&&
+   _enc->rc.twopass_buffer_bytes!=OC_RC_2PASS_HDR_SZ){
+    _enc->rc.twopass_buffer_bytes=0;
+    oc_rc_buffer_val(&_enc->rc,0x5032544F,4);
+    oc_rc_buffer_val(&_enc->rc,OC_RC_2PASS_VERSION,4);
+    oc_rc_buffer_val(&_enc->rc,_enc->rc.frames_total[0],4);
+    oc_rc_buffer_val(&_enc->rc,_enc->rc.frames_total[1],4);
+    oc_rc_buffer_val(&_enc->rc,_enc->rc.frames_total[2],4);
+    oc_rc_buffer_val(&_enc->rc,_enc->rc.exp[0],1);
+    oc_rc_buffer_val(&_enc->rc,_enc->rc.exp[1],1);
+    oc_rc_buffer_val(&_enc->rc,_enc->rc.scale_sum[0],8);
+    oc_rc_buffer_val(&_enc->rc,_enc->rc.scale_sum[1],8);
+  }
+  else{
+    /*The data for this frame has already been retrieved.*/
+    *_buf=NULL;
+    return 0;
+  }
+  *_buf=_enc->rc.twopass_buffer;
+  return _enc->rc.twopass_buffer_bytes;
+}
+
+static size_t oc_rc_buffer_fill(oc_rc_state *_rc,
+ unsigned char *_buf,size_t _bytes,size_t _consumed,size_t _goal){
+  while(_rc->twopass_buffer_fill<_goal&&_consumed<_bytes){
+    _rc->twopass_buffer[_rc->twopass_buffer_fill++]=_buf[_consumed++];
+  }
+  return _consumed;
+}
+
+static ogg_int64_t oc_rc_unbuffer_val(oc_rc_state *_rc,int _bytes){
+  ogg_int64_t ret;
+  int         shift;
+  ret=0;
+  shift=0;
+  while(_bytes-->0){
+    ret|=((ogg_int64_t)_rc->twopass_buffer[_rc->twopass_buffer_bytes++])<<shift;
+    shift+=8;
+  }
+  return ret;
+}
+
+int oc_enc_rc_2pass_in(oc_enc_ctx *_enc,unsigned char *_buf,size_t _bytes){
+  size_t consumed;
+  consumed=0;
+  /*Enable pass 2 mode if this is the first call.*/
+  if(_enc->rc.twopass==0){
+    _enc->rc.twopass=2;
+    _enc->rc.twopass_buffer_fill=0;
+    _enc->rc.frames_total[0]=0;
+    _enc->rc.nframe_metrics=0;
+    _enc->rc.cframe_metrics=0;
+    _enc->rc.frame_metrics_head=0;
+    _enc->rc.scale_window0=0;
+    _enc->rc.scale_window_end=0;
+  }
+  /*If we haven't got a valid summary header yet, try to parse one.*/
+  if(_enc->rc.frames_total[0]==0){
+    if(!_buf){
+      int frames_needed;
+      /*If we're using a whole-file buffer, we just need the first frame.
+        Otherwise, we may need as many as one per buffer slot.*/
+      frames_needed=_enc->rc.frame_metrics==NULL?1:_enc->rc.buf_delay;
+      return OC_RC_2PASS_HDR_SZ+frames_needed*OC_RC_2PASS_PACKET_SZ
+       -_enc->rc.twopass_buffer_fill;
+    }
+    consumed=oc_rc_buffer_fill(&_enc->rc,
+     _buf,_bytes,consumed,OC_RC_2PASS_HDR_SZ);
+    if(_enc->rc.twopass_buffer_fill>=OC_RC_2PASS_HDR_SZ){
+      ogg_int64_t scale_sum[2];
+      int         exp[2];
+      int         buf_delay;
+      /*Read the summary header data.*/
+      /*Check the magic value and version number.*/
+      if(oc_rc_unbuffer_val(&_enc->rc,4)!=0x5032544F||
+       oc_rc_unbuffer_val(&_enc->rc,4)!=OC_RC_2PASS_VERSION){
+        _enc->rc.twopass_buffer_bytes=0;
+        return TH_ENOTFORMAT;
+      }
+      _enc->rc.frames_total[0]=(ogg_uint32_t)oc_rc_unbuffer_val(&_enc->rc,4);
+      _enc->rc.frames_total[1]=(ogg_uint32_t)oc_rc_unbuffer_val(&_enc->rc,4);
+      _enc->rc.frames_total[2]=(ogg_uint32_t)oc_rc_unbuffer_val(&_enc->rc,4);
+      exp[0]=(int)oc_rc_unbuffer_val(&_enc->rc,1);
+      exp[1]=(int)oc_rc_unbuffer_val(&_enc->rc,1);
+      scale_sum[0]=oc_rc_unbuffer_val(&_enc->rc,8);
+      scale_sum[1]=oc_rc_unbuffer_val(&_enc->rc,8);
+      /*Make sure the file claims to have at least one frame.
+        Otherwise we probably got the placeholder data from an aborted pass 1.
+        Also make sure the total frame count doesn't overflow an integer.*/
+      buf_delay=_enc->rc.frames_total[0]+_enc->rc.frames_total[1]
+       +_enc->rc.frames_total[2];
+      if(_enc->rc.frames_total[0]==0||buf_delay<0||
+       (ogg_uint32_t)buf_delay<_enc->rc.frames_total[0]||
+       (ogg_uint32_t)buf_delay<_enc->rc.frames_total[1]){
+        _enc->rc.frames_total[0]=0;
+        _enc->rc.twopass_buffer_bytes=0;
+        return TH_EBADHEADER;
+      }
+      /*Got a valid header; set up pass 2.*/
+      _enc->rc.frames_left[0]=_enc->rc.frames_total[0];
+      _enc->rc.frames_left[1]=_enc->rc.frames_total[1];
+      _enc->rc.frames_left[2]=_enc->rc.frames_total[2];
+      /*If the user hasn't specified a buffer size, use the whole file.*/
+      if(_enc->rc.frame_metrics==NULL){
+        _enc->rc.buf_delay=buf_delay;
+        _enc->rc.nframes[0]=_enc->rc.frames_total[0];
+        _enc->rc.nframes[1]=_enc->rc.frames_total[1];
+        _enc->rc.nframes[2]=_enc->rc.frames_total[2];
+        _enc->rc.scale_sum[0]=scale_sum[0];
+        _enc->rc.scale_sum[1]=scale_sum[1];
+        _enc->rc.scale_window_end=buf_delay;
+        oc_enc_rc_reset(_enc);
+      }
+      _enc->rc.exp[0]=exp[0];
+      _enc->rc.exp[1]=exp[1];
+      /*Clear the header data from the buffer to make room for packet data.*/
+      _enc->rc.twopass_buffer_fill=0;
+      _enc->rc.twopass_buffer_bytes=0;
+    }
+  }
+  if(_enc->rc.frames_total[0]!=0){
+    ogg_int64_t curframe_num;
+    int         nframes_total;
+    curframe_num=_enc->state.curframe_num;
+    if(curframe_num>=0){
+      /*We just encoded a frame; make sure things matched.*/
+      if(_enc->rc.prev_metrics.dup_count!=_enc->prev_dup_count){
+        _enc->rc.twopass_buffer_bytes=0;
+        return TH_EINVAL;
+      }
+    }
+    curframe_num+=_enc->prev_dup_count+1;
+    nframes_total=_enc->rc.frames_total[0]+_enc->rc.frames_total[1]
+     +_enc->rc.frames_total[2];
+    if(curframe_num>=nframes_total){
+      /*We don't want any more data after the last frame, and we don't want to
+         allow any more frames to be encoded.*/
+      _enc->rc.twopass_buffer_bytes=0;
+    }
+    else if(_enc->rc.twopass_buffer_bytes==0){
+      if(_enc->rc.frame_metrics==NULL){
+        /*We're using a whole-file buffer:*/
+        if(!_buf)return OC_RC_2PASS_PACKET_SZ-_enc->rc.twopass_buffer_fill;
+        consumed=oc_rc_buffer_fill(&_enc->rc,
+         _buf,_bytes,consumed,OC_RC_2PASS_PACKET_SZ);
+        if(_enc->rc.twopass_buffer_fill>=OC_RC_2PASS_PACKET_SZ){
+          ogg_uint32_t dup_count;
+          ogg_int32_t  log_scale;
+          int          qti;
+          int          arg;
+          /*Read the metrics for the next frame.*/
+          dup_count=oc_rc_unbuffer_val(&_enc->rc,4);
+          log_scale=oc_rc_unbuffer_val(&_enc->rc,4);
+          _enc->rc.cur_metrics.log_scale=log_scale;
+          qti=(dup_count&0x80000000)>>31;
+          _enc->rc.cur_metrics.dup_count=dup_count&0x7FFFFFFF;
+          _enc->rc.cur_metrics.frame_type=qti;
+          _enc->rc.twopass_force_kf=qti==OC_INTRA_FRAME;
+          /*"Helpfully" set the dup count back to what it was in pass 1.*/
+          arg=_enc->rc.cur_metrics.dup_count;
+          th_encode_ctl(_enc,TH_ENCCTL_SET_DUP_COUNT,&arg,sizeof(arg));
+          /*Clear the buffer for the next frame.*/
+          _enc->rc.twopass_buffer_fill=0;
+        }
+      }
+      else{
+        int frames_needed;
+        /*We're using a finite buffer:*/
+        frames_needed=OC_CLAMPI(0,_enc->rc.buf_delay
+         -(_enc->rc.scale_window_end-_enc->rc.scale_window0),
+         _enc->rc.frames_left[0]+_enc->rc.frames_left[1]
+         -_enc->rc.nframes[0]-_enc->rc.nframes[1]);
+        while(frames_needed>0){
+          if(!_buf){
+            return OC_RC_2PASS_PACKET_SZ*frames_needed
+           -_enc->rc.twopass_buffer_fill;
+          }
+          consumed=oc_rc_buffer_fill(&_enc->rc,
+           _buf,_bytes,consumed,OC_RC_2PASS_PACKET_SZ);
+          if(_enc->rc.twopass_buffer_fill>=OC_RC_2PASS_PACKET_SZ){
+            oc_frame_metrics *m;
+            int               fmi;
+            ogg_uint32_t      dup_count;
+            ogg_int32_t       log_scale;
+            int               qti;
+            /*Read the metrics for the next frame.*/
+            dup_count=oc_rc_unbuffer_val(&_enc->rc,4);
+            log_scale=oc_rc_unbuffer_val(&_enc->rc,4);
+            /*Add the to the circular buffer.*/
+            fmi=_enc->rc.frame_metrics_head+_enc->rc.nframe_metrics++;
+            if(fmi>=_enc->rc.cframe_metrics)fmi-=_enc->rc.cframe_metrics;
+            m=_enc->rc.frame_metrics+fmi;
+            m->log_scale=log_scale;
+            qti=(dup_count&0x80000000)>>31;
+            m->dup_count=dup_count&0x7FFFFFFF;
+            m->frame_type=qti;
+            /*And accumulate the statistics over the window.*/
+            _enc->rc.nframes[qti]++;
+            _enc->rc.nframes[2]+=m->dup_count;
+            _enc->rc.scale_sum[qti]+=oc_bexp_q24(m->log_scale);
+            _enc->rc.scale_window_end+=m->dup_count+1;
+            /*Compute an upper bound on the number of remaining packets needed
+               for the current window.*/
+            frames_needed=OC_CLAMPI(0,_enc->rc.buf_delay
+             -(_enc->rc.scale_window_end-_enc->rc.scale_window0),
+             _enc->rc.frames_left[0]+_enc->rc.frames_left[1]
+             -_enc->rc.nframes[0]-_enc->rc.nframes[1]);
+            /*Clear the buffer for the next frame.*/
+            _enc->rc.twopass_buffer_fill=0;
+            _enc->rc.twopass_buffer_bytes=0;
+          }
+          /*Go back for more data.*/
+          else break;
+        }
+        /*If we've got all the frames we need, fill in the current metrics.
+          We're ready to go.*/
+        if(frames_needed<=0){
+          int arg;
+          *&_enc->rc.cur_metrics=
+           *(_enc->rc.frame_metrics+_enc->rc.frame_metrics_head);
+          _enc->rc.twopass_force_kf=
+           _enc->rc.cur_metrics.frame_type==OC_INTRA_FRAME;
+          /*"Helpfully" set the dup count back to what it was in pass 1.*/
+          arg=_enc->rc.cur_metrics.dup_count;
+          th_encode_ctl(_enc,TH_ENCCTL_SET_DUP_COUNT,&arg,sizeof(arg));
+          /*Mark us ready for the next frame.*/
+          _enc->rc.twopass_buffer_bytes=1;
+        }
+      }
+    }
+  }
+  return (int)consumed;
+}
diff --git a/lib/state.c b/lib/state.c
new file mode 100644 (file)
index 0000000..42ed33a
--- /dev/null
@@ -0,0 +1,1227 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: state.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <string.h>
+#include "internal.h"
+#if defined(OC_X86_ASM)
+#if defined(_MSC_VER)
+# include "x86_vc/x86int.h"
+#else
+# include "x86/x86int.h"
+#endif
+#endif
+#if defined(OC_DUMP_IMAGES)
+# include <stdio.h>
+# include "png.h"
+#endif
+
+/*Returns the fragment index of the top-left block in a macro block.
+  This can be used to test whether or not the whole macro block is valid.
+  _sb_map: The super block map.
+  _quadi:  The quadrant number.
+  Return: The index of the fragment of the upper left block in the macro
+   block, or -1 if the block lies outside the coded frame.*/
+static ptrdiff_t oc_sb_quad_top_left_frag(oc_sb_map_quad _sb_map[4],int _quadi){
+  /*It so happens that under the Hilbert curve ordering described below, the
+     upper-left block in each macro block is at index 0, except in macro block
+     3, where it is at index 2.*/
+  return _sb_map[_quadi][_quadi&_quadi<<1];
+}
+
+/*Fills in the mapping from block positions to fragment numbers for a single
+   color plane.
+  This function also fills in the "valid" flag of each quadrant in the super
+   block flags.
+  _sb_maps:  The array of super block maps for the color plane.
+  _sb_flags: The array of super block flags for the color plane.
+  _frag0:    The index of the first fragment in the plane.
+  _hfrags:   The number of horizontal fragments in a coded frame.
+  _vfrags:   The number of vertical fragments in a coded frame.*/
+static void oc_sb_create_plane_mapping(oc_sb_map _sb_maps[],
+ oc_sb_flags _sb_flags[],ptrdiff_t _frag0,int _hfrags,int _vfrags){
+  /*Contains the (macro_block,block) indices for a 4x4 grid of
+     fragments.
+    The pattern is a 4x4 Hilbert space-filling curve.
+    A Hilbert curve has the nice property that as the curve grows larger, its
+     fractal dimension approaches 2.
+    The intuition is that nearby blocks in the curve are also close spatially,
+     with the previous element always an immediate neighbor, so that runs of
+     blocks should be well correlated.*/
+  static const int SB_MAP[4][4][2]={
+    {{0,0},{0,1},{3,2},{3,3}},
+    {{0,3},{0,2},{3,1},{3,0}},
+    {{1,0},{1,3},{2,0},{2,3}},
+    {{1,1},{1,2},{2,1},{2,2}}
+  };
+  ptrdiff_t  yfrag;
+  unsigned   sbi;
+  int        y;
+  sbi=0;
+  yfrag=_frag0;
+  for(y=0;;y+=4){
+    int imax;
+    int x;
+    /*Figure out how many columns of blocks in this super block lie within the
+       image.*/
+    imax=_vfrags-y;
+    if(imax>4)imax=4;
+    else if(imax<=0)break;
+    for(x=0;;x+=4,sbi++){
+      ptrdiff_t xfrag;
+      int       jmax;
+      int       quadi;
+      int       i;
+      /*Figure out how many rows of blocks in this super block lie within the
+         image.*/
+      jmax=_hfrags-x;
+      if(jmax>4)jmax=4;
+      else if(jmax<=0)break;
+      /*By default, set all fragment indices to -1.*/
+      memset(_sb_maps[sbi][0],0xFF,sizeof(_sb_maps[sbi]));
+      /*Fill in the fragment map for this super block.*/
+      xfrag=yfrag+x;
+      for(i=0;i<imax;i++){
+        int j;
+        for(j=0;j<jmax;j++){
+          _sb_maps[sbi][SB_MAP[i][j][0]][SB_MAP[i][j][1]]=xfrag+j;
+        }
+        xfrag+=_hfrags;
+      }
+      /*Mark which quadrants of this super block lie within the image.*/
+      for(quadi=0;quadi<4;quadi++){
+        _sb_flags[sbi].quad_valid|=
+         (oc_sb_quad_top_left_frag(_sb_maps[sbi],quadi)>=0)<<quadi;
+      }
+    }
+    yfrag+=_hfrags<<2;
+  }
+}
+
+/*Fills in the Y plane fragment map for a macro block given the fragment
+   coordinates of its upper-left hand corner.
+  _mb_map:    The macro block map to fill.
+  _fplane: The description of the Y plane.
+  _xfrag0: The X location of the upper-left hand fragment in the luma plane.
+  _yfrag0: The Y location of the upper-left hand fragment in the luma plane.*/
+static void oc_mb_fill_ymapping(oc_mb_map_plane _mb_map[3],
+ const oc_fragment_plane *_fplane,int _xfrag0,int _yfrag0){
+  int i;
+  int j;
+  for(i=0;i<2;i++)for(j=0;j<2;j++){
+    _mb_map[0][i<<1|j]=(_yfrag0+i)*(ptrdiff_t)_fplane->nhfrags+_xfrag0+j;
+  }
+}
+
+/*Fills in the chroma plane fragment maps for a macro block.
+  This version is for use with chroma decimated in the X and Y directions
+   (4:2:0).
+  _mb_map:  The macro block map to fill.
+  _fplanes: The descriptions of the fragment planes.
+  _xfrag0:  The X location of the upper-left hand fragment in the luma plane.
+  _yfrag0:  The Y location of the upper-left hand fragment in the luma plane.*/
+static void oc_mb_fill_cmapping00(oc_mb_map_plane _mb_map[3],
+ const oc_fragment_plane _fplanes[3],int _xfrag0,int _yfrag0){
+  ptrdiff_t fragi;
+  _xfrag0>>=1;
+  _yfrag0>>=1;
+  fragi=_yfrag0*(ptrdiff_t)_fplanes[1].nhfrags+_xfrag0;
+  _mb_map[1][0]=fragi+_fplanes[1].froffset;
+  _mb_map[2][0]=fragi+_fplanes[2].froffset;
+}
+
+/*Fills in the chroma plane fragment maps for a macro block.
+  This version is for use with chroma decimated in the Y direction.
+  _mb_map:  The macro block map to fill.
+  _fplanes: The descriptions of the fragment planes.
+  _xfrag0:  The X location of the upper-left hand fragment in the luma plane.
+  _yfrag0:  The Y location of the upper-left hand fragment in the luma plane.*/
+static void oc_mb_fill_cmapping01(oc_mb_map_plane _mb_map[3],
+ const oc_fragment_plane _fplanes[3],int _xfrag0,int _yfrag0){
+  ptrdiff_t fragi;
+  int       j;
+  _yfrag0>>=1;
+  fragi=_yfrag0*(ptrdiff_t)_fplanes[1].nhfrags+_xfrag0;
+  for(j=0;j<2;j++){
+    _mb_map[1][j]=fragi+_fplanes[1].froffset;
+    _mb_map[2][j]=fragi+_fplanes[2].froffset;
+    fragi++;
+  }
+}
+
+/*Fills in the chroma plane fragment maps for a macro block.
+  This version is for use with chroma decimated in the X direction (4:2:2).
+  _mb_map:  The macro block map to fill.
+  _fplanes: The descriptions of the fragment planes.
+  _xfrag0:  The X location of the upper-left hand fragment in the luma plane.
+  _yfrag0:  The Y location of the upper-left hand fragment in the luma plane.*/
+static void oc_mb_fill_cmapping10(oc_mb_map_plane _mb_map[3],
+ const oc_fragment_plane _fplanes[3],int _xfrag0,int _yfrag0){
+  ptrdiff_t fragi;
+  int       i;
+  _xfrag0>>=1;
+  fragi=_yfrag0*(ptrdiff_t)_fplanes[1].nhfrags+_xfrag0;
+  for(i=0;i<2;i++){
+    _mb_map[1][i<<1]=fragi+_fplanes[1].froffset;
+    _mb_map[2][i<<1]=fragi+_fplanes[2].froffset;
+    fragi+=_fplanes[1].nhfrags;
+  }
+}
+
+/*Fills in the chroma plane fragment maps for a macro block.
+  This version is for use with no chroma decimation (4:4:4).
+  This uses the already filled-in luma plane values.
+  _mb_map:  The macro block map to fill.
+  _fplanes: The descriptions of the fragment planes.*/
+static void oc_mb_fill_cmapping11(oc_mb_map_plane _mb_map[3],
+ const oc_fragment_plane _fplanes[3]){
+  int k;
+  for(k=0;k<4;k++){
+    _mb_map[1][k]=_mb_map[0][k]+_fplanes[1].froffset;
+    _mb_map[2][k]=_mb_map[0][k]+_fplanes[2].froffset;
+  }
+}
+
+/*The function type used to fill in the chroma plane fragment maps for a
+   macro block.
+  _mb_map:  The macro block map to fill.
+  _fplanes: The descriptions of the fragment planes.
+  _xfrag0:  The X location of the upper-left hand fragment in the luma plane.
+  _yfrag0:  The Y location of the upper-left hand fragment in the luma plane.*/
+typedef void (*oc_mb_fill_cmapping_func)(oc_mb_map_plane _mb_map[3],
+ const oc_fragment_plane _fplanes[3],int _xfrag0,int _yfrag0);
+
+/*A table of functions used to fill in the chroma plane fragment maps for a
+   macro block for each type of chrominance decimation.*/
+static const oc_mb_fill_cmapping_func OC_MB_FILL_CMAPPING_TABLE[4]={
+  oc_mb_fill_cmapping00,
+  oc_mb_fill_cmapping01,
+  oc_mb_fill_cmapping10,
+  (oc_mb_fill_cmapping_func)oc_mb_fill_cmapping11
+};
+
+/*Fills in the mapping from macro blocks to their corresponding fragment
+   numbers in each plane.
+  _mb_maps:   The list of macro block maps.
+  _mb_modes:  The list of macro block modes; macro blocks completely outside
+               the coded region are marked invalid.
+  _fplanes:   The descriptions of the fragment planes.
+  _pixel_fmt: The chroma decimation type.*/
+static void oc_mb_create_mapping(oc_mb_map _mb_maps[],
+ signed char _mb_modes[],const oc_fragment_plane _fplanes[3],int _pixel_fmt){
+  oc_mb_fill_cmapping_func  mb_fill_cmapping;
+  unsigned                  sbi;
+  int                       y;
+  mb_fill_cmapping=OC_MB_FILL_CMAPPING_TABLE[_pixel_fmt];
+  /*Loop through the luma plane super blocks.*/
+  for(sbi=y=0;y<_fplanes[0].nvfrags;y+=4){
+    int x;
+    for(x=0;x<_fplanes[0].nhfrags;x+=4,sbi++){
+      int ymb;
+      /*Loop through the macro blocks in each super block in display order.*/
+      for(ymb=0;ymb<2;ymb++){
+        int xmb;
+        for(xmb=0;xmb<2;xmb++){
+          unsigned mbi;
+          int      mbx;
+          int      mby;
+          mbi=sbi<<2|OC_MB_MAP[ymb][xmb];
+          mbx=x|xmb<<1;
+          mby=y|ymb<<1;
+          /*Initialize fragment indices to -1.*/
+          memset(_mb_maps[mbi],0xFF,sizeof(_mb_maps[mbi]));
+          /*Make sure this macro block is within the encoded region.*/
+          if(mbx>=_fplanes[0].nhfrags||mby>=_fplanes[0].nvfrags){
+            _mb_modes[mbi]=OC_MODE_INVALID;
+            continue;
+          }
+          /*Fill in the fragment indices for the luma plane.*/
+          oc_mb_fill_ymapping(_mb_maps[mbi],_fplanes,mbx,mby);
+          /*Fill in the fragment indices for the chroma planes.*/
+          (*mb_fill_cmapping)(_mb_maps[mbi],_fplanes,mbx,mby);
+        }
+      }
+    }
+  }
+}
+
+/*Marks the fragments which fall all or partially outside the displayable
+   region of the frame.
+  _state: The Theora state containing the fragments to be marked.*/
+static void oc_state_border_init(oc_theora_state *_state){
+  oc_fragment       *frag;
+  oc_fragment       *yfrag_end;
+  oc_fragment       *xfrag_end;
+  oc_fragment_plane *fplane;
+  int                crop_x0;
+  int                crop_y0;
+  int                crop_xf;
+  int                crop_yf;
+  int                pli;
+  int                y;
+  int                x;
+  /*The method we use here is slow, but the code is dead simple and handles
+     all the special cases easily.
+    We only ever need to do it once.*/
+  /*Loop through the fragments, marking those completely outside the
+     displayable region and constructing a border mask for those that straddle
+     the border.*/
+  _state->nborders=0;
+  yfrag_end=frag=_state->frags;
+  for(pli=0;pli<3;pli++){
+    fplane=_state->fplanes+pli;
+    /*Set up the cropping rectangle for this plane.*/
+    crop_x0=_state->info.pic_x;
+    crop_xf=_state->info.pic_x+_state->info.pic_width;
+    crop_y0=_state->info.pic_y;
+    crop_yf=_state->info.pic_y+_state->info.pic_height;
+    if(pli>0){
+      if(!(_state->info.pixel_fmt&1)){
+        crop_x0=crop_x0>>1;
+        crop_xf=crop_xf+1>>1;
+      }
+      if(!(_state->info.pixel_fmt&2)){
+        crop_y0=crop_y0>>1;
+        crop_yf=crop_yf+1>>1;
+      }
+    }
+    y=0;
+    for(yfrag_end+=fplane->nfrags;frag<yfrag_end;y+=8){
+      x=0;
+      for(xfrag_end=frag+fplane->nhfrags;frag<xfrag_end;frag++,x+=8){
+        /*First check to see if this fragment is completely outside the
+           displayable region.*/
+        /*Note the special checks for an empty cropping rectangle.
+          This guarantees that if we count a fragment as straddling the
+           border below, at least one pixel in the fragment will be inside
+           the displayable region.*/
+        if(x+8<=crop_x0||crop_xf<=x||y+8<=crop_y0||crop_yf<=y||
+         crop_x0>=crop_xf||crop_y0>=crop_yf){
+          frag->invalid=1;
+        }
+        /*Otherwise, check to see if it straddles the border.*/
+        else if(x<crop_x0&&crop_x0<x+8||x<crop_xf&&crop_xf<x+8||
+         y<crop_y0&&crop_y0<y+8||y<crop_yf&&crop_yf<y+8){
+          ogg_int64_t mask;
+          int         npixels;
+          int         i;
+          mask=npixels=0;
+          for(i=0;i<8;i++){
+            int j;
+            for(j=0;j<8;j++){
+              if(x+j>=crop_x0&&x+j<crop_xf&&y+i>=crop_y0&&y+i<crop_yf){
+                mask|=(ogg_int64_t)1<<(i<<3|j);
+                npixels++;
+              }
+            }
+          }
+          /*Search the fragment array for border info with the same pattern.
+            In general, there will be at most 8 different patterns (per
+             plane).*/
+          for(i=0;;i++){
+            if(i>=_state->nborders){
+              _state->nborders++;
+              _state->borders[i].mask=mask;
+              _state->borders[i].npixels=npixels;
+            }
+            else if(_state->borders[i].mask!=mask)continue;
+            frag->borderi=i;
+            break;
+          }
+        }
+        else frag->borderi=-1;
+      }
+    }
+  }
+}
+
+static int oc_state_frarray_init(oc_theora_state *_state){
+  int       yhfrags;
+  int       yvfrags;
+  int       chfrags;
+  int       cvfrags;
+  ptrdiff_t yfrags;
+  ptrdiff_t cfrags;
+  ptrdiff_t nfrags;
+  unsigned  yhsbs;
+  unsigned  yvsbs;
+  unsigned  chsbs;
+  unsigned  cvsbs;
+  unsigned  ysbs;
+  unsigned  csbs;
+  unsigned  nsbs;
+  size_t    nmbs;
+  int       hdec;
+  int       vdec;
+  int       pli;
+  /*Figure out the number of fragments in each plane.*/
+  /*These parameters have already been validated to be multiples of 16.*/
+  yhfrags=_state->info.frame_width>>3;
+  yvfrags=_state->info.frame_height>>3;
+  hdec=!(_state->info.pixel_fmt&1);
+  vdec=!(_state->info.pixel_fmt&2);
+  chfrags=yhfrags+hdec>>hdec;
+  cvfrags=yvfrags+vdec>>vdec;
+  yfrags=yhfrags*(ptrdiff_t)yvfrags;
+  cfrags=chfrags*(ptrdiff_t)cvfrags;
+  nfrags=yfrags+2*cfrags;
+  /*Figure out the number of super blocks in each plane.*/
+  yhsbs=yhfrags+3>>2;
+  yvsbs=yvfrags+3>>2;
+  chsbs=chfrags+3>>2;
+  cvsbs=cvfrags+3>>2;
+  ysbs=yhsbs*yvsbs;
+  csbs=chsbs*cvsbs;
+  nsbs=ysbs+2*csbs;
+  nmbs=(size_t)ysbs<<2;
+  /*Check for overflow.
+    We support the ridiculous upper limits of the specification (1048560 by
+     1048560, or 3 TB frames) if the target architecture has 64-bit pointers,
+     but for those with 32-bit pointers (or smaller!) we have to check.
+    If the caller wants to prevent denial-of-service by imposing a more
+     reasonable upper limit on the size of attempted allocations, they must do
+     so themselves; we have no platform independent way to determine how much
+     system memory there is nor an application-independent way to decide what a
+     "reasonable" allocation is.*/
+  if(yfrags/yhfrags!=yvfrags||2*cfrags<cfrags||nfrags<yfrags||
+   ysbs/yhsbs!=yvsbs||2*csbs<csbs||nsbs<ysbs||nmbs>>2!=ysbs){
+    return TH_EIMPL;
+  }
+  /*Initialize the fragment array.*/
+  _state->fplanes[0].nhfrags=yhfrags;
+  _state->fplanes[0].nvfrags=yvfrags;
+  _state->fplanes[0].froffset=0;
+  _state->fplanes[0].nfrags=yfrags;
+  _state->fplanes[0].nhsbs=yhsbs;
+  _state->fplanes[0].nvsbs=yvsbs;
+  _state->fplanes[0].sboffset=0;
+  _state->fplanes[0].nsbs=ysbs;
+  _state->fplanes[1].nhfrags=_state->fplanes[2].nhfrags=chfrags;
+  _state->fplanes[1].nvfrags=_state->fplanes[2].nvfrags=cvfrags;
+  _state->fplanes[1].froffset=yfrags;
+  _state->fplanes[2].froffset=yfrags+cfrags;
+  _state->fplanes[1].nfrags=_state->fplanes[2].nfrags=cfrags;
+  _state->fplanes[1].nhsbs=_state->fplanes[2].nhsbs=chsbs;
+  _state->fplanes[1].nvsbs=_state->fplanes[2].nvsbs=cvsbs;
+  _state->fplanes[1].sboffset=ysbs;
+  _state->fplanes[2].sboffset=ysbs+csbs;
+  _state->fplanes[1].nsbs=_state->fplanes[2].nsbs=csbs;
+  _state->nfrags=nfrags;
+  _state->frags=_ogg_calloc(nfrags,sizeof(*_state->frags));
+  _state->frag_mvs=_ogg_malloc(nfrags*sizeof(*_state->frag_mvs));
+  _state->nsbs=nsbs;
+  _state->sb_maps=_ogg_malloc(nsbs*sizeof(*_state->sb_maps));
+  _state->sb_flags=_ogg_calloc(nsbs,sizeof(*_state->sb_flags));
+  _state->nhmbs=yhsbs<<1;
+  _state->nvmbs=yvsbs<<1;
+  _state->nmbs=nmbs;
+  _state->mb_maps=_ogg_calloc(nmbs,sizeof(*_state->mb_maps));
+  _state->mb_modes=_ogg_calloc(nmbs,sizeof(*_state->mb_modes));
+  _state->coded_fragis=_ogg_malloc(nfrags*sizeof(*_state->coded_fragis));
+  if(_state->frags==NULL||_state->frag_mvs==NULL||_state->sb_maps==NULL||
+   _state->sb_flags==NULL||_state->mb_maps==NULL||_state->mb_modes==NULL||
+   _state->coded_fragis==NULL){
+    return TH_EFAULT;
+  }
+  /*Create the mapping from super blocks to fragments.*/
+  for(pli=0;pli<3;pli++){
+    oc_fragment_plane *fplane;
+    fplane=_state->fplanes+pli;
+    oc_sb_create_plane_mapping(_state->sb_maps+fplane->sboffset,
+     _state->sb_flags+fplane->sboffset,fplane->froffset,
+     fplane->nhfrags,fplane->nvfrags);
+  }
+  /*Create the mapping from macro blocks to fragments.*/
+  oc_mb_create_mapping(_state->mb_maps,_state->mb_modes,
+   _state->fplanes,_state->info.pixel_fmt);
+  /*Initialize the invalid and borderi fields of each fragment.*/
+  oc_state_border_init(_state);
+  return 0;
+}
+
+static void oc_state_frarray_clear(oc_theora_state *_state){
+  _ogg_free(_state->coded_fragis);
+  _ogg_free(_state->mb_modes);
+  _ogg_free(_state->mb_maps);
+  _ogg_free(_state->sb_flags);
+  _ogg_free(_state->sb_maps);
+  _ogg_free(_state->frag_mvs);
+  _ogg_free(_state->frags);
+}
+
+
+/*Initializes the buffers used for reconstructed frames.
+  These buffers are padded with 16 extra pixels on each side, to allow
+   unrestricted motion vectors without special casing the boundary.
+  If chroma is decimated in either direction, the padding is reduced by a
+   factor of 2 on the appropriate sides.
+  _nrefs: The number of reference buffers to init; must be 3 or 4.*/
+static int oc_state_ref_bufs_init(oc_theora_state *_state,int _nrefs){
+  th_info       *info;
+  unsigned char *ref_frame_data;
+  size_t         ref_frame_data_sz;
+  size_t         ref_frame_sz;
+  size_t         yplane_sz;
+  size_t         cplane_sz;
+  int            yhstride;
+  int            yheight;
+  int            chstride;
+  int            cheight;
+  ptrdiff_t      yoffset;
+  ptrdiff_t      coffset;
+  ptrdiff_t     *frag_buf_offs;
+  ptrdiff_t      fragi;
+  int            hdec;
+  int            vdec;
+  int            rfi;
+  int            pli;
+  if(_nrefs<3||_nrefs>4)return TH_EINVAL;
+  info=&_state->info;
+  /*Compute the image buffer parameters for each plane.*/
+  hdec=!(info->pixel_fmt&1);
+  vdec=!(info->pixel_fmt&2);
+  yhstride=info->frame_width+2*OC_UMV_PADDING;
+  yheight=info->frame_height+2*OC_UMV_PADDING;
+  chstride=yhstride>>hdec;
+  cheight=yheight>>vdec;
+  yplane_sz=yhstride*(size_t)yheight;
+  cplane_sz=chstride*(size_t)cheight;
+  yoffset=OC_UMV_PADDING+OC_UMV_PADDING*(ptrdiff_t)yhstride;
+  coffset=(OC_UMV_PADDING>>hdec)+(OC_UMV_PADDING>>vdec)*(ptrdiff_t)chstride;
+  ref_frame_sz=yplane_sz+2*cplane_sz;
+  ref_frame_data_sz=_nrefs*ref_frame_sz;
+  /*Check for overflow.
+    The same caveats apply as for oc_state_frarray_init().*/
+  if(yplane_sz/yhstride!=yheight||2*cplane_sz<cplane_sz||
+   ref_frame_sz<yplane_sz||ref_frame_data_sz/_nrefs!=ref_frame_sz){
+    return TH_EIMPL;
+  }
+  ref_frame_data=_ogg_malloc(ref_frame_data_sz);
+  frag_buf_offs=_state->frag_buf_offs=
+   _ogg_malloc(_state->nfrags*sizeof(*frag_buf_offs));
+  if(ref_frame_data==NULL||frag_buf_offs==NULL){
+    _ogg_free(frag_buf_offs);
+    _ogg_free(ref_frame_data);
+    return TH_EFAULT;
+  }
+  /*Set up the width, height and stride for the image buffers.*/
+  _state->ref_frame_bufs[0][0].width=info->frame_width;
+  _state->ref_frame_bufs[0][0].height=info->frame_height;
+  _state->ref_frame_bufs[0][0].stride=yhstride;
+  _state->ref_frame_bufs[0][1].width=_state->ref_frame_bufs[0][2].width=
+   info->frame_width>>hdec;
+  _state->ref_frame_bufs[0][1].height=_state->ref_frame_bufs[0][2].height=
+   info->frame_height>>vdec;
+  _state->ref_frame_bufs[0][1].stride=_state->ref_frame_bufs[0][2].stride=
+   chstride;
+  for(rfi=1;rfi<_nrefs;rfi++){
+    memcpy(_state->ref_frame_bufs[rfi],_state->ref_frame_bufs[0],
+     sizeof(_state->ref_frame_bufs[0]));
+  }
+  /*Set up the data pointers for the image buffers.*/
+  for(rfi=0;rfi<_nrefs;rfi++){
+    _state->ref_frame_data[rfi]=ref_frame_data;
+    _state->ref_frame_bufs[rfi][0].data=ref_frame_data+yoffset;
+    ref_frame_data+=yplane_sz;
+    _state->ref_frame_bufs[rfi][1].data=ref_frame_data+coffset;
+    ref_frame_data+=cplane_sz;
+    _state->ref_frame_bufs[rfi][2].data=ref_frame_data+coffset;
+    ref_frame_data+=cplane_sz;
+    /*Flip the buffer upside down.
+      This allows us to decode Theora's bottom-up frames in their natural
+       order, yet return a top-down buffer with a positive stride to the user.*/
+    oc_ycbcr_buffer_flip(_state->ref_frame_bufs[rfi],
+     _state->ref_frame_bufs[rfi]);
+  }
+  _state->ref_ystride[0]=-yhstride;
+  _state->ref_ystride[1]=_state->ref_ystride[2]=-chstride;
+  /*Initialize the fragment buffer offsets.*/
+  ref_frame_data=_state->ref_frame_data[0];
+  fragi=0;
+  for(pli=0;pli<3;pli++){
+    th_img_plane      *iplane;
+    oc_fragment_plane *fplane;
+    unsigned char     *vpix;
+    ptrdiff_t          stride;
+    ptrdiff_t          vfragi_end;
+    int                nhfrags;
+    iplane=_state->ref_frame_bufs[0]+pli;
+    fplane=_state->fplanes+pli;
+    vpix=iplane->data;
+    vfragi_end=fplane->froffset+fplane->nfrags;
+    nhfrags=fplane->nhfrags;
+    stride=iplane->stride;
+    while(fragi<vfragi_end){
+      ptrdiff_t      hfragi_end;
+      unsigned char *hpix;
+      hpix=vpix;
+      for(hfragi_end=fragi+nhfrags;fragi<hfragi_end;fragi++){
+        frag_buf_offs[fragi]=hpix-ref_frame_data;
+        hpix+=8;
+      }
+      vpix+=stride<<3;
+    }
+  }
+  /*Initialize the reference frame indices.*/
+  _state->ref_frame_idx[OC_FRAME_GOLD]=
+   _state->ref_frame_idx[OC_FRAME_PREV]=
+   _state->ref_frame_idx[OC_FRAME_SELF]=-1;
+  _state->ref_frame_idx[OC_FRAME_IO]=_nrefs>3?3:-1;
+  return 0;
+}
+
+static void oc_state_ref_bufs_clear(oc_theora_state *_state){
+  _ogg_free(_state->frag_buf_offs);
+  _ogg_free(_state->ref_frame_data[0]);
+}
+
+
+void oc_state_vtable_init_c(oc_theora_state *_state){
+  _state->opt_vtable.frag_copy=oc_frag_copy_c;
+  _state->opt_vtable.frag_recon_intra=oc_frag_recon_intra_c;
+  _state->opt_vtable.frag_recon_inter=oc_frag_recon_inter_c;
+  _state->opt_vtable.frag_recon_inter2=oc_frag_recon_inter2_c;
+  _state->opt_vtable.idct8x8=oc_idct8x8_c;
+  _state->opt_vtable.state_frag_recon=oc_state_frag_recon_c;
+  _state->opt_vtable.state_frag_copy_list=oc_state_frag_copy_list_c;
+  _state->opt_vtable.state_loop_filter_frag_rows=
+   oc_state_loop_filter_frag_rows_c;
+  _state->opt_vtable.restore_fpu=oc_restore_fpu_c;
+  _state->opt_data.dct_fzig_zag=OC_FZIG_ZAG;
+}
+
+/*Initialize the accelerated function pointers.*/
+void oc_state_vtable_init(oc_theora_state *_state){
+#if defined(OC_X86_ASM)
+  oc_state_vtable_init_x86(_state);
+#else
+  oc_state_vtable_init_c(_state);
+#endif
+}
+
+
+int oc_state_init(oc_theora_state *_state,const th_info *_info,int _nrefs){
+  int ret;
+  /*First validate the parameters.*/
+  if(_info==NULL)return TH_EFAULT;
+  /*The width and height of the encoded frame must be multiples of 16.
+    They must also, when divided by 16, fit into a 16-bit unsigned integer.
+    The displayable frame offset coordinates must fit into an 8-bit unsigned
+     integer.
+    Note that the offset Y in the API is specified on the opposite side from
+     how it is specified in the bitstream, because the Y axis is flipped in
+     the bitstream.
+    The displayable frame must fit inside the encoded frame.
+    The color space must be one known by the encoder.*/
+  if((_info->frame_width&0xF)||(_info->frame_height&0xF)||
+   _info->frame_width<=0||_info->frame_width>=0x100000||
+   _info->frame_height<=0||_info->frame_height>=0x100000||
+   _info->pic_x+_info->pic_width>_info->frame_width||
+   _info->pic_y+_info->pic_height>_info->frame_height||
+   _info->pic_x>255||_info->frame_height-_info->pic_height-_info->pic_y>255||
+   /*Note: the following <0 comparisons may generate spurious warnings on
+      platforms where enums are unsigned.
+     We could cast them to unsigned and just use the following >= comparison,
+      but there are a number of compilers which will mis-optimize this.
+     It's better to live with the spurious warnings.*/
+   _info->colorspace<0||_info->colorspace>=TH_CS_NSPACES||
+   _info->pixel_fmt<0||_info->pixel_fmt>=TH_PF_NFORMATS){
+    return TH_EINVAL;
+  }
+  memset(_state,0,sizeof(*_state));
+  memcpy(&_state->info,_info,sizeof(*_info));
+  /*Invert the sense of pic_y to match Theora's right-handed coordinate
+     system.*/
+  _state->info.pic_y=_info->frame_height-_info->pic_height-_info->pic_y;
+  _state->frame_type=OC_UNKWN_FRAME;
+  oc_state_vtable_init(_state);
+  ret=oc_state_frarray_init(_state);
+  if(ret>=0)ret=oc_state_ref_bufs_init(_state,_nrefs);
+  if(ret<0){
+    oc_state_frarray_clear(_state);
+    return ret;
+  }
+  /*If the keyframe_granule_shift is out of range, use the maximum allowable
+     value.*/
+  if(_info->keyframe_granule_shift<0||_info->keyframe_granule_shift>31){
+    _state->info.keyframe_granule_shift=31;
+  }
+  _state->keyframe_num=0;
+  _state->curframe_num=-1;
+  /*3.2.0 streams mark the frame index instead of the frame count.
+    This was changed with stream version 3.2.1 to conform to other Ogg
+     codecs.
+    We add an extra bias when computing granule positions for new streams.*/
+  _state->granpos_bias=TH_VERSION_CHECK(_info,3,2,1);
+  return 0;
+}
+
+void oc_state_clear(oc_theora_state *_state){
+  oc_state_ref_bufs_clear(_state);
+  oc_state_frarray_clear(_state);
+}
+
+
+/*Duplicates the pixels on the border of the image plane out into the
+   surrounding padding for use by unrestricted motion vectors.
+  This function only adds the left and right borders, and only for the fragment
+   rows specified.
+  _refi: The index of the reference buffer to pad.
+  _pli:  The color plane.
+  _y0:   The Y coordinate of the first row to pad.
+  _yend: The Y coordinate of the row to stop padding at.*/
+void oc_state_borders_fill_rows(oc_theora_state *_state,int _refi,int _pli,
+ int _y0,int _yend){
+  th_img_plane  *iplane;
+  unsigned char *apix;
+  unsigned char *bpix;
+  unsigned char *epix;
+  int            stride;
+  int            hpadding;
+  hpadding=OC_UMV_PADDING>>(_pli!=0&&!(_state->info.pixel_fmt&1));
+  iplane=_state->ref_frame_bufs[_refi]+_pli;
+  stride=iplane->stride;
+  apix=iplane->data+_y0*(ptrdiff_t)stride;
+  bpix=apix+iplane->width-1;
+  epix=iplane->data+_yend*(ptrdiff_t)stride;
+  /*Note the use of != instead of <, which allows the stride to be negative.*/
+  while(apix!=epix){
+    memset(apix-hpadding,apix[0],hpadding);
+    memset(bpix+1,bpix[0],hpadding);
+    apix+=stride;
+    bpix+=stride;
+  }
+}
+
+/*Duplicates the pixels on the border of the image plane out into the
+   surrounding padding for use by unrestricted motion vectors.
+  This function only adds the top and bottom borders, and must be called after
+   the left and right borders are added.
+  _refi:      The index of the reference buffer to pad.
+  _pli:       The color plane.*/
+void oc_state_borders_fill_caps(oc_theora_state *_state,int _refi,int _pli){
+  th_img_plane  *iplane;
+  unsigned char *apix;
+  unsigned char *bpix;
+  unsigned char *epix;
+  int            stride;
+  int            hpadding;
+  int            vpadding;
+  int            fullw;
+  hpadding=OC_UMV_PADDING>>(_pli!=0&&!(_state->info.pixel_fmt&1));
+  vpadding=OC_UMV_PADDING>>(_pli!=0&&!(_state->info.pixel_fmt&2));
+  iplane=_state->ref_frame_bufs[_refi]+_pli;
+  stride=iplane->stride;
+  fullw=iplane->width+(hpadding<<1);
+  apix=iplane->data-hpadding;
+  bpix=iplane->data+(iplane->height-1)*(ptrdiff_t)stride-hpadding;
+  epix=apix-stride*(ptrdiff_t)vpadding;
+  while(apix!=epix){
+    memcpy(apix-stride,apix,fullw);
+    memcpy(bpix+stride,bpix,fullw);
+    apix-=stride;
+    bpix+=stride;
+  }
+}
+
+/*Duplicates the pixels on the border of the given reference image out into
+   the surrounding padding for use by unrestricted motion vectors.
+  _state: The context containing the reference buffers.
+  _refi:  The index of the reference buffer to pad.*/
+void oc_state_borders_fill(oc_theora_state *_state,int _refi){
+  int pli;
+  for(pli=0;pli<3;pli++){
+    oc_state_borders_fill_rows(_state,_refi,pli,0,
+     _state->ref_frame_bufs[_refi][pli].height);
+    oc_state_borders_fill_caps(_state,_refi,pli);
+  }
+}
+
+/*Determines the offsets in an image buffer to use for motion compensation.
+  _state:   The Theora state the offsets are to be computed with.
+  _offsets: Returns the offset for the buffer(s).
+            _offsets[0] is always set.
+            _offsets[1] is set if the motion vector has non-zero fractional
+             components.
+  _pli:     The color plane index.
+  _dx:      The X component of the motion vector.
+  _dy:      The Y component of the motion vector.
+  Return: The number of offsets returned: 1 or 2.*/
+int oc_state_get_mv_offsets(const oc_theora_state *_state,int _offsets[2],
+ int _pli,int _dx,int _dy){
+  /*Here is a brief description of how Theora handles motion vectors:
+    Motion vector components are specified to half-pixel accuracy in
+     undecimated directions of each plane, and quarter-pixel accuracy in
+     decimated directions.
+    Integer parts are extracted by dividing (not shifting) by the
+     appropriate amount, with truncation towards zero.
+    These integer values are used to calculate the first offset.
+
+    If either of the fractional parts are non-zero, then a second offset is
+     computed.
+    No third or fourth offsets are computed, even if both components have
+     non-zero fractional parts.
+    The second offset is computed by dividing (not shifting) by the
+     appropriate amount, always truncating _away_ from zero.*/
+#if 0
+  /*This version of the code doesn't use any tables, but is slower.*/
+  int ystride;
+  int xprec;
+  int yprec;
+  int xfrac;
+  int yfrac;
+  int offs;
+  ystride=_state->ref_ystride[_pli];
+  /*These two variables decide whether we are in half- or quarter-pixel
+     precision in each component.*/
+  xprec=1+(_pli!=0&&!(_state->info.pixel_fmt&1));
+  yprec=1+(_pli!=0&&!(_state->info.pixel_fmt&2));
+  /*These two variables are either 0 if all the fractional bits are zero or -1
+     if any of them are non-zero.*/
+  xfrac=OC_SIGNMASK(-(_dx&(xprec|1)));
+  yfrac=OC_SIGNMASK(-(_dy&(yprec|1)));
+  offs=(_dx>>xprec)+(_dy>>yprec)*ystride;
+  if(xfrac||yfrac){
+    int xmask;
+    int ymask;
+    xmask=OC_SIGNMASK(_dx);
+    ymask=OC_SIGNMASK(_dy);
+    yfrac&=ystride;
+    _offsets[0]=offs-(xfrac&xmask)+(yfrac&ymask);
+    _offsets[1]=offs-(xfrac&~xmask)+(yfrac&~ymask);
+    return 2;
+  }
+  else{
+    _offsets[0]=offs;
+    return 1;
+  }
+#else
+  /*Using tables simplifies the code, and there's enough arithmetic to hide the
+     latencies of the memory references.*/
+  static const signed char OC_MVMAP[2][64]={
+    {
+          -15,-15,-14,-14,-13,-13,-12,-12,-11,-11,-10,-10, -9, -9, -8,
+       -8, -7, -7, -6, -6, -5, -5, -4, -4, -3, -3, -2, -2, -1, -1,  0,
+        0,  0,  1,  1,  2,  2,  3,  3,  4,  4,  5,  5,  6,  6,  7,  7,
+        8,  8,  9,  9, 10, 10, 11, 11, 12, 12, 13, 13, 14, 14, 15, 15
+    },
+    {
+           -7, -7, -7, -7, -6, -6, -6, -6, -5, -5, -5, -5, -4, -4, -4,
+       -4, -3, -3, -3, -3, -2, -2, -2, -2, -1, -1, -1, -1,  0,  0,  0,
+        0,  0,  0,  0,  1,  1,  1,  1,  2,  2,  2,  2,  3,  3,  3,  3,
+        4,  4,  4,  4,  5,  5,  5,  5,  6,  6,  6,  6,  7,  7,  7,  7
+    }
+  };
+  static const signed char OC_MVMAP2[2][64]={
+    {
+        -1, 0,-1,  0,-1, 0,-1,  0,-1, 0,-1,  0,-1, 0,-1,
+      0,-1, 0,-1,  0,-1, 0,-1,  0,-1, 0,-1,  0,-1, 0,-1,
+      0, 1, 0, 1,  0, 1, 0, 1,  0, 1, 0, 1,  0, 1, 0, 1,
+      0, 1, 0, 1,  0, 1, 0, 1,  0, 1, 0, 1,  0, 1, 0, 1
+    },
+    {
+        -1,-1,-1,  0,-1,-1,-1,  0,-1,-1,-1,  0,-1,-1,-1,
+      0,-1,-1,-1,  0,-1,-1,-1,  0,-1,-1,-1,  0,-1,-1,-1,
+      0, 1, 1, 1,  0, 1, 1, 1,  0, 1, 1, 1,  0, 1, 1, 1,
+      0, 1, 1, 1,  0, 1, 1, 1,  0, 1, 1, 1,  0, 1, 1, 1
+    }
+  };
+  int ystride;
+  int qpx;
+  int qpy;
+  int mx;
+  int my;
+  int mx2;
+  int my2;
+  int offs;
+  ystride=_state->ref_ystride[_pli];
+  qpy=_pli!=0&&!(_state->info.pixel_fmt&2);
+  my=OC_MVMAP[qpy][_dy+31];
+  my2=OC_MVMAP2[qpy][_dy+31];
+  qpx=_pli!=0&&!(_state->info.pixel_fmt&1);
+  mx=OC_MVMAP[qpx][_dx+31];
+  mx2=OC_MVMAP2[qpx][_dx+31];
+  offs=my*ystride+mx;
+  if(mx2||my2){
+    _offsets[1]=offs+my2*ystride+mx2;
+    _offsets[0]=offs;
+    return 2;
+  }
+  _offsets[0]=offs;
+  return 1;
+#endif
+}
+
+void oc_state_frag_recon(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant){
+  _state->opt_vtable.state_frag_recon(_state,_fragi,_pli,_dct_coeffs,
+   _last_zzi,_dc_quant);
+}
+
+void oc_state_frag_recon_c(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant){
+  unsigned char *dst;
+  ptrdiff_t      frag_buf_off;
+  int            ystride;
+  int            mb_mode;
+  /*Apply the inverse transform.*/
+  /*Special case only having a DC component.*/
+  if(_last_zzi<2){
+    ogg_int16_t p;
+    int         ci;
+    /*We round this dequant product (and not any of the others) because there's
+       no iDCT rounding.*/
+    p=(ogg_int16_t)(_dct_coeffs[0]*(ogg_int32_t)_dc_quant+15>>5);
+    /*LOOP VECTORIZES.*/
+    for(ci=0;ci<64;ci++)_dct_coeffs[ci]=p;
+  }
+  else{
+    /*First, dequantize the DC coefficient.*/
+    _dct_coeffs[0]=(ogg_int16_t)(_dct_coeffs[0]*(int)_dc_quant);
+    oc_idct8x8(_state,_dct_coeffs,_last_zzi);
+  }
+  /*Fill in the target buffer.*/
+  frag_buf_off=_state->frag_buf_offs[_fragi];
+  mb_mode=_state->frags[_fragi].mb_mode;
+  ystride=_state->ref_ystride[_pli];
+  dst=_state->ref_frame_data[_state->ref_frame_idx[OC_FRAME_SELF]]+frag_buf_off;
+  if(mb_mode==OC_MODE_INTRA)oc_frag_recon_intra(_state,dst,ystride,_dct_coeffs);
+  else{
+    const unsigned char *ref;
+    int                  mvoffsets[2];
+    ref=
+     _state->ref_frame_data[_state->ref_frame_idx[OC_FRAME_FOR_MODE(mb_mode)]]
+     +frag_buf_off;
+    if(oc_state_get_mv_offsets(_state,mvoffsets,_pli,
+     _state->frag_mvs[_fragi][0],_state->frag_mvs[_fragi][1])>1){
+      oc_frag_recon_inter2(_state,
+       dst,ref+mvoffsets[0],ref+mvoffsets[1],ystride,_dct_coeffs);
+    }
+    else oc_frag_recon_inter(_state,dst,ref+mvoffsets[0],ystride,_dct_coeffs);
+  }
+}
+
+/*Copies the fragments specified by the lists of fragment indices from one
+   frame to another.
+  _fragis:    A pointer to a list of fragment indices.
+  _nfragis:   The number of fragment indices to copy.
+  _dst_frame: The reference frame to copy to.
+  _src_frame: The reference frame to copy from.
+  _pli:       The color plane the fragments lie in.*/
+void oc_state_frag_copy_list(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli){
+  _state->opt_vtable.state_frag_copy_list(_state,_fragis,_nfragis,_dst_frame,
+   _src_frame,_pli);
+}
+
+void oc_state_frag_copy_list_c(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli){
+  const ptrdiff_t     *frag_buf_offs;
+  const unsigned char *src_frame_data;
+  unsigned char       *dst_frame_data;
+  ptrdiff_t            fragii;
+  int                  ystride;
+  dst_frame_data=_state->ref_frame_data[_state->ref_frame_idx[_dst_frame]];
+  src_frame_data=_state->ref_frame_data[_state->ref_frame_idx[_src_frame]];
+  ystride=_state->ref_ystride[_pli];
+  frag_buf_offs=_state->frag_buf_offs;
+  for(fragii=0;fragii<_nfragis;fragii++){
+    ptrdiff_t frag_buf_off;
+    frag_buf_off=frag_buf_offs[_fragis[fragii]];
+    oc_frag_copy(_state,dst_frame_data+frag_buf_off,
+     src_frame_data+frag_buf_off,ystride);
+  }
+}
+
+static void loop_filter_h(unsigned char *_pix,int _ystride,int *_bv){
+  int y;
+  _pix-=2;
+  for(y=0;y<8;y++){
+    int f;
+    f=_pix[0]-_pix[3]+3*(_pix[2]-_pix[1]);
+    /*The _bv array is used to compute the function
+      f=OC_CLAMPI(OC_MINI(-_2flimit-f,0),f,OC_MAXI(_2flimit-f,0));
+      where _2flimit=_state->loop_filter_limits[_state->qis[0]]<<1;*/
+    f=*(_bv+(f+4>>3));
+    _pix[1]=OC_CLAMP255(_pix[1]+f);
+    _pix[2]=OC_CLAMP255(_pix[2]-f);
+    _pix+=_ystride;
+  }
+}
+
+static void loop_filter_v(unsigned char *_pix,int _ystride,int *_bv){
+  int x;
+  _pix-=_ystride*2;
+  for(x=0;x<8;x++){
+    int f;
+    f=_pix[x]-_pix[_ystride*3+x]+3*(_pix[_ystride*2+x]-_pix[_ystride+x]);
+    /*The _bv array is used to compute the function
+      f=OC_CLAMPI(OC_MINI(-_2flimit-f,0),f,OC_MAXI(_2flimit-f,0));
+      where _2flimit=_state->loop_filter_limits[_state->qis[0]]<<1;*/
+    f=*(_bv+(f+4>>3));
+    _pix[_ystride+x]=OC_CLAMP255(_pix[_ystride+x]+f);
+    _pix[_ystride*2+x]=OC_CLAMP255(_pix[_ystride*2+x]-f);
+  }
+}
+
+/*Initialize the bounding values array used by the loop filter.
+  _bv: Storage for the array.
+  Return: 0 on success, or a non-zero value if no filtering need be applied.*/
+int oc_state_loop_filter_init(oc_theora_state *_state,int _bv[256]){
+  int flimit;
+  int i;
+  flimit=_state->loop_filter_limits[_state->qis[0]];
+  if(flimit==0)return 1;
+  memset(_bv,0,sizeof(_bv[0])*256);
+  for(i=0;i<flimit;i++){
+    if(127-i-flimit>=0)_bv[127-i-flimit]=i-flimit;
+    _bv[127-i]=-i;
+    _bv[127+i]=i;
+    if(127+i+flimit<256)_bv[127+i+flimit]=flimit-i;
+  }
+  return 0;
+}
+
+/*Apply the loop filter to a given set of fragment rows in the given plane.
+  The filter may be run on the bottom edge, affecting pixels in the next row of
+   fragments, so this row also needs to be available.
+  _bv:        The bounding values array.
+  _refi:      The index of the frame buffer to filter.
+  _pli:       The color plane to filter.
+  _fragy0:    The Y coordinate of the first fragment row to filter.
+  _fragy_end: The Y coordinate of the fragment row to stop filtering at.*/
+void oc_state_loop_filter_frag_rows(const oc_theora_state *_state,int _bv[256],
+ int _refi,int _pli,int _fragy0,int _fragy_end){
+  _state->opt_vtable.state_loop_filter_frag_rows(_state,_bv,_refi,_pli,
+   _fragy0,_fragy_end);
+}
+
+void oc_state_loop_filter_frag_rows_c(const oc_theora_state *_state,int *_bv,
+ int _refi,int _pli,int _fragy0,int _fragy_end){
+  const oc_fragment_plane *fplane;
+  const oc_fragment       *frags;
+  const ptrdiff_t         *frag_buf_offs;
+  unsigned char           *ref_frame_data;
+  ptrdiff_t                fragi_top;
+  ptrdiff_t                fragi_bot;
+  ptrdiff_t                fragi0;
+  ptrdiff_t                fragi0_end;
+  int                      ystride;
+  int                      nhfrags;
+  _bv+=127;
+  fplane=_state->fplanes+_pli;
+  nhfrags=fplane->nhfrags;
+  fragi_top=fplane->froffset;
+  fragi_bot=fragi_top+fplane->nfrags;
+  fragi0=fragi_top+_fragy0*(ptrdiff_t)nhfrags;
+  fragi0_end=fragi0+(_fragy_end-_fragy0)*(ptrdiff_t)nhfrags;
+  ystride=_state->ref_ystride[_pli];
+  frags=_state->frags;
+  frag_buf_offs=_state->frag_buf_offs;
+  ref_frame_data=_state->ref_frame_data[_refi];
+  /*The following loops are constructed somewhat non-intuitively on purpose.
+    The main idea is: if a block boundary has at least one coded fragment on
+     it, the filter is applied to it.
+    However, the order that the filters are applied in matters, and VP3 chose
+     the somewhat strange ordering used below.*/
+  while(fragi0<fragi0_end){
+    ptrdiff_t fragi;
+    ptrdiff_t fragi_end;
+    fragi=fragi0;
+    fragi_end=fragi+nhfrags;
+    while(fragi<fragi_end){
+      if(frags[fragi].coded){
+        unsigned char *ref;
+        ref=ref_frame_data+frag_buf_offs[fragi];
+        if(fragi>fragi0)loop_filter_h(ref,ystride,_bv);
+        if(fragi0>fragi_top)loop_filter_v(ref,ystride,_bv);
+        if(fragi+1<fragi_end&&!frags[fragi+1].coded){
+          loop_filter_h(ref+8,ystride,_bv);
+        }
+        if(fragi+nhfrags<fragi_bot&&!frags[fragi+nhfrags].coded){
+          loop_filter_v(ref+(ystride<<3),ystride,_bv);
+        }
+      }
+      fragi++;
+    }
+    fragi0+=nhfrags;
+  }
+}
+
+#if defined(OC_DUMP_IMAGES)
+int oc_state_dump_frame(const oc_theora_state *_state,int _frame,
+ const char *_suf){
+  /*Dump a PNG of the reconstructed image.*/
+  png_structp    png;
+  png_infop      info;
+  png_bytep     *image;
+  FILE          *fp;
+  char           fname[16];
+  unsigned char *y_row;
+  unsigned char *u_row;
+  unsigned char *v_row;
+  unsigned char *y;
+  unsigned char *u;
+  unsigned char *v;
+  ogg_int64_t    iframe;
+  ogg_int64_t    pframe;
+  int            y_stride;
+  int            u_stride;
+  int            v_stride;
+  int            framei;
+  int            width;
+  int            height;
+  int            imgi;
+  int            imgj;
+  width=_state->info.frame_width;
+  height=_state->info.frame_height;
+  iframe=_state->granpos>>_state->info.keyframe_granule_shift;
+  pframe=_state->granpos-(iframe<<_state->info.keyframe_granule_shift);
+  sprintf(fname,"%08i%s.png",(int)(iframe+pframe),_suf);
+  fp=fopen(fname,"wb");
+  if(fp==NULL)return TH_EFAULT;
+  image=(png_bytep *)oc_malloc_2d(height,6*width,sizeof(**image));
+  if(image==NULL){
+    fclose(fp);
+    return TH_EFAULT;
+  }
+  png=png_create_write_struct(PNG_LIBPNG_VER_STRING,NULL,NULL,NULL);
+  if(png==NULL){
+    oc_free_2d(image);
+    fclose(fp);
+    return TH_EFAULT;
+  }
+  info=png_create_info_struct(png);
+  if(info==NULL){
+    png_destroy_write_struct(&png,NULL);
+    oc_free_2d(image);
+    fclose(fp);
+    return TH_EFAULT;
+  }
+  if(setjmp(png_jmpbuf(png))){
+    png_destroy_write_struct(&png,&info);
+    oc_free_2d(image);
+    fclose(fp);
+    return TH_EFAULT;
+  }
+  framei=_state->ref_frame_idx[_frame];
+  y_row=_state->ref_frame_bufs[framei][0].data;
+  u_row=_state->ref_frame_bufs[framei][1].data;
+  v_row=_state->ref_frame_bufs[framei][2].data;
+  y_stride=_state->ref_frame_bufs[framei][0].stride;
+  u_stride=_state->ref_frame_bufs[framei][1].stride;
+  v_stride=_state->ref_frame_bufs[framei][2].stride;
+  /*Chroma up-sampling is just done with a box filter.
+    This is very likely what will actually be used in practice on a real
+     display, and also removes one more layer to search in for the source of
+     artifacts.
+    As an added bonus, it's dead simple.*/
+  for(imgi=height;imgi-->0;){
+    int dc;
+    y=y_row;
+    u=u_row;
+    v=v_row;
+    for(imgj=0;imgj<6*width;){
+      float    yval;
+      float    uval;
+      float    vval;
+      unsigned rval;
+      unsigned gval;
+      unsigned bval;
+      /*This is intentionally slow and very accurate.*/
+      yval=(*y-16)*(1.0F/219);
+      uval=(*u-128)*(2*(1-0.114F)/224);
+      vval=(*v-128)*(2*(1-0.299F)/224);
+      rval=OC_CLAMPI(0,(int)(65535*(yval+vval)+0.5F),65535);
+      gval=OC_CLAMPI(0,(int)(65535*(
+       yval-uval*(0.114F/0.587F)-vval*(0.299F/0.587F))+0.5F),65535);
+      bval=OC_CLAMPI(0,(int)(65535*(yval+uval)+0.5F),65535);
+      image[imgi][imgj++]=(unsigned char)(rval>>8);
+      image[imgi][imgj++]=(unsigned char)(rval&0xFF);
+      image[imgi][imgj++]=(unsigned char)(gval>>8);
+      image[imgi][imgj++]=(unsigned char)(gval&0xFF);
+      image[imgi][imgj++]=(unsigned char)(bval>>8);
+      image[imgi][imgj++]=(unsigned char)(bval&0xFF);
+      dc=(y-y_row&1)|(_state->info.pixel_fmt&1);
+      y++;
+      u+=dc;
+      v+=dc;
+    }
+    dc=-((height-1-imgi&1)|_state->info.pixel_fmt>>1);
+    y_row+=y_stride;
+    u_row+=dc&u_stride;
+    v_row+=dc&v_stride;
+  }
+  png_init_io(png,fp);
+  png_set_compression_level(png,Z_BEST_COMPRESSION);
+  png_set_IHDR(png,info,width,height,16,PNG_COLOR_TYPE_RGB,
+   PNG_INTERLACE_NONE,PNG_COMPRESSION_TYPE_DEFAULT,PNG_FILTER_TYPE_DEFAULT);
+  switch(_state->info.colorspace){
+    case TH_CS_ITU_REC_470M:{
+      png_set_gAMA(png,info,2.2);
+      png_set_cHRM_fixed(png,info,31006,31616,
+       67000,32000,21000,71000,14000,8000);
+    }break;
+    case TH_CS_ITU_REC_470BG:{
+      png_set_gAMA(png,info,2.67);
+      png_set_cHRM_fixed(png,info,31271,32902,
+       64000,33000,29000,60000,15000,6000);
+    }break;
+    default:break;
+  }
+  png_set_pHYs(png,info,_state->info.aspect_numerator,
+   _state->info.aspect_denominator,0);
+  png_set_rows(png,info,image);
+  png_write_png(png,info,PNG_TRANSFORM_IDENTITY,NULL);
+  png_write_end(png,info);
+  png_destroy_write_struct(&png,&info);
+  oc_free_2d(image);
+  fclose(fp);
+  return 0;
+}
+#endif
+
+
+
+ogg_int64_t th_granule_frame(void *_encdec,ogg_int64_t _granpos){
+  oc_theora_state *state;
+  state=(oc_theora_state *)_encdec;
+  if(_granpos>=0){
+    ogg_int64_t iframe;
+    ogg_int64_t pframe;
+    iframe=_granpos>>state->info.keyframe_granule_shift;
+    pframe=_granpos-(iframe<<state->info.keyframe_granule_shift);
+    /*3.2.0 streams store the frame index in the granule position.
+      3.2.1 and later store the frame count.
+      We return the index, so adjust the value if we have a 3.2.1 or later
+       stream.*/
+    return iframe+pframe-TH_VERSION_CHECK(&state->info,3,2,1);
+  }
+  return -1;
+}
+
+double th_granule_time(void *_encdec,ogg_int64_t _granpos){
+  oc_theora_state *state;
+  state=(oc_theora_state *)_encdec;
+  if(_granpos>=0){
+    return (th_granule_frame(_encdec, _granpos)+1)*(
+     (double)state->info.fps_denominator/state->info.fps_numerator);
+  }
+  return -1;
+}
diff --git a/lib/theora.exp b/lib/theora.exp
new file mode 100644 (file)
index 0000000..b4e0225
--- /dev/null
@@ -0,0 +1,55 @@
+# export list for libtheora\r
+_theora_version_string\r
+_theora_version_number\r
+_theora_encode_init\r
+_theora_encode_YUVin\r
+_theora_encode_packetout\r
+_theora_encode_header\r
+_theora_encode_comment\r
+_theora_encode_tables\r
+_theora_decode_header\r
+_theora_decode_init\r
+_theora_decode_packetin\r
+_theora_decode_YUVout\r
+_theora_control\r
+_theora_packet_isheader\r
+_theora_packet_iskeyframe\r
+_theora_granule_shift\r
+_theora_granule_frame\r
+_theora_granule_time\r
+_theora_info_init\r
+_theora_info_clear\r
+_theora_clear\r
+_theora_comment_init\r
+_theora_comment_add\r
+_theora_comment_add_tag\r
+_theora_comment_query\r
+_theora_comment_query_count\r
+_theora_comment_clear\r
+_th_version_string\r
+_th_version_number\r
+_th_decode_headerin\r
+_th_decode_alloc\r
+_th_setup_free\r
+_th_decode_ctl\r
+_th_decode_packetin\r
+_th_decode_ycbcr_out\r
+_th_decode_free\r
+_th_packet_isheader\r
+_th_packet_iskeyframe\r
+_th_granule_frame\r
+_th_granule_time\r
+_th_info_init\r
+_th_info_clear\r
+_th_comment_init\r
+_th_comment_add\r
+_th_comment_add_tag\r
+_th_comment_query\r
+_th_comment_query_count\r
+_th_comment_clear\r
+_th_encode_alloc\r
+_th_encode_ctl\r
+_th_encode_flushheader\r
+_th_encode_packetout\r
+_th_encode_ycbcr_in\r
+_th_encode_free\r
diff --git a/lib/theoradec.exp b/lib/theoradec.exp
new file mode 100644 (file)
index 0000000..41dec1c
--- /dev/null
@@ -0,0 +1,43 @@
+# export list for theoradec
+_th_version_string
+_th_version_number
+_th_decode_headerin
+_th_decode_alloc
+_th_setup_free
+_th_decode_ctl
+_th_decode_packetin
+_th_decode_ycbcr_out
+_th_decode_free
+_th_packet_isheader
+_th_packet_iskeyframe
+_th_granule_frame
+_th_granule_time
+_th_info_init
+_th_info_clear
+_th_comment_init
+_th_comment_add
+_th_comment_add_tag
+_th_comment_query
+_th_comment_query_count
+_th_comment_clear
+_theora_version_string
+_theora_version_number
+_theora_decode_header
+_theora_decode_init
+_theora_decode_packetin
+_theora_decode_YUVout
+_theora_control
+_theora_packet_isheader
+_theora_packet_iskeyframe
+_theora_granule_shift
+_theora_granule_frame
+_theora_granule_time
+_theora_info_init
+_theora_info_clear
+_theora_clear
+_theora_comment_init
+_theora_comment_add
+_theora_comment_add_tag
+_theora_comment_query
+_theora_comment_query_count
+_theora_comment_clear
diff --git a/lib/theoraenc.exp b/lib/theoraenc.exp
new file mode 100644 (file)
index 0000000..d278455
--- /dev/null
@@ -0,0 +1,15 @@
+# export list for theoraenc
+_th_encode_alloc
+_th_encode_ctl
+_th_encode_flushheader
+_th_encode_ycbcr_in
+_th_encode_packetout
+_th_encode_free
+_TH_VP31_QUANT_INFO
+_TH_VP31_HUFF_CODES
+_theora_encode_init
+_theora_encode_YUVin
+_theora_encode_packetout
+_theora_encode_header
+_theora_encode_comment
+_theora_encode_tables
diff --git a/lib/tokenize.c b/lib/tokenize.c
new file mode 100644 (file)
index 0000000..60574c3
--- /dev/null
@@ -0,0 +1,1072 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: tokenize.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+#include <stdlib.h>
+#include <string.h>
+#include "encint.h"
+
+
+
+static int oc_make_eob_token(int _run_count){
+  if(_run_count<4)return OC_DCT_EOB1_TOKEN+_run_count-1;
+  else{
+    int cat;
+    cat=OC_ILOGNZ_32(_run_count)-3;
+    cat=OC_MINI(cat,3);
+    return OC_DCT_REPEAT_RUN0_TOKEN+cat;
+  }
+}
+
+static int oc_make_eob_token_full(int _run_count,int *_eb){
+  if(_run_count<4){
+    *_eb=0;
+    return OC_DCT_EOB1_TOKEN+_run_count-1;
+  }
+  else{
+    int cat;
+    cat=OC_ILOGNZ_32(_run_count)-3;
+    cat=OC_MINI(cat,3);
+    *_eb=_run_count-OC_BYTE_TABLE32(4,8,16,0,cat);
+    return OC_DCT_REPEAT_RUN0_TOKEN+cat;
+  }
+}
+
+/*Returns the number of blocks ended by an EOB token.*/
+static int oc_decode_eob_token(int _token,int _eb){
+  return (0x20820C41U>>_token*5&0x1F)+_eb;
+}
+
+/*TODO: This is now only used during DCT tokenization, and never for runs; it
+   should be simplified.*/
+static int oc_make_dct_token_full(int _zzi,int _zzj,int _val,int *_eb){
+  int neg;
+  int zero_run;
+  int token;
+  int eb;
+  neg=_val<0;
+  _val=abs(_val);
+  zero_run=_zzj-_zzi;
+  if(zero_run>0){
+    int adj;
+    /*Implement a minor restriction on stack 1 so that we know during DC fixups
+       that extending a dctrun token from stack 1 will never overflow.*/
+    adj=_zzi!=1;
+    if(_val<2&&zero_run<17+adj){
+      if(zero_run<6){
+        token=OC_DCT_RUN_CAT1A+zero_run-1;
+        eb=neg;
+      }
+      else if(zero_run<10){
+        token=OC_DCT_RUN_CAT1B;
+        eb=zero_run-6+(neg<<2);
+      }
+      else{
+        token=OC_DCT_RUN_CAT1C;
+        eb=zero_run-10+(neg<<3);
+      }
+    }
+    else if(_val<4&&zero_run<3+adj){
+      if(zero_run<2){
+        token=OC_DCT_RUN_CAT2A;
+        eb=_val-2+(neg<<1);
+      }
+      else{
+        token=OC_DCT_RUN_CAT2B;
+        eb=zero_run-2+(_val-2<<1)+(neg<<2);
+      }
+    }
+    else{
+      if(zero_run<9)token=OC_DCT_SHORT_ZRL_TOKEN;
+      else token=OC_DCT_ZRL_TOKEN;
+      eb=zero_run-1;
+    }
+  }
+  else if(_val<3){
+    token=OC_ONE_TOKEN+(_val-1<<1)+neg;
+    eb=0;
+  }
+  else if(_val<7){
+    token=OC_DCT_VAL_CAT2+_val-3;
+    eb=neg;
+  }
+  else if(_val<9){
+    token=OC_DCT_VAL_CAT3;
+    eb=_val-7+(neg<<1);
+  }
+  else if(_val<13){
+    token=OC_DCT_VAL_CAT4;
+    eb=_val-9+(neg<<2);
+  }
+  else if(_val<21){
+    token=OC_DCT_VAL_CAT5;
+    eb=_val-13+(neg<<3);
+  }
+  else if(_val<37){
+    token=OC_DCT_VAL_CAT6;
+    eb=_val-21+(neg<<4);
+  }
+  else if(_val<69){
+    token=OC_DCT_VAL_CAT7;
+    eb=_val-37+(neg<<5);
+  }
+  else{
+    token=OC_DCT_VAL_CAT8;
+    eb=_val-69+(neg<<9);
+  }
+  *_eb=eb;
+  return token;
+}
+
+/*Token logging to allow a few fragments of efficient rollback.
+  Late SKIP analysis is tied up in the tokenization process, so we need to be
+   able to undo a fragment's tokens on a whim.*/
+
+static const unsigned char OC_ZZI_HUFF_OFFSET[64]={
+   0,16,16,16,16,16,32,32,
+  32,32,32,32,32,32,32,48,
+  48,48,48,48,48,48,48,48,
+  48,48,48,48,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64
+};
+
+static int oc_token_bits(oc_enc_ctx *_enc,int _huffi,int _zzi,int _token){
+  return _enc->huff_codes[_huffi+OC_ZZI_HUFF_OFFSET[_zzi]][_token].nbits
+   +OC_DCT_TOKEN_EXTRA_BITS[_token];
+}
+
+static void oc_enc_tokenlog_checkpoint(oc_enc_ctx *_enc,
+ oc_token_checkpoint *_cp,int _pli,int _zzi){
+  _cp->pli=_pli;
+  _cp->zzi=_zzi;
+  _cp->eob_run=_enc->eob_run[_pli][_zzi];
+  _cp->ndct_tokens=_enc->ndct_tokens[_pli][_zzi];
+}
+
+void oc_enc_tokenlog_rollback(oc_enc_ctx *_enc,
+ const oc_token_checkpoint *_stack,int _n){
+  int i;
+  for(i=_n;i-->0;){
+    int pli;
+    int zzi;
+    pli=_stack[i].pli;
+    zzi=_stack[i].zzi;
+    _enc->eob_run[pli][zzi]=_stack[i].eob_run;
+    _enc->ndct_tokens[pli][zzi]=_stack[i].ndct_tokens;
+  }
+}
+
+static void oc_enc_token_log(oc_enc_ctx *_enc,
+ int _pli,int _zzi,int _token,int _eb){
+  ptrdiff_t ti;
+  ti=_enc->ndct_tokens[_pli][_zzi]++;
+  _enc->dct_tokens[_pli][_zzi][ti]=(unsigned char)_token;
+  _enc->extra_bits[_pli][_zzi][ti]=(ogg_uint16_t)_eb;
+}
+
+static void oc_enc_eob_log(oc_enc_ctx *_enc,
+ int _pli,int _zzi,int _run_count){
+  int token;
+  int eb;
+  token=oc_make_eob_token_full(_run_count,&eb);
+  oc_enc_token_log(_enc,_pli,_zzi,token,eb);
+}
+
+
+void oc_enc_tokenize_start(oc_enc_ctx *_enc){
+  memset(_enc->ndct_tokens,0,sizeof(_enc->ndct_tokens));
+  memset(_enc->eob_run,0,sizeof(_enc->eob_run));
+  memset(_enc->dct_token_offs,0,sizeof(_enc->dct_token_offs));
+  memset(_enc->dc_pred_last,0,sizeof(_enc->dc_pred_last));
+}
+
+typedef struct oc_quant_token oc_quant_token;
+
+/*A single node in the Viterbi trellis.
+  We maintain up to 2 of these per coefficient:
+    - A token to code if the value is zero (EOB, zero run, or combo token).
+    - A token to code if the value is not zero (DCT value token).*/
+struct oc_quant_token{
+  unsigned char next;
+  signed char   token;
+  ogg_int16_t   eb;
+  ogg_uint32_t  cost;
+  int           bits;
+  int           qc;
+};
+
+/*Tokenizes the AC coefficients, possibly adjusting the quantization, and then
+   dequantizes and de-zig-zags the result.
+  The DC coefficient is not preserved; it should be restored by the caller.*/
+int oc_enc_tokenize_ac(oc_enc_ctx *_enc,int _pli,ptrdiff_t _fragi,
+ ogg_int16_t *_qdct,const ogg_uint16_t *_dequant,const ogg_int16_t *_dct,
+ int _zzi,oc_token_checkpoint **_stack,int _acmin){
+  oc_token_checkpoint *stack;
+  ogg_int64_t          zflags;
+  ogg_int64_t          nzflags;
+  ogg_int64_t          best_flags;
+  ogg_uint32_t         d2_accum[64];
+  oc_quant_token       tokens[64][2];
+  ogg_uint16_t        *eob_run;
+  const unsigned char *dct_fzig_zag;
+  ogg_uint32_t         cost;
+  int                  bits;
+  int                  eob;
+  int                  token;
+  int                  eb;
+  int                  next;
+  int                  huffi;
+  int                  zzi;
+  int                  ti;
+  int                  zzj;
+  int                  qc;
+  huffi=_enc->huff_idxs[_enc->state.frame_type][1][_pli+1>>1];
+  eob_run=_enc->eob_run[_pli];
+  memset(tokens[0],0,sizeof(tokens[0]));
+  best_flags=nzflags=0;
+  zflags=1;
+  d2_accum[0]=0;
+  zzj=64;
+  for(zzi=OC_MINI(_zzi,63);zzi>0;zzi--){
+    ogg_int32_t  lambda;
+    ogg_uint32_t best_cost;
+    int          best_bits=best_bits;
+    int          best_next=best_next;
+    int          best_token=best_token;
+    int          best_eb=best_eb;
+    int          best_qc=best_qc;
+    int          flush_bits;
+    ogg_uint32_t d2;
+    int          dq;
+    int          e;
+    int          c;
+    int          s;
+    int          tj;
+    lambda=_enc->lambda;
+    qc=_qdct[zzi];
+    s=-(qc<0);
+    qc=qc+s^s;
+    c=_dct[OC_FZIG_ZAG[zzi]];
+    if(qc<=1){
+      ogg_uint32_t sum_d2;
+      int          nzeros;
+      int          dc_reserve;
+      /*The hard case: try a zero run.*/
+      if(!qc){
+        /*Skip runs that are already quantized to zeros.
+          If we considered each zero coefficient in turn, we might
+           theoretically find a better way to partition long zero runs (e.g.,
+           a run of > 17 zeros followed by a 1 might be better coded as a short
+           zero run followed by a combo token, rather than the longer zero
+           token followed by a 1 value token), but zeros are so common that
+           this becomes very computationally expensive (quadratic instead of
+           linear in the number of coefficients), for a marginal gain.*/
+        while(zzi>1&&!_qdct[zzi-1])zzi--;
+        /*The distortion of coefficients originally quantized to zero is
+           treated as zero (since we'll never quantize them to anything else).*/
+        d2=0;
+      }
+      else{
+        c=c+s^s;
+        d2=c*(ogg_int32_t)c;
+      }
+      eob=eob_run[zzi];
+      nzeros=zzj-zzi;
+      zzj&=63;
+      sum_d2=d2+d2_accum[zzj];
+      d2_accum[zzi]=sum_d2;
+      flush_bits=eob>0?oc_token_bits(_enc,huffi,zzi,oc_make_eob_token(eob)):0;
+      /*We reserve 1 spot for combo run tokens that start in the 1st AC stack
+         to ensure they can be extended to include the DC coefficient if
+         necessary; this greatly simplifies stack-rewriting later on.*/
+      dc_reserve=zzi+62>>6;
+      best_cost=0xFFFFFFFF;
+      for(;;){
+        if(nzflags>>zzj&1){
+          int cat;
+          int val;
+          int val_s;
+          int zzk;
+          int tk;
+          next=tokens[zzj][1].next;
+          tk=next&1;
+          zzk=next>>1;
+          /*Try a pure zero run to this point.*/
+          cat=nzeros+55>>6;
+          token=OC_DCT_SHORT_ZRL_TOKEN+cat;
+          bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+          d2=sum_d2-d2_accum[zzj];
+          cost=d2+lambda*bits+tokens[zzj][1].cost;
+          if(cost<=best_cost){
+            best_next=(zzj<<1)+1;
+            best_token=token;
+            best_eb=nzeros-1;
+            best_cost=cost;
+            best_bits=bits+tokens[zzj][1].bits;
+            best_qc=0;
+          }
+          if(nzeros<16+dc_reserve){
+            val=_qdct[zzj];
+            val_s=-(val<0);
+            val=val+val_s^val_s;
+            if(val<=2){
+              /*Try a +/- 1 combo token.*/
+              if(nzeros<6){
+                token=OC_DCT_RUN_CAT1A+nzeros-1;
+                eb=-val_s;
+              }
+              else{
+                cat=nzeros+54>>6;
+                token=OC_DCT_RUN_CAT1B+cat;
+                eb=(-val_s<<cat+2)+nzeros-6-(cat<<2);
+              }
+              e=(_dct[OC_FZIG_ZAG[zzj]]+val_s^val_s)-_dequant[zzj];
+              d2=e*(ogg_int32_t)e+sum_d2-d2_accum[zzj];
+              bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+              cost=d2+lambda*bits+tokens[zzk][tk].cost;
+              if(cost<=best_cost){
+                best_next=next;
+                best_token=token;
+                best_eb=eb;
+                best_cost=cost;
+                best_bits=bits+tokens[zzk][tk].bits;
+                best_qc=1+val_s^val_s;
+              }
+            }
+            if(nzeros<2+dc_reserve&&2<=val&&val<=4){
+              /*Try a +/- 2/3 combo token.*/
+              cat=nzeros>>1;
+              token=OC_DCT_RUN_CAT2A+cat;
+              bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+              val=2+((val+val_s^val_s)>2);
+              e=(_dct[OC_FZIG_ZAG[zzj]]+val_s^val_s)-_dequant[zzj]*val;
+              d2=e*(ogg_int32_t)e+sum_d2-d2_accum[zzj];
+              cost=d2+lambda*bits+tokens[zzk][tk].cost;
+              if(cost<=best_cost){
+                best_cost=cost;
+                best_bits=bits+tokens[zzk][tk].bits;
+                best_next=next;
+                best_token=token;
+                best_eb=(-val_s<<1+cat)+(val-2<<cat)+(nzeros-1>>1);
+                best_qc=val+val_s^val_s;
+              }
+            }
+          }
+          /*zzj can't be coded as a zero, so stop trying to extend the run.*/
+          if(!(zflags>>zzj&1))break;
+        }
+        /*We could try to consider _all_ potentially non-zero coefficients, but
+           if we already found a bunch of them not worth coding, it's fairly
+           unlikely they would now be worth coding from this position; skipping
+           them saves a lot of work.*/
+        zzj=(tokens[zzj][0].next>>1)-(tokens[zzj][0].qc!=0)&63;
+        if(zzj==0){
+          /*We made it all the way to the end of the block; try an EOB token.*/
+          if(eob<4095){
+            bits=oc_token_bits(_enc,huffi,zzi,oc_make_eob_token(eob+1))
+             -flush_bits;
+          }
+          else bits=oc_token_bits(_enc,huffi,zzi,OC_DCT_EOB1_TOKEN);
+          cost=sum_d2+bits*lambda;
+          /*If the best route so far is still a pure zero run to the end of the
+             block, force coding it as an EOB.
+            Even if it's not optimal for this block, it has a good chance of
+             getting combined with an EOB token from subsequent blocks, saving
+             bits overall.*/
+          if(cost<=best_cost||best_token<=OC_DCT_ZRL_TOKEN&&zzi+best_eb==63){
+            best_next=0;
+            /*This token is just a marker; in reality we may not emit any
+               tokens, but update eob_run[] instead.*/
+            best_token=OC_DCT_EOB1_TOKEN;
+            best_eb=0;
+            best_cost=cost;
+            best_bits=bits;
+            best_qc=0;
+          }
+          break;
+        }
+        nzeros=zzj-zzi;
+      }
+      tokens[zzi][0].next=(unsigned char)best_next;
+      tokens[zzi][0].token=(signed char)best_token;
+      tokens[zzi][0].eb=(ogg_int16_t)best_eb;
+      tokens[zzi][0].cost=best_cost;
+      tokens[zzi][0].bits=best_bits;
+      tokens[zzi][0].qc=best_qc;
+      zflags|=(ogg_int64_t)1<<zzi;
+      if(qc){
+        dq=_dequant[zzi];
+        if(zzi<_acmin)lambda=0;
+        e=dq-c;
+        d2=e*(ogg_int32_t)e;
+        token=OC_ONE_TOKEN-s;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        zzj=zzi+1&63;
+        tj=best_flags>>zzj&1;
+        next=(zzj<<1)+tj;
+        tokens[zzi][1].next=(unsigned char)next;
+        tokens[zzi][1].token=(signed char)token;
+        tokens[zzi][1].eb=0;
+        tokens[zzi][1].cost=d2+lambda*bits+tokens[zzj][tj].cost;
+        tokens[zzi][1].bits=bits+tokens[zzj][tj].bits;
+        tokens[zzi][1].qc=1+s^s;
+        nzflags|=(ogg_int64_t)1<<zzi;
+        best_flags|=
+         (ogg_int64_t)(tokens[zzi][1].cost<tokens[zzi][0].cost)<<zzi;
+      }
+    }
+    else{
+      eob=eob_run[zzi];
+      if(zzi<_acmin)lambda=0;
+      c=c+s^s;
+      dq=_dequant[zzi];
+      /*No zero run can extend past this point.*/
+      d2_accum[zzi]=0;
+      flush_bits=eob>0?oc_token_bits(_enc,huffi,zzi,oc_make_eob_token(eob)):0;
+      if(qc<=2){
+        e=2*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_TWO_TOKEN-s;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e-=dq;
+        d2=e*(ogg_int32_t)e;
+        token=OC_ONE_TOKEN-s;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<=best_cost){
+          best_token=token;
+          best_bits=bits;
+          best_cost=cost;
+          qc--;
+        }
+        best_eb=0;
+      }
+      else if(qc<=3){
+        e=3*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT2;
+        best_eb=-s;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e-=dq;
+        d2=e*(ogg_int32_t)e;
+        token=OC_TWO_TOKEN-s;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<=best_cost){
+          best_token=token;
+          best_eb=0;
+          best_bits=bits;
+          best_cost=cost;
+          qc--;
+        }
+      }
+      else if(qc<=6){
+        e=qc*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT2+qc-3;
+        best_eb=-s;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e-=dq;
+        d2=e*(ogg_int32_t)e;
+        token=best_token-1;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<=best_cost){
+          best_token=token;
+          best_bits=bits;
+          best_cost=cost;
+          qc--;
+        }
+      }
+      else if(qc<=8){
+        e=qc*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT3;
+        best_eb=(-s<<1)+qc-7;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e=6*dq-c;
+        d2=e*(ogg_int32_t)e;
+        token=OC_DCT_VAL_CAT2+3;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<=best_cost){
+          best_token=token;
+          best_eb=-s;
+          best_bits=bits;
+          best_cost=cost;
+          qc=6;
+        }
+      }
+      else if(qc<=12){
+        e=qc*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT4;
+        best_eb=(-s<<2)+qc-9;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e=8*dq-c;
+        d2=e*(ogg_int32_t)e;
+        token=best_token-1;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<=best_cost){
+          best_token=token;
+          best_eb=(-s<<1)+1;
+          best_bits=bits;
+          best_cost=cost;
+          qc=8;
+        }
+      }
+      else if(qc<=20){
+        e=qc*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT5;
+        best_eb=(-s<<3)+qc-13;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e=12*dq-c;
+        d2=e*(ogg_int32_t)e;
+        token=best_token-1;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<=best_cost){
+          best_token=token;
+          best_eb=(-s<<2)+3;
+          best_bits=bits;
+          best_cost=cost;
+          qc=12;
+        }
+      }
+      else if(qc<=36){
+        e=qc*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT6;
+        best_eb=(-s<<4)+qc-21;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e=20*dq-c;
+        d2=e*(ogg_int32_t)e;
+        token=best_token-1;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<=best_cost){
+          best_token=token;
+          best_eb=(-s<<3)+7;
+          best_bits=bits;
+          best_cost=cost;
+          qc=20;
+        }
+      }
+      else if(qc<=68){
+        e=qc*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT7;
+        best_eb=(-s<<5)+qc-37;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e=36*dq-c;
+        d2=e*(ogg_int32_t)e;
+        token=best_token-1;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<best_cost){
+          best_token=token;
+          best_eb=(-s<<4)+15;
+          best_bits=bits;
+          best_cost=cost;
+          qc=36;
+        }
+      }
+      else{
+        e=qc*dq-c;
+        d2=e*(ogg_int32_t)e;
+        best_token=OC_DCT_VAL_CAT8;
+        best_eb=(-s<<9)+qc-69;
+        best_bits=flush_bits+oc_token_bits(_enc,huffi,zzi,best_token);
+        best_cost=d2+lambda*best_bits;
+        e=68*dq-c;
+        d2=e*(ogg_int32_t)e;
+        token=best_token-1;
+        bits=flush_bits+oc_token_bits(_enc,huffi,zzi,token);
+        cost=d2+lambda*bits;
+        if(cost<best_cost){
+          best_token=token;
+          best_eb=(-s<<5)+31;
+          best_bits=bits;
+          best_cost=cost;
+          qc=68;
+        }
+      }
+      zzj=zzi+1&63;
+      tj=best_flags>>zzj&1;
+      next=(zzj<<1)+tj;
+      tokens[zzi][1].next=(unsigned char)next;
+      tokens[zzi][1].token=(signed char)best_token;
+      tokens[zzi][1].eb=best_eb;
+      tokens[zzi][1].cost=best_cost+tokens[zzj][tj].cost;
+      tokens[zzi][1].bits=best_bits+tokens[zzj][tj].bits;
+      tokens[zzi][1].qc=qc+s^s;
+      nzflags|=(ogg_int64_t)1<<zzi;
+      best_flags|=(ogg_int64_t)1<<zzi;
+    }
+    zzj=zzi;
+  }
+  /*Emit the tokens from the best path through the trellis.*/
+  stack=*_stack;
+  /*We blow away the first entry here so that things vectorize better.
+    The DC coefficient is not actually stored in the array yet.*/
+  for(zzi=0;zzi<64;zzi++)_qdct[zzi]=0;
+  dct_fzig_zag=_enc->state.opt_data.dct_fzig_zag;
+  zzi=1;
+  ti=best_flags>>1&1;
+  bits=tokens[zzi][ti].bits;
+  do{
+    oc_enc_tokenlog_checkpoint(_enc,stack++,_pli,zzi);
+    eob=eob_run[zzi];
+    if(tokens[zzi][ti].token<OC_NDCT_EOB_TOKEN_MAX){
+      if(++eob>=4095){
+        oc_enc_eob_log(_enc,_pli,zzi,eob);
+        eob=0;
+      }
+      eob_run[zzi]=eob;
+      /*We don't include the actual EOB cost for this block in the return value.
+        It will be paid for by the fragment that terminates the EOB run.*/
+      bits-=tokens[zzi][ti].bits;
+      zzi=_zzi;
+      break;
+    }
+    /*Emit pending EOB run if any.*/
+    if(eob>0){
+      oc_enc_eob_log(_enc,_pli,zzi,eob);
+      eob_run[zzi]=0;
+    }
+    oc_enc_token_log(_enc,_pli,zzi,tokens[zzi][ti].token,tokens[zzi][ti].eb);
+    next=tokens[zzi][ti].next;
+    qc=tokens[zzi][ti].qc;
+    zzj=(next>>1)-1&63;
+    /*TODO: It may be worth saving the dequantized coefficient in the trellis
+       above; we had to compute it to measure the error anyway.*/
+    _qdct[dct_fzig_zag[zzj]]=(ogg_int16_t)(qc*(int)_dequant[zzj]);
+    zzi=next>>1;
+    ti=next&1;
+  }
+  while(zzi);
+  *_stack=stack;
+  return bits;
+}
+
+void oc_enc_pred_dc_frag_rows(oc_enc_ctx *_enc,
+ int _pli,int _fragy0,int _frag_yend){
+  const oc_fragment_plane *fplane;
+  const oc_fragment       *frags;
+  ogg_int16_t             *frag_dc;
+  ptrdiff_t                fragi;
+  int                     *pred_last;
+  int                      nhfrags;
+  int                      fragx;
+  int                      fragy;
+  fplane=_enc->state.fplanes+_pli;
+  frags=_enc->state.frags;
+  frag_dc=_enc->frag_dc;
+  pred_last=_enc->dc_pred_last[_pli];
+  nhfrags=fplane->nhfrags;
+  fragi=fplane->froffset+_fragy0*nhfrags;
+  for(fragy=_fragy0;fragy<_frag_yend;fragy++){
+    if(fragy==0){
+      /*For the first row, all of the cases reduce to just using the previous
+         predictor for the same reference frame.*/
+      for(fragx=0;fragx<nhfrags;fragx++,fragi++){
+        if(frags[fragi].coded){
+          int ref;
+          ref=OC_FRAME_FOR_MODE(frags[fragi].mb_mode);
+          frag_dc[fragi]=(ogg_int16_t)(frags[fragi].dc-pred_last[ref]);
+          pred_last[ref]=frags[fragi].dc;
+        }
+      }
+    }
+    else{
+      const oc_fragment *u_frags;
+      int                l_ref;
+      int                ul_ref;
+      int                u_ref;
+      u_frags=frags-nhfrags;
+      l_ref=-1;
+      ul_ref=-1;
+      u_ref=u_frags[fragi].coded?OC_FRAME_FOR_MODE(u_frags[fragi].mb_mode):-1;
+      for(fragx=0;fragx<nhfrags;fragx++,fragi++){
+        int ur_ref;
+        if(fragx+1>=nhfrags)ur_ref=-1;
+        else{
+          ur_ref=u_frags[fragi+1].coded?
+           OC_FRAME_FOR_MODE(u_frags[fragi+1].mb_mode):-1;
+        }
+        if(frags[fragi].coded){
+          int pred;
+          int ref;
+          ref=OC_FRAME_FOR_MODE(frags[fragi].mb_mode);
+          /*We break out a separate case based on which of our neighbors use
+             the same reference frames.
+            This is somewhat faster than trying to make a generic case which
+             handles all of them, since it reduces lots of poorly predicted
+             jumps to one switch statement, and also lets a number of the
+             multiplications be optimized out by strength reduction.*/
+          switch((l_ref==ref)|(ul_ref==ref)<<1|
+           (u_ref==ref)<<2|(ur_ref==ref)<<3){
+            default:pred=pred_last[ref];break;
+            case  1:
+            case  3:pred=frags[fragi-1].dc;break;
+            case  2:pred=u_frags[fragi-1].dc;break;
+            case  4:
+            case  6:
+            case 12:pred=u_frags[fragi].dc;break;
+            case  5:pred=(frags[fragi-1].dc+u_frags[fragi].dc)/2;break;
+            case  8:pred=u_frags[fragi+1].dc;break;
+            case  9:
+            case 11:
+            case 13:{
+              pred=(75*frags[fragi-1].dc+53*u_frags[fragi+1].dc)/128;
+            }break;
+            case 10:pred=(u_frags[fragi-1].dc+u_frags[fragi+1].dc)/2;break;
+            case 14:{
+              pred=(3*(u_frags[fragi-1].dc+u_frags[fragi+1].dc)
+               +10*u_frags[fragi].dc)/16;
+            }break;
+            case  7:
+            case 15:{
+              int p0;
+              int p1;
+              int p2;
+              p0=frags[fragi-1].dc;
+              p1=u_frags[fragi-1].dc;
+              p2=u_frags[fragi].dc;
+              pred=(29*(p0+p2)-26*p1)/32;
+              if(abs(pred-p2)>128)pred=p2;
+              else if(abs(pred-p0)>128)pred=p0;
+              else if(abs(pred-p1)>128)pred=p1;
+            }break;
+          }
+          frag_dc[fragi]=(ogg_int16_t)(frags[fragi].dc-pred);
+          pred_last[ref]=frags[fragi].dc;
+          l_ref=ref;
+        }
+        else l_ref=-1;
+        ul_ref=u_ref;
+        u_ref=ur_ref;
+      }
+    }
+  }
+}
+
+void oc_enc_tokenize_dc_frag_list(oc_enc_ctx *_enc,int _pli,
+ const ptrdiff_t *_coded_fragis,ptrdiff_t _ncoded_fragis,
+ int _prev_ndct_tokens1,int _prev_eob_run1){
+  const ogg_int16_t *frag_dc;
+  ptrdiff_t          fragii;
+  unsigned char     *dct_tokens0;
+  unsigned char     *dct_tokens1;
+  ogg_uint16_t      *extra_bits0;
+  ogg_uint16_t      *extra_bits1;
+  ptrdiff_t          ti0;
+  ptrdiff_t          ti1r;
+  ptrdiff_t          ti1w;
+  int                eob_run0;
+  int                eob_run1;
+  int                neobs1;
+  int                token;
+  int                eb;
+  int                token1=token1;
+  int                eb1=eb1;
+  /*Return immediately if there are no coded fragments; otherwise we'd flush
+     any trailing EOB run into the AC 1 list and never read it back out.*/
+  if(_ncoded_fragis<=0)return;
+  frag_dc=_enc->frag_dc;
+  dct_tokens0=_enc->dct_tokens[_pli][0];
+  dct_tokens1=_enc->dct_tokens[_pli][1];
+  extra_bits0=_enc->extra_bits[_pli][0];
+  extra_bits1=_enc->extra_bits[_pli][1];
+  ti0=_enc->ndct_tokens[_pli][0];
+  ti1w=ti1r=_prev_ndct_tokens1;
+  eob_run0=_enc->eob_run[_pli][0];
+  /*Flush any trailing EOB run for the 1st AC coefficient.
+    This is needed to allow us to track tokens to the end of the list.*/
+  eob_run1=_enc->eob_run[_pli][1];
+  if(eob_run1>0)oc_enc_eob_log(_enc,_pli,1,eob_run1);
+  /*If there was an active EOB run at the start of the 1st AC stack, read it
+     in and decode it.*/
+  if(_prev_eob_run1>0){
+    token1=dct_tokens1[ti1r];
+    eb1=extra_bits1[ti1r];
+    ti1r++;
+    eob_run1=oc_decode_eob_token(token1,eb1);
+    /*Consume the portion of the run that came before these fragments.*/
+    neobs1=eob_run1-_prev_eob_run1;
+  }
+  else eob_run1=neobs1=0;
+  for(fragii=0;fragii<_ncoded_fragis;fragii++){
+    int val;
+    /*All tokens in the 1st AC coefficient stack are regenerated as the DC
+       coefficients are produced.
+      This can be done in-place; stack 1 cannot get larger.*/
+    if(!neobs1){
+      /*There's no active EOB run in stack 1; read the next token.*/
+      token1=dct_tokens1[ti1r];
+      eb1=extra_bits1[ti1r];
+      ti1r++;
+      if(token1<OC_NDCT_EOB_TOKEN_MAX){
+        neobs1=oc_decode_eob_token(token1,eb1);
+        /*It's an EOB run; add it to the current (inactive) one.
+          Because we may have moved entries to stack 0, we may have an
+           opportunity to merge two EOB runs in stack 1.*/
+        eob_run1+=neobs1;
+      }
+    }
+    val=frag_dc[_coded_fragis[fragii]];
+    if(val){
+      /*There was a non-zero DC value, so there's no alteration to stack 1
+         for this fragment; just code the stack 0 token.*/
+      /*Flush any pending EOB run.*/
+      if(eob_run0>0){
+        token=oc_make_eob_token_full(eob_run0,&eb);
+        dct_tokens0[ti0]=(unsigned char)token;
+        extra_bits0[ti0]=(ogg_uint16_t)eb;
+        ti0++;
+        eob_run0=0;
+      }
+      token=oc_make_dct_token_full(0,0,val,&eb);
+      dct_tokens0[ti0]=(unsigned char)token;
+      extra_bits0[ti0]=(ogg_uint16_t)eb;
+      ti0++;
+    }
+    else{
+      /*Zero DC value; that means the entry in stack 1 might need to be coded
+         from stack 0.
+        This requires a stack 1 fixup.*/
+      if(neobs1>0){
+        /*We're in the middle of an active EOB run in stack 1.
+          Move it to stack 0.*/
+        if(++eob_run0>=4095){
+          token=oc_make_eob_token_full(eob_run0,&eb);
+          dct_tokens0[ti0]=(unsigned char)token;
+          extra_bits0[ti0]=(ogg_uint16_t)eb;
+          ti0++;
+          eob_run0=0;
+        }
+        eob_run1--;
+      }
+      else{
+        /*No active EOB run in stack 1, so we can't extend one in stack 0.
+          Flush it if we've got it.*/
+        if(eob_run0>0){
+          token=oc_make_eob_token_full(eob_run0,&eb);
+          dct_tokens0[ti0]=(unsigned char)token;
+          extra_bits0[ti0]=(ogg_uint16_t)eb;
+          ti0++;
+          eob_run0=0;
+        }
+        /*Stack 1 token is one of: a pure zero run token, a single
+           coefficient token, or a zero run/coefficient combo token.
+          A zero run token is expanded and moved to token stack 0, and the
+           stack 1 entry dropped.
+          A single coefficient value may be transformed into combo token that
+           is moved to stack 0, or if it cannot be combined, it is left alone
+           and a single length-1 zero run is emitted in stack 0.
+          A combo token is extended and moved to stack 0.
+          During AC coding, we restrict the run lengths on combo tokens for
+           stack 1 to guarantee we can extend them.*/
+        switch(token1){
+          case OC_DCT_SHORT_ZRL_TOKEN:{
+            if(eb1<7){
+              dct_tokens0[ti0]=OC_DCT_SHORT_ZRL_TOKEN;
+              extra_bits0[ti0]=(ogg_uint16_t)(eb1+1);
+              ti0++;
+              /*Don't write the AC coefficient back out.*/
+              continue;
+            }
+            /*Fall through.*/
+          }
+          case OC_DCT_ZRL_TOKEN:{
+            dct_tokens0[ti0]=OC_DCT_ZRL_TOKEN;
+            extra_bits0[ti0]=(ogg_uint16_t)(eb1+1);
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+          case OC_ONE_TOKEN:
+          case OC_MINUS_ONE_TOKEN:{
+            dct_tokens0[ti0]=OC_DCT_RUN_CAT1A;
+            extra_bits0[ti0]=(ogg_uint16_t)(token1-OC_ONE_TOKEN);
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+          case OC_TWO_TOKEN:
+          case OC_MINUS_TWO_TOKEN:{
+            dct_tokens0[ti0]=OC_DCT_RUN_CAT2A;
+            extra_bits0[ti0]=(ogg_uint16_t)(token1-OC_TWO_TOKEN<<1);
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+          case OC_DCT_VAL_CAT2:{
+            dct_tokens0[ti0]=OC_DCT_RUN_CAT2A;
+            extra_bits0[ti0]=(ogg_uint16_t)((eb1<<1)+1);
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+          case OC_DCT_RUN_CAT1A:
+          case OC_DCT_RUN_CAT1A+1:
+          case OC_DCT_RUN_CAT1A+2:
+          case OC_DCT_RUN_CAT1A+3:{
+            dct_tokens0[ti0]=(unsigned char)(token1+1);
+            extra_bits0[ti0]=(ogg_uint16_t)eb1;
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+          case OC_DCT_RUN_CAT1A+4:{
+            dct_tokens0[ti0]=OC_DCT_RUN_CAT1B;
+            extra_bits0[ti0]=(ogg_uint16_t)(eb1<<2);
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+          case OC_DCT_RUN_CAT1B:{
+            if((eb1&3)<3){
+              dct_tokens0[ti0]=OC_DCT_RUN_CAT1B;
+              extra_bits0[ti0]=(ogg_uint16_t)(eb1+1);
+              ti0++;
+              /*Don't write the AC coefficient back out.*/
+              continue;
+            }
+            eb1=((eb1&4)<<1)-1;
+            /*Fall through.*/
+          }
+          case OC_DCT_RUN_CAT1C:{
+            dct_tokens0[ti0]=OC_DCT_RUN_CAT1C;
+            extra_bits0[ti0]=(ogg_uint16_t)(eb1+1);
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+          case OC_DCT_RUN_CAT2A:{
+            eb1=(eb1<<1)-1;
+            /*Fall through.*/
+          }
+          case OC_DCT_RUN_CAT2B:{
+            dct_tokens0[ti0]=OC_DCT_RUN_CAT2B;
+            extra_bits0[ti0]=(ogg_uint16_t)(eb1+1);
+            ti0++;
+            /*Don't write the AC coefficient back out.*/
+          }continue;
+        }
+        /*We can't merge tokens, write a short zero run and keep going.*/
+        dct_tokens0[ti0]=OC_DCT_SHORT_ZRL_TOKEN;
+        extra_bits0[ti0]=0;
+        ti0++;
+      }
+    }
+    if(!neobs1){
+      /*Flush any (inactive) EOB run.*/
+      if(eob_run1>0){
+        token=oc_make_eob_token_full(eob_run1,&eb);
+        dct_tokens1[ti1w]=(unsigned char)token;
+        extra_bits1[ti1w]=(ogg_uint16_t)eb;
+        ti1w++;
+        eob_run1=0;
+      }
+      /*There's no active EOB run, so log the current token.*/
+      dct_tokens1[ti1w]=(unsigned char)token1;
+      extra_bits1[ti1w]=(ogg_uint16_t)eb1;
+      ti1w++;
+    }
+    else{
+      /*Otherwise consume one EOB from the current run.*/
+      neobs1--;
+      /*If we have more than 4095 EOBs outstanding in stack1, flush the run.*/
+      if(eob_run1-neobs1>=4095){
+        token=oc_make_eob_token_full(4095,&eb);
+        dct_tokens1[ti1w]=(unsigned char)token;
+        extra_bits1[ti1w]=(ogg_uint16_t)eb;
+        ti1w++;
+        eob_run1-=4095;
+      }
+    }
+  }
+  /*Save the current state.*/
+  _enc->ndct_tokens[_pli][0]=ti0;
+  _enc->ndct_tokens[_pli][1]=ti1w;
+  _enc->eob_run[_pli][0]=eob_run0;
+  _enc->eob_run[_pli][1]=eob_run1;
+}
+
+/*Final EOB run welding.*/
+void oc_enc_tokenize_finish(oc_enc_ctx *_enc){
+  int pli;
+  int zzi;
+  /*Emit final EOB runs.*/
+  for(pli=0;pli<3;pli++)for(zzi=0;zzi<64;zzi++){
+    int eob_run;
+    eob_run=_enc->eob_run[pli][zzi];
+    if(eob_run>0)oc_enc_eob_log(_enc,pli,zzi,eob_run);
+  }
+  /*Merge the final EOB run of one token list with the start of the next, if
+     possible.*/
+  for(zzi=0;zzi<64;zzi++)for(pli=0;pli<3;pli++){
+    int       old_tok1;
+    int       old_tok2;
+    int       old_eb1;
+    int       old_eb2;
+    int       new_tok;
+    int       new_eb;
+    int       zzj;
+    int       plj;
+    ptrdiff_t ti=ti;
+    int       run_count;
+    /*Make sure this coefficient has tokens at all.*/
+    if(_enc->ndct_tokens[pli][zzi]<=0)continue;
+    /*Ensure the first token is an EOB run.*/
+    old_tok2=_enc->dct_tokens[pli][zzi][0];
+    if(old_tok2>=OC_NDCT_EOB_TOKEN_MAX)continue;
+    /*Search for a previous coefficient that has any tokens at all.*/
+    old_tok1=OC_NDCT_EOB_TOKEN_MAX;
+    for(zzj=zzi,plj=pli;zzj>=0;zzj--){
+      while(plj-->0){
+        ti=_enc->ndct_tokens[plj][zzj]-1;
+        if(ti>=_enc->dct_token_offs[plj][zzj]){
+          old_tok1=_enc->dct_tokens[plj][zzj][ti];
+          break;
+        }
+      }
+      if(plj>=0)break;
+      plj=3;
+    }
+    /*Ensure its last token was an EOB run.*/
+    if(old_tok1>=OC_NDCT_EOB_TOKEN_MAX)continue;
+    /*Pull off the associated extra bits, if any, and decode the runs.*/
+    old_eb1=_enc->extra_bits[plj][zzj][ti];
+    old_eb2=_enc->extra_bits[pli][zzi][0];
+    run_count=oc_decode_eob_token(old_tok1,old_eb1)
+     +oc_decode_eob_token(old_tok2,old_eb2);
+    /*We can't possibly combine these into one run.
+      It might be possible to split them more optimally, but we'll just leave
+       them as-is.*/
+    if(run_count>=4096)continue;
+    /*We CAN combine them into one run.*/
+    new_tok=oc_make_eob_token_full(run_count,&new_eb);
+    _enc->dct_tokens[plj][zzj][ti]=(unsigned char)new_tok;
+    _enc->extra_bits[plj][zzj][ti]=(ogg_uint16_t)new_eb;
+    _enc->dct_token_offs[pli][zzi]++;
+  }
+}
diff --git a/lib/x86/mmxencfrag.c b/lib/x86/mmxencfrag.c
new file mode 100644 (file)
index 0000000..c79ff01
--- /dev/null
@@ -0,0 +1,900 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+  last mod: $Id: dsp_mmx.c 14579 2008-03-12 06:42:40Z xiphmont $
+
+ ********************************************************************/
+#include <stddef.h>
+#include "x86enc.h"
+
+#if defined(OC_X86_ASM)
+
+unsigned oc_enc_frag_sad_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride){
+  ptrdiff_t ystride3;
+  ptrdiff_t ret;
+  __asm__ __volatile__(
+    /*Load the first 4 rows of each block.*/
+    "movq (%[src]),%%mm0\n\t"
+    "movq (%[ref]),%%mm1\n\t"
+    "movq (%[src],%[ystride]),%%mm2\n\t"
+    "movq (%[ref],%[ystride]),%%mm3\n\t"
+    "lea (%[ystride],%[ystride],2),%[ystride3]\n\t"
+    "movq (%[src],%[ystride],2),%%mm4\n\t"
+    "movq (%[ref],%[ystride],2),%%mm5\n\t"
+    "movq (%[src],%[ystride3]),%%mm6\n\t"
+    "movq (%[ref],%[ystride3]),%%mm7\n\t"
+    /*Compute their SADs and add them in %%mm0*/
+    "psadbw %%mm1,%%mm0\n\t"
+    "psadbw %%mm3,%%mm2\n\t"
+    "lea (%[src],%[ystride],4),%[src]\n\t"
+    "paddw %%mm2,%%mm0\n\t"
+    "lea (%[ref],%[ystride],4),%[ref]\n\t"
+    /*Load the next 3 rows as registers become available.*/
+    "movq (%[src]),%%mm2\n\t"
+    "movq (%[ref]),%%mm3\n\t"
+    "psadbw %%mm5,%%mm4\n\t"
+    "psadbw %%mm7,%%mm6\n\t"
+    "paddw %%mm4,%%mm0\n\t"
+    "movq (%[ref],%[ystride]),%%mm5\n\t"
+    "movq (%[src],%[ystride]),%%mm4\n\t"
+    "paddw %%mm6,%%mm0\n\t"
+    "movq (%[ref],%[ystride],2),%%mm7\n\t"
+    "movq (%[src],%[ystride],2),%%mm6\n\t"
+    /*Start adding their SADs to %%mm0*/
+    "psadbw %%mm3,%%mm2\n\t"
+    "psadbw %%mm5,%%mm4\n\t"
+    "paddw %%mm2,%%mm0\n\t"
+    "psadbw %%mm7,%%mm6\n\t"
+    /*Load last row as registers become available.*/
+    "movq (%[src],%[ystride3]),%%mm2\n\t"
+    "movq (%[ref],%[ystride3]),%%mm3\n\t"
+    /*And finish adding up their SADs.*/
+    "paddw %%mm4,%%mm0\n\t"
+    "psadbw %%mm3,%%mm2\n\t"
+    "paddw %%mm6,%%mm0\n\t"
+    "paddw %%mm2,%%mm0\n\t"
+    "movd %%mm0,%[ret]\n\t"
+    :[ret]"=a"(ret),[src]"+%r"(_src),[ref]"+r"(_ref),[ystride3]"=&r"(ystride3)
+    :[ystride]"r"((ptrdiff_t)_ystride)
+  );
+  return (unsigned)ret;
+}
+
+unsigned oc_enc_frag_sad_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh){
+  /*Early termination is for suckers.*/
+  return oc_enc_frag_sad_mmxext(_src,_ref,_ystride);
+}
+
+/*Assumes the first two rows of %[ref1] and %[ref2] are in %%mm0...%%mm3, the
+   first two rows of %[src] are in %%mm4,%%mm5, and {1}x8 is in %%mm7.
+  We pre-load the next two rows of data as registers become available.*/
+#define OC_SAD2_LOOP \
+ "#OC_SAD2_LOOP\n\t" \
+ /*We want to compute (%%mm0+%%mm1>>1) on unsigned bytes without overflow, but \
+    pavgb computes (%%mm0+%%mm1+1>>1). \
+   The latter is exactly 1 too large when the low bit of two corresponding \
+    bytes is only set in one of them. \
+   Therefore we pxor the operands, pand to mask out the low bits, and psubb to \
+    correct the output of pavgb.*/ \
+ "movq %%mm0,%%mm6\n\t" \
+ "lea (%[ref1],%[ystride],2),%[ref1]\n\t" \
+ "pxor %%mm1,%%mm0\n\t" \
+ "pavgb %%mm1,%%mm6\n\t" \
+ "lea (%[ref2],%[ystride],2),%[ref2]\n\t" \
+ "movq %%mm2,%%mm1\n\t" \
+ "pand %%mm7,%%mm0\n\t" \
+ "pavgb %%mm3,%%mm2\n\t" \
+ "pxor %%mm3,%%mm1\n\t" \
+ "movq (%[ref2],%[ystride]),%%mm3\n\t" \
+ "psubb %%mm0,%%mm6\n\t" \
+ "movq (%[ref1]),%%mm0\n\t" \
+ "pand %%mm7,%%mm1\n\t" \
+ "psadbw %%mm6,%%mm4\n\t" \
+ "movd %[ret],%%mm6\n\t" \
+ "psubb %%mm1,%%mm2\n\t" \
+ "movq (%[ref2]),%%mm1\n\t" \
+ "lea (%[src],%[ystride],2),%[src]\n\t" \
+ "psadbw %%mm2,%%mm5\n\t" \
+ "movq (%[ref1],%[ystride]),%%mm2\n\t" \
+ "paddw %%mm4,%%mm5\n\t" \
+ "movq (%[src]),%%mm4\n\t" \
+ "paddw %%mm5,%%mm6\n\t" \
+ "movq (%[src],%[ystride]),%%mm5\n\t" \
+ "movd %%mm6,%[ret]\n\t" \
+
+/*Same as above, but does not pre-load the next two rows.*/
+#define OC_SAD2_TAIL \
+ "#OC_SAD2_TAIL\n\t" \
+ "movq %%mm0,%%mm6\n\t" \
+ "pavgb %%mm1,%%mm0\n\t" \
+ "pxor %%mm1,%%mm6\n\t" \
+ "movq %%mm2,%%mm1\n\t" \
+ "pand %%mm7,%%mm6\n\t" \
+ "pavgb %%mm3,%%mm2\n\t" \
+ "pxor %%mm3,%%mm1\n\t" \
+ "psubb %%mm6,%%mm0\n\t" \
+ "pand %%mm7,%%mm1\n\t" \
+ "psadbw %%mm0,%%mm4\n\t" \
+ "psubb %%mm1,%%mm2\n\t" \
+ "movd %[ret],%%mm6\n\t" \
+ "psadbw %%mm2,%%mm5\n\t" \
+ "paddw %%mm4,%%mm5\n\t" \
+ "paddw %%mm5,%%mm6\n\t" \
+ "movd %%mm6,%[ret]\n\t" \
+
+unsigned oc_enc_frag_sad2_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh){
+  ptrdiff_t ret;
+  __asm__ __volatile__(
+    "movq (%[ref1]),%%mm0\n\t"
+    "movq (%[ref2]),%%mm1\n\t"
+    "movq (%[ref1],%[ystride]),%%mm2\n\t"
+    "movq (%[ref2],%[ystride]),%%mm3\n\t"
+    "xor %[ret],%[ret]\n\t"
+    "movq (%[src]),%%mm4\n\t"
+    "pxor %%mm7,%%mm7\n\t"
+    "pcmpeqb %%mm6,%%mm6\n\t"
+    "movq (%[src],%[ystride]),%%mm5\n\t"
+    "psubb %%mm6,%%mm7\n\t"
+    OC_SAD2_LOOP
+    OC_SAD2_LOOP
+    OC_SAD2_LOOP
+    OC_SAD2_TAIL
+    :[ret]"=&a"(ret),[src]"+r"(_src),[ref1]"+%r"(_ref1),[ref2]"+r"(_ref2)
+    :[ystride]"r"((ptrdiff_t)_ystride)
+  );
+  return (unsigned)ret;
+}
+
+/*Load an 8x4 array of pixel values from %[src] and %[ref] and compute their
+   16-bit difference in %%mm0...%%mm7.*/
+#define OC_LOAD_SUB_8x4(_off) \
+ "#OC_LOAD_SUB_8x4\n\t" \
+ "movd "_off"(%[src]),%%mm0\n\t" \
+ "movd "_off"(%[ref]),%%mm4\n\t" \
+ "movd "_off"(%[src],%[src_ystride]),%%mm1\n\t" \
+ "lea (%[src],%[src_ystride],2),%[src]\n\t" \
+ "movd "_off"(%[ref],%[ref_ystride]),%%mm5\n\t" \
+ "lea (%[ref],%[ref_ystride],2),%[ref]\n\t" \
+ "movd "_off"(%[src]),%%mm2\n\t" \
+ "movd "_off"(%[ref]),%%mm7\n\t" \
+ "movd "_off"(%[src],%[src_ystride]),%%mm3\n\t" \
+ "movd "_off"(%[ref],%[ref_ystride]),%%mm6\n\t" \
+ "punpcklbw %%mm4,%%mm0\n\t" \
+ "lea (%[src],%[src_ystride],2),%[src]\n\t" \
+ "punpcklbw %%mm4,%%mm4\n\t" \
+ "lea (%[ref],%[ref_ystride],2),%[ref]\n\t" \
+ "psubw %%mm4,%%mm0\n\t" \
+ "movd "_off"(%[src]),%%mm4\n\t" \
+ "movq %%mm0,"_off"*2(%[buf])\n\t" \
+ "movd "_off"(%[ref]),%%mm0\n\t" \
+ "punpcklbw %%mm5,%%mm1\n\t" \
+ "punpcklbw %%mm5,%%mm5\n\t" \
+ "psubw %%mm5,%%mm1\n\t" \
+ "movd "_off"(%[src],%[src_ystride]),%%mm5\n\t" \
+ "punpcklbw %%mm7,%%mm2\n\t" \
+ "punpcklbw %%mm7,%%mm7\n\t" \
+ "psubw %%mm7,%%mm2\n\t" \
+ "movd "_off"(%[ref],%[ref_ystride]),%%mm7\n\t" \
+ "punpcklbw %%mm6,%%mm3\n\t" \
+ "lea (%[src],%[src_ystride],2),%[src]\n\t" \
+ "punpcklbw %%mm6,%%mm6\n\t" \
+ "psubw %%mm6,%%mm3\n\t" \
+ "movd "_off"(%[src]),%%mm6\n\t" \
+ "punpcklbw %%mm0,%%mm4\n\t" \
+ "lea (%[ref],%[ref_ystride],2),%[ref]\n\t" \
+ "punpcklbw %%mm0,%%mm0\n\t" \
+ "lea (%[src],%[src_ystride],2),%[src]\n\t" \
+ "psubw %%mm0,%%mm4\n\t" \
+ "movd "_off"(%[ref]),%%mm0\n\t" \
+ "punpcklbw %%mm7,%%mm5\n\t" \
+ "neg %[src_ystride]\n\t" \
+ "punpcklbw %%mm7,%%mm7\n\t" \
+ "psubw %%mm7,%%mm5\n\t" \
+ "movd "_off"(%[src],%[src_ystride]),%%mm7\n\t" \
+ "punpcklbw %%mm0,%%mm6\n\t" \
+ "lea (%[ref],%[ref_ystride],2),%[ref]\n\t" \
+ "punpcklbw %%mm0,%%mm0\n\t" \
+ "neg %[ref_ystride]\n\t" \
+ "psubw %%mm0,%%mm6\n\t" \
+ "movd "_off"(%[ref],%[ref_ystride]),%%mm0\n\t" \
+ "lea (%[src],%[src_ystride],8),%[src]\n\t" \
+ "punpcklbw %%mm0,%%mm7\n\t" \
+ "neg %[src_ystride]\n\t" \
+ "punpcklbw %%mm0,%%mm0\n\t" \
+ "lea (%[ref],%[ref_ystride],8),%[ref]\n\t" \
+ "psubw %%mm0,%%mm7\n\t" \
+ "neg %[ref_ystride]\n\t" \
+ "movq "_off"*2(%[buf]),%%mm0\n\t" \
+
+/*Load an 8x4 array of pixel values from %[src] into %%mm0...%%mm7.*/
+#define OC_LOAD_8x4(_off) \
+ "#OC_LOAD_8x4\n\t" \
+ "movd "_off"(%[src]),%%mm0\n\t" \
+ "movd "_off"(%[src],%[ystride]),%%mm1\n\t" \
+ "movd "_off"(%[src],%[ystride],2),%%mm2\n\t" \
+ "pxor %%mm7,%%mm7\n\t" \
+ "movd "_off"(%[src],%[ystride3]),%%mm3\n\t" \
+ "punpcklbw %%mm7,%%mm0\n\t" \
+ "movd "_off"(%[src4]),%%mm4\n\t" \
+ "punpcklbw %%mm7,%%mm1\n\t" \
+ "movd "_off"(%[src4],%[ystride]),%%mm5\n\t" \
+ "punpcklbw %%mm7,%%mm2\n\t" \
+ "movd "_off"(%[src4],%[ystride],2),%%mm6\n\t" \
+ "punpcklbw %%mm7,%%mm3\n\t" \
+ "movd "_off"(%[src4],%[ystride3]),%%mm7\n\t" \
+ "punpcklbw %%mm4,%%mm4\n\t" \
+ "punpcklbw %%mm5,%%mm5\n\t" \
+ "psrlw $8,%%mm4\n\t" \
+ "psrlw $8,%%mm5\n\t" \
+ "punpcklbw %%mm6,%%mm6\n\t" \
+ "punpcklbw %%mm7,%%mm7\n\t" \
+ "psrlw $8,%%mm6\n\t" \
+ "psrlw $8,%%mm7\n\t" \
+
+/*Performs the first two stages of an 8-point 1-D Hadamard transform.
+  The transform is performed in place, except that outputs 0-3 are swapped with
+   outputs 4-7.
+  Outputs 2, 3, 6 and 7 from the second stage are negated (which allows us to
+   perform this stage in place with no temporary registers).*/
+#define OC_HADAMARD_AB_8x4 \
+ "#OC_HADAMARD_AB_8x4\n\t" \
+ /*Stage A: \
+   Outputs 0-3 are swapped with 4-7 here.*/ \
+ "paddw %%mm1,%%mm5\n\t" \
+ "paddw %%mm2,%%mm6\n\t" \
+ "paddw %%mm1,%%mm1\n\t" \
+ "paddw %%mm2,%%mm2\n\t" \
+ "psubw %%mm5,%%mm1\n\t" \
+ "psubw %%mm6,%%mm2\n\t" \
+ "paddw %%mm3,%%mm7\n\t" \
+ "paddw %%mm0,%%mm4\n\t" \
+ "paddw %%mm3,%%mm3\n\t" \
+ "paddw %%mm0,%%mm0\n\t" \
+ "psubw %%mm7,%%mm3\n\t" \
+ "psubw %%mm4,%%mm0\n\t" \
+ /*Stage B:*/ \
+ "paddw %%mm2,%%mm0\n\t" \
+ "paddw %%mm3,%%mm1\n\t" \
+ "paddw %%mm6,%%mm4\n\t" \
+ "paddw %%mm7,%%mm5\n\t" \
+ "paddw %%mm2,%%mm2\n\t" \
+ "paddw %%mm3,%%mm3\n\t" \
+ "paddw %%mm6,%%mm6\n\t" \
+ "paddw %%mm7,%%mm7\n\t" \
+ "psubw %%mm0,%%mm2\n\t" \
+ "psubw %%mm1,%%mm3\n\t" \
+ "psubw %%mm4,%%mm6\n\t" \
+ "psubw %%mm5,%%mm7\n\t" \
+
+/*Performs the last stage of an 8-point 1-D Hadamard transform in place.
+  Ouputs 1, 3, 5, and 7 are negated (which allows us to perform this stage in
+   place with no temporary registers).*/
+#define OC_HADAMARD_C_8x4 \
+ "#OC_HADAMARD_C_8x4\n\t" \
+ /*Stage C:*/ \
+ "paddw %%mm1,%%mm0\n\t" \
+ "paddw %%mm3,%%mm2\n\t" \
+ "paddw %%mm5,%%mm4\n\t" \
+ "paddw %%mm7,%%mm6\n\t" \
+ "paddw %%mm1,%%mm1\n\t" \
+ "paddw %%mm3,%%mm3\n\t" \
+ "paddw %%mm5,%%mm5\n\t" \
+ "paddw %%mm7,%%mm7\n\t" \
+ "psubw %%mm0,%%mm1\n\t" \
+ "psubw %%mm2,%%mm3\n\t" \
+ "psubw %%mm4,%%mm5\n\t" \
+ "psubw %%mm6,%%mm7\n\t" \
+
+/*Performs an 8-point 1-D Hadamard transform.
+  The transform is performed in place, except that outputs 0-3 are swapped with
+   outputs 4-7.
+  Outputs 1, 2, 5 and 6 are negated (which allows us to perform the transform
+   in place with no temporary registers).*/
+#define OC_HADAMARD_8x4 \
+ OC_HADAMARD_AB_8x4 \
+ OC_HADAMARD_C_8x4 \
+
+/*Performs the first part of the final stage of the Hadamard transform and
+   summing of absolute values.
+  At the end of this part, %%mm1 will contain the DC coefficient of the
+   transform.*/
+#define OC_HADAMARD_C_ABS_ACCUM_A_8x4(_r6,_r7) \
+ /*We use the fact that \
+     (abs(a+b)+abs(a-b))/2=max(abs(a),abs(b)) \
+    to merge the final butterfly with the abs and the first stage of \
+    accumulation. \
+   Thus we can avoid using pabsw, which is not available until SSSE3. \
+   Emulating pabsw takes 3 instructions, so the straightforward MMXEXT \
+    implementation would be (3+3)*8+7=55 instructions (+4 for spilling \
+    registers). \
+   Even with pabsw, it would be (3+1)*8+7=39 instructions (with no spills). \
+   This implementation is only 26 (+4 for spilling registers).*/ \
+ "#OC_HADAMARD_C_ABS_ACCUM_A_8x4\n\t" \
+ "movq %%mm7,"_r7"(%[buf])\n\t" \
+ "movq %%mm6,"_r6"(%[buf])\n\t" \
+ /*mm7={0x7FFF}x4 \
+   mm0=max(abs(mm0),abs(mm1))-0x7FFF*/ \
+ "pcmpeqb %%mm7,%%mm7\n\t" \
+ "movq %%mm0,%%mm6\n\t" \
+ "psrlw $1,%%mm7\n\t" \
+ "paddw %%mm1,%%mm6\n\t" \
+ "pmaxsw %%mm1,%%mm0\n\t" \
+ "paddsw %%mm7,%%mm6\n\t" \
+ "psubw %%mm6,%%mm0\n\t" \
+ /*mm2=max(abs(mm2),abs(mm3))-0x7FFF \
+   mm4=max(abs(mm4),abs(mm5))-0x7FFF*/ \
+ "movq %%mm2,%%mm6\n\t" \
+ "movq %%mm4,%%mm1\n\t" \
+ "pmaxsw %%mm3,%%mm2\n\t" \
+ "pmaxsw %%mm5,%%mm4\n\t" \
+ "paddw %%mm3,%%mm6\n\t" \
+ "paddw %%mm5,%%mm1\n\t" \
+ "movq "_r7"(%[buf]),%%mm3\n\t" \
+
+/*Performs the second part of the final stage of the Hadamard transform and
+   summing of absolute values.*/
+#define OC_HADAMARD_C_ABS_ACCUM_B_8x4(_r6,_r7) \
+ "#OC_HADAMARD_C_ABS_ACCUM_B_8x4\n\t" \
+ "paddsw %%mm7,%%mm6\n\t" \
+ "movq "_r6"(%[buf]),%%mm5\n\t" \
+ "paddsw %%mm7,%%mm1\n\t" \
+ "psubw %%mm6,%%mm2\n\t" \
+ "psubw %%mm1,%%mm4\n\t" \
+ /*mm7={1}x4 (needed for the horizontal add that follows) \
+   mm0+=mm2+mm4+max(abs(mm3),abs(mm5))-0x7FFF*/ \
+ "movq %%mm3,%%mm6\n\t" \
+ "pmaxsw %%mm5,%%mm3\n\t" \
+ "paddw %%mm2,%%mm0\n\t" \
+ "paddw %%mm5,%%mm6\n\t" \
+ "paddw %%mm4,%%mm0\n\t" \
+ "paddsw %%mm7,%%mm6\n\t" \
+ "paddw %%mm3,%%mm0\n\t" \
+ "psrlw $14,%%mm7\n\t" \
+ "psubw %%mm6,%%mm0\n\t" \
+
+/*Performs the last stage of an 8-point 1-D Hadamard transform, takes the
+   absolute value of each component, and accumulates everything into mm0.
+  This is the only portion of SATD which requires MMXEXT (we could use plain
+   MMX, but it takes 4 instructions and an extra register to work around the
+   lack of a pmaxsw, which is a pretty serious penalty).*/
+#define OC_HADAMARD_C_ABS_ACCUM_8x4(_r6,_r7) \
+ OC_HADAMARD_C_ABS_ACCUM_A_8x4(_r6,_r7) \
+ OC_HADAMARD_C_ABS_ACCUM_B_8x4(_r6,_r7) \
+
+/*Performs an 8-point 1-D Hadamard transform, takes the absolute value of each
+   component, and accumulates everything into mm0.
+  Note that mm0 will have an extra 4 added to each column, and that after
+   removing this value, the remainder will be half the conventional value.*/
+#define OC_HADAMARD_ABS_ACCUM_8x4(_r6,_r7) \
+ OC_HADAMARD_AB_8x4 \
+ OC_HADAMARD_C_ABS_ACCUM_8x4(_r6,_r7)
+
+/*Performs two 4x4 transposes (mostly) in place.
+  On input, {mm0,mm1,mm2,mm3} contains rows {e,f,g,h}, and {mm4,mm5,mm6,mm7}
+   contains rows {a,b,c,d}.
+  On output, {0x40,0x50,0x60,0x70}+_off(%[buf]) contains {e,f,g,h}^T, and
+   {mm4,mm5,mm6,mm7} contains the transposed rows {a,b,c,d}^T.*/
+#define OC_TRANSPOSE_4x4x2(_off) \
+ "#OC_TRANSPOSE_4x4x2\n\t" \
+ /*First 4x4 transpose:*/ \
+ "movq %%mm5,0x10+"_off"(%[buf])\n\t" \
+ /*mm0 = e3 e2 e1 e0 \
+   mm1 = f3 f2 f1 f0 \
+   mm2 = g3 g2 g1 g0 \
+   mm3 = h3 h2 h1 h0*/ \
+ "movq %%mm2,%%mm5\n\t" \
+ "punpcklwd %%mm3,%%mm2\n\t" \
+ "punpckhwd %%mm3,%%mm5\n\t" \
+ "movq %%mm0,%%mm3\n\t" \
+ "punpcklwd %%mm1,%%mm0\n\t" \
+ "punpckhwd %%mm1,%%mm3\n\t" \
+ /*mm0 = f1 e1 f0 e0 \
+   mm3 = f3 e3 f2 e2 \
+   mm2 = h1 g1 h0 g0 \
+   mm5 = h3 g3 h2 g2*/ \
+ "movq %%mm0,%%mm1\n\t" \
+ "punpckldq %%mm2,%%mm0\n\t" \
+ "punpckhdq %%mm2,%%mm1\n\t" \
+ "movq %%mm3,%%mm2\n\t" \
+ "punpckhdq %%mm5,%%mm3\n\t" \
+ "movq %%mm0,0x40+"_off"(%[buf])\n\t" \
+ "punpckldq %%mm5,%%mm2\n\t" \
+ /*mm0 = h0 g0 f0 e0 \
+   mm1 = h1 g1 f1 e1 \
+   mm2 = h2 g2 f2 e2 \
+   mm3 = h3 g3 f3 e3*/ \
+ "movq 0x10+"_off"(%[buf]),%%mm5\n\t" \
+ /*Second 4x4 transpose:*/ \
+ /*mm4 = a3 a2 a1 a0 \
+   mm5 = b3 b2 b1 b0 \
+   mm6 = c3 c2 c1 c0 \
+   mm7 = d3 d2 d1 d0*/ \
+ "movq %%mm6,%%mm0\n\t" \
+ "punpcklwd %%mm7,%%mm6\n\t" \
+ "movq %%mm1,0x50+"_off"(%[buf])\n\t" \
+ "punpckhwd %%mm7,%%mm0\n\t" \
+ "movq %%mm4,%%mm7\n\t" \
+ "punpcklwd %%mm5,%%mm4\n\t" \
+ "movq %%mm2,0x60+"_off"(%[buf])\n\t" \
+ "punpckhwd %%mm5,%%mm7\n\t" \
+ /*mm4 = b1 a1 b0 a0 \
+   mm7 = b3 a3 b2 a2 \
+   mm6 = d1 c1 d0 c0 \
+   mm0 = d3 c3 d2 c2*/ \
+ "movq %%mm4,%%mm5\n\t" \
+ "punpckldq %%mm6,%%mm4\n\t" \
+ "movq %%mm3,0x70+"_off"(%[buf])\n\t" \
+ "punpckhdq %%mm6,%%mm5\n\t" \
+ "movq %%mm7,%%mm6\n\t" \
+ "punpckhdq %%mm0,%%mm7\n\t" \
+ "punpckldq %%mm0,%%mm6\n\t" \
+ /*mm4 = d0 c0 b0 a0 \
+   mm5 = d1 c1 b1 a1 \
+   mm6 = d2 c2 b2 a2 \
+   mm7 = d3 c3 b3 a3*/ \
+
+static unsigned oc_int_frag_satd_thresh_mmxext(const unsigned char *_src,
+ int _src_ystride,const unsigned char *_ref,int _ref_ystride,unsigned _thresh){
+  OC_ALIGN8(ogg_int16_t  buf[64]);
+  ogg_int16_t *bufp;
+  unsigned     ret;
+  unsigned     ret2;
+  bufp=buf;
+  __asm__ __volatile__(
+    OC_LOAD_SUB_8x4("0x00")
+    OC_HADAMARD_8x4
+    OC_TRANSPOSE_4x4x2("0x00")
+    /*Finish swapping out this 8x4 block to make room for the next one.
+      mm0...mm3 have been swapped out already.*/
+    "movq %%mm4,0x00(%[buf])\n\t"
+    "movq %%mm5,0x10(%[buf])\n\t"
+    "movq %%mm6,0x20(%[buf])\n\t"
+    "movq %%mm7,0x30(%[buf])\n\t"
+    OC_LOAD_SUB_8x4("0x04")
+    OC_HADAMARD_8x4
+    OC_TRANSPOSE_4x4x2("0x08")
+    /*Here the first 4x4 block of output from the last transpose is the second
+       4x4 block of input for the next transform.
+      We have cleverly arranged that it already be in the appropriate place, so
+       we only have to do half the loads.*/
+    "movq 0x10(%[buf]),%%mm1\n\t"
+    "movq 0x20(%[buf]),%%mm2\n\t"
+    "movq 0x30(%[buf]),%%mm3\n\t"
+    "movq 0x00(%[buf]),%%mm0\n\t"
+    OC_HADAMARD_ABS_ACCUM_8x4("0x28","0x38")
+    /*Up to this point, everything fit in 16 bits (8 input + 1 for the
+       difference + 2*3 for the two 8-point 1-D Hadamards - 1 for the abs - 1
+       for the factor of two we dropped + 3 for the vertical accumulation).
+      Now we finally have to promote things to dwords.
+      We break this part out of OC_HADAMARD_ABS_ACCUM_8x4 to hide the long
+       latency of pmaddwd by starting the next series of loads now.*/
+    "mov %[thresh],%[ret2]\n\t"
+    "pmaddwd %%mm7,%%mm0\n\t"
+    "movq 0x50(%[buf]),%%mm1\n\t"
+    "movq 0x58(%[buf]),%%mm5\n\t"
+    "movq %%mm0,%%mm4\n\t"
+    "movq 0x60(%[buf]),%%mm2\n\t"
+    "punpckhdq %%mm0,%%mm0\n\t"
+    "movq 0x68(%[buf]),%%mm6\n\t"
+    "paddd %%mm0,%%mm4\n\t"
+    "movq 0x70(%[buf]),%%mm3\n\t"
+    "movd %%mm4,%[ret]\n\t"
+    "movq 0x78(%[buf]),%%mm7\n\t"
+    /*The sums produced by OC_HADAMARD_ABS_ACCUM_8x4 each have an extra 4
+       added to them, and a factor of two removed; correct the final sum here.*/
+    "lea -32(%[ret],%[ret]),%[ret]\n\t"
+    "movq 0x40(%[buf]),%%mm0\n\t"
+    "cmp %[ret2],%[ret]\n\t"
+    "movq 0x48(%[buf]),%%mm4\n\t"
+    "jae 1f\n\t"
+    OC_HADAMARD_ABS_ACCUM_8x4("0x68","0x78")
+    "pmaddwd %%mm7,%%mm0\n\t"
+    /*There isn't much to stick in here to hide the latency this time, but the
+       alternative to pmaddwd is movq->punpcklwd->punpckhwd->paddd, whose
+       latency is even worse.*/
+    "sub $32,%[ret]\n\t"
+    "movq %%mm0,%%mm4\n\t"
+    "punpckhdq %%mm0,%%mm0\n\t"
+    "paddd %%mm0,%%mm4\n\t"
+    "movd %%mm4,%[ret2]\n\t"
+    "lea (%[ret],%[ret2],2),%[ret]\n\t"
+    ".p2align 4,,15\n\t"
+    "1:\n\t"
+    /*Although it looks like we're using 7 registers here, gcc can alias %[ret]
+       and %[ret2] with some of the inputs, since for once we don't write to
+       them until after we're done using everything but %[buf] (which is also
+       listed as an output to ensure gcc _doesn't_ alias them against it).*/
+    /*Note that _src_ystride and _ref_ystride must be given non-overlapping
+       constraints, otherewise if gcc can prove they're equal it will allocate
+       them to the same register (which is bad); _src and _ref face a similar
+       problem, though those are never actually the same.*/
+    :[ret]"=a"(ret),[ret2]"=r"(ret2),[buf]"+r"(bufp)
+    :[src]"r"(_src),[src_ystride]"c"((ptrdiff_t)_src_ystride),
+     [ref]"r"(_ref),[ref_ystride]"d"((ptrdiff_t)_ref_ystride),
+     [thresh]"m"(_thresh)
+    /*We have to use neg, so we actually clobber the condition codes for once
+       (not to mention cmp, sub, and add).*/
+    :"cc"
+  );
+  return ret;
+}
+
+unsigned oc_enc_frag_satd_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh){
+  return oc_int_frag_satd_thresh_mmxext(_src,_ystride,_ref,_ystride,_thresh);
+}
+
+/*Our internal implementation of frag_copy2 takes an extra stride parameter so
+   we can share code with oc_enc_frag_satd2_thresh_mmxext().*/
+static void oc_int_frag_copy2_mmxext(unsigned char *_dst,int _dst_ystride,
+ const unsigned char *_src1,const unsigned char *_src2,int _src_ystride){
+  __asm__ __volatile__(
+    /*Load the first 3 rows.*/
+    "movq (%[src1]),%%mm0\n\t"
+    "movq (%[src2]),%%mm1\n\t"
+    "movq (%[src1],%[src_ystride]),%%mm2\n\t"
+    "lea (%[src1],%[src_ystride],2),%[src1]\n\t"
+    "movq (%[src2],%[src_ystride]),%%mm3\n\t"
+    "lea (%[src2],%[src_ystride],2),%[src2]\n\t"
+    "pxor %%mm7,%%mm7\n\t"
+    "movq (%[src1]),%%mm4\n\t"
+    "pcmpeqb %%mm6,%%mm6\n\t"
+    "movq (%[src2]),%%mm5\n\t"
+    /*mm7={1}x8.*/
+    "psubb %%mm6,%%mm7\n\t"
+    /*Start averaging %%mm0 and %%mm1 into %%mm6.*/
+    "movq %%mm0,%%mm6\n\t"
+    "pxor %%mm1,%%mm0\n\t"
+    "pavgb %%mm1,%%mm6\n\t"
+    /*%%mm1 is free, start averaging %%mm3 into %%mm2 using %%mm1.*/
+    "movq %%mm2,%%mm1\n\t"
+    "pand %%mm7,%%mm0\n\t"
+    "pavgb %%mm3,%%mm2\n\t"
+    "pxor %%mm3,%%mm1\n\t"
+    /*%%mm3 is free.*/
+    "psubb %%mm0,%%mm6\n\t"
+    /*%%mm0 is free, start loading the next row.*/
+    "movq (%[src1],%[src_ystride]),%%mm0\n\t"
+    /*Start averaging %%mm5 and %%mm4 using %%mm3.*/
+    "movq %%mm4,%%mm3\n\t"
+    /*%%mm6 (row 0) is done; write it out.*/
+    "movq %%mm6,(%[dst])\n\t"
+    "pand %%mm7,%%mm1\n\t"
+    "pavgb %%mm5,%%mm4\n\t"
+    "psubb %%mm1,%%mm2\n\t"
+    /*%%mm1 is free, continue loading the next row.*/
+    "movq (%[src2],%[src_ystride]),%%mm1\n\t"
+    "pxor %%mm5,%%mm3\n\t"
+    "lea (%[src1],%[src_ystride],2),%[src1]\n\t"
+    /*%%mm2 (row 1) is done; write it out.*/
+    "movq %%mm2,(%[dst],%[dst_ystride])\n\t"
+    "pand %%mm7,%%mm3\n\t"
+    /*Start loading the next row.*/
+    "movq (%[src1]),%%mm2\n\t"
+    "lea (%[dst],%[dst_ystride],2),%[dst]\n\t"
+    "psubb %%mm3,%%mm4\n\t"
+    "lea (%[src2],%[src_ystride],2),%[src2]\n\t"
+    /*%%mm4 (row 2) is done; write it out.*/
+    "movq %%mm4,(%[dst])\n\t"
+    /*Continue loading the next row.*/
+    "movq (%[src2]),%%mm3\n\t"
+    /*Start averaging %%mm0 and %%mm1 into %%mm6.*/
+    "movq %%mm0,%%mm6\n\t"
+    "pxor %%mm1,%%mm0\n\t"
+    /*Start loading the next row.*/
+    "movq (%[src1],%[src_ystride]),%%mm4\n\t"
+    "pavgb %%mm1,%%mm6\n\t"
+    /*%%mm1 is free; start averaging %%mm3 into %%mm2 using %%mm1.*/
+    "movq %%mm2,%%mm1\n\t"
+    "pand %%mm7,%%mm0\n\t"
+    /*Continue loading the next row.*/
+    "movq (%[src2],%[src_ystride]),%%mm5\n\t"
+    "pavgb %%mm3,%%mm2\n\t"
+    "lea (%[src1],%[src_ystride],2),%[src1]\n\t"
+    "pxor %%mm3,%%mm1\n\t"
+    /*%%mm3 is free.*/
+    "psubb %%mm0,%%mm6\n\t"
+    /*%%mm0 is free, start loading the next row.*/
+    "movq (%[src1]),%%mm0\n\t"
+    /*Start averaging %%mm5 into %%mm4 using %%mm3.*/
+    "movq %%mm4,%%mm3\n\t"
+    /*%%mm6 (row 3) is done; write it out.*/
+    "movq %%mm6,(%[dst],%[dst_ystride])\n\t"
+    "pand %%mm7,%%mm1\n\t"
+    "lea (%[src2],%[src_ystride],2),%[src2]\n\t"
+    "pavgb %%mm5,%%mm4\n\t"
+    "lea (%[dst],%[dst_ystride],2),%[dst]\n\t"
+    "psubb %%mm1,%%mm2\n\t"
+    /*%%mm1 is free; continue loading the next row.*/
+    "movq (%[src2]),%%mm1\n\t"
+    "pxor %%mm5,%%mm3\n\t"
+    /*%%mm2 (row 4) is done; write it out.*/
+    "movq %%mm2,(%[dst])\n\t"
+    "pand %%mm7,%%mm3\n\t"
+    /*Start loading the next row.*/
+    "movq (%[src1],%[src_ystride]),%%mm2\n\t"
+    "psubb %%mm3,%%mm4\n\t"
+    /*Start averaging %%mm0 and %%mm1 into %%mm6.*/
+    "movq %%mm0,%%mm6\n\t"
+    /*Continue loading the next row.*/
+    "movq (%[src2],%[src_ystride]),%%mm3\n\t"
+    /*%%mm4 (row 5) is done; write it out.*/
+    "movq %%mm4,(%[dst],%[dst_ystride])\n\t"
+    "pxor %%mm1,%%mm0\n\t"
+    "pavgb %%mm1,%%mm6\n\t"
+    /*%%mm4 is free; start averaging %%mm3 into %%mm2 using %%mm4.*/
+    "movq %%mm2,%%mm4\n\t"
+    "pand %%mm7,%%mm0\n\t"
+    "pavgb %%mm3,%%mm2\n\t"
+    "pxor %%mm3,%%mm4\n\t"
+    "lea (%[dst],%[dst_ystride],2),%[dst]\n\t"
+    "psubb %%mm0,%%mm6\n\t"
+    "pand %%mm7,%%mm4\n\t"
+    /*%%mm6 (row 6) is done, write it out.*/
+    "movq %%mm6,(%[dst])\n\t"
+    "psubb %%mm4,%%mm2\n\t"
+    /*%%mm2 (row 7) is done, write it out.*/
+    "movq %%mm2,(%[dst],%[dst_ystride])\n\t"
+    :[dst]"+r"(_dst),[src1]"+%r"(_src1),[src2]"+r"(_src2)
+    :[dst_ystride]"r"((ptrdiff_t)_dst_ystride),
+     [src_ystride]"r"((ptrdiff_t)_src_ystride)
+    :"memory"
+  );
+}
+
+unsigned oc_enc_frag_satd2_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh){
+  OC_ALIGN8(unsigned char ref[64]);
+  oc_int_frag_copy2_mmxext(ref,8,_ref1,_ref2,_ystride);
+  return oc_int_frag_satd_thresh_mmxext(_src,_ystride,ref,8,_thresh);
+}
+
+unsigned oc_enc_frag_intra_satd_mmxext(const unsigned char *_src,
+ int _ystride){
+  OC_ALIGN8(ogg_int16_t  buf[64]);
+  ogg_int16_t *bufp;
+  unsigned     ret;
+  unsigned     ret2;
+  bufp=buf;
+  __asm__ __volatile__(
+    OC_LOAD_8x4("0x00")
+    OC_HADAMARD_8x4
+    OC_TRANSPOSE_4x4x2("0x00")
+    /*Finish swapping out this 8x4 block to make room for the next one.
+      mm0...mm3 have been swapped out already.*/
+    "movq %%mm4,0x00(%[buf])\n\t"
+    "movq %%mm5,0x10(%[buf])\n\t"
+    "movq %%mm6,0x20(%[buf])\n\t"
+    "movq %%mm7,0x30(%[buf])\n\t"
+    OC_LOAD_8x4("0x04")
+    OC_HADAMARD_8x4
+    OC_TRANSPOSE_4x4x2("0x08")
+    /*Here the first 4x4 block of output from the last transpose is the second
+       4x4 block of input for the next transform.
+      We have cleverly arranged that it already be in the appropriate place, so
+       we only have to do half the loads.*/
+    "movq 0x10(%[buf]),%%mm1\n\t"
+    "movq 0x20(%[buf]),%%mm2\n\t"
+    "movq 0x30(%[buf]),%%mm3\n\t"
+    "movq 0x00(%[buf]),%%mm0\n\t"
+    /*We split out the stages here so we can save the DC coefficient in the
+       middle.*/
+    OC_HADAMARD_AB_8x4
+    OC_HADAMARD_C_ABS_ACCUM_A_8x4("0x28","0x38")
+    "movd %%mm1,%[ret]\n\t"
+    OC_HADAMARD_C_ABS_ACCUM_B_8x4("0x28","0x38")
+    /*Up to this point, everything fit in 16 bits (8 input + 1 for the
+       difference + 2*3 for the two 8-point 1-D Hadamards - 1 for the abs - 1
+       for the factor of two we dropped + 3 for the vertical accumulation).
+      Now we finally have to promote things to dwords.
+      We break this part out of OC_HADAMARD_ABS_ACCUM_8x4 to hide the long
+       latency of pmaddwd by starting the next series of loads now.*/
+    "pmaddwd %%mm7,%%mm0\n\t"
+    "movq 0x50(%[buf]),%%mm1\n\t"
+    "movq 0x58(%[buf]),%%mm5\n\t"
+    "movq 0x60(%[buf]),%%mm2\n\t"
+    "movq %%mm0,%%mm4\n\t"
+    "movq 0x68(%[buf]),%%mm6\n\t"
+    "punpckhdq %%mm0,%%mm0\n\t"
+    "movq 0x70(%[buf]),%%mm3\n\t"
+    "paddd %%mm0,%%mm4\n\t"
+    "movq 0x78(%[buf]),%%mm7\n\t"
+    "movd %%mm4,%[ret2]\n\t"
+    "movq 0x40(%[buf]),%%mm0\n\t"
+    "movq 0x48(%[buf]),%%mm4\n\t"
+    OC_HADAMARD_ABS_ACCUM_8x4("0x68","0x78")
+    "pmaddwd %%mm7,%%mm0\n\t"
+    /*We assume that the DC coefficient is always positive (which is true,
+       because the input to the INTRA transform was not a difference).*/
+    "movzx %w[ret],%[ret]\n\t"
+    "add %[ret2],%[ret2]\n\t"
+    "sub %[ret],%[ret2]\n\t"
+    "movq %%mm0,%%mm4\n\t"
+    "punpckhdq %%mm0,%%mm0\n\t"
+    "paddd %%mm0,%%mm4\n\t"
+    "movd %%mm4,%[ret]\n\t"
+    "lea -64(%[ret2],%[ret],2),%[ret]\n\t"
+    /*Although it looks like we're using 7 registers here, gcc can alias %[ret]
+       and %[ret2] with some of the inputs, since for once we don't write to
+       them until after we're done using everything but %[buf] (which is also
+       listed as an output to ensure gcc _doesn't_ alias them against it).*/
+    :[ret]"=a"(ret),[ret2]"=r"(ret2),[buf]"+r"(bufp)
+    :[src]"r"(_src),[src4]"r"(_src+4*_ystride),
+     [ystride]"r"((ptrdiff_t)_ystride),[ystride3]"r"((ptrdiff_t)3*_ystride)
+    /*We have to use sub, so we actually clobber the condition codes for once
+       (not to mention add).*/
+    :"cc"
+  );
+  return ret;
+}
+
+void oc_enc_frag_sub_mmx(ogg_int16_t _residue[64],
+ const unsigned char *_src,const unsigned char *_ref,int _ystride){
+  int i;
+  __asm__ __volatile__("pxor %%mm7,%%mm7\n\t"::);
+  for(i=4;i-->0;){
+    __asm__ __volatile__(
+      /*mm0=[src]*/
+      "movq (%[src]),%%mm0\n\t"
+      /*mm1=[ref]*/
+      "movq (%[ref]),%%mm1\n\t"
+      /*mm4=[src+ystride]*/
+      "movq (%[src],%[ystride]),%%mm4\n\t"
+      /*mm5=[ref+ystride]*/
+      "movq (%[ref],%[ystride]),%%mm5\n\t"
+      /*Compute [src]-[ref].*/
+      "movq %%mm0,%%mm2\n\t"
+      "punpcklbw %%mm7,%%mm0\n\t"
+      "movq %%mm1,%%mm3\n\t"
+      "punpckhbw %%mm7,%%mm2\n\t"
+      "punpcklbw %%mm7,%%mm1\n\t"
+      "punpckhbw %%mm7,%%mm3\n\t"
+      "psubw %%mm1,%%mm0\n\t"
+      "psubw %%mm3,%%mm2\n\t"
+      /*Compute [src+ystride]-[ref+ystride].*/
+      "movq %%mm4,%%mm1\n\t"
+      "punpcklbw %%mm7,%%mm4\n\t"
+      "movq %%mm5,%%mm3\n\t"
+      "punpckhbw %%mm7,%%mm1\n\t"
+      "lea (%[src],%[ystride],2),%[src]\n\t"
+      "punpcklbw %%mm7,%%mm5\n\t"
+      "lea (%[ref],%[ystride],2),%[ref]\n\t"
+      "punpckhbw %%mm7,%%mm3\n\t"
+      "psubw %%mm5,%%mm4\n\t"
+      "psubw %%mm3,%%mm1\n\t"
+      /*Write the answer out.*/
+      "movq %%mm0,0x00(%[residue])\n\t"
+      "movq %%mm2,0x08(%[residue])\n\t"
+      "movq %%mm4,0x10(%[residue])\n\t"
+      "movq %%mm1,0x18(%[residue])\n\t"
+      "lea 0x20(%[residue]),%[residue]\n\t"
+      :[residue]"+r"(_residue),[src]"+r"(_src),[ref]"+r"(_ref)
+      :[ystride]"r"((ptrdiff_t)_ystride)
+      :"memory"
+    );
+  }
+}
+
+void oc_enc_frag_sub_128_mmx(ogg_int16_t _residue[64],
+ const unsigned char *_src,int _ystride){
+  ptrdiff_t ystride3;
+  __asm__ __volatile__(
+    /*mm0=[src]*/
+    "movq (%[src]),%%mm0\n\t"
+    /*mm1=[src+ystride]*/
+    "movq (%[src],%[ystride]),%%mm1\n\t"
+    /*mm6={-1}x4*/
+    "pcmpeqw %%mm6,%%mm6\n\t"
+    /*mm2=[src+2*ystride]*/
+    "movq (%[src],%[ystride],2),%%mm2\n\t"
+    /*[ystride3]=3*[ystride]*/
+    "lea (%[ystride],%[ystride],2),%[ystride3]\n\t"
+    /*mm6={1}x4*/
+    "psllw $15,%%mm6\n\t"
+    /*mm3=[src+3*ystride]*/
+    "movq (%[src],%[ystride3]),%%mm3\n\t"
+    /*mm6={128}x4*/
+    "psrlw $8,%%mm6\n\t"
+    /*mm7=0*/
+    "pxor %%mm7,%%mm7\n\t"
+    /*[src]=[src]+4*[ystride]*/
+    "lea (%[src],%[ystride],4),%[src]\n\t"
+    /*Compute [src]-128 and [src+ystride]-128*/
+    "movq %%mm0,%%mm4\n\t"
+    "punpcklbw %%mm7,%%mm0\n\t"
+    "movq %%mm1,%%mm5\n\t"
+    "punpckhbw %%mm7,%%mm4\n\t"
+    "psubw %%mm6,%%mm0\n\t"
+    "punpcklbw %%mm7,%%mm1\n\t"
+    "psubw %%mm6,%%mm4\n\t"
+    "punpckhbw %%mm7,%%mm5\n\t"
+    "psubw %%mm6,%%mm1\n\t"
+    "psubw %%mm6,%%mm5\n\t"
+    /*Write the answer out.*/
+    "movq %%mm0,0x00(%[residue])\n\t"
+    "movq %%mm4,0x08(%[residue])\n\t"
+    "movq %%mm1,0x10(%[residue])\n\t"
+    "movq %%mm5,0x18(%[residue])\n\t"
+    /*mm0=[src+4*ystride]*/
+    "movq (%[src]),%%mm0\n\t"
+    /*mm1=[src+5*ystride]*/
+    "movq (%[src],%[ystride]),%%mm1\n\t"
+    /*Compute [src+2*ystride]-128 and [src+3*ystride]-128*/
+    "movq %%mm2,%%mm4\n\t"
+    "punpcklbw %%mm7,%%mm2\n\t"
+    "movq %%mm3,%%mm5\n\t"
+    "punpckhbw %%mm7,%%mm4\n\t"
+    "psubw %%mm6,%%mm2\n\t"
+    "punpcklbw %%mm7,%%mm3\n\t"
+    "psubw %%mm6,%%mm4\n\t"
+    "punpckhbw %%mm7,%%mm5\n\t"
+    "psubw %%mm6,%%mm3\n\t"
+    "psubw %%mm6,%%mm5\n\t"
+    /*Write the answer out.*/
+    "movq %%mm2,0x20(%[residue])\n\t"
+    "movq %%mm4,0x28(%[residue])\n\t"
+    "movq %%mm3,0x30(%[residue])\n\t"
+    "movq %%mm5,0x38(%[residue])\n\t"
+    /*mm2=[src+6*ystride]*/
+    "movq (%[src],%[ystride],2),%%mm2\n\t"
+    /*mm3=[src+7*ystride]*/
+    "movq (%[src],%[ystride3]),%%mm3\n\t"
+    /*Compute [src+4*ystride]-128 and [src+5*ystride]-128*/
+    "movq %%mm0,%%mm4\n\t"
+    "punpcklbw %%mm7,%%mm0\n\t"
+    "movq %%mm1,%%mm5\n\t"
+    "punpckhbw %%mm7,%%mm4\n\t"
+    "psubw %%mm6,%%mm0\n\t"
+    "punpcklbw %%mm7,%%mm1\n\t"
+    "psubw %%mm6,%%mm4\n\t"
+    "punpckhbw %%mm7,%%mm5\n\t"
+    "psubw %%mm6,%%mm1\n\t"
+    "psubw %%mm6,%%mm5\n\t"
+    /*Write the answer out.*/
+    "movq %%mm0,0x40(%[residue])\n\t"
+    "movq %%mm4,0x48(%[residue])\n\t"
+    "movq %%mm1,0x50(%[residue])\n\t"
+    "movq %%mm5,0x58(%[residue])\n\t"
+    /*Compute [src+6*ystride]-128 and [src+7*ystride]-128*/
+    "movq %%mm2,%%mm4\n\t"
+    "punpcklbw %%mm7,%%mm2\n\t"
+    "movq %%mm3,%%mm5\n\t"
+    "punpckhbw %%mm7,%%mm4\n\t"
+    "psubw %%mm6,%%mm2\n\t"
+    "punpcklbw %%mm7,%%mm3\n\t"
+    "psubw %%mm6,%%mm4\n\t"
+    "punpckhbw %%mm7,%%mm5\n\t"
+    "psubw %%mm6,%%mm3\n\t"
+    "psubw %%mm6,%%mm5\n\t"
+    /*Write the answer out.*/
+    "movq %%mm2,0x60(%[residue])\n\t"
+    "movq %%mm4,0x68(%[residue])\n\t"
+    "movq %%mm3,0x70(%[residue])\n\t"
+    "movq %%mm5,0x78(%[residue])\n\t"
+    :[src]"+r"(_src),[ystride3]"=&r"(ystride3)
+    :[residue]"r"(_residue),[ystride]"r"((ptrdiff_t)_ystride)
+    :"memory"
+  );
+}
+
+void oc_enc_frag_copy2_mmxext(unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride){
+  oc_int_frag_copy2_mmxext(_dst,_ystride,_src1,_src2,_ystride);
+}
+
+#endif
diff --git a/lib/x86/mmxfdct.c b/lib/x86/mmxfdct.c
new file mode 100644 (file)
index 0000000..2118752
--- /dev/null
@@ -0,0 +1,665 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 1999-2006                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************/
+/*MMX fDCT implementation for x86_32*/
+/*$Id: fdct_ses2.c 14579 2008-03-12 06:42:40Z xiphmont $*/
+#include "x86enc.h"
+
+#if defined(OC_X86_ASM)
+
+# define OC_FDCT_STAGE1_8x4 \
+ "#OC_FDCT_STAGE1_8x4\n\t" \
+ /*Stage 1:*/ \
+ /*mm0=t7'=t0-t7*/ \
+ "psubw %%mm7,%%mm0\n\t" \
+ "paddw %%mm7,%%mm7\n\t" \
+ /*mm1=t6'=t1-t6*/ \
+ "psubw %%mm6,%%mm1\n\t" \
+ "paddw %%mm6,%%mm6\n\t" \
+ /*mm2=t5'=t2-t5*/ \
+ "psubw %%mm5,%%mm2\n\t" \
+ "paddw %%mm5,%%mm5\n\t" \
+ /*mm3=t4'=t3-t4*/ \
+ "psubw %%mm4,%%mm3\n\t" \
+ "paddw %%mm4,%%mm4\n\t" \
+ /*mm7=t0'=t0+t7*/ \
+ "paddw %%mm0,%%mm7\n\t" \
+ /*mm6=t1'=t1+t6*/ \
+ "paddw %%mm1,%%mm6\n\t" \
+ /*mm5=t2'=t2+t5*/ \
+ "paddw %%mm2,%%mm5\n\t" \
+ /*mm4=t3'=t3+t4*/ \
+ "paddw %%mm3,%%mm4\n\t" \
+
+# define OC_FDCT8x4(_r0,_r1,_r2,_r3,_r4,_r5,_r6,_r7) \
+ "#OC_FDCT8x4\n\t" \
+ /*Stage 2:*/ \
+ /*mm7=t3''=t0'-t3'*/ \
+ "psubw %%mm4,%%mm7\n\t" \
+ "paddw %%mm4,%%mm4\n\t" \
+ /*mm6=t2''=t1'-t2'*/ \
+ "psubw %%mm5,%%mm6\n\t" \
+ "movq %%mm7,"_r6"(%[y])\n\t" \
+ "paddw %%mm5,%%mm5\n\t" \
+ /*mm1=t5''=t6'-t5'*/ \
+ "psubw %%mm2,%%mm1\n\t" \
+ "movq %%mm6,"_r2"(%[y])\n\t" \
+ /*mm4=t0''=t0'+t3'*/ \
+ "paddw %%mm7,%%mm4\n\t" \
+ "paddw %%mm2,%%mm2\n\t" \
+ /*mm5=t1''=t1'+t2'*/ \
+ "movq %%mm4,"_r0"(%[y])\n\t" \
+ "paddw %%mm6,%%mm5\n\t" \
+ /*mm2=t6''=t6'+t5'*/ \
+ "paddw %%mm1,%%mm2\n\t" \
+ "movq %%mm5,"_r4"(%[y])\n\t" \
+ /*mm0=t7', mm1=t5'', mm2=t6'', mm3=t4'.*/ \
+ /*mm4, mm5, mm6, mm7 are free.*/ \
+ /*Stage 3:*/ \
+ /*mm6={2}x4, mm7={27146,0xB500>>1}x2*/ \
+ "mov $0x5A806A0A,%[a]\n\t" \
+ "pcmpeqb %%mm6,%%mm6\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "psrlw $15,%%mm6\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "paddw %%mm6,%%mm6\n\t" \
+ /*mm0=0, m2={-1}x4 \
+   mm5:mm4=t5''*27146+0xB500*/ \
+ "movq %%mm1,%%mm4\n\t" \
+ "movq %%mm1,%%mm5\n\t" \
+ "punpcklwd %%mm6,%%mm4\n\t" \
+ "movq %%mm2,"_r3"(%[y])\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "movq %%mm0,"_r7"(%[y])\n\t" \
+ "punpckhwd %%mm6,%%mm5\n\t" \
+ "pxor %%mm0,%%mm0\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "pcmpeqb %%mm2,%%mm2\n\t" \
+ /*mm2=t6'', mm1=t5''+(t5''!=0) \
+   mm4=(t5''*27146+0xB500>>16)*/ \
+ "pcmpeqw %%mm1,%%mm0\n\t" \
+ "psrad $16,%%mm4\n\t" \
+ "psubw %%mm2,%%mm0\n\t" \
+ "movq "_r3"(%[y]),%%mm2\n\t" \
+ "psrad $16,%%mm5\n\t" \
+ "paddw %%mm0,%%mm1\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ /*mm4=s=(t5''*27146+0xB500>>16)+t5''+(t5''!=0)>>1*/ \
+ "paddw %%mm1,%%mm4\n\t" \
+ "movq "_r7"(%[y]),%%mm0\n\t" \
+ "psraw $1,%%mm4\n\t" \
+ "movq %%mm3,%%mm1\n\t" \
+ /*mm3=t4''=t4'+s*/ \
+ "paddw %%mm4,%%mm3\n\t" \
+ /*mm1=t5'''=t4'-s*/ \
+ "psubw %%mm4,%%mm1\n\t" \
+ /*mm1=0, mm3={-1}x4 \
+   mm5:mm4=t6''*27146+0xB500*/ \
+ "movq %%mm2,%%mm4\n\t" \
+ "movq %%mm2,%%mm5\n\t" \
+ "punpcklwd %%mm6,%%mm4\n\t" \
+ "movq %%mm1,"_r5"(%[y])\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "movq %%mm3,"_r1"(%[y])\n\t" \
+ "punpckhwd %%mm6,%%mm5\n\t" \
+ "pxor %%mm1,%%mm1\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "pcmpeqb %%mm3,%%mm3\n\t" \
+ /*mm2=t6''+(t6''!=0), mm4=(t6''*27146+0xB500>>16)*/ \
+ "psrad $16,%%mm4\n\t" \
+ "pcmpeqw %%mm2,%%mm1\n\t" \
+ "psrad $16,%%mm5\n\t" \
+ "psubw %%mm3,%%mm1\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ "paddw %%mm1,%%mm2\n\t" \
+ /*mm1=t1'' \
+   mm4=s=(t6''*27146+0xB500>>16)+t6''+(t6''!=0)>>1*/ \
+ "paddw %%mm2,%%mm4\n\t" \
+ "movq "_r4"(%[y]),%%mm1\n\t" \
+ "psraw $1,%%mm4\n\t" \
+ "movq %%mm0,%%mm2\n\t" \
+ /*mm7={54491-0x7FFF,0x7FFF}x2 \
+   mm0=t7''=t7'+s*/ \
+ "paddw %%mm4,%%mm0\n\t" \
+ /*mm2=t6'''=t7'-s*/ \
+ "psubw %%mm4,%%mm2\n\t" \
+ /*Stage 4:*/ \
+ /*mm0=0, mm2=t0'' \
+   mm5:mm4=t1''*27146+0xB500*/ \
+ "movq %%mm1,%%mm4\n\t" \
+ "movq %%mm1,%%mm5\n\t" \
+ "punpcklwd %%mm6,%%mm4\n\t" \
+ "movq %%mm2,"_r3"(%[y])\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "movq "_r0"(%[y]),%%mm2\n\t" \
+ "punpckhwd %%mm6,%%mm5\n\t" \
+ "movq %%mm0,"_r7"(%[y])\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "pxor %%mm0,%%mm0\n\t" \
+ /*mm7={27146,0x4000>>1}x2 \
+   mm0=s=(t1''*27146+0xB500>>16)+t1''+(t1''!=0)*/ \
+ "psrad $16,%%mm4\n\t" \
+ "mov $0x20006A0A,%[a]\n\t" \
+ "pcmpeqw %%mm1,%%mm0\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "psrad $16,%%mm5\n\t" \
+ "psubw %%mm3,%%mm0\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ "paddw %%mm1,%%mm0\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "paddw %%mm4,%%mm0\n\t" \
+ /*mm6={0x00000E3D}x2 \
+   mm1=-(t0''==0), mm5:mm4=t0''*27146+0x4000*/ \
+ "movq %%mm2,%%mm4\n\t" \
+ "movq %%mm2,%%mm5\n\t" \
+ "punpcklwd %%mm6,%%mm4\n\t" \
+ "mov $0x0E3D,%[a]\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "punpckhwd %%mm6,%%mm5\n\t" \
+ "movd %[a],%%mm6\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "pxor %%mm1,%%mm1\n\t" \
+ "punpckldq %%mm6,%%mm6\n\t" \
+ "pcmpeqw %%mm2,%%mm1\n\t" \
+ /*mm4=r=(t0''*27146+0x4000>>16)+t0''+(t0''!=0)*/ \
+ "psrad $16,%%mm4\n\t" \
+ "psubw %%mm3,%%mm1\n\t" \
+ "psrad $16,%%mm5\n\t" \
+ "paddw %%mm1,%%mm2\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ "movq "_r5"(%[y]),%%mm1\n\t" \
+ "paddw %%mm2,%%mm4\n\t" \
+ /*mm2=t6'', mm0=_y[0]=u=r+s>>1 \
+   The naive implementation could cause overflow, so we use \
+    u=(r&s)+((r^s)>>1).*/ \
+ "movq "_r3"(%[y]),%%mm2\n\t" \
+ "movq %%mm0,%%mm7\n\t" \
+ "pxor %%mm4,%%mm0\n\t" \
+ "pand %%mm4,%%mm7\n\t" \
+ "psraw $1,%%mm0\n\t" \
+ "mov $0x7FFF54DC,%[a]\n\t" \
+ "paddw %%mm7,%%mm0\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ /*mm7={54491-0x7FFF,0x7FFF}x2 \
+   mm4=_y[4]=v=r-u*/ \
+ "psubw %%mm0,%%mm4\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "movq %%mm4,"_r4"(%[y])\n\t" \
+ /*mm0=0, mm7={36410}x4 \
+   mm1=(t5'''!=0), mm5:mm4=54491*t5'''+0x0E3D*/ \
+ "movq %%mm1,%%mm4\n\t" \
+ "movq %%mm1,%%mm5\n\t" \
+ "punpcklwd %%mm1,%%mm4\n\t" \
+ "mov $0x8E3A8E3A,%[a]\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "movq %%mm0,"_r0"(%[y])\n\t" \
+ "punpckhwd %%mm1,%%mm5\n\t" \
+ "pxor %%mm0,%%mm0\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "pcmpeqw %%mm0,%%mm1\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "psubw %%mm3,%%mm1\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "paddd %%mm6,%%mm4\n\t" \
+ "paddd %%mm6,%%mm5\n\t" \
+ /*mm0=0 \
+   mm3:mm1=36410*t6'''+((t5'''!=0)<<16)*/ \
+ "movq %%mm2,%%mm6\n\t" \
+ "movq %%mm2,%%mm3\n\t" \
+ "pmulhw %%mm7,%%mm6\n\t" \
+ "paddw %%mm2,%%mm1\n\t" \
+ "pmullw %%mm7,%%mm3\n\t" \
+ "pxor %%mm0,%%mm0\n\t" \
+ "paddw %%mm1,%%mm6\n\t" \
+ "movq %%mm3,%%mm1\n\t" \
+ "punpckhwd %%mm6,%%mm3\n\t" \
+ "punpcklwd %%mm6,%%mm1\n\t" \
+ /*mm3={-1}x4, mm6={1}x4 \
+   mm4=_y[5]=u=(54491*t5'''+36410*t6'''+0x0E3D>>16)+(t5'''!=0)*/ \
+ "paddd %%mm3,%%mm5\n\t" \
+ "paddd %%mm1,%%mm4\n\t" \
+ "psrad $16,%%mm5\n\t" \
+ "pxor %%mm6,%%mm6\n\t" \
+ "psrad $16,%%mm4\n\t" \
+ "pcmpeqb %%mm3,%%mm3\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ "psubw %%mm3,%%mm6\n\t" \
+ /*mm1=t7'', mm7={26568,0x3400}x2 \
+   mm2=s=t6'''-(36410*u>>16)*/ \
+ "movq %%mm4,%%mm1\n\t" \
+ "mov $0x340067C8,%[a]\n\t" \
+ "pmulhw %%mm7,%%mm4\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "movq %%mm1,"_r5"(%[y])\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "paddw %%mm1,%%mm4\n\t" \
+ "movq "_r7"(%[y]),%%mm1\n\t" \
+ "psubw %%mm4,%%mm2\n\t" \
+ /*mm6={0x00007B1B}x2 \
+   mm0=(s!=0), mm5:mm4=s*26568+0x3400*/ \
+ "movq %%mm2,%%mm4\n\t" \
+ "movq %%mm2,%%mm5\n\t" \
+ "punpcklwd %%mm6,%%mm4\n\t" \
+ "pcmpeqw %%mm2,%%mm0\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "mov $0x7B1B,%[a]\n\t" \
+ "punpckhwd %%mm6,%%mm5\n\t" \
+ "movd %[a],%%mm6\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "psubw %%mm3,%%mm0\n\t" \
+ "punpckldq %%mm6,%%mm6\n\t" \
+ /*mm7={64277-0x7FFF,0x7FFF}x2 \
+   mm2=_y[3]=v=(s*26568+0x3400>>17)+s+(s!=0)*/ \
+ "psrad $17,%%mm4\n\t" \
+ "paddw %%mm0,%%mm2\n\t" \
+ "psrad $17,%%mm5\n\t" \
+ "mov $0x7FFF7B16,%[a]\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "paddw %%mm4,%%mm2\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ /*mm0=0, mm7={12785}x4 \
+   mm1=(t7''!=0), mm2=t4'', mm5:mm4=64277*t7''+0x7B1B*/ \
+ "movq %%mm1,%%mm4\n\t" \
+ "movq %%mm1,%%mm5\n\t" \
+ "movq %%mm2,"_r3"(%[y])\n\t" \
+ "punpcklwd %%mm1,%%mm4\n\t" \
+ "movq "_r1"(%[y]),%%mm2\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "mov $0x31F131F1,%[a]\n\t" \
+ "punpckhwd %%mm1,%%mm5\n\t" \
+ "pxor %%mm0,%%mm0\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "pcmpeqw %%mm0,%%mm1\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "psubw %%mm3,%%mm1\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "paddd %%mm6,%%mm4\n\t" \
+ "paddd %%mm6,%%mm5\n\t" \
+ /*mm3:mm1=12785*t4'''+((t7''!=0)<<16)*/ \
+ "movq %%mm2,%%mm6\n\t" \
+ "movq %%mm2,%%mm3\n\t" \
+ "pmulhw %%mm7,%%mm6\n\t" \
+ "pmullw %%mm7,%%mm3\n\t" \
+ "paddw %%mm1,%%mm6\n\t" \
+ "movq %%mm3,%%mm1\n\t" \
+ "punpckhwd %%mm6,%%mm3\n\t" \
+ "punpcklwd %%mm6,%%mm1\n\t" \
+ /*mm3={-1}x4, mm6={1}x4 \
+   mm4=_y[1]=u=(12785*t4'''+64277*t7''+0x7B1B>>16)+(t7''!=0)*/ \
+ "paddd %%mm3,%%mm5\n\t" \
+ "paddd %%mm1,%%mm4\n\t" \
+ "psrad $16,%%mm5\n\t" \
+ "pxor %%mm6,%%mm6\n\t" \
+ "psrad $16,%%mm4\n\t" \
+ "pcmpeqb %%mm3,%%mm3\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ "psubw %%mm3,%%mm6\n\t" \
+ /*mm1=t3'', mm7={20539,0x3000}x2 \
+   mm4=s=(12785*u>>16)-t4''*/ \
+ "movq %%mm4,"_r1"(%[y])\n\t" \
+ "pmulhw %%mm7,%%mm4\n\t" \
+ "mov $0x3000503B,%[a]\n\t" \
+ "movq "_r6"(%[y]),%%mm1\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "psubw %%mm2,%%mm4\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ /*mm6={0x00006CB7}x2 \
+   mm0=(s!=0), mm5:mm4=s*20539+0x3000*/ \
+ "movq %%mm4,%%mm5\n\t" \
+ "movq %%mm4,%%mm2\n\t" \
+ "punpcklwd %%mm6,%%mm4\n\t" \
+ "pcmpeqw %%mm2,%%mm0\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "mov $0x6CB7,%[a]\n\t" \
+ "punpckhwd %%mm6,%%mm5\n\t" \
+ "movd %[a],%%mm6\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "psubw %%mm3,%%mm0\n\t" \
+ "punpckldq %%mm6,%%mm6\n\t" \
+ /*mm7={60547-0x7FFF,0x7FFF}x2 \
+   mm2=_y[7]=v=(s*20539+0x3000>>20)+s+(s!=0)*/ \
+ "psrad $20,%%mm4\n\t" \
+ "paddw %%mm0,%%mm2\n\t" \
+ "psrad $20,%%mm5\n\t" \
+ "mov $0x7FFF6C84,%[a]\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "paddw %%mm4,%%mm2\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ /*mm0=0, mm7={25080}x4 \
+   mm2=t2'', mm5:mm4=60547*t3''+0x6CB7*/ \
+ "movq %%mm1,%%mm4\n\t" \
+ "movq %%mm1,%%mm5\n\t" \
+ "movq %%mm2,"_r7"(%[y])\n\t" \
+ "punpcklwd %%mm1,%%mm4\n\t" \
+ "movq "_r2"(%[y]),%%mm2\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "mov $0x61F861F8,%[a]\n\t" \
+ "punpckhwd %%mm1,%%mm5\n\t" \
+ "pxor %%mm0,%%mm0\n\t" \
+ "pmaddwd %%mm7,%%mm5\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "pcmpeqw %%mm0,%%mm1\n\t" \
+ "psubw %%mm3,%%mm1\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "paddd %%mm6,%%mm4\n\t" \
+ "paddd %%mm6,%%mm5\n\t" \
+ /*mm3:mm1=25080*t2''+((t3''!=0)<<16)*/ \
+ "movq %%mm2,%%mm6\n\t" \
+ "movq %%mm2,%%mm3\n\t" \
+ "pmulhw %%mm7,%%mm6\n\t" \
+ "pmullw %%mm7,%%mm3\n\t" \
+ "paddw %%mm1,%%mm6\n\t" \
+ "movq %%mm3,%%mm1\n\t" \
+ "punpckhwd %%mm6,%%mm3\n\t" \
+ "punpcklwd %%mm6,%%mm1\n\t" \
+ /*mm1={-1}x4 \
+   mm4=u=(25080*t2''+60547*t3''+0x6CB7>>16)+(t3''!=0)*/ \
+ "paddd %%mm3,%%mm5\n\t" \
+ "paddd %%mm1,%%mm4\n\t" \
+ "psrad $16,%%mm5\n\t" \
+ "mov $0x28005460,%[a]\n\t" \
+ "psrad $16,%%mm4\n\t" \
+ "pcmpeqb %%mm1,%%mm1\n\t" \
+ "packssdw %%mm5,%%mm4\n\t" \
+ /*mm5={1}x4, mm6=_y[2]=u, mm7={21600,0x2800}x2 \
+   mm4=s=(25080*u>>16)-t2''*/ \
+ "movq %%mm4,%%mm6\n\t" \
+ "pmulhw %%mm7,%%mm4\n\t" \
+ "pxor %%mm5,%%mm5\n\t" \
+ "movd %[a],%%mm7\n\t" \
+ "psubw %%mm1,%%mm5\n\t" \
+ "punpckldq %%mm7,%%mm7\n\t" \
+ "psubw %%mm2,%%mm4\n\t" \
+ /*mm2=s+(s!=0) \
+   mm4:mm3=s*21600+0x2800*/ \
+ "movq %%mm4,%%mm3\n\t" \
+ "movq %%mm4,%%mm2\n\t" \
+ "punpckhwd %%mm5,%%mm4\n\t" \
+ "pcmpeqw %%mm2,%%mm0\n\t" \
+ "pmaddwd %%mm7,%%mm4\n\t" \
+ "psubw %%mm1,%%mm0\n\t" \
+ "punpcklwd %%mm5,%%mm3\n\t" \
+ "paddw %%mm0,%%mm2\n\t" \
+ "pmaddwd %%mm7,%%mm3\n\t" \
+ /*mm0=_y[4], mm1=_y[7], mm4=_y[0], mm5=_y[5] \
+   mm3=_y[6]=v=(s*21600+0x2800>>18)+s+(s!=0)*/ \
+ "movq "_r4"(%[y]),%%mm0\n\t" \
+ "psrad $18,%%mm4\n\t" \
+ "movq "_r5"(%[y]),%%mm5\n\t" \
+ "psrad $18,%%mm3\n\t" \
+ "movq "_r7"(%[y]),%%mm1\n\t" \
+ "packssdw %%mm4,%%mm3\n\t" \
+ "movq "_r0"(%[y]),%%mm4\n\t" \
+ "paddw %%mm2,%%mm3\n\t" \
+
+/*On input, mm4=_y[0], mm6=_y[2], mm0=_y[4], mm5=_y[5], mm3=_y[6], mm1=_y[7].
+  On output, {_y[4],mm1,mm2,mm3} contains the transpose of _y[4...7] and
+   {mm4,mm5,mm6,mm7} contains the transpose of _y[0...3].*/
+# define OC_TRANSPOSE8x4(_r0,_r1,_r2,_r3,_r4,_r5,_r6,_r7) \
+ "#OC_TRANSPOSE8x4\n\t" \
+ /*First 4x4 transpose:*/ \
+ /*mm0 = e3 e2 e1 e0 \
+   mm5 = f3 f2 f1 f0 \
+   mm3 = g3 g2 g1 g0 \
+   mm1 = h3 h2 h1 h0*/ \
+ "movq %%mm0,%%mm2\n\t" \
+ "punpcklwd %%mm5,%%mm0\n\t" \
+ "punpckhwd %%mm5,%%mm2\n\t" \
+ "movq %%mm3,%%mm5\n\t" \
+ "punpcklwd %%mm1,%%mm3\n\t" \
+ "punpckhwd %%mm1,%%mm5\n\t" \
+ /*mm0 = f1 e1 f0 e0 \
+   mm2 = f3 e3 f2 e2 \
+   mm3 = h1 g1 h0 g0 \
+   mm5 = h3 g3 h2 g2*/ \
+ "movq %%mm0,%%mm1\n\t" \
+ "punpckldq %%mm3,%%mm0\n\t" \
+ "movq %%mm0,"_r4"(%[y])\n\t" \
+ "punpckhdq %%mm3,%%mm1\n\t" \
+ "movq "_r1"(%[y]),%%mm0\n\t" \
+ "movq %%mm2,%%mm3\n\t" \
+ "punpckldq %%mm5,%%mm2\n\t" \
+ "punpckhdq %%mm5,%%mm3\n\t" \
+ "movq "_r3"(%[y]),%%mm5\n\t" \
+ /*_y[4] = h0 g0 f0 e0 \
+    mm1  = h1 g1 f1 e1 \
+    mm2  = h2 g2 f2 e2 \
+    mm3  = h3 g3 f3 e3*/ \
+ /*Second 4x4 transpose:*/ \
+ /*mm4 = a3 a2 a1 a0 \
+   mm0 = b3 b2 b1 b0 \
+   mm6 = c3 c2 c1 c0 \
+   mm5 = d3 d2 d1 d0*/ \
+ "movq %%mm4,%%mm7\n\t" \
+ "punpcklwd %%mm0,%%mm4\n\t" \
+ "punpckhwd %%mm0,%%mm7\n\t" \
+ "movq %%mm6,%%mm0\n\t" \
+ "punpcklwd %%mm5,%%mm6\n\t" \
+ "punpckhwd %%mm5,%%mm0\n\t" \
+ /*mm4 = b1 a1 b0 a0 \
+   mm7 = b3 a3 b2 a2 \
+   mm6 = d1 c1 d0 c0 \
+   mm0 = d3 c3 d2 c2*/ \
+ "movq %%mm4,%%mm5\n\t" \
+ "punpckldq %%mm6,%%mm4\n\t" \
+ "punpckhdq %%mm6,%%mm5\n\t" \
+ "movq %%mm7,%%mm6\n\t" \
+ "punpckhdq %%mm0,%%mm7\n\t" \
+ "punpckldq %%mm0,%%mm6\n\t" \
+ /*mm4 = d0 c0 b0 a0 \
+   mm5 = d1 c1 b1 a1 \
+   mm6 = d2 c2 b2 a2 \
+   mm7 = d3 c3 b3 a3*/ \
+
+/*MMX implementation of the fDCT.*/
+void oc_enc_fdct8x8_mmx(ogg_int16_t _y[64],const ogg_int16_t _x[64]){
+  ptrdiff_t a;
+  __asm__ __volatile__(
+    /*Add two extra bits of working precision to improve accuracy; any more and
+       we could overflow.*/
+    /*We also add biases to correct for some systematic error that remains in
+       the full fDCT->iDCT round trip.*/
+    "movq 0x00(%[x]),%%mm0\n\t"
+    "movq 0x10(%[x]),%%mm1\n\t"
+    "movq 0x20(%[x]),%%mm2\n\t"
+    "movq 0x30(%[x]),%%mm3\n\t"
+    "pcmpeqb %%mm4,%%mm4\n\t"
+    "pxor %%mm7,%%mm7\n\t"
+    "movq %%mm0,%%mm5\n\t"
+    "psllw $2,%%mm0\n\t"
+    "pcmpeqw %%mm7,%%mm5\n\t"
+    "movq 0x70(%[x]),%%mm7\n\t"
+    "psllw $2,%%mm1\n\t"
+    "psubw %%mm4,%%mm5\n\t"
+    "psllw $2,%%mm2\n\t"
+    "mov $1,%[a]\n\t"
+    "pslld $16,%%mm5\n\t"
+    "movd %[a],%%mm6\n\t"
+    "psllq $16,%%mm5\n\t"
+    "mov $0x10001,%[a]\n\t"
+    "psllw $2,%%mm3\n\t"
+    "movd %[a],%%mm4\n\t"
+    "punpckhwd %%mm6,%%mm5\n\t"
+    "psubw %%mm6,%%mm1\n\t"
+    "movq 0x60(%[x]),%%mm6\n\t"
+    "paddw %%mm5,%%mm0\n\t"
+    "movq 0x50(%[x]),%%mm5\n\t"
+    "paddw %%mm4,%%mm0\n\t"
+    "movq 0x40(%[x]),%%mm4\n\t"
+    /*We inline stage1 of the transform here so we can get better instruction
+       scheduling with the shifts.*/
+    /*mm0=t7'=t0-t7*/
+    "psllw $2,%%mm7\n\t"
+    "psubw %%mm7,%%mm0\n\t"
+    "psllw $2,%%mm6\n\t"
+    "paddw %%mm7,%%mm7\n\t"
+    /*mm1=t6'=t1-t6*/
+    "psllw $2,%%mm5\n\t"
+    "psubw %%mm6,%%mm1\n\t"
+    "psllw $2,%%mm4\n\t"
+    "paddw %%mm6,%%mm6\n\t"
+    /*mm2=t5'=t2-t5*/
+    "psubw %%mm5,%%mm2\n\t"
+    "paddw %%mm5,%%mm5\n\t"
+    /*mm3=t4'=t3-t4*/
+    "psubw %%mm4,%%mm3\n\t"
+    "paddw %%mm4,%%mm4\n\t"
+    /*mm7=t0'=t0+t7*/
+    "paddw %%mm0,%%mm7\n\t"
+    /*mm6=t1'=t1+t6*/
+    "paddw %%mm1,%%mm6\n\t"
+    /*mm5=t2'=t2+t5*/
+    "paddw %%mm2,%%mm5\n\t"
+    /*mm4=t3'=t3+t4*/
+    "paddw %%mm3,%%mm4\n\t"
+    OC_FDCT8x4("0x00","0x10","0x20","0x30","0x40","0x50","0x60","0x70")
+    OC_TRANSPOSE8x4("0x00","0x10","0x20","0x30","0x40","0x50","0x60","0x70")
+    /*Swap out this 8x4 block for the next one.*/
+    "movq 0x08(%[x]),%%mm0\n\t"
+    "movq %%mm7,0x30(%[y])\n\t"
+    "movq 0x78(%[x]),%%mm7\n\t"
+    "movq %%mm1,0x50(%[y])\n\t"
+    "movq 0x18(%[x]),%%mm1\n\t"
+    "movq %%mm6,0x20(%[y])\n\t"
+    "movq 0x68(%[x]),%%mm6\n\t"
+    "movq %%mm2,0x60(%[y])\n\t"
+    "movq 0x28(%[x]),%%mm2\n\t"
+    "movq %%mm5,0x10(%[y])\n\t"
+    "movq 0x58(%[x]),%%mm5\n\t"
+    "movq %%mm3,0x70(%[y])\n\t"
+    "movq 0x38(%[x]),%%mm3\n\t"
+    /*And increase its working precision, too.*/
+    "psllw $2,%%mm0\n\t"
+    "movq %%mm4,0x00(%[y])\n\t"
+    "psllw $2,%%mm7\n\t"
+    "movq 0x48(%[x]),%%mm4\n\t"
+    /*We inline stage1 of the transform here so we can get better instruction
+       scheduling with the shifts.*/
+    /*mm0=t7'=t0-t7*/
+    "psubw %%mm7,%%mm0\n\t"
+    "psllw $2,%%mm1\n\t"
+    "paddw %%mm7,%%mm7\n\t"
+    "psllw $2,%%mm6\n\t"
+    /*mm1=t6'=t1-t6*/
+    "psubw %%mm6,%%mm1\n\t"
+    "psllw $2,%%mm2\n\t"
+    "paddw %%mm6,%%mm6\n\t"
+    "psllw $2,%%mm5\n\t"
+    /*mm2=t5'=t2-t5*/
+    "psubw %%mm5,%%mm2\n\t"
+    "psllw $2,%%mm3\n\t"
+    "paddw %%mm5,%%mm5\n\t"
+    "psllw $2,%%mm4\n\t"
+    /*mm3=t4'=t3-t4*/
+    "psubw %%mm4,%%mm3\n\t"
+    "paddw %%mm4,%%mm4\n\t"
+    /*mm7=t0'=t0+t7*/
+    "paddw %%mm0,%%mm7\n\t"
+    /*mm6=t1'=t1+t6*/
+    "paddw %%mm1,%%mm6\n\t"
+    /*mm5=t2'=t2+t5*/
+    "paddw %%mm2,%%mm5\n\t"
+    /*mm4=t3'=t3+t4*/
+    "paddw %%mm3,%%mm4\n\t"
+    OC_FDCT8x4("0x08","0x18","0x28","0x38","0x48","0x58","0x68","0x78")
+    OC_TRANSPOSE8x4("0x08","0x18","0x28","0x38","0x48","0x58","0x68","0x78")
+    /*Here the first 4x4 block of output from the last transpose is the second
+       4x4 block of input for the next transform.
+      We have cleverly arranged that it already be in the appropriate place,
+       so we only have to do half the stores and loads.*/
+    "movq 0x00(%[y]),%%mm0\n\t"
+    "movq %%mm1,0x58(%[y])\n\t"
+    "movq 0x10(%[y]),%%mm1\n\t"
+    "movq %%mm2,0x68(%[y])\n\t"
+    "movq 0x20(%[y]),%%mm2\n\t"
+    "movq %%mm3,0x78(%[y])\n\t"
+    "movq 0x30(%[y]),%%mm3\n\t"
+    OC_FDCT_STAGE1_8x4
+    OC_FDCT8x4("0x00","0x10","0x20","0x30","0x08","0x18","0x28","0x38")
+    OC_TRANSPOSE8x4("0x00","0x10","0x20","0x30","0x08","0x18","0x28","0x38")
+    /*mm0={-2}x4*/
+    "pcmpeqw %%mm0,%%mm0\n\t"
+    "paddw %%mm0,%%mm0\n\t"
+    /*Round the results.*/
+    "psubw %%mm0,%%mm1\n\t"
+    "psubw %%mm0,%%mm2\n\t"
+    "psraw $2,%%mm1\n\t"
+    "psubw %%mm0,%%mm3\n\t"
+    "movq %%mm1,0x18(%[y])\n\t"
+    "psraw $2,%%mm2\n\t"
+    "psubw %%mm0,%%mm4\n\t"
+    "movq 0x08(%[y]),%%mm1\n\t"
+    "psraw $2,%%mm3\n\t"
+    "psubw %%mm0,%%mm5\n\t"
+    "psraw $2,%%mm4\n\t"
+    "psubw %%mm0,%%mm6\n\t"
+    "psraw $2,%%mm5\n\t"
+    "psubw %%mm0,%%mm7\n\t"
+    "psraw $2,%%mm6\n\t"
+    "psubw %%mm0,%%mm1\n\t"
+    "psraw $2,%%mm7\n\t"
+    "movq 0x40(%[y]),%%mm0\n\t"
+    "psraw $2,%%mm1\n\t"
+    "movq %%mm7,0x30(%[y])\n\t"
+    "movq 0x78(%[y]),%%mm7\n\t"
+    "movq %%mm1,0x08(%[y])\n\t"
+    "movq 0x50(%[y]),%%mm1\n\t"
+    "movq %%mm6,0x20(%[y])\n\t"
+    "movq 0x68(%[y]),%%mm6\n\t"
+    "movq %%mm2,0x28(%[y])\n\t"
+    "movq 0x60(%[y]),%%mm2\n\t"
+    "movq %%mm5,0x10(%[y])\n\t"
+    "movq 0x58(%[y]),%%mm5\n\t"
+    "movq %%mm3,0x38(%[y])\n\t"
+    "movq 0x70(%[y]),%%mm3\n\t"
+    "movq %%mm4,0x00(%[y])\n\t"
+    "movq 0x48(%[y]),%%mm4\n\t"
+    OC_FDCT_STAGE1_8x4
+    OC_FDCT8x4("0x40","0x50","0x60","0x70","0x48","0x58","0x68","0x78")
+    OC_TRANSPOSE8x4("0x40","0x50","0x60","0x70","0x48","0x58","0x68","0x78")
+    /*mm0={-2}x4*/
+    "pcmpeqw %%mm0,%%mm0\n\t"
+    "paddw %%mm0,%%mm0\n\t"
+    /*Round the results.*/
+    "psubw %%mm0,%%mm1\n\t"
+    "psubw %%mm0,%%mm2\n\t"
+    "psraw $2,%%mm1\n\t"
+    "psubw %%mm0,%%mm3\n\t"
+    "movq %%mm1,0x58(%[y])\n\t"
+    "psraw $2,%%mm2\n\t"
+    "psubw %%mm0,%%mm4\n\t"
+    "movq 0x48(%[y]),%%mm1\n\t"
+    "psraw $2,%%mm3\n\t"
+    "psubw %%mm0,%%mm5\n\t"
+    "movq %%mm2,0x68(%[y])\n\t"
+    "psraw $2,%%mm4\n\t"
+    "psubw %%mm0,%%mm6\n\t"
+    "movq %%mm3,0x78(%[y])\n\t"
+    "psraw $2,%%mm5\n\t"
+    "psubw %%mm0,%%mm7\n\t"
+    "movq %%mm4,0x40(%[y])\n\t"
+    "psraw $2,%%mm6\n\t"
+    "psubw %%mm0,%%mm1\n\t"
+    "movq %%mm5,0x50(%[y])\n\t"
+    "psraw $2,%%mm7\n\t"
+    "movq %%mm6,0x60(%[y])\n\t"
+    "psraw $2,%%mm1\n\t"
+    "movq %%mm7,0x70(%[y])\n\t"
+    "movq %%mm1,0x48(%[y])\n\t"
+    :[a]"=&r"(a)
+    :[y]"r"(_y),[x]"r"(_x)
+    :"memory"
+  );
+}
+
+#endif
diff --git a/lib/x86/mmxfrag.c b/lib/x86/mmxfrag.c
new file mode 100644 (file)
index 0000000..2c73293
--- /dev/null
@@ -0,0 +1,293 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: mmxfrag.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+/*MMX acceleration of fragment reconstruction for motion compensation.
+  Originally written by Rudolf Marek.
+  Additional optimization by Nils Pipenbrinck.
+  Note: Loops are unrolled for best performance.
+  The iteration each instruction belongs to is marked in the comments as #i.*/
+#include <stddef.h>
+#include "x86int.h"
+#include "mmxfrag.h"
+
+#if defined(OC_X86_ASM)
+
+/*Copies an 8x8 block of pixels from _src to _dst, assuming _ystride bytes
+   between rows.*/
+void oc_frag_copy_mmx(unsigned char *_dst,
+ const unsigned char *_src,int _ystride){
+  OC_FRAG_COPY_MMX(_dst,_src,_ystride);
+}
+
+void oc_frag_recon_intra_mmx(unsigned char *_dst,int _ystride,
+ const ogg_int16_t *_residue){
+  __asm__ __volatile__(
+    /*Set mm0 to 0xFFFFFFFFFFFFFFFF.*/
+    "pcmpeqw %%mm0,%%mm0\n\t"
+    /*#0 Load low residue.*/
+    "movq 0*8(%[residue]),%%mm1\n\t"
+    /*#0 Load high residue.*/
+    "movq 1*8(%[residue]),%%mm2\n\t"
+    /*Set mm0 to 0x8000800080008000.*/
+    "psllw $15,%%mm0\n\t"
+    /*#1 Load low residue.*/
+    "movq 2*8(%[residue]),%%mm3\n\t"
+    /*#1 Load high residue.*/
+    "movq 3*8(%[residue]),%%mm4\n\t"
+    /*Set mm0 to 0x0080008000800080.*/
+    "psrlw $8,%%mm0\n\t"
+    /*#2 Load low residue.*/
+    "movq 4*8(%[residue]),%%mm5\n\t"
+    /*#2 Load high residue.*/
+    "movq 5*8(%[residue]),%%mm6\n\t"
+    /*#0 Bias low  residue.*/
+    "paddsw %%mm0,%%mm1\n\t"
+    /*#0 Bias high residue.*/
+    "paddsw %%mm0,%%mm2\n\t"
+    /*#0 Pack to byte.*/
+    "packuswb %%mm2,%%mm1\n\t"
+    /*#1 Bias low  residue.*/
+    "paddsw %%mm0,%%mm3\n\t"
+    /*#1 Bias high residue.*/
+    "paddsw %%mm0,%%mm4\n\t"
+    /*#1 Pack to byte.*/
+    "packuswb %%mm4,%%mm3\n\t"
+    /*#2 Bias low  residue.*/
+    "paddsw %%mm0,%%mm5\n\t"
+    /*#2 Bias high residue.*/
+    "paddsw %%mm0,%%mm6\n\t"
+    /*#2 Pack to byte.*/
+    "packuswb %%mm6,%%mm5\n\t"
+    /*#0 Write row.*/
+    "movq %%mm1,(%[dst])\n\t"
+    /*#1 Write row.*/
+    "movq %%mm3,(%[dst],%[ystride])\n\t"
+    /*#2 Write row.*/
+    "movq %%mm5,(%[dst],%[ystride],2)\n\t"
+    /*#3 Load low residue.*/
+    "movq 6*8(%[residue]),%%mm1\n\t"
+    /*#3 Load high residue.*/
+    "movq 7*8(%[residue]),%%mm2\n\t"
+    /*#4 Load high residue.*/
+    "movq 8*8(%[residue]),%%mm3\n\t"
+    /*#4 Load high residue.*/
+    "movq 9*8(%[residue]),%%mm4\n\t"
+    /*#5 Load high residue.*/
+    "movq 10*8(%[residue]),%%mm5\n\t"
+    /*#5 Load high residue.*/
+    "movq 11*8(%[residue]),%%mm6\n\t"
+    /*#3 Bias low  residue.*/
+    "paddsw %%mm0,%%mm1\n\t"
+    /*#3 Bias high residue.*/
+    "paddsw %%mm0,%%mm2\n\t"
+    /*#3 Pack to byte.*/
+    "packuswb %%mm2,%%mm1\n\t"
+    /*#4 Bias low  residue.*/
+    "paddsw %%mm0,%%mm3\n\t"
+    /*#4 Bias high residue.*/
+    "paddsw %%mm0,%%mm4\n\t"
+    /*#4 Pack to byte.*/
+    "packuswb %%mm4,%%mm3\n\t"
+    /*#5 Bias low  residue.*/
+    "paddsw %%mm0,%%mm5\n\t"
+    /*#5 Bias high residue.*/
+    "paddsw %%mm0,%%mm6\n\t"
+    /*#5 Pack to byte.*/
+    "packuswb %%mm6,%%mm5\n\t"
+    /*#3 Write row.*/
+    "movq %%mm1,(%[dst],%[ystride3])\n\t"
+    /*#4 Write row.*/
+    "movq %%mm3,(%[dst4])\n\t"
+    /*#5 Write row.*/
+    "movq %%mm5,(%[dst4],%[ystride])\n\t"
+    /*#6 Load low residue.*/
+    "movq 12*8(%[residue]),%%mm1\n\t"
+    /*#6 Load high residue.*/
+    "movq 13*8(%[residue]),%%mm2\n\t"
+    /*#7 Load low residue.*/
+    "movq 14*8(%[residue]),%%mm3\n\t"
+    /*#7 Load high residue.*/
+    "movq 15*8(%[residue]),%%mm4\n\t"
+    /*#6 Bias low  residue.*/
+    "paddsw %%mm0,%%mm1\n\t"
+    /*#6 Bias high residue.*/
+    "paddsw %%mm0,%%mm2\n\t"
+    /*#6 Pack to byte.*/
+    "packuswb %%mm2,%%mm1\n\t"
+    /*#7 Bias low  residue.*/
+    "paddsw %%mm0,%%mm3\n\t"
+    /*#7 Bias high residue.*/
+    "paddsw %%mm0,%%mm4\n\t"
+    /*#7 Pack to byte.*/
+    "packuswb %%mm4,%%mm3\n\t"
+    /*#6 Write row.*/
+    "movq %%mm1,(%[dst4],%[ystride],2)\n\t"
+    /*#7 Write row.*/
+    "movq %%mm3,(%[dst4],%[ystride3])\n\t"
+    :
+    :[residue]"r"(_residue),
+     [dst]"r"(_dst),
+     [dst4]"r"(_dst+(_ystride<<2)),
+     [ystride]"r"((ptrdiff_t)_ystride),
+     [ystride3]"r"((ptrdiff_t)_ystride*3)
+    :"memory"
+  );
+}
+
+void oc_frag_recon_inter_mmx(unsigned char *_dst,const unsigned char *_src,
+ int _ystride,const ogg_int16_t *_residue){
+  int i;
+  /*Zero mm0.*/
+  __asm__ __volatile__("pxor %%mm0,%%mm0\n\t"::);
+  for(i=4;i-->0;){
+    __asm__ __volatile__(
+      /*#0 Load source.*/
+      "movq (%[src]),%%mm3\n\t"
+      /*#1 Load source.*/
+      "movq (%[src],%[ystride]),%%mm7\n\t"
+      /*#0 Get copy of src.*/
+      "movq %%mm3,%%mm4\n\t"
+      /*#0 Expand high source.*/
+      "punpckhbw %%mm0,%%mm4\n\t"
+      /*#0 Expand low  source.*/
+      "punpcklbw %%mm0,%%mm3\n\t"
+      /*#0 Add residue high.*/
+      "paddsw 8(%[residue]),%%mm4\n\t"
+      /*#1 Get copy of src.*/
+      "movq %%mm7,%%mm2\n\t"
+      /*#0 Add residue low.*/
+      "paddsw (%[residue]), %%mm3\n\t"
+      /*#1 Expand high source.*/
+      "punpckhbw %%mm0,%%mm2\n\t"
+      /*#0 Pack final row pixels.*/
+      "packuswb %%mm4,%%mm3\n\t"
+      /*#1 Expand low  source.*/
+      "punpcklbw %%mm0,%%mm7\n\t"
+      /*#1 Add residue low.*/
+      "paddsw 16(%[residue]),%%mm7\n\t"
+      /*#1 Add residue high.*/
+      "paddsw 24(%[residue]),%%mm2\n\t"
+      /*Advance residue.*/
+      "lea 32(%[residue]),%[residue]\n\t"
+      /*#1 Pack final row pixels.*/
+      "packuswb %%mm2,%%mm7\n\t"
+      /*Advance src.*/
+      "lea (%[src],%[ystride],2),%[src]\n\t"
+      /*#0 Write row.*/
+      "movq %%mm3,(%[dst])\n\t"
+      /*#1 Write row.*/
+      "movq %%mm7,(%[dst],%[ystride])\n\t"
+      /*Advance dst.*/
+      "lea (%[dst],%[ystride],2),%[dst]\n\t"
+      :[residue]"+r"(_residue),[dst]"+r"(_dst),[src]"+r"(_src)
+      :[ystride]"r"((ptrdiff_t)_ystride)
+      :"memory"
+    );
+  }
+}
+
+void oc_frag_recon_inter2_mmx(unsigned char *_dst,const unsigned char *_src1,
+ const unsigned char *_src2,int _ystride,const ogg_int16_t *_residue){
+  int i;
+  /*Zero mm7.*/
+  __asm__ __volatile__("pxor %%mm7,%%mm7\n\t"::);
+  for(i=4;i-->0;){
+    __asm__ __volatile__(
+      /*#0 Load src1.*/
+      "movq (%[src1]),%%mm0\n\t"
+      /*#0 Load src2.*/
+      "movq (%[src2]),%%mm2\n\t"
+      /*#0 Copy src1.*/
+      "movq %%mm0,%%mm1\n\t"
+      /*#0 Copy src2.*/
+      "movq %%mm2,%%mm3\n\t"
+      /*#1 Load src1.*/
+      "movq (%[src1],%[ystride]),%%mm4\n\t"
+      /*#0 Unpack lower src1.*/
+      "punpcklbw %%mm7,%%mm0\n\t"
+      /*#1 Load src2.*/
+      "movq (%[src2],%[ystride]),%%mm5\n\t"
+      /*#0 Unpack higher src1.*/
+      "punpckhbw %%mm7,%%mm1\n\t"
+      /*#0 Unpack lower src2.*/
+      "punpcklbw %%mm7,%%mm2\n\t"
+      /*#0 Unpack higher src2.*/
+      "punpckhbw %%mm7,%%mm3\n\t"
+      /*Advance src1 ptr.*/
+      "lea (%[src1],%[ystride],2),%[src1]\n\t"
+      /*Advance src2 ptr.*/
+      "lea (%[src2],%[ystride],2),%[src2]\n\t"
+      /*#0 Lower src1+src2.*/
+      "paddsw %%mm2,%%mm0\n\t"
+      /*#0 Higher src1+src2.*/
+      "paddsw %%mm3,%%mm1\n\t"
+      /*#1 Copy src1.*/
+      "movq %%mm4,%%mm2\n\t"
+      /*#0 Build lo average.*/
+      "psraw $1,%%mm0\n\t"
+      /*#1 Copy src2.*/
+      "movq %%mm5,%%mm3\n\t"
+      /*#1 Unpack lower src1.*/
+      "punpcklbw %%mm7,%%mm4\n\t"
+      /*#0 Build hi average.*/
+      "psraw $1,%%mm1\n\t"
+      /*#1 Unpack higher src1.*/
+      "punpckhbw %%mm7,%%mm2\n\t"
+      /*#0 low+=residue.*/
+      "paddsw (%[residue]),%%mm0\n\t"
+      /*#1 Unpack lower src2.*/
+      "punpcklbw %%mm7,%%mm5\n\t"
+      /*#0 high+=residue.*/
+      "paddsw 8(%[residue]),%%mm1\n\t"
+      /*#1 Unpack higher src2.*/
+      "punpckhbw %%mm7,%%mm3\n\t"
+      /*#1 Lower src1+src2.*/
+      "paddsw %%mm4,%%mm5\n\t"
+      /*#0 Pack and saturate.*/
+      "packuswb %%mm1,%%mm0\n\t"
+      /*#1 Higher src1+src2.*/
+      "paddsw %%mm2,%%mm3\n\t"
+      /*#0 Write row.*/
+      "movq %%mm0,(%[dst])\n\t"
+      /*#1 Build lo average.*/
+      "psraw $1,%%mm5\n\t"
+      /*#1 Build hi average.*/
+      "psraw $1,%%mm3\n\t"
+      /*#1 low+=residue.*/
+      "paddsw 16(%[residue]),%%mm5\n\t"
+      /*#1 high+=residue.*/
+      "paddsw 24(%[residue]),%%mm3\n\t"
+      /*#1 Pack and saturate.*/
+      "packuswb  %%mm3,%%mm5\n\t"
+      /*#1 Write row ptr.*/
+      "movq %%mm5,(%[dst],%[ystride])\n\t"
+      /*Advance residue ptr.*/
+      "add $32,%[residue]\n\t"
+      /*Advance dest ptr.*/
+      "lea (%[dst],%[ystride],2),%[dst]\n\t"
+     :[dst]"+r"(_dst),[residue]"+r"(_residue),
+      [src1]"+%r"(_src1),[src2]"+r"(_src2)
+     :[ystride]"r"((ptrdiff_t)_ystride)
+     :"memory"
+    );
+  }
+}
+
+void oc_restore_fpu_mmx(void){
+  __asm__ __volatile__("emms\n\t");
+}
+#endif
diff --git a/lib/x86/mmxfrag.h b/lib/x86/mmxfrag.h
new file mode 100644 (file)
index 0000000..a398427
--- /dev/null
@@ -0,0 +1,64 @@
+#if !defined(_x86_mmxfrag_H)
+# define _x86_mmxfrag_H (1)
+# include <stddef.h>
+# include "x86int.h"
+
+#if defined(OC_X86_ASM)
+
+/*Copies an 8x8 block of pixels from _src to _dst, assuming _ystride bytes
+   between rows.*/
+#define OC_FRAG_COPY_MMX(_dst,_src,_ystride) \
+  do{ \
+    const unsigned char *src; \
+    unsigned char       *dst; \
+    ptrdiff_t            ystride3; \
+    src=(_src); \
+    dst=(_dst); \
+    __asm__ __volatile__( \
+      /*src+0*ystride*/ \
+      "movq (%[src]),%%mm0\n\t" \
+      /*src+1*ystride*/ \
+      "movq (%[src],%[ystride]),%%mm1\n\t" \
+      /*ystride3=ystride*3*/ \
+      "lea (%[ystride],%[ystride],2),%[ystride3]\n\t" \
+      /*src+2*ystride*/ \
+      "movq (%[src],%[ystride],2),%%mm2\n\t" \
+      /*src+3*ystride*/ \
+      "movq (%[src],%[ystride3]),%%mm3\n\t" \
+      /*dst+0*ystride*/ \
+      "movq %%mm0,(%[dst])\n\t" \
+      /*dst+1*ystride*/ \
+      "movq %%mm1,(%[dst],%[ystride])\n\t" \
+      /*Pointer to next 4.*/ \
+      "lea (%[src],%[ystride],4),%[src]\n\t" \
+      /*dst+2*ystride*/ \
+      "movq %%mm2,(%[dst],%[ystride],2)\n\t" \
+      /*dst+3*ystride*/ \
+      "movq %%mm3,(%[dst],%[ystride3])\n\t" \
+      /*Pointer to next 4.*/ \
+      "lea (%[dst],%[ystride],4),%[dst]\n\t" \
+      /*src+0*ystride*/ \
+      "movq (%[src]),%%mm0\n\t" \
+      /*src+1*ystride*/ \
+      "movq (%[src],%[ystride]),%%mm1\n\t" \
+      /*src+2*ystride*/ \
+      "movq (%[src],%[ystride],2),%%mm2\n\t" \
+      /*src+3*ystride*/ \
+      "movq (%[src],%[ystride3]),%%mm3\n\t" \
+      /*dst+0*ystride*/ \
+      "movq %%mm0,(%[dst])\n\t" \
+      /*dst+1*ystride*/ \
+      "movq %%mm1,(%[dst],%[ystride])\n\t" \
+      /*dst+2*ystride*/ \
+      "movq %%mm2,(%[dst],%[ystride],2)\n\t" \
+      /*dst+3*ystride*/ \
+      "movq %%mm3,(%[dst],%[ystride3])\n\t" \
+      :[dst]"+r"(dst),[src]"+r"(src),[ystride3]"=&r"(ystride3) \
+      :[ystride]"r"((ptrdiff_t)(_ystride)) \
+      :"memory" \
+    ); \
+  } \
+  while(0)
+
+# endif
+#endif
diff --git a/lib/x86/mmxidct.c b/lib/x86/mmxidct.c
new file mode 100644 (file)
index 0000000..76424e6
--- /dev/null
@@ -0,0 +1,564 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: mmxidct.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+/*MMX acceleration of Theora's iDCT.
+  Originally written by Rudolf Marek, based on code from On2's VP3.*/
+#include "x86int.h"
+#include "../dct.h"
+
+#if defined(OC_X86_ASM)
+
+/*These are offsets into the table of constants below.*/
+/*7 rows of cosines, in order: pi/16 * (1 ... 7).*/
+#define OC_COSINE_OFFSET (0)
+/*A row of 8's.*/
+#define OC_EIGHT_OFFSET  (56)
+
+
+
+/*A table of constants used by the MMX routines.*/
+static const ogg_uint16_t __attribute__((aligned(8),used))
+ OC_IDCT_CONSTS[(7+1)*4]={
+  (ogg_uint16_t)OC_C1S7,(ogg_uint16_t)OC_C1S7,
+  (ogg_uint16_t)OC_C1S7,(ogg_uint16_t)OC_C1S7,
+  (ogg_uint16_t)OC_C2S6,(ogg_uint16_t)OC_C2S6,
+  (ogg_uint16_t)OC_C2S6,(ogg_uint16_t)OC_C2S6,
+  (ogg_uint16_t)OC_C3S5,(ogg_uint16_t)OC_C3S5,
+  (ogg_uint16_t)OC_C3S5,(ogg_uint16_t)OC_C3S5,
+  (ogg_uint16_t)OC_C4S4,(ogg_uint16_t)OC_C4S4,
+  (ogg_uint16_t)OC_C4S4,(ogg_uint16_t)OC_C4S4,
+  (ogg_uint16_t)OC_C5S3,(ogg_uint16_t)OC_C5S3,
+  (ogg_uint16_t)OC_C5S3,(ogg_uint16_t)OC_C5S3,
+  (ogg_uint16_t)OC_C6S2,(ogg_uint16_t)OC_C6S2,
+  (ogg_uint16_t)OC_C6S2,(ogg_uint16_t)OC_C6S2,
+  (ogg_uint16_t)OC_C7S1,(ogg_uint16_t)OC_C7S1,
+  (ogg_uint16_t)OC_C7S1,(ogg_uint16_t)OC_C7S1,
+      8,    8,    8,    8
+};
+
+/*Converts the expression in the argument to a string.*/
+#define OC_M2STR(_s) #_s
+
+/*38 cycles*/
+#define OC_IDCT_BEGIN \
+  "#OC_IDCT_BEGIN\n\t" \
+  "movq "OC_I(3)",%%mm2\n\t" \
+  "movq "OC_C(3)",%%mm6\n\t" \
+  "movq %%mm2,%%mm4\n\t" \
+  "movq "OC_J(5)",%%mm7\n\t" \
+  "pmulhw %%mm6,%%mm4\n\t" \
+  "movq "OC_C(5)",%%mm1\n\t" \
+  "pmulhw %%mm7,%%mm6\n\t" \
+  "movq %%mm1,%%mm5\n\t" \
+  "pmulhw %%mm2,%%mm1\n\t" \
+  "movq "OC_I(1)",%%mm3\n\t" \
+  "pmulhw %%mm7,%%mm5\n\t" \
+  "movq "OC_C(1)",%%mm0\n\t" \
+  "paddw %%mm2,%%mm4\n\t" \
+  "paddw %%mm7,%%mm6\n\t" \
+  "paddw %%mm1,%%mm2\n\t" \
+  "movq "OC_J(7)",%%mm1\n\t" \
+  "paddw %%mm5,%%mm7\n\t" \
+  "movq %%mm0,%%mm5\n\t" \
+  "pmulhw %%mm3,%%mm0\n\t" \
+  "paddw %%mm7,%%mm4\n\t" \
+  "pmulhw %%mm1,%%mm5\n\t" \
+  "movq "OC_C(7)",%%mm7\n\t" \
+  "psubw %%mm2,%%mm6\n\t" \
+  "paddw %%mm3,%%mm0\n\t" \
+  "pmulhw %%mm7,%%mm3\n\t" \
+  "movq "OC_I(2)",%%mm2\n\t" \
+  "pmulhw %%mm1,%%mm7\n\t" \
+  "paddw %%mm1,%%mm5\n\t" \
+  "movq %%mm2,%%mm1\n\t" \
+  "pmulhw "OC_C(2)",%%mm2\n\t" \
+  "psubw %%mm5,%%mm3\n\t" \
+  "movq "OC_J(6)",%%mm5\n\t" \
+  "paddw %%mm7,%%mm0\n\t" \
+  "movq %%mm5,%%mm7\n\t" \
+  "psubw %%mm4,%%mm0\n\t" \
+  "pmulhw "OC_C(2)",%%mm5\n\t" \
+  "paddw %%mm1,%%mm2\n\t" \
+  "pmulhw "OC_C(6)",%%mm1\n\t" \
+  "paddw %%mm4,%%mm4\n\t" \
+  "paddw %%mm0,%%mm4\n\t" \
+  "psubw %%mm6,%%mm3\n\t" \
+  "paddw %%mm7,%%mm5\n\t" \
+  "paddw %%mm6,%%mm6\n\t" \
+  "pmulhw "OC_C(6)",%%mm7\n\t" \
+  "paddw %%mm3,%%mm6\n\t" \
+  "movq %%mm4,"OC_I(1)"\n\t" \
+  "psubw %%mm5,%%mm1\n\t" \
+  "movq "OC_C(4)",%%mm4\n\t" \
+  "movq %%mm3,%%mm5\n\t" \
+  "pmulhw %%mm4,%%mm3\n\t" \
+  "paddw %%mm2,%%mm7\n\t" \
+  "movq %%mm6,"OC_I(2)"\n\t" \
+  "movq %%mm0,%%mm2\n\t" \
+  "movq "OC_I(0)",%%mm6\n\t" \
+  "pmulhw %%mm4,%%mm0\n\t" \
+  "paddw %%mm3,%%mm5\n\t" \
+  "movq "OC_J(4)",%%mm3\n\t" \
+  "psubw %%mm1,%%mm5\n\t" \
+  "paddw %%mm0,%%mm2\n\t" \
+  "psubw %%mm3,%%mm6\n\t" \
+  "movq %%mm6,%%mm0\n\t" \
+  "pmulhw %%mm4,%%mm6\n\t" \
+  "paddw %%mm3,%%mm3\n\t" \
+  "paddw %%mm1,%%mm1\n\t" \
+  "paddw %%mm0,%%mm3\n\t" \
+  "paddw %%mm5,%%mm1\n\t" \
+  "pmulhw %%mm3,%%mm4\n\t" \
+  "paddw %%mm0,%%mm6\n\t" \
+  "psubw %%mm2,%%mm6\n\t" \
+  "paddw %%mm2,%%mm2\n\t" \
+  "movq "OC_I(1)",%%mm0\n\t" \
+  "paddw %%mm6,%%mm2\n\t" \
+  "paddw %%mm3,%%mm4\n\t" \
+  "psubw %%mm1,%%mm2\n\t" \
+  "#end OC_IDCT_BEGIN\n\t" \
+
+/*38+8=46 cycles.*/
+#define OC_ROW_IDCT \
+  "#OC_ROW_IDCT\n" \
+  OC_IDCT_BEGIN \
+  /*r3=D'*/ \
+  "movq "OC_I(2)",%%mm3\n\t" \
+  /*r4=E'=E-G*/ \
+  "psubw %%mm7,%%mm4\n\t" \
+  /*r1=H'+H'*/ \
+  "paddw %%mm1,%%mm1\n\t" \
+  /*r7=G+G*/ \
+  "paddw %%mm7,%%mm7\n\t" \
+  /*r1=R1=A''+H'*/ \
+  "paddw %%mm2,%%mm1\n\t" \
+  /*r7=G'=E+G*/ \
+  "paddw %%mm4,%%mm7\n\t" \
+  /*r4=R4=E'-D'*/ \
+  "psubw %%mm3,%%mm4\n\t" \
+  "paddw %%mm3,%%mm3\n\t" \
+  /*r6=R6=F'-B''*/ \
+  "psubw %%mm5,%%mm6\n\t" \
+  "paddw %%mm5,%%mm5\n\t" \
+  /*r3=R3=E'+D'*/ \
+  "paddw %%mm4,%%mm3\n\t" \
+  /*r5=R5=F'+B''*/ \
+  "paddw %%mm6,%%mm5\n\t" \
+  /*r7=R7=G'-C'*/ \
+  "psubw %%mm0,%%mm7\n\t" \
+  "paddw %%mm0,%%mm0\n\t" \
+  /*Save R1.*/ \
+  "movq %%mm1,"OC_I(1)"\n\t" \
+  /*r0=R0=G.+C.*/ \
+  "paddw %%mm7,%%mm0\n\t" \
+  "#end OC_ROW_IDCT\n\t" \
+
+/*The following macro does two 4x4 transposes in place.
+  At entry, we assume:
+    r0 = a3 a2 a1 a0
+  I(1) = b3 b2 b1 b0
+    r2 = c3 c2 c1 c0
+    r3 = d3 d2 d1 d0
+
+    r4 = e3 e2 e1 e0
+    r5 = f3 f2 f1 f0
+    r6 = g3 g2 g1 g0
+    r7 = h3 h2 h1 h0
+
+  At exit, we have:
+  I(0) = d0 c0 b0 a0
+  I(1) = d1 c1 b1 a1
+  I(2) = d2 c2 b2 a2
+  I(3) = d3 c3 b3 a3
+
+  J(4) = h0 g0 f0 e0
+  J(5) = h1 g1 f1 e1
+  J(6) = h2 g2 f2 e2
+  J(7) = h3 g3 f3 e3
+
+  I(0) I(1) I(2) I(3) is the transpose of r0 I(1) r2 r3.
+  J(4) J(5) J(6) J(7) is the transpose of r4  r5  r6 r7.
+
+  Since r1 is free at entry, we calculate the Js first.*/
+/*19 cycles.*/
+#define OC_TRANSPOSE \
+  "#OC_TRANSPOSE\n\t" \
+  "movq %%mm4,%%mm1\n\t" \
+  "punpcklwd %%mm5,%%mm4\n\t" \
+  "movq %%mm0,"OC_I(0)"\n\t" \
+  "punpckhwd %%mm5,%%mm1\n\t" \
+  "movq %%mm6,%%mm0\n\t" \
+  "punpcklwd %%mm7,%%mm6\n\t" \
+  "movq %%mm4,%%mm5\n\t" \
+  "punpckldq %%mm6,%%mm4\n\t" \
+  "punpckhdq %%mm6,%%mm5\n\t" \
+  "movq %%mm1,%%mm6\n\t" \
+  "movq %%mm4,"OC_J(4)"\n\t" \
+  "punpckhwd %%mm7,%%mm0\n\t" \
+  "movq %%mm5,"OC_J(5)"\n\t" \
+  "punpckhdq %%mm0,%%mm6\n\t" \
+  "movq "OC_I(0)",%%mm4\n\t" \
+  "punpckldq %%mm0,%%mm1\n\t" \
+  "movq "OC_I(1)",%%mm5\n\t" \
+  "movq %%mm4,%%mm0\n\t" \
+  "movq %%mm6,"OC_J(7)"\n\t" \
+  "punpcklwd %%mm5,%%mm0\n\t" \
+  "movq %%mm1,"OC_J(6)"\n\t" \
+  "punpckhwd %%mm5,%%mm4\n\t" \
+  "movq %%mm2,%%mm5\n\t" \
+  "punpcklwd %%mm3,%%mm2\n\t" \
+  "movq %%mm0,%%mm1\n\t" \
+  "punpckldq %%mm2,%%mm0\n\t" \
+  "punpckhdq %%mm2,%%mm1\n\t" \
+  "movq %%mm4,%%mm2\n\t" \
+  "movq %%mm0,"OC_I(0)"\n\t" \
+  "punpckhwd %%mm3,%%mm5\n\t" \
+  "movq %%mm1,"OC_I(1)"\n\t" \
+  "punpckhdq %%mm5,%%mm4\n\t" \
+  "punpckldq %%mm5,%%mm2\n\t" \
+  "movq %%mm4,"OC_I(3)"\n\t" \
+  "movq %%mm2,"OC_I(2)"\n\t" \
+  "#end OC_TRANSPOSE\n\t" \
+
+/*38+19=57 cycles.*/
+#define OC_COLUMN_IDCT \
+  "#OC_COLUMN_IDCT\n" \
+  OC_IDCT_BEGIN \
+  "paddw "OC_8",%%mm2\n\t" \
+  /*r1=H'+H'*/ \
+  "paddw %%mm1,%%mm1\n\t" \
+  /*r1=R1=A''+H'*/ \
+  "paddw %%mm2,%%mm1\n\t" \
+  /*r2=NR2*/ \
+  "psraw $4,%%mm2\n\t" \
+  /*r4=E'=E-G*/ \
+  "psubw %%mm7,%%mm4\n\t" \
+  /*r1=NR1*/ \
+  "psraw $4,%%mm1\n\t" \
+  /*r3=D'*/ \
+  "movq "OC_I(2)",%%mm3\n\t" \
+  /*r7=G+G*/ \
+  "paddw %%mm7,%%mm7\n\t" \
+  /*Store NR2 at I(2).*/ \
+  "movq %%mm2,"OC_I(2)"\n\t" \
+  /*r7=G'=E+G*/ \
+  "paddw %%mm4,%%mm7\n\t" \
+  /*Store NR1 at I(1).*/ \
+  "movq %%mm1,"OC_I(1)"\n\t" \
+  /*r4=R4=E'-D'*/ \
+  "psubw %%mm3,%%mm4\n\t" \
+  "paddw "OC_8",%%mm4\n\t" \
+  /*r3=D'+D'*/ \
+  "paddw %%mm3,%%mm3\n\t" \
+  /*r3=R3=E'+D'*/ \
+  "paddw %%mm4,%%mm3\n\t" \
+  /*r4=NR4*/ \
+  "psraw $4,%%mm4\n\t" \
+  /*r6=R6=F'-B''*/ \
+  "psubw %%mm5,%%mm6\n\t" \
+  /*r3=NR3*/ \
+  "psraw $4,%%mm3\n\t" \
+  "paddw "OC_8",%%mm6\n\t" \
+  /*r5=B''+B''*/ \
+  "paddw %%mm5,%%mm5\n\t" \
+  /*r5=R5=F'+B''*/ \
+  "paddw %%mm6,%%mm5\n\t" \
+  /*r6=NR6*/ \
+  "psraw $4,%%mm6\n\t" \
+  /*Store NR4 at J(4).*/ \
+  "movq %%mm4,"OC_J(4)"\n\t" \
+  /*r5=NR5*/ \
+  "psraw $4,%%mm5\n\t" \
+  /*Store NR3 at I(3).*/ \
+  "movq %%mm3,"OC_I(3)"\n\t" \
+  /*r7=R7=G'-C'*/ \
+  "psubw %%mm0,%%mm7\n\t" \
+  "paddw "OC_8",%%mm7\n\t" \
+  /*r0=C'+C'*/ \
+  "paddw %%mm0,%%mm0\n\t" \
+  /*r0=R0=G'+C'*/ \
+  "paddw %%mm7,%%mm0\n\t" \
+  /*r7=NR7*/ \
+  "psraw $4,%%mm7\n\t" \
+  /*Store NR6 at J(6).*/ \
+  "movq %%mm6,"OC_J(6)"\n\t" \
+  /*r0=NR0*/ \
+  "psraw $4,%%mm0\n\t" \
+  /*Store NR5 at J(5).*/ \
+  "movq %%mm5,"OC_J(5)"\n\t" \
+  /*Store NR7 at J(7).*/ \
+  "movq %%mm7,"OC_J(7)"\n\t" \
+  /*Store NR0 at I(0).*/ \
+  "movq %%mm0,"OC_I(0)"\n\t" \
+  "#end OC_COLUMN_IDCT\n\t" \
+
+#define OC_MID(_m,_i) OC_M2STR(_m+(_i)*8)"(%[c])"
+#define OC_C(_i)      OC_MID(OC_COSINE_OFFSET,_i-1)
+#define OC_8          OC_MID(OC_EIGHT_OFFSET,0)
+
+static void oc_idct8x8_slow(ogg_int16_t _y[64]){
+  /*This routine accepts an 8x8 matrix, but in partially transposed form.
+    Every 4x4 block is transposed.*/
+  __asm__ __volatile__(
+#define OC_I(_k)      OC_M2STR((_k*16))"(%[y])"
+#define OC_J(_k)      OC_M2STR(((_k-4)*16)+8)"(%[y])"
+    OC_ROW_IDCT
+    OC_TRANSPOSE
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k)      OC_M2STR((_k*16)+64)"(%[y])"
+#define OC_J(_k)      OC_M2STR(((_k-4)*16)+72)"(%[y])"
+    OC_ROW_IDCT
+    OC_TRANSPOSE
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k)      OC_M2STR((_k*16))"(%[y])"
+#define OC_J(_k)      OC_I(_k)
+    OC_COLUMN_IDCT
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k)      OC_M2STR((_k*16)+8)"(%[y])"
+#define OC_J(_k)      OC_I(_k)
+    OC_COLUMN_IDCT
+#undef  OC_I
+#undef  OC_J
+    :
+    :[y]"r"(_y),[c]"r"(OC_IDCT_CONSTS)
+  );
+}
+
+/*25 cycles.*/
+#define OC_IDCT_BEGIN_10 \
+ "#OC_IDCT_BEGIN_10\n\t" \
+ "movq "OC_I(3)",%%mm2\n\t" \
+ "nop\n\t" \
+ "movq "OC_C(3)",%%mm6\n\t" \
+ "movq %%mm2,%%mm4\n\t" \
+ "movq "OC_C(5)",%%mm1\n\t" \
+ "pmulhw %%mm6,%%mm4\n\t" \
+ "movq "OC_I(1)",%%mm3\n\t" \
+ "pmulhw %%mm2,%%mm1\n\t" \
+ "movq "OC_C(1)",%%mm0\n\t" \
+ "paddw %%mm2,%%mm4\n\t" \
+ "pxor %%mm6,%%mm6\n\t" \
+ "paddw %%mm1,%%mm2\n\t" \
+ "movq "OC_I(2)",%%mm5\n\t" \
+ "pmulhw %%mm3,%%mm0\n\t" \
+ "movq %%mm5,%%mm1\n\t" \
+ "paddw %%mm3,%%mm0\n\t" \
+ "pmulhw "OC_C(7)",%%mm3\n\t" \
+ "psubw %%mm2,%%mm6\n\t" \
+ "pmulhw "OC_C(2)",%%mm5\n\t" \
+ "psubw %%mm4,%%mm0\n\t" \
+ "movq "OC_I(2)",%%mm7\n\t" \
+ "paddw %%mm4,%%mm4\n\t" \
+ "paddw %%mm5,%%mm7\n\t" \
+ "paddw %%mm0,%%mm4\n\t" \
+ "pmulhw "OC_C(6)",%%mm1\n\t" \
+ "psubw %%mm6,%%mm3\n\t" \
+ "movq %%mm4,"OC_I(1)"\n\t" \
+ "paddw %%mm6,%%mm6\n\t" \
+ "movq "OC_C(4)",%%mm4\n\t" \
+ "paddw %%mm3,%%mm6\n\t" \
+ "movq %%mm3,%%mm5\n\t" \
+ "pmulhw %%mm4,%%mm3\n\t" \
+ "movq %%mm6,"OC_I(2)"\n\t" \
+ "movq %%mm0,%%mm2\n\t" \
+ "movq "OC_I(0)",%%mm6\n\t" \
+ "pmulhw %%mm4,%%mm0\n\t" \
+ "paddw %%mm3,%%mm5\n\t" \
+ "paddw %%mm0,%%mm2\n\t" \
+ "psubw %%mm1,%%mm5\n\t" \
+ "pmulhw %%mm4,%%mm6\n\t" \
+ "paddw "OC_I(0)",%%mm6\n\t" \
+ "paddw %%mm1,%%mm1\n\t" \
+ "movq %%mm6,%%mm4\n\t" \
+ "paddw %%mm5,%%mm1\n\t" \
+ "psubw %%mm2,%%mm6\n\t" \
+ "paddw %%mm2,%%mm2\n\t" \
+ "movq "OC_I(1)",%%mm0\n\t" \
+ "paddw %%mm6,%%mm2\n\t" \
+ "psubw %%mm1,%%mm2\n\t" \
+ "nop\n\t" \
+ "#end OC_IDCT_BEGIN_10\n\t" \
+
+/*25+8=33 cycles.*/
+#define OC_ROW_IDCT_10 \
+ "#OC_ROW_IDCT_10\n\t" \
+ OC_IDCT_BEGIN_10 \
+ /*r3=D'*/ \
+ "movq "OC_I(2)",%%mm3\n\t" \
+ /*r4=E'=E-G*/ \
+ "psubw %%mm7,%%mm4\n\t" \
+ /*r1=H'+H'*/ \
+ "paddw %%mm1,%%mm1\n\t" \
+ /*r7=G+G*/ \
+ "paddw %%mm7,%%mm7\n\t" \
+ /*r1=R1=A''+H'*/ \
+ "paddw %%mm2,%%mm1\n\t" \
+ /*r7=G'=E+G*/ \
+ "paddw %%mm4,%%mm7\n\t" \
+ /*r4=R4=E'-D'*/ \
+ "psubw %%mm3,%%mm4\n\t" \
+ "paddw %%mm3,%%mm3\n\t" \
+ /*r6=R6=F'-B''*/ \
+ "psubw %%mm5,%%mm6\n\t" \
+ "paddw %%mm5,%%mm5\n\t" \
+ /*r3=R3=E'+D'*/ \
+ "paddw %%mm4,%%mm3\n\t" \
+ /*r5=R5=F'+B''*/ \
+ "paddw %%mm6,%%mm5\n\t" \
+ /*r7=R7=G'-C'*/ \
+ "psubw %%mm0,%%mm7\n\t" \
+ "paddw %%mm0,%%mm0\n\t" \
+ /*Save R1.*/ \
+ "movq %%mm1,"OC_I(1)"\n\t" \
+ /*r0=R0=G'+C'*/ \
+ "paddw %%mm7,%%mm0\n\t" \
+ "#end OC_ROW_IDCT_10\n\t" \
+
+/*25+19=44 cycles'*/
+#define OC_COLUMN_IDCT_10 \
+ "#OC_COLUMN_IDCT_10\n\t" \
+ OC_IDCT_BEGIN_10 \
+ "paddw "OC_8",%%mm2\n\t" \
+ /*r1=H'+H'*/ \
+ "paddw %%mm1,%%mm1\n\t" \
+ /*r1=R1=A''+H'*/ \
+ "paddw %%mm2,%%mm1\n\t" \
+ /*r2=NR2*/ \
+ "psraw $4,%%mm2\n\t" \
+ /*r4=E'=E-G*/ \
+ "psubw %%mm7,%%mm4\n\t" \
+ /*r1=NR1*/ \
+ "psraw $4,%%mm1\n\t" \
+ /*r3=D'*/ \
+ "movq "OC_I(2)",%%mm3\n\t" \
+ /*r7=G+G*/ \
+ "paddw %%mm7,%%mm7\n\t" \
+ /*Store NR2 at I(2).*/ \
+ "movq %%mm2,"OC_I(2)"\n\t" \
+ /*r7=G'=E+G*/ \
+ "paddw %%mm4,%%mm7\n\t" \
+ /*Store NR1 at I(1).*/ \
+ "movq %%mm1,"OC_I(1)"\n\t" \
+ /*r4=R4=E'-D'*/ \
+ "psubw %%mm3,%%mm4\n\t" \
+ "paddw "OC_8",%%mm4\n\t" \
+ /*r3=D'+D'*/ \
+ "paddw %%mm3,%%mm3\n\t" \
+ /*r3=R3=E'+D'*/ \
+ "paddw %%mm4,%%mm3\n\t" \
+ /*r4=NR4*/ \
+ "psraw $4,%%mm4\n\t" \
+ /*r6=R6=F'-B''*/ \
+ "psubw %%mm5,%%mm6\n\t" \
+ /*r3=NR3*/ \
+ "psraw $4,%%mm3\n\t" \
+ "paddw "OC_8",%%mm6\n\t" \
+ /*r5=B''+B''*/ \
+ "paddw %%mm5,%%mm5\n\t" \
+ /*r5=R5=F'+B''*/ \
+ "paddw %%mm6,%%mm5\n\t" \
+ /*r6=NR6*/ \
+ "psraw $4,%%mm6\n\t" \
+ /*Store NR4 at J(4).*/ \
+ "movq %%mm4,"OC_J(4)"\n\t" \
+ /*r5=NR5*/ \
+ "psraw $4,%%mm5\n\t" \
+ /*Store NR3 at I(3).*/ \
+ "movq %%mm3,"OC_I(3)"\n\t" \
+ /*r7=R7=G'-C'*/ \
+ "psubw %%mm0,%%mm7\n\t" \
+ "paddw "OC_8",%%mm7\n\t" \
+ /*r0=C'+C'*/ \
+ "paddw %%mm0,%%mm0\n\t" \
+ /*r0=R0=G'+C'*/ \
+ "paddw %%mm7,%%mm0\n\t" \
+ /*r7=NR7*/ \
+ "psraw $4,%%mm7\n\t" \
+ /*Store NR6 at J(6).*/ \
+ "movq %%mm6,"OC_J(6)"\n\t" \
+ /*r0=NR0*/ \
+ "psraw $4,%%mm0\n\t" \
+ /*Store NR5 at J(5).*/ \
+ "movq %%mm5,"OC_J(5)"\n\t" \
+ /*Store NR7 at J(7).*/ \
+ "movq %%mm7,"OC_J(7)"\n\t" \
+ /*Store NR0 at I(0).*/ \
+ "movq %%mm0,"OC_I(0)"\n\t" \
+ "#end OC_COLUMN_IDCT_10\n\t" \
+
+static void oc_idct8x8_10(ogg_int16_t _y[64]){
+  __asm__ __volatile__(
+#define OC_I(_k) OC_M2STR((_k*16))"(%[y])"
+#define OC_J(_k) OC_M2STR(((_k-4)*16)+8)"(%[y])"
+    /*Done with dequant, descramble, and partial transpose.
+      Now do the iDCT itself.*/
+    OC_ROW_IDCT_10
+    OC_TRANSPOSE
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k) OC_M2STR((_k*16))"(%[y])"
+#define OC_J(_k) OC_I(_k)
+    OC_COLUMN_IDCT_10
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k) OC_M2STR((_k*16)+8)"(%[y])"
+#define OC_J(_k) OC_I(_k)
+    OC_COLUMN_IDCT_10
+#undef  OC_I
+#undef  OC_J
+    :
+    :[y]"r"(_y),[c]"r"(OC_IDCT_CONSTS)
+  );
+}
+
+/*Performs an inverse 8x8 Type-II DCT transform.
+  The input is assumed to be scaled by a factor of 4 relative to orthonormal
+   version of the transform.*/
+void oc_idct8x8_mmx(ogg_int16_t _y[64],int _last_zzi){
+  /*_last_zzi is subtly different from an actual count of the number of
+     coefficients we decoded for this block.
+    It contains the value of zzi BEFORE the final token in the block was
+     decoded.
+    In most cases this is an EOB token (the continuation of an EOB run from a
+     previous block counts), and so this is the same as the coefficient count.
+    However, in the case that the last token was NOT an EOB token, but filled
+     the block up with exactly 64 coefficients, _last_zzi will be less than 64.
+    Provided the last token was not a pure zero run, the minimum value it can
+     be is 46, and so that doesn't affect any of the cases in this routine.
+    However, if the last token WAS a pure zero run of length 63, then _last_zzi
+     will be 1 while the number of coefficients decoded is 64.
+    Thus, we will trigger the following special case, where the real
+     coefficient count would not.
+    Note also that a zero run of length 64 will give _last_zzi a value of 0,
+     but we still process the DC coefficient, which might have a non-zero value
+     due to DC prediction.
+    Although convoluted, this is arguably the correct behavior: it allows us to
+     use a smaller transform when the block ends with a long zero run instead
+     of a normal EOB token.
+    It could be smarter... multiple separate zero runs at the end of a block
+     will fool it, but an encoder that generates these really deserves what it
+     gets.
+    Needless to say we inherited this approach from VP3.*/
+  /*Then perform the iDCT.*/
+  if(_last_zzi<10)oc_idct8x8_10(_y);
+  else oc_idct8x8_slow(_y);
+}
+
+#endif
diff --git a/lib/x86/mmxloop.h b/lib/x86/mmxloop.h
new file mode 100644 (file)
index 0000000..2e870c7
--- /dev/null
@@ -0,0 +1,215 @@
+#if !defined(_x86_mmxloop_H)
+# define _x86_mmxloop_H (1)
+# include <stddef.h>
+# include "x86int.h"
+
+#if defined(OC_X86_ASM)
+
+/*On entry, mm0={a0,...,a7}, mm1={b0,...,b7}, mm2={c0,...,c7}, mm3={d0,...d7}.
+  On exit, mm1={b0+lflim(R_0,L),...,b7+lflim(R_7,L)} and
+   mm2={c0-lflim(R_0,L),...,c7-lflim(R_7,L)}; mm0 and mm3 are clobbered.*/
+#define OC_LOOP_FILTER8_MMX \
+ "#OC_LOOP_FILTER8_MMX\n\t" \
+ /*mm7=0*/ \
+ "pxor %%mm7,%%mm7\n\t" \
+ /*mm6:mm0={a0,...,a7}*/ \
+ "movq %%mm0,%%mm6\n\t" \
+ "punpcklbw %%mm7,%%mm0\n\t" \
+ "punpckhbw %%mm7,%%mm6\n\t" \
+ /*mm3:mm5={d0,...,d7}*/ \
+ "movq %%mm3,%%mm5\n\t" \
+ "punpcklbw %%mm7,%%mm3\n\t" \
+ "punpckhbw %%mm7,%%mm5\n\t" \
+ /*mm6:mm0={a0-d0,...,a7-d7}*/ \
+ "psubw %%mm3,%%mm0\n\t" \
+ "psubw %%mm5,%%mm6\n\t" \
+ /*mm3:mm1={b0,...,b7}*/ \
+ "movq %%mm1,%%mm3\n\t" \
+ "punpcklbw %%mm7,%%mm1\n\t" \
+ "movq %%mm2,%%mm4\n\t" \
+ "punpckhbw %%mm7,%%mm3\n\t" \
+ /*mm5:mm4={c0,...,c7}*/ \
+ "movq %%mm2,%%mm5\n\t" \
+ "punpcklbw %%mm7,%%mm4\n\t" \
+ "punpckhbw %%mm7,%%mm5\n\t" \
+ /*mm7={3}x4 \
+   mm5:mm4={c0-b0,...,c7-b7}*/ \
+ "pcmpeqw %%mm7,%%mm7\n\t" \
+ "psubw %%mm1,%%mm4\n\t" \
+ "psrlw $14,%%mm7\n\t" \
+ "psubw %%mm3,%%mm5\n\t" \
+ /*Scale by 3.*/ \
+ "pmullw %%mm7,%%mm4\n\t" \
+ "pmullw %%mm7,%%mm5\n\t" \
+ /*mm7={4}x4 \
+   mm5:mm4=f={a0-d0+3*(c0-b0),...,a7-d7+3*(c7-b7)}*/ \
+ "psrlw $1,%%mm7\n\t" \
+ "paddw %%mm0,%%mm4\n\t" \
+ "psllw $2,%%mm7\n\t" \
+ "movq (%[ll]),%%mm0\n\t" \
+ "paddw %%mm6,%%mm5\n\t" \
+ /*R_i has the range [-127,128], so we compute -R_i instead. \
+   mm4=-R_i=-(f+4>>3)=0xFF^(f-4>>3)*/ \
+ "psubw %%mm7,%%mm4\n\t" \
+ "psubw %%mm7,%%mm5\n\t" \
+ "psraw $3,%%mm4\n\t" \
+ "psraw $3,%%mm5\n\t" \
+ "pcmpeqb %%mm7,%%mm7\n\t" \
+ "packsswb %%mm5,%%mm4\n\t" \
+ "pxor %%mm6,%%mm6\n\t" \
+ "pxor %%mm7,%%mm4\n\t" \
+ "packuswb %%mm3,%%mm1\n\t" \
+ /*Now compute lflim of -mm4 cf. Section 7.10 of the sepc.*/ \
+ /*There's no unsigned byte+signed byte with unsigned saturation op code, so \
+    we have to split things by sign (the other option is to work in 16 bits, \
+    but working in 8 bits gives much better parallelism). \
+   We compute abs(R_i), but save a mask of which terms were negative in mm6. \
+   Then we compute mm4=abs(lflim(R_i,L))=min(abs(R_i),max(2*L-abs(R_i),0)). \
+   Finally, we split mm4 into positive and negative pieces using the mask in \
+    mm6, and add and subtract them as appropriate.*/ \
+ /*mm4=abs(-R_i)*/ \
+ /*mm7=255-2*L*/ \
+ "pcmpgtb %%mm4,%%mm6\n\t" \
+ "psubb %%mm0,%%mm7\n\t" \
+ "pxor %%mm6,%%mm4\n\t" \
+ "psubb %%mm0,%%mm7\n\t" \
+ "psubb %%mm6,%%mm4\n\t" \
+ /*mm7=255-max(2*L-abs(R_i),0)*/ \
+ "paddusb %%mm4,%%mm7\n\t" \
+ /*mm4=min(abs(R_i),max(2*L-abs(R_i),0))*/ \
+ "paddusb %%mm7,%%mm4\n\t" \
+ "psubusb %%mm7,%%mm4\n\t" \
+ /*Now split mm4 by the original sign of -R_i.*/ \
+ "movq %%mm4,%%mm5\n\t" \
+ "pand %%mm6,%%mm4\n\t" \
+ "pandn %%mm5,%%mm6\n\t" \
+ /*mm1={b0+lflim(R_0,L),...,b7+lflim(R_7,L)}*/ \
+ /*mm2={c0-lflim(R_0,L),...,c7-lflim(R_7,L)}*/ \
+ "paddusb %%mm4,%%mm1\n\t" \
+ "psubusb %%mm4,%%mm2\n\t" \
+ "psubusb %%mm6,%%mm1\n\t" \
+ "paddusb %%mm6,%%mm2\n\t" \
+
+#define OC_LOOP_FILTER_V_MMX(_pix,_ystride,_ll) \
+  do{ \
+    ptrdiff_t ystride3__; \
+    __asm__ __volatile__( \
+      /*mm0={a0,...,a7}*/ \
+      "movq (%[pix]),%%mm0\n\t" \
+      /*ystride3=_ystride*3*/ \
+      "lea (%[ystride],%[ystride],2),%[ystride3]\n\t" \
+      /*mm3={d0,...,d7}*/ \
+      "movq (%[pix],%[ystride3]),%%mm3\n\t" \
+      /*mm1={b0,...,b7}*/ \
+      "movq (%[pix],%[ystride]),%%mm1\n\t" \
+      /*mm2={c0,...,c7}*/ \
+      "movq (%[pix],%[ystride],2),%%mm2\n\t" \
+      OC_LOOP_FILTER8_MMX \
+      /*Write it back out.*/ \
+      "movq %%mm1,(%[pix],%[ystride])\n\t" \
+      "movq %%mm2,(%[pix],%[ystride],2)\n\t" \
+      :[ystride3]"=&r"(ystride3__) \
+      :[pix]"r"(_pix-_ystride*2),[ystride]"r"((ptrdiff_t)(_ystride)), \
+       [ll]"r"(_ll) \
+      :"memory" \
+    ); \
+  } \
+  while(0)
+
+#define OC_LOOP_FILTER_H_MMX(_pix,_ystride,_ll) \
+  do{ \
+    unsigned char *pix__; \
+    ptrdiff_t      ystride3__; \
+    ptrdiff_t      d__; \
+    pix__=(_pix)-2; \
+    __asm__ __volatile__( \
+      /*x x x x d0 c0 b0 a0*/ \
+      "movd (%[pix]),%%mm0\n\t" \
+      /*x x x x d1 c1 b1 a1*/ \
+      "movd (%[pix],%[ystride]),%%mm1\n\t" \
+      /*ystride3=_ystride*3*/ \
+      "lea (%[ystride],%[ystride],2),%[ystride3]\n\t" \
+      /*x x x x d2 c2 b2 a2*/ \
+      "movd (%[pix],%[ystride],2),%%mm2\n\t" \
+      /*x x x x d3 c3 b3 a3*/ \
+      "lea (%[pix],%[ystride],4),%[d]\n\t" \
+      "movd (%[pix],%[ystride3]),%%mm3\n\t" \
+      /*x x x x d4 c4 b4 a4*/ \
+      "movd (%[d]),%%mm4\n\t" \
+      /*x x x x d5 c5 b5 a5*/ \
+      "movd (%[d],%[ystride]),%%mm5\n\t" \
+      /*x x x x d6 c6 b6 a6*/ \
+      "movd (%[d],%[ystride],2),%%mm6\n\t" \
+      /*x x x x d7 c7 b7 a7*/ \
+      "movd (%[d],%[ystride3]),%%mm7\n\t" \
+      /*mm0=d1 d0 c1 c0 b1 b0 a1 a0*/ \
+      "punpcklbw %%mm1,%%mm0\n\t" \
+      /*mm2=d3 d2 c3 c2 b3 b2 a3 a2*/ \
+      "punpcklbw %%mm3,%%mm2\n\t" \
+      /*mm3=d1 d0 c1 c0 b1 b0 a1 a0*/ \
+      "movq %%mm0,%%mm3\n\t" \
+      /*mm0=b3 b2 b1 b0 a3 a2 a1 a0*/ \
+      "punpcklwd %%mm2,%%mm0\n\t" \
+      /*mm3=d3 d2 d1 d0 c3 c2 c1 c0*/ \
+      "punpckhwd %%mm2,%%mm3\n\t" \
+      /*mm1=b3 b2 b1 b0 a3 a2 a1 a0*/ \
+      "movq %%mm0,%%mm1\n\t" \
+      /*mm4=d5 d4 c5 c4 b5 b4 a5 a4*/ \
+      "punpcklbw %%mm5,%%mm4\n\t" \
+      /*mm6=d7 d6 c7 c6 b7 b6 a7 a6*/ \
+      "punpcklbw %%mm7,%%mm6\n\t" \
+      /*mm5=d5 d4 c5 c4 b5 b4 a5 a4*/ \
+      "movq %%mm4,%%mm5\n\t" \
+      /*mm4=b7 b6 b5 b4 a7 a6 a5 a4*/ \
+      "punpcklwd %%mm6,%%mm4\n\t" \
+      /*mm5=d7 d6 d5 d4 c7 c6 c5 c4*/ \
+      "punpckhwd %%mm6,%%mm5\n\t" \
+      /*mm2=d3 d2 d1 d0 c3 c2 c1 c0*/ \
+      "movq %%mm3,%%mm2\n\t" \
+      /*mm0=a7 a6 a5 a4 a3 a2 a1 a0*/ \
+      "punpckldq %%mm4,%%mm0\n\t" \
+      /*mm1=b7 b6 b5 b4 b3 b2 b1 b0*/ \
+      "punpckhdq %%mm4,%%mm1\n\t" \
+      /*mm2=c7 c6 c5 c4 c3 c2 c1 c0*/ \
+      "punpckldq %%mm5,%%mm2\n\t" \
+      /*mm3=d7 d6 d5 d4 d3 d2 d1 d0*/ \
+      "punpckhdq %%mm5,%%mm3\n\t" \
+      OC_LOOP_FILTER8_MMX \
+      /*mm2={b0+R_0'',...,b7+R_7''}*/ \
+      "movq %%mm1,%%mm0\n\t" \
+      /*mm1={b0+R_0'',c0-R_0'',...,b3+R_3'',c3-R_3''}*/ \
+      "punpcklbw %%mm2,%%mm1\n\t" \
+      /*mm2={b4+R_4'',c4-R_4'',...,b7+R_7'',c7-R_7''}*/ \
+      "punpckhbw %%mm2,%%mm0\n\t" \
+      /*[d]=c1 b1 c0 b0*/ \
+      "movd %%mm1,%[d]\n\t" \
+      "movw %w[d],1(%[pix])\n\t" \
+      "psrlq $32,%%mm1\n\t" \
+      "shr $16,%[d]\n\t" \
+      "movw %w[d],1(%[pix],%[ystride])\n\t" \
+      /*[d]=c3 b3 c2 b2*/ \
+      "movd %%mm1,%[d]\n\t" \
+      "movw %w[d],1(%[pix],%[ystride],2)\n\t" \
+      "shr $16,%[d]\n\t" \
+      "movw %w[d],1(%[pix],%[ystride3])\n\t" \
+      "lea (%[pix],%[ystride],4),%[pix]\n\t" \
+      /*[d]=c5 b5 c4 b4*/ \
+      "movd %%mm0,%[d]\n\t" \
+      "movw %w[d],1(%[pix])\n\t" \
+      "psrlq $32,%%mm0\n\t" \
+      "shr $16,%[d]\n\t" \
+      "movw %w[d],1(%[pix],%[ystride])\n\t" \
+      /*[d]=c7 b7 c6 b6*/ \
+      "movd %%mm0,%[d]\n\t" \
+      "movw %w[d],1(%[pix],%[ystride],2)\n\t" \
+      "shr $16,%[d]\n\t" \
+      "movw %w[d],1(%[pix],%[ystride3])\n\t" \
+      :[pix]"+r"(pix__),[ystride3]"=&r"(ystride3__),[d]"=&r"(d__) \
+      :[ystride]"r"((ptrdiff_t)(_ystride)),[ll]"r"(_ll) \
+      :"memory" \
+    ); \
+  } \
+  while(0)
+
+# endif
+#endif
diff --git a/lib/x86/mmxstate.c b/lib/x86/mmxstate.c
new file mode 100644 (file)
index 0000000..808b0a7
--- /dev/null
@@ -0,0 +1,188 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: mmxstate.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+/*MMX acceleration of complete fragment reconstruction algorithm.
+  Originally written by Rudolf Marek.*/
+#include <string.h>
+#include "x86int.h"
+#include "mmxfrag.h"
+#include "mmxloop.h"
+
+#if defined(OC_X86_ASM)
+
+void oc_state_frag_recon_mmx(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant){
+  unsigned char *dst;
+  ptrdiff_t      frag_buf_off;
+  int            ystride;
+  int            mb_mode;
+  /*Apply the inverse transform.*/
+  /*Special case only having a DC component.*/
+  if(_last_zzi<2){
+    /*Note that this value must be unsigned, to keep the __asm__ block from
+       sign-extending it when it puts it in a register.*/
+    ogg_uint16_t p;
+    /*We round this dequant product (and not any of the others) because there's
+       no iDCT rounding.*/
+    p=(ogg_int16_t)(_dct_coeffs[0]*(ogg_int32_t)_dc_quant+15>>5);
+    /*Fill _dct_coeffs with p.*/
+    __asm__ __volatile__(
+      /*mm0=0000 0000 0000 AAAA*/
+      "movd %[p],%%mm0\n\t"
+      /*mm0=0000 0000 AAAA AAAA*/
+      "punpcklwd %%mm0,%%mm0\n\t"
+      /*mm0=AAAA AAAA AAAA AAAA*/
+      "punpckldq %%mm0,%%mm0\n\t"
+      "movq %%mm0,(%[y])\n\t"
+      "movq %%mm0,8(%[y])\n\t"
+      "movq %%mm0,16(%[y])\n\t"
+      "movq %%mm0,24(%[y])\n\t"
+      "movq %%mm0,32(%[y])\n\t"
+      "movq %%mm0,40(%[y])\n\t"
+      "movq %%mm0,48(%[y])\n\t"
+      "movq %%mm0,56(%[y])\n\t"
+      "movq %%mm0,64(%[y])\n\t"
+      "movq %%mm0,72(%[y])\n\t"
+      "movq %%mm0,80(%[y])\n\t"
+      "movq %%mm0,88(%[y])\n\t"
+      "movq %%mm0,96(%[y])\n\t"
+      "movq %%mm0,104(%[y])\n\t"
+      "movq %%mm0,112(%[y])\n\t"
+      "movq %%mm0,120(%[y])\n\t"
+      :
+      :[y]"r"(_dct_coeffs),[p]"r"((unsigned)p)
+      :"memory"
+    );
+  }
+  else{
+    /*Dequantize the DC coefficient.*/
+    _dct_coeffs[0]=(ogg_int16_t)(_dct_coeffs[0]*(int)_dc_quant);
+    oc_idct8x8_mmx(_dct_coeffs,_last_zzi);
+  }
+  /*Fill in the target buffer.*/
+  frag_buf_off=_state->frag_buf_offs[_fragi];
+  mb_mode=_state->frags[_fragi].mb_mode;
+  ystride=_state->ref_ystride[_pli];
+  dst=_state->ref_frame_data[_state->ref_frame_idx[OC_FRAME_SELF]]+frag_buf_off;
+  if(mb_mode==OC_MODE_INTRA)oc_frag_recon_intra_mmx(dst,ystride,_dct_coeffs);
+  else{
+    const unsigned char *ref;
+    int                  mvoffsets[2];
+    ref=
+     _state->ref_frame_data[_state->ref_frame_idx[OC_FRAME_FOR_MODE(mb_mode)]]
+     +frag_buf_off;
+    if(oc_state_get_mv_offsets(_state,mvoffsets,_pli,
+     _state->frag_mvs[_fragi][0],_state->frag_mvs[_fragi][1])>1){
+      oc_frag_recon_inter2_mmx(dst,ref+mvoffsets[0],ref+mvoffsets[1],ystride,
+       _dct_coeffs);
+    }
+    else oc_frag_recon_inter_mmx(dst,ref+mvoffsets[0],ystride,_dct_coeffs);
+  }
+}
+
+/*We copy these entire function to inline the actual MMX routines so that we
+   use only a single indirect call.*/
+
+/*Copies the fragments specified by the lists of fragment indices from one
+   frame to another.
+  _fragis:    A pointer to a list of fragment indices.
+  _nfragis:   The number of fragment indices to copy.
+  _dst_frame: The reference frame to copy to.
+  _src_frame: The reference frame to copy from.
+  _pli:       The color plane the fragments lie in.*/
+void oc_state_frag_copy_list_mmx(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli){
+  const ptrdiff_t     *frag_buf_offs;
+  const unsigned char *src_frame_data;
+  unsigned char       *dst_frame_data;
+  ptrdiff_t            fragii;
+  int                  ystride;
+  dst_frame_data=_state->ref_frame_data[_state->ref_frame_idx[_dst_frame]];
+  src_frame_data=_state->ref_frame_data[_state->ref_frame_idx[_src_frame]];
+  ystride=_state->ref_ystride[_pli];
+  frag_buf_offs=_state->frag_buf_offs;
+  for(fragii=0;fragii<_nfragis;fragii++){
+    ptrdiff_t frag_buf_off;
+    frag_buf_off=frag_buf_offs[_fragis[fragii]];
+    OC_FRAG_COPY_MMX(dst_frame_data+frag_buf_off,
+     src_frame_data+frag_buf_off,ystride);
+  }
+}
+
+/*Apply the loop filter to a given set of fragment rows in the given plane.
+  The filter may be run on the bottom edge, affecting pixels in the next row of
+   fragments, so this row also needs to be available.
+  _bv:        The bounding values array.
+  _refi:      The index of the frame buffer to filter.
+  _pli:       The color plane to filter.
+  _fragy0:    The Y coordinate of the first fragment row to filter.
+  _fragy_end: The Y coordinate of the fragment row to stop filtering at.*/
+void oc_state_loop_filter_frag_rows_mmx(const oc_theora_state *_state,
+ int _bv[256],int _refi,int _pli,int _fragy0,int _fragy_end){
+  OC_ALIGN8(unsigned char   ll[8]);
+  const oc_fragment_plane *fplane;
+  const oc_fragment       *frags;
+  const ptrdiff_t         *frag_buf_offs;
+  unsigned char           *ref_frame_data;
+  ptrdiff_t                fragi_top;
+  ptrdiff_t                fragi_bot;
+  ptrdiff_t                fragi0;
+  ptrdiff_t                fragi0_end;
+  int                      ystride;
+  int                      nhfrags;
+  memset(ll,_state->loop_filter_limits[_state->qis[0]],sizeof(ll));
+  fplane=_state->fplanes+_pli;
+  nhfrags=fplane->nhfrags;
+  fragi_top=fplane->froffset;
+  fragi_bot=fragi_top+fplane->nfrags;
+  fragi0=fragi_top+_fragy0*(ptrdiff_t)nhfrags;
+  fragi0_end=fragi0+(_fragy_end-_fragy0)*(ptrdiff_t)nhfrags;
+  ystride=_state->ref_ystride[_pli];
+  frags=_state->frags;
+  frag_buf_offs=_state->frag_buf_offs;
+  ref_frame_data=_state->ref_frame_data[_refi];
+  /*The following loops are constructed somewhat non-intuitively on purpose.
+    The main idea is: if a block boundary has at least one coded fragment on
+     it, the filter is applied to it.
+    However, the order that the filters are applied in matters, and VP3 chose
+     the somewhat strange ordering used below.*/
+  while(fragi0<fragi0_end){
+    ptrdiff_t fragi;
+    ptrdiff_t fragi_end;
+    fragi=fragi0;
+    fragi_end=fragi+nhfrags;
+    while(fragi<fragi_end){
+      if(frags[fragi].coded){
+        unsigned char *ref;
+        ref=ref_frame_data+frag_buf_offs[fragi];
+        if(fragi>fragi0)OC_LOOP_FILTER_H_MMX(ref,ystride,ll);
+        if(fragi0>fragi_top)OC_LOOP_FILTER_V_MMX(ref,ystride,ll);
+        if(fragi+1<fragi_end&&!frags[fragi+1].coded){
+          OC_LOOP_FILTER_H_MMX(ref+8,ystride,ll);
+        }
+        if(fragi+nhfrags<fragi_bot&&!frags[fragi+nhfrags].coded){
+          OC_LOOP_FILTER_V_MMX(ref+(ystride<<3),ystride,ll);
+        }
+      }
+      fragi++;
+    }
+    fragi0+=nhfrags;
+  }
+}
+
+#endif
diff --git a/lib/x86/sse2fdct.c b/lib/x86/sse2fdct.c
new file mode 100644 (file)
index 0000000..86c17d6
--- /dev/null
@@ -0,0 +1,523 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 1999-2006                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************/
+/*SSE2 fDCT implementation for x86_64.*/
+/*$Id: fdct_ses2.c 14579 2008-03-12 06:42:40Z xiphmont $*/
+#include <stddef.h>
+#include "x86enc.h"
+
+#if defined(OC_X86_64_ASM)
+
+# define OC_FDCT8x8 \
+ /*Note: xmm15={0}x8 and xmm14={-1}x8.*/ \
+ "#OC_FDCT8x8\n\t" \
+ /*Stage 1:*/ \
+ "movdqa %%xmm0,%%xmm11\n\t" \
+ "movdqa %%xmm1,%%xmm10\n\t" \
+ "movdqa %%xmm2,%%xmm9\n\t" \
+ "movdqa %%xmm3,%%xmm8\n\t" \
+ /*xmm11=t7'=t0-t7*/ \
+ "psubw %%xmm7,%%xmm11\n\t" \
+ /*xmm10=t6'=t1-t6*/ \
+ "psubw %%xmm6,%%xmm10\n\t" \
+ /*xmm9=t5'=t2-t5*/ \
+ "psubw %%xmm5,%%xmm9\n\t" \
+ /*xmm8=t4'=t3-t4*/ \
+ "psubw %%xmm4,%%xmm8\n\t" \
+ /*xmm0=t0'=t0+t7*/ \
+ "paddw %%xmm7,%%xmm0\n\t" \
+ /*xmm1=t1'=t1+t6*/ \
+ "paddw %%xmm6,%%xmm1\n\t" \
+ /*xmm5=t2'=t2+t5*/ \
+ "paddw %%xmm2,%%xmm5\n\t" \
+ /*xmm4=t3'=t3+t4*/ \
+ "paddw %%xmm3,%%xmm4\n\t" \
+ /*xmm2,3,6,7 are now free.*/ \
+ /*Stage 2:*/ \
+ "movdqa %%xmm0,%%xmm3\n\t" \
+ "mov $0x5A806A0A,%[a]\n\t" \
+ "movdqa %%xmm1,%%xmm2\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "movdqa %%xmm10,%%xmm6\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ /*xmm2=t2''=t1'-t2'*/ \
+ "psubw %%xmm5,%%xmm2\n\t" \
+ "pxor %%xmm12,%%xmm12\n\t" \
+ /*xmm3=t3''=t0'-t3'*/ \
+ "psubw %%xmm4,%%xmm3\n\t" \
+ "psubw %%xmm14,%%xmm12\n\t" \
+ /*xmm10=t5''=t6'-t5'*/ \
+ "psubw %%xmm9,%%xmm10\n\t" \
+ "paddw %%xmm12,%%xmm12\n\t" \
+ /*xmm4=t0''=t0'+t3'*/ \
+ "paddw %%xmm0,%%xmm4\n\t" \
+ /*xmm1=t1''=t1'+t2'*/ \
+ "paddw %%xmm5,%%xmm1\n\t" \
+ /*xmm6=t6''=t6'+t5'*/ \
+ "paddw %%xmm9,%%xmm6\n\t" \
+ /*xmm0,xmm5,xmm9 are now free.*/ \
+ /*Stage 3:*/ \
+ /*xmm10:xmm5=t5''*27146+0xB500 \
+   xmm0=t5''*/ \
+ "movdqa %%xmm10,%%xmm5\n\t" \
+ "movdqa %%xmm10,%%xmm0\n\t" \
+ "punpckhwd %%xmm12,%%xmm10\n\t" \
+ "pmaddwd %%xmm13,%%xmm10\n\t" \
+ "punpcklwd %%xmm12,%%xmm5\n\t" \
+ "pmaddwd %%xmm13,%%xmm5\n\t" \
+ /*xmm5=(t5''*27146+0xB500>>16)+t5''*/ \
+ "psrad $16,%%xmm10\n\t" \
+ "psrad $16,%%xmm5\n\t" \
+ "packssdw %%xmm10,%%xmm5\n\t" \
+ "paddw %%xmm0,%%xmm5\n\t" \
+ /*xmm0=s=(t5''*27146+0xB500>>16)+t5''+(t5''!=0)>>1*/ \
+ "pcmpeqw %%xmm15,%%xmm0\n\t" \
+ "psubw %%xmm14,%%xmm0\n\t" \
+ "paddw %%xmm5,%%xmm0\n\t" \
+ "movdqa %%xmm8,%%xmm5\n\t" \
+ "psraw $1,%%xmm0\n\t" \
+ /*xmm5=t5'''=t4'-s*/ \
+ "psubw %%xmm0,%%xmm5\n\t" \
+ /*xmm8=t4''=t4'+s*/ \
+ "paddw %%xmm0,%%xmm8\n\t" \
+ /*xmm0,xmm7,xmm9,xmm10 are free.*/ \
+ /*xmm7:xmm9=t6''*27146+0xB500*/ \
+ "movdqa %%xmm6,%%xmm7\n\t" \
+ "movdqa %%xmm6,%%xmm9\n\t" \
+ "punpckhwd %%xmm12,%%xmm7\n\t" \
+ "pmaddwd %%xmm13,%%xmm7\n\t" \
+ "punpcklwd %%xmm12,%%xmm9\n\t" \
+ "pmaddwd %%xmm13,%%xmm9\n\t" \
+ /*xmm9=(t6''*27146+0xB500>>16)+t6''*/ \
+ "psrad $16,%%xmm7\n\t" \
+ "psrad $16,%%xmm9\n\t" \
+ "packssdw %%xmm7,%%xmm9\n\t" \
+ "paddw %%xmm6,%%xmm9\n\t" \
+ /*xmm9=s=(t6''*27146+0xB500>>16)+t6''+(t6''!=0)>>1*/ \
+ "pcmpeqw %%xmm15,%%xmm6\n\t" \
+ "psubw %%xmm14,%%xmm6\n\t" \
+ "paddw %%xmm6,%%xmm9\n\t" \
+ "movdqa %%xmm11,%%xmm7\n\t" \
+ "psraw $1,%%xmm9\n\t" \
+ /*xmm7=t6'''=t7'-s*/ \
+ "psubw %%xmm9,%%xmm7\n\t" \
+ /*xmm9=t7''=t7'+s*/ \
+ "paddw %%xmm11,%%xmm9\n\t" \
+ /*xmm0,xmm6,xmm10,xmm11 are free.*/ \
+ /*Stage 4:*/ \
+ /*xmm10:xmm0=t1''*27146+0xB500*/ \
+ "movdqa %%xmm1,%%xmm0\n\t" \
+ "movdqa %%xmm1,%%xmm10\n\t" \
+ "punpcklwd %%xmm12,%%xmm0\n\t" \
+ "pmaddwd %%xmm13,%%xmm0\n\t" \
+ "punpckhwd %%xmm12,%%xmm10\n\t" \
+ "pmaddwd %%xmm13,%%xmm10\n\t" \
+ /*xmm0=(t1''*27146+0xB500>>16)+t1''*/ \
+ "psrad $16,%%xmm0\n\t" \
+ "psrad $16,%%xmm10\n\t" \
+ "mov $0x20006A0A,%[a]\n\t" \
+ "packssdw %%xmm10,%%xmm0\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "paddw %%xmm1,%%xmm0\n\t" \
+ /*xmm0=s=(t1''*27146+0xB500>>16)+t1''+(t1''!=0)*/ \
+ "pcmpeqw %%xmm15,%%xmm1\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "psubw %%xmm14,%%xmm1\n\t" \
+ "paddw %%xmm1,%%xmm0\n\t" \
+ /*xmm10:xmm4=t0''*27146+0x4000*/ \
+ "movdqa %%xmm4,%%xmm1\n\t" \
+ "movdqa %%xmm4,%%xmm10\n\t" \
+ "punpcklwd %%xmm12,%%xmm4\n\t" \
+ "pmaddwd %%xmm13,%%xmm4\n\t" \
+ "punpckhwd %%xmm12,%%xmm10\n\t" \
+ "pmaddwd %%xmm13,%%xmm10\n\t" \
+ /*xmm4=(t0''*27146+0x4000>>16)+t0''*/ \
+ "psrad $16,%%xmm4\n\t" \
+ "psrad $16,%%xmm10\n\t" \
+ "mov $0x6CB7,%[a]\n\t" \
+ "packssdw %%xmm10,%%xmm4\n\t" \
+ "movd %[a],%%xmm12\n\t" \
+ "paddw %%xmm1,%%xmm4\n\t" \
+ /*xmm4=r=(t0''*27146+0x4000>>16)+t0''+(t0''!=0)*/ \
+ "pcmpeqw %%xmm15,%%xmm1\n\t" \
+ "pshufd $00,%%xmm12,%%xmm12\n\t" \
+ "psubw %%xmm14,%%xmm1\n\t" \
+ "mov $0x7FFF6C84,%[a]\n\t" \
+ "paddw %%xmm1,%%xmm4\n\t" \
+ /*xmm0=_y[0]=u=r+s>>1 \
+   The naive implementation could cause overflow, so we use \
+    u=(r&s)+((r^s)>>1).*/ \
+ "movdqa %%xmm0,%%xmm6\n\t" \
+ "pxor %%xmm4,%%xmm0\n\t" \
+ "pand %%xmm4,%%xmm6\n\t" \
+ "psraw $1,%%xmm0\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "paddw %%xmm6,%%xmm0\n\t" \
+ /*xmm4=_y[4]=v=r-u*/ \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "psubw %%xmm0,%%xmm4\n\t" \
+ /*xmm1,xmm6,xmm10,xmm11 are free.*/ \
+ /*xmm6:xmm10=60547*t3''+0x6CB7*/ \
+ "movdqa %%xmm3,%%xmm10\n\t" \
+ "movdqa %%xmm3,%%xmm6\n\t" \
+ "punpcklwd %%xmm3,%%xmm10\n\t" \
+ "pmaddwd %%xmm13,%%xmm10\n\t" \
+ "mov $0x61F861F8,%[a]\n\t" \
+ "punpckhwd %%xmm3,%%xmm6\n\t" \
+ "pmaddwd %%xmm13,%%xmm6\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "paddd %%xmm12,%%xmm10\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "paddd %%xmm12,%%xmm6\n\t" \
+ /*xmm1:xmm2=25080*t2'' \
+   xmm12=t2''*/ \
+ "movdqa %%xmm2,%%xmm11\n\t" \
+ "movdqa %%xmm2,%%xmm12\n\t" \
+ "pmullw %%xmm13,%%xmm2\n\t" \
+ "pmulhw %%xmm13,%%xmm11\n\t" \
+ "movdqa %%xmm2,%%xmm1\n\t" \
+ "punpcklwd %%xmm11,%%xmm2\n\t" \
+ "punpckhwd %%xmm11,%%xmm1\n\t" \
+ /*xmm10=u=(25080*t2''+60547*t3''+0x6CB7>>16)+(t3''!=0)*/ \
+ "paddd %%xmm2,%%xmm10\n\t" \
+ "paddd %%xmm1,%%xmm6\n\t" \
+ "psrad $16,%%xmm10\n\t" \
+ "pcmpeqw %%xmm15,%%xmm3\n\t" \
+ "psrad $16,%%xmm6\n\t" \
+ "psubw %%xmm14,%%xmm3\n\t" \
+ "packssdw %%xmm6,%%xmm10\n\t" \
+ "paddw %%xmm3,%%xmm10\n\t" \
+ /*xmm2=_y[2]=u \
+   xmm10=s=(25080*u>>16)-t2''*/ \
+ "movdqa %%xmm10,%%xmm2\n\t" \
+ "pmulhw %%xmm13,%%xmm10\n\t" \
+ "psubw %%xmm12,%%xmm10\n\t" \
+ /*xmm1:xmm6=s*21600+0x2800*/ \
+ "pxor %%xmm12,%%xmm12\n\t" \
+ "psubw %%xmm14,%%xmm12\n\t" \
+ "mov $0x28005460,%[a]\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "movdqa %%xmm10,%%xmm6\n\t" \
+ "movdqa %%xmm10,%%xmm1\n\t" \
+ "punpcklwd %%xmm12,%%xmm6\n\t" \
+ "pmaddwd %%xmm13,%%xmm6\n\t" \
+ "mov $0x0E3D,%[a]\n\t" \
+ "punpckhwd %%xmm12,%%xmm1\n\t" \
+ "pmaddwd %%xmm13,%%xmm1\n\t" \
+ /*xmm6=(s*21600+0x2800>>18)+s*/ \
+ "psrad $18,%%xmm6\n\t" \
+ "psrad $18,%%xmm1\n\t" \
+ "movd %[a],%%xmm12\n\t" \
+ "packssdw %%xmm1,%%xmm6\n\t" \
+ "pshufd $00,%%xmm12,%%xmm12\n\t" \
+ "paddw %%xmm10,%%xmm6\n\t" \
+ /*xmm6=_y[6]=v=(s*21600+0x2800>>18)+s+(s!=0)*/ \
+ "mov $0x7FFF54DC,%[a]\n\t" \
+ "pcmpeqw %%xmm15,%%xmm10\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "psubw %%xmm14,%%xmm10\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "paddw %%xmm10,%%xmm6\n\t " \
+ /*xmm1,xmm3,xmm10,xmm11 are free.*/ \
+ /*xmm11:xmm10=54491*t5'''+0x0E3D*/ \
+ "movdqa %%xmm5,%%xmm10\n\t" \
+ "movdqa %%xmm5,%%xmm11\n\t" \
+ "punpcklwd %%xmm5,%%xmm10\n\t" \
+ "pmaddwd %%xmm13,%%xmm10\n\t" \
+ "mov $0x8E3A8E3A,%[a]\n\t" \
+ "punpckhwd %%xmm5,%%xmm11\n\t" \
+ "pmaddwd %%xmm13,%%xmm11\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "paddd %%xmm12,%%xmm10\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "paddd %%xmm12,%%xmm11\n\t" \
+ /*xmm7:xmm12=36410*t6''' \
+   xmm1=t6'''*/ \
+ "movdqa %%xmm7,%%xmm3\n\t" \
+ "movdqa %%xmm7,%%xmm1\n\t" \
+ "pmulhw %%xmm13,%%xmm3\n\t" \
+ "pmullw %%xmm13,%%xmm7\n\t" \
+ "paddw %%xmm1,%%xmm3\n\t" \
+ "movdqa %%xmm7,%%xmm12\n\t" \
+ "punpckhwd %%xmm3,%%xmm7\n\t" \
+ "punpcklwd %%xmm3,%%xmm12\n\t" \
+ /*xmm10=u=(54491*t5'''+36410*t6'''+0x0E3D>>16)+(t5'''!=0)*/ \
+ "paddd %%xmm12,%%xmm10\n\t" \
+ "paddd %%xmm7,%%xmm11\n\t" \
+ "psrad $16,%%xmm10\n\t" \
+ "pcmpeqw %%xmm15,%%xmm5\n\t" \
+ "psrad $16,%%xmm11\n\t" \
+ "psubw %%xmm14,%%xmm5\n\t" \
+ "packssdw %%xmm11,%%xmm10\n\t" \
+ "pxor %%xmm12,%%xmm12\n\t" \
+ "paddw %%xmm5,%%xmm10\n\t" \
+ /*xmm5=_y[5]=u \
+   xmm1=s=t6'''-(36410*u>>16)*/ \
+ "psubw %%xmm14,%%xmm12\n\t" \
+ "movdqa %%xmm10,%%xmm5\n\t" \
+ "mov $0x340067C8,%[a]\n\t" \
+ "pmulhw %%xmm13,%%xmm10\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "paddw %%xmm5,%%xmm10\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "psubw %%xmm10,%%xmm1\n\t" \
+ /*xmm11:xmm3=s*26568+0x3400*/ \
+ "movdqa %%xmm1,%%xmm3\n\t" \
+ "movdqa %%xmm1,%%xmm11\n\t" \
+ "punpcklwd %%xmm12,%%xmm3\n\t" \
+ "pmaddwd %%xmm13,%%xmm3\n\t" \
+ "mov $0x7B1B,%[a]\n\t" \
+ "punpckhwd %%xmm12,%%xmm11\n\t" \
+ "pmaddwd %%xmm13,%%xmm11\n\t" \
+ /*xmm3=(s*26568+0x3400>>17)+s*/ \
+ "psrad $17,%%xmm3\n\t" \
+ "psrad $17,%%xmm11\n\t" \
+ "movd %[a],%%xmm12\n\t" \
+ "packssdw %%xmm11,%%xmm3\n\t" \
+ "pshufd $00,%%xmm12,%%xmm12\n\t" \
+ "paddw %%xmm1,%%xmm3\n\t" \
+ /*xmm3=_y[3]=v=(s*26568+0x3400>>17)+s+(s!=0)*/ \
+ "mov $0x7FFF7B16,%[a]\n\t" \
+ "pcmpeqw %%xmm15,%%xmm1\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "psubw %%xmm14,%%xmm1\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "paddw %%xmm1,%%xmm3\n\t " \
+ /*xmm1,xmm7,xmm10,xmm11 are free.*/ \
+ /*xmm11:xmm10=64277*t7''+0x7B1B*/ \
+ "movdqa %%xmm9,%%xmm10\n\t" \
+ "movdqa %%xmm9,%%xmm11\n\t" \
+ "punpcklwd %%xmm9,%%xmm10\n\t" \
+ "pmaddwd %%xmm13,%%xmm10\n\t" \
+ "mov $0x31F131F1,%[a]\n\t" \
+ "punpckhwd %%xmm9,%%xmm11\n\t" \
+ "pmaddwd %%xmm13,%%xmm11\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "paddd %%xmm12,%%xmm10\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ "paddd %%xmm12,%%xmm11\n\t" \
+ /*xmm12:xmm7=12785*t4''*/ \
+ "movdqa %%xmm8,%%xmm7\n\t" \
+ "movdqa %%xmm8,%%xmm1\n\t" \
+ "pmullw %%xmm13,%%xmm7\n\t" \
+ "pmulhw %%xmm13,%%xmm1\n\t" \
+ "movdqa %%xmm7,%%xmm12\n\t" \
+ "punpcklwd %%xmm1,%%xmm7\n\t" \
+ "punpckhwd %%xmm1,%%xmm12\n\t" \
+ /*xmm10=u=(12785*t4''+64277*t7''+0x7B1B>>16)+(t7''!=0)*/ \
+ "paddd %%xmm7,%%xmm10\n\t" \
+ "paddd %%xmm12,%%xmm11\n\t" \
+ "psrad $16,%%xmm10\n\t" \
+ "pcmpeqw %%xmm15,%%xmm9\n\t" \
+ "psrad $16,%%xmm11\n\t" \
+ "psubw %%xmm14,%%xmm9\n\t" \
+ "packssdw %%xmm11,%%xmm10\n\t" \
+ "pxor %%xmm12,%%xmm12\n\t" \
+ "paddw %%xmm9,%%xmm10\n\t" \
+ /*xmm1=_y[1]=u \
+   xmm10=s=(12785*u>>16)-t4''*/ \
+ "psubw %%xmm14,%%xmm12\n\t" \
+ "movdqa %%xmm10,%%xmm1\n\t" \
+ "mov $0x3000503B,%[a]\n\t" \
+ "pmulhw %%xmm13,%%xmm10\n\t" \
+ "movd %[a],%%xmm13\n\t" \
+ "psubw %%xmm8,%%xmm10\n\t" \
+ "pshufd $00,%%xmm13,%%xmm13\n\t" \
+ /*xmm8:xmm7=s*20539+0x3000*/ \
+ "movdqa %%xmm10,%%xmm7\n\t" \
+ "movdqa %%xmm10,%%xmm8\n\t" \
+ "punpcklwd %%xmm12,%%xmm7\n\t" \
+ "pmaddwd %%xmm13,%%xmm7\n\t" \
+ "punpckhwd %%xmm12,%%xmm8\n\t" \
+ "pmaddwd %%xmm13,%%xmm8\n\t" \
+ /*xmm7=(s*20539+0x3000>>20)+s*/ \
+ "psrad $20,%%xmm7\n\t" \
+ "psrad $20,%%xmm8\n\t" \
+ "packssdw %%xmm8,%%xmm7\n\t" \
+ "paddw %%xmm10,%%xmm7\n\t" \
+ /*xmm7=_y[7]=v=(s*20539+0x3000>>20)+s+(s!=0)*/ \
+ "pcmpeqw %%xmm15,%%xmm10\n\t" \
+ "psubw %%xmm14,%%xmm10\n\t" \
+ "paddw %%xmm10,%%xmm7\n\t " \
+
+# define OC_TRANSPOSE8x8 \
+ "#OC_TRANSPOSE8x8\n\t" \
+ "movdqa %%xmm4,%%xmm8\n\t" \
+ /*xmm4 = f3 e3 f2 e2 f1 e1 f0 e0*/ \
+ "punpcklwd %%xmm5,%%xmm4\n\t" \
+ /*xmm8 = f7 e7 f6 e6 f5 e5 f4 e4*/ \
+ "punpckhwd %%xmm5,%%xmm8\n\t" \
+ /*xmm5 is free.*/ \
+ "movdqa %%xmm0,%%xmm5\n\t" \
+ /*xmm0 = b3 a3 b2 a2 b1 a1 b0 a0*/ \
+ "punpcklwd %%xmm1,%%xmm0\n\t" \
+ /*xmm5 = b7 a7 b6 a6 b5 a5 b4 a4*/ \
+ "punpckhwd %%xmm1,%%xmm5\n\t" \
+ /*xmm1 is free.*/ \
+ "movdqa %%xmm6,%%xmm1\n\t" \
+ /*xmm6 = h3 g3 h2 g2 h1 g1 h0 g0*/ \
+ "punpcklwd %%xmm7,%%xmm6\n\t" \
+ /*xmm1 = h7 g7 h6 g6 h5 g5 h4 g4*/ \
+ "punpckhwd %%xmm7,%%xmm1\n\t" \
+ /*xmm7 is free.*/ \
+ "movdqa %%xmm2,%%xmm7\n\t" \
+ /*xmm7 = d3 c3 d2 c2 d1 c1 d0 c0*/ \
+ "punpcklwd %%xmm3,%%xmm7\n\t" \
+ /*xmm2 = d7 c7 d6 c6 d5 c5 d4 c4*/ \
+ "punpckhwd %%xmm3,%%xmm2\n\t" \
+ /*xmm3 is free.*/ \
+ "movdqa %%xmm0,%%xmm3\n\t" \
+ /*xmm0 = d1 c1 b1 a1 d0 c0 b0 a0*/ \
+ "punpckldq %%xmm7,%%xmm0\n\t" \
+ /*xmm3 = d3 c3 b3 a3 d2 c2 b2 a2*/ \
+ "punpckhdq %%xmm7,%%xmm3\n\t" \
+ /*xmm7 is free.*/ \
+ "movdqa %%xmm5,%%xmm7\n\t" \
+ /*xmm5 = d5 c5 b5 a5 d4 c4 b4 a4*/ \
+ "punpckldq %%xmm2,%%xmm5\n\t" \
+ /*xmm7 = d7 c7 b7 a7 d6 c6 b6 a6*/ \
+ "punpckhdq %%xmm2,%%xmm7\n\t" \
+ /*xmm2 is free.*/ \
+ "movdqa %%xmm4,%%xmm2\n\t" \
+ /*xmm2 = h1 g1 f1 e1 h0 g0 f0 e0*/ \
+ "punpckldq %%xmm6,%%xmm2\n\t" \
+ /*xmm4 = h3 g3 f3 e3 h2 g2 f2 e2*/ \
+ "punpckhdq %%xmm6,%%xmm4\n\t" \
+ /*xmm6 is free.*/ \
+ "movdqa %%xmm8,%%xmm6\n\t" \
+ /*xmm6 = h5 g5 f5 e5 h4 g4 f4 e4*/ \
+ "punpckldq %%xmm1,%%xmm6\n\t" \
+ /*xmm8 = h7 g7 f7 e7 h6 g6 f6 e6*/ \
+ "punpckhdq %%xmm1,%%xmm8\n\t" \
+ /*xmm1 is free.*/ \
+ "movdqa %%xmm0,%%xmm1\n\t" \
+ /*xmm0 = h0 g0 f0 e0 d0 c0 b0 a0*/ \
+ "punpcklqdq %%xmm2,%%xmm0\n\t" \
+ /*xmm1 = h1 g1 f1 e1 d1 c1 b1 a1*/ \
+ "punpckhqdq %%xmm2,%%xmm1\n\t" \
+ /*xmm2 is free.*/ \
+ "movdqa %%xmm3,%%xmm2\n\t" \
+ /*xmm2 = h2 g2 f2 e2 d2 c2 b2 a2*/ \
+ "punpcklqdq %%xmm4,%%xmm2\n\t" \
+ /*xmm3 = h3 g3 f3 e3 d3 c3 b3 a3*/ \
+ "punpckhqdq %%xmm4,%%xmm3\n\t" \
+ /*xmm4 is free.*/ \
+ "movdqa %%xmm5,%%xmm4\n\t" \
+ /*xmm4 = h4 g4 f4 e4 d4 c4 b4 a4*/ \
+ "punpcklqdq %%xmm6,%%xmm4\n\t" \
+ /*xmm5 = h5 g5 f5 e5 d5 c5 b5 a5*/ \
+ "punpckhqdq %%xmm6,%%xmm5\n\t" \
+ /*xmm6 is free.*/ \
+ "movdqa %%xmm7,%%xmm6\n\t" \
+ /*xmm6 = h6 g6 f6 e6 d6 c6 b6 a6*/ \
+ "punpcklqdq %%xmm8,%%xmm6\n\t" \
+ /*xmm7 = h7 g7 f7 e7 d7 c7 b7 a7*/ \
+ "punpckhqdq %%xmm8,%%xmm7\n\t" \
+ /*xmm8 is free.*/ \
+
+/*SSE2 implementation of the fDCT for x86-64 only.
+  Because of the 8 extra XMM registers on x86-64, this version can operate
+   without any temporary stack access at all.*/
+void oc_enc_fdct8x8_x86_64sse2(ogg_int16_t _y[64],const ogg_int16_t _x[64]){
+  ptrdiff_t a;
+  __asm__ __volatile__(
+    /*Load the input.*/
+    "movdqa 0x00(%[x]),%%xmm0\n\t"
+    "movdqa 0x10(%[x]),%%xmm1\n\t"
+    "movdqa 0x20(%[x]),%%xmm2\n\t"
+    "movdqa 0x30(%[x]),%%xmm3\n\t"
+    "movdqa 0x40(%[x]),%%xmm4\n\t"
+    "movdqa 0x50(%[x]),%%xmm5\n\t"
+    "movdqa 0x60(%[x]),%%xmm6\n\t"
+    "movdqa 0x70(%[x]),%%xmm7\n\t"
+    /*Add two extra bits of working precision to improve accuracy; any more and
+       we could overflow.*/
+    /*We also add a few biases to correct for some systematic error that
+       remains in the full fDCT->iDCT round trip.*/
+    /*xmm15={0}x8*/
+    "pxor %%xmm15,%%xmm15\n\t"
+    /*xmm14={-1}x8*/
+    "pcmpeqb %%xmm14,%%xmm14\n\t"
+    "psllw $2,%%xmm0\n\t"
+    /*xmm8=xmm0*/
+    "movdqa %%xmm0,%%xmm8\n\t"
+    "psllw $2,%%xmm1\n\t"
+    /*xmm8={_x[7...0]==0}*/
+    "pcmpeqw %%xmm15,%%xmm8\n\t"
+    "psllw $2,%%xmm2\n\t"
+    /*xmm8={_x[7...0]!=0}*/
+    "psubw %%xmm14,%%xmm8\n\t"
+    "psllw $2,%%xmm3\n\t"
+    /*%[a]=1*/
+    "mov $1,%[a]\n\t"
+    /*xmm8={_x[6]!=0,0,_x[4]!=0,0,_x[2]!=0,0,_x[0]!=0,0}*/
+    "pslld $16,%%xmm8\n\t"
+    "psllw $2,%%xmm4\n\t"
+    /*xmm9={0,0,0,0,0,0,0,1}*/
+    "movd %[a],%%xmm9\n\t"
+    /*xmm8={0,0,_x[2]!=0,0,_x[0]!=0,0}*/
+    "pshufhw $0x00,%%xmm8,%%xmm8\n\t"
+    "psllw $2,%%xmm5\n\t"
+    /*%[a]={1}x2*/
+    "mov $0x10001,%[a]\n\t"
+    /*xmm8={0,0,0,0,0,0,0,_x[0]!=0}*/
+    "pshuflw $0x01,%%xmm8,%%xmm8\n\t"
+    "psllw $2,%%xmm6\n\t"
+    /*xmm10={0,0,0,0,0,0,1,1}*/
+    "movd %[a],%%xmm10\n\t"
+    /*xmm0=_x[7...0]+{0,0,0,0,0,0,0,_x[0]!=0}*/
+    "paddw %%xmm8,%%xmm0\n\t"
+    "psllw $2,%%xmm7\n\t"
+    /*xmm0=_x[7...0]+{0,0,0,0,0,0,1,(_x[0]!=0)+1}*/
+    "paddw %%xmm10,%%xmm0\n\t"
+    /*xmm1=_x[15...8]-{0,0,0,0,0,0,0,1}*/
+    "psubw %%xmm9,%%xmm1\n\t"
+    /*Transform columns.*/
+    OC_FDCT8x8
+    /*Transform rows.*/
+    OC_TRANSPOSE8x8
+    OC_FDCT8x8
+    /*TODO: zig-zag ordering?*/
+    OC_TRANSPOSE8x8
+    /*xmm14={-2,-2,-2,-2,-2,-2,-2,-2}*/
+    "paddw %%xmm14,%%xmm14\n\t"
+    "psubw %%xmm14,%%xmm0\n\t"
+    "psubw %%xmm14,%%xmm1\n\t"
+    "psraw $2,%%xmm0\n\t"
+    "psubw %%xmm14,%%xmm2\n\t"
+    "psraw $2,%%xmm1\n\t"
+    "psubw %%xmm14,%%xmm3\n\t"
+    "psraw $2,%%xmm2\n\t"
+    "psubw %%xmm14,%%xmm4\n\t"
+    "psraw $2,%%xmm3\n\t"
+    "psubw %%xmm14,%%xmm5\n\t"
+    "psraw $2,%%xmm4\n\t"
+    "psubw %%xmm14,%%xmm6\n\t"
+    "psraw $2,%%xmm5\n\t"
+    "psubw %%xmm14,%%xmm7\n\t"
+    "psraw $2,%%xmm6\n\t"
+    "psraw $2,%%xmm7\n\t"
+    /*Store the result.*/
+    "movdqa %%xmm0,0x00(%[y])\n\t"
+    "movdqa %%xmm1,0x10(%[y])\n\t"
+    "movdqa %%xmm2,0x20(%[y])\n\t"
+    "movdqa %%xmm3,0x30(%[y])\n\t"
+    "movdqa %%xmm4,0x40(%[y])\n\t"
+    "movdqa %%xmm5,0x50(%[y])\n\t"
+    "movdqa %%xmm6,0x60(%[y])\n\t"
+    "movdqa %%xmm7,0x70(%[y])\n\t"
+    :[a]"=&r"(a)
+    :[y]"r"(_y),[x]"r"(_x)
+    :"memory"
+  );
+}
+#endif
diff --git a/lib/x86/x86enc.c b/lib/x86/x86enc.c
new file mode 100644 (file)
index 0000000..43b7be3
--- /dev/null
@@ -0,0 +1,49 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86state.c 15675 2009-02-06 09:43:27Z tterribe $
+
+ ********************************************************************/
+#include "x86enc.h"
+
+#if defined(OC_X86_ASM)
+
+#include "../cpu.c"
+
+void oc_enc_vtable_init_x86(oc_enc_ctx *_enc){
+  ogg_uint32_t cpu_flags;
+  cpu_flags=oc_cpu_flags_get();
+  oc_enc_vtable_init_c(_enc);
+  if(cpu_flags&OC_CPU_X86_MMX){
+    _enc->opt_vtable.frag_sub=oc_enc_frag_sub_mmx;
+    _enc->opt_vtable.frag_sub_128=oc_enc_frag_sub_128_mmx;
+    _enc->opt_vtable.frag_recon_intra=oc_frag_recon_intra_mmx;
+    _enc->opt_vtable.frag_recon_inter=oc_frag_recon_inter_mmx;
+    _enc->opt_vtable.fdct8x8=oc_enc_fdct8x8_mmx;
+  }
+  if(cpu_flags&OC_CPU_X86_MMXEXT){
+    _enc->opt_vtable.frag_sad=oc_enc_frag_sad_mmxext;
+    _enc->opt_vtable.frag_sad_thresh=oc_enc_frag_sad_thresh_mmxext;
+    _enc->opt_vtable.frag_sad2_thresh=oc_enc_frag_sad2_thresh_mmxext;
+    _enc->opt_vtable.frag_satd_thresh=oc_enc_frag_satd_thresh_mmxext;
+    _enc->opt_vtable.frag_satd2_thresh=oc_enc_frag_satd2_thresh_mmxext;
+    _enc->opt_vtable.frag_intra_satd=oc_enc_frag_intra_satd_mmxext;
+    _enc->opt_vtable.frag_copy2=oc_enc_frag_copy2_mmxext;
+  }
+  if(cpu_flags&OC_CPU_X86_SSE2){
+# if defined(OC_X86_64_ASM)
+    /*_enc->opt_vtable.fdct8x8=oc_enc_fdct8x8_x86_64sse2;*/
+# endif
+  }
+}
+#endif
diff --git a/lib/x86/x86enc.h b/lib/x86/x86enc.h
new file mode 100644 (file)
index 0000000..06c3908
--- /dev/null
@@ -0,0 +1,47 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86int.h 15675 2009-02-06 09:43:27Z tterribe $
+
+ ********************************************************************/
+
+#if !defined(_x86_x86enc_H)
+# define _x86_x86enc_H (1)
+# include "../encint.h"
+# include "x86int.h"
+
+void oc_enc_vtable_init_x86(oc_enc_ctx *_enc);
+
+unsigned oc_enc_frag_sad_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride);
+unsigned oc_enc_frag_sad_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_sad2_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_satd_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_satd2_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_intra_satd_mmxext(const unsigned char *_src,int _ystride);
+void oc_enc_frag_sub_mmx(ogg_int16_t _diff[64],
+ const unsigned char *_x,const unsigned char *_y,int _stride);
+void oc_enc_frag_sub_128_mmx(ogg_int16_t _diff[64],
+ const unsigned char *_x,int _stride);
+void oc_enc_frag_copy2_mmxext(unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride);
+void oc_enc_fdct8x8_mmx(ogg_int16_t _y[64],const ogg_int16_t _x[64]);
+void oc_enc_fdct8x8_x86_64sse2(ogg_int16_t _y[64],const ogg_int16_t _x[64]);
+
+#endif
diff --git a/lib/x86/x86int.h b/lib/x86/x86int.h
new file mode 100644 (file)
index 0000000..ede724f
--- /dev/null
@@ -0,0 +1,42 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86int.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#if !defined(_x86_x86int_H)
+# define _x86_x86int_H (1)
+# include "../internal.h"
+
+void oc_state_vtable_init_x86(oc_theora_state *_state);
+
+void oc_frag_copy_mmx(unsigned char *_dst,
+ const unsigned char *_src,int _ystride);
+void oc_frag_recon_intra_mmx(unsigned char *_dst,int _ystride,
+ const ogg_int16_t *_residue);
+void oc_frag_recon_inter_mmx(unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t *_residue);
+void oc_frag_recon_inter2_mmx(unsigned char *_dst,const unsigned char *_src1,
+ const unsigned char *_src2,int _ystride,const ogg_int16_t *_residue);
+void oc_idct8x8_mmx(ogg_int16_t _y[64],int _last_zzi);
+void oc_state_frag_recon_mmx(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant);
+void oc_state_frag_copy_list_mmx(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli);
+void oc_state_loop_filter_frag_rows_mmx(const oc_theora_state *_state,
+ int _bv[256],int _refi,int _pli,int _fragy0,int _fragy_end);
+void oc_restore_fpu_mmx(void);
+
+#endif
diff --git a/lib/x86/x86state.c b/lib/x86/x86state.c
new file mode 100644 (file)
index 0000000..a786bec
--- /dev/null
@@ -0,0 +1,62 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86state.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include "x86int.h"
+
+#if defined(OC_X86_ASM)
+
+#include "../cpu.c"
+
+/*This table has been modified from OC_FZIG_ZAG by baking a 4x4 transpose into
+   each quadrant of the destination.*/
+static const unsigned char OC_FZIG_ZAG_MMX[128]={
+   0, 8, 1, 2, 9,16,24,17,
+  10, 3,32,11,18,25, 4,12,
+   5,26,19,40,33,34,41,48,
+  27, 6,13,20,28,21,14, 7,
+  56,49,42,35,43,50,57,36,
+  15,22,29,30,23,44,37,58,
+  51,59,38,45,52,31,60,53,
+  46,39,47,54,61,62,55,63,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+};
+
+void oc_state_vtable_init_x86(oc_theora_state *_state){
+  _state->cpu_flags=oc_cpu_flags_get();
+  if(_state->cpu_flags&OC_CPU_X86_MMX){
+    _state->opt_vtable.frag_copy=oc_frag_copy_mmx;
+    _state->opt_vtable.frag_recon_intra=oc_frag_recon_intra_mmx;
+    _state->opt_vtable.frag_recon_inter=oc_frag_recon_inter_mmx;
+    _state->opt_vtable.frag_recon_inter2=oc_frag_recon_inter2_mmx;
+    _state->opt_vtable.idct8x8=oc_idct8x8_mmx;
+    _state->opt_vtable.state_frag_recon=oc_state_frag_recon_mmx;
+    _state->opt_vtable.state_frag_copy_list=oc_state_frag_copy_list_mmx;
+    _state->opt_vtable.state_loop_filter_frag_rows=
+     oc_state_loop_filter_frag_rows_mmx;
+    _state->opt_vtable.restore_fpu=oc_restore_fpu_mmx;
+    _state->opt_data.dct_fzig_zag=OC_FZIG_ZAG_MMX;
+  }
+  else oc_state_vtable_init_c(_state);
+}
+#endif
diff --git a/lib/x86_vc/mmxencfrag.c b/lib/x86_vc/mmxencfrag.c
new file mode 100644 (file)
index 0000000..ac9dacf
--- /dev/null
@@ -0,0 +1,969 @@
+/********************************************************************\r
+ *                                                                  *\r
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *\r
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *\r
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *\r
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *\r
+ *                                                                  *\r
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *\r
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *\r
+ *                                                                  *\r
+ ********************************************************************\r
+\r
+  function:\r
+  last mod: $Id: dsp_mmx.c 14579 2008-03-12 06:42:40Z xiphmont $\r
+\r
+ ********************************************************************/\r
+#include <stddef.h>\r
+#include "x86enc.h"\r
+\r
+#if defined(OC_X86_ASM)\r
+\r
+unsigned oc_enc_frag_sad_mmxext(const unsigned char *_src,\r
+ const unsigned char *_ref,int _ystride){\r
+  ptrdiff_t ret;\r
+  __asm{\r
+#define SRC esi\r
+#define REF edx\r
+#define YSTRIDE ecx\r
+#define YSTRIDE3 edi\r
+    mov YSTRIDE,_ystride\r
+    mov SRC,_src\r
+    mov REF,_ref\r
+    /*Load the first 4 rows of each block.*/\r
+    movq mm0,[SRC]\r
+    movq mm1,[REF]\r
+    movq mm2,[SRC][YSTRIDE]\r
+    movq mm3,[REF][YSTRIDE]\r
+    lea YSTRIDE3,[YSTRIDE+YSTRIDE*2]\r
+    movq mm4,[SRC+YSTRIDE*2]\r
+    movq mm5,[REF+YSTRIDE*2]\r
+    movq mm6,[SRC+YSTRIDE3]\r
+    movq mm7,[REF+YSTRIDE3]\r
+    /*Compute their SADs and add them in mm0*/\r
+    psadbw mm0,mm1\r
+    psadbw mm2,mm3\r
+    lea SRC,[SRC+YSTRIDE*4]\r
+    paddw mm0,mm2\r
+    lea REF,[REF+YSTRIDE*4]\r
+    /*Load the next 3 rows as registers become available.*/\r
+    movq mm2,[SRC]\r
+    movq mm3,[REF]\r
+    psadbw mm4,mm5\r
+    psadbw mm6,mm7\r
+    paddw mm0,mm4\r
+    movq mm5,[REF+YSTRIDE]\r
+    movq mm4,[SRC+YSTRIDE]\r
+    paddw mm0,mm6\r
+    movq mm7,[REF+YSTRIDE*2]\r
+    movq mm6,[SRC+YSTRIDE*2]\r
+    /*Start adding their SADs to mm0*/\r
+    psadbw mm2,mm3\r
+    psadbw mm4,mm5\r
+    paddw mm0,mm2\r
+    psadbw mm6,mm7\r
+    /*Load last row as registers become available.*/\r
+    movq mm2,[SRC+YSTRIDE3]\r
+    movq mm3,[REF+YSTRIDE3]\r
+    /*And finish adding up their SADs.*/\r
+    paddw mm0,mm4\r
+    psadbw mm2,mm3\r
+    paddw mm0,mm6\r
+    paddw mm0,mm2\r
+    movd [ret],mm0\r
+#undef SRC\r
+#undef REF\r
+#undef YSTRIDE\r
+#undef YSTRIDE3\r
+  }\r
+  return (unsigned)ret;\r
+}\r
+\r
+unsigned oc_enc_frag_sad_thresh_mmxext(const unsigned char *_src,\r
+ const unsigned char *_ref,int _ystride,unsigned _thresh){\r
+  /*Early termination is for suckers.*/\r
+  return oc_enc_frag_sad_mmxext(_src,_ref,_ystride);\r
+}\r
+\r
+#define OC_SAD2_LOOP __asm{ \\r
+  /*We want to compute (mm0+mm1>>1) on unsigned bytes without overflow, but \\r
+     pavgb computes (mm0+mm1+1>>1). \\r
+   The latter is exactly 1 too large when the low bit of two corresponding \\r
+    bytes is only set in one of them. \\r
+   Therefore we pxor the operands, pand to mask out the low bits, and psubb to \\r
+    correct the output of pavgb.*/ \\r
+  __asm  movq mm6,mm0 \\r
+  __asm  lea REF1,[REF1+YSTRIDE*2] \\r
+  __asm  pxor mm0,mm1 \\r
+  __asm  pavgb mm6,mm1 \\r
+  __asm  lea REF2,[REF2+YSTRIDE*2] \\r
+  __asm  movq mm1,mm2 \\r
+  __asm  pand mm0,mm7 \\r
+  __asm  pavgb mm2,mm3 \\r
+  __asm  pxor mm1,mm3 \\r
+  __asm  movq mm3,[REF2+YSTRIDE] \\r
+  __asm  psubb mm6,mm0 \\r
+  __asm  movq mm0,[REF1] \\r
+  __asm  pand mm1,mm7 \\r
+  __asm  psadbw mm4,mm6 \\r
+  __asm  movd mm6,RET \\r
+  __asm  psubb mm2,mm1 \\r
+  __asm  movq mm1,[REF2] \\r
+  __asm  lea SRC,[SRC+YSTRIDE*2] \\r
+  __asm  psadbw mm5,mm2 \\r
+  __asm  movq mm2,[REF1+YSTRIDE] \\r
+  __asm  paddw mm5,mm4 \\r
+  __asm  movq mm4,[SRC] \\r
+  __asm  paddw mm6,mm5 \\r
+  __asm  movq mm5,[SRC+YSTRIDE] \\r
+  __asm  movd RET,mm6 \\r
+}\r
+\r
+/*Same as above, but does not pre-load the next two rows.*/\r
+#define OC_SAD2_TAIL __asm{ \\r
+  __asm  movq mm6,mm0 \\r
+  __asm  pavgb mm0,mm1 \\r
+  __asm  pxor mm6,mm1 \\r
+  __asm  movq mm1,mm2 \\r
+  __asm  pand mm6,mm7 \\r
+  __asm  pavgb mm2,mm3 \\r
+  __asm  pxor mm1,mm3 \\r
+  __asm  psubb mm0,mm6 \\r
+  __asm  pand mm1,mm7 \\r
+  __asm  psadbw mm4,mm0 \\r
+  __asm  psubb mm2,mm1 \\r
+  __asm  movd mm6,RET \\r
+  __asm  psadbw mm5,mm2 \\r
+  __asm  paddw mm5,mm4 \\r
+  __asm  paddw mm6,mm5 \\r
+  __asm  movd RET,mm6 \\r
+}\r
+\r
+unsigned oc_enc_frag_sad2_thresh_mmxext(const unsigned char *_src,\r
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,\r
+ unsigned _thresh){\r
+  ptrdiff_t ret;\r
+  __asm{\r
+#define REF1 ecx\r
+#define REF2 edi\r
+#define YSTRIDE esi\r
+#define SRC edx\r
+#define RET eax\r
+    mov YSTRIDE,_ystride\r
+    mov SRC,_src\r
+    mov REF1,_ref1\r
+    mov REF2,_ref2\r
+    movq mm0,[REF1]\r
+    movq mm1,[REF2]\r
+    movq mm2,[REF1+YSTRIDE]\r
+    movq mm3,[REF2+YSTRIDE]\r
+    xor RET,RET\r
+    movq mm4,[SRC]\r
+    pxor mm7,mm7\r
+    pcmpeqb mm6,mm6\r
+    movq mm5,[SRC+YSTRIDE]\r
+    psubb mm7,mm6\r
+    OC_SAD2_LOOP\r
+    OC_SAD2_LOOP\r
+    OC_SAD2_LOOP\r
+    OC_SAD2_TAIL\r
+    mov [ret],RET\r
+#undef REF1\r
+#undef REF2\r
+#undef YSTRIDE\r
+#undef SRC\r
+#undef RET\r
+  }\r
+  return (unsigned)ret;\r
+}\r
+\r
+/*Load an 8x4 array of pixel values from %[src] and %[ref] and compute their\r
+  16-bit difference in mm0...mm7.*/\r
+#define OC_LOAD_SUB_8x4(_off) __asm{ \\r
+  __asm  movd mm0,[_off+SRC] \\r
+  __asm  movd mm4,[_off+REF] \\r
+  __asm  movd mm1,[_off+SRC+SRC_YSTRIDE] \\r
+  __asm  lea SRC,[SRC+SRC_YSTRIDE*2] \\r
+  __asm  movd mm5,[_off+REF+REF_YSTRIDE] \\r
+  __asm  lea REF,[REF+REF_YSTRIDE*2] \\r
+  __asm  movd mm2,[_off+SRC] \\r
+  __asm  movd mm7,[_off+REF] \\r
+  __asm  movd mm3,[_off+SRC+SRC_YSTRIDE] \\r
+  __asm  movd mm6,[_off+REF+REF_YSTRIDE] \\r
+  __asm  punpcklbw mm0,mm4 \\r
+  __asm  lea SRC,[SRC+SRC_YSTRIDE*2] \\r
+  __asm  punpcklbw mm4,mm4 \\r
+  __asm  lea REF,[REF+REF_YSTRIDE*2] \\r
+  __asm  psubw mm0,mm4 \\r
+  __asm  movd mm4,[_off+SRC] \\r
+  __asm  movq [_off*2+BUF],mm0 \\r
+  __asm  movd mm0,[_off+REF] \\r
+  __asm  punpcklbw mm1,mm5 \\r
+  __asm  punpcklbw mm5,mm5 \\r
+  __asm  psubw mm1,mm5 \\r
+  __asm  movd mm5,[_off+SRC+SRC_YSTRIDE] \\r
+  __asm  punpcklbw mm2,mm7 \\r
+  __asm  punpcklbw mm7,mm7 \\r
+  __asm  psubw mm2,mm7 \\r
+  __asm  movd mm7,[_off+REF+REF_YSTRIDE] \\r
+  __asm  punpcklbw mm3,mm6 \\r
+  __asm  lea SRC,[SRC+SRC_YSTRIDE*2] \\r
+  __asm  punpcklbw mm6,mm6 \\r
+  __asm  psubw mm3,mm6 \\r
+  __asm  movd mm6,[_off+SRC] \\r
+  __asm  punpcklbw mm4,mm0 \\r
+  __asm  lea REF,[REF+REF_YSTRIDE*2] \\r
+  __asm  punpcklbw mm0,mm0 \\r
+  __asm  lea SRC,[SRC+SRC_YSTRIDE*2] \\r
+  __asm  psubw mm4,mm0 \\r
+  __asm  movd mm0,[_off+REF] \\r
+  __asm  punpcklbw mm5,mm7 \\r
+  __asm  neg SRC_YSTRIDE \\r
+  __asm  punpcklbw mm7,mm7 \\r
+  __asm  psubw mm5,mm7 \\r
+  __asm  movd mm7,[_off+SRC+SRC_YSTRIDE] \\r
+  __asm  punpcklbw mm6,mm0 \\r
+  __asm  lea REF,[REF+REF_YSTRIDE*2] \\r
+  __asm  punpcklbw mm0,mm0 \\r
+  __asm  neg REF_YSTRIDE \\r
+  __asm  psubw mm6,mm0 \\r
+  __asm  movd mm0,[_off+REF+REF_YSTRIDE] \\r
+  __asm  lea SRC,[SRC+SRC_YSTRIDE*8] \\r
+  __asm  punpcklbw mm7,mm0 \\r
+  __asm  neg SRC_YSTRIDE \\r
+  __asm  punpcklbw mm0,mm0 \\r
+  __asm  lea REF,[REF+REF_YSTRIDE*8] \\r
+  __asm  psubw mm7,mm0 \\r
+  __asm  neg REF_YSTRIDE \\r
+  __asm  movq mm0,[_off*2+BUF] \\r
+}\r
+\r
+/*Load an 8x4 array of pixel values from %[src] into %%mm0...%%mm7.*/\r
+#define OC_LOAD_8x4(_off) __asm{ \\r
+  __asm  movd mm0,[_off+SRC] \\r
+  __asm  movd mm1,[_off+SRC+YSTRIDE] \\r
+  __asm  movd mm2,[_off+SRC+YSTRIDE*2] \\r
+  __asm  pxor mm7,mm7 \\r
+  __asm  movd mm3,[_off+SRC+YSTRIDE3] \\r
+  __asm  punpcklbw mm0,mm7 \\r
+  __asm  movd mm4,[_off+SRC4] \\r
+  __asm  punpcklbw mm1,mm7 \\r
+  __asm  movd mm5,[_off+SRC4+YSTRIDE] \\r
+  __asm  punpcklbw mm2,mm7 \\r
+  __asm  movd mm6,[_off+SRC4+YSTRIDE*2] \\r
+  __asm  punpcklbw mm3,mm7 \\r
+  __asm  movd mm7,[_off+SRC4+YSTRIDE3] \\r
+  __asm  punpcklbw mm4,mm4 \\r
+  __asm  punpcklbw mm5,mm5 \\r
+  __asm  psrlw mm4,8 \\r
+  __asm  psrlw mm5,8 \\r
+  __asm  punpcklbw mm6,mm6 \\r
+  __asm  punpcklbw mm7,mm7 \\r
+  __asm  psrlw mm6,8 \\r
+  __asm  psrlw mm7,8 \\r
+}\r
+\r
+/*Performs the first two stages of an 8-point 1-D Hadamard transform.\r
+  The transform is performed in place, except that outputs 0-3 are swapped with\r
+   outputs 4-7.\r
+  Outputs 2, 3, 6 and 7 from the second stage are negated (which allows us to\r
+   perform this stage in place with no temporary registers).*/\r
+#define OC_HADAMARD_AB_8x4 __asm{ \\r
+  /*Stage A: \\r
+    Outputs 0-3 are swapped with 4-7 here.*/ \\r
+  __asm  paddw mm5,mm1 \\r
+  __asm  paddw mm6,mm2 \\r
+  __asm  paddw mm1,mm1 \\r
+  __asm  paddw mm2,mm2 \\r
+  __asm  psubw mm1,mm5 \\r
+  __asm  psubw mm2,mm6 \\r
+  __asm  paddw mm7,mm3 \\r
+  __asm  paddw mm4,mm0 \\r
+  __asm  paddw mm3,mm3 \\r
+  __asm  paddw mm0,mm0 \\r
+  __asm  psubw mm3,mm7 \\r
+  __asm  psubw mm0,mm4 \\r
+   /*Stage B:*/ \\r
+  __asm  paddw mm0,mm2 \\r
+  __asm  paddw mm1,mm3 \\r
+  __asm  paddw mm4,mm6 \\r
+  __asm  paddw mm5,mm7 \\r
+  __asm  paddw mm2,mm2 \\r
+  __asm  paddw mm3,mm3 \\r
+  __asm  paddw mm6,mm6 \\r
+  __asm  paddw mm7,mm7 \\r
+  __asm  psubw mm2,mm0 \\r
+  __asm  psubw mm3,mm1 \\r
+  __asm  psubw mm6,mm4 \\r
+  __asm  psubw mm7,mm5 \\r
+}\r
+\r
+/*Performs the last stage of an 8-point 1-D Hadamard transform in place.\r
+  Ouputs 1, 3, 5, and 7 are negated (which allows us to perform this stage in\r
+   place with no temporary registers).*/\r
+#define OC_HADAMARD_C_8x4 __asm{ \\r
+  /*Stage C:*/ \\r
+  __asm  paddw mm0,mm1 \\r
+  __asm  paddw mm2,mm3 \\r
+  __asm  paddw mm4,mm5 \\r
+  __asm  paddw mm6,mm7 \\r
+  __asm  paddw mm1,mm1 \\r
+  __asm  paddw mm3,mm3 \\r
+  __asm  paddw mm5,mm5 \\r
+  __asm  paddw mm7,mm7 \\r
+  __asm  psubw mm1,mm0 \\r
+  __asm  psubw mm3,mm2 \\r
+  __asm  psubw mm5,mm4 \\r
+  __asm  psubw mm7,mm6 \\r
+}\r
+\r
+/*Performs an 8-point 1-D Hadamard transform.\r
+  The transform is performed in place, except that outputs 0-3 are swapped with\r
+   outputs 4-7.\r
+  Outputs 1, 2, 5 and 6 are negated (which allows us to perform the transform\r
+   in place with no temporary registers).*/\r
+#define OC_HADAMARD_8x4 __asm{ \\r
+  OC_HADAMARD_AB_8x4 \\r
+  OC_HADAMARD_C_8x4 \\r
+}\r
+\r
+/*Performs the first part of the final stage of the Hadamard transform and\r
+   summing of absolute values.\r
+  At the end of this part, mm1 will contain the DC coefficient of the\r
+   transform.*/\r
+#define OC_HADAMARD_C_ABS_ACCUM_A_8x4(_r6,_r7) __asm{ \\r
+  /*We use the fact that \\r
+      (abs(a+b)+abs(a-b))/2=max(abs(a),abs(b)) \\r
+     to merge the final butterfly with the abs and the first stage of \\r
+     accumulation. \\r
+    Thus we can avoid using pabsw, which is not available until SSSE3. \\r
+    Emulating pabsw takes 3 instructions, so the straightforward MMXEXT \\r
+     implementation would be (3+3)*8+7=55 instructions (+4 for spilling \\r
+     registers). \\r
+    Even with pabsw, it would be (3+1)*8+7=39 instructions (with no spills). \\r
+    This implementation is only 26 (+4 for spilling registers).*/ \\r
+  __asm  movq [_r7+BUF],mm7 \\r
+  __asm  movq [_r6+BUF],mm6 \\r
+  /*mm7={0x7FFF}x4 \\r
+    mm0=max(abs(mm0),abs(mm1))-0x7FFF*/ \\r
+  __asm  pcmpeqb mm7,mm7 \\r
+  __asm  movq mm6,mm0 \\r
+  __asm  psrlw mm7,1 \\r
+  __asm  paddw mm6,mm1 \\r
+  __asm  pmaxsw mm0,mm1 \\r
+  __asm  paddsw mm6,mm7 \\r
+  __asm  psubw mm0,mm6 \\r
+  /*mm2=max(abs(mm2),abs(mm3))-0x7FFF \\r
+    mm4=max(abs(mm4),abs(mm5))-0x7FFF*/ \\r
+  __asm  movq mm6,mm2 \\r
+  __asm  movq mm1,mm4 \\r
+  __asm  pmaxsw mm2,mm3 \\r
+  __asm  pmaxsw mm4,mm5 \\r
+  __asm  paddw mm6,mm3 \\r
+  __asm  paddw mm1,mm5 \\r
+  __asm  movq mm3,[_r7+BUF] \\r
+}\r
+\r
+/*Performs the second part of the final stage of the Hadamard transform and\r
+   summing of absolute values.*/\r
+#define OC_HADAMARD_C_ABS_ACCUM_B_8x4(_r6,_r7) __asm{ \\r
+  __asm  paddsw mm6,mm7 \\r
+  __asm  movq mm5,[_r6+BUF] \\r
+  __asm  paddsw mm1,mm7 \\r
+  __asm  psubw mm2,mm6 \\r
+  __asm  psubw mm4,mm1 \\r
+  /*mm7={1}x4 (needed for the horizontal add that follows) \\r
+    mm0+=mm2+mm4+max(abs(mm3),abs(mm5))-0x7FFF*/ \\r
+  __asm  movq mm6,mm3 \\r
+  __asm  pmaxsw mm3,mm5 \\r
+  __asm  paddw mm0,mm2 \\r
+  __asm  paddw mm6,mm5 \\r
+  __asm  paddw mm0,mm4 \\r
+  __asm  paddsw mm6,mm7 \\r
+  __asm  paddw mm0,mm3 \\r
+  __asm  psrlw mm7,14 \\r
+  __asm  psubw mm0,mm6 \\r
+}\r
+\r
+/*Performs the last stage of an 8-point 1-D Hadamard transform, takes the\r
+   absolute value of each component, and accumulates everything into mm0.\r
+  This is the only portion of SATD which requires MMXEXT (we could use plain\r
+   MMX, but it takes 4 instructions and an extra register to work around the\r
+   lack of a pmaxsw, which is a pretty serious penalty).*/\r
+#define OC_HADAMARD_C_ABS_ACCUM_8x4(_r6,_r7) __asm{ \\r
+  OC_HADAMARD_C_ABS_ACCUM_A_8x4(_r6,_r7) \\r
+  OC_HADAMARD_C_ABS_ACCUM_B_8x4(_r6,_r7) \\r
+}\r
+\r
+/*Performs an 8-point 1-D Hadamard transform, takes the absolute value of each\r
+   component, and accumulates everything into mm0.\r
+  Note that mm0 will have an extra 4 added to each column, and that after\r
+   removing this value, the remainder will be half the conventional value.*/\r
+#define OC_HADAMARD_ABS_ACCUM_8x4(_r6,_r7) __asm{ \\r
+  OC_HADAMARD_AB_8x4 \\r
+  OC_HADAMARD_C_ABS_ACCUM_8x4(_r6,_r7) \\r
+}\r
+\r
+/*Performs two 4x4 transposes (mostly) in place.\r
+  On input, {mm0,mm1,mm2,mm3} contains rows {e,f,g,h}, and {mm4,mm5,mm6,mm7}\r
+   contains rows {a,b,c,d}.\r
+  On output, {0x40,0x50,0x60,0x70}+_off+BUF contains {e,f,g,h}^T, and\r
+   {mm4,mm5,mm6,mm7} contains the transposed rows {a,b,c,d}^T.*/\r
+#define OC_TRANSPOSE_4x4x2(_off) __asm{ \\r
+  /*First 4x4 transpose:*/ \\r
+  __asm  movq [0x10+_off+BUF],mm5 \\r
+  /*mm0 = e3 e2 e1 e0 \\r
+    mm1 = f3 f2 f1 f0 \\r
+    mm2 = g3 g2 g1 g0 \\r
+    mm3 = h3 h2 h1 h0*/ \\r
+  __asm  movq mm5,mm2 \\r
+  __asm  punpcklwd mm2,mm3 \\r
+  __asm  punpckhwd mm5,mm3 \\r
+  __asm  movq mm3,mm0 \\r
+  __asm  punpcklwd mm0,mm1 \\r
+  __asm  punpckhwd mm3,mm1 \\r
+  /*mm0 = f1 e1 f0 e0 \\r
+    mm3 = f3 e3 f2 e2 \\r
+    mm2 = h1 g1 h0 g0 \\r
+    mm5 = h3 g3 h2 g2*/ \\r
+  __asm  movq mm1,mm0 \\r
+  __asm  punpckldq mm0,mm2 \\r
+  __asm  punpckhdq mm1,mm2 \\r
+  __asm  movq mm2,mm3 \\r
+  __asm  punpckhdq mm3,mm5 \\r
+  __asm  movq [0x40+_off+BUF],mm0 \\r
+  __asm  punpckldq mm2,mm5 \\r
+  /*mm0 = h0 g0 f0 e0 \\r
+    mm1 = h1 g1 f1 e1 \\r
+    mm2 = h2 g2 f2 e2 \\r
+    mm3 = h3 g3 f3 e3*/ \\r
+  __asm  movq mm5,[0x10+_off+BUF] \\r
+  /*Second 4x4 transpose:*/ \\r
+  /*mm4 = a3 a2 a1 a0 \\r
+    mm5 = b3 b2 b1 b0 \\r
+    mm6 = c3 c2 c1 c0 \\r
+    mm7 = d3 d2 d1 d0*/ \\r
+  __asm  movq mm0,mm6 \\r
+  __asm  punpcklwd mm6,mm7 \\r
+  __asm  movq [0x50+_off+BUF],mm1 \\r
+  __asm  punpckhwd mm0,mm7 \\r
+  __asm  movq mm7,mm4 \\r
+  __asm  punpcklwd mm4,mm5 \\r
+  __asm  movq [0x60+_off+BUF],mm2 \\r
+  __asm  punpckhwd mm7,mm5 \\r
+  /*mm4 = b1 a1 b0 a0 \\r
+    mm7 = b3 a3 b2 a2 \\r
+    mm6 = d1 c1 d0 c0 \\r
+    mm0 = d3 c3 d2 c2*/ \\r
+  __asm  movq mm5,mm4 \\r
+  __asm  punpckldq mm4,mm6 \\r
+  __asm  movq [0x70+_off+BUF],mm3 \\r
+  __asm  punpckhdq mm5,mm6 \\r
+  __asm  movq mm6,mm7 \\r
+  __asm  punpckhdq mm7,mm0 \\r
+  __asm  punpckldq mm6,mm0 \\r
+  /*mm4 = d0 c0 b0 a0 \\r
+    mm5 = d1 c1 b1 a1 \\r
+    mm6 = d2 c2 b2 a2 \\r
+    mm7 = d3 c3 b3 a3*/ \\r
+}\r
+\r
+static unsigned oc_int_frag_satd_thresh_mmxext(const unsigned char *_src,\r
+ int _src_ystride,const unsigned char *_ref,int _ref_ystride,unsigned _thresh){\r
+  OC_ALIGN8(ogg_int16_t  buf[64]);\r
+  ogg_int16_t           *bufp;\r
+  unsigned               ret1;\r
+  unsigned               ret2;\r
+  bufp=buf;\r
+  __asm{\r
+#define SRC esi\r
+#define REF eax\r
+#define SRC_YSTRIDE ecx\r
+#define REF_YSTRIDE edx\r
+#define BUF edi\r
+#define RET eax\r
+#define RET2 edx\r
+    mov SRC,_src\r
+    mov SRC_YSTRIDE,_src_ystride\r
+    mov REF,_ref\r
+    mov REF_YSTRIDE,_ref_ystride\r
+    mov BUF,bufp\r
+    OC_LOAD_SUB_8x4(0x00)\r
+    OC_HADAMARD_8x4\r
+    OC_TRANSPOSE_4x4x2(0x00)\r
+    /*Finish swapping out this 8x4 block to make room for the next one.\r
+      mm0...mm3 have been swapped out already.*/\r
+    movq [0x00+BUF],mm4\r
+    movq [0x10+BUF],mm5\r
+    movq [0x20+BUF],mm6\r
+    movq [0x30+BUF],mm7\r
+    OC_LOAD_SUB_8x4(0x04)\r
+    OC_HADAMARD_8x4\r
+    OC_TRANSPOSE_4x4x2(0x08)\r
+    /*Here the first 4x4 block of output from the last transpose is the second\r
+       4x4 block of input for the next transform.\r
+      We have cleverly arranged that it already be in the appropriate place, so\r
+       we only have to do half the loads.*/\r
+    movq mm1,[0x10+BUF]\r
+    movq mm2,[0x20+BUF]\r
+    movq mm3,[0x30+BUF]\r
+    movq mm0,[0x00+BUF]\r
+    OC_HADAMARD_ABS_ACCUM_8x4(0x28,0x38)\r
+    /*Up to this point, everything fit in 16 bits (8 input + 1 for the\r
+       difference + 2*3 for the two 8-point 1-D Hadamards - 1 for the abs - 1\r
+       for the factor of two we dropped + 3 for the vertical accumulation).\r
+      Now we finally have to promote things to dwords.\r
+      We break this part out of OC_HADAMARD_ABS_ACCUM_8x4 to hide the long\r
+       latency of pmaddwd by starting the next series of loads now.*/\r
+    mov RET2,_thresh\r
+    pmaddwd mm0,mm7\r
+    movq mm1,[0x50+BUF]\r
+    movq mm5,[0x58+BUF]\r
+    movq mm4,mm0\r
+    movq mm2,[0x60+BUF]\r
+    punpckhdq mm0,mm0\r
+    movq mm6,[0x68+BUF]\r
+    paddd mm4,mm0\r
+    movq mm3,[0x70+BUF]\r
+    movd RET,mm4\r
+    movq mm7,[0x78+BUF]\r
+    /*The sums produced by OC_HADAMARD_ABS_ACCUM_8x4 each have an extra 4\r
+       added to them, and a factor of two removed; correct the final sum here.*/\r
+    lea RET,[RET+RET-32]\r
+    movq mm0,[0x40+BUF]\r
+    cmp RET,RET2\r
+    movq mm4,[0x48+BUF]\r
+    jae at_end\r
+    OC_HADAMARD_ABS_ACCUM_8x4(0x68,0x78)\r
+    pmaddwd mm0,mm7\r
+    /*There isn't much to stick in here to hide the latency this time, but the\r
+       alternative to pmaddwd is movq->punpcklwd->punpckhwd->paddd, whose\r
+       latency is even worse.*/\r
+    sub RET,32\r
+    movq mm4,mm0\r
+    punpckhdq mm0,mm0\r
+    paddd mm4,mm0\r
+    movd RET2,mm4\r
+    lea RET,[RET+RET2*2]\r
+    align 16\r
+at_end:\r
+    mov ret1,RET\r
+#undef SRC\r
+#undef REF\r
+#undef SRC_YSTRIDE\r
+#undef REF_YSTRIDE\r
+#undef BUF\r
+#undef RET\r
+#undef RET2\r
+  }\r
+  return ret1;\r
+}\r
+\r
+unsigned oc_enc_frag_satd_thresh_mmxext(const unsigned char *_src,\r
+ const unsigned char *_ref,int _ystride,unsigned _thresh){\r
+  return oc_int_frag_satd_thresh_mmxext(_src,_ystride,_ref,_ystride,_thresh);\r
+}\r
+\r
+\r
+/*Our internal implementation of frag_copy2 takes an extra stride parameter so\r
+   we can share code with oc_enc_frag_satd2_thresh_mmxext().*/\r
+static void oc_int_frag_copy2_mmxext(unsigned char *_dst,int _dst_ystride,\r
+ const unsigned char *_src1,const unsigned char *_src2,int _src_ystride){\r
+  __asm{\r
+    /*Load the first 3 rows.*/\r
+#define DST_YSTRIDE edi\r
+#define SRC_YSTRIDE esi\r
+#define DST eax\r
+#define SRC1 edx\r
+#define SRC2 ecx\r
+    mov DST_YSTRIDE,_dst_ystride\r
+    mov SRC_YSTRIDE,_src_ystride\r
+    mov DST,_dst\r
+    mov SRC1,_src1\r
+    mov SRC2,_src2\r
+    movq mm0,[SRC1]\r
+    movq mm1,[SRC2]\r
+    movq mm2,[SRC1+SRC_YSTRIDE]\r
+    lea SRC1,[SRC1+SRC_YSTRIDE*2]\r
+    movq mm3,[SRC2+SRC_YSTRIDE]\r
+    lea SRC2,[SRC2+SRC_YSTRIDE*2]\r
+    pxor mm7,mm7\r
+    movq mm4,[SRC1]\r
+    pcmpeqb mm6,mm6\r
+    movq mm5,[SRC2]\r
+    /*mm7={1}x8.*/\r
+    psubb mm7,mm6\r
+    /*Start averaging mm0 and mm1 into mm6.*/\r
+    movq mm6,mm0\r
+    pxor mm0,mm1\r
+    pavgb mm6,mm1\r
+    /*mm1 is free, start averaging mm3 into mm2 using mm1.*/\r
+    movq mm1,mm2\r
+    pand mm0,mm7\r
+    pavgb mm2,mm3\r
+    pxor mm1,mm3\r
+    /*mm3 is free.*/\r
+    psubb mm6,mm0\r
+    /*mm0 is free, start loading the next row.*/\r
+    movq mm0,[SRC1+SRC_YSTRIDE]\r
+    /*Start averaging mm5 and mm4 using mm3.*/\r
+    movq mm3,mm4\r
+    /*mm6 [row 0] is done; write it out.*/\r
+    movq [DST],mm6\r
+    pand mm1,mm7\r
+    pavgb mm4,mm5\r
+    psubb mm2,mm1\r
+    /*mm1 is free, continue loading the next row.*/\r
+    movq mm1,[SRC2+SRC_YSTRIDE]\r
+    pxor mm3,mm5\r
+    lea SRC1,[SRC1+SRC_YSTRIDE*2]\r
+    /*mm2 [row 1] is done; write it out.*/\r
+    movq [DST+DST_YSTRIDE],mm2\r
+    pand mm3,mm7\r
+    /*Start loading the next row.*/\r
+    movq mm2,[SRC1]\r
+    lea DST,[DST+DST_YSTRIDE*2]\r
+    psubb mm4,mm3\r
+    lea SRC2,[SRC2+SRC_YSTRIDE*2]\r
+    /*mm4 [row 2] is done; write it out.*/\r
+    movq [DST],mm4\r
+    /*Continue loading the next row.*/\r
+    movq mm3,[SRC2]\r
+    /*Start averaging mm0 and mm1 into mm6.*/\r
+    movq mm6,mm0\r
+    pxor mm0,mm1\r
+    /*Start loading the next row.*/\r
+    movq mm4,[SRC1+SRC_YSTRIDE]\r
+    pavgb mm6,mm1\r
+    /*mm1 is free; start averaging mm3 into mm2 using mm1.*/\r
+    movq mm1,mm2\r
+    pand mm0,mm7\r
+    /*Continue loading the next row.*/\r
+    movq mm5,[SRC2+SRC_YSTRIDE]\r
+    pavgb mm2,mm3\r
+    lea SRC1,[SRC1+SRC_YSTRIDE*2]\r
+    pxor mm1,mm3\r
+    /*mm3 is free.*/\r
+    psubb mm6,mm0\r
+    /*mm0 is free, start loading the next row.*/\r
+    movq mm0,[SRC1]\r
+    /*Start averaging mm5 into mm4 using mm3.*/\r
+    movq mm3,mm4\r
+    /*mm6 [row 3] is done; write it out.*/\r
+    movq [DST+DST_YSTRIDE],mm6\r
+    pand mm1,mm7\r
+    lea SRC2,[SRC2+SRC_YSTRIDE*2]\r
+    pavgb mm4,mm5\r
+    lea DST,[DST+DST_YSTRIDE*2]\r
+    psubb mm2,mm1\r
+    /*mm1 is free; continue loading the next row.*/\r
+    movq mm1,[SRC2]\r
+    pxor mm3,mm5\r
+    /*mm2 [row 4] is done; write it out.*/\r
+    movq [DST],mm2\r
+    pand mm3,mm7\r
+    /*Start loading the next row.*/\r
+    movq mm2,[SRC1+SRC_YSTRIDE]\r
+    psubb mm4,mm3\r
+    /*Start averaging mm0 and mm1 into mm6.*/\r
+    movq mm6,mm0\r
+    /*Continue loading the next row.*/\r
+    movq mm3,[SRC2+SRC_YSTRIDE]\r
+    /*mm4 [row 5] is done; write it out.*/\r
+    movq [DST+DST_YSTRIDE],mm4\r
+    pxor mm0,mm1\r
+    pavgb mm6,mm1\r
+    /*mm4 is free; start averaging mm3 into mm2 using mm4.*/\r
+    movq mm4,mm2\r
+    pand mm0,mm7\r
+    pavgb mm2,mm3\r
+    pxor mm4,mm3\r
+    lea DST,[DST+DST_YSTRIDE*2]\r
+    psubb mm6,mm0\r
+    pand mm4,mm7\r
+    /*mm6 [row 6] is done, write it out.*/\r
+    movq [DST],mm6\r
+    psubb mm2,mm4\r
+    /*mm2 [row 7] is done, write it out.*/\r
+    movq [DST+DST_YSTRIDE],mm2\r
+#undef SRC1\r
+#undef SRC2\r
+#undef SRC_YSTRIDE\r
+#undef DST_YSTRIDE\r
+#undef DST\r
+  }\r
+}\r
+\r
+unsigned oc_enc_frag_satd2_thresh_mmxext(const unsigned char *_src,\r
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,\r
+ unsigned _thresh){\r
+  OC_ALIGN8(unsigned char ref[64]);\r
+  oc_int_frag_copy2_mmxext(ref,8,_ref1,_ref2,_ystride);\r
+  return oc_int_frag_satd_thresh_mmxext(_src,_ystride,ref,8,_thresh);\r
+}\r
+\r
+unsigned oc_enc_frag_intra_satd_mmxext(const unsigned char *_src,\r
+ int _ystride){\r
+  OC_ALIGN8(ogg_int16_t  buf[64]);\r
+  ogg_int16_t           *bufp;\r
+  unsigned               ret1;\r
+  unsigned               ret2;\r
+  bufp=buf;\r
+  __asm{\r
+#define SRC eax\r
+#define SRC4 esi\r
+#define BUF edi\r
+#define RET eax\r
+#define RET_WORD ax\r
+#define RET2 ecx\r
+#define YSTRIDE edx\r
+#define YSTRIDE3 ecx\r
+    mov SRC,_src\r
+    mov BUF,bufp\r
+    mov YSTRIDE,_ystride\r
+    /* src4 = src+4*ystride */\r
+    lea SRC4,[SRC+YSTRIDE*4]\r
+    /* ystride3 = 3*ystride */\r
+    lea YSTRIDE3,[YSTRIDE+YSTRIDE*2]\r
+    OC_LOAD_8x4(0x00)\r
+    OC_HADAMARD_8x4\r
+    OC_TRANSPOSE_4x4x2(0x00)\r
+    /*Finish swapping out this 8x4 block to make room for the next one.\r
+      mm0...mm3 have been swapped out already.*/\r
+    movq [0x00+BUF],mm4\r
+    movq [0x10+BUF],mm5\r
+    movq [0x20+BUF],mm6\r
+    movq [0x30+BUF],mm7\r
+    OC_LOAD_8x4(0x04)\r
+    OC_HADAMARD_8x4\r
+    OC_TRANSPOSE_4x4x2(0x08)\r
+    /*Here the first 4x4 block of output from the last transpose is the second\r
+      4x4 block of input for the next transform.\r
+      We have cleverly arranged that it already be in the appropriate place, so\r
+      we only have to do half the loads.*/\r
+    movq mm1,[0x10+BUF]\r
+    movq mm2,[0x20+BUF]\r
+    movq mm3,[0x30+BUF]\r
+    movq mm0,[0x00+BUF]\r
+    /*We split out the stages here so we can save the DC coefficient in the\r
+      middle.*/\r
+    OC_HADAMARD_AB_8x4\r
+    OC_HADAMARD_C_ABS_ACCUM_A_8x4(0x28,0x38)\r
+    movd RET,mm1\r
+    OC_HADAMARD_C_ABS_ACCUM_B_8x4(0x28,0x38)\r
+    /*Up to this point, everything fit in 16 bits (8 input + 1 for the\r
+      difference + 2*3 for the two 8-point 1-D Hadamards - 1 for the abs - 1\r
+      for the factor of two we dropped + 3 for the vertical accumulation).\r
+      Now we finally have to promote things to dwords.\r
+      We break this part out of OC_HADAMARD_ABS_ACCUM_8x4 to hide the long\r
+      latency of pmaddwd by starting the next series of loads now.*/\r
+    pmaddwd mm0,mm7\r
+    movq mm1,[0x50+BUF]\r
+    movq mm5,[0x58+BUF]\r
+    movq mm2,[0x60+BUF]\r
+    movq mm4,mm0\r
+    movq mm6,[0x68+BUF]\r
+    punpckhdq mm0,mm0\r
+    movq mm3,[0x70+BUF]\r
+    paddd mm4,mm0\r
+    movq mm7,[0x78+BUF]\r
+    movd RET2,mm4\r
+    movq mm0,[0x40+BUF]\r
+    movq mm4,[0x48+BUF]\r
+    OC_HADAMARD_ABS_ACCUM_8x4(0x68,0x78)\r
+    pmaddwd mm0,mm7\r
+    /*We assume that the DC coefficient is always positive (which is true,\r
+    because the input to the INTRA transform was not a difference).*/\r
+    movzx RET,RET_WORD\r
+    add RET2,RET2\r
+    sub RET2,RET\r
+    movq mm4,mm0\r
+    punpckhdq mm0,mm0\r
+    paddd mm4,mm0\r
+    movd RET,mm4\r
+    lea RET,[-64+RET2+RET*2]\r
+    mov [ret1],RET\r
+#undef SRC\r
+#undef SRC4\r
+#undef BUF\r
+#undef RET\r
+#undef RET_WORD\r
+#undef RET2\r
+#undef YSTRIDE\r
+#undef YSTRIDE3\r
+  }\r
+  return ret1;\r
+}\r
+\r
+void oc_enc_frag_sub_mmx(ogg_int16_t _residue[64],\r
+ const unsigned char *_src, const unsigned char *_ref,int _ystride){\r
+  int i;\r
+  __asm  pxor mm7,mm7\r
+  for(i=4;i-->0;){\r
+    __asm{\r
+#define SRC edx\r
+#define YSTRIDE esi\r
+#define RESIDUE eax\r
+#define REF ecx\r
+      mov YSTRIDE,_ystride\r
+      mov RESIDUE,_residue\r
+      mov SRC,_src\r
+      mov REF,_ref\r
+      /*mm0=[src]*/\r
+      movq mm0,[SRC]\r
+      /*mm1=[ref]*/\r
+      movq mm1,[REF]\r
+      /*mm4=[src+ystride]*/\r
+      movq mm4,[SRC+YSTRIDE]\r
+      /*mm5=[ref+ystride]*/\r
+      movq mm5,[REF+YSTRIDE]\r
+      /*Compute [src]-[ref].*/\r
+      movq mm2,mm0\r
+      punpcklbw mm0,mm7\r
+      movq mm3,mm1\r
+      punpckhbw mm2,mm7\r
+      punpcklbw mm1,mm7\r
+      punpckhbw mm3,mm7\r
+      psubw mm0,mm1\r
+      psubw mm2,mm3\r
+      /*Compute [src+ystride]-[ref+ystride].*/\r
+      movq mm1,mm4\r
+      punpcklbw mm4,mm7\r
+      movq mm3,mm5\r
+      punpckhbw mm1,mm7\r
+      lea SRC,[SRC+YSTRIDE*2]\r
+      punpcklbw mm5,mm7\r
+      lea REF,[REF+YSTRIDE*2]\r
+      punpckhbw mm3,mm7\r
+      psubw mm4,mm5\r
+      psubw mm1,mm3\r
+      /*Write the answer out.*/\r
+      movq [RESIDUE+0x00],mm0\r
+      movq [RESIDUE+0x08],mm2\r
+      movq [RESIDUE+0x10],mm4\r
+      movq [RESIDUE+0x18],mm1\r
+      lea RESIDUE,[RESIDUE+0x20]\r
+      mov _residue,RESIDUE\r
+      mov _src,SRC\r
+      mov _ref,REF\r
+#undef SRC\r
+#undef YSTRIDE\r
+#undef RESIDUE\r
+#undef REF\r
+    }\r
+  }\r
+}\r
+\r
+void oc_enc_frag_sub_128_mmx(ogg_int16_t _residue[64],\r
+ const unsigned char *_src,int _ystride){\r
+   __asm{\r
+#define YSTRIDE edx\r
+#define YSTRIDE3 edi\r
+#define RESIDUE ecx\r
+#define SRC eax\r
+    mov YSTRIDE,_ystride\r
+    mov RESIDUE,_residue\r
+    mov SRC,_src\r
+    /*mm0=[src]*/\r
+    movq mm0,[SRC]\r
+    /*mm1=[src+ystride]*/\r
+    movq mm1,[SRC+YSTRIDE]\r
+    /*mm6={-1}x4*/\r
+    pcmpeqw mm6,mm6\r
+    /*mm2=[src+2*ystride]*/\r
+    movq mm2,[SRC+YSTRIDE*2]\r
+    /*[ystride3]=3*[ystride]*/\r
+    lea YSTRIDE3,[YSTRIDE+YSTRIDE*2]\r
+    /*mm6={1}x4*/\r
+    psllw mm6,15\r
+    /*mm3=[src+3*ystride]*/\r
+    movq mm3,[SRC+YSTRIDE3]\r
+    /*mm6={128}x4*/\r
+    psrlw mm6,8\r
+    /*mm7=0*/ \r
+    pxor mm7,mm7\r
+    /*[src]=[src]+4*[ystride]*/\r
+    lea SRC,[SRC+YSTRIDE*4]\r
+    /*Compute [src]-128 and [src+ystride]-128*/\r
+    movq mm4,mm0\r
+    punpcklbw mm0,mm7\r
+    movq mm5,mm1\r
+    punpckhbw mm4,mm7\r
+    psubw mm0,mm6\r
+    punpcklbw mm1,mm7\r
+    psubw mm4,mm6\r
+    punpckhbw mm5,mm7\r
+    psubw mm1,mm6\r
+    psubw mm5,mm6\r
+    /*Write the answer out.*/\r
+    movq [RESIDUE+0x00],mm0\r
+    movq [RESIDUE+0x08],mm4\r
+    movq [RESIDUE+0x10],mm1\r
+    movq [RESIDUE+0x18],mm5\r
+    /*mm0=[src+4*ystride]*/\r
+    movq mm0,[SRC]\r
+    /*mm1=[src+5*ystride]*/\r
+    movq mm1,[SRC+YSTRIDE]\r
+    /*Compute [src+2*ystride]-128 and [src+3*ystride]-128*/\r
+    movq mm4,mm2\r
+    punpcklbw mm2,mm7\r
+    movq mm5,mm3\r
+    punpckhbw mm4,mm7\r
+    psubw mm2,mm6\r
+    punpcklbw mm3,mm7\r
+    psubw mm4,mm6\r
+    punpckhbw mm5,mm7\r
+    psubw mm3,mm6\r
+    psubw mm5,mm6\r
+    /*Write the answer out.*/\r
+    movq [RESIDUE+0x20],mm2\r
+    movq [RESIDUE+0x28],mm4\r
+    movq [RESIDUE+0x30],mm3\r
+    movq [RESIDUE+0x38],mm5\r
+    /*Compute [src+6*ystride]-128 and [src+7*ystride]-128*/\r
+    movq mm2,[SRC+YSTRIDE*2]\r
+    movq mm3,[SRC+YSTRIDE3]\r
+    movq mm4,mm0\r
+    punpcklbw mm0,mm7\r
+    movq mm5,mm1\r
+    punpckhbw mm4,mm7\r
+    psubw mm0,mm6\r
+    punpcklbw mm1,mm7\r
+    psubw mm4,mm6\r
+    punpckhbw mm5,mm7\r
+    psubw mm1,mm6\r
+    psubw mm5,mm6\r
+    /*Write the answer out.*/\r
+    movq [RESIDUE+0x40],mm0\r
+    movq [RESIDUE+0x48],mm4\r
+    movq [RESIDUE+0x50],mm1\r
+    movq [RESIDUE+0x58],mm5\r
+    /*Compute [src+6*ystride]-128 and [src+7*ystride]-128*/\r
+    movq mm4,mm2\r
+    punpcklbw mm2,mm7\r
+    movq mm5,mm3\r
+    punpckhbw mm4,mm7\r
+    psubw mm2,mm6\r
+    punpcklbw mm3,mm7\r
+    psubw mm4,mm6\r
+    punpckhbw mm5,mm7\r
+    psubw mm3,mm6\r
+    psubw mm5,mm6\r
+    /*Write the answer out.*/\r
+    movq [RESIDUE+0x60],mm2\r
+    movq [RESIDUE+0x68],mm4\r
+    movq [RESIDUE+0x70],mm3\r
+    movq [RESIDUE+0x78],mm5\r
+#undef YSTRIDE\r
+#undef YSTRIDE3\r
+#undef RESIDUE\r
+#undef SRC\r
+  }\r
+}\r
+\r
+void oc_enc_frag_copy2_mmxext(unsigned char *_dst,\r
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride){\r
+  oc_int_frag_copy2_mmxext(_dst,_ystride,_src1,_src2,_ystride);\r
+}\r
+\r
+#endif\r
diff --git a/lib/x86_vc/mmxfdct.c b/lib/x86_vc/mmxfdct.c
new file mode 100644 (file)
index 0000000..dcf17c9
--- /dev/null
@@ -0,0 +1,670 @@
+/********************************************************************\r
+ *                                                                  *\r
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *\r
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *\r
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *\r
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *\r
+ *                                                                  *\r
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 1999-2006                *\r
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *\r
+ *                                                                  *\r
+ ********************************************************************/ \r
+ /*MMX fDCT implementation for x86_32*/\r
+/*$Id: fdct_ses2.c 14579 2008-03-12 06:42:40Z xiphmont $*/\r
+#include "x86enc.h"\r
+\r
+#if defined(OC_X86_ASM)\r
+\r
+#define OC_FDCT_STAGE1_8x4  __asm{ \\r
+  /*Stage 1:*/ \\r
+  /*mm0=t7'=t0-t7*/ \\r
+  __asm  psubw mm0,mm7 \\r
+  __asm  paddw mm7,mm7 \\r
+  /*mm1=t6'=t1-t6*/ \\r
+  __asm  psubw mm1, mm6 \\r
+  __asm  paddw mm6,mm6 \\r
+  /*mm2=t5'=t2-t5*/ \\r
+  __asm  psubw mm2,mm5 \\r
+  __asm  paddw mm5,mm5 \\r
+  /*mm3=t4'=t3-t4*/ \\r
+  __asm  psubw mm3,mm4 \\r
+  __asm  paddw mm4,mm4 \\r
+  /*mm7=t0'=t0+t7*/ \\r
+  __asm  paddw mm7,mm0 \\r
+  /*mm6=t1'=t1+t6*/  \\r
+  __asm  paddw mm6,mm1 \\r
+  /*mm5=t2'=t2+t5*/ \\r
+  __asm  paddw mm5,mm2 \\r
+  /*mm4=t3'=t3+t4*/ \\r
+  __asm  paddw mm4,mm3\\r
+}\r
+\r
+#define OC_FDCT8x4(_r0,_r1,_r2,_r3,_r4,_r5,_r6,_r7) __asm{ \\r
+  /*Stage 2:*/ \\r
+  /*mm7=t3''=t0'-t3'*/ \\r
+  __asm  psubw mm7,mm4 \\r
+  __asm  paddw mm4,mm4 \\r
+  /*mm6=t2''=t1'-t2'*/ \\r
+  __asm  psubw mm6,mm5 \\r
+  __asm  movq [Y+_r6],mm7 \\r
+  __asm  paddw mm5,mm5 \\r
+  /*mm1=t5''=t6'-t5'*/ \\r
+  __asm  psubw mm1,mm2 \\r
+  __asm  movq [Y+_r2],mm6 \\r
+  /*mm4=t0''=t0'+t3'*/ \\r
+  __asm  paddw mm4,mm7 \\r
+  __asm  paddw mm2,mm2 \\r
+  /*mm5=t1''=t1'+t2'*/ \\r
+  __asm  movq [Y+_r0],mm4 \\r
+  __asm  paddw mm5,mm6 \\r
+  /*mm2=t6''=t6'+t5'*/ \\r
+  __asm  paddw mm2,mm1 \\r
+  __asm  movq [Y+_r4],mm5 \\r
+  /*mm0=t7', mm1=t5'', mm2=t6'', mm3=t4'.*/ \\r
+  /*mm4, mm5, mm6, mm7 are free.*/ \\r
+  /*Stage 3:*/ \\r
+  /*mm6={2}x4, mm7={27146,0xB500>>1}x2*/ \\r
+  __asm  mov A,0x5A806A0A \\r
+  __asm  pcmpeqb mm6,mm6 \\r
+  __asm  movd mm7,A \\r
+  __asm  psrlw mm6,15 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  paddw mm6,mm6 \\r
+  /*mm0=0, m2={-1}x4 \\r
+    mm5:mm4=t5''*27146+0xB500*/ \\r
+  __asm  movq mm4,mm1 \\r
+  __asm  movq mm5,mm1 \\r
+  __asm  punpcklwd mm4,mm6 \\r
+  __asm  movq [Y+_r3],mm2 \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  movq [Y+_r7],mm0 \\r
+  __asm  punpckhwd mm5,mm6 \\r
+  __asm  pxor mm0,mm0 \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  pcmpeqb mm2,mm2 \\r
+  /*mm2=t6'', mm1=t5''+(t5''!=0) \\r
+    mm4=(t5''*27146+0xB500>>16)*/ \\r
+  __asm  pcmpeqw mm0,mm1 \\r
+  __asm  psrad mm4,16 \\r
+  __asm  psubw mm0,mm2 \\r
+  __asm  movq mm2, [Y+_r3] \\r
+  __asm  psrad mm5,16 \\r
+  __asm  paddw mm1,mm0 \\r
+  __asm  packssdw mm4,mm5 \\r
+  /*mm4=s=(t5''*27146+0xB500>>16)+t5''+(t5''!=0)>>1*/ \\r
+  __asm  paddw mm4,mm1 \\r
+  __asm  movq mm0, [Y+_r7] \\r
+  __asm  psraw mm4,1 \\r
+  __asm  movq mm1,mm3 \\r
+  /*mm3=t4''=t4'+s*/ \\r
+  __asm  paddw mm3,mm4 \\r
+  /*mm1=t5'''=t4'-s*/ \\r
+  __asm  psubw mm1,mm4 \\r
+  /*mm1=0, mm3={-1}x4 \\r
+    mm5:mm4=t6''*27146+0xB500*/ \\r
+  __asm  movq mm4,mm2 \\r
+  __asm  movq mm5,mm2 \\r
+  __asm  punpcklwd mm4,mm6 \\r
+  __asm  movq [Y+_r5],mm1 \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  movq [Y+_r1],mm3 \\r
+  __asm  punpckhwd mm5,mm6 \\r
+  __asm  pxor mm1,mm1 \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  pcmpeqb mm3,mm3 \\r
+  /*mm2=t6''+(t6''!=0), mm4=(t6''*27146+0xB500>>16)*/ \\r
+  __asm  psrad mm4,16 \\r
+  __asm  pcmpeqw mm1,mm2 \\r
+  __asm  psrad mm5,16 \\r
+  __asm  psubw mm1,mm3 \\r
+  __asm  packssdw mm4,mm5 \\r
+  __asm  paddw mm2,mm1 \\r
+  /*mm1=t1'' \\r
+    mm4=s=(t6''*27146+0xB500>>16)+t6''+(t6''!=0)>>1*/ \\r
+  __asm  paddw mm4,mm2 \\r
+  __asm  movq mm1,[Y+_r4] \\r
+  __asm  psraw mm4,1 \\r
+  __asm  movq mm2,mm0 \\r
+  /*mm7={54491-0x7FFF,0x7FFF}x2 \\r
+    mm0=t7''=t7'+s*/ \\r
+  __asm  paddw mm0,mm4 \\r
+  /*mm2=t6'''=t7'-s*/ \\r
+  __asm  psubw mm2,mm4 \\r
+  /*Stage 4:*/ \\r
+  /*mm0=0, mm2=t0'' \\r
+    mm5:mm4=t1''*27146+0xB500*/ \\r
+  __asm  movq mm4,mm1 \\r
+  __asm  movq mm5,mm1 \\r
+  __asm  punpcklwd mm4,mm6 \\r
+  __asm  movq [Y+_r3],mm2 \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  movq mm2,[Y+_r0] \\r
+  __asm  punpckhwd mm5,mm6 \\r
+  __asm  movq [Y+_r7],mm0 \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  pxor mm0,mm0 \\r
+  /*mm7={27146,0x4000>>1}x2 \\r
+    mm0=s=(t1''*27146+0xB500>>16)+t1''+(t1''!=0)*/ \\r
+  __asm  psrad mm4,16 \\r
+  __asm  mov A,0x20006A0A \\r
+  __asm  pcmpeqw mm0,mm1 \\r
+  __asm  movd mm7,A \\r
+  __asm  psrad mm5,16 \\r
+  __asm  psubw mm0,mm3 \\r
+  __asm  packssdw mm4,mm5 \\r
+  __asm  paddw mm0,mm1 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  paddw mm0,mm4 \\r
+  /*mm6={0x00000E3D}x2 \\r
+    mm1=-(t0''==0), mm5:mm4=t0''*27146+0x4000*/ \\r
+  __asm  movq mm4,mm2 \\r
+  __asm  movq mm5,mm2 \\r
+  __asm  punpcklwd mm4,mm6 \\r
+  __asm  mov A,0x0E3D \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  punpckhwd mm5,mm6 \\r
+  __asm  movd mm6,A \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  pxor mm1,mm1 \\r
+  __asm  punpckldq mm6,mm6 \\r
+  __asm  pcmpeqw mm1,mm2 \\r
+  /*mm4=r=(t0''*27146+0x4000>>16)+t0''+(t0''!=0)*/ \\r
+  __asm  psrad mm4,16 \\r
+  __asm  psubw mm1,mm3 \\r
+  __asm  psrad mm5,16 \\r
+  __asm  paddw mm2,mm1 \\r
+  __asm  packssdw mm4,mm5 \\r
+  __asm  movq mm1,[Y+_r5] \\r
+  __asm  paddw mm4,mm2 \\r
+  /*mm2=t6'', mm0=_y[0]=u=r+s>>1 \\r
+    The naive implementation could cause overflow, so we use \\r
+     u=(r&s)+((r^s)>>1).*/ \\r
+  __asm  movq mm2,[Y+_r3] \\r
+  __asm  movq mm7,mm0 \\r
+  __asm  pxor mm0,mm4 \\r
+  __asm  pand mm7,mm4 \\r
+  __asm  psraw mm0,1 \\r
+  __asm  mov A,0x7FFF54DC \\r
+  __asm  paddw mm0,mm7 \\r
+  __asm  movd mm7,A \\r
+  /*mm7={54491-0x7FFF,0x7FFF}x2 \\r
+    mm4=_y[4]=v=r-u*/ \\r
+  __asm  psubw mm4,mm0 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  movq [Y+_r4],mm4 \\r
+  /*mm0=0, mm7={36410}x4 \\r
+    mm1=(t5'''!=0), mm5:mm4=54491*t5'''+0x0E3D*/ \\r
+  __asm  movq mm4,mm1 \\r
+  __asm  movq mm5,mm1 \\r
+  __asm  punpcklwd mm4,mm1 \\r
+  __asm  mov A,0x8E3A8E3A \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  movq [Y+_r0],mm0 \\r
+  __asm  punpckhwd mm5,mm1 \\r
+  __asm  pxor mm0,mm0 \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  pcmpeqw mm1,mm0 \\r
+  __asm  movd mm7,A \\r
+  __asm  psubw mm1,mm3 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  paddd mm4,mm6 \\r
+  __asm  paddd mm5,mm6 \\r
+  /*mm0=0 \\r
+    mm3:mm1=36410*t6'''+((t5'''!=0)<<16)*/ \\r
+  __asm  movq mm6,mm2 \\r
+  __asm  movq mm3,mm2 \\r
+  __asm  pmulhw mm6,mm7 \\r
+  __asm  paddw mm1,mm2 \\r
+  __asm  pmullw mm3,mm7 \\r
+  __asm  pxor mm0,mm0 \\r
+  __asm  paddw mm6,mm1 \\r
+  __asm  movq mm1,mm3 \\r
+  __asm  punpckhwd mm3,mm6 \\r
+  __asm  punpcklwd mm1,mm6 \\r
+  /*mm3={-1}x4, mm6={1}x4 \\r
+    mm4=_y[5]=u=(54491*t5'''+36410*t6'''+0x0E3D>>16)+(t5'''!=0)*/ \\r
+  __asm  paddd mm5,mm3 \\r
+  __asm  paddd mm4,mm1 \\r
+  __asm  psrad mm5,16 \\r
+  __asm  pxor mm6,mm6 \\r
+  __asm  psrad mm4,16 \\r
+  __asm  pcmpeqb mm3,mm3 \\r
+  __asm  packssdw mm4,mm5 \\r
+  __asm  psubw mm6,mm3 \\r
+  /*mm1=t7'', mm7={26568,0x3400}x2 \\r
+    mm2=s=t6'''-(36410*u>>16)*/ \\r
+  __asm  movq mm1,mm4 \\r
+  __asm  mov A,0x340067C8 \\r
+  __asm  pmulhw mm4,mm7 \\r
+  __asm  movd mm7,A \\r
+  __asm  movq [Y+_r5],mm1 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  paddw mm4,mm1 \\r
+  __asm  movq mm1,[Y+_r7] \\r
+  __asm  psubw mm2,mm4 \\r
+  /*mm6={0x00007B1B}x2 \\r
+    mm0=(s!=0), mm5:mm4=s*26568+0x3400*/ \\r
+  __asm  movq mm4,mm2 \\r
+  __asm  movq mm5,mm2 \\r
+  __asm  punpcklwd mm4,mm6 \\r
+  __asm  pcmpeqw mm0,mm2 \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  mov A,0x7B1B \\r
+  __asm  punpckhwd mm5,mm6 \\r
+  __asm  movd mm6,A \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  psubw mm0,mm3 \\r
+  __asm  punpckldq mm6,mm6 \\r
+  /*mm7={64277-0x7FFF,0x7FFF}x2 \\r
+    mm2=_y[3]=v=(s*26568+0x3400>>17)+s+(s!=0)*/ \\r
+  __asm  psrad mm4,17 \\r
+  __asm  paddw mm2,mm0 \\r
+  __asm  psrad mm5,17 \\r
+  __asm  mov A,0x7FFF7B16 \\r
+  __asm  packssdw mm4,mm5 \\r
+  __asm  movd mm7,A \\r
+  __asm  paddw mm2,mm4 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  /*mm0=0, mm7={12785}x4 \\r
+    mm1=(t7''!=0), mm2=t4'', mm5:mm4=64277*t7''+0x7B1B*/ \\r
+  __asm  movq mm4,mm1 \\r
+  __asm  movq mm5,mm1 \\r
+  __asm  movq [Y+_r3],mm2 \\r
+  __asm  punpcklwd mm4,mm1 \\r
+  __asm  movq mm2,[Y+_r1] \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  mov A,0x31F131F1 \\r
+  __asm  punpckhwd mm5,mm1 \\r
+  __asm  pxor mm0,mm0 \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  pcmpeqw mm1,mm0 \\r
+  __asm  movd mm7,A \\r
+  __asm  psubw mm1,mm3 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  paddd mm4,mm6 \\r
+  __asm  paddd mm5,mm6 \\r
+  /*mm3:mm1=12785*t4'''+((t7''!=0)<<16)*/ \\r
+  __asm  movq mm6,mm2 \\r
+  __asm  movq mm3,mm2 \\r
+  __asm  pmulhw mm6,mm7 \\r
+  __asm  pmullw mm3,mm7 \\r
+  __asm  paddw mm6,mm1 \\r
+  __asm  movq mm1,mm3 \\r
+  __asm  punpckhwd mm3,mm6 \\r
+  __asm  punpcklwd mm1,mm6 \\r
+  /*mm3={-1}x4, mm6={1}x4 \\r
+    mm4=_y[1]=u=(12785*t4'''+64277*t7''+0x7B1B>>16)+(t7''!=0)*/ \\r
+  __asm  paddd mm5,mm3 \\r
+  __asm  paddd mm4,mm1 \\r
+  __asm  psrad mm5,16 \\r
+  __asm  pxor mm6,mm6 \\r
+  __asm  psrad mm4,16 \\r
+  __asm  pcmpeqb mm3,mm3 \\r
+  __asm  packssdw mm4,mm5 \\r
+  __asm  psubw mm6,mm3 \\r
+  /*mm1=t3'', mm7={20539,0x3000}x2 \\r
+    mm4=s=(12785*u>>16)-t4''*/ \\r
+  __asm  movq [Y+_r1],mm4 \\r
+  __asm  pmulhw mm4,mm7 \\r
+  __asm  mov A,0x3000503B \\r
+  __asm  movq mm1,[Y+_r6] \\r
+  __asm  movd mm7,A \\r
+  __asm  psubw mm4,mm2 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  /*mm6={0x00006CB7}x2 \\r
+    mm0=(s!=0), mm5:mm4=s*20539+0x3000*/ \\r
+  __asm  movq mm5,mm4 \\r
+  __asm  movq mm2,mm4 \\r
+  __asm  punpcklwd mm4,mm6 \\r
+  __asm  pcmpeqw mm0,mm2 \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  mov A,0x6CB7 \\r
+  __asm  punpckhwd mm5,mm6 \\r
+  __asm  movd mm6,A \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  psubw mm0,mm3 \\r
+  __asm  punpckldq mm6,mm6 \\r
+  /*mm7={60547-0x7FFF,0x7FFF}x2 \\r
+    mm2=_y[7]=v=(s*20539+0x3000>>20)+s+(s!=0)*/ \\r
+  __asm  psrad mm4,20 \\r
+  __asm  paddw mm2,mm0 \\r
+  __asm  psrad mm5,20 \\r
+  __asm  mov A,0x7FFF6C84 \\r
+  __asm  packssdw mm4,mm5 \\r
+  __asm  movd mm7,A \\r
+  __asm  paddw mm2,mm4 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  /*mm0=0, mm7={25080}x4 \\r
+    mm2=t2'', mm5:mm4=60547*t3''+0x6CB7*/ \\r
+  __asm  movq mm4,mm1 \\r
+  __asm  movq mm5,mm1 \\r
+  __asm  movq [Y+_r7],mm2 \\r
+  __asm  punpcklwd mm4,mm1 \\r
+  __asm  movq mm2,[Y+_r2] \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  mov A,0x61F861F8 \\r
+  __asm  punpckhwd mm5,mm1 \\r
+  __asm  pxor mm0,mm0 \\r
+  __asm  pmaddwd mm5,mm7 \\r
+  __asm  movd mm7,A \\r
+  __asm  pcmpeqw mm1,mm0 \\r
+  __asm  psubw mm1,mm3 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  paddd mm4,mm6 \\r
+  __asm  paddd mm5,mm6 \\r
+  /*mm3:mm1=25080*t2''+((t3''!=0)<<16)*/ \\r
+  __asm  movq mm6,mm2 \\r
+  __asm  movq mm3,mm2 \\r
+  __asm  pmulhw mm6,mm7 \\r
+  __asm  pmullw mm3,mm7 \\r
+  __asm  paddw mm6,mm1 \\r
+  __asm  movq mm1,mm3 \\r
+  __asm  punpckhwd mm3,mm6 \\r
+  __asm  punpcklwd mm1,mm6 \\r
+  /*mm1={-1}x4 \\r
+    mm4=u=(25080*t2''+60547*t3''+0x6CB7>>16)+(t3''!=0)*/ \\r
+  __asm  paddd mm5,mm3 \\r
+  __asm  paddd mm4,mm1 \\r
+  __asm  psrad mm5,16 \\r
+  __asm  mov A,0x28005460 \\r
+  __asm  psrad mm4,16 \\r
+  __asm  pcmpeqb mm1,mm1 \\r
+  __asm  packssdw mm4,mm5 \\r
+  /*mm5={1}x4, mm6=_y[2]=u, mm7={21600,0x2800}x2 \\r
+    mm4=s=(25080*u>>16)-t2''*/ \\r
+  __asm  movq mm6,mm4 \\r
+  __asm  pmulhw mm4,mm7 \\r
+  __asm  pxor mm5,mm5 \\r
+  __asm  movd mm7,A \\r
+  __asm  psubw mm5,mm1 \\r
+  __asm  punpckldq mm7,mm7 \\r
+  __asm  psubw mm4,mm2 \\r
+  /*mm2=s+(s!=0) \\r
+    mm4:mm3=s*21600+0x2800*/ \\r
+  __asm  movq mm3,mm4 \\r
+  __asm  movq mm2,mm4 \\r
+  __asm  punpckhwd mm4,mm5 \\r
+  __asm  pcmpeqw mm0,mm2 \\r
+  __asm  pmaddwd mm4,mm7 \\r
+  __asm  psubw mm0,mm1 \\r
+  __asm  punpcklwd mm3,mm5 \\r
+  __asm  paddw mm2,mm0 \\r
+  __asm  pmaddwd mm3,mm7 \\r
+  /*mm0=_y[4], mm1=_y[7], mm4=_y[0], mm5=_y[5] \\r
+    mm3=_y[6]=v=(s*21600+0x2800>>18)+s+(s!=0)*/ \\r
+  __asm  movq mm0,[Y+_r4] \\r
+  __asm  psrad mm4,18 \\r
+  __asm  movq mm5,[Y+_r5] \\r
+  __asm  psrad mm3,18 \\r
+  __asm  movq mm1,[Y+_r7] \\r
+  __asm  packssdw mm3,mm4 \\r
+  __asm  movq mm4,[Y+_r0] \\r
+  __asm  paddw mm3,mm2 \\r
+}\r
+\r
+/*On input, mm4=_y[0], mm6=_y[2], mm0=_y[4], mm5=_y[5], mm3=_y[6], mm1=_y[7].\r
+  On output, {_y[4],mm1,mm2,mm3} contains the transpose of _y[4...7] and\r
+   {mm4,mm5,mm6,mm7} contains the transpose of _y[0...3].*/\r
+#define OC_TRANSPOSE8x4(_r0,_r1,_r2,_r3,_r4,_r5,_r6,_r7) __asm{ \\r
+  /*First 4x4 transpose:*/ \\r
+  /*mm0 = e3 e2 e1 e0 \\r
+    mm5 = f3 f2 f1 f0 \\r
+    mm3 = g3 g2 g1 g0 \\r
+    mm1 = h3 h2 h1 h0*/ \\r
+  __asm  movq mm2,mm0 \\r
+  __asm  punpcklwd mm0,mm5 \\r
+  __asm  punpckhwd mm2,mm5 \\r
+  __asm  movq mm5,mm3 \\r
+  __asm  punpcklwd mm3,mm1 \\r
+  __asm  punpckhwd mm5,mm1 \\r
+  /*mm0 = f1 e1 f0 e0 \\r
+    mm2 = f3 e3 f2 e2 \\r
+    mm3 = h1 g1 h0 g0 \\r
+    mm5 = h3 g3 h2 g2*/ \\r
+  __asm  movq mm1,mm0 \\r
+  __asm  punpckldq mm0,mm3 \\r
+  __asm  movq [Y+_r4],mm0 \\r
+  __asm  punpckhdq mm1,mm3 \\r
+  __asm  movq mm0,[Y+_r1] \\r
+  __asm  movq mm3,mm2 \\r
+  __asm  punpckldq mm2,mm5 \\r
+  __asm  punpckhdq mm3,mm5 \\r
+  __asm  movq mm5,[Y+_r3] \\r
+  /*_y[4] = h0 g0 f0 e0 \\r
+   mm1  = h1 g1 f1 e1 \\r
+   mm2  = h2 g2 f2 e2 \\r
+   mm3  = h3 g3 f3 e3*/ \\r
+  /*Second 4x4 transpose:*/ \\r
+  /*mm4 = a3 a2 a1 a0 \\r
+    mm0 = b3 b2 b1 b0 \\r
+    mm6 = c3 c2 c1 c0 \\r
+    mm5 = d3 d2 d1 d0*/ \\r
+  __asm  movq mm7,mm4 \\r
+  __asm  punpcklwd mm4,mm0 \\r
+  __asm  punpckhwd mm7,mm0 \\r
+  __asm  movq mm0,mm6 \\r
+  __asm  punpcklwd mm6,mm5 \\r
+  __asm  punpckhwd mm0,mm5 \\r
+  /*mm4 = b1 a1 b0 a0 \\r
+    mm7 = b3 a3 b2 a2 \\r
+    mm6 = d1 c1 d0 c0 \\r
+    mm0 = d3 c3 d2 c2*/ \\r
+  __asm  movq mm5,mm4 \\r
+  __asm  punpckldq mm4,mm6 \\r
+  __asm  punpckhdq mm5,mm6 \\r
+  __asm  movq mm6,mm7 \\r
+  __asm  punpckhdq mm7,mm0 \\r
+  __asm  punpckldq mm6,mm0 \\r
+  /*mm4 = d0 c0 b0 a0 \\r
+    mm5 = d1 c1 b1 a1 \\r
+    mm6 = d2 c2 b2 a2 \\r
+    mm7 = d3 c3 b3 a3*/ \\r
+}\r
+\r
+/*MMX implementation of the fDCT.*/\r
+void oc_enc_fdct8x8_mmx(ogg_int16_t _y[64],const ogg_int16_t _x[64]){\r
+  ptrdiff_t a;\r
+  __asm{\r
+#define Y eax\r
+#define A ecx\r
+#define X edx\r
+    /*Add two extra bits of working precision to improve accuracy; any more and\r
+       we could overflow.*/\r
+    /*We also add biases to correct for some systematic error that remains in\r
+       the full fDCT->iDCT round trip.*/\r
+    mov X, _x\r
+    mov Y, _y\r
+    movq mm0,[0x00+X]\r
+    movq mm1,[0x10+X]\r
+    movq mm2,[0x20+X]\r
+    movq mm3,[0x30+X]\r
+    pcmpeqb mm4,mm4\r
+    pxor mm7,mm7\r
+    movq mm5,mm0\r
+    psllw mm0,2\r
+    pcmpeqw mm5,mm7\r
+    movq mm7,[0x70+X]\r
+    psllw mm1,2\r
+    psubw mm5,mm4\r
+    psllw mm2,2\r
+    mov A,1\r
+    pslld mm5,16\r
+    movd mm6,A\r
+    psllq mm5,16\r
+    mov A,0x10001\r
+    psllw mm3,2\r
+    movd mm4,A\r
+    punpckhwd mm5,mm6\r
+    psubw mm1,mm6\r
+    movq mm6,[0x60+X]\r
+    paddw mm0,mm5\r
+    movq mm5,[0x50+X]\r
+    paddw mm0,mm4\r
+    movq mm4,[0x40+X]\r
+    /*We inline stage1 of the transform here so we can get better instruction\r
+       scheduling with the shifts.*/\r
+    /*mm0=t7'=t0-t7*/\r
+    psllw mm7,2\r
+    psubw mm0,mm7\r
+    psllw mm6,2\r
+    paddw mm7,mm7\r
+    /*mm1=t6'=t1-t6*/\r
+    psllw mm5,2\r
+    psubw mm1,mm6\r
+    psllw mm4,2\r
+    paddw mm6,mm6\r
+    /*mm2=t5'=t2-t5*/\r
+    psubw mm2,mm5\r
+    paddw mm5,mm5\r
+    /*mm3=t4'=t3-t4*/\r
+    psubw mm3,mm4\r
+    paddw mm4,mm4\r
+    /*mm7=t0'=t0+t7*/\r
+    paddw mm7,mm0\r
+    /*mm6=t1'=t1+t6*/\r
+    paddw mm6,mm1\r
+    /*mm5=t2'=t2+t5*/\r
+    paddw mm5,mm2\r
+    /*mm4=t3'=t3+t4*/\r
+    paddw mm4,mm3\r
+    OC_FDCT8x4(0x00,0x10,0x20,0x30,0x40,0x50,0x60,0x70)\r
+    OC_TRANSPOSE8x4(0x00,0x10,0x20,0x30,0x40,0x50,0x60,0x70)\r
+    /*Swap out this 8x4 block for the next one.*/\r
+    movq mm0,[0x08+X]\r
+    movq [0x30+Y],mm7\r
+    movq mm7,[0x78+X]\r
+    movq [0x50+Y],mm1\r
+    movq mm1,[0x18+X]\r
+    movq [0x20+Y],mm6\r
+    movq mm6,[0x68+X]\r
+    movq [0x60+Y],mm2\r
+    movq mm2,[0x28+X]\r
+    movq [0x10+Y],mm5\r
+    movq mm5,[0x58+X]\r
+    movq [0x70+Y],mm3\r
+    movq mm3,[0x38+X]\r
+    /*And increase its working precision, too.*/\r
+    psllw mm0,2\r
+    movq [0x00+Y],mm4\r
+    psllw mm7,2\r
+    movq mm4,[0x48+X]\r
+    /*We inline stage1 of the transform here so we can get better instruction\r
+       scheduling with the shifts.*/\r
+    /*mm0=t7'=t0-t7*/\r
+    psubw mm0,mm7\r
+    psllw mm1,2\r
+    paddw mm7,mm7\r
+    psllw mm6,2\r
+    /*mm1=t6'=t1-t6*/\r
+    psubw mm1,mm6\r
+    psllw mm2,2\r
+    paddw mm6,mm6\r
+    psllw mm5,2\r
+    /*mm2=t5'=t2-t5*/\r
+    psubw mm2,mm5\r
+    psllw mm3,2\r
+    paddw mm5,mm5\r
+    psllw mm4,2\r
+    /*mm3=t4'=t3-t4*/\r
+    psubw mm3,mm4\r
+    paddw mm4,mm4\r
+    /*mm7=t0'=t0+t7*/\r
+    paddw mm7,mm0\r
+    /*mm6=t1'=t1+t6*/\r
+    paddw mm6,mm1\r
+    /*mm5=t2'=t2+t5*/\r
+    paddw mm5,mm2\r
+    /*mm4=t3'=t3+t4*/\r
+    paddw mm4,mm3\r
+    OC_FDCT8x4(0x08,0x18,0x28,0x38,0x48,0x58,0x68,0x78)\r
+    OC_TRANSPOSE8x4(0x08,0x18,0x28,0x38,0x48,0x58,0x68,0x78)\r
+    /*Here the first 4x4 block of output from the last transpose is the second\r
+       4x4 block of input for the next transform.\r
+      We have cleverly arranged that it already be in the appropriate place,\r
+       so we only have to do half the stores and loads.*/\r
+    movq mm0,[0x00+Y]\r
+    movq [0x58+Y],mm1\r
+    movq mm1,[0x10+Y]\r
+    movq [0x68+Y],mm2\r
+    movq mm2,[0x20+Y]\r
+    movq [0x78+Y],mm3\r
+    movq mm3,[0x30+Y]\r
+    OC_FDCT_STAGE1_8x4\r
+    OC_FDCT8x4(0x00,0x10,0x20,0x30,0x08,0x18,0x28,0x38)\r
+    OC_TRANSPOSE8x4(0x00,0x10,0x20,0x30,0x08,0x18,0x28,0x38)\r
+    /*mm0={-2}x4*/\r
+    pcmpeqw mm0,mm0\r
+    paddw mm0,mm0\r
+    /*Round the results.*/\r
+    psubw mm1,mm0\r
+    psubw mm2,mm0\r
+    psraw mm1,2\r
+    psubw mm3,mm0\r
+    movq [0x18+Y],mm1\r
+    psraw mm2,2\r
+    psubw mm4,mm0\r
+    movq mm1,[0x08+Y]\r
+    psraw mm3,2\r
+    psubw mm5,mm0\r
+    psraw mm4,2\r
+    psubw mm6,mm0\r
+    psraw mm5,2\r
+    psubw mm7,mm0\r
+    psraw mm6,2\r
+    psubw mm1,mm0\r
+    psraw mm7,2\r
+    movq mm0,[0x40+Y]\r
+    psraw mm1,2\r
+    movq [0x30+Y],mm7\r
+    movq mm7,[0x78+Y]\r
+    movq [0x08+Y],mm1\r
+    movq mm1,[0x50+Y]\r
+    movq [0x20+Y],mm6\r
+    movq mm6,[0x68+Y]\r
+    movq [0x28+Y],mm2\r
+    movq mm2,[0x60+Y]\r
+    movq [0x10+Y],mm5\r
+    movq mm5,[0x58+Y]\r
+    movq [0x38+Y],mm3\r
+    movq mm3,[0x70+Y]\r
+    movq [0x00+Y],mm4\r
+    movq mm4,[0x48+Y]\r
+    OC_FDCT_STAGE1_8x4\r
+    OC_FDCT8x4(0x40,0x50,0x60,0x70,0x48,0x58,0x68,0x78)\r
+    OC_TRANSPOSE8x4(0x40,0x50,0x60,0x70,0x48,0x58,0x68,0x78)\r
+    /*mm0={-2}x4*/\r
+    pcmpeqw mm0,mm0\r
+    paddw mm0,mm0\r
+    /*Round the results.*/\r
+    psubw mm1,mm0\r
+    psubw mm2,mm0\r
+    psraw mm1,2\r
+    psubw mm3,mm0\r
+    movq [0x58+Y],mm1\r
+    psraw mm2,2\r
+    psubw mm4,mm0\r
+    movq mm1,[0x48+Y]\r
+    psraw mm3,2\r
+    psubw mm5,mm0\r
+    movq [0x68+Y],mm2\r
+    psraw mm4,2\r
+    psubw mm6,mm0\r
+    movq [0x78+Y],mm3\r
+    psraw mm5,2\r
+    psubw mm7,mm0\r
+    movq [0x40+Y],mm4\r
+    psraw mm6,2\r
+    psubw mm1,mm0\r
+    movq [0x50+Y],mm5\r
+    psraw mm7,2\r
+    movq [0x60+Y],mm6\r
+    psraw mm1,2\r
+    movq [0x70+Y],mm7\r
+    movq [0x48+Y],mm1\r
+#undef Y\r
+#undef A\r
+#undef X\r
+  }\r
+}\r
+\r
+#endif\r
diff --git a/lib/x86_vc/mmxfrag.c b/lib/x86_vc/mmxfrag.c
new file mode 100644 (file)
index 0000000..4eb2084
--- /dev/null
@@ -0,0 +1,337 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: mmxfrag.c 16578 2009-09-25 19:50:48Z cristianadam $
+
+ ********************************************************************/
+
+/*MMX acceleration of fragment reconstruction for motion compensation.
+  Originally written by Rudolf Marek.
+  Additional optimization by Nils Pipenbrinck.
+  Note: Loops are unrolled for best performance.
+  The iteration each instruction belongs to is marked in the comments as #i.*/
+#include <stddef.h>
+#include "x86int.h"
+#include "mmxfrag.h"
+
+#if defined(OC_X86_ASM)
+
+/*Copies an 8x8 block of pixels from _src to _dst, assuming _ystride bytes
+   between rows.*/
+void oc_frag_copy_mmx(unsigned char *_dst,
+ const unsigned char *_src,int _ystride){
+#define SRC edx
+#define DST eax
+#define YSTRIDE ecx
+#define YSTRIDE3 esi
+  OC_FRAG_COPY_MMX(_dst,_src,_ystride);
+#undef SRC
+#undef DST
+#undef YSTRIDE
+#undef YSTRIDE3
+}
+
+void oc_frag_recon_intra_mmx(unsigned char *_dst,int _ystride,
+ const ogg_int16_t *_residue){
+  __asm{
+#define DST edx
+#define DST4 esi
+#define YSTRIDE eax
+#define YSTRIDE3 edi
+#define RESIDUE ecx
+    mov DST,_dst
+    mov YSTRIDE,_ystride
+    mov RESIDUE,_residue
+    lea DST4,[DST+YSTRIDE*4]
+    lea YSTRIDE3,[YSTRIDE+YSTRIDE*2]
+    /*Set mm0 to 0xFFFFFFFFFFFFFFFF.*/
+    pcmpeqw mm0,mm0
+    /*#0 Load low residue.*/
+    movq mm1,[0*8+RESIDUE]
+    /*#0 Load high residue.*/
+    movq mm2,[1*8+RESIDUE]
+    /*Set mm0 to 0x8000800080008000.*/
+    psllw mm0,15
+    /*#1 Load low residue.*/
+    movq mm3,[2*8+RESIDUE]
+    /*#1 Load high residue.*/
+    movq mm4,[3*8+RESIDUE]
+    /*Set mm0 to 0x0080008000800080.*/
+    psrlw mm0,8
+    /*#2 Load low residue.*/
+    movq mm5,[4*8+RESIDUE]
+    /*#2 Load high residue.*/
+    movq mm6,[5*8+RESIDUE]
+    /*#0 Bias low  residue.*/
+    paddsw mm1,mm0
+    /*#0 Bias high residue.*/
+    paddsw mm2,mm0
+    /*#0 Pack to byte.*/
+    packuswb mm1,mm2
+    /*#1 Bias low  residue.*/
+    paddsw mm3,mm0
+    /*#1 Bias high residue.*/
+    paddsw mm4,mm0
+    /*#1 Pack to byte.*/
+    packuswb mm3,mm4
+    /*#2 Bias low  residue.*/
+    paddsw mm5,mm0
+    /*#2 Bias high residue.*/
+    paddsw mm6,mm0
+    /*#2 Pack to byte.*/
+    packuswb mm5,mm6
+    /*#0 Write row.*/
+    movq [DST],mm1
+    /*#1 Write row.*/
+    movq [DST+YSTRIDE],mm3
+    /*#2 Write row.*/
+    movq [DST+YSTRIDE*2],mm5
+    /*#3 Load low residue.*/
+    movq mm1,[6*8+RESIDUE]
+    /*#3 Load high residue.*/
+    movq mm2,[7*8+RESIDUE]
+    /*#4 Load high residue.*/
+    movq mm3,[8*8+RESIDUE]
+    /*#4 Load high residue.*/
+    movq mm4,[9*8+RESIDUE]
+    /*#5 Load high residue.*/
+    movq mm5,[10*8+RESIDUE]
+    /*#5 Load high residue.*/
+    movq mm6,[11*8+RESIDUE]
+    /*#3 Bias low  residue.*/
+    paddsw mm1,mm0
+    /*#3 Bias high residue.*/
+    paddsw mm2,mm0
+    /*#3 Pack to byte.*/
+    packuswb mm1,mm2
+    /*#4 Bias low  residue.*/
+    paddsw mm3,mm0
+    /*#4 Bias high residue.*/
+    paddsw mm4,mm0
+    /*#4 Pack to byte.*/
+    packuswb mm3,mm4
+    /*#5 Bias low  residue.*/
+    paddsw mm5,mm0
+    /*#5 Bias high residue.*/
+    paddsw mm6,mm0
+    /*#5 Pack to byte.*/
+    packuswb mm5,mm6
+    /*#3 Write row.*/
+    movq [DST+YSTRIDE3],mm1
+    /*#4 Write row.*/
+    movq [DST4],mm3
+    /*#5 Write row.*/
+    movq [DST4+YSTRIDE],mm5
+    /*#6 Load low residue.*/
+    movq mm1,[12*8+RESIDUE]
+    /*#6 Load high residue.*/
+    movq mm2,[13*8+RESIDUE]
+    /*#7 Load low residue.*/
+    movq mm3,[14*8+RESIDUE]
+    /*#7 Load high residue.*/
+    movq mm4,[15*8+RESIDUE]
+    /*#6 Bias low  residue.*/
+    paddsw mm1,mm0
+    /*#6 Bias high residue.*/
+    paddsw mm2,mm0
+    /*#6 Pack to byte.*/
+    packuswb mm1,mm2
+    /*#7 Bias low  residue.*/
+    paddsw mm3,mm0
+    /*#7 Bias high residue.*/
+    paddsw mm4,mm0
+    /*#7 Pack to byte.*/
+    packuswb mm3,mm4
+    /*#6 Write row.*/
+    movq [DST4+YSTRIDE*2],mm1
+    /*#7 Write row.*/
+    movq [DST4+YSTRIDE3],mm3
+#undef DST
+#undef DST4
+#undef YSTRIDE
+#undef YSTRIDE3
+#undef RESIDUE
+  }
+}
+
+void oc_frag_recon_inter_mmx(unsigned char *_dst,const unsigned char *_src,
+ int _ystride,const ogg_int16_t *_residue){
+  int i;
+  /*Zero mm0.*/
+  __asm pxor mm0,mm0;
+  for(i=4;i-->0;){
+    __asm{
+#define DST edx
+#define SRC ecx
+#define YSTRIDE edi
+#define RESIDUE eax
+      mov DST,_dst
+      mov SRC,_src
+      mov YSTRIDE,_ystride
+      mov RESIDUE,_residue
+      /*#0 Load source.*/
+      movq mm3,[SRC]
+      /*#1 Load source.*/
+      movq mm7,[SRC+YSTRIDE]
+      /*#0 Get copy of src.*/
+      movq mm4,mm3
+      /*#0 Expand high source.*/
+      punpckhbw mm4,mm0
+      /*#0 Expand low  source.*/
+      punpcklbw mm3,mm0
+      /*#0 Add residue high.*/
+      paddsw mm4,[8+RESIDUE]
+      /*#1 Get copy of src.*/
+      movq mm2,mm7
+      /*#0 Add residue low.*/
+      paddsw  mm3,[RESIDUE]
+      /*#1 Expand high source.*/
+      punpckhbw mm2,mm0
+      /*#0 Pack final row pixels.*/
+      packuswb mm3,mm4
+      /*#1 Expand low  source.*/
+      punpcklbw mm7,mm0
+      /*#1 Add residue low.*/
+      paddsw mm7,[16+RESIDUE]
+      /*#1 Add residue high.*/
+      paddsw mm2,[24+RESIDUE]
+      /*Advance residue.*/
+      lea RESIDUE,[32+RESIDUE]
+      /*#1 Pack final row pixels.*/
+      packuswb mm7,mm2
+      /*Advance src.*/
+      lea SRC,[SRC+YSTRIDE*2]
+      /*#0 Write row.*/
+      movq [DST],mm3
+      /*#1 Write row.*/
+      movq [DST+YSTRIDE],mm7
+      /*Advance dst.*/
+      lea DST,[DST+YSTRIDE*2]
+      mov _residue,RESIDUE
+      mov _dst,DST
+      mov _src,SRC
+#undef DST
+#undef SRC
+#undef YSTRIDE
+#undef RESIDUE
+    }
+  }
+}
+
+void oc_frag_recon_inter2_mmx(unsigned char *_dst,const unsigned char *_src1,
+ const unsigned char *_src2,int _ystride,const ogg_int16_t *_residue){
+  int i;
+  /*Zero mm7.*/
+  __asm pxor mm7,mm7;
+  for(i=4;i-->0;){
+    __asm{
+#define SRC1 ecx
+#define SRC2 edi
+#define YSTRIDE esi
+#define RESIDUE edx
+#define DST eax
+      mov YSTRIDE,_ystride
+      mov DST,_dst
+      mov RESIDUE,_residue
+      mov SRC1,_src1
+      mov SRC2,_src2
+      /*#0 Load src1.*/
+      movq mm0,[SRC1]
+      /*#0 Load src2.*/
+      movq mm2,[SRC2]
+      /*#0 Copy src1.*/
+      movq mm1,mm0
+      /*#0 Copy src2.*/
+      movq mm3,mm2
+      /*#1 Load src1.*/
+      movq mm4,[SRC1+YSTRIDE]
+      /*#0 Unpack lower src1.*/
+      punpcklbw mm0,mm7
+      /*#1 Load src2.*/
+      movq mm5,[SRC2+YSTRIDE]
+      /*#0 Unpack higher src1.*/
+      punpckhbw mm1,mm7
+      /*#0 Unpack lower src2.*/
+      punpcklbw mm2,mm7
+      /*#0 Unpack higher src2.*/
+      punpckhbw mm3,mm7
+      /*Advance src1 ptr.*/
+      lea SRC1,[SRC1+YSTRIDE*2]
+      /*Advance src2 ptr.*/
+      lea SRC2,[SRC2+YSTRIDE*2]
+      /*#0 Lower src1+src2.*/
+      paddsw mm0,mm2
+      /*#0 Higher src1+src2.*/
+      paddsw mm1,mm3
+      /*#1 Copy src1.*/
+      movq mm2,mm4
+      /*#0 Build lo average.*/
+      psraw mm0,1
+      /*#1 Copy src2.*/
+      movq mm3,mm5
+      /*#1 Unpack lower src1.*/
+      punpcklbw mm4,mm7
+      /*#0 Build hi average.*/
+      psraw mm1,1
+      /*#1 Unpack higher src1.*/
+      punpckhbw mm2,mm7
+      /*#0 low+=residue.*/
+      paddsw mm0,[RESIDUE]
+      /*#1 Unpack lower src2.*/
+      punpcklbw mm5,mm7
+      /*#0 high+=residue.*/
+      paddsw mm1,[8+RESIDUE]
+      /*#1 Unpack higher src2.*/
+      punpckhbw mm3,mm7
+      /*#1 Lower src1+src2.*/
+      paddsw mm5,mm4
+      /*#0 Pack and saturate.*/
+      packuswb mm0,mm1
+      /*#1 Higher src1+src2.*/
+      paddsw mm3,mm2
+      /*#0 Write row.*/
+      movq [DST],mm0
+      /*#1 Build lo average.*/
+      psraw mm5,1
+      /*#1 Build hi average.*/
+      psraw mm3,1
+      /*#1 low+=residue.*/
+      paddsw mm5,[16+RESIDUE]
+      /*#1 high+=residue.*/
+      paddsw mm3,[24+RESIDUE]
+      /*#1 Pack and saturate.*/
+      packuswb  mm5,mm3
+      /*#1 Write row ptr.*/
+      movq [DST+YSTRIDE],mm5
+      /*Advance residue ptr.*/
+      add RESIDUE,32
+      /*Advance dest ptr.*/
+      lea DST,[DST+YSTRIDE*2]
+      mov _dst,DST
+      mov _residue,RESIDUE
+      mov _src1,SRC1
+      mov _src2,SRC2
+#undef SRC1
+#undef SRC2
+#undef YSTRIDE
+#undef RESIDUE
+#undef DST
+    }
+  }
+}
+
+void oc_restore_fpu_mmx(void){
+  __asm emms;
+}
+
+#endif
diff --git a/lib/x86_vc/mmxfrag.h b/lib/x86_vc/mmxfrag.h
new file mode 100644 (file)
index 0000000..45ee93e
--- /dev/null
@@ -0,0 +1,61 @@
+#if !defined(_x86_vc_mmxfrag_H)
+# define _x86_vc_mmxfrag_H (1)
+# include <stddef.h>
+# include "x86int.h"
+
+#if defined(OC_X86_ASM)
+
+/*Copies an 8x8 block of pixels from _src to _dst, assuming _ystride bytes
+   between rows.*/
+#define OC_FRAG_COPY_MMX(_dst,_src,_ystride) \
+  do{ \
+    const unsigned char *src; \
+    unsigned char       *dst; \
+    src=(_src); \
+    dst=(_dst); \
+    __asm  mov SRC,src \
+    __asm  mov DST,dst \
+    __asm  mov YSTRIDE,_ystride \
+    /*src+0*ystride*/ \
+    __asm  movq mm0,[SRC] \
+    /*src+1*ystride*/ \
+    __asm  movq mm1,[SRC+YSTRIDE] \
+    /*ystride3=ystride*3*/ \
+    __asm  lea YSTRIDE3,[YSTRIDE+YSTRIDE*2] \
+    /*src+2*ystride*/ \
+    __asm  movq mm2,[SRC+YSTRIDE*2] \
+    /*src+3*ystride*/ \
+    __asm  movq mm3,[SRC+YSTRIDE3] \
+    /*dst+0*ystride*/ \
+    __asm  movq [DST],mm0 \
+    /*dst+1*ystride*/ \
+    __asm  movq [DST+YSTRIDE],mm1 \
+    /*Pointer to next 4.*/ \
+    __asm  lea SRC,[SRC+YSTRIDE*4] \
+    /*dst+2*ystride*/ \
+    __asm  movq [DST+YSTRIDE*2],mm2 \
+    /*dst+3*ystride*/ \
+    __asm  movq [DST+YSTRIDE3],mm3 \
+    /*Pointer to next 4.*/ \
+    __asm  lea DST,[DST+YSTRIDE*4] \
+    /*src+0*ystride*/ \
+    __asm  movq mm0,[SRC] \
+    /*src+1*ystride*/ \
+    __asm  movq mm1,[SRC+YSTRIDE] \
+    /*src+2*ystride*/ \
+    __asm  movq mm2,[SRC+YSTRIDE*2] \
+    /*src+3*ystride*/ \
+    __asm  movq mm3,[SRC+YSTRIDE3] \
+    /*dst+0*ystride*/ \
+    __asm  movq [DST],mm0 \
+    /*dst+1*ystride*/ \
+    __asm  movq [DST+YSTRIDE],mm1 \
+    /*dst+2*ystride*/ \
+    __asm  movq [DST+YSTRIDE*2],mm2 \
+    /*dst+3*ystride*/ \
+    __asm  movq [DST+YSTRIDE3],mm3 \
+  } \
+  while(0)
+
+# endif
+#endif
diff --git a/lib/x86_vc/mmxidct.c b/lib/x86_vc/mmxidct.c
new file mode 100644 (file)
index 0000000..8f5ff68
--- /dev/null
@@ -0,0 +1,562 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: mmxidct.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+/*MMX acceleration of Theora's iDCT.
+  Originally written by Rudolf Marek, based on code from On2's VP3.*/
+#include "x86int.h"
+#include "../dct.h"
+
+#if defined(OC_X86_ASM)
+
+/*These are offsets into the table of constants below.*/
+/*7 rows of cosines, in order: pi/16 * (1 ... 7).*/
+#define OC_COSINE_OFFSET (0)
+/*A row of 8's.*/
+#define OC_EIGHT_OFFSET  (56)
+
+
+
+/*A table of constants used by the MMX routines.*/
+static const __declspec(align(16))ogg_uint16_t
+ OC_IDCT_CONSTS[(7+1)*4]={
+  (ogg_uint16_t)OC_C1S7,(ogg_uint16_t)OC_C1S7,
+  (ogg_uint16_t)OC_C1S7,(ogg_uint16_t)OC_C1S7,
+  (ogg_uint16_t)OC_C2S6,(ogg_uint16_t)OC_C2S6,
+  (ogg_uint16_t)OC_C2S6,(ogg_uint16_t)OC_C2S6,
+  (ogg_uint16_t)OC_C3S5,(ogg_uint16_t)OC_C3S5,
+  (ogg_uint16_t)OC_C3S5,(ogg_uint16_t)OC_C3S5,
+  (ogg_uint16_t)OC_C4S4,(ogg_uint16_t)OC_C4S4,
+  (ogg_uint16_t)OC_C4S4,(ogg_uint16_t)OC_C4S4,
+  (ogg_uint16_t)OC_C5S3,(ogg_uint16_t)OC_C5S3,
+  (ogg_uint16_t)OC_C5S3,(ogg_uint16_t)OC_C5S3,
+  (ogg_uint16_t)OC_C6S2,(ogg_uint16_t)OC_C6S2,
+  (ogg_uint16_t)OC_C6S2,(ogg_uint16_t)OC_C6S2,
+  (ogg_uint16_t)OC_C7S1,(ogg_uint16_t)OC_C7S1,
+  (ogg_uint16_t)OC_C7S1,(ogg_uint16_t)OC_C7S1,
+      8,    8,    8,    8
+};
+
+/*38 cycles*/
+#define OC_IDCT_BEGIN __asm{ \
+  __asm movq mm2,OC_I(3) \
+  __asm movq mm6,OC_C(3) \
+  __asm movq mm4,mm2 \
+  __asm movq mm7,OC_J(5) \
+  __asm pmulhw mm4,mm6 \
+  __asm movq mm1,OC_C(5) \
+  __asm pmulhw mm6,mm7 \
+  __asm movq mm5,mm1 \
+  __asm pmulhw mm1,mm2 \
+  __asm movq mm3,OC_I(1) \
+  __asm pmulhw mm5,mm7 \
+  __asm movq mm0,OC_C(1) \
+  __asm paddw mm4,mm2 \
+  __asm paddw mm6,mm7 \
+  __asm paddw mm2,mm1 \
+  __asm movq mm1,OC_J(7) \
+  __asm paddw mm7,mm5 \
+  __asm movq mm5,mm0 \
+  __asm pmulhw mm0,mm3 \
+  __asm paddw mm4,mm7 \
+  __asm pmulhw mm5,mm1 \
+  __asm movq mm7,OC_C(7) \
+  __asm psubw mm6,mm2 \
+  __asm paddw mm0,mm3 \
+  __asm pmulhw mm3,mm7 \
+  __asm movq mm2,OC_I(2) \
+  __asm pmulhw mm7,mm1 \
+  __asm paddw mm5,mm1 \
+  __asm movq mm1,mm2 \
+  __asm pmulhw mm2,OC_C(2) \
+  __asm psubw mm3,mm5 \
+  __asm movq mm5,OC_J(6) \
+  __asm paddw mm0,mm7 \
+  __asm movq mm7,mm5 \
+  __asm psubw mm0,mm4 \
+  __asm pmulhw mm5,OC_C(2) \
+  __asm paddw mm2,mm1 \
+  __asm pmulhw mm1,OC_C(6) \
+  __asm paddw mm4,mm4 \
+  __asm paddw mm4,mm0 \
+  __asm psubw mm3,mm6 \
+  __asm paddw mm5,mm7 \
+  __asm paddw mm6,mm6 \
+  __asm pmulhw mm7,OC_C(6) \
+  __asm paddw mm6,mm3 \
+  __asm movq OC_I(1),mm4 \
+  __asm psubw mm1,mm5 \
+  __asm movq mm4,OC_C(4) \
+  __asm movq mm5,mm3 \
+  __asm pmulhw mm3,mm4 \
+  __asm paddw mm7,mm2 \
+  __asm movq OC_I(2),mm6 \
+  __asm movq mm2,mm0 \
+  __asm movq mm6,OC_I(0) \
+  __asm pmulhw mm0,mm4 \
+  __asm paddw mm5,mm3 \
+  __asm movq mm3,OC_J(4) \
+  __asm psubw mm5,mm1 \
+  __asm paddw mm2,mm0 \
+  __asm psubw mm6,mm3 \
+  __asm movq mm0,mm6 \
+  __asm pmulhw mm6,mm4 \
+  __asm paddw mm3,mm3 \
+  __asm paddw mm1,mm1 \
+  __asm paddw mm3,mm0 \
+  __asm paddw mm1,mm5 \
+  __asm pmulhw mm4,mm3 \
+  __asm paddw mm6,mm0 \
+  __asm psubw mm6,mm2 \
+  __asm paddw mm2,mm2 \
+  __asm movq mm0,OC_I(1) \
+  __asm paddw mm2,mm6 \
+  __asm paddw mm4,mm3 \
+  __asm psubw mm2,mm1 \
+}
+
+/*38+8=46 cycles.*/
+#define OC_ROW_IDCT __asm{ \
+  OC_IDCT_BEGIN \
+  /*r3=D'*/ \
+  __asm  movq mm3,OC_I(2) \
+  /*r4=E'=E-G*/ \
+  __asm  psubw mm4,mm7 \
+  /*r1=H'+H'*/ \
+  __asm  paddw mm1,mm1 \
+  /*r7=G+G*/ \
+  __asm  paddw mm7,mm7 \
+  /*r1=R1=A''+H'*/ \
+  __asm  paddw mm1,mm2 \
+  /*r7=G'=E+G*/ \
+  __asm  paddw mm7,mm4 \
+  /*r4=R4=E'-D'*/ \
+  __asm  psubw mm4,mm3 \
+  __asm  paddw mm3,mm3 \
+  /*r6=R6=F'-B''*/ \
+  __asm  psubw mm6,mm5 \
+  __asm  paddw mm5,mm5 \
+  /*r3=R3=E'+D'*/ \
+  __asm  paddw mm3,mm4 \
+  /*r5=R5=F'+B''*/ \
+  __asm  paddw mm5,mm6 \
+  /*r7=R7=G'-C'*/ \
+  __asm  psubw mm7,mm0 \
+  __asm  paddw mm0,mm0 \
+  /*Save R1.*/ \
+  __asm  movq OC_I(1),mm1 \
+  /*r0=R0=G.+C.*/ \
+  __asm  paddw mm0,mm7 \
+}
+
+/*The following macro does two 4x4 transposes in place.
+  At entry, we assume:
+    r0 = a3 a2 a1 a0
+  I(1) = b3 b2 b1 b0
+    r2 = c3 c2 c1 c0
+    r3 = d3 d2 d1 d0
+
+    r4 = e3 e2 e1 e0
+    r5 = f3 f2 f1 f0
+    r6 = g3 g2 g1 g0
+    r7 = h3 h2 h1 h0
+
+  At exit, we have:
+  I(0) = d0 c0 b0 a0
+  I(1) = d1 c1 b1 a1
+  I(2) = d2 c2 b2 a2
+  I(3) = d3 c3 b3 a3
+
+  J(4) = h0 g0 f0 e0
+  J(5) = h1 g1 f1 e1
+  J(6) = h2 g2 f2 e2
+  J(7) = h3 g3 f3 e3
+
+  I(0) I(1) I(2) I(3) is the transpose of r0 I(1) r2 r3.
+  J(4) J(5) J(6) J(7) is the transpose of r4  r5  r6 r7.
+
+  Since r1 is free at entry, we calculate the Js first.*/
+/*19 cycles.*/
+#define OC_TRANSPOSE __asm{ \
+  __asm movq mm1,mm4 \
+  __asm punpcklwd mm4,mm5 \
+  __asm movq OC_I(0),mm0 \
+  __asm punpckhwd mm1,mm5 \
+  __asm movq mm0,mm6 \
+  __asm punpcklwd mm6,mm7 \
+  __asm movq mm5,mm4 \
+  __asm punpckldq mm4,mm6 \
+  __asm punpckhdq mm5,mm6 \
+  __asm movq mm6,mm1 \
+  __asm movq OC_J(4),mm4 \
+  __asm punpckhwd mm0,mm7 \
+  __asm movq OC_J(5),mm5 \
+  __asm punpckhdq mm6,mm0 \
+  __asm movq mm4,OC_I(0) \
+  __asm punpckldq mm1,mm0 \
+  __asm movq mm5,OC_I(1) \
+  __asm movq mm0,mm4 \
+  __asm movq OC_J(7),mm6 \
+  __asm punpcklwd mm0,mm5 \
+  __asm movq OC_J(6),mm1 \
+  __asm punpckhwd mm4,mm5 \
+  __asm movq mm5,mm2 \
+  __asm punpcklwd mm2,mm3 \
+  __asm movq mm1,mm0 \
+  __asm punpckldq mm0,mm2 \
+  __asm punpckhdq mm1,mm2 \
+  __asm movq mm2,mm4 \
+  __asm movq OC_I(0),mm0 \
+  __asm punpckhwd mm5,mm3 \
+  __asm movq OC_I(1),mm1 \
+  __asm punpckhdq mm4,mm5 \
+  __asm punpckldq mm2,mm5 \
+  __asm movq OC_I(3),mm4 \
+  __asm movq OC_I(2),mm2 \
+}
+
+/*38+19=57 cycles.*/
+#define OC_COLUMN_IDCT __asm{ \
+  OC_IDCT_BEGIN \
+  __asm paddw mm2,OC_8 \
+  /*r1=H'+H'*/ \
+  __asm paddw mm1,mm1 \
+  /*r1=R1=A''+H'*/ \
+  __asm paddw mm1,mm2 \
+  /*r2=NR2*/ \
+  __asm psraw mm2,4 \
+  /*r4=E'=E-G*/ \
+  __asm psubw mm4,mm7 \
+  /*r1=NR1*/ \
+  __asm psraw mm1,4 \
+  /*r3=D'*/ \
+  __asm movq mm3,OC_I(2) \
+  /*r7=G+G*/ \
+  __asm paddw mm7,mm7 \
+  /*Store NR2 at I(2).*/ \
+  __asm movq OC_I(2),mm2 \
+  /*r7=G'=E+G*/ \
+  __asm paddw mm7,mm4 \
+  /*Store NR1 at I(1).*/ \
+  __asm movq OC_I(1),mm1 \
+  /*r4=R4=E'-D'*/ \
+  __asm psubw mm4,mm3 \
+  __asm paddw mm4,OC_8 \
+  /*r3=D'+D'*/ \
+  __asm paddw mm3,mm3 \
+  /*r3=R3=E'+D'*/ \
+  __asm paddw mm3,mm4 \
+  /*r4=NR4*/ \
+  __asm psraw mm4,4 \
+  /*r6=R6=F'-B''*/ \
+  __asm psubw mm6,mm5 \
+  /*r3=NR3*/ \
+  __asm psraw mm3,4 \
+  __asm paddw mm6,OC_8 \
+  /*r5=B''+B''*/ \
+  __asm paddw mm5,mm5 \
+  /*r5=R5=F'+B''*/ \
+  __asm paddw mm5,mm6 \
+  /*r6=NR6*/ \
+  __asm psraw mm6,4 \
+  /*Store NR4 at J(4).*/ \
+  __asm movq OC_J(4),mm4 \
+  /*r5=NR5*/ \
+  __asm psraw mm5,4 \
+  /*Store NR3 at I(3).*/ \
+  __asm movq OC_I(3),mm3 \
+  /*r7=R7=G'-C'*/ \
+  __asm psubw mm7,mm0 \
+  __asm paddw mm7,OC_8 \
+  /*r0=C'+C'*/ \
+  __asm paddw mm0,mm0 \
+  /*r0=R0=G'+C'*/ \
+  __asm paddw mm0,mm7 \
+  /*r7=NR7*/ \
+  __asm psraw mm7,4 \
+  /*Store NR6 at J(6).*/ \
+  __asm movq OC_J(6),mm6 \
+  /*r0=NR0*/ \
+  __asm psraw mm0,4 \
+  /*Store NR5 at J(5).*/ \
+  __asm movq OC_J(5),mm5 \
+  /*Store NR7 at J(7).*/ \
+  __asm movq OC_J(7),mm7 \
+  /*Store NR0 at I(0).*/ \
+  __asm movq OC_I(0),mm0 \
+}
+
+#define OC_MID(_m,_i) [CONSTS+_m+(_i)*8]
+#define OC_C(_i)      OC_MID(OC_COSINE_OFFSET,_i-1)
+#define OC_8          OC_MID(OC_EIGHT_OFFSET,0)
+
+static void oc_idct8x8_slow(ogg_int16_t _y[64]){
+  /*This routine accepts an 8x8 matrix, but in partially transposed form.
+    Every 4x4 block is transposed.*/
+  __asm{
+#define CONSTS eax
+#define Y edx
+    mov CONSTS,offset OC_IDCT_CONSTS
+    mov Y,_y
+#define OC_I(_k)      [Y+_k*16]
+#define OC_J(_k)      [Y+(_k-4)*16+8]
+    OC_ROW_IDCT
+    OC_TRANSPOSE
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k)      [Y+(_k*16)+64]
+#define OC_J(_k)      [Y+(_k-4)*16+72]
+    OC_ROW_IDCT
+    OC_TRANSPOSE
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k)      [Y+_k*16]
+#define OC_J(_k)      OC_I(_k)
+    OC_COLUMN_IDCT
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k)      [Y+_k*16+8]
+#define OC_J(_k)      OC_I(_k)
+    OC_COLUMN_IDCT
+#undef  OC_I
+#undef  OC_J
+#undef  CONSTS
+#undef  Y
+  }
+}
+
+/*25 cycles.*/
+#define OC_IDCT_BEGIN_10 __asm{ \
+  __asm movq mm2,OC_I(3) \
+  __asm nop \
+  __asm movq mm6,OC_C(3) \
+  __asm movq mm4,mm2 \
+  __asm movq mm1,OC_C(5) \
+  __asm pmulhw mm4,mm6 \
+  __asm movq mm3,OC_I(1) \
+  __asm pmulhw mm1,mm2 \
+  __asm movq mm0,OC_C(1) \
+  __asm paddw mm4,mm2 \
+  __asm pxor mm6,mm6 \
+  __asm paddw mm2,mm1 \
+  __asm movq mm5,OC_I(2) \
+  __asm pmulhw mm0,mm3 \
+  __asm movq mm1,mm5 \
+  __asm paddw mm0,mm3 \
+  __asm pmulhw mm3,OC_C(7) \
+  __asm psubw mm6,mm2 \
+  __asm pmulhw mm5,OC_C(2) \
+  __asm psubw mm0,mm4 \
+  __asm movq mm7,OC_I(2) \
+  __asm paddw mm4,mm4 \
+  __asm paddw mm7,mm5 \
+  __asm paddw mm4,mm0 \
+  __asm pmulhw mm1,OC_C(6) \
+  __asm psubw mm3,mm6 \
+  __asm movq OC_I(1),mm4 \
+  __asm paddw mm6,mm6 \
+  __asm movq mm4,OC_C(4) \
+  __asm paddw mm6,mm3 \
+  __asm movq mm5,mm3 \
+  __asm pmulhw mm3,mm4 \
+  __asm movq OC_I(2),mm6 \
+  __asm movq mm2,mm0 \
+  __asm movq mm6,OC_I(0) \
+  __asm pmulhw mm0,mm4 \
+  __asm paddw mm5,mm3 \
+  __asm paddw mm2,mm0 \
+  __asm psubw mm5,mm1 \
+  __asm pmulhw mm6,mm4 \
+  __asm paddw mm6,OC_I(0) \
+  __asm paddw mm1,mm1 \
+  __asm movq mm4,mm6 \
+  __asm paddw mm1,mm5 \
+  __asm psubw mm6,mm2 \
+  __asm paddw mm2,mm2 \
+  __asm movq mm0,OC_I(1) \
+  __asm paddw mm2,mm6 \
+  __asm psubw mm2,mm1 \
+  __asm nop \
+}
+
+/*25+8=33 cycles.*/
+#define OC_ROW_IDCT_10 __asm{ \
+  OC_IDCT_BEGIN_10 \
+  /*r3=D'*/ \
+   __asm movq mm3,OC_I(2) \
+  /*r4=E'=E-G*/ \
+   __asm psubw mm4,mm7 \
+  /*r1=H'+H'*/ \
+   __asm paddw mm1,mm1 \
+  /*r7=G+G*/ \
+   __asm paddw mm7,mm7 \
+  /*r1=R1=A''+H'*/ \
+   __asm paddw mm1,mm2 \
+  /*r7=G'=E+G*/ \
+   __asm paddw mm7,mm4 \
+  /*r4=R4=E'-D'*/ \
+   __asm psubw mm4,mm3 \
+   __asm paddw mm3,mm3 \
+  /*r6=R6=F'-B''*/ \
+   __asm psubw mm6,mm5 \
+   __asm paddw mm5,mm5 \
+  /*r3=R3=E'+D'*/ \
+   __asm paddw mm3,mm4 \
+  /*r5=R5=F'+B''*/ \
+   __asm paddw mm5,mm6 \
+  /*r7=R7=G'-C'*/ \
+   __asm psubw mm7,mm0 \
+   __asm paddw mm0,mm0 \
+  /*Save R1.*/ \
+   __asm movq OC_I(1),mm1 \
+  /*r0=R0=G'+C'*/ \
+   __asm paddw mm0,mm7 \
+}
+
+/*25+19=44 cycles'*/
+#define OC_COLUMN_IDCT_10 __asm{ \
+  OC_IDCT_BEGIN_10 \
+  __asm paddw mm2,OC_8 \
+  /*r1=H'+H'*/ \
+  __asm paddw mm1,mm1 \
+  /*r1=R1=A''+H'*/ \
+  __asm paddw mm1,mm2 \
+  /*r2=NR2*/ \
+  __asm psraw mm2,4 \
+  /*r4=E'=E-G*/ \
+  __asm psubw mm4,mm7 \
+  /*r1=NR1*/ \
+  __asm psraw mm1,4 \
+  /*r3=D'*/ \
+  __asm movq mm3,OC_I(2) \
+  /*r7=G+G*/ \
+  __asm paddw mm7,mm7 \
+  /*Store NR2 at I(2).*/ \
+  __asm movq OC_I(2),mm2 \
+  /*r7=G'=E+G*/ \
+  __asm paddw mm7,mm4 \
+  /*Store NR1 at I(1).*/ \
+  __asm movq OC_I(1),mm1 \
+  /*r4=R4=E'-D'*/ \
+  __asm psubw mm4,mm3 \
+  __asm paddw mm4,OC_8 \
+  /*r3=D'+D'*/ \
+  __asm paddw mm3,mm3 \
+  /*r3=R3=E'+D'*/ \
+  __asm paddw mm3,mm4 \
+  /*r4=NR4*/ \
+  __asm psraw mm4,4 \
+  /*r6=R6=F'-B''*/ \
+  __asm psubw mm6,mm5 \
+  /*r3=NR3*/ \
+  __asm psraw mm3,4 \
+  __asm paddw mm6,OC_8 \
+  /*r5=B''+B''*/ \
+  __asm paddw mm5,mm5 \
+  /*r5=R5=F'+B''*/ \
+  __asm paddw mm5,mm6 \
+  /*r6=NR6*/ \
+  __asm psraw mm6,4 \
+  /*Store NR4 at J(4).*/ \
+  __asm movq OC_J(4),mm4 \
+  /*r5=NR5*/ \
+  __asm psraw mm5,4 \
+  /*Store NR3 at I(3).*/ \
+  __asm movq OC_I(3),mm3 \
+  /*r7=R7=G'-C'*/ \
+  __asm psubw mm7,mm0 \
+  __asm paddw mm7,OC_8 \
+  /*r0=C'+C'*/ \
+  __asm paddw mm0,mm0 \
+  /*r0=R0=G'+C'*/ \
+  __asm paddw mm0,mm7 \
+  /*r7=NR7*/ \
+  __asm psraw mm7,4 \
+  /*Store NR6 at J(6).*/ \
+  __asm movq OC_J(6),mm6 \
+  /*r0=NR0*/ \
+  __asm psraw mm0,4 \
+  /*Store NR5 at J(5).*/ \
+  __asm movq OC_J(5),mm5 \
+  /*Store NR7 at J(7).*/ \
+  __asm movq OC_J(7),mm7 \
+  /*Store NR0 at I(0).*/ \
+  __asm movq OC_I(0),mm0 \
+}
+
+static void oc_idct8x8_10(ogg_int16_t _y[64]){
+  __asm{
+#define CONSTS eax
+#define Y edx
+    mov CONSTS,offset OC_IDCT_CONSTS
+    mov Y,_y
+#define OC_I(_k) [Y+_k*16]
+#define OC_J(_k) [Y+(_k-4)*16+8]
+    /*Done with dequant, descramble, and partial transpose.
+      Now do the iDCT itself.*/
+    OC_ROW_IDCT_10
+    OC_TRANSPOSE
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k) [Y+_k*16]
+#define OC_J(_k) OC_I(_k)
+    OC_COLUMN_IDCT_10
+#undef  OC_I
+#undef  OC_J
+#define OC_I(_k) [Y+_k*16+8]
+#define OC_J(_k) OC_I(_k)
+    OC_COLUMN_IDCT_10
+#undef  OC_I
+#undef  OC_J
+#undef  CONSTS
+#undef  Y
+  }
+}
+
+/*Performs an inverse 8x8 Type-II DCT transform.
+  The input is assumed to be scaled by a factor of 4 relative to orthonormal
+   version of the transform.*/
+void oc_idct8x8_mmx(ogg_int16_t _y[64],int _last_zzi){
+  /*_last_zzi is subtly different from an actual count of the number of
+     coefficients we decoded for this block.
+    It contains the value of zzi BEFORE the final token in the block was
+     decoded.
+    In most cases this is an EOB token (the continuation of an EOB run from a
+     previous block counts), and so this is the same as the coefficient count.
+    However, in the case that the last token was NOT an EOB token, but filled
+     the block up with exactly 64 coefficients, _last_zzi will be less than 64.
+    Provided the last token was not a pure zero run, the minimum value it can
+     be is 46, and so that doesn't affect any of the cases in this routine.
+    However, if the last token WAS a pure zero run of length 63, then _last_zzi
+     will be 1 while the number of coefficients decoded is 64.
+    Thus, we will trigger the following special case, where the real
+     coefficient count would not.
+    Note also that a zero run of length 64 will give _last_zzi a value of 0,
+     but we still process the DC coefficient, which might have a non-zero value
+     due to DC prediction.
+    Although convoluted, this is arguably the correct behavior: it allows us to
+     use a smaller transform when the block ends with a long zero run instead
+     of a normal EOB token.
+    It could be smarter... multiple separate zero runs at the end of a block
+     will fool it, but an encoder that generates these really deserves what it
+     gets.
+    Needless to say we inherited this approach from VP3.*/
+  /*Perform the iDCT.*/
+  if(_last_zzi<10)oc_idct8x8_10(_y);
+  else oc_idct8x8_slow(_y);
+}
+
+#endif
diff --git a/lib/x86_vc/mmxloop.h b/lib/x86_vc/mmxloop.h
new file mode 100644 (file)
index 0000000..2561fca
--- /dev/null
@@ -0,0 +1,219 @@
+#if !defined(_x86_vc_mmxloop_H)
+# define _x86_vc_mmxloop_H (1)
+# include <stddef.h>
+# include "x86int.h"
+
+#if defined(OC_X86_ASM)
+
+/*On entry, mm0={a0,...,a7}, mm1={b0,...,b7}, mm2={c0,...,c7}, mm3={d0,...d7}.
+  On exit, mm1={b0+lflim(R_0,L),...,b7+lflim(R_7,L)} and
+   mm2={c0-lflim(R_0,L),...,c7-lflim(R_7,L)}; mm0 and mm3 are clobbered.*/
+#define OC_LOOP_FILTER8_MMX __asm{ \
+  /*mm7=0*/ \
+  __asm pxor mm7,mm7 \
+  /*mm6:mm0={a0,...,a7}*/ \
+  __asm movq mm6,mm0 \
+  __asm punpcklbw mm0,mm7 \
+  __asm punpckhbw mm6,mm7 \
+  /*mm3:mm5={d0,...,d7}*/ \
+  __asm movq mm5,mm3 \
+  __asm punpcklbw mm3,mm7 \
+  __asm punpckhbw mm5,mm7 \
+  /*mm6:mm0={a0-d0,...,a7-d7}*/ \
+  __asm psubw mm0,mm3 \
+  __asm psubw mm6,mm5 \
+  /*mm3:mm1={b0,...,b7}*/ \
+  __asm movq mm3,mm1 \
+  __asm punpcklbw mm1,mm7 \
+  __asm movq mm4,mm2 \
+  __asm punpckhbw mm3,mm7 \
+  /*mm5:mm4={c0,...,c7}*/ \
+  __asm movq mm5,mm2 \
+  __asm punpcklbw mm4,mm7 \
+  __asm punpckhbw mm5,mm7 \
+  /*mm7={3}x4 \
+    mm5:mm4={c0-b0,...,c7-b7}*/ \
+  __asm pcmpeqw mm7,mm7 \
+  __asm psubw mm4,mm1 \
+  __asm psrlw mm7,14 \
+  __asm psubw mm5,mm3 \
+  /*Scale by 3.*/ \
+  __asm pmullw mm4,mm7 \
+  __asm pmullw mm5,mm7 \
+  /*mm7={4}x4 \
+    mm5:mm4=f={a0-d0+3*(c0-b0),...,a7-d7+3*(c7-b7)}*/ \
+  __asm psrlw mm7,1 \
+  __asm paddw mm4,mm0 \
+  __asm psllw mm7,2 \
+  __asm movq mm0,[LL] \
+  __asm paddw mm5,mm6 \
+  /*R_i has the range [-127,128], so we compute -R_i instead. \
+    mm4=-R_i=-(f+4>>3)=0xFF^(f-4>>3)*/ \
+  __asm psubw mm4,mm7 \
+  __asm psubw mm5,mm7 \
+  __asm psraw mm4,3 \
+  __asm psraw mm5,3 \
+  __asm pcmpeqb mm7,mm7 \
+  __asm packsswb mm4,mm5 \
+  __asm pxor mm6,mm6 \
+  __asm pxor mm4,mm7 \
+  __asm packuswb mm1,mm3 \
+  /*Now compute lflim of -mm4 cf. Section 7.10 of the sepc.*/ \
+  /*There's no unsigned byte+signed byte with unsigned saturation op code, so \
+     we have to split things by sign (the other option is to work in 16 bits, \
+     but working in 8 bits gives much better parallelism). \
+    We compute abs(R_i), but save a mask of which terms were negative in mm6. \
+    Then we compute mm4=abs(lflim(R_i,L))=min(abs(R_i),max(2*L-abs(R_i),0)). \
+    Finally, we split mm4 into positive and negative pieces using the mask in \
+     mm6, and add and subtract them as appropriate.*/ \
+  /*mm4=abs(-R_i)*/ \
+  /*mm7=255-2*L*/ \
+  __asm pcmpgtb mm6,mm4 \
+  __asm psubb mm7,mm0 \
+  __asm pxor mm4,mm6 \
+  __asm psubb mm7,mm0 \
+  __asm psubb mm4,mm6 \
+  /*mm7=255-max(2*L-abs(R_i),0)*/ \
+  __asm paddusb mm7,mm4 \
+  /*mm4=min(abs(R_i),max(2*L-abs(R_i),0))*/ \
+  __asm paddusb mm4,mm7 \
+  __asm psubusb mm4,mm7 \
+  /*Now split mm4 by the original sign of -R_i.*/ \
+  __asm movq mm5,mm4 \
+  __asm pand mm4,mm6 \
+  __asm pandn mm6,mm5 \
+  /*mm1={b0+lflim(R_0,L),...,b7+lflim(R_7,L)}*/ \
+  /*mm2={c0-lflim(R_0,L),...,c7-lflim(R_7,L)}*/ \
+  __asm paddusb mm1,mm4 \
+  __asm psubusb mm2,mm4 \
+  __asm psubusb mm1,mm6 \
+  __asm paddusb mm2,mm6 \
+}
+
+#define OC_LOOP_FILTER_V_MMX(_pix,_ystride,_ll) \
+  do{ \
+    /*Used local variable pix__ in order to fix compilation errors like: \
+       "error C2425: 'SHL' : non-constant expression in 'second operand'".*/ \
+    unsigned char *pix__; \
+    unsigned char *ll__; \
+    ll__=(_ll); \
+    pix__=(_pix); \
+    __asm mov YSTRIDE,_ystride \
+    __asm mov LL,ll__ \
+    __asm mov PIX,pix__ \
+    __asm sub PIX,YSTRIDE \
+    __asm sub PIX,YSTRIDE \
+    /*mm0={a0,...,a7}*/ \
+    __asm movq mm0,[PIX] \
+    /*ystride3=_ystride*3*/ \
+    __asm lea YSTRIDE3,[YSTRIDE+YSTRIDE*2] \
+    /*mm3={d0,...,d7}*/ \
+    __asm movq mm3,[PIX+YSTRIDE3] \
+    /*mm1={b0,...,b7}*/ \
+    __asm movq mm1,[PIX+YSTRIDE] \
+    /*mm2={c0,...,c7}*/ \
+    __asm movq mm2,[PIX+YSTRIDE*2] \
+    OC_LOOP_FILTER8_MMX \
+    /*Write it back out.*/ \
+    __asm movq [PIX+YSTRIDE],mm1 \
+    __asm movq [PIX+YSTRIDE*2],mm2 \
+  } \
+  while(0)
+
+#define OC_LOOP_FILTER_H_MMX(_pix,_ystride,_ll) \
+  do{ \
+    /*Used local variable ll__ in order to fix compilation errors like: \
+       "error C2443: operand size conflict".*/ \
+    unsigned char *ll__; \
+    unsigned char *pix__; \
+    ll__=(_ll); \
+    pix__=(_pix)-2; \
+    __asm mov PIX,pix__ \
+    __asm mov YSTRIDE,_ystride \
+    __asm mov LL,ll__ \
+    /*x x x x d0 c0 b0 a0*/ \
+    __asm movd mm0,[PIX] \
+    /*x x x x d1 c1 b1 a1*/ \
+    __asm movd mm1,[PIX+YSTRIDE] \
+    /*ystride3=_ystride*3*/ \
+    __asm lea YSTRIDE3,[YSTRIDE+YSTRIDE*2] \
+    /*x x x x d2 c2 b2 a2*/ \
+    __asm movd mm2,[PIX+YSTRIDE*2] \
+    /*x x x x d3 c3 b3 a3*/ \
+    __asm lea D,[PIX+YSTRIDE*4] \
+    __asm movd mm3,[PIX+YSTRIDE3] \
+    /*x x x x d4 c4 b4 a4*/ \
+    __asm movd mm4,[D] \
+    /*x x x x d5 c5 b5 a5*/ \
+    __asm movd mm5,[D+YSTRIDE] \
+    /*x x x x d6 c6 b6 a6*/ \
+    __asm movd mm6,[D+YSTRIDE*2] \
+    /*x x x x d7 c7 b7 a7*/ \
+    __asm movd mm7,[D+YSTRIDE3] \
+    /*mm0=d1 d0 c1 c0 b1 b0 a1 a0*/ \
+    __asm punpcklbw mm0,mm1 \
+    /*mm2=d3 d2 c3 c2 b3 b2 a3 a2*/ \
+    __asm punpcklbw mm2,mm3 \
+    /*mm3=d1 d0 c1 c0 b1 b0 a1 a0*/ \
+    __asm movq mm3,mm0 \
+    /*mm0=b3 b2 b1 b0 a3 a2 a1 a0*/ \
+    __asm punpcklwd mm0,mm2 \
+    /*mm3=d3 d2 d1 d0 c3 c2 c1 c0*/ \
+    __asm punpckhwd mm3,mm2 \
+    /*mm1=b3 b2 b1 b0 a3 a2 a1 a0*/ \
+    __asm movq mm1,mm0 \
+    /*mm4=d5 d4 c5 c4 b5 b4 a5 a4*/ \
+    __asm punpcklbw mm4,mm5 \
+    /*mm6=d7 d6 c7 c6 b7 b6 a7 a6*/ \
+    __asm punpcklbw mm6,mm7 \
+    /*mm5=d5 d4 c5 c4 b5 b4 a5 a4*/ \
+    __asm movq mm5,mm4 \
+    /*mm4=b7 b6 b5 b4 a7 a6 a5 a4*/ \
+    __asm punpcklwd mm4,mm6 \
+    /*mm5=d7 d6 d5 d4 c7 c6 c5 c4*/ \
+    __asm punpckhwd mm5,mm6 \
+    /*mm2=d3 d2 d1 d0 c3 c2 c1 c0*/ \
+    __asm movq mm2,mm3 \
+    /*mm0=a7 a6 a5 a4 a3 a2 a1 a0*/ \
+    __asm punpckldq mm0,mm4 \
+    /*mm1=b7 b6 b5 b4 b3 b2 b1 b0*/ \
+    __asm punpckhdq mm1,mm4 \
+    /*mm2=c7 c6 c5 c4 c3 c2 c1 c0*/ \
+    __asm punpckldq mm2,mm5 \
+    /*mm3=d7 d6 d5 d4 d3 d2 d1 d0*/ \
+    __asm punpckhdq mm3,mm5 \
+    OC_LOOP_FILTER8_MMX \
+    /*mm2={b0+R_0'',...,b7+R_7''}*/ \
+    __asm movq mm0,mm1 \
+    /*mm1={b0+R_0'',c0-R_0'',...,b3+R_3'',c3-R_3''}*/ \
+    __asm punpcklbw mm1,mm2 \
+    /*mm2={b4+R_4'',c4-R_4'',...,b7+R_7'',c7-R_7''}*/ \
+    __asm punpckhbw mm0,mm2 \
+    /*[d]=c1 b1 c0 b0*/ \
+    __asm movd D,mm1 \
+    __asm mov [PIX+1],D_WORD \
+    __asm psrlq mm1,32 \
+    __asm shr D,16 \
+    __asm mov [PIX+YSTRIDE+1],D_WORD \
+    /*[d]=c3 b3 c2 b2*/ \
+    __asm movd D,mm1 \
+    __asm mov [PIX+YSTRIDE*2+1],D_WORD \
+    __asm shr D,16 \
+    __asm mov [PIX+YSTRIDE3+1],D_WORD \
+    __asm lea PIX,[PIX+YSTRIDE*4] \
+    /*[d]=c5 b5 c4 b4*/ \
+    __asm movd D,mm0 \
+    __asm mov [PIX+1],D_WORD \
+    __asm psrlq mm0,32 \
+    __asm shr D,16 \
+    __asm mov [PIX+YSTRIDE+1],D_WORD \
+    /*[d]=c7 b7 c6 b6*/ \
+    __asm movd D,mm0 \
+    __asm mov [PIX+YSTRIDE*2+1],D_WORD \
+    __asm shr D,16 \
+    __asm mov [PIX+YSTRIDE3+1],D_WORD \
+  } \
+  while(0)
+
+# endif
+#endif
diff --git a/lib/x86_vc/mmxstate.c b/lib/x86_vc/mmxstate.c
new file mode 100644 (file)
index 0000000..73bd198
--- /dev/null
@@ -0,0 +1,211 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: mmxstate.c 16584 2009-09-26 19:35:55Z tterribe $
+
+ ********************************************************************/
+
+/*MMX acceleration of complete fragment reconstruction algorithm.
+  Originally written by Rudolf Marek.*/
+#include <string.h>
+#include "x86int.h"
+#include "mmxfrag.h"
+#include "mmxloop.h"
+
+#if defined(OC_X86_ASM)
+
+void oc_state_frag_recon_mmx(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant){
+  unsigned char *dst;
+  ptrdiff_t      frag_buf_off;
+  int            ystride;
+  int            mb_mode;
+  /*Apply the inverse transform.*/
+  /*Special case only having a DC component.*/
+  if(_last_zzi<2){
+    /*Note that this value must be unsigned, to keep the __asm__ block from
+       sign-extending it when it puts it in a register.*/
+    ogg_uint16_t p;
+    /*We round this dequant product (and not any of the others) because there's
+       no iDCT rounding.*/
+    p=(ogg_int16_t)(_dct_coeffs[0]*(ogg_int32_t)_dc_quant+15>>5);
+    /*Fill _dct_coeffs with p.*/
+    __asm{
+#define Y eax
+#define P ecx
+      mov Y,_dct_coeffs
+      movzx P,p
+      /*mm0=0000 0000 0000 AAAA*/
+      movd mm0,P
+      /*mm0=0000 0000 AAAA AAAA*/
+      punpcklwd mm0,mm0
+      /*mm0=AAAA AAAA AAAA AAAA*/
+      punpckldq mm0,mm0
+      movq [Y],mm0
+      movq [8+Y],mm0
+      movq [16+Y],mm0
+      movq [24+Y],mm0
+      movq [32+Y],mm0
+      movq [40+Y],mm0
+      movq [48+Y],mm0
+      movq [56+Y],mm0
+      movq [64+Y],mm0
+      movq [72+Y],mm0
+      movq [80+Y],mm0
+      movq [88+Y],mm0
+      movq [96+Y],mm0
+      movq [104+Y],mm0
+      movq [112+Y],mm0
+      movq [120+Y],mm0
+#undef Y
+#undef P
+    }
+  }
+  else{
+    /*Dequantize the DC coefficient.*/
+    _dct_coeffs[0]=(ogg_int16_t)(_dct_coeffs[0]*(int)_dc_quant);
+    oc_idct8x8_mmx(_dct_coeffs,_last_zzi);
+  }
+  /*Fill in the target buffer.*/
+  frag_buf_off=_state->frag_buf_offs[_fragi];
+  mb_mode=_state->frags[_fragi].mb_mode;
+  ystride=_state->ref_ystride[_pli];
+  dst=_state->ref_frame_data[_state->ref_frame_idx[OC_FRAME_SELF]]+frag_buf_off;
+  if(mb_mode==OC_MODE_INTRA)oc_frag_recon_intra_mmx(dst,ystride,_dct_coeffs);
+  else{
+    const unsigned char *ref;
+    int                  mvoffsets[2];
+    ref=
+     _state->ref_frame_data[_state->ref_frame_idx[OC_FRAME_FOR_MODE(mb_mode)]]
+     +frag_buf_off;
+    if(oc_state_get_mv_offsets(_state,mvoffsets,_pli,
+     _state->frag_mvs[_fragi][0],_state->frag_mvs[_fragi][1])>1){
+      oc_frag_recon_inter2_mmx(dst,ref+mvoffsets[0],ref+mvoffsets[1],ystride,
+       _dct_coeffs);
+    }
+    else oc_frag_recon_inter_mmx(dst,ref+mvoffsets[0],ystride,_dct_coeffs);
+  }
+}
+
+/*We copy these entire function to inline the actual MMX routines so that we
+   use only a single indirect call.*/
+
+/*Copies the fragments specified by the lists of fragment indices from one
+   frame to another.
+  _fragis:    A pointer to a list of fragment indices.
+  _nfragis:   The number of fragment indices to copy.
+  _dst_frame: The reference frame to copy to.
+  _src_frame: The reference frame to copy from.
+  _pli:       The color plane the fragments lie in.*/
+void oc_state_frag_copy_list_mmx(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli){
+  const ptrdiff_t     *frag_buf_offs;
+  const unsigned char *src_frame_data;
+  unsigned char       *dst_frame_data;
+  ptrdiff_t            fragii;
+  int                  ystride;
+  dst_frame_data=_state->ref_frame_data[_state->ref_frame_idx[_dst_frame]];
+  src_frame_data=_state->ref_frame_data[_state->ref_frame_idx[_src_frame]];
+  ystride=_state->ref_ystride[_pli];
+  frag_buf_offs=_state->frag_buf_offs;
+  for(fragii=0;fragii<_nfragis;fragii++){
+    ptrdiff_t frag_buf_off;
+    frag_buf_off=frag_buf_offs[_fragis[fragii]];
+#define SRC edx
+#define DST eax
+#define YSTRIDE ecx
+#define YSTRIDE3 edi
+    OC_FRAG_COPY_MMX(dst_frame_data+frag_buf_off,
+     src_frame_data+frag_buf_off,ystride);
+#undef SRC
+#undef DST
+#undef YSTRIDE
+#undef YSTRIDE3
+  }
+}
+
+/*Apply the loop filter to a given set of fragment rows in the given plane.
+  The filter may be run on the bottom edge, affecting pixels in the next row of
+   fragments, so this row also needs to be available.
+  _bv:        The bounding values array.
+  _refi:      The index of the frame buffer to filter.
+  _pli:       The color plane to filter.
+  _fragy0:    The Y coordinate of the first fragment row to filter.
+  _fragy_end: The Y coordinate of the fragment row to stop filtering at.*/
+void oc_state_loop_filter_frag_rows_mmx(const oc_theora_state *_state,
+ int _bv[256],int _refi,int _pli,int _fragy0,int _fragy_end){
+  OC_ALIGN8(unsigned char  ll[8]);
+  const oc_fragment_plane *fplane;
+  const oc_fragment       *frags;
+  const ptrdiff_t         *frag_buf_offs;
+  unsigned char           *ref_frame_data;
+  ptrdiff_t                fragi_top;
+  ptrdiff_t                fragi_bot;
+  ptrdiff_t                fragi0;
+  ptrdiff_t                fragi0_end;
+  int                      ystride;
+  int                      nhfrags;
+  memset(ll,_state->loop_filter_limits[_state->qis[0]],sizeof(ll));
+  fplane=_state->fplanes+_pli;
+  nhfrags=fplane->nhfrags;
+  fragi_top=fplane->froffset;
+  fragi_bot=fragi_top+fplane->nfrags;
+  fragi0=fragi_top+_fragy0*(ptrdiff_t)nhfrags;
+  fragi0_end=fragi0+(_fragy_end-_fragy0)*(ptrdiff_t)nhfrags;
+  ystride=_state->ref_ystride[_pli];
+  frags=_state->frags;
+  frag_buf_offs=_state->frag_buf_offs;
+  ref_frame_data=_state->ref_frame_data[_refi];
+  /*The following loops are constructed somewhat non-intuitively on purpose.
+    The main idea is: if a block boundary has at least one coded fragment on
+     it, the filter is applied to it.
+    However, the order that the filters are applied in matters, and VP3 chose
+     the somewhat strange ordering used below.*/
+  while(fragi0<fragi0_end){
+    ptrdiff_t fragi;
+    ptrdiff_t fragi_end;
+    fragi=fragi0;
+    fragi_end=fragi+nhfrags;
+    while(fragi<fragi_end){
+      if(frags[fragi].coded){
+        unsigned char *ref;
+        ref=ref_frame_data+frag_buf_offs[fragi];
+#define PIX eax
+#define YSTRIDE3 edi
+#define YSTRIDE ecx
+#define LL edx
+#define D esi
+#define D_WORD si
+        if(fragi>fragi0)OC_LOOP_FILTER_H_MMX(ref,ystride,ll);
+        if(fragi0>fragi_top)OC_LOOP_FILTER_V_MMX(ref,ystride,ll);
+        if(fragi+1<fragi_end&&!frags[fragi+1].coded){
+          OC_LOOP_FILTER_H_MMX(ref+8,ystride,ll);
+        }
+        if(fragi+nhfrags<fragi_bot&&!frags[fragi+nhfrags].coded){
+          OC_LOOP_FILTER_V_MMX(ref+(ystride<<3),ystride,ll);
+        }
+#undef PIX
+#undef YSTRIDE3
+#undef YSTRIDE
+#undef LL
+#undef D
+#undef D_WORD
+      }
+      fragi++;
+    }
+    fragi0+=nhfrags;
+  }
+}
+
+#endif
diff --git a/lib/x86_vc/x86enc.c b/lib/x86_vc/x86enc.c
new file mode 100644 (file)
index 0000000..e1960e1
--- /dev/null
@@ -0,0 +1,49 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86state.c 15675 2009-02-06 09:43:27Z tterribe $
+
+ ********************************************************************/
+#include "x86enc.h"
+
+#if defined(OC_X86_ASM)
+
+#include "../cpu.c"
+
+void oc_enc_vtable_init_x86(oc_enc_ctx *_enc){
+  ogg_uint32_t cpu_flags;
+  cpu_flags=oc_cpu_flags_get();
+  oc_enc_vtable_init_c(_enc);
+  if(cpu_flags&OC_CPU_X86_MMX){
+    _enc->opt_vtable.frag_sub=oc_enc_frag_sub_mmx;
+    _enc->opt_vtable.frag_sub_128=oc_enc_frag_sub_128_mmx;
+    _enc->opt_vtable.frag_recon_intra=oc_frag_recon_intra_mmx;
+    _enc->opt_vtable.frag_recon_inter=oc_frag_recon_inter_mmx;
+    _enc->opt_vtable.fdct8x8=oc_enc_fdct8x8_mmx;
+  }
+  if(cpu_flags&OC_CPU_X86_MMXEXT){
+    _enc->opt_vtable.frag_sad=oc_enc_frag_sad_mmxext;
+    _enc->opt_vtable.frag_sad_thresh=oc_enc_frag_sad_thresh_mmxext;
+    _enc->opt_vtable.frag_sad2_thresh=oc_enc_frag_sad2_thresh_mmxext;
+    _enc->opt_vtable.frag_satd_thresh=oc_enc_frag_satd_thresh_mmxext;
+    _enc->opt_vtable.frag_satd2_thresh=oc_enc_frag_satd2_thresh_mmxext;
+    _enc->opt_vtable.frag_intra_satd=oc_enc_frag_intra_satd_mmxext;
+    _enc->opt_vtable.frag_copy2=oc_enc_frag_copy2_mmxext;
+  }
+  if(cpu_flags&OC_CPU_X86_SSE2){
+# if defined(OC_X86_64_ASM)
+    _enc->opt_vtable.fdct8x8=oc_enc_fdct8x8_x86_64sse2;
+# endif
+  }
+}
+#endif
diff --git a/lib/x86_vc/x86enc.h b/lib/x86_vc/x86enc.h
new file mode 100644 (file)
index 0000000..5814846
--- /dev/null
@@ -0,0 +1,47 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86int.h 15675 2009-02-06 09:43:27Z tterribe $
+
+ ********************************************************************/
+
+#if !defined(_x86_vc_x86enc_H)
+# define _x86_vc_x86enc_H (1)
+# include "../encint.h"
+# include "x86int.h"
+
+void oc_enc_vtable_init_x86(oc_enc_ctx *_enc);
+
+unsigned oc_enc_frag_sad_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride);
+unsigned oc_enc_frag_sad_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_sad2_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_satd_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref,int _ystride,unsigned _thresh);
+unsigned oc_enc_frag_satd2_thresh_mmxext(const unsigned char *_src,
+ const unsigned char *_ref1,const unsigned char *_ref2,int _ystride,
+ unsigned _thresh);
+unsigned oc_enc_frag_intra_satd_mmxext(const unsigned char *_src,int _ystride);
+void oc_enc_frag_sub_mmx(ogg_int16_t _diff[64],
+ const unsigned char *_x,const unsigned char *_y,int _stride);
+void oc_enc_frag_sub_128_mmx(ogg_int16_t _diff[64],
+ const unsigned char *_x,int _stride);
+void oc_enc_frag_copy2_mmxext(unsigned char *_dst,
+ const unsigned char *_src1,const unsigned char *_src2,int _ystride);
+void oc_enc_fdct8x8_mmx(ogg_int16_t _y[64],const ogg_int16_t _x[64]);
+void oc_enc_fdct8x8_x86_64sse2(ogg_int16_t _y[64],const ogg_int16_t _x[64]);
+
+#endif
diff --git a/lib/x86_vc/x86int.h b/lib/x86_vc/x86int.h
new file mode 100644 (file)
index 0000000..4cca485
--- /dev/null
@@ -0,0 +1,42 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86int.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#if !defined(_x86_vc_x86int_H)
+# define _x86_vc_x86int_H (1)
+# include "../internal.h"
+
+void oc_state_vtable_init_x86(oc_theora_state *_state);
+
+void oc_frag_copy_mmx(unsigned char *_dst,
+ const unsigned char *_src,int _ystride);
+void oc_frag_recon_intra_mmx(unsigned char *_dst,int _ystride,
+ const ogg_int16_t *_residue);
+void oc_frag_recon_inter_mmx(unsigned char *_dst,
+ const unsigned char *_src,int _ystride,const ogg_int16_t *_residue);
+void oc_frag_recon_inter2_mmx(unsigned char *_dst,const unsigned char *_src1,
+ const unsigned char *_src2,int _ystride,const ogg_int16_t *_residue);
+void oc_idct8x8_mmx(ogg_int16_t _y[64],int _last_zzi);
+void oc_state_frag_recon_mmx(const oc_theora_state *_state,ptrdiff_t _fragi,
+ int _pli,ogg_int16_t _dct_coeffs[64],int _last_zzi,ogg_uint16_t _dc_quant);
+void oc_state_frag_copy_list_mmx(const oc_theora_state *_state,
+ const ptrdiff_t *_fragis,ptrdiff_t _nfragis,
+ int _dst_frame,int _src_frame,int _pli);
+void oc_state_loop_filter_frag_rows_mmx(const oc_theora_state *_state,
+ int _bv[256],int _refi,int _pli,int _fragy0,int _fragy_end);
+void oc_restore_fpu_mmx(void);
+
+#endif
diff --git a/lib/x86_vc/x86state.c b/lib/x86_vc/x86state.c
new file mode 100644 (file)
index 0000000..a786bec
--- /dev/null
@@ -0,0 +1,62 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
+ *                                                                  *
+ ********************************************************************
+
+  function:
+    last mod: $Id: x86state.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include "x86int.h"
+
+#if defined(OC_X86_ASM)
+
+#include "../cpu.c"
+
+/*This table has been modified from OC_FZIG_ZAG by baking a 4x4 transpose into
+   each quadrant of the destination.*/
+static const unsigned char OC_FZIG_ZAG_MMX[128]={
+   0, 8, 1, 2, 9,16,24,17,
+  10, 3,32,11,18,25, 4,12,
+   5,26,19,40,33,34,41,48,
+  27, 6,13,20,28,21,14, 7,
+  56,49,42,35,43,50,57,36,
+  15,22,29,30,23,44,37,58,
+  51,59,38,45,52,31,60,53,
+  46,39,47,54,61,62,55,63,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+  64,64,64,64,64,64,64,64,
+};
+
+void oc_state_vtable_init_x86(oc_theora_state *_state){
+  _state->cpu_flags=oc_cpu_flags_get();
+  if(_state->cpu_flags&OC_CPU_X86_MMX){
+    _state->opt_vtable.frag_copy=oc_frag_copy_mmx;
+    _state->opt_vtable.frag_recon_intra=oc_frag_recon_intra_mmx;
+    _state->opt_vtable.frag_recon_inter=oc_frag_recon_inter_mmx;
+    _state->opt_vtable.frag_recon_inter2=oc_frag_recon_inter2_mmx;
+    _state->opt_vtable.idct8x8=oc_idct8x8_mmx;
+    _state->opt_vtable.state_frag_recon=oc_state_frag_recon_mmx;
+    _state->opt_vtable.state_frag_copy_list=oc_state_frag_copy_list_mmx;
+    _state->opt_vtable.state_loop_filter_frag_rows=
+     oc_state_loop_filter_frag_rows_mmx;
+    _state->opt_vtable.restore_fpu=oc_restore_fpu_mmx;
+    _state->opt_data.dct_fzig_zag=OC_FZIG_ZAG_MMX;
+  }
+  else oc_state_vtable_init_c(_state);
+}
+#endif
diff --git a/libtheora.spec.in b/libtheora.spec.in
new file mode 100644 (file)
index 0000000..ce9345e
--- /dev/null
@@ -0,0 +1,82 @@
+Name:          libtheora
+Version:       @VERSION@
+Release:       0.xiph.0.4.alpha5
+Summary:       The Theora Video Compression Codec.
+
+Group:         System Environment/Libraries
+License:       BSD
+URL:           http://www.theora.org/
+Vendor:                Xiph.org Foundation <team@xiph.org>
+Source:                http://downloads.xiph.org/releases/theora/%{name}-%{version}.tar.gz
+BuildRoot:     %{_tmppath}/%{name}-%{version}-root
+
+BuildRequires: libogg-devel >= 2:1.1
+BuildRequires: libvorbis-devel >= 1:1.0.1
+BuildRequires: SDL-devel
+
+# this needs to be explicit since vorbis's .so versioning didn't get bumped
+# when going from 1.0 to 1.0.1
+Requires:       libvorbis >= 1:1.0.1
+
+%description
+Theora is Xiph.Org's first publicly released video codec, intended
+for use within the Ogg's project's Ogg multimedia streaming system.
+Theora is derived directly from On2's VP3 codec; Currently the two are
+nearly identical, varying only in encapsulating decoder tables in the
+bitstream headers, but Theora will make use of this extra freedom
+in the future to improve over what is possible with VP3.
+
+%package devel
+Summary:        Development tools for Theora applications.
+Group:          Development/Libraries
+Requires:       %{name} = %{version}-%{release}
+Requires:       libogg-devel >= 2:1.1
+
+%description devel
+The libtheora-devel package contains the header files and documentation
+needed to develop applications with Ogg Theora.
+
+%prep
+%setup -q -n %{name}-%{version}
+
+%build
+%configure --enable-shared
+make
+
+%install
+rm -rf $RPM_BUILD_ROOT
+# make sure our temp doc build dir is removed
+rm -rf $(pwd)/__docs
+
+%makeinstall docdir=$(pwd)/__docs
+
+find $RPM_BUILD_ROOT -type f -name "*.la" -exec rm -f {} ';'
+
+%clean 
+rm -rf $RPM_BUILD_ROOT
+
+%post -p /sbin/ldconfig
+
+%postun -p /sbin/ldconfig
+
+%files
+%defattr(-,root,root)
+%doc COPYING README
+%{_libdir}/libtheora.so.*
+
+%files devel
+%defattr(-,root,root,-)
+%doc __docs/*
+%{_libdir}/libtheora.a
+%{_libdir}/libtheora.so
+%dir %{_includedir}/theora
+%{_includedir}/theora/codec.h
+%{_includedir}/theora/theora.h
+%{_includedir}/theora/theoradec.h
+%{_libdir}/pkgconfig/theora.pc
+
+%changelog
+* Sat Aug 20 2005 Ralph Giles <giles at xiph.org>
+- updated version for 1.0alpha5 release
+* Thu Jun 10 2004 Thomas Vander Stichele <thomas at apestaart dot org>
+- transported fedora.us spec file
diff --git a/ltmain.sh b/ltmain.sh
new file mode 100755 (executable)
index 0000000..6939dcc
--- /dev/null
+++ b/ltmain.sh
@@ -0,0 +1,8406 @@
+# Generated from ltmain.m4sh.
+
+# ltmain.sh (GNU libtool) 2.2.6
+# Written by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
+
+# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006, 2007 2008 Free Software Foundation, Inc.
+# This is free software; see the source for copying conditions.  There is NO
+# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+# GNU Libtool 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.
+#
+# As a special exception to the GNU General Public License,
+# if you distribute this file as part of a program or library that
+# is built using GNU Libtool, you may include this file under the
+# same distribution terms that you use for the rest of that program.
+#
+# GNU Libtool 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 GNU Libtool; see the file COPYING.  If not, a copy
+# can be downloaded from http://www.gnu.org/licenses/gpl.html,
+# or obtained by writing to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+
+# Usage: $progname [OPTION]... [MODE-ARG]...
+#
+# Provide generalized library-building support services.
+#
+#     --config             show all configuration variables
+#     --debug              enable verbose shell tracing
+# -n, --dry-run            display commands without modifying any files
+#     --features           display basic configuration information and exit
+#     --mode=MODE          use operation mode MODE
+#     --preserve-dup-deps  don't remove duplicate dependency libraries
+#     --quiet, --silent    don't print informational messages
+#     --tag=TAG            use configuration variables from tag TAG
+# -v, --verbose            print informational messages (default)
+#     --version            print version information
+# -h, --help               print short or long help message
+#
+# MODE must be one of the following:
+#
+#       clean              remove files from the build directory
+#       compile            compile a source file into a libtool object
+#       execute            automatically set library path, then run a program
+#       finish             complete the installation of libtool libraries
+#       install            install libraries or executables
+#       link               create a library or an executable
+#       uninstall          remove libraries from an installed directory
+#
+# MODE-ARGS vary depending on the MODE.
+# Try `$progname --help --mode=MODE' for a more detailed description of MODE.
+#
+# When reporting a bug, please describe a test case to reproduce it and
+# include the following information:
+#
+#       host-triplet:  $host
+#       shell:         $SHELL
+#       compiler:              $LTCC
+#       compiler flags:                $LTCFLAGS
+#       linker:                $LD (gnu? $with_gnu_ld)
+#       $progname:             (GNU libtool) 2.2.6
+#       automake:              $automake_version
+#       autoconf:              $autoconf_version
+#
+# Report bugs to <bug-libtool@gnu.org>.
+
+PROGRAM=ltmain.sh
+PACKAGE=libtool
+VERSION=2.2.6
+TIMESTAMP=""
+package_revision=1.3012
+
+# Be Bourne compatible
+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
+  emulate sh
+  NULLCMD=:
+  # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which
+  # is contrary to our usage.  Disable this feature.
+  alias -g '${1+"$@"}'='"$@"'
+  setopt NO_GLOB_SUBST
+else
+  case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac
+fi
+BIN_SH=xpg4; export BIN_SH # for Tru64
+DUALCASE=1; export DUALCASE # for MKS sh
+
+# NLS nuisances: We save the old values to restore during execute mode.
+# Only set LANG and LC_ALL to C if already set.
+# These must not be set unconditionally because not all systems understand
+# e.g. LANG=C (notably SCO).
+lt_user_locale=
+lt_safe_locale=
+for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
+do
+  eval "if test \"\${$lt_var+set}\" = set; then
+          save_$lt_var=\$$lt_var
+          $lt_var=C
+         export $lt_var
+         lt_user_locale=\"$lt_var=\\\$save_\$lt_var; \$lt_user_locale\"
+         lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\"
+       fi"
+done
+
+$lt_unset CDPATH
+
+
+
+
+
+: ${CP="cp -f"}
+: ${ECHO="echo"}
+: ${EGREP="/bin/grep -E"}
+: ${FGREP="/bin/grep -F"}
+: ${GREP="/bin/grep"}
+: ${LN_S="ln -s"}
+: ${MAKE="make"}
+: ${MKDIR="mkdir"}
+: ${MV="mv -f"}
+: ${RM="rm -f"}
+: ${SED="/bin/sed"}
+: ${SHELL="${CONFIG_SHELL-/bin/sh}"}
+: ${Xsed="$SED -e 1s/^X//"}
+
+# Global variables:
+EXIT_SUCCESS=0
+EXIT_FAILURE=1
+EXIT_MISMATCH=63  # $? = 63 is used to indicate version mismatch to missing.
+EXIT_SKIP=77     # $? = 77 is used to indicate a skipped test to automake.
+
+exit_status=$EXIT_SUCCESS
+
+# Make sure IFS has a sensible default
+lt_nl='
+'
+IFS="  $lt_nl"
+
+dirname="s,/[^/]*$,,"
+basename="s,^.*/,,"
+
+# func_dirname_and_basename file append nondir_replacement
+# perform func_basename and func_dirname in a single function
+# call:
+#   dirname:  Compute the dirname of FILE.  If nonempty,
+#             add APPEND to the result, otherwise set result
+#             to NONDIR_REPLACEMENT.
+#             value returned in "$func_dirname_result"
+#   basename: Compute filename of FILE.
+#             value retuned in "$func_basename_result"
+# Implementation must be kept synchronized with func_dirname
+# and func_basename. For efficiency, we do not delegate to
+# those functions but instead duplicate the functionality here.
+func_dirname_and_basename ()
+{
+  # Extract subdirectory from the argument.
+  func_dirname_result=`$ECHO "X${1}" | $Xsed -e "$dirname"`
+  if test "X$func_dirname_result" = "X${1}"; then
+    func_dirname_result="${3}"
+  else
+    func_dirname_result="$func_dirname_result${2}"
+  fi
+  func_basename_result=`$ECHO "X${1}" | $Xsed -e "$basename"`
+}
+
+# Generated shell functions inserted here.
+
+# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
+# is ksh but when the shell is invoked as "sh" and the current value of
+# the _XPG environment variable is not equal to 1 (one), the special
+# positional parameter $0, within a function call, is the name of the
+# function.
+progpath="$0"
+
+# The name of this program:
+# In the unlikely event $progname began with a '-', it would play havoc with
+# func_echo (imagine progname=-n), so we prepend ./ in that case:
+func_dirname_and_basename "$progpath"
+progname=$func_basename_result
+case $progname in
+  -*) progname=./$progname ;;
+esac
+
+# Make sure we have an absolute path for reexecution:
+case $progpath in
+  [\\/]*|[A-Za-z]:\\*) ;;
+  *[\\/]*)
+     progdir=$func_dirname_result
+     progdir=`cd "$progdir" && pwd`
+     progpath="$progdir/$progname"
+     ;;
+  *)
+     save_IFS="$IFS"
+     IFS=:
+     for progdir in $PATH; do
+       IFS="$save_IFS"
+       test -x "$progdir/$progname" && break
+     done
+     IFS="$save_IFS"
+     test -n "$progdir" || progdir=`pwd`
+     progpath="$progdir/$progname"
+     ;;
+esac
+
+# Sed substitution that helps us do robust quoting.  It backslashifies
+# metacharacters that are still active within double-quoted strings.
+Xsed="${SED}"' -e 1s/^X//'
+sed_quote_subst='s/\([`"$\\]\)/\\\1/g'
+
+# Same as above, but do not quote variable references.
+double_quote_subst='s/\(["`\\]\)/\\\1/g'
+
+# Re-`\' parameter expansions in output of double_quote_subst that were
+# `\'-ed in input to the same.  If an odd number of `\' preceded a '$'
+# in input to double_quote_subst, that '$' was protected from expansion.
+# Since each input `\' is now two `\'s, look for any number of runs of
+# four `\'s followed by two `\'s and then a '$'.  `\' that '$'.
+bs='\\'
+bs2='\\\\'
+bs4='\\\\\\\\'
+dollar='\$'
+sed_double_backslash="\
+  s/$bs4/&\\
+/g
+  s/^$bs2$dollar/$bs&/
+  s/\\([^$bs]\\)$bs2$dollar/\\1$bs2$bs$dollar/g
+  s/\n//g"
+
+# Standard options:
+opt_dry_run=false
+opt_help=false
+opt_quiet=false
+opt_verbose=false
+opt_warning=:
+
+# func_echo arg...
+# Echo program name prefixed message, along with the current mode
+# name if it has been set yet.
+func_echo ()
+{
+    $ECHO "$progname${mode+: }$mode: $*"
+}
+
+# func_verbose arg...
+# Echo program name prefixed message in verbose mode only.
+func_verbose ()
+{
+    $opt_verbose && func_echo ${1+"$@"}
+
+    # A bug in bash halts the script if the last line of a function
+    # fails when set -e is in force, so we need another command to
+    # work around that:
+    :
+}
+
+# func_error arg...
+# Echo program name prefixed message to standard error.
+func_error ()
+{
+    $ECHO "$progname${mode+: }$mode: "${1+"$@"} 1>&2
+}
+
+# func_warning arg...
+# Echo program name prefixed warning message to standard error.
+func_warning ()
+{
+    $opt_warning && $ECHO "$progname${mode+: }$mode: warning: "${1+"$@"} 1>&2
+
+    # bash bug again:
+    :
+}
+
+# func_fatal_error arg...
+# Echo program name prefixed message to standard error, and exit.
+func_fatal_error ()
+{
+    func_error ${1+"$@"}
+    exit $EXIT_FAILURE
+}
+
+# func_fatal_help arg...
+# Echo program name prefixed message to standard error, followed by
+# a help hint, and exit.
+func_fatal_help ()
+{
+    func_error ${1+"$@"}
+    func_fatal_error "$help"
+}
+help="Try \`$progname --help' for more information."  ## default
+
+
+# func_grep expression filename
+# Check whether EXPRESSION matches any line of FILENAME, without output.
+func_grep ()
+{
+    $GREP "$1" "$2" >/dev/null 2>&1
+}
+
+
+# func_mkdir_p directory-path
+# Make sure the entire path to DIRECTORY-PATH is available.
+func_mkdir_p ()
+{
+    my_directory_path="$1"
+    my_dir_list=
+
+    if test -n "$my_directory_path" && test "$opt_dry_run" != ":"; then
+
+      # Protect directory names starting with `-'
+      case $my_directory_path in
+        -*) my_directory_path="./$my_directory_path" ;;
+      esac
+
+      # While some portion of DIR does not yet exist...
+      while test ! -d "$my_directory_path"; do
+        # ...make a list in topmost first order.  Use a colon delimited
+       # list incase some portion of path contains whitespace.
+        my_dir_list="$my_directory_path:$my_dir_list"
+
+        # If the last portion added has no slash in it, the list is done
+        case $my_directory_path in */*) ;; *) break ;; esac
+
+        # ...otherwise throw away the child directory and loop
+        my_directory_path=`$ECHO "X$my_directory_path" | $Xsed -e "$dirname"`
+      done
+      my_dir_list=`$ECHO "X$my_dir_list" | $Xsed -e 's,:*$,,'`
+
+      save_mkdir_p_IFS="$IFS"; IFS=':'
+      for my_dir in $my_dir_list; do
+       IFS="$save_mkdir_p_IFS"
+        # mkdir can fail with a `File exist' error if two processes
+        # try to create one of the directories concurrently.  Don't
+        # stop in that case!
+        $MKDIR "$my_dir" 2>/dev/null || :
+      done
+      IFS="$save_mkdir_p_IFS"
+
+      # Bail out if we (or some other process) failed to create a directory.
+      test -d "$my_directory_path" || \
+        func_fatal_error "Failed to create \`$1'"
+    fi
+}
+
+
+# func_mktempdir [string]
+# Make a temporary directory that won't clash with other running
+# libtool processes, and avoids race conditions if possible.  If
+# given, STRING is the basename for that directory.
+func_mktempdir ()
+{
+    my_template="${TMPDIR-/tmp}/${1-$progname}"
+
+    if test "$opt_dry_run" = ":"; then
+      # Return a directory name, but don't create it in dry-run mode
+      my_tmpdir="${my_template}-$$"
+    else
+
+      # If mktemp works, use that first and foremost
+      my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null`
+
+      if test ! -d "$my_tmpdir"; then
+        # Failing that, at least try and use $RANDOM to avoid a race
+        my_tmpdir="${my_template}-${RANDOM-0}$$"
+
+        save_mktempdir_umask=`umask`
+        umask 0077
+        $MKDIR "$my_tmpdir"
+        umask $save_mktempdir_umask
+      fi
+
+      # If we're not in dry-run mode, bomb out on failure
+      test -d "$my_tmpdir" || \
+        func_fatal_error "cannot create temporary directory \`$my_tmpdir'"
+    fi
+
+    $ECHO "X$my_tmpdir" | $Xsed
+}
+
+
+# func_quote_for_eval arg
+# Aesthetically quote ARG to be evaled later.
+# This function returns two values: FUNC_QUOTE_FOR_EVAL_RESULT
+# is double-quoted, suitable for a subsequent eval, whereas
+# FUNC_QUOTE_FOR_EVAL_UNQUOTED_RESULT has merely all characters
+# which are still active within double quotes backslashified.
+func_quote_for_eval ()
+{
+    case $1 in
+      *[\\\`\"\$]*)
+       func_quote_for_eval_unquoted_result=`$ECHO "X$1" | $Xsed -e "$sed_quote_subst"` ;;
+      *)
+        func_quote_for_eval_unquoted_result="$1" ;;
+    esac
+
+    case $func_quote_for_eval_unquoted_result in
+      # Double-quote args containing shell metacharacters to delay
+      # word splitting, command substitution and and variable
+      # expansion for a subsequent eval.
+      # Many Bourne shells cannot handle close brackets correctly
+      # in scan sets, so we specify it separately.
+      *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \    ]*|*]*|"")
+        func_quote_for_eval_result="\"$func_quote_for_eval_unquoted_result\""
+        ;;
+      *)
+        func_quote_for_eval_result="$func_quote_for_eval_unquoted_result"
+    esac
+}
+
+
+# func_quote_for_expand arg
+# Aesthetically quote ARG to be evaled later; same as above,
+# but do not quote variable references.
+func_quote_for_expand ()
+{
+    case $1 in
+      *[\\\`\"]*)
+       my_arg=`$ECHO "X$1" | $Xsed \
+           -e "$double_quote_subst" -e "$sed_double_backslash"` ;;
+      *)
+        my_arg="$1" ;;
+    esac
+
+    case $my_arg in
+      # Double-quote args containing shell metacharacters to delay
+      # word splitting and command substitution for a subsequent eval.
+      # Many Bourne shells cannot handle close brackets correctly
+      # in scan sets, so we specify it separately.
+      *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \    ]*|*]*|"")
+        my_arg="\"$my_arg\""
+        ;;
+    esac
+
+    func_quote_for_expand_result="$my_arg"
+}
+
+
+# func_show_eval cmd [fail_exp]
+# Unless opt_silent is true, then output CMD.  Then, if opt_dryrun is
+# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
+# is given, then evaluate it.
+func_show_eval ()
+{
+    my_cmd="$1"
+    my_fail_exp="${2-:}"
+
+    ${opt_silent-false} || {
+      func_quote_for_expand "$my_cmd"
+      eval "func_echo $func_quote_for_expand_result"
+    }
+
+    if ${opt_dry_run-false}; then :; else
+      eval "$my_cmd"
+      my_status=$?
+      if test "$my_status" -eq 0; then :; else
+       eval "(exit $my_status); $my_fail_exp"
+      fi
+    fi
+}
+
+
+# func_show_eval_locale cmd [fail_exp]
+# Unless opt_silent is true, then output CMD.  Then, if opt_dryrun is
+# not true, evaluate CMD.  If the evaluation of CMD fails, and FAIL_EXP
+# is given, then evaluate it.  Use the saved locale for evaluation.
+func_show_eval_locale ()
+{
+    my_cmd="$1"
+    my_fail_exp="${2-:}"
+
+    ${opt_silent-false} || {
+      func_quote_for_expand "$my_cmd"
+      eval "func_echo $func_quote_for_expand_result"
+    }
+
+    if ${opt_dry_run-false}; then :; else
+      eval "$lt_user_locale
+           $my_cmd"
+      my_status=$?
+      eval "$lt_safe_locale"
+      if test "$my_status" -eq 0; then :; else
+       eval "(exit $my_status); $my_fail_exp"
+      fi
+    fi
+}
+
+
+
+
+
+# func_version
+# Echo version message to standard output and exit.
+func_version ()
+{
+    $SED -n '/^# '$PROGRAM' (GNU /,/# warranty; / {
+        s/^# //
+       s/^# *$//
+        s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/
+        p
+     }' < "$progpath"
+     exit $?
+}
+
+# func_usage
+# Echo short help message to standard output and exit.
+func_usage ()
+{
+    $SED -n '/^# Usage:/,/# -h/ {
+        s/^# //
+       s/^# *$//
+       s/\$progname/'$progname'/
+       p
+    }' < "$progpath"
+    $ECHO
+    $ECHO "run \`$progname --help | more' for full usage"
+    exit $?
+}
+
+# func_help
+# Echo long help message to standard output and exit.
+func_help ()
+{
+    $SED -n '/^# Usage:/,/# Report bugs to/ {
+        s/^# //
+       s/^# *$//
+       s*\$progname*'$progname'*
+       s*\$host*'"$host"'*
+       s*\$SHELL*'"$SHELL"'*
+       s*\$LTCC*'"$LTCC"'*
+       s*\$LTCFLAGS*'"$LTCFLAGS"'*
+       s*\$LD*'"$LD"'*
+       s/\$with_gnu_ld/'"$with_gnu_ld"'/
+       s/\$automake_version/'"`(automake --version) 2>/dev/null |$SED 1q`"'/
+       s/\$autoconf_version/'"`(autoconf --version) 2>/dev/null |$SED 1q`"'/
+       p
+     }' < "$progpath"
+    exit $?
+}
+
+# func_missing_arg argname
+# Echo program name prefixed message to standard error and set global
+# exit_cmd.
+func_missing_arg ()
+{
+    func_error "missing argument for $1"
+    exit_cmd=exit
+}
+
+exit_cmd=:
+
+
+
+
+
+# Check that we have a working $ECHO.
+if test "X$1" = X--no-reexec; then
+  # Discard the --no-reexec flag, and continue.
+  shift
+elif test "X$1" = X--fallback-echo; then
+  # Avoid inline document here, it may be left over
+  :
+elif test "X`{ $ECHO '\t'; } 2>/dev/null`" = 'X\t'; then
+  # Yippee, $ECHO works!
+  :
+else
+  # Restart under the correct shell, and then maybe $ECHO will work.
+  exec $SHELL "$progpath" --no-reexec ${1+"$@"}
+fi
+
+if test "X$1" = X--fallback-echo; then
+  # used as fallback echo
+  shift
+  cat <<EOF
+$*
+EOF
+  exit $EXIT_SUCCESS
+fi
+
+magic="%%%MAGIC variable%%%"
+magic_exe="%%%MAGIC EXE variable%%%"
+
+# Global variables.
+# $mode is unset
+nonopt=
+execute_dlfiles=
+preserve_args=
+lo2o="s/\\.lo\$/.${objext}/"
+o2lo="s/\\.${objext}\$/.lo/"
+extracted_archives=
+extracted_serial=0
+
+opt_dry_run=false
+opt_duplicate_deps=false
+opt_silent=false
+opt_debug=:
+
+# If this variable is set in any of the actions, the command in it
+# will be execed at the end.  This prevents here-documents from being
+# left over by shells.
+exec_cmd=
+
+# func_fatal_configuration arg...
+# Echo program name prefixed message to standard error, followed by
+# a configuration failure hint, and exit.
+func_fatal_configuration ()
+{
+    func_error ${1+"$@"}
+    func_error "See the $PACKAGE documentation for more information."
+    func_fatal_error "Fatal configuration error."
+}
+
+
+# func_config
+# Display the configuration for all the tags in this script.
+func_config ()
+{
+    re_begincf='^# ### BEGIN LIBTOOL'
+    re_endcf='^# ### END LIBTOOL'
+
+    # Default configuration.
+    $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath"
+
+    # Now print the configurations for the tags.
+    for tagname in $taglist; do
+      $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath"
+    done
+
+    exit $?
+}
+
+# func_features
+# Display the features supported by this script.
+func_features ()
+{
+    $ECHO "host: $host"
+    if test "$build_libtool_libs" = yes; then
+      $ECHO "enable shared libraries"
+    else
+      $ECHO "disable shared libraries"
+    fi
+    if test "$build_old_libs" = yes; then
+      $ECHO "enable static libraries"
+    else
+      $ECHO "disable static libraries"
+    fi
+
+    exit $?
+}
+
+# func_enable_tag tagname
+# Verify that TAGNAME is valid, and either flag an error and exit, or
+# enable the TAGNAME tag.  We also add TAGNAME to the global $taglist
+# variable here.
+func_enable_tag ()
+{
+  # Global variable:
+  tagname="$1"
+
+  re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
+  re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
+  sed_extractcf="/$re_begincf/,/$re_endcf/p"
+
+  # Validate tagname.
+  case $tagname in
+    *[!-_A-Za-z0-9,/]*)
+      func_fatal_error "invalid tag name: $tagname"
+      ;;
+  esac
+
+  # Don't test for the "default" C tag, as we know it's
+  # there but not specially marked.
+  case $tagname in
+    CC) ;;
+    *)
+      if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
+       taglist="$taglist $tagname"
+
+       # Evaluate the configuration.  Be careful to quote the path
+       # and the sed script, to avoid splitting on whitespace, but
+       # also don't use non-portable quotes within backquotes within
+       # quotes we have to do it in 2 steps:
+       extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
+       eval "$extractedcf"
+      else
+       func_error "ignoring unknown tag $tagname"
+      fi
+      ;;
+  esac
+}
+
+# Parse options once, thoroughly.  This comes as soon as possible in
+# the script to make things like `libtool --version' happen quickly.
+{
+
+  # Shorthand for --mode=foo, only valid as the first argument
+  case $1 in
+  clean|clea|cle|cl)
+    shift; set dummy --mode clean ${1+"$@"}; shift
+    ;;
+  compile|compil|compi|comp|com|co|c)
+    shift; set dummy --mode compile ${1+"$@"}; shift
+    ;;
+  execute|execut|execu|exec|exe|ex|e)
+    shift; set dummy --mode execute ${1+"$@"}; shift
+    ;;
+  finish|finis|fini|fin|fi|f)
+    shift; set dummy --mode finish ${1+"$@"}; shift
+    ;;
+  install|instal|insta|inst|ins|in|i)
+    shift; set dummy --mode install ${1+"$@"}; shift
+    ;;
+  link|lin|li|l)
+    shift; set dummy --mode link ${1+"$@"}; shift
+    ;;
+  uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
+    shift; set dummy --mode uninstall ${1+"$@"}; shift
+    ;;
+  esac
+
+  # Parse non-mode specific arguments:
+  while test "$#" -gt 0; do
+    opt="$1"
+    shift
+
+    case $opt in
+      --config)                func_config                                     ;;
+
+      --debug)         preserve_args="$preserve_args $opt"
+                       func_echo "enabling shell trace mode"
+                       opt_debug='set -x'
+                       $opt_debug
+                       ;;
+
+      -dlopen)         test "$#" -eq 0 && func_missing_arg "$opt" && break
+                       execute_dlfiles="$execute_dlfiles $1"
+                       shift
+                       ;;
+
+      --dry-run | -n)  opt_dry_run=:                                   ;;
+      --features)       func_features                                  ;;
+      --finish)                mode="finish"                                   ;;
+
+      --mode)          test "$#" -eq 0 && func_missing_arg "$opt" && break
+                       case $1 in
+                         # Valid mode arguments:
+                         clean)        ;;
+                         compile)      ;;
+                         execute)      ;;
+                         finish)       ;;
+                         install)      ;;
+                         link)         ;;
+                         relink)       ;;
+                         uninstall)    ;;
+
+                         # Catch anything else as an error
+                         *) func_error "invalid argument for $opt"
+                            exit_cmd=exit
+                            break
+                            ;;
+                       esac
+
+                       mode="$1"
+                       shift
+                       ;;
+
+      --preserve-dup-deps)
+                       opt_duplicate_deps=:                            ;;
+
+      --quiet|--silent)        preserve_args="$preserve_args $opt"
+                       opt_silent=:
+                       ;;
+
+      --verbose| -v)   preserve_args="$preserve_args $opt"
+                       opt_silent=false
+                       ;;
+
+      --tag)           test "$#" -eq 0 && func_missing_arg "$opt" && break
+                       preserve_args="$preserve_args $opt $1"
+                       func_enable_tag "$1"    # tagname is set here
+                       shift
+                       ;;
+
+      # Separate optargs to long options:
+      -dlopen=*|--mode=*|--tag=*)
+                       func_opt_split "$opt"
+                       set dummy "$func_opt_split_opt" "$func_opt_split_arg" ${1+"$@"}
+                       shift
+                       ;;
+
+      -\?|-h)          func_usage                                      ;;
+      --help)          opt_help=:                                      ;;
+      --version)       func_version                                    ;;
+
+      -*)              func_fatal_help "unrecognized option \`$opt'"   ;;
+
+      *)               nonopt="$opt"
+                       break
+                       ;;
+    esac
+  done
+
+
+  case $host in
+    *cygwin* | *mingw* | *pw32* | *cegcc*)
+      # don't eliminate duplications in $postdeps and $predeps
+      opt_duplicate_compiler_generated_deps=:
+      ;;
+    *)
+      opt_duplicate_compiler_generated_deps=$opt_duplicate_deps
+      ;;
+  esac
+
+  # Having warned about all mis-specified options, bail out if
+  # anything was wrong.
+  $exit_cmd $EXIT_FAILURE
+}
+
+# func_check_version_match
+# Ensure that we are using m4 macros, and libtool script from the same
+# release of libtool.
+func_check_version_match ()
+{
+  if test "$package_revision" != "$macro_revision"; then
+    if test "$VERSION" != "$macro_version"; then
+      if test -z "$macro_version"; then
+        cat >&2 <<_LT_EOF
+$progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
+$progname: definition of this LT_INIT comes from an older release.
+$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
+$progname: and run autoconf again.
+_LT_EOF
+      else
+        cat >&2 <<_LT_EOF
+$progname: Version mismatch error.  This is $PACKAGE $VERSION, but the
+$progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
+$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
+$progname: and run autoconf again.
+_LT_EOF
+      fi
+    else
+      cat >&2 <<_LT_EOF
+$progname: Version mismatch error.  This is $PACKAGE $VERSION, revision $package_revision,
+$progname: but the definition of this LT_INIT comes from revision $macro_revision.
+$progname: You should recreate aclocal.m4 with macros from revision $package_revision
+$progname: of $PACKAGE $VERSION and run autoconf again.
+_LT_EOF
+    fi
+
+    exit $EXIT_MISMATCH
+  fi
+}
+
+
+## ----------- ##
+##    Main.    ##
+## ----------- ##
+
+$opt_help || {
+  # Sanity checks first:
+  func_check_version_match
+
+  if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
+    func_fatal_configuration "not configured to build any kind of library"
+  fi
+
+  test -z "$mode" && func_fatal_error "error: you must specify a MODE."
+
+
+  # Darwin sucks
+  eval std_shrext=\"$shrext_cmds\"
+
+
+  # Only execute mode is allowed to have -dlopen flags.
+  if test -n "$execute_dlfiles" && test "$mode" != execute; then
+    func_error "unrecognized option \`-dlopen'"
+    $ECHO "$help" 1>&2
+    exit $EXIT_FAILURE
+  fi
+
+  # Change the help message to a mode-specific one.
+  generic_help="$help"
+  help="Try \`$progname --help --mode=$mode' for more information."
+}
+
+
+# func_lalib_p file
+# True iff FILE is a libtool `.la' library or `.lo' object file.
+# This function is only a basic sanity check; it will hardly flush out
+# determined imposters.
+func_lalib_p ()
+{
+    test -f "$1" &&
+      $SED -e 4q "$1" 2>/dev/null \
+        | $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
+}
+
+# func_lalib_unsafe_p file
+# True iff FILE is a libtool `.la' library or `.lo' object file.
+# This function implements the same check as func_lalib_p without
+# resorting to external programs.  To this end, it redirects stdin and
+# closes it afterwards, without saving the original file descriptor.
+# As a safety measure, use it only where a negative result would be
+# fatal anyway.  Works if `file' does not exist.
+func_lalib_unsafe_p ()
+{
+    lalib_p=no
+    if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then
+       for lalib_p_l in 1 2 3 4
+       do
+           read lalib_p_line
+           case "$lalib_p_line" in
+               \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;;
+           esac
+       done
+       exec 0<&5 5<&-
+    fi
+    test "$lalib_p" = yes
+}
+
+# func_ltwrapper_script_p file
+# True iff FILE is a libtool wrapper script
+# This function is only a basic sanity check; it will hardly flush out
+# determined imposters.
+func_ltwrapper_script_p ()
+{
+    func_lalib_p "$1"
+}
+
+# func_ltwrapper_executable_p file
+# True iff FILE is a libtool wrapper executable
+# This function is only a basic sanity check; it will hardly flush out
+# determined imposters.
+func_ltwrapper_executable_p ()
+{
+    func_ltwrapper_exec_suffix=
+    case $1 in
+    *.exe) ;;
+    *) func_ltwrapper_exec_suffix=.exe ;;
+    esac
+    $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1
+}
+
+# func_ltwrapper_scriptname file
+# Assumes file is an ltwrapper_executable
+# uses $file to determine the appropriate filename for a
+# temporary ltwrapper_script.
+func_ltwrapper_scriptname ()
+{
+    func_ltwrapper_scriptname_result=""
+    if func_ltwrapper_executable_p "$1"; then
+       func_dirname_and_basename "$1" "" "."
+       func_stripname '' '.exe' "$func_basename_result"
+       func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper"
+    fi
+}
+
+# func_ltwrapper_p file
+# True iff FILE is a libtool wrapper script or wrapper executable
+# This function is only a basic sanity check; it will hardly flush out
+# determined imposters.
+func_ltwrapper_p ()
+{
+    func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1"
+}
+
+
+# func_execute_cmds commands fail_cmd
+# Execute tilde-delimited COMMANDS.
+# If FAIL_CMD is given, eval that upon failure.
+# FAIL_CMD may read-access the current command in variable CMD!
+func_execute_cmds ()
+{
+    $opt_debug
+    save_ifs=$IFS; IFS='~'
+    for cmd in $1; do
+      IFS=$save_ifs
+      eval cmd=\"$cmd\"
+      func_show_eval "$cmd" "${2-:}"
+    done
+    IFS=$save_ifs
+}
+
+
+# func_source file
+# Source FILE, adding directory component if necessary.
+# Note that it is not necessary on cygwin/mingw to append a dot to
+# FILE even if both FILE and FILE.exe exist: automatic-append-.exe
+# behavior happens only for exec(3), not for open(2)!  Also, sourcing
+# `FILE.' does not work on cygwin managed mounts.
+func_source ()
+{
+    $opt_debug
+    case $1 in
+    */* | *\\*)        . "$1" ;;
+    *)         . "./$1" ;;
+    esac
+}
+
+
+# func_infer_tag arg
+# Infer tagged configuration to use if any are available and
+# if one wasn't chosen via the "--tag" command line option.
+# Only attempt this if the compiler in the base compile
+# command doesn't match the default compiler.
+# arg is usually of the form 'gcc ...'
+func_infer_tag ()
+{
+    $opt_debug
+    if test -n "$available_tags" && test -z "$tagname"; then
+      CC_quoted=
+      for arg in $CC; do
+        func_quote_for_eval "$arg"
+       CC_quoted="$CC_quoted $func_quote_for_eval_result"
+      done
+      case $@ in
+      # Blanks in the command may have been stripped by the calling shell,
+      # but not from the CC environment variable when configure was run.
+      " $CC "* | "$CC "* | " `$ECHO $CC` "* | "`$ECHO $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$ECHO $CC_quoted` "* | "`$ECHO $CC_quoted` "*) ;;
+      # Blanks at the start of $base_compile will cause this to fail
+      # if we don't check for them as well.
+      *)
+       for z in $available_tags; do
+         if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then
+           # Evaluate the configuration.
+           eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
+           CC_quoted=
+           for arg in $CC; do
+             # Double-quote args containing other shell metacharacters.
+             func_quote_for_eval "$arg"
+             CC_quoted="$CC_quoted $func_quote_for_eval_result"
+           done
+           case "$@ " in
+             " $CC "* | "$CC "* | " `$ECHO $CC` "* | "`$ECHO $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$ECHO $CC_quoted` "* | "`$ECHO $CC_quoted` "*)
+             # The compiler in the base compile command matches
+             # the one in the tagged configuration.
+             # Assume this is the tagged configuration we want.
+             tagname=$z
+             break
+             ;;
+           esac
+         fi
+       done
+       # If $tagname still isn't set, then no tagged configuration
+       # was found and let the user know that the "--tag" command
+       # line option must be used.
+       if test -z "$tagname"; then
+         func_echo "unable to infer tagged configuration"
+         func_fatal_error "specify a tag with \`--tag'"
+#      else
+#        func_verbose "using $tagname tagged configuration"
+       fi
+       ;;
+      esac
+    fi
+}
+
+
+
+# func_write_libtool_object output_name pic_name nonpic_name
+# Create a libtool object file (analogous to a ".la" file),
+# but don't create it if we're doing a dry run.
+func_write_libtool_object ()
+{
+    write_libobj=${1}
+    if test "$build_libtool_libs" = yes; then
+      write_lobj=\'${2}\'
+    else
+      write_lobj=none
+    fi
+
+    if test "$build_old_libs" = yes; then
+      write_oldobj=\'${3}\'
+    else
+      write_oldobj=none
+    fi
+
+    $opt_dry_run || {
+      cat >${write_libobj}T <<EOF
+# $write_libobj - a libtool object file
+# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+#
+# Please DO NOT delete this file!
+# It is necessary for linking the library.
+
+# Name of the PIC object.
+pic_object=$write_lobj
+
+# Name of the non-PIC object
+non_pic_object=$write_oldobj
+
+EOF
+      $MV "${write_libobj}T" "${write_libobj}"
+    }
+}
+
+# func_mode_compile arg...
+func_mode_compile ()
+{
+    $opt_debug
+    # Get the compilation command and the source file.
+    base_compile=
+    srcfile="$nonopt"  #  always keep a non-empty value in "srcfile"
+    suppress_opt=yes
+    suppress_output=
+    arg_mode=normal
+    libobj=
+    later=
+    pie_flag=
+
+    for arg
+    do
+      case $arg_mode in
+      arg  )
+       # do not "continue".  Instead, add this to base_compile
+       lastarg="$arg"
+       arg_mode=normal
+       ;;
+
+      target )
+       libobj="$arg"
+       arg_mode=normal
+       continue
+       ;;
+
+      normal )
+       # Accept any command-line options.
+       case $arg in
+       -o)
+         test -n "$libobj" && \
+           func_fatal_error "you cannot specify \`-o' more than once"
+         arg_mode=target
+         continue
+         ;;
+
+       -pie | -fpie | -fPIE)
+          pie_flag="$pie_flag $arg"
+         continue
+         ;;
+
+       -shared | -static | -prefer-pic | -prefer-non-pic)
+         later="$later $arg"
+         continue
+         ;;
+
+       -no-suppress)
+         suppress_opt=no
+         continue
+         ;;
+
+       -Xcompiler)
+         arg_mode=arg  #  the next one goes into the "base_compile" arg list
+         continue      #  The current "srcfile" will either be retained or
+         ;;            #  replaced later.  I would guess that would be a bug.
+
+       -Wc,*)
+         func_stripname '-Wc,' '' "$arg"
+         args=$func_stripname_result
+         lastarg=
+         save_ifs="$IFS"; IFS=','
+         for arg in $args; do
+           IFS="$save_ifs"
+           func_quote_for_eval "$arg"
+           lastarg="$lastarg $func_quote_for_eval_result"
+         done
+         IFS="$save_ifs"
+         func_stripname ' ' '' "$lastarg"
+         lastarg=$func_stripname_result
+
+         # Add the arguments to base_compile.
+         base_compile="$base_compile $lastarg"
+         continue
+         ;;
+
+       *)
+         # Accept the current argument as the source file.
+         # The previous "srcfile" becomes the current argument.
+         #
+         lastarg="$srcfile"
+         srcfile="$arg"
+         ;;
+       esac  #  case $arg
+       ;;
+      esac    #  case $arg_mode
+
+      # Aesthetically quote the previous argument.
+      func_quote_for_eval "$lastarg"
+      base_compile="$base_compile $func_quote_for_eval_result"
+    done # for arg
+
+    case $arg_mode in
+    arg)
+      func_fatal_error "you must specify an argument for -Xcompile"
+      ;;
+    target)
+      func_fatal_error "you must specify a target with \`-o'"
+      ;;
+    *)
+      # Get the name of the library object.
+      test -z "$libobj" && {
+       func_basename "$srcfile"
+       libobj="$func_basename_result"
+      }
+      ;;
+    esac
+
+    # Recognize several different file suffixes.
+    # If the user specifies -o file.o, it is replaced with file.lo
+    case $libobj in
+    *.[cCFSifmso] | \
+    *.ada | *.adb | *.ads | *.asm | \
+    *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \
+    *.[fF][09]? | *.for | *.java | *.obj | *.sx)
+      func_xform "$libobj"
+      libobj=$func_xform_result
+      ;;
+    esac
+
+    case $libobj in
+    *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;;
+    *)
+      func_fatal_error "cannot determine name of library object from \`$libobj'"
+      ;;
+    esac
+
+    func_infer_tag $base_compile
+
+    for arg in $later; do
+      case $arg in
+      -shared)
+       test "$build_libtool_libs" != yes && \
+         func_fatal_configuration "can not build a shared library"
+       build_old_libs=no
+       continue
+       ;;
+
+      -static)
+       build_libtool_libs=no
+       build_old_libs=yes
+       continue
+       ;;
+
+      -prefer-pic)
+       pic_mode=yes
+       continue
+       ;;
+
+      -prefer-non-pic)
+       pic_mode=no
+       continue
+       ;;
+      esac
+    done
+
+    func_quote_for_eval "$libobj"
+    test "X$libobj" != "X$func_quote_for_eval_result" \
+      && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"'   &()|`$[]' \
+      && func_warning "libobj name \`$libobj' may not contain shell special characters."
+    func_dirname_and_basename "$obj" "/" ""
+    objname="$func_basename_result"
+    xdir="$func_dirname_result"
+    lobj=${xdir}$objdir/$objname
+
+    test -z "$base_compile" && \
+      func_fatal_help "you must specify a compilation command"
+
+    # Delete any leftover library objects.
+    if test "$build_old_libs" = yes; then
+      removelist="$obj $lobj $libobj ${libobj}T"
+    else
+      removelist="$lobj $libobj ${libobj}T"
+    fi
+
+    # On Cygwin there's no "real" PIC flag so we must build both object types
+    case $host_os in
+    cygwin* | mingw* | pw32* | os2* | cegcc*)
+      pic_mode=default
+      ;;
+    esac
+    if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then
+      # non-PIC code in shared libraries is not supported
+      pic_mode=default
+    fi
+
+    # Calculate the filename of the output object if compiler does
+    # not support -o with -c
+    if test "$compiler_c_o" = no; then
+      output_obj=`$ECHO "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext}
+      lockfile="$output_obj.lock"
+    else
+      output_obj=
+      need_locks=no
+      lockfile=
+    fi
+
+    # Lock this critical section if it is needed
+    # We use this script file to make the link, it avoids creating a new file
+    if test "$need_locks" = yes; then
+      until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
+       func_echo "Waiting for $lockfile to be removed"
+       sleep 2
+      done
+    elif test "$need_locks" = warn; then
+      if test -f "$lockfile"; then
+       $ECHO "\
+*** ERROR, $lockfile exists and contains:
+`cat $lockfile 2>/dev/null`
+
+This indicates that another process is trying to use the same
+temporary object file, and libtool could not work around it because
+your compiler does not support \`-c' and \`-o' together.  If you
+repeat this compilation, it may succeed, by chance, but you had better
+avoid parallel builds (make -j) in this platform, or get a better
+compiler."
+
+       $opt_dry_run || $RM $removelist
+       exit $EXIT_FAILURE
+      fi
+      removelist="$removelist $output_obj"
+      $ECHO "$srcfile" > "$lockfile"
+    fi
+
+    $opt_dry_run || $RM $removelist
+    removelist="$removelist $lockfile"
+    trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15
+
+    if test -n "$fix_srcfile_path"; then
+      eval srcfile=\"$fix_srcfile_path\"
+    fi
+    func_quote_for_eval "$srcfile"
+    qsrcfile=$func_quote_for_eval_result
+
+    # Only build a PIC object if we are building libtool libraries.
+    if test "$build_libtool_libs" = yes; then
+      # Without this assignment, base_compile gets emptied.
+      fbsd_hideous_sh_bug=$base_compile
+
+      if test "$pic_mode" != no; then
+       command="$base_compile $qsrcfile $pic_flag"
+      else
+       # Don't build PIC code
+       command="$base_compile $qsrcfile"
+      fi
+
+      func_mkdir_p "$xdir$objdir"
+
+      if test -z "$output_obj"; then
+       # Place PIC objects in $objdir
+       command="$command -o $lobj"
+      fi
+
+      func_show_eval_locale "$command" \
+          'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE'
+
+      if test "$need_locks" = warn &&
+        test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
+       $ECHO "\
+*** ERROR, $lockfile contains:
+`cat $lockfile 2>/dev/null`
+
+but it should contain:
+$srcfile
+
+This indicates that another process is trying to use the same
+temporary object file, and libtool could not work around it because
+your compiler does not support \`-c' and \`-o' together.  If you
+repeat this compilation, it may succeed, by chance, but you had better
+avoid parallel builds (make -j) in this platform, or get a better
+compiler."
+
+       $opt_dry_run || $RM $removelist
+       exit $EXIT_FAILURE
+      fi
+
+      # Just move the object if needed, then go on to compile the next one
+      if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then
+       func_show_eval '$MV "$output_obj" "$lobj"' \
+         'error=$?; $opt_dry_run || $RM $removelist; exit $error'
+      fi
+
+      # Allow error messages only from the first compilation.
+      if test "$suppress_opt" = yes; then
+       suppress_output=' >/dev/null 2>&1'
+      fi
+    fi
+
+    # Only build a position-dependent object if we build old libraries.
+    if test "$build_old_libs" = yes; then
+      if test "$pic_mode" != yes; then
+       # Don't build PIC code
+       command="$base_compile $qsrcfile$pie_flag"
+      else
+       command="$base_compile $qsrcfile $pic_flag"
+      fi
+      if test "$compiler_c_o" = yes; then
+       command="$command -o $obj"
+      fi
+
+      # Suppress compiler output if we already did a PIC compilation.
+      command="$command$suppress_output"
+      func_show_eval_locale "$command" \
+        '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE'
+
+      if test "$need_locks" = warn &&
+        test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
+       $ECHO "\
+*** ERROR, $lockfile contains:
+`cat $lockfile 2>/dev/null`
+
+but it should contain:
+$srcfile
+
+This indicates that another process is trying to use the same
+temporary object file, and libtool could not work around it because
+your compiler does not support \`-c' and \`-o' together.  If you
+repeat this compilation, it may succeed, by chance, but you had better
+avoid parallel builds (make -j) in this platform, or get a better
+compiler."
+
+       $opt_dry_run || $RM $removelist
+       exit $EXIT_FAILURE
+      fi
+
+      # Just move the object if needed
+      if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then
+       func_show_eval '$MV "$output_obj" "$obj"' \
+         'error=$?; $opt_dry_run || $RM $removelist; exit $error'
+      fi
+    fi
+
+    $opt_dry_run || {
+      func_write_libtool_object "$libobj" "$objdir/$objname" "$objname"
+
+      # Unlock the critical section if it was locked
+      if test "$need_locks" != no; then
+       removelist=$lockfile
+        $RM "$lockfile"
+      fi
+    }
+
+    exit $EXIT_SUCCESS
+}
+
+$opt_help || {
+test "$mode" = compile && func_mode_compile ${1+"$@"}
+}
+
+func_mode_help ()
+{
+    # We need to display help for each of the modes.
+    case $mode in
+      "")
+        # Generic help is extracted from the usage comments
+        # at the start of this file.
+        func_help
+        ;;
+
+      clean)
+        $ECHO \
+"Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE...
+
+Remove files from the build directory.
+
+RM is the name of the program to use to delete files associated with each FILE
+(typically \`/bin/rm').  RM-OPTIONS are options (such as \`-f') to be passed
+to RM.
+
+If FILE is a libtool library, object or program, all the files associated
+with it are deleted. Otherwise, only FILE itself is deleted using RM."
+        ;;
+
+      compile)
+      $ECHO \
+"Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE
+
+Compile a source file into a libtool library object.
+
+This mode accepts the following additional options:
+
+  -o OUTPUT-FILE    set the output file name to OUTPUT-FILE
+  -no-suppress      do not suppress compiler output for multiple passes
+  -prefer-pic       try to building PIC objects only
+  -prefer-non-pic   try to building non-PIC objects only
+  -shared           do not build a \`.o' file suitable for static linking
+  -static           only build a \`.o' file suitable for static linking
+
+COMPILE-COMMAND is a command to be used in creating a \`standard' object file
+from the given SOURCEFILE.
+
+The output file name is determined by removing the directory component from
+SOURCEFILE, then substituting the C source code suffix \`.c' with the
+library object suffix, \`.lo'."
+        ;;
+
+      execute)
+        $ECHO \
+"Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]...
+
+Automatically set library path, then run a program.
+
+This mode accepts the following additional options:
+
+  -dlopen FILE      add the directory containing FILE to the library path
+
+This mode sets the library path environment variable according to \`-dlopen'
+flags.
+
+If any of the ARGS are libtool executable wrappers, then they are translated
+into their corresponding uninstalled binary, and any of their required library
+directories are added to the library path.
+
+Then, COMMAND is executed, with ARGS as arguments."
+        ;;
+
+      finish)
+        $ECHO \
+"Usage: $progname [OPTION]... --mode=finish [LIBDIR]...
+
+Complete the installation of libtool libraries.
+
+Each LIBDIR is a directory that contains libtool libraries.
+
+The commands that this mode executes may require superuser privileges.  Use
+the \`--dry-run' option if you just want to see what would be executed."
+        ;;
+
+      install)
+        $ECHO \
+"Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND...
+
+Install executables or libraries.
+
+INSTALL-COMMAND is the installation command.  The first component should be
+either the \`install' or \`cp' program.
+
+The following components of INSTALL-COMMAND are treated specially:
+
+  -inst-prefix PREFIX-DIR  Use PREFIX-DIR as a staging area for installation
+
+The rest of the components are interpreted as arguments to that command (only
+BSD-compatible install options are recognized)."
+        ;;
+
+      link)
+        $ECHO \
+"Usage: $progname [OPTION]... --mode=link LINK-COMMAND...
+
+Link object files or libraries together to form another library, or to
+create an executable program.
+
+LINK-COMMAND is a command using the C compiler that you would use to create
+a program from several object files.
+
+The following components of LINK-COMMAND are treated specially:
+
+  -all-static       do not do any dynamic linking at all
+  -avoid-version    do not add a version suffix if possible
+  -dlopen FILE      \`-dlpreopen' FILE if it cannot be dlopened at runtime
+  -dlpreopen FILE   link in FILE and add its symbols to lt_preloaded_symbols
+  -export-dynamic   allow symbols from OUTPUT-FILE to be resolved with dlsym(3)
+  -export-symbols SYMFILE
+                    try to export only the symbols listed in SYMFILE
+  -export-symbols-regex REGEX
+                    try to export only the symbols matching REGEX
+  -LLIBDIR          search LIBDIR for required installed libraries
+  -lNAME            OUTPUT-FILE requires the installed library libNAME
+  -module           build a library that can dlopened
+  -no-fast-install  disable the fast-install mode
+  -no-install       link a not-installable executable
+  -no-undefined     declare that a library does not refer to external symbols
+  -o OUTPUT-FILE    create OUTPUT-FILE from the specified objects
+  -objectlist FILE  Use a list of object files found in FILE to specify objects
+  -precious-files-regex REGEX
+                    don't remove output files matching REGEX
+  -release RELEASE  specify package release information
+  -rpath LIBDIR     the created library will eventually be installed in LIBDIR
+  -R[ ]LIBDIR       add LIBDIR to the runtime path of programs and libraries
+  -shared           only do dynamic linking of libtool libraries
+  -shrext SUFFIX    override the standard shared library file extension
+  -static           do not do any dynamic linking of uninstalled libtool libraries
+  -static-libtool-libs
+                    do not do any dynamic linking of libtool libraries
+  -version-info CURRENT[:REVISION[:AGE]]
+                    specify library version info [each variable defaults to 0]
+  -weak LIBNAME     declare that the target provides the LIBNAME interface
+
+All other options (arguments beginning with \`-') are ignored.
+
+Every other argument is treated as a filename.  Files ending in \`.la' are
+treated as uninstalled libtool libraries, other files are standard or library
+object files.
+
+If the OUTPUT-FILE ends in \`.la', then a libtool library is created,
+only library objects (\`.lo' files) may be specified, and \`-rpath' is
+required, except when creating a convenience library.
+
+If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created
+using \`ar' and \`ranlib', or on Windows using \`lib'.
+
+If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file
+is created, otherwise an executable program is created."
+        ;;
+
+      uninstall)
+        $ECHO \
+"Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE...
+
+Remove libraries from an installation directory.
+
+RM is the name of the program to use to delete files associated with each FILE
+(typically \`/bin/rm').  RM-OPTIONS are options (such as \`-f') to be passed
+to RM.
+
+If FILE is a libtool library, all the files associated with it are deleted.
+Otherwise, only FILE itself is deleted using RM."
+        ;;
+
+      *)
+        func_fatal_help "invalid operation mode \`$mode'"
+        ;;
+    esac
+
+    $ECHO
+    $ECHO "Try \`$progname --help' for more information about other modes."
+
+    exit $?
+}
+
+  # Now that we've collected a possible --mode arg, show help if necessary
+  $opt_help && func_mode_help
+
+
+# func_mode_execute arg...
+func_mode_execute ()
+{
+    $opt_debug
+    # The first argument is the command name.
+    cmd="$nonopt"
+    test -z "$cmd" && \
+      func_fatal_help "you must specify a COMMAND"
+
+    # Handle -dlopen flags immediately.
+    for file in $execute_dlfiles; do
+      test -f "$file" \
+       || func_fatal_help "\`$file' is not a file"
+
+      dir=
+      case $file in
+      *.la)
+       # Check to see that this really is a libtool archive.
+       func_lalib_unsafe_p "$file" \
+         || func_fatal_help "\`$lib' is not a valid libtool archive"
+
+       # Read the libtool library.
+       dlname=
+       library_names=
+       func_source "$file"
+
+       # Skip this library if it cannot be dlopened.
+       if test -z "$dlname"; then
+         # Warn if it was a shared library.
+         test -n "$library_names" && \
+           func_warning "\`$file' was not linked with \`-export-dynamic'"
+         continue
+       fi
+
+       func_dirname "$file" "" "."
+       dir="$func_dirname_result"
+
+       if test -f "$dir/$objdir/$dlname"; then
+         dir="$dir/$objdir"
+       else
+         if test ! -f "$dir/$dlname"; then
+           func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'"
+         fi
+       fi
+       ;;
+
+      *.lo)
+       # Just add the directory containing the .lo file.
+       func_dirname "$file" "" "."
+       dir="$func_dirname_result"
+       ;;
+
+      *)
+       func_warning "\`-dlopen' is ignored for non-libtool libraries and objects"
+       continue
+       ;;
+      esac
+
+      # Get the absolute pathname.
+      absdir=`cd "$dir" && pwd`
+      test -n "$absdir" && dir="$absdir"
+
+      # Now add the directory to shlibpath_var.
+      if eval "test -z \"\$$shlibpath_var\""; then
+       eval "$shlibpath_var=\"\$dir\""
+      else
+       eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\""
+      fi
+    done
+
+    # This variable tells wrapper scripts just to set shlibpath_var
+    # rather than running their programs.
+    libtool_execute_magic="$magic"
+
+    # Check if any of the arguments is a wrapper script.
+    args=
+    for file
+    do
+      case $file in
+      -*) ;;
+      *)
+       # Do a test to see if this is really a libtool program.
+       if func_ltwrapper_script_p "$file"; then
+         func_source "$file"
+         # Transform arg to wrapped name.
+         file="$progdir/$program"
+       elif func_ltwrapper_executable_p "$file"; then
+         func_ltwrapper_scriptname "$file"
+         func_source "$func_ltwrapper_scriptname_result"
+         # Transform arg to wrapped name.
+         file="$progdir/$program"
+       fi
+       ;;
+      esac
+      # Quote arguments (to preserve shell metacharacters).
+      func_quote_for_eval "$file"
+      args="$args $func_quote_for_eval_result"
+    done
+
+    if test "X$opt_dry_run" = Xfalse; then
+      if test -n "$shlibpath_var"; then
+       # Export the shlibpath_var.
+       eval "export $shlibpath_var"
+      fi
+
+      # Restore saved environment variables
+      for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
+      do
+       eval "if test \"\${save_$lt_var+set}\" = set; then
+                $lt_var=\$save_$lt_var; export $lt_var
+             else
+               $lt_unset $lt_var
+             fi"
+      done
+
+      # Now prepare to actually exec the command.
+      exec_cmd="\$cmd$args"
+    else
+      # Display what would be done.
+      if test -n "$shlibpath_var"; then
+       eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\""
+       $ECHO "export $shlibpath_var"
+      fi
+      $ECHO "$cmd$args"
+      exit $EXIT_SUCCESS
+    fi
+}
+
+test "$mode" = execute && func_mode_execute ${1+"$@"}
+
+
+# func_mode_finish arg...
+func_mode_finish ()
+{
+    $opt_debug
+    libdirs="$nonopt"
+    admincmds=
+
+    if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
+      for dir
+      do
+       libdirs="$libdirs $dir"
+      done
+
+      for libdir in $libdirs; do
+       if test -n "$finish_cmds"; then
+         # Do each command in the finish commands.
+         func_execute_cmds "$finish_cmds" 'admincmds="$admincmds
+'"$cmd"'"'
+       fi
+       if test -n "$finish_eval"; then
+         # Do the single finish_eval.
+         eval cmds=\"$finish_eval\"
+         $opt_dry_run || eval "$cmds" || admincmds="$admincmds
+       $cmds"
+       fi
+      done
+    fi
+
+    # Exit here if they wanted silent mode.
+    $opt_silent && exit $EXIT_SUCCESS
+
+    $ECHO "X----------------------------------------------------------------------" | $Xsed
+    $ECHO "Libraries have been installed in:"
+    for libdir in $libdirs; do
+      $ECHO "   $libdir"
+    done
+    $ECHO
+    $ECHO "If you ever happen to want to link against installed libraries"
+    $ECHO "in a given directory, LIBDIR, you must either use libtool, and"
+    $ECHO "specify the full pathname of the library, or use the \`-LLIBDIR'"
+    $ECHO "flag during linking and do at least one of the following:"
+    if test -n "$shlibpath_var"; then
+      $ECHO "   - add LIBDIR to the \`$shlibpath_var' environment variable"
+      $ECHO "     during execution"
+    fi
+    if test -n "$runpath_var"; then
+      $ECHO "   - add LIBDIR to the \`$runpath_var' environment variable"
+      $ECHO "     during linking"
+    fi
+    if test -n "$hardcode_libdir_flag_spec"; then
+      libdir=LIBDIR
+      eval flag=\"$hardcode_libdir_flag_spec\"
+
+      $ECHO "   - use the \`$flag' linker flag"
+    fi
+    if test -n "$admincmds"; then
+      $ECHO "   - have your system administrator run these commands:$admincmds"
+    fi
+    if test -f /etc/ld.so.conf; then
+      $ECHO "   - have your system administrator add LIBDIR to \`/etc/ld.so.conf'"
+    fi
+    $ECHO
+
+    $ECHO "See any operating system documentation about shared libraries for"
+    case $host in
+      solaris2.[6789]|solaris2.1[0-9])
+        $ECHO "more information, such as the ld(1), crle(1) and ld.so(8) manual"
+       $ECHO "pages."
+       ;;
+      *)
+        $ECHO "more information, such as the ld(1) and ld.so(8) manual pages."
+        ;;
+    esac
+    $ECHO "X----------------------------------------------------------------------" | $Xsed
+    exit $EXIT_SUCCESS
+}
+
+test "$mode" = finish && func_mode_finish ${1+"$@"}
+
+
+# func_mode_install arg...
+func_mode_install ()
+{
+    $opt_debug
+    # There may be an optional sh(1) argument at the beginning of
+    # install_prog (especially on Windows NT).
+    if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh ||
+       # Allow the use of GNU shtool's install command.
+       $ECHO "X$nonopt" | $GREP shtool >/dev/null; then
+      # Aesthetically quote it.
+      func_quote_for_eval "$nonopt"
+      install_prog="$func_quote_for_eval_result "
+      arg=$1
+      shift
+    else
+      install_prog=
+      arg=$nonopt
+    fi
+
+    # The real first argument should be the name of the installation program.
+    # Aesthetically quote it.
+    func_quote_for_eval "$arg"
+    install_prog="$install_prog$func_quote_for_eval_result"
+
+    # We need to accept at least all the BSD install flags.
+    dest=
+    files=
+    opts=
+    prev=
+    install_type=
+    isdir=no
+    stripme=
+    for arg
+    do
+      if test -n "$dest"; then
+       files="$files $dest"
+       dest=$arg
+       continue
+      fi
+
+      case $arg in
+      -d) isdir=yes ;;
+      -f)
+       case " $install_prog " in
+       *[\\\ /]cp\ *) ;;
+       *) prev=$arg ;;
+       esac
+       ;;
+      -g | -m | -o)
+       prev=$arg
+       ;;
+      -s)
+       stripme=" -s"
+       continue
+       ;;
+      -*)
+       ;;
+      *)
+       # If the previous option needed an argument, then skip it.
+       if test -n "$prev"; then
+         prev=
+       else
+         dest=$arg
+         continue
+       fi
+       ;;
+      esac
+
+      # Aesthetically quote the argument.
+      func_quote_for_eval "$arg"
+      install_prog="$install_prog $func_quote_for_eval_result"
+    done
+
+    test -z "$install_prog" && \
+      func_fatal_help "you must specify an install program"
+
+    test -n "$prev" && \
+      func_fatal_help "the \`$prev' option requires an argument"
+
+    if test -z "$files"; then
+      if test -z "$dest"; then
+       func_fatal_help "no file or destination specified"
+      else
+       func_fatal_help "you must specify a destination"
+      fi
+    fi
+
+    # Strip any trailing slash from the destination.
+    func_stripname '' '/' "$dest"
+    dest=$func_stripname_result
+
+    # Check to see that the destination is a directory.
+    test -d "$dest" && isdir=yes
+    if test "$isdir" = yes; then
+      destdir="$dest"
+      destname=
+    else
+      func_dirname_and_basename "$dest" "" "."
+      destdir="$func_dirname_result"
+      destname="$func_basename_result"
+
+      # Not a directory, so check to see that there is only one file specified.
+      set dummy $files; shift
+      test "$#" -gt 1 && \
+       func_fatal_help "\`$dest' is not a directory"
+    fi
+    case $destdir in
+    [\\/]* | [A-Za-z]:[\\/]*) ;;
+    *)
+      for file in $files; do
+       case $file in
+       *.lo) ;;
+       *)
+         func_fatal_help "\`$destdir' must be an absolute directory name"
+         ;;
+       esac
+      done
+      ;;
+    esac
+
+    # This variable tells wrapper scripts just to set variables rather
+    # than running their programs.
+    libtool_install_magic="$magic"
+
+    staticlibs=
+    future_libdirs=
+    current_libdirs=
+    for file in $files; do
+
+      # Do each installation.
+      case $file in
+      *.$libext)
+       # Do the static libraries later.
+       staticlibs="$staticlibs $file"
+       ;;
+
+      *.la)
+       # Check to see that this really is a libtool archive.
+       func_lalib_unsafe_p "$file" \
+         || func_fatal_help "\`$file' is not a valid libtool archive"
+
+       library_names=
+       old_library=
+       relink_command=
+       func_source "$file"
+
+       # Add the libdir to current_libdirs if it is the destination.
+       if test "X$destdir" = "X$libdir"; then
+         case "$current_libdirs " in
+         *" $libdir "*) ;;
+         *) current_libdirs="$current_libdirs $libdir" ;;
+         esac
+       else
+         # Note the libdir as a future libdir.
+         case "$future_libdirs " in
+         *" $libdir "*) ;;
+         *) future_libdirs="$future_libdirs $libdir" ;;
+         esac
+       fi
+
+       func_dirname "$file" "/" ""
+       dir="$func_dirname_result"
+       dir="$dir$objdir"
+
+       if test -n "$relink_command"; then
+         # Determine the prefix the user has applied to our future dir.
+         inst_prefix_dir=`$ECHO "X$destdir" | $Xsed -e "s%$libdir\$%%"`
+
+         # Don't allow the user to place us outside of our expected
+         # location b/c this prevents finding dependent libraries that
+         # are installed to the same prefix.
+         # At present, this check doesn't affect windows .dll's that
+         # are installed into $libdir/../bin (currently, that works fine)
+         # but it's something to keep an eye on.
+         test "$inst_prefix_dir" = "$destdir" && \
+           func_fatal_error "error: cannot install \`$file' to a directory not ending in $libdir"
+
+         if test -n "$inst_prefix_dir"; then
+           # Stick the inst_prefix_dir data into the link command.
+           relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"`
+         else
+           relink_command=`$ECHO "X$relink_command" | $Xsed -e "s%@inst_prefix_dir@%%"`
+         fi
+
+         func_warning "relinking \`$file'"
+         func_show_eval "$relink_command" \
+           'func_fatal_error "error: relink \`$file'\'' with the above command before installing it"'
+       fi
+
+       # See the names of the shared library.
+       set dummy $library_names; shift
+       if test -n "$1"; then
+         realname="$1"
+         shift
+
+         srcname="$realname"
+         test -n "$relink_command" && srcname="$realname"T
+
+         # Install the shared library and build the symlinks.
+         func_show_eval "$install_prog $dir/$srcname $destdir/$realname" \
+             'exit $?'
+         tstripme="$stripme"
+         case $host_os in
+         cygwin* | mingw* | pw32* | cegcc*)
+           case $realname in
+           *.dll.a)
+             tstripme=""
+             ;;
+           esac
+           ;;
+         esac
+         if test -n "$tstripme" && test -n "$striplib"; then
+           func_show_eval "$striplib $destdir/$realname" 'exit $?'
+         fi
+
+         if test "$#" -gt 0; then
+           # Delete the old symlinks, and create new ones.
+           # Try `ln -sf' first, because the `ln' binary might depend on
+           # the symlink we replace!  Solaris /bin/ln does not understand -f,
+           # so we also need to try rm && ln -s.
+           for linkname
+           do
+             test "$linkname" != "$realname" \
+               && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })"
+           done
+         fi
+
+         # Do each command in the postinstall commands.
+         lib="$destdir/$realname"
+         func_execute_cmds "$postinstall_cmds" 'exit $?'
+       fi
+
+       # Install the pseudo-library for information purposes.
+       func_basename "$file"
+       name="$func_basename_result"
+       instname="$dir/$name"i
+       func_show_eval "$install_prog $instname $destdir/$name" 'exit $?'
+
+       # Maybe install the static library, too.
+       test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library"
+       ;;
+
+      *.lo)
+       # Install (i.e. copy) a libtool object.
+
+       # Figure out destination file name, if it wasn't already specified.
+       if test -n "$destname"; then
+         destfile="$destdir/$destname"
+       else
+         func_basename "$file"
+         destfile="$func_basename_result"
+         destfile="$destdir/$destfile"
+       fi
+
+       # Deduce the name of the destination old-style object file.
+       case $destfile in
+       *.lo)
+         func_lo2o "$destfile"
+         staticdest=$func_lo2o_result
+         ;;
+       *.$objext)
+         staticdest="$destfile"
+         destfile=
+         ;;
+       *)
+         func_fatal_help "cannot copy a libtool object to \`$destfile'"
+         ;;
+       esac
+
+       # Install the libtool object if requested.
+       test -n "$destfile" && \
+         func_show_eval "$install_prog $file $destfile" 'exit $?'
+
+       # Install the old object if enabled.
+       if test "$build_old_libs" = yes; then
+         # Deduce the name of the old-style object file.
+         func_lo2o "$file"
+         staticobj=$func_lo2o_result
+         func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?'
+       fi
+       exit $EXIT_SUCCESS
+       ;;
+
+      *)
+       # Figure out destination file name, if it wasn't already specified.
+       if test -n "$destname"; then
+         destfile="$destdir/$destname"
+       else
+         func_basename "$file"
+         destfile="$func_basename_result"
+         destfile="$destdir/$destfile"
+       fi
+
+       # If the file is missing, and there is a .exe on the end, strip it
+       # because it is most likely a libtool script we actually want to
+       # install
+       stripped_ext=""
+       case $file in
+         *.exe)
+           if test ! -f "$file"; then
+             func_stripname '' '.exe' "$file"
+             file=$func_stripname_result
+             stripped_ext=".exe"
+           fi
+           ;;
+       esac
+
+       # Do a test to see if this is really a libtool program.
+       case $host in
+       *cygwin* | *mingw*)
+           if func_ltwrapper_executable_p "$file"; then
+             func_ltwrapper_scriptname "$file"
+             wrapper=$func_ltwrapper_scriptname_result
+           else
+             func_stripname '' '.exe' "$file"
+             wrapper=$func_stripname_result
+           fi
+           ;;
+       *)
+           wrapper=$file
+           ;;
+       esac
+       if func_ltwrapper_script_p "$wrapper"; then
+         notinst_deplibs=
+         relink_command=
+
+         func_source "$wrapper"
+
+         # Check the variables that should have been set.
+         test -z "$generated_by_libtool_version" && \
+           func_fatal_error "invalid libtool wrapper script \`$wrapper'"
+
+         finalize=yes
+         for lib in $notinst_deplibs; do
+           # Check to see that each library is installed.
+           libdir=
+           if test -f "$lib"; then
+             func_source "$lib"
+           fi
+           libfile="$libdir/"`$ECHO "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test
+           if test -n "$libdir" && test ! -f "$libfile"; then
+             func_warning "\`$lib' has not been installed in \`$libdir'"
+             finalize=no
+           fi
+         done
+
+         relink_command=
+         func_source "$wrapper"
+
+         outputname=
+         if test "$fast_install" = no && test -n "$relink_command"; then
+           $opt_dry_run || {
+             if test "$finalize" = yes; then
+               tmpdir=`func_mktempdir`
+               func_basename "$file$stripped_ext"
+               file="$func_basename_result"
+               outputname="$tmpdir/$file"
+               # Replace the output file specification.
+               relink_command=`$ECHO "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'`
+
+               $opt_silent || {
+                 func_quote_for_expand "$relink_command"
+                 eval "func_echo $func_quote_for_expand_result"
+               }
+               if eval "$relink_command"; then :
+                 else
+                 func_error "error: relink \`$file' with the above command before installing it"
+                 $opt_dry_run || ${RM}r "$tmpdir"
+                 continue
+               fi
+               file="$outputname"
+             else
+               func_warning "cannot relink \`$file'"
+             fi
+           }
+         else
+           # Install the binary that we compiled earlier.
+           file=`$ECHO "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"`
+         fi
+       fi
+
+       # remove .exe since cygwin /usr/bin/install will append another
+       # one anyway
+       case $install_prog,$host in
+       */usr/bin/install*,*cygwin*)
+         case $file:$destfile in
+         *.exe:*.exe)
+           # this is ok
+           ;;
+         *.exe:*)
+           destfile=$destfile.exe
+           ;;
+         *:*.exe)
+           func_stripname '' '.exe' "$destfile"
+           destfile=$func_stripname_result
+           ;;
+         esac
+         ;;
+       esac
+       func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?'
+       $opt_dry_run || if test -n "$outputname"; then
+         ${RM}r "$tmpdir"
+       fi
+       ;;
+      esac
+    done
+
+    for file in $staticlibs; do
+      func_basename "$file"
+      name="$func_basename_result"
+
+      # Set up the ranlib parameters.
+      oldlib="$destdir/$name"
+
+      func_show_eval "$install_prog \$file \$oldlib" 'exit $?'
+
+      if test -n "$stripme" && test -n "$old_striplib"; then
+       func_show_eval "$old_striplib $oldlib" 'exit $?'
+      fi
+
+      # Do each command in the postinstall commands.
+      func_execute_cmds "$old_postinstall_cmds" 'exit $?'
+    done
+
+    test -n "$future_libdirs" && \
+      func_warning "remember to run \`$progname --finish$future_libdirs'"
+
+    if test -n "$current_libdirs"; then
+      # Maybe just do a dry run.
+      $opt_dry_run && current_libdirs=" -n$current_libdirs"
+      exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs'
+    else
+      exit $EXIT_SUCCESS
+    fi
+}
+
+test "$mode" = install && func_mode_install ${1+"$@"}
+
+
+# func_generate_dlsyms outputname originator pic_p
+# Extract symbols from dlprefiles and create ${outputname}S.o with
+# a dlpreopen symbol table.
+func_generate_dlsyms ()
+{
+    $opt_debug
+    my_outputname="$1"
+    my_originator="$2"
+    my_pic_p="${3-no}"
+    my_prefix=`$ECHO "$my_originator" | sed 's%[^a-zA-Z0-9]%_%g'`
+    my_dlsyms=
+
+    if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
+      if test -n "$NM" && test -n "$global_symbol_pipe"; then
+       my_dlsyms="${my_outputname}S.c"
+      else
+       func_error "not configured to extract global symbols from dlpreopened files"
+      fi
+    fi
+
+    if test -n "$my_dlsyms"; then
+      case $my_dlsyms in
+      "") ;;
+      *.c)
+       # Discover the nlist of each of the dlfiles.
+       nlist="$output_objdir/${my_outputname}.nm"
+
+       func_show_eval "$RM $nlist ${nlist}S ${nlist}T"
+
+       # Parse the name list into a source file.
+       func_verbose "creating $output_objdir/$my_dlsyms"
+
+       $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\
+/* $my_dlsyms - symbol resolution table for \`$my_outputname' dlsym emulation. */
+/* Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION */
+
+#ifdef __cplusplus
+extern \"C\" {
+#endif
+
+/* External symbol declarations for the compiler. */\
+"
+
+       if test "$dlself" = yes; then
+         func_verbose "generating symbol list for \`$output'"
+
+         $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist"
+
+         # Add our own program objects to the symbol list.
+         progfiles=`$ECHO "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
+         for progfile in $progfiles; do
+           func_verbose "extracting global C symbols from \`$progfile'"
+           $opt_dry_run || eval "$NM $progfile | $global_symbol_pipe >> '$nlist'"
+         done
+
+         if test -n "$exclude_expsyms"; then
+           $opt_dry_run || {
+             eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T'
+             eval '$MV "$nlist"T "$nlist"'
+           }
+         fi
+
+         if test -n "$export_symbols_regex"; then
+           $opt_dry_run || {
+             eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T'
+             eval '$MV "$nlist"T "$nlist"'
+           }
+         fi
+
+         # Prepare the list of exported symbols
+         if test -z "$export_symbols"; then
+           export_symbols="$output_objdir/$outputname.exp"
+           $opt_dry_run || {
+             $RM $export_symbols
+             eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
+             case $host in
+             *cygwin* | *mingw* | *cegcc* )
+                eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
+                eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"'
+               ;;
+             esac
+           }
+         else
+           $opt_dry_run || {
+             eval "${SED} -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
+             eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T'
+             eval '$MV "$nlist"T "$nlist"'
+             case $host in
+               *cygwin | *mingw* | *cegcc* )
+                 eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
+                 eval 'cat "$nlist" >> "$output_objdir/$outputname.def"'
+                 ;;
+             esac
+           }
+         fi
+       fi
+
+       for dlprefile in $dlprefiles; do
+         func_verbose "extracting global C symbols from \`$dlprefile'"
+         func_basename "$dlprefile"
+         name="$func_basename_result"
+         $opt_dry_run || {
+           eval '$ECHO ": $name " >> "$nlist"'
+           eval "$NM $dlprefile 2>/dev/null | $global_symbol_pipe >> '$nlist'"
+         }
+       done
+
+       $opt_dry_run || {
+         # Make sure we have at least an empty file.
+         test -f "$nlist" || : > "$nlist"
+
+         if test -n "$exclude_expsyms"; then
+           $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T
+           $MV "$nlist"T "$nlist"
+         fi
+
+         # Try sorting and uniquifying the output.
+         if $GREP -v "^: " < "$nlist" |
+             if sort -k 3 </dev/null >/dev/null 2>&1; then
+               sort -k 3
+             else
+               sort +2
+             fi |
+             uniq > "$nlist"S; then
+           :
+         else
+           $GREP -v "^: " < "$nlist" > "$nlist"S
+         fi
+
+         if test -f "$nlist"S; then
+           eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"'
+         else
+           $ECHO '/* NONE */' >> "$output_objdir/$my_dlsyms"
+         fi
+
+         $ECHO >> "$output_objdir/$my_dlsyms" "\
+
+/* The mapping between symbol names and symbols.  */
+typedef struct {
+  const char *name;
+  void *address;
+} lt_dlsymlist;
+"
+         case $host in
+         *cygwin* | *mingw* | *cegcc* )
+           $ECHO >> "$output_objdir/$my_dlsyms" "\
+/* DATA imports from DLLs on WIN32 con't be const, because
+   runtime relocations are performed -- see ld's documentation
+   on pseudo-relocs.  */"
+           lt_dlsym_const= ;;
+         *osf5*)
+           echo >> "$output_objdir/$my_dlsyms" "\
+/* This system does not cope well with relocations in const data */"
+           lt_dlsym_const= ;;
+         *)
+           lt_dlsym_const=const ;;
+         esac
+
+         $ECHO >> "$output_objdir/$my_dlsyms" "\
+extern $lt_dlsym_const lt_dlsymlist
+lt_${my_prefix}_LTX_preloaded_symbols[];
+$lt_dlsym_const lt_dlsymlist
+lt_${my_prefix}_LTX_preloaded_symbols[] =
+{\
+  { \"$my_originator\", (void *) 0 },"
+
+         case $need_lib_prefix in
+         no)
+           eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms"
+           ;;
+         *)
+           eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms"
+           ;;
+         esac
+         $ECHO >> "$output_objdir/$my_dlsyms" "\
+  {0, (void *) 0}
+};
+
+/* This works around a problem in FreeBSD linker */
+#ifdef FREEBSD_WORKAROUND
+static const void *lt_preloaded_setup() {
+  return lt_${my_prefix}_LTX_preloaded_symbols;
+}
+#endif
+
+#ifdef __cplusplus
+}
+#endif\
+"
+       } # !$opt_dry_run
+
+       pic_flag_for_symtable=
+       case "$compile_command " in
+       *" -static "*) ;;
+       *)
+         case $host in
+         # compiling the symbol table file with pic_flag works around
+         # a FreeBSD bug that causes programs to crash when -lm is
+         # linked before any other PIC object.  But we must not use
+         # pic_flag when linking with -static.  The problem exists in
+         # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1.
+         *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*)
+           pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;;
+         *-*-hpux*)
+           pic_flag_for_symtable=" $pic_flag"  ;;
+         *)
+           if test "X$my_pic_p" != Xno; then
+             pic_flag_for_symtable=" $pic_flag"
+           fi
+           ;;
+         esac
+         ;;
+       esac
+       symtab_cflags=
+       for arg in $LTCFLAGS; do
+         case $arg in
+         -pie | -fpie | -fPIE) ;;
+         *) symtab_cflags="$symtab_cflags $arg" ;;
+         esac
+       done
+
+       # Now compile the dynamic symbol file.
+       func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?'
+
+       # Clean up the generated files.
+       func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T"'
+
+       # Transform the symbol file into the correct name.
+       symfileobj="$output_objdir/${my_outputname}S.$objext"
+       case $host in
+       *cygwin* | *mingw* | *cegcc* )
+         if test -f "$output_objdir/$my_outputname.def"; then
+           compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
+           finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"`
+         else
+           compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
+           finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
+         fi
+         ;;
+       *)
+         compile_command=`$ECHO "X$compile_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
+         finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$symfileobj%"`
+         ;;
+       esac
+       ;;
+      *)
+       func_fatal_error "unknown suffix for \`$my_dlsyms'"
+       ;;
+      esac
+    else
+      # We keep going just in case the user didn't refer to
+      # lt_preloaded_symbols.  The linker will fail if global_symbol_pipe
+      # really was required.
+
+      # Nullify the symbol file.
+      compile_command=`$ECHO "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"`
+      finalize_command=`$ECHO "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"`
+    fi
+}
+
+# func_win32_libid arg
+# return the library type of file 'arg'
+#
+# Need a lot of goo to handle *both* DLLs and import libs
+# Has to be a shell function in order to 'eat' the argument
+# that is supplied when $file_magic_command is called.
+func_win32_libid ()
+{
+  $opt_debug
+  win32_libid_type="unknown"
+  win32_fileres=`file -L $1 2>/dev/null`
+  case $win32_fileres in
+  *ar\ archive\ import\ library*) # definitely import
+    win32_libid_type="x86 archive import"
+    ;;
+  *ar\ archive*) # could be an import, or static
+    if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null |
+       $EGREP 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then
+      win32_nmres=`eval $NM -f posix -A $1 |
+       $SED -n -e '
+           1,100{
+               / I /{
+                   s,.*,import,
+                   p
+                   q
+               }
+           }'`
+      case $win32_nmres in
+      import*)  win32_libid_type="x86 archive import";;
+      *)        win32_libid_type="x86 archive static";;
+      esac
+    fi
+    ;;
+  *DLL*)
+    win32_libid_type="x86 DLL"
+    ;;
+  *executable*) # but shell scripts are "executable" too...
+    case $win32_fileres in
+    *MS\ Windows\ PE\ Intel*)
+      win32_libid_type="x86 DLL"
+      ;;
+    esac
+    ;;
+  esac
+  $ECHO "$win32_libid_type"
+}
+
+
+
+# func_extract_an_archive dir oldlib
+func_extract_an_archive ()
+{
+    $opt_debug
+    f_ex_an_ar_dir="$1"; shift
+    f_ex_an_ar_oldlib="$1"
+    func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" 'exit $?'
+    if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
+     :
+    else
+      func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib"
+    fi
+}
+
+
+# func_extract_archives gentop oldlib ...
+func_extract_archives ()
+{
+    $opt_debug
+    my_gentop="$1"; shift
+    my_oldlibs=${1+"$@"}
+    my_oldobjs=""
+    my_xlib=""
+    my_xabs=""
+    my_xdir=""
+
+    for my_xlib in $my_oldlibs; do
+      # Extract the objects.
+      case $my_xlib in
+       [\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;;
+       *) my_xabs=`pwd`"/$my_xlib" ;;
+      esac
+      func_basename "$my_xlib"
+      my_xlib="$func_basename_result"
+      my_xlib_u=$my_xlib
+      while :; do
+        case " $extracted_archives " in
+       *" $my_xlib_u "*)
+         func_arith $extracted_serial + 1
+         extracted_serial=$func_arith_result
+         my_xlib_u=lt$extracted_serial-$my_xlib ;;
+       *) break ;;
+       esac
+      done
+      extracted_archives="$extracted_archives $my_xlib_u"
+      my_xdir="$my_gentop/$my_xlib_u"
+
+      func_mkdir_p "$my_xdir"
+
+      case $host in
+      *-darwin*)
+       func_verbose "Extracting $my_xabs"
+       # Do not bother doing anything if just a dry run
+       $opt_dry_run || {
+         darwin_orig_dir=`pwd`
+         cd $my_xdir || exit $?
+         darwin_archive=$my_xabs
+         darwin_curdir=`pwd`
+         darwin_base_archive=`basename "$darwin_archive"`
+         darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true`
+         if test -n "$darwin_arches"; then
+           darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'`
+           darwin_arch=
+           func_verbose "$darwin_base_archive has multiple architectures $darwin_arches"
+           for darwin_arch in  $darwin_arches ; do
+             func_mkdir_p "unfat-$$/${darwin_base_archive}-${darwin_arch}"
+             $LIPO -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}"
+             cd "unfat-$$/${darwin_base_archive}-${darwin_arch}"
+             func_extract_an_archive "`pwd`" "${darwin_base_archive}"
+             cd "$darwin_curdir"
+             $RM "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}"
+           done # $darwin_arches
+            ## Okay now we've a bunch of thin objects, gotta fatten them up :)
+           darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$basename" | sort -u`
+           darwin_file=
+           darwin_files=
+           for darwin_file in $darwin_filelist; do
+             darwin_files=`find unfat-$$ -name $darwin_file -print | $NL2SP`
+             $LIPO -create -output "$darwin_file" $darwin_files
+           done # $darwin_filelist
+           $RM -rf unfat-$$
+           cd "$darwin_orig_dir"
+         else
+           cd $darwin_orig_dir
+           func_extract_an_archive "$my_xdir" "$my_xabs"
+         fi # $darwin_arches
+       } # !$opt_dry_run
+       ;;
+      *)
+        func_extract_an_archive "$my_xdir" "$my_xabs"
+       ;;
+      esac
+      my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP`
+    done
+
+    func_extract_archives_result="$my_oldobjs"
+}
+
+
+
+# func_emit_wrapper_part1 [arg=no]
+#
+# Emit the first part of a libtool wrapper script on stdout.
+# For more information, see the description associated with
+# func_emit_wrapper(), below.
+func_emit_wrapper_part1 ()
+{
+       func_emit_wrapper_part1_arg1=no
+       if test -n "$1" ; then
+         func_emit_wrapper_part1_arg1=$1
+       fi
+
+       $ECHO "\
+#! $SHELL
+
+# $output - temporary wrapper script for $objdir/$outputname
+# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+#
+# The $output program cannot be directly executed until all the libtool
+# libraries that it depends on are installed.
+#
+# This wrapper script should never be moved out of the build directory.
+# If it is, it will not operate correctly.
+
+# Sed substitution that helps us do robust quoting.  It backslashifies
+# metacharacters that are still active within double-quoted strings.
+Xsed='${SED} -e 1s/^X//'
+sed_quote_subst='$sed_quote_subst'
+
+# Be Bourne compatible
+if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then
+  emulate sh
+  NULLCMD=:
+  # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which
+  # is contrary to our usage.  Disable this feature.
+  alias -g '\${1+\"\$@\"}'='\"\$@\"'
+  setopt NO_GLOB_SUBST
+else
+  case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac
+fi
+BIN_SH=xpg4; export BIN_SH # for Tru64
+DUALCASE=1; export DUALCASE # for MKS sh
+
+# The HP-UX ksh and POSIX shell print the target directory to stdout
+# if CDPATH is set.
+(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
+
+relink_command=\"$relink_command\"
+
+# This environment variable determines our operation mode.
+if test \"\$libtool_install_magic\" = \"$magic\"; then
+  # install mode needs the following variables:
+  generated_by_libtool_version='$macro_version'
+  notinst_deplibs='$notinst_deplibs'
+else
+  # When we are sourced in execute mode, \$file and \$ECHO are already set.
+  if test \"\$libtool_execute_magic\" != \"$magic\"; then
+    ECHO=\"$qecho\"
+    file=\"\$0\"
+    # Make sure echo works.
+    if test \"X\$1\" = X--no-reexec; then
+      # Discard the --no-reexec flag, and continue.
+      shift
+    elif test \"X\`{ \$ECHO '\t'; } 2>/dev/null\`\" = 'X\t'; then
+      # Yippee, \$ECHO works!
+      :
+    else
+      # Restart under the correct shell, and then maybe \$ECHO will work.
+      exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"}
+    fi
+  fi\
+"
+       $ECHO "\
+
+  # Find the directory that this script lives in.
+  thisdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\`
+  test \"x\$thisdir\" = \"x\$file\" && thisdir=.
+
+  # Follow symbolic links until we get to the real thisdir.
+  file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\`
+  while test -n \"\$file\"; do
+    destdir=\`\$ECHO \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\`
+
+    # If there was a directory component, then change thisdir.
+    if test \"x\$destdir\" != \"x\$file\"; then
+      case \"\$destdir\" in
+      [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;;
+      *) thisdir=\"\$thisdir/\$destdir\" ;;
+      esac
+    fi
+
+    file=\`\$ECHO \"X\$file\" | \$Xsed -e 's%^.*/%%'\`
+    file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\`
+  done
+"
+}
+# end: func_emit_wrapper_part1
+
+# func_emit_wrapper_part2 [arg=no]
+#
+# Emit the second part of a libtool wrapper script on stdout.
+# For more information, see the description associated with
+# func_emit_wrapper(), below.
+func_emit_wrapper_part2 ()
+{
+       func_emit_wrapper_part2_arg1=no
+       if test -n "$1" ; then
+         func_emit_wrapper_part2_arg1=$1
+       fi
+
+       $ECHO "\
+
+  # Usually 'no', except on cygwin/mingw when embedded into
+  # the cwrapper.
+  WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_part2_arg1
+  if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then
+    # special case for '.'
+    if test \"\$thisdir\" = \".\"; then
+      thisdir=\`pwd\`
+    fi
+    # remove .libs from thisdir
+    case \"\$thisdir\" in
+    *[\\\\/]$objdir ) thisdir=\`\$ECHO \"X\$thisdir\" | \$Xsed -e 's%[\\\\/][^\\\\/]*$%%'\` ;;
+    $objdir )   thisdir=. ;;
+    esac
+  fi
+
+  # Try to get the absolute directory name.
+  absdir=\`cd \"\$thisdir\" && pwd\`
+  test -n \"\$absdir\" && thisdir=\"\$absdir\"
+"
+
+       if test "$fast_install" = yes; then
+         $ECHO "\
+  program=lt-'$outputname'$exeext
+  progdir=\"\$thisdir/$objdir\"
+
+  if test ! -f \"\$progdir/\$program\" ||
+     { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\
+       test \"X\$file\" != \"X\$progdir/\$program\"; }; then
+
+    file=\"\$\$-\$program\"
+
+    if test ! -d \"\$progdir\"; then
+      $MKDIR \"\$progdir\"
+    else
+      $RM \"\$progdir/\$file\"
+    fi"
+
+         $ECHO "\
+
+    # relink executable if necessary
+    if test -n \"\$relink_command\"; then
+      if relink_command_output=\`eval \$relink_command 2>&1\`; then :
+      else
+       $ECHO \"\$relink_command_output\" >&2
+       $RM \"\$progdir/\$file\"
+       exit 1
+      fi
+    fi
+
+    $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null ||
+    { $RM \"\$progdir/\$program\";
+      $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; }
+    $RM \"\$progdir/\$file\"
+  fi"
+       else
+         $ECHO "\
+  program='$outputname'
+  progdir=\"\$thisdir/$objdir\"
+"
+       fi
+
+       $ECHO "\
+
+  if test -f \"\$progdir/\$program\"; then"
+
+       # Export our shlibpath_var if we have one.
+       if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
+         $ECHO "\
+    # Add our own library path to $shlibpath_var
+    $shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
+
+    # Some systems cannot cope with colon-terminated $shlibpath_var
+    # The second colon is a workaround for a bug in BeOS R4 sed
+    $shlibpath_var=\`\$ECHO \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\`
+
+    export $shlibpath_var
+"
+       fi
+
+       # fixup the dll searchpath if we need to.
+       if test -n "$dllsearchpath"; then
+         $ECHO "\
+    # Add the dll search path components to the executable PATH
+    PATH=$dllsearchpath:\$PATH
+"
+       fi
+
+       $ECHO "\
+    if test \"\$libtool_execute_magic\" != \"$magic\"; then
+      # Run the actual program with our arguments.
+"
+       case $host in
+       # Backslashes separate directories on plain windows
+       *-*-mingw | *-*-os2* | *-cegcc*)
+         $ECHO "\
+      exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
+"
+         ;;
+
+       *)
+         $ECHO "\
+      exec \"\$progdir/\$program\" \${1+\"\$@\"}
+"
+         ;;
+       esac
+       $ECHO "\
+      \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2
+      exit 1
+    fi
+  else
+    # The program doesn't exist.
+    \$ECHO \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2
+    \$ECHO \"This script is just a wrapper for \$program.\" 1>&2
+    $ECHO \"See the $PACKAGE documentation for more information.\" 1>&2
+    exit 1
+  fi
+fi\
+"
+}
+# end: func_emit_wrapper_part2
+
+
+# func_emit_wrapper [arg=no]
+#
+# Emit a libtool wrapper script on stdout.
+# Don't directly open a file because we may want to
+# incorporate the script contents within a cygwin/mingw
+# wrapper executable.  Must ONLY be called from within
+# func_mode_link because it depends on a number of variables
+# set therein.
+#
+# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR
+# variable will take.  If 'yes', then the emitted script
+# will assume that the directory in which it is stored is
+# the $objdir directory.  This is a cygwin/mingw-specific
+# behavior.
+func_emit_wrapper ()
+{
+       func_emit_wrapper_arg1=no
+       if test -n "$1" ; then
+         func_emit_wrapper_arg1=$1
+       fi
+
+       # split this up so that func_emit_cwrapperexe_src
+       # can call each part independently.
+       func_emit_wrapper_part1 "${func_emit_wrapper_arg1}"
+       func_emit_wrapper_part2 "${func_emit_wrapper_arg1}"
+}
+
+
+# func_to_host_path arg
+#
+# Convert paths to host format when used with build tools.
+# Intended for use with "native" mingw (where libtool itself
+# is running under the msys shell), or in the following cross-
+# build environments:
+#    $build          $host
+#    mingw (msys)    mingw  [e.g. native]
+#    cygwin          mingw
+#    *nix + wine     mingw
+# where wine is equipped with the `winepath' executable.
+# In the native mingw case, the (msys) shell automatically
+# converts paths for any non-msys applications it launches,
+# but that facility isn't available from inside the cwrapper.
+# Similar accommodations are necessary for $host mingw and
+# $build cygwin.  Calling this function does no harm for other
+# $host/$build combinations not listed above.
+#
+# ARG is the path (on $build) that should be converted to
+# the proper representation for $host. The result is stored
+# in $func_to_host_path_result.
+func_to_host_path ()
+{
+  func_to_host_path_result="$1"
+  if test -n "$1" ; then
+    case $host in
+      *mingw* )
+        lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
+        case $build in
+          *mingw* ) # actually, msys
+            # awkward: cmd appends spaces to result
+            lt_sed_strip_trailing_spaces="s/[ ]*\$//"
+            func_to_host_path_tmp1=`( cmd //c echo "$1" |\
+              $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""`
+            func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\
+              $SED -e "$lt_sed_naive_backslashify"`
+            ;;
+          *cygwin* )
+            func_to_host_path_tmp1=`cygpath -w "$1"`
+            func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\
+              $SED -e "$lt_sed_naive_backslashify"`
+            ;;
+          * )
+            # Unfortunately, winepath does not exit with a non-zero
+            # error code, so we are forced to check the contents of
+            # stdout. On the other hand, if the command is not
+            # found, the shell will set an exit code of 127 and print
+            # *an error message* to stdout. So we must check for both
+            # error code of zero AND non-empty stdout, which explains
+            # the odd construction:
+            func_to_host_path_tmp1=`winepath -w "$1" 2>/dev/null`
+            if test "$?" -eq 0 && test -n "${func_to_host_path_tmp1}"; then
+              func_to_host_path_result=`echo "$func_to_host_path_tmp1" |\
+                $SED -e "$lt_sed_naive_backslashify"`
+            else
+              # Allow warning below.
+              func_to_host_path_result=""
+            fi
+            ;;
+        esac
+        if test -z "$func_to_host_path_result" ; then
+          func_error "Could not determine host path corresponding to"
+          func_error "  '$1'"
+          func_error "Continuing, but uninstalled executables may not work."
+          # Fallback:
+          func_to_host_path_result="$1"
+        fi
+        ;;
+    esac
+  fi
+}
+# end: func_to_host_path
+
+# func_to_host_pathlist arg
+#
+# Convert pathlists to host format when used with build tools.
+# See func_to_host_path(), above. This function supports the
+# following $build/$host combinations (but does no harm for
+# combinations not listed here):
+#    $build          $host
+#    mingw (msys)    mingw  [e.g. native]
+#    cygwin          mingw
+#    *nix + wine     mingw
+#
+# Path separators are also converted from $build format to
+# $host format. If ARG begins or ends with a path separator
+# character, it is preserved (but converted to $host format)
+# on output.
+#
+# ARG is a pathlist (on $build) that should be converted to
+# the proper representation on $host. The result is stored
+# in $func_to_host_pathlist_result.
+func_to_host_pathlist ()
+{
+  func_to_host_pathlist_result="$1"
+  if test -n "$1" ; then
+    case $host in
+      *mingw* )
+        lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
+        # Remove leading and trailing path separator characters from
+        # ARG. msys behavior is inconsistent here, cygpath turns them
+        # into '.;' and ';.', and winepath ignores them completely.
+        func_to_host_pathlist_tmp2="$1"
+        # Once set for this call, this variable should not be
+        # reassigned. It is used in tha fallback case.
+        func_to_host_pathlist_tmp1=`echo "$func_to_host_pathlist_tmp2" |\
+          $SED -e 's|^:*||' -e 's|:*$||'`
+        case $build in
+          *mingw* ) # Actually, msys.
+            # Awkward: cmd appends spaces to result.
+            lt_sed_strip_trailing_spaces="s/[ ]*\$//"
+            func_to_host_pathlist_tmp2=`( cmd //c echo "$func_to_host_pathlist_tmp1" |\
+              $SED -e "$lt_sed_strip_trailing_spaces" ) 2>/dev/null || echo ""`
+            func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\
+              $SED -e "$lt_sed_naive_backslashify"`
+            ;;
+          *cygwin* )
+            func_to_host_pathlist_tmp2=`cygpath -w -p "$func_to_host_pathlist_tmp1"`
+            func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp2" |\
+              $SED -e "$lt_sed_naive_backslashify"`
+            ;;
+          * )
+            # unfortunately, winepath doesn't convert pathlists
+            func_to_host_pathlist_result=""
+            func_to_host_pathlist_oldIFS=$IFS
+            IFS=:
+            for func_to_host_pathlist_f in $func_to_host_pathlist_tmp1 ; do
+              IFS=$func_to_host_pathlist_oldIFS
+              if test -n "$func_to_host_pathlist_f" ; then
+                func_to_host_path "$func_to_host_pathlist_f"
+                if test -n "$func_to_host_path_result" ; then
+                  if test -z "$func_to_host_pathlist_result" ; then
+                    func_to_host_pathlist_result="$func_to_host_path_result"
+                  else
+                    func_to_host_pathlist_result="$func_to_host_pathlist_result;$func_to_host_path_result"
+                  fi
+                fi
+              fi
+              IFS=:
+            done
+            IFS=$func_to_host_pathlist_oldIFS
+            ;;
+        esac
+        if test -z "$func_to_host_pathlist_result" ; then
+          func_error "Could not determine the host path(s) corresponding to"
+          func_error "  '$1'"
+          func_error "Continuing, but uninstalled executables may not work."
+          # Fallback. This may break if $1 contains DOS-style drive
+          # specifications. The fix is not to complicate the expression
+          # below, but for the user to provide a working wine installation
+          # with winepath so that path translation in the cross-to-mingw
+          # case works properly.
+          lt_replace_pathsep_nix_to_dos="s|:|;|g"
+          func_to_host_pathlist_result=`echo "$func_to_host_pathlist_tmp1" |\
+            $SED -e "$lt_replace_pathsep_nix_to_dos"`
+        fi
+        # Now, add the leading and trailing path separators back
+        case "$1" in
+          :* ) func_to_host_pathlist_result=";$func_to_host_pathlist_result"
+            ;;
+        esac
+        case "$1" in
+          *: ) func_to_host_pathlist_result="$func_to_host_pathlist_result;"
+            ;;
+        esac
+        ;;
+    esac
+  fi
+}
+# end: func_to_host_pathlist
+
+# func_emit_cwrapperexe_src
+# emit the source code for a wrapper executable on stdout
+# Must ONLY be called from within func_mode_link because
+# it depends on a number of variable set therein.
+func_emit_cwrapperexe_src ()
+{
+       cat <<EOF
+
+/* $cwrappersource - temporary wrapper executable for $objdir/$outputname
+   Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+
+   The $output program cannot be directly executed until all the libtool
+   libraries that it depends on are installed.
+
+   This wrapper executable should never be moved out of the build directory.
+   If it is, it will not operate correctly.
+
+   Currently, it simply execs the wrapper *script* "$SHELL $output",
+   but could eventually absorb all of the scripts functionality and
+   exec $objdir/$outputname directly.
+*/
+EOF
+           cat <<"EOF"
+#include <stdio.h>
+#include <stdlib.h>
+#ifdef _MSC_VER
+# include <direct.h>
+# include <process.h>
+# include <io.h>
+# define setmode _setmode
+#else
+# include <unistd.h>
+# include <stdint.h>
+# ifdef __CYGWIN__
+#  include <io.h>
+#  define HAVE_SETENV
+#  ifdef __STRICT_ANSI__
+char *realpath (const char *, char *);
+int putenv (char *);
+int setenv (const char *, const char *, int);
+#  endif
+# endif
+#endif
+#include <malloc.h>
+#include <stdarg.h>
+#include <assert.h>
+#include <string.h>
+#include <ctype.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <sys/stat.h>
+
+#if defined(PATH_MAX)
+# define LT_PATHMAX PATH_MAX
+#elif defined(MAXPATHLEN)
+# define LT_PATHMAX MAXPATHLEN
+#else
+# define LT_PATHMAX 1024
+#endif
+
+#ifndef S_IXOTH
+# define S_IXOTH 0
+#endif
+#ifndef S_IXGRP
+# define S_IXGRP 0
+#endif
+
+#ifdef _MSC_VER
+# define S_IXUSR _S_IEXEC
+# define stat _stat
+# ifndef _INTPTR_T_DEFINED
+#  define intptr_t int
+# endif
+#endif
+
+#ifndef DIR_SEPARATOR
+# define DIR_SEPARATOR '/'
+# define PATH_SEPARATOR ':'
+#endif
+
+#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \
+  defined (__OS2__)
+# define HAVE_DOS_BASED_FILE_SYSTEM
+# define FOPEN_WB "wb"
+# ifndef DIR_SEPARATOR_2
+#  define DIR_SEPARATOR_2 '\\'
+# endif
+# ifndef PATH_SEPARATOR_2
+#  define PATH_SEPARATOR_2 ';'
+# endif
+#endif
+
+#ifndef DIR_SEPARATOR_2
+# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR)
+#else /* DIR_SEPARATOR_2 */
+# define IS_DIR_SEPARATOR(ch) \
+       (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2))
+#endif /* DIR_SEPARATOR_2 */
+
+#ifndef PATH_SEPARATOR_2
+# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR)
+#else /* PATH_SEPARATOR_2 */
+# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2)
+#endif /* PATH_SEPARATOR_2 */
+
+#ifdef __CYGWIN__
+# define FOPEN_WB "wb"
+#endif
+
+#ifndef FOPEN_WB
+# define FOPEN_WB "w"
+#endif
+#ifndef _O_BINARY
+# define _O_BINARY 0
+#endif
+
+#define XMALLOC(type, num)      ((type *) xmalloc ((num) * sizeof(type)))
+#define XFREE(stale) do { \
+  if (stale) { free ((void *) stale); stale = 0; } \
+} while (0)
+
+#undef LTWRAPPER_DEBUGPRINTF
+#if defined DEBUGWRAPPER
+# define LTWRAPPER_DEBUGPRINTF(args) ltwrapper_debugprintf args
+static void
+ltwrapper_debugprintf (const char *fmt, ...)
+{
+    va_list args;
+    va_start (args, fmt);
+    (void) vfprintf (stderr, fmt, args);
+    va_end (args);
+}
+#else
+# define LTWRAPPER_DEBUGPRINTF(args)
+#endif
+
+const char *program_name = NULL;
+
+void *xmalloc (size_t num);
+char *xstrdup (const char *string);
+const char *base_name (const char *name);
+char *find_executable (const char *wrapper);
+char *chase_symlinks (const char *pathspec);
+int make_executable (const char *path);
+int check_executable (const char *path);
+char *strendzap (char *str, const char *pat);
+void lt_fatal (const char *message, ...);
+void lt_setenv (const char *name, const char *value);
+char *lt_extend_str (const char *orig_value, const char *add, int to_end);
+void lt_opt_process_env_set (const char *arg);
+void lt_opt_process_env_prepend (const char *arg);
+void lt_opt_process_env_append (const char *arg);
+int lt_split_name_value (const char *arg, char** name, char** value);
+void lt_update_exe_path (const char *name, const char *value);
+void lt_update_lib_path (const char *name, const char *value);
+
+static const char *script_text_part1 =
+EOF
+
+           func_emit_wrapper_part1 yes |
+               $SED -e 's/\([\\"]\)/\\\1/g' \
+                    -e 's/^/  "/' -e 's/$/\\n"/'
+           echo ";"
+           cat <<EOF
+
+static const char *script_text_part2 =
+EOF
+           func_emit_wrapper_part2 yes |
+               $SED -e 's/\([\\"]\)/\\\1/g' \
+                    -e 's/^/  "/' -e 's/$/\\n"/'
+           echo ";"
+
+           cat <<EOF
+const char * MAGIC_EXE = "$magic_exe";
+const char * LIB_PATH_VARNAME = "$shlibpath_var";
+EOF
+
+           if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
+              func_to_host_pathlist "$temp_rpath"
+             cat <<EOF
+const char * LIB_PATH_VALUE   = "$func_to_host_pathlist_result";
+EOF
+           else
+             cat <<"EOF"
+const char * LIB_PATH_VALUE   = "";
+EOF
+           fi
+
+           if test -n "$dllsearchpath"; then
+              func_to_host_pathlist "$dllsearchpath:"
+             cat <<EOF
+const char * EXE_PATH_VARNAME = "PATH";
+const char * EXE_PATH_VALUE   = "$func_to_host_pathlist_result";
+EOF
+           else
+             cat <<"EOF"
+const char * EXE_PATH_VARNAME = "";
+const char * EXE_PATH_VALUE   = "";
+EOF
+           fi
+
+           if test "$fast_install" = yes; then
+             cat <<EOF
+const char * TARGET_PROGRAM_NAME = "lt-$outputname"; /* hopefully, no .exe */
+EOF
+           else
+             cat <<EOF
+const char * TARGET_PROGRAM_NAME = "$outputname"; /* hopefully, no .exe */
+EOF
+           fi
+
+
+           cat <<"EOF"
+
+#define LTWRAPPER_OPTION_PREFIX         "--lt-"
+#define LTWRAPPER_OPTION_PREFIX_LENGTH  5
+
+static const size_t opt_prefix_len         = LTWRAPPER_OPTION_PREFIX_LENGTH;
+static const char *ltwrapper_option_prefix = LTWRAPPER_OPTION_PREFIX;
+
+static const char *dumpscript_opt       = LTWRAPPER_OPTION_PREFIX "dump-script";
+
+static const size_t env_set_opt_len     = LTWRAPPER_OPTION_PREFIX_LENGTH + 7;
+static const char *env_set_opt          = LTWRAPPER_OPTION_PREFIX "env-set";
+  /* argument is putenv-style "foo=bar", value of foo is set to bar */
+
+static const size_t env_prepend_opt_len = LTWRAPPER_OPTION_PREFIX_LENGTH + 11;
+static const char *env_prepend_opt      = LTWRAPPER_OPTION_PREFIX "env-prepend";
+  /* argument is putenv-style "foo=bar", new value of foo is bar${foo} */
+
+static const size_t env_append_opt_len  = LTWRAPPER_OPTION_PREFIX_LENGTH + 10;
+static const char *env_append_opt       = LTWRAPPER_OPTION_PREFIX "env-append";
+  /* argument is putenv-style "foo=bar", new value of foo is ${foo}bar */
+
+int
+main (int argc, char *argv[])
+{
+  char **newargz;
+  int  newargc;
+  char *tmp_pathspec;
+  char *actual_cwrapper_path;
+  char *actual_cwrapper_name;
+  char *target_name;
+  char *lt_argv_zero;
+  intptr_t rval = 127;
+
+  int i;
+
+  program_name = (char *) xstrdup (base_name (argv[0]));
+  LTWRAPPER_DEBUGPRINTF (("(main) argv[0]      : %s\n", argv[0]));
+  LTWRAPPER_DEBUGPRINTF (("(main) program_name : %s\n", program_name));
+
+  /* very simple arg parsing; don't want to rely on getopt */
+  for (i = 1; i < argc; i++)
+    {
+      if (strcmp (argv[i], dumpscript_opt) == 0)
+       {
+EOF
+           case "$host" in
+             *mingw* | *cygwin* )
+               # make stdout use "unix" line endings
+               echo "          setmode(1,_O_BINARY);"
+               ;;
+             esac
+
+           cat <<"EOF"
+         printf ("%s", script_text_part1);
+         printf ("%s", script_text_part2);
+         return 0;
+       }
+    }
+
+  newargz = XMALLOC (char *, argc + 1);
+  tmp_pathspec = find_executable (argv[0]);
+  if (tmp_pathspec == NULL)
+    lt_fatal ("Couldn't find %s", argv[0]);
+  LTWRAPPER_DEBUGPRINTF (("(main) found exe (before symlink chase) at : %s\n",
+                         tmp_pathspec));
+
+  actual_cwrapper_path = chase_symlinks (tmp_pathspec);
+  LTWRAPPER_DEBUGPRINTF (("(main) found exe (after symlink chase) at : %s\n",
+                         actual_cwrapper_path));
+  XFREE (tmp_pathspec);
+
+  actual_cwrapper_name = xstrdup( base_name (actual_cwrapper_path));
+  strendzap (actual_cwrapper_path, actual_cwrapper_name);
+
+  /* wrapper name transforms */
+  strendzap (actual_cwrapper_name, ".exe");
+  tmp_pathspec = lt_extend_str (actual_cwrapper_name, ".exe", 1);
+  XFREE (actual_cwrapper_name);
+  actual_cwrapper_name = tmp_pathspec;
+  tmp_pathspec = 0;
+
+  /* target_name transforms -- use actual target program name; might have lt- prefix */
+  target_name = xstrdup (base_name (TARGET_PROGRAM_NAME));
+  strendzap (target_name, ".exe");
+  tmp_pathspec = lt_extend_str (target_name, ".exe", 1);
+  XFREE (target_name);
+  target_name = tmp_pathspec;
+  tmp_pathspec = 0;
+
+  LTWRAPPER_DEBUGPRINTF (("(main) libtool target name: %s\n",
+                         target_name));
+EOF
+
+           cat <<EOF
+  newargz[0] =
+    XMALLOC (char, (strlen (actual_cwrapper_path) +
+                   strlen ("$objdir") + 1 + strlen (actual_cwrapper_name) + 1));
+  strcpy (newargz[0], actual_cwrapper_path);
+  strcat (newargz[0], "$objdir");
+  strcat (newargz[0], "/");
+EOF
+
+           cat <<"EOF"
+  /* stop here, and copy so we don't have to do this twice */
+  tmp_pathspec = xstrdup (newargz[0]);
+
+  /* do NOT want the lt- prefix here, so use actual_cwrapper_name */
+  strcat (newargz[0], actual_cwrapper_name);
+
+  /* DO want the lt- prefix here if it exists, so use target_name */
+  lt_argv_zero = lt_extend_str (tmp_pathspec, target_name, 1);
+  XFREE (tmp_pathspec);
+  tmp_pathspec = NULL;
+EOF
+
+           case $host_os in
+             mingw*)
+           cat <<"EOF"
+  {
+    char* p;
+    while ((p = strchr (newargz[0], '\\')) != NULL)
+      {
+       *p = '/';
+      }
+    while ((p = strchr (lt_argv_zero, '\\')) != NULL)
+      {
+       *p = '/';
+      }
+  }
+EOF
+           ;;
+           esac
+
+           cat <<"EOF"
+  XFREE (target_name);
+  XFREE (actual_cwrapper_path);
+  XFREE (actual_cwrapper_name);
+
+  lt_setenv ("BIN_SH", "xpg4"); /* for Tru64 */
+  lt_setenv ("DUALCASE", "1");  /* for MSK sh */
+  lt_update_lib_path (LIB_PATH_VARNAME, LIB_PATH_VALUE);
+  lt_update_exe_path (EXE_PATH_VARNAME, EXE_PATH_VALUE);
+
+  newargc=0;
+  for (i = 1; i < argc; i++)
+    {
+      if (strncmp (argv[i], env_set_opt, env_set_opt_len) == 0)
+        {
+          if (argv[i][env_set_opt_len] == '=')
+            {
+              const char *p = argv[i] + env_set_opt_len + 1;
+              lt_opt_process_env_set (p);
+            }
+          else if (argv[i][env_set_opt_len] == '\0' && i + 1 < argc)
+            {
+              lt_opt_process_env_set (argv[++i]); /* don't copy */
+            }
+          else
+            lt_fatal ("%s missing required argument", env_set_opt);
+          continue;
+        }
+      if (strncmp (argv[i], env_prepend_opt, env_prepend_opt_len) == 0)
+        {
+          if (argv[i][env_prepend_opt_len] == '=')
+            {
+              const char *p = argv[i] + env_prepend_opt_len + 1;
+              lt_opt_process_env_prepend (p);
+            }
+          else if (argv[i][env_prepend_opt_len] == '\0' && i + 1 < argc)
+            {
+              lt_opt_process_env_prepend (argv[++i]); /* don't copy */
+            }
+          else
+            lt_fatal ("%s missing required argument", env_prepend_opt);
+          continue;
+        }
+      if (strncmp (argv[i], env_append_opt, env_append_opt_len) == 0)
+        {
+          if (argv[i][env_append_opt_len] == '=')
+            {
+              const char *p = argv[i] + env_append_opt_len + 1;
+              lt_opt_process_env_append (p);
+            }
+          else if (argv[i][env_append_opt_len] == '\0' && i + 1 < argc)
+            {
+              lt_opt_process_env_append (argv[++i]); /* don't copy */
+            }
+          else
+            lt_fatal ("%s missing required argument", env_append_opt);
+          continue;
+        }
+      if (strncmp (argv[i], ltwrapper_option_prefix, opt_prefix_len) == 0)
+        {
+          /* however, if there is an option in the LTWRAPPER_OPTION_PREFIX
+             namespace, but it is not one of the ones we know about and
+             have already dealt with, above (inluding dump-script), then
+             report an error. Otherwise, targets might begin to believe
+             they are allowed to use options in the LTWRAPPER_OPTION_PREFIX
+             namespace. The first time any user complains about this, we'll
+             need to make LTWRAPPER_OPTION_PREFIX a configure-time option
+             or a configure.ac-settable value.
+           */
+          lt_fatal ("Unrecognized option in %s namespace: '%s'",
+                    ltwrapper_option_prefix, argv[i]);
+        }
+      /* otherwise ... */
+      newargz[++newargc] = xstrdup (argv[i]);
+    }
+  newargz[++newargc] = NULL;
+
+  LTWRAPPER_DEBUGPRINTF     (("(main) lt_argv_zero : %s\n", (lt_argv_zero ? lt_argv_zero : "<NULL>")));
+  for (i = 0; i < newargc; i++)
+    {
+      LTWRAPPER_DEBUGPRINTF (("(main) newargz[%d]   : %s\n", i, (newargz[i] ? newargz[i] : "<NULL>")));
+    }
+
+EOF
+
+           case $host_os in
+             mingw*)
+               cat <<"EOF"
+  /* execv doesn't actually work on mingw as expected on unix */
+  rval = _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
+  if (rval == -1)
+    {
+      /* failed to start process */
+      LTWRAPPER_DEBUGPRINTF (("(main) failed to launch target \"%s\": errno = %d\n", lt_argv_zero, errno));
+      return 127;
+    }
+  return rval;
+EOF
+               ;;
+             *)
+               cat <<"EOF"
+  execv (lt_argv_zero, newargz);
+  return rval; /* =127, but avoids unused variable warning */
+EOF
+               ;;
+           esac
+
+           cat <<"EOF"
+}
+
+void *
+xmalloc (size_t num)
+{
+  void *p = (void *) malloc (num);
+  if (!p)
+    lt_fatal ("Memory exhausted");
+
+  return p;
+}
+
+char *
+xstrdup (const char *string)
+{
+  return string ? strcpy ((char *) xmalloc (strlen (string) + 1),
+                         string) : NULL;
+}
+
+const char *
+base_name (const char *name)
+{
+  const char *base;
+
+#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+  /* Skip over the disk name in MSDOS pathnames. */
+  if (isalpha ((unsigned char) name[0]) && name[1] == ':')
+    name += 2;
+#endif
+
+  for (base = name; *name; name++)
+    if (IS_DIR_SEPARATOR (*name))
+      base = name + 1;
+  return base;
+}
+
+int
+check_executable (const char *path)
+{
+  struct stat st;
+
+  LTWRAPPER_DEBUGPRINTF (("(check_executable)  : %s\n",
+                         path ? (*path ? path : "EMPTY!") : "NULL!"));
+  if ((!path) || (!*path))
+    return 0;
+
+  if ((stat (path, &st) >= 0)
+      && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH)))
+    return 1;
+  else
+    return 0;
+}
+
+int
+make_executable (const char *path)
+{
+  int rval = 0;
+  struct stat st;
+
+  LTWRAPPER_DEBUGPRINTF (("(make_executable)   : %s\n",
+                         path ? (*path ? path : "EMPTY!") : "NULL!"));
+  if ((!path) || (!*path))
+    return 0;
+
+  if (stat (path, &st) >= 0)
+    {
+      rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR);
+    }
+  return rval;
+}
+
+/* Searches for the full path of the wrapper.  Returns
+   newly allocated full path name if found, NULL otherwise
+   Does not chase symlinks, even on platforms that support them.
+*/
+char *
+find_executable (const char *wrapper)
+{
+  int has_slash = 0;
+  const char *p;
+  const char *p_next;
+  /* static buffer for getcwd */
+  char tmp[LT_PATHMAX + 1];
+  int tmp_len;
+  char *concat_name;
+
+  LTWRAPPER_DEBUGPRINTF (("(find_executable)   : %s\n",
+                         wrapper ? (*wrapper ? wrapper : "EMPTY!") : "NULL!"));
+
+  if ((wrapper == NULL) || (*wrapper == '\0'))
+    return NULL;
+
+  /* Absolute path? */
+#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+  if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':')
+    {
+      concat_name = xstrdup (wrapper);
+      if (check_executable (concat_name))
+       return concat_name;
+      XFREE (concat_name);
+    }
+  else
+    {
+#endif
+      if (IS_DIR_SEPARATOR (wrapper[0]))
+       {
+         concat_name = xstrdup (wrapper);
+         if (check_executable (concat_name))
+           return concat_name;
+         XFREE (concat_name);
+       }
+#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+    }
+#endif
+
+  for (p = wrapper; *p; p++)
+    if (*p == '/')
+      {
+       has_slash = 1;
+       break;
+      }
+  if (!has_slash)
+    {
+      /* no slashes; search PATH */
+      const char *path = getenv ("PATH");
+      if (path != NULL)
+       {
+         for (p = path; *p; p = p_next)
+           {
+             const char *q;
+             size_t p_len;
+             for (q = p; *q; q++)
+               if (IS_PATH_SEPARATOR (*q))
+                 break;
+             p_len = q - p;
+             p_next = (*q == '\0' ? q : q + 1);
+             if (p_len == 0)
+               {
+                 /* empty path: current directory */
+                 if (getcwd (tmp, LT_PATHMAX) == NULL)
+                   lt_fatal ("getcwd failed");
+                 tmp_len = strlen (tmp);
+                 concat_name =
+                   XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1);
+                 memcpy (concat_name, tmp, tmp_len);
+                 concat_name[tmp_len] = '/';
+                 strcpy (concat_name + tmp_len + 1, wrapper);
+               }
+             else
+               {
+                 concat_name =
+                   XMALLOC (char, p_len + 1 + strlen (wrapper) + 1);
+                 memcpy (concat_name, p, p_len);
+                 concat_name[p_len] = '/';
+                 strcpy (concat_name + p_len + 1, wrapper);
+               }
+             if (check_executable (concat_name))
+               return concat_name;
+             XFREE (concat_name);
+           }
+       }
+      /* not found in PATH; assume curdir */
+    }
+  /* Relative path | not found in path: prepend cwd */
+  if (getcwd (tmp, LT_PATHMAX) == NULL)
+    lt_fatal ("getcwd failed");
+  tmp_len = strlen (tmp);
+  concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1);
+  memcpy (concat_name, tmp, tmp_len);
+  concat_name[tmp_len] = '/';
+  strcpy (concat_name + tmp_len + 1, wrapper);
+
+  if (check_executable (concat_name))
+    return concat_name;
+  XFREE (concat_name);
+  return NULL;
+}
+
+char *
+chase_symlinks (const char *pathspec)
+{
+#ifndef S_ISLNK
+  return xstrdup (pathspec);
+#else
+  char buf[LT_PATHMAX];
+  struct stat s;
+  char *tmp_pathspec = xstrdup (pathspec);
+  char *p;
+  int has_symlinks = 0;
+  while (strlen (tmp_pathspec) && !has_symlinks)
+    {
+      LTWRAPPER_DEBUGPRINTF (("checking path component for symlinks: %s\n",
+                             tmp_pathspec));
+      if (lstat (tmp_pathspec, &s) == 0)
+       {
+         if (S_ISLNK (s.st_mode) != 0)
+           {
+             has_symlinks = 1;
+             break;
+           }
+
+         /* search backwards for last DIR_SEPARATOR */
+         p = tmp_pathspec + strlen (tmp_pathspec) - 1;
+         while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p)))
+           p--;
+         if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p)))
+           {
+             /* no more DIR_SEPARATORS left */
+             break;
+           }
+         *p = '\0';
+       }
+      else
+       {
+         char *errstr = strerror (errno);
+         lt_fatal ("Error accessing file %s (%s)", tmp_pathspec, errstr);
+       }
+    }
+  XFREE (tmp_pathspec);
+
+  if (!has_symlinks)
+    {
+      return xstrdup (pathspec);
+    }
+
+  tmp_pathspec = realpath (pathspec, buf);
+  if (tmp_pathspec == 0)
+    {
+      lt_fatal ("Could not follow symlinks for %s", pathspec);
+    }
+  return xstrdup (tmp_pathspec);
+#endif
+}
+
+char *
+strendzap (char *str, const char *pat)
+{
+  size_t len, patlen;
+
+  assert (str != NULL);
+  assert (pat != NULL);
+
+  len = strlen (str);
+  patlen = strlen (pat);
+
+  if (patlen <= len)
+    {
+      str += len - patlen;
+      if (strcmp (str, pat) == 0)
+       *str = '\0';
+    }
+  return str;
+}
+
+static void
+lt_error_core (int exit_status, const char *mode,
+              const char *message, va_list ap)
+{
+  fprintf (stderr, "%s: %s: ", program_name, mode);
+  vfprintf (stderr, message, ap);
+  fprintf (stderr, ".\n");
+
+  if (exit_status >= 0)
+    exit (exit_status);
+}
+
+void
+lt_fatal (const char *message, ...)
+{
+  va_list ap;
+  va_start (ap, message);
+  lt_error_core (EXIT_FAILURE, "FATAL", message, ap);
+  va_end (ap);
+}
+
+void
+lt_setenv (const char *name, const char *value)
+{
+  LTWRAPPER_DEBUGPRINTF (("(lt_setenv) setting '%s' to '%s'\n",
+                          (name ? name : "<NULL>"),
+                          (value ? value : "<NULL>")));
+  {
+#ifdef HAVE_SETENV
+    /* always make a copy, for consistency with !HAVE_SETENV */
+    char *str = xstrdup (value);
+    setenv (name, str, 1);
+#else
+    int len = strlen (name) + 1 + strlen (value) + 1;
+    char *str = XMALLOC (char, len);
+    sprintf (str, "%s=%s", name, value);
+    if (putenv (str) != EXIT_SUCCESS)
+      {
+        XFREE (str);
+      }
+#endif
+  }
+}
+
+char *
+lt_extend_str (const char *orig_value, const char *add, int to_end)
+{
+  char *new_value;
+  if (orig_value && *orig_value)
+    {
+      int orig_value_len = strlen (orig_value);
+      int add_len = strlen (add);
+      new_value = XMALLOC (char, add_len + orig_value_len + 1);
+      if (to_end)
+        {
+          strcpy (new_value, orig_value);
+          strcpy (new_value + orig_value_len, add);
+        }
+      else
+        {
+          strcpy (new_value, add);
+          strcpy (new_value + add_len, orig_value);
+        }
+    }
+  else
+    {
+      new_value = xstrdup (add);
+    }
+  return new_value;
+}
+
+int
+lt_split_name_value (const char *arg, char** name, char** value)
+{
+  const char *p;
+  int len;
+  if (!arg || !*arg)
+    return 1;
+
+  p = strchr (arg, (int)'=');
+
+  if (!p)
+    return 1;
+
+  *value = xstrdup (++p);
+
+  len = strlen (arg) - strlen (*value);
+  *name = XMALLOC (char, len);
+  strncpy (*name, arg, len-1);
+  (*name)[len - 1] = '\0';
+
+  return 0;
+}
+
+void
+lt_opt_process_env_set (const char *arg)
+{
+  char *name = NULL;
+  char *value = NULL;
+
+  if (lt_split_name_value (arg, &name, &value) != 0)
+    {
+      XFREE (name);
+      XFREE (value);
+      lt_fatal ("bad argument for %s: '%s'", env_set_opt, arg);
+    }
+
+  lt_setenv (name, value);
+  XFREE (name);
+  XFREE (value);
+}
+
+void
+lt_opt_process_env_prepend (const char *arg)
+{
+  char *name = NULL;
+  char *value = NULL;
+  char *new_value = NULL;
+
+  if (lt_split_name_value (arg, &name, &value) != 0)
+    {
+      XFREE (name);
+      XFREE (value);
+      lt_fatal ("bad argument for %s: '%s'", env_prepend_opt, arg);
+    }
+
+  new_value = lt_extend_str (getenv (name), value, 0);
+  lt_setenv (name, new_value);
+  XFREE (new_value);
+  XFREE (name);
+  XFREE (value);
+}
+
+void
+lt_opt_process_env_append (const char *arg)
+{
+  char *name = NULL;
+  char *value = NULL;
+  char *new_value = NULL;
+
+  if (lt_split_name_value (arg, &name, &value) != 0)
+    {
+      XFREE (name);
+      XFREE (value);
+      lt_fatal ("bad argument for %s: '%s'", env_append_opt, arg);
+    }
+
+  new_value = lt_extend_str (getenv (name), value, 1);
+  lt_setenv (name, new_value);
+  XFREE (new_value);
+  XFREE (name);
+  XFREE (value);
+}
+
+void
+lt_update_exe_path (const char *name, const char *value)
+{
+  LTWRAPPER_DEBUGPRINTF (("(lt_update_exe_path) modifying '%s' by prepending '%s'\n",
+                          (name ? name : "<NULL>"),
+                          (value ? value : "<NULL>")));
+
+  if (name && *name && value && *value)
+    {
+      char *new_value = lt_extend_str (getenv (name), value, 0);
+      /* some systems can't cope with a ':'-terminated path #' */
+      int len = strlen (new_value);
+      while (((len = strlen (new_value)) > 0) && IS_PATH_SEPARATOR (new_value[len-1]))
+        {
+          new_value[len-1] = '\0';
+        }
+      lt_setenv (name, new_value);
+      XFREE (new_value);
+    }
+}
+
+void
+lt_update_lib_path (const char *name, const char *value)
+{
+  LTWRAPPER_DEBUGPRINTF (("(lt_update_lib_path) modifying '%s' by prepending '%s'\n",
+                          (name ? name : "<NULL>"),
+                          (value ? value : "<NULL>")));
+
+  if (name && *name && value && *value)
+    {
+      char *new_value = lt_extend_str (getenv (name), value, 0);
+      lt_setenv (name, new_value);
+      XFREE (new_value);
+    }
+}
+
+
+EOF
+}
+# end: func_emit_cwrapperexe_src
+
+# func_mode_link arg...
+func_mode_link ()
+{
+    $opt_debug
+    case $host in
+    *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
+      # It is impossible to link a dll without this setting, and
+      # we shouldn't force the makefile maintainer to figure out
+      # which system we are compiling for in order to pass an extra
+      # flag for every libtool invocation.
+      # allow_undefined=no
+
+      # FIXME: Unfortunately, there are problems with the above when trying
+      # to make a dll which has undefined symbols, in which case not
+      # even a static library is built.  For now, we need to specify
+      # -no-undefined on the libtool link line when we can be certain
+      # that all symbols are satisfied, otherwise we get a static library.
+      allow_undefined=yes
+      ;;
+    *)
+      allow_undefined=yes
+      ;;
+    esac
+    libtool_args=$nonopt
+    base_compile="$nonopt $@"
+    compile_command=$nonopt
+    finalize_command=$nonopt
+
+    compile_rpath=
+    finalize_rpath=
+    compile_shlibpath=
+    finalize_shlibpath=
+    convenience=
+    old_convenience=
+    deplibs=
+    old_deplibs=
+    compiler_flags=
+    linker_flags=
+    dllsearchpath=
+    lib_search_path=`pwd`
+    inst_prefix_dir=
+    new_inherited_linker_flags=
+
+    avoid_version=no
+    dlfiles=
+    dlprefiles=
+    dlself=no
+    export_dynamic=no
+    export_symbols=
+    export_symbols_regex=
+    generated=
+    libobjs=
+    ltlibs=
+    module=no
+    no_install=no
+    objs=
+    non_pic_objects=
+    precious_files_regex=
+    prefer_static_libs=no
+    preload=no
+    prev=
+    prevarg=
+    release=
+    rpath=
+    xrpath=
+    perm_rpath=
+    temp_rpath=
+    thread_safe=no
+    vinfo=
+    vinfo_number=no
+    weak_libs=
+    single_module="${wl}-single_module"
+    func_infer_tag $base_compile
+
+    # We need to know -static, to get the right output filenames.
+    for arg
+    do
+      case $arg in
+      -shared)
+       test "$build_libtool_libs" != yes && \
+         func_fatal_configuration "can not build a shared library"
+       build_old_libs=no
+       break
+       ;;
+      -all-static | -static | -static-libtool-libs)
+       case $arg in
+       -all-static)
+         if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then
+           func_warning "complete static linking is impossible in this configuration"
+         fi
+         if test -n "$link_static_flag"; then
+           dlopen_self=$dlopen_self_static
+         fi
+         prefer_static_libs=yes
+         ;;
+       -static)
+         if test -z "$pic_flag" && test -n "$link_static_flag"; then
+           dlopen_self=$dlopen_self_static
+         fi
+         prefer_static_libs=built
+         ;;
+       -static-libtool-libs)
+         if test -z "$pic_flag" && test -n "$link_static_flag"; then
+           dlopen_self=$dlopen_self_static
+         fi
+         prefer_static_libs=yes
+         ;;
+       esac
+       build_libtool_libs=no
+       build_old_libs=yes
+       break
+       ;;
+      esac
+    done
+
+    # See if our shared archives depend on static archives.
+    test -n "$old_archive_from_new_cmds" && build_old_libs=yes
+
+    # Go through the arguments, transforming them on the way.
+    while test "$#" -gt 0; do
+      arg="$1"
+      shift
+      func_quote_for_eval "$arg"
+      qarg=$func_quote_for_eval_unquoted_result
+      func_append libtool_args " $func_quote_for_eval_result"
+
+      # If the previous option needs an argument, assign it.
+      if test -n "$prev"; then
+       case $prev in
+       output)
+         func_append compile_command " @OUTPUT@"
+         func_append finalize_command " @OUTPUT@"
+         ;;
+       esac
+
+       case $prev in
+       dlfiles|dlprefiles)
+         if test "$preload" = no; then
+           # Add the symbol object into the linking commands.
+           func_append compile_command " @SYMFILE@"
+           func_append finalize_command " @SYMFILE@"
+           preload=yes
+         fi
+         case $arg in
+         *.la | *.lo) ;;  # We handle these cases below.
+         force)
+           if test "$dlself" = no; then
+             dlself=needless
+             export_dynamic=yes
+           fi
+           prev=
+           continue
+           ;;
+         self)
+           if test "$prev" = dlprefiles; then
+             dlself=yes
+           elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then
+             dlself=yes
+           else
+             dlself=needless
+             export_dynamic=yes
+           fi
+           prev=
+           continue
+           ;;
+         *)
+           if test "$prev" = dlfiles; then
+             dlfiles="$dlfiles $arg"
+           else
+             dlprefiles="$dlprefiles $arg"
+           fi
+           prev=
+           continue
+           ;;
+         esac
+         ;;
+       expsyms)
+         export_symbols="$arg"
+         test -f "$arg" \
+           || func_fatal_error "symbol file \`$arg' does not exist"
+         prev=
+         continue
+         ;;
+       expsyms_regex)
+         export_symbols_regex="$arg"
+         prev=
+         continue
+         ;;
+       framework)
+         case $host in
+           *-*-darwin*)
+             case "$deplibs " in
+               *" $qarg.ltframework "*) ;;
+               *) deplibs="$deplibs $qarg.ltframework" # this is fixed later
+                  ;;
+             esac
+             ;;
+         esac
+         prev=
+         continue
+         ;;
+       inst_prefix)
+         inst_prefix_dir="$arg"
+         prev=
+         continue
+         ;;
+       objectlist)
+         if test -f "$arg"; then
+           save_arg=$arg
+           moreargs=
+           for fil in `cat "$save_arg"`
+           do
+#            moreargs="$moreargs $fil"
+             arg=$fil
+             # A libtool-controlled object.
+
+             # Check to see that this really is a libtool object.
+             if func_lalib_unsafe_p "$arg"; then
+               pic_object=
+               non_pic_object=
+
+               # Read the .lo file
+               func_source "$arg"
+
+               if test -z "$pic_object" ||
+                  test -z "$non_pic_object" ||
+                  test "$pic_object" = none &&
+                  test "$non_pic_object" = none; then
+                 func_fatal_error "cannot find name of object for \`$arg'"
+               fi
+
+               # Extract subdirectory from the argument.
+               func_dirname "$arg" "/" ""
+               xdir="$func_dirname_result"
+
+               if test "$pic_object" != none; then
+                 # Prepend the subdirectory the object is found in.
+                 pic_object="$xdir$pic_object"
+
+                 if test "$prev" = dlfiles; then
+                   if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
+                     dlfiles="$dlfiles $pic_object"
+                     prev=
+                     continue
+                   else
+                     # If libtool objects are unsupported, then we need to preload.
+                     prev=dlprefiles
+                   fi
+                 fi
+
+                 # CHECK ME:  I think I busted this.  -Ossama
+                 if test "$prev" = dlprefiles; then
+                   # Preload the old-style object.
+                   dlprefiles="$dlprefiles $pic_object"
+                   prev=
+                 fi
+
+                 # A PIC object.
+                 func_append libobjs " $pic_object"
+                 arg="$pic_object"
+               fi
+
+               # Non-PIC object.
+               if test "$non_pic_object" != none; then
+                 # Prepend the subdirectory the object is found in.
+                 non_pic_object="$xdir$non_pic_object"
+
+                 # A standard non-PIC object
+                 func_append non_pic_objects " $non_pic_object"
+                 if test -z "$pic_object" || test "$pic_object" = none ; then
+                   arg="$non_pic_object"
+                 fi
+               else
+                 # If the PIC object exists, use it instead.
+                 # $xdir was prepended to $pic_object above.
+                 non_pic_object="$pic_object"
+                 func_append non_pic_objects " $non_pic_object"
+               fi
+             else
+               # Only an error if not doing a dry-run.
+               if $opt_dry_run; then
+                 # Extract subdirectory from the argument.
+                 func_dirname "$arg" "/" ""
+                 xdir="$func_dirname_result"
+
+                 func_lo2o "$arg"
+                 pic_object=$xdir$objdir/$func_lo2o_result
+                 non_pic_object=$xdir$func_lo2o_result
+                 func_append libobjs " $pic_object"
+                 func_append non_pic_objects " $non_pic_object"
+               else
+                 func_fatal_error "\`$arg' is not a valid libtool object"
+               fi
+             fi
+           done
+         else
+           func_fatal_error "link input file \`$arg' does not exist"
+         fi
+         arg=$save_arg
+         prev=
+         continue
+         ;;
+       precious_regex)
+         precious_files_regex="$arg"
+         prev=
+         continue
+         ;;
+       release)
+         release="-$arg"
+         prev=
+         continue
+         ;;
+       rpath | xrpath)
+         # We need an absolute path.
+         case $arg in
+         [\\/]* | [A-Za-z]:[\\/]*) ;;
+         *)
+           func_fatal_error "only absolute run-paths are allowed"
+           ;;
+         esac
+         if test "$prev" = rpath; then
+           case "$rpath " in
+           *" $arg "*) ;;
+           *) rpath="$rpath $arg" ;;
+           esac
+         else
+           case "$xrpath " in
+           *" $arg "*) ;;
+           *) xrpath="$xrpath $arg" ;;
+           esac
+         fi
+         prev=
+         continue
+         ;;
+       shrext)
+         shrext_cmds="$arg"
+         prev=
+         continue
+         ;;
+       weak)
+         weak_libs="$weak_libs $arg"
+         prev=
+         continue
+         ;;
+       xcclinker)
+         linker_flags="$linker_flags $qarg"
+         compiler_flags="$compiler_flags $qarg"
+         prev=
+         func_append compile_command " $qarg"
+         func_append finalize_command " $qarg"
+         continue
+         ;;
+       xcompiler)
+         compiler_flags="$compiler_flags $qarg"
+         prev=
+         func_append compile_command " $qarg"
+         func_append finalize_command " $qarg"
+         continue
+         ;;
+       xlinker)
+         linker_flags="$linker_flags $qarg"
+         compiler_flags="$compiler_flags $wl$qarg"
+         prev=
+         func_append compile_command " $wl$qarg"
+         func_append finalize_command " $wl$qarg"
+         continue
+         ;;
+       *)
+         eval "$prev=\"\$arg\""
+         prev=
+         continue
+         ;;
+       esac
+      fi # test -n "$prev"
+
+      prevarg="$arg"
+
+      case $arg in
+      -all-static)
+       if test -n "$link_static_flag"; then
+         # See comment for -static flag below, for more details.
+         func_append compile_command " $link_static_flag"
+         func_append finalize_command " $link_static_flag"
+       fi
+       continue
+       ;;
+
+      -allow-undefined)
+       # FIXME: remove this flag sometime in the future.
+       func_fatal_error "\`-allow-undefined' must not be used because it is the default"
+       ;;
+
+      -avoid-version)
+       avoid_version=yes
+       continue
+       ;;
+
+      -dlopen)
+       prev=dlfiles
+       continue
+       ;;
+
+      -dlpreopen)
+       prev=dlprefiles
+       continue
+       ;;
+
+      -export-dynamic)
+       export_dynamic=yes
+       continue
+       ;;
+
+      -export-symbols | -export-symbols-regex)
+       if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
+         func_fatal_error "more than one -exported-symbols argument is not allowed"
+       fi
+       if test "X$arg" = "X-export-symbols"; then
+         prev=expsyms
+       else
+         prev=expsyms_regex
+       fi
+       continue
+       ;;
+
+      -framework)
+       prev=framework
+       continue
+       ;;
+
+      -inst-prefix-dir)
+       prev=inst_prefix
+       continue
+       ;;
+
+      # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:*
+      # so, if we see these flags be careful not to treat them like -L
+      -L[A-Z][A-Z]*:*)
+       case $with_gcc/$host in
+       no/*-*-irix* | /*-*-irix*)
+         func_append compile_command " $arg"
+         func_append finalize_command " $arg"
+         ;;
+       esac
+       continue
+       ;;
+
+      -L*)
+       func_stripname '-L' '' "$arg"
+       dir=$func_stripname_result
+       if test -z "$dir"; then
+         if test "$#" -gt 0; then
+           func_fatal_error "require no space between \`-L' and \`$1'"
+         else
+           func_fatal_error "need path for \`-L' option"
+         fi
+       fi
+       # We need an absolute path.
+       case $dir in
+       [\\/]* | [A-Za-z]:[\\/]*) ;;
+       *)
+         absdir=`cd "$dir" && pwd`
+         test -z "$absdir" && \
+           func_fatal_error "cannot determine absolute directory name of \`$dir'"
+         dir="$absdir"
+         ;;
+       esac
+       case "$deplibs " in
+       *" -L$dir "*) ;;
+       *)
+         deplibs="$deplibs -L$dir"
+         lib_search_path="$lib_search_path $dir"
+         ;;
+       esac
+       case $host in
+       *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
+         testbindir=`$ECHO "X$dir" | $Xsed -e 's*/lib$*/bin*'`
+         case :$dllsearchpath: in
+         *":$dir:"*) ;;
+         ::) dllsearchpath=$dir;;
+         *) dllsearchpath="$dllsearchpath:$dir";;
+         esac
+         case :$dllsearchpath: in
+         *":$testbindir:"*) ;;
+         ::) dllsearchpath=$testbindir;;
+         *) dllsearchpath="$dllsearchpath:$testbindir";;
+         esac
+         ;;
+       esac
+       continue
+       ;;
+
+      -l*)
+       if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then
+         case $host in
+         *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc*)
+           # These systems don't actually have a C or math library (as such)
+           continue
+           ;;
+         *-*-os2*)
+           # These systems don't actually have a C library (as such)
+           test "X$arg" = "X-lc" && continue
+           ;;
+         *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
+           # Do not include libc due to us having libc/libc_r.
+           test "X$arg" = "X-lc" && continue
+           ;;
+         *-*-rhapsody* | *-*-darwin1.[012])
+           # Rhapsody C and math libraries are in the System framework
+           deplibs="$deplibs System.ltframework"
+           continue
+           ;;
+         *-*-sco3.2v5* | *-*-sco5v6*)
+           # Causes problems with __ctype
+           test "X$arg" = "X-lc" && continue
+           ;;
+         *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*)
+           # Compiler inserts libc in the correct place for threads to work
+           test "X$arg" = "X-lc" && continue
+           ;;
+         esac
+       elif test "X$arg" = "X-lc_r"; then
+        case $host in
+        *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
+          # Do not include libc_r directly, use -pthread flag.
+          continue
+          ;;
+        esac
+       fi
+       deplibs="$deplibs $arg"
+       continue
+       ;;
+
+      -module)
+       module=yes
+       continue
+       ;;
+
+      # Tru64 UNIX uses -model [arg] to determine the layout of C++
+      # classes, name mangling, and exception handling.
+      # Darwin uses the -arch flag to determine output architecture.
+      -model|-arch|-isysroot)
+       compiler_flags="$compiler_flags $arg"
+       func_append compile_command " $arg"
+       func_append finalize_command " $arg"
+       prev=xcompiler
+       continue
+       ;;
+
+      -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads)
+       compiler_flags="$compiler_flags $arg"
+       func_append compile_command " $arg"
+       func_append finalize_command " $arg"
+       case "$new_inherited_linker_flags " in
+           *" $arg "*) ;;
+           * ) new_inherited_linker_flags="$new_inherited_linker_flags $arg" ;;
+       esac
+       continue
+       ;;
+
+      -multi_module)
+       single_module="${wl}-multi_module"
+       continue
+       ;;
+
+      -no-fast-install)
+       fast_install=no
+       continue
+       ;;
+
+      -no-install)
+       case $host in
+       *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*)
+         # The PATH hackery in wrapper scripts is required on Windows
+         # and Darwin in order for the loader to find any dlls it needs.
+         func_warning "\`-no-install' is ignored for $host"
+         func_warning "assuming \`-no-fast-install' instead"
+         fast_install=no
+         ;;
+       *) no_install=yes ;;
+       esac
+       continue
+       ;;
+
+      -no-undefined)
+       allow_undefined=no
+       continue
+       ;;
+
+      -objectlist)
+       prev=objectlist
+       continue
+       ;;
+
+      -o) prev=output ;;
+
+      -precious-files-regex)
+       prev=precious_regex
+       continue
+       ;;
+
+      -release)
+       prev=release
+       continue
+       ;;
+
+      -rpath)
+       prev=rpath
+       continue
+       ;;
+
+      -R)
+       prev=xrpath
+       continue
+       ;;
+
+      -R*)
+       func_stripname '-R' '' "$arg"
+       dir=$func_stripname_result
+       # We need an absolute path.
+       case $dir in
+       [\\/]* | [A-Za-z]:[\\/]*) ;;
+       *)
+         func_fatal_error "only absolute run-paths are allowed"
+         ;;
+       esac
+       case "$xrpath " in
+       *" $dir "*) ;;
+       *) xrpath="$xrpath $dir" ;;
+       esac
+       continue
+       ;;
+
+      -shared)
+       # The effects of -shared are defined in a previous loop.
+       continue
+       ;;
+
+      -shrext)
+       prev=shrext
+       continue
+       ;;
+
+      -static | -static-libtool-libs)
+       # The effects of -static are defined in a previous loop.
+       # We used to do the same as -all-static on platforms that
+       # didn't have a PIC flag, but the assumption that the effects
+       # would be equivalent was wrong.  It would break on at least
+       # Digital Unix and AIX.
+       continue
+       ;;
+
+      -thread-safe)
+       thread_safe=yes
+       continue
+       ;;
+
+      -version-info)
+       prev=vinfo
+       continue
+       ;;
+
+      -version-number)
+       prev=vinfo
+       vinfo_number=yes
+       continue
+       ;;
+
+      -weak)
+        prev=weak
+       continue
+       ;;
+
+      -Wc,*)
+       func_stripname '-Wc,' '' "$arg"
+       args=$func_stripname_result
+       arg=
+       save_ifs="$IFS"; IFS=','
+       for flag in $args; do
+         IFS="$save_ifs"
+          func_quote_for_eval "$flag"
+         arg="$arg $wl$func_quote_for_eval_result"
+         compiler_flags="$compiler_flags $func_quote_for_eval_result"
+       done
+       IFS="$save_ifs"
+       func_stripname ' ' '' "$arg"
+       arg=$func_stripname_result
+       ;;
+
+      -Wl,*)
+       func_stripname '-Wl,' '' "$arg"
+       args=$func_stripname_result
+       arg=
+       save_ifs="$IFS"; IFS=','
+       for flag in $args; do
+         IFS="$save_ifs"
+          func_quote_for_eval "$flag"
+         arg="$arg $wl$func_quote_for_eval_result"
+         compiler_flags="$compiler_flags $wl$func_quote_for_eval_result"
+         linker_flags="$linker_flags $func_quote_for_eval_result"
+       done
+       IFS="$save_ifs"
+       func_stripname ' ' '' "$arg"
+       arg=$func_stripname_result
+       ;;
+
+      -Xcompiler)
+       prev=xcompiler
+       continue
+       ;;
+
+      -Xlinker)
+       prev=xlinker
+       continue
+       ;;
+
+      -XCClinker)
+       prev=xcclinker
+       continue
+       ;;
+
+      # -msg_* for osf cc
+      -msg_*)
+       func_quote_for_eval "$arg"
+       arg="$func_quote_for_eval_result"
+       ;;
+
+      # -64, -mips[0-9] enable 64-bit mode on the SGI compiler
+      # -r[0-9][0-9]* specifies the processor on the SGI compiler
+      # -xarch=*, -xtarget=* enable 64-bit mode on the Sun compiler
+      # +DA*, +DD* enable 64-bit mode on the HP compiler
+      # -q* pass through compiler args for the IBM compiler
+      # -m*, -t[45]*, -txscale* pass through architecture-specific
+      # compiler args for GCC
+      # -F/path gives path to uninstalled frameworks, gcc on darwin
+      # -p, -pg, --coverage, -fprofile-* pass through profiling flag for GCC
+      # @file GCC response files
+      -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
+      -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*)
+        func_quote_for_eval "$arg"
+       arg="$func_quote_for_eval_result"
+        func_append compile_command " $arg"
+        func_append finalize_command " $arg"
+        compiler_flags="$compiler_flags $arg"
+        continue
+        ;;
+
+      # Some other compiler flag.
+      -* | +*)
+        func_quote_for_eval "$arg"
+       arg="$func_quote_for_eval_result"
+       ;;
+
+      *.$objext)
+       # A standard object.
+       objs="$objs $arg"
+       ;;
+
+      *.lo)
+       # A libtool-controlled object.
+
+       # Check to see that this really is a libtool object.
+       if func_lalib_unsafe_p "$arg"; then
+         pic_object=
+         non_pic_object=
+
+         # Read the .lo file
+         func_source "$arg"
+
+         if test -z "$pic_object" ||
+            test -z "$non_pic_object" ||
+            test "$pic_object" = none &&
+            test "$non_pic_object" = none; then
+           func_fatal_error "cannot find name of object for \`$arg'"
+         fi
+
+         # Extract subdirectory from the argument.
+         func_dirname "$arg" "/" ""
+         xdir="$func_dirname_result"
+
+         if test "$pic_object" != none; then
+           # Prepend the subdirectory the object is found in.
+           pic_object="$xdir$pic_object"
+
+           if test "$prev" = dlfiles; then
+             if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
+               dlfiles="$dlfiles $pic_object"
+               prev=
+               continue
+             else
+               # If libtool objects are unsupported, then we need to preload.
+               prev=dlprefiles
+             fi
+           fi
+
+           # CHECK ME:  I think I busted this.  -Ossama
+           if test "$prev" = dlprefiles; then
+             # Preload the old-style object.
+             dlprefiles="$dlprefiles $pic_object"
+             prev=
+           fi
+
+           # A PIC object.
+           func_append libobjs " $pic_object"
+           arg="$pic_object"
+         fi
+
+         # Non-PIC object.
+         if test "$non_pic_object" != none; then
+           # Prepend the subdirectory the object is found in.
+           non_pic_object="$xdir$non_pic_object"
+
+           # A standard non-PIC object
+           func_append non_pic_objects " $non_pic_object"
+           if test -z "$pic_object" || test "$pic_object" = none ; then
+             arg="$non_pic_object"
+           fi
+         else
+           # If the PIC object exists, use it instead.
+           # $xdir was prepended to $pic_object above.
+           non_pic_object="$pic_object"
+           func_append non_pic_objects " $non_pic_object"
+         fi
+       else
+         # Only an error if not doing a dry-run.
+         if $opt_dry_run; then
+           # Extract subdirectory from the argument.
+           func_dirname "$arg" "/" ""
+           xdir="$func_dirname_result"
+
+           func_lo2o "$arg"
+           pic_object=$xdir$objdir/$func_lo2o_result
+           non_pic_object=$xdir$func_lo2o_result
+           func_append libobjs " $pic_object"
+           func_append non_pic_objects " $non_pic_object"
+         else
+           func_fatal_error "\`$arg' is not a valid libtool object"
+         fi
+       fi
+       ;;
+
+      *.$libext)
+       # An archive.
+       deplibs="$deplibs $arg"
+       old_deplibs="$old_deplibs $arg"
+       continue
+       ;;
+
+      *.la)
+       # A libtool-controlled library.
+
+       if test "$prev" = dlfiles; then
+         # This library was specified with -dlopen.
+         dlfiles="$dlfiles $arg"
+         prev=
+       elif test "$prev" = dlprefiles; then
+         # The library was specified with -dlpreopen.
+         dlprefiles="$dlprefiles $arg"
+         prev=
+       else
+         deplibs="$deplibs $arg"
+       fi
+       continue
+       ;;
+
+      # Some other compiler argument.
+      *)
+       # Unknown arguments in both finalize_command and compile_command need
+       # to be aesthetically quoted because they are evaled later.
+       func_quote_for_eval "$arg"
+       arg="$func_quote_for_eval_result"
+       ;;
+      esac # arg
+
+      # Now actually substitute the argument into the commands.
+      if test -n "$arg"; then
+       func_append compile_command " $arg"
+       func_append finalize_command " $arg"
+      fi
+    done # argument parsing loop
+
+    test -n "$prev" && \
+      func_fatal_help "the \`$prevarg' option requires an argument"
+
+    if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then
+      eval arg=\"$export_dynamic_flag_spec\"
+      func_append compile_command " $arg"
+      func_append finalize_command " $arg"
+    fi
+
+    oldlibs=
+    # calculate the name of the file, without its directory
+    func_basename "$output"
+    outputname="$func_basename_result"
+    libobjs_save="$libobjs"
+
+    if test -n "$shlibpath_var"; then
+      # get the directories listed in $shlibpath_var
+      eval shlib_search_path=\`\$ECHO \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\`
+    else
+      shlib_search_path=
+    fi
+    eval sys_lib_search_path=\"$sys_lib_search_path_spec\"
+    eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\"
+
+    func_dirname "$output" "/" ""
+    output_objdir="$func_dirname_result$objdir"
+    # Create the object directory.
+    func_mkdir_p "$output_objdir"
+
+    # Determine the type of output
+    case $output in
+    "")
+      func_fatal_help "you must specify an output file"
+      ;;
+    *.$libext) linkmode=oldlib ;;
+    *.lo | *.$objext) linkmode=obj ;;
+    *.la) linkmode=lib ;;
+    *) linkmode=prog ;; # Anything else should be a program.
+    esac
+
+    specialdeplibs=
+
+    libs=
+    # Find all interdependent deplibs by searching for libraries
+    # that are linked more than once (e.g. -la -lb -la)
+    for deplib in $deplibs; do
+      if $opt_duplicate_deps ; then
+       case "$libs " in
+       *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
+       esac
+      fi
+      libs="$libs $deplib"
+    done
+
+    if test "$linkmode" = lib; then
+      libs="$predeps $libs $compiler_lib_search_path $postdeps"
+
+      # Compute libraries that are listed more than once in $predeps
+      # $postdeps and mark them as special (i.e., whose duplicates are
+      # not to be eliminated).
+      pre_post_deps=
+      if $opt_duplicate_compiler_generated_deps; then
+       for pre_post_dep in $predeps $postdeps; do
+         case "$pre_post_deps " in
+         *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;;
+         esac
+         pre_post_deps="$pre_post_deps $pre_post_dep"
+       done
+      fi
+      pre_post_deps=
+    fi
+
+    deplibs=
+    newdependency_libs=
+    newlib_search_path=
+    need_relink=no # whether we're linking any uninstalled libtool libraries
+    notinst_deplibs= # not-installed libtool libraries
+    notinst_path= # paths that contain not-installed libtool libraries
+
+    case $linkmode in
+    lib)
+       passes="conv dlpreopen link"
+       for file in $dlfiles $dlprefiles; do
+         case $file in
+         *.la) ;;
+         *)
+           func_fatal_help "libraries can \`-dlopen' only libtool libraries: $file"
+           ;;
+         esac
+       done
+       ;;
+    prog)
+       compile_deplibs=
+       finalize_deplibs=
+       alldeplibs=no
+       newdlfiles=
+       newdlprefiles=
+       passes="conv scan dlopen dlpreopen link"
+       ;;
+    *)  passes="conv"
+       ;;
+    esac
+
+    for pass in $passes; do
+      # The preopen pass in lib mode reverses $deplibs; put it back here
+      # so that -L comes before libs that need it for instance...
+      if test "$linkmode,$pass" = "lib,link"; then
+       ## FIXME: Find the place where the list is rebuilt in the wrong
+       ##        order, and fix it there properly
+        tmp_deplibs=
+       for deplib in $deplibs; do
+         tmp_deplibs="$deplib $tmp_deplibs"
+       done
+       deplibs="$tmp_deplibs"
+      fi
+
+      if test "$linkmode,$pass" = "lib,link" ||
+        test "$linkmode,$pass" = "prog,scan"; then
+       libs="$deplibs"
+       deplibs=
+      fi
+      if test "$linkmode" = prog; then
+       case $pass in
+       dlopen) libs="$dlfiles" ;;
+       dlpreopen) libs="$dlprefiles" ;;
+       link) libs="$deplibs %DEPLIBS% $dependency_libs" ;;
+       esac
+      fi
+      if test "$linkmode,$pass" = "lib,dlpreopen"; then
+       # Collect and forward deplibs of preopened libtool libs
+       for lib in $dlprefiles; do
+         # Ignore non-libtool-libs
+         dependency_libs=
+         case $lib in
+         *.la) func_source "$lib" ;;
+         esac
+
+         # Collect preopened libtool deplibs, except any this library
+         # has declared as weak libs
+         for deplib in $dependency_libs; do
+            deplib_base=`$ECHO "X$deplib" | $Xsed -e "$basename"`
+           case " $weak_libs " in
+           *" $deplib_base "*) ;;
+           *) deplibs="$deplibs $deplib" ;;
+           esac
+         done
+       done
+       libs="$dlprefiles"
+      fi
+      if test "$pass" = dlopen; then
+       # Collect dlpreopened libraries
+       save_deplibs="$deplibs"
+       deplibs=
+      fi
+
+      for deplib in $libs; do
+       lib=
+       found=no
+       case $deplib in
+       -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe|-threads)
+         if test "$linkmode,$pass" = "prog,link"; then
+           compile_deplibs="$deplib $compile_deplibs"
+           finalize_deplibs="$deplib $finalize_deplibs"
+         else
+           compiler_flags="$compiler_flags $deplib"
+           if test "$linkmode" = lib ; then
+               case "$new_inherited_linker_flags " in
+                   *" $deplib "*) ;;
+                   * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;;
+               esac
+           fi
+         fi
+         continue
+         ;;
+       -l*)
+         if test "$linkmode" != lib && test "$linkmode" != prog; then
+           func_warning "\`-l' is ignored for archives/objects"
+           continue
+         fi
+         func_stripname '-l' '' "$deplib"
+         name=$func_stripname_result
+         if test "$linkmode" = lib; then
+           searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path"
+         else
+           searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path"
+         fi
+         for searchdir in $searchdirs; do
+           for search_ext in .la $std_shrext .so .a; do
+             # Search the libtool library
+             lib="$searchdir/lib${name}${search_ext}"
+             if test -f "$lib"; then
+               if test "$search_ext" = ".la"; then
+                 found=yes
+               else
+                 found=no
+               fi
+               break 2
+             fi
+           done
+         done
+         if test "$found" != yes; then
+           # deplib doesn't seem to be a libtool library
+           if test "$linkmode,$pass" = "prog,link"; then
+             compile_deplibs="$deplib $compile_deplibs"
+             finalize_deplibs="$deplib $finalize_deplibs"
+           else
+             deplibs="$deplib $deplibs"
+             test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
+           fi
+           continue
+         else # deplib is a libtool library
+           # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib,
+           # We need to do some special things here, and not later.
+           if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+             case " $predeps $postdeps " in
+             *" $deplib "*)
+               if func_lalib_p "$lib"; then
+                 library_names=
+                 old_library=
+                 func_source "$lib"
+                 for l in $old_library $library_names; do
+                   ll="$l"
+                 done
+                 if test "X$ll" = "X$old_library" ; then # only static version available
+                   found=no
+                   func_dirname "$lib" "" "."
+                   ladir="$func_dirname_result"
+                   lib=$ladir/$old_library
+                   if test "$linkmode,$pass" = "prog,link"; then
+                     compile_deplibs="$deplib $compile_deplibs"
+                     finalize_deplibs="$deplib $finalize_deplibs"
+                   else
+                     deplibs="$deplib $deplibs"
+                     test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
+                   fi
+                   continue
+                 fi
+               fi
+               ;;
+             *) ;;
+             esac
+           fi
+         fi
+         ;; # -l
+       *.ltframework)
+         if test "$linkmode,$pass" = "prog,link"; then
+           compile_deplibs="$deplib $compile_deplibs"
+           finalize_deplibs="$deplib $finalize_deplibs"
+         else
+           deplibs="$deplib $deplibs"
+           if test "$linkmode" = lib ; then
+               case "$new_inherited_linker_flags " in
+                   *" $deplib "*) ;;
+                   * ) new_inherited_linker_flags="$new_inherited_linker_flags $deplib" ;;
+               esac
+           fi
+         fi
+         continue
+         ;;
+       -L*)
+         case $linkmode in
+         lib)
+           deplibs="$deplib $deplibs"
+           test "$pass" = conv && continue
+           newdependency_libs="$deplib $newdependency_libs"
+           func_stripname '-L' '' "$deplib"
+           newlib_search_path="$newlib_search_path $func_stripname_result"
+           ;;
+         prog)
+           if test "$pass" = conv; then
+             deplibs="$deplib $deplibs"
+             continue
+           fi
+           if test "$pass" = scan; then
+             deplibs="$deplib $deplibs"
+           else
+             compile_deplibs="$deplib $compile_deplibs"
+             finalize_deplibs="$deplib $finalize_deplibs"
+           fi
+           func_stripname '-L' '' "$deplib"
+           newlib_search_path="$newlib_search_path $func_stripname_result"
+           ;;
+         *)
+           func_warning "\`-L' is ignored for archives/objects"
+           ;;
+         esac # linkmode
+         continue
+         ;; # -L
+       -R*)
+         if test "$pass" = link; then
+           func_stripname '-R' '' "$deplib"
+           dir=$func_stripname_result
+           # Make sure the xrpath contains only unique directories.
+           case "$xrpath " in
+           *" $dir "*) ;;
+           *) xrpath="$xrpath $dir" ;;
+           esac
+         fi
+         deplibs="$deplib $deplibs"
+         continue
+         ;;
+       *.la) lib="$deplib" ;;
+       *.$libext)
+         if test "$pass" = conv; then
+           deplibs="$deplib $deplibs"
+           continue
+         fi
+         case $linkmode in
+         lib)
+           # Linking convenience modules into shared libraries is allowed,
+           # but linking other static libraries is non-portable.
+           case " $dlpreconveniencelibs " in
+           *" $deplib "*) ;;
+           *)
+             valid_a_lib=no
+             case $deplibs_check_method in
+               match_pattern*)
+                 set dummy $deplibs_check_method; shift
+                 match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
+                 if eval "\$ECHO \"X$deplib\"" 2>/dev/null | $Xsed -e 10q \
+                   | $EGREP "$match_pattern_regex" > /dev/null; then
+                   valid_a_lib=yes
+                 fi
+               ;;
+               pass_all)
+                 valid_a_lib=yes
+               ;;
+             esac
+             if test "$valid_a_lib" != yes; then
+               $ECHO
+               $ECHO "*** Warning: Trying to link with static lib archive $deplib."
+               $ECHO "*** I have the capability to make that library automatically link in when"
+               $ECHO "*** you link to this library.  But I can only do this if you have a"
+               $ECHO "*** shared version of the library, which you do not appear to have"
+               $ECHO "*** because the file extensions .$libext of this argument makes me believe"
+               $ECHO "*** that it is just a static archive that I should not use here."
+             else
+               $ECHO
+               $ECHO "*** Warning: Linking the shared library $output against the"
+               $ECHO "*** static library $deplib is not portable!"
+               deplibs="$deplib $deplibs"
+             fi
+             ;;
+           esac
+           continue
+           ;;
+         prog)
+           if test "$pass" != link; then
+             deplibs="$deplib $deplibs"
+           else
+             compile_deplibs="$deplib $compile_deplibs"
+             finalize_deplibs="$deplib $finalize_deplibs"
+           fi
+           continue
+           ;;
+         esac # linkmode
+         ;; # *.$libext
+       *.lo | *.$objext)
+         if test "$pass" = conv; then
+           deplibs="$deplib $deplibs"
+         elif test "$linkmode" = prog; then
+           if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
+             # If there is no dlopen support or we're linking statically,
+             # we need to preload.
+             newdlprefiles="$newdlprefiles $deplib"
+             compile_deplibs="$deplib $compile_deplibs"
+             finalize_deplibs="$deplib $finalize_deplibs"
+           else
+             newdlfiles="$newdlfiles $deplib"
+           fi
+         fi
+         continue
+         ;;
+       %DEPLIBS%)
+         alldeplibs=yes
+         continue
+         ;;
+       esac # case $deplib
+
+       if test "$found" = yes || test -f "$lib"; then :
+       else
+         func_fatal_error "cannot find the library \`$lib' or unhandled argument \`$deplib'"
+       fi
+
+       # Check to see that this really is a libtool archive.
+       func_lalib_unsafe_p "$lib" \
+         || func_fatal_error "\`$lib' is not a valid libtool archive"
+
+       func_dirname "$lib" "" "."
+       ladir="$func_dirname_result"
+
+       dlname=
+       dlopen=
+       dlpreopen=
+       libdir=
+       library_names=
+       old_library=
+       inherited_linker_flags=
+       # If the library was installed with an old release of libtool,
+       # it will not redefine variables installed, or shouldnotlink
+       installed=yes
+       shouldnotlink=no
+       avoidtemprpath=
+
+
+       # Read the .la file
+       func_source "$lib"
+
+       # Convert "-framework foo" to "foo.ltframework"
+       if test -n "$inherited_linker_flags"; then
+         tmp_inherited_linker_flags=`$ECHO "X$inherited_linker_flags" | $Xsed -e 's/-framework \([^ $]*\)/\1.ltframework/g'`
+         for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do
+           case " $new_inherited_linker_flags " in
+             *" $tmp_inherited_linker_flag "*) ;;
+             *) new_inherited_linker_flags="$new_inherited_linker_flags $tmp_inherited_linker_flag";;
+           esac
+         done
+       fi
+       dependency_libs=`$ECHO "X $dependency_libs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
+       if test "$linkmode,$pass" = "lib,link" ||
+          test "$linkmode,$pass" = "prog,scan" ||
+          { test "$linkmode" != prog && test "$linkmode" != lib; }; then
+         test -n "$dlopen" && dlfiles="$dlfiles $dlopen"
+         test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen"
+       fi
+
+       if test "$pass" = conv; then
+         # Only check for convenience libraries
+         deplibs="$lib $deplibs"
+         if test -z "$libdir"; then
+           if test -z "$old_library"; then
+             func_fatal_error "cannot find name of link library for \`$lib'"
+           fi
+           # It is a libtool convenience library, so add in its objects.
+           convenience="$convenience $ladir/$objdir/$old_library"
+           old_convenience="$old_convenience $ladir/$objdir/$old_library"
+         elif test "$linkmode" != prog && test "$linkmode" != lib; then
+           func_fatal_error "\`$lib' is not a convenience library"
+         fi
+         tmp_libs=
+         for deplib in $dependency_libs; do
+           deplibs="$deplib $deplibs"
+           if $opt_duplicate_deps ; then
+             case "$tmp_libs " in
+             *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
+             esac
+           fi
+           tmp_libs="$tmp_libs $deplib"
+         done
+         continue
+       fi # $pass = conv
+
+
+       # Get the name of the library we link against.
+       linklib=
+       for l in $old_library $library_names; do
+         linklib="$l"
+       done
+       if test -z "$linklib"; then
+         func_fatal_error "cannot find name of link library for \`$lib'"
+       fi
+
+       # This library was specified with -dlopen.
+       if test "$pass" = dlopen; then
+         if test -z "$libdir"; then
+           func_fatal_error "cannot -dlopen a convenience library: \`$lib'"
+         fi
+         if test -z "$dlname" ||
+            test "$dlopen_support" != yes ||
+            test "$build_libtool_libs" = no; then
+           # If there is no dlname, no dlopen support or we're linking
+           # statically, we need to preload.  We also need to preload any
+           # dependent libraries so libltdl's deplib preloader doesn't
+           # bomb out in the load deplibs phase.
+           dlprefiles="$dlprefiles $lib $dependency_libs"
+         else
+           newdlfiles="$newdlfiles $lib"
+         fi
+         continue
+       fi # $pass = dlopen
+
+       # We need an absolute path.
+       case $ladir in
+       [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;;
+       *)
+         abs_ladir=`cd "$ladir" && pwd`
+         if test -z "$abs_ladir"; then
+           func_warning "cannot determine absolute directory name of \`$ladir'"
+           func_warning "passing it literally to the linker, although it might fail"
+           abs_ladir="$ladir"
+         fi
+         ;;
+       esac
+       func_basename "$lib"
+       laname="$func_basename_result"
+
+       # Find the relevant object directory and library name.
+       if test "X$installed" = Xyes; then
+         if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
+           func_warning "library \`$lib' was moved."
+           dir="$ladir"
+           absdir="$abs_ladir"
+           libdir="$abs_ladir"
+         else
+           dir="$libdir"
+           absdir="$libdir"
+         fi
+         test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes
+       else
+         if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then
+           dir="$ladir"
+           absdir="$abs_ladir"
+           # Remove this search path later
+           notinst_path="$notinst_path $abs_ladir"
+         else
+           dir="$ladir/$objdir"
+           absdir="$abs_ladir/$objdir"
+           # Remove this search path later
+           notinst_path="$notinst_path $abs_ladir"
+         fi
+       fi # $installed = yes
+       func_stripname 'lib' '.la' "$laname"
+       name=$func_stripname_result
+
+       # This library was specified with -dlpreopen.
+       if test "$pass" = dlpreopen; then
+         if test -z "$libdir" && test "$linkmode" = prog; then
+           func_fatal_error "only libraries may -dlpreopen a convenience library: \`$lib'"
+         fi
+         # Prefer using a static library (so that no silly _DYNAMIC symbols
+         # are required to link).
+         if test -n "$old_library"; then
+           newdlprefiles="$newdlprefiles $dir/$old_library"
+           # Keep a list of preopened convenience libraries to check
+           # that they are being used correctly in the link pass.
+           test -z "$libdir" && \
+               dlpreconveniencelibs="$dlpreconveniencelibs $dir/$old_library"
+         # Otherwise, use the dlname, so that lt_dlopen finds it.
+         elif test -n "$dlname"; then
+           newdlprefiles="$newdlprefiles $dir/$dlname"
+         else
+           newdlprefiles="$newdlprefiles $dir/$linklib"
+         fi
+       fi # $pass = dlpreopen
+
+       if test -z "$libdir"; then
+         # Link the convenience library
+         if test "$linkmode" = lib; then
+           deplibs="$dir/$old_library $deplibs"
+         elif test "$linkmode,$pass" = "prog,link"; then
+           compile_deplibs="$dir/$old_library $compile_deplibs"
+           finalize_deplibs="$dir/$old_library $finalize_deplibs"
+         else
+           deplibs="$lib $deplibs" # used for prog,scan pass
+         fi
+         continue
+       fi
+
+
+       if test "$linkmode" = prog && test "$pass" != link; then
+         newlib_search_path="$newlib_search_path $ladir"
+         deplibs="$lib $deplibs"
+
+         linkalldeplibs=no
+         if test "$link_all_deplibs" != no || test -z "$library_names" ||
+            test "$build_libtool_libs" = no; then
+           linkalldeplibs=yes
+         fi
+
+         tmp_libs=
+         for deplib in $dependency_libs; do
+           case $deplib in
+           -L*) func_stripname '-L' '' "$deplib"
+                newlib_search_path="$newlib_search_path $func_stripname_result"
+                ;;
+           esac
+           # Need to link against all dependency_libs?
+           if test "$linkalldeplibs" = yes; then
+             deplibs="$deplib $deplibs"
+           else
+             # Need to hardcode shared library paths
+             # or/and link against static libraries
+             newdependency_libs="$deplib $newdependency_libs"
+           fi
+           if $opt_duplicate_deps ; then
+             case "$tmp_libs " in
+             *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
+             esac
+           fi
+           tmp_libs="$tmp_libs $deplib"
+         done # for deplib
+         continue
+       fi # $linkmode = prog...
+
+       if test "$linkmode,$pass" = "prog,link"; then
+         if test -n "$library_names" &&
+            { { test "$prefer_static_libs" = no ||
+                test "$prefer_static_libs,$installed" = "built,yes"; } ||
+              test -z "$old_library"; }; then
+           # We need to hardcode the library path
+           if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then
+             # Make sure the rpath contains only unique directories.
+             case "$temp_rpath:" in
+             *"$absdir:"*) ;;
+             *) temp_rpath="$temp_rpath$absdir:" ;;
+             esac
+           fi
+
+           # Hardcode the library path.
+           # Skip directories that are in the system default run-time
+           # search path.
+           case " $sys_lib_dlsearch_path " in
+           *" $absdir "*) ;;
+           *)
+             case "$compile_rpath " in
+             *" $absdir "*) ;;
+             *) compile_rpath="$compile_rpath $absdir"
+             esac
+             ;;
+           esac
+           case " $sys_lib_dlsearch_path " in
+           *" $libdir "*) ;;
+           *)
+             case "$finalize_rpath " in
+             *" $libdir "*) ;;
+             *) finalize_rpath="$finalize_rpath $libdir"
+             esac
+             ;;
+           esac
+         fi # $linkmode,$pass = prog,link...
+
+         if test "$alldeplibs" = yes &&
+            { test "$deplibs_check_method" = pass_all ||
+              { test "$build_libtool_libs" = yes &&
+                test -n "$library_names"; }; }; then
+           # We only need to search for static libraries
+           continue
+         fi
+       fi
+
+       link_static=no # Whether the deplib will be linked statically
+       use_static_libs=$prefer_static_libs
+       if test "$use_static_libs" = built && test "$installed" = yes; then
+         use_static_libs=no
+       fi
+       if test -n "$library_names" &&
+          { test "$use_static_libs" = no || test -z "$old_library"; }; then
+         case $host in
+         *cygwin* | *mingw* | *cegcc*)
+             # No point in relinking DLLs because paths are not encoded
+             notinst_deplibs="$notinst_deplibs $lib"
+             need_relink=no
+           ;;
+         *)
+           if test "$installed" = no; then
+             notinst_deplibs="$notinst_deplibs $lib"
+             need_relink=yes
+           fi
+           ;;
+         esac
+         # This is a shared library
+
+         # Warn about portability, can't link against -module's on some
+         # systems (darwin).  Don't bleat about dlopened modules though!
+         dlopenmodule=""
+         for dlpremoduletest in $dlprefiles; do
+           if test "X$dlpremoduletest" = "X$lib"; then
+             dlopenmodule="$dlpremoduletest"
+             break
+           fi
+         done
+         if test -z "$dlopenmodule" && test "$shouldnotlink" = yes && test "$pass" = link; then
+           $ECHO
+           if test "$linkmode" = prog; then
+             $ECHO "*** Warning: Linking the executable $output against the loadable module"
+           else
+             $ECHO "*** Warning: Linking the shared library $output against the loadable module"
+           fi
+           $ECHO "*** $linklib is not portable!"
+         fi
+         if test "$linkmode" = lib &&
+            test "$hardcode_into_libs" = yes; then
+           # Hardcode the library path.
+           # Skip directories that are in the system default run-time
+           # search path.
+           case " $sys_lib_dlsearch_path " in
+           *" $absdir "*) ;;
+           *)
+             case "$compile_rpath " in
+             *" $absdir "*) ;;
+             *) compile_rpath="$compile_rpath $absdir"
+             esac
+             ;;
+           esac
+           case " $sys_lib_dlsearch_path " in
+           *" $libdir "*) ;;
+           *)
+             case "$finalize_rpath " in
+             *" $libdir "*) ;;
+             *) finalize_rpath="$finalize_rpath $libdir"
+             esac
+             ;;
+           esac
+         fi
+
+         if test -n "$old_archive_from_expsyms_cmds"; then
+           # figure out the soname
+           set dummy $library_names
+           shift
+           realname="$1"
+           shift
+           libname=`eval "\\$ECHO \"$libname_spec\""`
+           # use dlname if we got it. it's perfectly good, no?
+           if test -n "$dlname"; then
+             soname="$dlname"
+           elif test -n "$soname_spec"; then
+             # bleh windows
+             case $host in
+             *cygwin* | mingw* | *cegcc*)
+               func_arith $current - $age
+               major=$func_arith_result
+               versuffix="-$major"
+               ;;
+             esac
+             eval soname=\"$soname_spec\"
+           else
+             soname="$realname"
+           fi
+
+           # Make a new name for the extract_expsyms_cmds to use
+           soroot="$soname"
+           func_basename "$soroot"
+           soname="$func_basename_result"
+           func_stripname 'lib' '.dll' "$soname"
+           newlib=libimp-$func_stripname_result.a
+
+           # If the library has no export list, then create one now
+           if test -f "$output_objdir/$soname-def"; then :
+           else
+             func_verbose "extracting exported symbol list from \`$soname'"
+             func_execute_cmds "$extract_expsyms_cmds" 'exit $?'
+           fi
+
+           # Create $newlib
+           if test -f "$output_objdir/$newlib"; then :; else
+             func_verbose "generating import library for \`$soname'"
+             func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?'
+           fi
+           # make sure the library variables are pointing to the new library
+           dir=$output_objdir
+           linklib=$newlib
+         fi # test -n "$old_archive_from_expsyms_cmds"
+
+         if test "$linkmode" = prog || test "$mode" != relink; then
+           add_shlibpath=
+           add_dir=
+           add=
+           lib_linked=yes
+           case $hardcode_action in
+           immediate | unsupported)
+             if test "$hardcode_direct" = no; then
+               add="$dir/$linklib"
+               case $host in
+                 *-*-sco3.2v5.0.[024]*) add_dir="-L$dir" ;;
+                 *-*-sysv4*uw2*) add_dir="-L$dir" ;;
+                 *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \
+                   *-*-unixware7*) add_dir="-L$dir" ;;
+                 *-*-darwin* )
+                   # if the lib is a (non-dlopened) module then we can not
+                   # link against it, someone is ignoring the earlier warnings
+                   if /usr/bin/file -L $add 2> /dev/null |
+                        $GREP ": [^:]* bundle" >/dev/null ; then
+                     if test "X$dlopenmodule" != "X$lib"; then
+                       $ECHO "*** Warning: lib $linklib is a module, not a shared library"
+                       if test -z "$old_library" ; then
+                         $ECHO
+                         $ECHO "*** And there doesn't seem to be a static archive available"
+                         $ECHO "*** The link will probably fail, sorry"
+                       else
+                         add="$dir/$old_library"
+                       fi
+                     elif test -n "$old_library"; then
+                       add="$dir/$old_library"
+                     fi
+                   fi
+               esac
+             elif test "$hardcode_minus_L" = no; then
+               case $host in
+               *-*-sunos*) add_shlibpath="$dir" ;;
+               esac
+               add_dir="-L$dir"
+               add="-l$name"
+             elif test "$hardcode_shlibpath_var" = no; then
+               add_shlibpath="$dir"
+               add="-l$name"
+             else
+               lib_linked=no
+             fi
+             ;;
+           relink)
+             if test "$hardcode_direct" = yes &&
+                test "$hardcode_direct_absolute" = no; then
+               add="$dir/$linklib"
+             elif test "$hardcode_minus_L" = yes; then
+               add_dir="-L$dir"
+               # Try looking first in the location we're being installed to.
+               if test -n "$inst_prefix_dir"; then
+                 case $libdir in
+                   [\\/]*)
+                     add_dir="$add_dir -L$inst_prefix_dir$libdir"
+                     ;;
+                 esac
+               fi
+               add="-l$name"
+             elif test "$hardcode_shlibpath_var" = yes; then
+               add_shlibpath="$dir"
+               add="-l$name"
+             else
+               lib_linked=no
+             fi
+             ;;
+           *) lib_linked=no ;;
+           esac
+
+           if test "$lib_linked" != yes; then
+             func_fatal_configuration "unsupported hardcode properties"
+           fi
+
+           if test -n "$add_shlibpath"; then
+             case :$compile_shlibpath: in
+             *":$add_shlibpath:"*) ;;
+             *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;;
+             esac
+           fi
+           if test "$linkmode" = prog; then
+             test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs"
+             test -n "$add" && compile_deplibs="$add $compile_deplibs"
+           else
+             test -n "$add_dir" && deplibs="$add_dir $deplibs"
+             test -n "$add" && deplibs="$add $deplibs"
+             if test "$hardcode_direct" != yes &&
+                test "$hardcode_minus_L" != yes &&
+                test "$hardcode_shlibpath_var" = yes; then
+               case :$finalize_shlibpath: in
+               *":$libdir:"*) ;;
+               *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
+               esac
+             fi
+           fi
+         fi
+
+         if test "$linkmode" = prog || test "$mode" = relink; then
+           add_shlibpath=
+           add_dir=
+           add=
+           # Finalize command for both is simple: just hardcode it.
+           if test "$hardcode_direct" = yes &&
+              test "$hardcode_direct_absolute" = no; then
+             add="$libdir/$linklib"
+           elif test "$hardcode_minus_L" = yes; then
+             add_dir="-L$libdir"
+             add="-l$name"
+           elif test "$hardcode_shlibpath_var" = yes; then
+             case :$finalize_shlibpath: in
+             *":$libdir:"*) ;;
+             *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
+             esac
+             add="-l$name"
+           elif test "$hardcode_automatic" = yes; then
+             if test -n "$inst_prefix_dir" &&
+                test -f "$inst_prefix_dir$libdir/$linklib" ; then
+               add="$inst_prefix_dir$libdir/$linklib"
+             else
+               add="$libdir/$linklib"
+             fi
+           else
+             # We cannot seem to hardcode it, guess we'll fake it.
+             add_dir="-L$libdir"
+             # Try looking first in the location we're being installed to.
+             if test -n "$inst_prefix_dir"; then
+               case $libdir in
+                 [\\/]*)
+                   add_dir="$add_dir -L$inst_prefix_dir$libdir"
+                   ;;
+               esac
+             fi
+             add="-l$name"
+           fi
+
+           if test "$linkmode" = prog; then
+             test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs"
+             test -n "$add" && finalize_deplibs="$add $finalize_deplibs"
+           else
+             test -n "$add_dir" && deplibs="$add_dir $deplibs"
+             test -n "$add" && deplibs="$add $deplibs"
+           fi
+         fi
+       elif test "$linkmode" = prog; then
+         # Here we assume that one of hardcode_direct or hardcode_minus_L
+         # is not unsupported.  This is valid on all known static and
+         # shared platforms.
+         if test "$hardcode_direct" != unsupported; then
+           test -n "$old_library" && linklib="$old_library"
+           compile_deplibs="$dir/$linklib $compile_deplibs"
+           finalize_deplibs="$dir/$linklib $finalize_deplibs"
+         else
+           compile_deplibs="-l$name -L$dir $compile_deplibs"
+           finalize_deplibs="-l$name -L$dir $finalize_deplibs"
+         fi
+       elif test "$build_libtool_libs" = yes; then
+         # Not a shared library
+         if test "$deplibs_check_method" != pass_all; then
+           # We're trying link a shared library against a static one
+           # but the system doesn't support it.
+
+           # Just print a warning and add the library to dependency_libs so
+           # that the program can be linked against the static library.
+           $ECHO
+           $ECHO "*** Warning: This system can not link to static lib archive $lib."
+           $ECHO "*** I have the capability to make that library automatically link in when"
+           $ECHO "*** you link to this library.  But I can only do this if you have a"
+           $ECHO "*** shared version of the library, which you do not appear to have."
+           if test "$module" = yes; then
+             $ECHO "*** But as you try to build a module library, libtool will still create "
+             $ECHO "*** a static module, that should work as long as the dlopening application"
+             $ECHO "*** is linked with the -dlopen flag to resolve symbols at runtime."
+             if test -z "$global_symbol_pipe"; then
+               $ECHO
+               $ECHO "*** However, this would only work if libtool was able to extract symbol"
+               $ECHO "*** lists from a program, using \`nm' or equivalent, but libtool could"
+               $ECHO "*** not find such a program.  So, this module is probably useless."
+               $ECHO "*** \`nm' from GNU binutils and a full rebuild may help."
+             fi
+             if test "$build_old_libs" = no; then
+               build_libtool_libs=module
+               build_old_libs=yes
+             else
+               build_libtool_libs=no
+             fi
+           fi
+         else
+           deplibs="$dir/$old_library $deplibs"
+           link_static=yes
+         fi
+       fi # link shared/static library?
+
+       if test "$linkmode" = lib; then
+         if test -n "$dependency_libs" &&
+            { test "$hardcode_into_libs" != yes ||
+              test "$build_old_libs" = yes ||
+              test "$link_static" = yes; }; then
+           # Extract -R from dependency_libs
+           temp_deplibs=
+           for libdir in $dependency_libs; do
+             case $libdir in
+             -R*) func_stripname '-R' '' "$libdir"
+                  temp_xrpath=$func_stripname_result
+                  case " $xrpath " in
+                  *" $temp_xrpath "*) ;;
+                  *) xrpath="$xrpath $temp_xrpath";;
+                  esac;;
+             *) temp_deplibs="$temp_deplibs $libdir";;
+             esac
+           done
+           dependency_libs="$temp_deplibs"
+         fi
+
+         newlib_search_path="$newlib_search_path $absdir"
+         # Link against this library
+         test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
+         # ... and its dependency_libs
+         tmp_libs=
+         for deplib in $dependency_libs; do
+           newdependency_libs="$deplib $newdependency_libs"
+           if $opt_duplicate_deps ; then
+             case "$tmp_libs " in
+             *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
+             esac
+           fi
+           tmp_libs="$tmp_libs $deplib"
+         done
+
+         if test "$link_all_deplibs" != no; then
+           # Add the search paths of all dependency libraries
+           for deplib in $dependency_libs; do
+             case $deplib in
+             -L*) path="$deplib" ;;
+             *.la)
+               func_dirname "$deplib" "" "."
+               dir="$func_dirname_result"
+               # We need an absolute path.
+               case $dir in
+               [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;;
+               *)
+                 absdir=`cd "$dir" && pwd`
+                 if test -z "$absdir"; then
+                   func_warning "cannot determine absolute directory name of \`$dir'"
+                   absdir="$dir"
+                 fi
+                 ;;
+               esac
+               if $GREP "^installed=no" $deplib > /dev/null; then
+               case $host in
+               *-*-darwin*)
+                 depdepl=
+                 eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
+                 if test -n "$deplibrary_names" ; then
+                   for tmp in $deplibrary_names ; do
+                     depdepl=$tmp
+                   done
+                   if test -f "$absdir/$objdir/$depdepl" ; then
+                     depdepl="$absdir/$objdir/$depdepl"
+                     darwin_install_name=`${OTOOL} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
+                      if test -z "$darwin_install_name"; then
+                          darwin_install_name=`${OTOOL64} -L $depdepl  | awk '{if (NR == 2) {print $1;exit}}'`
+                      fi
+                     compiler_flags="$compiler_flags ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}"
+                     linker_flags="$linker_flags -dylib_file ${darwin_install_name}:${depdepl}"
+                     path=
+                   fi
+                 fi
+                 ;;
+               *)
+                 path="-L$absdir/$objdir"
+                 ;;
+               esac
+               else
+                 eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
+                 test -z "$libdir" && \
+                   func_fatal_error "\`$deplib' is not a valid libtool archive"
+                 test "$absdir" != "$libdir" && \
+                   func_warning "\`$deplib' seems to be moved"
+
+                 path="-L$absdir"
+               fi
+               ;;
+             esac
+             case " $deplibs " in
+             *" $path "*) ;;
+             *) deplibs="$path $deplibs" ;;
+             esac
+           done
+         fi # link_all_deplibs != no
+       fi # linkmode = lib
+      done # for deplib in $libs
+      if test "$pass" = link; then
+       if test "$linkmode" = "prog"; then
+         compile_deplibs="$new_inherited_linker_flags $compile_deplibs"
+         finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs"
+       else
+         compiler_flags="$compiler_flags "`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
+       fi
+      fi
+      dependency_libs="$newdependency_libs"
+      if test "$pass" = dlpreopen; then
+       # Link the dlpreopened libraries before other libraries
+       for deplib in $save_deplibs; do
+         deplibs="$deplib $deplibs"
+       done
+      fi
+      if test "$pass" != dlopen; then
+       if test "$pass" != conv; then
+         # Make sure lib_search_path contains only unique directories.
+         lib_search_path=
+         for dir in $newlib_search_path; do
+           case "$lib_search_path " in
+           *" $dir "*) ;;
+           *) lib_search_path="$lib_search_path $dir" ;;
+           esac
+         done
+         newlib_search_path=
+       fi
+
+       if test "$linkmode,$pass" != "prog,link"; then
+         vars="deplibs"
+       else
+         vars="compile_deplibs finalize_deplibs"
+       fi
+       for var in $vars dependency_libs; do
+         # Add libraries to $var in reverse order
+         eval tmp_libs=\"\$$var\"
+         new_libs=
+         for deplib in $tmp_libs; do
+           # FIXME: Pedantically, this is the right thing to do, so
+           #        that some nasty dependency loop isn't accidentally
+           #        broken:
+           #new_libs="$deplib $new_libs"
+           # Pragmatically, this seems to cause very few problems in
+           # practice:
+           case $deplib in
+           -L*) new_libs="$deplib $new_libs" ;;
+           -R*) ;;
+           *)
+             # And here is the reason: when a library appears more
+             # than once as an explicit dependence of a library, or
+             # is implicitly linked in more than once by the
+             # compiler, it is considered special, and multiple
+             # occurrences thereof are not removed.  Compare this
+             # with having the same library being listed as a
+             # dependency of multiple other libraries: in this case,
+             # we know (pedantically, we assume) the library does not
+             # need to be listed more than once, so we keep only the
+             # last copy.  This is not always right, but it is rare
+             # enough that we require users that really mean to play
+             # such unportable linking tricks to link the library
+             # using -Wl,-lname, so that libtool does not consider it
+             # for duplicate removal.
+             case " $specialdeplibs " in
+             *" $deplib "*) new_libs="$deplib $new_libs" ;;
+             *)
+               case " $new_libs " in
+               *" $deplib "*) ;;
+               *) new_libs="$deplib $new_libs" ;;
+               esac
+               ;;
+             esac
+             ;;
+           esac
+         done
+         tmp_libs=
+         for deplib in $new_libs; do
+           case $deplib in
+           -L*)
+             case " $tmp_libs " in
+             *" $deplib "*) ;;
+             *) tmp_libs="$tmp_libs $deplib" ;;
+             esac
+             ;;
+           *) tmp_libs="$tmp_libs $deplib" ;;
+           esac
+         done
+         eval $var=\"$tmp_libs\"
+       done # for var
+      fi
+      # Last step: remove runtime libs from dependency_libs
+      # (they stay in deplibs)
+      tmp_libs=
+      for i in $dependency_libs ; do
+       case " $predeps $postdeps $compiler_lib_search_path " in
+       *" $i "*)
+         i=""
+         ;;
+       esac
+       if test -n "$i" ; then
+         tmp_libs="$tmp_libs $i"
+       fi
+      done
+      dependency_libs=$tmp_libs
+    done # for pass
+    if test "$linkmode" = prog; then
+      dlfiles="$newdlfiles"
+    fi
+    if test "$linkmode" = prog || test "$linkmode" = lib; then
+      dlprefiles="$newdlprefiles"
+    fi
+
+    case $linkmode in
+    oldlib)
+      if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
+       func_warning "\`-dlopen' is ignored for archives"
+      fi
+
+      case " $deplibs" in
+      *\ -l* | *\ -L*)
+       func_warning "\`-l' and \`-L' are ignored for archives" ;;
+      esac
+
+      test -n "$rpath" && \
+       func_warning "\`-rpath' is ignored for archives"
+
+      test -n "$xrpath" && \
+       func_warning "\`-R' is ignored for archives"
+
+      test -n "$vinfo" && \
+       func_warning "\`-version-info/-version-number' is ignored for archives"
+
+      test -n "$release" && \
+       func_warning "\`-release' is ignored for archives"
+
+      test -n "$export_symbols$export_symbols_regex" && \
+       func_warning "\`-export-symbols' is ignored for archives"
+
+      # Now set the variables for building old libraries.
+      build_libtool_libs=no
+      oldlibs="$output"
+      objs="$objs$old_deplibs"
+      ;;
+
+    lib)
+      # Make sure we only generate libraries of the form `libNAME.la'.
+      case $outputname in
+      lib*)
+       func_stripname 'lib' '.la' "$outputname"
+       name=$func_stripname_result
+       eval shared_ext=\"$shrext_cmds\"
+       eval libname=\"$libname_spec\"
+       ;;
+      *)
+       test "$module" = no && \
+         func_fatal_help "libtool library \`$output' must begin with \`lib'"
+
+       if test "$need_lib_prefix" != no; then
+         # Add the "lib" prefix for modules if required
+         func_stripname '' '.la' "$outputname"
+         name=$func_stripname_result
+         eval shared_ext=\"$shrext_cmds\"
+         eval libname=\"$libname_spec\"
+       else
+         func_stripname '' '.la' "$outputname"
+         libname=$func_stripname_result
+       fi
+       ;;
+      esac
+
+      if test -n "$objs"; then
+       if test "$deplibs_check_method" != pass_all; then
+         func_fatal_error "cannot build libtool library \`$output' from non-libtool objects on this host:$objs"
+       else
+         $ECHO
+         $ECHO "*** Warning: Linking the shared library $output against the non-libtool"
+         $ECHO "*** objects $objs is not portable!"
+         libobjs="$libobjs $objs"
+       fi
+      fi
+
+      test "$dlself" != no && \
+       func_warning "\`-dlopen self' is ignored for libtool libraries"
+
+      set dummy $rpath
+      shift
+      test "$#" -gt 1 && \
+       func_warning "ignoring multiple \`-rpath's for a libtool library"
+
+      install_libdir="$1"
+
+      oldlibs=
+      if test -z "$rpath"; then
+       if test "$build_libtool_libs" = yes; then
+         # Building a libtool convenience library.
+         # Some compilers have problems with a `.al' extension so
+         # convenience libraries should have the same extension an
+         # archive normally would.
+         oldlibs="$output_objdir/$libname.$libext $oldlibs"
+         build_libtool_libs=convenience
+         build_old_libs=yes
+       fi
+
+       test -n "$vinfo" && \
+         func_warning "\`-version-info/-version-number' is ignored for convenience libraries"
+
+       test -n "$release" && \
+         func_warning "\`-release' is ignored for convenience libraries"
+      else
+
+       # Parse the version information argument.
+       save_ifs="$IFS"; IFS=':'
+       set dummy $vinfo 0 0 0
+       shift
+       IFS="$save_ifs"
+
+       test -n "$7" && \
+         func_fatal_help "too many parameters to \`-version-info'"
+
+       # convert absolute version numbers to libtool ages
+       # this retains compatibility with .la files and attempts
+       # to make the code below a bit more comprehensible
+
+       case $vinfo_number in
+       yes)
+         number_major="$1"
+         number_minor="$2"
+         number_revision="$3"
+         #
+         # There are really only two kinds -- those that
+         # use the current revision as the major version
+         # and those that subtract age and use age as
+         # a minor version.  But, then there is irix
+         # which has an extra 1 added just for fun
+         #
+         case $version_type in
+         darwin|linux|osf|windows|none)
+           func_arith $number_major + $number_minor
+           current=$func_arith_result
+           age="$number_minor"
+           revision="$number_revision"
+           ;;
+         freebsd-aout|freebsd-elf|sunos)
+           current="$number_major"
+           revision="$number_minor"
+           age="0"
+           ;;
+         irix|nonstopux)
+           func_arith $number_major + $number_minor
+           current=$func_arith_result
+           age="$number_minor"
+           revision="$number_minor"
+           lt_irix_increment=no
+           ;;
+         esac
+         ;;
+       no)
+         current="$1"
+         revision="$2"
+         age="$3"
+         ;;
+       esac
+
+       # Check that each of the things are valid numbers.
+       case $current in
+       0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
+       *)
+         func_error "CURRENT \`$current' must be a nonnegative integer"
+         func_fatal_error "\`$vinfo' is not valid version information"
+         ;;
+       esac
+
+       case $revision in
+       0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
+       *)
+         func_error "REVISION \`$revision' must be a nonnegative integer"
+         func_fatal_error "\`$vinfo' is not valid version information"
+         ;;
+       esac
+
+       case $age in
+       0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
+       *)
+         func_error "AGE \`$age' must be a nonnegative integer"
+         func_fatal_error "\`$vinfo' is not valid version information"
+         ;;
+       esac
+
+       if test "$age" -gt "$current"; then
+         func_error "AGE \`$age' is greater than the current interface number \`$current'"
+         func_fatal_error "\`$vinfo' is not valid version information"
+       fi
+
+       # Calculate the version variables.
+       major=
+       versuffix=
+       verstring=
+       case $version_type in
+       none) ;;
+
+       darwin)
+         # Like Linux, but with the current version available in
+         # verstring for coding it into the library header
+         func_arith $current - $age
+         major=.$func_arith_result
+         versuffix="$major.$age.$revision"
+         # Darwin ld doesn't like 0 for these options...
+         func_arith $current + 1
+         minor_current=$func_arith_result
+         xlcverstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision"
+         verstring="-compatibility_version $minor_current -current_version $minor_current.$revision"
+         ;;
+
+       freebsd-aout)
+         major=".$current"
+         versuffix=".$current.$revision";
+         ;;
+
+       freebsd-elf)
+         major=".$current"
+         versuffix=".$current"
+         ;;
+
+       irix | nonstopux)
+         if test "X$lt_irix_increment" = "Xno"; then
+           func_arith $current - $age
+         else
+           func_arith $current - $age + 1
+         fi
+         major=$func_arith_result
+
+         case $version_type in
+           nonstopux) verstring_prefix=nonstopux ;;
+           *)         verstring_prefix=sgi ;;
+         esac
+         verstring="$verstring_prefix$major.$revision"
+
+         # Add in all the interfaces that we are compatible with.
+         loop=$revision
+         while test "$loop" -ne 0; do
+           func_arith $revision - $loop
+           iface=$func_arith_result
+           func_arith $loop - 1
+           loop=$func_arith_result
+           verstring="$verstring_prefix$major.$iface:$verstring"
+         done
+
+         # Before this point, $major must not contain `.'.
+         major=.$major
+         versuffix="$major.$revision"
+         ;;
+
+       linux)
+         func_arith $current - $age
+         major=.$func_arith_result
+         versuffix="$major.$age.$revision"
+         ;;
+
+       osf)
+         func_arith $current - $age
+         major=.$func_arith_result
+         versuffix=".$current.$age.$revision"
+         verstring="$current.$age.$revision"
+
+         # Add in all the interfaces that we are compatible with.
+         loop=$age
+         while test "$loop" -ne 0; do
+           func_arith $current - $loop
+           iface=$func_arith_result
+           func_arith $loop - 1
+           loop=$func_arith_result
+           verstring="$verstring:${iface}.0"
+         done
+
+         # Make executables depend on our current version.
+         verstring="$verstring:${current}.0"
+         ;;
+
+       qnx)
+         major=".$current"
+         versuffix=".$current"
+         ;;
+
+       sunos)
+         major=".$current"
+         versuffix=".$current.$revision"
+         ;;
+
+       windows)
+         # Use '-' rather than '.', since we only want one
+         # extension on DOS 8.3 filesystems.
+         func_arith $current - $age
+         major=$func_arith_result
+         versuffix="-$major"
+         ;;
+
+       *)
+         func_fatal_configuration "unknown library version type \`$version_type'"
+         ;;
+       esac
+
+       # Clear the version info if we defaulted, and they specified a release.
+       if test -z "$vinfo" && test -n "$release"; then
+         major=
+         case $version_type in
+         darwin)
+           # we can't check for "0.0" in archive_cmds due to quoting
+           # problems, so we reset it completely
+           verstring=
+           ;;
+         *)
+           verstring="0.0"
+           ;;
+         esac
+         if test "$need_version" = no; then
+           versuffix=
+         else
+           versuffix=".0.0"
+         fi
+       fi
+
+       # Remove version info from name if versioning should be avoided
+       if test "$avoid_version" = yes && test "$need_version" = no; then
+         major=
+         versuffix=
+         verstring=""
+       fi
+
+       # Check to see if the archive will have undefined symbols.
+       if test "$allow_undefined" = yes; then
+         if test "$allow_undefined_flag" = unsupported; then
+           func_warning "undefined symbols not allowed in $host shared libraries"
+           build_libtool_libs=no
+           build_old_libs=yes
+         fi
+       else
+         # Don't allow undefined symbols.
+         allow_undefined_flag="$no_undefined_flag"
+       fi
+
+      fi
+
+      func_generate_dlsyms "$libname" "$libname" "yes"
+      libobjs="$libobjs $symfileobj"
+      test "X$libobjs" = "X " && libobjs=
+
+      if test "$mode" != relink; then
+       # Remove our outputs, but don't remove object files since they
+       # may have been created when compiling PIC objects.
+       removelist=
+       tempremovelist=`$ECHO "$output_objdir/*"`
+       for p in $tempremovelist; do
+         case $p in
+           *.$objext | *.gcno)
+              ;;
+           $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*)
+              if test "X$precious_files_regex" != "X"; then
+                if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1
+                then
+                  continue
+                fi
+              fi
+              removelist="$removelist $p"
+              ;;
+           *) ;;
+         esac
+       done
+       test -n "$removelist" && \
+         func_show_eval "${RM}r \$removelist"
+      fi
+
+      # Now set the variables for building old libraries.
+      if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then
+       oldlibs="$oldlibs $output_objdir/$libname.$libext"
+
+       # Transform .lo files to .o files.
+       oldobjs="$objs "`$ECHO "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP`
+      fi
+
+      # Eliminate all temporary directories.
+      #for path in $notinst_path; do
+      #        lib_search_path=`$ECHO "X$lib_search_path " | $Xsed -e "s% $path % %g"`
+      #        deplibs=`$ECHO "X$deplibs " | $Xsed -e "s% -L$path % %g"`
+      #        dependency_libs=`$ECHO "X$dependency_libs " | $Xsed -e "s% -L$path % %g"`
+      #done
+
+      if test -n "$xrpath"; then
+       # If the user specified any rpath flags, then add them.
+       temp_xrpath=
+       for libdir in $xrpath; do
+         temp_xrpath="$temp_xrpath -R$libdir"
+         case "$finalize_rpath " in
+         *" $libdir "*) ;;
+         *) finalize_rpath="$finalize_rpath $libdir" ;;
+         esac
+       done
+       if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then
+         dependency_libs="$temp_xrpath $dependency_libs"
+       fi
+      fi
+
+      # Make sure dlfiles contains only unique files that won't be dlpreopened
+      old_dlfiles="$dlfiles"
+      dlfiles=
+      for lib in $old_dlfiles; do
+       case " $dlprefiles $dlfiles " in
+       *" $lib "*) ;;
+       *) dlfiles="$dlfiles $lib" ;;
+       esac
+      done
+
+      # Make sure dlprefiles contains only unique files
+      old_dlprefiles="$dlprefiles"
+      dlprefiles=
+      for lib in $old_dlprefiles; do
+       case "$dlprefiles " in
+       *" $lib "*) ;;
+       *) dlprefiles="$dlprefiles $lib" ;;
+       esac
+      done
+
+      if test "$build_libtool_libs" = yes; then
+       if test -n "$rpath"; then
+         case $host in
+         *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc*)
+           # these systems don't actually have a c library (as such)!
+           ;;
+         *-*-rhapsody* | *-*-darwin1.[012])
+           # Rhapsody C library is in the System framework
+           deplibs="$deplibs System.ltframework"
+           ;;
+         *-*-netbsd*)
+           # Don't link with libc until the a.out ld.so is fixed.
+           ;;
+         *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
+           # Do not include libc due to us having libc/libc_r.
+           ;;
+         *-*-sco3.2v5* | *-*-sco5v6*)
+           # Causes problems with __ctype
+           ;;
+         *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*)
+           # Compiler inserts libc in the correct place for threads to work
+           ;;
+         *)
+           # Add libc to deplibs on all other systems if necessary.
+           if test "$build_libtool_need_lc" = "yes"; then
+             deplibs="$deplibs -lc"
+           fi
+           ;;
+         esac
+       fi
+
+       # Transform deplibs into only deplibs that can be linked in shared.
+       name_save=$name
+       libname_save=$libname
+       release_save=$release
+       versuffix_save=$versuffix
+       major_save=$major
+       # I'm not sure if I'm treating the release correctly.  I think
+       # release should show up in the -l (ie -lgmp5) so we don't want to
+       # add it in twice.  Is that correct?
+       release=""
+       versuffix=""
+       major=""
+       newdeplibs=
+       droppeddeps=no
+       case $deplibs_check_method in
+       pass_all)
+         # Don't check for shared/static.  Everything works.
+         # This might be a little naive.  We might want to check
+         # whether the library exists or not.  But this is on
+         # osf3 & osf4 and I'm not really sure... Just
+         # implementing what was already the behavior.
+         newdeplibs=$deplibs
+         ;;
+       test_compile)
+         # This code stresses the "libraries are programs" paradigm to its
+         # limits. Maybe even breaks it.  We compile a program, linking it
+         # against the deplibs as a proxy for the library.  Then we can check
+         # whether they linked in statically or dynamically with ldd.
+         $opt_dry_run || $RM conftest.c
+         cat > conftest.c <<EOF
+         int main() { return 0; }
+EOF
+         $opt_dry_run || $RM conftest
+         if $LTCC $LTCFLAGS -o conftest conftest.c $deplibs; then
+           ldd_output=`ldd conftest`
+           for i in $deplibs; do
+             case $i in
+             -l*)
+               func_stripname -l '' "$i"
+               name=$func_stripname_result
+               if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+                 case " $predeps $postdeps " in
+                 *" $i "*)
+                   newdeplibs="$newdeplibs $i"
+                   i=""
+                   ;;
+                 esac
+               fi
+               if test -n "$i" ; then
+                 libname=`eval "\\$ECHO \"$libname_spec\""`
+                 deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
+                 set dummy $deplib_matches; shift
+                 deplib_match=$1
+                 if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
+                   newdeplibs="$newdeplibs $i"
+                 else
+                   droppeddeps=yes
+                   $ECHO
+                   $ECHO "*** Warning: dynamic linker does not accept needed library $i."
+                   $ECHO "*** I have the capability to make that library automatically link in when"
+                   $ECHO "*** you link to this library.  But I can only do this if you have a"
+                   $ECHO "*** shared version of the library, which I believe you do not have"
+                   $ECHO "*** because a test_compile did reveal that the linker did not use it for"
+                   $ECHO "*** its dynamic dependency list that programs get resolved with at runtime."
+                 fi
+               fi
+               ;;
+             *)
+               newdeplibs="$newdeplibs $i"
+               ;;
+             esac
+           done
+         else
+           # Error occurred in the first compile.  Let's try to salvage
+           # the situation: Compile a separate program for each library.
+           for i in $deplibs; do
+             case $i in
+             -l*)
+               func_stripname -l '' "$i"
+               name=$func_stripname_result
+               $opt_dry_run || $RM conftest
+               if $LTCC $LTCFLAGS -o conftest conftest.c $i; then
+                 ldd_output=`ldd conftest`
+                 if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+                   case " $predeps $postdeps " in
+                   *" $i "*)
+                     newdeplibs="$newdeplibs $i"
+                     i=""
+                     ;;
+                   esac
+                 fi
+                 if test -n "$i" ; then
+                   libname=`eval "\\$ECHO \"$libname_spec\""`
+                   deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
+                   set dummy $deplib_matches; shift
+                   deplib_match=$1
+                   if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
+                     newdeplibs="$newdeplibs $i"
+                   else
+                     droppeddeps=yes
+                     $ECHO
+                     $ECHO "*** Warning: dynamic linker does not accept needed library $i."
+                     $ECHO "*** I have the capability to make that library automatically link in when"
+                     $ECHO "*** you link to this library.  But I can only do this if you have a"
+                     $ECHO "*** shared version of the library, which you do not appear to have"
+                     $ECHO "*** because a test_compile did reveal that the linker did not use this one"
+                     $ECHO "*** as a dynamic dependency that programs can get resolved with at runtime."
+                   fi
+                 fi
+               else
+                 droppeddeps=yes
+                 $ECHO
+                 $ECHO "*** Warning!  Library $i is needed by this library but I was not able to"
+                 $ECHO "*** make it link in!  You will probably need to install it or some"
+                 $ECHO "*** library that it depends on before this library will be fully"
+                 $ECHO "*** functional.  Installing it before continuing would be even better."
+               fi
+               ;;
+             *)
+               newdeplibs="$newdeplibs $i"
+               ;;
+             esac
+           done
+         fi
+         ;;
+       file_magic*)
+         set dummy $deplibs_check_method; shift
+         file_magic_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
+         for a_deplib in $deplibs; do
+           case $a_deplib in
+           -l*)
+             func_stripname -l '' "$a_deplib"
+             name=$func_stripname_result
+             if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+               case " $predeps $postdeps " in
+               *" $a_deplib "*)
+                 newdeplibs="$newdeplibs $a_deplib"
+                 a_deplib=""
+                 ;;
+               esac
+             fi
+             if test -n "$a_deplib" ; then
+               libname=`eval "\\$ECHO \"$libname_spec\""`
+               for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
+                 potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
+                 for potent_lib in $potential_libs; do
+                     # Follow soft links.
+                     if ls -lLd "$potent_lib" 2>/dev/null |
+                        $GREP " -> " >/dev/null; then
+                       continue
+                     fi
+                     # The statement above tries to avoid entering an
+                     # endless loop below, in case of cyclic links.
+                     # We might still enter an endless loop, since a link
+                     # loop can be closed while we follow links,
+                     # but so what?
+                     potlib="$potent_lib"
+                     while test -h "$potlib" 2>/dev/null; do
+                       potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'`
+                       case $potliblink in
+                       [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";;
+                       *) potlib=`$ECHO "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";;
+                       esac
+                     done
+                     if eval $file_magic_cmd \"\$potlib\" 2>/dev/null |
+                        $SED -e 10q |
+                        $EGREP "$file_magic_regex" > /dev/null; then
+                       newdeplibs="$newdeplibs $a_deplib"
+                       a_deplib=""
+                       break 2
+                     fi
+                 done
+               done
+             fi
+             if test -n "$a_deplib" ; then
+               droppeddeps=yes
+               $ECHO
+               $ECHO "*** Warning: linker path does not have real file for library $a_deplib."
+               $ECHO "*** I have the capability to make that library automatically link in when"
+               $ECHO "*** you link to this library.  But I can only do this if you have a"
+               $ECHO "*** shared version of the library, which you do not appear to have"
+               $ECHO "*** because I did check the linker path looking for a file starting"
+               if test -z "$potlib" ; then
+                 $ECHO "*** with $libname but no candidates were found. (...for file magic test)"
+               else
+                 $ECHO "*** with $libname and none of the candidates passed a file format test"
+                 $ECHO "*** using a file magic. Last file checked: $potlib"
+               fi
+             fi
+             ;;
+           *)
+             # Add a -L argument.
+             newdeplibs="$newdeplibs $a_deplib"
+             ;;
+           esac
+         done # Gone through all deplibs.
+         ;;
+       match_pattern*)
+         set dummy $deplibs_check_method; shift
+         match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
+         for a_deplib in $deplibs; do
+           case $a_deplib in
+           -l*)
+             func_stripname -l '' "$a_deplib"
+             name=$func_stripname_result
+             if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+               case " $predeps $postdeps " in
+               *" $a_deplib "*)
+                 newdeplibs="$newdeplibs $a_deplib"
+                 a_deplib=""
+                 ;;
+               esac
+             fi
+             if test -n "$a_deplib" ; then
+               libname=`eval "\\$ECHO \"$libname_spec\""`
+               for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
+                 potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
+                 for potent_lib in $potential_libs; do
+                   potlib="$potent_lib" # see symlink-check above in file_magic test
+                   if eval "\$ECHO \"X$potent_lib\"" 2>/dev/null | $Xsed -e 10q | \
+                      $EGREP "$match_pattern_regex" > /dev/null; then
+                     newdeplibs="$newdeplibs $a_deplib"
+                     a_deplib=""
+                     break 2
+                   fi
+                 done
+               done
+             fi
+             if test -n "$a_deplib" ; then
+               droppeddeps=yes
+               $ECHO
+               $ECHO "*** Warning: linker path does not have real file for library $a_deplib."
+               $ECHO "*** I have the capability to make that library automatically link in when"
+               $ECHO "*** you link to this library.  But I can only do this if you have a"
+               $ECHO "*** shared version of the library, which you do not appear to have"
+               $ECHO "*** because I did check the linker path looking for a file starting"
+               if test -z "$potlib" ; then
+                 $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)"
+               else
+                 $ECHO "*** with $libname and none of the candidates passed a file format test"
+                 $ECHO "*** using a regex pattern. Last file checked: $potlib"
+               fi
+             fi
+             ;;
+           *)
+             # Add a -L argument.
+             newdeplibs="$newdeplibs $a_deplib"
+             ;;
+           esac
+         done # Gone through all deplibs.
+         ;;
+       none | unknown | *)
+         newdeplibs=""
+         tmp_deplibs=`$ECHO "X $deplibs" | $Xsed \
+             -e 's/ -lc$//' -e 's/ -[LR][^ ]*//g'`
+         if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+           for i in $predeps $postdeps ; do
+             # can't use Xsed below, because $i might contain '/'
+             tmp_deplibs=`$ECHO "X $tmp_deplibs" | $Xsed -e "s,$i,,"`
+           done
+         fi
+         if $ECHO "X $tmp_deplibs" | $Xsed -e 's/[      ]//g' |
+            $GREP . >/dev/null; then
+           $ECHO
+           if test "X$deplibs_check_method" = "Xnone"; then
+             $ECHO "*** Warning: inter-library dependencies are not supported in this platform."
+           else
+             $ECHO "*** Warning: inter-library dependencies are not known to be supported."
+           fi
+           $ECHO "*** All declared inter-library dependencies are being dropped."
+           droppeddeps=yes
+         fi
+         ;;
+       esac
+       versuffix=$versuffix_save
+       major=$major_save
+       release=$release_save
+       libname=$libname_save
+       name=$name_save
+
+       case $host in
+       *-*-rhapsody* | *-*-darwin1.[012])
+         # On Rhapsody replace the C library with the System framework
+         newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's/ -lc / System.ltframework /'`
+         ;;
+       esac
+
+       if test "$droppeddeps" = yes; then
+         if test "$module" = yes; then
+           $ECHO
+           $ECHO "*** Warning: libtool could not satisfy all declared inter-library"
+           $ECHO "*** dependencies of module $libname.  Therefore, libtool will create"
+           $ECHO "*** a static module, that should work as long as the dlopening"
+           $ECHO "*** application is linked with the -dlopen flag."
+           if test -z "$global_symbol_pipe"; then
+             $ECHO
+             $ECHO "*** However, this would only work if libtool was able to extract symbol"
+             $ECHO "*** lists from a program, using \`nm' or equivalent, but libtool could"
+             $ECHO "*** not find such a program.  So, this module is probably useless."
+             $ECHO "*** \`nm' from GNU binutils and a full rebuild may help."
+           fi
+           if test "$build_old_libs" = no; then
+             oldlibs="$output_objdir/$libname.$libext"
+             build_libtool_libs=module
+             build_old_libs=yes
+           else
+             build_libtool_libs=no
+           fi
+         else
+           $ECHO "*** The inter-library dependencies that have been dropped here will be"
+           $ECHO "*** automatically added whenever a program is linked with this library"
+           $ECHO "*** or is declared to -dlopen it."
+
+           if test "$allow_undefined" = no; then
+             $ECHO
+             $ECHO "*** Since this library must not contain undefined symbols,"
+             $ECHO "*** because either the platform does not support them or"
+             $ECHO "*** it was explicitly requested with -no-undefined,"
+             $ECHO "*** libtool will only create a static version of it."
+             if test "$build_old_libs" = no; then
+               oldlibs="$output_objdir/$libname.$libext"
+               build_libtool_libs=module
+               build_old_libs=yes
+             else
+               build_libtool_libs=no
+             fi
+           fi
+         fi
+       fi
+       # Done checking deplibs!
+       deplibs=$newdeplibs
+      fi
+      # Time to change all our "foo.ltframework" stuff back to "-framework foo"
+      case $host in
+       *-*-darwin*)
+         newdeplibs=`$ECHO "X $newdeplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
+         new_inherited_linker_flags=`$ECHO "X $new_inherited_linker_flags" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
+         deplibs=`$ECHO "X $deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
+         ;;
+      esac
+
+      # move library search paths that coincide with paths to not yet
+      # installed libraries to the beginning of the library search list
+      new_libs=
+      for path in $notinst_path; do
+       case " $new_libs " in
+       *" -L$path/$objdir "*) ;;
+       *)
+         case " $deplibs " in
+         *" -L$path/$objdir "*)
+           new_libs="$new_libs -L$path/$objdir" ;;
+         esac
+         ;;
+       esac
+      done
+      for deplib in $deplibs; do
+       case $deplib in
+       -L*)
+         case " $new_libs " in
+         *" $deplib "*) ;;
+         *) new_libs="$new_libs $deplib" ;;
+         esac
+         ;;
+       *) new_libs="$new_libs $deplib" ;;
+       esac
+      done
+      deplibs="$new_libs"
+
+      # All the library-specific variables (install_libdir is set above).
+      library_names=
+      old_library=
+      dlname=
+
+      # Test again, we may have decided not to build it any more
+      if test "$build_libtool_libs" = yes; then
+       if test "$hardcode_into_libs" = yes; then
+         # Hardcode the library paths
+         hardcode_libdirs=
+         dep_rpath=
+         rpath="$finalize_rpath"
+         test "$mode" != relink && rpath="$compile_rpath$rpath"
+         for libdir in $rpath; do
+           if test -n "$hardcode_libdir_flag_spec"; then
+             if test -n "$hardcode_libdir_separator"; then
+               if test -z "$hardcode_libdirs"; then
+                 hardcode_libdirs="$libdir"
+               else
+                 # Just accumulate the unique libdirs.
+                 case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
+                 *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
+                   ;;
+                 *)
+                   hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
+                   ;;
+                 esac
+               fi
+             else
+               eval flag=\"$hardcode_libdir_flag_spec\"
+               dep_rpath="$dep_rpath $flag"
+             fi
+           elif test -n "$runpath_var"; then
+             case "$perm_rpath " in
+             *" $libdir "*) ;;
+             *) perm_rpath="$perm_rpath $libdir" ;;
+             esac
+           fi
+         done
+         # Substitute the hardcoded libdirs into the rpath.
+         if test -n "$hardcode_libdir_separator" &&
+            test -n "$hardcode_libdirs"; then
+           libdir="$hardcode_libdirs"
+           if test -n "$hardcode_libdir_flag_spec_ld"; then
+             eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\"
+           else
+             eval dep_rpath=\"$hardcode_libdir_flag_spec\"
+           fi
+         fi
+         if test -n "$runpath_var" && test -n "$perm_rpath"; then
+           # We should set the runpath_var.
+           rpath=
+           for dir in $perm_rpath; do
+             rpath="$rpath$dir:"
+           done
+           eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var"
+         fi
+         test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs"
+       fi
+
+       shlibpath="$finalize_shlibpath"
+       test "$mode" != relink && shlibpath="$compile_shlibpath$shlibpath"
+       if test -n "$shlibpath"; then
+         eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var"
+       fi
+
+       # Get the real and link names of the library.
+       eval shared_ext=\"$shrext_cmds\"
+       eval library_names=\"$library_names_spec\"
+       set dummy $library_names
+       shift
+       realname="$1"
+       shift
+
+       if test -n "$soname_spec"; then
+         eval soname=\"$soname_spec\"
+       else
+         soname="$realname"
+       fi
+       if test -z "$dlname"; then
+         dlname=$soname
+       fi
+
+       lib="$output_objdir/$realname"
+       linknames=
+       for link
+       do
+         linknames="$linknames $link"
+       done
+
+       # Use standard objects if they are pic
+       test -z "$pic_flag" && libobjs=`$ECHO "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
+       test "X$libobjs" = "X " && libobjs=
+
+       delfiles=
+       if test -n "$export_symbols" && test -n "$include_expsyms"; then
+         $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp"
+         export_symbols="$output_objdir/$libname.uexp"
+         delfiles="$delfiles $export_symbols"
+       fi
+
+       orig_export_symbols=
+       case $host_os in
+       cygwin* | mingw* | cegcc*)
+         if test -n "$export_symbols" && test -z "$export_symbols_regex"; then
+           # exporting using user supplied symfile
+           if test "x`$SED 1q $export_symbols`" != xEXPORTS; then
+             # and it's NOT already a .def file. Must figure out
+             # which of the given symbols are data symbols and tag
+             # them as such. So, trigger use of export_symbols_cmds.
+             # export_symbols gets reassigned inside the "prepare
+             # the list of exported symbols" if statement, so the
+             # include_expsyms logic still works.
+             orig_export_symbols="$export_symbols"
+             export_symbols=
+             always_export_symbols=yes
+           fi
+         fi
+         ;;
+       esac
+
+       # Prepare the list of exported symbols
+       if test -z "$export_symbols"; then
+         if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then
+           func_verbose "generating symbol list for \`$libname.la'"
+           export_symbols="$output_objdir/$libname.exp"
+           $opt_dry_run || $RM $export_symbols
+           cmds=$export_symbols_cmds
+           save_ifs="$IFS"; IFS='~'
+           for cmd in $cmds; do
+             IFS="$save_ifs"
+             eval cmd=\"$cmd\"
+             func_len " $cmd"
+             len=$func_len_result
+             if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
+               func_show_eval "$cmd" 'exit $?'
+               skipped_export=false
+             else
+               # The command line is too long to execute in one step.
+               func_verbose "using reloadable object file for export list..."
+               skipped_export=:
+               # Break out early, otherwise skipped_export may be
+               # set to false by a later but shorter cmd.
+               break
+             fi
+           done
+           IFS="$save_ifs"
+           if test -n "$export_symbols_regex" && test "X$skipped_export" != "X:"; then
+             func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
+             func_show_eval '$MV "${export_symbols}T" "$export_symbols"'
+           fi
+         fi
+       fi
+
+       if test -n "$export_symbols" && test -n "$include_expsyms"; then
+         tmp_export_symbols="$export_symbols"
+         test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
+         $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"'
+       fi
+
+       if test "X$skipped_export" != "X:" && test -n "$orig_export_symbols"; then
+         # The given exports_symbols file has to be filtered, so filter it.
+         func_verbose "filter symbol list for \`$libname.la' to tag DATA exports"
+         # FIXME: $output_objdir/$libname.filter potentially contains lots of
+         # 's' commands which not all seds can handle. GNU sed should be fine
+         # though. Also, the filter scales superlinearly with the number of
+         # global variables. join(1) would be nice here, but unfortunately
+         # isn't a blessed tool.
+         $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter
+         delfiles="$delfiles $export_symbols $output_objdir/$libname.filter"
+         export_symbols=$output_objdir/$libname.def
+         $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
+       fi
+
+       tmp_deplibs=
+       for test_deplib in $deplibs; do
+         case " $convenience " in
+         *" $test_deplib "*) ;;
+         *)
+           tmp_deplibs="$tmp_deplibs $test_deplib"
+           ;;
+         esac
+       done
+       deplibs="$tmp_deplibs"
+
+       if test -n "$convenience"; then
+         if test -n "$whole_archive_flag_spec" &&
+           test "$compiler_needs_object" = yes &&
+           test -z "$libobjs"; then
+           # extract the archives, so we have objects to list.
+           # TODO: could optimize this to just extract one archive.
+           whole_archive_flag_spec=
+         fi
+         if test -n "$whole_archive_flag_spec"; then
+           save_libobjs=$libobjs
+           eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
+           test "X$libobjs" = "X " && libobjs=
+         else
+           gentop="$output_objdir/${outputname}x"
+           generated="$generated $gentop"
+
+           func_extract_archives $gentop $convenience
+           libobjs="$libobjs $func_extract_archives_result"
+           test "X$libobjs" = "X " && libobjs=
+         fi
+       fi
+
+       if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then
+         eval flag=\"$thread_safe_flag_spec\"
+         linker_flags="$linker_flags $flag"
+       fi
+
+       # Make a backup of the uninstalled library when relinking
+       if test "$mode" = relink; then
+         $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $?
+       fi
+
+       # Do each of the archive commands.
+       if test "$module" = yes && test -n "$module_cmds" ; then
+         if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
+           eval test_cmds=\"$module_expsym_cmds\"
+           cmds=$module_expsym_cmds
+         else
+           eval test_cmds=\"$module_cmds\"
+           cmds=$module_cmds
+         fi
+       else
+         if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
+           eval test_cmds=\"$archive_expsym_cmds\"
+           cmds=$archive_expsym_cmds
+         else
+           eval test_cmds=\"$archive_cmds\"
+           cmds=$archive_cmds
+         fi
+       fi
+
+       if test "X$skipped_export" != "X:" &&
+          func_len " $test_cmds" &&
+          len=$func_len_result &&
+          test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
+         :
+       else
+         # The command line is too long to link in one step, link piecewise
+         # or, if using GNU ld and skipped_export is not :, use a linker
+         # script.
+
+         # Save the value of $output and $libobjs because we want to
+         # use them later.  If we have whole_archive_flag_spec, we
+         # want to use save_libobjs as it was before
+         # whole_archive_flag_spec was expanded, because we can't
+         # assume the linker understands whole_archive_flag_spec.
+         # This may have to be revisited, in case too many
+         # convenience libraries get linked in and end up exceeding
+         # the spec.
+         if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then
+           save_libobjs=$libobjs
+         fi
+         save_output=$output
+         output_la=`$ECHO "X$output" | $Xsed -e "$basename"`
+
+         # Clear the reloadable object creation command queue and
+         # initialize k to one.
+         test_cmds=
+         concat_cmds=
+         objlist=
+         last_robj=
+         k=1
+
+         if test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "$with_gnu_ld" = yes; then
+           output=${output_objdir}/${output_la}.lnkscript
+           func_verbose "creating GNU ld script: $output"
+           $ECHO 'INPUT (' > $output
+           for obj in $save_libobjs
+           do
+             $ECHO "$obj" >> $output
+           done
+           $ECHO ')' >> $output
+           delfiles="$delfiles $output"
+         elif test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "X$file_list_spec" != X; then
+           output=${output_objdir}/${output_la}.lnk
+           func_verbose "creating linker input file list: $output"
+           : > $output
+           set x $save_libobjs
+           shift
+           firstobj=
+           if test "$compiler_needs_object" = yes; then
+             firstobj="$1 "
+             shift
+           fi
+           for obj
+           do
+             $ECHO "$obj" >> $output
+           done
+           delfiles="$delfiles $output"
+           output=$firstobj\"$file_list_spec$output\"
+         else
+           if test -n "$save_libobjs"; then
+             func_verbose "creating reloadable object files..."
+             output=$output_objdir/$output_la-${k}.$objext
+             eval test_cmds=\"$reload_cmds\"
+             func_len " $test_cmds"
+             len0=$func_len_result
+             len=$len0
+
+             # Loop over the list of objects to be linked.
+             for obj in $save_libobjs
+             do
+               func_len " $obj"
+               func_arith $len + $func_len_result
+               len=$func_arith_result
+               if test "X$objlist" = X ||
+                  test "$len" -lt "$max_cmd_len"; then
+                 func_append objlist " $obj"
+               else
+                 # The command $test_cmds is almost too long, add a
+                 # command to the queue.
+                 if test "$k" -eq 1 ; then
+                   # The first file doesn't have a previous command to add.
+                   eval concat_cmds=\"$reload_cmds $objlist $last_robj\"
+                 else
+                   # All subsequent reloadable object files will link in
+                   # the last one created.
+                   eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj~\$RM $last_robj\"
+                 fi
+                 last_robj=$output_objdir/$output_la-${k}.$objext
+                 func_arith $k + 1
+                 k=$func_arith_result
+                 output=$output_objdir/$output_la-${k}.$objext
+                 objlist=$obj
+                 func_len " $last_robj"
+                 func_arith $len0 + $func_len_result
+                 len=$func_arith_result
+               fi
+             done
+             # Handle the remaining objects by creating one last
+             # reloadable object file.  All subsequent reloadable object
+             # files will link in the last one created.
+             test -z "$concat_cmds" || concat_cmds=$concat_cmds~
+             eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\"
+             if test -n "$last_robj"; then
+               eval concat_cmds=\"\${concat_cmds}~\$RM $last_robj\"
+             fi
+             delfiles="$delfiles $output"
+
+           else
+             output=
+           fi
+
+           if ${skipped_export-false}; then
+             func_verbose "generating symbol list for \`$libname.la'"
+             export_symbols="$output_objdir/$libname.exp"
+             $opt_dry_run || $RM $export_symbols
+             libobjs=$output
+             # Append the command to create the export file.
+             test -z "$concat_cmds" || concat_cmds=$concat_cmds~
+             eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\"
+             if test -n "$last_robj"; then
+               eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\"
+             fi
+           fi
+
+           test -n "$save_libobjs" &&
+             func_verbose "creating a temporary reloadable object file: $output"
+
+           # Loop through the commands generated above and execute them.
+           save_ifs="$IFS"; IFS='~'
+           for cmd in $concat_cmds; do
+             IFS="$save_ifs"
+             $opt_silent || {
+                 func_quote_for_expand "$cmd"
+                 eval "func_echo $func_quote_for_expand_result"
+             }
+             $opt_dry_run || eval "$cmd" || {
+               lt_exit=$?
+
+               # Restore the uninstalled library and exit
+               if test "$mode" = relink; then
+                 ( cd "$output_objdir" && \
+                   $RM "${realname}T" && \
+                   $MV "${realname}U" "$realname" )
+               fi
+
+               exit $lt_exit
+             }
+           done
+           IFS="$save_ifs"
+
+           if test -n "$export_symbols_regex" && ${skipped_export-false}; then
+             func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
+             func_show_eval '$MV "${export_symbols}T" "$export_symbols"'
+           fi
+         fi
+
+          if ${skipped_export-false}; then
+           if test -n "$export_symbols" && test -n "$include_expsyms"; then
+             tmp_export_symbols="$export_symbols"
+             test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
+             $opt_dry_run || eval '$ECHO "X$include_expsyms" | $Xsed | $SP2NL >> "$tmp_export_symbols"'
+           fi
+
+           if test -n "$orig_export_symbols"; then
+             # The given exports_symbols file has to be filtered, so filter it.
+             func_verbose "filter symbol list for \`$libname.la' to tag DATA exports"
+             # FIXME: $output_objdir/$libname.filter potentially contains lots of
+             # 's' commands which not all seds can handle. GNU sed should be fine
+             # though. Also, the filter scales superlinearly with the number of
+             # global variables. join(1) would be nice here, but unfortunately
+             # isn't a blessed tool.
+             $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter
+             delfiles="$delfiles $export_symbols $output_objdir/$libname.filter"
+             export_symbols=$output_objdir/$libname.def
+             $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
+           fi
+         fi
+
+         libobjs=$output
+         # Restore the value of output.
+         output=$save_output
+
+         if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then
+           eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
+           test "X$libobjs" = "X " && libobjs=
+         fi
+         # Expand the library linking commands again to reset the
+         # value of $libobjs for piecewise linking.
+
+         # Do each of the archive commands.
+         if test "$module" = yes && test -n "$module_cmds" ; then
+           if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
+             cmds=$module_expsym_cmds
+           else
+             cmds=$module_cmds
+           fi
+         else
+           if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
+             cmds=$archive_expsym_cmds
+           else
+             cmds=$archive_cmds
+           fi
+         fi
+       fi
+
+       if test -n "$delfiles"; then
+         # Append the command to remove temporary files to $cmds.
+         eval cmds=\"\$cmds~\$RM $delfiles\"
+       fi
+
+       # Add any objects from preloaded convenience libraries
+       if test -n "$dlprefiles"; then
+         gentop="$output_objdir/${outputname}x"
+         generated="$generated $gentop"
+
+         func_extract_archives $gentop $dlprefiles
+         libobjs="$libobjs $func_extract_archives_result"
+         test "X$libobjs" = "X " && libobjs=
+       fi
+
+       save_ifs="$IFS"; IFS='~'
+       for cmd in $cmds; do
+         IFS="$save_ifs"
+         eval cmd=\"$cmd\"
+         $opt_silent || {
+           func_quote_for_expand "$cmd"
+           eval "func_echo $func_quote_for_expand_result"
+         }
+         $opt_dry_run || eval "$cmd" || {
+           lt_exit=$?
+
+           # Restore the uninstalled library and exit
+           if test "$mode" = relink; then
+             ( cd "$output_objdir" && \
+               $RM "${realname}T" && \
+               $MV "${realname}U" "$realname" )
+           fi
+
+           exit $lt_exit
+         }
+       done
+       IFS="$save_ifs"
+
+       # Restore the uninstalled library and exit
+       if test "$mode" = relink; then
+         $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $?
+
+         if test -n "$convenience"; then
+           if test -z "$whole_archive_flag_spec"; then
+             func_show_eval '${RM}r "$gentop"'
+           fi
+         fi
+
+         exit $EXIT_SUCCESS
+       fi
+
+       # Create links to the real library.
+       for linkname in $linknames; do
+         if test "$realname" != "$linkname"; then
+           func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?'
+         fi
+       done
+
+       # If -module or -export-dynamic was specified, set the dlname.
+       if test "$module" = yes || test "$export_dynamic" = yes; then
+         # On all known operating systems, these are identical.
+         dlname="$soname"
+       fi
+      fi
+      ;;
+
+    obj)
+      if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
+       func_warning "\`-dlopen' is ignored for objects"
+      fi
+
+      case " $deplibs" in
+      *\ -l* | *\ -L*)
+       func_warning "\`-l' and \`-L' are ignored for objects" ;;
+      esac
+
+      test -n "$rpath" && \
+       func_warning "\`-rpath' is ignored for objects"
+
+      test -n "$xrpath" && \
+       func_warning "\`-R' is ignored for objects"
+
+      test -n "$vinfo" && \
+       func_warning "\`-version-info' is ignored for objects"
+
+      test -n "$release" && \
+       func_warning "\`-release' is ignored for objects"
+
+      case $output in
+      *.lo)
+       test -n "$objs$old_deplibs" && \
+         func_fatal_error "cannot build library object \`$output' from non-libtool objects"
+
+       libobj=$output
+       func_lo2o "$libobj"
+       obj=$func_lo2o_result
+       ;;
+      *)
+       libobj=
+       obj="$output"
+       ;;
+      esac
+
+      # Delete the old objects.
+      $opt_dry_run || $RM $obj $libobj
+
+      # Objects from convenience libraries.  This assumes
+      # single-version convenience libraries.  Whenever we create
+      # different ones for PIC/non-PIC, this we'll have to duplicate
+      # the extraction.
+      reload_conv_objs=
+      gentop=
+      # reload_cmds runs $LD directly, so let us get rid of
+      # -Wl from whole_archive_flag_spec and hope we can get by with
+      # turning comma into space..
+      wl=
+
+      if test -n "$convenience"; then
+       if test -n "$whole_archive_flag_spec"; then
+         eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\"
+         reload_conv_objs=$reload_objs\ `$ECHO "X$tmp_whole_archive_flags" | $Xsed -e 's|,| |g'`
+       else
+         gentop="$output_objdir/${obj}x"
+         generated="$generated $gentop"
+
+         func_extract_archives $gentop $convenience
+         reload_conv_objs="$reload_objs $func_extract_archives_result"
+       fi
+      fi
+
+      # Create the old-style object.
+      reload_objs="$objs$old_deplibs "`$ECHO "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test
+
+      output="$obj"
+      func_execute_cmds "$reload_cmds" 'exit $?'
+
+      # Exit if we aren't doing a library object file.
+      if test -z "$libobj"; then
+       if test -n "$gentop"; then
+         func_show_eval '${RM}r "$gentop"'
+       fi
+
+       exit $EXIT_SUCCESS
+      fi
+
+      if test "$build_libtool_libs" != yes; then
+       if test -n "$gentop"; then
+         func_show_eval '${RM}r "$gentop"'
+       fi
+
+       # Create an invalid libtool object if no PIC, so that we don't
+       # accidentally link it into a program.
+       # $show "echo timestamp > $libobj"
+       # $opt_dry_run || eval "echo timestamp > $libobj" || exit $?
+       exit $EXIT_SUCCESS
+      fi
+
+      if test -n "$pic_flag" || test "$pic_mode" != default; then
+       # Only do commands if we really have different PIC objects.
+       reload_objs="$libobjs $reload_conv_objs"
+       output="$libobj"
+       func_execute_cmds "$reload_cmds" 'exit $?'
+      fi
+
+      if test -n "$gentop"; then
+       func_show_eval '${RM}r "$gentop"'
+      fi
+
+      exit $EXIT_SUCCESS
+      ;;
+
+    prog)
+      case $host in
+       *cygwin*) func_stripname '' '.exe' "$output"
+                 output=$func_stripname_result.exe;;
+      esac
+      test -n "$vinfo" && \
+       func_warning "\`-version-info' is ignored for programs"
+
+      test -n "$release" && \
+       func_warning "\`-release' is ignored for programs"
+
+      test "$preload" = yes \
+        && test "$dlopen_support" = unknown \
+       && test "$dlopen_self" = unknown \
+       && test "$dlopen_self_static" = unknown && \
+         func_warning "\`LT_INIT([dlopen])' not used. Assuming no dlopen support."
+
+      case $host in
+      *-*-rhapsody* | *-*-darwin1.[012])
+       # On Rhapsody replace the C library is the System framework
+       compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'`
+       finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's/ -lc / System.ltframework /'`
+       ;;
+      esac
+
+      case $host in
+      *-*-darwin*)
+       # Don't allow lazy linking, it breaks C++ global constructors
+       # But is supposedly fixed on 10.4 or later (yay!).
+       if test "$tagname" = CXX ; then
+         case ${MACOSX_DEPLOYMENT_TARGET-10.0} in
+           10.[0123])
+             compile_command="$compile_command ${wl}-bind_at_load"
+             finalize_command="$finalize_command ${wl}-bind_at_load"
+           ;;
+         esac
+       fi
+       # Time to change all our "foo.ltframework" stuff back to "-framework foo"
+       compile_deplibs=`$ECHO "X $compile_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
+       finalize_deplibs=`$ECHO "X $finalize_deplibs" | $Xsed -e 's% \([^ $]*\).ltframework% -framework \1%g'`
+       ;;
+      esac
+
+
+      # move library search paths that coincide with paths to not yet
+      # installed libraries to the beginning of the library search list
+      new_libs=
+      for path in $notinst_path; do
+       case " $new_libs " in
+       *" -L$path/$objdir "*) ;;
+       *)
+         case " $compile_deplibs " in
+         *" -L$path/$objdir "*)
+           new_libs="$new_libs -L$path/$objdir" ;;
+         esac
+         ;;
+       esac
+      done
+      for deplib in $compile_deplibs; do
+       case $deplib in
+       -L*)
+         case " $new_libs " in
+         *" $deplib "*) ;;
+         *) new_libs="$new_libs $deplib" ;;
+         esac
+         ;;
+       *) new_libs="$new_libs $deplib" ;;
+       esac
+      done
+      compile_deplibs="$new_libs"
+
+
+      compile_command="$compile_command $compile_deplibs"
+      finalize_command="$finalize_command $finalize_deplibs"
+
+      if test -n "$rpath$xrpath"; then
+       # If the user specified any rpath flags, then add them.
+       for libdir in $rpath $xrpath; do
+         # This is the magic to use -rpath.
+         case "$finalize_rpath " in
+         *" $libdir "*) ;;
+         *) finalize_rpath="$finalize_rpath $libdir" ;;
+         esac
+       done
+      fi
+
+      # Now hardcode the library paths
+      rpath=
+      hardcode_libdirs=
+      for libdir in $compile_rpath $finalize_rpath; do
+       if test -n "$hardcode_libdir_flag_spec"; then
+         if test -n "$hardcode_libdir_separator"; then
+           if test -z "$hardcode_libdirs"; then
+             hardcode_libdirs="$libdir"
+           else
+             # Just accumulate the unique libdirs.
+             case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
+             *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
+               ;;
+             *)
+               hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
+               ;;
+             esac
+           fi
+         else
+           eval flag=\"$hardcode_libdir_flag_spec\"
+           rpath="$rpath $flag"
+         fi
+       elif test -n "$runpath_var"; then
+         case "$perm_rpath " in
+         *" $libdir "*) ;;
+         *) perm_rpath="$perm_rpath $libdir" ;;
+         esac
+       fi
+       case $host in
+       *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
+         testbindir=`${ECHO} "$libdir" | ${SED} -e 's*/lib$*/bin*'`
+         case :$dllsearchpath: in
+         *":$libdir:"*) ;;
+         ::) dllsearchpath=$libdir;;
+         *) dllsearchpath="$dllsearchpath:$libdir";;
+         esac
+         case :$dllsearchpath: in
+         *":$testbindir:"*) ;;
+         ::) dllsearchpath=$testbindir;;
+         *) dllsearchpath="$dllsearchpath:$testbindir";;
+         esac
+         ;;
+       esac
+      done
+      # Substitute the hardcoded libdirs into the rpath.
+      if test -n "$hardcode_libdir_separator" &&
+        test -n "$hardcode_libdirs"; then
+       libdir="$hardcode_libdirs"
+       eval rpath=\" $hardcode_libdir_flag_spec\"
+      fi
+      compile_rpath="$rpath"
+
+      rpath=
+      hardcode_libdirs=
+      for libdir in $finalize_rpath; do
+       if test -n "$hardcode_libdir_flag_spec"; then
+         if test -n "$hardcode_libdir_separator"; then
+           if test -z "$hardcode_libdirs"; then
+             hardcode_libdirs="$libdir"
+           else
+             # Just accumulate the unique libdirs.
+             case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
+             *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
+               ;;
+             *)
+               hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
+               ;;
+             esac
+           fi
+         else
+           eval flag=\"$hardcode_libdir_flag_spec\"
+           rpath="$rpath $flag"
+         fi
+       elif test -n "$runpath_var"; then
+         case "$finalize_perm_rpath " in
+         *" $libdir "*) ;;
+         *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;;
+         esac
+       fi
+      done
+      # Substitute the hardcoded libdirs into the rpath.
+      if test -n "$hardcode_libdir_separator" &&
+        test -n "$hardcode_libdirs"; then
+       libdir="$hardcode_libdirs"
+       eval rpath=\" $hardcode_libdir_flag_spec\"
+      fi
+      finalize_rpath="$rpath"
+
+      if test -n "$libobjs" && test "$build_old_libs" = yes; then
+       # Transform all the library objects into standard objects.
+       compile_command=`$ECHO "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
+       finalize_command=`$ECHO "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
+      fi
+
+      func_generate_dlsyms "$outputname" "@PROGRAM@" "no"
+
+      # template prelinking step
+      if test -n "$prelink_cmds"; then
+       func_execute_cmds "$prelink_cmds" 'exit $?'
+      fi
+
+      wrappers_required=yes
+      case $host in
+      *cygwin* | *mingw* )
+        if test "$build_libtool_libs" != yes; then
+          wrappers_required=no
+        fi
+        ;;
+      *cegcc)
+        # Disable wrappers for cegcc, we are cross compiling anyway.
+        wrappers_required=no
+        ;;
+      *)
+        if test "$need_relink" = no || test "$build_libtool_libs" != yes; then
+          wrappers_required=no
+        fi
+        ;;
+      esac
+      if test "$wrappers_required" = no; then
+       # Replace the output file specification.
+       compile_command=`$ECHO "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
+       link_command="$compile_command$compile_rpath"
+
+       # We have no uninstalled library dependencies, so finalize right now.
+       exit_status=0
+       func_show_eval "$link_command" 'exit_status=$?'
+
+       # Delete the generated files.
+       if test -f "$output_objdir/${outputname}S.${objext}"; then
+         func_show_eval '$RM "$output_objdir/${outputname}S.${objext}"'
+       fi
+
+       exit $exit_status
+      fi
+
+      if test -n "$compile_shlibpath$finalize_shlibpath"; then
+       compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command"
+      fi
+      if test -n "$finalize_shlibpath"; then
+       finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command"
+      fi
+
+      compile_var=
+      finalize_var=
+      if test -n "$runpath_var"; then
+       if test -n "$perm_rpath"; then
+         # We should set the runpath_var.
+         rpath=
+         for dir in $perm_rpath; do
+           rpath="$rpath$dir:"
+         done
+         compile_var="$runpath_var=\"$rpath\$$runpath_var\" "
+       fi
+       if test -n "$finalize_perm_rpath"; then
+         # We should set the runpath_var.
+         rpath=
+         for dir in $finalize_perm_rpath; do
+           rpath="$rpath$dir:"
+         done
+         finalize_var="$runpath_var=\"$rpath\$$runpath_var\" "
+       fi
+      fi
+
+      if test "$no_install" = yes; then
+       # We don't need to create a wrapper script.
+       link_command="$compile_var$compile_command$compile_rpath"
+       # Replace the output file specification.
+       link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
+       # Delete the old output file.
+       $opt_dry_run || $RM $output
+       # Link the executable and exit
+       func_show_eval "$link_command" 'exit $?'
+       exit $EXIT_SUCCESS
+      fi
+
+      if test "$hardcode_action" = relink; then
+       # Fast installation is not supported
+       link_command="$compile_var$compile_command$compile_rpath"
+       relink_command="$finalize_var$finalize_command$finalize_rpath"
+
+       func_warning "this platform does not like uninstalled shared libraries"
+       func_warning "\`$output' will be relinked during installation"
+      else
+       if test "$fast_install" != no; then
+         link_command="$finalize_var$compile_command$finalize_rpath"
+         if test "$fast_install" = yes; then
+           relink_command=`$ECHO "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'`
+         else
+           # fast_install is set to needless
+           relink_command=
+         fi
+       else
+         link_command="$compile_var$compile_command$compile_rpath"
+         relink_command="$finalize_var$finalize_command$finalize_rpath"
+       fi
+      fi
+
+      # Replace the output file specification.
+      link_command=`$ECHO "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
+
+      # Delete the old output files.
+      $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname
+
+      func_show_eval "$link_command" 'exit $?'
+
+      # Now create the wrapper script.
+      func_verbose "creating $output"
+
+      # Quote the relink command for shipping.
+      if test -n "$relink_command"; then
+       # Preserve any variables that may affect compiler behavior
+       for var in $variables_saved_for_relink; do
+         if eval test -z \"\${$var+set}\"; then
+           relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command"
+         elif eval var_value=\$$var; test -z "$var_value"; then
+           relink_command="$var=; export $var; $relink_command"
+         else
+           func_quote_for_eval "$var_value"
+           relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command"
+         fi
+       done
+       relink_command="(cd `pwd`; $relink_command)"
+       relink_command=`$ECHO "X$relink_command" | $Xsed -e "$sed_quote_subst"`
+      fi
+
+      # Quote $ECHO for shipping.
+      if test "X$ECHO" = "X$SHELL $progpath --fallback-echo"; then
+       case $progpath in
+       [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";;
+       *) qecho="$SHELL `pwd`/$progpath --fallback-echo";;
+       esac
+       qecho=`$ECHO "X$qecho" | $Xsed -e "$sed_quote_subst"`
+      else
+       qecho=`$ECHO "X$ECHO" | $Xsed -e "$sed_quote_subst"`
+      fi
+
+      # Only actually do things if not in dry run mode.
+      $opt_dry_run || {
+       # win32 will think the script is a binary if it has
+       # a .exe suffix, so we strip it off here.
+       case $output in
+         *.exe) func_stripname '' '.exe' "$output"
+                output=$func_stripname_result ;;
+       esac
+       # test for cygwin because mv fails w/o .exe extensions
+       case $host in
+         *cygwin*)
+           exeext=.exe
+           func_stripname '' '.exe' "$outputname"
+           outputname=$func_stripname_result ;;
+         *) exeext= ;;
+       esac
+       case $host in
+         *cygwin* | *mingw* )
+           func_dirname_and_basename "$output" "" "."
+           output_name=$func_basename_result
+           output_path=$func_dirname_result
+           cwrappersource="$output_path/$objdir/lt-$output_name.c"
+           cwrapper="$output_path/$output_name.exe"
+           $RM $cwrappersource $cwrapper
+           trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15
+
+           func_emit_cwrapperexe_src > $cwrappersource
+
+           # The wrapper executable is built using the $host compiler,
+           # because it contains $host paths and files. If cross-
+           # compiling, it, like the target executable, must be
+           # executed on the $host or under an emulation environment.
+           $opt_dry_run || {
+             $LTCC $LTCFLAGS -o $cwrapper $cwrappersource
+             $STRIP $cwrapper
+           }
+
+           # Now, create the wrapper script for func_source use:
+           func_ltwrapper_scriptname $cwrapper
+           $RM $func_ltwrapper_scriptname_result
+           trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15
+           $opt_dry_run || {
+             # note: this script will not be executed, so do not chmod.
+             if test "x$build" = "x$host" ; then
+               $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result
+             else
+               func_emit_wrapper no > $func_ltwrapper_scriptname_result
+             fi
+           }
+         ;;
+         * )
+           $RM $output
+           trap "$RM $output; exit $EXIT_FAILURE" 1 2 15
+
+           func_emit_wrapper no > $output
+           chmod +x $output
+         ;;
+       esac
+      }
+      exit $EXIT_SUCCESS
+      ;;
+    esac
+
+    # See if we need to build an old-fashioned archive.
+    for oldlib in $oldlibs; do
+
+      if test "$build_libtool_libs" = convenience; then
+       oldobjs="$libobjs_save $symfileobj"
+       addlibs="$convenience"
+       build_libtool_libs=no
+      else
+       if test "$build_libtool_libs" = module; then
+         oldobjs="$libobjs_save"
+         build_libtool_libs=no
+       else
+         oldobjs="$old_deplibs $non_pic_objects"
+         if test "$preload" = yes && test -f "$symfileobj"; then
+           oldobjs="$oldobjs $symfileobj"
+         fi
+       fi
+       addlibs="$old_convenience"
+      fi
+
+      if test -n "$addlibs"; then
+       gentop="$output_objdir/${outputname}x"
+       generated="$generated $gentop"
+
+       func_extract_archives $gentop $addlibs
+       oldobjs="$oldobjs $func_extract_archives_result"
+      fi
+
+      # Do each command in the archive commands.
+      if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then
+       cmds=$old_archive_from_new_cmds
+      else
+
+       # Add any objects from preloaded convenience libraries
+       if test -n "$dlprefiles"; then
+         gentop="$output_objdir/${outputname}x"
+         generated="$generated $gentop"
+
+         func_extract_archives $gentop $dlprefiles
+         oldobjs="$oldobjs $func_extract_archives_result"
+       fi
+
+       # POSIX demands no paths to be encoded in archives.  We have
+       # to avoid creating archives with duplicate basenames if we
+       # might have to extract them afterwards, e.g., when creating a
+       # static archive out of a convenience library, or when linking
+       # the entirety of a libtool archive into another (currently
+       # not supported by libtool).
+       if (for obj in $oldobjs
+           do
+             func_basename "$obj"
+             $ECHO "$func_basename_result"
+           done | sort | sort -uc >/dev/null 2>&1); then
+         :
+       else
+         $ECHO "copying selected object files to avoid basename conflicts..."
+         gentop="$output_objdir/${outputname}x"
+         generated="$generated $gentop"
+         func_mkdir_p "$gentop"
+         save_oldobjs=$oldobjs
+         oldobjs=
+         counter=1
+         for obj in $save_oldobjs
+         do
+           func_basename "$obj"
+           objbase="$func_basename_result"
+           case " $oldobjs " in
+           " ") oldobjs=$obj ;;
+           *[\ /]"$objbase "*)
+             while :; do
+               # Make sure we don't pick an alternate name that also
+               # overlaps.
+               newobj=lt$counter-$objbase
+               func_arith $counter + 1
+               counter=$func_arith_result
+               case " $oldobjs " in
+               *[\ /]"$newobj "*) ;;
+               *) if test ! -f "$gentop/$newobj"; then break; fi ;;
+               esac
+             done
+             func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj"
+             oldobjs="$oldobjs $gentop/$newobj"
+             ;;
+           *) oldobjs="$oldobjs $obj" ;;
+           esac
+         done
+       fi
+       eval cmds=\"$old_archive_cmds\"
+
+       func_len " $cmds"
+       len=$func_len_result
+       if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
+         cmds=$old_archive_cmds
+       else
+         # the command line is too long to link in one step, link in parts
+         func_verbose "using piecewise archive linking..."
+         save_RANLIB=$RANLIB
+         RANLIB=:
+         objlist=
+         concat_cmds=
+         save_oldobjs=$oldobjs
+         oldobjs=
+         # Is there a better way of finding the last object in the list?
+         for obj in $save_oldobjs
+         do
+           last_oldobj=$obj
+         done
+         eval test_cmds=\"$old_archive_cmds\"
+         func_len " $test_cmds"
+         len0=$func_len_result
+         len=$len0
+         for obj in $save_oldobjs
+         do
+           func_len " $obj"
+           func_arith $len + $func_len_result
+           len=$func_arith_result
+           func_append objlist " $obj"
+           if test "$len" -lt "$max_cmd_len"; then
+             :
+           else
+             # the above command should be used before it gets too long
+             oldobjs=$objlist
+             if test "$obj" = "$last_oldobj" ; then
+               RANLIB=$save_RANLIB
+             fi
+             test -z "$concat_cmds" || concat_cmds=$concat_cmds~
+             eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\"
+             objlist=
+             len=$len0
+           fi
+         done
+         RANLIB=$save_RANLIB
+         oldobjs=$objlist
+         if test "X$oldobjs" = "X" ; then
+           eval cmds=\"\$concat_cmds\"
+         else
+           eval cmds=\"\$concat_cmds~\$old_archive_cmds\"
+         fi
+       fi
+      fi
+      func_execute_cmds "$cmds" 'exit $?'
+    done
+
+    test -n "$generated" && \
+      func_show_eval "${RM}r$generated"
+
+    # Now create the libtool archive.
+    case $output in
+    *.la)
+      old_library=
+      test "$build_old_libs" = yes && old_library="$libname.$libext"
+      func_verbose "creating $output"
+
+      # Preserve any variables that may affect compiler behavior
+      for var in $variables_saved_for_relink; do
+       if eval test -z \"\${$var+set}\"; then
+         relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command"
+       elif eval var_value=\$$var; test -z "$var_value"; then
+         relink_command="$var=; export $var; $relink_command"
+       else
+         func_quote_for_eval "$var_value"
+         relink_command="$var=$func_quote_for_eval_result; export $var; $relink_command"
+       fi
+      done
+      # Quote the link command for shipping.
+      relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
+      relink_command=`$ECHO "X$relink_command" | $Xsed -e "$sed_quote_subst"`
+      if test "$hardcode_automatic" = yes ; then
+       relink_command=
+      fi
+
+      # Only create the output if not a dry run.
+      $opt_dry_run || {
+       for installed in no yes; do
+         if test "$installed" = yes; then
+           if test -z "$install_libdir"; then
+             break
+           fi
+           output="$output_objdir/$outputname"i
+           # Replace all uninstalled libtool libraries with the installed ones
+           newdependency_libs=
+           for deplib in $dependency_libs; do
+             case $deplib in
+             *.la)
+               func_basename "$deplib"
+               name="$func_basename_result"
+               eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
+               test -z "$libdir" && \
+                 func_fatal_error "\`$deplib' is not a valid libtool archive"
+               newdependency_libs="$newdependency_libs $libdir/$name"
+               ;;
+             *) newdependency_libs="$newdependency_libs $deplib" ;;
+             esac
+           done
+           dependency_libs="$newdependency_libs"
+           newdlfiles=
+
+           for lib in $dlfiles; do
+             case $lib in
+             *.la)
+               func_basename "$lib"
+               name="$func_basename_result"
+               eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
+               test -z "$libdir" && \
+                 func_fatal_error "\`$lib' is not a valid libtool archive"
+               newdlfiles="$newdlfiles $libdir/$name"
+               ;;
+             *) newdlfiles="$newdlfiles $lib" ;;
+             esac
+           done
+           dlfiles="$newdlfiles"
+           newdlprefiles=
+           for lib in $dlprefiles; do
+             case $lib in
+             *.la)
+               # Only pass preopened files to the pseudo-archive (for
+               # eventual linking with the app. that links it) if we
+               # didn't already link the preopened objects directly into
+               # the library:
+               func_basename "$lib"
+               name="$func_basename_result"
+               eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
+               test -z "$libdir" && \
+                 func_fatal_error "\`$lib' is not a valid libtool archive"
+               newdlprefiles="$newdlprefiles $libdir/$name"
+               ;;
+             esac
+           done
+           dlprefiles="$newdlprefiles"
+         else
+           newdlfiles=
+           for lib in $dlfiles; do
+             case $lib in
+               [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
+               *) abs=`pwd`"/$lib" ;;
+             esac
+             newdlfiles="$newdlfiles $abs"
+           done
+           dlfiles="$newdlfiles"
+           newdlprefiles=
+           for lib in $dlprefiles; do
+             case $lib in
+               [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
+               *) abs=`pwd`"/$lib" ;;
+             esac
+             newdlprefiles="$newdlprefiles $abs"
+           done
+           dlprefiles="$newdlprefiles"
+         fi
+         $RM $output
+         # place dlname in correct position for cygwin
+         tdlname=$dlname
+         case $host,$output,$installed,$module,$dlname in
+           *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;;
+         esac
+         $ECHO > $output "\
+# $outputname - a libtool library file
+# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+#
+# Please DO NOT delete this file!
+# It is necessary for linking the library.
+
+# The name that we can dlopen(3).
+dlname='$tdlname'
+
+# Names of this library.
+library_names='$library_names'
+
+# The name of the static archive.
+old_library='$old_library'
+
+# Linker flags that can not go in dependency_libs.
+inherited_linker_flags='$new_inherited_linker_flags'
+
+# Libraries that this one depends upon.
+dependency_libs='$dependency_libs'
+
+# Names of additional weak libraries provided by this library
+weak_library_names='$weak_libs'
+
+# Version information for $libname.
+current=$current
+age=$age
+revision=$revision
+
+# Is this an already installed library?
+installed=$installed
+
+# Should we warn about portability when linking against -modules?
+shouldnotlink=$module
+
+# Files to dlopen/dlpreopen
+dlopen='$dlfiles'
+dlpreopen='$dlprefiles'
+
+# Directory that this library needs to be installed in:
+libdir='$install_libdir'"
+         if test "$installed" = no && test "$need_relink" = yes; then
+           $ECHO >> $output "\
+relink_command=\"$relink_command\""
+         fi
+       done
+      }
+
+      # Do a symbolic link so that the libtool archive can be found in
+      # LD_LIBRARY_PATH before the program is installed.
+      func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?'
+      ;;
+    esac
+    exit $EXIT_SUCCESS
+}
+
+{ test "$mode" = link || test "$mode" = relink; } &&
+    func_mode_link ${1+"$@"}
+
+
+# func_mode_uninstall arg...
+func_mode_uninstall ()
+{
+    $opt_debug
+    RM="$nonopt"
+    files=
+    rmforce=
+    exit_status=0
+
+    # This variable tells wrapper scripts just to set variables rather
+    # than running their programs.
+    libtool_install_magic="$magic"
+
+    for arg
+    do
+      case $arg in
+      -f) RM="$RM $arg"; rmforce=yes ;;
+      -*) RM="$RM $arg" ;;
+      *) files="$files $arg" ;;
+      esac
+    done
+
+    test -z "$RM" && \
+      func_fatal_help "you must specify an RM program"
+
+    rmdirs=
+
+    origobjdir="$objdir"
+    for file in $files; do
+      func_dirname "$file" "" "."
+      dir="$func_dirname_result"
+      if test "X$dir" = X.; then
+       objdir="$origobjdir"
+      else
+       objdir="$dir/$origobjdir"
+      fi
+      func_basename "$file"
+      name="$func_basename_result"
+      test "$mode" = uninstall && objdir="$dir"
+
+      # Remember objdir for removal later, being careful to avoid duplicates
+      if test "$mode" = clean; then
+       case " $rmdirs " in
+         *" $objdir "*) ;;
+         *) rmdirs="$rmdirs $objdir" ;;
+       esac
+      fi
+
+      # Don't error if the file doesn't exist and rm -f was used.
+      if { test -L "$file"; } >/dev/null 2>&1 ||
+        { test -h "$file"; } >/dev/null 2>&1 ||
+        test -f "$file"; then
+       :
+      elif test -d "$file"; then
+       exit_status=1
+       continue
+      elif test "$rmforce" = yes; then
+       continue
+      fi
+
+      rmfiles="$file"
+
+      case $name in
+      *.la)
+       # Possibly a libtool archive, so verify it.
+       if func_lalib_p "$file"; then
+         func_source $dir/$name
+
+         # Delete the libtool libraries and symlinks.
+         for n in $library_names; do
+           rmfiles="$rmfiles $objdir/$n"
+         done
+         test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library"
+
+         case "$mode" in
+         clean)
+           case "  $library_names " in
+           # "  " in the beginning catches empty $dlname
+           *" $dlname "*) ;;
+           *) rmfiles="$rmfiles $objdir/$dlname" ;;
+           esac
+           test -n "$libdir" && rmfiles="$rmfiles $objdir/$name $objdir/${name}i"
+           ;;
+         uninstall)
+           if test -n "$library_names"; then
+             # Do each command in the postuninstall commands.
+             func_execute_cmds "$postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1'
+           fi
+
+           if test -n "$old_library"; then
+             # Do each command in the old_postuninstall commands.
+             func_execute_cmds "$old_postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1'
+           fi
+           # FIXME: should reinstall the best remaining shared library.
+           ;;
+         esac
+       fi
+       ;;
+
+      *.lo)
+       # Possibly a libtool object, so verify it.
+       if func_lalib_p "$file"; then
+
+         # Read the .lo file
+         func_source $dir/$name
+
+         # Add PIC object to the list of files to remove.
+         if test -n "$pic_object" &&
+            test "$pic_object" != none; then
+           rmfiles="$rmfiles $dir/$pic_object"
+         fi
+
+         # Add non-PIC object to the list of files to remove.
+         if test -n "$non_pic_object" &&
+            test "$non_pic_object" != none; then
+           rmfiles="$rmfiles $dir/$non_pic_object"
+         fi
+       fi
+       ;;
+
+      *)
+       if test "$mode" = clean ; then
+         noexename=$name
+         case $file in
+         *.exe)
+           func_stripname '' '.exe' "$file"
+           file=$func_stripname_result
+           func_stripname '' '.exe' "$name"
+           noexename=$func_stripname_result
+           # $file with .exe has already been added to rmfiles,
+           # add $file without .exe
+           rmfiles="$rmfiles $file"
+           ;;
+         esac
+         # Do a test to see if this is a libtool program.
+         if func_ltwrapper_p "$file"; then
+           if func_ltwrapper_executable_p "$file"; then
+             func_ltwrapper_scriptname "$file"
+             relink_command=
+             func_source $func_ltwrapper_scriptname_result
+             rmfiles="$rmfiles $func_ltwrapper_scriptname_result"
+           else
+             relink_command=
+             func_source $dir/$noexename
+           fi
+
+           # note $name still contains .exe if it was in $file originally
+           # as does the version of $file that was added into $rmfiles
+           rmfiles="$rmfiles $objdir/$name $objdir/${name}S.${objext}"
+           if test "$fast_install" = yes && test -n "$relink_command"; then
+             rmfiles="$rmfiles $objdir/lt-$name"
+           fi
+           if test "X$noexename" != "X$name" ; then
+             rmfiles="$rmfiles $objdir/lt-${noexename}.c"
+           fi
+         fi
+       fi
+       ;;
+      esac
+      func_show_eval "$RM $rmfiles" 'exit_status=1'
+    done
+    objdir="$origobjdir"
+
+    # Try to remove the ${objdir}s in the directories where we deleted files
+    for dir in $rmdirs; do
+      if test -d "$dir"; then
+       func_show_eval "rmdir $dir >/dev/null 2>&1"
+      fi
+    done
+
+    exit $exit_status
+}
+
+{ test "$mode" = uninstall || test "$mode" = clean; } &&
+    func_mode_uninstall ${1+"$@"}
+
+test -z "$mode" && {
+  help="$generic_help"
+  func_fatal_help "you must specify a MODE"
+}
+
+test -z "$exec_cmd" && \
+  func_fatal_help "invalid operation mode \`$mode'"
+
+if test -n "$exec_cmd"; then
+  eval exec "$exec_cmd"
+  exit $EXIT_FAILURE
+fi
+
+exit $exit_status
+
+
+# The TAGs below are defined such that we never get into a situation
+# in which we disable both kinds of libraries.  Given conflicting
+# choices, we go for a static library, that is the most portable,
+# since we can't tell whether shared libraries were disabled because
+# the user asked for that or because the platform doesn't support
+# them.  This is particularly important on AIX, because we don't
+# support having both static and shared libraries enabled at the same
+# time on that platform, so we default to a shared-only configuration.
+# If a disable-shared tag is given, we'll fallback to a static-only
+# configuration.  But we'll never go from static-only to shared-only.
+
+# ### BEGIN LIBTOOL TAG CONFIG: disable-shared
+build_libtool_libs=no
+build_old_libs=yes
+# ### END LIBTOOL TAG CONFIG: disable-shared
+
+# ### BEGIN LIBTOOL TAG CONFIG: disable-static
+build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac`
+# ### END LIBTOOL TAG CONFIG: disable-static
+
+# Local Variables:
+# mode:shell-script
+# sh-indentation:2
+# End:
+# vi:sw=2
+
diff --git a/m4/Makefile.am b/m4/Makefile.am
new file mode 100644 (file)
index 0000000..51d571f
--- /dev/null
@@ -0,0 +1,6 @@
+EXTRA_DIST = \
+       as-ac-expand.m4 \
+       ogg.m4 \
+       pkg.m4 \
+       sdl.m4 \
+       vorbis.m4
diff --git a/m4/Makefile.in b/m4/Makefile.in
new file mode 100644 (file)
index 0000000..6fcec23
--- /dev/null
@@ -0,0 +1,298 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+EXTRA_DIST = \
+       as-ac-expand.m4 \
+       ogg.m4 \
+       pkg.m4 \
+       sdl.m4 \
+       vorbis.m4
+
+subdir = m4
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES =
+DIST_SOURCES =
+DIST_COMMON = Makefile.am Makefile.in
+all: all-am
+
+.SUFFIXES:
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  m4/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+tags: TAGS
+TAGS:
+
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+check-am: all-am
+check: check-am
+all-am: Makefile
+
+installdirs:
+
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-am
+
+distclean-am: clean-am distclean-generic distclean-libtool
+
+dvi: dvi-am
+
+dvi-am:
+
+info: info-am
+
+info-am:
+
+install-data-am:
+
+install-exec-am:
+
+install-info: install-info-am
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+uninstall-am: uninstall-info-am
+
+.PHONY: all all-am check check-am clean clean-generic clean-libtool \
+       distclean distclean-generic distclean-libtool distdir dvi \
+       dvi-am info info-am install install-am install-data \
+       install-data-am install-exec install-exec-am install-info \
+       install-info-am install-man install-strip installcheck \
+       installcheck-am installdirs maintainer-clean \
+       maintainer-clean-generic mostlyclean mostlyclean-generic \
+       mostlyclean-libtool uninstall uninstall-am uninstall-info-am
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/m4/as-ac-expand.m4 b/m4/as-ac-expand.m4
new file mode 100644 (file)
index 0000000..d6c9e33
--- /dev/null
@@ -0,0 +1,43 @@
+dnl as-ac-expand.m4 0.2.0
+dnl autostars m4 macro for expanding directories using configure's prefix
+dnl thomas@apestaart.org
+
+dnl AS_AC_EXPAND(VAR, CONFIGURE_VAR)
+dnl example
+dnl AS_AC_EXPAND(SYSCONFDIR, $sysconfdir)
+dnl will set SYSCONFDIR to /usr/local/etc if prefix=/usr/local
+
+AC_DEFUN([AS_AC_EXPAND],
+[
+  EXP_VAR=[$1]
+  FROM_VAR=[$2]
+
+  dnl first expand prefix and exec_prefix if necessary
+  prefix_save=$prefix
+  exec_prefix_save=$exec_prefix
+
+  dnl if no prefix given, then use /usr/local, the default prefix
+  if test "x$prefix" = "xNONE"; then
+    prefix="$ac_default_prefix"
+  fi
+  dnl if no exec_prefix given, then use prefix
+  if test "x$exec_prefix" = "xNONE"; then
+    exec_prefix=$prefix
+  fi
+
+  full_var="$FROM_VAR"
+  dnl loop until it doesn't change anymore
+  while true; do
+    new_full_var="`eval echo $full_var`"
+    if test "x$new_full_var" = "x$full_var"; then break; fi
+    full_var=$new_full_var
+  done
+
+  dnl clean up
+  full_var=$new_full_var
+  AC_SUBST([$1], "$full_var")
+
+  dnl restore prefix and exec_prefix
+  prefix=$prefix_save
+  exec_prefix=$exec_prefix_save
+])
diff --git a/m4/ogg.m4 b/m4/ogg.m4
new file mode 100644 (file)
index 0000000..db91a6d
--- /dev/null
+++ b/m4/ogg.m4
@@ -0,0 +1,116 @@
+# Configure paths for libogg
+# Jack Moffitt <jack@icecast.org> 10-21-2000
+# Shamelessly stolen from Owen Taylor and Manish Singh
+
+dnl XIPH_PATH_OGG([ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]])
+dnl Test for libogg, and define OGG_CFLAGS and OGG_LIBS
+dnl
+AC_DEFUN([XIPH_PATH_OGG],
+[dnl 
+dnl Get the cflags and libraries
+dnl
+AC_ARG_WITH(ogg,AC_HELP_STRING([--with-ogg=PFX],[Prefix where libogg is installed (optional)]), ogg_prefix="$withval", ogg_prefix="")
+AC_ARG_WITH(ogg-libraries,AC_HELP_STRING([--with-ogg-libraries=DIR],[Directory where libogg library is installed (optional)]), ogg_libraries="$withval", ogg_libraries="")
+AC_ARG_WITH(ogg-includes,AC_HELP_STRING([--with-ogg-includes=DIR],[Directory where libogg header files are installed (optional)]), ogg_includes="$withval", ogg_includes="")
+AC_ARG_ENABLE(oggtest,AC_HELP_STRING([--disable-oggtest],[Do not try to compile and run a test Ogg program]),, enable_oggtest=yes)
+
+  if test "x$ogg_libraries" != "x" ; then
+    OGG_LIBS="-L$ogg_libraries"
+  elif test "x$ogg_prefix" = "xno" || test "x$ogg_prefix" = "xyes" ; then
+    OGG_LIBS=""
+  elif test "x$ogg_prefix" != "x" ; then
+    OGG_LIBS="-L$ogg_prefix/lib"
+  elif test "x$prefix" != "xNONE" ; then
+    OGG_LIBS="-L$libdir"
+  fi
+
+  if test "x$ogg_prefix" != "xno" ; then
+    OGG_LIBS="$OGG_LIBS -logg"
+  fi
+
+  if test "x$ogg_includes" != "x" ; then
+    OGG_CFLAGS="-I$ogg_includes"
+  elif test "x$ogg_prefix" = "xno" || test "x$ogg_prefix" = "xyes" ; then
+    OGG_CFLAGS=""
+  elif test "x$ogg_prefix" != "x" ; then
+    OGG_CFLAGS="-I$ogg_prefix/include"
+  elif test "x$prefix" != "xNONE"; then
+    OGG_CFLAGS=""
+  fi
+
+  AC_MSG_CHECKING(for Ogg)
+  if test "x$ogg_prefix" = "xno" ; then
+    no_ogg="disabled"
+    enable_oggtest="no"
+  else
+    no_ogg=""
+  fi
+
+
+  if test "x$enable_oggtest" = "xyes" ; then
+    ac_save_CFLAGS="$CFLAGS"
+    ac_save_LIBS="$LIBS"
+    CFLAGS="$CFLAGS $OGG_CFLAGS"
+    LIBS="$LIBS $OGG_LIBS"
+dnl
+dnl Now check if the installed Ogg is sufficiently new.
+dnl
+      rm -f conf.oggtest
+      AC_TRY_RUN([
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <ogg/ogg.h>
+
+int main ()
+{
+  system("touch conf.oggtest");
+  return 0;
+}
+
+],, no_ogg=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+  fi
+
+  if test "x$no_ogg" = "xdisabled" ; then
+     AC_MSG_RESULT(no)
+     ifelse([$2], , :, [$2])
+  elif test "x$no_ogg" = "x" ; then
+     AC_MSG_RESULT(yes)
+     ifelse([$1], , :, [$1])
+  else
+     AC_MSG_RESULT(no)
+     if test -f conf.oggtest ; then
+       :
+     else
+       echo "*** Could not run Ogg test program, checking why..."
+       CFLAGS="$CFLAGS $OGG_CFLAGS"
+       LIBS="$LIBS $OGG_LIBS"
+       AC_TRY_LINK([
+#include <stdio.h>
+#include <ogg/ogg.h>
+],     [ return 0; ],
+       [ echo "*** The test program compiled, but did not run. This usually means"
+       echo "*** that the run-time linker is not finding Ogg or finding the wrong"
+       echo "*** version of Ogg. If it is not finding Ogg, you'll need to set your"
+       echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+       echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+       echo "*** is required on your system"
+       echo "***"
+       echo "*** If you have an old version installed, it is best to remove it, although"
+       echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"],
+       [ echo "*** The test program failed to compile or link. See the file config.log for the"
+       echo "*** exact error that occured. This usually means Ogg was incorrectly installed"
+       echo "*** or that you have moved Ogg since it was installed." ])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+     OGG_CFLAGS=""
+     OGG_LIBS=""
+     ifelse([$2], , :, [$2])
+  fi
+  AC_SUBST(OGG_CFLAGS)
+  AC_SUBST(OGG_LIBS)
+  rm -f conf.oggtest
+])
diff --git a/m4/pkg.m4 b/m4/pkg.m4
new file mode 100644 (file)
index 0000000..996e294
--- /dev/null
+++ b/m4/pkg.m4
@@ -0,0 +1,157 @@
+# pkg.m4 - Macros to locate and utilise pkg-config.            -*- Autoconf -*-
+#
+# Copyright © 2004 Scott James Remnant <scott@netsplit.com>.
+#
+# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+#
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+# PKG_PROG_PKG_CONFIG([MIN-VERSION])
+# ----------------------------------
+AC_DEFUN([PKG_PROG_PKG_CONFIG],
+[m4_pattern_forbid([^_?PKG_[A-Z_]+$])
+m4_pattern_allow([^PKG_CONFIG(_PATH)?$])
+AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility])dnl
+if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then
+       AC_PATH_TOOL([PKG_CONFIG], [pkg-config])
+fi
+if test -n "$PKG_CONFIG"; then
+       _pkg_min_version=m4_default([$1], [0.9.0])
+       AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version])
+       if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then
+               AC_MSG_RESULT([yes])
+       else
+               AC_MSG_RESULT([no])
+               PKG_CONFIG=""
+       fi
+
+fi[]dnl
+])# PKG_PROG_PKG_CONFIG
+
+# PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
+#
+# Check to see whether a particular set of modules exists.  Similar
+# to PKG_CHECK_MODULES(), but does not set variables or print errors.
+#
+#
+# Similar to PKG_CHECK_MODULES, make sure that the first instance of
+# this or PKG_CHECK_MODULES is called, or make sure to call
+# PKG_CHECK_EXISTS manually
+# --------------------------------------------------------------
+AC_DEFUN([PKG_CHECK_EXISTS],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+if test -n "$PKG_CONFIG" && \
+    AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then
+  m4_ifval([$2], [$2], [:])
+m4_ifvaln([$3], [else
+  $3])dnl
+fi])
+
+
+# _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES])
+# ---------------------------------------------
+m4_define([_PKG_CONFIG],
+[if test -n "$PKG_CONFIG"; then
+    if test -n "$$1"; then
+        pkg_cv_[]$1="$$1"
+    else
+        PKG_CHECK_EXISTS([$3],
+                         [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null`],
+                        [pkg_failed=yes])
+    fi
+else
+       pkg_failed=untried
+fi[]dnl
+])# _PKG_CONFIG
+
+# _PKG_SHORT_ERRORS_SUPPORTED
+# -----------------------------
+AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])
+if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
+        _pkg_short_errors_supported=yes
+else
+        _pkg_short_errors_supported=no
+fi[]dnl
+])# _PKG_SHORT_ERRORS_SUPPORTED
+
+
+# PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND],
+# [ACTION-IF-NOT-FOUND])
+#
+#
+# Note that if there is a possibility the first call to
+# PKG_CHECK_MODULES might not happen, you should be sure to include an
+# explicit call to PKG_PROG_PKG_CONFIG in your configure.ac
+#
+#
+# --------------------------------------------------------------
+AC_DEFUN([PKG_CHECK_MODULES],
+[AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl
+AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl
+AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl
+
+pkg_failed=no
+AC_MSG_CHECKING([for $1])
+
+_PKG_CONFIG([$1][_CFLAGS], [cflags], [$2])
+_PKG_CONFIG([$1][_LIBS], [libs], [$2])
+
+m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS
+and $1[]_LIBS to avoid the need to call pkg-config.
+See the pkg-config man page for more details.])
+
+if test $pkg_failed = yes; then
+        _PKG_SHORT_ERRORS_SUPPORTED
+        if test $_pkg_short_errors_supported = yes; then
+               $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "$2"`
+        else
+               $1[]_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "$2"`
+        fi
+       # Put the nasty error message in config.log where it belongs
+       echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD
+
+       ifelse([$4], , [AC_MSG_ERROR(dnl
+[Package requirements ($2) were not met:
+
+$$1_PKG_ERRORS
+
+Consider adjusting the PKG_CONFIG_PATH environment variable if you
+installed software in a non-standard prefix.
+
+_PKG_TEXT
+])],
+               [AC_MSG_RESULT([no])
+                $4])
+elif test $pkg_failed = untried; then
+       ifelse([$4], , [AC_MSG_FAILURE(dnl
+[The pkg-config script could not be found or is too old.  Make sure it
+is in your PATH or set the PKG_CONFIG environment variable to the full
+path to pkg-config.
+
+_PKG_TEXT
+
+To get pkg-config, see <http://pkg-config.freedesktop.org/>.])],
+               [$4])
+else
+       $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS
+       $1[]_LIBS=$pkg_cv_[]$1[]_LIBS
+        AC_MSG_RESULT([yes])
+       ifelse([$3], , :, [$3])
+fi[]dnl
+])# PKG_CHECK_MODULES
diff --git a/m4/sdl.m4 b/m4/sdl.m4
new file mode 100644 (file)
index 0000000..f5fb1f4
--- /dev/null
+++ b/m4/sdl.m4
@@ -0,0 +1,180 @@
+# Configure paths for SDL
+# Sam Lantinga 9/21/99
+# stolen from Manish Singh
+# stolen back from Frank Belew
+# stolen from Manish Singh
+# Shamelessly stolen from Owen Taylor
+
+dnl AM_PATH_SDL([MINIMUM-VERSION, [ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]]])
+dnl Test for SDL, and define SDL_CFLAGS and SDL_LIBS
+dnl
+AC_DEFUN([AM_PATH_SDL],
+[dnl 
+dnl Get the cflags and libraries from the sdl-config script
+dnl
+AC_ARG_WITH(sdl-prefix,[  --with-sdl-prefix=PFX   Prefix where SDL is installed (optional)],
+            sdl_prefix="$withval", sdl_prefix="")
+AC_ARG_WITH(sdl-exec-prefix,[  --with-sdl-exec-prefix=PFX Exec prefix where SDL is installed (optional)],
+            sdl_exec_prefix="$withval", sdl_exec_prefix="")
+AC_ARG_ENABLE(sdltest, [  --disable-sdltest       Do not try to compile and run a test SDL program],
+                   , enable_sdltest=yes)
+
+  if test x$sdl_exec_prefix != x ; then
+     sdl_args="$sdl_args --exec-prefix=$sdl_exec_prefix"
+     if test x${SDL_CONFIG+set} != xset ; then
+        SDL_CONFIG=$sdl_exec_prefix/bin/sdl-config
+     fi
+  fi
+  if test x$sdl_prefix != x ; then
+     sdl_args="$sdl_args --prefix=$sdl_prefix"
+     if test x${SDL_CONFIG+set} != xset ; then
+        SDL_CONFIG=$sdl_prefix/bin/sdl-config
+     fi
+  fi
+
+  AC_REQUIRE([AC_CANONICAL_TARGET])
+  PATH="$prefix/bin:$prefix/usr/bin:$PATH"
+  AC_PATH_PROG(SDL_CONFIG, sdl-config, no, [$PATH])
+  min_sdl_version=ifelse([$1], ,0.11.0,$1)
+  AC_MSG_CHECKING(for SDL - version >= $min_sdl_version)
+  no_sdl=""
+  if test "$SDL_CONFIG" = "no" ; then
+    no_sdl=yes
+  else
+    SDL_CFLAGS=`$SDL_CONFIG $sdlconf_args --cflags`
+    SDL_LIBS=`$SDL_CONFIG $sdlconf_args --libs`
+
+    sdl_major_version=`$SDL_CONFIG $sdl_args --version | \
+           sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\1/'`
+    sdl_minor_version=`$SDL_CONFIG $sdl_args --version | \
+           sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\2/'`
+    sdl_micro_version=`$SDL_CONFIG $sdl_config_args --version | \
+           sed 's/\([[0-9]]*\).\([[0-9]]*\).\([[0-9]]*\)/\3/'`
+    if test "x$enable_sdltest" = "xyes" ; then
+      ac_save_CFLAGS="$CFLAGS"
+      ac_save_CXXFLAGS="$CXXFLAGS"
+      ac_save_LIBS="$LIBS"
+      CFLAGS="$CFLAGS $SDL_CFLAGS"
+      CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
+      LIBS="$LIBS $SDL_LIBS"
+dnl
+dnl Now check if the installed SDL is sufficiently new. (Also sanity
+dnl checks the results of sdl-config to some extent
+dnl
+      rm -f conf.sdltest
+      AC_TRY_RUN([
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include "SDL.h"
+
+char*
+my_strdup (char *str)
+{
+  char *new_str;
+  
+  if (str)
+    {
+      new_str = (char *)malloc ((strlen (str) + 1) * sizeof(char));
+      strcpy (new_str, str);
+    }
+  else
+    new_str = NULL;
+  
+  return new_str;
+}
+
+int main (int argc, char *argv[])
+{
+  int major, minor, micro;
+  char *tmp_version;
+
+  /* This hangs on some systems (?)
+  system ("touch conf.sdltest");
+  */
+  { FILE *fp = fopen("conf.sdltest", "a"); if ( fp ) fclose(fp); }
+
+  /* HP/UX 9 (%@#!) writes to sscanf strings */
+  tmp_version = my_strdup("$min_sdl_version");
+  if (sscanf(tmp_version, "%d.%d.%d", &major, &minor, &micro) != 3) {
+     printf("%s, bad version string\n", "$min_sdl_version");
+     exit(1);
+   }
+
+   if (($sdl_major_version > major) ||
+      (($sdl_major_version == major) && ($sdl_minor_version > minor)) ||
+      (($sdl_major_version == major) && ($sdl_minor_version == minor) && ($sdl_micro_version >= micro)))
+    {
+      return 0;
+    }
+  else
+    {
+      printf("\n*** 'sdl-config --version' returned %d.%d.%d, but the minimum version\n", $sdl_major_version, $sdl_minor_version, $sdl_micro_version);
+      printf("*** of SDL required is %d.%d.%d. If sdl-config is correct, then it is\n", major, minor, micro);
+      printf("*** best to upgrade to the required version.\n");
+      printf("*** If sdl-config was wrong, set the environment variable SDL_CONFIG\n");
+      printf("*** to point to the correct copy of sdl-config, and remove the file\n");
+      printf("*** config.cache before re-running configure\n");
+      return 1;
+    }
+}
+
+],, no_sdl=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+       CFLAGS="$ac_save_CFLAGS"
+       CXXFLAGS="$ac_save_CXXFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+  fi
+  if test "x$no_sdl" = x ; then
+     AC_MSG_RESULT(yes)
+     ifelse([$2], , :, [$2])     
+  else
+     AC_MSG_RESULT(no)
+     if test "$SDL_CONFIG" = "no" ; then
+       echo "*** The sdl-config script installed by SDL could not be found"
+       echo "*** If SDL was installed in PREFIX, make sure PREFIX/bin is in"
+       echo "*** your path, or set the SDL_CONFIG environment variable to the"
+       echo "*** full path to sdl-config."
+     else
+       if test -f conf.sdltest ; then
+        :
+       else
+          echo "*** Could not run SDL test program, checking why..."
+          CFLAGS="$CFLAGS $SDL_CFLAGS"
+          CXXFLAGS="$CXXFLAGS $SDL_CFLAGS"
+          LIBS="$LIBS $SDL_LIBS"
+          AC_TRY_LINK([
+#include <stdio.h>
+#include "SDL.h"
+
+int main(int argc, char *argv[])
+{ return 0; }
+#undef  main
+#define main K_and_R_C_main
+],      [ return 0; ],
+        [ echo "*** The test program compiled, but did not run. This usually means"
+          echo "*** that the run-time linker is not finding SDL or finding the wrong"
+          echo "*** version of SDL. If it is not finding SDL, you'll need to set your"
+          echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+          echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+          echo "*** is required on your system"
+         echo "***"
+          echo "*** If you have an old version installed, it is best to remove it, although"
+          echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"],
+        [ echo "*** The test program failed to compile or link. See the file config.log for the"
+          echo "*** exact error that occured. This usually means SDL was incorrectly installed"
+          echo "*** or that you have moved SDL since it was installed. In the latter case, you"
+          echo "*** may want to edit the sdl-config script: $SDL_CONFIG" ])
+          CFLAGS="$ac_save_CFLAGS"
+          CXXFLAGS="$ac_save_CXXFLAGS"
+          LIBS="$ac_save_LIBS"
+       fi
+     fi
+     SDL_CFLAGS=""
+     SDL_LIBS=""
+     ifelse([$3], , :, [$3])
+  fi
+  AC_SUBST(SDL_CFLAGS)
+  AC_SUBST(SDL_LIBS)
+  rm -f conf.sdltest
+])
diff --git a/m4/vorbis.m4 b/m4/vorbis.m4
new file mode 100644 (file)
index 0000000..69715a7
--- /dev/null
@@ -0,0 +1,122 @@
+# Configure paths for libvorbis
+# Jack Moffitt <jack@icecast.org> 10-21-2000
+# Shamelessly stolen from Owen Taylor and Manish Singh
+# thomasvs added check for vorbis_bitrate_addblock which is new in rc3
+
+dnl XIPH_PATH_VORBIS([ACTION-IF-FOUND [, ACTION-IF-NOT-FOUND]])
+dnl Test for libvorbis, and define VORBIS_CFLAGS and VORBIS_LIBS
+dnl
+AC_DEFUN([XIPH_PATH_VORBIS],
+[dnl 
+dnl Get the cflags and libraries
+dnl
+AC_ARG_WITH(vorbis,[  --with-vorbis=PFX   Prefix where libvorbis is installed (optional)], vorbis_prefix="$withval", vorbis_prefix="")
+AC_ARG_WITH(vorbis-libraries,[  --with-vorbis-libraries=DIR   Directory where libvorbis library is installed (optional)], vorbis_libraries="$withval", vorbis_libraries="")
+AC_ARG_WITH(vorbis-includes,[  --with-vorbis-includes=DIR   Directory where libvorbis header files are installed (optional)], vorbis_includes="$withval", vorbis_includes="")
+AC_ARG_ENABLE(vorbistest, [  --disable-vorbistest    Do not try to compile and run a test Vorbis program],, enable_vorbistest=yes)
+
+  if test "x$vorbis_libraries" != "x" ; then
+    VORBIS_LIBS="-L$vorbis_libraries"
+  elif test "x$vorbis_prefix" != "x" ; then
+    VORBIS_LIBS="-L$vorbis_prefix/lib"
+  elif test "x$prefix" != "xNONE"; then
+    VORBIS_LIBS="-L$libdir"
+  fi
+
+  VORBIS_LIBS="$VORBIS_LIBS -lvorbis -lm"
+  VORBISFILE_LIBS="-lvorbisfile"
+  VORBISENC_LIBS="-lvorbisenc"
+
+  if test "x$vorbis_includes" != "x" ; then
+    VORBIS_CFLAGS="-I$vorbis_includes"
+  elif test "x$vorbis_prefix" != "x" ; then
+    VORBIS_CFLAGS="-I$vorbis_prefix/include"
+  elif test "x$prefix" != "xNONE"; then
+    VORBIS_CFLAGS=""
+  fi
+
+
+  AC_MSG_CHECKING(for Vorbis)
+  no_vorbis=""
+
+
+  if test "x$enable_vorbistest" = "xyes" ; then
+    ac_save_CFLAGS="$CFLAGS"
+    ac_save_LIBS="$LIBS"
+    CFLAGS="$CFLAGS $VORBIS_CFLAGS $OGG_CFLAGS"
+    LIBS="$LIBS $VORBIS_LIBS $VORBISENC_LIBS $OGG_LIBS"
+dnl
+dnl Now check if the installed Vorbis is sufficiently new.
+dnl
+      rm -f conf.vorbistest
+      AC_TRY_RUN([
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <vorbis/codec.h>
+#include <vorbis/vorbisenc.h>
+
+int main ()
+{
+    vorbis_block       vb;
+    vorbis_dsp_state   vd;
+    vorbis_info                vi;
+
+    vorbis_info_init (&vi);
+    vorbis_encode_init (&vi, 2, 44100, -1, 128000, -1);
+    vorbis_analysis_init (&vd, &vi);
+    vorbis_block_init (&vd, &vb);
+    /* this function was added in 1.0rc3, so this is what we're testing for */
+    vorbis_bitrate_addblock (&vb);
+
+    system("touch conf.vorbistest");
+    return 0;
+}
+
+],, no_vorbis=yes,[echo $ac_n "cross compiling; assumed OK... $ac_c"])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+  fi
+
+  if test "x$no_vorbis" = "x" ; then
+     AC_MSG_RESULT(yes)
+     ifelse([$1], , :, [$1])     
+  else
+     AC_MSG_RESULT(no)
+     if test -f conf.vorbistest ; then
+       :
+     else
+       echo "*** Could not run Vorbis test program, checking why..."
+       CFLAGS="$CFLAGS $VORBIS_CFLAGS"
+       LIBS="$LIBS $VORBIS_LIBS $OGG_LIBS"
+       AC_TRY_LINK([
+#include <stdio.h>
+#include <vorbis/codec.h>
+],     [ return 0; ],
+       [ echo "*** The test program compiled, but did not run. This usually means"
+       echo "*** that the run-time linker is not finding Vorbis or finding the wrong"
+       echo "*** version of Vorbis. If it is not finding Vorbis, you'll need to set your"
+       echo "*** LD_LIBRARY_PATH environment variable, or edit /etc/ld.so.conf to point"
+       echo "*** to the installed location  Also, make sure you have run ldconfig if that"
+       echo "*** is required on your system"
+       echo "***"
+       echo "*** If you have an old version installed, it is best to remove it, although"
+       echo "*** you may also be able to get things to work by modifying LD_LIBRARY_PATH"],
+       [ echo "*** The test program failed to compile or link. See the file config.log for the"
+       echo "*** exact error that occured. This usually means Vorbis was incorrectly installed"
+       echo "*** or that you have moved Vorbis since it was installed." ])
+       CFLAGS="$ac_save_CFLAGS"
+       LIBS="$ac_save_LIBS"
+     fi
+     VORBIS_CFLAGS=""
+     VORBIS_LIBS=""
+     VORBISFILE_LIBS=""
+     VORBISENC_LIBS=""
+     ifelse([$2], , :, [$2])
+  fi
+  AC_SUBST(VORBIS_CFLAGS)
+  AC_SUBST(VORBIS_LIBS)
+  AC_SUBST(VORBISFILE_LIBS)
+  AC_SUBST(VORBISENC_LIBS)
+  rm -f conf.vorbistest
+])
diff --git a/macosx/English.lproj/InfoPlist.strings b/macosx/English.lproj/InfoPlist.strings
new file mode 100644 (file)
index 0000000..e5964ff
Binary files /dev/null and b/macosx/English.lproj/InfoPlist.strings differ
diff --git a/macosx/Info.plist b/macosx/Info.plist
new file mode 100644 (file)
index 0000000..1731a8d
--- /dev/null
@@ -0,0 +1,30 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+    <key>CFBundleDevelopmentRegion</key>
+    <string>English</string>
+    <key>CFBundleExecutable</key>
+    <string>Theora</string>
+    <key>CFBundleGetInfoString</key>
+    <string>Theora framework 1.1alpha1svn, Copyright © 2002-2009Xiph.Org Foundation</string>
+    <key>CFBundleIconFile</key>
+    <string></string>
+    <key>CFBundleIdentifier</key>
+    <string>org.xiph.theora</string>
+    <key>CFBundleInfoDictionaryVersion</key>
+    <string>6.0</string>
+    <key>CFBundlePackageType</key>
+    <string>FMWK</string>
+    <key>CFBundleSignature</key>
+    <string>????</string>
+    <key>CFBundleVersion</key>
+    <string>1.0d6</string>
+    <key>CFBundleShortVersionString</key>
+    <string>1.1alpha1svn</string>
+    <key>NSHumanReadableCopyright</key>
+    <string>Theora framework 1.1alpha1svn, Copyright © 2002-2009Xiph.Org Foundation</string>
+    <key>CSResourcesFileMapped</key>
+    <true/>
+</dict>
+</plist>
diff --git a/macosx/Theora.xcodeproj/project.pbxproj b/macosx/Theora.xcodeproj/project.pbxproj
new file mode 100644 (file)
index 0000000..380245f
--- /dev/null
@@ -0,0 +1,864 @@
+// !$*UTF8*$!
+{
+       archiveVersion = 1;
+       classes = {
+       };
+       objectVersion = 42;
+       objects = {
+
+/* Begin PBXBuildFile section */
+               084C31FE0FE4E5BD00117FC9 /* apiwrapper.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31D90FE4E5BD00117FC9 /* apiwrapper.c */; };
+               084C31FF0FE4E5BD00117FC9 /* apiwrapper.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DA0FE4E5BD00117FC9 /* apiwrapper.h */; };
+               084C32000FE4E5BD00117FC9 /* bitpack.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31DB0FE4E5BD00117FC9 /* bitpack.c */; };
+               084C32010FE4E5BD00117FC9 /* bitpack.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DC0FE4E5BD00117FC9 /* bitpack.h */; };
+               084C32020FE4E5BD00117FC9 /* dct.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DD0FE4E5BD00117FC9 /* dct.h */; };
+               084C32030FE4E5BD00117FC9 /* decapiwrapper.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31DE0FE4E5BD00117FC9 /* decapiwrapper.c */; };
+               084C32040FE4E5BD00117FC9 /* decinfo.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31DF0FE4E5BD00117FC9 /* decinfo.c */; };
+               084C32050FE4E5BD00117FC9 /* decint.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E00FE4E5BD00117FC9 /* decint.h */; };
+               084C32060FE4E5BD00117FC9 /* decode.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E10FE4E5BD00117FC9 /* decode.c */; };
+               084C32070FE4E5BD00117FC9 /* dequant.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E20FE4E5BD00117FC9 /* dequant.c */; };
+               084C32080FE4E5BD00117FC9 /* dequant.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E30FE4E5BD00117FC9 /* dequant.h */; };
+               084C32090FE4E5BD00117FC9 /* fragment.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E40FE4E5BD00117FC9 /* fragment.c */; };
+               084C320A0FE4E5BD00117FC9 /* huffdec.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E50FE4E5BD00117FC9 /* huffdec.c */; };
+               084C320B0FE4E5BD00117FC9 /* huffdec.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E60FE4E5BD00117FC9 /* huffdec.h */; };
+               084C320C0FE4E5BD00117FC9 /* huffman.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E70FE4E5BD00117FC9 /* huffman.h */; };
+               084C320D0FE4E5BD00117FC9 /* idct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E80FE4E5BD00117FC9 /* idct.c */; };
+               084C320E0FE4E5BD00117FC9 /* info.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E90FE4E5BD00117FC9 /* info.c */; };
+               084C320F0FE4E5BD00117FC9 /* internal.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EA0FE4E5BD00117FC9 /* internal.c */; };
+               084C32100FE4E5BD00117FC9 /* ocintrin.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31EB0FE4E5BD00117FC9 /* ocintrin.h */; };
+               084C32110FE4E5BD00117FC9 /* quant.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EC0FE4E5BD00117FC9 /* quant.c */; };
+               084C32120FE4E5BD00117FC9 /* quant.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31ED0FE4E5BD00117FC9 /* quant.h */; };
+               084C32130FE4E5BD00117FC9 /* state.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EE0FE4E5BD00117FC9 /* state.c */; };
+               084C32140FE4E5BD00117FC9 /* mmxfrag.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F00FE4E5BD00117FC9 /* mmxfrag.c */; };
+               084C32150FE4E5BD00117FC9 /* mmxfrag.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F10FE4E5BD00117FC9 /* mmxfrag.h */; };
+               084C32160FE4E5BD00117FC9 /* mmxidct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F20FE4E5BD00117FC9 /* mmxidct.c */; };
+               084C32170FE4E5BD00117FC9 /* mmxloop.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F30FE4E5BD00117FC9 /* mmxloop.h */; };
+               084C32180FE4E5BD00117FC9 /* mmxstate.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F40FE4E5BD00117FC9 /* mmxstate.c */; };
+               084C32190FE4E5BD00117FC9 /* x86int.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F50FE4E5BD00117FC9 /* x86int.h */; };
+               084C321A0FE4E5BD00117FC9 /* x86state.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F60FE4E5BD00117FC9 /* x86state.c */; };
+               084C32210FE4E5BD00117FC9 /* apiwrapper.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31D90FE4E5BD00117FC9 /* apiwrapper.c */; };
+               084C32220FE4E5BD00117FC9 /* apiwrapper.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DA0FE4E5BD00117FC9 /* apiwrapper.h */; };
+               084C32230FE4E5BD00117FC9 /* bitpack.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31DB0FE4E5BD00117FC9 /* bitpack.c */; };
+               084C32240FE4E5BD00117FC9 /* bitpack.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DC0FE4E5BD00117FC9 /* bitpack.h */; };
+               084C32250FE4E5BD00117FC9 /* dct.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DD0FE4E5BD00117FC9 /* dct.h */; };
+               084C32260FE4E5BD00117FC9 /* decapiwrapper.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31DE0FE4E5BD00117FC9 /* decapiwrapper.c */; };
+               084C32270FE4E5BD00117FC9 /* decinfo.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31DF0FE4E5BD00117FC9 /* decinfo.c */; };
+               084C32280FE4E5BD00117FC9 /* decint.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E00FE4E5BD00117FC9 /* decint.h */; };
+               084C32290FE4E5BD00117FC9 /* decode.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E10FE4E5BD00117FC9 /* decode.c */; };
+               084C322A0FE4E5BD00117FC9 /* dequant.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E20FE4E5BD00117FC9 /* dequant.c */; };
+               084C322B0FE4E5BD00117FC9 /* dequant.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E30FE4E5BD00117FC9 /* dequant.h */; };
+               084C322C0FE4E5BD00117FC9 /* fragment.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E40FE4E5BD00117FC9 /* fragment.c */; };
+               084C322D0FE4E5BD00117FC9 /* huffdec.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E50FE4E5BD00117FC9 /* huffdec.c */; };
+               084C322E0FE4E5BD00117FC9 /* huffdec.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E60FE4E5BD00117FC9 /* huffdec.h */; };
+               084C322F0FE4E5BD00117FC9 /* huffman.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31E70FE4E5BD00117FC9 /* huffman.h */; };
+               084C32300FE4E5BD00117FC9 /* idct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E80FE4E5BD00117FC9 /* idct.c */; };
+               084C32310FE4E5BD00117FC9 /* info.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E90FE4E5BD00117FC9 /* info.c */; };
+               084C32320FE4E5BD00117FC9 /* internal.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EA0FE4E5BD00117FC9 /* internal.c */; };
+               084C32330FE4E5BD00117FC9 /* ocintrin.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31EB0FE4E5BD00117FC9 /* ocintrin.h */; };
+               084C32340FE4E5BD00117FC9 /* quant.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EC0FE4E5BD00117FC9 /* quant.c */; };
+               084C32350FE4E5BD00117FC9 /* quant.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31ED0FE4E5BD00117FC9 /* quant.h */; };
+               084C32360FE4E5BD00117FC9 /* state.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EE0FE4E5BD00117FC9 /* state.c */; };
+               084C32370FE4E5BD00117FC9 /* mmxfrag.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F00FE4E5BD00117FC9 /* mmxfrag.c */; };
+               084C32380FE4E5BD00117FC9 /* mmxfrag.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F10FE4E5BD00117FC9 /* mmxfrag.h */; };
+               084C32390FE4E5BD00117FC9 /* mmxidct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F20FE4E5BD00117FC9 /* mmxidct.c */; };
+               084C323A0FE4E5BD00117FC9 /* mmxloop.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F30FE4E5BD00117FC9 /* mmxloop.h */; };
+               084C323B0FE4E5BD00117FC9 /* mmxstate.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F40FE4E5BD00117FC9 /* mmxstate.c */; };
+               084C323C0FE4E5BD00117FC9 /* x86int.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F50FE4E5BD00117FC9 /* x86int.h */; };
+               084C323D0FE4E5BD00117FC9 /* x86state.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F60FE4E5BD00117FC9 /* x86state.c */; };
+               084C32620FE4E5D500117FC9 /* analyze.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32450FE4E5D500117FC9 /* analyze.c */; };
+               084C32630FE4E5D500117FC9 /* encapiwrapper.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32460FE4E5D500117FC9 /* encapiwrapper.c */; };
+               084C32640FE4E5D500117FC9 /* encfrag.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32470FE4E5D500117FC9 /* encfrag.c */; };
+               084C32650FE4E5D500117FC9 /* encinfo.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32480FE4E5D500117FC9 /* encinfo.c */; };
+               084C32660FE4E5D500117FC9 /* encint.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32490FE4E5D500117FC9 /* encint.h */; };
+               084C32670FE4E5D500117FC9 /* encode.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324A0FE4E5D500117FC9 /* encode.c */; };
+               084C32690FE4E5D500117FC9 /* enquant.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324C0FE4E5D500117FC9 /* enquant.c */; };
+               084C326A0FE4E5D500117FC9 /* enquant.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C324D0FE4E5D500117FC9 /* enquant.h */; };
+               084C326B0FE4E5D500117FC9 /* fdct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324E0FE4E5D500117FC9 /* fdct.c */; };
+               084C326C0FE4E5D500117FC9 /* huffenc.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324F0FE4E5D500117FC9 /* huffenc.c */; };
+               084C326D0FE4E5D500117FC9 /* huffenc.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32500FE4E5D500117FC9 /* huffenc.h */; };
+               084C326E0FE4E5D500117FC9 /* mathops.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32510FE4E5D500117FC9 /* mathops.c */; };
+               084C326F0FE4E5D500117FC9 /* mathops.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32520FE4E5D500117FC9 /* mathops.h */; };
+               084C32700FE4E5D500117FC9 /* mcenc.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32530FE4E5D500117FC9 /* mcenc.c */; };
+               084C32710FE4E5D500117FC9 /* modedec.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32540FE4E5D500117FC9 /* modedec.h */; };
+               084C32720FE4E5D500117FC9 /* rate.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32550FE4E5D500117FC9 /* rate.c */; };
+               084C32730FE4E5D500117FC9 /* tokenize.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32560FE4E5D500117FC9 /* tokenize.c */; };
+               084C32750FE4E5D500117FC9 /* mmxencfrag.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32590FE4E5D500117FC9 /* mmxencfrag.c */; };
+               084C32760FE4E5D500117FC9 /* mmxfdct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C325A0FE4E5D500117FC9 /* mmxfdct.c */; };
+               084C32770FE4E5D500117FC9 /* sse2fdct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C325B0FE4E5D500117FC9 /* sse2fdct.c */; };
+               084C32780FE4E5D500117FC9 /* x86enc.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C325C0FE4E5D500117FC9 /* x86enc.c */; };
+               084C32790FE4E5D500117FC9 /* x86enc.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C325D0FE4E5D500117FC9 /* x86enc.h */; };
+               084C327D0FE4E5D500117FC9 /* analyze.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32450FE4E5D500117FC9 /* analyze.c */; };
+               084C327E0FE4E5D500117FC9 /* encapiwrapper.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32460FE4E5D500117FC9 /* encapiwrapper.c */; };
+               084C327F0FE4E5D500117FC9 /* encfrag.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32470FE4E5D500117FC9 /* encfrag.c */; };
+               084C32800FE4E5D500117FC9 /* encinfo.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32480FE4E5D500117FC9 /* encinfo.c */; };
+               084C32810FE4E5D500117FC9 /* encint.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32490FE4E5D500117FC9 /* encint.h */; };
+               084C32820FE4E5D500117FC9 /* encode.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324A0FE4E5D500117FC9 /* encode.c */; };
+               084C32840FE4E5D500117FC9 /* enquant.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324C0FE4E5D500117FC9 /* enquant.c */; };
+               084C32850FE4E5D500117FC9 /* enquant.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C324D0FE4E5D500117FC9 /* enquant.h */; };
+               084C32860FE4E5D500117FC9 /* fdct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324E0FE4E5D500117FC9 /* fdct.c */; };
+               084C32870FE4E5D500117FC9 /* huffenc.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C324F0FE4E5D500117FC9 /* huffenc.c */; };
+               084C32880FE4E5D500117FC9 /* huffenc.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32500FE4E5D500117FC9 /* huffenc.h */; };
+               084C32890FE4E5D500117FC9 /* mathops.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32510FE4E5D500117FC9 /* mathops.c */; };
+               084C328A0FE4E5D500117FC9 /* mathops.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32520FE4E5D500117FC9 /* mathops.h */; };
+               084C328B0FE4E5D500117FC9 /* mcenc.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32530FE4E5D500117FC9 /* mcenc.c */; };
+               084C328C0FE4E5D500117FC9 /* modedec.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C32540FE4E5D500117FC9 /* modedec.h */; };
+               084C328D0FE4E5D500117FC9 /* rate.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32550FE4E5D500117FC9 /* rate.c */; };
+               084C328E0FE4E5D500117FC9 /* tokenize.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32560FE4E5D500117FC9 /* tokenize.c */; };
+               084C32900FE4E5D500117FC9 /* mmxencfrag.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C32590FE4E5D500117FC9 /* mmxencfrag.c */; };
+               084C32910FE4E5D500117FC9 /* mmxfdct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C325A0FE4E5D500117FC9 /* mmxfdct.c */; };
+               084C32920FE4E5D500117FC9 /* sse2fdct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C325B0FE4E5D500117FC9 /* sse2fdct.c */; };
+               084C32930FE4E5D500117FC9 /* x86enc.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C325C0FE4E5D500117FC9 /* x86enc.c */; };
+               084C32940FE4E5D500117FC9 /* x86enc.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C325D0FE4E5D500117FC9 /* x86enc.h */; };
+               084C32A70FE4E7FE00117FC9 /* apiwrapper.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31D90FE4E5BD00117FC9 /* apiwrapper.c */; };
+               084C32A80FE4E7FF00117FC9 /* apiwrapper.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DA0FE4E5BD00117FC9 /* apiwrapper.h */; };
+               084C32A90FE4E82500117FC9 /* dct.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31DD0FE4E5BD00117FC9 /* dct.h */; };
+               084C32AA0FE4E83100117FC9 /* idct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E80FE4E5BD00117FC9 /* idct.c */; };
+               084C32AB0FE4E83300117FC9 /* internal.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EA0FE4E5BD00117FC9 /* internal.c */; };
+               084C32AC0FE4E83600117FC9 /* fragment.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31E40FE4E5BD00117FC9 /* fragment.c */; };
+               084C32AD0FE4E84800117FC9 /* quant.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31ED0FE4E5BD00117FC9 /* quant.h */; };
+               084C32AE0FE4E84A00117FC9 /* quant.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EC0FE4E5BD00117FC9 /* quant.c */; };
+               084C32AF0FE4E84C00117FC9 /* ocintrin.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31EB0FE4E5BD00117FC9 /* ocintrin.h */; };
+               084C32B00FE4E84F00117FC9 /* state.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31EE0FE4E5BD00117FC9 /* state.c */; };
+               084C32B10FE4E85300117FC9 /* x86int.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F50FE4E5BD00117FC9 /* x86int.h */; };
+               084C32B20FE4E85300117FC9 /* x86state.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F60FE4E5BD00117FC9 /* x86state.c */; };
+               084C32B30FE4E85D00117FC9 /* mmxstate.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F40FE4E5BD00117FC9 /* mmxstate.c */; };
+               084C32B40FE4E86A00117FC9 /* mmxfrag.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F00FE4E5BD00117FC9 /* mmxfrag.c */; };
+               084C32B50FE4E86B00117FC9 /* mmxfrag.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F10FE4E5BD00117FC9 /* mmxfrag.h */; };
+               084C32B60FE4E87200117FC9 /* mmxidct.c in Sources */ = {isa = PBXBuildFile; fileRef = 084C31F20FE4E5BD00117FC9 /* mmxidct.c */; };
+               084C32B70FE4E88300117FC9 /* mmxloop.h in Headers */ = {isa = PBXBuildFile; fileRef = 084C31F30FE4E5BD00117FC9 /* mmxloop.h */; };
+               097729950BCAC60000303091 /* codec.h in Headers */ = {isa = PBXBuildFile; fileRef = 097729930BCAC60000303091 /* codec.h */; settings = {ATTRIBUTES = (Public, ); }; };
+               097729960BCAC60000303091 /* theoradec.h in Headers */ = {isa = PBXBuildFile; fileRef = 097729940BCAC60000303091 /* theoradec.h */; settings = {ATTRIBUTES = (Public, ); }; };
+               37C9B0140EBB831F0046849C /* theoraenc.h in Headers */ = {isa = PBXBuildFile; fileRef = 37C9B0130EBB831F0046849C /* theoraenc.h */; settings = {ATTRIBUTES = (Public, ); }; };
+               37CA8E390DD747F1005C8CB6 /* internal.h in Headers */ = {isa = PBXBuildFile; fileRef = 37CA8E380DD747F1005C8CB6 /* internal.h */; };
+               734A751909D76ADD002D8FAE /* Ogg.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 734A751809D76ADD002D8FAE /* Ogg.framework */; };
+               734A75BF09D76BB9002D8FAE /* theora.h in Headers */ = {isa = PBXBuildFile; fileRef = 734A75BE09D76BB9002D8FAE /* theora.h */; settings = {ATTRIBUTES = (Public, ); }; };
+               73514EC90B0C7E5700CEC060 /* cpu.h in Headers */ = {isa = PBXBuildFile; fileRef = 73514EC70B0C7E5700CEC060 /* cpu.h */; };
+               8D07F2BE0486CC7A007CD1D0 /* Theora_Prefix.pch in Headers */ = {isa = PBXBuildFile; fileRef = 32BAE0B70371A74B00C91783 /* Theora_Prefix.pch */; };
+               8D07F2C00486CC7A007CD1D0 /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 089C1666FE841158C02AAC07 /* InfoPlist.strings */; };
+/* End PBXBuildFile section */
+
+/* Begin PBXFileReference section */
+               0844FE7E0FCCC99A004A99B0 /* cpu.c */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.c; name = cpu.c; path = ../lib/cpu.c; sourceTree = SOURCE_ROOT; };
+               084C31D90FE4E5BD00117FC9 /* apiwrapper.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = apiwrapper.c; sourceTree = "<group>"; };
+               084C31DA0FE4E5BD00117FC9 /* apiwrapper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = apiwrapper.h; sourceTree = "<group>"; };
+               084C31DB0FE4E5BD00117FC9 /* bitpack.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = bitpack.c; sourceTree = "<group>"; };
+               084C31DC0FE4E5BD00117FC9 /* bitpack.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = bitpack.h; sourceTree = "<group>"; };
+               084C31DD0FE4E5BD00117FC9 /* dct.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dct.h; sourceTree = "<group>"; };
+               084C31DE0FE4E5BD00117FC9 /* decapiwrapper.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = decapiwrapper.c; sourceTree = "<group>"; };
+               084C31DF0FE4E5BD00117FC9 /* decinfo.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = decinfo.c; sourceTree = "<group>"; };
+               084C31E00FE4E5BD00117FC9 /* decint.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = decint.h; sourceTree = "<group>"; };
+               084C31E10FE4E5BD00117FC9 /* decode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = decode.c; sourceTree = "<group>"; };
+               084C31E20FE4E5BD00117FC9 /* dequant.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = dequant.c; sourceTree = "<group>"; };
+               084C31E30FE4E5BD00117FC9 /* dequant.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dequant.h; sourceTree = "<group>"; };
+               084C31E40FE4E5BD00117FC9 /* fragment.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = fragment.c; sourceTree = "<group>"; };
+               084C31E50FE4E5BD00117FC9 /* huffdec.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = huffdec.c; sourceTree = "<group>"; };
+               084C31E60FE4E5BD00117FC9 /* huffdec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = huffdec.h; sourceTree = "<group>"; };
+               084C31E70FE4E5BD00117FC9 /* huffman.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = huffman.h; sourceTree = "<group>"; };
+               084C31E80FE4E5BD00117FC9 /* idct.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = idct.c; sourceTree = "<group>"; };
+               084C31E90FE4E5BD00117FC9 /* info.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = info.c; sourceTree = "<group>"; };
+               084C31EA0FE4E5BD00117FC9 /* internal.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = internal.c; sourceTree = "<group>"; };
+               084C31EB0FE4E5BD00117FC9 /* ocintrin.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ocintrin.h; sourceTree = "<group>"; };
+               084C31EC0FE4E5BD00117FC9 /* quant.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = quant.c; sourceTree = "<group>"; };
+               084C31ED0FE4E5BD00117FC9 /* quant.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = quant.h; sourceTree = "<group>"; };
+               084C31EE0FE4E5BD00117FC9 /* state.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = state.c; sourceTree = "<group>"; };
+               084C31F00FE4E5BD00117FC9 /* mmxfrag.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mmxfrag.c; sourceTree = "<group>"; };
+               084C31F10FE4E5BD00117FC9 /* mmxfrag.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mmxfrag.h; sourceTree = "<group>"; };
+               084C31F20FE4E5BD00117FC9 /* mmxidct.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mmxidct.c; sourceTree = "<group>"; };
+               084C31F30FE4E5BD00117FC9 /* mmxloop.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mmxloop.h; sourceTree = "<group>"; };
+               084C31F40FE4E5BD00117FC9 /* mmxstate.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mmxstate.c; sourceTree = "<group>"; };
+               084C31F50FE4E5BD00117FC9 /* x86int.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = x86int.h; sourceTree = "<group>"; };
+               084C31F60FE4E5BD00117FC9 /* x86state.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = x86state.c; sourceTree = "<group>"; };
+               084C32450FE4E5D500117FC9 /* analyze.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = analyze.c; sourceTree = "<group>"; };
+               084C32460FE4E5D500117FC9 /* encapiwrapper.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encapiwrapper.c; sourceTree = "<group>"; };
+               084C32470FE4E5D500117FC9 /* encfrag.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encfrag.c; sourceTree = "<group>"; };
+               084C32480FE4E5D500117FC9 /* encinfo.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encinfo.c; sourceTree = "<group>"; };
+               084C32490FE4E5D500117FC9 /* encint.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = encint.h; sourceTree = "<group>"; };
+               084C324A0FE4E5D500117FC9 /* encode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encode.c; sourceTree = "<group>"; };
+               084C324B0FE4E5D500117FC9 /* encoder_disabled.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encoder_disabled.c; sourceTree = "<group>"; };
+               084C324C0FE4E5D500117FC9 /* enquant.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = enquant.c; sourceTree = "<group>"; };
+               084C324D0FE4E5D500117FC9 /* enquant.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = enquant.h; sourceTree = "<group>"; };
+               084C324E0FE4E5D500117FC9 /* fdct.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = fdct.c; sourceTree = "<group>"; };
+               084C324F0FE4E5D500117FC9 /* huffenc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = huffenc.c; sourceTree = "<group>"; };
+               084C32500FE4E5D500117FC9 /* huffenc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = huffenc.h; sourceTree = "<group>"; };
+               084C32510FE4E5D500117FC9 /* mathops.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mathops.c; sourceTree = "<group>"; };
+               084C32520FE4E5D500117FC9 /* mathops.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mathops.h; sourceTree = "<group>"; };
+               084C32530FE4E5D500117FC9 /* mcenc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mcenc.c; sourceTree = "<group>"; };
+               084C32540FE4E5D500117FC9 /* modedec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = modedec.h; sourceTree = "<group>"; };
+               084C32550FE4E5D500117FC9 /* rate.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = rate.c; sourceTree = "<group>"; };
+               084C32560FE4E5D500117FC9 /* tokenize.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = tokenize.c; sourceTree = "<group>"; };
+               084C32590FE4E5D500117FC9 /* mmxencfrag.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mmxencfrag.c; sourceTree = "<group>"; };
+               084C325A0FE4E5D500117FC9 /* mmxfdct.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mmxfdct.c; sourceTree = "<group>"; };
+               084C325B0FE4E5D500117FC9 /* sse2fdct.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = sse2fdct.c; sourceTree = "<group>"; };
+               084C325C0FE4E5D500117FC9 /* x86enc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = x86enc.c; sourceTree = "<group>"; };
+               084C325D0FE4E5D500117FC9 /* x86enc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = x86enc.h; sourceTree = "<group>"; };
+               089C1667FE841158C02AAC07 /* English */ = {isa = PBXFileReference; fileEncoding = 10; lastKnownFileType = text.plist.strings; name = English; path = English.lproj/InfoPlist.strings; sourceTree = "<group>"; };
+               097729930BCAC60000303091 /* codec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = codec.h; path = ../include/theora/codec.h; sourceTree = SOURCE_ROOT; };
+               097729940BCAC60000303091 /* theoradec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = theoradec.h; path = ../include/theora/theoradec.h; sourceTree = SOURCE_ROOT; };
+               09C8F6430C82FBE500F72188 /* libtheoradec.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libtheoradec.a; sourceTree = BUILT_PRODUCTS_DIR; };
+               32BAE0B70371A74B00C91783 /* Theora_Prefix.pch */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = Theora_Prefix.pch; sourceTree = "<group>"; };
+               37C9B0130EBB831F0046849C /* theoraenc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = theoraenc.h; path = ../include/theora/theoraenc.h; sourceTree = SOURCE_ROOT; };
+               37CA8E380DD747F1005C8CB6 /* internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = internal.h; path = ../lib/internal.h; sourceTree = SOURCE_ROOT; };
+               734A751809D76ADD002D8FAE /* Ogg.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Ogg.framework; path = /Library/Frameworks/Ogg.framework; sourceTree = "<absolute>"; };
+               734A75BE09D76BB9002D8FAE /* theora.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; name = theora.h; path = ../include/theora/theora.h; sourceTree = SOURCE_ROOT; };
+               73514EC70B0C7E5700CEC060 /* cpu.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; name = cpu.h; path = "../lib//cpu.h"; sourceTree = SOURCE_ROOT; };
+               738837100B192732005C7A69 /* libtheoraenc.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libtheoraenc.a; sourceTree = BUILT_PRODUCTS_DIR; };
+               8D07F2C70486CC7A007CD1D0 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist; path = Info.plist; sourceTree = "<group>"; };
+               8D07F2C80486CC7A007CD1D0 /* Theora.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Theora.framework; sourceTree = BUILT_PRODUCTS_DIR; };
+/* End PBXFileReference section */
+
+/* Begin PBXFrameworksBuildPhase section */
+               09C8F6410C82FBE500F72188 /* Frameworks */ = {
+                       isa = PBXFrameworksBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+               7388370E0B192732005C7A69 /* Frameworks */ = {
+                       isa = PBXFrameworksBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+               8D07F2C30486CC7A007CD1D0 /* Frameworks */ = {
+                       isa = PBXFrameworksBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               734A751909D76ADD002D8FAE /* Ogg.framework in Frameworks */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+/* End PBXFrameworksBuildPhase section */
+
+/* Begin PBXGroup section */
+               034768DDFF38A45A11DB9C8B /* Products */ = {
+                       isa = PBXGroup;
+                       children = (
+                               8D07F2C80486CC7A007CD1D0 /* Theora.framework */,
+                               738837100B192732005C7A69 /* libtheoraenc.a */,
+                               09C8F6430C82FBE500F72188 /* libtheoradec.a */,
+                       );
+                       name = Products;
+                       sourceTree = "<group>";
+               };
+               084C31D80FE4E5BD00117FC9 /* lib */ = {
+                       isa = PBXGroup;
+                       children = (
+                               084C32450FE4E5D500117FC9 /* analyze.c */,
+                               084C32460FE4E5D500117FC9 /* encapiwrapper.c */,
+                               084C32470FE4E5D500117FC9 /* encfrag.c */,
+                               084C32480FE4E5D500117FC9 /* encinfo.c */,
+                               084C32490FE4E5D500117FC9 /* encint.h */,
+                               084C324A0FE4E5D500117FC9 /* encode.c */,
+                               084C324B0FE4E5D500117FC9 /* encoder_disabled.c */,
+                               084C324C0FE4E5D500117FC9 /* enquant.c */,
+                               084C324D0FE4E5D500117FC9 /* enquant.h */,
+                               084C324E0FE4E5D500117FC9 /* fdct.c */,
+                               084C324F0FE4E5D500117FC9 /* huffenc.c */,
+                               084C32500FE4E5D500117FC9 /* huffenc.h */,
+                               084C32510FE4E5D500117FC9 /* mathops.c */,
+                               084C32520FE4E5D500117FC9 /* mathops.h */,
+                               084C32530FE4E5D500117FC9 /* mcenc.c */,
+                               084C32540FE4E5D500117FC9 /* modedec.h */,
+                               084C32550FE4E5D500117FC9 /* rate.c */,
+                               084C32560FE4E5D500117FC9 /* tokenize.c */,
+                               084C31D90FE4E5BD00117FC9 /* apiwrapper.c */,
+                               084C31DA0FE4E5BD00117FC9 /* apiwrapper.h */,
+                               084C31DB0FE4E5BD00117FC9 /* bitpack.c */,
+                               084C31DC0FE4E5BD00117FC9 /* bitpack.h */,
+                               084C31DD0FE4E5BD00117FC9 /* dct.h */,
+                               084C31DE0FE4E5BD00117FC9 /* decapiwrapper.c */,
+                               084C31DF0FE4E5BD00117FC9 /* decinfo.c */,
+                               084C31E00FE4E5BD00117FC9 /* decint.h */,
+                               084C31E10FE4E5BD00117FC9 /* decode.c */,
+                               084C31E20FE4E5BD00117FC9 /* dequant.c */,
+                               084C31E30FE4E5BD00117FC9 /* dequant.h */,
+                               084C31E40FE4E5BD00117FC9 /* fragment.c */,
+                               084C31E50FE4E5BD00117FC9 /* huffdec.c */,
+                               084C31E60FE4E5BD00117FC9 /* huffdec.h */,
+                               084C31E70FE4E5BD00117FC9 /* huffman.h */,
+                               084C31E80FE4E5BD00117FC9 /* idct.c */,
+                               084C31E90FE4E5BD00117FC9 /* info.c */,
+                               084C31EA0FE4E5BD00117FC9 /* internal.c */,
+                               084C31EB0FE4E5BD00117FC9 /* ocintrin.h */,
+                               084C31EC0FE4E5BD00117FC9 /* quant.c */,
+                               084C31ED0FE4E5BD00117FC9 /* quant.h */,
+                               084C31EE0FE4E5BD00117FC9 /* state.c */,
+                               084C32570FE4E5D500117FC9 /* x86 */,
+                       );
+                       name = lib;
+                       path = ../lib;
+                       sourceTree = SOURCE_ROOT;
+               };
+               084C32570FE4E5D500117FC9 /* x86 */ = {
+                       isa = PBXGroup;
+                       children = (
+                               084C31F00FE4E5BD00117FC9 /* mmxfrag.c */,
+                               084C31F10FE4E5BD00117FC9 /* mmxfrag.h */,
+                               084C31F20FE4E5BD00117FC9 /* mmxidct.c */,
+                               084C31F30FE4E5BD00117FC9 /* mmxloop.h */,
+                               084C31F40FE4E5BD00117FC9 /* mmxstate.c */,
+                               084C31F50FE4E5BD00117FC9 /* x86int.h */,
+                               084C31F60FE4E5BD00117FC9 /* x86state.c */,
+                               084C32590FE4E5D500117FC9 /* mmxencfrag.c */,
+                               084C325A0FE4E5D500117FC9 /* mmxfdct.c */,
+                               084C325B0FE4E5D500117FC9 /* sse2fdct.c */,
+                               084C325C0FE4E5D500117FC9 /* x86enc.c */,
+                               084C325D0FE4E5D500117FC9 /* x86enc.h */,
+                       );
+                       path = x86;
+                       sourceTree = "<group>";
+               };
+               0867D691FE84028FC02AAC07 /* Theora */ = {
+                       isa = PBXGroup;
+                       children = (
+                               734A75BD09D76B96002D8FAE /* Headers */,
+                               08FB77ACFE841707C02AAC07 /* Source */,
+                               089C1665FE841158C02AAC07 /* Resources */,
+                               0867D69AFE84028FC02AAC07 /* External Frameworks and Libraries */,
+                               034768DDFF38A45A11DB9C8B /* Products */,
+                       );
+                       name = Theora;
+                       sourceTree = "<group>";
+               };
+               0867D69AFE84028FC02AAC07 /* External Frameworks and Libraries */ = {
+                       isa = PBXGroup;
+                       children = (
+                               734A751809D76ADD002D8FAE /* Ogg.framework */,
+                       );
+                       name = "External Frameworks and Libraries";
+                       sourceTree = "<group>";
+               };
+               089C1665FE841158C02AAC07 /* Resources */ = {
+                       isa = PBXGroup;
+                       children = (
+                               8D07F2C70486CC7A007CD1D0 /* Info.plist */,
+                               089C1666FE841158C02AAC07 /* InfoPlist.strings */,
+                       );
+                       name = Resources;
+                       sourceTree = "<group>";
+               };
+               08FB77ACFE841707C02AAC07 /* Source */ = {
+                       isa = PBXGroup;
+                       children = (
+                               084C31D80FE4E5BD00117FC9 /* lib */,
+                               0844FE7E0FCCC99A004A99B0 /* cpu.c */,
+                               73514EC70B0C7E5700CEC060 /* cpu.h */,
+                               37CA8E380DD747F1005C8CB6 /* internal.h */,
+                               32BAE0B70371A74B00C91783 /* Theora_Prefix.pch */,
+                       );
+                       name = Source;
+                       sourceTree = "<group>";
+               };
+               734A75BD09D76B96002D8FAE /* Headers */ = {
+                       isa = PBXGroup;
+                       children = (
+                               37C9B0130EBB831F0046849C /* theoraenc.h */,
+                               097729940BCAC60000303091 /* theoradec.h */,
+                               097729930BCAC60000303091 /* codec.h */,
+                               734A75BE09D76BB9002D8FAE /* theora.h */,
+                       );
+                       name = Headers;
+                       sourceTree = "<group>";
+               };
+/* End PBXGroup section */
+
+/* Begin PBXHeadersBuildPhase section */
+               09C8F63F0C82FBE500F72188 /* Headers */ = {
+                       isa = PBXHeadersBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               084C32220FE4E5BD00117FC9 /* apiwrapper.h in Headers */,
+                               084C32240FE4E5BD00117FC9 /* bitpack.h in Headers */,
+                               084C32250FE4E5BD00117FC9 /* dct.h in Headers */,
+                               084C32280FE4E5BD00117FC9 /* decint.h in Headers */,
+                               084C322B0FE4E5BD00117FC9 /* dequant.h in Headers */,
+                               084C322E0FE4E5BD00117FC9 /* huffdec.h in Headers */,
+                               084C322F0FE4E5BD00117FC9 /* huffman.h in Headers */,
+                               084C32330FE4E5BD00117FC9 /* ocintrin.h in Headers */,
+                               084C32350FE4E5BD00117FC9 /* quant.h in Headers */,
+                               084C32380FE4E5BD00117FC9 /* mmxfrag.h in Headers */,
+                               084C323A0FE4E5BD00117FC9 /* mmxloop.h in Headers */,
+                               084C323C0FE4E5BD00117FC9 /* x86int.h in Headers */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+               7388370C0B192732005C7A69 /* Headers */ = {
+                       isa = PBXHeadersBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               084C32810FE4E5D500117FC9 /* encint.h in Headers */,
+                               084C32850FE4E5D500117FC9 /* enquant.h in Headers */,
+                               084C32880FE4E5D500117FC9 /* huffenc.h in Headers */,
+                               084C328A0FE4E5D500117FC9 /* mathops.h in Headers */,
+                               084C328C0FE4E5D500117FC9 /* modedec.h in Headers */,
+                               084C32940FE4E5D500117FC9 /* x86enc.h in Headers */,
+                               084C32A80FE4E7FF00117FC9 /* apiwrapper.h in Headers */,
+                               084C32A90FE4E82500117FC9 /* dct.h in Headers */,
+                               084C32AD0FE4E84800117FC9 /* quant.h in Headers */,
+                               084C32AF0FE4E84C00117FC9 /* ocintrin.h in Headers */,
+                               084C32B10FE4E85300117FC9 /* x86int.h in Headers */,
+                               084C32B50FE4E86B00117FC9 /* mmxfrag.h in Headers */,
+                               084C32B70FE4E88300117FC9 /* mmxloop.h in Headers */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+               8D07F2BD0486CC7A007CD1D0 /* Headers */ = {
+                       isa = PBXHeadersBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               8D07F2BE0486CC7A007CD1D0 /* Theora_Prefix.pch in Headers */,
+                               734A75BF09D76BB9002D8FAE /* theora.h in Headers */,
+                               73514EC90B0C7E5700CEC060 /* cpu.h in Headers */,
+                               097729950BCAC60000303091 /* codec.h in Headers */,
+                               097729960BCAC60000303091 /* theoradec.h in Headers */,
+                               37CA8E390DD747F1005C8CB6 /* internal.h in Headers */,
+                               37C9B0140EBB831F0046849C /* theoraenc.h in Headers */,
+                               084C31FF0FE4E5BD00117FC9 /* apiwrapper.h in Headers */,
+                               084C32010FE4E5BD00117FC9 /* bitpack.h in Headers */,
+                               084C32020FE4E5BD00117FC9 /* dct.h in Headers */,
+                               084C32050FE4E5BD00117FC9 /* decint.h in Headers */,
+                               084C32080FE4E5BD00117FC9 /* dequant.h in Headers */,
+                               084C320B0FE4E5BD00117FC9 /* huffdec.h in Headers */,
+                               084C320C0FE4E5BD00117FC9 /* huffman.h in Headers */,
+                               084C32100FE4E5BD00117FC9 /* ocintrin.h in Headers */,
+                               084C32120FE4E5BD00117FC9 /* quant.h in Headers */,
+                               084C32150FE4E5BD00117FC9 /* mmxfrag.h in Headers */,
+                               084C32170FE4E5BD00117FC9 /* mmxloop.h in Headers */,
+                               084C32190FE4E5BD00117FC9 /* x86int.h in Headers */,
+                               084C32660FE4E5D500117FC9 /* encint.h in Headers */,
+                               084C326A0FE4E5D500117FC9 /* enquant.h in Headers */,
+                               084C326D0FE4E5D500117FC9 /* huffenc.h in Headers */,
+                               084C326F0FE4E5D500117FC9 /* mathops.h in Headers */,
+                               084C32710FE4E5D500117FC9 /* modedec.h in Headers */,
+                               084C32790FE4E5D500117FC9 /* x86enc.h in Headers */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+/* End PBXHeadersBuildPhase section */
+
+/* Begin PBXNativeTarget section */
+               09C8F6420C82FBE500F72188 /* libtheoradec (static) */ = {
+                       isa = PBXNativeTarget;
+                       buildConfigurationList = 09C8F6610C82FC3E00F72188 /* Build configuration list for PBXNativeTarget "libtheoradec (static)" */;
+                       buildPhases = (
+                               09C8F63F0C82FBE500F72188 /* Headers */,
+                               09C8F6400C82FBE500F72188 /* Sources */,
+                               09C8F6410C82FBE500F72188 /* Frameworks */,
+                       );
+                       buildRules = (
+                       );
+                       dependencies = (
+                       );
+                       name = "libtheoradec (static)";
+                       productName = libtheoradec;
+                       productReference = 09C8F6430C82FBE500F72188 /* libtheoradec.a */;
+                       productType = "com.apple.product-type.library.static";
+               };
+               7388370F0B192732005C7A69 /* libtheoraenc (static) */ = {
+                       isa = PBXNativeTarget;
+                       buildConfigurationList = 738837110B19277F005C7A69 /* Build configuration list for PBXNativeTarget "libtheoraenc (static)" */;
+                       buildPhases = (
+                               7388370C0B192732005C7A69 /* Headers */,
+                               7388370D0B192732005C7A69 /* Sources */,
+                               7388370E0B192732005C7A69 /* Frameworks */,
+                       );
+                       buildRules = (
+                       );
+                       dependencies = (
+                       );
+                       name = "libtheoraenc (static)";
+                       productName = theora;
+                       productReference = 738837100B192732005C7A69 /* libtheoraenc.a */;
+                       productType = "com.apple.product-type.library.static";
+               };
+               8D07F2BC0486CC7A007CD1D0 /* Theora */ = {
+                       isa = PBXNativeTarget;
+                       buildConfigurationList = 4FADC24208B4156D00ABE55E /* Build configuration list for PBXNativeTarget "Theora" */;
+                       buildPhases = (
+                               8D07F2BD0486CC7A007CD1D0 /* Headers */,
+                               8D07F2BF0486CC7A007CD1D0 /* Resources */,
+                               8D07F2C10486CC7A007CD1D0 /* Sources */,
+                               8D07F2C30486CC7A007CD1D0 /* Frameworks */,
+                               8D07F2C50486CC7A007CD1D0 /* Rez */,
+                       );
+                       buildRules = (
+                       );
+                       dependencies = (
+                       );
+                       name = Theora;
+                       productInstallPath = "$(HOME)/Library/Frameworks";
+                       productName = Theora;
+                       productReference = 8D07F2C80486CC7A007CD1D0 /* Theora.framework */;
+                       productType = "com.apple.product-type.framework";
+               };
+/* End PBXNativeTarget section */
+
+/* Begin PBXProject section */
+               0867D690FE84028FC02AAC07 /* Project object */ = {
+                       isa = PBXProject;
+                       buildConfigurationList = 4FADC24608B4156D00ABE55E /* Build configuration list for PBXProject "Theora" */;
+                       compatibilityVersion = "Xcode 2.4";
+                       hasScannedForEncodings = 1;
+                       mainGroup = 0867D691FE84028FC02AAC07 /* Theora */;
+                       productRefGroup = 034768DDFF38A45A11DB9C8B /* Products */;
+                       projectDirPath = "";
+                       projectRoot = ..;
+                       targets = (
+                               8D07F2BC0486CC7A007CD1D0 /* Theora */,
+                               7388370F0B192732005C7A69 /* libtheoraenc (static) */,
+                               09C8F6420C82FBE500F72188 /* libtheoradec (static) */,
+                       );
+               };
+/* End PBXProject section */
+
+/* Begin PBXResourcesBuildPhase section */
+               8D07F2BF0486CC7A007CD1D0 /* Resources */ = {
+                       isa = PBXResourcesBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               8D07F2C00486CC7A007CD1D0 /* InfoPlist.strings in Resources */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+/* End PBXResourcesBuildPhase section */
+
+/* Begin PBXRezBuildPhase section */
+               8D07F2C50486CC7A007CD1D0 /* Rez */ = {
+                       isa = PBXRezBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+/* End PBXRezBuildPhase section */
+
+/* Begin PBXSourcesBuildPhase section */
+               09C8F6400C82FBE500F72188 /* Sources */ = {
+                       isa = PBXSourcesBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               084C32210FE4E5BD00117FC9 /* apiwrapper.c in Sources */,
+                               084C32230FE4E5BD00117FC9 /* bitpack.c in Sources */,
+                               084C32260FE4E5BD00117FC9 /* decapiwrapper.c in Sources */,
+                               084C32270FE4E5BD00117FC9 /* decinfo.c in Sources */,
+                               084C32290FE4E5BD00117FC9 /* decode.c in Sources */,
+                               084C322A0FE4E5BD00117FC9 /* dequant.c in Sources */,
+                               084C322C0FE4E5BD00117FC9 /* fragment.c in Sources */,
+                               084C322D0FE4E5BD00117FC9 /* huffdec.c in Sources */,
+                               084C32300FE4E5BD00117FC9 /* idct.c in Sources */,
+                               084C32310FE4E5BD00117FC9 /* info.c in Sources */,
+                               084C32320FE4E5BD00117FC9 /* internal.c in Sources */,
+                               084C32340FE4E5BD00117FC9 /* quant.c in Sources */,
+                               084C32360FE4E5BD00117FC9 /* state.c in Sources */,
+                               084C32370FE4E5BD00117FC9 /* mmxfrag.c in Sources */,
+                               084C32390FE4E5BD00117FC9 /* mmxidct.c in Sources */,
+                               084C323B0FE4E5BD00117FC9 /* mmxstate.c in Sources */,
+                               084C323D0FE4E5BD00117FC9 /* x86state.c in Sources */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+               7388370D0B192732005C7A69 /* Sources */ = {
+                       isa = PBXSourcesBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               084C327D0FE4E5D500117FC9 /* analyze.c in Sources */,
+                               084C327E0FE4E5D500117FC9 /* encapiwrapper.c in Sources */,
+                               084C327F0FE4E5D500117FC9 /* encfrag.c in Sources */,
+                               084C32800FE4E5D500117FC9 /* encinfo.c in Sources */,
+                               084C32820FE4E5D500117FC9 /* encode.c in Sources */,
+                               084C32840FE4E5D500117FC9 /* enquant.c in Sources */,
+                               084C32860FE4E5D500117FC9 /* fdct.c in Sources */,
+                               084C32870FE4E5D500117FC9 /* huffenc.c in Sources */,
+                               084C32890FE4E5D500117FC9 /* mathops.c in Sources */,
+                               084C328B0FE4E5D500117FC9 /* mcenc.c in Sources */,
+                               084C328D0FE4E5D500117FC9 /* rate.c in Sources */,
+                               084C328E0FE4E5D500117FC9 /* tokenize.c in Sources */,
+                               084C32900FE4E5D500117FC9 /* mmxencfrag.c in Sources */,
+                               084C32910FE4E5D500117FC9 /* mmxfdct.c in Sources */,
+                               084C32920FE4E5D500117FC9 /* sse2fdct.c in Sources */,
+                               084C32930FE4E5D500117FC9 /* x86enc.c in Sources */,
+                               084C32A70FE4E7FE00117FC9 /* apiwrapper.c in Sources */,
+                               084C32AA0FE4E83100117FC9 /* idct.c in Sources */,
+                               084C32AB0FE4E83300117FC9 /* internal.c in Sources */,
+                               084C32AC0FE4E83600117FC9 /* fragment.c in Sources */,
+                               084C32AE0FE4E84A00117FC9 /* quant.c in Sources */,
+                               084C32B00FE4E84F00117FC9 /* state.c in Sources */,
+                               084C32B20FE4E85300117FC9 /* x86state.c in Sources */,
+                               084C32B30FE4E85D00117FC9 /* mmxstate.c in Sources */,
+                               084C32B40FE4E86A00117FC9 /* mmxfrag.c in Sources */,
+                               084C32B60FE4E87200117FC9 /* mmxidct.c in Sources */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+               8D07F2C10486CC7A007CD1D0 /* Sources */ = {
+                       isa = PBXSourcesBuildPhase;
+                       buildActionMask = 2147483647;
+                       files = (
+                               084C31FE0FE4E5BD00117FC9 /* apiwrapper.c in Sources */,
+                               084C32000FE4E5BD00117FC9 /* bitpack.c in Sources */,
+                               084C32030FE4E5BD00117FC9 /* decapiwrapper.c in Sources */,
+                               084C32040FE4E5BD00117FC9 /* decinfo.c in Sources */,
+                               084C32060FE4E5BD00117FC9 /* decode.c in Sources */,
+                               084C32070FE4E5BD00117FC9 /* dequant.c in Sources */,
+                               084C32090FE4E5BD00117FC9 /* fragment.c in Sources */,
+                               084C320A0FE4E5BD00117FC9 /* huffdec.c in Sources */,
+                               084C320D0FE4E5BD00117FC9 /* idct.c in Sources */,
+                               084C320E0FE4E5BD00117FC9 /* info.c in Sources */,
+                               084C320F0FE4E5BD00117FC9 /* internal.c in Sources */,
+                               084C32110FE4E5BD00117FC9 /* quant.c in Sources */,
+                               084C32130FE4E5BD00117FC9 /* state.c in Sources */,
+                               084C32140FE4E5BD00117FC9 /* mmxfrag.c in Sources */,
+                               084C32160FE4E5BD00117FC9 /* mmxidct.c in Sources */,
+                               084C32180FE4E5BD00117FC9 /* mmxstate.c in Sources */,
+                               084C321A0FE4E5BD00117FC9 /* x86state.c in Sources */,
+                               084C32620FE4E5D500117FC9 /* analyze.c in Sources */,
+                               084C32630FE4E5D500117FC9 /* encapiwrapper.c in Sources */,
+                               084C32640FE4E5D500117FC9 /* encfrag.c in Sources */,
+                               084C32650FE4E5D500117FC9 /* encinfo.c in Sources */,
+                               084C32670FE4E5D500117FC9 /* encode.c in Sources */,
+                               084C32690FE4E5D500117FC9 /* enquant.c in Sources */,
+                               084C326B0FE4E5D500117FC9 /* fdct.c in Sources */,
+                               084C326C0FE4E5D500117FC9 /* huffenc.c in Sources */,
+                               084C326E0FE4E5D500117FC9 /* mathops.c in Sources */,
+                               084C32700FE4E5D500117FC9 /* mcenc.c in Sources */,
+                               084C32720FE4E5D500117FC9 /* rate.c in Sources */,
+                               084C32730FE4E5D500117FC9 /* tokenize.c in Sources */,
+                               084C32750FE4E5D500117FC9 /* mmxencfrag.c in Sources */,
+                               084C32760FE4E5D500117FC9 /* mmxfdct.c in Sources */,
+                               084C32770FE4E5D500117FC9 /* sse2fdct.c in Sources */,
+                               084C32780FE4E5D500117FC9 /* x86enc.c in Sources */,
+                       );
+                       runOnlyForDeploymentPostprocessing = 0;
+               };
+/* End PBXSourcesBuildPhase section */
+
+/* Begin PBXVariantGroup section */
+               089C1666FE841158C02AAC07 /* InfoPlist.strings */ = {
+                       isa = PBXVariantGroup;
+                       children = (
+                               089C1667FE841158C02AAC07 /* English */,
+                       );
+                       name = InfoPlist.strings;
+                       sourceTree = "<group>";
+               };
+/* End PBXVariantGroup section */
+
+/* Begin XCBuildConfiguration section */
+               09C8F6620C82FC3E00F72188 /* Debug */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               COPY_PHASE_STRIP = NO;
+                               GCC_DYNAMIC_NO_PIC = NO;
+                               GCC_ENABLE_FIX_AND_CONTINUE = YES;
+                               GCC_GENERATE_DEBUGGING_SYMBOLS = YES;
+                               GCC_OPTIMIZATION_LEVEL = 0;
+                               HEADER_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       ../../ogg/include,
+                               );
+                               INSTALL_PATH = /usr/local/lib;
+                               PREBINDING = NO;
+                               PRODUCT_NAME = theoradec;
+                               ZERO_LINK = YES;
+                       };
+                       name = Debug;
+               };
+               09C8F6630C82FC3E00F72188 /* Release */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               COPY_PHASE_STRIP = YES;
+                               GCC_ENABLE_FIX_AND_CONTINUE = NO;
+                               GCC_GENERATE_DEBUGGING_SYMBOLS = NO;
+                               HEADER_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       ../../ogg/include,
+                               );
+                               INSTALL_PATH = /usr/local/lib;
+                               PREBINDING = NO;
+                               PRODUCT_NAME = theoradec;
+                               ZERO_LINK = NO;
+                       };
+                       name = Release;
+               };
+               4FADC24308B4156D00ABE55E /* Debug */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               COPY_PHASE_STRIP = NO;
+                               DYLIB_COMPATIBILITY_VERSION = 1;
+                               DYLIB_CURRENT_VERSION = 1;
+                               FRAMEWORK_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       /Library/Frameworks,
+                               );
+                               FRAMEWORK_VERSION = A;
+                               GCC_ENABLE_FIX_AND_CONTINUE = YES;
+                               GCC_OPTIMIZATION_LEVEL = 0;
+                               GCC_PRECOMPILE_PREFIX_HEADER = YES;
+                               GCC_PREFIX_HEADER = Theora_Prefix.pch;
+                               INFOPLIST_FILE = Info.plist;
+                               INSTALL_PATH = /Library/Frameworks;
+                               LIBRARY_STYLE = DYNAMIC;
+                               MACH_O_TYPE = mh_dylib;
+                               OTHER_LDFLAGS_i386 = "-Wl,-read_only_relocs,suppress";
+                               PRODUCT_NAME = Theora;
+                               WRAPPER_EXTENSION = framework;
+                               ZERO_LINK = YES;
+                       };
+                       name = Debug;
+               };
+               4FADC24408B4156D00ABE55E /* Release */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               DYLIB_COMPATIBILITY_VERSION = 1;
+                               DYLIB_CURRENT_VERSION = 1;
+                               FRAMEWORK_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       /Library/Frameworks,
+                               );
+                               FRAMEWORK_VERSION = A;
+                               GCC_PRECOMPILE_PREFIX_HEADER = YES;
+                               GCC_PREFIX_HEADER = Theora_Prefix.pch;
+                               INFOPLIST_FILE = Info.plist;
+                               INSTALL_PATH = /Library/Frameworks;
+                               LIBRARY_STYLE = DYNAMIC;
+                               MACH_O_TYPE = mh_dylib;
+                               OTHER_LDFLAGS_i386 = "-Wl,-read_only_relocs,suppress";
+                               PREBINDING = YES;
+                               PRODUCT_NAME = Theora;
+                               WRAPPER_EXTENSION = framework;
+                       };
+                       name = Release;
+               };
+               4FADC24708B4156D00ABE55E /* Debug */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               GCC_OPTIMIZATION_LEVEL = 0;
+                               GCC_PREPROCESSOR_DEFINITIONS = (
+                                       "$(GCC_PREPROCESSOR_DEFINITIONS)",
+                                       __MACOSX__,
+                               );
+                               GCC_WARN_ABOUT_RETURN_TYPE = YES;
+                               GCC_WARN_UNUSED_VARIABLE = YES;
+                               HEADER_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       ../include,
+                                       "../lib/**",
+                               );
+                               OTHER_CFLAGS = "";
+                               PREBINDING = NO;
+                               SDKROOT = /Developer/SDKs/MacOSX10.4u.sdk;
+                       };
+                       name = Debug;
+               };
+               4FADC24808B4156D00ABE55E /* Release */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               ARCHS = "$(ARCHS_STANDARD_32_BIT_PRE_XCODE_3_1)";
+                               ARCHS_STANDARD_32_BIT_PRE_XCODE_3_1 = "ppc i386";
+                               GCC_OPTIMIZATION_LEVEL = 3;
+                               GCC_PREPROCESSOR_DEFINITIONS = (
+                                       "$(GCC_PREPROCESSOR_DEFINITIONS)",
+                                       __MACOSX__,
+                               );
+                               GCC_WARN_ABOUT_RETURN_TYPE = YES;
+                               GCC_WARN_UNUSED_VARIABLE = YES;
+                               HEADER_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       ../include,
+                                       "../lib/**",
+                               );
+                               OTHER_CFLAGS = (
+                                       "$(OTHER_CFLAGS)",
+                                       "-falign-loops=16",
+                                       "-fforce-addr",
+                                       "-fomit-frame-pointer",
+                                       "-finline-functions",
+                                       "-funroll-loops",
+                               );
+                               PER_ARCH_CFLAGS_i386 = "-DOC_X86_ASM";
+                               PREBINDING = NO;
+                               SDKROOT = /Developer/SDKs/MacOSX10.4u.sdk;
+                       };
+                       name = Release;
+               };
+               738837120B19277F005C7A69 /* Debug */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               COPY_PHASE_STRIP = NO;
+                               GCC_DYNAMIC_NO_PIC = NO;
+                               GCC_ENABLE_FIX_AND_CONTINUE = YES;
+                               GCC_GENERATE_DEBUGGING_SYMBOLS = YES;
+                               GCC_OPTIMIZATION_LEVEL = 0;
+                               HEADER_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       ../../ogg/include,
+                               );
+                               INSTALL_PATH = /usr/local/lib;
+                               PREBINDING = NO;
+                               PRODUCT_NAME = theoraenc;
+                               ZERO_LINK = YES;
+                       };
+                       name = Debug;
+               };
+               738837130B19277F005C7A69 /* Release */ = {
+                       isa = XCBuildConfiguration;
+                       buildSettings = {
+                               COPY_PHASE_STRIP = YES;
+                               GCC_ENABLE_FIX_AND_CONTINUE = NO;
+                               GCC_GENERATE_DEBUGGING_SYMBOLS = NO;
+                               HEADER_SEARCH_PATHS = (
+                                       "$(inherited)",
+                                       ../../ogg/include,
+                               );
+                               INSTALL_PATH = /usr/local/lib;
+                               PREBINDING = NO;
+                               PRODUCT_NAME = theoraenc;
+                               ZERO_LINK = NO;
+                       };
+                       name = Release;
+               };
+/* End XCBuildConfiguration section */
+
+/* Begin XCConfigurationList section */
+               09C8F6610C82FC3E00F72188 /* Build configuration list for PBXNativeTarget "libtheoradec (static)" */ = {
+                       isa = XCConfigurationList;
+                       buildConfigurations = (
+                               09C8F6620C82FC3E00F72188 /* Debug */,
+                               09C8F6630C82FC3E00F72188 /* Release */,
+                       );
+                       defaultConfigurationIsVisible = 0;
+                       defaultConfigurationName = Release;
+               };
+               4FADC24208B4156D00ABE55E /* Build configuration list for PBXNativeTarget "Theora" */ = {
+                       isa = XCConfigurationList;
+                       buildConfigurations = (
+                               4FADC24308B4156D00ABE55E /* Debug */,
+                               4FADC24408B4156D00ABE55E /* Release */,
+                       );
+                       defaultConfigurationIsVisible = 0;
+                       defaultConfigurationName = Release;
+               };
+               4FADC24608B4156D00ABE55E /* Build configuration list for PBXProject "Theora" */ = {
+                       isa = XCConfigurationList;
+                       buildConfigurations = (
+                               4FADC24708B4156D00ABE55E /* Debug */,
+                               4FADC24808B4156D00ABE55E /* Release */,
+                       );
+                       defaultConfigurationIsVisible = 0;
+                       defaultConfigurationName = Release;
+               };
+               738837110B19277F005C7A69 /* Build configuration list for PBXNativeTarget "libtheoraenc (static)" */ = {
+                       isa = XCConfigurationList;
+                       buildConfigurations = (
+                               738837120B19277F005C7A69 /* Debug */,
+                               738837130B19277F005C7A69 /* Release */,
+                       );
+                       defaultConfigurationIsVisible = 0;
+                       defaultConfigurationName = Release;
+               };
+/* End XCConfigurationList section */
+       };
+       rootObject = 0867D690FE84028FC02AAC07 /* Project object */;
+}
diff --git a/macosx/Theora_Prefix.pch b/macosx/Theora_Prefix.pch
new file mode 100644 (file)
index 0000000..ddae807
--- /dev/null
@@ -0,0 +1,5 @@
+//
+// Prefix header for all source files of the 'Theora' target in the 'Theora' project.
+//
+
+#include <Carbon/Carbon.h>
diff --git a/missing b/missing
new file mode 100755 (executable)
index 0000000..6a37006
--- /dev/null
+++ b/missing
@@ -0,0 +1,336 @@
+#! /bin/sh
+# Common stub for a few missing GNU programs while installing.
+# Copyright (C) 1996, 1997, 1999, 2000, 2002 Free Software Foundation, Inc.
+# Originally by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
+
+# 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, 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., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program that contains a
+# configuration script generated by Autoconf, you may include it under
+# the same distribution terms that you use for the rest of that program.
+
+if test $# -eq 0; then
+  echo 1>&2 "Try \`$0 --help' for more information"
+  exit 1
+fi
+
+run=:
+
+# In the cases where this matters, `missing' is being run in the
+# srcdir already.
+if test -f configure.ac; then
+  configure_ac=configure.ac
+else
+  configure_ac=configure.in
+fi
+
+case "$1" in
+--run)
+  # Try to run requested program, and just exit if it succeeds.
+  run=
+  shift
+  "$@" && exit 0
+  ;;
+esac
+
+# If it does not exist, or fails to run (possibly an outdated version),
+# try to emulate it.
+case "$1" in
+
+  -h|--h|--he|--hel|--help)
+    echo "\
+$0 [OPTION]... PROGRAM [ARGUMENT]...
+
+Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
+error status if there is no known handling for PROGRAM.
+
+Options:
+  -h, --help      display this help and exit
+  -v, --version   output version information and exit
+  --run           try to run the given command, and emulate it if it fails
+
+Supported PROGRAM values:
+  aclocal      touch file \`aclocal.m4'
+  autoconf     touch file \`configure'
+  autoheader   touch file \`config.h.in'
+  automake     touch all \`Makefile.in' files
+  bison        create \`y.tab.[ch]', if possible, from existing .[ch]
+  flex         create \`lex.yy.c', if possible, from existing .c
+  help2man     touch the output file
+  lex          create \`lex.yy.c', if possible, from existing .c
+  makeinfo     touch the output file
+  tar          try tar, gnutar, gtar, then tar without non-portable flags
+  yacc         create \`y.tab.[ch]', if possible, from existing .[ch]"
+    ;;
+
+  -v|--v|--ve|--ver|--vers|--versi|--versio|--version)
+    echo "missing 0.4 - GNU automake"
+    ;;
+
+  -*)
+    echo 1>&2 "$0: Unknown \`$1' option"
+    echo 1>&2 "Try \`$0 --help' for more information"
+    exit 1
+    ;;
+
+  aclocal*)
+    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
+       # We have it, but it failed.
+       exit 1
+    fi
+
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+         you modified \`acinclude.m4' or \`${configure_ac}'.  You might want
+         to install the \`Automake' and \`Perl' packages.  Grab them from
+         any GNU archive site."
+    touch aclocal.m4
+    ;;
+
+  autoconf)
+    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
+       # We have it, but it failed.
+       exit 1
+    fi
+
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+         you modified \`${configure_ac}'.  You might want to install the
+         \`Autoconf' and \`GNU m4' packages.  Grab them from any GNU
+         archive site."
+    touch configure
+    ;;
+
+  autoheader)
+    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
+       # We have it, but it failed.
+       exit 1
+    fi
+
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+         you modified \`acconfig.h' or \`${configure_ac}'.  You might want
+         to install the \`Autoconf' and \`GNU m4' packages.  Grab them
+         from any GNU archive site."
+    files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
+    test -z "$files" && files="config.h"
+    touch_files=
+    for f in $files; do
+      case "$f" in
+      *:*) touch_files="$touch_files "`echo "$f" |
+                                      sed -e 's/^[^:]*://' -e 's/:.*//'`;;
+      *) touch_files="$touch_files $f.in";;
+      esac
+    done
+    touch $touch_files
+    ;;
+
+  automake*)
+    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
+       # We have it, but it failed.
+       exit 1
+    fi
+
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+         you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
+         You might want to install the \`Automake' and \`Perl' packages.
+         Grab them from any GNU archive site."
+    find . -type f -name Makefile.am -print |
+          sed 's/\.am$/.in/' |
+          while read f; do touch "$f"; done
+    ;;
+
+  autom4te)
+    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
+       # We have it, but it failed.
+       exit 1
+    fi
+
+    echo 1>&2 "\
+WARNING: \`$1' is needed, and you do not seem to have it handy on your
+         system.  You might have modified some files without having the
+         proper tools for further handling them.
+         You can get \`$1Help2man' as part of \`Autoconf' from any GNU
+         archive site."
+
+    file=`echo "$*" | sed -n 's/.*--output[ =]*\([^ ]*\).*/\1/p'`
+    test -z "$file" && file=`echo "$*" | sed -n 's/.*-o[ ]*\([^ ]*\).*/\1/p'`
+    if test -f "$file"; then
+       touch $file
+    else
+       test -z "$file" || exec >$file
+       echo "#! /bin/sh"
+       echo "# Created by GNU Automake missing as a replacement of"
+       echo "#  $ $@"
+       echo "exit 0"
+       chmod +x $file
+       exit 1
+    fi
+    ;;
+
+  bison|yacc)
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+         you modified a \`.y' file.  You may need the \`Bison' package
+         in order for those modifications to take effect.  You can get
+         \`Bison' from any GNU archive site."
+    rm -f y.tab.c y.tab.h
+    if [ $# -ne 1 ]; then
+        eval LASTARG="\${$#}"
+       case "$LASTARG" in
+       *.y)
+           SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
+           if [ -f "$SRCFILE" ]; then
+                cp "$SRCFILE" y.tab.c
+           fi
+           SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
+           if [ -f "$SRCFILE" ]; then
+                cp "$SRCFILE" y.tab.h
+           fi
+         ;;
+       esac
+    fi
+    if [ ! -f y.tab.h ]; then
+       echo >y.tab.h
+    fi
+    if [ ! -f y.tab.c ]; then
+       echo 'main() { return 0; }' >y.tab.c
+    fi
+    ;;
+
+  lex|flex)
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+         you modified a \`.l' file.  You may need the \`Flex' package
+         in order for those modifications to take effect.  You can get
+         \`Flex' from any GNU archive site."
+    rm -f lex.yy.c
+    if [ $# -ne 1 ]; then
+        eval LASTARG="\${$#}"
+       case "$LASTARG" in
+       *.l)
+           SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
+           if [ -f "$SRCFILE" ]; then
+                cp "$SRCFILE" lex.yy.c
+           fi
+         ;;
+       esac
+    fi
+    if [ ! -f lex.yy.c ]; then
+       echo 'main() { return 0; }' >lex.yy.c
+    fi
+    ;;
+
+  help2man)
+    if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
+       # We have it, but it failed.
+       exit 1
+    fi
+
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+        you modified a dependency of a manual page.  You may need the
+        \`Help2man' package in order for those modifications to take
+        effect.  You can get \`Help2man' from any GNU archive site."
+
+    file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
+    if test -z "$file"; then
+       file=`echo "$*" | sed -n 's/.*--output=\([^ ]*\).*/\1/p'`
+    fi
+    if [ -f "$file" ]; then
+       touch $file
+    else
+       test -z "$file" || exec >$file
+       echo ".ab help2man is required to generate this page"
+       exit 1
+    fi
+    ;;
+
+  makeinfo)
+    if test -z "$run" && (makeinfo --version) > /dev/null 2>&1; then
+       # We have makeinfo, but it failed.
+       exit 1
+    fi
+
+    echo 1>&2 "\
+WARNING: \`$1' is missing on your system.  You should only need it if
+         you modified a \`.texi' or \`.texinfo' file, or any other file
+         indirectly affecting the aspect of the manual.  The spurious
+         call might also be the consequence of using a buggy \`make' (AIX,
+         DU, IRIX).  You might want to install the \`Texinfo' package or
+         the \`GNU make' package.  Grab either from any GNU archive site."
+    file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
+    if test -z "$file"; then
+      file=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
+      file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $file`
+    fi
+    touch $file
+    ;;
+
+  tar)
+    shift
+    if test -n "$run"; then
+      echo 1>&2 "ERROR: \`tar' requires --run"
+      exit 1
+    fi
+
+    # We have already tried tar in the generic part.
+    # Look for gnutar/gtar before invocation to avoid ugly error
+    # messages.
+    if (gnutar --version > /dev/null 2>&1); then
+       gnutar "$@" && exit 0
+    fi
+    if (gtar --version > /dev/null 2>&1); then
+       gtar "$@" && exit 0
+    fi
+    firstarg="$1"
+    if shift; then
+       case "$firstarg" in
+       *o*)
+           firstarg=`echo "$firstarg" | sed s/o//`
+           tar "$firstarg" "$@" && exit 0
+           ;;
+       esac
+       case "$firstarg" in
+       *h*)
+           firstarg=`echo "$firstarg" | sed s/h//`
+           tar "$firstarg" "$@" && exit 0
+           ;;
+       esac
+    fi
+
+    echo 1>&2 "\
+WARNING: I can't seem to be able to run \`tar' with the given arguments.
+         You may want to install GNU tar or Free paxutils, or check the
+         command line arguments."
+    exit 1
+    ;;
+
+  *)
+    echo 1>&2 "\
+WARNING: \`$1' is needed, and you do not seem to have it handy on your
+         system.  You might have modified some files without having the
+         proper tools for further handling them.  Check the \`README' file,
+         it often tells you about the needed prerequirements for installing
+         this package.  You may also peek at any GNU archive site, in case
+         some other package would contain this missing \`$1' program."
+    exit 1
+    ;;
+esac
+
+exit 0
diff --git a/mkinstalldirs b/mkinstalldirs
new file mode 100755 (executable)
index 0000000..8ab885e
--- /dev/null
@@ -0,0 +1,99 @@
+#! /bin/sh
+# mkinstalldirs --- make directory hierarchy
+# Author: Noah Friedman <friedman@prep.ai.mit.edu>
+# Created: 1993-05-16
+# Public domain
+
+errstatus=0
+dirmode=""
+
+usage="\
+Usage: mkinstalldirs [-h] [--help] [-m mode] dir ..."
+
+# process command line arguments
+while test $# -gt 0 ; do
+   case "${1}" in
+     -h | --help | --h* )                      # -h for help
+       echo "${usage}" 1>&2; exit 0 ;;
+     -m )                                      # -m PERM arg
+       shift
+       test $# -eq 0 && { echo "${usage}" 1>&2; exit 1; }
+       dirmode="${1}"
+       shift ;;
+     -- ) shift; break ;;                      # stop option processing
+     -* ) echo "${usage}" 1>&2; exit 1 ;;      # unknown option
+     * )  break ;;                             # first non-opt arg
+   esac
+done
+
+for file
+do
+  if test -d "$file"; then
+    shift
+  else
+    break
+  fi
+done
+
+case $# in
+0) exit 0 ;;
+esac
+
+case $dirmode in
+'')
+  if mkdir -p -- . 2>/dev/null; then
+    echo "mkdir -p -- $*"
+    exec mkdir -p -- "$@"
+  fi ;;
+*)
+  if mkdir -m "$dirmode" -p -- . 2>/dev/null; then
+    echo "mkdir -m $dirmode -p -- $*"
+    exec mkdir -m "$dirmode" -p -- "$@"
+  fi ;;
+esac
+
+for file
+do
+   set fnord `echo ":$file" | sed -ne 's/^:\//#/;s/^://;s/\// /g;s/^#/\//;p'`
+   shift
+
+   pathcomp=
+   for d
+   do
+     pathcomp="$pathcomp$d"
+     case "$pathcomp" in
+       -* ) pathcomp=./$pathcomp ;;
+     esac
+
+     if test ! -d "$pathcomp"; then
+       echo "mkdir $pathcomp"
+
+       mkdir "$pathcomp" || lasterr=$?
+
+       if test ! -d "$pathcomp"; then
+         errstatus=$lasterr
+       else
+         if test ! -z "$dirmode"; then
+            echo "chmod $dirmode $pathcomp"
+
+            lasterr=""
+            chmod "$dirmode" "$pathcomp" || lasterr=$?
+
+            if test ! -z "$lasterr"; then
+              errstatus=$lasterr
+            fi
+         fi
+       fi
+     fi
+
+     pathcomp="$pathcomp/"
+   done
+done
+
+exit $errstatus
+
+# Local Variables:
+# mode: shell-script
+# sh-indentation: 3
+# End:
+# mkinstalldirs ends here
diff --git a/packaging/libtheora.spec b/packaging/libtheora.spec
new file mode 100644 (file)
index 0000000..d53ca2e
--- /dev/null
@@ -0,0 +1,65 @@
+Name:       libtheora
+Summary:    Theora Video Compression Codec
+Version:    1.1.1
+Release:    1
+Group:      System/Libraries
+License:    BSD
+URL:        http://www.theora.org/
+Source0:    http://downloads.xiph.org/releases/theora/%{name}-%{version}.tar.bz2
+Requires(post):  /sbin/ldconfig
+Requires(postun):  /sbin/ldconfig
+BuildRequires:  pkgconfig(ogg)
+BuildRequires:  pkgconfig(vorbis)
+BuildRequires:  pkgconfig(libpng)
+
+BuildRoot:  %{_tmppath}/%{name}-%{version}-build
+
+%description
+Theora is a free and open video compression format from the Xiph.org Foundation.
+It can be used to distribute film and video online and on disc without the
+licensing and royalty fees or vendor lock-in associated with other formats.
+
+%package devel
+Summary:    Development tools for Theora applications
+Group:      Development/Libraries
+Requires:   %{name} = %{version}-%{release}
+
+%description devel
+Description: Headers for Theora Video Compression Codec
+
+%prep
+%setup -q -n %{name}-%{version}
+
+%build
+
+%configure --disable-static \
+    --enable-shared \
+    --disable-sdltest \
+    --disable-examples
+
+make %{?jobs:-j%jobs}
+
+%install
+rm -rf %{buildroot}
+%make_install
+rm -rf $RPM_BUILD_ROOT%{_docdir}
+
+%clean
+rm -rf %{buildroot}
+
+%post -p /sbin/ldconfig
+
+%postun -p /sbin/ldconfig
+
+%files
+%{_libdir}/libtheora.so.*
+%{_libdir}/libtheoradec.so.*
+%{_libdir}/libtheoraenc.so.*
+
+%files devel
+%{_includedir}/theora
+%{_libdir}/*.so
+%{_libdir}/pkgconfig/theora.pc
+%{_libdir}/pkgconfig/theoraenc.pc
+%{_libdir}/pkgconfig/theoradec.pc
+
diff --git a/symbian/bld.inf b/symbian/bld.inf
new file mode 100644 (file)
index 0000000..56a1514
--- /dev/null
@@ -0,0 +1,35 @@
+/*
+   Copyright (C) 2003 Commonwealth Scientific and Industrial Research
+   Organisation (CSIRO) Australia
+
+   Redistribution and use in source and binary forms, with or without
+   modification, are permitted provided that the following conditions
+   are met:
+
+   - Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+
+   - Redistributions in binary form must reproduce the above copyright
+   notice, this list of conditions and the following disclaimer in the
+   documentation and/or other materials provided with the distribution.
+
+   - Neither the name of CSIRO Australia nor the names of its
+   contributors may be used to endorse or promote products derived from
+   this software without specific prior written permission.
+
+   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
+   PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE ORGANISATION OR
+   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+*/
+
+PRJ_MMPFILES
+
+theora.mmp
diff --git a/symbian/config.h b/symbian/config.h
new file mode 100644 (file)
index 0000000..21f6b87
--- /dev/null
@@ -0,0 +1,57 @@
+/*
+   Copyright (C) 2003 Commonwealth Scientific and Industrial Research
+   Organisation (CSIRO) Australia
+
+   Redistribution and use in source and binary forms, with or without
+   modification, are permitted provided that the following conditions
+   are met:
+
+   - Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+
+   - Redistributions in binary form must reproduce the above copyright
+   notice, this list of conditions and the following disclaimer in the
+   documentation and/or other materials provided with the distribution.
+
+   - Neither the name of CSIRO Australia nor the names of its
+   contributors may be used to endorse or promote products derived from
+   this software without specific prior written permission.
+
+   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
+   PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE ORGANISATION OR
+   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+*/
+
+#ifndef CONFIG_H
+#define CONFIG_H
+
+/* Do not build encoding support */
+
+#define THEORA_SUPPORT_ENCODE 0
+
+/* Do not build floating point code */
+
+#define        THEORA_DISABLE_FLOAT 1
+
+#ifdef __WINS__
+
+/* Disable some warnings */
+
+#pragma warning(disable: 4100) /* unreferenced formal parameter */
+//#pragma warning(disable: 4121) /* alignment of a member was sensitive to packing */
+#pragma warning(disable: 4244) /* conversion from '...' to '...', possible loss of data */
+#pragma warning(disable: 4505) /* unreferenced local function has been removed */
+#pragma warning(disable: 4701) /* local variable may be be used without having been initialized */
+#pragma warning(disable: 4761) /* integral size mismatch in argument: conversion supplied */
+
+#endif
+
+#endif /* ! CONFIG_H */
diff --git a/symbian/theora.mmp b/symbian/theora.mmp
new file mode 100644 (file)
index 0000000..70e0df3
--- /dev/null
@@ -0,0 +1,41 @@
+/*
+   Copyright (C) 2003 Commonwealth Scientific and Industrial Research
+   Organisation (CSIRO) Australia
+
+   Redistribution and use in source and binary forms, with or without
+   modification, are permitted provided that the following conditions
+   are met:
+
+   - Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+
+   - Redistributions in binary form must reproduce the above copyright
+   notice, this list of conditions and the following disclaimer in the
+   documentation and/or other materials provided with the distribution.
+
+   - Neither the name of CSIRO Australia nor the names of its
+   contributors may be used to endorse or promote products derived from
+   this software without specific prior written permission.
+
+   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
+   PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE ORGANISATION OR
+   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+*/
+
+TARGET        theora.lib
+TARGETTYPE    lib
+UID           0
+MACRO         HAVE_CONFIG_H
+SOURCEPATH    ..\lib
+SOURCE        blockmap.c comment.c dct.c dct_decode.c decode.c frarray.c frinit.c huffman.c
+SOURCE        idct.c mcomp.c misc_common.c pb.c pp.c quant.c reconstruct.c scan.c toplevel.c encoder_disabled.c
+USERINCLUDE   .
+SYSTEMINCLUDE \epoc32\include \epoc32\include\libc ..\include ..\..\ogg\include ..\..\ogg\symbian
diff --git a/tests/Makefile.am b/tests/Makefile.am
new file mode 100644 (file)
index 0000000..7c11232
--- /dev/null
@@ -0,0 +1,69 @@
+INCLUDES = -I$(top_srcdir)/include
+
+noinst_HEADERS = tests.h
+
+AM_CFLAGS = $(OGG_CFLAGS)
+
+THEORADIR = ../lib
+THEORA_LIBS = $(THEORADIR)/libtheora.la $(OGG_LIBS)
+THEORADEC_LIBS = $(THEORADIR)/libtheoradec.la $(OGG_LIBS)
+THEORAENC_LIBS = $(THEORADIR)/libtheoraenc.la \
+                $(THEORADIR)/libtheoradec.la $(OGG_LIBS)
+test: check
+
+TESTS_ENVIRONMENT = $(VALGRIND_ENVIRONMENT)
+
+TESTS_DEC = noop_theora \
+       comment comment_theoradec comment_theora
+
+TESTS_ENC = noop noop_theoraenc \
+       granulepos granulepos_theoraenc granulepos_theora
+
+if THEORA_DISABLE_ENCODE
+TESTS = $(TESTS_DEC)
+else
+TESTS = $(TESTS_DEC) $(TESTS_ENC)
+endif
+
+check_PROGRAMS = $(TESTS)
+# dummy call tests for the current api
+noop_SOURCES = noop.c
+noop_LDADD = $(THEORAENC_LIBS)
+noop_CFLAGS = $(OGG_CFLAGS)
+
+# dummy call tests for the pre-1.0 legacy api with current link line
+noop_theoraenc_SOURCES = noop_theora.c
+noop_theoraenc_LDADD = $(THEORAENC_LIBS)
+noop_theoraenc_CFLAGS = $(OGG_CFLAGS)
+
+# dummy call tests for the pre-1.0 legacy api with legacy link line
+noop_theora_SOURCES = noop_theora.c
+noop_theora_LDADD = $(THEORA_LIBS)
+noop_theora_CFLAGS = $(OGG_CFLAGS)
+
+# comment utilities for the current api
+comment_SOURCES = comment.c
+comment_LDADD = $(THEORADEC_LIBS)
+comment_CFLAGS = $(OGG_CFLAGS)
+
+# comment utilities for the legacy api and current lib
+comment_theoradec_SOURCES = comment.c
+comment_theoradec_LDADD = $(THEORADEC_LIBS)
+comment_theoradec_CFLAGS = $(OGG_CFLAGS)
+
+# comment utilities for the legacy api and legacy lib
+comment_theora_SOURCES = comment_theora.c
+comment_theora_LDADD = $(THEORA_LIBS)
+comment_theora_CFLAGS = $(OGG_CFLAGS)
+
+granulepos_SOURCES = granulepos.c
+granulepos_LDADD = $(THEORAENC_LIBS) -lm
+granulepos_CFLAGS = $(OGG_CFLAGS)
+
+granulepos_theoraenc_SOURCES = granulepos_theora.c
+granulepos_theoraenc_LDADD = $(THEORAENC_LIBS) -lm
+granulepos_theoraenc_CFLAGS = $(OGG_CFLAGS)
+
+granulepos_theora_SOURCES = granulepos_theora.c
+granulepos_theora_LDADD = $(THEORA_LIBS) -lm
+granulepos_theora_CFLAGS = $(OGG_CFLAGS)
diff --git a/tests/Makefile.in b/tests/Makefile.in
new file mode 100644 (file)
index 0000000..dc25a71
--- /dev/null
@@ -0,0 +1,787 @@
+# Makefile.in generated by automake 1.6.3 from Makefile.am.
+# @configure_input@
+
+# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002
+# Free Software Foundation, Inc.
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+SHELL = @SHELL@
+
+srcdir = @srcdir@
+top_srcdir = @top_srcdir@
+VPATH = @srcdir@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+
+bindir = @bindir@
+sbindir = @sbindir@
+libexecdir = @libexecdir@
+datadir = @datadir@
+sysconfdir = @sysconfdir@
+sharedstatedir = @sharedstatedir@
+localstatedir = @localstatedir@
+libdir = @libdir@
+infodir = @infodir@
+mandir = @mandir@
+includedir = @includedir@
+oldincludedir = /usr/include
+pkgdatadir = $(datadir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+top_builddir = ..
+
+ACLOCAL = @ACLOCAL@
+AUTOCONF = @AUTOCONF@
+AUTOMAKE = @AUTOMAKE@
+AUTOHEADER = @AUTOHEADER@
+
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+INSTALL = @INSTALL@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_DATA = @INSTALL_DATA@
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = @program_transform_name@
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+host_alias = @host_alias@
+host_triplet = @host@
+
+EXEEXT = @EXEEXT@
+OBJEXT = @OBJEXT@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+ACLOCAL_AMFLAGS = @ACLOCAL_AMFLAGS@
+AMTAR = @AMTAR@
+AR = @AR@
+ARGZ_H = @ARGZ_H@
+AS = @AS@
+AWK = @AWK@
+BUILDABLE_EXAMPLES = @BUILDABLE_EXAMPLES@
+CAIRO_CFLAGS = @CAIRO_CFLAGS@
+CAIRO_LIBS = @CAIRO_LIBS@
+CC = @CC@
+CPP = @CPP@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+DEBUG = @DEBUG@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+F77 = @F77@
+GCJ = @GCJ@
+GCJFLAGS = @GCJFLAGS@
+GETOPT_OBJS = @GETOPT_OBJS@
+GREP = @GREP@
+HAVE_BIBTEX = @HAVE_BIBTEX@
+HAVE_DOXYGEN = @HAVE_DOXYGEN@
+HAVE_PDFLATEX = @HAVE_PDFLATEX@
+HAVE_PKG_CONFIG = @HAVE_PKG_CONFIG@
+HAVE_TRANSFIG = @HAVE_TRANSFIG@
+HAVE_VALGRIND = @HAVE_VALGRIND@
+INCLTDL = @INCLTDL@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+LD = @LD@
+LIBADD_DL = @LIBADD_DL@
+LIBADD_DLD_LINK = @LIBADD_DLD_LINK@
+LIBADD_DLOPEN = @LIBADD_DLOPEN@
+LIBADD_SHL_LOAD = @LIBADD_SHL_LOAD@
+LIBLTDL = @LIBLTDL@
+LIBM = @LIBM@
+LIBTOOL = @LIBTOOL@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTDLDEPS = @LTDLDEPS@
+LTDLINCL = @LTDLINCL@
+LTDLOPEN = @LTDLOPEN@
+LT_CONFIG_H = @LT_CONFIG_H@
+LT_DLLOADERS = @LT_DLLOADERS@
+LT_DLPREOPEN = @LT_DLPREOPEN@
+MAINT = @MAINT@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OGG_CFLAGS = @OGG_CFLAGS@
+OGG_LIBS = @OGG_LIBS@
+OSS_LIBS = @OSS_LIBS@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PKG_CONFIG = @PKG_CONFIG@
+PNG_CFLAGS = @PNG_CFLAGS@
+PNG_LIBS = @PNG_LIBS@
+PROFILE = @PROFILE@
+RANLIB = @RANLIB@
+RC = @RC@
+SDL_CFLAGS = @SDL_CFLAGS@
+SDL_CONFIG = @SDL_CONFIG@
+SDL_LIBS = @SDL_LIBS@
+SED = @SED@
+STRIP = @STRIP@
+THDEC_LIB_AGE = @THDEC_LIB_AGE@
+THDEC_LIB_CURRENT = @THDEC_LIB_CURRENT@
+THDEC_LIB_REVISION = @THDEC_LIB_REVISION@
+THENC_LIB_AGE = @THENC_LIB_AGE@
+THENC_LIB_CURRENT = @THENC_LIB_CURRENT@
+THENC_LIB_REVISION = @THENC_LIB_REVISION@
+THEORADEC_LDFLAGS = @THEORADEC_LDFLAGS@
+THEORAENC_LDFLAGS = @THEORAENC_LDFLAGS@
+THEORA_LDFLAGS = @THEORA_LDFLAGS@
+TH_LIB_AGE = @TH_LIB_AGE@
+TH_LIB_CURRENT = @TH_LIB_CURRENT@
+TH_LIB_REVISION = @TH_LIB_REVISION@
+VALGRIND_ENVIRONMENT = @VALGRIND_ENVIRONMENT@
+VERSION = @VERSION@
+VORBISENC_LIBS = @VORBISENC_LIBS@
+VORBISFILE_LIBS = @VORBISFILE_LIBS@
+VORBIS_CFLAGS = @VORBIS_CFLAGS@
+VORBIS_LIBS = @VORBIS_LIBS@
+am__include = @am__include@
+am__quote = @am__quote@
+install_sh = @install_sh@
+lt_ECHO = @lt_ECHO@
+ltdl_LIBOBJS = @ltdl_LIBOBJS@
+ltdl_LTLIBOBJS = @ltdl_LTLIBOBJS@
+sys_symbol_underscore = @sys_symbol_underscore@
+INCLUDES = -I$(top_srcdir)/include
+
+noinst_HEADERS = tests.h
+
+AM_CFLAGS = $(OGG_CFLAGS)
+
+THEORADIR = ../lib
+THEORA_LIBS = $(THEORADIR)/libtheora.la $(OGG_LIBS)
+THEORADEC_LIBS = $(THEORADIR)/libtheoradec.la $(OGG_LIBS)
+THEORAENC_LIBS = $(THEORADIR)/libtheoraenc.la \
+                $(THEORADIR)/libtheoradec.la $(OGG_LIBS)
+
+
+TESTS_ENVIRONMENT = $(VALGRIND_ENVIRONMENT)
+
+TESTS_DEC = noop_theora \
+       comment comment_theoradec comment_theora
+
+
+TESTS_ENC = noop noop_theoraenc \
+       granulepos granulepos_theoraenc granulepos_theora
+
+
+@THEORA_DISABLE_ENCODE_TRUE@TESTS = $(TESTS_DEC)
+@THEORA_DISABLE_ENCODE_FALSE@TESTS = $(TESTS_DEC) $(TESTS_ENC)
+
+check_PROGRAMS = $(TESTS)
+# dummy call tests for the current api
+noop_SOURCES = noop.c
+noop_LDADD = $(THEORAENC_LIBS)
+noop_CFLAGS = $(OGG_CFLAGS)
+
+# dummy call tests for the pre-1.0 legacy api with current link line
+noop_theoraenc_SOURCES = noop_theora.c
+noop_theoraenc_LDADD = $(THEORAENC_LIBS)
+noop_theoraenc_CFLAGS = $(OGG_CFLAGS)
+
+# dummy call tests for the pre-1.0 legacy api with legacy link line
+noop_theora_SOURCES = noop_theora.c
+noop_theora_LDADD = $(THEORA_LIBS)
+noop_theora_CFLAGS = $(OGG_CFLAGS)
+
+# comment utilities for the current api
+comment_SOURCES = comment.c
+comment_LDADD = $(THEORADEC_LIBS)
+comment_CFLAGS = $(OGG_CFLAGS)
+
+# comment utilities for the legacy api and current lib
+comment_theoradec_SOURCES = comment.c
+comment_theoradec_LDADD = $(THEORADEC_LIBS)
+comment_theoradec_CFLAGS = $(OGG_CFLAGS)
+
+# comment utilities for the legacy api and legacy lib
+comment_theora_SOURCES = comment_theora.c
+comment_theora_LDADD = $(THEORA_LIBS)
+comment_theora_CFLAGS = $(OGG_CFLAGS)
+
+granulepos_SOURCES = granulepos.c
+granulepos_LDADD = $(THEORAENC_LIBS) -lm
+granulepos_CFLAGS = $(OGG_CFLAGS)
+
+granulepos_theoraenc_SOURCES = granulepos_theora.c
+granulepos_theoraenc_LDADD = $(THEORAENC_LIBS) -lm
+granulepos_theoraenc_CFLAGS = $(OGG_CFLAGS)
+
+granulepos_theora_SOURCES = granulepos_theora.c
+granulepos_theora_LDADD = $(THEORA_LIBS) -lm
+granulepos_theora_CFLAGS = $(OGG_CFLAGS)
+subdir = tests
+mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
+CONFIG_HEADER = $(top_builddir)/config.h
+CONFIG_CLEAN_FILES =
+@THEORA_DISABLE_ENCODE_TRUE@check_PROGRAMS = noop_theora$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_TRUE@   comment$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_TRUE@   comment_theoradec$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_TRUE@   comment_theora$(EXEEXT)
+@THEORA_DISABLE_ENCODE_FALSE@check_PROGRAMS = noop_theora$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  comment$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  comment_theoradec$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  comment_theora$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  noop$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  noop_theoraenc$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  granulepos$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  granulepos_theoraenc$(EXEEXT) \
+@THEORA_DISABLE_ENCODE_FALSE@  granulepos_theora$(EXEEXT)
+am_comment_OBJECTS = comment-comment.$(OBJEXT)
+comment_OBJECTS = $(am_comment_OBJECTS)
+comment_DEPENDENCIES = $(THEORADIR)/libtheoradec.la
+comment_LDFLAGS =
+am_comment_theora_OBJECTS = comment_theora-comment_theora.$(OBJEXT)
+comment_theora_OBJECTS = $(am_comment_theora_OBJECTS)
+comment_theora_DEPENDENCIES = $(THEORADIR)/libtheora.la
+comment_theora_LDFLAGS =
+am_comment_theoradec_OBJECTS = comment_theoradec-comment.$(OBJEXT)
+comment_theoradec_OBJECTS = $(am_comment_theoradec_OBJECTS)
+comment_theoradec_DEPENDENCIES = $(THEORADIR)/libtheoradec.la
+comment_theoradec_LDFLAGS =
+am_granulepos_OBJECTS = granulepos-granulepos.$(OBJEXT)
+granulepos_OBJECTS = $(am_granulepos_OBJECTS)
+granulepos_DEPENDENCIES = $(THEORADIR)/libtheoraenc.la \
+       $(THEORADIR)/libtheoradec.la
+granulepos_LDFLAGS =
+am_granulepos_theora_OBJECTS = \
+       granulepos_theora-granulepos_theora.$(OBJEXT)
+granulepos_theora_OBJECTS = $(am_granulepos_theora_OBJECTS)
+granulepos_theora_DEPENDENCIES = $(THEORADIR)/libtheora.la
+granulepos_theora_LDFLAGS =
+am_granulepos_theoraenc_OBJECTS = \
+       granulepos_theoraenc-granulepos_theora.$(OBJEXT)
+granulepos_theoraenc_OBJECTS = $(am_granulepos_theoraenc_OBJECTS)
+granulepos_theoraenc_DEPENDENCIES = $(THEORADIR)/libtheoraenc.la \
+       $(THEORADIR)/libtheoradec.la
+granulepos_theoraenc_LDFLAGS =
+am_noop_OBJECTS = noop-noop.$(OBJEXT)
+noop_OBJECTS = $(am_noop_OBJECTS)
+noop_DEPENDENCIES = $(THEORADIR)/libtheoraenc.la \
+       $(THEORADIR)/libtheoradec.la
+noop_LDFLAGS =
+am_noop_theora_OBJECTS = noop_theora-noop_theora.$(OBJEXT)
+noop_theora_OBJECTS = $(am_noop_theora_OBJECTS)
+noop_theora_DEPENDENCIES = $(THEORADIR)/libtheora.la
+noop_theora_LDFLAGS =
+am_noop_theoraenc_OBJECTS = noop_theoraenc-noop_theora.$(OBJEXT)
+noop_theoraenc_OBJECTS = $(am_noop_theoraenc_OBJECTS)
+noop_theoraenc_DEPENDENCIES = $(THEORADIR)/libtheoraenc.la \
+       $(THEORADIR)/libtheoradec.la
+noop_theoraenc_LDFLAGS =
+
+DEFS = @DEFS@
+DEFAULT_INCLUDES =  -I. -I$(srcdir) -I$(top_builddir)
+CPPFLAGS = @CPPFLAGS@
+LDFLAGS = @LDFLAGS@
+LIBS = @LIBS@
+depcomp = $(SHELL) $(top_srcdir)/depcomp
+am__depfiles_maybe = depfiles
+@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/comment-comment.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/comment_theora-comment_theora.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/comment_theoradec-comment.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/granulepos-granulepos.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/granulepos_theora-granulepos_theora.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/granulepos_theoraenc-granulepos_theora.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/noop-noop.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/noop_theora-noop_theora.Po \
+@AMDEP_TRUE@   ./$(DEPDIR)/noop_theoraenc-noop_theora.Po
+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
+       $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) \
+       $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+CCLD = $(CC)
+LINK = $(LIBTOOL) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+       $(AM_LDFLAGS) $(LDFLAGS) -o $@
+CFLAGS = @CFLAGS@
+DIST_SOURCES = $(comment_SOURCES) $(comment_theora_SOURCES) \
+       $(comment_theoradec_SOURCES) $(granulepos_SOURCES) \
+       $(granulepos_theora_SOURCES) $(granulepos_theoraenc_SOURCES) \
+       $(noop_SOURCES) $(noop_theora_SOURCES) \
+       $(noop_theoraenc_SOURCES)
+HEADERS = $(noinst_HEADERS)
+
+DIST_COMMON = $(noinst_HEADERS) Makefile.am Makefile.in
+SOURCES = $(comment_SOURCES) $(comment_theora_SOURCES) $(comment_theoradec_SOURCES) $(granulepos_SOURCES) $(granulepos_theora_SOURCES) $(granulepos_theoraenc_SOURCES) $(noop_SOURCES) $(noop_theora_SOURCES) $(noop_theoraenc_SOURCES)
+
+all: all-am
+
+.SUFFIXES:
+.SUFFIXES: .c .lo .o .obj
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am  $(top_srcdir)/configure.ac $(ACLOCAL_M4)
+       cd $(top_srcdir) && \
+         $(AUTOMAKE) --gnu  tests/Makefile
+Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in  $(top_builddir)/config.status
+       cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)
+
+clean-checkPROGRAMS:
+       @list='$(check_PROGRAMS)'; for p in $$list; do \
+         f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \
+         echo " rm -f $$p $$f"; \
+         rm -f $$p $$f ; \
+       done
+comment-comment.$(OBJEXT): comment.c
+comment$(EXEEXT): $(comment_OBJECTS) $(comment_DEPENDENCIES) 
+       @rm -f comment$(EXEEXT)
+       $(LINK) $(comment_LDFLAGS) $(comment_OBJECTS) $(comment_LDADD) $(LIBS)
+comment_theora-comment_theora.$(OBJEXT): comment_theora.c
+comment_theora$(EXEEXT): $(comment_theora_OBJECTS) $(comment_theora_DEPENDENCIES) 
+       @rm -f comment_theora$(EXEEXT)
+       $(LINK) $(comment_theora_LDFLAGS) $(comment_theora_OBJECTS) $(comment_theora_LDADD) $(LIBS)
+comment_theoradec-comment.$(OBJEXT): comment.c
+comment_theoradec$(EXEEXT): $(comment_theoradec_OBJECTS) $(comment_theoradec_DEPENDENCIES) 
+       @rm -f comment_theoradec$(EXEEXT)
+       $(LINK) $(comment_theoradec_LDFLAGS) $(comment_theoradec_OBJECTS) $(comment_theoradec_LDADD) $(LIBS)
+granulepos-granulepos.$(OBJEXT): granulepos.c
+granulepos$(EXEEXT): $(granulepos_OBJECTS) $(granulepos_DEPENDENCIES) 
+       @rm -f granulepos$(EXEEXT)
+       $(LINK) $(granulepos_LDFLAGS) $(granulepos_OBJECTS) $(granulepos_LDADD) $(LIBS)
+granulepos_theora-granulepos_theora.$(OBJEXT): granulepos_theora.c
+granulepos_theora$(EXEEXT): $(granulepos_theora_OBJECTS) $(granulepos_theora_DEPENDENCIES) 
+       @rm -f granulepos_theora$(EXEEXT)
+       $(LINK) $(granulepos_theora_LDFLAGS) $(granulepos_theora_OBJECTS) $(granulepos_theora_LDADD) $(LIBS)
+granulepos_theoraenc-granulepos_theora.$(OBJEXT): granulepos_theora.c
+granulepos_theoraenc$(EXEEXT): $(granulepos_theoraenc_OBJECTS) $(granulepos_theoraenc_DEPENDENCIES) 
+       @rm -f granulepos_theoraenc$(EXEEXT)
+       $(LINK) $(granulepos_theoraenc_LDFLAGS) $(granulepos_theoraenc_OBJECTS) $(granulepos_theoraenc_LDADD) $(LIBS)
+noop-noop.$(OBJEXT): noop.c
+noop$(EXEEXT): $(noop_OBJECTS) $(noop_DEPENDENCIES) 
+       @rm -f noop$(EXEEXT)
+       $(LINK) $(noop_LDFLAGS) $(noop_OBJECTS) $(noop_LDADD) $(LIBS)
+noop_theora-noop_theora.$(OBJEXT): noop_theora.c
+noop_theora$(EXEEXT): $(noop_theora_OBJECTS) $(noop_theora_DEPENDENCIES) 
+       @rm -f noop_theora$(EXEEXT)
+       $(LINK) $(noop_theora_LDFLAGS) $(noop_theora_OBJECTS) $(noop_theora_LDADD) $(LIBS)
+noop_theoraenc-noop_theora.$(OBJEXT): noop_theora.c
+noop_theoraenc$(EXEEXT): $(noop_theoraenc_OBJECTS) $(noop_theoraenc_DEPENDENCIES) 
+       @rm -f noop_theoraenc$(EXEEXT)
+       $(LINK) $(noop_theoraenc_LDFLAGS) $(noop_theoraenc_OBJECTS) $(noop_theoraenc_LDADD) $(LIBS)
+
+mostlyclean-compile:
+       -rm -f *.$(OBJEXT) core *.core
+
+distclean-compile:
+       -rm -f *.tab.c
+
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/comment-comment.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/comment_theora-comment_theora.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/comment_theoradec-comment.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/granulepos-granulepos.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/granulepos_theora-granulepos_theora.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/granulepos_theoraenc-granulepos_theora.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/noop-noop.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/noop_theora-noop_theora.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/noop_theoraenc-noop_theora.Po@am__quote@
+
+distclean-depend:
+       -rm -rf ./$(DEPDIR)
+
+.c.o:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `test -f '$<' || echo '$(srcdir)/'`$<
+
+.c.obj:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(COMPILE) -c `cygpath -w $<`
+
+.c.lo:
+@AMDEP_TRUE@   source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/$*.Plo' tmpdepfile='$(DEPDIR)/$*.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LTCOMPILE) -c -o $@ `test -f '$<' || echo '$(srcdir)/'`$<
+
+comment-comment.o: comment.c
+@AMDEP_TRUE@   source='comment.c' object='comment-comment.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment-comment.Po' tmpdepfile='$(DEPDIR)/comment-comment.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_CFLAGS) $(CFLAGS) -c -o comment-comment.o `test -f 'comment.c' || echo '$(srcdir)/'`comment.c
+
+comment-comment.obj: comment.c
+@AMDEP_TRUE@   source='comment.c' object='comment-comment.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment-comment.Po' tmpdepfile='$(DEPDIR)/comment-comment.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_CFLAGS) $(CFLAGS) -c -o comment-comment.obj `cygpath -w comment.c`
+
+comment-comment.lo: comment.c
+@AMDEP_TRUE@   source='comment.c' object='comment-comment.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment-comment.Plo' tmpdepfile='$(DEPDIR)/comment-comment.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_CFLAGS) $(CFLAGS) -c -o comment-comment.lo `test -f 'comment.c' || echo '$(srcdir)/'`comment.c
+
+comment_theora-comment_theora.o: comment_theora.c
+@AMDEP_TRUE@   source='comment_theora.c' object='comment_theora-comment_theora.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment_theora-comment_theora.Po' tmpdepfile='$(DEPDIR)/comment_theora-comment_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_theora_CFLAGS) $(CFLAGS) -c -o comment_theora-comment_theora.o `test -f 'comment_theora.c' || echo '$(srcdir)/'`comment_theora.c
+
+comment_theora-comment_theora.obj: comment_theora.c
+@AMDEP_TRUE@   source='comment_theora.c' object='comment_theora-comment_theora.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment_theora-comment_theora.Po' tmpdepfile='$(DEPDIR)/comment_theora-comment_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_theora_CFLAGS) $(CFLAGS) -c -o comment_theora-comment_theora.obj `cygpath -w comment_theora.c`
+
+comment_theora-comment_theora.lo: comment_theora.c
+@AMDEP_TRUE@   source='comment_theora.c' object='comment_theora-comment_theora.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment_theora-comment_theora.Plo' tmpdepfile='$(DEPDIR)/comment_theora-comment_theora.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_theora_CFLAGS) $(CFLAGS) -c -o comment_theora-comment_theora.lo `test -f 'comment_theora.c' || echo '$(srcdir)/'`comment_theora.c
+
+comment_theoradec-comment.o: comment.c
+@AMDEP_TRUE@   source='comment.c' object='comment_theoradec-comment.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment_theoradec-comment.Po' tmpdepfile='$(DEPDIR)/comment_theoradec-comment.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_theoradec_CFLAGS) $(CFLAGS) -c -o comment_theoradec-comment.o `test -f 'comment.c' || echo '$(srcdir)/'`comment.c
+
+comment_theoradec-comment.obj: comment.c
+@AMDEP_TRUE@   source='comment.c' object='comment_theoradec-comment.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment_theoradec-comment.Po' tmpdepfile='$(DEPDIR)/comment_theoradec-comment.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_theoradec_CFLAGS) $(CFLAGS) -c -o comment_theoradec-comment.obj `cygpath -w comment.c`
+
+comment_theoradec-comment.lo: comment.c
+@AMDEP_TRUE@   source='comment.c' object='comment_theoradec-comment.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/comment_theoradec-comment.Plo' tmpdepfile='$(DEPDIR)/comment_theoradec-comment.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(comment_theoradec_CFLAGS) $(CFLAGS) -c -o comment_theoradec-comment.lo `test -f 'comment.c' || echo '$(srcdir)/'`comment.c
+
+granulepos-granulepos.o: granulepos.c
+@AMDEP_TRUE@   source='granulepos.c' object='granulepos-granulepos.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos-granulepos.Po' tmpdepfile='$(DEPDIR)/granulepos-granulepos.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_CFLAGS) $(CFLAGS) -c -o granulepos-granulepos.o `test -f 'granulepos.c' || echo '$(srcdir)/'`granulepos.c
+
+granulepos-granulepos.obj: granulepos.c
+@AMDEP_TRUE@   source='granulepos.c' object='granulepos-granulepos.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos-granulepos.Po' tmpdepfile='$(DEPDIR)/granulepos-granulepos.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_CFLAGS) $(CFLAGS) -c -o granulepos-granulepos.obj `cygpath -w granulepos.c`
+
+granulepos-granulepos.lo: granulepos.c
+@AMDEP_TRUE@   source='granulepos.c' object='granulepos-granulepos.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos-granulepos.Plo' tmpdepfile='$(DEPDIR)/granulepos-granulepos.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_CFLAGS) $(CFLAGS) -c -o granulepos-granulepos.lo `test -f 'granulepos.c' || echo '$(srcdir)/'`granulepos.c
+
+granulepos_theora-granulepos_theora.o: granulepos_theora.c
+@AMDEP_TRUE@   source='granulepos_theora.c' object='granulepos_theora-granulepos_theora.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos_theora-granulepos_theora.Po' tmpdepfile='$(DEPDIR)/granulepos_theora-granulepos_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_theora_CFLAGS) $(CFLAGS) -c -o granulepos_theora-granulepos_theora.o `test -f 'granulepos_theora.c' || echo '$(srcdir)/'`granulepos_theora.c
+
+granulepos_theora-granulepos_theora.obj: granulepos_theora.c
+@AMDEP_TRUE@   source='granulepos_theora.c' object='granulepos_theora-granulepos_theora.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos_theora-granulepos_theora.Po' tmpdepfile='$(DEPDIR)/granulepos_theora-granulepos_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_theora_CFLAGS) $(CFLAGS) -c -o granulepos_theora-granulepos_theora.obj `cygpath -w granulepos_theora.c`
+
+granulepos_theora-granulepos_theora.lo: granulepos_theora.c
+@AMDEP_TRUE@   source='granulepos_theora.c' object='granulepos_theora-granulepos_theora.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos_theora-granulepos_theora.Plo' tmpdepfile='$(DEPDIR)/granulepos_theora-granulepos_theora.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_theora_CFLAGS) $(CFLAGS) -c -o granulepos_theora-granulepos_theora.lo `test -f 'granulepos_theora.c' || echo '$(srcdir)/'`granulepos_theora.c
+
+granulepos_theoraenc-granulepos_theora.o: granulepos_theora.c
+@AMDEP_TRUE@   source='granulepos_theora.c' object='granulepos_theoraenc-granulepos_theora.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos_theoraenc-granulepos_theora.Po' tmpdepfile='$(DEPDIR)/granulepos_theoraenc-granulepos_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_theoraenc_CFLAGS) $(CFLAGS) -c -o granulepos_theoraenc-granulepos_theora.o `test -f 'granulepos_theora.c' || echo '$(srcdir)/'`granulepos_theora.c
+
+granulepos_theoraenc-granulepos_theora.obj: granulepos_theora.c
+@AMDEP_TRUE@   source='granulepos_theora.c' object='granulepos_theoraenc-granulepos_theora.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos_theoraenc-granulepos_theora.Po' tmpdepfile='$(DEPDIR)/granulepos_theoraenc-granulepos_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_theoraenc_CFLAGS) $(CFLAGS) -c -o granulepos_theoraenc-granulepos_theora.obj `cygpath -w granulepos_theora.c`
+
+granulepos_theoraenc-granulepos_theora.lo: granulepos_theora.c
+@AMDEP_TRUE@   source='granulepos_theora.c' object='granulepos_theoraenc-granulepos_theora.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/granulepos_theoraenc-granulepos_theora.Plo' tmpdepfile='$(DEPDIR)/granulepos_theoraenc-granulepos_theora.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(granulepos_theoraenc_CFLAGS) $(CFLAGS) -c -o granulepos_theoraenc-granulepos_theora.lo `test -f 'granulepos_theora.c' || echo '$(srcdir)/'`granulepos_theora.c
+
+noop-noop.o: noop.c
+@AMDEP_TRUE@   source='noop.c' object='noop-noop.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop-noop.Po' tmpdepfile='$(DEPDIR)/noop-noop.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_CFLAGS) $(CFLAGS) -c -o noop-noop.o `test -f 'noop.c' || echo '$(srcdir)/'`noop.c
+
+noop-noop.obj: noop.c
+@AMDEP_TRUE@   source='noop.c' object='noop-noop.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop-noop.Po' tmpdepfile='$(DEPDIR)/noop-noop.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_CFLAGS) $(CFLAGS) -c -o noop-noop.obj `cygpath -w noop.c`
+
+noop-noop.lo: noop.c
+@AMDEP_TRUE@   source='noop.c' object='noop-noop.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop-noop.Plo' tmpdepfile='$(DEPDIR)/noop-noop.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_CFLAGS) $(CFLAGS) -c -o noop-noop.lo `test -f 'noop.c' || echo '$(srcdir)/'`noop.c
+
+noop_theora-noop_theora.o: noop_theora.c
+@AMDEP_TRUE@   source='noop_theora.c' object='noop_theora-noop_theora.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop_theora-noop_theora.Po' tmpdepfile='$(DEPDIR)/noop_theora-noop_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_theora_CFLAGS) $(CFLAGS) -c -o noop_theora-noop_theora.o `test -f 'noop_theora.c' || echo '$(srcdir)/'`noop_theora.c
+
+noop_theora-noop_theora.obj: noop_theora.c
+@AMDEP_TRUE@   source='noop_theora.c' object='noop_theora-noop_theora.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop_theora-noop_theora.Po' tmpdepfile='$(DEPDIR)/noop_theora-noop_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_theora_CFLAGS) $(CFLAGS) -c -o noop_theora-noop_theora.obj `cygpath -w noop_theora.c`
+
+noop_theora-noop_theora.lo: noop_theora.c
+@AMDEP_TRUE@   source='noop_theora.c' object='noop_theora-noop_theora.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop_theora-noop_theora.Plo' tmpdepfile='$(DEPDIR)/noop_theora-noop_theora.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_theora_CFLAGS) $(CFLAGS) -c -o noop_theora-noop_theora.lo `test -f 'noop_theora.c' || echo '$(srcdir)/'`noop_theora.c
+
+noop_theoraenc-noop_theora.o: noop_theora.c
+@AMDEP_TRUE@   source='noop_theora.c' object='noop_theoraenc-noop_theora.o' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop_theoraenc-noop_theora.Po' tmpdepfile='$(DEPDIR)/noop_theoraenc-noop_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_theoraenc_CFLAGS) $(CFLAGS) -c -o noop_theoraenc-noop_theora.o `test -f 'noop_theora.c' || echo '$(srcdir)/'`noop_theora.c
+
+noop_theoraenc-noop_theora.obj: noop_theora.c
+@AMDEP_TRUE@   source='noop_theora.c' object='noop_theoraenc-noop_theora.obj' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop_theoraenc-noop_theora.Po' tmpdepfile='$(DEPDIR)/noop_theoraenc-noop_theora.TPo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_theoraenc_CFLAGS) $(CFLAGS) -c -o noop_theoraenc-noop_theora.obj `cygpath -w noop_theora.c`
+
+noop_theoraenc-noop_theora.lo: noop_theora.c
+@AMDEP_TRUE@   source='noop_theora.c' object='noop_theoraenc-noop_theora.lo' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@   depfile='$(DEPDIR)/noop_theoraenc-noop_theora.Plo' tmpdepfile='$(DEPDIR)/noop_theoraenc-noop_theora.TPlo' @AMDEPBACKSLASH@
+@AMDEP_TRUE@   $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+       $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(noop_theoraenc_CFLAGS) $(CFLAGS) -c -o noop_theoraenc-noop_theora.lo `test -f 'noop_theora.c' || echo '$(srcdir)/'`noop_theora.c
+CCDEPMODE = @CCDEPMODE@
+
+mostlyclean-libtool:
+       -rm -f *.lo
+
+clean-libtool:
+       -rm -rf .libs _libs
+
+distclean-libtool:
+       -rm -f libtool
+uninstall-info-am:
+
+ETAGS = etags
+ETAGSFLAGS =
+
+tags: TAGS
+
+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
+       list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       mkid -fID $$unique
+
+TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \
+               $(TAGS_FILES) $(LISP)
+       tags=; \
+       here=`pwd`; \
+       list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \
+       unique=`for i in $$list; do \
+           if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+         done | \
+         $(AWK) '    { files[$$0] = 1; } \
+              END { for (i in files) print i; }'`; \
+       test -z "$(ETAGS_ARGS)$$tags$$unique" \
+         || $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+            $$tags $$unique
+
+GTAGS:
+       here=`$(am__cd) $(top_builddir) && pwd` \
+         && cd $(top_srcdir) \
+         && gtags -i $(GTAGS_ARGS) $$here
+
+distclean-tags:
+       -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH
+
+check-TESTS: $(TESTS)
+       @failed=0; all=0; xfail=0; xpass=0; \
+       srcdir=$(srcdir); export srcdir; \
+       list='$(TESTS)'; \
+       if test -n "$$list"; then \
+         for tst in $$list; do \
+           if test -f ./$$tst; then dir=./; \
+           elif test -f $$tst; then dir=; \
+           else dir="$(srcdir)/"; fi; \
+           if $(TESTS_ENVIRONMENT) $${dir}$$tst; then \
+             all=`expr $$all + 1`; \
+             case " $(XFAIL_TESTS) " in \
+             *" $$tst "*) \
+               xpass=`expr $$xpass + 1`; \
+               failed=`expr $$failed + 1`; \
+               echo "XPASS: $$tst"; \
+             ;; \
+             *) \
+               echo "PASS: $$tst"; \
+             ;; \
+             esac; \
+           elif test $$? -ne 77; then \
+             all=`expr $$all + 1`; \
+             case " $(XFAIL_TESTS) " in \
+             *" $$tst "*) \
+               xfail=`expr $$xfail + 1`; \
+               echo "XFAIL: $$tst"; \
+             ;; \
+             *) \
+               failed=`expr $$failed + 1`; \
+               echo "FAIL: $$tst"; \
+             ;; \
+             esac; \
+           fi; \
+         done; \
+         if test "$$failed" -eq 0; then \
+           if test "$$xfail" -eq 0; then \
+             banner="All $$all tests passed"; \
+           else \
+             banner="All $$all tests behaved as expected ($$xfail expected failures)"; \
+           fi; \
+         else \
+           if test "$$xpass" -eq 0; then \
+             banner="$$failed of $$all tests failed"; \
+           else \
+             banner="$$failed of $$all tests did not behave as expected ($$xpass unexpected passes)"; \
+           fi; \
+         fi; \
+         dashes=`echo "$$banner" | sed s/./=/g`; \
+         echo "$$dashes"; \
+         echo "$$banner"; \
+         echo "$$dashes"; \
+         test "$$failed" -eq 0; \
+       else :; fi
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+
+top_distdir = ..
+distdir = $(top_distdir)/$(PACKAGE)-$(VERSION)
+
+distdir: $(DISTFILES)
+       @list='$(DISTFILES)'; for file in $$list; do \
+         if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+         dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
+         if test "$$dir" != "$$file" && test "$$dir" != "."; then \
+           dir="/$$dir"; \
+           $(mkinstalldirs) "$(distdir)$$dir"; \
+         else \
+           dir=''; \
+         fi; \
+         if test -d $$d/$$file; then \
+           if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+             cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
+           fi; \
+           cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
+         else \
+           test -f $(distdir)/$$file \
+           || cp -p $$d/$$file $(distdir)/$$file \
+           || exit 1; \
+         fi; \
+       done
+check-am: all-am
+       $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS)
+       $(MAKE) $(AM_MAKEFLAGS) check-TESTS
+check: check-am
+all-am: Makefile $(HEADERS)
+
+installdirs:
+
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+       @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+       $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+         INSTALL_STRIP_FLAG=-s \
+         `test -z '$(STRIP)' || \
+           echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+       -rm -f Makefile $(CONFIG_CLEAN_FILES)
+
+maintainer-clean-generic:
+       @echo "This command is intended for maintainers to use"
+       @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-checkPROGRAMS clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-am
+
+distclean-am: clean-am distclean-compile distclean-depend \
+       distclean-generic distclean-libtool distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+info: info-am
+
+info-am:
+
+install-data-am:
+
+install-exec-am:
+
+install-info: install-info-am
+
+install-man:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-compile mostlyclean-generic \
+       mostlyclean-libtool
+
+uninstall-am: uninstall-info-am
+
+.PHONY: GTAGS all all-am check check-TESTS check-am clean \
+       clean-checkPROGRAMS clean-generic clean-libtool distclean \
+       distclean-compile distclean-depend distclean-generic \
+       distclean-libtool distclean-tags distdir dvi dvi-am info \
+       info-am install install-am install-data install-data-am \
+       install-exec install-exec-am install-info install-info-am \
+       install-man install-strip installcheck installcheck-am \
+       installdirs maintainer-clean maintainer-clean-generic \
+       mostlyclean mostlyclean-compile mostlyclean-generic \
+       mostlyclean-libtool tags uninstall uninstall-am \
+       uninstall-info-am
+
+test: check
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/tests/comment.c b/tests/comment.c
new file mode 100644 (file)
index 0000000..d972e68
--- /dev/null
@@ -0,0 +1,91 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: routines for validating comment header code
+  last mod: $Id: comment.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <theora/theoradec.h>
+
+#include <string.h>
+#include "tests.h"
+
+#define ARTIST1 "Bug-eyed Fish"
+#define ARTIST2 "VJ Fugu"
+#define COPYRIGHT "Copyright (C) 2005. Some Rights Reserved."
+#define LICENSE "Creative Commons Attribution-ShareAlike 2.5"
+
+static int
+test_comments ()
+{
+  th_comment tc;
+  int n;
+  char * value;
+
+  INFO ("+ Initializing th_comment");
+  th_comment_init (&tc);
+
+  INFO ("+ Adding ARTIST1");
+  th_comment_add (&tc, "ARTIST=" ARTIST1);
+
+  INFO ("+ Adding LICENSE by tag");
+  th_comment_add_tag (&tc, "LICENSE", LICENSE);
+
+  INFO ("+ Adding ARTIST2 by tag");
+  th_comment_add_tag (&tc, "ARTIST", ARTIST2);
+
+  INFO ("+ Querying value of LICENSE");
+  value = th_comment_query (&tc, "LICENSE", 0);
+  printf("foo %s\n", value);
+
+  if (strcmp (value, LICENSE))
+    FAIL ("Incorrect value for LICENSE");
+
+  INFO ("+ Querying count of ARTIST comments");
+  n = th_comment_query_count (&tc, "ARTIST");
+
+  if (n != 2)
+    FAIL ("Incorrect count of ARTIST comments");
+
+  INFO ("+ Querying value of ARTIST index 0");
+  value = th_comment_query (&tc, "ARTIST", 0);
+  if (strcmp (value, ARTIST1))
+    FAIL ("Incorrect value for ARTIST index 0");
+
+  INFO ("+ Querying value of ARTIST index 1");
+  value = th_comment_query (&tc, "ARTIST", 1);
+  if (strcmp (value, ARTIST2))
+    FAIL ("Incorrect value for ARTIST index 1");
+
+  INFO ("+ Querying value of ARTIST index 2 (out of bounds)");
+  value = th_comment_query (&tc, "ARTIST", 2);
+  if (value != NULL)
+    FAIL ("Non-NULL value for ARTIST index 2 (out of bounds)");
+
+  INFO ("+ Querying value of UNDEF index 7 (tag not defined)");
+  value = th_comment_query (&tc, "UNDEF", 7);
+  if (value != NULL)
+    FAIL ("Non-NULL value for UNDEF index 7 (tag not defined)");
+
+  INFO ("+ Clearing th_comment");
+  th_comment_clear (&tc);
+
+  return 0;
+}
+
+int main(int argc, char *argv[])
+{
+  test_comments ();
+
+  exit (0);
+}
diff --git a/tests/comment_theora.c b/tests/comment_theora.c
new file mode 100644 (file)
index 0000000..e101cd1
--- /dev/null
@@ -0,0 +1,91 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: routines for validating comment header code
+  last mod: $Id: comment_theora.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <theora/theora.h>
+
+#include <string.h>
+#include "tests.h"
+
+#define ARTIST1 "Bug-eyed Fish"
+#define ARTIST2 "VJ Fugu"
+#define COPYRIGHT "Copyright (C) 2005. Some Rights Reserved."
+#define LICENSE "Creative Commons Attribution-ShareAlike 2.5"
+
+static int
+test_comments ()
+{
+  theora_comment tc;
+  int n;
+  char * value;
+
+  INFO ("+ Initializing theora_comment");
+  theora_comment_init (&tc);
+
+  INFO ("+ Adding ARTIST1");
+  theora_comment_add (&tc, "ARTIST=" ARTIST1);
+
+  INFO ("+ Adding LICENSE by tag");
+  theora_comment_add_tag (&tc, "LICENSE", LICENSE);
+
+  INFO ("+ Adding ARTIST2 by tag");
+  theora_comment_add_tag (&tc, "ARTIST", ARTIST2);
+
+  INFO ("+ Querying value of LICENSE");
+  value = theora_comment_query (&tc, "LICENSE", 0);
+  printf("foo %s\n", value);
+
+  if (strcmp (value, LICENSE))
+    FAIL ("Incorrect value for LICENSE");
+
+  INFO ("+ Querying count of ARTIST comments");
+  n = theora_comment_query_count (&tc, "ARTIST");
+
+  if (n != 2)
+    FAIL ("Incorrect count of ARTIST comments");
+
+  INFO ("+ Querying value of ARTIST index 0");
+  value = theora_comment_query (&tc, "ARTIST", 0);
+  if (strcmp (value, ARTIST1))
+    FAIL ("Incorrect value for ARTIST index 0");
+
+  INFO ("+ Querying value of ARTIST index 1");
+  value = theora_comment_query (&tc, "ARTIST", 1);
+  if (strcmp (value, ARTIST2))
+    FAIL ("Incorrect value for ARTIST index 1");
+
+  INFO ("+ Querying value of ARTIST index 2 (out of bounds)");
+  value = theora_comment_query (&tc, "ARTIST", 2);
+  if (value != NULL)
+    FAIL ("Non-NULL value for ARTIST index 2 (out of bounds)");
+
+  INFO ("+ Querying value of UNDEF index 7 (tag not defined)");
+  value = theora_comment_query (&tc, "UNDEF", 7);
+  if (value != NULL)
+    FAIL ("Non-NULL value for UNDEF index 7 (tag not defined)");
+
+  INFO ("+ Clearing theora_comment");
+  theora_comment_clear (&tc);
+
+  return 0;
+}
+
+int main(int argc, char *argv[])
+{
+  test_comments ();
+
+  exit (0);
+}
diff --git a/tests/granulepos.c b/tests/granulepos.c
new file mode 100644 (file)
index 0000000..a81dea8
--- /dev/null
@@ -0,0 +1,149 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: routines for validating encoder granulepos generation
+  last mod: $Id: granulepos.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <theora/theoraenc.h>
+#include <math.h>
+
+#include "tests.h"
+
+static int ilog(unsigned int v){
+  int ret=0;
+  while(v){
+    ret++;
+    v>>=1;
+  }
+  return(ret);
+}
+
+static int
+granulepos_test_encode (int frequency)
+{
+  th_info ti;
+  th_enc_ctx *te;
+  int result;
+  int frame, tframe, keyframe, keydist;
+  int shift;
+  double rate, ttime;
+  th_ycbcr_buffer yuv;
+  unsigned char *framedata;
+  ogg_packet op;
+  long long int last_granule = -1;
+
+/*  INFO ("+ Initializing th_info struct"); */
+  th_info_init (&ti);
+
+  ti.frame_width = 32;
+  ti.frame_height = 32;
+  ti.pic_width = ti.frame_width;
+  ti.pic_height = ti.frame_height;
+  ti.pic_x = 0;
+  ti.pic_y = 0;
+  ti.fps_numerator = 16;
+  ti.fps_denominator = 1;
+  ti.aspect_numerator = 1;
+  ti.aspect_denominator = 1;
+  ti.colorspace = TH_CS_UNSPECIFIED;
+  ti.pixel_fmt = TH_PF_420;
+  ti.quality = 16;
+  ti.keyframe_granule_shift=ilog(frequency);
+
+/*  INFO ("+ Allocating encoder context"); */
+  te = th_encode_alloc(&ti);
+  if (te == NULL) {
+    INFO ("+ Clearing th_info");
+    th_info_clear(&ti);
+    FAIL ("negative return code initializing encoder");
+  }
+
+/*  INFO ("+ Setting up dummy 4:2:0 frame data"); */
+  framedata = calloc(ti.frame_height, ti.frame_width);
+  yuv[0].width = ti.frame_width;
+  yuv[0].height = ti.frame_height;
+  yuv[0].stride = ti.frame_width;
+  yuv[0].data = framedata;
+  yuv[1].width = ti.frame_width / 2;
+  yuv[1].height = ti.frame_width / 2;
+  yuv[1].stride = ti.frame_width;
+  yuv[1].data = framedata;
+  yuv[2].width = ti.frame_width / 2;
+  yuv[2].height = ti.frame_width / 2;
+  yuv[2].stride = ti.frame_width;
+  yuv[2].data = framedata;
+
+  INFO ("+ Checking granulepos generation");
+  shift = ti.keyframe_granule_shift;
+  rate = (double)ti.fps_denominator/ti.fps_numerator;
+  for (frame = 0; frame < frequency * 2 + 1; frame++) {
+    result = th_encode_ycbcr_in (te, yuv);
+    if (result < 0) {
+      printf("th_encode_ycbcr_in() returned %d\n", result);
+      FAIL ("negative error code submitting frame for compression");
+    }
+    result = th_encode_packetout (te, frame >= frequency * 2, &op);
+    if (result <= 0) {
+      printf("th_encode_packetout() returned %d\n", result);
+      FAIL("failed to retrieve compressed frame");
+    }
+    if ((long long int)op.granulepos < last_granule)
+      FAIL ("encoder returned a decreasing granulepos value");
+    last_granule = op.granulepos;
+    keyframe = op.granulepos >> shift;
+    keydist = op.granulepos - (keyframe << shift);
+    tframe = th_granule_frame (te, op.granulepos);
+    ttime = th_granule_time(te, op.granulepos);
+#if DEBUG
+    printf("++ frame %d granulepos %lld %d:%d %d %.3lfs\n",
+       frame, (long long int)op.granulepos, keyframe, keydist,
+       tframe, th_granule_time (te, op.granulepos));
+#endif
+    /* granulepos stores the frame count */
+    if ((keyframe + keydist) != frame + 1)
+      FAIL ("encoder granulepos does not map to the correct frame number");
+    /* th_granule_frame() returns the frame index */
+    if (tframe != frame)
+      FAIL ("th_granule_frame() returned incorrect results");
+    /* th_granule_time() returns the end time */
+    if (fabs(rate*(frame+1) - ttime) > 1.0e-6)
+      FAIL ("th_granule_time() returned incorrect results");
+  }
+
+  /* clean up */
+/*  INFO ("+ Freeing dummy frame data"); */
+  free(framedata);
+
+/*  INFO ("+ Clearing th_info struct"); */
+  th_info_clear(&ti);
+
+/*  INFO ("+ Freeing encoder context"); */
+  th_encode_free(te);
+
+  return 0;
+}
+
+int main(int argc, char *argv[])
+{
+
+  granulepos_test_encode (1);
+  granulepos_test_encode (2);
+  granulepos_test_encode (3);
+  granulepos_test_encode (4);
+  granulepos_test_encode (8);
+  granulepos_test_encode (64);
+
+  exit (0);
+}
diff --git a/tests/granulepos_theora.c b/tests/granulepos_theora.c
new file mode 100644 (file)
index 0000000..9ab7f8b
--- /dev/null
@@ -0,0 +1,154 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: routines for validating encoder granulepos generation
+  last mod: $Id: granulepos_theora.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <stdlib.h>
+#include <theora/theora.h>
+#include <math.h>
+
+#include "tests.h"
+
+static int ilog(unsigned int v){
+  int ret=0;
+  while(v){
+    ret++;
+    v>>=1;
+  }
+  return(ret);
+}
+
+static int
+granulepos_test_encode (int frequency, int auto_p)
+{
+  theora_info ti;
+  theora_state th;
+  int result;
+  int frame, tframe, keyframe, keydist;
+  int shift;
+  double rate, ttime;
+  yuv_buffer yuv;
+  unsigned char *framedata;
+  ogg_packet op;
+  long long int last_granule = -1;
+
+/*  INFO ("+ Initializing theora_info struct"); */
+  theora_info_init (&ti);
+
+  ti.width = 32;
+  ti.height = 32;
+  ti.frame_width = ti.width;
+  ti.frame_height = ti.frame_height;
+  ti.offset_x = 0;
+  ti.offset_y = 0;
+  ti.fps_numerator = 16;
+  ti.fps_denominator = 1;
+  ti.aspect_numerator = 1;
+  ti.aspect_denominator = 1;
+  ti.colorspace = OC_CS_UNSPECIFIED;
+  ti.pixelformat = OC_PF_420;
+  ti.target_bitrate = 0;
+  ti.quality = 16;
+
+  ti.dropframes_p = 0;
+  ti.quick_p = 1;
+
+  /* check variations of automatic or forced keyframe choice */
+  ti.keyframe_auto_p = auto_p;
+  /* check with variations of the maximum gap */
+  ti.keyframe_frequency = frequency;
+  ti.keyframe_frequency_force = frequency;
+
+  ti.keyframe_data_target_bitrate = ti.target_bitrate * 1.5;
+  ti.keyframe_auto_threshold = 80;
+  ti.keyframe_mindistance = MIN(8, frequency);
+  ti.noise_sensitivity = 1;
+
+/*  INFO ("+ Initializing theora_state for encoding"); */
+  result = theora_encode_init (&th, &ti);
+  if (result == OC_DISABLED) {
+    INFO ("+ Clearing theora_state");
+    theora_clear (&th);
+  } else if (result < 0) {
+    FAIL ("negative return code initializing encoder");
+  }
+
+/*  INFO ("+ Setting up dummy 4:2:0 frame data"); */
+  framedata = calloc(ti.height, ti.width);
+  yuv.y_width = ti.width;
+  yuv.y_height = ti.height;
+  yuv.y_stride = ti.width;
+  yuv.y = framedata;
+  yuv.uv_width = ti.width / 2;
+  yuv.uv_height = ti.width / 2;
+  yuv.uv_stride = ti.width;
+  yuv.u = framedata;
+  yuv.v = framedata;
+
+  INFO ("+ Checking granulepos generation");
+  shift = theora_granule_shift(&ti);
+  rate = (double)ti.fps_denominator/ti.fps_numerator;
+  for (frame = 0; frame < frequency * 2 + 1; frame++) {
+    result = theora_encode_YUVin (&th, &yuv);
+    if (result < 0) {
+      printf("theora_encode_YUVin() returned %d\n", result);
+      FAIL ("negative error code submitting frame for compression");
+    }
+    theora_encode_packetout (&th, frame >= frequency * 2, &op);
+    if ((long long int)op.granulepos < last_granule)
+      FAIL ("encoder returned a decreasing granulepos value");
+    last_granule = op.granulepos;
+    keyframe = op.granulepos >> shift;
+    keydist = op.granulepos - (keyframe << shift);
+    tframe = theora_granule_frame (&th, op.granulepos);
+    ttime = theora_granule_time(&th, op.granulepos);
+#if DEBUG
+    printf("++ frame %d granulepos %lld %d:%d %d %.3lfs\n", 
+       frame, (long long int)op.granulepos, keyframe, keydist,
+       tframe, theora_granule_time (&th, op.granulepos));
+#endif
+    if ((keyframe + keydist) != frame + 1)
+      FAIL ("encoder granulepos does not map to the correct frame number");
+    if (tframe != frame)
+      FAIL ("theora_granule_frame returned incorrect results");
+    if (fabs(rate*(frame+1) - ttime) > 1.0e-6)
+      FAIL ("theora_granule_time returned incorrect results");
+  }
+
+  /* clean up */
+/*  INFO ("+ Freeing dummy frame data"); */
+  free (framedata);
+
+/*  INFO ("+ Clearing theora_info struct"); */
+  theora_info_clear (&ti);
+
+/*  INFO ("+ Clearing theora_state"); */
+  theora_clear (&th);
+
+  return 0;
+}
+
+int main(int argc, char *argv[])
+{
+
+  granulepos_test_encode (1, 1);
+  granulepos_test_encode (2, 1);
+  granulepos_test_encode (3, 1);
+  granulepos_test_encode (4, 1);
+  granulepos_test_encode (8, 1);
+  granulepos_test_encode (64, 1);
+
+  exit (0);
+}
diff --git a/tests/noop.c b/tests/noop.c
new file mode 100644 (file)
index 0000000..8c1ba2f
--- /dev/null
@@ -0,0 +1,119 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: routines for validating codec initialization
+  last mod: $Id: noop.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <theora/theoraenc.h>
+#include <theora/theoradec.h>
+
+#include "tests.h"
+
+static int
+noop_test_info ()
+{
+  th_info ti;
+
+  INFO ("+ Initializing th_info struct");
+  th_info_init (&ti);
+
+  INFO ("+ Clearing empty th_info struct");
+  th_info_clear (&ti);
+
+  return 0;
+}
+
+static int
+noop_test_comments ()
+{
+  th_comment tc;
+
+  INFO ("+ Initializing th_comment struct");
+  th_comment_init (&tc);
+
+  INFO ("+ Clearing empty th_comment struct")
+  th_comment_clear (&tc);
+
+  return 0;
+}
+
+static int
+noop_test_encode ()
+{
+  th_info ti;
+  th_enc_ctx *te;
+
+  INFO ("+ Initializing th_info struct");
+  th_info_init (&ti);
+
+  INFO ("+ Testing encoder context with empty th_info");
+  te = th_encode_alloc(&ti);
+  if (te != NULL)
+    FAIL("td_encode_alloc accepted an unconfigured th_info");
+
+  INFO ("+ Setting 16x16 image size");
+  ti.frame_width = 16;
+  ti.frame_height = 16;
+
+  INFO ("+ Allocating encoder context");
+  te = th_encode_alloc(&ti);
+  if (te == NULL)
+    FAIL("td_encode_alloc returned a null pointer");
+
+  INFO ("+ Clearing th_info struct");
+  th_info_clear (&ti);
+
+  INFO ("+ Freeing encoder context");
+  th_encode_free(te);
+
+  return 0;
+}
+
+static int
+noop_test_decode ()
+{
+  th_info ti;
+  th_dec_ctx *td;
+
+  INFO ("+ Testing decoder context with null info and setup");
+  td = th_decode_alloc(NULL, NULL);
+  if (td != NULL)
+    FAIL("td_decode_alloc accepted null info pointers");
+
+  INFO ("+ Initializing th_info struct");
+  th_info_init (&ti);
+
+  INFO ("+ Testing decoder context with empty info and null setup");
+  td = th_decode_alloc(&ti, NULL);
+  if (td != NULL)
+    FAIL("td_decode_alloc accepted null info pointers");
+
+  INFO ("+ Clearing th_info struct");
+  th_info_clear (&ti);
+
+  return 0;
+}
+
+int main(int argc, char *argv[])
+{
+  noop_test_info ();
+
+  noop_test_comments ();
+
+  noop_test_encode ();
+
+  noop_test_decode ();
+
+  exit (0);
+}
diff --git a/tests/noop_theora.c b/tests/noop_theora.c
new file mode 100644 (file)
index 0000000..5069874
--- /dev/null
@@ -0,0 +1,88 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: routines for validating codec initialization
+  last mod: $Id: noop_theora.c 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include <theora/theora.h>
+
+#include "tests.h"
+
+static int
+noop_test_encode ()
+{
+  theora_info ti;
+  theora_state th;
+
+  INFO ("+ Initializing theora_info struct");
+  theora_info_init (&ti);
+
+  INFO ("+ Setting a 16x16 frame");
+  ti.width = 16;
+  ti.height = 16;
+
+  INFO ("+ Initializing theora_state for encoding");
+  if (theora_encode_init (&th, &ti) != OC_DISABLED) {
+    INFO ("+ Clearing theora_state");
+    theora_clear (&th);
+  }
+
+  INFO ("+ Clearing theora_info struct");
+  theora_info_clear (&ti);
+
+  return 0;
+}
+
+static int
+noop_test_decode ()
+{
+  theora_info ti;
+  theora_state th;
+
+  INFO ("+ Initializing theora_info struct");
+  theora_info_init (&ti);
+
+  INFO ("+ Initializing theora_state for decoding");
+  theora_decode_init (&th, &ti);
+
+  INFO ("+ Clearing theora_state");
+  theora_clear (&th);
+
+  INFO ("+ Clearing theora_info struct");
+  theora_info_clear (&ti);
+
+  return 0;
+}
+
+static int
+noop_test_comments ()
+{
+  theora_comment tc;
+
+  theora_comment_init (&tc);
+  theora_comment_clear (&tc);
+
+  return 0;
+}
+
+int main(int argc, char *argv[])
+{
+  /*noop_test_decode ();*/
+
+  noop_test_encode ();
+
+  noop_test_comments ();
+
+  exit (0);
+}
diff --git a/tests/tests.h b/tests/tests.h
new file mode 100644 (file)
index 0000000..3bbff24
--- /dev/null
@@ -0,0 +1,33 @@
+/********************************************************************
+ *                                                                  *
+ * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
+ * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
+ * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
+ * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
+ *                                                                  *
+ * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
+ * by the Xiph.Org Foundation http://www.xiph.org/                  *
+ *                                                                  *
+ ********************************************************************
+
+  function: common test utilities
+  last mod: $Id: tests.h 16503 2009-08-22 18:14:02Z giles $
+
+ ********************************************************************/
+
+#include "config.h"
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#define INFO(str) \
+  { printf ("----  %s ...\n", (str)); }
+
+#define WARN(str) \
+  { printf ("%s:%d: warning: %s\n", __FILE__, __LINE__, (str)); }
+
+#define FAIL(str) \
+  { printf ("%s:%d: %s\n", __FILE__, __LINE__, (str)); exit(1); }
+
+#undef MIN
+#define MIN(a,b) ((a)<(b)?(a):(b))
diff --git a/theora-uninstalled.pc.in b/theora-uninstalled.pc.in
new file mode 100644 (file)
index 0000000..6446850
--- /dev/null
@@ -0,0 +1,14 @@
+# theora uninstalled pkg-config file
+
+prefix=
+exec_prefix=
+libdir=${pcfiledir}/lib
+includedir=${pcfiledir}/include
+
+Name: theora uninstalled
+Description: Theora video codec (not installed)
+Version: @VERSION@
+Requires: ogg >= 1.1
+Conflicts:
+Libs: ${libdir}/libtheora.la
+Cflags: -I${includedir}
diff --git a/theora.pc.in b/theora.pc.in
new file mode 100644 (file)
index 0000000..96efec9
--- /dev/null
@@ -0,0 +1,14 @@
+# theora installed pkg-config file
+
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+includedir=@includedir@
+
+Name: theora
+Description: Theora video codec
+Version: @VERSION@
+Requires: ogg >= 1.1
+Conflicts:
+Libs: -L${libdir} -ltheora
+Cflags: -I${includedir}
diff --git a/theoradec-uninstalled.pc.in b/theoradec-uninstalled.pc.in
new file mode 100644 (file)
index 0000000..8bf9df1
--- /dev/null
@@ -0,0 +1,14 @@
+# theoradec uninstalled pkg-config file
+
+prefix=
+exec_prefix=
+libdir=${pcfiledir}/lib
+includedir=${pcfiledir}/include
+
+Name: theora uninstalled
+Description: Theora video codec(decoder) (not installed)
+Version: @VERSION@
+Requires: ogg >= 1.1
+Conflicts:
+Libs: ${libdir}/libtheoradec.la
+Cflags: -I${includedir}
diff --git a/theoradec.pc.in b/theoradec.pc.in
new file mode 100644 (file)
index 0000000..615718d
--- /dev/null
@@ -0,0 +1,14 @@
+# theoradec installed pkg-config file
+
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+includedir=@includedir@
+
+Name: theora
+Description: Theora video codec (decoder)
+Version: @VERSION@
+Requires: ogg >= 1.1
+Conflicts:
+Libs: -L${libdir} -ltheoradec
+Cflags: -I${includedir}
diff --git a/theoraenc-uninstalled.pc.in b/theoraenc-uninstalled.pc.in
new file mode 100644 (file)
index 0000000..00c6224
--- /dev/null
@@ -0,0 +1,14 @@
+# theoraenc uninstalled pkg-config file
+
+prefix=
+exec_prefix=
+libdir=${pcfiledir}/lib
+includedir=${pcfiledir}/include
+
+Name: theora uninstalled
+Description: Theora video codec (encoder) (not installed)
+Version: @VERSION@
+Requires: theoradec, ogg >= 1.1
+Conflicts:
+Libs: ${libdir}/libtheoraenc.la
+Cflags: -I${includedir}
diff --git a/theoraenc.pc.in b/theoraenc.pc.in
new file mode 100644 (file)
index 0000000..007ac8f
--- /dev/null
@@ -0,0 +1,14 @@
+# theoraenc installed pkg-config file
+
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+includedir=@includedir@
+
+Name: theora
+Description: Theora video codec (encoder)
+Version: @VERSION@
+Requires: theoradec, ogg >= 1.1
+Conflicts:
+Libs: -L${libdir} -ltheoraenc
+Cflags: -I${includedir}