美文网首页
一个简单的景观生态学“斑块”patch计数算法

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

作者: 杨康chin | 来源:发表于2022-06-26 20:37 被阅读0次
#### 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

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

相关文章

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

    写了一个景观生态学“斑块”统计的比较简单的递归算法,每次发现一个斑块(这里指考虑了标准化的正方形区域),向四个方向...

  • 高可用实践-限流算法

    限流算法 常见的限流算法有计数器算法、漏桶算法和令牌桶算法。 计数器法 计数器算法“简单粗暴”。该算法会维护一个c...

  • JVM之垃圾回收

    1、引用计数算法 引用计数算法的原理很简单:给对象添加一个引用计数器,每当有一个地方引用它时,计数器值+1;当引用...

  • Android 性能优化-GC确定回收的算法

    本文中分享两种GC确定回收的算法 引用计数算法以及可达性分析算法 引用计数算法:简单来说引用计数算法就是当前内存地...

  • ASP.NET Core中使用固定窗口限流

    算法原理 固定窗口算法又称计数器算法,是一种简单的限流算法。在单位时间内设定一个阈值和一个计数值,每收到一个请求则...

  • JVM垃圾回收算法笔记

    常用垃圾回收算法 引用计数(Reference Counting) 引用计数算法实现简单,判定效率也高,基本原理是...

  • Java内存管理

    内存回收算法 引用计数算法 对象中添加一个引用计数器,有地方引用时,+1;当某个引用失效时,-1。优点:实现简单 ...

  • php的垃圾回收算法

    编程语言的垃圾收集算法有很多种,今天我们谈一谈常见的集中垃圾收集算法。 引用计数算法 引用计数算法很简单,它实际上...

  • 《深入理解Java虚拟机》学习笔记(三)垃圾回收

    判断对象是否存活引用计数算法:为对象添加引用计数器,引用计数器+1,引用失效计数器-1,算法简单,效率高,很难解决...

  • JAVA判断一个对象生存还是死亡

    JAVA中判断一个对象是否死亡的算法有两种: 引用计数算法 可达性分析算法 一、引用计数算法 所谓引用计数算法就是...

网友评论

      本文标题:一个简单的景观生态学“斑块”patch计数算法

      本文链接:https://www.haomeiwen.com/subject/pamgvrtx.html