Jak mogę renderować wartość punktów w samym plot
w samym plot
?Wyświetlane wartości w R Plot
Dziękuję.
Jak mogę renderować wartość punktów w samym plot
w samym plot
?Wyświetlane wartości w R Plot
Dziękuję.
b0 = 2.5; b1 = 2
n = 100
x = rnorm(n, 20, 15)
y = b0 + b1*x + rnorm(n, 0, 15)
plot(x, y)
plot(x, y, type='n')
text(x, y, round(y, 2), cex=0.45)
text(x, y, round(y, 2), cex=0.8)
text(x, y, paste(round(x, 2), round(y, 2), sep=", "), cex=0.8) # for (x, y), but this gets cluttered.
Zastosowanie cex
do wielkości znaków (patrz pomoc dla tekstu). I użyj plot(x, y, type='n')
, aby poprawnie ustawić okno, bez faktycznego drukowania czegokolwiek.
Zastosowanie text()
:
plot(1:10, 1:10)
text(5, 5, "Foo")
i zobaczyć help(text)
dla opcji na umieszczenie tekstu. Funkcja jest wektoryzowane więc można też zrobić coś w rodzaju
text(1:10, 1:10, LETTERS[1:10])
jeśli wektory tekstów i stanowisk.
podobna do odpowiedzi Vince'a wyjątkiem stosowania ggplot2:
b0 = 2.5; b1 = 2
n = 20
x = rnorm(n, 20, 15)
y = b0 + b1*x + rnorm(n, 0, 15)
dat<-data.frame(x,y)
library(ggplot2)
ggplot(data=dat)+geom_text(aes(x=x,y=y),size=4,label=paste(round(x, 2), round(y, 2), sep=", "))
wielkość znaków można zmienić poprzez zmianę parametru size.
Powinienem zajrzeć do ggplot więcej. Wydaje się, że rośnie popularność. Używałem kratownicy do twardych rzeczy. – Vince
x <- 1/3
plot(1,type="none",ann=FALSE)
## text and values only
text(mean(par("usr")[1:2]),mean(par("usr")[3:4])-par("cxy")[2]*2,
paste("z = ",round(x,2)))
## text, values, and mathematical expressions
text(mean(par("usr")[1:2]),mean(par("usr")[3:4]),
bquote(x^2==.(round(x,2))))
text(mean(par("usr")[1:2]),mean(par("usr")[3:4])-par("cxy")[2],
substitute(gamma==value,list(value=round(x,2))))
Za pomocą ggplot2 można dodawać zarówno punkty, jak i etykiety. Umieszczenie aes() w ggplot() ma tę zaletę, że aes() będzie domyślną wartością dla wszystkich geomów. Stąd w tym przypadku trzeba tylko podać wartości X i raz, ale są one wykorzystywane zarówno przez geom_point() i geom_text()
Zmodyfikowany kod Ian Fellows będzie wyglądać następująco:
b0 <- 2.5
b1 <- 2
n <- 20
dat <- data.frame(x = rnorm(n, 20, 15))
dat$y <- b0 + b1*dat$x + rnorm(n, 0, 15)
dat$text <- with(dat, paste(round(x, 2), round(y, 2), sep=", "))
library(ggplot2)
ggplot(data=dat, aes(x = x, y = y, label = text)) + geom_point() + geom_text(size=4, hjust = 1, vjust = 1)
może to pomóc również
# example data
dat <- data.frame(name = sample(letters[1:4],20, replace=T), x1 = rnorm(20,2), x2 = 42+x1*rnorm(20,0,2))
# plot the data
plot(dat$x1,dat$x2)
# use identify to print name for each 'dot' that you click with left mouse
identify(dat$x1,dat$x2,labels=name)
# When done identifying point, click with right mousebutton.
Lubię tę funkcję dla celów interaktywnych. Nie wiem jak to osiągnąć w ggplot chociaż
znalazłem tę metodę i to bardzo przydatne:
for i=1:6
text(x(i),y(i),num2str(y(i)));
end
Powtórz ten wiersz dla każdego członka w działce.
To nie jest prawidłowy kod R. – joran
Niewielkie punkty: Masz literówkę na linii 5 (gra zamiast gry); i byłbym skłonny używać formatu lub formatu C zamiast okrągłego, ponieważ chcesz, aby ciąg zwracał nie liczbę. Spróbuj, na przykład, format (y, przycięcie = PRAWDA, cyfry = 2) –
Dzięki Richie. Myślałem o formacie, ale pomyślałem, że funkcja round() będzie bardziej oczywista dla początkującego. Metoda paste() przekształci się w ciągi. – Vince