How to use prune for CNNs?

5 visualizaciones (últimos 30 días)
Nour Mohamed
Nour Mohamed el 12 de En. de 2021
Respondida: Maksym Tymchenko el 2 de Nov. de 2023
I want to prune pretrained CNNs by certain rates (0.1-0.9). But when I try to use the prune function I get the following error:
Check for missing argument or incorrect argument data type in call to function 'prune'.
How can I use this function for CNNs (in this case resnet18) and is there a way to specify the pruning rate?
Thank you,
  1 comentario
Shaw
Shaw el 3 de Nov. de 2021
Did you get any solution for this?

Iniciar sesión para comentar.

Respuestas (2)

Nitin Kapgate
Nitin Kapgate el 15 de En. de 2021
Currently the "prune" function does not provide the functionality to prune the network at specified pruninng rate.
The prune function removes zero-sized inputs, layers, and outputs from a network.
This leaves a network which may have fewer inputs and outputs, but which implements the same operations, as zero-sized inputs and outputs do not convey any information.
  1 comentario
Nour Mohamed
Nour Mohamed el 18 de En. de 2021
Thank you for your answer. But why can't I use it with CNNs? Why do I get that error?

Iniciar sesión para comentar.


Maksym Tymchenko
Maksym Tymchenko el 2 de Nov. de 2023
In MATLAB, you can compress deep neural networks by using the Deep Learning Model Quantization Library, which is a free Add-On to the Deep Learning Toolbox.
This library contains a set of different functions that allow you to compress your deep learning network.
You mentioned pruning, this is a type of structural compression where the least important weights in the network are discarded making the network smaller. The "prune" function that you mentioned only accepts "shallow neural networks" as input. That is the reason why it did not work on resnet18. If you want to perform structural compression on a deep neural network like resnet18, you can use either:
Both of these functions work only on dlnetwork objects, so you might need to convert your network to that form in order to use them. For an example of how to prune convolutional filters in a CNN see:

Categorías

Más información sobre Image Data Workflows en Help Center y File Exchange.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by