博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
汇流累积量
阅读量:5996 次
发布时间:2019-06-20

本文共 861 字,大约阅读时间需要 2 分钟。

最近研究汇流累积量的计算,下了些资料,不过都是英文的看着真的很吃力。

搞明白了其中一种方法,是用Matlab写的:

78 72 69 71 58 49

74 67 56 49 46 50
69 53 44 37 38 48
64 58 55 22 31 24
68 61 47 21 16 19
74 53 34 12 11 12

1.算法初始值dem高程值矩阵、x坐标值矩阵和y坐标值矩阵。

2.返回汇流累积量flowacc、坡度slope。

首先计算坡度,采用邻接矩阵36*36表示。

[ic1,icd1] = ixneighbors(dem);

e = (dem(ic1)-dem(icd1))./hypot(X(ic1)-X(icd1),Y(ic1)-Y(icd1));

接着计算汇流方向,这里仍采用邻接矩阵表示,没有采用类似ESRI的D8编码方法。single方式,根据计算8个方向的坡度取最大的,另外一种是Multi方式

还有边缘处理、sink点处理等.

最后采用求多元方程组解的方式求得汇流累积向量flowacc,很神奇,原来矩阵运算可以求累积。

switch params.edges

    case 'open';
        flowacc = (speye(nrc,nrc)-spdiags(edgecorrection,0,nrc,nrc)*M')\params.W0(:);
    otherwise     
        flowacc = (speye(nrc,nrc)-M')\params.W0(:);  %36*1=(36*36-36*36)\36*1,表示(speye(nrc,nrc)-M')*flowacc = params.W0(:);     
end

flowacc = reshape(flowacc,siz);

这种方法最后得到的数据比正常的结果都增加了1。

1 1 1 1 1 1

1 2 2 3 3 1
1 4 8 6 5 1
1 1 1 21 1 2
1 1 1 2 25 1
1 3 5 8 36 2

参考D8编码方法:

转载地址:http://lhmlx.baihongyu.com/

你可能感兴趣的文章
[华为机试练习题]9.坐标移动
查看>>
April Fools Day Contest 2016 B. Scrambled
查看>>
iOS开发--多线程
查看>>
网易游戏2015年暑期实习生面试经历-游戏研发project师
查看>>
Celery的实践指南
查看>>
Shell中的while循环【转】
查看>>
Linux下安装memcached
查看>>
qt介绍
查看>>
error
查看>>
ASP.NET MVC下使用AngularJs语言(一):Hello your name
查看>>
[书目20111003]Ivor Horton's Beginning Java, Java 7 Edition
查看>>
centos使用yum安装软件的时候出现了undefined symbol: CRYPTO_set_locking_callback
查看>>
对springMVC的简单理解
查看>>
android studio下生成jni头文件
查看>>
最简单的Android教程之自定义控件
查看>>
虚拟 router 原理分析- 每天5分钟玩转 OpenStack(101)
查看>>
使用linux的shell脚本实现在当前行重复动态显示时间等字符串信息(不另起新行)...
查看>>
myeclipse开发代码颜色搭配保护视力
查看>>
iOS开发-数据存储NSCoder
查看>>
SQL Server 存储过程【转】
查看>>