คัดลอกแรสเตอร์จาก lat / lon ถึง UTM ใน R หรือไม่


13

ฉันต้องเปลี่ยนมันเป็น UTM เพื่อให้บัฟเฟอร์ทำงานได้

wets<-readOGR(dsn=".",layer="shapefile")
r.raster <- raster()
extent(r.raster) <- extent(wets)
res(r.raster) <- 100 

wets.r <- rasterize(wet,r.raster)
plot(wets.r)
wetsbuf<-buffer(wets.r,width=500)

ในระหว่างการสร้างบัฟเฟอร์ซึ่งเป็นบรรทัดสุดท้ายของรหัสมันให้คำเตือนนี้:

Warning message:  
In couldBeLonLat(x) :
  raster has a longitude/latitude CRS, but coordinates do not match that

นี่คือข้อมูล

  summary(wets.r)
          layer
 Min.        1
 1st Qu.     1
 Median      2
 3rd Qu.     9
 Max.       11
 NA's    52629

summary(wets)

  Object of class SpatialPolygonsDataFrame
Coordinates:
      min       max
 x  683705  714088.8
 y 4326266 4343768.0
 Is projected: TRUE 
 proj4string :
 [+proj=tmerc +lat_0=0 +lon_0=24 +k=0.9996 +x_0=500000 +y_0=0 +datum=GGRS87
 +units=m +no_defs +ellps=GRS80 +towgs84=-199.87,74.79,246.62]
 Data attributes:
   Min. 1st Qu.  Median    Mean 3rd Qu.    Max. 
    0.0     2.5     5.0     5.0     7.5    10.0 






 wets.r

class       : RasterLayer 
dimensions  : 175, 304, 53200  (nrow, ncol, ncell)
resolution  : 100, 100  (x, y)
extent      : 683705, 714105, 4326268, 4343768  (xmin, xmax, ymin, ymax)
coord. ref. : +proj=longlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0 
data source : in memory
names       : layer 
values      : 1, 11  (min, max)
attributes  :
   ID FID
 from:  1   0
 to  : 11  10

ฉันต้องเปลี่ยนการปฏิเสธเพื่อให้สามารถทำบัฟเฟอร์ได้


คุณมีข้อมูลในระบบพิกัดที่คาดการณ์หรือ CS ทางภูมิศาสตร์หรือไม่?
แอรอน

ข้อมูลเวกเตอร์เริ่มต้นอยู่ในระบบพิกัดที่ฉันคิด
gsa

คาดการณ์ (เช่น UTM) หรือทางภูมิศาสตร์ (lat / lon)?
แอรอน

ฉันไม่รู้วิธีตรวจสอบสิ่งนี้ฉันคิดว่า UTM ไม่แน่ใจ
gsa

คุณมีพิกัดอะไรและพื้นที่ (รัฐเมือง)
ed.hank

คำตอบ:


16

นี่คือวิธีที่คุณสามารถปฏิเสธการแรสเตอร์ใน R โดยใช้แพ็คเกจแรสเตอร์ ในตัวอย่างนี้อินพุต geotiff อยู่ในระบบพิกัดทางภูมิศาสตร์ NAD83 และฉันปฏิเสธไปยังระบบพิกัดที่คาดการณ์ NAD 83 UTM 15 การอ้างอิงที่ดีสำหรับการคาดการณ์รูปแบบ Proj4 ซึ่งจะถูกใช้โดย RGDAL, สามารถพบได้ที่spatialreference.org

library(raster)

# Create RasterLayer object
r <- raster('C:/temp/binary_nad83.tif')

# Define the Proj.4 spatial reference 
# http://spatialreference.org/ref/epsg/26915/proj4/
sr <- "+proj=utm +zone=15 +ellps=GRS80 +datum=NAD83 +units=m +no_defs" 

# Project Raster
projected_raster <- projectRaster(r, crs = sr)

# Write the RasterLayer to disk (See datatype documentation for other formats)
writeRaster(projected_raster, filename="C:/temp/binary_utm15.tif", datatype='INT1U', overwrite=TRUE)

ขอบคุณสำหรับคำตอบมันคืนค่านี้: ข้อผิดพลาดใน projectExtent (จาก, projto): ไม่สามารถทำการเปลี่ยนแปลงนี้ได้นอกจากนี้: ข้อความเตือน: ใน rgdal :: rawTransform (projfrom, projto, nrow (xy), xy [, 1], xy [,: 218 จุดที่คาดการณ์ไม่แน่นอน
gsa

คุณใช้แรสเตอร์แบนด์เดียวหรือหลายวง? ตัวอย่างนี้ใช้สำหรับแรสเตอร์แบนด์เดียว
แอรอน

มันมาจากกระบวนการแรสเตอร์ของเวกเตอร์ (พื้นที่ชุ่มน้ำ) ไม่ใช่ภาพจากดาวเทียมดังนั้นฉันจะไปกับวงดนตรีเดี่ยว
gsa

ลองอัปเดตแพคเกจแรสเตอร์ / rgal ของคุณ: r-sig-geo.2731867.n2.nabble.com/…
แอรอน

@gsa หากใช้งานได้เป็นความคิดที่ดีที่จะอัปโหลดและยอมรับคำตอบ! มิฉะนั้นแก้ไขและชี้แจงคำถามเดิมของคุณ
Simbamangu
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.