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

📄 mesh.c

📁 spice中支持多层次元件模型仿真的可单独运行的插件源码
💻 C
字号:
/**********Copyright 1991 Regents of the University of California.  All rights reserved.Author:	1991 David A. Gates, U. C. Berkeley CAD Group**********/#include "spice.h"#include <stdio.h>#include "const.h"#include "util.h"#include "numcards.h"#include "numgen.h"#include "meshdefs.h"#include "sperror.h"#include "suffix.h"#ifdef __STDC__extern int XMSHnewCard(GENERIC**,GENERIC*);extern int YMSHnewCard(GENERIC**,GENERIC*);extern int MESHparam(int,IFvalue*,GENERIC*);#elseextern int XMSHnewCard();extern int YMSHnewCard();extern int MESHparam();#endif /* STDC */IFparm MESHpTable[] = {  IP("location",MESH_LOCATION,	IF_REAL,	"Meshline location"),  IP("width",	MESH_WIDTH,	IF_REAL,	"Distance to next line"),  IP("number",	MESH_NUMBER,	IF_INTEGER,	"Meshline number"),  IP("node",	MESH_NUMBER,	IF_INTEGER,	"Meshline number"),  IP("ratio",	MESH_RATIO,	IF_REAL,	"Suggested spacing ratio"),  IP("h.start",	MESH_H_START,	IF_REAL,	"Spacing at start of interval"),  IP("h1",	MESH_H_START,	IF_REAL,	"Spacing at start of interVal"),  IP("h.end",	MESH_H_END,	IF_REAL,	"Spacing at end of interval"),  IP("h2",	MESH_H_END,	IF_REAL,	"Spacing at end of interval"),  IP("h.max",	MESH_H_MAX,	IF_REAL,	"Max spacing during interval"),  IP("h3",	MESH_H_MAX,	IF_REAL,	"Max spacing during interval")};IFcardInfo XMSHinfo = {  "x.mesh",  "Location of mesh lines",  NUMELEMS(MESHpTable),  MESHpTable,  XMSHnewCard,  MESHparam,  NULL};IFcardInfo YMSHinfo = {  "y.mesh",  "Location of mesh lines",  NUMELEMS(MESHpTable),  MESHpTable,  YMSHnewCard,  MESHparam,  NULL};intXMSHnewCard( inCard, inModel )    GENERIC **inCard;    GENERIC *inModel;{    MESHcard *tmpCard, *newCard;    GENnumModel *model = (GENnumModel *)inModel;    newCard = NEW( MESHcard );    if (!newCard) {        *inCard = (GENERIC *)NULL;        return(E_NOMEM);    }    newCard->MESHnextCard = (MESHcard *)NULL;    *inCard = (GENERIC *)newCard;    tmpCard = model->GENxMeshes;    if (!tmpCard) { /* First in list */        model->GENxMeshes = newCard;    } else {	/* Go to end of list */        while (tmpCard->MESHnextCard) tmpCard = tmpCard->MESHnextCard;	/* And add new card */	tmpCard->MESHnextCard = newCard;    }    return(OK);}intYMSHnewCard( inCard, inModel )    GENERIC **inCard;    GENERIC *inModel;{    MESHcard *tmpCard, *newCard;    GENnumModel *model = (GENnumModel *)inModel;    newCard = NEW( MESHcard );    if (!newCard) {        *inCard = (GENERIC *)NULL;        return(E_NOMEM);    }    newCard->MESHnextCard = (MESHcard *)NULL;    *inCard = (GENERIC *)newCard;    tmpCard = model->GENyMeshes;    if (!tmpCard) { /* First in list */        model->GENyMeshes = newCard;    } else {	/* Go to end of list */        while (tmpCard->MESHnextCard) tmpCard = tmpCard->MESHnextCard;	/* And add new card */	tmpCard->MESHnextCard = newCard;    }    return(OK);}intMESHparam( param, value, inCard )    int param;    IFvalue *value;    GENERIC *inCard;{    MESHcard *card = (MESHcard *)inCard;    switch (param) {	case MESH_LOCATION:	    card->MESHlocation = value->rValue;	    card->MESHlocationGiven = TRUE;	    break;	case MESH_WIDTH:	    card->MESHwidth = value->rValue;	    card->MESHwidthGiven = TRUE;	    break;	case MESH_H_START:	    card->MESHhStart = value->rValue;	    card->MESHhStartGiven = TRUE;	    break;	case MESH_H_END:	    card->MESHhEnd = value->rValue;	    card->MESHhEndGiven = TRUE;	    break;	case MESH_H_MAX:	    card->MESHhMax = value->rValue;	    card->MESHhMaxGiven = TRUE;	    break;	case MESH_RATIO:	    card->MESHratio = value->rValue;	    card->MESHratioGiven = TRUE;	    break;	case MESH_NUMBER:	    card->MESHnumber = value->iValue;	    card->MESHnumberGiven = TRUE;	    break;	default:	    return(E_BADPARM);	    break;    }    return(OK);}

⌨️ 快捷键说明

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