请求 Simpy 资源永远不会成功
Requesting a Simpy resource never succeeds
我目前正在尝试使用 SimPy 为服务计数器建模,但我 运行 在使用 yield 来保存资源方面遇到了困难。在 Counter.arrive() 函数下,如果行 "yield req" 存在,整个函数将跳过执行(至少我认为这是因为我没有得到任何打印输出)。但是,如果我注释掉该行,代码就会像什么都没发生一样执行。这是一个问题,因为如果没有 yield,代码不会被阻塞,直到请求被批准并且整个模拟失败,因为每个人都可以使用该资源。
代码片段如下:
import simpy
class Counter:
def __init__(self, env, name, staff):
self.env = env
self.staff = simpy.Resource(env, staff)
self.name = name
self.dreq = []
def arrive(self, name):
...
req = self.staff.request()
yield req
output = "Req: %s\n" % req
self.dreq.append(req)
...
print(output)
...
def customer(env, counter, name):
print("Customer %s arrived at %s" %(name,env.now))
counter.arrive(name)
yield env.timeout(5)
print("Customer %s left at %s" %(name,env.now))
...
env = simpy.Environment()
counter = Counter(env, "A", 1)
def setup(env, counter, MAX_CUST):
for i in range(MAX_CUST):
env.process(customer(env,counter, 1))
yield env.timeout(1)
env.process(setup(env,counter,5))
env.run(until=100)
编辑:我知道使用 yield
应该暂停该功能,直到请求获得批准,但第一个请求也没有通过,这没有意义,因为有 1 个可用资源单元在开头。
文档方便:https://simpy.readthedocs.io/en/3.0.6/topical_guides/resources.html
请求(和超时以及您需要 yield
的所有内容)由 simpy 处理,因此它需要到达 simpy 才能得到处理。你告诉 simpy 用 env.process
:
处理 customer
env.process(customer(env,counter, 1))
在 customer
你调用 counter.arrive(name)
。因为 arrive
是一个生成器(因为 yield)它什么都不做,直到有东西调用它 next
。 Simpy 需要知道它才能正确处理它。您应该可以通过以下方式做到这一点:
env.process(counter.arrive(name))
这应该可以解决您的问题。
请注意,同样在此代码中,您永远不会释放资源,因此实际上只有一位客户可以到达。
我目前正在尝试使用 SimPy 为服务计数器建模,但我 运行 在使用 yield 来保存资源方面遇到了困难。在 Counter.arrive() 函数下,如果行 "yield req" 存在,整个函数将跳过执行(至少我认为这是因为我没有得到任何打印输出)。但是,如果我注释掉该行,代码就会像什么都没发生一样执行。这是一个问题,因为如果没有 yield,代码不会被阻塞,直到请求被批准并且整个模拟失败,因为每个人都可以使用该资源。
代码片段如下:
import simpy
class Counter:
def __init__(self, env, name, staff):
self.env = env
self.staff = simpy.Resource(env, staff)
self.name = name
self.dreq = []
def arrive(self, name):
...
req = self.staff.request()
yield req
output = "Req: %s\n" % req
self.dreq.append(req)
...
print(output)
...
def customer(env, counter, name):
print("Customer %s arrived at %s" %(name,env.now))
counter.arrive(name)
yield env.timeout(5)
print("Customer %s left at %s" %(name,env.now))
...
env = simpy.Environment()
counter = Counter(env, "A", 1)
def setup(env, counter, MAX_CUST):
for i in range(MAX_CUST):
env.process(customer(env,counter, 1))
yield env.timeout(1)
env.process(setup(env,counter,5))
env.run(until=100)
编辑:我知道使用 yield
应该暂停该功能,直到请求获得批准,但第一个请求也没有通过,这没有意义,因为有 1 个可用资源单元在开头。
文档方便:https://simpy.readthedocs.io/en/3.0.6/topical_guides/resources.html
请求(和超时以及您需要 yield
的所有内容)由 simpy 处理,因此它需要到达 simpy 才能得到处理。你告诉 simpy 用 env.process
:
customer
env.process(customer(env,counter, 1))
在 customer
你调用 counter.arrive(name)
。因为 arrive
是一个生成器(因为 yield)它什么都不做,直到有东西调用它 next
。 Simpy 需要知道它才能正确处理它。您应该可以通过以下方式做到这一点:
env.process(counter.arrive(name))
这应该可以解决您的问题。
请注意,同样在此代码中,您永远不会释放资源,因此实际上只有一位客户可以到达。