Sha256: 4ac9f4d4b5bcd31c784b86a28956c1878dc419d4d5556da015aaef8a0478368b

Contents?: true

Size: 1.04 KB

Versions: 1

Compression:

Stored size: 1.04 KB

Contents

#include "hilbert.h"
#include <stdio.h>
#define Need_Float(x) do {if (!RB_TYPE_P(x, T_FLOAT)) {(x) = rb_to_float(x);}} while(0)
#define GET_FLOAT(x) Need_Float(x);(x) = RFLOAT_VALUE(x)

double func(double x)
{
  return((x * x) * 3);
}

static VALUE
rb_func(VALUE self, VALUE x)
{
  GET_FLOAT(x);
  return(DBL2NUM((x * x)/2));
}


static VALUE
execute(VALUE self, VALUE a, VALUE b, VALUE n)
{
  GET_FLOAT(a);
  GET_FLOAT(b);
  GET_FLOAT(n);

  int i;
  double s1=0.0, s2=0.0, d;
  double x, y[n+1];
  d=(b-a)/(double)n;
  for(i=0; i<=n; i++)
  {
    x=(double)i*d+a;
    y[i]=func(x);
  }
  for(i=1; i<=n-1; i+=2)
  {
    s1+=y[i];
  }
  for(i=2; i<=n-2; i+=2)
  {
    s2+=y[i];
  }

  double s=(y[0]+4.0*s1+2.0*s2+y[n])*d/3.0;

  return DBL2NUM(s);
}



void
Init_hilbert(void)
{
  VALUE rb_mQMatrix = rb_define_class("QMatrix", rb_cObject);
  rb_define_method(rb_mQMatrix, "execute", execute, 3);
  rb_define_method(rb_mQMatrix, "func", rb_func, 1);
}

// VALUE rb_mQMatrix;

// void
// Init_q_matrix(void)
// {
//   rb_mQMatrix = rb_define_module("QMatrix");
// }

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
hilbert-0.0.2700001 ext/hilbert/hilbert.c