[pgrouting-dev] Thinking about V4.0
    Vicky Vergara 
    vicky at georepublic.de
       
    Thu Dec 16 10:27:27 PST 2021
    
    
  
Hello all.
I am working on what is going to be pgRouting v4.0 due at the end of 2023
Many ideas have come out from my experiments
>From the internals simplifying (C/C++) code.
For usage:
*pgr_TRSP*
Currently it is a mess internally (C/C++) and externally.
Lets talk externally
Currently the documentation in one page has the following signatures:
pgr_trsp(sql text, source integer, target integer, directed boolean,
has_rcost boolean [,restrict_sql text]);
RETURNS SETOF (seq, id1, id2, cost)
pgr_trsp(sql text, source_edge integer, source_pos float8, target_edge
integer, target_pos float8,
                  directed boolean, has_rcost boolean [,restrict_sql text]);
RETURNS SETOF (seq, id1, id2, cost)
pgr_trspViaVertices(sql text, vids integer[], directed boolean, has_rcost
boolean [, turn_restrict_sql text]);
RETURNS SETOF (seq, id1, id2, id3, cost)
pgr_trspViaEdges(sql text, eids integer[], pcts float8[], directed boolean,
has_rcost boolean [, turn_restrict_sql text]);
RETURNS SETOF (seq, id1, id2, id3, cost)
*Change those signatures*
FROM:
pgr_trsp(sql text, source integer, target integer, directed boolean,
has_rcost boolean [,restrict_sql text]);
RETURNS SETOF (seq, id1, id2, cost)
TO
    driving_side CHAR DEFAULT 'b', -- 'r'/'l'/'b'/NULL
    details BOOLEAN DEFAULT false,
pgr_trsp(Edges SQL, Restrictions sql, From vid, To vid [,directed]) -- one
to one
pgr_trsp(Edges SQL, Restrictions sql, From vid, To vids [directed]) -- one
to many
pgr_trsp(Edges SQL, Restrictions sql, From vids, To vid [,directed]) --
many to one
pgr_trsp(Edges SQL, Restrictions sql, From vids, To vids [,directed]) --
many to many
pgr_trsp(Edges SQL, Restrictions sql, Combinations SQL [,directed]) --
combinations
RETURNS SET OF (seq, path_seq, start_vid, end_vid, node, edge, cost,
agg_cost)
Note that regardless of the call all columns are returned
FROM:
pgr_trsp(sql text, source_edge integer, source_pos float8, target_edge
integer, target_pos float8,
                  directed boolean, has_rcost boolean [,restrict_sql text]);
RETURNS SETOF (seq, id1, id2, cost)
TO
pgr_trsp_withPoints(Edges SQL, Restrictions sql, Points SQL, From vid, To
vid [,directed][,driving_side][,details]) -- one to one
pgr_trsp_withPoints(Edges SQL, Restrictions sql, Points SQL, From vid, To
vids [,directed][,driving_side][,details]) -- one to many
pgr_trsp_withPoints(Edges SQL, Restrictions sql, Points SQL, From vids, To
vid [,directed][,driving_side][,details]) -- many to one
pgr_trsp_withPoints(Edges SQL, Restrictions sql, Points SQL, From vids, To
vids [,directed][,driving_side][,details]) -- many to many
pgr_trsp_withPoints(Edges SQL, Restrictions sql, Points SQL, Combinations
SQL [,directed][,driving_side][,details]) -- combinations
RETURNS SET OF (seq, path_seq, start_pid, end_pid, node, edge, cost,
agg_cost)
Note: that regardless of the call all columns are returned
FROM:
pgr_trspViaVertices(sql text, vids integer[], directed boolean, has_rcost
boolean [, turn_restrict_sql text]);
RETURNS SETOF (seq, id1, id2, id3, cost)
TO
pgr_trspVia(Edges SQL, Restrictions sql, Via Array,
 [,directed][,strict][,allow_u_turn])
