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">
4 <refentry id=
"smoothstep">
9 <holder>Khronos Group
</holder>
12 <refentrytitle>smoothstep
</refentrytitle>
13 <manvolnum>3G
</manvolnum>
16 <refname>smoothstep
</refname>
17 <refpurpose>perform Hermite interpolation between two values
</refpurpose>
19 <refsynopsisdiv><title>Declaration
</title>
22 <funcdef>genType
<function>smoothstep
</function></funcdef>
23 <paramdef>genType
<parameter>edge0
</parameter></paramdef>
24 <paramdef>genType
<parameter>edge1
</parameter></paramdef>
25 <paramdef>genType
<parameter>x
</parameter></paramdef>
30 <funcdef>genType
<function>smoothstep
</function></funcdef>
31 <paramdef>float
<parameter>edge0
</parameter></paramdef>
32 <paramdef>float
<parameter>edge1
</parameter></paramdef>
33 <paramdef>genType
<parameter>x
</parameter></paramdef>
38 <funcdef>genDType
<function>smoothstep
</function></funcdef>
39 <paramdef>genDType
<parameter>edge0
</parameter></paramdef>
40 <paramdef>genDType
<parameter>edge1
</parameter></paramdef>
41 <paramdef>genDType
<parameter>x
</parameter></paramdef>
46 <funcdef>genDType
<function>smoothstep
</function></funcdef>
47 <paramdef>double
<parameter>edge0
</parameter></paramdef>
48 <paramdef>double
<parameter>edge1
</parameter></paramdef>
49 <paramdef>genDType
<parameter>x
</parameter></paramdef>
53 <refsect1 id=
"parameters"><title>Parameters
</title>
56 <term><parameter>edge0
</parameter></term>
59 Specifies the value of the lower edge of the Hermite function.
64 <term><parameter>edge1
</parameter></term>
67 Specifies the value of the upper edge of the Hermite function.
72 <term><parameter>x
</parameter></term>
75 Specifies the source value for interpolation.
81 <refsect1 id=
"description"><title>Description
</title>
83 <function>smoothstep
</function> performs smooth Hermite interpolation between
0 and
84 1 when
<parameter>edge0
</parameter> < <parameter>x
</parameter> < <parameter>edge1
</parameter>.
85 This is useful in cases where a threshold function with a smooth transition is desired.
86 <function>smoothstep
</function> is equivalent to:
89 <programlisting><![CDATA[ genType t; /* Or genDType t; */
90 t = clamp((x - edge0) / (edge1 - edge0),
0.0,
1.0);
91 return t * t * (
3.0 -
2.0 * t);
95 Results are undefined if
<parameter>edge0
</parameter> ≥ <parameter>edge1
</parameter>.
98 <refsect1 id=
"versions"><title>Version Support
</title>
99 <informaltable frame=
"topbot">
104 <entry>smoothstep (genType)
</entry>#newin13#
107 <entry>smoothstep (genDType)
</entry>#newin40#
113 <refsect1 id=
"seealso"><title>See Also
</title>
115 <citerefentry><refentrytitle>mix
</refentrytitle></citerefentry>,
116 <citerefentry><refentrytitle>step
</refentrytitle></citerefentry>
119 <refsect1 id=
"Copyright"><title>Copyright
</title>
121 Copyright
<trademark class=
"copyright"></trademark> 2011 Khronos Group.
122 This material may be distributed subject to the terms and conditions set forth in
123 the Open Publication License, v
1.0,
8 June
1999.
124 <ulink url=
"http://opencontent.org/openpub/">http://opencontent.org/openpub/
</ulink>.