densenet201 - (Not recommended) DenseNet-201 convolutional neural network - MATLAB (original) (raw)

(Not recommended) DenseNet-201 convolutional neural network

Syntax

Description

DenseNet-201 is a convolutional neural network that is 201 layers deep. You can load a pretrained version of the network trained on more than a million images from the ImageNet database [1]. The pretrained network can classify images into 1000 object categories, such as keyboard, mouse, pencil, and many animals. As a result, the network has learned rich feature representations for a wide range of images. The network has an image input size of 224-by-224. For more pretrained networks in MATLAB®, see Pretrained Deep Neural Networks.

[net](#mw%5Fbe09cfba-ca2b-4ef6-95a2-5ce311606c5a) = densenet201 returns a DenseNet-201 network trained on the ImageNet data set.

This function requires the Deep Learning Toolbox™ Model for DenseNet-201 Network support package. If this support package is not installed, then the function provides a download link.

example

[net](#mw%5Fbe09cfba-ca2b-4ef6-95a2-5ce311606c5a) = densenet201('Weights',`'imagenet'`) returns a DenseNet-201 network trained on the ImageNet data set. This syntax is equivalent to net = densenet201.

[lgraph](#mw%5F955789e9-91a9-47ed-893e-043c656b71a4) = densenet201('Weights',`'none'`) returns the untrained DenseNet-201 network architecture. The untrained model does not require the support package.

Examples

collapse all

Download and install the Deep Learning Toolbox Model for DenseNet-201 Network support package.

Type densenet201 at the command line.

If the Deep Learning Toolbox Model for DenseNet-201 Network support package is not installed, then the function provides a link to the required support package in the Add-On Explorer. To install the support package, click the link, and then clickInstall. Check that the installation is successful by typingdensenet201 at the command line. If the required support package is installed, then the function returns a DAGNetwork object.

ans =

DAGNetwork with properties:

     Layers: [709×1 nnet.cnn.layer.Layer]
Connections: [806×2 table]

Visualize the network using Deep Network Designer.

deepNetworkDesigner(densenet201)

Explore other pretrained neural networks in Deep Network Designer by clicking New.

Deep Network Designer start page showing available pretrained neural networks

If you need to download a neural network, pause on the desired neural network and click Install to open the Add-On Explorer.

Output Arguments

collapse all

Pretrained DenseNet-201 convolutional neural network, returned as a DAGNetwork object.

Untrained DenseNet-201 convolutional neural network architecture, returned as aLayerGraph object.

References

[1] ImageNet. http://www.image-net.org.

[2] Huang, Gao, Zhuang Liu, Laurens Van Der Maaten, and Kilian Q. Weinberger. “Densely Connected Convolutional Networks.” In 2017 IEEE Conference on Computer Vision and Pattern Recognition (CVPR), 2261–69. Honolulu, HI: IEEE, 2017. https://doi.org/10.1109/CVPR.2017.243.

Extended Capabilities

expand all

For code generation, you can load the network by using the syntax net = densenet201 or by passing the densenet201 function tocoder.loadDeepLearningNetwork (MATLAB Coder). For example: net = coder.loadDeepLearningNetwork('densenet201')

For more information, see Load Pretrained Networks for Code Generation (MATLAB Coder).

The syntax densenet201('Weights','none') is not supported for code generation.

Usage notes and limitations:

Version History

Introduced in R2018a

collapse all

densenet201 is not recommended. Use the imagePretrainedNetwork function instead and specify"densenet201" as the model.

There are no plans to remove support for the densenet201 function. However, the imagePretrainedNetwork function has additional functionality that helps with transfer learning workflows. For example, you can specify the number of classes in your data using thenumClasses option, and the function returns a network that is ready for retraining without the need for modification.

The imagePretrainedNetwork function returns the network as a dlnetwork object, which does not store the class names, To get the class names of the pretrained network, use the second output argument of the imagePretrainedNetwork function.

This table shows some typical usages of the densenet201 function and how to update your code to use theimagePretrainedNetwork function instead.

Not Recommended Recommended
net = densenet201; [net,classNames] = imagePretrainedNetwork("densenet201");
net = densenet201(Weights="none"); net = imagePretrainedNetwork("densenet201",Weights="none");

The imagePretrainedNetwork returns a dlnetwork object, which also has these advantages:

To train a neural network specified as a dlnetwork object, use the trainnet function.