This file is indexed.

/usr/share/routino/www/documentation/limits.html is in routino-www 3.0-3.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>

<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">

<title>Routino : Numerical Limits</title>

<!--
 Routino documentation - ID limits

 Part of the Routino routing software.

 This file Copyright 2013-2015 Andrew M. Bishop

 This program is free software: you can redistribute it and/or modify
 it under the terms of the GNU Affero General Public License as published by
 the Free Software Foundation, either version 3 of the License, or
 (at your option) any later version.

 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 GNU Affero General Public License for more details.

 You should have received a copy of the GNU Affero General Public License
 along with this program.  If not, see http://www.gnu.org/licenses/.
-->

<link href="style.css" type="text/css" rel="stylesheet">
</head>

<body>

<!-- Header Start -->

<div class="header">

<h1>Routino : Numerical Limits</h1>

</div>

<!-- Header End -->

<!-- Content Start -->

<div class="content">

<h2 id="H_1_1">32/64-bit Data IDs</h2>

The
<a class="ext" title="OpenStreetMap" href="http://www.openstreetmap.org/">OpenStreetMap</a>
data uses a numerical identifier for each node, way and relation.  These
identifiers started at 1 and increase for every new item of each type that is
added.  When an object is deleted the identifier is not re-used so the highest
identifier will always be higher than the number of objects.

<p>
The identifier needs to be handled carefully to ensure that it does not overflow
the data type allocated for it.  Depending on the data type used to store the
identifier there are are a number of numerical limits as described below:

<ol>
  <li>If a signed 32-bit integer is used to store the identifier then the
    maximum value that can be handled is 2147483647 (2<sup>31</sup>-1) before
    overflow.
  <li>If an unsigned 32-bit integer is used to store the identifier then the
    maximum value that can be handled is 4294967295 (2<sup>32</sup>-1) before
    overflow.
  <li>If a signed 64-bit integer is used to store the identifier then the
    maximum value that can be handled is 9223372036854775807 (2<sup>63</sup>-1)
    before overflow.
</ol>

For the purposes of this document the possibility of overflow of a 64-bit
integer is ignored.

<p>
The part of Routino that handles the node, way and relation identifiers is the
<tt>planetsplitter</tt> program.


<h3 id="H_1_1_1">ID Above 31-bits</h3>

The first identifier exceeding 31-bits (for a node) is predicted to be created
in the OpenStreetMap database in February 2013.

<p>
All versions of Routino use unsigned 32-bit integers to store the identifier.
Therefore all versions of Routino will continue working correctly when node
number 2147483648 (2<sup>31</sup>) or higher is present.


<h3 id="H_1_1_2">ID Above 32-bits</h3>

The ability of Routino to handle identifiers larger than 32-bits does not depend
on having a 64-bit operating system.

<p>
Before version 2.0.1 of Routino there was no check that the identifier read from
the input data would fit within an unsigned 32-bit integer.  Earlier versions of
Routino will therefore fail to report an error and will process data incorrectly
when node number 4294967296 (2<sup>32</sup>) or higher is present.

<p>
From version 2.0.2 the code is written to allow the node, way and relation
identifier data type to be changed to 64-bits.  This means that a consistent
data type is used for handling identifiers and the format used for printing them
is consistent with the variable type.

<p>
From version 2.0.2 onwards it is possible to make a simple change to the code to
process data with node identifiers above 4294967296 (2<sup>32</sup>) without
error.  The binary format of the database will be unchanged by the use of 64-bit
identifiers (since the identifiers are not stored in the database).

<p>
To recompile with 64-bit node identifiers the file <tt>src/typesx.h</tt> should
be edited and the two lines below changed from:

<pre class="boxed">
typedef uint32_t node_t;

#define Pnode_t PRIu32
</pre>

to:

<pre class="boxed">
typedef uint64_t node_t;

#define Pnode_t PRIu64
</pre>

<p>
A similar change can also be made for way or relation identifiers although since
there are currently fewer of these the limit is not as close to being reached.

<p>
Between version 2.0.2 and version 2.4 a bug means that route relations will
ignore the way or relation identifier if it is equal to 4294967295
(2<sup>32</sup>-1).

<p>
From version 2.4 onwards when a numerical limit is reached the
<tt>planetsplitter</tt> program will exit with an error message that describes
which limit was reached and which data type needs to be changed.


<h2 id="H_1_2">Database Format</h2>

The other limitation in Routino is the number of objects stored in the database
that is generated by the <tt>planetsplitter</tt> data processing.  This number
may be significantly different from the highest identifier in the input data set
for two reasons.  Firstly any nodes, ways or relations that have been deleted
will not be present in the data.  Secondly when a partial planet database
(continent, country or smaller) is processed there will be only a fraction of
the total number of nodes, ways and relations.

<p>
The limiting factor is the largest of the following.
<ol>
  <li>The number of nodes in the input data files.
  <li>The number of segments in the input data files.
  <li>The number of highways in the input data files.
  <li>The number of relations in the input data files.
</ol>

Normally the number of nodes will be the limiting factor.


<h3 id="H_1_2_1">32-bit Indexes</h3>

Before version 1.2 the database could hold up to 4294967295 (2<sup>32</sup>-1)
items of each type (node, segment, way) since an unsigned 32-bit integer is
used.

<p>
Versions 1.3 to 1.4.1 have a limit of 2147483647 (2<sup>31</sup>-1) items since
half of the 32-bit integer range is reserved for fake nodes and segments that
are inserted if a waypoint is not close to a node.

<p>
From version 1.5 the limit is 4294901760 (2<sup>32</sup>-2<sup>16</sup>) for the
number of items of each type that can be stored.  The small remaining part of
the 32-bit unsigned integer range is reserved for fake nodes and segments.


<h3 id="H_1_2_2">64-bit Indexes</h3>

When using a 32-bit operating system it is not possible to create a database
that exceeds about 2GB in total.  This will be fewer than 2<sup>32</sup> objects
in the database in total.  The use of 64-bit indexes will require a 64-bit
operating system.

<p>
From version 2.0.2 onwards it is possible to make a simple change to the code to
index the database objects with 64-bit integers insted of 32-bit integers.

<p>
To recompile with 64-bit index integers the file <tt>src/types.h</tt> should be
edited and the two lines below changed from:

<pre class="boxed">
typedef uint32_t index_t;

#define Pindex_t PRIu32
</pre>

to:

<pre class="boxed">
typedef uint64_t index_t;

#define Pindex_t PRIu64
</pre>

This change will affect nodes, segments, ways and relations together.  The
database that is generated will no longer be compatible with Routino that has
been compiled with 32-bit indexes.  The size of the database will also grow by
about 50% when this change is made.


</div>

<!-- Content End -->

<!-- Footer Start -->

<div class="footer">

<address>
&copy; Andrew M. Bishop - <a href="http://www.routino.org/">http://www.routino.org/</a>
</address>

</div>

<!-- Footer End -->

</body>

</html>