Matlab批量读取元胞数组中数据保存到txt文件中(WIDER FACE数据集中,读取人脸标注矩形框信息)
2016-08-26 18:30
751 查看
http://blog.csdn.net/xzzppp/article/details/51888603
WIDER FACE:http://mmlab.ie.cuhk.edu.hk/projects/WIDERFace/
1、文件说明:"wider_face_split.zip" 文件包含三个子文件:
wider_face_train.mat, wider_face_val.mat, andwider_face_test.mat.
其中,每个子文件中元胞数组:
The 'event_list'包含61个种类的文件夹名
The 'face_bbx_list' 包含每个种类中图片中人脸的标注矩形框
The 'file_list' 包含每个种类中图片名
标注的矩形框的格式如下:
<x_left y_top width height>.
参考地址:http://mmlab.ie.cuhk.edu.hk/projects/WIDERFace/support/example/README.txt
2、 要求
导出数据为如下格式
格式:event_list\file_list\face_bbx_list
注:
event_list、file_list、face_bbx_list三个元胞数组里面的内容是一一对应的,切记要一一对应。
对应图片:http://mmlab.ie.cuhk.edu.hk/projects/WIDERFace/
matlab程序:
[plain] view
plain copy
<span style="font-size:24px;"><span style="font-size:24px;">%功能描述,读取'wider_face_train.mat'文件中存储的文件夹名、文件图片名及标注矩形框位置(每个图片一行)
clc;clear;
wider_face_val = load('wider_face_val.mat') %加载'wider_face_val.mat'文件
fid = fopen('val.txt','w'); %以只读方式打开文件'val.txt'
for i = 1:61 %文件夹个数
num_j = length(wider_face_val.file_list{i,1}) %每个文件夹中图片个数
for j = 1:num_j %遍历每个文件夹中图片
%[num_k, num_un] = size(wider_face_val.face_bbx_list{i,1}{j,1}) %取每个图片中人脸个数,即标注矩形框个数
fprintf(fid, '%s%s', wider_face_val.event_list{i,1},'\'); %写入文件夹名
fprintf(fid, '%s%s ', wider_face_val.file_list{i,1}{j,1},'.jpg'); %写入图片名
fprintf(fid, '%g ', wider_face_val.face_bbx_list{i,1}{j,1}); %写入标注矩形框坐标
fprintf(fid, '\n'); %换行
end
end
fclose(fid); %关闭文件</span></span>
[plain] view
plain copy
<span style="font-size:24px;"><span style="font-size:24px;">%功能描述,读取'wider_face_train.mat'文件中存储的文件夹名、文件图片名及标注矩形框位置(每个人脸矩形框一行)
clc;clear;
wider_face_train = load('wider_face_train.mat') %加载'wider_face_train.mat'文件
fid = fopen('train.txt','w'); %以只读方式打开文件'train.txt'
for i = 1:61 %文件夹个数
num_j = length(wider_face_train.file_list{i,1}) %每个文件夹中图片个数
for j = 1:num_j %遍历每个文件夹中图片
[num_k, num_un] = size(wider_face_train.face_bbx_list{i,1}{j,1}) %取每个图片中人脸个数,即标注矩形框个数
if num_k == 1
fprintf(fid, '%s%s', wider_face_train.event_list{i,1},'\'); %写入文件夹名
fprintf(fid, '%s%s ', wider_face_train.file_list{i,1}{j,1},'.jpg'); %写入图片名
fprintf(fid, '%g ', wider_face_train.face_bbx_list{i,1}{j,1}); %写入标注矩形框坐标
fprintf(fid, '\n'); %换行
else
for k = 1:num_k %遍历每个图片中标注框
%a = wider_face_train.face_bbx_list{i,1}{j,1}( k, :);
fprintf(fid, '%s%s', wider_face_train.event_list{i,1},'\');
fprintf(fid, '%s%s ', wider_face_train.file_list{i,1}{j,1},'.jpg');
fprintf(fid, '%g ', wider_face_train.face_bbx_list{i,1}{j,1}( k, :)); %写入该图片中第k个标注框位置
fprintf(fid, '\n');
end
end
end
end
fclose(fid); %关闭文件</span></span>
[plain] view
plain copy
<span style="font-size:24px;">%功能描述:读取'wider_face_train.mat'文件中存储的图片名及标注矩形框位置(每个人脸矩形框一行)
%格式形如“name.jpg x y x+w y+h”,且x,y,w,h都为整数
clc;clear;
wider_face_train = load('wider_face_train.mat');
fid = fopen('11.txt','w');
for i = 1:61
num_j = length(wider_face_train.file_list{i,1});
for j = 1:num_j
[num_k, num_un] = size(wider_face_train.face_bbx_list{i,1}{j,1});
if num_k == 1
%fprintf(fid, '%s%s', wider_face_val.event_list{i,1},'\');
fprintf(fid, '%s%s ', wider_face_train.file_list{i,1}{j,1},'.jpg');
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 1 )));
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 2 )));
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 1 ) + wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 3 )));
fprintf(fid, '%g', int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 2 ) + wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 4 )));
fprintf(fid, '\n');
else
for k = 1:num_k
%fprintf(fid, '%s%s', wider_face_val.event_list{i,1},'\');
fprintf(fid, '%s%s ', wider_face_train.file_list{i,1}{j,1},'.jpg');
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 1 )));
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 2 )));
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 1 ) + wider_face_train.face_bbx_list{i,1}{j,1}( k, 3 )));
fprintf(fid, '%g', int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 2 ) + wider_face_train.face_bbx_list{i,1}{j,1}( k, 4 )));
fprintf(fid, '\n');
end
end
end
end
fclose(fid);</span>
[plain] view
plain copy
<span style="font-size:24px;">%功能描述:读取'wider_face_train.mat'文件中存储的图片名及标注矩形框位置(每个人脸矩形框一行)
%格式形如“name.jpg x y w h”,且x,y,w,h都为整数
%要求:去掉x,y小于0,且w,h为0的人脸框
clc;clear;
wider_face_train = load('wider_face_val.mat');
fid = fopen('val_chenqi.txt','w');
for i = 1:61
num_j = length(wider_face_train.file_list{i,1});
for j = 1:num_j
[num_k, num_un] = size(wider_face_train.face_bbx_list{i,1}{j,1});
if num_k == 1
%fprintf(fid, '%s%s', wider_face_val.event_list{i,1},'\');
if int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 3 ))==0 | int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 4 ))==0
continue;
end
a1 = int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 1 ));
if a1 < 0
a1 = 0;
end
b1 = int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 2 ));
if b1 < 0
b1 = 0;
end
fprintf(fid, '%s%s ', wider_face_train.file_list{i,1}{j,1},'.jpg');
fprintf(fid, '%g ', a1 );
fprintf(fid, '%g ', b1 );
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 3 )));
fprintf(fid, '%g', int16(wider_face_train.face_bbx_list{i,1}{j,1}( num_k, 4 )));
fprintf(fid, '\n');
else
for k = 1:num_k
%fprintf(fid, '%s%s', wider_face_val.event_list{i,1},'\');
if int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 3 ))==0 | int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 4 ))==0
continue;
end
a2 = int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 1 ));
if a2 < 0
a2 = 0;
end
b2 = int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 2 ));
if b2 < 0
b2 = 0;
end
fprintf(fid, '%s%s ', wider_face_train.file_list{i,1}{j,1},'.jpg');
fprintf(fid, '%g ', a2 );
fprintf(fid, '%g ', b2 );
fprintf(fid, '%g ', int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 3 )));
fprintf(fid, '%g', int16(wider_face_train.face_bbx_list{i,1}{j,1}( k, 4 )));
fprintf(fid, '\n');
end
end
end
end
fclose(fid);</span>
相关文章推荐
- Matlab批量读取元胞数组中数据保存到txt文件中(WIDER FACE数据集中,读取人脸标注矩形框信息)
- Matlab批量读取元胞数组中数据保存到txt文件中(WIDER FACE数据集中,读取人脸标注矩形框信息)
- Matlab批量读取元胞数组中数据保存到txt文件中(WIDER FACE数据集中,读取人脸标注矩形框信息)
- Python3解析MS-Celeb-1M人脸数据集中的FaceImageCroppedWithAlignment.tsv文件
- 目标检测坐标信息txt文件转Pascal VOC XML 格式(仅包括对角框正矩形标注)
- C语言读取txt里面的图像数据字符串换成十六进制然后保存为bmp格式的图像文件
- 读取含有json格式数据的txt文件 并且把数据保存到数据库
- QT和VS读取.txt文件中的数据并保存为数组
- C#中如何将信息保存到txt文件中去,以及如何读取
- 如何将视差数据保存为 txt 数据文件以便在 Matlab 中读取分析?
- 从oracle中读取数据并保存在txt文件中
- Java 读取excel指定行列数据以及将数据保存到txt文件中
- QT和VS读取.txt文件中的数据并保存为数组
- java读取Excel数据,然后写入到txt文件,并批量保存到oracle数据库中
- 读取XML文件数据,XML数据标注格式转换为TXT格式
- 利用正则表达式读取txt文件中的邮箱,电话号码,url地址,手机号,将数据一行一个保存到一个新的文件中去
- C编写以二进制读取文件(任意格式eg :图片),保存到C语言数据格式的TXT文档
- MATLAB中批量从txt文件中读取指定行的数据保存为txt文件
- Matlab读取和保存TXT文件数据
- DEM数据文件的读取与保存