Dear John and R-list Thank you for your comment. Here are my data in the dput format:
cs.not.log.bp <- ( structure(c(168, 69, 16, 69, 41, 6, 148, 6, 5, 4, 7, 4, 4, 2, 7, 2, 4, 2, 4, 2, 1, 0, 2, 0), .Dim = c(4L, 6L), .Dimnames = list( c("IUCN.Terrestrial", "IUCN.Marine", "National.CS.Terrestrial", "National.CS.Marine"), c("NE", "LC", "NT", "VU", "EN", "CR" ))) ) The database format is shown below, where columns represent conservation status and the rows are two classification methods each split into marine and terrestrial: NE LC NT VU EN CR IUCN.Terrestrial 168 41 5 4 4 1 IUCN.Marine 69 6 4 2 2 0 National.CS.Terrestrial 16 148 7 7 4 2 National.CS.Marine 69 6 4 2 2 0 I would like to plot the conservation status according to two classifications (i.e. my groups - IUCN status and national status), and for each of those groups I would like data for the marine and terrestrial species to be stacked. I have tried the following code (where cs.not.log.bp is my data), but it does not work: barplot(cs.not.log.bp[c(1:2),], xlab = "Conservation status", ylab = "Number of species", col = c("grey90","grey80"), ylim = c(0,250), space = 2) barplot(cs.not.log.bp[c(3:4),], col = c("grey60","grey30"), beside = T,add = T,names.arg = NA) legend("topright",c("IUCN Terrestrial","IUCN Marine","National CS Terrestrial","National CS Marine"), col = c("grey90","grey80","grey60","grey30"), pch = 15) What happens is that some of the data in the second group stacks onto the first group and then the remainder forms a second group. I would like only "like" data (i.e. from the same database row) to stack within a group. There was one other similar post on the R-list (http://r.789695.n4.nabble.com/barplot-question-td3670861.html ) where the user had the same problem as I did, but it does not seem that this was resolved. Please let me know if you have any suggestions. Thanks and best wishes, Nicola -----Original Message----- From: John Kane [mailto:jrkrid...@inbox.com] Sent: 25 April 2012 02:58 PM To: Nicola Van Wilgen; r-help@r-project.org Subject: RE: [R] FW: Combined grouped and stacked bargraph Hi Nicola, You have provided the code and data as requested the data is in a very unfriendly format. If you would supply the data in an easily useable format so that the readers here can work with it it would help. Since it looks like you have a small data set the easiest thing is to use dput() [see ?dput for information] and then just paste the output into your email. I expect you would get faster and better answers. John Kane Kingston ON Canada > -----Original Message----- > From: nicola.vanwil...@sanparks.org > Sent: Wed, 25 Apr 2012 14:42:49 +0200 > To: r-help@r-project.org > Subject: [R] FW: Combined grouped and stacked bargraph > > Dear R list, > > It appears that my request from yesterday got a bit garbled. I have > tried to rephrase and retype it - please let me know if you can help me > - I am having some trouble drawing a bar-graph with two groups, both of > which are stacked. > > I would like to plot the conservation status according to two > classifications (i.e. my groups - IUCN status and national status), and > for each of those groups I would like data for the marine and > terrestrial species to be stacked. My data look like this (where the > names for the columns are conservation status': NE, LC, NT, VU, EN and > CR; and the matrix name is cs.not.log.bp): > > IUCN.Terrestrial 168 41 5 4 4 1 > > IUCN.Marine 69 6 4 2 2 0 > > National.CS.Terrestrial 16 148 7 7 4 2 > > National.CS.Marine 69 6 4 2 2 0 > > I have tried the following code, but it does not work: > > barplot(cs.not.log.bp[c(1:2),], xlab = "Conservation status", ylab = > "Number of species", col = c("grey90","grey80"),names = cs.names, ylim = > c(0,250), space = 2) > > barplot(cs.not.log.bp[c(3:4),], col = c("grey60","grey30"), beside = > T,add = T,names.arg = NA) > > legend("topright",c("IUCN Terrestrial","IUCN Marine","National CS > Terrestrial","National CS Marine"), col = > c("grey90","grey80","grey60","grey30"), pch = 15) > > What happens is that some of the data in the second group stacks onto > the first group and then the remainder forms a second group. I would > like only "like" data (i.e. from the same database row) to stack within > a group. > > There was one other similar post on the R-list > (http://r.789695.n4.nabble.com/barplot-question-td3670861.html ) where > the user had the same problem as I did, but it does not seem that this > was resolved. > > Please let me know if you have any suggestions. > > Thanks and best wishes, > > Nicola > > -----Original Message----- > From: r-help-boun...@r-project.org [mailto:r-help-boun...@r-project.org] > On Behalf Of Nicola Van Wilgen > Sent: 24 April 2012 01:12 PM > To: r-help@r-project.org > Subject: [R] Combined grouped and stacked bargraph > > Dear R list, > > > > I am having some trouble drawing a bar-graph with two groups, both of > which are stacked. > > > > A sample of my data (IUCN and national conservation status for marine > and terrestrial species) look like this: > > Status > > IUCN Terrestrial > > IUCN Marine > > National CS Terrestrial > > National CS Marine > > NE > > 168 > > 69 > > 16 > > 69 > > LC > > 41 > > 6 > > 148 > > 6 > > NT > > 5 > > 4 > > 7 > > 4 > > VU > > 4 > > 2 > > 7 > > 2 > > EN > > 4 > > 2 > > 4 > > 2 > > CR > > 1 > > 0 > > 2 > > 0 > > > > I would like to plot the conservation status for two groups (IUCN status > and national status), and for each of those groups I would like data for > the marine and terrestrial species to be stacked. I needed to transpose > the data to plot correctly, so my data in the code below look like this > (where the names for data in the columns are NE, LC, NT, VU, EN and CR; > and the matrix name is cs.not.log.bp): > > > > IUCN.Terrestrial 168 41 5 4 4 1 > > IUCN.Marine 69 6 4 2 2 0 > > National.CS.Terrestrial 16 148 7 7 4 2 > > National.CS.Marine 69 6 4 2 2 0 > > > > I have tried the following code, but it does not work: > > > > barplot(cs.not.log.bp[c(1:2),], xlab = "Conservation status", ylab = > "Number of species", col = c("grey90","grey80"), > > names = cs.names, ylim = c(0,250), space = 2) > > barplot(cs.not.log.bp[c(3:4),], col = c("grey60","grey30"), beside = > T,add = T,names.arg = NA) > > legend("topright",c("IUCN Terrestrial","IUCN Marine","National CS > Terrestrial","National CS Marine"), > > col = c("grey90","grey80","grey60","grey30"), pch = 15) > > > > What happens is that some of the data in the second group stacks onto > the first group and then the remainder forms a second group. I would > like only "like" data to stack within a group. > > > > There was one other similar post on the R-list > (http://r.789695.n4.nabble.com/barplot-question-td3670861.html ) where > the user had the same problem as I did, but it does not seem that this > was resolved. > > > > Please let me know if you have any suggestions. > > > > Thanks and best wishes, > > > > Nicola > ____________________________________________________________ FREE ONLINE PHOTOSHARING - Share your photos online with your friends and family! Visit http://www.inbox.com/photosharing to find out more! -------------------------------------------------------------------------------- This e-mail communication and any attachments are confidential and are intended only for the individual(s) or entity named above and others who have been specifically authorized to receive it. If you are not the intended recipient, please do not copy, use or disclose the contents of this communication to others. Please notify the sender that you have received this email in error by replying to the e-mail or by telephoning the sender. Please then delete the e-mail and any copies of it. This information may contain private, confidential or privileged material. Thank you. -------------------------------------------------------------------------------- ______________________________________________ R-help@r-project.org mailing list https://stat.ethz.ch/mailman/listinfo/r-help PLEASE do read the posting guide http://www.R-project.org/posting-guide.html and provide commented, minimal, self-contained, reproducible code.