File: octave_10.html

package info (click to toggle)
octave 2.0.16-2
  • links: PTS
  • area: main
  • in suites: potato
  • size: 26,276 kB
  • ctags: 16,450
  • sloc: cpp: 67,548; fortran: 41,514; ansic: 26,682; sh: 7,361; makefile: 4,077; lex: 2,008; yacc: 1,849; lisp: 1,702; perl: 1,676; exp: 123
file content (152 lines) | stat: -rw-r--r-- 4,662 bytes parent folder | download
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
<HTML>
<HEAD>
<!-- This HTML file has been created by texi2html 1.51
     from ./octave.texi on 18 June 1999 -->

<TITLE>GNU Octave - Evaluation</TITLE>
</HEAD>
<BODY>
Go to the <A HREF="octave_1.html">first</A>, <A HREF="octave_9.html">previous</A>, <A HREF="octave_11.html">next</A>, <A HREF="octave_40.html">last</A> section, <A HREF="octave_toc.html">table of contents</A>.
<P><HR><P>


<H1><A NAME="SEC77" HREF="octave_toc.html#TOC77">Evaluation</A></H1>

<P>
Normally, you evaluate expressions simply by typing them at the Octave
prompt, or by asking Octave to interpret commands that you have saved in
a file.

</P>
<P>
Sometimes, you may find it necessary to evaluate an expression that has
been computed and stored in a string, or use a string as the name of a
function to call.  The <CODE>eval</CODE> and <CODE>feval</CODE> functions allow you
to do just that, and are necessary in order to evaluate commands that
are not known until run time, or to write functions that will need to
call user-supplied functions.

</P>
<P>
<DL>
<DT><U>Built-in Function:</U>  <B>eval</B> <I>(<VAR>command</VAR>)</I>
<DD><A NAME="IDX387"></A>
Parse the string <VAR>command</VAR> and evaluate it as if it were an Octave
program, returning the last value computed.  The <VAR>command</VAR> is
evaluated in the current context, so any results remain available after
<CODE>eval</CODE> returns.  For example,

</P>

<PRE>
eval ("a = 13")
     -| a = 13
     => 13
</PRE>

<P>
In this case, the value of the evaluated expression is printed and it is
also returned returned from <CODE>eval</CODE>.  Just as with any other
expression, you can turn printing off by ending the expression in a
semicolon.  For example,

</P>

<PRE>
eval ("a = 13;")
     => 13
</PRE>

<P>
In this example, the variable <CODE>a</CODE> has been given the value 13, but
the value of the expression is not printed.  You can also turn off
automatic printing for all expressions executed by <CODE>eval</CODE> using the
variable <CODE>default_eval_print_flag</CODE>.
</DL>

</P>
<P>
<DL>
<DT><U>Built-in Variable:</U> <B>default_eval_print_flag</B>
<DD><A NAME="IDX388"></A>
If the value of this variable is nonzero, Octave prints the results of
commands executed by <CODE>eval</CODE> that do not end with semicolons.  If it
is zero, automatic printing is suppressed.  The default value is 1.
</DL>

</P>
<P>
<DL>
<DT><U>Built-in Function:</U>  <B>feval</B> <I>(<VAR>name</VAR>, ...)</I>
<DD><A NAME="IDX389"></A>
Evaluate the function named <VAR>name</VAR>.  Any arguments after the first
are passed on to the named function.  For example,

</P>

<PRE>
feval ("acos", -1)
     => 3.1416
</PRE>

<P>
calls the function <CODE>acos</CODE> with the argument <SAMP>`-1'</SAMP>.

</P>
<P>
The function <CODE>feval</CODE> is necessary in order to be able to write
functions that call user-supplied functions, because Octave does not
have a way to declare a pointer to a function (like C) or to declare a
special kind of variable that can be used to hold the name of a function
(like <CODE>EXTERNAL</CODE> in Fortran).  Instead, you must refer to functions
by name, and use <CODE>feval</CODE> to call them.
</DL>

</P>
<P>
Here is a simple-minded function using <CODE>feval</CODE> that finds the root
of a user-supplied function of one variable using Newton's method.

</P>

<PRE>
<A NAME="IDX390"></A><A NAME="IDX391"></A>function result = newtroot (fname, x)

# usage: newtroot (fname, x)
#
#   fname : a string naming a function f(x).
#   x     : initial guess

  delta = tol = sqrt (eps);
  maxit = 200;
  fx = feval (fname, x);
  for i = 1:maxit
    if (abs (fx) &#60; tol)
      result = x;
      return;
    else
      fx_new = feval (fname, x + delta);
      deriv = (fx_new - fx) / delta;
      x = x - fx / deriv;
      fx = fx_new;
    endif
  endfor

  result = x;

endfunction
</PRE>

<P>
Note that this is only meant to be an example of calling user-supplied
functions and should not be taken too seriously.  In addition to using a
more robust algorithm, any serious code would check the number and type
of all the arguments, ensure that the supplied function really was a
function, etc.  See See section <A HREF="octave_5.html#SEC52">Predicates for Numeric Objects</A>, for example,
for a list of predicates for numeric objects, and See section <A HREF="octave_8.html#SEC61">Status of Variables</A>, for a description of the <CODE>exist</CODE> function.

</P>
<P><HR><P>
Go to the <A HREF="octave_1.html">first</A>, <A HREF="octave_9.html">previous</A>, <A HREF="octave_11.html">next</A>, <A HREF="octave_40.html">last</A> section, <A HREF="octave_toc.html">table of contents</A>.
</BODY>
</HTML>