File: gradn.m

package info (click to toggle)
plplot 5.10.0%2Bdfsg2-0.4
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 25,792 kB
  • ctags: 13,517
  • sloc: ansic: 83,001; xml: 27,081; ada: 18,878; cpp: 15,966; tcl: 11,651; python: 7,075; f90: 7,058; ml: 6,974; java: 6,665; perl: 5,029; sh: 2,208; makefile: 210; lisp: 75; sed: 25; fortran: 7
file content (51 lines) | stat: -rw-r--r-- 1,232 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
## Copyright (C) 1998, 1999, 2000 Joao Cardoso.
## 
## This program is free software; you can redistribute it and/or modify it
## under the terms of the GNU General Public License as published by the
## Free Software Foundation; either version 2 of the License, or (at your
## option) any later version.
## 
## This program is distributed in the hope that it will be useful, but
## WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
## General Public License for more details.
##
## This file is part of plplot_octave.

function [gx gy] = gradn(z, dx, dy, order)

# [gx gy] = gradn(z, [dx, dy [,order]])
#
# gx and gy are the x and y components of the gradient of matrix z.
# dx and dy are scalars giving the x and y step of z, default to 1
# order is the order of the "gradient", default 1, max 4

if (nargin == 1)
	dx = dy = 1;
endif

if (nargin == 3)
	order = 1;
endif

if (nargin == 2 || nargin > 4)
	help grad; return
endif

[nr nc] = size(z);

if (nr == 1 || nc == 1)
	help gradn; return
endif

gx = gy = zeros(nr,nc);

for i=1:nr
	gx(i,:) = diffn(z(i,:), dx, order);  
endfor

for i=1:nc
	gy(:,i) = diffn(z(:,i), dy, order);  
endfor
	
endfunction