default_scope_funcs.py 1.9 KB
Newer Older
Y
Yu Yang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
"""
Default scope function.

`Paddle` manages Scope as programming language's scope.  It just a 
thread-local stack of Scope. Top of that stack is current scope, the bottom 
of that stack is all scopes' parent. 

Invoking `create_var/get_var`  can `create/get` variable in current scope. 
Invoking `enter_local_scope/leave_local_scope` can create or destroy local 
scope. 

A `scoped_function` will take a `function` as input. That function will be 
invoked in a new local scope. 
"""

import paddle.v2.framework.core
import threading

__tl_scope__ = threading.local()

__all__ = [
    'get_cur_scope', 'enter_local_scope', 'leave_local_scope', 'create_var',
    'get_var', 'scoped_function'
]


def get_cur_scope():
    """
    Get current scope.
    :rtype: paddle.v2.framework.core.Scope
    """
    cur_scope_stack = getattr(__tl_scope__, 'cur_scope', None)
    if cur_scope_stack is None:
        __tl_scope__.cur_scope = list()
    if len(__tl_scope__.cur_scope) == 0:
        __tl_scope__.cur_scope.append(paddle.v2.framework.core.Scope(None))
    return __tl_scope__.cur_scope[-1]


def enter_local_scope():
    """
    Enter a new local scope
    """
    cur_scope = get_cur_scope()
    new_scope = paddle.v2.framework.core.Scope(cur_scope)
    __tl_scope__.cur_scope.append(new_scope)


def leave_local_scope():
    """
    Leave local scope
    """
    __tl_scope__.cur_scope.pop()


def create_var(name):
    """
    create variable in current scope.
    """
    return get_cur_scope().create_var(name)


def get_var(name):
    """
    get variable in current scope.
    """
    return get_cur_scope().get_var(name)


def scoped_function(func):
    """
    invoke `func` in new scope.
    
    :param func: a callable function that will be run in new scope.
    :type func: callable
    """
    enter_local_scope()
    try:
        func()
    except:
        raise
    finally:
        leave_local_scope()