codec identifiers in anidb

Forum for discussing AniDB rules & standards. No small talk!

Moderator: AniDB

Locked
Rar
AniDB Staff
Posts: 1471
Joined: Fri Mar 12, 2004 2:41 pm
Location: UK
Contact:

codec identifiers in anidb

Post by Rar »

Err... this was just a quick suggestion to change some of the existing codec identifiers in anidb to make more sense, but has spiralled into a big overview of video encoding. I'm not an expert, if I've made mistakes, tell me. Blanks are where I've been lazy.

Video codec identifiers in anidb

1>unknown Used if the codec is not known (generally due to lazy file adders or people who don't know how to deal with non-avi containers), or if the codec is known but not in the list.
2>DivX UNK If you somehow know it's divx, but not the version, this might be used. Seems difficult to believe you'd know it was Divx and not some other ASP codec, but not know the version.
3>DivX3
5>DivX4
7>DivX5
17>XviD
9>MPG1 (vcd) From wikipedia: "VCD display resolution is 352x240 pixels (NTSC) or 352x288 pixels (PAL), approximately one quarter of full TV resolution. VCD video is in MPEG-1 format; audio is encoded as MPEG Layer 2 (MP2); video is stored at 1150 kilobits per second, audio at 224 kbit/s." Basically a specific limitation of the MPEG standard, which can be directly ripped to file.
10>MPG2 (svcd) From wikipedia: "SVCDs store digital video in MPEG-2 format at a resolution of 480x480 pixels (for NTSC) or 480x576 pixels (for PAL)... Video may be encoded at a variable bit rate, up to 2.6 megabits per second. Audio is stored in MPEG Layer 2 format, with a bit rate varying from 128 to 384 kilobits per second." Again, a specific limitation of the MPEG-2 standard.
11>MPG4 MPEG-4 is a collection of standards, that covers lots of things beyond video. Most of the codecs in this list are based on MPEG-4 so this is used when the file uses one that's not in the list (eg lavc).
18>MS MP4x The non-standard implimentation of MPEG-4 Part 2 by Microsoft, precursor to the current wmv format. It was reverse engineered to create DivX ;-)
12>ASF This is a Microsoft patented container for their wmv and wma streams, not a video codec.
13>MOV This is a Quicktime container format that can hold a wide variety of data, not a video codec.
14>RM (also ram) RM is a RealNetworks container, not a video codec. This is generally used for versions of RealVideo prior to 9.
20>RV9 From Doom9: "RealVideo 9 and 10 are video codecs developed by RealNetworks, with MMX/SSE2/SSE3 optimizations from Intel, and AltiVec (OS X) optimizations from RealNetworks. RV9 and 10 are bitstream compatible, RV 10 is an encoder side improvement to gain quality by letting the encoder spend more time making wise decisions.... RV9/10 is not based on wavelets, and not on fractals, and does not include inherent pre-filtering. Which technology is its foundation? Since it is not open source and not a standard, I can't say, but it's nothing magic. It was not optimized for low bitrates, but to avoid compression artifacts at any bitrate." Generally used by French, Québécois, and other fools.
15>Vivo From wikipedia: "The Vivo platform was a known player when streaming media was in its infancy and was deployed mainly on erotic sites during the mid 1990s... Vivo format is based upon H.263 codec. It uses inter-frame coding, but does not insert any key frames, except at the beginning of the clip, which effectively disables the possibility of seeking."
21>IV5 Perhaps meant to be Indeo 5, and early vfw codec. Part of a long series of codecs by Intel, primarily used for streaming.
16>DVD I presume this is some kind of MPEG-2 misunderstanding, there is no 'dvd' video codec.
22>H264/AVC
19>WMV9 (also WMV3)

Some rework needed, perhaps:
'Unknown/Other' <- Unknown, ASF, MOV
'Legacy' <- MS MP4x, RM (also ram), IV5, Vivo (and h263, cinepak, etcetc)
'MPEG-1' <- MPG1 (vcd)
'MPEG-2' <- DVD, MPG2 (svcd)
'DivX3'
'DivX4'
'DivX5'
'Xvid'
'ASP Other' <- DivX UNK, MPG4 (and lavc, 3ivx, etcetc)
'H.264/AVC'
'RealVideo 9/10'
'Windows Media Video'
What to identify separately and what to combine is a fun issue, but hey. Future additions, depending on encoder usage, might be Dirac, VP7, Theora, etc.

