Skip to content

GSoC 2022 Add Google OR Tools functionality in vrpRouting

Manas Sivakumar edited this page Sep 11, 2022 · 30 revisions

Table of Contents

Proposal

Brief Description

Vrprouting is a subsection of pgrouting that deals with vehicle routing problems for now. In the long run Vrprouting aims to become the one-stop for all kinds of optimization functions. In this project google OR-tools needs to be integrated with vrprouting.

Google OR is an open-source software suite that can solve optimization problems such as these. The aim of this project is to use Google OR functions and wrap it up with Vrprouting functions to solve the above-mentioned problem

State of the Project Before GSoC

Currently, in Vrprouting, Vehicle routing optimization functions with various constraints have been implemented and are in the experimental stage. No functions related to scheduling, linear optimization and bin packing have been implemented.

Benefits to the Community

Adding google-or tools functionalities have multiple benefits:

  • Bin packing algorithm can be used to find the optimum way to fill items into various trucks/vehicles
  • Knapsack problem can be used to find optimum ways of organising your items
  • Schedule employees in multiple shifts, subject to a complex set of constraints and staffing requirements.
  • In the future, one can extend existing implemented google or-tools functions to more functions and libraries and improve Vrprouting.

Deliverables

  • Implementation of OR-Tools Bin Packing functions: vrp_knapsack, vrp_multiple_knapsack and vrp_bin_packing
  • SQL Queries to run the implemented function with self-documentation
  • Users' Documentation of the function
  • pgTap test cases
  • Wiki page of the function

If time permits

  • Extending the or-tools scheduling library to other algorithms like the “Job shop problem” function signature would be vrp_or_job_shop_scheduler.
  • Additional pgTAP tests and unit tests.

Detailed Proposal

Detailed Proposal in Google Doc

Participants

Title GitHub Handle Name
1st Mentor @krashish8 Ashish Kumar
2nd Mentor @cvvergara Celia Virginia Vergara Castillo
Student Developer @Manas23601 Manas Sivakumar

Timeline

Community Bonding Period (May 20th - June 12th)

  • Get to know my mentors and other members of Pgrouting.
  • Understand the coding principles and application development process of the Pgrouting community.
  • Understand the existing code and available implementation to find suitable measures to improve them.
  • Explore the Google OR functionalities to a greater depth
  • Set up a local development environment for myself.
  • Learn more about PostGIS and Postgresql.
  • Learn how to write a PgTAP.

Introduction Mail : GSoC22 Introduction
Community Bonding Report : Community Bonding Report

First Coding Period (June 13th - July 24th)

Week 1 (June 13th - June 19th)

  • Create a basic skeleton for vrp_or_employee_scheduler
  • Set up a blog for weekly reports

Week 1 report

  • Report Mail : [SoC], [pgRouting-dev]

  • What did I get done this week?

    • Created a branch manas-2022 in the GSoC-pgRouting repository.
    • Added My name as a contributor in vrpRouting-introduction.rst
    • Made a Pull Request with the following changes. (Pull Request)
  • What do I plan on doing next week?

    • Create a function skeleton for vrp_knapsack.
    • Create a basic skeleton for doc and docqueries.
  • Am I blocked on anything?

    • I was sick for the majority of last week so I couldn't focus on my week1 tasks. Now that I am fully recovered, I will finish my week1 tasks along with week 2.

Week 2 (June 20th - June 26th)

  • Create a basic skeleton for user’s documentation, pgtaps, SQL code
  • Understanding Google Or tools terminology

