FFmpeg coverage


Directory: ../../../ffmpeg/
File: src/libavfilter/vf_gblur_init.h
Date: 2025-01-20 09:27:23
Exec Total Coverage
Lines: 46 46 100.0%
Functions: 5 5 100.0%
Branches: 26 26 100.0%

Line Branch Exec Source
1 /*
2 * Copyright (c) 2011 Pascal Getreuer
3 * Copyright (c) 2016 Paul B Mahol
4 *
5 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
7 *
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above
11 * copyright notice, this list of conditions and the following
12 * disclaimer in the documentation and/or other materials provided
13 * with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19 * HOLDER BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
20 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
22 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
23 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
24 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27
28 #ifndef AVFILTER_GBLUR_INIT_H
29 #define AVFILTER_GBLUR_INIT_H
30
31 #include "config.h"
32 #include "libavutil/attributes.h"
33 #include "libavutil/common.h"
34 #include "gblur.h"
35
36 3 static void postscale_c(float *buffer, int length,
37 float postscale, float min, float max)
38 {
39
2/2
✓ Branch 0 taken 196608 times.
✓ Branch 1 taken 3 times.
196611 for (int i = 0; i < length; i++) {
40 196608 buffer[i] *= postscale;
41 196608 buffer[i] = av_clipf(buffer[i], min, max);
42 }
43 3 }
44
45 3 static void horiz_slice_c(float *buffer, int width, int height, int steps,
46 float nu, float bscale, float *localbuf)
47 {
48 int x;
49
2/2
✓ Branch 0 taken 768 times.
✓ Branch 1 taken 3 times.
771 for (int y = 0; y < height; y++) {
50
2/2
✓ Branch 0 taken 1536 times.
✓ Branch 1 taken 768 times.
2304 for (int step = 0; step < steps; step++) {
51 1536 float *ptr = buffer + width * y;
52 1536 ptr[0] *= bscale;
53
54 /* Filter rightwards */
55
2/2
✓ Branch 0 taken 391680 times.
✓ Branch 1 taken 1536 times.
393216 for (x = 1; x < width; x++)
56 391680 ptr[x] += nu * ptr[x - 1];
57 1536 ptr[x = width - 1] *= bscale;
58
59 /* Filter leftwards */
60
2/2
✓ Branch 0 taken 391680 times.
✓ Branch 1 taken 1536 times.
393216 for (; x > 0; x--)
61 391680 ptr[x - 1] += nu * ptr[x];
62 }
63 }
64 3 }
65
66 6 static void do_vertical_columns(float *buffer, int width, int height,
67 int column_begin, int column_end, int steps,
68 float nu, float boundaryscale, int column_step)
69 {
70 6 const int numpixels = width * height;
71 int i;
72
2/2
✓ Branch 0 taken 96 times.
✓ Branch 1 taken 6 times.
102 for (int x = column_begin; x < column_end;) {
73
2/2
✓ Branch 0 taken 192 times.
✓ Branch 1 taken 96 times.
288 for (int step = 0; step < steps; step++) {
74 192 float *ptr = buffer + x;
75
2/2
✓ Branch 0 taken 1536 times.
✓ Branch 1 taken 192 times.
1728 for (int k = 0; k < column_step; k++) {
76 1536 ptr[k] *= boundaryscale;
77 }
78 /* Filter downwards */
79
2/2
✓ Branch 0 taken 48960 times.
✓ Branch 1 taken 192 times.
49152 for (i = width; i < numpixels; i += width) {
80
2/2
✓ Branch 0 taken 391680 times.
✓ Branch 1 taken 48960 times.
440640 for (int k = 0; k < column_step; k++) {
81 391680 ptr[i + k] += nu * ptr[i - width + k];
82 }
83 }
84 192 i = numpixels - width;
85
86
2/2
✓ Branch 0 taken 1536 times.
✓ Branch 1 taken 192 times.
1728 for (int k = 0; k < column_step; k++)
87 1536 ptr[i + k] *= boundaryscale;
88
89 /* Filter upwards */
90
2/2
✓ Branch 0 taken 48960 times.
✓ Branch 1 taken 192 times.
49152 for (; i > 0; i -= width) {
91
2/2
✓ Branch 0 taken 391680 times.
✓ Branch 1 taken 48960 times.
440640 for (int k = 0; k < column_step; k++)
92 391680 ptr[i - width + k] += nu * ptr[i + k];
93 }
94 }
95 96 x += column_step;
96 }
97 6 }
98
99 3 static void verti_slice_c(float *buffer, int width, int height,
100 int slice_start, int slice_end, int steps,
101 float nu, float boundaryscale)
102 {
103 3 int aligned_end = slice_start + (((slice_end - slice_start) >> 3) << 3);
104 /* Filter vertically along columns (process 8 columns in each step) */
105 3 do_vertical_columns(buffer, width, height, slice_start, aligned_end,
106 steps, nu, boundaryscale, 8);
107 /* Filter un-aligned columns one by one */
108 3 do_vertical_columns(buffer, width, height, aligned_end, slice_end,
109 steps, nu, boundaryscale, 1);
110 3 }
111
112 13 static av_unused void ff_gblur_init(GBlurContext *s)
113 {
114 13 s->localbuf = NULL;
115 13 s->horiz_slice = horiz_slice_c;
116 13 s->verti_slice = verti_slice_c;
117 13 s->postscale_slice = postscale_c;
118 #if ARCH_X86
119 13 ff_gblur_init_x86(s);
120 #endif
121 13 }
122
123 #endif /* AVFILTER_GBLUR_INIT_H */
124