Any relational language or funCTIonal language. These kinds of programming language describe relationships between variables in terms of funCTIons or {inference rules}, and the language executor ({interpreter} or compiler) applies some fixed algorithm to these relations to produce a result. Declarative languages contrast with imperative languages which specify explicit manipulation of the computer' s internal state or procedural languages which specify an explicit sequence of steps to follow. The most common examples of declarative languages are {logic programming} languages such as {Prolog} and {funCTIonal languages} like {Haskell}. See also produCTIon system. (2004-05-17)