Mit den data.frame
unten (Quelle: http://eric.univ-lyon2.fr/~ricco/tanagra/fichiers/en_Tanagra_PLSR_Software_Comparison.pdf)Korrelation zwischen Variablen und Komponenten pls Paket
Daten
df <- read.table(text = c("
diesel twodoors sportsstyle wheelbase length width height curbweight enginesize horsepower horse_per_weight conscity price symboling
0 1 0 97 172 66 56 2209 109 85 0.0385 8.7 7975 2
0 0 0 100 177 66 54 2337 109 102 0.0436 9.8 13950 2
0 0 0 116 203 72 57 3740 234 155 0.0414 14.7 34184 -1
0 1 1 103 184 68 52 3016 171 161 0.0534 12.4 15998 3
0 0 0 101 177 65 54 2765 164 121 0.0438 11.2 21105 0
0 1 0 90 169 65 52 2756 194 207 0.0751 13.8 34028 3
1 0 0 105 175 66 54 2700 134 72 0.0267 7.6 18344 0
0 0 0 108 187 68 57 3020 120 97 0.0321 12.4 11900 0
0 0 1 94 157 64 51 1967 90 68 0.0346 7.6 6229 1
0 1 0 95 169 64 53 2265 98 112 0.0494 9.0 9298 1
1 0 0 96 166 64 53 2275 110 56 0.0246 6.9 7898 0
0 1 0 100 177 66 53 2507 136 110 0.0439 12.4 15250 2
0 1 1 94 157 64 51 1876 90 68 0.0362 6.4 5572 1
0 0 0 95 170 64 54 2024 97 69 0.0341 7.6 7349 1
0 1 1 95 171 66 52 2823 152 154 0.0546 12.4 16500 1
0 0 0 103 175 65 60 2535 122 88 0.0347 9.8 8921 -1
0 0 0 113 200 70 53 4066 258 176 0.0433 15.7 32250 0
0 0 0 95 165 64 55 1938 97 69 0.0356 7.6 6849 1
1 0 0 97 172 66 56 2319 97 68 0.0293 6.4 9495 2
0 0 0 97 172 66 56 2275 109 85 0.0374 8.7 8495 2"), header = T)
und dieser
-Code
library(plsdepot)
df.plsdepot = plsreg1(df[, 1:11], df[, 14, drop = FALSE], comps = 3)
data<-df.plsdepot$cor.xyt
data<-as.data.frame(data)
Ich habe diese data.frame
der Korrelation zwischen Variablen und Komponenten
data
# t1 t2 t3
#diesel -0.23513860 -0.38154681 0.439221649
#twodoors 0.71849247 0.45622386 0.055982798
#sportsstyle 0.51909329 -0.02381952 -0.672617464
#wheelbase -0.86843937 0.34114664 -0.254589548
#length -0.75311884 0.62404991 -0.085596033
#width -0.67444970 0.62282146 -0.158675019
#height -0.67228557 -0.14675385 0.317166599
#curbweight -0.59305898 0.73532560 -0.241983833
#enginesize -0.39475651 0.82353941 -0.252270394
#horsepower 0.04843256 0.96637015 -0.148407288
#horse_per_weight 0.50515322 0.81502376 -0.006045151
#symboling 0.64900253 0.23673633 0.346902434
und ich schaffte es, sie als plotten unter
library(plsdepot)
df.plsdepot = plsreg1(df[, 1:11], df[, 14, drop = FALSE], comps = 3)
plot(df.plsdepot, comps = c(1, 2))
Ich hatte pls
Paket statt plsdepot
zu verwenden. Ich brauche die Korrelationen zwischen Variablen und Komponenten zu erhalten und zeichnen sie
pls
Verwendung schaffte ich es, wie unten
library(pls)
Y <- as.matrix(df[,14])
X <- as.matrix(df[,1:11])
df.pls <- mvr(Y ~ X, ncomp = 3, method = "oscorespls", scale = T)
plot(df.pls, "correlation")
jedoch die Korrelation zwischen Variablen und Komponenten zu plotten, konnte ich nicht Finden Sie einen Weg, um diese Werte zu erhalten (Korrelation zwischen Variablen und Komponenten) und konvertieren Sie sie in data.frame mit pls
Paket.
Irgendwelche Hilfe, wie ich diese Korrelationswerte unter Verwendung Paket erhalten kann, wird sehr geschätzt?
Dies ist ein Duplikat von dem, was ich gestern geantwortet habe, ist es nicht? http://stackoverflow.com/questions/39137287/plotting-partial-least-squares-repression-plsr-biplot-with-gplot2 –
@CyrusMohammadian Ich glaube nicht. In der Frage, die Sie beantwortet haben, ist keiner der "Scores" (rechte y-Achse) mehr als 0,6, aber in der Korrelationszahl mit "pls" (untere Abbildung oben) liegen mehrere Korrelationswerte über 0.6 – aelwan
Ich habe alle Elemente von 'überprüft 'df.pls'' eins nach dem anderen mindestens 3 oder 4 mal. Nichts entspricht der Erzeugung der Ausgabe.Ich würde die Dokumentation für "pls" suchen, um besser zu verstehen, wie es mit dem Zeichnen von Korrelationen umgeht. –