Кумулятивный график с заданной осью X

121
7

У меня есть данные, которые выглядят так.
В котором я хочу построить накопительную ценность dat1 с уважением
к оси х. Также запишите его вместе с dat2.


#x-axis dat1              dat2
-10 0.0140149 0.0140146
-9 0.00890835 0.00891768
-8 0.00672276 0.00672488
-7 0.00876399 0.00879401
-6 0.00806879 0.00808141
-5 0.0088366 0.00885121
-4 0.00856872 0.00857769
-3 0.0195384 0.0196094
-2 0.0160239 0.0161829
-1 0.0254455 0.0257845
0 0.0397413 0.0400913
1 0.0743316 0.0755453
2 0.0247501 0.0253324
3 0.0214285 0.021778
4 0.0241462 0.0244967
5 0.0150943 0.015241
6 0.0141398 0.0142373
7 0.0101515 0.0102948
8 0.0308843 0.031294
9 0.0095504 0.00960626
10 0.00729676 0.0073713

Какой общий способ сделать это в R?


Я смотрел ECDF от Hmisc, он, похоже, не делает того, что я хочу.
В частности, это не позволяет нам дать значение оси x.

спросил(а) 2021-01-19T14:56:37+03:00 2 месяца, 3 недели назад
1
Решение
123

Я думаю, что функция, которую вы ищете, это cumsum(), которая будет делать кумулятивную сумму по вектору.


#put your data into 3 vectors
x<-c(-10,-9,-8,-7,-6,-5,-4,-3,-2,-1,0,1,2,3,4,5,6,7,8,9,10)
dat1<-c(0.0140149,0.00890835,0.00672276,0.00876399,0.00806879,0.0088366,0.00856872,0.0195384,0.0160239,0.0254455,0.0397413,0.0743316,0.0247501,0.0214285,0.0241462,0.0150943,0.0141398,0.0101515,0.0308843,0.0095504,0.00729676)
dat2<-c(0.014015,0.008918,0.006725,0.008794,0.008081,0.008851,0.008578,0.019609,0.016183,0.025785,0.040091,0.075545,0.025332,0.021778,0.024497,0.015241,0.014237,0.010295,0.031294,0.009606,0.007371)

#create a new vector called cdat1 to hold the cumulative sum
cdat1<-cumsum(dat1)
plot(x,cdat1)
points(x,dat2,col="red")

Я использую вышеперечисленные функции, чтобы добавить dat2 к существующему сюжету. Запустите это в R и посмотрите, дает ли он вам то, что вам нужно.

ответил(а) 2021-01-19T14:56:37+03:00 2 месяца, 3 недели назад
87

Если у вас есть эти данные в текстовом файле (например, data.txt), вы также можете сделать следующее:


A <- read.table("data.txt",header=TRUE)
attach(A)
plot(x.axis, cumsum(dat1))
points(x.axis, cumsum(dat2), col='red')

Как сказал JD Long, функция cumsum - это то, что вы искали.

ответил(а) 2021-01-19T14:56:37+03:00 2 месяца, 3 недели назад
Ваш ответ
Введите минимум 50 символов
Чтобы , пожалуйста,
Выберите тему жалобы:

Другая проблема