Preference learning

From HandWiki

Preference learning is a subfield in machine learning, which is a classification method based on observed preference information.[1] In the view of supervised learning, preference learning trains on a set of items which have preferences toward labels or other items and predicts the preferences for all items. While the concept of preference learning has been emerged for some time in many fields such as economics,[2] it's a relatively new topic in Artificial Intelligence research. Several workshops have been discussing preference learning and related topics in the past decade.[3]

Tasks

The main task in preference learning concerns problems in "learning to rank". According to different types of preference information observed, the tasks are categorized as three main problems in the book Preference Learning:[4]

Label ranking

In label ranking, the model has an instance space [math]\displaystyle{ X=\{x_i\}\,\! }[/math] and a finite set of labels [math]\displaystyle{ Y=\{y_i|i=1,2,\cdots,k\}\,\! }[/math]. The preference information is given in the form [math]\displaystyle{ y_i \succ_{x} y_j\,\! }[/math] indicating instance [math]\displaystyle{ x\,\! }[/math] shows preference in [math]\displaystyle{ y_i\,\! }[/math] rather than [math]\displaystyle{ y_j\,\! }[/math]. A set of preference information is used as training data in the model. The task of this model is to find a preference ranking among the labels for any instance.

It was observed some conventional classification problems can be generalized in the framework of label ranking problem:[5] if a training instance [math]\displaystyle{ x\,\! }[/math] is labeled as class [math]\displaystyle{ y_i\,\! }[/math], it implies that [math]\displaystyle{ \forall j \neq i, y_i \succ_{x} y_j\,\! }[/math]. In the multi-label case, [math]\displaystyle{ x\,\! }[/math] is associated with a set of labels [math]\displaystyle{ L \subseteq Y\,\! }[/math] and thus the model can extract a set of preference information [math]\displaystyle{ \{y_i \succ_{x} y_j | y_i \in L, y_j \in Y\backslash L\}\,\! }[/math]. Training a preference model on this preference information and the classification result of an instance is just the corresponding top ranking label.

Instance ranking

Instance ranking also has the instance space [math]\displaystyle{ X\,\! }[/math] and label set [math]\displaystyle{ Y\,\! }[/math]. In this task, labels are defined to have a fixed order [math]\displaystyle{ y_1 \succ y_2 \succ \cdots \succ y_k\,\! }[/math] and each instance [math]\displaystyle{ x_l\,\! }[/math] is associated with a label [math]\displaystyle{ y_l\,\! }[/math]. Giving a set of instances as training data, the goal of this task is to find the ranking order for a new set of instances.

Object ranking

Object ranking is similar to instance ranking except that no labels are associated with instances. Given a set of pairwise preference information in the form [math]\displaystyle{ x_i \succ x_j\,\! }[/math] and the model should find out a ranking order among instances.

Techniques

There are two practical representations of the preference information [math]\displaystyle{ A \succ B\,\! }[/math]. One is assigning [math]\displaystyle{ A\,\! }[/math] and [math]\displaystyle{ B\,\! }[/math] with two real numbers [math]\displaystyle{ a\,\! }[/math] and [math]\displaystyle{ b\,\! }[/math] respectively such that [math]\displaystyle{ a \gt b\,\! }[/math]. Another one is assigning a binary value [math]\displaystyle{ V(A,B) \in \{0,1\}\,\! }[/math] for all pairs [math]\displaystyle{ (A,B)\,\! }[/math] denoting whether [math]\displaystyle{ A \succ B\,\! }[/math] or [math]\displaystyle{ B \succ A\,\! }[/math]. Corresponding to these two different representations, there are two different techniques applied to the learning process.

Utility function

