[R-sig-Geo] How to count unique TRUE's
Robert J. Hijmans
r.hijmans at gmail.com
Tue Mar 31 21:44:56 CEST 2015
Forrest, it seems to me that you can simplify and do
output$AC[i] <- length(gIntersection(tmp, ac))
instead of
tmp2 <- as.vector(gIntersects(tmp, ac, byid=TRUE))
output$AC[i] <- length(tmp[tmp2 == TRUE])
Robert
On Tue, Mar 31, 2015 at 11:56 AM, Forrest Stevens <forrest at ufl.edu> wrote:
> I'm guessing based on the data and situation you describe that some
> variant of this would probably get you close:
>
>
> ## Sample data:
> d <- data.frame(A=c(T,F,F,T), B=c(F,T,F,T))
>
> ## Count row-wise trues:
> sum( apply(d, MARGIN=1, sum) >= 1 )
>
>
> Hope that helps,
> Forrest
> --
> Forrest R. Stevens
> Ph.D. Candidate, QSE3 IGERT Fellow
> Department of Geography
> Land Use and Environmental Change Institute
> University of Florida
> www.clas.ufl.edu/users/forrest
>
>
> On Tue, Mar 31, 2015 at 2:29 PM, Tom Philippi <tephilippi at gmail.com> wrote:
>> I can't quite make sense of what your objects look like, but I suspect you
>> need to change byid to a vector, so you are byid for the points but not the
>> polygons byid=c(FALSE,TRUE) or vice versa.
>>
>>
>> On Tue, Mar 31, 2015 at 10:55 AM, Walter Anderson <wandrson01 at gmail.com>
>> wrote:
>>
>>> I have a buffered project SpatialPolygonDataFrame and a
>>> SpatialPointDataFrame that I want to intersect (one project at a time)
>>> and count the number of points within each polygon's footprint.
>>>
>>> I am using the following code:
>>>
>>> for (i in 1:numprjs)
>>> {
>>> curprj <- as.character(output at PROJECT[i])
>>> tmp <- subset(buf2640, buf2640$PROJECT == curprj)
>>> tmp2 <- as.vector(gIntersects(tmp, ac, byid=TRUE))
>>> output$AC[i] <- length(tmp[tmp2 == TRUE])
>>> }
>>>
>>> The problem is that when the project's polygons cover more than one
>>> overlapping shapes (derived from multiple sub-projects that are given
>>> the same project id), the above code can multiple count a single ac
>>> point if it falls within the boundaries of two or more of a single
>>> projects polygons.
>>>
>>> As an example project 'B1103' has two points within its two polygons;
>>> however, the above code reports three. I believe the following extract
>>> of the core gIntersects command shows why
>>>
>>> 2 3
>>> 122 FALSE TRUE
>>> 313 TRUE TRUE
>>>
>>> So clearly the problem is my use of as.vector, which is taking all of
>>> the columns and combining them into a single vector; however, I am
>>> unsure of the best way to count the number of true in the original data
>>> structure created by the gIntersects command.
>>>
>>> Walter Anderson
>>>
>>> _______________________________________________
>>> R-sig-Geo mailing list
>>> R-sig-Geo at r-project.org
>>> https://stat.ethz.ch/mailman/listinfo/r-sig-geo
>>>
>>
>> [[alternative HTML version deleted]]
>>
>> _______________________________________________
>> R-sig-Geo mailing list
>> R-sig-Geo at r-project.org
>> https://stat.ethz.ch/mailman/listinfo/r-sig-geo
>
> _______________________________________________
> R-sig-Geo mailing list
> R-sig-Geo at r-project.org
> https://stat.ethz.ch/mailman/listinfo/r-sig-geo
More information about the R-sig-Geo
mailing list