Week 2 Report:

  • Report Mail : [SoC], [pgRouting-dev]

  • What did I get done this week?

    • Deviated from Proposal's Timeline by first implementing the Bin Packing Functions. Will implement Employee Scheduler type if time permits
    • Discussion on function naming convention. Snake-style? Camel Style ?
    • Created a SQL function for knapsack_0_1.
    • Configured CMake to process OR-Tools
    • Created empty placeholders for doc, docqueries, and src files for knapsack
    • Looked at Google OR-tools terminology
    • Learned about pgTAPs
    • Made a Pull Request with the following changes. (Pull Request)
  • What do I plan on doing next week?

    • Figure out how to add the google OR-Tools library to vrpRouting
  • Am I blocked on anything?

    • Didn't have a clear understanding of vrprouting's file structure.
    • Wasted a lot of time reading how postgresSQL works internally.

Week 3 (June 27th - July 03rd)

  • Modularizing the or-tools optimization code into functions(constraints, variable).
  • Building and running the functions in Vrprouting

Week 3 Report:

  • Report Mail : [SoC], [pgRouting-dev]

  • What did I get done this week?

    • Design Challenge: Function signature for knapsack and how Input parameters need to be passed.
      • Both weights and values are arrays of integers.
      • A table has 2 columns [weight, value] and the data is fetched from an SQL query.
      • 2 separate tables for weight and value, run 2 separate SQL queries to fetch the data.
    • Going with Design 2 for now. Comparison with 1st approach is required in the future.
    • Created a driver file for vrp_knapsack_0_1.
    • Updated doc for vrp_knapsack_0_1.
    • Added OR-Tools C++ build Instructions for Ubuntu in Github Actions.
    • Experimented with different CMake Modules to add OR-Tools to vrpRouting such as.
    • Addressed Issues previously raised
    • Made a Pull Request with the following changes. (Pull Request)
  • What do I plan on doing next week?

    • Complete the driver functions for knapsack. Make necessary structs and SQL conversion functions.
    • Experiment with other CMake Modules to Integrate OR-Tools.
    • Use OR-tools library within vrpRouting.
  • Am I blocked on anything?

    • None
  • Resources:


Week 4 (July 04th - July 10th)

  • Create the necessary class wrappers for the functions.

Week 4 Report:

  • Report Mail : [SoC], [pgRouting-dev]

  • What did I get done this week?

    • Updated knapsack driver file with new signature.
    • Working on Knapsack driver implementation with necessary structs.
    • Compiled OR-tools with vrpRouting CMake.
    • Experimented with add_subdirectory() method in CMake.
    • Fixed Lint Errors on my code due to trailing white spaces and indentation mistakes.
    • Updated various developer tool scripts and adjusted them according to my local setup.
    • Made a Pull Request with the following changes. (Pull Request)
  • Hindrance working with OR-Tools CMake:

    • I was able to compile OR-Tools with add_subdirectory and find_package methods, the Issue occurs when I try to use the OR-Tools Library as part of a vrpRouting function.
    • find_package: the location of the root .config file is required. It seems like the ortools.config file is unable to identify all the sub-dependencies .configs inside OR-Tools package and hence fails to work.
      • The target .configs were located in an another folder.
      • Attempted to manually add all the .configs by looping over the project repo. Failed to do so as I couldn't find any discernible pattern to exploit.
    • add_subdirectory: In this Method we compile the two projects separately and link them. This is similar to the approach followed in VROOM addition.
      • Although they were linked, the driver files inside OR-Tools wasn't unlike VROOM.
  • What do I plan on doing next week?

    • Considering I have put two weeks of effort into compiling OR-Tools in vrpRouting with no fruitful results, I have decided to keep it aside for now, finish other works and circle back to it later.
    • Make knapsack function work without using ortools in knapsack driver
  • Am I blocked on anything?

    • None

Week 5 (July 11th - July 17th)

  • Transforming the solution computed to suitable containers for PostgreSQL

Week 5 Report:

  • Report Mail : [Soc], [pgRouting-dev]

  • What did I get done this week?

    • Minor Changes to Knapsack Function Signature in sql and src.
    • Updated docqueries.
    • Created necessary structs and SQL conversion functions in c_common, c_types and include/driver.
    • Completed Knapsack src/driver implementation.
    • Tested out knapsack function without ortools processing using doc_queries_generator.pl developer tool script.
    • Made a Pull Request with the following changes. (Pull Request)
  • What do I plan on doing next week?

    • Compile OR-tools with vrprouting OR-tools
    • Try to use ortools in knapsack driver
  • Am I blocked on anything?

    • None

