Zulip Chat Archive
Stream: general
Topic: listing all declarations used in theorem
Chris Hughes (Oct 21 2022 at 13:14):
Has anyone written meta code to list all the declarations used in a theorem including the declarations used by theorems that the first theorem uses and so on? I wrote some, but it's not fast enough to execute without a deterministic timeout. I want this for Lean 3 by the way.
Yaël Dillies (Oct 21 2022 at 13:54):
leancrawler? That's what people use for LTE or sphere eversion
Alex J. Best (Oct 21 2022 at 15:27):
Does the code in #16911 help, something like this should be possible in lean without timeouts, but if you re-visit declarations more than once I can see why it would be too slow
Jason Rute (Oct 21 2022 at 17:22):
Lean has a docs#hash_map and even docs#name_map and docs#name_set specialized to names, so it is possible to loop over everything and store what you have already seen to speed it up.
Chris Hughes (Oct 24 2022 at 13:57):
I wrote the most optimized code I could using name_set and stuff, and it's still not quite fast enough. Is there some way to just increase deterministic timeout to more than 2^32-1
Mario Carneiro (Oct 24 2022 at 14:00):
if you run lean from the command line there is no timeout
Last updated: May 02 2025 at 03:31 UTC