UpValues
✖
UpValues
Details and Options

- UpValues[f] also gives rules corresponding to g[…,f,…].
- When evaluating an expression, matching upvalues are applied before matching downvalues. »
- If a function has attribute HoldAllComplete, no upvalues are applied prior to entering the body of the function. »
- UpValues are typically defined using UpSet, UpSetDelayed, TagSet or TagSetDelayed.
- You can specify the upvalues for f by making an assignment of the form UpValues[f]=list.
- The list returned by UpValues has elements of the form HoldPattern[lhs]:>rhs.
Examples
open allclose allBasic Examples (1)Summary of the most common use cases
Define an upvalue for a symbol g using TagSetDelayed:

https://wolfram.com/xid/0binok32-g7dmym
Define an upvalue using UpSetDelayed:

https://wolfram.com/xid/0binok32-x05u6n
These are the upvalues associated with g:

https://wolfram.com/xid/0binok32-cfxz30

Scope (3)Survey of the scope of standard use cases
UpValues returns rules corresponding to upvalues defined for a symbol:

https://wolfram.com/xid/0binok32-ej5l4f

https://wolfram.com/xid/0binok32-hwcsbv


https://wolfram.com/xid/0binok32-vbp451
Obtain the upvalues of symbols whose names start with x:

https://wolfram.com/xid/0binok32-qemtic

UpValues can be used to set the values directly:

https://wolfram.com/xid/0binok32-fnyunm

https://wolfram.com/xid/0binok32-o1jvud


https://wolfram.com/xid/0binok32-fi993w

Applications (2)Sample problems that can be solved with this function
The resulting rules are in the order given:

https://wolfram.com/xid/0binok32-x0ymvo

https://wolfram.com/xid/0binok32-c7zzt7


https://wolfram.com/xid/0binok32-lcusj6


https://wolfram.com/xid/0binok32-mejklw


https://wolfram.com/xid/0binok32-d5hgcx

Copy a symbol's definitions to another symbol:

https://wolfram.com/xid/0binok32-vlfjkm

https://wolfram.com/xid/0binok32-3qya6g


https://wolfram.com/xid/0binok32-s3n84l


https://wolfram.com/xid/0binok32-61ai2p

Properties & Relations (7)Properties of the function, and connections to other functions
Values can be defined by immediate or delayed assignments:

https://wolfram.com/xid/0binok32-0u43ux

https://wolfram.com/xid/0binok32-4vbarr

HoldPattern is used to protect the rules from their own definitions:

https://wolfram.com/xid/0binok32-eeylic

https://wolfram.com/xid/0binok32-dt1z0i


https://wolfram.com/xid/0binok32-do5nb

UpValues["sym"] will issue a message if the specified symbol does not exist:

https://wolfram.com/xid/0binok32-g0zu8z


If the symbol exists but has no definitions, an empty list is returned:

https://wolfram.com/xid/0binok32-1bblgi

Definition and Information display upvalues but do not return them as values:

https://wolfram.com/xid/0binok32-bgcyj

https://wolfram.com/xid/0binok32-iprh14


https://wolfram.com/xid/0binok32-njo2fh

UpValues returns a value that can be used in a program:

https://wolfram.com/xid/0binok32-in70p

Evaluation of an expression involves applying matching upvalues:

https://wolfram.com/xid/0binok32-ilxq7d

https://wolfram.com/xid/0binok32-cn8i41

Matching upvalues are used before matching downvalues in evaluation:

https://wolfram.com/xid/0binok32-t5y2ul

https://wolfram.com/xid/0binok32-wda5v9

https://wolfram.com/xid/0binok32-r9h2a1

The upvalue for g is used prior to the downvalue for f:

https://wolfram.com/xid/0binok32-7lvacr

Compare with a manual application of the upvalue and downvalue:

https://wolfram.com/xid/0binok32-3xb42l


https://wolfram.com/xid/0binok32-t78qyf

Define an upvalue for g that applies for all heads:

https://wolfram.com/xid/0binok32-n1ygnt


https://wolfram.com/xid/0binok32-huf63q

Even if a function has attribute HoldAll, the upvalue will be applied during evaluation:

https://wolfram.com/xid/0binok32-8ht5xk

If a function has attribute HoldAllComplete, the upvalue will not be applied:

https://wolfram.com/xid/0binok32-jbf42v

Wolfram Research (1991), UpValues, Wolfram Language function, https://reference.wolfram.com/language/ref/UpValues.html (updated 1996).
Text
Wolfram Research (1991), UpValues, Wolfram Language function, https://reference.wolfram.com/language/ref/UpValues.html (updated 1996).
Wolfram Research (1991), UpValues, Wolfram Language function, https://reference.wolfram.com/language/ref/UpValues.html (updated 1996).
CMS
Wolfram Language. 1991. "UpValues." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 1996. https://reference.wolfram.com/language/ref/UpValues.html.
Wolfram Language. 1991. "UpValues." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 1996. https://reference.wolfram.com/language/ref/UpValues.html.
APA
Wolfram Language. (1991). UpValues. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/UpValues.html
Wolfram Language. (1991). UpValues. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/UpValues.html
BibTeX
@misc{reference.wolfram_2025_upvalues, author="Wolfram Research", title="{UpValues}", year="1996", howpublished="\url{https://reference.wolfram.com/language/ref/UpValues.html}", note=[Accessed: 04-April-2025
]}
BibLaTeX
@online{reference.wolfram_2025_upvalues, organization={Wolfram Research}, title={UpValues}, year={1996}, url={https://reference.wolfram.com/language/ref/UpValues.html}, note=[Accessed: 04-April-2025
]}