Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
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_contrib
Commits
071092d9
Commit
071092d9
authored
Aug 20, 2015
by
Vladimir
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added VOT2015 Dataset interface + VOT2015 sample cpp
parent
44e790b8
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
69 additions
and
66 deletions
+69
-66
track_vot.hpp
modules/datasets/include/opencv2/datasets/track_vot.hpp
+6
-0
track_vot.cpp
modules/datasets/samples/track_vot.cpp
+7
-5
track_vot.cpp
modules/datasets/src/track_vot.cpp
+56
-61
No files found.
modules/datasets/include/opencv2/datasets/track_vot.hpp
View file @
071092d9
...
...
@@ -44,9 +44,15 @@
#include <string>
#include <vector>
#include <map>
#include <iostream>
#include "opencv2/datasets/dataset.hpp"
#include "opencv2/datasets/util.hpp"
#include <opencv2/highgui.hpp>
#include <opencv2/core.hpp>
#include <sys/stat.h>
using
namespace
std
;
...
...
modules/datasets/samples/track_vot.cpp
View file @
071092d9
...
...
@@ -55,6 +55,8 @@ using namespace std;
using
namespace
cv
;
using
namespace
cv
::
datasets
;
#define DATASET_ID 1
int
main
(
int
argc
,
char
*
argv
[])
{
const
char
*
keys
=
...
...
@@ -72,18 +74,18 @@ int main(int argc, char *argv[])
}
Ptr
<
TRACK_vot
>
dataset
=
TRACK_vot
::
create
();
dataset
->
load
(
path
);
dataset
->
load
(
"D:/opencv/VOT 2015"
);
printf
(
"Datasets number: %d
\n
"
,
dataset
->
getDatasetsNum
());
for
(
int
i
=
1
;
i
<=
dataset
->
getDatasetsNum
();
i
++
)
printf
(
"
\t
Dataset #%d size: %d
\n
"
,
i
,
dataset
->
getDatasetLength
(
i
));
dataset
->
initDataset
(
dataset
ID
);
dataset
->
initDataset
(
DATASET_
ID
);
for
(
int
i
=
0
;
i
<
dataset
->
getDatasetLength
(
dataset
ID
);
i
++
)
for
(
int
i
=
0
;
i
<
dataset
->
getDatasetLength
(
DATASET_
ID
);
i
++
)
{
Mat
frame
;
if
(
!
dataset
->
getNextFrame
(
frame
))
break
;
dataset
->
getNextFrame
(
frame
);
//Draw Ground Truth BB
vector
<
Point2d
>
gtPoints
=
dataset
->
getGT
();
for
(
int
j
=
0
;
j
<
(
int
)(
gtPoints
.
size
()
-
1
);
j
++
)
...
...
modules/datasets/src/track_vot.cpp
View file @
071092d9
...
...
@@ -41,23 +41,21 @@
#include "opencv2/datasets/track_vot.hpp"
#include <sys/stat.h>
#include <opencv2/core.hpp>
#include <opencv2/highgui.hpp>
using
namespace
std
;
namespace
cv
{
namespace
datasets
{
class
TRACK_votImpl
:
public
TRACK_vot
{
public
:
namespace
datasets
{
class
TRACK_votImpl
:
public
TRACK_vot
{
public
:
//Constructor
TRACK_votImpl
()
{
activeDatasetID
=
1
;
frameCounter
=
0
;
}
...
...
@@ -67,7 +65,6 @@ namespace cv
//Load Dataset
virtual
void
load
(
const
string
&
path
);
protected
:
virtual
int
getDatasetsNum
();
virtual
int
getDatasetLength
(
int
id
);
...
...
@@ -78,39 +75,40 @@ namespace cv
virtual
vector
<
Point2d
>
getGT
();
private
:
void
loadDataset
(
const
string
&
path
);
string
numberToString
(
int
number
);
};
};
void
TRACK_votImpl
::
load
(
const
string
&
path
)
{
void
TRACK_votImpl
::
load
(
const
string
&
path
)
{
loadDataset
(
path
);
}
}
string
TRACK_votImpl
::
numberToString
(
int
number
)
{
string
TRACK_votImpl
::
numberToString
(
int
number
)
{
string
out
;
char
numberStr
[
9
];
sprintf
(
numberStr
,
"%u"
,
number
);
for
(
unsigned
int
i
=
0
;
i
<
8
-
strlen
(
numberStr
);
++
i
)
for
(
unsigned
int
i
=
0
;
i
<
8
-
strlen
(
numberStr
);
++
i
)
{
out
+=
"0"
;
}
out
+=
numberStr
;
return
out
;
}
}
inline
bool
fileExists
(
const
std
::
string
&
name
)
{
inline
bool
fileExists
(
const
std
::
string
&
name
)
{
struct
stat
buffer
;
return
(
stat
(
name
.
c_str
(),
&
buffer
)
==
0
);
}
}
void
TRACK_votImpl
::
loadDataset
(
const
string
&
rootPath
)
{
string
nameListPath
=
rootPath
+
"/list.txt"
;
ifstream
namesList
(
nameListPath
.
c_str
()
);
void
TRACK_votImpl
::
loadDataset
(
const
string
&
rootPath
)
{
ifstream
namesList
(
rootPath
+
"/list.txt"
)
;
//ifstream lengthsList(rootPath + "/lengths.txt"
);
vector
<
int
>
datasetsLengths
;
string
datasetName
;
...
...
@@ -128,16 +126,15 @@ namespace cv
Ptr
<
TRACK_votObj
>
currDataset
(
new
TRACK_votObj
);
//Open dataset's ground truth file
string
gtListPath
=
rootPath
+
"/"
+
datasetName
+
"/groundtruth.txt"
;
ifstream
gtList
(
gtListPath
.
c_str
());
ifstream
gtList
(
rootPath
+
"/"
+
datasetName
+
"/groundtruth.txt"
);
if
(
!
gtList
.
is_open
())
printf
(
"Error to open groundtruth.txt!!!"
)
;
cout
<<
"Error to open groundtruth.txt!!!"
;
//Make a list of datasets lengths
int
currFrameID
=
1
;
if
(
currDatasetID
==
0
)
printf
(
"VOT 2015 Dataset Initialization...
\n
"
)
;
bool
trFLG
=
true
;
cout
<<
"VOT 2015 Dataset Initialization...
\n
"
;
do
{
currFrameID
++
;
...
...
@@ -166,39 +163,39 @@ namespace cv
//Add object to storage
objects
.
push_back
(
currObj
);
}
while
(
trFLG
);
}
while
(
true
);
datasetsLengths
.
push_back
(
currFrameID
-
1
);
datasetsLengths
.
push_back
(
currFrameID
-
1
);
data
.
push_back
(
objects
);
}
}
else
{
printf
(
"Couldn't find a *list.txt* in VOT 2015 folder!!!"
)
;
cout
<<
rootPath
+
"Couldn't find a *list.txt* in VOT 2015 folder!!!"
;
}
namesList
.
close
();
return
;
}
}
int
TRACK_votImpl
::
getDatasetsNum
()
{
return
(
int
)(
data
.
size
()
);
}
int
TRACK_votImpl
::
getDatasetsNum
()
{
return
data
.
size
(
);
}
int
TRACK_votImpl
::
getDatasetLength
(
int
id
)
{
int
TRACK_votImpl
::
getDatasetLength
(
int
id
)
{
if
(
id
>
0
&&
id
<=
(
int
)
data
.
size
())
return
(
int
)(
data
[
id
-
1
].
size
()
);
return
data
[
id
-
1
].
size
(
);
else
{
printf
(
"Dataset ID is out of range...
\n
Allowed IDs are: 1~%d
\n
"
,
(
int
)
data
.
size
())
;
cout
<<
"Dataset ID is out of range...
\n
"
<<
"Allowed IDs are: 1~"
<<
(
int
)
data
.
size
()
<<
endl
;
return
-
1
;
}
}
}
bool
TRACK_votImpl
::
initDataset
(
int
id
)
{
bool
TRACK_votImpl
::
initDataset
(
int
id
)
{
if
(
id
>
0
&&
id
<=
(
int
)
data
.
size
())
{
activeDatasetID
=
id
;
...
...
@@ -206,31 +203,29 @@ namespace cv
}
else
{
printf
(
"Dataset ID is out of range...
\n
Allowed IDs are: 1~%d
\n
"
,
(
int
)
data
.
size
())
;
cout
<<
"Dataset ID is out of range...
\n
"
<<
"Allowed IDs are: 1~"
<<
(
int
)
data
.
size
()
<<
endl
;
return
false
;
}
}
}
bool
TRACK_votImpl
::
getNextFrame
(
Mat
&
frame
)
{
if
(
frameCounter
>=
(
int
)
data
[
activeDatasetID
-
1
].
size
())
return
false
;
string
imgPath
=
data
[
activeDatasetID
-
1
][
frameCounter
]
->
imagePath
;
frame
=
imread
(
imgPath
);
bool
TRACK_votImpl
::
getNextFrame
(
Mat
&
frame
)
{
frame
=
imread
(
data
[
activeDatasetID
-
1
][
frameCounter
]
->
imagePath
);
frameCounter
++
;
return
!
frame
.
empty
();
}
}
Ptr
<
TRACK_vot
>
TRACK_vot
::
create
()
{
Ptr
<
TRACK_vot
>
TRACK_vot
::
create
()
{
return
Ptr
<
TRACK_votImpl
>
(
new
TRACK_votImpl
);
}
}
vector
<
Point2d
>
TRACK_votImpl
::
getGT
()
{
vector
<
Point2d
>
TRACK_votImpl
::
getGT
()
{
Ptr
<
TRACK_votObj
>
currObj
=
data
[
activeDatasetID
-
1
][
frameCounter
-
1
];
return
currObj
->
gtbb
;
}
}
}
}
}
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