Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
beb3e6ff
O
Opencv
项目概览
Greenplum
/
Opencv
11 个月 前同步成功
通知
7
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
Opencv
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
beb3e6ff
编写于
8月 09, 2012
作者:
V
Vladislav Vinogradov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
added GMG_GPU to bgfg_segm sample
上级
f7f1fb2b
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
21 addition
and
5 deletion
+21
-5
samples/gpu/bgfg_segm.cpp
samples/gpu/bgfg_segm.cpp
+21
-5
未找到文件。
samples/gpu/bgfg_segm.cpp
浏览文件 @
beb3e6ff
...
...
@@ -14,7 +14,8 @@ enum Method
FGD_STAT
,
MOG
,
MOG2
,
VIBE
VIBE
,
GMG
};
int
main
(
int
argc
,
const
char
**
argv
)
...
...
@@ -22,7 +23,7 @@ int main(int argc, const char** argv)
cv
::
CommandLineParser
cmd
(
argc
,
argv
,
"{ c | camera | false | use camera }"
"{ f | file | 768x576.avi | input video file }"
"{ m | method | mog | method (fgd
_stat, mog, mog2, vibe
) }"
"{ m | method | mog | method (fgd
, mog, mog2, vibe, gmg
) }"
"{ h | help | false | print help message }"
);
if
(
cmd
.
get
<
bool
>
(
"help"
))
...
...
@@ -37,13 +38,13 @@ int main(int argc, const char** argv)
string
file
=
cmd
.
get
<
string
>
(
"file"
);
string
method
=
cmd
.
get
<
string
>
(
"method"
);
if
(
method
!=
"fgd
_stat"
&&
method
!=
"mog"
&&
method
!=
"mog2"
&&
method
!=
"vibe
"
)
if
(
method
!=
"fgd
"
&&
method
!=
"mog"
&&
method
!=
"mog2"
&&
method
!=
"vibe"
&&
method
!=
"gmg
"
)
{
cerr
<<
"Incorrect method"
<<
endl
;
return
-
1
;
}
Method
m
=
method
==
"fgd
_stat"
?
FGD_STAT
:
method
==
"mog"
?
MOG
:
method
==
"mog2"
?
MOG2
:
VIBE
;
Method
m
=
method
==
"fgd
"
?
FGD_STAT
:
method
==
"mog"
?
MOG
:
method
==
"mog2"
?
MOG2
:
method
==
"vibe"
?
VIBE
:
GMG
;
VideoCapture
cap
;
...
...
@@ -67,6 +68,8 @@ int main(int argc, const char** argv)
MOG_GPU
mog
;
MOG2_GPU
mog2
;
VIBE_GPU
vibe
;
GMG_GPU
gmg
;
gmg
.
numInitializationFrames
=
40
;
GpuMat
d_fgmask
;
GpuMat
d_fgimg
;
...
...
@@ -93,12 +96,16 @@ int main(int argc, const char** argv)
case
VIBE
:
vibe
.
initialize
(
d_frame
);
break
;
case
GMG
:
gmg
.
initialize
(
d_frame
.
size
());
break
;
}
namedWindow
(
"image"
,
WINDOW_NORMAL
);
namedWindow
(
"foreground mask"
,
WINDOW_NORMAL
);
namedWindow
(
"foreground image"
,
WINDOW_NORMAL
);
if
(
m
!=
VIBE
)
if
(
m
!=
VIBE
&&
m
!=
GMG
)
namedWindow
(
"mean background image"
,
WINDOW_NORMAL
);
for
(;;)
...
...
@@ -108,6 +115,8 @@ int main(int argc, const char** argv)
break
;
d_frame
.
upload
(
frame
);
int64
start
=
cv
::
getTickCount
();
//update the model
switch
(
m
)
{
...
...
@@ -130,8 +139,15 @@ int main(int argc, const char** argv)
case
VIBE
:
vibe
(
d_frame
,
d_fgmask
);
break
;
case
GMG
:
gmg
(
d_frame
,
d_fgmask
);
break
;
}
double
fps
=
cv
::
getTickFrequency
()
/
(
cv
::
getTickCount
()
-
start
);
std
::
cout
<<
"FPS : "
<<
fps
<<
std
::
endl
;
d_fgimg
.
setTo
(
Scalar
::
all
(
0
));
d_frame
.
copyTo
(
d_fgimg
,
d_fgmask
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录