# HG changeset patch # User Jaroslav Hajek # Date 1263548094 -3600 # Node ID ed49cef7e005d213369bf65582a8589ae4998b36 # Parent e4936c129cbd4d74d508c96127583824f737c42a simplify Array::insert methods diff -r e4936c129cbd -r ed49cef7e005 liboctave/Array.cc --- a/liboctave/Array.cc Fri Jan 15 08:57:07 2010 +0100 +++ b/liboctave/Array.cc Fri Jan 15 10:34:54 2010 +0100 @@ -1493,96 +1493,23 @@ } -// FIXME: Remove these methods or implement them using assign. - template Array& Array::insert (const Array& a, octave_idx_type r, octave_idx_type c) { + idx_vector i (r, r + a.rows ()); + idx_vector j (c, c + a.columns ()); if (ndims () == 2 && a.ndims () == 2) - insert2 (a, r, c); + assign (i, j, a); else - insertN (a, r, c); - - return *this; -} - - -template -Array& -Array::insert2 (const Array& a, octave_idx_type r, octave_idx_type c) -{ - octave_idx_type a_rows = a.rows (); - octave_idx_type a_cols = a.cols (); - - if (r < 0 || r + a_rows > rows () || c < 0 || c + a_cols > cols ()) - { - (*current_liboctave_error_handler) ("range error for insert"); - return *this; - } - - for (octave_idx_type j = 0; j < a_cols; j++) - for (octave_idx_type i = 0; i < a_rows; i++) - elem (r+i, c+j) = a.elem (i, j); - - return *this; -} - -template -Array& -Array::insertN (const Array& a, octave_idx_type r, octave_idx_type c) -{ - dim_vector dv = dims (); - - dim_vector a_dv = a.dims (); - - int n = a_dv.length (); - - if (n == dimensions.length ()) { - Array a_ra_idx (a_dv.length (), 0); - - a_ra_idx.elem (0) = r; - a_ra_idx.elem (1) = c; - - for (int i = 0; i < n; i++) - { - if (a_ra_idx(i) < 0 || (a_ra_idx(i) + a_dv(i)) > dv(i)) - { - (*current_liboctave_error_handler) - ("Array::insert: range error for insert"); - return *this; - } - } - - octave_idx_type n_elt = a.numel (); - - const T *a_data = a.data (); - - octave_idx_type iidx = 0; - - octave_idx_type a_rows = a_dv(0); - - octave_idx_type this_rows = dv(0); - - octave_idx_type numel_page = a_dv(0) * a_dv(1); - - octave_idx_type count_pages = 0; - - for (octave_idx_type i = 0; i < n_elt; i++) - { - if (i != 0 && i % a_rows == 0) - iidx += (this_rows - a_rows); - - if (i % numel_page == 0) - iidx = c * dv(0) + r + dv(0) * dv(1) * count_pages++; - - elem (iidx++) = a_data[i]; - } + Array idx (a.ndims ()); + idx(0) = i; + idx(1) = j; + for (int k = 0; k < a.ndims (); k++) + idx(k) = idx_vector (0, a.dimensions(k)); + assign (idx, a); } - else - (*current_liboctave_error_handler) - ("Array::insert: invalid indexing operation"); return *this; } @@ -1592,88 +1519,12 @@ Array::insert (const Array& a, const Array& ra_idx) { octave_idx_type n = ra_idx.length (); - - if (n >= dimensions.length ()) - { - const dim_vector dva = a.dims (); - const dim_vector dv = dims ().redim (n); - int len_a = dva.length (); - int non_full_dim = 0; - - for (octave_idx_type i = 0; i < n; i++) - { - if (ra_idx(i) < 0 || (ra_idx(i) + - (i < len_a ? dva(i) : 1)) > dv(i)) - { - (*current_liboctave_error_handler) - ("Array::insert: range error for insert"); - return *this; - } - - if (dv(i) != (i < len_a ? dva(i) : 1)) - non_full_dim++; - } - - if (dva.numel ()) - { - if (non_full_dim < 2) - { - // Special case for fast concatenation - const T *a_data = a.data (); - octave_idx_type numel_to_move = 1; - octave_idx_type skip = 0; - for (int i = 0; i < len_a; i++) - if (ra_idx(i) == 0 && dva(i) == dv(i)) - numel_to_move *= dva(i); - else - { - skip = numel_to_move * (dv(i) - dva(i)); - numel_to_move *= dva(i); - break; - } - - octave_idx_type jidx = ra_idx(n-1); - for (int i = n-2; i >= 0; i--) - { - jidx *= dv(i); - jidx += ra_idx(i); - } - - octave_idx_type iidx = 0; - octave_idx_type moves = dva.numel () / numel_to_move; - for (octave_idx_type i = 0; i < moves; i++) - { - for (octave_idx_type j = 0; j < numel_to_move; j++) - elem (jidx++) = a_data[iidx++]; - jidx += skip; - } - } - else - { - // Generic code - const T *a_data = a.data (); - int nel = a.numel (); - Array a_idx (n, 0); - - for (int i = 0; i < nel; i++) - { - int iidx = a_idx(n-1) + ra_idx(n-1); - for (int j = n-2; j >= 0; j--) - { - iidx *= dv(j); - iidx += a_idx(j) + ra_idx(j); - } - - elem (iidx) = a_data[i]; - - increment_index (a_idx, dva); - } - } - } - } - else - (*current_liboctave_error_handler) - ("Array::insert: invalid indexing operation"); + Array idx (n); + const dim_vector dva = a.dims ().redim (n); + for (octave_idx_type k = 0; k < n; k++) + idx(k) = idx_vector (ra_idx (k), ra_idx (k) + dva(k)); + + assign (idx, a); return *this; } diff -r e4936c129cbd -r ed49cef7e005 liboctave/Array.h --- a/liboctave/Array.h Fri Jan 15 08:57:07 2010 +0100 +++ b/liboctave/Array.h Fri Jan 15 10:34:54 2010 +0100 @@ -585,13 +585,14 @@ // Dispatcher to the above two. void delete_elements (const Array& ia); - // FIXME -- are these required? What exactly are they supposed to do?. + // Insert an array into another at a specified position. + // If size (a) is [d1 d2 ... dN] and idx is [i1 i2 ... iN], + // this method is equivalent to + // x(i1:i1+d1-1, i2:i2+d2-1, ... , iN:iN+dN-1) = a. + Array& insert (const Array& a, const Array& idx); + // This is just a special case for idx = [r c 0 ...] Array& insert (const Array& a, octave_idx_type r, octave_idx_type c); - Array& insert2 (const Array& a, octave_idx_type r, octave_idx_type c); - Array& insertN (const Array& a, octave_idx_type r, octave_idx_type c); - - Array& insert (const Array& a, const Array& idx); void maybe_economize (void) { diff -r e4936c129cbd -r ed49cef7e005 liboctave/ChangeLog --- a/liboctave/ChangeLog Fri Jan 15 08:57:07 2010 +0100 +++ b/liboctave/ChangeLog Fri Jan 15 10:34:54 2010 +0100 @@ -1,3 +1,9 @@ +2010-01-15 Jaroslav Hajek + + * Array.cc (Array::insert): Rewrite using assign. + (Array::insert2, Array::insertN): Remove. + * Array.h: Update declarations. Add brief documentation. + 2010-01-15 Jaroslav Hajek * Array-b.cc: Inline ascending and descending sort.