Implementation
Scheduling Horizon
We need 6 days for previous month.
data:image/s3,"s3://crabby-images/73ec9/73ec9cc424669d6c3870e5a87c27c41cd09cc9d0" alt=""
Days Sets
We define the 1st week including six previous month days.
data:image/s3,"s3://crabby-images/dde4e/dde4e15ad89b289b0f7abc92fbb9958188ce68d9" alt=""
Then, the days set above should include one Monday.
data:image/s3,"s3://crabby-images/e8f33/e8f330a2f63ea375698bf26442624a30820ad45c" alt=""
We can create 1stMondayWeek,2ndMondayWeek..
data:image/s3,"s3://crabby-images/c6e83/c6e831505dc03efeda360ae7f62d304290daf042" alt=""
Using the days set above, we constraint work hours.
data:image/s3,"s3://crabby-images/7f2f1/7f2f1555f1cb719ecdb66cea54d69f68df613b8e" alt=""
Macro
Calculate work hours for the 5th and 6th weeks using a macro because of the possibility of fractions of days.
data:image/s3,"s3://crabby-images/ce75a/ce75a6096c570fea6722c21d207aadbc745c970e" alt=""
Formula I calculates the day of the week. Note that it is calculated only for periods of 5 days or more. This is because if the period is too narrow, the required staff may be inadequate.
data:image/s3,"s3://crabby-images/9949f/9949fee2d2e0be2c5ae27ef0da019967f77d0d89" alt=""
Formula H is linear calculatiion.
data:image/s3,"s3://crabby-images/dae9c/dae9c294b135dc35411a3e24be44d300bf758ff0" alt=""
Expression G performs the rounding up process. Solvers can only process in increments of 15 minutes, so we will use 0.25 hour increments.
data:image/s3,"s3://crabby-images/81227/81227a8d38658189251081b0661d3acb14c55780" alt=""
Load the Example Project File
File → Open Project File from GitHub
data:image/s3,"s3://crabby-images/14413/144130b960885033630c76817447aa4644713f38" alt=""