Configuration
- class compas.robots.Configuration(joint_values=None, joint_types=None, joint_names=None)[source]
Bases:
compas.data.data.Data
Represents the configuration of a robot based on the state of its joints. If the names of joints are also provided, the configuration behaves as a dictionary of joint name-value pairs.
This concept is also refered to as “Joint State”.
- Parameters
- Attributes
joint_values (
list
offloat
) – Joint values expressed in radians or meters, depending on the respective type.joint_types (
list
ofcompas.robots.Joint.SUPPORTED_TYPES
) – Joint types, e.g. a list ofcompas.robots.Joint.REVOLUTE
for revolute joints.data (
dict
) – The data representing the configuration.prismatic_values (
list
offloat
) – Prismatic joint values in meters.revolute_values (
list
offloat
) – Revolute joint values in radians.
Examples
>>> config = Configuration.from_revolute_values([math.pi/2, 0., 0.]) >>> config.joint_values [1.5707963267948966, 0.0, 0.0]
>>> config = Configuration.from_prismatic_and_revolute_values([8.312], [math.pi/2, 0., 0., 0., 2*math.pi, 0.8]) >>> str(config) 'Configuration((8.312, 1.571, 0.000, 0.000, 0.000, 6.283, 0.800), (2, 0, 0, 0, 0, 0, 0))'
>>> from compas.robots import Joint >>> config = Configuration([math.pi/2, 3., 0.1], [Joint.REVOLUTE, Joint.PRISMATIC, Joint.PLANAR]) >>> str(config) 'Configuration((1.571, 3.000, 0.100), (0, 2, 5))'
Methods
Raises an error if there is not a joint name for every value.
close_to
(other[, tol])Returns
True
if the other Configuration's joint_values are within a certain range.copy
([cls])Make an independent copy of the data object.
from_data
(data)Construct an object of this type from the provided data.
from_json
(filepath)Construct an object from serialized data contained in a JSON file.
from_jsonstring
(string)Construct an object from serialized data contained in a JSON string.
from_prismatic_and_revolute_values
(...[, ...])Construct a configuration from prismatic and revolute joint values.
from_revolute_values
(values[, joint_names])Construct a configuration from revolute joint values in radians.
get
(key[, default])items
()iter_differences
(other)Generator over the differences to another Configuration's joint_values.
keys
()max_difference
(other)Returns the maximum difference to another Configuration's joint values.
merge
(other)Merge the configuration with another configuration in place along joint names.
merged
(other)Get a new
Configuration
with this configuration merged with another configuration.scale
(scale_factor)Scales the joint positions of the current configuration.
scaled
(scale_factor)Return a scaled copy of this configuration.
to_data
()Convert an object to its native data representation.
to_json
(filepath[, pretty])Serialize the data representation of an object to a JSON file.
to_jsonstring
([pretty])Serialize the data representation of an object to a JSON string.
Validate the object's data against its data schema (self.DATASCHEMA).
Validate the object's data against its json schema (self.JSONSCHEMA).
values
()