This disclosure relates to the field of artificial intelligence (AI) technologies, and in particular, to an image classification method and a related device thereof.
Image object detection is one of the important tasks of computer vision, and has important applications in fields such as self-driving and industrial vision. For a detection task of a specific type of objects (for example, an industrial machine or a power grid device), obtaining an image of this type of objects is costly. Therefore, only a small quantity of images can be obtained. Therefore, a small-sample object detection technology emerges.
A neural network model used in the small-sample object detection technology includes two branches. An input of one branch is a reference image (which may also be referred to as a support image), and an input of the other branch is a to-be-classified image (which may also be referred to as a query image). When the model classifies the to-be-classified image, a large quantity of reference images belonging to a basic category and a small quantity of reference images belonging to a new category are usually input. Under the actions of these reference images, the model may detect that a category of the to-be-classified image is the basic category or the new category.
In an image classification process, a quantity of reference images belonging to the basic category greatly differs from a quantity of reference images belonging to the new category. The model is prone to ignoring impact caused by the reference image of the new category. When the category of the to-be-classified image is actually the new category, the model is prone to determining the to-be-classified image as the basic category by mistake, resulting in low accuracy of image classification.
Embodiments of this disclosure provide an image classification method and a related device thereof, to accurately identify an image belonging to a new category, and not to determine the image belonging to the new category as an image belonging to a basic category by mistake, thereby improving accuracy of image classification.
A first aspect of embodiments of this disclosure provides an image classification method, where the method is implemented by using an image classification model, and the method includes:
When a category of a to-be-classified image needs to be determined, a reference image related to the to-be-classified image may be first obtained.
After the to-be-classified image and the reference image are obtained, the reference image and the to-be-classified image may be input to the image classification model, to obtain a first feature of the reference image and a second feature of the to-be-classified image by using the image classification model.
Then, a third feature of the to-be-classified image is generated based on the first feature of the reference image and the second feature of the to-be-classified image by using the image classification model.
Then, by using the image classification model, a first classification result of the reference image is generated based on the first feature of the reference image, and a second classification result of the to-be-classified image is generated based on the third feature of the to-be-classified image. The first classification result may be considered as a final classification result of the reference image (that is, one output of the image classification model). Therefore, a category of the reference image may be determined based on the first classification result. The second classification result may be considered as a preliminary classification result of the to-be-classified image. In this disclosure, the result is not used to determine the category of the to-be-classified image.
Finally, a third classification result (that is, another output of the image classification model) is generated based on the first classification result of the reference image and the second classification result of the to-be-classified image by using the image classification model. The third classification result may be considered as a final classification result of the to-be-classified image. Therefore, the category of the to-be-classified image may be determined based on the third classification result.
It can be learned from the foregoing method that, after the reference image and the to-be-classified image are input to the image classification model, the image classification model may perform the following steps: obtaining the first feature of the reference image and the second feature of the to-be-classified image; then generating the third feature based on the first feature and the second feature; then generating the first classification result based on the first feature, where the first classification result may be used to determine the category of the reference image, and generating the second classification result based on the third feature; finally generating the third classification result based on the first classification result and the second classification result; and determining the category of the to-be-classified image based on the obtained third classification result. It can be learned that, in a process in which the image classification model generates the third classification result of the to-be-classified image, the first classification result of the reference image is integrated. This is equivalent to that the image classification model focuses on category information of the reference image. Regardless of whether the category of the reference image belongs to a new category or a basic category, the model can notice impact caused by the category of the reference image in a classification process of the to-be-classified image. Therefore, the model does not fit the new category to the basic category. In other words, if the to-be-classified image is an image belonging to the new category, the image classification model may accurately determine the category of the to-be-classified image as a category in the new category, and does not determine the category of the to-be-classified image as a category in the basic category by mistake, thereby improving accuracy of image classification.
In a possible implementation, the generating the third classification result based on the first classification result and the second classification result includes: performing addition processing on the first classification result and the second classification result to obtain a fourth classification result; performing addition processing on the first classification result and a model parameter of the image classification model to obtain a fifth classification result; performing multiplication processing on the fifth classification result and a preset weight parameter to obtain a sixth classification result; and performing subtraction processing on the fourth classification result and the sixth classification result to obtain the third classification result. In the foregoing implementation, the second classification result of the to-be-classified image is adjusted by using the first classification result of the reference image (that is, the first classification result and the second classification result are added), to obtain the fourth classification result of the to-be-classified image. However, if the category of the reference image is the same as the category of the to-be-classified image, the first classification result of the reference image has a positive adjustment effect on the second classification result of the to-be-classified image. If the category of the reference image is different from the category of the to-be-classified image, the first classification result of the reference image has a negative adjustment effect on the second classification result of the to-be-classified image. To make the final classification result of the to-be-classified image accurate enough, impact brought by the two cases needs to be balanced. After the fourth classification result of the to-be-classified image is obtained, a series of processing may be performed: performing addition processing on the first classification result of the reference image and the model parameter of the image classification model to obtain the fifth classification result of the reference image; performing multiplication processing on the fifth classification result of the reference image and the preset weight parameter to obtain a sixth classification result of the reference image; and performing subtraction processing on the fourth classification result of the to-be-classified image and the sixth classification result of the reference image to obtain the third classification result of the to-be-classified image. In this way, the third classification result of the to-be-classified image has sufficient accuracy, and may be considered as the final classification result of the to-be-classified image. Therefore, the category of the to-be-classified image may be determined based on the third classification result.
In a possible implementation, the generating the third classification result based on the first classification result and the second classification result includes: the image classification model directly performs addition on the first classification result of the reference image and the second classification result of the to-be-classified image to obtain the third classification result of the to-be-classified image. The third classification result of the to-be-classified image may be considered as the final classification result of the to-be-classified image. Therefore, the category of the to-be-classified image may be determined based on the third classification result.
In a possible implementation, the generating the first classification result based on the first feature includes: calculating, based on the first feature of the reference image, a probability that the reference image belongs to each category, to obtain the first classification result of the reference image. Because the first classification result of the reference image includes the probability that the reference image belongs to each category (that is, a probability that a target object presented in the reference image belongs to each category), the category of the reference image may be determined based on the first classification result. Further, the first classification result may further include location information of the target object in the reference image.
The generating the second classification result based on the third feature includes: calculating, based on the third feature of the to-be-classified image, a probability that the to-be-classified image belongs to each category, to obtain the second classification result of the to-be-classified image. Because the second classification result of the to-be-classified image includes the probability that the to-be-classified image belongs to each category (that is, a probability that a target object presented in the to-be-classified image belongs to each category), the second classification result may be used to determine the category of the to-be-classified image (but the second classification result is not used to determine the category of the to-be-classified image in this embodiment of this disclosure). Further, the second classification result may further include location information of the target object in the to-be-classified image.
In a possible implementation, the generating the third feature based on the first feature and the second feature includes: performing feature fusion processing on the first feature of the reference image and the second feature of the to-be-classified image to obtain the third feature of the to-be-classified image.
In a possible implementation, the feature fusion processing includes at least one of addition processing, multiplication processing, subtraction processing, concatenation processing, and concatenation convolution processing.
In a possible implementation, the obtaining the first feature of the reference image and the second feature of the to-be-classified image includes: performing feature extraction processing on the reference image to obtain the first feature of the reference image; and performing feature extraction processing on the to-be-classified image to obtain the second feature of the to-be-classified image.
A second aspect of embodiments of this disclosure provides a model training method. The method includes: obtaining a reference image and a to-be-classified image; inputting the reference image and the to-be-classified image to a to-be-trained model to obtain a third classification result of the to-be-classified image, where the to-be-trained model is configured to: obtain a first feature of the reference image and a second feature of the to-be-classified image; generate a third feature based on the first feature and the second feature; generate a first classification result based on the first feature; generate a second classification result based on the third feature; and generate the third classification result based on the first classification result and the second classification result; determining a first predicted category of the reference image based on the first classification result, and determining a second predicted category of the to-be-classified image based on the third classification result; obtaining a target loss based on a first reality category of the reference image, the first predicted category of the reference image, a second reality category of the to-be-classified image, and the second predicted category of the to-be-classified image, where the target loss indicates a difference between the first reality category and the first predicted category, and a difference between the second reality category and the second predicted category; and updating a model parameter of the to-be-trained model based on the target loss until a model training condition is met, to obtain an image classification model.
The image classification model obtained based on the foregoing method has a capability of classifying the to-be-classified image by using the reference image. In an image classification process, the image classification model may focus on category information of the reference image. Regardless of whether a category of the reference image is a new category or a basic category, the model can notice impact caused by the category of the reference image in a classification process of the to-be-classified image. Therefore, the model does not fit the new category to the basic category. In other words, if the to-be-classified image is an image belonging to the new category, the image classification model may accurately determine the category of the to-be-classified image as a category in the new category, and does not determine the category of the to-be-classified image as a category in the basic category by mistake, thereby improving accuracy of image classification.
In a possible implementation, the obtaining a target loss based on a first reality category of the reference image, the first predicted category of the reference image, a second reality category of the to-be-classified image, and the second predicted category of the to-be-classified image includes: obtaining a first sub-loss based on the first reality category and the first predicted category of the reference image, where the first sub-loss indicates the difference between the first reality category and the first predicted category; obtaining a second sub-loss based on the second reality category and the second predicted category of the to-be-classified image, where the second sub-loss indicates the difference between the second reality category and the second predicted category; and performing addition processing on the first sub-loss and the second sub-loss to obtain the target loss.
In a possible implementation, the to-be-trained model is configured to perform addition processing on the first classification result and the second classification result to obtain the third classification result.
In a possible implementation, the to-be-trained model is configured to: calculate, based on the first feature, a probability that the reference image belongs to each category, to obtain the first classification result; and calculate, based on the third feature, a probability that the to-be-classified image belongs to each category, to obtain the second classification result.
In a possible implementation, the to-be-trained model is configured to perform feature fusion processing on the first feature and the second feature to obtain the third feature.
In a possible implementation, the feature fusion processing includes at least one of addition processing, multiplication processing, subtraction processing, concatenation processing, and concatenation convolution processing.
In a possible implementation, the to-be-trained model is configured to: perform feature extraction processing on the reference image to obtain the first feature; and perform feature extraction processing on the to-be-classified image to obtain the second feature.
A third aspect of embodiments of this disclosure provides an image classification apparatus. The apparatus includes: a feature extraction module, configured to obtain a first feature of a reference image and a second feature of a to-be-classified image; a feature fusion module, configured to generate a third feature based on the first feature and the second feature; a first classification module, configured to generate a first classification result based on the first feature, where the first classification result is used to determine a category of the reference image; a second classification module, configured to generate a second classification result based on the third feature; and a classification result adjustment module, configured to generate a third classification result based on the first classification result and the second classification result, where the third classification result is used to determine a category of the to-be-classified image.
It can be learned from the foregoing apparatus that, after the reference image and the to-be-classified image are input to an image classification model, the image classification model may perform the following steps: obtaining the first feature of the reference image and the second feature of the to-be-classified image; then generating the third feature based on the first feature and the second feature; then generating the first classification result based on the first feature, where the first classification result may be used to determine the category of the reference image, and generating the second classification result based on the third feature; finally generating the third classification result based on the first classification result and the second classification result; and determining the category of the to-be-classified image based on the obtained third classification result. It can be learned that, in a process in which the image classification model generates the third classification result of the to-be-classified image, the first classification result of the reference image is integrated. This is equivalent to that the image classification model focuses on category information of the reference image. Regardless of whether the category of the reference image is a new category or a basic category, the model can notice impact caused by the category of the reference image in a classification process of the to-be-classified image. Therefore, the model does not fit the new category to the basic category. In other words, if the to-be-classified image is an image belonging to the new category, the image classification model may accurately determine the category of the to-be-classified image as a category in the new category, and does not determine the category of the to-be-classified image as a category in the basic category by mistake, thereby improving accuracy of image classification.
In a possible implementation, the classification result adjustment module is configured to perform addition processing on the first classification result and the second classification result to obtain the third classification result.
In a possible implementation, the classification result adjustment module is configured to: perform addition processing on the first classification result and the second classification result to obtain a fourth classification result; perform addition processing on the first classification result and a model parameter of the image classification model to obtain a fifth classification result; perform multiplication processing on the fifth classification result and a preset weight parameter to obtain a sixth classification result; and perform subtraction processing on the fourth classification result and the sixth classification result to obtain the third classification result.
In a possible implementation, the first classification module is configured to calculate, based on the first feature, a probability that the reference image belongs to each category, to obtain the first classification result; and the second classification module is configured to calculate, based on the third feature, a probability that the to-be-classified image belongs to each category, to obtain the second classification result.
In a possible implementation, the feature fusion module is configured to perform feature fusion processing on the first feature and the second feature to obtain the third feature.
In a possible implementation, the feature fusion processing includes at least one of addition processing, multiplication processing, subtraction processing, concatenation processing, and concatenation convolution processing.
In a possible implementation, the feature extraction module includes a first feature extraction module and a second feature extraction module. The first feature extraction module is configured to perform feature extraction processing on the reference image to obtain the first feature, and the second feature extraction module is configured to perform feature extraction processing on the to-be-classified image to obtain the second feature.
A fourth aspect of embodiments of this disclosure provides a model training apparatus. The apparatus includes: an obtaining module, configured to obtain a reference image and a to-be-classified image; a processing module, configured to input the reference image and the to-be-classified image to a to-be-trained model to obtain a third classification result of the to-be-classified image, where the to-be-trained model is configured to: obtain a first feature of the reference image and a second feature of the to-be-classified image; generate a third feature based on the first feature and the second feature; generate a first classification result based on the first feature; generate a second classification result based on the third feature; and generate a third classification result based on the first classification result and the second classification result; a determining module, configured to determine a first predicted category of the reference image based on the first classification result, and determine a second predicted category of the to-be-classified image based on the third classification result; a computation module, configured to obtain a target loss based on a first reality category of the reference image, the first predicted category of the reference image, a second reality category of the to-be-classified image, and the second predicted category of the to-be-classified image, where the target loss indicates a difference between the first reality category and the first predicted category, and a difference between the second reality category and the second predicted category; and an update module, configured to update a model parameter of the to-be-trained model based on the target loss until a model training condition is met, to obtain an image classification model.
The image classification model obtained based on the foregoing apparatus has a capability of classifying the to-be-classified image by using the reference image. In an image classification process, the image classification model may focus on category information of the reference image. Regardless of whether a category of the reference image is a new category or a basic category, the model can notice impact caused by the category of the reference image in a classification process of the to-be-classified image. Therefore, the model does not fit the new category to the basic category. In other words, if the to-be-classified image is an image belonging to the new category, the image classification model may accurately determine the category of the to-be-classified image as a category in the new category, and does not determine the category of the to-be-classified image as a category in the basic category by mistake, thereby improving accuracy of image classification.
In a possible implementation, the computation module is configured to: obtain a first sub-loss based on the first reality category and the first predicted category of the reference image, where the first sub-loss indicates the difference between the first reality category and the first predicted category; obtain a second sub-loss based on the second reality category and the second predicted category of the to-be-classified image, where the second sub-loss indicates the difference between the second reality category and the second predicted category; and perform addition processing on the first sub-loss and the second sub-loss to obtain the target loss.
In a possible implementation, the to-be-trained model is configured to perform addition processing on the first classification result and the second classification result to obtain the third classification result.
In a possible implementation, the to-be-trained model is configured to: calculate, based on the first feature, a probability that the reference image belongs to each category, to obtain the first classification result; and calculate, based on the third feature, a probability that the to-be-classified image belongs to each category, to obtain the second classification result.
In a possible implementation, the to-be-trained model is configured to perform feature fusion processing on the first feature and the second feature to obtain the third feature.
In a possible implementation, the feature fusion processing includes at least one of addition processing, multiplication processing, subtraction processing, concatenation processing, and concatenation convolution processing.
In a possible implementation, the to-be-trained model is configured to: perform feature extraction processing on the reference image to obtain the first feature; and perform feature extraction processing on the to-be-classified image to obtain the second feature.
A fifth aspect of embodiments of this disclosure provides an image classification apparatus. The apparatus includes a memory and a processor. The memory stores code, the processor is configured to execute the code, and when the code is executed, the image classification apparatus performs the method according to any one of the first aspect or the possible implementations of the first aspect.
A sixth aspect of embodiments of this disclosure provides a model training apparatus. The apparatus includes a memory and a processor. The memory stores code, the processor is configured to execute the code, and when the code is executed, the model training apparatus performs the method according to any one of the second aspect or the possible implementations of the second aspect.
A seventh aspect of embodiments of this disclosure provides a circuit system. The circuit system includes a processing circuit. The processing circuit is configured to perform the method according to any one of the first aspect, the possible implementations of the first aspect, the second aspect, or the possible implementations of the second aspect.
An eighth aspect of embodiments of this disclosure provides a chip system. The chip system includes a processor. The processor is configured to invoke a computer program or computer instructions stored in a memory, so that the processor performs the method according to any one of the first aspect, the possible implementations of the first aspect, the second aspect, or the possible implementations of the second aspect.
In a possible implementation, the processor is coupled to the memory through an interface.
In a possible implementation, the chip system further includes a memory. The memory stores a computer program or computer instructions.
A ninth aspect of embodiments of this disclosure provides a computer storage medium. The computer storage medium stores a computer program. When the program is executed by a computer, the computer is enabled to perform the method according to any one of the first aspect, the possible implementations of the first aspect, the second aspect, or the possible implementations of the second aspect.
A tenth aspect of embodiments of this disclosure provides a computer program product. The computer program product stores instructions. When the instructions are executed by a computer, the computer is enabled to perform the method according to any one of the first aspect, the possible implementations of the first aspect, the second aspect, or the possible implementations of the second aspect.
In embodiments of this disclosure, after a reference image and a to-be-classified image are input to an image classification model, the image classification model may perform the following steps: obtaining a first feature of the reference image and a second feature of the to-be-classified image; then generating a third feature based on the first feature and the second feature; then generating a first classification result based on the first feature, where the first classification result may be used to determine a category of the reference image, and generating a second classification result based on the third feature; finally generating a third classification result based on the first classification result and the second classification result; and determining a category of the to-be-classified image based on the obtained third classification result. It can be learned that, in a process in which the image classification model generates the third classification result of the to-be-classified image, the first classification result of the reference image is integrated. This is equivalent to that the image classification model focuses on category information of the reference image. Regardless of whether the category of the reference image is a new category or a basic category, the model can notice impact caused by the category of the reference image in a classification process of the to-be-classified image. Therefore, the model does not fit the new category to the basic category. In other words, if the to-be-classified image is an image belonging to the new category, the image classification model may accurately determine the category of the to-be-classified image as a category in the new category, and does not determine the category of the to-be-classified image as a category in the basic category by mistake, thereby improving accuracy of image classification.
Embodiments of this disclosure provide an image classification method and a related device thereof, to accurately identify an image belonging to a new category, and not to determine the image belonging to the new category as an image belonging to a basic category by mistake, thereby improving accuracy of image classification.
In the specification, claims, and the accompanying drawings of this disclosure, the terms “first”, “second”, and the like are intended to distinguish similar objects but do not necessarily indicate a specific order or sequence. It should be understood that the terms used in such a way are interchangeable in proper circumstances, and this is merely a discrimination manner for describing objects having a same attribute in embodiments of this disclosure. In addition, the terms “include”, “contain” and any other variants mean to cover the non-exclusive inclusion, so that a process, method, system, product, or device that includes a series of units is not necessarily limited to those units, but may include other units not expressly listed or inherent to such a process, method, system, product, or device.
Object detection on images is one of the important tasks of computer vision, and has important applications in fields such as self-driving and industrial vision. For a detection task of a specific type of objects (for example, an industrial machine or a power grid device), costs for obtaining an image of the type of objects are huge. Therefore, only a small quantity of images can be obtained. Therefore, a small sample object detection technology emerges.
A neural network model used in an image object detection technology includes two branches. An input of one branch is a reference image (which may also be referred to as a support image), and an input of the other branch is a to-be-classified image (which may also be referred to as a query image). In a training process of the model, the reference image usually includes a large quantity of images belonging to the basic category and a small quantity of images belonging to the new category. The model is trained by jointly using the reference image and the to-be-classified image, so that the trained model has a capability of detecting whether the image belongs to the basic category or the new category. For example, the basic category may be a common transportation, including a vehicle, a bicycle, a motorcycle, and the like, and the new category is a less common transportation, including an airplane, a high-speed railway, and the like.
In the foregoing training process, because there are a large quantity of images of the basic category and a small quantity of images of the new category, when the trained model performs image classification, an image belonging to the new category is prone to being determined as an image of the basic category by mistake, resulting in a poor image classification effect. Still as in the foregoing example, a large quantity of vehicle images, bicycle images, and motorcycle images are used in the model training process, and only a small quantity of airplane images are used. In this case, when an airplane image is input to a trained model for classification, the model is prone to determining a category of the image as one of a vehicle, a bicycle, and a motorcycle by mistake.
To resolve the foregoing problem, this disclosure provides an image classification method. The method may be implemented with reference to an AI technology. The AI technology is a technical discipline that is used to simulate, extend, and expand human intelligence by using a digital computer or a machine controlled by a digital computer. The AI technology obtains an optimal result by sensing the environment, obtaining knowledge, and using knowledge. In other words, the AI technology is a branch of computer science, and is intended to understand essence of intelligence and produce a new intelligent machine that can react in a manner similar to human intelligence. Using AI for image processing is a common application manner of AI.
An overall working procedure of an AI system is first described with reference to
The infrastructure provides computing capability support for the AI system, implements communication with the external world, and implements support by using a basic platform. The infrastructure communicates with the outside by using a sensor. A computing capability is provided by a smart chip (a hardware acceleration chip such as a central processing unit (CPU), a network processing unit (NPU), a graphics processing unit (GPU), an application-specific integrated circuit (ASIC), or a field-programmable gate array (FPGA)). The basic platform includes related platforms, for example, a distributed computing framework and a network, for assurance and support. The basic platforms may include a cloud storage and computing network, an interconnection network, and the like. For example, the sensor communicates with the outside to obtain data, and the data is provided for the smart chip in a distributed computing system provided by the basic platform for computing.
Data at an upper layer of the infrastructure indicates a data source in the field of AI. The data relates to a graph, an image, speech, and text, further relates to internet of things data of a device, and includes service data of an existing system and perception data such as a force, displacement, a liquid level, a temperature, and humidity.
Data processing usually includes a manner such as data training, machine learning, deep learning, searching, inference, or decision-making.
Machine learning and deep learning may mean performing symbolic and formalized intelligent information modeling, extraction, preprocessing, training, and the like on data.
Inference is a process in which a human intelligent inference manner is simulated in a computer or an intelligent system, and machine thinking and problem resolving are performed by using formal information according to an inference control policy. A typical function is searching and matching.
Decision-making is a process in which a decision is made after intelligent information is inferred, and usually provides functions such as classification, ranking, and prediction.
After data processing mentioned above is performed on data, some general capabilities may be further formed based on a data processing result, for example, an algorithm or a general system, such as translation, text analysis, computer vision processing, voice recognition, and image recognition.
The smart product and industry application are products and applications of the AI system in various fields. The smart product and industry application involve packaging overall AI solutions, to productize and apply intelligent information decision-making. Application fields of the intelligent information decision-making mainly include smart terminals, smart transportation, smart health care, autonomous driving, smart cities, and the like.
The following describes several application scenarios of this disclosure.
The data processing device may be a device or a server with a data processing function, such as a cloud server, a network server, an application server, or a management server. The data processing device receives the image processing request from the smart terminal through an interaction interface, and then performs, by using a memory storing data and a processor processing data, image processing in a manner of machine learning, deep learning, searching, inference, decision-making, or the like. The memory in the data processing device may be a general name, and includes a local storage and a database storing historical data. The database may be in the data processing device, or may be in another network server.
In the image processing system shown in
In
In the image processing system shown in
In
The user equipment in
The processor in
In a process in which the execution device 110 preprocesses the input data, or in a process in which a computation module 111 of the execution device 110 performs related processing such as computing (for example, performs function implementation of a neural network in this disclosure), the execution device 110 may invoke data, code, and the like in a data storage system 150 for corresponding processing, and may further store, in the data storage system 150, data, an instruction, and the like that are obtained through the corresponding processing.
Finally, the I/O interface 112 returns a processing result to the client device 140, to provide the processing result for the user.
It should be noted that a training device 120 may generate corresponding target models/rules for different targets or different tasks based on different training data. The corresponding target models/rules may be used to implement the foregoing targets or complete the foregoing tasks, to provide a required result for the user. The training data may be stored in a database 130, and is a training sample collected by a data collection device 160.
In a case shown in
It should be noted that
An embodiment of this disclosure further provides a chip. The chip includes a neural network processing unit NPU. The chip may be disposed in the execution device 110 shown in
The neural network processing unit NPU serves as a coprocessor, and may be disposed on a host CPU. The host CPU assigns a task. A core part of the NPU is an operation circuit. A controller controls the operation circuit to extract data in a memory (a weight memory or an input memory) and perform an operation.
In some implementations, the operation circuit includes a plurality of process engines (PEs) inside. In some implementations, the operation circuit is a two-dimensional systolic array. The operation circuit may alternatively be a one-dimensional systolic array or another electronic circuit capable of performing mathematical operations such as multiplication and addition. In some implementations, the operation circuit is a general-purpose matrix processor.
For example, it is assumed that there is an input matrix A, a weight matrix B, and an output matrix C. The operation circuit fetches, from a weight memory, data corresponding to the matrix B, and caches the data on each PE in the operation circuit. The operation circuit fetches data of the matrix A from an input memory to perform a matrix operation on the matrix B, and stores an obtained partial result or an obtained final result of the matrix in an accumulator.
A vector computation unit may perform further processing such as vector multiplication, vector addition, an exponential operation, a logarithmic operation, or value comparison on an output of the operation circuit. For example, the vector computation unit may be configured to perform network computation, such as pooling, batch normalization, or local response normalization at a non-convolutional/non-fully connected (non-FC) layer in a neural network.
In some implementations, the vector computation unit can store a processed output vector in a unified cache. For example, the vector computation unit may apply a nonlinear function to the output, for example, a vector of an accumulated value, of the operation circuit to generate an activation value. In some implementations, the vector computation unit generates a normalized value, a combined value, or both a normalized value and a combined value. In some implementations, the processed output vector can be used as an activated input to the operation circuit, for example, the processed output vector can be used at a subsequent layer of the neural network.
A unified memory is configured to store input data and output data.
For weight data, a direct memory access controller (DMAC) directly transfers input data from an external memory to the input memory and/or the unified memory, stores, in the weight memory, weight data in the external memory, and stores, in the external memory, data in the unified memory.
A bus interface unit (BIU) is configured to implement interaction between the host CPU, the DMAC, and an instruction fetch buffer by using a bus.
The instruction fetch buffer connected to the controller is configured to store instructions used by the controller.
The controller is configured to invoke the instructions cached in the instruction fetch buffer, to control a working process of an operation accelerator.
Usually, the unified memory, the input memory, the weight memory, and the instruction fetch buffer each are an on-chip memory. The external memory is a memory outside the NPU. The external memory may be a double data rate synchronous dynamic random-access memory (DDR SDRAM), a high bandwidth memory (HBM), or another readable and writable memory.
Embodiments of this disclosure relate to massive application of a neural network. Therefore, for ease of understanding, the following first describes terms and concepts related to the neural network in embodiments of this disclosure.
The neural network may include a neuron. The neuron may be an operation unit that uses xs and an intercept of 1 as an input. An output of the operation unit may be as follows:
h
W, b(x)=f(WTx)=f(Σs=1nWsxs+b) (1)
s=1, 2, . . . , or n. n is a natural number greater than 1. Ws is a weight of xs. b is a bias of the neuron. f is an activation function (activation functions) of the neuron, and is used to introduce a nonlinear feature into the neural network, to convert an input signal in the neuron into an output signal. The output signal of the activation function may be used as an input of a next convolutional layer. The activation function may be a sigmoid function. The neural network is a network formed by connecting a plurality of single neurons together. To be specific, an output of a neuron may be an input of another neuron. An input of each neuron may be connected to a local receptive field of a previous layer to extract a feature of the local receptive field. The local receptive field may be a region including several neurons.
Work at each layer of the neural network may be described by using a mathematical expression y=a(Wx+b). From a physical layer, work at each layer of the neural network may be understood as completing transformation from input space to output space (namely, from row space to column space of a matrix) by performing five operations on the input space (a set of input vectors). The five operations include: 1. dimension increasing/dimension reduction; 2. scaling up/scaling down; 3. rotation; 4. translation; and 5. “bending”. The operation 1, 2, and 3 are performed by Wx, the operation 4 is performed by +b , and the operation 5 is performed by a( ). The word “space” is used herein for expression because a classified object is not a single thing, but a type of things. Space is a collection of all individuals of such type of things. W is a weight vector, and each value in the vector indicates a weight value of one neuron in the neural network at this layer. The vector W determines the space transformation from the input space to the output space described above, that is, a weight W of each layer controls a method for space transformation. An objective of training the neural network is to finally obtain a weight matrix (a weight matrix formed by vectors W at a plurality of layers) at all layers of a trained neural network. Therefore, a training process of the neural network is essentially a manner of learning control of space transformation, and more specifically, learning a weight matrix.
Because it is expected that an output of the neural network is as close as possible to a value that is actually expected to be predicted, a current predicted value of the network may be compared with a target value that is actually expected, and then a weight vector at each layer of the neural network is updated based on a difference between the current predicted value and the target value (certainly, there is usually an initialization process before a first update, that is, a parameter is preconfigured for each layer of the neural network). For example, if the predicted value of the network is large, the weight vector is adjusted to lower the predicted value, and adjustment is continuously performed until the neural network can predict the target value that is actually expected. Therefore, “how to obtain a difference between the predicted value and the target value through comparison” needs to be predefined. This is a loss function or an objective function. The loss function and the objective function are important equations that measure the difference between the predicted value and the target value. The loss function is used as an example. A higher output value (loss) of the loss function indicates a larger difference. Therefore, training of the neural network is a process of minimizing the loss.
In a training process, a neural network may correct a value of a parameter of an initial neural network model by using an error BP algorithm, so that a reconstruction error loss of the neural network model becomes increasingly smaller. An input signal is forward transferred until the error loss is generated in an output, and the parameter of the initial neural network model is updated through BP of information about the error loss, to converge the error loss. The BP algorithm is an error-loss-centered BP motion intended to obtain a parameter, such as a weight matrix, of an optimal neural network model.
The following describes the method provided in this disclosure from a neural network training side and a neural network application side.
A model training method provided in embodiments of this disclosure relates to image processing. The model training method may be applied to data processing methods such as data training, machine learning, and deep learning. Symbolized and formalized intelligent information modeling, extraction, preprocessing, training, and the like are performed on training data (for example, a reference image and a to-be-classified image in this disclosure), to finally obtain a trained neural network (for example, an image classification model in this disclosure). In addition, the foregoing trained neural network may be used in an image processing method provided in embodiments of this disclosure. Input data (for example, the reference image and the to-be-classified image in this disclosure) is input to the trained neural network, to obtain output data (for example, a first classification result of the reference image and a third classification result of the to-be-classified image in this disclosure). It should be noted that the model training method and the image processing method that are provided in embodiments of this disclosure may be generated based on a same idea, or may be understood as two parts of a system or two phases, such as a model training phase and a model application phase, of an overall procedure.
When the category of the to-be-classified image needs to be determined, the reference image related to the to-be-classified image may be first obtained. It should be noted that a quantity of reference images is usually greater than a quantity of to-be-classified images. Categories of different reference images are usually different (in other words, different reference images present objects of different categories). A quantity of reference images belonging to a basic category is usually relatively large, a quantity of reference images belonging to a new category is usually relatively small. A category to which the to-be-classified image belongs is usually one of categories to which a plurality of reference images belong. For example, as shown in
Then, the reference image is input to the first feature extraction module of the image classification model, so that feature extraction processing may be performed on the reference image by using the first feature extraction module, to obtain the first feature of the reference image. Similarly, the to-be-classified image is input to the second feature extraction module of the image classification model, so that feature extraction processing is performed on the to-be-classified image by using the second feature extraction module, to obtain the second feature of the to-be-classified image.
A plurality of reference images may be input into a first feature extraction module Es. For any reference image Si (namely, an ith reference image), the first feature extraction module Es may perform feature extraction processing on a reference image Si to obtain a first feature Es(Si) of the reference image Si. Similarly, a to-be-classified image Q may be input to a second feature extraction module Eq. The second feature extraction module Eq may divide the to-be-classified image into a plurality of image subblocks. The second feature extraction module Eq may perform feature extraction processing on any image subblock Qj (namely, a jth image block) to obtain a second feature Eq(Qj ) of the image subblock Qj of the to-be-classified image Q.
After obtaining the first feature of the reference image, the first feature extraction module may send the first feature of the reference image to the feature fusion module. Similarly, after obtaining the second feature of the to-be-classified image, the second feature extraction module may input the second feature of the to-be-classified image to the feature fusion module. In this way, the feature fusion module may perform feature fusion processing on the first feature and the second feature to obtain the third feature of the to-be-classified image. The feature fusion processing may include at least one of addition processing, multiplication processing, subtraction processing, concatenation processing, and concatenation convolution processing.
The first feature extraction module Es may input first features of all reference images to a feature fusion module T, and the second feature extraction module Eq may input second features of all image subblocks of the to-be-classified image to the feature fusion module T. Therefore, the feature fusion module T may perform feature fusion on the first features of all the reference images and the second features of all the image subblocks of the to-be-classified image to obtain a plurality of third features. For example, the feature fusion module T may perform feature fusion on the first feature Es(Si) of the reference image Si and the second feature Eq(Qj ) of the image subblock Qj to obtain a third feature T(Si, Qj). In this case, the third feature T(Si, Qj) may be considered as a third feature obtained for the image subblock Qj of the to-be-classified image Q under an action of the reference image Si. In addition, a third feature obtained for the image subblock Qj of the to-be-classified image Q under an action of a remaining reference image may be further obtained. Therefore, a third feature obtained for the image subblock Qj of the to-be-classified image Q under an action of each reference image may be considered as a third feature of the image subblock Qj of the to-be-classified image Q. In this way, third features of each image subblock of the to-be-classified image Q (that is, third features of the to-be-classified image Q) may be obtained.
After obtaining the first feature of the reference image, the first feature extraction module may further input the first feature of the reference image to the first classification module. In this case, the first classification module may calculate, based on the first feature of the reference image, a probability that the reference image belongs to each category, to obtain the first classification result (that is, a final classification result of the reference image). Because the first classification result includes the probability that the reference image belongs to each category (that is, a probability that a target object presented in the reference image belongs to each category), the category of the reference image may be determined based on the first classification result. In addition, the first classification result may further include location information (for example, two-dimensional coordinates) of the target object in the reference image.
For example, it is assumed that the reference image is an image presenting a bicycle. After obtaining a first feature of the image, the first classification module may calculate, based on the first feature of the image, a probability that the image belongs to each category such as a vehicle, an airplane, a train, and a bicycle, to obtain a first classification result of the image. The classification result includes a probability that the image belongs to a vehicle category, a probability that the image belongs to an airplane category, a probability that the image belongs to a train category, a probability that the image belongs to a bicycle category, and the like. Therefore, based on these probabilities, a category to which the image belongs may be determined (generally, in the classification result, the probability that the image belongs to a bicycle is the largest, and therefore, it may be determined that the image belongs to a bicycle category). In addition, the classification result may further include two-dimensional coordinates of the bicycle in the image.
The first feature extraction module Es may input first features of all the reference images to a first classification module Ps. The first classification module Ps may calculate a first feature Es(Si) of any reference image Si to obtain a first classification result bis, cis of the reference image Si. bis is coordinates of a target object in the reference image Si in the reference image Si, and cis is a probability that the reference image Si belongs to each category (in other words, category probability distribution of the reference image Si). In this case, after it is determined, from cis, that a probability that the reference image Si belongs to a category is the largest, it may be determined that the reference image Si belongs to the category.
After obtaining the third feature of the to-be-classified image, the feature fusion module may send the third feature to the second classification module. In this case, the second classification module may calculate, based on the third feature of the to-be-classified image, a probability that the to-be-classified image belongs to each category, to obtain the second classification result. Because the second classification result includes the probability that the to-be-classified image belongs to each category (that is, a probability that a target object presented in the to-be-classified image belongs to each category), the second classification result may be used to determine the category of the to-be-classified image (but the second classification result is not used to determine the category of the to-be-classified image in this embodiment of this disclosure, and details are not described herein). In addition, the second classification result may further include location information (for example, two-dimensional coordinates) of the target object in the to-be-classified image.
For example, it is assumed that the to-be-classified image is an image presenting an airplane. After obtaining a third feature of the image, the second classification module may calculate, based on the third feature of the image, a probability that the image belongs to each category such as a vehicle, an airplane, a train, and a bicycle, to obtain a second classification result of the image. The classification result includes a probability that the image belongs to a vehicle category, a probability that the image belongs to an airplane category, a probability that the image belongs to a train category, a probability that the image belongs to a bicycle category, and the like. Therefore, the classification result may be used to determine a category to which the image belongs (but this operation is not performed in this embodiment of this disclosure, and details are not described herein). In addition, the classification result may further include two-dimensional coordinates of the airplane in the image.
The feature fusion module T may send third features of all the image subblocks to a second classification module Pq. The second classifying module Pq may calculate the third feature T(Si, Qj) obtained for any image subblock Qj under the action of the reference image Si, to obtain a second classification result bijq, cijq of the image subblock Qj under the action of the reference image Si. bijq is coordinates of the image subblock Qj in the to-be-classified image Q, and cijq is a probability that the image subblock Qj belongs to each category. In this case, a second classification result (that is, a second classification result of the image subblock Qj) of the image subblock Qj under the action of each reference image may be obtained. Similarly, a second classification result (that is, a second classification result of a remaining image block) of the remaining image block under the action of each reference image may also be obtained. After second classification results of all the image blocks are obtained, it is equivalent to obtaining a second classification result of the to-be-classified image Q.
However, in a model training process in a related technology, because there are a relatively large quantity of images of the basic category (for example, a vehicle or a bicycle) and a relatively small quantity of images of the new category (for example, an airplane) in a reference image used for training, a model obtained by training based on these reference images is prone to fitting the new category to the basic category in an image classification process. In other words, when classifying a to-be-classified image belonging to the new category, the model is prone to determining the to-be-classified image as an image belonging to the basic category by mistake. Therefore, it is not accurate enough to directly use the second classification result of the to-be-classified image to determine the category of the to-be-classified image. Therefore, the second classification result of the to-be-classified image needs to be adjusted.
After obtaining the first classification result of the reference image, the first classification module may send the first classification result of the reference image to the classification result adjustment module. Similarly, after obtaining the second classification result of the to-be-classified image, the second classification module may send the second classification result of the to-be-classified image to the classification result adjustment module. In this case, the classification result adjustment module may adjust the second classification result of the to-be-classified image by using the first classification result of the reference image, to obtain the third classification result of the to-be-classified image (that is, a final classification result of the to-be-classified image). Then, the category of the to-be-classified image may be determined based on the third classification result of the to-be-classified image. The classification result adjustment module may adjust the second classification result in multiple manners, which are separately described in the following.
In a possible implementation, the classification result adjustment module performs addition processing on the first classification result of the reference image and the second classification result of the to-be-classified image, to obtain the third classification result of the to-be-classified image.
The second classification result bijq, cijq of the image subblock Qj under the action of the reference image Si may be added to the first classification result bis, cis of the reference image Si, to obtain a third classification result {circumflex over (b)}ijq, ĉijq of the image subblock Qj under the action of the reference image Si:
{circumflex over (b)}
ij
q
=b
ij
q
+b
i
s
ĉ
ij
q
=c
ij
q
+c
i
s (2)
According to the foregoing formula, third classification results of the image subblock under Qj actions of all the reference images may be obtained, and a category of the image subblock Qj may be determined based on these classification results. By analogy, a third classification result of each image subblock under the action of each reference image may be obtained (equivalent to obtaining third classification results of all the image subblocks, that is, a third classification result of the to-be-classified image Q). In this way, a category of each image subblock in the to-be-classified image Q may be determined. Because a target object presented in the to-be-classified image Q is distributed on the image subblocks, when categories of most of the image subblocks are a same category, the category of these image subblocks is the category of the to-be-classified image Q (that is, a category of the target object presented in the to-be-classified image Q). Coordinates of these image subblocks in the to-be-classified image Q are coordinates of the target object in the to-be-classified image Q.
In another possible implementation, the classification result adjustment module may first perform addition processing on the first classification result of the reference image and the second classification result of the to-be-classified image, to obtain a fourth classification result of the to-be-classified image. Then, the classification result adjustment module performs addition processing on the first classification result of the reference image and a model parameter of the image classification model, to obtain a fifth classification result of the reference image. Then, the classification result adjustment module performs multiplication processing on the fifth classification result of the reference image and a preset weight parameter, to obtain a sixth classification result of the reference image. Finally, the classification result adjustment module performs subtraction processing on the fourth classification result of the to-be-classified image and the sixth classification result of the reference image, to obtain the third classification result of the to-be-classified image.
The second classification result bijq, cijq of the image subblock Qj under the action of the reference image Si may be added to the first classification result bis, cis of the reference image Si, to obtain a fourth classification result {circumflex over (b)}ijq, ĉijq of the image subblock Qj under the action of the reference image Si. It should be noted that, when the category of the reference image Si is the same as the category of the to-be-classified image Q, the first classification result bis, cis of the reference image Si has a positive adjustment effect on the second classification result bijq, cijq of the image subblock Qj under the action of the reference image Si. When the category of the reference image Si is different from the category of the to-be-classified image Q, the first classification result bis, cis of the reference image Si has a negative adjustment effect on the second classification result bijq, cijq of the image subblock Qj under the action of the reference image Si. It can be learned that, to make the final classification result accurate enough, impact brought by the two cases needs to be balanced.
The following describes the foregoing balancing process with reference to
It is assumed that s, p, and f are valid values (obtained by calculating the image) of S, Q, and F respectively, and s*, p*, and f* are invalid values (to be specific, S, Q, and F are all set to 0) of S, Q, and F respectively. A difference generated in the final classification result when each variable is a valid value and an invalid value may be calculated, to analyze an effect of each variable on the final classification result.
A total effect (total effect, TE) of S on P may be denoted as:
TE=Ps,q,f−Ps*,q*,f* (3)
In the foregoing formula, Ps,q,f is a final classification result obtained when S, Q, and F are all valid values. Ps*,q*,f* is a final classification result obtained when S, Q, and F are all invalid values.
A natural direct effect (NDE) of S on P may be denoted as:
NDE=Ps,q*,f*−Ps*,q*,f* (4)
In the foregoing formula, Ps,q*,f* is a final classification result obtained when S is a valid value, and Q and F are both invalid values.
Then, a total indirect effect (TIE) of S on P is:
TIE=TE−NDE=Ps,q,f−Ps,q*,f* (5)
Because the TE of S on P is equal to a sum of the TIE of S on P and the NDE of S on P, based on a relationship (that is, the formula (5) between the TE and Ps,q,f, the following may be obtained:
NDE+TIE+Ps*,q*,f*=Ps,q,f (6)
To reduce impact, on the final classification result, of the NDE of S on P, the NDE may be appropriately reduced to obtain a new final classification result:
αNDE+TE+Ps*,q*,f*=Ps,q,f″ (7)
In the formula, α is generally greater than 0 and less than 1, and the specific value may be set based on actual requirements. Ps,q,f″ is the new final classification result. In this way, the formula (4) and the formula (5) may be substituted into the formula (7) to obtain:
P
s,q,f
″=P
s,q,f−(1−α)(Ps,q*,f*−Ps*,q*,f*) (8)
After the formula (8) is obtained, the fourth classification result {circumflex over (b)}ijq, ĉijq of the image subblock Qj under the action of the reference image Si may be used as an original final classification result (that is, Ps,q,f substituted into the formula (8)). Correspondingly, Ps,q*,f* is bis+A and cis+A. A is a model parameter (which may be considered as a constant) of the feature fusion module and the classification result adjustment module in a trained image classification model. Ps*,q*,f* is B, and B is the model parameter (also a constant) of the trained image classification model. Therefore, a corresponding new final classification result (that is, the third classification result of the image subblock Qj under the action of the reference image Si) may be obtained:
{tilde over (b)}
ij
q
={circumflex over (b)}
ij
q=(1−α)(bis+A−B)
{tilde over (c)}
ij
q
=ĉ
ij
q=(1−α)(cis+A−B) (9)
The third classification result of the image subblock Qj under the action of the reference image Si may be obtained according to the formula (9). By analogy, third classification results of the image subblock Qj under actions of all the reference images may be obtained (equivalent to obtaining a third classification result of the image subblock Qj), and the category of the image subblock Qj may be determined based on these classification results. Similarly, third classification results of each image subblock under actions of all the reference images may also be obtained (equivalent to obtaining a third classification result of each image subblock, that is, a third classification result of the to-be-classified image Q). In this way, the category of each image subblock in the to-be-classified image Q may be determined. Because a target object presented in the to-be-classified image Q is distributed on the image subblocks, when categories of most of the image subblocks are a same category, the category of these image subblocks is the category of the to-be-classified image Q (that is, a category of the target object presented in the to-be-classified image Q) Coordinates of these image subblocks in the to-be-classified image Q are coordinates of the target object in the to-be-classified image Q.
It should be noted that in the formula (9), (1−α) is equivalent to the foregoing preset weight parameter, A−B is equivalent to the foregoing model parameter of the image classification model, (bis+A−B) and (cis+A−B) are equivalent to the foregoing fifth classification result of the reference image, and (1−α)(bis+A−B) and (1−α)(cis+A−B) are equivalent to the foregoing sixth classification result of the reference image.
In addition, the image classification model provided in embodiments of this disclosure may be compared with image classification models in related technologies. A same test sample (including reference images and a to-be-classified image) may be input to the image classification model provided in embodiments of this disclosure and the image classification models in the related technologies for testing. Obtained results are shown in Table 1 to Table 4. There are 10 reference images belonging to the new category in a first test sample, and 30 reference images belonging to the new category in a second test sample. There are far more than 30 reference images belonging to the basic category in the first test sample and the second test sample.
Table 1 and Table 3 show average precision rates under six conditions. The six conditions are: an intersection over union between 0.5 and 0.95 (a step is 0.05), an intersection over union equal to 0.5, an intersection over union equal to 0.75, detecting a large-scale object (including more pixels), detecting a meso-scale object (including moderate pixels), and detecting a small-scale object (including fewer pixels). The intersection over union indicates a ratio of a predicted location (that is, a predicted detection box including a target object) of the target object in the to-be-classified image to a real location (that is, a real detection box including the target object). Table 2 and Table 4 show average recall rates under six conditions. The six conditions are: setting one detection box, setting 10 detection boxes, setting 100 detection boxes, detecting a large-scale object, detecting a meso-scale object, and detecting a small-scale object. Table 1 to Table 4 are as follows:
It can be learned that performance of the model provided in embodiments of this disclosure is obviously better than performance of the models in the related technologies.
In embodiments of this disclosure, after a reference image and a to-be-classified image are input to an image classification model, the image classification model may perform the following steps: obtaining a first feature of the reference image and a second feature of the to-be-classified image; then generating a third feature based on the first feature and the second feature; then generating a first classification result based on the first feature, where the first classification result may be used to determine a category of the reference image, and generating a second classification result based on the third feature; finally generating a third classification result based on the first classification result and the second classification result; and determining a category of the to-be-classified image based on the obtained third classification result. It can be learned that, in a process in which the image classification model generates the third classification result of the to-be-classified image, the first classification result of the reference image is integrated. This is equivalent to that the image classification model focuses on category information of the reference image. Regardless of whether the category of the reference image is a new category or a basic category, the model can notice impact caused by the category of the reference image in a classification process of the to-be-classified image. Therefore, the model does not fit the new category to the basic category. In other words, if the to-be-classified image is an image belonging to the new category, the image classification model may accurately determine the category of the to-be-classified image as a category in the new category, and does not determine the category of the to-be-classified image as a category in the basic category by mistake, thereby improving accuracy of image classification.
The foregoing describes in detail the image classification method provided in embodiments of this disclosure. The following describes a model training method provided in embodiments of this disclosure.
When a to-be-trained model needs to be trained, a batch of training samples, to be specific, a reference image and a to-be-classified image used for training, may be obtained. The to-be-trained model includes two branches. One branch includes a first feature extraction module and a first classification module. The other branch includes a second feature extraction module, a feature fusion module, a second classification module, and a classification result adjustment module. It should be noted that a first reality category of the reference image and a second reality category of the to-be-classified image are known. For descriptions of the reference image and the to-be-classified image, refer to related descriptions of step 401 in the embodiment shown in
After the reference image and the to-be-classified image are obtained, the reference image may be input to the first feature module, so that feature extraction processing is performed on the reference image by using the first feature extraction module, to obtain the first feature of the reference image. Similarly, the to-be-classified image is input to the second feature module, so that feature extraction processing is performed on the to-be-classified image by using the second feature extraction module, to obtain the second feature of the to-be-classified image.
After obtaining the first feature of the reference image, the first feature extraction module may send the first feature of the reference image to the feature fusion module. Similarly, after obtaining the second feature of the to-be-classified image, the second feature extraction module may input the second feature of the to-be-classified image to the feature fusion module. In this way, the feature fusion module may perform feature fusion processing on the first feature and the second feature to obtain the third feature of the to-be-classified image.
After obtaining the first feature of the reference image, the first feature extraction module may further input the first feature of the reference image to the first classification module. In this case, the first classification module may calculate, based on the first feature of the reference image, a probability that the reference image belongs to each category, to obtain the first classification result.
After obtaining the third feature of the to-be-classified image, the feature fusion module may send the third feature to the second classification module. In this case, the second classification module may calculate, based on the third feature of the to-be-classified image, a probability that the to-be-classified image belongs to each category, to obtain the second classification result.
After obtaining the first classification result of the reference image, the first classification module may send the first classification result of the reference image to the classification result adjustment module. Similarly, after obtaining the second classification result of the to-be-classified image, the second classification module may send the second classification result of the to-be-classified image to the classification result adjustment module. In this case, the classification result adjustment module may adjust the second classification result of the to-be-classified image by using the first classification result of the reference image, to obtain the third classification result of the to-be-classified image. The classification result adjustment module may obtain the third classification result in multiple manners.
In a possible implementation, the classification result adjustment module performs addition processing on the first classification result of the reference image and the second classification result of the to-be-classified image, to obtain the third classification result of the to-be-classified image.
It should be understood that, in a model training process, there may be no need to balance positive impact and negative impact that are brought by the first classification result of the reference image to the second classification result of the to-be-classified image. However, in an actual application process of the model (that is, in the embodiment shown in
For a process in which the to-be-trained model obtains the first classification result of the reference image and the third classification result of the to-be-classified image, refer to related descriptions of step 401 to step 405 in the embodiment shown in
After the first classification result of the reference image and the third classification result of the to-be-classified image are obtained by using the to-be-trained model, the first predicted category of the reference image may be determined based on the first classification result of the reference image, and the second predicted category of the to-be-classified image may be determined based on the third classification result of the to-be-classified image.
After the first predicted category of the reference image and the second predicted category of the to-be-classified image are obtained, calculation may be performed based on the first reality category of the reference image, the first predicted category of the reference image, the second reality category of the to-be-classified image, and the second predicted category of the to-be-classified image, to obtain the target loss. The target loss may be obtained in multiple manners.
In a possible implementation, the first predicted category and the first reality category of the reference image are calculated by using a first objective function, to obtain a first sub-loss, where the first sub-loss indicates the difference between the first reality category and the first predicted category. The second predicted category and the second reality category of the to-be-classified image are calculated by using a second objective function, to obtain a second sub-loss, where the second sub-loss indicates the difference between the second reality category and the second predicted category. After the first sub-loss and the second sub-loss are obtained, addition processing is performed on the first sub-loss and the second sub-loss to obtain the target loss.
After the target loss is obtained, the model parameter of the to-be-trained model may be updated based on the target loss. The to-be-trained model of which the parameter is updated is trained by using a next batch of training samples (that is, step 702 to step 705 are performed again), until the model training condition is met (for example, the target loss is converged), to obtain the image classification model.
The image classification model obtained through training in this embodiment of this disclosure has a capability of classifying the to-be-classified image by using the reference image. In an image classification process, the image classification model may focus on category information of the reference image. Regardless of whether a category of the reference image is a new category or a basic category, the model can notice impact caused by the category of the reference image in a classification process of the to-be-classified image. Therefore, the model does not fit the new category to the basic category. In other words, if the to-be-classified image is an image belonging to the new category, the image classification model may accurately determine the category of the to-be-classified image as a category in the new category, and does not determine the category of the to-be-classified image as a category in the basic category by mistake, thereby improving accuracy of image classification.
The foregoing describes in detail the model training method provided in embodiments of this disclosure. The following separately describes an image classification apparatus and a model training apparatus provided in embodiments of this disclosure.
In a possible implementation, the classification result adjustment module 805 is configured to perform addition processing on the first classification result and the second classification result to obtain the third classification result.
In a possible implementation, the classification result adjustment module 805 is configured to: perform addition processing on the first classification result and the second classification result to obtain a fourth classification result; perform addition processing on the first classification result and a model parameter of the image classification model to obtain a fifth classification result; perform multiplication processing on the fifth classification result and a preset weight parameter to obtain a sixth classification result; and perform subtraction processing on the fourth classification result and the sixth classification result to obtain the third classification result.
In a possible implementation, the first classification module 803 is configured to calculate, based on the first feature, a probability that the reference image belongs to each category, to obtain the first classification result; and the second classification module 804 is configured to calculate, based on the third feature, a probability that the to-be-classified image belongs to each category, to obtain the second classification result.
In a possible implementation, the feature fusion module 802 is configured to perform feature fusion processing on the first feature and the second feature to obtain the third feature.
In a possible implementation, the feature fusion processing includes at least one of addition processing, multiplication processing, subtraction processing, concatenation processing, and concatenation convolution processing.
In a possible implementation, the feature extraction module 801 includes a first feature extraction module and a second feature extraction module. The first feature extraction module is configured to perform feature extraction processing on the reference image to obtain the first feature, and the second feature extraction module is configured to perform feature extraction processing on the to-be-classified image to obtain the second feature.
In a possible implementation, the computation module 904 is configured to: obtain a first sub-loss based on the first reality category and the first predicted category of the reference image, where the first sub-loss indicates the difference between the first reality category and the first predicted category; obtain a second sub-loss based on the second reality category and the second predicted category of the to-be-classified image, where the second sub-loss indicates the difference between the second reality category and the second predicted category; and perform addition processing on the first sub-loss and the second sub-loss to obtain the target loss.
In a possible implementation, the to-be-trained model is configured to perform addition processing on the first classification result and the second classification result to obtain the third classification result.
In a possible implementation, the to-be-trained model is configured to: calculate, based on the first feature, a probability that the reference image belongs to each category, to obtain the first classification result; and calculate, based on the third feature, a probability that the to-be-classified image belongs to each category, to obtain the second classification result.
In a possible implementation, the to-be-trained model is configured to perform feature fusion processing on the first feature and the second feature to obtain the third feature.
In a possible implementation, the feature fusion processing includes at least one of addition processing, multiplication processing, subtraction processing, concatenation processing, and concatenation convolution processing.
In a possible implementation, the to-be-trained model is configured to: perform feature extraction processing on the reference image to obtain the first feature; and perform feature extraction processing on the to-be-classified image to obtain the second feature.
It should be noted that, content such as information exchange between the modules/units of the apparatus and the execution processes thereof is based on the same idea as the method embodiments of this disclosure, and produces the same technical effects as that of the method embodiments of this disclosure. For specific content, refer to the foregoing descriptions in the method embodiments of this disclosure. Details are not described herein again.
An embodiment of this disclosure further relates to an execution device.
The memory 1004 may include a read-only memory (ROM) and a random-access memory (RAM), and provide instructions and data for the processor 1003. A part of the memory 1004 may further include a non-volatile random-access memory (NVRAM). The memory 1004 stores a processor and operation instructions, an executable module or a data structure, a subnet thereof, or an extended set thereof. The operation instructions may include various operation instructions to implement various operations.
The processor 1003 controls an operation of the execution device. During specific application, the components of the execution device are coupled together through a bus system. In addition to a data bus, the bus system may further include a power bus, a control bus, a status signal bus, and the like. However, for clear description, various types of buses in the figure are marked as the bus system.
The method disclosed in the foregoing embodiments of this disclosure may be applied to the processor 1003, or may be implemented by the processor 1003. The processor 1003 may be an integrated circuit chip, and has a signal processing capability. In an implementation process, steps in the foregoing methods may be implemented by using a hardware integrated logical circuit in the processor 1003, or by using instructions in a form of software. The processor 1003 may be a general-purpose processor, a digital signal processor (DSP), a microprocessor, or a microcontroller. The processor 1003 may further include an ASIC, an FPGA, or another programmable logic device, a discrete gate, a transistor logic device, or a discrete hardware component. The processor 1003 may implement or perform the methods, the steps, and the logical block diagrams that are disclosed in embodiments of this disclosure. The general-purpose processor may be a microprocessor, or the processor may be any other processor. Steps of the methods disclosed with reference to embodiments of this disclosure may be directly executed and completed by a hardware decoding processor, or may be executed and completed by using a combination of hardware and software modules in the decoding processor. The software module may be located in a mature storage medium in the art, for example, a RAM, a flash memory, a ROM, a programmable ROM (PROM), an electrically erasable programmable memory, or a register. The storage medium is located in the memory 1004, and the processor 1003 reads information in the memory 1004 and completes the steps in the foregoing methods in combination with hardware of the processor 1003.
The receiver 1001 may be configured to receive input digital or character information, and generate a signal input related to setting and function control of the execution device. The transmitter 1002 may be configured to output digital or character information by using a first interface. The transmitter 1002 may be further configured to send instructions to a disk group by using the first interface, to modify data in the disk group. The transmitter 1002 may further include a display device such as a display.
In this embodiment of this disclosure, in a case, the processor 1003 is configured to perform image object detection on an image by using the image classification model in the embodiment corresponding to
An embodiment of this disclosure further relates to a training device.
The training device 1100 may further include one or more power supplies 1126, one or more wired or wireless network interfaces 1150, one or more input/output interfaces 1158, or one or more operating systems 1141, for example, Windows Server™, Mac OS X™, Unix™, Linux™, and FreeBSD™.
The training device may perform the model training method in the embodiment corresponding to
An embodiment of this disclosure further relates to a computer-readable storage medium. The computer-readable storage medium stores a program used for signal processing. When the program is run on a computer, the computer is enabled to perform the steps performed by the foregoing execution device, or the computer is enabled to perform the steps performed by the foregoing training device.
An embodiment of this disclosure further relates to a computer program product. The computer program product stores instructions. When the instructions are executed by a computer, the computer is enabled to perform the steps performed by the foregoing execution device, or the computer is enabled to perform the steps performed by the foregoing training device.
The execution device, the training device, or the terminal device in embodiments of this disclosure may be a chip. The chip includes a processing unit and a communication unit. The processing unit may be, for example, a processor. The communication unit may be, for example, an input/output interface, a pin, or a circuit. The processing unit may execute computer-executable instructions stored in a storage unit, so that a chip in the execution device performs the data processing method described in the foregoing embodiments, or a chip in the training device performs the data processing method described in the foregoing embodiments. Optionally, the storage unit is a storage unit in the chip, for example, a register or a cache. Alternatively, the storage unit may be a storage unit in a wireless access device but outside the chip, for example, a ROM, another type of static storage device that can store static information and instructions, or a RAM.
In some implementations, the operation circuit 1203 includes a plurality of PE inside. In some implementations, the operation circuit 1203 is a two-dimensional systolic array. The operation circuit 1203 may alternatively be a one-dimensional systolic array or another electronic circuit capable of performing mathematical operations such as multiplication and addition. In some implementations, the operation circuit 1203 is a general-purpose matrix processor.
For example, it is assumed that there is an input matrix A, a weight matrix B, and an output matrix C. The operation circuit fetches, from a weight memory 1202, data corresponding to the matrix B, and caches the data on each PE in the operation circuit. The operation circuit fetches data of the matrix A from an input memory 1201, to perform a matrix operation on the matrix B, and stores an obtained partial result or an obtained final result of the matrix in an accumulator 1208.
A unified memory 1206 is configured to store input data and output data. The weight data is directly transferred to the weight memory 1202 by using a DMAC 1205. The input data is also transferred to the unified memory 1206 by using the DMAC.
A BIU namely, a BIU 1213, and is configured to perform interaction between an Advanced extensible Interface (AXI) bus and the DMAC and between the AXI bus and an instruction fetch buffer (IFB) 1209.
The BIU 1213 is used by the instruction fetch buffer 1209 to obtain instructions from an external memory, and is further used by the DMAC 1205 to obtain original data of the input matrix A or the weight matrix B from the external memory.
The DMAC is mainly configured to transfer input data in the external memory DDR to the unified memory 1206, transfer weight data to the weight memory 1202, or transfer input data to the input memory 1201.
A vector computation unit 1207 includes a plurality of operation processing units; and if necessary, perform further processing such as vector multiplication, vector addition, an exponential operation, a logarithmic operation, or value comparison on an output of the operation circuit 1203. The vector computation unit 1207 is mainly configured to perform network computation, such as batch normalization, pixel-level summation, or upsampling on a prediction label plane, at a non-convolutional/fully connected layer in a neural network.
In some implementations, the vector computation unit 1207 can store a processed output vector in the unified memory 1206. For example, the vector computation unit 1207 may apply a linear function or a nonlinear function to the output of the operation circuit 1203, for example, perform linear interpolation on a prediction label plane extracted at a convolutional layer. For another example, the linear function or the nonlinear function is applied to a vector of an accumulated value to generate an activation value. In some implementations, the vector computation unit 1207 generates a normalized value, a pixel-level summation value, or both. In some implementations, the processed output vector can be used as an activated input to the operation circuit 1203, for example, the processed output vector can be used at a subsequent layer of the neural network.
The instruction fetch buffer 1209 connected to the controller 1204 is configured to store instructions used by the controller 1204.
The unified memory 1206, the input memory 1201, the weight memory 1202, and the instruction fetch buffer 1209 are all on-chip memories. The external memory is private for a hardware architecture of the NPU.
The processor mentioned above may be a general-purpose central processing unit, a microprocessor, an ASIC, or one or more integrated circuits for controlling program execution.
In addition, it should be noted that the apparatus embodiments described above are merely an example. The units described as separate parts may or may not be physically separate, and parts displayed as units may or may not be physical units, may be located in one position, or may be distributed on a plurality of network units. Some or all of the modules may be selected based on actual requirements to achieve the objectives of the solutions of embodiments. In addition, in the accompanying drawings of the apparatus embodiments provided by this disclosure, connection relationships between modules indicate that the modules have communication connections with each other, which may be implemented as one or more communication buses or signal cables.
Based on the description of the foregoing implementations, a person skilled in the art may clearly understand that this disclosure may be implemented by software in addition to necessary universal hardware, or by dedicated hardware, including a dedicated integrated circuit, a dedicated CPU, a dedicated memory, a dedicated component, and the like. Usually, any function implemented by a computer program may be easily implemented by using corresponding hardware. In addition, specific hardware structures used to implement a same function may be various, for example, an analog circuit, a digital circuit, or a dedicated circuit. However, in this disclosure, a software program implementation is a better implementation in most cases. Based on such an understanding, the technical solutions of this disclosure essentially or the part contributing to the other technologies may be implemented in a form of a software product. The computer software product is stored in a readable storage medium, such as a floppy disk, a Universal Serial Bus (USB) flash drive, a removable hard disk, a ROM, a RAM, a magnetic disk, or an optical disc of a computer, and includes several instructions for instructing a computer device (which may be a personal computer, a training device, or a network device) to perform the methods in embodiments of this disclosure.
All or some of the foregoing embodiments may be implemented by software, hardware, firmware, or any combination thereof. When software is used to implement the embodiments, all or some of the embodiments may be implemented in a form of a computer program product.
The computer program product includes one or more computer instructions. When the computer program instructions are loaded and executed on a computer, the procedures or functions according to embodiments of this disclosure are all or partially generated. The computer may be a general-purpose computer, a dedicated computer, a computer network, or another programmable apparatus. The computer instructions may be stored in a computer-readable storage medium or may be transmitted from a computer-readable storage medium to another computer-readable storage medium. For example, the computer instructions may be transmitted from a website, computer, training device, or data center to another website, computer, training device, or data center in a wired (for example, a coaxial cable, an optical fiber, or a digital subscriber line (DSL)) or wireless (for example, infrared, radio, or microwave) manner. The computer-readable storage medium may be any usable medium accessible by the computer, or a data storage device, such as a training device or a data center, integrating one or more usable media. The usable medium may be a magnetic medium (for example, a floppy disk, a hard disk, or a magnetic tape), an optical medium (for example, a digital versatile disc (DVD)), a semiconductor medium (for example, a solid-state drive (SSD)), or the like.
Number | Date | Country | Kind |
---|---|---|---|
202110745619.5 | Jun 2021 | CN | national |
This is a continuation of International Patent Application No. PCT/CN2022/101015 filed on Jun. 24, 2022, which claims priority to Chinese Patent Application No. 202110745619.5 filed on Jun. 30, 2021. The disclosures of the aforementioned applications are hereby incorporated by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2022/101015 | Jun 2022 | WO |
Child | 18400930 | US |