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

💡 [REQUEST] - <title>Pruning tutorial: clarify how to achieve comparable performance to non-pruned? #3308

Open
drscotthawley opened this issue Mar 30, 2025 · 0 comments

Comments

@drscotthawley
Copy link
Contributor

🚀 Describe the improvement or the new tutorial

In the pruning tutorial https://pytorch.org/tutorials/intermediate/pruning_tutorial.html,
the method of pruning that is implemented appears to be completely random. "In this example, we will prune at random 30% of the connections..."

But isn't the goal of pruning produce a smaller network with nearly the same capabilities as the original?
I don't see anything in the tutorial about checking the performance of the new network, or how to intelligently prune the network in order to achieve the goal of pruning. The tutorial takes a randomly-initialized network, randomly prunes it, and then...

...it just suddenly ends...?

Is the idea that we're supposed to just keep iteratively trying random pruning until something finally works ok? That sounds unbearably undirected and inefficient. Did I miss something crucial while reading the tutorial?

Requesting: Clarification on how to achieve the "goal" of pruning: intelligently pruning the network to achieve comparable capabilities.
Just telling me I can define my own pruning function isn't enough, because...it's a tutorial, I don't know what such a function should entail.

Existing tutorials on this topic

https://pytorch.org/tutorials/intermediate/pruning_tutorial.html

Additional context

"In this example, we will prune at random 30% of the connections "

Why/how will that help achieve the goal of pruning? Won't it just randomly turn off parts of the network with no regard to its effect on performance? (This application seems more like Dropout than actual pruning.)

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

No branches or pull requests

1 participant