一个简单的景观生态学“斑块”patch计数算法

#### Patch counting
def expand_array(square_array):
    sh = square_array.shape[0]
    new_array = []
    new_array.extend([0]*(sh+2))
    for i in range(sh):
        new_array.append(0)
        new_array.extend(square_array[i,:])
        new_array.append(0)

    new_array.extend([0]*(sh+2))
    new_array=np.array(new_array).reshape(sh+2,sh+2)
    return new_array

        
def recursive_find_all_points(i,j,data,point_result,flag):
    
    ### if 0, ignore
    if data[i,j]==0:
        return point_result
    ### if already considered, continue
    if (i,j) in [e for w in point_result.values() for e in w]:
        return point_result
    ### if it's a new patch, count it.
    if flag == "origin":
#         print('1 block!')
        point_result[len(point_result)] = []
    point_result[len(point_result)-1].append((i,j)) 
    
    ### recursion in four directions
    for direction in [(-1,0),(1,0),(0,-1),(0,1)]:
        point_result = recursive_find_all_points(i+direction[0], j+direction[1], data, point_result, flag="derived")

    return point_result


def get_patches(array):
    """
        Remember to only input 0,1 matrix. Which means only one class is calculated each time.
    """
    expanded_array = expand_array(array)
    patches = get_points_result(expanded_array)
    return patches
截屏2022-06-26 下午8.35.26.png

写了一个景观生态学“斑块”统计的比较简单的递归算法,每次发现一个斑块(这里指考虑了标准化的正方形区域),向四个方向扩散并判断连接性,直到全部碰壁。然后把这些点放入列表里,避免重复计算。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 什么是景观生态学?景观生态学的研究内容? 以景观为研究对象,以人与自然协调为指导思想,重点研究景观的结构、功能和变...
    裕祺阅读 12,070评论 3 4
  • 第四章 1.导致景观变化的驱动因子有哪些?(影响景观形成的主要因素有哪些?)地形地貌、气候、土壤、植被分别通过什么...
    裕祺阅读 6,415评论 0 2
  • 绪论 1、起源(景观生态学的由来): 景观生态学(Landscape Ecology) 首先是20世纪60年代在欧...
    裕祺阅读 3,509评论 0 9
  • 决定把以前的应试资料全部悄悄地公开了~祝林大各位学子别花太多时间考试 单选题10X2 景观要素的三种类型:斑块、 ...
    裕祺阅读 1,489评论 0 2
  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 3,371评论 0 19