Interactive Principal Component Analysis in R

[This article was first published on, and kindly contributed to R-bloggers]. (You can report issue about the content on this page here)
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.

This article is part of a R-Tips Weekly, a weekly video tutorial that shows you step-by-step how to do common R coding tasks.

Identify Clusters in your Data:

We’ll make an Interactive PCA visualization to investigate clusters and learn why observations are similar to each other. Here are the links to get set up. ????

(Click image to play tutorial)

PCA is all about data wrangling

PCA is a great tool for mining your data for clusters. But, most beginners get a few things wrong:

  • PCA only works with numeric data
  • Categorical data must be encoded as numeric data (e.g. one-hot)
  • Numeric data must be scaled (otherwise your PCA will be misleading)

Data Wrangling is SUPER Critical
We need to use dplyr to encode categorical features as numeric.

PCA Data Wrangling

Full code in the video Github Repository

Before Encoding
PCA will not work with Categorical Data
(You’ll get a nice error message)

PCA Category Data Conversion

After Encoding
PCA likes data in this format ????

PCA Encoding Numerical

Visualizing Clusters

What can we do with PCA + ggplot2? Let’s visualize clusters in our data!

First, fit a PCA using prcomp().

Next, use autoplot() from the ggfortify package.

Then visualize. As an added bonus, we can make it interactive with ggplotly()!

That’s some XMAS magic. Santa approves. ????

But if you really want to improve your productivity…

Here’s how to master R programming and become powered by R. ????

What happens after you learn R for Business.

Your Job Performance Review after you’ve launched your first Shiny App. ????

This is career acceleration.


  1. Sign Up to Get the R-Tips Weekly (You’ll get email notifications of NEW R-Tips as they are released):

  2. Set Up the GitHub Repo:

  3. Check out the setup video ( Or, Hit Pull in the Git Menu to get the R-Tips Code

Once you take these actions, you’ll be set up to receive R-Tips with Code every week. =)

To leave a comment for the author, please follow the link and comment on their blog: offers daily e-mail updates about R news and tutorials about learning R and many other topics. Click here if you're looking to post or find an R/data-science job.
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.

Never miss an update!
Subscribe to R-bloggers to receive
e-mails with the latest R posts.
(You will not see this message again.)

Click here to close (This popup will not appear again)