⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cmath2.c

📁 spice中支持多层次元件模型仿真的可单独运行的插件源码
💻 C
字号:
/**********Copyright 1990 Regents of the University of California.  All rights reserved.Author: 1985 Wayne A. Christopher, U. C. Berkeley CAD Group**********//* * Routines to do complex mathematical functions. These routines require * the -lm libraries. We sacrifice a lot of space to be able * to avoid having to do a seperate call for every vector element, * but it pays off in time savings.  These routines should never * allow FPE's to happen. * * Complex functions are called as follows: *  cx_something(data, type, length, &newlength, &newtype), *  and return a char * that is cast to complex or double. */#include "spice.h"#include "cpdefs.h"#include "ftedefs.h"#include "ftedata.h"#include "ftecmath.h"#include "suffix.h"char *cx_tan(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    double *d, u, v;    complex *c;    double *dd = (double *) data;    complex *cc = (complex *) data;    int i;    if (type == VF_REAL) {        d = alloc_d(length);        *newtype = VF_REAL;    } else {        c = alloc_c(length);        *newtype = VF_COMPLEX;    }    *newlength = length;    if (type == VF_COMPLEX) {        for (i = 0; i < length; i++) {rcheck(cos(degtorad(realpart(&cc[i])))*cosh(degtorad(imagpart(&cc[i]))),"tan");rcheck(sin(degtorad(realpart(&cc[i])))*sinh(degtorad(imagpart(&cc[i]))),"tan");            u = degtorad(realpart(&cc[i]));            v = degtorad(imagpart(&cc[i]));        /* The Lattice C compiler won't take multi-line macros, and         * CMS won't take >80 column lines....         */#define xx1 sin(u) * cosh(v)#define xx2 cos(u) * sinh(v)#define xx3 cos(u) * cosh(v)#define xx4 sin(u) * sinh(v)        cdiv(xx1, xx2, xx3, xx4, realpart(&c[i]), imagpart(&c[i]));        }        return ((char *) c);    } else {        for (i = 0; i < length; i++) {            rcheck(cos(degtorad(dd[i])) != 0, "tan");            d[i] = sin(degtorad(dd[i])) / cos(degtorad(dd[i]));        }        return ((char *) d);    }}char *cx_atan(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    double *d;    double *dd = (double *) data;    complex *cc = (complex *) data;    int i;    d = alloc_d(length);    *newtype = VF_REAL;    *newlength = length;    if (type == VF_COMPLEX) {        for (i = 0; i < length; i++)            d[i] = radtodeg(atan(realpart(&cc[i])));    } else {        for (i = 0; i < length; i++)            d[i] = radtodeg(atan(dd[i]));    }    return ((char *) d);}/* Normalize the data so that the magnitude of the greatest value is 1. */char *cx_norm(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    double *d, largest = 0.0;    complex *c;    double *dd = (double *) data;    complex *cc = (complex *) data;    int i;    if (type == VF_REAL) {        d = alloc_d(length);        *newtype = VF_REAL;    } else {        c = alloc_c(length);        *newtype = VF_COMPLEX;    }    *newlength = length;    if (type == VF_COMPLEX) {        for (i = 0; i < length; i++)            if (cmag(&cc[i]) > largest)                largest = cmag(&cc[i]);    } else {        for (i = 0; i < length; i++)            if (FTEcabs(dd[i]) > largest)                largest = FTEcabs(dd[i]);    }    if (largest == 0.0) {        fprintf(cp_err, "Error: can't normalize a 0 vector\n");        return (NULL);    }    if (type == VF_COMPLEX) {        for (i = 0; i < length; i++) {            realpart(&c[i]) = realpart(&cc[i]) / largest;            imagpart(&c[i]) = imagpart(&cc[i]) / largest;        }        return ((char *) c);    } else {        for (i = 0; i < length; i++)            d[i] = dd[i] / largest;        return ((char *) d);    }}char *cx_uminus(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    double *d;    complex *c;    double *dd = (double *) data;    complex *cc = (complex *) data;    int i;    if (type == VF_REAL) {        d = alloc_d(length);        *newtype = VF_REAL;    } else {        c = alloc_c(length);        *newtype = VF_COMPLEX;    }    *newlength = length;    if (type == VF_COMPLEX) {        for (i = 0; i < length; i++) {            realpart(&c[i]) = - realpart(&cc[i]);            imagpart(&c[i]) = - imagpart(&cc[i]);        }        return ((char *) c);    } else {        for (i = 0; i < length; i++)            d[i] = - dd[i];        return ((char *) d);    }}char *cx_rnd(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    double *d;    complex *c;    int i, j, k;    double *dd = (double *) data;    complex *cc = (complex *) data;    if (type == VF_REAL) {        d = alloc_d(length);        *newtype = VF_REAL;    } else {        c = alloc_c(length);        *newtype = VF_COMPLEX;    }    *newlength = length;    if (type == VF_COMPLEX) {        for (i = 0; i < length; i++) {            j = floor(realpart(&cc[i]));            k = floor(imagpart(&cc[i]));            realpart(&c[i]) = j ? random() % j : 0;            imagpart(&c[i]) = k ? random() % k : 0;        }        return ((char *) c);    } else {        for (i = 0; i < length; i++) {            j = floor(dd[i]);            d[i] = j ? random() % j : 0;        }        return ((char *) d);    }}/* Compute the mean of a vector. */char *cx_mean(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    complex *c;    double *d;    complex *cc = (complex *) data;    double *dd = (double *) data;    int i;    *newlength = 1;    rcheck(length > 0, "mean");    if (type == VF_REAL) {        d = alloc_d(1);        *newtype = VF_REAL;        for (i = 0; i < length; i++)            *d += dd[i];        *d /= length;        return ((char *) d);    } else {        c = alloc_c(1);        *newtype = VF_COMPLEX;        for (i = 0; i < length; i++) {            realpart(c) += realpart(cc + i);            imagpart(c) += imagpart(cc + i);        }        realpart(c) /= length;        imagpart(c) /= length;        return ((char *) c);    }}/* ARGSUSED */char *cx_length(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    double *d;    *newlength = 1;    *newtype = VF_REAL;    d = alloc_d(1);    *d = length;    return ((char *) d);}/* Return a vector from 0 to the magnitude of the argument. Length of the * argument is irrelevent. *//* ARGSUSED */char *cx_vector(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    complex *cc = (complex *) data;    double *dd = (double *) data;    int i, len;    double *d;    if (type == VF_REAL)        len = FTEcabs(*dd);    else        len = cmag(cc);    if (len == 0)        len = 1;    d = alloc_d(len);    *newlength = len;    *newtype = VF_REAL;    for (i = 0; i < len; i++)        d[i] = i;    return ((char *) d);}/* Create a vector of the given length composed of all ones. *//* ARGSUSED */char *cx_unitvec(data, type, length, newlength, newtype)    char *data;    short type;    int length;    int *newlength;    short *newtype;{    complex *cc = (complex *) data;    double *dd = (double *) data;    int i, len;    double *d;    if (type == VF_REAL)        len = FTEcabs(*dd);    else        len = cmag(cc);    if (len == 0)        len = 1;    d = alloc_d(len);    *newlength = len;    *newtype = VF_REAL;    for (i = 0; i < len; i++)        d[i] = 1;    return ((char *) d);}/* Calling methods for these functions are: *  cx_something(data1, data2, datatype1, datatype2, length)/* Calling methods for these functions are: *  cx_something(data1, data2, datatype1, datatype2, length) * The length of the two data vectors is always the same, and is the length * of the result. The result type is complex iff one of the args is * complex. */char *cx_plus(data1, data2, datatype1, datatype2, length)    char *data1, *data2;    short datatype1, datatype2;{    double *dd1 = (double *) data1;    double *dd2 = (double *) data2;    double *d;    complex *cc1 = (complex *) data1;    complex *cc2 = (complex *) data2;    complex *c, c1, c2;    int i;    if ((datatype1 == VF_REAL) && (datatype2 == VF_REAL)) {        d = alloc_d(length);        for (i = 0; i < length; i++)            d[i] = dd1[i] + dd2[i];        return ((char *) d);    } else {        c = alloc_c(length);        for (i = 0; i < length; i++) {            if (datatype1 == VF_REAL) {                realpart(&c1) = dd1[i];                imagpart(&c1) = 0.0;            } else {                realpart(&c1) = realpart(&cc1[i]);                imagpart(&c1) = imagpart(&cc1[i]);            }            if (datatype2 == VF_REAL) {                realpart(&c2) = dd2[i];                imagpart(&c2) = 0.0;            } else {                realpart(&c2) = realpart(&cc2[i]);                imagpart(&c2) = imagpart(&cc2[i]);            }            realpart(&c[i]) = realpart(&c1) + realpart(&c2);            imagpart(&c[i]) = imagpart(&c1) + imagpart(&c2);        }        return ((char *) c);    }}char *cx_minus(data1, data2, datatype1, datatype2, length)    char *data1, *data2;    short datatype1, datatype2;{    double *dd1 = (double *) data1;    double *dd2 = (double *) data2;    double *d;    complex *cc1 = (complex *) data1;    complex *cc2 = (complex *) data2;    complex *c, c1, c2;    int i;    if ((datatype1 == VF_REAL) && (datatype2 == VF_REAL)) {        d = alloc_d(length);        for (i = 0; i < length; i++)            d[i] = dd1[i] - dd2[i];        return ((char *) d);    } else {        c = alloc_c(length);        for (i = 0; i < length; i++) {            if (datatype1 == VF_REAL) {                realpart(&c1) = dd1[i];                imagpart(&c1) = 0.0;            } else {                realpart(&c1) = realpart(&cc1[i]);                imagpart(&c1) = imagpart(&cc1[i]);            }            if (datatype2 == VF_REAL) {                realpart(&c2) = dd2[i];                imagpart(&c2) = 0.0;            } else {                realpart(&c2) = realpart(&cc2[i]);                imagpart(&c2) = imagpart(&cc2[i]);            }            realpart(&c[i]) = realpart(&c1) - realpart(&c2);            imagpart(&c[i]) = imagpart(&c1) - imagpart(&c2);        }        return ((char *) c);    }}char *cx_times(data1, data2, datatype1, datatype2, length)    char *data1, *data2;    short datatype1, datatype2;{    double *dd1 = (double *) data1;    double *dd2 = (double *) data2;    double *d;    complex *cc1 = (complex *) data1;    complex *cc2 = (complex *) data2;    complex *c, c1, c2;    int i;    if ((datatype1 == VF_REAL) && (datatype2 == VF_REAL)) {        d = alloc_d(length);        for (i = 0; i < length; i++)            d[i] = dd1[i] * dd2[i];        return ((char *) d);    } else {        c = alloc_c(length);        for (i = 0; i < length; i++) {            if (datatype1 == VF_REAL) {                realpart(&c1) = dd1[i];                imagpart(&c1) = 0.0;            } else {                realpart(&c1) = realpart(&cc1[i]);                imagpart(&c1) = imagpart(&cc1[i]);            }            if (datatype2 == VF_REAL) {                realpart(&c2) = dd2[i];                imagpart(&c2) = 0.0;            } else {                realpart(&c2) = realpart(&cc2[i]);                imagpart(&c2) = imagpart(&cc2[i]);            }            realpart(&c[i]) = realpart(&c1) * realpart(&c2)                - imagpart(&c1) * imagpart(&c2);            imagpart(&c[i]) = imagpart(&c1) * realpart(&c2)                + realpart(&c1) * imagpart(&c2);        }        return ((char *) c);    }}char *cx_mod(data1, data2, datatype1, datatype2, length)    char *data1, *data2;    short datatype1, datatype2;{    double *dd1 = (double *) data1;    double *dd2 = (double *) data2;    double *d;    complex *cc1 = (complex *) data1;    complex *cc2 = (complex *) data2;    complex *c, c1, c2;    int i, r1, r2, i1, i2, r3, i3;    if ((datatype1 == VF_REAL) && (datatype2 == VF_REAL)) {        d = alloc_d(length);        for (i = 0; i < length; i++) {            r1 = floor(FTEcabs(dd1[i]));            rcheck(r1 > 0, "mod");            r2 = floor(FTEcabs(dd2[i]));            rcheck(r2 > 0, "mod");            r3 = r1 % r2;            d[i] = (double) r3;        }        return ((char *) d);    } else {        c = alloc_c(length);        for (i = 0; i < length; i++) {            if (datatype1 == VF_REAL) {                realpart(&c1) = dd1[i];                imagpart(&c1) = 0.0;            } else {                realpart(&c1) = realpart(&cc1[i]);                imagpart(&c1) = imagpart(&cc1[i]);            }            if (datatype2 == VF_REAL) {                realpart(&c2) = dd2[i];                imagpart(&c2) = 0.0;            } else {                realpart(&c2) = realpart(&cc2[i]);                imagpart(&c2) = imagpart(&cc2[i]);            }            r1 = floor(FTEcabs(realpart(&c1)));            rcheck(r1 > 0, "mod");            r2 = floor(FTEcabs(realpart(&c2)));            rcheck(r2 > 0, "mod");            i1 = floor(FTEcabs(imagpart(&c1)));            rcheck(i1 > 0, "mod");            i2 = floor(FTEcabs(imagpart(&c2)));            rcheck(i2 > 0, "mod");            r3 = r1 % r2;            i3 = i1 % i2;            realpart(&c[i]) = (double) r3;            imagpart(&c[i]) = (double) i3;        }        return ((char *) c);    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -