Mercurial > hg > octave-lyh
view examples/paramdemo.cc @ 17213:334d8edd48bc
lo-regexp.cc: prevent cast of negative floating point value to size_t.
* regexp.cc: simplify two expressions like "static_cast<size_t> (e - 1) + 1"
to "static_cast<size_t> (e), where 'e' is a nonnegative index value of type
double. This prevents a cast of -1.0 to the unsigned integral type "size_t"
whenever 'e' is zero. A test case where this occurs (for the second change) is
regexprep ('World', '^', 'Hello ', 'emptymatch').
author | Philipp Kutin <philipp.kutin@gmail.com> |
---|---|
date | Thu, 08 Aug 2013 10:58:37 +0200 |
parents | be41c30bcb44 |
children |
line wrap: on
line source
#include <octave/oct.h> DEFUN_DLD (paramdemo, args, nargout, "Parameter Check Demo") { octave_value retval; int nargin = args.length (); if (nargin != 1) print_usage (); else if (nargout != 0) error ("paramdemo: OUTPUT argument required"); else { NDArray m = args(0).array_value (); double min_val = -10.0; double max_val = 10.0; octave_stdout << "Properties of input array:\n"; if (m.any_element_is_negative ()) octave_stdout << " includes negative values\n"; if (m.any_element_is_inf_or_nan ()) octave_stdout << " includes Inf or NaN values\n"; if (m.any_element_not_one_or_zero ()) octave_stdout << " includes other values than 1 and 0\n"; if (m.all_elements_are_int_or_inf_or_nan ()) octave_stdout << " includes only int, Inf or NaN values\n"; if (m.all_integers (min_val, max_val)) octave_stdout << " includes only integers in [-10,10]\n"; } return retval; }