Book Image

GNU Octave Beginner's Guide

By : Jesper Schmidt Hansen
Book Image

GNU Octave Beginner's Guide

By: Jesper Schmidt Hansen

Overview of this book

Today, scientific computing and data analysis play an integral part in most scientific disciplines ranging from mathematics and biology to imaging processing and finance. With GNU Octave you have a highly flexible tool that can solve a vast number of such different problems as complex statistical analysis and dynamical system studies.The GNU Octave Beginner's Guide gives you an introduction that enables you to solve and analyze complicated numerical problems. The book is based on numerous concrete examples and at the end of each chapter you will find exercises to test your knowledge. It's easy to learn GNU Octave, with the GNU Octave Beginner's Guide to hand.Using real-world examples the GNU Octave Beginner's Guide will take you through the most important aspects of GNU Octave. This practical guide takes you from the basics where you are introduced to the interpreter to a more advanced level where you will learn how to build your own specialized and highly optimized GNU Octave toolbox package. The book starts by introducing you to work variables like vectors and matrices, demonstrating how to perform simple arithmetic operations on these objects before explaining how to use some of the simple functionality that comes with GNU Octave, including plotting. It then goes on to show you how to write new functionality into GNU Octave and how to make a toolbox package to solve your specific problem. Finally, it demonstrates how to optimize your code and link GNU Octave with C and C++ code enabling you to solve even the most computationally demanding tasks. After reading GNU Octave Beginner's Guide you will be able to use and tailor GNU Octave to solve most numerical problems and perform complicated data analysis with ease.
Table of Contents (15 chapters)
GNU Octave
Credits
About the Author
About the Reviewers
www.PacktPub.com
Preface

Time for action - putting together mathematical functions


  1. 1. Let us try to calculate the range of the function:

(3.3)

octave:12> x = 0.5;
octave:13> f = exp(-5*sqrt(x))*sin(2*pi*x)
f = 3.5689e-018
  1. 2. In a more useful vector form:

octave:14> x = [0:0.1:1];
octave:15> f = exp(-5*sqrt(x)).*sin(2*pi*x)
f =
Columns 1 through 7:
0.00000 0.12093 0.10165 0.01650 0.02488 0.00000 -0.01222
Columns 8 through 11:
-0.01450 -0.01086 -0.00512 -0.00000

What just happened?

It should be clear what Commands 12 and 13 do. In Command 15, we must use the element-wise .* operator. Had we not done so, Octave would try to perform a matrix multiplication between the vectors given by exp(-5*sqrt(x)) and sin(2*pi*x), which is not defined, and not what we want either.

We could also have used the element-wise operator in Command 13 when x is a scalar; that is, Command 14 is a generalized version that works for both scalars and vector and matrix arrays.

Note

Whenever possible, always make generalized versions of...