File: [local] / OpenXM_contrib / gnuplot / Attic / bf_test.c (download)
Revision 1.1.1.2 (vendor branch), Sat Jan 22 14:16:03 2000 UTC (24 years, 8 months ago) by maekawa
Branch: GNUPLOT
CVS Tags: maekawa-ipv6, VERSION_3_7_3, VERSION_3_7_1, RELEASE_20000124, RELEASE_1_2_3, RELEASE_1_2_2_KNOPPIX_b, RELEASE_1_2_2_KNOPPIX, RELEASE_1_2_2, RELEASE_1_2_1, RELEASE_1_1_3, RELEASE_1_1_2 Changes since 1.1.1.1: +1 -1
lines
Import gnuplot 3.7.1
|
#ifndef lint
static char *RCSid = "$Id: bf_test.c,v 1.9 1998/12/02 18:38:13 lhecking Exp $";
#endif
/*
* Test routines for binary files
* cc bf_test.c -o bf_test binary_files.o -lm
*
* Copyright (c) 1992 Robert K. Cunningham, MIT Lincoln Laboratory
*
*/
/* Note that this file is not compiled into gnuplot, and so
* its more-restrictive copyright need not apply to gnuplot
* as a whole. (I think.)
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include "ansichek.h"
#include "stdfn.h"
#define GPFAR /**/
#include "binary.h"
#include "alloc.h"
void int_error __PROTO((char *error_text, int dummy));
void FreeHelp __PROTO((void));
float function __PROTO((int p, double x, double y));
typedef struct {
float xmin, xmax;
float ymin, ymax;
} range;
#define NUM_PLOTS 2
range TheRange[] = {{-3,3,-2,2},
{-3,3,-3,3},
{-3,3,-3,3}};/* Sampling rate causes this to go from -3:6*/
/*---- Stubs to make this work without including huge libraries ----*/
void int_error(error_text, dummy)
char *error_text;
int dummy;
{
fprintf(stderr, "Fatal error..\n%s\n...now exiting to system ...\n",
error_text);
exit(EXIT_FAILURE);
}
void FreeHelp()
{
}
/*---- End of stubs ----*/
float function(p, x, y)
int p;
double x, y;
{
float t;
switch (p) {
case 0:
t = 1.0 / (x * x + y * y + 1.0);
break;
case 1:
t = sin(x * x + y * y) / (x * x + y * y);
if (t > 1.0)
t = 1.0;
break;
case 2:
t = sin(x * x + y * y) / (x * x + y * y);
/* sinc modulated sinc */
t *= sin(4. * (x * x + y * y)) / (4. * (x * x + y * y));
if (t > 1.0)
t = 1.0;
break;
default:
fprintf(stderr, "Unknown function\n");
break;
}
return t;
}
#define ISOSAMPLES (double)5
int main()
{
int plot;
int i, j;
float x, y;
float *rt, *ct;
float **m;
int xsize, ysize;
char buf[256];
FILE *fout;
/* Create a few standard test interfaces */
for (plot = 0; plot < NUM_PLOTS; plot++) {
xsize = (TheRange[plot].xmax - TheRange[plot].xmin) * ISOSAMPLES + 1;
ysize = (TheRange[plot].ymax - TheRange[plot].ymin) * ISOSAMPLES + 1;
rt = vector(0, xsize - 1);
ct = vector(0, ysize - 1);
m = matrix(0, xsize - 1, 0, ysize - 1);
for (y = TheRange[plot].ymin, j = 0; j < ysize; j++, y += 1.0 / (double) ISOSAMPLES) {
ct[j] = y;
}
for (x = TheRange[plot].xmin, i = 0; i < xsize; i++, x += 1.0 / (double) ISOSAMPLES) {
rt[i] = x;
for (y = TheRange[plot].ymin, j = 0; j < ysize; j++, y += 1.0 / (double) ISOSAMPLES) {
m[i][j] = function(plot, x, y);
}
}
sprintf(buf, "binary%d", plot + 1);
if (!(fout = fopen(buf, "wb")))
int_error("Could not open file", 0);
else {
fwrite_matrix(fout, m, 0, xsize - 1, 0, ysize - 1, rt, ct);
}
free_vector(rt, 0, ysize - 1);
free_vector(ct, 0, xsize - 1);
free_matrix(m, 0, xsize - 1, 0, ysize - 1);
}
/* Show that it's ok to vary sampling rate, as long as x1<x2, y1<y2... */
xsize = (TheRange[plot].xmax - TheRange[plot].xmin) * ISOSAMPLES + 1;
ysize = (TheRange[plot].ymax - TheRange[plot].ymin) * ISOSAMPLES + 1;
rt = vector(0, xsize - 1);
ct = vector(0, ysize - 1);
m = matrix(0, xsize - 1, 0, ysize - 1);
for (y = TheRange[plot].ymin, j = 0; j < ysize; j++, y += 1.0 / (double) ISOSAMPLES) {
ct[j] = y > 0 ? 2 * y : y;
}
for (x = TheRange[plot].xmin, i = 0; i < xsize; i++, x += 1.0 / (double) ISOSAMPLES) {
rt[i] = x > 0 ? 2 * x : x;
for (y = TheRange[plot].ymin, j = 0; j < ysize; j++, y += 1.0 / (double) ISOSAMPLES) {
m[i][j] = function(plot, x, y);
}
}
sprintf(buf, "binary%d", plot + 1);
if (!(fout = fopen(buf, "wb")))
int_error("Could not open file", 0);
else {
fwrite_matrix(fout, m, 0, xsize - 1, 0, ysize - 1, rt, ct);
}
free_vector(rt, 0, ysize - 1);
free_vector(ct, 0, xsize - 1);
free_matrix(m, 0, xsize - 1, 0, ysize - 1);
exit(EXIT_SUCCESS);
}