Mercurial > hg > octave-nkf
view liboctave/Bounds.cc @ 1677:ef7f804cb722
[project @ 1995-12-28 20:20:29 by jwe]
author | jwe |
---|---|
date | Thu, 28 Dec 1995 20:22:03 +0000 |
parents | dc527156c38c |
children | 51fd6b03c3bb |
line wrap: on
line source
// Bounds.cc -*- C++ -*- /* Copyright (C) 1992, 1993, 1994, 1995 John W. Eaton This file is part of Octave. Octave 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, or (at your option) any later version. Octave 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. You should have received a copy of the GNU General Public License along with Octave; see the file COPYING. If not, write to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #if defined (__GNUG__) #pragma implementation #endif #ifdef HAVE_CONFIG_H #include <config.h> #endif #include <iostream.h> #include "Bounds.h" #include "lo-error.h" // error handling void Bounds::error (const char* msg) { (*current_liboctave_error_handler) ("fatal bounds error: ", msg); } Bounds::Bounds (const ColumnVector l, const ColumnVector u) { if (l.capacity () != u.capacity ()) { error ("inconsistent sizes for lower and upper bounds"); return; } nb = l.capacity (); lb = l; ub = u; } Bounds& Bounds::set_bounds (const ColumnVector l, const ColumnVector u) { if (l.capacity () != u.capacity ()) { error ("inconsistent sizes for lower and upper bounds"); return *this; } nb = l.capacity (); lb = l; ub = u; return *this; } Bounds& Bounds::set_lower_bounds (const ColumnVector l) { if (nb != l.capacity ()) { error ("inconsistent size for lower bounds"); return *this; } lb = l; return *this; } Bounds& Bounds::set_upper_bounds (const ColumnVector u) { if (nb != u.capacity ()) { error ("inconsistent size for upper bounds"); return *this; } ub = u; return *this; } ostream& operator << (ostream& os, const Bounds& b) { for (int i = 0; i < b.size (); i++) os << b.lower_bound (i) << " " << b.upper_bound (i) << "\n"; return os; } /* ;;; Local Variables: *** ;;; mode: C++ *** ;;; page-delimiter: "^/\\*" *** ;;; End: *** */