Skip to main content

Task scheduler for python

Project description

PyPlanPro

UNDER CONSTRUCTION

This project is currently under construction and is not yet ready for use. We are working hard to bring you a great project, and will update this README as soon as it's ready for use. Thank you for your patience!

In the meantime, feel free to check out the project code and contribute if you'd like. We welcome any feedback or suggestions you may have.

This Python program is a task scheduler that takes a set of tasks and assigns them to resources within their respective resource groups. The program uses Google OR-Tools library to build a constraint programming model and solve it, minimizing the makespan of the tasks.

Features

Define tasks with duration, priority, and resource groups Define resources with availability slots Schedule tasks to resources within their respective resource groups, minimizing the makespan Output the optimal or feasible schedule if found

Requirements

To run this program, you need to have the following packages installed:

Python 3.6 or later ortools (pip install ortools)

Installation

pip install pyplanpro

Usage

  1. Import the necessary classes and functions:
from pyplanpro import Resource, ResourceGroup, Task, Scheduler
  1. Define resources and resource groups:
r1_availability_slots = [
     {"slot_id" : 0, "start":0, "end":4},
     {"slot_id" : 1, "start":5, "end":10}
]
r2_availability_slots = [
     {"slot_id" : 0, "start":0, "end":10}
]
resource1 = Resource(id=1, availability_slots=r1_availability_slots)
resource2 = Resource(id=2, availability_slots=r2_availability_slots)
resource_group = ResourceGroup(id=1, resources=[resource1, resource2])
  1. Define tasks with duration, and resource group:
tasks = [Task(id=1, duration=3, resource_group=resource_group)]
  1. Set the scheduling horizon:
horizon = 50
  1. Call the Scheduler function with tasks and horizon:
s = Scheduler()
s.schedule(tasks, horizon= horizon)

If a solution is found, the program will print the optimal or feasible schedule with makespan, resource assignments, task start and end times, and durations.

Makespan = 8.0
Assigned to resource 2
Task (0, 0): starts: 0, end: 8, duration: 8

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyplanpro-0.0.6.tar.gz (22.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyplanpro-0.0.6-py3-none-any.whl (24.5 kB view details)

Uploaded Python 3

File details

Details for the file pyplanpro-0.0.6.tar.gz.

File metadata

  • Download URL: pyplanpro-0.0.6.tar.gz
  • Upload date:
  • Size: 22.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for pyplanpro-0.0.6.tar.gz
Algorithm Hash digest
SHA256 da227a0dc1fba8a3f6652bab5fb5f93c365545346c6202a23c37154a0c13fd6b
MD5 9399749589427d0159e2d904f9d27be0
BLAKE2b-256 f3b5b43330a563fefaa7f4bd3a8e2af15477c345707c343f69a13f02495e96a7

See more details on using hashes here.

File details

Details for the file pyplanpro-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: pyplanpro-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 24.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for pyplanpro-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 efcd5eb7988b8cde23a67b7cdebea910578e10007e989e280825ff9225587441
MD5 2bb6b4c62993c12392bae4e4f45c6a8a
BLAKE2b-256 9acccbc8e6659cb3527bf3a39f69bdbe4bd47663893c8344787168fb3f092fed

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page