view examples/embedded.cc @ 14163:55d41048ea68 stable

update FCN_FILES list in test/Makefile.am * test/Makefile.am (FCN_FILES): Rename test_contin.m to test_line_contine.m in the list. Include test_index.m and test_logical_index.m in the list. Remove test_index-wfi-f.m, test_index-wfi-t.m, test_logical-wfi-f.m, test_logical-wfi-t.m from the list.
author John W. Eaton <jwe@octave.org>
date Fri, 06 Jan 2012 13:46:56 -0500
parents db1f49eaba6b
children 3c5e6971064c 27a6bb1a2f74
line wrap: on
line source

#include <iostream>
#include <octave/oct.h>
#include <octave/octave.h>
#include <octave/parse.h>

int
main (void)
{
  string_vector argv (2);
  argv(0) = "embedded";
  argv(1) = "-q";

  octave_main (2, argv.c_str_vec(), 1);

  octave_idx_type n = 2;
  Matrix a_matrix = Matrix (1, 2);

  std::cout << "GCD of [";
  for (octave_idx_type i = 0; i < n; i++)
    {
      a_matrix (i) = 5 * (i + 1);
      if (i != 0)
        std::cout << ", " << 5 * (i + 2);
      else
        std::cout << 5 * (i + 2);
    }
  std::cout << "] is ";

  octave_value_list in = octave_value (a_matrix);
  octave_value_list out = feval ("gcd", in, 1);

  if (!error_state && out.length () > 0)
    {
      a_matrix = out(0).matrix_value ();
      if (a_matrix.numel () == 1)
        std::cout << a_matrix(0) << "\n";
      else
        std::cout << "invalid\n";
    }
  else
    std::cout << "invalid\n";

  return 0;
}