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.
R Programming week2 Functions and Scoping Rules的更多相关文章
- R Programming week2 Control Structures
Control Structures Control structures in R allow you to control the flow of execution of the program ...
- Coursera系列-R Programming第二周
博客总目录,记录学习R与数据分析的一切:http://www.cnblogs.com/weibaar/p/4507801.html --- 好久没发博客 且容我大吼一句 终于做完这周R Progra ...
- Coursera系列-R Programming第三周-词法作用域
完成R Programming第三周 这周作业有点绕,更多地是通过一个缓存逆矩阵的案例,向我们示范[词法作用域 Lexical Scopping]的功效.但是作业里给出的函数有点绕口,花费了我们蛮多心 ...
- 让reddit/r/programming炸锅的一个帖子,还是挺有意思的
这是原帖 http://www.reddit.com/r/programming/comments/358tnp/five_programming_problems_every_software_en ...
- 解决proto文件转换时提示“Note that enum values use C++ scoping rules, meaning that enum values are siblings of their type, not children of it. ”
前言: 想将.proto文件转换成.pb文件时一直报错,一开始以为是文件编码格式的问题,后来将文件改成windows下的utf-8格式后,又出现了新的报错(见下图).百度了很久,才找到解决方法. &q ...
- R Programming week 3-Loop functions
Looping on the Command Line Writing for, while loops is useful when programming but not particularly ...
- [R] [Johns Hopkins] R Programming 作業 Week 2 - Air Pollution
Introduction For this first programming assignment you will write three functions that are meant to ...
- Standard C++ Programming: Virtual Functions and Inlining
原文链接:http://www.drdobbs.com/cpp/standard-c-programming-virtual-functions/184403747 By Josée Lajoie a ...
- R Programming week 3-Debugging
Something’s Wrong! Indications that something’s not right message: A generic notification/diagnostic ...
随机推荐
- HTML form表单的默认提交方式
默认为Get,亲测.. key值为控件name属性值,如果没有 url中就没有此值 aspx中默认Form表单提交方式为post
- HOSVD高阶奇异值分解
高阶奇异值分解(High Order Singular Value Decomposition, HOSVD) 奇异值分解SVD(Singular Value Decomposition)是线性 ...
- oracle安装登录sqlplus / as sysdba然后报错ERROR: ORA-01031 insufficient privileges
解决办法: 一般情况下检查操作系统的登录用户是否包含在ORA_DBA组中. 控制面板->管理工具->计算机管理->系统工具->本地用户和组->ORA_DBA组. 如果OR ...
- GitHub Pages使用入门
1.什么是GitHub Pages GitHub Pages可以当做项目的Websites,GitHub Pages有两种最基本的用法: 作为你自己(或者组织)的网站(访问地址示例:http://us ...
- java抛出异常后,后续代码是否可继续执行
参考:https://www.cnblogs.com/wangyingli/p/5912269.html 仅此可正常执行异常后内容 try{ throw new Exception("参数越 ...
- CAShapeLayer和贝塞尔曲线配合使用
前言 CAShapeLayer继承自CALayer,因此,可使用CALayer的所有属性.但是,CAShapeLayer需要和贝塞尔曲线配合使用才有意义. 关于UIBezierPath,请阅读文章:i ...
- Ueditor中代码的高亮和背景在前端页面的实现
首先废话就不多说,这个富文本编辑器的下载和js等基本文件的导入略. 我的最终目标是这样的,我们在页面中的富文本框中输入代码,希望它能够被后台接受.存入数据库,当通过服务器将这些代码再一次显示在前台的页 ...
- CodeForces 723D Lakes in Berland (dfs搜索)
题意:给定一个n*m的矩阵,*表示陆地, . 表示水,一些连通的水且不在边界表示湖,让你填最少的陆地使得图中湖剩下恰好为k. 析:很简单的一个搜索题,搜两次,第一次把每个湖的位置和连通块的数量记下来, ...
- P3755 [CQOI2017]老C的任务
传送门 可以离线,把询问拆成四个,然后把所有的按\(x\)坐标排序,这样就只要考虑\(y\)坐标了.然后把\(y\)坐标离散化,用树状数组统计即可 记得开longlong //minamoto #in ...
- 洛谷P4216 [SCOI2015]情报传递(树剖+主席树)
传送门 我们可以进行离线处理,把每一个情报员的权值设为它开始收集情报的时间 那么设询问的时间为$t$,就是问路径上有多少个情报员的权值小于等于$t-c-1$ 这个只要用主席树上树就可以解决了,顺便用树 ...