diff scripts/general/triu.m @ 1083:fb8ca633c439

[project @ 1995-01-28 19:24:32 by jwe]
author jwe
date Sat, 28 Jan 1995 19:24:45 +0000
parents 3f257ab07921
children 611d403c7f3d
line wrap: on
line diff
--- a/scripts/general/triu.m
+++ b/scripts/general/triu.m
@@ -27,24 +27,22 @@
 
   if (nargin > 0)
     [nr, nc] = size (x);
-    retval = x;
+    retval = zeros (nr, nc);
   endif
 
   if (nargin == 1)
     k = 0;
   elseif (nargin == 2)
-    max_nr_nc = max (nr, nc);
-    if ((k > 0 && k > nc - 1) || (k < 0 && k < 1 - nr))
+    if ((k > 0 && k > nc) || (k < 0 && k < -nr))
       error ("triu: requested diagonal out of range")
     endif
   else
     usage ("triu (x [, k])");
   endif
 
-  for j = 1:nc
-    for i = j+1-k:nr
-      retval (i, j) = 0.0;
-    endfor
+  for j = max (1, k) : nc
+    nr_limit = min (nr, j-k);
+    retval (1:nr_limit, j) = x (1:nr_limit, j);
   endfor
 
 endfunction