1 <?xml version=
"1.0" encoding=
"UTF-8"?>
2 <!DOCTYPE book PUBLIC
"-//OASIS//DTD DocBook MathML Module V1.1b1//EN"
3 "http://www.oasis-open.org/docbook/xml/mathml/1.1CR1/dbmathml.dtd">
9 <holder>Khronos Group
</holder>
12 <refentrytitle>mix
</refentrytitle>
13 <manvolnum>3G
</manvolnum>
16 <refname>mix
</refname>
17 <refpurpose>linearly interpolate between two values
</refpurpose>
19 <refsynopsisdiv><title>Declaration
</title>
22 <funcdef>genType
<function>mix
</function></funcdef>
23 <paramdef>genType
<parameter>x
</parameter></paramdef>
24 <paramdef>genType
<parameter>y
</parameter></paramdef>
25 <paramdef>genType
<parameter>a
</parameter></paramdef>
30 <funcdef>genType
<function>mix
</function></funcdef>
31 <paramdef>genType
<parameter>x
</parameter></paramdef>
32 <paramdef>genType
<parameter>y
</parameter></paramdef>
33 <paramdef>float
<parameter>a
</parameter></paramdef>
38 <funcdef>genDType
<function>mix
</function></funcdef>
39 <paramdef>genDType
<parameter>x
</parameter></paramdef>
40 <paramdef>genDType
<parameter>y
</parameter></paramdef>
41 <paramdef>genDType
<parameter>a
</parameter></paramdef>
46 <funcdef>genDType
<function>mix
</function></funcdef>
47 <paramdef>genDType
<parameter>x
</parameter></paramdef>
48 <paramdef>genDType
<parameter>y
</parameter></paramdef>
49 <paramdef>double
<parameter>a
</parameter></paramdef>
54 <funcdef>genType
<function>mix
</function></funcdef>
55 <paramdef>genType
<parameter>x
</parameter></paramdef>
56 <paramdef>genType
<parameter>y
</parameter></paramdef>
57 <paramdef>genBType
<parameter>a
</parameter></paramdef>
62 <funcdef>genDType
<function>mix
</function></funcdef>
63 <paramdef>genDType
<parameter>x
</parameter></paramdef>
64 <paramdef>genDType
<parameter>y
</parameter></paramdef>
65 <paramdef>genBType
<parameter>a
</parameter></paramdef>
69 <refsect1 id=
"parameters"><title>Parameters
</title>
72 <term><parameter>x
</parameter></term>
75 Specify the start of the range in which to interpolate.
80 <term><parameter>y
</parameter></term>
83 Specify the end of the range in which to interpolate.
88 <term><parameter>a
</parameter></term>
91 Specify the value to use to interpolate between
<parameter>x
</parameter> and
<parameter>y
</parameter>.
97 <refsect1 id=
"description"><title>Description
</title>
99 <function>mix
</function> performs a linear interpolation between
<parameter>x
</parameter>
100 and
<parameter>y
</parameter> using
<parameter>a
</parameter> to weight between them. The return value
101 is computed as follows:
105 <mml:mo lspace='
2px' rspace='
2px'
>⋅</mml:mo>
106 <mml:mo stretchy='false'
>(
</mml:mo>
108 <mml:mo>−</mml:mo>
110 <mml:mo stretchy='false'
>)
</mml:mo>
113 <mml:mo lspace='
2px' rspace='
2px'
>⋅</mml:mo>
119 For the variants of
<function>mix
</function> where
<parameter>a
</parameter> is
<constant>genBType
</constant>,
120 elements for which
<parameter>a
</parameter>[
<emphasis>i
</emphasis>] is
<constant>false
</constant>, the result for that
121 element is taken from
<parameter>x
</parameter>, and where
<parameter>a
</parameter>[
<emphasis>i
</emphasis>] is
122 <constant>true
</constant>, it will be taken from
<parameter>y
</parameter>.
125 <refsect1 id=
"versions"><title>Version Support
</title>
126 <informaltable frame=
"topbot">
131 <entry>mix (genType)
</entry>#newin11#
134 <entry>mix (genDType)
</entry>#newin40#
140 <refsect1 id=
"seealso"><title>See Also
</title>
142 <citerefentry><refentrytitle>min
</refentrytitle></citerefentry>,
143 <citerefentry><refentrytitle>max
</refentrytitle></citerefentry>
146 <refsect1 id=
"Copyright"><title>Copyright
</title>
148 Copyright
<trademark class=
"copyright"></trademark> 2011 Khronos Group.
149 This material may be distributed subject to the terms and conditions set forth in
150 the Open Publication License, v
1.0,
8 June
1999.
151 <ulink url=
"http://opencontent.org/openpub/">http://opencontent.org/openpub/
</ulink>.