ngspice/src/frontend/interp.c

62 lines
1.8 KiB
C

/**********
Copyright 1990 Regents of the University of California. All rights reserved.
Author: 1985 Wayne A. Christopher, U. C. Berkeley CAD Group
**********/
/*
* Polynomial interpolation code.
*/
#include "ngspice/ngspice.h"
#include "ngspice/cpdefs.h"
#include "ngspice/ftedefs.h"
#include "ngspice/dvec.h"
#include "interp.h"
void
lincopy(struct dvec *ov, double *newscale, int newlen, struct dvec *oldscale)
{
if (!isreal(ov)) {
fprintf(cp_err, "Warning: vector %s is a complex vector - "
"complex vectors cannot be interpolated\n",
ov->v_name);
return;
}
if (ov->v_length == 1) {
fprintf(cp_err, "Warning: %s is a scalar - "
"interpolation is not possible\n",
ov->v_name);
return;
}
if (ov->v_length < oldscale->v_length) {
fprintf(cp_err, "Warning: %s only contains %d points - "
"interpolation is not performed unless there are "
"at least as many points as the scale vector (%d)\n",
ov->v_name, ov->v_length, oldscale->v_length);
return;
}
/* Allocate the vector to receive the linearized data */
struct dvec * const v = dvec_alloc(copy(ov->v_name),
ov->v_type,
ov->v_flags | VF_PERMANENT,
newlen, NULL);
/* Do interpolation and then add the vector to the current plot. If
* interpolation fails, the vector must be freed. */
if (!ft_interpolate(ov->v_realdata, v->v_realdata, oldscale->v_realdata,
oldscale->v_length, newscale, newlen, 1)) {
fprintf(cp_err, "Error: can't interpolate %s\n", ov->v_name);
dvec_free(v);
return;
}
vec_new(v);
} /* end of function lincopy */