RETURNS SET OF (seq, path_id, path_seq, start_pid, end_pid, node, edge,
cost, agg_cost)
FROM:
pgr_trspViaEdges(sql text, eids integer[], pcts float8[], directed boolean,
has_rcost boolean [, turn_restrict_sql text]);
RETURNS SETOF (seq, id1, id2, id3, cost)
TO
pgr_trsp_withPointsVia(Edges SQL, Restrictions sql, Points SQL, Via Array
[,directed][,driving_side][,details][,strict][,allow_u_turn])
RETURNS SET OF (seq, path_id, path_seq, start_pid, end_pid, node, edge,
cost, agg_cost)
Note that regardless of the call all columns are returned
*About Via functions*
pgr_dijkstraVia(Edges SQL, Via Array
[,directed][,driving_side][,details][,strict][,allow_u_turn])
pgr_withPointsVia(Edges SQL, Points SQL, Via Array
[,directed][,driving_side][,details][,strict][,allow_u_turn])
pgr_trsp_withPointsVia(Edges SQL, Restrictions sql, Points SQL, Via Array
[,directed][,driving_side][,details][,strict][,allow_u_turn])
RETURNS SET OF (seq, path_id, path_seq, start_pid, end_pid, node, edge,
cost, agg_cost)
Note: that regardless of the call the same columns are returned
Note: currently only pgr_dijkstraVia exist
*About unifying return columns*
For example on dijkstra
pgr_dijkstra(Edges SQL, start_vid,  end_vid  [, directed])
pgr_dijkstra(Edges SQL, start_vid,  end_vids [, directed])
pgr_dijkstra(Edges SQL, start_vids, end_vid  [, directed])
pgr_dijkstra(Edges SQL, start_vids, end_vids [, directed])
pgr_dijkstra(Edges SQL, Combinations SQL [, directed])
RETURNS SET OF (seq, path_seq [, start_vid] [, end_vid], node, edge, cost,
agg_cost)
Depending on the call, are the columns returned
Change to
RETURNS SET OF (seq, path_seq , start_vid, end_vid, node, edge, cost,
agg_cost)
That way regardless of the call the same columns are returned
That unification of many other official, proposed and experimental
functions like pgr_astar, pgr_bdAstar etc.
Having for the same (family) calls the same returned columns, makes it
easier to remember, aka less complicated API
*About naming because of withPoints*.
Currently there are the following proposed functions and they all work with
dijkstra
* pgr_withPoints
* pgr_withPointsCost
* pgr_withPointsCostMatrix
* pgr_withPointsKSP
* pgr_withPointsDD
* pgr_withPointsVia -- to be done
Thinking about trsp (for when they are developed):
* pgr_trsp_withPoints
* pgr_trsp_withPointsCost
* pgr_trsp_withPointsCostMatrix
* pgr_trsp_withPointsKSP
* pgr_trsp_withPointsDD
* pgr_trsp_withPointsVia
Thinking about aStar (for when they are developed):
* pgr_aStar_withPoints
* pgr_aStar_withPointsCost
* pgr_aStar_withPointsCostMatrix
* pgr_aStar_withPointsKSP
* pgr_aStar_withPointsDD
* pgr_aStar_withPointsVia
Having this convention when with points are involved, makes it easier to
remember, aka less complicated API
I would like your thoughts
Regards
Vicky
-- 
Georepublic UG (haftungsbeschränkt)
Salzmannstraße 44,
81739 München, Germany
Vicky Vergara
Operations Research
eMail: vicky at georepublic.de
Web: https://georepublic.info
Tel: +49 (089) 4161 7698-1
Fax: +49 (089) 4161 7698-9
Commercial register: Amtsgericht München, HRB 181428
CEO: Daniel Kastl
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/pgrouting-dev/attachments/20211216/40e489e9/attachment.html>
    
    
More information about the pgrouting-dev
mailing list