提交 77ff1e13 authored 作者: Razvan Pascanu's avatar Razvan Pascanu

Corrected __call__ of Function class to look at the flag to know if it needs

to check for input aliasing and removed the transitivity assumption on the aliasing.
上级 d1751f9b
...@@ -531,32 +531,40 @@ class Function(object): ...@@ -531,32 +531,40 @@ class Function(object):
for k, arg in kwargs.iteritems(): for k, arg in kwargs.iteritems():
self[k] = arg self[k] = arg
## Collect aliased inptus among the storage space
args_share_memory = []
for i in xrange(len(self.input_storage)):
if self.input_storage[i].storage[0] != None:
is_aliased = False
for j in xrange(len(args_share_memory)):
if numpy.may_share_memory(
self.input_storage[i].storage[0] ,
self.input_storage[args_share_memory[j][0]].storage[0]):
is_aliased = True
args_share_memory[j] += [i]
break
if not is_aliased: if ( not hasattr(self, '_check_for_aliased_inputs') or
args_share_memory.append( [i] ) self._check_for_aliased_inputs):
## Collect aliased inptus among the storage space
# Check for groups of more than one argument that share memory args_share_memory = []
for group in args_share_memory: for i in xrange(len(self.input_storage)):
if len(group) > 1: if isinstance(self.input_storage[i].storage[0],
# see if any of these arguments are mutable numpy.ndarray):
mutable = numpy.any( [self.maker.inputs[idx].mutable for is_aliased = False
idx in group]) for j in xrange(len(args_share_memory)):
# copy all but the first for k in args_share_memory[j]:
for idx in group[1:]: if numpy.may_share_memory(
self.input_storage[i].storage[0] = copy.copy( self.input_storage[i].storage[0] ,
self.input_storage[i].storage[0]) self.input_storage[k].storage[0]):
is_aliased = True
args_share_memory[j] += [i]
break
if is_aliased:
break
if not is_aliased:
args_share_memory.append( [i] )
# Check for groups of more than one argument that share memory
for group in args_share_memory:
if len(group) > 1:
# see if any of these arguments are mutable
mutable = numpy.any( [(
self.maker.inputs[idx].mutable or
self.maker.inputs[idx].borrow ) for idx in group ])
# copy all but the first
for idx in group[1:]:
self.input_storage[i].storage[0] = copy.copy(
self.input_storage[i].storage[0])
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论