1 /*
2 * filestorage_sample demonstrate the usage of the opencv serialization functionality
3 */
4
5 #include "opencv2/core/core.hpp"
6 #include <iostream>
7 #include <string>
8
9 using std::string;
10 using std::cout;
11 using std::endl;
12 using std::cerr;
13 using std::ostream;
14 using namespace cv;
15
help(char ** av)16 static void help(char** av)
17 {
18 cout << "\nfilestorage_sample demonstrate the usage of the opencv serialization functionality.\n"
19 << "usage:\n"
20 << av[0] << " outputfile.yml.gz\n"
21 << "\n outputfile above can have many different extenstions, see below."
22 << "\nThis program demonstrates the use of FileStorage for serialization, that is use << and >> in OpenCV\n"
23 << "For example, how to create a class and have it serialize, but also how to use it to read and write matrices.\n"
24 << "FileStorage allows you to serialize to various formats specified by the file end type."
25 << "\nYou should try using different file extensions.(e.g. yaml yml xml xml.gz yaml.gz etc...)\n" << endl;
26 }
27
28 struct MyData
29 {
MyDataMyData30 MyData() :
31 A(0), X(0), id()
32 {
33 }
MyDataMyData34 explicit MyData(int) :
35 A(97), X(CV_PI), id("mydata1234")
36 {
37 }
38 int A;
39 double X;
40 string id;
writeMyData41 void write(FileStorage& fs) const //Write serialization for this class
42 {
43 fs << "{" << "A" << A << "X" << X << "id" << id << "}";
44 }
readMyData45 void read(const FileNode& node) //Read serialization for this class
46 {
47
48 A = (int)node["A"];
49 X = (double)node["X"];
50 id = (string)node["id"];
51 }
52 };
53
54 //These write and read functions must exist as per the inline functions in operations.hpp
write(FileStorage & fs,const std::string &,const MyData & x)55 static void write(FileStorage& fs, const std::string&, const MyData& x){
56 x.write(fs);
57 }
read(const FileNode & node,MyData & x,const MyData & default_value=MyData ())58 static void read(const FileNode& node, MyData& x, const MyData& default_value = MyData()){
59 if(node.empty())
60 x = default_value;
61 else
62 x.read(node);
63 }
64
operator <<(ostream & out,const MyData & m)65 static ostream& operator<<(ostream& out, const MyData& m){
66 out << "{ id = " << m.id << ", ";
67 out << "X = " << m.X << ", ";
68 out << "A = " << m.A << "}";
69 return out;
70 }
main(int ac,char ** av)71 int main(int ac, char** av)
72 {
73 if (ac != 2)
74 {
75 help(av);
76 return 1;
77 }
78
79 string filename = av[1];
80
81 //write
82 {
83 FileStorage fs(filename, FileStorage::WRITE);
84
85 cout << "writing images\n";
86 fs << "images" << "[";
87
88 fs << "image1.jpg" << "myfi.png" << "../data/baboon.jpg";
89 cout << "image1.jpg" << " myfi.png" << " ../data/baboon.jpg" << endl;
90
91 fs << "]";
92
93 cout << "writing mats\n";
94 Mat R =Mat_<double>::eye(3, 3),T = Mat_<double>::zeros(3, 1);
95 cout << "R = " << R << "\n";
96 cout << "T = " << T << "\n";
97 fs << "R" << R;
98 fs << "T" << T;
99
100 cout << "writing MyData struct\n";
101 MyData m(1);
102 fs << "mdata" << m;
103 cout << m << endl;
104 }
105
106 //read
107 {
108 FileStorage fs(filename, FileStorage::READ);
109
110 if (!fs.isOpened())
111 {
112 cerr << "failed to open " << filename << endl;
113 help(av);
114 return 1;
115 }
116
117 FileNode n = fs["images"];
118 if (n.type() != FileNode::SEQ)
119 {
120 cerr << "images is not a sequence! FAIL" << endl;
121 return 1;
122 }
123
124 cout << "reading images\n";
125 FileNodeIterator it = n.begin(), it_end = n.end();
126 for (; it != it_end; ++it)
127 {
128 cout << (string)*it << "\n";
129 }
130
131 Mat R, T;
132 cout << "reading R and T" << endl;
133
134 fs["R"] >> R;
135 fs["T"] >> T;
136
137 cout << "R = " << R << "\n";
138 cout << "T = " << T << endl;
139
140 MyData m;
141 fs["mdata"] >> m;
142
143 cout << "read mdata\n";
144 cout << m << endl;
145
146 cout << "attempting to read mdata_b\n"; //Show default behavior for empty matrix
147 fs["mdata_b"] >> m;
148 cout << "read mdata_b\n";
149 cout << m << endl;
150
151 }
152
153 cout << "Try opening " << filename << " to see the serialized data." << endl << endl;
154
155 //read from string
156 {
157 cout << "Read data from string\n";
158 string dataString =
159 "%YAML:1.0\n"
160 "mdata:\n"
161 " A: 97\n"
162 " X: 3.1415926535897931e+00\n"
163 " id: mydata1234\n";
164 MyData m;
165 FileStorage fs(dataString, FileStorage::READ | FileStorage::MEMORY);
166 cout << "attempting to read mdata_b from string\n"; //Show default behavior for empty matrix
167 fs["mdata"] >> m;
168 cout << "read mdata\n";
169 cout << m << endl;
170 }
171
172 //write to string
173 {
174 cout << "Write data to string\n";
175 FileStorage fs(filename, FileStorage::WRITE | FileStorage::MEMORY | FileStorage::FORMAT_YAML);
176
177 cout << "writing MyData struct\n";
178 MyData m(1);
179 fs << "mdata" << m;
180 cout << m << endl;
181 string createdString = fs.releaseAndGetString();
182 cout << "Created string:\n" << createdString << "\n";
183 }
184
185 return 0;
186 }
187