Как отсортировать вектор с несколькими наборами данных в каждой строке? - PullRequest
0 голосов
/ 28 декабря 2018

Я очень плохо знаком с R и кодированием.Пытаясь отсортировать набор данных, которые я получил:

filename = read.delim("UA0001.dat", header = FALSE, skip=16)

Я получаю матрицу с одним столбцом и несколькими строками, где в каждом столбце есть 8 различных точек данных.

V1

1-3.39 3.11 4.361 3.35 3.76 3.66 3.44 3.72
2-3.13 3.35 3.01 3.05 2.73 2.90 2.73 2.31
.
.
.

Как мне все это разделить, чтобы у меня была матрица с одним столбцом, где каждая из этих точек данных размещена в отдельных строках?

V1

1-3.39
2-3.11
3-4.36 
4-3.35
5-3.76
.
.
.

Ответы [ 2 ]

0 голосов
/ 28 декабря 2018

Вот вариант с unmatrix из gdata

library(gdata)
matrix(unmatrix(mat, byrow = TRUE))
#      [,1]
# [1,] 3.390
# [2,] 3.110
# [3,] 4.361
# [4,] 3.350
# [5,] 3.760
# [6,] 3.660
# [7,] 3.440
# [8,] 3.720
# [9,] 3.130
#[10,] 3.350
#[11,] 3.010
#[12,] 3.050
#[13,] 2.730
#[14,] 2.900
#[15,] 2.730
#[16,] 2.310

или с aperm

matrix(aperm(mat, c(2, 1)))

data

mat <-matrix(c(3.39, 3.11, 4.361, 3.35, 3.76, 3.66, 3.44, 3.72,
 3.13 ,3.35, 3.01, 3.05, 2.73, 2.90, 2.73, 2.31), byrow = TRUE, nrow = 2)
0 голосов
/ 28 декабря 2018

Вы можете просто реструктурировать его, взяв транспонирование и разбив его на вектор и преобразовав его обратно в матрицу с ncol = 1

matrix(c(t(mat)), ncol = 1)


#       [,1]
# [1,] 3.390
# [2,] 3.110
# [3,] 4.361
# [4,] 3.350
# [5,] 3.760
# [6,] 3.660
# [7,] 3.440
# [8,] 3.720
# [9,] 3.130
#[10,] 3.350
#[11,] 3.010
#[12,] 3.050
#[13,] 2.730
#[14,] 2.900
#[15,] 2.730
#[16,] 2.310

data

mat <-matrix(c(3.39, 3.11, 4.361, 3.35, 3.76, 3.66, 3.44, 3.72,
 3.13 ,3.35, 3.01, 3.05, 2.73, 2.90, 2.73, 2.31), byrow = TRUE, nrow = 2)
...