Skip to content

Latest commit

 

History

History
188 lines (94 loc) · 7.04 KB

functionnalities.md

File metadata and controls

188 lines (94 loc) · 7.04 KB

Liste des fonctionnalités

Road2 propose un ensemble de fonctionnalités regroupées dans plusieurs groupes.

Groupe de fonctionnalités 1 : Interface pour calculer des itinéraires

Définir un point de départ, un point d'arrivée et des points intermédiaires

Fonctionnalités classiques et inévitables, elles ne seront pas détaillées ici. Précision : il est possible de préciser autant de point intermédiaire que l'on souhaite.

Définir des contraintes

La notion de contrainte est définie dans les concepts. Pour faire simple, il s'agit de spécifier des conditions que l'itinéraire devra remplir. La plus connue est certainement l'interdiction de prendre des autoroutes. Mais on peut avoir des conditions beaucoup plus complexes et on peut en appliquer plusieurs au calcul d'un itinéraire.

Préciser la ressource employée

Comme précisé dans les concepts, Road2 gère des ressources. Chaque requête doit préciser la ressources qu'elle interroge.

Préciser le profile voulu

Il est possible de préciser quel moyen de transport, l'itinéraire concerne.

Préciser l'optimisation voulue

Il est possible de préciser l'optimisation que l'on veut appliquer lors du calcul.

Ajouter des informations sur chaque tronçons

Selon les données présentes dans les graphes, il est possible de choisir les informations que l'on souhaite récupérer dans la réponse du calcul.

Préciser le contenu de la réponse

Par l'intermédiaire de plusieurs paramètres, il est possible de préciser le contenu de la réponse :

  • La présence ou non des étapes du parcours.
  • Le format des géométries dans la réponse. Pour le moment, geojson, polyline et wkt sont disponibles.
  • La présence ou non d'une bbox dans la réponse.

Choisir les unités de la requête et de la réponse

Grâce à des paramètres de la requête, il est possible d'influencer le format de la requête elle-même, et de la réponse :

  • Il est possible de définir la projection employée.
  • Le format des durées est modifiable.
  • Le format des distances est modifiable.

Groupe de fonctionnalités 2 : Interface pour calculer des isochrones et des isodistances

Définir un point de départ ou d'arrivée

Fonctionnalité inévitable pour le calcul d'un isochrone.

Préciser la ressource employée

Comme précisé dans les concepts, Road2 gère des ressources. Chaque requête doit préciser la ressources qu'elle interroge.

Préciser le type de coût employé

Divers coûts sont possibles pour le calcul, il s'agit donc de le préciser.

Définir la valeur du coût employée

Fonctionnalités inévitable pour un tel calcul.

Préciser le profil voulu

Il est possible de préciser quel moyen de transport, l'isochrone concerne.

Indiquer la direction considérée pour le résultat du calcul

Un isochrone peut se définir dans deux directions : départ ou arrivée. Il s'agit donc de préciser laquelle.

Définir des contraintes

La notion de contrainte est définie dans les concepts. Elle est limitée aux interdictions, comme par exemple, l'interdiction de prendre des autoroutes.

Préciser le contenu de la réponse

Par l'intermédiaire de plusieurs paramètres, un seul pour le moment, il est possible de préciser le contenu de la réponse :

  • Le format des géométrie dans la réponse. Pour le moment, geojson, polyline et wkt sont disponibles.

Choisir les unités de la requête et de la réponse

Grâce à des paramètres de la requête, il est possible d'influencer le format de la requête elle-même, et de la réponse :

  • Il est possible de définir la projection employée.
  • Le format des durées est modifiable.
  • Le format des distances est modifiable.

Groupe de fonctionnalités 3 : Proposer un service web

Road2 prend la forme d'un serveur web qui fournit un service de calcul d'itinéraire. Il possède donc plusieurs fonctionnalités liées à cela.

Utiliser les protocoles HTTP et HTTPS

Fonctionnalité explicite.

Configurer les CORS

Fonctionnalité explicite.

Disposer de plusieurs APIs

Comme présenté dans les concepts, Road2 offre la possibilité de proposer aux clients différentes APIs simultanément.

Disposer de plusieurs moteurs

Comme présenté dans les concepts, Road2 offre la possibilité de proposer aux clients différents moteurs simultanément.

Groupe de fonctionnalités 4 : Administrer le service

Le service peut être administrer de deux manières : la configuration et une API dédiée.

Configurer les ressources via la configuration

Via la configuration fichier du serveur, il est possible de créer des ressources qui se baseront sur une ou plusieurs sources.

Limiter certains usages via la configuration

Les APIs de Road2 proposent plusieurs options, comme la possibilité de calculer des itinéraires avec des points intermédiaires. Il peut être intéressant de limiter l'usage de ces options afin de ne pas surcharger le service.

Obtenir la version du serveur via l'API

Fonctionnalité explicite.

Obtenir l'état de santé du serveur via l'API

L'objectif est de récupérer l'état de chaque source de chaque service et d'en faire un compte-rendu.

Obtenir la configuration de l'administrateur

Obtenir la configuration des services gérés par un administrateur

Obtenir la configuration d'un service via son id

Redémarrer un service via son id

Obtenir la liste des projections gérés par un service

Obtenir la présence d'une projection via son id

Groupe de fonctionnalités 5 : Fonctionnalités spécifiques à OSRM

Optimisation des graphes pour des réponses plus rapides

Fonctionnalité explicite.

Calcul des itinéraires

Fonctionnalité explicite.

Gestions des contraintes simples ou exclusions

Les exclusions sont les contraintes classiques comme l'interdiction d'emprunter certains type de voies (ex. autoroutes). Ce sont les seuls contraintes disponibles via OSRM.

Déterminer le point du graphe le plus proche

Pour un point donnée, OSRM peut renovyer les points les plus proches du graphe.

Groupe de fonctionnalités 6 : Fonctionnalités spécifiques à PGRouting

Calcul d'itinéraire

Fonctionnalité explicite.

Calcul d'isochrone

Fonctionnalité explicite.

Gestion de contraintes complexes

PGRouting gère tout les types de contraintes, des plus simples au plus complexes. On peut donc interdire l'accès aux autoroutes ou préférer les routes qui ont une largeur supérieure à 5 mètres.

Groupe de fonctionnalités 7 : Fonctionnalités spécifiques à l'API simple/1.0.0

Obtenir un GetCapabilities

Le GetCapabilities est une réponse JSON qui décrit les paramètres de chaque opérations et les valeurs disponibles pour une instance de Road2.

On trouvera un exemple dans la {{ 'documentation'.format(repo_url, repo_branch) }}.