Werken met lijsten

R voor SAS-gebruikers

Melinda Higgins, PhD

Research Professor/Senior Biostatistician Emory University

Maak een lijst door andere objecten te combineren

# Maak logische scalair
logic_scalar <- TRUE
logic_scalar
[1] TRUE

true-scalar element

R voor SAS-gebruikers

Maak een lijst door andere objecten te combineren

# Maak tekenreeksvector age_charvec
age_charvec <- c("child", "young", "old")
age_charvec
[1] "child" "young" "old"

true-scalar en tekenreeksvector

R voor SAS-gebruikers

Maak een lijst door andere objecten te combineren

# Maak matrix num_matrix
a <- c(5.0, 3.1, 2.4)
b <- c(4.1, 2.2, 5.4)
num_matrix <- matrix(c(a, b),
                     nrow = 3,
                     ncol = 2)
num_matrix
     [,1] [,2]
[1,]  5.0  4.1
[2,]  3.1  2.2
[3,]  2.4  5.4

true-scalar, tekenreeksvector en matrix

R voor SAS-gebruikers

Maak een lijst van objecten van verschillende types

# Maak lijst van scalaire, vector en matrix
list_logicagemtx <-
  list(logic_scalar, age_charvec, num_matrix)
list_logicagemtx
[[1]]
[1] TRUE

[[2]]
[1] "child" "young" "old"  

[[3]]
     [,1] [,2]
[1,]  5.0  4.1
[2,]  3.1  2.2
[3,]  2.4  5.4

alle elementen gecombineerd in een lijst

R voor SAS-gebruikers

Benoemde lijstelementen

# Geef elementen van de lijst namen, bekijk namen
names(list_logicagemtx) <- c("logicalValue", "ageDescription", "numericMatrix")
names(list_logicagemtx)
[1] "logicalValue"   "ageDescription" "numericMatrix"
# Bekijk de structuur van list_logicagemtx
str(list_logicagemtx)
List of 3
 $ logicalValue  : logi TRUE
 $ ageDescription: chr [1:3] "child" "young" "old"
 $ numericMatrix : num [1:3, 1:2] 5 3.1 2.4 4.1 2.2 5.4
R voor SAS-gebruikers

Selecteer elementen uit een lijst op naam

# Selecteer ageDescription met $
list_logicagemtx$ageDescription
[1] "child" "young" "old"
# Controleer de class van ageDescription
class(list_logicagemtx$ageDescription)
[1] "character"
# Bevestig vectorklasse
is.vector(list_logicagemtx$ageDescription)
[1] TRUE

selecteer tekenreeksvector uit lijst

R voor SAS-gebruikers

Hmisc-uitvoer

# Voer Hmisc::describe() uit voor sex en bmi
davisHmisc <- daviskeep %>%
  select(sex, bmi) %>%
  Hmisc::describe()

# Structuur van de uitvoer van Hmisc::describe()
str(davisHmisc)
List of 2
 $ sex:List of 5
  ..$ descript: chr "sex"
  ..$ units   : NULL
  ..$ format  : NULL
  ..$ counts  : Named num [1:3] 199 0 2
  .. ..- attr(*, "names")= chr [1:3] "n" "missing" "distinct"
  ..$ values  :List of 2
  .. ..$ value    : chr [1:2] "F" "M"
  .. ..$ frequency: num [1:2(1d)] 111 88
  ..- attr(*, "class")= chr "describe"
 $ bmi:List of 6
  ..$ descript: chr "bmi"

... rest of output omitted ...
R voor SAS-gebruikers

Hmisc-uitvoer

# Bekijk het element sex van de Hmisc describe-uitvoer
davisHmisc$sex
sex
       n  missing distinct
     199        0        2

Value          F     M
Frequency    111    88
Proportion 0.558 0.442
# Bevestig dat de describe-class ook een lijst is
is.list(davisHmisc$sex)
[1] TRUE
R voor SAS-gebruikers

Hmisc-uitvoer

# Bekijk namen van elementen in davisHmisc$sex
names(davisHmisc$sex)
[1] "descript" "units" "format" "counts" "values"
# Gebruik $ opnieuw om counts voor sex te tonen
davisHmisc$sex$counts
  n  missing distinct
199        0        2
R voor SAS-gebruikers

Uitvoer van correlatietests

# Sla uitvoer van psych::corr.test() op
daviscorr <- daviskeep %>%
  select(bmi, weight, height) %>%
  psych::corr.test()
# Bekijk namen van 11 elementen in psych::corr-uitvoer
names(daviscorr)
 [1]  "r"      "n"      "t"      "p"      "se"     
 [6]  "sef"    "adjust" "sym"    "ci"     "ci.adj"
 [11] "Call"
R voor SAS-gebruikers

Uitvoer van correlatietests

daviscorr$p
                bmi       weight       height
bmi    0.000000e+00 2.569508e-64 3.628533e-08
weight 8.565028e-65 0.000000e+00 4.017148e-40
height 3.628533e-08 2.008574e-40 0.000000e+00
daviscorr$ci
                lower         r     upper            p
bmi-weght   0.8410885 0.8775201 0.9060257 8.565028e-65
bmi-heght   0.2524241 0.3782344 0.4914688 3.628533e-08
weght-heght 0.7074835 0.7707306 0.8217303 2.008574e-40
R voor SAS-gebruikers

Uitvoer van t-toetsen

# ONGEPOOLED t-toets: bmi per sex
davisunpooled <- t.test(bmi ~ sex,
                        data = daviskeep)
class(davisunpooled)
[1] "htest"
is.list(davisunpooled)
[1] TRUE
names(davispooled)
[1] "statistic"   "parameter"   
[3] "p.value"     "conf.int"    
[5] "estimate"    "null.value"  
[7] "alternative" "method"      
[9] "data.name"
R voor SAS-gebruikers

Uitvoer van chi-kwadraattoetsen

# Maak kruistabel van bmigt25 en sex en bekijk tabel
tablebmisex <- daviskeep %>%
  with(table(bmigt25, sex))
daviscs <- chisq.test(tablebmisex)
class(daviscs)
[1] "htest"
names(daviscs)
[1] "statistic" "parameter" "p.value"   "method"    "data.name" "observed"
[7] "expected"  "residuals" "stdres"
R voor SAS-gebruikers

Uitvoer van htest-lijstklasse

Uitvoer t-toets

davisunpooled$statistic
davisunpooled$parameter
davisunpooled$p.value
        t
-7.515792

      df
149.4533

[1] 4.818621e-12

Uitvoer chi-kwadraattoets

daviscs$observed
                 sex
bmigt25             F   M
  1. underwt/norm 107  54
  2. overwt/obese   4  34
daviscs$expected
                 sex
bmigt25                  F        M
  1. underwt/norm 89.80402 71.19598
  2. overwt/obese 21.19598 16.80402
R voor SAS-gebruikers

Laten we met lijstuitvoer werken om je abalone-analyseresultaten te verfijnen.

R voor SAS-gebruikers

Preparing Video For Download...