You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

100 lines
2.2 KiB

/**********
Copyright 1990 Regents of the University of California. All rights reserved.
Author: 1985 Thomas L. Quarles
**********/
#include <stdio.h>
#include "ifsim.h"
#include "iferrmsg.h"
#include "pzdefs.h"
#include "cktdefs.h"
/* ARGSUSED */
int
PZsetParm(CKTcircuit *ckt, void *anal, int which, IFvalue *value)
{
switch(which) {
case PZ_NODEI:
((PZAN*)anal)->PZin_pos = ((CKTnode*)value->nValue)->number;
break;
case PZ_NODEG:
((PZAN*)anal)->PZin_neg = ((CKTnode*)value->nValue)->number;
break;
case PZ_NODEJ:
((PZAN*)anal)->PZout_pos = ((CKTnode*)value->nValue)->number;
break;
case PZ_NODEK:
((PZAN*)anal)->PZout_neg = ((CKTnode*)value->nValue)->number;
break;
case PZ_V:
if(value->iValue) {
((PZAN*)anal)->PZinput_type = PZ_IN_VOL;
}
break;
case PZ_I:
if(value->iValue) {
((PZAN*)anal)->PZinput_type = PZ_IN_CUR;
}
break;
case PZ_POL:
if(value->iValue) {
((PZAN*)anal)->PZwhich = PZ_DO_POLES;
}
break;
case PZ_ZER:
if(value->iValue) {
((PZAN*)anal)->PZwhich = PZ_DO_ZEROS;
}
break;
case PZ_PZ:
if(value->iValue) {
((PZAN*)anal)->PZwhich = PZ_DO_POLES | PZ_DO_ZEROS;
}
break;
default:
return(E_BADPARM);
}
return(OK);
}
static IFparm PZparms[] = {
{ "nodei", PZ_NODEI, IF_SET|IF_ASK|IF_NODE, "" },
{ "nodeg", PZ_NODEG, IF_SET|IF_ASK|IF_NODE, "" },
{ "nodej", PZ_NODEJ, IF_SET|IF_ASK|IF_NODE, "" },
{ "nodek", PZ_NODEK, IF_SET|IF_ASK|IF_NODE, "" },
{ "vol", PZ_V, IF_SET|IF_ASK|IF_FLAG, "" },
{ "cur", PZ_I, IF_SET|IF_ASK|IF_FLAG, "" },
{ "pol", PZ_POL, IF_SET|IF_ASK|IF_FLAG, "" },
{ "zer", PZ_ZER, IF_SET|IF_ASK|IF_FLAG, "" },
{ "pz", PZ_PZ, IF_SET|IF_ASK|IF_FLAG, "" }
};
SPICEanalysis PZinfo = {
{
"PZ",
"pole-zero analysis",
sizeof(PZparms)/sizeof(IFparm),
PZparms
},
sizeof(PZAN),
NODOMAIN,
1,
PZsetParm,
PZaskQuest,
NULL,
PZan
};