-
Notifications
You must be signed in to change notification settings - Fork 46
/
Copy pathparse_osm.m
113 lines (96 loc) · 3.1 KB
/
parse_osm.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
function [parsed_osm] = parse_osm(osm_xml)
%PARSE_OSM Parse into a structure a loaded OSM XML structure.
%
% parsed_osm = PARSE_OSM(osm_xml) takes as input a MATLAB structure
% osm_xml containing the XML data loaded from an OpenStreetMap file using
% function load_osm_xml, and returns another MATLAB structure containing
% a subset of these data parsed appropriately for further usage by other
% functions.
%
% 2010.11.20 (c) Ioannis Filippidis, [email protected]
%
% See also PARSE_OPENSTREETMAP, LOAD_OSM_XML.
% memo about osm contents
% data primitives
% 1) nodes
% id (unique between nodes)
% lat \in [-90, 90] (latitude)
% lon \in [-180, 180] (longitude)
% ele (elevation = altitude - optional)
% tags
% 2) ways (& closed ways = areas)
% id
% nodes (node ids)
% tags
% 3) relations
% members
% tags (k=v)
% Attributes
parsed_osm.bounds = parse_bounds(osm_xml.bounds);
parsed_osm.node = parse_node(osm_xml.node);
parsed_osm.way = parse_way(osm_xml.way);
%parsed_osm.relation = parse_relation(osm.relation);
parsed_osm.Attributes = osm_xml.Attributes;
function [parsed_bounds] = parse_bounds(bounds)
bounds = bounds.Attributes;
ymax = str2double(bounds.maxlat);
xmax = str2double(bounds.maxlon);
ymin = str2double(bounds.minlat);
xmin = str2double(bounds.minlon);
parsed_bounds = [xmin, xmax; ymin, ymax];
function [parsed_node] = parse_node(node)
Nnodes = size(node,2);
id = zeros(1, Nnodes);
xy = zeros(2, Nnodes);
for i=1:Nnodes
id(1,i) = str2double(node{i}.Attributes.id);
xy(:,i) = [str2double(node{i}.Attributes.lon);...
str2double(node{i}.Attributes.lat)];
end
parsed_node.id = id;
parsed_node.xy = xy;
function [parsed_way] = parse_way(way)
Nways = size(way,2);
id = zeros(1, Nways);
nd = cell(1, Nways);
tag = cell(1, Nways);
for i=1:Nways
waytemp = way{i};
id(1,i) = str2double(waytemp.Attributes.id);
Nnd = size(waytemp.nd, 2);
ndtemp = zeros(1, Nnd);
for j=1:Nnd
if Nnd == 1
ndtemp(1,j) = str2double(waytemp.nd.Attributes.ref);
else
ndtemp(1, j) = str2double(waytemp.nd{j}.Attributes.ref);
end
end
nd{1, i} = ndtemp;
% way with or without tag(s) ?
if isfield(waytemp, 'tag')
tag{1, i} = waytemp.tag;
else
tag{1, i} = []; % no tags for this way
end
% Ntag = size(waytemp.tag,2);
% for k=1:Ntag
% if(strcmp(waytemp.tag{k}.Attributes.k,'name'))
% tag{1,i} = gr2gren(waytemp.tag{k}.Attributes.v);
% end
% end
end
parsed_way.id = id;
parsed_way.nd = nd;
parsed_way.tag = tag;
function [parsed_relation] = parse_relation(relation)
Nrelation = size(relation, 2);
id = zeros(1,Nrelation);
%member = cell(1, Nrelation);
%tag = cell(1, Nrelation);
for i = 1:Nrelation
currelation = relation{i};
curid = currelation.Attributes.id;
id(1, i) = str2double(curid);
end
parsed_relation.id = id;