NAME

clamp - returns smallest integer not less than a scalar or each vector component.

SYNOPSIS

  float  clamp(float x, float a, float b);
  float1 clamp(float1 x, float1 a, float1 b);
  float2 clamp(float2 x, float2 a, float2 b);
  float3 clamp(float3 x, float3 a, float3 b);
  float4 clamp(float4 x, float4 a, float4 b);
 
  half   clamp(half x, half a, half b);
  half1  clamp(half1 x, half1 a, half1 b);
  half2  clamp(half2 x, half2 a, half2 b);
  half3  clamp(half3 x, half3 a, half3 b);
  half4  clamp(half4 x, half4 a, half4 b);
 
  fixed  clamp(fixed x, fixed a, fixed b);
  fixed1 clamp(fixed1 x, fixed1 a, fixed1 b);
  fixed2 clamp(fixed2 x, fixed2 a, fixed2 b);
  fixed3 clamp(fixed3 x, fixed3 a, fixed3 b);
  fixed4 clamp(fixed4 x, fixed4 a, fixed4 b);

PARAMETERS

x

Vector or scalar to clamp.

a

Vector or scalar for bottom of clamp range.

b

Vector or scalar for top of clamp range.

DESCRIPTION

Returns x clamped to the range [a,b] as follows:

1) Returns a if x is less than a; else

2) Returns b if x is greater than b; else

3) Returns x otherwise.

For vectors, the returned vector contains the clamped result of each element of the vector x clamped using the respective element of vectors a and b.

REFERENCE IMPLEMENTATION

clamp for float scalars could be implemented like this.

  float clamp(float x, float a, float b)
  {
    return max(a, min(b, x));
  }

PROFILE SUPPORT

clamp is supported in all profiles except fp20.

SEE ALSO

max, min, saturate