Continue to Site

Welcome to EDAboard.com

Welcome to our site! EDAboard.com is an international Electronics Discussion Forum focused on EDA software, circuits, schematics, books, theory, papers, asic, pld, 8051, DSP, Network, RF, Analog Design, PCB, Service Manuals... and a whole lot more! To participate you need to register. Registration is free. Click here to register now.

[SOLVED] how "if" statement in eldo works?

Status
Not open for further replies.

vaah

Member level 3
Member level 3
Joined
May 24, 2012
Messages
67
Helped
1
Reputation
2
Reaction score
1
Trophy points
1,288
Location
US
Activity points
1,785
Hello guys,

I want to use sort of special function in a subcircuit. Let assume we have a subcircuit as specified below

.subckt res X Y param: ro=10K
R1 X Y ro
if (((X)-V(Y))>=1) .param ro= 5K
endif

.ends

It gives two errors as,

+ Syntax error in expression IF ( ( V ( X )-V(Y ) ) > 1) .PARAM RO = 5K
+ Error: signe < or > expected at IF ( ( V ( X )-V(Y ) ) > 1)

I was expecting to see these errors bu I wonder how I can do that if I don't want to use a Verilog-A model?
I appreciate your help
 
Last edited:

I don't know if you can make a subcircuit act on results
it has yet to generate. That's what V(node) means, to me
and likely the simulator would think V(node) is to be a
declared vector then, only it may be reserved.

Consider veriloga if eldo has such an integration (?).
Also consider that such a case statement may make
the simulation unsolvable, hyperabrupt change in
circuit state generally doesn't work out well. A
B source that used tanh() to swing between 10K
and 5K over an acceptably small (but nonzero) range
would be a much better (in terms of probability of
actually finishing) solution.

Or, macromodel it with a switch primitive and two
resistors, if you must go SPICE-only
 

Status
Not open for further replies.

Similar threads

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Back
Top