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 - using imagesc


  1. 1. Let us first consider a one dimensional problem with 20 grid points. The coefficient matrix is generated by calling cmat_1d:

octave:5> A=cmat_1d(20);
  1. 2. To set the gray colour map, use (also see Chapter 3):

octave:6> colormap("gray");
  1. 3. To make a scaled image of the matrix, we use:

octave:7> imagesc(full(A))
  • The result is shown in the left-hand side figure below.

What just happened?

Notice that in Command 7, we use the full matrix of A because imagesc does not currently support sparse matrices. It is easy to see that matrix elements indeed follow the matrix given by Equation (6.14).

For the two-dimensional problem, we can do the same. The result is shown in the right figure for a domain discretized into a 5 x 5 grid. For this grid size, we have 16 boundary points which are given by ones (white) on the matrix diagonal and only 9 interior points given by -4 (black)—see Equation (6.17). The so-called "fringes" on each side of the diagonal represent...