This application claims the priority benefit of Taiwan application serial no. 109146620, filed on Dec. 29, 2020. The entirety of the above-mentioned patent application is hereby incorporated by reference herein and made a part of this specification.
The disclosure relates to an electronic device and a method for screening features for predicting a physiological state.
The use of blood to obtain multiple metabolite indexes of a test subject such that the doctor may determine the physiological state of the test subject according to the multiple metabolite indexes is an important medical technology that is gradually developing. Taking the determination of the degree of obesity of the test subject as an example, the conventional technology may use the body mass index (BMI) to determine the degree of obesity of the test subject, but the calculation of the BMI only takes into account the weight and height without considering the metabolic status of the test subject.
There are many types of metabolites produced by the human body, and the correlation between each metabolite and different physiological states is also different. Therefore, if a method for screening out metabolites that are highly related to a specific physiological state can be developed, the method may assist the doctor in monitoring the physiological state of the test subject more accurately.
The disclosure provides an electronic device and a method for screening features for predicting a physiological state, which can screen out the features that are significantly related to a specific physiological state from multiple features.
An electronic device for screening features for predicting a physiological state of the disclosure includes a processor, a storage medium, and a transceiver. The storage medium stores multiple modules. The processor is coupled to the storage medium and the transceiver, and accesses and executes the multiple modules. The multiple modules include a data collection module, a training module, a computing module, and an output module. The data collection module obtains multiple physiological data corresponding to multiple features through the transceiver. The training module generates multiple first subsets of the multiple features according to the multiple physiological data based on a first model. The multiple first subsets correspond to the multiple physiological data. The computing module selects a first feature from the multiple features according to the multiple first subsets, calculates a first relation index of the first feature and a second feature corresponding to the multiple features, and selects the second feature as an accompanied feature of the first feature according to the first relation index. The output module outputs the first feature and the accompanied feature through the transceiver.
In an embodiment of the disclosure, the training module generates multiple second subsets of the multiple features according to the multiple physiological data based on a second model. The multiple second subsets respectively correspond to the multiple physiological data. The computing module selects the first feature from the multiple features according to the multiple first subsets and the multiple second subsets.
In an embodiment of the disclosure, the computing module calculates a first number of the first feature in the multiple first subsets, and calculates a second number of the first feature in the multiple second subsets. The computing module selects the first feature from the multiple features according to the first number and the second number.
In an embodiment of the disclosure, the computing module calculates a first score of the first feature according to the first number, a first weight corresponding to the first model, the second number, and a second weight corresponding to the second model. The computing module selects the first feature from the multiple features in response to the first score being greater than a first threshold value.
In an embodiment of the disclosure, the computing module calculates a first score of the first feature according to the first number, a first weight corresponding to the first model, the second number, and a second weight corresponding to the second model. The computing module calculates a third number of a third feature in the multiple first subsets and a fourth number of the third feature in the multiple second subsets. The computing module calculates a second score of the third feature according to the third number, the first weight, the fourth number, and the second weight. The computing module selects the first feature from the first feature and the third feature in response to the first score being greater than the second score.
In an embodiment of the disclosure, the computing module obtains a first number of the first feature in each of the multiple first subsets to generate a first vector. The computing module obtains a second number of the second feature in each of the multiple first subsets to generate a second vector. The computing module calculates the first relation index according to the first vector and the second vector.
In an embodiment of the disclosure, the computing module selects the second feature as the accompanied feature of the first feature in response to the first relation index being greater than a second threshold value.
In an embodiment of the disclosure, the computing module calculates a second relation index corresponding to a third feature and a fourth feature in the multiple features. The computing module selects the second feature as the accompanied feature of the first feature in response to the first relation index being greater than the second relation index.
In an embodiment of the disclosure, the training module trains at least one first prediction model of the physiological state according to the multiple physiological data, the first feature, and the accompanied feature, and calculates at least one first performance index corresponding to the at least one first prediction model. The training module randomly selects a third feature and a fourth feature from the multiple features. Any one of the third feature and the fourth feature is different from any one of the first feature and the second feature. The training module trains at least one second prediction model of the physiological state according to the multiple physiological data, the third feature, and the fourth feature, and calculates at least one second performance index of the at least one second prediction model. The computing module determines that the first feature and the accompanied feature are usable in response to the at least one first performance index being greater than the at least one second performance index. The output module outputs the first feature and the accompanied feature in response to the first feature and the accompanied feature being usable.
In an embodiment of the disclosure, the multiple features correspond to multiple metabolites of a human body.
In an embodiment of the disclosure, the data collection module receives a physiological data set through the transceiver, and divides the physiological data set into multiple training data and multiple test data respectively corresponding to the multiple physiological data according to a bootstrap. The training module generates the multiple first subsets according to the multiple training data. The training module generates the at least one first prediction model according to the multiple training data. The training module calculates the at least one first performance index according to the multiple test data.
In an embodiment of the disclosure, the first model or the second model is associated with one of a random forest algorithm, a logistic regression, and a support vector machine.
In an embodiment of the disclosure, the first model generates the multiple first subsets based on one of a stepwise selection and a feature importance.
A method for screening features for predicting a physiological state of the disclosure includes the following steps. Multiple physiological data corresponding to multiple features are obtained. Multiple first subsets of the multiple features are generated according to the multiple physiological data based on a first model. The multiple first subsets respectively correspond to the multiple physiological data. A first feature is selected from the multiple features according to the multiple first subsets, a first relation index of the first feature and a second feature corresponding to the multiple features is calculated, and the second feature is selected as an accompanied feature of the first feature according to the first relation index. The first feature and the accompanied feature are output.
Based on the above, the disclosure may select the feature that can significantly affect the prediction result of the physiological state of a test subject, and select the accompanied feature corresponding to the feature. The disclosure may output the feature and the accompanied feature as reference for the user. For example, assuming that the user is a doctor, the user may determine the degree of obesity of the test subject only by referring to the metabolite and the accompanied metabolite output by the disclosure without the need to spend effort on analyzing metabolites that are totally unrelated to obesity.
In order for the content of the disclosure to be more understandable, the following embodiments are specifically cited as examples on which the disclosure can be implemented. In addition, wherever possible, elements/components/steps with the same reference numerals in the drawings and embodiments represent the same or similar parts.
The processor 110 is, for example, a central processing unit (CPU), other programmable general-purpose or specific-purpose micro control unit (MCU), microprocessor, digital signal processor (DSP), programmable controller, application specific integrated circuit (ASIC), graphics processing unit (GPU), image signal processor (ISP), image processing unit (IPU), arithmetic logic unit (ALU), complex programmable logic device (CPLD), field programmable gate array (FPGA), other similar elements, or a combination of the above elements. The processor 110 may be coupled to the storage medium 120 and the transceiver 130, and access and execute multiple modules and various applications stored in the storage medium 120.
The storage medium 120 is, for example, any type of fixed or removable random access memory (RAM), read-only memory (ROM), flash memory, hard disk drive (HDD), solid state drive (SSD), similar elements, or a combination of the above elements, which is used to store multiple modules or various applications that may be executed by the processor 110. In this embodiment, the storage medium 120 may store multiple modules including a data collection module 121, a training module 122, a computing module 123, an output module 124, etc., and the functions thereof will be explained later.
The transceiver 130 transmits and receives signals in a wireless or wired manner. The transceiver 130 may also execute operations such as low noise amplification, impedance matching, frequency mixing, up or down frequency conversion, filtering, and amplification.
In Step S201, the data collection module 121 may receive a physiological data set of a test subject through the transceiver 130. The physiological data set may include K feature values respectively corresponding to K features. The K features (which are respectively features f1, f2, . . . , fK) may respectively correspond to K types of metabolites of a human body, where K may be any positive integer.
In Step S202, the data collection module 121 may divide the physiological data set into N physiological data corresponding to the K features, where N may be any positive integer. Specifically, the data collection module 121 may divide the physiological data set into the N physiological data according to a bootstrap. Each of the N physiological data may include training data and test data. In other words, the data collection module 121 may divide the physiological data set into N training data and N test data respectively corresponding to the N physiological data.
In an embodiment, the data collection module 121 may divide the physiological data set into a single physiological data corresponding to the K features. The physiological data may include the training data and the test data. Specifically, the data collection module 121 may divide the physiological data set into the training data and the test data according to k-fold cross-validation, thereby generating the physiological data.
In Step S203, the training module 122 may generate N subsets SB1 of the K features according to the N training data based on a first model. The N subsets SB1 may respectively correspond to the N training data. The first model may be configured to select one or more features that significantly affect a specific physiological state (for example, the degree of obesity) from the K features according to a training data. The one or more features are the subsets SB1 of the K features. Accordingly, the N training data may generate the N subsets SB1 of the K features, which are respectively subsets SB11, SB12, . . . , SB1N.
Similarly, the training module 122 may generate N subsets SB2 of the K features according to the N training data based on a second model. The N subsets SB2 may respectively correspond to the N training data. The second model may be configured to select one or more features that significantly affect a specific physiological state (for example, the degree of obesity) from the K features according to a training data. The one or more features are the subsets SB2 of the K features. Accordingly, the N training data may generate the N subsets SB2 of the K features, which are respectively subsets SB11, SB22, . . . , SB2N.
Similarly, the training module 122 may generate N subsets SB3 of the K features according to the N training data based on a third model. The N subsets SB3 may respectively correspond to the N training data. The third model may be configured to select one or more features that significantly affect a specific physiological state (for example, the degree of obesity) from the K features according to a training data. The one or more features are the subsets SB3 of the K features. Accordingly, the N training data may generate the N subsets SB3 of the K features, which are respectively subsets SB13, SB23, . . . , SB3N.
A number M of models adopted in Step S203 may be defined by the user according to requirements. Although the number M in this embodiment is equal to 3 (that is, 3 models such as the first model, the second model, and the third model are adopted), the disclosure is not limited thereto. For example, the number M may be any positive integer greater than 1.
In an embodiment, the first model (the second model, or the third model) may correspond to a random forest (RF) algorithm, a logistic regression, or a support vector machine (SVM), but the disclosure is not limited thereto. The first model (the second model, or the third model) may, for example, use a stepwise selection or a feature importance to select one or more features that significantly affect a specific physiological state from the K features. For example, the first model may use the stepwise selection to select one or more features from the K features based on a p-value or an Akaike information criterion (AIC). Different models may adopt the same or different algorithms. For example, the first model, the second model, and the third model may adopt the same or different algorithms.
In Step S204, the computing module 123 may obtain the N subsets SB1 corresponding to the first model (which are respectively the subsets SB11, SB21, . . . SB1N), the N subsets SB2 corresponding to the second model (which are respectively the subsets SB12, SB22, . . . , SB2N), and the N subsets SB3 corresponding to the third model (which are respectively the subsets SB31, SB23, . . . , SB3N).
In Step S205, the computing module 123 may calculate a score of each of the K features according to N subsets SBm, where m is the index of the model. For example, m=1 corresponds to the first model, m=2 corresponds to the second model, and m=3 corresponds to the third model.
Assuming that the computing module 123 intends to calculate a score Zj of a feature fj in the K features, the computing module 123 may calculate a number Sj,SB
S
j,SB
=Σi=1NSj,SB
For example, assuming that the total number of physiological data is 3 (N=3) and the total number of features is 5 (K=5), the computing module 123 may generate the following Table 1, Table 2, and Table 3 according to Equation (1). Table 1 corresponds to the first model, Table 2 corresponds to the second model, and Table 3 corresponds to the third model. Taking a feature f1 in Table 1 as an example, a number S1,SB
After obtaining the number Sj,SB
R
j,SB
=S
j,SB
/N (2)
For example, assuming that N=3, the computing module 123 may generate the following Table 4 according to Table 1, Table 2, and Table 3 based on Equation (2). A number Sj,SB
After obtaining the ratio Rj,SB
Z
j=Σm=1MRj,SB
For example, assuming that the weight w1=⅓, the weight w2=⅓, and the weight w3=⅓, the computing module 123 may generate the following Table 5 according to Table 4 based on Equation (3) as shown below.
After obtaining the score Zj corresponding to the feature fj in the K features, in Step S206, the computing module 123 may determine whether the feature fj is a selected feature according to a threshold value m1 and the score Zj.
In an embodiment, the threshold value m1 may be associated with a score ranking of the feature fj in the K features. For example, the threshold value m1 may indicate that features with what high scores in the K features are used as selected features. Taking Table 5 as an example, the computing module 123 may select the feature f1 with the highest score from the feature f1 to the feature f5 as the selected feature according to the threshold value m1. In other words, the computing module 123 may select the feature f1 corresponding to the score Z1 from the feature f1 to the feature f5 as the selected feature in response to the score Z1 being greater than the score Z2, the score Z3, the score Z4, and the score Z5.
In an embodiment, the computing module 123 may select the feature fj as the selected feature in response to the score Zj exceeding the threshold value m1. Taking Table 5 as an example, assuming that the threshold value m1 is equal to 5/9, the computing module 123 may select the feature f1 as the selected feature in response to the score Z1 of the feature f1 being greater than 5/9.
In Step S207, the computing module 123 may calculate a relation index between each of the K features and other features. Specifically, the computing module 123 may obtain K vectors respectively corresponding to the K features, and select two vectors from the K vectors to calculate the relation index between the two vectors.
If the computing module 123 intends to calculate the relation index between a feature fA and a feature fB in the K features, the computing module 123 may generate a vector VA,SB
V
A,SB
=(SA,SB
V
B,SB
=(SB,SB
For example, the computing module 123 may generate the following Table 6 according to Tables 1, 2, and 3 based on Equation (4) and Equation (5). Table 6 includes M*K vectors corresponding to the K features (where K=5) and M models (where M=3). Each vector may include N elements (where N=3) corresponding to the N training data.
The computing module 123 may calculate the relation index corresponding to at least two features. For example, if the at least two features include only two features, the computing module 123 may calculate the relation index between the two features (for example, the feature fA and the feature fB) based on Equation (6), where C(Vx, Vy) is the correlation coefficient between a vector Vx and a vector Vy, and Wm is the weight corresponding to the m-th model. For another example, if the at least two features exceed two features, the computing module 123 may calculate the p-value of the at least two features based on an analysis of variance (ANOVA) test as the relation index.
RI(fA,fB)=Σm=1MC(VA,SB
In an embodiment, the weights corresponding to the first model, the second model, and the third model may respectively be the weight w1=0, the weight w2=0, and the weight w3=1. In an embodiment, the weights corresponding to the first model, the second model, and the third model may respectively be the weight w1=⅓, the weight w2=⅓, and the weight w3=⅓. For example, if the weight w1=⅓, the weight w2=⅓, and the weight w3=⅓, the computing module 123 may generate Table 7 according to the vectors of Table 6 based on Equation (6).
In Step S208, the computing module 123 may determine whether the feature fA and the feature fB are the selected feature pair according to the threshold value m2 and the relation index RI(fA, fB).
In an embodiment, the threshold value m2 may be associated with a relation index ranking of a feature pair in C2K feature pairs. For example, the threshold value m2 may indicate that feature pairs with what high relation indexes in the C2K feature pairs are used as selected feature pairs. Taking Table 7 as an example, the computing module 123 may select the feature pair (f1, f2) with the highest relation index from 10 feature pairs according to the threshold value m2 as the selected feature pair. In other words, the computing module 123 may select the feature pair (f1, f2) from the 10 feature pairs in Table 7 as the selected feature pair in response to the relation index RI(f1, f2) being greater than the relation indexes RI(f1, f3), RI(f1, f4), RI(f1, f5), RI(f2, f3), RI(f2, f3), RI(f2, f5), RI(f3, f4), RI(f3, f5), and RI(f4, f5).
In an embodiment, the computing module 123 may select the feature pair (fA, fB) as the selected feature pair in response to the relation index RI(fA, fB) exceeding the threshold value m2. Taking Table 7 as an example, assuming that the threshold value m2 is equal to ¼, the computing module 123 may select the feature pair (f1, f2) as the selected feature pair in response to the relation index RI(f1, f2) being greater than ¼, but the selected feature pair is not limited to one pair.
After executing Step S206 and Step S208 to respectively obtain the selected feature and the selected feature pair, in Step S209, the computing module 123 may obtain a feature corresponding to the selected feature from the selected feature pair as an accompanied feature. For example, after determining that the feature fA is the selected feature and the feature pair (fA, fB) is the selected feature pair, the computing module 123 may select the feature fB corresponding to the feature fA from the feature pair (fA, fB) as the accompanied feature of the feature fA.
In an embodiment, the accompanied feature may be selected by a professional from the K features according to experience as the accompanied feature.
In Step S210, the output module 124 may output the selected feature and the accompanied feature through the transceiver 130. In an embodiment, the computing module 123 may determine whether the selected feature and the accompanied feature are usable. If the selected feature and the accompanied feature are usable, the output module 124 may output the selected feature and the accompanied feature. If the selected feature and the accompanied feature are not usable, the output module 124 may not output the selected feature and the accompanied feature.
In Step S301, the computing module 123 obtains a selected feature and an accompanied feature corresponding to the selected feature.
In Step S302, the training module 122 may obtain parts corresponding to the selected feature and the accompanied feature from N training data to train at least one first prediction model for predicting a physiological state. The at least one first prediction model may correspond to an RF algorithm, a logistic regression, or a SVM, but the disclosure is not limited thereto.
In Step S303, the training module 122 may obtain parts corresponding to the selected feature and the accompanied feature from N test data to calculate at least one first performance index corresponding to the at least one first prediction model. The at least one first performance index may correspond to parameters such as accuracy (ACC), precision, recall rate, false positive (FP), or F1 score in a confusion matrix.
In Step S304, the training module 122 may select two random features from the K features. Any one of the two random features is different from any one of the selected feature and the accompanied feature. Then, the training module 122 may obtain parts corresponding to the two random features from the N training data to train at least one second prediction model for predicting the physiological state. The at least one second prediction model may correspond to the RF algorithm, the logistic regression, or the SVM, but the disclosure is not limited thereto.
In an embodiment, the training module 122 may select multiple random features corresponding to the number of selected features and accompanied features from the K features, so as to train the at least one second prediction model. For example, if the total number of selected features and accompanied features obtained by the computing module 123 in Step S301 is 4, the training module 122 may select 4 random features from the K features to train the at least one second prediction model.
In Step S305, the training module 122 may obtain parts corresponding to the two random features (or multiple random features corresponding to the number of selected features and accompanied features) from the N test data to calculate at least one second performance index corresponding to the at least one second prediction model. The at least one second performance index may correspond to the parameters such as ACC, precision, recall, FP, or F1 score in the confusion matrix.
In Step S306, the computing module 123 may determine whether the at least one first performance index is greater than the at least one second performance index. If the at least one first performance index is greater than the at least one second performance index, Step S307 is proceeded. If the at least one first performance index is less than or equal to the at least one second performance index, Step S308 is proceeded.
In Step S307, the computing module 123 may determine that the selected feature and the accompanied feature are usable. In Step S308, the computing module 123 may determine that the selected feature and the accompanied feature are not usable.
The multiple first subsets respectively correspond to the multiple physiological data. In Step S403, a first feature is selected from the multiple features according to the multiple first subsets, a first relation index of the first feature and a second feature corresponding to the multiple features is calculated, and the second feature is selected as the accompanied feature of the first feature according to the first relation index. In Step S404, the first feature and the accompanied feature are output.
In summary, the disclosure may use different types of models to select the feature that significantly affects the prediction result of the physiological state from multiple features, and may select the accompanied feature corresponding to the feature according to the relation index between the feature and other features. The accompanied features selected according to the method may also significantly affect the prediction result of the physiological state. After obtaining at least one feature and at least one corresponding accompanied feature, the disclosure may train the prediction model according to the at least one feature and the at least one accompanied feature, and calculate the performance index of the prediction model. If the performance index shows that the at least one feature and the at least one accompanied feature may significantly affect the prediction result of the physiological state by the prediction model, the disclosure may output the at least one feature and the at least one accompanied feature as reference for the user.
Number | Date | Country | Kind |
---|---|---|---|
109146620 | Dec 2020 | TW | national |