If we can find a mapping from data to real numbers, ranking the data can be solved by ranking the real numbers. This mapping is called utility function. For label ranking the mapping is a function [math]\displaystyle{ f: X \times Y \rightarrow \mathbb{R}\,\! }[/math] such that [math]\displaystyle{ y_i \succ_x y_j \Rightarrow f(x,y_i) \gt f(x,y_j)\,\! }[/math]. For instance ranking and object ranking, the mapping is a function [math]\displaystyle{ f: X \rightarrow \mathbb{R}\,\! }[/math].

Finding the utility function is a regression learning problem which is well developed in machine learning.

Preference relations

The binary representation of preference information is called preference relation. For each pair of alternatives (instances or labels), a binary predicate can be learned by conventional supervising learning approach. Fürnkranz and Hüllermeier proposed this approach in label ranking problem.[6] For object ranking, there is an early approach by Cohen et al.[7]

Using preference relations to predict the ranking will not be so intuitive. Since preference relation is not transitive, it implies that the solution of ranking satisfying those relations would sometimes be unreachable, or there could be more than one solution. A more common approach is to find a ranking solution which is maximally consistent with the preference relations. This approach is a natural extension of pairwise classification.[6]

Uses

Preference learning can be used in ranking search results according to feedback of user preference. Given a query and a set of documents, a learning model is used to find the ranking of documents corresponding to the relevance with this query. More discussions on research in this field can be found in Tie-Yan Liu's survey paper.[8]

Another application of preference learning is recommender systems.[9] Online store may analyze customer's purchase record to learn a preference model and then recommend similar products to customers. Internet content providers can make use of user's ratings to provide more user preferred contents.

See also

References

  1. Mohri, Mehryar; Rostamizadeh, Afshin; Talwalkar, Ameet (2012). Foundations of Machine Learning. USA, Massachusetts: MIT Press. ISBN 9780262018258. 
  2. Shogren, Jason F.; List, John A.; Hayes, Dermot J. (2000). "Preference Learning in Consecutive Experimental Auctions". American Journal of Agricultural Economics 82 (4): 1016–1021. doi:10.1111/0002-9092.00099. http://econpapers.repec.org/article/oupajagec/v_3a82_3ay_3a2000_3ai_3a4_3ap_3a1016-1021.htm. 
  3. "Preference learning workshops". http://www.preference-learning.org/#Workshops. 
  4. Fürnkranz, Johannes; Hüllermeier, Eyke (2011). "Preference Learning: An Introduction". Preference Learning. Springer-Verlag New York, Inc.. pp. 3–8. ISBN 978-3-642-14124-9. https://books.google.com/books?id=nc3XcH9XSgYC&pg=PA4. 
  5. "Constraint classification for multiclass classification and ranking". In Proceedings of the 16th Annual Conference on Neural Information Processing Systems, NIPS-02: 785–792. 2003. 
  6. 6.0 6.1 Fürnkranz, Johannes; Hüllermeier, Eyke (2003). "Pairwise Preference Learning and Ranking". Proceedings of the 14th European Conference on Machine Learning: 145–156. 
  7. Cohen, William W.; Schapire, Robert E.; Singer, Yoram (1998). "Learning to order things". In Proceedings of the 1997 Conference on Advances in Neural Information Processing Systems: 451–457. http://dl.acm.org/citation.cfm?id=302528.302736. 
  8. Liu, Tie-Yan (2009). "Learning to Rank for Information Retrieval". Foundations and Trends in Information Retrieval 3 (3): 225–331. doi:10.1561/1500000016. http://dl.acm.org/citation.cfm?id=1618303.1618304. 
  9. Gemmis, Marco De; Iaquinta, Leo; Lops, Pasquale; Musto, Cataldo; Narducci, Fedelucio; Semeraro, Giovanni (2009). "Preference Learning in Recommender Systems". Preference Learning 41: 387–407. doi:10.1007/978-3-642-14125-6_18. ISBN 978-3-642-14124-9. http://www.ecmlpkdd2009.net/wp-content/uploads/2008/09/preference-learning.pdf#page=45. 

External links