<div dir="ltr">Another topic for you : in addition of the time criterion, I would like to add a second criterion regarding the cyclability of the ways (an index between 1 and 5, 5 being the best cyclability). <br><br>Until now, I've been looking in the code for classes that take the speed weight for ways as an attribute, considering that this second could fit in these classes too. Until I found it in the classes : ExtractionContainers, Contractor, ImportEdge, NodeBasedGraph, EdgeBasedGraph, QueryEdge and EdgeBasedNode. <br><br>Any clue on another class to look into or a better way to integrate a new criterion for routing into OSRM?<br></div><div class="gmail_extra"><br><div class="gmail_quote">2015-02-12 16:38 GMT+01:00 Romain NKONGO <span dir="ltr"><<a href="mailto:romain.rnk49@gmail.com" target="_blank">romain.rnk49@gmail.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Ok, so after reading the Leaflet file, it seems to be an appropriate way to send a HTTP request to the server and get the response back as variables I could process in my script. Now I wonder how I could take this interesting piece of code and adapt it to my AngularJS implementation.<br></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">2015-02-12 15:00 GMT+01:00 Romain NKONGO <span dir="ltr"><<a href="mailto:romain.rnk49@gmail.com" target="_blank">romain.rnk49@gmail.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div>Thanks to all for your suggestions.<br><br></div>To Guillaume : I searched about the $http.get function and I wrote this function to test if all goes well (I think I've tried it before) : <br>    var getItinerary2=function(){<br>        $http.get("<a href="http://localhost:5000/viaroute?loc=47.3654647,0.6822917&loc=47.3905003,0.6920979&compression=false" target="_blank">http://localhost:5000/viaroute?loc=47.3654647,0.6822917&loc=47.3905003,0.6920979&compression=false</a>"<span><br>        .success(function(data, status, headers, config) {<br>            console.log(data);<br>          }).<br>            error(function(data, status, headers, config) {<br></span>            console.log("error");<br>          });<br>    };<br><br></div><div>Then I call it when I press Submit but the error function is triggered (the browser console prints "error").<br></div><div>Am I doing something wrong?<br><br></div><div>To Patrick : I will take a look at the JS file to find what could be helpful. But, to be clear, what I'm trying to do is send a query to the OSRM server and get back the response in the backend, in my script, not directly in frontend, as I want to extract some information from the output.<br><br></div><div>To Emil : I saw the Cucumber Suite in the OSRM project but those are precomputed tests, with known responses to the requests. In my case, I will run tests on a large map (OSM file size : 122 Mo) with random locations pairs inside the area.<br></div></div><div><div><div class="gmail_extra"><br><div class="gmail_quote">2015-02-12 13:47 GMT+01:00 Emil Tin <span dir="ltr"><<a href="mailto:emil@tin.dk" target="_blank">emil@tin.dk</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div><br></div><div>The OSRM project includes a set of cucumber tests that does a lot of testing of binaries, including preparing data and querying the server. It’s ruby based but maybe it can help you. Look in the folder features/. The various support files that queries osrm are in features/support/</div><div><br></div><div>See <a href="https://github.com/Project-OSRM/osrm-backend/wiki/Cucumber-Test-Suite" target="_blank">https://github.com/Project-OSRM/osrm-backend/wiki/Cucumber-Test-Suite</a> for more.</div><span><font color="#888888"><div><br></div><div><br></div><div>Emil</div><div><br></div><div> </div></font></span><div><blockquote type="cite"><div><div><div>On 12 Feb 2015, at 10:46 , Romain NKONGO <<a href="mailto:romain.rnk49@gmail.com" target="_blank">romain.rnk49@gmail.com</a>> wrote:</div><br></div></div><div><div><div><div dir="ltr"><div><div><div><div><div><div><div>Hello to all the OSRM community.<br><br></div>I'm a french student who works on a university project, along with my supervisor and uses the open source project OSRM to achieve it.<br><br></div>At some point, I have to run some tests (like thousands of tests) to extract some values from the JSON outputs (e.g. the total time). Now our problem is we tried several ways to do this, by sending HTTP GET requests to the running server and treat the returned response as JSON. But we tried with Javascript, jQuery and AngularJS, with functions like $resource.get, jQuery.getJSON $http.get or $http.jsonp and we never managed to get the returned response in a way that we could use it for further treatment in our script. Actually, we were able to send the requests to the server but the response is returned in the fom of an URL link which contains the JSON output in its body, not in the form of a variable in our Javascript that we could manipulate.<br><br></div>As a matter of fact, we have two issues for this :<br></div>- some of the functions we used  (which are based on jsonp) added a callback parameter to the sent URL, so the request became invalid with 'Query malformed at the position' errors<br></div>- I've seen in the OSRM documentation that the JSON output is encoded with the Google polyline algorithm so it could be an invalid JSON for Javascript (we also observed errors like SyntaxError: JSON.parse: unexpected end of data at line 1 column 1 of the JSON data<br><br></div>We essentially want to use the viaroute service, so our URL is something like that : "<a>htttp://localhost:5000/viaroute?loc=a,b&loc=c,d</a>" with a,b, c and d random float numbers.<br><br></div><div>Has anyone ever tried to run some customized tests on OSRM, with any Web language, and if so can he give me some tricks of how he succeeded to get the JSON ouptut where he wanted?<br><br></div><div>To be clearer of how I proceeded in AngularJS, here the code of my app.js : <br>var app = angular.module('clientOSRM', ['ngResource']);<br><br>app.controller('appController', ['$scope','$http', 'appServices', function ($scope,$http, appServices) {<br>    //Initialisation de notre input, sa valeur sera stockée en instantané dans cette variable (ng-model)<br>    $scope.valueInput1 = "47.3654647,0.6822917";<br>    $scope.valueInput2 = "47.3905003,0.6920979";<br><br><br>    var getItineraryParams = function () {<br>        return {<br>        start: $scope.valueInput1,<br>        end: $scope.valueInput2<br>        //start: "47.3654647,0.6822917",<br>        //end: "47.3905003,0.6920979"<br>            //start: "a,b",<br>            //end: "c,d"<br>        }<br>    };<br><br>    //Une fonction accessible que dans ce controleur (mot clé var)<br>    var getItinerary = function () {<br>        appServices.osrm.get(getItineraryParams(),<br>            function (itinerary) {<br>        alert("Succes : "+typeof itinerary);<br>                console.log(itinerary);<br>            },<br>            function (error) {<br>        alert("erreur : "+typeof error+"; status : "+error.status);<br>                console.log(error);<br>            }<br>        );<br>    /*$http.jsonp("<a href="http://localhost:5000/viaroute?loc=47.3654647,0.6822917&loc=47.3905003,0.6920979&alt=false&geometry=false&output=json" target="_blank">http://localhost:5000/viaroute?loc=47.3654647,0.6822917&loc=47.3905003,0.6920979&alt=false&geometry=false&output=json</a>")<br>    .success(function(data, status, headers, config) {<br>        console.log(data);<br>      }).<br>      error(function(data, status, headers, config) {<br>        console.log(data);<br>      });*/<br>    <br>    };<br><br>    //Une fonction accessible depuis la vue<br>    //Fonction appelée à l'envoi du formulaire (balise ng-submit dans <form>)<br>    $scope.submit = function () {<br>        //On peut récupérer la valeur de notre input !<br>        //console.log($scope.valueInput1);<br>        getItinerary();<br>    };<br>}]);<br><br>app.run(function ($rootScope) {<br><br>    $rootScope.safeApply = function (fn) {<br>        var phase = $rootScope.$$phase;<br>        if (phase === '$apply' || phase === '$digest') {<br>            if (fn && (typeof(fn) === 'function')) {<br>                fn();<br>            }<br>        } else {<br>            this.$apply(fn);<br>        }<br>    };<br><br>});<br><br></div><div>and also the appServices.js code :<br>app.factory('appServices', function ($resource) {<br><br>    return {<br>        osrm: $resource("", {}, {<br>            'get': {<br>                method: 'GET',<br>                params: {start: '@start', end: '@end'},<br>                isArray:true,<br>                url: "<a href="http://localhost:5000/viaroute?loc=:start&loc=:end&alt=false&geometry=false" target="_blank">http://localhost:5000/viaroute?loc=:start&loc=:end&alt=false&geometry=false</a>"<br>            }<br>        })<br>    };<br>});<br><br></div><div>In the getItinerary function in app.js, the error function (the 3rd parameter) is always triggered even with a HTTP status code '200 OK' of the request.<br><br></div><div>Any ideas where it could go wrong?<br><br></div><div>Thanks in advance.<br></div><div><div><br><br></div></div></div></div></div><span>
_______________________________________________<br>OSRM-talk mailing list<br><a href="mailto:OSRM-talk@openstreetmap.org" target="_blank">OSRM-talk@openstreetmap.org</a><br><a href="https://lists.openstreetmap.org/listinfo/osrm-talk" target="_blank">https://lists.openstreetmap.org/listinfo/osrm-talk</a><br></span></div></blockquote></div><br></div><br>_______________________________________________<br>
OSRM-talk mailing list<br>
<a href="mailto:OSRM-talk@openstreetmap.org" target="_blank">OSRM-talk@openstreetmap.org</a><br>
<a href="https://lists.openstreetmap.org/listinfo/osrm-talk" target="_blank">https://lists.openstreetmap.org/listinfo/osrm-talk</a><br>
<br></blockquote></div><br></div>
</div></div></blockquote></div><br></div>
</div></div></blockquote></div><br></div>