The Census Bureau does not provide a nationwide shapefile of public-use microdata areas (the smallest geography available in the American Community Survey). I tried to combine them all with several different methods, but even the one that de-duplicates identifiers breaks when it gets to California. Am I doing something stupid or does it require a difficult workaround? Here, the code is reproduced until things break.
library(taRifx.geo) library(maptools) td <- tempdir() ; tf <- tempfile() setInternet2( TRUE ) download.file( "ftp://ftp2.census.gov/geo/tiger/TIGER2014/PUMA/" , tf ) al <- readLines( tf ) tl <- al[ grep( "geo/tiger/TIGER2014/PUMA/tl_2014_" , al ) ] fp <- gsub( "(.*)geo/tiger/TIGER2014/PUMA/tl_2014_([0-9]*)_puma10\\.zip(.*)" , "\\2" , tl ) # get rid of alaska fp <- fp[ fp != '02' ] af <- paste0( "ftp://ftp2.census.gov/geo/tiger/TIGER2014/PUMA/tl_2014_" , fp , "_puma10.zip" ) d <- NULL for ( i in af ){ try( file.remove( z ) , silent = TRUE ) download.file( i , tf , mode = 'wb' ) z <- unzip( tf , exdir = td ) b <- readShapePoly( z[ grep( 'shp$' , z ) ] ) if ( is.null( d ) ) d <- b else d <- taRifx.geo:::rbind.SpatialPolygonsDataFrame( d , b , fix.duplicated.IDs = TRUE ) } # Error in `row.names<-.data.frame`(`*tmp*`, value = c("d.0", "d.1", "d.2", : # duplicate 'row.names' are not allowed # In addition: Warning message: # non-unique values when setting 'row.names': 'd.0', 'd.1', 'd.10', 'd.11', 'd.12', 'd.13', 'd.14', 'd.15', 'd.16', 'd.17', 'd.18', 'd.19', 'd.2', 'd.3', 'd.4', 'd.5', 'd.6', 'd.7', 'd.8', 'd.9'