У меня есть код SAS, аналогичный приведенной ниже логике. Я хотел бы преобразовать его в сценарий R, используя метод if-else или ifelse. Вот пример кода SAS:
if cat1=1 then do;
if cat2 eq 'U' then do;
if var1 =. then var1 = var3;
end;
else if cat2='A' then do;
if var1 =. then var1=var2;
end;
end;
else do;
if cat2 eq 'U' then do;
if cat3 = 'NC' then do;
if var1 =. then do;
if var2 ge 4.0 then var1 =1.15;
else if var2 le 4.0 then var1 = 10.0;
else var1 = 6.1;
end;
end;
end;
end;
Вот преобразованный код R-скрипта. Однако последний шаг (df4) перезаписывает все предыдущие шаги. Есть ли лучший способ преобразовать эту логику в оператор R if-else.
df <- data.frame(cat1 = c(rep(1,3), rep(0,4)),
cat2 = c(rep('U',2), rep('A',3), 'U', 'U'),
cat3 = c(rep('NC',2), rep('RF',2), 'NC', 'NC', 'NC'),
var1 = c(rep(NA,5),.14, NA),
var2 = c(rep(NA,2), 4.5, 2.3, 8.5, 3.4, 2.4),
var3 = c(rep(2.6, 2), 3.9, NA, 4.2, .012, NA))
df2 <- transform(df,
var1 = ifelse(is.na(var1) & cat1 ==1 & cat2 == 'U', var3, var1)
)
df3 <- transform(df2,
var1 = ifelse(is.na(var1) & cat1 ==1 & cat2 == 'A', var2, var1)
)
df4 <- transform(df3,
var1 = ifelse(is.na(var1) & cat2 == 'U' & cat3 == 'NC' & var2 >= 4.0, 1.15,
ifelse(var2 <= 4.0, 10.0, 6.1))
)
Пожалуйста помоги?