This application is based on and claims priority under 35 USC § 119 to Korean Patent Application No. 10-2021-0085534 filed on Jun. 30, 2021 and to Korean Patent Application No. 10-2021-0114779 filed on Aug. 30, 2021 in the Korean Intellectual Property Office (KIPO), the contents of which are herein incorporated by reference in their entireties.
Example embodiments relate generally to machine learning techniques, and more particularly to methods of optimizing neural network models, and neural network model processing systems performing the methods of optimizing the neural network models.
There are various methods of classifying data based on machine learning. Among them is a method of classifying data using a neural network or an artificial neural network (ANN). The ANN may be obtained by engineering a cell structure model of a human brain where a process of efficiently recognizing a pattern is performed. The ANN refers to a calculation model that is based on software or hardware and is designed to imitate biological calculation abilities by applying many artificial neurons interconnected through connection lines. The human brain consists of neurons that are basic units of a nerve, and encrypts or decrypts information according to different types of dense connections between these neurons. Artificial neurons in the ANN are obtained through simplification of biological neuron functionality. The ANN performs a cognition or learning process by interconnecting the artificial neurons having connection intensities.
Recently, deep learning processes and services have been researched to overcome limitation of the ANN, and researches are conducting various research projects of analyzing and optimizing improving neural network models as the deep learning processes and services have been developed. Conventionally, optimization techniques using general-purpose algorithms have been used.
At least one example embodiment of the disclosure provides a method of efficiently optimizing a neural network model to be most appropriate or suitable for a target device.
At least one example embodiment of the disclosure provides a neural network model processing system that performs the method of optimizing the neural network model.
At least one example embodiment of the disclosure provides a method of efficiently operating the neural network model.
According to example embodiments, in a method of optimizing a neural network model, first model information about a first neural network model is received. Device information about a first target device used to execute the first neural network model is received. An analysis whether the first neural network model is suitable for executing on the first target device is performed, based on the first model information, the device information and at least one of a plurality of suitability determination algorithms. A result of the analysis is output such that the first model information and the result of the analysis are displayed on a screen.
According to example embodiments, a neural network model processing system includes an input device, a storage device, an output device and a processor. The input device receives first model information about a first neural network model and device information about a first target device used to execute the first neural network model. The storage device stores information about program routines. The program routines are configured to cause the processor to perform an analysis whether the first neural network model is suitable for executing on the first target device, based on the first model information, the device information and at least one of a plurality of suitability determination algorithms, and to generate a result of the analysis such that the first model information and the result of the analysis are displayed on a screen. The output device visually outputs the result of the analysis. The processor is connected to the input device, the storage device and the output device, and controls execution of the program routines.
According to example embodiments, in a method of optimizing a neural network model, a graphical user interface (GUI) for optimizing the neural network model is provided. First model information about a first neural network model that is to be optimized is received through the GUI. Device information about a first target device used to execute the first neural network model is received through the GUI. An analysis whether the first neural network model is suitable for executing on the first target device is performed, based on the first model information, the device information and at least one of a plurality of suitability determination algorithms. A result of the analysis is visually output on the GUI such that the first model information and the result of the analysis are displayed on one screen. A first user input for selecting a first layer from among layers of the first neural network model is received through the GUI based on the result of the analysis. The first layer is changed into a second layer based on the first user input. A result of changing the first layer into the second layer is visually output on the GUI. A second user input for selecting a third layer from among the layers of the first neural network model is received through the GUI. A quantization scheme of the third layer is changed based on the second user input. A result of changing the quantization scheme of the third layer is visually output on the GUI. When performing the analysis, performance scores of a structure and the layers of the first neural network model are obtained by performing a first analysis on the first neural network model based on a first algorithm. The first algorithm is used to determine performance efficiency of the structure and the layers of the first neural network model associated with the first target device. Complexity scores of the structure and the layers of the first neural network model are obtained by performing a second analysis on the first neural network model based on a second algorithm. The second algorithm is used to analyze complexity and capacity of the structure and the layers of the first neural network model. Memory footprint scores of the structure and the layers of the first neural network model are obtained by performing a third analysis on the first neural network model based on a third algorithm. The third algorithm is used to determine memory efficiency of the structure and the layers of the first neural network model associated with the first target device. Total scores of the first neural network model are obtained based on the performance scores, the complexity scores and the memory footprint scores.
According to example embodiments, in a method, a graphical user interface (GUI) is provided. First model information about a first neural network model is received. Device information about a first target device used to execute the first neural network model is received. An analysis whether the first neural network model is suitable for executing on the first target device is performed, based on the first model information, the device information and at least one of a plurality of suitability determination algorithms. A first graphical representation is displayed on the GUI such that the first model information and a result of the analysis are displayed on one screen. The first graphical representation includes the first model information and the result of the analysis. A second graphical representation is displayed on the GUI such that a result of changing at least one of the layers of the first neural network model based on the result of the analysis is displayed. The second graphical representation includes the process and the result of changing the at least one of the layers of the first neural network model.
Illustrative, non-limiting example embodiments will be more clearly understood from the following detailed description taken in conjunction with the accompanying drawings.
Various example embodiments will be described more fully with reference to the accompanying drawings, in which example embodiments are shown. The disclosure may, however, be embodied in many different forms and should not be construed as limited to the example embodiments set forth herein. Like reference numerals refer to like elements throughout this application.
Referring to
In the method of optimizing the neural network model according to example embodiments, first model information of a first neural network model is received (step S100). For example, the first neural network model may be a neural network model in which a training has been completed (e.g., a pre-trained neural network model), or may be a neural network model in which a training is being performed. In other words, the method of optimizing the neural network model according to example embodiments may be performed and/or executed after the training on the first neural network model is completed, or while the training on the first neural network model is performed. Examples of the neural network model will be described with reference to
A training (or training operation) on a neural network model indicates a process of solving a task in an optimized manner when the task to be solved and a set of functions for the task are given, and indicates a process for improving or enhancing the performance and/or accuracy of the neural network model. For example, the training on the neural network model may include an operation of determining a network structure of the neural network model, an operation of determining parameters, such as weights, used in the neural network model, or the like. In addition, during the training on the neural network model, parameters other than an architecture and data type may be changed while the architecture and data type are maintained.
Device information of a first target device used to execute or drive the first neural network model is received (step S200). For example, the first target device may include a processing element that executes or drives the first neural network model, and/or a neural network system (or electronic system) that includes the processing element. An example of the neural network system will be described with reference to
An analysis whether the first neural network model is appropriate for executing or driving on the first target device is performed, based on the first model information, the device information, and at least one of a plurality of suitability determination algorithms (step S300). For example, the plurality of suitability determination algorithms may include a first algorithm that is used to determine performance efficiency of the first neural network model, a second algorithm that is used to analyze complexity and capacity of the first neural network model, a third algorithm that is used to determine memory efficiency of the first neural network model, or the like. Examples of the plurality of suitability determination algorithms and the analysis in step S300 will be described with reference to
A result of the analysis is visualized and output such that the first model information and the result of the analysis are displayed on a screen (step S400). For example, step S400 may be performed using a graphical user interface (GUI). For example, the result of the analysis may be displayed based on at least one of scores and color, and a graphic representation including the first model information and the result of the analysis may be displayed on the GUI such that the first model information and the result of the analysis are displayed together. The GUI will be described with reference to
In the method of optimizing the neural network model according to example embodiments, a neural network model determined to be most appropriate or suitable for a target device may be efficiently implemented. For example, before a training is performed on a neural network model, the neural network model optimized for the target device may be designed. After the training is completed on the neural network model, it may be checked and/or determined whether the neural network model is suitable for the target device, and if necessary, the neural network model may be modified and/or a new configuration that is more suitable may be suggested. In addition, optimized performance may be obtained by applying suitable quantization scheme to each component of the neural network model. Further, the GUI for such operations may be provided. Accordingly, a user may efficiently design and modify the neural network model to be most optimized for the target device, and may apply the suitable quantization scheme.
Referring to
The processor 1100 may be used to perform the method of optimizing the neural network model according to example embodiments. For example, the processor 1100 may include a microprocessor, an application processor (AP), a digital signal processor (DSP), a graphic processing unit (GPU), or the like. Although only one processor 1100 is illustrated in
The storage device 1200 may store and/or include a program (PR) 1210 for the method of optimizing the neural network model according to example embodiments. The storage device 1200 may further store and/or include suitability determination algorithms (SDA) 1220, updating algorithms (UA) 1230 and quantization schemes (QS) 1240 that are used to perform the method of optimizing the neural network model according to example embodiments. The program 1210, the suitability determination algorithms 1220, the updating algorithms 1230 and the quantization schemes 1240 may be provided from the storage device 1200 to the processor 1100.
In some example embodiments, the storage device 1200 may include at least one of various non-transitory computer-readable storage mediums used to provide commands and/or data to a computer. For example, the non-transitory computer-readable storage mediums may include a volatile memory such as a static random access memory (SRAM), a dynamic random access memory (DRAM), or the like, and/or a nonvolatile memory such as a flash memory, a magnetoresistive random access memory (MRAM), a phase-change random access memory (PRAM), a resistive random access memory (RRAM), or the like. The non-transitory computer-readable storage mediums may be inserted into the computer, may be integrated in the computer, or may be connected to the computer through a communication medium such as a network and/or a wireless link.
The input device 1310 may be used to receive an input for the method of optimizing the neural network model according to example embodiments. For example, the input device 1310 may receive model information MI and device information DI, and may further receive a user input. For example, the input device 1310 may include at least one of various input means, such as a keyboard, a keypad, a touch pad, a touch screen, a mouse, a remote controller, or the like.
The output device 1320 may be used to provide an output for the method of optimizing the neural network model according to example embodiments. For example, the output device 1320 may provide visualized output VOUT. For example, the output device 1320 may include an output means for displaying the visualized output VOUT, such as a display device, and may further include at least one of various output means, such as a speaker, a printer, or the like.
The neural network model processing system 1000 may perform the method of optimizing the neural network model according to example embodiments, which is described with reference to
Referring to
In some example embodiments, the neural network model processing system 2000 may be a computing system. For example, the computing system may be a fixed computing system such as a desktop computer, a workstation or a server, or may be a portable computing system such as a laptop computer.
The processor 2100 may be substantially the same as or similar to the processor 1100 in
In other words, the program PR may include a plurality of instructions and/or procedures executable by the processor 2100, and the plurality of instructions and/or procedures included in the program PR may allow the processor 2100 to perform the method of optimizing the neural network model according to example embodiments. Each of the procedures may denote a series of instructions for performing a certain task. A procedure may be referred to as a function, a routine, a subroutine, or a subprogram. Each of the procedures may process data provided from the outside and/or data generated by another procedure.
The storage device 2600 may be substantially the same as or similar to the storage device 1200 in
The storage device 2600 may store data, which is to be processed by the processor 2100, or data obtained through processing by the processor 2100. The processor 2100 may process the data stored in the storage device 2600 to generate new data, based on the program PR and may store the generated data in the storage device 2600.
The I/O device 2200 may be substantially the same as or similar to the I/O device 1300 in
The network interface 2300 may provide access to a network outside the neural network model processing system 2000. For example, the network may include a plurality of computing systems and communication links, and the communication links may include wired links, optical links, wireless links, or arbitrary other type links. The model information MI and the device information DI in
Referring to
Herein, the term “module” may indicate, but is not limited to, a software and/or hardware component, such as a field programmable gate array (FPGA) or an application specific integrated circuit (ASIC), which performs certain tasks. A module may be configured to reside in a tangible addressable storage medium and be configured to execute on one or more processors. For example, a “module” may include components such as software components, object-oriented software components, class components and task components, and processes, functions, routines, segments of program code, drivers, firmware, microcode, circuitry, data, databases, data structures, tables, arrays, and variables. A “module” may be divided into a plurality of “modules” that perform detailed functions.
The analysis module 300 may perform an analysis (or analyzing operation) whether a neural network model is appropriate for executing on a target device, based on suitability determination algorithms (e.g., the suitability determination algorithms SDA in
The analysis module 300 may include a pre-listed table (PT) 310 for the target device, a performance estimator (PE) 320, a pre-trained deep learning model (PM) 330 for the target device, a complexity determining unit (CD) 340, a capacity measuring unit (CM) 350, and a memory estimator (ME) 360. Detailed operations associated with the analysis using each component will be described with reference to
The updating module 400 may perform an update (or updating algorithms) on the neural network model based on updating algorithms (e.g., the updating algorithms UA in
The quantization module 500 may perform a quantization (or quantizing operation) on the neural network model based on quantization schemes (e.g., the quantization schemes QS in
The GUI control module 200 may control a GUI to perform an optimization on the neural network model. For example, the GUI control module 200 may control the GUI to receive a user input UI and to output a graphical representation GR. For example, the user input UI may include the model information MI and the device information DI in
In some example embodiments, at least some elements of the neural network model optimizing module 100 may be implemented as instruction codes or program routines (e.g., a software program). For example, the instruction codes or the program routines may be executed by a computer-based electronic system, and may be stored in any storage device located inside or outside the computer-based electronic system. In other example embodiments, at least some elements of the neural network model optimizing module 100 may be implemented as hardware. For example, at least some elements of the neural network model optimizing module 100 may be included in a computer-based electronic system.
Referring to
The input layer IL may include i input nodes x1, x2, . . . , xi, where i is a natural number. Input data (e.g., vector input data) IDAT whose length is i may be input to the input nodes x1, x2, . . . , xi such that each element of the input data IDAT is input to a respective one of the input nodes x1, x2, . . . , xi.
The plurality of hidden layers HL1, HL2, HLn may include n hidden layers, where n is a natural number, and may include a plurality of hidden nodes h11, h12, h13, h1m, h21, h22, h23, . . . h2m, hn1, hn2, hn3, . . . hnm. For example, the hidden layer HL1 may include m hidden nodes h11, h12, h13, . . . h1m, the hidden layer HL2 may include m hidden nodes h21, h22, h23, . . . , h2m, and the hidden layer HLn may include m hidden nodes hn1, hn2, hn3, . . . , hnm, where m is a natural number.
The output layer OL may include j output nodes y1, y2, . . . yj, where j is a natural number. Each of the output nodes y1, y2, . . . yj may correspond to a respective one of classes to be categorized. The output layer OL may generate output values (e.g., class scores or numerical output such as a regression variable) and/or output data ODAT associated with the input data IDAT for each of the classes. In some example embodiments, the output layer OL may be a fully-connected layer and may indicate, for example, a probability that the input data IDAT corresponds to a car.
A structure of the neural network illustrated in
Each node (e.g., the node WO may receive an output of a previous node (e.g., the node x1), may perform a computing operation, computation or calculation on the received output, and may output a result of the computing operation, computation or calculation as an output to a next node (e.g., the node h21). Each node may calculate a value to be output by applying the input to a specific function, e.g., a nonlinear function.
In some example embodiments, the structure of the neural network is set in advance, and the weighted values for the connections between the nodes are set appropriately by using data having an already known answer of which class the data belongs to (sometimes referred to as a “label”). The data with the already known answer is sometimes referred to as “training data”, and a process of determining the weighted value is sometimes referred to as “training”. The neural network “learns” to associate the data with corresponding labels during the training process. A group of an independently trainable structure and the weighted value is sometimes referred to as a “model”, and a process of predicting, by the model with the determined weighted value, which class input data belongs to, and then outputting the predicted value, is sometimes referred to as a “testing” process.
The general neural network illustrated in
Referring to
Unlike the general neural network, each layer of the CNN may have three dimensions of a width, a height and a depth, and thus data that is input to each layer may be volume data having three dimensions of a width, a height and a depth. For example, if an input image in
Each of the convolutional layers CONV1, CONV2, CONV3, CONV4, CONV5 and CONV6 may perform a convolutional operation on input volume data. In an image processing, the convolutional operation indicates an operation in which image data is processed based on a mask with weighted values and an output value is obtained by multiplying input values by the weighted values and adding up the total multiplication results. The mask may be referred to as a filter, a window or a kernel.
Parameters of each convolutional layer may include a set of learnable filters. Every filter may be small spatially (along a width and a height), but may extend through the full depth of an input volume. For example, during the forward pass, each filter may be slid (e.g., convolved) across the width and height of the input volume, and dot products may be computed between the entries of the filter and the input at any position. As the filter is slid over the width and height of the input volume, a two-dimensional activation map corresponding to responses of that filter at every spatial position may be generated. As a result, an output volume may be generated by stacking these activation maps along the depth dimension. For example, if input volume data having a size of 32*32*3 passes through the convolutional layer CONV1 having four filters with zero-padding, output volume data of the convolutional layer CONV1 may have a size of 32*32*12 (e.g., a depth of volume data increases).
Each of the RELU layers RELU1, RELU2, RELU3, RELU4, RELU5 and RELU6 may perform a rectified linear unit (RELU) operation that corresponds to an activation function defined by, e.g., a function f(x)=max(0, x) (e.g., an output is zero for all negative input x). For example, if input volume data having a size of 32*32*12 passes through the RELU layer RELU1 to perform the rectified linear unit operation, output volume data of the RELU layer RELU1 may have a size of 32*32*12 (e.g., a size of volume data is maintained).
Each of the pooling layers POOL1, POOL2 and POOL3 may perform a down-sampling operation on input volume data along spatial dimensions of width and height. For example, four input values arranged in a 2*2 matrix formation may be converted into one output value based on a 2*2 filter. For example, a maximum value of four input values arranged in a 2*2 matrix formation may be selected based on 2*2 maximum pooling, or an average value of four input values arranged in a 2*2 matrix formation may be obtained based on 2*2 average pooling. For example, if input volume data having a size of 32*32*12 passes through the pooling layer POOL1 having a 2*2 filter, output volume data of the pooling layer POOL1 may have a size of 16*16*12 (e.g., a width and a height of volume data decreases, and a depth of volume data is maintained).
Typically, one convolutional layer (e.g., CONV1) and one RELU layer (e.g., RELU1) may form a pair of CONV/RELU layers in the CNN, pairs of the CONV/RELU layers may be repeatedly arranged in the CNN, and the pooling layer may be periodically inserted in the CNN, thereby reducing a spatial size of image and extracting a characteristic of image.
The output layer or fully-connected layer FC may output results (e.g., class scores) of the input volume data IDAT for each of the classes. For example, the input volume data IDAT corresponding to the two-dimensional image may be converted into a one-dimensional matrix or vector as the convolutional operation and the down-sampling operation are repeated. For example, the fully-connected layer FC may indicate probabilities that the input volume data IDAT corresponds to a car, a truck, an airplane, a ship and a horse.
The types and number of layers included in the CNN may not be limited to an example described with reference to
Referring to
A structure illustrated on the right side of
In the RNN in
In the RNN in
In the RNN in
In the RNN in
Referring to
The plurality of heterogeneous resources may include a central processing unit (CPU) 610, a neural processing unit (NPU) 620, a graphic processing unit (GPU) 630, a digital signal processor (DSP) 640 and an image signal processor (ISP) 650, and may further include a dedicated hardware (DHW) 660, a memory (MEM) 670, a direct memory access unit (DMA) 680 and a connectivity 690. The CPU 610, the NPU 620, the GPU 630, the DSP 640, the ISP 650 and the dedicated hardware 660 may be referred to as processors, processing units (PE), computing resources, etc. The DMA 680 and the connectivity 690 may be referred to as communication resources.
The CPU 610, the NPU 620, the GPU 630, the DSP 640, the ISP 650 and the dedicated hardware 660 may perform various computational functions such as particular calculations and tasks, and may be used to execute a neural network model. For example, the dedicated hardware 660 may include a vision processing unit (VPU), a vision intellectual property (VIP), etc. The memory 670 may operate as a working memory or a data storage for data processed by the plurality of heterogeneous resources, and may store data associated with the neural network model. The DMA 680 may control an access to the memory 670. For example, the DMA 680 may include a memory DMA (MDMA), a peripheral DMA (PDMA), a remote DMA (RDMA), a smart DMA (SDMA), etc. The connectivity 690 may perform wire/wireless communication with an internal element and/or an external device. For example, the connectivity 690 may include an internal bus that supports an internal communication such as a system bus, peripheral component interconnect (PCI), PCI express (PCIe), etc., and/or may support an external communication such as a mobile telecommunication, universal serial bus (USB), Ethernet, WiFi, Bluetooth, near field communication (NFC), radio frequency identification (RFID), etc.
Although not illustrates in
In some example embodiments, the neural network system 600 may be included in any computing device and/or mobile device.
In some example embodiments, at least one of various services and/or applications, e.g., a computer vision (e.g., image classifying, image detection, image segmentation, image tracking, etc.) service, a user authentication service based on bio-information or biometric data, an advanced driver assistance system (ADAS) service, a voice assistant service, an automatic speech recognition (ASR) service, or the like, may be performed, executed and/or processed by the neural network model described with reference to
Referring to
As described with reference to
Referring to
For example, it may be analyzed whether the structure and the layers of the first neural network model are efficient for the first target device based on the pre-listed table 310 (step S312a), and the first scores may be obtained based on a result of step S312a (step S312b). For example, the pre-listed table 310 used in step S312a may be a table or list in which structures and layers that are efficient and/or inefficient for inference in the first target device are pre-defined. For example, the pre-listed table 310 may be included in the model information (e.g., the model information MI in
In addition, second scores of the structure and the layers of the first neural network model may be obtained by predicting processing time of the structure and the layers of the first neural network model using a performance estimator (e.g., the performance estimator 320 in
For example, the performance of the structure and the layers of the first neural network model may be analyzed using the performance estimator 320 (step S314a), and the second scores may be obtained based on a result of step S314a (step S314b). For example, the performance estimator 320 used in step S314a may be a tool for estimating the processing time of the neural network model, and may be implemented in the form of software and/or hardware. For example, the scoring in step S314b may be performed such that a structure and/or layer that drop the performance are represented, and a higher score may be given for a structure or layer having higher performance and a lower score may be given for a structure or layer having lower performance.
Further, third scores of the structure and the layers of the first neural network model may be obtained using a pre-trained deep learning model (e.g., the pre-trained deep learning model 330 in
For example, the pre-trained deep learning model 330 used in step S316 may be a model that is trained using different components depending on the first target device. For example, the pre-trained deep learning model 330 may be included in the model information MI, and may be received with the model information MI. For example, the scoring in step S316 may be performed based on a determination output of the pre-trained deep learning model 330.
In other words, in step S312, the structures and/or layers of the models that are efficient and/or inefficient for the inference in the first target device may be pre-defined, the inefficient layer may be detected using the pre-listed table 310, and a defined solution may be provided. In step S314, each component may be simulated using the tool for estimating the processing time, and the performance of each component may be predicted and scored. In step S316, the deep learning model may be pre-trained by recording the performance obtained by executing several models having various structures and layers on the first target device, and the performance and suitability of each component of the first neural network model may be measured using the pre-trained deep learning model.
Although
Performance scores of the structure and the layers of the first neural network model may be obtained based on the first scores, the second scores and the third scores (step S318). For example, the performance scores may be obtained based on a weight summing scheme in which the first, second and third scores are summed with different weights. For example, the weights may be differently set for each target device. For example, first, second and third weights for the first, second and third scores may be included in the model information MI, and may be received with the model information MI.
In some example embodiments, the first scores, the second scores, the third scores, and the performance scores may be obtained for each of the structure and the layers of the first neural network model.
Referring to
In step S320, the optimization point may be determined and guided by analyzing the complexity and capacity of the structure and the layers of the first neural network model, and a result of the determination may be scored and visually displayed in step S400.
Referring to
For example, the complexity of the structure and the layers of the first neural network model may be analyzed by using a complexity determining unit (e.g., the complexity determining unit 340 in
In some example embodiments, a criterion for determining the complexity by the complexity determining unit 340 may include the number of parameters, units and layers included in the neural network model. In some example embodiments, a scheme and/or algorithm for determining the complexity by the complexity determining unit 340 may include a complexity evaluation function, which is disclosed in the paper “On the Complexity of Neural Network Classifiers: A Comparison Between Shallow and Deep Architectures” by Monica Bianchini and Franco Scarselli. However, example embodiments are not limited thereto, and the complexity may be determined and/or checked using various criteria, schemes and/or algorithms.
In addition, fifth scores of the structure and the layers of the first neural network model may be obtained by measuring the capacity of the structure and the layers of the first neural network model (step S324).
For example, the capacity of the structure and the layers of the first neural network model may be analyzed by using a capacity measuring unit (e.g., the capacity measuring unit 350 in
In some example embodiments, a scheme and/or algorithm for measuring the capacity by the capacity measuring unit 350 may include an algorithm, which is disclosed in the paper “Deep Neural Network Capacity” by Aosen Wang et al. However, example embodiments are not limited thereto, and the capacity may be measured using various criteria, schemes and/or algorithms.
In other words, in step S322, the degree of overhead in which the first neural network model is executed on the first target device may be measured using the algorithm for determining the complexity of the first neural network model, and the overhead of the first neural network model may be predicted by measuring the performance of the first target device depending on the complexity of the first neural network model. In step S324, the capacity of the first neural network model may be measured, the optimization point may be determined and guided using the capacity of the first neural network model, and it may be easier to optimize the first neural network model as the capacity of the first neural network model become large.
Although
Complexity scores of the structure and the layers of the first neural network model may be obtained based on the fourth scores and the fifth scores (step S326). For example, the complexity scores may be obtained based on a weight summing scheme in which the fourth and fifth scores are summed with different weights. For example, the weights may be differently set for each target device. For example, fourth and fifth weights for the fourth and fifth scores may be included in the model information MI, and may be received with the model information MI.
In some example embodiments, the fourth scores, the fifth scores, and the complexity scores may be obtained for each of the structure and the layers of the first neural network model.
Referring to
In step S330, the optimization point depending on the memory utilization may be determined and guided by analyzing the memory footprint of the structure and the layers of the first neural network model, and a result of the determination may be scored and visually displayed in step S400.
Referring to
For example, due to the characteristic of the first target device, there may be the limitation of a memory such as an SRAM, a DRAM, or the like, and thus the performance of the first target device may vary depending on the limitation of the memory (e.g., read/write operations). The memory usage, bottleneck point, memory sharing, or the like, which may occur in each operation depending on the structure and/or type of the first neural network model, may be calculated in advance using a memory estimator (e.g., the memory estimator 360 in
In some example embodiments, the memory footprint scores may be obtained for each of the structure and the layers of the first neural network model.
Referring to
When the first neural network model is unavailable (or is not available) within the memory limitation (step S512: NO), the first neural network model may be changed, modified or updated (step S514). For example, the first neural network model may be changed depending on the memory usage, bottleneck point, memory sharing, or the like. Steps S512 and S514 may correspond to step S500 in
When the first neural network model is available within the memory limitation (step S512: YES), the process may be terminated without changing the first neural network model.
Referring to
Total scores of the first neural network model may be obtained based on the performance scores obtained in step S310, the complexity scores obtained in step S320 and the memory footprint scores obtained in step S330 (step S340). For example, the total scores may be obtained based on a weight summing scheme in which the performance scores, the complexity scores and the memory footprint scores are summed with different weights. For example, the weights may be differently set for each target device. For example, the weights for the performance scores, the complexity scores and the memory footprint scores may be included in the model information MI, and may be received with the model information MI.
Referring to
The first model information of the first neural network model is received through the GUI (step S100a). The device information of the first target device used to execute or drive the first neural network model is received through the GUI (step S200a). The analysis whether the first neural network model is appropriate for executing or driving on the first target device is performed, based on the first model information, the device information, and at least one of the plurality of suitability determination algorithms (step S300). The result of the analysis is displayed on the GUI such that the first model information and the result of the analysis are displayed on a screen (step S400a). Steps S100a, S200a and S400a may be similar to steps S100, S200 and S400 in
Referring to
Referring to
In some example embodiments, the graphical representations GR12, GR13, GR14 and GR15 of
However, example embodiments are not limited thereto, and graphical representations may be implemented using different shapes, or the like, as long as the graphical representations may indicate a layer having a lower score in a visually distinguishable manner from other layers.
In some example embodiments, one of the buttons 112, 114, 116 and 118 may be selected by receiving a user input using an input device 1310 such as, for example, a mouse or a touch screen included in the neural network model processing system 1000.
Referring to
At least one of the layers of the first neural network model is changed or modified based on the result of the analysis (step S500). For example, as with step S400, a result of the model change may be visualized and output in step S500, and S500 may be performed using the GUI. For example, step S500 may be performed by the updating module 400 in
Referring to
Referring to
The process and the result of the model change may be displayed on the GUI such that the first model information and the process and the result of the model change are displayed on a screen (step S500a). Step S500a may be similar to step S500 in
Referring to
Referring to
Referring to
Referring to
In some example embodiments, the layer and corresponding layer box may be selected in
As described above, the neural network model may be changed or modified using the visual interface based on the suitability determination algorithm, and the neural network model optimized for the target device may be designed by repeating such modification process. From simple modifications to new alternative structures may be proposed, and both an automatic optimization function and a conditional optimization function based on a user's input condition may be provided.
Referring to
Different quantization schemes are applied to at least some of the layers of the first neural network model (step S600). For example, as with step S400, a result of the quantization scheme change may be visualized and output in step S600, and S600 may be performed using the GUI. For example, step S600 may be performed by the quantization module 500 in
Referring to
Unlike steps S100, S200, S300 and S400, step S600 may be performed after the training on the first neural network model is completed. For example, the second model information may be obtained by changing at least a part of the first model information. For example, although not illustrated in detail, step S500 in
A quantization is a kind of a compression on a neural network model. A compression (or compressing operation) on a neural network model indicates a process for reducing the size and amount of computation of the neural network model while the performance and/or accuracy of the neural network model that is pre-trained are maintained as much as possible. A quantization (or quantizing operation) indicates a technique for reducing a size in which a neural network model is actually stored by decreasing weights, which are generally expressed in floating points, to the specific number of bits.
Referring to
The process and the result of the quantization scheme change may be displayed on the GUI such that the second model information and the process and the result of the quantization scheme change are displayed on a screen (step S600a). Step S600a may be similar to step S600 in
Referring to
Referring to
Referring to
As described above, the accuracy of the quantization scheme applied to each component may be checked, and the accuracy may be improved by applying different quantization schemes to components depending on the loss rate by the degree of distribution restoration. For example, an algorithm to detect a suitable quantization scheme for each layer and feature map depending the degree of loss may be provided by comparing the quantization accuracy of layers and feature maps of the floating point model. An optimized quantization performance may be obtained by applying different quantization schemes to each component and checking a result immediately. A user may arbitrarily set the target minimum/maximum range for one or multiple components, may set the quantization distribution mode, and may perform a re-quantization by differently applying an asymmetric scheme, a symmetric scheme, or the like, and/or by applying different bit-widths.
Referring to
The inventive concept may be applied to various electronic devices and systems that include the deep learning, ANN and/or machine learning systems. For example, the inventive concept may be applied to systems such as a personal computer (PC), a server computer, a data center, a workstation, a mobile phone, a smart phone, a tablet computer, a laptop computer, a personal digital assistant (PDA), a portable multimedia player (PMP), a digital camera, a portable game console, a music player, a camcorder, a video player, a navigation device, a wearable device, an internet of things (IoT) device, an internet of everything (IoE) device, an e-book reader, a virtual reality (VR) device, an augmented reality (AR) device, a robotic device, a drone, etc.
In the method of optimizing the neural network model and the neural network model processing system according to example embodiments, a neural network model to be most appropriate or suitable for a target device may be efficiently implemented. For example, before a training is performed on a neural network model, the neural network model optimized for the target device may be designed. After the training is completed on the neural network model, it may be checked and/or determined whether the neural network model is suitable for the target device, and if necessary, the neural network model may be modified and/or a new configuration that is more suitable may be suggested. In addition, optimized performance may be obtained by applying suitable quantization scheme to each component of the neural network model. Further, the GUI for such operations may be provided. Accordingly, a user may efficiently design and modify the neural network model to be most optimized for the target device, and may apply the suitable quantization scheme.
At least one of the components, elements, modules or units (collectively “components” in this paragraph) represented by a block in the drawings may be embodied as various numbers of hardware, software and/or firmware structures that execute respective functions described above, according to an example embodiment. According to example embodiments, at least one of these components may use a direct circuit structure, such as a memory, a processor, a logic circuit, a look-up table, etc. that may execute the respective functions through controls of one or more microprocessors or other control apparatuses. Also, at least one of these components may be specifically embodied by a module, a program, or a part of code, which contains one or more executable instructions for performing specified logic functions, and executed by one or more microprocessors or other control apparatuses. Further, at least one of these components may include or may be implemented by a processor such as a central processing unit (CPU) that performs the respective functions, a microprocessor, or the like. Two or more of these components may be combined into one single component which performs all operations or functions of the combined two or more components. Also, at least part of functions of at least one of these components may be performed by another of these components. Functional aspects of the above exemplary embodiments may be implemented in algorithms that execute on one or more processors. Furthermore, the components represented by a block or processing steps may employ any number of related art techniques for electronics configuration, signal processing and/or control, data processing and the like.
The foregoing is illustrative of example embodiments and is not to be construed as limiting thereof. Although some example embodiments have been described, those skilled in the art will readily appreciate that many modifications are possible in the example embodiments without materially departing from the novel teachings and advantages of the example embodiments. Accordingly, all such modifications are intended to be included within the scope of the example embodiments as defined in the claims. Therefore, it is to be understood that the foregoing is illustrative of various example embodiments and is not to be construed as limited to the specific example embodiments disclosed, and that modifications to the disclosed example embodiments, as well as other example embodiments, are intended to be included within the scope of the appended claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
10-2021-0085534 | Jun 2021 | KR | national |
10-2021-0114779 | Aug 2021 | KR | national |