The present disclosure relates to opinion mining technologies, and in particular, to an information processing method and apparatus.
With rapid expansion of the Internet, online shopping has become increasingly popular, many online shopping websites provide a product evaluation platform, making it convenient for users to share produce use experience and to make comments upon products, and the comments are of important reference value for both consumers and product providers.
Currently, the related art uses an opinion mining (also known as comment mining) apparatus to analyze an evaluation text (also known as corpus) from the product evaluation platform, to obtain users' opinion information for the products, however, tests have proved that the precision rate of opinion information obtained by the information processing apparatus provided by the related art is not high, which makes wrong opinion information become “noise”, and too much “noise” results in that the product providers cannot make accurate judgment on the product market reaction, and also results in that the consumers cannot correctly select required products according to the opinion information.
Embodiments of the present invention provide an information processing method and apparatus, which can enhance precision of extracting opinion information from an evaluation text.
The technical solution of the embodiments of the present invention is implemented as follows:
The embodiments of the present invention provide an information processing method, the method including:
training a Deep Neural Network (DNN) by using an evaluation object seed, an evaluation term seed and an evaluation relationship seed, the DNN including a first input layer, a first hidden layer and a first output layer, the number of nodes of the first input layer corresponding to that of the first output layer, and the number of nodes of the first input layer being greater than that of the first hidden layer;
at the first input layer, connecting vectors corresponding to a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship to obtain a first input vector, at the first hidden layer, compressing the first input vector to obtain a first middle vector, and at the first output layer, decoding the first middle vector to obtain a first output vector; and
determining a first output vector whose decoding error value is less than a decoding error value threshold, and determining a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined first output vector as first opinion information.
Preferably, the training a DNN by using an evaluation object seed, an evaluation term seed and an evaluation relationship seed includes:
at the first input layer, connecting vectors corresponding to the evaluation object seed, the evaluation term seed and the evaluation relationship seed to obtain a second input vector;
at the first hidden layer, compressing the second input vector to obtain a second middle vector; and
updating a parameter set of the DNN until a Euclidean distance between a second output vector and the second input vector is minimum, the second output vector being a vector obtained by decoding the second middle vector at the first output layer.
Preferably, the method further includes:
sorting evaluation objects in the first opinion information according to the following dimensions in descending order: the number of times the evaluation objects in the first opinion information occur in an evaluation text; and the number of times the evaluation objects in the first opinion information are identified as evaluation object positive examples;
selecting M evaluation objects, in descending order, from the evaluation objects sorted in descending order, and determining the selected M evaluation objects as a subset of the evaluation object seed, M being an integer greater than 1; and
training the DNN by using the evaluation object seed, the evaluation term seed and the evaluation relationship seed after updating.
Preferably, after the training the DNN by using the evaluation object seed, the evaluation term seed and the evaluation relationship seed after updating, the method further includes:
at the first input layer of the DND after updating, connecting vectors corresponding to the candidate evaluation object, the candidate evaluation term and the candidate evaluation relationship to obtain a third input vector, at the first hidden layer of the DND after updating, compressing the third input vector to obtain a third middle vector, and at the first output layer of the DND after updating, decoding the third middle vector to obtain a third output vector; and
determining a third output vector whose decoding error value is less than a decoding error value threshold, and determining a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined third output vector as second opinion information.
Preferably, before the determining a first output vector whose decoding error value is less than a decoding error value threshold, the method further includes:
determining the decoding error value threshold according to the following dimensions:
target precision of opinion information extracted from an evaluation text; and target quantity of the opinion information extracted from the evaluation text; wherein
the decoding error value threshold is negatively correlated with the target precision, and is positively correlated with the target quantity.
Preferably, before, at the first input layer of the DNN, connecting vectors corresponding to a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship, the method further includes:
mapping the candidate evaluation object and the candidate evaluation term into corresponding vectors by using the DNN; and
at a second hidden layer to an nth hidden layer of the DNN, recursively mapping objects included in a syntactic dependency path of the evaluation relationship into vectors; wherein
a Euclidean distance between any two vectors in the vectors obtained through mapping is positively correlated with a semantic or syntactic likelihood ratio test (LRT) index of the any two vectors, n is a positive integer, and n corresponds to the number of the objects included in the syntactic dependency path of the evaluation relationship.
Preferably, before, at the first input layer of the DNN, connecting vectors mapped by an evaluation object, an evaluation term and an evaluation relationship, the method further includes:
extracting nouns from the evaluation text;
determining an LRT index between an initial evaluation object seed and the nouns extracted from the evaluation text; and
determining nouns in the extracted nouns the LRT index between which and the initial evaluation object seed is greater than an LRT index threshold as a subset of the evaluation object seed.
The embodiments of the present invention further provide an information processing apparatus, including:
a training unit, configured to train a DNN by using an evaluation object seed, an evaluation term seed and an evaluation relationship seed, the DNN including a first input layer, a first hidden layer and a first output layer, the number of nodes of the first input layer corresponding to that of the first output layer, and the number of nodes of the first input layer being greater than that of the first hidden layer;
a connection unit, configured to, at the first input layer, connect vectors corresponding to a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship to obtain a first input vector;
a compression unit, configured to, at the first hidden layer, compress the first input vector to obtain a first middle vector;
a decoding unit, configured to, at the first output layer, decode the first middle vector to obtain a first output vector; and
a first determination unit, configured to determine a first output vector whose decoding error value is less than a decoding error value threshold, and determine a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined first output vector as first opinion information.
Preferably, the connection unit is further configured to, at the first input layer, connect vectors corresponding to the evaluation object seed, the evaluation term seed and the evaluation relationship seed to obtain a second input vector;
the compression unit is further configured to, at the first hidden layer, compress the second input vector to obtain a second middle vector;
the decoding unit is further configured to, at the first output layer, decode the second middle vector to obtain a second output vector; and
the training unit is further configured to update a parameter set of the DNN until a Euclidean distance between the second output vector and the second input vector is minimum.
Preferably, the apparatus further includes:
a sorting unit, configured to sort evaluation objects in the first opinion information according to the following dimensions in descending order: the number of times the evaluation objects in the first opinion information occur in an evaluation text; and the number of times the evaluation objects in the first opinion information are identified as evaluation object positive examples;
an updating unit, configured to select M evaluation objects, in descending order, from the evaluation objects sorted in descending order, and determine the selected M evaluation objects as a subset of the evaluation object seed, M being an integer greater than 1; and
the training unit is further configured to train the DNN by using the evaluation object seed, the evaluation term seed and the evaluation relationship seed after updating.
Preferably, the connection unit is further configured to, at the first input layer of the DND after updating, connect vectors corresponding to the candidate evaluation object, the candidate evaluation term and the candidate evaluation relationship to obtain a third input vector;
the compression unit is further configured to, at the first hidden layer of the DND after updating, compress the third input vector to obtain a third middle vector;
the decoding unit is further configured to, at the first output layer of the DND after updating, decode the third middle vector to obtain a third output vector; and
the first determination unit is further configured to determine a third output vector whose decoding error value is less than a decoding error value threshold, and determine a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined third output vector as second opinion information.
Preferably, the first determination unit is further configured to, before determining a first output vector whose decoding error value is less than a decoding error value threshold, determine the decoding error value threshold according to the following dimensions:
target precision of opinion information extracted from an evaluation text; and target quantity of the opinion information extracted from the evaluation text; wherein
the decoding error value threshold is negatively correlated with the target precision, and is positively correlated with the target quantity.
Preferably, the apparatus further includes:
a first mapping unit, configured to map the candidate evaluation object and the candidate evaluation term into corresponding vectors by using the DNN; and
a second mapping unit, configured to, at a second hidden layer to an nth hidden layer of the DNN, recursively map objects included in a syntactic dependency path of the evaluation relationship into vectors; wherein
a Euclidean distance between any two vectors in the vectors obtained through mapping is positively correlated with a semantic or syntactic LRT index of the any two vectors, n is a positive integer, and n corresponds to the number of the objects included in the syntactic dependency path of the evaluation relationship.
Preferably, the apparatus further includes:
an extraction unit, configured to extract nouns from the evaluation text; and
a second determination unit, configured to determine an LRT index between an initial evaluation object seed and the nouns extracted from the evaluation text; and determine nouns in the extracted nouns the LRT index between which and the initial evaluation object seed is greater than an LRT index threshold as a subset of the evaluation object seed.
In the embodiments of the present invention, vectors corresponding to an evaluation object, an evaluation term and an evaluation relationship are connected at a first input layer of a DNN and are input to a first hidden layer, and as the number of nodes of the first hidden layer is less than that of the first input layer, it is equivalent to compressing semantic or syntactic features represented by each dimension of the input vectors at the first hidden layer; when the vectors are output to a first output layer for computing, as the number of nodes of the first output layer corresponds to that of the first input layer, it is equivalent to decoding and outputting a middle vector after compression at the hidden layer, and during implementation of the present disclosure, the inventor finds that the smaller a decoding error value of a vector is, the greater the probability that the evaluation object, the evaluation term and the evaluation relationship corresponding to the vector are correct opinion information is, so that extraction precision of opinion information can be controlled according to the decoding error value, achieving an effect of enhancing precision of extracting opinion information from an evaluation text.
In order to make the objectives, technical solutions and advantages of the present disclosure more comprehensible, the present disclosure is further described below in detail with reference to accompanying drawings and embodiments. It should be understood that specific embodiments described herein are merely used to explain the present disclosure, but not intended to limit the present disclosure.
During implementation of the present disclosure, the inventor finds that, in the related art, opinion information obtained by an information processing apparatus includes evaluation objects (generally functions or attributes of a product), evaluation terms (words expressing user opinion polarity, which can be understood as polarity sentiment words) and evaluation relationships (that is, modification relationships between the evaluation terms and the evaluation objects); the inventor also finds the problem that the precision rate of opinion information output by the information processing apparatus in the related art is not high, which is shown in the following aspects:
1) Incorrect Identification of Evaluation Terms.
That is, words not expressing user opinion polarity are identified as evaluation terms.
For example, if an evaluation text in an mp3 field (i.e., the evaluation text is from an evaluation platform of an mp3 product) includes an evaluation text “Just another mp3 I bought”, the information processing apparatus, when processing the evaluation text according to a syntactic dependency path, thinks that the word closest to an evaluation object in a sentence is an evaluation term, therefore, when “mp3” is used as an evaluation object seed to search for an evaluation term in the evaluation text, for the evaluation text, it is determined that “another” is an evaluation term that modifies the evaluation object “mp3”, and as the evaluation term “another” is not a polarity sentiment word (e.g., good, bad), it results in that noise opinion information is output, thereby affecting precision of extracting opinion information.
Similarly, in the related art, when the information processing apparatus uses a co-occurrence statistical manner to determine opinion information, if, in the evaluation text in the mp3 field, a ratio of the number of times “another” and the evaluation object seed “mp3” co-occur in the evaluation text (set as a) to the sum of the number of times “another” occurs alone in the evaluation text (set as b) and the number of times “mp3” occurs alone in the evaluation text (set as c), that is, a/(b+c), exceeds a preset threshold, it is determined that “another” and “mp3” are elements in the opinion information, it is determined according to part of speech that “another” is used for evaluating “mp3”, and the corresponding opinion information is “another mp3”, which results in that noise opinion information is extracted, thereby affecting precision of extracting opinion information.
2) Incorrect Identification of Evaluation Objects.
That is, a word modified by an evaluation object is identified incorrectly.
For example, for an evaluation text “the mp3 has many good things”, the information processing apparatus, when processing the evaluation text based on a syntactic dependency path, thinks that the word closest to an evaluation object in a sentence is an evaluation term, that is, an evaluation relationship exists between the word closest to the evaluation object and the evaluation object, therefore, when “good” is used as an evaluation term seed to look for an evaluation object in the evaluation text in the mp3 field (i.e., the evaluation text is an evaluation text of an mp3 product), for the evaluation text, it is determined that the object modified by “good”, i.e., the evaluation object, is “things”, however, things is a word irrelevant to the field of mp3 products, which thus generates noise opinion information.
Similarly, in the related art, when the information processing apparatus uses a co-occurrence statistical manner to determine opinion information, when “mp3” is used as an evaluation term seed to look for an evaluation object in the evaluation text of mp3, if a ratio of the number of times “another” and “mp3” co-occur in the evaluation text to the number of times “another” and “mp3” occur separately in the evaluation text exceeds a preset threshold, it is determined that “another” and “mp3” are elements in the opinion information, it is determined according to part of speech that “another” is used for evaluating “mp3”, and the corresponding opinion information is “another mp3”, which thus generates noise opinion information.
In combination with the analysis, the inventor finds that, in the related art, during extraction of opinion information, only any two in an evaluation term, an evaluation object and an evaluation relationship are verified in an evaluation text, thus resulting in the problem of low precision of extraction of opinion information. For example, when an evaluation term is determined according to an evaluation object seed term, it is determined that the evaluation term is used for modifying the evaluation object seed term, but whether a modification relationship between the determined evaluation term and the evaluation object seed term is correct has not been verified; likewise, when the evaluation object is determined according to an evaluation term seed, it is determined that the evaluation term seed is used for modifying the determined evaluation object, but whether a modification relationship between the evaluation term seed and the determined evaluation object is correct is not verified, resulting in that the information processing apparatus in the related art has a problem that extraction precision of opinion information is not high; accordingly, the inventor thinks that precision of extracting the opinion information can be improved significantly if the evaluation term, the evaluation object and the evaluation relationship can be verified at the same time when the opinion information is extracted from the evaluation text.
One embodiment of the present invention describes an information processing method, which can verify evaluation terms, evaluation objects and evaluation relationships included in an evaluation text at the same time and has high precision of extraction of opinion information; as shown in
Step 101. Train a DNN by using an evaluation object seed, an evaluation term seed and an evaluation relationship seed.
The DNN includes a first input layer, a first hidden layer and a first output layer, the number of nodes of the first input layer corresponds to that of the first output layer, and the number of nodes of the first input layer is greater than that of the first hidden layer.
The evaluation object seed, the evaluation term seed and the evaluation relationship seed can correspond to a different product field (such as MP3 or Phone), and the evaluation object seed, the evaluation term seed and the evaluation relationship seed constitute correct opinion information (opposite to noise opinion information) of a product in a corresponding field; therefore, seeds can also be seen as positive examples, and the evaluation object seed, the evaluation term seed and the evaluation relationship seed constitute opinion information positive examples.
Step 102. At the first input layer, connect vectors corresponding to a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship to obtain a first input vector.
A candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship constitute candidate opinion information, and the embodiment of the present invention is aimed at extracting correct opinion information from the candidate opinion information; the candidate evaluation object and the candidate evaluation term can be obtained through extraction from an evaluation text, for example, verbs and adjectives can be extracted from the evaluation text as candidate evaluation terms, and nouns are extracted from the evaluation text as candidate evaluation objects; the candidate evaluation relationship can be determined based on a syntactic dependency path of the evaluation text.
Vectors corresponding to the candidate evaluation object and the candidate evaluation term can be obtained through word vector learning by using the DNN, the word vector learning refers to mapping the candidate evaluation object and the candidate evaluation term to a high-dimensional space to obtain vectors, and each dimension of the vectors represents a syntactic or semantic feature of the term; the embodiment of the present invention carries out word vector learning according to the following strategy, i.e., when two words are syntactically or semantically closer, a Euclidean distance between word vectors of the two words is smaller.
The vector corresponding to the candidate evaluation relationship can be obtained by recursively mapping the evaluation relationship according to a syntactic dependency path at a second hidden layer to an nth hidden layer of the DNN; wherein a Euclidean distance between any two vectors in the vectors obtained through mapping is positively correlated with a semantic or syntactic LRT index of the any two vectors, n is a positive integer, and n corresponds to the number of the objects included in the syntactic dependency path of the evaluation relationship.
Step 103. At the first hidden layer, compress the first input vector to obtain a first middle vector, and at the first output layer, decode the first middle vector to obtain a first output vector.
As the number of nodes (also referred to as computing units) of the first hidden layer is less than that of the first input layer and each node of the first hidden layer only carries an operation of one dimension of a vector, semantic or syntactic features of the vector output by the first input layer to the first hidden layer can be compressed; as the number of nodes of the first output layer is the same as that of the first input layer, the middle vector output by the first hidden layer to the first output layer can be decoded.
Step 104. Determine a first output vector whose decoding error value is less than a decoding error value threshold, and determine a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined first output vector as first opinion information.
During implementation of the present disclosure, the inventor finds that, if a vector corresponding to an opinion information positive example (i.e., the vector formed by connecting the vectors corresponding to the evaluation object seed, the evaluation term seed and the evaluation relationship seed) is input at the first input layer, as the closer semantic or syntactic features between vectors are, the smaller the Euclidean distance between the vectors is, therefore, semantic or syntactic features of the opinion information positive example can be well decoded at the first output layer (that is, a less decoding error value will be obtained); on the contrary, if an opinion information negative example (i.e., noise opinion information) is input at the first input layer, a decoding error value of the vector output at the first output layer will be greater than that of the vector corresponding to the opinion information positive example, thus leading to failure of decoding at the output layer; accordingly, the process of extracting opinion information from an evaluation text can be converted to a process of, at the first input layer, inputting first input vectors corresponding to a candidate evaluation term, a candidate evaluation object and a candidate evaluation relationship and verifying a first output vector with a less decoding error value at the first output layer, for example, a candidate evaluation term, a candidate evaluation object and a candidate evaluation relationship corresponding to vectors in the first output vectors decoded and output whose decoding error value is less than a decoding error value threshold can be output as opinion information positive examples (i.e., first opinion information).
Before first input vectors corresponding to a candidate evaluation term, a candidate evaluation object and a candidate evaluation relationship are input at the first input layer, it is necessary to use an evaluation term seed, an evaluation object seed and an evaluation relationship seed to train a DNN, so that the DNN has good performance of correctly decoding semantic or syntactic features of vectors corresponding to positive examples at the first output layer (i.e., the decoding error value is small).
As one example, the DNN can be trained in the following manner: at the first input layer, connecting vectors corresponding to the evaluation object seed, the evaluation term seed and the evaluation relationship seed to obtain a second input vector; at the first hidden layer, compressing the second input vector to obtain a second middle vector; and updating a parameter set of the DNN until a Euclidean distance between a second output vector and the second input vector is minimum, the second output vector being a vector obtained by decoding the second middle vector at the first output layer.
During actual applications, evaluation object seeds inevitably have a problem of sparse distribution, thus resulting in that first opinion information extracted from the evaluation text is incomplete; in view of this, evaluation objects in the first opinion information can be sorted according to the following dimensions in descending order: the number of times the evaluation objects in the first opinion information occur in an evaluation text; and the number of times the evaluation objects in the first opinion information are identified as evaluation object positive examples; selecting M (M is an integer greater than 1) evaluation objects, in descending order, from the evaluation objects sorted in descending order, and determining the selected M evaluation objects as a subset of the evaluation object seed, equivalent to expanding the evaluation object seeds according to the opinion information (i.e., first opinion information) extracted from the evaluation text for the first time, in this way, re-training the DNN by using the evaluation term seed, the evaluation relationship seed and the evaluation object seed after updating can make the DNN have good performance of correctly decoding semantic or syntactic features of vectors corresponding to positive examples at the first output layer.
Correspondingly, it is feasible to, at the first input layer of the DND after updating, connect vectors corresponding to the candidate evaluation object, the candidate evaluation term and the candidate evaluation relationship to obtain a third input vector, at the first hidden layer of the DND after updating, compress the third input vector to obtain a third middle vector, and at the first output layer of the DND after updating, decode the third middle vector to obtain a third output vector; and determine a third output vector whose decoding error value is less than a decoding error value threshold, and determine a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined third output vector as second opinion information; as the second opinion information is obtained based on the re-trained DNN, the second opinion information is more comprehensive relative to the first opinion information, that is, compared with the first opinion information, the second opinion information includes more candidate evaluation term positive examples, candidate evaluation object positive examples and candidate evaluation relationship positive examples.
In order to further overcome the problem of sparse distribution of the evaluation object seeds, at the first input layer of the DNN, before vectors corresponding to the evaluation object, the evaluation term and the evaluation relationship are connected to train the DNN, nouns can be extracted from the evaluation text; an LRT index between an initial evaluation object seed and the nouns extracted from the evaluation text is determined, and nouns in the extracted nouns the LRT index between which and the initial evaluation object seed is greater than an LRT index threshold are determined as a subset of the evaluation object seed; equivalent to expanding the evaluation object seed based on the evaluation text, as the expanded evaluation object seed is an evaluation object positive example acquired from the evaluation text, training the DNN by using the expanded evaluation object seed, the evaluation term seed and the evaluation relationship seed can make the DNN have good performance of correctly decoding semantic or syntactic features of vectors corresponding to positive examples at the first output layer.
During actual applications, the decoding error value threshold can be determined according to the following dimensions:
target precision of opinion information extracted from an evaluation text; and target quantity of the opinion information extracted from the evaluation text; wherein the decoding error value threshold is negatively correlated with the target precision, and is positively correlated with the target quantity; that is to say, the smaller the decoding error value threshold is, the higher the precision of the first opinion information and the second opinion information is, as the decoding error value threshold becomes less, equivalent to improving requirements for decoding precision, the fewer the first output vectors less than the decoding error value obtained at the first output layer are, and correspondingly, the number of the first opinion information (or the second opinion information) is less; and vice versa.
In the embodiment of the present invention, vectors corresponding to an evaluation object, an evaluation term and an evaluation relationship are connected at a first input layer of a DNN and are input to a first hidden layer, and as the number of nodes of the first hidden layer is less than that of the first input layer, it is equivalent to compressing semantic or syntactic features represented by each dimension of the input vectors at the first hidden layer; when the vectors are output to a first output layer for computing, as the number of nodes of the first output layer corresponds to that of the first input layer, it is equivalent to decoding and outputting a middle vector after compression at the hidden layer, and during implementation of the present disclosure, the inventor finds that the smaller a decoding error value of a vector is, the greater the probability that the evaluation object, the evaluation term and the evaluation relationship corresponding to the vectors are correct opinion information is, so that extraction precision of opinion information can be controlled according to the decoding error value, achieving an effect of enhancing precision of extracting opinion information from an evaluation text; at the same time, vectors are formed by connecting vectors corresponding to a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship, which is equivalent to verifying the evaluation object, the evaluation term and the evaluation relationship simultaneously by using a decoding error threshold during extraction of opinion information, and precision of the extraction of opinion information is definitely higher than that in the related art.
The embodiments of the present invention further describe a computer storage medium, the computer storage medium stores a computer executable instruction, and the computer executable instruction is used for performing the information processing method shown in
The embodiments of the present invention further describe an information processing apparatus, as shown in
a training unit 21, configured to train a DNN by using an evaluation object seed, an evaluation term seed and an evaluation relationship seed, the DNN including a first input layer, a first hidden layer and a first output layer, the number of nodes of the first input layer corresponding to that of the first output layer, and the number of nodes of the first input layer being greater than that of the first hidden layer;
a connection unit 22, configured to, at the first input layer, connect vectors corresponding to a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship to obtain a first input vector;
a compression unit 23, configured to, at the first hidden layer, compress the first input vector to obtain a first middle vector;
a decoding unit 24, configured to, at the first output layer, decode the first middle vector to obtain a first output vector; and
a first determination unit 25, configured to determine a first output vector whose decoding error value is less than a decoding error value threshold, and determine a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined first output vector as first opinion information.
As one implementation, the connection unit 22 is further configured to, at the first input layer, connect vectors corresponding to the evaluation object seed, the evaluation term seed and the evaluation relationship seed to obtain a second input vector;
the compression unit 23 is further configured to, at the first hidden layer, compress the second input vector to obtain a second middle vector;
the decoding unit 24 is further configured to, at the first output layer, decode the second middle vector to obtain a second output vector; and
the training unit 25 is further configured to update a parameter set of the DNN until a Euclidean distance between the second output vector and the second input vector is minimum.
As one implementation, as shown in
a sorting unit 25, configured to sort evaluation objects in the first opinion information according to the following dimensions in descending order: the number of times the evaluation objects in the first opinion information occur in an evaluation text; and the number of times the evaluation objects in the first opinion information are identified as evaluation object positive examples;
an updating unit 26, configured to select M evaluation objects, in descending order, from the evaluation objects sorted in descending order, and determine the selected M evaluation objects as a subset of the evaluation object seed, M being an integer greater than 1; and
the training unit 21 is further configured to train the DNN by using the evaluation object seed, the evaluation term seed and the evaluation relationship seed after updating.
As one implementation, the connection unit 22 is further configured to, at the first input layer of the DND after updating, connect vectors corresponding to the candidate evaluation object, the candidate evaluation term and the candidate evaluation relationship to obtain a third input vector;
the compression unit 23 is further configured to, at the first hidden layer of the DND after updating, compress the third input vector to obtain a third middle vector;
the decoding unit 24 is further configured to, at the first output layer of the DND after updating, decode the third middle vector to obtain a third output vector; and
the first determination unit 25 is further configured to determine a third output vector whose decoding error value is less than a decoding error value threshold, and determine a candidate evaluation object, a candidate evaluation term and a candidate evaluation relationship corresponding to the determined third output vector as second opinion information.
As one implementation, the first determination unit 25 is further configured to, before determining a first output vector whose decoding error value is less than a decoding error value threshold, determine the decoding error value threshold according to the following dimensions:
target precision of opinion information extracted from an evaluation text; and target quantity of the opinion information extracted from the evaluation text; wherein the decoding error value threshold is negatively correlated with the target precision, and is positively correlated with the target quantity.
As one implementation, as shown in
a first mapping unit 27, configured to map the candidate evaluation object and the candidate evaluation term into corresponding vectors by using the DNN; and
a second mapping unit 28, configured to, at a second hidden layer to an nth hidden layer of the DNN, recursively map objects included in a syntactic dependency path of the evaluation relationship into vectors; wherein
a Euclidean distance between any two vectors in the vectors obtained through mapping is positively correlated with a semantic or syntactic LRT index of the any two vectors, n is a positive integer, and n corresponds to the number of the objects included in the syntactic dependency path of the evaluation relationship.
As one implementation, as shown in
an extraction unit 29, configured to extract nouns from the evaluation text; and
a second determination unit 210, configured to determine an LRT index between an initial evaluation object seed and the nouns extracted from the evaluation text; and determine nouns in the extracted nouns the LRT index between which and the initial evaluation object seed is greater than an LRT index threshold as a subset of the evaluation object seed.
It should be noted that, the technical features of information processing performed by the information processing apparatus correspond to those described in the method embodiment, and reference can be made to the description in the method embodiment for details not disclosed in the apparatus embodiment.
It should be noted that, the information processing apparatus described in the embodiment of the present invention can be run in one or more servers, and units in the information processing apparatus can be implemented by a Central Processing Unit (CPU) and a co-processing computer card in the information processing apparatus.
Description is given below in combination with an actual processing scenario, as shown in
Step 1. Acquire Seeds
It is necessary to acquire seeds before the evaluation text from the evaluation platform is processed, the acquired seeds including an evaluation term seed, an evaluation object seed and an evaluation relationship seed; the evaluation term seed, the evaluation object seed and the evaluation relationship seed can constitute opinion information (also referred to as evaluation phrase).
1) For the evaluation term seed, the information processing apparatus acquires independent evaluation terms in 186 fields (corresponding to different products) from a SentiWordNet as an evaluation term seed set OS.
2) For the evaluation object seed, the information processing apparatus uses an LRT index to determine the evaluation object seed.
By taking determination of an evaluation object seed in the mp3 field as an example, firstly, the information processing apparatus takes a noun or a noun phrase as an evaluation object, and uses a Tokenizer (such as Stanford Tokenizer) to word-segment the evaluation text, to obtain a noun set {Ti};
secondly, based on an initial evaluation object seed set {Ti} in the mp3 field (Ti corresponds to product attributes of mp3, for example, storage capacity, size, hardware configuration and the like), an LRT index between Ti and a noun set {Tj} extracted from the evaluation text in the mp3 field are determined;
next, a preset number of Tj with the highest LRT index are combined with an initial object seed set {Ti}, to serve as an evaluation object seed set TS; the LRT index reflects correlation between Tj and an initial evaluation object seed T, that is to say, the higher the correlation between Tjs is, the greater the probability that Tj represents product attributes in the mp3 field is, therefore, in the embodiment of the present invention, the initial evaluation object seed set {Ti} in the mp3 field is expanded according to the mp3 evaluation text, so as to determine corresponding evaluation objects according to different evaluation texts in actual applications, which overcomes the defect that an evaluation object distribution coefficient causes extracted opinion information to be one-sided; one example of the LRT index is as shown in Formula (1) below:
LRT=2 log L(p1,k1,n1)+log L(p2,k2,n2)−log L(p,k1,n1)−log {p,k2,n2} (1)
where k1=tf(Ti,Tj), k2=tf(Ti,
It should also be noted that, for the evaluation text, as evaluation objects may occur in a multiple-word-connection form, the information processing apparatus may segment a noun word group in the evaluation text into single nouns, it is necessary to first detect noun phrases in the evaluation text and combine the phrases into one term, during actual applications, the noun phrases can be determined based on a co-occurrence statistical manner, that is, multiple continuous nouns whose occurrence frequency exceeds a certain threshold are connected into a noun phrase t, and one example of the occurrence frequency is as shown in Formula (2) below:
where |t| denotes the number of terms included in t, tf(t) denotes the number of times t occurs in the evaluation text, L denotes all possible phrase sets including t, and n(L) indicates the number of the sets L.
3) For the evaluation relationship seed, as an evaluation relationship in the evaluation text can be represented with a syntactic dependency in a sentence of the evaluation text, the information processing apparatus can extract an evaluation relationship template from the evaluation text as an initial evaluation relationship seed set RS; description is given as follows.
Firstly, syntactic dependency analysis is performed on all sentences in the evaluation text, and then an evaluation relationship template is extracted from a syntactic dependency path through a template extraction technology (e.g., evaluation relationship graph walk algorithm
TC-TC template: the template corresponds to a situation where two evaluation objects juxtaposed are extracted, for example, in an example sentence “both color and style of the dress are pretty good”, color and style are two juxtaposed evaluation objects.
OC-TC template: the template corresponds to a situation where one evaluation term modifies one evaluation object, for example, in an example sentence “fabrics of the dress are great”, “fabrics” is an evaluation object, and “great” is an evaluation term.
OC-OC template: the template corresponds to a situation where two evaluation terms are juxtaposed.
In the process that the information processing apparatus extracts a template, the shortest path from a candidate evaluation term <OC> to a candidate evaluation object <TC> in the syntax tree is taken as an evaluation relationship template, referring to
During actual applications, the longer the template extracted by the information processing apparatus is, the lower the semantic accuracy expressed by the template is; therefore, the information processing apparatus can extract the template according to a template length threshold, for example, when the template length threshold is 4, the template extracted by the information processing apparatus includes 4 terms at most; the information processing apparatus can also sort the extracted templates according to occurrence frequency in the evaluation text, and takes a template whose occurrence frequency exceeds a preset threshold as an evaluation relationship template seed.
As the opinion information is in a phrase form, the opinion information is equivalent to an evaluation phrase; correspondingly, in the embodiment of the present invention, the information processing apparatus can use the following manner to indicate the obtained seed set: se={so,st,sr}, where so ∈ OS , st ∈ TS, and sr ∈ RS.
Step 2. Extract Candidate Opinion Information Based on an Evaluation Text
In the embodiment of the present invention, one opinion information is represented in the following manner, e={o,t,r}; where o is an evaluation term (words expressing user opinion polarity, which can be understood as polarity sentiment words), t is an evaluation object (generally functions or attributes of a product), and r (i.e., the evaluation term is used for modifying the evaluation object) indicates that the evaluation term o is used for modifying the evaluation object t; in one example of the opinion information, in “this mp3 has clear screen”, o={clear}, t={Screen}, and r indicates that clear is used for modifying screen; as the opinion information is in a phrase form, candidate opinion information is extracted from an evaluation text (also referred to as corpus), equivalent to extracting a candidate evaluation phrase in the evaluation text from the evaluation platform.
As a candidate evaluation phrase is often in a verb or adjective form and the candidate evaluation object is often in a noun form, the information processing apparatus described in the embodiment of the present invention extracts a noun from the evaluation text as a candidate evaluation object and extracts a verb or adjective as a candidate evaluation term, and a candidate evaluation object set C can be represented in the following manner: C={OC, TC}; where OC denotes a candidate evaluation term, and TC denotes a candidate evaluation object.
Correspondingly, a candidate evaluation phrase set can be represented in the following manner: ce={co,ct,cr}, where co ∈ OC, ct ∈ TC, and a candidate evaluation relationship between co and ct can be determined by the information processing apparatus based on a syntactic dependency path in the evaluation text, which has been described in detail in step 1 and is not repeated herein.
Step 3. Word Vector Learning
That is, the evaluation term seed, the evaluation object seed, the candidate evaluation object, and the candidate evaluation term determined in the above steps are mapped into word vectors (also referred to as word representation), a word vector is a mathematical object one-to-one corresponding to each word, the word vector can be represented in a vector form, each dimension of the word vector carries certain potential syntactic or semantic information of the word, and word vector learning means mapping a word to a high-dimensional space to obtain a corresponding word vector; the word vector learning in the step is aimed at: when two words are syntactically or semantically closer, a Euclidean distance between word vectors of the two words is smaller.
The information processing apparatus uses a real matrix LT to represent word vectors of |Vw| words, the number of dimensions of each word vector is n, and correspondingly, LT ∈ n×|V
where sθ(c)=the score of inputting c made by the DNN (c is a candidate evaluation term or candidate evaluation object); sθ(v)sθ(c)=the score of inputting a random word v made by the DNN, C={OC, TC}, θ is a parameter set of the DNN used for training word vectors, the value of {circumflex over (θ)} represents semantic or syntactic correlation between c and v, the less the value of {circumflex over (θ)} is, the greater the syntactic correlation between c and v is, therefore, when the minimum value of {circumflex over (θ)} is obtained by traversing c and v, c and v corresponding to the minimum value of {circumflex over (θ)} are mapped into vectors with the minimum Euclidean distance.
During implementation of the present disclosure, the inventor finds that, the DNN is a very effective tool for allowing the information processing apparatus to carry out word vector learning; moreover, during actual applications, it is difficult to obtain negative examples (which do not constitute evaluation terms, evaluation objects and evaluation relationships of opinion information in any field) in the evaluation text; therefore, the embodiment of the present invention uses a One-Class Classification technology, that is, only positive examples are used (corresponding to determining an evaluation object seed, an evaluation term seed and an evaluation relationship seed in step 1) to determine opinion information in the evaluation text; that is to say, the embodiment of the present invention fuses a DNN technology and the One-Class Classification technology into a One-Class Classification DNN (OCDNN) technology, the following describes that the information processing apparatus uses the OCDNN technology to perform processing of word vector learning, as shown in
Step 4. Obtain Vector Representation of an Evaluation Relationship
Similar to the processing in step 3, the step is aimed at mapping an evaluation relationship into a vector (including the evaluation relationship seed obtained in step 1 and the candidate evaluation relationship obtained in step 3), as shown in
One schematic diagram showing that an evaluation relationship is mapped into a vector according to a syntactic dependency path is as shown in
1) [OC] (corresponding to x1) and listen (corresponding to x2) are mapped into a vector y1
The dotted box in
y
1
=f(W(dep)[x1:x2]+b) (4)
where [x1;x2] denotes connection of vectors corresponding to OC (corresponding to x1) and “listen” (corresponding to x2), f( ) denotes a sigmoid function, W(xcomp) denotes a parameter matrix corresponding to syntactic dependency, i.e., an object complement (xcomp) relationship, between x1 and x2, and an initial value of W(xcomp) is as shown by Formula (5):
W
(dep)=1/2[I1;I2;Ib]+ε (5)
where I1 corresponds to the syntactic dependency (i.e., the xcomp between x1 and x2), I1 denotes a n-order matrix, I2 denotes a n-dimension space vector, and ε is generated from uniform distribution U[−0.001, 0.001].
2) y1 and “to” (corresponding to x3) are mapped into a vector y2
The number of nodes (i.e., computing units) of an input layer (corresponding to y1 and “to”) is equal to the number of nodes of an output layer (corresponding to y1), as each computing unit carries training of one dimension of the vector, it is equivalent to compressing syntactic or semantic features of y1 and “to” into the vector y2 , and y2 can be represented with Formula (6):
y
2
=f(W(prep)[y1:x3]+b) (6)
where [yi:x3] denotes connection of vectors corresponding to y1 and “to” (corresponding to x3), f( ) denotes a sigmoid function, W(prep) denotes a parameter matrix corresponding to syntactic dependency, i.e., a prep relationship, between y1 and x3 , and an initial value of W(prep) is as shown by Formula (7):
W
(prep)=1/2[I3;I4;Ib]+ε (7)
where I3 corresponds to the syntactic dependency (i.e., the xcomp between x1 and x2), I3 denotes a n-order matrix, I4 denotes a n-dimension space vector, and ε is generated from uniform distribution U[−0.001, 0.001].
3) y2 and [TC] (corresponding to x4) are mapped into a vector y3
The number of nodes (i.e., computing units) of an input layer (corresponding to Y2 and [TC]) is equal to the number of nodes of an output layer (corresponding to y4), as each computing unit carries training of one dimension of the vector, it is equivalent to compressing syntactic or semantic features of y2 and [TC] into the vector y3, and y3 can be represented with Formula (8):
y
3
=f(W(pobj)[y2;x2]+b) (8)
where [y2:x3] denotes connection of vectors corresponding to y2 and [TC] (corresponding to x4), f( ) denotes a sigmoid function, W(pobj) denotes a parameter matrix corresponding to syntactic dependency, i.e., a pobj relationship, between y1 and x3 , and an initial value of W(pobj) is as shown by Formula (9):
W
(pobj)=1/2[I5;I6;Ib]+ε (9)
where I5 corresponds to the syntactic dependency (i.e., the xcomp between y1 and x3), I6 denotes a n-order matrix, I4 denotes a n-dimension space vector, and ε is generated from uniform distribution U[−0.001, 0.001].
4) Train W(xcomp), W(prep) and W(pobj)
Steps 1) to 3) are repeated to adjust values of W(comp), W(prep) and W(pobj), to minimize a Euclidean distance between an input layer and an output layer of a recursive decoder corresponding to Formulas (10), (11) and (12);
E
rae1
=∥[x
1
;x
2
]−[x′
1
;x′
2]∥2 (10)
E
rae2
=∥[y
1
;x
3
]−[y′
1
;x′
3]∥2 (11)
E
rae3
=∥[y
2
;x
4
]−[y′
2
;x′
4]∥2 (12)
where Erae1 denotes a Euclidean distance between an input layer x1;x2 and a decoding (the decoding process is represented with dotted lines in
Step 4. Train the DNN, to extract first opinion information
1) Train the DNN
Vectors ce={co,ct,cr} corresponding to the evaluation term seed, the evaluation object seed and the evaluation relationship seed se={so,st,sr}are connected at an input layer of an upper neural network shown in
2) Extract First Opinion Information
Specifically, as shown in
The structure of the self-decoder shown in
The information processing apparatus can filter the vectors output by the output layer according to a decoding error value threshold θ, and output a candidate evaluation term, a candidate evaluation object and a candidate evaluation relationship corresponding to a vector in the output vectors whose decoding error value is less than θ as first opinion information.
During actual applications, the value of θ can be determined by introducing an evaluation object negative example, for example, words in common nouns, for example, “thing” and “one”, which are not evaluation objects, can be used as an evaluation object negative example GN, an evaluation object positive example VO is acquired from the SentiWordNet, and the value of θ is determined according to Formulas (13) and (14):
where PE denotes opinion information, the opinion information (including evaluation terms, evaluation objects and evaluation relationships) corresponds to a vector in the vectors output by the output layer whose decoding error value is less than θ, Er( ) is a decoding error value of the output layer, tf(t) is the number of times the evaluation object t occurs in PE, and tf+(t) is the number of times the evaluation object t is correctly identified as an evaluation object positive example; pp(t) is a ratio of the number of times the evaluation object t in PE is identified as an evaluation object positive example to the number of times the evaluation object occurs in the evaluation text, Eθ is positively correlated with θ, Eθ represents precision of extracting opinion information from the evaluation text by the information processing apparatus, the less Eθ is, the higher the precision of extracting opinion information is, but the number of the extracted opinion information is less, the greater Eθ is, the lower the precision of extracting opinion information is, and the number of the extracted opinion information is correspondingly more (i.e., the proportion of identifying evaluation object negative samples as evaluation object positive samples increases); therefore, the value of θ can be adjusted according to actual requirements, for example, in Scenario 1, when the requirement for the precision of opinion information output by the output layer is higher but no attention is paid to the number of the opinion information output, θ can be set as a higher value, for example, 0.1, and at this time, a vector, whose decoding error value is less than 0.1, in the vectors obtained through decoding of the output layer corresponds to the first opinion information; in Scenario 2, when the requirement for the precision of opinion information output by the output layer is lower than that in Scenario 1 and it is necessary to output more opinion information than Scenario 1, θ can be set as a value greater than that in Scenario 1, for example, 0.2, and at this time, a vector, whose decoding error value is less than 0.2, in the vectors obtained through decoding of the output layer corresponds to the first opinion information.
It can be seen that, as the output vectors of the output layer include an evaluation term, an evaluation object and an evaluation relationship at the same time, and the information processing apparatus filters the output vectors according to a decoding error value at the output layer of the upper DNN, equivalent to jointly verifying a candidate evaluation term, a candidate evaluation object and a candidate evaluation relationship, to obtain opinion information, which, compared with that only two of the evaluation term, the evaluation object and the evaluation relationship are verified in the related art, the precision of extracting opinion information is higher.
It should be noted that, in step 4, as the information processing apparatus uses the recursive self-decoder shown in
Step 5. Re-Train the DNN, to Extract Second Opinion Information
That is, a new evaluation object seed is acquired from the first opinion information to be merged into an evaluation object seed set TS, to use the TS as a new evaluation object seed to re-train the DNN, upon completion of the training, vectors corresponding to candidate evaluation terms, candidate evaluation objects and candidate evaluation relationships are connected into a vector vc=(vco,vct,vcr) at the input layer of the upper DNN shown in
The evaluation objects t in the opinion information output in step 5 are arranged in descending order according to Formula (15):
s(t)=pp(t)×log tf(t) (15)
where pp(t)=tf+(t)/tf(t) indicates the number of times t is identified as an evaluation object positive example, and tf(t) indicates the number of times t occurs in an evaluation text;
s(t) reflects the number of times t occurs in the evaluation text and the number of times t is identified as an evaluation object positive example, when the number of times t occurs in the evaluation text and the number of times t is identified as an evaluation object positive example are greater, the probability that t is an evaluation object positive example is greater, on this basis, M evaluation objects t with the greatest s(t) are taken as evaluation object seeds to be incorporated into the evaluation object seed set TS in step 1, and the expanded TS is used to re-train the upper DNN shown in
As the TS is expanded, during word vector learning, the defect of sparse distribution of evaluation objects in the TS can be overcome, so that the opinion information extracted in step 5 is more accurate.
In order to verify the influences of step 5 on the precision of extracting opinion information from the evaluation text, the inventor carries out the following experiment:
opinion information is extracted from evaluation texts in an MP3 field, a Hotel field, a Mattress field and a Phone field according to the method described in the embodiment of the present invention by using the DNN technology, each time the opinion information is extracted, M evaluation objects t with the greatest s(t) are added to the evaluation object seed set TS to re-train the upper DNN shown in
the experiment is carried out by using a DP method and LRTBOOT in the prior art, every extraction precision is as shown by the vertical coordinates in
In order to verify the beneficial effects brought about by the embodiment of the present invention, in the embodiment of the present invention, the method described in the embodiment of the present invention implemented with the DNN technology is compared with the AdjRule method, the DP method, the DP-HIT method and the LRTBOOT method, and the following experiment is carried out:
A precision rate (denoted by P), a recall rate (denoted by R) and an F value are used to assess results of extracting evaluation terms and evaluation objects from evaluation texts with different methods, which are defined as follows:
P=the number of identified positive example words/the number of all the identified words
R=the number of identified positive example words/the number of positive example words in the evaluation texts
F=2PR/(P+R)
As shown in Table 1, when the same test data is used, the proportion of extracting positive example words in different fields according to the technical solution in the embodiment of the present invention is superior to that according to the method in the related art,
Table 2 and Table 3 give the proportion of extracting opinion information (including evaluation terms, evaluation objects and evaluation relationships) according to the technical solution in the embodiment of the present invention, during actual applications, the precision of extracting opinion information from an evaluation text is more convincing than the precision of simply identifying positive example evaluation terms and positive example evaluation objects, and it can be seen from Table 2 and Table 3 that the P, R and F parameters achieved in the technical solution in the embodiment of the present invention is superior to the P, R and F parameters achieved in the related art; D1-D2 represent evaluation text test libraries in different fields.
A person of ordinary skill in the art may understand that all or some of the steps of the foregoing method embodiments may be implemented by a program instructing relevant hardware. The program may be stored in a computer readable storage medium, and during execution of the program, the execution includes the steps of the foregoing method embodiments; the storage medium includes: any medium that can store program codes, such as a mobile storage device, a random access memory (RAM), a read-only memory (ROM), a magnetic disk, or an optical disc.
When the integrated units of the present disclosure are implemented in a form of a software functional module and sold or used as an independent product, the integrated units may be stored in a computer-readable storage medium. Based on such an understanding, the technical solutions of the embodiments of the present invention essentially, or the part contributing to the related art may be embodied in the form of a software product. The computer software product is stored in a storage medium and includes several instructions for instructing a computer device (which may be a personal computer, a server, or a network device) to perform all or a part of the steps of the methods in the embodiments of the present invention. The foregoing storage medium includes: any medium that can store program codes, such as a mobile storage device, a RAM, a ROM, a magnetic disk, or an optical disc.
The above descriptions are merely specific implementations of the present disclosure, but the protection scope of the present disclosure is not limited thereto. Variations or replacements that can be easily thought of by any person skilled in the art within the technical scope disclosed in the present disclosure should be included in the protection scope of the present disclosure. Therefore, the protection scope of the present disclosure should be subject to the protection scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
201410271542.2 | Jun 2014 | CN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2015/081274 | 6/11/2015 | WO | 00 |