Audio codec identifiers in anidb

1>unknown If you don't know, don't care, or don't have the option.
2>AC3 Dolby Digital audio.
3>DivX Audio An early hack of the WMA codec by Microsoft, would correctly include the ;-)
4>MP3 UNK Reasonably pointless.
5>MP3 Used for CBR mp3 audio. Specified in MPEG-1 Part 3 Layer 3.
6>MP3 VBR Used for VBR mp3 audio.
7>MSAudio Some other WMA type thing?
8>Ogg Vorbis The mighty ogg.
9>AAC Specifed in MPEG-2 Layer 3, and extended in MPEG-4 Layer 3.
10>PCM Uncompressed digital audio.

Mostly fine, a few suggestions:
-Rename 'Ogg Vorbis' to 'Vorbis'
-Rename 'DivX Audio' to 'WMA [and DivX ;-) Audio]'
-Remove 'MP3 UNK' and move any files with it to 'Unknown'
-Rename 'MP3' to 'MP3 CBR'
-Add 'MP2'
Seems likely additions may be needed in the future depending on the uptake of other audio formats.


A chart of stuff

-MPEG-1 (1992) (wikipedia)
--MPEG-1 Part 2 (Video)
---SDL MPEG (SMPEG) (wikipedia)
---VCD (1993) (wikipedia)
--MPEG-1 Part 3 (Audio)
---MPEG-1 Part 3 Layer 2 (MP2)
---MPEG-1 Part 3 Layer 3 (MP3) (wikipedia)

-MPEG-2 (1994) (wikipedia)
--MPEG-2 Part 2 (Video)
---DVD (wikipedia)
---SVCD (wikipedia)
--MPEG-2 Part 3 (Audio)
---AAC (wikipedia)

-MPEG-4 (1998) (wikipedia) (Doom9)
--MPEG-4 Part 2 (Video)
---Advanced Simple Profile (ASP)
----DivX4
----DivX5
----Xvid
----in ffmpeg (libavcodec ie lavc)
----3ivx
----many others
---Microsoft based non-standard implementations
----MSMPEG4
----DivX ;-) (DivX3)
----MSMPEG4v2
----Windows Media Video 7 (WMV1)
----Windows Media Video 8 (WMV2)
----Windows Media Video 9 (WMV3)
--MPEG-4 Part 2 (Audio)
---HE-AAC
--MPEG-4 Part 10 (also known as AVC or H.264) (May 2003)
---x264
---NeroDigital AVC
---MainConcept
---Moonlight
---many others

-RealNetworks (wikipedia)
--RealVideo
---In player version 4 and 5, by rv10.dll (Feb 1997)
---'G2' in player version 6 and 7, by rv20.dll (Apr 1999)
---In player version 8, by rv30.dll (May 2000)
---In player version 9 and 10, by rv40.dll (Apr 2002) (Doom9)
--RealAudio hodgepoge (wikipedia)
Amour
Posts: 640
Joined: Fri Oct 08, 2004 5:19 pm
Location: France

Post by Amour »

> -Rename 'MP3' to 'MP3 CBR'

No need. I prefer 'MP3' alone.

And I vote for the deletion of 'DivX UNK'. If you don't know exactly what it is, then leave it unknown.
nwa
AniDB Staff
Posts: 585
Joined: Sat Jun 07, 2003 10:51 am

Post by nwa »

what about DTS audio?
Rar
AniDB Staff
Posts: 1471
Joined: Fri Mar 12, 2004 2:41 pm
Location: UK
Contact:

Post by Rar »

nwa: Dunno. Should only add it if a reasonable number of releases use it. Wiki seems to suggest a bitrate of 1.5 megabits/second, which seems somewhat large for p2p.

amour: The problem is 'MP3' is a superset of 'MP3 VBR' and it's not very clear what that entry means unless to note the other one. The main reason it's useful differentiating at all is the dodgy avi handling of vbr audio.

Rar
Isochroma
Posts: 27
Joined: Sat Aug 28, 2004 2:31 am

suggestions

Post by Isochroma »

