Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Slightly faster PortRef comparisons #228

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

nikosavola
Copy link
Contributor

Use Python slots for faster lookup and try-except instead of if-else.

I found this to be somewhat faster for exporting Spice. What do you think?

Relates to #227

Use Python slots for faster lookup and try-except instead of if-else
@nikosavola nikosavola force-pushed the 227-faster-portref-handling-for-spice-export branch from f376bf3 to 5bd12fc Compare June 25, 2024 11:27
@dan-fritchman
Copy link
Owner

dan-fritchman commented Jun 26, 2024

Surprising!

My guess is the topic referenced in issue #227 (the set/list combo... actually being one) would move the needle much more.

The Set/List combo is "turned off" for reasons I don't entirely remember, but certainly included "caused weird failures I didn't understand elsewhere" in the causal chain.

That reminds me, in any case we've gotta get the tests passing. I think (hope) it's mostly #229 (codecov) in the way. But until that works, who knows. I may be able to get to that late in the week, or you're welcome to roll it in here.

@dan-fritchman
Copy link
Owner

Now that #230 is done - recommend merging main into here.
That'll give the CI tests a chance of passing.

@nikosavola
Copy link
Contributor Author

Older Python + Pydantic combinations appear to not automagically handle the slotted class, there might be a manual flag to add in the dataclass decorator I assume.

@dan-fritchman
Copy link
Owner

Ah.
There is an issue re Python 3.7-8 and Pydantic v2: #217.
I've written up some thoughts on what we support (and why) there.
It looks like this would brick Pydantic v1 as well, which I'm even more reticent to do.

Did the SetList change not work?
Or not things up as much as you expected, or at this?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants