নিম্নলিখিত ম্যাট্রিক্স এ = ( 2.2 0.4 0.4 2.8 ) এর ইগেনভ্যালুগুলি এবং ইগেনভেেক্টরগুলির কাছ থেকে একটি উপবৃত্তের পরিকল্পনা করতে কেউ কি আর কোড নিয়ে আসতে পারেন?
নিম্নলিখিত ম্যাট্রিক্স এ = ( 2.2 0.4 0.4 2.8 ) এর ইগেনভ্যালুগুলি এবং ইগেনভেেক্টরগুলির কাছ থেকে একটি উপবৃত্তের পরিকল্পনা করতে কেউ কি আর কোড নিয়ে আসতে পারেন?
উত্তর:
আপনি ইগেনভেেক্টরগুলি এবং মূল্যগুলি মাধ্যমে বের করতে পারেন eigen(A)
। তবে চোলস্কির পচন ব্যবহার করা সহজ। নোট করুন আত্মবিশ্বাসের উপাত্তের জন্য উপবৃত্তির পরিকল্পনার সময়, উপবৃত্ত-অক্ষগুলি সাধারণত সম্পর্কিত ইজেনভ্যালুগুলির দৈর্ঘ্য = বর্গক্ষেত্রের আকারযুক্ত হয় এবং কোলেস্কির পচন এটি দেয়।
ctr <- c(0, 0) # data centroid -> colMeans(dataMatrix)
A <- matrix(c(2.2, 0.4, 0.4, 2.8), nrow=2) # covariance matrix -> cov(dataMatrix)
RR <- chol(A) # Cholesky decomposition
angles <- seq(0, 2*pi, length.out=200) # angles for ellipse
ell <- 1 * cbind(cos(angles), sin(angles)) %*% RR # ellipse scaled with factor 1
ellCtr <- sweep(ell, 2, ctr, "+") # center ellipse to the data centroid
plot(ellCtr, type="l", lwd=2, asp=1) # plot ellipse
points(ctr[1], ctr[2], pch=4, lwd=2) # plot data centroid
library(car) # verify with car's ellipse() function
ellipse(c(0, 0), shape=A, radius=0.98, col="red", lty=2)
সম্পাদনা করুন: আইজেনভেেক্টরগুলিকেও প্লট করার জন্য আপনাকে আরও জটিল পদ্ধতির ব্যবহার করতে হবে। এটি সানকুলসু এর উত্তরের সমতুল্য, এটি কোডটি সংক্ষিপ্ত করতে কেবল ম্যাট্রিক্স স্বরলিপি ব্যবহার করে।
eigVal <- eigen(A)$values
eigVec <- eigen(A)$vectors
eigScl <- eigVec %*% diag(sqrt(eigVal)) # scale eigenvectors to length = square-root
xMat <- rbind(ctr[1] + eigScl[1, ], ctr[1] - eigScl[1, ])
yMat <- rbind(ctr[2] + eigScl[2, ], ctr[2] - eigScl[2, ])
ellBase <- cbind(sqrt(eigVal[1])*cos(angles), sqrt(eigVal[2])*sin(angles)) # normal ellipse
ellRot <- eigVec %*% t(ellBase) # rotated ellipse
plot((ellRot+ctr)[1, ], (ellRot+ctr)[2, ], asp=1, type="l", lwd=2)
matlines(xMat, yMat, lty=1, lwd=2, col="green")
points(ctr[1], ctr[2], pch=4, col="red", lwd=3)
আমি মনে করি এটি আপনি চান এটি আর কোড। আমি এই থ্রেড থেকে আর-মেলিং তালিকায় আর-কোড ধার নিয়েছি । মূলত ধারণাটি হ'ল: প্রধান এবং গৌণ অর্ধ-ব্যাসার্ধ হ'ল দুটি আইগেন মান এবং আপনি উপবৃত্তিকে প্রথম ইগেন ভেক্টর এবং এক্স-অক্ষের মধ্যে কোণের পরিমাণ দ্বারা ঘোরান
mat <- matrix(c(2.2, 0.4, 0.4, 2.8), 2, 2)
eigens <- eigen(mat)
evs <- sqrt(eigens$values)
evecs <- eigens$vectors
a <- evs[1]
b <- evs[2]
x0 <- 0
y0 <- 0
alpha <- atan(evecs[ , 1][2] / evecs[ , 1][1])
theta <- seq(0, 2 * pi, length=(1000))
x <- x0 + a * cos(theta) * cos(alpha) - b * sin(theta) * sin(alpha)
y <- y0 + a * cos(theta) * sin(alpha) + b * sin(theta) * cos(alpha)
png("graph.png")
plot(x, y, type = "l", main = expression("x = a cos " * theta * " + " * x[0] * " and y = b sin " * theta * " + " * y[0]), asp = 1)
arrows(0, 0, a * evecs[ , 1][2], a * evecs[ , 1][2])
arrows(0, 0, b * evecs[ , 2][3], b * evecs[ , 2][2])
dev.off()
asp=1
1 এবং লম্ব তীরের একটি অনুপাত আছে set আপনার কোড পরিবর্তন evs <- sqrt(eigens$values)
করা আমার উত্তর হিসাবে একই উপবৃত্ত দেয়।