2006-10-30 16:59:40 +00:00
<?xml version="1.0" encoding="utf-8"?>
2007-09-27 21:53:57 +00:00
<!-- in sync with r22140 -->
2007-09-27 14:28:51 +00:00
<!-- missing cosmetic commit 21537 -->
2006-06-05 05:02:47 +00:00
<chapter id= "encoding-guide" >
2006-09-27 08:59:17 +00:00
<title > Encodieren mit <application > MEncoder</application> </title>
<sect1 id= "menc-feat-dvd-mpeg4" >
2007-09-27 15:27:13 +00:00
<title > Erzeugen eines hochwertigen MPEG-4-Rips ("DivX") eines DVD-Films</title>
2006-09-27 08:59:17 +00:00
<para >
2006-10-30 16:59:40 +00:00
Eine häufig gestellte Frage ist
2007-09-27 15:27:13 +00:00
"Wie mache ich den hochwertigsten Rip für eine gegebene Größe?".
2006-09-27 08:59:17 +00:00
Eine weitere Frage ist
2007-09-27 15:27:13 +00:00
"Wie mache ich den qualitativ bestmöglichen DVD-Rip? Die Dateigröße ist
mir egal, ich will einfach nur die beste Qualität."
2006-09-27 08:59:17 +00:00
</para>
<para >
Die letzte Frage ist zumindest etwas falsch gestellt. Wenn du dir
2006-10-30 16:59:40 +00:00
schließlich keine Gedanken um die Dateigröße machst, warum kopierst Du
2006-09-27 08:59:17 +00:00
dann nicht einfach den kompletten MPEG-2-Videostream der DVD?
2006-10-30 16:59:40 +00:00
Sicherlich, deine AVI wird am Ende 5GB groß sein, so oder so, jedoch ist
dies mit Sicherheit deine beste Option, wenn du die beste Qualität
erhalten willst und dich nicht um die Größe kümmerst.
2006-09-27 08:59:17 +00:00
</para>
<para >
Tatsache ist, der Grund eine DVD in MPEG-4 umzuencodieren ist
2006-10-30 16:59:40 +00:00
gerade <emphasis role= "bold" > weil</emphasis> dir die Größe wichtig ist.
2006-09-27 08:59:17 +00:00
</para>
<para >
Es ist sehr schwierig, ein Rezept zum Erzeugen eines sehr
hochwertigen DVD-Rips anzubieten. Es gilt mehrere Faktoren zu
2006-10-30 16:59:40 +00:00
berücksichtigen, und du solltest dich mit diesen Details auskennen oder
du wirst voraussichtlich am Ende von den Resultaten enttäuscht.
Nachfolgend werden wir einige dieser Themen etwas näher untersuchen
2006-09-27 08:59:17 +00:00
und uns danach ein Beispiel ansehen. Wir gehen davon aus, dass Du
<systemitem class= "library" > libavcodec</systemitem> zum Encodieren des
Videos verwendest, obwohl diese Theorie genauso gut auf andere Codecs
zutrifft.
</para>
<para >
2006-10-30 16:59:40 +00:00
Ist dies alles zu viel für dich, solltest du womöglich auf eins der vielen
guten Frontends zurückgreifen, die in der
2006-09-27 08:59:17 +00:00
<ulink url= "http://www.mplayerhq.hu/design7/projects.html#mencoder_frontends" > MEncoder-Sektion</ulink>
2006-10-30 16:59:40 +00:00
unserer diesbezüglichen Projektseite zu finden sind.
2006-09-27 08:59:17 +00:00
Auf diese Weise solltest du in der Lage sein, hochwertige Rips zu
2006-10-30 16:59:40 +00:00
erhalten ohne viel nachdenken zu müssen, da die meisten dieser Tools dazu entworfen
wurden, clevere Entscheidungen für dich zu treffen.
2006-09-27 08:59:17 +00:00
</para>
<sect2 id= "menc-feat-dvd-mpeg4-preparing-encode" >
<title > Vorbereitung aufs Encodieren: Identifiziere Quellmaterial und Framerate</title>
<para >
2006-10-30 16:59:40 +00:00
Bevor du über das Encodieren eines Films nachdenkst, solltest du einige einleitende
2006-09-27 08:59:17 +00:00
Schritte vornehmen.
</para>
<para >
Der erste und allerwichtigste Schritt vor dem Encodieren sollte sein,
festzustellen, mit welchem Inhaltstyp du umgehst.
Kommt dein Quellmaterial von einer DVD oder einem Rundfunk-/Kabel-/Satelliten-TV,
2006-10-30 16:59:40 +00:00
wird es in einem von zwei Formaten abgespeichert: NTSC für Nord-Amerika und Japan,
PAL für Europa usw.
2006-09-27 08:59:17 +00:00
Es ist wichtig, sich klar zu machen, dass dies ganz einfach die Formatierung
2006-10-30 16:59:40 +00:00
für die Präsentation auf einem Fernsehgerät ist und häufig
2006-09-27 08:59:17 +00:00
<emphasis role= "bold" > nicht</emphasis> mit dem originalen Format des Films
korrespondiert. Die Erfahrung zeigt, dass NTSC-Material schwieriger zu
encodieren ist, da mehr Elemente in der Quelle zu identifizieren sind.
Um eine geeignete Encodierung zu produzieren, solltest du das originale
Format kennen.
2006-10-30 16:59:40 +00:00
Fehler, dies sollte man berücksichtigen, führen zu diversen Fehlerstellen
in deiner Encodierung, einschließlich hässlicher Kammartefakte (combing/interlacing)
2006-09-27 08:59:17 +00:00
und doppelten oder gar verlorenen Frames.
2006-10-30 16:59:40 +00:00
Abgesehen davon, dass sie unschön sind, beeinflussen diese Artefakte die
2006-09-27 08:59:17 +00:00
Codierungseffizienz negativ:
2006-10-30 16:59:40 +00:00
Du erhältst eine schlechtere Qualität pro Bitrateneinheit.
2006-09-27 08:59:17 +00:00
</para>
<sect3 id= "menc-feat-dvd-mpeg4-preparing-encode-fps" >
<title > Identifizieren der Quellframerate</title>
<para >
Hier ist eine Liste der verbreiteten Typen des Quellmaterials, in der Du
diese und ihre Eigenschaften voraussichtlich finden wirst:
</para>
<itemizedlist >
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > Standardfilm</emphasis> : Produziert für
2006-09-27 08:59:17 +00:00
theatralische Anzeige bei 24fps.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > PAL-Video</emphasis> : Aufgenommen mit einer
PAL-Videokamera bei 50 Feldern pro Sekunde.
Ein Feld besteht ganz einfach aus den ungerade oder gerade nummerierten
Zeilen eines Frames.
Das Fernsehen wurde entworfen, diese Felder als billige Form einer
analogen Komprimierung im Wechsel zu aktualisieren.
Das menschliche Auge kompensiert dies angeblich, aber wenn du
Interlacing einmal verstanden hast, wirst du lernen, es auch auf
dem TV-Bildschirm zu erkennen und nie wieder Spass am Fernsehen haben.
Zwei Felder machen <emphasis role= "bold" > keinen</emphasis> kompletten
Frame, da sie in einer 50-stel Sekunde zeitlich getrennt aufgenommen
werden und so nicht Schlange stehen solange keine Bewegung da ist.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > NTSC-Video</emphasis> : Aufgenommen mit einer
NTSC-Videokamera bei 60000/1001 Feldern pro Sekunde oder 60 Feldern
pro Sekunde zu Zeiten vor dem Farbfernsehen.
2006-10-30 16:59:40 +00:00
Ansonsten ähnlich wie PAL.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > Animation</emphasis> : Üblicherweise bei
2006-09-27 08:59:17 +00:00
24fps gezeichnet, kommt jedoch auch in Varianten mit gemischter
Framerate vor.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > Computer Graphics (CG)</emphasis> : Kann
2006-10-30 16:59:40 +00:00
irgendeine Framerate sein, jedoch sind einige üblicher als andere;
24 und 30 Frames pro Sekunde sind typisch für NTSC und 25fps ist
typisch für PAL.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > Alter Film</emphasis> : Diverse niedrigere
Frameraten.
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3 id= "menc-feat-dvd-mpeg4-preparing-encode-material" >
<title > Identifizieren des Quellmaterials</title>
<para >
Filme, die sich aus Frames zusammensetzen, werden den progressiven
2006-10-30 16:59:40 +00:00
zugeordnet, während die aus unabhängigen Feldern bestehenden
entweder interlaced (engl. für verschachteln) oder Video
2006-09-27 08:59:17 +00:00
genannt werden - somit ist letzterer Terminus zweideutig.
</para>
<para >
Um das ganze noch komplizierter zu machen, sind manche Filme ein
Gemisch aus einigen den oben beschriebenen Formen.
</para>
<para >
Das wichtigste Unterscheidungsmerkmal zwischen all diesen
Formaten ist, dass einige Frame-basiert, andere wiederum
Feld-basiert sind.
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > Immer</emphasis> wenn ein Film für die
Anzeige auf dem Fernseher vorbereitet wird (einschließlich
2006-09-27 08:59:17 +00:00
DVD), wird er in ein Feld-basiertes Format konvertiert.
2006-10-23 12:26:10 +00:00
Die verschiedenen Methoden, mit denen dies bewerkstelligt werden
2007-09-27 15:27:13 +00:00
kann, werden zusammengenommen als "telecine" bezeichnet, von welchen
das verrufene NTSC "3:2 pulldown" eine Abart darstellt.
2006-09-27 08:59:17 +00:00
Sofern das Originalmaterial nicht Feld-basiert war (bei gleicher
2006-10-30 16:59:40 +00:00
Feldrate), erhältst du einen Film in einem anderen Format als
2006-09-27 08:59:17 +00:00
das Original.
</para>
<itemizedlist >
<title > Es gibt einige verbreitete Typen des pulldown:</title>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > PAL 2:2 pulldown</emphasis> : Das schönste von
2006-09-27 08:59:17 +00:00
allen.
Jeder Frame wird durch das wechselweise Extrahieren und Anzeigen
2006-10-30 16:59:40 +00:00
der geradzahligen und ungeradzahligen Zeilen für die Dauer von zwei
2006-09-27 08:59:17 +00:00
Feldern dargestellt.
Hat das Originalmaterial 24fps, beschleunigt dieser Prozess den Film
um 4%.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > PAL 2:2:2:2:2:2:2:2:2:2:2:3 pulldown</emphasis> :
2006-10-30 16:59:40 +00:00
Jeder 12-te Frame, anstatt nur jeder 2-te, wird für die Dauer von zwei
2006-09-27 08:59:17 +00:00
Feldern dargestellt.
Dies vermeidet die 4% Geschwindigkeitssteigerung, macht jedoch das
Umkehren des Prozesses viel schwieriger.
2006-10-30 16:59:40 +00:00
Es ist üblicherweise in Musical-Produktionen zu sehen, wo das Anpassen der
Geschwindigkeit um 4% sicherlich das musikalische Ergebnis kaputt machen würde.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem > <para >
<emphasis role= "bold" > NTSC 3:2 telecine</emphasis> : Frames werden
2006-10-30 16:59:40 +00:00
abwechselnd für die Dauer von 3 oder 2 Feldern angezeigt.
2006-09-27 08:59:17 +00:00
Dies verleiht der Feldrate das 2.5-fache der originalen Framerate.
Das Resultat wird dadurch auch leicht von 60 Feldern pro Sekunde auf
60000/1001 Felder pro Sekunde verlangsamt, um die NTSC-Felddrate
beizubehalten.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > NTSC 2:2 pulldown</emphasis> : Verwendet zur
Darstellung von 30fps Material auf NTSC.
2006-10-30 16:59:40 +00:00
Schön, genau wie das 2:2 PAL pulldown.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</itemizedlist>
<para >
Es gibt auch Methoden zur Konvertierung zwischen NTSC- und PAL-Video,
jedoch liegen diese Themen jenseits des Rahmens dieser Anleitung.
2006-10-30 16:59:40 +00:00
Wenn du auf solch einen Film stößt und ihn encodieren willst, solltest
2006-09-27 08:59:17 +00:00
du besser eine Kopie im originalen Format suchen.
Die Konvertierung zwischen diesen beiden Formaten ist hochdestruktiv und
2006-10-30 16:59:40 +00:00
kann nicht spurlos rückgängig gemacht werden, somit wird deine Encodierung
außerordentlich darunter leiden, wenn sie aus einer konvertierten Quelle
2006-09-27 08:59:17 +00:00
erzeugt wurde.
</para>
<para >
Wenn ein Video auf DVD gespeichert wird, werden fortlaufend Feldpaare
als Frames gruppiert, auch wenn nicht beabsichtigt ist, diese gleichzeitig
zu zeigen.
Der bei DVD und digitalem TV verwendete MPEG-2-Standard bietet einen Weg
2006-10-30 16:59:40 +00:00
für beides, die originalen progressiven Frames zu encodieren und die Anzahl
der Felder, für die ein Frame gezeigt werden soll, im Header dieses Frames
2006-09-27 08:59:17 +00:00
zu speichern.
2007-09-27 15:27:13 +00:00
Wurde diese Methode angewandt, wird dieser Film oft als "soft telecined"
2006-09-27 08:59:17 +00:00
beschrieben, da der Prozess eher nur den DVD-Player anweist, pulldown
2006-10-30 16:59:40 +00:00
auf den Film anzuwenden, als den Film selbst abzuändern.
Dieser Fall sollte möglichst bevorzugt werden, da er (eigentlich ignoriert)
leicht vom Encoder rückgängig gemacht werden kann und da er die maximale
Qualität beibehält.
2006-09-27 08:59:17 +00:00
Wie auch immer, viele DVD- und Rundfunkproduktionsstudios verwenden
keine passenden Encodierungstechniken, sie produzieren stattdessen Filme mit
2007-09-27 15:27:13 +00:00
"hard telecine", bei denen Felder sogar in encodiertes MPEG-2 dupliziert
2006-09-27 08:59:17 +00:00
werden.
</para>
<para >
2006-10-30 16:59:40 +00:00
Die Vorgehensweisen für den Umgang mit solchen Fällen werden
<link linkend= "menc-feat-telecine" > später in diesem Handbuch</link>
2006-09-27 08:59:17 +00:00
behandelt.
Wir lassen dich jetzt mit einigen Anleitungen zur Identifizierung der
2006-10-30 16:59:40 +00:00
Materialtypen zurück, mit denen du es zu tun hast:
2006-09-27 08:59:17 +00:00
</para>
<itemizedlist >
<title > NTSC-Bereiche:</title>
<listitem >
<para >
Wenn <application > MPlayer</application> angibt, dass die Framerate
2006-10-30 16:59:40 +00:00
während des Betrachtens des Films zu 24000/1001 gewechselt hat
und diese nie wieder zurückwechselt, handelt es sich meist mit
2007-09-27 15:27:13 +00:00
Sicherheit um progressiven Inhalt, der "soft telecined" wurde.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
Wenn <application > MPlayer</application> anzeigt, dass die Framerate
2006-10-30 16:59:40 +00:00
zwischen 24000/1001 und 30000/1001 vor und zurück wechselt, und Du
siehst hin und wieder Kammartefakte, dann gibt es mehrere Möglichkeiten.
2006-09-27 08:59:17 +00:00
Die Segmente mit 24000/1001 fps sind meist mit Sicherheit progressiver
2007-09-27 15:27:13 +00:00
Inhalt, "soft telecined", jedoch könnten die Teile mit 30000/1001 fps
entweder "hard telecined" 24000/1001 fps Inhalt oder 60000/1001 Felder
2006-09-27 08:59:17 +00:00
pro Sekunde NTSC-Video sein.
2006-10-30 16:59:40 +00:00
Verwende die selben Richtwerte wie in den folgenden zwei Fällen, um zu
2006-09-27 08:59:17 +00:00
bestimmen, um was es sich handelt.
</para>
</listitem>
<listitem >
<para >
Wenn <application > MPlayer</application> nie einen Frameratenwechsel
2006-10-30 16:59:40 +00:00
anzeigt und jeder einzelne Frame mit Bewegung gekämmt (combed) erscheint,
2006-09-27 08:59:17 +00:00
ist dein Film ein NTSC-Video bei 60000/1001 Feldern pro Sekunde.
</para>
</listitem>
<listitem >
<para >
Wenn <application > MPlayer</application> nie einen Frameratenwechsel
2006-10-30 16:59:40 +00:00
anzeigt und zwei von fünf Frames gekämmt (combed) erscheinen, ist der
2007-09-27 15:27:13 +00:00
Inhalt deines Films "hard telecined" 24000/1001 fps.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</itemizedlist>
<itemizedlist >
<title > PAL-Bereiche:</title>
<listitem >
<para >
Wenn du niemals irgend ein Combing siehst, ist dein Film 2:2 pulldown.
</para>
</listitem>
<listitem >
<para >
Siehst du alle halbe Sekunde abwechselnd ein- und ausgehendes Combing,
dann ist dein Film 2:2:2:2:2:2:2:2:2:2:2:3 pulldown.
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Hast du immer während Bewegungen Combing gesehen, dann ist dein Film
2006-09-27 08:59:17 +00:00
PAL-Video bei 50 Feldern pro Sekunde.
</para>
</listitem>
</itemizedlist>
<note >
<title > Tipp:</title>
<para >
<application > MPlayer</application> kann das Filmplayback
2006-10-30 16:59:40 +00:00
mittels der Option -speed verlangsamen oder Frame für Frame abspielen.
2006-09-27 08:59:17 +00:00
Versuche <option > -speed</option> 0.2 zu verwenden, um den Film sehr lamgsam
2007-09-27 15:27:13 +00:00
anzusehen oder drücke wiederholt die Taste "<keycap > .</keycap> ", um jeweils
2006-09-27 08:59:17 +00:00
einen Frame abzuspielen und identifiziere dann das Muster, falls du bei voller
Geschwindigkeit nichts erkennen kannst.
</para>
</note>
</sect3>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-2pass" >
<title > Konstanter Quantisierungsparameter vs. Multipass</title>
<para >
2006-10-30 16:59:40 +00:00
Es ist möglich, deinen Film in einer großen Auswahl von Qualitäten zu
2006-09-27 08:59:17 +00:00
encodieren.
Mit modernen Videoencodern und ein wenig Pre-Codec-Kompression
2006-10-30 16:59:40 +00:00
(Herunterskalierung und Rauschunterdrückung), kann eine sehr gute
Qualität bei 700 MB für einen 90-110-minütigen Breitwandfilm erreicht werden.
Des Weiteren können alle Filme - sogar die längsten - mit nahezu perfekter
Qualität bei 1400 MB encodiert werden.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Es gibt drei Annäherungen für das Encodieren eines Videos: konstante Bitrate
2006-09-27 08:59:17 +00:00
(CBR), konstanter Quantisierungsparameter und Multipass (ABR, oder mittlere Bitrate).
</para>
<para >
2006-10-30 16:59:40 +00:00
Die Komplexität der Frames eines Filmes und somit die Anzahl der für
2006-09-27 08:59:17 +00:00
deren Komprimierung erforderlichen Bits kann von einer Szene zur anderen
2006-10-30 16:59:40 +00:00
außerordentlich variieren.
Moderne Videoencoder können sich durch Variieren der Bitrate an diese
2006-09-27 08:59:17 +00:00
Anforderungen anpassen.
In einfachen Modi wie CBR kennen die Encoder jedoch nicht den
2006-10-30 16:59:40 +00:00
Bitratenbedarf zukünftiger Szenen und sind somit nicht in der Lage,
die angeforderte mittlere Bitrate über längere Zeitspannen zu
überschreiten.
Erweiterte Modi wie etwa Multipass-Encodierung können die Statistik
früherer Durchgänge berücksichtigen; dies behebt das oben erwähnte
2006-09-27 08:59:17 +00:00
Problem.
</para>
<note > <title > Anmerkung:</title>
<para >
2006-10-30 16:59:40 +00:00
Die meisten Codecs, die ABR-Encodierung unterstützen, unterstützen nur
die Encodierung in zwei Durchgängen (two pass) während einige andere wie
2006-09-27 08:59:17 +00:00
etwa <systemitem class= "library" > x264</systemitem> ,
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem>
2006-09-27 08:59:17 +00:00
und <systemitem class= "library" > libavcodec</systemitem> Multipass
2006-10-30 16:59:40 +00:00
unterstützen, was die Qualität bei jedem Durchgang leicht verbessert.
2006-09-27 08:59:17 +00:00
Jedoch ist diese Verbesserung weder messbar noch ist sie nach dem
2006-10-30 16:59:40 +00:00
4-ten Durchgang oder so spürbar.
Aus diesem Grund werden in diesem Abschnitt die Encoderierung mit 2 Durchläufen
2006-09-27 08:59:17 +00:00
(two pass) und Multipass abwechselnd angewandt.
</para>
</note>
<para >
In jedem dieser Modi bricht der Videocodec (wie etwa
<systemitem class= "library" > libavcodec</systemitem> )
2006-10-30 16:59:40 +00:00
den Videoframe in 16x16 Pixel Macroblöcke und wendet danach einen
2006-09-27 08:59:17 +00:00
Quantisierer auf jeden Macroblock an. Je niedriger der Quantisierer desto
2006-10-30 16:59:40 +00:00
besser die Qualität und desto höher die Bitrate.
2006-09-27 08:59:17 +00:00
Die Methode, die der Filmencoder zur Bestimmung des auf einen gegebenen
Macroblock anzuwendenden Quantisierer verwendet, variiert und ist in
2006-10-30 16:59:40 +00:00
hohem Maße einstellbar. (Dies ist eine extrem übertriebene Vereinfachung
des aktuellen Prozesses aber nützlich, um das Grundkonzept zu verstehen.)
2006-09-27 08:59:17 +00:00
</para>
<para >
Wenn du eine konstante Bitrate festlegst, wird der Videocodec das Video
so encodieren, dass so viele Details wie notwendig und so wenig
2006-10-30 16:59:40 +00:00
wie möglich ausgesondert werden, um unterhalb der vorgegebenen Bitrate zu
bleiben. Wenn du dich wirklich nicht um die Dateigröße kümmerst, könntest
2006-09-27 08:59:17 +00:00
du auch CBR verwenden und eine nahezu endlose Bitrate festlegen.
(In der Praxis bedeutet dies einen Wert, der hoch genug ist, kein Limit
2006-10-30 16:59:40 +00:00
aufzuwerfen wie 10000Kbit.) Ohne echte Einschränkung der Bitrate wird
der Codec als Ergebnis den niedrigsten möglichen Quantisierer für jeden
Macroblock anwenden (wie durch <option > vqmin</option> für
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavcodec</systemitem>
spezifiziert, Standardwert ist 2).
Sobald du eine Bitrate festlegst, die niedrig genug ist, den
2006-10-30 16:59:40 +00:00
Codec zur Anwendung eines höheren Quantisierers zu zwingen, bist Du
nahezu sicher dabei, die Qualität deines Videos zu ruinieren.
Um dies zu vermeiden, solltst du möglicherweise dein Video wie
in der später in diesem Handbuch beschriebenen Methode reduzieren.
Im Allgemeinen solltst du CBR vollkommen meiden, wenn dir Qualität
2006-09-27 08:59:17 +00:00
wichtig ist.
</para>
<para >
Mit konstantem Quantisierer wendet der Codec denselben Quantisierer, wie
2006-10-30 16:59:40 +00:00
durch die Option <option > vqscale</option> (für
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavcodec</systemitem> ) spezifiziert, auf jeden
Macroblock an.
2006-10-30 16:59:40 +00:00
Willst du einen Rip mit höchstmöglicher Qualität und ignorierst dabei
2006-09-27 08:59:17 +00:00
wiederum die Bitrate, kannst du <option > vqscale=2</option> verwenden.
Dies wird dieselbe Bitrate und PSNR (peak signal-to-noise ratio) liefern
wie CBR mit <option > vbitrate</option> =infinity und der Standardeinstellung
<option > vqmin</option> =2.
</para>
<para >
Das Problem mit konstantem Quantisierer ist, dass der vorgegebene Quantisierer
2006-10-30 16:59:40 +00:00
zum Einsatz kommt, egal ob der Macroblock ihn benötigt oder nicht. Dies heißt,
es wäre möglich, einen höheren Quantisierer auf einen Macroblock anzuwenden,
ohne sichtbare Qualität zu opfern. Warum die Bits für einen unnötig kleinen
Quantisierer verschwenden? Deine CPU hat soundso viele Arbeitsgänge Zeit zur
Verfügung, die Festplatte jedoch nur soundso viele Bits.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Bei einer Encodierung mit zwei Durchläufen (two pass), wird der erste Durchgang
den Film so rippen, als würde CBR vorliegen, jedoch wird ein Log die Eigenschaften
jedes Frames beibehalten. Diese Daten werden danach während des zweiten Durchgangs
2006-09-27 08:59:17 +00:00
dazu verwendet, intelligente Entscheidungen zur Wahl des Quantisierers zu treffen.
2006-10-30 16:59:40 +00:00
Während schneller Action oder hochdetaillierter Szenen werden womöglich
höhere Quantisierer, während langsamen Bewegungen und Szenen mit weniger Details
2006-09-27 08:59:17 +00:00
niedrigere Quantisierer verwendet.
Normalerweise ist die Anzahl der Bewegungen wichtiger als die der Details.
</para>
<para >
Wenn du <option > vqscale=2</option> verwendest, verschwendest du Bits. Wenn
2006-10-30 16:59:40 +00:00
du <option > vqscale=3</option> anwendest, wirst du keinen Rip mit bestmöglicher
Qualität erhalten. Angenommen du rippst eine DVD mit <option > vqscale=3</option>
und das Resultat ist 1800Kbit. Wenn du in zwei Durchgängen mit
2006-09-27 08:59:17 +00:00
<option > vbitrate=1800</option> encodierst, wird das daraus resultierende Video
2006-10-30 16:59:40 +00:00
eine <emphasis role= "bold" > bessere Qualität</emphasis> bei
2006-09-27 08:59:17 +00:00
<emphasis role= "bold" > gleicher Bitrate</emphasis> haben.
</para>
<para >
2006-10-30 16:59:40 +00:00
Da du nun davon überzeugt bist, dass zwei Durchgänge (two pass) den besten
Weg darstellen, stellt sich jetzt tatsächlich die Frage, welche Bitrate
2006-09-27 08:59:17 +00:00
verwendet werden soll? Die Antwort ist, dass es nicht nur eine
2006-10-30 16:59:40 +00:00
Antwort gibt. Idealerweise willst du eine Bitrate wählen, die die beste Balance
zwischen Qualität und Dateigröße ergibt. Die kann abhängig vom Quellvideo
2006-09-27 08:59:17 +00:00
variieren.
</para>
<para >
2006-10-30 16:59:40 +00:00
Interessiert die Größe nicht, stellen etwa 2000Kbit plus oder minus 200Kbit
einen guten Ausgangspunkt für einen sehr hochqualitativen Rip dar.
2006-09-27 08:59:17 +00:00
Bei einem Video mit schneller Action oder hohen Details, oder wenn du schlicht
2006-10-30 16:59:40 +00:00
und ergreifend ein sehr kritisches Auge besitzst, könntest du dich für 2400
2006-09-27 08:59:17 +00:00
oder 2600 entscheiden.
Bei einigen DVDs kannst du eventuell keinen Unterschied bei 1400Kbit feststellen.
2006-10-30 16:59:40 +00:00
Um ein besseres Gefühl zu bekommen, ist es eine gute Idee, mit Szenen bei
2006-09-27 08:59:17 +00:00
unterschiedlichen Bitraten herumzuexperimentieren.
</para>
<para >
2006-10-30 16:59:40 +00:00
Wenn du eine bestimmte Größe anvisierst, musst du die Bitrate irgendwie
2006-09-27 08:59:17 +00:00
kalkulieren.
2006-10-30 16:59:40 +00:00
Aber zuvor solltest du wissen, wieviel Platz du für den/die Audiotrack(s)
2006-09-27 08:59:17 +00:00
reservieren musst, daher solltest Du
<link linkend= "menc-feat-dvd-mpeg4-audio" > diese(n) zuerst rippen</link> .
Du kannst die Bitrate mit folgender Gleichung berechnen:
<systemitem > Bitrate = (zielgroesse_in_MByte - soundgroesse_in_MByte) * 1024 * 1024 / laenge_in_sek * 8 / 1000</systemitem>
2006-10-30 16:59:40 +00:00
Um zum Beispiel einen zweistündigen Film auf eine 702MB CD mit einem 60MB
Audiotrack zu bekommen, sollte die Videobitrate folgendermaßen sein:
2006-09-27 08:59:17 +00:00
<systemitem > (702 - 60) * 1024 * 1024 / (120*60) * 8 / 1000 = 740kbps</systemitem>
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-constraints" >
2006-10-30 16:59:40 +00:00
<title > Randbedingungen für effizientes Encodieren</title>
2006-09-27 08:59:17 +00:00
<para >
Aufgrund der Natur der MPEG-Komprimierung gibt es zahlreiche
2006-10-30 16:59:40 +00:00
Randbedingungen, denen du zum Erreichen maximaler Qualität folgen
2006-09-27 08:59:17 +00:00
solltest.
2006-10-30 16:59:40 +00:00
MPEG splittet das Video in Macroblöcke genannte 16x16 Quadrate auf,
jeder davon zusammengesetzt aus 4 8x8 Blöcken mit
Luma-(Intensitäts)-Informationen und zwei halb-auflösenden 8x8
Chroma-(Farb)-Blöcken (einer für die Rot-Cyan-Achse und der andere für
2006-09-27 08:59:17 +00:00
die Blau-Gelb-Achse).
2006-10-30 16:59:40 +00:00
Selbst wenn Breite und Höhe deines Films kein Vielfaches von 16 sind,
wird der Encoder ausreichend 16x16 Macroblöcke zur Abdeckung des
2006-09-27 08:59:17 +00:00
gesamten Bildbereichs verwenden und der Extraplatz wird verschwendet.
Folglich ist es keine gute Idee, im Interesse der Maximierung der
2006-10-30 16:59:40 +00:00
Qualität bei fester Dateigröße, Abmessungen zu verwenden, die kein
2006-09-27 08:59:17 +00:00
Vielfaches von 16 sind.
</para>
<para >
2006-10-30 16:59:40 +00:00
Die meisten DVDs besitzen ein bestimmtes Maß schwarzer Balken
2006-12-19 00:01:16 +00:00
an ihren Rändern. Diese dort zu belassen wird für die Qualität in mehrfacher
Hinsicht <emphasis role= "bold" > sehr</emphasis> schädlich sein.
2006-09-27 08:59:17 +00:00
</para>
<orderedlist >
<listitem >
<para >
2007-09-27 17:45:28 +00:00
MPEG-Kompression hängt in höchstem Maße von den
2006-09-27 08:59:17 +00:00
Frequenzbereichs-Transformationen ab, insbesondere von der
2006-10-30 16:59:40 +00:00
Discrete Cosine Transform (DCT), die der Fourier Transform ähnelt.
Diese Art Encodierung ist für darstellende Muster und weiche
Übergänge effizient, hat jedoch große Probleme mit scharfen Kanten.
2006-09-27 08:59:17 +00:00
Um diese zu encodieren muss sie viel mehr Bits verwenden,
oder es wird andernfalls ein als Ringing bekannter Artefakt
auftreten.
</para>
<para >
Die Discrete Frequency Transform (DCT) erfolgt separat auf jeden
Macroblock (eigentlich auf jeden Block), somit trifft dieses Problem
nur zu, wenn sich in einem Block eine scharfe Kante befindet.
Beginnt dein schwarzer Rand exakt an den Grenzen zum Vielfachen von
16 Pixeln, stellt dies kein Problem dar.
2006-10-30 16:59:40 +00:00
Seis drum, die schwarzen Ränder bei DVDs werden in den seltensten
Fällen schön angeordnet, daher wirst du sie in der Praxis immer
abschneiden müssen, um diesen Nachteil zu vermeiden.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</orderedlist>
<para >
2006-10-30 16:59:40 +00:00
Zusätzlich zu den Frequenzbereichs-Transformationen verwendet die
2006-09-27 08:59:17 +00:00
MPEG-Kompression Bewegungsvektoren, um den Wechsel von einem Frame
zum anderen darzustellen.
Bewegungsvektoren arbeiten bei Inhalt, der von den Kanten eines Bildes
2006-10-30 16:59:40 +00:00
her einfließt, normalerweise weniger effizient, da dieser im vorherigen
2006-09-27 08:59:17 +00:00
Frame nicht vorhanden ist. Solange sich das Bild bis voll zur Kante des
2006-10-30 16:59:40 +00:00
encodierten Bereichs hin vergrößert, haben Bewegungsvektoren kein Problem
mit Inhalt, der sich aus den Kanten des Bildes hinausbewegt. Die Präsenz
schwarzer Ränder kann jedoch Ärger machen:
2006-09-27 08:59:17 +00:00
</para>
<orderedlist continuation= "continues" >
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Die MPEG-Kompression speichert für jeden Macroblock einen Vektor,
2006-09-27 08:59:17 +00:00
um ausfindig zu machen, welcher Teil des vorherigen Frames in diesen
2006-10-30 16:59:40 +00:00
Macroblock als Basis zur Vorhersage des nächsten Frames kopiert
werden soll. Nur die verbleibenden Unterschiede müssen encodiert werden.
Überspannt der Macroblock die Kante des Bildes und enthält einen
2006-09-27 08:59:17 +00:00
Teil des schwarzen Randes, werden Bewegungsvektoren aus anderen
2006-10-30 16:59:40 +00:00
Teilen des Bildes den schwarzen Rand überschreiben. Dies bedeutet, dass
jede Menge Bits entweder zur wiederholten Schwärzung des überschriebenen
Randes aufgewendet werden müssen, oder es wird (eher) erst gar kein
Bewegungsvektor genutzt und alle Änderungen innerhalb dieses Macroblocks
müssen explizit encodiert werden. So oder so wird die Encodiereffizienz
außerordentlich reduziert.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Nochmal, dieses Problem trifft nur dann zu, wenn schwarze Ränder
2006-09-27 08:59:17 +00:00
nicht an den Grenzen eines Vielfachen von 16 anstehen.
</para>
</listitem>
<listitem >
<para >
Zuletzt noch was, angenommen wir haben einen Macroblock im Inneren des
2006-10-30 16:59:40 +00:00
Bildes und ein Objekt bewegt sich aus Richtung Nähe der Kante des Bildes
2006-09-27 08:59:17 +00:00
her in diesen Block hinein. Die MPEG-Encodierung kann nicht sagen
2007-09-27 15:27:13 +00:00
"kopiere den Teil, der innerhalb des Bildes liegt, den schwarzen Rand
aber nicht". Somit wird der schwarze Rand ebenfalls mit hinein kopiert
2006-10-30 16:59:40 +00:00
und jede Menge Bits müssen zur Encodierung des Teils des Bildes, der
2006-09-27 08:59:17 +00:00
dort angenommen wird, aufgewendet werden.
</para>
<para >
2006-10-30 16:59:40 +00:00
Läuft das Bild ständig zur Kante des encodierten Bereichs hin, besitzt
2006-09-27 08:59:17 +00:00
MPEG spezielle Optimierungen, um immer wieder dann die Pixel am Rand des
2006-10-30 16:59:40 +00:00
Bildes zu kopieren, wenn ein Bewegungsvektor von außerhalb des
2006-09-27 08:59:17 +00:00
encodierten Bereichs ankommt. Dieses Feature wird nutzlos, wenn der Film
2006-10-30 16:59:40 +00:00
schwarze Ränder hat. Im Gegensatz zu den Problemen 1 und 2 hilft hier
kein Anordnen der Ränder am Vielfachen von 16.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Obwohl die Ränder komplett schwarz sind und sich nie ändern, ist
zumindest ein minimaler Overhead damit verbunden, mehr Macroblöcke
2006-09-27 08:59:17 +00:00
zu besitzen.
</para>
</listitem>
</orderedlist>
<para >
2006-10-30 16:59:40 +00:00
Aus all diesen Gründen wird empfohlen, schwarze Ränder komplett abzuschneiden.
2006-09-27 08:59:17 +00:00
Mehr noch, liegt ein Bereich mit Rauschen/Verzerrung an der Kante des Bildes,
steigert dessen Abschneiden ebenso die Encodiereffizienz. Videophile Puristen,
2006-10-30 16:59:40 +00:00
die den Originalzustand so nah wie möglich sichern wollen,
mögen dieses Abschneiden (cropping) beanstanden, wenn du jedoch nicht planst,
bei konstantem Quantisierer zu encodieren, wird der Qualitätsgewinn, den Du
durch dieses Abschneiden erreichst, beträchtlich über dem Verlust an Informationen
2006-09-27 08:59:17 +00:00
an den Kanten liegen.
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-crop" >
<title > Abschneiden und Skalieren</title>
<para >
Wiederaufruf der vorherigen Sektion, dass die letzte von Dir
2006-10-30 16:59:40 +00:00
encodierte Bildgröße ein Vielfaches von 16 sein sollte (bei beidem,
Breite und Höhe).
2006-09-27 08:59:17 +00:00
Diese kann durch Abschneiden, Skalieren erreicht werden oder durch
eine Kombination von beidem.
</para>
<para >
2006-10-30 16:59:40 +00:00
Beim Abschneiden gibt es ein paar Richtwerte, die befolgt werden müssen,
um eine Zerstörung des Films zu vermeiden.
2006-09-27 08:59:17 +00:00
Das normale YUV-Format, 4:2:0, speichert Chroma-(Farb)-Informationen
in einer Unterstichprobe (subsampled), z.B. wird Chroma nur halb so oft
2006-10-30 16:59:40 +00:00
in jede Richtung gesampelt wie Luma-(Intensitäts)-Informationen.
2006-09-27 08:59:17 +00:00
Beobachte dieses Diagramm, in dem L Luma-Samplingpunkte bedeuten und C
2006-10-30 16:59:40 +00:00
für Chroma steht.
2006-09-27 08:59:17 +00:00
</para>
<informaltable >
<?dbhtml table-width="40%" ?>
<?dbfo table-width="40%" ?>
<tgroup cols= "8" align= "center" >
<colspec colnum= "1" colname= "col1" />
<colspec colnum= "2" colname= "col2" />
<colspec colnum= "3" colname= "col3" />
<colspec colnum= "4" colname= "col4" />
<colspec colnum= "5" colname= "col5" />
<colspec colnum= "6" colname= "col6" />
<colspec colnum= "7" colname= "col7" />
<colspec colnum= "8" colname= "col8" />
<spanspec spanname= "spa1-2" namest= "col1" nameend= "col2" />
<spanspec spanname= "spa3-4" namest= "col3" nameend= "col4" />
<spanspec spanname= "spa5-6" namest= "col5" nameend= "col6" />
<spanspec spanname= "spa7-8" namest= "col7" nameend= "col8" />
<tbody >
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
<row >
<entry spanname= "spa1-2" > C</entry>
<entry spanname= "spa3-4" > C</entry>
<entry spanname= "spa5-6" > C</entry>
<entry spanname= "spa7-8" > C</entry>
</row>
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
<row >
<entry spanname= "spa1-2" > C</entry>
<entry spanname= "spa3-4" > C</entry>
<entry spanname= "spa5-6" > C</entry>
<entry spanname= "spa7-8" > C</entry>
</row>
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
</tbody>
</tgroup>
</informaltable>
<para >
2006-10-30 16:59:40 +00:00
Wie du sehen kannst, kommen Zeilen und Spalten des Bildes natürlich paarweise.
Folglich <emphasis > müssen</emphasis> deine Abschneide-Offsets und
2006-09-27 08:59:17 +00:00
Abmessungen geradzahlig sein.
Sind sie dies nicht, wird Chroma nicht mehr korrekt mit Luma abgeglichen.
2006-10-30 16:59:40 +00:00
In der Theorie ist es möglich, mit ungeraden Offsets abzuschneiden, jedoch
2006-09-27 08:59:17 +00:00
erfordert dies ein Resampling von Chroma, was potentiell eine mit Verlust
2006-10-30 16:59:40 +00:00
verbundene Operation bedeutet und vom Crop-Filter nicht unterstützt
2006-09-27 08:59:17 +00:00
wird.
</para>
<para >
2006-10-30 16:59:40 +00:00
Weiterhin wird interlaced Video folgendermaßen gesampelt:
2006-09-27 08:59:17 +00:00
</para>
<informaltable >
<?dbhtml table-width="80%" ?>
<?dbfo table-width="80%" ?>
<tgroup cols= "16" align= "center" >
<colspec colnum= "1" colname= "col1" />
<colspec colnum= "2" colname= "col2" />
<colspec colnum= "3" colname= "col3" />
<colspec colnum= "4" colname= "col4" />
<colspec colnum= "5" colname= "col5" />
<colspec colnum= "6" colname= "col6" />
<colspec colnum= "7" colname= "col7" />
<colspec colnum= "8" colname= "col8" />
<colspec colnum= "9" colname= "col9" />
<colspec colnum= "10" colname= "col10" />
<colspec colnum= "11" colname= "col11" />
<colspec colnum= "12" colname= "col12" />
<colspec colnum= "13" colname= "col13" />
<colspec colnum= "14" colname= "col14" />
<colspec colnum= "15" colname= "col15" />
<colspec colnum= "16" colname= "col16" />
<spanspec spanname= "spa1-2" namest= "col1" nameend= "col2" />
<spanspec spanname= "spa3-4" namest= "col3" nameend= "col4" />
<spanspec spanname= "spa5-6" namest= "col5" nameend= "col6" />
<spanspec spanname= "spa7-8" namest= "col7" nameend= "col8" />
<spanspec spanname= "spa9-10" namest= "col9" nameend= "col10" />
<spanspec spanname= "spa11-12" namest= "col11" nameend= "col12" />
<spanspec spanname= "spa13-14" namest= "col13" nameend= "col14" />
<spanspec spanname= "spa15-16" namest= "col15" nameend= "col16" />
<tbody >
<row >
<entry namest= "col1" nameend= "col8" > Oberes Feld</entry>
<entry namest= "col9" nameend= "col16" > Unteres Feld</entry>
</row>
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry spanname= "spa1-2" > C</entry>
<entry spanname= "spa3-4" > C</entry>
<entry spanname= "spa5-6" > C</entry>
<entry spanname= "spa7-8" > C</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry spanname= "spa9-10" > C</entry>
<entry spanname= "spa11-12" > C</entry>
<entry spanname= "spa13-14" > C</entry>
<entry spanname= "spa15-16" > C</entry>
</row>
<row >
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry spanname= "spa1-2" > C</entry>
<entry spanname= "spa3-4" > C</entry>
<entry spanname= "spa5-6" > C</entry>
<entry spanname= "spa7-8" > C</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
<row >
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry spanname= "spa9-10" > C</entry>
<entry spanname= "spa11-12" > C</entry>
<entry spanname= "spa13-14" > C</entry>
<entry spanname= "spa15-16" > C</entry>
</row>
<row >
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
<entry > L</entry>
</row>
</tbody>
</tgroup>
</informaltable>
<para >
Wie du erkennen kannst, wiederholt sich das Muster bis nach 4 Zeilen nicht.
2006-10-30 16:59:40 +00:00
Somit müssen bei interlaced Video dein y-Offset und die Höhe für das
2006-09-27 08:59:17 +00:00
Ausschneiden ein Vielfaches von 4 sein.
</para>
<para >
2006-10-30 16:59:40 +00:00
Die ursprüngliche DVD-Auflösung ist 720x480 für NTSC und 720x576 für PAL, es
2006-09-27 08:59:17 +00:00
gibt jedoch ein Aspektkennzeichen, das spezifiziert, ob Vollbild (4:3) oder
Breitwandfilm (16:9) vorliegt. Viele (wenn nicht die meisten) Breitwandfilm-DVDs
2006-10-30 16:59:40 +00:00
sind nicht grundsätzlich 16:9, sondern entweder 1.85:1 oder 2.35:1 (Cinescope).
Dies bedeutet, dass es schwarze Bänder im Video geben wird, die herausgeschnitten
werden müssen.
2006-09-27 08:59:17 +00:00
</para>
<para >
<application > MPlayer</application> stellt einen Crop-Erkennungsfilter
2006-10-30 16:59:40 +00:00
zur Verfügung, der das Ausschnittsrechteck (<option > -vf cropdetect</option> )
2006-09-27 08:59:17 +00:00
bestimmt.
Starte <application > MPlayer</application> mit
<option > -vf cropdetect</option> , und er wird die Crop-Einstellungen
2006-10-30 16:59:40 +00:00
zum Entfernen der Ränder ausgeben.
du solltest den Film lange genug laufen lassen, damit die gesamte Bildfläche
2006-09-27 08:59:17 +00:00
verwendet wird, um akkurate Crop-Werte zu erhalten.
</para>
<para >
Teste danach die Werte, die von <application > MPlayer</application>
2006-10-30 16:59:40 +00:00
über die Befehlszeile mittels <option > cropdetect</option> ausgegeben wurden
und passe das Rechteck nach deinen Bedürfnissen an.
2006-09-27 08:59:17 +00:00
Der Filter <option > rectangle</option> kann dabei helfen, indem er dir erlaubt,
2006-10-30 16:59:40 +00:00
das Rechteck interaktiv über dem Film zu positionieren.
2006-09-27 08:59:17 +00:00
Vergiss nicht, den oben genannten Teilbarkeitsrichtwerten zu folgen, sodass du
die Chroma-Ebenen nicht verkehrt anordnest.
</para>
<para >
2006-10-30 16:59:40 +00:00
In bestimmten Fällen könnte Skalieren nicht wünschenswert sein.
2006-09-27 08:59:17 +00:00
Skalierung in vertikaler Richtung ist mit interlaced Video
schwierig, und wenn du das Interlacing beibehalten willst, solltest
2006-10-30 16:59:40 +00:00
du für gewöhnlich das Skalieren bleiben lassen.
2006-09-27 08:59:17 +00:00
Hast du nicht vor zu skalieren, willst aber nach wie vor Abmessungen
2006-10-30 16:59:40 +00:00
in einem Vielfachen von 16 verwenden, musst du über den Rand
2006-09-27 08:59:17 +00:00
hinausschneiden.
2006-10-30 16:59:40 +00:00
Schneide aber lieber nicht über den Rand hinaus, da schwarze Ränder
2006-09-27 08:59:17 +00:00
sehr schlecht zu encodieren sind!
</para>
<para >
2006-10-30 16:59:40 +00:00
Weil MPEG-4 16x16 Macroblöcke nutzt, solltest du dich vergewissern,
2006-09-27 08:59:17 +00:00
dass jede Abmessung des zu encodierenden Videos ein Vielfaches von
2006-10-30 16:59:40 +00:00
16 ist oder du verschlechterst andernfalls die Qualität, speziell bei
2006-09-27 08:59:17 +00:00
niedrigeren Bitraten. Du kannst dies durch Abrunden der Breite und
2006-10-30 16:59:40 +00:00
Höhe des Ausschnittsrechtecks hinunter auf den nächsten Wert eines
2006-09-27 08:59:17 +00:00
Vielfachen von 16 erreichen.
2006-10-30 16:59:40 +00:00
Wie früher bereits erklärt, wirst du beim Abschneiden das y-Offset
um die Hälfte der Differenz der alten und neuen Höhe erhöhen wollen,
2006-09-27 08:59:17 +00:00
sodass das daraus resultierende Video aus der Mitte des Frames genommen
wird. Und stelle wegen der Art, wie ein DVD-Video gesampelt wird, sicher,
dass das Offset eine gerade Zahl ist. (Verwende in der Tat - als eine
2006-10-30 16:59:40 +00:00
Regel - nie ungerade Werte für irgendwelche Parameter beim Abschneiden
2006-09-27 08:59:17 +00:00
oder Skalieren eines Videos) Wenn du dich beim Wegwerfen einiger extra
2006-10-30 16:59:40 +00:00
Pixel nicht wohl fühlst, ziehst du es stattdessen vor, das Video zu
2006-09-27 08:59:17 +00:00
skalieren.
Wir werden uns dies im unten stehenden Beispiel mal ansehen.
2006-10-30 16:59:40 +00:00
Du kannst den <option > cropdetect</option> -Filter sogar alles oben erwähnte
für dich erledigen lassen, da dieser einen optionalen Parameter
<option > round</option> besitzt, der standardmäßig gleich 16 ist.
2006-09-27 08:59:17 +00:00
</para>
<para >
2007-09-27 15:27:13 +00:00
Pass auch auf "halbschwarze" Pixel an den Kanten auf. Stelle sicher, dass
2006-09-27 08:59:17 +00:00
du diese ebenfalls mit abschneidest oder du vergeudest dort Bits, wo sie
doch besser anderswo verwendet werden sollten.
</para>
<para >
2006-10-30 16:59:40 +00:00
Nachdem nun alles gesagt ist, wirst du möglicherweise bei einem
2006-09-27 08:59:17 +00:00
Video landen, dessen Pixel nicht ganz 1.85:1 oder 2.35:1, aber ziemlich
2006-10-30 16:59:40 +00:00
nahe dran sind. Du könntest ein neues Seitenverhältnis manuell berechnen,
aber <application > MEncoder</application> bietet eine Option für
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavcodec</systemitem> genannt
2006-10-30 16:59:40 +00:00
<option > autoaspect</option> , die das für dich erledigt.
2006-09-27 08:59:17 +00:00
Skaliere dieses Video auf keinen Fall hoch, um die Pixel abzugleichen
solange du keinen Festplattenplatz verschwenden willst.
Das Skalieren sollte beim Playback gemacht werden und der Player wird das
2006-10-30 16:59:40 +00:00
in der AVI gespeicherte Seitenverhältnis zur Bestimmung der besten
Auflösung verwenden.
Unglücklicherweise erzwingen nicht alle Player diese Auto-Skalierinformation,
2006-09-27 08:59:17 +00:00
und deshalb willst du vielleicht trotzdem neu skalieren.
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-resolution-bitrate" >
2006-10-30 16:59:40 +00:00
<title > Auswahl von Auflösung und Bitrate</title>
2006-09-27 08:59:17 +00:00
<para >
Wenn du nicht vor hast, im Modus mit konstantem Quantisier zu encodieren,
2006-10-30 16:59:40 +00:00
musst du eine Bitrate auswählen.
2006-09-27 08:59:17 +00:00
Das Konzept der Bitrate ist denkbar einfach.
Sie ist die (mittlere) Anzahl Bits, die pro Sekunde zum Speichern des
Films verbraucht werden.
Normalerweise wird die Bitrate in Kilobit (1000 Bit) pro Sekunde gemessen.
2006-10-30 16:59:40 +00:00
Die Größe deines Films auf der Platte ist die Bitrate multipliziert mit der
2007-09-27 15:27:13 +00:00
Dauer des Films, plus einem kleinen "Overhead" (siehe zum Beispiel in der
2006-10-30 16:59:40 +00:00
Sektion über
2006-09-27 08:59:17 +00:00
<link linkend= "menc-feat-dvd-mpeg4-muxing-avi-limitations" > den AVI-Container</link> ).
2006-10-30 16:59:40 +00:00
Weitere Parameter wie Skalierung, Cropping, usw. werden die Dateigröße
<emphasis role= "bold" > nicht</emphasis> ändern, solange du nicht auch
die Bitrate veränderst!
2006-09-27 08:59:17 +00:00
</para>
<para >
Die Bitrate skaliert <emphasis role= "bold" > nicht</emphasis> proportional
2006-10-30 16:59:40 +00:00
zur Auflösung.
2006-09-27 08:59:17 +00:00
Dies bedeutet, eine Datei 320x240 mit 200 KBit/Sek wird nicht dieselbe
2006-10-30 16:59:40 +00:00
Qualität aufweisen wie der gleiche Film bei 640x480 und 800 KBit/Sek!
Dafür gibt es zwei Gründe:
2006-09-27 08:59:17 +00:00
<orderedlist >
<listitem >
<para >
<emphasis role= "bold" > Wahrnehmbar</emphasis> : du bemerkst
2006-10-30 16:59:40 +00:00
MPEG-Artefakte eher, wenn sie größer hochskaliert sind!
Artefakte erscheinen bei einer Skalierung von Blöcken (8x8).
Dein Auge wird in 4800 kleinen Blöcken nicht so leicht Fehler sehen
wie es welche in 1200 großen Blöcken sieht (vorausgesetzt du skalierst
2006-09-27 08:59:17 +00:00
beide auf Vollbild).
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > Theoretisch</emphasis> : Wenn du ein Bild
2006-10-30 16:59:40 +00:00
runterskalierst, aber nach wie vor die selbe Größe der (8x8)
Blöcke zur Frequenzraumtransformation verwendest, bewegst Du
mehr Daten in die Hochfrequenzbänder.
Grob gesagt, jedes Pixel enthält mehr des Details als es dies
2006-09-27 08:59:17 +00:00
zuvor tat.
2006-10-30 16:59:40 +00:00
Somit enthält dein herunterskaliertes Bild 1/4 der Information
in räumlichen Richtungen, es könnte immer noch einen hohen Anteil
2006-09-27 08:59:17 +00:00
Information im Frequenzbereich enthalten (vorausgesetzt dass die
hohen Frequenzen im originalen 640x480 Bild nicht ausgenutzt wurden).
</para>
</listitem>
</orderedlist>
</para>
<para >
2006-10-30 16:59:40 +00:00
Vergangene Leitfäden legten nahe, eine Bitrate und Auflösung zu wählen,
2007-09-27 15:27:13 +00:00
die auf eine "Bits pro Pixel"-Näherung basieren, dies ist jedoch im
2006-10-30 16:59:40 +00:00
allgemeinen aus oben genannten Gründen nicht gültig.
Eine bessere Schätzung scheint zu sein, dass Bitraten proportional zur
Quadratwurzel der Auflösung skalieren, sodass 320x240 und 400 KBit/Sek
vergleichbar mit 640x480 bei 800 KBit/Sek wären.
2006-09-27 08:59:17 +00:00
Dies wurde aber nicht mit theoretischer oder empirischer Strenge verifiziert.
Desweiteren ist es in Anbetracht der Tatsache, dass Filme in Bezug auf Rauschen, Details,
2006-10-30 16:59:40 +00:00
Bewegungsgrad usw. außerordentlich variieren, zwecklos, allgemeine Empfehlungen
für die Bits pro Diagonallänge (dem Analog zu Bits pro Pixel
2006-09-27 08:59:17 +00:00
unter Verwendung der Quadratwurzel) abzugeben.
</para>
<para >
So weit haben wir nun die Schwierigkeit der Wahl von Bitrate und
2006-10-30 16:59:40 +00:00
Auflösung diskutiert.
2006-09-27 08:59:17 +00:00
</para>
<sect3 id= "menc-feat-dvd-mpeg4-resolution-bitrate-compute" >
2006-10-30 16:59:40 +00:00
<title > Berechnen der Auflösung</title>
2006-09-27 08:59:17 +00:00
<para >
2006-10-30 16:59:40 +00:00
Die folgenden Schritte werden dich in der Berechnung der Auflösung
2006-09-27 08:59:17 +00:00
deiner Encodierung anleiten, ohne das Video allzusehr zu verzerren,
2006-10-30 16:59:40 +00:00
indem verschiedene Typen von Informationen über das Quellvideo in
2006-09-27 08:59:17 +00:00
Betracht gezogen werden.
2006-10-30 16:59:40 +00:00
Zuerst solltest du die encodierte Auflösung berechnen:
2006-09-27 08:59:17 +00:00
<systemitem > ARc = (Wc x (ARa / PRdvd )) / Hc</systemitem>
<itemizedlist >
<title > wobwei:</title>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Wc und Hc die Breite und Höhe des zugeschnittenen Videos darstellen
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
ARa das angezeigte Seitenverhältnis ist, das üblicherweise 4/3 oder 16/9 beträgt
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
PRdvd das Pixelverhältnis der DVD ist, welches gleich 1.25=(720/576) für
PAL-DVDs und 1.5=(720/480) für NTSC-DVDs beträgt
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</itemizedlist>
</para>
<para >
2006-10-30 16:59:40 +00:00
Dann kannst du die X- und Y-Auflösung berechnen, gemäß eines gewisse Faktors
der Kompressionsqualität (CQ):
2006-09-27 08:59:17 +00:00
<systemitem > ResY = INT(SQRT( 1000*Bitrate/25/ARc/CQ )/16) * 16</systemitem>
und
<systemitem > ResX = INT( ResY * ARc / 16) * 16</systemitem>
</para>
<para >
Okay, aber was ist der CQ?
2006-10-30 16:59:40 +00:00
Der CQ repräsentiert die Anzahl Bits pro Pixel und pro Frame der Encodierung.
Grob ausgedrückt, je größer der CQ, desto geringer die Wahrscheinlichkeit,
2006-09-27 08:59:17 +00:00
Encodierungsartefakte zu sehen.
2006-10-30 16:59:40 +00:00
Trotz allem, wenn du eine Zielgröße für deinen Film hast (1 oder 2 CDs zum Beispiel),
2006-09-27 08:59:17 +00:00
gibt es eine begrenzte Gesamtzahl an Bits, die du aufwenden kannst; deswegen ist es
2006-10-30 16:59:40 +00:00
notwendig, einen guten Kompromiss zwischen Komprimierbarkeit und Qualität zu suchen.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Der CQ hängt von der Bitrate, der Effektivität des Videocodecs und der
Filmauflösung ab.
Um den CQ anzuheben, könntest du typischerweise den Film unter der Annahme
herunterskalieren, dass die Bitrate mit der Funktion der Zielgröße und der
Länge des Films berechnest, die ja konstant sind.
2006-11-13 09:48:00 +00:00
Mit MPEG-4 ASP-Codecs wie <systemitem class= "library" > Xvid</systemitem>
2006-09-27 08:59:17 +00:00
und <systemitem class= "library" > libavcodec</systemitem> , resultiert ein CQ
2006-10-30 16:59:40 +00:00
unter 0.18 für gewöhnlich in einem ziemlich blockhaften Bild, weil nicht
2006-09-27 08:59:17 +00:00
genug Bits zum Codieren der Information jedes Macroblocks vorhanden sind.
2006-10-30 16:59:40 +00:00
(MPEG4, wie auch viele andere Codecs, gruppiert Pixel nach Blöcken verschiedener
Pixel, um das Bild zu komprimieren; sind nicht genügend Bits vorhanden,
werden die Kanten dieser Blöcke sichtbar.)
Es ist daher weise, einen CQ im Bereich von 0.20 bis 0.22 für einen 1 CD-Rip
und 0.26-0.28 für einen 2 CD-Rip mit Standard-Encodieroptionen zu nehmen.
Höherentwickelte Encodieroptionen wie die hier für
2006-09-27 08:59:17 +00:00
<link linkend= "menc-feat-mpeg4-lavc-example-settings" > <systemitem class= "library" > libavcodec</systemitem> </link>
und
2006-11-13 09:48:00 +00:00
<link linkend= "menc-feat-xvid-example-settings" > <systemitem class= "library" > Xvid</systemitem> </link>
2006-10-30 16:59:40 +00:00
aufgelisteten sollten es möglich machen, dieselbe Qualität mit einem CQ im Bereich
von 0.18 bis 0.20 für einen 1 CD-Rip und 0.24 bis 0.26 für einen 2 CD-Rip zu erreichen.
2007-09-27 17:45:28 +00:00
Mit den MPEG-4 AVC-Codecs wie <systemitem class= "library" > x264</systemitem> ,
2006-09-27 08:59:17 +00:00
kannst du einen CQ im Bereich von 0.14 bis 0.16 mit Standard-Encodieroptionen
verwenden, und solltest bis auf 0.10 bis 0.12 mit den
<link linkend= "menc-feat-x264-example-settings" > erweiterten Encodieroptionen von <systemitem class= "library" > x264</systemitem> </link>
2006-10-30 16:59:40 +00:00
runter gehen können.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Bitte nimm zur Kenntnis, dass der CQ lediglich eine richtungsweisendes Maß ist,
da sie vom encodierten Inhalt abhängt. Ein CQ von 0.18 kann für einen
Bergman-Film recht hübsch aussehen, im Gegensatz zu einem Film wie
The Matrix, der jede Menge High-Motion-Szenen enthält.
Auf der anderen Seite ist es nutzlos, den CQ höher als 0.30 zu schrauben,
da du ohne spürbaren Qualitätsgewinn Bits vergeuden würdest.
Beachte ebenso, dass wie früher in diesem Handbuch bereits angemerkt,
niedrig auflösende Videos einen größeren CQ benötigen, um gut auszusehen
(im Vergleich z.B. zur DVD-Auflösung).
2006-09-27 08:59:17 +00:00
</para>
</sect3>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-filtering" >
<title > Filtern</title>
<para >
Zu lernen, wie man <application > MEncoder</application> s Videofilter
verwendet, ist essentiell, um gute Encodierungen zu produzieren.
2006-10-30 16:59:40 +00:00
Jede Videoverarbeitung wird über Filter ausgeführt -- Ausschneiden,
2006-09-27 08:59:17 +00:00
Skalieren, Farbanpassung, Rauschentfernung, Scharfzeichnen, Deinterlacing,
2006-10-30 16:59:40 +00:00
telecine, inverses telecine und Deblocking, um nur ein paar davon aufzuzählen.
Zusammen mit der gewaltigen Zahl unterstützter Inputformate, ist die Vielfalt der
in <application > MEncoder</application> verfügbaren Filter eine seiner
Hauptvorteile im Vergleich zu ähnlichen Programmen.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Filter werden in einer Kette über die Option -vf geladen:
2006-09-27 08:59:17 +00:00
<screen > -vf filter1=Optionen,filter2=Optionen,...</screen>
Die meisten Filter nehmen mehrere numerische, kommagetrennte
Optionen entgegen, jedoch variiert die Syntax der Optionen von
2006-10-30 16:59:40 +00:00
Filter zu Filter, also lies bitte die Manpage für Details
2006-09-27 08:59:17 +00:00
zu den Filtern, die du verwenden willst.
</para>
<para >
Filter wirken auf das Video in der Reihenfolge ein, in der sie geladen werden.
Zum Beispiel wird folgende Kette:
<screen > -vf crop=688:464:12:4,scale=640:464</screen>
zuerst den Bereich 688x464 aus dem Bild schneiden mit der oberen, linken
Ecke bei (12,4) und danach das Ergebnis auf 640x464 herunter skalieren.
</para>
<para >
2006-10-30 16:59:40 +00:00
Bestimmte Filter müssen zu oder nahe dem Anfang der Filterkette geladen
2006-09-27 08:59:17 +00:00
werden, um Vorteile aus den Informationen des Videodecoders zu ziehen,
2006-10-30 16:59:40 +00:00
die ansonsten durch andere Filter verloren gehen oder ungültig gemacht
würden.
2006-09-27 08:59:17 +00:00
Die wichtigsten Beispiele sind <option > pp</option>
(Nachbearbeitung (postprocessing), nur wenn es Deblock- oder
2006-10-30 16:59:40 +00:00
Dering-Operationen durchführt), <option > spp</option> (ein weiterer
2006-09-27 08:59:17 +00:00
Postprozessor zum Entfernen von MPEG-Artefakten), <option > pullup</option>
(umgekehrtes telecine) und <option > softpulldown</option> (zur Konvertierung
von soft telecine nach hard telecine).
</para>
<para >
2006-10-30 16:59:40 +00:00
Im Allgemeinen solltest du den Film so wenig wie möglich Filtern, um
2006-09-27 08:59:17 +00:00
nahe an der originalen DVD-Quelle zu bleiben. Ausschneiden ist oft
notwendig (wie oben beschrieben), vermeide aber das Skalieren von Videos.
2006-10-30 16:59:40 +00:00
Obwohl das Herunterskalieren manchmal vorgezogen wird, um höhere Quantisierer
2006-09-27 08:59:17 +00:00
zu verwenden, wollen wir beide diese Dinge vermeiden: Erinnere dich daran,
dass wir von Anfang an beschlossen hatten, einen Kompromiss zwischen
2006-10-30 16:59:40 +00:00
Bits und Qualität zu schließen.
2006-09-27 08:59:17 +00:00
</para>
<para >
Passe ebenso kein Gamma, Kontrast, Helligkeit, usw. an. Was auf deinem
Display gut aussieht, sieht auf anderen eventuell nicht gut aus. Diese
Anpassungen sollten nur im Playback vorgenommen werden.
</para>
<para >
Eine Sache, die du vielleicht machen willst, ist, das Video durch einen sehr
feinen Entrauschfilter (Denoise) zu schicken, wie etwa <option > -vf hqdn3d=2:1:2</option> .
2006-10-30 16:59:40 +00:00
Nochmals, es geht darum, die Bits einer besseren Verwendung zuzuführen: Warum
2006-09-27 08:59:17 +00:00
Bits zum Encodieren des Rauschens verschwenden, wenn du dieses Rauschen auch
2006-10-30 16:59:40 +00:00
während des Playback entfernen kannst?
Die Parameter für <option > hqdn3d</option> zu erhöhen, wird überdies
die Komprimierbarkeit erhöhen, erhöhst du jedoch die Werte zu sehr, riskierst Du
2006-09-27 08:59:17 +00:00
eine Verringerung der Bildsichtbarkeit. Die oben vorgeschlagenen Werte
(<option > 2:1:2</option> ) sind ziemlich konservativ; du solltest dich frei
2006-10-30 16:59:40 +00:00
fühlen, mit höheren Werten herumzuexperimentieren und die Ergebnisse
2006-09-27 08:59:17 +00:00
selbst zu beobachten.
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-interlacing" >
<title > Interlacing und Telecine</title>
<para >
Nahezu alle Filme sind bei 24 fps aufgenommen. Weil NTSC 30000/1001 fps entspricht,
2006-10-30 16:59:40 +00:00
müssen mit diesen 24 fps Videos einige Verarbeitungen durchgeführt werden,
2006-09-27 08:59:17 +00:00
um sie mit der korrekten NTSC-Framerate laufen zu lassen. Der Prozess wird 3:2
2006-10-30 16:59:40 +00:00
pulldown genannt, allgemein telecine zugeordnet (weil pulldown des öfteren
während des telecine-Prozesses angewandt wird), und naiv so beschrieben,
2006-09-27 08:59:17 +00:00
dass er durch Verlangsamung des Films auf 24000/1001 fps und dem
Wiederholen jeden vierten Frames arbeitet.
</para>
<para >
2006-10-30 16:59:40 +00:00
Keine spezielle Verarbeitung ist jedoch bei einem Video für PAL-DVDs
durchzuführen, das bei 25 fps läuft. (Technisch gesehen kann PAL telecined
2006-09-27 08:59:17 +00:00
werden, 2:2 pulldown genannt, dies ist jedoch in der Praxis nicht von Bedeutung.)
Der 24 fps Film wird einfach mit 25 fps abgespielt. Das Resultat ist, dass
2006-10-30 16:59:40 +00:00
der Film ein wenig schneller abläuft, doch solange du kein Alien bist, wirst
du möglicherweise keinen Unterschied wahrnehmen.
Die meisten PAL-DVDs haben pitch-korrigiertes Audio, dadurch hören sie sich
2006-09-27 08:59:17 +00:00
bei 25 fps abgespielt korrekt an, obwohl der Audiotrack (und infolgedessen der
2006-10-30 16:59:40 +00:00
gesamte Film) eine 4% kürzere Abspielzeit hat wie NTSC-DVDs.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Weil das Video in einer PAL-DVD nicht verändert wurde, musst du dich nicht
2006-09-27 08:59:17 +00:00
viel um die Framerate sorgen. Die Quelle ist 25 fps und dein Rip wird 25
fps haben. Wenn du jedoch einen NTSC-DVD-Film rippst, musst du eventuell
umgekehrtes telecine anwenden.
</para>
<para >
2006-10-30 16:59:40 +00:00
Für mit 24 fps aufgenommene Filme ist das Video auf der NTSC-DVD entweder telecined
2006-09-27 08:59:17 +00:00
30000/1001 oder hat andernfalls progressive 24000/1001 fps und es ist vorgesehen,
on-the-fly vom DVD-Player telecined zu werden. Auf der anderen Seite sind TV-Serien
2006-10-30 16:59:40 +00:00
üblicherweise nur interlaced, nicht telecined. Dies ist keine feste Regel: Einige
TV-Serien sind interlaced (wie etwa Buffy die Vampirjägerin), wogegen andere
2006-09-27 08:59:17 +00:00
eine Mixtur aus progressive und interlaced sind (so wie Angel oder 24) - wers kennt :).
</para>
<para >
2006-10-30 16:59:40 +00:00
Es wird strengstens empfohlen, die Sektion über
2006-09-27 08:59:17 +00:00
<link linkend= "menc-feat-telecine" > Wie mit telecine und interlacing in NTSC-DVDs umgehen</link>
2006-10-30 16:59:40 +00:00
durchzulesen, um den Umgang mit den verschiedenen Möglichkeiten zu lernen.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Wenn du aber hauptsächlich nur Filme rippst, gehst du wahrscheinlich entweder
2006-09-27 08:59:17 +00:00
mit 24 fps progressivem oder telecined Video um, in welchem Falle du
den Filter <option > pullup</option> mittels <option > -vf pullup,softskip</option>
verwenden kannst.
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-encoding-interlaced" >
<title > Interlaced Video encodieren</title>
<para >
Ist der Film, den du encodieren willst, interlaced (NTSC-Video oder
2006-10-30 16:59:40 +00:00
PAL-Video), wirst du wählen müssen, ob du ihn deinterlacen willst
2006-09-27 08:59:17 +00:00
oder nicht.
2006-10-30 16:59:40 +00:00
Während das Deinterlacing deinen Film zwar auf progressiven Scan-Displays
2006-09-27 08:59:17 +00:00
wie Computermonitoren und Projektoren verwendbar macht, wird dich dies
doch etwas kosten: Die Feldrate von 50 oder 60000/1001 Feldern pro Sekunde
2006-10-30 16:59:40 +00:00
wird auf 25 oder 30000/1001 Frames pro Sekunde halbiert und annähernd die
Hälfte der Informationen in deinem Film geht während Szenen mit
2006-09-27 08:59:17 +00:00
signifikanter Bewegung verloren.
</para>
<para >
2006-10-30 16:59:40 +00:00
Deswegen wird empfohlen, wenn du aus Gründen hochqualitativer
Archivierung encodierst, kein Deinterlacing durchzuführen.
2006-09-27 08:59:17 +00:00
Du kannst den Film immer noch beim Playback deinterlacen,
2006-10-30 16:59:40 +00:00
wenn du ihn auf progressiven Scan-Geräten anzeigst. Und zukünftige
2006-09-27 08:59:17 +00:00
Player werden in der Lage sein, auf volle Feldrate zu
deinterlacen, mit Interpolation auf 50 oder 60000/1001 komplette
Frames pro Sekunde aus interlaced Video heraus.
</para>
<para >
Spezielle Sorgfalt solltest du bei der Arbeit mit interlaced Video walten lassen:
</para>
<orderedlist >
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Ausschneidehöhe und y-Offset müssen Vielfache von 4 sein.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Jedes vertikale Skalieren muss im interlaced Modus durchgeführt werden.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Nachbearbeitungs- (postprocessing) und Rauschunterdrückungsfilter (denoising)
2006-09-27 08:59:17 +00:00
funktionieren eventuell nicht wie erwartet, wenn du nicht speziell darauf achtest,
2006-10-30 16:59:40 +00:00
dass sie zu einem Zeitpunkt nur ein Feld verarbeiten, und sie können das Video
2006-09-27 08:59:17 +00:00
kaputt machen, wenn sie inkorrekt angewendet werden.
</para>
</listitem>
</orderedlist>
<para >
Mit diesen Dingen im Kopf, hier das erste Beispiel:
</para>
<screen > mencoder <replaceable > capture.avi</replaceable> -mc 0 -oac lavc -ovc lavc -lavcopts \
vcodec=mpeg2video:vbitrate=6000:ilme:ildct:acodec=mp2:abitrate=224</screen>
<para >
Beachte die Optionen <option > ilme</option> und <option > ildct</option> .
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-av-sync" >
<title > Anmerkungen zur Audio-/Videosynchronisation</title>
<para >
<application > MEncoder</application> s Algorithmen der Audio-/Videosynchronisation
wurden mit der Intention entwickelt, Dateien mit kaputter Sychronisation wieder herzustellen.
2006-10-30 16:59:40 +00:00
In einigen Fällen können unnötiges Überspringen und Duplizieren
von Frames und möglicherweise leichte A/V-Desynchronisation verursachen, auch wenn sie
2006-09-27 08:59:17 +00:00
mit dem richtigen Input verwendet werden
2006-10-30 16:59:40 +00:00
(gewiss, Probleme mit A/V-Synchronisation treffen nur zu, wenn du den Audiotrack während
2006-09-27 08:59:17 +00:00
der Transcodierung des Videos verarbeitest oder kopierst, wozu auch nachhaltig
ermutigt wird).
2006-10-30 16:59:40 +00:00
Hierfür müsstest du mit der Option <option > -mc 0</option> in die
2006-09-27 08:59:17 +00:00
Grundeinstellung der A/V-Synchronisation wechseln oder diese in deine
<systemitem > ~/.mplayer/mencoder</systemitem> Konfigurationsdatei eintragen,
2006-10-30 16:59:40 +00:00
solange du ausschließlich mit guten Quellen arbeitest (DVD, TV-Capture,
2006-09-27 08:59:17 +00:00
hochqualitativen MPEG-4-Rips usw.) und mit nicht-kaputten ASF/RM/MOV-Dateien.
</para>
<para >
2006-10-30 16:59:40 +00:00
Wenn du dich überdies gegen merkwürdige Frameübersprünge und -duplikationen
2006-09-27 08:59:17 +00:00
absichern willst, kannst du beides verwenden, <option > -mc 0</option>
und <option > -noskip</option> .
Dies verhindert <emphasis > jede</emphasis> A/V-Synchronisation und kopiert die Frames
eins-zu-eins, somit kannst du sie nicht verwenden, falls du irgendwelche Filter
2006-10-30 16:59:40 +00:00
verwendest, die unvorhersagbar Frames hinzufügen oder streichen oder falls
2006-09-27 08:59:17 +00:00
deine Input-Datei eine variable Framerate besitzt!
Deshalb wird eine allgemeine Anwendung von <option > -noskip</option> nicht empfohlen.
</para>
<para >
2006-10-30 16:59:40 +00:00
Die von <application > MEncoder</application> unterstützte sogenannte
2007-09-27 15:27:13 +00:00
"3-pass" Audioencodierung soll laut Berichten A/V-Desynchronisation
2006-09-27 08:59:17 +00:00
verursachen.
Dies geschieht definitiv dann, wenn sie in Verbindung mit bestimmten Filtern
verwendet wird, daher wird <emphasis > nicht</emphasis> empfohlen, den
3-pass-Audio-Modus anzuwenden.
2006-10-30 16:59:40 +00:00
Dieses Feature ist nur aus Kompatibilitätsgründen übrig geblieben und für
2006-09-27 08:59:17 +00:00
erfahrene Benutzer, die wissen, wann es sicher anzuwenden ist und wann nicht.
2006-10-30 16:59:40 +00:00
Wenn du zuvor noch nie etwas vom 3-pass-Modus gehört hast, vergiss, dass wir es je
erwähnt haben!
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Es gab auch Berichte über A/V-Desynchronisation, wenn
2006-09-27 08:59:17 +00:00
mit <application > MEncoder</application> von stdin encodiert wurde.
Lass das bleiben! Verwende immer eine Datei oder ein CD/DVD/usw-Laufwerk
als Input.
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-codec" >
<title > Auswahl des Videocodecs</title>
<para >
2006-10-30 16:59:40 +00:00
Welcher Videocodec die beste Wahl ist, hängt von mehreren Faktoren
wie Größe, Qualität, Streambarkeit, Brauchbarkeit und Popularität, manche
davon weitgehend vom persönlichen Geschmack und technischen
2006-09-27 08:59:17 +00:00
Randbedingungen ab.
</para>
<itemizedlist >
<listitem >
<para >
<emphasis role= "bold" > Kompressionseffizienz</emphasis> :
Es ist leicht zu verstehen, dass die meisten Codecs der neueren Generation
2006-10-30 16:59:40 +00:00
dafür gemacht wurden, Qualität und Komprimierung zu verbessern.
2006-09-27 08:59:17 +00:00
Deshalb behauptet der Autor dieses Handbuches und viele andere Leute, dass
du nichts verkehrt machen kannst,
<footnote id= 'fn-menc-feat-dvd-mpeg4-codec-cpu' >
2006-10-30 16:59:40 +00:00
<para > Sei trotzdem vorsichtig: MPEG-4 AVC-Videos in DVD-Auflösung zu
2006-09-27 08:59:17 +00:00
decodieren erfordert einen schnellen Rechner (z.B. einen Pentium 4
2006-10-30 16:59:40 +00:00
über 1.5GHz oder einen Pentium M über 1GHz).
2006-09-27 08:59:17 +00:00
</para>
</footnote>
wenn du MPEG-4 AVC-Codecs wie
<systemitem class= "library" > x264</systemitem> anstatt MPEG-4 ASP-Codecs
wie <systemitem class= "library" > libavcodec</systemitem> MPEG-4 oder
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem> wählst.
2006-09-27 08:59:17 +00:00
(Zukunftsorientierte Codec-Entwickler interessiert eventuell Michael
Niedermayers Meinung
2007-09-27 15:27:13 +00:00
"<ulink url= "http://guru.multimedia.cx/?p=10" > why MPEG4-ASP sucks</ulink> "
2006-09-27 08:59:17 +00:00
zu lesen.)
2006-10-30 16:59:40 +00:00
Ebenso solltest du mit MPEG-4 ASP eine bessere Qualität erhalten als mit
2006-09-27 08:59:17 +00:00
MPEG-2-Codecs.
</para>
<para >
2006-10-30 16:59:40 +00:00
Allerdings können neuere Codecs, die noch stark in der Entwicklung stecken,
unter unentdeckten Bugs leiden, die die Encodierung ruinieren können.
2006-09-27 08:59:17 +00:00
Dies nimmt man schlicht in Kauf, wenn man "bleeding edge"-Technologie
verwendet.
</para>
<para >
2006-10-30 16:59:40 +00:00
Außerdem erfordert der Umgang mit einem neuen Codec und sich mit dessen Optionen
vertraut zu machen eine Zeit, bis du weißt, was alles anzupassen
ist, um die erhoffte Bildqualität zu erreichen.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > Hardware-Kompatibilität</emphasis> :
Gewöhnlich dauert es bei neuen standalone Video-Playern lange, bis der
Support für die neuesten Videocodecs eingebunden ist.
Als ein Ergebnis unterstützen die meisten nur MPEG-1 (wie VCD, XVCD
2006-09-27 08:59:17 +00:00
und KVCD), MPEG-2 (wie DVD, SVCD und KVCD) und MPEG-4 ASP (wie DivX,
LMP4 von <systemitem class= "library" > libavcodec</systemitem> und
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem> )
2006-10-30 16:59:40 +00:00
(Vorsicht: Im Allgemeinen werden nicht alle MPEG-4 ASP-Features unterstützt).
2006-09-27 08:59:17 +00:00
Sieh bitte in den technischen Spezifikationen deines Players nach (falls
welche vorhanden sind) oder google nach mehr Informationen.
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > Beste Qualität pro Encodierzeit</emphasis> :
2006-09-27 08:59:17 +00:00
Codecs, die es schon einige Zeit gibt (wie
<systemitem class= "library" > libavcodec</systemitem> MPEG-4 und
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem> ), sind gewöhnlich heftig
2006-10-30 16:59:40 +00:00
mit allen möglichen intelligenten Algorithmen und SIMD Assembly-Code optimiert.
Das sind sie deshalb, weil sie darauf abzielen, das beste Verhältnis von Qualität
2006-09-27 08:59:17 +00:00
pro Encodierzeit zu liefern.
Jedoch haben sie oft einige sehr fortschrittliche Optionen, die,
wenn aktiviert, das Encodieren bei marginalem Gewinn wirklich langsam
machen.
</para>
<para >
Wenn du es auf die Wahnsinnsgeschwindigkeit abzielst, solltest du
2006-10-30 16:59:40 +00:00
in der Nähe der Standardeinstellungen des Videocodecs bleiben
2006-09-27 08:59:17 +00:00
(obwohl du ruhig weitere Optionen ausprobieren solltest, die in
anderen Sektionen dieses Handbuchs angesprochen werden).
</para>
<para >
2006-10-30 16:59:40 +00:00
Vielleicht überlegst du auch, einen Codec auszuwählen, der mit
Multi-Threading klarkommt, was nur für Benutzer von Rechnern
2006-09-27 08:59:17 +00:00
mit mehreren CPUs von Nutzen ist.
<systemitem class= "library" > libavcodec</systemitem> MPEG-4 erlaubt
dies zwar, aber die Geschwindigkeitsgewinne sind begrenzt und es gibt
2006-10-30 16:59:40 +00:00
einen leicht negativen Effekt in Bezug auf die Bildqualität.
2006-11-13 09:48:00 +00:00
Die Multi-Thread-Encodierung von <systemitem class= "library" > Xvid</systemitem> ,
2006-09-27 08:59:17 +00:00
durch die Option <option > threads</option> aktiviert, kann zum Ankurbeln
2006-10-30 16:59:40 +00:00
der Encodiergeschwindigkeit - um in typischen Fällen etwa 40-60% -
bei wenn überhaupt geringer Bildverschlechterung verwendet werden.
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > x264</systemitem> erlaubt ebenfalls
2007-09-27 21:22:26 +00:00
Multi-Thread-Encodierung, was das Encodieren momentan um 94% beschleunigt
bei gleichzeitiger Verringerung des PSNR um einen Wert zwischen 0.005dB und 0.01dB.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > Persönlicher Geschmack</emphasis> :
2006-09-27 08:59:17 +00:00
Hier beginnt die Angelegenheit oft irrational zu werden: Aus den selben
2006-10-30 16:59:40 +00:00
Gründen, aus denen manche über Jahre an DivX 3 hängen, während neuere
2006-09-27 08:59:17 +00:00
Codecs bereits Wunder wirken, ziehen einige Leute
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem>
2006-09-27 08:59:17 +00:00
oder <systemitem class= "library" > libavcodec</systemitem> MPEG-4 dem
<systemitem class= "library" > x264</systemitem> vor.
</para>
<para >
Du solltest dir dein eigenes Urteil bilden; lass dich nicht von Leuten
2006-10-30 16:59:40 +00:00
vollquasseln, die auf den einen Codec schwören.
2006-09-27 08:59:17 +00:00
Nimm ein paar Beispiel-Clips von Originalquellen und vergleiche die
verschiedenen Encodier-Optionen und Codecs, um den einen zu finden, mit
dem du am besten klarkommst.
Der beste Codec ist der, den du beherrschst und der in deinen Augen
auf deinem Display am besten aussieht.
<footnote id= 'fn-menc-feat-dvd-mpeg4-codec-playback' >
<para > Dieselbe Encodierung kann auf dem Monitor eines anderen vollkommen
anders aussehen oder wenn sie von einem anderen Decoder abgespielt wird,
also mach deine Encodierungen zukunftssicher indem du sie unter verschiedenen
2006-10-30 16:59:40 +00:00
Setups ablaufen lässt.</para> </footnote> !
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</itemizedlist>
<para >
Sieh dazu bitte in der Sektion
<link linkend= "menc-feat-selecting-codec" > Auswahl der Codecs und Containerformate</link>
2006-10-30 16:59:40 +00:00
nach der Liste der unterstützten Codecs.
2006-09-27 08:59:17 +00:00
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-audio" >
<title > Audio</title>
<para >
2006-10-30 16:59:40 +00:00
Audio ist ein leichter zu lösendes Problem: Wenn du Wert auf Qualität legst,
2006-09-27 08:59:17 +00:00
lass es einfach so wie es ist.
Gerade AC3 5.1 Streams sind meist 448Kbit/s und jedes Bit wert.
2006-10-30 16:59:40 +00:00
Möglicherweise gerätst du in Versuchung, Audio in hochwertiges Vorbis
umzuwandeln, aber nur weil du heute keinen A/V-Receiver für AC3-pass-through
2006-09-27 08:59:17 +00:00
besitzt, bedeutet dies nicht, dass du nicht morgen doch einen hast.
2006-10-30 16:59:40 +00:00
Halte deine DVD-Rips zukunftssicher, indem du den AC3-Stream beibehältst.
Du behältst den AC3-Stream entweder, indem du ihn
<link linkend= "menc-feat-mpeg4" > während der Encodierung</link>
2006-09-27 08:59:17 +00:00
direkt in den Video-Stream kopierst.
Du kannst den AC3-Stream aber auch extrahieren, um ihn in Container wie NUT
oder Matroska zu muxen.
<screen > mplayer <replaceable > source_file.vob</replaceable> -aid 129 -dumpaudio -dumpfile <replaceable > sound.ac3</replaceable> </screen>
dumpt Audiotrack Nummer 129 aus der Datei <replaceable > source_file.vob</replaceable>
2006-10-30 16:59:40 +00:00
(NB: DVD-VOB-Dateien verwenden gewöhnlich andere Audionummerierungen,
2006-09-27 08:59:17 +00:00
was bedeutet, dass der VOB-Audiotrack 129 der 2-te Audiotrack der Datei ist)
in die Datei <replaceable > sound.ac3</replaceable> .
</para>
<para >
Aber manchmal hast du wirklich keine andere Wahl als den Sound weiter zu
2006-10-30 16:59:40 +00:00
komprimieren, sodass mehr Bits fürs Video aufgewendet werden können.
Die meisten Leute entscheiden sich für eine Audiokomprimierung mit MP3- oder
2006-09-27 08:59:17 +00:00
Vorbis-Audiocodecs.
Wobei letzterer ein sehr platzsparender Codec ist, MP3 wird von Hardware-Playern
2006-10-30 16:59:40 +00:00
besser unterstützt, wobei sich dieser Trend auch ändert.
2006-09-27 08:59:17 +00:00
</para>
<para >
Verwende <emphasis > nicht</emphasis> <option > -nosound</option> beim Encodieren
2006-10-30 16:59:40 +00:00
einer Datei, die Audio enhält, sogar wenn du Audio später separat
2006-09-27 08:59:17 +00:00
encodierst und muxt.
Zwar kann es im Idealfall manchmal funktionieren, wenn du <option > -nosound</option>
verwendest, wahrscheinlich um einige Probleme in deinen
Encodier-Befehlszeileneinstellungen zu verbergen.
2006-10-30 16:59:40 +00:00
In anderen Worten, einen Soundtrack während dem Encodieren zu haben, stellt sicher,
2006-09-27 08:59:17 +00:00
vorausgesetzt du siehst keine Meldungen wie
<quote > Too many audio packets in the buffer</quote> , dass du in der Lage sein
wirst, eine korrekte Synchronisation zu erhalten.
</para>
<para >
Du brauchst <application > MEncoder</application> zur Verarbeitung des Sounds.
2006-10-30 16:59:40 +00:00
Du kannst zum Beispiel den originalen Soundtrack während dem Encodieren mit
2006-09-27 08:59:17 +00:00
<option > -oac copy</option> kopieren oder ihn mittels
2007-09-27 15:27:13 +00:00
<option > -oac pcm -channels 1 -srate 4000</option> in eine "leichte"
2006-09-27 08:59:17 +00:00
4 kHz Mono WAV-PCM konvertieren.
2006-10-30 16:59:40 +00:00
Anderenfalls wird er - in einigen Fällen - eine Videodatei erzeugen, die
nicht mit Audio synchron läuft.
2006-09-27 08:59:17 +00:00
So was kommt vor, wenn die Anzahl der Videoframes in der Quelldatei nicht
2006-10-30 16:59:40 +00:00
mit der Gesamtlänge der Audioframes zusammenpasst oder immer dann, wenn
2006-09-27 08:59:17 +00:00
Unstetigkeiten/Splices vorhanden sind, wo Audioframes oder extra Audioframes
fehlen.
Der korrekte Weg, mit dieser Art Problem umzugehen, ist Stille (silence)
2006-10-30 16:59:40 +00:00
einzufügen oder Audio an diesen Punkten wegzuschneiden.
2006-09-27 08:59:17 +00:00
Seis drum, <application > MPlayer</application> kann das nicht, also wenn du
AC3-Audio demuxt und es in einer separaten Anwendung encodierst (oder
es mit <application > MPlayer</application> in eine PCM dumpst), die Splices
bleiben inkorrekt und der einzige Weg sie zu korrigieren ist, Videoframes
an diesem Splice zu streichen bzw. zu duplizieren.
Solange <application > MEncoder</application> Audio beim Encodieren des
2006-10-28 14:20:15 +00:00
Videos sieht, kann er dieses Streichen/Duplizieren erledigen (was
2006-10-30 16:59:40 +00:00
gewöhnlich OK ist, da es bei voller Schwärze/Szenenwechsel stattfindet),
2006-09-27 08:59:17 +00:00
aber wenn <application > MEncoder</application> Audio nicht erkennen kann,
wird er einfach alle Frames so wie sie ankommen verarbeiten und sie werden
2006-10-30 16:59:40 +00:00
einfach nicht zum endgültigen Audiostream passen, wenn du beispielsweise
2006-09-27 08:59:17 +00:00
deinen Audio- und Videotrack in eine Matroska-Datei mergst.
</para>
<para >
2006-10-30 16:59:40 +00:00
Zuallererst wirst du den DVD-Sound in eine WAV-Datei konvertieren müssen, die
2006-09-27 08:59:17 +00:00
der Audiocodec als Input nutzen kann.
Zum Beispiel:
<screen > mplayer <replaceable > source_file.vob</replaceable> -ao pcm:file=<replaceable > destination_sound.wav</replaceable> -vc dummy -aid 1 -vo null</screen>
wird den zweiten Audiotrack aus der Datei <replaceable > source_file.vob</replaceable>
in die Datei <replaceable > destination_sound.wav</replaceable> dumpen.
Vielleicht willst du den Sound vor dem Encodieren normalisieren, da
2006-10-30 16:59:40 +00:00
DVD-Audiotracks gemeinhin bei niedriger Lautstärke aufgenommen sind.
2006-09-27 08:59:17 +00:00
Du kannst beispielsweise das Tool <application > normalize</application> verwenden,
2006-10-30 16:59:40 +00:00
das in den meisten Distributionen zur Verfügung steht.
2006-09-27 08:59:17 +00:00
Wenn du Windows nutzt, kann ein Tool wie <application > BeSweet</application>
denselben Job erledigen.
Du wirst entweder nach Vorbis oder MP3 komprimieren.
Zum Beispiel:
<screen > oggenc -q1 <replaceable > destination_sound.wav</replaceable> </screen>
wird <replaceable > destination_sound.wav</replaceable> mit
2006-10-30 16:59:40 +00:00
der Encodierqualität 1 encodieren, was annähernd 80Kb/s ergibt und
die Minimalqualität darstellt, mit der du encodieren solltest, wenn du
Wert auf Qualität legst.
2006-10-30 19:19:19 +00:00
Nimm bitte zur Kenntnis, dass <application > MEncoder</application> aktuell keine Vorbis-Audiotracks
2006-09-27 08:59:17 +00:00
in die Output-Datei muxen kann, da er nur AVI- und MPEG-Container als
2006-10-30 16:59:40 +00:00
Output unterstützt, wobei es beim Audio-/Videoplayback zu
Synchronisationproblemen mit einigen Playern führen wird, wenn die AVI-Datei
VBR-Audiostreams wie z.B. Vorbis enthält.
2006-09-27 08:59:17 +00:00
Keine Bange, dieses Dokument wird dir zeigen, wie du das mit
Third-Party-Programmen hinbekommst.
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-muxing" >
<title > Muxen</title>
<para >
2006-10-30 16:59:40 +00:00
Nun da du dein Video encodiert hast, wirst du es höchstwahrscheinlich
2006-09-27 08:59:17 +00:00
mit einem oder mehr Audiotracks in einen Movie-Container wie etwa
AVI, MPEG, Matroska oder NUT muxen.
<application > MEncoder</application> ist aktuell nur in der Lage,
Audio und Video nativ in MPEG- und AVI-Containerformate auszugeben.
Zum Beispiel:
<screen > mencoder -oac copy -ovc copy -o <replaceable > output_movie.avi</replaceable> -audiofile <replaceable > input_audio.mp2</replaceable> <replaceable > input_video.avi</replaceable> </screen>
2006-10-30 16:59:40 +00:00
würde die Video-Datei <replaceable > input_video.avi</replaceable>
2006-09-27 08:59:17 +00:00
und die Audio-Datei <replaceable > input_audio.mp2</replaceable>
in die AVI-Datei <replaceable > output_movie.avi</replaceable> mergen.
Dieser Befehl funktioniert mit MPEG-1 Layer I, II und III Audio (eher
bekannt als MP3), WAV und auch mit ein paar weiteren Audioformaten.
</para>
<para >
2006-10-30 19:19:19 +00:00
<application > MEncoder</application> zeichnet sich aus durch experimentellen Support für
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavformat</systemitem> , das eine
Programmbibliothek des FFmpeg-Projekts ist, welches das Muxen und
2006-10-30 16:59:40 +00:00
Demuxen einer Vielzahl von Containern unterstützt.
2006-09-27 08:59:17 +00:00
Zum Beispiel:
<screen > mencoder -oac copy -ovc copy -o <replaceable > output_movie.asf</replaceable> -audiofile <replaceable > input_audio.mp2</replaceable> <replaceable > input_video.avi</replaceable> -of lavf -lavfopts format=asf</screen>
2006-10-30 16:59:40 +00:00
wird das selbe machen, wie das obere Beispiel, außer dass der
2006-09-27 08:59:17 +00:00
Output-Container ASF sein wird.
Bitte nimm zur Kenntnis, dass dieser Support hochexperimentell ist
(aber von Tag zu Tag besser wird) und nur funktionieren wird, wenn du
2006-10-30 16:59:40 +00:00
<application > MPlayer</application> mit aktiviertem Support für
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavformat</systemitem> kompiliert
hast (was meint, dass eine Pre-Packaged Binary Version in den meisten
2006-10-30 16:59:40 +00:00
Fällen nicht funktionieren wird).
2006-09-27 08:59:17 +00:00
</para>
<sect3 id= "menc-feat-dvd-mpeg4-muxing-filter-issues" >
2006-10-30 16:59:40 +00:00
<title > Verbessern der Mux- und A/V-Synchronisationszuverlässigkeit</title>
2006-09-27 08:59:17 +00:00
<para >
2006-10-30 16:59:40 +00:00
Es kann vorkommen, dass du ernsthafte A/V-Synchronisationsprobleme hast während
2006-09-27 08:59:17 +00:00
du versuchst, deine Video- und einige Audiotracks zu muxen, wobei es nichts
2006-10-30 16:59:40 +00:00
ändert, wenn du das Audiodelay anpasst, du bekommst nie eine korrekte
2006-09-27 08:59:17 +00:00
Synchronisation zu Stande.
Dies kann vorkommen, wenn du manche Videofilter verwendest, die einige Frames
weglassen oder duplizieren, wie etwa die inverse telecine-Filter.
ich kann dich nur dazu ermutigen, den <option > harddup</option> -Videofilter
2006-10-30 16:59:40 +00:00
ans Ende der Filterkette anzuhängen, um solcherlei Problemen aus dem Weg
2006-09-27 08:59:17 +00:00
zu gehen.
</para>
<para >
2006-10-30 16:59:40 +00:00
Ohne <option > harddup</option> verlässt sich <application > MEncoder</application> ,
2006-09-27 08:59:17 +00:00
wenn er einen Frame duplizieren will, darauf, dass der Muxer eine Marke auf den
Container setzt, sodass der letzte Frame nochmals angezeigt wird, um
2006-10-30 16:59:40 +00:00
während des Schreibens des aktuellen Frames synchron zu bleiben.
2006-09-27 08:59:17 +00:00
Mit <option > harddup</option> wird <application > MEncoder</application>
statt dessen einfach den zuletzt angezeigten Frame nochmal in die Filterkette
einschieben.
Dies bedeutet, dass der Encoder <emphasis > exakt</emphasis> denselben Frame
zweimal entgegen nimmt und komprimiert.
2006-10-30 16:59:40 +00:00
Dies ergibt eine etwas größere Datei, verursacht jedoch keine Probleme
2006-09-27 08:59:17 +00:00
beim Demuxen oder Remuxen in ein anderes Containerformat.
</para>
<para >
Du kommst auch nicht um den Einsatz von <option > harddup</option> im
Zusammenhang mit Containerformaten herum, die nicht allzu fest mit
<application > MEncoder</application> verlinkt sind, wie etwa diejenigen,
2006-10-30 16:59:40 +00:00
welche von <systemitem class= "library" > libavformat</systemitem> unterstützt
werden, der keine Frameduplikation auf Container-Level unterstützt.
2006-09-27 08:59:17 +00:00
</para>
</sect3>
<sect3 id= "menc-feat-dvd-mpeg4-muxing-avi-limitations" >
<title > Limitierungen des AVI-Containers</title>
<para >
2006-10-30 16:59:40 +00:00
Obwohl es das am breitesten unterstützte Containerformat nach MPEG-1 ist,
2006-09-27 08:59:17 +00:00
besitzt AVI auch einige gravierende Nachteile.
Der vielleicht offensichtlichste ist der Overhead.
2006-10-30 16:59:40 +00:00
Für jeden Block der AVI-Datei werden 24 Byte auf Header und Indizes
2006-09-27 08:59:17 +00:00
verschwendet.
2006-10-30 16:59:40 +00:00
Dies heißt übersetzt etwas mehr als 5 MB pro Stunde oder 1-2.5%
Overhead für einen 700 MB Film. Das sieht nicht nach viel aus, könnte aber
2006-09-27 08:59:17 +00:00
die Differenz zwischen einem Video mit 700 KBit/Sek oder 714 KBit/Sek
2006-10-30 16:59:40 +00:00
bedeuten, und jedes bisschen mehr an Qualität zählt.
2006-09-27 08:59:17 +00:00
</para>
<para >
Zu dieser schockierenden Ineffizienz kommen bei AVI noch folgende
2006-10-30 16:59:40 +00:00
wesentlichen Einschränkungen:
2006-09-27 08:59:17 +00:00
</para>
<orderedlist >
<listitem >
<para >
Nur Inhalt mit festen fps kann gespeichert werden. Dies ist insbesondere
2006-10-30 16:59:40 +00:00
dann einschränkend, wenn das Originalmaterial, das du encodieren willst,
2006-09-27 08:59:17 +00:00
gemischter Inhalt ist, zum Beispiel ein Mix aus NTSC-Video und
Filmmaterial.
2006-10-30 16:59:40 +00:00
Eigentlich gibt es Hacks, die es ermöglichen, Inhalt mit gemischter
Framerate in einer AVI unterzubringen, diese vergrößern jedoch den
(ohnehin großen) Overhead fünffach oder mehr und sind somit ungeeignet.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
Audio in AVI-Dateien muss entweder konstante Bitrate (CBR) oder
2006-10-30 16:59:40 +00:00
konstante Framegröße haben (also alle Frames decodieren zur selben Anzahl
2006-09-27 08:59:17 +00:00
Samples).
2006-10-30 16:59:40 +00:00
Unglücklicherweise erfüllt Vorbis, der effektivste Codec, keine dieser
2006-09-27 08:59:17 +00:00
Anforderungen.
Deshalb wirst du einen weniger effizienten Codec wie MP3 oder AC3 verwenden
2006-10-30 16:59:40 +00:00
müssen, wenn du planst, einen Film in AVI zu speichern.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</orderedlist>
<para >
2006-10-30 16:59:40 +00:00
Nachdem ich nun all dies erzählt habe, muss ich anmerken, momentan
unterstützt <application > MEncoder</application> keinen Output mit
2006-09-27 08:59:17 +00:00
variablen fps oder Vorbis-Encodierung.
2006-10-30 16:59:40 +00:00
Deswegen magst du dies nicht als Einschränkung ansehen, falls
2006-09-27 08:59:17 +00:00
<application > MEncoder</application> das einzige Tool ist, das du
nutzt, um deine Ecodierungen zu produzieren.
2006-10-30 16:59:40 +00:00
Es ist dennoch möglich, <application > MEncoder</application> nur zur
2006-09-27 08:59:17 +00:00
Videoencodierung zu verwenden und danach externe Tools, um Audio
zu encodieren und in ein anderes Containerformat zu muxen.
</para>
</sect3>
<sect3 id= "menc-feat-dvd-mpeg4-muxing-matroska" >
<title > Muxen in den Matroska-Container</title>
<para >
Matroska ist ein freies, offenes Containerformat, das darauf abzielt,
2006-10-30 16:59:40 +00:00
eine Menge erweiterter Features bereitzustellen, mit denen ältere Container
wie AVI nicht umgehen können.
Zum Beispiel unterstützt Matroska Audioinhalt mit variabler Bitrate (VBR),
variable Frameraten (VFR), Kapitel, Dateianhänge,
2007-09-27 15:27:13 +00:00
Fehlererkennung Error Detection Code (EDC) und modern A/V-Codecs wie "Advanced Audio
Coding" (AAC), "Vorbis" oder "MPEG-4 AVC" (H.264), so gut wie nichts
2006-09-27 08:59:17 +00:00
womit AVI etwas anfangen kann.
</para>
<para >
Die zum Erzeugen von Matroska-Dateien erforderlichen Tools werden
zusammen <application > mkvtoolnix</application> genannt und stehen
2006-10-30 16:59:40 +00:00
für die meisten Unix-Plattformen wie auch <application > Windows</application>
zur Verfügung.
2006-09-27 08:59:17 +00:00
Weil Matroska ein offener Standard ist, findest du vielleicht andere
2006-10-30 16:59:40 +00:00
Tools, die sich besser für dich eignen, aber da mkvtoolnix das am meisten
Verbreitete ist und von Matroska selbst unterstützt wird, werden wir nur
2006-09-27 08:59:17 +00:00
dessen Anwendung einbeziehen.
</para>
<para >
2006-10-30 16:59:40 +00:00
Möglicherweise der einfachste Weg, mit Matroska anzufangen, ist
2006-09-27 08:59:17 +00:00
<application > MMG</application> zu verwenden, das grafische Frontend,
das mit <application > mkvtoolnix</application> daherkommt, und dem
<ulink url= "http://www.bunkus.org/videotools/mkvtoolnix/doc/mkvmerge-gui.html" > guide to mkvmerge GUI (mmg)</ulink>
zu folgen.
</para>
<para >
Du kannst Audio und Video-Dateien auch per Befehlszeile muxen:
<screen > mkvmerge -o <replaceable > output.mkv</replaceable> <replaceable > input_video.avi</replaceable> <replaceable > input_audio1.mp3</replaceable> <replaceable > input_audio2.ac3</replaceable> </screen>
2006-10-30 16:59:40 +00:00
würde die Video-Datei <replaceable > input_video.avi</replaceable>
2006-09-27 08:59:17 +00:00
und die zwei Audio-Dateien <replaceable > input_audio1.mp3</replaceable>
und <replaceable > input_audio2.ac3</replaceable> in die Matroska-Datei
<replaceable > output.mkv</replaceable> mergen.
Matroska, wie zuvor beschrieben, ist in der Lage, noch viel mehr als
das zu tun, wie etwa multiple Audiotracks (inklusive Feintuning der
Audio-/Videosynchronisation), Kapitel, Untertitel, Splitting, usw...
Sieh bitte in den Dokumentationen dieser Anwendungen nach mehr Details.
</para>
</sect3>
</sect2>
</sect1>
<sect1 id= "menc-feat-telecine" >
<title > Wie mit telecine und interlacing in NTSC-DVDs umgehen</title>
<sect2 id= "menc-feat-telecine-intro" >
2006-10-30 16:59:40 +00:00
<title > Einführung</title>
2006-09-27 08:59:17 +00:00
<formalpara >
<title > Was ist telecine?</title>
<para >
Wenn du nicht viel von dem verstehst, was in diesem Dokument beschrieben wird, lies den
2006-10-30 16:59:40 +00:00
<ulink url= "http://en.wikipedia.org/wiki/Telecine" > Wikipedia-Artikel über Telecine</ulink> .
Dies ist eine verständliche und einigermaßen umfassende
2006-09-27 08:59:17 +00:00
Beschreibung dessen, was telecine ist.
</para>
</formalpara>
<formalpara >
<title > Eine Anmerkung zu Zahlen</title>
<para >
2006-10-30 16:59:40 +00:00
Viele Dokumente, einschließlich des oben verlinkten Handbuchs, beziehen
2006-09-27 08:59:17 +00:00
sich auf den Wert Felder pro Sekunde von NTSC-Video als 59.94 und den
2006-10-30 16:59:40 +00:00
korrespondierenden Frames pro Sekunde als 29.97 (für telecined und
interlaced) und 23.976 (für progressiv). Zur Vereinfachung runden
2006-09-27 08:59:17 +00:00
manche dieser Dokumente sogar auf 60, 30 und 24 auf.
</para>
</formalpara>
<para >
2006-10-30 16:59:40 +00:00
Streng genommen sind alle diese Zahlen Näherungswerte. Das schwarz/weiße
NTSC-Video war exakt 60 Felder pro Sekunde, später wurde jedoch 60000/1001
gewählt, um die Farbdaten anzupassen, solange man gleichzeitig
zu Schwarz/weiß-Fernsehen kompatibel blieb. Digitales NTSC-Video
2006-09-27 08:59:17 +00:00
(so wie auf einer DVD) hat ebenfalls 60000/1001 Felder pro Sekunde. Hieraus
wird interlaced und telecined Video als 30000/1001 Frames pro Sekunde
enthaltend abgeleitet; progressive Video hat 24000/1001 Frames pro Sekunde.
</para>
<para >
2006-10-30 16:59:40 +00:00
Ältere Versionen der <application > MEncoder</application> -Dokumentation
2006-09-27 08:59:17 +00:00
und viele archivierten Posts in Mailing-Listen beziehen sich auf 59.94,
29.97 und 23.976.
Alle <application > MEncoder</application> -Dokumentationen wurden insofern
aktualisiert, dass sie fraktionale Werte verwenden, und du solltest dies
auch tun.
</para>
<para >
<option > -ofps 23.976</option> ist inkorrekt.
<option > -ofps 24000/1001</option> sollte statt dessen benutzt werden.
</para>
<formalpara >
<title > Wie telecine angewandt wird</title>
<para >
Jedes Video, das zur Anzeige auf einem NTSC-Fernseh-Set vorgesehen ist,
2006-10-30 16:59:40 +00:00
muss 60000/1001 Felder pro Sekunde haben. Für TV-Filme und Shows
hergestellt sind sie häufig direkt mit 60000/1001 Feldern pro Sekunde
2006-09-27 08:59:17 +00:00
aufgenommen, die Mehrheit der Kinofilme jedoch mit 24 oder 24000/1001
Frames pro Sekunde. Wenn cinematische Movie-DVDs gemastert werden,
2006-10-30 16:59:40 +00:00
wird das Video danach fürs Fernsehen mittels eines telecine genannten
2006-09-27 08:59:17 +00:00
Prozesses konvertiert.
</para>
</formalpara>
<para >
Auf einer DVD wird das Video eigentlich nie als 60000/1001 Felder
2006-10-30 16:59:40 +00:00
pro Sekunde abgelegt. Für ein Video, das ursprünglich 60000/1001 war,
2006-09-27 08:59:17 +00:00
wird jedes Feldpaar zu einem Frame kombiniert, was dann 30000/1001
Frames pro Sekunde ergibt. Hardware-DVD-Player lesen dann ein im
Videostream eingebettetes Kennzeichen aus, um zu bestimmen, ob die gerade
oder ungerade nummerierten Zeilen das erste Feld formen sollen.
</para>
<para >
2006-10-30 16:59:40 +00:00
Üblicherweise bleibt ein Inhalt mit 24000/1001 Frames pro Sekunde
so wie er ist, wenn er für eine DVD encodiert wird, und der DVD-Player
2006-09-27 08:59:17 +00:00
muss das Telecining on-the-fly bewerkstelligen. Manchmal jedoch wird das
Video telecined <emphasis > bevor</emphasis> es auf der DVD gespeichert wird;
2006-10-30 16:59:40 +00:00
selbst wenn es ursprünglich 24000/1001 Frames pro Sekunde war, wird es
2006-09-27 08:59:17 +00:00
60000/1001 Felder pro Sekunde. Wenn es auf der DVD gespeichert wird,
werden Feldpaare zu 30000/1001 Frames pro Sekunde kombiniert.
</para>
<para >
2006-11-18 17:25:25 +00:00
Wenn man das aus 60000/1001 Feldern pro Sekunde geformten Einzelframes
2006-09-27 08:59:17 +00:00
erzeugte Video betrachtet, ist telecined oder anderenfalls Interlacing
klar sichtbar woimmer Bewegung auftritt, da ein Feld (sagen wir, die
geradzahlig nummerierten Zeilen) einen Moment zur Zeit 1/(60000/1001) Sekunden
2006-10-30 16:59:40 +00:00
später als das andere repräsentiert. Spielt man ein interlaced Video auf
einem Computer ab, sehen beide hässlich aus, weil der Monitor eine höhere
Auflösung besitzt und weil das Video Frame für Frame anstatt Feld für Feld
2006-09-27 08:59:17 +00:00
angezeigt wird.
</para>
<itemizedlist >
<title > Anmerkungen</title>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Dieser Abschnitt gilt nur für NTSC-DVDs und nicht für PAL.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Die <application > MEncoder</application> -Beispielzeilen überall im
2006-09-27 08:59:17 +00:00
Dokument sind <emphasis role= "bold" > nicht</emphasis> zum
2006-10-30 16:59:40 +00:00
eigentlichen Gebrauch vorgesehen. Sie sind schlicht das bloße Minimum,
das zum Encodieren der betreffenden Videokategorie benötigt wird.
2006-09-27 08:59:17 +00:00
Wie mache ich gute DVD-Rips oder wie feintune ich
<systemitem class= "library" > libavcodec</systemitem> auf maximale
2006-10-30 16:59:40 +00:00
Qualität gehören nicht zum Umfang dieses Dokuments.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Es gibt ein paar Fußnoten speziell für dieses Handbuch, die so ähnlich
2006-09-27 08:59:17 +00:00
verlinkt sind:
<link linkend= "menc-feat-telecine-footnotes" > [1]</link>
</para>
</listitem>
</itemizedlist>
</sect2>
<sect2 id= "menc-feat-telecine-ident" >
<title > Wie kann man sagen, welchen Typ Video man hat</title>
<sect3 id= "menc-feat-telecine-ident-progressive" >
<title > Progressiv</title>
<para >
2006-10-30 16:59:40 +00:00
Progressive Video wurde ursprünglich mit 24000/1001 fps gefilmt und
ohne Änderung auf der DVD abgespeichert.
2006-09-27 08:59:17 +00:00
</para>
<para >
Wenn du eine progressive DVD in <application > MPlayer</application> abspielst,
wird <application > MPlayer</application> folgende Zeile ausgeben, sobald
das Abspielen des Films beginnt:
<screen > demux_mpg: 24000/1001 fps progressive NTSC content detected, switching framerate.</screen>
2006-10-30 16:59:40 +00:00
Von diesem Punkt an vorwärts sollte demux_mpg nie erzählen, es finde
2007-09-27 15:27:13 +00:00
"30000/1001 fps NTSC content."
2006-09-27 08:59:17 +00:00
</para>
<para >
Wenn du progressives Video ankuckst, solltest du nie irgendein
Interlacing sehen. Sei trotzdem vorsichtig, weil manchmal ein winziges
bisschen telecine dort hineingemischt wurde, wo du es nicht erwartest.
Ich bin TV-Serien-DVDs begegnet, die eine Sekunde telecine bei jedem
2006-10-30 16:59:40 +00:00
Szenenwechsel haben oder an extrem zufälligen Stellen. Ich hatte mir einmal
eine DVD angesehen, die eine progressive erste Hälfte besaß, und die
zweite Hälfte war telecined. Willst du<emphasis > wirklich</emphasis>
gründlich sein, kannst du den kompletten Film scannen:
2006-09-27 08:59:17 +00:00
<screen > mplayer dvd://1 -nosound -vo null -benchmark</screen>
Das Verwenden von <option > -benchmark</option> veranlasst
<application > MPlayer</application> , den Film so schnell er es nur kann
abzuspielen; dies dauert je nach Hardware trotzdem noch eine
Weile. Jedesmal wenn demux_mpg einen Frameratenwechsel meldet, wird dir
2006-10-30 16:59:40 +00:00
die Zeile unmittelbar darüber die Zeit zeigen, bei welcher der Wechsel
2006-09-27 08:59:17 +00:00
auftrat.
</para>
<para >
Manchmal wird progressive Video auf DVDs
2007-09-27 15:27:13 +00:00
"soft telecine" zugeordnet, weil es dazu vorgesehen ist,
2006-09-27 08:59:17 +00:00
vom DVD-Player telecined zu werden.
</para>
</sect3>
<sect3 id= "menc-feat-telecine-ident-telecined" >
<title > Telecined</title>
<para >
2006-10-30 16:59:40 +00:00
Telecined Video war ursprünglich mit 24000/1001 aufgenommen, wurde aber
2006-09-27 08:59:17 +00:00
telecined, <emphasis > bevor</emphasis> es auf die DVD geschrieben wurde.
</para>
<para >
<application > MPlayer</application> meldet keine (nie)
Frameratenwechsel, wenn er telecined Video abspielt.
</para>
<para >
Beim Betrachten eines telecined Videos wirst du Interlacing-Artefakte
2007-09-27 15:27:13 +00:00
sehen, die zu "blinken" scheinen: sie erscheinen wiederholt
2006-09-27 08:59:17 +00:00
und verschwinden wieder.
Du kannst dir das so genauer hinschauen
<orderedlist >
<listitem >
<screen > mplayer dvd://1</screen>
</listitem>
<listitem >
<para >
Suche einen Teil mit Bewegung.
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Benutze die Taste <keycap > .</keycap> , um jeweils einen Frame vorwärts zu rücken.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
Schau auf das Muster der interlaced und progressive aussehenden
Frames. Ist das Muster, das du siehst PPPII,PPPII,PPPII,... dann ist das
2006-10-30 16:59:40 +00:00
Video telecined. Siehst du andere Muster, dann wurde das Video womöglich
2006-09-27 08:59:17 +00:00
mittels einiger Nicht-Standard-Methoden telecined;
<application > MEncoder</application> kann ein Nicht-Standard-telecine
2006-10-30 16:59:40 +00:00
nicht verlustfrei nach progressive konvertieren. Siehst du überhaupt
keine Muster, ist es höchstwahrscheinlich interlaced.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</orderedlist>
</para>
<para >
2007-09-27 15:27:13 +00:00
Manchmal wird telecined Video auf DVDs "hard telecine"
2006-09-27 08:59:17 +00:00
zugeordnet. Da hard telecine bereits 60000/1001 Felder pro Sekunde hat,
spielt der DVD-Player das Video ohne irgendeine Manipulation ab.
</para>
<para >
Ein anderer Weg, zu sagen, ob deine Quelle telecined ist oder nicht,
ist die Quelle mit den Befehlszeilenoptionen <option > -vf pullup</option>
und <option > -v</option> abzuspielen, um nachzusehen, wie
<option > pullup</option> zu den Frames passt.
Ist die Quelle telecined, solltest du in der Befehlszeile ein 3:2 Muster
mit abwechselnd <systemitem > 0+.1.+2</systemitem> und <systemitem > 0++1</systemitem>
anzeigen.
Diese Technik hat den Vorteil, dass du die Quelle nicht zu beobachten
2006-10-30 16:59:40 +00:00
brauchst, um sie zu identifizieren, was von Nutzen sein könnte, falls du
2006-09-27 08:59:17 +00:00
den Encodiervorgang automatisieren willst oder besagte Prozedur ferngesteuert
mittels einer langsamen Verbindung vornehmen willst.
</para>
</sect3>
<sect3 id= "menc-feat-telecine-ident-interlaced" >
<title > Interlaced</title>
<para >
2006-10-30 16:59:40 +00:00
Interlaced Video wurde ursprünglich als 60000/1001 Felder pro Sekunde
2006-09-27 08:59:17 +00:00
aufgenommen und auf der DVD als 30000/1001 Frames pro Sekunde abgespeichert.
2007-09-27 15:27:13 +00:00
Der interlacing-Effekt (oft "combing" genannt) ist ein Ergebnis
2006-09-27 08:59:17 +00:00
von Kammpaaren von Feldern in Frames. Jedes Feld wird einzeln als
1/(60000/1001) Sekunden angenommen, und wenn sie simultan angezeigt werden,
wird der Unterschied offensichtlich.
</para>
<para >
Wie bei telecined Video sollte <application > MPlayer</application> niemals
einen Frameratewechsel beim Abspielen des interlaced Inhalts melden.
</para>
<para >
Wenn du ein interlaced Video genau ansiehst, in dem du dich mit der Taste
<keycap > .</keycap> durch die Frames bewegst, wirst du sehen, dass
jeder einzelne Frame interlaced ist.
</para>
</sect3>
<sect3 id= "menc-feat-telecine-ident-mixedpt" >
<title > Gemischtes progressive und telecine</title>
<para >
2007-09-27 15:27:13 +00:00
Alle "gemischten progressive und telecine" Videos wurden ursprünglich
2006-09-27 08:59:17 +00:00
als 24000/1001 Frames pro Sekunde aufgenommen, jedoch werden einige Teile
telecined beendet.
</para>
<para >
Spielt <application > MPlayer</application> diese Kategorie ab, wird er
2007-09-27 15:27:13 +00:00
(oft wiederholt) zwischen "30000/1001 fps NTSC"
und "24000/1001 fps progressive NTSC" zurück und vor wechseln.
2006-10-30 16:59:40 +00:00
Beobachte die untere Hälfte von <application > MPlayer</application> s Ausgabe,
2006-09-27 08:59:17 +00:00
um diese Meldungen anzusehen.
</para>
<para >
2007-09-27 15:27:13 +00:00
Du solltest die Sektion "30000/1001 fps NTSC" überprüfen, um
2006-09-27 08:59:17 +00:00
sicher zu gehen, dass sie auch wirklich telecine sind und nicht einfach
interlaced.
</para>
</sect3>
<sect3 id= "menc-feat-telecine-ident-mixedpi" >
<title > Gemischtes progressive und interlaced</title>
<para >
2007-09-27 15:27:13 +00:00
In "gemischtem progressive und interlaced" Inhalt wurde progressive
2006-09-27 08:59:17 +00:00
und interlaced Video zusammengeklebt.
</para>
<para >
2007-09-27 15:27:13 +00:00
Diese Kategorie sieht aus wie "gemischtes progressive und telecine",
2006-09-27 08:59:17 +00:00
bis du die Sektion 30000/1001 fps untersuchst und feststellst, dass
sie das telecine-Muster nicht haben.
</para>
</sect3>
</sect2>
<sect2 id= "menc-feat-telecine-encode" >
<title > Wie jede Kategorie encodieren</title>
<para >
Wie ich anfangs angemerkt hatte, sind die
<application > MEncoder</application> -Beispielzeilen unten eigentlich
<emphasis role= "bold" > nicht</emphasis> zur Anwendung bestimmt;
sie demonstrieren nur die Minimalparameter zur korrekten Encodierung
jeder Kategorie.
</para>
<sect3 id= "menc-feat-telecine-encode-progressive" >
<title > Progressive</title>
<para >
Progressive Video erfordert kein spezielles Filtern, um es zu encodieren.
Der einzige Parameter, den du gewiss anwenden solltest ist
<option > -ofps 24000/1001</option> . Andernfalls wird
<application > MEncoder</application> versuchen, bei 30000/1001 fps
zu encodieren und Frames duplizieren.
</para>
<para >
<screen > mencoder dvd://1 -oac copy -ovc lavc -ofps 24000/1001</screen>
</para>
<para >
2006-10-30 16:59:40 +00:00
Dennoch ist es öfters der Fall, dass ein Video, das progressive aussieht,
2006-09-27 08:59:17 +00:00
eigentlich kurze Teile telecine eingemischt hat. Solange du dir nicht
sicher bist, ist es am sichersten, das Video als
<link linkend= "menc-feat-telecine-encode-mixedpt" > gemischtes progressive und telecine</link> .
zu behandeln. Der Performance-Verlust ist gering
<link linkend= "menc-feat-telecine-footnotes" > [3]</link> .
</para>
</sect3>
<sect3 id= "menc-feat-telecine-encode-telecined" >
<title > Telecined</title>
<para >
Telecine kann umgekehrt werden, um den originalen 24000/1001-Inhalt zu erhalten,
indem man einen Prozess verwendet, der inverse-telecine genannt wird.
2006-10-30 16:59:40 +00:00
<application > MPlayer</application> enthält verschiedene Filter, um dies
2006-09-27 08:59:17 +00:00
zu erreichen; der beste Filter, <option > pullup</option> wird in der Sektion
<link linkend= "menc-feat-telecine-encode-mixedpt" > Gemischtes progressive und telecine</link>
beschrieben.
</para>
</sect3>
<sect3 id= "menc-feat-telecine-encode-interlaced" >
<title > Interlaced</title>
<para >
2006-10-30 16:59:40 +00:00
In den meisten praktischen Fällen ist es nicht möglich, ein komplett
2006-09-27 08:59:17 +00:00
progressives Video aus interlaced Inhalt zu erhalten. Der einzige Weg,
2006-10-30 16:59:40 +00:00
dies ohne den Verlust der Hälfte der vertikalen Auflösung zu erreichen,
2006-09-27 08:59:17 +00:00
ist das Verdoppeln der Framerate, und man kann versuchen zu
2007-09-27 15:27:13 +00:00
"schätzen", wie die korrespondierenden Zeilen für jedes Feld
2006-10-30 16:59:40 +00:00
vervollständigt werden sollten (dies hat Nachteile - siehe Methode 3).
2006-09-27 08:59:17 +00:00
</para>
<orderedlist >
<listitem >
<para >
Das Video in interlaced Form encodieren. Normalerweise richtet Interlacing
2006-10-30 16:59:40 +00:00
verheerenden Schaden für die Fähigkeit des Encoders an, gut zu komprimieren,
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavcodec</systemitem> hat jedoch zwei
2006-10-30 16:59:40 +00:00
eigens für das ein wenig bessere Abspeichern von interlaced Video gedachte
2006-09-27 08:59:17 +00:00
Parameter: <option > ildct</option> und <option > ilme</option> . Auch wenn
die Verwendung von <option > mbd=2</option> dringend zu empfehlen ist
<link linkend= "menc-feat-telecine-footnotes" > [2]</link> , weil es
2006-10-30 16:59:40 +00:00
Macroblöcke wie nicht-interlaced an Stellen encodiert, an denen keine Bewegung
2006-09-27 08:59:17 +00:00
stattfindet. Beachte, dass <option > -ofps</option> hier NICHT notwendig ist.
<screen > mencoder dvd://1 -oac copy -ovc lavc -lavcopts ildct:ilme:mbd=2</screen>
</para>
</listitem>
<listitem >
<para >
Nutze einen Deinterlacing-Filter vor dem Encodieren. Es stehen verschiedene
dieser Filter zur Auswahl, jeder mit seinen eigenen Vor-
2006-11-23 22:51:42 +00:00
und Nachteilen. Ziehe <option > mplayer -pphelp</option> und <option > mplayer -vf help</option>
zu Rate, um zu sehen, welche
2007-09-27 15:27:13 +00:00
verfügbar sind (suche nach "deint"), lies Michael Niedermayers
2006-11-23 22:51:42 +00:00
<ulink url= "http://guru.multimedia.cx/deinterlacing-filters/" > Deinterlacing-Filter-Vergleich</ulink>
und durchsuche die
2006-12-04 19:46:47 +00:00
<ulink url= "http://www.mplayerhq.hu/design7/mailing_lists.html" > MPlayer-Mailinglisten</ulink> ,
2006-11-23 22:51:42 +00:00
um Diskussionen über die zahlreichen Filter zu finden.
Nochmals, die Framerate ändert sich nicht, also kein
2006-10-30 16:59:40 +00:00
<option > -ofps</option> . Deinterlacing sollte außerdem nach dem Zuschneiden
2006-09-27 08:59:17 +00:00
(cropping) <link linkend= "menc-feat-telecine-footnotes" > [1]</link>
und vor dem Skalieren angewandt werden.
2006-11-23 22:51:42 +00:00
<screen > mencoder dvd://1 -oac copy -vf yadif -ovc lavc</screen>
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Unglücklicherweise arbeitet diese Option im Zusammenhang mit
2006-09-27 08:59:17 +00:00
<application > MEncoder</application> fehlerhaft; sie sollte mit
<application > MEncoder G2</application> gut funktionieren, den gibts aber
2006-10-30 16:59:40 +00:00
noch nicht. Du könntest Abstürze erleben. Seis drum, der Zweck von
2006-09-27 08:59:17 +00:00
<option > -vf tfields</option> ist es, einen vollen Frame aus jedem Feld
zu erzeugen, was eine Framerate von 60000/1001 ergibt. Der Vorteil dieses
2006-10-30 16:59:40 +00:00
Lösungsansatzes ist, dass nie irgendwelche Daten verloren gehen;
dennoch, da jeder Frame aus nur einem Feld kommt, müssen die fehlenden Zeilen
2006-09-27 08:59:17 +00:00
irgendwie interpoliert werden. Es gibt keine sehr guten Methoden, die
fehlenden Daten zu generieren, und so wird das Resultat ein bisschen aussehen,
2006-10-30 16:59:40 +00:00
als hätte man irgendeinen Deinterlacing-Filter verwendet. Die fehlenden Zeilen
2006-09-27 08:59:17 +00:00
zu generieren erzeugt auch weitere Probleme, einfach weil sich die Menge
2006-10-30 16:59:40 +00:00
an Daten verdoppelt. Somit sind höhere Encodier-Bitraten nötig, um
die Qualität beizubehalten und mehr CPU-Power wird für beides,
2006-09-27 08:59:17 +00:00
Encodieren und Decodieren, aufgewendet. Das Attribut tfields hat mehrere
2006-10-30 16:59:40 +00:00
verschiedene Optionen dafür, wie die fehlenden Zeilen jedes Frames erzeugt
2006-09-27 08:59:17 +00:00
werden.
2006-10-30 16:59:40 +00:00
Wenn du diese Methode nutzt, dann nimm Bezug auf das Handbuch und wähle,
welche Option auch immer am besten für dein Material aussieht.
2006-09-27 08:59:17 +00:00
Beachte, dass du wenn <option > tfields</option> verwendet wird,
sowohl <option > -fps</option> als auch <option > -ofps</option> spezifizieren <emphasis role= "bold" > musst</emphasis> ,
um die doppelte Framerate der originalen Quelle zu erhalten.
<screen > mencoder dvd://1 -oac copy -vf tfields=2 -ovc lavc -fps 60000/1001 -ofps 60000/1001</screen>
</para>
</listitem>
<listitem >
<para >
Wenn du vorhast, dramatisch herunterzuskalieren, kannst du nur eins
der beiden Felder extrahieren und encodieren. Sicherlich, du wirst die
2006-10-30 16:59:40 +00:00
Hälfte der vertikalen Auflösung verlieren, aber wenn du planst, bis auf
2006-09-27 08:59:17 +00:00
1/2 des Originals herunter zu skalieren, macht der Verlust so gut wie
gar nichts aus. Das Resultat wird eine progressive Datei mit 30000/1001
Frames pro Sekunde sein. Die Prozedur ist, <option > -vf field</option>
2006-10-30 16:59:40 +00:00
zu verwenden, dann die Ränder abzuschneiden
2006-09-27 08:59:17 +00:00
<link linkend= "menc-feat-telecine-footnotes" > [1]</link> und angemessen
zu skalieren. Vergiss nicht, dass du die Skalierung anpassen musst, um
2006-10-30 16:59:40 +00:00
das Halbieren der vertikalen Auflösung zu kompensieren.
2006-09-27 08:59:17 +00:00
<screen > mencoder dvd://1 -oac copy -vf field=0 -ovc lavc</screen>
</para>
</listitem>
</orderedlist>
</sect3>
<sect3 id= "menc-feat-telecine-encode-mixedpt" >
<title > Gemischtes progressive und telecine</title>
<para >
Um progressive und telecine Video komplett in progressive Video
2006-10-30 16:59:40 +00:00
umzuwandeln, müssen die telecined Teile inverse-telecined werden.
2006-09-27 08:59:17 +00:00
Die drei Wege, dies zu erreichen, werden unten beschrieben.
Beachte, dass du inverse-telecine <emphasis role= "bold" > immer</emphasis>
2006-10-30 16:59:40 +00:00
vor der Reskalierung durchführen solltest; es sei denn, du weißt wirklich,
was du tust; mache inverse-telecine auch vor dem Entfernen der Ränder
2006-09-27 08:59:17 +00:00
<link linkend= "menc-feat-telecine-footnotes" > [1]</link> .
2006-10-30 16:59:40 +00:00
<option > -ofps 24000/1001</option> wird hier benötigt, weil das Output-Video
2006-09-27 08:59:17 +00:00
24000/1001 Frames pro Sekunde werden soll.
</para>
<itemizedlist >
<listitem >
<para >
<option > -vf pullup</option> wurde entworfen, um auf telecined Material
2006-10-30 16:59:40 +00:00
inverse-telecine anzuwenden, während die progressiven Daten unangetastet
2006-09-27 08:59:17 +00:00
bleiben. Damit dies richtig funktioniert, <emphasis role= "bold" > muss</emphasis>
<option > pullup</option> vom <option > softskip</option> -Filter gefolgt werden, sonst
2006-10-30 16:59:40 +00:00
wird <application > MEncoder</application> abstürzen.
2006-09-27 08:59:17 +00:00
<option > pullup</option> ist trotz allem die sauberste und akkurateste
Methode, die zum Encodieren von beidem telecine und
2007-09-27 15:27:13 +00:00
"gemischtem progressive und telecine" zur Verfügung steht.
2006-09-27 08:59:17 +00:00
<screen > mencoder dvd://1 -oac copy -vf pullup,softskip -ovc lavc -ofps 24000/1001</screen>
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Eine ältere Methode ist, anstatt inverse-telecine auf die telecined Teile
2006-09-27 08:59:17 +00:00
anzuwenden, telecine auf nicht-telecined Teile und dann inverse-telecine auf das
2006-10-30 16:59:40 +00:00
ganze Video anzuwenden. Hört sich verwirrend an? softpulldown ist
2006-09-27 08:59:17 +00:00
ein Filter, der ein Video durchgeht und die komplette Datei telecined macht.
Lassen wir auf softpulldown entweder <option > detc</option> oder <option > ivtc</option>
folgen, wird das Endergebnis vollkommen progressiv. <option > -ofps 24000/1001</option>
2006-10-30 16:59:40 +00:00
wird benötigt.
2006-09-27 08:59:17 +00:00
<screen > mencoder dvd://1 -oac copy -vf softpulldown,ivtc=1 -ovc lavc -ofps 24000/1001</screen>
</para>
</listitem>
<listitem >
<para >
Ich habe <option > -vf filmdint</option> selbst verwendet, aber lies hier, was
2006-10-30 16:59:40 +00:00
D Richard Felker III zu erzählen hat:
2006-09-27 08:59:17 +00:00
<blockquote >
<para >
Es ist OK, aber IMO versucht er zu oft eher ein deinterlace
2006-10-30 16:59:40 +00:00
als ein inverse telecine durchzuführen (ganz wie Settop-DVD-Player
& progressive TVs), was ein hässliches Flimmern erzeugt und
2006-09-27 08:59:17 +00:00
andere Artefakte. Wenn du vorhast, es anzuwenden, musst du zumindest
einige Zeit darauf verwenden, die Optionen zu tunen und zuerst den Output
zu beobachten, damit du auch sicher sein kannst, dass du nichts
vermasselst.
</para>
</blockquote>
</para>
</listitem>
</itemizedlist>
</sect3>
<sect3 id= "menc-feat-telecine-encode-mixedpi" >
<title > Gemischtes progressive und interlaced</title>
<para >
2006-10-30 16:59:40 +00:00
Es gibt zwei Optionen für den Umgang mit dieser Kategorie, jede von
2006-09-27 08:59:17 +00:00
beiden stellt einen Kompromiss dar. Du solltest basierend auf
Dauer/Stelle jedes Typs entscheiden.
</para>
<itemizedlist >
<listitem >
<para >
Behandle es wie progressive. Die interlaced Teile werden interlaced
2006-10-30 16:59:40 +00:00
aussehen und einige der interlaced Felder müssen weggelassen werden,
was ein wenig zu Sprüngen führt. Du kannst einen
2006-09-27 08:59:17 +00:00
Nachbearbeitungsfilter verwenden, wenn du willst, aber dies wird die
2006-10-30 16:59:40 +00:00
progressive-Anteile geringfügig verringern.
2006-09-27 08:59:17 +00:00
</para>
<para >
Diese Option sollte definitiv nicht verwendet werden, wenn du eventuell
2006-10-30 16:59:40 +00:00
Video auf einem interlaced Gerät anzeigen willst (mit einer TV-Karte
2006-09-27 08:59:17 +00:00
zum Beispiel). Wenn du interlaced Frames in einem Video mit 24000/1001
Frames pro Sekunde hast, werden diese zusammen mit den progressive
2007-09-27 15:27:13 +00:00
Frames telecined. Die Hälfte der interlaced "Frames" werden für die
2006-09-27 08:59:17 +00:00
Dauer von drei Feldern (3/(60000/1001) Sekunden) angezeigt, was
2007-09-27 15:27:13 +00:00
einen flimmernden "Zeitrücksprung"-Effekt zur Folge hat, der
2006-09-27 08:59:17 +00:00
ziemlich schlecht aussieht. Solltest du dies dennoch versuchen,
<emphasis role= "bold" > musst</emphasis> du einen
Deinterlacing-Filter wie <option > lb</option> oder <option > l5</option>
anwenden.
</para>
<para >
2006-10-30 16:59:40 +00:00
Es wäre auch keine gute Idee für eine progressive Anzeige. Es wird
2006-09-27 08:59:17 +00:00
Paare aufeinander folgender interlaced Felder auslassen, was eine
Unstetigkeit zur Folge hat, die eher sichtbar ist als mit der
zweiten Methode, die einige progressive Frames zweimal anzeigt.
Ein interlaced Video mit 30000/1001 Frames pro Sekunde ist bereits
ein bisschen abgehackt, weil es wirklich mit 60000/1001 Felder pro
Sekunde angezeigt werden sollte, sodass sich die doppelten Frames
nicht zu sehr abzeichnen.
</para>
<para >
2006-10-30 16:59:40 +00:00
Egal welchen Weg du wählst, es ist das beste, deinen Inhalt
zu berücksichtigen und wie du ihn anzeigen willst. Ist dein Video
2006-09-27 08:59:17 +00:00
zu 90% progressive und du hast nie vor, es auf einem TV-Bildschirm
2006-10-30 16:59:40 +00:00
anzuzeigen, solltest du einen progressive-Ansatz wählen. Ist es nur
2006-09-27 08:59:17 +00:00
halb-progressive, willst du es eventuell so encodieren, als sei alles
interlaced.
</para>
</listitem>
<listitem >
<para >
Behandle es wie interlaced. Einige Frames des progressive-Anteils
2006-10-30 16:59:40 +00:00
müssen dupliziert werden, was zu Sprüngen führt. Nochmal,
Deinterlacing-Filter können die progressive-Anteile leicht verringern.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</itemizedlist>
</sect3>
</sect2>
<sect2 id= "menc-feat-telecine-footnotes" >
2006-10-30 16:59:40 +00:00
<title > Fußnoten</title>
2006-09-27 08:59:17 +00:00
<orderedlist >
<listitem >
<formalpara >
2006-10-30 16:59:40 +00:00
<title > Über das Zuschneiden (cropping):</title>
2006-09-27 08:59:17 +00:00
<para >
Videodaten auf DVDs werden in einem YUV 4:2:0 genannten Format abgelegt.
In einem YUV-Video, werden Helligkeit und Chrominanz separat gespeichert.
Da das menschliche Auge ein bisschen weniger empfindlich auf Farbe
reagiert als auf Helligkeit, ist in einem YUV 4:2:0 Bild nur ein
2006-10-30 16:59:40 +00:00
Chrominanz-Pixel für alle vier Helligkeits-Pixel vorhanden.
2006-09-27 08:59:17 +00:00
In einem progressive Bild, besitzt jedes Quadrat von vier luma-Pixeln (zwei
auf jeder Seite) ein gemeinsames chroma-Pixel. Du musst progressive YUV
2006-10-30 16:59:40 +00:00
4:2:0 zu geradzahligen Auflösungen zurechtschneiden und geradzahlige
2006-09-27 08:59:17 +00:00
Offsets verwenden. Zum Beispiel ist
<option > crop=716:380:2:26</option> OK,
<option > crop=716:380:3:26 </option> aber nicht.
</para>
</formalpara>
<para >
Wenn du es mit interlaced YUV 4:2:0 zu tun hast, ist die Situation
ein wenig komplizierter. Anstatt dass immer vier luma-Pixel im
<emphasis > Frame</emphasis> sich ein chroma-Pixel teilen, teilen sich
immer vier luma-Pixel in jedem <emphasis > Feld</emphasis> ein
chroma-Pixel. Wenn Felder zur Formung eines Frames interlaced werden,
ist jede Scanzeile ein Pixel hoch. Jetzt liegen anstatt je vier
luma-Pixel in einem Quadrat immer zwei Pixel nebeneinander und die
anderen zwei Pixel liegen zwei Scanzeilen weiter unten nebeneinander.
Die zwei luma-Pixel in der dazwischen liegenden Scanzeile sind vom
anderen Feld und teilen sich somit ein anderes chroma-Pixel mit
zwei luma-Pixeln zwei Scanzeile entfernt. All diese Konfusion macht
es notwendig, vertikale Ausschneide-Abmessungen und Offsets zu
haben, die ein Vielfaches von vier sind. Horizontal kann geradzahlig
bleiben.
</para>
<para >
2006-10-30 16:59:40 +00:00
Für telecined Video empfehle ich, das Zuschneiden nach dem inverse
2006-09-27 08:59:17 +00:00
telecining stattfinden zu lassen. Ist das Video einmal progressive,
musst du nur noch mit geraden Zahlen zuschneiden. Wenn du wirklich die
leichte Beschleunigung haben willst, die zuerst zuzuschneiden
2006-10-30 16:59:40 +00:00
möglicherweise bietet, musst du vertikal mit einem Vielfachen von vier
2006-09-27 08:59:17 +00:00
zuschneiden, oder der inverse-telecine Filter wird keine korrekten Daten
haben.
</para>
<para >
2006-10-30 16:59:40 +00:00
Für interlaced (nicht telecined) Video musst du immer
2006-09-27 08:59:17 +00:00
mit einem Vielfachen von vier zuschneiden, es sei denn, du verwendest
<option > -vf field</option> vor dem Schneiden.
</para>
</listitem>
<listitem > <formalpara >
2006-10-30 16:59:40 +00:00
<title > Über Encodier-Parameter und Qualität:</title>
2006-09-27 08:59:17 +00:00
<para >
2006-10-30 16:59:40 +00:00
Nur weil ich hier <option > mbd=2</option> vorschlage, heißt das nicht,
2006-09-27 08:59:17 +00:00
dass es woanders benutzt werden soll. Zusammen mit <option > trell</option>
ist <option > mbd=2</option> eine der Optionen von
<systemitem class= "library" > libavcodec</systemitem> , welche die
2006-10-30 16:59:40 +00:00
Qualität am deutlichsten heben, und du solltest stets das letzte der beiden
anwenden, außer das Abfallen der Encodiergeschwindigkeit ist abschreckend
hoch (z.B. Encodierung in Echtzeit). Es gibt eine Menge anderer Optionen für
<systemitem class= "library" > libavcodec</systemitem> , die die Encodierqualität
2006-09-27 08:59:17 +00:00
verbessern (und die Encodiergeschwindigkeit verringern), dies liegt aber jenseits
des Rahmens dieses Dokuments.
</para>
</formalpara>
</listitem>
<listitem >
<formalpara >
2006-10-30 16:59:40 +00:00
<title > Über die Performance von pullup:</title>
2006-09-27 08:59:17 +00:00
<para >
<option > Pullup</option> kann sicher (zusammen mit <option > softskip</option> )
2006-10-30 16:59:40 +00:00
auf progressive Video angewandt werden und ist für gewöhnlich eine gute Idee,
2006-09-27 08:59:17 +00:00
es sei denn, die Quelle wurde definitiv als vollkommen progressive verifiziert.
2006-10-30 16:59:40 +00:00
Der Performaceverlust ist in den meisten Fällen gering. Bei einer Minimalencodierung
2006-09-27 08:59:17 +00:00
macht <option > pullup</option> <application > MEncoder</application>
2006-10-30 16:59:40 +00:00
50% langsamer. Das Hinzufügen von Soundverarbeitung und erweiterten
<option > lavcopts</option> überschattet diesen Unterschied
und drückt den Performanceabfall, der mit dem Verwenden von <option > pullup</option>
2006-09-27 08:59:17 +00:00
verbunden war, runter auf 2%.
</para>
</formalpara>
</listitem>
</orderedlist>
</sect2>
</sect1>
<sect1 id= "menc-feat-enc-libavcodec" >
<title > Encodieren mit der <systemitem class= "library" > libavcodec</systemitem>
Codecfamilie</title>
<para >
<link linkend= "ffmpeg" > <systemitem class= "library" > libavcodec</systemitem> </link>
2006-10-30 16:59:40 +00:00
stellt einfache Encodierung für eine Menge interessanter Video- und Audioformate
zur Verfügung.
2006-09-27 08:59:17 +00:00
Du kannst folgende Codecs encodieren (mehr oder weniger aktuell):
</para>
<sect2 id= "menc-feat-enc-libavcodec-video-codecs" >
<title > Videocodecs von <systemitem class= "library" > libavcodec</systemitem> </title>
<para >
<informaltable frame= "all" >
<tgroup cols= "2" >
<thead >
<row > <entry > Name des Videocodecs</entry> <entry > Beschreibung</entry> </row>
</thead>
<tbody >
<row > <entry > mjpeg</entry> <entry >
Motion-JPEG
</entry> </row>
<row > <entry > ljpeg</entry> <entry >
Verlustfreies JPEG
</entry> </row>
<row > <entry > h261</entry> <entry >
H.261
</entry> </row>
<row > <entry > h263</entry> <entry >
H.263
</entry> </row>
<row > <entry > h263p</entry> <entry >
H.263+
</entry> </row>
<row > <entry > mpeg4</entry> <entry >
2006-11-13 09:48:00 +00:00
ISO Standard MPEG-4 (DivX, Xvid-kompatibel)
2006-09-27 08:59:17 +00:00
</entry> </row>
<row > <entry > msmpeg4</entry> <entry >
Pre-Standard MPEG-4 Variante von MS, v3 (AKA DivX3)
</entry> </row>
<row > <entry > msmpeg4v2</entry> <entry >
Pre-Standard MPEG-4 von MS, v2 (in alten ASF-Dateien verwendet)
</entry> </row>
<row > <entry > wmv1</entry> <entry >
Windows Media Video, Version 1 (AKA WMV7)
</entry> </row>
<row > <entry > wmv2</entry> <entry >
Windows Media Video, Version 2 (AKA WMV8)
</entry> </row>
<row > <entry > rv10</entry> <entry >
RealVideo 1.0
</entry> </row>
<row > <entry > rv20</entry> <entry >
RealVideo 2.0
</entry> </row>
<row > <entry > mpeg1video</entry> <entry >
MPEG-1 Video
</entry> </row>
<row > <entry > mpeg2video</entry> <entry >
MPEG-2 Video
</entry> </row>
<row > <entry > huffyuv</entry> <entry >
Verlustfreie (lossless) Kompression
</entry> </row>
<row > <entry > asv1</entry> <entry >
ASUS Video v1
</entry> </row>
<row > <entry > asv2</entry> <entry >
ASUS Video v2
</entry> </row>
<row > <entry > ffv1</entry> <entry >
FFmpeg's verlustfreier (lossless) Videocodec
</entry> </row>
<row > <entry > svq1</entry> <entry >
Sorenson Video 1
</entry> </row>
<row > <entry > flv</entry> <entry >
Sorenson H.263, der in Flash Video benutzt wird
</entry> </row>
<row > <entry > dvvideo</entry> <entry >
Sony Digital Video
</entry> </row>
<row > <entry > snow</entry> <entry >
FFmpeg's experimenteller Wavelet-basierter Codec
</entry> </row>
</tbody>
</tgroup>
</informaltable>
2006-10-30 16:59:40 +00:00
Die erste Spalte enthält die Codecnamen, die nach der Konfiguration
<literal > vcodec</literal> übergeben werden müssen, wie:
2006-09-27 08:59:17 +00:00
<option > -lavcopts vcodec=msmpeg4</option>
</para>
<informalexample >
<para >
Ein Beispiel mit MJPEG-Komprimierung:
<screen > mencoder dvd://2 -o title2.avi -ovc lavc -lavcopts vcodec=mjpeg -oac copy</screen>
</para>
</informalexample>
</sect2>
<sect2 id= "menc-feat-enc-libavcodec-audio-codecs" >
<title > Audiocodecs von <systemitem class= "library" > libavcodec</systemitem> </title>
<para >
<informaltable frame= "all" >
<tgroup cols= "2" >
<thead >
<row > <entry > Name des Audiocodecs</entry> <entry > Beschreibung</entry> </row>
</thead>
<tbody >
<row >
<entry > mp2</entry>
<entry > MPEG Layer 2</entry>
</row>
<row >
<entry > ac3</entry>
<entry > AC3, AKA Dolby Digital</entry>
</row>
<row >
<entry > adpcm_ima_wav</entry>
<entry > IMA adaptive PCM (4 Bit pro Sample, 4:1-Kompression)</entry>
</row>
<row >
<entry > sonic</entry>
<entry > experimenteller verlustbehafteter/verlustfreier Codec</entry>
</row>
</tbody>
</tgroup>
</informaltable>
2006-10-30 16:59:40 +00:00
Die erste Spalte enthält die Codecnamen, die nach der Konfiguration
<literal > acodec</literal> übergeben werden müssen, wie:
2006-09-27 08:59:17 +00:00
<option > -lavcopts acodec=ac3</option>
</para>
<informalexample >
<para >
Ein Beispiel mit AC3-Kompression:
<screen > mencoder dvd://2 -o title2.avi -oac lavc -lavcopts acodec=ac3 -ovc copy</screen>
</para>
</informalexample>
<para >
Im Gegensatz zu den Videocodecs von <systemitem class= "library" > libavcodec</systemitem>
2006-10-30 16:59:40 +00:00
machen dessen Audiocodecs keinen weisen Gebrauch von den Bits, die ihnen übergeben
2006-09-27 08:59:17 +00:00
werden, da es ihnen an einem minimalen psychoakustischen Modell fehlt (falls
2006-10-30 16:59:40 +00:00
überhaupt eins vorhanden ist), wodurch sich die meisten anderen
2006-09-27 08:59:17 +00:00
Codec-Implementierungen auszeichnen.
2006-10-30 16:59:40 +00:00
Beachte jedoch, dass all diese Audiocodecs sehr schnell sind und überall dort
2006-09-27 08:59:17 +00:00
hervorragend arbeiten, wo <application > MEncoder</application> mit
<systemitem class= "library" > libavcodec</systemitem> kompiliert wurde (was
2006-10-30 16:59:40 +00:00
meistens der Fall ist) und nicht von externen Programmbibliotheken abhängt.
2006-09-27 08:59:17 +00:00
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-lavc-encoding-options" >
<title > Encodieroptionen von libavcodec</title>
<para >
2006-10-30 16:59:40 +00:00
Idealerweise möchtest du eventuell in der Lage sein, dem Encoder einfach zu sagen,
2007-09-27 15:27:13 +00:00
er soll in den "hochqualitativen" Modus wechseln und weiter machen.
2006-10-30 16:59:40 +00:00
Das wäre vermutlich nett, aber unglücklicherweise schwer zu implementieren, da
verschiedene Encodieroptionen unterschiedliche Qualitätsresultate hervorbringen,
abhängig vom Quellmaterial.
Das liegt daran, dass die Komprimierung von den visuellen Eigenschaften des fraglichen Videos abhängt.
2006-09-27 08:59:17 +00:00
Zum Beispiel haben Anime und Live-Action sehr unterschiedliche Eigenschaften und
2006-10-30 16:59:40 +00:00
benötigen aus diesm Grund verschiedene Optionen, um optimale Encodierung zu erreichen.
2006-09-27 08:59:17 +00:00
Die gute Neuigkeit ist, dass einige Optionen wie <option > mbd=2</option> ,
<option > trell</option> und <option > v4mv</option> nie ausgelassen werden sollten.
Siehe unten nach der detaillierten Beschreibung allgemeiner Encodieroptionen.
</para>
<itemizedlist >
<title > Anzupassende Optionen:</title>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > vmax_b_frames</emphasis> : 1 oder 2 ist gut, abhängig vom Film.
2006-09-27 08:59:17 +00:00
Beachte, dass du, falls deine Encodierung von DivX5 decodierbar sein muss, den
2006-10-30 16:59:40 +00:00
Support für "closed GOP" aktivieren musst, indem du die
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavcodec</systemitem> -Option <option > cgop</option>
verwendest, du musst jedoch Szenenerkennung deaktivieren, was wiederum keine gute
Idee ist, da es die Ecodierungseffizienz etwas angreift.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > vb_strategy=1</emphasis> : hilft in Szenen mit viel
Bewegung (high-motion).
2006-10-30 16:59:40 +00:00
Bei manchen Videos wird vmax_b_frames der Qualität schaden, vmax_b_frames=2
2006-09-27 08:59:17 +00:00
zusammen mit vb_strategy=1 hilft jedoch.
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > dia</emphasis> : Bewegungssuchbereich. Größer ist besser
2006-09-27 08:59:17 +00:00
als kleiner.
2006-10-30 16:59:40 +00:00
Negative Werte sind ein komplett anderer Maßstab.
Gute Werte sind -1 für ein schnelle oder 2-4 für langsame Encodierung.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > predia</emphasis> : Bewegungssuche Vorabdurchlauf (pre-pass).
Nicht so wichtig wie dia. Gute Werte sind 1 (Standard) bis 4. Erfordert preme=2, um
2006-10-30 16:59:40 +00:00
wirklich was zu nützen.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > cmp, subcmp, precmp</emphasis> : Vergleichsfunktion zur
2006-10-30 16:59:40 +00:00
Bewegungseinschätzung.
2006-09-27 08:59:17 +00:00
Experimentiere mit Werten von 0 (Standard), 2 (hadamard), 3 (dct) und
6 (Ratenverzerrung).
2006-10-30 16:59:40 +00:00
0 ist am schnellsten und ausreichend für precmp.
Für cmp und subcmp ist 2 gut bei Anime, und 3 ist gut bei Live-Action.
2006-09-27 08:59:17 +00:00
6 kann leicht besser sein oder auch nicht, ist aber langsam.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > last_pred</emphasis> : Anzahl der Bewegungsvorhersagen, die
vom vorherigen Frame genommen werden sollen.
2006-10-30 16:59:40 +00:00
1-3 oder so hilft bei geringer Geschwindigkeitseinbuße.
Höhere Werte sind langsam bei keinerlei Zusatzgewinn.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > cbp, mv0</emphasis> : Kontrolliert die Auswahl von Macroblöcken.
Kleine Geschwindigkeitseinbußen bei kleinem Qualitätsgewinn.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > qprd</emphasis> : adaptive Quantisierung basierend auf der
2006-10-30 16:59:40 +00:00
Komplexität des Macroblocks.
Kann hilfreich sein oder schaden, abhängig vom Video und anderen Optionen.
2006-09-27 08:59:17 +00:00
Dies kann Artefakte verursachen, es sei denn, du setzt vqmax auf einen halbwegs
kleinen Wert (6 ist gut, vielleicht so langsam wie 4); vqmin=1 sollte ebenfalls
helfen.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > qns</emphasis> : sehr langsam, speziell wenn kombiniert
mit qprd.
Diese Option veranlasst den Encoder, durch Kompressionsartefakte entstandenes
Rauschen zu minimieren anstatt das encodierte Video strikt der Quelle anzupassen.
2006-10-30 16:59:40 +00:00
Verwende dies nicht, es sei denn du, hast bereits alles andere so weit wie möglich
2006-09-27 08:59:17 +00:00
optimiert und die Resultate sind immer noch nicht gut genug.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > vqcomp</emphasis> : Frequenzkontrolle optimieren.
2006-10-30 16:59:40 +00:00
Welche Werte gut sind, hängt vom Film ab.
2006-09-27 08:59:17 +00:00
Du kannst dies sicher so lassen wie es ist, wenn du willst.
2006-10-30 16:59:40 +00:00
Wird vqcomp verringert, werden mehr Bits auf Szenen mit geringer Komlexität
gelegt, wird es erhöht, legt es diese Bits auf Szenen mit hoher Komlexität
2006-09-27 08:59:17 +00:00
(Standard: 0.5, Bereich: 0-1. empfohlener Bereich: 0.5-0.7).
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > vlelim, vcelim</emphasis> : Setzt die Schwelle für die
2006-09-27 08:59:17 +00:00
Eliminierung einzelner Koeffizienten bei Helligkeits- und Farbanteilen.
2006-10-30 16:59:40 +00:00
Sie werden in allen MPEG-ähnlichen Algorithmen getrennt encodiert.
2006-09-27 08:59:17 +00:00
Die Idee hinter diesen Optionen ist, einige gute Heuristiken zu verwenden,
um zu bestimmen, wenn ein Wechsel innerhalb eines Blocks kleiner als der
der von dir festgelegte Schwellenwert ist und in solch einem Fall den
2007-09-27 15:27:13 +00:00
Block einfach so zu encodieren als fände "kein Wechsel" statt.
2006-10-30 16:59:40 +00:00
Das spart Bits und beschleunigt womöglich die Encodierunng. vlelim=-4 und vcelim=9
scheinen gut für Live-Filme zu sein, helfen aber scheinbar nicht bei Anime;
beim Encodieren einer Animation solltest du sie womöglich unverändert lassen.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > qpel</emphasis> : Bewegungsabschätzung auf ein viertel
2006-09-27 08:59:17 +00:00
Pixel (quarter pel).
2006-10-30 16:59:40 +00:00
MPEG-4 verwendet als Voreinstellung eine Halbpixel-Genauigkeit für die Bewegungssuche,
2006-09-27 08:59:17 +00:00
deswegen hat diese Option einen Overhead, da mehr Informationen in der
encodierte Datei untergebracht werden.
2006-10-30 16:59:40 +00:00
Der Kompressionsgewinn/-verlust hängt vom Film ab, ist aber in der Regel nicht
2006-09-27 08:59:17 +00:00
sonderlich effektiv bei Anime.
2006-10-30 16:59:40 +00:00
qpel zieht immer eine signifikante Erhöhung der CPU-Decodierzeit nach
2006-09-27 08:59:17 +00:00
sich (+25% in der Praxis).
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > psnr</emphasis> : wirkt sich eigentlich nicht auf
2006-10-30 16:59:40 +00:00
das Encodieren aus, schreibt jedoch eine Log-Datei mit Typ/Größe/Qualität
2006-09-27 08:59:17 +00:00
jedes Frames und gibt am Ende die Summe des PSNR Signal-zu-Rauschabstands
(Peak Signal to Noise Ratio) aus.
</para>
</listitem>
</itemizedlist>
<itemizedlist >
<title > Optionen, mit denen besser nicht herumgespielt werden sollte:</title>
<listitem >
<para >
<emphasis role= "bold" > vme</emphasis> : Der Standardwert ist der beste.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > lumi_mask, dark_mask</emphasis> : Psychovisuell adaptive
Quantisierung.
Du solltest nicht im Traum daran denken, mit diesen Optionen herumzuspielen,
2006-10-30 16:59:40 +00:00
wenn dir Qualität wichtig ist.
Vernünftige Werte mögen in deinem Fall effektiv sein, aber sei gewarnt,
2006-09-27 08:59:17 +00:00
dies ist sehr subjektiv.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > scplx_mask</emphasis> : Versucht, Blockartefakte
zu verhindern, Postprocessing ist aber besser.
</para>
</listitem>
</itemizedlist>
</sect2>
<sect2 id= "menc-feat-mpeg4-lavc-example-settings" >
2006-10-30 16:59:40 +00:00
<title > Beispiele für Encodierungseinstellungen</title>
2006-09-27 08:59:17 +00:00
<para >
Die folgenden Einstellungen sind Beispiele verschiedener Kombinationen
2006-10-30 16:59:40 +00:00
von Encodierungsoptionen, die den Kompromiss Geschwindigkeit gegenüber
Qualität bei gleicher Zielbitrate beeinflussen.
2006-09-27 08:59:17 +00:00
</para>
<para >
Alle Encodierungseinstellungen wurden auf einem Beispielvideo
mit 720x448 @30000/1001 fps getestet, die Zielbitrate war 900kbps und
2006-10-04 18:32:16 +00:00
der Rechner war ein AMD-64 3400+ mit 2400 MHz im 64bit-Modus.
2006-09-27 08:59:17 +00:00
Jede Encodiereinstellung zeichnet sich aus durch die gemessene
Encodiergeschwindigkeit (in Frames pro Sekunde) und den PSNR-Verlust
2007-09-27 15:27:13 +00:00
(in dB) im Vergleich zu Einstellungen für "sehr hohe Qualität".
2006-10-30 16:59:40 +00:00
Bitte habe Verständnis, dass du abhängig von deiner Quelldatei,
2006-09-27 08:59:17 +00:00
deinem Rechnertyp und Entwicklungsfortschritten sehr unterschiedliche
Resultate erzielen wirst.
</para>
<para >
<informaltable frame= "all" >
<tgroup cols= "4" >
<thead >
<row > <entry > Beschreibung</entry> <entry > Encodieroptionen</entry> <entry > Geschwindigkeit (in fps)</entry> <entry > Relativer PSNR-Verlust (in dB)</entry> </row>
</thead>
<tbody >
<row >
2006-10-30 16:59:40 +00:00
<entry > Sehr hohe Qualität</entry>
2006-09-27 08:59:17 +00:00
<entry > <option > vcodec=mpeg4:mbd=2:mv0:trell:v4mv:cbp:last_pred=3:predia=2:dia=2:vmax_b_frames=2:vb_strategy=1:precmp=2:cmp=2:subcmp=2:preme=2:qns=2</option> </entry>
<entry > 6fps</entry>
<entry > 0dB</entry>
</row>
<row >
2006-10-30 16:59:40 +00:00
<entry > Hohe Qualität</entry>
2006-09-27 08:59:17 +00:00
<entry > <option > vcodec=mpeg4:mbd=2:trell:v4mv:last_pred=2:dia=-1:vmax_b_frames=2:vb_strategy=1:cmp=3:subcmp=3:precmp=0:vqcomp=0.6:turbo</option> </entry>
<entry > 15fps</entry>
<entry > -0.5dB</entry>
</row>
<row >
<entry > Schnell</entry>
<entry > <option > vcodec=mpeg4:mbd=2:trell:v4mv:turbo</option> </entry>
<entry > 42fps</entry>
<entry > -0.74dB</entry>
</row>
<row >
<entry > Echtzeit</entry>
<entry > <option > vcodec=mpeg4:mbd=2:turbo</option> </entry>
<entry > 54fps</entry>
<entry > -1.21dB</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</sect2>
2006-10-30 16:59:40 +00:00
<sect2 id= "custommatrices" > <title > Maßgeschneiderte inter/intra-Matrizen</title>
2006-09-27 08:59:17 +00:00
<para >
Mit diesem Feature von <link linkend= "ffmpeg" > <systemitem class= "library" > libavcodec</systemitem> </link>
bist du in der Lage, eigene inter- (I-Frames/Keyframes) und intra-Matrizen
2006-10-30 16:59:40 +00:00
(P-Frames/predicted Frames) zu setzen. Es wird von vielen Codecs unterstützt:
2006-09-27 08:59:17 +00:00
<systemitem > mpeg1video</systemitem> und <systemitem > mpeg2video</systemitem>
sollen damit funktionieren.
</para>
<para >
Eine typische Anwendung dieses Features ist, die von den
<ulink url= "http://www.kvcd.net/" > KVCD</ulink> -Specifikationen
bevorzugten Matrizen zu setzen.
</para>
<para >
2007-09-27 15:27:13 +00:00
Die <emphasis role= "bold" > KVCD "Notch" Quantisierungsmatrix:</emphasis>
2006-09-27 08:59:17 +00:00
</para>
<para >
Intra:
<screen > 8 9 12 22 26 27 29 34
9 10 14 26 27 29 34 37
2006-06-05 05:02:47 +00:00
12 14 18 27 29 34 37 38
22 26 27 31 36 37 38 40
26 27 29 36 39 38 40 48
27 29 34 37 38 40 48 58
29 34 37 38 40 48 58 69
2006-09-27 08:59:17 +00:00
34 37 38 40 48 58 69 79</screen>
2006-06-05 05:02:47 +00:00
2006-09-27 08:59:17 +00:00
Inter:
<screen > 16 18 20 22 24 26 28 30
2006-06-05 05:02:47 +00:00
18 20 22 24 26 28 30 32
20 22 24 26 28 30 32 34
22 24 26 30 32 32 34 36
24 26 28 32 34 34 36 38
26 28 30 32 34 36 38 40
28 30 32 34 36 38 42 42
2006-09-27 08:59:17 +00:00
30 32 34 36 38 40 42 44</screen>
</para>
<para >
Anwendung:
<screen > $ mencoder <replaceable > input.avi</replaceable> -o <replaceable > output.avi</replaceable> -oac copy -ovc lavc -lavcopts inter_matrix=...:intra_matrix=... </screen>
</para>
<para >
<screen > $ mencoder <replaceable > input.avi</replaceable> -ovc lavc -lavcopts
2006-06-05 05:02:47 +00:00
vcodec=mpeg2video:intra_matrix=8,9,12,22,26,27,29,34,9,10,14,26,27,29,34,37,
12,14,18,27,29,34,37,38,22,26,27,31,36,37,38,40,26,27,29,36,39,38,40,48,27,
29,34,37,38,40,48,58,29,34,37,38,40,48,58,69,34,37,38,40,48,58,69,79
:inter_matrix=16,18,20,22,24,26,28,30,18,20,22,24,26,28,30,32,20,22,24,26,
28,30,32,34,22,24,26,30,32,32,34,36,24,26,28,32,34,34,36,38,26,28,30,32,34,
2006-09-27 08:59:17 +00:00
36,38,40,28,30,32,34,36,38,42,42,30,32,34,36,38,40,42,44 -oac copy -o svcd.mpg</screen>
</para>
</sect2>
<sect2 id= "menc-feat-dvd-mpeg4-example" >
<title > Beispiel</title>
<para >
Jetzt hast du gerade eben deine brandneue Kopie von Harry Potter und die
2006-10-30 16:59:40 +00:00
Kammer des Schreckens gekauft (natürlich die Breitbildedition), und du
willst diese DVD so rippen, dass du sie deinem Home Theatre PC hinzufügen
2006-09-27 08:59:17 +00:00
kannst. Dies ist eine Region-1-DVD, also ist sie NTSC. Das unten stehende
Beispiel wird auch auf PAL zutreffen, nur dass du
2006-10-30 16:59:40 +00:00
<option > -ofps 24000/1001</option> weglässt (weil die Ausgabeframerate die
2006-09-27 08:59:17 +00:00
gleiche ist wie die Eingabeframerate), und logischerweise werden die
Ausschnittsabmessungen anders sein.
</para>
<para >
Nach dem Start von <option > mplayer dvd://1</option> , verfolgen wir den
detailliert in der Sektion <link linkend= "menc-feat-telecine" > Wie mit telecine
und interlacing in NTSC-DVDs umgehen</link> beschriebenen Prozess und
entdecken, dass es progressive Video mit 24000/1001 fps ist, was bedeutet, dass
wir keinen inverse telecine-Filter wie <option > pullup</option> oder
2006-10-30 16:59:40 +00:00
<option > filmdint</option> anwenden müssen.
2006-09-27 08:59:17 +00:00
</para>
2007-09-27 21:22:26 +00:00
<para id= "menc-feat-dvd-mpeg4-example-crop" >
2006-10-30 16:59:40 +00:00
Als Nächstes wollen wir das passende Ausschnittsrechteck bestimmen, also
2007-09-27 21:22:26 +00:00
verwenden wir den cropdetect-Filter:
2006-09-27 08:59:17 +00:00
<screen > mplayer dvd://1 -vf cropdetect</screen>
2006-10-30 16:59:40 +00:00
Stelle sicher, dass du einen voll gefüllten Frame anstrebst (wie zum
2007-09-27 21:22:26 +00:00
Beispiel eine helle Szene, nach den Eröffnungs-Credits und Filmlogos),
und dass du diese Ausgabe in <application > MPlayer</application> s Konsole siehst:
2006-09-27 08:59:17 +00:00
<screen > crop area: X: 0..719 Y: 57..419 (-vf crop=720:362:0:58)</screen>
Wir spielen den Film dann mit diesem Filter ab, um seine Korrektheit zu testen:
<screen > mplayer dvd://1 -vf crop=720:362:0:58</screen>
2006-10-30 16:59:40 +00:00
Und wir sehen, dass er einfach perfekt aussieht. Als Nächstes vergewissern wir
uns, dass Breite und Höhe ein Vielfaches von 16 sind. Die Breite ist gut,
aber die Höhe ist es nicht. Da wir in der 7-ten Klasse in Mathe nicht gefehlt
haben, wissen wir, dass das am nähesten liegende Vielfache von 16 kleiner
2006-09-27 08:59:17 +00:00
als 362 der Wert 352 ist (Taschenrechner ist erlaubt).
</para>
<para >
2006-10-30 16:59:40 +00:00
Wir könnten einfach <option > crop=720:352:0:58</option> verwenden, aber es wäre
2006-09-27 08:59:17 +00:00
nett, ein bisschen von oben und ein bisschen von unten wegzunehmen, sodass
2006-10-30 16:59:40 +00:00
wir zentriert bleiben. Wir haben die Höhe um 10 Pixel schrumpfen lassen, aber
wir wollen das y-Offset nicht um 5 Pixel erhöhen, da dies eine ungerade Zahl
ist und die Qualität nachteilig beeinflussen würde. Statt dessen werden wir
das y-Offset um 4 Pixel erhöhen:
2006-09-27 08:59:17 +00:00
<screen > mplayer dvd://1 -vf crop=720:352:0:62</screen>
Ein anderer Grund, Pixel von beidem - oben und unten - abzuschnipseln ist,
dass wir sicher gehen wollen, jegliches halbschwarze Pixel eliminiert zu
haben, falls welche existieren. Beachte, falls das Video telecined
2006-10-30 16:59:40 +00:00
ist, stelle sicher, dass der <option > pullup</option> -Filter (oder für
2006-09-27 08:59:17 +00:00
welchen umgekehrten telecine-Filter auch immer du dich entschieden hast)
in der Filterkette auftaucht, bevor du zuschneidest. Ist es interlaced,
deinterlace es vor dem Zuschneiden.
(Wenn du dich entscheidest, interlaced Video beizubehalten, dann vergewissere dich, dass
das vertikale crop-Offset ein Vielfaches von 4 ist.)
</para>
<para >
Wenn du wirklich besorgt um den Verlust dieser 10 Pixel bist, ziehst du
2006-10-30 16:59:40 +00:00
statt dessen etwa das Herunterskalieren der Abmessungen auf das am nächsten
2006-09-27 08:59:17 +00:00
liegende Vielfache von 16 vor.
2006-10-30 16:59:40 +00:00
Die Filterkette würde dann etwa so aussehen:
2006-09-27 08:59:17 +00:00
<screen > -vf crop=720:362:0:58,scale=720:352</screen>
Das Video auf diese Art herunter zu skalieren wird bedeuten, dass eine
kleine Menge Details verloren geht, obwohl es vermutlich nicht wahrnehmbar
2006-10-30 16:59:40 +00:00
sein wird. Hoch zu skalieren führt zu niedrigerer Qualität (es sei denn,
du erhöhst die Bitrate). Ausschneiden sondert sämtliche dieser Pixel
aus. Es ist ein Kompromiss, den du unter allen Umständen
in Betracht ziehen solltest. Zum Beispiel, wenn das DVD-Video für das Fernsehen
2006-09-27 08:59:17 +00:00
hergestellt wurde, solltest du vertikales Skalieren vermeiden, da das
2006-10-30 16:59:40 +00:00
Zeilensampling mit der Art und Weise korrespondiert, für die der Inhalt
ursprünglich aufgenommen wurde.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Bei der Überprüfung sehen wir, dass unser Film ordentlich Action enthält
und sehr viele Details, also wählen wir 2400Kbit für unsere Bitrate.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Wir sind nun bereit, die 2-pass Encodierung durchzuführen. Erster Durchlauf:
2006-09-27 08:59:17 +00:00
<screen > mencoder dvd://1 -ofps 24000/1001 -oac copy -vf pullup,softskip,crop=720:352:0:62,hqdn3d=2:1:2 -ovc lavc \
-lavcopts vcodec=mpeg4:vbitrate=2400:v4mv:mbd=2:trell:cmp=3:subcmp=3:mbcmp=3:autoaspect:vpass=1 \
-o Harry_Potter_2.avi</screen>
2006-10-30 16:59:40 +00:00
Und der zweite Durchlauf ist derselbe, außer dass wir <option > vpass=2</option>
2006-09-27 08:59:17 +00:00
festlegen:
<screen > mencoder dvd://1 -ofps 24000/1001 -oac copy -vf pullup,softskip,crop=720:352:0:62,hqdn3d=2:1:2 -ovc lavc \
-lavcopts vcodec=mpeg4:vbitrate=2400:v4mv:mbd=2:trell:cmp=3:subcmp=3:mbcmp=3:autoaspect:vpass=2 \
-o Harry_Potter_2.avi</screen>
</para>
<para >
2006-10-30 16:59:40 +00:00
Die Optionen <option > v4mv:mbd=2:trell</option> werden die Qualität
außerordentlich erhöhen, auf Kosten der Encodierdauer. Es gibt
einen kleinen Grund, diese Optionen auszulassen, wenn das Primärziel
die Qualität ist. Die Optionen
<option > cmp=3:subcmp=3:mbcmp=3</option> wählen eine Vergleichsfunktion,
die eine höhere Qualität liefert als die Standardeinstellungen.
2006-09-27 08:59:17 +00:00
Du darfst mit diesem Parameter rumexperimentieren (ziehe die Manpage
2006-10-30 16:59:40 +00:00
zu möglichen Werten zu Rate) da verschiedene Funktionen abhängig vom
Quellmaterial einen starken Einfluss auf die Qualität haben. Wenn du zum Beispiel
2006-09-27 08:59:17 +00:00
meinst, dass <systemitem class= "library" > libavcodec</systemitem> zu
2006-10-30 16:59:40 +00:00
viele Blockartefakte produziert, könntest du ja das experimentelle
NSSE als Vergleichsfunktion via <option > *cmp=10</option> wählen.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Für diesen Film wird das resultierende AVI 138 Minuten lang und nahezu
3GB groß sein. Und weil du erzählt hast, dass eine große Datei nichts
ausmacht, ist dies eine perfekt akzeptierbare Größe. Wolltest du sie aber
kleiner haben, könntest du eine niedrigere Bitrate hernehmen. Erhöhte
Bitraten haben verminderte Rückgaben, während wir also deutlich eine
2006-09-27 08:59:17 +00:00
Verbesserung von 1800Kbit nach 2000Kbit sehen, ist es oberhalb 2000Kbit
2006-10-30 16:59:40 +00:00
nicht so auffällig. Fühl dich frei solange herum zu experimentieren bis
du glücklich bist.
2006-09-27 08:59:17 +00:00
</para>
<para >
Weil wir das Quellvideo durch einen Denoise-Filter geschickt haben,
2006-10-30 16:59:40 +00:00
könntest du einige davon während des Playbacks wieder hinzufügen wollen.
2006-09-27 08:59:17 +00:00
Dies zusammen mit dem Nachbearbeitungsfilter <option > spp</option>
2006-10-30 16:59:40 +00:00
verbessert die Wahrnehmung der Qualität drastisch und hilft dabei,
2006-09-27 08:59:17 +00:00
blockhafte Artefakte aus dem Video zu eliminieren.
Mit <application > MPlayer</application> s Option <option > autoq</option>
2006-10-30 16:59:40 +00:00
kannst du den Nachbearbeitungsaufwand des spp-Filters abhängig von der
verfügbaren CPU variieren. An dieser Stelle kannst du auch Gamma- und/oder
2006-09-27 08:59:17 +00:00
Farbkorrektur zur besten Anpassung an dein Display verwenden, wenn du willst.
Zum Beispiel:
<screen > mplayer Harry_Potter_2.avi -vf spp,noise=9ah:5ah,eq2=1.2 -autoq 3</screen>
</para>
</sect2>
</sect1>
<sect1 id= "menc-feat-xvid" >
2006-11-13 09:48:00 +00:00
<title > Encodieren mit dem <systemitem class= "library" > Xvid</systemitem> -Codec</title>
2006-09-27 08:59:17 +00:00
<para >
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem> ist eine freie
2006-09-27 08:59:17 +00:00
Programmbibliothek zum Encodieren von MPEG-4 ASP-Videostreams.
Bevor du mit <link linkend= "xvid" > zu encodieren beginnst, musst du
2006-10-30 16:59:40 +00:00
<application > MEncoder</application> so einstellen, dass er es unterstützt</link> .
2006-09-27 08:59:17 +00:00
</para>
<para >
Dieses Handbuch beabsichtigt, sich vorwiegend durch dieselbe Art von
Informationen auszuzeichnen wie x264's Encodier-Handbuch.
Beginne deshalb damit,
<link linkend= "menc-feat-x264-encoding-options-intro" > den ersten Teil</link>
dieses Handbuchs zu lesen.
</para>
<sect2 id= "menc-feat-xvid-intro" >
<title > Welche Optionen sollte ich verwenden, um die besten Resultate zu erzielen?</title>
<para >
Bitte beginne mit der Durchsicht der
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem> -Sektion von
2006-09-27 08:59:17 +00:00
<application > MPlayer</application> s Manpage.
2006-10-30 16:59:40 +00:00
Diese Sektion ist als Ergänzung zur Manpage zu verstehen.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-11-13 09:48:00 +00:00
Die Standardeinstellungen von Xvid sind bereits ein guter Kompromiss zwischen
2006-10-30 16:59:40 +00:00
Geschwindigkeit und Qualität, deshalb kannst du ruhig bei ihnen
bleiben, wenn nachfolgender Abschnitt dich allzusehr ins Grübeln bringt.
2006-09-27 08:59:17 +00:00
</para>
</sect2>
<sect2 id= "menc-feat-xvid-encoding-options" >
2006-11-13 09:48:00 +00:00
<title > Encodieroptionen von <systemitem class= "library" > Xvid</systemitem> </title>
2006-09-27 08:59:17 +00:00
<itemizedlist >
<listitem >
<para >
<emphasis role= "bold" > vhq</emphasis>
2006-10-30 16:59:40 +00:00
Diese Einstellung betreffen den Entscheidungsalgorithmus für
Macroblöcke, wobei gilt, je höher die Einstellung desto weiser die
2006-09-27 08:59:17 +00:00
Entscheidung.
2006-10-30 16:59:40 +00:00
Die Standardeinstellung kann für jede Encodierung sicher verwendet
werden, während höhere Einstellungen immer für PSNR hilfreich, jedoch
2006-09-27 08:59:17 +00:00
signifikant langsamer sind.
Nimm bitte zur Kenntnis, dass ein besserer PSNR nicht notwedigerweise
bedeutet, dass das Bild besser aussehen wird, aber er zeigt dir, dass
2006-10-30 16:59:40 +00:00
du näher am Original bist.
Wird er deaktiviert, beschleunigt dies die Encodierung spürbar; wenn
Geschwindigkeit ein Kriterium für dich ist, kann dieser Kompromiss es wert sein.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > bvhq</emphasis>
Dies erledigt dieselbe Arbeit wie vhq, macht dies jedoch bei B-Frames.
2006-10-30 16:59:40 +00:00
Es hat einen vernachlässigbar kleinen Einfluss auf die Geschwindigkeit, und
verbessert geringfügig die Qualität (um etwa +0.1dB PSNR).
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > max_bframes</emphasis>
2006-10-30 16:59:40 +00:00
Eine höhere Anzahl von erlaubten hintereinander folgenden B-frames verbessert
gewöhnlich die Komprimierbarkeit, obwohl dies auch zu mehr Blockartefakten
führt.
2006-09-27 08:59:17 +00:00
Die Standardeinstellung ist ein guter Kompromiss zwischen Komprimierbarkeit
2006-10-30 16:59:40 +00:00
und Qualität, aber wenn du Bitraten-hungrig bist kannst du sie bis auf 3
2006-09-27 08:59:17 +00:00
hochschrauben.
2006-10-30 16:59:40 +00:00
Du kannst sie auch auf 1 oder 0 verringern, wenn du auf perfekte Qualität
2006-09-27 08:59:17 +00:00
abzielst, wenngleich du in diesem Fall sicherstellen solltest, dass deine
2006-10-30 16:59:40 +00:00
Zielbitrate hoch genug ist, um zu gewährleisten, dass der Encoder nicht
die Quantisierer höher setzen muss, um den Wert zu erreichen.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > bf_threshold</emphasis>
Dies kontrolliert die B-Frame-Empfindlichkeit des Encoders, wobei ein
2006-10-30 16:59:40 +00:00
höherer Wert dazu führt, dass mehr B-Frames angewendet werden (und
2006-09-27 08:59:17 +00:00
umgekehrt).
Diese Einstellung muss zusammen mit <option > max_bframes</option>
2006-10-30 16:59:40 +00:00
verwendet werden; bist du Bitraten-hungrig, solltest du beides erhöhen,
2006-09-27 08:59:17 +00:00
<option > max_bframes</option> und <option > bf_threshold</option> ,
2006-10-30 16:59:40 +00:00
während du <option > max_bframes</option> erhöhen und
2006-09-27 08:59:17 +00:00
<option > bf_threshold</option> verringern kannst, sodass der Encoder
B-Frames nur an Stellen anwendet, die diese auch
<emphasis role= "bold" > wirklich</emphasis> brauchen.
2006-10-30 16:59:40 +00:00
Eine niedrigere Zahl an <option > max_bframes</option> und ein höherer Wert
bei <option > bf_threshold</option> ist möglicherweise keine kluge Wahl,
2006-09-27 08:59:17 +00:00
da dies den Encoder zwingt, B-Frames in Stellen zu setzen, die nicht
2006-10-30 16:59:40 +00:00
davon profitieren würden und dies daher die visuelle Qualität reduziert.
2006-09-27 08:59:17 +00:00
Wie auch immer, wenn du mit Standalone-Playern kompatibel bleiben musst,
2006-10-30 16:59:40 +00:00
die nur alte DivX-Profile unterstützen (der wiederum höchstens einen
aufeinander folgenden B-Frame unterstützt), wäre dies dein einziger Weg,
2006-09-27 08:59:17 +00:00
die Komprimierbarkeit mittels B-Frames zu verbessern.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > trellis</emphasis>
Optimiert den Quantisierungsprozess um einen optimalen Kompromiss
zwischen PSNR und Bitrate zu erhalten, was signifikant Bit-sparend
wirkt.
2006-10-30 16:59:40 +00:00
Diese Bits können woanders im Video wieder verwendet werden
und verbessern die visuelle Gesamtqualität.
2006-09-27 08:59:17 +00:00
Du solltest es immer eingeschaltet lassen, da sein Einfluss auf
2006-10-30 16:59:40 +00:00
die Qualität gewaltig ist.
2006-09-27 08:59:17 +00:00
Gerade wenn du Geschwindigkeit haben willst, darfst du es nicht
deaktivieren, solange du nicht <option > vhq</option>
und alle anderen CPU-hungrigeren Optionen auf
ein Minimum heruntergesetzt hast.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > hq_ac</emphasis>
2006-10-30 16:59:40 +00:00
Aktiviert die Vorhersagemethode für einen besseren Koeffizientenaufwand, was
die Dateigröße leicht um etwa 0.15 bis 0.19% reduziert (was mit einer
PSNR-Erhöhung um weniger als 0.01dB einhergeht), während es eine
vernachlässigbar kleine Einwirkung auf die Geschwindigkeit hat.
2006-09-27 08:59:17 +00:00
Es empfiehlt sich deshalb, dies immer eingeschaltet zu lassen.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > cartoon</emphasis>
Entworfen, um Kartoon-Inhalt besser zu encodieren, und hat keine Auswirkung
auf die Geschwindigkeit, da es lediglich die Heuristiken zur Bestimmung des
2006-10-30 16:59:40 +00:00
Modus für diese Art Inhalt abstimmt.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > me_quality</emphasis>
2006-10-30 16:59:40 +00:00
Diese Einstellung ist da, um die Präzision der Bewegungseinschätzung zu
2006-09-27 08:59:17 +00:00
kontrollieren.
2006-10-30 16:59:40 +00:00
Je höher <option > me_quality</option> , desto präziser wird die Schätzung
2006-09-27 08:59:17 +00:00
der Originalbewegung sein, und desto besser wird der resultierende Ausschnitt
die Originalbewegung einfangen.
</para>
<para >
Die Standardeinstellung ist in jedem Fall die beste;
folglich ist es nicht empfehlenswert, sie herunter zu drehen,
es sei denn du hast es wirklich auf Geschwindigkeit abgesehen,
2006-10-30 16:59:40 +00:00
da alle durch eine gute Bewegungseinschätzung gesparten Bits
woanders verwendet würden, was die Gesamtqualität verbessern
würde.
2006-09-27 08:59:17 +00:00
Gehe deshalb nie unter 5, selbst wenn es der letzte Ausweg
sein sollte.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > chroma_me</emphasis>
2006-10-30 16:59:40 +00:00
Verbessert die Bewegungsabschätzung dadurch, dass auch die
2006-09-27 08:59:17 +00:00
chroma-(Farb)-Informationen einbezogen werden, wobei
<option > me_quality</option> alleine nur luma (Graustufen)
verwendet.
Dies verlangsamt die Encodierung um 5-10%, verbessert aber die
2006-10-30 16:59:40 +00:00
visuelle Qualität durch Reduzieren von Blockeffekten ein wenig
und reduziert die Dateigröße um rund 1.3%.
2006-09-27 08:59:17 +00:00
Wenn du Geschwindigkeit haben willst, solltest du diese Option
2006-10-30 16:59:40 +00:00
deaktivieren, bevor du anfängst zu überlegen,
2006-09-27 08:59:17 +00:00
<option > me_quality</option> zu reduzieren.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > chroma_opt</emphasis>
2006-10-30 16:59:40 +00:00
Ist dafür vorgesehen, die chroma-Bildqualität rund um reine
weiße/schwarze Kanten zu verbessern, eher noch als die
2006-09-27 08:59:17 +00:00
Kompression zu verbessern.
2007-09-27 15:27:13 +00:00
Dies kann dabei helfen, den "Rote Stufen"-Effekt zu reduzieren.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > lumi_mask</emphasis>
2006-10-30 16:59:40 +00:00
Versucht, weniger Bitrate auf den Teil eines Bildes zu übergeben,
2006-09-27 08:59:17 +00:00
der vom menschlichen Auge nicht gut zu sehen ist, was dem Encoder
erlauben sollte, die eingesparten Bits auf wichtigere Teile des
Bildes anzuwenden.
2006-10-30 16:59:40 +00:00
Die durch diese Option gewonnene Encodierungsqualität hängt in
hohem Maße von persönlichen Vorlieben und von Monitortyp und
2006-09-27 08:59:17 +00:00
dessen Einstellungen ab (typischerweise wird es nicht gut aussehen,
wenn er hell oder ein TFT-Monitor ist).
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > qpel</emphasis>
Hebt die Anzahl Kandidaten der Bewegungsvektoren durch
2006-10-30 16:59:40 +00:00
Erhöhung der Präzision der Bewegungsabschätzung von einem
2006-09-27 08:59:17 +00:00
halben Pixel (halfpel) auf ein viertel Pixel
(quarterpel) an.
Die Idee dahinter ist, bessere Bewegungsvektoren zu finden,
2006-10-30 16:59:40 +00:00
was wiederum die Bitrate reduziert (deshalb wird die Qualität
2006-09-27 08:59:17 +00:00
verbessert).
2006-10-30 16:59:40 +00:00
Bewegungsvektoren mit viertel Pixel Präzision brauchen ein
paar Extrabits für die Codierung, die Bewegungsvektoren ergeben aber
2006-09-27 08:59:17 +00:00
nicht immer ein (viel) besseres Resultat.
2006-10-30 16:59:40 +00:00
Sehr oft verbraucht der Codec dennoch Bits für die Extrapräzision,
jedoch wird im Gegenzug eine geringe oder keine Extraqualität
2006-09-27 08:59:17 +00:00
gewonnen.
2006-10-30 16:59:40 +00:00
Unglücklicherweise gibt es keinen Weg, den möglichen Gewinn von
2006-09-27 08:59:17 +00:00
<option > qpel</option> vorzuaussagen, also musst du eigentlich
mit und ohne encodieren, um sicher zu gehen.
</para>
<para >
<option > qpel</option> kann fast die doppelte Encodierzeit in
Anspruch nehmen und erfordert etwa 25% mehr
2006-10-30 16:59:40 +00:00
Verarbeitungsleistung fürs Decodieren.
Es wird nicht von allen Standalone-Playern unterstützt.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > gmc</emphasis>
Versucht, Bits beim Schwenken von Szenen einzusparen, indem es einen
2006-10-30 16:59:40 +00:00
einzelnen Bewegungsvektor für den gesamten Frame verwendet.
Dies erhöht fast immer den PSNR, verlangsamt aber signifikant
2006-09-27 08:59:17 +00:00
die Encodierung (genauso wie die Decodierung).
Deshalb solltest du es nur nutzen, wenn du <option > vhq</option>
auf das Maximum gestellt hast.
2006-11-13 09:48:00 +00:00
<systemitem class= "library" > Xvid</systemitem> s GMC ist höher
2006-09-27 08:59:17 +00:00
entwickelt als das von DivX, wird aber nur von ein paar
2006-10-30 16:59:40 +00:00
Standalone-Playern unterstützt.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</itemizedlist>
</sect2>
<sect2 id= "menc-feat-xvid-encoding-profiles" >
<title > Encodierung Profile</title>
<para >
2006-11-13 09:48:00 +00:00
Xvid unterstützt Encodierungsprofile über die Option <option > profile</option> ,
die dazu verwendet werden, den Eigenschaften des Xvid-Videostreams
2006-10-30 16:59:40 +00:00
Restriktionen so aufzuerlegen, dass es überall dort abgespielt werden kann,
wo das gewählte Profil unterstützt wird.
Die Restriktionen beziehen sich auf Auflösungen, Bitraten und
2006-09-27 08:59:17 +00:00
bestimmte MPEG-4-Features.
2006-10-30 16:59:40 +00:00
Die folgende Tabelle zeigt, was jedes Profil unterstützt.
2006-09-27 08:59:17 +00:00
</para>
<informaltable >
<tgroup cols= "16" align= "center" >
<colspec colnum= "1" colname= "col1" />
<colspec colnum= "2" colname= "col2" />
<colspec colnum= "3" colname= "col3" />
<colspec colnum= "4" colname= "col4" />
<colspec colnum= "5" colname= "col5" />
<colspec colnum= "6" colname= "col6" />
<colspec colnum= "7" colname= "col7" />
<colspec colnum= "8" colname= "col8" />
<colspec colnum= "9" colname= "col9" />
<colspec colnum= "10" colname= "col10" />
<colspec colnum= "11" colname= "col11" />
<colspec colnum= "12" colname= "col12" />
<colspec colnum= "13" colname= "col13" />
<colspec colnum= "14" colname= "col14" />
<colspec colnum= "15" colname= "col15" />
<colspec colnum= "16" colname= "col16" />
<colspec colnum= "17" colname= "col17" />
<spanspec spanname= "spa2-5" namest= "col2" nameend= "col5" />
<spanspec spanname= "spa6-11" namest= "col6" nameend= "col11" />
<spanspec spanname= "spa12-17" namest= "col12" nameend= "col17" />
<tbody >
<row >
<entry > </entry>
<entry spanname= "spa2-5" > Einfach</entry>
<entry spanname= "spa6-11" > Einfach erweitert</entry>
<entry spanname= "spa12-17" > DivX</entry>
</row>
<row >
<entry > Profilname</entry>
<entry > 0</entry>
<entry > 1</entry>
<entry > 2</entry>
<entry > 3</entry>
<entry > 0</entry>
<entry > 1</entry>
<entry > 2</entry>
<entry > 3</entry>
<entry > 4</entry>
<entry > 5</entry>
<entry > Handheld</entry>
<entry > Portable NTSC</entry>
<entry > Portable PAL</entry>
<entry > Home Theater NTSC</entry>
<entry > Home Theater PAL</entry>
<entry > HDTV</entry>
</row>
<row >
<entry > Breite [Pixel]</entry>
<entry > 176</entry>
<entry > 176</entry>
<entry > 352</entry>
<entry > 352</entry>
<entry > 176</entry>
<entry > 176</entry>
<entry > 352</entry>
<entry > 352</entry>
<entry > 352</entry>
<entry > 720</entry>
<entry > 176</entry>
<entry > 352</entry>
<entry > 352</entry>
<entry > 720</entry>
<entry > 720</entry>
<entry > 1280</entry>
</row>
<row >
2006-10-30 16:59:40 +00:00
<entry > Höhe [Pixel]</entry>
2006-09-27 08:59:17 +00:00
<entry > 144</entry>
<entry > 144</entry>
<entry > 288</entry>
<entry > 288</entry>
<entry > 144</entry>
<entry > 144</entry>
<entry > 288</entry>
<entry > 288</entry>
<entry > 576</entry>
<entry > 576</entry>
<entry > 144</entry>
<entry > 240</entry>
<entry > 288</entry>
<entry > 480</entry>
<entry > 576</entry>
<entry > 720</entry>
</row>
<row >
<entry > Framerate [fps]</entry>
<entry > 15</entry>
<entry > 15</entry>
<entry > 15</entry>
<entry > 15</entry>
<entry > 30</entry>
<entry > 30</entry>
<entry > 15</entry>
<entry > 30</entry>
<entry > 30</entry>
<entry > 30</entry>
<entry > 15</entry>
<entry > 30</entry>
<entry > 25</entry>
<entry > 30</entry>
<entry > 25</entry>
<entry > 30</entry>
</row>
<row >
<entry > Max. mittlere Bitrate [kbps]</entry>
<entry > 64</entry>
<entry > 64</entry>
<entry > 128</entry>
<entry > 384</entry>
<entry > 128</entry>
<entry > 128</entry>
<entry > 384</entry>
<entry > 768</entry>
<entry > 3000</entry>
<entry > 8000</entry>
<entry > 537.6</entry>
<entry > 4854</entry>
<entry > 4854</entry>
<entry > 4854</entry>
<entry > 4854</entry>
<entry > 9708.4</entry>
</row>
<row >
2006-10-30 16:59:40 +00:00
<entry > Höchstwert mittlere Bitrate über 3 Sek. [kbps]</entry>
2006-09-27 08:59:17 +00:00
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > 800</entry>
<entry > 8000</entry>
<entry > 8000</entry>
<entry > 8000</entry>
<entry > 8000</entry>
<entry > 16000</entry>
</row>
<row >
<entry > Max. B-Frames</entry>
<entry > 0</entry>
<entry > 0</entry>
<entry > 0</entry>
<entry > 0</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > 0</entry>
<entry > 1</entry>
<entry > 1</entry>
<entry > 1</entry>
<entry > 1</entry>
<entry > 2</entry>
</row>
<row >
<entry > MPEG-Quantisierung</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry > Adaptive Quantisierung</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
</row>
<row >
<entry > Interlaced Encodierung</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
</row>
<row >
<entry > Viertelpixel</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
<row >
<entry > Globale Bewegungskompensierung</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > X</entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
<entry > </entry>
</row>
</tbody>
</tgroup>
</informaltable>
</sect2>
<sect2 id= "menc-feat-xvid-example-settings" >
<title > Encodierungseinstellungen Beispiele</title>
<para >
Die folgenden Einstellungen sind Beispiele unterschiedlicher
Kombinationen von Encodierungsoptionen, die den Kompromiss
2006-10-30 16:59:40 +00:00
zwischen Geschwindigkeit gegenüber Qualität bei gleicher
2006-09-27 08:59:17 +00:00
Zielbitrate betreffen.
</para>
<para >
Alle Encodierungseinstellungen wurden auf einem Beispielvideo
mit 720x448 @30000/1001 fps getestet, die Zielbitrate war 900kbps,
und der Rechner war ein
2006-10-04 18:32:16 +00:00
AMD-64 3400+ mit 2400 MHz im 64bit-Modus.
2006-09-27 08:59:17 +00:00
Jede Encodierungseinstellung zeichnet sich aus durch die gemessene
Encodiergeschwindigkeit (in Frames pro Sekunde) und den PSNR-Verlust
2007-09-27 15:27:13 +00:00
(in dB) im Vergleich zu Einstellungen für "sehr hohe Qualität".
2006-10-30 16:59:40 +00:00
Bitte hab Verständnis, dass du abhängig von deiner Quelldatei,
2006-09-27 08:59:17 +00:00
deinem Rechnertyp und Entwicklungsfortschritten sehr unterschiedliche
Resultate erzielen wirst.
</para>
<para >
<informaltable frame= "all" >
<tgroup cols= "4" >
<thead >
<row > <entry > Beschreibung</entry> <entry > Encodieroptionen</entry> <entry > Geschwindigkeit (in fps)</entry> <entry > Relativer PSNR-Verlust (in dB)</entry> </row>
</thead>
<tbody >
<row >
2006-10-30 16:59:40 +00:00
<entry > Sehr hohe Qualität</entry>
2006-09-27 08:59:17 +00:00
<entry > <option > chroma_opt:vhq=4:bvhq=1:quant_type=mpeg</option> </entry>
<entry > 16fps</entry>
<entry > 0dB</entry>
</row>
<row >
2006-10-30 16:59:40 +00:00
<entry > Hohe Qualität</entry>
2006-09-27 08:59:17 +00:00
<entry > <option > vhq=2:bvhq=1:chroma_opt:quant_type=mpeg</option> </entry>
<entry > 18fps</entry>
<entry > -0.1dB</entry>
</row>
<row >
<entry > Schnell</entry>
<entry > <option > turbo:vhq=0</option> </entry>
<entry > 28fps</entry>
<entry > -0.69dB</entry>
</row>
<row >
<entry > Echtzeit</entry>
<entry > <option > turbo:nochroma_me:notrellis:max_bframes=0:vhq=0</option> </entry>
<entry > 38fps</entry>
<entry > -1.48dB</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</sect2>
</sect1>
<sect1 id= "menc-feat-x264" >
<title > Encodieren mit dem <systemitem class= "library" > x264</systemitem> -Codec</title>
<para >
<systemitem class= "library" > x264</systemitem> ist eine freie
Programmbibliothek zum Encodieren von H.264/AVC-Videostreams.
Bevor du mit <link linkend= "xvid" > zu encodieren beginnst, musst
2006-10-30 16:59:40 +00:00
du <application > MEncoder</application> so einstellen, dass er es unterstützt</link> .
2006-09-27 08:59:17 +00:00
</para>
<sect2 id= "menc-feat-x264-encoding-options" >
<title > Encodieroptionen von x264</title>
<para >
Bitte beginne mit der Durchsicht der
<systemitem class= "library" > x264</systemitem> -Sektion von
<application > MPlayer</application> s Manpage.
Diese Sektion ist als Anhang zur Manpage vorgesehen.
Hier wirst du Schnellhinweise dazu finden, welche Optionen am
wahrscheinlichsten die meisten Leute interessieren. Die Manpage
2006-10-30 16:59:40 +00:00
ist knapper gehalten, aber auch vollständiger, und zeigt oft
2006-09-27 08:59:17 +00:00
viel bessere technische Details.
</para>
<sect3 id= "menc-feat-x264-encoding-options-intro" >
2006-10-30 16:59:40 +00:00
<title > Einführung</title>
<para > Dieses Handbuch berücksichtigt zwei Hauptkategorien der Encodieroptionen:</para>
2006-09-27 08:59:17 +00:00
<orderedlist >
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Optionen, die hauptsächlich Encodierdauer gegenüber Qualität abwägen
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
Optionen, die zur Erfüllung zahlreicher persönlicher Vorlieben und spezieller Anforderungen nützlich sind
2006-09-27 08:59:17 +00:00
</para>
</listitem>
</orderedlist>
<para >
2006-10-30 16:59:40 +00:00
Letztendlich kannst nur du entscheiden, welche Optionen für deine
Zwecke am besten geeignet sind. Die Entscheidung für die erste
2006-09-27 08:59:17 +00:00
Klasse der Optionen ist die einfachste:
2006-10-30 16:59:40 +00:00
Du musst nur entscheiden, ob du denkst, dass Qualitätsunterschiede
Geschwindigkeitsunterschiede rechtfertigen. Für die zweite Klasse
der Optionen sind die Vorzüge weitaus subjektiver, und mehr Faktoren
können involviert sein. Beachte, dass manche der Optionen für
2007-09-27 15:27:13 +00:00
"persönliche Vorlieben und spezielle Anforderungen"
2006-10-30 16:59:40 +00:00
noch große Auswirkungen auf Geschwindigkeit oder Qualität haben können,
das ist aber nicht, wozu sie primär benutzt werden. Ein paar der
2007-09-27 15:27:13 +00:00
Optionen für "persönliche Vorlieben" können sogar Änderungen
2006-10-30 16:59:40 +00:00
verursachen, die für manche Leute besser aussehen aber schlechter
für andere.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Bevor du fortfährst, musst du verstehen, dass dieses Handbuch nur
eine Qualitätsmetrik verwendet: globaler PSNR.
Für eine kurze Erklärung, was PSNR ist, schau dir
2006-09-27 08:59:17 +00:00
<ulink url= "http://en.wikipedia.org/wiki/PSNR" > den Wikipedia-Artikel zu PSNR</ulink>
an.
Globaler PSNR ist die letzte gemeldete PSNR-Nummer, wenn du die
Option <option > psnr</option> in <option > x264encopts</option>
einbindest.
Jedesmal wenn du eine Forderung nach PSNR liest, ist eine der Annahmen
hinter dieser Forderung, dass gleiche Bitraten verwendet werden.
</para>
<para >
Nahezu alle dieser Handbuchkommentare unterstellen, dass du
2-pass anwendest.
2006-10-30 16:59:40 +00:00
Beim Vergleich der Optionen gibt es zwei Hauptgründe, 2-pass-Encodierung
2006-09-27 08:59:17 +00:00
zu nutzen.
Der erste ist, 2-pass bringt rund 1dB PSNR, was einen sehr
2006-10-30 16:59:40 +00:00
großen Unterschied ausmacht.
Der zweite ist, Optionen zu testen, indem man direkte Qualitätsvergleiche
zu 1-pass-Encodierung anstellt, führt einen einen wichtigen verwirrenden
2006-09-27 08:59:17 +00:00
Faktor ein: die Bitrate variiert bei jeder Encodierung oft signifikant.
2006-10-30 16:59:40 +00:00
Es ist nicht immer einfach zu sagen, ob Qualitätsänderungen vorwiegend
auf geänderte Optionen zurückzuführen sind oder ob sie meist
essentielle, zufällige Unterschiede in der erhaltenen Bitrate reflektieren.
2006-09-27 08:59:17 +00:00
</para>
</sect3>
<sect3 id= "menc-feat-x264-encoding-options-speedvquality" >
2007-09-27 21:22:26 +00:00
<title > Optionen, die primär Geschwindigkeit und Qualität betreffen</title>
2006-09-27 08:59:17 +00:00
<itemizedlist >
<listitem >
<para >
<emphasis role= "bold" > subq</emphasis> :
Von den Optionen, die dir erlauben, einen Kompromiss zwischen
2006-10-30 16:59:40 +00:00
Geschwindigkeit und Qualität einzugehen, sind <option > subq</option>
und <option > frameref</option> (siehe unten) gewöhnlich die bei weitem
2006-09-27 08:59:17 +00:00
wichtigsten.
2006-10-30 16:59:40 +00:00
Wenn du dich für die Optimierung von entweder Geschwindigkeit oder Qualität
interessierst, sind diese die ersten, die du in Erwägung ziehen solltest.
2006-09-27 08:59:17 +00:00
Bei der Dimension Geschwindigkeit, interagieren die Optionen
<option > frameref</option> und <option > subq</option> ziemlich stark
miteinander.
Die Erfahrung zeigt, dass mit einem Referenzframe <option > subq=5</option>
(die Standardeinstellung) das ganze etwa 35% mehr Zeit in Anspruch nimmt als
<option > subq=1</option> .
2006-10-30 16:59:40 +00:00
Mit 6 Referenzframes wächst der Nachteil auf 60%.
Der Effekt, den <option > subq</option> auf den PSNR ausübt, scheint ziemlich
2006-09-27 08:59:17 +00:00
konstant zu sein, ungeachtet der Anzahl der Referenzframes.
2006-10-30 16:59:40 +00:00
Typischerweise erreicht <option > subq=5</option> einen 0.2-0.5 dB höheren globalen
2006-09-27 08:59:17 +00:00
PSNR im Vergleich zu <option > subq=1</option> .
2006-10-30 16:59:40 +00:00
Dies ist gewöhnlich ausreichend, um sichtbar zu werden.
2006-09-27 08:59:17 +00:00
</para>
<para >
2007-09-27 21:22:26 +00:00
<option > subq=6</option> ist langsamer und führt bei erträglichen Kosten zu besserer
2006-10-30 16:59:40 +00:00
Qualität.
Im Vergleich zu <option > subq=5</option> gewinnt sie gewöhnlich 0.1-0.4 dB
globalen PSNR mit Geschwindigkeitseinbußen, die sich zwischen 25%-100%
2006-09-27 08:59:17 +00:00
bewegen.
2006-10-30 16:59:40 +00:00
Im Unterschied zu anderen Levels von <option > subq</option> hängt das
2006-09-27 08:59:17 +00:00
Verhalten von <option > subq=6</option> nicht sehr von <option > frameref</option>
2006-10-30 16:59:40 +00:00
und <option > me</option> ab. Statt dessen hängt die Effektivität von
<option > subq=6</option> größtenteils von der Anzahl der verwendeten
2006-09-27 08:59:17 +00:00
B-Frames ab. Im Normalgebrauch bedeutet dies, <option > subq=6</option>
2006-10-30 16:59:40 +00:00
hat einen großen Einfluss auf Geschwindigkeit und Qualität
2006-09-27 08:59:17 +00:00
in komplexen, stark bewegten Szenen, kann aber auch einen geringen Effekt
in Szenen mit wenig Bewegung haben. Beachte, dass dennoch empfohlen wird,
<option > bframes</option> immer auf etwas anderes als null
zu setzen (siehe unten).
</para>
2007-09-27 21:22:26 +00:00
<para >
<option > subq=7</option> ist der langsamste Modus mit der höchsten Qualität.
Im Vergleich zu <option > subq=6</option> erreicht er normalerweise zwischen 0.01-0.05 dB
Zuwachs des globalen PSNR bei Geschwindigkeitseinbußen variierend von 15%-33%.
Da der Kompromiss zwischen Zeit gegenüber Qualität recht gering ist, solltest
du ihn nur benutzen, wenn du jedes mögliche Bit einsparen möchtest und
Encodierzeit keine Rolle spielt.
</para>
2006-09-27 08:59:17 +00:00
</listitem>
<listitem >
<para >
<emphasis role= "bold" > frameref</emphasis> :
<option > frameref</option> ist per Voreinstellung auf 1 gesetzt, jedoch
2006-10-30 16:59:40 +00:00
solltest du deshalb nicht darauf schließen, dass es unbedingt
2006-09-27 08:59:17 +00:00
auf 1 gesetzt sein muss.
2006-10-30 16:59:40 +00:00
Allein die Erhöhung von <option > frameref</option> auf 2 bringt rund
2006-09-27 08:59:17 +00:00
0.15dB PSNR mit einem Geschwindigkeitsnachteil von 5-10%; dies sieht nach
einem guten Kompromiss aus.
<option > frameref=3</option> bringt rund 0.25dB PSNR mehr als
<option > frameref=1</option> , was einen sichtbaren Unterschied machen
sollte.
<option > frameref=3</option> ist rund 15% langsamer als
<option > frameref=1</option> .
2006-10-30 16:59:40 +00:00
Leider setzen vermindernde Rückgaben schnell ein.
<option > frameref=6</option> kann erwartungsgemäß nur
0.05-0.1 dB mehr als <option > frameref=3</option> bei zusätzlichen
2006-09-27 08:59:17 +00:00
15% Geschwindigkeitsnachteil.
2006-10-30 16:59:40 +00:00
Oberhalb <option > frameref=6</option> sind die Qualitätsgewinne
für gewöhnlich sehr klein (obwohl du während der ganzen Diskussion
im Kopf behalten solltest, dass sie abhängig von deiner Quelle stark
variieren können).
2006-09-27 08:59:17 +00:00
In einem ziemlich typischen Fall wird <option > frameref=12</option>
2006-10-30 16:59:40 +00:00
den globalen PSNR um ein bisschen mehr als 0.02dB gegenüber
<option > frameref=6</option> verbessern, bei Geschwindigkeitseinbußen
2006-09-27 08:59:17 +00:00
von 15%-20%.
Bei so hohen <option > frameref</option> -Werten ist das wirklich
einzig Gute, dass man sagen kann, dass ein weiteres Anheben dieses
2006-10-30 16:59:40 +00:00
Wertes ziemlich sicher nie den PSNR <emphasis role= "bold" > schädigen</emphasis>
wird, jedoch sind zusätzliche Qualitätsvorteile sogar kaum messbar,
2006-09-27 08:59:17 +00:00
geschweige denn wahrnehmbar.
</para>
<note > <title > Beachte:</title>
<para >
2006-10-30 16:59:40 +00:00
Das Erhöhen von <option > frameref</option> auf unnötig hohe Werte
2006-09-27 08:59:17 +00:00
<emphasis role= "bold" > kann</emphasis> und
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > tut dies üblicherweise auch</emphasis>
die Codiereffizienz schädigen, wenn du CABAC ausschaltest.
2006-09-27 08:59:17 +00:00
Mit eingeschaltetem CABAC (das Standardverhalten) scheint die
2007-09-27 15:27:13 +00:00
Möglichkeit, <option > frameref</option> "zu hoch"
2006-10-30 16:59:40 +00:00
zu setzen, gegenwärtig zu weit entfernt um sich Sorgen zu machen,
und in der Zukunft werden womöglich Optimierungen diese Möglichkeit
ganz und gar ausschließen.
2006-09-27 08:59:17 +00:00
</para>
</note>
<para >
2006-10-30 16:59:40 +00:00
Wenn du auf Geschwindigkeit abzielst, ist ein vernünftiger
2006-09-27 08:59:17 +00:00
Kompromiss, im ersten Durchgang niedrigere <option > subq</option> - und
<option > frameref</option> -Werte zu nehmen, und sie danach im
2006-10-30 16:59:40 +00:00
zweten Durchgang zu erhöhen.
Typischerweise hat dies einen vernachlässigbar negativen Effekt
auf die Encodierqualität: Du wirst womöglich unter 0.1dB PSNR
verlieren, was viel zu klein für einen sichtbaren Unterschied
2006-09-27 08:59:17 +00:00
sein sollte.
2006-10-30 16:59:40 +00:00
Trotzdem, unterschiedliche Werte für <option > frameref</option>
können auf verschiedene Weise die Frametypenbestimmung beeinflussen.
Höchstwahrscheinlich sind dies außerordentlich seltene Fälle,
2006-09-27 08:59:17 +00:00
willst du jedoch wirklich sicher gehen, ziehe in Betracht, ob
dein Video entweder Vollbild- respektive Einblendungsmuster
2006-10-30 16:59:40 +00:00
oder sehr große temporäre Überdeckungen enthält, was einen I-Frame
erzwingen könnte.
2006-09-27 08:59:17 +00:00
Passe <option > frameref</option> des ersten Durchgangs so an,
2006-10-30 16:59:40 +00:00
dass es groß genug ist, die Dauer des Einblendungszyklus
(oder der Überdeckungen) zu enthalten.
Zum Beispiel, wenn die Szene zwischen zwei Bildern über eine
Zeitspanne von drei Frames rückwärts und vorwärts springt,
2006-09-27 08:59:17 +00:00
setze <option > frameref</option> des ersten Durchgangs auf 3
2006-10-30 16:59:40 +00:00
oder höher.
2006-09-27 08:59:17 +00:00
Dieser Sachverhalt kommt vermutlich extrem selten in
Videomaterial mit Live Action vor, erscheint aber manchmal
bei eingefangenen Computerspiel-Sequenzen.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > me</emphasis> :
2006-10-30 16:59:40 +00:00
Diese Option dient der Wahl der Suchmethode der Bewegungseinschätzung.
Diese Option zu verändern stellt einen überschaubaren Kompromiss
zwischen Qualität und Geschwindigkeit dar.
2006-10-17 11:21:11 +00:00
<option > me=dia</option> ist nur ein paar Prozent schneller als
2006-09-27 08:59:17 +00:00
die Standardsuche, auf Kosten von unter 0.1dB globalem PSNR. Die
2006-10-17 11:21:11 +00:00
Standardeinstellung (<option > me=hex</option> ) ist ein angemessener
2006-10-30 16:59:40 +00:00
Kompromiss zwischen Qualität und Geschwindigkeit.
2006-10-17 11:21:11 +00:00
<option > me=umh</option> bringt ein wenig unter 0.1dB globalem PSNR,
2006-10-30 16:59:40 +00:00
mit Geschwindigkeitsnachteil, der abhängig von <option > frameref</option>
2006-09-27 08:59:17 +00:00
variiert. Bei hohen <option > frameref</option> -Werten (z.B. 12 oder so)
2006-10-17 11:21:11 +00:00
ist <option > me=umh</option> etwa 40% langsamer als die Standardeinstellung
2006-10-30 16:59:40 +00:00
<option > me=hex</option> . Mit <option > frameref=3</option> fällt der
2006-09-27 08:59:17 +00:00
Geschwindigkeitsnachteil auf 25%-30%.
</para>
<para >
2006-10-30 16:59:40 +00:00
<option > me=esa</option> verwendet eine gründliche, für die praktische
2006-09-27 08:59:17 +00:00
Anwendung zu langsame Suche.
</para>
</listitem>
<listitem >
<para >
2006-10-17 11:21:11 +00:00
<emphasis role= "bold" > partitions=all</emphasis> :
2006-09-27 08:59:17 +00:00
Diese Option aktiviert die Verwendung von 8x4, 4x8 und 4x4 Unterteilungen
2006-10-30 16:59:40 +00:00
in den vorhergesagten Macroblöcken (zusätzlich zu den Standardunterteilungen).
Sie zu aktivieren führt zu einem
recht beständigen Geschwindigkeitsverlust von 10%-15%. Sie ist
2006-09-27 08:59:17 +00:00
ziemlich nutzlos bei Quellen, die nur langsame Bewegungen enthalten,
obwohl in manchen Quellen mit sehr viel Bewegung und vielen kleinen,
2006-10-30 16:59:40 +00:00
sich bewegenden Objekten Zugewinne von etwa 0.1dB erwartet werden können.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > bframes</emphasis> :
Wenn du gewohnt bist, mit anderen Codecs zu encodieren, hast du
2006-10-30 16:59:40 +00:00
womöglich empfunden, dass B-Frames nicht immer nützlich sind.
Bei H.264 wurde dies geändert: es gibt neue Techniken und Blocktypen,
die in B-Frames möglich sind.
Für gewöhnlich kann selbst ein einfältiger Algorithmus zur Wahl
2006-09-27 08:59:17 +00:00
der B-Frames einen signifikanten PSNR-Vorteil bringen.
Es ist interessant festzustellen, dass die Anwendung von B-Frames
normalerweise den zweiten Durchgang ein bisschen beschleunigt,
und er kann auch eine Encodierung mit einfachem Durchgang etwas
schneller machen, wenn adaptive B-Frame-Bestimmung deaktiviert
ist.
</para>
<para >
Mit deaktivierter adaptiver B-Framebestimmung
(<option > nob_adapt</option> von <option > x264encopts</option> )
2006-10-30 16:59:40 +00:00
ist der optimale Wert für diese Einstellung normalerweise nicht
2006-09-27 08:59:17 +00:00
mehr als <option > bframes=1</option> , andernfalls leiden Szenen
mit sehr viel Bewegung darunter.
Mit aktivierter adaptiver B-Framebestimmung (das Standardverhalten)
2006-10-30 16:59:40 +00:00
ist es sicher, höhere Werte zu verwenden; der Encoder wird die Anwendung
2006-09-27 08:59:17 +00:00
von B-Frames in Szenen reduzieren, in denen sie die Kompression
2006-10-30 16:59:40 +00:00
schädigen könnten.
2006-09-27 08:59:17 +00:00
Der Encoder zieht es selten vor, mehr als 3 oder 4 B-Frames zu
2006-10-30 16:59:40 +00:00
verwenden; diese Option höher zu setzen wird einen geringen Effekt haben.
2006-09-27 08:59:17 +00:00
</para> </listitem>
<listitem >
<para >
<emphasis role= "bold" > b_adapt</emphasis> :
2006-10-30 16:59:40 +00:00
Beachte: Dies ist standardmäßig eingeschaltet.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Ist diese Option aktiviert, wird der Encoder einen einigermaßen schnellen
2006-09-27 08:59:17 +00:00
Entscheidungsprozess zur Reduzierung der Anzahl B-Frames in Szenen anwenden, die
2006-10-30 16:59:40 +00:00
nicht viel von ihnen profitieren würden.
2006-09-27 08:59:17 +00:00
Du kannst <option > b_bias</option> dazu verwenden, zu optimieren wie
2006-10-30 16:59:40 +00:00
froh der Encoder über B-Frames sein soll.
Der Geschwindigkeitsnachteil adaptiver B-Frames ist gegenwärtig ziemlich
bescheiden, und genauso ist der potentielle Qualitätsgewinn.
2006-09-27 08:59:17 +00:00
Es sollte aber normalerweise nicht schaden.
Beachte, dass dies nur Geschwindigkeit und Frametypenbestimmung im ersten
Durchgang betrifft.
<option > b_adapt</option> und <option > b_bias</option> haben keinen
2006-10-30 16:59:40 +00:00
Effekt auf nachfolgende Durchgänge.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem > <para >
<emphasis role= "bold" > b_pyramid</emphasis> :
Du kannst diese Option genauso gut aktivieren, falls du >=2 B-Frames
verwendest; wie die Manpage dir sagt, erreichst du eine kleine
2006-10-30 16:59:40 +00:00
Qualitätsverbesserung bei keinerlei Geschwindigkeitseinbuße.
2006-09-27 08:59:17 +00:00
Beachte, dass diese Videos von libavcodec-basierten Decodern
2006-10-30 16:59:40 +00:00
älter als etwa 5. März 2005 nicht gelesen werden können.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > weight_b</emphasis> :
2006-10-30 16:59:40 +00:00
In typischen Fällen gibt es nicht viel Gewinn mit dieser Option.
Trotzdem, in überblendenden oder ins Schwarze übergehenden Szenen
liefert die gewichtete Vorhersage ziemlich große Einsparungen bei der Bitrate.
In MPEG-4 ASP wird ein Übergang ins Schwarze gewöhnlich am besten
als eine Serie aufwändiger I-Frames codiert; das Verwenden einer
gewichteten Vorhersage in B-Frames macht es möglich, wenigstens
2006-09-27 08:59:17 +00:00
manche von diesen in viel kleinere B-Frames zu wandeln.
Der Verlust an Encodierzeit ist minimal, da keine extra Bestimmungen
2006-10-30 16:59:40 +00:00
vorgenommen werden müssen.
2006-09-27 08:59:17 +00:00
Auch werden die CPU-Anforderungen des Encoders, im Gegensatz zu den
2006-10-30 16:59:40 +00:00
Einschätzungen mancher Leute, von gewichteter Vorhersage nicht sonderlich
2006-09-27 08:59:17 +00:00
beeinflusst, ansonsten bleibt alles gleich.
</para>
<para >
Leider hat der aktuelle Algorithmus zur adaptiven B-Frame-Bestimmung
2006-10-30 16:59:40 +00:00
eine starke Tendenz, B-Frames während des Fadens zu verhindern.
Bis sich dies ändert, kann es eine gute Idee sein,
<option > nob_adapt</option> zu deinen x264encopts hinzuzufügen, falls
du erwartest, dass Fades einen großen Effekt in deinem jeweiligen
2006-09-27 08:59:17 +00:00
Videoclip erzeugen.
</para>
</listitem>
2007-09-27 21:22:26 +00:00
<listitem id= "menc-feat-x264-encoding-options-speedvquality-threads" >
<para >
<emphasis role= "bold" > threads</emphasis> :
Diese Option erlaubt es, mehrere Threads zu erstellen, um parallel auf mehreren
CPUs zu encodieren. Du kannst die Anzahl der Threads manuell wählen oder,
besser, setze <option > threads=auto</option> und lasse
<systemitem class= "library" > x264</systemitem> erkennen, wie viele CPUs
verfügbar sind, und die passende Anzahl Threads automatisch wählen.
Wenn du eine Multi-Prozessor-Maschine hast, solltest du wirklich in Erwägung
ziehen, dies zu benutzen, da es die Encodiergeschwindigkeit linear in
der Anzahl der CPU-Kerne (ca. 94% pro CPU-Kern) erhöhen kann, bei sehr
geringem Qualitätsverlust (ca. 0.005dB bei Dualprozessor, ca. 0.01dB bei
einer Quad-Prozessor-Maschine).
</para>
</listitem>
2006-09-27 08:59:17 +00:00
</itemizedlist>
</sect3>
<sect3 id= "menc-feat-x264-encoding-options-misc-preferences" >
<title > Diverse Eigenschaften betreffende Optionen</title>
<itemizedlist >
<listitem >
<para >
<emphasis role= "bold" > 2-pass-Encodierung</emphasis> :
Oben wurde vorgeschlagen, immer 2-pass-Encodierung anzuwenden.
2006-10-30 16:59:40 +00:00
Es gibt aber durchaus Gründe, dies nicht zu tun. Beispielsweise bist du,
2006-09-27 08:59:17 +00:00
wenn du Live-TV aufnimmst und in Echtzeit encodierst,
gezwungen, einen einzigen Durchgang zu verwenden.
2006-10-30 16:59:40 +00:00
Auch ist ein Durchgang offensichtlich schneller als zwei Durchgänge;
wenn du exakt die gleichen Optionen bei beiden Durchgängen anwendest,
ist das Encodieren in zwei Durchgängen mindestens zweimal so langsam.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Noch gibt es sehr gute Gründe, in zwei Durchgängen zu encodieren.
2006-09-27 08:59:17 +00:00
Zum einen ist Ratenkontrolle in einem Durchgang kein Allheilmittel.
2006-10-30 16:59:40 +00:00
Sie trifft oft eine unvernünftige Auswahl, weil sie das große
2006-09-27 08:59:17 +00:00
Bild nicht sehen kann. Zum Beispiel angenommen, du hast ein zwei Minuten
2006-10-30 16:59:40 +00:00
langes Video bestehend aus zwei ausgeprägten Hälften. Die erste Hälfte
2006-09-27 08:59:17 +00:00
besitzt eine 60 Sekunden dauernde Szene mit sehr viel Bewegung, die
2006-10-30 16:59:40 +00:00
einzeln für sich etwa 2500kbps benötigt, um anständig auszusehen.
2006-09-27 08:59:17 +00:00
Direkt daruffolgend kommt eine viel weniger anspruchsvolle 60 Sekunden
lange Szene, die bei 300kbps gut aussieht. Angenommen du forderst in
der Theorie 1400kbps an, was beiden Szenen ausreichend entgegenkommen
2006-10-30 16:59:40 +00:00
würde. Die Ratenkontrolle in einem Durchgang wird in diesem Fall
2007-09-27 15:27:13 +00:00
ein paar "Fehler" machen. Zuallererst wird es in beiden Segmenten
2006-10-30 16:59:40 +00:00
1400kbps anpeilen. Das erste Segment könnte schwer überquantisiert enden,
was es unakzeptabel und unangemessen blockhaft aussehen lässt.
2006-09-27 08:59:17 +00:00
Das zweite Segment wird schwer unterquantisiert sein; es sieht vielleicht
perfekt aus, aber der Bitratenverlust dieser Perfektion wird komplett
unangemessen sein.
2006-10-30 16:59:40 +00:00
Noch schwerer vermeidbar ist das Problem am Übergang beider Szenen.
Die ersten Sekunden der Hälfte mit wenig Bewegung wird enorm
überquantisiert sein, weil die Ratenkontrolle noch die Art Anforderung
an die Bitrate erwartet, der sie in der ersten Hälfte des Videos begegnet
2007-09-27 15:27:13 +00:00
war. Diese "Fehlerperiode" der extrem überquantisierten Szene
2006-10-30 16:59:40 +00:00
mit wenig Bewegung wird fürchterlich schlecht aussehen, und wird sogar
weniger als die 300kbps in Anspruch nehmen als das, was sie genommen hätte, um annehmbar
auszusehen. Es gibt Mittel und Wege, diese Fälle des Encodierens in einem
2006-09-27 08:59:17 +00:00
Durchgang zu mildern, diese werden allerdingst dahin tendieren, die
2006-10-30 16:59:40 +00:00
fehlerhaften Vorhersagen der Bitraten zu häufen.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Multipass-Ratenkontrolle kann gegenüber der eines einzigen Durchgangs
enorm große Vorteile bieten.
2006-09-27 08:59:17 +00:00
Indem sie die im ersten Encodierungsdurchlauf gesammelte Statistik
verwendet, kann der Encoder mit angemessener Genauigkeit den Aufwand
2006-10-30 16:59:40 +00:00
(in Bit) abschätzen, den das Encodieren jeden gegebenen Frames bei
2006-09-27 08:59:17 +00:00
jedem gegebenen Quantisierer erfordert. Dies erlaubt eine viel
rationalere, besser geplante Zuweisung von Bits zwischen den
bithungrigen Szenen mit viel Bewegung und denen bescheidenen mit
wenig Bewegung.
2006-10-30 16:59:40 +00:00
Siehe <option > qcomp</option> unten für einige Ideen darüber, wie man
2006-09-27 08:59:17 +00:00
diese Zuweisungen nach seinem Geschmack optimiert.
</para>
<para >
2006-10-30 16:59:40 +00:00
Darüber hinaus brauchen zwei Durchgänge zweimal so lang wie ein Durchgang.
Du kannst die Optionen im ersten Durchgang auf höhere Geschwindigkeit
und niedrigere Qualität optimieren.
Wenn du deine Optionen geschickt wählst, kannst du einen sehr schnellen
2006-09-27 08:59:17 +00:00
ersten Durchgang hinkriegen.
2006-10-30 16:59:40 +00:00
Die resultierende Qualität im zweiten Durchgang wird geringfügig niedriger
ausfallen, weil die Größenvorhersage weniger akkurat ist, jedoch
ist die Qualitätsdifferenz normalerweise viel zu klein, um sichtbar zu sein.
2006-09-27 08:59:17 +00:00
Versuche zum Beispiel <option > subq=1:frameref=1</option> zu
2006-10-30 16:59:40 +00:00
<option > x264encopts</option> des ersten Durchgangs hinzuzufügen.
2006-09-27 08:59:17 +00:00
Verwende dann im zweiten Durchgang langsamere, hochwertigere Optionen:
2006-10-17 11:21:11 +00:00
<option > subq=6:frameref=15:partitions=all:me=umh</option>
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
2006-10-30 16:59:40 +00:00
<emphasis role= "bold" > Encodierung mit drei Durchgängen</emphasis> ?
2006-09-27 08:59:17 +00:00
2006-10-30 16:59:40 +00:00
x264 bietet die Möglichkeit, eine beliebige Anzahl aufeinander folgender
Durchgänge auszuführen. Wenn du <option > pass=1</option> im ersten Durchgang
2006-09-27 08:59:17 +00:00
spezifizierst, dann verwende <option > pass=3</option> im nachfolgenden
Durchgang, der nachfolgende Durchgang wird beides tun, die Statistik des
vorhergehenden Durchgangs lesen und seine eigene Statistik schreiben.
2006-10-30 16:59:40 +00:00
Ein zusätzlicher Durchgang, der diesem folgt, wird eine sehr gute Basis
haben, von der aus er hochpräzise Vorhersagen der Framegrößen bei
einem gewählten Quantisierer machen kann.
In der Praxis ist der damit erzielte gesamte Qualitätsgewinn
gewöhnlich nahezu null, und ziemlich wahrscheinlich resultiert ein dritter
Durchgang in einem geringfügig schlechteren globalen PSNR als der Durchgang
davor. In der typischen Anwendung helfen drei Durchgänge, wenn du entweder
eine schleche Vorhersage der Bitraten oder schlecht aussehende Szenenübergänge
2006-09-27 08:59:17 +00:00
beim Verwenden nur eines Durchlaufs bekommst.
Dies passiert mit ziemlicher Wahrscheinlichkeit bei extrem kurzen Clips.
2006-10-30 16:59:40 +00:00
Ebenso gibt es ein paar Spezialfälle, in denen drei (oder mehr) Durchgänge
2006-09-27 08:59:17 +00:00
erfahrenen Nutzern dienlich sind, aber um es kurz zu machen, dieses Handbuch
2006-10-30 16:59:40 +00:00
behandelt die Diskussion solcher speziellen Fälle nicht.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > qcomp</emphasis> :
2007-09-27 15:27:13 +00:00
<option > qcomp</option> wägt die Anzahl der für "aufwändige" Frames
mit viel Bewegung vorgesehenen Bits gegen die für "weniger aufwändige"
2006-09-27 08:59:17 +00:00
Frames mit wenig Bewegung ab.
Bei einem Extrem zielt <option > qcomp=0</option> auf eine echte konstante
2006-10-30 16:59:40 +00:00
Bitrate ab. Typischerweise würde dies Szenen mit viel Bewegung vollkommen
ätzend aussehen lassen, während Szenen mit wenig Bewegung womöglich absolut
perfekt aussehen, jedoch öfter mehr Bitrate verwenden würden, als sie es für
lediglich sehr gutes Aussehen bräuchten. Beim anderen Extrem
2006-09-27 08:59:17 +00:00
erreicht <option > qcomp=1</option> nahezu konstante Quantisierungsparameter
(QP). Ein konstanter QP sieht nicht schlecht aus, die meisten Leute meinen
2006-10-30 16:59:40 +00:00
aber, es sei vernünftiger, etwas Bitrate aus den extrem aufwändigen Szenen
zu nehmen (wobei dort der Qualitätsverlust micht ganz so augenfällig ist)
und sie wieder den Szenen zuzuweisen, die bei sehr guter Qualität leichter
2006-09-27 08:59:17 +00:00
zu encodieren sind.
2006-10-30 16:59:40 +00:00
<option > qcomp</option> ist per Voreinstellung auf 0.6 gesetzt, was für den
Geschmack mancher Leute etwas zu langsam sein könnte (0.7-0.8 werden im
2006-09-27 08:59:17 +00:00
Allgemeinen auch verwendet).
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > keyint</emphasis> :
2006-10-30 16:59:40 +00:00
<option > keyint</option> ist einzig und allein zur Abwägung der
Durchsuchbarkeit der Datei gegenüber der Codiereffiziez da.
2006-09-27 08:59:17 +00:00
Als Standardwert ist <option > keyint</option> auf 250 gesetzt. In
Material mit 25fps garantiert dies, auf 10 Sekunden genau
2006-10-30 16:59:40 +00:00
suchen zu können. Wenn du meinst, es wäre wichtig und nützlich,
auf 5 Sekunden genau suchen zu können, setze es auf <option > keyint=125</option> ;
dies wird der Qualität/Bitrate leicht schaden. Wenn es dir nur um Qualität
geht und nicht um die Durchsuchbarkeit, kannst du viel höhere Werte
setzen (vorausgesetzt du verstehst, daß es verringerte Resultate gibt, die verschwindend
2006-09-27 08:59:17 +00:00
klein werden oder sogar gegen null gehen). Der Videostream wird nach
wie vor suchbare Stellen besitzen, solange einige Szenenwechsel
vorhanden sind.
</para>
</listitem>
<listitem >
<para >
2006-10-17 11:21:11 +00:00
<emphasis role= "bold" > deblock</emphasis> :
2006-09-27 08:59:17 +00:00
Dieses Thema ist im Begriff etwas kontrovers zu geraten.
</para>
<para >
2006-10-30 16:59:40 +00:00
H.264 definiert eine simple Deblocking-Prozedur bei I-Blöcken, die
von vorgegebenen Stärken und vom QP des strittigen Blocks
abhängigen.
Mit dem Standardwert werden hohe QP-Blöcke stark gefiltert, und
niedrige QP-Blöcke werden überhaupt nicht entblockt.
Die vom Standard definierten vorgegebenen Stärken sind mit
Bedacht gewählt und die Chancen stehen sehr gut, dass sie
2006-09-27 08:59:17 +00:00
PSNR-optimal sind, egal welches Video auch immer du zu encodieren
versuchst.
2006-10-17 11:21:11 +00:00
Der Parameter <option > deblock</option> erlaubt dir, Offsets festzulegen,
2006-09-27 08:59:17 +00:00
um Deblocking-Schwellen voreinzustellen.
</para>
<para >
2006-10-30 16:59:40 +00:00
Viele Leute scheinen zu glauben, es sei eine gute Idee, die Stärke
des Deblocking-Filters um hohe Beträge abzusenken (sagen wir -3).
Dies ist jedoch meist keine gute Idee, und in den meisten Fällen
2006-09-27 08:59:17 +00:00
verstehen Leute, die das machen, nicht viel davon wie Deblocking
2006-10-30 16:59:40 +00:00
standardmäßig funktioniert.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Die erste und wichtigste Sache, die man über den
2006-09-27 08:59:17 +00:00
in-loop-Deblocking-Filter wissen sollte, ist, dass die
Standardschwellenwerte meistens PSNR-optimal sind.
2006-10-30 16:59:40 +00:00
In den seltenen Fällen, in denen sie nicht optimal sind, ist das
2006-09-27 08:59:17 +00:00
ideale Offset plus oder minus 1.
2006-10-30 16:59:40 +00:00
Die Deblocking-Parameter durch einen höheren Betrag anzupassen
2006-09-27 08:59:17 +00:00
garantiert meist, dem PSNR zu schaden.
2006-10-30 16:59:40 +00:00
Das Verstärken des Filters wird mehr Details verwischen; den
Filter zu schwächen wird das Auftreten von Blockeffekten
erhöhen.
2006-09-27 08:59:17 +00:00
</para>
<para >
Es ist definitiv eine schlechte Idee, die Deblocking-Schwellenwerte
2006-10-30 16:59:40 +00:00
herabzusetzen, falls deine Quelle eine vorwiegend niedrige räumliche
Komplexität besitzt (z.B. nicht viele Details oder Rauschen).
2006-09-27 08:59:17 +00:00
Der in-loop-Filter macht eigentlich einen exzellenten Job durch
das Kaschieren auftretender Artefakte.
2006-10-30 16:59:40 +00:00
Besitzt die Quelle eine hohe räumliche Komplexität, sind Artefakte
2006-09-27 08:59:17 +00:00
weniger bemerkbar.
Dies ist so, weil das Schwingen (ringing) dazu neigt, wie Details
oder Rauschen auszusehen.
Die viselle Wahrnehmung des Menschen erkennt leicht, wenn Details
entfernt wurden, aber erkennt nicht so leicht, wenn Rauschen falsch
dargestellt wird.
2006-10-30 16:59:40 +00:00
Wird die Qualität subjektiv, sind Details und Rauschen etwas
2006-09-27 08:59:17 +00:00
austauschbares.
2006-10-30 16:59:40 +00:00
Durch das Herabsetzen der Deblocking-Filterstärke verstärkst du
höchstwahrscheinlich Fehler durch Hinzufügen von
Schwingungsartefakten, aber dem Auge fällt nichts auf, weil
2006-09-27 08:59:17 +00:00
es die Artefakte mit Details verwechselt.
</para>
<para >
Dies rechtfertigt jedoch <emphasis role= "bold" > nach wie vor</emphasis>
2006-10-30 16:59:40 +00:00
nicht das Herabsetzen der Deblocking-Filterstärke.
Du kannst im Allgemeinen besseres Qualitätsrauschen im Postprocessing
2006-09-27 08:59:17 +00:00
erzielen.
Falls deine H.264-Encodierungen zu verschwommen oder verschmiert
aussehen, versuche, mit
<option > -vf noise</option> beim Abspielen des encodierten Films
herumzuspielen.
<option > -vf noise=8a:4a</option> sollte die meisten weichen Artefakte
kaschieren.
Es wird meist mit Sicherheit besser aussehen als die Resultate, die
2006-10-30 16:59:40 +00:00
du durch einfaches Herumtüfteln mit dem Deblocking-Filter bekommen
hättest.
2006-09-27 08:59:17 +00:00
</para> </listitem>
</itemizedlist>
</sect3>
</sect2>
<sect2 id= "menc-feat-x264-example-settings" >
2006-10-30 16:59:40 +00:00
<title > Beispiele für Encodieroptionen</title>
2006-09-27 08:59:17 +00:00
<para >
Die folgenden Einstellungen sind Beispiele unterschiedlicher
Kombinationen von Encodier-Optionen, die einen Kompromiss zwischen
2006-10-30 16:59:40 +00:00
Geschwindigkeit und Qualität bei gleicher Zielbitrate darstellen.
2006-09-27 08:59:17 +00:00
</para>
<para >
All diese Encodier-Einstellungen wurden an einem Beispielvideo
mit 720x448 @30000/1001 fps getestet, die Zielbitrate war 900kbps,
und der Rechner war ein
2006-10-04 18:32:16 +00:00
AMD-64 3400+ mit 2400 MHz im 64bit-Modus.
2006-09-27 08:59:17 +00:00
Jede Encodier-Einstellung zeichnet sich durch eine gemessene
Encodiergeschwindigkeit (in Frames pro Sekunde) und dem
2007-09-27 15:27:13 +00:00
PSNR-Verlust (in dB) im Vergleich zu den "sehr
hochwertigen" Einstellung aus.
2006-10-30 16:59:40 +00:00
Bitte hab dafür Verständnis, dass du abhängig von deiner Quelle, deinem
2006-09-27 08:59:17 +00:00
Rechnertyp und Entwicklungsfortschritten sehr unterschiedliche Resultate
erhalten kannst.
</para>
<para >
<informaltable frame= "all" >
<tgroup cols= "4" >
<thead >
<row > <entry > Beschreibung</entry> <entry > Encodier-Optionen</entry> <entry > Geschwindigkeit (in fps)</entry> <entry > Relativer PSNR-Verlust (in dB)</entry> </row>
</thead>
<tbody >
<row >
2006-10-30 16:59:40 +00:00
<entry > Sehr hohe Qualität</entry>
2006-10-17 11:21:11 +00:00
<entry > <option > subq=6:partitions=all:8x8dct:me=umh:frameref=5:bframes=3:b_pyramid:weight_b</option> </entry>
2006-09-27 08:59:17 +00:00
<entry > 6fps</entry>
<entry > 0dB</entry>
</row>
<row >
2006-10-30 16:59:40 +00:00
<entry > Hohe Qualität</entry>
2006-10-17 11:21:11 +00:00
<entry > <option > subq=5:8x8dct:frameref=2:bframes=3:b_pyramid:weight_b</option> </entry>
2006-09-27 08:59:17 +00:00
<entry > 13fps</entry>
<entry > -0.89dB</entry>
</row>
<row >
<entry > Schnell</entry>
<entry > <option > subq=4:bframes=2:b_pyramid:weight_b</option> </entry>
<entry > 17fps</entry>
<entry > -1.48dB</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</sect2>
</sect1>
2007-09-27 21:22:26 +00:00
<sect1 id= "menc-feat-quicktime-7" >
<title >
<application > MEncoder</application> benutzen, um <application > QuickTime</application> -kompatible Dateien zu erstellen
</title>
<sect2 id= "menc-feat-quicktime-7-why-use-it" >
<title >
Warum sollte jemand <application > QuickTime</application> -kompatible Dateien erstellen wollen?
</title>
<para >
Es gibt mehrere Gründe, warum das Erstellen von <application > QuickTime</application> -kompatiblen
Dateien wünschenswert sein kann.
</para>
<itemizedlist >
<listitem >
<para >
Du willst, dass jeder Computeranalphabet deine Encodierung auf jeder größeren
Plattform (Windows, Mac OS X, Unices … ) anschauen kann.
</para>
</listitem>
<listitem >
<para >
<application > QuickTime</application> kann von mehr Features der Hardware- und
Softwarebeschleunigung von Max OS X gebrauch machen als plattformunabhängige
Player wie <application > MPlayer</application> oder <application > VLC</application> .
Das heißt, dass deine Encodierungen eine bessere Chance haben, auf älteren
G4-Machinen flüssig abgespielt werden zu können.
</para>
</listitem>
<listitem >
<para >
<application > QuickTime</application> 7 unterstützt den Next-Generation-Codec H.264,
der deutlich bessere Bildqualität erreicht als vorige Codecgenerationen
(MPEG-2, MPEG-4 … ).
</para>
</listitem>
</itemizedlist>
</sect2>
<sect2 id= "menc-feat-quicktime-7-constraints" >
<title > Beschränkungen von <application > QuickTime</application> 7</title>
<para >
<application > QuickTime</application> 7 unterstützt H.264 Video und AAC Audio,
aber es unterstützt diese nicht gemuxt im AVI-Containerformat.
Du kannst jedoch <application > MEncoder</application> verwenden, um Video
und Audio zu encodieren, und dann ein separates Programm wie
<application > mp4creator</application> (Teil des
<ulink url= "http://mpeg4ip.sourceforge.net/" > MPEG4IP-Pakets</ulink> )
verwenden, um Video- und Tonspuren in einen MP4-Container zu muxen.
</para>
<para >
<application > QuickTime</application> s Unterstützung für H.264 ist begrenzt,
daher wirst du ein paar fortgeschrittene Features weglassen müssen.
Wenn du dein Video mit Features encodierst, die
<application > QuickTime</application> 7 nicht unterstützt, werden dir
<application > QuickTime</application> -basierte Player ein ziemlich weißes
Bild zeigen an Stelle des erwarteten Videos.
</para>
<itemizedlist >
<listitem >
<para >
<emphasis role= "bold" > B-Frames</emphasis> :
<application > QuickTime</application> 7 unterstützt maximal einen B-Frame, z.B.
<option > -x264encopts bframes=1</option> . Dies bedeutet, dass
<option > b_pyramid</option> and <option > weight_b</option> keine Auswirkungen
haben werden, da sie <option > bframes</option> größer als 1 erwarten.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > Macroblöcke</emphasis> :
<application > QuickTime</application> 7 unterstützt keine 8x8 DCT Macroblöcke.
Diese Option (<option > 8x8dct</option> ) ist per Voreinstellung aus, stelle daher sicher,
dass du sie nicht explizit aktiviert.
Dies bedeutet auch, dass die Option <option > i8x8</option> keine Auswirkungen haben
wird, denn sie benötigt <option > 8x8dct</option> .
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > Seitenverhältnis</emphasis> :
<application > QuickTime</application> 7 unterstützt Informationen über
SAR (sample aspect ratio) nicht; es nimmt SAR=1 an.
Lies <link linkend= "menc-feat-quicktime-7-scale" > den Abschnitt über Skalierung</link>
für eine Umgehung dieses Problems.
</para>
</listitem>
</itemizedlist>
</sect2>
<sect2 id= "menc-feat-quicktime-7-crop" >
<title > Beschneidung der Ränder (Cropping)</title>
<para >
Angenommen, du willst deine nagelneu gekaufte Kopie von "Chroniken von Narnia"
rippen. Deine DVD ist Region 1, d.h. sie ist in NTSC.
Das weiter unten stehende Beispiel kann man auch auf PAL anwenden, nur
dass du dann <option > -ofps 24000/1001</option> weglassen und etwas andere
Maße für <option > crop</option> und <option > scale</option> verwenden musst.
</para>
<para >
Nach dem Ausführen von <option > mplayer dvd://1</option> folgst du den Anweisungen,
die detailliert im Abschnitt
<link linkend= "menc-feat-telecine" > Wie mit telecine und interlacing in NTSC-DVDs umgehen</link>
beschrieben sind, und stellst fest, dass es sich um
24000/1001 fps progressives Video handelt. Das vereinfacht das Vorgehen etwas,
da du keinen inverse telecine Filter wie <option > pullup</option> oder einen
Deinterlacing-Filter wie <option > yadif</option> anwenden musst.
</para>
<para >
Als nächstes musst du die schwarzen Streifen oben und unten vom Video entfernen
wie in <link linkend= "menc-feat-dvd-mpeg4-example-crop" > vorigem</link>
Abschnitt beschrieben.
</para>
</sect2>
<sect2 id= "menc-feat-quicktime-7-scale" >
<title > Skalierung</title>
<para >
Der nächste Schritt ist wirklich herzzerreißend.
<application > QuickTime</application> 7 unterstützt keine MPEG-4-Videos
mit einer sample aspect ratio ungleich 1, daher wirst du das Video auf quadratische
Pixel hochskalieren (was eine Menge Platz verschwendet) oder herunterskalieren
(was ein paar Details der Quelle verliert) müssen.
Beides ist höchst ineffizient, jedoch einfach nicht zu vermeiden, wenn
dein Video von <application > QuickTime</application> 7 abspielbar sein soll.
<application > MEncoder</application> kann die passende Hoch- oder Herunterskalierung
durchführen bei Angabe von <option > -vf scale=-10:-1</option> oder
<option > -vf scale=-1:-10</option> respektive.
Dies wird dein Video auf die für die geschnittene Höhe korrekte Breite
schneiden, gerundet auf das nächste Vielfache von 16 für optimale Kompression.
Beachte, dass wenn du schneidest, solltest du zuerst schneiden und erst dann skalieren:
<screen > -vf crop=720:352:0:62,scale=-10:-1</screen>
</para>
</sect2>
<sect2 id= "menc-feat-quicktime-7-avsync" >
<title > A/V-Synchronisation</title>
<para >
Weil du in einen anderen Container muxen wirst, solltest du immer die Option
<option > harddup</option> verwenden, um sicherzustellen, dass doppelte
Frames in der Videoausgabe tatsächlich dupliziert werden.
Ohne diese Option wird <application > MEncoder</application> einfach eine Markierung
im Videostream machen, dass ein doppelter Frame vorkommt, und sich darauf
verlassen, dass die Software dafür sorgt, dass derselbe Frame zweimal
angezeigt wird. Leider überlebt diese "weiche Duplikation" das Remuxen
nicht, daher wird der Ton langsam Synchronisation zum Video verlieren.
</para>
<para >
Die endgültige Filterkette sieht so aus:
<screen > -vf crop=720:352:0:62,scale=-10:-1,harddup</screen>
</para>
</sect2>
<sect2 id= "menc-feat-quicktime-7-bitrate" >
<title > Bitrate</title>
<para >
Wie immer geht es bei der Wahl der Bitrate sowohl um technische Gegebenheiten
der Quelle, wie <link linkend= "menc-feat-dvd-mpeg4-resolution-bitrate" > hier</link>
erklärt wird, als auch um persönlichen Geschmack.
Dieser Film enthält durchaus einige Actionszenen und viele Details, aber
H.264-Video sieht gut aus auch bei viel geringeren Bitraten als XviD oder
andere MPEG-4-Codecs.
Nach vielem Experimentieren hat der Autor dieser Anleitung beschlossen,
den Film bei 900kbps zu encodieren, und dachte, er sehe ziemlich gut aus.
Du kannst die Bitrate verringern, um Platz zu sparen, oder erhöhen, um
die Qualität zu verbessern.
</para>
</sect2>
<sect2 id= "menc-feat-quicktime-7-example" >
<title > Encoding-Beispiel</title>
<para >
Du bist jetzt soweit, das Video zu encodieren. Da du auf Qualität Wert legst,
wirst du natürlich eine Encodierung mit zwei Durchläufen machen.
Um etwas Encodierzeit zu sparen, kannst du die Option <option > turbo</option>
beim ersten Durchlauf angeben; dies verringert <option > subq</option> und
<option > frameref</option> auf 1. Um etwas Platz zu sparen, kannst du die
Option <option > ss</option> verwenden, um die ersten Sekunden des Videos zu
überspringen. (Ich fand, dass dieser bestimmte Film 32 Sekunden Vorspann hat.)
<option > bframes</option> kann 0 oder 1 sein.
Die anderen Optionen werden in
<link linkend= "menc-feat-x264-encoding-options-speedvquality" > Encodierung mit dem <systemitem class= "library" > x264</systemitem> -Codec</link>
und der Manpage beschrieben.
<screen > mencoder dvd://1 -o /dev/null -ss 32 -ovc x264 \
-x264encopts pass=1:turbo:bitrate=900:bframes=1:\
me=umh:partitions=all:trellis=1:qp_step=4:qcomp=0.7:direct_pred=auto:keyint=300 \
-vf crop=720:352:0:62,scale=-10:-1,harddup \
-oac faac -faacopts br=192:mpeg=4:object=1 -channels 2 -srate 48000 \
-ofps 24000/1001</screen>
Wenn du einen Rechner mit mehreren Prozessoren hast, nutze die Chance, den
Encodierungsvorgang dramatisch zu beschleunigen, indem du
<link linkend= "menc-feat-x264-encoding-options-speedvquality-threads" >
<systemitem class= "library" > x264</systemitem> 's Multithreading-Modus
</link>
verwendest, indem du die Option <option > threads=auto</option> der
<option > x264encopts</option> -Kommandozeile hinzufügst.
</para>
<para >
Der zweite Durchlauf ist derselbe, außer dass du die Ausgabedatei angibst
und <option > pass=2</option> setzt.
<screen > mencoder dvd://1 <emphasis role= "bold" > -o narnia.avi</emphasis> -ss 32 -ovc x264 \
-x264encopts <emphasis role= "bold" > pass=2</emphasis> :turbo:bitrate=900:frameref=5:bframes=1:\
me=umh:partitions=all:trellis=1:qp_step=4:qcomp=0.7:direct_pred=auto:keyint=300 \
-vf crop=720:352:0:62,scale=-10:-1,harddup \
-oac faac -faacopts br=192:mpeg=4:object=1 -channels 2 -srate 48000 \
-ofps 24000/1001</screen>
</para>
<para >
Das resultierende AVI sollte in <application > MPlayer</application>
perfekt abspielbar sein, aber natürlich kann <application > QuickTime</application>
es nicht abspielen. Denn es unterstützt H264 in AVI nicht.
Der nächste Schritt ist also, das Video in einen MP4-Container zu muxen.
</para>
</sect2>
<sect2 id= "menc-feat-quicktime-7-remux" >
<title > Remuxen zu MP4</title>
<para >
Es gibt mehrere Möglichkeiten, AVI-Dateien nach MP4 zu muxen. Du kannst
<application > mp4creator</application> verwenden, welches Teil des
<ulink url= "http://mpeg4ip.sourceforge.net/" > MPEG4IP-Pakets</ulink> ist.
</para>
<para >
Demuxe das AVI <application > MPlayer</application> zuerst in separate Audio- und Videostreams.
<screen > mplayer narnia.avi -dumpaudio -dumpfile narnia.aac
mplayer narnia.avi -dumpvideo -dumpfile narnia.h264</screen>
Die Dateinamen sind wichtig; <application > mp4creator</application>
verlangt, dass AAC-Audiostreams <systemitem > .aac</systemitem> und
H.264-Videostreams <systemitem > .h264</systemitem> heißen.
</para>
<para >
Benutze nun <application > mp4creator</application> , um aus Audio- und
Videostreams eine MP4-Datei zu erzeugen.
<screen > mp4creator -create=narnia.aac narnia.mp4
mp4creator -create=narnia.h264 -rate=23.976 narnia.mp4</screen>
Anders als bei der Encodierung musst du die Framerate als Dezimalzahl
(23.976) und nicht als Bruch (24000/1001) angeben.
</para>
<para >
Diese Datei <systemitem > narnia.mp4</systemitem> sollte nun mit jeder
<application > QuickTime</application> 7 Anwendung wie dem
<application > QuickTime Player</application> oder
<application > iTunes</application> abspielbar sein.
Wenn du vorhast, das Video mit einem <application > QuickTime</application> -Plugin
im Browser anzuschauen, solltest du den Film außerdem "hinten", so dass
das <application > QuickTime</application> -Plugin während des Downloads
die Wiedergabe starten kann.
<application > mp4creator</application> kann diese Art Tracks erstellen:
<screen > mp4creator -hint=1 narnia.mp4
mp4creator -hint=2 narnia.mp4
mp4creator -optimize narnia.mp4</screen>
Du kannst das Ergebnis überprüfen, um sicherzustellen, dass die Hint-Tracks
erfolgreich erstellt wurden:
<screen > mp4creator -list narnia.mp4</screen>
Du solltest eine Auflistung der Tracks sehen:
1 Audio-, 1 Video- und 2 Hint-Tracks.
<screen > Track Type Info
1 audio MPEG-4 AAC LC, 8548.714 secs, 190 kbps, 48000 Hz
2 video H264 Main@5.1, 8549.132 secs, 899 kbps, 848x352 @ 23.976001 fps
3 hint Payload mpeg4-generic for track 1
4 hint Payload H264 for track 2
</screen>
</para>
</sect2>
<sect2 id= "menc-feat-quicktime-7-metadata" >
<title > Metadata-Tags hinzufügen</title>
<para >
Wenn du deinem Video Tags hinzufügen möchtest, die in iTunes angezeigt werden,
kannst du dazu
<ulink url= "http://atomicparsley.sourceforge.net/" > AtomicParsley</ulink>
verwenden.
<screen > AtomicParsley narnia.mp4 --metaEnema --title "The Chronicles of Narnia" --year 2005 --stik Movie --freefree --overWrite</screen>
Die Option <option > --metaEnema</option> entfernt jegliche existierenden Metadaten
(<application > mp4creator</application> fügt seinen Namen im Tag
"encoding tool" hinzu), und <option > --freefree</option> macht den frei
gewordenen Platz geltend.
Die Option <option > --stik</option> setzt den Videotyp
(wie z.B. Film und Serie), den iTunes verwendet, um verwandte Videodateien
zu gruppieren.
Die Option <option > --overWrite</option> überschreibt die ursprüngliche Datei.
Ohne sie erstellt <application > AtomicParsley</application> eine automatisch
benannte Datei im selben Verzeichnis und lässt die Originaldatei unberührt.
</para>
</sect2>
</sect1>
<!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -->
2006-09-27 08:59:17 +00:00
<sect1 id= "menc-feat-video-for-windows" >
<title > Encodieren mit der <systemitem class= "library" > Video for Windows</systemitem> Codecfamilie</title>
<para >
2006-10-30 16:59:40 +00:00
Video for Windows bietet einfaches Encodieren mittels binärer Video-Codecs.
2006-09-27 08:59:17 +00:00
Du kannst mit folgenden Codecs encodieren (solltest du mehr haben, teile es
uns bitte mit!)
</para>
<para >
2006-10-30 16:59:40 +00:00
Beachte, dass der Support hierfür sehr experimentell ist, und
2006-09-27 08:59:17 +00:00
einige Codecs arbeiten vielleicht nicht korrekt. Manche Codecs werden
2006-10-30 16:59:40 +00:00
nur in bestimmten Farbräumen funktionieren, versuche
2006-09-27 08:59:17 +00:00
<option > -vf format=bgr24</option> und <option > -vf format=yuy2</option> ,
falls ein Codec versagt oder einen falschen Output liefert.
</para>
<sect2 id= "menc-feat-enc-vfw-video-codecs" >
2006-10-30 16:59:40 +00:00
<title > Von Video for Windows unterstützte Codecs</title>
2006-09-27 08:59:17 +00:00
<para >
<informaltable frame= "all" >
<tgroup cols= "4" >
<thead >
<row >
<entry > Video-Codec Dateiname</entry>
<entry > Beschreibung (FourCC)</entry>
<entry > md5sum</entry>
<entry > Kommentar</entry>
</row>
</thead>
<tbody >
<row >
<entry > aslcodec_vfw.dll</entry>
<entry > Alparysoft verlustfreier (lossless) Codec vfw (ASLC)</entry>
<entry > 608af234a6ea4d90cdc7246af5f3f29a</entry>
<entry > </entry>
</row>
<row >
<entry > avimszh.dll</entry>
<entry > AVImszh (MSZH)</entry>
<entry > 253118fe1eedea04a95ed6e5f4c28878</entry>
2006-10-30 16:59:40 +00:00
<entry > benötigt <option > -vf format</option> </entry>
2006-09-27 08:59:17 +00:00
</row>
<row >
<entry > avizlib.dll</entry>
<entry > AVIzlib (ZLIB)</entry>
<entry > 2f1cc76bbcf6d77d40d0e23392fa8eda</entry>
<entry > </entry>
</row>
<row >
<entry > divx.dll</entry>
<entry > DivX4Windows-VFW</entry>
<entry > acf35b2fc004a89c829531555d73f1e6</entry>
<entry > </entry>
</row>
<row >
<entry > huffyuv.dll</entry>
<entry > HuffYUV verlustfrei (lossless) (HFYU)</entry>
<entry > b74695b50230be4a6ef2c4293a58ac3b</entry>
<entry > </entry>
</row>
<row >
<entry > iccvid.dll</entry>
<entry > Cinepak Video (cvid)</entry>
<entry > cb3b7ee47ba7dbb3d23d34e274895133</entry>
<entry > </entry>
</row>
<row >
<entry > icmw_32.dll</entry>
<entry > Motion Wavelets (MWV1)</entry>
<entry > c9618a8fc73ce219ba918e3e09e227f2</entry>
<entry > </entry>
</row>
<row >
<entry > jp2avi.dll</entry>
<entry > ImagePower MJPEG2000 (IPJ2)</entry>
<entry > d860a11766da0d0ea064672c6833768b</entry>
<entry > <option > -vf flip</option> </entry>
</row>
<row >
<entry > m3jp2k32.dll</entry>
<entry > Morgan MJPEG2000 (MJ2C)</entry>
<entry > f3c174edcbaef7cb947d6357cdfde7ff</entry>
<entry > </entry>
</row>
<row >
<entry > m3jpeg32.dll</entry>
<entry > Morgan Motion JPEG Codec (MJPG)</entry>
<entry > 1cd13fff5960aa2aae43790242c323b1</entry>
<entry > </entry>
</row>
<row >
<entry > mpg4c32.dll</entry>
<entry > Microsoft MPEG-4 v1/v2</entry>
<entry > b5791ea23f33010d37ab8314681f1256</entry>
<entry > </entry>
</row>
<row >
<entry > tsccvid.dll</entry>
<entry > TechSmith Camtasia Screen Codec (TSCC)</entry>
<entry > 8230d8560c41d444f249802a2700d1d5</entry>
<entry > </entry>
</row>
<row >
<entry > vp31vfw.dll</entry>
<entry > On2 Open Source VP3 Codec (VP31)</entry>
<entry > 845f3590ea489e2e45e876ab107ee7d2</entry>
<entry > </entry>
</row>
<row >
<entry > vp4vfw.dll</entry>
<entry > On2 VP4 Personal Codec (VP40)</entry>
<entry > fc5480a482ccc594c2898dcc4188b58f</entry>
<entry > </entry>
</row>
<row >
<entry > vp6vfw.dll</entry>
<entry > On2 VP6 Personal Codec (VP60)</entry>
<entry > 04d635a364243013898fd09484f913fb</entry>
2007-09-27 21:53:57 +00:00
<entry > </entry>
2006-09-27 08:59:17 +00:00
</row>
<row >
<entry > vp7vfw.dll</entry>
<entry > On2 VP7 Personal Codec (VP70)</entry>
<entry > cb4cc3d4ea7c94a35f1d81c3d750bc8d</entry>
<entry > falscher FourCC?</entry>
</row>
<row >
<entry > ViVD2.dll</entry>
<entry > SoftMedia ViVD V2 Codec VfW (GXVE)</entry>
<entry > a7b4bf5cac630bb9262c3f80d8a773a1</entry>
<entry > </entry>
</row>
</tbody>
</tgroup>
</informaltable>
2006-10-30 16:59:40 +00:00
Die erste Spalte enthält die Codec-Namen, die nach dem Parameter
<literal > codec</literal> übergeben werden sollten, wie:
2006-09-27 08:59:17 +00:00
<option > -xvfwopts codec=divx.dll</option> .
Der FourCC-Code, der von jedem Codec verwendet wird, steht in Klammern.
</para>
<informalexample >
<para >
Ein Beispiel mit VP3-Kompression:
<screen > mencoder dvd://2 -o title2.avi -ovc vfw -xvfwopts codec=vp31vfw.dll -oac copy</screen>
</para>
</informalexample>
</sect2>
</sect1>
<sect1 id= "menc-feat-vcd-dvd" >
2006-10-30 19:19:19 +00:00
<title > Verwendung von <application > MEncoder</application> zum Erzeugen VCD/SVCD/DVD-konformer Dateien.</title>
2006-09-27 08:59:17 +00:00
<sect2 id= "menc-feat-vcd-dvd-constraints" >
2006-10-30 16:59:40 +00:00
<title > Formatbeschränkungen</title>
2006-09-27 08:59:17 +00:00
<para >
<application > MEncoder</application> ist in der Lage, MPEG-Dateien im VCD-, SCVD-
und DVD-Format durch Verwendung der
<systemitem class= "library" > libavcodec</systemitem> -Programmbibliothek
zu erzeugen.
2006-10-30 16:59:40 +00:00
Diese Dateien können danach im Zusammenhang mit
2006-09-27 08:59:17 +00:00
<ulink url= "http://www.gnu.org/software/vcdimager/vcdimager.html" > vcdimager</ulink>
oder
<ulink url= "http://dvdauthor.sourceforge.net/" > dvdauthor</ulink>
zum Erzeugen von Disks verwendet werden, die auf einem Standard Set-Top-Player
2006-10-30 16:59:40 +00:00
abgespielt werden können.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Die Formate DVD, SVCD und VCD sind starken Beschränkungen unterworfen.
Es ist nur eine kleine Auswahl an encodierten Bildgrößen und Seitenverhältnissen
verfügbar.
Wenn dein Film nicht bereits die Anforderungen erfüllt, musst du das Bild
skalieren, zuschneiden oder schwarze Ränder hinzufügen, um es konform zu machen.
2006-09-27 08:59:17 +00:00
</para>
<sect3 id= "menc-feat-vcd-dvd-constraints-resolution" >
2006-10-30 16:59:40 +00:00
<title > Formatbeschränkungen</title>
2006-09-27 08:59:17 +00:00
<informaltable frame= "all" >
<tgroup cols= "9" >
<thead >
<row >
<entry > Format</entry>
2006-10-30 16:59:40 +00:00
<entry > Auflösung</entry>
2006-09-27 08:59:17 +00:00
<entry > V. Codec</entry>
<entry > V. Bitrate</entry>
<entry > Samplerate</entry>
<entry > A. Codec</entry>
<entry > A. Bitrate</entry>
<entry > FPS</entry>
2006-10-30 16:59:40 +00:00
<entry > Seitenverhältnis</entry>
2006-09-27 08:59:17 +00:00
</row>
</thead>
<tbody >
<row >
<entry > NTSC DVD</entry>
<entry > 720x480, 704x480, 352x480, 352x240</entry>
<entry > MPEG-2</entry>
<entry > 9800 kbps</entry>
<entry > 48000 Hz</entry>
<entry > AC3,PCM</entry>
<entry > 1536 kbps (max)</entry>
<entry > 30000/1001, 24000/1001</entry>
2006-10-30 16:59:40 +00:00
<entry > 4:3, 16:9 (nur für 720x480)</entry>
2006-09-27 08:59:17 +00:00
</row>
<row >
<entry > NTSC DVD</entry>
<entry > 352x240<footnote id= 'fn-rare-resolutions' > <para >
2006-10-30 16:59:40 +00:00
Diese Auflösungen werden selten für DVDs verwendet, da sie von
ziemlch niedriger Qualität sind.</para> </footnote> </entry>
2006-09-27 08:59:17 +00:00
<entry > MPEG-1</entry>
<entry > 1856 kbps</entry>
<entry > 48000 Hz</entry>
<entry > AC3,PCM</entry>
<entry > 1536 kbps (max)</entry>
<entry > 30000/1001, 24000/1001</entry>
<entry > 4:3, 16:9</entry>
</row>
<row >
<entry > NTSC SVCD</entry>
<entry > 480x480</entry>
<entry > MPEG-2</entry>
<entry > 2600 kbps</entry>
<entry > 44100 Hz</entry>
<entry > MP2</entry>
<entry > 384 kbps (max)</entry>
<entry > 30000/1001</entry>
<entry > 4:3</entry>
</row>
<row >
<entry > NTSC VCD</entry>
<entry > 352x240</entry>
<entry > MPEG-1</entry>
<entry > 1150 kbps</entry>
<entry > 44100 Hz</entry>
<entry > MP2</entry>
<entry > 224 kbps</entry>
<entry > 24000/1001, 30000/1001</entry>
<entry > 4:3</entry>
</row>
<row >
<entry > PAL DVD</entry>
<entry > 720x576, 704x576, 352x576, 352x288</entry>
<entry > MPEG-2</entry>
<entry > 9800 kbps</entry>
<entry > 48000 Hz</entry>
<entry > MP2,AC3,PCM</entry>
<entry > 1536 kbps (max)</entry>
<entry > 25</entry>
2006-10-30 16:59:40 +00:00
<entry > 4:3, 16:9 (nur für 720x576)</entry>
2006-09-27 08:59:17 +00:00
</row>
<row >
<entry > PAL DVD</entry>
<entry > 352x288<footnoteref linkend= 'fn-rare-resolutions' /> </entry>
<entry > MPEG-1</entry>
<entry > 1856 kbps</entry>
<entry > 48000 Hz</entry>
<entry > MP2,AC3,PCM</entry>
<entry > 1536 kbps (max)</entry>
<entry > 25</entry>
<entry > 4:3, 16:9</entry>
</row>
<row >
<entry > PAL SVCD</entry>
<entry > 480x576</entry>
<entry > MPEG-2</entry>
<entry > 2600 kbps</entry>
<entry > 44100 Hz</entry>
<entry > MP2</entry>
<entry > 384 kbps (max)</entry>
<entry > 25</entry>
<entry > 4:3</entry>
</row>
<row >
<entry > PAL VCD</entry>
<entry > 352x288</entry>
<entry > MPEG-1</entry>
<entry > 1152 kbps</entry>
<entry > 44100 Hz</entry>
<entry > MP2</entry>
<entry > 224 kbps</entry>
<entry > 25</entry>
<entry > 4:3</entry>
</row>
</tbody>
</tgroup>
</informaltable>
<para >
2006-10-30 16:59:40 +00:00
Wenn ein Film ein 2.35:1 Seitenverhältnis hat (die meisten aktuellen Action-Filme),
wirst du schwarze Ränder hinzufügen oder den Film auf 16:9 zuschneiden müssen,
2006-09-27 08:59:17 +00:00
um eine DVD oder VCD herzustellen.
2006-10-30 16:59:40 +00:00
Wenn du schwarze Ränder hinzufügst, versuche diese an 16-Pixel-Rändern
auszurichten, um den Einfluß auf die Encodier-Performance zu minimieren.
Zum Glück besitzen DVDs eine ausreichend hohe Bitrate, damit du dich
2006-09-27 08:59:17 +00:00
nicht zu sehr um die Encodier-Effizienz sorgen musst. SVCD
2006-10-30 16:59:40 +00:00
und VCD jedoch sind höchst mager an Bitrate und erfordern Aufwand, um akzeptable
Qualität zu erreichen.
2006-09-27 08:59:17 +00:00
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-constraints-gop" >
2006-10-30 16:59:40 +00:00
<title > GOP-Größenbeschränkungen</title>
2006-09-27 08:59:17 +00:00
<para >
DVD, VCD und SVCD zwingen dich auch zu relativ niedrigen
2006-10-30 16:59:40 +00:00
GOP-Größen (Group of Pictures).
Für Material mit 30 fps ist die größte erlaubte GOP-Größe 18.
Für 25 oder 24 fps ist das Maximum 15.
Die GOP-Größe wird mittels der Option <option > keyint</option> gesetzt.
2006-09-27 08:59:17 +00:00
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-constraints-bitrate" >
2006-10-30 16:59:40 +00:00
<title > Bitraten-Beschränkungen</title>
2006-09-27 08:59:17 +00:00
<para >
VCD-Video muss bei CBR 1152 kbps sein.
2006-10-30 16:59:40 +00:00
Zu dieser nach oben begrenzten Einschränkung kommt auch noch eine
extrem niedrige vbv-Puffergröße von 327 Kilobit.
2006-09-27 08:59:17 +00:00
SVCD erlaubt das Variieren der Video-Bitraten auf bis zu 2500 kbps,
2006-10-30 16:59:40 +00:00
und eine etwas weniger restriktive vbv-Puffergröße von 917 Kilobit
2006-09-27 08:59:17 +00:00
ist erlaubt.
2006-10-30 16:59:40 +00:00
DVD-Video-Bitraten können sich bis auf irgendwo um die 9800 kbps
einpegeln (wenngleich typische Bitraten etwa halb so groß sind),
und die vbv-Puffergröße ist 1835 Kilobit.
2006-09-27 08:59:17 +00:00
</para>
</sect3>
</sect2>
<sect2 id= "menc-feat-vcd-dvd-output" >
<title > Output-Optionen</title>
<para >
<application > MEncoder</application> besitzt Optionen zur Kontrolle des
Output-Formats.
2006-10-30 16:59:40 +00:00
Durch das Verwenden dieser Optionen können wir ihn anweisen, den
2006-09-27 08:59:17 +00:00
korrekten Dateityp zu erzeugen.
</para>
<para >
2006-10-30 16:59:40 +00:00
Die Optionen für VCD und SVCD werden xvcd und xsvcd genannt, weil sie
2006-09-27 08:59:17 +00:00
erweiterte Formate sind.
2006-10-30 16:59:40 +00:00
Sie sind nicht strikt Standard-konform, hauptsächlich weil der Output
keine Scan-Offsets enthält.
2006-09-27 08:59:17 +00:00
Wenn du ein SVCD-Image generieren musst, solltest du die Output-Datei
dem
<ulink url= "http://www.gnu.org/software/vcdimager/vcdimager.html" > vcdimager</ulink>
2006-10-30 16:59:40 +00:00
übergeben.
2006-09-27 08:59:17 +00:00
</para>
<para >
VCD:
<screen > -of mpeg -mpegopts format=xvcd</screen>
</para>
<para >
SVCD:
<screen > -of mpeg -mpegopts format=xsvcd</screen>
</para>
<para >
2006-11-09 15:05:51 +00:00
DVD (mit Zeitstempeln für jeden Frame, wenn möglich):
<screen > -of mpeg -mpegopts format=dvd:tsaf</screen>
2006-09-27 08:59:17 +00:00
</para>
<para >
DVD mit NTSC-Pullup:
2006-11-09 15:05:51 +00:00
<screen > -of mpeg -mpegopts format=dvd:tsaf:telecine -ofps 24000/1001</screen>
2006-09-27 08:59:17 +00:00
Dies erlaubt 24000/1001 fps progressive-Inhalt bei 30000/1001
2006-10-30 16:59:40 +00:00
fps encodiert zu werden, wobei die DVD-Konformität erhalten bleibt.
2006-09-27 08:59:17 +00:00
</para>
<sect3 id= "menc-feat-vcd-dvd-output-aspect" >
2006-10-30 16:59:40 +00:00
<title > Seitenverhältnis</title>
2006-09-27 08:59:17 +00:00
<para >
2006-10-30 16:59:40 +00:00
Der Parameter für das Seitenverhältnis von <option > -lavcopts</option> wird zum Encodieren
des Seitenverhältnisses einer Datei verwendet.
Während des Playbacks wird das Seitenverhältnis dazu benutzt, die korrekte
Größe des Videos wieder herzustellen.
2006-09-27 08:59:17 +00:00
</para>
<para >
16:9 oder "Breitbild"
<screen > -lavcopts aspect=16/9</screen>
</para>
<para >
4:3 oder "Vollbild"
<screen > -lavcopts aspect=4/3</screen>
</para>
<para >
2.35:1 oder "Cinemascope" NTSC
<screen > -vf scale=720:368,expand=720:480 -lavcopts aspect=16/9</screen>
2006-10-30 16:59:40 +00:00
Um die korrekte Skalierungsgröße zu berechnen, verwende die
2006-09-27 08:59:17 +00:00
erweiterte NTSC-Breite von 854/2.35 = 368
</para>
<para >
2.35:1 oder "Cinemascope" PAL
2007-09-27 17:45:28 +00:00
<screen > -vf scale=720:432,expand=720:576 -lavcopts aspect=16/9</screen>
2006-10-30 16:59:40 +00:00
Um die korrekte Skalierungsgröße zu berechnen, verwende die
2006-09-27 08:59:17 +00:00
erweiterte PAL-Breite von 1024/2.35 = 432
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-a-v-sync" >
<title > Aufrechterhalten der A/V-Synchronisation</title>
<para >
2006-10-30 16:59:40 +00:00
Um die Audio-/Video-Synchronisation während der kompletten
2006-09-27 08:59:17 +00:00
Encodierung aufrechtzuerhalten, muss
<application > MEncoder</application> Frames auslassen oder duplizieren.
Dies funktioniert beim Muxen in eine AVI-Datei ziemlich gut,
2006-10-30 16:59:40 +00:00
aber meist schlägt das Aufrechterhalten der A/V-Synchronisation mit
2006-09-27 08:59:17 +00:00
anderen Muxern wie etwa MPEG garantiert fehl.
2006-10-30 16:59:40 +00:00
Dies ist der Grund, weshalb es nötig ist, den
<option > harddup</option> -Video-Filter am Ende der Filterkette anzuhängen,
2006-09-27 08:59:17 +00:00
um diese Art Problem zu vermeiden.
Du findest mehr technische Informationen zu <option > harddup</option>
im Abschnitt
2006-10-30 16:59:40 +00:00
<link linkend= "menc-feat-dvd-mpeg4-muxing-filter-issues" > Verbessern der Mux- und A/V-Synchronisationszuverlässigkeit</link>
2006-09-27 08:59:17 +00:00
oder in der Manpage.
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-output-srate" >
<title > Sampleraten-Konvertierung</title>
<para >
Wenn die Audio-Samplerate in der Originaldatei nicht dieselbe wie die
vom Zielformat angeforderte ist, wird eine Sampleraten-Konvertierung
erforderlich.
Dies wird erreicht, indem man die Option <option > -srate</option> und
den <option > -af lavcresample</option> Audio-Filter zusammen
anwedet.
</para>
<para >
DVD:
<screen > -srate 48000 -af lavcresample=48000</screen>
</para>
<para >
VCD und SVCD:
<screen > -srate 44100 -af lavcresample=44100</screen>
</para>
</sect3>
</sect2>
<sect2 id= "menc-feat-vcd-dvd-lavc" >
<title > Verwenden des libavcodec zur VCD/SVCD/DVD-Encodierung</title>
<sect3 id= "menc-feat-vcd-dvd-lavc-intro" >
2006-10-30 16:59:40 +00:00
<title > Einführung</title>
2006-09-27 08:59:17 +00:00
<para >
<systemitem class= "library" > libavcodec</systemitem> kann verwendet
werden, um ein VCD/SVCD/DVD-konformes Video durch die Anwendung der
passenden Optionen zu erzeugen.
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-lavc-options" >
<title > lavcopts</title>
<para >
Dies ist eine Liste von Feldern in <option > -lavcopts</option> , die du
2006-10-30 16:59:40 +00:00
möglicherweise ändern musst, um einen für VCD, SVCD
2006-09-27 08:59:17 +00:00
oder DVD konformen Film herzustellen:
</para>
<itemizedlist >
<listitem >
<para >
<emphasis role= "bold" > acodec</emphasis> :
2006-10-30 16:59:40 +00:00
<option > mp2</option> für VCD, SVCD oder PAL DVD;
<option > ac3</option> wird am häufigsten für DVD verwendet.
PCM-Audio kann auch für DVD verwendet werden, aber dies ist meistens
2006-09-27 08:59:17 +00:00
eine riesen Platzverschwendung.
2006-10-30 16:59:40 +00:00
Beachte, dass MP3-Audio nicht konform für irgendeines dieser Formate
2006-09-27 08:59:17 +00:00
ist, aber Player haben oft ohnehin kein Problem, es abzuspielen.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > abitrate</emphasis> :
2006-10-30 16:59:40 +00:00
224 für VCD; bis zu 384 für SVCD; bis zu 1536 für DVD, aber
übliche Werte reichen von 192 kbps für Stereo bis 384 kbps für
2006-09-27 08:59:17 +00:00
5.1-Kanal-Sound.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > vcodec</emphasis> :
2006-10-30 16:59:40 +00:00
<option > mpeg1video</option> für VCD;
<option > mpeg2video</option> für SVCD;
<option > mpeg2video</option> wird gewöhnlich für DVD verwendet, man kann aber auch
<option > mpeg1video</option> für CIF-Auflösungen verwenden.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > keyint</emphasis> :
2006-10-30 16:59:40 +00:00
Angewandt, um die GOP-Größe zu setzen.
18 für Material mit 30fps oder 15 für Material mit 25/24 fps.
2006-09-27 08:59:17 +00:00
Kommerzielle Hersteller scheinen Keyframe-Intervalle von 12 zu bevorzugen.
2006-10-30 16:59:40 +00:00
Es ist möglich, dies viel größer zu machen und dennoch die Kompatibilität
2006-09-27 08:59:17 +00:00
zu den meisten Player zu behalten.
Ein <option > keyint</option> von 25 sollte nie irgendwelche Probleme machen.
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > vrc_buf_size</emphasis> :
2006-10-30 16:59:40 +00:00
327 für VCD, 917 für SVCD und 1835 für DVD.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > vrc_minrate</emphasis> :
2006-10-30 16:59:40 +00:00
1152 für VCD. kann für SVCD und DVD so gelassen werden.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > vrc_maxrate</emphasis> :
2006-10-30 16:59:40 +00:00
1152 für VCD; 2500 für SVCD; 9800 für DVD.
Für SVCD und DVD könntest du niedrigere Werte verwenden, abhängig von
deinen persönlichen Vorlieben und Anforderungen.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
<listitem >
<para >
<emphasis role= "bold" > vbitrate</emphasis> :
2006-10-30 16:59:40 +00:00
1152 für VCD;
bis zu 2500 für SVCD;
bis zu 9800 für DVD.
Für letztere zwei Formate sollte vbitrate basierend auf persönliche
2006-09-27 08:59:17 +00:00
Vorlieben gesetzt werden.
Zum Beispiel, wenn du darauf bestehst, 20 Stunden oder so passend auf
2006-10-30 16:59:40 +00:00
eine DVD zu bringen, könntest du vbitrate=400 benutzen.
Die sich daraus ergebende Video-Qualität würde womöglich äußerst mies.
Wenn du versuchst, die maximal mögliche Qualität auf eine DVD zu quetschen,
2006-09-27 08:59:17 +00:00
nimm vbitrate=9800, aber sei gewarnt, dass dich dies zu weniger als
2006-10-30 16:59:40 +00:00
einer Stunde Video auf einer Single-Layer DVD zwingen würde.
2006-09-27 08:59:17 +00:00
</para>
</listitem>
2007-09-27 14:45:50 +00:00
<listitem >
<para >
2007-09-27 21:22:26 +00:00
<emphasis role= "bold" > vstrict</emphasis> :
2007-09-27 14:45:50 +00:00
<option > vstrict</option> =0 sollte verwendet werden, um DVDs zu erstellen.
Ohne diese Option erzeugt <application > MPlayer</application> einen Stream, der von
manchen standalone DVD-Playern nicht korrekt decodiert werden kann.
</para>
</listitem>
2006-09-27 08:59:17 +00:00
</itemizedlist>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-lavc-examples" >
<title > Beispiele</title>
<para >
Dies ist eine typische Zusammenstellung von mindestens zu verwendenden
<option > -lavcopts</option> -Optionen zum Encodieren eines Videos:
</para>
<para >
VCD:
<screen > -lavcopts vcodec=mpeg1video:vrc_buf_size=327:vrc_minrate=1152:\
vrc_maxrate=1152:vbitrate=1152:keyint=15:acodec=mp2</screen>
</para>
<para >
SVCD:
<screen > -lavcopts vcodec=mpeg2video:vrc_buf_size=917:vrc_maxrate=2500:vbitrate=1800:\
keyint=15:acodec=mp2</screen>
</para>
<para >
DVD:
<screen > -lavcopts vcodec=mpeg2video:vrc_buf_size=1835:vrc_maxrate=9800:vbitrate=5000:\
2007-09-27 14:45:50 +00:00
keyint=15:vstrict=0:acodec=ac3</screen>
2006-09-27 08:59:17 +00:00
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-lavc-advanced" >
<title > Erweiterte Optionen</title>
<para >
2006-10-30 16:59:40 +00:00
Für das Encodieren höherer Qualität könntest du auch qualitätssteigernde
Optionen an lavcopts anfügen, wie etwa <option > trell</option> ,
2006-09-27 08:59:17 +00:00
<option > mbd=2</option> und weitere.
Beachte, dass <option > qpel</option> und <option > v4mv</option> , obwohl
2006-10-30 16:59:40 +00:00
oft bei MPEG-4 nützlich, nicht auf MPEG-1 oder MPEG-2 anwendbar sind.
Außerdem, wenn du versuchst, eine sehr hochwertige DVD-Encodierung zu
machen, kann es nützlich sein, <option > dc=10</option> an lavcopts
anzufügen.
Wobei dies helfen könnte, das Auftreten von Blöcken in fahl-farbenen
2006-09-27 08:59:17 +00:00
Bereichen zu reduzieren.
2006-10-30 16:59:40 +00:00
Zusammenfassend ist dies ein Beispiel einer Zusammenstellung von lavcopts für
für eine höherwertige DVD:
2006-09-27 08:59:17 +00:00
</para>
<para >
<screen > -lavcopts vcodec=mpeg2video:vrc_buf_size=1835:vrc_maxrate=9800:vbitrate=8000:\
keyint=15:trell:mbd=2:precmp=2:subcmp=2:cmp=2:dia=-10:predia=-10:cbp:mv0:\
2007-09-27 14:45:50 +00:00
vqmin=1:lmin=1:dc=10:vstrict=0</screen>
2006-09-27 08:59:17 +00:00
</para>
</sect3>
</sect2>
<sect2 id= "menc-feat-vcd-dvd-audio" >
<title > Encodieren von Audio</title>
<para >
2006-10-30 16:59:40 +00:00
VCD und SVCD unterstützen MPEG-1 Layer II Audio, indem sie einen
2006-09-27 08:59:17 +00:00
MP2-Encoder von
<systemitem class= "library" > toolame</systemitem> ,
<systemitem class= "library" > twolame</systemitem> ,
oder <systemitem class= "library" > libavcodec</systemitem>
verwenden.
Der libavcodec MP2 ist weit davon entfernt, so gut zu sein wie die
2006-10-30 16:59:40 +00:00
anderen zwei Bibliotheken, dennoch sollte er immer verfügbar sein.
VCD unterstützt nur Audio mit konstanten Bitraten (CBR) wogegen SVCD
auch variable Bitraten (VBR) unterstützt.
2006-09-27 08:59:17 +00:00
Sei vorsichtig, wenn du VBR benutzt, weil einige schlechte
2006-10-30 16:59:40 +00:00
Standalone-Player diese nicht so gut unterstützen könnten.
2006-09-27 08:59:17 +00:00
</para>
<para >
2006-10-30 16:59:40 +00:00
Für DVD-Audio wird der AC3-Codec von
2006-09-27 08:59:17 +00:00
<systemitem class= "library" > libavcodec</systemitem>
verwendet.
</para>
<sect3 id= "menc-feat-vcd-dvd-audio-toolame" >
<title > toolame</title>
<para >
2006-10-30 16:59:40 +00:00
Für VCD und SVCD:
2006-09-27 08:59:17 +00:00
<screen > -oac toolame -toolameopts br=224</screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-audio-twolame" >
<title > twolame</title>
<para >
2006-10-30 16:59:40 +00:00
Für VCD und SVCD:
2006-09-27 08:59:17 +00:00
<screen > -oac twolame -twolameopts br=224</screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-audio-lavc" >
<title > libavcodec</title>
<para >
2006-10-30 16:59:40 +00:00
Für DVD mit 2-Kanal-Sound:
2006-09-27 08:59:17 +00:00
<screen > -oac lavc -lavcopts acodec=ac3:abitrate=192</screen>
</para>
<para >
2006-10-30 16:59:40 +00:00
Für DVD mit 5.1-Kanal-Sound:
2006-09-27 08:59:17 +00:00
<screen > -channels 6 -oac lavc -lavcopts acodec=ac3:abitrate=384</screen>
</para>
<para >
2006-10-30 16:59:40 +00:00
Für VCD und SVCD:
2006-09-27 08:59:17 +00:00
<screen > -oac lavc -lavcopts acodec=mp2:abitrate=224</screen>
</para>
</sect3>
</sect2>
<sect2 id= "menc-feat-vcd-dvd-all" >
<title > Zusammenfassung</title>
<para >
Diese Sektion zeigt einige komplette Befehle zum Erzeugen von
VCD/SVCD/DVD-konformen Videos.
</para>
<sect3 id= "menc-feat-vcd-dvd-all-pal-dvd" >
<title > PAL DVD</title>
<para >
2006-11-09 15:05:51 +00:00
<screen > mencoder -oac lavc -ovc lavc -of mpeg -mpegopts format=dvd:tsaf -vf scale=720:576,\
2006-09-27 08:59:17 +00:00
harddup -srate 48000 -af lavcresample=48000 -lavcopts vcodec=mpeg2video:\
2007-09-27 14:45:50 +00:00
vrc_buf_size=1835:vrc_maxrate=9800:vbitrate=5000:keyint=15:vstrict=0:acodec=ac3:\
2006-09-27 08:59:17 +00:00
abitrate=192:aspect=16/9 -ofps 25 \
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-all-ntsc-dvd" >
<title > NTSC DVD</title>
<para >
2006-11-09 15:05:51 +00:00
<screen > mencoder -oac lavc -ovc lavc -of mpeg -mpegopts format=dvd:tsaf -vf scale=720:480,\
2006-06-05 05:02:47 +00:00
harddup -srate 48000 -af lavcresample=48000 -lavcopts vcodec=mpeg2video:\
2007-09-27 14:45:50 +00:00
vrc_buf_size=1835:vrc_maxrate=9800:vbitrate=5000:keyint=18:vstrict=0:acodec=ac3:\
2006-06-05 05:02:47 +00:00
abitrate=192:aspect=16/9 -ofps 30000/1001 \
2006-09-27 08:59:17 +00:00
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-all-pal-ac3-copy" >
<title > PAL AVI mit enthaltenem AC3 Audio nach DVD</title>
<para >
Hat die Quelle bereits AC3-Audio, nimm -oac copy anstatt es
erneut zu encodieren.
2006-11-09 15:05:51 +00:00
<screen > mencoder -oac copy -ovc lavc -of mpeg -mpegopts format=dvd:tsaf -vf scale=720:576,\
2006-06-05 05:02:47 +00:00
harddup -lavcopts vcodec=mpeg2video:vrc_buf_size=1835:vrc_maxrate=9800:\
2007-09-27 14:45:50 +00:00
vbitrate=5000:keyint=15:vstrict=0:aspect=16/9 -ofps 25 \
2006-09-27 08:59:17 +00:00
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-all-ntsc-ac3-copy" >
<title > NTSC AVI mit AC3-Ton nach DVD</title>
<para >
Hat die Quelle bereits AC3-Audio und ist NTSC @ 24000/1001 fps:
2006-11-09 15:05:51 +00:00
<screen > mencoder -oac copy -ovc lavc -of mpeg -mpegopts format=dvd:tsaf:telecine \
2006-06-05 05:02:47 +00:00
-vf scale=720:480,harddup -lavcopts vcodec=mpeg2video:vrc_buf_size=1835:\
2007-09-27 14:45:50 +00:00
vrc_maxrate=9800:vbitrate=5000:keyint=15:vstrict=0:aspect=16/9 -ofps 24000/1001 \
2006-09-27 08:59:17 +00:00
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-all-pal-svcd" >
<title > PAL SVCD</title>
<para >
<screen > mencoder -oac lavc -ovc lavc -of mpeg -mpegopts format=xsvcd -vf \
2006-06-05 05:02:47 +00:00
scale=480:576,harddup -srate 44100 -af lavcresample=44100 -lavcopts \
vcodec=mpeg2video:mbd=2:keyint=15:vrc_buf_size=917:vrc_minrate=600:\
vbitrate=2500:vrc_maxrate=2500:acodec=mp2:abitrate=224 -ofps 25 \
2006-09-27 08:59:17 +00:00
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-all-ntsc-svcd" >
<title > NTSC SVCD</title>
<para >
<screen > mencoder -oac lavc -ovc lavc -of mpeg -mpegopts format=xsvcd -vf \
2006-06-05 05:02:47 +00:00
scale=480:480,harddup -srate 44100 -af lavcresample=44100 -lavcopts \
vcodec=mpeg2video:mbd=2:keyint=18:vrc_buf_size=917:vrc_minrate=600:\
vbitrate=2500:vrc_maxrate=2500:acodec=mp2:abitrate=224 -ofps 30000/1001 \
2006-09-27 08:59:17 +00:00
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-all-pal-vcd" >
<title > PAL VCD</title>
<para >
<screen > mencoder -oac lavc -ovc lavc -of mpeg -mpegopts format=xvcd -vf \
2006-06-05 05:02:47 +00:00
scale=352:288,harddup -srate 44100 -af lavcresample=44100 -lavcopts \
vcodec=mpeg1video:keyint=15:vrc_buf_size=327:vrc_minrate=1152:vbitrate=1152:\
vrc_maxrate=1152:acodec=mp2:abitrate=224 -ofps 25 \
2006-09-27 08:59:17 +00:00
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
<sect3 id= "menc-feat-vcd-dvd-all-ntsc-vcd" >
<title > NTSC VCD</title>
<para >
<screen > mencoder -oac lavc -ovc lavc -of mpeg -mpegopts format=xvcd -vf \
2006-06-05 05:02:47 +00:00
scale=352:240,harddup -srate 44100 -af lavcresample=44100 -lavcopts \
vcodec=mpeg1video:keyint=18:vrc_buf_size=327:vrc_minrate=1152:vbitrate=1152:\
vrc_maxrate=1152:acodec=mp2:abitrate=224 -ofps 30000/1001 \
2006-09-27 08:59:17 +00:00
-o <replaceable > movie.mpg</replaceable> <replaceable > movie.avi</replaceable> </screen>
</para>
</sect3>
2006-06-05 05:02:47 +00:00
2006-09-27 08:59:17 +00:00
</sect2>
2006-06-05 05:02:47 +00:00
2006-09-27 08:59:17 +00:00
</sect1>
2006-06-05 05:02:47 +00:00
</chapter>