bokeh.models.transforms¶
Represent transformations of data to happen on the client (browser) side.
-
class
CustomJSTransform(**kwargs)[source]¶ Bases:
bokeh.models.transforms.TransformApply a custom defined transform to data.
-
args¶ property type:
Dict(String,Instance(Model) )A mapping of names to Bokeh plot objects. These objects are made available to the callback code snippet as the values of named parameters to the callback.
-
func¶ property type:
StringA snippet of JavaScript code to transform a single value. The variable
xwill contain the untransformed value and can be expected to be present in the function namespace at render time. The snippet will be into the body of a function and therefore requires a return statement.Example:
func = ''' return Math.floor(x) + 0.5 '''
-
v_func¶ property type:
StringA snippet of JavaScript code to transform an array of values. The variable
xswill contain the untransformed array and can be expected to be present in the function namespace at render time. The snippet will be into the body of a function and therefore requires a return statement.Example:
v_func = ''' new_xs = new Array(xs.length) for(i = 0; i < xs.length; i++) { new_xs[i] = xs[i] + 0.5 } return new_xs '''
Warning
The vectorized function,
v_func, must return an array of the same length as the inputxsarray.
-
classmethod
from_coffeescript(func, v_func, args={})[source]¶ Create a CustomJSTransform instance from a pair of CoffeeScript snippets. The function bodies are translated to JavaScript functions using node and therefore require return statements.
The
funcsnippet namespace will contain the variablex(the untransformed value) at render time. Thev_funcsnippet namespace will contain the variablexs(the untransformed vector) at render time.Example:
func = "return Math.cos(x)" v_func = "return [Math.cos(x) for x in xs]" transform = CustomJSTransform.from_coffeescript(func, v_func)
Parameters: Returns: CustomJSTransform
-
classmethod
from_py_func(func, v_func)[source]¶ Create a CustomJSTransform instance from a pair of Python functions. The function is translated to JavaScript using PyScript.
The python functions must have no positional arguments. It’s possible to pass Bokeh models (e.g. a ColumnDataSource) as keyword arguments to the functions.
The
funcfunction namespace will contain the variablex(the untransformed value) at render time. Thev_funcfunction namespace will contain the variablexs(the untransformed vector) at render time.Warning
The vectorized function,
v_func, must return an array of the same length as the inputxsarray.Example:
def transform(): from flexx.pyscript.stubs import Math return Math.cos(x) def v_transform(): from flexx.pyscript.stubs import Math return [Math.cos(x) for x in xs] customjs_transform = CustomJSTransform.from_py_func(transform, v_transform)
Parameters: Returns: CustomJSTransform
-
-
class
Dodge(**kwargs)[source]¶ Bases:
bokeh.models.transforms.TransformApply either fixed dodge amount to data.
-
class
Interpolator(**kwargs)[source]¶ Bases:
bokeh.models.transforms.TransformBase class for interpolator transforms.
Interpolators return the value of a function which has been evaluated between specified (x, y) pairs of data. As an example, if two control point pairs were provided to the interpolator, a linear interpolaction at a specific value of ‘x’ would result in the value of ‘y’ which existed on the line conneting the two control points.
The control point pairs for the interpolators can be specified through either
- A literal sequence of values:
- or a pair of columns defined in a ColumnDataSource object:
This is the base class and is not intended to end use. Please see the documentation for the final derived classes (Jitter, LineraInterpolator, StepInterpolator) for mor information on their specific methods of interpolation.
Note
This is an abstract base class used to help organize the hierarchy of Bokeh model types. It is not useful to instantiate on its own.
-
clip¶ property type:
BoolDetermine if the interpolation should clip the result to include only values inside its predefined range. If this is set to False, it will return the most value of the closest point.
-
data¶ property type:
Instance(ColumnarDataSource)Data which defines the source for the named columns if a string is passed to either the
xoryparameters.
-
class
Jitter(**kwargs)[source]¶ Bases:
bokeh.models.transforms.TransformApply either a uniform or normally sampled random jitter to data.
-
distribution¶ property type:
Enum(JitterRandomDistribution)The random distribution upon which to pull the random scatter
-
-
class
LinearInterpolator(**kwargs)[source]¶ Bases:
bokeh.models.transforms.InterpolatorCompute a linear interpolation between the control points provided through the
x,y, anddataparameters.
-
class
StepInterpolator(**kwargs)[source]¶ Bases:
bokeh.models.transforms.InterpolatorCompute a step-wise interpolation between the points provided through the
x,y, anddataparameters.-
mode¶ property type:
Enum(StepMode)Adjust the behavior of the returned value in relation to the control points. The parameter can assume one of three values:
after(default): Assume the y-value associated with the nearest x-value which is less than or equal to the point to transform.before: Assume the y-value associated with the nearest x-value which is greater than the point to transform.center: Assume the y-value associated with the nearest x-value to the point to transform.
-
-
class
Transform(**kwargs)[source]¶ Bases:
bokeh.model.ModelBase class for
Transformmodels that represent a computation to be carried out on the client-side.JavaScript implementations should implement the following methods:
Note
This is an abstract base class used to help organize the hierarchy of Bokeh model types. It is not useful to instantiate on its own.