AddGrainC

From Avisynth wiki
(Difference between revisions)
Jump to: navigation, search
m (Requirements:)
(AddGrainC: new version)
 
(22 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{FilterCat|External_filters|Adjustment_filters|Effects}}
+
{{FilterCat6|External_filters|Plugins|Plugins_x64|Adjustment_filters|Effects|Deep_color_tools}}
{{Filter
+
{{Filter3
 
|
 
|
 
*{{Author/Tom Barry}}
 
*{{Author/Tom Barry}}
Line 6: Line 6:
 
*{{Author/LaTo}}
 
*{{Author/LaTo}}
 
*{{Author/cretindesalpes}}
 
*{{Author/cretindesalpes}}
|1.7.1
+
*[https://github.com/HolyWu/ HolyWu]
|[http://ldesoras.free.fr/src/avs/AddGrainC-1.7.1.7z AddGrainC-1.7.1.7z]
+
*StvG
 +
*{{Author/pinterf}}
 +
|1.8.3
 +
|[https://github.com/pinterf/AddGrainC/releases AddGrainC_v1.8.3.7z]
 
|Effects
 
|Effects
|
+
|[http://www.gnu.org/licenses/gpl-2.0.txt GPLv2]
* YV12
+
|6=[http://forum.doom9.org/showthread.php?t=111849 Doom9 Thread]}}
|[http://www.gnu.org/licenses/gpl-2.0.txt GPLv2]}}
+
<br>
+
 
== Description ==
 
== Description ==
:AddGrainC generates film like grain or other effects (like rain) by adding random noise to a video clip.
+
Generate [[wikipedia:Film_grain|film-like grain]] or other effects (like rain) by adding random noise to a video clip. This noise may optionally be horizontally or vertically correlated to cause streaking.  
:This noise may optionally be horizontally or vertically correlated to cause streaking.
+
 
 +
'''AddGrain''' and '''AddGrainC''' are ''aliases'' for one another; there is no difference in functionality, only in syntax. <br/>
 +
 
 +
'''Note''': self-registers as [[MT_NICE_FILTER]] in AviSynth+.
 +
<br>
 
<br>
 
<br>
== Requirements: ==
+
== Requirements ==
:- AviSynth 2.5.8 or later
+
* [x86]: [[AviSynth+]] or [http://sourceforge.net/projects/avisynth2/ AviSynth 2.6]
:- [http://www.microsoft.com/en-us/download/details.aspx?id=30679 Microsoft Visual C++ 2012 Redistributable Package]
+
* [x64]: [[AviSynth+]]
:- MMX or SSE2 capable cpu
+
* [[FAQ_different_types_content#How_do_I_recognize_progressive.2C_interlaced.2C_telecined.2C_hybrid_and_blended_content.3F|Progressive]] input only  
:- [[FAQ_different_types_content#How_do_I_recognize_progressive.2C_interlaced.2C_telecined.2C_hybrid_and_blended_content.3F|Progressive]] input only  
+
* Supported color formats: [[Y8]], [[YV12]], [[YV16]], [[YV24]], [[YV411]], [[RGB24]], [[RGB32]]
:- Supported color formats: [[RGB24]], [[RGB32]], [[YUY2]], [[YV12]], [[YV16]], [[YV24]], [[YV411]], [[Y8]]
+
**AviSynth+: all [[planar]] formats (8/10/12/14/16bit and float, YUV/RGB with or without alpha), plus [[RGB48]] and [[RGB64]] are supported.
 
<br>
 
<br>
  
== Syntax and Parameters ==
+
== [[Script variables|Syntax and Parameters]] ==
:{{Template:FuncDef|AddGrainC (float "var", float "uvar", float "hcorr", float "vcorr", int "seed", bool "constant", bool "sse2")}}
+
:{{Template:FuncDef|AddGrain (''clip'', ''float'' "var", ''float'' "hcorr", ''float'' "vcorr", ''float'' "uvar", ''int'' "seed", ''bool'' "constant", ''bool'' "sse2")}}
 +
:{{Template:FuncDef|AddGrainC (''clip'', ''float'' "var", ''float'' "uvar", ''float'' "hcorr", ''float'' "vcorr", ''int'' "seed", ''bool'' "constant", ''bool'' "sse2")}}
 
<br>
 
<br>
::{{Par|var|float|1.0}}
+
::{{Par2| |clip| }}
:::The standard deviation (strength) of the luma noise, 0 is disabled.
+
:::Input clip.
 
<br>
 
<br>
::{{Par|uvar|float|0.0}}
+
::{{Par2|var|float|1.0}}
:::The standard deviation (strength) of the chroma noise, 0 is disabled.
+
:::The standard deviation (strength) of the luma noise, 0.0 is disabled.
:::uvar does nothing in RGB mode.
+
 
<br>
 
<br>
::{{Par|hcorr|float|0.0}}
+
::{{Par2|uvar|float|0.0}}
::{{Par|vcorr|float|0.0}}
+
:::The standard deviation (strength) of the chroma noise, 0.0 is disabled.
 +
:::{{Template:FuncDef|uvar}} does nothing in [[RGB]] mode.
 +
<br>
 +
::{{Par2|hcorr|float|0.0}}
 +
::{{Par2|vcorr|float|0.0}}
 
:::Horizontal and vertical correlation, which causes a nifty streaking effect.
 
:::Horizontal and vertical correlation, which causes a nifty streaking effect.
 
::::Range: 0.0 - 1.0
 
::::Range: 0.0 - 1.0
 
<br>
 
<br>
::{{Par|seed|int|-1}}
+
::{{Par2|seed|int|-1}}
 
:::Specifies a repeatable grain sequence. Set to at least 0 to use.
 
:::Specifies a repeatable grain sequence. Set to at least 0 to use.
 
<br>
 
<br>
::{{Par|constant|bool|false}}
+
::{{Par2|constant|bool|false}}
 
:::Specifies a constant grain pattern on every frame.
 
:::Specifies a constant grain pattern on every frame.
 
<br>
 
<br>
::{{Par|sse2|bool|true}}
+
::{{Par2|sse2|bool|true}}
:::Enable sse2 optimization if available. 1.5x faster than mmx.
+
:::Debug parameter, set to false for C routines
 
<br>
 
<br>
 +
 
== Examples ==
 
== Examples ==
 +
AddGrainC with default values:
 
  [[AviSource]]("Blah.avi")
 
  [[AviSource]]("Blah.avi")
  StaticNoiseC(var=1.0, uvar=0.0, hcorr=0.0, vcorr=0.0, seed=-1, constant=false, sse2=true)
+
  AddGrainC(var=1.0, uvar=0.0, hcorr=0.0, vcorr=0.0, seed=-1, constant=false, sse2=true)
 
<br>
 
<br>
 
== Changelog ==
 
== Changelog ==
 
  Version      Date            Developer      Changes<br>
 
  Version      Date            Developer      Changes<br>
  [http://ldesoras.free.fr/src/avs/AddGrainC-1.7.1.7z 1.7.1]      2013/11/25      Firesledge      Added a 64-bit version. Compiled with MSVC 2012 (requires the 2012 runtime libraries)  
+
v1.8.3      2021/03/09      pinterf        - Fix: possible crash for packed RGB formats
  [http://ldesoras.free.fr/src/avs/AddGrainC-1.7.0.7z 1.7.0]      2012/08/16      Firesledge      Supports Y8, YV16, YV24 and YV411 colorspaces.
+
  [http://latoninf.free.fr/d9/AddGrainC-1.6.1.7z 1.6.1]      2011/10/29      LaTo INV.        Automatic switch to MMX if SSE2 is not supported by the CPU.
+
v1.8.2      2020/05/20      pinterf        - Fix SIMD code: 8/16/32 bits gave different look for the same given fixed seeds.
  [http://forum.doom9.org/showpost.php?p=1534699&postcount=55 1.6.0]      2011/10/28      LaTo INV.        Added SSE2 code (50% faster than MMX)
+
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.4.7z 1.5.4]      2011/10/27      Firesledge      Fixed bad pixels on the last line in YV12 mode when constant=true,
+
v1.8.1      2020/04/09      pinterf        - AddGrain: original parameter order restored (compatibility)
                                              fixed potential problems with frame width > 4096 pixels
+
                                              - bool sse2 parameter is restored as well. sse2 = false disables simd optimization.
                                              and fixed several other minor things.
+
                                              - simd: make internal noise block load unaligned.<br>
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.3.7z 1.5.3]      2011/10/26      Firesledge      Fixed coloring and bluring in RGB24 mode.
+
v1.8        2020/04/09      pinterf        - Plugin name changed back to AddGrainC
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.2.7z 1.5.2]      2011/10/26      Firesledge      Removed the SSE2 requirement.
+
                                              - Fix output darkening (regression in VS port)
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.1.7z 1.5.1]      2010/05/13      Firesledge      The source code compiles on Visual C++ versions older than 2008.
+
                                              - Add back documentation, credits
  [http://forum.doom9.org/showpost.php?p=1398231&postcount=36 1.5]        2010/05/07      Foxyshadis      Limit the initial seed generation to fix memory issues.
+
                                              - Add back SIMD optimization (SSE2, SSE4)
  1.4          2006/08/11      Foxyshadis     Constant replaces seed, seed repeatable.
+
                                              - Add back version resource<br>
  [http://forum.doom9.org/showpost.php?p=838887&postcount=18 1.3]        2006/06/10      Foxyshadis      Crashfix, noisegen optimization.
+
              2020/03/30      StvG            - Backport to AviSynth+
  [http://forum.doom9.org/showpost.php?p=837288&postcount=14 1.2]        2006/06/06      Foxyshadis      Supports YUY2, RGB. Fix cache mess.
+
                                              - Changes to 1.7.1:
  [http://forum.doom9.org/showpost.php?p=835592&postcount=9 1.1]        2006/06/01      Foxyshadis      Chroma grain + constant seed.
+
                                                * Support AviSynth+ high bit depth
  [http://neuron2.net/trbarry/AddGrain.zip 1.0]        2003/06/18      Tom Barry        Initial Release
+
                                                * Register Avisynth+ MT mode as [[MT_MULTI_INSTANCE]]
== Links ==
+
                                                * AddGrain parameter order made similar to AddGrainC:
 +
                                                  var, uvar, hcorr, vcorr, seed, constant (was: var, hcorr, vcorr, uvar, seed, constant)
 +
                                                * Removed bool "sse2" parameter
 +
                                                * Name is AddGrain
 +
                                                * Removed SIMD optimization<br>
 +
              2014-2018      HolyWu          - VapourSynth port<br>
 +
  [http://ldesoras.free.fr/src/avs/AddGrainC-1.7.1.7z 1.7.1]      2013/11/25      Firesledge      - Added a 64-bit version. Compiled with MSVC 2012 (requires the 2012 runtime libraries)  
 +
  [http://ldesoras.free.fr/src/avs/AddGrainC-1.7.0.7z 1.7.0]      2012/08/16      Firesledge      - Supports Y8, YV16, YV24 and YV411 colorspaces.
 +
  [http://latoninf.free.fr/d9/AddGrainC-1.6.1.7z 1.6.1]      2011/10/29      LaTo INV.        - Automatic switch to MMX if SSE2 is not supported by the CPU.
 +
  [http://forum.doom9.org/showpost.php?p=1534699&postcount=55 1.6.0]      2011/10/28      LaTo INV.        - Added SSE2 code (50% faster than MMX)
 +
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.4.7z 1.5.4]      2011/10/27      Firesledge      - Fixed bad pixels on the last line in YV12 mode when constant=true,
 +
                                                fixed potential problems with frame width > 4096 pixels
 +
                                                and fixed several other minor things.
 +
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.3.7z 1.5.3]      2011/10/26      Firesledge      - Fixed coloring and bluring in RGB24 mode.
 +
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.2.7z 1.5.2]      2011/10/26      Firesledge      - Removed the SSE2 requirement.
 +
  [http://ldesoras.free.fr/src/avs/old/AddGrainC-1.5.1.7z 1.5.1]      2010/05/13      Firesledge      - The source code compiles on Visual C++ versions older than 2008.
 +
  [http://forum.doom9.org/showpost.php?p=1398231&postcount=36 1.5]        2010/05/07      Foxyshadis      - Limit the initial seed generation to fix memory issues.
 +
  1.4          2006/08/11      Foxyshadis       - Constant replaces seed, seed repeatable.
 +
  [http://forum.doom9.org/showpost.php?p=838887&postcount=18 1.3]        2006/06/10      Foxyshadis      - Crashfix, noisegen optimization.
 +
  [http://forum.doom9.org/showpost.php?p=837288&postcount=14 1.2]        2006/06/06      Foxyshadis      - Supports YUY2, RGB. Fix cache mess.
 +
  [http://forum.doom9.org/showpost.php?p=835592&postcount=9 1.1]        2006/06/01      Foxyshadis      - Chroma grain + constant seed.
 +
  [http://neuron2.net/trbarry/AddGrain.zip 1.0]        2003/06/18      Tom Barry        - Initial Release
 +
 
 +
==External Links ==
 
*[http://forum.doom9.org/showthread.php?t=111849 Doom9 Forum] - AddGrainC discussion.
 
*[http://forum.doom9.org/showthread.php?t=111849 Doom9 Forum] - AddGrainC discussion.
<br>
+
*[https://github.com/pinterf/AddGrainC GitHub] - Source code repository.
 
<br>
 
<br>
 
<br>
 
<br>
 
-----------------------------------------------
 
-----------------------------------------------
 
'''Back to [[External_filters#Effects|External Filters]] &larr;'''
 
'''Back to [[External_filters#Effects|External Filters]] &larr;'''

Latest revision as of 11:36, 9 March 2021

Abstract
Author
Version 1.8.3
Download AddGrainC_v1.8.3.7z
Category Effects
License GPLv2
Discussion Doom9 Thread

Contents

[edit] Description

Generate film-like grain or other effects (like rain) by adding random noise to a video clip. This noise may optionally be horizontally or vertically correlated to cause streaking.

AddGrain and AddGrainC are aliases for one another; there is no difference in functionality, only in syntax.

Note: self-registers as MT_NICE_FILTER in AviSynth+.

[edit] Requirements


[edit] Syntax and Parameters

AddGrain (clip, float "var", float "hcorr", float "vcorr", float "uvar", int "seed", bool "constant", bool "sse2")
AddGrainC (clip, float "var", float "uvar", float "hcorr", float "vcorr", int "seed", bool "constant", bool "sse2")


clip   =
Input clip.


float  var = 1.0
The standard deviation (strength) of the luma noise, 0.0 is disabled.


float  uvar = 0.0
The standard deviation (strength) of the chroma noise, 0.0 is disabled.
uvar does nothing in RGB mode.


float  hcorr = 0.0
float  vcorr = 0.0
Horizontal and vertical correlation, which causes a nifty streaking effect.
Range: 0.0 - 1.0


int  seed = -1
Specifies a repeatable grain sequence. Set to at least 0 to use.


bool  constant = false
Specifies a constant grain pattern on every frame.


bool  sse2 = true
Debug parameter, set to false for C routines


[edit] Examples

AddGrainC with default values:

AviSource("Blah.avi")
AddGrainC(var=1.0, uvar=0.0, hcorr=0.0, vcorr=0.0, seed=-1, constant=false, sse2=true)


[edit] Changelog

Version      Date            Developer       Changes
v1.8.3 2021/03/09 pinterf - Fix: possible crash for packed RGB formats v1.8.2 2020/05/20 pinterf - Fix SIMD code: 8/16/32 bits gave different look for the same given fixed seeds. v1.8.1 2020/04/09 pinterf - AddGrain: original parameter order restored (compatibility) - bool sse2 parameter is restored as well. sse2 = false disables simd optimization. - simd: make internal noise block load unaligned.
v1.8 2020/04/09 pinterf - Plugin name changed back to AddGrainC - Fix output darkening (regression in VS port) - Add back documentation, credits - Add back SIMD optimization (SSE2, SSE4) - Add back version resource
2020/03/30 StvG - Backport to AviSynth+ - Changes to 1.7.1: * Support AviSynth+ high bit depth * Register Avisynth+ MT mode as MT_MULTI_INSTANCE * AddGrain parameter order made similar to AddGrainC: var, uvar, hcorr, vcorr, seed, constant (was: var, hcorr, vcorr, uvar, seed, constant) * Removed bool "sse2" parameter * Name is AddGrain * Removed SIMD optimization
2014-2018 HolyWu - VapourSynth port
1.7.1 2013/11/25 Firesledge - Added a 64-bit version. Compiled with MSVC 2012 (requires the 2012 runtime libraries) 1.7.0 2012/08/16 Firesledge - Supports Y8, YV16, YV24 and YV411 colorspaces. 1.6.1 2011/10/29 LaTo INV. - Automatic switch to MMX if SSE2 is not supported by the CPU. 1.6.0 2011/10/28 LaTo INV. - Added SSE2 code (50% faster than MMX) 1.5.4 2011/10/27 Firesledge - Fixed bad pixels on the last line in YV12 mode when constant=true, fixed potential problems with frame width > 4096 pixels and fixed several other minor things. 1.5.3 2011/10/26 Firesledge - Fixed coloring and bluring in RGB24 mode. 1.5.2 2011/10/26 Firesledge - Removed the SSE2 requirement. 1.5.1 2010/05/13 Firesledge - The source code compiles on Visual C++ versions older than 2008. 1.5 2010/05/07 Foxyshadis - Limit the initial seed generation to fix memory issues. 1.4 2006/08/11 Foxyshadis - Constant replaces seed, seed repeatable. 1.3 2006/06/10 Foxyshadis - Crashfix, noisegen optimization. 1.2 2006/06/06 Foxyshadis - Supports YUY2, RGB. Fix cache mess. 1.1 2006/06/01 Foxyshadis - Chroma grain + constant seed. 1.0 2003/06/18 Tom Barry - Initial Release

[edit] External Links




Back to External Filters

Personal tools