आर में वफ़ल चार्ट कैसे बनाएं?


11

मैं R में piecharts का उपयोग करने के विकल्प के रूप में एक वफ़ल चार्ट कैसे कर सकता हूं?

help.search("waffle")
No help files found with alias or concept or title matching waffle
using fuzzy matching.

निकटतम मैंने पाया कि बाहर मोज़ेकप्लॉट हैं।


मुझे नहीं पता, लेकिन एक बेहतर विधि का उपयोग क्यों नहीं किया? डॉट चार्ट बहुत बेहतर हैं।
पीटर Flom

2
जो लोग वफ़ल चार्ट जानना चाहते हैं, उनके लिए, ईगर आइज़ ब्लॉग पर रॉबर्ट कोसरा ने उनके बारे में एक टुकड़ा दिया है। जॉन पेल्टियर की टिप्पणियों पर भी ध्यान दें।
एंडी डब्ल्यू

निकटतम चीज जो मुझे मिल सकती है वह यह है । एफडब्ल्यूआईडब्ल्यू, मैं पीटर से सहमत हूं, जब मैं डेटा की कल्पना करता हूं तो मैं पीज़ और वेफल्स से बचता हूं।

जवाबों:


13

अब वफ़ल नामक एक पैकेज है ।

जीथुब पृष्ठ से उदाहरण:

parts <- c(80, 30, 20, 10)
waffle(parts, rows=8)

परिणाम:

परिणाम

सादर


मुझे नहीं पता था कि इन्हें "वफ़ल चार्ट" कहा जाता था। मैं उन्हें पसंद करता हूं - अच्छा पाई चार्ट रिप्लेसमेंट
छायाकार

7

मुझे संदेह है कि geom_tileपैकेज से ggplot2आप वह काम कर सकते हैं जिसकी आपको तलाश है। इस StackOverflow सवाल पर शेन का जवाब आपको मिलना चाहिए।

संपादित करें: यहां एक उदाहरण है, तुलना के लिए कुछ अन्य भूखंडों के साथ।

library(ggplot2)

# Here's some data I had lying around
tb <- structure(list(region = c("Africa", "Asia", "Latin America", 
"Other", "US-born"), ncases = c(36L, 34L, 56L, 2L, 44L)), .Names = c("region", 
"ncases"), row.names = c(NA, -5L), class = "data.frame")


# A bar chart of counts
ggplot(tb, aes(x = region, weight = ncases, fill = region)) +
    geom_bar()

# Pie chart.  Forgive me, Hadley, for I must sin.
ggplot(tb, aes(x = factor(1), weight = ncases, fill = region)) +
    geom_bar(width = 1) +
    coord_polar(theta = "y") +
    labs(x = "", y = "")

# Percentage pie.
ggplot(tb, aes(x = factor(1), weight = ncases/sum(ncases), fill = region)) +
    geom_bar() +
    scale_y_continuous(formatter = 'percent') +
    coord_polar(theta = "y") +
    labs(x = "", y = "")


# Waffles
# How many rows do you want the y axis to have?
ndeep <- 5

# I need to convert my data into a data.frame with uniquely-specified x
# and y coordinates for each case
# Note - it's actually important to specify y first for a
# horizontally-accumulating waffle
# One y for each row; then divide the total number of cases by the number of
# rows and round up to get the appropriate number of x increments
tb4waffles <- expand.grid(y = 1:ndeep,
                          x = seq_len(ceiling(sum(tb$ncases) / ndeep)))

# Expand the counts into a full vector of region labels - i.e., de-aggregate
regionvec <- rep(tb$region, tb$ncases)

# Depending on the value of ndeep, there might be more spots on the x-y grid
# than there are cases - so fill those with NA
tb4waffles$region <- c(regionvec, rep(NA, nrow(tb4waffles) - length(regionvec)))

# Plot it
ggplot(tb4waffles, aes(x = x, y = y, fill = region)) + 
    geom_tile(color = "white") + # The color of the lines between tiles
    scale_fill_manual("Region of Birth",
                      values = RColorBrewer::brewer.pal(5, "Dark2")) +
    opts(title = "TB Cases by Region of Birth")

उदाहरण वफ़ल साजिश

जाहिर है, सौंदर्यशास्त्र सही होने पर अतिरिक्त काम करना है (उदाहरण के लिए, उन कुल्हाड़ियों का मतलब क्या है?), लेकिन यह इसके बारे में यांत्रिकी है। मैं पाठक के लिए एक अभ्यास के रूप में "सुंदर" छोड़ता हूं।


3

यहाँ @ rbkunst के डेटा का उपयोग करते हुए आधार आर में एक है:

waffle <- function(x, rows, cols = seq_along(x), ...) {
  xx <- rep(cols, times = x)
  lx <- length(xx)
  m <- matrix(nrow = rows, ncol = (lx %/% rows) + (lx %% rows != 0))
  m[1:length(xx)] <- xx

  op <- par(no.readonly = TRUE)
  on.exit(par(op))

  par(list(...))
  plot.new()
  o <- cbind(c(row(m)), c(col(m))) + 1
  plot.window(xlim = c(0, max(o[, 2]) + 1), ylim = c(0, max(o[, 1]) + 1),
              asp = 1, xaxs = 'i', yaxs = 'i')
  rect(o[, 2], o[, 1], o[, 2] + .85, o[, 1] + .85, col = c(m), border = NA)

  invisible(list(m = m, o = o))
}


cols <- c("#F8766D", "#7CAE00", "#00BFC4", "#C77CFF")
m <- waffle(c(80, 30, 20, 10), rows = 8, cols = cols, mar = c(0,0,0,7),
            bg = 'cornsilk')
legend('right', legend = LETTERS[1:4], pch = 15, col = cols, pt.cex = 2,
       bty = 'n')

यहाँ छवि विवरण दर्ज करें


2
सभी उदाहरणों में लगता है कि उच्च स्याही: सूचना अनुपात।
फ्रैंक हरेल

1
मैं @ फ्रेंक हरेल से सहमत हूं। इसका उदाहरण एकवचन है। मुझे माप से परे रेखांकन पसंद है, लेकिन इस उदाहरण के लिए पाठकों से चार आवृत्तियों वाली एक तालिका को समझने की अपेक्षा करना उचित है। यदि कोई ग्राफ़ पसंद किया जाता है, तो एक डॉट या बार चार्ट सरल होता है (आवृत्तियों को एनोटेशन के रूप में भी जोड़ा जा सकता है)। मैं बहुत छोटे बच्चों के लिए कुछ शैक्षणिक मूल्य की कल्पना कर सकता हूं।
निक कॉक्स

1
तो आप कह रहे हैं कि जब मैं वार्षिक बार चार्ट कन्वेंशन में इस प्लॉट को पेश करता हूं, तो मुझे भीड़ में बहुत नफरत की उम्मीद करनी चाहिए? सिर के लिए धन्यवाद
कच्चे 3

इसे गोल करें: ग्राफ पाठकों को कह रहा है: यहां देखें, आप ग्राफ को समझने के लिए खुद को गिन सकते हैं! यदि संख्या बड़ी है, तो यह संभव नहीं है। यदि संख्याएँ छोटी हैं, तो भी यह अन्य रेखांकन की तुलना में अधिक सहायक नहीं है। छोटे बच्चों के लिए, यह सुदृढीकरण है इसलिए वे ग्राफिक्स को समझते हैं। संदेश की जरूरत किसे है?
निक कॉक्स

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.