Hex Artifact Content
Not logged in

Artifact 661cc94986b9e03b4c542fcae483050d37517292:

Wiki page [VirtualRouting] by sandro 2018-03-23 22:06:48.
0000: 44 20 32 30 31 38 2d 30 33 2d 32 33 54 32 32 3a  D 2018-03-23T22:
0010: 30 36 3a 34 38 2e 35 34 37 0a 4c 20 56 69 72 74  06:48.547.L Virt
0020: 75 61 6c 52 6f 75 74 69 6e 67 0a 50 20 33 35 37  ualRouting.P 357
0030: 33 61 36 31 38 30 63 30 31 63 65 33 61 62 66 39  3a6180c01ce3abf9
0040: 62 39 65 30 61 39 36 61 37 66 36 36 37 39 34 39  b9e0a96a7f667949
0050: 65 64 33 65 39 0a 55 20 73 61 6e 64 72 6f 0a 57  ed3e9.U sandro.W
0060: 20 38 36 34 34 0a 3c 61 20 68 72 65 66 3d 22 68   8644.<a href="h
0070: 74 74 70 73 3a 2f 2f 77 77 77 2e 67 61 69 61 2d  ttps://www.gaia-
0080: 67 69 73 2e 69 74 2f 66 6f 73 73 69 6c 2f 6c 69  gis.it/fossil/li
0090: 62 73 70 61 74 69 61 6c 69 74 65 2f 77 69 6b 69  bspatialite/wiki
00a0: 3f 6e 61 6d 65 3d 34 2e 33 2e 30 2d 64 6f 63 22  ?name=4.3.0-doc"
00b0: 3e 62 61 63 6b 3c 2f 61 3e 3c 68 72 3e 3c 62 72  >back</a><hr><br
00c0: 3e 0d 0a 3c 68 31 3e 49 6e 74 72 6f 64 75 63 74  >..<h1>Introduct
00d0: 69 6f 6e 3c 2f 68 31 3e 0d 0a 50 72 65 76 69 6f  ion</h1>..Previo
00e0: 75 73 20 76 65 72 73 69 6f 6e 73 20 6f 66 20 53  us versions of S
00f0: 70 61 74 69 61 4c 69 74 65 20 74 72 61 64 69 74  patiaLite tradit
0100: 69 6f 6e 61 6c 6c 79 20 73 75 70 70 6f 72 74 65  ionally supporte
0110: 64 20 61 20 3c 62 3e 70 75 72 65 20 53 51 4c 20  d a <b>pure SQL 
0120: 72 6f 75 74 69 6e 67 20 6d 6f 64 75 6c 65 3c 2f  routing module</
0130: 62 3e 20 74 68 61 74 20 77 61 73 20 6e 61 6d 65  b> that was name
0140: 64 20 3c 61 20 68 72 65 66 3d 22 68 74 74 70 73  d <a href="https
0150: 3a 2f 2f 77 77 77 2e 67 61 69 61 2d 67 69 73 2e  ://www.gaia-gis.
0160: 69 74 2f 66 6f 73 73 69 6c 2f 6c 69 62 73 70 61  it/fossil/libspa
0170: 74 69 61 6c 69 74 65 2f 77 69 6b 69 3f 6e 61 6d  tialite/wiki?nam
0180: 65 3d 56 69 72 74 75 61 6c 4e 65 74 77 6f 72 6b  e=VirtualNetwork
0190: 2b 72 65 6c 6f 61 64 65 64 22 3e 56 69 72 74 75  +reloaded">Virtu
01a0: 61 6c 4e 65 74 77 6f 72 6b 3c 2f 61 3e 2e 3c 62  alNetwork</a>.<b
01b0: 72 3e 3c 62 72 3e 0d 0a 53 69 6e 63 65 20 76 65  r><br>..Since ve
01c0: 72 73 69 6f 6e 20 3c 62 3e 35 2e 30 2e 30 3c 2f  rsion <b>5.0.0</
01d0: 62 3e 20 61 20 62 72 61 6e 64 20 6e 65 77 20 3c  b> a brand new <
01e0: 62 3e 72 6f 75 74 69 6e 67 20 6d 6f 64 75 6c 65  b>routing module
01f0: 3c 2f 62 3e 20 28 6d 6f 72 65 20 61 64 76 61 6e  </b> (more advan
0200: 63 65 64 20 61 6e 64 20 73 6f 70 68 69 73 74 69  ced and sophisti
0210: 63 61 74 65 64 29 20 69 73 20 61 76 61 69 6c 61  cated) is availa
0220: 62 6c 65 2c 20 74 68 61 74 20 69 73 20 63 61 6c  ble, that is cal
0230: 6c 65 64 20 3c 62 3e 56 69 72 74 75 61 6c 52 6f  led <b>VirtualRo
0240: 75 74 69 6e 67 3c 2f 62 3e 2e 3c 62 72 3e 0d 0a  uting</b>.<br>..
0250: 54 68 65 20 6e 6f 77 20 6f 62 73 6f 6c 65 74 65  The now obsolete
0260: 20 3c 62 3e 56 69 72 74 75 61 6c 4e 65 74 77 6f   <b>VirtualNetwo
0270: 72 6b 3c 2f 62 3e 20 69 73 20 73 74 69 6c 6c 20  rk</b> is still 
0280: 73 75 70 70 6f 72 74 65 64 20 62 79 20 76 65 72  supported by ver
0290: 73 69 6f 6e 20 3c 62 3e 35 2e 30 2e 30 3c 2f 62  sion <b>5.0.0</b
02a0: 3e 20 73 6f 20 61 73 20 74 6f 20 6e 6f 74 20 63  > so as to not c
02b0: 61 75 73 65 20 61 6e 20 61 62 72 75 70 74 20 62  ause an abrupt b
02c0: 72 65 61 6b 20 74 6f 20 61 6c 72 65 61 64 79 20  reak to already 
02d0: 65 78 69 73 74 69 6e 67 20 61 70 70 6c 69 63 61  existing applica
02e0: 74 69 6f 6e 73 2c 20 62 75 74 20 77 69 6c 6c 20  tions, but will 
02f0: 70 72 65 73 75 6d 61 62 6c 79 20 62 65 20 64 69  presumably be di
0300: 73 63 6f 6e 74 69 6e 75 65 64 20 69 6e 20 66 75  scontinued in fu
0310: 74 75 72 65 20 76 65 72 73 69 6f 6e 73 2e 3c 62  ture versions.<b
0320: 72 3e 0d 0a 55 73 69 6e 67 20 3c 62 3e 56 69 72  r>..Using <b>Vir
0330: 74 75 61 6c 52 6f 75 74 69 6e 67 3c 2f 62 3e 20  tualRouting</b> 
0340: 69 6e 73 74 65 61 64 20 6f 66 20 3c 62 3e 56 69  instead of <b>Vi
0350: 72 74 75 61 6c 4e 65 74 77 69 72 6b 3c 2f 62 3e  rtualNetwirk</b>
0360: 20 69 73 20 77 61 72 6d 6c 79 20 72 65 63 6f 6d   is warmly recom
0370: 6d 65 6e 64 65 64 20 66 6f 72 20 61 6e 79 20 6e  mended for any n
0380: 65 77 20 64 65 76 65 6c 6f 70 6d 65 6e 74 2e 20  ew development. 
0390: 0d 0a 3c 68 32 3e 54 68 65 6f 72 65 74 69 63 61  ..<h2>Theoretica
03a0: 6c 20 66 6f 75 6e 64 61 74 69 6f 6e 73 20 2d 20  l foundations - 
03b0: 61 6e 20 75 6c 74 72 61 2d 71 75 69 63 6b 20 72  an ultra-quick r
03c0: 65 63 61 6c 6c 3c 2f 68 32 3e 0d 0a 41 6c 6c 20  ecall</h2>..All 
03d0: 3c 62 3e 52 6f 75 74 69 6e 67 20 61 6c 67 6f 72  <b>Routing algor
03e0: 69 74 68 6d 73 3c 2f 62 3e 20 28 3c 69 3e 61 6b  ithms</b> (<i>ak
03f0: 61 3c 2f 69 3e 20 3c 62 3e 53 68 6f 72 74 65 73  a</i> <b>Shortes
0400: 74 20 50 61 74 68 3c 2f 62 3e 20 61 6c 67 6f 72  t Path</b> algor
0410: 69 74 68 6d 73 29 20 61 72 65 20 62 61 73 65 64  ithms) are based
0420: 20 6f 6e 20 74 68 65 20 6d 61 74 68 65 6d 61 74   on the mathemat
0430: 69 63 73 20 6f 66 20 74 68 65 20 3c 61 20 68 72  ics of the <a hr
0440: 65 66 3d 22 68 74 74 70 73 3a 2f 2f 65 6e 2e 77  ef="https://en.w
0450: 69 6b 69 70 65 64 69 61 2e 6f 72 67 2f 77 69 6b  ikipedia.org/wik
0460: 69 2f 47 72 61 70 68 5f 74 68 65 6f 72 79 22 3e  i/Graph_theory">
0470: 47 72 61 70 68 20 74 68 65 6f 72 79 3c 2f 61 3e  Graph theory</a>
0480: 20 6f 72 20 74 6f 20 62 65 20 6d 6f 72 65 20 70   or to be more p
0490: 72 65 63 69 73 65 3a 20 6f 6e 20 3c 62 3e 57 65  recise: on <b>We
04a0: 69 67 68 74 65 64 20 47 72 61 70 68 73 3c 2f 62  ighted Graphs</b
04b0: 3e 2e 0d 0a 3c 62 72 3e 0d 0a 3c 69 6d 67 20 73  >...<br>..<img s
04c0: 72 63 3d 22 68 74 74 70 3a 2f 2f 77 77 77 2e 67  rc="http://www.g
04d0: 61 69 61 2d 67 69 73 2e 69 74 2f 67 61 69 61 2d  aia-gis.it/gaia-
04e0: 73 69 6e 73 2f 6e 65 74 77 6f 72 6b 2e 70 6e 67  sins/network.png
04f0: 22 20 61 6c 74 3d 22 6e 65 74 77 6f 72 6b 22 3e  " alt="network">
0500: 0d 0a 3c 62 72 3e 0d 0a 41 20 74 6f 70 6f 6c 6f  ..<br>..A topolo
0510: 67 69 63 61 6c 6c 79 20 76 61 6c 69 64 20 3c 62  gically valid <b
0520: 3e 4e 65 74 77 6f 72 6b 3c 2f 62 3e 20 69 73 20  >Network</b> is 
0530: 61 20 64 61 74 61 73 65 74 20 74 68 61 74 20 66  a dataset that f
0540: 75 6c 66 69 6c 6c 73 20 74 68 65 20 66 6f 6c 6c  ulfills the foll
0550: 6f 77 69 6e 67 20 72 65 71 75 69 72 65 6d 65 6e  owing requiremen
0560: 74 73 3a 0d 0a 3c 75 6c 3e 0d 0a 3c 6c 69 3e 41  ts:..<ul>..<li>A
0570: 6c 6c 20 69 74 65 6d 73 20 69 6e 20 74 68 65 20  ll items in the 
0580: 64 61 74 61 73 65 74 20 61 72 65 20 63 61 6c 6c  dataset are call
0590: 65 64 20 3c 62 3e 4c 69 6e 6b 73 3c 2f 62 3e 20  ed <b>Links</b> 
05a0: 28 3c 69 3e 61 6b 61 3c 2f 69 3e 20 3c 62 3e 41  (<i>aka</i> <b>A
05b0: 72 63 73 3c 2f 62 3e 29 2c 20 61 6e 64 20 61 72  rcs</b>), and ar
05c0: 65 20 65 78 70 65 63 74 65 64 20 74 6f 20 72 65  e expected to re
05d0: 70 72 65 73 65 6e 74 20 73 6f 6d 65 20 6f 72 69  present some ori
05e0: 65 6e 74 65 64 20 63 6f 6e 6e 65 63 74 69 6f 6e  ented connection
05f0: 20 6a 6f 69 6e 69 6e 67 20 74 77 6f 20 3c 62 3e   joining two <b>
0600: 4e 6f 64 65 73 3c 2f 62 3e 2e 3c 62 72 3e 0d 0a  Nodes</b>.<br>..
0610: 3c 75 3e 45 78 61 6d 70 6c 65 3c 2f 75 3e 3a 20  <u>Example</u>: 
0620: 69 6e 20 74 68 65 20 61 62 6f 76 65 20 66 69 67  in the above fig
0630: 75 72 65 20 4c 69 6e 6b 20 3c 62 3e 4c 33 3c 2f  ure Link <b>L3</
0640: 62 3e 20 63 6f 6e 6e 65 63 74 73 20 4e 6f 64 65  b> connects Node
0650: 73 20 3c 62 3e 4e 32 3c 2f 62 3e 20 61 6e 64 20  s <b>N2</b> and 
0660: 3c 62 3e 4e 35 3c 2f 62 3e 2e 3c 2f 6c 69 3e 0d  <b>N5</b>.</li>.
0670: 0a 3c 6c 69 3e 53 6f 20 61 6c 6c 20 3c 62 3e 4c  .<li>So all <b>L
0680: 69 6e 6b 73 3c 2f 62 3e 20 61 72 65 20 61 6c 77  inks</b> are alw
0690: 61 79 73 20 65 78 70 65 63 74 65 64 20 74 6f 20  ays expected to 
06a0: 65 78 70 6c 69 63 69 74 6c 79 20 72 65 66 65 72  explicitly refer
06b0: 65 6e 63 65 20 61 20 3c 62 3e 53 74 61 72 74 2d  ence a <b>Start-
06c0: 4e 6f 64 65 3c 2f 62 3e 20 28 3c 69 3e 61 6b 61  Node</b> (<i>aka
06d0: 3c 2f 69 3e 20 3c 62 3e 4e 6f 64 65 2d 46 72 6f  </i> <b>Node-Fro
06e0: 6d 3c 2f 62 3e 29 20 61 6e 64 20 61 6e 20 3c 62  m</b>) and an <b
06f0: 3e 45 6e 64 2d 4e 6f 64 65 3c 2f 62 3e 20 28 3c  >End-Node</b> (<
0700: 69 3e 61 6b 61 3c 2f 69 3e 20 3c 62 3e 4e 6f 64  i>aka</i> <b>Nod
0710: 65 2d 54 6f 3c 2f 62 3e 29 2e 0d 0a 3c 75 6c 3e  e-To</b>)...<ul>
0720: 0d 0a 3c 6c 69 3e 4c 69 6e 6b 73 20 61 72 65 20  ..<li>Links are 
0730: 61 6c 77 61 79 73 20 3c 62 3e 6f 72 69 65 6e 74  always <b>orient
0740: 65 64 3c 2f 62 3e 2c 20 61 6e 64 20 74 68 65 69  ed</b>, and thei
0750: 72 20 6e 61 74 75 72 61 6c 20 64 69 72 65 63 74  r natural direct
0760: 69 6f 6e 20 69 73 20 3c 62 3e 46 72 6f 6d 2d 54  ion is <b>From-T
0770: 6f 3c 2f 62 3e 3a 0d 0a 3c 75 6c 3e 0d 0a 3c 6c  o</b>:..<ul>..<l
0780: 69 3e 69 6e 20 61 6e 20 3c 62 3e 75 6e 69 64 69  i>in an <b>unidi
0790: 72 65 63 74 69 6f 6e 61 6c 3c 2f 62 3e 20 4e 65  rectional</b> Ne
07a0: 74 77 6f 72 6b 20 65 61 63 68 20 4c 69 6e 6b 20  twork each Link 
07b0: 69 73 20 61 6e 20 3c 62 3e 6f 6e 65 2d 77 61 79  is an <b>one-way
07c0: 3c 2f 62 3e 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e  </b> connection.
07d0: 3c 62 72 3e 0d 0a 49 66 20 74 68 65 20 63 6f 6e  <br>..If the con
07e0: 6e 65 63 74 69 6f 6e 20 69 73 20 61 76 61 69 6c  nection is avail
07f0: 61 62 6c 65 20 69 6e 20 74 68 65 20 6f 70 70 6f  able in the oppo
0800: 73 69 74 65 20 64 69 72 65 63 74 69 6f 6e 20 61  site direction a
0810: 20 73 65 63 6f 6e 64 20 4c 69 6e 6b 20 6d 75 73   second Link mus
0820: 74 20 62 65 20 65 78 70 6c 69 63 69 74 6c 79 20  t be explicitly 
0830: 64 65 63 6c 61 72 65 64 2e 3c 62 72 3e 0d 0a 3c  declared.<br>..<
0840: 75 3e 45 78 61 6d 70 6c 65 3c 2f 75 3e 3a 20 4c  u>Example</u>: L
0850: 69 6e 6b 20 3c 62 3e 58 31 3c 2f 62 3e 20 67 6f  ink <b>X1</b> go
0860: 65 73 20 66 72 6f 6d 20 4e 6f 64 65 20 3c 62 3e  es from Node <b>
0870: 41 3c 2f 62 3e 20 74 6f 20 4e 6f 64 65 20 3c 62  A</b> to Node <b
0880: 3e 42 3c 2f 62 3e 2c 20 61 6e 64 20 4c 69 6e 6b  >B</b>, and Link
0890: 20 3c 62 3e 58 32 3c 2f 62 3e 20 67 6f 65 73 20   <b>X2</b> goes 
08a0: 66 72 6f 6d 20 4e 6f 64 65 20 3c 62 3e 42 3c 2f  from Node <b>B</
08b0: 62 3e 20 74 6f 20 4e 6f 64 65 20 3c 62 3e 41 3c  b> to Node <b>A<
08c0: 2f 62 3e 2e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 69  /b>.</li>..<li>i
08d0: 6e 20 61 20 3c 62 3e 62 69 64 69 72 65 63 74 69  n a <b>bidirecti
08e0: 6f 6e 61 6c 3c 2f 62 3e 20 4e 65 74 77 6f 72 6b  onal</b> Network
08f0: 20 61 6c 6c 20 4c 69 6e 6b 73 20 61 72 65 20 61   all Links are a
0900: 73 73 75 6d 65 64 20 74 6f 20 65 73 74 61 62 6c  ssumed to establ
0910: 69 73 68 20 61 20 63 6f 6e 6e 65 63 74 69 6f 6e  ish a connection
0920: 20 69 6e 20 62 6f 74 68 20 64 69 72 65 63 74 69   in both directi
0930: 6f 6e 73 2e 3c 62 72 3e 0d 0a 44 65 66 69 6e 69  ons.<br>..Defini
0940: 74 69 6e 67 20 61 6e 20 3c 62 3e 6f 6e 65 2d 77  ting an <b>one-w
0950: 61 79 20 63 6f 6e 6e 65 63 74 69 6f 6e 3c 2f 62  ay connection</b
0960: 3e 20 72 65 71 75 69 72 65 73 20 61 6e 20 61 70  > requires an ap
0970: 70 72 6f 70 72 69 61 74 65 20 61 74 74 72 69 62  propriate attrib
0980: 75 74 65 20 74 6f 20 62 65 20 73 65 74 20 28 73  ute to be set (s
0990: 65 65 20 62 65 6c 6f 77 29 2e 3c 2f 6c 69 3e 0d  ee below).</li>.
09a0: 0a 3c 2f 75 6c 3e 3c 2f 6c 69 3e 0d 0a 3c 6c 69  .</ul></li>..<li
09b0: 3e 54 68 65 20 3c 62 3e 53 74 61 72 74 2d 3c 2f  >The <b>Start-</
09c0: 62 3e 20 61 6e 64 20 3c 62 3e 45 6e 64 2d 4e 6f  b> and <b>End-No
09d0: 64 65 3c 2f 62 3e 20 63 6f 75 6c 64 20 65 76 65  de</b> could eve
09e0: 6e 74 75 61 6c 6c 79 20 62 65 20 74 68 65 20 73  ntually be the s
09f0: 61 6d 65 2c 20 61 6e 64 20 69 6e 20 74 68 69 73  ame, and in this
0a00: 20 63 61 73 65 20 77 65 27 6c 6c 20 68 61 76 65   case we'll have
0a10: 20 61 20 3c 62 3e 73 65 6c 66 2d 63 6c 6f 73 65   a <b>self-close
0a20: 64 3c 2f 62 3e 20 4c 69 6e 6b 2e 3c 2f 6c 69 3e  d</b> Link.</li>
0a30: 0d 0a 3c 6c 69 3e 4e 65 74 77 6f 72 6b 27 73 20  ..<li>Network's 
0a40: 4c 69 6e 6b 73 20 3c 62 3e 63 61 6e 3c 2f 62 3e  Links <b>can</b>
0a50: 20 65 76 65 6e 74 75 61 6c 6c 79 20 64 65 66 69   eventually defi
0a60: 6e 65 20 61 20 6c 69 6e 65 61 72 20 47 65 6f 6d  ne a linear Geom
0a70: 65 74 72 79 20 28 3c 62 3e 4c 49 4e 45 53 54 52  etry (<b>LINESTR
0a80: 49 4e 47 3c 2f 62 3e 29 20 67 6f 69 6e 67 20 66  ING</b>) going f
0a90: 72 6f 6d 20 74 68 65 20 3c 62 3e 53 74 61 72 74  rom the <b>Start
0aa0: 2d 4e 6f 64 65 3c 2f 62 3e 20 74 6f 20 74 68 65  -Node</b> to the
0ab0: 20 3c 62 3e 45 6e 64 2d 4e 6f 64 65 3c 2f 62 3e   <b>End-Node</b>
0ac0: 2c 20 62 75 74 20 74 68 69 73 20 69 73 20 61 6e  , but this is an
0ad0: 20 6f 70 74 69 6f 6e 61 6c 20 66 65 61 74 75 72   optional featur
0ae0: 65 2c 20 6e 6f 74 20 61 20 6d 61 6e 64 61 74 6f  e, not a mandato
0af0: 72 79 20 72 65 71 75 69 72 65 6d 65 6e 74 2e 3c  ry requirement.<
0b00: 2f 6c 69 3e 0d 0a 3c 6c 69 3e 57 68 61 74 20 69  /li>..<li>What i
0b10: 73 20 61 62 73 6f 6c 75 74 65 6c 79 20 6d 61 6e  s absolutely man
0b20: 64 61 74 6f 72 79 20 69 73 20 74 68 61 74 20 65  datory is that e
0b30: 61 63 68 20 3c 62 3e 4c 69 6e 6b 3c 2f 62 3e 20  ach <b>Link</b> 
0b40: 6d 75 73 74 20 65 78 70 6c 69 63 69 74 6c 79 20  must explicitly 
0b50: 72 65 66 65 72 65 6e 63 65 20 69 74 73 20 3c 62  reference its <b
0b60: 3e 4e 6f 64 65 73 3c 2f 62 3e 2e 3c 2f 6c 69 3e  >Nodes</b>.</li>
0b70: 0d 0a 3c 2f 75 6c 3e 3c 2f 6c 69 3e 0d 0a 3c 6c  ..</ul></li>..<l
0b80: 69 3e 41 20 4e 65 74 77 6f 72 6b 20 73 75 70 70  i>A Network supp
0b90: 6f 72 74 69 6e 67 20 47 65 6f 6d 65 74 72 69 65  orting Geometrie
0ba0: 73 20 69 73 20 61 20 3c 62 3e 53 70 61 74 69 61  s is a <b>Spatia
0bb0: 6c 20 4e 65 74 77 6f 72 6b 3c 2f 62 3e 3b 20 6f  l Network</b>; o
0bc0: 74 68 65 72 77 69 73 65 20 61 20 4e 65 74 77 6f  therwise a Netwo
0bd0: 72 6b 20 6c 61 63 6b 69 6e 67 20 61 6e 79 20 47  rk lacking any G
0be0: 65 6f 6d 65 74 72 79 20 69 73 20 61 20 3c 62 3e  eometry is a <b>
0bf0: 4c 6f 67 69 63 61 6c 20 4e 65 74 77 6f 72 6b 3c  Logical Network<
0c00: 2f 62 3e 2e 0d 0a 3c 75 6c 3e 0d 0a 3c 6c 69 3e  /b>...<ul>..<li>
0c10: 49 6e 20 61 20 3c 62 3e 53 70 61 74 69 61 6c 20  In a <b>Spatial 
0c20: 4e 65 74 77 6f 72 6b 3c 2f 62 3e 20 61 6c 6c 20  Network</b> all 
0c30: 4c 69 6e 6b 73 20 3c 62 3e 6d 75 73 74 3c 2f 62  Links <b>must</b
0c40: 3e 20 68 61 76 65 20 61 20 63 6f 72 72 65 73 70  > have a corresp
0c50: 6f 6e 64 69 6e 67 20 47 65 6f 6d 65 74 72 79 2e  onding Geometry.
0c60: 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 49 6e 20 61 20  </li>..<li>In a 
0c70: 3c 62 3e 4c 6f 67 69 63 61 6c 20 4e 65 74 77 6f  <b>Logical Netwo
0c80: 72 6b 3c 2f 62 3e 20 61 6c 6c 20 4c 69 6e 6b 73  rk</b> all Links
0c90: 20 3c 62 3e 61 72 65 20 73 74 72 69 63 74 6c 79   <b>are strictly
0ca0: 20 66 6f 72 62 69 64 64 65 6e 3c 2f 62 3e 20 74   forbidden</b> t
0cb0: 6f 20 68 61 76 65 20 61 6e 79 20 47 65 6f 6d 65  o have any Geome
0cc0: 74 72 79 2e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 49  try.</li>..<li>I
0cd0: 6e 20 61 20 3c 62 3e 53 70 61 74 69 61 6c 20 4e  n a <b>Spatial N
0ce0: 65 74 77 6f 72 6b 3c 2f 62 3e 20 62 6f 74 68 20  etwork</b> both 
0cf0: 74 68 65 20 3c 62 3e 53 74 61 72 74 50 6f 69 6e  the <b>StartPoin
0d00: 74 3c 2f 62 3e 20 61 6e 64 20 3c 62 3e 45 6e 64  t</b> and <b>End
0d10: 50 6f 69 6e 74 3c 2f 62 3e 20 6f 66 20 65 61 63  Point</b> of eac
0d20: 68 20 4c 69 6e 6b 27 73 20 3c 62 3e 4c 49 4e 45  h Link's <b>LINE
0d30: 53 54 52 49 4e 47 3c 2f 62 3e 20 61 72 65 20 61  STRING</b> are a
0d40: 6c 77 61 79 73 20 65 78 70 65 63 74 65 64 20 74  lways expected t
0d50: 6f 20 65 78 61 63 74 6c 79 20 63 6f 69 6e 63 69  o exactly coinci
0d60: 64 65 20 77 69 74 68 20 74 68 65 20 63 6f 72 72  de with the corr
0d70: 65 73 70 6f 6e 64 69 6e 67 20 3c 62 3e 4e 6f 64  esponding <b>Nod
0d80: 65 73 3c 2f 62 3e 2e 3c 2f 6c 69 3e 0d 0a 3c 2f  es</b>.</li>..</
0d90: 75 6c 3e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 49 6e  ul></li>..<li>In
0da0: 20 61 20 3c 62 3e 53 70 61 74 69 61 6c 20 4e 65   a <b>Spatial Ne
0db0: 74 77 6f 72 6b 3c 2f 62 3e 20 61 6c 6c 20 72 65  twork</b> all re
0dc0: 66 65 72 65 6e 63 65 73 20 74 6f 20 74 68 65 20  ferences to the 
0dd0: 73 61 6d 65 20 3c 62 3e 4e 6f 64 65 3c 2f 62 3e  same <b>Node</b>
0de0: 20 62 79 20 64 69 66 66 65 72 65 6e 74 20 4c 69   by different Li
0df0: 6e 6b 73 20 3c 62 3e 6d 75 73 74 3c 2f 62 3e 20  nks <b>must</b> 
0e00: 62 65 20 61 6e 20 65 78 61 63 74 20 6d 61 74 63  be an exact matc
0e10: 68 2e 3c 62 72 3e 0d 0a 3c 75 3e 45 78 61 6d 70  h.<br>..<u>Examp
0e20: 6c 65 3c 2f 75 3e 3a 20 4e 6f 64 65 20 3c 62 3e  le</u>: Node <b>
0e30: 4e 35 3c 2f 62 3e 20 69 73 20 73 68 61 72 65 64  N5</b> is shared
0e40: 20 62 79 20 4c 69 6e 6b 73 20 3c 62 3e 4c 33 3c   by Links <b>L3<
0e50: 2f 62 3e 2c 20 3c 62 3e 4c 36 3c 2f 62 3e 2c 20  /b>, <b>L6</b>, 
0e60: 3c 62 3e 4c 37 3c 2f 62 3e 2c 20 3c 62 3e 4c 39  <b>L7</b>, <b>L9
0e70: 3c 2f 62 3e 20 61 6e 64 20 3c 62 3e 4c 31 30 3c  </b> and <b>L10<
0e80: 2f 62 3e 2c 20 73 6f 20 61 6c 6c 20 74 68 65 69  /b>, so all thei
0e90: 72 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20  r corresponding 
0ea0: 4c 49 4e 45 53 54 52 49 4e 47 53 20 61 72 65 20  LINESTRINGS are 
0eb0: 65 78 70 65 63 74 65 64 20 74 6f 20 68 61 76 65  expected to have
0ec0: 20 74 68 65 20 63 6f 72 72 65 73 70 6f 6e 64 69   the correspondi
0ed0: 6e 67 20 65 78 74 72 65 6d 69 74 79 20 28 3c 62  ng extremity (<b
0ee0: 3e 53 74 61 72 74 2d 3c 2f 62 3e 20 6f 72 20 3c  >Start-</b> or <
0ef0: 62 3e 45 6e 64 2d 3c 2f 62 3e 2c 20 64 65 70 65  b>End-</b>, depe
0f00: 6e 64 69 6e 67 20 6f 6e 20 74 68 65 20 6f 72 69  nding on the ori
0f10: 65 6e 74 61 74 69 6f 6e 29 20 70 6f 69 6e 74 73  entation) points
0f20: 20 74 68 61 74 20 6d 75 73 74 20 65 78 61 63 74   that must exact
0f30: 6c 79 20 6d 61 74 63 68 20 74 68 65 20 6f 74 68  ly match the oth
0f40: 65 72 2e 3c 62 72 3e 0d 0a 41 20 3c 62 3e 74 6f  er.<br>..A <b>to
0f50: 70 6f 6c 6f 67 69 63 61 6c 20 69 6e 63 6f 6e 73  pological incons
0f60: 69 73 74 65 6e 63 79 3c 2f 62 3e 20 65 78 69 73  istency</b> exis
0f70: 74 73 20 69 66 20 61 6e 79 20 6f 66 20 74 68 65  ts if any of the
0f80: 73 65 20 63 6f 6e 64 69 74 69 6f 6e 73 20 61 72  se conditions ar
0f90: 65 20 6e 6f 74 20 73 61 74 69 73 66 69 65 64 2c  e not satisfied,
0fa0: 20 77 68 69 63 68 20 6c 65 61 64 73 20 74 6f 20   which leads to 
0fb0: 61 6e 20 3c 62 3e 69 6e 76 61 6c 69 64 3c 2f 62  an <b>invalid</b
0fc0: 3e 20 4e 65 74 77 6f 72 6b 2e 3c 2f 6c 69 3e 0d  > Network.</li>.
0fd0: 0a 3c 6c 69 3e 49 6e 20 61 20 3c 62 3e 53 70 61  .<li>In a <b>Spa
0fe0: 74 69 61 6c 20 4e 65 74 77 6f 72 6b 3c 2f 62 3e  tial Network</b>
0ff0: 20 74 77 6f 0d 0a 3c 6c 69 3e 41 63 63 6f 72 64   two..<li>Accord
1000: 69 6e 67 6c 79 20 74 6f 20 74 68 65 20 61 62 6f  ingly to the abo
1010: 76 65 20 70 72 65 6d 69 73 65 73 2c 20 3c 62 3e  ve premises, <b>
1020: 4e 6f 64 65 73 3c 2f 62 3e 20 61 72 65 20 6e 65  Nodes</b> are ne
1030: 76 65 72 20 65 78 70 65 63 74 65 64 20 74 6f 20  ver expected to 
1040: 62 65 20 65 78 70 6c 69 63 69 74 6c 79 20 64 65  be explicitly de
1050: 63 6c 61 72 65 64 20 69 6e 20 61 20 73 65 70 61  clared in a sepa
1060: 72 61 74 65 20 54 61 62 6c 65 2e 3c 62 72 3e 0d  rate Table.<br>.
1070: 0a 4a 75 73 74 20 61 20 73 69 6e 67 6c 65 20 54  .Just a single T
1080: 61 62 6c 65 20 64 65 63 6c 61 72 69 6e 67 20 61  able declaring a
1090: 6c 6c 20 3c 62 3e 4c 69 6e 6b 73 3c 2f 62 3e 20  ll <b>Links</b> 
10a0: 69 73 20 72 65 71 75 69 72 65 64 20 69 6e 20 6f  is required in o
10b0: 72 64 65 72 20 74 6f 20 66 75 6c 6c 79 20 64 65  rder to fully de
10c0: 66 69 6e 65 20 61 20 74 6f 70 6f 6c 6f 67 69 63  fine a topologic
10d0: 61 6c 6c 79 20 76 61 6c 69 64 20 4e 65 74 77 6f  ally valid Netwo
10e0: 72 6b 2e 3c 62 72 3e 0d 0a 41 6c 6c 20 74 68 65  rk.<br>..All the
10f0: 20 4e 6f 64 65 73 20 63 61 6e 20 74 68 65 6e 20   Nodes can then 
1100: 62 65 20 65 61 73 69 6c 79 20 65 78 74 72 61 63  be easily extrac
1110: 74 65 64 20 66 72 6f 6d 20 74 68 65 20 4c 69 6e  ted from the Lin
1120: 6b 73 27 20 64 65 66 69 6e 69 74 69 6f 6e 73 20  ks' definitions 
1130: 61 6e 64 20 74 68 65 20 63 6f 6f 72 64 69 6e 61  and the coordina
1140: 74 65 73 20 66 6f 72 20 65 61 63 68 20 4e 6f 64  tes for each Nod
1150: 65 20 63 61 6e 20 62 65 20 64 69 72 65 63 74 6c  e can be directl
1160: 79 20 73 65 74 20 62 79 20 65 78 74 72 61 63 74  y set by extract
1170: 69 6e 67 20 74 68 65 20 65 78 74 72 65 6d 65 20  ing the extreme 
1180: 50 6f 69 6e 74 20 6f 66 20 74 68 65 20 63 6f 72  Point of the cor
1190: 72 65 73 70 6f 6e 64 69 6e 67 20 4c 69 6e 65 73  responding Lines
11a0: 74 72 69 6e 67 73 2e 3c 62 72 3e 0d 0a 49 66 20  trings.<br>..If 
11b0: 61 6e 79 20 6d 69 73 6d 61 74 63 68 20 69 73 20  any mismatch is 
11c0: 64 65 74 65 63 74 65 64 20 74 68 69 73 20 73 75  detected this su
11d0: 72 65 6c 79 20 6d 65 61 6e 73 20 74 68 61 74 20  rely means that 
11e0: 74 68 65 20 4e 65 74 77 6f 72 6b 20 69 73 20 69  the Network is i
11f0: 6e 76 61 6c 69 64 2e 3c 2f 6c 69 3e 0d 0a 3c 6c  nvalid.</li>..<l
1200: 69 3e 41 20 3c 62 3e 4c 69 6e 6b 3c 2f 62 3e 20  i>A <b>Link</b> 
1210: 6d 61 79 20 6c 65 67 69 74 69 6d 61 74 65 6c 79  may legitimately
1220: 20 73 65 6c 66 2d 69 6e 74 65 72 73 65 63 74 20   self-intersect 
1230: 69 74 73 65 6c 66 20 28 65 2e 67 2e 20 66 6f 72  itself (e.g. for
1240: 6d 69 6e 67 20 61 20 6c 6f 6f 70 29 2c 20 61 73  ming a loop), as
1250: 20 73 68 6f 77 6e 20 69 6e 20 74 68 65 20 61 62   shown in the ab
1260: 6f 76 65 20 66 69 67 75 72 65 20 62 79 20 4c 69  ove figure by Li
1270: 6e 6b 20 3c 62 3e 4c 31 35 3c 2f 62 3e 20 28 6f  nk <b>L15</b> (o
1280: 72 61 6e 67 65 20 73 70 6f 74 29 2e 3c 2f 6c 69  range spot).</li
1290: 3e 0d 0a 3c 6c 69 3e 54 77 6f 20 3c 62 3e 4c 69  >..<li>Two <b>Li
12a0: 6e 6b 73 3c 2f 62 3e 20 6d 61 79 20 6c 65 67 69  nks</b> may legi
12b0: 74 69 6d 61 74 65 6c 79 20 69 6e 74 65 72 73 65  timately interse
12c0: 63 74 20 77 68 65 72 65 20 6e 6f 20 4e 6f 64 65  ct where no Node
12d0: 20 65 78 69 73 74 73 2c 20 61 73 20 65 78 65 6d   exists, as exem
12e0: 70 6c 69 66 69 65 64 20 6f 6e 20 74 68 65 20 61  plified on the a
12f0: 62 6f 76 65 20 66 69 67 75 72 65 20 62 79 20 4c  bove figure by L
1300: 69 6e 6b 73 20 3c 62 3e 4c 34 3c 2f 62 3e 20 61  inks <b>L4</b> a
1310: 6e 64 20 3c 62 3e 4c 37 3c 2f 62 3e 20 28 67 72  nd <b>L7</b> (gr
1320: 65 65 6e 20 73 70 6f 74 29 2e 3c 62 72 3e 0d 0a  een spot).<br>..
1330: 54 68 69 73 20 75 73 75 61 6c 6c 79 20 68 61 70  This usually hap
1340: 70 65 6e 73 20 77 68 65 6e 20 6f 6e 65 20 6f 66  pens when one of
1350: 20 74 68 65 20 74 77 6f 20 4c 69 6e 6b 73 20 6f   the two Links o
1360: 76 65 72 70 61 73 73 65 73 20 74 68 65 20 6f 74  verpasses the ot
1370: 68 65 72 2c 20 6f 72 20 77 68 65 72 65 20 73 6f  her, or where so
1380: 6d 65 20 74 65 63 68 6e 69 63 61 6c 20 72 65 73  me technical res
1390: 74 72 69 63 74 69 6f 6e 20 65 78 69 73 74 73 20  triction exists 
13a0: 28 65 2e 67 2e 20 74 77 6f 20 69 6e 73 75 6c 61  (e.g. two insula
13b0: 74 65 64 20 77 69 72 65 73 20 69 6e 20 61 6e 20  ted wires in an 
13c0: 45 6c 65 63 74 72 69 63 61 6c 20 4e 65 74 77 6f  Electrical Netwo
13d0: 72 6b 29 2e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 3c  rk).</li>..<li><
13e0: 62 3e 4c 69 6e 6b 73 3c 2f 62 3e 20 61 72 65 6e  b>Links</b> aren
13f0: 27 74 20 73 74 72 69 63 74 6c 79 20 72 65 71 75  't strictly requ
1400: 69 72 65 64 20 74 6f 20 62 65 20 61 73 73 6f 63  ired to be assoc
1410: 69 61 74 65 64 20 77 69 74 68 20 61 6e 79 20 73  iated with any s
1420: 70 65 63 69 66 69 63 20 61 74 74 72 69 62 75 74  pecific attribut
1430: 65 2c 20 62 75 74 20 74 68 65 20 66 6f 6c 6c 6f  e, but the follo
1440: 77 69 6e 67 20 61 74 74 72 69 62 75 74 65 73 20  wing attributes 
1450: 61 72 65 20 61 6c 6d 6f 73 74 20 75 6e 69 76 65  are almost unive
1460: 72 73 61 6c 6c 79 20 73 75 70 70 6f 72 74 65 64  rsally supported
1470: 3a 0d 0a 3c 75 6c 3e 0d 0a 3c 6c 69 3e 61 20 3c  :..<ul>..<li>a <
1480: 62 3e 6e 61 6d 65 3c 2f 62 3e 20 69 64 65 6e 74  b>name</b> ident
1490: 69 66 79 69 6e 67 20 74 68 65 20 4c 69 6e 6b 2e  ifying the Link.
14a0: 3c 62 72 3e 0d 0a 3c 75 3e 45 78 61 6d 70 6c 65  <br>..<u>Example
14b0: 73 3c 2f 75 3e 3a 20 74 68 65 20 3c 69 3e 72 6f  s</u>: the <i>ro
14c0: 61 64 20 74 6f 70 6f 6e 79 6d 3c 2f 69 3e 20 69  ad toponym</i> i
14d0: 6e 20 61 20 3c 62 3e 72 6f 61 64 20 6e 65 74 77  n a <b>road netw
14e0: 6f 72 6b 3c 2f 62 3e 2c 20 6f 72 20 74 68 65 20  ork</b>, or the 
14f0: 3c 69 3e 72 69 76 65 72 20 6e 61 6d 65 3c 2f 69  <i>river name</i
1500: 3e 20 69 6e 20 61 6e 20 3c 62 3e 68 79 64 72 6f  > in an <b>hydro
1510: 67 72 61 70 68 69 63 20 6e 65 74 77 6f 72 6b 3c  graphic network<
1520: 2f 62 3e 2e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 6f  /b>.</li>..<li>o
1530: 6e 65 20 28 6f 72 20 65 76 65 6e 20 6d 6f 72 65  ne (or even more
1540: 29 20 61 70 70 72 6f 70 72 69 61 74 65 20 3c 62  ) appropriate <b
1550: 3e 63 6f 73 74 20 76 61 6c 75 65 3c 2f 62 3e 28  >cost value</b>(
1560: 73 29 2e 3c 62 72 3e 0d 0a 3c 75 3e 45 78 61 6d  s).<br>..<u>Exam
1570: 70 6c 65 3c 2f 75 3e 3a 20 74 68 65 20 3c 69 3e  ple</u>: the <i>
1580: 74 69 6d 65 3c 2f 69 3e 20 72 65 71 75 69 72 65  time</i> require
1590: 64 20 74 6f 20 74 72 61 76 65 72 73 65 20 74 68  d to traverse th
15a0: 65 20 4c 69 6e 6b 20 28 6d 61 79 20 62 65 20 64  e Link (may be d
15b0: 69 73 74 69 6e 67 75 69 73 68 65 64 20 62 65 74  istinguished bet
15c0: 77 65 65 6e 20 70 65 64 65 73 74 72 69 61 6e 73  ween pedestrians
15d0: 2c 20 62 69 63 79 63 6c 65 73 2c 20 63 61 72 73  , bicycles, cars
15e0: 2c 20 6c 6f 72 72 69 65 73 20 61 6e 64 20 73 6f  , lorries and so
15f0: 20 6f 6e 29 2e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e   on).</li>..<li>
1600: 61 20 70 61 69 72 20 6f 66 20 3c 62 3e 62 6f 6f  a pair of <b>boo
1610: 6c 65 61 6e 20 66 6c 61 67 73 3c 2f 62 3e 20 28  lean flags</b> (
1620: 3c 62 3e 66 72 6f 6d 2d 74 6f 3c 2f 62 3e 20 61  <b>from-to</b> a
1630: 6e 64 20 3c 62 3e 74 6f 2d 66 72 6f 6d 3c 2f 62  nd <b>to-from</b
1640: 3e 29 20 61 72 65 20 69 6e 74 65 6e 64 65 6e 64  >) are intendend
1650: 20 74 6f 20 73 70 65 63 69 66 79 20 69 66 20 74   to specify if t
1660: 68 65 20 4c 69 6e 6b 20 63 61 6e 20 62 65 20 74  he Link can be t
1670: 72 61 76 65 72 73 65 64 20 6f 6e 20 62 6f 74 68  raversed on both
1680: 20 64 69 72 65 63 74 69 6f 6e 73 20 6f 72 20 6a   directions or j
1690: 75 73 74 20 69 6e 20 6f 6e 65 20 28 3c 62 3e 6f  ust in one (<b>o
16a0: 6e 65 2d 77 61 79 3c 2f 62 3e 29 2e 3c 2f 6c 69  ne-way</b>).</li
16b0: 3e 0d 0a 3c 2f 75 6c 3e 3c 2f 6c 69 3e 0d 0a 3c  >..</ul></li>..<
16c0: 2f 75 6c 3e 0d 0a 3c 68 34 3e 4c 6f 67 69 63 61  /ul>..<h4>Logica
16d0: 6c 20 63 6f 6e 63 6c 75 73 69 6f 6e 73 3c 2f 68  l conclusions</h
16e0: 34 3e 0d 0a 41 6e 79 20 74 6f 70 6f 6c 6f 67 69  4>..Any topologi
16f0: 63 61 6c 6c 79 20 76 61 6c 69 64 20 3c 62 3e 4e  cally valid <b>N
1700: 65 74 77 6f 72 6b 3c 2f 62 3e 20 28 69 72 72 65  etwork</b> (irre
1710: 73 70 65 63 74 69 76 65 20 6f 66 20 77 68 65 74  spective of whet
1720: 68 65 72 20 69 74 20 69 73 20 61 20 3c 62 3e 53  her it is a <b>S
1730: 70 61 74 69 61 6c 3c 2f 62 3e 20 6f 72 20 3c 62  patial</b> or <b
1740: 3e 4c 6f 67 69 63 61 6c 3c 2f 62 3e 20 74 79 70  >Logical</b> typ
1750: 65 29 20 69 73 20 61 20 76 61 6c 69 64 20 3c 62  e) is a valid <b
1760: 3e 47 72 61 70 68 3c 2f 62 3e 2e 3c 62 72 3e 0d  >Graph</b>.<br>.
1770: 0a 41 20 4e 65 74 77 6f 72 6b 20 61 6c 6c 6f 77  .A Network allow
1780: 69 6e 67 20 74 68 65 20 73 75 70 70 6f 72 74 20  ing the support 
1790: 28 64 69 72 65 63 74 20 6f 72 20 69 6e 64 69 72  (direct or indir
17a0: 65 63 74 29 20 6f 66 20 73 6f 6d 65 20 61 70 70  ect) of some app
17b0: 72 6f 70 72 69 61 74 65 20 3c 62 3e 63 6f 73 74  ropriate <b>cost
17c0: 20 76 61 6c 75 65 3c 2f 62 3e 20 69 73 20 61 20   value</b> is a 
17d0: 76 61 6c 69 64 20 3c 62 3e 57 65 69 67 68 74 65  valid <b>Weighte
17e0: 64 20 47 72 61 70 68 3c 2f 62 3e 2c 20 61 6e 64  d Graph</b>, and
17f0: 20 63 61 6e 20 63 6f 6e 73 65 71 75 65 6e 74 6c   can consequentl
1800: 79 20 73 75 70 70 6f 72 74 20 3c 62 3e 52 6f 75  y support <b>Rou
1810: 74 69 6e 67 20 61 6c 67 6f 72 69 74 68 6d 73 3c  ting algorithms<
1820: 2f 62 3e 2e 3c 62 72 3e 0d 0a 41 6c 6c 20 52 6f  /b>.<br>..All Ro
1830: 75 74 69 6e 67 20 61 6c 67 6f 72 69 74 68 6d 73  uting algorithms
1840: 20 61 72 65 20 69 6e 74 65 6e 64 65 64 20 74 6f   are intended to
1850: 20 69 64 65 6e 74 69 66 79 20 74 68 65 20 3c 62   identify the <b
1860: 3e 53 68 6f 72 74 65 73 74 20 50 61 74 68 3c 2f  >Shortest Path</
1870: 62 3e 20 73 6f 6c 75 74 69 6f 6e 20 63 6f 6e 6e  b> solution conn
1880: 65 63 74 69 6e 67 20 74 77 6f 20 3c 62 3e 4e 6f  ecting two <b>No
1890: 64 65 73 3c 2f 62 3e 20 69 6e 20 61 20 3c 62 3e  des</b> in a <b>
18a0: 77 65 69 67 68 74 65 64 20 67 72 61 70 68 3c 2f  weighted graph</
18b0: 62 3e 20 28 3c 69 3e 61 6b 61 3c 2f 69 3e 20 3c  b> (<i>aka</i> <
18c0: 62 3e 4e 65 74 77 6f 72 6b 3c 2f 62 3e 29 2e 3c  b>Network</b>).<
18d0: 62 72 3e 3c 62 72 3e 0d 0a 3c 62 3e 3c 75 3e 4e  br><br>..<b><u>N
18e0: 6f 74 65 3c 2f 75 3e 3c 2f 62 3e 3a 20 74 68 65  ote</u></b>: the
18f0: 20 74 65 72 6d 20 3c 62 3e 3c 69 3e 53 68 6f 72   term <b><i>Shor
1900: 74 65 73 74 20 50 61 74 68 3c 2f 69 3e 3c 2f 62  test Path</i></b
1910: 3e 20 63 61 6e 20 62 65 20 65 61 73 69 6c 79 20  > can be easily 
1920: 6d 69 73 75 6e 64 65 72 73 74 6f 6f 64 2e 3c 62  misunderstood.<b
1930: 72 3e 0d 0a 44 75 65 20 74 6f 20 68 69 73 74 6f  r>..Due to histo
1940: 72 69 63 61 6c 20 72 65 61 73 6f 6e 73 20 74 68  rical reasons th
1950: 65 20 6d 6f 73 74 20 63 6f 6d 6d 6f 6e 20 61 70  e most common ap
1960: 70 6c 69 63 61 74 69 6f 6e 20 66 69 65 6c 64 20  plication field 
1970: 66 6f 72 20 52 6f 75 74 69 6e 67 20 61 6c 67 6f  for Routing algo
1980: 72 69 74 68 6d 73 20 69 73 20 72 65 6c 61 74 65  rithms is relate
1990: 64 20 74 6f 20 3c 62 3e 52 6f 61 64 20 4e 65 74  d to <b>Road Net
19a0: 77 6f 72 6b 73 3c 2f 62 3e 2c 20 62 75 74 20 61  works</b>, but a
19b0: 6c 73 6f 20 6d 61 6e 79 20 6f 74 68 65 72 20 6b  lso many other k
19c0: 69 6e 64 73 20 6f 66 20 4e 65 74 77 6f 72 6b 73  inds of Networks
19d0: 20 65 78 69 73 74 3a 0d 0a 3c 75 6c 3e 0d 0a 3c   exist:..<ul>..<
19e0: 6c 69 3e 48 79 64 72 6f 67 72 61 70 68 69 63 20  li>Hydrographic 
19f0: 4e 65 74 77 6f 72 6b 73 2e 3c 2f 6c 69 3e 0d 0a  Networks.</li>..
1a00: 3c 6c 69 3e 47 61 73 20 2f 20 57 61 74 65 72 20  <li>Gas / Water 
1a10: 2f 20 4f 69 6c 20 4e 65 74 77 6f 72 6b 73 2e 3c  / Oil Networks.<
1a20: 2f 6c 69 3e 0d 0a 3c 6c 69 3e 45 6c 65 63 74 72  /li>..<li>Electr
1a30: 69 63 61 6c 20 4e 65 74 77 6f 72 6b 73 2e 3c 2f  ical Networks.</
1a40: 6c 69 3e 0d 0a 3c 6c 69 3e 54 65 6c 65 63 6f 6d  li>..<li>Telecom
1a50: 75 6e 69 63 61 74 69 6f 6e 20 4e 65 74 77 6f 72  unication Networ
1a60: 6b 73 2e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 53 6f  ks.</li>..<li>So
1a70: 63 69 61 6c 20 6f 72 20 45 63 6f 6e 6f 6d 69 63  cial or Economic
1a80: 61 6c 20 4e 65 74 77 6f 72 6b 73 20 72 65 70 72  al Networks repr
1a90: 65 73 65 6e 74 69 6e 67 20 72 65 6c 61 74 69 6f  esenting relatio
1aa0: 6e 73 68 69 70 73 20 62 65 74 77 65 65 6e 20 69  nships between i
1ab0: 6e 64 69 76 69 64 75 61 6c 73 20 6f 72 20 63 6f  ndividuals or co
1ac0: 6d 70 61 6e 69 65 73 2e 3c 2f 6c 69 3e 0d 0a 3c  mpanies.</li>..<
1ad0: 6c 69 3e 45 70 69 64 65 6d 69 6f 6c 6f 67 69 63  li>Epidemiologic
1ae0: 61 6c 20 4e 65 74 77 6f 72 6b 73 20 72 65 70 72  al Networks repr
1af0: 65 73 65 6e 74 69 6e 67 20 74 68 65 20 70 72 6f  esenting the pro
1b00: 70 61 67 61 74 69 6f 6e 20 6f 66 20 69 6e 66 65  pagation of infe
1b10: 63 74 69 76 65 20 64 69 73 65 61 73 65 73 20 62  ctive diseases b
1b20: 65 74 77 65 65 6e 20 69 6e 64 69 76 69 64 75 61  etween individua
1b30: 6c 73 20 6f 72 20 67 72 6f 75 70 73 2e 3c 2f 6c  ls or groups.</l
1b40: 69 3e 0d 0a 3c 2f 75 6c 3e 3c 2f 6c 69 3e 20 0d  i>..</ul></li> .
1b50: 0a 3c 62 72 3e 0d 0a 49 6e 20 61 6c 6c 20 74 68  .<br>..In all th
1b60: 65 20 61 62 6f 76 65 20 63 61 73 65 73 20 77 65  e above cases we
1b70: 20 63 65 72 74 61 69 6e 6c 79 20 68 61 76 65 20   certainly have 
1b80: 76 61 6c 69 64 20 4e 65 74 77 6f 72 6b 73 20 73  valid Networks s
1b90: 75 70 70 6f 72 74 69 6e 67 20 52 6f 75 74 69 6e  upporting Routin
1ba0: 67 20 61 6c 67 6f 72 69 74 68 6e 73 2c 20 62 75  g algorithns, bu
1bb0: 74 20 6e 6f 74 20 61 6c 6c 20 6f 66 20 74 68 65  t not all of the
1bc0: 6d 20 63 61 6e 20 69 6d 70 6c 79 20 73 6f 6d 65  m can imply some
1bd0: 74 68 69 6e 67 20 6c 69 6b 65 20 61 20 3c 69 3e  thing like a <i>
1be0: 73 70 61 74 69 61 6c 20 64 69 73 74 61 6e 63 65  spatial distance
1bf0: 3c 2f 69 3e 2c 20 61 20 3c 69 3e 67 65 6f 6d 65  </i>, a <i>geome
1c00: 74 72 69 63 20 6c 65 6e 67 74 68 3c 2f 69 3e 20  tric length</i> 
1c10: 6f 72 20 61 20 3c 69 3e 74 72 61 76 65 6c 20 73  or a <i>travel s
1c20: 70 65 65 64 3c 2f 69 3e 2e 3c 62 72 3e 0d 0a 49  peed</i>.<br>..I
1c30: 6e 20 74 68 65 20 6d 6f 73 74 20 67 65 6e 65 72  n the most gener
1c40: 61 6c 20 61 63 63 65 70 74 69 6f 6e 20 3c 62 3e  al acception <b>
1c50: 63 6f 73 74 73 3c 2f 62 3e 20 63 61 6e 20 62 65  costs</b> can be
1c60: 20 72 65 70 72 65 73 65 6e 74 65 64 20 62 79 20   represented by 
1c70: 61 6e 79 20 72 65 61 73 6f 6e 61 62 6c 65 20 70  any reasonable p
1c80: 68 79 73 69 63 61 6c 20 71 75 61 6e 74 69 74 79  hysical quantity
1c90: 2e 3c 62 72 3e 0d 0a 53 6f 20 61 20 6d 6f 72 65  .<br>..So a more
1ca0: 20 67 65 6e 65 72 61 6c 69 7a 65 64 20 64 65 66   generalized def
1cb0: 69 6e 69 74 69 6f 6e 20 69 73 20 61 73 73 75 6d  inition is assum
1cc0: 69 6e 67 20 74 68 61 74 20 52 6f 75 74 69 6e 67  ing that Routing
1cd0: 20 61 6c 67 6f 72 69 74 68 6d 73 20 61 72 65 20   algorithms are 
1ce0: 69 6e 74 65 6e 64 65 64 20 74 6f 20 69 64 65 6e  intended to iden
1cf0: 74 69 66 79 20 3c 62 3e 6c 65 73 73 65 72 20 63  tify <b>lesser c
1d00: 6f 73 74 3c 2f 62 3e 20 73 6f 6c 75 74 69 6f 6e  ost</b> solution
1d10: 73 20 6f 6e 20 61 20 3c 62 3e 77 65 69 67 68 74  s on a <b>weight
1d20: 65 64 20 67 72 61 70 68 3c 2f 62 3e 2e 3c 62 72  ed graph</b>.<br
1d30: 3e 0d 0a 54 68 65 20 65 78 61 63 74 20 69 6e 74  >..The exact int
1d40: 65 72 70 72 65 74 61 74 69 6f 6e 20 6f 66 20 74  erpretation of t
1d50: 68 65 20 69 6e 76 6f 6c 76 65 64 20 3c 62 3e 63  he involved <b>c
1d60: 6f 73 74 73 3c 2f 62 3e 20 28 3c 69 3e 61 6b 61  osts</b> (<i>aka
1d70: 3c 2f 69 3e 20 3c 62 3e 77 65 69 67 68 74 73 3c  </i> <b>weights<
1d80: 2f 62 3e 29 20 73 74 72 69 63 74 6c 79 20 64 65  /b>) strictly de
1d90: 70 65 6e 64 73 20 6f 6e 20 74 68 65 20 76 65 72  pends on the ver
1da0: 79 20 73 70 65 63 69 66 69 63 20 6e 61 74 75 72  y specific natur
1db0: 65 20 6f 66 20 65 61 63 68 20 4e 65 74 77 6f 72  e of each Networ
1dc0: 6b 2e 0d 0a 3c 68 33 3e 54 68 65 20 44 69 6a 6b  k...<h3>The Dijk
1dd0: 73 74 72 61 27 73 20 61 6c 67 6f 72 69 74 68 6d  stra's algorithm
1de0: 3c 2f 68 33 3e 0d 0a 54 68 69 73 20 77 65 6c 6c  </h3>..This well
1df0: 20 6b 6e 6f 77 6e 20 3c 61 20 68 72 65 66 3d 22   known <a href="
1e00: 68 74 74 70 73 3a 2f 2f 65 6e 2e 77 69 6b 69 70  https://en.wikip
1e10: 65 64 69 61 2e 6f 72 67 2f 77 69 6b 69 2f 44 69  edia.org/wiki/Di
1e20: 6a 6b 73 74 72 61 25 32 37 73 5f 61 6c 67 6f 72  jkstra%27s_algor
1e30: 69 74 68 6d 22 3e 61 6c 67 6f 72 69 74 68 6d 3c  ithm">algorithm<
1e40: 2f 61 3e 20 69 73 6e 27 74 20 6e 65 63 65 73 73  /a> isn't necess
1e50: 61 72 69 6c 79 20 74 68 65 20 66 61 73 74 65 73  arily the fastes
1e60: 74 20 6f 6e 65 2c 20 62 75 74 20 69 74 20 61 6c  t one, but it al
1e70: 77 61 79 73 20 65 6e 73 75 72 65 73 20 3c 62 3e  ways ensures <b>
1e80: 66 75 6c 6c 20 63 6f 72 72 65 63 74 6e 65 73 73  full correctness
1e90: 3c 2f 62 3e 3a 0d 0a 3c 75 6c 3e 0d 0a 3c 6c 69  </b>:..<ul>..<li
1ea0: 3e 41 6e 79 20 4e 6f 64 65 2d 74 6f 2d 4e 6f 64  >Any Node-to-Nod
1eb0: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 69 64 65  e connection ide
1ec0: 6e 74 69 66 69 65 64 20 62 79 20 44 69 6a 6b 73  ntified by Dijks
1ed0: 74 72 61 27 73 20 69 73 20 63 65 72 74 61 69 6e  tra's is certain
1ee0: 6c 79 20 65 6e 73 75 72 65 64 20 74 6f 20 62 65  ly ensured to be
1ef0: 20 3c 62 3e 6f 70 74 69 6d 61 6c 3c 2f 62 3e 2e   <b>optimal</b>.
1f00: 3c 62 72 3e 0d 0a 49 6e 20 6f 74 68 65 72 20 77  <br>..In other w
1f10: 6f 72 64 73 2c 20 6e 6f 20 63 6f 6e 6e 65 74 63  ords, no connetc
1f20: 74 69 6f 6e 20 70 72 65 73 65 6e 74 69 6e 67 20  tion presenting 
1f30: 61 20 6c 6f 77 65 72 20 63 6f 73 74 20 63 61 6e  a lower cost can
1f40: 20 63 6f 6e 63 65 70 74 75 61 6c 6c 79 20 65 78   conceptually ex
1f50: 69 73 74 2e 3c 2f 6c 69 3e 0d 0a 3c 6c 69 3e 57  ist.</li>..<li>W
1f60: 68 65 6e 20 44 69 6a 73 6a 74 72 61 27 73 20 66  hen Dijsjtra's f
1f70: 61 69 6c 73 20 74 6f 20 69 64 65 6e 74 69 66 79  ails to identify
1f80: 20 61 20 73 6f 6c 75 74 69 6f 6e 20 74 68 69 73   a solution this
1f90: 20 73 75 72 65 6c 79 20 6d 65 61 6e 73 20 74 68   surely means th
1fa0: 61 74 20 6e 6f 20 73 6f 6c 75 74 69 6f 6e 20 69  at no solution i
1fb0: 73 20 70 6f 73 73 69 62 6c 65 2e 3c 2f 6c 69 3e  s possible.</li>
1fc0: 0d 0a 3c 2f 75 6c 3e 0d 0a 3c 68 33 3e 54 68 65  ..</ul>..<h3>The
1fd0: 20 41 2a 20 61 6c 67 6f 72 69 74 68 6d 3c 2f 68   A* algorithm</h
1fe0: 33 3e 0d 0a 4d 61 6e 79 20 61 6c 74 65 72 6e 61  3>..Many alterna
1ff0: 74 69 76 65 20 52 6f 75 74 69 6e 67 20 61 6c 67  tive Routing alg
2000: 6f 72 69 74 68 6d 73 20 68 61 76 65 20 62 65 65  orithms have bee
2010: 6e 20 69 6e 76 65 6e 74 65 64 20 64 75 72 69 6e  n invented durin
2020: 67 20 74 68 65 20 79 65 61 72 73 2e 3c 62 72 3e  g the years.<br>
2030: 0d 0a 41 6c 6c 20 74 68 65 6d 20 61 72 65 20 62  ..All them are b
2040: 61 73 65 64 20 6f 6e 20 68 65 75 72 69 73 74 69  ased on heuristi
2050: 63 20 61 73 73 75 6d 70 74 69 6f 6e 73 20 61 6e  c assumptions an
2060: 64 20 61 72 65 20 69 6e 74 65 6e 64 65 64 20 74  d are intended t
2070: 6f 20 62 65 20 66 61 73 74 65 72 20 74 68 61 6e  o be faster than
2080: 20 44 69 6a 6b 73 74 72 61 27 73 2c 20 62 75 74   Dijkstra's, but
2090: 20 6e 6f 6e 65 20 6f 66 20 74 68 65 6d 20 63 61   none of them ca
20a0: 6e 20 65 6e 73 75 72 65 20 3c 62 3e 66 75 6c 6c  n ensure <b>full
20b0: 20 63 6f 72 72 65 63 74 6e 65 73 73 3c 2f 62 3e   correctness</b>
20c0: 20 61 73 20 44 69 6a 6b 73 74 72 61 27 73 20 64   as Dijkstra's d
20d0: 6f 65 73 2e 3c 62 72 3e 0d 0a 54 68 65 20 3c 61  oes.<br>..The <a
20e0: 20 68 72 65 66 3d 22 68 74 74 70 73 3a 2f 2f 65   href="https://e
20f0: 6e 2e 77 69 6b 69 70 65 64 69 61 2e 6f 72 67 2f  n.wikipedia.org/
2100: 77 69 6b 69 2f 41 2a 5f 73 65 61 72 63 68 5f 61  wiki/A*_search_a
2110: 6c 67 6f 72 69 74 68 6d 22 3e 41 2a 20 61 6c 67  lgorithm">A* alg
2120: 6f 72 69 74 68 6d 3c 2f 61 3e 20 61 70 70 6c 69  orithm</a> appli
2130: 65 73 20 61 20 6d 69 6c 64 20 68 65 75 72 69 73  es a mild heuris
2140: 74 69 63 20 6f 70 74 69 6d 69 7a 61 74 69 6f 6e  tic optimization
2150: 2c 20 61 6e 64 20 63 61 6e 20 62 65 20 61 20 72  , and can be a r
2160: 65 61 6c 69 73 74 69 63 20 61 6c 74 65 72 6e 61  ealistic alterna
2170: 74 69 76 65 20 74 6f 20 44 69 6a 6b 73 74 72 61  tive to Dijkstra
2180: 27 73 20 69 6e 20 6d 61 6e 79 20 63 61 73 65 73  's in many cases
2190: 2e 3c 62 72 3e 3c 62 72 3e 0d 0a 3c 68 72 3e 0d  .<br><br>..<hr>.
21a0: 0a 3c 68 32 3e 43 72 65 61 74 69 6e 67 20 61 20  .<h2>Creating a 
21b0: 56 69 72 74 75 61 6c 52 6f 75 74 69 6e 67 20 54  VirtualRouting T
21c0: 61 62 6c 65 3c 2f 68 32 3e 0d 0a 0d 0a 3c 68 72  able</h2>....<hr
21d0: 3e 3c 62 72 3e 0d 0a 3c 61 20 68 72 65 66 3d 22  ><br>..<a href="
21e0: 68 74 74 70 73 3a 2f 2f 77 77 77 2e 67 61 69 61  https://www.gaia
21f0: 2d 67 69 73 2e 69 74 2f 66 6f 73 73 69 6c 2f 6c  -gis.it/fossil/l
2200: 69 62 73 70 61 74 69 61 6c 69 74 65 2f 77 69 6b  ibspatialite/wik
2210: 69 3f 6e 61 6d 65 3d 34 2e 33 2e 30 2d 64 6f 63  i?name=4.3.0-doc
2220: 22 3e 62 61 63 6b 3c 2f 61 3e 0a 5a 20 31 35 32  ">back</a>.Z 152
2230: 34 30 66 65 35 30 38 30 35 62 32 66 32 39 36 38  40fe50805b2f2968
2240: 65 35 32 62 61 65 31 63 64 30 63 64 36 0a        e52bae1cd0cd6.