File: vtkLineIntegralConvolution2D_fs2.glsl

package info (click to toggle)
paraview 4.0.1-1~bpo70%2B1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy-backports
  • size: 526,572 kB
  • sloc: cpp: 2,284,430; ansic: 816,374; python: 239,936; xml: 70,162; tcl: 48,295; fortran: 39,116; yacc: 5,466; java: 3,518; perl: 3,107; lex: 1,620; sh: 1,555; makefile: 932; asm: 471; pascal: 228
file content (111 lines) | stat: -rw-r--r-- 4,804 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
//=========================================================================
//
//  Program:   Visualization Toolkit
//  Module:    vtkLineIntegralConvolution2D_fs2.glsl
//
//  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
//  All rights reserved.
//  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
//
//     This software is distributed WITHOUT ANY WARRANTY; without even
//     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
//     PURPOSE.  See the above copyright notice for more information.
//
//=========================================================================

// Filename: vtkLineIntegralConvolution2D_fs2.glsl
// Filename is useful when using gldb-gui

#version 110

#extension GL_ARB_draw_buffers : enable

uniform sampler2D licTexture;
uniform float     uLicTexWid; // texture width
uniform float     uLicTexHgt; // texture height

// shift to the neighboring fragment
float tcordxDelt = 1.0 / uLicTexWid;
float tcordyDelt = 1.0 / uLicTexHgt;

// the 8 surrounding fragments accessed by the 3x3 Laplacian matrix
// -1 -1 -1
// -1  9 -1
// -1 -1 -1
vec2  cordShift0 = vec2( -tcordxDelt,  tcordyDelt );
vec2  cordShift1 = vec2(  0.0,         tcordyDelt );
vec2  cordShift2 = vec2(  tcordxDelt,  tcordyDelt );

vec2  cordShift3 = vec2( -tcordxDelt,  0.0        );
vec2  cordShift4 = vec2(  tcordxDelt,  0.0        );

vec2  cordShift5 = vec2( -tcordxDelt, -tcordyDelt );
vec2  cordShift6 = vec2(  0.0,        -tcordyDelt );
vec2  cordShift7 = vec2(  tcordxDelt, -tcordyDelt );

// used for handling exceptions
vec2  miniTCoord = vec2(       tcordxDelt,       tcordyDelt );
vec2  maxiTCoord = vec2( 1.0 - tcordxDelt, 1.0 - tcordyDelt );
vec4  miniTexVal = vec4( 0.0, 0.0, 0.0, 0.0 );
vec4  maxiTexVal = vec4( 1.0, 1.0, 1.0, 1.0 );

// perform a 3x3 Laplacian high-pass filter on the input image
void main( void )
{
  int   bException;
  vec4  outputValu;
  vec4  fragTexVal = texture2D( licTexture, gl_TexCoord[0].st );

  // In pass #1 LIC (vtkLineIntegralConvolution2D_fs1), any fragment where
  // the vector is zero is assigned with a negative texture value (by negating
  // the associated input noise texture value). High-pass filtering is skipped
  // for this fragment in order to pass the original input noise value forward
  // to pass #2 LIC. The line below checks if the current is such a fragment.
  bvec4 exception0 = lessThan( fragTexVal, miniTexVal );

  // checks if this fragment has 8 valid surrounding fragments (in tcoords)
  bvec2 exception1 = lessThan   ( gl_TexCoord[0].st, miniTCoord );
  bvec2 exception2 = greaterThan( gl_TexCoord[0].st, maxiTCoord );

  // perform high-pass filtering
  outputValu  = fragTexVal * 9.0;
  outputValu -= texture2D( licTexture, gl_TexCoord[0].st + cordShift0 ) +
                texture2D( licTexture, gl_TexCoord[0].st + cordShift1 ) +
                texture2D( licTexture, gl_TexCoord[0].st + cordShift2 ) +

                texture2D( licTexture, gl_TexCoord[0].st + cordShift3 ) +
                texture2D( licTexture, gl_TexCoord[0].st + cordShift4 ) +

                texture2D( licTexture, gl_TexCoord[0].st + cordShift5 ) +
                texture2D( licTexture, gl_TexCoord[0].st + cordShift6 ) +
                texture2D( licTexture, gl_TexCoord[0].st + cordShift7 );

  // Checks if high-pass filtering produces out-of-range texture values
  // that might incur artifacts near the interface between the valid flow
  // areas and zero-vector areas. In case of such a filtering result, the
  // initial texture value (from the output of pass #1 LIC) is simply
  // adopted to suppress artifacts as much as possible.
  bvec4 exception3 = lessThan   ( outputValu, miniTexVal );
  bvec4 exception4 = greaterThan( outputValu, maxiTexVal );
  bException = int(  any( exception3 )  ) + int(  any( exception4 )  );
  outputValu = fragTexVal * float(     bException ) +
               outputValu * float( 1 - bException );

  // In cased of any invalid surrounding fragment, high-pass filtering is
  // skipped and the initial texture value (from the output of pass #1 LIC)
  // is employed instead.
  bException = int(  any( exception1 )  ) + int(  any( exception2 )  );
  bException = ( bException + 1 ) / 2;
  outputValu = fragTexVal * float(     bException ) +
               outputValu * float( 1 - bException );

  // In case of a zero-vector fragment, the negative texture value (the noise
  // texture value stored in the output of pass #1 LIC) is negated again below
  // to restore the positive noise texture value that is then forwarded to pass
  // #2 LIC as the input noise.
  bException = int(  any( exception0 )  );
  outputValu = fragTexVal * float( 0 - bException ) +
               outputValu * float( 1 - bException );

  gl_FragData[0]= outputValu;
}