Week 6 (July 18th - July 24th)

  • Testing the function using sample pgtap’s. Preparation of first coding period report

Week 6 Report:

  • Report Mail : [Soc], [pgRouting-dev]

  • What have I done this week?*

    • After contacting the official community of OR-Tools in Discord. I realised the root cause of the error to be how the abseil-cpp dependency is compiled. apparently there seems to some C++ version discrepancy from my end when I compile.
    • By default, I compile with C++14 where as abseil-cpp at least requires C++17 and above.
    • Due to multiple C++ dialect requirements, absl and all it sub-dependencies failed for me.
  • Huge Roadblock

    • Compiling OR-tools with CMake has proved to be a deadend for me. Considering I'm already half way done, I have decided to forsake all my efforts on compiling OR-Tools C++ and redirect my efforts to an alternate solution that is PL/Python.
    • Switching to python from C++ for knapsack implementation.
    • Made a Pull Request with the following changes. (Pull Request).
  • What do I plan to do next week?*

    • Convert knapsack c++ to python
    • figure out how to add python ortools to pgrouting requirements
  • Am I blocked on anything?*

    • None

Second Coding Period (July 25th - September 04th)

Week 7 (July 25th - July 31st)

  • Create a basic skeleton for vrp_or_knapsack_0_1
  • Create a basic skeleton for vrp_or_mulitple_knapsack_0_1
  • Create a basic skeleton for vrp_or_bin_packing
  • Create a basic skeleton for user’s documentation, pgtaps, SQL code.

Week 7 Report:

  • Report Mail : [SoC], [pgRouting-dev]

  • What have I done this week?*

    • Added plpython3u extension to vrpRouting wherever necessary except in Github Actions.
    • Learned how to use PL/Python. Made Sample functions demonstrating basic coding principles.
    • Implemented multiple_knapsack in PL/Python.
    • Implemented bin_packing in PL/Python
    • Converted knapsack from c++ to PL/Python.
    • Updated CMake. i.e no more src requirement for OR-Tools.
    • Made a Pull Request with the following changes. (Pull Request)
  • What do I plan to do next week?*

    • figure out how to compile ortools library in vrpRouting.
    • update Ubuntu Github action to build PL/Python extension.
  • Am I blocked on anything?*

    • None

Week 8 (August 01st - August 07th)

  • Building and running the code in Vrprouting

Week 8 Report:

  • Report Mail : [SoC], [pgRouting-dev]

  • What have I done this week?*

    • Error Handling in bin_packing, multiple_knapsack and knapsack.
    • Cleaned code.
    • Added plpython3u to build worflow
    • Made a Pull Request with the following changes. (Pull Request)
  • What do I plan to do next week?*

    • pgTAPs
    • Make necessary changes to tool scripts
  • Am I blocked on anything?*

    • None

Week 9 (August 08th - August 14th)

  • wrappers the implemented functions using SQL commands.

Week 9 Report:

Report Mail : [SoC], [pgRouting-dev]

  • What have I done this week?*

    • partially implemented no_crash_test and inner_query pgTAP.
  • What do I plan to do next week?*

    • pgTAPs
    • Make necessary changes to tool scripts
  • Am I blocked on anything?*

    • I was occupied with an urgent family issue.

Week 10 (August 15th - August 21st)

  • Transforming the solution computed to suitable containers for PostgreSQL

Week 10 Report:

Report Mail : [SoC], [pgRouting-dev]

  • What have I done this week?*

    • pgTAP for ortools
      • no_crash_test
      • types_check
      • inner_query
    • Built Google OR-tools in Github Actions.
    • Completed docqueries for knapsack, bin_packing and multiple_knapsack.
    • Partially completed Documentation.
    • Made a Pull Request with the following changes. (Pull Request)
  • What do I plan to do next week?*

    • Enhancements/bugs if any
    • Update Results and Inner Queries Tables in User's Documentation.
    • Create Final Pull Request

