EEDI2

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
m (update link)
m (add Deep_color_tools category)
 
(7 intermediate revisions by one user not shown)
Line 1: Line 1:
{{FilterCat4|External_filters|Plugins|Restoration_filters|Deinterlacers}}
+
{{FilterCat6|External_filters|Plugins|Plugins_x64|Restoration_filters|Deinterlacers|Deep_color_tools}}
 
{{Filter3
 
{{Filter3
| {{Author/tritical}}
+
| {{Author/tritical}}, {{Author/HolyWu}}, {{Author/Asd-g}}
| v0.9.2
+
| v1.0.0
|
+
|[https://github.com/Asd-g/AviSynth-EEDI2/releases EEDI2-1.0.0.7z]
[http://web.archive.org/web/20151125175557/http://bengal.missouri.edu/~kes25c/EEDI2v092.zip EEDI2v092.zip]
+
[http://web.archive.org/web/20160304124723/https://filetea.me/t1st3BqcWqxQnCaa4Dqu1pe4g/dl EEDI2_092_ICL13.7z]
+
<!--[http://web.archive.org/web/20160227124555/https://filetea.me/t1sAPBJWv6pR2SyFt2BQ3iQ1A/dl EEDI2_092_ICL10.7z]-->
+
 
| Deinterlacing  
 
| Deinterlacing  
 
| [http://www.gnu.org/licenses/gpl-2.0.txt GPLv2]
 
| [http://www.gnu.org/licenses/gpl-2.0.txt GPLv2]
Line 14: Line 11:
 
== Description ==
 
== Description ==
 
[[EEDI2]] (Enhanced Edge Directed Interpolation) resizes an image by 2x in the vertical direction by copying the existing image to 2*y(n) and interpolating the missing field. It is intended for edge-directed interpolation for deinterlacing (i.e. not really made for resizing a normal image, but can do that as well).
 
[[EEDI2]] (Enhanced Edge Directed Interpolation) resizes an image by 2x in the vertical direction by copying the existing image to 2*y(n) and interpolating the missing field. It is intended for edge-directed interpolation for deinterlacing (i.e. not really made for resizing a normal image, but can do that as well).
 
+
<br>
*<tt>EEDI2_092_ICL13.7z</tt> is an optimized version built with Intel C++ Compiler 13. See [http://forum.doom9.org/showthread.php?t=173238 discussion].
+
 
<br>
 
<br>
 
== Requirements ==
 
== Requirements ==
*AviSynth 2.5.8 or [http://sourceforge.net/projects/avisynth2/ greater]
+
* [x86]: [[AviSynth+]] or [https://sourceforge.net/projects/avisynth2/ AviSynth 2.6]
*Supported color formats: [[YUY2]], [[YV12]]
+
* [x64]: [[AviSynth+]]
 +
* Supported color formats: [[Y8]], [[YV12]], [[YV16]], [[YV24]]
 +
**AviSynth+: all [[planar]] formats (8/10/12/14/16-bit, Y/YUV/RGB with or without alpha) are supported.
 +
<br>
 +
* [https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads Microsoft Visual C++ 2019 Redistributable Package (x86 / x64)]
 +
:<span style="color:red">***</span> <tt>vc_redist.x86.exe</tt> is required for <tt>EEDI2-x86</tt>
 +
:<span style="color:red">***</span> <tt>vc_redist.x64.exe</tt> is required for <tt>EEDI2-x64</tt>
 
<br>
 
<br>
  
Line 26: Line 28:
 
<br>
 
<br>
 
::{{Par2| |clip| }}
 
::{{Par2| |clip| }}
:::Input clip.
+
:::Input clip to process. It must be in 8..16-bit planar format with or without alpha.
 
<br>
 
<br>
 
::{{Par2|mthresh|int|10}}
 
::{{Par2|mthresh|int|10}}
Line 85: Line 87:
 
== Changelog ==
 
== Changelog ==
 
<pre>
 
<pre>
 +
  06/18/2020  v1.0.0
 +
 +
      - Initial release; port of the VapourSynth plugin
 +
      - 8-16bit all planar colorspace support
 +
      - Dropped YUY2 colorspace
 +
 
   06/07/2006  v0.9.2
 
   06/07/2006  v0.9.2
  
Line 115: Line 123:
 
!!width="150px"| Download
 
!!width="150px"| Download
 
!!width="150px"| Mirror
 
!!width="150px"| Mirror
 +
|-
 +
!v0.9.2 (x86_x64)
 +
|[https://github.com/avisynth-repository/EEDI2/releases/download/v0.9.2/EEDI2_092_32_64.7z EEDI2_092_32_64.7z]
 +
|[https://web.archive.org/web/20191106173125if_/http://www.iol.ie/%7Eschubert/gas/EEDI2_092_32_64.7z EEDI2_092_32_64.7z] /// [https://www.mediafire.com/file/8wzph49hp2uset6/EEDI2_092_32_64.7z/file MediaFire]
 
|-
 
|-
 
!v0.9.2
 
!v0.9.2
|<strike>[http://bengal.missouri.edu/~kes25c/EEDI2v092.zip EEDI2v092.zip]</strike>
+
|[http://web.archive.org/web/20140420183147if_/http://bengal.missouri.edu/~kes25c/EEDI2v092.zip EEDI2v092.zip]
|[http://web.archive.org/web/20140420183147/http://bengal.missouri.edu/~kes25c/EEDI2v092.zip EEDI2v092.zip]
+
|
 
|}
 
|}
 +
* x86/x84 version compiled by [https://forum.doom9.org/showthread.php?t=173259 Groucho2004].
 +
<!--[http://web.archive.org/web/20160304124723if_/https://filetea.me/t1st3BqcWqxQnCaa4Dqu1pe4g/dl EEDI2_092_ICL13.7z]-->
 +
<!--[http://web.archive.org/web/20160227124555if_/https://filetea.me/t1sAPBJWv6pR2SyFt2BQ3iQ1A/dl EEDI2_092_ICL10.7z]-->
 +
<!--*[http://forum.doom9.org/showthread.php?t=173238 Doom9 Forum] - EEDI2 0.9.2 built with ICL13.-->
 
<br>
 
<br>
 
== External Links ==
 
== External Links ==
*[http://forum.doom9.org/showthread.php?p=744308#post744308 Doom9 Forum] - EEDI2 discussion.
+
*[https://github.com/avisynth-repository/EEDI2 GitHub] - Source code repository (v0.9.2).
*[http://forum.doom9.org/showthread.php?t=173238 Doom9 Forum] - EEDI2 0.9.2 built with ICL10.
+
*[https://github.com/Asd-g/AviSynth-EEDI2 GitHub] - Source code repository (v1.0.0).
 +
*[https://github.com/HomeOfVapourSynthEvolution/VapourSynth-EEDI2 GitHub] - Source code repository (VapourSynth).
 
*[http://forum.doom9.org/showthread.php?t=171136  Doom9 Forum] - EEDI2 for VapourSynth.
 
*[http://forum.doom9.org/showthread.php?t=171136  Doom9 Forum] - EEDI2 for VapourSynth.
*GitHub - HandBrake's EEDI2 with nicely commented source code: [http://github.com/HandBrake/HandBrake/blob/master/libhb/eedi2.c eedi2.c], [http://github.com/HandBrake/HandBrake/blob/master/libhb/eedi2.h eedi2.h]
+
*GitHub - HandBrake's EEDI2 port with nicely commented source code: [http://github.com/HandBrake/HandBrake/blob/master/libhb/eedi2.c eedi2.c], [http://github.com/HandBrake/HandBrake/blob/master/libhb/eedi2.h eedi2.h]
 
<br>
 
<br>
 
<br>
 
<br>
 
-----------------------------------------------
 
-----------------------------------------------
 
'''Back to [[External_filters#Deinterlacing|External Filters]] &larr;'''
 
'''Back to [[External_filters#Deinterlacing|External Filters]] &larr;'''

Latest revision as of 18:33, 25 June 2020

Abstract
Author tritical, HolyWu, Asd-g
Version v1.0.0
Download EEDI2-1.0.0.7z
Category Deinterlacing
License GPLv2
Discussion Doom9 Thread

Contents

[edit] Description

EEDI2 (Enhanced Edge Directed Interpolation) resizes an image by 2x in the vertical direction by copying the existing image to 2*y(n) and interpolating the missing field. It is intended for edge-directed interpolation for deinterlacing (i.e. not really made for resizing a normal image, but can do that as well).

[edit] Requirements


*** vc_redist.x86.exe is required for EEDI2-x86
*** vc_redist.x64.exe is required for EEDI2-x64


[edit] Syntax and Parameters

EEDI2 (clip, int "mthresh", int "lthresh", int "vthresh", int "estr", int "dstr", int "maxd", int "field", int "map", int "nt", int "pp")


clip   =
Input clip to process. It must be in 8..16-bit planar format with or without alpha.


int  mthresh = 10
int  lthresh = 20
int  vthresh = 20
These all control edge detection used for building the initial edge map.
  • mthresh is the edge magnitude threshold... its range is from 0 to 255, lower values will detect weaker edges.
  • lthresh is the laplacian threshold... its range is 0 to 510, lower values will detect weaker lines.
  • vthresh is the variance threshold... its range is 0 to a large number, lower values will detect weaker edges.
Use the "map" option to tweak these settings as needed.


int  estr = 2
int  dstr = 4
These are used for dilation and erosion of the edge map.
  • estr sets the required number of edge pixels (<=) in a 3x3 area, in which the center pixel has been detected as an edge pixel, for the center pixel to be removed from the edge map.
  • dstr sets the required number of edge pixels (>=) in a 3x3 area, in which the center pixel has not been detected as an edge pixel, for the center pixel to be added to the edge map.
Use the "map" option to tweak these settings as needed.


int  maxd = 24
Sets the maximum pixel search distance for determining the interpolation direction.
Larger values will be able to connect edges and lines of smaller slope but can lead to artifacts. Sometimes using a smaller maxd will give better results than a larger setting. The maximum possible value for maxd is 29.


int  field = -1
Controls which field in the resized image the original image will be copied too.
When using AviSynth's internal parity value top field first (tff) = 1 and bottom field first (bff) = 0. Possible options:
  • -2 = alternates each frame, uses AviSynth's internal parity value to start
  • -1 = uses AviSynth's internal parity value
  • 0 = bottom field
  • 1 = top field
  • 2 = alternates each frame, starts with bottom
  • 3 = alternates each frame, starts with top


int  map = 0
Allows one of three possible maps to be shown. Possible settings:
  • 0 - no map
  • 1 - edge map (edge pixels will be set to 255 and non-edge pixels will be set to 0.)
  • 2 - original scale direction map
  • 3 - 2x scale direction map


int  nt = 50
Defines a noise threshold between pixels in the sliding vectors, this is used to set initial starting values.
Lower values should reduce artifacts but sacrifice edge reconstruction... while higher values should improve edge reconstruction but lead to more artifacts. The possible range of values is 0 to 256.


int  pp = 1
Enables two optional post-processing modes aimed at reducing artifacts by identifying problems areas and then using plain vertical linear interpolation in those parts. The possible settings are:
  • 0 - no post-processing
  • 1 - check for spatial consistency of final interpolation directions
  • 2 - check for junctions and corners
  • 3 - do both 1 and 2
Using the pp modes will slow down processing and can cause some loss of edge directedness.


[edit] Examples

EEDI2 with default settings:

AviSource("blah.avi")
EEDI2(mthresh=10, lthresh=20, vthresh=20, estr=2, dstr=4, maxd=24, field=-1, map=0, nt=50, pp=1)


[edit] Changelog

   06/18/2020  v1.0.0

       - Initial release; port of the VapourSynth plugin
       - 8-16bit all planar colorspace support
       - Dropped YUY2 colorspace

   06/07/2006  v0.9.2

       + various internal changes to help reduce artifacts around repeated
         patterns and to improve construction of lines/edges with small slope
       - Changed map from bool to int
       - Changed default maxd value from 12 to 24
       - Changed default pp value from 0 to 1
       - a few minor bugfixes


   04/03/2006  v0.9.1

       + Added pp parameter and pp modes 1, 2, and 3
       - A few minor internal changes
       - Fixed some documentation errors (field parameter)
       - do a vi.SetFieldBased(false) in constructor
       - fixed a bug causing reads past the last line and incorrect interpolation
         of the very top or very bottom line in some cases


   11/29/2005  v0.9

       - Initial release


[edit] Archived Downloads

Version Download Mirror
v0.9.2 (x86_x64) EEDI2_092_32_64.7z EEDI2_092_32_64.7z /// MediaFire
v0.9.2 EEDI2v092.zip


[edit] External Links

  • GitHub - Source code repository (v0.9.2).
  • GitHub - Source code repository (v1.0.0).
  • GitHub - Source code repository (VapourSynth).
  • Doom9 Forum - EEDI2 for VapourSynth.
  • GitHub - HandBrake's EEDI2 port with nicely commented source code: eedi2.c, eedi2.h




Back to External Filters

Personal tools