Netlogo:Shapefile与Raster

时间:2015-10-05 18:35:12

标签: gis netlogo

我目前正在使用NetLogo中的模型来模拟某些农场的土地利用变化。为此,我需要在NetLogo中使用GIS扩展。我远没有运行模型,但我想知道我的模型的最佳方式是:

(1)使用具有农场边界的shapefile并将其与其他栅格地图(例如距离市场的欧几里德距离)重叠

(2)使用具有表示场的单元ID的栅格。这样,我可以在属性和其他栅格地图之间实现完美重叠。

提前谢谢!

2 个答案:

答案 0 :(得分:2)

我怀疑答案取决于您打算如何使用GIS文件中包含的信息。我真正建议的是,你收集人们集成GIS的几种方式,看看看起来最相似的东西。这是你的第一个例子。

我最近的模型具有很强的空间成分,可以传播流行病。流行感染力受人口的强烈影响。我在分区域一级获得了模型中所有国家(选择国家的下拉框)的人口密度作为光栅文件。将其作为补丁信息导入NetLogo可有效调整栅格大小。然后我将NetLogo补丁转换为实际平方公里(对于每个国家/地区),以便为每个NetLogo补丁创建填充。

答案 1 :(得分:0)

到这一天结束时,这是解决问题的最佳方式:

extensions [gis] 
globals 
[ 
  land-use-map 
  lotid-patch-map 
  def-risk-map 
  market-dist-map 
] 

patches-own
[ 
  land-use 
  lotid-patch 
  def-risk 
  market-dist
]

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; load the maps   ;;
;;;;;;;;;;;;;;;;;;;;; 

to load-gis

  clear-all

  set land-use-map gis:load-dataset "area2_lu_black.asc"     ;loads the land use map
  set lotid-patch-map gis:load-dataset "area2_lot.asc"       ;loads the lots map 
  set def-risk-map gis:load-dataset "area2_risk.asc"         ;loads the deforestation risk map 
  set market-dist-map gis:load-dataset "area2_mkt.asc"       ;loads the distance from markets map 

  gis:set-world-envelope-ds gis:envelope-of land-use-map     ;sets the envelope of the world to match that of the GIS dataset

  gis:apply-raster land-use-map land-use                     ;patches in the land-use-map have a specific land-use now
  gis:apply-raster lotid-patch-map lotid-patch               ;patches in the lot-id-map have a specific lot-id now
  gis:apply-raster def-risk-map def-risk                     ;patches in the def-risk-map have a specific def-risk now   
  gis:apply-raster market-dist-map market-dist               ;patches in the market-dist-map have a specific market-dist now 

  ask patches [

    if land-use = 1 [ set pcolor 64 ] ; Green = Forest
    if land-use = 2 [ set pcolor 14 ] ; Dark red = Agriculture
    if land-use = 3 [ set pcolor 45 ] ; Yellow = Reforestation 

  ]

  let view gis:load-dataset "area2.shp"                      ;load a shapefile of the properties
  gis:set-world-envelope-ds gis:envelope-of view
  foreach gis:feature-list-of view
  [
    gis:set-drawing-color white                              ;draws the line of the shapefile
    gis:draw ? 1
  ] 

end