R in action读书笔记(21)第十六章 高级图形进阶(上)
16.1 R 中的四种图形系统
基础图形函数可自动调用,而grid和lattice函数的调用必须要加载相应的包(如library(lattice))。要调用ggplot2函数需下载并安装该包(install.packages("ggplot2")),第一次使用前还要进行加载(library(ggplot2))。
16.2 lattice 包
lattice包为单变量和多变量数据的可视化提供了一个全面的图形系统。在一个或多个其他变量的条件下,栅栏图形展示某个变量的分布或与其他变量间的关系。
> library(lattice)
> histogram(~height|voice.part,data=singer,main="Distributionof heights by voice pitch",xlab="height (inches)")
lattice包提供了丰富的函数,可生成单变量图形(点图、核密度图、直方图、柱状图和箱线图)、双变量图形(散点图、带状图和平行箱线图)和多变量图形(三维图和散点图矩阵)。各种高级绘图函数都服从以下格式:
graph_function(formula,data=,options)
graph_function是某个函数。
formula指定要展示的变量和条件变量。
data指定一个数据框。
options是逗号分隔参数,用来修改图形的内容、摆放方式和标注。
lattice中高级绘图函数的常见选项
lattice绘图示例:
> gear<-factor(gear,levels=c(3,4,5),labels=c("3 gears","4 gears","5 gears"))
> cyl<-factor(cyl,levels=c(4,6,8),labels=c("4 cylinders","6 cylinders","8 cylinders"))
> densityplot(~mpg,main="Density plot",xlab="miles per gallon")
> densityplot(~mpg | cyl,main="Density plot by number of cylinders",xlab="miles per gallon")
> bwplot(cyl~mpg|gear,main="box plots by cylinders and gears",xlab="carweight",ylab="cylinders")
> xyplot(mpg~wt|cyl*gear,main="scatter plots by cylinders and gears",xlab="car weight",ylab="miles per gallon")
> cloud(mpg~wt*qsec|cyl,main="d scatter plots by cylinders")
> dotplot(cyl~mpg|gear,main="dot plots by number of gears and cylinders",xlab="miles per gallon"
> splom(mtcars[c(1,4,5,6)],main="scatter plot matrix for mtcars data")
16.2.1 条件变量
> myshingle<-equal.count(x,number=#,overlap=proportion)
将会把连续型变量x分割到#区间中,重叠度为proportion,每个数值范围内的观测数相等,并返回为一个变量myshingle(或类shingle)。输出或者绘制该对象(如plot(myshingle))将会展示瓦块区间。一旦一个连续型变量被转换为一个瓦块,你便可以将它作为一个条件变量使用。
> displacement<-equal.count(mtcars$disp,number=3,overlap=0)
> xyplot(mpg~wt|displacement,data=mtcars,
+ main="miles per gallon vs weight by engine displacement",
+ xlab="weight",ylab="miles per gallon",
+ layout=c(3,1),aspect=1.5)
16.2.2 面板函数
每个高级绘图函数都调用了一个默认的函数来绘制面板。这些默认的函数服从如下命名惯例:panel.graph_function,其中graph_function是该水平绘图函数。如:xyplot(mpg~wt|displacement,data=mtcars)也可以写成:xyplot(mpg~wt|displacement,data=mtcars,panel=panel.xyplot)。自定义面板函数的xyplot:
>displacement<-equal.count(mtcars$disp,number=3,overlap=0)
> mypanel<-function(x,y){
+ panel.xyplot(x,y,pch=19)
+ panel.rug(x,y)
+ panel.grid(h=-1,v=-1)
+ panel.lmline(x,y,col="red",wd=1,lty=2)
+ }
>xyplot(mpg~wt|displacement,data=mtcars,
+ layout=c(3,1),
+ aspect=1.5,
+ main="miles per gallon vs weightby engine displacement",
+ xlab="weight",ylab="miles per gallon",
+ pannel=mypanel)
自定义面板函数和额外选项的xyplot
> library(lattice)
>mtcars$transmission<-factor(mtcars$am,levels=c(0,1),
+ labels=c("Automatic","Manual"))
> panel.smoother<-function(x,y){
+ panel.grid(h=-1,v=-1)
+ panel.xyplot(x,y)
+ panel.loess(x,y)
+ panel.abline(h=mean(y),lwd=2,lty=2,col="green")
+ }
> xyplot(mpg~disp|transmission,data=mtcars,
+ scales=list(cex=.8,col="red"),
+ panel=panel.smoother,
+ xlab="displacement",ylab="miles per gallon",
+ main="mpg vs displacement bytransmission typr",
+ sub="dotted lines are group means",aspect=1)
16.2.3 分组变量
当一个lattice图形表达式含有条件变量时,将会生成在该变量各个水平下的面板。若你想将结果叠加到一起,则可以将变量设定为分组变量(grouping variable).
> library(lattice)
>mtcars$transmission<-factor(mtcars$am,levels=c(0,1),
+ labels=c("Automatic","Manual"))
> densityplot(~mpg,data=mtcars,
+ group=transmission,
+ main="mpg distributuion bytransmission type",
+ xlab="miles per gallon",
+ auto.key=TRUE)
对图例进行更多的控制,可使用key =选项
> library(lattice)
> mtcars$transmission<-factor(mtcars$am,levels=c(0,1),
+ labels=c("Automatic","Manual"))
>colors=c("red","blue")#设定颜色、线和点类型
> lines=c(1,2)
> points=c(16,17)
>key.trans<-list(title="Transmission",#自定义图例
+ space="bottom",columns=2,
+ text=list(levels(mtcars$transmission)),
+ points=list(pch=points,col=colors),
+ lines=list(col=colors,lty=lines),
+ cex.title=1,cex=.9)
>densityplot(~mpg,data=mtcars,
+ group=transmission,
+ main="mpg distributuion bytransmission type",
+ xlab="miles per gallon",
+ pch=points,lty=lines,col=colors,#自定义密度图
+ lwd=2,jitter=.005,
+ key=key.trans)
包含分组变量和条件变量以及自定义图例的xyplot
> library(lattice)
>colors="darkgreen"
> symbols<-c(1:12)
> linetype<-c(1:3)
>
>key.species<-list(title="plant",
+ space="right",
+ text=list(levels(CO2$Plant)),
+ points=list(pch=symbols,col=colors))
>
>xyplot(uptake~conc|Type*Treatment,data=CO2,
+ group=Plant,
+ type="o",
+ pch=symbols,col=colors,lty=linetype,
+ main="carbon dioxide uptake\ningrass plants",
+ ylab=expression(paste("Uptake",
+ bgroup("(",italic(frac("umol","m"^2)),")"))),
+ xlab=expression(paste("Concenteation",
+ bgroup("(",italic(frac(mL,L)),")"))),
+ sub="Grass species:echinochloacrus-gailli",
+ key=key.species)
R in action读书笔记(21)第十六章 高级图形进阶(上)的更多相关文章
- R in action读书笔记(22)第十六章 高级图形进阶(下)
16.2.4 图形参数 在lattice图形中,lattice函数默认的图形参数包含在一个很大的列表对象中,你可通过trellis.par.get()函数来获取,并用trellis.par.set() ...
- R in action读书笔记(12)第九章 方差分析
第九章方差分析 9.2 ANOVA 模型拟合 9.2.1 aov()函数 aov(formula, data = NULL, projections =FALSE, qr = TRUE, contra ...
- R in action读书笔记(8)-第八章:回归(上)
8.1回归的多面性 8.2 OLS回归 OLS回归拟合模型形式: 为了能够恰当地解释oLs模型的系数,数据必须满足以下统计假设. 口正态性对于固定的自变量值,因变量值成正态分布. 口独立性Yi值之间相 ...
- Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第十六章:实例化和截头锥体裁切
原文:Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第十六章:实例化和截头锥体裁切 代码工程地址: https://git ...
- UNP学习笔记(第二十六章 线程)
线程有时称为轻权进程(lightweight process) 同一进程内的所有线程共享相同的全局内存.这使得线程之间易于共享信息,然后这样也会带来同步的问题 同一进程内的所有线程处理共享全局变量外还 ...
- R in action读书笔记(19)第十四章 主成分和因子分析
第十四章:主成分和因子分析 本章内容 主成分分析 探索性因子分析 其他潜变量模型 主成分分析(PCA)是一种数据降维技巧,它能将大量相关变量转化为一组很少的不相关变量,这些无关变量称为主成分.探索性因 ...
- R in action读书笔记(16)第十二章 重抽样与自助法之 置换检验
第十二章:重抽样与自助法 本章,我们将探究两种应用广泛的依据随机化思想的统计方法:置换检验和自助法 12.1 置换检验 置换检验,也称随机化检验或重随机化检验. 有两种处理条件的实验,十个受试者已经被 ...
- WPF,Silverlight与XAML读书笔记第四十六 - 外观效果之三皮肤与主题
说明:本系列基本上是<WPF揭秘>的读书笔记.在结构安排与文章内容上参照<WPF揭秘>的编排,对内容进行了总结并加入一些个人理解. 皮肤 皮肤是应用程序中样式与模板的集合,可以 ...
- 《深入理解java虚拟机》读书笔记十一——第十二章
第十二章 Java内存模型与线程 1.硬件效率与一致性 由于计算机的存储设备与处理器的运算速度有几个数量级的差距,所以现代计算机系统都不得不加入一层读写速度尽可能接近处理器运算速度的高速缓存(Cac ...
随机推荐
- 查看和改动MySQL数据库表存储引擎
要做一名合格的程序猿,除了把代码写的美丽外,熟知数据库方面的知识也是不可或缺的.以下总结一下怎样查看和改动MySQL数据库表存储引擎: 1.查看数据库所能支持的存储引擎: ...
- 大学生程序设计邀请赛(华东师范大学)B. 分词 DP
B. 分词 有一句句子因为粘贴的时候出现了一点问题空格全部丢失了.现在给一本字典,每个词都对应这个词出现的频率(每十亿).根据这个频率,我们可以根据下面的公式算出这个词带来的收益 P(word): ...
- 请说出作用域public,private,protected,以及不写时的区别
这四个作用域的可见范围如下表所示. 说明:如果在修饰的元素上面没有写任何访问修饰符,则表示friendly. 作用域 当前类 同一package 子孙类 其他package public ...
- openfire源码编译后部署到linux
1.源码通过编号后,会生成target目录,直接把target目录拷贝到linux下即可: 2.启动openfire: ./openfire.sh start 3.退出直接ctr + c 问题:如果一 ...
- HDU4642博弈好题
链接:http://acm.hdu.edu.cn/ 两个人进行翻棋游戏,若a[n][m]为1,则不管先手就可以翻a[n][m]使其为0,这样不管后手翻什么都会使得a[n][m]为1,先手总是有棋可翻: ...
- 【转】Commonjs规范及Node模块实现
前言: Node在实现中并非完全按照CommonJS规范实现,而是对模块规范进行了一定的取舍,同时也增加了少许自身需要的特性.本文将详细介绍NodeJS的模块实现 引入 nodejs是区别于javas ...
- Python基础第九天
一.内容
- box-shadow 模拟border
border会占据空间;如果想加边框效果,但是又不占用空间,可以使用box-shadow来模拟 demo div 100*100 border:10px solid red; 可以写: div 100 ...
- C#即时通讯系统设计与实现(一)
最近学习了一下即时通讯,写了几天了,现在把遇到的问题和得到的心得在这里分享下. 即时通讯,C/S模式,在服务器上架设服务端,服务端是服务形式的,可以设置为开机自启动,客户端进行访问,可以安装在任意一台 ...
- bzoj 1025: [SCOI2009]游戏【数学+dp】
很容易发现行数就是lcm环长,也就是要求和为n的若干数lcm的个数 有结论若p1^a1+p2^a2+...+pm^am<=n,则ans=p1^a1p2^a2..*pm^am是n的一个可行答案.( ...