/*
sf_psi.c
Ruby/GSL: Ruby extension library for GSL (GNU Scientific Library)
(C) Copyright 2001-2006 by Yoshiki Tsunesada
Ruby/GSL is free software: you can redistribute it and/or modify it
under the terms of the GNU General Public License.
This library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY.
*/
#include "rb_gsl_sf.h"
static VALUE rb_gsl_sf_psi_int(VALUE obj, VALUE n)
{
return rb_gsl_sf_eval1_int(gsl_sf_psi_int, n);
}
static VALUE rb_gsl_sf_psi_int_e(VALUE obj, VALUE n)
{
return rb_gsl_sf_eval_e_int(gsl_sf_psi_int_e, n);
}
static VALUE rb_gsl_sf_psi(VALUE obj, VALUE x)
{
return rb_gsl_sf_eval1(gsl_sf_psi, x);
}
static VALUE rb_gsl_sf_psi_e(VALUE obj, VALUE x)
{
return rb_gsl_sf_eval_e(gsl_sf_psi_e, x);
}
#ifdef GSL_1_6_LATER
static VALUE rb_gsl_sf_psi_1(VALUE obj, VALUE x)
{
return rb_gsl_sf_eval1(gsl_sf_psi_1, x);
}
#endif
#ifdef GSL_1_4_9_LATER
static VALUE rb_gsl_sf_psi_1_e(VALUE obj, VALUE x)
{
return rb_gsl_sf_eval_e(gsl_sf_psi_1_e, x);
}
#endif
static VALUE rb_gsl_sf_psi_1piy(VALUE obj, VALUE x)
{
return rb_gsl_sf_eval1(gsl_sf_psi_1piy, x);
}
static VALUE rb_gsl_sf_psi_1piy_e(VALUE obj, VALUE x)
{
return rb_gsl_sf_eval_e(gsl_sf_psi_1piy_e, x);
}
static VALUE rb_gsl_sf_psi_1_int(VALUE obj, VALUE n)
{
return rb_gsl_sf_eval1_int(gsl_sf_psi_1_int, n);
}
static VALUE rb_gsl_sf_psi_1_int_e(VALUE obj, VALUE n)
{
return rb_gsl_sf_eval_e_int(gsl_sf_psi_1_int_e, n);
}
static VALUE rb_gsl_sf_psi_n(VALUE obj, VALUE m, VALUE x)
{
return rb_gsl_sf_eval_int_double(gsl_sf_psi_n, m, x);
}
static VALUE rb_gsl_sf_psi_n_e(VALUE obj, VALUE m, VALUE x)
{
return rb_gsl_sf_eval_e_int_double(gsl_sf_psi_n_e, m, x);
}
void Init_gsl_sf_psi(VALUE module)
{
rb_define_module_function(module, "psi_int", rb_gsl_sf_psi_int, 1);
rb_define_module_function(module, "psi_int_e", rb_gsl_sf_psi_int_e, 1);
rb_define_module_function(module, "psi_1piy", rb_gsl_sf_psi_1piy, 1);
rb_define_module_function(module, "psi_1piy_e", rb_gsl_sf_psi_1piy_e, 1);
rb_define_module_function(module, "psi_1_int", rb_gsl_sf_psi_1_int, 1);
rb_define_module_function(module, "psi_1_int_e", rb_gsl_sf_psi_1_int_e, 1);
rb_define_module_function(module, "psi_n", rb_gsl_sf_psi_n, 2);
rb_define_module_function(module, "psi_n_e", rb_gsl_sf_psi_n_e, 2);
rb_define_module_function(module, "psi", rb_gsl_sf_psi, 1);
rb_define_module_function(module, "psi_e", rb_gsl_sf_psi_e, 1);
#ifdef GSL_1_6_LATER
rb_define_module_function(module, "psi_1", rb_gsl_sf_psi_1, 1);
#endif
#ifdef GSL_1_4_9_LATER
rb_define_module_function(module, "psi_1_e", rb_gsl_sf_psi_1_e, 1);
#endif
}
syntax highlighted by Code2HTML, v. 0.9.1