• R Programming week2 Functions and Scoping Rules


    A Diversion on Binding Values to Symbol

    When R tries to bind a value to a symbol,it searches through a series of environments to find the appropriate value.When you are working on the command line and need to retrieve the value of an Robject, the order is roughly

    1. Search the global environment for asymbol name matching the one requested.

    2. Search the namespaces of each of thepackages on the search list

    The search list can be found by using thesearch function.

    >search() [1] ".GlobalEnv" "package:stats""package:graphics" [4] "package:grDevices""package:utils" "package:datasets" [7]"package:methods" "Autoloads" "package:base"

    Binding Values to Symbol

    The global environment or the user’sworkspace is always the first element of the search list and

    the base package is always the last.

    The order of the packages on the searchlist matters!

    User’s can configure which packages getloaded on startup so you cannot assume that there will

    be a set list of packages available.

    When a user loads a package with librarythe namespace of that package gets put in position

    2 of the search list (by default) andeverything else gets shifted down the list.

    Note that R has separate namespaces forfunctions and non-functions so it’s possible to have an

    object named c and a function named c.

    Scoping Rules

    The scoping rules for R are the mainfeature that make it different from the original S language. The scoping rulesdetermine how a value is associated with a free variable in a function

    R uses lexical scoping or static scoping. Acommon alternative is dynamic scoping.

    Related to the scoping rules is how R usesthe search list to bind a value to a symbol

    Lexical scoping turns out to beparticularly useful for simplifying statistical computations

    Lexical Scoping

    Consider the following function.

    f<- function(x, y) {

    x^2 + y / z

    }

    This function has 2 formal arguments x andy. In the body of the function there is another symbol z. In this case z iscalled a free variable. The scoping rules of a language determine how valuesare assigned to free variables. Free variables are not formal arguments and arenot local variables (assigned insided the function body).

    Lexical scoping in R means that:

    the values of free variables are searchedfor in the environment in which the function was defined.

    What is an environment?

    An environment is a collection of (symbol,value) pairs, i.e. x is a symbol and 3.14 might be its

    value.

    Every environment has a parent environment;it is possible for an environment to have multiple

    “children”

    the only environment without a parent isthe empty environment

    A function + an environment = a closure orfunction closure

    Searching for the value for a freevariable:

    If the value of a symbol is not found inthe environment in which a function was defined, then the

    search is continued in the parentenvironment.

    The search continues down the sequence ofparent environments until we hit the top-level

    environment; this usually the globalenvironment (workspace) or the namespace of a package.

    After the top-level environment, the searchcontinues down the search list until we hit the empty

    environment. If a value for a given symbolcannot be found once the empty environment is

    arrived at, then an error is thrown.

    Why does all this matter?

    Typically, a function is defined in theglobal environment, so that the values of free variables are

    just found in the user’s workspac

    This behavior is logical for most peopleand is usually the “right thing” to do

    However, in R you can have functionsdefined inside other functions

    -Languages like C don’t let you do this

    Now things get interesting — In this casethe environment in which a function is defined is the

    body of another function!

    make.power<- function(n) {

    pow <- function(x) {

    x^n

    }

    pow

    }

    This function returns another function asits value

    >cube <- make.power(3)

    >square <- make.power(2)

    >cube(3)

    [1]27

    >square(3)

    [1] 9

    Exploring a Function Closure

    What’s in a function’s environment?

    >ls(environment(cube))

    [1]"n" "pow"

    >get("n", environment(cube))

    [1] 3

    >ls(environment(square))

    [1]"n" "pow"

    >get("n", environment(square))

    [1] 2

    Lexical vs. Dynamic Scoping

    y<- 10

    f<- function(x) {

    y <- 2

    y^2 + g(x)

    }

    g<- function(x) {

    x*y

    }

    With lexical scoping the value of y in thefunction g is looked up in the environment in which the

    function was defined, in this case theglobal environment, so the value of y is 10.

    With dynamic scoping, the value of y islooked up in the environment from which the function was

    called (sometimes referred to as thecalling environment).

    - InR the calling environment

    So the value of y would be 2.

    When a function is defined in the globalenvironment and is subsequently called from the global environment, then thedefining environment and the calling environment are the same. This cansometimes give the appearance of dynamic scoping.

    >g <- function(x) {

    + a<- 3

    +x+a+y

    + }

    >g(2)

    Errorin g(2) : object "y" not found

    >y <- 3

    >g(2)

    [1] 8

    Consequences of Lexical Scoping

    In R, all objects must be stored in memory

    All functions must carry a pointer to theirrespective defining environments, which could be

    anywhere

    In S-PLUS, free variables are always lookedup in the global workspace, so everything can be

    stored on the disk because the “definingenvironment” of all functions is the same.

  • 相关阅读:
    ASP.NET Core应用程序容器化、持续集成与Kubernetes集群部署(二)
    ASP.NET Core应用程序容器化、持续集成与Kubernetes集群部署(一)
    2018年9月15日上海MVP线下技术交流活动简报
    在.NET中使用机器学习API(ML.NET)实现化学分子式数据格式的判定
    使用Roslyn的C#语言服务实现UML类图的自动生成
    ASP.NET Core应用程序的参数配置及使用
    微软最有价值专家(Microsoft MVP)项目经验分享
    漫谈单体架构与微服务架构(上):单体架构
    ASP.NET Core Web API下事件驱动型架构的实现(五):在微服务中使用自我监听模式保证数据库更新与消息派发的可靠性
    使用C#读写结构化的二进制文件
  • 原文地址:https://www.cnblogs.com/jpld/p/4444228.html
Copyright © 2020-2023  润新知