Utility Function ================ *Utility functions* are the components of :doc:`multi-attribute models ` that define the aggregation aspect of :doc:`option evaluation `. For each aggregate :doc:`attribute ` Y, whose descendants in the :doc:`tree of attributes ` are X\ :sub:`1`, X\ :sub:`2`,..., X\ :sub:`n`, the corresponding utility function f defines the mapping: f: X\ :sub:`1` × X\ :sub:`2` × ... × X\ :sub:`n` —> Y .. image:: images/FunctXnY.png :alt: Utility function Y=f(X1,X2,...Xn) In :doc:`DEXi `, a utility function maps all the *combinations* of the lower-level attribute values into the values of Y. The mapping is represented in a table, where each row gives the value of f for one combination of the lower-level attribute values. Rows are also called *decision rules*, because each row can be interpreted as an *if-then* rule of the form: **if** X\ :sub:`1` = value\ :sub:`1` **and** X\ :sub:`2` = value\ :sub:`2` **and** ... **and** X\ :sub:`n` = value\ :sub:`n` **then** Y = value (or value :doc:`interval `) In the context of representation, such rules are also called *elementary rules*. This name is used for contrast with :doc:`complex rules `. Example ------- See :doc:`utility functions ` as defined in the :doc:`Car Evaluation ` model. See also -------- Editing functions with :doc:`Function Editor ` and some recommendations on :doc:`function editing `. Representing utility functions with :doc:`complex rules ` and :doc:`weights `. Avoiding :doc:`combinatorial explosion ` and calculating utility function size. Calculating :doc:`utility function status ` measures. Saving functions on :doc:`files `. .. toctree:: :hidden: DEXiGlosIntervals DEXiGlosComplex DEXiGlosWei DEXiGlosExplos DEXiGlosNonEnt DEXiGlosFunctDef