I did an encoding of Wonderful Days... original audio stream was 768kbps DTS. No transcoding, just straight transmux into mkv.

As for filetypes, how about just using the FourCC for video? Such an apporach makes much more sense that trying to define an arbitrary list of codecs. User friendly names can be mapped to the FourCCs, or they can be listed together as one string.
egg
Posts: 769
Joined: Tue Nov 11, 2003 7:17 am

Post by egg »

It was pointed out before [note this is only accessible to mods], the fourCC is not always reliable. Here are some excerpts:
wahaha wrote:This is somewhat related to Poll: XviD/DivX.

A single "divx"-4cc (as used in some anime-keep encodes) is a problem - for old files it could be DivX4 while it could aswell be DivX5. In such a case, set the codec to "DivX (unknown)", although it really is DivX5 for all newer encodes.

A suggestion for how to set the codec-value:
(Most single 4CCs in GSpot directly translate to the codec-entries in AniDB:)
divx -> DivX (Unknown)
div3 -> DivX3
div4 -> DivX4
dx50 -> DivX5
xvid -> XviD
wmv3 -> WMV9

However, if GSpot shows a second "xvid"-4cc after the slash, it should be set to xvid:
DX50/xvid -> XviD
divx/xvid -> XviD
[...]

If the second 4cc is "divx", set it to DivX5:
DX50/divx -> DivX5
[...]

Other values I've seen where I'm not sure what to set:
"div3/div4" -> I'd set it to DivX4 or DivX (Unknown)
"xvid/yv12" -> I'd set it to XviD
PetriW wrote:this is the current table used in AniDB O'Matic:
colums are: codec/compression in file, long name, short name, anidb id

Code: Select all

    ('div3',      'DivX 3 Low-Motion',  'DivX3',    '3'),
    ('div3/div3', 'DivX 3 Low-Motion',  'DivX3',    '3'),
    ('div4/div3', 'DivX 3 Fast-Motion', 'DivX3',    '3'),
    ('div5',      'DivX 5.0',           'DivX5',    '7'),
    ('dx50',      'DivX 5.0',           'DivX5',    '7'),
    ('xvid/dx50', 'DivX 5.0',           'DivX5',    '7'),
    ('divx/dx50', 'DivX 5.0',           'DivX5',    '7'),
    ('divx',      'DivX 4 (OpenDivX)',  'DivX4',    '5'),
    ('divx/divx', 'DivX 4 (OpenDivX)',  'DivX4',    '5'),
    ('xvid',      'XviD',               'XviD',    '17'),
    ('xvid/xvid', 'XviD',               'XviD',    '17'),
    ('xvid/divx', 'DivX 4 (OpenDivX)',  'DivX4',    '5'),
    ('mp42',      'S-Mpeg 4 version 2', 'MS MP4x', '18'),
    ('mp43',      'S-Mpeg 4 version 3', 'MS MP4x', '18')
AOM has certain rules to how it detemines what codec a file has. If a column is unknown it's assumed to be corrupt (anidb has several files like that) and the codec is predicted the same way GSpot does it, aka compression has priority then codec then known over unknown.
This table above was made by parsing over 15% of all avi files in AniDB fyi.
rowaasr13
Posts: 415
Joined: Sat Sep 27, 2003 4:57 am

Post by rowaasr13 »

PetriW's table much more correct.

DIV4 always were DivX 3 Fast-Motion. It is never DivX 4. And DIVX 4cc is DivX 4. Actually if DB is ever switched to 4cc, just add divs field along with it and then, as already suggested, map pairs on user-friendly names.
dinoex
Posts: 35
Joined: Wed Nov 17, 2004 8:28 pm
Contact:

Post by dinoex »

this is my stats of "ecoder/vcodec" pairs.

Code: Select all

