Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv
Commits
3f62e785
Commit
3f62e785
authored
Aug 26, 2013
by
Vladislav Vinogradov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
used new device layer for cv::gpu::copyMakeBorder
parent
7b3bbcea
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
0 additions
and
109 deletions
+0
-109
core.cpp
modules/cudaarithm/src/core.cpp
+0
-109
copy_make_border.cu
modules/cudaarithm/src/cuda/copy_make_border.cu
+0
-0
No files found.
modules/cudaarithm/src/core.cpp
View file @
3f62e785
...
...
@@ -343,113 +343,4 @@ Ptr<LookUpTable> cv::cuda::createLookUpTable(InputArray lut)
return
makePtr
<
LookUpTableImpl
>
(
lut
);
}
////////////////////////////////////////////////////////////////////////
// copyMakeBorder
namespace
cv
{
namespace
cuda
{
namespace
device
{
namespace
imgproc
{
template
<
typename
T
,
int
cn
>
void
copyMakeBorder_gpu
(
const
PtrStepSzb
&
src
,
const
PtrStepSzb
&
dst
,
int
top
,
int
left
,
int
borderMode
,
const
T
*
borderValue
,
cudaStream_t
stream
);
}
}}}
namespace
{
template
<
typename
T
,
int
cn
>
void
copyMakeBorder_caller
(
const
PtrStepSzb
&
src
,
const
PtrStepSzb
&
dst
,
int
top
,
int
left
,
int
borderType
,
const
Scalar
&
value
,
cudaStream_t
stream
)
{
using
namespace
::
cv
::
cuda
::
device
::
imgproc
;
Scalar_
<
T
>
val
(
saturate_cast
<
T
>
(
value
[
0
]),
saturate_cast
<
T
>
(
value
[
1
]),
saturate_cast
<
T
>
(
value
[
2
]),
saturate_cast
<
T
>
(
value
[
3
]));
copyMakeBorder_gpu
<
T
,
cn
>
(
src
,
dst
,
top
,
left
,
borderType
,
val
.
val
,
stream
);
}
}
#if defined __GNUC__ && __GNUC__ > 2 && __GNUC_MINOR__ > 4
typedef
Npp32s
__attribute__
((
__may_alias__
))
Npp32s_a
;
#else
typedef
Npp32s
Npp32s_a
;
#endif
void
cv
::
cuda
::
copyMakeBorder
(
InputArray
_src
,
OutputArray
_dst
,
int
top
,
int
bottom
,
int
left
,
int
right
,
int
borderType
,
Scalar
value
,
Stream
&
_stream
)
{
GpuMat
src
=
_src
.
getGpuMat
();
CV_Assert
(
src
.
depth
()
<=
CV_32F
&&
src
.
channels
()
<=
4
);
CV_Assert
(
borderType
==
BORDER_REFLECT_101
||
borderType
==
BORDER_REPLICATE
||
borderType
==
BORDER_CONSTANT
||
borderType
==
BORDER_REFLECT
||
borderType
==
BORDER_WRAP
);
_dst
.
create
(
src
.
rows
+
top
+
bottom
,
src
.
cols
+
left
+
right
,
src
.
type
());
GpuMat
dst
=
_dst
.
getGpuMat
();
cudaStream_t
stream
=
StreamAccessor
::
getStream
(
_stream
);
if
(
borderType
==
BORDER_CONSTANT
&&
(
src
.
type
()
==
CV_8UC1
||
src
.
type
()
==
CV_8UC4
||
src
.
type
()
==
CV_32SC1
||
src
.
type
()
==
CV_32FC1
))
{
NppiSize
srcsz
;
srcsz
.
width
=
src
.
cols
;
srcsz
.
height
=
src
.
rows
;
NppiSize
dstsz
;
dstsz
.
width
=
dst
.
cols
;
dstsz
.
height
=
dst
.
rows
;
NppStreamHandler
h
(
stream
);
switch
(
src
.
type
())
{
case
CV_8UC1
:
{
Npp8u
nVal
=
saturate_cast
<
Npp8u
>
(
value
[
0
]);
nppSafeCall
(
nppiCopyConstBorder_8u_C1R
(
src
.
ptr
<
Npp8u
>
(),
static_cast
<
int
>
(
src
.
step
),
srcsz
,
dst
.
ptr
<
Npp8u
>
(),
static_cast
<
int
>
(
dst
.
step
),
dstsz
,
top
,
left
,
nVal
)
);
break
;
}
case
CV_8UC4
:
{
Npp8u
nVal
[]
=
{
saturate_cast
<
Npp8u
>
(
value
[
0
]),
saturate_cast
<
Npp8u
>
(
value
[
1
]),
saturate_cast
<
Npp8u
>
(
value
[
2
]),
saturate_cast
<
Npp8u
>
(
value
[
3
])};
nppSafeCall
(
nppiCopyConstBorder_8u_C4R
(
src
.
ptr
<
Npp8u
>
(),
static_cast
<
int
>
(
src
.
step
),
srcsz
,
dst
.
ptr
<
Npp8u
>
(),
static_cast
<
int
>
(
dst
.
step
),
dstsz
,
top
,
left
,
nVal
)
);
break
;
}
case
CV_32SC1
:
{
Npp32s
nVal
=
saturate_cast
<
Npp32s
>
(
value
[
0
]);
nppSafeCall
(
nppiCopyConstBorder_32s_C1R
(
src
.
ptr
<
Npp32s
>
(),
static_cast
<
int
>
(
src
.
step
),
srcsz
,
dst
.
ptr
<
Npp32s
>
(),
static_cast
<
int
>
(
dst
.
step
),
dstsz
,
top
,
left
,
nVal
)
);
break
;
}
case
CV_32FC1
:
{
Npp32f
val
=
saturate_cast
<
Npp32f
>
(
value
[
0
]);
Npp32s
nVal
=
*
(
reinterpret_cast
<
Npp32s_a
*>
(
&
val
));
nppSafeCall
(
nppiCopyConstBorder_32s_C1R
(
src
.
ptr
<
Npp32s
>
(),
static_cast
<
int
>
(
src
.
step
),
srcsz
,
dst
.
ptr
<
Npp32s
>
(),
static_cast
<
int
>
(
dst
.
step
),
dstsz
,
top
,
left
,
nVal
)
);
break
;
}
}
if
(
stream
==
0
)
cudaSafeCall
(
cudaDeviceSynchronize
()
);
}
else
{
typedef
void
(
*
caller_t
)(
const
PtrStepSzb
&
src
,
const
PtrStepSzb
&
dst
,
int
top
,
int
left
,
int
borderType
,
const
Scalar
&
value
,
cudaStream_t
stream
);
static
const
caller_t
callers
[
6
][
4
]
=
{
{
copyMakeBorder_caller
<
uchar
,
1
>
,
copyMakeBorder_caller
<
uchar
,
2
>
,
copyMakeBorder_caller
<
uchar
,
3
>
,
copyMakeBorder_caller
<
uchar
,
4
>
},
{
0
/*copyMakeBorder_caller<schar, 1>*/
,
0
/*copyMakeBorder_caller<schar, 2>*/
,
0
/*copyMakeBorder_caller<schar, 3>*/
,
0
/*copyMakeBorder_caller<schar, 4>*/
},
{
copyMakeBorder_caller
<
ushort
,
1
>
,
0
/*copyMakeBorder_caller<ushort, 2>*/
,
copyMakeBorder_caller
<
ushort
,
3
>
,
copyMakeBorder_caller
<
ushort
,
4
>
},
{
copyMakeBorder_caller
<
short
,
1
>
,
0
/*copyMakeBorder_caller<short, 2>*/
,
copyMakeBorder_caller
<
short
,
3
>
,
copyMakeBorder_caller
<
short
,
4
>
},
{
0
/*copyMakeBorder_caller<int, 1>*/
,
0
/*copyMakeBorder_caller<int, 2>*/
,
0
/*copyMakeBorder_caller<int, 3>*/
,
0
/*copyMakeBorder_caller<int , 4>*/
},
{
copyMakeBorder_caller
<
float
,
1
>
,
0
/*copyMakeBorder_caller<float, 2>*/
,
copyMakeBorder_caller
<
float
,
3
>
,
copyMakeBorder_caller
<
float
,
4
>
}
};
caller_t
func
=
callers
[
src
.
depth
()][
src
.
channels
()
-
1
];
CV_Assert
(
func
!=
0
);
func
(
src
,
dst
,
top
,
left
,
borderType
,
value
,
stream
);
}
}
#endif
/* !defined (HAVE_CUDA) */
modules/cudaarithm/src/cuda/copy_make_border.cu
View file @
3f62e785
This diff is collapsed.
Click to expand it.
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