Skip to content

ClusterSchedulingEnv is a Gymnasium-compatible reinforcement learning environment designed to simulate complex cluster scheduling scenarios. It provides a robust framework for developing and testing reinforcement learning agents in environments where resource management, scheduling, and optimization are critical.

Notifications You must be signed in to change notification settings

dev0Guy/ClusterSchedulingEnv

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Nov 16, 2024
45fabbf · Nov 16, 2024

History

37 Commits
Nov 16, 2024
Nov 16, 2024
Nov 16, 2024
Nov 16, 2024
Nov 16, 2024
Nov 16, 2024
Nov 16, 2024
Nov 16, 2024

Repository files navigation

Cluster Environment Gym

The ClusterEnv environment is a simulation of a cluster system designed to manage the scheduling and allocation of jobs on machines with limited resources. It is built using the gymnasium library and supports custom configurations for jobs, machines, and resources.

Wrappers

Observation Wrapper

CombineMachinJobWrapper

The wrapper combines two separate observation components, jobs and machines, into a single unified observation space.

Action Wrapper

DiscreteActionWrapper

The wrapper simplifies the action space by converting it into a discrete set of actions, enabling agents to operate within a simpler action space. Here’s a detailed breakdown of its functionality: In the ClusterEnv, the default action space may involve complex multi-dimensional actions, such as specifying machine-job pairings or time management commands. This wrapper:

  1. Converts the action space into a discrete space of size (J * M + 1):
    • additional action represents a “skip time” operation.
    • The remaining actions represent all possible combinations of jobs and machines.
  2. Transforms a discrete action into a corresponding multi-dimensional action understandable by the ClusterEnv

Reward Wrapper

AverageSlowDownReward

custom Gymnasium RewardWrapper for the ClusterEnv environment that penalizes the agent based on the average slowdown of pending jobs. It tracks the number of ticks that each job remains in the Pending state, incrementing a slowdown counter for such jobs at each clock tick. The reward is calculated as the negative sum of the inverse of the slowdown values for all pending jobs, incentivizing the agent to prioritize reducing job slowdowns. This wrapper promotes efficient job scheduling by penalizing prolonged delays in job execution.

S i = S i + 1 Pending , i ( t ) R ( t ) = i = 1 N 1 S i where  S i > 0

Env Wrapper

ScheduleFromSelectedTimeWrapper

The wrapper customizes job scheduling in the ClusterEnv by dynamically validating and scheduling jobs based on resource availability and arrival times. It ensures jobs are scheduled only if sufficient resources are available on the target machine for the required duration using a sliding window approach. The wrapper updates machine resource states upon successful scheduling, preventing over-allocation or invalid assignments. This ensures efficient resource utilization and supports dynamic scheduling in resource-constrained environments.

QueueWrapper

The wrapper modifies the ClusterEnv to focus on a subset of jobs (queue_size), sorting them by status and dynamically updating their order based on priority (e.g., pending jobs). It adjusts the action space to reference only the selected subset of jobs and remaps job indices in actions accordingly. The observation space is modified to include only the top queue_size jobs and their statuses, ensuring that the agent operates on the most relevant subset. This wrapper streamlines decision-making by reducing complexity while prioritizing pending jobs for scheduling.

Extra Information

Notations:

  • J : Number of jobs
  • R: Number of resources
  • T: Number of ticks
  • A: Job arrival rate

Observation space

The environment provides the following observation:

  • Machines: Free space per resource over time. Shape: (M, R, T)
  • Jobs: Resource utilization demands over time. Shape: (J, R, T)
  • Status: Current state of each job (Not Created, Pending, Running, Completed). Shape: (J)

Action space

consist of gym.spaces.MultiDiscrete of [TickActionOptions, M, J]
where TickActionOptions:
0 - No time increment
1 - Increment time

Job Generation Process

The following describes the mathematical process used to generate jobs

  1. Job Arrival Times -
    Job arrival times are modeled as a Bernoulli process:
T enter , i = j = 1 i B j , B j Bernoulli ( p )
  1. Job Durations -
    Job durations are sampled from a mixture of two uniform distributions:
D i = { Uniform ( 1 , 3 ) , if  U i < 0.8   Uniform ( 10 , 15 ) , otherwise where U i Uniform ( 0 , 1 )
  1. Resource Demands -
    Each job (i) is assigned resource demands based on its dominant resource:
R i , k = { Uniform ( 127.5 , 255 ) , if  k = R dom , i   Uniform ( 25.5 , 51 ) , if  k R dom , i where R dom , i Uniform { 0 , R 1 }
  1. Job Activity Over Time -
    Jobs are active based on their arrival times and durations:
A i , t = { 1 , if  T enter , i t < T enter , i + D i   0 , otherwise
  1. Final Resource Utilization-
    The 3D array representing job resource utilization is calculated as:
J i , k , t = A i , t R i , k J i , k , t = A i , t R i , k

Machines Generation Process

Each machine is reset with 255.0 of shape (J,R,T)

About

ClusterSchedulingEnv is a Gymnasium-compatible reinforcement learning environment designed to simulate complex cluster scheduling scenarios. It provides a robust framework for developing and testing reinforcement learning agents in environments where resource management, scheduling, and optimization are critical.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages