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.4.tar.gz (21.6 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.4-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyplanpro-0.0.4.tar.gz
  • Upload date:
  • Size: 21.6 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.4.tar.gz
Algorithm Hash digest
SHA256 536d686c075a2d5068a11f44dc2d32ce23731fe792a86318843e03a7b6b20f88
MD5 e8161d8692d6a63d11a2dd9a4c2a4b01
BLAKE2b-256 484205e83091e261e2afdbd4cbe478e6997c079505ed565ccec6dc3744cd527b

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyplanpro-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 22.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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 cd58ade8957c0107907ffd3d979286166ec45a2bff7707dbfb73ed2df2f48adf
MD5 c44e0e071726a662d3c0d90cda9282b3
BLAKE2b-256 2ff25b9b18667c69b2e8dffabecc3cec00c470db0a6491a5b495943a8d0da19a

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