neuronPCA
Description
The compressNetworkUsingProjection function uses principal
      component analysis (PCA) to identify the subspace of learnable parameters that result in the
      highest variance in neuron activations by analyzing the network activations using a data set
      representative of the training data. The PCA step can be computationally intensive. If you
      expect to compress the same network multiple times (for example, when exploring different
      levels of compression), then you can perform the PCA step up front using a
        neuronPCA object.
Depending on the network, projection configuration, and code generation libraries used (including library-free code generation), forward passes of a projected deep neural network can be faster when you deploy the network to embedded hardware.
If you prune or quantize your network, then use compression using projection after pruning and before quantization.
Creation
Description
npca = neuronPCA(net,mbq)net using the data in the mini-batch queue
          mbq. The software analyzes the input and output activations of the
          projectable layers in net. This feature requires the Deep Learning Toolbox™ Model Compression
        Library support package. This support package is a free add-on that you can download using
    the Add-On Explorer. Alternatively, see Deep Learning Toolbox Model Compression Library.
npca = neuronPCA(___,Name=Value)LayerNames property or specifies additional options using
          one or more name-value arguments.
Input Arguments
Name-Value Arguments
Properties
Examples
References
[1] "Compressing Neural Networks Using Network Projection." Accessed July 20, 2023. https://www.mathworks.com/company/technical-articles/compressing-neural-networks-using-network-projection.html.