Simpy:用匹配的时间存储 put/get

Simpy: Store put/get with matching times

我想模拟出租车客运系统。有C出租车站,出租车和乘客可以在离开前在那里匹配。由于出租车和乘客都在排队,我正在考虑使用 capacity = C 的 Store,其中乘客产生“get”请求,而出租车产生“put”请求。

但是,“获取”请求似乎是立即从商店获取资源(出租车)。在这种情况下如何处理匹配时间?

例如,如果有 2 个访问点,则过程将类似于

0.00 Passenger 0 arrives
0.10 Passenger 1 arrives
0.11 Taxi 0 arrives
0.11 Passenger 0 is matching with Taxi 0
0.15 Passenger 2 arrives
0.16 Taxi 1 arrives
0.16 Passenger 1 is matching with Taxi 1
0.17 Taxi 2 arrives (and wait in the queue because 2 access points are occupied)
0.20 Passenger 0 and Taxi 0 finish and leave the system
0.20 Passenger 2 is matching with Taxi 2

我的猜测是您希望一次消耗一辆出租车。但是,如果资源池有资源,它会立即满足所有请求。那么如果三个乘客同时请求打车,资源池中有三辆出租车,那么三个请求都会被同时填满。

如果你想让出租车一次消耗一个,那么你需要添加一个看门人。在这种情况下是出租车站,通常是销售柜台。

出租车站是一种资源的资源池。资源代表队列的头部。当乘客到达时,他们请求队列的头部,如果其他人已经在队列的头部,乘客排队等待轮到他们。一旦乘客排在队伍的前面,他们就会从您的出租车店叫一辆出租车。如果出租车店空无一人,则需要等待 return 秒。请注意,在他们的出租车请求实际填满之前,乘客不会释放出租车站队列的负责人。另请注意,乘客打完车后需要return打车到出租车店

看看我的例子

"""
simulation of passengers waiting for taxis at a taxi stand

Passengers first wait to be first in line to seize the taxi stand
Then they wait for the next taxi
There is a short delay as the passenger gets into to taxi
before the passenger releases the the taxi stand, allowing 
the next passenger to wait for the next taxi

When the sim start, the taxi stand will have a queue of taxi
that will be eventualy depleted by the arriving passengers
as the passengers arrive faster then the taxi can server

programmer Michael R. Gibbs
"""

import simpy
from random import randint

class IdClass():
    """
    quick class that generates unique id's 
    for each object created
    """

    nextId = 1

    def __init__(self):
        self.id = type(self).nextId
        type(self).nextId +=1

class Passenger(IdClass):
    """
    Passenger waiting for a taxi
    """


class Taxi(IdClass):
    """
    Taxi is the resource passengers are competing for
    """


def getTaxi(env, passenger, taxiStand, taxiQueue):
    """
    passenger waits for cab
    then takes cap for a trip
    Taxi returns after trip
    """

    

    # get in line at the taxi stand
    with taxiStand.request() as turnReq:
        print(f'{env.now} passenger {passenger.id} has entered taxi stand queue')
        yield turnReq

        # first in line, now wait for taxi
        print(f'{env.now} passenger {passenger.id} is waiting for taxi')
        taxi = yield taxiQueue.get()

        # got taxi, tine to get into cab
        print(f'{env.now} passenger {passenger.id} has taken taxi {taxi.id}')
        yield env.timeout(2)

        # now cab leaves and taxi stand is free for next passenger

    # leave stand and use taxit
    print(f'{env.now} taxi {taxi.id} has left')
    yield env.timeout(randint(10,60))

    # taxi returns for next passenger
    yield taxiQueue.put(taxi)
    print(f'{env.now} taxi {taxi.id} has return')


def genPassengers(env, taxiStand, taxiQueue):
    """
    generates arriving passengers and kicks off their taxi use
    """

    while True:
        yield env.timeout(randint(1,15))
        env.process(getTaxi(env,Passenger(), taxiStand, taxiQueue))


# create simulation
env = simpy.Environment()

# start taxiStand
taxiStand = simpy.Resource(env, capacity=1)

# start taxi queue with 5 taxies
taxiQueue = simpy.Store(env) # unlimited capacity
taxiQueue.items = [Taxi() for _ in range(5)]

# start taxi stand with a queue of 3 passengers
for _ in range(3):
    env.process(getTaxi(env, Passenger(),taxiStand,taxiQueue))

# start generating passengers
env.process(genPassengers(env,taxiStand,taxiQueue))

# start sim
env.run(until = 100)