#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <gsl/gsl_sf_bessel.h>

int main() {
	int lMax;
	while (1 == scanf("%d", &lMax)){
		double x;
		if (1 != scanf(" %lf", &x))
			abort();
		double orig[lMax+1], gsl[lMax+2], relerr[lMax+1];
		for(int l=0; l <= lMax; ++l) 
			if (1 != scanf(" %lf", orig+l))
				abort();
#if defined JTEST || defined DJTEST
		if(gsl_sf_bessel_jl_array(lMax+1,x,gsl))
#elif defined YTEST || defined DYTEST
		if(gsl_sf_bessel_yl_array(lMax+1,x,gsl))
#else
		if(gsl_sf_bessel_jl_steed_array(lMax+1,x,gsl))
#endif
			abort();
#if defined DJTEST || defined DYTEST || defined DJTEST_STEED
#if 1
		for (int l = 0; l <= lMax; ++l)
			gsl[l] = -gsl[l+1] + (l/x) * gsl[l];
#else
	// todo varianta 10.51.2
#endif			
#endif
		for (int l = 0; l <= lMax; ++l)
			relerr[l] = fabs(gsl[l] - orig[l]) / (fabs(gsl[l]) + fabs(orig[l])) * 2;
		printf("x = %.16g\n", x);
		printf("orig: ");
		for (int l = 0; l <= lMax; ++l)
			printf("%.16g ", orig[l]);
		printf("\ngsl:  ");
		for (int l = 0; l <= lMax; ++l)
			printf("%.16g ", gsl[l]);
		printf("\nrerr:  ");
		for (int l = 0; l <= lMax; ++l)
			printf("%.16g ", relerr[l]);
		putchar('\n');
	}
}