Tizen.MachineLearning.Train/a> namespace<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-prerequisites\">Prerequisites<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-building-blocks\">Building blocks<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-model-class\">Model class<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-layer-class\">Layer class<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-optimizer-class\">Optimizer class<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-dataset-class\">Dataset class<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-construct-a-model\">Construct a model<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-construct-a-model-from-a-description-file\">Construct a model from a description file<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-create-a-model-from-ini-formatted-file\">Create a model from INI formatted file<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-construct-a-model-on-code\">Construct a model on code<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-configure-the-model\">Configure the model<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-add-a-layer\">Add a layer<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-get-a-layer\">Get a layer<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-set-an-optimizer\">Set an optimizer<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-set-a-dataset\">Set a dataset<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-sample-batch-and-epoch\">Sample, batch, and epoch<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-construct-a-dataset-on-code\">Construct a dataset on code<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-set-a-dataset-from-file\">Set a dataset from file<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-compile-the-model\">Compile the model<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-train-the-model\">Train the model<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-destroy-the-model\">Destroy the model<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-use-the-trained-model-for-inference\">Use the trained model for inference<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Machine Learning Train","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"ue5jpGfQdUXno3d4BoOU","name":"documentation::article","path":"docs\/application\/dotnet\/guides\/machine-learning\/machine-learning-train","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"36b67efb62e52d5d8a8c30c2d1b4d81e9900f7007638eacd6906501f7b02f6bd"}" wire:effects="[]" wire:id="ue5jpGfQdUXno3d4BoOU" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-machine-learning-train\"><a href=\"#content-machine-learning-train\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Machine Learning Train<\/h1><div data-knowledge-base-metadata><\/div>\n<p>You can use the <code>Tizen.MachineLearning.Train<\/code> class to construct, control, and train a machine learning model in Tizen devices.<\/p>\n<p>The main features of machine learning train include the following:<\/p>\n<ul>\n<li>\n<p>Constructing a deep neural network (DNN)<\/p>\n<p>You can construct a DNN model using a model description file or by writing code through <code>Tizen.MachineLearning.Train<\/code> class.<\/p>\n<\/li>\n<li>\n<p>Training with your own data<\/p>\n<p><code>Tizen.MachineLearning.Train<\/code> class also allows you to train the model with your own data as a file I\/O or by defining a data generator.<\/p>\n<\/li>\n<li>\n<p>Evaluating the model during training<\/p>\n<p>You can validate and test your model during the training process easily by defining the dataset.<\/p>\n<\/li>\n<\/ul>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>Every example code does not handle all error use cases.\nThe error must be handled more extensively compared to the example code written on this page.<\/p>\n<\/div>\n<h2 id=\"content-prerequisites\"><a href=\"#content-prerequisites\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Prerequisites<\/h2>\n<p>To enable your application to use <code>Tizen.MachineLearning.Train<\/code> class, follow the steps below:<\/p>\n<ol>\n<li>\n<p>To use the method and properties of the <code>Tizen.MachineLearning.Train.Model<\/code>, <code>Tizen.MachineLearning.Train.Dataset<\/code>, <code>Tizen.MachineLearning.Train.Layer<\/code> and <code>Tizen.MachineLearning.Train.Optimizer<\/code>, include the <code>Tizen.MachineLearning.Train<\/code> namespace in your application:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">using<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MachineLearning<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Train<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>To use <code>Tizen.MachineLearning.Train<\/code> class, include the following features in your <code>tizen-manifest.xml<\/code> file:<\/p>\n<code class=\"language-XML\">&lt;feature name=&quot;http:\/\/tizen.org\/feature\/machine_learning&quot;&gt;true&lt;\/feature&gt;\n&lt;feature name=&quot;http:\/\/tizen.org\/feature\/machine_learning.training&quot;&gt;true&lt;\/feature&gt;\n<\/code>\n<p>In case of saving or loading model files from outside of the application's own resources, the application has to request permission by adding the following privileges to the <code>tizen-manifest.xml<\/code> file:<\/p>\n<code class=\"language-XML\">&lt;privileges&gt;\n  &lt;!-- For accessing media storage --&gt;\n  &lt;privilege&gt;http:\/\/tizen.org\/privilege\/mediastorage&lt;\/privilege&gt;\n\n  &lt;!-- For accessing external storage --&gt;\n  &lt;privilege&gt;http:\/\/tizen.org\/privilege\/externalstorage&lt;\/privilege&gt;\n&lt;\/privileges&gt;\n<\/code>\n<\/li>\n<\/ol>\n<h2 id=\"content-building-blocks\"><a href=\"#content-building-blocks\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Building blocks<\/h2>\n<p>Following are the four major class of <code>Tizen.MachineLearning.Train<\/code>:<\/p>\n<ul>\n<li><a href=\"#model-class\">Tizen.MachineLearning.Train.Model<\/a><\/li>\n<li><a href=\"#layer-class\">Tizen.MachineLearning.Train.Layer<\/a><\/li>\n<li><a href=\"#optimizer-class\">Tizen.MachineLearning.Train.Optimizer<\/a><\/li>\n<li><a href=\"#dataset-class\">Tizen.MachineLearning.Train.Dataset<\/a><\/li>\n<\/ul>\n<h3 id=\"content-model-class\"><a href=\"#content-model-class\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Model class<\/h3>\n<p><code>Tizen.MachineLearning.Train.Model<\/code> class is a wrapper component that has the topology of <code>Tizen.MachineLearning.Train.Layer<\/code>, <code>Tizen.MachineLearning.Train.Optimizer<\/code>, and <code>Tizen.MachineLearning.Train.Dataset<\/code> class.\n<code>Tizen.MachineLearning.Train.Model<\/code> class performs training and saves the updated parameters that can later be used for inference.\nIn the following figure, <code>data<\/code> represents input data or feature and <code>label<\/code> is the actual value to be tested over prediction:<\/p>\n<p><img src=\"media\/model.png\" alt=\"model\" \/><\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">filePath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Applications.Application.Current.DirectoryInfo.Data;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">binPath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> filePath <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;model_weights.bin&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">iniPath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> filePath <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;model.ini&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">iniWithBinPath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> filePath <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;model_and_weights.ini&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/* Configure model(omitted for brevity) *\/<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Compile model - This freezes the model. Afterwards the model cannot be modified.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Compile<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;loss=cross&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;batch_size=16&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Run model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Run<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;epochs=2&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Save and load below format.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Save<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(binPath, NNTrainerModelFormat.Bin);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Save<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(iniPath, NNTrainerModelFormat.Ini);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Save<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(iniWithBinPath, NNTrainerModelFormat.iniWithBin);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Model will be disposed by GC but you can use Dispose() as below.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Dispose<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>A number of properties can be set at <code>Model.Compile<\/code> and <code>Model.Run<\/code> phase:<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Method<\/th>\n<th>Key<\/th>\n<th>Value<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>Model.Compile<\/code>, <code>Model.Run<\/code><\/td>\n<td>epochs<\/td>\n<td>(integer)<\/td>\n<td>Determines epochs for the model.<\/td>\n<\/tr>\n<tr>\n<td><\/td>\n<td>save_path<\/td>\n<td>(string)<\/td>\n<td>Model path to save parameters after a single epoch.<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h3 id=\"content-layer-class\"><a href=\"#content-layer-class\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Layer class<\/h3>\n<p><code>Tizen.MachineLearning.Train.Layer<\/code> class is a component that does actual computation while managing internal trainable parameters.\nThe following example shows how to create, add and get the layer to the model:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create layer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">fcLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Layer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerLayerType.FC);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Configure layer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">fcLayer.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;unit=10&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;activation=softmax&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;bias_initializer=zeros&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;name=fc100&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ After adding the layer to model, you do not need to destroy layer since ownership is transferred to the model.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AddLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(fcLayer);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Get layer from the model with the given name.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ The returned layer must not be deleted as it is owned by the model.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">layerName<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;fc100&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Layer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">getLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(layername);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>There are two types of layers. One type includes commonly trainable weights and the other type does not include them.\nThe following are the available properties for each layer type which include commonly trainable weights.<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Type<\/th>\n<th>Key<\/th>\n<th>Value<\/th>\n<th>Default value<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>(Universal properties)<\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Universal properties that apply to every layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>name<\/td>\n<td>(string)<\/td>\n<td><\/td>\n<td>An identifier for each layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>trainable<\/td>\n<td>(boolean)<\/td>\n<td>true<\/td>\n<td>Allow weights to be trained if true<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>input_layers<\/td>\n<td>(string)<\/td>\n<td><\/td>\n<td>Comma-separated names of layers to be inputs of the current layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>input_shape<\/td>\n<td>(string)<\/td>\n<td><\/td>\n<td>Comma-separated formatted string as &quot;channel:height:width&quot;. If there is no channel then it must be 1. The first layer of the model must have input_shape. Other can be omitted as it is calculated at compile phase.<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>flatten<\/td>\n<td>(boolean)<\/td>\n<td><\/td>\n<td>Flatten shape from <code>c:h:w<\/code> to <code>1:1:c*h*w<\/code><\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>activation<\/td>\n<td>(categorical)<\/td>\n<td><\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>loss<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Loss<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>weight_initializer<\/td>\n<td>(categorical)<\/td>\n<td>xavier_uniform<\/td>\n<td>Weight initializer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>zeros<\/td>\n<td><\/td>\n<td>Zero initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_normal<\/td>\n<td><\/td>\n<td>LeCun normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_uniform<\/td>\n<td><\/td>\n<td>LeCun uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_normal<\/td>\n<td><\/td>\n<td>Xavier normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_uniform<\/td>\n<td><\/td>\n<td>Xavier uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_normal<\/td>\n<td><\/td>\n<td>He normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_uniform<\/td>\n<td><\/td>\n<td>He uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>bias_initializer<\/td>\n<td>(categorical)<\/td>\n<td>zeros<\/td>\n<td>Bias initializer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>zeros<\/td>\n<td><\/td>\n<td>Zero initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_normal<\/td>\n<td><\/td>\n<td>LeCun normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_uniform<\/td>\n<td><\/td>\n<td>LeCun uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_normal<\/td>\n<td><\/td>\n<td>Xavier normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_uniform<\/td>\n<td><\/td>\n<td>Xavier uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_normal<\/td>\n<td><\/td>\n<td>He normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_uniform<\/td>\n<td><\/td>\n<td>He uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>weight_regularizer<\/td>\n<td>(categorical)<\/td>\n<td><\/td>\n<td>Weight regularizer. Currently, only l2norm is supported<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>l2norm<\/td>\n<td><\/td>\n<td>L2 weight regularizer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>weight_regularizer_constant<\/td>\n<td>(float)<\/td>\n<td>1<\/td>\n<td>Weight regularizer constant<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.FC<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Fully connected layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of outputs<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Conv1D<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>1D convolution layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>filters<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of filters<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>kernel_size<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Kernel size<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>stride<\/td>\n<td>(unsigned integer)<\/td>\n<td>1<\/td>\n<td>Strides<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>padding<\/td>\n<td>(categorical)<\/td>\n<td>valid<\/td>\n<td>Padding type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>valid<\/td>\n<td><\/td>\n<td>No padding<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>same<\/td>\n<td><\/td>\n<td>Preserve dimension<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Size of padding applied uniformly to all side<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(array of unsigned integer of size 2)<\/td>\n<td><\/td>\n<td>Padding for left, right<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Conv2D<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>2D convolution layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>filters<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of filters<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>kernel_size<\/td>\n<td>(array of unsigned integer)<\/td>\n<td><\/td>\n<td>Comma-separated unsigned integers for kernel size, <code>height, width<\/code> respectively<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>stride<\/td>\n<td>(array of unsigned integer)<\/td>\n<td>1, 1<\/td>\n<td>Comma-separated unsigned integers for strides, <code>height, width<\/code> respectively<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>padding<\/td>\n<td>(categorical)<\/td>\n<td>valid<\/td>\n<td>Padding type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>valid<\/td>\n<td><\/td>\n<td>No padding<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>same<\/td>\n<td><\/td>\n<td>Preserve height\/width dimension<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Size of padding applied uniformly to all side<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(array of unsigned integer of size 2)<\/td>\n<td><\/td>\n<td>Padding for height, width<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(array of unsigned integer of size 4)<\/td>\n<td><\/td>\n<td>Padding for top, bottom, left, right<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Embedding<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Embedding layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>in_dim<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Vocabulary size<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>out_dim<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Word embedding size<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.RNN<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>RNN layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of output neurons<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_activation<\/td>\n<td>(categorical)<\/td>\n<td>tanh<\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>return_sequences<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Return only the last output if true, else return full output<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>dropout<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Dropout rate<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>integrate_bias<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Integrate bias_ih, bias_hh to bias_h<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.RNNCell<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>RNN cell layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of output neurons<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_activation<\/td>\n<td>(categorical)<\/td>\n<td>tanh<\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>dropout<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Dropout rate<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>integrate_bias<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Integrate bias_ih, bias_hh to bias_h<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.LSTM<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>LSTM layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of output neurons<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_activation<\/td>\n<td>(categorical)<\/td>\n<td>tanh<\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>recurrent_activation<\/td>\n<td>(categorical)<\/td>\n<td>sigmoid<\/td>\n<td>Activation type for recurrent step<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>return_sequences<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Return only the last output if true, else return full output<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>dropout<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Dropout rate<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>integrate_bias<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Integrate bias_ih, bias_hh to bias_h<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>max_timestep<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Maximum timestep<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.LSTMCell<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>LSTM cell layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of output neurons<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_activation<\/td>\n<td>(categorical)<\/td>\n<td>tanh<\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>recurrent_activation<\/td>\n<td>(categorical)<\/td>\n<td>sigmoid<\/td>\n<td>Activation type for recurrent step<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>dropout<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Dropout rate<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>integrate_bias<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Integrate bias_ih, bias_hh to bias_h<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.GRU<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>GRU layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of output neurons<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_activation<\/td>\n<td>(categorical)<\/td>\n<td>tanh<\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>recurrent_activation<\/td>\n<td>(categorical)<\/td>\n<td>sigmoid<\/td>\n<td>Activation type for recurrent step<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>return_sequences<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Return only the last output if true, else return full output<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>dropout<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Dropout rate<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>integrate_bias<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Integrate bias_ih, bias_hh to bias_h<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>reset_after<\/td>\n<td>(boolean)<\/td>\n<td>true<\/td>\n<td>Apply reset gate before\/after the matrix<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.GRUCell<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>GRU cell layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of output neurons<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>reset_after<\/td>\n<td>(boolean)<\/td>\n<td>true<\/td>\n<td>Apply reset gate before\/after the matrix multiplication<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_activation<\/td>\n<td>(categorical)<\/td>\n<td>tanh<\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>recurrent_activation<\/td>\n<td>(categorical)<\/td>\n<td>sigmoid<\/td>\n<td>Activation type for recurrent step<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>dropout<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Dropout rate<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>integrate_bias<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Integrate bias_ih, bias_hh to bias_h<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.ZoneoutLSTMCell<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Zoneout LSTM cell layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>unit<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of output neurons<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_activation<\/td>\n<td>(categorical)<\/td>\n<td>tanh<\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>recurrent_activation<\/td>\n<td>(categorical)<\/td>\n<td>sigmoid<\/td>\n<td>Activation type for recurrent step<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>cell_state_zoneout_rate<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Zoneout rate for cell state<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>hidden_state_zoneout_rate<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Zoneout rate for hidden state<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>integrate_bias<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Integrate bias_ih, bias_hh to bias_h<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<p>The following are the available properties for each layer type which do not include (<code>weight_initializer<\/code>, <code>bias_initializer<\/code>, <code>weight_regularizer<\/code>, <code>weight_regularizer_constant<\/code>) properties.<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Type<\/th>\n<th>Key<\/th>\n<th>Value<\/th>\n<th>Default value<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>(Universal properties)<\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Universal properties that apply to every layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>name<\/td>\n<td>(string)<\/td>\n<td><\/td>\n<td>An identifier for each layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>trainable<\/td>\n<td>(boolean)<\/td>\n<td>true<\/td>\n<td>Allow weights to be trained if true<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>input_layers<\/td>\n<td>(string)<\/td>\n<td><\/td>\n<td>Comma-separated names of layers to be inputs of the current layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>input_shape<\/td>\n<td>(string)<\/td>\n<td><\/td>\n<td>Comma-separated formatted string as &quot;channel:height:width&quot;. If there is no channel then it must be 1. First layer of the model must have input_shape. Other can be omitted as it is calculated at compile phase.<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>flatten<\/td>\n<td>(boolean)<\/td>\n<td><\/td>\n<td>Flatten shape from <code>c:h:w<\/code> to <code>1:1:c*h*w<\/code><\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>activation<\/td>\n<td>(categorical)<\/td>\n<td><\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>loss<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Loss<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Input<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Input layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>normalization<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Normalize input if true<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>standardization<\/td>\n<td>(boolean)<\/td>\n<td>false<\/td>\n<td>Standardize input if true<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.BN<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Batch normalization layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>epsilon<\/td>\n<td>(float)<\/td>\n<td>0.001<\/td>\n<td>Small value to avoid dividing by zero<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>moving_mean_initializer<\/td>\n<td>(categorical)<\/td>\n<td>zeros<\/td>\n<td>Moving mean initializer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>zeros<\/td>\n<td><\/td>\n<td>Zero initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_normal<\/td>\n<td><\/td>\n<td>LeCun normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_uniform<\/td>\n<td><\/td>\n<td>LeCun uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_normal<\/td>\n<td><\/td>\n<td>Xavier normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_uniform<\/td>\n<td><\/td>\n<td>Xavier uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_normal<\/td>\n<td><\/td>\n<td>He normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_uniform<\/td>\n<td><\/td>\n<td>He uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>moving_variance_initializer<\/td>\n<td>(categorical)<\/td>\n<td>ones<\/td>\n<td>Moving variance initializer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>zeros<\/td>\n<td><\/td>\n<td>Zero initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_normal<\/td>\n<td><\/td>\n<td>LeCun normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_uniform<\/td>\n<td><\/td>\n<td>LeCun uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_normal<\/td>\n<td><\/td>\n<td>Xavier normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_uniform<\/td>\n<td><\/td>\n<td>Xavier uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_normal<\/td>\n<td><\/td>\n<td>He normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_uniform<\/td>\n<td><\/td>\n<td>He uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>gamma_initializer<\/td>\n<td>(categorical)<\/td>\n<td>ones<\/td>\n<td>Gamma initializer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>zeros<\/td>\n<td><\/td>\n<td>Zero initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_normal<\/td>\n<td><\/td>\n<td>LeCun normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_uniform<\/td>\n<td><\/td>\n<td>LeCun uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_normal<\/td>\n<td><\/td>\n<td>Xavier normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_uniform<\/td>\n<td><\/td>\n<td>Xavier uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_normal<\/td>\n<td><\/td>\n<td>He normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_uniform<\/td>\n<td><\/td>\n<td>He uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>beta_initializer<\/td>\n<td>(categorical)<\/td>\n<td>zeros<\/td>\n<td>Beta initializer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>zeros<\/td>\n<td><\/td>\n<td>Zero initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_normal<\/td>\n<td><\/td>\n<td>LeCun normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>lecun_uniform<\/td>\n<td><\/td>\n<td>LeCun uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_normal<\/td>\n<td><\/td>\n<td>Xavier normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>xavier_uniform<\/td>\n<td><\/td>\n<td>Xavier uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_normal<\/td>\n<td><\/td>\n<td>He normal initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>he_uniform<\/td>\n<td><\/td>\n<td>He uniform initialization<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>momentum<\/td>\n<td>(float)<\/td>\n<td>0.99<\/td>\n<td>Momentum for moving average in batch normalization<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Pooling2D<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Pooling layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>pooling<\/td>\n<td>(categorical)<\/td>\n<td><\/td>\n<td>Pooling type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>max<\/td>\n<td><\/td>\n<td>Max pooling<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>average<\/td>\n<td><\/td>\n<td>Average pooling<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>global_max<\/td>\n<td><\/td>\n<td>Global max pooling<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>global_average<\/td>\n<td><\/td>\n<td>Global average pooling<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>pool_size<\/td>\n<td>(array of unsigned integer)<\/td>\n<td><\/td>\n<td>Comma-separated unsigned integers for pooling size, <code>height, width<\/code>  respectively<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>stride<\/td>\n<td>(array of unsigned integer)<\/td>\n<td>1, 1<\/td>\n<td>Comma-separated unsigned integers for stride, <code>height, width<\/code>  respectively<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>padding<\/td>\n<td>(categorical)<\/td>\n<td>valid<\/td>\n<td>Padding type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>valid<\/td>\n<td><\/td>\n<td>No padding<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>same<\/td>\n<td><\/td>\n<td>Preserve height\/width dimension<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Size of padding applied uniformly to all side<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(array of unsigned integer of size 2)<\/td>\n<td><\/td>\n<td>Padding for height, width<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>(array of unsigned integer of size 4)<\/td>\n<td><\/td>\n<td>Padding for top, bottom, left, right<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Flatten<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Flatten layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Activation<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Activation layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>activation<\/td>\n<td>(categorical)<\/td>\n<td><\/td>\n<td>Activation type<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>tanh<\/td>\n<td><\/td>\n<td>Hyperbolic tangent<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>sigmoid<\/td>\n<td><\/td>\n<td>Sigmoid function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>relu<\/td>\n<td><\/td>\n<td>Relu function<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>softmax<\/td>\n<td><\/td>\n<td>Softmax function<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Addition<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Addition layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Concat<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Concat layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.MultiOut<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Multiout layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Split<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Split layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>split_dimension<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Which dimension to split. Split batch dimension is not allowed<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Permute<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Permute layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.Dropout<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Dropout layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>dropout<\/td>\n<td>(float)<\/td>\n<td>0<\/td>\n<td>Dropout rate<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.BackboneNNStreamer<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>NNStreamer layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>model_path<\/td>\n<td>(string)<\/td>\n<td><\/td>\n<td>NNStreamer model path<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.CentroidKNN<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Centroid KNN layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>num_class<\/td>\n<td>(unsigned integer)<\/td>\n<td><\/td>\n<td>Number of class<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.PreprocessFlip<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Preprocess flip layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>flip_direction<\/td>\n<td>(categorical)<\/td>\n<td><\/td>\n<td>Flip direction<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>horizontal<\/td>\n<td><\/td>\n<td>Horizontal direction<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>vertical<\/td>\n<td><\/td>\n<td>Vertical direction<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td><\/td>\n<td>horizontal_and_vertical<\/td>\n<td>horizontal_and_vertical<\/td>\n<td>Horizontal and vertical direction<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.PreprocessTranslate<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Preprocess translate layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>random_translate<\/td>\n<td>(float)<\/td>\n<td><\/td>\n<td>Translate factor value<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.PreprocessL2Norm<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Preprocess l2norm layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.LoseMSE<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>MSE loss layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.LossCrossEntropySigmoid<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Cross entropy with sigmoid loss layer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerLayerType.LossCrossEntropySoftmax<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td><\/td>\n<td>Cross entropy with softmax loss layer<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h3 id=\"content-optimizer-class\"><a href=\"#content-optimizer-class\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Optimizer class<\/h3>\n<p><code>Tizen.MachineLearning.Train.Optimizer<\/code> class determines how to update model parameters according to loss from prediction.\nCurrently, Stochastic Gradient Descent optimizer and Adam optimizer are supported:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create optimizer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">optimizer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Oprimizer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerOptimizerType.SGD);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Configure an optimizer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">optimizer.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;beta1=0.002&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;beta2=0.001&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Set optimizer to the model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ No need to destroy optimizer after setting optimizer since the ownership is transferred to the model.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetOptimizer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(optimizer);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>Following are the available properties for each optimizer type:<\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Type<\/th>\n<th>Key<\/th>\n<th>value<\/th>\n<th>Description<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>(Universal properties)<\/td>\n<td><\/td>\n<td><\/td>\n<td>Universal properties that apply to every layer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>learning_rate<\/td>\n<td>(float)<\/td>\n<td>Initial learning rate for the optimizer<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerOptimizerType.SGD<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td>Stochastic Gradient Descent optimizer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>decay_steps<\/td>\n<td>(float)<\/td>\n<td>Decay steps<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>decay_rate<\/td>\n<td>(float)<\/td>\n<td>Decay rate<\/td>\n<\/tr>\n<tr>\n<td><code>NNTrainerOptimizerType.Adam<\/code><\/td>\n<td><\/td>\n<td><\/td>\n<td>Adam optimizer<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>decay_steps<\/td>\n<td>(float)<\/td>\n<td>Decay steps<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>decay_rate<\/td>\n<td>(float)<\/td>\n<td>Decay rate<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>beta1<\/td>\n<td>(float)<\/td>\n<td>Beta1 coefficient for Adam<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>beta2<\/td>\n<td>(float)<\/td>\n<td>Beta2 coefficient for Adam<\/td>\n<\/tr>\n<tr>\n<td>\ufeff<\/td>\n<td>epsilon<\/td>\n<td>(float)<\/td>\n<td>Epsilon coefficient for Adam<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h3 id=\"content-dataset-class\"><a href=\"#content-dataset-class\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Dataset class<\/h3>\n<p><code>Tizen.MachineLearning.Train.Dataset<\/code> class is in charge of feeding data into the model.\nThe dataset can be created from a file.\nFor more information, see <a href=\"#configure-the-model\">configure the model<\/a> section.<\/p>\n<p>The following code is an example of handling <code>Tizen.MachineLearning.Train.Dataset<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">datasetFilePath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Applications.Application.Current.DirectoryInfo.Data <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;trainingSet.dat&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">NNTrainerDatasetMode<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[] <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">datasetMode<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">NNTrainerDatasetMode<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[] {<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  NNTrainerDatasetMode.Test,<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  NNTrainerDatasetMode.Train,<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  NNTrainerDatasetMode.Valid<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">};<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create dataset<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">dataset<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Dataset<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">int<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">i<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">0<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">; i <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">&lt;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">; i<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">++<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    dataset.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AddFile<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(datasetMode[i], datasetFilePath);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">    \/\/ configure dataset<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    dataset.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(datasetMode[i], <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;buffer_size=1&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ after setting a dataset to model,<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ you do not need to destroy dataset since ownership is transferred to the model.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetDataset<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(dataset);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-construct-a-model\"><a href=\"#content-construct-a-model\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Construct a model<\/h2>\n<p>A model can be constructed with the given configuration file.\nIf you have a model configuration file that describes the model, the file can be used to construct initially with <code>Tizen.MachineLearning.Train.Model(string modelConf)<\/code>.\nEven if the model is constructed from a file, switching, modifying, or setting a component is possible until you compile with <code>Tizen.MachineLearning.Train.Model.Compile()<\/code>.<\/p>\n<h3 id=\"content-construct-a-model-from-a-description-file\"><a href=\"#content-construct-a-model-from-a-description-file\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Construct a model from a description file<\/h3>\n<p>As of now, only INI formatted files <code>*.ini<\/code> are supported to construct a model from a file.<\/p>\n<h4 id=\"content-create-a-model-from-ini-formatted-file\"><a href=\"#content-create-a-model-from-ini-formatted-file\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Create a model from INI formatted file<\/h4>\n<p>Special sections <code>[Model]<\/code>, <code>[Optimizers]<\/code>, <code>[train_set]<\/code>, <code>[valid_set]<\/code>, <code>[test_set]<\/code> are respectively referring to <code>model<\/code>, <code>optimizer<\/code> and data provider objects.\nRest of INI sections map to a <code>layer<\/code>. Keys and values from each section set properties of the layer.\nAll keys and values are treated as case-insensitive.<\/p>\n<p>Following is an example of the <code>*.ini<\/code> file:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">[Model]<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Special section that describes model itself<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Type<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = NeuralNetwork  <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Model type : only NeuralNetwork is supported as of now<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">batch_size<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 9<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">####  Model run related properties<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Epochs<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 20     <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Epochs<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">[Optimizer]<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Type<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = adam  <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Optimizer : Adaptive Moment Estimation(adam)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Learning_rate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 0.0001  <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Learning rate for the optimizer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Decay_rate<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 0.96 <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># The decay rate for decaying the learning rate<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Decay_steps<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 1000       <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># decay step for the exponentially decayed learning rate<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">beta1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 0.9     <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># beta 1 for adam<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">beta2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 0.9999  <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># beta 2 for adam<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">epsilon<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 1e-7  <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># epsilon for adam<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">[train_set]<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Type<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = file<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">BufferSize<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 9<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">path<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;trainingSet.dat&quot;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">[valid_set]<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Type<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = file<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">path<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;valSet.dat&quot;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Add [test_set] section if applicable<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Layer Sections, each section name refers to name of the layer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">[inputlayer]<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Type<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = input<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Input_Shape<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 1:1:62720 <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Input dimension in channel:height:width<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Normalization<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = true<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">[outputlayer]<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Type<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = fully_connected<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Unit<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 2    <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Width of output dimension<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">bias_initializer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = zeros<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">weight_initializer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = xavier_uniform<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Activation<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = sigmoid  <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># activation : sigmoid, softmax<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">weight_regularizer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = l2norm<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">weight_regularizer_constant<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = 0.005<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">input_layers<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = inputlayer<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">[loss]<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">Type<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> = cross <\/span><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># Define loss as a layer<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The following restrictions must be adhered to:<\/p>\n<ul>\n<li>Model file must have a <code>[Model]<\/code> section.<\/li>\n<li>Model file must have at least one layer.<\/li>\n<li>Valid keys must have valid properties. The invalid keys in each section result in an error.<\/li>\n<\/ul>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>All paths inside the INI file are relative to the INI file path unless the absolute path is stated.\nConsider setting <code>save_path<\/code>, <code>train_set<\/code>, <code>valid_set<\/code>, and <code>test_set<\/code> from the code rather than describing inside the model file to avoid this behavior.<\/p>\n<\/div>\n<p>The following example constructs model from INI file:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">configurePath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Applications.Application.Current.DirectoryInfo.Resource <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;model.ini&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(configurePath);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h3 id=\"content-construct-a-model-on-code\"><a href=\"#content-construct-a-model-on-code\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Construct a model on code<\/h3>\n<p>An empty model can be constructed with <code>Tizen.MachineLearning.Train.Model()<\/code>.<\/p>\n<h2 id=\"content-configure-the-model\"><a href=\"#content-configure-the-model\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Configure the model<\/h2>\n<p>After constructing a model, the model can be configured by following the steps as described below:<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>The example code written here reproduces the model description from <a href=\"#create-a-model-from-ini-formatted-file\">create a model from INI formatted file<\/a> except the following is different:<\/p>\n<ul>\n<li>Relative path is changed to dynamic app resource and data path.<\/li>\n<li>Model related properties that can only be set at compile or run phase.<\/li>\n<\/ul>\n<\/div>\n<p>First, an empty model needs to be created:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h3 id=\"content-add-a-layer\"><a href=\"#content-add-a-layer\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Add a layer<\/h3>\n<p><code>Tizen.MachineLearning.Train.Model.AddLayer<\/code> appends a layer to the end of the graph in the model:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">inputLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Layer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerLayerType.Input);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  inputLayer.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;name=inputlayer&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;input_shape=1:1:62720&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;normalization=true&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AddLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(inputLayer);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">fcLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Layer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerLayerType.FC);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  fcLayer.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;name=outputlayer&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;unit=2&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;bias_initializer=zeros&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;weight_initializer=xavier_uniform&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;activation=sigmoid&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AddLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(fcLayer);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h3 id=\"content-get-a-layer\"><a href=\"#content-get-a-layer\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Get a layer<\/h3>\n<p><code>Tizen.MachineLearning.Train.Model.GetLayer<\/code> gets a layer from the model with the given name:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Constructs the neural network model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Creates and add a neural network layer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">inputLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Layer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerLayerType.Input);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Set a name for the layer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  inputLayer.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;name=inputlayer&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Adds layer in neural network model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AddLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(inputLayer);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Get layer from the model with the given name.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ The returned layer must not be deleted as it is owned by the model.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">layerName<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;inputlayer&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Layer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">getLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetLayer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(layername);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h3 id=\"content-set-an-optimizer\"><a href=\"#content-set-an-optimizer\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Set an optimizer<\/h3>\n<p>Create an optimizer using <code>Tizen.MachineLearning.Train.Optimizer<\/code> class and set it to the model. The manner is the same as for <code>Tizen.MachineLearning.Train.Layer<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Create an optimizer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">optimizer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Optimizer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerOptimizerType.Adam);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Configure a optimizer<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  optimizer.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;learning_rate=0.0001&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;decay_rate=0.96&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;decay_steps=1000&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;beta1=0.002&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;beta2=0.001&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;epsilon=1e-7&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ Set optimizer to the model<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetOptimizer<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(optimizer);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h3 id=\"content-set-a-dataset\"><a href=\"#content-set-a-dataset\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Set a dataset<\/h3>\n<p>The dataset can be created from a file. Here, you need to provide streams of tensor data and arrays of values representing the label, usually one-hot encoded.<\/p>\n<h4 id=\"content-sample-batch-and-epoch\"><a href=\"#content-sample-batch-and-epoch\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Sample, batch, and epoch<\/h4>\n<p>This section explains the following three concepts: sample, batch, and epoch.<\/p>\n<p>Let's assume a given model requires three inputs and two labels. This has been reflected in the examples below:<\/p>\n<ol>\n<li>\n<p>Sample<\/p>\n<p>A sample denotes a single pair of inputs\/labels. The example can be as follows:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_3<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Batch<\/p>\n<p>A batch is a bundle of samples which is fed to a single iteration. If a batch is of size 5, the batch layout, where <code>\/*<\/code> denotes nth sample will be as follows:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">4<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">5<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]],<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">4<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">5<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]],<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_3<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_3<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_3<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_3<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">4<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input_3<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">5<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]],<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">4<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_1<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">5<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]],<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">4<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label_2<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">\/<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">5<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]],<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Epoch<\/p>\n<p>An epoch refers to a full, exhaustive visit to a dataset.<\/p>\n<p>So, if you consider <a href=\"https:\/\/www.cs.toronto.edu\/~kriz\/cifar.html#The%20CIFAR-100%20dataset\">Cifar-100<\/a>{:target=&quot;_blank&quot;} dataset when using the full training set, a single training epoch will contain 50,000 samples. If the batch size is 100, it will be of 500 batches (or iterations).<\/p>\n<\/li>\n<\/ol>\n<h4 id=\"content-construct-a-dataset-on-code\"><a href=\"#content-construct-a-dataset-on-code\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Construct a dataset on code<\/h4>\n<p>An empty dataset can be constructed with <code>Tizen.MachineLearning.Train.Dataset<\/code> class.\nA data provider added with <code>NNTrainerDatasetMode.Train<\/code>, <code>NNTrainerDatasetMode.Valid<\/code>, <code>NNTrainerDatasetMode.Test<\/code> will be used when training, validating, and testing respectively.<\/p>\n<p>Consider setting property with <code>Tizen.MachineLearning.Train.Dataset.SetProperty<\/code> when the data provider needs certain properties.<\/p>\n<h4 id=\"content-set-a-dataset-from-file\"><a href=\"#content-set-a-dataset-from-file\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Set a dataset from file<\/h4>\n<p>To create a dataset from files, each file must contain an array of samples.\nA single sample consists of an array of raw float array for input and another array or raw float array for labels that contains the same size as model output:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"># If a model requires two inputs and a single label for a sample, a single sample would contain...<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">float<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">array<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">float<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">array<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]],<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">...<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">,<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">float<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">array<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">input<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">2<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">float<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">array<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label1<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]]<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>As an example, again, consider the <a href=\"https:\/\/www.cs.toronto.edu\/~kriz\/cifar.html#The%20CIFAR-100%20dataset\">Cifar-100<\/a>{:target=&quot;_blank&quot;} dataset.\nIn Cifar-100 data, it contains an image of size 3 * 32 * 32 and a coarse label of 20 classes, and a fine label of 100 classes.<\/p>\n<p>If your model requires an image and two labels (coarse, fine) both one-hot encoded for a sample, the file layout would be:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3072<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">pixels<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">20<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">floats<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">coarse<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">100<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">floats<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">fine<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]],<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">...<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">...<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[[<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">3072<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">pixels<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">20<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">floats<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">coarse<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">][<\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">100<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">floats<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">for<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">fine<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">label<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">]]<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>After preparing the file, create dataset as follows:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">datasetFilePath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Applications.Application.Current.DirectoryInfo.Data <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;trainingSet.dat&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Model<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">dataset<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Dataset<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ a file data provider to be used for training<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  dataset.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">AddFile<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerDatasetMode.Train, datasetFilePath);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  dataset.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetProperty<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(NNTrainerDatasetMode.Train, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;buffer_size=9&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetDataset<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(dataset);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The property <code>buffer_size<\/code> defines the maximum amount of batches to be queued while training. When it is not given, it is set to 1.<\/p>\n<h2 id=\"content-compile-the-model\"><a href=\"#content-compile-the-model\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Compile the model<\/h2>\n<p>Compiling a model finalizes the model with loss.\nOnce compiled, any modification to the properties of the model is restricted.\nAdding layers or changing the optimizer or dataset of the model is not permitted either:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Compile<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;loss=cross&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-train-the-model\"><a href=\"#content-train-the-model\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Train the model<\/h2>\n<p>Now, the model is ready to train. Train model as follows:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">try<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">  model.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Run<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;batch_size=9&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;epochs=20&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">catch<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Exception<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">e<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">  \/\/ handle error<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-destroy-the-model\"><a href=\"#content-destroy-the-model\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Destroy the model<\/h2>\n<p>Model will be disposed by GC, but you can use <code>Dispose()<\/code> method.\n<code>Tizen.MachineLearning.Train.Model.AddLayer<\/code>, <code>Tizen.MachineLearning.Train.Model.SetOptimizer<\/code>, and <code>Tizen.MachineLearning.Train.Model.SetDataset<\/code> transfers ownership to the model.\n<code>Tizen.MachineLearning.Train.Layer<\/code>, <code>Tizen.MachineLearning.Train.Optimizer<\/code> and <code>Tizen.MachineLearning.Train.Dataset<\/code> that belongs to the <code>model<\/code> are also deleted.<\/p>\n<h2 id=\"content-use-the-trained-model-for-inference\"><a href=\"#content-use-the-trained-model-for-inference\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Use the trained model for inference<\/h2>\n<p>The trained model can be used for inference with Machine Learning Inference APIs.\nEnsure that the INI file contains the correct weight file in <code>save_path<\/code> in <code>[Model]<\/code> section.\nThe valid INI file can be made with<code>Tizen.MachineLearning.Train.Model.Save<\/code> if you have constructed the model with the provided method.\nFor example, you can use the trained model with a single API as follows:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">using<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MachineLearning<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Inference<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">TensorInfo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">inInfo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">TensorInfo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">outInfo<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">modelFilePath<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Applications.Application.Current.DirectoryInfo.Data <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;modelFile.ini&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">..<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">single<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SingleShot<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(modelFilePath, inInfo, outInfo);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>You can use the trained model with Pipeline API as follows:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">using<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MachineLearning<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Inference<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/* framework is &#39;nntrainer&#39;*\/<\/span><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">const<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">string<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">description<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;appsrc ! other\/tensor,dimension=(string)2:1:1:1,type=(string)  int8,framerate=(fraction)0\/1 ! tensor_filter framework=nntrainer model=model.ini ! tensor_sink&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">pipeline<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Pipeline<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(description);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-related-information\"><a href=\"#content-related-information\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Related information<\/h2>\n<ul>\n<li>\n<p>Dependencies<\/p>\n<ul>\n<li>Tizen 7.0 and Higher<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>API References<\/p>\n<ul>\n<li><a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.MachineLearning.Train.md\">Tizen.MachineLearning.Train<\/a> namespace<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-prerequisites\">Prerequisites<\/a><\/li>\n<li><a href=\"#content-building-blocks\">Building blocks<\/a><\/li>\n<li><a href=\"#content-model-class\">Model class<\/a><\/li>\n<li><a href=\"#content-layer-class\">Layer class<\/a><\/li>\n<li><a href=\"#content-optimizer-class\">Optimizer class<\/a><\/li>\n<li><a href=\"#content-dataset-class\">Dataset class<\/a><\/li>\n<li><a href=\"#content-construct-a-model\">Construct a model<\/a><\/li>\n<li><a href=\"#content-construct-a-model-from-a-description-file\">Construct a model from a description file<\/a><\/li>\n<li><a href=\"#content-create-a-model-from-ini-formatted-file\">Create a model from INI formatted file<\/a><\/li>\n<li><a href=\"#content-construct-a-model-on-code\">Construct a model on code<\/a><\/li>\n<li><a href=\"#content-configure-the-model\">Configure the model<\/a><\/li>\n<li><a href=\"#content-add-a-layer\">Add a layer<\/a><\/li>\n<li><a href=\"#content-get-a-layer\">Get a layer<\/a><\/li>\n<li><a href=\"#content-set-an-optimizer\">Set an optimizer<\/a><\/li>\n<li><a href=\"#content-set-a-dataset\">Set a dataset<\/a><\/li>\n<li><a href=\"#content-sample-batch-and-epoch\">Sample, batch, and epoch<\/a><\/li>\n<li><a href=\"#content-construct-a-dataset-on-code\">Construct a dataset on code<\/a><\/li>\n<li><a href=\"#content-set-a-dataset-from-file\">Set a dataset from file<\/a><\/li>\n<li><a href=\"#content-compile-the-model\">Compile the model<\/a><\/li>\n<li><a href=\"#content-train-the-model\">Train the model<\/a><\/li>\n<li><a href=\"#content-destroy-the-model\">Destroy the model<\/a><\/li>\n<li><a href=\"#content-use-the-trained-model-for-inference\">Use the trained model for inference<\/a><\/li>\n<li><a href=\"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Machine Learning Train","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"89Yz2lZbCCgvbSOWDuJk","name":"__mountParamsContainer","path":"docs\/application\/dotnet\/guides\/machine-learning\/machine-learning-train","method":"GET","release":"a-a-a"},"checksum":"c635d3f704bd5761e342443e7192f795f970f72e8fa197dfff9a2a66b292a9ad"}')" >