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

perf: Slightly optimise object interner for larger codebase #5170

Merged
merged 6 commits into from
Jan 21, 2025

Conversation

siketyan
Copy link
Contributor

We have a larger codebase of TypeSpec (total. 17K lines formatted) and found that emitting part is very slow than the compile part, taking 15 seconds avg. on my M3 Pro machine.

After enabling --cpu-prof option of Node.js, I found that intern function is taking larger part of the framegraph. As the JSDoc says, it's not well optimised yet.

This pull request is maybe the first try of the optimisation and slightly improves the execution time of the emitting part. It lowed the execution time from 15 seconds to 6 seconds.

Profiling comparison

← after, before →

image

@bterlson
Copy link
Member

bterlson commented Nov 26, 2024

Hey cool, the bottleneck got hit 😁 How hard was the facepalm when you saw the comment?

This is a good simple approach. There are likely more optimal approaches that would be more work (e.g. I had considered sorting keys and then storing the known keys and values in a trie, which I think is effectively what the records and tuples polyfill does). But I don't think this can hurt to improve for now since it seems to help your perf significantly. Let's see what Will thinks.

@markcowl markcowl assigned markcowl and unassigned markcowl Dec 5, 2024
@microsoft-github-policy-service microsoft-github-policy-service bot added the stale Mark a PR that hasn't been recently updated and will be closed. label Jan 6, 2025
@siketyan
Copy link
Contributor Author

siketyan commented Jan 7, 2025

@witemple-msft cc @bterlson Hi, could you please review this when you have time? 🙏 This bottleneck still hitting our codebase to slow down openapi3 emitting. Thank you!

@witemple-msft witemple-msft self-requested a review as a code owner January 9, 2025 16:52
Copy link
Member

@witemple-msft witemple-msft left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ack, sorry! I had asked Brian what he thought and then I missed that he already commented. If Brian's good with it, I'm good with it.

@siketyan
Copy link
Contributor Author

I will add a changelog for this today 🙏

Signed-off-by: Naoki Ikeguchi <[email protected]>
auto-merge was automatically disabled January 10, 2025 01:56

Head branch was pushed to by a user without write access

@siketyan
Copy link
Contributor Author

@witemple-msft I added a chronus changelog for this change, could you please take a look?

@timotheeguerin timotheeguerin added this pull request to the merge queue Jan 21, 2025
Merged via the queue into microsoft:main with commit 4855f87 Jan 21, 2025
18 checks passed
@siketyan siketyan deleted the perf/optimise-interner branch January 22, 2025 00:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
compiler:core Issues for @typespec/compiler stale Mark a PR that hasn't been recently updated and will be closed.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants