The present application claims priority from Japanese applications JP2022-113074, filed on Jul. 14, 2022, and JP2023-083326 filed May 19, 2023, the contents of which are hereby incorporated by reference into this application.
The present invention relates to a data management system and a data management method of a machine learning model, and is suitable to be applied to a past-results-data management system and a past-results-data management method of a machine learning model that supports determination of the necessity of input/output data of machine learning in accordance with the life cycle of machine learning.
In machine learning, to maintain or improve the accuracy of a model, it is effective to repeat the life cycle including inference and evaluation. At this time, it is necessary to accumulate data at the time of inference and monitor and analyze the accumulated data, and there is increasing demand for a platform to provide these functions.
Regarding the life cycle of machine learning, for example, JP 2021-60940 A discloses an operation support system using machine learning that supports repeating the training of a model generated from input data and replacing the model with a higher-accuracy one.
However, the above-described conventional technology does not devise an operation considering whether or not input data and output data of a model of machine learning are data necessary for the subsequent machine learning. As a result, as the life cycle rotates, data is accumulated, which causes a problem that the running cost of the system increases.
The present invention has been made in view of the above points, and is intended to propose a data management system and a data management method of a machine learning model capable of efficiently operating deletion of unnecessary data.
To solve the problem, the present invention provides a data management system of a machine learning model that manages a model and its associated data while operating the model along the life cycle of machine learning, the data management system including: flag management information that manages and defines respective flags corresponding to, of a plurality of processes included in the life cycle, one or more predetermined processes; an operation unit that operates the model along the life cycle; and a data management unit that manages input data and output data of the model, in which the operation unit assigns flags defined in the flag management information to the input data and the output data of the model in accordance with involvement in the predetermined processes at time of operating the model, and the data management unit determines, with respect to each of the input data and the output data, necessity of storage of data on the basis of a flag assigned to the data by the operation unit.
Furthermore, to solve the problem, the present invention provides a data management method implemented by a data management system of a machine learning model that manages a model and its associated data while operating the model along the life cycle of machine learning, the data management system including: flag management information that manages and defines respective flags corresponding to, of a plurality of processes included in the life cycle, one or more predetermined processes; an operation unit that operates the model along the life cycle; and a data management unit that manages input data and output data of the model, and
According to the present invention, it is possible to efficiently operate deletion of unnecessary data in data management of a machine learning model.
An embodiment of the present invention will be described in detail below with reference to drawings.
It is noted that the following description and the drawings are examples for explaining the present invention, and, for clarification of the description, they are partially omitted or simplified accordingly. Furthermore, all of combinations of characteristics described in the embodiment are not necessarily essential means for solving the problem. The present invention is not limited to the embodiment, and all application examples consistent with the concept of the present invention are included in the technical scope of the present invention. Various additions, modifications, etc. can be made by those skilled in the art within the scope of the present invention. The present invention can be embodied in various other forms. Unless otherwise defined, each component may be plural or singular.
In the following description, a variety of information may be described in forms of representation such as a “table”, a “chart”, a “list”, and a “queue”; however, besides these, a variety of information may be represented by a data structure. To show that it does not depend on a data structure, an “XX table”, an “XX list”, or the like may be referred to as “XX information”. When contents of each piece of information are described, the terms such as “identification information”, “identifier”, “name”, “ID”, and “number” are used; these can be replaced with one another.
Furthermore, in the following description, there is a case where a process performed by executing a program is described; the program is executed by at least one or more processors (for example, CPUs), and thus a predetermined process is performed using a storage resource (for example, a memory) and/or an interface device (for example, a communication port) accordingly, and therefore, the subject of the process may be the processor(s). Likewise, the subject of the process performed by executing the program may be a controller, a device, a system, a computer, a node, a storage system, a storage device, a server, a management computer, a client, or a host that includes the processor(s). The subject (for example, the processor(s)) of the process performed by executing the program may include a hardware circuit that performs some or all of the process. For example, the subject of the process performed by executing the program may include a hardware circuit that performs encryption and decryption or compression and decompression. The processor operates in accordance with the program, and thereby operates as a functional unit that realizes a predetermined function. A device and a system that include the processor are a device and a system that include this functional unit.
The program may be installed in a device such as a computer from a program source. The program source may be, for example, a program distribution server or a computer-readable storage medium. In a case where the program source is a program distribution server, the program distribution server includes a processor (for example, a CPU) and a storage resource, and the storage resource may further store therein a distribution program and a program to be distributed. Then, the processor of the program distribution server may be configured to execute the distribution program, thereby distributing the program to be distributed to other computers. Furthermore, in the following description, two or more programs may be realized as one program, or one program may be realized as two or more programs.
(1) System Configuration
The CPU 10 is an example of a processor; the processor is not limited to a central processing unit (CPU), and may be a graphics processing unit (GPU) or the like.
The main storage device 20 is a memory such as a dynamic RAM (DRAM), and stores therein a program and data.
Specifically, the auxiliary storage device 30 is a storage device such as a hard disk drive (HDD) or a solid state drive (SSD); however, the auxiliary storage device 30 is not limited to these, and a cloud or the like may be used. According to
The input device 2 is an input device manipulated by a user. Specifically, the input device 2 is, for example, a mouse, a keyboard, etc.
The display device 3 is an output device used by the user. Specifically, the display device 3 is, for example, a display. The display device 3 displays thereon various display screens (a monitoring screen 110, a retraining screen 120, an evaluation screen 130, and a data management result screen 140 to be described later) generated by the information display unit 26. It is noted that the output format of information from the data management system 1 in the present embodiment is not limited to display, and various commonly-known output formats, such as data output to a recording medium and printing, can be adopted.
(2) Data Configuration
The various management tables 31 to 38 held by the auxiliary storage device 30 are described in detail below with a specific example.
(2-1) Data Management Table 31
The data ID 311 is an identifier that can identify input/output data (referred to as “the data” in the description of
The importance 316 indicates a degree of importance as data held by the data management system 1 based on a flag assigned to the data. A larger numerical value is registered with respect to more important one as data to be held, and a smaller numerical values is registered with respect to less important one. In the data management system 1 according to the present embodiment, in accordance with a process in which the data may be involved (i.e., what process the data has been used in or what process the data may be used in) in rotating the life cycle of machine learning, each piece of input/output data is assigned a flag (a flag ID) corresponding to the process. As shown in the flag importance management table 32 of
The deletion recommendation 317 indicates a value of evaluation of whether or not deletion of the data is recommended. The evaluation value stored in the deletion recommendation 317 is determined on the basis of the importance 316 of the data; however, a method of this determination is not limited to a particular method. In this example, in a case where the importance 316 of the data is equal to or lower than a predetermined threshold, “1” indicating that deletion of the data is recommended is stored; in a case where the importance 316 of the data exceeds the predetermined threshold, “0” indicating that deletion of the data is not recommended is stored. As a variation of the determination method, phased thresholds may be provided, and the level (the evaluation value) of deletion recommendation may be calculated in several phases.
The value of each item of the data management table 31 described above is appropriately registered or updated in units of records during execution of a data input process (step S1 in
(2-2) Flag Importance Management Table 32
The flag ID 321 is an identifier that can identify a flag (referred to as “the flag” in the description of
The importance 323 indicates the priority of data that has been assigned the flag to be maintained (i.e., to not be deleted) in the data management system 1. The higher the degree of importance 323 is, the more important the flag is, which means that input/output data that has been assigned the flag should be maintained (should not be deleted) in the data management system 1.
The value of each item of the flag importance management table 32 described above is registered in advance in units of records. Furthermore, after the value has been registered in each item of the flag importance management table 32, change of the importance 323, addition or deletion of a flag (a record), etc. can be made as necessary. Moreover, types of flags managed in the flag importance management table 32 are not limited to the above example.
(2-3) Retraining Likelihood Management Table 33
The retraining likelihood ID 331 is an identifier that can identify data managed in a corresponding record, and a different ID is assigned to each data having a likelihood of retraining. The flag ID 332 indicates an ID of a flag related to a retraining likelihood based on the flag ID 321 of the flag importance management table 32 of
The value of each item of the retraining likelihood management table 33 described above is registered in units of records in a data input process (step S1 in
(2-4) Retraining Likelihood History Management Table 34
The retraining likelihood history ID 341 is an identifier that can identify data managed in a corresponding record, and a different ID is assigned to each input data used in a training process (used in retraining) after registered in the retraining likelihood management table 33. The flag ID 342 indicates an ID of a flag related to a retraining likelihood history based on the flag ID 321 of the flag importance management table 32 of
In a case where data registered in the retraining likelihood management table 33 is used in a training process (step S2 in
(2-5) Monitoring Screen Management Table 35
The monitoring screen ID 351 is an identifier that can identify data managed in a corresponding record, and a different ID is assigned to each data displayed on the monitoring screen. The flag ID 352 indicates an ID of a flag related to the monitoring screen based on the flag ID 321 of the flag importance management table 32 of
The value of each item of the monitoring screen management table 35 described above is registered in units of records in a model update process (step S4 in
(2-6) Monitoring Screen History Management Table 36
The monitoring screen history ID 361 is an identifier that can identify data managed in a corresponding record, and a different ID is assigned to each data displayed on the monitoring screen. The flag ID 362 indicates an ID of a flag related to a monitoring screen history based on the flag ID 321 of the flag importance management table 32 of
In a case where there is data deleted from the monitoring screen management table 35 in a model update process (step S4 in
(2-7) Training Process Management Table 37
The training process ID 371 is an identifier that can identify data managed in a corresponding record, and a different ID is assigned to each input data used in a training process. The flag ID 372 indicates an ID of a flag related to a training process based on the flag ID 321 of the flag importance management table 32 of
The value of each item of the training process management table 37 described above is registered in units of records in a training process (step S2 in
(2-8) Evaluation Process Management Table 38
The evaluation process ID 381 is an identifier that can identify data managed in a corresponding record, and a different ID is assigned to each output data evaluated in an evaluation process. The flag ID 382 indicates an ID of a flag related to an evaluation process based on the flag ID 321 of the flag importance management table 32 of
The value of each item of the evaluation process management table 38 described above is registered in units of records in an evaluation process (step S3 in
(3) Processes
As for processes performed by the data management system 1 according to the present embodiment, first, the whole process, and then details of each process constituting the whole process will be described below.
(3-1) Whole Process
According to
Next, the training processing unit 22 performs a training process of retraining the model in a case where the accuracy of the output data generated in the data input process is poor (step S2). Although the details will be described later with reference to
Next, the evaluation processing unit 23 generates output data from the new model generated in step S2, and performs an evaluation process of evaluating this output data (step S3). Although the details will be described later with reference to
Next, in a case where the accuracy of the output data generated in the evaluation process of step S3 is excellent, the model update processing unit 24 performs a model update process of updating the model to be used (step S4). Although the details will be described later with reference to
Next, the data management unit 25 performs a data management process of calculating the importance of each data on the basis of a flag assigned to the data in the processes of steps S1 to S4, determining whether the data is data of which the deletion is recommended, and storing the data in the data management table 31 (step S5). Although the details will be described later with reference to
Last, the information display unit 26 performs a result display process of displaying the data management result screen 140 showing the result of the determination of deletion recommendation determined in the data management process of step S5 on the display device 3 (step S6). Although the details will be described later with reference to
Machine learning can maintain or improve the accuracy of a model by repeating the life cycle; therefore, after the process in step S6, it is preferable to return to step S1 and repeatedly perform the processes of steps S1 to S6. However, in the data management system 1 according to the present embodiment, the result display process of step S6 does not necessarily have to be performed each time a series of the processes of steps S1 to S5 is performed. Specifically, for example, in a case where a user operation to request display of information regarding deletion recommendation data has been made while a series of the processes of steps S1 to S5 is performed in a regular or irregular loop, the process of step S6 may be performed after step S5 of the latest loop processing at that time.
(3-2) Data Input Process
According to
Next, the data input unit 21 checks whether there is a model in the auxiliary storage device 30 (step S102). In a case where there is a model in step S102 (YES in step S102), the data input unit 21 ends the data input process.
In a case where there is no model in step S102 (NO in step S102), the data input unit 21 generates a model on the basis of the input data stored in the data management table 31 in step S101 (step S103).
Next, the data input unit 21 generates output data from the model generated in step S103 with the input data in step S101 as an input (step S104), and registers the generated output data in the data management table 31 (step S105). At this time, in the data management table 31, a record related to the output data is newly created, and respective values of the items of data ID 311, date 312, data 313, data type 314, and model version 315 in the record are registered. It is noted that respective values of the items of importance 316 and deletion recommendation 317 are registered in the data management process.
Next, the data input unit 21 registers the input data and the output data in the monitoring screen management table 35 (step S106). At this time, in the monitoring screen management table 35, a record is newly created with respect to each of the input data and the output data, and respective values of the items are registered.
Next, the data input unit 21 checks if at least either a condition that “the output data has been detected to be abnormal” or a condition that “the rarity of the input data is high” is met (step S107). The output data is detected to be abnormal, for example, in a case where the output data is extremely different as compared with other output data or in a case where the output data exceeds a predetermined threshold. The rarity of the input data can be calculated from comparison with other input data, and the input data is determined to be high in rarity, for example, in a case where its rarity exceeds a predetermined threshold. The detection of the abnormality of the output data and the determination of the rarity of the input data are realized by a general programming process.
In a case where at least either of the above conditions is met in step S107 (YES in step S107), it can be determined that this input data is data having singularity and is data highly likely to be used in the subsequent training process (i.e., having a high likelihood of being used in retraining). Thus, the data input unit 21 registers the input data in the retraining likelihood management table 33 (step S108), and then, ends the data input process. In step S108, in the retraining likelihood management table 33, a record is newly created with respect to the input data, and respective values of the items are registered.
On the other hand, in a case where neither of the above conditions is met in step S107 (NO in step S107), this input data is unlikely to be used in the subsequent training process; thus, the data input unit 21 ends the data input process without registering the input data in the retraining likelihood management table 33.
(3-3) Training Process
According to
In a case of the monitoring screen 110 shown in
To return to the description of
In a case of the retraining screen 120 shown in
To return to the description of
Next, the training processing unit 22 registers the input data (in other words, the data of the date selected in step S203) used in the generation of the model in step S204 in the training process management table 37 (step S205).
Next, the training processing unit 22 acquires the flag ID 321 of “retraining likelihood” from the flag importance management table 32 (step S206). Specifically, according to the flag importance management table 32 of
Next, the training processing unit 22 checks whether or not data (a record) corresponding to a combination of the data ID acquired in step S204 and the flag ID acquired in step S206 has been registered in the retraining likelihood management table 33 (step S207).
In a case where data corresponding to the conditions has been registered in the retraining likelihood management table 33 in step S207 (YES in step S207), it means that already-registered data (retraining likelihood data) in the retraining likelihood management table 33 has been used in the retraining in step S204; thus, the training processing unit 22 deletes the record of the data from the retraining likelihood management table 33 (step S208). Then, the training processing unit 22 registers the data with the data ID acquired in step S204 in the retraining likelihood history management table 34 (step S209), and ends the training process.
On the other hand, in a case where data corresponding to the conditions has not been registered in the retraining likelihood management table 33 in step S207 (NO in step S207), already-registered data (retraining likelihood data) in the retraining likelihood management table 33 has not been used in the retraining in step S204, and does not meet the condition to delete its record from the retraining likelihood management table 33. Therefore, in this case, the training processing unit 22 ends the training process.
The training process is performed as described above, thereby it becomes possible to select high-accuracy data having a likelihood of retraining and perform training of the model and also possible to register the data used in the retraining in the training process management table 37 and assign the data the flag “F0005” of “training process”. Furthermore, in a case where already-registered data in the retraining likelihood management table 33 has been used in retraining, it is possible to delete the registration of the data from the retraining likelihood management table 33 and also possible to register the data in the retraining likelihood history management table 34 and assign the data the flag “F0002” of “retraining likelihood history”.
It is noted that steps S206 and S207 may be swapped in the processing order, and steps S208 and S209 may also be swapped in the processing order.
(3-4) Evaluation Process
According to
In a case of the evaluation screen 130 shown in
To return to the description of
Next, the evaluation processing unit 23 stores the input data of the dates selected through the evaluation screen 130 (i.e., the data used as input data in the evaluation process of step S302) and the output data generated in the evaluation process in the data management table 31 (step S303). The storage of these input/output data in the data management table 31 is performed by a similar procedure to step S301 in
Next, the evaluation processing unit 23 registers the input data of the dates selected through the evaluation screen 130 (i.e., the data used as input data in the evaluation process of step S302) and the output data generated in the evaluation process management table 38 (step S304). In other words, in step S304, the evaluation processing unit 23 registers the data stored in the data management table 31 in step S303 in the evaluation process management table 38 as well. At this time, in the evaluation process management table 38, with respect to each of input data or output data to be registered, a record is newly created with an evaluation process ID 381 assigned. The flag ID “F0006” corresponding to “evaluation process” is registered in the flag ID 382 (see the flag importance management table 32), and a data ID of the target data is registered in the data ID 383 with reference to the data ID 311 of the data management table 31. Furthermore, the date and time at the moment is registered in the registration date and time 384.
The evaluation process of
It is noted that with respect to the new model regenerated in the training process, in a case where it is determined as a result of the evaluation process of
(3-5) Model Update Process
According to
Next, the model update processing unit 24 registers the input data of the date used in the previous evaluation process and the output data generated from the new model updated in step S401 (i.e., the output data generated in step S302 of the evaluation process) in the monitoring screen management table 35 (step S402). The procedure of registering input/output data in the monitoring screen management table 35 is similar to step S106 in
Next, with reference to the data management table 31, the model update processing unit 24 searches for data (an old version of data) having a model version different from the model version of the data registered on the same date (period) as the data registered in the monitoring screen management table 35 in step S402, and acquires a data ID 311 of corresponding data (step S403).
Next, with reference to the flag importance management table 32, the model update processing unit 24 acquires a flag ID 321 corresponding to “monitoring screen” (“F0003” in this example) (step S404).
Next, the model update processing unit 24 checks whether data (a record) corresponding to a combination of the data ID acquired in step S403 and the flag ID acquired in step S404 has been registered in the monitoring screen management table 35 (step S405).
In a case where data corresponding to the condition has been registered in the monitoring screen management table 35 in step S405 (YES in step S405), it means that aside from the data associated with the new model version registered in step S402, data associated with an old model version has been registered in the monitoring screen management table 35. Therefore, in this case, the model update processing unit 24 registers the data with the data ID acquired in step S403 in the monitoring screen history management table 36 (step S406), and deletes a record of the data from the monitoring screen management table 35 (step S407). Through the processes of steps S406 and S407, the data associated with the old model version is deleted from the monitoring screen management table 35 and registered in the monitoring screen history management table 36, and the data is assigned the flag ID “F0004” corresponding to “monitoring screen history” instead of the flag ID “F0003” corresponding to “monitoring screen”. After the process of step S407, the model update processing unit 24 ends the model update process.
On the other hand, in a case where data corresponding to the condition has not been registered in the monitoring screen management table 35 in step S405 (NO in step S405), the data associated with the old model version has not been registered in the monitoring screen management table 35, and there is no data associated with a different model version on the same date in the monitoring screen management table 35. Therefore, in this case, the model update processing unit 24 ends the model update process without performing the above-described processes of steps S406 and S407.
It is noted that steps S406 and S407 may be swapped in the processing order.
(3-6) Data Management Process
According to
In the processes of loop 1, first, the data management unit 25 acquires a data ID 311 of the record (step S502). Further, the data management unit 25 sets the value of importance 316 of the record to “0” (Step S503). It is noted that the process of step S503 is a process for resetting the importance, and is not necessarily limited to resetting the value to “0”.
Next, the data management unit 25 acquires records one at a time from the flag importance management table 32, and starts processes of loop 2 (steps S505 to S508) (step S504). As described above, each record of the flag importance management table 32 manages a flag assigned to data and its importance in each of predetermined processes in the life cycle of machine learning.
In the processes of loop 2, first, the data management unit 25 acquires a flag ID 321 from the record of the flag importance management table 32 acquired in step S504 (step S505).
Next, the data management unit 25 checks whether data with the data ID acquired in step S502 has been registered in the management table (specifically, any of the retraining likelihood management table 33, the retraining likelihood history management table 34, the monitoring screen management table 35, the monitoring screen history management table 36, the training process management table 37, and the evaluation process management table 38) that manages a flag corresponding to the flag ID 321 acquired in step S505 (step S506).
In a case where the condition is not met in step S506 (NO in step S506), the data management unit 25 checks whether the condition for terminating loop 2 is met (whether the processes have completed with respect to all the records of the flag importance management table 32), and, in a case where the condition is not met, returning to step S504, repeats the processes of loop 2. In a case where the condition for terminating loop 2 is met, the data management unit 25 proceeds to step S509.
On the other hand, in a case where the condition is met in step S506 (YES in step S506), the data management unit 25 acquires importance 323 of the flag ID 321 acquired in step S505 from the data management table 31 (step S507), and adds the acquired importance to the importance of the data ID acquired in step S502 (step S508). The data management unit 25 temporarily stores the importance after the addition of the respective degrees, and, in a case where the condition for terminating loop 2 is met, registers the final importance after the addition of the respective degrees in importance 316 of a record that manages the data ID in the data management table 31. Alternatively, each time the importance is added in step S508, the data management unit 25 may update the importance 316 of the record that manages the data ID in the data management table 31 with the importance after the addition of the respective degrees. After that, the data management unit 25 checks whether the condition for terminating loop 2 is met, and, in a case where the condition is not met, returning to step S504, repeats the processes of loop 2. In a case where the condition for terminating loop 2 is met, the data management unit 25 proceeds to step S509.
By repeating the processes of loop 2 as many times as the number of records of the flag importance management table 32 as described above, the total value of respective degrees of importance of flags assigned to data indicated by a data ID acquired in step S502 is registered in the importance 316 of a record corresponding to the data ID in the data management table 31.
After breaking the processes of loop 2, the data management unit 25 determines whether or not the importance of the data calculated through the processes of loop 2 is equal to or lower than a predetermined threshold (step S509). The predetermined threshold may be set in the system in advance, or may be arbitrarily able to be changed by the user.
In a case where the importance of the data is equal to or lower than the threshold in step S509 (YES in step S509), the importance of the data is low, thus the data management unit 25 registers “1” indicating that deletion is recommended in deletion recommendation 317 of the record that manages the data in the data management table 31 (step S510). On the other hand, in a case where the importance of the data exceeds the threshold in step S509 (NO in step S509), the importance of the data is high, thus the data management unit 25 registers “0” indicating that deletion is not recommended in deletion recommendation 317 of the record that manages the data in the data management table 31 (step S511).
After the process of step S510 or S511 is finished, the data management unit 25 checks whether the condition for terminating loop 1 is met (whether the processes have completed with respect to all the records of the data management table 31), and, in a case where the condition is not met, returning to step S501, repeats the processes of loop 1. In a case where the condition for terminating loop 1 is met, the data management unit 25 ends the data management process.
By repeating the processes of loop 1 as many times as the number of records of the data management table 31 as described above, “1” as for data having a low impact if deleted or “0” as for data having a high impact if deleted is registered in deletion recommendation 317 of each record of the data management table 31. As a result, it is possible to distinguish the advisability of deletion recommendation of each data by the value of the deletion recommendation 317 of the data management table 31.
(3-7) Result Display Process
According to
In the processes of loop 1, first, the information display unit 26 acquires deletion recommendation 317 of the record (step S602), and determines whether or not its value is “1” indicating that deletion is recommended (step S603).
In a case where the value of the deletion recommendation 317 is other than “1”, i.e., “0” in step S603 (NO in step S603), the information display unit 26 checks whether the condition for terminating loop 1 is met (whether the processes have completed with respect to all the records of the data management table 31), and, in a case where the condition is not met, returning to step S602, repeats the processes of loop 1. In a case where the condition for terminating loop 1 is met, the information display unit 26 proceeds to step S610 to be described later.
On the other hand, in a case where the value of the deletion recommendation 317 is “1” in step S603 (YES in step S603), the information display unit 26 acquires a data ID 311 of the record (step S604).
Next, the information display unit 26 acquires records one at a time from the flag importance management table 32, and starts processes of loop 2 (steps S606 to S608) (step S605).
In the processes of loop 2, first, the information display unit 26 acquires a flag ID 321 from the record of the flag importance management table 32 acquired in step S605 (step S606).
Next, the information display unit 26 checks whether data with the data ID acquired in step S604 has been registered in the management table (specifically, any of the retraining likelihood management table 33, the retraining likelihood history management table 34, the monitoring screen management table 35, the monitoring screen history management table 36, the training process management table 37, and the evaluation process management table 38) that manages a flag corresponding to the flag ID 321 acquired in step S606 (step S607).
In a case where the condition is not met in step S607 (NO in step S607), the information display unit 26 checks whether the condition for terminating loop 2 is met (whether the processes have completed with respect to all the records of the flag importance management table 32), and, in a case where the condition is not met, returning to step S605, repeats the processes of loop 2. In a case where the condition for terminating loop 2 is met, the information display unit 26 proceeds to step S609.
On the other hand, in a case where the condition is met in step S607 (YES in step S607), the information display unit 26 acquires record information of the data from the management table that manages the flag corresponding to the flag ID 321 acquired in step S606 (step S608). Specifically, for example, the information display unit 26 checks whether there is the data in the monitoring screen history management table 36 on the basis of the flag ID, and, in a case where the acquired data ID has been registered, acquires information (a monitoring screen history ID 361, a flag ID 362, a data ID 363, and a use period 364) of a corresponding record. After that, the information display unit 26 checks whether the condition for terminating loop 2 is met, and, in a case where the condition is not met, returning to step S605, repeats the processes of loop 2. In a case where the condition for terminating loop 2 is met, the information display unit 26 proceeds to step S609.
By repeating the processes of loop 2 as many times as the number of records of the flag importance management table 32 as described above, the information display unit 26 can acquire, with respect to data of which the deletion is recommended in the data management table 31, a flag assigned to the data in each management table and a list of information related to the flag.
After breaking the processes of loop 2, the information display unit 26 acquires information (specifically, a data ID 311, a date 312, data 313, a data type 314, a model version 315, importance 316, and deletion recommendation 317) of the record corresponding to the data ID acquired in step S604 from the data management table 31 (step S609).
After that, the information display unit 26 checks whether the condition for terminating loop 1 is met (whether the processes have completed with respect to all the records of the data management table 31), and, in a case where the condition is not met, returning to step S601, repeats the processes of loop 1. In a case where the condition for terminating loop 1 is met, the information display unit 26 proceeds to step S610.
By repeating the processes of loop 1 as many times as the number of records of the data management table 31 as described above, the information display unit 26 can acquire, with respect to data determined that its deletion is recommended, various information including its additional information.
Last, the information display unit 26 creates the data management result screen 140 formed in a predetermined form of display using the information acquired through the foregoing steps, causes the display device 3 to display the created data management result screen 140 (step S610), and ends the result display process.
In a case of the data management result screen 140 shown in
In a case where the user wants to delete some of the data after checking the data management result screen 140, the user ticks a box for the data he/she wants to delete in the deletion candidate data list section 141, and presses a data deletion button 144. When an operation to press the data deletion button 144 has been made, the data management system 1 (for example, the data management unit 25) deletes a record that manages the data with a tick mark from the data management table 31. Furthermore, at this time, the record of the target data is also deleted from the table that manages the flag assigned to the target data.
As a result, the data management system 1 can delete input/output data that has been determined to have a low impact if deleted and on which the user, too, has made a final judgment that it can be deleted from the system. Thus, in the data management system 1, it is possible to efficiently operate deletion of unnecessary data while the life cycle of machine learning rotates, and it is possible to realize log rotation in which only necessary data remains. Then, the amount of data held by the system can be appropriately reduced, and therefore, an effect of suppressing the running cost can be obtained.
It is noted that in the above description, the user looks at the data management result screen 140 and makes a final judgment of whether or not the data determined that its deletion is recommended is actually deleted; however, a program (for example, the data management unit 25) may be configured to automatically perform a process of deleting the data determined that its deletion is recommended. Besides this, for example, it may be configured to provide a grace period until deletion of the data determined that its deletion is recommended, and inform the user that it is during the grace period, and then delete the data after the grace period.
(4) Modification Example
As described in the description of the data management system 1, output data output from a model may include, for example, abnormal data detected to be abnormal by the model. In the data management system 1, output data detected to be abnormal is determined to be data having a likelihood of retraining and is assigned a retraining likelihood flag; however, there is possibility that such abnormal data may actually be normal data (hereinafter, also referred to as “false positive data”). In a data management system that manages input/output data in a model of machine learning, input data of a model that has generated such false positive data is identified and utilized for parameter adjustment, etc., which can help improve the model. Accordingly, the data management system 1A pays attention to, of output data generated from a model, output data detected to be abnormal (abnormal data), and, in keeping with user's determination (incident response) of whether or not this abnormality detection is false positive, extracts input data of the model that has generated abnormal data determined to be false positive (false positive data), thereby realizing effective input/output data management. It is noted that such input data is also referred to as “input data corresponding to false positive data”. Characteristic configurations, processes, etc. of the data management system 1A will be described in detail below.
As shown in
The incident collection unit 41 has a function of collecting input/output data to be managed as an incident in model generation and storing the collected data in the incident management table 41 or the false positive management table 52. A process performed by the incident collection unit 41 will be described in detail with reference to an incident collection process shown in
The incident management unit 42 has a function of, with respect to data of an incident collected by the incident collection unit 41, updating the incident management table 51 and the false positive management table 52 according to an incident response of the user who determines whether output data detected to be abnormal (abnormal data) is false positive. A process performed by the incident management unit 42 will be described in detail with reference to an incident evaluation process shown in
It is noted that although not shown in
It is noted that a degree of importance of “5” of the false positive flag shown in
The incident management table 51 shown in
The incident ID 511 indicates an identifier (an incident ID) assigned to each abnormal data when registered in the incident management table 51. The model execution ID 512 indicates a model execution ID of abnormal data managed in a corresponding record. The model execution ID 512 corresponds to the model execution ID 318 of the data management table 31A. The data ID 513 indicates a data ID of abnormal data managed in a corresponding record. The data ID 513 corresponds to the data ID 311 of the data management table 31A. The detection date and time 514 indicates the date and time of when abnormal data managed in a corresponding record has been detected to be abnormal by a model. The detection date and time 514 corresponds to the date 312 of the data management table 31A; however, it may hold more detailed information than the date 312.
The state 515 indicates a state of an incident response to abnormal data managed in a corresponding record. The state 515 is, for example, any one selected from several types of status prepared in advance (it may be configured to be able to add or delete any status to/from the several types of status). Specifically, examples of the several types of status include: “new” set at the time of new registration to the incident management table 51; “on hold” set in a case where the user puts an incident response on hold; “in progress” set in a case where the user is working on an incident response; “completed” set in a case where the user has determined that it is not false positive and completed an incident response; and “false positive” set in a case where the user has determined that it is false positive and completed an incident response. It is noted that the above-described types of status are an example, and the type of status is not limited to these; however, it is preferable that at least two or more types of status indicating whether or not it is “false positive” be prepared.
The false positive management table 52 shown in
The false positive management ID 521 indicates an identifier (a false positive management ID) assigned to each input data (input data corresponding to false positive data) when registered in the false positive management table 52. The flag ID 522 indicates a flag ID of input data managed in a corresponding record. The flag ID 522 corresponds to the flag ID 321 of the flag importance management table 32A, and input data corresponding to false positive data is assigned flag ID “F0007”. The model execution ID 523 indicates a model execution ID of input data managed in a corresponding record. The model execution ID 523 corresponds to the model execution ID 318 of the data management table 31A. The data ID 524 indicates a data ID of input data managed in a corresponding record. The data ID 524 corresponds to the data ID 311 of the data management table 31A.
According to
In step S702, the incident collection unit 41 stores predetermined information regarding the new abnormal data found in step S701 in the incident management table 51. In the process of step S702, specifically, a new record is created in the incident management table 51, and a variety of information is registered in this new record. At this time, “new” is set in the state 515 of the new record.
Next, the incident collection unit 41 stores predetermined information regarding the input data corresponding to the abnormal data registered in the incident management table 51 in step S702 (i.e., the input data of the time when the model has output the abnormal data) in the false positive management table 52. Specifically, in step S703, with reference to the data management table 31A, the incident collection unit 41 searches for input data having the same model execution ID 318 as the model execution ID 512 of the abnormal data newly registered in the incident management table 51 in step S702, and acquires information regarding the corresponding input data and registers the information in the new record of the false positive management table 52. At this time, the value of the flag ID 522 of the new record may be unregistered. After the process of step S703 is finished, the incident collection unit 41 ends the incident collection process.
According to
The incident management screen is generated, for example, by the information display unit 26 or the incident management unit 42 executing a predetermined program on the basis of the incident management table 51 or various other data, and is displayed on the user side by any output method such as through a user interface. A method of displaying information on the incident management screen is not particularly limited; however, in the description here, as an example, at system startup, a site where the incident has occurred, a model, other reference information, etc. are displayed in the form of a list for each abnormal data.
After the incident to be checked is selected in step S801, predetermined detailed information regarding the selected incident is displayed on the incident management screen. This detailed information may include not only information of the abnormal data stored in the incident management table 51 but also various any other data. For example, the detailed information may include the graph on the monitoring screen 110 shown in
Next, on the basis of a result of the true-false determination in step S802, the user updates the “state” of the incident to be checked on the incident management screen (step S803). This “state” indicates a state of an incident response, and corresponds to any of the types of status prepared for the state 515 of the incident management table 51. Specifically, in a case where a result of the determination in step S803 is “false positive (the incident is false)”, the user updates the “state” of the incident to be checked to “false positive”. On the other hand, in a case where a result of the determination in step S803 is “not false positive (the incident is true)”, the user updates the “state” of the incident to be checked to “completed”. Furthermore, in a case where the true-false determination of the incident is put off in step S803, the user updates the state to “on hold” or “in progress” according to the progress.
After the “state” of the incident is updated on the incident management screen in step S803, the incident management unit 42 updates the state 515 of the corresponding record in the incident management table 51 with the updated “state” (step S804).
Next, the incident management unit 42 determines whether or not a result of the true-false determination of the incident by the user in step S802 is false positive (step S805). Specifically, the incident management unit 42 determines whether or not the state 515 of the incident management table 51 updated in Step S804 is “false positive” (Step S805). In a case where it is “false positive” (YES in step S805), the process moves on to step S806; on the other hand, in a case where it is other than “false positive” (NO in step S805), the incident evaluation process ends.
In step S806, the incident management unit 42 updates the false positive management table 52 pertaining to the input data corresponding to the abnormal data of the incident determined to be “false positive”, and sets a false positive flag. Specifically, in step S806, with the model execution ID 512 of the record in which the state 515 of the incident management table 51 has been updated to “false positive” as a key, the incident management unit 42 searches the model execution ID 523 of the false positive management table 52, and sets the value of the flag ID 522 of the record having the same model execution ID to “F0007”. Then, after step S806 is finished, the incident management unit 42 ends the incident evaluation process.
It is noted that, in the above-described incident evaluation process of
In this case, specifically, for example, in step S806, the incident management unit 42 notifies the incident collection unit 41 of the value of the model execution ID 512 in the record of the incident management table 51 in which the state 515 has been changed to “false positive” in step S804. Then, with the notified model execution ID as a key, the incident collection unit 41 searches the model execution ID 318 of the data management table 31A, and acquires information regarding input data having the same model execution ID and registers the information in the new record of the false positive management table 52. At this time, the value of the flag ID 522 of the new record is set to “F0007” indicating the false positive flag. The setting of the value of the flag ID 522 may be performed by the incident collection unit 41 at the time of registration of the new record, or may be performed by the incident management unit 42 when having received a notification of the completion of registration of the new record in the false positive management table 52 from the incident collection unit 41. Anyway, in a case where the other example of the processing procedure described above is adopted, the process of step S703 in
In a case where the other example of the processing procedure is adopted, information regarding the input data corresponding to the abnormal data determined not to be false positive is not stored in the false positive management table 52; thus, it is possible to reduce the data processing amount and simplify information managed in the false positive management table. Meanwhile, in a case where the examples of the processing procedure shown in
As described above, the data management system 1A performs the incident collection process and the incident evaluation process; thus, with respect to an incident determined to be false positive by the user, a false positive flag can be set in input data (input data that is the source of false positive) that is the source of a model that has generated the output data resulting in the incident, and information regarding the input data can be stored in the false positive management table 52. Then, the data management system 1A can use the input data assigned the false positive flag, for example, as follows.
For example, as first use, the data assigned the false positive flag may be set so as not to be used in retraining. In this case, when the false positive flag is assigned to the input data in step S806 of
It is noted that if the input data assigned the false positive flag is not abnormal data, and the retraining likelihood flag is removed from the input data, this may affect the calculation of importance of the data. Therefore, in the first use, it may be configured to perform control of avoiding the input data assigned the false positive flag being selected as data used in retraining through the retraining screen 120 (see
Furthermore, for example, as second use, the input data assigned the false positive flag may be used in the evaluation of a model updated to a new version. In this case, when the new version model has generated output data from the input data assigned the false positive flag, if no abnormality is detected in the output data, it becomes clear that the input data is not the source of the abnormal output data, and it can be determined that the model accuracy is improved.
In this way, the data management system 1A that is a modification example of the data management system 1 can provide the user with information about “input data that is the source of false positive”, and therefore it is possible to realize more efficient data management than the data management system 1.
Number | Date | Country | Kind |
---|---|---|---|
2022-113074 | Jul 2022 | JP | national |
2023-083326 | May 2023 | JP | national |