Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
3bf28d40
Commit
3bf28d40
authored
Jan 19, 2020
by
Paul B Mahol
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avfilter/vf_v360: change remaps to int16_t type
parent
ff5e241b
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
48 additions
and
48 deletions
+48
-48
v360.h
libavfilter/v360.h
+6
-6
vf_v360.c
libavfilter/vf_v360.c
+37
-37
vf_v360_init.c
libavfilter/x86/vf_v360_init.c
+5
-5
No files found.
libavfilter/v360.h
View file @
3bf28d40
...
@@ -96,8 +96,8 @@ enum RotationOrder {
...
@@ -96,8 +96,8 @@ enum RotationOrder {
};
};
typedef
struct
XYRemap
{
typedef
struct
XYRemap
{
u
int16_t
u
[
4
][
4
];
int16_t
u
[
4
][
4
];
u
int16_t
v
[
4
][
4
];
int16_t
v
[
4
][
4
];
float
ker
[
4
][
4
];
float
ker
[
4
][
4
];
}
XYRemap
;
}
XYRemap
;
...
@@ -152,25 +152,25 @@ typedef struct V360Context {
...
@@ -152,25 +152,25 @@ typedef struct V360Context {
int
nb_allocated
;
int
nb_allocated
;
int
elements
;
int
elements
;
u
int16_t
*
u
[
2
],
*
v
[
2
];
int16_t
*
u
[
2
],
*
v
[
2
];
int16_t
*
ker
[
2
];
int16_t
*
ker
[
2
];
unsigned
map
[
4
];
unsigned
map
[
4
];
void
(
*
in_transform
)(
const
struct
V360Context
*
s
,
void
(
*
in_transform
)(
const
struct
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
);
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
);
void
(
*
out_transform
)(
const
struct
V360Context
*
s
,
void
(
*
out_transform
)(
const
struct
V360Context
*
s
,
int
i
,
int
j
,
int
width
,
int
height
,
int
i
,
int
j
,
int
width
,
int
height
,
float
*
vec
);
float
*
vec
);
void
(
*
calculate_kernel
)(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
void
(
*
calculate_kernel
)(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
uint16_t
*
u
,
u
int16_t
*
v
,
int16_t
*
ker
);
int16_t
*
u
,
int16_t
*
v
,
int16_t
*
ker
);
int
(
*
remap_slice
)(
AVFilterContext
*
ctx
,
void
*
arg
,
int
jobnr
,
int
nb_jobs
);
int
(
*
remap_slice
)(
AVFilterContext
*
ctx
,
void
*
arg
,
int
jobnr
,
int
nb_jobs
);
void
(
*
remap_line
)(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
const
src
,
ptrdiff_t
in_linesize
,
void
(
*
remap_line
)(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
const
src
,
ptrdiff_t
in_linesize
,
const
uint16_t
*
const
u
,
const
u
int16_t
*
const
v
,
const
int16_t
*
const
ker
);
const
int16_t
*
const
u
,
const
int16_t
*
const
v
,
const
int16_t
*
const
ker
);
}
V360Context
;
}
V360Context
;
void
ff_v360_init
(
V360Context
*
s
,
int
depth
);
void
ff_v360_init
(
V360Context
*
s
,
int
depth
);
...
...
libavfilter/vf_v360.c
View file @
3bf28d40
...
@@ -211,7 +211,7 @@ static int query_formats(AVFilterContext *ctx)
...
@@ -211,7 +211,7 @@ static int query_formats(AVFilterContext *ctx)
#define DEFINE_REMAP1_LINE(bits, div) \
#define DEFINE_REMAP1_LINE(bits, div) \
static void remap1_##bits##bit_line_c(uint8_t *dst, int width, const uint8_t *const src, \
static void remap1_##bits##bit_line_c(uint8_t *dst, int width, const uint8_t *const src, \
ptrdiff_t in_linesize, \
ptrdiff_t in_linesize, \
const
uint16_t *const u, const uint16_t *const v,
\
const
int16_t *const u, const int16_t *const v,
\
const int16_t *const ker) \
const int16_t *const ker) \
{ \
{ \
const uint##bits##_t *const s = (const uint##bits##_t *const)src; \
const uint##bits##_t *const s = (const uint##bits##_t *const)src; \
...
@@ -260,8 +260,8 @@ static int remap##ws##_##bits##bit_slice(AVFilterContext *ctx, void *arg, int jo
...
@@ -260,8 +260,8 @@ static int remap##ws##_##bits##bit_slice(AVFilterContext *ctx, void *arg, int jo
const int slice_end = (height * (jobnr + 1)) / nb_jobs; \
const int slice_end = (height * (jobnr + 1)) / nb_jobs; \
\
\
for (int y = slice_start; y < slice_end; y++) { \
for (int y = slice_start; y < slice_end; y++) { \
const
uint16_t *const u = s->u[map] + y * uv_linesize * ws * ws;
\
const
int16_t *const u = s->u[map] + y * uv_linesize * ws * ws;
\
const
uint16_t *const v = s->v[map] + y * uv_linesize * ws * ws;
\
const
int16_t *const v = s->v[map] + y * uv_linesize * ws * ws;
\
const int16_t *const ker = s->ker[map] + y * uv_linesize * ws * ws; \
const int16_t *const ker = s->ker[map] + y * uv_linesize * ws * ws; \
\
\
s->remap_line(dst + y * out_linesize, width, src, in_linesize, u, v, ker); \
s->remap_line(dst + y * out_linesize, width, src, in_linesize, u, v, ker); \
...
@@ -282,7 +282,7 @@ DEFINE_REMAP(4, 16)
...
@@ -282,7 +282,7 @@ DEFINE_REMAP(4, 16)
#define DEFINE_REMAP_LINE(ws, bits, div) \
#define DEFINE_REMAP_LINE(ws, bits, div) \
static void remap##ws##_##bits##bit_line_c(uint8_t *dst, int width, const uint8_t *const src, \
static void remap##ws##_##bits##bit_line_c(uint8_t *dst, int width, const uint8_t *const src, \
ptrdiff_t in_linesize, \
ptrdiff_t in_linesize, \
const
uint16_t *const u, const uint16_t *const v,
\
const
int16_t *const u, const int16_t *const v,
\
const int16_t *const ker) \
const int16_t *const ker) \
{ \
{ \
const uint##bits##_t *const s = (const uint##bits##_t *const)src; \
const uint##bits##_t *const s = (const uint##bits##_t *const)src; \
...
@@ -291,8 +291,8 @@ static void remap##ws##_##bits##bit_line_c(uint8_t *dst, int width, const uint8_
...
@@ -291,8 +291,8 @@ static void remap##ws##_##bits##bit_line_c(uint8_t *dst, int width, const uint8_
in_linesize /= div; \
in_linesize /= div; \
\
\
for (int x = 0; x < width; x++) { \
for (int x = 0; x < width; x++) { \
const
uint16_t *const uu = u + x * ws * ws;
\
const
int16_t *const uu = u + x * ws * ws;
\
const
uint16_t *const vv = v + x * ws * ws;
\
const
int16_t *const vv = v + x * ws * ws;
\
const int16_t *const kker = ker + x * ws * ws; \
const int16_t *const kker = ker + x * ws * ws; \
int tmp = 0; \
int tmp = 0; \
\
\
...
@@ -343,7 +343,7 @@ void ff_v360_init(V360Context *s, int depth)
...
@@ -343,7 +343,7 @@ void ff_v360_init(V360Context *s, int depth)
* @param ker ker remap data
* @param ker ker remap data
*/
*/
static
void
nearest_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
static
void
nearest_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
uint16_t
*
u
,
u
int16_t
*
v
,
int16_t
*
ker
)
int16_t
*
u
,
int16_t
*
v
,
int16_t
*
ker
)
{
{
const
int
i
=
roundf
(
dv
)
+
1
;
const
int
i
=
roundf
(
dv
)
+
1
;
const
int
j
=
roundf
(
du
)
+
1
;
const
int
j
=
roundf
(
du
)
+
1
;
...
@@ -363,7 +363,7 @@ static void nearest_kernel(float du, float dv, const XYRemap *rmap,
...
@@ -363,7 +363,7 @@ static void nearest_kernel(float du, float dv, const XYRemap *rmap,
* @param ker ker remap data
* @param ker ker remap data
*/
*/
static
void
bilinear_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
static
void
bilinear_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
uint16_t
*
u
,
u
int16_t
*
v
,
int16_t
*
ker
)
int16_t
*
u
,
int16_t
*
v
,
int16_t
*
ker
)
{
{
for
(
int
i
=
0
;
i
<
2
;
i
++
)
{
for
(
int
i
=
0
;
i
<
2
;
i
++
)
{
for
(
int
j
=
0
;
j
<
2
;
j
++
)
{
for
(
int
j
=
0
;
j
<
2
;
j
++
)
{
...
@@ -406,7 +406,7 @@ static inline void calculate_bicubic_coeffs(float t, float *coeffs)
...
@@ -406,7 +406,7 @@ static inline void calculate_bicubic_coeffs(float t, float *coeffs)
* @param ker ker remap data
* @param ker ker remap data
*/
*/
static
void
bicubic_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
static
void
bicubic_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
uint16_t
*
u
,
u
int16_t
*
v
,
int16_t
*
ker
)
int16_t
*
u
,
int16_t
*
v
,
int16_t
*
ker
)
{
{
float
du_coeffs
[
4
];
float
du_coeffs
[
4
];
float
dv_coeffs
[
4
];
float
dv_coeffs
[
4
];
...
@@ -459,7 +459,7 @@ static inline void calculate_lanczos_coeffs(float t, float *coeffs)
...
@@ -459,7 +459,7 @@ static inline void calculate_lanczos_coeffs(float t, float *coeffs)
* @param ker ker remap data
* @param ker ker remap data
*/
*/
static
void
lanczos_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
static
void
lanczos_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
uint16_t
*
u
,
u
int16_t
*
v
,
int16_t
*
ker
)
int16_t
*
u
,
int16_t
*
v
,
int16_t
*
ker
)
{
{
float
du_coeffs
[
4
];
float
du_coeffs
[
4
];
float
dv_coeffs
[
4
];
float
dv_coeffs
[
4
];
...
@@ -501,7 +501,7 @@ static void calculate_spline16_coeffs(float t, float *coeffs)
...
@@ -501,7 +501,7 @@ static void calculate_spline16_coeffs(float t, float *coeffs)
* @param ker ker remap data
* @param ker ker remap data
*/
*/
static
void
spline16_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
static
void
spline16_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
uint16_t
*
u
,
u
int16_t
*
v
,
int16_t
*
ker
)
int16_t
*
u
,
int16_t
*
v
,
int16_t
*
ker
)
{
{
float
du_coeffs
[
4
];
float
du_coeffs
[
4
];
float
dv_coeffs
[
4
];
float
dv_coeffs
[
4
];
...
@@ -554,7 +554,7 @@ static void calculate_gaussian_coeffs(float t, float *coeffs)
...
@@ -554,7 +554,7 @@ static void calculate_gaussian_coeffs(float t, float *coeffs)
* @param ker ker remap data
* @param ker ker remap data
*/
*/
static
void
gaussian_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
static
void
gaussian_kernel
(
float
du
,
float
dv
,
const
XYRemap
*
rmap
,
uint16_t
*
u
,
u
int16_t
*
v
,
int16_t
*
ker
)
int16_t
*
u
,
int16_t
*
v
,
int16_t
*
ker
)
{
{
float
du_coeffs
[
4
];
float
du_coeffs
[
4
];
float
dv_coeffs
[
4
];
float
dv_coeffs
[
4
];
...
@@ -1212,7 +1212,7 @@ static void cube3x2_to_xyz(const V360Context *s,
...
@@ -1212,7 +1212,7 @@ static void cube3x2_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_cube3x2
(
const
V360Context
*
s
,
static
void
xyz_to_cube3x2
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
scalew
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_width
/
3
.
f
)
:
1
.
f
-
s
->
in_pad
;
const
float
scalew
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_width
/
3
.
f
)
:
1
.
f
-
s
->
in_pad
;
const
float
scaleh
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_height
/
2
.
f
)
:
1
.
f
-
s
->
in_pad
;
const
float
scaleh
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_height
/
2
.
f
)
:
1
.
f
-
s
->
in_pad
;
...
@@ -1363,7 +1363,7 @@ static void cube6x1_to_xyz(const V360Context *s,
...
@@ -1363,7 +1363,7 @@ static void cube6x1_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_cube1x6
(
const
V360Context
*
s
,
static
void
xyz_to_cube1x6
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
scalew
=
s
->
fin_pad
>
0
?
1
.
f
-
(
float
)(
s
->
fin_pad
)
/
s
->
in_width
:
1
.
f
-
s
->
in_pad
;
const
float
scalew
=
s
->
fin_pad
>
0
?
1
.
f
-
(
float
)(
s
->
fin_pad
)
/
s
->
in_width
:
1
.
f
-
s
->
in_pad
;
const
float
scaleh
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_height
/
6
.
f
)
:
1
.
f
-
s
->
in_pad
;
const
float
scaleh
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_height
/
6
.
f
)
:
1
.
f
-
s
->
in_pad
;
...
@@ -1441,7 +1441,7 @@ static void xyz_to_cube1x6(const V360Context *s,
...
@@ -1441,7 +1441,7 @@ static void xyz_to_cube1x6(const V360Context *s,
*/
*/
static
void
xyz_to_cube6x1
(
const
V360Context
*
s
,
static
void
xyz_to_cube6x1
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
scalew
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_width
/
6
.
f
)
:
1
.
f
-
s
->
in_pad
;
const
float
scalew
=
s
->
fin_pad
>
0
?
1
.
f
-
s
->
fin_pad
/
(
s
->
in_width
/
6
.
f
)
:
1
.
f
-
s
->
in_pad
;
const
float
scaleh
=
s
->
fin_pad
>
0
?
1
.
f
-
(
float
)(
s
->
fin_pad
)
/
s
->
in_height
:
1
.
f
-
s
->
in_pad
;
const
float
scaleh
=
s
->
fin_pad
>
0
?
1
.
f
-
(
float
)(
s
->
fin_pad
)
/
s
->
in_height
:
1
.
f
-
s
->
in_pad
;
...
@@ -1588,7 +1588,7 @@ static void stereographic_to_xyz(const V360Context *s,
...
@@ -1588,7 +1588,7 @@ static void stereographic_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_stereographic
(
const
V360Context
*
s
,
static
void
xyz_to_stereographic
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
x
=
av_clipf
(
vec
[
0
]
/
(
1
.
f
-
vec
[
1
]),
-
1
.
f
,
1
.
f
)
*
s
->
input_mirror_modifier
[
0
];
const
float
x
=
av_clipf
(
vec
[
0
]
/
(
1
.
f
-
vec
[
1
]),
-
1
.
f
,
1
.
f
)
*
s
->
input_mirror_modifier
[
0
];
const
float
y
=
av_clipf
(
vec
[
2
]
/
(
1
.
f
-
vec
[
1
]),
-
1
.
f
,
1
.
f
)
*
s
->
input_mirror_modifier
[
1
];
const
float
y
=
av_clipf
(
vec
[
2
]
/
(
1
.
f
-
vec
[
1
]),
-
1
.
f
,
1
.
f
)
*
s
->
input_mirror_modifier
[
1
];
...
@@ -1625,7 +1625,7 @@ static void xyz_to_stereographic(const V360Context *s,
...
@@ -1625,7 +1625,7 @@ static void xyz_to_stereographic(const V360Context *s,
*/
*/
static
void
xyz_to_equirect
(
const
V360Context
*
s
,
static
void
xyz_to_equirect
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
phi
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
];
const
float
phi
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
];
const
float
theta
=
asinf
(
-
vec
[
1
])
*
s
->
input_mirror_modifier
[
1
];
const
float
theta
=
asinf
(
-
vec
[
1
])
*
s
->
input_mirror_modifier
[
1
];
...
@@ -1662,7 +1662,7 @@ static void xyz_to_equirect(const V360Context *s,
...
@@ -1662,7 +1662,7 @@ static void xyz_to_equirect(const V360Context *s,
*/
*/
static
void
xyz_to_mercator
(
const
V360Context
*
s
,
static
void
xyz_to_mercator
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
phi
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
];
const
float
phi
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
];
const
float
theta
=
-
vec
[
1
]
*
s
->
input_mirror_modifier
[
1
];
const
float
theta
=
-
vec
[
1
]
*
s
->
input_mirror_modifier
[
1
];
...
@@ -1727,7 +1727,7 @@ static void mercator_to_xyz(const V360Context *s,
...
@@ -1727,7 +1727,7 @@ static void mercator_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_ball
(
const
V360Context
*
s
,
static
void
xyz_to_ball
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
l
=
hypotf
(
vec
[
0
],
vec
[
1
]);
const
float
l
=
hypotf
(
vec
[
0
],
vec
[
1
]);
const
float
r
=
sqrtf
(
1
.
f
+
vec
[
2
])
/
M_SQRT2
;
const
float
r
=
sqrtf
(
1
.
f
+
vec
[
2
])
/
M_SQRT2
;
...
@@ -1833,7 +1833,7 @@ static void hammer_to_xyz(const V360Context *s,
...
@@ -1833,7 +1833,7 @@ static void hammer_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_hammer
(
const
V360Context
*
s
,
static
void
xyz_to_hammer
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
theta
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
];
const
float
theta
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
];
...
@@ -1902,7 +1902,7 @@ static void sinusoidal_to_xyz(const V360Context *s,
...
@@ -1902,7 +1902,7 @@ static void sinusoidal_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_sinusoidal
(
const
V360Context
*
s
,
static
void
xyz_to_sinusoidal
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
theta
=
asinf
(
-
vec
[
1
])
*
s
->
input_mirror_modifier
[
1
];
const
float
theta
=
asinf
(
-
vec
[
1
])
*
s
->
input_mirror_modifier
[
1
];
const
float
phi
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
]
*
cosf
(
theta
);
const
float
phi
=
atan2f
(
vec
[
0
],
-
vec
[
2
])
*
s
->
input_mirror_modifier
[
0
]
*
cosf
(
theta
);
...
@@ -2128,7 +2128,7 @@ static void eac_to_xyz(const V360Context *s,
...
@@ -2128,7 +2128,7 @@ static void eac_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_eac
(
const
V360Context
*
s
,
static
void
xyz_to_eac
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
pixel_pad
=
2
;
const
float
pixel_pad
=
2
;
const
float
u_pad
=
pixel_pad
/
width
;
const
float
u_pad
=
pixel_pad
/
width
;
...
@@ -2436,7 +2436,7 @@ static void dfisheye_to_xyz(const V360Context *s,
...
@@ -2436,7 +2436,7 @@ static void dfisheye_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_dfisheye
(
const
V360Context
*
s
,
static
void
xyz_to_dfisheye
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
scale
=
1
.
f
-
s
->
in_pad
;
const
float
scale
=
1
.
f
-
s
->
in_pad
;
...
@@ -2558,7 +2558,7 @@ static void barrel_to_xyz(const V360Context *s,
...
@@ -2558,7 +2558,7 @@ static void barrel_to_xyz(const V360Context *s,
*/
*/
static
void
xyz_to_barrel
(
const
V360Context
*
s
,
static
void
xyz_to_barrel
(
const
V360Context
*
s
,
const
float
*
vec
,
int
width
,
int
height
,
const
float
*
vec
,
int
width
,
int
height
,
uint16_t
us
[
4
][
4
],
u
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
int16_t
us
[
4
][
4
],
int16_t
vs
[
4
][
4
],
float
*
du
,
float
*
dv
)
{
{
const
float
scale
=
0
.
99
f
;
const
float
scale
=
0
.
99
f
;
...
@@ -2757,8 +2757,8 @@ static av_always_inline int v360_slice(AVFilterContext *ctx, void *arg, int jobn
...
@@ -2757,8 +2757,8 @@ static av_always_inline int v360_slice(AVFilterContext *ctx, void *arg, int jobn
for
(
int
j
=
slice_start
;
j
<
slice_end
;
j
++
)
{
for
(
int
j
=
slice_start
;
j
<
slice_end
;
j
++
)
{
for
(
int
i
=
0
;
i
<
width
;
i
++
)
{
for
(
int
i
=
0
;
i
<
width
;
i
++
)
{
u
int16_t
*
u
=
s
->
u
[
p
]
+
(
j
*
uv_linesize
+
i
)
*
s
->
elements
;
int16_t
*
u
=
s
->
u
[
p
]
+
(
j
*
uv_linesize
+
i
)
*
s
->
elements
;
u
int16_t
*
v
=
s
->
v
[
p
]
+
(
j
*
uv_linesize
+
i
)
*
s
->
elements
;
int16_t
*
v
=
s
->
v
[
p
]
+
(
j
*
uv_linesize
+
i
)
*
s
->
elements
;
int16_t
*
ker
=
s
->
ker
[
p
]
+
(
j
*
uv_linesize
+
i
)
*
s
->
elements
;
int16_t
*
ker
=
s
->
ker
[
p
]
+
(
j
*
uv_linesize
+
i
)
*
s
->
elements
;
if
(
s
->
out_transpose
)
if
(
s
->
out_transpose
)
...
@@ -2807,43 +2807,43 @@ static int config_output(AVFilterLink *outlink)
...
@@ -2807,43 +2807,43 @@ static int config_output(AVFilterLink *outlink)
s
->
calculate_kernel
=
nearest_kernel
;
s
->
calculate_kernel
=
nearest_kernel
;
s
->
remap_slice
=
depth
<=
8
?
remap1_8bit_slice
:
remap1_16bit_slice
;
s
->
remap_slice
=
depth
<=
8
?
remap1_8bit_slice
:
remap1_16bit_slice
;
s
->
elements
=
1
;
s
->
elements
=
1
;
sizeof_uv
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_uv
=
sizeof
(
int16_t
)
*
s
->
elements
;
sizeof_ker
=
0
;
sizeof_ker
=
0
;
break
;
break
;
case
BILINEAR
:
case
BILINEAR
:
s
->
calculate_kernel
=
bilinear_kernel
;
s
->
calculate_kernel
=
bilinear_kernel
;
s
->
remap_slice
=
depth
<=
8
?
remap2_8bit_slice
:
remap2_16bit_slice
;
s
->
remap_slice
=
depth
<=
8
?
remap2_8bit_slice
:
remap2_16bit_slice
;
s
->
elements
=
2
*
2
;
s
->
elements
=
2
*
2
;
sizeof_uv
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_uv
=
sizeof
(
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
int16_t
)
*
s
->
elements
;
break
;
break
;
case
BICUBIC
:
case
BICUBIC
:
s
->
calculate_kernel
=
bicubic_kernel
;
s
->
calculate_kernel
=
bicubic_kernel
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
elements
=
4
*
4
;
s
->
elements
=
4
*
4
;
sizeof_uv
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_uv
=
sizeof
(
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
int16_t
)
*
s
->
elements
;
break
;
break
;
case
LANCZOS
:
case
LANCZOS
:
s
->
calculate_kernel
=
lanczos_kernel
;
s
->
calculate_kernel
=
lanczos_kernel
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
elements
=
4
*
4
;
s
->
elements
=
4
*
4
;
sizeof_uv
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_uv
=
sizeof
(
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
int16_t
)
*
s
->
elements
;
break
;
break
;
case
SPLINE16
:
case
SPLINE16
:
s
->
calculate_kernel
=
spline16_kernel
;
s
->
calculate_kernel
=
spline16_kernel
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
elements
=
4
*
4
;
s
->
elements
=
4
*
4
;
sizeof_uv
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_uv
=
sizeof
(
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
int16_t
)
*
s
->
elements
;
break
;
break
;
case
GAUSSIAN
:
case
GAUSSIAN
:
s
->
calculate_kernel
=
gaussian_kernel
;
s
->
calculate_kernel
=
gaussian_kernel
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
remap_slice
=
depth
<=
8
?
remap4_8bit_slice
:
remap4_16bit_slice
;
s
->
elements
=
4
*
4
;
s
->
elements
=
4
*
4
;
sizeof_uv
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_uv
=
sizeof
(
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
u
int16_t
)
*
s
->
elements
;
sizeof_ker
=
sizeof
(
int16_t
)
*
s
->
elements
;
break
;
break
;
default
:
default
:
av_assert0
(
0
);
av_assert0
(
0
);
...
...
libavfilter/x86/vf_v360_init.c
View file @
3bf28d40
...
@@ -24,19 +24,19 @@
...
@@ -24,19 +24,19 @@
#include "libavfilter/v360.h"
#include "libavfilter/v360.h"
void
ff_remap1_8bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
void
ff_remap1_8bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
const
uint16_t
*
u
,
const
uint16_t
*
v
,
const
int16_t
*
ker
);
const
int16_t
*
const
u
,
const
int16_t
*
const
v
,
const
int16_t
*
const
ker
);
void
ff_remap2_8bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
void
ff_remap2_8bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
const
uint16_t
*
u
,
const
uint16_t
*
v
,
const
int16_t
*
ker
);
const
int16_t
*
const
u
,
const
int16_t
*
const
v
,
const
int16_t
*
const
ker
);
void
ff_remap4_8bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
void
ff_remap4_8bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
const
uint16_t
*
u
,
const
uint16_t
*
v
,
const
int16_t
*
ker
);
const
int16_t
*
const
u
,
const
int16_t
*
const
v
,
const
int16_t
*
const
ker
);
void
ff_remap1_16bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
void
ff_remap1_16bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
const
uint16_t
*
u
,
const
uint16_t
*
v
,
const
int16_t
*
ker
);
const
int16_t
*
const
u
,
const
int16_t
*
const
v
,
const
int16_t
*
const
ker
);
void
ff_remap2_16bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
void
ff_remap2_16bit_line_avx2
(
uint8_t
*
dst
,
int
width
,
const
uint8_t
*
src
,
ptrdiff_t
in_linesize
,
const
uint16_t
*
u
,
const
uint16_t
*
v
,
const
int16_t
*
ker
);
const
int16_t
*
const
u
,
const
int16_t
*
const
v
,
const
int16_t
*
const
ker
);
av_cold
void
ff_v360_init_x86
(
V360Context
*
s
,
int
depth
)
av_cold
void
ff_v360_init_x86
(
V360Context
*
s
,
int
depth
)
{
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment