Assignment 3 3bb4 (2)

.pdf
School
McMaster University**We aren't endorsed by this school
Course
SFWR ENG 3BB4
Subject
Industrial Engineering
Date
Dec 18, 2024
Pages
6
Uploaded by MajorWolfMaster107
LIFT = LIFT[0],LIFT[n:0..10] = (when (n < 10) enter -> LIFT[n+1]|when (n > 0) exit -> LIFT[n-1]).property CAPACITY_CHECK = CHECK[0],CHECK[i:0..10] = (when(i<10) enter -> CHECK[i+1] |when(i>0) exit -> CHECK[i-1] |when(i==0 )exit -> CHECK[0]).CARPARKCONTROL(N=4) = SPACES[N],SPACES[i:0..N] = (when(i>0) arrive->SPACES[i-1]|when(i<N) depart->SPACES[i+1]).ARRIVALS = (arrive->ARRIVALS).DEPARTURES = (depart->DEPARTURES).property SAFE_CARPARK(N=4) = SPACES[N],SPACES[i:0..N] = (when (i > 0) arrive -> SPACES[i-1]|when (i < N) depart -> SPACES[i+1]|when (i == N) depart -> SPACES[N]).progress CARS_ENTER = {arrive}||CARPARK =(ARRIVALS||CARPARKCONTROL(4)||DEPARTURES|| SAFE_CARPARK).If car departure (depart) has lower prioritythan car arrival (arrive), starvation does not occur. Lower priority for depart means that arrive actions will always take precedence whenever both actions are enabled, but, the arrive action depends on there being at least one free space in the car park (when(i > 0) in CARPARKCONTROL). Once the car park is full, the arrive action is blocked until a depart action frees up space. Since arrive actions cannot occur forever without corresponding depart actions freeing up space, depart is eventually executed. This guarantees that space is made available, allowing cars to enter, and prevents starvation.Assignment 3Thursday, November 28, 20245:29 PM3bb4 Page 1
Background image
SLAVE = (start -> rotate -> join -> SLAVE).MASTER(N=3) = MASTER[1], MASTER[i:1..N] = (slave[i].start -> rotate -> slave[i].join -> rotate -> if (i < N) then MASTER[i+1] else MASTER[1]).5.a)4.CUSTOMER = (prepay[c:1..2] -> gas[x:1..2]-> if (x==c) then CUSTOMER else ERROR).PUMP(N=2) = (activate[c:1..N][x:1..2] -> gas[c][x] -> PUMP).CASHIER(N=2, M=3) = (customer[c:1..N].prepay[x:1..2] -> activate[1..M][c][x] -> CASHIER).DELIVER(N=2, M=3) = (gas[1..M][c:1..N][x:1..2] -> customer[c].gas[x] -> DELIVER).||STATION(M=3) = (CASHIER || pump[1..M]:PUMP || DELIVER)/{pump[i:1..M].activate/activate[i],pump[i:1..M].gas/gas[i]}.||GAS_STATION(N=2) = (customer[1..N]:CUSTOMER ||STATION).b)property FIFO = (customer[i:1..2].prepay[1..2] -> PAID[i]),PAID[i:1..2] = (customer[i].gas[1..2] -> FIFO|customer[j:1..2].prepay[1..2] -> PAID[i][j]),PAID[i:1..2][j:1..2]= (customer[i].gas[1..2] -> PAID[j]).||CHECKING = (GAS_STATION || FIFO).3bb4 Page 2
Background image
||SLAVES(N=3) = forall [i:1..N] (slave[i]:SLAVE).||MASTER_SLAVES(N=3) = (MASTER(N) || SLAVES(N)).3bb4 Page 3
Background image
3bb4 Page 4
Background image
3bb4 Page 5
Background image
3bb4 Page 6
Background image