Introducing the healthvis R package – one line D3 graphics with R
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.
We have been a little slow on the posting for the last couple of months here at Simply Stats. That’s bad news for the blog, but good news for our research programs!
Today I’m announcing the new healthvis R package that is being developed by my student Prasad Patil (who needs a website like yesterday), Hector Corrada Bravo, and myself*. The basic idea is that I have loved D3 interactive graphics for a while. But they are hard to create from scratch, since they require knowledge of both Javascript and the D3 library.
Even with those skills, it can take a while to develop a new graphic. On the other hand, I know a lot about R and am often analyzing biomedical data where interactive graphics could be hugely useful. There are a couple of really useful tools for creating interactive graphics in R, most notably Shiny, which is awesome. But these tools still require a bit of development to get right and are designed for “stand alone” tools.
So we created an R package that builds specific graphs that come up commonly in the analysis of health data like survival curves, heatmaps, and icon arrays. For example, here is how you make an interactive survival plot comparing treated to untreated individuals with healthvis:
# Load libraries library(healthvis) library(survival) # Run a cox proportional hazards regression cobj <- coxph(Surv(time, status)~trt+age+celltype+prior, data=veteran) # Plot using healthvis - one line! survivalVis(cobj, data=veteran, plot.title="Veteran Survival Data", group="trt", group.names=c("Treatment", "No Treatment"), line.col=c("#E495A5","#39BEB1"))
The “survivalVis” command above produces an interactive graphic like this. Here it is embedded (you may have to scroll to see the dropdowns on the right – we are working on resizing)
The advantage of this approach is that you can make common graphics interactive without a lot of development time. Here are some other unique features:
-
The graphics are hosted on Google App Engine. With one click you can get a permanent link and share it with collaborators.
-
With another click you can get the code to embed the graphics in your website.
-
If you have already created D3 graphics it only takes a few minutes to develop a healthvis version to let R users create their own – email us and we will make it part of the healthvis package!
-
healthvis is totally general – you can develop graphics that don’t have anything to do with health with our framework. Just email to get in touch if you want to be a developer at [email protected]
We have started a blog over at healthvis.org where we will be talking about the tricks we learn while developing D3 graphics, updates to the healthvis package, and generally talking about visualization for new technologies like those developed by the CCNE and individualized health. If you are interested in getting involved as a developer, user or tester, drop us a line and let us know. In the meantime, happy visualizing!
* This project is supported by the JHU CCNE (U54CA151838) and the Johns Hopkins inHealth initiative.
R-bloggers.com 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.