#setwd("c:/Users/janousova/Documents/Vyuka/Vicerozmerky a AKD/Vicerozmerky - vyuka/Bi8600c_Vícrozměrky_cvičení/2014") # data: X1=matrix(c(4,3,10,8),2,2) X1 x0=as.matrix(c(3.5,9)) # vykresleni dat: plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1) # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) # na zaklade tohoto obrazku, ma modry bod x0 stejnou vzdalenost od cervenych bodu -> ne vzdy (pri pouziti ruznych metrik to muze byt ruzne, coz si ukazeme) #### Euklidova metrika - vypocet vzdalenosti subjektu x0 od dvou ostatnich subjektu: euc.dist <- array(0,nrow(X1)) for (i in 1:nrow(X1)) { euc.dist[i] <- sqrt(sum((X1[i,] - x0) ^ 2)) # vypocet vzdalenosti } euc.dist ## Euklidova metrika - vykresleni: windows(10,5) par(mfrow=c(1,2),mar=c(5,5,1,1),oma=c(0,0,0,0)) # vzdalenosti subjektu x0 od dvou ostatnich subjektu plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) lines(c(x0[1],X1[1,1]),c(x0[2],X1[1,2]),col="blue",lwd=2) lines(c(x0[1],X1[2,1]),c(x0[2],X1[2,2]),col="blue",lwd=2) # znazorneni bodu, ktere lezi ve stejne vzdalenosti od bodu x0 plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) #install.packages("plotrix") library(plotrix) draw.circle(x0[1],x0[2],min(euc.dist),border="blue",lty=1,lwd=2) #### Hammingova (manhattanska) metrika - vypocet vzdalenosti subjektu x0 od dvou ostatnich subjektu: h.dist <- array(0,nrow(X1)) for (i in 1:nrow(X1)) { h.dist[i] <- sum(abs(X1[i,]-x0)) # vypocet vzdalenosti } h.dist ## Hammingova (manhattanska) metrika - vykresleni: windows(10,5) par(mfrow=c(1,2),mar=c(5,5,1,1),oma=c(0,0,0,0)) # vzdalenosti subjektu x0 od dvou ostatnich subjektu plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) lines(c(x0[1],X1[1,1]),c(x0[2],x0[2]),col="blue",lwd=2) lines(c(X1[1,1],X1[1,1]),c(x0[2],X1[1,2]),col="blue",lwd=2) lines(c(x0[1],X1[2,1]),c(x0[2],x0[2]),col="blue",lwd=2) lines(c(X1[2,1],X1[2,1]),c(x0[2],X1[2,2]),col="blue",lwd=2) # znazorneni bodu, ktere lezi ve stejne vzdalenosti od bodu x0 plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) lines(c(x0[1]-min(h.dist),x0[1]),c(x0[2],x0[2]-min(h.dist)),col="blue",lwd=2) lines(c(x0[1]-min(h.dist),x0[1]),c(x0[2],x0[2]+min(h.dist)),col="blue",lwd=2) lines(c(x0[1],x0[1]+min(h.dist)),c(x0[2]-min(h.dist),x0[2]),col="blue",lwd=2) lines(c(x0[1],x0[1]+min(h.dist)),c(x0[2]+min(h.dist),x0[2]),col="blue",lwd=2) #### Cebysevova metrika - vypocet vzdalenosti subjektu x0 od dvou ostatnich subjektu: ceb.dist <- array(0,nrow(X1)) for (i in 1:nrow(X1)) { ceb.dist[i] = max(abs(X1[i,]-x0)) # vypocet vzdalenosti } ceb.dist ## Cebysevova metrika - vykresleni: windows(10,5) par(mfrow=c(1,2),mar=c(5,5,1,1),oma=c(0,0,0,0)) # vzdalenosti subjektu x0 od dvou ostatnich subjektu plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) lines(c(x0[1],X1[1,1]),c(x0[2],x0[2]),col="gray",lwd=2) lines(c(X1[1,1],X1[1,1]),c(x0[2],X1[1,2]),col="blue",lwd=2) lines(c(x0[1],X1[2,1]),c(x0[2],x0[2]),col="gray",lwd=2) lines(c(X1[2,1],X1[2,1]),c(x0[2],X1[2,2]),col="blue",lwd=2) # znazorneni bodu, ktere lezi ve stejne vzdalenosti od bodu x0 plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) lines(c(x0[1]-min(ceb.dist),x0[1]-min(ceb.dist)),c(x0[2]-min(ceb.dist),x0[2]+min(ceb.dist)),col="blue",lwd=2) lines(c(x0[1]-min(ceb.dist),x0[1]+min(ceb.dist)),c(x0[2]-min(ceb.dist),x0[2]-min(ceb.dist)),col="blue",lwd=2) lines(c(x0[1]-min(ceb.dist),x0[1]+min(ceb.dist)),c(x0[2]+min(ceb.dist),x0[2]+min(ceb.dist)),col="blue",lwd=2) lines(c(x0[1]+min(ceb.dist),x0[1]+min(ceb.dist)),c(x0[2]-min(ceb.dist),x0[2]+min(ceb.dist)),col="blue",lwd=2) ##### Vykrelseni do jednoho grafu: windows(10,5) par(mfrow=c(1,2),mar=c(5,5,1,1),oma=c(0,0,0,0)) # vzdalenosti subjektu x0 od dvou ostatnich subjektu plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) lines(c(x0[1],X1[1,1]),c(x0[2],X1[1,2]),col="green",lwd=2) # Euklidova vzd lines(c(x0[1],X1[2,1]),c(x0[2],X1[2,2]),col="green",lwd=2) # Euklidova vzd lines(c(x0[1],X1[1,1]),c(x0[2],x0[2]),col="gray",lwd=2) lines(c(X1[1,1],X1[1,1]),c(x0[2],X1[1,2]),col="blue",lwd=2) lines(c(x0[1],X1[2,1]),c(x0[2],x0[2]),col="gray",lwd=2) lines(c(X1[2,1],X1[2,1]),c(x0[2],X1[2,2]),col="blue",lwd=2) # znazorneni bodu, ktere lezi ve stejne vzdalenosti od bodu x0 plot(X1,xlim=c(2,5),ylim=c(7,11),col="red",pch=16,cex=1.5,asp=1,xlab="x1",ylab="x2") # asp=1 - x and y ranges are same points(t(x0),pch=16,col="blue",cex=1.5) draw.circle(x0[1],x0[2],min(euc.dist),border="green",lty=1,lwd=2) # Euklidova vzd lines(c(x0[1]-min(h.dist),x0[1]),c(x0[2],x0[2]-min(h.dist)),col="magenta",lwd=2) # Hammingova (manhattanska) vzd lines(c(x0[1]-min(h.dist),x0[1]),c(x0[2],x0[2]+min(h.dist)),col="magenta",lwd=2) # Hammingova (manhattanska) vzd lines(c(x0[1],x0[1]+min(h.dist)),c(x0[2]-min(h.dist),x0[2]),col="magenta",lwd=2) # Hammingova (manhattanska) vzd lines(c(x0[1],x0[1]+min(h.dist)),c(x0[2]+min(h.dist),x0[2]),col="magenta",lwd=2) # Hammingova (manhattanska) vzd lines(c(x0[1]-min(ceb.dist),x0[1]-min(ceb.dist)),c(x0[2]-min(ceb.dist),x0[2]+min(ceb.dist)),col="blue",lwd=2) # Cebysevova vzd lines(c(x0[1]-min(ceb.dist),x0[1]+min(ceb.dist)),c(x0[2]-min(ceb.dist),x0[2]-min(ceb.dist)),col="blue",lwd=2) # Cebysevova vzd lines(c(x0[1]-min(ceb.dist),x0[1]+min(ceb.dist)),c(x0[2]+min(ceb.dist),x0[2]+min(ceb.dist)),col="blue",lwd=2) # Cebysevova vzd lines(c(x0[1]+min(ceb.dist),x0[1]+min(ceb.dist)),c(x0[2]-min(ceb.dist),x0[2]+min(ceb.dist)),col="blue",lwd=2) # Cebysevova vzd