Class Index | File Index

Classes


Class pv.Scale.quantile


Extends pv.Scale.
Represents a quantile scale; a function that maps from a value within a sortable domain to a quantized numeric range. Typically, the domain is a set of numbers, but any sortable value (such as strings) can be used as the domain of a quantile scale. The range defaults to [0,1], with 0 corresponding to the smallest value in the domain, 1 the largest, .5 the median, etc.

By default, the number of quantiles in the range corresponds to the number of values in the domain. The #quantiles method can be used to specify an explicit number of quantiles; for example, quantiles(4) produces a standard quartile scale. A quartile scale's range is a set of four discrete values, such as [0, 1/3, 2/3, 1]. Calling the #range method will scale these discrete values accordingly, similar to {@link pv.Scale.ordinal#splitFlush}.

For example, given the strings ["c", "a", "b"], a default quantile scale:

pv.Scale.quantile("c", "a", "b")
will return 0 for "a", .5 for "b", and 1 for "c".
Defined in: QuantileScale.js.

Class Summary
Constructor Attributes Constructor Name and Description
 
Constructs a default quantile scale.
Method Summary
Method Attributes Method Name and Description
 
by(f)
Returns a view of this scale by the specified accessor function f.
 
Sets or gets the input domain.
 
Sets or gets the quantile boundaries.
 
Sets or gets the output range.
Class Detail
pv.Scale.quantile()
Constructs a default quantile scale. The arguments to this constructor are optional, and equivalent to calling #domain. The default domain is the empty set, and the default range is [0,1].
Method Detail
{pv.Scale.quantile} by(f)
Returns a view of this scale by the specified accessor function f. Given a scale y, y.by(function(d) d.foo) is equivalent to function(d) y(d.foo).

This method is provided for convenience, such that scales can be succinctly defined inline. For example, given an array of data elements that have a score attribute with the domain [0, 1], the height property could be specified as:

.height(pv.Scale.linear().range(0, 480).by(function(d) d.score))
This is equivalent to:
.height(function(d) d.score * 480)
This method should be used judiciously; it is typically more clear to invoke the scale directly, passing in the value to be scaled.
Parameters:
{function} f
an accessor function.
Returns:
{pv.Scale.quantile} a view of this scale by the specified accessor function.

{pv.Scale.quantile} domain()
Sets or gets the input domain. This method can be invoked several ways:

1. domain(values...)

Specifying the domain as a series of values is the most explicit and recommended approach. However, if the domain values are derived from data, you may find the second method more appropriate.

2. domain(array, f)

Rather than enumerating the domain values as explicit arguments to this method, you can specify a single argument of an array. In addition, you can specify an optional accessor function to extract the domain values from the array.

3. domain()

Invoking the domain method with no arguments returns the current domain as an array.

Parameters:
{...} domain...
domain values.
Returns:
{pv.Scale.quantile} this, or the current domain.

quantiles(x)
Sets or gets the quantile boundaries. By default, each element in the domain is in its own quantile. If the argument to this method is a number, it specifies the number of equal-sized quantiles by which to divide the domain.

If no arguments are specified, this method returns the quantile boundaries; the first element is always the minimum value of the domain, and the last element is the maximum value of the domain. Thus, the length of the returned array is always one greater than the number of quantiles.

Parameters:
{number} x
the number of quantiles.

{pv.Scale.quantile} range()
Sets or gets the output range. This method can be invoked several ways:

1. range(min, ..., max)

The range may be specified as a series of numbers or colors. Most commonly, two numbers are specified: the minimum and maximum pixel values. For a color scale, values may be specified as pv.Colors or equivalent strings. For a diverging scale, or other subdivided non-uniform scales, multiple values can be specified. For example:

    .range("red", "white", "green")

Currently, only numbers and colors are supported as range values. The number of range values must exactly match the number of domain values, or the behavior of the scale is undefined.

2. range()

Invoking the range method with no arguments returns the current range as an array of numbers or colors.

Parameters:
{...} range...
range values.
Returns:
{pv.Scale.quantile} this, or the current range.

Documentation generated by JsDoc Toolkit 2.3.2 on Sun May 30 2010 18:10:25 GMT-0700 (PDT)