gsl/wrk.patch

377 lines
10 KiB
Diff
Raw Normal View History

2013-01-23 16:06:28 +00:00
diff -up wrk/ode-initval2/control.c.wrk wrk/ode-initval2/control.c
--- wrk/ode-initval2/control.c.wrk 2013-01-23 17:06:22.402902397 +0100
2013-01-23 16:37:05 +00:00
+++ wrk/ode-initval2/control.c 2013-01-23 17:36:43.945159375 +0100
2013-01-23 16:06:28 +00:00
@@ -78,8 +78,11 @@ gsl_odeiv2_control_hadjust (gsl_odeiv2_c
const double y[], const double yerr[],
const double dydt[], double *h)
{
2013-01-23 16:07:41 +00:00
- return c->type->hadjust (c->state, s->dimension, s->type->order (s->state),
2013-01-23 16:37:05 +00:00
+// printf("pred hadjust\n%d\n", s->type->order (s->state));
2013-01-23 16:07:41 +00:00
+ int ret = c->type->hadjust (c->state, s->dimension, s->type->order (s->state),
2013-01-23 16:06:28 +00:00
y, yerr, dydt, h);
2013-01-23 16:37:05 +00:00
+ // printf("po hadjust\n%d\n", s->type->order (s->state));
2013-01-23 16:07:41 +00:00
+return ret;
2013-01-23 16:06:28 +00:00
}
int
2013-01-18 15:03:01 +00:00
diff -up wrk/ode-initval2/cstd.c.wrk wrk/ode-initval2/cstd.c
--- wrk/ode-initval2/cstd.c.wrk 2013-01-18 16:02:19.566833381 +0100
2013-01-23 16:37:05 +00:00
+++ wrk/ode-initval2/cstd.c 2013-01-23 17:37:01.010263153 +0100
2013-01-21 10:18:49 +00:00
@@ -80,11 +80,14 @@ std_control_init (void *vstate,
return GSL_SUCCESS;
}
+#define PD(fl) printf("%lu\n", *((unsigned long *)&(fl)))
+
static int
std_control_hadjust (void *vstate, size_t dim, unsigned int ord,
2013-01-18 15:03:01 +00:00
const double y[], const double yerr[], const double yp[],
double *h)
{
2013-01-23 16:37:05 +00:00
+//printf("hadjustim\n");
2013-01-18 15:03:01 +00:00
std_control_state_t *state = (std_control_state_t *) vstate;
const double eps_abs = state->eps_abs;
2013-01-21 12:20:23 +00:00
@@ -109,9 +112,18 @@ std_control_hadjust (void *vstate, size_
2013-01-18 15:10:40 +00:00
if (rmax > 1.1)
{
2013-01-22 09:54:36 +00:00
+// printf("skracujem\n");
2013-01-18 15:10:40 +00:00
/* decrease step, no more than factor of 5, but a fraction S more
than scaling suggests (for better accuracy) */
2013-01-21 10:28:33 +00:00
- double r = S / pow (rmax, 1.0 / ord);
+ double pom = pow (rmax, 1.0 / ord);
+ double r = S / pom;
2013-01-22 09:54:36 +00:00
+// printf("ord %d", ord);
+//printf ("S\n");
+//PD(S);
+//printf("rmax\n");
+//PD(rmax);
2013-01-22 11:26:48 +00:00
+//printf("pom\n");
+//PD(pom);
2013-01-21 10:28:33 +00:00
2013-01-21 10:16:56 +00:00
if (r < 0.2)
r = 0.2;
2013-01-21 12:20:23 +00:00
@@ -122,6 +134,7 @@ std_control_hadjust (void *vstate, size_
2013-01-18 15:10:40 +00:00
}
else if (rmax < 0.5)
{
2013-01-22 09:54:36 +00:00
+// printf("predlzujem\n");
2013-01-18 15:10:40 +00:00
/* increase step, no more than factor of 5 */
double r = S / pow (rmax, 1.0 / (ord + 1.0));
2013-01-21 12:20:23 +00:00
@@ -137,6 +150,7 @@ std_control_hadjust (void *vstate, size_
2013-01-21 10:00:04 +00:00
}
else
{
2013-01-22 09:54:36 +00:00
+// printf("nemenim\n");
2013-01-21 10:00:04 +00:00
/* no change */
return GSL_ODEIV_HADJ_NIL;
}
2013-01-17 17:50:09 +00:00
diff -up wrk/ode-initval2/evolve.c.wrk wrk/ode-initval2/evolve.c
--- wrk/ode-initval2/evolve.c.wrk 2013-01-17 18:48:06.473062671 +0100
2013-01-23 16:37:05 +00:00
+++ wrk/ode-initval2/evolve.c 2013-01-23 17:36:26.634053595 +0100
2013-01-17 17:50:09 +00:00
@@ -28,6 +28,8 @@
#include "odeiv_util.h"
+#define PD(fl) printf("%lu\n", *((unsigned long *)&(fl)))
+
gsl_odeiv2_evolve *
gsl_odeiv2_evolve_alloc (size_t dim)
{
@@ -118,6 +120,8 @@ gsl_odeiv2_evolve_apply (gsl_odeiv2_evol
const gsl_odeiv2_system * dydt,
double *t, double t1, double *h, double y[])
{
2013-01-22 09:54:36 +00:00
+// printf("vstup do apply\n");
+// PD(*h);
2013-01-17 17:50:09 +00:00
const double t0 = *t;
double h0 = *h;
int step_status;
2013-01-17 18:35:20 +00:00
@@ -151,7 +155,8 @@ gsl_odeiv2_evolve_apply (gsl_odeiv2_evol
}
try_step:
-
2013-01-22 09:54:36 +00:00
+//printf("po navasti\n");
+//PD(h0);
2013-01-17 18:35:20 +00:00
if ((dt >= 0.0 && h0 > dt) || (dt < 0.0 && h0 < dt))
{
h0 = dt;
2013-01-23 16:30:32 +00:00
@@ -164,9 +169,11 @@ try_step:
if (step->type->can_use_dydt_in)
{
+ printf("pred stepapply vonku\n%d\n", step->type->order (step->state));
2013-01-23 16:26:53 +00:00
step_status =
gsl_odeiv2_step_apply (step, t0, h0, y, e->yerr, e->dydt_in,
e->dydt_out, dydt);
+ printf("po stepapply vonku\n%d\n", step->type->order (step->state));
}
else
{
2013-01-23 16:30:32 +00:00
@@ -206,6 +213,7 @@ try_step:
2013-01-17 18:05:16 +00:00
DBL_MEMCPY (y, e->y0, dydt->dimension);
e->failed_steps++;
2013-01-23 16:37:05 +00:00
+ //printf("skacem prvy\n");
2013-01-17 18:05:16 +00:00
goto try_step;
}
else
2013-01-23 16:30:32 +00:00
@@ -228,16 +236,19 @@ try_step:
2013-01-17 18:47:30 +00:00
{
*t = t0 + h0;
}
-
2013-01-22 09:54:36 +00:00
+//printf("pred con\n");
+//PD(h0);
2013-01-17 18:47:30 +00:00
if (con != NULL)
{
/* Check error and attempt to adjust the step. */
2013-01-23 16:10:25 +00:00
double h_old = h0;
-
2013-01-23 16:37:05 +00:00
+// printf("pred hadjust vonku\n%d\n", step->type->order (step->state));
2013-01-17 19:00:38 +00:00
const int hadjust_status
=
gsl_odeiv2_control_hadjust (con, step, y, e->yerr, e->dydt_out, &h0);
2013-01-22 09:54:36 +00:00
+//printf("po hadjust\n");
+//PD(h0);
2013-01-17 19:00:38 +00:00
if (hadjust_status == GSL_ODEIV_HADJ_DEC)
{
2013-01-23 16:30:32 +00:00
@@ -254,6 +265,8 @@ try_step:
2013-01-17 18:05:16 +00:00
DBL_MEMCPY (y, e->y0, dydt->dimension);
e->failed_steps++;
2013-01-23 16:37:05 +00:00
+//printf("skacem druhy\n");
2013-01-22 09:54:36 +00:00
+//PD(h0);
2013-01-17 18:05:16 +00:00
goto try_step;
}
else
2013-01-23 16:30:32 +00:00
@@ -279,6 +292,9 @@ try_step:
2013-01-17 17:50:09 +00:00
*h = h0;
}
2013-01-22 09:54:36 +00:00
+// printf("vystup z apply\n");
+// PD(*h);
2013-01-17 17:50:09 +00:00
+
return step_status;
}
2013-01-16 14:03:45 +00:00
diff -up wrk/ode-initval2/msbdf.c.wrk wrk/ode-initval2/msbdf.c
2013-01-17 14:12:43 +00:00
--- wrk/ode-initval2/msbdf.c.wrk 2013-01-09 10:35:45.259960403 +0100
2013-01-23 16:52:22 +00:00
+++ wrk/ode-initval2/msbdf.c 2013-01-23 17:52:12.141920679 +0100
2013-01-17 14:56:14 +00:00
@@ -43,6 +43,8 @@
framework.
*/
+#define PD(fl) printf("%lu\n", *((unsigned long *)&(fl)))
+
#include <config.h>
#include <stdlib.h>
#include <string.h>
@@ -116,7 +118,6 @@ static void *
2013-01-17 14:12:43 +00:00
msbdf_alloc (size_t dim)
{
msbdf_state_t *state = (msbdf_state_t *) malloc (sizeof (msbdf_state_t));
-
if (state == 0)
{
GSL_ERROR_NULL ("failed to allocate space for msbdf_state", GSL_ENOMEM);
2013-01-17 14:56:14 +00:00
@@ -611,6 +612,15 @@ msbdf_calccoeffs (const size_t ord, cons
printf ("errcoeff=%.5e\n", *errcoeff);
#endif
2013-01-17 15:23:03 +00:00
+/*PD(l[0]);
2013-01-17 14:56:14 +00:00
+PD(l[1]);
+PD(*errcoeff);
+PD(*ordm1coeff);
+PD(*ordp1coeff);
+PD(*ordp2coeff);
+PD(*gamma);
+printf("\n");
2013-01-17 15:23:03 +00:00
+*/
2013-01-17 14:56:14 +00:00
return GSL_SUCCESS;
}
2013-01-17 17:25:54 +00:00
@@ -1082,7 +1092,8 @@ msbdf_apply (void *vstate, size_t dim, d
2013-01-17 15:52:25 +00:00
const gsl_odeiv2_system * sys)
{
/* Carries out a step by BDF linear multistep methods. */
-
2013-01-22 09:54:36 +00:00
+//printf("zaciatok msbdf\n");
+//PD(h);
2013-01-17 15:52:25 +00:00
msbdf_state_t *state = (msbdf_state_t *) vstate;
double *const z = state->z;
2013-01-23 14:46:21 +00:00
@@ -1109,7 +1120,7 @@ msbdf_apply (void *vstate, size_t dim, d
const size_t max_failcount = 3;
size_t i;
-
+printf("ord at msbdf start\n%d\n", ord);
#ifdef DEBUG
{
size_t di;
2013-01-23 14:17:53 +00:00
@@ -1329,7 +1340,7 @@ msbdf_apply (void *vstate, size_t dim, d
{
const int deltaord = ord - ordprev[0];
-
2013-01-23 14:26:59 +00:00
+printf("ord\n%d\n%d\n", ord, ordprev[0]);
2013-01-23 14:17:53 +00:00
if (deltaord > 1 || deltaord < -1)
{
printf ("-- order change %d\n", deltaord);
2013-01-17 17:25:54 +00:00
@@ -1466,7 +1477,10 @@ msbdf_apply (void *vstate, size_t dim, d
2013-01-17 15:23:03 +00:00
/* Calculate polynomial coefficients (l), error coefficient and
auxiliary coefficients
*/
-
2013-01-17 15:52:25 +00:00
+/*printf("%d\n", ord);
2013-01-17 15:24:04 +00:00
+printf("%lu\n", state->ordwait);
2013-01-17 15:23:03 +00:00
+PD(h);
2013-01-17 15:52:25 +00:00
+PD(hprev[0]);*/
2013-01-17 15:23:03 +00:00
msbdf_calccoeffs (ord, state->ordwait, h, hprev, l, &errcoeff,
&ordm1coeff, &ordp1coeff, &ordp2coeff, &gamma);
2013-01-17 14:16:32 +00:00
2013-01-23 16:52:22 +00:00
@@ -1619,6 +1633,7 @@ msbdf_apply (void *vstate, size_t dim, d
/* Consider and execute order change for next step */
+printf("ord before eval\n%d\n", state->ord);
if (state->ordwait == 0)
{
msbdf_eval_order (abscor, tempvec, svec, errcoeff, dim, errlev,
@@ -1675,7 +1690,9 @@ msbdf_apply (void *vstate, size_t dim, d
2013-01-17 17:25:54 +00:00
printf ("-- nJ=%d, nM=%d\n", (int) state->nJ, (int) state->nM);
#endif
}
-
2013-01-23 15:00:58 +00:00
+printf("koniec msbdf, ord:\n%d\n", ord);
2013-01-23 16:44:17 +00:00
+printf("ord at msbdf end\n%d\n", state->ord);
2013-01-22 09:54:36 +00:00
+//PD(h);
2013-01-17 17:25:54 +00:00
return GSL_SUCCESS;
}
2013-01-16 14:03:45 +00:00
diff -up wrk/ode-initval2/test.c.wrk wrk/ode-initval2/test.c
--- wrk/ode-initval2/test.c.wrk 2013-01-09 10:48:22.051415928 +0100
2013-01-23 15:21:49 +00:00
+++ wrk/ode-initval2/test.c 2013-01-23 16:15:54.368720700 +0100
2013-01-16 14:03:45 +00:00
@@ -923,6 +923,18 @@ rhs_ringmod (double t, const double y[],
f[13] = (-y[0] + uin1 - (ri + rg1) * y[13]) / ls1;
f[14] = (-y[1] - (rc + rg1) * y[14]) / ls1;
+ /*int i;
+ printf("temp states\n");
+ for (i=0; i<15; ++i) {
+
+ printf("%lu\n", *((unsigned long *)(&(y[i]))));
+ }
+
+ printf("%lu\n", *((unsigned long *)(&(rg2))));
+ printf("%lu\n", *((unsigned long *)(&(ls2))));
+ printf("%lu\n", *((unsigned long *)(&(rg3))));
+ printf("%lu\n", *((unsigned long *)(&(ls3))));
+*/
return GSL_SUCCESS;
}
2013-01-17 12:24:50 +00:00
2013-01-17 16:13:11 +00:00
@@ -1239,6 +1251,8 @@ test_evolve_system (const gsl_odeiv2_ste
gsl_odeiv2_driver_free (d);
}
+#define PD(fl) printf("%lu\n", *((unsigned long *)&(fl)))
+
int
sys_driver (const gsl_odeiv2_step_type * T,
const gsl_odeiv2_system * sys,
@@ -1264,10 +1278,23 @@ sys_driver (const gsl_odeiv2_step_type *
2013-01-17 13:20:57 +00:00
nfe = 0;
nje = 0;
+ int poc=0;
while (t < t1)
{
2013-01-23 15:21:49 +00:00
+ // printf("pred evolve apply\n");
2013-01-17 17:25:54 +00:00
+// PD(h);
2013-01-17 13:20:57 +00:00
s = gsl_odeiv2_evolve_apply (d->e, d->c, d->s, sys, &t, t1, &h, y);
2013-01-17 14:18:50 +00:00
2013-01-23 15:21:49 +00:00
+//printf("po evolve apply\n");
2013-01-23 14:26:59 +00:00
+ printf("\nkrok %d\n", ++poc);
2013-01-17 17:25:54 +00:00
+//PD(h);
2013-01-22 12:01:40 +00:00
+/* int k;
2013-01-17 13:20:57 +00:00
+ for (k=0; k<15; ++k) {
2013-01-17 13:43:43 +00:00
+ printf(" %lu\n",(*(unsigned long int *)(&(y[k]))));
2013-01-17 13:20:57 +00:00
+ }
2013-01-17 13:43:43 +00:00
+ printf(" %lu\n",(*(unsigned long int *)(&t)));
2013-01-22 12:01:40 +00:00
+*/
2013-01-17 13:20:57 +00:00
+ //printf("\n");
#ifdef DEBUG
printf ("%.5e %.5e %.5e %d\n", t, y[0], y[1],
gsl_odeiv2_step_order (d->s));
2013-01-22 11:29:10 +00:00
@@ -2003,10 +2030,11 @@ test_extreme_problems (void)
2013-01-17 13:20:57 +00:00
2013-01-22 11:29:10 +00:00
for (i = 0; steppers[i] != 0; i++)
2013-01-17 13:20:57 +00:00
{
2013-01-22 11:29:10 +00:00
+ // printf("spustam driver p=%ld i=%ld\n", p, i);
2013-01-17 13:20:57 +00:00
int s = sys_driver (steppers[i], prob[p], start[p], end[p],
initstepsize[p], &y[sd[p] * i],
epsabs[p], epsrel[p], probname[p]);
-
2013-01-22 11:29:10 +00:00
+ //printf("koniec drivera\n");
2013-01-17 13:20:57 +00:00
if (s != GSL_SUCCESS)
{
printf ("start=%.5e, initstepsize=%.5e\n", start[p],
2013-01-22 11:29:10 +00:00
@@ -2018,7 +2046,7 @@ test_extreme_problems (void)
/* Compare results */
- for (i = 1; steppers[i] != 0; i++)
+ for (i = 0; steppers[i] != 0; i++)
for (k = 0; k < sd[p]; k++)
{
const double val1 = y[k];
2013-01-17 16:13:11 +00:00
@@ -2450,7 +2478,7 @@ main (void)
2013-01-17 13:20:57 +00:00
/* Basic tests for all steppers */
- for (i = 0; p[i].type != 0; i++)
+ /*for (i = 0; p[i].type != 0; i++)
{
test_stepper (p[i].type);
}
2013-01-17 16:13:11 +00:00
@@ -2469,9 +2497,9 @@ main (void)
2013-01-17 13:20:57 +00:00
test_stepsize_fail (p[i].type, p[i].h);
test_user_break (p[i].type, p[i].h);
}
-
+*/
/* Derivative test for explicit steppers */
-
+/*
explicit_stepper[0].type = gsl_odeiv2_step_rk4;
explicit_stepper[0].h = 1.0e-3;
explicit_stepper[1].type = gsl_odeiv2_step_rk2;
2013-01-17 16:13:11 +00:00
@@ -2491,16 +2519,16 @@ main (void)
2013-01-17 13:20:57 +00:00
test_stepfn (explicit_stepper[i].type);
test_stepfn2 (explicit_stepper[i].type);
}
-
+*/
/* Special tests */
- test_nonstiff_problems ();
+ // test_nonstiff_problems ();
- test_stiff_problems ();
+ // test_stiff_problems ();
test_extreme_problems ();
- test_driver ();
+ //test_driver ();
exit (gsl_test_summary ());
}