第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會有你想問的

R模型矩陣中因子的所有層次

R模型矩陣中因子的所有層次

牛魔王的故事 2019-10-16 12:43:51
我有一個(gè)data.frame由數(shù)字和因子組成的變量,如下所示。testFrame <- data.frame(First=sample(1:10, 20, replace=T),           Second=sample(1:20, 20, replace=T), Third=sample(1:10, 20, replace=T),           Fourth=rep(c("Alice","Bob","Charlie","David"), 5),           Fifth=rep(c("Edward","Frank","Georgia","Hank","Isaac"),4))我想建立一個(gè)matrix將虛擬變量分配給因子并僅保留數(shù)字變量的方法。model.matrix(~ First + Second + Third + Fourth + Fifth, data=testFrame)如預(yù)期的那樣,在運(yùn)行時(shí),lm這會將每個(gè)因子的一個(gè)水平作為參考水平。但是,我想為matrix所有因素的每個(gè)層次建立一個(gè)帶有虛擬/指標(biāo)變量的。我正在為此建立矩陣,glmnet所以我不必?fù)?dān)心多重共線性。有沒有一種方法可以model.matrix為每個(gè)因子水平創(chuàng)建虛擬對象?
查看完整描述

3 回答

?
慕桂英546537

TA貢獻(xiàn)1848條經(jīng)驗(yàn) 獲得超10個(gè)贊

您需要重置contrasts因子變量:


model.matrix(~ Fourth + Fifth, data=testFrame, 

        contrasts.arg=list(Fourth=contrasts(testFrame$Fourth, contrasts=F), 

                Fifth=contrasts(testFrame$Fifth, contrasts=F)))

或者,鍵入少一點(diǎn),但沒有適當(dāng)?shù)拿Q:


model.matrix(~ Fourth + Fifth, data=testFrame, 

    contrasts.arg=list(Fourth=diag(nlevels(testFrame$Fourth)), 

            Fifth=diag(nlevels(testFrame$Fifth))))


查看完整回答
反對 回復(fù) 2019-10-16
?
慕工程0101907

TA貢獻(xiàn)1887條經(jīng)驗(yàn) 獲得超5個(gè)贊

(嘗試贖回自己...)為響應(yīng)Jared關(guān)于@Fabians自動(dòng)化的回答,請注意,您需要提供的只是一個(gè)對比矩陣的命名列表。contrasts()取一個(gè)向量/因數(shù)并從中產(chǎn)生對比度矩陣。對于這個(gè)那么我們可以用lapply()運(yùn)行contrasts()在我們的數(shù)據(jù)集,例如用于各個(gè)因素testFrame提供的示例:


> lapply(testFrame[,4:5], contrasts, contrasts = FALSE)

$Fourth

        Alice Bob Charlie David

Alice       1   0       0     0

Bob         0   1       0     0

Charlie     0   0       1     0

David       0   0       0     1


$Fifth

        Edward Frank Georgia Hank Isaac

Edward       1     0       0    0     0

Frank        0     1       0    0     0

Georgia      0     0       1    0     0

Hank         0     0       0    1     0

Isaac        0     0       0    0     1

@fabians哪個(gè)插槽很好地回答:


model.matrix(~ ., data=testFrame, 

             contrasts.arg = lapply(testFrame[,4:5], contrasts, contrasts=FALSE))


查看完整回答
反對 回復(fù) 2019-10-16
  • 3 回答
  • 0 關(guān)注
  • 964 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號