Am I blocked on anything?

  • None

Week 11 (August 22nd - August 28th)

  • Testing the functions using sample pgtap’s.
  • Proof-checking the blog

Week 11 Report:

Report Mail : https://lists.osgeo.org/pipermail/soc/2022-August/004951.html

  • What have I done this week?*

    • Updated signature of all functions to print as SQL Table rows instead of terminal messages
    • Completed Documentation for all OR-Tools functions. Doc
    • Updated Docqueries, pgTAPs and SQL files
    • Pull Request
  • What do I plan to do next week?*

    • Final PR to vrpRouting repo
    • Final report

Am I blocked on anything?

  • None

Week 12 (August 29th - September 04th)

  • Preparation of the final report

Log of Pull Requests

Pull Request Description Date Status
#257 GSoC-2022: Manas Sivakumar Week 11 August 28th, 2022 Merged
#252 GSoC-2022: Manas Sivakumar Week 10 August 21st, 2022 Merged
#247 GSoC-2022: Manas Sivakumar Week 8 August 7th, 2022 Merged
#241 GSoC-2022: Manas Sivakumar Week 7 July 31st, 2022 Merged
#236 GSoC-2022: Manas Sivakumar Week 6 July 26th, 2022 Merged
#229 GSoC-2022: Manas Sivakumar Week 5 July 18th, 2022 Merged
#227 GSoC-2022: Manas Sivakumar Week 4 July 11th, 2022 Merged
#225 GSoC-2022: Manas Sivakumar Week 3 July 3rd, 2022 Merged
#219 GSoC-2022: Manas Sivakumar Week 2 June 26th, 2022 Merged
#215 GSoC-2022: Manas Sivakumar Week 1 June 18th, 2022 Merged
#197 Task 2: Experience with GitHub & Git February 11th, 2022 GSoC Task Pull Request - Not to Merge

Slides

https://docs.google.com/presentation/d/1HbLVxSCwjrUiJE2cy3sdFihpyWihugJ02mJtr643B0Y/edit?usp=sharing

Final Report

To be added.

Community Bonding Period (May 20th - June 12th)

Tasks

  • Request writing access to the OSGeo wiki, for editing all info related to my project.
  • Set up the development environment.
  • Interact with mentors, introduce myself to the community, and actively get involved in the discussion.
  • Set up a wiki page to keep track of weekly progress.
  • Add a wiki link to OSGeo's accepted student's wiki page.
  • Studied GSoC students guide and the OSGeo recommendations for students.
  • Introduce myself and my project on OSGeo's SOC and pgrouting-dev mailing list.
  • Get familiar with pgRouting’s development style. Understand expected coding, documentation, and testing standards set by pgRouting.
  • Develop a better understanding of PostgreSQL, PostGIS, Pl/pgSQL, and how they interact with pgRouting.
  • Learn to create unit tests using pgTAP.
  • Created a public repository GSoC-pgRouting where all my works are reflected in the GSoC period.
  • Learned how and where to create Pull Request, merge and how to commit, etc.
  • Created a new branch named [to be made] in the GSoC-pgRouting repository, where I will be merging all the Pull Requests.

Meeting Discussions

  1. June 3rd

    • Introduction meeting with the mentors.
    • Basic Repository preparation of vrpRouting.
    • Understood the files and structures of functions.
  2. June 22nd

    • Learned about code structures.
    • Learned about the work of different directories like src, sql, doc, docqueries, drivers and pgtaps.
  3. July 1st

    • Review of the PR.
    • Learned how to add google OR-tools to CMakeLists.txt.
    • Learned how to make docqueries.

Pre-Bonding Period (March 07th - April 19th)

References

Clone this wiki locally