count   ecoder/vcodec  (Anidb)
1403    xvid/XVID      (Xvid)
786     xvid/DX50      (Xvid or Divx5)
738     div3/DIV3      (Divx3)
538     divx/DX50      (Divx5)
394     xvid/DIVX      (Xvid or Divx4)
282     /XVID          (Xvid)
100     /DX50          (Xvid or Divx5)
87      divx/DIVX      (DivX4)
59      DX50/DX50      (Divx5)
48      div4/DIV3      (Divx4 or Divx3)
37      XVID/XVID      (Xvid)
32      DIVX/DX50      (Divx5)
30      /MPEG1         (mgp1)
28      WMV3/WMV3      (wmv9)
22      DIVX/DIVX      (Divx4)
20      wmv3/WMV3      (wmv9)
19      DIV3/DIV3      (Divx3)
17      yv12/DX50      (Divx5)
17      /MP43          (MS)
11      MP43/MP43      (MS)
9       div5/DIV5      (Divx5)
9       /WMV3          (wmv9)
5       /SVQ3          (unknown)
4       div5/DIV3      (Divx5 or Divx3)
3       yv12/XVID      (Xvid)
3       mp43/MP43      (ms)
3       divf/DIVX      (Divx4)
2       div6/DIV5      (Divx5)
2       div3/div3      (Divx3)
2       DIV4/DIV3      (Divx4 or Divx3)
2       /RV40          (RM)
2       /MP42          (MS)
2       /DIV3          (Divx3)
1       x264/H264      (H264/AVC)
1       mp42/MP42      (MS)
1       XVID/DX50      (Xvid or Divx5)
1       XVID/DIVX      (Xvid or Divx4)
1       MP42/MP42      (MS)
1       3ivx/3IV2      (unknown)
1       3iv2/3IV2      (unknown)
1       /avc1          (unknown)
1       /WMV1          (unknown)
1       /RV30          (rm)
1       (0)/DIVX       (Divx4)
What is the recommended mapping to anidb?

Back when I added "xvid/DX50" as "Divx5"
some mods asked to check for "xvid" first,
which is not matching the list posted by petriw above.
Last edited by dinoex on Wed Aug 17, 2005 5:19 pm, edited 1 time in total.
dinoex
Posts: 35
Joined: Wed Nov 17, 2004 8:28 pm
Contact:

Post by dinoex »

Here is my list of audio codecs

Code: Select all

count   codec           (Anidb)
4154    mp3             (mp3)
331     vorbis          (ogg/vorbis)
89      ffwmav2         (dvix Audio)
54      faad            (aac)
48      AC3             (ac3)
20      msadpcm         (pcm or msausdio)
13      ffwmav1         (divx audio)
10      pcm             (pcm)
9       wma9dmo         (msaudio)
3       racookwin       (unknown Real Audio) 
"msadpcm" is the only case of doubt here
it is listed in andb files as "unkown", "pcm" or "msaudio" ?

How should this codecs be set in andb?
Skywalka
Posts: 889
Joined: Tue Sep 16, 2003 7:57 pm

Post by Skywalka »

I think you shoudl use "layer" instead of "part" when it comes to MPEG and it's different parts ;-)

http://en.wikipedia.org/wiki/Mp3
The name is derived from "MPEG-1 Audio Layer 3"

All articles on wikipedia use it and I never heard it differently.
Rar
AniDB Staff
Posts: 1471
Joined: Fri Mar 12, 2004 2:41 pm
Location: UK
Contact:

Post by Rar »

Isochroma: Fortunately nuts do not make up a 'reasonable number of releases'.

dinoex: 4cc alone is a poor method of identifying codecs. Also, if you don't say what tool you're using, and why it gets confused between pcm and msaudio (which should be easy to distinguish) the data isn't of much use.

Skywalka: Try reading the post again. There's not point even correcting you.

Rar
dinoex
Posts: 35
Joined: Wed Nov 17, 2004 8:28 pm
Contact:

Post by dinoex »

this data was collected by using mplayer

the tool identify its as "msadpcm"

which can be read as "msaudio"
or as "PCM", dependend on what you prefer to sort it in.

Not sure if tehre is a difrfent to pcm,
but there is a diffrent to "msaudo" codec= wma9dmo

There is for now not much tools that will run
on non windows systems.
But any Info how to detect further differences is welcome.
Isochroma
Posts: 27
Joined: Sat Aug 28, 2004 2:31 am

Div6?

Post by Isochroma »

How about separating div6 from div5? I think that the quality difference between these two versions would make it desireable that users could identify them...
Bokoo

AC3 has 2 channel and 6 channel

Post by Bokoo »

AC3 has 2 channel and 6(5.1) channel
big difference, but there are not that many 6 channel audio anime
Locked