时间:2021-05-20
对于那些有一点编程经验的人来说,vector,matrix,array,list,data.frame就相当于编程语言中的容器,因为只是将R看做数据处理工具所以它们的底层是靠什么实现的,内存怎么处理的具体也不要深究。
R语言很奇怪的是它是面向对象的语言,所以经常会调用系统的方法,而且更奇怪的是总是调用“谓语”的方法,用起来像是写句子一样,记起来真是让人费解。比如is.vector(),read.table(),as.vector()、、
直接开始吧:(由于习惯,大部分用"="代替"<-")
或者赋值函数assign,
assign("a",c(1,2,3,4,5,6,7,8,9)) > is.vector(a)[1] TRUE > is.matrix(a) [1] FALSE> is.array(a)[1] FALSE> is.list(a)[1] FALSE或者利用随机分布函数,rnrom(n,mean,sd),runif(n,min,max)、、、
> b=runif(20,min=1,max=20)> b [1] 2.181016 18.417605 9.748379 2.122849 1.281871 4.099617 [7] 14.162348 18.034863 7.464664 9.599227 18.973259 1.900773[13] 8.995223 11.048916 11.667131 3.859275 17.992988 1.089552[19] 13.490061 12.864029或者按照一定的步长:
> a=seq(1,20,by=3)> a[1] 1 4 7 10 13 16 19或者重复:
> s=rep(a,times=3)> s [1] 1 4 7 10 13 16 19 1 4 7 10 13 16 19 1 4 7 10 13 16 19逻辑向量:
> b=a>8;b[1] FALSE FALSE FALSE TRUE TRUE TRUE TRUE缺失数据用大写NA表示,数据不确定用NaN表示,数据是无穷用Inf表示(一会全大写,一会大写加小写,一会首字母大写,真是醉了),判断是否为空数据用函数is.na(),判断是否不确定用函数is.nan(),数据是否有限用is.finite(),数据是否为无穷用函数is.infinite():
> z=c(1:3,Na);zError: object 'Na' not found> z=c(1:3,NA);z[1] 1 2 3 NA > is.na(z)[1] FALSE FALSE FALSE TRUE将缺失的数据赋值为0:
> z[is.na(z)]=0;z[1] 1 2 3 0下面将这几个有问题的数据放在一个向量中:
> z=c(0/1,0/0,1/0,NA);z[1] 0 NaN Inf NA> is.na(z)[1] FALSE TRUE FALSE TRUE> is.nan(z)[1] FALSE TRUE FALSE FALSE> is.finite(z)[1] TRUE FALSE FALSE FALSE> is.infinite(z)[1] FALSE FALSE TRUE FALSE可以看见,与容器不同,vector的下标是从1开始的:
> a[0]numeric(0) > a[1][1] 3选取第2和第3个数,引用非常方便:
引用除了第一个值的所有数,用了减号"-":
> a[-c[1]][1] 8 8 8 2 7 3 5 3①+-×÷,其他运算如log,exp,cos,sqrt等也相似。其意义是对应的向量的每个元素分别做运算,
> x=c(1,2,3)> y=c(2,3,4)> z=2*x+y-1> z[1] 3 6 9 > x^2[1] 1 4 9 > cos(x)[1] 0.5403023 -0.4161468 -0.9899925 > sqrt(x)[1] 1.000000 1.414214 1.732051②与向量有关的函数,min(x),max(x), sum(x),range(x),太简单就不在细说,需要强调的是which.min(x),这个还是蛮重要的。
> a=rnorm(10,mean=5,sd=2)> a [1] 5.914559 2.604346 5.342572 9.006863 6.547221 7.519781 7.330211 [8] 8.322956 6.875491 5.883626> which.max(a)[1] 4> which.min(a)[1] 2> a[which.max(a)][1] 9.006863> a[which.min(a)][1] 2.604346其他的如sd(a),var(a),length(a),sort(a),分别是求方差,标准差,长度,排序。与python不同R语言的vector所有操作都不会改变vector本身的值。
R的对象都有两个基本的属性:mode和length,向量的类型为:logical(逻辑型)、numeric(数值型)、complex(复数型)、character(字符型)。
> b=c(0:9)> b [1] 0 1 2 3 4 5 6 7 8 9> is.numeric(b)[1] TRUE> is.character(b)[1] FALSE> c=as.character(b)> c [1] "0" "1" "2" "3" "4" "5" "6" "7" "8" "9"> is.numeric(c)[1] FALSE> is.character(c)[1] TRUE多维的同一类型集合(字符型、数值型、逻辑型、复数型),R可以很容易地生成和处理数组,特别是矩阵matrix是一个二维数组。
或者:
> a=array(a,dim=c(3,3))> a [,1] [,2] [,3][1,] 1 5 8[2,] 3 6 9[3,] 4 7 3或者:
> a=matrix(a,nrow=3,ncol=3);a [,1] [,2] [,3][1,] 1 5 8[2,] 3 6 9[3,] 4 7 3 > is.vector(a)[1] FALSE> is.matrix(a)[1] TRUE> is.array(a)[1] TRUE > is.list(a)[1] FALSE可以发现,a已经通过定义维度将其变成了一个矩阵(matrix)和数组(array),下面将讲matrix其实是一个二维的array。
到此这篇关于R语言中的vector(向量),array(数组)使用总结的文章就介绍到这了,更多相关R语言向量数组内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Vector可实现自动增长的对象数组。java.util.vector提供了向量类(vector)以实现类似动态数组的功能。在Java语言中没有指针的概念,但如
java.util.vector提供了向量类(vector)以实现类似动态数组的功能。在Java语言中没有指针的概念,但如果正确灵活地使用指针又确实可以大大提高
矩阵向量vector用于描述一维数据,是R语言中最基础的数据结构形式矩阵matrix可以描述二维数据,和向量相似,其内部元素可以是实数、复数、字符、逻辑型数据矩
R的数据结构有很多种,常用的包括向量vector,矩阵matrix,数组array,列表list和dataframe数据框。前三个都有其特定的性质和结构今天要介
简介向量(Vector)是一个封装了动态大小数组的顺序容器。向量是一个能够存放任意类型的动态数组。C++中Vector的使用头文件#include需要使用std