jsprit ====== jsprit is a java based, open source toolkit for solving rich traveling salesman (TSP) and vehicle routing problems (VRP). It is lightweight, flexible and easy-to-use, and based on a single all-purpose meta-heuristic currently solving - Capacitated VRP - Multiple Depot VRP - VRP with Time Windows - VRP with Backhauls - VRP with Pickups and Deliveries - VRP with Heterogeneous Fleet - Time-dependent VRP - Traveling Salesman Problem - Dial-a-Ride Problem - Various combination of these types Setting up the problem, defining additional constraints, modifying the algorithms and visualising the discovered solutions is as easy and handy as reading classical VRP instances to benchmark your algorithm. It is fit for change and extension due to a modular design and a comprehensive set of unit and integration-tests. ##In Development - continues improvement of code, handling and performance - simplifying management of soft and hard constraints - various capacity dimensions and multiple time-windows - large scale instances ##Documentation Please visit [jsprit-wiki](https://github.com/jsprit/jsprit/wiki) to learn more. ##License This software is released under [LGPL](http://opensource.org/licenses/LGPL-3.0). ##Get Started ####You know Maven and have an IDE [Add the latest snapshot (i.e. head of development) to your pom](https://github.com/jsprit/jsprit/wiki/Add-latest-snapshot-to-your-pom). [Add the latest release to your pom](https://github.com/jsprit/jsprit/wiki/Add-latest-release-to-your-pom). If you do not want Maven to manage your dependencies, go to [snapshot-jars](https://github.com/jsprit/mvn-rep/tree/master/snapshots/jsprit) or [realease-jars](https://github.com/jsprit/mvn-rep/tree/master/releases/jsprit) to download jsprit-binaries directly. Just click on the jar-file you want to download and use the 'Raw'-button to actually download it. Put the jars into your classpath. Note that you then need to put all [dependencies](https://github.com/jsprit/jsprit/wiki/Modules-and-Dependencies) jsprit relies on manually to your classpath as well. ####If not The following documentation is recommended: GeoTools - Quickstart Here you learn to setup the Java environment and an Integrated Development Environment (IDE). In the subsection Adding Jars to your Project you learn to integrate external libraries in your project. Just copy/paste the above jsprit releases/snapshots to your pom.xml instead of the GeoTools-artifacts. ##[Contributors](https://github.com/jsprit/jsprit/graphs/contributors) [Pierre-David Bélanger](https://github.com/pierredavidbelanger) ##About The jsprit-project is created and maintained by Stefan Schröder. It is motivated by two issues. First, there is an almost endless list of papers and algorithms to tackle vehicle routing problems, **BUT** there are (as far as I know) only a [very few open source implementations](https://github.com/jsprit/jsprit/wiki/Other-Projects) of one of these thousands algorithms. Second, it is motivated by my PhD-project at [KIT](http://www.kit.edu/english/index.php) where I apply vehicle routing algorithms to solve behavioural models of freight agents to assess (freight) transport policy measures. It is mainly inspired by my research group at [KIT-ECON](http://netze.econ.kit.edu/21.php), and by an awesome open-source project called [MATSim](www.matsim.org) and its developers. If you have questions or if you use jsprit, it would be great you give feedback and let me know your experience: Email: jsprit.vehicle.routing@gmail.com